Merge with -r 22620:23107.
[blender.git] / source / blender / makesrna / intern / rna_object.c
index 32a97d2..8525cf6 100644 (file)
 #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", ""},
+       {PARKEY, "KEY", 0, "Key", ""},
        {PARSKEL, "ARMATURE", 0, "Armature", ""},
        {PARSKEL, "LATTICE", 0, "Lattice", ""}, // PARSKEL reuse will give issues
        {PARVERT1, "VERTEX", 0, "Vertex", ""},
@@ -52,11 +64,28 @@ static EnumPropertyItem parent_type_items[] = {
        {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"
@@ -71,17 +100,24 @@ static EnumPropertyItem parent_type_items[] = {
 
 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);
+}
+
+void rna_Object_matrix_update(bContext *C, PointerRNA *ptr)
+{
+       ED_object_apply_obmat(ptr->id.data);
+       rna_Object_update(C, ptr);
 }
 
 void rna_Object_update_data(bContext *C, PointerRNA *ptr)
 {
-       DAG_object_flush_update(CTX_data_scene(C), ptr->id.data, OB_RECALC_DATA);
+       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));
 }
 
@@ -199,9 +235,9 @@ static EnumPropertyItem *rna_Object_parent_type_itemf(bContext *C, PointerRNA *p
                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, PARSKEL);
+                       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, PARSKEL);
+                       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) {
@@ -234,7 +270,7 @@ 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)
@@ -377,7 +413,17 @@ static void rna_Object_active_material_index_range(PointerRNA *ptr, int *min, in
 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_material_set(PointerRNA *ptr, PointerRNA value)
+{
+       Object *ob= (Object*)ptr->id.data;
+
+       assign_material(ob, value.data, ob->actcol);
 }
 
 static void rna_Object_active_particle_system_index_range(PointerRNA *ptr, int *min, int *max)
@@ -400,15 +446,6 @@ static void rna_Object_active_particle_system_index_set(struct PointerRNA *ptr,
        psys_set_current_num(ob, value);
 }
 
-#if 0
-static void rna_Object_active_material_set(PointerRNA *ptr, PointerRNA value)
-{
-       Object *ob= (Object*)ptr->id.data;
-
-       assign_material(ob, value.data, ob->actcol);
-}
-#endif
-
 static PointerRNA rna_MaterialSlot_material_get(PointerRNA *ptr)
 {
        Object *ob= (Object*)ptr->id.data;
@@ -478,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;
@@ -528,6 +645,16 @@ 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;
@@ -666,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[] = {
@@ -678,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}};
 
@@ -725,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);
@@ -740,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);
@@ -803,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");
@@ -820,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.");
@@ -838,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.");
@@ -933,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);
@@ -944,7 +1075,7 @@ 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");
@@ -952,7 +1083,13 @@ static void rna_def_object(BlenderRNA *brna)
        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.");
@@ -1027,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, "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.");
@@ -1086,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);
@@ -1116,13 +1257,13 @@ static void rna_def_object(BlenderRNA *brna)
        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_OBJECT|ND_GEOM_DATA, "rna_Object_update_data");
+       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, NC_OBJECT|ND_GEOM_DATA, "rna_Object_update_data");
+       RNA_def_property_update(prop, 0, "rna_Object_update_data");
 
        /* empty */
 
@@ -1132,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.");
@@ -1258,33 +1399,39 @@ 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, MINAFRAMEF, MAXFRAMEF);
        RNA_def_property_ui_text(prop, "Time Offset", "Animation offset in frames for IPO's and dupligroup instances.");
@@ -1309,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);
@@ -1364,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");
@@ -1375,11 +1523,6 @@ 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);
@@ -1387,7 +1530,7 @@ static void rna_def_object(BlenderRNA *brna)
        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, NC_OBJECT|ND_GEOM_DATA, "rna_Object_update_data");
+       RNA_def_property_update(prop, 0, "rna_Object_update_data");
 
        prop= RNA_def_property(srna, "active_shape_key", PROP_POINTER, PROP_NONE);
        RNA_def_property_struct_type(prop, "ShapeKey");
@@ -1398,17 +1541,48 @@ static void rna_def_object(BlenderRNA *brna)
        RNA_def_property_int_sdna(prop, NULL, "shapenr");
        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, NC_OBJECT|ND_GEOM_DATA, "rna_Object_update_data");
+       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