From: Luiz Capitulino <lcapitulino@redhat.com>
To: Avi Kivity <avi@redhat.com>
Cc: aliguori@us.ibm.com, qemu-devel@nongnu.org
Subject: [Qemu-devel] Re: [PATCH 04/29] Introduce QDict
Date: Thu, 20 Aug 2009 12:08:28 -0300 [thread overview]
Message-ID: <20090820120828.5c5c66e5@doriath> (raw)
In-Reply-To: <4A8D589D.2060208@redhat.com>
On Thu, 20 Aug 2009 17:07:25 +0300
Avi Kivity <avi@redhat.com> wrote:
> On 08/20/2009 04:57 PM, Luiz Capitulino wrote:
> > On Thu, 20 Aug 2009 10:57:54 +0300
> > Avi Kivity<avi@redhat.com> wrote:
> >
> >
> >> On 08/20/2009 02:07 AM, Luiz Capitulino wrote:
> >>
> >>> QDict is a high-level dictionary data type that can be used to store a
> >>> collection of QObjects. A unique key is associated with only one
> >>> QObject.
> >>>
> >>> The following functions are available:
> >>>
> >>> - qdict_new() Create a new dictionary
> >>> - qdict_add() Add a new 'key:object' pair
> >>>
> >>>
> >> qdict_put() is both symmetrical with qdict_get(), and also conveys the
> >> fact that you can replace an existing key/value.
> >>
> > Would it be useful in the current Monitor code? If so, how?
> >
>
> The current code, no, but once we read qdicts from the monitor, you need
> to be able to handle { a: 1, a: 2 }.
qdict_add() will refuse to add an existing key, but I can change
it to replace instead.
Would this be enough?
> >>> + */
> >>> +int qdict_get_int(const QDict *qdict, const char *key)
> >>> +{
> >>> + QObject *obj = qdict_get_obj(qdict, key, QTYPE_QINT);
> >>> + return qint_to_int(qobject_to_qint(obj));
> >>> +}
> >>>
> >>>
> >> This assumption does not hold if the dict came from a user.
> >>
> > Then the user has to know what he or she is doing. :)
> >
>
> They don't, as a rule.
That's why there's an assert() there. :)
> > The problem with high-level functions that receive a QObject
> > but return a plain int is: what do you return if QObject is
> > not an QInt?
> >
>
> Pass a default value to return.
Looks a good solution, although I think both cases are useful.
For most handlers, for example, the monitor code _must_ push
the key specified in qemu-monitor.hx into the dictionary. Not
doing this is a bug.
But we also support optional keys, which may or may not be
pushed into the dictionary.
We need two functions then and this also applies to QString.
next prev parent reply other threads:[~2009-08-20 15:08 UTC|newest]
Thread overview: 64+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-08-19 23:07 [Qemu-devel] [PATCH v1 00/29] QMonitor Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 01/29] Introduce QObject Luiz Capitulino
2009-08-20 8:34 ` [Qemu-devel] " Paolo Bonzini
2009-08-20 14:17 ` Luiz Capitulino
2009-08-20 14:21 ` Paolo Bonzini
2009-08-20 15:12 ` Luiz Capitulino
2009-08-20 15:15 ` Paolo Bonzini
2009-08-20 8:51 ` Paolo Bonzini
2009-08-19 23:07 ` [Qemu-devel] [PATCH 02/29] Introduce QInt Luiz Capitulino
2009-08-20 7:51 ` [Qemu-devel] " Avi Kivity
2009-08-20 9:22 ` Paolo Bonzini
2009-08-20 13:24 ` Luiz Capitulino
2009-08-20 13:26 ` Avi Kivity
2009-08-20 14:51 ` Luiz Capitulino
2009-08-20 14:55 ` Avi Kivity
2009-08-20 15:14 ` Luiz Capitulino
2009-08-20 8:37 ` Paolo Bonzini
2009-08-20 13:44 ` Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 03/29] Introduce QString Luiz Capitulino
2009-08-20 8:41 ` [Qemu-devel] " Paolo Bonzini
2009-08-20 14:19 ` Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 04/29] Introduce QDict Luiz Capitulino
2009-08-20 7:57 ` [Qemu-devel] " Avi Kivity
2009-08-20 13:57 ` Luiz Capitulino
2009-08-20 14:07 ` Avi Kivity
2009-08-20 15:08 ` Luiz Capitulino [this message]
2009-08-20 15:26 ` Avi Kivity
2009-08-20 9:00 ` Paolo Bonzini
2009-08-20 14:14 ` Luiz Capitulino
2009-08-24 15:40 ` [Qemu-devel] " Markus Armbruster
2009-08-24 16:11 ` Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 05/29] Add wrappers to functions used by the Monitor Luiz Capitulino
2009-08-24 16:47 ` Markus Armbruster
2009-08-19 23:07 ` [Qemu-devel] [PATCH 06/29] monitor: New format for handlers argument types Luiz Capitulino
2009-08-24 16:21 ` Markus Armbruster
2009-08-24 17:00 ` Luiz Capitulino
2009-09-04 14:06 ` Anthony Liguori
2009-09-04 14:48 ` Luiz Capitulino
2009-09-04 15:18 ` Markus Armbruster
2009-08-19 23:07 ` [Qemu-devel] [PATCH 07/29] monitor: Setup a QDict with arguments to handlers Luiz Capitulino
2009-08-24 16:25 ` Markus Armbruster
2009-08-24 17:07 ` Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 08/29] monitor: Export QDict header Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 09/29] monitor: Port handler_0 to use QDict Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 10/29] monitor: Port handler_1 " Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 11/29] monitor: Port handler_2 " Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 12/29] monitor: Port handler_3 " Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 13/29] monitor: Port handler_4 " Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 14/29] monitor: Port handler_5 " Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 15/29] monitor: Port handler_6 " Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 16/29] monitor: Port handler_7 " Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 17/29] monitor: Drop handler_8 and handler_9 Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 18/29] monitor: Port handler_10 to use QDict Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 19/29] monitor: Split monitor_handle_command() Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 20/29] monitor: Drop unused macros Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 21/29] monitor: Drop str_allocated[] Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 22/29] monitor: Drop args[] handling code Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 23/29] monitor: fail when 'i' type is greater than 32-bit Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 24/29] monitor: Update supported types documentation Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 25/29] Add check support Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 26/29] Introduce QInt unit-tests Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 27/29] Introduce QString unit-tests Luiz Capitulino
2009-08-19 23:07 ` [Qemu-devel] [PATCH 28/29] Introduce QDict test data file Luiz Capitulino
2009-08-19 23:08 ` [Qemu-devel] [PATCH 29/29] Introduce QDict unit-tests Luiz Capitulino
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20090820120828.5c5c66e5@doriath \
--to=lcapitulino@redhat.com \
--cc=aliguori@us.ibm.com \
--cc=avi@redhat.com \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).