use static functions where possible for some local functions.
[blender.git] / source / blender / makesrna / intern / rna_armature.c
index 4c8f5597e1e0c29114fe0a3c83426c1ce6615f90..dcf89b7ac1e319a8245aedc91117e1a62b7064cb 100644 (file)
 
 static void rna_Armature_update_data(bContext *C, PointerRNA *ptr)
 {
-       Main *bmain= CTX_data_main(C);
-       Scene *scene= CTX_data_scene(C);
        ID *id= ptr->id.data;
-       Object *ob;
 
-       for(ob=bmain->object.first; ob; ob= ob->id.next) {
-               if(ob->data == id) {
-                       /* 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);
-               }
-       }
+       DAG_id_flush_update(id, OB_RECALC_DATA);
+       WM_event_add_notifier(C, NC_GEOM|ND_DATA, id);
 }
 
 static void rna_Armature_redraw_data(bContext *C, PointerRNA *ptr)
 {
-       Main *bmain= CTX_data_main(C);
        ID *id= ptr->id.data;
-       Object *ob;
 
-       for(ob=bmain->object.first; ob; ob= ob->id.next)
-               if(ob->data == id)
-                       WM_event_add_notifier(C, NC_OBJECT|ND_GEOM_DATA, ob);
+       WM_event_add_notifier(C, NC_GEOM|ND_DATA, id);
 }
 
 static void rna_bone_layer_set(short *layer, const int *values)
@@ -144,18 +132,6 @@ static void rna_Armature_path_end_frame_set(PointerRNA *ptr, int value)
        data->pathef= value;
 }
 
-static void rna_EditBone_name_get(PointerRNA *ptr, char *value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       BLI_strncpy(value, data->name, sizeof(data->name));
-}
-
-static int rna_EditBone_name_length(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return strlen(data->name);
-}
-
 static void rna_EditBone_name_set(PointerRNA *ptr, const char *value)
 {
        bArmature *arm= (bArmature*)ptr->id.data;
@@ -169,53 +145,17 @@ static void rna_EditBone_name_set(PointerRNA *ptr, const char *value)
        ED_armature_bone_rename(arm, oldname, newname);
 }
 
-static int rna_EditBone_active_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (((data->flag) & BONE_ACTIVE) != 0);
-}
-
-static void rna_EditBone_active_set(PointerRNA *ptr, int value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       if(value) data->flag |= BONE_ACTIVE;
-       else data->flag &= ~BONE_ACTIVE;
-}
-
-static float rna_EditBone_bbone_in_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (float)(data->ease1);
-}
-
-static void rna_EditBone_bbone_in_set(PointerRNA *ptr, float value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       data->ease1= CLAMPIS(value, 0.0f, 2.0f);
-}
-
-static float rna_EditBone_bbone_out_get(PointerRNA *ptr)
+static void rna_Bone_name_set(PointerRNA *ptr, const char *value)
 {
-       EditBone *data= (EditBone*)(ptr->data);
-       return (float)(data->ease2);
-}
-
-static void rna_EditBone_bbone_out_set(PointerRNA *ptr, float value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       data->ease2= CLAMPIS(value, 0.0f, 2.0f);
-}
-
-static int rna_EditBone_bbone_segments_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (int)(data->segments);
-}
-
-static void rna_EditBone_bbone_segments_set(PointerRNA *ptr, int value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       data->segments= CLAMPIS(value, 1, 32);
+       bArmature *arm= (bArmature*)ptr->id.data;
+       Bone *bone= (Bone*)ptr->data;
+       char oldname[32], newname[32];
+       
+       /* need to be on the stack */
+       BLI_strncpy(newname, value, 32);
+       BLI_strncpy(oldname, bone->name, 32);
+       
+       ED_armature_bone_rename(arm, oldname, newname);
 }
 
 static void rna_EditBone_layer_get(PointerRNA *ptr, int values[16])
@@ -261,12 +201,6 @@ static void rna_EditBone_connected_check(EditBone *ebone)
        }
 }
 
-static int rna_EditBone_connected_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (((data->flag) & BONE_CONNECTED) != 0);
-}
-
 static void rna_EditBone_connected_set(PointerRNA *ptr, int value)
 {
        EditBone *ebone= (EditBone*)(ptr->data);
@@ -277,190 +211,6 @@ static void rna_EditBone_connected_set(PointerRNA *ptr, int value)
        rna_EditBone_connected_check(ebone);
 }
 
-static int rna_EditBone_cyclic_offset_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (!((data->flag) & BONE_NO_CYCLICOFFSET) != 0);
-}
-
-static void rna_EditBone_cyclic_offset_set(PointerRNA *ptr, int value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       if(!value) data->flag |= BONE_NO_CYCLICOFFSET;
-       else data->flag &= ~BONE_NO_CYCLICOFFSET;
-}
-
-static int rna_EditBone_deform_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (!((data->flag) & BONE_NO_DEFORM) != 0);
-}
-
-static void rna_EditBone_deform_set(PointerRNA *ptr, int value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       if(!value) data->flag |= BONE_NO_DEFORM;
-       else data->flag &= ~BONE_NO_DEFORM;
-}
-
-static int rna_EditBone_draw_wire_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (((data->flag) & BONE_DRAWWIRE) != 0);
-}
-
-static void rna_EditBone_draw_wire_set(PointerRNA *ptr, int value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       if(value) data->flag |= BONE_DRAWWIRE;
-       else data->flag &= ~BONE_DRAWWIRE;
-}
-
-static float rna_EditBone_envelope_distance_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (float)(data->dist);
-}
-
-static void rna_EditBone_envelope_distance_set(PointerRNA *ptr, float value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       data->dist= CLAMPIS(value, 0.0f, 1000.0f);
-}
-
-static float rna_EditBone_envelope_weight_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (float)(data->weight);
-}
-
-static void rna_EditBone_envelope_weight_set(PointerRNA *ptr, float value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       data->weight= CLAMPIS(value, 0.0f, 1000.0f);
-}
-
-static float rna_EditBone_radius_head_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (float)(data->rad_head);
-}
-
-static void rna_EditBone_radius_head_set(PointerRNA *ptr, float value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       if(data->parent)
-               data->parent->rad_tail= value;
-       else
-               data->rad_head= value;
-}
-
-static float rna_EditBone_radius_tail_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (float)(data->rad_tail);
-}
-
-static void rna_EditBone_radius_tail_set(PointerRNA *ptr, float value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       data->rad_tail= value;
-}
-
-static void rna_EditBone_head_get(PointerRNA *ptr, float values[3])
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       values[0]= (float)(((float*)data->head)[0]);
-       values[1]= (float)(((float*)data->head)[1]);
-       values[2]= (float)(((float*)data->head)[2]);
-}
-
-static void rna_EditBone_head_set(PointerRNA *ptr, const float values[3])
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       ((float*)data->head)[0]= values[0];
-       ((float*)data->head)[1]= values[1];
-       ((float*)data->head)[2]= values[2];
-}
-
-static int rna_EditBone_head_selected_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (((data->flag) & BONE_ROOTSEL) != 0);
-}
-
-static void rna_EditBone_head_selected_set(PointerRNA *ptr, int value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       if(value) data->flag |= BONE_ROOTSEL;
-       else data->flag &= ~BONE_ROOTSEL;
-}
-
-static int rna_EditBone_hidden_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (((data->flag) & BONE_HIDDEN_A) != 0);
-}
-
-static void rna_EditBone_hidden_set(PointerRNA *ptr, int value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       if(value) data->flag |= BONE_HIDDEN_A;
-       else data->flag &= ~BONE_HIDDEN_A;
-}
-
-static int rna_EditBone_hinge_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (!((data->flag) & BONE_HINGE) != 0);
-}
-
-static void rna_EditBone_hinge_set(PointerRNA *ptr, int value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       if(!value) data->flag |= BONE_HINGE;
-       else data->flag &= ~BONE_HINGE;
-}
-
-static int rna_EditBone_inherit_scale_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (!((data->flag) & BONE_NO_SCALE) != 0);
-}
-
-static void rna_EditBone_inherit_scale_set(PointerRNA *ptr, int value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       if(!value) data->flag |= BONE_NO_SCALE;
-       else data->flag &= ~BONE_NO_SCALE;
-}
-
-static int rna_EditBone_locked_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (((data->flag) & BONE_EDITMODE_LOCKED) != 0);
-}
-
-static void rna_EditBone_locked_set(PointerRNA *ptr, int value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       if(value) data->flag |= BONE_EDITMODE_LOCKED;
-       else data->flag &= ~BONE_EDITMODE_LOCKED;
-}
-
-static int rna_EditBone_multiply_vertexgroup_with_envelope_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (((data->flag) & BONE_MULT_VG_ENV) != 0);
-}
-
-static void rna_EditBone_multiply_vertexgroup_with_envelope_set(PointerRNA *ptr, int value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       if(value) data->flag |= BONE_MULT_VG_ENV;
-       else data->flag &= ~BONE_MULT_VG_ENV;
-}
-
 static PointerRNA rna_EditBone_parent_get(PointerRNA *ptr)
 {
        EditBone *data= (EditBone*)(ptr->data);
@@ -497,47 +247,6 @@ static void rna_EditBone_parent_set(PointerRNA *ptr, PointerRNA value)
        }
 }
 
-static float rna_EditBone_roll_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (float)(data->roll);
-}
-
-static void rna_EditBone_roll_set(PointerRNA *ptr, float value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       data->roll= value;
-}
-
-static void rna_EditBone_tail_get(PointerRNA *ptr, float values[3])
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       values[0]= (float)(((float*)data->tail)[0]);
-       values[1]= (float)(((float*)data->tail)[1]);
-       values[2]= (float)(((float*)data->tail)[2]);
-}
-
-static void rna_EditBone_tail_set(PointerRNA *ptr, const float values[3])
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       ((float*)data->tail)[0]= values[0];
-       ((float*)data->tail)[1]= values[1];
-       ((float*)data->tail)[2]= values[2];
-}
-
-static int rna_EditBone_tail_selected_get(PointerRNA *ptr)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       return (((data->flag) & BONE_TIPSEL) != 0);
-}
-
-static void rna_EditBone_tail_selected_set(PointerRNA *ptr, int value)
-{
-       EditBone *data= (EditBone*)(ptr->data);
-       if(value) data->flag |= BONE_TIPSEL;
-       else data->flag &= ~BONE_TIPSEL;
-}
-
 static void rna_Armature_editbone_transform_update(bContext *C, PointerRNA *ptr)
 {
        bArmature *arm= (bArmature*)ptr->id.data;
@@ -608,128 +317,105 @@ static void rna_def_bone_common(StructRNA *srna, int editbone)
 
        /* strings */
        prop= RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
+       RNA_def_property_string_sdna(prop, NULL, "name");
        RNA_def_property_ui_text(prop, "Name", "");
        RNA_def_struct_name_property(srna, prop);
-       if(editbone) RNA_def_property_string_funcs(prop, "rna_EditBone_name_get", "rna_EditBone_name_length", "rna_EditBone_name_set");
+       if(editbone) RNA_def_property_string_funcs(prop, NULL, NULL, "rna_EditBone_name_set");
+       else RNA_def_property_string_funcs(prop, NULL, NULL, "rna_Bone_name_set");
        RNA_def_property_update(prop, 0, "rna_Armature_redraw_data");
 
        /* flags */
-       prop= RNA_def_property(srna, "layer", PROP_BOOLEAN, PROP_NONE);
-       if(editbone) {
-               RNA_def_property_array(prop, 16);
-               RNA_def_property_boolean_funcs(prop, "rna_EditBone_layer_get", "rna_EditBone_layer_set");
-       }
-       else {
-               RNA_def_property_boolean_sdna(prop, NULL, "layer", 1);
-               RNA_def_property_array(prop, 16);
-               RNA_def_property_boolean_funcs(prop, NULL, "rna_Bone_layer_set");
-       }
+       prop= RNA_def_property(srna, "layer", PROP_BOOLEAN, PROP_LAYER_MEMBER);
+       RNA_def_property_boolean_sdna(prop, NULL, "layer", 1);
+       RNA_def_property_array(prop, 16);
+       if(editbone) RNA_def_property_boolean_funcs(prop, "rna_EditBone_layer_get", "rna_EditBone_layer_set");
+       else RNA_def_property_boolean_funcs(prop, NULL, "rna_Bone_layer_set");
        RNA_def_property_ui_text(prop, "Layers", "Layers bone exists in");
        RNA_def_property_update(prop, 0, "rna_Armature_redraw_data");
 
        prop= RNA_def_property(srna, "connected", PROP_BOOLEAN, PROP_NONE);
-       if(editbone) RNA_def_property_boolean_funcs(prop, "rna_EditBone_connected_get", "rna_EditBone_connected_set");
-       else {
-               RNA_def_property_boolean_sdna(prop, NULL, "flag", BONE_CONNECTED);
-               RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-       }
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", BONE_CONNECTED);
+       if(editbone) RNA_def_property_boolean_funcs(prop, NULL, "rna_EditBone_connected_set");
+       else RNA_def_property_clear_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Connected", "When bone has a parent, bone's head is struck to the parent's tail.");
        RNA_def_property_update(prop, 0, "rna_Armature_update_data");
        
        prop= RNA_def_property(srna, "active", PROP_BOOLEAN, PROP_NONE);
-       if(editbone) RNA_def_property_boolean_funcs(prop, "rna_EditBone_active_get", "rna_EditBone_active_set");
-       else RNA_def_property_boolean_sdna(prop, NULL, "flag", BONE_ACTIVE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", BONE_ACTIVE);
        RNA_def_property_ui_text(prop, "Active", "Bone was the last bone clicked on (most operations are applied to only this bone)");
        RNA_def_property_update(prop, 0, "rna_Armature_redraw_data");
        
        prop= RNA_def_property(srna, "hinge", PROP_BOOLEAN, PROP_NONE);
-       if(editbone) RNA_def_property_boolean_funcs(prop, "rna_EditBone_hinge_get", "rna_EditBone_hinge_set");
-       else RNA_def_property_boolean_negative_sdna(prop, NULL, "flag", BONE_HINGE);
+       RNA_def_property_boolean_negative_sdna(prop, NULL, "flag", BONE_HINGE);
        RNA_def_property_ui_text(prop, "Inherit Rotation", "Bone doesn't inherit rotation or scale from parent bone.");
        RNA_def_property_update(prop, 0, "rna_Armature_update_data");
        
        prop= RNA_def_property(srna, "multiply_vertexgroup_with_envelope", PROP_BOOLEAN, PROP_NONE);
-       if(editbone) RNA_def_property_boolean_funcs(prop, "rna_EditBone_multiply_vertexgroup_with_envelope_get", "rna_EditBone_multiply_vertexgroup_with_envelope_set");
-       else RNA_def_property_boolean_sdna(prop, NULL, "flag", BONE_MULT_VG_ENV);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", BONE_MULT_VG_ENV);
        RNA_def_property_ui_text(prop, "Multiply Vertex Group with Envelope", "When deforming bone, multiply effects of Vertex Group weights with Envelope influence.");
        RNA_def_property_update(prop, 0, "rna_Armature_update_data");
        
        prop= RNA_def_property(srna, "deform", PROP_BOOLEAN, PROP_NONE);
-       if(editbone) RNA_def_property_boolean_funcs(prop, "rna_EditBone_deform_get", "rna_EditBone_deform_set");
-       else RNA_def_property_boolean_negative_sdna(prop, NULL, "flag", BONE_NO_DEFORM);
+       RNA_def_property_boolean_negative_sdna(prop, NULL, "flag", BONE_NO_DEFORM);
        RNA_def_property_ui_text(prop, "Deform", "Bone does not deform any geometry.");
        RNA_def_property_update(prop, 0, "rna_Armature_update_data");
        
        prop= RNA_def_property(srna, "inherit_scale", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_ui_text(prop, "Inherit Scale", "Bone inherits scaling from parent bone.");
-       if(editbone) RNA_def_property_boolean_funcs(prop, "rna_EditBone_inherit_scale_get", "rna_EditBone_inherit_scale_set");
-       else RNA_def_property_boolean_negative_sdna(prop, NULL, "flag", BONE_NO_SCALE);
+       RNA_def_property_boolean_negative_sdna(prop, NULL, "flag", BONE_NO_SCALE);
        RNA_def_property_update(prop, 0, "rna_Armature_update_data");
        
        prop= RNA_def_property(srna, "draw_wire", PROP_BOOLEAN, PROP_NONE);
-       if(editbone) RNA_def_property_boolean_funcs(prop, "rna_EditBone_draw_wire_get", "rna_EditBone_draw_wire_set");
-       else RNA_def_property_boolean_sdna(prop, NULL, "flag", BONE_DRAWWIRE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", BONE_DRAWWIRE);
        RNA_def_property_ui_text(prop, "Draw Wire", "Bone is always drawn as Wireframe regardless of viewport draw mode. Useful for non-obstructive custom bone shapes.");
        RNA_def_property_update(prop, 0, "rna_Armature_redraw_data");
        
        prop= RNA_def_property(srna, "cyclic_offset", PROP_BOOLEAN, PROP_NONE);
-       if(editbone) RNA_def_property_boolean_funcs(prop, "rna_EditBone_cyclic_offset_get", "rna_EditBone_cyclic_offset_set");
-       else RNA_def_property_boolean_negative_sdna(prop, NULL, "flag", BONE_NO_CYCLICOFFSET);
+       RNA_def_property_boolean_negative_sdna(prop, NULL, "flag", BONE_NO_CYCLICOFFSET);
        RNA_def_property_ui_text(prop, "Cyclic Offset", "When bone doesn't have a parent, it receives cyclic offset effects.");
        RNA_def_property_update(prop, 0, "rna_Armature_update_data");
 
        /* Number values */
                /* envelope deform settings */
        prop= RNA_def_property(srna, "envelope_distance", PROP_FLOAT, PROP_NONE);
-       if(editbone) RNA_def_property_float_funcs(prop, "rna_EditBone_envelope_distance_get", "rna_EditBone_envelope_distance_set", NULL);
-       else RNA_def_property_float_sdna(prop, NULL, "dist");
+       RNA_def_property_float_sdna(prop, NULL, "dist");
        RNA_def_property_range(prop, 0.0f, 1000.0f);
        RNA_def_property_ui_text(prop, "Envelope Deform Distance", "Bone deformation distance (for Envelope deform only).");
        RNA_def_property_update(prop, 0, "rna_Armature_update_data");
        
        prop= RNA_def_property(srna, "envelope_weight", PROP_FLOAT, PROP_NONE);
-       if(editbone) RNA_def_property_float_funcs(prop, "rna_EditBone_envelope_weight_get", "rna_EditBone_envelope_weight_set", NULL);
-       else RNA_def_property_float_sdna(prop, NULL, "weight");
+       RNA_def_property_float_sdna(prop, NULL, "weight");
        RNA_def_property_range(prop, 0.0f, 1000.0f);
        RNA_def_property_ui_text(prop, "Envelope Deform Weight", "Bone deformation weight (for Envelope deform only).");
        RNA_def_property_update(prop, 0, "rna_Armature_update_data");
        
        prop= RNA_def_property(srna, "head_radius", PROP_FLOAT, PROP_NONE);
-       if(editbone) {
-               RNA_def_property_float_funcs(prop, "rna_EditBone_radius_head_get", "rna_EditBone_radius_head_set", NULL);
-               RNA_def_property_update(prop, 0, "rna_Armature_editbone_transform_update");
-       }
-       else RNA_def_property_float_sdna(prop, NULL, "rad_head");
+       if(editbone) RNA_def_property_update(prop, 0, "rna_Armature_editbone_transform_update");
+       RNA_def_property_float_sdna(prop, NULL, "rad_head");
        //RNA_def_property_range(prop, 0, 1000);  // XXX range is 0 to lim, where lim= 10000.0f*MAX2(1.0, view3d->grid);
        RNA_def_property_ui_text(prop, "Envelope Head Radius", "Radius of head of bone (for Envelope deform only).");
        
        prop= RNA_def_property(srna, "tail_radius", PROP_FLOAT, PROP_NONE);
-       if(editbone) {
-               RNA_def_property_float_funcs(prop, "rna_EditBone_radius_tail_get", "rna_EditBone_radius_tail_set", NULL);
-               RNA_def_property_update(prop, 0, "rna_Armature_editbone_transform_update");
-       }
-       else RNA_def_property_float_sdna(prop, NULL, "rad_tail");
+       if(editbone) RNA_def_property_update(prop, 0, "rna_Armature_editbone_transform_update");
+       RNA_def_property_float_sdna(prop, NULL, "rad_tail");
        //RNA_def_property_range(prop, 0, 1000);  // XXX range is 0 to lim, where lim= 10000.0f*MAX2(1.0, view3d->grid);
        RNA_def_property_ui_text(prop, "Envelope Tail Radius", "Radius of tail of bone (for Envelope deform only).");
        
                /* b-bones deform settings */
        prop= RNA_def_property(srna, "bbone_segments", PROP_INT, PROP_NONE);
-       if(editbone) RNA_def_property_int_funcs(prop, "rna_EditBone_bbone_segments_get", "rna_EditBone_bbone_segments_set", NULL);
-       else RNA_def_property_int_sdna(prop, NULL, "segments");
+       RNA_def_property_int_sdna(prop, NULL, "segments");
        RNA_def_property_range(prop, 1, 32);
        RNA_def_property_ui_text(prop, "B-Bone Segments", "Number of subdivisions of bone (for B-Bones only).");
        RNA_def_property_update(prop, 0, "rna_Armature_update_data");
        
        prop= RNA_def_property(srna, "bbone_in", PROP_FLOAT, PROP_NONE);
-       if(editbone) RNA_def_property_float_funcs(prop, "rna_EditBone_bbone_in_get", "rna_EditBone_bbone_in_set", NULL);
-       else RNA_def_property_float_sdna(prop, NULL, "ease1");
+       RNA_def_property_float_sdna(prop, NULL, "ease1");
        RNA_def_property_range(prop, 0.0f, 2.0f);
        RNA_def_property_ui_text(prop, "B-Bone Ease In", "Length of first Bezier Handle (for B-Bones only).");
        RNA_def_property_update(prop, 0, "rna_Armature_update_data");
        
        prop= RNA_def_property(srna, "bbone_out", PROP_FLOAT, PROP_NONE);
-       if(editbone) RNA_def_property_float_funcs(prop, "rna_EditBone_bbone_out_get", "rna_EditBone_bbone_out_set", NULL);
-       else RNA_def_property_float_sdna(prop, NULL, "ease2");
+       RNA_def_property_float_sdna(prop, NULL, "ease2");
        RNA_def_property_range(prop, 0.0f, 2.0f);
        RNA_def_property_ui_text(prop, "B-Bone Ease Out", "Length of second Bezier Handle (for B-Bones only).");
        RNA_def_property_update(prop, 0, "rna_Armature_update_data");
@@ -779,9 +465,12 @@ static void rna_def_edit_bone(BlenderRNA *brna)
        PropertyRNA *prop;
        
        srna= RNA_def_struct(brna, "EditBone", NULL);
+       RNA_def_struct_sdna(srna, "EditBone");
        RNA_def_struct_ui_text(srna, "Edit Bone", "Editmode bone in an Armature datablock.");
        RNA_def_struct_ui_icon(srna, ICON_BONE_DATA);
        
+       RNA_define_verify_sdna(0); // not in sdna
+
        prop= RNA_def_property(srna, "parent", PROP_POINTER, PROP_NONE);
        RNA_def_property_struct_type(prop, "EditBone");
        RNA_def_property_pointer_funcs(prop, "rna_EditBone_parent_get", "rna_EditBone_parent_set", NULL);
@@ -790,46 +479,48 @@ static void rna_def_edit_bone(BlenderRNA *brna)
        RNA_def_property_update(prop, 0, "rna_Armature_redraw_data");
        
        prop= RNA_def_property(srna, "roll", PROP_FLOAT, PROP_NONE);
-       RNA_def_property_float_funcs(prop, "rna_EditBone_roll_get", "rna_EditBone_roll_set", NULL);
+       RNA_def_property_float_sdna(prop, NULL, "roll");
        RNA_def_property_ui_text(prop, "Roll", "Bone rotation around head-tail axis.");
        RNA_def_property_update(prop, 0, "rna_Armature_editbone_transform_update");
 
-       prop= RNA_def_property(srna, "head", PROP_FLOAT, PROP_VECTOR);
+       prop= RNA_def_property(srna, "head", PROP_FLOAT, PROP_TRANSLATION);
+       RNA_def_property_float_sdna(prop, NULL, "head");
        RNA_def_property_array(prop, 3);
-       RNA_def_property_float_funcs(prop, "rna_EditBone_head_get", "rna_EditBone_head_set", NULL);
        RNA_def_property_ui_text(prop, "Head", "Location of head end of the bone.");
        RNA_def_property_update(prop, 0, "rna_Armature_editbone_transform_update");
 
-       prop= RNA_def_property(srna, "tail", PROP_FLOAT, PROP_VECTOR);
+       prop= RNA_def_property(srna, "tail", PROP_FLOAT, PROP_TRANSLATION);
+       RNA_def_property_float_sdna(prop, NULL, "tail");
        RNA_def_property_array(prop, 3);
-       RNA_def_property_float_funcs(prop, "rna_EditBone_tail_get", "rna_EditBone_tail_set", NULL);
        RNA_def_property_ui_text(prop, "Tail", "Location of tail end of the bone.");
        RNA_def_property_update(prop, 0, "rna_Armature_editbone_transform_update");
 
        rna_def_bone_common(srna, 1);
 
        prop= RNA_def_property(srna, "hidden", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_funcs(prop, "rna_EditBone_hidden_get", "rna_EditBone_hidden_set");
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", BONE_HIDDEN_A);
        RNA_def_property_ui_text(prop, "Hidden", "Bone is not visible when in Edit Mode");
        RNA_def_property_update(prop, 0, "rna_Armature_redraw_data");
 
        prop= RNA_def_property(srna, "locked", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_funcs(prop, "rna_EditBone_locked_get", "rna_EditBone_locked_set");
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", BONE_EDITMODE_LOCKED);
        RNA_def_property_ui_text(prop, "Locked", "Bone is not able to be transformed when in Edit Mode.");
        RNA_def_property_update(prop, 0, "rna_Armature_redraw_data");
 
        prop= RNA_def_property(srna, "head_selected", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_funcs(prop, "rna_EditBone_head_selected_get", "rna_EditBone_head_selected_set");
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", BONE_ROOTSEL);
        RNA_def_property_ui_text(prop, "Head Selected", "");
        RNA_def_property_update(prop, 0, "rna_Armature_redraw_data");
        
        prop= RNA_def_property(srna, "tail_selected", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_funcs(prop, "rna_EditBone_tail_selected_get", "rna_EditBone_tail_selected_set");
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", BONE_TIPSEL);
        RNA_def_property_ui_text(prop, "Tail Selected", "");
        RNA_def_property_update(prop, 0, "rna_Armature_redraw_data");
+
+       RNA_define_verify_sdna(1);
 }
 
-void rna_def_armature(BlenderRNA *brna)
+static void rna_def_armature(BlenderRNA *brna)
 {
        StructRNA *srna;
        PropertyRNA *prop;
@@ -878,15 +569,16 @@ void rna_def_armature(BlenderRNA *brna)
        
        /* Boolean values */
                /* layer */
-       prop= RNA_def_property(srna, "layer", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "layer", PROP_BOOLEAN, PROP_LAYER_MEMBER);
        RNA_def_property_boolean_sdna(prop, NULL, "layer", 1);
        RNA_def_property_array(prop, 16);
        RNA_def_property_ui_text(prop, "Visible Layers", "Armature layer visibility.");
        RNA_def_property_boolean_funcs(prop, NULL, "rna_Armature_layer_set");
        RNA_def_property_update(prop, NC_OBJECT|ND_POSE, NULL);
+       RNA_def_property_flag(prop, PROP_LIB_EXCEPTION);
        
                /* layer protection */
-       prop= RNA_def_property(srna, "layer_protection", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "layer_protection", PROP_BOOLEAN, PROP_LAYER);
        RNA_def_property_boolean_sdna(prop, NULL, "layer_protected", 1);
        RNA_def_property_array(prop, 16);
        RNA_def_property_ui_text(prop, "Layer Proxy Protection", "Protected layers in Proxy Instances are restored to Proxy settings on file reload and undo.");        
@@ -896,7 +588,7 @@ void rna_def_armature(BlenderRNA *brna)
        prop= RNA_def_property(srna, "rest_position", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", ARM_RESTPOS);
        RNA_def_property_ui_text(prop, "Rest Position", "Show Armature in Rest Position. No posing possible.");
-       RNA_def_property_update(prop, 0, "rna_Armature_redraw_data");
+       RNA_def_property_update(prop, 0, "rna_Armature_update_data");
        
        prop= RNA_def_property(srna, "draw_axes", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", ARM_DRAWAXES);
@@ -911,7 +603,7 @@ void rna_def_armature(BlenderRNA *brna)
        prop= RNA_def_property(srna, "delay_deform", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", ARM_DELAYDEFORM);
        RNA_def_property_ui_text(prop, "Delay Deform", "Don't deform children when manipulating bones in Pose Mode");
-       RNA_def_property_update(prop, 0, "rna_Armature_redraw_data");
+       RNA_def_property_update(prop, 0, "rna_Armature_update_data");
        
        prop= RNA_def_property(srna, "x_axis_mirror", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", ARM_MIRROR_EDIT);
@@ -1004,13 +696,13 @@ void rna_def_armature(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Ghosting Frame Step", "Frame step for Ghosts (not for 'On Keyframes' Onion-skining method).");
        RNA_def_property_update(prop, 0, "rna_Armature_redraw_data");
        
-       prop= RNA_def_property(srna, "ghost_start_frame", PROP_INT, PROP_NONE);
+       prop= RNA_def_property(srna, "ghost_start_frame", PROP_INT, PROP_TIME);
        RNA_def_property_int_sdna(prop, NULL, "ghostsf");
        RNA_def_property_int_funcs(prop, NULL, "rna_Armature_ghost_start_frame_set", NULL);
        RNA_def_property_ui_text(prop, "Ghosting Start Frame", "Starting frame of range of Ghosts to display (not for 'Around Current Frame' Onion-skinning method).");
        RNA_def_property_update(prop, 0, "rna_Armature_redraw_data");
        
-       prop= RNA_def_property(srna, "ghost_end_frame", PROP_INT, PROP_NONE);
+       prop= RNA_def_property(srna, "ghost_end_frame", PROP_INT, PROP_TIME);
        RNA_def_property_int_sdna(prop, NULL, "ghostef");
        RNA_def_property_int_funcs(prop, NULL, "rna_Armature_ghost_end_frame_set", NULL);
        RNA_def_property_ui_text(prop, "Ghosting End Frame", "End frame of range of Ghosts to display (not for 'Around Current Frame' Onion-skinning method).");
@@ -1023,13 +715,13 @@ void rna_def_armature(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Paths Frame Step", "Number of frames between 'dots' on Bone Paths (when drawing).");
        RNA_def_property_update(prop, 0, "rna_Armature_redraw_data");
        
-       prop= RNA_def_property(srna, "path_start_frame", PROP_INT, PROP_NONE);
+       prop= RNA_def_property(srna, "path_start_frame", PROP_INT, PROP_TIME);
        RNA_def_property_int_sdna(prop, NULL, "pathsf");
        RNA_def_property_int_funcs(prop, NULL, "rna_Armature_path_start_frame_set", NULL);
        RNA_def_property_ui_text(prop, "Paths Calculation Start Frame", "Starting frame of range of frames to use for Bone Path calculations.");
        RNA_def_property_update(prop, 0, "rna_Armature_update_data");
        
-       prop= RNA_def_property(srna, "path_end_frame", PROP_INT, PROP_NONE);
+       prop= RNA_def_property(srna, "path_end_frame", PROP_INT, PROP_TIME);
        RNA_def_property_int_sdna(prop, NULL, "pathef");
        RNA_def_property_int_funcs(prop, NULL, "rna_Armature_path_end_frame_set", NULL);
        RNA_def_property_ui_text(prop, "Paths Calculation End Frame", "End frame of range of frames to use for Bone Path calculations.");