diff options
| author | Markus Armbruster | 2019-03-01 16:40:51 +0100 |
|---|---|---|
| committer | Markus Armbruster | 2019-03-05 14:43:11 +0100 |
| commit | 56a4689582433125d7042ba506a081e08dc264d4 (patch) | |
| tree | 014c10ef50a1c9ac64768c1091b443d8fdd7ba5d /tests/qapi-schema/include | |
| parent | tests/qapi-schema: Cover forward reference to sub-module (diff) | |
| download | qemu-56a4689582433125d7042ba506a081e08dc264d4.tar.gz qemu-56a4689582433125d7042ba506a081e08dc264d4.tar.xz qemu-56a4689582433125d7042ba506a081e08dc264d4.zip | |
qapi: Fix array first used in a different module
We generally put implicitly defined types in whatever module triggered
their definition. This is wrong for array types, as the included test
case demonstrates. Let's have a closer look at it.
Type 'Status' is defined sub-sub-module.json. Array type ['Status']
occurs in main module qapi-schema-test.json and in
include/sub-module.json. The main module's use is first, so the array
type gets put into the main module.
The generated C headers define StatusList in qapi-types.h. But
include/qapi-types-sub-module.h uses it without including
qapi-types.h. Oops.
To fix that, put the array type into its element type's module.
Now StatusList gets generated into qapi-types-sub-module.h, which all
its users include.
Signed-off-by: Markus Armbruster <armbru@redhat.com>
Message-Id: <20190301154051.23317-8-armbru@redhat.com>
Reviewed-by: Eric Blake <eblake@redhat.com>
Diffstat (limited to 'tests/qapi-schema/include')
| -rw-r--r-- | tests/qapi-schema/include/sub-module.json | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/tests/qapi-schema/include/sub-module.json b/tests/qapi-schema/include/sub-module.json index f2bdbd3990..afdb267228 100644 --- a/tests/qapi-schema/include/sub-module.json +++ b/tests/qapi-schema/include/sub-module.json @@ -3,3 +3,5 @@ # Sub-module of ../qapi-schema-test.json { 'include': '../sub-sub-module.json' } + +{ 'struct': 'SecondArrayRef', 'data': { 's': ['Status'] } } |
