2008-07-23 07:56:08 +00:00
# include "BPy_Interface0D.h"
2008-07-12 04:02:08 +00:00
2008-07-23 07:56:08 +00:00
# include "BPy_Convert.h"
# include "Interface0D/BPy_CurvePoint.h"
# include "Interface0D/CurvePoint/BPy_StrokeVertex.h"
# include "Interface0D/BPy_SVertex.h"
# include "Interface0D/BPy_ViewVertex.h"
# include "Interface1D/BPy_FEdge.h"
# include "BPy_Nature.h"
2008-07-12 04:02:08 +00:00
# ifdef __cplusplus
extern " C " {
# endif
///////////////////////////////////////////////////////////////////////////////////////////
2008-07-15 01:07:19 +00:00
/*--------------- Python API function prototypes for Interface0D instance -----------*/
soc-2008-mxcurioni: reimplemented the initialization/allocation for base classes. The Python object type tp_new slot is now set to PyType_GenericNew, instead of the former custom functions. As a note, by default, Python does not set this slot: it is therefore mandatory for the base classes. For children classes, only __init__ is needed.
To make our base classes subclasses, the Py_TPFLAGS_BASETYPE flag was added to the object type tp_flags slot.
Finally, I began to implement CurvePoint, descendant of Interface0D. This commit allowed me to verify that my SWIG replacement method works: interfaces are well taken into account by children. For a test, use the following code:
================================
import Blender
from Blender import Freestyle
from Blender.Freestyle import *
print Interface0D()
print CurvePoint()
================================
The __repr__ method is only implemented in Interface0D:
PyObject * Interface0D___repr__(BPy_Interface0D* self)
{
return PyString_FromFormat("type: %s - address: %p", self->if0D->getExactTypeName().c_str(), self->if0D );}
and the result is of the form:
type: Interface0D - address: 0x18e5ccc0
type: CurvePoint - address: 0x18e473f0
As you can see, the correct getExactTypeName of the class is called.
2008-07-15 05:33:12 +00:00
static int Interface0D___init__ ( BPy_Interface0D * self , PyObject * args , PyObject * kwds ) ;
2008-07-15 01:07:19 +00:00
static void Interface0D___dealloc__ ( BPy_Interface0D * self ) ;
static PyObject * Interface0D___repr__ ( BPy_Interface0D * self ) ;
static PyObject * Interface0D_getExactTypeName ( BPy_Interface0D * self ) ;
static PyObject * Interface0D_getX ( BPy_Interface0D * self ) ;
static PyObject * Interface0D_getY ( BPy_Interface0D * self ) ;
static PyObject * Interface0D_getZ ( BPy_Interface0D * self ) ;
static PyObject * Interface0D_getPoint3D ( BPy_Interface0D * self ) ;
static PyObject * Interface0D_getProjectedX ( BPy_Interface0D * self ) ;
static PyObject * Interface0D_getProjectedY ( BPy_Interface0D * self ) ;
static PyObject * Interface0D_getProjectedZ ( BPy_Interface0D * self ) ;
static PyObject * Interface0D_getPoint2D ( BPy_Interface0D * self ) ;
2008-07-18 02:55:23 +00:00
static PyObject * Interface0D_getFEdge ( BPy_Interface0D * self , PyObject * args ) ;
2008-07-15 01:07:19 +00:00
static PyObject * Interface0D_getId ( BPy_Interface0D * self ) ;
static PyObject * Interface0D_getNature ( BPy_Interface0D * self ) ;
/*----------------------Interface0D instance definitions ----------------------------*/
static PyMethodDef BPy_Interface0D_methods [ ] = {
{ " getExactTypeName " , ( PyCFunction ) Interface0D_getExactTypeName , METH_NOARGS , " ( ) Returns the string of the name of the interface." } ,
{ " getX " , ( PyCFunction ) Interface0D_getX , METH_NOARGS , " ( ) Returns the 3D x coordinate of the point. " } ,
{ " getY " , ( PyCFunction ) Interface0D_getY , METH_NOARGS , " ( ) Returns the 3D y coordinate of the point. " } ,
{ " getZ " , ( PyCFunction ) Interface0D_getZ , METH_NOARGS , " ( ) Returns the 3D z coordinate of the point. " } ,
{ " getPoint3D " , ( PyCFunction ) Interface0D_getPoint3D , METH_NOARGS , " () Returns the 3D point. " } ,
{ " getProjectedX " , ( PyCFunction ) Interface0D_getProjectedX , METH_NOARGS , " () Returns the 2D x coordinate of the point. " } ,
{ " getProjectedY " , ( PyCFunction ) Interface0D_getProjectedY , METH_NOARGS , " () Returns the 2D y coordinate of the point. " } ,
{ " getProjectedZ " , ( PyCFunction ) Interface0D_getProjectedZ , METH_NOARGS , " () Returns the 2D z coordinate of the point. " } ,
{ " getPoint2D " , ( PyCFunction ) Interface0D_getPoint2D , METH_NOARGS , " () Returns the 2D point. " } ,
2008-07-18 02:55:23 +00:00
{ " getFEdge " , ( PyCFunction ) Interface0D_getFEdge , METH_VARARGS , " (Interface0D i) Returns the FEdge that lies between this Interface0D and the Interface0D given as argument. " } ,
2008-07-15 01:07:19 +00:00
{ " getId " , ( PyCFunction ) Interface0D_getId , METH_NOARGS , " () Returns the Id of the point. " } ,
{ " getNature " , ( PyCFunction ) Interface0D_getNature , METH_NOARGS , " () Returns the nature of the point. " } ,
2008-07-12 04:02:08 +00:00
{ NULL , NULL , 0 , NULL }
} ;
2008-07-15 01:07:19 +00:00
/*-----------------------BPy_Interface0D type definition ------------------------------*/
2008-07-12 04:02:08 +00:00
PyTypeObject Interface0D_Type = {
PyObject_HEAD_INIT ( NULL )
0 , /* ob_size */
" Interface0D " , /* tp_name */
sizeof ( BPy_Interface0D ) , /* tp_basicsize */
0 , /* tp_itemsize */
/* methods */
2008-07-15 01:07:19 +00:00
( destructor ) Interface0D___dealloc__ , /* tp_dealloc */
NULL , /* printfunc tp_print; */
NULL , /* getattrfunc tp_getattr; */
NULL , /* setattrfunc tp_setattr; */
NULL , /* tp_compare */
( reprfunc ) Interface0D___repr__ , /* tp_repr */
2008-07-12 04:02:08 +00:00
/* Method suites for standard classes */
NULL , /* PyNumberMethods *tp_as_number; */
NULL , /* PySequenceMethods *tp_as_sequence; */
NULL , /* PyMappingMethods *tp_as_mapping; */
2008-07-09 08:24:13 +00:00
2008-07-12 04:02:08 +00:00
/* More standard operations (here for binary compatibility) */
2008-07-09 08:24:13 +00:00
2008-07-12 04:02:08 +00:00
NULL , /* hashfunc tp_hash; */
NULL , /* ternaryfunc tp_call; */
NULL , /* reprfunc tp_str; */
NULL , /* getattrofunc tp_getattro; */
NULL , /* setattrofunc tp_setattro; */
2008-07-09 08:24:13 +00:00
2008-07-12 04:02:08 +00:00
/* Functions to access object as input/output buffer */
NULL , /* PyBufferProcs *tp_as_buffer; */
2008-07-09 08:24:13 +00:00
2008-07-12 04:02:08 +00:00
/*** Flags to define presence of optional/expanded features ***/
soc-2008-mxcurioni: reimplemented the initialization/allocation for base classes. The Python object type tp_new slot is now set to PyType_GenericNew, instead of the former custom functions. As a note, by default, Python does not set this slot: it is therefore mandatory for the base classes. For children classes, only __init__ is needed.
To make our base classes subclasses, the Py_TPFLAGS_BASETYPE flag was added to the object type tp_flags slot.
Finally, I began to implement CurvePoint, descendant of Interface0D. This commit allowed me to verify that my SWIG replacement method works: interfaces are well taken into account by children. For a test, use the following code:
================================
import Blender
from Blender import Freestyle
from Blender.Freestyle import *
print Interface0D()
print CurvePoint()
================================
The __repr__ method is only implemented in Interface0D:
PyObject * Interface0D___repr__(BPy_Interface0D* self)
{
return PyString_FromFormat("type: %s - address: %p", self->if0D->getExactTypeName().c_str(), self->if0D );}
and the result is of the form:
type: Interface0D - address: 0x18e5ccc0
type: CurvePoint - address: 0x18e473f0
As you can see, the correct getExactTypeName of the class is called.
2008-07-15 05:33:12 +00:00
Py_TPFLAGS_DEFAULT | Py_TPFLAGS_BASETYPE , /* long tp_flags; */
2008-07-09 08:24:13 +00:00
2008-07-12 04:02:08 +00:00
NULL , /* char *tp_doc; Documentation string */
/*** Assigned meaning in release 2.0 ***/
/* call function for all accessible objects */
NULL , /* traverseproc tp_traverse; */
2008-07-09 08:24:13 +00:00
2008-07-12 04:02:08 +00:00
/* delete references to contained objects */
NULL , /* inquiry tp_clear; */
/*** Assigned meaning in release 2.1 ***/
/*** rich comparisons ***/
NULL , /* richcmpfunc tp_richcompare; */
2008-07-09 08:24:13 +00:00
2008-07-12 04:02:08 +00:00
/*** weak reference enabler ***/
0 , /* long tp_weaklistoffset; */
2008-07-09 08:24:13 +00:00
2008-07-12 04:02:08 +00:00
/*** Added in release 2.2 ***/
/* Iterators */
NULL , /* getiterfunc tp_iter; */
NULL , /* iternextfunc tp_iternext; */
/*** Attribute descriptor and subclassing stuff ***/
2008-07-15 01:07:19 +00:00
BPy_Interface0D_methods , /* struct PyMethodDef *tp_methods; */
NULL , /* struct PyMemberDef *tp_members; */
NULL , /* struct PyGetSetDef *tp_getset; */
NULL , /* struct _typeobject *tp_base; */
NULL , /* PyObject *tp_dict; */
NULL , /* descrgetfunc tp_descr_get; */
NULL , /* descrsetfunc tp_descr_set; */
0 , /* long tp_dictoffset; */
soc-2008-mxcurioni: reimplemented the initialization/allocation for base classes. The Python object type tp_new slot is now set to PyType_GenericNew, instead of the former custom functions. As a note, by default, Python does not set this slot: it is therefore mandatory for the base classes. For children classes, only __init__ is needed.
To make our base classes subclasses, the Py_TPFLAGS_BASETYPE flag was added to the object type tp_flags slot.
Finally, I began to implement CurvePoint, descendant of Interface0D. This commit allowed me to verify that my SWIG replacement method works: interfaces are well taken into account by children. For a test, use the following code:
================================
import Blender
from Blender import Freestyle
from Blender.Freestyle import *
print Interface0D()
print CurvePoint()
================================
The __repr__ method is only implemented in Interface0D:
PyObject * Interface0D___repr__(BPy_Interface0D* self)
{
return PyString_FromFormat("type: %s - address: %p", self->if0D->getExactTypeName().c_str(), self->if0D );}
and the result is of the form:
type: Interface0D - address: 0x18e5ccc0
type: CurvePoint - address: 0x18e473f0
As you can see, the correct getExactTypeName of the class is called.
2008-07-15 05:33:12 +00:00
( initproc ) Interface0D___init__ , /* initproc tp_init; */
2008-07-15 01:07:19 +00:00
NULL , /* allocfunc tp_alloc; */
soc-2008-mxcurioni: reimplemented the initialization/allocation for base classes. The Python object type tp_new slot is now set to PyType_GenericNew, instead of the former custom functions. As a note, by default, Python does not set this slot: it is therefore mandatory for the base classes. For children classes, only __init__ is needed.
To make our base classes subclasses, the Py_TPFLAGS_BASETYPE flag was added to the object type tp_flags slot.
Finally, I began to implement CurvePoint, descendant of Interface0D. This commit allowed me to verify that my SWIG replacement method works: interfaces are well taken into account by children. For a test, use the following code:
================================
import Blender
from Blender import Freestyle
from Blender.Freestyle import *
print Interface0D()
print CurvePoint()
================================
The __repr__ method is only implemented in Interface0D:
PyObject * Interface0D___repr__(BPy_Interface0D* self)
{
return PyString_FromFormat("type: %s - address: %p", self->if0D->getExactTypeName().c_str(), self->if0D );}
and the result is of the form:
type: Interface0D - address: 0x18e5ccc0
type: CurvePoint - address: 0x18e473f0
As you can see, the correct getExactTypeName of the class is called.
2008-07-15 05:33:12 +00:00
PyType_GenericNew , /* newfunc tp_new; */
2008-07-12 04:02:08 +00:00
/* 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
} ;
//-------------------MODULE INITIALIZATION--------------------------------
2008-07-15 01:07:19 +00:00
PyMODINIT_FUNC Interface0D_Init ( PyObject * module )
2008-07-12 04:02:08 +00:00
{
2008-07-15 01:07:19 +00:00
if ( module = = NULL )
return ;
2008-07-12 04:02:08 +00:00
if ( PyType_Ready ( & Interface0D_Type ) < 0 )
2008-07-15 01:07:19 +00:00
return ;
Py_INCREF ( & Interface0D_Type ) ;
PyModule_AddObject ( module , " Interface0D " , ( PyObject * ) & Interface0D_Type ) ;
2008-07-17 06:35:30 +00:00
if ( PyType_Ready ( & CurvePoint_Type ) < 0 )
return ;
soc-2008-mxcurioni: reimplemented the initialization/allocation for base classes. The Python object type tp_new slot is now set to PyType_GenericNew, instead of the former custom functions. As a note, by default, Python does not set this slot: it is therefore mandatory for the base classes. For children classes, only __init__ is needed.
To make our base classes subclasses, the Py_TPFLAGS_BASETYPE flag was added to the object type tp_flags slot.
Finally, I began to implement CurvePoint, descendant of Interface0D. This commit allowed me to verify that my SWIG replacement method works: interfaces are well taken into account by children. For a test, use the following code:
================================
import Blender
from Blender import Freestyle
from Blender.Freestyle import *
print Interface0D()
print CurvePoint()
================================
The __repr__ method is only implemented in Interface0D:
PyObject * Interface0D___repr__(BPy_Interface0D* self)
{
return PyString_FromFormat("type: %s - address: %p", self->if0D->getExactTypeName().c_str(), self->if0D );}
and the result is of the form:
type: Interface0D - address: 0x18e5ccc0
type: CurvePoint - address: 0x18e473f0
As you can see, the correct getExactTypeName of the class is called.
2008-07-15 05:33:12 +00:00
Py_INCREF ( & CurvePoint_Type ) ;
PyModule_AddObject ( module , " CurvePoint " , ( PyObject * ) & CurvePoint_Type ) ;
2008-07-17 06:35:30 +00:00
if ( PyType_Ready ( & SVertex_Type ) < 0 )
return ;
Py_INCREF ( & SVertex_Type ) ;
PyModule_AddObject ( module , " SVertex " , ( PyObject * ) & SVertex_Type ) ;
2008-07-20 05:01:29 +00:00
if ( PyType_Ready ( & ViewVertex_Type ) < 0 )
return ;
Py_INCREF ( & ViewVertex_Type ) ;
PyModule_AddObject ( module , " ViewVertex " , ( PyObject * ) & ViewVertex_Type ) ;
2008-07-22 08:15:21 +00:00
if ( PyType_Ready ( & StrokeVertex_Type ) < 0 )
return ;
Py_INCREF ( & StrokeVertex_Type ) ;
PyModule_AddObject ( module , " StrokeVertex " , ( PyObject * ) & StrokeVertex_Type ) ;
2008-07-09 08:24:13 +00:00
}
2008-07-12 04:02:08 +00:00
//------------------------INSTANCE METHODS ----------------------------------
2008-07-09 08:24:13 +00:00
soc-2008-mxcurioni: reimplemented the initialization/allocation for base classes. The Python object type tp_new slot is now set to PyType_GenericNew, instead of the former custom functions. As a note, by default, Python does not set this slot: it is therefore mandatory for the base classes. For children classes, only __init__ is needed.
To make our base classes subclasses, the Py_TPFLAGS_BASETYPE flag was added to the object type tp_flags slot.
Finally, I began to implement CurvePoint, descendant of Interface0D. This commit allowed me to verify that my SWIG replacement method works: interfaces are well taken into account by children. For a test, use the following code:
================================
import Blender
from Blender import Freestyle
from Blender.Freestyle import *
print Interface0D()
print CurvePoint()
================================
The __repr__ method is only implemented in Interface0D:
PyObject * Interface0D___repr__(BPy_Interface0D* self)
{
return PyString_FromFormat("type: %s - address: %p", self->if0D->getExactTypeName().c_str(), self->if0D );}
and the result is of the form:
type: Interface0D - address: 0x18e5ccc0
type: CurvePoint - address: 0x18e473f0
As you can see, the correct getExactTypeName of the class is called.
2008-07-15 05:33:12 +00:00
int Interface0D___init__ ( BPy_Interface0D * self , PyObject * args , PyObject * kwds )
2008-07-15 01:07:19 +00:00
{
soc-2008-mxcurioni: reimplemented the initialization/allocation for base classes. The Python object type tp_new slot is now set to PyType_GenericNew, instead of the former custom functions. As a note, by default, Python does not set this slot: it is therefore mandatory for the base classes. For children classes, only __init__ is needed.
To make our base classes subclasses, the Py_TPFLAGS_BASETYPE flag was added to the object type tp_flags slot.
Finally, I began to implement CurvePoint, descendant of Interface0D. This commit allowed me to verify that my SWIG replacement method works: interfaces are well taken into account by children. For a test, use the following code:
================================
import Blender
from Blender import Freestyle
from Blender.Freestyle import *
print Interface0D()
print CurvePoint()
================================
The __repr__ method is only implemented in Interface0D:
PyObject * Interface0D___repr__(BPy_Interface0D* self)
{
return PyString_FromFormat("type: %s - address: %p", self->if0D->getExactTypeName().c_str(), self->if0D );}
and the result is of the form:
type: Interface0D - address: 0x18e5ccc0
type: CurvePoint - address: 0x18e473f0
As you can see, the correct getExactTypeName of the class is called.
2008-07-15 05:33:12 +00:00
self - > if0D = new Interface0D ( ) ;
return 0 ;
2008-07-15 01:07:19 +00:00
}
void Interface0D___dealloc__ ( BPy_Interface0D * self )
{
delete self - > if0D ;
self - > ob_type - > tp_free ( ( PyObject * ) self ) ;
}
PyObject * Interface0D___repr__ ( BPy_Interface0D * self )
{
return PyString_FromFormat ( " type: %s - address: %p " , self - > if0D - > getExactTypeName ( ) . c_str ( ) , self - > if0D ) ;
}
2008-07-12 04:02:08 +00:00
PyObject * Interface0D_getExactTypeName ( BPy_Interface0D * self ) {
return PyString_FromString ( self - > if0D - > getExactTypeName ( ) . c_str ( ) ) ;
2008-07-09 08:24:13 +00:00
}
2008-07-12 04:02:08 +00:00
PyObject * Interface0D_getX ( BPy_Interface0D * self ) {
return PyFloat_FromDouble ( self - > if0D - > getX ( ) ) ;
2008-07-09 08:24:13 +00:00
}
2008-07-12 04:02:08 +00:00
PyObject * Interface0D_getY ( BPy_Interface0D * self ) {
return PyFloat_FromDouble ( self - > if0D - > getY ( ) ) ;
2008-07-09 08:24:13 +00:00
}
2008-07-12 04:02:08 +00:00
PyObject * Interface0D_getZ ( BPy_Interface0D * self ) {
return PyFloat_FromDouble ( self - > if0D - > getZ ( ) ) ;
2008-07-09 08:24:13 +00:00
}
2008-07-12 04:02:08 +00:00
PyObject * Interface0D_getPoint3D ( BPy_Interface0D * self ) {
2008-07-18 02:55:23 +00:00
Vec3f v ( self - > if0D - > getPoint3D ( ) ) ;
return Vector_from_Vec3f ( v ) ;
2008-07-09 08:24:13 +00:00
}
2008-07-12 04:02:08 +00:00
PyObject * Interface0D_getProjectedX ( BPy_Interface0D * self ) {
return PyFloat_FromDouble ( self - > if0D - > getProjectedX ( ) ) ;
2008-07-09 08:24:13 +00:00
}
2008-07-12 04:02:08 +00:00
PyObject * Interface0D_getProjectedY ( BPy_Interface0D * self ) {
return PyFloat_FromDouble ( self - > if0D - > getProjectedY ( ) ) ;
2008-07-09 08:24:13 +00:00
}
2008-07-12 04:02:08 +00:00
PyObject * Interface0D_getProjectedZ ( BPy_Interface0D * self ) {
return PyFloat_FromDouble ( self - > if0D - > getProjectedZ ( ) ) ;
2008-07-09 08:24:13 +00:00
}
2008-07-12 04:02:08 +00:00
PyObject * Interface0D_getPoint2D ( BPy_Interface0D * self ) {
2008-07-18 02:55:23 +00:00
Vec2f v ( self - > if0D - > getPoint2D ( ) ) ;
return Vector_from_Vec2f ( v ) ;
2008-07-09 08:24:13 +00:00
}
2008-07-18 02:55:23 +00:00
PyObject * Interface0D_getFEdge ( BPy_Interface0D * self , PyObject * args ) {
PyObject * py_if0D ;
if ( ! ( PyArg_ParseTuple ( args , " O " , & py_if0D ) & & BPy_Interface0D_Check ( py_if0D ) ) ) {
cout < < " ERROR: Interface0D_getFEdge " < < endl ;
Py_RETURN_NONE ;
}
FEdge * fe = self - > if0D - > getFEdge ( * ( ( ( BPy_Interface0D * ) py_if0D ) - > if0D ) ) ;
if ( fe )
return BPy_FEdge_from_FEdge ( * fe ) ;
Py_RETURN_NONE ;
2008-07-09 08:24:13 +00:00
}
2008-07-12 04:02:08 +00:00
PyObject * Interface0D_getId ( BPy_Interface0D * self ) {
2008-07-18 02:55:23 +00:00
Id id ( self - > if0D - > getId ( ) ) ;
return BPy_Id_from_Id ( id ) ;
2008-07-09 08:24:13 +00:00
}
2008-07-12 04:02:08 +00:00
PyObject * Interface0D_getNature ( BPy_Interface0D * self ) {
2008-07-20 05:01:29 +00:00
return BPy_Nature_from_Nature ( self - > if0D - > getNature ( ) ) ;
2008-07-09 08:24:13 +00:00
}
2008-07-12 04:02:08 +00:00
///////////////////////////////////////////////////////////////////////////////////////////
# ifdef __cplusplus
}
# endif