- Trying to fix linking problems in OSX; - Making module .Get functions behave like the ones in Blender 2.25 - 2.27 (Guignot pointed the incompatibility); - Included more types to Blender.Types; - Found by luck and corrected two bugs that were making Blender crash; - Added/updated some simple functions.
		
			
				
	
	
		
			1019 lines
		
	
	
		
			32 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			1019 lines
		
	
	
		
			32 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* 
 | |
|  *
 | |
|  * ***** 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): Willian P. Germano
 | |
|  *
 | |
|  * ***** END GPL/BL DUAL LICENSE BLOCK *****
 | |
| */
 | |
| 
 | |
| #include "Lamp.h"
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:              M_Lamp_New                                         */
 | |
| /* Python equivalent:     Blender.Lamp.New                                   */
 | |
| /*****************************************************************************/
 | |
| static PyObject *M_Lamp_New(PyObject *self, PyObject *args, PyObject *keywords)
 | |
| {
 | |
|   char        *type_str = "Lamp";
 | |
|   char        *name_str = "LampData";
 | |
|   static char *kwlist[] = {"type_str", "name_str", NULL};
 | |
|   C_Lamp      *py_lamp; /* for Lamp Data object wrapper in Python */
 | |
|   Lamp        *bl_lamp; /* for actual Lamp Data we create in Blender */
 | |
|   char        buf[21];
 | |
| 
 | |
|   printf ("In Lamp_New()\n");
 | |
| 
 | |
|   if (!PyArg_ParseTupleAndKeywords(args, keywords, "|ss", kwlist,
 | |
|                           &type_str, &name_str))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_AttributeError,
 | |
|             "expected string(s) or empty argument"));
 | |
| 
 | |
|   bl_lamp = add_lamp(); /* first create in Blender */
 | |
|   if (bl_lamp) /* now create the wrapper obj in Python */
 | |
|     py_lamp = (C_Lamp *)Lamp_CreatePyObject(bl_lamp);
 | |
|   else
 | |
|     return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|                             "couldn't create Lamp Data in Blender"));
 | |
| 
 | |
|   if (py_lamp == NULL)
 | |
|     return (EXPP_ReturnPyObjError (PyExc_MemoryError,
 | |
|                             "couldn't create Lamp Data object"));
 | |
| 
 | |
|   py_lamp->lamp = bl_lamp; /* link Python lamp wrapper with Blender Lamp */
 | |
| 
 | |
|   if (strcmp (type_str, "Lamp") == 0)
 | |
|     bl_lamp->type = (short)EXPP_LAMP_TYPE_LAMP;
 | |
|   else if (strcmp (type_str, "Sun") == 0)
 | |
|     bl_lamp->type = (short)EXPP_LAMP_TYPE_SUN;
 | |
|   else if (strcmp (type_str, "Spot") == 0)
 | |
|     bl_lamp->type = (short)EXPP_LAMP_TYPE_SPOT;
 | |
|   else if (strcmp (type_str, "Hemi") == 0)
 | |
|     bl_lamp->type = (short)EXPP_LAMP_TYPE_HEMI;
 | |
|   else
 | |
|     return (EXPP_ReturnPyObjError (PyExc_AttributeError,
 | |
|             "unknown lamp type"));
 | |
| 
 | |
|   if (strcmp(name_str, "LampData") == 0)
 | |
|     return (PyObject *)py_lamp;
 | |
|   else { /* user gave us a name for the lamp, use it */
 | |
|     PyOS_snprintf(buf, sizeof(buf), "%s", name_str);
 | |
|     rename_id(&bl_lamp->id, buf);
 | |
|   }
 | |
| 
 | |
|   return (PyObject *)py_lamp;
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:              M_Lamp_Get                                         */
 | |
| /* Python equivalent:     Blender.Lamp.Get                                   */
 | |
| /* Description:           Receives a string and returns the lamp data obj    */
 | |
| /*                        whose name matches the string.  If no argument is  */
 | |
| /*                        passed in, a list of all lamp data names in the    */
 | |
| /*                        current scene is returned.                         */
 | |
| /*****************************************************************************/
 | |
| static PyObject *M_Lamp_Get(PyObject *self, PyObject *args)
 | |
| {
 | |
|   char *name = NULL;
 | |
|   Lamp *lamp_iter;
 | |
| 
 | |
|   if (!PyArg_ParseTuple(args, "|s", &name))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected string argument (or nothing)"));
 | |
| 
 | |
|   lamp_iter = G.main->lamp.first;
 | |
| 
 | |
|   if (name) { /* (name) - Search lamp by name */
 | |
| 
 | |
|     C_Lamp *wanted_lamp = NULL;
 | |
| 
 | |
|     while ((lamp_iter) && (wanted_lamp == NULL)) {
 | |
| 
 | |
|       if (strcmp (name, lamp_iter->id.name+2) == 0)
 | |
|         wanted_lamp = (C_Lamp *)Lamp_CreatePyObject(lamp_iter);
 | |
| 
 | |
|       lamp_iter = lamp_iter->id.next;
 | |
|     }
 | |
| 
 | |
|     if (wanted_lamp == NULL) { /* Requested lamp doesn't exist */
 | |
|       char error_msg[64];
 | |
|       PyOS_snprintf(error_msg, sizeof(error_msg),
 | |
|                       "Lamp \"%s\" not found", name);
 | |
|       return (EXPP_ReturnPyObjError (PyExc_NameError, error_msg));
 | |
|     }
 | |
| 
 | |
|     return (PyObject *)wanted_lamp;
 | |
|   }
 | |
| 
 | |
|   else { /* () - return a list of all lamps in the scene */
 | |
|     int index = 0;
 | |
|     PyObject *lamplist, *pyobj;
 | |
| 
 | |
|     lamplist = PyList_New (BLI_countlist (&(G.main->lamp)));
 | |
| 
 | |
|     if (lamplist == NULL)
 | |
|       return (PythonReturnErrorObject (PyExc_MemoryError,
 | |
|               "couldn't create PyList"));
 | |
| 
 | |
|     while (lamp_iter) {
 | |
|       pyobj = Lamp_CreatePyObject (lamp_iter);
 | |
| 
 | |
|       if (!pyobj)
 | |
|         return (PythonReturnErrorObject (PyExc_MemoryError,
 | |
|                   "couldn't create PyString"));
 | |
| 
 | |
|       PyList_SET_ITEM (lamplist, index, pyobj);
 | |
| 
 | |
|       lamp_iter = lamp_iter->id.next;
 | |
|       index++;
 | |
|     }
 | |
| 
 | |
|     return lamplist;
 | |
|   }
 | |
| }
 | |
| 
 | |
| static PyObject *M_Lamp_TypesDict (void)
 | |
| { /* create the Blender.Lamp.Types constant dict */
 | |
|   PyObject *Types = M_constant_New();
 | |
| 
 | |
|   if (Types) {
 | |
|     C_constant *c = (C_constant *)Types;
 | |
| 
 | |
|     constant_insert (c, "Lamp", PyInt_FromLong (EXPP_LAMP_TYPE_LAMP));
 | |
|     constant_insert (c, "Sun",  PyInt_FromLong (EXPP_LAMP_TYPE_SUN));
 | |
|     constant_insert (c, "Spot", PyInt_FromLong (EXPP_LAMP_TYPE_SPOT));
 | |
|     constant_insert (c, "Hemi", PyInt_FromLong (EXPP_LAMP_TYPE_HEMI));
 | |
| 
 | |
|   }
 | |
| 
 | |
|   return Types;
 | |
| }
 | |
| 
 | |
| static PyObject *M_Lamp_ModesDict (void)
 | |
| { /* create the Blender.Lamp.Modes constant dict */
 | |
|   PyObject *Modes = M_constant_New();
 | |
| 
 | |
|   if (Modes) {
 | |
|     C_constant *c = (C_constant *)Modes;
 | |
| 
 | |
|     constant_insert (c, "Shadows", PyInt_FromLong (EXPP_LAMP_MODE_SHADOWS));
 | |
|     constant_insert (c, "Halo", PyInt_FromLong (EXPP_LAMP_MODE_HALO));
 | |
|     constant_insert (c, "Layer", PyInt_FromLong (EXPP_LAMP_MODE_LAYER));
 | |
|     constant_insert (c, "Quad", PyInt_FromLong (EXPP_LAMP_MODE_QUAD));
 | |
|     constant_insert (c, "Negative", PyInt_FromLong (EXPP_LAMP_MODE_NEGATIVE));
 | |
|     constant_insert (c, "Sphere", PyInt_FromLong (EXPP_LAMP_MODE_SPHERE));
 | |
|     constant_insert (c, "Square", PyInt_FromLong (EXPP_LAMP_MODE_SQUARE));
 | |
|     constant_insert (c, "OnlyShadow",
 | |
|                     PyInt_FromLong (EXPP_LAMP_MODE_ONLYSHADOW));
 | |
|   }
 | |
| 
 | |
|   return Modes;
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:              M_Lamp_Init                                        */
 | |
| /*****************************************************************************/
 | |
| /* Needed by the Blender module, to register the Blender.Lamp submodule */
 | |
| PyObject *M_Lamp_Init (void)
 | |
| {
 | |
|   PyObject  *submodule, *Types, *Modes;
 | |
| 
 | |
|   Lamp_Type.ob_type = &PyType_Type;
 | |
| 
 | |
|   Types = M_Lamp_TypesDict ();
 | |
|   Modes = M_Lamp_ModesDict ();
 | |
| 
 | |
|   submodule = Py_InitModule3("Blender.Lamp", M_Lamp_methods, M_Lamp_doc);
 | |
| 
 | |
|   if (Types) PyModule_AddObject(submodule, "Types", Types);
 | |
|   if (Modes) PyModule_AddObject(submodule, "Modes", Modes);
 | |
| 
 | |
|   return (submodule);
 | |
| }
 | |
| 
 | |
| /* Three Python Lamp_Type helper functions needed by the Object module: */
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:    Lamp_CreatePyObject                                          */
 | |
| /* Description: This function will create a new C_Lamp from an existing      */
 | |
| /*              Blender lamp structure.                                      */
 | |
| /*****************************************************************************/
 | |
| PyObject *Lamp_CreatePyObject (Lamp *lamp)
 | |
| {
 | |
|   C_Lamp *pylamp;
 | |
|   float *rgb[3];
 | |
| 
 | |
|   pylamp = (C_Lamp *)PyObject_NEW (C_Lamp, &Lamp_Type);
 | |
| 
 | |
|   if (!pylamp)
 | |
|     return EXPP_ReturnPyObjError (PyExc_MemoryError,
 | |
|             "couldn't create C_Lamp object");
 | |
| 
 | |
|   pylamp->lamp = lamp;
 | |
| 
 | |
|   rgb[0] = &lamp->r;
 | |
|   rgb[1] = &lamp->g;
 | |
|   rgb[2] = &lamp->b;
 | |
| 
 | |
|   pylamp->color = (C_rgbTuple *)rgbTuple_New(rgb);
 | |
| 
 | |
|   return (PyObject *)pylamp;
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:    Lamp_CheckPyObject                                           */
 | |
| /* Description: This function returns true when the given PyObject is of the */
 | |
| /*              type Lamp. Otherwise it will return false.                   */
 | |
| /*****************************************************************************/
 | |
| int Lamp_CheckPyObject (PyObject *pyobj)
 | |
| {
 | |
|   return (pyobj->ob_type == &Lamp_Type);
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:    Lamp_FromPyObject                                            */
 | |
| /* Description: This function returns the Blender lamp from the given        */
 | |
| /*              PyObject.                                                    */
 | |
| /*****************************************************************************/
 | |
| Lamp *Lamp_FromPyObject (PyObject *pyobj)
 | |
| {
 | |
|   return ((C_Lamp *)pyobj)->lamp;
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python C_Lamp methods:                                                    */
 | |
| /*****************************************************************************/
 | |
| static PyObject *Lamp_getName(C_Lamp *self)
 | |
| {
 | |
|   PyObject *attr = PyString_FromString(self->lamp->id.name+2);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.name attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getType(C_Lamp *self)
 | |
| { 
 | |
|   PyObject *attr = PyInt_FromLong(self->lamp->type);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.type attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getMode(C_Lamp *self)
 | |
| {
 | |
|   PyObject *attr = PyInt_FromLong(self->lamp->mode);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.mode attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getSamples(C_Lamp *self)
 | |
| {
 | |
|   PyObject *attr = PyInt_FromLong(self->lamp->samp);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.samples attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getBufferSize(C_Lamp *self)
 | |
| {
 | |
|   PyObject *attr = PyInt_FromLong(self->lamp->bufsize);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.bufferSize attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getHaloStep(C_Lamp *self)
 | |
| {
 | |
|   PyObject *attr = PyInt_FromLong(self->lamp->shadhalostep);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.haloStep attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getEnergy(C_Lamp *self)
 | |
| {
 | |
|   PyObject *attr = PyFloat_FromDouble(self->lamp->energy);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.energy attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getDist(C_Lamp *self)
 | |
| {
 | |
|   PyObject *attr = PyFloat_FromDouble(self->lamp->dist);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.dist attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getSpotSize(C_Lamp *self)
 | |
| {
 | |
|   PyObject *attr = PyFloat_FromDouble(self->lamp->spotsize);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.spotSize attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getSpotBlend(C_Lamp *self)
 | |
| {
 | |
|   PyObject *attr = PyFloat_FromDouble(self->lamp->spotblend);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.spotBlend attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getClipStart(C_Lamp *self)
 | |
| {
 | |
|   PyObject *attr = PyFloat_FromDouble(self->lamp->clipsta);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.clipStart attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getClipEnd(C_Lamp *self)
 | |
| {
 | |
|   PyObject *attr = PyFloat_FromDouble(self->lamp->clipend);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.clipEnd attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getBias(C_Lamp *self)
 | |
| {
 | |
|   PyObject *attr = PyFloat_FromDouble(self->lamp->bias);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.bias attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getSoftness(C_Lamp *self)
 | |
| {
 | |
|   PyObject *attr = PyFloat_FromDouble(self->lamp->soft);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.softness attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getHaloInt(C_Lamp *self)
 | |
| {
 | |
|   PyObject *attr = PyFloat_FromDouble(self->lamp->haint);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.haloInt attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getQuad1(C_Lamp *self)
 | |
| { /* should we complain if Lamp is not of type Quad? */
 | |
|   PyObject *attr = PyFloat_FromDouble(self->lamp->att1);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.quad1 attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getQuad2(C_Lamp *self)
 | |
| { /* should we complain if Lamp is not of type Quad? */
 | |
|   PyObject *attr = PyFloat_FromDouble(self->lamp->att2);
 | |
| 
 | |
|   if (attr) return attr;
 | |
| 
 | |
|   return (EXPP_ReturnPyObjError (PyExc_RuntimeError,
 | |
|           "couldn't get Lamp.quad2 attribute"));
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_getCol(C_Lamp *self)
 | |
| {
 | |
|   return rgbTuple_getCol(self->color);
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setName(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   char *name = NULL;
 | |
|   char buf[21];
 | |
| 
 | |
|   if (!PyArg_ParseTuple(args, "s", &name))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected string argument"));
 | |
|   
 | |
|   PyOS_snprintf(buf, sizeof(buf), "%s", name);
 | |
| 
 | |
|   rename_id(&self->lamp->id, buf);
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setType(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   char *type;
 | |
| 
 | |
|   if (!PyArg_ParseTuple(args, "s", &type))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected string argument"));
 | |
| 
 | |
|   if (strcmp (type, "Lamp") == 0)
 | |
|     self->lamp->type = (short)EXPP_LAMP_TYPE_LAMP;
 | |
|   else if (strcmp (type, "Sun") == 0)
 | |
|     self->lamp->type = (short)EXPP_LAMP_TYPE_SUN; 
 | |
|   else if (strcmp (type, "Spot") == 0)
 | |
|     self->lamp->type = (short)EXPP_LAMP_TYPE_SPOT;  
 | |
|   else if (strcmp (type, "Hemi") == 0)
 | |
|     self->lamp->type = (short)EXPP_LAMP_TYPE_HEMI;  
 | |
|   else
 | |
|     return (EXPP_ReturnPyObjError (PyExc_AttributeError,
 | |
|             "unknown lamp type"));
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| /* This one is 'private'. It is not really a method, just a helper function for
 | |
|  * when script writers use Lamp.type = t instead of Lamp.setType(t), since in
 | |
|  * the first case t shoud be an int and in the second it should be a string. So
 | |
|  * while the method setType expects a string ('persp' or 'ortho') or an empty
 | |
|  * argument, this function should receive an int (0 or 1). */
 | |
| static PyObject *Lamp_setIntType(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   short value;
 | |
| 
 | |
|   if (!PyArg_ParseTuple(args, "h", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected int argument in [0,3]"));
 | |
| 
 | |
|   if (value >= 0 && value <= 3)
 | |
|     self->lamp->type = value;
 | |
|   else
 | |
|     return (EXPP_ReturnPyObjError (PyExc_ValueError,
 | |
|             "expected int argument in [0,3]"));
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setMode(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   char *m[8] = {NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL};
 | |
|   short i, flag = 0;
 | |
| 
 | |
|   if (!PyArg_ParseTuple(args, "|ssssssss", &m[0], &m[1], &m[2],
 | |
|                         &m[3], &m[4], &m[5], &m[6], &m[7]))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_AttributeError,
 | |
|             "expected from none to eight string argument(s)"));
 | |
| 
 | |
|   for (i = 0; i < 8; i++) {
 | |
|     if (m[i] == NULL) break;
 | |
|     if (strcmp(m[i], "Shadows") == 0)
 | |
|       flag |= (short)EXPP_LAMP_MODE_SHADOWS;
 | |
|     else if (strcmp(m[i], "Halo") == 0)
 | |
|       flag |= (short)EXPP_LAMP_MODE_HALO;
 | |
|     else if (strcmp(m[i], "Layer") == 0)
 | |
|       flag |= (short)EXPP_LAMP_MODE_LAYER;
 | |
|     else if (strcmp(m[i], "Quad") == 0)
 | |
|       flag |= (short)EXPP_LAMP_MODE_QUAD;
 | |
|     else if (strcmp(m[i], "Negative") == 0)
 | |
|       flag |= (short)EXPP_LAMP_MODE_NEGATIVE;
 | |
|     else if (strcmp(m[i], "OnlyShadow") == 0)
 | |
|       flag |= (short)EXPP_LAMP_MODE_ONLYSHADOW;
 | |
|     else if (strcmp(m[i], "Sphere") == 0)
 | |
|       flag |= (short)EXPP_LAMP_MODE_SPHERE;
 | |
|     else if (strcmp(m[i], "Square") == 0)
 | |
|       flag |= (short)EXPP_LAMP_MODE_SQUARE;
 | |
|     else
 | |
|       return (EXPP_ReturnPyObjError (PyExc_AttributeError,
 | |
|               "unknown lamp flag argument"));
 | |
|   }
 | |
| 
 | |
|   self->lamp->mode = flag;
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| /* Another helper function, for the same reason.
 | |
|  * (See comment before Lamp_setIntType above). */
 | |
| static PyObject *Lamp_setIntMode(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   short value;
 | |
| 
 | |
|   if (!PyArg_ParseTuple(args, "h", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected int argument"));
 | |
| 
 | |
| /* well, with so many flag bits, we just accept any short int, no checking */
 | |
|   self->lamp->mode = value;
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setSamples(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   short value;
 | |
| 
 | |
|   if (!PyArg_ParseTuple(args, "h", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected int argument in [1,16]"));
 | |
| 
 | |
|   self->lamp->samp = EXPP_ClampInt (value,
 | |
|                   EXPP_LAMP_SAMPLES_MIN, EXPP_LAMP_SAMPLES_MAX);
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setBufferSize(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   short value;
 | |
| 
 | |
|   if (!PyArg_ParseTuple(args, "h", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected int argument in [512, 5120]"));
 | |
|   
 | |
|   self->lamp->bufsize = EXPP_ClampInt (value,
 | |
|                   EXPP_LAMP_BUFFERSIZE_MIN, EXPP_LAMP_BUFFERSIZE_MAX);
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setHaloStep(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   short value;
 | |
| 
 | |
|   if (!PyArg_ParseTuple(args, "h", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected int argument in [0,12]"));
 | |
| 
 | |
|   self->lamp->shadhalostep = EXPP_ClampInt (value,
 | |
|                   EXPP_LAMP_HALOSTEP_MIN, EXPP_LAMP_HALOSTEP_MAX);
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setEnergy(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   float value;
 | |
|   
 | |
|   if (!PyArg_ParseTuple(args, "f", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected float argument"));
 | |
| 
 | |
|   self->lamp->energy = EXPP_ClampFloat (value,
 | |
|                   EXPP_LAMP_ENERGY_MIN, EXPP_LAMP_ENERGY_MAX);
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setDist(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   float value;
 | |
|   
 | |
|   if (!PyArg_ParseTuple(args, "f", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected float argument"));
 | |
| 
 | |
|   self->lamp->dist = EXPP_ClampFloat (value,
 | |
|                   EXPP_LAMP_DIST_MIN, EXPP_LAMP_DIST_MAX);
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setSpotSize(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   float value;
 | |
|   
 | |
|   if (!PyArg_ParseTuple(args, "f", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected float argument"));
 | |
| 
 | |
|   self->lamp->spotsize = EXPP_ClampFloat (value,
 | |
|                   EXPP_LAMP_SPOTSIZE_MIN, EXPP_LAMP_SPOTSIZE_MAX);
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setSpotBlend(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   float value;
 | |
|   
 | |
|   if (!PyArg_ParseTuple(args, "f", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected float argument"));
 | |
| 
 | |
|   self->lamp->spotblend = EXPP_ClampFloat (value,
 | |
|                   EXPP_LAMP_SPOTBLEND_MIN, EXPP_LAMP_SPOTBLEND_MAX);
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setClipStart(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   float value;
 | |
|   
 | |
|   if (!PyArg_ParseTuple(args, "f", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected float argument"));
 | |
|   
 | |
|   self->lamp->clipsta = EXPP_ClampFloat (value,
 | |
|                   EXPP_LAMP_CLIPSTART_MIN, EXPP_LAMP_CLIPSTART_MAX);
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setClipEnd(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   float value;
 | |
| 
 | |
|   if (!PyArg_ParseTuple(args, "f", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected float argument"));
 | |
| 
 | |
|   self->lamp->clipend = EXPP_ClampFloat (value,
 | |
|                   EXPP_LAMP_CLIPEND_MIN, EXPP_LAMP_CLIPEND_MAX);
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setBias(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   float value;
 | |
|   
 | |
|   if (!PyArg_ParseTuple(args, "f", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected float argument"));
 | |
| 
 | |
|   self->lamp->bias = EXPP_ClampFloat (value,
 | |
|                   EXPP_LAMP_BIAS_MIN, EXPP_LAMP_BIAS_MAX);
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setSoftness(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   float value;
 | |
|   
 | |
|   if (!PyArg_ParseTuple(args, "f", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected float argument"));
 | |
| 
 | |
|   self->lamp->soft = EXPP_ClampFloat (value,
 | |
|                   EXPP_LAMP_SOFTNESS_MIN, EXPP_LAMP_SOFTNESS_MAX);
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setHaloInt(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   float value;
 | |
| 
 | |
|   if (!PyArg_ParseTuple(args, "f", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected float argument"));
 | |
| 
 | |
|   self->lamp->haint = EXPP_ClampFloat (value,
 | |
|                   EXPP_LAMP_HALOINT_MIN, EXPP_LAMP_HALOINT_MAX);
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setQuad1(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   float value;
 | |
| 
 | |
|   if (!PyArg_ParseTuple(args, "f", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected float argument"));
 | |
| 
 | |
|   self->lamp->att1 = EXPP_ClampFloat (value,
 | |
|                   EXPP_LAMP_QUAD1_MIN, EXPP_LAMP_QUAD1_MAX);
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setQuad2(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   float value;
 | |
| 
 | |
|   if (!PyArg_ParseTuple(args, "f", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected float argument"));
 | |
| 
 | |
|   self->lamp->att2 = EXPP_ClampFloat (value,
 | |
|                   EXPP_LAMP_QUAD2_MIN, EXPP_LAMP_QUAD2_MAX);
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setColorComponent(C_Lamp *self, char *key,
 | |
|                 PyObject *args)
 | |
| { /* for compatibility with old bpython */
 | |
|   float value;
 | |
| 
 | |
|   if (!PyArg_ParseTuple(args, "f", &value))
 | |
|     return (EXPP_ReturnPyObjError (PyExc_TypeError,
 | |
|             "expected float argument in [0.0, 1.0]"));
 | |
| 
 | |
|   value = EXPP_ClampFloat (value, EXPP_LAMP_COL_MIN,
 | |
|                   EXPP_LAMP_COL_MAX);
 | |
| 
 | |
|   if (!strcmp(key, "R"))
 | |
|     self->lamp->r = value;
 | |
|   else if (!strcmp(key, "G"))
 | |
|     self->lamp->g = value;
 | |
|   else if (!strcmp(key, "B"))
 | |
|     self->lamp->b = value;
 | |
| 
 | |
|   Py_INCREF(Py_None);
 | |
|   return Py_None;
 | |
| }
 | |
| 
 | |
| static PyObject *Lamp_setCol(C_Lamp *self, PyObject *args)
 | |
| {
 | |
|   return rgbTuple_setCol(self->color, args);
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:    LampDeAlloc                                                  */
 | |
| /* Description: This is a callback function for the C_Lamp type. It is       */
 | |
| /*              the destructor function.                                     */
 | |
| /*****************************************************************************/
 | |
| static void LampDeAlloc (C_Lamp *self)
 | |
| {
 | |
|   PyObject_DEL (self);
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:    LampGetAttr                                                  */
 | |
| /* Description: This is a callback function for the C_Lamp type. It is       */
 | |
| /*              the function that accesses C_Lamp member variables and       */
 | |
| /*              methods.                                                     */
 | |
| /*****************************************************************************/
 | |
| static PyObject *LampGetAttr (C_Lamp *self, char *name)
 | |
| {
 | |
|   PyObject *attr = Py_None;
 | |
| 
 | |
|   if (strcmp(name, "name") == 0)
 | |
|     attr = PyString_FromString(self->lamp->id.name+2);
 | |
|   else if (strcmp(name, "type") == 0)
 | |
|     attr = PyInt_FromLong(self->lamp->type);
 | |
|   else if (strcmp(name, "mode") == 0)
 | |
|     attr = PyInt_FromLong(self->lamp->mode);
 | |
|   else if (strcmp(name, "samples") == 0)
 | |
|     attr = PyInt_FromLong(self->lamp->samp);
 | |
|   else if (strcmp(name, "bufferSize") == 0)
 | |
|     attr = PyInt_FromLong(self->lamp->bufsize);
 | |
|   else if (strcmp(name, "haloStep") == 0)
 | |
|     attr = PyInt_FromLong(self->lamp->shadhalostep);
 | |
|   else if (strcmp(name, "R") == 0)
 | |
|     attr = PyFloat_FromDouble(self->lamp->r);
 | |
|   else if (strcmp(name, "G") == 0)
 | |
|     attr = PyFloat_FromDouble(self->lamp->g);
 | |
|   else if (strcmp(name, "B") == 0)
 | |
|     attr = PyFloat_FromDouble(self->lamp->b);
 | |
|   else if (strcmp(name, "col") == 0)
 | |
|     attr = Lamp_getCol(self);
 | |
|   else if (strcmp(name, "energy") == 0)
 | |
|     attr = PyFloat_FromDouble(self->lamp->energy);
 | |
|   else if (strcmp(name, "dist") == 0)
 | |
|     attr = PyFloat_FromDouble(self->lamp->dist);
 | |
|   else if (strcmp(name, "spotSize") == 0)
 | |
|     attr = PyFloat_FromDouble(self->lamp->spotsize);
 | |
|   else if (strcmp(name, "spotBlend") == 0)
 | |
|     attr = PyFloat_FromDouble(self->lamp->spotblend);
 | |
|   else if (strcmp(name, "clipStart") == 0)
 | |
|     attr = PyFloat_FromDouble(self->lamp->clipsta);
 | |
|   else if (strcmp(name, "clipEnd") == 0)
 | |
|     attr = PyFloat_FromDouble(self->lamp->clipend);
 | |
|   else if (strcmp(name, "bias") == 0)
 | |
|     attr = PyFloat_FromDouble(self->lamp->bias);
 | |
|   else if (strcmp(name, "softness") == 0)
 | |
|     attr = PyFloat_FromDouble(self->lamp->soft);
 | |
|   else if (strcmp(name, "haloInt") == 0)
 | |
|     attr = PyFloat_FromDouble(self->lamp->haint);
 | |
|   else if (strcmp(name, "quad1") == 0)
 | |
|     attr = PyFloat_FromDouble(self->lamp->att1);
 | |
|   else if (strcmp(name, "quad2") == 0)
 | |
|     attr = PyFloat_FromDouble(self->lamp->att2);
 | |
| 
 | |
|   else if (strcmp(name, "Types") == 0) {
 | |
|     attr = Py_BuildValue("{s:h,s:h,s:h,s:h}",
 | |
|                     "Lamp", EXPP_LAMP_TYPE_LAMP,
 | |
|                     "Sun" , EXPP_LAMP_TYPE_SUN,
 | |
|                     "Spot", EXPP_LAMP_TYPE_SPOT,
 | |
|                     "Hemi", EXPP_LAMP_TYPE_HEMI);
 | |
|   }
 | |
| 
 | |
|   else if (strcmp(name, "Modes") == 0) {
 | |
|     attr = Py_BuildValue("{s:h,s:h,s:h,s:h,s:h,s:h,s:h,s:h}",
 | |
|                     "Shadows",    EXPP_LAMP_MODE_SHADOWS,
 | |
|                     "Halo",       EXPP_LAMP_MODE_HALO,
 | |
|                     "Layer",      EXPP_LAMP_MODE_LAYER,
 | |
|                     "Quad",       EXPP_LAMP_MODE_QUAD,
 | |
|                     "Negative",   EXPP_LAMP_MODE_NEGATIVE,
 | |
|                     "OnlyShadow", EXPP_LAMP_MODE_ONLYSHADOW,
 | |
|                     "Sphere",     EXPP_LAMP_MODE_SPHERE,
 | |
|                     "Square",     EXPP_LAMP_MODE_SQUARE);
 | |
|   }
 | |
| 
 | |
|   else if (strcmp(name, "__members__") == 0) {
 | |
|     /* 23 entries */
 | |
|     attr = Py_BuildValue("[s,s,s,s,s,s,s,s,s,s,s,s,s,s,s,s,s,s,s,s,s,s,s]",
 | |
|                     "name", "type", "mode", "samples", "bufferSize",
 | |
|                     "haloStep", "R", "G", "B", "energy", "dist",
 | |
|                     "spotSize", "spotBlend", "clipStart", "clipEnd",
 | |
|                     "bias", "softness", "haloInt", "quad1", "quad2",
 | |
|                     "Types", "Modes", "col");
 | |
|   }
 | |
| 
 | |
|   if (!attr)
 | |
|     return (EXPP_ReturnPyObjError (PyExc_MemoryError,
 | |
|                       "couldn't create PyObject"));
 | |
| 
 | |
|   if (attr != Py_None) return attr; /* member attribute found, return it */
 | |
| 
 | |
|   /* not an attribute, search the methods table */
 | |
|   return Py_FindMethod(C_Lamp_methods, (PyObject *)self, name);
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:    LampSetAttr                                                  */
 | |
| /* Description: This is a callback function for the C_Lamp type. It is the   */
 | |
| /*              function that changes Lamp Data members values. If this      */
 | |
| /*              data is linked to a Blender Lamp, it also gets updated.      */
 | |
| /*****************************************************************************/
 | |
| static int LampSetAttr (C_Lamp *self, char *name, PyObject *value)
 | |
| {
 | |
|   PyObject *valtuple; 
 | |
|   PyObject *error = NULL;
 | |
| 
 | |
|   valtuple = Py_BuildValue("(O)", value); /* the set* functions expect a tuple */
 | |
| 
 | |
|   if (!valtuple)
 | |
|     return EXPP_ReturnIntError(PyExc_MemoryError,
 | |
|                   "LampSetAttr: couldn't create tuple");
 | |
| 
 | |
|   if (strcmp (name, "name") == 0)
 | |
|     error = Lamp_setName (self, valtuple);
 | |
|   else if (strcmp (name, "type") == 0)
 | |
|     error = Lamp_setIntType (self, valtuple); /* special case */
 | |
|   else if (strcmp (name, "mode") == 0)
 | |
|     error = Lamp_setIntMode (self, valtuple); /* special case */
 | |
|   else if (strcmp (name, "samples") == 0)
 | |
|     error = Lamp_setSamples (self, valtuple);
 | |
|   else if (strcmp (name, "bufferSize") == 0)
 | |
|     error = Lamp_setBufferSize (self, valtuple);
 | |
|   else if (strcmp (name, "haloStep") == 0)
 | |
|     error = Lamp_setHaloStep (self, valtuple);
 | |
|   else if (strcmp (name, "R") == 0)
 | |
|     error = Lamp_setColorComponent (self, "R", valtuple);
 | |
|   else if (strcmp (name, "G") == 0)
 | |
|     error = Lamp_setColorComponent (self, "G", valtuple);
 | |
|   else if (strcmp (name, "B") == 0)
 | |
|     error = Lamp_setColorComponent (self, "B", valtuple);
 | |
|   else if (strcmp (name, "energy") == 0)
 | |
|     error = Lamp_setEnergy (self, valtuple);
 | |
|   else if (strcmp (name, "dist") == 0)
 | |
|     error = Lamp_setDist (self, valtuple);
 | |
|   else if (strcmp (name, "spotSize") == 0)
 | |
|     error = Lamp_setSpotSize (self, valtuple);
 | |
|   else if (strcmp (name, "spotBlend") == 0)
 | |
|     error = Lamp_setSpotBlend (self, valtuple);
 | |
|   else if (strcmp (name, "clipStart") == 0)
 | |
|     error = Lamp_setClipStart (self, valtuple);
 | |
|   else if (strcmp (name, "clipEnd") == 0)
 | |
|     error = Lamp_setClipEnd (self, valtuple);
 | |
|   else if (strcmp (name, "bias") == 0)
 | |
|     error = Lamp_setBias (self, valtuple);
 | |
|   else if (strcmp (name, "softness") == 0)
 | |
|     error = Lamp_setSoftness (self, valtuple);
 | |
|   else if (strcmp (name, "haloInt") == 0)
 | |
|     error = Lamp_setHaloInt (self, valtuple);
 | |
|   else if (strcmp (name, "quad1") == 0)
 | |
|     error = Lamp_setQuad1 (self, valtuple);
 | |
|   else if (strcmp (name, "quad2") == 0)
 | |
|     error = Lamp_setQuad2 (self, valtuple);
 | |
|   else if (strcmp (name, "col") == 0)
 | |
|     error = Lamp_setCol (self, valtuple);
 | |
| 
 | |
|   else { /* Error */
 | |
|     Py_DECREF(valtuple);
 | |
|   
 | |
|     if ((strcmp (name, "Types") == 0) || /* user tried to change a */
 | |
|         (strcmp (name, "Modes") == 0))   /* constant dict type ... */
 | |
|       return (EXPP_ReturnIntError (PyExc_AttributeError,
 | |
|                    "constant dictionary -- cannot be changed"));
 | |
| 
 | |
|     else /* ... or no member with the given name was found */
 | |
|       return (EXPP_ReturnIntError (PyExc_AttributeError,
 | |
|                    "attribute not found"));
 | |
|   }
 | |
| 
 | |
|   Py_DECREF(valtuple);
 | |
|   
 | |
|   if (error != Py_None) return -1;
 | |
| 
 | |
|   Py_DECREF(Py_None); /* was incref'ed by the called Lamp_set* function */
 | |
|   return 0; /* normal exit */
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:    LampCompare                                                  */
 | |
| /* Description: This is a callback function for the C_Lamp type. It          */
 | |
| /*              compares two Lamp_Type objects. Only the "==" and "!="       */
 | |
| /*              comparisons are meaninful. Returns 0 for equality and -1 if  */
 | |
| /*              they don't point to the same Blender Lamp struct.            */
 | |
| /*              In Python it becomes 1 if they are equal, 0 otherwise.       */
 | |
| /*****************************************************************************/
 | |
| static int LampCompare (C_Lamp *a, C_Lamp *b)
 | |
| {
 | |
|   Lamp *pa = a->lamp, *pb = b->lamp;
 | |
|   return (pa == pb) ? 0:-1;
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:    LampPrint                                                    */
 | |
| /* Description: This is a callback function for the C_Lamp type. It          */
 | |
| /*              builds a meaninful string to 'print' lamp objects.           */
 | |
| /*****************************************************************************/
 | |
| static int LampPrint(C_Lamp *self, FILE *fp, int flags)
 | |
| { 
 | |
|   fprintf(fp, "[Lamp \"%s\"]", self->lamp->id.name+2);
 | |
|   return 0;
 | |
| }
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Function:    LampRepr                                                     */
 | |
| /* Description: This is a callback function for the C_Lamp type. It          */
 | |
| /*              builds a meaninful string to represent lamp objects.         */
 | |
| /*****************************************************************************/
 | |
| static PyObject *LampRepr (C_Lamp *self)
 | |
| {
 | |
|   return PyString_FromString(self->lamp->id.name+2);
 | |
| }
 |