trick/trick_source/trick_swig/trick_swig.i
Alex Lin c6614fff75 Functions with enumerated default arguments bad
After digging around the SWIG issues database I found a feature
compactdefaultargs that creates a call to functions with default
arguments like it did before.  The important part is that the
code runs.

refs #176
2016-02-18 13:43:07 -06:00

109 lines
3.8 KiB
OpenEdge ABL

/* 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 <sstream>
#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, "<<msg<<")"<<std::endl
#endif
#ifndef SWIG_exception_fail
#define SWIG_exception_fail(code, msg) std::cout<<"SWIG_exception_fail(errorcode, "<<msg<<")"<<std::endl
#endif
#ifndef Py_RETURN_TRUE
#define Py_RETURN_TRUE return Py_INCREF(Py_True), Py_True
#endif
#ifndef Py_RETURN_FALSE
#define Py_RETURN_FALSE return Py_INCREF(Py_False), Py_False
#endif
#ifndef Py_RETURN_NONE
#define Py_RETURN_NONE return Py_INCREF(Py_None), Py_None
#endif
%}
// This pythoncode section overrides the default swig defined functions in each py file.
// It sets the "static" argument to 1 which disallows new attributes
// to be created in our classes.
// It also provides more information to the user about how to correct the problem
#if SWIG_VERSION > 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