- Mostly this cleans up the #includes and header files in the python project. - Warning fixes are mostly casting issues and misc fixes. General warning clean up. - #include Python.h MUST come as the first include to avoid the POSIX redefine warning in the unix makefiles - fno-strict-aliasing flag added to makefile to fix a unavoidable type punning warning in types.c
		
			
				
	
	
		
			240 lines
		
	
	
		
			7.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			240 lines
		
	
	
		
			7.1 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): Alex Mole
 | |
|  *
 | |
|  * ***** END GPL/BL DUAL LICENSE BLOCK *****
 | |
| */
 | |
| #include "MTex.h" /*This must come first*/
 | |
| 
 | |
| #include "BKE_utildefines.h"
 | |
| #include "Texture.h"
 | |
| #include "gen_utils.h"
 | |
| 
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python BPy_MTex methods declarations:                                     */
 | |
| /*****************************************************************************/
 | |
| static PyObject *MTex_setTex( BPy_MTex * self, PyObject * args );
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python method structure definition for Blender.Texture.MTex module:       */
 | |
| /*****************************************************************************/
 | |
| struct PyMethodDef M_MTex_methods[] = {
 | |
| 	{NULL, NULL, 0, NULL}
 | |
| };
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python BPy_MTex methods table:                                            */
 | |
| /*****************************************************************************/
 | |
| static PyMethodDef BPy_MTex_methods[] = {
 | |
| 	/* name, method, flags, doc */
 | |
| 	{"setTex", ( PyCFunction ) MTex_setTex, METH_VARARGS,
 | |
| 	 "(i) - Set MTex Texture"},
 | |
| 	{NULL, NULL, 0, NULL}
 | |
| };
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python MTex_Type callback function prototypes:                            */
 | |
| /*****************************************************************************/
 | |
| static void MTex_dealloc( BPy_MTex * self );
 | |
| static int MTex_setAttr( BPy_MTex * self, char *name, PyObject * v );
 | |
| static int MTex_compare( BPy_MTex * a, BPy_MTex * b );
 | |
| static PyObject *MTex_getAttr( BPy_MTex * self, char *name );
 | |
| static PyObject *MTex_repr( BPy_MTex * self );
 | |
| 
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python MTex_Type structure definition:                                    */
 | |
| /*****************************************************************************/
 | |
| PyTypeObject MTex_Type = {
 | |
| 	PyObject_HEAD_INIT( NULL ) 
 | |
| 	0,	/* ob_size */
 | |
| 	"Blender MTex",		/* tp_name */
 | |
| 	sizeof( BPy_MTex ),	/* tp_basicsize */
 | |
| 	0,			/* tp_itemsize */
 | |
| 	/* methods */
 | |
| 	( destructor ) MTex_dealloc,	/* tp_dealloc */
 | |
| 	0,			/* tp_print */
 | |
| 	( getattrfunc ) MTex_getAttr,	/* tp_getattr */
 | |
| 	( setattrfunc ) MTex_setAttr,	/* tp_setattr */
 | |
| 	( cmpfunc ) MTex_compare,	/* tp_compare */
 | |
| 	( reprfunc ) MTex_repr,	/* tp_repr */
 | |
| 	0,			/* tp_as_number */
 | |
| 	0,			/* tp_as_sequence */
 | |
| 	0,			/* tp_as_mapping */
 | |
| 	0,			/* tp_as_hash */
 | |
| 	0, 0, 0, 0, 0, 0,
 | |
| 	0,			/* tp_doc */
 | |
| 	0, 0, 0, 0, 0, 0,
 | |
| 	0,			/* tp_methods */
 | |
| 	0,			/* tp_members */
 | |
| };
 | |
| 
 | |
| 
 | |
| PyObject *MTex_Init( void )
 | |
| {
 | |
| 	PyObject *submodule;
 | |
| 
 | |
| 	MTex_Type.ob_type = &PyType_Type;
 | |
| 
 | |
| 	submodule = Py_InitModule( "Blender.Texture.MTex", M_MTex_methods );
 | |
| 
 | |
| 	return submodule;
 | |
| }
 | |
| 
 | |
| PyObject *MTex_CreatePyObject( MTex * mtex )
 | |
| {
 | |
| 	BPy_MTex *pymtex;
 | |
| 
 | |
| 	pymtex = ( BPy_MTex * ) PyObject_NEW( BPy_MTex, &MTex_Type );
 | |
| 	if( !pymtex )
 | |
| 		return EXPP_ReturnPyObjError( PyExc_MemoryError,
 | |
| 					      "couldn't create BPy_MTex PyObject" );
 | |
| 
 | |
| 	pymtex->mtex = mtex;
 | |
| 	return ( PyObject * ) pymtex;
 | |
| }
 | |
| 
 | |
| MTex *MTex_FromPyObject( PyObject * pyobj )
 | |
| {
 | |
| 	return ( ( BPy_MTex * ) pyobj )->mtex;
 | |
| }
 | |
| 
 | |
| 
 | |
| int MTex_CheckPyObject( PyObject * pyobj )
 | |
| {
 | |
| 	return ( pyobj->ob_type == &MTex_Type );
 | |
| }
 | |
| 
 | |
| 
 | |
| /*****************************************************************************/
 | |
| /* Python BPy_MTex methods:                                                  */
 | |
| /*****************************************************************************/
 | |
| 
 | |
| static PyObject *MTex_setTex( BPy_MTex * self, PyObject * args )
 | |
| {
 | |
| 	BPy_Texture *pytex = NULL;
 | |
| 	if( !PyArg_ParseTuple( args, "O!", &Texture_Type, &pytex ) )
 | |
| 		return EXPP_ReturnPyObjError( PyExc_TypeError,
 | |
| 					      "expected Texture argument" );
 | |
| 
 | |
| 	if( self->mtex->tex )
 | |
| 		self->mtex->tex->id.us--;
 | |
| 
 | |
| 	self->mtex->tex = Texture_FromPyObject( ( PyObject * ) pytex );
 | |
| 
 | |
| 	Py_INCREF( Py_None );
 | |
| 	return Py_None;
 | |
| }
 | |
| 
 | |
| static void MTex_dealloc( BPy_MTex * self )
 | |
| {
 | |
| 	PyObject_DEL( self );
 | |
| }
 | |
| 
 | |
| static PyObject *MTex_getAttr( BPy_MTex * self, char *name )
 | |
| {
 | |
| 	if( STREQ( name, "tex" ) ) {
 | |
| 		if( self->mtex->tex )
 | |
| 			return Texture_CreatePyObject( self->mtex->tex );
 | |
| 		else {
 | |
| 			Py_INCREF( Py_None );
 | |
| 			return Py_None;
 | |
| 		}
 | |
| 	} else if( STREQ( name, "texco" ) )
 | |
| 		return PyInt_FromLong( self->mtex->texco );
 | |
| 	else if( STREQ( name, "mapto" ) )
 | |
| 		return PyInt_FromLong( self->mtex->mapto );
 | |
| 
 | |
| 	else if( STREQ( name, "__members__" ) )
 | |
| 		return Py_BuildValue( "[s,s,s]", "tex", "texco", "mapto" );
 | |
| 
 | |
| 	/* not an attribute, search the methods table */
 | |
| 	return Py_FindMethod( BPy_MTex_methods, ( PyObject * ) self, name );
 | |
| }
 | |
| 
 | |
| static int MTex_setAttr( BPy_MTex * self, char *name, PyObject * value )
 | |
| {
 | |
| 	PyObject *valtuple;
 | |
| 	PyObject *error = NULL;
 | |
| 
 | |
| 	/* Put "value" in a tuple, because we want to pass it to functions  *
 | |
| 	 * that only accept PyTuples.                                       */
 | |
| 	valtuple = Py_BuildValue( "(O)", value );
 | |
| 	if( !valtuple )
 | |
| 		return EXPP_ReturnIntError( PyExc_MemoryError,
 | |
| 					    "MTex_setAttr: couldn't create PyTuple" );
 | |
| 
 | |
| 	if( STREQ( name, "tex" ) )
 | |
| 		error = MTex_setTex( self, valtuple );
 | |
| 	else if( STREQ( name, "texco" ) ) {
 | |
| 		if( PyInt_Check( value ) ) {
 | |
| 			int texco = PyInt_AsLong( value );
 | |
| 			/* TODO: sanity-check this input! */
 | |
| 			self->mtex->texco = (short)texco;
 | |
| 			Py_INCREF( Py_None );	/* because we decref it below */
 | |
| 			error = Py_None;
 | |
| 		}
 | |
| 	} else if( STREQ( name, "mapto" ) ) {
 | |
| 		if( PyInt_Check( value ) ) {
 | |
| 			int mapto = PyInt_AsLong( value );
 | |
| 			/* TODO: sanity-check this input! */
 | |
| 			self->mtex->mapto = (short)mapto;
 | |
| 			Py_INCREF( Py_None );	/* because we decref it below */
 | |
| 			error = Py_None;
 | |
| 		}
 | |
| 	}
 | |
| 
 | |
| 	else {
 | |
| 		/* Error */
 | |
| 		Py_DECREF( valtuple );
 | |
| 		return EXPP_ReturnIntError( PyExc_KeyError,
 | |
| 					    "attribute not found" );
 | |
| 	}
 | |
| 
 | |
| 	Py_DECREF( valtuple );
 | |
| 
 | |
| 	if( error != Py_None )
 | |
| 		return -1;
 | |
| 
 | |
| 	/* Py_None was INCREF'd by the set*() function, so we need to DECREF it */
 | |
| 	Py_DECREF( Py_None );
 | |
| 
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| static int MTex_compare( BPy_MTex * a, BPy_MTex * b )
 | |
| {
 | |
| 	return ( a->mtex == b->mtex ) ? 0 : -1;
 | |
| }
 | |
| 
 | |
| static PyObject *MTex_repr( BPy_MTex * self )
 | |
| {
 | |
| 	return PyString_FromFormat( "[MTex]" );
 | |
| }
 |