2014-07-05 11:02:51 -05:00
|
|
|
// -*- C++ -*-
|
2008-03-06 10:46:43 -06:00
|
|
|
//
|
2014-07-05 11:02:51 -05:00
|
|
|
// This file is part of the Coriolis Software.
|
2018-01-06 10:55:44 -06:00
|
|
|
// Copyright (c) UPMC 2010-2018, All Rights Reserved
|
2008-03-06 10:46:43 -06:00
|
|
|
//
|
2014-07-05 11:02:51 -05:00
|
|
|
// +-----------------------------------------------------------------+
|
2008-03-06 10:46:43 -06:00
|
|
|
// | 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 : "./PyEntity.cpp" |
|
2014-07-05 11:02:51 -05:00
|
|
|
// +-----------------------------------------------------------------+
|
|
|
|
|
2008-03-06 10:46:43 -06:00
|
|
|
|
2008-05-21 17:46:29 -05:00
|
|
|
#include "hurricane/isobar/PyNet.h"
|
|
|
|
#include "hurricane/isobar/PyLayer.h"
|
|
|
|
#include "hurricane/isobar/PyPoint.h"
|
|
|
|
#include "hurricane/isobar/PyBox.h"
|
|
|
|
#include "hurricane/isobar/PyCell.h"
|
|
|
|
#include "hurricane/isobar/PyInstance.h"
|
|
|
|
#include "hurricane/isobar/PyReference.h"
|
|
|
|
#include "hurricane/isobar/PyComponent.h"
|
|
|
|
#include "hurricane/isobar/PyPlug.h"
|
|
|
|
#include "hurricane/isobar/PyHorizontal.h"
|
|
|
|
#include "hurricane/isobar/PyVertical.h"
|
|
|
|
#include "hurricane/isobar/PyContact.h"
|
2008-11-20 04:56:11 -06:00
|
|
|
#include "hurricane/isobar/PyPad.h"
|
2008-05-21 17:46:29 -05:00
|
|
|
#include "hurricane/isobar/PyPin.h"
|
2013-04-17 11:14:41 -05:00
|
|
|
#include "hurricane/isobar/PyRoutingPad.h"
|
2012-11-16 06:48:38 -06:00
|
|
|
#include "hurricane/Cell.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" {
|
|
|
|
|
|
|
|
|
2014-07-05 11:02:51 -05:00
|
|
|
// +=================================================================+
|
2008-03-06 10:46:43 -06:00
|
|
|
// | "PyEntity" Python Module Code Part |
|
2014-07-05 11:02:51 -05:00
|
|
|
// +=================================================================+
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
#if defined(__PYTHON_MODULE__)
|
|
|
|
|
|
|
|
#define METHOD_HEAD(function) GENERIC_METHOD_HEAD(Entity,entity,function)
|
|
|
|
|
|
|
|
|
2014-07-05 11:02:51 -05:00
|
|
|
// +-------------------------------------------------------------+
|
2008-03-06 10:46:43 -06:00
|
|
|
// | "PyEntity" Attribute Methods |
|
2014-07-05 11:02:51 -05:00
|
|
|
// +-------------------------------------------------------------+
|
2008-03-06 10:46:43 -06:00
|
|
|
|
2008-03-17 08:54:33 -05:00
|
|
|
// Standart destroy (Attribute).
|
|
|
|
DBoDestroyAttribute(PyEntity_destroy ,PyEntity)
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
// ---------------------------------------------------------------
|
2008-03-17 08:54:33 -05:00
|
|
|
// Attribute Method : "PyEntity_getCell ()"
|
2008-03-06 10:46:43 -06:00
|
|
|
|
2009-01-22 05:37:42 -06:00
|
|
|
static PyObject* PyEntity_getCell ( PyEntity *self ) {
|
2016-06-11 14:56:12 -05:00
|
|
|
cdebug_log(20,0) << "PyEntity_getCell ()" << endl;
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
Cell* cell = NULL;
|
|
|
|
|
|
|
|
HTRY
|
2008-03-17 08:54:33 -05:00
|
|
|
METHOD_HEAD ( "Entity.getCell()" )
|
|
|
|
cell = entity->getCell ();
|
2008-03-06 10:46:43 -06:00
|
|
|
HCATCH
|
|
|
|
|
|
|
|
return PyCell_Link ( cell );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ---------------------------------------------------------------
|
|
|
|
// PyEntity Attribute Method table.
|
|
|
|
|
|
|
|
PyMethodDef PyEntity_Methods[] =
|
2008-03-17 08:54:33 -05:00
|
|
|
{ { "getCell" , (PyCFunction)PyEntity_getCell , METH_NOARGS , "Returns the entity cell." }
|
2016-12-07 05:21:40 -06:00
|
|
|
, { "destroy" , (PyCFunction)PyEntity_destroy , METH_NOARGS
|
2008-03-17 08:54:33 -05:00
|
|
|
, "Destroy associated hurricane object, the python object remains." }
|
2008-03-06 10:46:43 -06:00
|
|
|
, {NULL, NULL, 0, NULL} /* sentinel */
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2014-07-05 11:02:51 -05:00
|
|
|
// +-------------------------------------------------------------+
|
2008-03-06 10:46:43 -06:00
|
|
|
// | "PyEntity" Object Methods |
|
2014-07-05 11:02:51 -05:00
|
|
|
// +-------------------------------------------------------------+
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
DBoDeleteMethod(Entity)
|
|
|
|
PyTypeObjectLinkPyType(Entity)
|
|
|
|
|
|
|
|
|
2009-01-22 05:37:42 -06:00
|
|
|
#else // End of Python Module Code Part.
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
|
2014-07-05 11:02:51 -05:00
|
|
|
// +=================================================================+
|
2008-03-06 10:46:43 -06:00
|
|
|
// | "PyEntity" Shared Library Code Part |
|
2014-07-05 11:02:51 -05:00
|
|
|
// +=================================================================+
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
|
|
|
|
// ---------------------------------------------------------------
|
|
|
|
// Allocator Method : "PyEntity_NEW ()"
|
|
|
|
//
|
|
|
|
// No PyEntity should ever be created, it's not a terminal object
|
|
|
|
// of the class hierarchy. Instead create the real underlying PyObject.
|
|
|
|
|
2008-11-20 04:56:11 -06:00
|
|
|
PyObject* PyEntity_NEW ( Entity* entity ) {
|
2008-03-06 10:46:43 -06:00
|
|
|
if ( !entity ) {
|
|
|
|
PyErr_SetString ( HurricaneError, "Invalid Entity (bad occurrence)" ); \
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
Cell* cell = dynamic_cast<Cell*>(entity);
|
|
|
|
if ( cell ) return PyCell_Link ( cell );
|
|
|
|
|
|
|
|
Instance* instance = dynamic_cast<Instance*>(entity);
|
|
|
|
if ( instance ) return PyInstance_Link ( instance );
|
|
|
|
|
|
|
|
Reference* reference = dynamic_cast<Reference*>(entity);
|
|
|
|
if ( reference ) return PyReference_Link ( reference );
|
|
|
|
|
2013-04-17 11:14:41 -05:00
|
|
|
RoutingPad* rp = dynamic_cast<RoutingPad*>(entity);
|
|
|
|
if ( rp ) return PyRoutingPad_Link ( rp );
|
|
|
|
|
2008-03-06 10:46:43 -06:00
|
|
|
Horizontal* horizontal = dynamic_cast<Horizontal*>(entity);
|
|
|
|
if ( horizontal ) return PyHorizontal_Link ( horizontal );
|
|
|
|
|
|
|
|
Vertical* vertical = dynamic_cast<Vertical*>(entity);
|
|
|
|
if ( vertical ) return PyVertical_Link ( vertical );
|
2008-11-20 04:56:11 -06:00
|
|
|
|
|
|
|
Pad* pad = dynamic_cast<Pad*>(entity);
|
|
|
|
if ( pad ) return PyPad_Link ( pad );
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
Contact* contact = dynamic_cast<Contact*>(entity);
|
|
|
|
if ( contact ) return PyContact_Link ( contact );
|
|
|
|
|
|
|
|
Plug* plug = dynamic_cast<Plug*>(entity);
|
|
|
|
if ( plug ) return PyPlug_Link ( plug );
|
|
|
|
|
|
|
|
Pin* pin = dynamic_cast<Pin*>(entity);
|
|
|
|
if ( pin ) return PyPin_Link ( pin );
|
|
|
|
|
|
|
|
Net* net = dynamic_cast<Net*>(entity);
|
|
|
|
if ( net ) return PyNet_Link ( net );
|
|
|
|
|
|
|
|
Py_RETURN_NONE;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2009-09-30 10:11:49 -05:00
|
|
|
PyTypeRootObjectDefinitions(Entity)
|
2008-03-06 10:46:43 -06:00
|
|
|
|
2014-07-05 11:02:51 -05:00
|
|
|
|
2008-03-06 10:46:43 -06:00
|
|
|
// ---------------------------------------------------------------
|
|
|
|
// PyEntity Object Definitions.
|
|
|
|
|
|
|
|
|
2014-07-05 11:02:51 -05:00
|
|
|
#endif // Shared Library Code Part.
|
2008-03-06 10:46:43 -06:00
|
|
|
|
2014-07-05 11:02:51 -05:00
|
|
|
} // extern "C".
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
|
2014-07-05 11:02:51 -05:00
|
|
|
// +=================================================================+
|
|
|
|
// | "PyEntity" Shared Library Code Part |
|
|
|
|
// +=================================================================+
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
|
|
|
|
# if !defined(__PYTHON_MODULE__)
|
|
|
|
|
2009-01-22 05:37:42 -06:00
|
|
|
Hurricane::Entity* EntityCast ( PyObject* derivedObject ) {
|
2008-03-06 10:46:43 -06:00
|
|
|
if ( IsPyCell (derivedObject) ) return PYCELL_O(derivedObject);
|
|
|
|
if ( IsPyInstance (derivedObject) ) return PYINSTANCE_O(derivedObject);
|
|
|
|
if ( IsPyReference (derivedObject) ) return PYREFERENCE_O(derivedObject);
|
|
|
|
if ( IsPyPlug (derivedObject) ) return PYPLUG_O(derivedObject);
|
|
|
|
if ( IsPyHorizontal(derivedObject) ) return PYHORIZONTAL_O(derivedObject);
|
|
|
|
if ( IsPyVertical (derivedObject) ) return PYVERTICAL_O(derivedObject);
|
2013-04-17 11:14:41 -05:00
|
|
|
if ( IsPyRoutingPad(derivedObject) ) return PYROUTINGPAD_O(derivedObject);
|
2008-03-06 10:46:43 -06:00
|
|
|
if ( IsPyContact (derivedObject) ) return PYCONTACT_O(derivedObject);
|
|
|
|
if ( IsPyPin (derivedObject) ) return PYPIN_O(derivedObject);
|
|
|
|
if ( IsPyNet (derivedObject) ) return PYNET_O(derivedObject);
|
|
|
|
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
2009-01-22 05:37:42 -06:00
|
|
|
#endif
|
2008-03-06 10:46:43 -06:00
|
|
|
|
2014-07-05 11:02:51 -05:00
|
|
|
} // Isobar namespace.
|