diff options
author | Kevin Wolf <kwolf@redhat.com> | 2015-01-19 21:22:45 +0100 |
---|---|---|
committer | Kevin Wolf <kwolf@redhat.com> | 2015-06-12 16:58:06 +0200 |
commit | 7990d2c99c974ae8e3c3f719d8321ddc6eac93bc (patch) | |
tree | 2554b4c9eabe054aabefcc9448c8a0503f22a29d /qobject | |
parent | bd50530a9f40f6560a03caeaaddd451e2ce90ed8 (diff) | |
download | hqemu-7990d2c99c974ae8e3c3f719d8321ddc6eac93bc.zip hqemu-7990d2c99c974ae8e3c3f719d8321ddc6eac93bc.tar.gz |
qdict: Add qdict_{set,copy}_default()
In the block layer functions that determine options for a child block
device, it's a common pattern to either copy options from the parent's
options or to set a default string if the option isn't explicitly set
yet for the child. Provide convenience functions so that it becomes a
one-liner for each option.
Signed-off-by: Kevin Wolf <kwolf@redhat.com>
Reviewed-by: Max Reitz <mreitz@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Diffstat (limited to 'qobject')
-rw-r--r-- | qobject/qdict.c | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/qobject/qdict.c b/qobject/qdict.c index 50c0ab3..190791b 100644 --- a/qobject/qdict.c +++ b/qobject/qdict.c @@ -477,6 +477,39 @@ static void qdict_destroy_obj(QObject *obj) g_free(qdict); } +/** + * qdict_copy_default(): If no entry mapped by 'key' exists in 'dst' yet, the + * value of 'key' in 'src' is copied there (and the refcount increased + * accordingly). + */ +void qdict_copy_default(QDict *dst, QDict *src, const char *key) +{ + QObject *val; + + if (qdict_haskey(dst, key)) { + return; + } + + val = qdict_get(src, key); + if (val) { + qobject_incref(val); + qdict_put_obj(dst, key, val); + } +} + +/** + * qdict_set_default_str(): If no entry mapped by 'key' exists in 'dst' yet, a + * new QString initialised by 'val' is put there. + */ +void qdict_set_default_str(QDict *dst, const char *key, const char *val) +{ + if (qdict_haskey(dst, key)) { + return; + } + + qdict_put(dst, key, qstring_from_str(val)); +} + static void qdict_flatten_qdict(QDict *qdict, QDict *target, const char *prefix); |