synched with trunk at revision 36569
[blender.git] / source / blender / makesrna / intern / rna_modifier.c
index a01f448..b957f12 100644 (file)
@@ -1,4 +1,4 @@
-/**
+/*
  * $Id$
  *
  * ***** BEGIN GPL LICENSE BLOCK *****
  * ***** END GPL LICENSE BLOCK *****
  */
 
+/** \file blender/makesrna/intern/rna_modifier.c
+ *  \ingroup RNA
+ */
+
+
 #include <float.h>
 #include <limits.h>
 #include <stdlib.h>
 
 #include "RNA_define.h"
-#include "RNA_types.h"
 
 #include "rna_internal.h"
 
 #include "DNA_object_force.h"
 #include "DNA_scene_types.h"
 
+#include "MEM_guardedalloc.h"
+
 #include "BLI_math.h"
 
 #include "BKE_animsys.h"
 #include "BKE_bmesh.h" /* For BevelModifierData */
+#include "BKE_multires.h"
 #include "BKE_smoke.h" /* For smokeModifier_free & smokeModifier_createType */
 
 #include "WM_api.h"
@@ -56,8 +63,8 @@ EnumPropertyItem modifier_type_items[] ={
        {eModifierType_EdgeSplit, "EDGE_SPLIT", ICON_MOD_EDGESPLIT, "Edge Split", ""},
        {eModifierType_Mask, "MASK", ICON_MOD_MASK, "Mask", ""},
        {eModifierType_Mirror, "MIRROR", ICON_MOD_MIRROR, "Mirror", ""},
-       {eModifierType_Screw, "SCREW", ICON_MOD_SCREW, "Screw", ""},
        {eModifierType_Multires, "MULTIRES", ICON_MOD_MULTIRES, "Multiresolution", ""},
+       {eModifierType_Screw, "SCREW", ICON_MOD_SCREW, "Screw", ""},
        {eModifierType_Solidify, "SOLIDIFY", ICON_MOD_SOLIDIFY, "Solidify", ""},
        {eModifierType_Subsurf, "SUBSURF", ICON_MOD_SUBSURF, "Subdivision Surface", ""},
        {eModifierType_UVProject, "UV_PROJECT", ICON_MOD_UVPROJECT, "UV Project", ""},
@@ -72,6 +79,7 @@ EnumPropertyItem modifier_type_items[] ={
        {eModifierType_Shrinkwrap, "SHRINKWRAP", ICON_MOD_SHRINKWRAP, "Shrinkwrap", ""},
        {eModifierType_SimpleDeform, "SIMPLE_DEFORM", ICON_MOD_SIMPLEDEFORM, "Simple Deform", ""},
        {eModifierType_Smooth, "SMOOTH", ICON_MOD_SMOOTH, "Smooth", ""},
+       {eModifierType_Warp, "WARP", ICON_MOD_SUBSURF, "Warp", ""},
        {eModifierType_Wave, "WAVE", ICON_MOD_WAVE, "Wave", ""},
        {0, "", 0, "Simulate", ""},
        {eModifierType_Cloth, "CLOTH", ICON_MOD_CLOTH, "Cloth", ""},
@@ -83,14 +91,19 @@ EnumPropertyItem modifier_type_items[] ={
        {eModifierType_Smoke, "SMOKE", ICON_MOD_SMOKE, "Smoke", ""},
        {eModifierType_Softbody, "SOFT_BODY", ICON_MOD_SOFT, "Soft Body", ""},
        {eModifierType_Surface, "SURFACE", ICON_MOD_PHYSICS, "Surface", ""},
+       {eModifierType_NavMesh, "NAVMESH", ICON_MOD_PHYSICS, "Navigation mesh", ""},
        {0, NULL, 0, NULL, NULL}};
 
 #ifdef RNA_RUNTIME
 
+#include "DNA_particle_types.h"
+#include "DNA_smoke_types.h"
+
 #include "BKE_context.h"
 #include "BKE_depsgraph.h"
 #include "BKE_library.h"
 #include "BKE_modifier.h"
+#include "BKE_particle.h"
 
 static void rna_UVProject_projectors_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
 {
@@ -169,6 +182,10 @@ static StructRNA* rna_Modifier_refine(struct PointerRNA *ptr)
                        return &RNA_SolidifyModifier;
                case eModifierType_Screw:
                        return &RNA_ScrewModifier;
+               case eModifierType_Warp:
+                       return &RNA_WarpModifier;
+               case eModifierType_NavMesh:
+                       return &RNA_NavMeshModifier;
                default:
                        return &RNA_Modifier;
        }
@@ -177,10 +194,10 @@ static StructRNA* rna_Modifier_refine(struct PointerRNA *ptr)
 void rna_Modifier_name_set(PointerRNA *ptr, const char *value)
 {
        ModifierData *md= ptr->data;
-       char oldname[32];
+       char oldname[sizeof(md->name)];
        
        /* make a copy of the old name first */
-       BLI_strncpy(oldname, md->name, sizeof(oldname));
+       BLI_strncpy(oldname, md->name, sizeof(md->name));
        
        /* copy the new name into the name slot */
        BLI_strncpy(md->name, value, sizeof(md->name));
@@ -202,20 +219,23 @@ static char *rna_Modifier_path(PointerRNA *ptr)
 
 static void rna_Modifier_update(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_MODIFIER, ptr->id.data);
 }
 
 static void rna_Modifier_dependency_update(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
        rna_Modifier_update(bmain, scene, ptr);
-    DAG_scene_sort(scene);
+       DAG_scene_sort(bmain, scene);
 }
 
 static void rna_Smoke_set_type(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
        SmokeModifierData *smd= (SmokeModifierData *)ptr->data;
        Object *ob= (Object*)ptr->id.data;
+       ParticleSystemModifierData *psmd = NULL;
+       ParticleSystem *psys = NULL;
+       ParticleSettings *part = NULL;
 
        // nothing changed
        if((smd->type & MOD_SMOKE_TYPE_DOMAIN) && smd->domain)
@@ -229,6 +249,28 @@ static void rna_Smoke_set_type(Main *bmain, Scene *scene, PointerRNA *ptr)
                        ob->dt = OB_WIRE;
                        break;
                case MOD_SMOKE_TYPE_FLOW:
+                       for(psys=ob->particlesystem.first; psys; psys=psys->next)
+                               if(psys->part->type == PART_EMITTER)
+                                       break;
+                       if(ob->type == OB_MESH && !psys) {
+                               /* add particle system */
+                               psmd = (ParticleSystemModifierData *)object_add_particle_system(scene, ob, NULL);
+                               if(psmd)
+                               {
+                                       psys = psmd->psys;
+                                       part = psys->part;
+                                       part->lifetime = 1.0f;
+                                       part->sta = 1.0f;
+                                       part->end = 250.0f;
+                                       part->ren_as = PART_DRAW_NOT;
+                                       part->draw_as = PART_DRAW_DOT;
+                                       sprintf(psys->name, "SmokeParticles");
+                                       psys->recalc |= (PSYS_RECALC_RESET|PSYS_RECALC_PHYS);
+                                       DAG_id_tag_update(ptr->id.data, OB_RECALC_DATA);
+                               }
+                       }
+                       if(smd->flow)
+                               smd->flow->psys = psys;
                case MOD_SMOKE_TYPE_COLL:
                case 0:
                default:
@@ -336,10 +378,10 @@ static void rna_SolidifyModifier_vgroup_set(PointerRNA *ptr, const char *value)
        rna_object_vgroup_name_set(ptr, value, smd->defgrp_name, sizeof(smd->defgrp_name));
 }
 
-static void rna_DisplaceModifier_uvlayer_set(PointerRNA *ptr, const char *value)
+static void rna_MappingInfo_uvlayer_set(PointerRNA *ptr, const char *value)
 {
-       DisplaceModifierData *smd= (DisplaceModifierData*)ptr->data;
-       rna_object_uvlayer_name_set(ptr, value, smd->uvlayer_name, sizeof(smd->uvlayer_name));
+       MappingInfoModifierData *mmd= (MappingInfoModifierData *)ptr->data;
+       rna_object_uvlayer_name_set(ptr, value, mmd->uvlayer_name, sizeof(mmd->uvlayer_name));
 }
 
 static void rna_UVProjectModifier_uvlayer_set(PointerRNA *ptr, const char *value)
@@ -348,6 +390,12 @@ static void rna_UVProjectModifier_uvlayer_set(PointerRNA *ptr, const char *value
        rna_object_uvlayer_name_set(ptr, value, umd->uvlayer_name, sizeof(umd->uvlayer_name));
 }
 
+static void RNA_WarpModifier_vgroup_set(PointerRNA *ptr, const char *value)
+{
+       WarpModifierData *tmd= (WarpModifierData*)ptr->data;
+       rna_object_vgroup_name_set(ptr, value, tmd->defgrp_name, sizeof(tmd->defgrp_name));
+}
+
 static void rna_WaveModifier_uvlayer_set(PointerRNA *ptr, const char *value)
 {
        WaveModifierData *wmd= (WaveModifierData*)ptr->data;
@@ -370,7 +418,7 @@ static int rna_MultiresModifier_external_get(PointerRNA *ptr)
        return CustomData_external_test(&me->fdata, CD_MDISPS);
 }
 
-static void rna_MultiresModifier_filename_get(PointerRNA *ptr, char *value)
+static void rna_MultiresModifier_filepath_get(PointerRNA *ptr, char *value)
 {
        Object *ob= (Object*)ptr->id.data;
        CustomDataExternal *external= ((Mesh*)ob->data)->fdata.external;
@@ -378,16 +426,18 @@ static void rna_MultiresModifier_filename_get(PointerRNA *ptr, char *value)
        BLI_strncpy(value, (external)? external->filename: "", sizeof(external->filename));
 }
 
-static void rna_MultiresModifier_filename_set(PointerRNA *ptr, const char *value)
+static void rna_MultiresModifier_filepath_set(PointerRNA *ptr, const char *value)
 {
        Object *ob= (Object*)ptr->id.data;
        CustomDataExternal *external= ((Mesh*)ob->data)->fdata.external;
 
-       if(external)
+       if(external && strcmp(external->filename, value)) {
                BLI_strncpy(external->filename, value, sizeof(external->filename));
+               multires_force_external_reload(ob);
+       }
 }
 
-static int rna_MultiresModifier_filename_length(PointerRNA *ptr)
+static int rna_MultiresModifier_filepath_length(PointerRNA *ptr)
 {
        Object *ob= (Object*)ptr->id.data;
        CustomDataExternal *external= ((Mesh*)ob->data)->fdata.external;
@@ -399,9 +449,12 @@ static void modifier_object_set(Object *self, Object **ob_p, int type, PointerRN
 {
        Object *ob= value.data;
 
-       if(!self || ob != self)
-               if(!ob || ob->type == type)
+       if(!self || ob != self) {
+               if(!ob || type == OB_EMPTY || ob->type == type) {
+                       id_lib_extern((ID *)ob);
                        *ob_p= ob;
+               }
+       }
 }
 
 static void rna_LatticeModifier_object_set(PointerRNA *ptr, PointerRNA value)
@@ -421,7 +474,7 @@ static void rna_CurveModifier_object_set(PointerRNA *ptr, PointerRNA value)
 
 static void rna_CastModifier_object_set(PointerRNA *ptr, PointerRNA value)
 {
-       modifier_object_set(ptr->id.data, &((CastModifierData*)ptr->data)->object, OB_MESH, value);
+       modifier_object_set(ptr->id.data, &((CastModifierData*)ptr->data)->object, OB_EMPTY, value);
 }
 
 static void rna_ArmatureModifier_object_set(PointerRNA *ptr, PointerRNA value)
@@ -444,6 +497,19 @@ static void rna_ShrinkwrapModifier_target_set(PointerRNA *ptr, PointerRNA value)
        modifier_object_set(ptr->id.data, &((ShrinkwrapModifierData*)ptr->data)->target, OB_MESH, value);
 }
 
+static int rna_ShrinkwrapModifier_face_cull_get(PointerRNA *ptr)
+{
+       ShrinkwrapModifierData *swm= (ShrinkwrapModifierData*)ptr->data;
+       return swm->shrinkOpts & (MOD_SHRINKWRAP_CULL_TARGET_FRONTFACE|MOD_SHRINKWRAP_CULL_TARGET_BACKFACE);
+}
+
+static void rna_ShrinkwrapModifier_face_cull_set(struct PointerRNA *ptr, int value)
+{
+       ShrinkwrapModifierData *swm= (ShrinkwrapModifierData*)ptr->data;
+       
+       swm->shrinkOpts= (swm->shrinkOpts & ~(MOD_SHRINKWRAP_CULL_TARGET_FRONTFACE|MOD_SHRINKWRAP_CULL_TARGET_BACKFACE)) | value;
+}
+
 static void rna_MeshDeformModifier_object_set(PointerRNA *ptr, PointerRNA value)
 {
        modifier_object_set(ptr->id.data, &((MeshDeformModifierData*)ptr->data)->object, OB_MESH, value);
@@ -466,7 +532,7 @@ static void rna_ArrayModifier_curve_set(PointerRNA *ptr, PointerRNA value)
 
 static int rna_MeshDeformModifier_is_bound_get(PointerRNA *ptr)
 {
-       return (((MeshDeformModifierData*)ptr->data)->bindcos != NULL);
+       return (((MeshDeformModifierData*)ptr->data)->bindcagecos != NULL);
 }
 
 static PointerRNA rna_SoftBodyModifier_settings_get(PointerRNA *ptr)
@@ -497,7 +563,7 @@ static void rna_UVProjector_object_set(PointerRNA *ptr, PointerRNA value)
 {
        Object **ob= (Object**)ptr->data;
 
-    if(*ob)
+       if(*ob)
                id_us_min((ID*)*ob);
        if(value.data)
                id_us_plus((ID*)value.data);
@@ -554,17 +620,117 @@ static void rna_def_modifier_subsurf(BlenderRNA *brna)
        RNA_def_property_ui_range(prop, 0, 6, 1, 0);
        RNA_def_property_ui_text(prop, "Render Levels", "Number of subdivisions to perform when rendering");
 
-       prop= RNA_def_property(srna, "optimal_display", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_only_control_edges", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flags", eSubsurfModifierFlag_ControlEdges);
        RNA_def_property_ui_text(prop, "Optimal Display", "Skip drawing/rendering of interior subdivided edges");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
        
-       prop= RNA_def_property(srna, "subsurf_uv", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_subsurf_uv", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flags", eSubsurfModifierFlag_SubsurfUv);
        RNA_def_property_ui_text(prop, "Subdivide UVs", "Use subsurf to subdivide UVs");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 }
 
+static void rna_def_modifier_generic_map_info(StructRNA *srna)
+{
+       static EnumPropertyItem prop_texture_coordinates_items[] = {
+               {MOD_DISP_MAP_LOCAL, "LOCAL", 0, "Map", ""},
+               {MOD_DISP_MAP_GLOBAL, "GLOBAL", 0, "Global", ""},
+               {MOD_DISP_MAP_OBJECT, "OBJECT", 0, "Object", ""},
+               {MOD_DISP_MAP_UV, "UV", 0, "UV", ""},
+               {0, NULL, 0, NULL, NULL}};
+
+       PropertyRNA *prop;
+
+       prop= RNA_def_property(srna, "texture", PROP_POINTER, PROP_NONE);
+       RNA_def_property_ui_text(prop, "Texture", "");
+       RNA_def_property_flag(prop, PROP_EDITABLE);
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop= RNA_def_property(srna, "texture_coords", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "texmapping");
+       RNA_def_property_enum_items(prop, prop_texture_coordinates_items);
+       RNA_def_property_ui_text(prop, "Texture Coordinates", "");
+       RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
+
+       prop= RNA_def_property(srna, "uv_layer", PROP_STRING, PROP_NONE);
+       RNA_def_property_string_sdna(prop, NULL, "uvlayer_name");
+       RNA_def_property_ui_text(prop, "UV Layer", "UV layer name");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_MappingInfo_uvlayer_set");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop= RNA_def_property(srna, "texture_coordinate_object", PROP_POINTER, PROP_NONE);
+       RNA_def_property_pointer_sdna(prop, NULL, "map_object");
+       RNA_def_property_ui_text(prop, "Texture Coordinate Object", "");
+       RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
+       RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
+}
+
+static void rna_def_modifier_warp(BlenderRNA *brna)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+
+       static EnumPropertyItem prop_falloff_items[] = {
+               {eWarp_Falloff_None,    "NONE", 0, "No Falloff", ""},
+               {eWarp_Falloff_Curve,   "CURVE", 0, "Curve", ""},
+               {eWarp_Falloff_Smooth,  "SMOOTH", ICON_SMOOTHCURVE, "Smooth", ""},
+               {eWarp_Falloff_Sphere,  "SPHERE", ICON_SPHERECURVE, "Sphere", ""},
+               {eWarp_Falloff_Root,    "ROOT", ICON_ROOTCURVE, "Root", ""},
+               {eWarp_Falloff_Sharp,   "SHARP", ICON_SHARPCURVE, "Sharp", ""},
+               {eWarp_Falloff_Linear,  "LINEAR", ICON_LINCURVE, "Linear", ""},
+               {eWarp_Falloff_Const,   "CONSTANT", ICON_NOCURVE, "Constant", ""},
+               {0, NULL, 0, NULL, NULL}};
+
+       srna= RNA_def_struct(brna, "WarpModifier", "Modifier");
+       RNA_def_struct_ui_text(srna, "Warp Modifier", "Warp modifier");
+       RNA_def_struct_sdna(srna, "WarpModifierData");
+       //RNA_def_struct_ui_icon(srna, ICON_MOD_SUBSURF);
+
+       prop= RNA_def_property(srna, "object_from", PROP_POINTER, PROP_NONE);
+       RNA_def_property_ui_text(prop, "From", "Object to transform from");
+       RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
+       RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
+
+       prop= RNA_def_property(srna, "object_to", PROP_POINTER, PROP_NONE);
+       RNA_def_property_ui_text(prop, "To", "Object to transform to");
+       RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
+       RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
+
+       prop= RNA_def_property(srna, "strength", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);
+       RNA_def_property_ui_range(prop, -100, 100, 10, 2);
+       RNA_def_property_ui_text(prop, "Strength", "");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop= RNA_def_property(srna, "falloff_type", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_items(prop, prop_falloff_items);
+       RNA_def_property_ui_text(prop, "Falloff Type", "");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop= RNA_def_property(srna, "falloff_radius", PROP_FLOAT, PROP_UNSIGNED);
+       RNA_def_property_ui_text(prop, "Radius", "Radius to apply");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop= RNA_def_property(srna, "falloff_curve", PROP_POINTER, PROP_NONE);
+       RNA_def_property_pointer_sdna(prop, NULL, "curfalloff");
+       RNA_def_property_ui_text(prop, "Falloff Curve", "Custom Lamp Falloff Curve");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop= RNA_def_property(srna, "use_volume_preserve", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_WARP_VOLUME_PRESERVE);
+       RNA_def_property_ui_text(prop, "Preserve Volume", "Preserve volume when rotations are used");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop= RNA_def_property(srna, "vertex_group", PROP_STRING, PROP_NONE);
+       RNA_def_property_string_sdna(prop, NULL, "defgrp_name");
+       RNA_def_property_ui_text(prop, "Vertex Group", "Vertex group name for modulating the deform");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "RNA_WarpModifier_vgroup_set");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       rna_def_modifier_generic_map_info(srna);
+}
+
 static void rna_def_modifier_multires(BlenderRNA *brna)
 {
        StructRNA *srna;
@@ -599,17 +765,17 @@ static void rna_def_modifier_multires(BlenderRNA *brna)
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Total Levels", "Number of subdivisions for which displacements are stored");
 
-       prop= RNA_def_property(srna, "external", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "is_external", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
        RNA_def_property_boolean_funcs(prop, "rna_MultiresModifier_external_get", NULL);
        RNA_def_property_ui_text(prop, "External", "Store multires displacements outside the .blend file, to save memory");
 
-       prop= RNA_def_property(srna, "filename", PROP_STRING, PROP_FILEPATH);
-       RNA_def_property_string_funcs(prop, "rna_MultiresModifier_filename_get", "rna_MultiresModifier_filename_length", "rna_MultiresModifier_filename_set");
-       RNA_def_property_ui_text(prop, "Filename", "Path to external displacements file");
+       prop= RNA_def_property(srna, "filepath", PROP_STRING, PROP_FILEPATH);
+       RNA_def_property_string_funcs(prop, "rna_MultiresModifier_filepath_get", "rna_MultiresModifier_filepath_length", "rna_MultiresModifier_filepath_set");
+       RNA_def_property_ui_text(prop, "File Path", "Path to external displacements file");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "optimal_display", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_only_control_edges", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flags", eMultiresModifierFlag_ControlEdges);
        RNA_def_property_ui_text(prop, "Optimal Display", "Skip drawing/rendering of interior subdivided edges");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -627,13 +793,13 @@ static void rna_def_modifier_lattice(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "object", PROP_POINTER, PROP_NONE);
        RNA_def_property_ui_text(prop, "Object", "Lattice object to deform with");
-       RNA_def_property_pointer_funcs(prop, NULL, "rna_LatticeModifier_object_set", NULL);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_LatticeModifier_object_set", NULL, "rna_Lattice_object_poll");
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 
        prop= RNA_def_property(srna, "vertex_group", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "name");
-       RNA_def_property_ui_text(prop, "Vertex Group", "Vertex group name");
+       RNA_def_property_ui_text(prop, "Vertex Group", "Name of Vertex Group which determines influence of modifier per point");
        RNA_def_property_string_funcs(prop, NULL, NULL, "rna_LatticeModifier_vgroup_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 }
@@ -659,13 +825,13 @@ static void rna_def_modifier_curve(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "object", PROP_POINTER, PROP_NONE);
        RNA_def_property_ui_text(prop, "Object", "Curve object to deform with");
-       RNA_def_property_pointer_funcs(prop, NULL, "rna_CurveModifier_object_set", NULL);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_CurveModifier_object_set", NULL, "rna_Curve_object_poll");
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 
        prop= RNA_def_property(srna, "vertex_group", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "name");
-       RNA_def_property_ui_text(prop, "Vertex Group", "Vertex group name");
+       RNA_def_property_ui_text(prop, "Vertex Group", "Name of Vertex Group which determines influence of modifier per point");
        RNA_def_property_string_funcs(prop, NULL, NULL, "rna_CurveModifier_vgroup_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
@@ -686,17 +852,20 @@ static void rna_def_modifier_build(BlenderRNA *brna)
        RNA_def_struct_sdna(srna, "BuildModifierData");
        RNA_def_struct_ui_icon(srna, ICON_MOD_BUILD);
 
-       prop= RNA_def_property(srna, "start", PROP_FLOAT, PROP_TIME);
+       prop= RNA_def_property(srna, "frame_start", PROP_FLOAT, PROP_TIME);
+       RNA_def_property_float_sdna(prop, NULL, "start");
        RNA_def_property_range(prop, MINAFRAMEF, MAXFRAMEF);
        RNA_def_property_ui_text(prop, "Start", "Specify the start frame of the effect");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "length", PROP_FLOAT, PROP_TIME);
+       prop= RNA_def_property(srna, "frame_duration", PROP_FLOAT, PROP_TIME);
+       RNA_def_property_float_sdna(prop, NULL, "length");
        RNA_def_property_range(prop, 1, MAXFRAMEF);
        RNA_def_property_ui_text(prop, "Length", "Specify the total time the build effect requires");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "randomize", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_random_order", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "randomize", 1);
        RNA_def_property_ui_text(prop, "Randomize", "Randomize the faces or edges during build");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
@@ -716,42 +885,47 @@ static void rna_def_modifier_mirror(BlenderRNA *brna)
        RNA_def_struct_sdna(srna, "MirrorModifierData");
        RNA_def_struct_ui_icon(srna, ICON_MOD_MIRROR);
 
-       prop= RNA_def_property(srna, "x", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_x", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_MIR_AXIS_X);
        RNA_def_property_ui_text(prop, "X", "Enable X axis mirror");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "y", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_y", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_MIR_AXIS_Y);
        RNA_def_property_ui_text(prop, "Y", "Enable Y axis mirror");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "z", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_z", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_MIR_AXIS_Z);
        RNA_def_property_ui_text(prop, "Z", "Enable Z axis mirror");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "clip", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_clip", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_MIR_CLIPPING);
        RNA_def_property_ui_text(prop, "Clip", "Prevents vertices from going through the mirror during transform");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "mirror_vertex_groups", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_mirror_vertex_groups", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_MIR_VGROUP);
        RNA_def_property_ui_text(prop, "Mirror Vertex Groups", "Mirror vertex groups (e.g. .R->.L)");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
+       
+       prop= RNA_def_property(srna, "use_mirror_merge", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_negative_sdna(prop, NULL, "flag", MOD_MIR_NO_MERGE);
+       RNA_def_property_ui_text(prop, "Merge Vertices", "Merge vertices within the merge threshold");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "mirror_u", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_mirror_u", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_MIR_MIRROR_U);
        RNA_def_property_ui_text(prop, "Mirror U", "Mirror the U texture coordinate around the 0.5 point");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "mirror_v", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_mirror_v", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_MIR_MIRROR_V);
        RNA_def_property_ui_text(prop, "Mirror V", "Mirror the V texture coordinate around the 0.5 point");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "merge_limit", PROP_FLOAT, PROP_DISTANCE);
+       prop= RNA_def_property(srna, "merge_threshold", PROP_FLOAT, PROP_DISTANCE);
        RNA_def_property_float_sdna(prop, NULL, "tolerance");
        RNA_def_property_range(prop, 0, FLT_MAX);
        RNA_def_property_ui_range(prop, 0, 1, 0.01, 6);
@@ -778,6 +952,7 @@ static void rna_def_modifier_decimate(BlenderRNA *brna)
        prop= RNA_def_property(srna, "ratio", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "percent");
        RNA_def_property_range(prop, 0, 1);
+       RNA_def_property_ui_range(prop, 0, 1, 1, 2);
        RNA_def_property_ui_text(prop, "Ratio", "Defines the ratio of triangles to reduce to");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
@@ -804,37 +979,37 @@ static void rna_def_modifier_wave(BlenderRNA *brna)
        RNA_def_struct_sdna(srna, "WaveModifierData");
        RNA_def_struct_ui_icon(srna, ICON_MOD_WAVE);
 
-       prop= RNA_def_property(srna, "x", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_x", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_WAVE_X);
        RNA_def_property_ui_text(prop, "X", "X axis motion");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "y", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_y", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_WAVE_Y);
        RNA_def_property_ui_text(prop, "Y", "Y axis motion");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "cyclic", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_cyclic", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_WAVE_CYCL);
        RNA_def_property_ui_text(prop, "Cyclic", "Cyclic wave effect");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "normals", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_normal", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_WAVE_NORM);
-       RNA_def_property_ui_text(prop, "Normals", "Dispace along normals");
+       RNA_def_property_ui_text(prop, "Normals", "Displace along normals");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "x_normal", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_normal_x", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_WAVE_NORM_X);
        RNA_def_property_ui_text(prop, "X Normal", "Enable displacement along the X normal");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "y_normal", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_normal_y", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_WAVE_NORM_Y);
        RNA_def_property_ui_text(prop, "Y Normal", "Enable displacement along the Y normal");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "z_normal", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_normal_z", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_WAVE_NORM_Z);
        RNA_def_property_ui_text(prop, "Z Normal", "Enable displacement along the Z normal");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -846,6 +1021,7 @@ static void rna_def_modifier_wave(BlenderRNA *brna)
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop= RNA_def_property(srna, "lifetime", PROP_FLOAT, PROP_TIME);
+       RNA_def_property_float_sdna(prop, NULL, "lifetime");
        RNA_def_property_range(prop, MINAFRAMEF, MAXFRAMEF);
        RNA_def_property_ui_text(prop, "Lifetime",  "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -894,7 +1070,7 @@ static void rna_def_modifier_wave(BlenderRNA *brna)
        RNA_def_property_flag(prop, PROP_EDITABLE);
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "texture_coordinates", PROP_ENUM, PROP_NONE);
+       prop= RNA_def_property(srna, "texture_coords", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "texmapping");
        RNA_def_property_enum_items(prop, prop_texture_coordinates_items);
        RNA_def_property_ui_text(prop, "Texture Coordinates", "Texture coordinates used for modulating input");
@@ -906,7 +1082,7 @@ static void rna_def_modifier_wave(BlenderRNA *brna)
        RNA_def_property_string_funcs(prop, NULL, NULL, "rna_WaveModifier_uvlayer_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "texture_coordinates_object", PROP_POINTER, PROP_NONE);
+       prop= RNA_def_property(srna, "texture_coords_object", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "map_object");
        RNA_def_property_ui_text(prop, "Texture Coordinates Object", "");
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
@@ -950,45 +1126,40 @@ static void rna_def_modifier_armature(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "object", PROP_POINTER, PROP_NONE);
        RNA_def_property_ui_text(prop, "Object", "Armature object to deform with");
-       RNA_def_property_pointer_funcs(prop, NULL, "rna_ArmatureModifier_object_set", NULL);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_ArmatureModifier_object_set", NULL, "rna_Armature_object_poll");
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 
-       prop= RNA_def_property(srna, "vertex_group", PROP_STRING, PROP_NONE);
-       RNA_def_property_string_sdna(prop, NULL, "defgrp_name");
-       RNA_def_property_ui_text(prop, "Vertex Group", "Vertex group name");
-       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_ArmatureModifier_vgroup_set");
-       RNA_def_property_update(prop, 0, "rna_Modifier_update");
-
-       prop= RNA_def_property(srna, "invert", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "deformflag", ARM_DEF_INVERT_VGROUP);
-       RNA_def_property_ui_text(prop, "Invert", "Invert vertex group influence");
+       prop= RNA_def_property(srna, "use_bone_envelopes", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "deformflag", ARM_DEF_ENVELOPE);
+       RNA_def_property_ui_text(prop, "Use Bone Envelopes", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop= RNA_def_property(srna, "use_vertex_groups", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "deformflag", ARM_DEF_VGROUP);
        RNA_def_property_ui_text(prop, "Use Vertex Groups", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
-
-       prop= RNA_def_property(srna, "use_bone_envelopes", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "deformflag", ARM_DEF_ENVELOPE);
-       RNA_def_property_ui_text(prop, "Use Bone Envelopes", "");
-       RNA_def_property_update(prop, 0, "rna_Modifier_update");
-
-       prop= RNA_def_property(srna, "quaternion", PROP_BOOLEAN, PROP_NONE);
+       
+       prop= RNA_def_property(srna, "use_deform_preserve_volume", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "deformflag", ARM_DEF_QUATERNION);
-       RNA_def_property_ui_text(prop, "Quaternion", "Deform rotation interpolation with quaternions");
-       RNA_def_property_update(prop, 0, "rna_Modifier_update");
-
-       prop= RNA_def_property(srna, "b_bone_rest", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "deformflag", ARM_DEF_B_BONE_REST);
-       RNA_def_property_ui_text(prop, "B-Bone Rest",  "Make B-Bones deform already in rest position");
+       RNA_def_property_ui_text(prop, "Preserve Volume", "Deform rotation interpolation with quaternions");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "multi_modifier", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_multi_modifier", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "multi", 0);
        RNA_def_property_ui_text(prop, "Multi Modifier",  "Use same input as previous modifier, and mix results using overall vgroup");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
+       
+       prop= RNA_def_property(srna, "vertex_group", PROP_STRING, PROP_NONE);
+       RNA_def_property_string_sdna(prop, NULL, "defgrp_name");
+       RNA_def_property_ui_text(prop, "Vertex Group", "Name of Vertex Group which determines influence of modifier per point");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_ArmatureModifier_vgroup_set");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop= RNA_def_property(srna, "invert_vertex_group", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "deformflag", ARM_DEF_INVERT_VGROUP);
+       RNA_def_property_ui_text(prop, "Invert", "Invert vertex group influence");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
 }
 
 static void rna_def_modifier_hook(BlenderRNA *brna)
@@ -1024,7 +1195,7 @@ static void rna_def_modifier_hook(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "vertex_group", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "name");
-       RNA_def_property_ui_text(prop, "Vertex Group", "Vertex group name");
+       RNA_def_property_ui_text(prop, "Vertex Group", "Name of Vertex Group which determines influence of modifier per point");
        RNA_def_property_string_funcs(prop, NULL, NULL, "rna_HookModifier_vgroup_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 }
@@ -1042,13 +1213,13 @@ static void rna_def_modifier_softbody(BlenderRNA *brna)
        prop= RNA_def_property(srna, "settings", PROP_POINTER, PROP_NONE);
        RNA_def_property_flag(prop, PROP_NEVER_NULL);
        RNA_def_property_struct_type(prop, "SoftBodySettings");
-       RNA_def_property_pointer_funcs(prop, "rna_SoftBodyModifier_settings_get", NULL, NULL);
+       RNA_def_property_pointer_funcs(prop, "rna_SoftBodyModifier_settings_get", NULL, NULL, NULL);
        RNA_def_property_ui_text(prop, "Soft Body Settings", "");
 
        prop= RNA_def_property(srna, "point_cache", PROP_POINTER, PROP_NONE);
        RNA_def_property_flag(prop, PROP_NEVER_NULL);
        RNA_def_property_struct_type(prop, "PointCache");
-       RNA_def_property_pointer_funcs(prop, "rna_SoftBodyModifier_point_cache_get", NULL, NULL);
+       RNA_def_property_pointer_funcs(prop, "rna_SoftBodyModifier_point_cache_get", NULL, NULL, NULL);
        RNA_def_property_ui_text(prop, "Soft Body Point Cache", "");
 }
 
@@ -1069,8 +1240,8 @@ static void rna_def_modifier_boolean(BlenderRNA *brna)
        RNA_def_struct_ui_icon(srna, ICON_MOD_BOOLEAN);
 
        prop= RNA_def_property(srna, "object", PROP_POINTER, PROP_NONE);
-       RNA_def_property_ui_text(prop, "Object", "Mesh object to use for boolean operation");
-       RNA_def_property_pointer_funcs(prop, NULL, "rna_BooleanModifier_object_set", NULL);
+       RNA_def_property_ui_text(prop, "Object", "Mesh object to use for Boolean operation");
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_BooleanModifier_object_set", NULL, "rna_Mesh_object_poll");
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 
@@ -1108,7 +1279,8 @@ static void rna_def_modifier_array(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Count",  "Number of duplicates to make");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "length", PROP_FLOAT, PROP_DISTANCE);
+       prop= RNA_def_property(srna, "fit_length", PROP_FLOAT, PROP_DISTANCE);
+       RNA_def_property_float_sdna(prop, NULL, "length");
        RNA_def_property_range(prop, 0, INT_MAX);
        RNA_def_property_ui_range(prop, 0, 10000, 10, 2);
        RNA_def_property_ui_text(prop, "Length", "Length to fit array within");
@@ -1117,43 +1289,43 @@ static void rna_def_modifier_array(BlenderRNA *brna)
        prop= RNA_def_property(srna, "curve", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "curve_ob");
        RNA_def_property_ui_text(prop, "Curve", "Curve object to fit array length to");
-       RNA_def_property_pointer_funcs(prop, NULL, "rna_ArrayModifier_curve_set", NULL);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_ArrayModifier_curve_set", NULL, "rna_Curve_object_poll");
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 
        /* Offset parameters */
-       prop= RNA_def_property(srna, "constant_offset", PROP_BOOLEAN, PROP_TRANSLATION);
+       prop= RNA_def_property(srna, "use_constant_offset", PROP_BOOLEAN, PROP_TRANSLATION);
        RNA_def_property_boolean_sdna(prop, NULL, "offset_type", MOD_ARR_OFF_CONST);
-       RNA_def_property_ui_text(prop, "Constant Offset", "");
+       RNA_def_property_ui_text(prop, "Constant Offset", "Add a constant offset");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
        
-       prop= RNA_def_property(srna, "constant_offset_displacement", PROP_FLOAT, PROP_TRANSLATION);
+       prop= RNA_def_property(srna, "constant_offset_displace", PROP_FLOAT, PROP_TRANSLATION);
        RNA_def_property_float_sdna(prop, NULL, "offset");
        RNA_def_property_ui_text(prop, "Constant Offset Displacement", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "relative_offset", PROP_BOOLEAN, PROP_TRANSLATION);
+       prop= RNA_def_property(srna, "use_relative_offset", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "offset_type", MOD_ARR_OFF_RELATIVE);
-       RNA_def_property_ui_text(prop, "Relative Offset", "");
+       RNA_def_property_ui_text(prop, "Relative Offset", "Add an offset relative to the object's bounding box");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "relative_offset_displacement", PROP_FLOAT, PROP_TRANSLATION);
+       prop= RNA_def_property(srna, "relative_offset_displace", PROP_FLOAT, PROP_NONE); /* PROP_TRANSLATION causes units to be used which we dont want */
        RNA_def_property_float_sdna(prop, NULL, "scale");
        RNA_def_property_ui_text(prop, "Relative Offset Displacement", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        /* Vertex merging parameters */
-       prop= RNA_def_property(srna, "merge_adjacent_vertices", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_merge_vertices", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flags", MOD_ARR_MERGE);
        RNA_def_property_ui_text(prop, "Merge Vertices", "Merge vertices in adjacent duplicates");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "merge_end_vertices", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_merge_vertices_cap", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flags", MOD_ARR_MERGEFINAL);
        RNA_def_property_ui_text(prop, "Merge Vertices", "Merge vertices in first and last duplicates");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "merge_distance", PROP_FLOAT, PROP_DISTANCE);
+       prop= RNA_def_property(srna, "merge_threshold", PROP_FLOAT, PROP_DISTANCE);
        RNA_def_property_float_sdna(prop, NULL, "merge_dist");
        RNA_def_property_range(prop, 0, FLT_MAX);
        RNA_def_property_ui_range(prop, 0, 1, 1, 4);
@@ -1161,27 +1333,27 @@ static void rna_def_modifier_array(BlenderRNA *brna)
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        /* Offset object */
-       prop= RNA_def_property(srna, "add_offset_object", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_object_offset", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "offset_type", MOD_ARR_OFF_OBJ);
-       RNA_def_property_ui_text(prop, "Add Offset Object", "Add an object transformation to the total offset");
+       RNA_def_property_ui_text(prop, "Object Offset", "Add another object's transformation to the total offset");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop= RNA_def_property(srna, "offset_object", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "offset_ob");
-       RNA_def_property_ui_text(prop, "Offset Object", "");
+       RNA_def_property_ui_text(prop, "Object Offset", "");
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
        
        /* Caps */
        prop= RNA_def_property(srna, "start_cap", PROP_POINTER, PROP_NONE);
        RNA_def_property_ui_text(prop, "Start Cap", "Mesh object to use as a start cap");
-       RNA_def_property_pointer_funcs(prop, NULL, "rna_ArrayModifier_start_cap_set", NULL);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_ArrayModifier_start_cap_set", NULL, "rna_Mesh_object_poll");
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop= RNA_def_property(srna, "end_cap", PROP_POINTER, PROP_NONE);
        RNA_def_property_ui_text(prop, "End Cap", "Mesh object to use as an end cap");
-       RNA_def_property_pointer_funcs(prop, NULL, "rna_ArrayModifier_end_cap_set", NULL);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_ArrayModifier_end_cap_set", NULL, "rna_Mesh_object_poll");
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 }
@@ -1208,7 +1380,7 @@ static void rna_def_modifier_edgesplit(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Use Edge Angle", "Split edges with high angle between faces");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "use_sharp", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_edge_sharp", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flags", MOD_EDGESPLIT_FROMFLAG);
        RNA_def_property_ui_text(prop, "Use Sharp Edges", "Split edges that are marked as sharp");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -1227,13 +1399,6 @@ static void rna_def_modifier_displace(BlenderRNA *brna)
                {MOD_DISP_DIR_RGB_XYZ, "RGB_TO_XYZ", 0, "RGB to XYZ", ""},
                {0, NULL, 0, NULL, NULL}};
 
-       static EnumPropertyItem prop_texture_coordinates_items[] = {
-               {MOD_DISP_MAP_LOCAL, "LOCAL", 0, "Map", ""},
-               {MOD_DISP_MAP_GLOBAL, "GLOBAL", 0, "Global", ""},
-               {MOD_DISP_MAP_OBJECT, "OBJECT", 0, "Object", ""},
-               {MOD_DISP_MAP_UV, "UV", 0, "UV", ""},
-               {0, NULL, 0, NULL, NULL}};
-
        srna= RNA_def_struct(brna, "DisplaceModifier", "Modifier");
        RNA_def_struct_ui_text(srna, "Displace Modifier", "Displacement modifier");
        RNA_def_struct_sdna(srna, "DisplaceModifierData");
@@ -1241,16 +1406,12 @@ static void rna_def_modifier_displace(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "vertex_group", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "defgrp_name");
-       RNA_def_property_ui_text(prop, "Vertex Group", "Vertex group name");
+       RNA_def_property_ui_text(prop, "Vertex Group", "Name of Vertex Group which determines influence of modifier per point");
        RNA_def_property_string_funcs(prop, NULL, NULL, "rna_DisplaceModifier_vgroup_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "texture", PROP_POINTER, PROP_NONE);
-       RNA_def_property_ui_text(prop, "Texture", "");
-       RNA_def_property_flag(prop, PROP_EDITABLE);
-       RNA_def_property_update(prop, 0, "rna_Modifier_update");
-
-       prop= RNA_def_property(srna, "midlevel", PROP_FLOAT, PROP_DISTANCE);
+       prop= RNA_def_property(srna, "mid_level", PROP_FLOAT, PROP_DISTANCE);
+       RNA_def_property_float_sdna(prop, NULL, "midlevel");
        RNA_def_property_range(prop, 0, 1);
        RNA_def_property_ui_range(prop, 0, 1, 10, 3);
        RNA_def_property_ui_text(prop, "Midlevel", "Material value that gives no displacement");
@@ -1258,7 +1419,7 @@ static void rna_def_modifier_displace(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "strength", PROP_FLOAT, PROP_NONE);
        RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);
-       RNA_def_property_ui_range(prop, -100, 100, 10, 2);
+       RNA_def_property_ui_range(prop, -100, 100, 10, 3);
        RNA_def_property_ui_text(prop, "Strength", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
@@ -1267,23 +1428,7 @@ static void rna_def_modifier_displace(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Direction", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "texture_coordinates", PROP_ENUM, PROP_NONE);
-       RNA_def_property_enum_sdna(prop, NULL, "texmapping");
-       RNA_def_property_enum_items(prop, prop_texture_coordinates_items);
-       RNA_def_property_ui_text(prop, "Texture Coordinates", "");
-       RNA_def_property_update(prop, 0, "rna_Modifier_update");
-
-       prop= RNA_def_property(srna, "uv_layer", PROP_STRING, PROP_NONE);
-       RNA_def_property_string_sdna(prop, NULL, "uvlayer_name");
-       RNA_def_property_ui_text(prop, "UV Layer", "UV layer name");
-       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_DisplaceModifier_uvlayer_set");
-       RNA_def_property_update(prop, 0, "rna_Modifier_update");
-
-       prop= RNA_def_property(srna, "texture_coordinate_object", PROP_POINTER, PROP_NONE);
-       RNA_def_property_pointer_sdna(prop, NULL, "map_object");
-       RNA_def_property_ui_text(prop, "Texture Coordinate Object", "");
-       RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
-       RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
+       rna_def_modifier_generic_map_info(srna);
 }
 
 static void rna_def_modifier_uvproject(BlenderRNA *brna)
@@ -1302,7 +1447,8 @@ static void rna_def_modifier_uvproject(BlenderRNA *brna)
        RNA_def_property_string_funcs(prop, NULL, NULL, "rna_UVProjectModifier_uvlayer_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "num_projectors", PROP_INT, PROP_NONE);
+       prop= RNA_def_property(srna, "projector_count", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "num_projectors");
        RNA_def_property_ui_text(prop, "Number of Projectors", "Number of projectors to use");
        RNA_def_property_int_funcs(prop, NULL, "rna_UVProjectModifier_num_projectors_set", NULL);
        RNA_def_property_range(prop, 1, MOD_UVPROJECT_MAX);
@@ -1318,21 +1464,35 @@ static void rna_def_modifier_uvproject(BlenderRNA *brna)
        RNA_def_property_flag(prop, PROP_EDITABLE);
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "horizontal_aspect_ratio", PROP_FLOAT, PROP_NONE);
+       prop= RNA_def_property(srna, "aspect_x", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "aspectx");
        RNA_def_property_range(prop, 1, FLT_MAX);
-       RNA_def_property_ui_range(prop, 1, 1000, 100, 2);
+       RNA_def_property_ui_range(prop, 1, 1000, 1, 3);
        RNA_def_property_ui_text(prop, "Horizontal Aspect Ratio", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "vertical_aspect_ratio", PROP_FLOAT, PROP_NONE);
+       prop= RNA_def_property(srna, "aspect_y", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "aspecty");
        RNA_def_property_range(prop, 1, FLT_MAX);
-       RNA_def_property_ui_range(prop, 1, 1000, 100, 2);
+       RNA_def_property_ui_range(prop, 1, 1000, 1, 3);
        RNA_def_property_ui_text(prop, "Vertical Aspect Ratio", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
+       
+       prop= RNA_def_property(srna, "scale_x", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "scalex");
+       RNA_def_property_range(prop, 0, FLT_MAX);
+       RNA_def_property_ui_range(prop, 0, 1000, 1, 3);
+       RNA_def_property_ui_text(prop, "Horizontal Scale", "");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "override_image", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "scale_y", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "scaley");
+       RNA_def_property_range(prop, 0, FLT_MAX);
+       RNA_def_property_ui_range(prop, 0, 1000, 1, 3);
+       RNA_def_property_ui_text(prop, "Vertical Scale", "");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop= RNA_def_property(srna, "use_image_override", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flags", MOD_UVPROJECT_OVERRIDEIMAGE);
        RNA_def_property_ui_text(prop, "Override Image", "Override faces' current images with the given image");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -1342,9 +1502,10 @@ static void rna_def_modifier_uvproject(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "object", PROP_POINTER, PROP_NONE);
        RNA_def_property_struct_type(prop, "Object");
-       RNA_def_property_pointer_funcs(prop, "rna_UVProjector_object_get", "rna_UVProjector_object_set", NULL);
+       RNA_def_property_pointer_funcs(prop, "rna_UVProjector_object_get", "rna_UVProjector_object_set", NULL, NULL);
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_ui_text(prop, "Object", "Object to use as projector transform");
+       RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 }
 
 static void rna_def_modifier_smooth(BlenderRNA *brna)
@@ -1357,17 +1518,17 @@ static void rna_def_modifier_smooth(BlenderRNA *brna)
        RNA_def_struct_sdna(srna, "SmoothModifierData");
        RNA_def_struct_ui_icon(srna, ICON_MOD_SMOOTH);
 
-       prop= RNA_def_property(srna, "x", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_x", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_SMOOTH_X);
        RNA_def_property_ui_text(prop, "X", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "y", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_y", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_SMOOTH_Y);
        RNA_def_property_ui_text(prop, "Y", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "z", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_z", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_SMOOTH_Z);
        RNA_def_property_ui_text(prop, "Z", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -1375,18 +1536,19 @@ static void rna_def_modifier_smooth(BlenderRNA *brna)
        prop= RNA_def_property(srna, "factor", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "fac");
        RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);
-       RNA_def_property_ui_range(prop, -10, 10, 0.5, 2);
+       RNA_def_property_ui_range(prop, -10, 10, 1, 3);
        RNA_def_property_ui_text(prop, "Factor", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "repeat", PROP_INT, PROP_NONE);
+       prop= RNA_def_property(srna, "iterations", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "repeat");
        RNA_def_property_ui_range(prop, 0, 30, 1, 0);
        RNA_def_property_ui_text(prop, "Repeat", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
        
        prop= RNA_def_property(srna, "vertex_group", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "defgrp_name");
-       RNA_def_property_ui_text(prop, "Vertex Group", "Vertex group name");
+       RNA_def_property_ui_text(prop, "Vertex Group", "Name of Vertex Group which determines influence of modifier per point");
        RNA_def_property_string_funcs(prop, NULL, NULL, "rna_SmoothModifier_vgroup_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 }
@@ -1415,26 +1577,26 @@ static void rna_def_modifier_cast(BlenderRNA *brna)
        
        prop= RNA_def_property(srna, "object", PROP_POINTER, PROP_NONE);
        RNA_def_property_ui_text(prop, "Object", "Control object: if available, its location determines the center of the effect");
-       RNA_def_property_pointer_funcs(prop, NULL, "rna_CastModifier_object_set", NULL);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_CastModifier_object_set", NULL, NULL);
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 
-       prop= RNA_def_property(srna, "x", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_x", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_CAST_X);
        RNA_def_property_ui_text(prop, "X", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "y", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_y", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_CAST_Y);
        RNA_def_property_ui_text(prop, "Y", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "z", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_z", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_CAST_Z);
        RNA_def_property_ui_text(prop, "Z", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
        
-       prop= RNA_def_property(srna, "from_radius", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_radius_as_size", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_CAST_SIZE_FROM_RADIUS);
        RNA_def_property_ui_text(prop, "From Radius", "Use radius as size of projection shape (0 = auto)");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -1453,13 +1615,13 @@ static void rna_def_modifier_cast(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "radius", PROP_FLOAT, PROP_DISTANCE);
        RNA_def_property_range(prop, 0, FLT_MAX);
-       RNA_def_property_ui_range(prop, 0, 100, 10, 2);
+       RNA_def_property_ui_range(prop, 0, 100, 5, 2);
        RNA_def_property_ui_text(prop, "Radius", "Only deform vertices within this distance from the center of the effect (leave as 0 for infinite.)");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop= RNA_def_property(srna, "size", PROP_FLOAT, PROP_NONE);
        RNA_def_property_range(prop, 0, FLT_MAX);
-       RNA_def_property_ui_range(prop, 0, 100, 10, 2);
+       RNA_def_property_ui_range(prop, 0, 100, 5, 2);
        RNA_def_property_ui_text(prop, "Size", "Size of projection shape (leave as 0 for auto.)");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
@@ -1474,10 +1636,12 @@ static void rna_def_modifier_meshdeform(BlenderRNA *brna)
 {
        StructRNA *srna;
        PropertyRNA *prop;
+#if 0
        static EnumPropertyItem prop_mode_items[] = {
                {0, "VOLUME", 0, "Volume", "Bind to volume inside cage mesh"},
                {1, "SURFACE", 0, "Surface", "Bind to surface of cage mesh"},
                {0, NULL, 0, NULL, NULL}};
+#endif
 
        srna= RNA_def_struct(brna, "MeshDeformModifier", "Modifier");
        RNA_def_struct_ui_text(srna, "MeshDeform Modifier", "Mesh deformation modifier to deform with other meshes");
@@ -1486,7 +1650,7 @@ static void rna_def_modifier_meshdeform(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "object", PROP_POINTER, PROP_NONE);
        RNA_def_property_ui_text(prop, "Object", "Mesh object to deform with");
-       RNA_def_property_pointer_funcs(prop, NULL, "rna_MeshDeformModifier_object_set", NULL);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_MeshDeformModifier_object_set", NULL, NULL);
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
        
@@ -1495,7 +1659,7 @@ static void rna_def_modifier_meshdeform(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Bound", "Whether geometry has been bound to control cage");
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
        
-       prop= RNA_def_property(srna, "invert", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "invert_vertex_group", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_MDEF_INVERT_VGROUP);
        RNA_def_property_ui_text(prop, "Invert", "Invert vertex group influence");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -1512,25 +1676,33 @@ static void rna_def_modifier_meshdeform(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Precision", "The grid size for binding");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "dynamic", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_dynamic_bind", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_MDEF_DYNAMIC_BIND);
        RNA_def_property_ui_text(prop, "Dynamic", "Recompute binding dynamically on top of other deformers (slower and more memory consuming.)");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
+#if 0
        prop= RNA_def_property(srna, "mode", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_items(prop, prop_mode_items);
        RNA_def_property_ui_text(prop, "Mode", "Method of binding vertices are bound to cage mesh");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
+#endif
 }
 
 static void rna_def_modifier_particlesystem(BlenderRNA *brna)
 {
        StructRNA *srna;
+       PropertyRNA *prop;
 
        srna= RNA_def_struct(brna, "ParticleSystemModifier", "Modifier");
        RNA_def_struct_ui_text(srna, "ParticleSystem Modifier", "Particle system simulation modifier");
        RNA_def_struct_sdna(srna, "ParticleSystemModifierData");
        RNA_def_struct_ui_icon(srna, ICON_MOD_PARTICLES);
+       
+       prop= RNA_def_property(srna, "particle_system", PROP_POINTER, PROP_NONE);
+       RNA_def_property_flag(prop, PROP_NEVER_NULL);
+       RNA_def_property_pointer_sdna(prop, NULL, "psys");
+       RNA_def_property_ui_text(prop, "Particle System", "Particle System that this modifier controls");
 }
 
 static void rna_def_modifier_particleinstance(BlenderRNA *brna)
@@ -1556,7 +1728,7 @@ static void rna_def_modifier_particleinstance(BlenderRNA *brna)
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 
-       prop= RNA_def_property(srna, "particle_system_number", PROP_INT, PROP_NONE);
+       prop= RNA_def_property(srna, "particle_system_index", PROP_INT, PROP_NONE);
        RNA_def_property_int_sdna(prop, NULL, "psys");
        RNA_def_property_range(prop, 1, 10);
        RNA_def_property_ui_text(prop, "Particle System Number", "");
@@ -1568,42 +1740,42 @@ static void rna_def_modifier_particleinstance(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Axis", "Pole axis for rotation");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
        
-       prop= RNA_def_property(srna, "normal", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_normal", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", eParticleInstanceFlag_Parents);
        RNA_def_property_ui_text(prop, "Normal", "Create instances from normal particles");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "children", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_children", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", eParticleInstanceFlag_Children);
        RNA_def_property_ui_text(prop, "Children", "Create instances from child particles");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "path", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_path", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", eParticleInstanceFlag_Path);
        RNA_def_property_ui_text(prop, "Path", "Create instances along particle paths");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "unborn", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_unborn", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", eParticleInstanceFlag_Unborn);
        RNA_def_property_ui_text(prop, "Unborn", "Show instances when particles are unborn");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "alive", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_alive", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", eParticleInstanceFlag_Alive);
        RNA_def_property_ui_text(prop, "Alive", "Show instances when particles are alive");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "dead", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_dead", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", eParticleInstanceFlag_Dead);
        RNA_def_property_ui_text(prop, "Dead", "Show instances when particles are dead");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "keep_shape", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_preserve_shape", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", eParticleInstanceFlag_KeepShape);
        RNA_def_property_ui_text(prop, "Keep Shape", "Don't stretch the object");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "size", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_size", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", eParticleInstanceFlag_UseSize);
        RNA_def_property_ui_text(prop, "Size", "Use particle size to scale the instances");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -1640,25 +1812,36 @@ static void rna_def_modifier_explode(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Protect", "Clean vertex group edges");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "split_edges", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", eExplodeFlag_EdgeSplit);
-       RNA_def_property_ui_text(prop, "Split Edges", "Split face edges for nicer shrapnel");
+       prop= RNA_def_property(srna, "use_edge_cut", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", eExplodeFlag_EdgeCut);
+       RNA_def_property_ui_text(prop, "Cut Edges", "Cut face edges for nicer shrapnel");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "unborn", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_unborn", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", eExplodeFlag_Unborn);
        RNA_def_property_ui_text(prop, "Unborn", "Show mesh when particles are unborn");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "alive", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_alive", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", eExplodeFlag_Alive);
        RNA_def_property_ui_text(prop, "Alive", "Show mesh when particles are alive");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "dead", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_dead", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", eExplodeFlag_Dead);
        RNA_def_property_ui_text(prop, "Dead", "Show mesh when particles are dead");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop= RNA_def_property(srna, "use_size", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", eExplodeFlag_PaSize);
+       RNA_def_property_ui_text(prop, "Size", "Use particle size for the shrapnel");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop= RNA_def_property(srna, "particle_uv", PROP_STRING, PROP_NONE);
+       RNA_def_property_string_sdna(prop, NULL, "uvname");
+       RNA_def_property_string_maxlength(prop, 32);
+       RNA_def_property_ui_text(prop, "Particle UV", "UV Layer to change with particle age");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
 }
 
 static void rna_def_modifier_cloth(BlenderRNA *brna)
@@ -1693,9 +1876,9 @@ static void rna_def_modifier_smoke(BlenderRNA *brna)
        
        static EnumPropertyItem prop_smoke_type_items[] = {
                        {0, "NONE", 0, "None", ""},
-                       {MOD_SMOKE_TYPE_DOMAIN, "TYPE_DOMAIN", 0, "Domain", ""},
-                       {MOD_SMOKE_TYPE_FLOW, "TYPE_FLOW", 0, "Flow", "Inflow/Outflow"},
-                       {MOD_SMOKE_TYPE_COLL, "TYPE_COLL", 0, "Collision", ""},
+                       {MOD_SMOKE_TYPE_DOMAIN, "DOMAIN", 0, "Domain", ""},
+                       {MOD_SMOKE_TYPE_FLOW, "FLOW", 0, "Flow", "Inflow/Outflow"},
+                       {MOD_SMOKE_TYPE_COLL, "COLLISION", 0, "Collision", ""},
                        {0, NULL, 0, NULL, NULL}};
        
        srna= RNA_def_struct(brna, "SmokeModifier", "Modifier");
@@ -1735,7 +1918,7 @@ static void rna_def_modifier_collision(BlenderRNA *brna)
        prop= RNA_def_property(srna, "settings", PROP_POINTER, PROP_NONE);
        RNA_def_property_flag(prop, PROP_NEVER_NULL);
        RNA_def_property_struct_type(prop, "CollisionSettings");
-       RNA_def_property_pointer_funcs(prop, "rna_CollisionModifier_settings_get", NULL, NULL);
+       RNA_def_property_pointer_funcs(prop, "rna_CollisionModifier_settings_get", NULL, NULL, NULL);
        RNA_def_property_ui_text(prop, "Settings", "");
 }
 
@@ -1768,7 +1951,7 @@ static void rna_def_modifier_bevel(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Width", "Bevel value/amount");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "only_vertices", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_only_vertices", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flags", BME_BEVEL_VERT);
        RNA_def_property_ui_text(prop, "Only Vertices", "Bevel verts/corners, not edges");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -1785,7 +1968,7 @@ static void rna_def_modifier_bevel(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Edge Weight Method", "What edge weight to use for weighting a vertex");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "angle", PROP_FLOAT, PROP_NONE);
+       prop= RNA_def_property(srna, "angle_limit", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "bevel_angle");
        RNA_def_property_range(prop, 0, 180);
        RNA_def_property_ui_range(prop, 0, 180, 100, 2);
@@ -1803,28 +1986,41 @@ static void rna_def_modifier_shrinkwrap(BlenderRNA *brna)
                {MOD_SHRINKWRAP_PROJECT, "PROJECT", 0, "Project", ""},
                {MOD_SHRINKWRAP_NEAREST_VERTEX, "NEAREST_VERTEX", 0, "Nearest Vertex", ""},
                {0, NULL, 0, NULL, NULL}};
+       
+       static EnumPropertyItem shrink_face_cull_items[] = {
+               {0, "OFF", 0, "Off", ""},
+               {MOD_SHRINKWRAP_CULL_TARGET_FRONTFACE, "FRONT", 0, "Front", ""},
+               {MOD_SHRINKWRAP_CULL_TARGET_BACKFACE, "BACK", 0, "Back", ""},
+               {0, NULL, 0, NULL, NULL}};
 
        srna= RNA_def_struct(brna, "ShrinkwrapModifier", "Modifier");
        RNA_def_struct_ui_text(srna, "Shrinkwrap Modifier", "Shrink wrapping modifier to shrink wrap and object to a target");
        RNA_def_struct_sdna(srna, "ShrinkwrapModifierData");
        RNA_def_struct_ui_icon(srna, ICON_MOD_SHRINKWRAP);
 
-       prop= RNA_def_property(srna, "mode", PROP_ENUM, PROP_NONE);
+       prop= RNA_def_property(srna, "wrap_method", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "shrinkType");
        RNA_def_property_enum_items(prop, shrink_type_items);
        RNA_def_property_ui_text(prop, "Mode", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
+       prop= RNA_def_property(srna, "cull_face", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "shrinkOpts");
+       RNA_def_property_enum_items(prop, shrink_face_cull_items);
+       RNA_def_property_enum_funcs(prop, "rna_ShrinkwrapModifier_face_cull_get", "rna_ShrinkwrapModifier_face_cull_set", NULL);
+       RNA_def_property_ui_text(prop, "Face Cull", "Stop vertices from projecting to a the face on the target when facing towards/away");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
        prop= RNA_def_property(srna, "target", PROP_POINTER, PROP_NONE);
        RNA_def_property_ui_text(prop, "Target", "Mesh target to shrink to");
-       RNA_def_property_pointer_funcs(prop, NULL, "rna_ShrinkwrapModifier_target_set", NULL);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_ShrinkwrapModifier_target_set", NULL, "rna_Mesh_object_poll");
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 
        prop= RNA_def_property(srna, "auxiliary_target", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "auxTarget");
        RNA_def_property_ui_text(prop, "Auxiliary Target", "Additional mesh target to shrink to");
-       RNA_def_property_pointer_funcs(prop, NULL, "rna_ShrinkwrapModifier_auxiliary_target_set", NULL);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_ShrinkwrapModifier_auxiliary_target_set", NULL, "rna_Mesh_object_poll");
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 
@@ -1833,25 +2029,25 @@ static void rna_def_modifier_shrinkwrap(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Vertex Group", "Vertex group name");
        RNA_def_property_string_funcs(prop, NULL, NULL, "rna_ShrinkwrapModifier_vgroup_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
-       
+
        prop= RNA_def_property(srna, "offset", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "keepDist");
-       RNA_def_property_range(prop, 0, FLT_MAX);
-       RNA_def_property_ui_range(prop, 0, 100, 1, 2);
+       RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);
+       RNA_def_property_ui_range(prop, -100, 100, 1, 2);
        RNA_def_property_ui_text(prop, "Offset", "Distance to keep from the target");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "x", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_project_x", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "projAxis", MOD_SHRINKWRAP_PROJECT_OVER_X_AXIS);
        RNA_def_property_ui_text(prop, "X", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "y", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_project_y", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "projAxis", MOD_SHRINKWRAP_PROJECT_OVER_Y_AXIS);
        RNA_def_property_ui_text(prop, "Y", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "z", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_project_z", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "projAxis", MOD_SHRINKWRAP_PROJECT_OVER_Z_AXIS);
        RNA_def_property_ui_text(prop, "Z", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -1863,27 +2059,17 @@ static void rna_def_modifier_shrinkwrap(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Subsurf Levels", "Number of subdivisions that must be performed before extracting vertices' positions and normals");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "negative", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_negative_direction", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "shrinkOpts", MOD_SHRINKWRAP_PROJECT_ALLOW_NEG_DIR);
        RNA_def_property_ui_text(prop, "Negative", "Allow vertices to move in the negative direction of axis");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "positive", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_positive_direction", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "shrinkOpts", MOD_SHRINKWRAP_PROJECT_ALLOW_POS_DIR);
        RNA_def_property_ui_text(prop, "Positive", "Allow vertices to move in the positive direction of axis");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "cull_front_faces", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "shrinkOpts", MOD_SHRINKWRAP_CULL_TARGET_FRONTFACE);
-       RNA_def_property_ui_text(prop, "Cull Front Faces", "Stop vertices from projecting to a front face on the target");
-       RNA_def_property_update(prop, 0, "rna_Modifier_update");
-
-       prop= RNA_def_property(srna, "cull_back_faces", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "shrinkOpts", MOD_SHRINKWRAP_CULL_TARGET_BACKFACE);
-       RNA_def_property_ui_text(prop, "Cull Back Faces", "Stop vertices from projecting to a back face on the target");
-       RNA_def_property_update(prop, 0, "rna_Modifier_update");
-
-       prop= RNA_def_property(srna, "keep_above_surface", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_keep_above_surface", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "shrinkOpts", MOD_SHRINKWRAP_KEEP_ABOVE_SURFACE);
        RNA_def_property_ui_text(prop, "Keep Above Surface", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -1928,7 +2114,7 @@ static void rna_def_modifier_mask(BlenderRNA *brna)
        prop= RNA_def_property(srna, "armature", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "ob_arm");
        RNA_def_property_ui_text(prop, "Armature", "Armature to use as source of bones to mask");
-       RNA_def_property_pointer_funcs(prop, NULL, "rna_MaskModifier_armature_set", NULL);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_MaskModifier_armature_set", NULL, "rna_Armature_object_poll");
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 
@@ -1938,7 +2124,7 @@ static void rna_def_modifier_mask(BlenderRNA *brna)
        RNA_def_property_string_funcs(prop, NULL, NULL, "rna_MaskModifier_vgroup_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "invert", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "invert_vertex_group", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_MASK_INV);
        RNA_def_property_ui_text(prop, "Invert", "Use vertices that are not part of region defined");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -1961,7 +2147,8 @@ static void rna_def_modifier_simpledeform(BlenderRNA *brna)
        RNA_def_struct_sdna(srna, "SimpleDeformModifierData");
        RNA_def_struct_ui_icon(srna, ICON_MOD_SIMPLEDEFORM);
 
-       prop= RNA_def_property(srna, "mode", PROP_ENUM, PROP_NONE);
+       prop= RNA_def_property(srna, "deform_method", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "mode");
        RNA_def_property_enum_items(prop, simple_deform_mode_items);
        RNA_def_property_ui_text(prop, "Mode", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -1977,14 +2164,14 @@ static void rna_def_modifier_simpledeform(BlenderRNA *brna)
        RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 
-       prop= RNA_def_property(srna, "relative", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "use_relative", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "originOpts", MOD_SIMPLEDEFORM_ORIGIN_LOCAL);
        RNA_def_property_ui_text(prop, "Relative", "Sets the origin of deform space to be relative to the object");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop= RNA_def_property(srna, "factor", PROP_FLOAT, PROP_NONE);
        RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);
-       RNA_def_property_ui_range(prop, -10, 10, 0.5, 2);
+       RNA_def_property_ui_range(prop, -10, 10, 1, 3);
        RNA_def_property_ui_text(prop, "Factor", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
@@ -1996,12 +2183,12 @@ static void rna_def_modifier_simpledeform(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Limits", "Lower/Upper limits for deform");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "lock_x_axis", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "lock_x", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "axis", MOD_SIMPLEDEFORM_LOCK_AXIS_X);
        RNA_def_property_ui_text(prop, "Lock X Axis", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop= RNA_def_property(srna, "lock_y_axis", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "lock_y", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "axis", MOD_SIMPLEDEFORM_LOCK_AXIS_Y);
        RNA_def_property_ui_text(prop, "Lock Y Axis", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -2027,13 +2214,20 @@ static void rna_def_modifier_solidify(BlenderRNA *brna)
        RNA_def_struct_sdna(srna, "SolidifyModifierData");
        RNA_def_struct_ui_icon(srna, ICON_MOD_SOLIDIFY);
 
-       prop= RNA_def_property(srna, "offset", PROP_FLOAT, PROP_DISTANCE);
+       prop= RNA_def_property(srna, "thickness", PROP_FLOAT, PROP_DISTANCE);
        RNA_def_property_float_sdna(prop, NULL, "offset");
        RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);
        RNA_def_property_ui_range(prop, -10, 10, 0.1, 4);
        RNA_def_property_ui_text(prop, "Thickness", "Thickness of the shell");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
+       prop= RNA_def_property(srna, "offset", PROP_FLOAT, PROP_FACTOR);
+       RNA_def_property_float_sdna(prop, NULL, "offset_fac");
+       RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);
+       RNA_def_property_ui_range(prop, -1, 1, 0.1, 4);
+       RNA_def_property_ui_text(prop, "Offset", "Offset the thickness from the center");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
        prop= RNA_def_property(srna, "edge_crease_inner", PROP_FLOAT, PROP_FACTOR);
        RNA_def_property_float_sdna(prop, NULL, "crease_inner");
        RNA_def_property_range(prop, 0, 1);
@@ -2055,6 +2249,18 @@ static void rna_def_modifier_solidify(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Rim Crease", "Assign a crease to the edges making up the rim");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
+       prop= RNA_def_property(srna, "material_offset", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "mat_ofs");
+       RNA_def_property_range(prop, SHRT_MIN, SHRT_MAX);
+       RNA_def_property_ui_text(prop, "Material Offset", "Offset material index of generated faces");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop= RNA_def_property(srna, "material_offset_rim", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "mat_ofs_rim");
+       RNA_def_property_range(prop, SHRT_MIN, SHRT_MAX);
+       RNA_def_property_ui_text(prop, "Rim Material Offset", "Offset material index of generated rim faces");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
        prop= RNA_def_property(srna, "vertex_group", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "defgrp_name");
        RNA_def_property_ui_text(prop, "Vertex Group", "Vertex group name");
@@ -2076,6 +2282,12 @@ static void rna_def_modifier_solidify(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "High Quality Normals", "Calculate normals which result in more even thickness (slow, disable when not needed)");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
+       prop= RNA_def_property(srna, "invert_vertex_group", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_SOLIDIFY_VGROUP_INV);
+       RNA_def_property_ui_text(prop, "Vertex Group Invert", "Invert the vertex group influence");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+       
+       
 }
 
 static void rna_def_modifier_screw(BlenderRNA *brna)
@@ -2101,20 +2313,20 @@ static void rna_def_modifier_screw(BlenderRNA *brna)
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 
        prop= RNA_def_property(srna, "steps", PROP_INT, PROP_UNSIGNED);
-    RNA_def_property_range(prop, 2, 10000);
+       RNA_def_property_range(prop, 2, 10000);
        RNA_def_property_ui_range(prop, 2, 512, 1, 0);
        RNA_def_property_ui_text(prop, "Steps", "Number of steps in the revolution");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop= RNA_def_property(srna, "render_steps", PROP_INT, PROP_UNSIGNED);
-    RNA_def_property_range(prop, 2, 10000);
+       RNA_def_property_range(prop, 2, 10000);
        RNA_def_property_ui_range(prop, 2, 512, 1, 0);
        RNA_def_property_ui_text(prop, "Render Steps", "Number of steps in the revolution");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop= RNA_def_property(srna, "iterations", PROP_INT, PROP_UNSIGNED);
        RNA_def_property_int_sdna(prop, NULL, "iter");
-    RNA_def_property_range(prop, 1, 10000);
+       RNA_def_property_range(prop, 1, 10000);
        RNA_def_property_ui_range(prop, 1, 100, 1, 0);
        RNA_def_property_ui_text(prop, "Iterations", "Number of times to apply the screw operation");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -2125,7 +2337,7 @@ static void rna_def_modifier_screw(BlenderRNA *brna)
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop= RNA_def_property(srna, "angle", PROP_FLOAT, PROP_ANGLE);
-    RNA_def_property_ui_range(prop, 0, -M_PI*2, M_PI*2, 2);
+       RNA_def_property_ui_range(prop, 0, -M_PI*2, M_PI*2, 2);
        RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);
        RNA_def_property_ui_text(prop, "Angle", "Angle of revolution");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -2152,10 +2364,21 @@ static void rna_def_modifier_screw(BlenderRNA *brna)
 
        /*prop= RNA_def_property(srna, "use_angle_object", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_SCREW_OBJECT_ANGLE);
-       RNA_def_property_ui_text(prop, "Object Angle", "Use the angle between the objects rather then the fixed angle");
+       RNA_def_property_ui_text(prop, "Object Angle", "Use the angle between the objects rather than the fixed angle");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");*/
 }
 
+static void rna_def_modifier_navmesh(BlenderRNA *brna)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+
+       srna= RNA_def_struct(brna, "NavMeshModifier", "Modifier");
+       RNA_def_struct_ui_text(srna, "NavMesh Modifier", "NavMesh modifier");
+       RNA_def_struct_sdna(srna, "NavMeshModifierData");
+       RNA_def_struct_ui_icon(srna, ICON_MOD_DECIM);
+}
+
 void RNA_def_modifier(BlenderRNA *brna)
 {
        StructRNA *srna;
@@ -2183,34 +2406,40 @@ void RNA_def_modifier(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Type", "");
        
        /* flags */
-       prop= RNA_def_property(srna, "realtime", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_viewport", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "mode", eModifierMode_Realtime);
        RNA_def_property_ui_text(prop, "Realtime", "Realtime display of a modifier");
        RNA_def_property_flag(prop, PROP_LIB_EXCEPTION);
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
        RNA_def_property_ui_icon(prop, ICON_RESTRICT_VIEW_OFF, 0);
        
-       prop= RNA_def_property(srna, "render", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_render", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "mode", eModifierMode_Render);
        RNA_def_property_ui_text(prop, "Render", "Use modifier during rendering");
        RNA_def_property_ui_icon(prop, ICON_SCENE, 0);
+       RNA_def_property_update(prop, NC_OBJECT|ND_MODIFIER, NULL);
        
-       prop= RNA_def_property(srna, "editmode", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_in_editmode", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "mode", eModifierMode_Editmode);
        RNA_def_property_ui_text(prop, "Editmode", "Use modifier while in the edit mode");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
        RNA_def_property_ui_icon(prop, ICON_EDITMODE_HLT, 0);
        
-       prop= RNA_def_property(srna, "on_cage", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_on_cage", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "mode", eModifierMode_OnCage);
        RNA_def_property_ui_text(prop, "On Cage", "Enable direct editing of modifier control cage");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
        
-       prop= RNA_def_property(srna, "expanded", PROP_BOOLEAN, PROP_NONE);
+       prop= RNA_def_property(srna, "show_expanded", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "mode", eModifierMode_Expanded);
        RNA_def_property_ui_text(prop, "Expanded", "Set modifier expanded in the user interface");
        RNA_def_property_ui_icon(prop, ICON_TRIA_RIGHT, 1);
 
+       prop= RNA_def_property(srna, "use_apply_on_spline", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "mode", eModifierMode_ApplyOnSpline);
+       RNA_def_property_ui_text(prop, "Apply on spline", "Apply this and all preceding deformation modifiers on splines' points rather than on filled curve/surface");
+       RNA_def_property_ui_icon(prop, ICON_SURFACE_DATA, 0);
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        /* types */
        rna_def_modifier_subsurf(brna);
@@ -2241,11 +2470,13 @@ void RNA_def_modifier(BlenderRNA *brna)
        rna_def_modifier_fluidsim(brna);
        rna_def_modifier_mask(brna);
        rna_def_modifier_simpledeform(brna);
+       rna_def_modifier_warp(brna);
        rna_def_modifier_multires(brna);
        rna_def_modifier_surface(brna);
        rna_def_modifier_smoke(brna);
        rna_def_modifier_solidify(brna);
        rna_def_modifier_screw(brna);
+       rna_def_modifier_navmesh(brna);
 }
 
 #endif