Merge branch 'master' into blender2.8
authorCampbell Barton <ideasman42@gmail.com>
Wed, 8 Aug 2018 01:33:42 +0000 (11:33 +1000)
committerCampbell Barton <ideasman42@gmail.com>
Wed, 8 Aug 2018 01:33:42 +0000 (11:33 +1000)
1  2 
source/blender/makesrna/intern/rna_mesh.c
source/blender/python/bmesh/bmesh_py_types_meshdata.c

index 7eed5e03d01c574dc9ef01ed1166d317bc94439b,c97cf2923f2e8772322d1875aaa08b3b3b5f6dfd..50f2d49c1b5e3762a87c93d5df8e15dd3420b603
@@@ -68,12 -68,11 +68,12 @@@ const EnumPropertyItem rna_enum_mesh_de
  #include "BLI_math.h"
  
  #include "BKE_customdata.h"
 -#include "BKE_depsgraph.h"
  #include "BKE_main.h"
  #include "BKE_mesh.h"
  #include "BKE_report.h"
  
 +#include "DEG_depsgraph.h"
 +
  #include "ED_mesh.h" /* XXX Bad level call */
  
  #include "WM_api.h"
@@@ -187,10 -186,12 +187,10 @@@ static void rna_MeshEdgeLayer_name_set(
        rna_cd_layer_name_set(rna_mesh_edata(ptr), (CustomDataLayer *)ptr->data, value);
  }
  #endif
 -#if 0
  static void rna_MeshPolyLayer_name_set(PointerRNA *ptr, const char *value)
  {
        rna_cd_layer_name_set(rna_mesh_pdata(ptr), (CustomDataLayer *)ptr->data, value);
  }
 -#endif
  static void rna_MeshLoopLayer_name_set(PointerRNA *ptr, const char *value)
  {
        rna_cd_layer_name_set(rna_mesh_ldata(ptr), (CustomDataLayer *)ptr->data, value);
@@@ -223,7 -224,7 +223,7 @@@ static void rna_Mesh_update_data(Main *
  
        /* cheating way for importers to avoid slow updates */
        if (id->us > 0) {
 -              DAG_id_tag_update(id, 0);
 +              DEG_id_tag_update(id, 0);
                WM_main_add_notifier(NC_GEOM | ND_DATA, id);
        }
  }
@@@ -237,20 -238,6 +237,20 @@@ static void rna_Mesh_update_data_edit_c
        }
  }
  
 +static void rna_Mesh_update_data_edit_weight(Main *bmain, Scene *scene, PointerRNA *ptr)
 +{
 +      BKE_mesh_batch_cache_dirty(rna_mesh(ptr), BKE_MESH_BATCH_DIRTY_ALL);
 +
 +      rna_Mesh_update_data(bmain, scene, ptr);
 +}
 +
 +
 +static void rna_Mesh_update_data_edit_active_color(Main *bmain, Scene *scene, PointerRNA *ptr)
 +{
 +      BKE_mesh_batch_cache_dirty(rna_mesh(ptr), BKE_MESH_BATCH_DIRTY_ALL);
 +
 +      rna_Mesh_update_data(bmain, scene, ptr);
 +}
  static void rna_Mesh_update_select(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
  {
        ID *id = ptr->id.data;
@@@ -276,9 -263,6 +276,9 @@@ static void rna_Mesh_update_vertmask(Ma
        if ((me->editflag & ME_EDIT_PAINT_VERT_SEL) && (me->editflag & ME_EDIT_PAINT_FACE_SEL)) {
                me->editflag &= ~ME_EDIT_PAINT_FACE_SEL;
        }
 +
 +      BKE_mesh_batch_cache_dirty(me, BKE_MESH_BATCH_DIRTY_ALL);
 +
        rna_Mesh_update_draw(bmain, scene, ptr);
  }
  
@@@ -288,9 -272,6 +288,9 @@@ static void rna_Mesh_update_facemask(Ma
        if ((me->editflag & ME_EDIT_PAINT_VERT_SEL) && (me->editflag & ME_EDIT_PAINT_FACE_SEL)) {
                me->editflag &= ~ME_EDIT_PAINT_VERT_SEL;
        }
 +
 +      BKE_mesh_batch_cache_dirty(me, BKE_MESH_BATCH_DIRTY_ALL);
 +
        rna_Mesh_update_draw(bmain, scene, ptr);
  }
  
@@@ -777,6 -758,13 +777,6 @@@ static void rna_CustomDataLayer_active_
        if (render) CustomData_set_layer_render(data, type, n);
        else CustomData_set_layer_active(data, type, n);
  
 -      /* sync loop layer */
 -      if (type == CD_MTEXPOLY) {
 -              CustomData *ldata = rna_mesh_ldata(ptr);
 -              if (render) CustomData_set_layer_render(ldata, CD_MLOOPUV, n);
 -              else CustomData_set_layer_active(ldata, CD_MLOOPUV, n);
 -      }
 -
        BKE_mesh_update_customdata_pointers(me, true);
  }
  
@@@ -881,36 -869,6 +881,36 @@@ static int rna_MeshUVLoopLayer_data_len
        return (me->edit_btmesh) ? 0 : me->totloop;
  }
  
 +static bool rna_MeshUVLoopLayer_active_render_get(PointerRNA *ptr)
 +{
 +      return rna_CustomDataLayer_active_get(ptr, rna_mesh_ldata(ptr), CD_MLOOPUV, 1);
 +}
 +
 +static bool rna_MeshUVLoopLayer_active_get(PointerRNA *ptr)
 +{
 +      return rna_CustomDataLayer_active_get(ptr, rna_mesh_ldata(ptr), CD_MLOOPUV, 0);
 +}
 +
 +static bool rna_MeshUVLoopLayer_clone_get(PointerRNA *ptr)
 +{
 +      return rna_CustomDataLayer_clone_get(ptr, rna_mesh_ldata(ptr), CD_MLOOPUV);
 +}
 +
 +static void rna_MeshUVLoopLayer_active_render_set(PointerRNA *ptr, bool value)
 +{
 +      rna_CustomDataLayer_active_set(ptr, rna_mesh_ldata(ptr), value, CD_MLOOPUV, 1);
 +}
 +
 +static void rna_MeshUVLoopLayer_active_set(PointerRNA *ptr, bool value)
 +{
 +      rna_CustomDataLayer_active_set(ptr, rna_mesh_ldata(ptr), value, CD_MLOOPUV, 0);
 +}
 +
 +static void rna_MeshUVLoopLayer_clone_set(PointerRNA *ptr, bool value)
 +{
 +      rna_CustomDataLayer_clone_set(ptr, rna_mesh_ldata(ptr), value, CD_MLOOPUV);
 +}
 +
  /* face uv_textures */
  
  DEFINE_CUSTOMDATA_LAYER_COLLECTION(tessface_uv_texture, fdata, CD_MTFACE)
@@@ -962,6 -920,57 +962,6 @@@ static void rna_MeshTextureFaceLayer_cl
        rna_CustomDataLayer_clone_set(ptr, rna_mesh_fdata(ptr), value, CD_MTFACE);
  }
  
 -/* poly uv_textures */
 -
 -DEFINE_CUSTOMDATA_LAYER_COLLECTION(uv_texture, pdata, CD_MTEXPOLY)
 -DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(uv_texture, pdata, CD_MTEXPOLY, active, MeshTexturePolyLayer)
 -DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(uv_texture, pdata, CD_MTEXPOLY, clone, MeshTexturePolyLayer)
 -DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(uv_texture, pdata, CD_MTEXPOLY, stencil, MeshTexturePolyLayer)
 -DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(uv_texture, pdata, CD_MTEXPOLY, render, MeshTexturePolyLayer)
 -
 -static void rna_MeshTexturePolyLayer_data_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
 -{
 -      Mesh *me = rna_mesh(ptr);
 -      CustomDataLayer *layer = (CustomDataLayer *)ptr->data;
 -      rna_iterator_array_begin(iter, layer->data, sizeof(MTexPoly), (me->edit_btmesh) ? 0 : me->totpoly, 0, NULL);
 -}
 -
 -static int rna_MeshTexturePolyLayer_data_length(PointerRNA *ptr)
 -{
 -      Mesh *me = rna_mesh(ptr);
 -      return (me->edit_btmesh) ? 0 : me->totpoly;
 -}
 -
 -static bool rna_MeshTexturePolyLayer_active_render_get(PointerRNA *ptr)
 -{
 -      return rna_CustomDataLayer_active_get(ptr, rna_mesh_pdata(ptr), CD_MTEXPOLY, 1);
 -}
 -
 -static bool rna_MeshTexturePolyLayer_active_get(PointerRNA *ptr)
 -{
 -      return rna_CustomDataLayer_active_get(ptr, rna_mesh_pdata(ptr), CD_MTEXPOLY, 0);
 -}
 -
 -static bool rna_MeshTexturePolyLayer_clone_get(PointerRNA *ptr)
 -{
 -      return rna_CustomDataLayer_clone_get(ptr, rna_mesh_pdata(ptr), CD_MTEXPOLY);
 -}
 -
 -static void rna_MeshTexturePolyLayer_active_render_set(PointerRNA *ptr, bool value)
 -{
 -      rna_CustomDataLayer_active_set(ptr, rna_mesh_pdata(ptr), value, CD_MTEXPOLY, 1);
 -}
 -
 -static void rna_MeshTexturePolyLayer_active_set(PointerRNA *ptr, int value)
 -{
 -      rna_CustomDataLayer_active_set(ptr, rna_mesh_pdata(ptr), value, CD_MTEXPOLY, 0);
 -}
 -
 -static void rna_MeshTexturePolyLayer_clone_set(PointerRNA *ptr, bool value)
 -{
 -      rna_CustomDataLayer_clone_set(ptr, rna_mesh_pdata(ptr), value, CD_MTEXPOLY);
 -}
 -
  /* vertex_color_layers */
  
  DEFINE_CUSTOMDATA_LAYER_COLLECTION(tessface_vertex_color, fdata, CD_MCOL)
@@@ -1185,75 -1194,42 +1185,75 @@@ static int rna_MeshPaintMaskLayer_data_
  
  /* End paint mask */
  
 -static void rna_TexturePoly_image_set(PointerRNA *ptr, PointerRNA value)
 +/* Face maps */
 +
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION(face_map, pdata, CD_FACEMAP)
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(face_map, pdata, CD_FACEMAP, active, MeshFaceMapLayer)
 +
 +static char *rna_MeshFaceMapLayer_path(PointerRNA *ptr)
  {
 -      MTexPoly *tf = (MTexPoly *)ptr->data;
 -      ID *id = value.data;
 +      CustomDataLayer *cdl = ptr->data;
 +      char name_esc[sizeof(cdl->name) * 2];
 +      BLI_strescape(name_esc, cdl->name, sizeof(name_esc));
 +      return BLI_sprintfN("face_maps[\"%s\"]", name_esc);
 +}
  
 -      if (id) {
 -              /* special exception here, individual faces don't count
 -               * as reference, but we do ensure the refcount is not zero */
 -              if (id->us == 0)
 -                      id_us_plus(id);
 -              else
 -                      id_lib_extern(id);
 +static void rna_MeshFaceMapLayer_data_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
 +{
 +      Mesh *me = rna_mesh(ptr);
 +      CustomDataLayer *layer = (CustomDataLayer *)ptr->data;
 +      rna_iterator_array_begin(iter, layer->data, sizeof(int), me->totpoly, 0, NULL);
 +}
 +
 +static int rna_MeshFaceMapLayer_data_length(PointerRNA *ptr)
 +{
 +      Mesh *me = rna_mesh(ptr);
 +      return me->totpoly;
 +}
 +
 +static PointerRNA rna_Mesh_face_map_new(struct Mesh *me, ReportList *reports, const char *name)
 +{
 +      if (BKE_mesh_ensure_facemap_customdata(me) == false) {
 +              BKE_report(reports, RPT_ERROR, "Currently only single face-map layers are supported");
 +              return PointerRNA_NULL;
        }
  
 -      tf->tpage = (struct Image *)id;
 +      CustomData *pdata = rna_mesh_pdata_helper(me);
 +
 +      int index = CustomData_get_layer_index(pdata, CD_FACEMAP);
 +      BLI_assert(index != -1);
 +      CustomDataLayer *cdl = &pdata->layers[index];
 +      rna_cd_layer_name_set(pdata, cdl, name);
 +
 +      PointerRNA ptr;
 +      RNA_pointer_create(&me->id, &RNA_MeshFaceMapLayer, cdl, &ptr);
 +      return ptr;
  }
  
 -/* while this is supposed to be readonly,
 - * keep it to support importers that only make tessfaces */
 -static void rna_TextureFace_image_set(PointerRNA *ptr, PointerRNA value)
 -{
 -      MTFace *tf = (MTFace *)ptr->data;
 -      ID *id = value.data;
 -
 -      if (id) {
 -              /* special exception here, individual faces don't count
 -               * as reference, but we do ensure the refcount is not zero */
 -              if (id->us == 0)
 -                      id_us_plus(id);
 -              else
 -                      id_lib_extern(id);
 +static void rna_Mesh_face_map_remove(struct Mesh *me, ReportList *reports, struct CustomDataLayer *layer)
 +{
 +      /* just for sanity check */
 +      {
 +              CustomData *pdata = rna_mesh_pdata_helper(me);
 +              int index = CustomData_get_layer_index(pdata, CD_FACEMAP);
 +              if (index != -1) {
 +                      CustomDataLayer *layer_test = &pdata->layers[index];
 +                      if (layer != layer_test) {
 +                              /* don't show name, its likely freed memory */
 +                              BKE_report(reports, RPT_ERROR, "FaceMap not in mesh");
 +                              return;
 +                      }
 +              }
        }
  
 -      tf->tpage = (struct Image *)id;
 +      if (BKE_mesh_clear_facemap_customdata(me) == false) {
 +              BKE_reportf(reports, RPT_ERROR, "Error removing face-map");
 +      }
  }
  
 +/* End face maps */
 +
 +
  static int rna_MeshTessFace_verts_get_length(PointerRNA *ptr, int length[RNA_MAX_ARRAY_DIMENSION])
  {
        MFace *face = (MFace *)ptr->data;
@@@ -1404,6 -1380,14 +1404,6 @@@ static char *rna_MeshTextureFaceLayer_p
        return BLI_sprintfN("tessface_uv_textures[\"%s\"]", name_esc);
  }
  
 -static char *rna_MeshTexturePolyLayer_path(PointerRNA *ptr)
 -{
 -      CustomDataLayer *cdl = ptr->data;
 -      char name_esc[sizeof(cdl->name) * 2];
 -      BLI_strescape(name_esc, cdl->name, sizeof(name_esc));
 -      return BLI_sprintfN("uv_textures[\"%s\"]", name_esc);
 -}
 -
  static char *rna_VertCustomData_data_path(PointerRNA *ptr, const char *collection, int type)
  {
        CustomDataLayer *cdl;
@@@ -1499,6 -1483,11 +1499,6 @@@ static char *rna_MeshTextureFace_path(P
        return rna_FaceCustomData_data_path(ptr, "tessface_uv_textures", CD_MTFACE);
  }
  
 -static char *rna_MeshTexturePoly_path(PointerRNA *ptr)
 -{
 -      return rna_PolyCustomData_data_path(ptr, "uv_textures", CD_MTEXPOLY);
 -}
 -
  static char *rna_MeshColorLayer_path(PointerRNA *ptr)
  {
        CustomDataLayer *cdl = ptr->data;
@@@ -1686,12 -1675,6 +1686,12 @@@ void rna_MeshStringProperty_s_set(Point
        MStringProperty *ms = (MStringProperty *)ptr->data;
        BLI_strncpy(ms->s, value, sizeof(ms->s));
  }
 +
 +static char *rna_MeshFaceMap_path(PointerRNA *ptr)
 +{
 +      return rna_PolyCustomData_data_path(ptr, "face_maps", CD_FACEMAP);
 +}
 +
  /***************************************/
  
  static int rna_Mesh_tot_vert_get(PointerRNA *ptr)
@@@ -1785,23 -1768,23 +1785,23 @@@ DEFINE_CUSTOMDATA_PROPERTY_API(polygon
  DEFINE_CUSTOMDATA_PROPERTY_API(polygon, string, CD_PROP_STR, pdata, totpoly, MeshPolygonStringPropertyLayer)
  #undef DEFINE_CUSTOMDATA_PROPERTY_API
  
 -static PointerRNA rna_Mesh_uv_texture_new(struct Mesh *me, const char *name)
 +static PointerRNA rna_Mesh_uv_layers_new(struct Mesh *me, const char *name)
  {
        PointerRNA ptr;
 -      CustomData *pdata;
 +      CustomData *ldata;
        CustomDataLayer *cdl = NULL;
        int index = ED_mesh_uv_texture_add(me, name, false);
  
        if (index != -1) {
 -              pdata = rna_mesh_pdata_helper(me);
 -              cdl = &pdata->layers[CustomData_get_layer_index_n(pdata, CD_MTEXPOLY, index)];
 +              ldata = rna_mesh_ldata_helper(me);
 +              cdl = &ldata->layers[CustomData_get_layer_index_n(ldata, CD_MLOOPUV, index)];
        }
  
 -      RNA_pointer_create(&me->id, &RNA_MeshTexturePolyLayer, cdl, &ptr);
 +      RNA_pointer_create(&me->id, &RNA_MeshUVLoopLayer, cdl, &ptr);
        return ptr;
  }
  
 -static void rna_Mesh_uv_texture_layers_remove(struct Mesh *me, ReportList *reports, CustomDataLayer *layer)
 +static void rna_Mesh_uv_layers_remove(struct Mesh *me, ReportList *reports, CustomDataLayer *layer)
  {
        if (ED_mesh_uv_texture_remove_named(me, layer->name) == false) {
                BKE_reportf(reports, RPT_ERROR, "Texture layer '%s' not found", layer->name);
@@@ -1876,14 -1859,14 +1876,14 @@@ static void UNUSED_FUNCTION(rna_mesh_un
        (void)rna_Mesh_uv_layer_render_index_get;
        (void)rna_Mesh_uv_layer_render_index_set;
        (void)rna_Mesh_uv_layer_render_set;
 -      (void)rna_Mesh_uv_texture_render_get;
 -      (void)rna_Mesh_uv_texture_render_index_get;
 -      (void)rna_Mesh_uv_texture_render_index_set;
 -      (void)rna_Mesh_uv_texture_render_set;
        (void)rna_Mesh_vertex_color_render_get;
        (void)rna_Mesh_vertex_color_render_index_get;
        (void)rna_Mesh_vertex_color_render_index_set;
        (void)rna_Mesh_vertex_color_render_set;
 +      (void)rna_Mesh_face_map_index_range;
 +      (void)rna_Mesh_face_map_active_index_set;
 +      (void)rna_Mesh_face_map_active_index_get;
 +      (void)rna_Mesh_face_map_active_set;
        /* end unused function block */
  }
  
@@@ -1911,7 -1894,7 +1911,7 @@@ static void rna_def_mvert_group(Blender
        prop = RNA_def_property(srna, "weight", PROP_FLOAT, PROP_NONE);
        RNA_def_property_range(prop, 0.0f, 1.0f);
        RNA_def_property_ui_text(prop, "Weight", "Vertex Weight");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data_edit_weight");
  }
  
  static void rna_def_mvert(BlenderRNA *brna)
@@@ -2281,24 -2264,6 +2281,24 @@@ static void rna_def_mloopuv(BlenderRNA 
        RNA_def_property_ui_text(prop, "Name", "Name of UV map");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
  
 +      prop = RNA_def_property(srna, "active", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_funcs(prop, "rna_MeshUVLoopLayer_active_get", "rna_MeshUVLoopLayer_active_set");
 +      RNA_def_property_ui_text(prop, "Active", "Set the map as active for display and editing");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +
 +      prop = RNA_def_property(srna, "active_render", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_sdna(prop, NULL, "active_rnd", 0);
 +      RNA_def_property_boolean_funcs(prop, "rna_MeshUVLoopLayer_active_render_get",
 +                                     "rna_MeshUVLoopLayer_active_render_set");
 +      RNA_def_property_ui_text(prop, "Active Render", "Set the map 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_MeshUVLoopLayer_clone_get", "rna_MeshUVLoopLayer_clone_set");
 +      RNA_def_property_ui_text(prop, "Active Clone", "Set the map as active for cloning");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +
        srna = RNA_def_struct(brna, "MeshUVLoop", NULL);
        RNA_def_struct_sdna(srna, "MLoopUV");
        RNA_def_struct_path_func(srna, "rna_MeshUVLoop_path");
@@@ -2368,6 -2333,13 +2368,6 @@@ static void rna_def_mtface(BlenderRNA *
        RNA_def_struct_path_func(srna, "rna_MeshTextureFace_path");
        RNA_def_struct_ui_icon(srna, ICON_FACESEL_HLT);
  
 -      prop = RNA_def_property(srna, "image", PROP_POINTER, PROP_NONE);
 -      RNA_def_property_pointer_sdna(prop, NULL, "tpage");
 -      RNA_def_property_pointer_funcs(prop, NULL, "rna_TextureFace_image_set", NULL, NULL);
 -      RNA_def_property_flag(prop, PROP_EDITABLE);
 -      RNA_def_property_ui_text(prop, "Image", "");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 -
        /* these are for editing only, access at loops now */
  #if 0
        prop = RNA_def_property(srna, "select_uv", PROP_BOOLEAN, PROP_NONE);
  
  }
  
 -static void rna_def_mtexpoly(BlenderRNA *brna)
 -{
 -      StructRNA *srna;
 -      PropertyRNA *prop;
 -#if 0  /* BMESH_TODO: needed later when do another todo */
 -      int uv_dim[] = {4, 2};
 -#endif
 -
 -      srna = RNA_def_struct(brna, "MeshTexturePolyLayer", NULL);
 -      RNA_def_struct_ui_text(srna, "Mesh UV Map", "UV map with assigned image textures in a Mesh data-block");
 -      RNA_def_struct_sdna(srna, "CustomDataLayer");
 -      RNA_def_struct_path_func(srna, "rna_MeshTexturePolyLayer_path");
 -      RNA_def_struct_ui_icon(srna, ICON_GROUP_UVS);
 -
 -      prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
 -      RNA_def_struct_name_property(srna, prop);
 -      RNA_def_property_string_funcs(prop, NULL, NULL, "rna_MeshUVLayer_name_set");
 -      RNA_def_property_ui_text(prop, "Name", "Name of UV map");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 -
 -      prop = RNA_def_property(srna, "active", PROP_BOOLEAN, PROP_NONE);
 -      RNA_def_property_boolean_funcs(prop, "rna_MeshTexturePolyLayer_active_get", "rna_MeshTexturePolyLayer_active_set");
 -      RNA_def_property_ui_text(prop, "Active", "Set the map as active for display and editing");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 -
 -      prop = RNA_def_property(srna, "active_render", PROP_BOOLEAN, PROP_NONE);
 -      RNA_def_property_boolean_sdna(prop, NULL, "active_rnd", 0);
 -      RNA_def_property_boolean_funcs(prop, "rna_MeshTexturePolyLayer_active_render_get",
 -                                     "rna_MeshTexturePolyLayer_active_render_set");
 -      RNA_def_property_ui_text(prop, "Active Render", "Set the map 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_MeshTexturePolyLayer_clone_get", "rna_MeshTexturePolyLayer_clone_set");
 -      RNA_def_property_ui_text(prop, "Active Clone", "Set the map 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, "MeshTexturePoly");
 -      RNA_def_property_ui_text(prop, "Data", "");
 -      RNA_def_property_collection_funcs(prop, "rna_MeshTexturePolyLayer_data_begin", "rna_iterator_array_next",
 -                                        "rna_iterator_array_end", "rna_iterator_array_get",
 -                                        "rna_MeshTexturePolyLayer_data_length", NULL, NULL, NULL);
 -
 -      srna = RNA_def_struct(brna, "MeshTexturePoly", NULL);
 -      RNA_def_struct_sdna(srna, "MTexPoly");
 -      RNA_def_struct_ui_text(srna, "Mesh UV Map Face", "UV map and image texture for a face");
 -      RNA_def_struct_path_func(srna, "rna_MeshTexturePoly_path");
 -      RNA_def_struct_ui_icon(srna, ICON_FACESEL_HLT);
 -
 -      prop = RNA_def_property(srna, "image", PROP_POINTER, PROP_NONE);
 -      RNA_def_property_pointer_sdna(prop, NULL, "tpage");
 -      RNA_def_property_pointer_funcs(prop, NULL, "rna_TexturePoly_image_set", NULL, NULL);
 -      RNA_def_property_flag(prop, PROP_EDITABLE);
 -      RNA_def_property_ui_text(prop, "Image", "");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 -
 -#if 0 /* moved to MeshUVLoopLayer */
 -      prop = RNA_def_property(srna, "select_uv", PROP_BOOLEAN, PROP_NONE);
 -      RNA_def_property_boolean_sdna(prop, NULL, "flag", TF_SEL1);
 -      RNA_def_property_array(prop, 4);
 -      RNA_def_property_ui_text(prop, "UV Selected", "");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_select");
 -
 -      prop = RNA_def_property(srna, "pin_uv", PROP_BOOLEAN, PROP_NONE);
 -      RNA_def_property_boolean_sdna(prop, NULL, "unwrap", TF_PIN1);
 -      RNA_def_property_array(prop, 4);
 -      RNA_def_property_ui_text(prop, "UV Pinned", "");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_select");
 -
 -      prop = RNA_def_property(srna, "uv_raw", PROP_FLOAT, PROP_NONE);
 -      RNA_def_property_multi_array(prop, 2, uv_dim);
 -      RNA_def_property_float_sdna(prop, NULL, "uv");
 -      RNA_def_property_ui_text(prop, "UV", "Fixed size UV coordinates array");
 -#endif
 -}
 -
  static void rna_def_mcol(BlenderRNA *brna)
  {
        StructRNA *srna;
@@@ -2888,13 -2938,13 +2888,13 @@@ static void rna_def_loop_colors(Blender
                                       "rna_Mesh_vertex_color_active_set", NULL, NULL);
        RNA_def_property_flag(prop, PROP_EDITABLE | PROP_NEVER_UNLINK);
        RNA_def_property_ui_text(prop, "Active Vertex Color Layer", "Active vertex color layer");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data_edit_active_color");
  
        prop = RNA_def_property(srna, "active_index", PROP_INT, PROP_UNSIGNED);
        RNA_def_property_int_funcs(prop, "rna_Mesh_vertex_color_active_index_get",
                                   "rna_Mesh_vertex_color_active_index_set", "rna_Mesh_vertex_color_index_range");
        RNA_def_property_ui_text(prop, "Active Vertex Color Index", "Active vertex color index");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data_edit_active_color");
  }
  
  static void rna_def_uv_layers(BlenderRNA *brna, PropertyRNA *cprop)
        StructRNA *srna;
        PropertyRNA *prop;
  
 -      /* FunctionRNA *func; */
 -      /* PropertyRNA *parm; */
 +      FunctionRNA *func;
 +      PropertyRNA *parm;
  
        RNA_def_property_srna(cprop, "UVLoopLayers");
        srna = RNA_def_struct(brna, "UVLoopLayers", NULL);
        RNA_def_struct_sdna(srna, "Mesh");
        RNA_def_struct_ui_text(srna, "UV Loop Layers", "Collection of uv loop layers");
  
 +      func = RNA_def_function(srna, "new", "rna_Mesh_uv_layers_new");
 +      RNA_def_function_ui_description(func, "Add a UV map layer to Mesh");
 +      RNA_def_string(func, "name", "UVMap", 0, "", "UV map name");
 +      parm = RNA_def_pointer(func, "layer", "MeshUVLoopLayer", "", "The newly created layer");
 +      RNA_def_parameter_flags(parm, 0, PARM_RNAPTR);
 +      RNA_def_function_return(func, parm);
 +
 +      func = RNA_def_function(srna, "remove", "rna_Mesh_uv_layers_remove");
 +      RNA_def_function_ui_description(func, "Remove a vertex color layer");
 +      RNA_def_function_flag(func, FUNC_USE_REPORTS);
 +      parm = RNA_def_pointer(func, "layer", "MeshUVLoopLayer", "", "The layer to remove");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +
        prop = RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
        RNA_def_property_struct_type(prop, "MeshUVLoopLayer");
        RNA_def_property_pointer_funcs(prop, "rna_Mesh_uv_layer_active_get",
@@@ -3087,6 -3124,7 +3087,6 @@@ static void rna_def_tessface_uv_texture
        RNA_def_parameter_flags(parm, 0, PARM_RNAPTR);
        RNA_def_function_return(func, parm);
  
 -
        prop = RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
        RNA_def_property_struct_type(prop, "MeshTextureFaceLayer");
        RNA_def_property_pointer_funcs(prop, "rna_Mesh_tessface_uv_texture_active_get",
  
        prop = RNA_def_property(srna, "active_index", PROP_INT, PROP_UNSIGNED);
        RNA_def_property_int_funcs(prop, "rna_Mesh_tessface_uv_texture_active_index_get",
 -                                 "rna_Mesh_tessface_uv_texture_active_index_set", "rna_Mesh_uv_texture_index_range");
 -      RNA_def_property_ui_text(prop, "Active UV Map Index", "Active UV Map index");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 -}
 -
 -
 -static void rna_def_uv_textures(BlenderRNA *brna, PropertyRNA *cprop)
 -{
 -      StructRNA *srna;
 -      PropertyRNA *prop;
 -
 -      FunctionRNA *func;
 -      PropertyRNA *parm;
 -
 -      RNA_def_property_srna(cprop, "UVTextures");
 -      srna = RNA_def_struct(brna, "UVTextures", NULL);
 -      RNA_def_struct_sdna(srna, "Mesh");
 -      RNA_def_struct_ui_text(srna, "UV Maps", "Collection of UV maps");
 -
 -      func = RNA_def_function(srna, "new", "rna_Mesh_uv_texture_new");
 -      RNA_def_function_ui_description(func, "Add a UV map layer to Mesh");
 -      RNA_def_string(func, "name", "UVMap", 0, "", "UV map name");
 -      parm = RNA_def_pointer(func, "layer", "MeshTexturePolyLayer", "", "The newly created layer");
 -      RNA_def_parameter_flags(parm, 0, PARM_RNAPTR);
 -      RNA_def_function_return(func, parm);
 -
 -      func = RNA_def_function(srna, "remove", "rna_Mesh_uv_texture_layers_remove");
 -      RNA_def_function_ui_description(func, "Remove a vertex color layer");
 -      RNA_def_function_flag(func, FUNC_USE_REPORTS);
 -      parm = RNA_def_pointer(func, "layer", "MeshTexturePolyLayer", "", "The layer to remove");
 -      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 -
 -      prop = RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
 -      RNA_def_property_struct_type(prop, "MeshTexturePolyLayer");
 -      RNA_def_property_pointer_funcs(prop, "rna_Mesh_uv_texture_active_get",
 -                                     "rna_Mesh_uv_texture_active_set", NULL, NULL);
 -      RNA_def_property_flag(prop, PROP_EDITABLE | PROP_NEVER_UNLINK);
 -      RNA_def_property_ui_text(prop, "Active UV Map", "Active UV Map");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 -
 -      prop = RNA_def_property(srna, "active_index", PROP_INT, PROP_UNSIGNED);
 -      RNA_def_property_int_funcs(prop, "rna_Mesh_uv_texture_active_index_get",
 -                                 "rna_Mesh_uv_texture_active_index_set", "rna_Mesh_uv_texture_index_range");
 +                                 "rna_Mesh_tessface_uv_texture_active_index_set", "rna_Mesh_uv_layer_index_range");
        RNA_def_property_ui_text(prop, "Active UV Map Index", "Active UV Map index");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
  }
@@@ -3140,9 -3220,9 +3140,9 @@@ static void rna_def_skin_vertices(Blend
  
        prop = RNA_def_property(srna, "use_root", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", MVERT_SKIN_ROOT);
-     RNA_def_property_ui_text(prop, "Root",
-                              "Vertex is a root for rotation calculations and armature generation, "
-                              "setting this flag does not clear other roots in the same mesh island");
+       RNA_def_property_ui_text(prop, "Root",
+                                "Vertex is a root for rotation calculations and armature generation, "
+                                "setting this flag does not clear other roots in the same mesh island");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
  
        prop = RNA_def_property(srna, "use_loose", PROP_BOOLEAN, PROP_NONE);
@@@ -3181,79 -3261,6 +3181,79 @@@ static void rna_def_paint_mask(BlenderR
        RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
  }
  
 +static void rna_def_face_map(BlenderRNA *brna)
 +{
 +      StructRNA *srna;
 +      PropertyRNA *prop;
 +
 +      srna = RNA_def_struct(brna, "MeshFaceMapLayer", NULL);
 +      RNA_def_struct_ui_text(srna, "Mesh Face Map Layer", "Per-face map index");
 +      RNA_def_struct_sdna(srna, "CustomDataLayer");
 +      RNA_def_struct_path_func(srna, "rna_MeshFaceMapLayer_path");
 +
 +      prop = RNA_def_property(srna, "name", PROP_STRING, PROP_NONE);
 +      RNA_def_struct_name_property(srna, prop);
 +      RNA_def_property_string_funcs(prop, NULL, NULL, "rna_MeshPolyLayer_name_set");
 +      RNA_def_property_ui_text(prop, "Name", "Name of face-map layer");
 +      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, "MeshFaceMap");
 +      RNA_def_property_ui_text(prop, "Data", "");
 +      RNA_def_property_collection_funcs(prop, "rna_MeshFaceMapLayer_data_begin", "rna_iterator_array_next",
 +                                        "rna_iterator_array_end", "rna_iterator_array_get",
 +                                        "rna_MeshFaceMapLayer_data_length", NULL, NULL, NULL);
 +
 +      /* FaceMap struct */
 +      srna = RNA_def_struct(brna, "MeshFaceMap", NULL);
 +      RNA_def_struct_sdna(srna, "MIntProperty");
 +      RNA_def_struct_ui_text(srna, "Int Property", "");
 +      RNA_def_struct_path_func(srna, "rna_MeshFaceMap_path");
 +
 +      prop = RNA_def_property(srna, "value", PROP_INT, PROP_NONE);
 +      RNA_def_property_int_sdna(prop, NULL, "i");
 +      RNA_def_property_ui_text(prop, "Value", "");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +}
 +
 +static void rna_def_face_maps(BlenderRNA *brna, PropertyRNA *cprop)
 +{
 +      StructRNA *srna;
 +      PropertyRNA *prop;
 +
 +      RNA_def_property_srna(cprop, "MeshFaceMapLayers");
 +      srna = RNA_def_struct(brna, "MeshFaceMapLayers", NULL);
 +      RNA_def_struct_ui_text(srna, "Mesh Face Map Layer", "Per-face map index");
 +      RNA_def_struct_sdna(srna, "Mesh");
 +      RNA_def_struct_ui_text(srna, "Mesh FaceMaps", "Collection of mesh face-maps");
 +
 +      /* add this since we only ever have one layer anyway, don't bother with active_index */
 +      prop = RNA_def_property(srna, "active", PROP_POINTER, PROP_NONE);
 +      RNA_def_property_struct_type(prop, "MeshFaceMapLayer");
 +      RNA_def_property_pointer_funcs(prop, "rna_Mesh_face_map_active_get",
 +                                     NULL, NULL, NULL);
 +      RNA_def_property_ui_text(prop, "Active FaceMap Layer", "");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +
 +      FunctionRNA *func;
 +      PropertyRNA *parm;
 +
 +      func = RNA_def_function(srna, "new", "rna_Mesh_face_map_new");
 +      RNA_def_function_flag(func, FUNC_USE_REPORTS);
 +      RNA_def_function_ui_description(func, "Add a float property layer to Mesh");
 +      RNA_def_string(func, "name", "Face Map", 0, "", "Face map name");
 +      parm = RNA_def_pointer(func, "layer", "MeshFaceMapLayer", "", "The newly created layer");
 +      RNA_def_parameter_flags(parm, 0, PARM_RNAPTR);
 +      RNA_def_function_return(func, parm);
 +
 +      func = RNA_def_function(srna, "remove", "rna_Mesh_face_map_remove");
 +      RNA_def_function_ui_description(func, "Remove a face map layer");
 +      RNA_def_function_flag(func, FUNC_USE_REPORTS);
 +      parm = RNA_def_pointer(func, "layer", "MeshFaceMapLayer", "", "The layer to remove");
 +      RNA_def_parameter_flags(parm, PROP_NEVER_NULL, PARM_REQUIRED);
 +      RNA_def_property_clear_flag(parm, PROP_THICK_WRAP);
 +}
 +
  static void rna_def_mesh(BlenderRNA *brna)
  {
        StructRNA *srna;
                                 "All UV maps for tessellated faces (read-only, for use by renderers)");
        rna_def_tessface_uv_textures(brna, prop);
  
 -      /* UV maps */
 -      prop = RNA_def_property(srna, "uv_textures", PROP_COLLECTION, PROP_NONE);
 -      RNA_def_property_collection_sdna(prop, NULL, "pdata.layers", "pdata.totlayer");
 -      RNA_def_property_collection_funcs(prop, "rna_Mesh_uv_textures_begin", NULL, NULL, NULL,
 -                                        "rna_Mesh_uv_textures_length", NULL, NULL, NULL);
 -      RNA_def_property_struct_type(prop, "MeshTexturePolyLayer");
 -      RNA_def_property_ui_text(prop, "UV Maps", "All UV maps");
 -      rna_def_uv_textures(brna, prop);
 -
 -      prop = RNA_def_property(srna, "uv_texture_clone", PROP_POINTER, PROP_NONE);
 -      RNA_def_property_struct_type(prop, "MeshTexturePolyLayer");
 -      RNA_def_property_pointer_funcs(prop, "rna_Mesh_uv_texture_clone_get",
 -                                     "rna_Mesh_uv_texture_clone_set", NULL, NULL);
 -      RNA_def_property_flag(prop, PROP_EDITABLE);
 -      RNA_def_property_ui_text(prop, "Clone UV Map", "UV map 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_uv_texture_index_range");
 -      RNA_def_property_ui_text(prop, "Clone UV Map Index", "Clone UV map index");
 -
 -      prop = RNA_def_property(srna, "uv_texture_stencil", PROP_POINTER, PROP_NONE);
 -      RNA_def_property_struct_type(prop, "MeshTexturePolyLayer");
 -      RNA_def_property_pointer_funcs(prop, "rna_Mesh_uv_texture_stencil_get",
 -                                     "rna_Mesh_uv_texture_stencil_set", NULL, NULL);
 -      RNA_def_property_flag(prop, PROP_EDITABLE);
 -      RNA_def_property_ui_text(prop, "Mask UV Map", "UV map to mask the painted area");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 -
 -      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_uv_texture_index_range");
 -      RNA_def_property_ui_text(prop, "Mask UV Map Index", "Mask UV map index");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 -
        /* Tessellated face colors - used by renderers */
  
        prop = RNA_def_property(srna, "tessface_vertex_colors", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_ui_text(prop, "String Property Layers", "");
        rna_def_polygon_string_layers(brna, prop);
  
 +      /* face-maps */
 +      prop = RNA_def_property(srna, "face_maps", PROP_COLLECTION, PROP_NONE);
 +      RNA_def_property_collection_sdna(prop, NULL, "pdata.layers", "pdata.totlayer");
 +      RNA_def_property_collection_funcs(prop, "rna_Mesh_face_maps_begin", NULL, NULL, NULL,
 +                                        "rna_Mesh_face_maps_length", NULL, NULL, NULL);
 +      RNA_def_property_struct_type(prop, "MeshFaceMapLayer");
 +      RNA_def_property_ui_text(prop, "FaceMap", "");
 +      rna_def_face_maps(brna, prop);
 +
        /* Skin vertices */
        prop = RNA_def_property(srna, "skin_vertices", PROP_COLLECTION, PROP_NONE);
        RNA_def_property_collection_sdna(prop, NULL, "vdata.layers", "vdata.totlayer");
        RNA_def_property_ui_text(prop, "Draw Faces", "Display all faces as shades in the 3D view and UV editor");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
  
 -      prop = RNA_def_property(srna, "show_normal_face", PROP_BOOLEAN, PROP_NONE);
 -      RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_DRAWNORMALS);
 -      RNA_def_property_ui_text(prop, "Draw Normals", "Display face normals as lines");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
 -
 -      prop = RNA_def_property(srna, "show_normal_loop", PROP_BOOLEAN, PROP_NONE);
 -      RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_DRAW_LNORMALS);
 -      RNA_def_property_ui_text(prop, "Draw Split Normals", "Display vertex-per-face normals as lines");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
 -
 -      prop = RNA_def_property(srna, "show_normal_vertex", PROP_BOOLEAN, PROP_NONE);
 -      RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_DRAW_VNORMALS);
 -      RNA_def_property_ui_text(prop, "Draw Vertex Normals", "Display vertex normals as lines");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
 -
 -      prop = RNA_def_property(srna, "show_weight", PROP_BOOLEAN, PROP_NONE);
 -      RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_DRAWEIGHT);
 -      RNA_def_property_ui_text(prop, "Show Weights", "Draw weights in editmode");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data_edit_color");  /* needs to rebuild 'dm' */
 -
        prop = RNA_def_property(srna, "show_edge_crease", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_DRAWCREASES);
        RNA_def_property_ui_text(prop, "Draw Creases", "Display creases created for Subdivision Surface modifier");
@@@ -3672,10 -3725,10 +3672,10 @@@ void RNA_def_mesh(BlenderRNA *brna
        rna_def_mpolygon(brna);
        rna_def_mloopuv(brna);
        rna_def_mtface(brna);
 -      rna_def_mtexpoly(brna);
        rna_def_mcol(brna);
        rna_def_mloopcol(brna);
        rna_def_mproperties(brna);
 +      rna_def_face_map(brna);
  }
  
  #endif
index 34c086c04c11ba18358ec50e489843ee4d78fdd8,97e64fd376e32f6f3ddd9d3b4f47e4fec732c610..62981798b1a228ad6b8770feacb332880703187e
  #include "../generic/py_capi_utils.h"
  #include "../generic/python_utildefines.h"
  
 -
 -/* Mesh BMTexPoly
 - * ************** */
 -
 -#define BPy_BMTexPoly_Check(v)  (Py_TYPE(v) == &BPy_BMTexPoly_Type)
 -
 -typedef struct BPy_BMTexPoly {
 -      PyObject_VAR_HEAD
 -      MTexPoly *data;
 -} BPy_BMTexPoly;
 -
 -extern PyObject *pyrna_id_CreatePyObject(ID *id);
 -extern bool      pyrna_id_FromPyObject(PyObject *obj, ID **id);
 -
 -PyDoc_STRVAR(bpy_bmtexpoly_image_doc,
 -"Image or None.\n\n:type: :class:`bpy.types.Image`"
 -);
 -static PyObject *bpy_bmtexpoly_image_get(BPy_BMTexPoly *self, void *UNUSED(closure))
 -{
 -      return pyrna_id_CreatePyObject((ID *)self->data->tpage);
 -}
 -
 -static int bpy_bmtexpoly_image_set(BPy_BMTexPoly *self, PyObject *value, void *UNUSED(closure))
 -{
 -      ID *id;
 -
 -      if (value == Py_None) {
 -              id = NULL;
 -      }
 -      else if (pyrna_id_FromPyObject(value, &id) && id && GS(id->name) == ID_IM) {
 -              /* pass */
 -      }
 -      else {
 -              PyErr_Format(PyExc_KeyError, "BMTexPoly.image = x"
 -                           "expected an image or None, not '%.200s'",
 -                           Py_TYPE(value)->tp_name);
 -              return -1;
 -      }
 -
 -      id_lib_extern(id);
 -      self->data->tpage = (struct Image *)id;
 -
 -      return 0;
 -}
 -
 -static PyGetSetDef bpy_bmtexpoly_getseters[] = {
 -      /* attributes match rna_def_mtpoly  */
 -      {(char *)"image", (getter)bpy_bmtexpoly_image_get, (setter)bpy_bmtexpoly_image_set, (char *)bpy_bmtexpoly_image_doc, NULL},
 -
 -      {NULL, NULL, NULL, NULL, NULL} /* Sentinel */
 -};
 -
 -static PyTypeObject BPy_BMTexPoly_Type; /* bm.loops.layers.uv.active */
 -
 -static void bm_init_types_bmtexpoly(void)
 -{
 -      BPy_BMTexPoly_Type.tp_basicsize = sizeof(BPy_BMTexPoly);
 -
 -      BPy_BMTexPoly_Type.tp_name = "BMTexPoly";
 -
 -      BPy_BMTexPoly_Type.tp_doc = NULL; // todo
 -
 -      BPy_BMTexPoly_Type.tp_getset = bpy_bmtexpoly_getseters;
 -
 -      BPy_BMTexPoly_Type.tp_flags = Py_TPFLAGS_DEFAULT;
 -
 -      PyType_Ready(&BPy_BMTexPoly_Type);
 -}
 -
 -int BPy_BMTexPoly_AssignPyObject(struct MTexPoly *mtpoly, PyObject *value)
 -{
 -      if (UNLIKELY(!BPy_BMTexPoly_Check(value))) {
 -              PyErr_Format(PyExc_TypeError, "expected BMTexPoly, not a %.200s", Py_TYPE(value)->tp_name);
 -              return -1;
 -      }
 -      else {
 -              *((MTexPoly *)mtpoly) = *(((BPy_BMTexPoly *)value)->data);
 -              return 0;
 -      }
 -}
 -
 -PyObject *BPy_BMTexPoly_CreatePyObject(struct MTexPoly *mtpoly)
 -{
 -      BPy_BMTexPoly *self = PyObject_New(BPy_BMTexPoly, &BPy_BMTexPoly_Type);
 -      self->data = mtpoly;
 -      return (PyObject *)self;
 -}
 -
 -/* --- End Mesh BMTexPoly --- */
 -
  /* Mesh Loop UV
   * ************ */
  
@@@ -224,7 -314,7 +224,7 @@@ static int bpy_bmvertskin_flag_set(BPy_
  static PyGetSetDef bpy_bmvertskin_getseters[] = {
        /* attributes match rna_mesh_gen  */
        {(char *)"radius",    (getter)bpy_bmvertskin_radius_get, (setter)bpy_bmvertskin_radius_set, (char *)bpy_bmvertskin_radius_doc, NULL},
-     {(char *)"use_root",  (getter)bpy_bmvertskin_flag_get,   (setter)bpy_bmvertskin_flag_set,   (char *)bpy_bmvertskin_flag__use_root_doc,  (void *)MVERT_SKIN_ROOT},
+       {(char *)"use_root",  (getter)bpy_bmvertskin_flag_get,   (setter)bpy_bmvertskin_flag_set,   (char *)bpy_bmvertskin_flag__use_root_doc,  (void *)MVERT_SKIN_ROOT},
        {(char *)"use_loose", (getter)bpy_bmvertskin_flag_get,   (setter)bpy_bmvertskin_flag_set,   (char *)bpy_bmvertskin_flag__use_loose_doc, (void *)MVERT_SKIN_LOOSE},
  
        {NULL, NULL, NULL, NULL, NULL} /* Sentinel */
@@@ -707,6 -797,7 +707,6 @@@ PyObject *BPy_BMDeformVert_CreatePyObje
  /* call to init all types */
  void BPy_BM_init_types_meshdata(void)
  {
 -      bm_init_types_bmtexpoly();
        bm_init_types_bmloopuv();
        bm_init_types_bmloopcol();
        bm_init_types_bmdvert();