qapi: Fix to reject empty union base gracefully
[qemu/ar7.git] / include / qapi / opts-visitor.h
blob6462c96c29ac7945be21e2618a0299b9e2534f7d
1 /*
2 * Options Visitor
4 * Copyright Red Hat, Inc. 2012
6 * Author: Laszlo Ersek <lersek@redhat.com>
8 * This work is licensed under the terms of the GNU LGPL, version 2.1 or later.
9 * See the COPYING.LIB file in the top-level directory.
13 #ifndef OPTS_VISITOR_H
14 #define OPTS_VISITOR_H
16 #include "qapi/visitor.h"
17 #include "qemu/option.h"
19 /* Inclusive upper bound on the size of any flattened range. This is a safety
20 * (= anti-annoyance) measure; wrong ranges should not cause long startup
21 * delays nor exhaust virtual memory.
23 #define OPTS_VISITOR_RANGE_MAX 65536
25 typedef struct OptsVisitor OptsVisitor;
27 /* Contrarily to qemu-option.c::parse_option_number(), OptsVisitor's "int"
28 * parser relies on strtoll() instead of strtoull(). Consequences:
29 * - string representations of negative numbers yield negative values,
30 * - values below INT64_MIN or LLONG_MIN are rejected,
31 * - values above INT64_MAX or LLONG_MAX are rejected.
33 * The Opts input visitor does not implement support for visiting QAPI
34 * alternates, numbers (other than integers), null, or arbitrary
35 * QTypes. It also requires a non-null list argument to
36 * visit_start_list().
38 Visitor *opts_visitor_new(const QemuOpts *opts);
40 #endif