clone and stencil layer access added, renamed mask to stencil layer internally
[blender.git] / source / blender / makesrna / intern / rna_mesh.c
index e1744bb3d234ba2ec17ca6848fae43013708334e..c298d83850b0a24ad2494b9c97163a6dc5767457 100644 (file)
@@ -39,7 +39,7 @@
 #include "DNA_scene_types.h"
 
 #include "BLI_editVert.h"
-#include "BLI_arithb.h"
+#include "BLI_math.h"
 
 #include "BKE_customdata.h"
 #include "BKE_depsgraph.h"
 #include "WM_api.h"
 #include "WM_types.h"
 
-#include "BLI_arithb.h" /* CalcNormFloat */
-
-
-static void rna_Mesh_update_data(bContext *C, PointerRNA *ptr)
+static void rna_Mesh_update_data(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
        ID *id= ptr->id.data;
 
        DAG_id_flush_update(id, OB_RECALC_DATA);
-       WM_event_add_notifier(C, NC_GEOM|ND_DATA, id);
+       WM_main_add_notifier(NC_GEOM|ND_DATA, id);
 }
 
-static void rna_Mesh_update_select(bContext *C, PointerRNA *ptr)
+static void rna_Mesh_update_select(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
        ID *id= ptr->id.data;
 
-       WM_event_add_notifier(C, NC_GEOM|ND_SELECT, id);
+       WM_main_add_notifier(NC_GEOM|ND_SELECT, id);
 }
 
-void rna_Mesh_update_draw(bContext *C, PointerRNA *ptr)
+void rna_Mesh_update_draw(Main *bmain, Scene *scene, PointerRNA *ptr)
 {
        ID *id= ptr->id.data;
 
-       WM_event_add_notifier(C, NC_GEOM|ND_DATA, id);
+       WM_main_add_notifier(NC_GEOM|ND_DATA, id);
 }
 
 static void rna_MeshVertex_normal_get(PointerRNA *ptr, float *value)
@@ -126,9 +123,20 @@ static void rna_MeshFace_normal_get(PointerRNA *ptr, float *values)
        MFace *mface= (MFace*)ptr->data;
        
        if(mface->v4)
-               CalcNormFloat4(me->mvert[mface->v1].co, me->mvert[mface->v2].co, me->mvert[mface->v3].co, me->mvert[mface->v4].co, values);
+               normal_quad_v3( values,me->mvert[mface->v1].co, me->mvert[mface->v2].co, me->mvert[mface->v3].co, me->mvert[mface->v4].co);
+       else
+               normal_tri_v3( values,me->mvert[mface->v1].co, me->mvert[mface->v2].co, me->mvert[mface->v3].co);
+}
+
+static float rna_MeshFace_area_get(PointerRNA *ptr)
+{
+       Mesh *me= (Mesh*)ptr->id.data;
+       MFace *mface= (MFace*)ptr->data;
+
+       if(mface->v4)
+               return area_quad_v3(me->mvert[mface->v1].co, me->mvert[mface->v2].co, me->mvert[mface->v3].co, me->mvert[mface->v4].co);
        else
-               CalcNormFloat(me->mvert[mface->v1].co, me->mvert[mface->v2].co, me->mvert[mface->v3].co, values);
+               return area_tri_v3(me->mvert[mface->v1].co, me->mvert[mface->v2].co, me->mvert[mface->v3].co);
 }
 
 /* notice red and blue are swapped */
@@ -260,6 +268,15 @@ static int rna_CustomDataLayer_active_get(PointerRNA *ptr, int type, int render)
        else return (n == CustomData_get_active_layer_index(fdata, type));
 }
 
+static int rna_CustomDataLayer_clone_get(PointerRNA *ptr, int type, int render)
+{
+       Mesh *me= (Mesh*)ptr->id.data;
+       CustomData *fdata= rna_mesh_fdata(me);
+       int n= ((CustomDataLayer*)ptr->data) - fdata->layers;
+
+       return (n == CustomData_get_clone_layer_index(fdata, type));
+}
+
 static void rna_CustomDataLayer_active_set(PointerRNA *ptr, int value, int type, int render)
 {
        Mesh *me= (Mesh*)ptr->id.data;
@@ -273,6 +290,18 @@ static void rna_CustomDataLayer_active_set(PointerRNA *ptr, int value, int type,
        else CustomData_set_layer_active_index(fdata, type, n);
 }
 
+static void rna_CustomDataLayer_clone_set(PointerRNA *ptr, int value, int type, int render)
+{
+       Mesh *me= (Mesh*)ptr->id.data;
+       CustomData *fdata= rna_mesh_fdata(me);
+       int n= ((CustomDataLayer*)ptr->data) - fdata->layers;
+
+       if(value == 0)
+               return;
+
+       CustomData_set_layer_clone_index(fdata, type, n);
+}
+
 static int rna_uv_texture_check(CollectionPropertyIterator *iter, void *data)
 {
        CustomDataLayer *layer= (CustomDataLayer*)data;
@@ -301,6 +330,26 @@ static PointerRNA rna_Mesh_active_uv_texture_get(PointerRNA *ptr)
        return rna_pointer_inherit_refine(ptr, &RNA_MeshTextureFaceLayer, cdl);
 }
 
+static PointerRNA rna_Mesh_uv_texture_clone_get(PointerRNA *ptr)
+{
+       Mesh *me= (Mesh*)ptr->data;
+       CustomData *fdata= rna_mesh_fdata(me);
+       int index= CustomData_get_clone_layer_index(fdata, CD_MTFACE);
+       CustomDataLayer *cdl= (index == -1)? NULL: &fdata->layers[index];
+
+       return rna_pointer_inherit_refine(ptr, &RNA_MeshTextureFaceLayer, cdl);
+}
+
+static PointerRNA rna_Mesh_uv_texture_stencil_get(PointerRNA *ptr)
+{
+       Mesh *me= (Mesh*)ptr->data;
+       CustomData *fdata= rna_mesh_fdata(me);
+       int index= CustomData_get_stencil_layer_index(fdata, CD_MTFACE);
+       CustomDataLayer *cdl= (index == -1)? NULL: &fdata->layers[index];
+
+       return rna_pointer_inherit_refine(ptr, &RNA_MeshTextureFaceLayer, cdl);
+}
+
 static void rna_Mesh_active_uv_texture_set(PointerRNA *ptr, PointerRNA value)
 {
        Mesh *me= (Mesh*)ptr->data;
@@ -317,6 +366,36 @@ static void rna_Mesh_active_uv_texture_set(PointerRNA *ptr, PointerRNA value)
        }
 }
 
+static void rna_Mesh_uv_texture_clone_set(PointerRNA *ptr, PointerRNA value)
+{
+       Mesh *me= (Mesh*)ptr->data;
+       CustomData *fdata= rna_mesh_fdata(me);
+       CustomDataLayer *cdl;
+       int a;
+
+       for(cdl=fdata->layers, a=0; a<fdata->totlayer; cdl++, a++) {
+               if(value.data == cdl) {
+                       CustomData_set_layer_clone_index(fdata, CD_MTFACE, a);
+                       return;
+               }
+       }
+}
+
+static void rna_Mesh_uv_texture_stencil_set(PointerRNA *ptr, PointerRNA value)
+{
+       Mesh *me= (Mesh*)ptr->data;
+       CustomData *fdata= rna_mesh_fdata(me);
+       CustomDataLayer *cdl;
+       int a;
+
+       for(cdl=fdata->layers, a=0; a<fdata->totlayer; cdl++, a++) {
+               if(value.data == cdl) {
+                       CustomData_set_layer_stencil_index(fdata, CD_MTFACE, a);
+                       return;
+               }
+       }
+}
+
 static int rna_Mesh_active_uv_texture_index_get(PointerRNA *ptr)
 {
        Mesh *me= (Mesh*)ptr->data;
@@ -324,6 +403,20 @@ static int rna_Mesh_active_uv_texture_index_get(PointerRNA *ptr)
        return CustomData_get_active_layer(fdata, CD_MTFACE);
 }
 
+static int rna_Mesh_uv_texture_clone_index_get(PointerRNA *ptr)
+{
+       Mesh *me= (Mesh*)ptr->data;
+       CustomData *fdata= rna_mesh_fdata(me);
+       return CustomData_get_clone_layer(fdata, CD_MTFACE);
+}
+
+static int rna_Mesh_uv_texture_stencil_index_get(PointerRNA *ptr)
+{
+       Mesh *me= (Mesh*)ptr->data;
+       CustomData *fdata= rna_mesh_fdata(me);
+       return CustomData_get_stencil_layer(fdata, CD_MTFACE);
+}
+
 static void rna_Mesh_active_uv_texture_index_set(PointerRNA *ptr, int value)
 {
        Mesh *me= (Mesh*)ptr->data;
@@ -333,6 +426,22 @@ static void rna_Mesh_active_uv_texture_index_set(PointerRNA *ptr, int value)
        mesh_update_customdata_pointers(me);
 }
 
+static void rna_Mesh_uv_texture_clone_index_set(PointerRNA *ptr, int value)
+{
+       Mesh *me= (Mesh*)ptr->data;
+       CustomData *fdata= rna_mesh_fdata(me);
+
+       CustomData_set_layer_clone(fdata, CD_MTFACE, value);
+}
+
+static void rna_Mesh_uv_texture_stencil_index_set(PointerRNA *ptr, int value)
+{
+       Mesh *me= (Mesh*)ptr->data;
+       CustomData *fdata= rna_mesh_fdata(me);
+
+       CustomData_set_layer_stencil(fdata, CD_MTFACE, value);
+}
+
 static void rna_Mesh_active_uv_texture_index_range(PointerRNA *ptr, int *min, int *max)
 {
        Mesh *me= (Mesh*)ptr->data;
@@ -472,6 +581,11 @@ static int rna_MeshTextureFaceLayer_active_get(PointerRNA *ptr)
        return rna_CustomDataLayer_active_get(ptr, CD_MTFACE, 0);
 }
 
+static int rna_MeshTextureFaceLayer_clone_get(PointerRNA *ptr)
+{
+       return rna_CustomDataLayer_clone_get(ptr, CD_MTFACE, 0);
+}
+
 static void rna_MeshTextureFaceLayer_active_render_set(PointerRNA *ptr, int value)
 {
        rna_CustomDataLayer_active_set(ptr, value, CD_MTFACE, 1);
@@ -482,12 +596,18 @@ static void rna_MeshTextureFaceLayer_active_set(PointerRNA *ptr, int value)
        rna_CustomDataLayer_active_set(ptr, value, CD_MTFACE, 0);
 }
 
+static void rna_MeshTextureFaceLayer_clone_set(PointerRNA *ptr, int value)
+{
+       rna_CustomDataLayer_clone_set(ptr, value, CD_MTFACE, 0);
+}
+
 static void rna_MeshTextureFaceLayer_name_set(PointerRNA *ptr, const char *value)
 {
        Mesh *me= (Mesh*)ptr->id.data;
+       CustomData *fdata= rna_mesh_fdata(me);
        CustomDataLayer *cdl= (CustomDataLayer*)ptr->data;
        BLI_strncpy(cdl->name, value, sizeof(cdl->name));
-       CustomData_set_layer_unique_name(&me->fdata, cdl - me->fdata.layers);
+       CustomData_set_layer_unique_name(fdata, cdl - fdata->layers);
 }
 
 static int rna_vertex_color_check(CollectionPropertyIterator *iter, void *data)
@@ -596,9 +716,10 @@ static void rna_MeshColorLayer_active_set(PointerRNA *ptr, int value)
 static void rna_MeshColorLayer_name_set(PointerRNA *ptr, const char *value)
 {
        Mesh *me= (Mesh*)ptr->id.data;
+       CustomData *fdata= rna_mesh_fdata(me);
        CustomDataLayer *cdl= (CustomDataLayer*)ptr->data;
        BLI_strncpy(cdl->name, value, sizeof(cdl->name));
-       CustomData_set_layer_unique_name(&me->fdata, cdl - me->fdata.layers);
+       CustomData_set_layer_unique_name(fdata, cdl - fdata->layers);
 }
 
 static void rna_MeshFloatPropertyLayer_data_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
@@ -735,6 +856,27 @@ static void rna_MeshFace_verts_set(PointerRNA *ptr, const int *values)
        memcpy(&face->v1, values, (face->v4 ? 4 : 3) * sizeof(int));
 }
 
+static int rna_MeshVertex_index_get(PointerRNA *ptr)
+{
+       Mesh *me= (Mesh*)ptr->id.data;
+       MVert *vert= (MVert*)ptr->data;
+       return (int)(vert - me->mvert);
+}
+
+static int rna_MeshEdge_index_get(PointerRNA *ptr)
+{
+       Mesh *me= (Mesh*)ptr->id.data;
+       MEdge *edge= (MEdge*)ptr->data;
+       return (int)(edge - me->medge);
+}
+
+static int rna_MeshFace_index_get(PointerRNA *ptr)
+{
+       Mesh *me= (Mesh*)ptr->id.data;
+       MFace *face= (MFace*)ptr->data;
+       return (int)(face - me->mface);
+}
+
 /* path construction */
 
 static char *rna_VertexGroupElement_path(PointerRNA *ptr)
@@ -769,7 +911,7 @@ static char *rna_MeshVertex_path(PointerRNA *ptr)
 
 static char *rna_MeshTextureFaceLayer_path(PointerRNA *ptr)
 {
-       return BLI_sprintfN("uv_textures[%s]", ((CustomDataLayer*)ptr->data)->name);
+       return BLI_sprintfN("uv_textures[\"%s\"]", ((CustomDataLayer*)ptr->data)->name);
 }
 
 static char *rna_CustomDataData_path(PointerRNA *ptr, char *collection, int type)
@@ -784,7 +926,7 @@ static char *rna_CustomDataData_path(PointerRNA *ptr, char *collection, int type
                if(cdl->type == type) {
                        b= ((char*)ptr->data - ((char*)cdl->data))/CustomData_sizeof(type);
                        if(b >= 0 && b < me->totface)
-                               return BLI_sprintfN("%s[%s].data[%d]", collection, cdl->name, b);
+                               return BLI_sprintfN("%s[\"%s\"].data[%d]", collection, cdl->name, b);
                }
        }
 
@@ -798,7 +940,7 @@ static char *rna_MeshTextureFace_path(PointerRNA *ptr)
 
 static char *rna_MeshColorLayer_path(PointerRNA *ptr)
 {
-       return BLI_sprintfN("vertex_colors[%s]", ((CustomDataLayer*)ptr->data)->name);
+       return BLI_sprintfN("vertex_colors[\"%s\"]", ((CustomDataLayer*)ptr->data)->name);
 }
 
 static char *rna_MeshColor_path(PointerRNA *ptr)
@@ -813,7 +955,7 @@ static char *rna_MeshSticky_path(PointerRNA *ptr)
 
 static char *rna_MeshIntPropertyLayer_path(PointerRNA *ptr)
 {
-       return BLI_sprintfN("int_layers[%s]", ((CustomDataLayer*)ptr->data)->name);
+       return BLI_sprintfN("int_layers[\"%s\"]", ((CustomDataLayer*)ptr->data)->name);
 }
 
 static char *rna_MeshIntProperty_path(PointerRNA *ptr)
@@ -823,7 +965,7 @@ static char *rna_MeshIntProperty_path(PointerRNA *ptr)
 
 static char *rna_MeshFloatPropertyLayer_path(PointerRNA *ptr)
 {
-       return BLI_sprintfN("float_layers[%s]", ((CustomDataLayer*)ptr->data)->name);
+       return BLI_sprintfN("float_layers[\"%s\"]", ((CustomDataLayer*)ptr->data)->name);
 }
 
 static char *rna_MeshFloatProperty_path(PointerRNA *ptr)
@@ -833,7 +975,7 @@ static char *rna_MeshFloatProperty_path(PointerRNA *ptr)
 
 static char *rna_MeshStringPropertyLayer_path(PointerRNA *ptr)
 {
-       return BLI_sprintfN("string_layers[%s]", ((CustomDataLayer*)ptr->data)->name);
+       return BLI_sprintfN("string_layers[\"%s\"]", ((CustomDataLayer*)ptr->data)->name);
 }
 
 static char *rna_MeshStringProperty_path(PointerRNA *ptr)
@@ -905,9 +1047,14 @@ static void rna_def_mvert(BlenderRNA *brna)
        RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 
        prop= RNA_def_property(srna, "groups", PROP_COLLECTION, PROP_NONE);
-       RNA_def_property_collection_funcs(prop, "rna_MeshVertex_groups_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", 0, 0, 0, 0, 0);
+       RNA_def_property_collection_funcs(prop, "rna_MeshVertex_groups_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", 0, 0, 0);
        RNA_def_property_struct_type(prop, "VertexGroupElement");
        RNA_def_property_ui_text(prop, "Groups", "Weights for the vertex groups this vertex is member of.");
+
+       prop= RNA_def_property(srna, "index", PROP_INT, PROP_UNSIGNED);
+       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+       RNA_def_property_int_funcs(prop, "rna_MeshVertex_index_get", NULL, NULL);
+       RNA_def_property_ui_text(prop, "Index", "Index number of the vertex.");
 }
 
 static void rna_def_medge(BlenderRNA *brna)
@@ -966,6 +1113,11 @@ static void rna_def_medge(BlenderRNA *brna)
        RNA_def_property_boolean_sdna(prop, NULL, "flag", ME_FGON);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Fgon", "Fgon edge");
+
+       prop= RNA_def_property(srna, "index", PROP_INT, PROP_UNSIGNED);
+       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+       RNA_def_property_int_funcs(prop, "rna_MeshEdge_index_get", NULL, NULL);
+       RNA_def_property_ui_text(prop, "Index", "Index number of the vertex.");
 }
 
 static void rna_def_mface(BlenderRNA *brna)
@@ -987,6 +1139,12 @@ static void rna_def_mface(BlenderRNA *brna)
        RNA_def_property_int_funcs(prop, "rna_MeshFace_verts_get", "rna_MeshFace_verts_set", NULL);
        RNA_def_property_ui_text(prop, "Vertices", "Vertex indices");
 
+       /* leaving this fixed size array for foreach_set used in import scripts */
+       prop= RNA_def_property(srna, "verts_raw", PROP_INT, PROP_UNSIGNED);
+       RNA_def_property_int_sdna(prop, NULL, "v1");
+       RNA_def_property_array(prop, 4);
+       RNA_def_property_ui_text(prop, "Vertices", "Fixed size vertex indices array");
+
        prop= RNA_def_property(srna, "material_index", PROP_INT, PROP_UNSIGNED);
        RNA_def_property_int_sdna(prop, NULL, "mat_nr");
        RNA_def_property_ui_text(prop, "Material Index", "");
@@ -1013,7 +1171,17 @@ static void rna_def_mface(BlenderRNA *brna)
        RNA_def_property_range(prop, -1.0f, 1.0f);
        RNA_def_property_clear_flag(prop, PROP_EDITABLE);
        RNA_def_property_float_funcs(prop, "rna_MeshFace_normal_get", NULL, NULL);
-       RNA_def_property_ui_text(prop, "Normal", "Face unit-space normal vector.");
+       RNA_def_property_ui_text(prop, "face normal", "local space unit length normal vector for this face");
+
+       prop= RNA_def_property(srna, "area", PROP_FLOAT, PROP_UNSIGNED);
+       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+       RNA_def_property_float_funcs(prop, "rna_MeshFace_area_get", NULL, NULL);
+       RNA_def_property_ui_text(prop, "face area", "read only area of the face");
+
+       prop= RNA_def_property(srna, "index", PROP_INT, PROP_UNSIGNED);
+       RNA_def_property_clear_flag(prop, PROP_EDITABLE);
+       RNA_def_property_int_funcs(prop, "rna_MeshFace_index_get", NULL, NULL);
+       RNA_def_property_ui_text(prop, "Index", "Index number of the vertex.");
 }
 
 static void rna_def_mtface(BlenderRNA *brna)
@@ -1051,10 +1219,16 @@ static void rna_def_mtface(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Active Render", "Sets the layer as active for rendering");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 
+       prop= RNA_def_property(srna, "active_clone", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "active_clone", 0);
+       RNA_def_property_boolean_funcs(prop, "rna_MeshTextureFaceLayer_clone_get", "rna_MeshTextureFaceLayer_clone_set");
+       RNA_def_property_ui_text(prop, "Active Clone", "Sets the layer as active for cloning");
+       RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
+
        prop= RNA_def_property(srna, "data", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_struct_type(prop, "MeshTextureFace");
        RNA_def_property_ui_text(prop, "Data", "");
-       RNA_def_property_collection_funcs(prop, "rna_MeshTextureFaceLayer_data_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", "rna_MeshTextureFaceLayer_data_length", 0, 0, 0, 0);
+       RNA_def_property_collection_funcs(prop, "rna_MeshTextureFaceLayer_data_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", "rna_MeshTextureFaceLayer_data_length", 0, 0);
 
        srna= RNA_def_struct(brna, "MeshTextureFace", NULL);
        RNA_def_struct_sdna(srna, "MTFace");
@@ -1226,7 +1400,7 @@ static void rna_def_mcol(BlenderRNA *brna)
        prop= RNA_def_property(srna, "data", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_struct_type(prop, "MeshColor");
        RNA_def_property_ui_text(prop, "Data", "");
-       RNA_def_property_collection_funcs(prop, "rna_MeshColorLayer_data_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", "rna_MeshColorLayer_data_length", 0, 0, 0, 0);
+       RNA_def_property_collection_funcs(prop, "rna_MeshColorLayer_data_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", "rna_MeshColorLayer_data_length", 0, 0);
 
        srna= RNA_def_struct(brna, "MeshColor", NULL);
        RNA_def_struct_sdna(srna, "MCol");
@@ -1281,7 +1455,7 @@ static void rna_def_mproperties(BlenderRNA *brna)
        prop= RNA_def_property(srna, "data", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_struct_type(prop, "MeshFloatProperty");
        RNA_def_property_ui_text(prop, "Data", "");
-       RNA_def_property_collection_funcs(prop, "rna_MeshFloatPropertyLayer_data_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", "rna_MeshFloatPropertyLayer_data_length", 0, 0, 0, 0);
+       RNA_def_property_collection_funcs(prop, "rna_MeshFloatPropertyLayer_data_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", "rna_MeshFloatPropertyLayer_data_length", 0, 0);
 
        srna= RNA_def_struct(brna, "MeshFloatProperty", NULL);
        RNA_def_struct_sdna(srna, "MFloatProperty");
@@ -1307,7 +1481,7 @@ static void rna_def_mproperties(BlenderRNA *brna)
        prop= RNA_def_property(srna, "data", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_struct_type(prop, "MeshIntProperty");
        RNA_def_property_ui_text(prop, "Data", "");
-       RNA_def_property_collection_funcs(prop, "rna_MeshIntPropertyLayer_data_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", "rna_MeshIntPropertyLayer_data_length", 0, 0, 0, 0);
+       RNA_def_property_collection_funcs(prop, "rna_MeshIntPropertyLayer_data_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", "rna_MeshIntPropertyLayer_data_length", 0, 0);
 
        srna= RNA_def_struct(brna, "MeshIntProperty", NULL);
        RNA_def_struct_sdna(srna, "MIntProperty");
@@ -1333,7 +1507,7 @@ static void rna_def_mproperties(BlenderRNA *brna)
        prop= RNA_def_property(srna, "data", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_struct_type(prop, "MeshStringProperty");
        RNA_def_property_ui_text(prop, "Data", "");
-       RNA_def_property_collection_funcs(prop, "rna_MeshStringPropertyLayer_data_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", "rna_MeshStringPropertyLayer_data_length", 0, 0, 0, 0);
+       RNA_def_property_collection_funcs(prop, "rna_MeshStringPropertyLayer_data_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", "rna_MeshStringPropertyLayer_data_length", 0, 0);
 
        srna= RNA_def_struct(brna, "MeshStringProperty", NULL);
        RNA_def_struct_sdna(srna, "MStringProperty");
@@ -1381,6 +1555,27 @@ void rna_def_texmat_common(StructRNA *srna, const char *texspace_editable)
        RNA_def_property_ui_text(prop, "Materials", "");
 }
 
+
+/* scene.objects */
+static void rna_def_mesh_faces(BlenderRNA *brna, PropertyRNA *cprop)
+{
+       StructRNA *srna;
+       PropertyRNA *prop;
+
+//     FunctionRNA *func;
+//     PropertyRNA *parm;
+
+       RNA_def_property_srna(cprop, "MeshFaces");
+       srna= RNA_def_struct(brna, "MeshFaces", NULL);
+       RNA_def_struct_sdna(srna, "Mesh");
+       RNA_def_struct_ui_text(srna, "Mesh Faces", "Collection of mesh faces.");
+
+       prop= RNA_def_property(srna, "active", PROP_INT, PROP_NONE);
+       RNA_def_property_int_sdna(prop, NULL, "act_face");
+       RNA_def_property_ui_text(prop, "Active Face", "The active face for this mesh");
+}
+
+
 static void rna_def_mesh(BlenderRNA *brna)
 {
        StructRNA *srna;
@@ -1404,17 +1599,23 @@ static void rna_def_mesh(BlenderRNA *brna)
        RNA_def_property_collection_sdna(prop, NULL, "mface", "totface");
        RNA_def_property_struct_type(prop, "MeshFace");
        RNA_def_property_ui_text(prop, "Faces", "Faces of the mesh.");
+       rna_def_mesh_faces(brna, prop);
 
        prop= RNA_def_property(srna, "sticky", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_collection_sdna(prop, NULL, "msticky", "totvert");
        RNA_def_property_struct_type(prop, "MeshSticky");
        RNA_def_property_ui_text(prop, "Sticky", "Sticky texture coordinates.");
 
-       /* UV textures */
+       /* TODO, should this be allowed to be its self? */
+       prop= RNA_def_property(srna, "texture_mesh", PROP_POINTER, PROP_NONE);
+       RNA_def_property_pointer_sdna(prop, NULL, "texcomesh");
+       RNA_def_property_flag(prop, PROP_EDITABLE|PROP_ID_SELF_CHECK);
+       RNA_def_property_ui_text(prop, "Texture Mesh", "Use another mesh for texture indicies (vertex indicies must be aligned).");
 
+       /* UV textures */
        prop= RNA_def_property(srna, "uv_textures", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_collection_sdna(prop, NULL, "fdata.layers", "fdata.totlayer");
-       RNA_def_property_collection_funcs(prop, "rna_Mesh_uv_textures_begin", 0, 0, 0, "rna_Mesh_uv_textures_length", 0, 0, 0, 0);
+       RNA_def_property_collection_funcs(prop, "rna_Mesh_uv_textures_begin", 0, 0, 0, "rna_Mesh_uv_textures_length", 0, 0);
        RNA_def_property_struct_type(prop, "MeshTextureFaceLayer");
        RNA_def_property_ui_text(prop, "UV Textures", "");
 
@@ -1430,11 +1631,31 @@ static void rna_def_mesh(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Active UV Texture Index", "Active UV texture index.");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 
+       prop= RNA_def_property(srna, "uv_texture_clone", PROP_POINTER, PROP_UNSIGNED);
+       RNA_def_property_struct_type(prop, "MeshTextureFaceLayer");
+       RNA_def_property_pointer_funcs(prop, "rna_Mesh_uv_texture_clone_get", "rna_Mesh_uv_texture_clone_set", NULL);
+       RNA_def_property_flag(prop, PROP_EDITABLE);
+       RNA_def_property_ui_text(prop, "Clone UV Texture", "UV texture to be used as cloning source.");
+
+       prop= RNA_def_property(srna, "uv_texture_clone_index", PROP_INT, PROP_UNSIGNED);
+       RNA_def_property_int_funcs(prop, "rna_Mesh_uv_texture_clone_index_get", "rna_Mesh_uv_texture_clone_index_set", "rna_Mesh_active_uv_texture_index_range");
+       RNA_def_property_ui_text(prop, "Clone UV Texture Index", "Clone UV texture index.");
+
+       prop= RNA_def_property(srna, "uv_texture_stencil", PROP_POINTER, PROP_UNSIGNED);
+       RNA_def_property_struct_type(prop, "MeshTextureFaceLayer");
+       RNA_def_property_pointer_funcs(prop, "rna_Mesh_uv_texture_stencil_get", "rna_Mesh_uv_texture_stencil_set", NULL);
+       RNA_def_property_flag(prop, PROP_EDITABLE);
+       RNA_def_property_ui_text(prop, "Mask UV Texture", "UV texture to mask the painted area.");
+
+       prop= RNA_def_property(srna, "uv_texture_stencil_index", PROP_INT, PROP_UNSIGNED);
+       RNA_def_property_int_funcs(prop, "rna_Mesh_uv_texture_stencil_index_get", "rna_Mesh_uv_texture_stencil_index_set", "rna_Mesh_active_uv_texture_index_range");
+       RNA_def_property_ui_text(prop, "Mask UV Texture Index", "Mask UV texture index.");
+
        /* Vertex colors */
 
        prop= RNA_def_property(srna, "vertex_colors", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_collection_sdna(prop, NULL, "fdata.layers", "fdata.totlayer");
-       RNA_def_property_collection_funcs(prop, "rna_Mesh_vertex_colors_begin", 0, 0, 0, "rna_Mesh_vertex_colors_length", 0, 0, 0, 0);
+       RNA_def_property_collection_funcs(prop, "rna_Mesh_vertex_colors_begin", 0, 0, 0, "rna_Mesh_vertex_colors_length", 0, 0);
        RNA_def_property_struct_type(prop, "MeshColorLayer");
        RNA_def_property_ui_text(prop, "Vertex Colors", "");
 
@@ -1452,19 +1673,19 @@ static void rna_def_mesh(BlenderRNA *brna)
 
        prop= RNA_def_property(srna, "float_layers", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_collection_sdna(prop, NULL, "fdata.layers", "fdata.totlayer");
-       RNA_def_property_collection_funcs(prop, "rna_Mesh_float_layers_begin", 0, 0, 0, "rna_Mesh_float_layers_length", 0, 0, 0, 0);
+       RNA_def_property_collection_funcs(prop, "rna_Mesh_float_layers_begin", 0, 0, 0, "rna_Mesh_float_layers_length", 0, 0);
        RNA_def_property_struct_type(prop, "MeshFloatPropertyLayer");
        RNA_def_property_ui_text(prop, "Float Property Layers", "");
 
        prop= RNA_def_property(srna, "int_layers", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_collection_sdna(prop, NULL, "fdata.layers", "fdata.totlayer");
-       RNA_def_property_collection_funcs(prop, "rna_Mesh_int_layers_begin", 0, 0, 0, "rna_Mesh_int_layers_length", 0, 0, 0, 0);
+       RNA_def_property_collection_funcs(prop, "rna_Mesh_int_layers_begin", 0, 0, 0, "rna_Mesh_int_layers_length", 0, 0);
        RNA_def_property_struct_type(prop, "MeshIntPropertyLayer");
        RNA_def_property_ui_text(prop, "Int Property Layers", "");
 
        prop= RNA_def_property(srna, "string_layers", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_collection_sdna(prop, NULL, "fdata.layers", "fdata.totlayer");
-       RNA_def_property_collection_funcs(prop, "rna_Mesh_string_layers_begin", 0, 0, 0, "rna_Mesh_string_layers_length", 0, 0, 0, 0);
+       RNA_def_property_collection_funcs(prop, "rna_Mesh_string_layers_begin", 0, 0, 0, "rna_Mesh_string_layers_length", 0, 0);
        RNA_def_property_struct_type(prop, "MeshStringPropertyLayer");
        RNA_def_property_ui_text(prop, "String Property Layers", "");
 
@@ -1502,6 +1723,10 @@ static void rna_def_mesh(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Draw Edges", "Displays selected edges using hilights in the 3d view and UV editor");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
        
+       prop= RNA_def_property(srna, "all_edges", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_ALLEDGES);
+       RNA_def_property_ui_text(prop, "All Edges", "Displays all edges for wireframe in all view modes in the 3d view");
+
        prop= RNA_def_property(srna, "draw_faces", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_DRAWFACES);
        RNA_def_property_ui_text(prop, "Draw Faces", "Displays all faces as shades in the 3d view and UV editor");
@@ -1536,8 +1761,7 @@ static void rna_def_mesh(BlenderRNA *brna)
        RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_DRAWSHARP);
        RNA_def_property_ui_text(prop, "Draw Sharp", "Displays sharp edges, used with the EdgeSplit modifier");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
-       
-       
+
        prop= RNA_def_property(srna, "draw_edge_lenght", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_DRAW_EDGELEN);
        RNA_def_property_ui_text(prop, "Edge Length", "Displays selected edge lengths");
@@ -1553,6 +1777,28 @@ static void rna_def_mesh(BlenderRNA *brna)
        RNA_def_property_ui_text(prop, "Face Area", "Displays the area of selected faces");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
 
+       /* editflag */
+       prop= RNA_def_property(srna, "use_mirror_x", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "editflag", ME_EDIT_MIRROR_X);
+       RNA_def_property_ui_text(prop, "X Mirror", "X Axis mirror editing");
+
+       /*
+       prop= RNA_def_property(srna, "use_mirror_y", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "editflag", ME_EDIT_MIRROR_Y);
+       RNA_def_property_ui_text(prop, "Y Mirror", "Y Axis mirror editing");
+
+       prop= RNA_def_property(srna, "use_mirror_x", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "editflag", ME_EDIT_MIRROR_Z);
+       RNA_def_property_ui_text(prop, "Z Mirror", "Z Axis mirror editing");
+        */
+
+       prop= RNA_def_property(srna, "use_paint_mask", PROP_BOOLEAN, PROP_NONE);
+       RNA_def_property_boolean_sdna(prop, NULL, "editflag", ME_EDIT_PAINT_MASK);
+       RNA_def_property_ui_text(prop, "Paint Mask", "Face selection masking for painting");
+       RNA_def_property_ui_icon(prop, ICON_FACESEL_HLT, 0);
+       RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
+
+
        rna_def_texmat_common(srna, "rna_Mesh_texspace_editable");
 
        RNA_api_mesh(srna);