New files from new booleans
[blender.git] / intern / boolop / intern / BOP_Segment.h
1 /**
2  * ***** BEGIN GPL/BL DUAL 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. The Blender
8  * Foundation also sells licenses for use in proprietary software under
9  * the Blender License.  See http://www.blender.org/BL/ for information
10  * about this.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License
18  * along with this program; if not, write to the Free Software Foundation,
19  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA.
20  *
21  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV.
22  * All rights reserved.
23  *
24  * The Original Code is: all of this file.
25  *
26  * Contributor(s): none yet.
27  *
28  * ***** END GPL/BL DUAL LICENSE BLOCK *****
29  */
30  
31 #ifndef BOP_SEGMENT_H
32 #define BOP_SEGMENT_H
33
34 #include "BOP_Indexs.h"
35 #include <iostream>
36 using namespace std;
37
38 class BOP_Segment
39 {
40 private:
41         int getEdgeBetween(unsigned int v1, unsigned int v2);
42         bool isOnEdge(unsigned int v, unsigned int e);
43
44 public:
45         // Cfg : Configuration of the vertices
46         // Values:
47         //         20 IN,
48         //         1X Intersected edge X{1,2,3} of the face,
49         //         0X Coincident vertice X{1,2,3} of the face,
50         //         0 otherwise
51         unsigned int m_cfg1, m_cfg2; 
52         BOP_Index m_v1, m_v2;     // if cfgX >0, vX is the vertice index of the face
53         BOP_Segment();
54
55         static bool isIn(unsigned int cfg);
56         static bool isEdge(unsigned int cfg);
57         static bool isVertex(unsigned int cfg);
58         static bool isDefined(unsigned int cfg);
59         static bool isUndefined(unsigned int cfg);
60         static unsigned int getEdge(unsigned int cfg);
61         static BOP_Index getVertex(unsigned int cfg);
62         static unsigned int createEdgeCfg(unsigned int edge);
63         static unsigned int createVertexCfg(BOP_Index vertex);
64         static unsigned int createInCfg();
65         static unsigned int createUndefinedCfg();
66         void invert();  
67         void sort();
68         unsigned int getConfig();
69
70         friend   ostream &operator<<(ostream &stream, const BOP_Segment &c);
71 };
72
73 #endif