-> New memory allocator for Bmesh
[blender-staging.git] / source / blender / blenkernel / intern / bmesh_private.h
1 /**
2  * BME_private.h    jan 2007
3  *
4  *      low level, 'private' function prototypes for bmesh kernel.
5  *
6  * $Id: BKE_bmesh.h,v 1.00 2007/01/17 17:42:01 Briggs Exp $
7  *
8  * ***** BEGIN GPL LICENSE BLOCK *****
9  *
10  * This program is free software; you can redistribute it and/or
11  * modify it under the terms of the GNU General Public License
12  * as published by the Free Software Foundation; either version 2
13  * of the License, or (at your option) any later version. The Blender
14  * Foundation also sells licenses for use in proprietary software under
15  * the Blender License.  See http://www.blender.org/BL/ for information
16  * about this.  
17  *
18  * This program is distributed in the hope that it will be useful,
19  * but WITHOUT ANY WARRANTY; without even the implied warranty of
20  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
21  * GNU General Public License for more details.
22  *
23  * You should have received a copy of the GNU General Public License
24  * along with this program; if not, write to the Free Software Foundation,
25  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
26  *
27  * The Original Code is Copyright (C) 2004 Blender Foundation.
28  * All rights reserved.
29  *
30  * The Original Code is: all of this file.
31  *
32  * Contributor(s): Geoffrey Bantle.
33  *
34  * ***** END GPL LICENSE BLOCK *****
35  */
36
37 #ifndef BMESH_PRIVATE
38 #define BMESH_PRIVATE
39
40 #include "BKE_bmesh.h"
41
42 /*MEMORY MANAGMENT*/
43 struct BME_mempool;
44 typedef struct BME_mempool BME_mempool;
45
46 struct BME_mempool *BME_mempool_create(int esize, int tote, int pchunk);
47 void BME_mempool_destroy(struct BME_mempool *pool);
48 void *BME_mempool_alloc(struct BME_mempool *pool);
49 void BME_mempool_free(struct BME_mempool *pool, void *address);
50
51 /*ALLOCATION/DEALLOCATION*/
52 struct BME_Vert *BME_addvertlist(struct BME_Mesh *bm, struct BME_Vert *example);
53 struct BME_Edge *BME_addedgelist(struct BME_Mesh *bm, struct BME_Vert *v1, struct BME_Vert *v2, struct BME_Edge *example);
54 struct BME_Poly *BME_addpolylist(struct BME_Mesh *bm, struct BME_Poly *example); 
55 struct BME_Loop *BME_create_loop(struct BME_Mesh *bm, struct BME_Vert *v, struct BME_Edge *e, struct BME_Poly *f, struct BME_Loop *example);
56
57 void BME_free_vert(struct BME_Mesh *bm, struct BME_Vert *v);
58 void BME_free_edge(struct BME_Mesh *bm, struct BME_Edge *e);
59 void BME_free_poly(struct BME_Mesh *bm, struct BME_Poly *f);
60 void BME_free_loop(struct BME_Mesh *bm, struct BME_Loop *l);
61 //void BME_delete_loop(struct BME_Mesh *bm, struct BME_Loop *l);
62
63 /*DOUBLE CIRCULAR LINKED LIST FUNCTIONS*/
64 void BME_cycle_append(void *h, void *nt);
65 int BME_cycle_remove(void *h, void *remn);
66 int BME_cycle_validate(int len, void *h);
67 /*DISK CYCLE MANAGMENT*/
68 int BME_disk_append_edge(struct BME_Edge *e, struct BME_Vert *v);
69 void BME_disk_remove_edge(struct BME_Edge *e, struct BME_Vert *v);
70 /*RADIAL CYCLE MANAGMENT*/
71 void BME_radial_append(struct BME_Edge *e, struct BME_Loop *l);
72 void BME_radial_remove_loop(struct BME_Loop *l, struct BME_Edge *e);
73
74 /*MISC FUNCTIONS*/
75 int BME_edge_swapverts(struct BME_Edge *e, struct BME_Vert *orig, struct BME_Vert *new); /*relink edge*/
76 int BME_disk_hasedge(struct BME_Vert *v, struct BME_Edge *e);
77
78 /*Error reporting. Shouldnt be called by tools ever.*/
79 void BME_error(void);
80 #endif