RNA: make curve and metaball update functions consistent with
authorBrecht Van Lommel <brechtvanlommel@pandora.be>
Mon, 10 Aug 2009 21:10:09 +0000 (21:10 +0000)
committerBrecht Van Lommel <brechtvanlommel@pandora.be>
Mon, 10 Aug 2009 21:10:09 +0000 (21:10 +0000)
others, these cannot assume the existence of an edit object
or active object.

source/blender/makesrna/intern/rna_curve.c
source/blender/makesrna/intern/rna_meta.c

index 92b4dead516349fe0356e67a8f49624addc3870e..62786dd56cf043b92dba7bbfab60c96685b78f0a 100644 (file)
@@ -55,6 +55,7 @@ EnumPropertyItem beztriple_interpolation_mode_items[] = {
 
 #include "BKE_curve.h"
 #include "BKE_depsgraph.h"
+#include "BKE_main.h"
 
 #include "WM_api.h"
 #include "WM_types.h"
@@ -148,13 +149,20 @@ static void rna_BPoint_array_begin(CollectionPropertyIterator *iter, PointerRNA
        rna_iterator_array_begin(iter, (void*)nu->bp, sizeof(BPoint*), nu->pntsv>0 ? nu->pntsu*nu->pntsv : nu->pntsu, 0, NULL);
 }
 
-static void rna_Curve_update(bContext *C, PointerRNA *ptr)
+static void rna_Curve_update_data(bContext *C, PointerRNA *ptr)
 {
+       Main *bmain= CTX_data_main(C);
        Scene *scene= CTX_data_scene(C);
-       Object *obedit= CTX_data_edit_object(C);
-
-       DAG_object_flush_update(scene, obedit, OB_RECALC_DATA);
-       WM_event_add_notifier(C, NC_OBJECT|ND_GEOM_DATA, scene);
+       Curve *cu= ptr->id.data;
+       Object *ob;
+
+       for(ob=bmain->object.first; ob; ob= ob->id.next) {
+               if(ob->data == cu) {
+                       /* XXX this will loop over all objects again (slow) */
+                       DAG_object_flush_update(scene, ob, OB_RECALC_DATA);
+                       WM_event_add_notifier(C, NC_OBJECT|ND_GEOM_DATA, ob);
+               }
+       }
 }
 
 #else
@@ -172,38 +180,38 @@ static void rna_def_bpoint(BlenderRNA *brna)
        prop= RNA_def_property(srna, "selected", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "f1", 0);
        RNA_def_property_ui_text(prop, "Selected", "Selection status");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "hidden", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "hide", 0);
        RNA_def_property_ui_text(prop, "Hidden", "Visibility status");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        /* Vector value */
        prop= RNA_def_property(srna, "point", PROP_FLOAT, PROP_VECTOR);
        RNA_def_property_array(prop, 4);
        RNA_def_property_float_sdna(prop, NULL, "vec");
        RNA_def_property_ui_text(prop, "Point", "Point coordinates");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        /* Number values */
        prop= RNA_def_property(srna, "tilt", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "alfa");
        /*RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);*/
        RNA_def_property_ui_text(prop, "Tilt", "Tilt in 3d View");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "weight", PROP_FLOAT, PROP_NONE);
        RNA_def_property_range(prop, 0.01f, 100.0f);
        RNA_def_property_ui_text(prop, "Weight", "Softbody goal weight");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "bevel_radius", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "radius");
        /*RNA_def_property_range(prop, 0.0f, 1.0f);*/
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Bevel Radius", "Radius for bevelling");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 }
 
 static void rna_def_beztriple(BlenderRNA *brna)
@@ -219,80 +227,80 @@ static void rna_def_beztriple(BlenderRNA *brna)
        prop= RNA_def_property(srna, "selected_handle1", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "f1", 0);
        RNA_def_property_ui_text(prop, "Handle 1 selected", "Handle 1 selection status");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "selected_handle2", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "f3", 0);
        RNA_def_property_ui_text(prop, "Handle 2 selected", "Handle 2 selection status");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "selected_control_point", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "f2", 0);
        RNA_def_property_ui_text(prop, "Control Point selected", "Control point selection status");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "hidden", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "hide", 0);
        RNA_def_property_ui_text(prop, "Hidden", "Visibility status");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        /* Enums */
        prop= RNA_def_property(srna, "handle1_type", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "h1");
        RNA_def_property_enum_items(prop, beztriple_handle_type_items);
        RNA_def_property_ui_text(prop, "Handle 1 Type", "Handle types");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "handle2_type", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "h2");
        RNA_def_property_enum_items(prop, beztriple_handle_type_items);
        RNA_def_property_ui_text(prop, "Handle 2 Type", "Handle types");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "interpolation", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "ipo");
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
        RNA_def_property_enum_items(prop, beztriple_interpolation_mode_items);
        RNA_def_property_ui_text(prop, "Interpolation", "(For F-Curves Only) Interpolation to use for segment of curve starting from current BezTriple.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        /* Vector values */
        prop= RNA_def_property(srna, "handle1", PROP_FLOAT, PROP_VECTOR);
        RNA_def_property_array(prop, 3);
        RNA_def_property_float_funcs(prop, "rna_BezTriple_handle1_get", "rna_BezTriple_handle1_set", NULL);
        RNA_def_property_ui_text(prop, "Handle 1", "Coordinates of the first handle");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "control_point", PROP_FLOAT, PROP_VECTOR);
        RNA_def_property_array(prop, 3);
        RNA_def_property_float_funcs(prop, "rna_BezTriple_ctrlpoint_get", "rna_BezTriple_ctrlpoint_set", NULL);
        RNA_def_property_ui_text(prop, "Control Point", "Coordinates of the control point");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "handle2", PROP_FLOAT, PROP_VECTOR);
        RNA_def_property_array(prop, 3);
        RNA_def_property_float_funcs(prop, "rna_BezTriple_handle2_get", "rna_BezTriple_handle2_set", NULL);
        RNA_def_property_ui_text(prop, "Handle 2", "Coordinates of the second handle");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        /* Number values */
        prop= RNA_def_property(srna, "tilt", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "alfa");
        /*RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);*/
        RNA_def_property_ui_text(prop, "Tilt", "Tilt in 3d View");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "weight", PROP_FLOAT, PROP_NONE);
        RNA_def_property_range(prop, 0.01f, 100.0f);
        RNA_def_property_ui_text(prop, "Weight", "Softbody goal weight");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "bevel_radius", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "radius");
        /*RNA_def_property_range(prop, 0.0f, 1.0f);*/
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Bevel Radius", "Radius for bevelling");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 }
 
 static void rna_def_path(BlenderRNA *brna, StructRNA *srna)
@@ -304,28 +312,28 @@ static void rna_def_path(BlenderRNA *brna, StructRNA *srna)
        RNA_def_property_int_sdna(prop, NULL, "pathlen");
        RNA_def_property_range(prop, 1, 32767);
        RNA_def_property_ui_text(prop, "Path Length", "If no speed IPO was set, the length of path in frames.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        /* flags */
        prop= RNA_def_property(srna, "path", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_PATH);
        RNA_def_property_ui_text(prop, "Path", "Enable the curve to become a translation path.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "follow", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_FOLLOW);
        RNA_def_property_ui_text(prop, "Follow", "Make curve path children to rotate along the path.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "stretch", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_STRETCH);
        RNA_def_property_ui_text(prop, "Stretch", "Option for curve-deform: makes deformed child to stretch along entire path.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "offset_path_distance", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_OFFS_PATHDIST);
        RNA_def_property_ui_text(prop, "Offset Path Distance", "Children will use TimeOffs value as path distance offset.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 }
 
 static void rna_def_nurbs(BlenderRNA *brna, StructRNA *srna)
@@ -336,12 +344,12 @@ static void rna_def_nurbs(BlenderRNA *brna, StructRNA *srna)
        prop= RNA_def_property(srna, "uv_orco", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_UV_ORCO);
        RNA_def_property_ui_text(prop, "UV Orco", "Forces to use UV coordinates for texture mapping 'orco'.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "vertex_normal_flip", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_negative_sdna(prop, NULL, "flag", CU_NOPUNOFLIP);
        RNA_def_property_ui_text(prop, "Vertex Normal Flip", "Flip vertex normals towards the camera during render");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 }
 
 static void rna_def_font(BlenderRNA *brna, StructRNA *srna)
@@ -360,73 +368,74 @@ static void rna_def_font(BlenderRNA *brna, StructRNA *srna)
        prop= RNA_def_property(srna, "spacemode", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_items(prop, prop_align_items);
        RNA_def_property_ui_text(prop, "Text Align", "Text align from the object center.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        /* number values */
        prop= RNA_def_property(srna, "text_size", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "fsize");
        RNA_def_property_range(prop, 0.1f, 10.0f);
        RNA_def_property_ui_text(prop, "Font size", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "line_dist", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "linedist");
        RNA_def_property_range(prop, 0.0f, 10.0f);
        RNA_def_property_ui_text(prop, "Distance between lines of text", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "word_spacing", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "wordspace");
        RNA_def_property_range(prop, 0.0f, 10.0f);
        RNA_def_property_ui_text(prop, "Spacing between words", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "spacing", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "spacing");
        RNA_def_property_range(prop, 0.0f, 10.0f);
        RNA_def_property_ui_text(prop, "Global spacing between characters", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "shear", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "shear");
        RNA_def_property_range(prop, -1.0f, 1.0f);
        RNA_def_property_ui_text(prop, "Shear", "Italic angle of the characters");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "x_offset", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "xof");
        RNA_def_property_range(prop, -50.0f, 50.0f);
        RNA_def_property_ui_text(prop, "X Offset", "Horizontal offset from the object center");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "y_offset", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "yof");
        RNA_def_property_range(prop, -50.0f, 50.0f);
        RNA_def_property_ui_text(prop, "Y Offset", "Vertical offset from the object center");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "ul_position", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "ulpos");
        RNA_def_property_range(prop, -0.2f, 0.8f);
        RNA_def_property_ui_text(prop, "Underline position", "Vertical position of underline");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "ul_height", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "ulheight");
        RNA_def_property_range(prop, -0.2f, 0.8f);
        RNA_def_property_ui_text(prop, "Underline thickness", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "active_textbox", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "actbox");
        RNA_def_property_range(prop, 0, 100);
        RNA_def_property_ui_text(prop, "The active text box", "");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        /* strings */
        prop= RNA_def_property(srna, "family", PROP_STRING, PROP_NONE);
        RNA_def_property_string_maxlength(prop, 21);
        RNA_def_property_ui_text(prop, "Family", "Blender uses font from selfmade objects.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "str", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "str");
@@ -440,26 +449,28 @@ static void rna_def_font(BlenderRNA *brna, StructRNA *srna)
        RNA_def_property_pointer_sdna(prop, NULL, "textoncurve");
        RNA_def_property_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Text on Curve", "Curve deforming text object.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "font", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "vfont");
        RNA_def_property_ui_text(prop, "Font", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "textbox", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "tb");
        RNA_def_property_ui_text(prop, "Textbox", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "edit_format", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "curinfo");
        RNA_def_property_ui_text(prop, "Edit Format", "Editing settings character formatting.");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        /* flags */
        prop= RNA_def_property(srna, "fast", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_FAST);
        RNA_def_property_ui_text(prop, "Fast", "Don't fill polygons while editing.");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 }
 
 static void rna_def_textbox(BlenderRNA *brna)
@@ -475,25 +486,25 @@ static void rna_def_textbox(BlenderRNA *brna)
        RNA_def_property_float_sdna(prop, NULL, "x");
        RNA_def_property_range(prop, -50.0f, 50.0f);
        RNA_def_property_ui_text(prop, "Textbox X Offset", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "y", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "y");
        RNA_def_property_range(prop, -50.0f, 50.0f);
        RNA_def_property_ui_text(prop, "Textbox Y Offset", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "width", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "w");
        RNA_def_property_range(prop, 0.0f, 50.0f);
        RNA_def_property_ui_text(prop, "Textbox Width", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "height", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "h");
        RNA_def_property_range(prop, 0.0f, 50.0f);
        RNA_def_property_ui_text(prop, "Textbox Height", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 }
 
 static void rna_def_charinfo(BlenderRNA *brna)
@@ -509,27 +520,27 @@ static void rna_def_charinfo(BlenderRNA *brna)
        prop= RNA_def_property(srna, "style", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_STYLE);
        RNA_def_property_ui_text(prop, "Style", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "bold", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_BOLD);
        RNA_def_property_ui_text(prop, "Bold", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "italic", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_ITALIC);
        RNA_def_property_ui_text(prop, "Italic", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "underline", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_UNDERLINE);
        RNA_def_property_ui_text(prop, "Underline", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "wrap", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_WRAP);
        RNA_def_property_ui_text(prop, "Wrap", "");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 }
 
 static void rna_def_surface(BlenderRNA *brna)
@@ -587,37 +598,37 @@ static void rna_def_curve(BlenderRNA *brna)
        RNA_def_property_range(prop, 0, 32);
        RNA_def_property_ui_range(prop, 0, 32, 1.0, 0);
        RNA_def_property_ui_text(prop, "Bevel Resolution", "Bevel resolution when depth is non-zero and no specific bevel object has been defined.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "width", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "width");
        RNA_def_property_ui_range(prop, 0, 2.0, 0.1, 0);
        RNA_def_property_ui_text(prop, "Width", "Scale the original width (1.0) based on given factor.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "extrude", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "ext1");
        RNA_def_property_ui_range(prop, 0, 100.0, 0.1, 0);
        RNA_def_property_ui_text(prop, "Extrude", "Amount of curve extrusion when not using a bevel object.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "bevel_depth", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "ext2");
        RNA_def_property_ui_range(prop, 0, 100.0, 0.1, 0);
        RNA_def_property_ui_text(prop, "Bevel Depth", "Bevel depth when not using a bevel object.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "resolution_u", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "resolu");
        RNA_def_property_ui_range(prop, 1, 1024, 1, 0);
        RNA_def_property_ui_text(prop, "Resolution U", "Surface resolution in U direction.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "resolution_v", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "resolv");
        RNA_def_property_ui_range(prop, 1, 1024, 1, 0);
        RNA_def_property_ui_text(prop, "Resolution V", "Surface resolution in V direction.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "render_resolution_u", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "resolu_ren");
@@ -633,41 +644,41 @@ static void rna_def_curve(BlenderRNA *brna)
        prop= RNA_def_property(srna, "eval_time", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "ctime");
        RNA_def_property_ui_text(prop, "Evaluation Time", "Parametric position along the length of the curve that Objects 'following' it should be at.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        /* pointers */
        prop= RNA_def_property(srna, "bevel_object", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "bevobj");
        RNA_def_property_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Bevel Object", "Curve object name that defines the bevel shape.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "taper_object", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "taperobj");
        RNA_def_property_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Taper Object", "Curve object name that defines the taper (width).");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        /* Flags */
        prop= RNA_def_property(srna, "curve_2d", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_negative_sdna(prop, NULL, "flag", CU_3D);
        RNA_def_property_ui_text(prop, "2D Curve", "Define curve in two dimensions only. Note that fill only works when this is enabled.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "front", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_FRONT);
        RNA_def_property_ui_text(prop, "Front", "Draw filled front for extruded/beveled curves.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "back", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_BACK);
        RNA_def_property_ui_text(prop, "Back", "Draw filled back for extruded/beveled curves.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "retopo", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_RETOPO);
        RNA_def_property_ui_text(prop, "Retopo", "Turn on the re-topology tool.");
-       RNA_def_property_update(prop, 0, "rna_Curve_update");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 }
 
 static void rna_def_curve_nurb(BlenderRNA *brna)
@@ -701,89 +712,107 @@ static void rna_def_curve_nurb(BlenderRNA *brna)
        RNA_def_property_enum_sdna(prop, NULL, "tilt_interp");
        RNA_def_property_enum_items(prop, spline_interpolation_items);
        RNA_def_property_ui_text(prop, "Tilt Interpolation", "The type of tilt interpolation for 3D, Bezier curves.");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "radius_interpolation", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "radius_interp");
        RNA_def_property_enum_items(prop, spline_interpolation_items);
        RNA_def_property_ui_text(prop, "Radius Interpolation", "The type of radius interpolation for Bezier curves.");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
 
        prop= RNA_def_property(srna, "point_count_u", PROP_INT, PROP_NONE);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE); /* editing this needs knot recalc*/
        RNA_def_property_int_sdna(prop, NULL, "pntsu");
        RNA_def_property_ui_text(prop, "Points U", "Total number points for the curve or surface in the U direction");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "point_count_v", PROP_INT, PROP_NONE);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE); /* editing this needs knot recalc*/
        RNA_def_property_int_sdna(prop, NULL, "pntsv");
        RNA_def_property_ui_text(prop, "Points V", "Total number points for the surface on the V direction");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
 
        prop= RNA_def_property(srna, "order_u", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "orderu");
        RNA_def_property_range(prop, 2, 6);
        RNA_def_property_ui_text(prop, "Order U", "Nurbs order in the U direction (For curves and surfaces), Higher values let points influence a greater area");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "order_v", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "orderv");
        RNA_def_property_range(prop, 2, 6);
        RNA_def_property_ui_text(prop, "Order V", "Nurbs order in the V direction (For surfaces only), Higher values let points influence a greater area");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
 
        prop= RNA_def_property(srna, "resolution_u", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "resolu");
        RNA_def_property_range(prop, 1, 1024);
        RNA_def_property_ui_text(prop, "Resolution U", "Curve or Surface subdivisions per segment");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "resolution_v", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "resolv");
        RNA_def_property_range(prop, 1, 1024);
        RNA_def_property_ui_text(prop, "Resolution V", "Surface subdivisions per segment");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "cyclic_u", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flagu", CU_CYCLIC);
        RNA_def_property_ui_text(prop, "Cyclic U", "Make this curve or surface a closed loop in the U direction.");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "cyclic_v", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flagv", CU_CYCLIC);
        RNA_def_property_ui_text(prop, "Cyclic V", "Make this surface a closed loop in the V direction.");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
 
        /* Note, endpoint and bezier flags should never be on at the same time! */
        prop= RNA_def_property(srna, "endpoint_u", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flagu", 2);
        RNA_def_property_ui_text(prop, "Endpoint U", "Make this nurbs curve or surface meet the endpoints in the U direction (Cyclic U must be disabled).");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "endpoint_v", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flagv", 2);
        RNA_def_property_ui_text(prop, "Endpoint V", "Make this nurbs surface meet the endpoints in the V direction (Cyclic V must be disabled).");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "bezier_u", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flagu", 4);
        RNA_def_property_ui_text(prop, "Bezier U", "Make this nurbs curve or surface act like a bezier spline in the U direction (Order U must be 3 or 4, Cyclic U must be disabled).");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "bezier_v", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flagv", 4);
        RNA_def_property_ui_text(prop, "Bezier V", "Make this nurbs surface act like a bezier spline in the V direction (Order V must be 3 or 4, Cyclic V must be disabled).");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
 
        prop= RNA_def_property(srna, "smooth", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", CU_SMOOTH);
        RNA_def_property_ui_text(prop, "Smooth", "Smooth the normals of the surface or beveled curve.");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "hide", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "hide", 1);
        RNA_def_property_ui_text(prop, "Hide", "Hide this curve in editmode.");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 
        prop= RNA_def_property(srna, "material_index", PROP_INT, PROP_UNSIGNED);
        RNA_def_property_int_sdna(prop, NULL, "mat_nr");
        RNA_def_property_ui_text(prop, "Material Index", "");
        RNA_def_property_int_funcs(prop, NULL, NULL, "rna_Curve_material_index_range");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
        
        prop= RNA_def_property(srna, "character_index", PROP_INT, PROP_UNSIGNED);
        RNA_def_property_int_sdna(prop, NULL, "charidx");
        RNA_def_property_clear_flag(prop, PROP_EDITABLE); /* editing this needs knot recalc*/
-       RNA_def_property_ui_text(prop, "Character Index", "the location of this character in the text data (only for text curves)");
+       RNA_def_property_ui_text(prop, "Character Index", "Location of this character in the text data (only for text curves)");
+       RNA_def_property_update(prop, 0, "rna_Curve_update_data");
 }
 
 void RNA_def_curve(BlenderRNA *brna)
index ad16c5a7c5c4d8a747a1a858012918380ca44ada..75922fdf2a0afd64ce8ee140d9082260958185a5 100644 (file)
@@ -39,6 +39,7 @@
 
 #include "BKE_mball.h"
 #include "BKE_depsgraph.h"
+#include "BKE_main.h"
 
 #include "WM_types.h"
 #include "WM_api.h"
@@ -51,29 +52,19 @@ static int rna_Meta_texspace_editable(PointerRNA *ptr)
 
 static void rna_MetaBall_update_data(bContext *C, PointerRNA *ptr)
 {
+       Main *bmain= CTX_data_main(C);
        Scene *scene= CTX_data_scene(C);
-       Object *active_object = CTX_data_active_object(C);
-       Object *obedit= CTX_data_edit_object(C);
-
-       if(obedit) {
-               copy_mball_properties(scene, obedit);
-               WM_event_add_notifier(C, NC_OBJECT|ND_GEOM_DATA, obedit);
-               DAG_object_flush_update(scene, obedit, OB_RECALC_DATA);
+       MetaBall *mb= ptr->id.data;
+       Object *ob;
+
+       for(ob=bmain->object.first; ob; ob= ob->id.next) {
+               if(ob->data == mb) {
+                       copy_mball_properties(scene, ob);
+                       /* XXX this will loop over all objects again (slow) */
+                       DAG_object_flush_update(scene, ob, OB_RECALC_DATA);
+                       WM_event_add_notifier(C, NC_OBJECT|ND_GEOM_DATA, ob);
+               }
        }
-       else if(active_object) {
-               copy_mball_properties(scene, active_object);
-               WM_event_add_notifier(C, NC_OBJECT|ND_GEOM_DATA, active_object);
-               DAG_object_flush_update(scene, active_object, OB_RECALC_DATA);
-       }       
-}
-
-static void rna_MetaElem_update_data(bContext *C, PointerRNA *ptr)
-{
-       Scene *scene= CTX_data_scene(C);
-       Object *obedit= CTX_data_edit_object(C);
-       
-       WM_event_add_notifier(C, NC_OBJECT|ND_GEOM_DATA, obedit);
-       DAG_object_flush_update(scene, obedit, OB_RECALC_DATA);
 }
 
 #else
@@ -99,59 +90,59 @@ void rna_def_metaelement(BlenderRNA *brna)
        prop= RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_items(prop, prop_type_items);
        RNA_def_property_ui_text(prop, "Type", "Metaball types.");
-       RNA_def_property_update(prop, 0, "rna_MetaElem_update_data");
+       RNA_def_property_update(prop, 0, "rna_MetaBall_update_data");
        
        /* number values */
        prop= RNA_def_property(srna, "location", PROP_FLOAT, PROP_VECTOR);
        RNA_def_property_float_sdna(prop, NULL, "x");
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Location", "");
-       RNA_def_property_update(prop, 0, "rna_MetaElem_update_data");
+       RNA_def_property_update(prop, 0, "rna_MetaBall_update_data");
 
        prop= RNA_def_property(srna, "rotation", PROP_FLOAT, PROP_ROTATION);
        RNA_def_property_float_sdna(prop, NULL, "quat");
        RNA_def_property_ui_text(prop, "Rotation", "");
-       RNA_def_property_update(prop, 0, "rna_MetaElem_update_data");
+       RNA_def_property_update(prop, 0, "rna_MetaBall_update_data");
 
        prop= RNA_def_property(srna, "radius", PROP_FLOAT, PROP_UNSIGNED);
        RNA_def_property_float_sdna(prop, NULL, "rad");
        RNA_def_property_ui_text(prop, "Radius", "");
-       RNA_def_property_update(prop, 0, "rna_MetaElem_update_data");
+       RNA_def_property_update(prop, 0, "rna_MetaBall_update_data");
 
        prop= RNA_def_property(srna, "size_x", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "expx");
        RNA_def_property_range(prop, 0.0f, 20.0f);
        RNA_def_property_ui_text(prop, "Size X", "Size of element, use of components depends on element type.");
-       RNA_def_property_update(prop, 0, "rna_MetaElem_update_data");
+       RNA_def_property_update(prop, 0, "rna_MetaBall_update_data");
 
        prop= RNA_def_property(srna, "size_y", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "expy");
        RNA_def_property_range(prop, 0.0f, 20.0f);
        RNA_def_property_ui_text(prop, "Size Y", "Size of element, use of components depends on element type.");
-       RNA_def_property_update(prop, 0, "rna_MetaElem_update_data");
+       RNA_def_property_update(prop, 0, "rna_MetaBall_update_data");
 
        prop= RNA_def_property(srna, "size_z", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "expz");
        RNA_def_property_range(prop, 0.0f, 20.0f);
        RNA_def_property_ui_text(prop, "Size Z", "Size of element, use of components depends on element type.");
-       RNA_def_property_update(prop, 0, "rna_MetaElem_update_data");
+       RNA_def_property_update(prop, 0, "rna_MetaBall_update_data");
        
        prop= RNA_def_property(srna, "stiffness", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "s");
        RNA_def_property_range(prop, 0.0f, 10.0f);
        RNA_def_property_ui_text(prop, "Stiffness", "Stiffness defines how much of the element to fill.");
-       RNA_def_property_update(prop, 0, "rna_MetaElem_update_data");
+       RNA_def_property_update(prop, 0, "rna_MetaBall_update_data");
        
        /* flags */
        prop= RNA_def_property(srna, "negative", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MB_NEGATIVE);
        RNA_def_property_ui_text(prop, "Negative", "Set metaball as negative one.");
-       RNA_def_property_update(prop, 0, "rna_MetaElem_update_data");
+       RNA_def_property_update(prop, 0, "rna_MetaBall_update_data");
        
        prop= RNA_def_property(srna, "hide", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MB_HIDE);
        RNA_def_property_ui_text(prop, "Hide", "Hide element.");
-       RNA_def_property_update(prop, 0, "rna_MetaElem_update_data");
+       RNA_def_property_update(prop, 0, "rna_MetaBall_update_data");
 }
 
 void rna_def_metaball(BlenderRNA *brna)