clone and stencil layer access added, renamed mask to stencil layer internally
[blender.git] / source / blender / makesrna / intern / rna_key.c
index 9daf1155149505c92812b2286b92d291c105958a..9e560a50af07e1a8c8875afd1f3ee2fa979e4d11 100644 (file)
 #include "WM_api.h"
 #include "WM_types.h"
 
+static Key *rna_ShapeKey_find_key(ID *id)
+{
+       switch(GS(id->name)) {
+               case ID_CU: return ((Curve*)id)->key;
+               case ID_KE: return (Key*)id;
+               case ID_LT: return ((Lattice*)id)->key;
+               case ID_ME: return ((Mesh*)id)->key;
+               default: return NULL;
+       }
+}
+
 void rna_ShapeKey_name_set(PointerRNA *ptr, const char *value)
 {
        KeyBlock *kb= ptr->data;
@@ -63,7 +74,7 @@ void rna_ShapeKey_name_set(PointerRNA *ptr, const char *value)
        
        /* make sure the name is truly unique */
        if (ptr->id.data) {
-               Key *key= ptr->id.data;
+               Key *key= rna_ShapeKey_find_key(ptr->id.data);
                BLI_uniquename(&key->block, kb, "Key", '.', offsetof(KeyBlock, name), 32);
        }
        
@@ -86,17 +97,6 @@ static void rna_ShapeKey_value_range(PointerRNA *ptr, float *min, float *max)
        *max= data->slidermax;
 }
 
-static Key *rna_ShapeKey_find_key(ID *id)
-{
-       switch(GS(id->name)) {
-               case ID_CU: return ((Curve*)id)->key;
-               case ID_KE: return (Key*)id;
-               case ID_LT: return ((Lattice*)id)->key;
-               case ID_ME: return ((Mesh*)id)->key;
-               default: return NULL;
-       }
-}
-
 static PointerRNA rna_ShapeKey_relative_key_get(PointerRNA *ptr)
 {
        Key *key= rna_ShapeKey_find_key(ptr->id.data);
@@ -286,16 +286,15 @@ static char *rna_ShapeKey_path(PointerRNA *ptr)
        return BLI_sprintfN("keys[\"%s\"]", ((KeyBlock*)ptr->data)->name);
 }
 
-static void rna_Key_update_data(bContext *C, PointerRNA *ptr)
+static void rna_Key_update_data(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
-       Main *bmain= CTX_data_main(C);
        Key *key= ptr->id.data;
        Object *ob;
 
        for(ob=bmain->object.first; ob; ob= ob->id.next) {
                if(ob_get_key(ob) == key) {
                        DAG_id_flush_update(&ob->id, OB_RECALC_DATA);
-                       WM_event_add_notifier(C, NC_OBJECT|ND_MODIFIER, ob);
+                       WM_main_add_notifier(NC_OBJECT|ND_MODIFIER, ob);
                }
        }
 }
@@ -391,6 +390,7 @@ static void rna_def_keyblock(BlenderRNA *brna)
        prop= RNA_def_property(srna, "value", PROP_FLOAT, PROP_FACTOR);
        RNA_def_property_float_sdna(prop, NULL, "curval");
        RNA_def_property_float_funcs(prop, NULL, "rna_ShapeKey_value_set", "rna_ShapeKey_value_range");
+       RNA_def_property_ui_range(prop, -10.0f, 10.0f, 10, 3);
        RNA_def_property_ui_text(prop, "Value", "Value of shape key at the current frame.");
        RNA_def_property_update(prop, 0, "rna_Key_update_data");
 
@@ -433,7 +433,7 @@ static void rna_def_keyblock(BlenderRNA *brna)
        RNA_def_property_collection_sdna(prop, NULL, "data", "totelem");
        RNA_def_property_struct_type(prop, "UnknownType");
        RNA_def_property_ui_text(prop, "Data", "");
-       RNA_def_property_collection_funcs(prop, "rna_ShapeKey_data_begin", 0, 0, "rna_ShapeKey_data_get", "rna_ShapeKey_data_length", 0, 0, 0, 0);
+       RNA_def_property_collection_funcs(prop, "rna_ShapeKey_data_begin", 0, 0, "rna_ShapeKey_data_get", "rna_ShapeKey_data_length", 0, 0);
 }
 
 static void rna_def_key(BlenderRNA *brna)