| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * $Id$ | 
					
						
							|  |  |  |  * ***** BEGIN GPL/BL DUAL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version. The Blender | 
					
						
							|  |  |  |  * Foundation also sells licenses for use in proprietary software under | 
					
						
							|  |  |  |  * the Blender License.  See http://www.blender.org/BL/ for information
 | 
					
						
							|  |  |  |  * about this. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							|  |  |  |  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This is a new part of Blender. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  |  * Contributor(s): Stephen Swaney | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL/BL DUAL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "Python.h"
 | 
					
						
							|  |  |  | #include "DNA_curve_types.h"
 | 
					
						
							|  |  |  | #include "BKE_curve.h"
 | 
					
						
							|  |  |  | #include "MEM_guardedalloc.h"
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | #include "gen_utils.h"
 | 
					
						
							|  |  |  | #include "CurNurb.h"
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | #include "BezTriple.h"
 | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * forward declarations go here | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-22 16:10:46 +00:00
										 |  |  | static PyObject *M_CurNurb_New( PyObject * self, PyObject * args ); | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | PyObject *CurNurb_CreatePyObject( Nurb * blen_nurb ); | 
					
						
							|  |  |  | static PyObject *CurNurb_setMatIndex( BPy_CurNurb * self, PyObject * args ); | 
					
						
							|  |  |  | static PyObject *CurNurb_getMatIndex( BPy_CurNurb * self ); | 
					
						
							| 
									
										
										
										
											2005-04-17 14:37:40 +00:00
										 |  |  | static PyObject *CurNurb_getFlagU( BPy_CurNurb * self ); | 
					
						
							|  |  |  | static PyObject *CurNurb_setFlagU( BPy_CurNurb * self, PyObject * args ); | 
					
						
							|  |  |  | static PyObject *CurNurb_getFlagV( BPy_CurNurb * self ); | 
					
						
							|  |  |  | static PyObject *CurNurb_setFlagV( BPy_CurNurb * self, PyObject * args ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | /* static PyObject* CurNurb_setXXX( BPy_CurNurb* self, PyObject* args ); */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | PyObject *CurNurb_getPoint( BPy_CurNurb * self, int index ); | 
					
						
							|  |  |  | static int CurNurb_length( PyInstanceObject * inst ); | 
					
						
							|  |  |  | static PyObject *CurNurb_getIter( BPy_CurNurb * self ); | 
					
						
							|  |  |  | static PyObject *CurNurb_iterNext( BPy_CurNurb * self ); | 
					
						
							|  |  |  | PyObject *CurNurb_append( BPy_CurNurb * self, PyObject * args ); | 
					
						
							|  |  |  | PyObject *CurNurb_pointAtIndex( Nurb * nurb, int index ); | 
					
						
							|  |  |  | static PyObject *CurNurb_isNurb( BPy_CurNurb * self ); | 
					
						
							| 
									
										
										
										
											2005-01-13 03:42:53 +00:00
										 |  |  | static PyObject *CurNurb_isCyclic( BPy_CurNurb * self ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | char M_CurNurb_doc[] = "CurNurb"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*	
 | 
					
						
							|  |  |  |   CurNurb_Type callback function prototypes:                           | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | static void CurNurb_dealloc( BPy_CurNurb * self ); | 
					
						
							|  |  |  | static int CurNurb_compare( BPy_CurNurb * a, BPy_CurNurb * b ); | 
					
						
							|  |  |  | static PyObject *CurNurb_getAttr( BPy_CurNurb * self, char *name ); | 
					
						
							|  |  |  | static int CurNurb_setAttr( BPy_CurNurb * self, char *name, PyObject * v ); | 
					
						
							|  |  |  | static PyObject *CurNurb_repr( BPy_CurNurb * self ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-22 16:10:46 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |    table of module methods | 
					
						
							|  |  |  |    these are the equivalent of class or static methods. | 
					
						
							|  |  |  |    you do not need an object instance to call one. | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyMethodDef M_CurNurb_methods[] = { | 
					
						
							|  |  |  | /*   name, method, flags, doc_string                */ | 
					
						
							|  |  |  | 	{"New", ( PyCFunction ) M_CurNurb_New, METH_VARARGS | METH_KEYWORDS, | 
					
						
							|  |  |  | 	 " () - doc string"}, | 
					
						
							|  |  |  | /*  {"Get", (PyCFunction) M_CurNurb_method, METH_NOARGS, " () - doc string"}, */ | 
					
						
							|  |  |  | /*   {"method", (PyCFunction) M_CurNurb_method, METH_NOARGS, " () - doc string"}, */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	{NULL, NULL, 0, NULL} | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * method table | 
					
						
							|  |  |  |  * table of instance methods | 
					
						
							|  |  |  |  * these methods are invoked on an instance of the type. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyMethodDef BPy_CurNurb_methods[] = { | 
					
						
							|  |  |  | /*   name,     method,                    flags,         doc               */ | 
					
						
							|  |  |  | /*  {"method", (PyCFunction) CurNurb_method, METH_NOARGS, " () - doc string"} */ | 
					
						
							|  |  |  | 	{"setMatIndex", ( PyCFunction ) CurNurb_setMatIndex, METH_VARARGS, | 
					
						
							|  |  |  | 	 "( index ) - set index into materials list"}, | 
					
						
							|  |  |  | 	{"getMatIndex", ( PyCFunction ) CurNurb_getMatIndex, METH_NOARGS, | 
					
						
							|  |  |  | 	 "( ) - get current material index"}, | 
					
						
							|  |  |  | 	{"setFlagU", ( PyCFunction ) CurNurb_setFlagU, METH_VARARGS, | 
					
						
							|  |  |  | 	 "( index ) - set flagU and recalculate the knots (0: uniform, 1: endpoints, 2: bezier)"}, | 
					
						
							|  |  |  | 	{"getFlagU", ( PyCFunction ) CurNurb_getFlagU, METH_NOARGS, | 
					
						
							|  |  |  | 	 "( ) - get flagU of the knots"}, | 
					
						
							|  |  |  | 	{"setFlagV", ( PyCFunction ) CurNurb_setFlagV, METH_VARARGS, | 
					
						
							|  |  |  | 	 "( index ) - set flagV and recalculate the knots (0: uniform, 1: endpoints, 2: bezier)"}, | 
					
						
							|  |  |  | 	{"getFlagV", ( PyCFunction ) CurNurb_getFlagV, METH_NOARGS, | 
					
						
							|  |  |  | 	 "( ) - get flagV of the knots"}, | 
					
						
							|  |  |  | 	{"append", ( PyCFunction ) CurNurb_append, METH_VARARGS, | 
					
						
							|  |  |  | 	 "( point ) - add a new point.  arg is BezTriple or list of x,y,z,w floats"}, | 
					
						
							|  |  |  | 	{"isNurb", ( PyCFunction ) CurNurb_isNurb, METH_NOARGS, | 
					
						
							|  |  |  | 	 "( ) - boolean function tests if this spline is type nurb or bezier"}, | 
					
						
							|  |  |  | 	{"isCyclic", ( PyCFunction ) CurNurb_isCyclic, METH_NOARGS, | 
					
						
							|  |  |  | 	 "( ) - boolean function tests if this spline is cyclic (closed) or not (open)"}, | 
					
						
							|  |  |  | 	{NULL, NULL, 0, NULL} | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* 
 | 
					
						
							|  |  |  |  *   methods for CurNurb as sequece | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PySequenceMethods CurNurb_as_sequence = { | 
					
						
							|  |  |  | 	( inquiry ) CurNurb_length,	/* sq_length   */ | 
					
						
							|  |  |  | 	( binaryfunc ) 0,	/* sq_concat */ | 
					
						
							|  |  |  | 	( intargfunc ) 0,	/* sq_repeat */ | 
					
						
							|  |  |  | 	( intargfunc ) CurNurb_getPoint,	/* sq_item */ | 
					
						
							|  |  |  | 	( intintargfunc ) 0,	/* sq_slice */ | 
					
						
							|  |  |  | 	0,			/* sq_ass_item */ | 
					
						
							|  |  |  | 	0,			/* sq_ass_slice */ | 
					
						
							|  |  |  | 	( objobjproc ) 0,	/* sq_contains */ | 
					
						
							|  |  |  | 	0, | 
					
						
							|  |  |  | 	0 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   Object Type definition | 
					
						
							|  |  |  |   full blown 2.3 struct | 
					
						
							|  |  |  |   if you are having trouble building with an earlier version of python, | 
					
						
							|  |  |  |    this is why. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyTypeObject CurNurb_Type = { | 
					
						
							|  |  |  | 	PyObject_HEAD_INIT( NULL ) /* required py macro */ | 
					
						
							|  |  |  | 	0,	/* ob_size */ | 
					
						
							|  |  |  | 	/*  For printing, in format "<module>.<name>" */ | 
					
						
							|  |  |  | 	"CurNurb",		/* char *tp_name; */ | 
					
						
							|  |  |  | 	sizeof( CurNurb_Type ),	/* int tp_basicsize, */ | 
					
						
							|  |  |  | 	0,			/* tp_itemsize;  For allocation */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Methods to implement standard operations */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	( destructor ) CurNurb_dealloc,	/*    destructor tp_dealloc; */ | 
					
						
							|  |  |  | 	0,			/*    printfunc tp_print; */ | 
					
						
							|  |  |  | 	( getattrfunc ) CurNurb_getAttr,	/*    getattrfunc tp_getattr; */ | 
					
						
							|  |  |  | 	( setattrfunc ) CurNurb_setAttr,	/*    setattrfunc tp_setattr; */ | 
					
						
							|  |  |  | 	( cmpfunc ) CurNurb_compare,	/*    cmpfunc tp_compare; */ | 
					
						
							|  |  |  | 	( reprfunc ) CurNurb_repr,	/*    reprfunc tp_repr; */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Method suites for standard classes */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	0,			/*    PyNumberMethods *tp_as_number; */ | 
					
						
							|  |  |  | 	&CurNurb_as_sequence,	/*    PySequenceMethods *tp_as_sequence; */ | 
					
						
							|  |  |  | 	0,			/*    PyMappingMethods *tp_as_mapping; */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* More standard operations (here for binary compatibility) */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	0,			/*    hashfunc tp_hash; */ | 
					
						
							|  |  |  | 	0,			/*    ternaryfunc tp_call; */ | 
					
						
							|  |  |  | 	0,			/*    reprfunc tp_str; */ | 
					
						
							|  |  |  | 	0,			/*    getattrofunc tp_getattro; */ | 
					
						
							|  |  |  | 	0,			/*    setattrofunc tp_setattro; */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Functions to access object as input/output buffer */ | 
					
						
							|  |  |  | 	0,			/*    PyBufferProcs *tp_as_buffer; */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /*** Flags to define presence of optional/expanded features ***/ | 
					
						
							|  |  |  | 	Py_TPFLAGS_DEFAULT,	/*    long tp_flags; */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	0,			/*  char *tp_doc;  Documentation string */ | 
					
						
							|  |  |  |   /*** Assigned meaning in release 2.0 ***/ | 
					
						
							|  |  |  | 	/* call function for all accessible objects */ | 
					
						
							|  |  |  | 	0,			/*    traverseproc tp_traverse; */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* delete references to contained objects */ | 
					
						
							|  |  |  | 	0,			/*    inquiry tp_clear; */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /***  Assigned meaning in release 2.1 ***/ | 
					
						
							|  |  |  |   /*** rich comparisons ***/ | 
					
						
							|  |  |  | 	0,			/*  richcmpfunc tp_richcompare; */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /***  weak reference enabler ***/ | 
					
						
							|  |  |  | 	0,			/* long tp_weaklistoffset; */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /*** Added in release 2.2 ***/ | 
					
						
							|  |  |  | 	/*   Iterators */ | 
					
						
							|  |  |  | 	( getiterfunc ) CurNurb_getIter,	/*    getiterfunc tp_iter; */ | 
					
						
							|  |  |  | 	( iternextfunc ) CurNurb_iterNext,	/*    iternextfunc tp_iternext; */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /*** Attribute descriptor and subclassing stuff ***/ | 
					
						
							|  |  |  | 	BPy_CurNurb_methods,	/*    struct PyMethodDef *tp_methods; */ | 
					
						
							|  |  |  | 	0,			/*    struct PyMemberDef *tp_members; */ | 
					
						
							|  |  |  | 	0,			/*    struct PyGetSetDef *tp_getset; */ | 
					
						
							|  |  |  | 	0,			/*    struct _typeobject *tp_base; */ | 
					
						
							|  |  |  | 	0,			/*    PyObject *tp_dict; */ | 
					
						
							|  |  |  | 	0,			/*    descrgetfunc tp_descr_get; */ | 
					
						
							|  |  |  | 	0,			/*    descrsetfunc tp_descr_set; */ | 
					
						
							|  |  |  | 	0,			/*    long tp_dictoffset; */ | 
					
						
							|  |  |  | 	0,			/*    initproc tp_init; */ | 
					
						
							|  |  |  | 	0,			/*    allocfunc tp_alloc; */ | 
					
						
							|  |  |  | 	0,			/*    newfunc tp_new; */ | 
					
						
							|  |  |  | 	/*  Low-level free-memory routine */ | 
					
						
							|  |  |  | 	0,			/*    freefunc tp_free;  */ | 
					
						
							|  |  |  | 	/* For PyObject_IS_GC */ | 
					
						
							|  |  |  | 	0,			/*    inquiry tp_is_gc;  */ | 
					
						
							|  |  |  | 	0,			/*    PyObject *tp_bases; */ | 
					
						
							|  |  |  | 	/* method resolution order */ | 
					
						
							|  |  |  | 	0,			/*    PyObject *tp_mro;  */ | 
					
						
							|  |  |  | 	0,			/*    PyObject *tp_cache; */ | 
					
						
							|  |  |  | 	0,			/*    PyObject *tp_subclasses; */ | 
					
						
							|  |  |  | 	0,			/*    PyObject *tp_weaklist; */ | 
					
						
							|  |  |  | 	0 | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | void CurNurb_dealloc( BPy_CurNurb * self ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	PyObject_DEL( self ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | static PyObject *CurNurb_getAttr( BPy_CurNurb * self, char *name ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	PyObject *attr = Py_None; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( strcmp( name, "mat_index" ) == 0 ) | 
					
						
							|  |  |  | 		attr = PyInt_FromLong( self->nurb->mat_nr ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	else if( strcmp( name, "points" ) == 0 ) | 
					
						
							|  |  |  | 		attr = PyInt_FromLong( self->nurb->pntsu ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-17 14:37:40 +00:00
										 |  |  | 	else if( strcmp( name, "flagU" ) == 0 ) | 
					
						
							|  |  |  | 		attr = CurNurb_getFlagU( self ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	else if( strcmp( name, "flagV" ) == 0 ) | 
					
						
							|  |  |  | 		attr = CurNurb_getFlagV( self ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( !attr ) | 
					
						
							|  |  |  | 		return EXPP_ReturnPyObjError( PyExc_MemoryError, | 
					
						
							|  |  |  | 					      "couldn't create PyObject" ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* member attribute found, return it */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( attr != Py_None ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 		return attr; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* not an attribute, search the methods table */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	return Py_FindMethod( BPy_CurNurb_methods, ( PyObject * ) self, name ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   setattr | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | static int CurNurb_setAttr( BPy_CurNurb * self, char *name, PyObject * value ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	PyObject *valtuple; | 
					
						
							|  |  |  | 	PyObject *error = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* make a tuple to pass to our type methods */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	valtuple = Py_BuildValue( "(O)", value ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( !valtuple ) | 
					
						
							|  |  |  | 		return EXPP_ReturnIntError( PyExc_MemoryError, | 
					
						
							|  |  |  | 					    "CurNurb.setAttr: cannot create pytuple" ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( strcmp( name, "mat_index" ) == 0 ) | 
					
						
							|  |  |  | 		error = CurNurb_setMatIndex( self, valtuple ); | 
					
						
							| 
									
										
										
										
											2005-04-17 14:37:40 +00:00
										 |  |  | 	else if( strcmp( name, "flagU" ) == 0 ) | 
					
						
							|  |  |  | 		error = CurNurb_setFlagU( self, valtuple ); | 
					
						
							|  |  |  | 	else if( strcmp( name, "flagV" ) == 0 ) | 
					
						
							|  |  |  | 		error = CurNurb_setFlagV( self, valtuple ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	else {			/* error - no match for name */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 		Py_DECREF( valtuple ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 		if( ( strcmp( name, "ZZZZ" ) == 0 ) ||	/* user tried to change a */ | 
					
						
							|  |  |  | 		    ( strcmp( name, "ZZZZ" ) == 0 ) )	/* constant dict type ... */ | 
					
						
							|  |  |  | 			return EXPP_ReturnIntError( PyExc_AttributeError, | 
					
						
							|  |  |  | 						    "constant dictionary -- cannot be changed" ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 		else | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 			return EXPP_ReturnIntError( PyExc_KeyError, | 
					
						
							|  |  |  | 						    "attribute not found" ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	Py_DECREF( valtuple );	/* since it is not being returned */ | 
					
						
							|  |  |  | 	if( error != Py_None ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 		return -1; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	Py_DECREF( Py_None ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 	return 0;		/* normal exit */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   compare | 
					
						
							|  |  |  |   in this case, we consider two CurNurbs equal, if they point to the same | 
					
						
							|  |  |  |   blender data. | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | static int CurNurb_compare( BPy_CurNurb * a, BPy_CurNurb * b ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	Nurb *pa = a->nurb; | 
					
						
							|  |  |  | 	Nurb *pb = b->nurb; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	return ( pa == pb ) ? 0 : -1; | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |   factory method to create a BPy_CurNurb from a Blender Nurb | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | PyObject *CurNurb_CreatePyObject( Nurb * blen_nurb ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	BPy_CurNurb *pyNurb; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	pyNurb = ( BPy_CurNurb * ) PyObject_NEW( BPy_CurNurb, &CurNurb_Type ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( !pyNurb ) | 
					
						
							|  |  |  | 		return EXPP_ReturnPyObjError( PyExc_MemoryError, | 
					
						
							|  |  |  | 					      "could not create BPy_CurNurb PyObject" ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	pyNurb->nurb = blen_nurb; | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	return ( PyObject * ) pyNurb; | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  *  CurNurb_repr | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | static PyObject *CurNurb_repr( BPy_CurNurb * self ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | {				/* used by 'repr' */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	return PyString_FromFormat( "[CurNurb \"%d\"]", self->nurb->type ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-02-09 15:53:35 +00:00
										 |  |  | /* XXX Can't this be simply removed? */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | static PyObject *M_CurNurb_New( PyObject * self, PyObject * args ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	return ( PyObject * ) 0; | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * CurNurb_append( point ) | 
					
						
							|  |  |  |  * append a new point to a nurb curve. | 
					
						
							|  |  |  |  * arg is BezTriple or list of xyzw floats  | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | PyObject *CurNurb_append( BPy_CurNurb * self, PyObject * args ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 	Nurb *nurb = self->nurb; | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	return CurNurb_appendPointToNurb( nurb, args ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * CurNurb_appendPointToNurb | 
					
						
							|  |  |  |  * this is a non-bpy utility func to add a point to a given nurb | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | PyObject *CurNurb_appendPointToNurb( Nurb * nurb, PyObject * args ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	int i; | 
					
						
							|  |  |  | 	int size; | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 	PyObject *pyOb; | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 	int npoints; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/*
 | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 	   do we have a list of four floats or a BezTriple? | 
					
						
							| 
									
										
										
										
											2005-05-12 05:45:13 +00:00
										 |  |  | 	*/ | 
					
						
							|  |  |  | 	if( !PyArg_ParseTuple( args, "O", &pyOb )) | 
					
						
							|  |  |  | 		return( EXPP_ReturnPyObjError | 
					
						
							|  |  |  | 				( PyExc_RuntimeError, | 
					
						
							|  |  |  | 				  "Internal error parsing arguments" ) ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( BezTriple_CheckPyObject( pyOb ) ) { | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 		BezTriple *tmp; | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 		npoints = nurb->pntsu; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*		printf("\ndbg: got a BezTriple\n"); */ | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 		tmp = nurb->bezt;	/* save old points */ | 
					
						
							|  |  |  | 		nurb->bezt = | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 			( BezTriple * ) MEM_mallocN( sizeof( BezTriple ) * | 
					
						
							|  |  |  | 						     ( npoints + 1 ), | 
					
						
							|  |  |  | 						     "CurNurb_append2" ); | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 		if( !nurb->bezt ) | 
					
						
							|  |  |  | 			return ( EXPP_ReturnPyObjError | 
					
						
							|  |  |  | 				 ( PyExc_MemoryError, "allocation failed" ) ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* copy old points to new */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 		memmove( nurb->bezt, tmp, sizeof( BezTriple ) * npoints ); | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 		if( tmp ) | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 			MEM_freeN( tmp ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 		nurb->pntsu++; | 
					
						
							|  |  |  | 		/* add new point to end of list */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 		memcpy( nurb->bezt + npoints, | 
					
						
							|  |  |  | 			BezTriple_FromPyObject( pyOb ), sizeof( BezTriple ) ); | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	} else if( PySequence_Check( pyOb ) ) { | 
					
						
							|  |  |  | 		size = PySequence_Size( pyOb ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | /*		printf("\ndbg: got a sequence of size %d\n", size );  */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 		if( size == 4 ) { | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 			BPoint *tmp; | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 			npoints = nurb->pntsu; | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			tmp = nurb->bp;	/* save old pts */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			nurb->bp = | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 				( BPoint * ) MEM_mallocN( sizeof( BPoint ) * | 
					
						
							|  |  |  | 							  ( npoints + 1 ), | 
					
						
							|  |  |  | 							  "CurNurb_append1" ); | 
					
						
							|  |  |  | 			if( !nurb->bp ) | 
					
						
							|  |  |  | 				return ( EXPP_ReturnPyObjError | 
					
						
							|  |  |  | 					 ( PyExc_MemoryError, | 
					
						
							|  |  |  | 					   "allocation failed" ) ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			memmove( nurb->bp, tmp, sizeof( BPoint ) * npoints ); | 
					
						
							|  |  |  | 			if( tmp ) | 
					
						
							|  |  |  | 				MEM_freeN( tmp ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			++nurb->pntsu; | 
					
						
							|  |  |  | 			/* initialize new BPoint from old */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 			memcpy( nurb->bp + npoints, nurb->bp, | 
					
						
							|  |  |  | 				sizeof( BPoint ) ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 			for( i = 0; i < 4; ++i ) { | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 				float tmpx = | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 					( float ) PyFloat_AsDouble | 
					
						
							|  |  |  | 					( PySequence_GetItem( pyOb, i ) ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 				nurb->bp[npoints].vec[i] = tmpx; | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 			makeknots( nurb, 1, nurb->flagu >> 1 ); | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 		} else if( size == 3 ) {	/* 3 xyz coords */ | 
					
						
							|  |  |  | 			printf( "\nNot Yet Implemented!\n" ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 	} else { | 
					
						
							|  |  |  | 		/* bail with error */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 		return ( EXPP_ReturnPyObjError | 
					
						
							|  |  |  | 			 ( PyExc_AttributeError, "expected better stuff" ) ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	return ( EXPP_incr_ret( Py_None ) ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  *  CurNurb_setMatIndex | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  set index into material list | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | static PyObject *CurNurb_setMatIndex( BPy_CurNurb * self, PyObject * args ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	int index; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( !PyArg_ParseTuple( args, "i", &( index ) ) ) | 
					
						
							|  |  |  | 		return ( EXPP_ReturnPyObjError | 
					
						
							|  |  |  | 			 ( PyExc_AttributeError, | 
					
						
							|  |  |  | 			   "expected integer argument" ) ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* fixme:  some range checking would be nice! */ | 
					
						
							|  |  |  | 	self->nurb->mat_nr = index; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	Py_INCREF( Py_None ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 	return Py_None; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * CurNurb_getMatIndex | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * returns index into material list | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | static PyObject *CurNurb_getMatIndex( BPy_CurNurb * self ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	PyObject *index = PyInt_FromLong( ( long ) self->nurb->mat_nr ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( index ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 		return index; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	return ( EXPP_ReturnPyObjError( PyExc_RuntimeError, | 
					
						
							|  |  |  | 					"could not get material index" ) ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-17 14:37:40 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * CurNurb_getFlagU | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * returns curve's flagu | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject *CurNurb_getFlagU( BPy_CurNurb * self ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	PyObject *flagu = PyInt_FromLong( ( long ) self->nurb->flagu ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if( flagu ) | 
					
						
							|  |  |  | 		return flagu; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return ( EXPP_ReturnPyObjError( PyExc_RuntimeError, | 
					
						
							|  |  |  | 					"could not get CurNurb.flagu index" ) ); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  *  CurNurb_setFlagU | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  set curve's flagu and recalculate the knots | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  Possible values: 0 - uniform, 1 - endpoints, 2 - bezier | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject *CurNurb_setFlagU( BPy_CurNurb * self, PyObject * args ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int flagu; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if( !PyArg_ParseTuple( args, "i", &( flagu ) ) ) | 
					
						
							|  |  |  | 		return ( EXPP_ReturnPyObjError | 
					
						
							|  |  |  | 			 ( PyExc_AttributeError, | 
					
						
							|  |  |  | 			   "expected integer argument" ) ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if( self->nurb->flagu != flagu ) { | 
					
						
							|  |  |  | 		self->nurb->flagu = flagu; | 
					
						
							|  |  |  | 		makeknots( self->nurb, 1, self->nurb->flagu >> 1 ); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Py_INCREF( Py_None ); | 
					
						
							|  |  |  | 	return Py_None; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * CurNurb_getFlagV | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * returns curve's flagu | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject *CurNurb_getFlagV( BPy_CurNurb * self ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	PyObject *flagv = PyInt_FromLong( ( long ) self->nurb->flagv ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if( flagv ) | 
					
						
							|  |  |  | 		return flagv; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return ( EXPP_ReturnPyObjError( PyExc_RuntimeError, | 
					
						
							|  |  |  | 					"could not get CurNurb.flagv" ) ); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  *  CurNurb_setFlagV | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  set curve's flagu and recalculate the knots | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  Possible values: 0 - uniform, 1 - endpoints, 2 - bezier | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject *CurNurb_setFlagV( BPy_CurNurb * self, PyObject * args ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int flagv; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if( !PyArg_ParseTuple( args, "i", &( flagv ) ) ) | 
					
						
							|  |  |  | 		return ( EXPP_ReturnPyObjError | 
					
						
							|  |  |  | 			 ( PyExc_AttributeError, | 
					
						
							|  |  |  | 			   "expected integer argument" ) ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if( self->nurb->flagv != flagv ) { | 
					
						
							|  |  |  | 		self->nurb->flagv = flagv; | 
					
						
							|  |  |  | 		makeknots( self->nurb, 2, self->nurb->flagv >> 1 ); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Py_INCREF( Py_None ); | 
					
						
							|  |  |  | 	return Py_None; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * CurNurb_getIter | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * create an iterator for our CurNurb. | 
					
						
							|  |  |  |  * this iterator returns the points for this CurNurb. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | static PyObject *CurNurb_getIter( BPy_CurNurb * self ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	self->bp = self->nurb->bp; | 
					
						
							|  |  |  | 	self->bezt = self->nurb->bezt; | 
					
						
							|  |  |  | 	self->atEnd = 0; | 
					
						
							|  |  |  | 	self->nextPoint = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* set exhausted flag if both bp and bezt are zero */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( ( !self->bp ) && ( !self->bezt ) ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 		self->atEnd = 1; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	Py_INCREF( self ); | 
					
						
							|  |  |  | 	return ( PyObject * ) self; | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | static PyObject *CurNurb_iterNext( BPy_CurNurb * self ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	PyObject *po;		/* return value */ | 
					
						
							|  |  |  | 	Nurb *pnurb = self->nurb; | 
					
						
							|  |  |  | 	int npoints = pnurb->pntsu; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* are we at end already? */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( self->atEnd ) | 
					
						
							|  |  |  | 		return ( EXPP_ReturnPyObjError( PyExc_StopIteration, | 
					
						
							|  |  |  | 						"iterator at end" ) ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( self->nextPoint < npoints ) { | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 		po = CurNurb_pointAtIndex( self->nurb, self->nextPoint ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 		self->nextPoint++; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		return po; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 	} else { | 
					
						
							|  |  |  | 		self->atEnd = 1;	/* set flag true */ | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	return ( EXPP_ReturnPyObjError( PyExc_StopIteration, | 
					
						
							|  |  |  | 					"iterator at end" ) ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * CurNurb_isNurb() | 
					
						
							|  |  |  |  * test whether spline nurb or bezier | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | static PyObject *CurNurb_isNurb( BPy_CurNurb * self ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* NOTE: a Nurb has bp and bezt pointers
 | 
					
						
							|  |  |  | 	 * depending on type. | 
					
						
							|  |  |  | 	 * It is possible both are NULL if no points exist. | 
					
						
							|  |  |  | 	 * in that case, we return False | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( self->nurb->bp ) { | 
					
						
							| 
									
										
										
										
											2005-02-09 15:53:35 +00:00
										 |  |  | 		return EXPP_incr_ret_True(); | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2005-02-09 15:53:35 +00:00
										 |  |  | 		return EXPP_incr_ret_False(); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-01-13 03:42:53 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * CurNurb_isCyclic() | 
					
						
							|  |  |  |  * test whether spline cyclic (closed) or not (open) | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject *CurNurb_isCyclic( BPy_CurNurb * self ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |         /* supposing that the flagu is always set */  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if( self->nurb->flagu & CU_CYCLIC ) { | 
					
						
							| 
									
										
										
										
											2005-02-09 15:53:35 +00:00
										 |  |  | 		return EXPP_incr_ret_True(); | 
					
						
							| 
									
										
										
										
											2005-01-13 03:42:53 +00:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2005-02-09 15:53:35 +00:00
										 |  |  | 		return EXPP_incr_ret_False(); | 
					
						
							| 
									
										
										
										
											2005-01-13 03:42:53 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * CurNurb_length | 
					
						
							|  |  |  |  * returns the number of points in a Nurb | 
					
						
							|  |  |  |  * this is a tp_as_sequence method, not a regular instance method. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | static int CurNurb_length( PyInstanceObject * inst ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 	Nurb *nurb; | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 	int len; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( CurNurb_CheckPyObject( ( PyObject * ) inst ) ) { | 
					
						
							|  |  |  | 		nurb = ( ( BPy_CurNurb * ) inst )->nurb; | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 		len = nurb->pntsu; | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 		return len; | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	return EXPP_ReturnIntError( PyExc_RuntimeError, | 
					
						
							|  |  |  | 				    "arg is not a BPy_CurNurb" ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * CurNurb_getPoint | 
					
						
							|  |  |  |  * returns the Nth point in a Nurb | 
					
						
							|  |  |  |  * this is one of the tp_as_sequence methods, hence the int N argument. | 
					
						
							|  |  |  |  * it is called via the [] operator, not as a usual instance method. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | PyObject *CurNurb_getPoint( BPy_CurNurb * self, int index ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	PyObject *pyo; | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 	Nurb *myNurb; | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	int npoints; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* for convenince */ | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 	myNurb = self->nurb; | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 	npoints = myNurb->pntsu; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* DELETED: bail if index < 0 */ | 
					
						
							|  |  |  | 	/* actually, this check is not needed since python treats */ | 
					
						
							|  |  |  | 	/* negative indices as starting from the right end of a sequence */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* bail if no Nurbs in Curve */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( npoints == 0 ) | 
					
						
							|  |  |  | 		return ( EXPP_ReturnPyObjError( PyExc_IndexError, | 
					
						
							|  |  |  | 						"no points in this CurNurb" ) ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( index >= npoints )	/* out of range!  */ | 
					
						
							|  |  |  | 		return ( EXPP_ReturnPyObjError( PyExc_IndexError, | 
					
						
							|  |  |  | 						"index out of range" ) ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	pyo = CurNurb_pointAtIndex( myNurb, index ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	return ( PyObject * ) pyo; | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* 
 | 
					
						
							|  |  |  |  * this is an internal routine.  not callable directly from python | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | PyObject *CurNurb_pointAtIndex( Nurb * nurb, int index ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 	PyObject *pyo; | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	if( nurb->bp ) {	/* we have a nurb curve */ | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 		int i; | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 		pyo = PyList_New( 4 ); | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 		for( i = 0; i < 4; i++ ) { | 
					
						
							|  |  |  | 			PyList_SetItem( pyo, i, | 
					
						
							|  |  |  | 					PyFloat_FromDouble( nurb->bp[index]. | 
					
						
							|  |  |  | 							    vec[i] ) ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	} else if( nurb->bezt ) {	/* we have a bezier */ | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 		/* if an error occurs, we just pass it on */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 		pyo = BezTriple_CreatePyObject( &( nurb->bezt[index] ) ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-07-29 12:00:34 +00:00
										 |  |  | 	} else			/* something is horribly wrong */ | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 		/* neither bp or bezt is set && pntsu != 0 */ | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 		return ( EXPP_ReturnPyObjError( PyExc_SystemError, | 
					
						
							|  |  |  | 						"inconsistant structure found" ) ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	return ( pyo ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | int CurNurb_CheckPyObject( PyObject * py_obj ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 	return ( py_obj->ob_type == &CurNurb_Type ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | PyObject *CurNurb_Init( void ) | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	PyObject *submodule; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	CurNurb_Type.ob_type = &PyType_Type; | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	submodule = | 
					
						
							| 
									
										
										
										
											2004-09-25 20:30:40 +00:00
										 |  |  | 		Py_InitModule3( "Blender.CurNurb", M_CurNurb_methods, | 
					
						
							|  |  |  | 				M_CurNurb_doc ); | 
					
						
							|  |  |  | 	return ( submodule ); | 
					
						
							| 
									
										
										
										
											2004-07-21 21:01:15 +00:00
										 |  |  | } |