]> SALOME platform Git repositories - modules/yacs.git/blobdiff - src/runtime/NeutralPythonConv.cxx
Salome HOME
copy tag mergefrom_BR_V0_1_CC_Salome_04oct07
[modules/yacs.git] / src / runtime / NeutralPythonConv.cxx
diff --git a/src/runtime/NeutralPythonConv.cxx b/src/runtime/NeutralPythonConv.cxx
new file mode 100644 (file)
index 0000000..ed6c156
--- /dev/null
@@ -0,0 +1,142 @@
+
+#include "NeutralPythonConv.hxx"
+#include "TypeConversions.hxx"
+#include "RuntimeSALOME.hxx"
+
+#include <iostream>
+#include <string>
+
+//#define _DEVDEBUG_
+#include "YacsTrace.hxx"
+
+using namespace YACS::ENGINE;
+using namespace std;
+
+void NeutralPyDouble::put(const void *data) throw(ConversionException)
+{
+  put((YACS::ENGINE::Any *)data);
+}
+
+//!Convert a YACS::ENGINE::Any (double) to a PyObject (PyFloat)
+/*!
+ *   \param data : YACS::ENGINE::Any object
+ */
+void NeutralPyDouble::put(YACS::ENGINE::Any *data) throw(ConversionException)
+{
+  double d = data->getDoubleValue();
+  PyObject *ob=PyFloat_FromDouble(d);
+  DEBTRACE( "ob refcnt: " << ob->ob_refcnt );
+  _port->put(ob);
+  Py_DECREF(ob);
+  DEBTRACE( "ob refcnt: " << ob->ob_refcnt );
+}
+
+
+void NeutralPyInt::put(const void *data) throw(ConversionException)
+{
+  put((YACS::ENGINE::Any *)data);
+}
+
+//!Convert a YACS::ENGINE::Any (integer) to a PyObject (PyLong)
+/*!
+ *   \param data : YACS::ENGINE::Any object
+ */
+void NeutralPyInt::put(YACS::ENGINE::Any *data) throw(ConversionException)
+{
+  int l = data->getIntValue();
+  PyObject *ob=PyLong_FromLong(l);
+  DEBTRACE( "ob refcnt: " << ob->ob_refcnt );
+  _port->put(ob);
+  Py_DECREF(ob);
+  DEBTRACE( "ob refcnt: " << ob->ob_refcnt );
+}
+
+void NeutralPyString::put(const void *data) throw(ConversionException)
+{
+  put((YACS::ENGINE::Any *)data);
+}
+
+//!Convert a YACS::ENGINE::Any (string) to a PyObject (PyString)
+/*!
+ *   \param data : YACS::ENGINE::Any object
+ */
+void NeutralPyString::put(YACS::ENGINE::Any *data) throw(ConversionException)
+{
+  string val=data->getStringValue();
+  PyObject *ob=PyString_FromString(val.c_str());
+  DEBTRACE( "ob refcnt: " << ob->ob_refcnt );
+  _port->put(ob);
+  Py_DECREF(ob);
+  DEBTRACE( "ob refcnt: " << ob->ob_refcnt );
+}
+
+void NeutralPyBool::put(const void *data) throw(ConversionException)
+{
+  put((YACS::ENGINE::Any *)data);
+}
+
+//!Convert a YACS::ENGINE::Any (bool) to a PyObject (PyLong)
+/*!
+ *   \param data : YACS::ENGINE::Any object
+ */
+void NeutralPyBool::put(YACS::ENGINE::Any *data) throw(ConversionException)
+{
+  int l = data->getBoolValue();
+  PyObject *ob=PyLong_FromLong(l);
+  DEBTRACE( "ob refcnt: " << ob->ob_refcnt );
+  _port->put(ob);
+  Py_DECREF(ob);
+  DEBTRACE( "ob refcnt: " << ob->ob_refcnt );
+}
+
+void NeutralPyObjref::put(const void *data) throw(ConversionException)
+{
+  put((YACS::ENGINE::Any *)data);
+}
+
+//!Convert a Neutral::Any Objref to a PyObject Objref
+/*!
+ *   \param data : Neutral::Any object
+ */
+void NeutralPyObjref::put(YACS::ENGINE::Any *data) throw(ConversionException)
+{
+  PyObject *ob;
+  {
+    InterpreterUnlocker loc;
+    ob=convertNeutralPyObject(edGetType(),data);
+  }
+  DEBTRACE( "ob refcnt: " << ob->ob_refcnt );
+  _port->put(ob);
+  Py_DECREF(ob);
+  DEBTRACE( "ob refcnt: " << ob->ob_refcnt );
+}
+
+void NeutralPySequence::put(const void *data) throw(ConversionException)
+{
+  put((YACS::ENGINE::Any *)data);
+}
+
+//!Convert a Neutral::Any sequence to a PyObject Sequence
+/*!
+ *   \param data : Neutral::Any object
+ */
+void NeutralPySequence::put(YACS::ENGINE::Any *data) throw(ConversionException)
+{
+  DEBTRACE( "--------NeutralPySequence::put" );
+  PyObject *ob;
+  {
+  InterpreterUnlocker loc;
+  ob=convertNeutralPyObject(edGetType(),data);
+  DEBTRACE( "ob refcnt: " << ob->ob_refcnt );
+#ifdef _DEVDEBUG_
+  cerr << "Sequence= ";
+  PyObject_Print(ob,stderr,Py_PRINT_RAW);
+  cerr << endl;
+#endif
+  }
+  _port->put(ob);
+  Py_DECREF(ob);
+  DEBTRACE( "ob refcnt: " << ob->ob_refcnt );
+}
+
+