From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from eggs.gnu.org ([208.118.235.92]:41132) by lists.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1TF3u6-00014V-GW for qemu-devel@nongnu.org; Fri, 21 Sep 2012 10:08:30 -0400 Received: from Debian-exim by eggs.gnu.org with spam-scanned (Exim 4.71) (envelope-from ) id 1TF3u4-0007G1-V9 for qemu-devel@nongnu.org; Fri, 21 Sep 2012 10:08:26 -0400 Received: from mail-ie0-f173.google.com ([209.85.223.173]:34534) by eggs.gnu.org with esmtp (Exim 4.71) (envelope-from ) id 1TF3u4-0007Cw-QF for qemu-devel@nongnu.org; Fri, 21 Sep 2012 10:08:24 -0400 Received: by mail-ie0-f173.google.com with SMTP id 17so990551iea.4 for ; Fri, 21 Sep 2012 07:08:24 -0700 (PDT) Sender: fluxion From: Michael Roth Date: Fri, 21 Sep 2012 09:07:32 -0500 Message-Id: <1348236465-23124-10-git-send-email-mdroth@linux.vnet.ibm.com> In-Reply-To: <1348236465-23124-1-git-send-email-mdroth@linux.vnet.ibm.com> References: <1348236465-23124-1-git-send-email-mdroth@linux.vnet.ibm.com> Subject: [Qemu-devel] [PATCH 09/22] qapi: QmpOutputVisitor, implement array handling List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: qemu-devel@nongnu.org Cc: blauwirbel@gmail.com, peter.maydell@linaro.org, aliguori@us.ibm.com, eblake@redhat.com Signed-off-by: Michael Roth --- qapi/qmp-output-visitor.c | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/qapi/qmp-output-visitor.c b/qapi/qmp-output-visitor.c index 2bce9d5..ea08795 100644 --- a/qapi/qmp-output-visitor.c +++ b/qapi/qmp-output-visitor.c @@ -181,6 +181,23 @@ static void qmp_output_type_number(Visitor *v, double *obj, const char *name, qmp_output_add(qov, name, qfloat_from_double(*obj)); } +static void qmp_output_start_carray(Visitor *v, void **obj, const char *name, + size_t elem_count, size_t elem_size, + Error **errp) +{ + qmp_output_start_list(v, name, errp); +} + +static void qmp_output_next_carray(Visitor *v, Error **errp) +{ +} + +static void qmp_output_end_carray(Visitor *v, Error **errp) +{ + QmpOutputVisitor *qov = to_qov(v); + qmp_output_pop(qov); +} + QObject *qmp_output_get_qobject(QmpOutputVisitor *qov) { QObject *obj = qmp_output_first(qov); @@ -228,6 +245,9 @@ QmpOutputVisitor *qmp_output_visitor_new(void) v->visitor.type_bool = qmp_output_type_bool; v->visitor.type_str = qmp_output_type_str; v->visitor.type_number = qmp_output_type_number; + v->visitor.start_carray = qmp_output_start_carray; + v->visitor.next_carray = qmp_output_next_carray; + v->visitor.end_carray = qmp_output_end_carray; QTAILQ_INIT(&v->stack); -- 1.7.9.5