Added _swig_setattr_nondynamic_instance_variable function call back for struct and moved it to right after struct declaration instead of at the end of the swig interface file. (#1795)

This commit is contained in:
Hong Chen 2024-10-15 10:41:17 -05:00 committed by GitHub
parent 48029fe031
commit 5a5379b975
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194

View File

@ -338,23 +338,6 @@ sub process_file() {
print OUT "$contents\n" ; print OUT "$contents\n" ;
print OUT $global_template_typedefs ; print OUT $global_template_typedefs ;
# Add _swig_setattr_nondynamic_instance_variable function for raising AttributeError for improper non-class attribute assingment in input processor.
# _swig_setattr_nondynamic_instance_variable function is added for each class in process_class subroutine.
foreach my $c ( @class_names ) {
if ( ! exists $class_typemap_printed{$c} ) {
my $c_ = $c ;
$c_ =~ s/\:/_/g ;
if ( $c !~ /::/ ) {
print OUT "\n#if SWIG_VERSION > 0x040000\n";
print OUT "%pythoncode %{\n" ;
print OUT " if '$c' in globals():\n";
print OUT " $c.__setattr__ = _swig_setattr_nondynamic_instance_variable(object.__setattr__)\n" ;
print OUT "%}\n" ;
print OUT "#endif\n";
}
}
}
# Add a trick_cast_as macro line for each class parsed in the file. These lines must appear at the bottom of the # Add a trick_cast_as macro line for each class parsed in the file. These lines must appear at the bottom of the
# file to ensure they are not in a namespace directive and they are after the #define statements they depend on. # file to ensure they are not in a namespace directive and they are after the #define statements they depend on.
undef %class_typemap_printed ; undef %class_typemap_printed ;
@ -785,7 +768,7 @@ sub process_typedef_struct($$$$) {
my ($typedef_struct_string , $contents_ref, $new_contents_ref , $class_names_ref) = @_ ; my ($typedef_struct_string , $contents_ref, $new_contents_ref , $class_names_ref) = @_ ;
my $extracted ; my $extracted ;
my ($tail , $struct_names, @struct_names) ; my ($tail , $my_struct_contents, $struct_names, @struct_names) ;
#print "*** typedef_struct_string = $typedef_struct_string ***\n" ; #print "*** typedef_struct_string = $typedef_struct_string ***\n" ;
@ -811,10 +794,12 @@ sub process_typedef_struct($$$$) {
foreach my $s ( @struct_names ) { foreach my $s ( @struct_names ) {
if ( $s !~ /\*/ ) { if ( $s !~ /\*/ ) {
push @$class_names_ref , $s ; push @$class_names_ref , $s ;
# Add _swig_setattr_nondynamic_instance_variable function for raising AttributeError for improper struct attribute assingment in input processor
$my_struct_contents .= "\n#if SWIG_VERSION > 0x040000\n\%pythoncode \%{\n if '$s' in globals():\n $s.__setattr__ = _swig_setattr_nondynamic_instance_variable(object.__setattr__)\n\%}\n#endif\n" ;
} }
} }
$$new_contents_ref .= $extracted . $tail ; $$new_contents_ref .= $extracted . $tail . $my_struct_contents ;
} }