Merge with -r 22620:23107.
[blender.git] / source / blender / makesrna / intern / rna_object.c
index 3b54409..8525cf6 100644 (file)
@@ -25,6 +25,7 @@
 #include <stdio.h>
 #include <stdlib.h>
 
+#include "RNA_access.h"
 #include "RNA_define.h"
 #include "RNA_types.h"
 
 #include "DNA_property_types.h"
 #include "DNA_scene_types.h"
 
+#include "WM_api.h"
 #include "WM_types.h"
 
+EnumPropertyItem object_mode_items[] = {
+       {OB_MODE_OBJECT, "OBJECT", ICON_OBJECT_DATAMODE, "Object", ""},
+       {OB_MODE_EDIT, "EDIT", ICON_EDITMODE_HLT, "Edit", ""},
+       {OB_MODE_SCULPT, "SCULPT", ICON_SCULPTMODE_HLT, "Sculpt", ""},
+       {OB_MODE_VERTEX_PAINT, "VERTEX_PAINT", ICON_VPAINT_HLT, "Vertex Paint", ""},
+       {OB_MODE_WEIGHT_PAINT, "WEIGHT_PAINT", ICON_WPAINT_HLT, "Weight Paint", ""},
+       {OB_MODE_TEXTURE_PAINT, "TEXTURE_PAINT", ICON_TPAINT_HLT, "Texture Paint", ""},
+       {OB_MODE_PARTICLE_EDIT, "PARTICLE_EDIT", ICON_PARTICLEMODE, "Particle Edit", ""},
+       {OB_MODE_POSE, "POSE", ICON_POSE_HLT, "Pose", ""},
+       {0, NULL, 0, NULL, NULL}};
+
+static EnumPropertyItem parent_type_items[] = {
+       {PAROBJECT, "OBJECT", 0, "Object", ""},
+       {PARCURVE, "CURVE", 0, "Curve", ""},
+       {PARKEY, "KEY", 0, "Key", ""},
+       {PARSKEL, "ARMATURE", 0, "Armature", ""},
+       {PARSKEL, "LATTICE", 0, "Lattice", ""}, // PARSKEL reuse will give issues
+       {PARVERT1, "VERTEX", 0, "Vertex", ""},
+       {PARVERT3, "VERTEX_3", 0, "3 Vertices", ""},
+       {PARBONE, "BONE", 0, "Bone", ""},
+       {0, NULL, 0, NULL, NULL}};
+
+EnumPropertyItem object_type_items[] = {
+       {OB_MESH, "MESH", 0, "Mesh", ""},
+       {OB_CURVE, "CURVE", 0, "Curve", ""},
+       {OB_SURF, "SURFACE", 0, "Surface", ""},
+       {OB_MBALL, "META", 0, "Meta", ""},
+       {OB_FONT, "TEXT", 0, "Text", ""},
+       {0, "", 0, NULL, NULL},
+       {OB_ARMATURE, "ARMATURE", 0, "Armature", ""},
+       {OB_LATTICE, "LATTICE", 0, "Lattice", ""},
+       {OB_EMPTY, "EMPTY", 0, "Empty", ""},
+       {0, "", 0, NULL, NULL},
+       {OB_CAMERA, "CAMERA", 0, "Camera", ""},
+       {OB_LAMP, "LAMP", 0, "Lamp", ""},
+       {0, NULL, 0, NULL, NULL}
+};
+
 #ifdef RNA_RUNTIME
 
+#include "DNA_key_types.h"
+
 #include "BKE_armature.h"
+#include "BKE_bullet.h"
 #include "BKE_context.h"
 #include "BKE_curve.h"
 #include "BKE_depsgraph.h"
+#include "BKE_effect.h"
+#include "BKE_key.h"
 #include "BKE_material.h"
 #include "BKE_mesh.h"
 #include "BKE_particle.h"
+#include "BKE_scene.h"
 
-static void rna_Object_update(bContext *C, PointerRNA *ptr)
+#include "ED_object.h"
+
+void rna_Object_update(bContext *C, PointerRNA *ptr)
 {
-       DAG_object_flush_update(CTX_data_scene(C), ptr->id.data, OB_RECALC_OB);
+       DAG_id_flush_update(ptr->id.data, OB_RECALC_OB);
 }
 
-static void rna_Object_update_data(bContext *C, PointerRNA *ptr)
+void rna_Object_matrix_update(bContext *C, PointerRNA *ptr)
 {
-       DAG_object_flush_update(CTX_data_scene(C), ptr->id.data, OB_RECALC_DATA);
+       ED_object_apply_obmat(ptr->id.data);
+       rna_Object_update(C, ptr);
+}
+
+void rna_Object_update_data(bContext *C, PointerRNA *ptr)
+{
+       DAG_id_flush_update(ptr->id.data, OB_RECALC_DATA);
+       WM_event_add_notifier(C, NC_OBJECT|ND_DRAW, ptr->id.data);
 }
 
 static void rna_Object_dependency_update(bContext *C, PointerRNA *ptr)
 {
-       DAG_object_flush_update(CTX_data_scene(C), ptr->id.data, OB_RECALC_OB);
+       DAG_id_flush_update(ptr->id.data, OB_RECALC_OB);
        DAG_scene_sort(CTX_data_scene(C));
 }
 
+static void rna_Object_layer_update(bContext *C, PointerRNA *ptr)
+{
+       Object *ob= (Object*)ptr->id.data;
+       Scene *scene= CTX_data_scene(C);
+       Base *base;
+
+       base= object_in_scene(ob, scene);
+       if(!base)
+               return;
+
+       /* try to avoid scene sort */
+       if((ob->lay & scene->lay) && (base->lay & scene->lay))
+               base->lay= ob->lay;
+       else if((ob->lay & scene->lay)==0 && (base->lay & scene->lay)==0)
+               base->lay= ob->lay;
+       else {
+               base->lay= ob->lay;
+               DAG_scene_sort(scene);
+       }
+}
+
 static int rna_Object_data_editable(PointerRNA *ptr)
 {
        Object *ob= (Object*)ptr->data;
@@ -118,6 +194,72 @@ static StructRNA *rna_Object_data_typef(PointerRNA *ptr)
        }
 }
 
+static void rna_Object_parent_set(PointerRNA *ptr, PointerRNA value)
+{
+       Object *ob= (Object*)ptr->data;
+       Object *par= (Object*)value.data;
+
+       ED_object_parent(ob, par, ob->partype, ob->parsubstr);
+}
+
+static void rna_Object_parent_type_set(PointerRNA *ptr, int value)
+{
+       Object *ob= (Object*)ptr->data;
+
+       ED_object_parent(ob, ob->parent, value, ob->parsubstr);
+}
+
+static void rna_Object_track_set(PointerRNA *ptr, PointerRNA value)
+{
+       Object *ob= (Object*)ptr->data;
+
+       if(ob != value.data)
+               ob->track= value.data;
+}
+
+static EnumPropertyItem *rna_Object_parent_type_itemf(bContext *C, PointerRNA *ptr, int *free)
+{
+       Object *ob= (Object*)ptr->data;
+       EnumPropertyItem *item= NULL;
+       int totitem= 0;
+
+       if(C==NULL) {
+               return parent_type_items;
+       }
+       
+       RNA_enum_items_add_value(&item, &totitem, parent_type_items, PAROBJECT);
+
+       if(ob->parent) {
+               Object *par= ob->parent;
+               
+               if(par->type == OB_CURVE)
+                       RNA_enum_items_add_value(&item, &totitem, parent_type_items, PARCURVE);
+               else if(par->type == OB_LATTICE)
+                       RNA_enum_items_add_value(&item, &totitem, &parent_type_items[4], PARSKEL); // special hack: prevents this overriding others
+               else if(par->type == OB_ARMATURE) {
+                       RNA_enum_items_add_value(&item, &totitem, &parent_type_items[3], PARSKEL); // special hack: prevents this being overrided
+                       RNA_enum_items_add_value(&item, &totitem, parent_type_items, PARBONE);
+               }
+               else if(par->type == OB_MESH) {
+                       RNA_enum_items_add_value(&item, &totitem, parent_type_items, PARVERT1);
+                       RNA_enum_items_add_value(&item, &totitem, parent_type_items, PARVERT3);
+               }
+       }
+
+       RNA_enum_item_end(&item, &totitem);
+
+       *free= 1;
+
+       return item;
+}
+
+static void rna_Object_parent_bone_set(PointerRNA *ptr, const char *value)
+{
+       Object *ob= (Object*)ptr->data;
+
+       ED_object_parent(ob, ob->parent, ob->partype, value);
+}
+
 static int rna_VertexGroup_index_get(PointerRNA *ptr)
 {
        Object *ob= (Object*)ptr->id.data;
@@ -128,7 +270,28 @@ static int rna_VertexGroup_index_get(PointerRNA *ptr)
 static PointerRNA rna_Object_active_vertex_group_get(PointerRNA *ptr)
 {
        Object *ob= (Object*)ptr->id.data;
-       return rna_pointer_inherit_refine(ptr, &RNA_VertexGroup, BLI_findlink(&ob->defbase, ob->actdef));
+       return rna_pointer_inherit_refine(ptr, &RNA_VertexGroup, BLI_findlink(&ob->defbase, ob->actdef-1));
+}
+
+static int rna_Object_active_vertex_group_index_get(PointerRNA *ptr)
+{
+       Object *ob= (Object*)ptr->id.data;
+       return MAX2(ob->actdef-1, 0);
+}
+
+static void rna_Object_active_vertex_group_index_set(PointerRNA *ptr, int value)
+{
+       Object *ob= (Object*)ptr->id.data;
+       ob->actdef= value+1;
+}
+
+static void rna_Object_active_vertex_group_index_range(PointerRNA *ptr, int *min, int *max)
+{
+       Object *ob= (Object*)ptr->id.data;
+
+       *min= 0;
+       *max= BLI_countlist(&ob->defbase)-1;
+       *max= MAX2(0, *max);
 }
 
 void rna_object_vgroup_name_index_get(PointerRNA *ptr, char *value, int index)
@@ -228,46 +391,60 @@ void rna_object_vcollayer_name_set(PointerRNA *ptr, const char *value, char *res
        BLI_strncpy(result, "", maxlen);
 }
 
+static int rna_Object_active_material_index_get(PointerRNA *ptr)
+{
+       Object *ob= (Object*)ptr->id.data;
+       return MAX2(ob->actcol-1, 0);
+}
+
+static void rna_Object_active_material_index_set(PointerRNA *ptr, int value)
+{
+       Object *ob= (Object*)ptr->id.data;
+       ob->actcol= value+1;
+}
+
 static void rna_Object_active_material_index_range(PointerRNA *ptr, int *min, int *max)
 {
        Object *ob= (Object*)ptr->id.data;
-       *min= 1;
-       *max= ob->totcol;
+       *min= 0;
+       *max= MAX2(ob->totcol-1, 0);
 }
 
 static PointerRNA rna_Object_active_material_get(PointerRNA *ptr)
 {
        Object *ob= (Object*)ptr->id.data;
-       return rna_pointer_inherit_refine(ptr, &RNA_MaterialSlot, ob->mat+ob->actcol);
+       Material *ma;
+
+       ma= (ob->totcol)? give_current_material(ob, ob->actcol): NULL;
+       return rna_pointer_inherit_refine(ptr, &RNA_Material, ma);
 }
 
-static void rna_Object_active_particle_system_index_range(PointerRNA *ptr, int *min, int *max)
+static void rna_Object_active_material_set(PointerRNA *ptr, PointerRNA value)
 {
        Object *ob= (Object*)ptr->id.data;
-       *min= 1;
-       *max= BLI_countlist(&ob->particlesystem);
+
+       assign_material(ob, value.data, ob->actcol);
 }
 
-static int rna_Object_active_particle_system_index_get(PointerRNA *ptr)
+static void rna_Object_active_particle_system_index_range(PointerRNA *ptr, int *min, int *max)
 {
        Object *ob= (Object*)ptr->id.data;
-       return psys_get_current_num(ob) + 1;
+       *min= 0;
+       *max= BLI_countlist(&ob->particlesystem)-1;
+       *max= MAX2(0, *max);
 }
 
-static void rna_Object_active_particle_system_index_set(struct PointerRNA *ptr, int value)
+static int rna_Object_active_particle_system_index_get(PointerRNA *ptr)
 {
        Object *ob= (Object*)ptr->id.data;
-       psys_set_current_num(ob, value);
+       return psys_get_current_num(ob);
 }
 
-#if 0
-static void rna_Object_active_material_set(PointerRNA *ptr, PointerRNA value)
+static void rna_Object_active_particle_system_index_set(struct PointerRNA *ptr, int value)
 {
        Object *ob= (Object*)ptr->id.data;
-
-       assign_material(ob, value.data, ob->actcol);
+       psys_set_current_num(ob, value);
 }
-#endif
 
 static PointerRNA rna_MaterialSlot_material_get(PointerRNA *ptr)
 {
@@ -292,7 +469,7 @@ static int rna_MaterialSlot_link_get(PointerRNA *ptr)
        Object *ob= (Object*)ptr->id.data;
        int index= (Material**)ptr->data - ob->mat;
 
-       return (ob->colbits & (1<<index)) != 0;
+       return ob->matbits[index] != 0;
 }
 
 static void rna_MaterialSlot_link_set(PointerRNA *ptr, int value)
@@ -300,10 +477,14 @@ static void rna_MaterialSlot_link_set(PointerRNA *ptr, int value)
        Object *ob= (Object*)ptr->id.data;
        int index= (Material**)ptr->data - ob->mat;
        
-       if(value)
+       if(value) {
+               ob->matbits[index]= 1;
                ob->colbits |= (1<<index);
-       else
+       }
+       else {
+               ob->matbits[index]= 0;
                ob->colbits &= ~(1<<index);
+       }
 }
 
 static int rna_MaterialSlot_name_length(PointerRNA *ptr)
@@ -334,6 +515,86 @@ static void rna_MaterialSlot_name_get(PointerRNA *ptr, char *str)
                strcpy(str, "");
 }
 
+/* why does this have to be so complicated?, can't all this crap be
+ * moved to in BGE conversion function? - Campbell *
+ *
+ * logic from check_body_type()
+ *  */
+static int rna_GameObjectSettings_physics_type_get(PointerRNA *ptr)
+{
+       Object *ob= (Object*)ptr->id.data;
+
+       /* determine the body_type setting based on flags */
+       if (!(ob->gameflag & OB_COLLISION)) {
+               if (ob->gameflag & OB_OCCLUDER) {
+                       ob->body_type = OB_BODY_TYPE_OCCLUDER;
+               } else {
+                       ob->body_type = OB_BODY_TYPE_NO_COLLISION;
+               }
+       } else if (ob->gameflag & OB_SENSOR) {
+               ob->body_type = OB_BODY_TYPE_SENSOR;
+       } else if (!(ob->gameflag & OB_DYNAMIC)) {
+               ob->body_type = OB_BODY_TYPE_STATIC;
+       } else if (!(ob->gameflag & (OB_RIGID_BODY|OB_SOFT_BODY))) {
+               ob->body_type = OB_BODY_TYPE_DYNAMIC;
+       } else if (ob->gameflag & OB_RIGID_BODY) {
+               ob->body_type = OB_BODY_TYPE_RIGID;
+       } else {
+               ob->body_type = OB_BODY_TYPE_SOFT;
+               /* create the structure here because we display soft body buttons in the main panel */
+               if (!ob->bsoft)
+                       ob->bsoft = bsbNew();
+       }
+
+       return ob->body_type;
+}
+
+static void rna_GameObjectSettings_physics_type_set(PointerRNA *ptr, int value)
+{
+       Object *ob= (Object*)ptr->id.data;
+       ob->body_type= value;
+
+       switch (ob->body_type) {
+       case OB_BODY_TYPE_SENSOR:
+               ob->gameflag |= OB_SENSOR|OB_COLLISION|OB_GHOST;
+               ob->gameflag &= ~(OB_OCCLUDER|OB_DYNAMIC|OB_RIGID_BODY|OB_SOFT_BODY|OB_ACTOR|OB_ANISOTROPIC_FRICTION|OB_DO_FH|OB_ROT_FH|OB_COLLISION_RESPONSE);
+               break;
+       case OB_BODY_TYPE_OCCLUDER:
+               ob->gameflag |= OB_OCCLUDER;
+               ob->gameflag &= ~(OB_SENSOR|OB_COLLISION|OB_DYNAMIC);
+               break;
+       case OB_BODY_TYPE_NO_COLLISION:
+               ob->gameflag &= ~(OB_SENSOR|OB_COLLISION|OB_OCCLUDER|OB_DYNAMIC);
+               break;
+       case OB_BODY_TYPE_STATIC:
+               ob->gameflag |= OB_COLLISION;
+               ob->gameflag &= ~(OB_DYNAMIC|OB_RIGID_BODY|OB_SOFT_BODY|OB_OCCLUDER|OB_SENSOR);
+               break;
+       case OB_BODY_TYPE_DYNAMIC:
+               ob->gameflag |= OB_COLLISION|OB_DYNAMIC|OB_ACTOR;
+               ob->gameflag &= ~(OB_RIGID_BODY|OB_SOFT_BODY|OB_OCCLUDER|OB_SENSOR);
+               break;
+       case OB_BODY_TYPE_RIGID:
+               ob->gameflag |= OB_COLLISION|OB_DYNAMIC|OB_RIGID_BODY|OB_ACTOR;
+               ob->gameflag &= ~(OB_SOFT_BODY|OB_OCCLUDER|OB_SENSOR);
+               break;
+       default:
+       case OB_BODY_TYPE_SOFT:
+               ob->gameflag |= OB_COLLISION|OB_DYNAMIC|OB_SOFT_BODY|OB_ACTOR;
+               ob->gameflag &= ~(OB_RIGID_BODY|OB_OCCLUDER|OB_SENSOR);
+
+               /* assume triangle mesh, if no bounds chosen for soft body */
+               if ((ob->gameflag & OB_BOUNDS) && (ob->boundtype<OB_BOUND_POLYH))
+               {
+                       ob->boundtype=OB_BOUND_POLYH;
+               }
+               /* create a BulletSoftBody structure if not already existing */
+               if (!ob->bsoft)
+                       ob->bsoft = bsbNew();
+               break;
+       }
+}
+
 static PointerRNA rna_Object_active_particle_system_get(PointerRNA *ptr)
 {
        Object *ob= (Object*)ptr->id.data;
@@ -384,6 +645,88 @@ static void rna_GameObjectSettings_state_set(PointerRNA *ptr, const int *values)
        }
 }
 
+/*
+static PointerRNA rna_DupliObject_object_get(PointerRNA *ptr)
+{
+       DupliObject *dob= (DupliObject*)ptr->data;
+       PointerRNA newptr;
+       RNA_pointer_create(&dob->ob->id, &RNA_Object, dob->ob, &newptr);
+       return newptr;
+}
+*/
+
+static void rna_Object_active_shape_key_index_range(PointerRNA *ptr, int *min, int *max)
+{
+       Object *ob= (Object*)ptr->id.data;
+       Key *key= ob_get_key(ob);
+
+       *min= 0;
+       *max= (key)? BLI_countlist(&key->block)-1: 0;
+       *max= MAX2(0, *max);
+}
+
+static int rna_Object_active_shape_key_index_get(PointerRNA *ptr)
+{
+       Object *ob= (Object*)ptr->id.data;
+
+       return MAX2(ob->shapenr-1, 0);
+}
+
+static void rna_Object_active_shape_key_index_set(PointerRNA *ptr, int value)
+{
+       Object *ob= (Object*)ptr->id.data;
+
+       ob->shapenr= value+1;
+       ob->shapeflag |= OB_SHAPE_TEMPLOCK;
+}
+
+static PointerRNA rna_Object_active_shape_key_get(PointerRNA *ptr)
+{
+       Object *ob= (Object*)ptr->id.data;
+       Key *key= ob_get_key(ob);
+       KeyBlock *kb;
+       PointerRNA keyptr;
+
+       if(key==NULL)
+               return PointerRNA_NULL;
+       
+       kb= BLI_findlink(&key->block, ob->shapenr-1);
+       RNA_pointer_create(&key->id, &RNA_ShapeKey, kb, &keyptr);
+       return keyptr;
+}
+
+static void rna_Object_shape_key_lock_set(PointerRNA *ptr, int value)
+{
+       Object *ob= (Object*)ptr->id.data;
+
+       if(value) ob->shapeflag |= OB_SHAPE_LOCK;
+       else ob->shapeflag &= ~OB_SHAPE_LOCK;
+
+       ob->shapeflag &= ~OB_SHAPE_TEMPLOCK;
+}
+
+static PointerRNA rna_Object_field_get(PointerRNA *ptr)
+{
+       Object *ob= (Object*)ptr->id.data;
+
+       /* weak */
+       if(!ob->pd)
+               ob->pd= object_add_collision_fields();
+       
+       return rna_pointer_inherit_refine(ptr, &RNA_FieldSettings, ob->pd);
+}
+
+static PointerRNA rna_Object_collision_get(PointerRNA *ptr)
+{
+       Object *ob= (Object*)ptr->id.data;
+
+       /* weak */
+       if(!ob->pd)
+               ob->pd= object_add_collision_fields();
+       
+       return rna_pointer_inherit_refine(ptr, &RNA_CollisionSettings, ob->pd);
+}
+
 #else
 
 static void rna_def_vertex_group(BlenderRNA *brna)
@@ -412,8 +755,8 @@ static void rna_def_material_slot(BlenderRNA *brna)
        PropertyRNA *prop;
 
        static EnumPropertyItem link_items[] = {
-               {0, "DATA", 0, "Data", ""},
                {1, "OBJECT", 0, "Object", ""},
+               {0, "DATA", 0, "Data", ""},
                {0, NULL, 0, NULL, NULL}};
        
        /* NOTE: there is no MaterialSlot equivalent in DNA, so the internal
@@ -450,11 +793,13 @@ static void rna_def_object_game_settings(BlenderRNA *brna)
        PropertyRNA *prop;
 
        static EnumPropertyItem body_type_items[] = {
-               {OB_BODY_TYPE_NO_COLLISION, "NO_COLLISION", 0, "No Collision", ""},
-               {OB_BODY_TYPE_STATIC, "STATIC", 0, "Static", ""},
-               {OB_BODY_TYPE_DYNAMIC, "DYNAMIC", 0, "Dynamic", ""},
-               {OB_BODY_TYPE_RIGID, "RIGID_BODY", 0, "Rigid Body", ""},
-               {OB_BODY_TYPE_SOFT, "SOFT_BODY", 0, "Soft Body", ""},
+               {OB_BODY_TYPE_NO_COLLISION, "NO_COLLISION", 0, "No Collision", "Disable colision for this object"},
+               {OB_BODY_TYPE_STATIC, "STATIC", 0, "Static", "Stationary object"},
+               {OB_BODY_TYPE_DYNAMIC, "DYNAMIC", 0, "Dynamic", "Linear physics"},
+               {OB_BODY_TYPE_RIGID, "RIGID_BODY", 0, "Rigid Body", "Linear and angular physics"},
+               {OB_BODY_TYPE_SOFT, "SOFT_BODY", 0, "Soft Body", "Soft body"},
+               {OB_BODY_TYPE_OCCLUDER, "OCCLUDE", 0, "Occlude", "Occluder for optimizing scene rendering"},
+               {OB_BODY_TYPE_SENSOR, "SENSOR", 0, "Sensor", "Collision Sensor, detects static and dynamic objects but not the other collision sensor objects"},
                {0, NULL, 0, NULL, NULL}};
 
        static EnumPropertyItem collision_bounds_items[] = {
@@ -462,8 +807,8 @@ static void rna_def_object_game_settings(BlenderRNA *brna)
                {OB_BOUND_SPHERE, "SPHERE", 0, "Sphere", ""},
                {OB_BOUND_CYLINDER, "CYLINDER", 0, "Cylinder", ""},
                {OB_BOUND_CONE, "CONE", 0, "Cone", ""},
-               {OB_BOUND_POLYH, "CONVEX_HULL", 0, "Convex Hull", ""},
-               {OB_BOUND_POLYT, "TRIANGLE_MESH", 0, "Triangle Mesh", ""},
+               {OB_BOUND_POLYT, "CONVEX_HULL", 0, "Convex Hull", ""},
+               {OB_BOUND_POLYH, "TRIANGLE_MESH", 0, "Triangle Mesh", ""},
                //{OB_DYN_MESH, "DYNAMIC_MESH", 0, "Dynamic Mesh", ""},
                {0, NULL, 0, NULL, NULL}};
 
@@ -489,7 +834,7 @@ static void rna_def_object_game_settings(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "properties", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_collection_sdna(prop, NULL, "prop", NULL);
-       RNA_def_property_struct_type(prop, "GameProperty");
+       RNA_def_property_struct_type(prop, "GameProperty"); /* rna_property.c */
        RNA_def_property_ui_text(prop, "Properties", "Game engine properties.");
 
        prop= RNA_def_property(srna, "show_sensors", PROP_BOOLEAN, PROP_NONE);
@@ -509,7 +854,7 @@ static void rna_def_object_game_settings(BlenderRNA *brna)
        prop= RNA_def_property(srna, "physics_type", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "body_type");
        RNA_def_property_enum_items(prop, body_type_items);
-       RNA_def_property_clear_flag(prop, PROP_EDITABLE); // this controls various gameflags
+       RNA_def_property_enum_funcs(prop, "rna_GameObjectSettings_physics_type_get", "rna_GameObjectSettings_physics_type_set", NULL);
        RNA_def_property_ui_text(prop, "Physics Type",  "Selects the type of physical representation.");
 
        prop= RNA_def_property(srna, "actor", PROP_BOOLEAN, PROP_NONE);
@@ -524,10 +869,10 @@ static void rna_def_object_game_settings(BlenderRNA *brna)
        RNA_def_property_range(prop, 0.01, 10000.0);
        RNA_def_property_ui_text(prop, "Mass", "Mass of the object.");
 
-       prop= RNA_def_property(srna, "radius", PROP_FLOAT, PROP_NONE);
+       prop= RNA_def_property(srna, "radius", PROP_FLOAT, PROP_NONE|PROP_UNIT_LENGTH);
        RNA_def_property_float_sdna(prop, NULL, "inertia");
        RNA_def_property_range(prop, 0.01, 10.0);
-       RNA_def_property_ui_text(prop, "Radius", "Radius for Bounding sphere and Fh/Fh Rot.");
+       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);
@@ -587,13 +932,13 @@ 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, "do_fh", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "material_physics", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag", OB_DO_FH);
-       RNA_def_property_ui_text(prop, "Do Fh", "Use Fh settings in materials.");
+       RNA_def_property_ui_text(prop, "Use Material Physics", "Use physics settings in materials.");
 
-       prop= RNA_def_property(srna, "rotation_fh", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "rotate_from_normal", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag", OB_ROT_FH);
-       RNA_def_property_ui_text(prop, "Rotation Fh", "Use face normal to rotate Object");
+       RNA_def_property_ui_text(prop, "Rotate From Normal", "Use face normal to rotate object, so that it points away from the surface");
 
        prop= RNA_def_property(srna, "form_factor", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "formfactor");
@@ -604,7 +949,7 @@ static void rna_def_object_game_settings(BlenderRNA *brna)
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag", OB_ANISOTROPIC_FRICTION);
        RNA_def_property_ui_text(prop, "Anisotropic Friction", "Enable anisotropic friction.");
 
-       prop= RNA_def_property(srna, "friction_coefficients", PROP_FLOAT, PROP_VECTOR);
+       prop= RNA_def_property(srna, "friction_coefficients", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "anisotropicFriction");
        RNA_def_property_range(prop, 0.0, 1.0);
        RNA_def_property_ui_text(prop, "Friction Coefficients", "Relative friction coefficient in the in the X, Y and Z directions, when anisotropic friction is enabled.");
@@ -622,7 +967,7 @@ static void rna_def_object_game_settings(BlenderRNA *brna)
        RNA_def_property_boolean_sdna(prop, NULL, "gameflag", OB_CHILD);
        RNA_def_property_ui_text(prop, "Collison Compound", "Add children to form a compound collision object.");
 
-       prop= RNA_def_property(srna, "collision_margin", PROP_FLOAT, PROP_NONE);
+       prop= RNA_def_property(srna, "collision_margin", PROP_FLOAT, PROP_NONE|PROP_UNIT_LENGTH);
        RNA_def_property_float_sdna(prop, NULL, "margin");
        RNA_def_property_range(prop, 0.0, 1.0);
        RNA_def_property_ui_text(prop, "Collision Margin", "Extra margin around object for collision detection, small amount required for stability.");
@@ -654,17 +999,6 @@ static void rna_def_object(BlenderRNA *brna)
        StructRNA *srna;
        PropertyRNA *prop;
 
-       static EnumPropertyItem parent_type_items[] = {
-               {PAROBJECT, "OBJECT", 0, "Object", ""},
-               {PARCURVE, "CURVE", 0, "Curve", ""},
-               //{PARKEY, "KEY", 0, "Key", ""},
-               {PARSKEL, "ARMATURE", 0, "Armature", ""},
-               {PARSKEL, "LATTICE", 0, "Lattice", ""}, // PARSKEL reuse will give issues
-               {PARVERT1, "VERTEX", 0, "Vertex", ""},
-               {PARVERT3, "VERTEX_3", 0, "3 Vertices", ""},
-               {PARBONE, "BONE", 0, "Bone", ""},
-               {0, NULL, 0, NULL, NULL}};
-       
        static EnumPropertyItem object_type_items[] = {
                {OB_EMPTY, "EMPTY", 0, "Empty", ""},
                {OB_MESH, "MESH", 0, "Mesh", ""},
@@ -728,6 +1062,8 @@ static void rna_def_object(BlenderRNA *brna)
                {OB_DUPLIGROUP, "GROUP", 0, "Group", "Enable group instancing."},
                {0, NULL, 0, NULL, NULL}};
 
+       int matrix_dimsize[]= {4, 4};
+
        srna= RNA_def_struct(brna, "Object", "ID");
        RNA_def_struct_ui_text(srna, "Object", "Object datablock defining an object in a scene..");
        RNA_def_struct_clear_flag(srna, STRUCT_ID_REFCOUNT);
@@ -739,58 +1075,78 @@ static void rna_def_object(BlenderRNA *brna)
        RNA_def_property_editable_func(prop, "rna_Object_data_editable");
        RNA_def_property_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Data", "Object data.");
-       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_update_data");
+       RNA_def_property_update(prop, 0, "rna_Object_update_data");
+
+       prop= RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "type");
+       RNA_def_property_enum_items(prop, object_type_items);
+       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+       RNA_def_property_ui_text(prop, "Type", "Type of Object.");
 
-       prop= RNA_def_property(srna, "layers", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "mode", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "mode");
+       RNA_def_property_enum_items(prop, object_mode_items);
+       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+       RNA_def_property_ui_text(prop, "Mode", "Object interaction mode.");
+
+       prop= RNA_def_property(srna, "layers", PROP_BOOLEAN, PROP_LAYER_MEMBER);
        RNA_def_property_boolean_sdna(prop, NULL, "lay", 1);
        RNA_def_property_array(prop, 20);
        RNA_def_property_ui_text(prop, "Layers", "Layers the object is on.");
        RNA_def_property_boolean_funcs(prop, NULL, "rna_Object_layer_set");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_layer_update");
 
        prop= RNA_def_property(srna, "selected", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", SELECT);
+       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Selected", "Object selection state.");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
 
        /* parent and track */
 
        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_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Parent", "Parent Object");
-
-       prop= RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
-       RNA_def_property_enum_sdna(prop, NULL, "type");
-       RNA_def_property_enum_items(prop, object_type_items);
-       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-       RNA_def_property_ui_text(prop, "Type", "Type of Object.");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_dependency_update");
        
        prop= RNA_def_property(srna, "parent_type", PROP_ENUM, PROP_NONE);
-       RNA_def_property_enum_sdna(prop, NULL, "partype");
+       RNA_def_property_enum_bitflag_sdna(prop, NULL, "partype");
        RNA_def_property_enum_items(prop, parent_type_items);
-       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+       RNA_def_property_enum_funcs(prop, NULL, "rna_Object_parent_type_set", "rna_Object_parent_type_itemf");
        RNA_def_property_ui_text(prop, "Parent Type", "Type of parent relation.");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_dependency_update");
 
        prop= RNA_def_property(srna, "parent_vertices", PROP_INT, PROP_UNSIGNED);
        RNA_def_property_int_sdna(prop, NULL, "par1");
        RNA_def_property_array(prop, 3);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Parent Vertices", "Indices of vertices in cases of a vertex parenting relation.");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_update");
 
        prop= RNA_def_property(srna, "parent_bone", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "parsubstr");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_Object_parent_bone_set");
        RNA_def_property_ui_text(prop, "Parent Bone", "Name of parent bone in case of a bone parenting relation.");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_dependency_update");
 
        prop= RNA_def_property(srna, "track", PROP_POINTER, PROP_NONE);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_Object_track_set", NULL);
        RNA_def_property_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Track", "Object being tracked to define the rotation (Old Track).");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_dependency_update");
 
        prop= RNA_def_property(srna, "track_axis", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "trackflag");
        RNA_def_property_enum_items(prop, track_items);
        RNA_def_property_ui_text(prop, "Track Axis", "Tracking axis pointing to the another object.");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_update");
 
        prop= RNA_def_property(srna, "up_axis", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "upflag");
        RNA_def_property_enum_items(prop, up_items);
        RNA_def_property_ui_text(prop, "Up Axis", "Specify the axis that points up.");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_update");
 
        /* proxy */
 
@@ -808,58 +1164,61 @@ static void rna_def_object(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Materials", "Material slots in the object.");
 
        prop= RNA_def_property(srna, "active_material", PROP_POINTER, PROP_NONE);
-       RNA_def_property_struct_type(prop, "MaterialSlot");
-       RNA_def_property_pointer_funcs(prop, "rna_Object_active_material_get", NULL, NULL);
+       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_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Active Material", "Active material being displayed.");
+       RNA_def_property_update(prop, NC_OBJECT|ND_SHADING, "rna_Object_update");
 
        prop= RNA_def_property(srna, "active_material_index", PROP_INT, PROP_UNSIGNED);
        RNA_def_property_int_sdna(prop, NULL, "actcol");
-       RNA_def_property_int_funcs(prop, NULL, NULL, "rna_Object_active_material_index_range");
+       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_SHADING, NULL);
+       
        /* transform */
 
-       prop= RNA_def_property(srna, "location", PROP_FLOAT, PROP_VECTOR);
+       prop= RNA_def_property(srna, "location", PROP_FLOAT, PROP_TRANSLATION);
        RNA_def_property_float_sdna(prop, NULL, "loc");
        RNA_def_property_ui_text(prop, "Location", "Location of the object.");
        RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_update");
 
-       prop= RNA_def_property(srna, "delta_location", PROP_FLOAT, PROP_VECTOR);
+       prop= RNA_def_property(srna, "delta_location", PROP_FLOAT, PROP_TRANSLATION);
        RNA_def_property_float_sdna(prop, NULL, "dloc");
        RNA_def_property_ui_text(prop, "Delta Location", "Extra added translation to object location.");
        RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_update");
        
-       prop= RNA_def_property(srna, "rotation", PROP_FLOAT, PROP_ROTATION);
+       prop= RNA_def_property(srna, "rotation", PROP_FLOAT, PROP_EULER);
        RNA_def_property_float_sdna(prop, NULL, "rot");
        RNA_def_property_ui_text(prop, "Rotation", "Rotation of the object.");
        RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_update");
 
-       prop= RNA_def_property(srna, "delta_rotation", PROP_FLOAT, PROP_ROTATION);
+       prop= RNA_def_property(srna, "delta_rotation", PROP_FLOAT, PROP_EULER);
        RNA_def_property_float_sdna(prop, NULL, "drot");
        RNA_def_property_ui_text(prop, "Delta Rotation", "Extra added rotation to the rotation of the object.");
        RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_update");
        
-       prop= RNA_def_property(srna, "scale", PROP_FLOAT, PROP_VECTOR);
+       prop= RNA_def_property(srna, "scale", PROP_FLOAT, PROP_XYZ);
        RNA_def_property_float_sdna(prop, NULL, "size");
        RNA_def_property_ui_text(prop, "Scale", "Scaling of the object.");
        RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_update");
 
-       prop= RNA_def_property(srna, "delta_scale", PROP_FLOAT, PROP_VECTOR);
+       prop= RNA_def_property(srna, "delta_scale", PROP_FLOAT, PROP_XYZ);
        RNA_def_property_float_sdna(prop, NULL, "dsize");
        RNA_def_property_ui_text(prop, "Delta Scale", "Extra added scaling to the scale of the object.");
        RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_update");
 
-       prop= RNA_def_property(srna, "lock_location", PROP_BOOLEAN, PROP_VECTOR);
+       prop= RNA_def_property(srna, "lock_location", PROP_BOOLEAN, PROP_XYZ);
        RNA_def_property_boolean_sdna(prop, NULL, "protectflag", OB_LOCK_LOCX);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Lock Location", "Lock editing of location in the interface.");
 
-       prop= RNA_def_property(srna, "lock_rotation", PROP_BOOLEAN, PROP_VECTOR);
+       prop= RNA_def_property(srna, "lock_rotation", PROP_BOOLEAN, PROP_XYZ);
        RNA_def_property_boolean_sdna(prop, NULL, "protectflag", OB_LOCK_ROTX);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Lock Rotation", "Lock editing of rotation in the interface.");
 
-       prop= RNA_def_property(srna, "lock_scale", PROP_BOOLEAN, PROP_VECTOR);
+       prop= RNA_def_property(srna, "lock_scale", PROP_BOOLEAN, PROP_XYZ);
        RNA_def_property_boolean_sdna(prop, NULL, "protectflag", OB_LOCK_SCALEX);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Lock Scale", "Lock editing of scale in the interface.");
@@ -867,8 +1226,9 @@ static void rna_def_object(BlenderRNA *brna)
        /* matrix */
        prop= RNA_def_property(srna, "matrix", PROP_FLOAT, PROP_MATRIX);
        RNA_def_property_float_sdna(prop, NULL, "obmat");
-       RNA_def_property_array(prop, 16);
+       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");
 
        /* collections */
        prop= RNA_def_property(srna, "constraints", PROP_COLLECTION, PROP_NONE);
@@ -895,8 +1255,15 @@ static void rna_def_object(BlenderRNA *brna)
 
        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", NULL, NULL);
+       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, 0, "rna_Object_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, 0, "rna_Object_update_data");
 
        /* empty */
 
@@ -906,7 +1273,7 @@ static void rna_def_object(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Empty Draw Type", "Viewport display style for empties.");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
 
-       prop= RNA_def_property(srna, "empty_draw_size", PROP_FLOAT, PROP_NONE);
+       prop= RNA_def_property(srna, "empty_draw_size", PROP_FLOAT, PROP_DISTANCE);
        RNA_def_property_float_sdna(prop, NULL, "empty_drawsize");
        RNA_def_property_range(prop, 0.01, 10.0);
        RNA_def_property_ui_text(prop, "Empty Draw Size", "Size of of display for empties in the viewport.");
@@ -921,17 +1288,20 @@ static void rna_def_object(BlenderRNA *brna)
        prop= RNA_def_property(srna, "color", PROP_FLOAT, PROP_COLOR);
        RNA_def_property_float_sdna(prop, NULL, "col");
        RNA_def_property_ui_text(prop, "Color", "Object color and alpha, used when faces have the ObColor mode enabled.");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
 
        /* physics */
 
        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_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_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);
@@ -947,10 +1317,12 @@ static void rna_def_object(BlenderRNA *brna)
        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, NULL);
 
        /* restrict */
 
@@ -962,10 +1334,12 @@ static void rna_def_object(BlenderRNA *brna)
        prop= RNA_def_property(srna, "restrict_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_update(prop, NC_OBJECT|ND_DRAW, NULL);
 
        prop= RNA_def_property(srna, "restrict_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_update(prop, NC_OBJECT|ND_DRAW, NULL);
 
        /* anim */
        
@@ -975,19 +1349,22 @@ static void rna_def_object(BlenderRNA *brna)
        RNA_def_property_boolean_sdna(prop, NULL, "ipoflag", OB_DRAWKEY);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE); // update ipo flag indirect
        RNA_def_property_ui_text(prop, "Draw Keys", "Draw object as key positions.");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_update");
 
        prop= RNA_def_property(srna, "draw_keys_selected", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "ipoflag", OB_DRAWKEYSEL);
        RNA_def_property_ui_text(prop, "Draw Keys Selected", "Limit the drawing of object keys to selected.");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
 
-       prop= RNA_def_property(srna, "track_rotation", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "track_override_parent", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "transflag", OB_POWERTRACK);
-       RNA_def_property_ui_text(prop, "Track Rotation", "Switch object rotation of in tracking.");
+       RNA_def_property_ui_text(prop, "Track Override Parent", "Override rotation from parenting.");
+       RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_update");
 
        prop= RNA_def_property(srna, "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_update");
 
        prop= RNA_def_property(srna, "dupli_type", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_bitflag_sdna(prop, NULL, "transflag");
@@ -1022,35 +1399,41 @@ static void rna_def_object(BlenderRNA *brna)
        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");
 
-       prop= RNA_def_property(srna, "dupli_frames_start", PROP_INT, PROP_NONE);
+       prop= RNA_def_property(srna, "dupli_frames_start", PROP_INT, PROP_NONE|PROP_UNIT_TIME);
        RNA_def_property_int_sdna(prop, NULL, "dupsta");
        RNA_def_property_range(prop, 1, 32767);
        RNA_def_property_ui_text(prop, "Dupli Frames Start", "Start frame for DupliFrames.");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_update");
 
-       prop= RNA_def_property(srna, "dupli_frames_end", PROP_INT, PROP_NONE);
+       prop= RNA_def_property(srna, "dupli_frames_end", PROP_INT, PROP_NONE|PROP_UNIT_TIME);
        RNA_def_property_int_sdna(prop, NULL, "dupend");
        RNA_def_property_range(prop, 1, 32767);
        RNA_def_property_ui_text(prop, "Dupli Frames End", "End frame for DupliFrames.");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_update");
 
-       prop= RNA_def_property(srna, "dupli_frames_on", PROP_INT, PROP_NONE);
+       prop= RNA_def_property(srna, "dupli_frames_on", PROP_INT, PROP_NONE|PROP_UNIT_TIME);
        RNA_def_property_int_sdna(prop, NULL, "dupon");
        RNA_def_property_range(prop, 1, 1500);
        RNA_def_property_ui_text(prop, "Dupli Frames On", "Number of frames to use between DupOff frames.");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_update");
 
-       prop= RNA_def_property(srna, "dupli_frames_off", PROP_INT, PROP_NONE);
+       prop= RNA_def_property(srna, "dupli_frames_off", PROP_INT, PROP_NONE|PROP_UNIT_TIME);
        RNA_def_property_int_sdna(prop, NULL, "dupoff");
        RNA_def_property_range(prop, 0, 1500);
        RNA_def_property_ui_text(prop, "Dupli Frames Off", "Recurring frames to exclude from the Dupliframes.");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Object_update");
 
+       prop= RNA_def_property(srna, "dupli_list", PROP_COLLECTION, PROP_NONE);
+       RNA_def_property_collection_sdna(prop, NULL, "duplilist", NULL);
+       RNA_def_property_struct_type(prop, "DupliObject");
+       RNA_def_property_ui_text(prop, "Dupli list", "Object duplis.");
+
+
        /* time offset */
 
-       prop= RNA_def_property(srna, "time_offset", PROP_FLOAT, PROP_NONE);
+       prop= RNA_def_property(srna, "time_offset", PROP_FLOAT, PROP_NONE|PROP_UNIT_TIME);
        RNA_def_property_float_sdna(prop, NULL, "sf");
-       RNA_def_property_range(prop, -MAXFRAMEF, MAXFRAMEF);
+       RNA_def_property_range(prop, MINAFRAMEF, MAXFRAMEF);
        RNA_def_property_ui_text(prop, "Time Offset", "Animation offset in frames for IPO's and dupligroup instances.");
        RNA_def_property_update(prop, NC_OBJECT|ND_TRANSFORM, "rna_Object_update");
 
@@ -1073,12 +1456,6 @@ static void rna_def_object(BlenderRNA *brna)
        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_update");
 
-       /* script link */
-
-       prop= RNA_def_property(srna, "script_link", PROP_POINTER, PROP_NEVER_NULL);
-       RNA_def_property_pointer_sdna(prop, NULL, "scriptlink");
-       RNA_def_property_ui_text(prop, "Script Link", "Scripts linked to this object.");
-
        /* drawing */
 
        prop= RNA_def_property(srna, "max_draw_type", PROP_ENUM, PROP_NONE);
@@ -1128,6 +1505,13 @@ static void rna_def_object(BlenderRNA *brna)
        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);
        
+       /* Grease Pencil */
+       prop= RNA_def_property(srna, "grease_pencil", PROP_POINTER, PROP_NONE);
+       RNA_def_property_pointer_sdna(prop, NULL, "gpd");
+       RNA_def_property_flag(prop, PROP_EDITABLE);
+       RNA_def_property_struct_type(prop, "GreasePencil");
+       RNA_def_property_ui_text(prop, "Grease Pencil Data", "Grease Pencil datablock");
+       
        /* pose */
        prop= RNA_def_property(srna, "pose_library", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "poselib");
@@ -1139,32 +1523,66 @@ static void rna_def_object(BlenderRNA *brna)
        RNA_def_property_struct_type(prop, "Pose");
        RNA_def_property_ui_text(prop, "Pose", "Current pose for armatures.");
 
-       prop= RNA_def_property(srna, "pose_mode", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", OB_POSEMODE);
-       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-       RNA_def_property_ui_text(prop, "Pose Mode", "Object with armature data is in pose mode.");
-
        /* shape keys */
 
        prop= RNA_def_property(srna, "shape_key_lock", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "shapeflag", OB_SHAPE_LOCK);
-       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+       RNA_def_property_boolean_funcs(prop, NULL, "rna_Object_shape_key_lock_set");
        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_update_data");
 
-       prop= RNA_def_property(srna, "active_shape_key", PROP_INT, PROP_NONE);
+       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_ui_text(prop, "Active Shape Key", "Current shape key.");
+
+       prop= RNA_def_property(srna, "active_shape_key_index", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "shapenr");
-       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
-       RNA_def_property_ui_text(prop, "Active Shape Key", "Current shape key index.");
+       RNA_def_property_int_funcs(prop, "rna_Object_active_shape_key_index_get", "rna_Object_active_shape_key_index_set", "rna_Object_active_shape_key_index_range");
+       RNA_def_property_ui_text(prop, "Active Shape Key Index", "Current shape key index.");
+       RNA_def_property_update(prop, 0, "rna_Object_update_data");
 
        RNA_api_object(srna);
 }
 
+static void rna_def_dupli_object(BlenderRNA *brna)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+
+       srna= RNA_def_struct(brna, "DupliObject", NULL);
+       RNA_def_struct_sdna(srna, "DupliObject");
+       RNA_def_struct_ui_text(srna, "Dupli Object", "Dupli Object data."); 
+       /* RNA_def_struct_ui_icon(srna, ICON_OBJECT_DATA); */
+
+       prop= RNA_def_property(srna, "object", PROP_POINTER, PROP_NONE);
+       /* RNA_def_property_struct_type(prop, "Object"); */
+       RNA_def_property_pointer_sdna(prop, NULL, "ob");
+       /* RNA_def_property_pointer_funcs(prop, "rna_DupliObject_object_get", NULL, NULL); */
+       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+       RNA_def_property_ui_text(prop, "Object", "Object this DupliObject represents.");
+
+       prop= RNA_def_property(srna, "ob_matrix", 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", "Object transformation matrix.");
+
+       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_ui_text(prop, "DupliObject Matrix", "DupliObject transformation matrix.");
+
+       /* TODO: DupliObject has more properties that can be wrapped */
+}
+
 void RNA_def_object(BlenderRNA *brna)
 {
        rna_def_object(brna);
        rna_def_object_game_settings(brna);
        rna_def_vertex_group(brna);
        rna_def_material_slot(brna);
+       rna_def_dupli_object(brna);
 }
 
 #endif