merge with/from trunk at r35190
[blender.git] / source / blender / makesrna / intern / rna_object.c
index f77e984cd37683e56314444f3e7db74c25373303..48054604a25acc9f1157f1964c2dc606aa5676a4 100644 (file)
@@ -1,4 +1,4 @@
-/**
+/*
  * $Id$
  *
  * ***** BEGIN GPL LICENSE BLOCK *****
 #include "DNA_action_types.h"
 #include "DNA_customdata_types.h"
 #include "DNA_controller_types.h"
+#include "DNA_group_types.h"
 #include "DNA_material_types.h"
 #include "DNA_mesh_types.h"
 #include "DNA_object_force.h"
 #include "DNA_object_types.h"
 #include "DNA_property_types.h"
 #include "DNA_scene_types.h"
+#include "DNA_meta_types.h"
+
+#include "BKE_tessmesh.h"
+#include "BKE_group.h" /* needed for object_in_group() */
+
+#include "BLO_sys_types.h" /* needed for intptr_t used in ED_mesh.h */
+#include "ED_mesh.h"
 
 #include "WM_api.h"
 #include "WM_types.h"
@@ -73,20 +81,29 @@ static EnumPropertyItem collision_bounds_items[] = {
        {OB_BOUND_CONE, "CONE", 0, "Cone", ""},
        {OB_BOUND_POLYT, "CONVEX_HULL", 0, "Convex Hull", ""},
        {OB_BOUND_POLYH, "TRIANGLE_MESH", 0, "Triangle Mesh", ""},
+       {OB_BOUND_CAPSULE, "CAPSULE", 0, "Capsule", ""},
        //{OB_DYN_MESH, "DYNAMIC_MESH", 0, "Dynamic Mesh", ""},
        {0, NULL, 0, NULL, NULL}};
 
+EnumPropertyItem metaelem_type_items[] = {
+       {MB_BALL, "BALL", ICON_META_BALL, "Ball", ""},
+       {MB_TUBE, "CAPSULE", ICON_META_CAPSULE, "Capsule", ""},
+       {MB_PLANE, "PLANE", ICON_META_PLANE, "Plane", ""},
+       {MB_ELIPSOID, "ELLIPSOID", ICON_META_ELLIPSOID, "Ellipsoid", ""}, // NOTE: typo at original definition!
+       {MB_CUBE, "CUBE", ICON_META_CUBE, "Cube", ""},
+       {0, NULL, 0, NULL, NULL}};
+
 /* used for 2 enums */
 #define OBTYPE_CU_CURVE {OB_CURVE, "CURVE", 0, "Curve", ""}
 #define OBTYPE_CU_SURF {OB_SURF, "SURFACE", 0, "Surface", ""}
-#define OBTYPE_CU_TEXT {OB_FONT, "TEXT", 0, "Text", ""}
+#define OBTYPE_CU_FONT {OB_FONT, "FONT", 0, "Font", ""}
     
 EnumPropertyItem object_type_items[] = {
        {OB_MESH, "MESH", 0, "Mesh", ""},
        OBTYPE_CU_CURVE,
        OBTYPE_CU_SURF,
        {OB_MBALL, "META", 0, "Meta", ""},
-       OBTYPE_CU_TEXT,
+       OBTYPE_CU_FONT,
        {0, "", 0, NULL, NULL},
        {OB_ARMATURE, "ARMATURE", 0, "Armature", ""},
        {OB_LATTICE, "LATTICE", 0, "Lattice", ""},
@@ -99,15 +116,17 @@ EnumPropertyItem object_type_items[] = {
 EnumPropertyItem object_type_curve_items[] = {
        OBTYPE_CU_CURVE,
        OBTYPE_CU_SURF,
-       OBTYPE_CU_TEXT,
+       OBTYPE_CU_FONT,
        {0, NULL, 0, NULL, NULL}};
-    
+
+
 #ifdef RNA_RUNTIME
 
 #include "BLI_math.h"
 
 #include "DNA_key_types.h"
 #include "DNA_constraint_types.h"
+#include "DNA_lattice_types.h"
 
 #include "BKE_armature.h"
 #include "BKE_bullet.h"
@@ -122,39 +141,101 @@ EnumPropertyItem object_type_curve_items[] = {
 #include "BKE_mesh.h"
 #include "BKE_particle.h"
 #include "BKE_scene.h"
+#include "BKE_deform.h"
 
 #include "BLI_editVert.h" /* for EditMesh->mat_nr */
 
 #include "ED_mesh.h"
 #include "ED_object.h"
 #include "ED_particle.h"
+#include "ED_curve.h"
+#include "ED_lattice.h"
 
-void rna_Object_internal_update(Main *bmain, Scene *scene, PointerRNA *ptr)
+static void rna_Object_internal_update(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
-       DAG_id_flush_update(ptr->id.data, OB_RECALC_OB);
+       DAG_id_tag_update(ptr->id.data, OB_RECALC_OB);
 }
 
-void rna_Object_matrix_update(Main *bmain, Scene *scene, PointerRNA *ptr)
+static void rna_Object_matrix_world_update(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
-       object_apply_mat4(ptr->id.data, ((Object *)ptr->id.data)->obmat);
+       /* dont use compat so we get predictable rotation */
+       object_apply_mat4(ptr->id.data, ((Object *)ptr->id.data)->obmat, FALSE, TRUE);
        rna_Object_internal_update(bmain, scene, ptr);
 }
 
+static void rna_Object_matrix_local_get(PointerRNA *ptr, float values[16])
+{
+       Object *ob= ptr->id.data;
+
+       if(ob->parent) {
+               float invmat[4][4]; /* for inverse of parent's matrix */
+               invert_m4_m4(invmat, ob->parent->obmat);
+               mul_m4_m4m4((float(*)[4])values, ob->obmat, invmat);
+       }
+       else {
+               copy_m4_m4((float(*)[4])values, ob->obmat);
+       }
+}
+
+static void rna_Object_matrix_local_set(PointerRNA *ptr, const float values[16])
+{
+       Object *ob= ptr->id.data;
+
+       /* localspace matrix is truly relative to the parent, but parameters
+        * stored in object are relative to parentinv matrix.  Undo the parent
+        * inverse part before updating obmat and calling apply_obmat() */
+       if(ob->parent) {
+               float invmat[4][4];
+               invert_m4_m4(invmat, ob->parentinv);
+               mul_m4_m4m4(ob->obmat, (float(*)[4])values, invmat);
+       }
+       else {
+               copy_m4_m4(ob->obmat, (float(*)[4])values);
+       }
+
+       /* dont use compat so we get predictable rotation */
+       object_apply_mat4(ob, ob->obmat, FALSE, FALSE);
+}
+
+static void rna_Object_matrix_basis_get(PointerRNA *ptr, float values[16])
+{
+       Object *ob= ptr->id.data;
+       object_to_mat4(ob, (float(*)[4])values);
+}
+
+static void rna_Object_matrix_basis_set(PointerRNA *ptr, const float values[16])
+{
+       Object *ob= ptr->id.data;
+       object_apply_mat4(ob, (float(*)[4])values, FALSE, FALSE);
+}
+
 void rna_Object_internal_update_data(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
-       DAG_id_flush_update(ptr->id.data, OB_RECALC_DATA);
+       DAG_id_tag_update(ptr->id.data, OB_RECALC_DATA);
        WM_main_add_notifier(NC_OBJECT|ND_DRAW, ptr->id.data);
 }
 
 void rna_Object_active_shape_update(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
        Object *ob= ptr->id.data;
-       int editmode= (scene->obedit == ob && ob->type == OB_MESH);
 
-       if(editmode) {
+       if(scene->obedit == ob) {
                /* exit/enter editmode to get new shape */
-               load_editMesh(scene, ob);
-               make_editMesh(scene, ob);
+               switch(ob->type) {
+                       case OB_MESH:
+                               EDBM_LoadEditBMesh(scene, ob);
+                               EDBM_MakeEditBMesh(scene->toolsettings, scene, ob);
+                               break;
+                       case OB_CURVE:
+                       case OB_SURF:
+                               load_editNurb(ob);
+                               make_editNurb(ob);
+                               break;
+                       case OB_LATTICE:
+                               load_editLatt(ob);
+                               make_editLatt(ob);
+                               break;
+               }
        }
 
        rna_Object_internal_update_data(bmain, scene, ptr);
@@ -162,8 +243,9 @@ void rna_Object_active_shape_update(Main *bmain, Scene *scene, PointerRNA *ptr)
 
 static void rna_Object_dependency_update(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
-       DAG_id_flush_update(ptr->id.data, OB_RECALC_OB);
-       DAG_scene_sort(scene);
+       DAG_id_tag_update(ptr->id.data, OB_RECALC_OB);
+       DAG_scene_sort(bmain, scene);
+       WM_main_add_notifier(NC_OBJECT|ND_PARENT, ptr->id.data);
 }
 
 /* when changing the selection flag the scene needs updating */
@@ -181,7 +263,7 @@ static void rna_Base_select_update(Main *bmain, Scene *scene, PointerRNA *ptr)
        ED_base_object_select(base, mode);
 }
 
-static void rna_Object_layer_update__internal(Scene *scene, Base *base, Object *ob)
+static void rna_Object_layer_update__internal(Main *bmain, Scene *scene, Base *base, Object *ob)
 {
        /* try to avoid scene sort */
        if((ob->lay & scene->lay) && (base->lay & scene->lay)) {
@@ -189,7 +271,7 @@ static void rna_Object_layer_update__internal(Scene *scene, Base *base, Object *
        } else if((ob->lay & scene->lay)==0 && (base->lay & scene->lay)==0) {
                /* pass */
        } else {
-               DAG_scene_sort(scene);
+               DAG_scene_sort(bmain, scene);
        }
 }
 
@@ -204,8 +286,10 @@ static void rna_Object_layer_update(Main *bmain, Scene *scene, PointerRNA *ptr)
        
        SWAP(int, base->lay, ob->lay);
 
-       rna_Object_layer_update__internal(scene, base, ob);
+       rna_Object_layer_update__internal(bmain, scene, base, ob);
        ob->lay= base->lay;
+
+       WM_main_add_notifier(NC_SCENE|ND_LAYER_CONTENT, scene);
 }
 
 static void rna_Base_layer_update(Main *bmain, Scene *scene, PointerRNA *ptr)
@@ -213,8 +297,10 @@ static void rna_Base_layer_update(Main *bmain, Scene *scene, PointerRNA *ptr)
        Base *base= (Base*)ptr->data;
        Object *ob= (Object*)base->object;
 
-       rna_Object_layer_update__internal(scene, base, ob);
+       rna_Object_layer_update__internal(bmain, scene, base, ob);
        ob->lay= base->lay;
+
+       WM_main_add_notifier(NC_SCENE|ND_LAYER_CONTENT, scene);
 }
 
 static int rna_Object_data_editable(PointerRNA *ptr)
@@ -329,6 +415,7 @@ static EnumPropertyItem *rna_Object_collision_bounds_itemf(bContext *C, PointerR
                RNA_enum_items_add_value(&item, &totitem, collision_bounds_items, OB_BOUND_CYLINDER);
                RNA_enum_items_add_value(&item, &totitem, collision_bounds_items, OB_BOUND_SPHERE);
                RNA_enum_items_add_value(&item, &totitem, collision_bounds_items, OB_BOUND_BOX);
+               RNA_enum_items_add_value(&item, &totitem, collision_bounds_items, OB_BOUND_CAPSULE);
        }
 
        RNA_enum_item_end(&item, &totitem);
@@ -344,6 +431,20 @@ static void rna_Object_parent_bone_set(PointerRNA *ptr, const char *value)
        ED_object_parent(ob, ob->parent, ob->partype, value);
 }
 
+static void rna_Object_dup_group_set(PointerRNA *ptr, PointerRNA value)
+{
+       Object *ob= (Object *)ptr->data;
+       Group *grp = (Group *)value.data;
+       
+       /* must not let this be set if the object belongs in this group already,
+        * thus causing a cycle/infinite-recursion leading to crashes on load [#25298]
+        */
+       if (object_in_group(ob, grp) == 0)
+               ob->dup_group = grp;
+       else
+               BKE_report(NULL, RPT_ERROR, "Cannot set dupli-group as object belongs in group being instanced thus causing a cycle");
+}
+
 static int rna_VertexGroup_index_get(PointerRNA *ptr)
 {
        Object *ob= (Object*)ptr->id.data;
@@ -401,32 +502,19 @@ int rna_object_vgroup_name_index_length(PointerRNA *ptr, int index)
 void rna_object_vgroup_name_index_set(PointerRNA *ptr, const char *value, short *index)
 {
        Object *ob= (Object*)ptr->id.data;
-       bDeformGroup *dg;
-       int a;
-
-       for(a=1, dg=ob->defbase.first; dg; dg=dg->next, a++) {
-               if(strcmp(dg->name, value) == 0) {
-                       *index= a;
-                       return;
-               }
-       }
-
-       *index= 0;
+       *index= defgroup_name_index(ob, value) + 1;
 }
 
 void rna_object_vgroup_name_set(PointerRNA *ptr, const char *value, char *result, int maxlen)
 {
        Object *ob= (Object*)ptr->id.data;
-       bDeformGroup *dg;
-
-       for(dg=ob->defbase.first; dg; dg=dg->next) {
-               if(strcmp(dg->name, value) == 0) {
-                       BLI_strncpy(result, value, maxlen);
-                       return;
-               }
+       bDeformGroup *dg= defgroup_find_name(ob, value);
+       if(dg) {
+               BLI_strncpy(result, value, maxlen);
+               return;
        }
 
-       BLI_strncpy(result, "", maxlen);
+       result[0]= '\0';
 }
 
 void rna_object_uvlayer_name_set(PointerRNA *ptr, const char *value, char *result, int maxlen)
@@ -489,8 +577,8 @@ static void rna_Object_active_material_index_set(PointerRNA *ptr, int value)
        if(ob->type==OB_MESH) {
                Mesh *me= ob->data;
 
-               if(me->edit_mesh)
-                       me->edit_mesh->mat_nr= value;
+               if(me->edit_btmesh)
+                       me->edit_btmesh->mat_nr= value;
        }
 }
 
@@ -501,11 +589,12 @@ static void rna_Object_active_material_index_range(PointerRNA *ptr, int *min, in
        *max= MAX2(ob->totcol-1, 0);
 }
 
+/* returns active base material */
 static PointerRNA rna_Object_active_material_get(PointerRNA *ptr)
 {
        Object *ob= (Object*)ptr->id.data;
        Material *ma;
-
+       
        ma= (ob->totcol)? give_current_material(ob, ob->actcol): NULL;
        return rna_pointer_inherit_refine(ptr, &RNA_Material, ma);
 }
@@ -514,6 +603,7 @@ static void rna_Object_active_material_set(PointerRNA *ptr, PointerRNA value)
 {
        Object *ob= (Object*)ptr->id.data;
 
+       DAG_id_tag_update(value.data, 0);
        assign_material(ob, value.data, ob->actcol);
 }
 
@@ -724,6 +814,12 @@ static void rna_MaterialSlot_name_get(PointerRNA *ptr, char *str)
                strcpy(str, "");
 }
 
+static void rna_MaterialSlot_update(Main *bmain, Scene *scene, PointerRNA *ptr)
+{
+       rna_Object_internal_update(bmain, scene, ptr);
+       WM_main_add_notifier(NC_OBJECT|ND_OB_SHADING, ptr->id.data);
+}
+
 /* why does this have to be so complicated?, can't all this crap be
  * moved to in BGE conversion function? - Campbell *
  *
@@ -979,31 +1075,32 @@ static void rna_Object_active_constraint_set(PointerRNA *ptr, PointerRNA value)
        constraints_set_active(&ob->constraints, (bConstraint *)value.data);
 }
 
-static bConstraint *rna_Object_constraint_new(Object *object, int type)
+static bConstraint *rna_Object_constraints_new(Object *object, int type)
 {
        WM_main_add_notifier(NC_OBJECT|ND_CONSTRAINT|NA_ADDED, object);
        return add_ob_constraint(object, NULL, type);
 }
 
-static int rna_Object_constraint_remove(Object *object, int index)
+static void rna_Object_constraints_remove(Object *object, ReportList *reports, bConstraint *con)
 {
-       int ok = remove_constraint_index(&object->constraints, index);
-       if(ok) {
-               ED_object_constraint_set_active(object, NULL);
-               WM_main_add_notifier(NC_OBJECT|ND_CONSTRAINT, object);
+       if(BLI_findindex(&object->constraints, con) == -1) {
+               BKE_reportf(reports, RPT_ERROR, "Constraint '%s' not found in object '%s'.", con->name, object->id.name+2);
+               return;
        }
 
-       return ok;
+       remove_constraint(&object->constraints, con);
+       ED_object_constraint_set_active(object, NULL);
+       WM_main_add_notifier(NC_OBJECT|ND_CONSTRAINT, object);
 }
 
-static ModifierData *rna_Object_modifier_new(Object *object, bContext *C, ReportList *reports, char *name, int type)
+static ModifierData *rna_Object_modifier_new(Object *object, bContext *C, ReportList *reports, const char *name, int type)
 {
-       return ED_object_modifier_add(reports, CTX_data_scene(C), object, name, type);
+       return ED_object_modifier_add(reports, CTX_data_main(C), CTX_data_scene(C), object, name, type);
 }
 
 static void rna_Object_modifier_remove(Object *object, bContext *C, ReportList *reports, ModifierData *md)
 {
-       ED_object_modifier_remove(reports, CTX_data_scene(C), object, md);
+       ED_object_modifier_remove(reports, CTX_data_main(C), CTX_data_scene(C), object, md);
 }
 
 static void rna_Object_boundbox_get(PointerRNA *ptr, float *values)
@@ -1014,17 +1111,109 @@ static void rna_Object_boundbox_get(PointerRNA *ptr, float *values)
                memcpy(values, bb->vec, sizeof(bb->vec));
        }
        else {
-               memset(values, -1.0f, sizeof(bb->vec));
+               fill_vn(values, sizeof(bb->vec)/sizeof(float), 0.0f);
+       }
+
+}
+
+static bDeformGroup *rna_Object_vgroup_new(Object *ob, const char *name)
+{
+       bDeformGroup *defgroup = ED_vgroup_add_name(ob, name);
+
+       WM_main_add_notifier(NC_OBJECT|ND_DRAW, ob);
+
+       return defgroup;
+}
+
+static void rna_Object_vgroup_remove(Object *ob, bDeformGroup *defgroup)
+{
+       ED_vgroup_delete(ob, defgroup);
+
+       WM_main_add_notifier(NC_OBJECT|ND_DRAW, ob);
+}
+
+static void rna_VertexGroup_vertex_add(ID *id, bDeformGroup *def, ReportList *reports, int index_len, int *index, float weight, int assignmode)
+{
+       Object *ob = (Object *)id;
+
+       if(ED_vgroup_object_is_edit_mode(ob)) {
+               BKE_reportf(reports, RPT_ERROR, "VertexGroup.add(): Can't be called while object is in edit mode.");
+               return;
        }
 
+       while(index_len--)
+               ED_vgroup_vert_add(ob, def, *index++, weight, assignmode); /* XXX, not efficient calling within loop*/
+
+       WM_main_add_notifier(NC_GEOM|ND_DATA, (ID *)ob->data);
+}
+
+static void rna_VertexGroup_vertex_remove(ID *id, bDeformGroup *dg, ReportList *reports, int index_len, int *index)
+{
+       Object *ob = (Object *)id;
+
+       if(ED_vgroup_object_is_edit_mode(ob)) {
+               BKE_reportf(reports, RPT_ERROR, "VertexGroup.remove(): Can't be called while object is in edit mode.");
+               return;
+       }
+
+       while(index_len--)
+               ED_vgroup_vert_remove(ob, dg, *index++);
+
+       WM_main_add_notifier(NC_GEOM|ND_DATA, (ID *)ob->data);
+}
+
+static float rna_VertexGroup_weight(ID *id, bDeformGroup *dg, ReportList *reports, int index)
+{
+       float weight = ED_vgroup_vert_weight((Object *)id, dg, index);
+
+       if(weight < 0) {
+               BKE_reportf(reports, RPT_ERROR, "Vertex not in group");
+       }
+       return weight;          
+}
+
+/* generic poll functions */
+int rna_Lattice_object_poll(PointerRNA *ptr, PointerRNA value)
+{
+       return ((Object *)value.id.data)->type == OB_LATTICE;
+}
+
+int rna_Curve_object_poll(PointerRNA *ptr, PointerRNA value)
+{
+       return ((Object *)value.id.data)->type == OB_CURVE;
+}
+
+int rna_Armature_object_poll(PointerRNA *ptr, PointerRNA value)
+{
+       return ((Object *)value.id.data)->type == OB_ARMATURE;
+}
+
+int rna_Mesh_object_poll(PointerRNA *ptr, PointerRNA value)
+{
+       return ((Object *)value.id.data)->type == OB_MESH;
+}
+
+int rna_Camera_object_poll(PointerRNA *ptr, PointerRNA value)
+{
+       return ((Object *)value.id.data)->type == OB_CAMERA;
 }
 
 #else
 
+static int rna_matrix_dimsize_4x4[]= {4, 4};
+
 static void rna_def_vertex_group(BlenderRNA *brna)
 {
        StructRNA *srna;
        PropertyRNA *prop;
+       FunctionRNA *func;
+
+       static EnumPropertyItem assign_mode_items[] = {
+               {WEIGHT_REPLACE,  "REPLACE",  0, "Replace",  "Replace"},
+               {WEIGHT_ADD,      "ADD",      0, "Add",      "Add"},
+               {WEIGHT_SUBTRACT, "SUBTRACT", 0, "Subtract", "Subtract"},
+               {0, NULL, 0, NULL, NULL}
+       };
 
        srna= RNA_def_struct(brna, "VertexGroup", NULL);
        RNA_def_struct_sdna(srna, "bDeformGroup");
@@ -1034,12 +1223,38 @@ static void rna_def_vertex_group(BlenderRNA *brna)
        prop= RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
        RNA_def_property_ui_text(prop, "Name", "Vertex group name");
        RNA_def_struct_name_property(srna, prop);
-       RNA_def_property_update(prop, NC_GEOM|ND_DATA|NA_RENAME, NULL);
+       RNA_def_property_update(prop, NC_GEOM|ND_DATA|NA_RENAME, "rna_Object_internal_update_data"); /* update data because modifiers may use [#24761] */
 
        prop= RNA_def_property(srna, "index", PROP_INT, PROP_UNSIGNED);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
        RNA_def_property_int_funcs(prop, "rna_VertexGroup_index_get", NULL, NULL);
        RNA_def_property_ui_text(prop, "Index", "Index number of the vertex group");
+
+       func= RNA_def_function(srna, "add", "rna_VertexGroup_vertex_add");
+       RNA_def_function_ui_description(func, "Add vertices to the group.");
+       RNA_def_function_flag(func, FUNC_USE_REPORTS|FUNC_USE_SELF_ID);
+       /* TODO, see how array size of 0 works, this shouldnt be used */
+       prop= RNA_def_int_array(func, "index", 1, NULL, 0, 0, "", "Index List.", 0, 0);          
+       RNA_def_property_flag(prop, PROP_DYNAMIC|PROP_REQUIRED);
+       prop= RNA_def_float(func, "weight", 0, 0.0f, 1.0f, "", "Vertex weight.", 0.0f, 1.0f);
+       RNA_def_property_flag(prop, PROP_REQUIRED);
+       prop= RNA_def_enum(func, "type", assign_mode_items, 0, "", "Vertex assign mode.");
+       RNA_def_property_flag(prop, PROP_REQUIRED);
+
+       func= RNA_def_function(srna, "remove", "rna_VertexGroup_vertex_remove");
+       RNA_def_function_ui_description(func, "Remove a vertex from the group.");
+       RNA_def_function_flag(func, FUNC_USE_REPORTS|FUNC_USE_SELF_ID);
+       /* TODO, see how array size of 0 works, this shouldnt be used */
+       prop= RNA_def_int_array(func, "index", 1, NULL, 0, 0, "", "Index List.", 0, 0);          
+       RNA_def_property_flag(prop, PROP_DYNAMIC|PROP_REQUIRED);
+
+       func= RNA_def_function(srna, "weight", "rna_VertexGroup_weight");
+       RNA_def_function_ui_description(func, "Get a vertex weight from the group.");
+       RNA_def_function_flag(func, FUNC_USE_REPORTS|FUNC_USE_SELF_ID);
+       prop=RNA_def_int(func, "index", 0, 0, INT_MAX, "Index", "The index of the vertex.", 0, INT_MAX);
+       RNA_def_property_flag(prop, PROP_REQUIRED);
+       prop= RNA_def_float(func, "weight", 0, 0.0f, 1.0f, "", "Vertex weight.", 0.0f, 1.0f);
+       RNA_def_function_return(func, prop);
 }
 
 static void rna_def_material_slot(BlenderRNA *brna)
@@ -1063,15 +1278,15 @@ static void rna_def_material_slot(BlenderRNA *brna)
        prop= RNA_def_property(srna, "material", PROP_POINTER, PROP_NONE);
        RNA_def_property_struct_type(prop, "Material");
        RNA_def_property_flag(prop, PROP_EDITABLE);
-       RNA_def_property_pointer_funcs(prop, "rna_MaterialSlot_material_get", "rna_MaterialSlot_material_set", NULL);
+       RNA_def_property_pointer_funcs(prop, "rna_MaterialSlot_material_get", "rna_MaterialSlot_material_set", NULL, NULL);
        RNA_def_property_ui_text(prop, "Material", "Material datablock used by this material slot");
-       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_internal_update");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_MaterialSlot_update");
 
        prop= RNA_def_property(srna, "link", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_items(prop, link_items);
        RNA_def_property_enum_funcs(prop, "rna_MaterialSlot_link_get", "rna_MaterialSlot_link_set", NULL);
        RNA_def_property_ui_text(prop, "Link", "Link material to object or the object's data");
-       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_internal_update");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_MaterialSlot_update");
 
        prop= RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
        RNA_def_property_string_funcs(prop, "rna_MaterialSlot_name_get", "rna_MaterialSlot_name_length", NULL);
@@ -1141,11 +1356,11 @@ static void rna_def_object_game_settings(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Physics Type",  "Selects the type of physical representation");
        RNA_def_property_update(prop, NC_LOGIC, NULL);
 
-       prop= RNA_def_property(srna, "actor", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_actor", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag", OB_ACTOR);
        RNA_def_property_ui_text(prop, "Actor", "Object is detected by the Near and Radar sensor");
 
-       prop= RNA_def_property(srna, "ghost", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_ghost", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag", OB_GHOST);
        RNA_def_property_ui_text(prop, "Ghost", "Object does not restitute collisions, like a ghost");
 
@@ -1159,7 +1374,7 @@ static void rna_def_object_game_settings(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Radius", "Radius of bounding sphere and material physics");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
 
-       prop= RNA_def_property(srna, "no_sleeping", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_sleep", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag", OB_COLLISION_RESPONSE);
        RNA_def_property_ui_text(prop, "No Sleeping", "Disable auto (de)activation in physics simulation");
 
@@ -1173,40 +1388,40 @@ static void rna_def_object_game_settings(BlenderRNA *brna)
        RNA_def_property_range(prop, 0.0, 1.0);
        RNA_def_property_ui_text(prop, "Rotation Damping", "General rotation damping");
 
-       prop= RNA_def_property(srna, "minimum_velocity", PROP_FLOAT, PROP_NONE);
+       prop= RNA_def_property(srna, "velocity_min", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "min_vel");
        RNA_def_property_range(prop, 0.0, 1000.0);
        RNA_def_property_ui_text(prop, "Velocity Min", "Clamp velocity to this minimum speed (except when totally still)");
 
-       prop= RNA_def_property(srna, "maximum_velocity", PROP_FLOAT, PROP_NONE);
+       prop= RNA_def_property(srna, "velocity_max", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "max_vel");
        RNA_def_property_range(prop, 0.0, 1000.0);
        RNA_def_property_ui_text(prop, "Velocity Max", "Clamp velocity to this maximum speed");
 
        /* lock position */
-       prop= RNA_def_property(srna, "lock_x_axis", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "lock_location_x", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag2", OB_LOCK_RIGID_BODY_X_AXIS);
        RNA_def_property_ui_text(prop, "Lock X Axis", "Disable simulation of linear motion along the X axis");
        
-       prop= RNA_def_property(srna, "lock_y_axis", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "lock_location_y", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag2", OB_LOCK_RIGID_BODY_Y_AXIS);
        RNA_def_property_ui_text(prop, "Lock Y Axis", "Disable simulation of linear motion along the Y axis");
        
-       prop= RNA_def_property(srna, "lock_z_axis", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "lock_location_z", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag2", OB_LOCK_RIGID_BODY_Z_AXIS);
        RNA_def_property_ui_text(prop, "Lock Z Axis", "Disable simulation of linear motion along the Z axis");
        
        
        /* lock rotation */
-       prop= RNA_def_property(srna, "lock_x_rot_axis", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "lock_rotation_x", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag2", OB_LOCK_RIGID_BODY_X_ROT_AXIS);
        RNA_def_property_ui_text(prop, "Lock X Rotation Axis", "Disable simulation of angular  motion along the X axis");
        
-       prop= RNA_def_property(srna, "lock_y_rot_axis", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "lock_rotation_y", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag2", OB_LOCK_RIGID_BODY_Y_ROT_AXIS);
        RNA_def_property_ui_text(prop, "Lock Y Rotation Axis", "Disable simulation of angular  motion along the Y axis");
        
-       prop= RNA_def_property(srna, "lock_z_rot_axis", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "lock_rotation_z", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag2", OB_LOCK_RIGID_BODY_Z_ROT_AXIS);
        RNA_def_property_ui_text(prop, "Lock Z Rotation Axis", "Disable simulation of angular  motion along the Z axis");
        
@@ -1216,11 +1431,11 @@ static void rna_def_object_game_settings(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Lock Z Rotation Axis", "Disable simulation of angular  motion along the Z axis");       
        
 
-       prop= RNA_def_property(srna, "material_physics", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_material_physics", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag", OB_DO_FH);
        RNA_def_property_ui_text(prop, "Use Material Physics", "Use physics settings in materials");
 
-       prop= RNA_def_property(srna, "rotate_from_normal", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_rotate_from_normal", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag", OB_ROT_FH);
        RNA_def_property_ui_text(prop, "Rotate From Normal", "Use face normal to rotate object, so that it points away from the surface");
 
@@ -1229,7 +1444,7 @@ static void rna_def_object_game_settings(BlenderRNA *brna)
        RNA_def_property_range(prop, 0.0, 1.0);
        RNA_def_property_ui_text(prop, "Form Factor", "Form factor scales the inertia tensor");
 
-       prop= RNA_def_property(srna, "anisotropic_friction", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_anisotropic_friction", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag", OB_ANISOTROPIC_FRICTION);
        RNA_def_property_ui_text(prop, "Anisotropic Friction", "Enable anisotropic friction");
 
@@ -1242,14 +1457,14 @@ static void rna_def_object_game_settings(BlenderRNA *brna)
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag", OB_BOUNDS);
        RNA_def_property_ui_text(prop, "Use Collision Bounds", "Specify a collision bounds type other than the default");
 
-       prop= RNA_def_property(srna, "collision_bounds", PROP_ENUM, PROP_NONE);
+       prop= RNA_def_property(srna, "collision_bounds_type", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "boundtype");
        RNA_def_property_enum_items(prop, collision_bounds_items);
        RNA_def_property_enum_funcs(prop, NULL, NULL, "rna_Object_collision_bounds_itemf");
        RNA_def_property_ui_text(prop, "Collision Bounds",  "Selects the collision type");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
 
-       prop= RNA_def_property(srna, "collision_compound", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_collision_compound", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag", OB_CHILD);
        RNA_def_property_ui_text(prop, "Collision Compound", "Add children to form a compound collision object");
 
@@ -1264,29 +1479,29 @@ static void rna_def_object_game_settings(BlenderRNA *brna)
 
        /* state */
 
-       prop= RNA_def_property(srna, "state", PROP_BOOLEAN, PROP_LAYER_MEMBER);
+       prop= RNA_def_property(srna, "states_visible", PROP_BOOLEAN, PROP_LAYER_MEMBER);
        RNA_def_property_boolean_sdna(prop, NULL, "state", 1);
        RNA_def_property_array(prop, OB_MAX_STATES);
        RNA_def_property_ui_text(prop, "State", "State determining which controllers are displayed");
        RNA_def_property_boolean_funcs(prop, "rna_GameObjectSettings_state_get", "rna_GameObjectSettings_state_set");
 
-       prop= RNA_def_property(srna, "used_state", PROP_BOOLEAN, PROP_LAYER_MEMBER);
+       prop= RNA_def_property(srna, "used_states", PROP_BOOLEAN, PROP_LAYER_MEMBER);
        RNA_def_property_array(prop, OB_MAX_STATES);
        RNA_def_property_ui_text(prop, "Used State", "States which are being used by controllers");
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
        RNA_def_property_boolean_funcs(prop, "rna_GameObjectSettings_used_state_get", NULL);
        
-       prop= RNA_def_property(srna, "initial_state", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "states_initial", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "init_state", 1);
        RNA_def_property_array(prop, OB_MAX_STATES);
        RNA_def_property_ui_text(prop, "Initial State", "Initial state when the game starts");
 
-       prop= RNA_def_property(srna, "debug_state", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_debug_state", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "scaflag", OB_DEBUGSTATE);
        RNA_def_property_ui_text(prop, "Debug State", "Print state debug info in the game engine");
        RNA_def_property_ui_icon(prop, ICON_INFO, 0);
 
-       prop= RNA_def_property(srna, "all_states", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_all_states", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "scaflag", OB_ALLSTATE);
        RNA_def_property_ui_text(prop, "All", "Set all state bits");
 
@@ -1313,32 +1528,30 @@ static void rna_def_object_constraints(BlenderRNA *brna, PropertyRNA *cprop)
        /* Collection active property */
        prop= RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
        RNA_def_property_struct_type(prop, "Constraint");
-       RNA_def_property_pointer_funcs(prop, "rna_Object_active_constraint_get", "rna_Object_active_constraint_set", NULL);
+       RNA_def_property_pointer_funcs(prop, "rna_Object_active_constraint_get", "rna_Object_active_constraint_set", NULL, NULL);
        RNA_def_property_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Active Constraint", "Active Object constraint");
 
 
        /* Constraint collection */
-       func= RNA_def_function(srna, "new", "rna_Object_constraint_new");
+       func= RNA_def_function(srna, "new", "rna_Object_constraints_new");
        RNA_def_function_ui_description(func, "Add a new constraint to this object");
-       /* return type */
-       parm= RNA_def_pointer(func, "constraint", "Constraint", "", "New constraint.");
-       RNA_def_function_return(func, parm);
        /* object to add */
        parm= RNA_def_enum(func, "type", constraint_type_items, 1, "", "Constraint type to add.");
        RNA_def_property_flag(parm, PROP_REQUIRED);
-
-       func= RNA_def_function(srna, "remove", "rna_Object_constraint_remove");
-       RNA_def_function_ui_description(func, "Remove a constraint from this object.");
        /* return type */
-       parm= RNA_def_boolean(func, "success", 0, "Success", "Removed the constraint successfully.");
+       parm= RNA_def_pointer(func, "constraint", "Constraint", "", "New constraint.");
        RNA_def_function_return(func, parm);
-       /* object to add */
-       parm= RNA_def_int(func, "index", 0, 0, INT_MAX, "Index", "", 0, INT_MAX);
-       RNA_def_property_flag(parm, PROP_REQUIRED);
+
+       func= RNA_def_function(srna, "remove", "rna_Object_constraints_remove");
+       RNA_def_function_ui_description(func, "Remove a constraint from this object.");
+       RNA_def_function_flag(func, FUNC_USE_REPORTS);
+       /* constraint to remove */
+       parm= RNA_def_pointer(func, "constraint", "Constraint", "", "Removed constraint.");
+       RNA_def_property_flag(parm, PROP_REQUIRED|PROP_NEVER_NULL);
 }
 
-/* armature.bones.* */
+/* object.modifiers */
 static void rna_def_object_modifiers(BlenderRNA *brna, PropertyRNA *cprop)
 {
        StructRNA *srna;
@@ -1358,7 +1571,7 @@ static void rna_def_object_modifiers(BlenderRNA *brna, PropertyRNA *cprop)
        RNA_def_property_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Active EditBone", "Armatures active edit bone");
        //RNA_def_property_update(prop, 0, "rna_Armature_act_editbone_update");
-       RNA_def_property_pointer_funcs(prop, NULL, "rna_Armature_act_edit_bone_set", NULL);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_Armature_act_edit_bone_set", NULL, NULL);
 
        /* todo, redraw */
 //             RNA_def_property_collection_active(prop, prop_act);
@@ -1381,34 +1594,92 @@ static void rna_def_object_modifiers(BlenderRNA *brna, PropertyRNA *cprop)
        func= RNA_def_function(srna, "remove", "rna_Object_modifier_remove");
        RNA_def_function_flag(func, FUNC_USE_CONTEXT|FUNC_USE_REPORTS);
        RNA_def_function_ui_description(func, "Remove an existing modifier from the object.");
+
        /* target to remove*/
        parm= RNA_def_pointer(func, "modifier", "Modifier", "", "Modifier to remove.");
-       RNA_def_property_flag(parm, PROP_REQUIRED);
+       RNA_def_property_flag(parm, PROP_REQUIRED|PROP_NEVER_NULL);
 }
 
-static void rna_def_object(BlenderRNA *brna)
+/* object.particle_systems */
+static void rna_def_object_particle_systems(BlenderRNA *brna, PropertyRNA *cprop)
 {
        StructRNA *srna;
+       
        PropertyRNA *prop;
 
-       static EnumPropertyItem object_type_items[] = {
-               {OB_EMPTY, "EMPTY", 0, "Empty", ""},
-               {OB_MESH, "MESH", 0, "Mesh", ""},
-               {OB_CURVE, "CURVE", 0, "Curve", ""},
-               {OB_SURF, "SURFACE", 0, "Surface", ""},
-               {OB_FONT, "TEXT", 0, "Text", ""},
-               {OB_MBALL, "META", 0, "Meta", ""},
-               {OB_LAMP, "LAMP", 0, "Lamp", ""},
-               {OB_CAMERA, "CAMERA", 0, "Camera", ""},
-               {OB_WAVE, "WAVE", 0, "Wave", ""},
-               {OB_LATTICE, "LATTICE", 0, "Lattice", ""},
-               {OB_ARMATURE, "ARMATURE", 0, "Armature", ""},
-               {0, NULL, 0, NULL, NULL}};
+       // FunctionRNA *func;
+       // PropertyRNA *parm;
+
+       RNA_def_property_srna(cprop, "ParticleSystems");
+       srna= RNA_def_struct(brna, "ParticleSystems", NULL);
+       RNA_def_struct_sdna(srna, "Object");
+       RNA_def_struct_ui_text(srna, "Particle Systems", "Collection of particle systems");
+
+       prop= RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
+       RNA_def_property_struct_type(prop, "ParticleSystem");
+       RNA_def_property_pointer_funcs(prop, "rna_Object_active_particle_system_get", NULL, NULL, NULL);
+       RNA_def_property_ui_text(prop, "Active Particle System", "Active particle system being displayed");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
+       
+       prop= RNA_def_property(srna, "active_index", PROP_INT, PROP_UNSIGNED);
+       RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
+       RNA_def_property_int_funcs(prop, "rna_Object_active_particle_system_index_get", "rna_Object_active_particle_system_index_set", "rna_Object_active_particle_system_index_range");
+       RNA_def_property_ui_text(prop, "Active Particle System Index", "Index of active particle system slot");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_particle_update");
+}
+
+
+/* object.vertex_groups */
+static void rna_def_object_vertex_groups(BlenderRNA *brna, PropertyRNA *cprop)
+{
+       StructRNA *srna;
+       
+       PropertyRNA *prop;
+
+       FunctionRNA *func;
+       PropertyRNA *parm;
+
+       RNA_def_property_srna(cprop, "VertexGroups");
+       srna= RNA_def_struct(brna, "VertexGroups", NULL);
+       RNA_def_struct_sdna(srna, "Object");
+       RNA_def_struct_ui_text(srna, "Vertex Groups", "Collection of vertex groups");
+
+       prop= RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
+       RNA_def_property_struct_type(prop, "VertexGroup");
+       RNA_def_property_pointer_funcs(prop, "rna_Object_active_vertex_group_get", "rna_Object_active_vertex_group_set", NULL, NULL);
+       RNA_def_property_ui_text(prop, "Active Vertex Group", "Vertex groups of the object");
+       RNA_def_property_update(prop, NC_GEOM|ND_DATA, "rna_Object_internal_update_data");
+
+       prop= RNA_def_property(srna, "active_index", PROP_INT, PROP_NONE);
+       RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
+       RNA_def_property_int_sdna(prop, NULL, "actdef");
+       RNA_def_property_int_funcs(prop, "rna_Object_active_vertex_group_index_get", "rna_Object_active_vertex_group_index_set", "rna_Object_active_vertex_group_index_range");
+       RNA_def_property_ui_text(prop, "Active Vertex Group Index", "Active index in vertex group array");
+       RNA_def_property_update(prop, NC_GEOM|ND_DATA, "rna_Object_internal_update_data");
+       
+       /* vertex groups */ // add_vertex_group
+       func= RNA_def_function(srna, "new", "rna_Object_vgroup_new");
+       RNA_def_function_ui_description(func, "Add vertex group to object.");
+       RNA_def_string(func, "name", "Group", 0, "", "Vertex group name."); /* optional */
+       parm= RNA_def_pointer(func, "group", "VertexGroup", "", "New vertex group.");
+       RNA_def_function_return(func, parm);
+
+       func= RNA_def_function(srna, "remove", "rna_Object_vgroup_remove");
+       RNA_def_function_ui_description(func, "Delete vertex group from object.");
+       parm= RNA_def_pointer(func, "group", "VertexGroup", "", "Vertex group to remove.");
+       RNA_def_property_flag(parm, PROP_REQUIRED|PROP_NEVER_NULL);
+}
+
+
+static void rna_def_object(BlenderRNA *brna)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
 
        static EnumPropertyItem empty_drawtype_items[] = {
+               {OB_PLAINAXES, "PLAIN_AXES", 0, "Plain Axes", ""},
                {OB_ARROWS, "ARROWS", 0, "Arrows", ""},
                {OB_SINGLE_ARROW, "SINGLE_ARROW", 0, "Single Arrow", ""},
-               {OB_PLAINAXES, "PLAIN_AXES", 0, "Plain Axes", ""},
                {OB_CIRCLE, "CIRCLE", 0, "Circle", ""},
                {OB_CUBE, "CUBE", 0, "Cube", ""},
                {OB_EMPTY_SPHERE, "SPHERE", 0, "Sphere", ""},
@@ -1443,7 +1714,8 @@ static void rna_def_object(BlenderRNA *brna)
                {OB_BOUND_SPHERE, "SPHERE", 0, "Sphere", ""},
                {OB_BOUND_CYLINDER, "CYLINDER", 0, "Cylinder", ""},
                {OB_BOUND_CONE, "CONE", 0, "Cone", ""},
-               {OB_BOUND_POLYH, "POLYHEDER", 0, "Polyheder", ""},
+               {OB_BOUND_POLYH, "POLYHEDRON", 0, "Polyhedron", ""},
+               {OB_BOUND_CAPSULE, "CAPSULE", 0, "Capsule", ""},
                {0, NULL, 0, NULL, NULL}};
 
        static EnumPropertyItem dupli_items[] = {
@@ -1469,8 +1741,7 @@ static void rna_def_object(BlenderRNA *brna)
        static float default_quat[4] = {1,0,0,0};       /* default quaternion values */
        static float default_axisAngle[4] = {0,0,1,0};  /* default axis-angle rotation values */
        static float default_scale[3] = {1,1,1}; /* default scale values */
-       int matrix_dimsize[]= {4, 4};
-       int boundbox_dimsize[]= {8, 3};
+       static int boundbox_dimsize[]= {8, 3};
 
        srna= RNA_def_struct(brna, "Object", "ID");
        RNA_def_struct_ui_text(srna, "Object", "Object datablock defining an object in a scene");
@@ -1479,9 +1750,9 @@ static void rna_def_object(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "data", PROP_POINTER, PROP_NONE);
        RNA_def_property_struct_type(prop, "ID");
-       RNA_def_property_pointer_funcs(prop, NULL, "rna_Object_data_set", "rna_Object_data_typef");
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_Object_data_set", "rna_Object_data_typef", NULL);
        RNA_def_property_editable_func(prop, "rna_Object_data_editable");
-       RNA_def_property_flag(prop, PROP_EDITABLE);
+       RNA_def_property_flag(prop, PROP_EDITABLE|PROP_NEVER_UNLINK);
        RNA_def_property_ui_text(prop, "Data", "Object data");
        RNA_def_property_update(prop, 0, "rna_Object_internal_update_data");
 
@@ -1505,9 +1776,9 @@ static void rna_def_object(BlenderRNA *brna)
        RNA_def_property_flag(prop, PROP_LIB_EXCEPTION);
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_layer_update");
 
-       prop= RNA_def_property(srna, "selected", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "select", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", SELECT);
-       RNA_def_property_ui_text(prop, "Selected", "Object selection state");
+       RNA_def_property_ui_text(prop, "Select", "Object selection state");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_select_update");
 
        /* for data access */
@@ -1515,11 +1786,11 @@ static void rna_def_object(BlenderRNA *brna)
        RNA_def_property_multi_array(prop, 2, boundbox_dimsize);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
        RNA_def_property_float_funcs(prop, "rna_Object_boundbox_get", NULL, NULL);
-       RNA_def_property_ui_text(prop, "Bound Box", "Objects bound box in object-space coordinates");
+       RNA_def_property_ui_text(prop, "Bound Box", "Objects bound box in object-space coordinates, all values are -1.0 when not available.");
 
        /* parent */
        prop= RNA_def_property(srna, "parent", PROP_POINTER, PROP_NONE);
-       RNA_def_property_pointer_funcs(prop, NULL, "rna_Object_parent_set", NULL);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_Object_parent_set", NULL, NULL);
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_ui_text(prop, "Parent", "Parent Object");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_dependency_update");
@@ -1569,26 +1840,28 @@ static void rna_def_object(BlenderRNA *brna)
        prop= RNA_def_property(srna, "material_slots", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_collection_sdna(prop, NULL, "mat", "totcol");
        RNA_def_property_struct_type(prop, "MaterialSlot");
-       RNA_def_property_collection_funcs(prop, NULL, NULL, NULL, "rna_iterator_array_get", 0, 0, 0); /* don't dereference pointer! */
+       RNA_def_property_collection_funcs(prop, NULL, NULL, NULL, "rna_iterator_array_get", NULL, NULL, NULL); /* don't dereference pointer! */
        RNA_def_property_ui_text(prop, "Material Slots", "Material slots in the object");
 
        prop= RNA_def_property(srna, "active_material", PROP_POINTER, PROP_NONE);
        RNA_def_property_struct_type(prop, "Material");
-       RNA_def_property_pointer_funcs(prop, "rna_Object_active_material_get", "rna_Object_active_material_set", NULL);
+       RNA_def_property_pointer_funcs(prop, "rna_Object_active_material_get", "rna_Object_active_material_set", NULL, NULL);
        RNA_def_property_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Active Material", "Active material being displayed");
-       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_internal_update");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_MaterialSlot_update");
 
        prop= RNA_def_property(srna, "active_material_index", PROP_INT, PROP_UNSIGNED);
        RNA_def_property_int_sdna(prop, NULL, "actcol");
+       RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
        RNA_def_property_int_funcs(prop, "rna_Object_active_material_index_get", "rna_Object_active_material_index_set", "rna_Object_active_material_index_range");
        RNA_def_property_ui_text(prop, "Active Material Index", "Index of active material slot");
-       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
+       RNA_def_property_update(prop, NC_MATERIAL|ND_SHADING, NULL);
        
        /* transform */
        prop= RNA_def_property(srna, "location", PROP_FLOAT, PROP_TRANSLATION);
        RNA_def_property_float_sdna(prop, NULL, "loc");
        RNA_def_property_editable_array_func(prop, "rna_Object_location_editable");
+       RNA_def_property_ui_range(prop, -FLT_MAX, FLT_MAX, 1, 3);
        RNA_def_property_ui_text(prop, "Location", "Location of the object");
        RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_internal_update");
        
@@ -1626,6 +1899,7 @@ static void rna_def_object(BlenderRNA *brna)
        prop= RNA_def_property(srna, "scale", PROP_FLOAT, PROP_XYZ);
        RNA_def_property_float_sdna(prop, NULL, "size");
        RNA_def_property_editable_array_func(prop, "rna_Object_scale_editable");
+       RNA_def_property_ui_range(prop, -FLT_MAX, FLT_MAX, 1, 3);
        RNA_def_property_float_array_default(prop, default_scale);
        RNA_def_property_ui_text(prop, "Scale", "Scaling of the object");
        RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_internal_update");
@@ -1633,6 +1907,7 @@ static void rna_def_object(BlenderRNA *brna)
        prop= RNA_def_property(srna, "dimensions", PROP_FLOAT, PROP_XYZ_LENGTH);
        RNA_def_property_array(prop, 3);
        RNA_def_property_float_funcs(prop, "rna_Object_dimensions_get", "rna_Object_dimensions_set", NULL);
+       RNA_def_property_ui_range(prop, -FLT_MAX, FLT_MAX, 1, 3);
        RNA_def_property_ui_text(prop, "Dimensions", "Absolute bounding box dimensions of the object");
        RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_internal_update");
        
@@ -1700,12 +1975,27 @@ static void rna_def_object(BlenderRNA *brna)
        RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_internal_update");
 
        /* matrix */
-       prop= RNA_def_property(srna, "matrix", PROP_FLOAT, PROP_MATRIX);
+       prop= RNA_def_property(srna, "matrix_world", PROP_FLOAT, PROP_MATRIX);
        RNA_def_property_float_sdna(prop, NULL, "obmat");
-       RNA_def_property_multi_array(prop, 2, matrix_dimsize);
-       RNA_def_property_ui_text(prop, "Matrix", "Transformation matrix");
-       RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_matrix_update");
-
+       RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
+       RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
+       RNA_def_property_ui_text(prop, "Matrix World", "Worldspace transformation matrix");
+       RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_matrix_world_update");
+
+       prop= RNA_def_property(srna, "matrix_local", PROP_FLOAT, PROP_MATRIX);
+       RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
+       RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
+       RNA_def_property_ui_text(prop, "Local Matrix", "Parent relative transformation matrix");
+       RNA_def_property_float_funcs(prop, "rna_Object_matrix_local_get", "rna_Object_matrix_local_set", NULL);
+       RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, NULL);
+
+       prop= RNA_def_property(srna, "matrix_basis", PROP_FLOAT, PROP_MATRIX);
+       RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
+       RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
+       RNA_def_property_ui_text(prop, "Input Matrix", "Matrix access to location, rotation and scale (including deltas), before constraints and parenting are applied.");
+       RNA_def_property_float_funcs(prop, "rna_Object_matrix_basis_get", "rna_Object_matrix_basis_set", NULL);
+       RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_internal_update");
+       
        /* collections */
        prop= RNA_def_property(srna, "constraints", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_struct_type(prop, "Constraint");
@@ -1722,7 +2012,7 @@ static void rna_def_object(BlenderRNA *brna)
        prop= RNA_def_property(srna, "game", PROP_POINTER, PROP_NONE);
        RNA_def_property_flag(prop, PROP_NEVER_NULL);
        RNA_def_property_struct_type(prop, "GameObjectSettings");
-       RNA_def_property_pointer_funcs(prop, "rna_Object_game_settings_get", NULL, NULL);
+       RNA_def_property_pointer_funcs(prop, "rna_Object_game_settings_get", NULL, NULL, NULL);
        RNA_def_property_ui_text(prop, "Game Settings", "Game engine related settings for the object");
 
        /* vertex groups */
@@ -1730,18 +2020,7 @@ static void rna_def_object(BlenderRNA *brna)
        RNA_def_property_collection_sdna(prop, NULL, "defbase", NULL);
        RNA_def_property_struct_type(prop, "VertexGroup");
        RNA_def_property_ui_text(prop, "Vertex Groups", "Vertex groups of the object");
-
-       prop= RNA_def_property(srna, "active_vertex_group", PROP_POINTER, PROP_NONE);
-       RNA_def_property_struct_type(prop, "VertexGroup");
-       RNA_def_property_pointer_funcs(prop, "rna_Object_active_vertex_group_get", "rna_Object_active_vertex_group_set", NULL);
-       RNA_def_property_ui_text(prop, "Active Vertex Group", "Vertex groups of the object");
-       RNA_def_property_update(prop, NC_GEOM|ND_DATA, "rna_Object_internal_update_data");
-
-       prop= RNA_def_property(srna, "active_vertex_group_index", PROP_INT, PROP_NONE);
-       RNA_def_property_int_sdna(prop, NULL, "actdef");
-       RNA_def_property_int_funcs(prop, "rna_Object_active_vertex_group_index_get", "rna_Object_active_vertex_group_index_set", "rna_Object_active_vertex_group_index_range");
-       RNA_def_property_ui_text(prop, "Active Vertex Group Index", "Active index in vertex group array");
-       RNA_def_property_update(prop, NC_GEOM|ND_DATA, "rna_Object_internal_update_data");
+       rna_def_object_vertex_groups(brna, prop);
 
        /* empty */
        prop= RNA_def_property(srna, "empty_draw_type", PROP_ENUM, PROP_NONE);
@@ -1772,13 +2051,13 @@ static void rna_def_object(BlenderRNA *brna)
        prop= RNA_def_property(srna, "field", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "pd");
        RNA_def_property_struct_type(prop, "FieldSettings");
-       RNA_def_property_pointer_funcs(prop, "rna_Object_field_get", NULL, NULL);
+       RNA_def_property_pointer_funcs(prop, "rna_Object_field_get", NULL, NULL, NULL);
        RNA_def_property_ui_text(prop, "Field Settings", "Settings for using the objects as a field in physics simulation");
 
        prop= RNA_def_property(srna, "collision", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "pd");
        RNA_def_property_struct_type(prop, "CollisionSettings");
-       RNA_def_property_pointer_funcs(prop, "rna_Object_collision_get", NULL, NULL);
+       RNA_def_property_pointer_funcs(prop, "rna_Object_collision_get", NULL, NULL, NULL);
        RNA_def_property_ui_text(prop, "Collision Settings", "Settings for using the objects as a collider in physics simulation");
 
        prop= RNA_def_property(srna, "soft_body", PROP_POINTER, PROP_NONE);
@@ -1790,32 +2069,22 @@ static void rna_def_object(BlenderRNA *brna)
        RNA_def_property_collection_sdna(prop, NULL, "particlesystem", NULL);
        RNA_def_property_struct_type(prop, "ParticleSystem");
        RNA_def_property_ui_text(prop, "Particle Systems", "Particle systems emitted from the object");
-
-       prop= RNA_def_property(srna, "active_particle_system", PROP_POINTER, PROP_NONE);
-       RNA_def_property_struct_type(prop, "ParticleSystem");
-       RNA_def_property_pointer_funcs(prop, "rna_Object_active_particle_system_get", NULL, NULL);
-       RNA_def_property_ui_text(prop, "Active Particle System", "Active particle system being displayed");
-       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
-
-       prop= RNA_def_property(srna, "active_particle_system_index", PROP_INT, PROP_UNSIGNED);
-       RNA_def_property_int_funcs(prop, "rna_Object_active_particle_system_index_get", "rna_Object_active_particle_system_index_set", "rna_Object_active_particle_system_index_range");
-       RNA_def_property_ui_text(prop, "Active Particle System Index", "Index of active particle system slot");
-       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_particle_update");
+       rna_def_object_particle_systems(brna, prop);
 
        /* restrict */
-       prop= RNA_def_property(srna, "restrict_view", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "hide", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "restrictflag", OB_RESTRICT_VIEW);
        RNA_def_property_ui_text(prop, "Restrict View", "Restrict visibility in the viewport");
        RNA_def_property_ui_icon(prop, ICON_RESTRICT_VIEW_OFF, 1);
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
 
-       prop= RNA_def_property(srna, "restrict_select", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "hide_select", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "restrictflag", OB_RESTRICT_SELECT);
        RNA_def_property_ui_text(prop, "Restrict Select", "Restrict selection in the viewport");
        RNA_def_property_ui_icon(prop, ICON_RESTRICT_SELECT_OFF, 1);
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
 
-       prop= RNA_def_property(srna, "restrict_render", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "hide_render", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "restrictflag", OB_RESTRICT_RENDER);
        RNA_def_property_ui_text(prop, "Restrict Render", "Restrict renderability");
        RNA_def_property_ui_icon(prop, ICON_RESTRICT_RENDER_OFF, 1);
@@ -1829,7 +2098,7 @@ static void rna_def_object(BlenderRNA *brna)
        
        /* duplicates */
                // XXX: evil old crap
-       prop= RNA_def_property(srna, "slow_parent", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_slow_parent", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "partype", PARSLOW);
        RNA_def_property_ui_text(prop, "Slow Parent", "Create a delay in the parent relationship");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_internal_update");
@@ -1845,7 +2114,7 @@ static void rna_def_object(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Dupli Frames Speed", "Set dupliframes to use the frame"); // TODO, better descriptio!
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_internal_update");
 
-       prop= RNA_def_property(srna, "use_dupli_verts_rotation", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_dupli_vertices_rotation", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "transflag", OB_DUPLIROT);
        RNA_def_property_ui_text(prop, "Dupli Verts Rotation", "Rotate dupli according to vertex normal");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
@@ -1864,6 +2133,7 @@ static void rna_def_object(BlenderRNA *brna)
        prop= RNA_def_property(srna, "dupli_group", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "dup_group");
        RNA_def_property_flag(prop, PROP_EDITABLE);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_Object_dup_group_set", NULL, NULL);
        RNA_def_property_ui_text(prop, "Dupli Group", "Instance an existing group");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_dependency_update");
 
@@ -1898,7 +2168,7 @@ static void rna_def_object(BlenderRNA *brna)
        RNA_def_property_struct_type(prop, "DupliObject");
        RNA_def_property_ui_text(prop, "Dupli list", "Object duplis");
 
-       prop= RNA_def_property(srna, "duplis_used", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "is_duplicator", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "transflag", OB_DUPLI);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
 
@@ -1909,33 +2179,33 @@ static void rna_def_object(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Time Offset", "Animation offset in frames for F-Curve and dupligroup instances");
        RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_internal_update");
 
-       prop= RNA_def_property(srna, "time_offset_edit", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_time_offset_edit", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "ipoflag", OB_OFFS_OB);
        RNA_def_property_ui_text(prop, "Time Offset Edit", "Use time offset when inserting keys and display time offset for F-Curve and action views");
 
-       prop= RNA_def_property(srna, "time_offset_parent", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_time_offset_parent", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "ipoflag", OB_OFFS_PARENT);
        RNA_def_property_ui_text(prop, "Time Offset Parent", "Apply the time offset to this objects parent relationship");
        RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_internal_update");
 
-       prop= RNA_def_property(srna, "time_offset_particle", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_time_offset_particle", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "ipoflag", OB_OFFS_PARTICLE);
        RNA_def_property_ui_text(prop, "Time Offset Particle", "Let the time offset work on the particle effect");
        RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_internal_update");
 
-       prop= RNA_def_property(srna, "time_offset_add_parent", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_time_offset_add_parent", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "ipoflag", OB_OFFS_PARENTADD);
        RNA_def_property_ui_text(prop, "Time Offset Add Parent", "Add the parents time offset value");
        RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_internal_update");
 
        /* drawing */
-       prop= RNA_def_property(srna, "max_draw_type", PROP_ENUM, PROP_NONE);
+       prop= RNA_def_property(srna, "draw_type", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "dt");
        RNA_def_property_enum_items(prop, drawtype_items);
        RNA_def_property_ui_text(prop, "Maximum Draw Type",  "Maximum draw type to display object with in viewport");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
 
-       prop= RNA_def_property(srna, "draw_bounds", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_bounds", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_BOUNDBOX);
        RNA_def_property_ui_text(prop, "Draw Bounds", "Displays the object's bounds");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
@@ -1946,32 +2216,32 @@ static void rna_def_object(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Draw Bounds Type", "Object boundary display type");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
        
-       prop= RNA_def_property(srna, "draw_name", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_name", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_DRAWNAME);
        RNA_def_property_ui_text(prop, "Draw Name", "Displays the object's name");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
        
-       prop= RNA_def_property(srna, "draw_axis", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_axis", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_AXIS);
        RNA_def_property_ui_text(prop, "Draw Axis", "Displays the object's origin and axis");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
        
-       prop= RNA_def_property(srna, "draw_texture_space", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_texture_space", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_TEXSPACE);
        RNA_def_property_ui_text(prop, "Draw Texture Space", "Displays the object's texture space");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
        
-       prop= RNA_def_property(srna, "draw_wire", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_wire", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_DRAWWIRE);
        RNA_def_property_ui_text(prop, "Draw Wire", "Adds the object's wireframe over solid drawing");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
        
-       prop= RNA_def_property(srna, "draw_transparent", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_transparent", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_DRAWTRANSP);
-       RNA_def_property_ui_text(prop, "Draw Transparent", "Enables transparent materials for the object (Mesh only)");
+       RNA_def_property_ui_text(prop, "Draw Transparent", "Displays material transparency in the object");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
        
-       prop= RNA_def_property(srna, "x_ray", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_x_ray", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "dtx", OB_DRAWXRAY);
        RNA_def_property_ui_text(prop, "X-Ray", "Makes the object draw in front of others");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
@@ -1986,6 +2256,7 @@ static void rna_def_object(BlenderRNA *brna)
        /* pose */
        prop= RNA_def_property(srna, "pose_library", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "poselib");
+       RNA_def_property_flag(prop, PROP_EDITABLE);
        RNA_def_property_struct_type(prop, "Action");
        RNA_def_property_ui_text(prop, "Pose Library", "Action used as a pose library for armatures");
 
@@ -1995,13 +2266,13 @@ static void rna_def_object(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Pose", "Current pose for armatures");
 
        /* shape keys */
-       prop= RNA_def_property(srna, "shape_key_lock", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_only_shape_key", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "shapeflag", OB_SHAPE_LOCK);
        RNA_def_property_ui_text(prop, "Shape Key Lock", "Always show the current Shape for this Object");
        RNA_def_property_ui_icon(prop, ICON_UNPINNED, 1);
        RNA_def_property_update(prop, 0, "rna_Object_internal_update_data");
 
-       prop= RNA_def_property(srna, "shape_key_edit_mode", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_shape_key_edit_mode", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "shapeflag", OB_SHAPE_EDIT_MODE);
        RNA_def_property_ui_text(prop, "Shape Key Edit Mode", "Apply shape keys in edit mode (for Meshes only)");
        RNA_def_property_ui_icon(prop, ICON_EDITMODE_HLT, 0);
@@ -2009,7 +2280,7 @@ static void rna_def_object(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "active_shape_key", PROP_POINTER, PROP_NONE);
        RNA_def_property_struct_type(prop, "ShapeKey");
-       RNA_def_property_pointer_funcs(prop, "rna_Object_active_shape_key_get", NULL, NULL);
+       RNA_def_property_pointer_funcs(prop, "rna_Object_active_shape_key_get", NULL, NULL, NULL);
        RNA_def_property_ui_text(prop, "Active Shape Key", "Current shape key");
 
        prop= RNA_def_property(srna, "active_shape_key_index", PROP_INT, PROP_NONE);
@@ -2034,17 +2305,19 @@ static void rna_def_dupli_object(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "object", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "ob");
-       /* RNA_def_property_pointer_funcs(prop, "rna_DupliObject_object_get", NULL, NULL); */
+       /* RNA_def_property_pointer_funcs(prop, "rna_DupliObject_object_get", NULL, NULL, NULL); */
        RNA_def_property_ui_text(prop, "Object", "Object being duplicated");
 
-       prop= RNA_def_property(srna, "object_matrix", PROP_FLOAT, PROP_MATRIX);
+       prop= RNA_def_property(srna, "matrix_original", PROP_FLOAT, PROP_MATRIX);
        RNA_def_property_float_sdna(prop, NULL, "omat");
-       RNA_def_property_array(prop, 16);
-       RNA_def_property_ui_text(prop, "Object Matrix", "Duplicated object transformation matrix");
+       RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
+       RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
+       RNA_def_property_ui_text(prop, "Object Matrix", "The original matrix of this object before it was duplicated");
 
        prop= RNA_def_property(srna, "matrix", PROP_FLOAT, PROP_MATRIX);
        RNA_def_property_float_sdna(prop, NULL, "mat");
-       RNA_def_property_array(prop, 16);
+       RNA_def_property_multi_array(prop, 2, rna_matrix_dimsize_4x4);
+       RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
        RNA_def_property_ui_text(prop, "Object Duplicate Matrix", "Object duplicate transformation matrix");
 
        /* TODO: DupliObject has more properties that can be wrapped */
@@ -2072,16 +2345,11 @@ static void rna_def_object_base(BlenderRNA *brna)
        RNA_def_property_boolean_funcs(prop, NULL, "rna_Base_layer_set");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Base_layer_update");
        
-       prop= RNA_def_property(srna, "selected", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "select", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", BA_SELECT);
-       RNA_def_property_ui_text(prop, "Selected", "Object base selection state");
+       RNA_def_property_ui_text(prop, "Select", "Object base selection state");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Base_select_update");
        
-       prop= RNA_def_property(srna, "selected_user", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", BA_WAS_SEL);
-       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-       RNA_def_property_ui_text(prop, "User Selected", "Object base user selection state, used to restore user selection after transformations");
-       
        RNA_api_object_base(srna);
 }
 
@@ -2096,4 +2364,3 @@ void RNA_def_object(BlenderRNA *brna)
 }
 
 #endif
-