Removed all castToSomething() methods from Interface0D's subclasses.
These methods are useless, because introspection-based automatic type
conversion takes place whenever it is applicable.
If you need to rewrite old style modules that rely on the cast methods,
apply the following rewriting rules:
- SVertex.castToSVertex()
- TVertex.castToViewVertex()
- TVertex.castToTVertex()
- NonTVertex.castToViewVertex()
- NonTVertex.castToNonTVertex()
These 5 methods return an object itself, so just removing a method
call will suffice. If you need to handle objects in a different way
depending on their types, then you can use Python's type checking
idioms such as "type(obj) is T" and "isinstance(obj, T)". Example:
[Original]
v = it.getObject()
# try to convert v into a TVertex object
vertex = v.castToTVertex()
if vertex != None:
... # do something on the TVertex object
# try to convert v into a NonTVertex object
vertex = v.castToNonTVertex()
if vertex != None:
... # do something on the NonTVertex object
[Rewritten]
vertex = it.getObject()
if type(vertex) is TVertex:
... # do something on the TVertex object
elif type(vertex) is NonTVertex:
... # do something on the NonTVertex object
- SVertex.castToViewVertex()
- SVertex.castToTVertex()
- SVertex.castToNonTVertex()
Use SVertex.viewvertex() instead. You don't need to care about
which cast method is appropriate. SVertex.viewvertex() does, if
necessary, introspection-based automatic type conversion for you.
- NonTVertex.castToSVertex()
Use NonTVertex.svertex() instead.
- CurvePoint.castToSVertex()
Let cp be a CurvePoint object, then this method can be expressed as
follows:
if cp.t2d() == 0.0:
return cp.A() # returns an SVertex
elif cp.t2d() == 1.0:
return cp.B() # returns an SVertex
return None
- CurvePoint.castToViewVertex()
- CurvePoint.castToTVertex()
- CurvePoint.castToNonVertex()
Similarly, these 3 methods can be expressed as follows:
if cp.t2d() == 0.0:
return cp.A().viewvertex()
elif cp.t2d() == 1.0:
return cp.B().viewvertex()
return None
225 lines
7.5 KiB
C++
225 lines
7.5 KiB
C++
#include "BPy_TVertex.h"
|
||
|
||
#include "../../BPy_Convert.h"
|
||
#include "../BPy_SVertex.h"
|
||
#include "../../BPy_Id.h"
|
||
#include "../../Interface1D/BPy_FEdge.h"
|
||
#include "../../Interface1D/BPy_ViewEdge.h"
|
||
|
||
#ifdef __cplusplus
|
||
extern "C" {
|
||
#endif
|
||
|
||
///////////////////////////////////////////////////////////////////////////////////////////
|
||
|
||
/*--------------- Python API function prototypes for TVertex___init__ instance -----------*/
|
||
static int TVertex___init__(BPy_TVertex *self, PyObject *args, PyObject *kwds);
|
||
|
||
static PyObject * TVertex_frontSVertex( BPy_TVertex *self );
|
||
static PyObject * TVertex_backSVertex( BPy_TVertex *self );
|
||
static PyObject * TVertex_setFrontSVertex( BPy_TVertex *self, PyObject *args);
|
||
static PyObject * TVertex_setBackSVertex( BPy_TVertex *self, PyObject *args);
|
||
static PyObject * TVertex_setId( BPy_TVertex *self, PyObject *args);
|
||
static PyObject * TVertex_getSVertex( BPy_TVertex *self, PyObject *args);
|
||
static PyObject * TVertex_mate( BPy_TVertex *self, PyObject *args);
|
||
|
||
/*----------------------TVertex instance definitions ----------------------------*/
|
||
static PyMethodDef BPy_TVertex_methods[] = {
|
||
// {"__copy__", ( PyCFunction ) TVertex___copy__, METH_NOARGS, "( )Cloning method."},
|
||
{"frontSVertex", ( PyCFunction ) TVertex_frontSVertex, METH_NOARGS, "( )Returns the SVertex that is closer to the viewpoint. "},
|
||
{"backSVertex", ( PyCFunction ) TVertex_backSVertex, METH_NOARGS, "( )Returns the SVertex that is further away from the viewpoint. "},
|
||
{"setFrontSVertex", ( PyCFunction ) TVertex_setFrontSVertex, METH_VARARGS, "(SVertex sv )Sets the SVertex that is closer to the viewpoint. "},
|
||
{"setBackSVertex", ( PyCFunction ) TVertex_setBackSVertex, METH_VARARGS, "(SVertex sv )Sets the SVertex that is further away from the viewpoint. "},
|
||
{"setId", ( PyCFunction ) TVertex_setId, METH_VARARGS, "(Id id )Sets the Id."},
|
||
{"getSVertex", ( PyCFunction ) TVertex_getSVertex, METH_VARARGS, "(FEdge fe )Returns the SVertex (among the 2) belonging to the FEdge iFEdge "},
|
||
{"mate", ( PyCFunction ) TVertex_mate, METH_VARARGS, "(ViewEdge ve )Returns the mate edge of iEdgeA. For example, if iEdgeA is frontEdgeA, then frontEdgeB is returned. If iEdgeA is frontEdgeB then frontEdgeA is returned. Same for back edges"},
|
||
{NULL, NULL, 0, NULL}
|
||
};
|
||
|
||
/*-----------------------BPy_TVertex type definition ------------------------------*/
|
||
|
||
PyTypeObject TVertex_Type = {
|
||
PyObject_HEAD_INIT( NULL )
|
||
0, /* ob_size */
|
||
"TVertex", /* tp_name */
|
||
sizeof( BPy_TVertex ), /* tp_basicsize */
|
||
0, /* tp_itemsize */
|
||
|
||
/* methods */
|
||
NULL, /* tp_dealloc */
|
||
NULL, /* printfunc tp_print; */
|
||
NULL, /* getattrfunc tp_getattr; */
|
||
NULL, /* setattrfunc tp_setattr; */
|
||
NULL, /* tp_compare */
|
||
NULL, /* tp_repr */
|
||
|
||
/* Method suites for standard classes */
|
||
|
||
NULL, /* PyNumberMethods *tp_as_number; */
|
||
NULL, /* PySequenceMethods *tp_as_sequence; */
|
||
NULL, /* PyMappingMethods *tp_as_mapping; */
|
||
|
||
/* More standard operations (here for binary compatibility) */
|
||
|
||
NULL, /* hashfunc tp_hash; */
|
||
NULL, /* ternaryfunc tp_call; */
|
||
NULL, /* reprfunc tp_str; */
|
||
NULL, /* getattrofunc tp_getattro; */
|
||
NULL, /* setattrofunc tp_setattro; */
|
||
|
||
/* Functions to access object as input/output buffer */
|
||
NULL, /* PyBufferProcs *tp_as_buffer; */
|
||
|
||
/*** Flags to define presence of optional/expanded features ***/
|
||
Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /* long tp_flags; */
|
||
|
||
NULL, /* char *tp_doc; Documentation string */
|
||
/*** Assigned meaning in release 2.0 ***/
|
||
/* call function for all accessible objects */
|
||
NULL, /* traverseproc tp_traverse; */
|
||
|
||
/* delete references to contained objects */
|
||
NULL, /* inquiry tp_clear; */
|
||
|
||
/*** Assigned meaning in release 2.1 ***/
|
||
/*** rich comparisons ***/
|
||
NULL, /* richcmpfunc tp_richcompare; */
|
||
|
||
/*** weak reference enabler ***/
|
||
0, /* long tp_weaklistoffset; */
|
||
|
||
/*** Added in release 2.2 ***/
|
||
/* Iterators */
|
||
NULL, /* getiterfunc tp_iter; */
|
||
NULL, /* iternextfunc tp_iternext; */
|
||
|
||
/*** Attribute descriptor and subclassing stuff ***/
|
||
BPy_TVertex_methods, /* struct PyMethodDef *tp_methods; */
|
||
NULL, /* struct PyMemberDef *tp_members; */
|
||
NULL, /* struct PyGetSetDef *tp_getset; */
|
||
&ViewVertex_Type, /* struct _typeobject *tp_base; */
|
||
NULL, /* PyObject *tp_dict; */
|
||
NULL, /* descrgetfunc tp_descr_get; */
|
||
NULL, /* descrsetfunc tp_descr_set; */
|
||
0, /* long tp_dictoffset; */
|
||
(initproc)TVertex___init__, /* initproc tp_init; */
|
||
NULL, /* allocfunc tp_alloc; */
|
||
NULL, /* newfunc tp_new; */
|
||
|
||
/* Low-level free-memory routine */
|
||
NULL, /* freefunc tp_free; */
|
||
|
||
/* For PyObject_IS_GC */
|
||
NULL, /* inquiry tp_is_gc; */
|
||
NULL, /* PyObject *tp_bases; */
|
||
|
||
/* method resolution order */
|
||
NULL, /* PyObject *tp_mro; */
|
||
NULL, /* PyObject *tp_cache; */
|
||
NULL, /* PyObject *tp_subclasses; */
|
||
NULL, /* PyObject *tp_weaklist; */
|
||
NULL
|
||
};
|
||
|
||
|
||
|
||
//------------------------INSTANCE METHODS ----------------------------------
|
||
|
||
int TVertex___init__(BPy_TVertex *self, PyObject *args, PyObject *kwds)
|
||
{
|
||
self->tv = new TVertex();
|
||
self->py_vv.vv = self->tv;
|
||
self->py_vv.py_if0D.if0D = self->tv;
|
||
self->py_vv.py_if0D.borrowed = 0;
|
||
|
||
return 0;
|
||
}
|
||
|
||
|
||
PyObject * TVertex_frontSVertex( BPy_TVertex *self ) {
|
||
SVertex *v = self->tv->frontSVertex();
|
||
if( v ){
|
||
return BPy_SVertex_from_SVertex( *v );
|
||
}
|
||
|
||
Py_RETURN_NONE;
|
||
}
|
||
|
||
PyObject * TVertex_backSVertex( BPy_TVertex *self ) {
|
||
SVertex *v = self->tv->backSVertex();
|
||
if( v ){
|
||
return BPy_SVertex_from_SVertex( *v );
|
||
}
|
||
|
||
Py_RETURN_NONE;
|
||
}
|
||
|
||
PyObject * TVertex_setFrontSVertex( BPy_TVertex *self, PyObject *args) {
|
||
PyObject *py_sv;
|
||
|
||
if(!( PyArg_ParseTuple(args, "O!", &SVertex_Type, &py_sv) ))
|
||
return NULL;
|
||
|
||
self->tv->setFrontSVertex( ((BPy_SVertex *) py_sv)->sv );
|
||
|
||
Py_RETURN_NONE;
|
||
}
|
||
|
||
PyObject * TVertex_setBackSVertex( BPy_TVertex *self, PyObject *args) {
|
||
PyObject *py_sv;
|
||
|
||
if(!( PyArg_ParseTuple(args, "O", &SVertex_Type, &py_sv) ))
|
||
return NULL;
|
||
|
||
self->tv->setBackSVertex( ((BPy_SVertex *) py_sv)->sv );
|
||
|
||
Py_RETURN_NONE;
|
||
}
|
||
|
||
PyObject * TVertex_setId( BPy_TVertex *self, PyObject *args) {
|
||
PyObject *py_id;
|
||
|
||
if(!( PyArg_ParseTuple(args, "O!", &Id_Type, &py_id) ))
|
||
return NULL;
|
||
|
||
if( ((BPy_Id *) py_id)->id )
|
||
self->tv->setId(*( ((BPy_Id *) py_id)->id ));
|
||
|
||
Py_RETURN_NONE;
|
||
}
|
||
|
||
PyObject * TVertex_getSVertex( BPy_TVertex *self, PyObject *args) {
|
||
PyObject *py_fe;
|
||
|
||
if(!( PyArg_ParseTuple(args, "O!", &FEdge_Type, &py_fe) ))
|
||
return NULL;
|
||
|
||
SVertex *sv = self->tv->getSVertex( ((BPy_FEdge *) py_fe)->fe );
|
||
if( sv ){
|
||
return BPy_SVertex_from_SVertex( *sv );
|
||
}
|
||
|
||
Py_RETURN_NONE;
|
||
}
|
||
|
||
PyObject * TVertex_mate( BPy_TVertex *self, PyObject *args) {
|
||
PyObject *py_ve;
|
||
|
||
if(!( PyArg_ParseTuple(args, "O!", &ViewEdge_Type, &py_ve) ))
|
||
return NULL;
|
||
|
||
ViewEdge *ve = self->tv->mate( ((BPy_ViewEdge *) py_ve)->ve );
|
||
if( ve ){
|
||
return BPy_ViewEdge_from_ViewEdge( *ve );
|
||
}
|
||
|
||
Py_RETURN_NONE;
|
||
}
|
||
|
||
|
||
///////////////////////////////////////////////////////////////////////////////////////////
|
||
|
||
#ifdef __cplusplus
|
||
}
|
||
#endif
|