coriolis/hurricane/src/isobar/PyTransformation.cpp

589 lines
20 KiB
C++
Raw Normal View History

2008-03-06 10:46:43 -06:00
//
// $Id: PyTransformation.cpp,v 1.17 2007/01/30 14:47:24 cobell Exp $
//
// x-----------------------------------------------------------------x
// | |
// | C O R I O L I S |
// | I s o b a r - Hurricane / Python Interface |
// | |
// | Author : Jean-Paul CHAPUT |
// | E-mail : Jean-Paul.Chaput@asim.lip6.fr |
// | =============================================================== |
// | C++ Module : "./PyTransformation.cpp" |
// | *************************************************************** |
// | U p d a t e s |
// | |
// x-----------------------------------------------------------------x
#include "hurricane/isobar/PyPoint.h"
#include "hurricane/isobar/PyBox.h"
#include "hurricane/isobar/PyTransformation.h"
2008-03-06 10:46:43 -06:00
namespace Isobar {
2008-03-28 04:48:47 -05:00
using namespace Hurricane;
2008-03-06 10:46:43 -06:00
extern "C" {
#define METHOD_HEAD(function) GENERIC_METHOD_HEAD(Transformation,transf,function)
// x=================================================================x
// | "PyTransformation" Python Module Code Part |
// x=================================================================x
#if defined(__PYTHON_MODULE__)
// x-------------------------------------------------------------x
// | Global Constants Loading |
// x-------------------------------------------------------------x
extern void TransformationLoadConstants ( PyObject* dictionnary )
{
PyObject* constant;
LOAD_CONSTANT ( Transformation::Orientation::ID, "OrientationID" )
LOAD_CONSTANT ( Transformation::Orientation::R1, "OrientationR1" )
LOAD_CONSTANT ( Transformation::Orientation::R2, "OrientationR2" )
LOAD_CONSTANT ( Transformation::Orientation::R3, "OrientationR3" )
LOAD_CONSTANT ( Transformation::Orientation::MX, "OrientationMX" )
LOAD_CONSTANT ( Transformation::Orientation::XR, "OrientationXR" )
LOAD_CONSTANT ( Transformation::Orientation::MY, "OrientationMY" )
LOAD_CONSTANT ( Transformation::Orientation::YR, "OrientationYR" )
}
// x-------------------------------------------------------------x
// | "PyTransformation" Attribute Methods |
// x-------------------------------------------------------------x
// Standart Accessors (Attributes).
2008-03-17 08:54:33 -05:00
DirectGetLongAttribute(PyTransformation_getTx, getTx, PyTransformation, Transformation)
DirectGetLongAttribute(PyTransformation_getTy, getTy, PyTransformation, Transformation)
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
// Standard destroy (Attribute).
DirectDestroyAttribute(PyTransformation_destroy, PyTransformation)
2008-03-06 10:46:43 -06:00
// ---------------------------------------------------------------
2008-03-17 08:54:33 -05:00
// Attribute Method : "PyBox_getTranslation ()"
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
static PyObject* PyTransformation_getTranslation ( PyTransformation *self ) {
trace << "PyBox_getTranslation ()" << endl;
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
METHOD_HEAD ( "Translation.getTranslation()" )
2008-03-06 10:46:43 -06:00
PyPoint* pyPoint = PyObject_NEW ( PyPoint, &PyTypePoint );
if (pyPoint == NULL) { return NULL; }
trace_in ();
trace << "new PyPoint [" << hex << pyPoint << "]" << endl;
trace_out ();
HTRY
pyPoint->_object = new Point ( transf->getTranslation() );
HCATCH
return ( (PyObject*)pyPoint );
}
// ---------------------------------------------------------------
2008-03-17 08:54:33 -05:00
// Attribute Method : "PyTransformation_getOrientation ()"
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
static PyObject* PyTransformation_getOrientation ( PyTransformation *self ) {
trace << "PyTransformation_getOrientation ()" << endl;
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
METHOD_HEAD ( "Translation.getOrientation()" )
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
return ( (PyObject*)Py_BuildValue("i",(long)transf->getOrientation().getCode()) );
2008-03-06 10:46:43 -06:00
}
// ---------------------------------------------------------------
2008-03-17 08:54:33 -05:00
// Attribute Method : "PyTransformation_getX ()"
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
static PyObject* PyTransformation_getX ( PyTransformation *self, PyObject* args )
2008-03-06 10:46:43 -06:00
{
2008-03-17 08:54:33 -05:00
trace << "PyTransformation_getX ()" << endl;
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
METHOD_HEAD ( "Transformation.getX()" )
2008-03-06 10:46:43 -06:00
PyObject* arg0;
PyObject* arg1;
long result = 0;
HTRY
2008-11-17 15:55:03 -06:00
__cs.init ("Transformation.getX");
2008-03-17 08:54:33 -05:00
if ( ! PyArg_ParseTuple(args,"|O&O&:Transformation.getX",Converter,&arg0,Converter,&arg1) )
2008-03-06 10:46:43 -06:00
return ( NULL );
2008-03-17 08:54:33 -05:00
if ( __cs.getObjectIds() == POINT_ARG ) { result = transf->getX ( *PYPOINT_O(arg0) ); }
else if ( __cs.getObjectIds() == INTS2_ARG ) { result = transf->getX ( PyInt_AsLong(arg0)
2008-03-06 10:46:43 -06:00
, PyInt_AsLong(arg1) ); }
else {
2008-03-17 08:54:33 -05:00
PyErr_SetString ( ConstructorError, "invalid number of parameters for Tranformation.getX()." );
2008-03-06 10:46:43 -06:00
return ( NULL );
}
HCATCH
return ( (PyObject*)Py_BuildValue("i",result) );
}
// ---------------------------------------------------------------
2008-03-17 08:54:33 -05:00
// Attribute Method : "PyTransformation_getY ()"
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
static PyObject* PyTransformation_getY ( PyTransformation *self, PyObject* args )
2008-03-06 10:46:43 -06:00
{
2008-03-17 08:54:33 -05:00
trace << "PyTransformation_getY ()" << endl;
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
METHOD_HEAD ( "Transformation.getY()" )
2008-03-06 10:46:43 -06:00
PyObject* arg0;
PyObject* arg1;
long result = 0;
HTRY
2008-11-17 15:55:03 -06:00
__cs.init ("Transformation.getY");
2008-03-17 08:54:33 -05:00
if ( ! PyArg_ParseTuple(args,"|O&O&:Transformation.getY",Converter,&arg0,Converter,&arg1) )
2008-03-06 10:46:43 -06:00
return ( NULL );
2008-03-17 08:54:33 -05:00
if ( __cs.getObjectIds() == POINT_ARG ) { result = transf->getY ( *PYPOINT_O(arg0) ); }
else if ( __cs.getObjectIds() == INTS2_ARG ) { result = transf->getY ( PyInt_AsLong(arg0)
2008-03-06 10:46:43 -06:00
, PyInt_AsLong(arg1) ); }
else {
2008-03-17 08:54:33 -05:00
PyErr_SetString ( ConstructorError, "invalid number of parameters for Tranformation.getY()." );
2008-03-06 10:46:43 -06:00
return ( NULL );
}
HCATCH
return ( (PyObject*)Py_BuildValue("i",result) );
}
// ---------------------------------------------------------------
2008-03-17 08:54:33 -05:00
// Attribute Method : "PyTransformation_getDx ()"
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
static PyObject* PyTransformation_getDx ( PyTransformation *self, PyObject* args )
2008-03-06 10:46:43 -06:00
{
2008-03-17 08:54:33 -05:00
trace << "PyTransformation_getDx ()" << endl;
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
METHOD_HEAD ( "Transformation.getDx()" )
2008-03-06 10:46:43 -06:00
PyObject* arg0;
PyObject* arg1;
long result = 0;
HTRY
2008-03-17 08:54:33 -05:00
if ( ! ParseTwoArg ( "Transformation.getDx", args, INTS2_ARG, &arg0, &arg1 ) ) return ( NULL );
2008-03-06 10:46:43 -06:00
result = transf->getDx ( PyInt_AsLong(arg0), PyInt_AsLong(arg1) );
HCATCH
return ( (PyObject*)Py_BuildValue("i",result) );
}
// ---------------------------------------------------------------
2008-03-17 08:54:33 -05:00
// Attribute Method : "PyTransformation_getDy ()"
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
static PyObject* PyTransformation_getDy ( PyTransformation *self, PyObject* args )
2008-03-06 10:46:43 -06:00
{
2008-03-17 08:54:33 -05:00
trace << "PyTransformation_getDy ()" << endl;
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
METHOD_HEAD ( "Transformation.getDy()" )
2008-03-06 10:46:43 -06:00
PyObject* arg0;
PyObject* arg1;
long result = 0;
HTRY
2008-03-17 08:54:33 -05:00
if ( ! ParseTwoArg ( "Transformation.getDy", args, INTS2_ARG, &arg0, &arg1 ) ) return ( NULL );
2008-03-06 10:46:43 -06:00
result = transf->getDy ( PyInt_AsLong(arg0), PyInt_AsLong(arg1) );
HCATCH
return ( (PyObject*)Py_BuildValue("i",result) );
}
// ---------------------------------------------------------------
2008-03-17 08:54:33 -05:00
// Attribute Method : "PyTransformation_getTransformation ()"
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
static PyObject* PyTransformation_getTransformation ( PyTransformation *self, PyObject* args )
2008-03-06 10:46:43 -06:00
{
2008-03-17 08:54:33 -05:00
trace << "PyTransformation_getTransformation ()" << endl;
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
METHOD_HEAD ( "Transformation.getTransformation()" )
2008-03-06 10:46:43 -06:00
PyObject* arg0;
Transformation result;
2008-03-17 08:54:33 -05:00
if ( ! ParseOneArg ( "Transformation.getTransformation", args, TRANS_ARG, &arg0 ) ) return ( NULL );
2008-03-06 10:46:43 -06:00
result = transf->getTransformation ( *PYTRANSFORMATION_O(arg0) );
PyTransformation* resultPyTransf = PyObject_NEW ( PyTransformation, &PyTypeTransformation );
if ( resultPyTransf == NULL ) { return NULL; }
trace_in ();
trace << "new PyTransformation [" << hex << resultPyTransf << "]" << endl;
trace_out ();
HTRY
resultPyTransf->_object = new Transformation ( result );
HCATCH
return ( (PyObject*)resultPyTransf );
}
// ---------------------------------------------------------------
2008-03-17 08:54:33 -05:00
// Attribute Method : "PyTransformation_getPoint ()"
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
static PyObject* PyTransformation_getPoint ( PyTransformation *self, PyObject* args )
2008-03-06 10:46:43 -06:00
{
2008-03-17 08:54:33 -05:00
trace << "PyTransformation_getPoint ()" << endl;
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
METHOD_HEAD ( "Transformation.getPoint()" )
2008-03-06 10:46:43 -06:00
PyObject* arg0;
PyObject* arg1;
Point result;
2008-11-17 15:55:03 -06:00
__cs.init ("Transformation.getPoint");
2008-03-17 08:54:33 -05:00
if ( ! PyArg_ParseTuple(args,"|O&O&:Transformation.getPoint",Converter,&arg0,Converter,&arg1) )
2008-03-06 10:46:43 -06:00
return ( NULL );
2008-03-17 08:54:33 -05:00
if ( __cs.getObjectIds() == POINT_ARG ) { result = transf->getPoint ( *PYPOINT_O(arg0) ); }
else if ( __cs.getObjectIds() == INTS2_ARG ) { result = transf->getPoint ( PyInt_AsLong(arg0)
2008-03-06 10:46:43 -06:00
, PyInt_AsLong(arg1) ); }
else {
2008-03-17 08:54:33 -05:00
PyErr_SetString ( ConstructorError, "invalid number of parameters for Tranformation.getPoint()." );
2008-03-06 10:46:43 -06:00
return ( NULL );
}
PyPoint* resultPyPoint = PyObject_NEW ( PyPoint, &PyTypePoint );
if ( resultPyPoint == NULL ) { return NULL; }
trace_in ();
trace << "new PyPoint [" << hex << resultPyPoint << "]" << endl;
trace_out ();
HTRY
resultPyPoint->_object = new Point ( result );
HCATCH
return ( (PyObject*)resultPyPoint );
}
// ---------------------------------------------------------------
2008-03-17 08:54:33 -05:00
// Attribute Method : "PyTransformation_getBox ()"
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
static PyObject* PyTransformation_getBox ( PyTransformation *self, PyObject* args )
2008-03-06 10:46:43 -06:00
{
2008-03-17 08:54:33 -05:00
trace << "PyTransformation_getBox ()" << endl;
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
METHOD_HEAD ( "Transformation.getBox()" )
2008-03-06 10:46:43 -06:00
PyObject* arg0;
PyObject* arg1;
PyObject* arg2;
PyObject* arg3;
Box result;
2008-11-17 15:55:03 -06:00
__cs.init ("Transformation.getBox");
2008-03-17 08:54:33 -05:00
if ( ! PyArg_ParseTuple(args,"|O&O&O&O&:Transformation.getBox"
2008-03-06 10:46:43 -06:00
,Converter,&arg0
,Converter,&arg1
,Converter,&arg2
,Converter,&arg3) )
return ( NULL );
2008-03-17 08:54:33 -05:00
if ( __cs.getObjectIds() == BOX_ARG ) { result = transf->getBox ( *PYBOX_O(arg0) ); }
else if ( __cs.getObjectIds() == POINTS2_ARG ) { result = transf->getBox ( *PYPOINT_O(arg0)
2008-03-06 10:46:43 -06:00
, *PYPOINT_O(arg1) ); }
2008-03-17 08:54:33 -05:00
else if ( __cs.getObjectIds() == INTS4_ARG ) { result = transf->getBox ( PyInt_AsLong(arg0)
2008-03-06 10:46:43 -06:00
, PyInt_AsLong(arg1)
, PyInt_AsLong(arg2)
, PyInt_AsLong(arg3) ); }
else {
2008-03-17 08:54:33 -05:00
PyErr_SetString ( ConstructorError, "invalid number of parameters for Tranformation.getBox()." );
2008-03-06 10:46:43 -06:00
return ( NULL );
}
PyBox* resultPyBox = PyObject_NEW ( PyBox, &PyTypeBox );
if ( resultPyBox == NULL ) { return NULL; }
trace_in ();
trace << "new PyBox [" << hex << resultPyBox << "]" << endl;
trace_out ();
HTRY
resultPyBox->_object = new Box ( result );
HCATCH
return ( (PyObject*)resultPyBox );
}
// ---------------------------------------------------------------
2008-03-17 08:54:33 -05:00
// Attribute Method : "PyTransformation_getInvert ()"
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
static PyObject* PyTransformation_getInvert ( PyTransformation *self )
2008-03-06 10:46:43 -06:00
{
2008-03-17 08:54:33 -05:00
trace << "PyTransformation_getInvert ()" << endl;
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
METHOD_HEAD ( "Transformation.getInvert()" )
2008-03-06 10:46:43 -06:00
Transformation result = transf->getInvert ();
PyTransformation* resultPyTransf = PyObject_NEW ( PyTransformation, &PyTypeTransformation );
if ( resultPyTransf == NULL ) { return NULL; }
trace_in ();
trace << "new PyTransformation [" << hex << resultPyTransf << "]" << endl;
trace_out ();
HTRY
resultPyTransf->_object = new Transformation ( result );
HCATCH
return ( (PyObject*)resultPyTransf );
}
// ---------------------------------------------------------------
// Attribute Method : "PyTransformation_Invert ()"
static PyObject* PyTransformation_Invert ( PyTransformation *self )
{
trace << "PyTransformation_Invert ()" << endl;
METHOD_HEAD ( "Transformation.Invert()" )
HTRY
transf->invert ();
HCATCH
Py_INCREF ( self );
return ( (PyObject*)self );
}
// ---------------------------------------------------------------
// Attribute Method : "PyTransformation_ApplyOn ()"
static PyObject* PyTransformation_ApplyOn ( PyTransformation *self, PyObject* args )
{
trace << "PyTransformation_ApplyOn ()" << endl;
METHOD_HEAD ( "Transformation.ApplyOn()" )
PyObject* arg0;
PyObject* arg1;
HTRY
2008-11-17 15:55:03 -06:00
__cs.init ("Transformation.ApplyOn");
2008-03-06 10:46:43 -06:00
if ( ! PyArg_ParseTuple(args,"|O&O&:Transformation.ApplyOn",Converter,&arg0,Converter,&arg1) )
return ( NULL );
2008-03-17 08:54:33 -05:00
if ( __cs.getObjectIds() == POINT_ARG ) { transf->applyOn ( *PYPOINT_O(arg0) ); }
else if ( __cs.getObjectIds() == BOX_ARG ) { transf->applyOn ( *PYBOX_O(arg0) ); }
else if ( __cs.getObjectIds() == TRANS_ARG ) { transf->applyOn ( *PYTRANSFORMATION_O(arg0) ); }
else if ( __cs.getObjectIds() == INTS2_ARG ) {
2008-03-06 10:46:43 -06:00
PyErr_SetString ( ConstructorError, "This set of ApplyOn() parameters has not been implemented." );
return ( NULL );
} else {
PyErr_SetString ( ConstructorError, "invalid number of parameters for Tranformation.ApplyOn()." );
return ( NULL );
}
HCATCH
Py_RETURN_NONE;
}
// ---------------------------------------------------------------
// PyTransformation Attribute Method table.
PyMethodDef PyTransformation_Methods[] =
2008-03-17 08:54:33 -05:00
{ { "getTx" , (PyCFunction)PyTransformation_getTx , METH_NOARGS, "Return the horizontal component of a Transformation." }
, { "getTy" , (PyCFunction)PyTransformation_getTy , METH_NOARGS, "Return the vertical component of a Transformation." }
, { "getTranslation" , (PyCFunction)PyTransformation_getTranslation , METH_NOARGS , "Return the translation component of a Transformation." }
, { "getOrientation" , (PyCFunction)PyTransformation_getOrientation , METH_NOARGS , "Return the orientation component of a Transformation." }
, { "getX" , (PyCFunction)PyTransformation_getX , METH_VARARGS, "Return X of transformed point <x,y>." }
, { "getY" , (PyCFunction)PyTransformation_getY , METH_VARARGS, "Return Y of transformed point <x,y>." }
, { "getDx" , (PyCFunction)PyTransformation_getDx , METH_VARARGS, "Return X of transformed point <x,y>." }
, { "getDy" , (PyCFunction)PyTransformation_getDy , METH_VARARGS, "Return Y of transformed point <x,y>." }
, { "getTransformation", (PyCFunction)PyTransformation_getTransformation, METH_VARARGS, "Return combined transformation." }
, { "getPoint" , (PyCFunction)PyTransformation_getPoint , METH_VARARGS, "Return transformed point <x,y>." }
, { "getBox" , (PyCFunction)PyTransformation_getBox , METH_VARARGS, "Return transformed box." }
, { "getInvert" , (PyCFunction)PyTransformation_getInvert , METH_NOARGS, "Return inverse transformation." }
2008-03-06 10:46:43 -06:00
, { "Invert" , (PyCFunction)PyTransformation_Invert , METH_NOARGS, "Inverse transformation." }
, { "ApplyOn" , (PyCFunction)PyTransformation_ApplyOn , METH_VARARGS, "Apply transformation to object." }
2008-03-17 08:54:33 -05:00
, { "destroy" , (PyCFunction)PyTransformation_destroy , METH_NOARGS
, "Destroy associated hurricane object, the python object remains." }
2008-03-06 10:46:43 -06:00
, {NULL, NULL, 0, NULL} /* sentinel */
};
// x-------------------------------------------------------------x
// | "PyTransformation" Object Methods |
// x-------------------------------------------------------------x
static Transformation::Orientation PyInt_AsOrientation ( PyObject* object ) {
switch ( PyInt_AsLong(object) ) {
case Transformation::Orientation::ID : return ( Transformation::Orientation(Transformation::Orientation::ID) );
case Transformation::Orientation::R1 : return ( Transformation::Orientation(Transformation::Orientation::R1) );
case Transformation::Orientation::R2 : return ( Transformation::Orientation(Transformation::Orientation::R2) );
case Transformation::Orientation::R3 : return ( Transformation::Orientation(Transformation::Orientation::R3) );
case Transformation::Orientation::MX : return ( Transformation::Orientation(Transformation::Orientation::MX) );
case Transformation::Orientation::XR : return ( Transformation::Orientation(Transformation::Orientation::XR) );
case Transformation::Orientation::MY : return ( Transformation::Orientation(Transformation::Orientation::MY) );
case Transformation::Orientation::YR : return ( Transformation::Orientation(Transformation::Orientation::YR) );
}
return ( Transformation::Orientation(Transformation::Orientation::ID) );
}
// ---------------------------------------------------------------
// Attribute Method : "PyTransformation_new ()"
static PyObject* PyTransformation_new(PyTypeObject *type, PyObject *args, PyObject *kwds) {
trace << "PyTransformation_new()" << endl;
Transformation* transf;
PyObject* arg0;
PyObject* arg1;
PyObject* arg2;
2008-11-17 15:55:03 -06:00
__cs.init ("Transformation.new");
2008-03-06 10:46:43 -06:00
if ( ! PyArg_ParseTuple(args,"|O&O&O&:Transformation.new"
,Converter,&arg0
,Converter,&arg1
,Converter,&arg2
)) {
PyErr_SetString ( ConstructorError, "invalid number of parameters for Transformation constructor." );
return NULL;
}
2008-03-06 10:46:43 -06:00
2008-03-17 08:54:33 -05:00
if ( __cs.getObjectIds() == NO_ARG ) { transf = new Transformation (); }
else if ( __cs.getObjectIds() == POINT_ARG ) { transf = new Transformation ( *PYPOINT_O(arg0) ); }
else if ( __cs.getObjectIds() == TRANS_ARG ) { transf = new Transformation ( *PYTRANSFORMATION_O(arg0) ); }
else if ( __cs.getObjectIds() == INTS2_ARG ) { transf = new Transformation ( PyInt_AsLong(arg0)
2008-03-06 10:46:43 -06:00
, PyInt_AsLong(arg1) ); }
2008-03-17 08:54:33 -05:00
else if ( __cs.getObjectIds() == POINT_INT_ARG ) { transf = new Transformation ( *PYPOINT_O(arg0)
2008-03-06 10:46:43 -06:00
, PyInt_AsOrientation(arg1) ); }
2008-03-17 08:54:33 -05:00
else if ( __cs.getObjectIds() == INTS3_ARG ) { transf = new Transformation ( PyInt_AsLong(arg0)
2008-03-06 10:46:43 -06:00
, PyInt_AsLong(arg1)
, PyInt_AsOrientation(arg2) ); }
else {
PyErr_SetString ( ConstructorError, "invalid number of parameters for Transformation constructor." );
return NULL;
2008-03-06 10:46:43 -06:00
}
PyTransformation* pyTransformation = PyObject_NEW(PyTransformation, &PyTypeTransformation);
if (pyTransformation == NULL) { return NULL; }
2008-03-06 10:46:43 -06:00
trace_in ();
trace << "new PyTransformation [" << hex << pyTransformation << "]" << endl;
trace_out ();
HTRY
pyTransformation->_object = transf;
HCATCH
return (PyObject*)pyTransformation;
2008-03-06 10:46:43 -06:00
}
DirectDeleteMethod(PyTransformation_DeAlloc,PyTransformation)
PyTypeObjectLinkPyType(Transformation)
PyTypeObjectConstructor(Transformation)
#else // End of Python Module Code Part.
// x=================================================================x
// | "PyTransformation" Shared Library Code Part |
// x=================================================================x
// x-------------------------------------------------------------x
// | "PyTransformation" Local Functions |
// x-------------------------------------------------------------x
// ---------------------------------------------------------------
// PyTransformation Object Definitions.
PyTypeObjectDefinitions(Transformation)
2008-03-06 10:46:43 -06:00
#endif // End of Shared Library Code Part.
} // End of extern "C".
} // End of Isobar namespace.