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"); _______________________________________________ Bf-blender-cvs mailing list Bf-blender-cvs@blender.org http://lists.blender.org/mailman/listinfo/bf-blender-cvs