Merge branch 'master' into blender2.8
[blender.git] / source / blender / bmesh / intern / bmesh_construct.h
1 /*
2  * ***** BEGIN GPL LICENSE BLOCK *****
3  *
4  * This program is free software; you can redistribute it and/or
5  * modify it under the terms of the GNU General Public License
6  * as published by the Free Software Foundation; either version 2
7  * of the License, or (at your option) any later version.
8  *
9  * This program is distributed in the hope that it will be useful,
10  * but WITHOUT ANY WARRANTY; without even the implied warranty of
11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12  * GNU General Public License for more details.
13  *
14  * You should have received a copy of the GNU General Public License
15  * along with this program; if not, write to the Free Software Foundation,
16  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17  *
18  * Contributor(s): Joseph Eagar.
19  *
20  * ***** END GPL LICENSE BLOCK *****
21  */
22
23 #ifndef __BMESH_CONSTRUCT_H__
24 #define __BMESH_CONSTRUCT_H__
25
26 /** \file blender/bmesh/intern/bmesh_construct.h
27  *  \ingroup bmesh
28  */
29
30 struct BMAllocTemplate;
31
32 bool BM_verts_from_edges(BMVert **vert_arr, BMEdge **edge_arr, const int len);
33
34 bool BM_edges_from_verts(BMEdge **edge_arr, BMVert **vert_arr, const int len);
35 void BM_edges_from_verts_ensure(BMesh *bm, BMEdge **edge_arr, BMVert **vert_arr, const int len);
36
37 /* sort before creation */
38 void    BM_verts_sort_radial_plane(BMVert **vert_arr, int len);
39
40 BMFace *BM_face_create_quad_tri(
41         BMesh *bm, BMVert *v1, BMVert *v2, BMVert *v3, BMVert *v4,
42         const BMFace *f_example, const eBMCreateFlag create_flag);
43
44 void BM_face_copy_shared(
45         BMesh *bm, BMFace *f,
46         BMLoopFilterFunc filter_fn, void *user_data);
47
48 BMFace *BM_face_create_ngon(
49         BMesh *bm, BMVert *v1, BMVert *v2, BMEdge **edges, const int len,
50         const BMFace *f_example, const eBMCreateFlag create_flag);
51 BMFace *BM_face_create_ngon_verts(
52         BMesh *bm, BMVert **vert_arr, const int len,
53         const BMFace *f_example, const eBMCreateFlag create_flag,
54         const bool calc_winding, const bool create_edges);
55
56 void BM_elem_attrs_copy_ex(
57         BMesh *bm_src, BMesh *bm_dst, const void *ele_src_v, void *ele_dst_v,
58         const char hflag_mask, const uint64_t cd_mask);
59 void BM_elem_attrs_copy(BMesh *bm_src, BMesh *bm_dst, const void *ele_src_v, void *ele_dst_v);
60 void BM_elem_select_copy(BMesh *bm_dst, void *ele_dst_v, const void *ele_src_v);
61
62 void   BM_mesh_copy_init_customdata(BMesh *bm_dst, BMesh *bm_src, const struct BMAllocTemplate *allocsize);
63 BMesh *BM_mesh_copy(BMesh *bm_old);
64
65 char  BM_face_flag_from_mflag(const char  mflag);
66 char  BM_edge_flag_from_mflag(const short mflag);
67 char  BM_vert_flag_from_mflag(const char  mflag);
68 char  BM_face_flag_to_mflag(BMFace *f);
69 short BM_edge_flag_to_mflag(BMEdge *e);
70 char  BM_vert_flag_to_mflag(BMVert *v);
71
72 #endif /* __BMESH_CONSTRUCT_H__ */