coriolis/hurricane/src/isobar/PyHorizontal.cpp

234 lines
8.7 KiB
C++
Raw Normal View History

2008-03-06 10:46:43 -06:00
// -*- C++ -*-
//
// This file is part of the Coriolis Project.
// Copyright (C) Laboratoire LIP6 - Departement ASIM
// Universite Pierre et Marie Curie
//
// Main contributors :
// Christophe Alexandre <Christophe.Alexandre@lip6.fr>
// Sophie Belloeil <Sophie.Belloeil@lip6.fr>
// Hugo Cl<43>ment <Hugo.Clement@lip6.fr>
// Jean-Paul Chaput <Jean-Paul.Chaput@lip6.fr>
// Damien Dupuis <Damien.Dupuis@lip6.fr>
// Christian Masson <Christian.Masson@lip6.fr>
// Marek Sroka <Marek.Sroka@lip6.fr>
//
// 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"
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" {
# 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
2008-03-17 08:54:33 -05:00
// Standart destroy (Attribute).
DBoDestroyAttribute(PyHorizontal_destroy, PyHorizontal)
2008-03-06 10:46:43 -06:00
// ---------------------------------------------------------------
// PyHorizontal Attribute Method table.
PyMethodDef PyHorizontal_Methods[] =
2008-03-17 08:54:33 -05:00
{ { "destroy" , (PyCFunction)PyHorizontal_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
// | "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
2008-03-18 04:42:44 -05:00
__cs.Init ("Horizontal.create");
if ( ! PyArg_ParseTuple(args,"O&O&O&|O&O&O&O&:Horizontal.create"
2008-03-06 10:46:43 -06:00
,Converter,&arg0
,Converter,&arg1
,Converter,&arg2
,Converter,&arg3
,Converter,&arg4
,Converter,&arg5
,Converter,&arg6
) ) return ( NULL );
2008-03-17 08:54:33 -05:00
if ( __cs.getObjectIds() == NET_LAYER_INT_ARG )
2008-03-18 04:42:44 -05:00
horizontal = Horizontal::create ( PYNET_O(arg0)
2008-03-06 10:46:43 -06:00
, PYLAYER_O(arg1)
, PyInt_AsLong(arg2) );
2008-03-17 08:54:33 -05:00
else if ( __cs.getObjectIds() == NET_LAYER_INTS2_ARG )
2008-03-18 04:42:44 -05:00
horizontal = Horizontal::create ( PYNET_O(arg0)
2008-03-06 10:46:43 -06:00
, PYLAYER_O(arg1)
, PyInt_AsLong(arg2)
, PyInt_AsLong(arg3) );
2008-03-17 08:54:33 -05:00
else if ( __cs.getObjectIds() == COMPS2_LAYER_INT_ARG )
2008-03-18 04:42:44 -05:00
horizontal = Horizontal::create ( ComponentCast(arg0)
2008-03-06 10:46:43 -06:00
, ComponentCast(arg1)
, PYLAYER_O(arg2)
, PyInt_AsLong(arg3) );
2008-03-17 08:54:33 -05:00
else if ( __cs.getObjectIds() == NET_LAYER_INTS3_ARG )
2008-03-18 04:42:44 -05:00
horizontal = Horizontal::create ( PYNET_O(arg0)
2008-03-06 10:46:43 -06:00
, PYLAYER_O(arg1)
, PyInt_AsLong(arg2)
, PyInt_AsLong(arg3)
, PyInt_AsLong(arg4) );
2008-03-17 08:54:33 -05:00
else if ( __cs.getObjectIds() == COMPS2_LAYER_INTS2_ARG )
2008-03-18 04:42:44 -05:00
horizontal = Horizontal::create ( ComponentCast(arg0)
2008-03-06 10:46:43 -06:00
, ComponentCast(arg1)
, PYLAYER_O(arg2)
, PyInt_AsLong(arg3)
, PyInt_AsLong(arg4) );
2008-03-17 08:54:33 -05:00
else if ( __cs.getObjectIds() == NET_LAYER_INTS4_ARG )
2008-03-18 04:42:44 -05:00
horizontal = Horizontal::create ( PYNET_O(arg0)
2008-03-06 10:46:43 -06:00
, PYLAYER_O(arg1)
, PyInt_AsLong(arg2)
, PyInt_AsLong(arg3)
, PyInt_AsLong(arg4)
, PyInt_AsLong(arg5) );
2008-03-17 08:54:33 -05:00
else if ( __cs.getObjectIds() == COMPS2_LAYER_INTS3_ARG )
2008-03-18 04:42:44 -05:00
horizontal = Horizontal::create ( ComponentCast(arg0)
2008-03-06 10:46:43 -06:00
, ComponentCast(arg1)
, PYLAYER_O(arg2)
, PyInt_AsLong(arg3)
, PyInt_AsLong(arg4)
, PyInt_AsLong(arg5) );
2008-03-17 08:54:33 -05:00
else if ( __cs.getObjectIds() == COMPS2_LAYER_INTS4_ARG )
2008-03-18 04:42:44 -05:00
horizontal = Horizontal::create ( ComponentCast(arg0)
2008-03-06 10:46:43 -06:00
, ComponentCast(arg1)
, PYLAYER_O(arg2)
, PyInt_AsLong(arg3)
, PyInt_AsLong(arg4)
, PyInt_AsLong(arg5)
, PyInt_AsLong(arg6) );
else {
2008-03-17 08:54:33 -05:00
cerr << __cs.getObjectIds() << endl;
2008-03-06 10:46:43 -06:00
PyErr_SetString ( ConstructorError, "invalid number of parameters for Horizontal constructor." );
return ( NULL );
}
HCATCH
return PyHorizontal_Link ( horizontal );
}
DBoDeleteMethod(Horizontal)
PyTypeObjectLinkPyType(Horizontal)
PyTypeObjectConstructor(Horizontal)
2008-03-17 08:54:33 -05:00
#else // End of Python Module Code Part.
2008-03-06 10:46:43 -06:00
// x=================================================================x
// | "PyHorizontal" Shared Library Code Part |
// x=================================================================x
// Link/Creation Method.
DBoLinkCreateMethod(PyHorizontal_Link,PyHorizontal,PyTypeHorizontal,Horizontal)
// ---------------------------------------------------------------
// PyHorizontal Object Definitions.
PyTypeInheritedObjectDefinitions(Horizontal, Segment)
2008-03-17 08:54:33 -05:00
#endif // End of Shared Library Code Part.
2008-03-06 10:46:43 -06:00
} // End of extern "C".
} // End of Isobar namespace.