From f499753f80df51fc4ea6b41042210ab23292fff5 Mon Sep 17 00:00:00 2001 From: Christian Vetter Date: Thu, 14 Nov 2024 14:32:01 +0100 Subject: [PATCH] Report errors when trying to using optional ranges --- .../flatdata/generator/tree/builder.py | 5 ++++- .../flatdata/generator/tree/errors.py | 6 ++++++ .../tests/tree/test_syntax_tree_builder.py | 15 ++++++++++++--- 3 files changed, 22 insertions(+), 4 deletions(-) diff --git a/flatdata-generator/flatdata/generator/tree/builder.py b/flatdata-generator/flatdata/generator/tree/builder.py index ee837def..bc53a9de 100644 --- a/flatdata-generator/flatdata/generator/tree/builder.py +++ b/flatdata-generator/flatdata/generator/tree/builder.py @@ -10,7 +10,7 @@ from flatdata.generator.tree.errors import ( InvalidEnumWidthError, InvalidRangeName, InvalidRangeReference, InvalidConstReference, InvalidConstValueReference, DuplicateInvalidValueReference, - InvalidStructInExplicitReference) + InvalidStructInExplicitReference, OptionalRange) from flatdata.generator.tree.nodes.explicit_reference import ExplicitReference from flatdata.generator.tree.nodes.archive import Archive from flatdata.generator.tree.nodes.node import Node @@ -181,6 +181,9 @@ def _check_ranges(root): for sibling in field.parent.fields: if sibling.name == name: raise InvalidRangeName(name) + # Also check that the range is not optional + if field.invalid_value: + raise OptionalRange(name) # Now check that structs with ranges are only used in vectors for reference in root.iterate(StructureReference): diff --git a/flatdata-generator/flatdata/generator/tree/errors.py b/flatdata-generator/flatdata/generator/tree/errors.py index 0c4754f6..22c8d4fa 100644 --- a/flatdata-generator/flatdata/generator/tree/errors.py +++ b/flatdata-generator/flatdata/generator/tree/errors.py @@ -148,4 +148,10 @@ class InvalidRangeReference(FlatdataSyntaxError): def __init__(self, name): super().__init__( "Structs with @range can only be used in vectors: {name}" + .format(name=name)) + +class OptionalRange(FlatdataSyntaxError): + def __init__(self, name): + super().__init__( + "@range cannot be combined with @optional, store empty ranges instead: {name}" .format(name=name)) \ No newline at end of file diff --git a/flatdata-generator/tests/tree/test_syntax_tree_builder.py b/flatdata-generator/tests/tree/test_syntax_tree_builder.py index 2062897b..ccd025fa 100644 --- a/flatdata-generator/tests/tree/test_syntax_tree_builder.py +++ b/flatdata-generator/tests/tree/test_syntax_tree_builder.py @@ -10,7 +10,7 @@ sys.path.insert(0, "..") from flatdata.generator.tree.errors import MissingSymbol, InvalidRangeName, InvalidRangeReference, \ InvalidConstReference, InvalidConstValueReference, DuplicateInvalidValueReference, \ - InvalidStructInExplicitReference + InvalidStructInExplicitReference, OptionalRange from flatdata.generator.tree.builder import build_ast from flatdata.generator.tree.nodes.trivial import Namespace, Structure, Field, Constant, Enumeration, EnumerationValue from flatdata.generator.tree.nodes.archive import Archive @@ -21,8 +21,6 @@ FieldReference, ArchiveReference, BuiltinStructureReference, ConstantValueReference, \ EnumerationReference, InvalidValueReference - - def test_validating_archive_with_no_structure_defined_raises_missing_symbol_error(): def __test(resource_type): with assert_raises(MissingSymbol): @@ -103,6 +101,17 @@ def test_range_cannot_be_used_in_struct_resource(): } """) +def test_optional_range(): + with assert_raises(OptionalRange): + build_ast("""namespace foo{ + const u32 NO_EDGES_REF = 200; + struct Node { + @range(edges_range) + @optional( NO_EDGES_REF ) + first_edge_ref : u32; + } + }""") + def test_ranges_can_be_used_in_normally(): build_ast("""namespace foo{ struct A {