svn merge ^/trunk/blender -r43887:43918
authorCampbell Barton <ideasman42@gmail.com>
Sun, 5 Feb 2012 22:13:10 +0000 (22:13 +0000)
committerCampbell Barton <ideasman42@gmail.com>
Sun, 5 Feb 2012 22:13:10 +0000 (22:13 +0000)
1  2 
release/scripts/startup/bl_ui/space_info.py
source/blender/blenkernel/BKE_blender.h
source/blender/editors/curve/editcurve.c
source/blender/editors/space_view3d/view3d_buttons.c
source/blender/makesrna/intern/rna_mesh.c
source/gameengine/Physics/Bullet/CcdPhysicsController.cpp

index fab422dfb4308594881b79d089f6a6c2356f11cc,95eb49062c01ff5a7631523299c77c855449f579..f7636c87bd568001f6d291dd808bf3dab06512a7
@@@ -170,8 -170,6 +170,8 @@@ class INFO_MT_file_export(Menu)
          if hasattr(bpy.types, "WM_OT_collada_export"):
              self.layout.operator("wm.collada_export", text="COLLADA (.dae)")
  
 +        self.layout.operator("export_mesh.wavefront", text="Wavefront (.obj), BMesh")
 +
  
  class INFO_MT_file_external_data(Menu):
      bl_label = "External Data"
@@@ -364,7 -362,7 +364,7 @@@ class INFO_MT_help(Menu)
          layout = self.layout
  
          layout.operator("wm.url_open", text="Manual", icon='HELP').url = 'http://wiki.blender.org/index.php/Doc:2.6/Manual'
-         layout.operator("wm.url_open", text="Release Log", icon='URL').url = 'http://www.blender.org/development/release-logs/blender-261/'
+         layout.operator("wm.url_open", text="Release Log", icon='URL').url = 'http://www.blender.org/development/release-logs/blender-262/'
  
          layout.separator()
  
index 48f1df2bd73b6c9727e36f3a3218bee5499a4588,7236015054d5b0f4b28ff3cb59c5ce1a4ba474fa..66b2c74d7588b26c9715789ce1dc298adc8bf44e
@@@ -51,7 -51,7 +51,7 @@@ extern "C" 
                /* can be left blank, otherwise a,b,c... etc with no quotes */
  #define BLENDER_VERSION_CHAR  
                /* alpha/beta/rc/release, docs use this */
- #define BLENDER_VERSION_CYCLE beta
+ #define BLENDER_VERSION_CYCLE rc
  
  extern char versionstr[]; /* from blender.c */
  
@@@ -90,7 -90,6 +90,7 @@@ extern void BKE_reset_undo(void)
  extern char *BKE_undo_menu_string(void);
  extern void BKE_undo_number(struct bContext *C, int nr);
  extern const char *BKE_undo_get_name(int nr, int *active);
 +void BKE_undo_save(char *fname);
  extern void BKE_undo_save_quit(void);
  extern struct Main *BKE_undo_get_main(struct Scene **scene);
  
index 4565806702f9e70e93543b07b6430c4a724f5afa,5c762ca61cc7515204eea3af485418df04760070..495c8a8f842efa314afd2a77bb660fb48a25a01f
@@@ -3389,8 -3389,12 +3389,12 @@@ static int convertspline(short type, Nu
                        nu->orderu= 4;
                        nu->orderv= 1;
                        nu->type = type;
+ #if 0         /* UNUSED */
                        if(nu->flagu & CU_NURB_CYCLIC) c= nu->orderu-1; 
                        else c= 0;
+ #endif
                        if(type== CU_NURBS) {
                                nu->flagu &= CU_NURB_CYCLIC; /* disable all flags except for cyclic */
                                nu->flagu |= CU_NURB_BEZIER;
@@@ -6457,12 -6461,12 +6461,12 @@@ static int curvesurf_prim_add(bContext 
        ListBase *editnurb;
        Nurb *nu;
        int newob= 0;
 -      int enter_editmode;
 +      int enter_editmode, is_aligned;
        unsigned int layer;
        float loc[3], rot[3];
        float mat[4][4];
  
 -      if(!ED_object_add_generic_get_opts(C, op, loc, rot, &enter_editmode, &layer))
 +      if(!ED_object_add_generic_get_opts(C, op, loc, rot, &enter_editmode, &layer, &is_aligned))
                return OPERATOR_CANCELLED;
  
        if (!isSurf) { /* adding curve */
@@@ -6857,9 -6861,10 +6861,9 @@@ static void *undo_check_lastsel(void *l
        return NULL;
  }
  
 -static void undoCurve_to_editCurve(void *ucu, void *obe)
 +static void undoCurve_to_editCurve(void *ucu, void *UNUSED(edata), void *cu_v)
  {
 -      Object *obedit= obe;
 -      Curve *cu= (Curve*)obedit->data;
 +      Curve *cu= cu_v;
        UndoCurve *undoCurve= ucu;
        ListBase *undobase= &undoCurve->nubase;
        ListBase *editbase= curve_editnurbs(cu);
  
        cu->lastsel= lastsel;
        cu->actnu= undoCurve->actnu;
 -
 +      /* BMESH_TODO */
 +#if 0
        ED_curve_updateAnimPaths(obedit);
 +#endif
  }
  
 -static void *editCurve_to_undoCurve(void *obe)
 +static void *editCurve_to_undoCurve(void *UNUSED(edata), void *cu_v)
  {
 -      Object *obedit= obe;
 -      Curve *cu= (Curve*)obedit->data;
 +      Curve *cu= cu_v;
        ListBase *nubase= curve_editnurbs(cu);
        UndoCurve *undoCurve;
        EditNurb *editnurb= cu->editnurb, tmpEditnurb;
index a595fc1f02be1f51504f200b9f7ea5dda938d355,5238fd30ae69c70371095fb687e9f457a7f4d180..55481d6aa7243a4c70af7153275fee098f9b3e86
@@@ -58,7 -58,6 +58,7 @@@
  #include "BKE_main.h"
  #include "BKE_mesh.h"
  #include "BKE_screen.h"
 +#include "BKE_tessmesh.h"
  #include "BKE_deform.h"
  #include "BKE_object.h"
  
@@@ -154,36 -153,32 +154,36 @@@ static void v3d_editvertex_buts(uiLayou
        
        if(ob->type==OB_MESH) {
                Mesh *me= ob->data;
 -              EditMesh *em = BKE_mesh_get_editmesh(me);
 -              EditVert *eve, *evedef=NULL;
 -              EditEdge *eed;
 +              BMEditMesh *em = me->edit_btmesh;
 +              BMesh *bm = em->bm;
 +              BMVert *eve, *evedef=NULL;
 +              BMEdge *eed;
 +              BMIter iter;
                
 -              eve= em->verts.first;
 -              while(eve) {
 -                      if(eve->f & SELECT) {
 +              BM_ITER(eve, &iter, bm, BM_VERTS_OF_MESH, NULL) {
 +                      if(BM_TestHFlag(eve, BM_SELECT)) {
                                evedef= eve;
                                tot++;
                                add_v3_v3(median, eve->co);
                        }
 -                      eve= eve->next;
                }
 -              eed= em->edges.first;
 -              while(eed) {
 -                      if((eed->f & SELECT)) {
 +
 +              BM_ITER(eed, &iter, bm, BM_EDGES_OF_MESH, NULL) {
 +                      if(BM_TestHFlag(eed, BM_SELECT)) {
 +                              float *f;
 +
                                totedge++;
 -                              median[3]+= eed->crease;
 -                              median[6]+= eed->bweight;
 +                              f = bm_get_cd_float(&bm->edata, eed->head.data, CD_CREASE);
 +                              median[3]+= f ? *f : 0.0f;
 +
 +                              f = bm_get_cd_float(&bm->edata, eed->head.data, CD_BWEIGHT);
 +                              median[6]+= f ? *f : 0.0f;
                        }
 -                      eed= eed->next;
                }
  
                /* check for defgroups */
                if(evedef)
 -                      dvert= CustomData_em_get(&em->vdata, evedef->data, CD_MDEFORMVERT);
 +                      dvert= CustomData_bmesh_get(&em->bm->vdata, evedef->head.data, CD_MDEFORMVERT);
                if(tot==1 && dvert && dvert->totweight) {
                        bDeformGroup *dg;
                        int i, max=1, init=1;
                                tfp->defweightp= &dvert->dw[0].weight;
                        }
                }
 -
 -              BKE_mesh_end_editmesh(me, em);
        }
        else if(ob->type==OB_CURVE || ob->type==OB_SURF) {
                Curve *cu= ob->data;
                
                if(ob->type==OB_MESH) {
                        Mesh *me= ob->data;
 -                      EditMesh *em = BKE_mesh_get_editmesh(me);
 +                      BMEditMesh *em = me->edit_btmesh;
 +                      BMVert *eve;
 +                      BMIter iter;
  
 -                      /* allow for some rounding error becasue of matrix transform */
                        if(len_v3(median) > 0.000001f) {
 -                              EditVert *eve;
  
 -                              for(eve= em->verts.first; eve; eve= eve->next) {
 -                                      if(eve->f & SELECT) {
 +                              BM_ITER(eve, &iter, em->bm, BM_VERTS_OF_MESH, NULL) {
 +                                      if(BM_TestHFlag(eve, BM_SELECT)) {
                                                add_v3_v3(eve->co, median);
                                        }
                                }
 -
 -                              recalc_editnormals(em);
 +                              
 +                              EDBM_RecalcNormals(em);
                        }
 -
 +                      
                        if(median[3] != 0.0f) {
 -                              EditEdge *eed;
 +                              BMEdge *eed;
                                const float fixed_crease= (ve_median[3] <= 0.0f ? 0.0f : (ve_median[3] >= 1.0f ? 1.0f : FLT_MAX));
 -
 +                              
                                if(fixed_crease != FLT_MAX) {
                                        /* simple case */
  
 -                                      for(eed= em->edges.first; eed; eed= eed->next) {
 -                                              if(eed->f & SELECT) {
 -                                                      eed->crease= fixed_crease;
 +                                      BM_ITER(eed, &iter, em->bm, BM_EDGES_OF_MESH, NULL) {
 +                                              if(BM_TestHFlag(eed, BM_SELECT)) {
 +                                                      float *crease = CustomData_bmesh_get(&em->bm->edata, eed->head.data, CD_CREASE);
 +                                                      if (!crease) break;
 +                                                      
 +                                                      *crease= fixed_crease;
                                                }
                                        }
                                }
                                                /* scale down */
                                                const float sca= median_new / median_orig;
                                                
 -                                              for(eed= em->edges.first; eed; eed= eed->next) {
 -                                                      if(eed->f & SELECT) {
 -                                                              eed->crease *= sca;
 -                                                              CLAMP(eed->crease, 0.0f, 1.0f);
 +                                              BM_ITER(eed, &iter, em->bm, BM_EDGES_OF_MESH, NULL) {
 +                                                      if(BM_TestHFlag(eed, BM_SELECT) && !BM_TestHFlag(eed, BM_HIDDEN)) {
 +                                                              float *crease = CustomData_bmesh_get(&em->bm->edata, eed->head.data, CD_CREASE);
 +                                                              
 +                                                              if (!crease) break;
 +                                                              
 +                                                              *crease *= sca;
 +                                                              CLAMP(*crease, 0.0f, 1.0f);
                                                        }
                                                }
                                        }
                                                /* scale up */
                                                const float sca= (1.0f - median_new) / (1.0f - median_orig);
  
 -                                              for(eed= em->edges.first; eed; eed= eed->next) {
 -                                                      if(eed->f & SELECT) {
 -                                                              eed->crease = 1.0f - ((1.0f - eed->crease) * sca);
 -                                                              CLAMP(eed->crease, 0.0f, 1.0f);
 +                                              BM_ITER(eed, &iter, em->bm, BM_EDGES_OF_MESH, NULL) {
 +                                                      if(BM_TestHFlag(eed, BM_SELECT) && !BM_TestHFlag(eed, BM_HIDDEN)) {
 +                                                              float *crease = CustomData_bmesh_get(&em->bm->edata, eed->head.data, CD_CREASE);
 +                                                              if (!crease) break;
 +
 +                                                              *crease = 1.0f - ((1.0f - *crease) * sca);
 +                                                              CLAMP(*crease, 0.0f, 1.0f);
                                                        }
                                                }
                                        }
                                }
                        }
 -
                        if (median[6] != 0.0f) {
 +#if 0 // BMESH_TODO
                                EditEdge *eed;
                                const float fixed_bweight= (ve_median[6] <= 0.0f ? 0.0f : (ve_median[6] >= 1.0f ? 1.0f : FLT_MAX));
  
                                                }
                                        }
                                }
 +#endif // BMESH_TODO
                        }
 -                      BKE_mesh_end_editmesh(me, em);
 +                      EDBM_RecalcNormals(em);
                }
                else if(ob->type==OB_CURVE || ob->type==OB_SURF) {
                        Curve *cu= ob->data;
  #define B_VGRP_PNL_EDIT_SINGLE 8 /* or greater */
  #define B_VGRP_PNL_COPY_SINGLE 16384 /* or greater */
  
 -static void act_vert_def(Object *ob, EditVert **eve, MDeformVert **dvert)
 +static void act_vert_def(Object *ob, BMVert **eve, MDeformVert **dvert)
  {
        if(ob && ob->mode & OB_MODE_EDIT && ob->type==OB_MESH && ob->defbase.first) {
                Mesh *me= ob->data;
 -              EditMesh *em = BKE_mesh_get_editmesh(me);
 -              EditSelection *ese = ((EditSelection*)em->selected.last);
 +              BMEditMesh *em = me->edit_btmesh;
 +              BMEditSelection *ese= (BMEditSelection*)em->bm->selected.last;
  
 -              if(ese && ese->type == EDITVERT) {
 -                      *eve= (EditVert*)ese->data;
 -                      *dvert= CustomData_em_get(&em->vdata, (*eve)->data, CD_MDEFORMVERT);
 +              if(ese && ese->htype == BM_VERT) {
 +                      *eve= (BMVert*)ese->data;
 +                      *dvert= CustomData_bmesh_get(&em->bm->vdata, (*eve)->head.data, CD_MDEFORMVERT);
                        return;
                }
 -
 -              BKE_mesh_end_editmesh(me, em);
        }
  
        *eve= NULL;
        *dvert= NULL;
  }
  
 -static void editvert_mirror_update(Object *ob, EditVert *eve, int def_nr, int index)
 +static void editvert_mirror_update(Object *ob, BMVert *eve, int def_nr, int index)
  {
        Mesh *me= ob->data;
 -      EditMesh *em = BKE_mesh_get_editmesh(me);
 -      EditVert *eve_mirr;
 +      BMEditMesh *em = me->edit_btmesh;
 +      BMVert *eve_mirr;
  
 -      eve_mirr= editmesh_get_x_mirror_vert(ob, em, eve, eve->co, index);
 +      eve_mirr= editbmesh_get_x_mirror_vert(ob, em, eve, eve->co, index);
  
        if(eve_mirr && eve_mirr != eve) {
 -              MDeformVert *dvert_src= CustomData_em_get(&em->vdata, eve->data, CD_MDEFORMVERT);
 -              MDeformVert *dvert_dst= CustomData_em_get(&em->vdata, eve_mirr->data, CD_MDEFORMVERT);
 +              MDeformVert *dvert_src= CustomData_bmesh_get(&em->bm->vdata, eve->head.data, CD_MDEFORMVERT);
 +              MDeformVert *dvert_dst= CustomData_bmesh_get(&em->bm->vdata, eve_mirr->head.data, CD_MDEFORMVERT);
                if(dvert_dst) {
                        if(def_nr == -1) {
                                /* all vgroups, add groups where neded  */
  
  static void vgroup_adjust_active(Object *ob, int def_nr)
  {
 -      EditVert *eve_act;
 +      BMVert *eve_act;
        MDeformVert *dvert_act;
  
        act_vert_def(ob, &eve_act, &dvert_act);
  
  static void vgroup_copy_active_to_sel(Object *ob)
  {
 -      EditVert *eve_act;
 +      BMVert *eve_act;
        MDeformVert *dvert_act;
  
        act_vert_def(ob, &eve_act, &dvert_act);
        }
        else {
                Mesh *me= ob->data;
 -              EditMesh *em = BKE_mesh_get_editmesh(me);
 -              EditVert *eve;
 +              BMEditMesh *em = me->edit_btmesh;
 +              BMIter iter;
 +              BMVert *eve;
                MDeformVert *dvert;
                int index= 0;
  
 -              for(eve= em->verts.first; eve; eve= eve->next, index++) {
 -                      if(eve->f & SELECT && eve != eve_act) {
 -                              dvert= CustomData_em_get(&em->vdata, eve->data, CD_MDEFORMVERT);
 +              BM_ITER(eve, &iter, em->bm, BM_VERTS_OF_MESH, NULL) {
 +                      if(BM_TestHFlag(eve, BM_SELECT) && eve != eve_act) {
 +                              dvert= CustomData_bmesh_get(&em->bm->vdata, eve->head.data, CD_MDEFORMVERT);
                                if(dvert) {
                                        defvert_copy(dvert, dvert_act);
  
  
                                }
                        }
 +
 +                      index++;
                }
        }
  }
  
  static void vgroup_copy_active_to_sel_single(Object *ob, const int def_nr)
  {
 -      EditVert *eve_act;
 +      BMVert *eve_act;
        MDeformVert *dv_act;
  
        act_vert_def(ob, &eve_act, &dv_act);
        }
        else {
                Mesh *me= ob->data;
 -              EditMesh *em = BKE_mesh_get_editmesh(me);
 -              EditVert *eve;
 +              BMEditMesh *em = me->edit_btmesh;
 +              BMIter iter;
 +              BMVert *eve;
                MDeformVert *dv;
                MDeformWeight *dw;
                float weight_act;
  
                if(dw == NULL)
                        return;
 -
 +              
                weight_act= dw->weight;
  
 -              for (eve= em->verts.first; eve; eve= eve->next, index++) {
 -                      if (eve->f & SELECT && eve != eve_act) {
 -                              dv= CustomData_em_get(&em->vdata, eve->data, CD_MDEFORMVERT);
 -                              if(dv) {
 -                                      dw= defvert_find_index(dv, def_nr);
 -                                      if (dw) {
 -                                              dw->weight= weight_act;
 +              eve = BMIter_New(&iter, em->bm, BM_VERTS_OF_MESH, NULL);
 +              for (index=0; eve; eve=BMIter_Step(&iter), index++) {
 +                      if(BM_TestHFlag(eve, BM_SELECT) && eve != eve_act) {
 +                              dv= CustomData_bmesh_get(&em->bm->vdata, eve->head.data, CD_MDEFORMVERT);
 +                              dw= defvert_find_index(dv, def_nr);
 +                              if (dw) {
 +                                      dw->weight= weight_act;
  
 -                                              if (me->editflag & ME_EDIT_MIRROR_X) {
 -                                                      editvert_mirror_update(ob, eve, -1, index);
 -                                              }
 +                                      if (me->editflag & ME_EDIT_MIRROR_X) {
 +                                              editvert_mirror_update(ob, eve, -1, index);
                                        }
                                }
                        }
                }
  
 -              if (me->editflag & ME_EDIT_MIRROR_X) {
 +              if(me->editflag & ME_EDIT_MIRROR_X) {
                        editvert_mirror_update(ob, eve_act, -1, -1);
                }
        }
  
  static void vgroup_normalize_active(Object *ob)
  {
 -      EditVert *eve_act;
 +      BMVert *eve_act;
        MDeformVert *dvert_act;
  
        act_vert_def(ob, &eve_act, &dvert_act);
@@@ -802,7 -787,7 +802,7 @@@ static int view3d_panel_vgroup_poll(con
  {
        Scene *scene= CTX_data_scene(C);
        Object *ob= OBACT;
 -      EditVert *eve_act;
 +      BMVert *eve_act;
        MDeformVert *dvert_act;
  
        act_vert_def(ob, &eve_act, &dvert_act);
@@@ -817,7 -802,7 +817,7 @@@ static void view3d_panel_vgroup(const b
        Scene *scene= CTX_data_scene(C);
        Object *ob= OBACT;
  
 -      EditVert *eve;
 +      BMVert *eve;
        MDeformVert *dv;
  
        act_vert_def(ob, &eve, &dv);
@@@ -1284,7 -1269,7 +1284,7 @@@ static void do_view3d_region_buttons(bC
        }
  
        /* default for now */
-       WM_event_add_notifier(C, NC_SPACE|ND_SPACE_VIEW3D, ob);
+       WM_event_add_notifier(C, NC_SPACE|ND_SPACE_VIEW3D, v3d);
  }
  
  static void view3d_panel_object(const bContext *C, Panel *pa)
index 320a7e95ef6a1a7f626619b960a4a0796d498df5,f0320d85bb8d8d2a87f95a7e15951dcc52972f15..bab9ed60f165c8f7ba960ca56bd0d52372ed6f63
@@@ -1,4 -1,4 +1,4 @@@
 -/*
 +/**
   * ***** BEGIN GPL LICENSE BLOCK *****
   *
   * This program is free software; you can redistribute it and/or
@@@ -8,7 -8,7 +8,7 @@@
   *
   * This program is distributed in the hope that it will be useful,
   * but WITHOUT ANY WARRANTY; without even the implied warranty of
 - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.        See the
   * GNU General Public License for more details.
   *
   * You should have received a copy of the GNU General Public License
   * ***** END GPL LICENSE BLOCK *****
   */
  
 +/*note: the original vertex color stuff is now just used for
 +  getting info on the layers themselves, accessing the data is
 +  done through the (not yet written) mpoly interfaces.*/
 +
  /** \file blender/makesrna/intern/rna_mesh.c
   *  \ingroup RNA
   */
  
  #include <stdlib.h>
  
 +#include "MEM_guardedalloc.h"
 +
  #include "RNA_access.h"
  #include "RNA_define.h"
 +#include "RNA_types.h"
  
  #include "rna_internal.h"
  
@@@ -46,7 -39,6 +46,7 @@@
  
  #include "WM_types.h"
  
 +#include "BLI_array.h"
  #include "BLI_math_base.h"
  #include "BLI_math_rotation.h"
  
  #include "BKE_depsgraph.h"
  #include "BKE_main.h"
  #include "BKE_mesh.h"
 -
 +#include "BKE_tessmesh.h"
  
  #include "ED_mesh.h" /* XXX Bad level call */
  
  #include "WM_api.h"
  #include "WM_types.h"
  
 -static void rna_Mesh_update_data(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
 +#include "rna_mesh_utils.h"
 +
 +static Mesh *rna_mesh(PointerRNA *ptr)
 +{
 +      Mesh *me = (Mesh *)ptr->id.data;
 +      return me;
 +}
 +
 +static CustomData *rna_mesh_pdata_helper(Mesh *me)
 +{
 +      return (me->edit_btmesh) ? &me->edit_btmesh->bm->pdata : &me->pdata;
 +}
 +
 +static CustomData *rna_mesh_ldata_helper(Mesh *me)
 +{
 +      return (me->edit_btmesh) ? &me->edit_btmesh->bm->ldata : &me->ldata;
 +}
 +
 +static CustomData *rna_mesh_fdata_helper(Mesh *me)
 +{
 +      return (me->edit_btmesh) ? NULL : &me->fdata;
 +}
 +
 +static CustomData *rna_mesh_pdata(PointerRNA *ptr)
 +{
 +      Mesh *me = rna_mesh(ptr);
 +      return rna_mesh_pdata_helper(me);
 +}
 +
 +static CustomData *rna_mesh_ldata(PointerRNA *ptr)
 +{
 +      Mesh *me = rna_mesh(ptr);
 +      return rna_mesh_ldata_helper(me);
 +}
 +
 +static CustomData *rna_mesh_fdata(PointerRNA *ptr)
 +{
 +      Mesh *me = rna_mesh(ptr);
 +      return rna_mesh_fdata_helper(me);
 +}
 +
 +static void rna_Mesh_update_data(Main *bmain, Scene *scene, PointerRNA *ptr)
  {
        ID *id= ptr->id.data;
  
        }
  }
  
 -static void rna_Mesh_update_select(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
 +static void rna_Mesh_update_select(Main *bmain, Scene *scene, PointerRNA *ptr)
  {
        ID *id= ptr->id.data;
        /* cheating way for importers to avoid slow updates */
        }
  }
  
 -void rna_Mesh_update_draw(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
 +void rna_Mesh_update_draw(Main *bmain, Scene *scene, PointerRNA *ptr)
  {
        ID *id= ptr->id.data;
        /* cheating way for importers to avoid slow updates */
@@@ -208,37 -159,21 +208,37 @@@ static void rna_MEdge_crease_set(Pointe
        medge->crease= (char)(CLAMPIS(value*255.0f, 0, 255));
  }
  
 +static void rna_MeshPolygon_normal_get(PointerRNA *ptr, float *values)
 +{
 +      Mesh *me = rna_mesh(ptr);
 +      MPoly *mp= (MPoly*)ptr->data;
 +
 +      /* BMESH_TODO: might be faster to look for a CD_NORMALS layer and use that */
 +      mesh_calc_poly_normal(mp, me->mloop+mp->loopstart, me->mvert, values);
 +}
 +
 +static float rna_MeshPolygon_area_get(PointerRNA *ptr)
 +{
 +      Mesh *me = (Mesh*)ptr->id.data;
 +      MPoly *mp = (MPoly*)ptr->data;
 +
 +      return mesh_calc_poly_area(mp, me->mloop+mp->loopstart, me->mvert, NULL);
 +}
 +
  static void rna_MeshFace_normal_get(PointerRNA *ptr, float *values)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 +      Mesh *me = rna_mesh(ptr);
        MFace *mface= (MFace*)ptr->data;
 -      
 +
        if(mface->v4)
 -              normal_quad_v3(values,me->mvert[mface->v1].co, me->mvert[mface->v2].co,
 -                             me->mvert[mface->v3].co, me->mvert[mface->v4].co);
 +              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;
 +      Mesh *me = rna_mesh(ptr);
        MFace *mface= (MFace*)ptr->data;
  
        if(mface->v4)
                return area_tri_v3(me->mvert[mface->v1].co, me->mvert[mface->v2].co, me->mvert[mface->v3].co);
  }
  
 +static void rna_MeshTextureFace_uv1_get(PointerRNA *ptr, float *values)
 +{
 +      MTFace *mtface= (MTFace*)ptr->data;
 +
 +      values[0]= mtface->uv[0][0];
 +      values[1]= mtface->uv[0][1];
 +}
 +
 +static void rna_MeshTextureFace_uv1_set(PointerRNA *ptr, const float *values)
 +{
 +      MTFace *mtface= (MTFace*)ptr->data;
 +
 +      mtface->uv[0][0]= values[0];
 +      mtface->uv[0][1]= values[1];
 +}
 +
 +static void rna_MeshTextureFace_uv2_get(PointerRNA *ptr, float *values)
 +{
 +      MTFace *mtface= (MTFace*)ptr->data;
 +
 +      values[0]= mtface->uv[1][0];
 +      values[1]= mtface->uv[1][1];
 +}
 +
 +static void rna_MeshTextureFace_uv2_set(PointerRNA *ptr, const float *values)
 +{
 +      MTFace *mtface= (MTFace*)ptr->data;
 +
 +      mtface->uv[1][0]= values[0];
 +      mtface->uv[1][1]= values[1];
 +}
 +
 +static void rna_MeshTextureFace_uv3_get(PointerRNA *ptr, float *values)
 +{
 +      MTFace *mtface= (MTFace*)ptr->data;
 +
 +      values[0]= mtface->uv[2][0];
 +      values[1]= mtface->uv[2][1];
 +}
 +
 +static void rna_MeshTextureFace_uv3_set(PointerRNA *ptr, const float *values)
 +{
 +      MTFace *mtface= (MTFace*)ptr->data;
 +
 +      mtface->uv[2][0]= values[0];
 +      mtface->uv[2][1]= values[1];
 +}
 +
 +static void rna_MeshTextureFace_uv4_get(PointerRNA *ptr, float *values)
 +{
 +      MTFace *mtface= (MTFace*)ptr->data;
 +
 +      values[0]= mtface->uv[3][0];
 +      values[1]= mtface->uv[3][1];
 +}
 +
 +static void rna_MeshTextureFace_uv4_set(PointerRNA *ptr, const float *values)
 +{
 +      MTFace *mtface= (MTFace*)ptr->data;
 +
 +      mtface->uv[3][0]= values[0];
 +      mtface->uv[3][1]= values[1];
 +}
 +
 +static int rna_CustomDataData_numverts(PointerRNA *ptr, int type)
 +{
 +      Mesh *me = rna_mesh(ptr);
 +      CustomData *fdata = rna_mesh_fdata(ptr);
 +      CustomDataLayer *cdl;
 +      int a, b;
 +
 +      for (cdl = fdata->layers, a = 0; a < fdata->totlayer; cdl++, a++) {
 +              if(cdl->type == type) {
 +                      b = ((char *)ptr->data - ((char*)cdl->data)) / CustomData_sizeof(type);
 +                      if(b >= 0 && b < me->totface) {
 +                              return (me->mface[b].v4 ? 4 : 3);
 +                      }
 +              }
 +      }
 +
 +      return 0;
 +}
 +
 +static int rna_MeshTextureFace_uv_get_length(PointerRNA *ptr, int length[RNA_MAX_ARRAY_DIMENSION])
 +{
 +      length[0]= rna_CustomDataData_numverts(ptr, CD_MTFACE);
 +      length[1]= 2;
 +      return length[0]*length[1];
 +}
 +
 +static void rna_MeshTextureFace_uv_get(PointerRNA *ptr, float *values)
 +{
 +      MTFace *mtface= (MTFace*)ptr->data;
 +      int totvert= rna_CustomDataData_numverts(ptr, CD_MTFACE);
 +
 +      memcpy(values, mtface->uv, totvert * 2 * sizeof(float));
 +}
 +
 +static void rna_MeshTextureFace_uv_set(PointerRNA *ptr, const float *values)
 +{
 +      MTFace *mtface= (MTFace*)ptr->data;
 +      int totvert= rna_CustomDataData_numverts(ptr, CD_MTFACE);
 +
 +      memcpy(mtface->uv, values, totvert * 2 * sizeof(float));
 +}
 +
  /* notice red and blue are swapped */
  static void rna_MeshColor_color1_get(PointerRNA *ptr, float *values)
  {
@@@ -426,33 -255,58 +426,33 @@@ static void rna_MeshColor_color4_set(Po
        (&mcol[3].r)[0]= (char)(CLAMPIS(values[2]*255.0f, 0, 255));
  }
  
 -static void rna_Mesh_texspace_set(Main *UNUSED(bmain), Scene *UNUSED(scene), PointerRNA *ptr)
 -{
 -      Mesh *me= (Mesh*)ptr->data;
 -      
 -      if (me->texflag & AUTOSPACE)
 -              tex_space_mesh(me);
 -}
 -
 -
 -static int rna_Mesh_texspace_editable(PointerRNA *ptr)
 +static void rna_MeshLoopColor_color_get(PointerRNA *ptr, float *values)
  {
 -      Mesh *me= (Mesh*)ptr->data;
 -      return (me->texflag & AUTOSPACE)? 0: PROP_EDITABLE;
 -}
 +      MLoopCol *mcol= (MLoopCol *)ptr->data;
  
 -static void rna_Mesh_texspace_loc_get(PointerRNA *ptr, float *values)
 -{
 -      Mesh *me= (Mesh *)ptr->data;
 -      
 -      if (!me->bb)
 -              tex_space_mesh(me);
 -      
 -      copy_v3_v3(values, me->loc);
 +      values[2]= (&mcol->r)[0]/255.0f;
 +      values[1]= (&mcol->r)[1]/255.0f;
 +      values[0]= (&mcol->r)[2]/255.0f;
  }
  
 -static void rna_Mesh_texspace_loc_set(PointerRNA *ptr, const float *values)
 +static void rna_MeshLoopColor_color_set(PointerRNA *ptr, const float *values)
  {
 -      Mesh *me= (Mesh *)ptr->data;
 -      
 -      copy_v3_v3(me->loc, values);
 -}
 +      MLoopCol *mcol= (MLoopCol *)ptr->data;
  
 -static void rna_Mesh_texspace_size_get(PointerRNA *ptr, float *values)
 -{
 -      Mesh *me= (Mesh *)ptr->data;
 -      
 -      if (!me->bb)
 -              tex_space_mesh(me);
 -      
 -      copy_v3_v3(values, me->size);
 +      (&mcol->r)[2]= (char)(CLAMPIS(values[0]*255.0f, 0, 255));
 +      (&mcol->r)[1]= (char)(CLAMPIS(values[1]*255.0f, 0, 255));
 +      (&mcol->r)[0]= (char)(CLAMPIS(values[2]*255.0f, 0, 255));
  }
  
 -static void rna_Mesh_texspace_size_set(PointerRNA *ptr, const float *values)
 +static int rna_Mesh_texspace_editable(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh *)ptr->data;
 -      
 -      copy_v3_v3(me->size, values);
 +      Mesh *me= (Mesh*)ptr->data;
 +      return (me->texflag & AUTOSPACE)? 0: PROP_EDITABLE;
  }
  
  static void rna_MeshVertex_groups_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 +      Mesh *me = rna_mesh(ptr);
  
        if(me->dvert) {
                MVert *mvert= (MVert*)ptr->data;
  
  static void rna_MeshFace_material_index_range(PointerRNA *ptr, int *min, int *max)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 +      Mesh *me = rna_mesh(ptr);
        *min= 0;
        *max= me->totcol-1;
        *max= MAX2(0, *max);
  }
  
 -static CustomData *rna_mesh_fdata(Mesh *me)
 -{
 -      return (me->edit_mesh)? &me->edit_mesh->fdata: &me->fdata;
 -}
 -
 -static int rna_CustomDataLayer_length(PointerRNA *ptr, int type)
 -{
 -      Mesh *me= (Mesh*)ptr->id.data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -      CustomDataLayer *layer;
 -      int i, length= 0;
 -
 -      for(layer=fdata->layers, i=0; i<fdata->totlayer; layer++, i++)
 -              if(layer->type == type)
 -                      length++;
 -
 -      return length;
 -}
 -
 -static int rna_CustomDataLayer_active_get(PointerRNA *ptr, int type, int render)
 +static int rna_CustomDataLayer_active_get(PointerRNA *ptr, CustomData *data, int type, int render)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -      int n= ((CustomDataLayer*)ptr->data) - fdata->layers;
 +      int n= ((CustomDataLayer*)ptr->data) - data->layers;
  
 -      if(render) return (n == CustomData_get_render_layer_index(fdata, type));
 -      else return (n == CustomData_get_active_layer_index(fdata, type));
 +      if(render) return (n == CustomData_get_render_layer_index(data, type));
 +      else return (n == CustomData_get_active_layer_index(data, type));
  }
  
 -static int rna_CustomDataLayer_clone_get(PointerRNA *ptr, int type, int UNUSED(render))
 +static int rna_CustomDataLayer_clone_get(PointerRNA *ptr, CustomData *data, int type, int render)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -      int n= ((CustomDataLayer*)ptr->data) - fdata->layers;
 +      int n= ((CustomDataLayer*)ptr->data) - data->layers;
  
 -      return (n == CustomData_get_clone_layer_index(fdata, type));
 +      return (n == CustomData_get_clone_layer_index(data, type));
  }
  
 -static void rna_CustomDataLayer_active_set(PointerRNA *ptr, int value, int type, int render)
 +static void rna_CustomDataLayer_active_set(PointerRNA *ptr, CustomData *data, 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;
 +      int n= ((CustomDataLayer*)ptr->data) - data->layers;
  
        if(value == 0)
                return;
  
 -      if(render) CustomData_set_layer_render_index(fdata, type, n);
 -      else CustomData_set_layer_active_index(fdata, type, n);
 +      if(render) CustomData_set_layer_render_index(data, type, n);
 +      else CustomData_set_layer_active_index(data, type, n);
  }
  
 -static void rna_CustomDataLayer_clone_set(PointerRNA *ptr, int value, int type, int UNUSED(render))
 +static void rna_CustomDataLayer_clone_set(PointerRNA *ptr, CustomData *data, 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;
 +      int n= ((CustomDataLayer*)ptr->data) - data->layers;
  
        if(value == 0)
                return;
  
 -      CustomData_set_layer_clone_index(fdata, type, n);
 -}
 -
 -static int rna_uv_texture_check(CollectionPropertyIterator *UNUSED(iter), void *data)
 -{
 -      CustomDataLayer *layer= (CustomDataLayer*)data;
 -      return (layer->type != CD_MTFACE);
 -}
 -
 -static void rna_Mesh_uv_textures_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
 -{
 -      Mesh *me= (Mesh*)ptr->data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -      rna_iterator_array_begin(iter, (void*)fdata->layers, sizeof(CustomDataLayer), fdata->totlayer, 0, rna_uv_texture_check);
 -}
 -
 -static int rna_Mesh_uv_textures_length(PointerRNA *ptr)
 -{
 -      return rna_CustomDataLayer_length(ptr, CD_MTFACE);
 -}
 -
 -static PointerRNA rna_Mesh_active_uv_texture_get(PointerRNA *ptr)
 -{
 -      Mesh *me= (Mesh*)ptr->data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -      int index= CustomData_get_active_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_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);
 +      CustomData_set_layer_clone_index(data, type, n);
  }
  
 -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);
 -}
 +/* uv_loop_layers */
  
 -static void rna_Mesh_active_uv_texture_set(PointerRNA *ptr, PointerRNA value)
 -{
 -      Mesh *me= (Mesh*)ptr->data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -      CustomDataLayer *cdl;
 -      int a;
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION(uv_loop_layer, ldata, CD_MLOOPUV)
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(uv_loop_layer, ldata, CD_MLOOPUV, active, MeshUVLoopLayer)
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(uv_loop_layer, ldata, CD_MLOOPUV, clone, MeshUVLoopLayer)
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(uv_loop_layer, ldata, CD_MLOOPUV, stencil, MeshUVLoopLayer)
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(uv_loop_layer, ldata, CD_MLOOPUV, render, MeshUVLoopLayer)
  
 -      for(cdl=fdata->layers, a=0; a<fdata->totlayer; cdl++, a++) {
 -              if(value.data == cdl) {
 -                      CustomData_set_layer_active_index(fdata, CD_MTFACE, a);
 -                      mesh_update_customdata_pointers(me);
 -                      return;
 -              }
 -      }
 -}
 +/* MeshUVLoopLayer */
  
 -static void rna_Mesh_uv_texture_clone_set(PointerRNA *ptr, PointerRNA value)
 +static char *rna_MeshUVLoopLayer_path(PointerRNA *ptr)
  {
 -      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;
 -              }
 -      }
 +      return BLI_sprintfN("uv_loop_layer[\"%s\"]", ((CustomDataLayer*)ptr->data)->name);
  }
  
 -static void rna_Mesh_uv_texture_stencil_set(PointerRNA *ptr, PointerRNA value)
 +static void rna_MeshUVLoopLayer_data_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
  {
 -      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;
 -              }
 -      }
 +      Mesh *me = rna_mesh(ptr);
 +      CustomDataLayer *layer = (CustomDataLayer *)ptr->data;
 +      rna_iterator_array_begin(iter, layer->data, sizeof(MLoopUV), (me->edit_btmesh) ? 0 : me->totloop, 0, NULL);
  }
  
 -static int rna_Mesh_active_uv_texture_index_get(PointerRNA *ptr)
 +static int rna_MeshUVLoopLayer_data_length(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -      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);
 +      Mesh *me = rna_mesh(ptr);
 +      return (me->edit_btmesh) ? 0 : me->totloop;
  }
  
 -static void rna_Mesh_active_uv_texture_index_set(PointerRNA *ptr, int value)
 -{
 -      Mesh *me= (Mesh*)ptr->data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 +/* face uv_textures */
  
 -      CustomData_set_layer_active(fdata, CD_MTFACE, value);
 -      mesh_update_customdata_pointers(me);
 -}
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION(tessface_uv_texture, fdata, CD_MTFACE)
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(tessface_uv_texture, fdata, CD_MTFACE, active, MeshTextureFaceLayer)
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(tessface_uv_texture, fdata, CD_MTFACE, clone, MeshTextureFaceLayer)
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(tessface_uv_texture, fdata, CD_MTFACE, stencil, MeshTextureFaceLayer)
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(tessface_uv_texture, fdata, CD_MTFACE, render, MeshTextureFaceLayer)
  
 -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;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -
 -      *min= 0;
 -      *max= CustomData_number_of_layers(fdata, CD_MTFACE)-1;
 -      *max= MAX2(0, *max);
 -}
 -
 -static PointerRNA rna_Mesh_active_mtface_get(PointerRNA *ptr)
 -{
 -      Mesh *me= (Mesh*)ptr->data;
 -      EditMesh *em= BKE_mesh_get_editmesh(me);
 -      MTFace *tf;
 -
 -      if (em && EM_texFaceCheck(em))
 -      {
 -              tf = EM_get_active_mtface(em, NULL, NULL, 1);
 -
 -              return rna_pointer_inherit_refine(ptr, &RNA_MeshTextureFace, tf);
 -      }
 -
 -      return rna_pointer_inherit_refine(ptr, &RNA_MeshTextureFace, NULL);
 -}
 -
 -static void rna_MeshTextureFace_uv1_get(PointerRNA *ptr, float *values)
 -{
 -      MTFace *mtface= (MTFace*)ptr->data;
 -      
 -      values[0]= mtface->uv[0][0];
 -      values[1]= mtface->uv[0][1];
 -}
 -
 -static void rna_MeshTextureFace_uv1_set(PointerRNA *ptr, const float *values)
 +static void rna_MeshTextureFaceLayer_data_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
  {
 -      MTFace *mtface= (MTFace*)ptr->data;
 -
 -      mtface->uv[0][0]= values[0];
 -      mtface->uv[0][1]= values[1];
 +      Mesh *me = rna_mesh(ptr);
 +      CustomDataLayer *layer= (CustomDataLayer*)ptr->data;
 +      rna_iterator_array_begin(iter, layer->data, sizeof(MTFace), (me->edit_btmesh)? 0: me->totface, 0, NULL);
  }
  
 -static void rna_MeshTextureFace_uv2_get(PointerRNA *ptr, float *values)
 +static int rna_MeshTextureFaceLayer_data_length(PointerRNA *ptr)
  {
 -      MTFace *mtface= (MTFace*)ptr->data;
 -
 -      values[0]= mtface->uv[1][0];
 -      values[1]= mtface->uv[1][1];
 +      Mesh *me = rna_mesh(ptr);
 +      return (me->edit_btmesh)? 0: me->totface;
  }
  
 -static void rna_MeshTextureFace_uv2_set(PointerRNA *ptr, const float *values)
 +static int rna_MeshTextureFaceLayer_active_render_get(PointerRNA *ptr)
  {
 -      MTFace *mtface= (MTFace*)ptr->data;
 -
 -      mtface->uv[1][0]= values[0];
 -      mtface->uv[1][1]= values[1];
 +      return rna_CustomDataLayer_active_get(ptr, rna_mesh_fdata(ptr), CD_MTFACE, 1);
  }
  
 -static void rna_MeshTextureFace_uv3_get(PointerRNA *ptr, float *values)
 -{
 -      MTFace *mtface= (MTFace*)ptr->data;
 -
 -      values[0]= mtface->uv[2][0];
 -      values[1]= mtface->uv[2][1];
 -}
 -
 -static void rna_MeshTextureFace_uv3_set(PointerRNA *ptr, const float *values)
 +static int rna_MeshTextureFaceLayer_active_get(PointerRNA *ptr)
  {
 -      MTFace *mtface= (MTFace*)ptr->data;
 -
 -      mtface->uv[2][0]= values[0];
 -      mtface->uv[2][1]= values[1];
 +      return rna_CustomDataLayer_active_get(ptr, rna_mesh_fdata(ptr), CD_MTFACE, 0);
  }
  
 -static void rna_MeshTextureFace_uv4_get(PointerRNA *ptr, float *values)
 +static int rna_MeshTextureFaceLayer_clone_get(PointerRNA *ptr)
  {
 -      MTFace *mtface= (MTFace*)ptr->data;
 -
 -      values[0]= mtface->uv[3][0];
 -      values[1]= mtface->uv[3][1];
 +      return rna_CustomDataLayer_clone_get(ptr, rna_mesh_fdata(ptr), CD_MTFACE, 0);
  }
  
 -static void rna_MeshTextureFace_uv4_set(PointerRNA *ptr, const float *values)
 +static void rna_MeshTextureFaceLayer_active_render_set(PointerRNA *ptr, int value)
  {
 -      MTFace *mtface= (MTFace*)ptr->data;
 -
 -      mtface->uv[3][0]= values[0];
 -      mtface->uv[3][1]= values[1];
 +      rna_CustomDataLayer_active_set(ptr, rna_mesh_fdata(ptr), value, CD_MTFACE, 1);
  }
  
 -static int rna_CustomDataData_numverts(PointerRNA *ptr, int type)
 +static void rna_MeshTextureFaceLayer_active_set(PointerRNA *ptr, int value)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -      CustomDataLayer *cdl;
 -      int a, b;
 -
 -      for(cdl=fdata->layers, a=0; a<fdata->totlayer; cdl++, a++) {
 -              if(cdl->type == type) {
 -                      b= ((char*)ptr->data - ((char*)cdl->data))/CustomData_sizeof(type);
 -                      if(b >= 0 && b < me->totface)
 -                              return (me->mface[b].v4? 4: 3);
 -              }
 -      }
 -
 -      return 0;
 +      rna_CustomDataLayer_active_set(ptr, rna_mesh_fdata(ptr), value, CD_MTFACE, 0);
  }
  
 -static int rna_MeshTextureFace_uv_get_length(PointerRNA *ptr, int length[RNA_MAX_ARRAY_DIMENSION])
 +static void rna_MeshTextureFaceLayer_clone_set(PointerRNA *ptr, int value)
  {
 -      length[0]= rna_CustomDataData_numverts(ptr, CD_MTFACE);
 -      length[1]= 2;
 -      return length[0]*length[1];
 +      rna_CustomDataLayer_clone_set(ptr, rna_mesh_fdata(ptr), value, CD_MTFACE, 0);
  }
  
 -static void rna_MeshTextureFace_uv_get(PointerRNA *ptr, float *values)
 +static void rna_MeshTextureFaceLayer_name_set(PointerRNA *ptr, const char *value)
  {
 -      MTFace *mtface= (MTFace*)ptr->data;
 -      int totvert= rna_CustomDataData_numverts(ptr, CD_MTFACE);
 -
 -      memcpy(values, mtface->uv, totvert * 2 * sizeof(float));
 +      CustomData *fdata= rna_mesh_fdata(ptr);
 +      CustomDataLayer *cdl= (CustomDataLayer*)ptr->data;
 +      BLI_strncpy_utf8(cdl->name, value, sizeof(cdl->name));
 +      CustomData_set_layer_unique_name(fdata, cdl - fdata->layers);
  }
  
 -static void rna_MeshTextureFace_uv_set(PointerRNA *ptr, const float *values)
 -{
 -      MTFace *mtface= (MTFace*)ptr->data;
 -      int totvert= rna_CustomDataData_numverts(ptr, CD_MTFACE);
 +/* poly uv_textures */
  
 -      memcpy(mtface->uv, values, totvert * 2 * sizeof(float));
 -}
 +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_MeshTextureFaceLayer_data_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
 +static void rna_MeshTexturePolyLayer_data_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 +      Mesh *me = rna_mesh(ptr);
        CustomDataLayer *layer= (CustomDataLayer*)ptr->data;
 -      rna_iterator_array_begin(iter, layer->data, sizeof(MTFace), (me->edit_mesh)? 0: me->totface, 0, NULL);
 +      rna_iterator_array_begin(iter, layer->data, sizeof(MTexPoly), (me->edit_btmesh) ? 0 : me->totpoly, 0, NULL);
  }
  
 -static int rna_MeshTextureFaceLayer_data_length(PointerRNA *ptr)
 +static int rna_MeshTexturePolyLayer_data_length(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 -      return (me->edit_mesh)? 0: me->totface;
 +      Mesh *me = rna_mesh(ptr);
 +      return (me->edit_btmesh) ? 0 : me->totpoly;
  }
  
 -static int rna_MeshTextureFaceLayer_active_render_get(PointerRNA *ptr)
 +static int rna_MeshTexturePolyLayer_active_render_get(PointerRNA *ptr)
  {
 -      return rna_CustomDataLayer_active_get(ptr, CD_MTFACE, 1);
 +      return rna_CustomDataLayer_active_get(ptr, rna_mesh_pdata(ptr), CD_MTEXPOLY, 1);
  }
  
 -static int rna_MeshTextureFaceLayer_active_get(PointerRNA *ptr)
 +static int rna_MeshTexturePolyLayer_active_get(PointerRNA *ptr)
  {
 -      return rna_CustomDataLayer_active_get(ptr, CD_MTFACE, 0);
 +      return rna_CustomDataLayer_active_get(ptr, rna_mesh_pdata(ptr), CD_MTEXPOLY, 0);
  }
  
 -static int rna_MeshTextureFaceLayer_clone_get(PointerRNA *ptr)
 +static int rna_MeshTexturePolyLayer_clone_get(PointerRNA *ptr)
  {
 -      return rna_CustomDataLayer_clone_get(ptr, CD_MTFACE, 0);
 +      return rna_CustomDataLayer_clone_get(ptr, rna_mesh_pdata(ptr), CD_MTEXPOLY, 0);
  }
  
 -static void rna_MeshTextureFaceLayer_active_render_set(PointerRNA *ptr, int value)
 +static void rna_MeshTexturePolyLayer_active_render_set(PointerRNA *ptr, int value)
  {
 -      rna_CustomDataLayer_active_set(ptr, value, CD_MTFACE, 1);
 +      rna_CustomDataLayer_active_set(ptr, rna_mesh_pdata(ptr), value, CD_MTEXPOLY, 1);
  }
  
 -static void rna_MeshTextureFaceLayer_active_set(PointerRNA *ptr, int value)
 +static void rna_MeshTexturePolyLayer_active_set(PointerRNA *ptr, int value)
  {
 -      rna_CustomDataLayer_active_set(ptr, value, CD_MTFACE, 0);
 +      rna_CustomDataLayer_active_set(ptr, rna_mesh_pdata(ptr), value, CD_MTEXPOLY, 0);
  }
  
 -static void rna_MeshTextureFaceLayer_clone_set(PointerRNA *ptr, int value)
 +static void rna_MeshTexturePolyLayer_clone_set(PointerRNA *ptr, int value)
  {
 -      rna_CustomDataLayer_clone_set(ptr, value, CD_MTFACE, 0);
 +      rna_CustomDataLayer_clone_set(ptr, rna_mesh_pdata(ptr), value, CD_MTEXPOLY, 0);
  }
  
 -static void rna_MeshTextureFaceLayer_name_set(PointerRNA *ptr, const char *value)
 +static void rna_MeshTexturePolyLayer_name_set(PointerRNA *ptr, const char *value)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 +      CustomData *pdata= rna_mesh_pdata(ptr);
        CustomDataLayer *cdl= (CustomDataLayer*)ptr->data;
        BLI_strncpy_utf8(cdl->name, value, sizeof(cdl->name));
 -      CustomData_set_layer_unique_name(fdata, cdl - fdata->layers);
 +      CustomData_set_layer_unique_name(pdata, cdl - pdata->layers);
  }
  
 -static int rna_vertex_color_check(CollectionPropertyIterator *UNUSED(iter), void *data)
 -{
 -      CustomDataLayer *layer= (CustomDataLayer*)data;
 -      return (layer->type != CD_MCOL);
 -}
 +/* vertex_color_layers */
  
 -static void rna_Mesh_vertex_colors_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
 -{
 -      Mesh *me= (Mesh*)ptr->data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -      rna_iterator_array_begin(iter, (void*)fdata->layers, sizeof(CustomDataLayer), fdata->totlayer, 0, rna_vertex_color_check);
 -}
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION(tessface_vertex_color, fdata, CD_MCOL)
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(tessface_vertex_color, fdata, CD_MCOL, active, MeshColorLayer)
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(tessface_vertex_color, fdata, CD_MCOL, render, MeshColorLayer)
  
 -static int rna_Mesh_vertex_colors_length(PointerRNA *ptr)
 +static void rna_MeshColorLayer_data_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
  {
 -      return rna_CustomDataLayer_length(ptr, CD_MCOL);
 +      Mesh *me = rna_mesh(ptr);
 +      CustomDataLayer *layer= (CustomDataLayer*)ptr->data;
 +      rna_iterator_array_begin(iter, layer->data, sizeof(CD_MCOL), me->totloop, 0, NULL);
  }
  
 -static PointerRNA rna_Mesh_active_vertex_color_get(PointerRNA *ptr)
 +static int rna_MeshColorLayer_data_length(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -      int index= CustomData_get_active_layer_index(fdata, CD_MCOL);
 -      CustomDataLayer *cdl= (index == -1)? NULL: &fdata->layers[index];
 -
 -      return rna_pointer_inherit_refine(ptr, &RNA_MeshColorLayer, cdl);
 +      Mesh *me = rna_mesh(ptr);
 +      return me->totloop;
  }
  
 -static void rna_Mesh_active_vertex_color_set(PointerRNA *ptr, PointerRNA value)
 +static int rna_MeshColorLayer_active_render_get(PointerRNA *ptr)
  {
 -      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_active_index(fdata, CD_MCOL, a);
 -                      mesh_update_customdata_pointers(me);
 -                      return;
 -              }
 -      }
 +      return rna_CustomDataLayer_active_get(ptr, rna_mesh_fdata(ptr), CD_MCOL, 1);
  }
  
 -static int rna_Mesh_active_vertex_color_index_get(PointerRNA *ptr)
 +static int rna_MeshColorLayer_active_get(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -      return CustomData_get_active_layer(fdata, CD_MCOL);
 +      return rna_CustomDataLayer_active_get(ptr, rna_mesh_fdata(ptr), CD_MCOL, 0);
  }
  
 -static void rna_Mesh_active_vertex_color_index_set(PointerRNA *ptr, int value)
 +static void rna_MeshColorLayer_active_render_set(PointerRNA *ptr, int value)
  {
 -      Mesh *me= (Mesh*)ptr->data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -
 -      CustomData_set_layer_active(fdata, CD_MCOL, value);
 -      mesh_update_customdata_pointers(me);
 +      rna_CustomDataLayer_active_set(ptr, rna_mesh_fdata(ptr), value, CD_MCOL, 1);
  }
  
 -static void rna_Mesh_active_vertex_color_index_range(PointerRNA *ptr, int *min, int *max)
 +static void rna_MeshColorLayer_active_set(PointerRNA *ptr, int value)
  {
 -      Mesh *me= (Mesh*)ptr->data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -
 -      *min= 0;
 -      *max= CustomData_number_of_layers(fdata, CD_MCOL)-1;
 -      *max= MAX2(0, *max);
 +      rna_CustomDataLayer_active_set(ptr, rna_mesh_fdata(ptr), value, CD_MCOL, 0);
  }
  
 -static void rna_MeshColorLayer_data_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION(vertex_color, ldata, CD_MLOOPCOL)
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(vertex_color, ldata, CD_MLOOPCOL, active, MeshLoopColorLayer)
 +DEFINE_CUSTOMDATA_LAYER_COLLECTION_ACTIVEITEM(vertex_color, ldata, CD_MLOOPCOL, render, MeshLoopColorLayer)
 +
 +static void rna_MeshLoopColorLayer_data_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 +      Mesh *me = rna_mesh(ptr);
        CustomDataLayer *layer= (CustomDataLayer*)ptr->data;
 -      rna_iterator_array_begin(iter, layer->data, sizeof(MCol)*4, (me->edit_mesh)? 0: me->totface, 0, NULL);
 +      rna_iterator_array_begin(iter, layer->data, sizeof(CD_MLOOPCOL), me->totloop, 0, NULL);
  }
  
 -static int rna_MeshColorLayer_data_length(PointerRNA *ptr)
 +static int rna_MeshLoopColorLayer_data_length(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 -      return (me->edit_mesh)? 0: me->totface;
 +      Mesh *me = rna_mesh(ptr);
 +      return me->totloop;
  }
  
 -static int rna_MeshColorLayer_active_render_get(PointerRNA *ptr)
 +static int rna_MeshLoopColorLayer_active_render_get(PointerRNA *ptr)
  {
 -      return rna_CustomDataLayer_active_get(ptr, CD_MCOL, 1);
 +      return rna_CustomDataLayer_active_get(ptr, rna_mesh_ldata(ptr), CD_MLOOPCOL, 1);
  }
  
 -static int rna_MeshColorLayer_active_get(PointerRNA *ptr)
 +static int rna_MeshLoopColorLayer_active_get(PointerRNA *ptr)
  {
 -      return rna_CustomDataLayer_active_get(ptr, CD_MCOL, 0);
 +      return rna_CustomDataLayer_active_get(ptr, rna_mesh_ldata(ptr), CD_MLOOPCOL, 0);
  }
  
 -static void rna_MeshColorLayer_active_render_set(PointerRNA *ptr, int value)
 +static void rna_MeshLoopColorLayer_active_render_set(PointerRNA *ptr, int value)
  {
 -      rna_CustomDataLayer_active_set(ptr, value, CD_MCOL, 1);
 +      rna_CustomDataLayer_active_set(ptr, rna_mesh_ldata(ptr), value, CD_MLOOPCOL, 1);
  }
  
 -static void rna_MeshColorLayer_active_set(PointerRNA *ptr, int value)
 +static void rna_MeshLoopColorLayer_active_set(PointerRNA *ptr, int value)
  {
 -      rna_CustomDataLayer_active_set(ptr, value, CD_MCOL, 0);
 +      rna_CustomDataLayer_active_set(ptr, rna_mesh_ldata(ptr), value, CD_MLOOPCOL, 0);
  }
  
 -static void rna_MeshColorLayer_name_set(PointerRNA *ptr, const char *value)
 +static void rna_MeshLoopColorLayer_name_set(PointerRNA *ptr, const char *value)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 +      /* Mesh *me = rna_mesh(ptr); */ /* UNUSED */
 +      /* CustomData *pdata = rna_mesh_pdata(ptr); */ /* UNUSED */
        CustomDataLayer *cdl= (CustomDataLayer*)ptr->data;
        BLI_strncpy_utf8(cdl->name, value, sizeof(cdl->name));
 -      CustomData_set_layer_unique_name(fdata, cdl - fdata->layers);
 +      CustomData_set_layer_unique_name(rna_mesh_ldata(ptr), cdl - rna_mesh_ldata(ptr)->layers);
  }
  
  static void rna_MeshFloatPropertyLayer_data_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 +      Mesh *me = rna_mesh(ptr);
        CustomDataLayer *layer= (CustomDataLayer*)ptr->data;
 -      rna_iterator_array_begin(iter, layer->data, sizeof(MFloatProperty), (me->edit_mesh)? 0: me->totface, 0, NULL);
 +      rna_iterator_array_begin(iter, layer->data, sizeof(MFloatProperty), me->totface, 0, NULL);
  }
  
  static int rna_MeshFloatPropertyLayer_data_length(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 -      return (me->edit_mesh)? 0: me->totface;
 +      Mesh *me = rna_mesh(ptr);
 +      return me->totface;
  }
  
 -static int rna_float_layer_check(CollectionPropertyIterator *UNUSED(iter), void *data)
 +static int rna_float_layer_check(CollectionPropertyIterator *iter, void *data)
  {
        CustomDataLayer *layer= (CustomDataLayer*)data;
        return (layer->type != CD_PROP_FLT);
  
  static void rna_Mesh_float_layers_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -      rna_iterator_array_begin(iter, (void*)fdata->layers, sizeof(CustomDataLayer), fdata->totlayer, 0, rna_float_layer_check);
 +      CustomData *pdata = rna_mesh_pdata(ptr);
 +      rna_iterator_array_begin(iter, (void*)pdata->layers, sizeof(CustomDataLayer), pdata->totlayer, 0, rna_float_layer_check);
  }
  
  static int rna_Mesh_float_layers_length(PointerRNA *ptr)
  {
 -      return rna_CustomDataLayer_length(ptr, CD_PROP_FLT);
 +      return CustomData_number_of_layers(rna_mesh_pdata(ptr), CD_PROP_FLT);
  }
  
 -static int rna_int_layer_check(CollectionPropertyIterator *UNUSED(iter), void *data)
 +static int rna_int_layer_check(CollectionPropertyIterator *iter, void *data)
  {
        CustomDataLayer *layer= (CustomDataLayer*)data;
        return (layer->type != CD_PROP_INT);
  
  static void rna_MeshIntPropertyLayer_data_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 +      Mesh *me = rna_mesh(ptr);
        CustomDataLayer *layer= (CustomDataLayer*)ptr->data;
 -      rna_iterator_array_begin(iter, layer->data, sizeof(MIntProperty), (me->edit_mesh)? 0: me->totface, 0, NULL);
 +      rna_iterator_array_begin(iter, layer->data, sizeof(MIntProperty), me->totface, 0, NULL);
  }
  
  static int rna_MeshIntPropertyLayer_data_length(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 -      return (me->edit_mesh)? 0: me->totface;
 +      Mesh *me = rna_mesh(ptr);
 +      return me->totface;
  }
  
  static void rna_Mesh_int_layers_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -      rna_iterator_array_begin(iter, (void*)fdata->layers, sizeof(CustomDataLayer), fdata->totlayer, 0, rna_int_layer_check);
 +      CustomData *pdata = rna_mesh_pdata(ptr);
 +      rna_iterator_array_begin(iter, (void*)pdata->layers, sizeof(CustomDataLayer), pdata->totlayer, 0, rna_int_layer_check);
  }
  
  static int rna_Mesh_int_layers_length(PointerRNA *ptr)
  {
 -      return rna_CustomDataLayer_length(ptr, CD_PROP_INT);
 +      return CustomData_number_of_layers(rna_mesh_pdata(ptr), CD_PROP_INT);
  }
  
 -static int rna_string_layer_check(CollectionPropertyIterator *UNUSED(iter), void *data)
 +static int rna_string_layer_check(CollectionPropertyIterator *iter, void *data)
  {
        CustomDataLayer *layer= (CustomDataLayer*)data;
        return (layer->type != CD_PROP_STR);
  
  static void rna_MeshStringPropertyLayer_data_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 +      Mesh *me = rna_mesh(ptr);
        CustomDataLayer *layer= (CustomDataLayer*)ptr->data;
 -      rna_iterator_array_begin(iter, layer->data, sizeof(MStringProperty), (me->edit_mesh)? 0: me->totface, 0, NULL);
 +      rna_iterator_array_begin(iter, layer->data, sizeof(MStringProperty), me->totface, 0, NULL);
  }
  
  static int rna_MeshStringPropertyLayer_data_length(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 -      return (me->edit_mesh)? 0: me->totface;
 +      Mesh *me = rna_mesh(ptr);
 +      return me->totface;
  }
  
  static void rna_Mesh_string_layers_begin(CollectionPropertyIterator *iter, PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->data;
 -      CustomData *fdata= rna_mesh_fdata(me);
 -      rna_iterator_array_begin(iter, (void*)fdata->layers, sizeof(CustomDataLayer), fdata->totlayer, 0, rna_string_layer_check);
 +      CustomData *pdata = rna_mesh_pdata(ptr);
 +      rna_iterator_array_begin(iter, (void*)pdata->layers, sizeof(CustomDataLayer), pdata->totlayer, 0, rna_string_layer_check);
  }
  
  static int rna_Mesh_string_layers_length(PointerRNA *ptr)
  {
 -      return rna_CustomDataLayer_length(ptr, CD_PROP_STR);
 +      return CustomData_number_of_layers(rna_mesh_pdata(ptr), CD_PROP_STR);
  }
  
  static void rna_TextureFace_image_set(PointerRNA *ptr, PointerRNA value)
  {
 -      MTFace *tf= (MTFace*)ptr->data;
 +      MTexPoly *tf= (MTexPoly*)ptr->data;
        ID *id= value.data;
  
        if(id) {
  
  static void rna_Mesh_auto_smooth_angle_set(PointerRNA *ptr, float value)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 +      Mesh *me = rna_mesh(ptr);
        value= RAD2DEGF(value);
        CLAMP(value, 1.0f, 80.0f);
        me->smoothresh= (int)value;
  
  static float rna_Mesh_auto_smooth_angle_get(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 +      Mesh *me = rna_mesh(ptr);
        return DEG2RADF((float)me->smoothresh);
  }
  
@@@ -884,165 -972,94 +884,165 @@@ static void rna_MeshFace_verts_set(Poin
        memcpy(&face->v1, values, (face->v4 ? 4 : 3) * sizeof(int));
  }
  
 +/* poly.vertices - this is faked loop access for convenience */
 +static int rna_MeshPoly_vertices_get_length(PointerRNA *ptr, int length[RNA_MAX_ARRAY_DIMENSION])
 +{
 +      MPoly *mp= (MPoly*)ptr->data;
 +      /* note, raw access uses dummy item, this _could_ crash, watch out for this, mface uses it but it cant work here */
 +      return (length[0]= mp->totloop);
 +}
 +
 +static void rna_MeshPoly_vertices_get(PointerRNA *ptr, int *values)
 +{
 +      Mesh *me = rna_mesh(ptr);
 +      MPoly *mp= (MPoly*)ptr->data;
 +      MLoop *ml= &me->mloop[mp->loopstart];
 +      unsigned int i;
 +      for(i= mp->totloop; i > 0; i--, values++, ml++) {
 +              *values = ml->v;
 +      }
 +}
 +
 +static void rna_MeshPoly_vertices_set(PointerRNA *ptr, const int *values)
 +{
 +      Mesh *me = rna_mesh(ptr);
 +      MPoly *mp= (MPoly*)ptr->data;
 +      MLoop *ml= &me->mloop[mp->loopstart];
 +      unsigned int i;
 +      for(i= mp->totloop; i > 0; i--, values++, ml++) {
 +              ml->v = *values;
 +      }
 +}
 +
 +
  static int rna_MeshVertex_index_get(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 +      Mesh *me = rna_mesh(ptr);
        MVert *vert= (MVert*)ptr->data;
        return (int)(vert - me->mvert);
  }
  
  static int rna_MeshEdge_index_get(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 +      Mesh *me = rna_mesh(ptr);
        MEdge *edge= (MEdge*)ptr->data;
        return (int)(edge - me->medge);
  }
  
  static int rna_MeshFace_index_get(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 +      Mesh *me = rna_mesh(ptr);
        MFace *face= (MFace*)ptr->data;
        return (int)(face - me->mface);
  }
  
 +static int rna_MeshPolygon_index_get(PointerRNA *ptr)
 +{
 +      Mesh *me = rna_mesh(ptr);
 +      MPoly *mpoly= (MPoly*)ptr->data;
 +      return (int)(mpoly - me->mpoly);
 +}
 +
  /* path construction */
  
  static char *rna_VertexGroupElement_path(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data; /* XXX not always! */
 +      Mesh *me = rna_mesh(ptr); /* XXX not always! */
        MDeformWeight *dw= (MDeformWeight*)ptr->data;
        MDeformVert *dvert;
        int a, b;
        
 -      /* sanity check: make sure that mesh pointer is valid */
 -      if (me == NULL) 
 -              return NULL;
 -      else if (GS(me->id.name) != ID_ME) {
 -              /* if object pointer, try to resolve the object's data to mesh pointer */
 -              if (GS(me->id.name) == ID_OB) {
 -                      Object *ob = (Object *)me;
 -                      
 -                      if (ob->type == OB_MESH)
 -                              me = (Mesh *)ob->data;
 -                      else
 -                              return NULL; /* nothing can be done */
 -              }
 -              else
 -                      return NULL; /* nothing can be done */
 -      }
 -      
 -      for(a=0, dvert=me->dvert; a<me->totvert; a++, dvert++) {
 -              for(b=0; b<dvert->totweight; b++) {
 +      for(a=0, dvert=me->dvert; a<me->totvert; a++, dvert++)
 +              for(b=0; b<dvert->totweight; b++)
                        if(dw == &dvert->dw[b])
 -                              return BLI_sprintfN("vertices[%d].groups[%d]", a, b);
 -              }
 -      }
 +                              return BLI_sprintfN("verts[%d].groups[%d]", a, b);
  
        return NULL;
  }
  
 +static char *rna_MeshPolygon_path(PointerRNA *ptr)
 +{
 +      return BLI_sprintfN("polygons[%d]", (int)((MPoly*)ptr->data - rna_mesh(ptr)->mpoly));
 +}
 +
  static char *rna_MeshFace_path(PointerRNA *ptr)
  {
 -      return BLI_sprintfN("faces[%d]", (int)((MFace*)ptr->data - ((Mesh*)ptr->id.data)->mface));
 +      return BLI_sprintfN("faces[%d]", (int)((MFace*)ptr->data - rna_mesh(ptr)->mface));
  }
  
  static char *rna_MeshEdge_path(PointerRNA *ptr)
  {
 -      return BLI_sprintfN("edges[%d]", (int)((MEdge*)ptr->data - ((Mesh*)ptr->id.data)->medge));
 +      return BLI_sprintfN("edges[%d]", (int)((MEdge*)ptr->data - rna_mesh(ptr)->medge));
 +}
 +
 +static char *rna_MeshLoop_path(PointerRNA *ptr)
 +{
 +      return BLI_sprintfN("loops[%d]", (int)((MLoop*)ptr->data - rna_mesh(ptr)->mloop));
  }
  
 +
  static char *rna_MeshVertex_path(PointerRNA *ptr)
  {
 -      return BLI_sprintfN("vertices[%d]", (int)((MVert*)ptr->data - ((Mesh*)ptr->id.data)->mvert));
 +      return BLI_sprintfN("vertices[%d]", (int)((MVert*)ptr->data - rna_mesh(ptr)->mvert));
  }
  
  static char *rna_MeshTextureFaceLayer_path(PointerRNA *ptr)
 +{
 +      return BLI_sprintfN("tessface_uv_textures[\"%s\"]", ((CustomDataLayer*)ptr->data)->name);
 +}
 +
 +static char *rna_MeshTexturePolyLayer_path(PointerRNA *ptr)
  {
        return BLI_sprintfN("uv_textures[\"%s\"]", ((CustomDataLayer*)ptr->data)->name);
  }
  
 -static char *rna_CustomDataData_path(PointerRNA *ptr, char *collection, int type)
 +static char *rna_PolyCustomData_data_path(PointerRNA *ptr, char *collection, int type)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 -      CustomData *fdata= rna_mesh_fdata(me);
        CustomDataLayer *cdl;
 -      int a, b;
 +      Mesh *me = rna_mesh(ptr);
 +      CustomData *pdata = rna_mesh_pdata(ptr);
 +      int a, b, totpoly = (me->edit_btmesh) ? 0 : me->totpoly;
 +
 +      for(cdl=pdata->layers, a=0; a<pdata->totlayer; cdl++, a++) {
 +              if(cdl->type == type) {
 +                      b= ((char*)ptr->data - ((char*)cdl->data))/CustomData_sizeof(type);
 +                      if(b >= 0 && b < totpoly)
 +                              return BLI_sprintfN("%s[\"%s\"].data[%d]", collection, cdl->name, b);
 +              }
 +      }
 +
 +      return NULL;
 +}
 +
 +static char *rna_LoopCustomData_data_path(PointerRNA *ptr, char *collection, int type)
 +{
 +      CustomDataLayer *cdl;
 +      Mesh *me = rna_mesh(ptr);
 +      CustomData *ldata = rna_mesh_ldata(ptr);
 +      int a, b, totloop = (me->edit_btmesh) ? 0 : me->totloop;
 +
 +      for(cdl=ldata->layers, a=0; a<ldata->totlayer; cdl++, a++) {
 +              if(cdl->type == type) {
 +                      b= ((char*)ptr->data - ((char*)cdl->data))/CustomData_sizeof(type);
 +                      if(b >= 0 && b < totloop)
 +                              return BLI_sprintfN("%s[\"%s\"].data[%d]", collection, cdl->name, b);
 +              }
 +      }
 +
 +      return NULL;
 +}
 +
 +static char *rna_FaceCustomData_data_path(PointerRNA *ptr, char *collection, int type)
 +{
 +      CustomDataLayer *cdl;
 +      Mesh *me = rna_mesh(ptr);
 +      CustomData *fdata = rna_mesh_fdata(ptr);
 +      int a, b, totloop = (me->edit_btmesh) ? 0 : me->totloop;
  
        for(cdl=fdata->layers, a=0; a<fdata->totlayer; cdl++, a++) {
                if(cdl->type == type) {
                        b= ((char*)ptr->data - ((char*)cdl->data))/CustomData_sizeof(type);
 -                      if(b >= 0 && b < me->totface)
 +                      if(b >= 0 && b < totloop)
                                return BLI_sprintfN("%s[\"%s\"].data[%d]", collection, cdl->name, b);
                }
        }
        return NULL;
  }
  
 +static char *rna_MeshUVLoop_path(PointerRNA *ptr)
 +{
 +      return rna_LoopCustomData_data_path(ptr, "uv_loop_layers", CD_MLOOPUV);
 +}
 +
  static char *rna_MeshTextureFace_path(PointerRNA *ptr)
  {
 -      return rna_CustomDataData_path(ptr, "uv_textures", CD_MTFACE);
 +      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)
 +{
 +      return BLI_sprintfN("tessface_vertex_colors[\"%s\"]", ((CustomDataLayer*)ptr->data)->name);
 +}
 +
 +static char *rna_MeshLoopColorLayer_path(PointerRNA *ptr)
  {
        return BLI_sprintfN("vertex_colors[\"%s\"]", ((CustomDataLayer*)ptr->data)->name);
  }
  
  static char *rna_MeshColor_path(PointerRNA *ptr)
  {
 -      return rna_CustomDataData_path(ptr, "vertex_colors", CD_MCOL);
 +      return rna_LoopCustomData_data_path(ptr, "vertex_colors", CD_MLOOPCOL);
  }
  
  static char *rna_MeshSticky_path(PointerRNA *ptr)
  {
 -      return BLI_sprintfN("sticky[%d]", (int)((MSticky*)ptr->data - ((Mesh*)ptr->id.data)->msticky));
 +      return BLI_sprintfN("sticky[%d]", (int)((MSticky*)ptr->data - rna_mesh(ptr)->msticky));
  }
  
  static char *rna_MeshIntPropertyLayer_path(PointerRNA *ptr)
  
  static char *rna_MeshIntProperty_path(PointerRNA *ptr)
  {
 -      return rna_CustomDataData_path(ptr, "layers_int", CD_MCOL);
 +      return rna_PolyCustomData_data_path(ptr, "layers_int", CD_PROP_INT);
  }
  
  static char *rna_MeshFloatPropertyLayer_path(PointerRNA *ptr)
  
  static char *rna_MeshFloatProperty_path(PointerRNA *ptr)
  {
 -      return rna_CustomDataData_path(ptr, "layers_float", CD_MCOL);
 +      return rna_PolyCustomData_data_path(ptr, "layers_float", CD_PROP_FLT);
  }
  
  static char *rna_MeshStringPropertyLayer_path(PointerRNA *ptr)
  
  static char *rna_MeshStringProperty_path(PointerRNA *ptr)
  {
 -      return rna_CustomDataData_path(ptr, "layers_string", CD_MCOL);
 +      return rna_PolyCustomData_data_path(ptr, "layers_string", CD_PROP_STR);
  }
  
  static int rna_Mesh_tot_vert_get(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 -      return me->edit_mesh ? me->edit_mesh->totvertsel : 0;
 +      Mesh *me = rna_mesh(ptr);
 +      return me->edit_btmesh ? me->edit_btmesh->bm->totvertsel : 0;
  }
  static int rna_Mesh_tot_edge_get(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 -      return me->edit_mesh ? me->edit_mesh->totedgesel: 0;
 +      Mesh *me = rna_mesh(ptr);
 +      return me->edit_btmesh ? me->edit_btmesh->bm->totedgesel: 0;
  }
  static int rna_Mesh_tot_face_get(PointerRNA *ptr)
  {
 -      Mesh *me= (Mesh*)ptr->id.data;
 -      return me->edit_mesh ? me->edit_mesh->totfacesel : 0;
 +      Mesh *me = rna_mesh(ptr);
 +      return me->edit_btmesh ? me->edit_btmesh->bm->totfacesel : 0;
  }
  
  static PointerRNA rna_Mesh_vertex_color_new(struct Mesh *me, struct bContext *C, const char *name)
  {
        PointerRNA ptr;
 -      CustomData *fdata;
 +      CustomData *ldata;
        CustomDataLayer *cdl= NULL;
        int index= ED_mesh_color_add(C, NULL, NULL, me, name, FALSE);
  
        if(index != -1) {
 -              fdata= rna_mesh_fdata(me);
 -              cdl= &fdata->layers[CustomData_get_layer_index_n(fdata, CD_MCOL, index)];
 +              ldata= rna_mesh_ldata_helper(me);
 +              cdl= &ldata->layers[CustomData_get_layer_index_n(ldata, CD_MLOOPCOL, index)];
        }
  
 -      RNA_pointer_create(&me->id, &RNA_MeshColorLayer, cdl, &ptr);
 +      RNA_pointer_create(&me->id, &RNA_MeshLoopColorLayer, cdl, &ptr);
        return ptr;
  }
  
@@@ -1195,16 -1197,16 +1195,16 @@@ static PointerRNA rna_Mesh_string_prope
  static PointerRNA rna_Mesh_uv_texture_new(struct Mesh *me, struct bContext *C, const char *name)
  {
        PointerRNA ptr;
 -      CustomData *fdata;
 +      CustomData *pdata;
        CustomDataLayer *cdl= NULL;
 -      int index= ED_mesh_uv_texture_add(C, me, name, FALSE);
 +      int index = ED_mesh_uv_texture_add(C, me, name, FALSE);
  
        if(index != -1) {
 -              fdata= rna_mesh_fdata(me);
 -              cdl= &fdata->layers[CustomData_get_layer_index_n(fdata, CD_MTFACE, index)];
 +              pdata= rna_mesh_pdata_helper(me);
 +              cdl= &pdata->layers[CustomData_get_layer_index_n(pdata, CD_MTEXPOLY, index)];
        }
  
 -      RNA_pointer_create(&me->id, &RNA_MeshTextureFaceLayer, cdl, &ptr);
 +      RNA_pointer_create(&me->id, &RNA_MeshTexturePolyLayer, cdl, &ptr);
        return ptr;
  }
  
@@@ -1273,7 -1275,8 +1273,7 @@@ static void rna_def_mvert(BlenderRNA *b
        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", NULL, NULL, NULL, NULL);
 +      RNA_def_property_collection_funcs(prop, "rna_MeshVertex_groups_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", NULL, NULL, NULL, NULL);
        RNA_def_property_struct_type(prop, "VertexGroupElement");
        RNA_def_property_ui_text(prop, "Groups", "Weights for the vertex groups this vertex is member of");
  
@@@ -1395,294 -1398,66 +1395,294 @@@ static void rna_def_mface(BlenderRNA *b
        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, "Face normal", "Local space unit length normal vector for this face");
 +      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");
 +      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_mloop(BlenderRNA *brna)
 +{
 +      StructRNA *srna;
 +      PropertyRNA *prop;
 +
 +      srna= RNA_def_struct(brna, "MeshLoop", NULL);
 +      RNA_def_struct_sdna(srna, "MLoop");
 +      RNA_def_struct_ui_text(srna, "Mesh Loop", "Loop in a Mesh datablock");
 +      RNA_def_struct_path_func(srna, "rna_MeshLoop_path");
 +      RNA_def_struct_ui_icon(srna, ICON_EDGESEL);
 +
 +      prop= RNA_def_property(srna, "vertex_index", PROP_INT, PROP_UNSIGNED);
 +      RNA_def_property_int_sdna(prop, NULL, "v");
 +      RNA_def_property_ui_text(prop, "Vertex", "Vertex index");
 +
 +      prop= RNA_def_property(srna, "edge_index", PROP_INT, PROP_UNSIGNED);
 +      RNA_def_property_int_sdna(prop, NULL, "e");
 +      RNA_def_property_ui_text(prop, "Edge", "Edge index");
 +}
 +
 +static void rna_def_mpolygon(BlenderRNA *brna)
 +{
 +      StructRNA *srna;
 +      PropertyRNA *prop;
 +
 +      srna= RNA_def_struct(brna, "MeshPolygon", NULL);
 +      RNA_def_struct_sdna(srna, "MPoly");
 +      RNA_def_struct_ui_text(srna, "Mesh Polygon", "Polygon in a Mesh datablock");
 +      RNA_def_struct_path_func(srna, "rna_MeshPolygon_path");
 +      RNA_def_struct_ui_icon(srna, ICON_FACESEL);
 +
 +      /* faked, actually access to loop vertex values, dont this way because manually setting up vertex/edge per loop is very low level
 +       * instead we setup poly sizes, assign indicies, then calc edges automatic when creating meshes from rna/py */
 +      prop= RNA_def_property(srna, "vertices", PROP_INT, PROP_UNSIGNED);
 +      RNA_def_property_array(prop, 3); // eek, this is still used in some cases but infact we dont want to use it at all here.
 +      RNA_def_property_flag(prop, PROP_DYNAMIC);
 +      RNA_def_property_dynamic_array_funcs(prop, "rna_MeshPoly_vertices_get_length");
 +      RNA_def_property_int_funcs(prop, "rna_MeshPoly_vertices_get", "rna_MeshPoly_vertices_set", NULL);
 +      RNA_def_property_ui_text(prop, "Vertices", "Vertex indices");
 +
 +      /* these are both very low level access */
 +      prop= RNA_def_property(srna, "loop_start", PROP_INT, PROP_UNSIGNED);
 +      RNA_def_property_int_sdna(prop, NULL, "loopstart");
 +      RNA_def_property_ui_text(prop, "Loop Start", "");
 +      /* also low level */
 +      prop= RNA_def_property(srna, "loop_total", PROP_INT, PROP_UNSIGNED);
 +      RNA_def_property_int_sdna(prop, NULL, "totloop");
 +      RNA_def_property_ui_text(prop, "Loop Total", "");
 +
 +      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", "");
 +      RNA_def_property_int_funcs(prop, NULL, NULL, "rna_MeshFace_material_index_range");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +
 +      prop= RNA_def_property(srna, "select", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_sdna(prop, NULL, "flag", ME_FACE_SEL);
 +      RNA_def_property_ui_text(prop, "Select", "");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_select");
 +
 +      prop= RNA_def_property(srna, "hide", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_sdna(prop, NULL, "flag", ME_HIDE);
 +      RNA_def_property_ui_text(prop, "Hide", "");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_select");
 +
 +      prop= RNA_def_property(srna, "use_smooth", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_sdna(prop, NULL, "flag", ME_SMOOTH);
 +      RNA_def_property_ui_text(prop, "Smooth", "");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +
 +      prop= RNA_def_property(srna, "normal", PROP_FLOAT, PROP_DIRECTION);
 +      RNA_def_property_array(prop, 3);
 +      RNA_def_property_range(prop, -1.0f, 1.0f);
 +      RNA_def_property_clear_flag(prop, PROP_EDITABLE);
 +      RNA_def_property_float_funcs(prop, "rna_MeshPolygon_normal_get", NULL, NULL);
 +      RNA_def_property_ui_text(prop, "face normal", "local space unit length normal vector for this polygon");
 +
 +      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_MeshPolygon_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_MeshPolygon_index_get", NULL, NULL);
 +      RNA_def_property_ui_text(prop, "Index", "Index number of the vertex");
 +}
 +
 +/* mesh.loop_uvs */
 +static void rna_def_mloopuv(BlenderRNA *brna)
 +{
 +      StructRNA *srna;
 +      PropertyRNA *prop;
 +
 +      srna= RNA_def_struct(brna, "MeshUVLoopLayer", NULL);
 +      RNA_def_struct_sdna(srna, "CustomDataLayer");
 +      RNA_def_struct_path_func(srna, "rna_MeshUVLoopLayer_path");
 +
 +      prop= RNA_def_property(srna, "data", PROP_COLLECTION, PROP_NONE);
 +      RNA_def_property_struct_type(prop, "MeshUVLoop");
 +      RNA_def_property_collection_funcs(prop, "rna_MeshUVLoopLayer_data_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", "rna_MeshUVLoopLayer_data_length", NULL, NULL, NULL);
 +
 +      srna= RNA_def_struct(brna, "MeshUVLoop", NULL);
 +      RNA_def_struct_sdna(srna, "MLoopUV");
 +      RNA_def_struct_path_func(srna, "rna_MeshUVLoop_path");
 +
 +      prop= RNA_def_property(srna, "uv", PROP_FLOAT, PROP_XYZ);
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +
 +      prop= RNA_def_property(srna, "pin_uv", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_sdna(prop, NULL, "flag", MLOOPUV_PINNED);
 +      RNA_def_property_ui_text(prop, "UV Pinned", "");
 +
 +      prop= RNA_def_property(srna, "select", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_sdna(prop, NULL, "flag", MLOOPUV_VERTSEL);
 +      RNA_def_property_ui_text(prop, "UV Select", "");
 +
 +      prop= RNA_def_property(srna, "select_edge", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_sdna(prop, NULL, "flag", MLOOPUV_EDGESEL);
 +      RNA_def_property_ui_text(prop, "UV Edge Select", "");
 +}
 +
 +static void rna_def_mtface(BlenderRNA *brna)
 +{
 +      StructRNA *srna;
 +      PropertyRNA *prop;
 +      const int uv_dim[]= {4, 2};
 +
 +      srna= RNA_def_struct(brna, "MeshTextureFaceLayer", NULL);
 +      RNA_def_struct_ui_text(srna, "Mesh UV Map", "UV map with assigned image textures in a Mesh datablock");
 +      RNA_def_struct_sdna(srna, "CustomDataLayer");
 +      RNA_def_struct_path_func(srna, "rna_MeshTextureFaceLayer_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_MeshTextureFaceLayer_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_MeshTextureFaceLayer_active_get", "rna_MeshTextureFaceLayer_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_MeshTextureFaceLayer_active_render_get",
 +                                     "rna_MeshTextureFaceLayer_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_MeshTextureFaceLayer_clone_get", "rna_MeshTextureFaceLayer_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, "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", NULL, NULL, NULL);
 +
 +      srna= RNA_def_struct(brna, "MeshTextureFace", NULL);
 +      RNA_def_struct_sdna(srna, "MTFace");
 +      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_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_ui_text(prop, "Image", "");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +
 +      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, "uv1", PROP_FLOAT, PROP_XYZ);
 +      RNA_def_property_array(prop, 2);
 +      RNA_def_property_float_funcs(prop, "rna_MeshTextureFace_uv1_get", "rna_MeshTextureFace_uv1_set", NULL);
 +      RNA_def_property_ui_text(prop, "UV 1", "");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +
 +      prop= RNA_def_property(srna, "uv2", PROP_FLOAT, PROP_XYZ);
 +      RNA_def_property_array(prop, 2);
 +      RNA_def_property_float_funcs(prop, "rna_MeshTextureFace_uv2_get", "rna_MeshTextureFace_uv2_set", NULL);
 +      RNA_def_property_ui_text(prop, "UV 2", "");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +
 +      prop= RNA_def_property(srna, "uv3", PROP_FLOAT, PROP_XYZ);
 +      RNA_def_property_array(prop, 2);
 +      RNA_def_property_float_funcs(prop, "rna_MeshTextureFace_uv3_get", "rna_MeshTextureFace_uv3_set", NULL);
 +      RNA_def_property_ui_text(prop, "UV 3", "");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +
 +      prop= RNA_def_property(srna, "uv4", PROP_FLOAT, PROP_XYZ);
 +      RNA_def_property_array(prop, 2);
 +      RNA_def_property_float_funcs(prop, "rna_MeshTextureFace_uv4_get", "rna_MeshTextureFace_uv4_set", NULL);
 +      RNA_def_property_ui_text(prop, "UV 4", "");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +
 +      prop= RNA_def_property(srna, "uv", PROP_FLOAT, PROP_NONE);
 +      RNA_def_property_multi_array(prop, 2, uv_dim);
 +      RNA_def_property_flag(prop, PROP_DYNAMIC);
 +      RNA_def_property_dynamic_array_funcs(prop, "rna_MeshTextureFace_uv_get_length");
 +      RNA_def_property_float_funcs(prop, "rna_MeshTextureFace_uv_get", "rna_MeshTextureFace_uv_set", NULL);
 +      RNA_def_property_ui_text(prop, "UV", "");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +
 +      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");
  
 -      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)
 +static void rna_def_mtexpoly(BlenderRNA *brna)
  {
        StructRNA *srna;
        PropertyRNA *prop;
 -      const int uv_dim[]= {4, 2};
 +#if 0  /* BMESH_TODO: needed later when do another todo */
 +      int uv_dim[]= {4, 2};
 +#endif
  
 -      srna= RNA_def_struct(brna, "MeshTextureFaceLayer", NULL);
 +      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 datablock");
        RNA_def_struct_sdna(srna, "CustomDataLayer");
 -      RNA_def_struct_path_func(srna, "rna_MeshTextureFaceLayer_path");
 +      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_MeshTextureFaceLayer_name_set");
 +      RNA_def_property_string_funcs(prop, NULL, NULL, "rna_MeshTexturePolyLayer_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_MeshTextureFaceLayer_active_get", "rna_MeshTextureFaceLayer_active_set");
 +      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_MeshTextureFaceLayer_active_render_get",
 -                                     "rna_MeshTextureFaceLayer_active_render_set");
 +      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_MeshTextureFaceLayer_clone_get", "rna_MeshTextureFaceLayer_clone_set");
 +      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, "MeshTextureFace");
 +      RNA_def_property_struct_type(prop, "MeshTexturePoly");
        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", NULL, NULL, NULL);
 +      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, "MeshTextureFace", NULL);
 -      RNA_def_struct_sdna(srna, "MTFace");
 +      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_MeshTextureFace_path");
 +      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_ui_text(prop, "UV Selected", "");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_select");
  
 +#if 0 /* moved to MeshUVLoopLayer */
        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, "uv1", PROP_FLOAT, PROP_XYZ);
 -      RNA_def_property_array(prop, 2);
 -      RNA_def_property_float_funcs(prop, "rna_MeshTextureFace_uv1_get", "rna_MeshTextureFace_uv1_set", NULL);
 -      RNA_def_property_ui_text(prop, "UV 1", "");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 -
 -      prop= RNA_def_property(srna, "uv2", PROP_FLOAT, PROP_XYZ);
 -      RNA_def_property_array(prop, 2);
 -      RNA_def_property_float_funcs(prop, "rna_MeshTextureFace_uv2_get", "rna_MeshTextureFace_uv2_set", NULL);
 -      RNA_def_property_ui_text(prop, "UV 2", "");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 -
 -      prop= RNA_def_property(srna, "uv3", PROP_FLOAT, PROP_XYZ);
 -      RNA_def_property_array(prop, 2);
 -      RNA_def_property_float_funcs(prop, "rna_MeshTextureFace_uv3_get", "rna_MeshTextureFace_uv3_set", NULL);
 -      RNA_def_property_ui_text(prop, "UV 3", "");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 -
 -      prop= RNA_def_property(srna, "uv4", PROP_FLOAT, PROP_XYZ);
 -      RNA_def_property_array(prop, 2);
 -      RNA_def_property_float_funcs(prop, "rna_MeshTextureFace_uv4_get", "rna_MeshTextureFace_uv4_set", NULL);
 -      RNA_def_property_ui_text(prop, "UV 4", "");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 -
 -      prop= RNA_def_property(srna, "uv", PROP_FLOAT, PROP_NONE);
 -      RNA_def_property_multi_array(prop, 2, uv_dim);
 -      RNA_def_property_flag(prop, PROP_DYNAMIC);
 -      RNA_def_property_dynamic_array_funcs(prop, "rna_MeshTextureFace_uv_get_length");
 -      RNA_def_property_float_funcs(prop, "rna_MeshTextureFace_uv_get", "rna_MeshTextureFace_uv_set", NULL);
 -      RNA_def_property_ui_text(prop, "UV", "");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 -
        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_msticky(BlenderRNA *brna)
@@@ -1740,7 -1546,7 +1740,7 @@@ static void rna_def_mcol(BlenderRNA *br
  
        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_MeshColorLayer_name_set");
 +      RNA_def_property_string_funcs(prop, NULL, NULL, NULL);
        RNA_def_property_ui_text(prop, "Name", "Name of Vertex color 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, "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", NULL, NULL, NULL);
 +      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", NULL, NULL, NULL);
  
        srna= RNA_def_struct(brna, "MeshColor", NULL);
        RNA_def_struct_sdna(srna, "MCol");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
  }
  
 +static void rna_def_mloopcol(BlenderRNA *brna)
 +{
 +      StructRNA *srna;
 +      PropertyRNA *prop;
 +
 +      srna= RNA_def_struct(brna, "MeshLoopColorLayer", NULL);
 +      RNA_def_struct_ui_text(srna, "Mesh Vertex Color Layer", "Layer of vertex colors in a Mesh datablock");
 +      RNA_def_struct_sdna(srna, "CustomDataLayer");
 +      RNA_def_struct_path_func(srna, "rna_MeshLoopColorLayer_path");
 +      RNA_def_struct_ui_icon(srna, ICON_GROUP_VCOL);
 +
 +      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_MeshLoopColorLayer_name_set");
 +      RNA_def_property_ui_text(prop, "Name", "Name of Vertex color layer");
 +      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_MeshLoopColorLayer_active_get", "rna_MeshLoopColorLayer_active_set");
 +      RNA_def_property_ui_text(prop, "Active", "Sets the layer 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_MeshLoopColorLayer_active_render_get", "rna_MeshLoopColorLayer_active_render_set");
 +      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, "data", PROP_COLLECTION, PROP_NONE);
 +      RNA_def_property_struct_type(prop, "MeshLoopColor");
 +      RNA_def_property_ui_text(prop, "Data", "");
 +      RNA_def_property_collection_funcs(prop, "rna_MeshLoopColorLayer_data_begin", "rna_iterator_array_next", "rna_iterator_array_end", "rna_iterator_array_get", "rna_MeshLoopColorLayer_data_length", NULL, NULL, NULL);
 +
 +
 +      srna= RNA_def_struct(brna, "MeshLoopColor", NULL);
 +      RNA_def_struct_sdna(srna, "MLoopCol");
 +      RNA_def_struct_ui_text(srna, "Mesh Vertex Color", "Vertex loop colors in a Mesh");
 +      RNA_def_struct_path_func(srna, "rna_MeshColor_path");
 +
 +      prop= RNA_def_property(srna, "color", PROP_FLOAT, PROP_COLOR);
 +      RNA_def_property_array(prop, 3);
 +      RNA_def_property_range(prop, 0.0f, 1.0f);
 +      RNA_def_property_float_funcs(prop, "rna_MeshLoopColor_color_get", "rna_MeshLoopColor_color_set", NULL);
 +      RNA_def_property_ui_text(prop, "Color", "");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +}
 +
  static void rna_def_mproperties(BlenderRNA *brna)
  {
        StructRNA *srna;
        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", NULL, NULL, NULL);
 +      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", NULL, NULL, NULL);
  
        srna= RNA_def_struct(brna, "MeshFloatProperty", NULL);
        RNA_def_struct_sdna(srna, "MFloatProperty");
        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", NULL, NULL, NULL);
 +      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", NULL, NULL, NULL);
  
        srna= RNA_def_struct(brna, "MeshIntProperty", NULL);
        RNA_def_struct_sdna(srna, "MIntProperty");
        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", NULL, NULL, NULL);
 +      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", NULL, NULL, NULL);
  
        srna= RNA_def_struct(brna, "MeshStringProperty", NULL);
        RNA_def_struct_sdna(srna, "MStringProperty");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
  }
  
 +void rna_def_texmat_common(StructRNA *srna, const char *texspace_editable)
 +{
 +      PropertyRNA *prop;
 +
 +      /* texture space */
 +      prop= RNA_def_property(srna, "auto_texspace", PROP_BOOLEAN, PROP_NONE);
 +      RNA_def_property_boolean_sdna(prop, NULL, "texflag", AUTOSPACE);
 +      RNA_def_property_ui_text(prop, "Auto Texture Space", "Adjusts active object's texture space automatically when transforming object");
 +
 +      prop= RNA_def_property(srna, "texspace_location", PROP_FLOAT, PROP_TRANSLATION);
 +      RNA_def_property_float_sdna(prop, NULL, "loc");
 +      RNA_def_property_ui_text(prop, "Texure Space Location", "Texture space location");
 +      RNA_def_property_editable_func(prop, texspace_editable);
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
 +
 +      prop= RNA_def_property(srna, "texspace_size", PROP_FLOAT, PROP_XYZ);
 +      RNA_def_property_float_sdna(prop, NULL, "size");
 +      RNA_def_property_ui_text(prop, "Texture Space Size", "Texture space size");
 +      RNA_def_property_editable_func(prop, texspace_editable);
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
 +
 +      /* not supported yet
 +      prop= RNA_def_property(srna, "texspace_rot", PROP_FLOAT, PROP_EULER);
 +      RNA_def_property_float(prop, NULL, "rot");
 +      RNA_def_property_ui_text(prop, "Texture Space Rotation", "Texture space rotation");
 +      RNA_def_property_editable_func(prop, texspace_editable);
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");*/
 +
 +      /* materials */
 +      prop= RNA_def_property(srna, "materials", PROP_COLLECTION, PROP_NONE);
 +      RNA_def_property_collection_sdna(prop, NULL, "mat", "totcol");
 +      RNA_def_property_struct_type(prop, "Material");
 +      RNA_def_property_ui_text(prop, "Materials", "");
 +      RNA_def_property_srna(prop, "IDMaterials"); /* see rna_ID.c */
 +      RNA_def_property_collection_funcs(prop, 0, NULL, NULL, NULL, NULL, NULL, NULL, "rna_IDMaterials_assign_int");
 +}
 +
 +
 +/* scene.objects */
  /* mesh.vertices */
  static void rna_def_mesh_vertices(BlenderRNA *brna, PropertyRNA *cprop)
  {
@@@ -2020,7 -1748,7 +2020,7 @@@ static void rna_def_mesh_faces(BlenderR
        PropertyRNA *prop;
  
        FunctionRNA *func;
 -      /*PropertyRNA *parm;*/
 +//    PropertyRNA *parm;
  
        RNA_def_property_srna(cprop, "MeshFaces");
        srna= RNA_def_struct(brna, "MeshFaces", NULL);
        RNA_def_property_int_sdna(prop, NULL, "act_face");
        RNA_def_property_ui_text(prop, "Active Face", "The active face for this mesh");
  
 -      prop= RNA_def_property(srna, "active_tface", PROP_POINTER, PROP_UNSIGNED);
 -      RNA_def_property_struct_type(prop, "MeshTextureFace");
 -      RNA_def_property_pointer_funcs(prop, "rna_Mesh_active_mtface_get", NULL, NULL, NULL);
 -      RNA_def_property_ui_text(prop, "Active UV Map Face", "Active UV Map Face");
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 -
        func= RNA_def_function(srna, "add", "ED_mesh_faces_add");
        RNA_def_function_flag(func, FUNC_USE_REPORTS);
        RNA_def_int(func, "count", 0, 0, INT_MAX, "Count", "Number of faces to add", 0, INT_MAX);
  #endif
  }
  
 -/* mesh.vertex_colors */
 -static void rna_def_vertex_colors(BlenderRNA *brna, PropertyRNA *cprop)
 +/* mesh.loops */
 +static void rna_def_mesh_loops(BlenderRNA *brna, PropertyRNA *cprop)
 +{
 +      StructRNA *srna;
 +
 +      /*PropertyRNA *prop;*/
 +
 +      FunctionRNA *func;
 +      /*PropertyRNA *parm;*/
 +
 +      RNA_def_property_srna(cprop, "MeshLoops");
 +      srna= RNA_def_struct(brna, "MeshLoops", NULL);
 +      RNA_def_struct_sdna(srna, "Mesh");
 +      RNA_def_struct_ui_text(srna, "Mesh Loops", "Collection of mesh loops");
 +
 +#if 0 // BMESH_TODO
 +      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 Polygon", "The active polygon for this mesh");
 +#endif
 +
 +      func= RNA_def_function(srna, "add", "ED_mesh_loops_add");
 +      RNA_def_function_flag(func, FUNC_USE_REPORTS);
 +      RNA_def_int(func, "count", 0, 0, INT_MAX, "Count", "Number of loops to add", 0, INT_MAX);
 +}
 +
 +/* mesh.polygons */
 +static void rna_def_mesh_polygons(BlenderRNA *brna, PropertyRNA *cprop)
  {
        StructRNA *srna;
 +
        PropertyRNA *prop;
  
        FunctionRNA *func;
        PropertyRNA *parm;
  
 +      RNA_def_property_srna(cprop, "MeshPolygons");
 +      srna= RNA_def_struct(brna, "MeshPolygons", NULL);
 +      RNA_def_struct_sdna(srna, "Mesh");
 +      RNA_def_struct_ui_text(srna, "Mesh Polygons", "Collection of mesh polygons");
 +
 +      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 Polygon", "The active polygon for this mesh");
 +
 +      func= RNA_def_function(srna, "add", "ED_mesh_polys_add");
 +      RNA_def_function_flag(func, FUNC_USE_REPORTS);
 +      parm= RNA_def_int(func, "count", 0, 0, INT_MAX, "Count", "Number of polygons to add", 0, INT_MAX);
 +}
 +
 +
 +/* mesh.vertex_colors */
 +static void rna_def_tessface_vertex_colors(BlenderRNA *brna, PropertyRNA *cprop)
 +{
 +      StructRNA *srna;
 +      PropertyRNA *prop;
 +
 +      //FunctionRNA *func;
 +      //PropertyRNA *parm;
 +
        RNA_def_property_srna(cprop, "VertexColors");
        srna= RNA_def_struct(brna, "VertexColors", NULL);
        RNA_def_struct_sdna(srna, "Mesh");
        RNA_def_struct_ui_text(srna, "Vertex Colors", "Collection of vertex colors");
        
 +      prop= RNA_def_property(srna, "active", PROP_POINTER, PROP_UNSIGNED);
 +      RNA_def_property_struct_type(prop, "MeshColorLayer");
 +      RNA_def_property_pointer_funcs(prop, "rna_Mesh_tessface_vertex_color_active_get", "rna_Mesh_tessface_vertex_color_active_set", NULL, NULL);
 +      RNA_def_property_ui_text(prop, "Active Vertex Color Layer", "Active vertex color layer");
 +      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_tessface_vertex_color_active_index_get", "rna_Mesh_tessface_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");
 +}
 +
 +static void rna_def_loop_colors(BlenderRNA *brna, PropertyRNA *cprop)
 +{
 +      StructRNA *srna;
 +      PropertyRNA *prop;
 +
 +      FunctionRNA *func;
 +      PropertyRNA *parm;
 +
 +      RNA_def_property_srna(cprop, "LoopColors");
 +      srna= RNA_def_struct(brna, "LoopColors", NULL);
 +      RNA_def_struct_sdna(srna, "Mesh");
 +      RNA_def_struct_ui_text(srna, "Loop Colors", "Collection of vertex colors");
 +      
        func= RNA_def_function(srna, "new", "rna_Mesh_vertex_color_new");
        RNA_def_function_flag(func, FUNC_USE_CONTEXT);
        RNA_def_function_ui_description(func, "Add a vertex color layer to Mesh");
        RNA_def_string(func, "name", "Col", 0, "", "Vertex color name");
 -      parm= RNA_def_pointer(func, "layer", "MeshColorLayer", "", "The newly created layer");
 +      parm= RNA_def_pointer(func, "layer", "MeshLoopColorLayer", "", "The newly created layer");
        RNA_def_property_flag(parm, PROP_RNAPTR);
        RNA_def_function_return(func, parm);
        
        RNA_def_property_flag(parm, PROP_REQUIRED|PROP_NEVER_NULL);
  */
        prop= RNA_def_property(srna, "active", PROP_POINTER, PROP_UNSIGNED);
 -      RNA_def_property_struct_type(prop, "MeshColorLayer");
 -      RNA_def_property_pointer_funcs(prop, "rna_Mesh_active_vertex_color_get", "rna_Mesh_active_vertex_color_set", NULL, NULL);
 +      RNA_def_property_struct_type(prop, "MeshLoopColorLayer");
 +      RNA_def_property_pointer_funcs(prop, "rna_Mesh_vertex_color_active_get", "rna_Mesh_vertex_color_active_set", NULL, NULL);
        RNA_def_property_flag(prop, PROP_EDITABLE);
        RNA_def_property_ui_text(prop, "Active Vertex Color Layer", "Active vertex color layer");
        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_active_vertex_color_index_get", "rna_Mesh_active_vertex_color_index_set", "rna_Mesh_active_vertex_color_index_range");
 +      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");
  }
  
 +static void rna_def_uv_loop_layers(BlenderRNA *brna, PropertyRNA *cprop)
 +{
 +      StructRNA *srna;
 +      PropertyRNA *prop;
 +
 +      //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");
 +      
 +      prop= RNA_def_property(srna, "active", PROP_POINTER, PROP_UNSIGNED);
 +      RNA_def_property_struct_type(prop, "MeshUVLoopLayer");
 +      RNA_def_property_pointer_funcs(prop, "rna_Mesh_uv_loop_layer_active_get", "rna_Mesh_uv_loop_layer_active_set", NULL, NULL);
 +      RNA_def_property_flag(prop, PROP_EDITABLE);
 +      RNA_def_property_ui_text(prop, "Active UV loop layer", "Active UV loop layer");
 +      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_loop_layer_active_index_get", "rna_Mesh_uv_loop_layer_active_index_set", "rna_Mesh_uv_loop_layer_index_range");
 +      RNA_def_property_ui_text(prop, "Active UV loop layer Index", "Active UV loop layer index");
 +      RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
 +}
 +
  /* mesh int layers */
  static void rna_def_int_layers(BlenderRNA *brna, PropertyRNA *cprop)
  {
@@@ -2252,32 -1884,6 +2252,32 @@@ static void rna_def_string_layers(Blend
  }
  
  /* mesh.uv_layers */
 +static void rna_def_tessface_uv_textures(BlenderRNA *brna, PropertyRNA *cprop)
 +{
 +      StructRNA *srna;
 +      PropertyRNA *prop;
 +
 +      //FunctionRNA *func;
 +      //PropertyRNA *parm;
 +
 +      RNA_def_property_srna(cprop, "TessfaceUVTextures");
 +      srna= RNA_def_struct(brna, "TessfaceUVTextures", NULL);
 +      RNA_def_struct_sdna(srna, "Mesh");
 +      RNA_def_struct_ui_text(srna, "UV Maps", "Collection of UV maps for tesselated faces");
 +      
 +      prop= RNA_def_property(srna, "active", PROP_POINTER, PROP_UNSIGNED);
 +      RNA_def_property_struct_type(prop, "MeshTextureFaceLayer");
 +      RNA_def_property_pointer_funcs(prop, "rna_Mesh_tessface_uv_texture_active_get", "rna_Mesh_tessface_uv_texture_active_set", NULL, NULL);
 +      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_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;
        
        func= RNA_def_function(srna, "new", "rna_Mesh_uv_texture_new");
        RNA_def_function_flag(func, FUNC_USE_CONTEXT);
 -      RNA_def_function_ui_description(func, "Add a UV texture layer to Mesh");
 +      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", "MeshTextureFaceLayer", "", "The newly created layer");
 +      parm= RNA_def_pointer(func, "layer", "MeshTexturePolyLayer", "", "The newly created layer");
        RNA_def_property_flag(parm, PROP_RNAPTR);
        RNA_def_function_return(func, parm);
  
        RNA_def_property_flag(parm, PROP_REQUIRED|PROP_NEVER_NULL);
  */
        prop= RNA_def_property(srna, "active", PROP_POINTER, PROP_UNSIGNED);
 -      RNA_def_property_struct_type(prop, "MeshTextureFaceLayer");
 -      RNA_def_property_pointer_funcs(prop, "rna_Mesh_active_uv_texture_get", "rna_Mesh_active_uv_texture_set", NULL, NULL);
 +      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);
        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_active_uv_texture_index_get",
 -                                 "rna_Mesh_active_uv_texture_index_set", "rna_Mesh_active_uv_texture_index_range");
 +      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_def_property_ui_text(prop, "Active UV Map Index", "Active UV Map index");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_data");
  }
@@@ -2346,18 -1953,6 +2346,18 @@@ static void rna_def_mesh(BlenderRNA *br
        RNA_def_property_ui_text(prop, "Faces", "Faces of the mesh");
        rna_def_mesh_faces(brna, prop);
  
 +      prop= RNA_def_property(srna, "loops", PROP_COLLECTION, PROP_NONE);
 +      RNA_def_property_collection_sdna(prop, NULL, "mloop", "totloop");
 +      RNA_def_property_struct_type(prop, "MeshLoop");
 +      RNA_def_property_ui_text(prop, "Loops", "Loops of the mesh");
 +      rna_def_mesh_loops(brna, prop);
 +
 +      prop= RNA_def_property(srna, "polygons", PROP_COLLECTION, PROP_NONE);
 +      RNA_def_property_collection_sdna(prop, NULL, "mpoly", "totpoly");
 +      RNA_def_property_struct_type(prop, "MeshPolygon");
 +      RNA_def_property_ui_text(prop, "Polygons", "Polygons of the mesh");
 +      rna_def_mesh_polygons(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");
        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 indices (vertex indices must be aligned)");
 +      RNA_def_property_ui_text(prop, "Texture Mesh", "Use another mesh for texture indicies (vertex indicies must be aligned)");
 +
 +      /* UV loop layers */
 +      prop= RNA_def_property(srna, "uv_loop_layers", PROP_COLLECTION, PROP_NONE);
 +      RNA_def_property_collection_sdna(prop, NULL, "ldata.layers", "ldata.totlayer");
 +      RNA_def_property_collection_funcs(prop, "rna_Mesh_uv_loop_layers_begin", NULL, NULL, NULL,
 +                                        "rna_Mesh_uv_loop_layers_length", NULL, NULL, NULL);
 +      RNA_def_property_struct_type(prop, "MeshUVLoopLayer");
 +      RNA_def_property_ui_text(prop, "UV Loop Layers", "All UV loop layers");
 +      rna_def_uv_loop_layers(brna, prop);
 +
 +      prop= RNA_def_property(srna, "uv_loop_layer_clone", PROP_POINTER, PROP_UNSIGNED);
 +      RNA_def_property_struct_type(prop, "MeshUVLoopLayer");
 +      RNA_def_property_pointer_funcs(prop, "rna_Mesh_uv_loop_layer_clone_get", "rna_Mesh_uv_loop_layer_clone_set", NULL, NULL);
 +      RNA_def_property_flag(prop, PROP_EDITABLE);
 +      RNA_def_property_ui_text(prop, "Clone UV loop layer", "UV loop layer to be used as cloning source");
  
 -      /* UV textures */
 -      prop= RNA_def_property(srna, "uv_textures", PROP_COLLECTION, PROP_NONE);
 +      prop= RNA_def_property(srna, "uv_loop_layer_clone_index", PROP_INT, PROP_UNSIGNED);
 +      RNA_def_property_int_funcs(prop, "rna_Mesh_uv_loop_layer_clone_index_get", "rna_Mesh_uv_loop_layer_clone_index_set", "rna_Mesh_uv_loop_layer_index_range");
 +      RNA_def_property_ui_text(prop, "Clone UV loop layer Index", "Clone UV loop layer index");
 +
 +      prop= RNA_def_property(srna, "uv_loop_layer_stencil", PROP_POINTER, PROP_UNSIGNED);
 +      RNA_def_property_struct_type(prop, "MeshUVLoopLayer");
 +      RNA_def_property_pointer_funcs(prop, "rna_Mesh_uv_loop_layer_stencil_get", "rna_Mesh_uv_loop_layer_stencil_set", NULL, NULL);
 +      RNA_def_property_flag(prop, PROP_EDITABLE);
 +      RNA_def_property_ui_text(prop, "Mask UV loop layer", "UV loop layer to mask the painted area");
 +
 +      prop= RNA_def_property(srna, "uv_loop_layer_stencil_index", PROP_INT, PROP_UNSIGNED);
 +      RNA_def_property_int_funcs(prop, "rna_Mesh_uv_loop_layer_stencil_index_get", "rna_Mesh_uv_loop_layer_stencil_index_set", "rna_Mesh_uv_loop_layer_index_range");
 +      RNA_def_property_ui_text(prop, "Mask UV loop layer Index", "Mask UV loop layer index");
 +
 +      /* Tesselated face UV maps - used by renderers */
 +      prop= RNA_def_property(srna, "tessface_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_tessface_uv_textures_begin", NULL, NULL, NULL,
 +                                        "rna_Mesh_tessface_uv_textures_length", NULL, NULL, NULL);
 +      RNA_def_property_struct_type(prop, "MeshTextureFaceLayer");
 +      RNA_def_property_ui_text(prop, "Tesselated Face UV Maps", "All UV maps for tesselated 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, "MeshTextureFaceLayer");
 -      RNA_def_property_ui_text(prop, "UV Maps", "");
 +      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_UNSIGNED);
 -      RNA_def_property_struct_type(prop, "MeshTextureFaceLayer");
 +      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_active_uv_texture_index_range");
 -      RNA_def_property_ui_text(prop, "Clone UV Map Index", "Clone UV texture index");
 +      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_UNSIGNED);
 -      RNA_def_property_struct_type(prop, "MeshTextureFaceLayer");
 +      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");
  
        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_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");
  
 +      /* Tesselated face colors - used by renderers */
 +
 +      prop= RNA_def_property(srna, "tessface_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_tessface_vertex_colors_begin", NULL, NULL, NULL,
 +                                        "rna_Mesh_tessface_vertex_colors_length", NULL, NULL, NULL);
 +      RNA_def_property_struct_type(prop, "MeshColorLayer");
 +      RNA_def_property_ui_text(prop, "Tesselated Face Colors", "All tesselated face colors (read-only, for use by renderers)");
 +      rna_def_tessface_vertex_colors(brna, prop);
 +
        /* 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_sdna(prop, NULL, "ldata.layers", "ldata.totlayer");
        RNA_def_property_collection_funcs(prop, "rna_Mesh_vertex_colors_begin", NULL, NULL, NULL,
                                          "rna_Mesh_vertex_colors_length", NULL, NULL, NULL);
 -      RNA_def_property_struct_type(prop, "MeshColorLayer");
 -      RNA_def_property_ui_text(prop, "Vertex Colors", "");
 -      rna_def_vertex_colors(brna, prop);
 +      RNA_def_property_struct_type(prop, "MeshLoopColorLayer");
 +      RNA_def_property_ui_text(prop, "Vertex Colors", "All vertex colors");
 +      rna_def_loop_colors(brna, prop);
  
        prop= RNA_def_property(srna, "layers_float", PROP_COLLECTION, PROP_NONE);
 -      RNA_def_property_collection_sdna(prop, NULL, "fdata.layers", "fdata.totlayer");
 +      RNA_def_property_collection_sdna(prop, NULL, "pdata.layers", "pdata.totlayer");
        RNA_def_property_collection_funcs(prop, "rna_Mesh_float_layers_begin", NULL, NULL, NULL,
                                          "rna_Mesh_float_layers_length", NULL, NULL, NULL);
        RNA_def_property_struct_type(prop, "MeshFloatPropertyLayer");
        rna_def_float_layers(brna, prop);
  
        prop= RNA_def_property(srna, "layers_int", PROP_COLLECTION, PROP_NONE);
 -      RNA_def_property_collection_sdna(prop, NULL, "fdata.layers", "fdata.totlayer");
 +      RNA_def_property_collection_sdna(prop, NULL, "pdata.layers", "pdata.totlayer");
        RNA_def_property_collection_funcs(prop, "rna_Mesh_int_layers_begin", NULL, NULL, NULL,
                                          "rna_Mesh_int_layers_length", NULL, NULL, NULL);
        RNA_def_property_struct_type(prop, "MeshIntPropertyLayer");
        rna_def_int_layers(brna, prop);
  
        prop= RNA_def_property(srna, "layers_string", PROP_COLLECTION, PROP_NONE);
 -      RNA_def_property_collection_sdna(prop, NULL, "fdata.layers", "fdata.totlayer");
 +      RNA_def_property_collection_sdna(prop, NULL, "pdata.layers", "pdata.totlayer");
        RNA_def_property_collection_funcs(prop, "rna_Mesh_string_layers_begin", NULL, NULL, NULL,
                                          "rna_Mesh_string_layers_length", NULL, NULL, NULL);
        RNA_def_property_struct_type(prop, "MeshStringPropertyLayer");
  
        prop= RNA_def_property(srna, "use_auto_smooth", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", ME_AUTOSMOOTH);
 -      RNA_def_property_ui_text(prop, "Auto Smooth",
 -                               "Treat all set-smoothed faces with angles less than the "
 -                               "specified angle as 'smooth' during render");
 +      RNA_def_property_ui_text(prop, "Auto Smooth", "Treats all set-smoothed faces with angles less than the specified angle as 'smooth' during render");
  
  #if 1 /* expose as radians */
        prop= RNA_def_property(srna, "auto_smooth_angle", PROP_FLOAT, PROP_ANGLE);
        RNA_def_property_int_sdna(prop, NULL, "smoothresh");
        RNA_def_property_range(prop, 1, 80);
  #endif
 -      RNA_def_property_ui_text(prop, "Auto Smooth Angle",
 -                               "Maximum angle between face normals that 'Auto Smooth' will operate on");
 +      RNA_def_property_ui_text(prop, "Auto Smooth Angle", "Defines maximum angle between face normals that 'Auto Smooth' will operate on");
  
        prop= RNA_def_property(srna, "show_double_sided", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "flag", ME_TWOSIDED);
        /* texture space */
        prop= RNA_def_property(srna, "use_auto_texspace", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "texflag", AUTOSPACE);
 -      RNA_def_property_ui_text(prop, "Auto Texture Space",
 -                               "Adjust active object's texture space automatically when transforming object");
 -      RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, "rna_Mesh_texspace_set");
 -      
 -      prop= RNA_def_property(srna, "texspace_location", PROP_FLOAT, PROP_TRANSLATION);
 +      RNA_def_property_ui_text(prop, "Auto Texture Space", "Adjusts active object's texture space automatically when transforming object");
 +
 +      /*prop= RNA_def_property(srna, "texspace_location", PROP_FLOAT, PROP_TRANSLATION);
        RNA_def_property_array(prop, 3);
        RNA_def_property_ui_text(prop, "Texture Space Location", "Texture space location");
        RNA_def_property_editable_func(prop, "rna_Mesh_texspace_editable");
 -      RNA_def_property_float_funcs(prop, "rna_Mesh_texspace_loc_get", "rna_Mesh_texspace_loc_set", NULL);     
 -      RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
 -      
 -      prop= RNA_def_property(srna, "texspace_size", PROP_FLOAT, PROP_XYZ);
 -      RNA_def_property_array(prop, 3);
 -      RNA_def_property_ui_text(prop, "Texture Space Size", "Texture space size");
 -      RNA_def_property_editable_func(prop, "rna_Mesh_texspace_editable");
 -      RNA_def_property_float_funcs(prop, "rna_Mesh_texspace_size_get", "rna_Mesh_texspace_size_set", NULL);
 +      RNA_def_property_float_funcs(prop, "rna_Mesh_texspace_loc_get", "rna_Mesh_texspace_loc_set", NULL);
        RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
 -      
 +      */
 +
        /* not supported yet
        prop= RNA_def_property(srna, "texspace_rot", PROP_FLOAT, PROP_EULER);
        RNA_def_property_float(prop, NULL, "rot");
        RNA_def_property_editable_func(prop, texspace_editable);
        RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
        */
 -      
 -      /* materials */
 -      prop= RNA_def_property(srna, "materials", PROP_COLLECTION, PROP_NONE);
 -      RNA_def_property_collection_sdna(prop, NULL, "mat", "totcol");
 -      RNA_def_property_struct_type(prop, "Material");
 -      RNA_def_property_ui_text(prop, "Materials", "");
 -      RNA_def_property_srna(prop, "IDMaterials"); /* see rna_ID.c */
 -      RNA_def_property_collection_funcs(prop, 0, NULL, NULL, NULL, NULL, NULL, NULL, "rna_IDMaterials_assign_int");
  
        /* Mesh Draw Options for Edit Mode*/
        
        prop= RNA_def_property(srna, "show_edges", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_DRAWEDGES);
 -      RNA_def_property_ui_text(prop, "Draw Edges", "Display selected edges using highlights in the 3D view and UV editor");
 +      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, "show_all_edges", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_ALLEDGES);
 -      RNA_def_property_ui_text(prop, "All Edges", "Display all edges for wireframe in all view modes in the 3D view");
 +      RNA_def_property_ui_text(prop, "All Edges", "Displays all edges for wireframe in all view modes in the 3D view");
        RNA_def_property_update(prop, NC_OBJECT|ND_DRAW, NULL);
  
        prop= RNA_def_property(srna, "show_faces", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_DRAWFACES);
 -      RNA_def_property_ui_text(prop, "Draw Faces", "Display all faces as shades in the 3D view and UV editor");
 +      RNA_def_property_ui_text(prop, "Draw Faces", "Displays 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_ui_text(prop, "Draw Normals", "Displays 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_ui_text(prop, "Draw Vertex Normals", "Displays vertex normals as lines");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
        
        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 subsurf weighting");
 +      RNA_def_property_ui_text(prop, "Draw Creases", "Displays creases created for subsurf weighting");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
        
        prop= RNA_def_property(srna, "show_edge_bevel_weight", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_DRAWBWEIGHTS);
 -      RNA_def_property_ui_text(prop, "Draw Bevel Weights", "Display weights created for the Bevel modifier");
 +      RNA_def_property_ui_text(prop, "Draw Bevel Weights", "Displays weights created for the Bevel modifier");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
        
        prop= RNA_def_property(srna, "show_edge_seams", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_DRAWSEAMS);
 -      RNA_def_property_ui_text(prop, "Draw Seams", "Display UV unwrapping seams");
 +      RNA_def_property_ui_text(prop, "Draw Seams", "Displays UV unwrapping seams");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
        
        prop= RNA_def_property(srna, "show_edge_sharp", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_DRAWSHARP);
 -      RNA_def_property_ui_text(prop, "Draw Sharp", "Display sharp edges, used with the EdgeSplit modifier");
 +      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, "show_extra_edge_length", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_DRAWEXTRA_EDGELEN);
 -      RNA_def_property_ui_text(prop, "Edge Length",
 -                               "Display selected edge lengths, using global values when set in the transform panel");
 +      RNA_def_property_ui_text(prop, "Edge Length", "Displays selected edge lengths, Using global values when set in the transform panel");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
        
        prop= RNA_def_property(srna, "show_extra_face_angle", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_DRAWEXTRA_FACEANG);
 -      RNA_def_property_ui_text(prop, "Faces Angles",
 -                               "Display the angles between the selected edges in degrees, using "
 -                               "global values when set in the transform panel");
 +      RNA_def_property_ui_text(prop, "Face Angles", "Displays the angles in the selected edges in degrees, Using global values when set in the transform panel");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
        
        prop= RNA_def_property(srna, "show_extra_face_area", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "drawflag", ME_DRAWEXTRA_FACEAREA);
 -      RNA_def_property_ui_text(prop, "Face Area",
 -                               "Display the area of selected faces, using global values when set in the transform panel");
 +      RNA_def_property_ui_text(prop, "Face Area", "Displays the area of selected faces, Using global values when set in the transform panel");
        RNA_def_property_update(prop, 0, "rna_Mesh_update_draw");
  
        prop= RNA_def_property(srna, "show_extra_indices", PROP_BOOLEAN, PROP_NONE);
  
        prop= RNA_def_property(srna, "use_mirror_topology", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "editflag", ME_EDIT_MIRROR_TOPO);
 -      RNA_def_property_ui_text(prop, "Topology Mirror",
 -                               "Use topology based mirroring (for when both sides of mesh have matching, unique topology)");
 +      RNA_def_property_ui_text(prop, "Topology Mirror", "Use topology based mirroring. For when both sides of mesh have matching, unique topology");
  
        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_facemask");
+       RNA_def_property_update(prop, NC_SPACE|ND_SPACE_VIEW3D, "rna_Mesh_update_facemask");
        
        prop= RNA_def_property(srna, "use_paint_mask_vertex", PROP_BOOLEAN, PROP_NONE);
        RNA_def_property_boolean_sdna(prop, NULL, "editflag", ME_EDIT_VERT_SEL);
        RNA_def_property_ui_text(prop, "Vertex Selection", "Vertex selection masking for painting (weight paint only)");
        RNA_def_property_ui_icon(prop, ICON_VERTEXSEL, 0);
-       RNA_def_property_update(prop, 0, "rna_Mesh_update_vertmask");
+       RNA_def_property_update(prop, NC_SPACE|ND_SPACE_VIEW3D, "rna_Mesh_update_vertmask");
  
        /* readonly editmesh info - use for extrude menu */
        prop= RNA_def_property(srna, "total_vert_sel", PROP_INT, PROP_UNSIGNED);
  
        /* pointers */
        rna_def_animdata_common(srna);
 +      rna_def_texmat_common(srna, "rna_Mesh_texspace_editable");
  
        RNA_api_mesh(srna);
  }
@@@ -2659,14 -2229,9 +2658,14 @@@ void RNA_def_mesh(BlenderRNA *brna
        rna_def_mvert_group(brna);
        rna_def_medge(brna);
        rna_def_mface(brna);
 +      rna_def_mloop(brna);
 +      rna_def_mpolygon(brna);
 +      rna_def_mloopuv(brna);
        rna_def_mtface(brna);
 +      rna_def_mtexpoly(brna);
        rna_def_msticky(brna);
        rna_def_mcol(brna);
 +      rna_def_mloopcol(brna);
        rna_def_mproperties(brna);
  }
  
index d1e80226cd4da1c361feaa2273d23573be620874,4b3e2ea33a35d954e5aed5c5d2f805c756c0513e..a22122a245e5f430e192cac08c8e9a147e302d92
@@@ -231,6 -231,8 +231,8 @@@ bool CcdPhysicsController::CreateSoftbo
                        if (trimeshshape->getMeshInterface()->getNumSubParts()==1)
                        {
                                unsigned char* vertexBase;
+                               btScalar* scaledVertexBase;
+                               btVector3 localScaling;
                                PHY_ScalarType vertexType;
                                int numverts;
                                int vertexstride;
                                int indexstride;
                                PHY_ScalarType indexType;
                                trimeshshape->getMeshInterface()->getLockedVertexIndexBase(&vertexBase,numverts,vertexType,vertexstride,&indexbase,indexstride,numtris,indexType);
-                               
-                               psb = btSoftBodyHelpers::CreateFromTriMesh(worldInfo,(const btScalar*)vertexBase,(const int*)indexbase,numtris,false);
+                               localScaling = scaledtrimeshshape->getLocalScaling();
+                               scaledVertexBase = new btScalar[numverts*3];
+                               for (int i=0; i<numverts*3; i+=3)
+                               {
+                                       scaledVertexBase[i] = ((const btScalar*)vertexBase)[i] * localScaling.getX();
+                                       scaledVertexBase[i+1] = ((const btScalar*)vertexBase)[i+1] * localScaling.getY();
+                                       scaledVertexBase[i+2] = ((const btScalar*)vertexBase)[i+2] * localScaling.getZ();
+                               }
+                               psb = btSoftBodyHelpers::CreateFromTriMesh(worldInfo,scaledVertexBase,(const int*)indexbase,numtris,false);
+                               delete [] scaledVertexBase;
                        }
                } else
                {
@@@ -1424,11 -1434,11 +1434,11 @@@ bool CcdShapeConstructionInfo::SetMesh(
        }
  
        MVert *mvert = dm->getVertArray(dm);
 -      MFace *mface = dm->getFaceArray(dm);
 -      numpolys = dm->getNumFaces(dm);
 +      MFace *mface = dm->getTessFaceArray(dm);
 +      numpolys = dm->getNumTessFaces(dm);
        numverts = dm->getNumVerts(dm);
 -      int* index = (int*)dm->getFaceDataArray(dm, CD_ORIGINDEX);
 -      MTFace *tface = (MTFace *)dm->getFaceDataArray(dm, CD_MTFACE);
 +      int* index = (int*)dm->getTessFaceDataArray(dm, CD_ORIGINDEX);
 +      MTFace *tface = (MTFace *)dm->getTessFaceDataArray(dm, CD_MTFACE);
  
        m_shapeType = (polytope) ? PHY_SHAPE_POLYTOPE : PHY_SHAPE_MESH;
  
@@@ -1724,10 -1734,10 +1734,10 @@@ bool CcdShapeConstructionInfo::UpdateMe
                 * */
  
                MVert *mvert = dm->getVertArray(dm);
 -              MFace *mface = dm->getFaceArray(dm);
 -              numpolys = dm->getNumFaces(dm);
 +              MFace *mface = dm->getTessFaceArray(dm);
 +              numpolys = dm->getNumTessFaces(dm);
                numverts = dm->getNumVerts(dm);
 -              int* index = (int*)dm->getFaceDataArray(dm, CD_ORIGINDEX);
 +              int* index = (int*)dm->getTessFaceDataArray(dm, CD_ORIGINDEX);
  
                MFace *mf;
                MVert *mv;
  
                if(CustomData_has_layer(&dm->faceData, CD_MTFACE))
                {
 -                      MTFace *tface = (MTFace *)dm->getFaceDataArray(dm, CD_MTFACE);
 +                      MTFace *tface = (MTFace *)dm->getTessFaceDataArray(dm, CD_MTFACE);
                        MTFace *tf;
  
                        vector<bool> vert_tag_array(numverts, false);