svn merge ^/trunk/blender -r43436:43443
[blender.git] / source / blender / blenkernel / BKE_tessmesh.h
1 #ifndef _BKE_TESSMESH_H
2 #define _BKE_TESSMESH_H
3
4 #include "bmesh.h"
5
6 struct BMesh;
7 struct BMLoop;
8 struct BMFace;
9 struct Mesh;
10 struct DerivedMesh;
11
12 /*
13 ok: the EDBM module is for editmode bmesh stuff.  in contrast, the 
14     BMEdit module is for code shared with blenkernel that concerns
15     the BMEditMesh structure.
16 */
17
18 /*this structure replaces EditMesh.
19  
20   through this, you get access to both the edit bmesh,
21   it's tesselation, and various stuff that doesn't belong in the BMesh
22   struct itself.
23   
24   the entire derivedmesh and modifier system works with this structure,
25   and not BMesh.  Mesh->edit_bmesh stores a pointer to this structure.*/
26 typedef struct BMEditMesh {
27         struct BMesh *bm;
28
29         /*this is for undoing failed operations*/
30         struct BMEditMesh *emcopy;
31         int emcopyusers;
32         
33         /*we store tesselations as triplets of three loops,
34           which each define a triangle.*/
35         struct BMLoop *(*looptris)[3];
36         int tottri;
37
38         /*derivedmesh stuff*/
39         struct DerivedMesh *derivedFinal, *derivedCage;
40         int lastDataMask;
41         
42         /*retopo data pointer*/
43         struct RetopoPaintData *retopo_paint_data;
44
45         /*index tables, to map indices to elements via
46           EDBM_init_index_arrays and associated functions.  don't
47           touch this or read it directly.*/
48         struct BMVert **vert_index;
49         struct BMEdge **edge_index;
50         struct BMFace **face_index;
51
52         /*selection mode*/
53         short selectmode;
54         short mat_nr;
55
56         /*Mesh structure this editmesh came from, if it came from one*/
57         struct Mesh *me;
58         struct Object *ob;
59
60         /*temp variables for x-mirror editing*/
61         int mirror_cdlayer; /* -1 is invalid */
62         int mirr_free_arrays;
63 } BMEditMesh;
64
65 /* undo triggers editmesh tessface update, this is odd but works OK.
66  * BMESH_TODO, look into having the update elsewhere. */
67 #define BMESH_EM_UNDO_RECALC_TESSFACE_WORKAROUND
68
69 void BMEdit_RecalcTesselation(BMEditMesh *tm);
70 BMEditMesh *BMEdit_Create(BMesh *bm);
71 BMEditMesh *BMEdit_Copy(BMEditMesh *tm);
72 void BMEdit_Free(BMEditMesh *em);
73 void BMEdit_UpdateLinkedCustomData(BMEditMesh *em);
74
75 #endif /* _BKE_TESSMESH_H */