Constraint.InsertKey was inserting keyframes for the wrong action-channel. It was doing so for the active bone, not the owner of the constraint.
		
			
				
	
	
		
			2693 lines
		
	
	
		
			87 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			2693 lines
		
	
	
		
			87 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * $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.
 | |
|  *
 | |
|  * Contributor(s): Joseph Gilbert, Ken Hughes, Joshua Leung
 | |
|  *
 | |
|  * ***** END GPL/BL DUAL LICENSE BLOCK *****
 | |
|  */
 | |
| 
 | |
| #include "Constraint.h" /*This must come first*/
 | |
| 
 | |
| #include "DNA_object_types.h"
 | |
| #include "DNA_effect_types.h"
 | |
| #include "DNA_vec_types.h"
 | |
| #include "DNA_curve_types.h"
 | |
| #include "DNA_text_types.h"
 | |
| 
 | |
| #include "BKE_main.h"
 | |
| #include "BKE_global.h"
 | |
| #include "BKE_library.h"
 | |
| #include "BKE_action.h"
 | |
| #include "BKE_armature.h"
 | |
| #include "BKE_constraint.h"
 | |
| #include "BLI_blenlib.h"
 | |
| #include "BIF_editconstraint.h"
 | |
| #include "BSE_editipo.h"
 | |
| #include "MEM_guardedalloc.h"
 | |
| #include "butspace.h"
 | |
| #include "blendef.h"
 | |
| #include "mydevice.h"
 | |
| 
 | |
| #include "IDProp.h"
 | |
| #include "Object.h"
 | |
| #include "NLA.h"
 | |
| #include "Text.h"
 | |
| #include "gen_utils.h"
 | |
| 
 | |
| enum constraint_constants {
 | |
| 	EXPP_CONSTR_XROT = 0,
 | |
| 	EXPP_CONSTR_YROT = 1,
 | |
| 	EXPP_CONSTR_ZROT = 2,
 | |
| 	EXPP_CONSTR_XSIZE = 10,
 | |
| 	EXPP_CONSTR_YSIZE = 11,
 | |
| 	EXPP_CONSTR_ZSIZE = 12,
 | |
| 	EXPP_CONSTR_XLOC = 20,
 | |
| 	EXPP_CONSTR_YLOC = 21,
 | |
| 	EXPP_CONSTR_ZLOC = 22,
 | |
| 
 | |
| 	EXPP_CONSTR_MAXX = TRACK_X,
 | |
| 	EXPP_CONSTR_MAXY = TRACK_Y,
 | |
| 	EXPP_CONSTR_MAXZ = TRACK_Z,
 | |
| 	EXPP_CONSTR_MINX = TRACK_nX,
 | |
| 	EXPP_CONSTR_MINY = TRACK_nY,
 | |
| 	EXPP_CONSTR_MINZ = TRACK_nZ,
 | |
| 
 | |
| 	EXPP_CONSTR_TARGET = 100,
 | |
| 	EXPP_CONSTR_STRETCH,
 | |
| 	EXPP_CONSTR_ITERATIONS,
 | |
| 	EXPP_CONSTR_BONE,
 | |
| 	EXPP_CONSTR_CHAINLEN,
 | |
| 	EXPP_CONSTR_POSWEIGHT,
 | |
| 	EXPP_CONSTR_ROTWEIGHT,
 | |
| 	EXPP_CONSTR_ROTATE,
 | |
| 	EXPP_CONSTR_USETIP,
 | |
| 
 | |
| 	EXPP_CONSTR_ACTION,
 | |
| 	EXPP_CONSTR_START,
 | |
| 	EXPP_CONSTR_END,
 | |
| 	EXPP_CONSTR_MIN,
 | |
| 	EXPP_CONSTR_MAX,
 | |
| 	EXPP_CONSTR_KEYON,
 | |
| 
 | |
| 	EXPP_CONSTR_TRACK,
 | |
| 	EXPP_CONSTR_UP,
 | |
| 
 | |
| 	EXPP_CONSTR_RESTLENGTH,
 | |
| 	EXPP_CONSTR_VOLVARIATION,
 | |
| 	EXPP_CONSTR_VOLUMEMODE,
 | |
| 	EXPP_CONSTR_PLANE,
 | |
| 
 | |
| 	EXPP_CONSTR_FOLLOW,
 | |
| 	EXPP_CONSTR_OFFSET,
 | |
| 	EXPP_CONSTR_FORWARD,
 | |
| 
 | |
| 	EXPP_CONSTR_LOCK,
 | |
| 
 | |
| 	EXPP_CONSTR_MINMAX,
 | |
| 	EXPP_CONSTR_STICKY,
 | |
| 
 | |
| 	EXPP_CONSTR_COPY,
 | |
| 	EXPP_CONSTR_LIMIT,
 | |
| 	EXPP_CONSTR_CLAMP,
 | |
| 	
 | |
| 	EXPP_CONSTR_LIMXMIN = LIMIT_XMIN,
 | |
| 	EXPP_CONSTR_LIMXMAX = LIMIT_XMAX,
 | |
| 	EXPP_CONSTR_LIMYMIN = LIMIT_YMIN,
 | |
| 	EXPP_CONSTR_LIMYMAX = LIMIT_YMAX,
 | |
| 	EXPP_CONSTR_LIMZMIN = LIMIT_ZMIN,
 | |
| 	EXPP_CONSTR_LIMZMAX = LIMIT_ZMAX,
 | |
| 	
 | |
| 	EXPP_CONSTR_LIMXROT = LIMIT_XROT,
 | |
| 	EXPP_CONSTR_LIMYROT = LIMIT_YROT,
 | |
| 	EXPP_CONSTR_LIMZROT = LIMIT_ZROT,
 | |
| 	
 | |
| 	EXPP_CONSTR_CLAMPCYCLIC,
 | |
| 	
 | |
| 	EXPP_CONSTR_XMIN,
 | |
| 	EXPP_CONSTR_XMAX,
 | |
| 	EXPP_CONSTR_YMIN,
 | |
| 	EXPP_CONSTR_YMAX,
 | |
| 	EXPP_CONSTR_ZMIN,
 | |
| 	EXPP_CONSTR_ZMAX,
 | |
| 	
 | |
| 	EXPP_CONSTR_SCRIPT,
 | |
| 	EXPP_CONSTR_PROPS,
 | |
| 	
 | |
| 	EXPP_CONSTR_FROM,
 | |
| 	EXPP_CONSTR_TO,
 | |
| 	EXPP_CONSTR_EXPO,
 | |
| 	EXPP_CONSTR_FROMMINX,
 | |
| 	EXPP_CONSTR_FROMMAXX,
 | |
| 	EXPP_CONSTR_FROMMINY,
 | |
| 	EXPP_CONSTR_FROMMAXY,
 | |
| 	EXPP_CONSTR_FROMMINZ,
 | |
| 	EXPP_CONSTR_FROMMAXZ,
 | |
| 	EXPP_CONSTR_TOMINX,
 | |
| 	EXPP_CONSTR_TOMAXX,
 | |
| 	EXPP_CONSTR_TOMINY,
 | |
| 	EXPP_CONSTR_TOMAXY,
 | |
| 	EXPP_CONSTR_TOMINZ,
 | |
| 	EXPP_CONSTR_TOMAXZ,
 | |
| 	EXPP_CONSTR_MAPX,
 | |
| 	EXPP_CONSTR_MAPY,
 | |
| 	EXPP_CONSTR_MAPZ,
 | |
| 	
 | |
| 	EXPP_CONSTR_OWNSPACE,
 | |
| 	EXPP_CONSTR_TARSPACE,
 | |
| 		
 | |
| 	EXPP_CONSTR_RB_TYPE,
 | |
| 	EXPP_CONSTR_RB_BALL,
 | |
| 	EXPP_CONSTR_RB_HINGE,
 | |
| 	EXPP_CONSTR_RB_GENERIC6DOF,
 | |
| 	EXPP_CONSTR_RB_VEHICLE,
 | |
| 	EXPP_CONSTR_RB_PIVX,
 | |
| 	EXPP_CONSTR_RB_PIVY,
 | |
| 	EXPP_CONSTR_RB_PIVZ,
 | |
| 	EXPP_CONSTR_RB_AXX,
 | |
| 	EXPP_CONSTR_RB_AXY,
 | |
| 	EXPP_CONSTR_RB_AXZ,
 | |
| 	EXPP_CONSTR_RB_MINLIMIT0,
 | |
| 	EXPP_CONSTR_RB_MINLIMIT1,
 | |
| 	EXPP_CONSTR_RB_MINLIMIT2,
 | |
| 	EXPP_CONSTR_RB_MINLIMIT3,
 | |
| 	EXPP_CONSTR_RB_MINLIMIT4,
 | |
| 	EXPP_CONSTR_RB_MINLIMIT5,
 | |
| 	EXPP_CONSTR_RB_MAXLIMIT0,
 | |
| 	EXPP_CONSTR_RB_MAXLIMIT1,
 | |
| 	EXPP_CONSTR_RB_MAXLIMIT2,
 | |
| 	EXPP_CONSTR_RB_MAXLIMIT3,
 | |
| 	EXPP_CONSTR_RB_MAXLIMIT4,
 | |
| 	EXPP_CONSTR_RB_MAXLIMIT5,
 | |
| 	EXPP_CONSTR_RB_EXTRAFZ,
 | |
| 	EXPP_CONSTR_RB_FLAG,
 | |
| 	
 | |
| };
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python BPy_Constraint methods declarations:                               */
 | |
| /*****************************************************************************/
 | |
| static PyObject *Constraint_getName( BPy_Constraint * self );
 | |
| static int Constraint_setName( BPy_Constraint * self, PyObject *arg );
 | |
| static PyObject *Constraint_getType( BPy_Constraint * self );
 | |
| static PyObject *Constraint_getInfluence( BPy_Constraint * self );
 | |
| static int Constraint_setInfluence( BPy_Constraint * self, PyObject * arg );
 | |
| 
 | |
| static PyObject *Constraint_insertKey( BPy_Constraint * self, PyObject * arg );
 | |
| 
 | |
| static PyObject *Constraint_getData( BPy_Constraint * self, PyObject * key );
 | |
| static int Constraint_setData( BPy_Constraint * self, PyObject * key, 
 | |
| 		PyObject * value );
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python BPy_Constraint methods table:                                      */
 | |
| /*****************************************************************************/
 | |
| static PyMethodDef BPy_Constraint_methods[] = {
 | |
| 	/* name, method, flags, doc */
 | |
| 	{"insertKey", ( PyCFunction ) Constraint_insertKey, METH_O,
 | |
| 	 "Insert influence keyframe for constraint"},
 | |
| 	{NULL, NULL, 0, NULL}
 | |
| };
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python BPy_Constraint attributes get/set structure:                       */
 | |
| /*****************************************************************************/
 | |
| static PyGetSetDef BPy_Constraint_getseters[] = {
 | |
| 	{"name",
 | |
| 	(getter)Constraint_getName, (setter)Constraint_setName,
 | |
| 	 "Constraint name", NULL},
 | |
| 	{"type",
 | |
| 	(getter)Constraint_getType, (setter)NULL,
 | |
| 	 "Constraint type (read only)", NULL},
 | |
| 	{"influence",
 | |
| 	(getter)Constraint_getInfluence, (setter)Constraint_setInfluence,
 | |
| 	 "Constraint influence", NULL},
 | |
| 	{NULL,NULL,NULL,NULL,NULL}  /* Sentinel */
 | |
| };
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python Constraint_Type Mapping Methods table:                             */
 | |
| /*****************************************************************************/
 | |
| static PyMappingMethods Constraint_as_mapping = {
 | |
| 	NULL,                               /* mp_length        */
 | |
| 	( binaryfunc ) Constraint_getData,	/* mp_subscript     */
 | |
| 	( objobjargproc ) Constraint_setData,	/* mp_ass_subscript */
 | |
| };
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python Constraint_Type callback function prototypes:                      */
 | |
| /*****************************************************************************/
 | |
| static PyObject *Constraint_repr( BPy_Constraint * self );
 | |
| static int Constraint_compare( BPy_Constraint * a, BPy_Constraint * b );
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python Constraint_Type structure definition:                              */
 | |
| /*****************************************************************************/
 | |
| PyTypeObject Constraint_Type = {
 | |
| 	PyObject_HEAD_INIT( NULL )  /* required py macro */
 | |
| 	0,                          /* ob_size */
 | |
| 	/*  For printing, in format "<module>.<name>" */
 | |
| 	"Blender Constraint",         /* char *tp_name; */
 | |
| 	sizeof( BPy_Constraint ),     /* int tp_basicsize; */
 | |
| 	0,                          /* tp_itemsize;  For allocation */
 | |
| 
 | |
| 	/* Methods to implement standard operations */
 | |
| 
 | |
| 	NULL,						/* destructor tp_dealloc; */
 | |
| 	NULL,                       /* printfunc tp_print; */
 | |
| 	NULL,                       /* getattrfunc tp_getattr; */
 | |
| 	NULL,                       /* setattrfunc tp_setattr; */
 | |
| 	( cmpfunc ) Constraint_compare, /* cmpfunc tp_compare; */
 | |
| 	( reprfunc ) Constraint_repr, /* reprfunc tp_repr; */
 | |
| 
 | |
| 	/* Method suites for standard classes */
 | |
| 
 | |
| 	NULL,                       /* PyNumberMethods *tp_as_number; */
 | |
| 	NULL,                       /* PySequenceMethods *tp_as_sequence; */
 | |
| 	&Constraint_as_mapping,       /* PyMappingMethods *tp_as_mapping; */
 | |
| 
 | |
| 	/* More standard operations (here for binary compatibility) */
 | |
| 
 | |
| 	NULL,                       /* hashfunc tp_hash; */
 | |
| 	NULL,                       /* ternaryfunc tp_call; */
 | |
| 	NULL,                       /* reprfunc tp_str; */
 | |
| 	NULL,                       /* getattrofunc tp_getattro; */
 | |
| 	NULL,                       /* setattrofunc tp_setattro; */
 | |
| 
 | |
| 	/* Functions to access object as input/output buffer */
 | |
| 	NULL,                       /* PyBufferProcs *tp_as_buffer; */
 | |
| 
 | |
|   /*** Flags to define presence of optional/expanded features ***/
 | |
| 	Py_TPFLAGS_DEFAULT,         /* long tp_flags; */
 | |
| 
 | |
| 	NULL,                       /*  char *tp_doc;  Documentation string */
 | |
|   /*** Assigned meaning in release 2.0 ***/
 | |
| 	/* call function for all accessible objects */
 | |
| 	NULL,                       /* traverseproc tp_traverse; */
 | |
| 
 | |
| 	/* delete references to contained objects */
 | |
| 	NULL,                       /* inquiry tp_clear; */
 | |
| 
 | |
|   /***  Assigned meaning in release 2.1 ***/
 | |
|   /*** rich comparisons ***/
 | |
| 	NULL,                       /* richcmpfunc tp_richcompare; */
 | |
| 
 | |
|   /***  weak reference enabler ***/
 | |
| 	0,                          /* long tp_weaklistoffset; */
 | |
| 
 | |
|   /*** Added in release 2.2 ***/
 | |
| 	/*   Iterators */
 | |
| 	NULL,                       /* getiterfunc tp_iter; */
 | |
| 	NULL,                       /* iternextfunc tp_iternext; */
 | |
| 
 | |
|   /*** Attribute descriptor and subclassing stuff ***/
 | |
| 	BPy_Constraint_methods,       /* struct PyMethodDef *tp_methods; */
 | |
| 	NULL,                       /* struct PyMemberDef *tp_members; */
 | |
| 	BPy_Constraint_getseters,     /* 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; */
 | |
| 	NULL,                       /* initproc tp_init; */
 | |
| 	NULL,                       /* allocfunc tp_alloc; */
 | |
| 	NULL,                       /* newfunc tp_new; */
 | |
| 	/*  Low-level free-memory routine */
 | |
| 	NULL,                       /* freefunc tp_free;  */
 | |
| 	/* For PyObject_IS_GC */
 | |
| 	NULL,                       /* inquiry tp_is_gc;  */
 | |
| 	NULL,                       /* PyObject *tp_bases; */
 | |
| 	/* method resolution order */
 | |
| 	NULL,                       /* PyObject *tp_mro;  */
 | |
| 	NULL,                       /* PyObject *tp_cache; */
 | |
| 	NULL,                       /* PyObject *tp_subclasses; */
 | |
| 	NULL,                       /* PyObject *tp_weaklist; */
 | |
| 	NULL
 | |
| };
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python BPy_Constraint methods:                                            */
 | |
| /*****************************************************************************/
 | |
| 
 | |
| /*
 | |
|  * return the name of this constraint
 | |
|  */
 | |
| 
 | |
| static PyObject *Constraint_getName( BPy_Constraint * self )
 | |
| {
 | |
| 	if( !self->con )
 | |
| 		return EXPP_ReturnPyObjError( PyExc_RuntimeError,
 | |
| 				"This constraint has been removed!" );
 | |
| 	
 | |
| 	return PyString_FromString( self->con->name );
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * set the name of this constraint
 | |
|  */
 | |
| 
 | |
| static int Constraint_setName( BPy_Constraint * self, PyObject * attr )
 | |
| {
 | |
| 	char *name = PyString_AsString( attr );
 | |
| 	if( !name )
 | |
| 		return EXPP_ReturnIntError( PyExc_TypeError, "expected string arg" );
 | |
| 
 | |
| 	if( !self->con )
 | |
| 		return EXPP_ReturnIntError( PyExc_RuntimeError,
 | |
| 				"This constraint has been removed!" );
 | |
| 	
 | |
| 	BLI_strncpy( self->con->name, name, sizeof( self->con->name ) );
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * return the influence of this constraint
 | |
|  */
 | |
| 
 | |
| static PyObject *Constraint_getInfluence( BPy_Constraint * self )
 | |
| {
 | |
| 	if( !self->con )
 | |
| 		return EXPP_ReturnPyObjError( PyExc_RuntimeError,
 | |
| 				"This constraint has been removed!" );
 | |
| 	
 | |
| 	return PyFloat_FromDouble( (double)self->con->enforce );
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * set the influence of this constraint
 | |
|  */
 | |
| 
 | |
| static int Constraint_setInfluence( BPy_Constraint * self, PyObject * value )
 | |
| {
 | |
| 	if( !self->con )
 | |
| 		return EXPP_ReturnIntError( PyExc_RuntimeError,
 | |
| 				"This constraint has been removed!" );
 | |
| 
 | |
| 	return EXPP_setFloatClamped( value, &self->con->enforce, 0.0, 1.0 );
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * return the type of this constraint
 | |
|  */
 | |
| 
 | |
| static PyObject *Constraint_getType( BPy_Constraint * self )
 | |
| {
 | |
| 	if( !self->con )
 | |
| 		return EXPP_ReturnPyObjError( PyExc_RuntimeError,
 | |
| 				"This constraint has been removed!" );
 | |
| 	
 | |
| 	return PyInt_FromLong( self->con->type );
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * add keyframe for influence
 | |
| 	base on code in add_influence_key_to_constraint_func()
 | |
|  */
 | |
| static PyObject *Constraint_insertKey( BPy_Constraint * self, PyObject * value )
 | |
| {
 | |
| 	bConstraint *con = self->con;
 | |
| 	Object *ob = self->obj;
 | |
| 	bPoseChannel *pchan = self->pchan;
 | |
| 	IpoCurve *icu;
 | |
| 	float cfra = (float)PyFloat_AsDouble(value);
 | |
| 	char actname[32] = "";
 | |
| 	
 | |
| 	if( !self->con )
 | |
| 		return EXPP_ReturnPyObjError( PyExc_RuntimeError,
 | |
| 				"This constraint has been removed!" );
 | |
| 
 | |
| 	/* get frame for inserting key */
 | |
| 	if( PyFloat_Check(value) )
 | |
| 		return EXPP_ReturnPyObjError( PyExc_TypeError,
 | |
| 				"expected a float argument" );
 | |
| 	
 | |
| 	/* find actname for locating that action-channel that a constraint channel should be added to */
 | |
| 	if (ob) {
 | |
| 		if (pchan) {
 | |
| 			/* actname is the name of the pchan that this constraint belongs to */
 | |
| 			BLI_strncpy(actname, pchan->name, 32);
 | |
| 		}
 | |
| 		else {
 | |
| 			/* hardcoded achan name -> "Object" (this may change in future) */
 | |
| 			strcpy(actname, "Object");
 | |
| 		}
 | |
| 	}
 | |
| 	else {
 | |
| 		return EXPP_ReturnPyObjError( PyExc_RuntimeError,
 | |
| 				"constraint doesn't belong to anything" );
 | |
| 	}
 | |
| 	icu= verify_ipocurve((ID *)ob, ID_CO, actname, con->name, CO_ENFORCE);
 | |
| 	
 | |
| 	if (!icu)
 | |
| 		return EXPP_ReturnPyObjError( PyExc_RuntimeError,
 | |
| 				"cannot get a curve from this IPO, may be using libdata" );
 | |
| 	
 | |
| 	if( ob->action )
 | |
| 		insert_vert_icu( icu, get_action_frame(ob, cfra), con->enforce, 0);
 | |
| 	else
 | |
| 		insert_vert_icu( icu, cfra, con->enforce, 0);
 | |
| 
 | |
| 	Py_RETURN_NONE;
 | |
| }
 | |
| 
 | |
| /******************************************************************************/
 | |
| /* Constraint Space Conversion get/set procedures							  */
 | |
| /* 		- These are called before/instead of individual constraint 			  */
 | |
| /*		  get/set procedures when OWNERSPACE or TARGETSPACE are chosen		  */
 | |
| /*		- They are only called from Constraint_g/setData					  */
 | |
| /******************************************************************************/
 | |
| 
 | |
| static PyObject *constspace_getter( BPy_Constraint * self, int type )
 | |
| {
 | |
| 	bConstraint *con= (bConstraint *)(self->con);
 | |
| 	
 | |
| 	/* depends on type being asked for
 | |
| 	 * NOTE: not all constraints support all space types 
 | |
| 	 */
 | |
| 	if (type == EXPP_CONSTR_OWNSPACE) {
 | |
| 		switch (con->type) {
 | |
| 			/* all of these support this... */
 | |
| 			case CONSTRAINT_TYPE_PYTHON:
 | |
| 			case CONSTRAINT_TYPE_LOCLIKE:
 | |
| 			case CONSTRAINT_TYPE_ROTLIKE:
 | |
| 			case CONSTRAINT_TYPE_SIZELIKE:
 | |
| 			case CONSTRAINT_TYPE_TRACKTO:
 | |
| 			case CONSTRAINT_TYPE_LOCLIMIT:
 | |
| 			case CONSTRAINT_TYPE_ROTLIMIT:
 | |
| 			case CONSTRAINT_TYPE_SIZELIMIT:
 | |
| 			case CONSTRAINT_TYPE_TRANSFORM:
 | |
| 				return PyInt_FromLong( (long)con->ownspace );
 | |
| 		}
 | |
| 	}
 | |
| 	else if (type == EXPP_CONSTR_TARSPACE) {
 | |
| 		switch (con->type) {
 | |
| 			/* all of these support this... */
 | |
| 			case CONSTRAINT_TYPE_PYTHON:
 | |
| 			case CONSTRAINT_TYPE_ACTION:
 | |
| 			case CONSTRAINT_TYPE_LOCLIKE:
 | |
| 			case CONSTRAINT_TYPE_ROTLIKE:
 | |
| 			case CONSTRAINT_TYPE_SIZELIKE:
 | |
| 			case CONSTRAINT_TYPE_TRACKTO:
 | |
| 			case CONSTRAINT_TYPE_TRANSFORM:
 | |
| 				return PyInt_FromLong( (long)con->tarspace );
 | |
| 		}
 | |
| 	}
 | |
| 	
 | |
| 	/* raise error if failed */
 | |
| 	return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );
 | |
| }
 | |
| 
 | |
| static int constspace_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bConstraint *con= (bConstraint *)(self->con);
 | |
| 	
 | |
| 	/* depends on type being asked for
 | |
| 	 * NOTE: not all constraints support all space types 
 | |
| 	 */
 | |
| 	if (type == EXPP_CONSTR_OWNSPACE) {
 | |
| 		switch (con->type) {
 | |
| 			/* all of these support this... */
 | |
| 			case CONSTRAINT_TYPE_PYTHON:
 | |
| 			case CONSTRAINT_TYPE_LOCLIKE:
 | |
| 			case CONSTRAINT_TYPE_ROTLIKE:
 | |
| 			case CONSTRAINT_TYPE_SIZELIKE:
 | |
| 			case CONSTRAINT_TYPE_TRACKTO:
 | |
| 			case CONSTRAINT_TYPE_LOCLIMIT:
 | |
| 			case CONSTRAINT_TYPE_ROTLIMIT:
 | |
| 			case CONSTRAINT_TYPE_SIZELIMIT:
 | |
| 			case CONSTRAINT_TYPE_TRANSFORM:
 | |
| 			{
 | |
| 				/* only copy depending on ownertype */
 | |
| 				if (self->pchan) {
 | |
| 					return EXPP_setIValueClamped( value, &con->ownspace, 
 | |
| 							CONSTRAINT_SPACE_WORLD, CONSTRAINT_SPACE_PARLOCAL, 'h' );
 | |
| 				}
 | |
| 				else {
 | |
| 					return EXPP_setIValueClamped( value, &con->ownspace, 
 | |
| 							CONSTRAINT_SPACE_WORLD, CONSTRAINT_SPACE_LOCAL, 'h' );
 | |
| 				}
 | |
| 			}
 | |
| 				break;
 | |
| 		}
 | |
| 	}
 | |
| 	else if (type == EXPP_CONSTR_TARSPACE) {
 | |
| 		switch (con->type) {
 | |
| 			/* all of these support this... */
 | |
| 			case CONSTRAINT_TYPE_PYTHON:
 | |
| 			case CONSTRAINT_TYPE_ACTION:
 | |
| 			case CONSTRAINT_TYPE_LOCLIKE:
 | |
| 			case CONSTRAINT_TYPE_ROTLIKE:
 | |
| 			case CONSTRAINT_TYPE_SIZELIKE:
 | |
| 			case CONSTRAINT_TYPE_TRACKTO:
 | |
| 			case CONSTRAINT_TYPE_TRANSFORM:
 | |
| 			{
 | |
| 				Object *tar;
 | |
| 				char *subtarget;
 | |
| 				
 | |
| 				// FIXME!!!
 | |
| 				//tar= get_constraint_target(con, &subtarget);
 | |
| 				tar = NULL;
 | |
| 				subtarget = NULL;
 | |
| 				
 | |
| 				/* only copy depending on target-type */
 | |
| 				if (tar && subtarget[0]) {
 | |
| 					return EXPP_setIValueClamped( value, &con->tarspace, 
 | |
| 							CONSTRAINT_SPACE_WORLD, CONSTRAINT_SPACE_PARLOCAL, 'h' );
 | |
| 				}
 | |
| 				else if (tar) {
 | |
| 					return EXPP_setIValueClamped( value, &con->tarspace, 
 | |
| 							CONSTRAINT_SPACE_WORLD, CONSTRAINT_SPACE_LOCAL, 'h' );
 | |
| 				}
 | |
| 			}
 | |
| 				break;
 | |
| 		}
 | |
| 	}
 | |
| 	
 | |
| 	/* raise error if failed */
 | |
| 	return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Specific constraint get/set procedures                                    */
 | |
| /*****************************************************************************/
 | |
| 
 | |
| static PyObject *kinematic_getter( BPy_Constraint * self, int type )
 | |
| {
 | |
| 	bKinematicConstraint *con = (bKinematicConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET:
 | |
| 		return Object_CreatePyObject( con->tar );
 | |
| 	case EXPP_CONSTR_BONE:
 | |
| 		return PyString_FromString( con->subtarget );
 | |
| 	case EXPP_CONSTR_STRETCH:
 | |
| 		return PyBool_FromLong( (long)( con->flag & CONSTRAINT_IK_STRETCH ) ) ;
 | |
| 	case EXPP_CONSTR_ITERATIONS:
 | |
| 		return PyInt_FromLong( (long)con->iterations );
 | |
| 	case EXPP_CONSTR_CHAINLEN:
 | |
| 		return PyInt_FromLong( (long)con->rootbone );
 | |
| 	case EXPP_CONSTR_POSWEIGHT:
 | |
| 		return PyFloat_FromDouble( (double)con->weight );
 | |
| 	case EXPP_CONSTR_ROTWEIGHT:
 | |
| 		return PyFloat_FromDouble( (double)con->orientweight );
 | |
| 	case EXPP_CONSTR_ROTATE:
 | |
| 		return PyBool_FromLong( (long)( con->flag & CONSTRAINT_IK_ROT ) ) ;
 | |
| 	case EXPP_CONSTR_USETIP:
 | |
| 		return PyBool_FromLong( (long)( con->flag & CONSTRAINT_IK_TIP ) ) ;
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int kinematic_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bKinematicConstraint *con = (bKinematicConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET: {
 | |
| 		Object *obj = (( BPy_Object * )value)->object;
 | |
| 		if( !BPy_Object_Check( value ) )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 					"expected BPy object argument" );
 | |
| 		con->tar = obj;
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_BONE: {
 | |
| 		char *name = PyString_AsString( value );
 | |
| 		if( !name )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError,
 | |
| 					"expected string arg" );
 | |
| 
 | |
| 		BLI_strncpy( con->subtarget, name, sizeof( con->subtarget ) );
 | |
| 
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_STRETCH:
 | |
| 		return EXPP_setBitfield( value, &con->flag, CONSTRAINT_IK_STRETCH, 'h' );
 | |
| 	case EXPP_CONSTR_ITERATIONS:
 | |
| 		return EXPP_setIValueClamped( value, &con->iterations, 1, 10000, 'h' );
 | |
| 	case EXPP_CONSTR_CHAINLEN:
 | |
| 		return EXPP_setIValueClamped( value, &con->rootbone, 0, 255, 'i' );
 | |
| 	case EXPP_CONSTR_POSWEIGHT:
 | |
| 		return EXPP_setFloatClamped( value, &con->weight, 0.01f, 1.0 );
 | |
| 	case EXPP_CONSTR_ROTWEIGHT:
 | |
| 		return EXPP_setFloatClamped( value, &con->orientweight, 0.01f, 1.0 );
 | |
| 	case EXPP_CONSTR_ROTATE:
 | |
| 		return EXPP_setBitfield( value, &con->flag, CONSTRAINT_IK_ROT, 'h' );
 | |
| 	case EXPP_CONSTR_USETIP:
 | |
| 		return EXPP_setBitfield( value, &con->flag, CONSTRAINT_IK_TIP, 'h' );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static PyObject *action_getter( BPy_Constraint * self, int type )
 | |
| {
 | |
| 	bActionConstraint *con = (bActionConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET:
 | |
| 		return Object_CreatePyObject( con->tar );
 | |
| 	case EXPP_CONSTR_BONE:
 | |
| 		return PyString_FromString( con->subtarget );
 | |
| 	case EXPP_CONSTR_ACTION:
 | |
| 		return Action_CreatePyObject( con->act );
 | |
| 	case EXPP_CONSTR_START:
 | |
| 		return PyInt_FromLong( (long)con->start );
 | |
| 	case EXPP_CONSTR_END:
 | |
| 		return PyInt_FromLong( (long)con->end );
 | |
| 	case EXPP_CONSTR_MIN:
 | |
| 		return PyFloat_FromDouble( (double)con->min );
 | |
| 	case EXPP_CONSTR_MAX:
 | |
| 		return PyFloat_FromDouble( (double)con->max );
 | |
| 	case EXPP_CONSTR_KEYON:
 | |
| 		return PyInt_FromLong( (long)con->type );
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int action_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bActionConstraint *con = (bActionConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET: {
 | |
| 		Object *obj = (( BPy_Object * )value)->object;
 | |
| 		if( !BPy_Object_Check( value ) )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 					"expected BPy object argument" );
 | |
| 		con->tar = obj;
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_BONE: {
 | |
| 		char *name = PyString_AsString( value );
 | |
| 		if( !name )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError,
 | |
| 					"expected string arg" );
 | |
| 
 | |
| 		BLI_strncpy( con->subtarget, name, sizeof( con->subtarget ) );
 | |
| 
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_ACTION: {
 | |
| 		bAction *act = (( BPy_Action * )value)->action;
 | |
| 		if( !BPy_Action_Check( value ) )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 					"expected BPy action argument" );
 | |
| 		con->act = act;
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_START:
 | |
| 		return EXPP_setIValueClamped( value, &con->start, 1, MAXFRAME, 'h' );
 | |
| 	case EXPP_CONSTR_END:
 | |
| 		return EXPP_setIValueClamped( value, &con->end, 1, MAXFRAME, 'h' );
 | |
| 	case EXPP_CONSTR_MIN:
 | |
| 		if (con->type < 10)
 | |
| 			return EXPP_setFloatClamped( value, &con->min, -180.0, 180.0 );
 | |
| 		else if (con->type < 20)
 | |
| 			return EXPP_setFloatClamped( value, &con->min, 0.0001, 1000.0 );
 | |
| 		else 
 | |
| 			return EXPP_setFloatClamped( value, &con->min, -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_MAX:
 | |
| 		if (con->type < 10)
 | |
| 			return EXPP_setFloatClamped( value, &con->max, -180.0, 180.0 );
 | |
| 		else if (con->type < 20)
 | |
| 			return EXPP_setFloatClamped( value, &con->max, 0.0001, 1000.0 );
 | |
| 		else 
 | |
| 			return EXPP_setFloatClamped( value, &con->max, -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_KEYON:
 | |
| 		return EXPP_setIValueRange( value, &con->type,
 | |
| 				EXPP_CONSTR_XROT, EXPP_CONSTR_ZLOC, 'h' );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static PyObject *trackto_getter( BPy_Constraint * self, int type )
 | |
| {
 | |
| 	bTrackToConstraint *con = (bTrackToConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET:
 | |
| 		return Object_CreatePyObject( con->tar );
 | |
| 	case EXPP_CONSTR_BONE:
 | |
| 		return PyString_FromString( con->subtarget );
 | |
| 	case EXPP_CONSTR_TRACK:
 | |
| 		return PyInt_FromLong( (long)con->reserved1 );
 | |
| 	case EXPP_CONSTR_UP:
 | |
| 		return PyInt_FromLong( (long)con->reserved2 );
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int trackto_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bTrackToConstraint *con = (bTrackToConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET: {
 | |
| 		Object *obj = (( BPy_Object * )value)->object;
 | |
| 		if( !BPy_Object_Check( value ) )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 					"expected BPy object argument" );
 | |
| 		con->tar = obj;
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_BONE: {
 | |
| 		char *name = PyString_AsString( value );
 | |
| 		if( !name )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError,
 | |
| 					"expected string arg" );
 | |
| 
 | |
| 		BLI_strncpy( con->subtarget, name, sizeof( con->subtarget ) );
 | |
| 
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_TRACK:
 | |
| 		return EXPP_setIValueRange( value, &con->reserved1,
 | |
| 				TRACK_X, TRACK_nZ, 'i' );
 | |
| 	case EXPP_CONSTR_UP:
 | |
| 		return EXPP_setIValueRange( value, &con->reserved2,
 | |
| 				UP_X, UP_Z, 'i' );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static PyObject *stretchto_getter( BPy_Constraint * self, int type )
 | |
| {
 | |
| 	bStretchToConstraint *con = (bStretchToConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET:
 | |
| 		return Object_CreatePyObject( con->tar );
 | |
| 	case EXPP_CONSTR_BONE:
 | |
| 		return PyString_FromString( con->subtarget );
 | |
| 	case EXPP_CONSTR_RESTLENGTH:
 | |
| 		return PyFloat_FromDouble( (double)con->orglength );
 | |
| 	case EXPP_CONSTR_VOLVARIATION:
 | |
| 		return PyFloat_FromDouble( (double)con->bulge );
 | |
| 	case EXPP_CONSTR_VOLUMEMODE:
 | |
| 		return PyInt_FromLong( (long)con->volmode );
 | |
| 	case EXPP_CONSTR_PLANE:
 | |
| 		return PyInt_FromLong( (long)con->plane );
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int stretchto_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bStretchToConstraint *con = (bStretchToConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET: {
 | |
| 		Object *obj = (( BPy_Object * )value)->object;
 | |
| 		if( !BPy_Object_Check( value ) )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 					"expected BPy object argument" );
 | |
| 		con->tar = obj;
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_BONE: {
 | |
| 		char *name = PyString_AsString( value );
 | |
| 		if( !name )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError,
 | |
| 					"expected string arg" );
 | |
| 
 | |
| 		BLI_strncpy( con->subtarget, name, sizeof( con->subtarget ) );
 | |
| 
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_RESTLENGTH:
 | |
| 		return EXPP_setFloatClamped( value, &con->orglength, 0.0, 100.0 );
 | |
| 	case EXPP_CONSTR_VOLVARIATION:
 | |
| 		return EXPP_setFloatClamped( value, &con->bulge, 0.0, 100.0 );
 | |
| 	case EXPP_CONSTR_VOLUMEMODE:
 | |
| 		return EXPP_setIValueRange( value, &con->volmode,
 | |
| 				VOLUME_XZ, NO_VOLUME, 'h' );
 | |
| 	case EXPP_CONSTR_PLANE: {
 | |
| 		int status, oldcode = con->plane;
 | |
| 		status = EXPP_setIValueRange( value, &con->plane,
 | |
| 				PLANE_X, PLANE_Z, 'h' );
 | |
| 		if( !status && con->plane == PLANE_Y ) {
 | |
| 			con->plane = oldcode;
 | |
| 			return EXPP_ReturnIntError( PyExc_ValueError,
 | |
| 					"value must be either PLANEX or PLANEZ" );
 | |
| 		}
 | |
| 		return status;
 | |
| 		}
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static PyObject *followpath_getter( BPy_Constraint * self, int type )
 | |
| {
 | |
| 	bFollowPathConstraint *con = (bFollowPathConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET:
 | |
| 		return Object_CreatePyObject( con->tar );
 | |
| 	case EXPP_CONSTR_FOLLOW:
 | |
| 		return PyBool_FromLong( (long)( con->followflag & SELECT ) );
 | |
| 	case EXPP_CONSTR_OFFSET:
 | |
| 		return PyFloat_FromDouble( (double)con->offset );
 | |
| 	case EXPP_CONSTR_FORWARD:
 | |
| 		return PyInt_FromLong( (long)con->trackflag );
 | |
| 	case EXPP_CONSTR_UP:
 | |
| 		return PyInt_FromLong( (long)con->upflag );
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int followpath_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bFollowPathConstraint *con = (bFollowPathConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET: {
 | |
| 		Object *obj = (( BPy_Object * )value)->object;
 | |
| 		if( !BPy_Object_Check( value ) )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 					"expected BPy object argument" );
 | |
| 		con->tar = obj;
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_FOLLOW:
 | |
| 		return EXPP_setBitfield( value, &con->followflag, SELECT, 'i' );
 | |
| 	case EXPP_CONSTR_OFFSET:
 | |
| 		return EXPP_setFloatClamped( value, &con->offset,
 | |
| 				-MAXFRAMEF, MAXFRAMEF );
 | |
| 	case EXPP_CONSTR_FORWARD:
 | |
| 		return EXPP_setIValueRange( value, &con->trackflag,
 | |
| 				TRACK_X, TRACK_nZ, 'i' );
 | |
| 	case EXPP_CONSTR_UP:
 | |
| 		return EXPP_setIValueRange( value, &con->upflag,
 | |
| 				UP_X, UP_Z, 'i' );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static PyObject *clampto_getter( BPy_Constraint * self, int type )
 | |
| {
 | |
| 	bClampToConstraint *con = (bClampToConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET:
 | |
| 		return Object_CreatePyObject( con->tar );
 | |
| 	case EXPP_CONSTR_CLAMP:
 | |
| 		return PyInt_FromLong( (long)con->flag );
 | |
| 	case EXPP_CONSTR_CLAMPCYCLIC:
 | |
| 		return PyBool_FromLong( (long)(con->flag2 & CLAMPTO_CYCLIC) );
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int clampto_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bClampToConstraint *con = (bClampToConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET: {
 | |
| 		Object *obj = (( BPy_Object * )value)->object;
 | |
| 		if( !BPy_Object_Check( value ) )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 					"expected BPy object argument" );
 | |
| 		con->tar = obj;
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_CLAMP:
 | |
| 		return EXPP_setIValueRange( value, &con->flag,
 | |
| 				CLAMPTO_AUTO, CLAMPTO_Z, 'i' );
 | |
| 	case EXPP_CONSTR_CLAMPCYCLIC:
 | |
| 		return EXPP_setBitfield( value, &con->flag2, CLAMPTO_CYCLIC, 'i' );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| static PyObject *locktrack_getter( BPy_Constraint * self, int type )
 | |
| {
 | |
| 	bLockTrackConstraint *con = (bLockTrackConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET:
 | |
| 		return Object_CreatePyObject( con->tar );
 | |
| 	case EXPP_CONSTR_BONE:
 | |
| 		return PyString_FromString( con->subtarget );
 | |
| 	case EXPP_CONSTR_TRACK:
 | |
| 		return PyInt_FromLong( (long)con->trackflag );
 | |
| 	case EXPP_CONSTR_LOCK:
 | |
| 		return PyInt_FromLong( (long)con->lockflag );
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int locktrack_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bLockTrackConstraint *con = (bLockTrackConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET: {
 | |
| 		Object *obj = (( BPy_Object * )value)->object;
 | |
| 		if( !BPy_Object_Check( value ) )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 					"expected BPy object argument" );
 | |
| 		con->tar = obj;
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_BONE: {
 | |
| 		char *name = PyString_AsString( value );
 | |
| 		if( !name )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError,
 | |
| 					"expected string arg" );
 | |
| 
 | |
| 		BLI_strncpy( con->subtarget, name, sizeof( con->subtarget ) );
 | |
| 
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_TRACK:
 | |
| 		return EXPP_setIValueRange( value, &con->trackflag,
 | |
| 				TRACK_X, TRACK_nZ, 'i' );
 | |
| 	case EXPP_CONSTR_LOCK:
 | |
| 		return EXPP_setIValueRange( value, &con->lockflag,
 | |
| 				LOCK_X, LOCK_Z, 'i' );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static PyObject *floor_getter( BPy_Constraint * self, int type )
 | |
| {
 | |
| 	bMinMaxConstraint *con = (bMinMaxConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET:
 | |
| 		return Object_CreatePyObject( con->tar );
 | |
| 	case EXPP_CONSTR_BONE:
 | |
| 		return PyString_FromString( con->subtarget );
 | |
| 	case EXPP_CONSTR_MINMAX:
 | |
| 		return PyInt_FromLong( (long)con->minmaxflag );
 | |
| 	case EXPP_CONSTR_OFFSET:
 | |
| 		return PyFloat_FromDouble( (double)con->offset );
 | |
| 	case EXPP_CONSTR_STICKY:
 | |
| 		return PyBool_FromLong( (long)( con->flag & MINMAX_STICKY ) ) ;
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int floor_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bMinMaxConstraint *con = (bMinMaxConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET: {
 | |
| 		Object *obj = (( BPy_Object * )value)->object;
 | |
| 		if( !BPy_Object_Check( value ) )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 					"expected BPy object argument" );
 | |
| 		con->tar = obj;
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_BONE: {
 | |
| 		char *name = PyString_AsString( value );
 | |
| 		if( !name )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError,
 | |
| 					"expected string arg" );
 | |
| 
 | |
| 		BLI_strncpy( con->subtarget, name, sizeof( con->subtarget ) );
 | |
| 
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_MINMAX:
 | |
| 		return EXPP_setIValueRange( value, &con->minmaxflag,
 | |
| 				EXPP_CONSTR_MAXX, EXPP_CONSTR_MINZ, 'i' );
 | |
| 	case EXPP_CONSTR_OFFSET:
 | |
| 		return EXPP_setFloatClamped( value, &con->offset, -100.0, 100.0 );
 | |
| 	case EXPP_CONSTR_STICKY:
 | |
| 		return EXPP_setBitfield( value, &con->flag, MINMAX_STICKY, 'h' );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static PyObject *locatelike_getter( BPy_Constraint * self, int type )
 | |
| {
 | |
| 	bLocateLikeConstraint *con = (bLocateLikeConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET:
 | |
| 		return Object_CreatePyObject( con->tar );
 | |
| 	case EXPP_CONSTR_BONE:
 | |
| 		return PyString_FromString( con->subtarget );
 | |
| 	case EXPP_CONSTR_COPY:
 | |
| 		return PyInt_FromLong( (long)con->flag );
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int locatelike_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bLocateLikeConstraint *con = (bLocateLikeConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET: {
 | |
| 		Object *obj = (( BPy_Object * )value)->object;
 | |
| 		if( !BPy_Object_Check( value ) )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 					"expected BPy object argument" );
 | |
| 		con->tar = obj;
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_BONE: {
 | |
| 		char *name = PyString_AsString( value );
 | |
| 		if( !name )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError,
 | |
| 					"expected string arg" );
 | |
| 
 | |
| 		BLI_strncpy( con->subtarget, name, sizeof( con->subtarget ) );
 | |
| 
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_COPY:
 | |
| 		return EXPP_setIValueRange( value, &con->flag,
 | |
| 				0, LOCLIKE_X | LOCLIKE_Y | LOCLIKE_Z | LOCLIKE_X_INVERT | LOCLIKE_Y_INVERT | LOCLIKE_Z_INVERT, 'i' );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static PyObject *rotatelike_getter( BPy_Constraint * self, int type )
 | |
| {
 | |
| 	bRotateLikeConstraint *con = (bRotateLikeConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET:
 | |
| 		return Object_CreatePyObject( con->tar );
 | |
| 	case EXPP_CONSTR_BONE:
 | |
| 		return PyString_FromString( con->subtarget );
 | |
| 	case EXPP_CONSTR_COPY:
 | |
| 		return PyInt_FromLong( (long)con->flag );
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int rotatelike_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bRotateLikeConstraint *con = (bRotateLikeConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET: {
 | |
| 		Object *obj = (( BPy_Object * )value)->object;
 | |
| 		if( !BPy_Object_Check( value ) )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 					"expected BPy object argument" );
 | |
| 		con->tar = obj;
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_BONE: {
 | |
| 		char *name = PyString_AsString( value );
 | |
| 		if( !name )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError,
 | |
| 					"expected string arg" );
 | |
| 
 | |
| 		BLI_strncpy( con->subtarget, name, sizeof( con->subtarget ) );
 | |
| 
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_COPY:
 | |
| 		return EXPP_setIValueRange( value, &con->flag,
 | |
| 				0, ROTLIKE_X | ROTLIKE_Y | ROTLIKE_Z | ROTLIKE_X_INVERT | ROTLIKE_Y_INVERT | ROTLIKE_Z_INVERT, 'i' );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static PyObject *sizelike_getter( BPy_Constraint * self, int type )
 | |
| {
 | |
| 	bSizeLikeConstraint *con = (bSizeLikeConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET:
 | |
| 		return Object_CreatePyObject( con->tar );
 | |
| 	case EXPP_CONSTR_BONE:
 | |
| 		return PyString_FromString( con->subtarget );
 | |
| 	case EXPP_CONSTR_COPY:
 | |
| 		return PyInt_FromLong( (long)con->flag );
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int sizelike_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bSizeLikeConstraint *con = (bSizeLikeConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET: {
 | |
| 		Object *obj = (( BPy_Object * )value)->object;
 | |
| 		if( !BPy_Object_Check( value ) )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 					"expected BPy object argument" );
 | |
| 		con->tar = obj;
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_BONE: {
 | |
| 		char *name = PyString_AsString( value );
 | |
| 		if( !name )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError,
 | |
| 					"expected string arg" );
 | |
| 
 | |
| 		BLI_strncpy( con->subtarget, name, sizeof( con->subtarget ) );
 | |
| 
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_COPY:
 | |
| 		return EXPP_setIValueRange( value, &con->flag,
 | |
| 				0, SIZELIKE_X | SIZELIKE_Y | SIZELIKE_Z, 'i' );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static PyObject *loclimit_getter( BPy_Constraint * self, int type)
 | |
| {
 | |
| 	bLocLimitConstraint *con = (bLocLimitConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_LIMIT:
 | |
| 		return PyInt_FromLong( (long)con->flag );
 | |
| 	case EXPP_CONSTR_XMIN:
 | |
| 		return PyFloat_FromDouble( (double)con->xmin );
 | |
| 	case EXPP_CONSTR_XMAX:
 | |
| 		return PyFloat_FromDouble( (double)con->xmax );
 | |
| 	case EXPP_CONSTR_YMIN:
 | |
| 		return PyFloat_FromDouble( (double)con->ymin );
 | |
| 	case EXPP_CONSTR_YMAX:
 | |
| 		return PyFloat_FromDouble( (double)con->ymax );
 | |
| 	case EXPP_CONSTR_ZMIN:
 | |
| 		return PyFloat_FromDouble( (double)con->zmin );
 | |
| 	case EXPP_CONSTR_ZMAX:
 | |
| 		return PyFloat_FromDouble( (double)con->zmax );
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );	
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int loclimit_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bLocLimitConstraint *con = (bLocLimitConstraint *)(self->con->data);	
 | |
| 	
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_LIMIT:
 | |
| 		return EXPP_setIValueRange( value, &con->flag, 0, 
 | |
| 			LIMIT_XMIN | LIMIT_XMAX | LIMIT_YMIN | LIMIT_YMAX | LIMIT_ZMIN | LIMIT_ZMAX , 'i' );
 | |
| 	case EXPP_CONSTR_XMIN:
 | |
| 		return EXPP_setFloatClamped( value, &con->xmin, -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_XMAX:
 | |
| 		return EXPP_setFloatClamped( value, &con->xmax, -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_YMIN:
 | |
| 		return EXPP_setFloatClamped( value, &con->ymin, -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_YMAX:
 | |
| 		return EXPP_setFloatClamped( value, &con->ymax, -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_ZMIN:
 | |
| 		return EXPP_setFloatClamped( value, &con->zmin, -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_ZMAX:
 | |
| 		return EXPP_setFloatClamped( value, &con->zmax, -1000.0, 1000.0 );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static PyObject *rotlimit_getter( BPy_Constraint * self, int type )
 | |
| {
 | |
| 	bRotLimitConstraint *con = (bRotLimitConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_LIMIT:
 | |
| 		return PyInt_FromLong( (long)con->flag );
 | |
| 	case EXPP_CONSTR_XMIN:
 | |
| 		return PyFloat_FromDouble( (double)con->xmin );
 | |
| 	case EXPP_CONSTR_XMAX:
 | |
| 		return PyFloat_FromDouble( (double)con->xmax );
 | |
| 	case EXPP_CONSTR_YMIN:
 | |
| 		return PyFloat_FromDouble( (double)con->ymin );
 | |
| 	case EXPP_CONSTR_YMAX:
 | |
| 		return PyFloat_FromDouble( (double)con->ymax );
 | |
| 	case EXPP_CONSTR_ZMIN:
 | |
| 		return PyFloat_FromDouble( (double)con->zmin );
 | |
| 	case EXPP_CONSTR_ZMAX:
 | |
| 		return PyFloat_FromDouble( (double)con->zmax );
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );	
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int rotlimit_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bRotLimitConstraint *con = (bRotLimitConstraint *)(self->con->data);	
 | |
| 	
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_LIMIT:
 | |
| 		return EXPP_setIValueRange( value, &con->flag, 0, 
 | |
| 			LIMIT_XROT | LIMIT_YROT | LIMIT_ZROT, 'i' );
 | |
| 	case EXPP_CONSTR_XMIN:
 | |
| 		return EXPP_setFloatClamped( value, &con->xmin, -360.0, 360.0 );
 | |
| 	case EXPP_CONSTR_XMAX:
 | |
| 		return EXPP_setFloatClamped( value, &con->xmax, -360.0, 360.0 );
 | |
| 	case EXPP_CONSTR_YMIN:
 | |
| 		return EXPP_setFloatClamped( value, &con->ymin, -360.0, 360.0 );
 | |
| 	case EXPP_CONSTR_YMAX:
 | |
| 		return EXPP_setFloatClamped( value, &con->ymax, -360.0, 360.0 );
 | |
| 	case EXPP_CONSTR_ZMIN:
 | |
| 		return EXPP_setFloatClamped( value, &con->zmin, -360.0, 360.0 );
 | |
| 	case EXPP_CONSTR_ZMAX:
 | |
| 		return EXPP_setFloatClamped( value, &con->zmax, -360.0, 360.0 );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static PyObject *sizelimit_getter( BPy_Constraint * self, int type)
 | |
| {
 | |
| 	bSizeLimitConstraint *con = (bSizeLimitConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_LIMIT:
 | |
| 		return PyInt_FromLong( (long)con->flag );
 | |
| 	case EXPP_CONSTR_XMIN:
 | |
| 		return PyFloat_FromDouble( (double)con->xmin );
 | |
| 	case EXPP_CONSTR_XMAX:
 | |
| 		return PyFloat_FromDouble( (double)con->xmax );
 | |
| 	case EXPP_CONSTR_YMIN:
 | |
| 		return PyFloat_FromDouble( (double)con->ymin );
 | |
| 	case EXPP_CONSTR_YMAX:
 | |
| 		return PyFloat_FromDouble( (double)con->ymax );
 | |
| 	case EXPP_CONSTR_ZMIN:
 | |
| 		return PyFloat_FromDouble( (double)con->zmin );
 | |
| 	case EXPP_CONSTR_ZMAX:
 | |
| 		return PyFloat_FromDouble( (double)con->zmax );
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );	
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int sizelimit_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bSizeLimitConstraint *con = (bSizeLimitConstraint *)(self->con->data);	
 | |
| 	
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_LIMIT:
 | |
| 		return EXPP_setIValueRange( value, &con->flag, 0, 
 | |
| 			LIMIT_XMIN | LIMIT_XMAX | LIMIT_YMIN | LIMIT_YMAX | LIMIT_ZMIN | LIMIT_ZMAX, 'i' );
 | |
| 	case EXPP_CONSTR_XMIN:
 | |
| 		return EXPP_setFloatClamped( value, &con->xmin, -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_XMAX:
 | |
| 		return EXPP_setFloatClamped( value, &con->xmax, -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_YMIN:
 | |
| 		return EXPP_setFloatClamped( value, &con->ymin, -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_YMAX:
 | |
| 		return EXPP_setFloatClamped( value, &con->ymax, -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_ZMIN:
 | |
| 		return EXPP_setFloatClamped( value, &con->zmin, -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_ZMAX:
 | |
| 		return EXPP_setFloatClamped( value, &con->zmax, -1000.0, 1000.0 );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static PyObject *script_getter( BPy_Constraint * self, int type )
 | |
| {
 | |
| 	bPythonConstraint *con = (bPythonConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 		// FIXME!!!
 | |
| 	//case EXPP_CONSTR_TARGET:
 | |
| 	//	return Object_CreatePyObject( con->tar );
 | |
| 	//case EXPP_CONSTR_BONE:
 | |
| 	//	return PyString_FromString( con->subtarget );
 | |
| 	case EXPP_CONSTR_SCRIPT:
 | |
| 		return Text_CreatePyObject( con->text );
 | |
| 	case EXPP_CONSTR_PROPS:
 | |
| 		return BPy_Wrap_IDProperty( NULL, con->prop, NULL);
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int script_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bPythonConstraint *con = (bPythonConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 		// FIXME!!!
 | |
| 	//case EXPP_CONSTR_TARGET: {
 | |
| 	//	Object *obj = (( BPy_Object * )value)->object;
 | |
| 	//	if( !BPy_Object_Check( value ) )
 | |
| 	//		return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 	//				"expected BPy object argument" );
 | |
| 	//	con->tar = obj;
 | |
| 	//	return 0;
 | |
| 	//	}
 | |
| 	//case EXPP_CONSTR_BONE: {
 | |
| 	//	char *name = PyString_AsString( value );
 | |
| 	//	if( !name )
 | |
| 	//		return EXPP_ReturnIntError( PyExc_TypeError,
 | |
| 	//				"expected string arg" );
 | |
| 	//
 | |
| 	//	BLI_strncpy( con->subtarget, name, sizeof( con->subtarget ) );
 | |
| 	//
 | |
| 	//	return 0;
 | |
| 	//	}
 | |
| 	case EXPP_CONSTR_SCRIPT: {
 | |
| 		Text *text = (( BPy_Text * )value)->text;
 | |
| 		if( !BPy_Object_Check( value ) )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 					"expected BPy text argument" );
 | |
| 		con->text = text;
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_PROPS:
 | |
| 		return EXPP_ReturnIntError( PyExc_RuntimeError,
 | |
| 					"setting ID-Properties of PyConstraints this way is not supported" );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| 
 | |
| static PyObject *rigidbody_getter( BPy_Constraint * self, int type)
 | |
| {
 | |
| 	bRigidBodyJointConstraint *con = (bRigidBodyJointConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET:
 | |
| 		return Object_CreatePyObject( con->tar );
 | |
| 	case EXPP_CONSTR_RB_PIVX:
 | |
| 		return PyFloat_FromDouble( (double)con->pivX );
 | |
| 	case EXPP_CONSTR_RB_PIVY:
 | |
| 		return PyFloat_FromDouble( (double)con->pivY );
 | |
| 	case EXPP_CONSTR_RB_PIVZ:
 | |
| 		return PyFloat_FromDouble( (double)con->pivZ );
 | |
| 	case EXPP_CONSTR_RB_AXX:
 | |
| 		return PyFloat_FromDouble( (double)con->axX );
 | |
| 	case EXPP_CONSTR_RB_AXY:
 | |
| 		return PyFloat_FromDouble( (double)con->axY );
 | |
| 	case EXPP_CONSTR_RB_AXZ:
 | |
| 		return PyFloat_FromDouble( (double)con->axZ );
 | |
| 	case EXPP_CONSTR_RB_MINLIMIT0:
 | |
| 		return PyFloat_FromDouble( (double)con->minLimit[0] );
 | |
| 	case EXPP_CONSTR_RB_MINLIMIT1:
 | |
| 		return PyFloat_FromDouble( (double)con->minLimit[1] );
 | |
| 	case EXPP_CONSTR_RB_MINLIMIT2:
 | |
| 		return PyFloat_FromDouble( (double)con->minLimit[2] );
 | |
| 	case EXPP_CONSTR_RB_MINLIMIT3:
 | |
| 		return PyFloat_FromDouble( (double)con->minLimit[3] );
 | |
| 	case EXPP_CONSTR_RB_MINLIMIT4:
 | |
| 		return PyFloat_FromDouble( (double)con->minLimit[4] );
 | |
| 	case EXPP_CONSTR_RB_MINLIMIT5:
 | |
| 		return PyFloat_FromDouble( (double)con->minLimit[5] );
 | |
| 	case EXPP_CONSTR_RB_MAXLIMIT0:
 | |
| 		return PyFloat_FromDouble( (double)con->maxLimit[0] );
 | |
| 	case EXPP_CONSTR_RB_MAXLIMIT1:
 | |
| 		return PyFloat_FromDouble( (double)con->maxLimit[1] );
 | |
| 	case EXPP_CONSTR_RB_MAXLIMIT2:
 | |
| 		return PyFloat_FromDouble( (double)con->maxLimit[2] );
 | |
| 	case EXPP_CONSTR_RB_MAXLIMIT3:
 | |
| 		return PyFloat_FromDouble( (double)con->maxLimit[3] );
 | |
| 	case EXPP_CONSTR_RB_MAXLIMIT4:
 | |
| 		return PyFloat_FromDouble( (double)con->maxLimit[4] );
 | |
| 	case EXPP_CONSTR_RB_MAXLIMIT5:
 | |
| 		return PyFloat_FromDouble( (double)con->maxLimit[5] );
 | |
| 	case EXPP_CONSTR_RB_EXTRAFZ:
 | |
| 		return PyFloat_FromDouble( (double)con->extraFz );		
 | |
| 	case EXPP_CONSTR_LIMIT:
 | |
| 		return PyInt_FromLong( (int)con->flag );
 | |
| 		
 | |
| 	case EXPP_CONSTR_RB_TYPE:
 | |
| 		return PyInt_FromLong( (int)con->type );
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );	
 | |
| 	}
 | |
| }
 | |
| 
 | |
| 
 | |
| static int rigidbody_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bRigidBodyJointConstraint *con = (bRigidBodyJointConstraint *)(self->con->data);	
 | |
| 	
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET: {
 | |
| 		Object *obj = (( BPy_Object * )value)->object;
 | |
| 		if( !BPy_Object_Check( value ) )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 					"expected BPy object argument" );
 | |
| 		con->tar = obj;
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_RB_PIVX:
 | |
| 		return EXPP_setFloatClamped( value, &con->pivX , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_PIVY:
 | |
| 		return EXPP_setFloatClamped( value, &con->pivY , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_PIVZ:
 | |
| 		return EXPP_setFloatClamped( value, &con->pivZ , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_AXX:
 | |
| 		return EXPP_setFloatClamped( value, &con->axX , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_AXY:
 | |
| 		return EXPP_setFloatClamped( value, &con->axY , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_AXZ:
 | |
| 		return EXPP_setFloatClamped( value, &con->axZ , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_MINLIMIT0:
 | |
| 		return EXPP_setFloatClamped( value, &con->minLimit[0] , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_MINLIMIT1:
 | |
| 		return EXPP_setFloatClamped( value, &con->minLimit[1] , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_MINLIMIT2:
 | |
| 		return EXPP_setFloatClamped( value, &con->minLimit[2] , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_MINLIMIT3:
 | |
| 		return EXPP_setFloatClamped( value, &con->minLimit[3] , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_MINLIMIT4:
 | |
| 		return EXPP_setFloatClamped( value, &con->minLimit[4] , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_MINLIMIT5:
 | |
| 		return EXPP_setFloatClamped( value, &con->minLimit[5] , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_MAXLIMIT0:
 | |
| 		return EXPP_setFloatClamped( value, &con->maxLimit[0] , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_MAXLIMIT1:
 | |
| 		return EXPP_setFloatClamped( value, &con->maxLimit[1] , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_MAXLIMIT2:
 | |
| 		return EXPP_setFloatClamped( value, &con->maxLimit[2] , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_MAXLIMIT3:
 | |
| 		return EXPP_setFloatClamped( value, &con->maxLimit[3] , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_MAXLIMIT4:
 | |
| 		return EXPP_setFloatClamped( value, &con->maxLimit[4] , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_MAXLIMIT5:
 | |
| 		return EXPP_setFloatClamped( value, &con->maxLimit[5] , -1000.0, 1000.0 );
 | |
| 	case EXPP_CONSTR_RB_EXTRAFZ:
 | |
| 		return EXPP_setFloatClamped( value, &con->extraFz , -1000.0, 1000.0 );						
 | |
| 	case EXPP_CONSTR_LIMIT:
 | |
| 		return EXPP_setIValueRange( value, &con->flag, 0, 
 | |
| 			LIMIT_XMIN | LIMIT_XMAX | LIMIT_YMIN | LIMIT_YMAX | LIMIT_ZMIN | LIMIT_ZMAX, 'i' );
 | |
| 	case EXPP_CONSTR_RB_TYPE:
 | |
| 		return EXPP_setIValueRange( value, &con->type, 0, 
 | |
| 			EXPP_CONSTR_RB_BALL | EXPP_CONSTR_RB_HINGE | EXPP_CONSTR_RB_GENERIC6DOF | EXPP_CONSTR_RB_VEHICLE, 'i' );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static PyObject *childof_getter( BPy_Constraint * self, int type )
 | |
| {
 | |
| 	bChildOfConstraint *con = (bChildOfConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET:
 | |
| 		return Object_CreatePyObject( con->tar );
 | |
| 	case EXPP_CONSTR_BONE:
 | |
| 		return PyString_FromString( con->subtarget );
 | |
| 	case EXPP_CONSTR_COPY:
 | |
| 		return PyInt_FromLong( (long)con->flag );
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int childof_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bChildOfConstraint *con = (bChildOfConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET: {
 | |
| 		Object *obj = (( BPy_Object * )value)->object;
 | |
| 		if( !BPy_Object_Check( value ) )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 					"expected BPy object argument" );
 | |
| 		con->tar = obj;
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_BONE: {
 | |
| 		char *name = PyString_AsString( value );
 | |
| 		if( !name )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError,
 | |
| 					"expected string arg" );
 | |
| 
 | |
| 		BLI_strncpy( con->subtarget, name, sizeof( con->subtarget ) );
 | |
| 
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_COPY:
 | |
| 		return EXPP_setIValueRange( value, &con->flag,
 | |
| 				0, CHILDOF_LOCX| CHILDOF_LOCY | CHILDOF_LOCZ | CHILDOF_ROTX | CHILDOF_ROTY | CHILDOF_ROTZ |
 | |
| 					CHILDOF_SIZEX |CHILDOF_SIZEY| CHILDOF_SIZEZ, 'i' );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static PyObject *transf_getter( BPy_Constraint * self, int type )
 | |
| {
 | |
| 	bTransformConstraint *con = (bTransformConstraint *)(self->con->data);
 | |
| 
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET:
 | |
| 		return Object_CreatePyObject( con->tar );
 | |
| 	case EXPP_CONSTR_BONE:
 | |
| 		return PyString_FromString( con->subtarget );
 | |
| 	case EXPP_CONSTR_FROM:
 | |
| 		return PyInt_FromLong( (long)con->from );
 | |
| 	case EXPP_CONSTR_TO:
 | |
| 		return PyInt_FromLong( (long)con->to );
 | |
| 	case EXPP_CONSTR_MAPX:
 | |
| 		return PyInt_FromLong( (long)con->map[0] );
 | |
| 	case EXPP_CONSTR_MAPY:
 | |
| 		return PyInt_FromLong( (long)con->map[1] );
 | |
| 	case EXPP_CONSTR_MAPZ:
 | |
| 		return PyInt_FromLong( (long)con->map[2] );
 | |
| 	case EXPP_CONSTR_FROMMINX:
 | |
| 		return PyFloat_FromDouble( (double)con->from_min[0] );
 | |
| 	case EXPP_CONSTR_FROMMAXX:
 | |
| 		return PyFloat_FromDouble( (double)con->from_max[0] );
 | |
| 	case EXPP_CONSTR_FROMMINY:
 | |
| 		return PyFloat_FromDouble( (double)con->from_min[1] );
 | |
| 	case EXPP_CONSTR_FROMMAXY:
 | |
| 		return PyFloat_FromDouble( (double)con->from_max[1] );
 | |
| 	case EXPP_CONSTR_FROMMINZ:
 | |
| 		return PyFloat_FromDouble( (double)con->from_min[2] );
 | |
| 	case EXPP_CONSTR_FROMMAXZ:
 | |
| 		return PyFloat_FromDouble( (double)con->from_max[2] );
 | |
| 	case EXPP_CONSTR_TOMINX:
 | |
| 		return PyFloat_FromDouble( (double)con->to_min[0] );
 | |
| 	case EXPP_CONSTR_TOMAXX:
 | |
| 		return PyFloat_FromDouble( (double)con->to_max[0] );
 | |
| 	case EXPP_CONSTR_TOMINY:
 | |
| 		return PyFloat_FromDouble( (double)con->to_min[1] );
 | |
| 	case EXPP_CONSTR_TOMAXY:
 | |
| 		return PyFloat_FromDouble( (double)con->to_max[1] );
 | |
| 	case EXPP_CONSTR_TOMINZ:
 | |
| 		return PyFloat_FromDouble( (double)con->to_min[2] );
 | |
| 	case EXPP_CONSTR_TOMAXZ:
 | |
| 		return PyFloat_FromDouble( (double)con->to_max[2] );
 | |
| 	case EXPP_CONSTR_EXPO:
 | |
| 		return PyBool_FromLong( (long)con->expo );
 | |
| 	default:
 | |
| 		return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int transf_setter( BPy_Constraint *self, int type, PyObject *value )
 | |
| {
 | |
| 	bTransformConstraint *con = (bTransformConstraint *)(self->con->data);
 | |
| 	float fmin, fmax, tmin, tmax;
 | |
| 	
 | |
| 	if (con->from == 2) {
 | |
| 		fmin = 0.0001;
 | |
| 		fmax = 1000.0;
 | |
| 	}
 | |
| 	else if (con->from == 1) {
 | |
| 		fmin = -360.0;
 | |
| 		fmax = 360.0;
 | |
| 	}
 | |
| 	else {
 | |
| 		fmin = -1000.0;
 | |
| 		fmax = 1000.0;
 | |
| 	}
 | |
| 	
 | |
| 	if (con->to == 2) {
 | |
| 		tmin = 0.0001;
 | |
| 		tmax = 1000.0;
 | |
| 	}
 | |
| 	else if (con->to == 1) {
 | |
| 		tmin = -360.0;
 | |
| 		tmax = 360.0;
 | |
| 	}
 | |
| 	else {
 | |
| 		tmin = -1000.0;
 | |
| 		tmax = 1000.0;
 | |
| 	}
 | |
| 	
 | |
| 	switch( type ) {
 | |
| 	case EXPP_CONSTR_TARGET: {
 | |
| 		Object *obj = (( BPy_Object * )value)->object;
 | |
| 		if( !BPy_Object_Check( value ) )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError, 
 | |
| 					"expected BPy object argument" );
 | |
| 		con->tar = obj;
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_BONE: {
 | |
| 		char *name = PyString_AsString( value );
 | |
| 		if( !name )
 | |
| 			return EXPP_ReturnIntError( PyExc_TypeError,
 | |
| 					"expected string arg" );
 | |
| 
 | |
| 		BLI_strncpy( con->subtarget, name, sizeof( con->subtarget ) );
 | |
| 
 | |
| 		return 0;
 | |
| 		}
 | |
| 	case EXPP_CONSTR_FROM:
 | |
| 		return EXPP_setIValueClamped( value, &con->from, 0, 3, 'h' );
 | |
| 	case EXPP_CONSTR_TO:
 | |
| 		return EXPP_setIValueClamped( value, &con->to, 0, 3, 'h' );
 | |
| 	case EXPP_CONSTR_MAPX:
 | |
| 		return EXPP_setIValueClamped( value, &con->map[0], 0, 3, 'h' );
 | |
| 	case EXPP_CONSTR_MAPY:
 | |
| 		return EXPP_setIValueClamped( value, &con->map[1], 0, 3, 'h' );
 | |
| 	case EXPP_CONSTR_MAPZ:
 | |
| 		return EXPP_setIValueClamped( value, &con->map[2], 0, 3, 'h' );
 | |
| 	case EXPP_CONSTR_FROMMINX:
 | |
| 		return EXPP_setFloatClamped( value, &con->from_min[0], fmin, fmax );
 | |
| 	case EXPP_CONSTR_FROMMAXX:
 | |
| 		return EXPP_setFloatClamped( value, &con->from_max[0], fmin, fmax );
 | |
| 	case EXPP_CONSTR_FROMMINY:
 | |
| 		return EXPP_setFloatClamped( value, &con->from_min[1], fmin, fmax );
 | |
| 	case EXPP_CONSTR_FROMMAXY:
 | |
| 		return EXPP_setFloatClamped( value, &con->from_max[1], fmin, fmax );
 | |
| 	case EXPP_CONSTR_FROMMINZ:
 | |
| 		return EXPP_setFloatClamped( value, &con->from_min[2], fmin, fmax );
 | |
| 	case EXPP_CONSTR_FROMMAXZ:
 | |
| 		return EXPP_setFloatClamped( value, &con->from_max[2], fmin, fmax );
 | |
| 	case EXPP_CONSTR_TOMINX:
 | |
| 		return EXPP_setFloatClamped( value, &con->to_min[0], tmin, tmax );
 | |
| 	case EXPP_CONSTR_TOMAXX:
 | |
| 		return EXPP_setFloatClamped( value, &con->to_max[0], tmin, tmax );
 | |
| 	case EXPP_CONSTR_TOMINY:
 | |
| 		return EXPP_setFloatClamped( value, &con->to_min[1], tmin, tmax );
 | |
| 	case EXPP_CONSTR_TOMAXY:
 | |
| 		return EXPP_setFloatClamped( value, &con->to_max[1], tmin, tmax );
 | |
| 	case EXPP_CONSTR_TOMINZ:
 | |
| 		return EXPP_setFloatClamped( value, &con->to_min[2], tmin, tmax );
 | |
| 	case EXPP_CONSTR_TOMAXZ:
 | |
| 		return EXPP_setFloatClamped( value, &con->to_max[2], tmin, tmax );
 | |
| 	case EXPP_CONSTR_EXPO:
 | |
| 		return EXPP_setBitfield( value, &con->expo, 1, 'h' );
 | |
| 	default:
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * get data from a constraint
 | |
|  */
 | |
| 
 | |
| static PyObject *Constraint_getData( BPy_Constraint * self, PyObject * key )
 | |
| {
 | |
| 	int setting;
 | |
| 
 | |
| 	if( !PyInt_Check( key ) )
 | |
| 		return EXPP_ReturnPyObjError( PyExc_TypeError,
 | |
| 				"expected an int arg" );
 | |
| 
 | |
| 	if( !self->con )
 | |
| 		return EXPP_ReturnPyObjError( PyExc_RuntimeError,
 | |
| 				"This constraint has been removed!" );
 | |
| 	
 | |
| 	setting = PyInt_AsLong( key );
 | |
| 	
 | |
| 	/* bypass doing settings of individual constraints, if we're just doing
 | |
| 	 * constraint space access-stuff 
 | |
| 	 */
 | |
| 	if ((setting==EXPP_CONSTR_OWNSPACE) || (setting==EXPP_CONSTR_TARSPACE)) {
 | |
| 		return constspace_getter( self, setting );
 | |
| 	}
 | |
| 	switch( self->con->type ) {
 | |
| 		case CONSTRAINT_TYPE_NULL:
 | |
| 			Py_RETURN_NONE;
 | |
| 		case CONSTRAINT_TYPE_TRACKTO:
 | |
| 			return trackto_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_KINEMATIC:
 | |
| 			return kinematic_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_FOLLOWPATH:
 | |
| 			return followpath_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_ACTION:
 | |
| 			return action_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_LOCKTRACK:
 | |
| 			return locktrack_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_STRETCHTO:
 | |
| 			return stretchto_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_MINMAX:
 | |
| 			return floor_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_LOCLIKE:
 | |
| 			return locatelike_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_ROTLIKE:
 | |
| 			return rotatelike_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_SIZELIKE:
 | |
| 			return sizelike_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_ROTLIMIT:
 | |
| 			return rotlimit_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_LOCLIMIT:
 | |
| 			return loclimit_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_SIZELIMIT:
 | |
| 			return sizelimit_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_RIGIDBODYJOINT:
 | |
| 			return rigidbody_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_CLAMPTO:
 | |
| 			return clampto_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_PYTHON:
 | |
| 			return script_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_CHILDOF:
 | |
| 			return childof_getter( self, setting );
 | |
| 		case CONSTRAINT_TYPE_TRANSFORM:
 | |
| 			return transf_getter( self, setting );
 | |
| 		default:
 | |
| 			return EXPP_ReturnPyObjError( PyExc_KeyError,
 | |
| 					"unknown constraint type" );
 | |
| 	}
 | |
| }
 | |
| 
 | |
| static int Constraint_setData( BPy_Constraint * self, PyObject * key, 
 | |
| 		PyObject * arg )
 | |
| {
 | |
| 	int key_int, result;
 | |
| 
 | |
| 	if( !PyNumber_Check( key ) )
 | |
| 		return EXPP_ReturnIntError( PyExc_TypeError,
 | |
| 				"expected an int arg" );
 | |
| 	if( !self->con )
 | |
| 		return EXPP_ReturnIntError( PyExc_RuntimeError,
 | |
| 				"This constraint has been removed!" );
 | |
| 	
 | |
| 	key_int = PyInt_AsLong( key );
 | |
| 	
 | |
| 	/* bypass doing settings of individual constraints, if we're just doing
 | |
| 	 * constraint space access-stuff 
 | |
| 	 */
 | |
| 	if ((key_int==EXPP_CONSTR_OWNSPACE) || (key_int==EXPP_CONSTR_TARSPACE)) {
 | |
| 		result = constspace_setter( self, key_int, arg );
 | |
| 	}
 | |
| 	else {
 | |
| 		switch( self->con->type ) {
 | |
| 		case CONSTRAINT_TYPE_KINEMATIC:
 | |
| 			result = kinematic_setter( self, key_int, arg );
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_ACTION:
 | |
| 			result = action_setter( self, key_int, arg );
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_TRACKTO:
 | |
| 			result = trackto_setter( self, key_int, arg );
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_STRETCHTO:
 | |
| 			result = stretchto_setter( self, key_int, arg );
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_FOLLOWPATH:
 | |
| 			result = followpath_setter( self, key_int, arg );
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_LOCKTRACK:
 | |
| 			result = locktrack_setter( self, key_int, arg );
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_MINMAX:
 | |
| 			result = floor_setter( self, key_int, arg );
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_LOCLIKE:
 | |
| 			result = locatelike_setter( self, key_int, arg );
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_ROTLIKE:
 | |
| 			result = rotatelike_setter( self, key_int, arg );
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_SIZELIKE:
 | |
| 			result = sizelike_setter( self, key_int, arg );
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_ROTLIMIT:
 | |
| 			result = rotlimit_setter( self, key_int, arg );
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_LOCLIMIT:
 | |
| 			result = loclimit_setter( self, key_int, arg );
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_SIZELIMIT:
 | |
| 			result = sizelimit_setter( self, key_int, arg);
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_RIGIDBODYJOINT:
 | |
| 			result = rigidbody_setter( self, key_int, arg);
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_CLAMPTO:
 | |
| 			result = clampto_setter( self, key_int, arg);
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_PYTHON:
 | |
| 			result = script_setter( self, key_int, arg);
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_CHILDOF:
 | |
| 			result = childof_setter( self, key_int, arg);
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_TRANSFORM:
 | |
| 			result = transf_setter( self, key_int, arg);
 | |
| 			break;
 | |
| 		case CONSTRAINT_TYPE_NULL:
 | |
| 			return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
 | |
| 		default:
 | |
| 			return EXPP_ReturnIntError( PyExc_RuntimeError,
 | |
| 					"unsupported constraint setting" );
 | |
| 		}
 | |
| 	}
 | |
| 	if( !result && self->pchan )
 | |
| 		update_pose_constraint_flags( self->obj->pose );
 | |
| 	return result;
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:    Constraint_compare                                           */
 | |
| /* Description: This compares 2 constraint python types, == or != only.      */
 | |
| /*****************************************************************************/
 | |
| static int Constraint_compare( BPy_Constraint * a, BPy_Constraint * b )
 | |
| {
 | |
| 	return ( a->con == b->con ) ? 0 : -1;
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:    Constraint_repr                                              */
 | |
| /* Description: This is a callback function for the BPy_Constraint type. It  */
 | |
| /*              builds a meaningful string to represent constraint objects.  */
 | |
| /*****************************************************************************/
 | |
| 
 | |
| static PyObject *Constraint_repr( BPy_Constraint * self )
 | |
| {
 | |
| 	bConstraintTypeInfo *cti;
 | |
| 
 | |
| 	if (!self->con)
 | |
| 		return PyString_FromString("[Constraint - Removed]");
 | |
| 	else
 | |
| 		cti= constraint_get_typeinfo(self->con);
 | |
| 	
 | |
| 	if (cti) {
 | |
| 		return PyString_FromFormat("[Constraint \"%s\", Type \"%s\"]",
 | |
| 				self->con->name, cti->name);
 | |
| 	}
 | |
| 	else {
 | |
| 		return PyString_FromString("[Constraint \"%s\", Type \"Unknown\"]");
 | |
| 	}
 | |
| }
 | |
| 
 | |
| /* Three Python Constraint_Type helper functions needed by the Object module: */
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:    Constraint_CreatePyObject                                    */
 | |
| /* Description: This function will create a new BPy_Constraint from an       */
 | |
| /*              existing Blender constraint structure.                       */
 | |
| /*****************************************************************************/
 | |
| PyObject *Constraint_CreatePyObject( bPoseChannel *pchan, Object *obj,
 | |
| 		bConstraint *con )
 | |
| {
 | |
| 	BPy_Constraint *pycon;
 | |
| 	pycon = ( BPy_Constraint * ) PyObject_NEW( BPy_Constraint,
 | |
| 			&Constraint_Type );
 | |
| 	if( !pycon )
 | |
| 		return EXPP_ReturnPyObjError( PyExc_MemoryError,
 | |
| 					      "couldn't create BPy_Constraint object" );
 | |
| 
 | |
| 	pycon->con = con;
 | |
| 
 | |
| 	/* one of these two will be NULL */
 | |
| 	pycon->obj = obj;	
 | |
| 	pycon->pchan = pchan;
 | |
| 	return ( PyObject * ) pycon;
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:    Constraint_FromPyObject                                      */
 | |
| /* Description: This function returns the Blender constraint from the given  */
 | |
| /*              PyObject.                                                    */
 | |
| /*****************************************************************************/
 | |
| bConstraint *Constraint_FromPyObject( BPy_Constraint * self )
 | |
| {
 | |
| 	return self->con;
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Constraint Sequence wrapper                                               */
 | |
| /*****************************************************************************/
 | |
| 
 | |
| /*
 | |
|  * Initialize the interator
 | |
|  */
 | |
| 
 | |
| static PyObject *ConstraintSeq_getIter( BPy_ConstraintSeq * self )
 | |
| {
 | |
| 	if( self->pchan )
 | |
| 		self->iter = (bConstraint *)self->pchan->constraints.first;
 | |
| 	else
 | |
| 		self->iter = (bConstraint *)self->obj->constraints.first;
 | |
| 	return EXPP_incr_ret ( (PyObject *) self );
 | |
| }
 | |
| 
 | |
| /*
 | |
|  * Get the next Constraint
 | |
|  */
 | |
| 
 | |
| static PyObject *ConstraintSeq_nextIter( BPy_ConstraintSeq * self )
 | |
| {
 | |
| 	bConstraint *this = self->iter;
 | |
| 	if( this ) {
 | |
| 		self->iter = this->next;
 | |
| 		return Constraint_CreatePyObject( self->pchan, self->obj, this );
 | |
| 	}
 | |
| 
 | |
| 	return EXPP_ReturnPyObjError( PyExc_StopIteration,
 | |
| 			"iterator at end" );
 | |
| }
 | |
| 
 | |
| /* return the number of constraints */
 | |
| 
 | |
| static int ConstraintSeq_length( BPy_ConstraintSeq * self )
 | |
| {
 | |
| 	return BLI_countlist( self->pchan ?
 | |
| 		&self->pchan->constraints : &self->obj->constraints );
 | |
| }
 | |
| 
 | |
| /* return a constraint */
 | |
| 
 | |
| static PyObject *ConstraintSeq_item( BPy_ConstraintSeq * self, int i )
 | |
| {
 | |
| 	bConstraint *con = NULL;
 | |
| 
 | |
| 	/* if index is negative, start counting from the end of the list */
 | |
| 	if( i < 0 )
 | |
| 		i += ConstraintSeq_length( self );
 | |
| 
 | |
| 	/* skip through the list until we get the constraint or end of list */
 | |
| 
 | |
| 	if( self->pchan )
 | |
| 		con = self->pchan->constraints.first;
 | |
| 	else
 | |
| 		con = self->obj->constraints.first;
 | |
| 
 | |
| 	while( i && con ) {
 | |
| 		--i;
 | |
| 		con = con->next;
 | |
| 	}
 | |
| 
 | |
| 	if( con )
 | |
| 		return Constraint_CreatePyObject( self->pchan, self->obj, con );
 | |
| 	else
 | |
| 		return EXPP_ReturnPyObjError( PyExc_IndexError,
 | |
| 				"array index out of range" );
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python BPy_ConstraintSeq sequence table:                                  */
 | |
| /*****************************************************************************/
 | |
| static PySequenceMethods ConstraintSeq_as_sequence = {
 | |
| 	( inquiry ) ConstraintSeq_length,	/* sq_length */
 | |
| 	( binaryfunc ) 0,	/* sq_concat */
 | |
| 	( intargfunc ) 0,	/* sq_repeat */
 | |
| 	( intargfunc ) ConstraintSeq_item,	/* sq_item */
 | |
| 	( intintargfunc ) 0,	/* sq_slice */
 | |
| 	( intobjargproc ) 0,	/* sq_ass_item */
 | |
| 	( intintobjargproc ) 0,	/* sq_ass_slice */
 | |
| 	( objobjproc ) 0,	/* sq_contains */
 | |
| 	( binaryfunc ) 0,		/* sq_inplace_concat */
 | |
| 	( intargfunc ) 0,		/* sq_inplace_repeat */
 | |
| };
 | |
| 
 | |
| /*
 | |
|  * helper function to check for a valid constraint argument
 | |
|  */
 | |
| 
 | |
| static bConstraint *locate_constr( BPy_ConstraintSeq *self, BPy_Constraint * value )
 | |
| {
 | |
| 	bConstraint *con;
 | |
| 
 | |
| 	/* check that argument is a modifier */
 | |
| 	if (!BPy_Constraint_Check(value))
 | |
| 		return (bConstraint *)EXPP_ReturnPyObjError( PyExc_TypeError,
 | |
| 				"expected a constraint as an argument" );
 | |
| 
 | |
| 	/* check whether constraint has been removed */
 | |
| 	if( !value->con )
 | |
| 		return (bConstraint *)EXPP_ReturnPyObjError( PyExc_RuntimeError,
 | |
| 				"This constraint has been removed!" );
 | |
| 
 | |
| 	/* verify the constraint is still exists in the stack */
 | |
| 	if( self->pchan )
 | |
| 		con = self->pchan->constraints.first;
 | |
| 	else
 | |
| 		con = self->obj->constraints.first;
 | |
| 	while( con && con != value->con )
 | |
| 	   	con = con->next;
 | |
| 
 | |
| 	/* if we didn't find it, exception */
 | |
| 	if( !con )
 | |
| 		return (bConstraint *)EXPP_ReturnPyObjError( PyExc_AttributeError,
 | |
| 				"This constraint is no longer in the object's stack" );
 | |
| 
 | |
| 	return con;
 | |
| }
 | |
| 
 | |
| 
 | |
| /* create a new constraint at the end of the list */
 | |
| 
 | |
| static PyObject *ConstraintSeq_append( BPy_ConstraintSeq *self, PyObject *value )
 | |
| {
 | |
| 	int type = (int)PyInt_AsLong(value);
 | |
| 	bConstraint *con;
 | |
| 
 | |
| 	/* type 0 is CONSTRAINT_TYPE_NULL, should we be able to add one of these?
 | |
| 	 * if the value is not an int it will be -1 */
 | |
| 	if( type < CONSTRAINT_TYPE_NULL || type > CONSTRAINT_TYPE_RIGIDBODYJOINT ) 
 | |
| 		return EXPP_ReturnPyObjError( PyExc_ValueError,
 | |
| 				"arg not in int or out of range" );
 | |
| 
 | |
| 	con = add_new_constraint( type );
 | |
| 	if( self->pchan ) {
 | |
| 		BLI_addtail( &self->pchan->constraints, con );
 | |
| 		update_pose_constraint_flags( self->obj->pose );
 | |
| 	}
 | |
| 	else
 | |
| 		BLI_addtail( &self->obj->constraints, con );
 | |
| 
 | |
| 	return Constraint_CreatePyObject( self->pchan, self->obj, con );
 | |
| }
 | |
| 
 | |
| /* move the constraint up in the stack */
 | |
| 
 | |
| static PyObject *ConstraintSeq_moveUp( BPy_ConstraintSeq *self, BPy_Constraint *value )
 | |
| {
 | |
| 	bConstraint *con = locate_constr( self,  value );
 | |
| 
 | |
| 	/* if we can't locate the constraint, return (exception already set) */
 | |
| 	if( !con )
 | |
| 		return (PyObject *)NULL;
 | |
| 
 | |
| 	const_moveUp( self->obj, con );
 | |
| 	Py_RETURN_NONE;
 | |
| }
 | |
| 
 | |
| /* move the constraint down in the stack */
 | |
| 
 | |
| static PyObject *ConstraintSeq_moveDown( BPy_ConstraintSeq *self, BPy_Constraint *value )
 | |
| {
 | |
| 	bConstraint *con = locate_constr( self,  value );
 | |
| 
 | |
| 	/* if we can't locate the constraint, return (exception already set) */
 | |
| 	if( !con )
 | |
| 		return (PyObject *)NULL;
 | |
| 
 | |
| 	const_moveDown( self->obj, con );
 | |
| 	Py_RETURN_NONE;
 | |
| }
 | |
| 
 | |
| /* remove an existing constraint */
 | |
| 
 | |
| static PyObject *ConstraintSeq_remove( BPy_ConstraintSeq *self, BPy_Constraint *value )
 | |
| {
 | |
| 	bConstraint *con = locate_constr( self,  value );
 | |
| 
 | |
| 	/* if we can't locate the constraint, return (exception already set) */
 | |
| 	if( !con )
 | |
| 		return (PyObject *)NULL;
 | |
| 
 | |
| 	/* do the actual removal */
 | |
| 	if( self->pchan )
 | |
| 		BLI_remlink( &self->pchan->constraints, con );
 | |
| 	else
 | |
| 		BLI_remlink( &self->obj->constraints, con);
 | |
| 	del_constr_func( self->obj, con );
 | |
| 
 | |
| 	/* erase the link to the constraint */
 | |
| 	value->con = NULL;
 | |
| 
 | |
| 	Py_RETURN_NONE;
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:    ConstraintSeq_dealloc                                        */
 | |
| /* Description: This is a callback function for the BPy_ConstraintSeq type.  */
 | |
| /*              It destroys data when the object is deleted.                 */
 | |
| /*****************************************************************************/
 | |
| static void ConstraintSeq_dealloc( BPy_Constraint * self )
 | |
| {
 | |
| 	PyObject_DEL( self );
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python BPy_ConstraintSeq methods table:                                   */
 | |
| /*****************************************************************************/
 | |
| static PyMethodDef BPy_ConstraintSeq_methods[] = {
 | |
| 	/* name, method, flags, doc */
 | |
| 	{"append", ( PyCFunction ) ConstraintSeq_append, METH_O,
 | |
| 	 "(type) - add a new constraint, where type is the constraint type"},
 | |
| 	{"remove", ( PyCFunction ) ConstraintSeq_remove, METH_O,
 | |
| 	 "(con) - remove an existing constraint, where con is a constraint from this object."},
 | |
| 	{"moveUp", ( PyCFunction ) ConstraintSeq_moveUp, METH_O,
 | |
| 	 "(con) - Move constraint up in stack"},
 | |
| 	{"moveDown", ( PyCFunction ) ConstraintSeq_moveDown, METH_O,
 | |
| 	 "(con) - Move constraint down in stack"},
 | |
| 	{NULL, NULL, 0, NULL}
 | |
| };
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python ConstraintSeq_Type structure definition:                           */
 | |
| /*****************************************************************************/
 | |
| PyTypeObject ConstraintSeq_Type = {
 | |
| 	PyObject_HEAD_INIT( NULL )  /* required py macro */
 | |
| 	0,                          /* ob_size */
 | |
| 	/*  For printing, in format "<module>.<name>" */
 | |
| 	"Blender.Constraints",      /* char *tp_name; */
 | |
| 	sizeof( BPy_ConstraintSeq ),     /* int tp_basicsize; */
 | |
| 	0,                          /* tp_itemsize;  For allocation */
 | |
| 
 | |
| 	/* Methods to implement standard operations */
 | |
| 
 | |
| 	( destructor ) ConstraintSeq_dealloc,/* destructor tp_dealloc; */
 | |
| 	NULL,                       /* printfunc tp_print; */
 | |
| 	NULL,                       /* getattrfunc tp_getattr; */
 | |
| 	NULL,                       /* setattrfunc tp_setattr; */
 | |
| 	NULL,                       /* cmpfunc tp_compare; */
 | |
| 	( reprfunc ) NULL,          /* reprfunc tp_repr; */
 | |
| 
 | |
| 	/* Method suites for standard classes */
 | |
| 
 | |
| 	NULL,                       /* PyNumberMethods *tp_as_number; */
 | |
| 	&ConstraintSeq_as_sequence,        /* PySequenceMethods *tp_as_sequence; */
 | |
| 	NULL,                       /* PyMappingMethods *tp_as_mapping; */
 | |
| 
 | |
| 	/* More standard operations (here for binary compatibility) */
 | |
| 
 | |
| 	NULL,                       /* hashfunc tp_hash; */
 | |
| 	NULL,                       /* ternaryfunc tp_call; */
 | |
| 	NULL,                       /* reprfunc tp_str; */
 | |
| 	NULL,                       /* getattrofunc tp_getattro; */
 | |
| 	NULL,                       /* setattrofunc tp_setattro; */
 | |
| 
 | |
| 	/* Functions to access object as input/output buffer */
 | |
| 	NULL,                       /* PyBufferProcs *tp_as_buffer; */
 | |
| 
 | |
|   /*** Flags to define presence of optional/expanded features ***/
 | |
| 	Py_TPFLAGS_DEFAULT,         /* long tp_flags; */
 | |
| 
 | |
| 	NULL,                       /*  char *tp_doc;  Documentation string */
 | |
|   /*** Assigned meaning in release 2.0 ***/
 | |
| 	/* call function for all accessible objects */
 | |
| 	NULL,                       /* traverseproc tp_traverse; */
 | |
| 
 | |
| 	/* delete references to contained objects */
 | |
| 	NULL,                       /* inquiry tp_clear; */
 | |
| 
 | |
|   /***  Assigned meaning in release 2.1 ***/
 | |
|   /*** rich comparisons ***/
 | |
| 	NULL,                       /* richcmpfunc tp_richcompare; */
 | |
| 
 | |
|   /***  weak reference enabler ***/
 | |
| 	0,                          /* long tp_weaklistoffset; */
 | |
| 
 | |
|   /*** Added in release 2.2 ***/
 | |
| 	/*   Iterators */
 | |
| 	( getiterfunc )ConstraintSeq_getIter, /* getiterfunc tp_iter; */
 | |
|     ( iternextfunc )ConstraintSeq_nextIter, /* iternextfunc tp_iternext; */
 | |
| 
 | |
|   /*** Attribute descriptor and subclassing stuff ***/
 | |
| 	BPy_ConstraintSeq_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; */
 | |
| 	NULL,                       /* initproc tp_init; */
 | |
| 	NULL,                       /* allocfunc tp_alloc; */
 | |
| 	NULL,                       /* newfunc tp_new; */
 | |
| 	/*  Low-level free-memory routine */
 | |
| 	NULL,                       /* freefunc tp_free;  */
 | |
| 	/* For PyObject_IS_GC */
 | |
| 	NULL,                       /* inquiry tp_is_gc;  */
 | |
| 	NULL,                       /* PyObject *tp_bases; */
 | |
| 	/* method resolution order */
 | |
| 	NULL,                       /* PyObject *tp_mro;  */
 | |
| 	NULL,                       /* PyObject *tp_cache; */
 | |
| 	NULL,                       /* PyObject *tp_subclasses; */
 | |
| 	NULL,                       /* PyObject *tp_weaklist; */
 | |
| 	NULL
 | |
| };
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:    PoseConstraintSeq_CreatePyObject                             */
 | |
| /* Description: This function will create a new BPy_ConstraintSeq from an    */
 | |
| /*              existing ListBase structure.                                 */
 | |
| /*****************************************************************************/
 | |
| PyObject *PoseConstraintSeq_CreatePyObject( bPoseChannel *pchan )
 | |
| {
 | |
| 	BPy_ConstraintSeq *pyseq;
 | |
| 	Object *ob;
 | |
| 
 | |
| 	for( ob = G.main->object.first; ob; ob = ob->id.next ) {
 | |
| 		if( ob->type == OB_ARMATURE ) {
 | |
| 			bPoseChannel *p = ob->pose->chanbase.first;
 | |
| 			while( p ) {
 | |
| 				if( p == pchan ) {
 | |
| 					pyseq = ( BPy_ConstraintSeq * ) PyObject_NEW( 
 | |
| 							BPy_ConstraintSeq, &ConstraintSeq_Type );
 | |
| 					if( !pyseq )
 | |
| 						return EXPP_ReturnPyObjError( PyExc_MemoryError,
 | |
| 								"couldn't create BPy_ConstraintSeq object" );
 | |
| 					pyseq->pchan = pchan;
 | |
| 					pyseq->obj = ob;
 | |
| 					return ( PyObject * ) pyseq;
 | |
| 				} else
 | |
| 					p = p->next;
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| 	return EXPP_ReturnPyObjError( PyExc_RuntimeError,
 | |
| 			"couldn't find ANY armature with the pose!" );
 | |
| 
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:    ObConstraintSeq_CreatePyObject                               */
 | |
| /* Description: This function will create a new BPy_ConstraintSeq from an    */
 | |
| /*              existing ListBase structure.                                 */
 | |
| /*****************************************************************************/
 | |
| PyObject *ObConstraintSeq_CreatePyObject( Object *obj )
 | |
| {
 | |
| 	BPy_ConstraintSeq *pyseq;
 | |
| 	pyseq = ( BPy_ConstraintSeq * ) PyObject_NEW( BPy_ConstraintSeq,
 | |
| 			&ConstraintSeq_Type );
 | |
| 	if( !pyseq )
 | |
| 		return EXPP_ReturnPyObjError( PyExc_MemoryError,
 | |
| 					      "couldn't create BPy_ConstraintSeq object" );
 | |
| 	pyseq->obj = obj;
 | |
| 	pyseq->pchan = NULL;
 | |
| 	return ( PyObject * ) pyseq;
 | |
| }
 | |
| 
 | |
| static PyObject *M_Constraint_TypeDict( void )
 | |
| {
 | |
| 	PyObject *S = PyConstant_New(  );
 | |
| 
 | |
| 	if( S ) {
 | |
| 		BPy_constant *d = ( BPy_constant * ) S;
 | |
| 		PyConstant_Insert( d, "NULL", 
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_NULL ) );
 | |
| 		PyConstant_Insert( d, "TRACKTO",
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_TRACKTO ) );
 | |
| 		PyConstant_Insert( d, "IKSOLVER", 
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_KINEMATIC ) );
 | |
| 		PyConstant_Insert( d, "FOLLOWPATH", 
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_FOLLOWPATH ) );
 | |
| 		PyConstant_Insert( d, "COPYROT", 
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_ROTLIKE ) );
 | |
| 		PyConstant_Insert( d, "COPYLOC", 
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_LOCLIKE ) );
 | |
| 		PyConstant_Insert( d, "COPYSIZE", 
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_SIZELIKE ) );
 | |
| 		PyConstant_Insert( d, "ACTION", 
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_ACTION ) );
 | |
| 		PyConstant_Insert( d, "LOCKTRACK", 
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_LOCKTRACK ) );
 | |
| 		PyConstant_Insert( d, "STRETCHTO", 
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_STRETCHTO ) );
 | |
| 		PyConstant_Insert( d, "FLOOR", 
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_MINMAX ) );
 | |
| 		PyConstant_Insert( d, "LIMITLOC", 
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_LOCLIMIT ) );
 | |
| 		PyConstant_Insert( d, "LIMITROT", 
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_ROTLIMIT ) );
 | |
| 		PyConstant_Insert( d, "LIMITSIZE", 
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_SIZELIMIT ) );
 | |
| 		PyConstant_Insert( d, "RIGIDBODYJOINT", 
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_RIGIDBODYJOINT ) );
 | |
| 		PyConstant_Insert( d, "CLAMPTO", 
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_CLAMPTO ) );
 | |
| 		PyConstant_Insert( d, "PYTHON",
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_PYTHON ) );
 | |
| 		PyConstant_Insert( d, "CHILDOF",
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_CHILDOF ) );
 | |
| 		PyConstant_Insert( d, "TRANSFORM",
 | |
| 				PyInt_FromLong( CONSTRAINT_TYPE_TRANSFORM ) );
 | |
| 	}
 | |
| 	return S;
 | |
| }
 | |
| 
 | |
| static PyObject *M_Constraint_SettingsDict( void )
 | |
| {
 | |
| 	PyObject *S = PyConstant_New(  );
 | |
| 	
 | |
| 	if( S ) {
 | |
| 		BPy_constant *d = ( BPy_constant * ) S;
 | |
| 		PyConstant_Insert( d, "XROT",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_XROT ) );
 | |
| 		PyConstant_Insert( d, "YROT",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_YROT ) );
 | |
| 		PyConstant_Insert( d, "ZROT",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_ZROT ) );
 | |
| 		PyConstant_Insert( d, "XSIZE",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_XSIZE ) );
 | |
| 		PyConstant_Insert( d, "YSIZE",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_YSIZE ) );
 | |
| 		PyConstant_Insert( d, "ZSIZE",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_ZSIZE ) );
 | |
| 		PyConstant_Insert( d, "XLOC",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_XLOC ) );
 | |
| 		PyConstant_Insert( d, "YLOC",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_YLOC ) );
 | |
| 		PyConstant_Insert( d, "ZLOC",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_ZLOC ) );
 | |
| 
 | |
| 		PyConstant_Insert( d, "UPX",
 | |
| 				PyInt_FromLong( UP_X ) );
 | |
| 		PyConstant_Insert( d, "UPY",
 | |
| 				PyInt_FromLong( UP_Y ) );
 | |
| 		PyConstant_Insert( d, "UPZ",
 | |
| 				PyInt_FromLong( UP_Z ) );
 | |
| 
 | |
| 		PyConstant_Insert( d, "TRACKX",
 | |
| 				PyInt_FromLong( TRACK_X ) );
 | |
| 		PyConstant_Insert( d, "TRACKY",
 | |
| 				PyInt_FromLong( TRACK_Y ) );
 | |
| 		PyConstant_Insert( d, "TRACKZ",
 | |
| 				PyInt_FromLong( TRACK_Z ) );
 | |
| 		PyConstant_Insert( d, "TRACKNEGX",
 | |
| 				PyInt_FromLong( TRACK_nX ) );
 | |
| 		PyConstant_Insert( d, "TRACKNEGY",
 | |
| 				PyInt_FromLong( TRACK_nY ) );
 | |
| 		PyConstant_Insert( d, "TRACKNEGZ",
 | |
| 				PyInt_FromLong( TRACK_nZ ) );
 | |
| 
 | |
| 		PyConstant_Insert( d, "VOLUMEXZ",
 | |
| 				PyInt_FromLong( VOLUME_XZ ) );
 | |
| 		PyConstant_Insert( d, "VOLUMEX",
 | |
| 				PyInt_FromLong( VOLUME_X ) );
 | |
| 		PyConstant_Insert( d, "VOLUMEZ",
 | |
| 				PyInt_FromLong( VOLUME_Z ) );
 | |
| 		PyConstant_Insert( d, "VOLUMENONE",
 | |
| 				PyInt_FromLong( NO_VOLUME ) );
 | |
| 
 | |
| 		PyConstant_Insert( d, "PLANEX",
 | |
| 				PyInt_FromLong( PLANE_X ) );
 | |
| 		PyConstant_Insert( d, "PLANEY",
 | |
| 				PyInt_FromLong( PLANE_Y ) );
 | |
| 		PyConstant_Insert( d, "PLANEZ",
 | |
| 				PyInt_FromLong( PLANE_Z ) );
 | |
| 
 | |
| 		PyConstant_Insert( d, "LOCKX",
 | |
| 				PyInt_FromLong( LOCK_X ) );
 | |
| 		PyConstant_Insert( d, "LOCKY",
 | |
| 				PyInt_FromLong( LOCK_Y ) );
 | |
| 		PyConstant_Insert( d, "LOCKZ",
 | |
| 				PyInt_FromLong( LOCK_Z ) );
 | |
| 
 | |
| 		PyConstant_Insert( d, "MAXX",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_MAXX ) );
 | |
| 		PyConstant_Insert( d, "MAXY",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_MAXY ) );
 | |
| 		PyConstant_Insert( d, "MAXZ",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_MAXZ ) );
 | |
| 		PyConstant_Insert( d, "MINX",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_MINX ) );
 | |
| 		PyConstant_Insert( d, "MINY",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_MINY ) );
 | |
| 		PyConstant_Insert( d, "MINZ",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_MINZ ) );
 | |
| 
 | |
| 		PyConstant_Insert( d, "COPYX",
 | |
| 				PyInt_FromLong( LOCLIKE_X ) );
 | |
| 		PyConstant_Insert( d, "COPYY",
 | |
| 				PyInt_FromLong( LOCLIKE_Y ) );
 | |
| 		PyConstant_Insert( d, "COPYZ",
 | |
| 				PyInt_FromLong( LOCLIKE_Z ) );
 | |
| 		PyConstant_Insert( d, "COPYXINVERT",
 | |
| 				PyInt_FromLong( LOCLIKE_X_INVERT ) );
 | |
| 		PyConstant_Insert( d, "COPYYINVERT",
 | |
| 				PyInt_FromLong( LOCLIKE_Y_INVERT ) );
 | |
| 		PyConstant_Insert( d, "COPYZINVERT",
 | |
| 				PyInt_FromLong( LOCLIKE_Z_INVERT ) );
 | |
| 				
 | |
| 		PyConstant_Insert( d, "PARLOCX",
 | |
| 				PyInt_FromLong( CHILDOF_LOCX ) );
 | |
| 		PyConstant_Insert( d, "PARLOCY",
 | |
| 				PyInt_FromLong( CHILDOF_LOCY ) );
 | |
| 		PyConstant_Insert( d, "PARLOCZ",
 | |
| 				PyInt_FromLong( CHILDOF_LOCZ ) );
 | |
| 		PyConstant_Insert( d, "PARROTX",
 | |
| 				PyInt_FromLong( CHILDOF_ROTX ) );
 | |
| 		PyConstant_Insert( d, "PARROTY",
 | |
| 				PyInt_FromLong( CHILDOF_ROTY ) );
 | |
| 		PyConstant_Insert( d, "PARROTZ",
 | |
| 				PyInt_FromLong( CHILDOF_ROTZ ) );
 | |
| 		PyConstant_Insert( d, "PARSIZEX",
 | |
| 				PyInt_FromLong( CHILDOF_LOCX ) );
 | |
| 		PyConstant_Insert( d, "PARSIZEY",
 | |
| 				PyInt_FromLong( CHILDOF_SIZEY ) );
 | |
| 		PyConstant_Insert( d, "PARSIZEZ",
 | |
| 				PyInt_FromLong( CHILDOF_SIZEZ ) );
 | |
| 				
 | |
| 		PyConstant_Insert( d, "CLAMPAUTO",
 | |
| 				PyInt_FromLong( CLAMPTO_AUTO ) );
 | |
| 		PyConstant_Insert( d, "CLAMPX",
 | |
| 				PyInt_FromLong( CLAMPTO_X ) );
 | |
| 		PyConstant_Insert( d, "CLAMPY",
 | |
| 				PyInt_FromLong( CLAMPTO_Y ) );
 | |
| 		PyConstant_Insert( d, "CLAMPZ",
 | |
| 				PyInt_FromLong( CLAMPTO_Z ) );
 | |
| 		PyConstant_Insert( d, "CLAMPCYCLIC",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_CLAMPCYCLIC ));
 | |
| 
 | |
| 		PyConstant_Insert( d, "TARGET",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_TARGET ) );
 | |
| 		PyConstant_Insert( d, "STRETCH", 
 | |
| 				PyInt_FromLong( EXPP_CONSTR_STRETCH ) );
 | |
| 		PyConstant_Insert( d, "ITERATIONS", 
 | |
| 				PyInt_FromLong( EXPP_CONSTR_ITERATIONS ) );
 | |
| 		PyConstant_Insert( d, "BONE", 
 | |
| 				PyInt_FromLong( EXPP_CONSTR_BONE ) );
 | |
| 		PyConstant_Insert( d, "CHAINLEN", 
 | |
| 				PyInt_FromLong( EXPP_CONSTR_CHAINLEN ) );
 | |
| 		PyConstant_Insert( d, "POSWEIGHT", 
 | |
| 				PyInt_FromLong( EXPP_CONSTR_POSWEIGHT ) );
 | |
| 		PyConstant_Insert( d, "ROTWEIGHT", 
 | |
| 				PyInt_FromLong( EXPP_CONSTR_ROTWEIGHT ) );
 | |
| 		PyConstant_Insert( d, "ROTATE", 
 | |
| 				PyInt_FromLong( EXPP_CONSTR_ROTATE ) );
 | |
| 		PyConstant_Insert( d, "USETIP", 
 | |
| 				PyInt_FromLong( EXPP_CONSTR_USETIP ) );
 | |
| 
 | |
| 		PyConstant_Insert( d, "ACTION", 
 | |
| 				PyInt_FromLong( EXPP_CONSTR_ACTION ) );
 | |
| 		PyConstant_Insert( d, "START", 
 | |
| 				PyInt_FromLong( EXPP_CONSTR_START ) );
 | |
| 		PyConstant_Insert( d, "END", 
 | |
| 				PyInt_FromLong( EXPP_CONSTR_END ) );
 | |
| 		PyConstant_Insert( d, "MIN", 
 | |
| 				PyInt_FromLong( EXPP_CONSTR_MIN ) );
 | |
| 		PyConstant_Insert( d, "MAX", 
 | |
| 				PyInt_FromLong( EXPP_CONSTR_MAX ) );
 | |
| 		PyConstant_Insert( d, "KEYON", 
 | |
| 				PyInt_FromLong( EXPP_CONSTR_KEYON ) );
 | |
| 
 | |
| 		PyConstant_Insert( d, "TRACK", 
 | |
| 				PyInt_FromLong( EXPP_CONSTR_TRACK ) );
 | |
| 		PyConstant_Insert( d, "UP", 
 | |
| 				PyInt_FromLong( EXPP_CONSTR_UP ) );
 | |
| 
 | |
| 		PyConstant_Insert( d, "RESTLENGTH",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RESTLENGTH ) );
 | |
| 		PyConstant_Insert( d, "VOLVARIATION",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_VOLVARIATION ) );
 | |
| 		PyConstant_Insert( d, "VOLUMEMODE",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_VOLUMEMODE ) );
 | |
| 		PyConstant_Insert( d, "PLANE",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_PLANE ) );
 | |
| 
 | |
| 		PyConstant_Insert( d, "FOLLOW",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_FOLLOW ) );
 | |
| 		PyConstant_Insert( d, "OFFSET",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_OFFSET ) );
 | |
| 		PyConstant_Insert( d, "FORWARD",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_FORWARD ) );
 | |
| 
 | |
| 		PyConstant_Insert( d, "LOCK",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_LOCK ) );
 | |
| 
 | |
| 		PyConstant_Insert( d, "COPY",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_COPY ) );
 | |
| 		PyConstant_Insert( d, "LIMIT",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_LIMIT ) );
 | |
| 		PyConstant_Insert( d, "CLAMP",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_CLAMP ) );
 | |
| 		
 | |
| 		PyConstant_Insert( d, "LIMIT_XMIN",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_LIMXMIN ) );
 | |
| 		PyConstant_Insert( d, "LIMIT_XMAX",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_LIMXMAX ) );
 | |
| 		PyConstant_Insert( d, "LIMIT_YMIN",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_LIMYMIN ) );
 | |
| 		PyConstant_Insert( d, "LIMIT_YMAX",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_LIMYMAX ) );
 | |
| 		PyConstant_Insert( d, "LIMIT_ZMIN",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_LIMZMIN ) );
 | |
| 		PyConstant_Insert( d, "LIMIT_ZMAX",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_LIMZMAX ) );
 | |
| 		
 | |
| 		PyConstant_Insert( d, "LIMIT_XROT",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_LIMXROT ) );
 | |
| 		PyConstant_Insert( d, "LIMIT_YROT",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_LIMYROT ) );
 | |
| 		PyConstant_Insert( d, "LIMIT_ZROT",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_LIMZROT ) );
 | |
| 		
 | |
| 		PyConstant_Insert( d, "XMIN",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_XMIN ) );
 | |
| 		PyConstant_Insert( d, "XMAX",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_XMAX ) );
 | |
| 		PyConstant_Insert( d, "YMIN",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_YMIN ) );
 | |
| 		PyConstant_Insert( d, "YMAX",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_YMAX ) );
 | |
| 		PyConstant_Insert( d, "ZMIN",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_ZMIN ) );
 | |
| 		PyConstant_Insert( d, "ZMAX",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_ZMAX ) );
 | |
| 				
 | |
| 		PyConstant_Insert( d, "SCRIPT",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_SCRIPT ) );
 | |
| 		PyConstant_Insert( d, "PROPERTIES",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_PROPS ) );
 | |
| 				
 | |
| 		PyConstant_Insert( d, "FROM",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_FROM ) );
 | |
| 		PyConstant_Insert( d, "TO",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_TO ) );
 | |
| 		PyConstant_Insert( d, "EXTRAPOLATE",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_EXPO ) );
 | |
| 		PyConstant_Insert( d, "MAPX",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_MAPX ) );
 | |
| 		PyConstant_Insert( d, "MAPY",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_MAPY ) );
 | |
| 		PyConstant_Insert( d, "MAPZ",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_MAPZ ) );
 | |
| 		PyConstant_Insert( d, "FROM_MINX",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_FROMMINX ) );
 | |
| 		PyConstant_Insert( d, "FROM_MAXX",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_FROMMAXX ) );
 | |
| 		PyConstant_Insert( d, "FROM_MINY",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_FROMMINY ) );
 | |
| 		PyConstant_Insert( d, "FROM_MAXY",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_FROMMAXY ) );
 | |
| 		PyConstant_Insert( d, "FROM_MINZ",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_FROMMINZ ) );
 | |
| 		PyConstant_Insert( d, "FROM_MAXZ",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_FROMMAXZ ) );
 | |
| 		PyConstant_Insert( d, "TO_MINX",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_TOMINX ) );
 | |
| 		PyConstant_Insert( d, "TO_MAXX",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_TOMAXX ) );
 | |
| 		PyConstant_Insert( d, "TO_MINY",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_TOMINY ) );
 | |
| 		PyConstant_Insert( d, "TO_MAXY",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_TOMAXY ) );
 | |
| 		PyConstant_Insert( d, "TO_MINZ",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_TOMINZ ) );
 | |
| 		PyConstant_Insert( d, "TO_MAXZ",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_TOMAXZ ) );
 | |
| 				
 | |
| 		PyConstant_Insert( d, "LOC",
 | |
| 				PyInt_FromLong( 0 ) );
 | |
| 		PyConstant_Insert( d, "ROT",
 | |
| 				PyInt_FromLong( 1 ) );
 | |
| 		PyConstant_Insert( d, "SCALE",
 | |
| 				PyInt_FromLong( 2 ) );
 | |
| 				
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_TYPE",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_TYPE ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_BALL",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_BALL ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_HINGE",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_HINGE ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_GENERIC6DOF",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_GENERIC6DOF ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_VEHICLE",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_VEHICLE ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_PIVX",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_PIVX ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_PIVY",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_PIVY ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_PIVZ",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_PIVZ ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_AXX",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_AXX ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_AXY",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_AXY ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_AXZ",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_AXZ ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_MINLIMIT0",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_MINLIMIT0 ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_MINLIMIT1",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_MINLIMIT1 ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_MINLIMIT2",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_MINLIMIT2 ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_MINLIMIT3",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_MINLIMIT3 ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_MINLIMIT4",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_MINLIMIT4 ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_MINLIMIT5",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_MINLIMIT5 ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_MAXLIMIT0",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_MAXLIMIT0 ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_MAXLIMIT1",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_MAXLIMIT1 ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_MAXLIMIT2",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_MAXLIMIT2 ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_MAXLIMIT3",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_MAXLIMIT3 ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_MAXLIMIT4",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_MAXLIMIT4 ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_MAXLIMIT5",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_MAXLIMIT5 ) );				
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_EXTRAFZ",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_EXTRAFZ ) );
 | |
| 		PyConstant_Insert( d, "CONSTR_RB_FLAG",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_RB_FLAG ) );
 | |
| 				
 | |
| 				
 | |
| 		PyConstant_Insert( d, "OWNERSPACE",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_OWNSPACE ) );
 | |
| 		PyConstant_Insert( d, "TARGETSPACE",
 | |
| 				PyInt_FromLong( EXPP_CONSTR_TARSPACE ) );
 | |
| 				
 | |
| 		PyConstant_Insert( d, "SPACE_WORLD",
 | |
| 				PyInt_FromLong( CONSTRAINT_SPACE_WORLD) );
 | |
| 		PyConstant_Insert( d, "SPACE_LOCAL",
 | |
| 				PyInt_FromLong( CONSTRAINT_SPACE_LOCAL ) );
 | |
| 		PyConstant_Insert( d, "SPACE_POSE",
 | |
| 				PyInt_FromLong( CONSTRAINT_SPACE_POSE) );
 | |
| 		PyConstant_Insert( d, "SPACE_PARLOCAL",
 | |
| 				PyInt_FromLong( CONSTRAINT_SPACE_PARLOCAL ) );
 | |
| 	}
 | |
| 	return S;
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:              Constraint_Init                                    */
 | |
| /*****************************************************************************/
 | |
| PyObject *Constraint_Init( void )
 | |
| {
 | |
| 	PyObject *submodule;
 | |
| 	PyObject *TypeDict = M_Constraint_TypeDict( );
 | |
| 	PyObject *SettingsDict = M_Constraint_SettingsDict( );
 | |
| 
 | |
| 	if( PyType_Ready( &ConstraintSeq_Type ) < 0
 | |
| 			|| PyType_Ready( &Constraint_Type ) < 0 )
 | |
| 		return NULL;
 | |
| 
 | |
| 	submodule = Py_InitModule3( "Blender.Constraint", NULL,
 | |
| 			"Constraint module for accessing and creating constraint data" );
 | |
| 
 | |
| 	if( TypeDict )
 | |
| 		PyModule_AddObject( submodule, "Type", TypeDict );
 | |
| 	
 | |
| 	if( SettingsDict )
 | |
| 		PyModule_AddObject( submodule, "Settings", SettingsDict );
 | |
| 	
 | |
| 	return submodule;
 | |
| }
 |