--- /dev/null
+
+#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 );
+}
+
+