Export the Pin name and direction to the Python interface.

* New: In Hurricane::PyPin, export ::getName() and ::getPlacementStatus().
This commit is contained in:
Jean-Paul Chaput 2020-08-02 18:07:27 +02:00
parent 134044ee99
commit 0745498505
1 changed files with 27 additions and 6 deletions

View File

@ -47,6 +47,9 @@ extern "C" {
// x-------------------------------------------------------------x // x-------------------------------------------------------------x
GetNameMethod(Pin, pin)
static Pin::PlacementStatus PyInt_AsPlacementStatus ( PyObject* object ) { static Pin::PlacementStatus PyInt_AsPlacementStatus ( PyObject* object ) {
switch ( PyAny_AsLong(object) ) { switch ( PyAny_AsLong(object) ) {
case Pin::PlacementStatus::UNPLACED : return ( Pin::PlacementStatus(Pin::PlacementStatus::UNPLACED) ); case Pin::PlacementStatus::UNPLACED : return ( Pin::PlacementStatus(Pin::PlacementStatus::UNPLACED) );
@ -151,13 +154,27 @@ extern "C" {
// Standart Accessors (Attributes). // Standart Accessors (Attributes).
PyObject* PyPin_getAccessDirection( PyPin* self ) { PyObject* PyPin_getAccessDirection( PyPin* self )
cdebug_log(20,0) << "PyNet_getAccessDirection ()" << endl; {
cdebug_log(20,0) << "PyPin_getAccessDirection ()" << endl;
METHOD_HEAD ( "Pin.getAccessDirection()" )
PyObject* pyObject = NULL;
HTRY
pyObject = (PyObject*)PyLong_FromLong( pin->getAccessDirection().getCode() );
HCATCH
return pyObject;
}
METHOD_HEAD ( "Net.getAccessDirection()" )
return (PyObject *)PyLong_FromLong( pin->getAccessDirection().getCode() );
static PyObject* PyPin_getPlacementStatus ( PyPin *self )
{
cdebug_log(20,0) << "PyPin_getPlacementStatus ()" << endl;
METHOD_HEAD ( "Pin.getPlacementStatus()" );
PyObject* pyObject = NULL;
HTRY
pyObject = (PyObject*)PyLong_FromLong((long)pin->getPlacementStatus().getCode());
HCATCH
return pyObject;
} }
@ -167,8 +184,12 @@ extern "C" {
PyMethodDef PyPin_Methods[] = PyMethodDef PyPin_Methods[] =
{ { "create" , (PyCFunction)PyPin_create , METH_VARARGS|METH_STATIC { { "create" , (PyCFunction)PyPin_create , METH_VARARGS|METH_STATIC
, "Create a new Pin." } , "Create a new Pin." }
, { "getName" , (PyCFunction)PyPin_getName , METH_NOARGS
, "Returns the pin name (may differ from the net name)." }
, { "getAccessDirection" , (PyCFunction)PyPin_getAccessDirection , METH_NOARGS , { "getAccessDirection" , (PyCFunction)PyPin_getAccessDirection , METH_NOARGS
, "Returns the pin accessdirection (by default set to UNDEFINED) ." } , "Returns the pin accessdirection (by default set to UNDEFINED) ." }
, { "getPlacementStatus" , (PyCFunction)PyPin_getPlacementStatus , METH_NOARGS
, "Returns the placement status of the pin." }
, {NULL, NULL, 0, NULL} /* sentinel */ , {NULL, NULL, 0, NULL} /* sentinel */
}; };