Cleanup: use `rna_enum_` prefix for RNA enums
[blender.git] / source / blender / makesrna / intern / rna_modifier.c
index ed85312948d31e66d0ddfcb7130d04f36ec75687..4ca7493eb130ffab58b77cd41399f077a44490ec 100644 (file)
 
 #include "BLI_math.h"
 
-#include "BLF_translation.h"
+#include "BLT_translation.h"
 
 #include "BKE_animsys.h"
-#include "BKE_bmesh.h" /* For BevelModifierData */
+#include "BKE_data_transfer.h"
+#include "BKE_DerivedMesh.h"
 #include "BKE_dynamicpaint.h"
+#include "BKE_effect.h"
+#include "BKE_mesh_mapping.h"
+#include "BKE_mesh_remap.h"
 #include "BKE_multires.h"
 #include "BKE_smoke.h" /* For smokeModifier_free & smokeModifier_createType */
 
+#include "RNA_access.h"
 #include "RNA_define.h"
 #include "RNA_enum_types.h"
 
 #include "WM_api.h"
 #include "WM_types.h"
 
-EnumPropertyItem modifier_type_items[] = {
+EnumPropertyItem rna_enum_object_modifier_type_items[] = {
        {0, "", 0, N_("Modify"), ""},
+       {eModifierType_DataTransfer, "DATA_TRANSFER", ICON_MOD_DATA_TRANSFER, "Data Transfer", ""},
        {eModifierType_MeshCache, "MESH_CACHE", ICON_MOD_MESHDEFORM, "Mesh Cache", ""},
+       {eModifierType_NormalEdit, "NORMAL_EDIT", ICON_MOD_NORMALEDIT, "Normal Edit", ""},
        {eModifierType_UVProject, "UV_PROJECT", ICON_MOD_UVPROJECT, "UV Project", ""},
        {eModifierType_UVWarp, "UV_WARP", ICON_MOD_UVPROJECT, "UV Warp", ""},
        {eModifierType_WeightVGEdit, "VERTEX_WEIGHT_EDIT", ICON_MOD_VERTEX_WEIGHT, "Vertex Weight Edit", ""},
@@ -81,13 +88,16 @@ EnumPropertyItem modifier_type_items[] = {
        {eModifierType_Solidify, "SOLIDIFY", ICON_MOD_SOLIDIFY, "Solidify", ""},
        {eModifierType_Subsurf, "SUBSURF", ICON_MOD_SUBSURF, "Subdivision Surface", ""},
        {eModifierType_Triangulate, "TRIANGULATE", ICON_MOD_TRIANGULATE, "Triangulate", ""},
+       {eModifierType_Wireframe, "WIREFRAME", ICON_MOD_WIREFRAME, "Wireframe", "Generate a wireframe on the edges of a mesh"},
        {0, "", 0, N_("Deform"), ""},
        {eModifierType_Armature, "ARMATURE", ICON_MOD_ARMATURE, "Armature", ""},
        {eModifierType_Cast, "CAST", ICON_MOD_CAST, "Cast", ""},
+       {eModifierType_CorrectiveSmooth, "CORRECTIVE_SMOOTH", ICON_MOD_SMOOTH, "Corrective Smooth", ""},
        {eModifierType_Curve, "CURVE", ICON_MOD_CURVE, "Curve", ""},
        {eModifierType_Displace, "DISPLACE", ICON_MOD_DISPLACE, "Displace", ""},
        {eModifierType_Hook, "HOOK", ICON_HOOK, "Hook", ""},
        {eModifierType_LaplacianSmooth, "LAPLACIANSMOOTH", ICON_MOD_SMOOTH, "Laplacian Smooth", ""},
+       {eModifierType_LaplacianDeform, "LAPLACIANDEFORM", ICON_MOD_MESHDEFORM, "Laplacian Deform", ""},
        {eModifierType_Lattice, "LATTICE", ICON_MOD_LATTICE, "Lattice", ""},
        {eModifierType_MeshDeform, "MESH_DEFORM", ICON_MOD_MESHDEFORM, "Mesh Deform", ""},
        {eModifierType_Shrinkwrap, "SHRINKWRAP", ICON_MOD_SHRINKWRAP, "Shrinkwrap", ""},
@@ -110,15 +120,153 @@ EnumPropertyItem modifier_type_items[] = {
        {0, NULL, 0, NULL, NULL}
 };
 
+EnumPropertyItem rna_enum_modifier_triangulate_quad_method_items[] = {
+       {MOD_TRIANGULATE_QUAD_BEAUTY, "BEAUTY", 0, "Beauty ", "Split the quads in nice triangles, slower method"},
+       {MOD_TRIANGULATE_QUAD_FIXED, "FIXED", 0, "Fixed", "Split the quads on the first and third vertices"},
+       {MOD_TRIANGULATE_QUAD_ALTERNATE, "FIXED_ALTERNATE", 0, "Fixed Alternate",
+                                            "Split the quads on the 2nd and 4th vertices"},
+       {MOD_TRIANGULATE_QUAD_SHORTEDGE, "SHORTEST_DIAGONAL", 0, "Shortest Diagonal",
+                                            "Split the quads based on the distance between the vertices"},
+       {0, NULL, 0, NULL, NULL}
+};
+
+EnumPropertyItem rna_enum_modifier_triangulate_ngon_method_items[] = {
+       {MOD_TRIANGULATE_NGON_BEAUTY, "BEAUTY", 0, "Beauty", "Arrange the new triangles evenly (slow)"},
+       {MOD_TRIANGULATE_NGON_EARCLIP, "CLIP", 0, "Clip", "Split the polygons with an ear clipping algorithm"},
+       {0, NULL, 0, NULL, NULL}
+};
+
+#ifndef RNA_RUNTIME
+/* use eWarp_Falloff_*** & eHook_Falloff_***, they're in sync */
+static EnumPropertyItem modifier_warp_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_InvSquare, "INVERSE_SQUARE", ICON_ROOTCURVE, "Inverse Square", ""},
+       {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}
+};
+#endif
+
+/* ***** Data Transfer ***** */
+
+EnumPropertyItem rna_enum_dt_method_vertex_items[] = {
+       {MREMAP_MODE_TOPOLOGY, "TOPOLOGY", 0, "Topology",
+        "Copy from identical topology meshes"},
+       {MREMAP_MODE_VERT_NEAREST, "NEAREST", 0, "Nearest vertex",
+        "Copy from closest vertex"},
+       {MREMAP_MODE_VERT_EDGE_NEAREST, "EDGE_NEAREST", 0, "Nearest Edge Vertex",
+        "Copy from closest vertex of closest edge"},
+       {MREMAP_MODE_VERT_EDGEINTERP_NEAREST, "EDGEINTERP_NEAREST", 0, "Nearest Edge Interpolated",
+        "Copy from interpolated values of vertices from closest point on closest edge"},
+       {MREMAP_MODE_VERT_POLY_NEAREST, "POLY_NEAREST", 0, "Nearest Face Vertex",
+        "Copy from closest vertex of closest face"},
+       {MREMAP_MODE_VERT_POLYINTERP_NEAREST, "POLYINTERP_NEAREST", 0, "Nearest Face Interpolated",
+        "Copy from interpolated values of vertices from closest point on closest face"},
+       {MREMAP_MODE_VERT_POLYINTERP_VNORPROJ, "POLYINTERP_VNORPROJ", 0, "Projected Face Interpolated",
+        "Copy from interpolated values of vertices from point on closest face hit by normal-projection"},
+       {0, NULL, 0, NULL, NULL}
+};
+
+EnumPropertyItem rna_enum_dt_method_edge_items[] = {
+       {MREMAP_MODE_TOPOLOGY, "TOPOLOGY", 0, "Topology",
+        "Copy from identical topology meshes"},
+       {MREMAP_MODE_EDGE_VERT_NEAREST, "VERT_NEAREST", 0, "Nearest Vertices",
+        "Copy from most similar edge (edge which vertices are the closest of destination edge’s ones)"},
+       {MREMAP_MODE_EDGE_NEAREST, "NEAREST", 0, "Nearest Edge",
+        "Copy from closest edge (using midpoints)"},
+       {MREMAP_MODE_EDGE_POLY_NEAREST, "POLY_NEAREST", 0, "Nearest Face Edge",
+        "Copy from closest edge of closest face (using midpoints)"},
+       {MREMAP_MODE_EDGE_EDGEINTERP_VNORPROJ, "EDGEINTERP_VNORPROJ", 0, "Projected Edge Interpolated",
+        "Interpolate all source edges hit by the projection of destination one along its own normal (from vertices)"},
+       {0, NULL, 0, NULL, NULL}
+};
+
+EnumPropertyItem rna_enum_dt_method_loop_items[] = {
+       {MREMAP_MODE_TOPOLOGY, "TOPOLOGY", 0, "Topology",
+        "Copy from identical topology meshes"},
+       {MREMAP_MODE_LOOP_NEAREST_LOOPNOR, "NEAREST_NORMAL", 0, "Nearest Corner And Best Matching Normal",
+        "Copy from nearest corner which has the best matching normal"},
+       {MREMAP_MODE_LOOP_NEAREST_POLYNOR, "NEAREST_POLYNOR", 0, "Nearest Corner And Best Matching Face Normal",
+        "Copy from nearest corner which has the face with the best matching normal to destination corner's face one"},
+       {MREMAP_MODE_LOOP_POLY_NEAREST, "NEAREST_POLY", 0, "Nearest Corner Of Nearest Face",
+        "Copy from nearest corner of nearest polygon"},
+       {MREMAP_MODE_LOOP_POLYINTERP_NEAREST, "POLYINTERP_NEAREST", 0, "Nearest Face Interpolated",
+        "Copy from interpolated corners of the nearest source polygon"},
+       {MREMAP_MODE_LOOP_POLYINTERP_LNORPROJ, "POLYINTERP_LNORPROJ", 0, "Projected Face Interpolated",
+        "Copy from interpolated corners of the source polygon hit by corner normal projection"},
+       {0, NULL, 0, NULL, NULL}
+};
+
+EnumPropertyItem rna_enum_dt_method_poly_items[] = {
+       {MREMAP_MODE_TOPOLOGY, "TOPOLOGY", 0, "Topology",
+        "Copy from identical topology meshes"},
+       {MREMAP_MODE_POLY_NEAREST, "NEAREST", 0, "Nearest Face",
+        "Copy from nearest polygon (using center points)"},
+       {MREMAP_MODE_POLY_NOR, "NORMAL", 0, "Best Normal-Matching",
+        "Copy from source polygon which normal is the closest to destination one"},
+       {MREMAP_MODE_POLY_POLYINTERP_PNORPROJ, "POLYINTERP_PNORPROJ", 0, "Projected Face Interpolated",
+        "Interpolate all source polygons intersected by the projection of destination one along its own normal"},
+       {0, NULL, 0, NULL, NULL}
+};
+
+EnumPropertyItem rna_enum_dt_mix_mode_items[] = {
+       {CDT_MIX_TRANSFER, "REPLACE", 0, "Replace",
+        "Overwrite all elements' data"},
+       {CDT_MIX_REPLACE_ABOVE_THRESHOLD, "ABOVE_THRESHOLD", 0, "Above Threshold",
+        "Only replace destination elements where data is above given threshold (exact behavior depends on data type)"},
+       {CDT_MIX_REPLACE_BELOW_THRESHOLD, "BELOW_THRESHOLD", 0, "Below Threshold",
+        "Only replace destination elements where data is below given threshold (exact behavior depends on data type)"},
+       {CDT_MIX_MIX, "MIX", 0, "Mix",
+        "Mix source value into destination one, using given threshold as factor"},
+       {CDT_MIX_ADD, "ADD", 0, "Add",
+        "Add source value to destination one, using given threshold as factor"},
+       {CDT_MIX_SUB, "SUB", 0, "Subtract",
+        "Subtract source value to destination one, using given threshold as factor"},
+       {CDT_MIX_MUL, "MUL", 0, "Multiply",
+        "Multiply source value to destination one, using given threshold as factor"},
+       /* etc. etc. */
+       {0, NULL, 0, NULL, NULL}
+};
+
+EnumPropertyItem rna_enum_dt_layers_select_src_items[] = {
+       {DT_LAYERS_ACTIVE_SRC, "ACTIVE", 0, "Active Layer",
+        "Only transfer active data layer"},
+       {DT_LAYERS_ALL_SRC, "ALL", 0, "All Layers",
+        "Transfer all data layers"},
+       {DT_LAYERS_VGROUP_SRC_BONE_SELECT, "BONE_SELECT", 0, "Selected Pose Bones",
+        "Transfer all vertex groups used by selected pose bones"},
+       {DT_LAYERS_VGROUP_SRC_BONE_DEFORM, "BONE_DEFORM", 0, "Deform Pose Bones",
+        "Transfer all vertex groups used by deform bones"},
+       {0, NULL, 0, NULL, NULL}
+};
+
+EnumPropertyItem rna_enum_dt_layers_select_dst_items[] = {
+       {DT_LAYERS_ACTIVE_DST, "ACTIVE", 0, "Active Layer",
+        "Affect active data layer of all targets"},
+       {DT_LAYERS_NAME_DST, "NAME", 0, "By Name",
+        "Match target data layers to affect by name"},
+       {DT_LAYERS_INDEX_DST, "INDEX", 0, "By Order",
+        "Match target data layers to affect by order (indices)"},
+       {0, NULL, 0, NULL, NULL}
+};
+
+
 #ifdef RNA_RUNTIME
 
 #include "DNA_particle_types.h"
+#include "DNA_curve_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_object.h"
 #include "BKE_particle.h"
 
 static void rna_UVProject_projectors_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
@@ -222,6 +370,16 @@ static StructRNA *rna_Modifier_refine(struct PointerRNA *ptr)
                        return &RNA_UVWarpModifier;
                case eModifierType_MeshCache:
                        return &RNA_MeshCacheModifier;
+               case eModifierType_LaplacianDeform:
+                       return &RNA_LaplacianDeformModifier;
+               case eModifierType_Wireframe:
+                       return &RNA_WireframeModifier;
+               case eModifierType_DataTransfer:
+                       return &RNA_DataTransferModifier;
+               case eModifierType_NormalEdit:
+                       return &RNA_NormalEditModifier;
+               case eModifierType_CorrectiveSmooth:
+                       return &RNA_CorrectiveSmoothModifier;
                /* Default */
                case eModifierType_None:
                case eModifierType_ShapeKey:
@@ -250,7 +408,7 @@ static void rna_Modifier_name_set(PointerRNA *ptr, const char *value)
        }
        
        /* fix all the animation data which may link to this */
-       BKE_all_animdata_fix_paths_rename(NULL, "modifiers", oldname, md->name);
+       BKE_animdata_fix_paths_rename_all(NULL, "modifiers", oldname, md->name);
 }
 
 static char *rna_Modifier_path(PointerRNA *ptr)
@@ -274,33 +432,46 @@ static void rna_Modifier_dependency_update(Main *bmain, Scene *scene, PointerRNA
        DAG_relations_tag_update(bmain);
 }
 
-static void rna_Smoke_set_type(Main *bmain, Scene *scene, PointerRNA *ptr)
-{
-       SmokeModifierData *smd = (SmokeModifierData *)ptr->data;
-       Object *ob = (Object *)ptr->id.data;
+/* Vertex Groups */
 
-       /* nothing changed */
-       if ((smd->type & MOD_SMOKE_TYPE_DOMAIN) && smd->domain)
-               return;
-               
-       smokeModifier_free(smd); /* XXX TODO: completely free all 3 pointers */
-       smokeModifier_createType(smd); /* create regarding of selected type */
-
-       switch (smd->type) {
-               case MOD_SMOKE_TYPE_DOMAIN:
-                       ob->dt = OB_WIRE;
-                       break;
-               case MOD_SMOKE_TYPE_FLOW:
-               case MOD_SMOKE_TYPE_COLL:
-               case 0:
-               default:
-                       break;
-       }
-       
-       /* update dependency since a domain - other type switch could have happened */
-       rna_Modifier_dependency_update(bmain, scene, ptr);
+#define RNA_MOD_VGROUP_NAME_SET(_type, _prop)                                               \
+static void rna_##_type##Modifier_##_prop##_set(PointerRNA *ptr, const char *value)         \
+{                                                                                           \
+       _type##ModifierData *tmd = (_type##ModifierData *)ptr->data;                            \
+       rna_object_vgroup_name_set(ptr, value, tmd->_prop, sizeof(tmd->_prop));                 \
 }
 
+RNA_MOD_VGROUP_NAME_SET(Armature, defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(Bevel, defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(Cast, defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(Curve, name);
+RNA_MOD_VGROUP_NAME_SET(DataTransfer, defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(Decimate, defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(CorrectiveSmooth, defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(Displace, defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(Hook, name);
+RNA_MOD_VGROUP_NAME_SET(LaplacianDeform, anchor_grp_name);
+RNA_MOD_VGROUP_NAME_SET(LaplacianSmooth, defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(Lattice, name);
+RNA_MOD_VGROUP_NAME_SET(Mask, vgroup);
+RNA_MOD_VGROUP_NAME_SET(MeshDeform, defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(NormalEdit, defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(Shrinkwrap, vgroup_name);
+RNA_MOD_VGROUP_NAME_SET(SimpleDeform, vgroup_name);
+RNA_MOD_VGROUP_NAME_SET(Smooth, defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(Solidify, defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(UVWarp, vgroup_name);
+RNA_MOD_VGROUP_NAME_SET(Warp, defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(Wave, defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(WeightVGEdit, defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(WeightVGEdit, mask_defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(WeightVGMix, defgrp_name_a);
+RNA_MOD_VGROUP_NAME_SET(WeightVGMix, defgrp_name_b);
+RNA_MOD_VGROUP_NAME_SET(WeightVGMix, mask_defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(WeightVGProximity, defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(WeightVGProximity, mask_defgrp_name);
+RNA_MOD_VGROUP_NAME_SET(Wireframe, defgrp_name);
+
 static void rna_ExplodeModifier_vgroup_get(PointerRNA *ptr, char *value)
 {
        ExplodeModifierData *emd = (ExplodeModifierData *)ptr->data;
@@ -319,169 +490,115 @@ static void rna_ExplodeModifier_vgroup_set(PointerRNA *ptr, const char *value)
        rna_object_vgroup_name_index_set(ptr, value, &emd->vgroup);
 }
 
-static void rna_SimpleDeformModifier_vgroup_set(PointerRNA *ptr, const char *value)
-{
-       SimpleDeformModifierData *smd = (SimpleDeformModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, smd->vgroup_name, sizeof(smd->vgroup_name));
-}
+#undef RNA_MOD_VGROUP_NAME_SET
 
-static void rna_ShrinkwrapModifier_vgroup_set(PointerRNA *ptr, const char *value)
-{
-       ShrinkwrapModifierData *smd = (ShrinkwrapModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, smd->vgroup_name, sizeof(smd->vgroup_name));
-}
-
-static void rna_LatticeModifier_vgroup_set(PointerRNA *ptr, const char *value)
-{
-       LatticeModifierData *lmd = (LatticeModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, lmd->name, sizeof(lmd->name));
-}
+/* UV layers */
 
-static void rna_ArmatureModifier_vgroup_set(PointerRNA *ptr, const char *value)
-{
-       ArmatureModifierData *lmd = (ArmatureModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, lmd->defgrp_name, sizeof(lmd->defgrp_name));
-}
-
-static void rna_CurveModifier_vgroup_set(PointerRNA *ptr, const char *value)
-{
-       CurveModifierData *lmd = (CurveModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, lmd->name, sizeof(lmd->name));
-}
-
-static void rna_DisplaceModifier_vgroup_set(PointerRNA *ptr, const char *value)
-{
-       DisplaceModifierData *lmd = (DisplaceModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, lmd->defgrp_name, sizeof(lmd->defgrp_name));
+#define RNA_MOD_UVLAYER_NAME_SET(_type, _prop)                                              \
+static void rna_##_type##Modifier_##_prop##_set(PointerRNA *ptr, const char *value)         \
+{                                                                                           \
+       _type##ModifierData *tmd = (_type##ModifierData *)ptr->data;                            \
+       rna_object_uvlayer_name_set(ptr, value, tmd->_prop, sizeof(tmd->_prop));                \
 }
 
-static void rna_HookModifier_vgroup_set(PointerRNA *ptr, const char *value)
-{
-       HookModifierData *lmd = (HookModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, lmd->name, sizeof(lmd->name));
-}
+RNA_MOD_UVLAYER_NAME_SET(MappingInfo, uvlayer_name);
+RNA_MOD_UVLAYER_NAME_SET(UVProject, uvlayer_name);
+RNA_MOD_UVLAYER_NAME_SET(UVWarp, uvlayer_name);
+RNA_MOD_UVLAYER_NAME_SET(WeightVGEdit, mask_tex_uvlayer_name);
+RNA_MOD_UVLAYER_NAME_SET(WeightVGMix, mask_tex_uvlayer_name);
+RNA_MOD_UVLAYER_NAME_SET(WeightVGProximity, mask_tex_uvlayer_name);
 
-static void rna_MaskModifier_vgroup_set(PointerRNA *ptr, const char *value)
-{
-       MaskModifierData *lmd = (MaskModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, lmd->vgroup, sizeof(lmd->vgroup));
-}
+#undef RNA_MOD_UVLAYER_NAME_SET
 
-static void rna_MeshDeformModifier_vgroup_set(PointerRNA *ptr, const char *value)
-{
-       MeshDeformModifierData *lmd = (MeshDeformModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, lmd->defgrp_name, sizeof(lmd->defgrp_name));
-}
+/* Objects */
 
-static void rna_SmoothModifier_vgroup_set(PointerRNA *ptr, const char *value)
+static void modifier_object_set(Object *self, Object **ob_p, int type, PointerRNA value)
 {
-       SmoothModifierData *lmd = (SmoothModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, lmd->defgrp_name, sizeof(lmd->defgrp_name));
-}
+       Object *ob = value.data;
 
-static void rna_LaplacianSmoothModifier_vgroup_set(PointerRNA *ptr, const char *value)
-{
-       LaplacianSmoothModifierData *lmd = (LaplacianSmoothModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, lmd->defgrp_name, sizeof(lmd->defgrp_name));
+       if (!self || ob != self) {
+               if (!ob || type == OB_EMPTY || ob->type == type) {
+                       id_lib_extern((ID *)ob);
+                       *ob_p = ob;
+               }
+       }
 }
 
-static void rna_WaveModifier_vgroup_set(PointerRNA *ptr, const char *value)
-{
-       WaveModifierData *lmd = (WaveModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, lmd->defgrp_name, sizeof(lmd->defgrp_name));
+#define RNA_MOD_OBJECT_SET(_type, _prop, _obtype)                                           \
+static void rna_##_type##Modifier_##_prop##_set(PointerRNA *ptr, PointerRNA value)          \
+{                                                                                           \
+       _type##ModifierData *tmd = (_type##ModifierData *)ptr->data;                            \
+       modifier_object_set(ptr->id.data, &tmd->_prop, _obtype, value);                         \
 }
 
-static void rna_CastModifier_vgroup_set(PointerRNA *ptr, const char *value)
+RNA_MOD_OBJECT_SET(Armature, object, OB_ARMATURE);
+RNA_MOD_OBJECT_SET(Array, start_cap, OB_MESH);
+RNA_MOD_OBJECT_SET(Array, end_cap, OB_MESH);
+RNA_MOD_OBJECT_SET(Array, curve_ob, OB_CURVE);
+RNA_MOD_OBJECT_SET(Boolean, object, OB_MESH);
+RNA_MOD_OBJECT_SET(Cast, object, OB_EMPTY);
+RNA_MOD_OBJECT_SET(Curve, object, OB_CURVE);
+RNA_MOD_OBJECT_SET(DataTransfer, ob_source, OB_MESH);
+RNA_MOD_OBJECT_SET(Lattice, object, OB_LATTICE);
+RNA_MOD_OBJECT_SET(Mask, ob_arm, OB_ARMATURE);
+RNA_MOD_OBJECT_SET(MeshDeform, object, OB_MESH);
+RNA_MOD_OBJECT_SET(NormalEdit, target, OB_EMPTY);
+RNA_MOD_OBJECT_SET(Shrinkwrap, target, OB_MESH);
+RNA_MOD_OBJECT_SET(Shrinkwrap, auxTarget, OB_MESH);
+
+static void rna_HookModifier_object_set(PointerRNA *ptr, PointerRNA value)
 {
-       CastModifierData *lmd = (CastModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, lmd->defgrp_name, sizeof(lmd->defgrp_name));
-}
+       HookModifierData *hmd = ptr->data;
+       Object *ob = (Object *)value.data;
 
-static void rna_SolidifyModifier_vgroup_set(PointerRNA *ptr, const char *value)
-{
-       SolidifyModifierData *smd = (SolidifyModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, smd->defgrp_name, sizeof(smd->defgrp_name));
+       hmd->object = ob;
+       id_lib_extern((ID *)ob);
+       BKE_object_modifier_hook_reset(ob, hmd);
 }
 
-static void rna_DecimateModifier_vgroup_set(PointerRNA *ptr, const char *value)
+static PointerRNA rna_UVProjector_object_get(PointerRNA *ptr)
 {
-       DecimateModifierData *dmd = (DecimateModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, dmd->defgrp_name, sizeof(dmd->defgrp_name));
+       Object **ob = (Object **)ptr->data;
+       return rna_pointer_inherit_refine(ptr, &RNA_Object, *ob);
 }
 
-static void rna_WeightVGModifier_vgroup_set(PointerRNA *ptr, const char *value)
+static void rna_UVProjector_object_set(PointerRNA *ptr, PointerRNA value)
 {
-       ModifierData *md = (ModifierData *)ptr->data;
-       if (md->type == eModifierType_WeightVGEdit) {
-               WeightVGEditModifierData *wmd = (WeightVGEditModifierData *)md;
-               rna_object_vgroup_name_set(ptr, value, wmd->defgrp_name, sizeof(wmd->defgrp_name));
-       }
-       else if (md->type == eModifierType_WeightVGMix) {
-               WeightVGMixModifierData *wmd = (WeightVGMixModifierData *)md;
-               rna_object_vgroup_name_set(ptr, value, wmd->defgrp_name_a, sizeof(wmd->defgrp_name_a));
-       }
-       else if (md->type == eModifierType_WeightVGProximity) {
-               WeightVGProximityModifierData *wmd = (WeightVGProximityModifierData *)md;
-               rna_object_vgroup_name_set(ptr, value, wmd->defgrp_name, sizeof(wmd->defgrp_name));
-       }
+       Object **ob_p = (Object **)ptr->data;
+       Object *ob = (Object *)value.data;
+       id_lib_extern((ID *)ob);
+       *ob_p = ob;
 }
 
-static void rna_WeightVGModifier_mask_vgroup_set(PointerRNA *ptr, const char *value)
-{
-       ModifierData *md = (ModifierData *)ptr->data;
-       if (md->type == eModifierType_WeightVGEdit) {
-               WeightVGEditModifierData *wmd = (WeightVGEditModifierData *)md;
-               rna_object_vgroup_name_set(ptr, value, wmd->mask_defgrp_name, sizeof(wmd->mask_defgrp_name));
-       }
-       else if (md->type == eModifierType_WeightVGMix) {
-               WeightVGMixModifierData *wmd = (WeightVGMixModifierData *)md;
-               rna_object_vgroup_name_set(ptr, value, wmd->mask_defgrp_name, sizeof(wmd->mask_defgrp_name));
-       }
-       else if (md->type == eModifierType_WeightVGProximity) {
-               WeightVGProximityModifierData *wmd = (WeightVGProximityModifierData *)md;
-               rna_object_vgroup_name_set(ptr, value, wmd->mask_defgrp_name, sizeof(wmd->mask_defgrp_name));
-       }
-}
+#undef RNA_MOD_OBJECT_SET
 
-static void rna_WeightVGMixModifier_vgroup2_set(PointerRNA *ptr, const char *value)
-{
-       WeightVGMixModifierData *wmd = (WeightVGMixModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, wmd->defgrp_name_b, sizeof(wmd->defgrp_name_b));
-}
+/* Other rna callbacks */
 
-static void rna_MappingInfo_uvlayer_set(PointerRNA *ptr, const char *value)
+static void rna_Smoke_set_type(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
-       MappingInfoModifierData *mmd = (MappingInfoModifierData *)ptr->data;
-       rna_object_uvlayer_name_set(ptr, value, mmd->uvlayer_name, sizeof(mmd->uvlayer_name));
-}
+       SmokeModifierData *smd = (SmokeModifierData *)ptr->data;
+       Object *ob = (Object *)ptr->id.data;
 
-static void rna_UVProjectModifier_uvlayer_set(PointerRNA *ptr, const char *value)
-{
-       UVProjectModifierData *umd = (UVProjectModifierData *)ptr->data;
-       rna_object_uvlayer_name_set(ptr, value, umd->uvlayer_name, sizeof(umd->uvlayer_name));
-}
+       /* nothing changed */
+       if ((smd->type & MOD_SMOKE_TYPE_DOMAIN) && smd->domain)
+               return;
 
-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));
-}
+       smokeModifier_free(smd); /* XXX TODO: completely free all 3 pointers */
+       smokeModifier_createType(smd); /* create regarding of selected type */
 
-static void rna_WeightVGModifier_mask_uvlayer_set(PointerRNA *ptr, const char *value)
-{
-       ModifierData *md = (ModifierData *)ptr->data;
-       if (md->type == eModifierType_WeightVGEdit) {
-               WeightVGEditModifierData *wmd = (WeightVGEditModifierData *)md;
-               rna_object_uvlayer_name_set(ptr, value, wmd->mask_tex_uvlayer_name, sizeof(wmd->mask_tex_uvlayer_name));
-       }
-       else if (md->type == eModifierType_WeightVGMix) {
-               WeightVGMixModifierData *wmd = (WeightVGMixModifierData *)md;
-               rna_object_uvlayer_name_set(ptr, value, wmd->mask_tex_uvlayer_name, sizeof(wmd->mask_tex_uvlayer_name));
-       }
-       else if (md->type == eModifierType_WeightVGProximity) {
-               WeightVGProximityModifierData *wmd = (WeightVGProximityModifierData *)md;
-               rna_object_uvlayer_name_set(ptr, value, wmd->mask_tex_uvlayer_name, sizeof(wmd->mask_tex_uvlayer_name));
+       switch (smd->type) {
+               case MOD_SMOKE_TYPE_DOMAIN:
+                       ob->dt = OB_WIRE;
+                       break;
+               case MOD_SMOKE_TYPE_FLOW:
+               case MOD_SMOKE_TYPE_COLL:
+               case 0:
+               default:
+                       break;
        }
+
+       /* update dependency since a domain - other type switch could have happened */
+       rna_Modifier_dependency_update(bmain, scene, ptr);
 }
 
 static void rna_MultiresModifier_type_set(PointerRNA *ptr, int value)
@@ -493,7 +610,8 @@ static void rna_MultiresModifier_type_set(PointerRNA *ptr, int value)
        mmd->simple = value;
 }
 
-static void rna_MultiresModifier_level_range(PointerRNA *ptr, int *min, int *max, int *softmin, int *softmax)
+static void rna_MultiresModifier_level_range(PointerRNA *ptr, int *min, int *max,
+                                             int *UNUSED(softmin), int *UNUSED(softmax))
 {
        MultiresModifierData *mmd = (MultiresModifierData *)ptr->data;
 
@@ -522,7 +640,7 @@ static void rna_MultiresModifier_filepath_set(PointerRNA *ptr, const char *value
        Object *ob = (Object *)ptr->id.data;
        CustomDataExternal *external = ((Mesh *)ob->data)->ldata.external;
 
-       if (external && strcmp(external->filename, value)) {
+       if (external && !STREQ(external->filename, value)) {
                BLI_strncpy(external->filename, value, sizeof(external->filename));
                multires_force_external_reload(ob);
        }
@@ -536,58 +654,6 @@ static int rna_MultiresModifier_filepath_length(PointerRNA *ptr)
        return strlen((external) ? external->filename : "");
 }
 
-static void modifier_object_set(Object *self, Object **ob_p, int type, PointerRNA value)
-{
-       Object *ob = value.data;
-
-       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)
-{
-       modifier_object_set(ptr->id.data, &((LatticeModifierData *)ptr->data)->object, OB_LATTICE, value);
-}
-
-static void rna_BooleanModifier_object_set(PointerRNA *ptr, PointerRNA value)
-{
-       modifier_object_set(ptr->id.data, &((BooleanModifierData *)ptr->data)->object, OB_MESH, value);
-}
-
-static void rna_CurveModifier_object_set(PointerRNA *ptr, PointerRNA value)
-{
-       modifier_object_set(ptr->id.data, &((CurveModifierData *)ptr->data)->object, OB_CURVE, value);
-}
-
-static void rna_CastModifier_object_set(PointerRNA *ptr, PointerRNA value)
-{
-       modifier_object_set(ptr->id.data, &((CastModifierData *)ptr->data)->object, OB_EMPTY, value);
-}
-
-static void rna_ArmatureModifier_object_set(PointerRNA *ptr, PointerRNA value)
-{
-       modifier_object_set(ptr->id.data, &((ArmatureModifierData *)ptr->data)->object, OB_ARMATURE, value);
-}
-
-static void rna_MaskModifier_armature_set(PointerRNA *ptr, PointerRNA value)
-{
-       modifier_object_set(ptr->id.data, &((MaskModifierData *)ptr->data)->ob_arm, OB_ARMATURE, value);
-}
-
-static void rna_ShrinkwrapModifier_auxiliary_target_set(PointerRNA *ptr, PointerRNA value)
-{
-       modifier_object_set(ptr->id.data, &((ShrinkwrapModifierData *)ptr->data)->auxTarget, OB_MESH, value);
-}
-
-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;
@@ -602,26 +668,6 @@ static void rna_ShrinkwrapModifier_face_cull_set(struct PointerRNA *ptr, int val
            (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);
-}
-
-static void rna_ArrayModifier_end_cap_set(PointerRNA *ptr, PointerRNA value)
-{
-       modifier_object_set(ptr->id.data, &((ArrayModifierData *)ptr->data)->end_cap, OB_MESH, value);
-}
-
-static void rna_ArrayModifier_start_cap_set(PointerRNA *ptr, PointerRNA value)
-{
-       modifier_object_set(ptr->id.data, &((ArrayModifierData *)ptr->data)->start_cap, OB_MESH, value);
-}
-
-static void rna_ArrayModifier_curve_set(PointerRNA *ptr, PointerRNA value)
-{
-       modifier_object_set(ptr->id.data, &((ArrayModifierData *)ptr->data)->curve_ob, OB_CURVE, value);
-}
-
 static int rna_MeshDeformModifier_is_bound_get(PointerRNA *ptr)
 {
        return (((MeshDeformModifierData *)ptr->data)->bindcagecos != NULL);
@@ -645,31 +691,13 @@ static PointerRNA rna_CollisionModifier_settings_get(PointerRNA *ptr)
        return rna_pointer_inherit_refine(ptr, &RNA_CollisionSettings, ob->pd);
 }
 
-static PointerRNA rna_UVProjector_object_get(PointerRNA *ptr)
-{
-       Object **ob = (Object **)ptr->data;
-       return rna_pointer_inherit_refine(ptr, &RNA_Object, *ob);
-}
-
-static void rna_UVProjector_object_set(PointerRNA *ptr, PointerRNA value)
-{
-       Object **ob = (Object **)ptr->data;
-
-       if (*ob)
-               id_us_min((ID *)*ob);
-       if (value.data)
-               id_us_plus((ID *)value.data);
-
-       *ob = value.data;
-}
-
 static void rna_UVProjectModifier_num_projectors_set(PointerRNA *ptr, int value)
 {
        UVProjectModifierData *md = (UVProjectModifierData *)ptr->data;
        int a;
 
-       md->num_projectors = CLAMPIS(value, 1, MOD_UVPROJECT_MAX);
-       for (a = md->num_projectors; a < MOD_UVPROJECT_MAX; a++)
+       md->num_projectors = CLAMPIS(value, 1, MOD_UVPROJECT_MAXPROJECTORS);
+       for (a = md->num_projectors; a < MOD_UVPROJECT_MAXPROJECTORS; a++)
                md->projectors[a] = NULL;
 }
 
@@ -715,50 +743,362 @@ static void rna_OceanModifier_ocean_chop_set(PointerRNA *ptr, float value)
        }
 }
 
-static float rna_EdgeSplitModifier_split_angle_get(PointerRNA *ptr)
+static int rna_LaplacianDeformModifier_is_bind_get(PointerRNA *ptr)
+{
+       LaplacianDeformModifierData *lmd = (LaplacianDeformModifierData *)ptr->data;
+       return ((lmd->flag & MOD_LAPLACIANDEFORM_BIND) && (lmd->cache_system != NULL));
+}
+
+/* NOTE: Curve and array modifiers requires curve path to be evaluated,
+ * dependency graph will make sure that curve eval would create such a path,
+ * but if curve was already evaluated we might miss path.
+ *
+ * So what we do here is: if path was not calculated for target curve we
+ * tag it for update.
+ */
+
+static void rna_CurveModifier_dependency_update(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
-       EdgeSplitModifierData *md = (EdgeSplitModifierData *)ptr->data;
-       return DEG2RADF(md->split_angle);
+       CurveModifierData *cmd = (CurveModifierData *)ptr->data;
+       rna_Modifier_update(bmain, scene, ptr);
+       DAG_relations_tag_update(bmain);
+       if (cmd->object != NULL) {
+               Curve *curve = cmd->object->data;
+               if ((curve->flag & CU_PATH) == 0) {
+                       DAG_id_tag_update(&curve->id, OB_RECALC_DATA);
+               }
+       }
 }
 
-static void rna_EdgeSplitModifier_split_angle_set(PointerRNA *ptr, float value)
+static void rna_ArrayModifier_dependency_update(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
-       EdgeSplitModifierData *md = (EdgeSplitModifierData *)ptr->data;
-       value = RAD2DEGF(value);
-       CLAMP(value, 0.0f, 180.0f);
-       md->split_angle = (int)value;
+       ArrayModifierData *amd = (ArrayModifierData *)ptr->data;
+       rna_Modifier_update(bmain, scene, ptr);
+       DAG_relations_tag_update(bmain);
+       if (amd->curve_ob != NULL) {
+               Curve *curve = amd->curve_ob->data;
+               if ((curve->flag & CU_PATH) == 0) {
+                       DAG_id_tag_update(&curve->id, OB_RECALC_DATA);
+               }
+       }
 }
 
-static float rna_BevelModifier_angle_limit_get(PointerRNA *ptr)
+
+static void rna_DataTransferModifier_use_data_update(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
-       BevelModifierData *md = (BevelModifierData *)ptr->data;
-       return DEG2RADF(md->bevel_angle);
+       DataTransferModifierData *dtmd = (DataTransferModifierData *)ptr->data;
+
+       if (!(dtmd->flags & MOD_DATATRANSFER_USE_VERT)) {
+               dtmd->data_types &= ~DT_TYPE_VERT_ALL;
+       }
+       if (!(dtmd->flags & MOD_DATATRANSFER_USE_EDGE)) {
+               dtmd->data_types &= ~DT_TYPE_EDGE_ALL;
+       }
+       if (!(dtmd->flags & MOD_DATATRANSFER_USE_LOOP)) {
+               dtmd->data_types &= ~DT_TYPE_LOOP_ALL;
+       }
+       if (!(dtmd->flags & MOD_DATATRANSFER_USE_POLY)) {
+               dtmd->data_types &= ~DT_TYPE_POLY_ALL;
+       }
+
+       rna_Modifier_update(bmain, scene, ptr);
+}
+
+static void rna_DataTransferModifier_data_types_update(Main *bmain, Scene *scene, PointerRNA *ptr)
+{
+       DataTransferModifierData *dtmd = (DataTransferModifierData *)ptr->data;
+       const int item_types = BKE_object_data_transfer_get_dttypes_item_types(dtmd->data_types);
+
+       if (item_types & ME_VERT) {
+               dtmd->flags |= MOD_DATATRANSFER_USE_VERT;
+       }
+       if (item_types & ME_EDGE) {
+               dtmd->flags |= MOD_DATATRANSFER_USE_EDGE;
+       }
+       if (item_types & ME_LOOP) {
+               dtmd->flags |= MOD_DATATRANSFER_USE_LOOP;
+       }
+       if (item_types & ME_POLY) {
+               dtmd->flags |= MOD_DATATRANSFER_USE_POLY;
+       }
+
+       rna_Modifier_update(bmain, scene, ptr);
+}
+
+static void rna_DataTransferModifier_verts_data_types_set(struct PointerRNA *ptr, int value)
+{
+       DataTransferModifierData *dtmd = (DataTransferModifierData *)ptr->data;
+
+       dtmd->data_types &= ~DT_TYPE_VERT_ALL;
+       dtmd->data_types |= value;
+}
+
+static void rna_DataTransferModifier_edges_data_types_set(struct PointerRNA *ptr, int value)
+{
+       DataTransferModifierData *dtmd = (DataTransferModifierData *)ptr->data;
+
+       dtmd->data_types &= ~DT_TYPE_EDGE_ALL;
+       dtmd->data_types |= value;
+}
+
+static void rna_DataTransferModifier_loops_data_types_set(struct PointerRNA *ptr, int value)
+{
+       DataTransferModifierData *dtmd = (DataTransferModifierData *)ptr->data;
+
+       dtmd->data_types &= ~DT_TYPE_LOOP_ALL;
+       dtmd->data_types |= value;
+}
+
+static void rna_DataTransferModifier_polys_data_types_set(struct PointerRNA *ptr, int value)
+{
+       DataTransferModifierData *dtmd = (DataTransferModifierData *)ptr->data;
+
+       dtmd->data_types &= ~DT_TYPE_POLY_ALL;
+       dtmd->data_types |= value;
+}
+
+static EnumPropertyItem *rna_DataTransferModifier_layers_select_src_itemf(bContext *C, PointerRNA *ptr, PropertyRNA *prop, bool *r_free)
+{
+       DataTransferModifierData *dtmd = (DataTransferModifierData *)ptr->data;
+       EnumPropertyItem *item = NULL, tmp_item = {0};
+       int totitem = 0;
+
+       if (!C) {  /* needed for docs and i18n tools */
+               return rna_enum_dt_layers_select_src_items;
+       }
+
+       /* No active here! */
+       RNA_enum_items_add_value(&item, &totitem, rna_enum_dt_layers_select_src_items, DT_LAYERS_ALL_SRC);
+
+       if (STREQ(RNA_property_identifier(prop), "layers_vgroup_select_src")) {
+               Object *ob_src = dtmd->ob_source;
+
+#if 0  /* XXX Don't think we want this in modifier version... */
+               if (BKE_object_pose_armature_get(ob_src)) {
+                       RNA_enum_items_add_value(&item, &totitem, rna_enum_dt_layers_select_src_items, DT_LAYERS_VGROUP_SRC_BONE_SELECT);
+                       RNA_enum_items_add_value(&item, &totitem, rna_enum_dt_layers_select_src_items, DT_LAYERS_VGROUP_SRC_BONE_DEFORM);
+               }
+#endif
+
+               if (ob_src) {
+                       bDeformGroup *dg;
+                       int i;
+
+                       RNA_enum_item_add_separator(&item, &totitem);
+
+                       for (i = 0, dg = ob_src->defbase.first; dg; i++, dg = dg->next) {
+                               tmp_item.value = i;
+                               tmp_item.identifier = tmp_item.name = dg->name;
+                               RNA_enum_item_add(&item, &totitem, &tmp_item);
+                       }
+               }
+       }
+       else if (STREQ(RNA_property_identifier(prop), "layers_shapekey_select_src")) {
+               /* TODO */
+       }
+       else if (STREQ(RNA_property_identifier(prop), "layers_uv_select_src")) {
+               Object *ob_src = dtmd->ob_source;
+
+               if (ob_src) {
+                       DerivedMesh *dm_src;
+                       CustomData *pdata;
+                       int num_data, i;
+
+                       /* XXX Is this OK? */
+                       dm_src = mesh_get_derived_final(dtmd->modifier.scene, ob_src, CD_MASK_BAREMESH | CD_MTEXPOLY);
+                       pdata = dm_src->getPolyDataLayout(dm_src);
+                       num_data = CustomData_number_of_layers(pdata, CD_MTEXPOLY);
+
+                       RNA_enum_item_add_separator(&item, &totitem);
+
+                       for (i = 0; i < num_data; i++) {
+                               tmp_item.value = i;
+                               tmp_item.identifier = tmp_item.name = CustomData_get_layer_name(pdata, CD_MTEXPOLY, i);
+                               RNA_enum_item_add(&item, &totitem, &tmp_item);
+                       }
+               }
+       }
+       else if (STREQ(RNA_property_identifier(prop), "layers_vcol_select_src")) {
+               Object *ob_src = dtmd->ob_source;
+
+               if (ob_src) {
+                       DerivedMesh *dm_src;
+                       CustomData *ldata;
+                       int num_data, i;
+
+                       /* XXX Is this OK? */
+                       dm_src = mesh_get_derived_final(dtmd->modifier.scene, ob_src, CD_MASK_BAREMESH | CD_MLOOPCOL);
+                       ldata = dm_src->getLoopDataLayout(dm_src);
+                       num_data = CustomData_number_of_layers(ldata, CD_MLOOPCOL);
+
+                       RNA_enum_item_add_separator(&item, &totitem);
+
+                       for (i = 0; i < num_data; i++) {
+                               tmp_item.value = i;
+                               tmp_item.identifier = tmp_item.name = CustomData_get_layer_name(ldata, CD_MLOOPCOL, i);
+                               RNA_enum_item_add(&item, &totitem, &tmp_item);
+                       }
+               }
+       }
+
+       RNA_enum_item_end(&item, &totitem);
+       *r_free = true;
+
+       return item;
+}
+
+static EnumPropertyItem *rna_DataTransferModifier_layers_select_dst_itemf(bContext *C, PointerRNA *ptr, PropertyRNA *prop, bool *r_free)
+{
+       DataTransferModifierData *dtmd = (DataTransferModifierData *)ptr->data;
+       EnumPropertyItem *item = NULL, tmp_item = {0};
+       int totitem = 0;
+
+       if (!C) {  /* needed for docs and i18n tools */
+               return rna_enum_dt_layers_select_dst_items;
+       }
+
+       /* No active here! */
+       RNA_enum_items_add_value(&item, &totitem, rna_enum_dt_layers_select_dst_items, DT_LAYERS_NAME_DST);
+       RNA_enum_items_add_value(&item, &totitem, rna_enum_dt_layers_select_dst_items, DT_LAYERS_INDEX_DST);
+
+       if (STREQ(RNA_property_identifier(prop), "layers_vgroup_select_dst")) {
+               /* Only list destination layers if we have a single source! */
+               if (dtmd->layers_select_src[DT_MULTILAYER_INDEX_MDEFORMVERT] >= 0) {
+                       Object *ob_dst = CTX_data_active_object(C); /* XXX Is this OK? */
+
+                       if (ob_dst) {
+                               bDeformGroup *dg;
+                               int i;
+
+                               RNA_enum_item_add_separator(&item, &totitem);
+
+                               for (i = 0, dg = ob_dst->defbase.first; dg; i++, dg = dg->next) {
+                                       tmp_item.value = i;
+                                       tmp_item.identifier = tmp_item.name = dg->name;
+                                       RNA_enum_item_add(&item, &totitem, &tmp_item);
+                               }
+                       }
+               }
+       }
+       else if (STREQ(RNA_property_identifier(prop), "layers_shapekey_select_dst")) {
+               /* TODO */
+       }
+       else if (STREQ(RNA_property_identifier(prop), "layers_uv_select_dst")) {
+               /* Only list destination layers if we have a single source! */
+               if (dtmd->layers_select_src[DT_MULTILAYER_INDEX_UV] >= 0) {
+                       Object *ob_dst = CTX_data_active_object(C); /* XXX Is this OK? */
+
+                       if (ob_dst && ob_dst->data) {
+                               Mesh *me_dst;
+                               CustomData *pdata;
+                               int num_data, i;
+
+                               me_dst = ob_dst->data;
+                               pdata = &me_dst->pdata;
+                               num_data = CustomData_number_of_layers(pdata, CD_MTEXPOLY);
+
+                               RNA_enum_item_add_separator(&item, &totitem);
+
+                               for (i = 0; i < num_data; i++) {
+                                       tmp_item.value = i;
+                                       tmp_item.identifier = tmp_item.name = CustomData_get_layer_name(pdata, CD_MTEXPOLY, i);
+                                       RNA_enum_item_add(&item, &totitem, &tmp_item);
+                               }
+                       }
+               }
+       }
+       else if (STREQ(RNA_property_identifier(prop), "layers_vcol_select_dst")) {
+               /* Only list destination layers if we have a single source! */
+               if (dtmd->layers_select_src[DT_MULTILAYER_INDEX_VCOL] >= 0) {
+                       Object *ob_dst = CTX_data_active_object(C); /* XXX Is this OK? */
+
+                       if (ob_dst && ob_dst->data) {
+                               Mesh *me_dst;
+                               CustomData *ldata;
+                               int num_data, i;
+
+                               me_dst = ob_dst->data;
+                               ldata = &me_dst->ldata;
+                               num_data = CustomData_number_of_layers(ldata, CD_MLOOPCOL);
+
+                               RNA_enum_item_add_separator(&item, &totitem);
+
+                               for (i = 0; i < num_data; i++) {
+                                       tmp_item.value = i;
+                                       tmp_item.identifier = tmp_item.name = CustomData_get_layer_name(ldata, CD_MLOOPCOL, i);
+                                       RNA_enum_item_add(&item, &totitem, &tmp_item);
+                               }
+                       }
+               }
+       }
+
+
+       RNA_enum_item_end(&item, &totitem);
+       *r_free = true;
+
+       return item;
 }
 
-static void rna_BevelModifier_angle_limit_set(PointerRNA *ptr, float value)
+static EnumPropertyItem *rna_DataTransferModifier_mix_mode_itemf(bContext *C, PointerRNA *ptr, PropertyRNA *UNUSED(prop), bool *r_free)
 {
-       BevelModifierData *md = (BevelModifierData *)ptr->data;
-       value = RAD2DEGF(value);
-       CLAMP(value, 0.0f, 180.0f);
-       md->bevel_angle = (int)value;
+       DataTransferModifierData *dtmd = (DataTransferModifierData *)ptr->data;
+       EnumPropertyItem *item = NULL;
+       int totitem = 0;
+
+       bool support_advanced_mixing, support_threshold;
+
+       if (!C) {  /* needed for docs and i18n tools */
+               return rna_enum_dt_mix_mode_items;
+       }
+
+       RNA_enum_items_add_value(&item, &totitem, rna_enum_dt_mix_mode_items, CDT_MIX_TRANSFER);
+
+       BKE_object_data_transfer_get_dttypes_capacity(dtmd->data_types, &support_advanced_mixing, &support_threshold);
+
+       if (support_threshold) {
+               RNA_enum_items_add_value(&item, &totitem, rna_enum_dt_mix_mode_items, CDT_MIX_REPLACE_ABOVE_THRESHOLD);
+               RNA_enum_items_add_value(&item, &totitem, rna_enum_dt_mix_mode_items, CDT_MIX_REPLACE_BELOW_THRESHOLD);
+       }
+
+       if (support_advanced_mixing) {
+               RNA_enum_item_add_separator(&item, &totitem);
+               RNA_enum_items_add_value(&item, &totitem, rna_enum_dt_mix_mode_items, CDT_MIX_MIX);
+               RNA_enum_items_add_value(&item, &totitem, rna_enum_dt_mix_mode_items, CDT_MIX_ADD);
+               RNA_enum_items_add_value(&item, &totitem, rna_enum_dt_mix_mode_items, CDT_MIX_SUB);
+               RNA_enum_items_add_value(&item, &totitem, rna_enum_dt_mix_mode_items, CDT_MIX_MUL);
+       }
+
+       RNA_enum_item_end(&item, &totitem);
+       *r_free = true;
+
+       return item;
 }
 
-static void rna_BevelModifier_defgrp_name_set(PointerRNA *ptr, const char *value)
+static void rna_CorrectiveSmoothModifier_update(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
-       BevelModifierData *md = (BevelModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, md->defgrp_name, sizeof(md->defgrp_name));
+       CorrectiveSmoothModifierData *csmd = (CorrectiveSmoothModifierData *)ptr->data;
+
+       MEM_SAFE_FREE(csmd->delta_cache);
+
+       rna_Modifier_update(bmain, scene, ptr);
 }
 
-static void rna_UVWarpModifier_vgroup_set(PointerRNA *ptr, const char *value)
+static void rna_CorrectiveSmoothModifier_rest_source_update(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
-       UVWarpModifierData *umd = (UVWarpModifierData *)ptr->data;
-       rna_object_vgroup_name_set(ptr, value, umd->vgroup_name, sizeof(umd->vgroup_name));
+       CorrectiveSmoothModifierData *csmd = (CorrectiveSmoothModifierData *)ptr->data;
+
+       if (csmd->rest_source != MOD_CORRECTIVESMOOTH_RESTSOURCE_BIND) {
+               MEM_SAFE_FREE(csmd->bind_coords);
+               csmd->bind_coords_num = 0;
+       }
+
+       rna_CorrectiveSmoothModifier_update(bmain, scene, ptr);
 }
 
-static void rna_UVWarpModifier_uvlayer_set(PointerRNA *ptr, const char *value)
+static int rna_CorrectiveSmoothModifier_is_bind_get(PointerRNA *ptr)
 {
-       UVWarpModifierData *umd = (UVWarpModifierData *)ptr->data;
-       rna_object_uvlayer_name_set(ptr, value, umd->uvlayer_name, sizeof(umd->uvlayer_name));
+       CorrectiveSmoothModifierData *csmd = (CorrectiveSmoothModifierData *)ptr->data;
+       return (csmd->bind_coords != NULL);
 }
 
 #else
@@ -815,6 +1155,13 @@ static void rna_def_modifier_subsurf(BlenderRNA *brna)
        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");
+
+#ifdef WITH_OPENSUBDIV
+       prop = RNA_def_property(srna, "use_opensubdiv", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "use_opensubdiv", 1);
+       RNA_def_property_ui_text(prop, "Use OpenSubdiv", "Use OpenSubdiv for the subdivisions (viewport only)");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+#endif
 }
 
 static void rna_def_modifier_generic_map_info(StructRNA *srna)
@@ -844,7 +1191,7 @@ static void rna_def_modifier_generic_map_info(StructRNA *srna)
        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 Map", "UV map name");
-       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_MappingInfo_uvlayer_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_MappingInfoModifier_uvlayer_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "texture_coords_object", PROP_POINTER, PROP_NONE);
@@ -859,18 +1206,6 @@ 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");
@@ -893,9 +1228,9 @@ static void rna_def_modifier_warp(BlenderRNA *brna)
        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_enum_items(prop, modifier_warp_falloff_items);
        RNA_def_property_ui_text(prop, "Falloff Type", "");
-       RNA_def_property_translation_context(prop, BLF_I18NCONTEXT_ID_CURVE); /* Abusing id_curve :/ */
+       RNA_def_property_translation_context(prop, BLT_I18NCONTEXT_ID_CURVE); /* Abusing id_curve :/ */
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "falloff_radius", PROP_FLOAT, PROP_UNSIGNED | PROP_DISTANCE);
@@ -915,7 +1250,7 @@ static void rna_def_modifier_warp(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 for modulating the deform");
-       RNA_def_property_string_funcs(prop, NULL, NULL, "RNA_WarpModifier_vgroup_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_WarpModifier_defgrp_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        rna_def_modifier_generic_map_info(srna);
@@ -999,7 +1334,7 @@ static void rna_def_modifier_lattice(BlenderRNA *brna)
        RNA_def_property_string_sdna(prop, NULL, "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_string_funcs(prop, NULL, NULL, "rna_LatticeModifier_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
        
        prop = RNA_def_property(srna, "strength", PROP_FLOAT, PROP_NONE);
@@ -1033,13 +1368,13 @@ static void rna_def_modifier_curve(BlenderRNA *brna)
        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_Curve_object_poll");
        RNA_def_property_flag(prop, PROP_EDITABLE | PROP_ID_SELF_CHECK);
-       RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
+       RNA_def_property_update(prop, 0, "rna_CurveModifier_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",
                                 "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_string_funcs(prop, NULL, NULL, "rna_CurveModifier_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "deform_axis", PROP_ENUM, PROP_NONE);
@@ -1071,8 +1406,13 @@ static void rna_def_modifier_build(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Length", "Total time the build effect requires");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
+       prop = RNA_def_property(srna, "use_reverse", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_BUILD_FLAG_REVERSE);
+       RNA_def_property_ui_text(prop, "Reversed", "Deconstruct the mesh instead of building it");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+       
        prop = RNA_def_property(srna, "use_random_order", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "randomize", 1);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_BUILD_FLAG_RANDOMIZE);
        RNA_def_property_ui_text(prop, "Randomize", "Randomize the faces or edges during build");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
@@ -1136,7 +1476,7 @@ static void rna_def_modifier_mirror(BlenderRNA *brna)
        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);
-       RNA_def_property_ui_text(prop, "Merge Limit", "Distance from axis within which mirrored vertices are merged");
+       RNA_def_property_ui_text(prop, "Merge Limit", "Distance within which mirrored vertices are merged");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "mirror_object", PROP_POINTER, PROP_NONE);
@@ -1170,7 +1510,7 @@ static void rna_def_modifier_decimate(BlenderRNA *brna)
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        /* (mode == MOD_DECIM_MODE_COLLAPSE) */
-       prop = RNA_def_property(srna, "ratio", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "ratio", PROP_FLOAT, PROP_FACTOR);
        RNA_def_property_float_sdna(prop, NULL, "percent");
        RNA_def_property_range(prop, 0, 1);
        RNA_def_property_ui_range(prop, 0, 1, 1, 4);
@@ -1189,7 +1529,7 @@ static void rna_def_modifier_decimate(BlenderRNA *brna)
        prop = RNA_def_property(srna, "angle_limit", PROP_FLOAT, PROP_ANGLE);
        RNA_def_property_float_sdna(prop, NULL, "angle");
        RNA_def_property_range(prop, 0, DEG2RAD(180));
-       RNA_def_property_ui_range(prop, 0, DEG2RAD(180), 100, 2);
+       RNA_def_property_ui_range(prop, 0, DEG2RAD(180), 10, 2);
        RNA_def_property_ui_text(prop, "Angle Limit", "Only dissolve angles below this (planar only)");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
@@ -1197,7 +1537,7 @@ static void rna_def_modifier_decimate(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 (collapse only)");
-       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_DecimateModifier_vgroup_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_DecimateModifier_defgrp_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "invert_vertex_group", PROP_BOOLEAN, PROP_NONE);
@@ -1209,6 +1549,24 @@ static void rna_def_modifier_decimate(BlenderRNA *brna)
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_DECIM_FLAG_TRIANGULATE);
        RNA_def_property_ui_text(prop, "Triangulate", "Keep triangulated faces resulting from decimation (collapse only)");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "use_symmetry", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_DECIM_FLAG_SYMMETRY);
+       RNA_def_property_ui_text(prop, "Symmetry", "Maintain symmetry on an axis");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "symmetry_axis", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "symmetry_axis");
+       RNA_def_property_enum_items(prop, rna_enum_object_axis_unsigned_items);
+       RNA_def_property_ui_text(prop, "Axis", "Axis of symmetry");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "vertex_group_factor", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "defgrp_factor");
+       RNA_def_property_range(prop, 0, 1000);
+       RNA_def_property_ui_range(prop, 0, 10, 1, 4);
+       RNA_def_property_ui_text(prop, "Factor", "Vertex group strength");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
        /* end collapse-only option */
 
        /* (mode == MOD_DECIM_MODE_DISSOLVE) */
@@ -1219,7 +1577,7 @@ static void rna_def_modifier_decimate(BlenderRNA *brna)
 
        prop = RNA_def_property(srna, "delimit", PROP_ENUM, PROP_NONE);
        RNA_def_property_flag(prop, PROP_ENUM_FLAG); /* important to run before default set */
-       RNA_def_property_enum_items(prop, mesh_delimit_mode_items);
+       RNA_def_property_enum_items(prop, rna_enum_mesh_delimit_mode_items);
        RNA_def_property_ui_text(prop, "Delimit", "Limit merging geometry");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
@@ -1327,7 +1685,7 @@ static void rna_def_modifier_wave(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 for modulating the wave");
-       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_WaveModifier_vgroup_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_WaveModifier_defgrp_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "speed", PROP_FLOAT, PROP_NONE);
@@ -1401,7 +1759,7 @@ static void rna_def_modifier_armature(BlenderRNA *brna)
        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_string_funcs(prop, NULL, NULL, "rna_ArmatureModifier_defgrp_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "invert_vertex_group", PROP_BOOLEAN, PROP_NONE);
@@ -1420,20 +1778,39 @@ static void rna_def_modifier_hook(BlenderRNA *brna)
        RNA_def_struct_sdna(srna, "HookModifierData");
        RNA_def_struct_ui_icon(srna, ICON_HOOK);
 
-       prop = RNA_def_property(srna, "falloff", PROP_FLOAT, PROP_DISTANCE);
+       prop = RNA_def_property(srna, "strength", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "force");
+       RNA_def_property_range(prop, 0, 1);
+       RNA_def_property_ui_text(prop, "Strength",  "Relative force of the hook");
+       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, modifier_warp_falloff_items);  /* share the enum */
+       RNA_def_property_ui_text(prop, "Falloff Type", "");
+       RNA_def_property_translation_context(prop, BLT_I18NCONTEXT_ID_CURVE); /* Abusing id_curve :/ */
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "falloff_radius", PROP_FLOAT, PROP_DISTANCE);
+       RNA_def_property_float_sdna(prop, NULL, "falloff");
        RNA_def_property_range(prop, 0, FLT_MAX);
        RNA_def_property_ui_range(prop, 0, 100, 100, 2);
-       RNA_def_property_ui_text(prop, "Falloff",  "If not zero, the distance from the hook where influence ends");
+       RNA_def_property_ui_text(prop, "Radius",  "If not zero, the distance from the hook where influence ends");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop = RNA_def_property(srna, "force", PROP_FLOAT, PROP_NONE);
-       RNA_def_property_range(prop, 0, 1);
-       RNA_def_property_ui_text(prop, "Force",  "Relative force of the hook");
+       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, "center", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "cent");
+       RNA_def_property_ui_text(prop, "Hook Center", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "object", PROP_POINTER, PROP_NONE);
        RNA_def_property_ui_text(prop, "Object", "Parent Object for hook, also recalculates and clears offset");
        RNA_def_property_flag(prop, PROP_EDITABLE | PROP_ID_SELF_CHECK);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_HookModifier_object_set", NULL, NULL);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
        
        prop = RNA_def_property(srna, "subtarget", PROP_STRING, PROP_NONE);
@@ -1442,11 +1819,16 @@ static void rna_def_modifier_hook(BlenderRNA *brna)
                                 "Name of Parent Bone for hook (if applicable), also recalculates and clears offset");
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 
+       prop = RNA_def_property(srna, "use_falloff_uniform", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_HOOK_UNIFORM_SPACE);
+       RNA_def_property_ui_text(prop, "Uniform Falloff", "Compensate for non-uniform object scale");
+       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, "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_string_funcs(prop, NULL, NULL, "rna_HookModifier_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 }
 
@@ -1543,9 +1925,9 @@ 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_Curve_object_poll");
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_ArrayModifier_curve_ob_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");
+       RNA_def_property_update(prop, 0, "rna_ArrayModifier_dependency_update");
 
        /* Offset parameters */
        prop = RNA_def_property(srna, "use_constant_offset", PROP_BOOLEAN, PROP_NONE);
@@ -1627,17 +2009,9 @@ static void rna_def_modifier_edgesplit(BlenderRNA *brna)
        RNA_def_struct_sdna(srna, "EdgeSplitModifierData");
        RNA_def_struct_ui_icon(srna, ICON_MOD_EDGESPLIT);
 
-#if 1 /* expose as radians */
        prop = RNA_def_property(srna, "split_angle", PROP_FLOAT, PROP_ANGLE);
-       RNA_def_property_float_funcs(prop, "rna_EdgeSplitModifier_split_angle_get",
-                                    "rna_EdgeSplitModifier_split_angle_set", NULL);
-       RNA_def_property_range(prop, 0, DEG2RAD(180));
-       RNA_def_property_ui_range(prop, 0, DEG2RAD(180), 100, 2);
-#else
-       prop = RNA_def_property(srna, "split_angle", PROP_FLOAT, PROP_NONE);
-       RNA_def_property_range(prop, 0, 180);
-       RNA_def_property_ui_range(prop, 0, 180, 100, 2);
-#endif
+       RNA_def_property_range(prop, 0.0f, DEG2RADF(180.0f));
+       RNA_def_property_ui_range(prop, 0.0f, DEG2RADF(180.0f), 10, 2);
        RNA_def_property_ui_text(prop, "Split Angle", "Angle above which to split edges");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
@@ -1662,9 +2036,11 @@ static void rna_def_modifier_displace(BlenderRNA *brna)
                {MOD_DISP_DIR_Y, "Y", 0, "Y", "Use the texture's intensity value to displace in the Y direction"},
                {MOD_DISP_DIR_Z, "Z", 0, "Z", "Use the texture's intensity value to displace in the Z direction"},
                {MOD_DISP_DIR_NOR, "NORMAL", 0, "Normal",
-                                  "Use the texture's intensity value to displace in the normal direction"},
+                "Use the texture's intensity value to displace along the vertex normal"},
+               {MOD_DISP_DIR_CLNOR, "CUSTOM_NORMAL", 0, "Custom Normal",
+                "Use the texture's intensity value to displace along the (averaged) custom normal (falls back to vertex)"},
                {MOD_DISP_DIR_RGB_XYZ, "RGB_TO_XYZ", 0, "RGB to XYZ",
-                                      "Use the texture's RGB values to displace the mesh in the XYZ direction"},
+                "Use the texture's RGB values to displace the mesh in the XYZ direction"},
                {0, NULL, 0, NULL, NULL}
        };
 
@@ -1677,7 +2053,7 @@ static void rna_def_modifier_displace(BlenderRNA *brna)
        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_DisplaceModifier_vgroup_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_DisplaceModifier_defgrp_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "mid_level", PROP_FLOAT, PROP_FACTOR);
@@ -1714,14 +2090,14 @@ static void rna_def_modifier_uvproject(BlenderRNA *brna)
        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 Map", "UV map name");
-       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_UVProjectModifier_uvlayer_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_UVProjectModifier_uvlayer_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        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);
+       RNA_def_property_range(prop, 1, MOD_UVPROJECT_MAXPROJECTORS);
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "projectors", PROP_COLLECTION, PROP_NONE);
@@ -1737,6 +2113,7 @@ static void rna_def_modifier_uvproject(BlenderRNA *brna)
 
        prop = RNA_def_property(srna, "aspect_x", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "aspectx");
+       RNA_def_property_flag(prop, PROP_PROPORTIONAL);
        RNA_def_property_range(prop, 1, FLT_MAX);
        RNA_def_property_ui_range(prop, 1, 1000, 1, 3);
        RNA_def_property_ui_text(prop, "Horizontal Aspect Ratio", "");
@@ -1744,6 +2121,7 @@ static void rna_def_modifier_uvproject(BlenderRNA *brna)
 
        prop = RNA_def_property(srna, "aspect_y", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "aspecty");
+       RNA_def_property_flag(prop, PROP_PROPORTIONAL);
        RNA_def_property_range(prop, 1, FLT_MAX);
        RNA_def_property_ui_range(prop, 1, 1000, 1, 3);
        RNA_def_property_ui_text(prop, "Vertical Aspect Ratio", "");
@@ -1751,6 +2129,7 @@ static void rna_def_modifier_uvproject(BlenderRNA *brna)
        
        prop = RNA_def_property(srna, "scale_x", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "scalex");
+       RNA_def_property_flag(prop, PROP_PROPORTIONAL);
        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", "");
@@ -1758,6 +2137,7 @@ static void rna_def_modifier_uvproject(BlenderRNA *brna)
 
        prop = RNA_def_property(srna, "scale_y", PROP_FLOAT, PROP_NONE);
        RNA_def_property_float_sdna(prop, NULL, "scaley");
+       RNA_def_property_flag(prop, PROP_PROPORTIONAL);
        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", "");
@@ -1807,24 +2187,108 @@ 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, 1, 3);
-       RNA_def_property_ui_text(prop, "Factor", "Strength of modifier effect");
-       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+       RNA_def_property_ui_range(prop, -10, 10, 1, 3);
+       RNA_def_property_ui_text(prop, "Factor", "Strength of modifier effect");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       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, -1);
+       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",
+                                "Name of Vertex Group which determines influence of modifier per point");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_SmoothModifier_defgrp_name_set");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+}
+
+
+static void rna_def_modifier_correctivesmooth(BlenderRNA *brna)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+
+       static EnumPropertyItem modifier_smooth_type_items[] = {
+               {MOD_CORRECTIVESMOOTH_SMOOTH_SIMPLE, "SIMPLE", 0, "Simple",
+                "Use the average of adjacent edge-vertices"},
+               {MOD_CORRECTIVESMOOTH_SMOOTH_LENGTH_WEIGHT, "LENGTH_WEIGHTED", 0, "Length Weight",
+                "Use the average of adjacent edge-vertices weighted by their length"},
+               {0, NULL, 0, NULL, NULL}
+       };
+
+       static EnumPropertyItem modifier_rest_source_items[] = {
+               {MOD_CORRECTIVESMOOTH_RESTSOURCE_ORCO, "ORCO", 0, "Original Coords",
+                "Use base mesh vert coords as the rest position"},
+               {MOD_CORRECTIVESMOOTH_RESTSOURCE_BIND, "BIND", 0, "Bind Coords",
+                "Use bind vert coords for rest position"},
+               {0, NULL, 0, NULL, NULL}
+       };
+
+       srna = RNA_def_struct(brna, "CorrectiveSmoothModifier", "Modifier");
+       RNA_def_struct_ui_text(srna, "Corrective Smooth Modifier", "Correct distortion caused by deformation");
+       RNA_def_struct_sdna(srna, "CorrectiveSmoothModifierData");
+       RNA_def_struct_ui_icon(srna, ICON_MOD_SMOOTH);
+
+       prop = RNA_def_property(srna, "factor", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "lambda");
+       RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);
+       RNA_def_property_ui_range(prop, 0.0, 1.0, 5, 3);
+       RNA_def_property_ui_text(prop, "Lambda Factor", "Smooth factor effect");
+       RNA_def_property_update(prop, 0, "rna_CorrectiveSmoothModifier_update");
 
        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, -1);
+       RNA_def_property_ui_range(prop, 0, 200, 1, -1);
        RNA_def_property_ui_text(prop, "Repeat", "");
-       RNA_def_property_update(prop, 0, "rna_Modifier_update");
-       
+       RNA_def_property_update(prop, 0, "rna_CorrectiveSmoothModifier_update");
+
+       prop = RNA_def_property(srna, "rest_source", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "rest_source");
+       RNA_def_property_enum_items(prop, modifier_rest_source_items);
+       RNA_def_property_ui_text(prop, "Rest Source", "Select the source of rest positions");
+       RNA_def_property_update(prop, 0, "rna_CorrectiveSmoothModifier_rest_source_update");
+
+       prop = RNA_def_property(srna, "smooth_type", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "smooth_type");
+       RNA_def_property_enum_items(prop, modifier_smooth_type_items);
+       RNA_def_property_ui_text(prop, "Smooth Type", "Method used for smoothing");
+       RNA_def_property_update(prop, 0, "rna_CorrectiveSmoothModifier_update");
+
+       prop = RNA_def_property(srna, "invert_vertex_group", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_CORRECTIVESMOOTH_INVERT_VGROUP);
+       RNA_def_property_ui_text(prop, "Invert", "Invert vertex group influence");
+       RNA_def_property_update(prop, 0, "rna_CorrectiveSmoothModifier_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_SmoothModifier_vgroup_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_CorrectiveSmoothModifier_defgrp_name_set");
+       RNA_def_property_update(prop, 0, "rna_CorrectiveSmoothModifier_update");
+
+       prop = RNA_def_property(srna, "is_bind", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_ui_text(prop, "Bind current shape", "");
+       RNA_def_property_boolean_funcs(prop, "rna_CorrectiveSmoothModifier_is_bind_get", NULL);
+       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "use_only_smooth", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_CORRECTIVESMOOTH_ONLY_SMOOTH);
+       RNA_def_property_ui_text(prop, "Only Smooth",
+                                "Apply smoothing without reconstructing the surface");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "use_pin_boundary", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_CORRECTIVESMOOTH_PIN_BOUNDARY);
+       RNA_def_property_ui_text(prop, "Pin Boundaries",
+                                "Excludes boundary vertices from being smoothed");
+       RNA_def_property_update(prop, 0, "rna_CorrectiveSmoothModifier_update");
 }
 
+
 static void rna_def_modifier_laplaciansmooth(BlenderRNA *brna)
 {
        StructRNA *srna;
@@ -1884,7 +2348,7 @@ static void rna_def_modifier_laplaciansmooth(BlenderRNA *brna)
        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_LaplacianSmoothModifier_vgroup_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_LaplacianSmoothModifier_defgrp_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 }
 
@@ -1967,7 +2431,7 @@ static void rna_def_modifier_cast(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_string_funcs(prop, NULL, NULL, "rna_CastModifier_vgroup_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_CastModifier_defgrp_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 }
 
@@ -1990,7 +2454,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, NULL);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_MeshDeformModifier_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");
        
@@ -2007,7 +2471,7 @@ static void rna_def_modifier_meshdeform(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_string_funcs(prop, NULL, NULL, "rna_MeshDeformModifier_vgroup_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_MeshDeformModifier_defgrp_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "precision", PROP_INT, PROP_NONE);
@@ -2066,6 +2530,7 @@ static void rna_def_modifier_particleinstance(BlenderRNA *brna)
 
        prop = RNA_def_property(srna, "object", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "ob");
+       RNA_def_property_pointer_funcs(prop, NULL, NULL, NULL, "rna_Mesh_object_poll");
        RNA_def_property_ui_text(prop, "Object", "Object that has the particle system");
        RNA_def_property_flag(prop, PROP_EDITABLE | PROP_ID_SELF_CHECK);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
@@ -2207,9 +2672,29 @@ static void rna_def_modifier_cloth(BlenderRNA *brna)
        RNA_def_property_pointer_sdna(prop, NULL, "coll_parms");
        RNA_def_property_ui_text(prop, "Cloth Collision Settings", "");
        
+       prop = RNA_def_property(srna, "solver_result", PROP_POINTER, PROP_NONE);
+       RNA_def_property_struct_type(prop, "ClothSolverResult");
+       RNA_def_property_pointer_sdna(prop, NULL, "solver_result");
+       RNA_def_property_ui_text(prop, "Solver Result", "");
+       
        prop = RNA_def_property(srna, "point_cache", PROP_POINTER, PROP_NONE);
        RNA_def_property_flag(prop, PROP_NEVER_NULL);
        RNA_def_property_ui_text(prop, "Point Cache", "");
+
+       prop = RNA_def_property(srna, "hair_grid_min", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "hair_grid_min");
+       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+       RNA_def_property_ui_text(prop, "Hair Grid Minimum", "");
+
+       prop = RNA_def_property(srna, "hair_grid_max", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "hair_grid_max");
+       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+       RNA_def_property_ui_text(prop, "Hair Grid Maximum", "");
+
+       prop = RNA_def_property(srna, "hair_grid_resolution", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "hair_grid_res");
+       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+       RNA_def_property_ui_text(prop, "Hair Grid Resolution", "");
 }
 
 static void rna_def_modifier_smoke(BlenderRNA *brna)
@@ -2271,7 +2756,7 @@ static void rna_def_modifier_dynamic_paint(BlenderRNA *brna)
        prop = RNA_def_property(srna, "ui_type", PROP_ENUM, PROP_NONE);
        RNA_def_property_clear_flag(prop, PROP_ANIMATABLE);
        RNA_def_property_enum_sdna(prop, NULL, "type");
-       RNA_def_property_enum_items(prop, prop_dynamicpaint_type_items);
+       RNA_def_property_enum_items(prop, rna_enum_prop_dynamicpaint_type_items);
        RNA_def_property_ui_text(prop, "Type", "");
 }
 
@@ -2300,19 +2785,27 @@ static void rna_def_modifier_bevel(BlenderRNA *brna)
 
        static EnumPropertyItem prop_limit_method_items[] = {
                {0, "NONE", 0, "None", "Bevel the entire mesh by a constant amount"},
-               {BME_BEVEL_ANGLE, "ANGLE", 0, "Angle", "Only bevel edges with sharp enough angles between faces"},
-               {BME_BEVEL_WEIGHT, "WEIGHT", 0, "Weight",
+               {MOD_BEVEL_ANGLE, "ANGLE", 0, "Angle", "Only bevel edges with sharp enough angles between faces"},
+               {MOD_BEVEL_WEIGHT, "WEIGHT", 0, "Weight",
                                   "Use bevel weights to determine how much bevel is applied in edge mode"},
-               {BME_BEVEL_VGROUP, "VGROUP", 0, "Vertex Group",
-                                  "Use vertex group weights to determine how much bevel is applied in vertex mode"},
+               {MOD_BEVEL_VGROUP, "VGROUP", 0, "Vertex Group",
+                                  "Use vertex group weights to select whether vertex or edge is beveled"},
+               {0, NULL, 0, NULL, NULL}
+       };
+
+       static EnumPropertyItem prop_val_type_items[] = {
+               {MOD_BEVEL_AMT_OFFSET, "OFFSET", 0, "Offset", "Amount is offset of new edges from original"},
+               {MOD_BEVEL_AMT_WIDTH, "WIDTH", 0, "Width", "Amount is width of new face"},
+               {MOD_BEVEL_AMT_DEPTH, "DEPTH", 0, "Depth", "Amount is perpendicular distance from original edge to bevel face"},
+               {MOD_BEVEL_AMT_PERCENT, "PERCENT", 0, "Percent", "Amount is percent of adjacent edge length"},
                {0, NULL, 0, NULL, NULL}
        };
 
        /* TO BE DEPRECATED */
        static EnumPropertyItem prop_edge_weight_method_items[] = {
                {0, "AVERAGE", 0, "Average", ""},
-               {BME_BEVEL_EMIN, "SHARPEST", 0, "Sharpest", ""},
-               {BME_BEVEL_EMAX, "LARGEST", 0, "Largest", ""},
+               {MOD_BEVEL_EMIN, "SHARPEST", 0, "Sharpest", ""},
+               {MOD_BEVEL_EMAX, "LARGEST", 0, "Largest", ""},
                {0, NULL, 0, NULL, NULL}
        };
 
@@ -2324,7 +2817,7 @@ static void rna_def_modifier_bevel(BlenderRNA *brna)
        prop = RNA_def_property(srna, "width", PROP_FLOAT, PROP_DISTANCE);
        RNA_def_property_float_sdna(prop, NULL, "value");
        RNA_def_property_range(prop, 0, FLT_MAX);
-       RNA_def_property_ui_range(prop, 0, 10, 0.1, 4);
+       RNA_def_property_ui_range(prop, 0.0f, 100.0f, 0.1, 4);
        RNA_def_property_ui_text(prop, "Width", "Bevel value/amount");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
@@ -2335,7 +2828,7 @@ static void rna_def_modifier_bevel(BlenderRNA *brna)
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        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_boolean_sdna(prop, NULL, "flags", MOD_BEVEL_VERT);
        RNA_def_property_ui_text(prop, "Only Vertices", "Bevel verts/corners, not edges");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
@@ -2352,22 +2845,13 @@ 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");
 
-#if 1 /* expose as radians */
        prop = RNA_def_property(srna, "angle_limit", PROP_FLOAT, PROP_ANGLE);
-       RNA_def_property_float_funcs(prop, "rna_BevelModifier_angle_limit_get",
-                                    "rna_BevelModifier_angle_limit_set", NULL);
-       RNA_def_property_range(prop, 0, DEG2RAD(180));
-       RNA_def_property_ui_range(prop, 0, DEG2RAD(180), 100, 2);
-#else
-       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);
-#endif
+       RNA_def_property_range(prop, 0.0f, DEG2RADF(180.0f));
+       RNA_def_property_ui_range(prop, 0.0f, DEG2RADF(180.0f), 10, 2);
        RNA_def_property_ui_text(prop, "Angle", "Angle above which to bevel edges");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-#ifdef USE_BM_BEVEL_OP_AS_MOD
        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");
@@ -2375,11 +2859,32 @@ static void rna_def_modifier_bevel(BlenderRNA *brna)
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "use_clamp_overlap", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_negative_sdna(prop, NULL, "flags", BME_BEVEL_OVERLAP_OK);
+       RNA_def_property_boolean_negative_sdna(prop, NULL, "flags", MOD_BEVEL_OVERLAP_OK);
        RNA_def_property_ui_text(prop, "Clamp Overlap", "Clamp the width to avoid overlap");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
-#endif
 
+       prop = RNA_def_property(srna, "offset_type", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "val_flags");
+       RNA_def_property_enum_items(prop, prop_val_type_items);
+       RNA_def_property_ui_text(prop, "Amount Type", "What distance Width measures");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "profile", PROP_FLOAT, PROP_FACTOR);
+       RNA_def_property_range(prop, 0.0f, 1.0f);
+       RNA_def_property_ui_range(prop, 0.15f, 1.0f, 0.05, 2);
+       RNA_def_property_ui_text(prop, "Profile", "The profile shape (0.5 = round)");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "material", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "mat");
+       RNA_def_property_range(prop, -1, SHRT_MAX);
+       RNA_def_property_ui_text(prop, "Material", "Material index of generated faces, -1 for automatic");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "loop_slide", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_negative_sdna(prop, NULL, "flags", MOD_BEVEL_EVEN_WIDTHS);
+       RNA_def_property_ui_text(prop, "Loop Slide", "Prefer sliding along edges to having even widths");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
 }
 
 static void rna_def_modifier_shrinkwrap(BlenderRNA *brna)
@@ -2434,15 +2939,14 @@ static void rna_def_modifier_shrinkwrap(BlenderRNA *brna)
        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_Mesh_object_poll");
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_ShrinkwrapModifier_auxTarget_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, "vertex_group", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "vgroup_name");
        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_string_funcs(prop, NULL, NULL, "rna_ShrinkwrapModifier_vgroup_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "offset", PROP_FLOAT, PROP_NONE);
@@ -2539,7 +3043,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_Armature_object_poll");
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_MaskModifier_ob_arm_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");
 
@@ -2584,29 +3088,25 @@ static void rna_def_modifier_simpledeform(BlenderRNA *brna)
        prop = RNA_def_property(srna, "vertex_group", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "vgroup_name");
        RNA_def_property_ui_text(prop, "Vertex Group", "Vertex group name");
-       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_SimpleDeformModifier_vgroup_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_SimpleDeformModifier_vgroup_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "origin", PROP_POINTER, PROP_NONE);
-       RNA_def_property_ui_text(prop, "Origin", "Origin of modifier space coordinates");
+       RNA_def_property_ui_text(prop, "Origin", "Offset the origin and orientation of the deformation");
        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, "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", "Set 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, 1, 3);
+       RNA_def_property_ui_range(prop, -10.0, 10.0, 1.0, 3);
        RNA_def_property_ui_text(prop, "Factor", "Amount to deform object");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "angle", PROP_FLOAT, PROP_ANGLE);
        RNA_def_property_float_sdna(prop, NULL, "factor");
        RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);
-       RNA_def_property_ui_range(prop, -10, 10, 1, 3);
+       RNA_def_property_float_default(prop, DEG2RADF(45.0f));
+       RNA_def_property_ui_range(prop, DEG2RAD(-360.0), DEG2RAD(360.0), 10.0, 3);
        RNA_def_property_ui_text(prop, "Angle", "Angle of deformation");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
@@ -2716,7 +3216,7 @@ static void rna_def_modifier_solidify(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_string_funcs(prop, NULL, NULL, "rna_SolidifyModifier_vgroup_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_SolidifyModifier_defgrp_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "use_rim", PROP_BOOLEAN, PROP_NONE);
@@ -2747,6 +3247,11 @@ static void rna_def_modifier_solidify(BlenderRNA *brna)
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_SOLIDIFY_FLIP);
        RNA_def_property_ui_text(prop, "Flip Normals", "Invert the face direction");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "use_rim_only", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_SOLIDIFY_NOSHELL);
+       RNA_def_property_ui_text(prop, "Only Rim", "Only add the rim to the original data");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
 }
 
 static void rna_def_modifier_screw(BlenderRNA *brna)
@@ -2797,7 +3302,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, -M_PI * 2, M_PI * 2, 10, -1);
        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");
@@ -2827,6 +3332,16 @@ static void rna_def_modifier_screw(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Smooth Shading", "Output faces with smooth shading rather than flat shaded");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
+       prop = RNA_def_property(srna, "use_stretch_u", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_SCREW_UV_STRETCH_U);
+       RNA_def_property_ui_text(prop, "Stretch U", "Stretch the U coordinates between 0-1 when UV's are present");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "use_stretch_v", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_SCREW_UV_STRETCH_V);
+       RNA_def_property_ui_text(prop, "Stretch V", "Stretch the V coordinates between 0-1 when UV's are present");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
 #if 0
        prop = RNA_def_property(srna, "use_angle_object", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_SCREW_OBJECT_ANGLE);
@@ -2840,13 +3355,6 @@ static void rna_def_modifier_uvwarp(BlenderRNA *brna)
        StructRNA *srna;
        PropertyRNA *prop;
 
-       static EnumPropertyItem uvwarp_axis[] = {
-               {0, "X", 0, "X", ""},
-               {1, "Y", 0, "Y", ""},
-               {2, "Z", 0, "Z", ""},
-               {0, NULL, 0, NULL, NULL}
-       };
-
        srna = RNA_def_struct(brna, "UVWarpModifier", "Modifier");
        RNA_def_struct_ui_text(srna, "UVWarp Modifier", "Add target position to uv coordinates");
        RNA_def_struct_sdna(srna, "UVWarpModifierData");
@@ -2854,13 +3362,13 @@ static void rna_def_modifier_uvwarp(BlenderRNA *brna)
 
        prop = RNA_def_property(srna, "axis_u", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "axis_u");
-       RNA_def_property_enum_items(prop, uvwarp_axis);
+       RNA_def_property_enum_items(prop, rna_enum_object_axis_unsigned_items);
        RNA_def_property_ui_text(prop, "U-Axis", "Pole axis for rotation");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "axis_v", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "axis_v");
-       RNA_def_property_enum_items(prop, uvwarp_axis);
+       RNA_def_property_enum_items(prop, rna_enum_object_axis_unsigned_items);
        RNA_def_property_ui_text(prop, "V-Axis", "Pole axis for rotation");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
@@ -2871,40 +3379,41 @@ static void rna_def_modifier_uvwarp(BlenderRNA *brna)
 
        prop = RNA_def_property(srna, "object_from", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "object_src");
-       RNA_def_property_ui_text(prop, "Target", "Object defining offset");
+       RNA_def_property_ui_text(prop, "Object From", "Object defining offset");
        RNA_def_property_flag(prop, PROP_EDITABLE);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 
        prop = RNA_def_property(srna, "bone_from", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "bone_src");
-       RNA_def_property_ui_text(prop, "Sub-Target", "Bone defining offset");
+       RNA_def_property_ui_text(prop, "Bone From", "Bone defining offset");
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 
        prop = RNA_def_property(srna, "object_to", PROP_POINTER, PROP_NONE);
        RNA_def_property_pointer_sdna(prop, NULL, "object_dst");
-       RNA_def_property_ui_text(prop, "Target", "Object defining offset");
+       RNA_def_property_ui_text(prop, "Object To", "Object defining offset");
        RNA_def_property_flag(prop, PROP_EDITABLE);
        RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
 
        prop = RNA_def_property(srna, "bone_to", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "bone_dst");
-       RNA_def_property_ui_text(prop, "Sub-Target", "Bone defining offset");
+       RNA_def_property_ui_text(prop, "Bone To", "Bone defining offset");
        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, "vgroup_name");
        RNA_def_property_ui_text(prop, "Vertex Group", "Vertex group name");
-       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_UVWarpModifier_vgroup_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_UVWarpModifier_vgroup_name_set");
        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_UVWarpModifier_uvlayer_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_UVWarpModifier_uvlayer_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 }
 
-static void rna_def_modifier_weightvg_mask(BlenderRNA *UNUSED(brna), StructRNA *srna)
+static void rna_def_modifier_weightvg_mask(BlenderRNA *UNUSED(brna), StructRNA *srna,
+                                           const char *mask_vgroup_setter, const char *mask_uvlayer_setter)
 {
        static EnumPropertyItem weightvg_mask_tex_map_items[] = {
                {MOD_DISP_MAP_LOCAL, "LOCAL", 0, "Local", "Use local generated coordinates"},
@@ -2928,7 +3437,7 @@ static void rna_def_modifier_weightvg_mask(BlenderRNA *UNUSED(brna), StructRNA *
 
        PropertyRNA *prop;
 
-       prop = RNA_def_property(srna, "mask_constant", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "mask_constant", PROP_FLOAT, PROP_FACTOR);
        RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);
        RNA_def_property_ui_range(prop, 0.0, 1.0, 1, -1);
        RNA_def_property_ui_text(prop, "Influence", "Global influence of current modifications on vgroup");
@@ -2937,7 +3446,7 @@ static void rna_def_modifier_weightvg_mask(BlenderRNA *UNUSED(brna), StructRNA *
        prop = RNA_def_property(srna, "mask_vertex_group", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "mask_defgrp_name");
        RNA_def_property_ui_text(prop, "Mask VGroup", "Masking vertex group name");
-       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_WeightVGModifier_mask_vgroup_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, mask_vgroup_setter);
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "mask_texture", PROP_POINTER, PROP_NONE);
@@ -2959,7 +3468,7 @@ static void rna_def_modifier_weightvg_mask(BlenderRNA *UNUSED(brna), StructRNA *
        prop = RNA_def_property(srna, "mask_tex_uv_layer", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "mask_tex_uvlayer_name");
        RNA_def_property_ui_text(prop, "UV Map", "UV map name");
-       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_WeightVGModifier_mask_uvlayer_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, mask_uvlayer_setter);
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "mask_tex_map_object", PROP_POINTER, PROP_NONE);
@@ -2997,13 +3506,13 @@ static void rna_def_modifier_weightvgedit(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_string_funcs(prop, NULL, NULL, "rna_WeightVGModifier_vgroup_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_WeightVGEditModifier_defgrp_name_set");
        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, weightvg_edit_falloff_type_items);
        RNA_def_property_ui_text(prop, "Falloff Type", "How weights are mapped to their new values");
-       RNA_def_property_translation_context(prop, BLF_I18NCONTEXT_ID_CURVE); /* Abusing id_curve :/ */
+       RNA_def_property_translation_context(prop, BLT_I18NCONTEXT_ID_CURVE); /* Abusing id_curve :/ */
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "use_add", PROP_BOOLEAN, PROP_NONE);
@@ -3018,7 +3527,7 @@ static void rna_def_modifier_weightvgedit(BlenderRNA *brna)
                                 "from vgroup");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
-       prop = RNA_def_property(srna, "default_weight", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "default_weight", PROP_FLOAT, PROP_FACTOR);
        RNA_def_property_range(prop, 0.0, 1.0f);
        RNA_def_property_ui_range(prop, 0.0, 1.0, 1, -1);
        RNA_def_property_ui_text(prop, "Default Weight", "Default weight a vertex will have if "
@@ -3047,7 +3556,8 @@ static void rna_def_modifier_weightvgedit(BlenderRNA *brna)
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        /* Common masking properties. */
-       rna_def_modifier_weightvg_mask(brna, srna);
+       rna_def_modifier_weightvg_mask(brna, srna, "rna_WeightVGEditModifier_mask_defgrp_name_set",
+                                      "rna_WeightVGEditModifier_mask_tex_uvlayer_name_set");
 }
 
 static void rna_def_modifier_weightvgmix(BlenderRNA *brna)
@@ -3085,13 +3595,13 @@ static void rna_def_modifier_weightvgmix(BlenderRNA *brna)
        prop = RNA_def_property(srna, "vertex_group_a", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "defgrp_name_a");
        RNA_def_property_ui_text(prop, "Vertex Group A", "First vertex group name");
-       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_WeightVGModifier_vgroup_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_WeightVGMixModifier_defgrp_name_a_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "vertex_group_b", PROP_STRING, PROP_NONE);
        RNA_def_property_string_sdna(prop, NULL, "defgrp_name_b");
        RNA_def_property_ui_text(prop, "Vertex Group B", "Second vertex group name");
-       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_WeightVGMixModifier_vgroup2_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_WeightVGMixModifier_defgrp_name_b_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "default_weight_a", PROP_FLOAT, PROP_NONE);
@@ -3120,7 +3630,8 @@ static void rna_def_modifier_weightvgmix(BlenderRNA *brna)
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        /* Common masking properties. */
-       rna_def_modifier_weightvg_mask(brna, srna);
+       rna_def_modifier_weightvg_mask(brna, srna, "rna_WeightVGMixModifier_mask_defgrp_name_set",
+                                      "rna_WeightVGMixModifier_mask_tex_uvlayer_name_set");
 }
 
 static void rna_def_modifier_weightvgproximity(BlenderRNA *brna)
@@ -3167,7 +3678,7 @@ static void rna_def_modifier_weightvgproximity(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_string_funcs(prop, NULL, NULL, "rna_WeightVGModifier_vgroup_set");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_WeightVGProximityModifier_defgrp_name_set");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "proximity_mode", PROP_ENUM, PROP_NONE);
@@ -3207,11 +3718,12 @@ static void rna_def_modifier_weightvgproximity(BlenderRNA *brna)
        prop = RNA_def_property(srna, "falloff_type", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_items(prop, weightvg_proximity_falloff_type_items);
        RNA_def_property_ui_text(prop, "Falloff Type", "How weights are mapped to their new values");
-       RNA_def_property_translation_context(prop, BLF_I18NCONTEXT_ID_CURVE); /* Abusing id_curve :/ */
+       RNA_def_property_translation_context(prop, BLT_I18NCONTEXT_ID_CURVE); /* Abusing id_curve :/ */
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        /* Common masking properties. */
-       rna_def_modifier_weightvg_mask(brna, srna);
+       rna_def_modifier_weightvg_mask(brna, srna, "rna_WeightVGProximityModifier_mask_defgrp_name_set",
+                                      "rna_WeightVGProximityModifier_mask_tex_uvlayer_name_set");
 }
 
 static void rna_def_modifier_remesh(BlenderRNA *brna)
@@ -3469,7 +3981,7 @@ static void rna_def_modifier_skin(BlenderRNA *brna)
        RNA_def_struct_sdna(srna, "SkinModifierData");
        RNA_def_struct_ui_icon(srna, ICON_MOD_SKIN);
 
-       prop = RNA_def_property(srna, "branch_smoothing", PROP_FLOAT, PROP_NONE);
+       prop = RNA_def_property(srna, "branch_smoothing", PROP_FLOAT, PROP_FACTOR);
        RNA_def_property_ui_text(prop, "Branch Smoothing", "Smooth complex geometry around branches");
        RNA_def_property_ui_range(prop, 0, 1, 1, -1);
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
@@ -3505,9 +4017,16 @@ static void rna_def_modifier_triangulate(BlenderRNA *brna)
        RNA_def_struct_sdna(srna, "TriangulateModifierData");
        RNA_def_struct_ui_icon(srna, ICON_MOD_TRIANGULATE);
 
-       prop = RNA_def_property(srna, "use_beauty", PROP_BOOLEAN, PROP_NONE);
-       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_TRIANGULATE_BEAUTY);
-       RNA_def_property_ui_text(prop, "Beauty Subdivide", "Subdivide across shortest diagonal");
+       prop = RNA_def_property(srna, "quad_method", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "quad_method");
+       RNA_def_property_enum_items(prop, rna_enum_modifier_triangulate_quad_method_items);
+       RNA_def_property_ui_text(prop, "Quad Method", "Method for splitting the quads into triangles");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "ngon_method", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_sdna(prop, NULL, "ngon_method");
+       RNA_def_property_enum_items(prop, rna_enum_modifier_triangulate_ngon_method_items);
+       RNA_def_property_ui_text(prop, "Polygon Method", "Method for splitting the polygons into triangles");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 }
 
@@ -3611,13 +4130,13 @@ static void rna_def_modifier_meshcache(BlenderRNA *brna)
        /* Axis Conversion */
        prop = RNA_def_property(srna, "forward_axis", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "forward_axis");
-       RNA_def_property_enum_items(prop, object_axis_items);
+       RNA_def_property_enum_items(prop, rna_enum_object_axis_items);
        RNA_def_property_ui_text(prop, "Forward", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
        prop = RNA_def_property(srna, "up_axis", PROP_ENUM, PROP_NONE);
        RNA_def_property_enum_sdna(prop, NULL, "up_axis");
-       RNA_def_property_enum_items(prop, object_axis_items);
+       RNA_def_property_enum_items(prop, rna_enum_object_axis_items);
        RNA_def_property_ui_text(prop, "Up", "");
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 
@@ -3663,6 +4182,414 @@ static void rna_def_modifier_meshcache(BlenderRNA *brna)
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
 }
 
+static void rna_def_modifier_laplaciandeform(BlenderRNA *brna)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+
+       srna = RNA_def_struct(brna, "LaplacianDeformModifier", "Modifier");
+       RNA_def_struct_ui_text(srna, "Laplacian Deform Modifier", "Mesh deform modifier");
+       RNA_def_struct_sdna(srna, "LaplacianDeformModifierData");
+       RNA_def_struct_ui_icon(srna, ICON_MOD_MESHDEFORM);
+
+       prop = RNA_def_property(srna, "vertex_group", PROP_STRING, PROP_NONE);
+       RNA_def_property_string_sdna(prop, NULL, "anchor_grp_name");
+       RNA_def_property_ui_text(prop, "Vertex Group for Anchors",
+                                "Name of Vertex Group which determines Anchors");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_LaplacianDeformModifier_anchor_grp_name_set");
+
+       prop = RNA_def_property(srna, "iterations", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "repeat");
+       RNA_def_property_ui_range(prop, 1, 50, 1, -1);
+       RNA_def_property_ui_text(prop, "Repeat", "");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "is_bind", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_funcs(prop, "rna_LaplacianDeformModifier_is_bind_get", NULL);
+       RNA_def_property_ui_text(prop, "Bound", "Whether geometry has been bound to anchors");
+       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+}
+
+static void rna_def_modifier_wireframe(BlenderRNA *brna)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+
+       srna = RNA_def_struct(brna, "WireframeModifier", "Modifier");
+       RNA_def_struct_ui_text(srna, "Wireframe Modifier", "Wireframe effect modifier");
+       RNA_def_struct_sdna(srna, "WireframeModifierData");
+       RNA_def_struct_ui_icon(srna, ICON_MOD_WIREFRAME);
+
+
+       prop = RNA_def_property(srna, "thickness", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "offset");
+       RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);
+       RNA_def_property_ui_range(prop, 0.0f, 1.0f, 0.01, 4);
+       RNA_def_property_ui_text(prop, "Thickness", "Thickness factor");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "thickness_vertex_group", PROP_FLOAT, PROP_FACTOR);
+       RNA_def_property_float_sdna(prop, NULL, "offset_fac_vg");
+       RNA_def_property_range(prop, 0.0, 1.0);
+       RNA_def_property_ui_range(prop, 0, 1, 0.1, 3);
+       RNA_def_property_ui_text(prop, "Vertex Group Factor",
+                                "Thickness factor to use for zero vertex group influence");
+       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, "use_replace", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_WIREFRAME_REPLACE);
+       RNA_def_property_ui_text(prop, "Replace", "Remove original geometry");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "use_boundary", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_WIREFRAME_BOUNDARY);
+       RNA_def_property_ui_text(prop, "Boundary", "Support face boundaries");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "use_even_offset", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_WIREFRAME_OFS_EVEN);
+       RNA_def_property_ui_text(prop, "Offset Even", "Scale the offset to give more even thickness");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "use_relative_offset", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_WIREFRAME_OFS_RELATIVE);
+       RNA_def_property_ui_text(prop, "Offset Relative", "Scale the offset by surrounding geometry");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "use_crease", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_WIREFRAME_CREASE);
+       RNA_def_property_ui_text(prop, "Offset Relative", "Crease hub edges for improved subsurf");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "crease_weight", PROP_FLOAT, PROP_NONE);
+       RNA_def_property_float_sdna(prop, NULL, "crease_weight");
+       RNA_def_property_range(prop, -FLT_MAX, FLT_MAX);
+       RNA_def_property_ui_range(prop, 0.0f, 1.0f, 0.1, 1);
+       RNA_def_property_ui_text(prop, "Weight", "Crease weight (if active)");
+       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, "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 selecting the affected areas");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_WireframeModifier_defgrp_name_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, "flag", MOD_WIREFRAME_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_datatransfer(BlenderRNA *brna)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+
+       static EnumPropertyItem DT_layer_vert_items[] = {
+               {DT_TYPE_MDEFORMVERT, "VGROUP_WEIGHTS", 0, "Vertex Group(s)", "Transfer active or all vertex groups"},
+#if 0  /* TODO */
+               {DT_TYPE_SHAPEKEY, "SHAPEKEYS", 0, "Shapekey(s)", "Transfer active or all shape keys"},
+#endif
+#if 0  /* XXX When SkinModifier is enabled, it seems to erase its own CD_MVERT_SKIN layer from final DM :( */
+               {DT_TYPE_SKIN, "SKIN", 0, "Skin Weight", "Transfer skin weights"},
+#endif
+               {DT_TYPE_BWEIGHT_VERT, "BEVEL_WEIGHT_VERT", 0, "Bevel Weight", "Transfer bevel weights"},
+               {0, NULL, 0, NULL, NULL}
+       };
+
+       static EnumPropertyItem DT_layer_edge_items[] = {
+               {DT_TYPE_SHARP_EDGE, "SHARP_EDGE", 0, "Sharp", "Transfer sharp mark"},
+               {DT_TYPE_SEAM, "SEAM", 0, "UV Seam", "Transfer UV seam mark"},
+               {DT_TYPE_CREASE, "CREASE", 0, "Subsurf Crease", "Transfer crease values"},
+               {DT_TYPE_BWEIGHT_EDGE, "BEVEL_WEIGHT_EDGE", 0, "Bevel Weight", "Transfer bevel weights"},
+               {DT_TYPE_FREESTYLE_EDGE, "FREESTYLE_EDGE", 0, "Freestyle Mark", "Transfer Freestyle edge mark"},
+               {0, NULL, 0, NULL, NULL}
+       };
+
+       static EnumPropertyItem DT_layer_loop_items[] = {
+               {DT_TYPE_LNOR, "CUSTOM_NORMAL", 0, "Custom Normals", "Transfer custom normals"},
+               {DT_TYPE_VCOL, "VCOL", 0, "VCol", "Vertex (face corners) colors"},
+               {DT_TYPE_UV, "UV", 0, "UVs", "Transfer UV layers"},
+               {0, NULL, 0, NULL, NULL}
+       };
+
+       static EnumPropertyItem DT_layer_poly_items[] = {
+               {DT_TYPE_SHARP_FACE, "SMOOTH", 0, "Smooth", "Transfer flat/smooth mark"},
+               {DT_TYPE_FREESTYLE_FACE, "FREESTYLE_FACE", 0, "Freestyle Mark", "Transfer Freestyle face mark"},
+               {0, NULL, 0, NULL, NULL}
+       };
+
+       srna = RNA_def_struct(brna, "DataTransferModifier", "Modifier");
+       RNA_def_struct_ui_text(srna, "Data Transfer Modifier", "Modifier transferring some data from a source mesh");
+       RNA_def_struct_sdna(srna, "DataTransferModifierData");
+       RNA_def_struct_ui_icon(srna, ICON_MOD_DATA_TRANSFER);
+
+       prop = RNA_def_property(srna, "object", PROP_POINTER, PROP_NONE);
+       RNA_def_property_pointer_sdna(prop, NULL, "ob_source");
+       RNA_def_property_ui_text(prop, "Source Object", "Object to transfer data from");
+       RNA_def_property_flag(prop, PROP_EDITABLE | PROP_ID_SELF_CHECK);
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_DataTransferModifier_ob_source_set", NULL, "rna_Mesh_object_poll");
+       RNA_def_property_update(prop, 0, "rna_Modifier_dependency_update");
+
+       prop = RNA_def_boolean(srna, "use_object_transform", true, "Object Transform",
+                              "Evaluate source and destination meshes in global space");
+       RNA_def_property_boolean_sdna(prop, NULL, "flags", MOD_DATATRANSFER_OBSRC_TRANSFORM);
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       /* Generic, UI-only data types toggles. */
+       prop = RNA_def_boolean(srna, "use_vert_data", false, "Vertex Data", "Enable vertex data transfer");
+       RNA_def_property_boolean_sdna(prop, NULL, "flags", MOD_DATATRANSFER_USE_VERT);
+       RNA_def_property_update(prop, 0, "rna_DataTransferModifier_use_data_update");
+
+       prop = RNA_def_boolean(srna, "use_edge_data", false, "Edge Data", "Enable edge data transfer");
+       RNA_def_property_boolean_sdna(prop, NULL, "flags", MOD_DATATRANSFER_USE_EDGE);
+       RNA_def_property_update(prop, 0, "rna_DataTransferModifier_use_data_update");
+
+       prop = RNA_def_boolean(srna, "use_loop_data", false, "Face Corner Data", "Enable face corner data transfer");
+       RNA_def_property_boolean_sdna(prop, NULL, "flags", MOD_DATATRANSFER_USE_LOOP);
+       RNA_def_property_update(prop, 0, "rna_DataTransferModifier_use_data_update");
+
+       prop = RNA_def_boolean(srna, "use_poly_data", false, "Face Data", "Enable face data transfer");
+       RNA_def_property_boolean_sdna(prop, NULL, "flags", MOD_DATATRANSFER_USE_POLY);
+       RNA_def_property_update(prop, 0, "rna_DataTransferModifier_use_data_update");
+
+       /* Actual data types selection. */
+       prop = RNA_def_enum(srna, "data_types_verts", DT_layer_vert_items, 0, "Vertex Data Types",
+                           "Which vertex data layers to transfer");
+       RNA_def_property_flag(prop, PROP_ENUM_FLAG);
+       RNA_def_property_enum_sdna(prop, NULL, "data_types");
+       RNA_def_property_enum_funcs(prop, NULL, "rna_DataTransferModifier_verts_data_types_set", NULL);
+       RNA_def_property_update(prop, 0, "rna_DataTransferModifier_data_types_update");
+
+       prop = RNA_def_enum(srna, "data_types_edges", DT_layer_edge_items, 0, "Edge Data Types",
+                           "Which edge data layers to transfer");
+       RNA_def_property_flag(prop, PROP_ENUM_FLAG);
+       RNA_def_property_enum_sdna(prop, NULL, "data_types");
+       RNA_def_property_enum_funcs(prop, NULL, "rna_DataTransferModifier_edges_data_types_set", NULL);
+       RNA_def_property_update(prop, 0, "rna_DataTransferModifier_data_types_update");
+
+       prop = RNA_def_enum(srna, "data_types_loops", DT_layer_loop_items, 0, "Face Corner Data Types",
+                           "Which face corner data layers to transfer");
+       RNA_def_property_flag(prop, PROP_ENUM_FLAG);
+       RNA_def_property_enum_sdna(prop, NULL, "data_types");
+       RNA_def_property_enum_funcs(prop, NULL, "rna_DataTransferModifier_loops_data_types_set", NULL);
+       RNA_def_property_update(prop, 0, "rna_DataTransferModifier_data_types_update");
+
+       prop = RNA_def_enum(srna, "data_types_polys", DT_layer_poly_items, 0, "Poly Data Types",
+                           "Which poly data layers to transfer");
+       RNA_def_property_flag(prop, PROP_ENUM_FLAG);
+       RNA_def_property_enum_sdna(prop, NULL, "data_types");
+       RNA_def_property_enum_funcs(prop, NULL, "rna_DataTransferModifier_polys_data_types_set", NULL);
+       RNA_def_property_update(prop, 0, "rna_DataTransferModifier_data_types_update");
+
+       /* Mapping methods. */
+       prop = RNA_def_enum(srna, "vert_mapping", rna_enum_dt_method_vertex_items, MREMAP_MODE_VERT_NEAREST, "Vertex Mapping",
+                           "Method used to map source vertices to destination ones");
+       RNA_def_property_enum_sdna(prop, NULL, "vmap_mode");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_enum(srna, "edge_mapping", rna_enum_dt_method_edge_items, MREMAP_MODE_EDGE_NEAREST, "Edge Mapping",
+                           "Method used to map source edges to destination ones");
+       RNA_def_property_enum_sdna(prop, NULL, "emap_mode");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_enum(srna, "loop_mapping", rna_enum_dt_method_loop_items, MREMAP_MODE_LOOP_NEAREST_POLYNOR,
+                           "Face Corner Mapping", "Method used to map source faces' corners to destination ones");
+       RNA_def_property_enum_sdna(prop, NULL, "lmap_mode");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_enum(srna, "poly_mapping", rna_enum_dt_method_poly_items, MREMAP_MODE_POLY_NEAREST, "Face Mapping",
+                           "Method used to map source faces to destination ones");
+       RNA_def_property_enum_sdna(prop, NULL, "pmap_mode");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       /* Mapping options and filtering. */
+       prop = RNA_def_boolean(srna, "use_max_distance", false, "Only Neighbor Geometry",
+                              "Source elements must be closer than given distance from destination one");
+       RNA_def_property_boolean_sdna(prop, NULL, "flags", MOD_DATATRANSFER_MAP_MAXDIST);
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_float(srna, "max_distance", 1.0f, 0.0f, FLT_MAX, "Max Distance",
+                            "Maximum allowed distance between source and destination element, for non-topology mappings",
+                            0.0f, 100.0f);
+       RNA_def_property_float_sdna(prop, NULL, "map_max_distance");
+       RNA_def_property_subtype(prop, PROP_DISTANCE);
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_float(srna, "ray_radius", 0.0f, 0.0f, FLT_MAX, "Ray Radius",
+                            "'Width' of rays (especially useful when raycasting against vertices or edges)", 0.0f, 10.0f);
+       RNA_def_property_float_sdna(prop, NULL, "map_ray_radius");
+       RNA_def_property_subtype(prop, PROP_DISTANCE);
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_float(srna, "islands_precision", 0.0f, 0.0f, 1.0f, "Islands Handling Refinement",
+                            "Factor controlling precision of islands handling "
+                            "(typically, 0.1 should be enough, higher values can make things really slow)", 0.0f, 1.0f);
+       RNA_def_property_subtype(prop, PROP_DISTANCE);
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       /* How to handle multi-layers types of data. */
+       prop = RNA_def_enum(srna, "layers_vgroup_select_src", rna_enum_dt_layers_select_src_items, DT_LAYERS_ALL_SRC,
+                           "Source Layers Selection", "Which layers to transfer, in case of multi-layers types");
+       RNA_def_property_enum_sdna(prop, NULL, "layers_select_src[DT_MULTILAYER_INDEX_MDEFORMVERT]");
+       RNA_def_property_enum_funcs(prop, NULL, NULL, "rna_DataTransferModifier_layers_select_src_itemf");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+#if 0
+       prop = RNA_def_enum(srna, "layers_shapekey_select_src", rna_enum_dt_layers_select_src_items, DT_LAYERS_ALL_SRC,
+                           "Source Layers Selection", "Which layers to transfer, in case of multi-layers types");
+       RNA_def_property_enum_sdna(prop, NULL, "layers_select_src[DT_MULTILAYER_INDEX_SHAPEKEY]");
+       RNA_def_property_enum_funcs(prop, NULL, NULL, "rna_DataTransferModifier_layers_select_src_itemf");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+#endif
+
+       prop = RNA_def_enum(srna, "layers_vcol_select_src", rna_enum_dt_layers_select_src_items, DT_LAYERS_ALL_SRC,
+                           "Source Layers Selection", "Which layers to transfer, in case of multi-layers types");
+       RNA_def_property_enum_sdna(prop, NULL, "layers_select_src[DT_MULTILAYER_INDEX_VCOL]");
+       RNA_def_property_enum_funcs(prop, NULL, NULL, "rna_DataTransferModifier_layers_select_src_itemf");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_enum(srna, "layers_uv_select_src", rna_enum_dt_layers_select_src_items, DT_LAYERS_ALL_SRC,
+                           "Source Layers Selection", "Which layers to transfer, in case of multi-layers types");
+       RNA_def_property_enum_sdna(prop, NULL, "layers_select_src[DT_MULTILAYER_INDEX_UV]");
+       RNA_def_property_enum_funcs(prop, NULL, NULL, "rna_DataTransferModifier_layers_select_src_itemf");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_enum(srna, "layers_vgroup_select_dst", rna_enum_dt_layers_select_dst_items, DT_LAYERS_NAME_DST,
+                           "Destination Layers Matching", "How to match source and destination layers");
+       RNA_def_property_enum_sdna(prop, NULL, "layers_select_dst[DT_MULTILAYER_INDEX_MDEFORMVERT]");
+       RNA_def_property_enum_funcs(prop, NULL, NULL, "rna_DataTransferModifier_layers_select_dst_itemf");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+#if 0
+       prop = RNA_def_enum(srna, "layers_shapekey_select_dst", rna_enum_dt_layers_select_dst_items, DT_LAYERS_NAME_DST,
+                           "Destination Layers Matching", "How to match source and destination layers");
+       RNA_def_property_enum_sdna(prop, NULL, "layers_select_dst[DT_MULTILAYER_INDEX_SHAPEKEY]");
+       RNA_def_property_enum_funcs(prop, NULL, NULL, "rna_DataTransferModifier_layers_select_dst_itemf");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+#endif
+
+       prop = RNA_def_enum(srna, "layers_vcol_select_dst", rna_enum_dt_layers_select_dst_items, DT_LAYERS_NAME_DST,
+                           "Destination Layers Matching", "How to match source and destination layers");
+       RNA_def_property_enum_sdna(prop, NULL, "layers_select_dst[DT_MULTILAYER_INDEX_VCOL]");
+       RNA_def_property_enum_funcs(prop, NULL, NULL, "rna_DataTransferModifier_layers_select_dst_itemf");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_enum(srna, "layers_uv_select_dst", rna_enum_dt_layers_select_dst_items, DT_LAYERS_NAME_DST,
+                           "Destination Layers Matching", "How to match source and destination layers");
+       RNA_def_property_enum_sdna(prop, NULL, "layers_select_dst[DT_MULTILAYER_INDEX_UV]");
+       RNA_def_property_enum_funcs(prop, NULL, NULL, "rna_DataTransferModifier_layers_select_dst_itemf");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       /* Mix stuff */
+       prop = RNA_def_enum(srna, "mix_mode", rna_enum_dt_mix_mode_items, CDT_MIX_TRANSFER, "Mix Mode",
+                          "How to affect destination elements with source values");
+       RNA_def_property_enum_funcs(prop, NULL, NULL, "rna_DataTransferModifier_mix_mode_itemf");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_float(srna, "mix_factor", 1.0f, 0.0f, 1.0f, "Mix Factor",
+                            "Factor to use when applying data to destination (exact behavior depends on mix mode)",
+                            0.0f, 1.0f);
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_string(srna, "vertex_group", NULL, MAX_VGROUP_NAME, "Vertex Group",
+                             "Vertex group name for selecting the affected areas");
+       RNA_def_property_string_sdna(prop, NULL, "defgrp_name");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_DataTransferModifier_defgrp_name_set");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_boolean(srna, "invert_vertex_group", false, "Invert", "Invert vertex group influence");
+       RNA_def_property_boolean_sdna(prop, NULL, "flags", MOD_DATATRANSFER_INVERT_VGROUP);
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+}
+
+static void rna_def_modifier_normaledit(BlenderRNA *brna)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+
+       static EnumPropertyItem prop_mode_items[] = {
+               {MOD_NORMALEDIT_MODE_RADIAL, "RADIAL", 0, "Radial",
+                       "From an ellipsoid (shape defined by the boundbox's dimensions, target is optional)"},
+               {MOD_NORMALEDIT_MODE_DIRECTIONAL, "DIRECTIONAL", 0, "Directional",
+                       "Normals 'track' (point to) the target object"},
+               {0, NULL, 0, NULL, NULL}
+       };
+
+       static EnumPropertyItem prop_mix_mode_items[] = {
+               {MOD_NORMALEDIT_MIX_COPY, "COPY", 0, "Copy", "Copy new normals (overwrite existing)"},
+               {MOD_NORMALEDIT_MIX_ADD, "ADD", 0, "Add", "Copy sum of new and old normals"},
+               {MOD_NORMALEDIT_MIX_SUB, "SUB", 0, "Subtract", "Copy new normals minus old normals"},
+               {MOD_NORMALEDIT_MIX_MUL, "MUL", 0, "Multiply", "Copy product of old and new normals (*not* cross product)"},
+               {0, NULL, 0, NULL, NULL}
+       };
+
+       srna = RNA_def_struct(brna, "NormalEditModifier", "Modifier");
+       RNA_def_struct_ui_text(srna, "Normal Edit Modifier", "Modifier affecting/generating custom normals");
+       RNA_def_struct_sdna(srna, "NormalEditModifierData");
+       RNA_def_struct_ui_icon(srna, ICON_MOD_NORMALEDIT);
+
+       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", "How to affect (generate) normals");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_float_array(srna, "offset", 3, NULL, -FLT_MAX, FLT_MAX, "Offset",
+                                  "Offset from object's center", -100.0f, 100.0f);
+       RNA_def_property_subtype(prop, PROP_COORDS);
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_property(srna, "mix_mode", PROP_ENUM, PROP_NONE);
+       RNA_def_property_enum_items(prop, prop_mix_mode_items);
+       RNA_def_property_ui_text(prop, "Mix Mode", "How to mix generated normals with existing ones");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+
+       prop = RNA_def_float(srna, "mix_factor", 1.0f, 0.0f, 1.0f, "Mix Factor",
+                            "How much of generated normals to mix with exiting ones", 0.0f, 1.0f);
+       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 selecting/weighting the affected areas");
+       RNA_def_property_string_funcs(prop, NULL, NULL, "rna_NormalEditModifier_defgrp_name_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, "flag", MOD_NORMALEDIT_INVERT_VGROUP);
+       RNA_def_property_ui_text(prop, "Invert", "Invert vertex group influence");
+       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", "Target object used to affect normals");
+       RNA_def_property_pointer_funcs(prop, NULL, "rna_NormalEditModifier_target_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, "use_direction_parallel", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "flag", MOD_NORMALEDIT_USE_DIRECTION_PARALLEL);
+       RNA_def_property_boolean_default(prop, true);
+       RNA_def_property_ui_text(prop, "Parallel Normals",
+                                "Use same direction for all normals, from origin to target's center "
+                                "(Directional mode only)");
+       RNA_def_property_update(prop, 0, "rna_Modifier_update");
+}
+
 void RNA_def_modifier(BlenderRNA *brna)
 {
        StructRNA *srna;
@@ -3686,32 +4613,33 @@ void RNA_def_modifier(BlenderRNA *brna)
        prop = RNA_def_property(srna, "type", PROP_ENUM, PROP_NONE);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
        RNA_def_property_enum_sdna(prop, NULL, "type");
-       RNA_def_property_enum_items(prop, modifier_type_items);
+       RNA_def_property_enum_items(prop, rna_enum_object_modifier_type_items);
        RNA_def_property_ui_text(prop, "Type", "");
        
        /* flags */
        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", "Display modifier in realtime");
+       RNA_def_property_ui_text(prop, "Realtime", "Display modifier in viewport");
        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, "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_text(prop, "Render", "Use modifier during render");
        RNA_def_property_ui_icon(prop, ICON_SCENE, 0);
        RNA_def_property_update(prop, NC_OBJECT | ND_MODIFIER, NULL);
        
        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, "Edit Mode", "Use modifier while in the Edit mode");
+       RNA_def_property_ui_text(prop, "Edit Mode", "Display modifier in 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, "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_ui_text(prop, "On Cage", "Adjust edit cage to modifier result");
+       RNA_def_property_ui_icon(prop, ICON_MESH_DATA, 0);
        RNA_def_property_update(prop, 0, "rna_Modifier_update");
        
        prop = RNA_def_property(srna, "show_expanded", PROP_BOOLEAN, PROP_NONE);
@@ -3744,6 +4672,7 @@ void RNA_def_modifier(BlenderRNA *brna)
        rna_def_modifier_displace(brna);
        rna_def_modifier_uvproject(brna);
        rna_def_modifier_smooth(brna);
+       rna_def_modifier_correctivesmooth(brna);
        rna_def_modifier_cast(brna);
        rna_def_modifier_meshdeform(brna);
        rna_def_modifier_particlesystem(brna);
@@ -3773,6 +4702,10 @@ void RNA_def_modifier(BlenderRNA *brna)
        rna_def_modifier_laplaciansmooth(brna);
        rna_def_modifier_triangulate(brna);
        rna_def_modifier_meshcache(brna);
+       rna_def_modifier_laplaciandeform(brna);
+       rna_def_modifier_wireframe(brna);
+       rna_def_modifier_datatransfer(brna);
+       rna_def_modifier_normaledit(brna);
 }
 
 #endif