[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [19038] trunk/blender/source/gameengine: " object" and "objectLastCreated" attribute for actuators, deprecates getObject/setObject() & getLastCreatedObject()

Campbell Barton ideasman42 at gmail.com
Thu Feb 19 11:34:56 CET 2009


Revision: 19038
          http://projects.blender.org/plugins/scmsvn/viewcvs.php?view=rev&root=bf-blender&revision=19038
Author:   campbellbarton
Date:     2009-02-19 11:34:51 +0100 (Thu, 19 Feb 2009)

Log Message:
-----------
"object" and "objectLastCreated" attribute for actuators, deprecates getObject/setObject() & getLastCreatedObject()
also removed some warnings

Modified Paths:
--------------
    trunk/blender/source/gameengine/Converter/BL_ShapeActionActuator.h
    trunk/blender/source/gameengine/Ketsji/KX_CameraActuator.cpp
    trunk/blender/source/gameengine/Ketsji/KX_ParentActuator.cpp
    trunk/blender/source/gameengine/Ketsji/KX_ParentActuator.h
    trunk/blender/source/gameengine/Ketsji/KX_SCA_AddObjectActuator.cpp
    trunk/blender/source/gameengine/Ketsji/KX_SCA_AddObjectActuator.h
    trunk/blender/source/gameengine/Ketsji/KX_TrackToActuator.cpp
    trunk/blender/source/gameengine/Ketsji/KX_TrackToActuator.h
    trunk/blender/source/gameengine/PyDoc/KX_CameraActuator.py
    trunk/blender/source/gameengine/PyDoc/KX_ParentActuator.py
    trunk/blender/source/gameengine/PyDoc/KX_SCA_AddObjectActuator.py
    trunk/blender/source/gameengine/PyDoc/KX_TrackToActuator.py

Modified: trunk/blender/source/gameengine/Converter/BL_ShapeActionActuator.h
===================================================================
--- trunk/blender/source/gameengine/Converter/BL_ShapeActionActuator.h	2009-02-19 10:21:17 UTC (rev 19037)
+++ trunk/blender/source/gameengine/Converter/BL_ShapeActionActuator.h	2009-02-19 10:34:51 UTC (rev 19038)
@@ -169,8 +169,8 @@
 	short	m_playtype;
 	short	m_priority;
 	struct bAction *m_action;
+	STR_String	m_framepropname;
 	STR_String	m_propname;
-	STR_String	m_framepropname;
 	vector<float> m_blendshape;
 };
 

Modified: trunk/blender/source/gameengine/Ketsji/KX_CameraActuator.cpp
===================================================================
--- trunk/blender/source/gameengine/Ketsji/KX_CameraActuator.cpp	2009-02-19 10:21:17 UTC (rev 19037)
+++ trunk/blender/source/gameengine/Ketsji/KX_CameraActuator.cpp	2009-02-19 10:34:51 UTC (rev 19038)
@@ -398,9 +398,9 @@
 };
 
 PyMethodDef KX_CameraActuator::Methods[] = {
+	// ---> deprecated (all)
 	{"setObject",(PyCFunction) KX_CameraActuator::sPySetObject, METH_O,			(PY_METHODCHAR)SetObject_doc},
 	{"getObject",(PyCFunction) KX_CameraActuator::sPyGetObject, METH_VARARGS,	(PY_METHODCHAR)GetObject_doc},
-	// ---> deprecated
 	{"setMin"	,(PyCFunction) KX_CameraActuator::sPySetMin,	METH_VARARGS,	(PY_METHODCHAR)SetMin_doc},
 	{"getMin"	,(PyCFunction) KX_CameraActuator::sPyGetMin,	METH_NOARGS,	(PY_METHODCHAR)GetMin_doc},
 	{"setMax"	,(PyCFunction) KX_CameraActuator::sPySetMax,	METH_VARARGS,	(PY_METHODCHAR)SetMax_doc},
@@ -421,14 +421,40 @@
 };
 
 PyObject* KX_CameraActuator::_getattr(const STR_String& attr) {
-	PyObject* object = _getattr_self(Attributes, this, attr);
+	PyObject* object;
+	
+	if (attr == "object") {
+		if (!m_ob)	Py_RETURN_NONE;
+		else		return m_ob->AddRef();
+	}
+	
+	object = _getattr_self(Attributes, this, attr);
 	if (object != NULL)
 		return object;
 	_getattr_up(SCA_IActuator);
 }
 
 int KX_CameraActuator::_setattr(const STR_String& attr, PyObject* value) {
-	int ret = _setattr_self(Attributes, this, attr, value);
+	int ret;
+	
+	if (attr == "object") {
+		KX_GameObject *gameobj;
+		
+		if (!ConvertPythonToGameObject(value, &gameobj, true))
+			return 1; // ConvertPythonToGameObject sets the error
+		
+		if (m_ob != NULL)
+			m_ob->UnregisterActuator(this);	
+
+		m_ob = (SCA_IObject*)gameobj;
+		
+		if (m_ob)
+			m_ob->RegisterActuator(this);
+		
+		return 0;
+	}
+	
+	ret = _setattr_self(Attributes, this, attr, value);
 	if (ret >= 0)
 		return ret;
 	return SCA_IActuator::_setattr(attr, value);
@@ -442,6 +468,9 @@
 PyObject* KX_CameraActuator::PyGetObject(PyObject* self, PyObject* args)
 {
 	int ret_name_only = 1;
+	
+	ShowDeprecationWarning("getObject()", "the object property");
+	
 	if (!PyArg_ParseTuple(args, "|i", &ret_name_only))
 		return NULL;
 	
@@ -462,6 +491,8 @@
 {
 	KX_GameObject *gameobj;
 	
+	ShowDeprecationWarning("setObject()", "the object property");
+	
 	if (!ConvertPythonToGameObject(value, &gameobj, true))
 		return NULL; // ConvertPythonToGameObject sets the error
 	

Modified: trunk/blender/source/gameengine/Ketsji/KX_ParentActuator.cpp
===================================================================
--- trunk/blender/source/gameengine/Ketsji/KX_ParentActuator.cpp	2009-02-19 10:21:17 UTC (rev 19037)
+++ trunk/blender/source/gameengine/Ketsji/KX_ParentActuator.cpp	2009-02-19 10:34:51 UTC (rev 19038)
@@ -166,15 +166,44 @@
 };
 
 PyMethodDef KX_ParentActuator::Methods[] = {
+	// ---> deprecated (all)
 	{"setObject",         (PyCFunction) KX_ParentActuator::sPySetObject, METH_O, (PY_METHODCHAR)SetObject_doc},
 	{"getObject",         (PyCFunction) KX_ParentActuator::sPyGetObject, METH_VARARGS, (PY_METHODCHAR)GetObject_doc},
 	{NULL,NULL} //Sentinel
 };
 
-PyObject* KX_ParentActuator::_getattr(const STR_String& attr) {
+PyObject* KX_ParentActuator::_getattr(const STR_String& attr) {	
+	
+	if (attr == "object") {
+		if (!m_ob)	Py_RETURN_NONE;
+		else		return m_ob->AddRef();
+	}
+	
 	_getattr_up(SCA_IActuator);
 }
 
+int KX_ParentActuator::_setattr(const STR_String& attr, PyObject* value) {
+	
+	if (attr == "object") {
+		KX_GameObject *gameobj;
+		
+		if (!ConvertPythonToGameObject(value, &gameobj, true))
+			return 1; // ConvertPythonToGameObject sets the error
+		
+		if (m_ob != NULL)
+			m_ob->UnregisterActuator(this);	
+
+		m_ob = (SCA_IObject*)gameobj;
+		
+		if (m_ob)
+			m_ob->RegisterActuator(this);
+		
+		return 0;
+	}
+	
+	return SCA_IActuator::_setattr(attr, value);
+}
+
 /* 1. setObject                                                            */
 const char KX_ParentActuator::SetObject_doc[] = 
 "setObject(object)\n"
@@ -183,6 +212,8 @@
 PyObject* KX_ParentActuator::PySetObject(PyObject* self, PyObject* value) {
 	KX_GameObject *gameobj;
 	
+	ShowDeprecationWarning("setObject()", "the object property");
+	
 	if (!ConvertPythonToGameObject(value, &gameobj, true))
 		return NULL; // ConvertPythonToGameObject sets the error
 	
@@ -206,6 +237,9 @@
 PyObject* KX_ParentActuator::PyGetObject(PyObject* self, PyObject* args)
 {
 	int ret_name_only = 1;
+	
+	ShowDeprecationWarning("getObject()", "the object property");
+	
 	if (!PyArg_ParseTuple(args, "|i", &ret_name_only))
 		return NULL;
 	

Modified: trunk/blender/source/gameengine/Ketsji/KX_ParentActuator.h
===================================================================
--- trunk/blender/source/gameengine/Ketsji/KX_ParentActuator.h	2009-02-19 10:21:17 UTC (rev 19037)
+++ trunk/blender/source/gameengine/Ketsji/KX_ParentActuator.h	2009-02-19 10:34:51 UTC (rev 19038)
@@ -77,6 +77,7 @@
 	/* --------------------------------------------------------------------- */
 
 	virtual PyObject* _getattr(const STR_String& attr);
+	virtual int _setattr(const STR_String& attr, PyObject* value);
 
 	/* 1. setObject                                                            */
 	KX_PYMETHOD_DOC_O(KX_ParentActuator,SetObject);

Modified: trunk/blender/source/gameengine/Ketsji/KX_SCA_AddObjectActuator.cpp
===================================================================
--- trunk/blender/source/gameengine/Ketsji/KX_SCA_AddObjectActuator.cpp	2009-02-19 10:21:17 UTC (rev 19037)
+++ trunk/blender/source/gameengine/Ketsji/KX_SCA_AddObjectActuator.cpp	2009-02-19 10:34:51 UTC (rev 19038)
@@ -188,9 +188,7 @@
 	NULL
 };
 PyMethodDef KX_SCA_AddObjectActuator::Methods[] = {
-  {"setObject", (PyCFunction) KX_SCA_AddObjectActuator::sPySetObject, METH_O, (PY_METHODCHAR)SetObject_doc},
   {"setTime", (PyCFunction) KX_SCA_AddObjectActuator::sPySetTime, METH_O, (PY_METHODCHAR)SetTime_doc},
-  {"getObject", (PyCFunction) KX_SCA_AddObjectActuator::sPyGetObject, METH_VARARGS, (PY_METHODCHAR)GetObject_doc},
   {"getTime", (PyCFunction) KX_SCA_AddObjectActuator::sPyGetTime, METH_NOARGS, (PY_METHODCHAR)GetTime_doc},
   {"getLinearVelocity", (PyCFunction) KX_SCA_AddObjectActuator::sPyGetLinearVelocity, METH_NOARGS, (PY_METHODCHAR)GetLinearVelocity_doc},
   {"setLinearVelocity", (PyCFunction) KX_SCA_AddObjectActuator::sPySetLinearVelocity, METH_VARARGS, (PY_METHODCHAR)SetLinearVelocity_doc},
@@ -199,15 +197,50 @@
   {"getLastCreatedObject", (PyCFunction) KX_SCA_AddObjectActuator::sPyGetLastCreatedObject, METH_NOARGS,"getLastCreatedObject() : get the object handle to the last created object\n"},
   {"instantAddObject", (PyCFunction) KX_SCA_AddObjectActuator::sPyInstantAddObject, METH_NOARGS,"instantAddObject() : immediately add object without delay\n"},
   
+  // ---> deprecated
+  {"setObject", (PyCFunction) KX_SCA_AddObjectActuator::sPySetObject, METH_O, (PY_METHODCHAR)SetObject_doc},
+  {"getObject", (PyCFunction) KX_SCA_AddObjectActuator::sPyGetObject, METH_VARARGS, (PY_METHODCHAR)GetObject_doc},
+  
   {NULL,NULL} //Sentinel
 };
 
 
 PyObject* KX_SCA_AddObjectActuator::_getattr(const STR_String& attr)
 {
+	if (attr == "object") {
+		if (!m_OriginalObject)	Py_RETURN_NONE;
+		else					return m_OriginalObject->AddRef();
+	}
+	else if (attr == "objectLastCreated") {
+		if (!m_OriginalObject)	Py_RETURN_NONE;
+		else					return m_lastCreatedObject->AddRef();
+	}
+	
   _getattr_up(SCA_IActuator);
 }
 
+int KX_SCA_AddObjectActuator::_setattr(const STR_String& attr, PyObject* value) {
+	
+	if (attr == "object") {
+		KX_GameObject *gameobj;
+		
+		if (!ConvertPythonToGameObject(value, &gameobj, true))
+			return 1; // ConvertPythonToGameObject sets the error
+		
+		if (m_OriginalObject != NULL)
+			m_OriginalObject->UnregisterActuator(this);	
+
+		m_OriginalObject = (SCA_IObject*)gameobj;
+		
+		if (m_OriginalObject)
+			m_OriginalObject->RegisterActuator(this);
+		
+		return 0;
+	}
+	
+	return SCA_IActuator::_setattr(attr, value);
+}
+
 /* 1. setObject */
 const char KX_SCA_AddObjectActuator::SetObject_doc[] = 
 "setObject(object)\n"
@@ -218,6 +251,8 @@
 {
 	KX_GameObject *gameobj;
 	
+	ShowDeprecationWarning("setObject()", "the object property");
+	
 	if (!ConvertPythonToGameObject(value, &gameobj, true))
 		return NULL; // ConvertPythonToGameObject sets the error
 	
@@ -277,6 +312,9 @@
 PyObject* KX_SCA_AddObjectActuator::PyGetObject(PyObject* self, PyObject* args)
 {
 	int ret_name_only = 1;
+	
+	ShowDeprecationWarning("getObject()", "the object property");
+	
 	if (!PyArg_ParseTuple(args, "|i", &ret_name_only))
 		return NULL;
 	

Modified: trunk/blender/source/gameengine/Ketsji/KX_SCA_AddObjectActuator.h
===================================================================
--- trunk/blender/source/gameengine/Ketsji/KX_SCA_AddObjectActuator.h	2009-02-19 10:21:17 UTC (rev 19037)
+++ trunk/blender/source/gameengine/Ketsji/KX_SCA_AddObjectActuator.h	2009-02-19 10:34:51 UTC (rev 19038)
@@ -60,14 +60,17 @@
 
 	/// Linear velocity upon creation of the object. 
 	MT_Vector3  m_linear_velocity;
+	/// Apply the velocity locally 
+	bool m_localLinvFlag;
 	
 	/// Angular velocity upon creation of the object. 
 	MT_Vector3  m_angular_velocity;
-
 	/// Apply the velocity locally 
-	bool m_localLinvFlag;
-	bool m_localAngvFlag;
+	bool m_localAngvFlag; 
 	
+	
+	
+	
 	SCA_IObject*	m_lastCreatedObject;
 	
 public:
@@ -107,10 +110,8 @@
 	virtual bool 
 	Update();
 
-	virtual PyObject*  
-	_getattr(
-		const STR_String& attr
-	);
+	virtual PyObject* _getattr(const STR_String& attr);
+	virtual int _setattr(const STR_String& attr, PyObject* value);
 
 		SCA_IObject*	
 	GetLastCreatedObject(

Modified: trunk/blender/source/gameengine/Ketsji/KX_TrackToActuator.cpp
===================================================================

@@ Diff output truncated at 10240 characters. @@




More information about the Bf-blender-cvs mailing list