From 48b7cadeca7a03fee1ed060380125207352462d4 Mon Sep 17 00:00:00 2001 From: kevstone Date: Thu, 1 Feb 2024 19:40:52 +0000 Subject: [PATCH] Added remaining base conversion validators --- .../code_object_converter/arg_converter.py | 2 +- .../array_access_converter.py | 3 +- .../code_objects_converter.py | 2 +- .../conditional_operation_converter.py | 3 +- .../constructor_function_converter.py | 4 +- .../conversion_pack/conversion_validation.py | 96 +++++++++++++++++-- .../data_member_converter.py | 2 +- .../declaration_specifier_converter.py | 2 +- .../destructor_function_converter.py | 3 +- .../for_statement_converter.py | 3 +- .../funcsig_converter.py | 4 +- .../funcsig_pointer_converter.py | 2 +- .../function_converter.py | 3 +- .../global_function_converter.py | 3 +- .../init_list_converter.py | 2 +- .../macro_definition_converter.py | 3 +- .../member_function_converter.py | 3 +- .../operation_converter.py | 3 +- .../paren_expression_converter.py | 3 +- .../return_statement_converter.py | 3 +- .../struct_arg_converter.py | 3 +- .../struct_member_access_converter.py | 3 +- .../unary_expression_converter.py | 3 +- .../value_declaration_reference_converter.py | 3 +- .../variable_declaration_converter.py | 4 +- .../virtual_member_function_converter.py | 3 +- 26 files changed, 131 insertions(+), 37 deletions(-) diff --git a/src/clang_convert/code_object_converter/arg_converter.py b/src/clang_convert/code_object_converter/arg_converter.py index 229b62ebb..e967d0414 100755 --- a/src/clang_convert/code_object_converter/arg_converter.py +++ b/src/clang_convert/code_object_converter/arg_converter.py @@ -26,7 +26,7 @@ class ArgConverter(code_interface_converter.CodeInterfaceConverter): cpp_arg = self.convert_funcbody_arg() debug.line("create_cpp_code_object", f"ArgConverter [OUT] cpp_arg=[{debug.as_debug_string(cpp_arg)}]") - return cpp_arg + return conversion_pack.conversion_validation.validate_arg(self._ccode_object, cpp_arg) def convert_funcsig_arg(self): carg = self._ccode_object diff --git a/src/clang_convert/code_object_converter/array_access_converter.py b/src/clang_convert/code_object_converter/array_access_converter.py index d45733e8d..4dcc4706a 100755 --- a/src/clang_convert/code_object_converter/array_access_converter.py +++ b/src/clang_convert/code_object_converter/array_access_converter.py @@ -13,4 +13,5 @@ class ArrayAccessConverter(code_interface_converter.CodeInterfaceConverter): cpp_name = conversion_funcs.convert_ccode_object(self._ccode_object.name, conversion_pack) cpp_index = conversion_funcs.convert_ccode_object(self._ccode_object.index, conversion_pack) - return array_access.ArrayAccess(cpp_name, cpp_index) + cpparray_access = array_access.ArrayAccess(cpp_name, cpp_index) + return conversion_pack.conversion_validation.validate_array_access(self._ccode_object, cpparray_access) diff --git a/src/clang_convert/code_object_converter/code_objects_converter.py b/src/clang_convert/code_object_converter/code_objects_converter.py index a97824ea0..0e8724e64 100755 --- a/src/clang_convert/code_object_converter/code_objects_converter.py +++ b/src/clang_convert/code_object_converter/code_objects_converter.py @@ -20,4 +20,4 @@ class CodeObjectsConverter(code_interface_converter.CodeInterfaceConverter): converted_object = conversion_funcs.convert_ccode_object(entry, conversion_pack) cpp_code_objects.add_code_object(converted_object) - return cpp_code_objects + return conversion_pack.conversion_validation.validate_code_objects(self._ccode_object, cpp_code_objects) diff --git a/src/clang_convert/code_object_converter/conditional_operation_converter.py b/src/clang_convert/code_object_converter/conditional_operation_converter.py index 880862f9f..832ee839a 100755 --- a/src/clang_convert/code_object_converter/conditional_operation_converter.py +++ b/src/clang_convert/code_object_converter/conditional_operation_converter.py @@ -14,4 +14,5 @@ class ConditionalOperationConverter(code_interface_converter.CodeInterfaceConver cpp_true_expression = conversion_funcs.convert_ccode_object(self._ccode_object.true_expression, conversion_pack) cpp_false_expression = conversion_funcs.convert_ccode_object(self._ccode_object.false_expression, conversion_pack) - return conditional_operation.ConditionalOperation(cpp_bool_expression, cpp_true_expression, cpp_false_expression) + cppconditional_operation = conditional_operation.ConditionalOperation(cpp_bool_expression, cpp_true_expression, cpp_false_expression) + return conversion_pack.conversion_validation.validate_conditional_operation(self._ccode_object, cppconditional_operation) diff --git a/src/clang_convert/code_object_converter/constructor_function_converter.py b/src/clang_convert/code_object_converter/constructor_function_converter.py index 710645e29..38e6825a7 100755 --- a/src/clang_convert/code_object_converter/constructor_function_converter.py +++ b/src/clang_convert/code_object_converter/constructor_function_converter.py @@ -12,5 +12,7 @@ class ConstructorFunctionConverter(member_function_converter.MemberFunctionConve def create_cpp_code_object(self, conversion_pack): cpp_funcsig = conversion_funcs.convert_ccode_object(self._ccode_object.funcsig, conversion_pack) cpp_body = conversion_funcs.convert_ccode_object(self._ccode_object.body, conversion_pack) - return constructor_function.ConstructorFunction(cpp_funcsig, cpp_body, conversion_pack.conversion_data.info.class_name, conversion_pack.conversion_data.info.super_class_name) + + cppconstructor_function = constructor_function.ConstructorFunction(cpp_funcsig, cpp_body, conversion_pack.conversion_data.info.class_name, conversion_pack.conversion_data.info.super_class_name) + return conversion_pack.conversion_validation.validate_constructor_function(self._ccode_object, cppconstructor_function) \ No newline at end of file diff --git a/src/clang_convert/code_object_converter/conversion_pack/conversion_validation.py b/src/clang_convert/code_object_converter/conversion_pack/conversion_validation.py index 2af477ef5..748021242 100755 --- a/src/clang_convert/code_object_converter/conversion_pack/conversion_validation.py +++ b/src/clang_convert/code_object_converter/conversion_pack/conversion_validation.py @@ -12,23 +12,101 @@ class ConversionValidation: # ---------- CodeObject Validation : Begin ----------------------------------------------------- # Perform full validation of converted C++ function call # The callee mapping is provided to check e.g. the function call is using the correct references etc - def validate_function_call(self, cfunction_call, cppfunction_call, callee_funcsig_mapping): - return cppfunction_call - - def validate_variable_declaration(self, cvariable_declaration, cppvariable_declaration): - return cppvariable_declaration - - def validate_unary_operation(self, cunary_operation, cppunary_operation): - return cppunary_operation + def validate_arg(self, carg, cpparg): + return cpparg + + def validate_array_access(self, carray_access, cpparray_access): + return cpparray_access def validate_binary_operation(self, cbinary_operation, cppbinary_operation): return cppbinary_operation + def validate_code_objects(self, ccode_objects, cppcode_objects): + return cppcode_objects + + def validate_compound_statement(self, ccompound_statement, cppcompound_statement): + return cppcompound_statement + + def validate_conditional_operation(self, cconditional_operation, cppconditional_operation): + return cppconditional_operation + + def validate_constructor_function(self, cconstructor_function, cppconstructor_function): + return cppconstructor_function + + def validate_data_member(self, cdata_member, cppdata_member): + return cppdata_member + + def validate_declaration_specifier(self, cdeclaration_specifier, cppdeclaration_specifier): + return cppdeclaration_specifier + + def validate_destructor_function(self, cdestructor_function, cppdestructor_function): + return cppdestructor_function + + def validate_for_statement(self, cfor_statement, cppfor_statement): + return cppfor_statement + + def validate_funcsig(self, cfuncsig, cppfuncsig): + return cppfuncsig + + def validate_funcsig_pointer(self, cfuncsig_pointer, cppfuncsig_pointer): + return cppfuncsig_pointer + + def validate_function_call(self, cfunction_call, cppfunction_call, callee_funcsig_mapping): + return cppfunction_call + + def validate_function(self, cfunction, cppfunction): + return cppfunction + + def validate_global_function(self, cglobal_function, cppglobal_function): + return cppglobal_function + def validate_if_statement(self, cif_statement, cppif_statement): return cppif_statement + def validate_init_list(self, cinit_list, cppinit_list): + return cppinit_list + + def validate_literal(self, cliteral, cppliteral): + return cppliteral + + def validate_macro_definition(self, cmacro_definition, cppmacro_definition): + return cppmacro_definition + def validate_macro_instantiation(self, cmacro_instantiation, cppmacro_instantiation): return cppmacro_instantiation + def validate_member_function(self, cmember_function, cppmember_function): + return cppmember_function + + def validate_operation(self, coperation, cppoperation): + return cppoperation + + def validate_paren_expression(self, cparen_expression, cppparen_expression): + return cppparen_expression + + def validate_return_statement(self, creturn_statement, cppreturn_statement): + return cppreturn_statement + + def validate_struct_arg(self, cstruct_arg, cppstruct_arg): + return cppstruct_arg + + def validate_struct_member_access(self, cstruct_member_access, cppstruct_member_access): + return cppstruct_member_access + + def validate_unary_expression(self, cunary_expression, cppunary_expression): + return cppunary_expression + + def validate_unary_operation(self, cunary_operation, cppunary_operation): + return cppunary_operation + + def validate_value_declaration_reference(self, cvalue_declaration_reference, cppvalue_declaration_reference): + return cppvalue_declaration_reference + + def validate_variable_declaration(self, cvariable_declaration, cppvariable_declaration): + return cppvariable_declaration + + def validate_virtual_member_function(self, cvirtual_member_function, cppvirtual_member_function): + return cppvirtual_member_function + # ---------- CodeObject Validation : End ----------------------------------------------------- - + \ No newline at end of file diff --git a/src/clang_convert/code_object_converter/data_member_converter.py b/src/clang_convert/code_object_converter/data_member_converter.py index 86a6401b4..6e40bcff1 100755 --- a/src/clang_convert/code_object_converter/data_member_converter.py +++ b/src/clang_convert/code_object_converter/data_member_converter.py @@ -40,4 +40,4 @@ class DataMemberConverter(arg_converter.ArgConverter): debug.line("create_cpp_code_object", f"Adding data member mapping cmember=[{debug.as_debug_string(cmember)}] cppmember=[{debug.as_debug_string(cppmember)}]") debug.line("create_cpp_code_object", f"DataMemberConverter [OUT] cppmember=[{debug.as_debug_string(cppmember)}]") - return cppmember + return conversion_pack.conversion_validation.validate_data_member(cmember, cppmember) diff --git a/src/clang_convert/code_object_converter/declaration_specifier_converter.py b/src/clang_convert/code_object_converter/declaration_specifier_converter.py index 650955ba4..4992d7e64 100755 --- a/src/clang_convert/code_object_converter/declaration_specifier_converter.py +++ b/src/clang_convert/code_object_converter/declaration_specifier_converter.py @@ -26,5 +26,5 @@ class DeclSpecConverter(code_interface_converter.CodeInterfaceConverter): conversion_pack.conversion_data.add_funcbody_type_mapping(cdecl_spec, cpp_decl_spec) debug.line("create_cpp_code_object", f"DeclSpecConverter [OUT] DeclSpec conversion: [{cdecl_spec.as_string()}] [{cdecl_spec}] -> [{cpp_decl_spec.as_string()}]") - return cpp_decl_spec + return conversion_pack.conversion_validation.validate_declaration_specifier(cdecl_spec, cpp_decl_spec) \ No newline at end of file diff --git a/src/clang_convert/code_object_converter/destructor_function_converter.py b/src/clang_convert/code_object_converter/destructor_function_converter.py index 542696a59..7cd46ebcc 100755 --- a/src/clang_convert/code_object_converter/destructor_function_converter.py +++ b/src/clang_convert/code_object_converter/destructor_function_converter.py @@ -13,5 +13,6 @@ class DestructorFunctionConverter(member_function_converter.MemberFunctionConver cpp_funcsig = conversion_funcs.convert_ccode_object(self._ccode_object.funcsig, conversion_pack) cpp_body = conversion_funcs.convert_ccode_object(self._ccode_object.body, conversion_pack) - return destructor_function.DestructorFunction(cpp_funcsig, cpp_body) + cppdestructor_function = destructor_function.DestructorFunction(cpp_funcsig, cpp_body) + return conversion_pack.conversion_validation.validate_destructor_function(self._ccode_object, cppdestructor_function) \ No newline at end of file diff --git a/src/clang_convert/code_object_converter/for_statement_converter.py b/src/clang_convert/code_object_converter/for_statement_converter.py index 7a9ed7b5b..7f900124f 100755 --- a/src/clang_convert/code_object_converter/for_statement_converter.py +++ b/src/clang_convert/code_object_converter/for_statement_converter.py @@ -15,5 +15,6 @@ class ForStatementConverter(code_interface_converter.CodeInterfaceConverter): cpp_iteration_expression = conversion_funcs.convert_ccode_object(self._ccode_object.iteration_expression, conversion_pack) cpp_statement = conversion_funcs.convert_ccode_object(self._ccode_object.statement, conversion_pack) - return for_statement.ForStatement(cpp_init_statement, cpp_condition, cpp_iteration_expression, cpp_statement) + cppfor_statement = for_statement.ForStatement(cpp_init_statement, cpp_condition, cpp_iteration_expression, cpp_statement) + return conversion_pack.conversion_validation.validate_for_statement(self._ccode_object, cppfor_statement) \ No newline at end of file diff --git a/src/clang_convert/code_object_converter/funcsig_converter.py b/src/clang_convert/code_object_converter/funcsig_converter.py index d639195df..5aaa87d0f 100755 --- a/src/clang_convert/code_object_converter/funcsig_converter.py +++ b/src/clang_convert/code_object_converter/funcsig_converter.py @@ -44,8 +44,8 @@ class FuncSigConverter(code_interface_converter.CodeInterfaceConverter): # Update the settings that we don't need (want?) to store in the map cppfuncsig.is_declaration = cfuncsig.is_declaration - return cppfuncsig - + return conversion_pack.conversion_validation.validate_funcsig(cfuncsig, cppfuncsig) + # The following functions are called when there isn't a stored mapping, so we need to work the mappings out! def is_cpp_static(self): diff --git a/src/clang_convert/code_object_converter/funcsig_pointer_converter.py b/src/clang_convert/code_object_converter/funcsig_pointer_converter.py index e8df82c83..caaa21b39 100755 --- a/src/clang_convert/code_object_converter/funcsig_pointer_converter.py +++ b/src/clang_convert/code_object_converter/funcsig_pointer_converter.py @@ -43,4 +43,4 @@ class FuncSigPointerConverter(funcsig_converter.FuncSigConverter): # Update the settings that we don't need (want?) to store in the map cppfuncsig_pointer.is_declaration = self._ccode_object.is_declaration - return cppfuncsig_pointer \ No newline at end of file + return conversion_pack.conversion_validation.validate_funcsig_pointer(self._ccode_object, cppfuncsig_pointer) \ No newline at end of file diff --git a/src/clang_convert/code_object_converter/function_converter.py b/src/clang_convert/code_object_converter/function_converter.py index 3eb797533..ce7d081ba 100755 --- a/src/clang_convert/code_object_converter/function_converter.py +++ b/src/clang_convert/code_object_converter/function_converter.py @@ -13,5 +13,6 @@ class FunctionConverter(code_interface_converter.CodeInterfaceConverter): cpp_funcsig = conversion_funcs.convert_ccode_object(self._ccode_object.funcsig, conversion_pack) cpp_body = conversion_funcs.convert_ccode_object(self._ccode_object.body, conversion_pack) - return function.Function(cpp_funcsig, cpp_body) + cppfunction = function.Function(cpp_funcsig, cpp_body) + return conversion_pack.conversion_validation.validate_function(self._ccode_object, cppfunction) \ No newline at end of file diff --git a/src/clang_convert/code_object_converter/global_function_converter.py b/src/clang_convert/code_object_converter/global_function_converter.py index e4ce3f5ea..f06d3512f 100755 --- a/src/clang_convert/code_object_converter/global_function_converter.py +++ b/src/clang_convert/code_object_converter/global_function_converter.py @@ -23,5 +23,6 @@ class GlobalFunctionConverter(function_converter.FunctionConverter): cpp_code_obj = conversion_funcs.convert_ccode_object(entry, self._conversion_pack) cpp_body.add_code_object(cpp_code_obj) - return global_function.GlobalFunction(cpp_body) + cppglobal_function = global_function.GlobalFunction(cpp_body) + return conversion_pack.conversion_validation.validate_global_function(self._ccode_object, cppglobal_function) diff --git a/src/clang_convert/code_object_converter/init_list_converter.py b/src/clang_convert/code_object_converter/init_list_converter.py index ceabeb5c5..2a0f8bf01 100755 --- a/src/clang_convert/code_object_converter/init_list_converter.py +++ b/src/clang_convert/code_object_converter/init_list_converter.py @@ -17,4 +17,4 @@ class InitListConverter(code_interface_converter.CodeInterfaceConverter): cpp_entry = conversion_funcs.convert_ccode_object(entry, conversion_pack) cpp_init_list.add_entry(cpp_entry) - return cpp_init_list + return conversion_pack.conversion_validation.validate_init_list(self._ccode_object, cpp_init_list) diff --git a/src/clang_convert/code_object_converter/macro_definition_converter.py b/src/clang_convert/code_object_converter/macro_definition_converter.py index a17257fc7..54f8c5c72 100755 --- a/src/clang_convert/code_object_converter/macro_definition_converter.py +++ b/src/clang_convert/code_object_converter/macro_definition_converter.py @@ -11,4 +11,5 @@ class MacroDefinitionConverter(code_interface_converter.CodeInterfaceConverter): def create_cpp_code_object(self, conversion_pack): # For now, just return a copy... - return macro_definition.MacroDefinition(self._ccode_object.as_lines()) + cppmacro_defintion = macro_definition.MacroDefinition(self._ccode_object.as_lines()) + return conversion_pack.conversion_validation.validate_macro_definition(self._ccode_object, cppmacro_defintion) diff --git a/src/clang_convert/code_object_converter/member_function_converter.py b/src/clang_convert/code_object_converter/member_function_converter.py index cbe51bca9..216a9dc62 100755 --- a/src/clang_convert/code_object_converter/member_function_converter.py +++ b/src/clang_convert/code_object_converter/member_function_converter.py @@ -13,5 +13,6 @@ class MemberFunctionConverter(function_converter.FunctionConverter): cpp_funcsig = conversion_funcs.convert_ccode_object(self._ccode_object.funcsig, conversion_pack) cpp_body = conversion_funcs.convert_ccode_object(self._ccode_object.body, conversion_pack) - return member_function.MemberFunction(cpp_funcsig, cpp_body) + cppmember_function = member_function.MemberFunction(cpp_funcsig, cpp_body) + return conversion_pack.conversion_validation.validate_member_function(self._ccode_object, cppmember_function) \ No newline at end of file diff --git a/src/clang_convert/code_object_converter/operation_converter.py b/src/clang_convert/code_object_converter/operation_converter.py index cb206488c..dc036b337 100755 --- a/src/clang_convert/code_object_converter/operation_converter.py +++ b/src/clang_convert/code_object_converter/operation_converter.py @@ -11,4 +11,5 @@ class OperationConverter(code_interface_converter.CodeInterfaceConverter): def create_cpp_code_object(self, conversion_pack): # By default we just return a copy of the value - return operation.Operation(self._ccode_object.value) + cppoperation = operation.Operation(self._ccode_object.value) + return conversion_pack.conversion_validation.validate_operation(self._ccode_object, cppoperation) diff --git a/src/clang_convert/code_object_converter/paren_expression_converter.py b/src/clang_convert/code_object_converter/paren_expression_converter.py index 97a4a2464..3862ab05b 100755 --- a/src/clang_convert/code_object_converter/paren_expression_converter.py +++ b/src/clang_convert/code_object_converter/paren_expression_converter.py @@ -12,4 +12,5 @@ class ParenExpressionConverter(code_interface_converter.CodeInterfaceConverter): def create_cpp_code_object(self, conversion_pack): cpp_expression = conversion_funcs.convert_ccode_object(self._ccode_object.expression, conversion_pack) - return paren_expression.ParenExpression(cpp_expression) + cppparen_expression = paren_expression.ParenExpression(cpp_expression) + return conversion_pack.conversion_validation.validate_paren_expression(self._ccode_object, cppparen_expression) diff --git a/src/clang_convert/code_object_converter/return_statement_converter.py b/src/clang_convert/code_object_converter/return_statement_converter.py index b888a2167..d80c6af5f 100755 --- a/src/clang_convert/code_object_converter/return_statement_converter.py +++ b/src/clang_convert/code_object_converter/return_statement_converter.py @@ -12,4 +12,5 @@ class ReturnStatementConverter(code_interface_converter.CodeInterfaceConverter): def create_cpp_code_object(self, conversion_pack): cpp_expression = conversion_funcs.convert_ccode_object(self._ccode_object.expression, conversion_pack) - return return_statement.ReturnStatement(cpp_expression) + cppreturn_statement = return_statement.ReturnStatement(cpp_expression) + return conversion_pack.conversion_validation.validate_return_statement(self._ccode_object, cppreturn_statement) diff --git a/src/clang_convert/code_object_converter/struct_arg_converter.py b/src/clang_convert/code_object_converter/struct_arg_converter.py index 6cd58edf9..e0fcaa638 100755 --- a/src/clang_convert/code_object_converter/struct_arg_converter.py +++ b/src/clang_convert/code_object_converter/struct_arg_converter.py @@ -26,4 +26,5 @@ class StructArgConverter(code_interface_converter.CodeInterfaceConverter): cpp_member = conversion_funcs.convert_ccode_object(member, conversion_pack) cpp_members.append(cpp_member) - return struct_arg.StructArg(cpp_decl_spec.type, cpp_members) + cppstruct_arg = struct_arg.StructArg(cpp_decl_spec.type, cpp_members) + return conversion_pack.conversion_validation.validate_struct_arg(self._ccode_object, cppstruct_arg) diff --git a/src/clang_convert/code_object_converter/struct_member_access_converter.py b/src/clang_convert/code_object_converter/struct_member_access_converter.py index 81d9ea374..52425c290 100755 --- a/src/clang_convert/code_object_converter/struct_member_access_converter.py +++ b/src/clang_convert/code_object_converter/struct_member_access_converter.py @@ -28,4 +28,5 @@ class StructMemberAccessConverter(code_interface_converter.CodeInterfaceConverte cpp_index = conversion_funcs.convert_ccode_object(cstruct_member_access.index, conversion_pack) cpp_member = conversion_funcs.convert_ccode_object(cstruct_member_access.member, conversion_pack) - return struct_member_access.StructMemberAccess(cpp_access, cpp_name, cpp_index, cpp_member) + cppstruct_member_access = struct_member_access.StructMemberAccess(cpp_access, cpp_name, cpp_index, cpp_member) + return conversion_pack.conversion_validation.validate_struct_member_access(self._ccode_object, cppstruct_member_access) diff --git a/src/clang_convert/code_object_converter/unary_expression_converter.py b/src/clang_convert/code_object_converter/unary_expression_converter.py index adbb89993..e6ec2dd11 100755 --- a/src/clang_convert/code_object_converter/unary_expression_converter.py +++ b/src/clang_convert/code_object_converter/unary_expression_converter.py @@ -13,4 +13,5 @@ class UnaryExpressionConverter(code_interface_converter.CodeInterfaceConverter): cpp_keyword = conversion_funcs.convert_ccode_object(self._ccode_object.keyword, conversion_pack) cpp_expression = conversion_funcs.convert_ccode_object(self._ccode_object.expression, conversion_pack) - return unary_expression.UnaryExpression(cpp_keyword, cpp_expression) + cppunary_expression = unary_expression.UnaryExpression(cpp_keyword, cpp_expression) + return conversion_pack.conversion_validation.validate_unary_expression(self._ccode_object, cppunary_expression) diff --git a/src/clang_convert/code_object_converter/value_declaration_reference_converter.py b/src/clang_convert/code_object_converter/value_declaration_reference_converter.py index 4564c2926..dabe84e03 100755 --- a/src/clang_convert/code_object_converter/value_declaration_reference_converter.py +++ b/src/clang_convert/code_object_converter/value_declaration_reference_converter.py @@ -39,4 +39,5 @@ class ValueDeclarationReferenceConverter(code_interface_converter.CodeInterfaceC cppdecl_ref_expr_value = conversion_funcs.convert_ccode_object(cdecl_ref_expr_value, conversion_pack) debug.line("create_cpp_code_object", f"ValueDeclarationReferenceConverter [4] cdecl_ref_expr_value=[{debug.as_debug_string(cdecl_ref_expr_value)}] cppdecl_ref_expr_value=[{debug.as_debug_string(cppdecl_ref_expr_value)}]") - return value_declaration_reference.ValueDeclarationReference(cppdecl_ref_expr_value) + cppvalue_declaration_reference = value_declaration_reference.ValueDeclarationReference(cppdecl_ref_expr_value) + return conversion_pack.conversion_validation.validate_value_declaration_reference(self._ccode_object, cppvalue_declaration_reference) diff --git a/src/clang_convert/code_object_converter/variable_declaration_converter.py b/src/clang_convert/code_object_converter/variable_declaration_converter.py index 643a63ac4..1d5faff9e 100755 --- a/src/clang_convert/code_object_converter/variable_declaration_converter.py +++ b/src/clang_convert/code_object_converter/variable_declaration_converter.py @@ -21,7 +21,5 @@ class VariableDeclarationConverter(code_interface_converter.CodeInterfaceConvert cpp_value = conversion_funcs.convert_ccode_object(self._ccode_object.value, conversion_pack) cpp_variable_declaration = variable_declaration.VariableDeclaration(cpp_variable, cpp_value) - cpp_variable_declaration = conversion_pack.conversion_validation.validate_variable_declaration(self._ccode_object, cpp_variable_declaration) - - return cpp_variable_declaration + return conversion_pack.conversion_validation.validate_variable_declaration(self._ccode_object, cpp_variable_declaration) \ No newline at end of file diff --git a/src/clang_convert/code_object_converter/virtual_member_function_converter.py b/src/clang_convert/code_object_converter/virtual_member_function_converter.py index 640c81ae1..58a614d0b 100755 --- a/src/clang_convert/code_object_converter/virtual_member_function_converter.py +++ b/src/clang_convert/code_object_converter/virtual_member_function_converter.py @@ -13,5 +13,6 @@ class VirtualMemberFunctionConverter(member_function_converter.MemberFunctionCon cpp_funcsig = conversion_funcs.convert_ccode_object(self._ccode_object.funcsig, conversion_pack) cpp_body = conversion_funcs.convert_ccode_object(self._ccode_object.body, conversion_pack) - return virtual_member_function.VirtualMemberFunction(cpp_funcsig, cpp_body) + cppvirtual_member_function = virtual_member_function.VirtualMemberFunction(cpp_funcsig, cpp_body) + return conversion_pack.conversion_validation.validate_virtual_member_function(self._ccode_object, cppvirtual_member_function) \ No newline at end of file