Make the Python interface closely mirroring the C++ one.
* Change: In Isobar, the Python interface was not exactly mirroring the
C++ one, now it is the case. The Python code should look likes almost
exactly like the C++ one, the only differences remaining being due
to the languages respective syntaxes. Note that in the case of
constructor functions, it leads to a slightly longer notation in
Python that it could have been (mimic the ".create()" static
member). Main modifications:
1. Mirror the static constructor syntax with create():
Cell( ... ) ==> Cell.create( ... )
2. Correct hierarchy for constants in Instance, Net, Pin
& Transformation. For example:
Hurricane.PlacementStatusFIXED
==> Hurricane.Instance.PlacementStatus.FIXED
Hurricane.OrientationID
==> Hurricane.Transformation.Orientation.ID
Hurricane.TypeLOGICAL ==> Hurricane.Net.Type.LOGICAL
Hurricane.DirectionIN ==> Hurricane.Net.Direction.IN
* Change: In CRL Core, correction to match the improved Python API
in the configutation helpers.
* Change: In Cumulus, correction to match the improved Python API.
* Change: In Stratus, correction to match the improved Python API.
* Change: In Documenation, update for the new Python interface
(both user's guide & examples).
* Note: We must port those changes into Chams for it to continue
to run.
* Change: In Documenation, update the Python script support part.
2014-06-28 10:37:59 -05:00
|
|
|
// -*- C++ -*-
|
|
|
|
//
|
|
|
|
// This file is part of the Coriolis Software.
|
|
|
|
// Copyright (c) UPMC 2008-2014, All Rights Reserved
|
|
|
|
//
|
|
|
|
// +-----------------------------------------------------------------+
|
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 |
|
|
|
|
// | |
|
Make the Python interface closely mirroring the C++ one.
* Change: In Isobar, the Python interface was not exactly mirroring the
C++ one, now it is the case. The Python code should look likes almost
exactly like the C++ one, the only differences remaining being due
to the languages respective syntaxes. Note that in the case of
constructor functions, it leads to a slightly longer notation in
Python that it could have been (mimic the ".create()" static
member). Main modifications:
1. Mirror the static constructor syntax with create():
Cell( ... ) ==> Cell.create( ... )
2. Correct hierarchy for constants in Instance, Net, Pin
& Transformation. For example:
Hurricane.PlacementStatusFIXED
==> Hurricane.Instance.PlacementStatus.FIXED
Hurricane.OrientationID
==> Hurricane.Transformation.Orientation.ID
Hurricane.TypeLOGICAL ==> Hurricane.Net.Type.LOGICAL
Hurricane.DirectionIN ==> Hurricane.Net.Direction.IN
* Change: In CRL Core, correction to match the improved Python API
in the configutation helpers.
* Change: In Cumulus, correction to match the improved Python API.
* Change: In Stratus, correction to match the improved Python API.
* Change: In Documenation, update for the new Python interface
(both user's guide & examples).
* Note: We must port those changes into Chams for it to continue
to run.
* Change: In Documenation, update the Python script support part.
2014-06-28 10:37:59 -05:00
|
|
|
// | Author : Jean-Paul CHAPUT |
|
|
|
|
// | E-mail : Jean-Paul.Chaput@asim.lip6.fr |
|
2008-03-06 10:46:43 -06:00
|
|
|
// | =============================================================== |
|
|
|
|
// | C++ Module : "./PyReference.cpp" |
|
Make the Python interface closely mirroring the C++ one.
* Change: In Isobar, the Python interface was not exactly mirroring the
C++ one, now it is the case. The Python code should look likes almost
exactly like the C++ one, the only differences remaining being due
to the languages respective syntaxes. Note that in the case of
constructor functions, it leads to a slightly longer notation in
Python that it could have been (mimic the ".create()" static
member). Main modifications:
1. Mirror the static constructor syntax with create():
Cell( ... ) ==> Cell.create( ... )
2. Correct hierarchy for constants in Instance, Net, Pin
& Transformation. For example:
Hurricane.PlacementStatusFIXED
==> Hurricane.Instance.PlacementStatus.FIXED
Hurricane.OrientationID
==> Hurricane.Transformation.Orientation.ID
Hurricane.TypeLOGICAL ==> Hurricane.Net.Type.LOGICAL
Hurricane.DirectionIN ==> Hurricane.Net.Direction.IN
* Change: In CRL Core, correction to match the improved Python API
in the configutation helpers.
* Change: In Cumulus, correction to match the improved Python API.
* Change: In Stratus, correction to match the improved Python API.
* Change: In Documenation, update for the new Python interface
(both user's guide & examples).
* Note: We must port those changes into Chams for it to continue
to run.
* Change: In Documenation, update the Python script support part.
2014-06-28 10:37:59 -05:00
|
|
|
// +-----------------------------------------------------------------+
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
|
2008-05-21 17:46:29 -05:00
|
|
|
#include "hurricane/isobar/PyReference.h"
|
|
|
|
#include "hurricane/isobar/PyPoint.h"
|
|
|
|
#include "hurricane/isobar/PyCell.h"
|
|
|
|
#include "hurricane/isobar/PyNet.h"
|
2010-04-27 07:25:56 -05:00
|
|
|
#include "hurricane/isobar/PyBox.h"
|
2012-11-16 06:48:38 -06:00
|
|
|
#include "hurricane/Cell.h"
|
|
|
|
using namespace Hurricane;
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
namespace Isobar {
|
|
|
|
|
|
|
|
extern "C" {
|
2008-03-17 08:54:33 -05:00
|
|
|
#undef ACCESS_OBJECT
|
|
|
|
#undef ACCESS_CLASS
|
|
|
|
#define ACCESS_OBJECT _baseObject._object
|
|
|
|
#define ACCESS_CLASS(_pyObject) &(_pyObject->_baseObject)
|
|
|
|
#define METHOD_HEAD(function) GENERIC_METHOD_HEAD(Reference,reference,function)
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
|
|
|
|
// x=================================================================x
|
|
|
|
// | "PyReference" Python Module Code Part |
|
|
|
|
// x=================================================================x
|
|
|
|
|
2008-03-17 08:54:33 -05:00
|
|
|
#if defined(__PYTHON_MODULE__)
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
|
|
|
|
// x-------------------------------------------------------------x
|
|
|
|
// | "PyReference" Attribute Methods |
|
|
|
|
// x-------------------------------------------------------------x
|
|
|
|
|
|
|
|
|
2008-03-17 08:54:33 -05:00
|
|
|
DBoDestroyAttribute(PyReference_destroy, PyReference)
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
// ---------------------------------------------------------------
|
2008-03-17 08:54:33 -05:00
|
|
|
// Attribute Method : "PyReference_getName ()"
|
2008-03-06 10:46:43 -06:00
|
|
|
|
2008-12-11 06:25:02 -06:00
|
|
|
GetNameMethod(Reference, reference)
|
2008-03-06 10:46:43 -06:00
|
|
|
|
Make the Python interface closely mirroring the C++ one.
* Change: In Isobar, the Python interface was not exactly mirroring the
C++ one, now it is the case. The Python code should look likes almost
exactly like the C++ one, the only differences remaining being due
to the languages respective syntaxes. Note that in the case of
constructor functions, it leads to a slightly longer notation in
Python that it could have been (mimic the ".create()" static
member). Main modifications:
1. Mirror the static constructor syntax with create():
Cell( ... ) ==> Cell.create( ... )
2. Correct hierarchy for constants in Instance, Net, Pin
& Transformation. For example:
Hurricane.PlacementStatusFIXED
==> Hurricane.Instance.PlacementStatus.FIXED
Hurricane.OrientationID
==> Hurricane.Transformation.Orientation.ID
Hurricane.TypeLOGICAL ==> Hurricane.Net.Type.LOGICAL
Hurricane.DirectionIN ==> Hurricane.Net.Direction.IN
* Change: In CRL Core, correction to match the improved Python API
in the configutation helpers.
* Change: In Cumulus, correction to match the improved Python API.
* Change: In Stratus, correction to match the improved Python API.
* Change: In Documenation, update for the new Python interface
(both user's guide & examples).
* Note: We must port those changes into Chams for it to continue
to run.
* Change: In Documenation, update the Python script support part.
2014-06-28 10:37:59 -05:00
|
|
|
// ---------------------------------------------------------------
|
|
|
|
// Attribute Method : "PyReference_create ()"
|
|
|
|
|
|
|
|
PyObject* PyReference_create ( PyObject*, PyObject *args ) {
|
|
|
|
trace << "PyReference_create()" << endl;
|
|
|
|
Reference* reference = NULL;
|
|
|
|
|
|
|
|
PyObject* arg0;
|
|
|
|
PyObject* arg1;
|
|
|
|
PyObject* arg2;
|
|
|
|
PyObject* arg3;
|
|
|
|
|
|
|
|
HTRY
|
|
|
|
|
|
|
|
__cs.init ("Reference.create");
|
|
|
|
if ( ! PyArg_ParseTuple(args,"O&O&O&|O&:Reference.create"
|
|
|
|
,Converter,&arg0
|
|
|
|
,Converter,&arg1
|
|
|
|
,Converter,&arg2
|
|
|
|
,Converter,&arg3
|
|
|
|
)) {
|
|
|
|
PyErr_SetString ( ConstructorError, "invalid number of parameters for Reference constructor." );
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( __cs.getObjectIds() == ":ent:string:int:int" )
|
|
|
|
reference = Reference::create ( PYCELL_O(arg0)
|
|
|
|
, Name(PyString_AsString(arg1))
|
|
|
|
, PyInt_AsLong(arg2)
|
|
|
|
, PyInt_AsLong(arg3) );
|
|
|
|
else if ( __cs.getObjectIds() == ":ent:name:point" )
|
|
|
|
reference = Reference::create ( PYCELL_O(arg0)
|
|
|
|
, Name(PyString_AsString(arg1))
|
|
|
|
, *PYPOINT_O(arg2) );
|
|
|
|
else {
|
|
|
|
PyErr_SetString ( ConstructorError, "invalid number of parameters for Reference constructor." );
|
|
|
|
return NULL;
|
|
|
|
}
|
|
|
|
|
|
|
|
HCATCH
|
|
|
|
return PyReference_Link ( reference );
|
|
|
|
}
|
|
|
|
|
2008-03-06 10:46:43 -06:00
|
|
|
// ---------------------------------------------------------------
|
2008-03-17 08:54:33 -05:00
|
|
|
// Attribute Method : "PyReference_getPoint ()"
|
2008-03-06 10:46:43 -06:00
|
|
|
|
2008-03-17 08:54:33 -05:00
|
|
|
static PyObject* PyReference_getPoint ( PyReference *self )
|
2008-03-06 10:46:43 -06:00
|
|
|
{
|
2008-03-17 08:54:33 -05:00
|
|
|
trace << "PyReference_getPoint()" << endl;
|
2008-03-06 10:46:43 -06:00
|
|
|
|
2008-03-17 08:54:33 -05:00
|
|
|
METHOD_HEAD ( "Reference.getPoint()" )
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
PyPoint* pyPoint = PyObject_NEW ( PyPoint, &PyTypePoint );
|
|
|
|
if (pyPoint == NULL) { return NULL; }
|
|
|
|
|
|
|
|
HTRY
|
2008-03-17 08:54:33 -05:00
|
|
|
pyPoint->_object = new Point ( reference->getPoint() );
|
2008-03-06 10:46:43 -06:00
|
|
|
HCATCH
|
|
|
|
|
|
|
|
return ( (PyObject*)pyPoint );
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-04-27 07:25:56 -05:00
|
|
|
// ---------------------------------------------------------------
|
|
|
|
// Attribute Method : "PyReference_getBoundingBox ()"
|
|
|
|
|
|
|
|
static PyObject* PyReference_getBoundingBox( PyReference *self ) {
|
|
|
|
trace << "PyReference_getBoundingBox()" << endl;
|
|
|
|
|
|
|
|
METHOD_HEAD ( "Reference.BoundingBox()" )
|
|
|
|
|
|
|
|
PyBox* pyBox = PyObject_NEW ( PyBox, &PyTypeBox );
|
|
|
|
if (pyBox == NULL) { return NULL; }
|
|
|
|
|
|
|
|
HTRY
|
|
|
|
pyBox->_object = new Box ( reference->getBoundingBox() );
|
|
|
|
HCATCH
|
|
|
|
|
|
|
|
return ( (PyObject*)pyBox );
|
|
|
|
}
|
|
|
|
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
|
|
|
|
// ---------------------------------------------------------------
|
2008-03-25 06:06:05 -05:00
|
|
|
// Attribute Method : "PyReference_translate ()"
|
2008-03-06 10:46:43 -06:00
|
|
|
|
2008-03-25 06:06:05 -05:00
|
|
|
static PyObject* PyReference_translate ( PyReference *self, PyObject* args ) {
|
|
|
|
trace << "PyReference_translate ()" << endl;
|
2008-03-06 10:46:43 -06:00
|
|
|
|
2008-03-25 06:06:05 -05:00
|
|
|
METHOD_HEAD ( "Reference.translate()" )
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
PyObject* arg0;
|
|
|
|
PyObject* arg1;
|
|
|
|
|
|
|
|
HTRY
|
|
|
|
|
2008-03-25 06:06:05 -05:00
|
|
|
if ( ! ParseTwoArg ( "Reference.translate", args, INTS2_ARG, &arg0, &arg1 ) ) return ( NULL );
|
2008-03-06 10:46:43 -06:00
|
|
|
|
2008-03-25 06:06:05 -05:00
|
|
|
reference->translate ( PyInt_AsLong(arg0), PyInt_AsLong(arg1) );
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
HCATCH
|
|
|
|
|
|
|
|
Py_RETURN_NONE;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// ---------------------------------------------------------------
|
|
|
|
// PyReference Attribute Method table.
|
|
|
|
|
|
|
|
PyMethodDef PyReference_Methods[] =
|
Make the Python interface closely mirroring the C++ one.
* Change: In Isobar, the Python interface was not exactly mirroring the
C++ one, now it is the case. The Python code should look likes almost
exactly like the C++ one, the only differences remaining being due
to the languages respective syntaxes. Note that in the case of
constructor functions, it leads to a slightly longer notation in
Python that it could have been (mimic the ".create()" static
member). Main modifications:
1. Mirror the static constructor syntax with create():
Cell( ... ) ==> Cell.create( ... )
2. Correct hierarchy for constants in Instance, Net, Pin
& Transformation. For example:
Hurricane.PlacementStatusFIXED
==> Hurricane.Instance.PlacementStatus.FIXED
Hurricane.OrientationID
==> Hurricane.Transformation.Orientation.ID
Hurricane.TypeLOGICAL ==> Hurricane.Net.Type.LOGICAL
Hurricane.DirectionIN ==> Hurricane.Net.Direction.IN
* Change: In CRL Core, correction to match the improved Python API
in the configutation helpers.
* Change: In Cumulus, correction to match the improved Python API.
* Change: In Stratus, correction to match the improved Python API.
* Change: In Documenation, update for the new Python interface
(both user's guide & examples).
* Note: We must port those changes into Chams for it to continue
to run.
* Change: In Documenation, update the Python script support part.
2014-06-28 10:37:59 -05:00
|
|
|
{ { "create" , (PyCFunction)PyReference_create , METH_NOARGS|METH_STATIC
|
|
|
|
, "Create a new Reference." }
|
|
|
|
, { "destroy" , (PyCFunction)PyReference_destroy , METH_NOARGS
|
2008-03-17 08:54:33 -05:00
|
|
|
, "destroy associated hurricane object, the python object remains." }
|
|
|
|
, { "getName" , (PyCFunction)PyReference_getName , METH_NOARGS , "Returns the name of the reference." }
|
|
|
|
, { "getPoint" , (PyCFunction)PyReference_getPoint , METH_NOARGS , "Return the reference point." }
|
2010-04-27 07:25:56 -05:00
|
|
|
, { "getBoundingBox" , (PyCFunction)PyReference_getBoundingBox , METH_NOARGS , "Return the reference boundingBox." }
|
2008-03-25 06:06:05 -05:00
|
|
|
, { "translate" , (PyCFunction)PyReference_translate , METH_VARARGS, "Translate the reference of dx and dy." }
|
2008-03-06 10:46:43 -06:00
|
|
|
, {NULL, NULL, 0, NULL} /* sentinel */
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// x-------------------------------------------------------------x
|
|
|
|
// | "PyReference" Object Methods |
|
|
|
|
// x-------------------------------------------------------------x
|
|
|
|
|
2009-09-30 10:11:49 -05:00
|
|
|
DBoDeleteMethod(Reference)
|
|
|
|
PyTypeObjectLinkPyType(Reference)
|
|
|
|
|
|
|
|
|
|
|
|
# else // End of Python Module Code Part.
|
|
|
|
|
|
|
|
|
|
|
|
// x=================================================================x
|
|
|
|
// | "PyReference" Shared Library Code Part |
|
|
|
|
// x=================================================================x
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Link/Creation Method.
|
2008-10-12 08:37:33 -05:00
|
|
|
DBoLinkCreateMethod(Reference)
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
|
|
|
|
// ---------------------------------------------------------------
|
|
|
|
// PyReference Object Definitions.
|
2009-09-30 10:11:49 -05:00
|
|
|
PyTypeInheritedObjectDefinitions(Reference, Entity)
|
2008-03-06 10:46:43 -06:00
|
|
|
|
|
|
|
|
2008-10-12 08:37: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.
|
|
|
|
|