This repository has been archived on 2023-10-09. You can view files and clone it, but cannot push or open issues or pull requests.
Files
blender-archive/source/blender/python/api2_2x/MTex.c
Joseph Gilbert e60291d39c Header file clean up and warning fixes
- 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
2005-07-18 03:50:37 +00:00

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]" );
}