Skip to content

Commit

Permalink
replace Optional with Union
Browse files Browse the repository at this point in the history
Signed-off-by: Paul Gesel <[email protected]>
  • Loading branch information
pac48 committed Aug 2, 2024
1 parent 03f753c commit 4e6975e
Show file tree
Hide file tree
Showing 4 changed files with 33 additions and 32 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
# -*- coding: utf-8 -*-
from typing import List, Optional
from typing import List, Union
from jinja2 import Template
from typeguard import typechecked
import os
Expand Down Expand Up @@ -108,18 +108,18 @@ def update_parameter_pass_validation(self) -> str:
return ''

@typechecked
def no_code(self, s: Optional[str]):
def no_code(self, s: Union[None, str]):
return ''

# value to c++ string conversion functions
@typechecked
def bool_to_str(self, cond: Optional[bool]):
def bool_to_str(self, cond: Union[None, bool]):
if cond is None:
return ''
return 'true' if cond else 'false'

@typechecked
def float_to_str(self, num: Optional[float]):
def float_to_str(self, num: Union[None, float]):
if num is None:
return ''
str_num = str(num)
Expand All @@ -136,65 +136,65 @@ def float_to_str(self, num: Optional[float]):
return str_num

@typechecked
def int_to_str(self, num: Optional[int]):
def int_to_str(self, num: Union[None, int]):
if num is None:
return ''
return str(num)

@typechecked
def str_to_str(self, s: Optional[str]):
def str_to_str(self, s: Union[None, str]):
if s is None:
return ''
return f'"{s}"'

@typechecked
def bool_array_to_str(self, values: Optional[list]):
def bool_array_to_str(self, values: Union[None, list]):
if values is None:
return ''
return '{' + ', '.join(self.bool_to_str(x) for x in values) + '}'

@typechecked
def float_array_to_str(self, values: Optional[list]):
def float_array_to_str(self, values: Union[None, list]):
if values is None:
return ''
return '{' + ', '.join(self.float_to_str(x) for x in values) + '}'

@typechecked
def int_array_to_str(self, values: Optional[list]):
def int_array_to_str(self, values: Union[None, list]):
if values is None:
return ''
return '{' + ', '.join(self.int_to_str(x) for x in values) + '}'

@typechecked
def str_array_to_str(self, s: Optional[list]):
def str_array_to_str(self, s: Union[None, list]):
if s is None:
return ''
return '{' + ', '.join(self.str_to_str(x) for x in s) + '}'

@typechecked
def str_array_fixed_to_str(self, s: Optional[list]):
def str_array_fixed_to_str(self, s: Union[None, list]):
raise compile_error('not implemented')

@typechecked
def str_fixed_to_str(self, s: Optional[str]):
def str_fixed_to_str(self, s: Union[None, str]):
if s is None:
return ''
return '{%s}' % self.str_to_str(s)

@typechecked
def float_array_fixed_to_str(self, values: Optional[list]):
def float_array_fixed_to_str(self, values: Union[None, list]):
if values is None:
return ''
return '{{' + ', '.join(self.float_to_str(x) for x in values) + '}}'

@typechecked
def int_array_fixed_to_str(self, values: Optional[list]):
def int_array_fixed_to_str(self, values: Union[None, list]):
if values is None:
return ''
return '{{' + ', '.join(self.int_to_str(x) for x in values) + '}}'

@typechecked
def bool_array_fixed_to_str(self, values: Optional[list]):
def bool_array_fixed_to_str(self, values: Union[None, list]):
if values is None:
return ''
return '{{' + ', '.join(self.bool_to_str(x) for x in values) + '}}'
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@
except:
TypeCheckError = TypeError

from typing import Any, List, Optional
from typing import Any, List, Union
from yaml.parser import ParserError
from yaml.scanner import ScannerError
import os
Expand Down Expand Up @@ -320,7 +320,7 @@ class ValidationFunction:
def __init__(
self,
function_name: str,
arguments: Optional[List[Any]],
arguments: Union[None, List[Any]],
code_gen_variable: CodeGenVariableBase,
):
self.code_gen_variable = code_gen_variable
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
# -*- coding: utf-8 -*-
from typing import List, Optional
from typing import List, Union
from jinja2 import Template
from typeguard import typechecked
import os
Expand Down Expand Up @@ -107,18 +107,18 @@ def update_parameter_pass_validation(self) -> str:
return ''

@typechecked
def no_code(self, s: Optional[str]):
def no_code(self, s: Union[None, str]):
return ''

# value to c++ string conversion functions
@typechecked
def bool_to_str(self, cond: Optional[bool]):
def bool_to_str(self, cond: Union[None, bool]):
if cond is None:
return ''
return 'True' if cond else 'False'

@typechecked
def float_to_str(self, num: Optional[float]):
def float_to_str(self, num: Union[None, float]):
if num is None:
return ''
str_num = str(num)
Expand All @@ -135,65 +135,65 @@ def float_to_str(self, num: Optional[float]):
return str_num

@typechecked
def int_to_str(self, num: Optional[int]):
def int_to_str(self, num: Union[None, int]):
if num is None:
return ''
return str(num)

@typechecked
def str_to_str(self, s: Optional[str]):
def str_to_str(self, s: Union[None, str]):
if s is None:
return ''
return f'"{s}"'

@typechecked
def bool_array_to_str(self, values: Optional[list]):
def bool_array_to_str(self, values: Union[None, list]):
if values is None:
return ''
return '[' + ', '.join(self.bool_to_str(x) for x in values) + ']'

@typechecked
def float_array_to_str(self, values: Optional[list]):
def float_array_to_str(self, values: Union[None, list]):
if values is None:
return ''
return '[' + ', '.join(self.float_to_str(x) for x in values) + ']'

@typechecked
def int_array_to_str(self, values: Optional[list]):
def int_array_to_str(self, values: Union[None, list]):
if values is None:
return ''
return '[' + ', '.join(self.int_to_str(x) for x in values) + ']'

@typechecked
def str_array_to_str(self, s: Optional[list]):
def str_array_to_str(self, s: Union[None, list]):
if s is None:
return ''
return '[' + ', '.join(self.str_to_str(x) for x in s) + ']'

@typechecked
def str_array_fixed_to_str(self, s: Optional[list]):
def str_array_fixed_to_str(self, s: Union[None, list]):
raise compile_error('not implemented')

@typechecked
def str_fixed_to_str(self, s: Optional[str]):
def str_fixed_to_str(self, s: Union[None, str]):
if s is None:
return ''
return '%s' % self.str_to_str(s)

@typechecked
def float_array_fixed_to_str(self, values: Optional[list]):
def float_array_fixed_to_str(self, values: Union[None, list]):
if values is None:
return ''
return '[' + ', '.join(self.float_to_str(x) for x in values) + ']'

@typechecked
def int_array_fixed_to_str(self, values: Optional[list]):
def int_array_fixed_to_str(self, values: Union[None, list]):
if values is None:
return ''
return '[' + ', '.join(self.int_to_str(x) for x in values) + ']'

@typechecked
def bool_array_fixed_to_str(self, values: Optional[list]):
def bool_array_fixed_to_str(self, values: Union[None, list]):
if values is None:
return ''
return '[' + ', '.join(self.bool_to_str(x) for x in values) + ']'
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,7 @@ def test_expected(test_input, expected):
pytest.skip(
'Evaluating optimized type validation cannot be completed when python is optimized'
)

with pytest.raises(expected) as e:
yaml_test_file = test_input
set_up(yaml_test_file)
Expand Down

0 comments on commit 4e6975e

Please sign in to comment.