prepared physics/game engine infrastructure for vehicle support.
[blender.git] / source / gameengine / Expressions / PyObjectPlus.cpp
1 /**
2  * $Id$
3  * ***** BEGIN GPL/BL DUAL LICENSE BLOCK *****
4  *
5  * This program is free software; you can redistribute it and/or
6  * modify it under the terms of the GNU General Public License
7  * as published by the Free Software Foundation; either version 2
8  * of the License, or (at your option) any later version. The Blender
9  * Foundation also sells licenses for use in proprietary software under
10  * the Blender License.  See http://www.blender.org/BL/ for information
11  * about this.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  * GNU General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software Foundation,
20  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
21  *
22  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
23  * All rights reserved.
24  *
25  * The Original Code is: all of this file.
26  *
27  * Contributor(s): none yet.
28  *
29  * ***** END GPL/BL DUAL LICENSE BLOCK *****
30  */
31
32 #ifdef HAVE_CONFIG_H
33 #include <config.h>
34 #endif
35
36 #ifndef NO_EXP_PYTHON_EMBEDDING
37
38 /*------------------------------
39  * PyObjectPlus cpp
40  *
41  * C++ library routines for Crawl 3.2
42  *
43  * Derived from work by
44  * David Redish
45  * graduate student
46  * Computer Science Department 
47  * Carnegie Mellon University (CMU)
48  * Center for the Neural Basis of Cognition (CNBC) 
49  * http://www.python.org/doc/PyCPP.html
50  *
51 ------------------------------*/
52 #include <MT_assert.h>
53 #include "stdlib.h"
54 #include "PyObjectPlus.h"
55 #include "STR_String.h"
56 /*------------------------------
57  * PyObjectPlus Type            -- Every class, even the abstract one should have a Type
58 ------------------------------*/
59
60 PyTypeObject PyObjectPlus::Type = {
61         PyObject_HEAD_INIT(&PyType_Type)
62         0,                              /*ob_size*/
63         "PyObjectPlus",                 /*tp_name*/
64         sizeof(PyObjectPlus),           /*tp_basicsize*/
65         0,                              /*tp_itemsize*/
66         /* methods */
67         PyDestructor,                   /*tp_dealloc*/
68         0,                              /*tp_print*/
69         __getattr,                      /*tp_getattr*/
70         __setattr,                      /*tp_setattr*/
71         0,                              /*tp_compare*/
72         __repr,                         /*tp_repr*/
73         0,                              /*tp_as_number*/
74         0,                              /*tp_as_sequence*/
75         0,                              /*tp_as_mapping*/
76         0,                              /*tp_hash*/
77         0,                              /*tp_call */
78 };
79
80 PyObjectPlus::~PyObjectPlus()
81 {
82         if (ob_refcnt)
83         {
84                 _Py_ForgetReference(this);
85         }
86 //      assert(ob_refcnt==0);
87 }
88
89 PyObjectPlus::PyObjectPlus(PyTypeObject *T)                             // constructor
90 {
91         MT_assert(T != NULL);
92         this->ob_type = T; 
93         _Py_NewReference(this);
94 };
95   
96 /*------------------------------
97  * PyObjectPlus Methods         -- Every class, even the abstract one should have a Methods
98 ------------------------------*/
99 PyMethodDef PyObjectPlus::Methods[] = {
100   {"isA",                (PyCFunction) sPy_isA,                 Py_NEWARGS},
101   {NULL, NULL}          /* Sentinel */
102 };
103
104 /*------------------------------
105  * PyObjectPlus Parents         -- Every class, even the abstract one should have parents
106 ------------------------------*/
107 PyParentObject PyObjectPlus::Parents[] = {&PyObjectPlus::Type, NULL};
108
109 /*------------------------------
110  * PyObjectPlus attributes      -- attributes
111 ------------------------------*/
112 PyObject *PyObjectPlus::_getattr(const STR_String& attr)
113 {
114         if (attr == "__doc__" && GetType()->tp_doc)
115                 return PyString_FromString(GetType()->tp_doc);
116
117   //if (streq(attr, "type"))
118   //  return Py_BuildValue("s", (*(GetParents()))->tp_name);
119
120   return Py_FindMethod(Methods, this, const_cast<char *>(attr.ReadPtr()));
121 }
122
123 int PyObjectPlus::_delattr(const STR_String& attr)
124 {
125         return 1;
126 }
127
128 int PyObjectPlus::_setattr(const STR_String& attr, PyObject *value)
129 {
130         //return PyObject::_setattr(attr,value);
131         //cerr << "Unknown attribute" << endl;
132   return 1;
133 }
134
135 /*------------------------------
136  * PyObjectPlus repr            -- representations
137 ------------------------------*/
138 PyObject *PyObjectPlus::_repr(void)
139 {
140   Py_Error(PyExc_SystemError, "Representation not overridden by object.");  
141 }
142
143 /*------------------------------
144  * PyObjectPlus isA             -- the isA functions
145 ------------------------------*/
146 bool PyObjectPlus::isA(PyTypeObject *T)         // if called with a Type, use "typename"
147 {
148   return isA(T->tp_name);
149 }
150
151
152 bool PyObjectPlus::isA(const char *mytypename)          // check typename of each parent
153 {
154   int i;
155   PyParentObject  P;
156   PyParentObject *Ps = GetParents();
157   
158   for (P = Ps[i=0]; P != NULL; P = Ps[i++])
159   {
160       if (STR_String(P->tp_name) == STR_String(mytypename)      )
161                   return true;
162   }
163         
164   return false;
165 }
166
167 PyObject *PyObjectPlus::Py_isA(PyObject *args)          // Python wrapper for isA
168 {
169   char *mytypename;
170   Py_Try(PyArg_ParseTuple(args, "s", &mytypename));
171   if(isA(mytypename))
172     {Py_INCREF(Py_True); return Py_True;}
173   else
174     {Py_INCREF(Py_False); return Py_False;};
175 }
176
177 #endif //NO_EXP_PYTHON_EMBEDDING
178