From mboxrd@z Thu Jan 1 00:00:00 1970 Received: from mailman by lists.gnu.org with tmda-scanned (Exim 4.43) id 1MvW26-00060M-VY for qemu-devel@nongnu.org; Wed, 07 Oct 2009 08:54:19 -0400 Received: from exim by lists.gnu.org with spam-scanned (Exim 4.43) id 1MvW22-0005yf-3u for qemu-devel@nongnu.org; Wed, 07 Oct 2009 08:54:18 -0400 Received: from [199.232.76.173] (port=42985 helo=monty-python.gnu.org) by lists.gnu.org with esmtp (Exim 4.43) id 1MvW21-0005yJ-O6 for qemu-devel@nongnu.org; Wed, 07 Oct 2009 08:54:13 -0400 Received: from mx1.redhat.com ([209.132.183.28]:9846) by monty-python.gnu.org with esmtp (Exim 4.60) (envelope-from ) id 1MvW21-0007AA-88 for qemu-devel@nongnu.org; Wed, 07 Oct 2009 08:54:13 -0400 Date: Wed, 7 Oct 2009 09:54:05 -0300 From: Luiz Capitulino Message-ID: <20091007095405.7ba40dc6@doriath> In-Reply-To: <4ACBF217.60300@us.ibm.com> References: <1254875232-25012-1-git-send-email-lcapitulino@redhat.com> <1254875232-25012-6-git-send-email-lcapitulino@redhat.com> <4ACBF217.60300@us.ibm.com> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Subject: [Qemu-devel] Re: [PATCH 05/15] monitor: Handle new and old style handlers List-Id: qemu-devel.nongnu.org List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , To: Anthony Liguori Cc: qemu-devel@nongnu.org, avi@redhat.com On Tue, 06 Oct 2009 20:42:47 -0500 Anthony Liguori wrote: > Luiz Capitulino wrote: > > This commit changes monitor_handle_command() to support old style > > _and_ new style handlers. > > > > New style handlers are protocol independent, they return their > > data to the Monitor, which in turn decides how to print them > > (ie. user protocol vs. machine protocol). > > > > Converted handlers will use the 'user_print' member of 'mon_cmd_t' > > to define its user protocol function, which will be called to print > > data in the user protocol format. > > > > Handlers which don't have 'user_print' defined are not converted > > and are handled as usual. > > > > Signed-off-by: Luiz Capitulino > > --- > > monitor.c | 32 ++++++++++++++++++++++++++------ > > 1 files changed, 26 insertions(+), 6 deletions(-) > > > > diff --git a/monitor.c b/monitor.c > > index 9d4c168..c0ba5ee 100644 > > --- a/monitor.c > > +++ b/monitor.c > > @@ -211,6 +211,11 @@ static int monitor_fprintf(FILE *stream, const char *fmt, ...) > > return 0; > > } > > > > +static inline int monitor_handler_ported(const mon_cmd_t *cmd) > > +{ > > + return cmd->user_print != NULL; > > +} > > + > > static int compare_cmd(const char *name, const char *list) > > { > > const char *p, *pstart; > > @@ -3053,17 +3058,32 @@ static void monitor_handle_command(Monitor *mon, const char *cmdline) > > qdict = qdict_new(); > > > > cmd = monitor_parse_command(mon, cmdline, qdict); > > - if (cmd) { > > - void (*handler)(Monitor *mon, const QDict *qdict); > > + if (!cmd) > > + goto out; > > + > > + qemu_errors_to_mon(mon); > > > > - qemu_errors_to_mon(mon); > > + if (monitor_handler_ported(cmd)) { > > + QObject *data = NULL; > > + void (*handler_new)(Monitor *mon, const QDict *params, > > + QObject **ret_data); > > > > Screams to be a typedef. > > > - handler = cmd->handler; > > - handler(mon, qdict); > > + handler_new = cmd->handler; > > + handler_new(mon, qdict, &data); > > > > At this point, couldn't cmd->handler be a union so we had a bit more > type safety? Yes, will do.