2.50: svn merge https://svn.blender.org/svnroot/bf-blender/trunk/blender -r19323...
[blender.git] / source / gameengine / GameLogic / SCA_ILogicBrick.h
index 5199f66f409426e2c5823b62e796a10aeee9782a..e59d05ea0516f111bbcccf5a1f1581176dbde646 100644 (file)
@@ -1,15 +1,12 @@
 /**
  * $Id$
  *
- * ***** BEGIN GPL/BL DUAL LICENSE BLOCK *****
+ * ***** BEGIN GPL 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.
+ * of the License, or (at your option) any later version.
  *
  * This program is distributed in the hope that it will be useful,
  * but WITHOUT ANY WARRANTY; without even the implied warranty of
@@ -27,7 +24,7 @@
  *
  * Contributor(s): none yet.
  *
- * ***** END GPL/BL DUAL LICENSE BLOCK *****
+ * ***** END GPL LICENSE BLOCK *****
  */
 #ifndef __KX_ILOGICBRICK
 #define __KX_ILOGICBRICK
 #include "Value.h"
 #include "SCA_IObject.h"
 #include "BoolValue.h"
+#include "GEN_Map.h"
+#include "GEN_HashedPtr.h"
 
 class SCA_ILogicBrick : public CValue
 {
        Py_Header;
+protected:
        SCA_IObject*            m_gameobj;
        int                                     m_Execute_Priority;
        int                                     m_Execute_Ueber_Priority;
@@ -48,7 +48,6 @@ class SCA_ILogicBrick : public CValue
        STR_String                      m_text;
        STR_String                      m_name;
        //unsigned long         m_drawcolor;
-protected:
        void RegisterEvent(CValue* eventval);
        void RemoveEvent();
        CValue* GetEvent();
@@ -62,13 +61,15 @@ public:
 
        SCA_IObject*    GetParent();
        virtual void    ReParent(SCA_IObject* parent);
+       virtual void    Relink(GEN_Map<GEN_HashedPtr, void*> *obj_map);
+       virtual void Delete() { Release(); }
 
        // act as a BoolValue (with value IsPositiveTrigger)
        virtual CValue* Calc(VALUE_OPERATOR op, CValue *val);
        virtual CValue* CalcFinal(VALUE_DATA_TYPE dtype, VALUE_OPERATOR op, CValue *val);
 
        virtual const STR_String &      GetText();
-       virtual float           GetNumber();
+       virtual double          GetNumber();
        virtual STR_String      GetName();
        virtual void            SetName(STR_String name);
        virtual void            ReplicaSetName(STR_String name);
@@ -78,16 +79,22 @@ public:
 
        virtual bool            LessComparedTo(SCA_ILogicBrick* other);
        
-       virtual PyObject* _getattr(const STR_String& attr);
+       virtual PyObject* py_getattro(PyObject *attr);
+       virtual int py_setattro(PyObject *attr, PyObject *value);
 
        static class SCA_LogicManager*  m_sCurrentLogicManager;
 
 
        // python methods
 
-       KX_PYMETHOD(SCA_ILogicBrick,GetOwner);
-       KX_PYMETHOD(SCA_ILogicBrick,SetExecutePriority);
-       KX_PYMETHOD(SCA_ILogicBrick,GetExecutePriority);
+       KX_PYMETHOD_NOARGS(SCA_ILogicBrick,GetOwner);
+       KX_PYMETHOD_VARARGS(SCA_ILogicBrick,SetExecutePriority);
+       KX_PYMETHOD_NOARGS(SCA_ILogicBrick,GetExecutePriority);
+       
+       static PyObject*        pyattr_get_owner(void *self_v, const KX_PYATTRIBUTE_DEF *attrdef);
+
+       // check that attribute is a property
+       static int CheckProperty(void *self, const PyAttributeDef *attrdef);
 
        enum KX_BOOL_TYPE {
                KX_BOOL_NODEF = 0,