/* include support for STLs */ %include "std_list.i" %include "std_map.i" %include "std_string.i" %include "std_vector.i" %include "trick_swig/swig_extend_str.i" %include "trick_swig/swig_class_typedef.i" %include "trick_swig/cast_as.i" %include "trick_swig/swig_int_typemap.i" /* compactdefaultargs fixes a bug with enumeration default arguments not being recogized in function calls starting in swig 3.0.x */ %feature("compactdefaultargs") ; /* SWIG can't understand GNU C keyword "__attribute__" */ #ifdef SWIG #define __attribute__(x) #endif %{ #include #include "sim_services/Units/include/UnitsMap.hh" #include "trick_utils/units/include/Unit.hh" #include "sim_services/MemoryManager/include/MemoryManager.hh" #include "sim_services/MemoryManager/include/reference.h" #include "sim_services/MemoryManager/include/memorymanager_c_intf.h" #include "sim_services/CheckPointAgent/include/PythonPrint.hh" #ifndef SWIG_as_voidptr #define SWIG_as_voidptr(a) const_cast< void * >(static_cast< const void * >(a)) #endif #ifndef SWIG_as_voidptrptr #define SWIG_as_voidptrptr(a) ((void)SWIG_as_voidptr(*a),reinterpret_cast< void** >(a)) #endif #ifndef SWIG_IsOK #define SWIG_IsOK(r) (r >= 0) #endif #ifndef SWIG_Error #define SWIG_Error(code, msg) std::cout<<"SWIG_Error(errorcode, "< 0x010321 %pythoncode %{ def _swig_getattr(self,class_type,name): if (name == "thisown"): return self.this.own() method = class_type.__swig_getmethods__.get(name,None) if method: return method(self) all_keys = [attr for attr in dir(class_type) if not attr.startswith('__')and attr != '_s' ] data_keys = sorted(class_type.__swig_setmethods__.keys()) method_keys = [ x for x in all_keys if x not in data_keys ] raise AttributeError("Type %s does not contain member %s.\n%s data = %s\n%s methods = %s" % (self.__class__.__name__,name,self.__class__.__name__,data_keys,self.__class__.__name__,method_keys)) def _swig_setattr_nondynamic(self,class_type,name,value,static=1): if (name == "thisown"): return self.this.own(value) if (name == "this"): # this line is changed to handle older swigs that used PySwigObject instead of the current SwigPyObject if type(value).__name__ == 'SwigPyObject' or type(value).__name__ == 'PySwigObject' : self.__dict__[name] = value return method = class_type.__swig_setmethods__.get(name,None) if method: return method(self,value) if (not static) or hasattr(self,name): self.__dict__[name] = value else: all_keys = [attr for attr in dir(class_type) if not attr.startswith('__') and attr != '_s' ] data_keys = sorted(class_type.__swig_setmethods__.keys()) method_keys = [ x for x in all_keys if x not in data_keys ] raise AttributeError("Type %s does not contain member %s.\n%s data = %s\n%s methods = %s" % (self.__class__.__name__,name,self.__class__.__name__,data_keys,self.__class__.__name__,method_keys)) def _swig_setattr(self,class_type,name,value): return _swig_setattr_nondynamic(self,class_type,name,value,1) %} #endif