| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * $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. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is: all of this file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Contributor(s): none yet. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL/BL DUAL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2002-11-25 11:16:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | #ifndef NO_EXP_PYTHON_EMBEDDING
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef _adr_py_lib_h_				// only process once,
 | 
					
						
							|  |  |  | #define _adr_py_lib_h_				// even if multiply included
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifndef __cplusplus				// c++ only
 | 
					
						
							|  |  |  | #error Must be compiled with C++
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "KX_Python.h"
 | 
					
						
							| 
									
										
										
										
											2004-05-16 13:05:15 +00:00
										 |  |  | #include "STR_String.h"
 | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*------------------------------
 | 
					
						
							|  |  |  |  * Python defines | 
					
						
							|  |  |  | ------------------------------*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 								// some basic python macros
 | 
					
						
							|  |  |  | #define Py_NEWARGS 1			
 | 
					
						
							| 
									
										
										
										
											2005-03-25 10:33:39 +00:00
										 |  |  | #define Py_Return { Py_INCREF(Py_None); return Py_None;}
 | 
					
						
							| 
									
										
										
										
											2005-04-23 12:25:21 +00:00
										 |  |  | static inline PyObject* Py_Success(bool truth) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (truth) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		Py_INCREF(Py_True); | 
					
						
							|  |  |  | 		return Py_True; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	Py_INCREF(Py_False); | 
					
						
							|  |  |  | 	return Py_False; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define Py_Error(E, M)   {PyErr_SetString(E, M); return NULL;}
 | 
					
						
							|  |  |  | #define Py_Try(F) {if (!(F)) return NULL;}
 | 
					
						
							|  |  |  | #define Py_Assert(A,E,M) {if (!(A)) {PyErr_SetString(E, M); return NULL;}}
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-23 12:25:21 +00:00
										 |  |  | static inline void Py_Fatal(char *M) { | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | 	//cout << M << endl; 
 | 
					
						
							|  |  |  | 	exit(-1); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 								// This must be the first line of each 
 | 
					
						
							|  |  |  | 								// PyC++ class
 | 
					
						
							|  |  |  | #define Py_Header \
 | 
					
						
							|  |  |  |  public: \ | 
					
						
							|  |  |  |   static PyTypeObject   Type; \ | 
					
						
							|  |  |  |   static PyMethodDef    Methods[]; \ | 
					
						
							|  |  |  |   static PyParentObject Parents[]; \ | 
					
						
							|  |  |  |   virtual PyTypeObject *GetType(void) {return &Type;}; \ | 
					
						
							|  |  |  |   virtual PyParentObject *GetParents(void) {return Parents;} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 								// This defines the _getattr_up macro
 | 
					
						
							|  |  |  | 								// which allows attribute and method calls
 | 
					
						
							|  |  |  | 								// to be properly passed up the hierarchy.
 | 
					
						
							|  |  |  | #define _getattr_up(Parent) \
 | 
					
						
							| 
									
										
										
										
											2004-05-16 13:05:15 +00:00
										 |  |  |   PyObject *rvalue = Py_FindMethod(Methods, this, const_cast<char*>(attr.ReadPtr())); \ | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  |   if (rvalue == NULL) \ | 
					
						
							|  |  |  |     { \ | 
					
						
							|  |  |  |       PyErr_Clear(); \ | 
					
						
							|  |  |  |       return Parent::_getattr(attr); \ | 
					
						
							|  |  |  |     } \ | 
					
						
							|  |  |  |   else \ | 
					
						
							|  |  |  |     return rvalue  | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-07 11:03:12 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * These macros are helpfull when embedding Python routines. The second | 
					
						
							|  |  |  |  * macro is one that also requires a documentation string | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #define KX_PYMETHOD(class_name, method_name)			\
 | 
					
						
							|  |  |  | 	PyObject* Py##method_name(PyObject* self, PyObject* args, PyObject* kwds); \ | 
					
						
							|  |  |  | 	static PyObject* sPy##method_name( PyObject* self, PyObject* args, PyObject* kwds) { \ | 
					
						
							|  |  |  | 		return ((class_name*) self)->Py##method_name(self, args, kwds);		\ | 
					
						
							|  |  |  | 	}; \ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define KX_PYMETHOD_DOC(class_name, method_name)			\
 | 
					
						
							|  |  |  | 	PyObject* Py##method_name(PyObject* self, PyObject* args, PyObject* kwds); \ | 
					
						
							|  |  |  | 	static PyObject* sPy##method_name( PyObject* self, PyObject* args, PyObject* kwds) { \ | 
					
						
							|  |  |  | 		return ((class_name*) self)->Py##method_name(self, args, kwds);		\ | 
					
						
							|  |  |  | 	}; \ | 
					
						
							|  |  |  |     static char method_name##_doc[]; \ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* The line above should remain empty */ | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Method table macro (with doc) | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #define KX_PYMETHODTABLE(class_name, method_name) \
 | 
					
						
							|  |  |  | 	{#method_name , (PyCFunction) class_name::sPy##method_name, METH_VARARGS, class_name::method_name##_doc} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Function implementation macro | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #define KX_PYMETHODDEF_DOC(class_name, method_name, doc_string) \
 | 
					
						
							|  |  |  | char class_name::method_name##_doc[] = doc_string; \ | 
					
						
							| 
									
										
										
										
											2004-07-17 05:28:23 +00:00
										 |  |  | PyObject* class_name::Py##method_name(PyObject*, PyObject* args, PyObject*) | 
					
						
							| 
									
										
										
										
											2004-06-07 11:03:12 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*------------------------------
 | 
					
						
							|  |  |  |  * PyObjectPlus | 
					
						
							|  |  |  | ------------------------------*/ | 
					
						
							|  |  |  | typedef PyTypeObject * PyParentObject;				// Define the PyParent Object
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-11-22 10:19:19 +00:00
										 |  |  | class PyObjectPlus : public PyObject  | 
					
						
							|  |  |  | {				// The PyObjectPlus abstract class
 | 
					
						
							|  |  |  | 	Py_Header;							// Always start with Py_Header
 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  | 	PyObjectPlus(PyTypeObject *T); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2005-12-20 09:13:06 +00:00
										 |  |  | 	virtual ~PyObjectPlus();					// destructor
 | 
					
						
							| 
									
										
										
										
											2004-11-22 10:19:19 +00:00
										 |  |  | 	static void PyDestructor(PyObject *P)				// python wrapper
 | 
					
						
							|  |  |  | 	{   | 
					
						
							|  |  |  | 		delete ((PyObjectPlus *) P);   | 
					
						
							|  |  |  | 	}; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2005-12-20 09:13:06 +00:00
										 |  |  | //	void INCREF(void) {
 | 
					
						
							|  |  |  | //		  Py_INCREF(this);
 | 
					
						
							|  |  |  | //	  };				// incref method
 | 
					
						
							|  |  |  | //	void DECREF(void) {
 | 
					
						
							|  |  |  | //		  Py_DECREF(this);
 | 
					
						
							|  |  |  | //	  };				// decref method
 | 
					
						
							| 
									
										
										
										
											2004-11-22 10:19:19 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	virtual PyObject *_getattr(const STR_String& attr);			// _getattr method
 | 
					
						
							|  |  |  | 	static  PyObject *__getattr(PyObject * PyObj, char *attr) 	// This should be the entry in Type. 
 | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return ((PyObjectPlus*) PyObj)->_getattr(STR_String(attr));  | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	virtual int _delattr(const STR_String& attr); | 
					
						
							|  |  |  | 	virtual int _setattr(const STR_String& attr, PyObject *value);		// _setattr method
 | 
					
						
							|  |  |  | 	static  int __setattr(PyObject *PyObj, 			// This should be the entry in Type. 
 | 
					
						
							|  |  |  | 				char *attr,  | 
					
						
							|  |  |  | 				PyObject *value) | 
					
						
							|  |  |  | 	{  | 
					
						
							|  |  |  | 		if (!value) | 
					
						
							|  |  |  | 			return ((PyObjectPlus*) PyObj)->_delattr(attr); | 
					
						
							|  |  |  | 		return ((PyObjectPlus*) PyObj)->_setattr(STR_String(attr), value);   | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	virtual PyObject *_repr(void);				// _repr method
 | 
					
						
							|  |  |  | 	static  PyObject *__repr(PyObject *PyObj)			// This should be the entry in Type.
 | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return ((PyObjectPlus*) PyObj)->_repr();   | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 									// isA methods
 | 
					
						
							|  |  |  | 	bool isA(PyTypeObject *T); | 
					
						
							|  |  |  | 	bool isA(const char *mytypename); | 
					
						
							|  |  |  | 	PyObject *Py_isA(PyObject *args); | 
					
						
							|  |  |  | 	static PyObject *sPy_isA(PyObject *self, PyObject *args, PyObject *kwd) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return ((PyObjectPlus*)self)->Py_isA(args); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif //  _adr_py_lib_h_
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif //NO_EXP_PYTHON_EMBEDDING
 | 
					
						
							|  |  |  | 
 |