[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [18943] trunk/blender/source/blender/ python/api2_2x/Modifier.c: add some more modifier types and access to shrink wrap target object ( but no other shrink wrap settings)
Campbell Barton
ideasman42 at gmail.com
Thu Feb 12 17:27:22 CET 2009
Revision: 18943
http://projects.blender.org/plugins/scmsvn/viewcvs.php?view=rev&root=bf-blender&revision=18943
Author: campbellbarton
Date: 2009-02-12 17:27:19 +0100 (Thu, 12 Feb 2009)
Log Message:
-----------
add some more modifier types and access to shrink wrap target object (but no other shrink wrap settings)
Modified Paths:
--------------
trunk/blender/source/blender/python/api2_2x/Modifier.c
Modified: trunk/blender/source/blender/python/api2_2x/Modifier.c
===================================================================
--- trunk/blender/source/blender/python/api2_2x/Modifier.c 2009-02-12 11:04:08 UTC (rev 18942)
+++ trunk/blender/source/blender/python/api2_2x/Modifier.c 2009-02-12 16:27:19 UTC (rev 18943)
@@ -982,7 +982,42 @@
}
}
+static PyObject *shrinkwrap_getter( BPy_Modifier * self, int type )
+{
+ ShrinkwrapModifierData *md = (ShrinkwrapModifierData *)(self->md);
+ switch( type ) {
+ case EXPP_MOD_OBJECT:
+ return Object_CreatePyObject( md->target );
+ default:
+ return EXPP_ReturnPyObjError( PyExc_KeyError, "key not found" );
+ }
+}
+
+static int shrinkwrap_setter( BPy_Modifier *self, int type, PyObject *value )
+{
+ ShrinkwrapModifierData *md = (ShrinkwrapModifierData *)(self->md);
+
+ switch( type ) {
+ case EXPP_MOD_OBJECT: { /* Only object for now */
+ Object *ob_new=NULL;
+ if (value == Py_None) {
+ md->target = NULL;
+ } else if (BPy_Object_Check( value )) {
+ ob_new = ((( BPy_Object * )value)->object);
+ md->target = ob_new;
+ } else {
+ return EXPP_ReturnIntError( PyExc_TypeError,
+ "Expected an Object or None value" );
+ }
+ return 0;
+ }
+ default:
+ return EXPP_ReturnIntError( PyExc_KeyError, "key not found" );
+ }
+}
+
+
/* static PyObject *uvproject_getter( BPy_Modifier * self, int type )
{
DisplaceModifierData *md = (DisplaceModifierData *)(self->md);
@@ -1062,6 +1097,8 @@
return edgesplit_getter( self, setting );
case eModifierType_Displace:
return displace_getter( self, setting );
+ case eModifierType_Shrinkwrap:
+ return shrinkwrap_getter( self, setting );
/*case eModifierType_UVProject:
return uvproject_getter( self, setting );*/
case eModifierType_Hook:
@@ -1132,6 +1169,8 @@
return edgesplit_setter( self, key_int, arg );
case eModifierType_Displace:
return displace_setter( self, key_int, arg );
+ case eModifierType_Shrinkwrap:
+ return shrinkwrap_setter( self, key_int, arg );
/*case eModifierType_UVProject:
return uvproject_setter( self, key_int, arg );*/
case eModifierType_Hook:
@@ -1550,6 +1589,22 @@
PyInt_FromLong( eModifierType_Cast ) );
PyConstant_Insert( d, "DISPLACE",
PyInt_FromLong( eModifierType_Displace ) );
+ PyConstant_Insert( d, "MESHDEFORM",
+ PyInt_FromLong( eModifierType_MeshDeform ) );
+ PyConstant_Insert( d, "PARTICLESYSTEM",
+ PyInt_FromLong( eModifierType_ParticleSystem ) );
+ PyConstant_Insert( d, "PARTICLEINSTANCE",
+ PyInt_FromLong( eModifierType_ParticleInstance ) );
+ PyConstant_Insert( d, "EXPLODE",
+ PyInt_FromLong( eModifierType_Explode ) );
+ PyConstant_Insert( d, "CLOTH",
+ PyInt_FromLong( eModifierType_Cloth ) );
+ PyConstant_Insert( d, "BEVEL",
+ PyInt_FromLong( eModifierType_Bevel ) );
+ PyConstant_Insert( d, "SHRINKWRAP",
+ PyInt_FromLong( eModifierType_Shrinkwrap ) );
+ PyConstant_Insert( d, "SHRINKWRAP",
+ PyInt_FromLong( eModifierType_Shrinkwrap ) );
}
return S;
}
More information about the Bf-blender-cvs
mailing list