9af2398977
In my "build everything" tree, a change to the types in qapi-schema.json triggers a recompile of about 4800 out of 5100 objects. The previous commit split up qmp-commands.h, qmp-event.h, qmp-visit.h, qapi-types.h. Each of these headers still includes all its shards. Reduce compile time by including just the shards we actually need. To illustrate the benefits: adding a type to qapi/migration.json now recompiles some 2300 instead of 4800 objects. The next commit will improve it further. Signed-off-by: Markus Armbruster <armbru@redhat.com> Message-Id: <20180211093607.27351-24-armbru@redhat.com> Reviewed-by: Eric Blake <eblake@redhat.com> Reviewed-by: Marc-André Lureau <marcandre.lureau@redhat.com> [eblake: rebase to master] Signed-off-by: Eric Blake <eblake@redhat.com>
52 lines
1.8 KiB
C
52 lines
1.8 KiB
C
/*
|
|
* Clone Visitor
|
|
*
|
|
* Copyright (C) 2016 Red Hat, Inc.
|
|
*
|
|
* This work is licensed under the terms of the GNU GPL, version 2 or later.
|
|
* See the COPYING file in the top-level directory.
|
|
*
|
|
*/
|
|
|
|
#ifndef QAPI_CLONE_VISITOR_H
|
|
#define QAPI_CLONE_VISITOR_H
|
|
|
|
#include "qapi/visitor.h"
|
|
|
|
/*
|
|
* The clone visitor is for direct use only by the QAPI_CLONE() macro;
|
|
* it requires that the root visit occur on an object, list, or
|
|
* alternate, and is not usable directly on built-in QAPI types.
|
|
*/
|
|
typedef struct QapiCloneVisitor QapiCloneVisitor;
|
|
|
|
void *qapi_clone(const void *src, void (*visit_type)(Visitor *, const char *,
|
|
void **, Error **));
|
|
void qapi_clone_members(void *dst, const void *src, size_t sz,
|
|
void (*visit_type_members)(Visitor *, void *,
|
|
Error **));
|
|
|
|
/*
|
|
* Deep-clone QAPI object @src of the given @type, and return the result.
|
|
*
|
|
* Not usable on QAPI scalars (integers, strings, enums), nor on a
|
|
* QAPI object that references the 'any' type. Safe when @src is NULL.
|
|
*/
|
|
#define QAPI_CLONE(type, src) \
|
|
((type *)qapi_clone(src, \
|
|
(void (*)(Visitor *, const char *, void**, \
|
|
Error **))visit_type_ ## type))
|
|
|
|
/*
|
|
* Copy deep clones of @type members from @src to @dst.
|
|
*
|
|
* Not usable on QAPI scalars (integers, strings, enums), nor on a
|
|
* QAPI object that references the 'any' type.
|
|
*/
|
|
#define QAPI_CLONE_MEMBERS(type, dst, src) \
|
|
qapi_clone_members(dst, src, sizeof(type), \
|
|
(void (*)(Visitor *, void *, \
|
|
Error **))visit_type_ ## type ## _members)
|
|
|
|
#endif
|