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