[Bf-blender-cvs] SVN commit: /data/svn/bf-blender [25908] trunk/blender/source/blender/ makesrna: rna/py api
Campbell Barton
ideasman42 at gmail.com
Tue Jan 12 00:40:03 CET 2010
Revision: 25908
http://projects.blender.org/plugins/scmsvn/viewcvs.php?view=rev&root=bf-blender&revision=25908
Author: campbellbarton
Date: 2010-01-12 00:40:01 +0100 (Tue, 12 Jan 2010)
Log Message:
-----------
rna/py api
bpy.data.groups.new()/remove()
bpy.data.actions.new()/remove()
Modified Paths:
--------------
trunk/blender/source/blender/makesrna/RNA_types.h
trunk/blender/source/blender/makesrna/intern/rna_main_api.c
Modified: trunk/blender/source/blender/makesrna/RNA_types.h
===================================================================
--- trunk/blender/source/blender/makesrna/RNA_types.h 2010-01-11 23:09:46 UTC (rev 25907)
+++ trunk/blender/source/blender/makesrna/RNA_types.h 2010-01-11 23:40:01 UTC (rev 25908)
@@ -333,6 +333,8 @@
#define MainLamps Main
#define MainObjects Main
#define MainTexts Main
+#define MainActions Main
+#define MainGroups Main
#ifdef __cplusplus
}
Modified: trunk/blender/source/blender/makesrna/intern/rna_main_api.c
===================================================================
--- trunk/blender/source/blender/makesrna/intern/rna_main_api.c 2010-01-11 23:09:46 UTC (rev 25907)
+++ trunk/blender/source/blender/makesrna/intern/rna_main_api.c 2010-01-11 23:40:01 UTC (rev 25908)
@@ -47,6 +47,8 @@
#include "BKE_texture.h"
#include "BKE_scene.h"
#include "BKE_text.h"
+#include "BKE_action.h"
+#include "BKE_group.h"
#include "DNA_armature_types.h"
#include "DNA_camera_types.h"
@@ -55,6 +57,7 @@
#include "DNA_mesh_types.h"
#include "DNA_object_types.h"
#include "DNA_text_types.h"
+#include "DNA_group_types.h"
#include "ED_screen.h"
@@ -179,6 +182,19 @@
/* XXX python now has invalid pointer? */
}
+Group *rna_Main_groups_new(Main *bmain, char* name)
+{
+ return add_group(name);
+}
+void rna_Main_groups_remove(Main *bmain, ReportList *reports, Group *group)
+{
+ free_group(group);
+ unlink_group(group);
+ group->id.us= 0;
+ free_libblock(&bmain->group, group);
+ /* XXX python now has invalid pointer? */
+}
+
Text *rna_Main_texts_new(Main *bmain, char* name)
{
return add_empty_text(name);
@@ -214,6 +230,23 @@
/* XXX python now has invalid pointer? */
}
+bAction *rna_Main_actions_new(Main *bmain, char* name)
+{
+ bAction *act= add_empty_action(name);
+ act->id.us--;
+ act->id.flag &= ~LIB_FAKEUSER;
+ return act;
+}
+void rna_Main_actions_remove(Main *bmain, ReportList *reports, bAction *act)
+{
+ if(act->id.us == 0)
+ free_libblock(&bmain->action, act);
+ else
+ BKE_reportf(reports, RPT_ERROR, "Action \"%s\" must have zero users to be removed, found %d.", act->id.name+2, act->id.us);
+
+ /* XXX python now has invalid pointer? */
+}
+
#else
void RNA_api_main(StructRNA *srna)
@@ -437,7 +470,27 @@
}
void RNA_def_main_groups(BlenderRNA *brna, PropertyRNA *cprop)
{
+ StructRNA *srna;
+ FunctionRNA *func;
+ PropertyRNA *parm;
+ RNA_def_property_srna(cprop, "MainGroups");
+ srna= RNA_def_struct(brna, "MainGroups", NULL);
+ RNA_def_struct_ui_text(srna, "Main Groups", "Collection of groups.");
+
+ func= RNA_def_function(srna, "new", "rna_Main_groups_new");
+ RNA_def_function_ui_description(func, "Add a new group to the main database");
+ parm= RNA_def_string(func, "name", "Group", 0, "", "New name for the datablock.");
+ RNA_def_property_flag(parm, PROP_REQUIRED);
+ /* return type */
+ parm= RNA_def_pointer(func, "group", "Group", "", "New group datablock.");
+ RNA_def_function_return(func, parm);
+
+ func= RNA_def_function(srna, "remove", "rna_Main_groups_remove");
+ RNA_def_function_flag(func, FUNC_USE_REPORTS);
+ RNA_def_function_ui_description(func, "Remove a group from the current blendfile.");
+ parm= RNA_def_pointer(func, "group", "Group", "", "Group to remove.");
+ RNA_def_property_flag(parm, PROP_REQUIRED);
}
void RNA_def_main_texts(BlenderRNA *brna, PropertyRNA *cprop)
{
@@ -503,7 +556,27 @@
}
void RNA_def_main_actions(BlenderRNA *brna, PropertyRNA *cprop)
{
+ StructRNA *srna;
+ FunctionRNA *func;
+ PropertyRNA *parm;
+ RNA_def_property_srna(cprop, "MainActions");
+ srna= RNA_def_struct(brna, "MainActions", NULL);
+ RNA_def_struct_ui_text(srna, "Main Actions", "Collection of actions.");
+
+ func= RNA_def_function(srna, "new", "rna_Main_actions_new");
+ RNA_def_function_ui_description(func, "Add a new action to the main database");
+ parm= RNA_def_string(func, "name", "Action", 0, "", "New name for the datablock.");
+ RNA_def_property_flag(parm, PROP_REQUIRED);
+ /* return type */
+ parm= RNA_def_pointer(func, "action", "Action", "", "New action datablock.");
+ RNA_def_function_return(func, parm);
+
+ func= RNA_def_function(srna, "remove", "rna_Main_actions_remove");
+ RNA_def_function_flag(func, FUNC_USE_REPORTS);
+ RNA_def_function_ui_description(func, "Remove a action from the current blendfile.");
+ parm= RNA_def_pointer(func, "action", "Action", "", "Action to remove.");
+ RNA_def_property_flag(parm, PROP_REQUIRED);
}
void RNA_def_main_particles(BlenderRNA *brna, PropertyRNA *cprop)
{
More information about the Bf-blender-cvs
mailing list