[libvirt] [PATCH 6/8] qemu: qapi: Add support for command features
Daniel P. Berrangé
berrange at redhat.com
Thu Nov 21 18:27:50 UTC 2019
On Mon, Nov 18, 2019 at 06:02:06PM +0100, Peter Krempa wrote:
> The top level commands now can have 'feature' flags for fixes so add
> support for querying those as well.
>
> Signed-off-by: Peter Krempa <pkrempa at redhat.com>
> ---
> src/qemu/qemu_qapi.c | 15 +++++++++++++++
> 1 file changed, 15 insertions(+)
>
> diff --git a/src/qemu/qemu_qapi.c b/src/qemu/qemu_qapi.c
> index 484f274c63..8e66f9f180 100644
> --- a/src/qemu/qemu_qapi.c
> +++ b/src/qemu/qemu_qapi.c
> @@ -216,6 +216,21 @@ virQEMUQAPISchemaTraverseCommand(virJSONValuePtr cur,
> {
> const char *query = virQEMUQAPISchemaTraverseContextNextQuery(ctxt);
> const char *querytype;
> + char modifier = *query;
> +
> + if (!c_isalpha(modifier))
> + query++;
> +
> + /* exit on modifers for other types */
> + if (modifier == '^' || modifier == '!' || modifier == '+' || modifier == '*')
> + return 0;
> +
> + if (modifier == '$') {
> + if (virQEMUQAPISchemaTraverseContextHasNextQuery(ctxt))
> + return -3;
> +
> + return virQEMUQAPISchemaTraverseHasObjectFeature(query, cur);
> + }
We're silently ignoring any unknown modifier, ok since this is trusted
data and no caller is wrong. For sanity I might still report an error
if there's one we don't expect though.
Reviewed-by: Daniel P. Berrangé <berrange at redhat.com>
Regards,
Daniel
--
|: https://berrange.com -o- https://www.flickr.com/photos/dberrange :|
|: https://libvirt.org -o- https://fstop138.berrange.com :|
|: https://entangle-photo.org -o- https://www.instagram.com/dberrange :|
More information about the libvir-list
mailing list