qapi: replace if condition list with dict {'all': [...]}
Replace the simple list sugar form with a recursive structure that will accept other operators in the following commits (all, any or not). Signed-off-by: Marc-André Lureau <marcandre.lureau@redhat.com> Message-Id: <20210804083105.97531-7-marcandre.lureau@redhat.com> Reviewed-by: Markus Armbruster <armbru@redhat.com> [Accidental code motion undone. Degenerate :forms: comment dropped. Helper _check_if() moved. Error messages tweaked. ui.json updated. Accidental changes to qapi-schema-test.json dropped.] Signed-off-by: Markus Armbruster <armbru@redhat.com>
This commit is contained in:
parent
d806f89f87
commit
5d83b9a130
@ -1136,7 +1136,8 @@
|
|||||||
{ 'name': 'gtk', 'if': 'defined(CONFIG_GTK)' },
|
{ 'name': 'gtk', 'if': 'defined(CONFIG_GTK)' },
|
||||||
{ 'name': 'sdl', 'if': 'defined(CONFIG_SDL)' },
|
{ 'name': 'sdl', 'if': 'defined(CONFIG_SDL)' },
|
||||||
{ 'name': 'egl-headless',
|
{ 'name': 'egl-headless',
|
||||||
'if': 'defined(CONFIG_OPENGL) && defined(CONFIG_GBM)' },
|
'if': { 'all': [ 'defined(CONFIG_OPENGL)',
|
||||||
|
'defined(CONFIG_GBM)' ] } },
|
||||||
{ 'name': 'curses', 'if': 'defined(CONFIG_CURSES)' },
|
{ 'name': 'curses', 'if': 'defined(CONFIG_CURSES)' },
|
||||||
{ 'name': 'cocoa', 'if': 'defined(CONFIG_COCOA)' },
|
{ 'name': 'cocoa', 'if': 'defined(CONFIG_COCOA)' },
|
||||||
{ 'name': 'spice-app', 'if': 'defined(CONFIG_SPICE)'} ] }
|
{ 'name': 'spice-app', 'if': 'defined(CONFIG_SPICE)'} ] }
|
||||||
@ -1167,7 +1168,8 @@
|
|||||||
'gtk': { 'type': 'DisplayGTK', 'if': 'defined(CONFIG_GTK)' },
|
'gtk': { 'type': 'DisplayGTK', 'if': 'defined(CONFIG_GTK)' },
|
||||||
'curses': { 'type': 'DisplayCurses', 'if': 'defined(CONFIG_CURSES)' },
|
'curses': { 'type': 'DisplayCurses', 'if': 'defined(CONFIG_CURSES)' },
|
||||||
'egl-headless': { 'type': 'DisplayEGLHeadless',
|
'egl-headless': { 'type': 'DisplayEGLHeadless',
|
||||||
'if': 'defined(CONFIG_OPENGL) && defined(CONFIG_GBM)' }
|
'if': { 'all': [ 'defined(CONFIG_OPENGL)',
|
||||||
|
'defined(CONFIG_GBM)' ] } }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -13,7 +13,8 @@
|
|||||||
|
|
||||||
import re
|
import re
|
||||||
from typing import (
|
from typing import (
|
||||||
List,
|
Any,
|
||||||
|
Dict,
|
||||||
Match,
|
Match,
|
||||||
Optional,
|
Optional,
|
||||||
Union,
|
Union,
|
||||||
@ -199,17 +200,29 @@ def guardend(name: str) -> str:
|
|||||||
name=c_fname(name).upper())
|
name=c_fname(name).upper())
|
||||||
|
|
||||||
|
|
||||||
def cgen_ifcond(ifcond: Union[str, List[str]]) -> str:
|
def cgen_ifcond(ifcond: Union[str, Dict[str, Any]]) -> str:
|
||||||
if not ifcond:
|
if not ifcond:
|
||||||
return ''
|
return ''
|
||||||
return '(' + ') && ('.join(ifcond) + ')'
|
if isinstance(ifcond, str):
|
||||||
|
return ifcond
|
||||||
|
|
||||||
|
oper, operands = next(iter(ifcond.items()))
|
||||||
|
oper = {'all': '&&'}[oper]
|
||||||
|
operands = [cgen_ifcond(o) for o in operands]
|
||||||
|
return '(' + (') ' + oper + ' (').join(operands) + ')'
|
||||||
|
|
||||||
|
|
||||||
def docgen_ifcond(ifcond: Union[str, List[str]]) -> str:
|
def docgen_ifcond(ifcond: Union[str, Dict[str, Any]]) -> str:
|
||||||
# TODO Doc generated for conditions needs polish
|
# TODO Doc generated for conditions needs polish
|
||||||
if not ifcond:
|
if not ifcond:
|
||||||
return ''
|
return ''
|
||||||
return ' and '.join(ifcond)
|
if isinstance(ifcond, str):
|
||||||
|
return ifcond
|
||||||
|
|
||||||
|
oper, operands = next(iter(ifcond.items()))
|
||||||
|
oper = {'all': ' and '}[oper]
|
||||||
|
operands = [docgen_ifcond(o) for o in operands]
|
||||||
|
return '(' + oper.join(operands) + ')'
|
||||||
|
|
||||||
|
|
||||||
def gen_if(cond: str) -> str:
|
def gen_if(cond: str) -> str:
|
||||||
|
@ -259,14 +259,9 @@ def check_flags(expr: _JSONObject, info: QAPISourceInfo) -> None:
|
|||||||
|
|
||||||
def check_if(expr: _JSONObject, info: QAPISourceInfo, source: str) -> None:
|
def check_if(expr: _JSONObject, info: QAPISourceInfo, source: str) -> None:
|
||||||
"""
|
"""
|
||||||
Normalize and validate the ``if`` member of an object.
|
Validate the ``if`` member of an object.
|
||||||
|
|
||||||
The ``if`` member may be either a ``str`` or a ``List[str]``.
|
The ``if`` member may be either a ``str`` or a dict.
|
||||||
A ``str`` value will be normalized to ``List[str]``.
|
|
||||||
|
|
||||||
:forms:
|
|
||||||
:sugared: ``Union[str, List[str]]``
|
|
||||||
:canonical: ``List[str]``
|
|
||||||
|
|
||||||
:param expr: The expression containing the ``if`` member to validate.
|
:param expr: The expression containing the ``if`` member to validate.
|
||||||
:param info: QAPI schema source file information.
|
:param info: QAPI schema source file information.
|
||||||
@ -275,31 +270,46 @@ def check_if(expr: _JSONObject, info: QAPISourceInfo, source: str) -> None:
|
|||||||
:raise QAPISemError:
|
:raise QAPISemError:
|
||||||
When the "if" member fails validation, or when there are no
|
When the "if" member fails validation, or when there are no
|
||||||
non-empty conditions.
|
non-empty conditions.
|
||||||
:return: None, ``expr`` is normalized in-place as needed.
|
:return: None
|
||||||
"""
|
"""
|
||||||
|
|
||||||
|
def _check_if(cond: Union[str, object]) -> None:
|
||||||
|
if isinstance(cond, str):
|
||||||
|
if not cond.strip():
|
||||||
|
raise QAPISemError(
|
||||||
|
info,
|
||||||
|
"'if' condition '%s' of %s makes no sense"
|
||||||
|
% (cond, source))
|
||||||
|
return
|
||||||
|
|
||||||
|
if not isinstance(cond, dict):
|
||||||
|
raise QAPISemError(
|
||||||
|
info,
|
||||||
|
"'if' condition of %s must be a string or an object" % source)
|
||||||
|
if len(cond) != 1:
|
||||||
|
raise QAPISemError(
|
||||||
|
info,
|
||||||
|
"'if' condition dict of %s must have one key: "
|
||||||
|
"'all'" % source)
|
||||||
|
check_keys(cond, info, "'if' condition", [],
|
||||||
|
["all"])
|
||||||
|
|
||||||
|
oper, operands = next(iter(cond.items()))
|
||||||
|
if not operands:
|
||||||
|
raise QAPISemError(
|
||||||
|
info, "'if' condition [] of %s is useless" % source)
|
||||||
|
|
||||||
|
if oper in ("all") and not isinstance(operands, list):
|
||||||
|
raise QAPISemError(
|
||||||
|
info, "'%s' condition of %s must be an array" % (oper, source))
|
||||||
|
for operand in operands:
|
||||||
|
_check_if(operand)
|
||||||
|
|
||||||
ifcond = expr.get('if')
|
ifcond = expr.get('if')
|
||||||
if ifcond is None:
|
if ifcond is None:
|
||||||
return
|
return
|
||||||
|
|
||||||
if isinstance(ifcond, list):
|
_check_if(ifcond)
|
||||||
if not ifcond:
|
|
||||||
raise QAPISemError(
|
|
||||||
info, "'if' condition [] of %s is useless" % source)
|
|
||||||
else:
|
|
||||||
# Normalize to a list
|
|
||||||
ifcond = expr['if'] = [ifcond]
|
|
||||||
|
|
||||||
for elt in ifcond:
|
|
||||||
if not isinstance(elt, str):
|
|
||||||
raise QAPISemError(
|
|
||||||
info,
|
|
||||||
"'if' condition of %s must be a string or a list of strings"
|
|
||||||
% source)
|
|
||||||
if not elt.strip():
|
|
||||||
raise QAPISemError(
|
|
||||||
info,
|
|
||||||
"'if' condition '%s' of %s makes no sense"
|
|
||||||
% (elt, source))
|
|
||||||
|
|
||||||
|
|
||||||
def normalize_members(members: object) -> None:
|
def normalize_members(members: object) -> None:
|
||||||
|
@ -32,7 +32,7 @@ from .parser import QAPISchemaParser
|
|||||||
|
|
||||||
class QAPISchemaIfCond:
|
class QAPISchemaIfCond:
|
||||||
def __init__(self, ifcond=None):
|
def __init__(self, ifcond=None):
|
||||||
self.ifcond = ifcond or []
|
self.ifcond = ifcond or {}
|
||||||
|
|
||||||
def cgen(self):
|
def cgen(self):
|
||||||
return cgen_ifcond(self.ifcond)
|
return cgen_ifcond(self.ifcond)
|
||||||
|
2
tests/qapi-schema/bad-if-all.err
Normal file
2
tests/qapi-schema/bad-if-all.err
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
bad-if-all.json: In struct 'TestIfStruct':
|
||||||
|
bad-if-all.json:2: 'all' condition of struct must be an array
|
3
tests/qapi-schema/bad-if-all.json
Normal file
3
tests/qapi-schema/bad-if-all.json
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
# check 'if all' is not a list
|
||||||
|
{ 'struct': 'TestIfStruct', 'data': { 'foo': 'int' },
|
||||||
|
'if': { 'all': 'ALL' } }
|
0
tests/qapi-schema/bad-if-all.out
Normal file
0
tests/qapi-schema/bad-if-all.out
Normal file
@ -1,3 +1,3 @@
|
|||||||
# check empty 'if' list
|
# check empty 'if' list
|
||||||
{ 'struct': 'TestIfStruct', 'data': { 'foo': 'int' },
|
{ 'struct': 'TestIfStruct', 'data': { 'foo': 'int' },
|
||||||
'if': [] }
|
'if': { 'all': [] } }
|
||||||
|
3
tests/qapi-schema/bad-if-key.err
Normal file
3
tests/qapi-schema/bad-if-key.err
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
bad-if-key.json: In struct 'TestIfStruct':
|
||||||
|
bad-if-key.json:2: 'if' condition has unknown key 'value'
|
||||||
|
Valid keys are 'all'.
|
3
tests/qapi-schema/bad-if-key.json
Normal file
3
tests/qapi-schema/bad-if-key.json
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
# check unknown 'if' dict key
|
||||||
|
{ 'struct': 'TestIfStruct', 'data': { 'foo': 'int' },
|
||||||
|
'if': { 'value': 'defined(TEST_IF_STRUCT)' } }
|
0
tests/qapi-schema/bad-if-key.out
Normal file
0
tests/qapi-schema/bad-if-key.out
Normal file
2
tests/qapi-schema/bad-if-keys.err
Normal file
2
tests/qapi-schema/bad-if-keys.err
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
bad-if-keys.json: In struct 'TestIfStruct':
|
||||||
|
bad-if-keys.json:2: 'if' condition dict of struct must have one key: 'all'
|
3
tests/qapi-schema/bad-if-keys.json
Normal file
3
tests/qapi-schema/bad-if-keys.json
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
# check multiple 'if' keys
|
||||||
|
{ 'struct': 'TestIfStruct', 'data': { 'foo': 'int' },
|
||||||
|
'if': { 'any': ['ANY'], 'all': ['ALL'] } }
|
0
tests/qapi-schema/bad-if-keys.out
Normal file
0
tests/qapi-schema/bad-if-keys.out
Normal file
@ -1,3 +1,3 @@
|
|||||||
# check invalid 'if' content
|
# check invalid 'if' content
|
||||||
{ 'struct': 'TestIfStruct', 'data': { 'foo': 'int' },
|
{ 'struct': 'TestIfStruct', 'data': { 'foo': 'int' },
|
||||||
'if': ['foo', ' '] }
|
'if': { 'all': ['foo', ' '] } }
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
bad-if.json: In struct 'TestIfStruct':
|
bad-if.json: In struct 'TestIfStruct':
|
||||||
bad-if.json:2: 'if' condition of struct must be a string or a list of strings
|
bad-if.json:2: 'if' condition of struct must be a string or an object
|
||||||
|
@ -1,3 +1,3 @@
|
|||||||
# check invalid 'if' type
|
# check invalid 'if' type
|
||||||
{ 'struct': 'TestIfStruct', 'data': { 'foo': 'int' },
|
{ 'struct': 'TestIfStruct', 'data': { 'foo': 'int' },
|
||||||
'if': { 'value': 'defined(TEST_IF_STRUCT)' } }
|
'if': ['defined(TEST_IF_STRUCT)'] }
|
||||||
|
@ -70,7 +70,8 @@
|
|||||||
# @base1:
|
# @base1:
|
||||||
# the first member
|
# the first member
|
||||||
##
|
##
|
||||||
{ 'struct': 'Base', 'data': { 'base1': 'Enum' } }
|
{ 'struct': 'Base', 'data': { 'base1': 'Enum' },
|
||||||
|
'if': { 'all': ['IFALL1', 'IFALL2'] } }
|
||||||
|
|
||||||
##
|
##
|
||||||
# @Variant1:
|
# @Variant1:
|
||||||
|
@ -12,15 +12,16 @@ enum QType
|
|||||||
module doc-good.json
|
module doc-good.json
|
||||||
enum Enum
|
enum Enum
|
||||||
member one
|
member one
|
||||||
if ['defined(IFONE)']
|
if defined(IFONE)
|
||||||
member two
|
member two
|
||||||
if ['defined(IFCOND)']
|
if defined(IFCOND)
|
||||||
feature enum-feat
|
feature enum-feat
|
||||||
object Base
|
object Base
|
||||||
member base1: Enum optional=False
|
member base1: Enum optional=False
|
||||||
|
if OrderedDict([('all', ['IFALL1', 'IFALL2'])])
|
||||||
object Variant1
|
object Variant1
|
||||||
member var1: str optional=False
|
member var1: str optional=False
|
||||||
if ['defined(IFSTR)']
|
if defined(IFSTR)
|
||||||
feature member-feat
|
feature member-feat
|
||||||
feature variant1-feat
|
feature variant1-feat
|
||||||
object Variant2
|
object Variant2
|
||||||
@ -29,7 +30,7 @@ object Object
|
|||||||
tag base1
|
tag base1
|
||||||
case one: Variant1
|
case one: Variant1
|
||||||
case two: Variant2
|
case two: Variant2
|
||||||
if ['IFTWO']
|
if IFTWO
|
||||||
feature union-feat1
|
feature union-feat1
|
||||||
object q_obj_Variant1-wrapper
|
object q_obj_Variant1-wrapper
|
||||||
member data: Variant1 optional=False
|
member data: Variant1 optional=False
|
||||||
@ -38,13 +39,13 @@ object q_obj_Variant2-wrapper
|
|||||||
enum SugaredUnionKind
|
enum SugaredUnionKind
|
||||||
member one
|
member one
|
||||||
member two
|
member two
|
||||||
if ['IFTWO']
|
if IFTWO
|
||||||
object SugaredUnion
|
object SugaredUnion
|
||||||
member type: SugaredUnionKind optional=False
|
member type: SugaredUnionKind optional=False
|
||||||
tag type
|
tag type
|
||||||
case one: q_obj_Variant1-wrapper
|
case one: q_obj_Variant1-wrapper
|
||||||
case two: q_obj_Variant2-wrapper
|
case two: q_obj_Variant2-wrapper
|
||||||
if ['IFTWO']
|
if IFTWO
|
||||||
feature union-feat2
|
feature union-feat2
|
||||||
alternate Alternate
|
alternate Alternate
|
||||||
tag type
|
tag type
|
||||||
|
@ -76,6 +76,12 @@ Members
|
|||||||
the first member
|
the first member
|
||||||
|
|
||||||
|
|
||||||
|
If
|
||||||
|
~~
|
||||||
|
|
||||||
|
"(IFALL1 and IFALL2)"
|
||||||
|
|
||||||
|
|
||||||
"Variant1" (Object)
|
"Variant1" (Object)
|
||||||
-------------------
|
-------------------
|
||||||
|
|
||||||
|
@ -1,2 +1,3 @@
|
|||||||
enum-if-invalid.json: In enum 'TestIfEnum':
|
enum-if-invalid.json: In enum 'TestIfEnum':
|
||||||
enum-if-invalid.json:2: 'if' condition of 'data' member 'bar' must be a string or a list of strings
|
enum-if-invalid.json:2: 'if' condition has unknown key 'val'
|
||||||
|
Valid keys are 'all'.
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
features-if-invalid.json: In struct 'Stru':
|
features-if-invalid.json: In struct 'Stru':
|
||||||
features-if-invalid.json:2: 'if' condition of 'features' member 'f' must be a string or a list of strings
|
features-if-invalid.json:2: 'if' condition of 'features' member 'f' must be a string or an object
|
||||||
|
@ -37,8 +37,11 @@ schemas = [
|
|||||||
'bad-data.json',
|
'bad-data.json',
|
||||||
'bad-ident.json',
|
'bad-ident.json',
|
||||||
'bad-if.json',
|
'bad-if.json',
|
||||||
|
'bad-if-all.json',
|
||||||
'bad-if-empty.json',
|
'bad-if-empty.json',
|
||||||
'bad-if-empty-list.json',
|
'bad-if-empty-list.json',
|
||||||
|
'bad-if-key.json',
|
||||||
|
'bad-if-keys.json',
|
||||||
'bad-if-list.json',
|
'bad-if-list.json',
|
||||||
'bad-type-bool.json',
|
'bad-type-bool.json',
|
||||||
'bad-type-dict.json',
|
'bad-type-dict.json',
|
||||||
|
@ -232,7 +232,7 @@
|
|||||||
{ 'union': 'TestIfUnion', 'data':
|
{ 'union': 'TestIfUnion', 'data':
|
||||||
{ 'foo': 'TestStruct',
|
{ 'foo': 'TestStruct',
|
||||||
'bar': { 'type': 'str', 'if': 'defined(TEST_IF_UNION_BAR)'} },
|
'bar': { 'type': 'str', 'if': 'defined(TEST_IF_UNION_BAR)'} },
|
||||||
'if': 'defined(TEST_IF_UNION) && defined(TEST_IF_STRUCT)' }
|
'if': { 'all': ['defined(TEST_IF_UNION)', 'defined(TEST_IF_STRUCT)'] } }
|
||||||
|
|
||||||
{ 'command': 'test-if-union-cmd',
|
{ 'command': 'test-if-union-cmd',
|
||||||
'data': { 'union-cmd-arg': 'TestIfUnion' },
|
'data': { 'union-cmd-arg': 'TestIfUnion' },
|
||||||
@ -241,25 +241,25 @@
|
|||||||
{ 'alternate': 'TestIfAlternate', 'data':
|
{ 'alternate': 'TestIfAlternate', 'data':
|
||||||
{ 'foo': 'int',
|
{ 'foo': 'int',
|
||||||
'bar': { 'type': 'TestStruct', 'if': 'defined(TEST_IF_ALT_BAR)'} },
|
'bar': { 'type': 'TestStruct', 'if': 'defined(TEST_IF_ALT_BAR)'} },
|
||||||
'if': 'defined(TEST_IF_ALT) && defined(TEST_IF_STRUCT)' }
|
'if': { 'all': ['defined(TEST_IF_ALT)', 'defined(TEST_IF_STRUCT)'] } }
|
||||||
|
|
||||||
{ 'command': 'test-if-alternate-cmd',
|
{ 'command': 'test-if-alternate-cmd',
|
||||||
'data': { 'alt-cmd-arg': 'TestIfAlternate' },
|
'data': { 'alt-cmd-arg': 'TestIfAlternate' },
|
||||||
'if': 'defined(TEST_IF_ALT)' }
|
'if': { 'all': ['defined(TEST_IF_ALT)'] } }
|
||||||
|
|
||||||
{ 'command': 'test-if-cmd',
|
{ 'command': 'test-if-cmd',
|
||||||
'data': {
|
'data': {
|
||||||
'foo': 'TestIfStruct',
|
'foo': 'TestIfStruct',
|
||||||
'bar': { 'type': 'TestIfEnum', 'if': 'defined(TEST_IF_CMD_BAR)' } },
|
'bar': { 'type': 'TestIfEnum', 'if': 'defined(TEST_IF_CMD_BAR)' } },
|
||||||
'returns': 'UserDefThree',
|
'returns': 'UserDefThree',
|
||||||
'if': ['defined(TEST_IF_CMD)', 'defined(TEST_IF_STRUCT)'] }
|
'if': { 'all': ['defined(TEST_IF_CMD)', 'defined(TEST_IF_STRUCT)'] } }
|
||||||
|
|
||||||
{ 'command': 'test-cmd-return-def-three', 'returns': 'UserDefThree' }
|
{ 'command': 'test-cmd-return-def-three', 'returns': 'UserDefThree' }
|
||||||
|
|
||||||
{ 'event': 'TEST_IF_EVENT', 'data':
|
{ 'event': 'TEST_IF_EVENT', 'data':
|
||||||
{ 'foo': 'TestIfStruct',
|
{ 'foo': 'TestIfStruct',
|
||||||
'bar': { 'type': ['TestIfEnum'], 'if': 'defined(TEST_IF_EVT_BAR)' } },
|
'bar': { 'type': ['TestIfEnum'], 'if': 'defined(TEST_IF_EVT_BAR)' } },
|
||||||
'if': 'defined(TEST_IF_EVT) && defined(TEST_IF_STRUCT)' }
|
'if': { 'all': ['defined(TEST_IF_EVT)', 'defined(TEST_IF_STRUCT)'] } }
|
||||||
|
|
||||||
# test 'features'
|
# test 'features'
|
||||||
|
|
||||||
@ -288,8 +288,9 @@
|
|||||||
{ 'name': 'feature2', 'if': 'defined(TEST_IF_FEATURE_2)'} ] }
|
{ 'name': 'feature2', 'if': 'defined(TEST_IF_FEATURE_2)'} ] }
|
||||||
{ 'struct': 'CondFeatureStruct3',
|
{ 'struct': 'CondFeatureStruct3',
|
||||||
'data': { 'foo': 'int' },
|
'data': { 'foo': 'int' },
|
||||||
'features': [ { 'name': 'feature1', 'if': [ 'defined(TEST_IF_COND_1)',
|
'features': [ { 'name': 'feature1',
|
||||||
'defined(TEST_IF_COND_2)'] } ] }
|
'if': { 'all': [ 'defined(TEST_IF_COND_1)',
|
||||||
|
'defined(TEST_IF_COND_2)'] } } ] }
|
||||||
|
|
||||||
{ 'enum': 'FeatureEnum1',
|
{ 'enum': 'FeatureEnum1',
|
||||||
'data': [ 'eins', 'zwei', 'drei' ],
|
'data': [ 'eins', 'zwei', 'drei' ],
|
||||||
@ -328,8 +329,9 @@
|
|||||||
'features': [ { 'name': 'feature1', 'if': 'defined(TEST_IF_FEATURE_1)'},
|
'features': [ { 'name': 'feature1', 'if': 'defined(TEST_IF_FEATURE_1)'},
|
||||||
{ 'name': 'feature2', 'if': 'defined(TEST_IF_FEATURE_2)'} ] }
|
{ 'name': 'feature2', 'if': 'defined(TEST_IF_FEATURE_2)'} ] }
|
||||||
{ 'command': 'test-command-cond-features3',
|
{ 'command': 'test-command-cond-features3',
|
||||||
'features': [ { 'name': 'feature1', 'if': [ 'defined(TEST_IF_COND_1)',
|
'features': [ { 'name': 'feature1',
|
||||||
'defined(TEST_IF_COND_2)'] } ] }
|
'if': { 'all': [ 'defined(TEST_IF_COND_1)',
|
||||||
|
'defined(TEST_IF_COND_2)'] } } ] }
|
||||||
|
|
||||||
{ 'event': 'TEST_EVENT_FEATURES0',
|
{ 'event': 'TEST_EVENT_FEATURES0',
|
||||||
'data': 'FeatureStruct1' }
|
'data': 'FeatureStruct1' }
|
||||||
|
@ -298,65 +298,65 @@ command __org.qemu_x-command q_obj___org.qemu_x-command-arg -> __org.qemu_x-Unio
|
|||||||
object TestIfStruct
|
object TestIfStruct
|
||||||
member foo: int optional=False
|
member foo: int optional=False
|
||||||
member bar: int optional=False
|
member bar: int optional=False
|
||||||
if ['defined(TEST_IF_STRUCT_BAR)']
|
if defined(TEST_IF_STRUCT_BAR)
|
||||||
if ['defined(TEST_IF_STRUCT)']
|
if defined(TEST_IF_STRUCT)
|
||||||
enum TestIfEnum
|
enum TestIfEnum
|
||||||
member foo
|
member foo
|
||||||
member bar
|
member bar
|
||||||
if ['defined(TEST_IF_ENUM_BAR)']
|
if defined(TEST_IF_ENUM_BAR)
|
||||||
if ['defined(TEST_IF_ENUM)']
|
if defined(TEST_IF_ENUM)
|
||||||
object q_obj_TestStruct-wrapper
|
object q_obj_TestStruct-wrapper
|
||||||
member data: TestStruct optional=False
|
member data: TestStruct optional=False
|
||||||
enum TestIfUnionKind
|
enum TestIfUnionKind
|
||||||
member foo
|
member foo
|
||||||
member bar
|
member bar
|
||||||
if ['defined(TEST_IF_UNION_BAR)']
|
if defined(TEST_IF_UNION_BAR)
|
||||||
if ['defined(TEST_IF_UNION) && defined(TEST_IF_STRUCT)']
|
if OrderedDict([('all', ['defined(TEST_IF_UNION)', 'defined(TEST_IF_STRUCT)'])])
|
||||||
object TestIfUnion
|
object TestIfUnion
|
||||||
member type: TestIfUnionKind optional=False
|
member type: TestIfUnionKind optional=False
|
||||||
tag type
|
tag type
|
||||||
case foo: q_obj_TestStruct-wrapper
|
case foo: q_obj_TestStruct-wrapper
|
||||||
case bar: q_obj_str-wrapper
|
case bar: q_obj_str-wrapper
|
||||||
if ['defined(TEST_IF_UNION_BAR)']
|
if defined(TEST_IF_UNION_BAR)
|
||||||
if ['defined(TEST_IF_UNION) && defined(TEST_IF_STRUCT)']
|
if OrderedDict([('all', ['defined(TEST_IF_UNION)', 'defined(TEST_IF_STRUCT)'])])
|
||||||
object q_obj_test-if-union-cmd-arg
|
object q_obj_test-if-union-cmd-arg
|
||||||
member union-cmd-arg: TestIfUnion optional=False
|
member union-cmd-arg: TestIfUnion optional=False
|
||||||
if ['defined(TEST_IF_UNION)']
|
if defined(TEST_IF_UNION)
|
||||||
command test-if-union-cmd q_obj_test-if-union-cmd-arg -> None
|
command test-if-union-cmd q_obj_test-if-union-cmd-arg -> None
|
||||||
gen=True success_response=True boxed=False oob=False preconfig=False
|
gen=True success_response=True boxed=False oob=False preconfig=False
|
||||||
if ['defined(TEST_IF_UNION)']
|
if defined(TEST_IF_UNION)
|
||||||
alternate TestIfAlternate
|
alternate TestIfAlternate
|
||||||
tag type
|
tag type
|
||||||
case foo: int
|
case foo: int
|
||||||
case bar: TestStruct
|
case bar: TestStruct
|
||||||
if ['defined(TEST_IF_ALT_BAR)']
|
if defined(TEST_IF_ALT_BAR)
|
||||||
if ['defined(TEST_IF_ALT) && defined(TEST_IF_STRUCT)']
|
if OrderedDict([('all', ['defined(TEST_IF_ALT)', 'defined(TEST_IF_STRUCT)'])])
|
||||||
object q_obj_test-if-alternate-cmd-arg
|
object q_obj_test-if-alternate-cmd-arg
|
||||||
member alt-cmd-arg: TestIfAlternate optional=False
|
member alt-cmd-arg: TestIfAlternate optional=False
|
||||||
if ['defined(TEST_IF_ALT)']
|
if OrderedDict([('all', ['defined(TEST_IF_ALT)'])])
|
||||||
command test-if-alternate-cmd q_obj_test-if-alternate-cmd-arg -> None
|
command test-if-alternate-cmd q_obj_test-if-alternate-cmd-arg -> None
|
||||||
gen=True success_response=True boxed=False oob=False preconfig=False
|
gen=True success_response=True boxed=False oob=False preconfig=False
|
||||||
if ['defined(TEST_IF_ALT)']
|
if OrderedDict([('all', ['defined(TEST_IF_ALT)'])])
|
||||||
object q_obj_test-if-cmd-arg
|
object q_obj_test-if-cmd-arg
|
||||||
member foo: TestIfStruct optional=False
|
member foo: TestIfStruct optional=False
|
||||||
member bar: TestIfEnum optional=False
|
member bar: TestIfEnum optional=False
|
||||||
if ['defined(TEST_IF_CMD_BAR)']
|
if defined(TEST_IF_CMD_BAR)
|
||||||
if ['defined(TEST_IF_CMD)', 'defined(TEST_IF_STRUCT)']
|
if OrderedDict([('all', ['defined(TEST_IF_CMD)', 'defined(TEST_IF_STRUCT)'])])
|
||||||
command test-if-cmd q_obj_test-if-cmd-arg -> UserDefThree
|
command test-if-cmd q_obj_test-if-cmd-arg -> UserDefThree
|
||||||
gen=True success_response=True boxed=False oob=False preconfig=False
|
gen=True success_response=True boxed=False oob=False preconfig=False
|
||||||
if ['defined(TEST_IF_CMD)', 'defined(TEST_IF_STRUCT)']
|
if OrderedDict([('all', ['defined(TEST_IF_CMD)', 'defined(TEST_IF_STRUCT)'])])
|
||||||
command test-cmd-return-def-three None -> UserDefThree
|
command test-cmd-return-def-three None -> UserDefThree
|
||||||
gen=True success_response=True boxed=False oob=False preconfig=False
|
gen=True success_response=True boxed=False oob=False preconfig=False
|
||||||
array TestIfEnumList TestIfEnum
|
array TestIfEnumList TestIfEnum
|
||||||
if ['defined(TEST_IF_ENUM)']
|
if defined(TEST_IF_ENUM)
|
||||||
object q_obj_TEST_IF_EVENT-arg
|
object q_obj_TEST_IF_EVENT-arg
|
||||||
member foo: TestIfStruct optional=False
|
member foo: TestIfStruct optional=False
|
||||||
member bar: TestIfEnumList optional=False
|
member bar: TestIfEnumList optional=False
|
||||||
if ['defined(TEST_IF_EVT_BAR)']
|
if defined(TEST_IF_EVT_BAR)
|
||||||
if ['defined(TEST_IF_EVT) && defined(TEST_IF_STRUCT)']
|
if OrderedDict([('all', ['defined(TEST_IF_EVT)', 'defined(TEST_IF_STRUCT)'])])
|
||||||
event TEST_IF_EVENT q_obj_TEST_IF_EVENT-arg
|
event TEST_IF_EVENT q_obj_TEST_IF_EVENT-arg
|
||||||
boxed=False
|
boxed=False
|
||||||
if ['defined(TEST_IF_EVT) && defined(TEST_IF_STRUCT)']
|
if OrderedDict([('all', ['defined(TEST_IF_EVT)', 'defined(TEST_IF_STRUCT)'])])
|
||||||
object FeatureStruct0
|
object FeatureStruct0
|
||||||
member foo: int optional=False
|
member foo: int optional=False
|
||||||
object FeatureStruct1
|
object FeatureStruct1
|
||||||
@ -379,17 +379,17 @@ object FeatureStruct4
|
|||||||
object CondFeatureStruct1
|
object CondFeatureStruct1
|
||||||
member foo: int optional=False
|
member foo: int optional=False
|
||||||
feature feature1
|
feature feature1
|
||||||
if ['defined(TEST_IF_FEATURE_1)']
|
if defined(TEST_IF_FEATURE_1)
|
||||||
object CondFeatureStruct2
|
object CondFeatureStruct2
|
||||||
member foo: int optional=False
|
member foo: int optional=False
|
||||||
feature feature1
|
feature feature1
|
||||||
if ['defined(TEST_IF_FEATURE_1)']
|
if defined(TEST_IF_FEATURE_1)
|
||||||
feature feature2
|
feature feature2
|
||||||
if ['defined(TEST_IF_FEATURE_2)']
|
if defined(TEST_IF_FEATURE_2)
|
||||||
object CondFeatureStruct3
|
object CondFeatureStruct3
|
||||||
member foo: int optional=False
|
member foo: int optional=False
|
||||||
feature feature1
|
feature feature1
|
||||||
if ['defined(TEST_IF_COND_1)', 'defined(TEST_IF_COND_2)']
|
if OrderedDict([('all', ['defined(TEST_IF_COND_1)', 'defined(TEST_IF_COND_2)'])])
|
||||||
enum FeatureEnum1
|
enum FeatureEnum1
|
||||||
member eins
|
member eins
|
||||||
member zwei
|
member zwei
|
||||||
@ -429,17 +429,17 @@ command test-command-features3 None -> None
|
|||||||
command test-command-cond-features1 None -> None
|
command test-command-cond-features1 None -> None
|
||||||
gen=True success_response=True boxed=False oob=False preconfig=False
|
gen=True success_response=True boxed=False oob=False preconfig=False
|
||||||
feature feature1
|
feature feature1
|
||||||
if ['defined(TEST_IF_FEATURE_1)']
|
if defined(TEST_IF_FEATURE_1)
|
||||||
command test-command-cond-features2 None -> None
|
command test-command-cond-features2 None -> None
|
||||||
gen=True success_response=True boxed=False oob=False preconfig=False
|
gen=True success_response=True boxed=False oob=False preconfig=False
|
||||||
feature feature1
|
feature feature1
|
||||||
if ['defined(TEST_IF_FEATURE_1)']
|
if defined(TEST_IF_FEATURE_1)
|
||||||
feature feature2
|
feature feature2
|
||||||
if ['defined(TEST_IF_FEATURE_2)']
|
if defined(TEST_IF_FEATURE_2)
|
||||||
command test-command-cond-features3 None -> None
|
command test-command-cond-features3 None -> None
|
||||||
gen=True success_response=True boxed=False oob=False preconfig=False
|
gen=True success_response=True boxed=False oob=False preconfig=False
|
||||||
feature feature1
|
feature feature1
|
||||||
if ['defined(TEST_IF_COND_1)', 'defined(TEST_IF_COND_2)']
|
if OrderedDict([('all', ['defined(TEST_IF_COND_1)', 'defined(TEST_IF_COND_2)'])])
|
||||||
event TEST_EVENT_FEATURES0 FeatureStruct1
|
event TEST_EVENT_FEATURES0 FeatureStruct1
|
||||||
boxed=False
|
boxed=False
|
||||||
event TEST_EVENT_FEATURES1 None
|
event TEST_EVENT_FEATURES1 None
|
||||||
|
@ -1,2 +1,2 @@
|
|||||||
struct-member-if-invalid.json: In struct 'Stru':
|
struct-member-if-invalid.json: In struct 'Stru':
|
||||||
struct-member-if-invalid.json:2: 'if' condition of 'data' member 'member' must be a string or a list of strings
|
struct-member-if-invalid.json:2: 'if' condition of 'data' member 'member' must be a string or an object
|
||||||
|
@ -3,4 +3,4 @@
|
|||||||
{ 'struct': 'Stru', 'data': { 'member': 'str' } }
|
{ 'struct': 'Stru', 'data': { 'member': 'str' } }
|
||||||
{ 'union': 'Uni',
|
{ 'union': 'Uni',
|
||||||
'base': { 'tag': 'Branches' }, 'discriminator': 'tag',
|
'base': { 'tag': 'Branches' }, 'discriminator': 'tag',
|
||||||
'data': { 'branch1': { 'type': 'Stru', 'if': [''] } } }
|
'data': { 'branch1': { 'type': 'Stru', 'if': { 'all': [''] } } } }
|
||||||
|
Loading…
Reference in New Issue
Block a user