]> git.proxmox.com Git - mirror_qemu.git/blame - include/qapi/opts-visitor.h
qapi: Document visitor interfaces, add assertions
[mirror_qemu.git] / include / qapi / opts-visitor.h
CommitLineData
eb7ee2cb
LE
1/*
2 * Options Visitor
3 *
4 * Copyright Red Hat, Inc. 2012
5 *
6 * Author: Laszlo Ersek <lersek@redhat.com>
7 *
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.
10 *
11 */
12
13#ifndef OPTS_VISITOR_H
14#define OPTS_VISITOR_H
15
7b1b5d19 16#include "qapi/visitor.h"
1de7afc9 17#include "qemu/option.h"
eb7ee2cb 18
15a849be
LE
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.
22 */
23#define OPTS_VISITOR_RANGE_MAX 65536
24
eb7ee2cb
LE
25typedef struct OptsVisitor OptsVisitor;
26
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.
adfb264c
EB
32 *
33 * The Opts input visitor does not implement support for visiting QAPI
34 * alternates, numbers (other than integers), or arbitrary QTypes.
eb7ee2cb
LE
35 */
36OptsVisitor *opts_visitor_new(const QemuOpts *opts);
37void opts_visitor_cleanup(OptsVisitor *nv);
38Visitor *opts_get_visitor(OptsVisitor *nv);
39
40#endif