[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [17646] branches/blender2.5/blender/source /blender/makesrna: * controller structs, bController, bExpressionCont and bPythoncont RNFied\n*controllers are available in objects\n* some typos in rna_sensor

Hamed Zaghaghi hamed.zaghaghi at gmail.com
Sun Nov 30 15:40:03 CET 2008


Revision: 17646
          http://projects.blender.org/plugins/scmsvn/viewcvs.php?view=rev&root=bf-blender&revision=17646
Author:   zaghaghi
Date:     2008-11-30 15:40:00 +0100 (Sun, 30 Nov 2008)

Log Message:
-----------
* controller structs, bController, bExpressionCont and bPythoncont RNFied\n*controllers are available in objects\n* some typos in rna_sensor

Modified Paths:
--------------
    branches/blender2.5/blender/source/blender/makesrna/RNA_access.h
    branches/blender2.5/blender/source/blender/makesrna/intern/makesrna.c
    branches/blender2.5/blender/source/blender/makesrna/intern/rna_internal.h
    branches/blender2.5/blender/source/blender/makesrna/intern/rna_object.c
    branches/blender2.5/blender/source/blender/makesrna/intern/rna_sensor.c

Added Paths:
-----------
    branches/blender2.5/blender/source/blender/makesrna/intern/rna_controller.c

Modified: branches/blender2.5/blender/source/blender/makesrna/RNA_access.h
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/RNA_access.h	2008-11-30 14:00:14 UTC (rev 17645)
+++ branches/blender2.5/blender/source/blender/makesrna/RNA_access.h	2008-11-30 14:40:00 UTC (rev 17646)
@@ -95,6 +95,7 @@
 extern StructRNA RNA_JoystickSensor;
 extern StructRNA RNA_ActuatorSensor;
 extern StructRNA RNA_DelaySensor;
+extern StructRNA RNA_Controller;
 extern StructRNA RNA_Camera;
 extern StructRNA RNA_Group;
 /* Pointer

Modified: branches/blender2.5/blender/source/blender/makesrna/intern/makesrna.c
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/makesrna.c	2008-11-30 14:00:14 UTC (rev 17645)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/makesrna.c	2008-11-30 14:40:00 UTC (rev 17646)
@@ -888,6 +888,7 @@
 	{"rna_screen.c", RNA_def_screen},
 	{"rna_wm.c", RNA_def_wm},
 	{"rna_sensor.c", RNA_def_sensor},
+	{"rna_controller.c", RNA_def_controller},
 	{"rna_camera.c", RNA_def_camera},
 	{"rna_group.c", RNA_def_group},
 	{NULL, NULL}};

Added: branches/blender2.5/blender/source/blender/makesrna/intern/rna_controller.c
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/rna_controller.c	                        (rev 0)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_controller.c	2008-11-30 14:40:00 UTC (rev 17646)
@@ -0,0 +1,106 @@
+/**
+ * $Id$
+ *
+ * ***** 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.
+ *
+ * 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.
+ *
+ * Contributor(s): Blender Foundation (2008).
+ *
+ * ***** END GPL LICENSE BLOCK *****
+ */
+
+#include <stdlib.h>
+
+#include "RNA_access.h"
+#include "RNA_define.h"
+#include "RNA_types.h"
+
+#include "rna_internal.h"
+
+#include "DNA_controller_types.h"
+
+#ifdef RNA_RUNTIME
+static struct StructRNA* rna_Controller_data_type(struct PointerRNA *ptr)
+{
+	bController *controller= (bController*)ptr->data;
+	switch(controller->type){
+		case CONT_LOGIC_AND:
+		case CONT_LOGIC_OR:
+		case CONT_LOGIC_NAND:
+		case CONT_LOGIC_NOR:
+		case CONT_LOGIC_XOR:
+		case CONT_LOGIC_XNOR:
+			return NULL;
+ 		case CONT_EXPRESSION:
+			return &RNA_ExpressionCont;
+		case CONT_PYTHON:
+			return &RNA_PythonCont;
+	}
+	return NULL;
+}
+#else
+
+void RNA_def_controller(BlenderRNA *brna)
+{
+	StructRNA *srna;
+	PropertyRNA *prop;
+	static EnumPropertyItem controller_types_items[] ={
+		{CONT_LOGIC_AND, "LOGICAND", "Logic And", ""},
+		{CONT_LOGIC_OR, "LOGICOR", "Logic Or", ""},
+		{CONT_LOGIC_NAND, "LOGICNAND", "Logic Nand", ""},
+		{CONT_LOGIC_NOR, "LOGICNOR", "Logic Nor", ""},
+		{CONT_LOGIC_XOR, "LOGICXOR", "Logic Xor", ""},
+		{CONT_LOGIC_XNOR, "LOGICXNOR", "Logic Xnor", ""},
+		{CONT_EXPRESSION, "EXPRESSION", "Expression", ""},
+		{CONT_PYTHON, "PYTHON", "Python Script", ""},
+		{0, NULL, NULL, NULL}};
+
+	srna= RNA_def_struct(brna, "Controller", NULL , "Controller");
+	RNA_def_struct_sdna(srna, "bController");
+
+	prop= RNA_def_property(srna, "controller_name", PROP_STRING, PROP_NONE);
+	RNA_def_property_string_sdna(prop, NULL, "name");
+	RNA_def_property_string_maxlength(prop, 31);
+	RNA_def_property_ui_text(prop, "Name", "Controller name.");
+
+	/* type is not editable, would need to do proper data free/alloc */
+	prop= RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
+	RNA_def_property_flag(prop, PROP_NOT_EDITABLE);
+	RNA_def_property_enum_items(prop, controller_types_items);
+	RNA_def_property_ui_text(prop, "Controller Types", "Controller types.");
+
+	prop= RNA_def_property(srna, "data", PROP_POINTER, PROP_NONE);
+	RNA_def_property_ui_text(prop, "Data", "Controller data.");
+	RNA_def_property_pointer_funcs(prop, NULL, "rna_Controller_data_type", NULL);
+
+	srna= RNA_def_struct(brna, "ExpressionCont", NULL , "ExpressionCont");
+	RNA_def_struct_sdna(srna, "bExpressionCont");
+
+	prop= RNA_def_property(srna, "expression", PROP_STRING, PROP_NONE);
+	RNA_def_property_string_sdna(prop, NULL, "str");
+	RNA_def_property_string_maxlength(prop, 127);
+	RNA_def_property_ui_text(prop, "Expression", "Expression.");
+
+	srna= RNA_def_struct(brna, "PythonCont", NULL , "PythonCont");
+	RNA_def_struct_sdna(srna, "bPythonCont");
+
+	prop= RNA_def_property(srna, "text", PROP_POINTER, PROP_NONE);
+	RNA_def_property_struct_type(prop, "ID");
+	RNA_def_property_ui_text(prop, "Python Text", "Python text.");
+}
+
+#endif
+

Modified: branches/blender2.5/blender/source/blender/makesrna/intern/rna_internal.h
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/rna_internal.h	2008-11-30 14:00:14 UTC (rev 17645)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_internal.h	2008-11-30 14:40:00 UTC (rev 17646)
@@ -93,6 +93,7 @@
 void RNA_def_screen(struct BlenderRNA *brna);
 void RNA_def_wm(struct BlenderRNA *brna);
 void RNA_def_sensor(struct BlenderRNA *brna);
+void RNA_def_controller(struct BlenderRNA *brna);
 void RNA_def_camera(struct BlenderRNA *brna);
 void RNA_def_group(struct BlenderRNA *brna);
 

Modified: branches/blender2.5/blender/source/blender/makesrna/intern/rna_object.c
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/rna_object.c	2008-11-30 14:00:14 UTC (rev 17645)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_object.c	2008-11-30 14:40:00 UTC (rev 17646)
@@ -61,6 +61,11 @@
 	prop= RNA_def_property(srna, "sensors", PROP_COLLECTION, PROP_NONE);
 	RNA_def_property_struct_type(prop, "Sensor");
 	RNA_def_property_ui_text(prop, "Sensors", "Sensors of this object.");
+
+	prop= RNA_def_property(srna, "controllers", PROP_COLLECTION, PROP_NONE);
+	RNA_def_property_struct_type(prop, "Controller");
+	RNA_def_property_ui_text(prop, "Controller", "Controllers of this object.");
+
 }
 
 #endif

Modified: branches/blender2.5/blender/source/blender/makesrna/intern/rna_sensor.c
===================================================================
--- branches/blender2.5/blender/source/blender/makesrna/intern/rna_sensor.c	2008-11-30 14:00:14 UTC (rev 17645)
+++ branches/blender2.5/blender/source/blender/makesrna/intern/rna_sensor.c	2008-11-30 14:40:00 UTC (rev 17646)
@@ -107,7 +107,7 @@
 	prop= RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
 	RNA_def_property_flag(prop, PROP_NOT_EDITABLE);
 	RNA_def_property_enum_items(prop, sensor_types_items);
-	RNA_def_property_ui_text(prop, "Sensor types", "Sensor Types.");
+	RNA_def_property_ui_text(prop, "Sensor Types", "Sensor types.");
 
 	prop= RNA_def_property(srna, "invert", PROP_BOOLEAN, PROP_NONE);
 	RNA_def_property_ui_text(prop, "Invert Output", "Invert the level(output) of this sensor.");
@@ -147,7 +147,7 @@
 	prop= RNA_def_property(srna, "property", PROP_STRING, PROP_NONE);
 	RNA_def_property_string_sdna(prop, NULL, "name");
 	RNA_def_property_string_maxlength(prop, 31);
-	RNA_def_property_ui_text(prop, "Property", "Only llok for objects with this property.");
+	RNA_def_property_ui_text(prop, "Property", "Only look for objects with this property.");
 
 	prop= RNA_def_property(srna, "distance", PROP_INT, PROP_NONE);
 	RNA_def_property_int_sdna(prop, NULL, "dist");





More information about the Bf-blender-cvs mailing list