X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModelAPI%2FModelAPI.i;h=6fd73dedba08d1c0fc98e94f641159c4fd032477;hb=ced98007eba772ef7ef3a3e7d98fee8477e8de07;hp=23c6d804365baa13edd81d377c3d67fe6bc23bac;hpb=02fc4b8cac85322c7bb8c5a00f7fafa3665a0fc6;p=modules%2Fshaper.git diff --git a/src/ModelAPI/ModelAPI.i b/src/ModelAPI/ModelAPI.i index 23c6d8043..6fd73dedb 100644 --- a/src/ModelAPI/ModelAPI.i +++ b/src/ModelAPI/ModelAPI.i @@ -49,6 +49,7 @@ %shared_ptr(ModelAPI_AttributeInteger) %shared_ptr(ModelAPI_AttributeIntArray) %shared_ptr(ModelAPI_AttributeString) +%shared_ptr(ModelAPI_AttributeStringArray) %shared_ptr(ModelAPI_AttributeReference) %shared_ptr(ModelAPI_AttributeRefAttr) %shared_ptr(ModelAPI_AttributeRefList) @@ -56,6 +57,7 @@ %shared_ptr(ModelAPI_AttributeBoolean) %shared_ptr(ModelAPI_AttributeSelection) %shared_ptr(ModelAPI_AttributeSelectionList) +%shared_ptr(ModelAPI_AttributeTables) %shared_ptr(ModelAPI_Validator) %shared_ptr(ModelAPI_AttributeValidator) %shared_ptr(ModelAPI_FeatureValidator) @@ -64,9 +66,34 @@ %shared_ptr(ModelAPI_ResultBody) %shared_ptr(ModelAPI_ResultPart) %shared_ptr(ModelAPI_ResultGroup) +%shared_ptr(ModelAPI_ResultField) %shared_ptr(ModelAPI_ResultParameter) %shared_ptr(ModelAPI_ResultCompSolid) +%typecheck(SWIG_TYPECHECK_POINTER) const ModelAPI_AttributeTables::Value { + $1 = (PyFloat_Check($input) || PyInt_Check($input) || PyLong_Check($input) || PyString_Check($input) || PyBool_Check($input)) ? 1 : 0; +} + +// Tables Value reading as int, double, boolean or string +%typemap(in) const ModelAPI_AttributeTables::Value { + if (PyInt_Check($input)) { + $1.myInt = int(PyInt_AsLong($input)); + $1.myDouble = double(PyInt_AsLong($input)); + $1.myBool = PyInt_AsLong($input) != 0; + } else if (PyFloat_Check($input)) { + $1.myInt = int(PyFloat_AsDouble($input)); + $1.myDouble = PyFloat_AsDouble($input); + } else if (PyBool_Check($input)) { + $1.myBool = $input == Py_True; + } else if (PyString_Check($input)) { + $1.myStr = PyString_AsString($input); + } else if ((SWIG_ConvertPtr($input, (void **)&$1, $1_descriptor, SWIG_POINTER_EXCEPTION)) == 0) { + } else { + PyErr_SetString(PyExc_ValueError, "Tables value must be int, double, string or bool."); + return NULL; + } +} + // all supported interfaces %include "ModelAPI_Entity.h" %include "ModelAPI_Document.h" @@ -83,6 +110,7 @@ %include "ModelAPI_AttributeInteger.h" %include "ModelAPI_AttributeIntArray.h" %include "ModelAPI_AttributeString.h" +%include "ModelAPI_AttributeStringArray.h" %include "ModelAPI_AttributeReference.h" %include "ModelAPI_AttributeRefAttr.h" %include "ModelAPI_AttributeBoolean.h" @@ -90,6 +118,7 @@ %include "ModelAPI_AttributeSelectionList.h" %include "ModelAPI_AttributeRefList.h" %include "ModelAPI_AttributeRefAttrList.h" +%include "ModelAPI_AttributeTables.h" %include "ModelAPI_Validator.h" %include "ModelAPI_AttributeValidator.h" %include "ModelAPI_FeatureValidator.h" @@ -98,6 +127,7 @@ %include "ModelAPI_ResultBody.h" %include "ModelAPI_ResultPart.h" %include "ModelAPI_ResultGroup.h" +%include "ModelAPI_ResultField.h" %include "ModelAPI_ResultParameter.h" %include "ModelAPI_Tools.h" %include "ModelAPI_ResultCompSolid.h" @@ -123,6 +153,7 @@ template std::shared_ptr shared_ptr_cast(std::shared_ptr %template(modelAPI_ResultPart) shared_ptr_cast; %template(modelAPI_ResultParameter) shared_ptr_cast; %template(modelAPI_ResultGroup) shared_ptr_cast; +%template(modelAPI_ResultField) shared_ptr_cast; %template(modelAPI_ResultCompSolid) shared_ptr_cast; // Attribute casts @@ -132,6 +163,7 @@ template std::shared_ptr shared_ptr_cast(std::shared_ptr %template(modelAPI_AttributeInteger) shared_ptr_cast; %template(modelAPI_AttributeIntArray) shared_ptr_cast; %template(modelAPI_AttributeString) shared_ptr_cast; +%template(modelAPI_AttributeStringArray) shared_ptr_cast; %template(modelAPI_AttributeReference) shared_ptr_cast; %template(modelAPI_AttributeRefAttr) shared_ptr_cast; %template(modelAPI_AttributeBoolean) shared_ptr_cast; @@ -139,3 +171,4 @@ template std::shared_ptr shared_ptr_cast(std::shared_ptr %template(modelAPI_AttributeSelectionList) shared_ptr_cast; %template(modelAPI_AttributeRefList) shared_ptr_cast; %template(modelAPI_AttributeRefAttrList) shared_ptr_cast; +%template(modelAPI_AttributeTables) shared_ptr_cast;