// -*- C++ -*- // // This file is part of the Coriolis Project. // Copyright (C) Laboratoire LIP6 - Departement ASIM // Universite Pierre et Marie Curie // // Main contributors : // Christophe Alexandre // Sophie Belloeil // Hugo Clément // Jean-Paul Chaput // Damien Dupuis // Christian Masson // Marek Sroka // // The Coriolis Project is free software; you can redistribute it // and/or modify it under the terms of the GNU General Public License // as published by the Free Software Foundation; either version 2 of // the License, or (at your option) any later version. // // The Coriolis Project is distributed in the hope that it will be // useful, but WITHOUT ANY WARRANTY; without even the implied warranty // of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with the Coriolis Project; if not, write to the Free Software // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 // USA // // License-Tag // Authors-Tag // =================================================================== // // $Id: PyHorizontal.cpp,v 1.15 2008/02/07 17:09:41 xtof Exp $ // // x-----------------------------------------------------------------x // | | // | C O R I O L I S | // | I s o b a r - Hurricane / Python Interface | // | | // | Author : Sophie BELLOEIL | // | E-mail : Sophie.Belloeil@asim.lip6.fr | // | =============================================================== | // | C++ Module : "./PyHorizontal.cpp" | // | *************************************************************** | // | U p d a t e s | // | | // x-----------------------------------------------------------------x #include "hurricane/isobar/PyNet.h" #include "hurricane/isobar/PyLayer.h" #include "hurricane/isobar/PyHorizontal.h" namespace Isobar { using namespace Hurricane; extern "C" { # undef ACCESS_OBJECT # undef ACCESS_CLASS # define ACCESS_OBJECT _baseObject._baseObject._baseObject._object # define ACCESS_CLASS(_pyObject) &(_pyObject->_baseObject._baseObject._baseObject) # define METHOD_HEAD(function) GENERIC_METHOD_HEAD_SUB(Horizontal,horizontal,function) // x=================================================================x // | "PyHorizontal" Python Module Code Part | // x=================================================================x # if defined(__PYTHON_MODULE__) // x-------------------------------------------------------------x // | "PyHorizontal" Attribute Methods | // x-------------------------------------------------------------x // Standart destroy (Attribute). DBoDestroyAttribute(PyHorizontal_destroy, PyHorizontal) // --------------------------------------------------------------- // PyHorizontal Attribute Method table. PyMethodDef PyHorizontal_Methods[] = { { "destroy" , (PyCFunction)PyHorizontal_destroy , METH_NOARGS , "destroy associated hurricane object, the python object remains." } , {NULL, NULL, 0, NULL} /* sentinel */ }; // x-------------------------------------------------------------x // | "PyHorizontal" Object Methods | // x-------------------------------------------------------------x // --------------------------------------------------------------- // Attribute Method : "PyHorizontal_new ()" static PyObject* PyHorizontal_new(PyTypeObject *type, PyObject *args, PyObject *kwds) { trace << "PyHorizontal_new()" << endl; PyObject* arg0; PyObject* arg1; PyObject* arg2; PyObject* arg3; PyObject* arg4; PyObject* arg5; PyObject* arg6; Horizontal* horizontal = NULL; HTRY __cs.Init ("Horizontal.create"); if ( ! PyArg_ParseTuple(args,"O&O&O&|O&O&O&O&:Horizontal.create" ,Converter,&arg0 ,Converter,&arg1 ,Converter,&arg2 ,Converter,&arg3 ,Converter,&arg4 ,Converter,&arg5 ,Converter,&arg6 ) ) return ( NULL ); if ( __cs.getObjectIds() == NET_LAYER_INT_ARG ) horizontal = Horizontal::create ( PYNET_O(arg0) , PYLAYER_O(arg1) , PyInt_AsLong(arg2) ); else if ( __cs.getObjectIds() == NET_LAYER_INTS2_ARG ) horizontal = Horizontal::create ( PYNET_O(arg0) , PYLAYER_O(arg1) , PyInt_AsLong(arg2) , PyInt_AsLong(arg3) ); else if ( __cs.getObjectIds() == COMPS2_LAYER_INT_ARG ) horizontal = Horizontal::create ( ComponentCast(arg0) , ComponentCast(arg1) , PYLAYER_O(arg2) , PyInt_AsLong(arg3) ); else if ( __cs.getObjectIds() == NET_LAYER_INTS3_ARG ) horizontal = Horizontal::create ( PYNET_O(arg0) , PYLAYER_O(arg1) , PyInt_AsLong(arg2) , PyInt_AsLong(arg3) , PyInt_AsLong(arg4) ); else if ( __cs.getObjectIds() == COMPS2_LAYER_INTS2_ARG ) horizontal = Horizontal::create ( ComponentCast(arg0) , ComponentCast(arg1) , PYLAYER_O(arg2) , PyInt_AsLong(arg3) , PyInt_AsLong(arg4) ); else if ( __cs.getObjectIds() == NET_LAYER_INTS4_ARG ) horizontal = Horizontal::create ( PYNET_O(arg0) , PYLAYER_O(arg1) , PyInt_AsLong(arg2) , PyInt_AsLong(arg3) , PyInt_AsLong(arg4) , PyInt_AsLong(arg5) ); else if ( __cs.getObjectIds() == COMPS2_LAYER_INTS3_ARG ) horizontal = Horizontal::create ( ComponentCast(arg0) , ComponentCast(arg1) , PYLAYER_O(arg2) , PyInt_AsLong(arg3) , PyInt_AsLong(arg4) , PyInt_AsLong(arg5) ); else if ( __cs.getObjectIds() == COMPS2_LAYER_INTS4_ARG ) horizontal = Horizontal::create ( ComponentCast(arg0) , ComponentCast(arg1) , PYLAYER_O(arg2) , PyInt_AsLong(arg3) , PyInt_AsLong(arg4) , PyInt_AsLong(arg5) , PyInt_AsLong(arg6) ); else { cerr << __cs.getObjectIds() << endl; PyErr_SetString ( ConstructorError, "invalid number of parameters for Horizontal constructor." ); return ( NULL ); } HCATCH return PyHorizontal_Link ( horizontal ); } DBoDeleteMethod(Horizontal) PyTypeObjectLinkPyType(Horizontal) PyTypeObjectConstructor(Horizontal) #else // End of Python Module Code Part. // x=================================================================x // | "PyHorizontal" Shared Library Code Part | // x=================================================================x // Link/Creation Method. DBoLinkCreateMethod(Horizontal) // --------------------------------------------------------------- // PyHorizontal Object Definitions. PyTypeObjectDefinitions(Horizontal) #endif // End of Shared Library Code Part. } // End of extern "C". } // End of Isobar namespace.