172 lines
5.4 KiB
C++
172 lines
5.4 KiB
C++
#include "BPy_Chain.h"
|
|
|
|
#include "../../BPy_Convert.h"
|
|
#include "../../BPy_Id.h"
|
|
#include "../BPy_ViewEdge.h"
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
///////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
//------------------------INSTANCE METHODS ----------------------------------
|
|
|
|
static char Chain___doc__[] =
|
|
"Class hierarchy: :class:`Interface1D` > :class:`Curve` > :class:`Chain`\n"
|
|
"\n"
|
|
"Class to represent a 1D elements issued from the chaining process. A\n"
|
|
"Chain is the last step before the :class:`Stroke` and is used in the\n"
|
|
"Splitting and Creation processes.\n"
|
|
"\n"
|
|
".. method:: __init__()\n"
|
|
"\n"
|
|
" Defult constructor.\n"
|
|
"\n"
|
|
".. method:: __init__(iBrother)\n"
|
|
"\n"
|
|
" Copy constructor.\n"
|
|
"\n"
|
|
" :arg iBrother: A Chain object.\n"
|
|
" :type iBrother: :class:`Chain`\n"
|
|
"\n"
|
|
".. method:: __init__(id)\n"
|
|
"\n"
|
|
" Builds a chain from its Id.\n"
|
|
"\n"
|
|
" :arg id: An Id object.\n"
|
|
" :type id: :class:`Id`\n";
|
|
|
|
static int Chain___init__(BPy_Chain *self, PyObject *args, PyObject *kwds)
|
|
{
|
|
|
|
PyObject *obj = 0;
|
|
|
|
if (! PyArg_ParseTuple(args, "|O", &obj) )
|
|
return -1;
|
|
|
|
if( !obj ){
|
|
self->c = new Chain();
|
|
|
|
} else if( BPy_Chain_Check(obj) ) {
|
|
self->c = new Chain(*( ((BPy_Chain *) obj)->c ));
|
|
|
|
} else if( BPy_Id_Check(obj) ) {
|
|
self->c = new Chain(*( ((BPy_Id *) obj)->id ));
|
|
|
|
} else {
|
|
PyErr_SetString(PyExc_TypeError, "invalid argument");
|
|
return -1;
|
|
}
|
|
|
|
self->py_c.c = self->c;
|
|
self->py_c.py_if1D.if1D = self->c;
|
|
self->py_c.py_if1D.borrowed = 0;
|
|
|
|
return 0;
|
|
}
|
|
|
|
static char Chain_push_viewedge_back___doc__[] =
|
|
".. method:: push_viewedge_back(iViewEdge, orientation)\n"
|
|
"\n"
|
|
" Adds a ViewEdge at the end of the Chain.\n"
|
|
"\n"
|
|
" :arg iViewEdge: The ViewEdge that must be added.\n"
|
|
" :type iViewEdge: :class:`ViewEdge`\n"
|
|
" :arg orientation: The orientation with which the ViewEdge must be\n"
|
|
" processed.\n"
|
|
" :type orientation: bool\n";
|
|
|
|
static PyObject * Chain_push_viewedge_back( BPy_Chain *self, PyObject *args ) {
|
|
PyObject *obj1 = 0, *obj2 = 0;
|
|
|
|
if(!( PyArg_ParseTuple(args, "O!O", &ViewEdge_Type, &obj1, &obj2) ))
|
|
return NULL;
|
|
|
|
ViewEdge *ve = ((BPy_ViewEdge *) obj1)->ve;
|
|
bool orientation = bool_from_PyBool( obj2 );
|
|
self->c->push_viewedge_back( ve, orientation);
|
|
|
|
Py_RETURN_NONE;
|
|
}
|
|
|
|
static char Chain_push_viewedge_front___doc__[] =
|
|
".. method:: push_viewedge_front(iViewEdge, orientation)\n"
|
|
"\n"
|
|
" Adds a ViewEdge at the beginning of the Chain.\n"
|
|
"\n"
|
|
" :arg iViewEdge: The ViewEdge that must be added.\n"
|
|
" :type iViewEdge: :class:`ViewEdge`\n"
|
|
" :arg orientation: The orientation with which the ViewEdge must be\n"
|
|
" processed.\n"
|
|
" :type orientation: bool\n";
|
|
|
|
static PyObject * Chain_push_viewedge_front( BPy_Chain *self, PyObject *args ) {
|
|
PyObject *obj1 = 0, *obj2 = 0;
|
|
|
|
if(!( PyArg_ParseTuple(args, "O!O", &ViewEdge_Type, &obj1, &obj2) ))
|
|
return NULL;
|
|
|
|
ViewEdge *ve = ((BPy_ViewEdge *) obj1)->ve;
|
|
bool orientation = bool_from_PyBool( obj2 );
|
|
self->c->push_viewedge_front(ve, orientation);
|
|
|
|
Py_RETURN_NONE;
|
|
}
|
|
|
|
/*----------------------Chain instance definitions ----------------------------*/
|
|
static PyMethodDef BPy_Chain_methods[] = {
|
|
{"push_viewedge_back", ( PyCFunction ) Chain_push_viewedge_back, METH_VARARGS, Chain_push_viewedge_back___doc__},
|
|
{"push_viewedge_front", ( PyCFunction ) Chain_push_viewedge_front, METH_VARARGS, Chain_push_viewedge_front___doc__},
|
|
{NULL, NULL, 0, NULL}
|
|
};
|
|
|
|
/*-----------------------BPy_Chain type definition ------------------------------*/
|
|
|
|
PyTypeObject Chain_Type = {
|
|
PyVarObject_HEAD_INIT(NULL, 0)
|
|
"Chain", /* tp_name */
|
|
sizeof(BPy_Chain), /* tp_basicsize */
|
|
0, /* tp_itemsize */
|
|
0, /* tp_dealloc */
|
|
0, /* tp_print */
|
|
0, /* tp_getattr */
|
|
0, /* tp_setattr */
|
|
0, /* tp_reserved */
|
|
0, /* tp_repr */
|
|
0, /* tp_as_number */
|
|
0, /* tp_as_sequence */
|
|
0, /* tp_as_mapping */
|
|
0, /* tp_hash */
|
|
0, /* tp_call */
|
|
0, /* tp_str */
|
|
0, /* tp_getattro */
|
|
0, /* tp_setattro */
|
|
0, /* tp_as_buffer */
|
|
Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE, /* tp_flags */
|
|
Chain___doc__, /* tp_doc */
|
|
0, /* tp_traverse */
|
|
0, /* tp_clear */
|
|
0, /* tp_richcompare */
|
|
0, /* tp_weaklistoffset */
|
|
0, /* tp_iter */
|
|
0, /* tp_iternext */
|
|
BPy_Chain_methods, /* tp_methods */
|
|
0, /* tp_members */
|
|
0, /* tp_getset */
|
|
&FrsCurve_Type, /* tp_base */
|
|
0, /* tp_dict */
|
|
0, /* tp_descr_get */
|
|
0, /* tp_descr_set */
|
|
0, /* tp_dictoffset */
|
|
(initproc)Chain___init__, /* tp_init */
|
|
0, /* tp_alloc */
|
|
0, /* tp_new */
|
|
};
|
|
|
|
///////////////////////////////////////////////////////////////////////////////////////////
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|