Message ID | 20170911110623.24981-2-marcandre.lureau@redhat.com |
---|---|
State | New |
Headers | show |
Series | Hi, | expand |
On 09/11/2017 06:05 AM, Marc-André Lureau wrote: > Instanciate a QObject* form a literal QLitObject. s/Instanciate/Instantiate/ s/form/from/ > > Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com> > --- > include/qapi/qmp/qlit.h | 2 ++ > qobject/qlit.c | 36 ++++++++++++++++++++++++++++++++++++ > tests/check-qlit.c | 26 ++++++++++++++++++++++++++ > 3 files changed, 64 insertions(+) > +QObject *qobject_from_qlit(const QLitObject *qlit) > +{ > + switch (qlit->type) { > + case QTYPE_QNULL: > + return QOBJECT(qnull()); > + case QTYPE_QNUM: > + return QOBJECT(qnum_from_int(qlit->value.qnum)); Is this going to work for all QNum values? > +++ b/tests/check-qlit.c > @@ -64,11 +64,37 @@ static void qlit_equal_qobject_test(void) > qobject_decref(qobj); > } > > +static void qobject_from_qlit_test(void) > +{ > + QObject *obj, *qobj = qobject_from_qlit(&qlit); > + QDict *qdict; > + QList *bee; > + > + qdict = qobject_to_qdict(qobj); > + g_assert_cmpint(qdict_get_int(qdict, "foo"), ==, 42); > + g_assert_cmpstr(qdict_get_str(qdict, "bar"), ==, "hello world"); > + g_assert(qobject_type(qdict_get(qdict, "baz")) == QTYPE_QNULL); Related to my question above - you pass because there are no floating point values in qlit. Is that something we want supported?
----- Original Message ----- > On 09/11/2017 06:05 AM, Marc-André Lureau wrote: > > Instanciate a QObject* form a literal QLitObject. > > s/Instanciate/Instantiate/ > s/form/from/ thanks > > > > > Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com> > > --- > > include/qapi/qmp/qlit.h | 2 ++ > > qobject/qlit.c | 36 ++++++++++++++++++++++++++++++++++++ > > tests/check-qlit.c | 26 ++++++++++++++++++++++++++ > > 3 files changed, 64 insertions(+) > > > +QObject *qobject_from_qlit(const QLitObject *qlit) > > +{ > > + switch (qlit->type) { > > + case QTYPE_QNULL: > > + return QOBJECT(qnull()); > > + case QTYPE_QNUM: > > + return QOBJECT(qnum_from_int(qlit->value.qnum)); > > Is this going to work for all QNum values? > > > +++ b/tests/check-qlit.c > > @@ -64,11 +64,37 @@ static void qlit_equal_qobject_test(void) > > qobject_decref(qobj); > > } > > > > +static void qobject_from_qlit_test(void) > > +{ > > + QObject *obj, *qobj = qobject_from_qlit(&qlit); > > + QDict *qdict; > > + QList *bee; > > + > > + qdict = qobject_to_qdict(qobj); > > + g_assert_cmpint(qdict_get_int(qdict, "foo"), ==, 42); > > + g_assert_cmpstr(qdict_get_str(qdict, "bar"), ==, "hello world"); > > + g_assert(qobject_type(qdict_get(qdict, "baz")) == QTYPE_QNULL); > > Related to my question above - you pass because there are no floating > point values in qlit. Is that something we want supported? Markus had some remarks about it when reviewing #define QLIT_QNUM. Only i64 are supported at this point, so it's left for whoever requires it in the future. > > -- > Eric Blake, Principal Software Engineer > Red Hat, Inc. +1-919-301-3266 > Virtualization: qemu.org | libvirt.org > >
Marc-André Lureau <marcandre.lureau@redhat.com> writes: > ----- Original Message ----- >> On 09/11/2017 06:05 AM, Marc-André Lureau wrote: >> > Instanciate a QObject* form a literal QLitObject. >> >> s/Instanciate/Instantiate/ >> s/form/from/ > > thanks > >> >> > >> > Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com> >> > --- >> > include/qapi/qmp/qlit.h | 2 ++ >> > qobject/qlit.c | 36 ++++++++++++++++++++++++++++++++++++ >> > tests/check-qlit.c | 26 ++++++++++++++++++++++++++ >> > 3 files changed, 64 insertions(+) >> >> > +QObject *qobject_from_qlit(const QLitObject *qlit) >> > +{ >> > + switch (qlit->type) { >> > + case QTYPE_QNULL: >> > + return QOBJECT(qnull()); >> > + case QTYPE_QNUM: >> > + return QOBJECT(qnum_from_int(qlit->value.qnum)); >> >> Is this going to work for all QNum values? >> >> > +++ b/tests/check-qlit.c >> > @@ -64,11 +64,37 @@ static void qlit_equal_qobject_test(void) >> > qobject_decref(qobj); >> > } >> > >> > +static void qobject_from_qlit_test(void) >> > +{ >> > + QObject *obj, *qobj = qobject_from_qlit(&qlit); >> > + QDict *qdict; >> > + QList *bee; >> > + >> > + qdict = qobject_to_qdict(qobj); >> > + g_assert_cmpint(qdict_get_int(qdict, "foo"), ==, 42); >> > + g_assert_cmpstr(qdict_get_str(qdict, "bar"), ==, "hello world"); >> > + g_assert(qobject_type(qdict_get(qdict, "baz")) == QTYPE_QNULL); >> >> Related to my question above - you pass because there are no floating >> point values in qlit. Is that something we want supported? > > Markus had some remarks about it when reviewing #define QLIT_QNUM. Only i64 are supported at this point, so it's left for whoever requires it in the future. Yes, QLitObject only supports int64_t for now. uint64_t and double aren't implemented. By the way, shouldn't QLitObject member type be QType instead of int?
Marc-André Lureau <marcandre.lureau@redhat.com> writes: > Instanciate a QObject* form a literal QLitObject. > > Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com> > --- > include/qapi/qmp/qlit.h | 2 ++ > qobject/qlit.c | 36 ++++++++++++++++++++++++++++++++++++ > tests/check-qlit.c | 26 ++++++++++++++++++++++++++ > 3 files changed, 64 insertions(+) > > diff --git a/include/qapi/qmp/qlit.h b/include/qapi/qmp/qlit.h > index b18406bce9..56feb25e04 100644 > --- a/include/qapi/qmp/qlit.h > +++ b/include/qapi/qmp/qlit.h > @@ -51,4 +51,6 @@ struct QLitDictEntry { > > bool qlit_equal_qobject(const QLitObject *lhs, const QObject *rhs); > > +QObject *qobject_from_qlit(const QLitObject *qlit); > + > #endif /* QLIT_H */ > diff --git a/qobject/qlit.c b/qobject/qlit.c > index 3c4882c784..df2ad97d33 100644 > --- a/qobject/qlit.c > +++ b/qobject/qlit.c > @@ -82,3 +82,39 @@ bool qlit_equal_qobject(const QLitObject *lhs, const QObject *rhs) > > return false; > } > + > +QObject *qobject_from_qlit(const QLitObject *qlit) > +{ > + switch (qlit->type) { > + case QTYPE_QNULL: > + return QOBJECT(qnull()); > + case QTYPE_QNUM: > + return QOBJECT(qnum_from_int(qlit->value.qnum)); > + case QTYPE_QSTRING: > + return QOBJECT(qstring_from_str(qlit->value.qstr)); > + case QTYPE_QDICT: { > + QDict *qdict = qdict_new(); > + QLitDictEntry *e; > + > + for (e = qlit->value.qdict; e->key; e++) { > + qdict_put_obj(qdict, e->key, qobject_from_qlit(&e->value)); > + } > + return QOBJECT(qdict); > + } > + case QTYPE_QLIST: { > + QList *qlist = qlist_new(); > + QLitObject *e; > + > + for (e = qlit->value.qlist; e->type != QTYPE_NONE; e++) { > + qlist_append_obj(qlist, qobject_from_qlit(e)); > + } > + return QOBJECT(qlist); > + } > + case QTYPE_QBOOL: > + return QOBJECT(qbool_from_bool(qlit->value.qbool)); > + case QTYPE_NONE: Please make that default: to remove the compiler's license to have the function return null on corrupted qlit->type. If compilers gripe unless you keep case QTYPE_NONE in place, keep it. > + assert(0); > + } > + > + return NULL; > +} > diff --git a/tests/check-qlit.c b/tests/check-qlit.c > index c59ec1ab88..acd6e02e96 100644 > --- a/tests/check-qlit.c > +++ b/tests/check-qlit.c > @@ -64,11 +64,37 @@ static void qlit_equal_qobject_test(void) > qobject_decref(qobj); > } > > +static void qobject_from_qlit_test(void) > +{ > + QObject *obj, *qobj = qobject_from_qlit(&qlit); > + QDict *qdict; > + QList *bee; > + > + qdict = qobject_to_qdict(qobj); > + g_assert_cmpint(qdict_get_int(qdict, "foo"), ==, 42); > + g_assert_cmpstr(qdict_get_str(qdict, "bar"), ==, "hello world"); > + g_assert(qobject_type(qdict_get(qdict, "baz")) == QTYPE_QNULL); > + > + bee = qdict_get_qlist(qdict, "bee"); > + obj = qlist_pop(bee); > + g_assert_cmpint(qnum_get_int(qobject_to_qnum(obj)), ==, 43); > + qobject_decref(obj); > + obj = qlist_pop(bee); > + g_assert_cmpint(qnum_get_int(qobject_to_qnum(obj)), ==, 44); > + qobject_decref(obj); > + obj = qlist_pop(bee); > + g_assert(qbool_get_bool(qobject_to_qbool(obj))); > + qobject_decref(obj); > + > + qobject_decref(qobj); > +} > + > int main(int argc, char **argv) > { > g_test_init(&argc, &argv, NULL); > > g_test_add_func("/qlit/equal_qobject", qlit_equal_qobject_test); > + g_test_add_func("/qlit/qobject_from_qlit", qobject_from_qlit_test); > > return g_test_run(); > } With the assertion tightened and the typos pointed out by Eric fixed: Reviewed-by: Markus Armbruster <armbru@redhat.com>
diff --git a/include/qapi/qmp/qlit.h b/include/qapi/qmp/qlit.h index b18406bce9..56feb25e04 100644 --- a/include/qapi/qmp/qlit.h +++ b/include/qapi/qmp/qlit.h @@ -51,4 +51,6 @@ struct QLitDictEntry { bool qlit_equal_qobject(const QLitObject *lhs, const QObject *rhs); +QObject *qobject_from_qlit(const QLitObject *qlit); + #endif /* QLIT_H */ diff --git a/qobject/qlit.c b/qobject/qlit.c index 3c4882c784..df2ad97d33 100644 --- a/qobject/qlit.c +++ b/qobject/qlit.c @@ -82,3 +82,39 @@ bool qlit_equal_qobject(const QLitObject *lhs, const QObject *rhs) return false; } + +QObject *qobject_from_qlit(const QLitObject *qlit) +{ + switch (qlit->type) { + case QTYPE_QNULL: + return QOBJECT(qnull()); + case QTYPE_QNUM: + return QOBJECT(qnum_from_int(qlit->value.qnum)); + case QTYPE_QSTRING: + return QOBJECT(qstring_from_str(qlit->value.qstr)); + case QTYPE_QDICT: { + QDict *qdict = qdict_new(); + QLitDictEntry *e; + + for (e = qlit->value.qdict; e->key; e++) { + qdict_put_obj(qdict, e->key, qobject_from_qlit(&e->value)); + } + return QOBJECT(qdict); + } + case QTYPE_QLIST: { + QList *qlist = qlist_new(); + QLitObject *e; + + for (e = qlit->value.qlist; e->type != QTYPE_NONE; e++) { + qlist_append_obj(qlist, qobject_from_qlit(e)); + } + return QOBJECT(qlist); + } + case QTYPE_QBOOL: + return QOBJECT(qbool_from_bool(qlit->value.qbool)); + case QTYPE_NONE: + assert(0); + } + + return NULL; +} diff --git a/tests/check-qlit.c b/tests/check-qlit.c index c59ec1ab88..acd6e02e96 100644 --- a/tests/check-qlit.c +++ b/tests/check-qlit.c @@ -64,11 +64,37 @@ static void qlit_equal_qobject_test(void) qobject_decref(qobj); } +static void qobject_from_qlit_test(void) +{ + QObject *obj, *qobj = qobject_from_qlit(&qlit); + QDict *qdict; + QList *bee; + + qdict = qobject_to_qdict(qobj); + g_assert_cmpint(qdict_get_int(qdict, "foo"), ==, 42); + g_assert_cmpstr(qdict_get_str(qdict, "bar"), ==, "hello world"); + g_assert(qobject_type(qdict_get(qdict, "baz")) == QTYPE_QNULL); + + bee = qdict_get_qlist(qdict, "bee"); + obj = qlist_pop(bee); + g_assert_cmpint(qnum_get_int(qobject_to_qnum(obj)), ==, 43); + qobject_decref(obj); + obj = qlist_pop(bee); + g_assert_cmpint(qnum_get_int(qobject_to_qnum(obj)), ==, 44); + qobject_decref(obj); + obj = qlist_pop(bee); + g_assert(qbool_get_bool(qobject_to_qbool(obj))); + qobject_decref(obj); + + qobject_decref(qobj); +} + int main(int argc, char **argv) { g_test_init(&argc, &argv, NULL); g_test_add_func("/qlit/equal_qobject", qlit_equal_qobject_test); + g_test_add_func("/qlit/qobject_from_qlit", qobject_from_qlit_test); return g_test_run(); }
Instanciate a QObject* form a literal QLitObject. Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com> --- include/qapi/qmp/qlit.h | 2 ++ qobject/qlit.c | 36 ++++++++++++++++++++++++++++++++++++ tests/check-qlit.c | 26 ++++++++++++++++++++++++++ 3 files changed, 64 insertions(+)