New files from new booleans
[blender.git] / intern / boolop / intern / BOP_Vertex.cpp
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 #include "BOP_Vertex.h"
32
33 /**
34  * Constructs a new vertex with the specified coordinates.
35  * @param x X-axis coordinate
36  * @param y Y-axis coordinate
37  * @param z Z-axis coordinate
38  */
39 BOP_Vertex::BOP_Vertex(double x, double y, double z) 
40 {
41         m_point.setValue(x,y,z);
42         m_tag = UNCLASSIFIED;   
43 }
44
45 /**
46  * Constructs a new vertex with the specified point.
47  * @param p point XYZ
48  */
49 BOP_Vertex::BOP_Vertex(MT_Point3 p) 
50 {
51         m_point = p;
52         m_tag = UNCLASSIFIED;   
53 }
54
55 /**
56  * Adds a new edge index to this vertex.
57  * @param i edge index
58  */
59 void BOP_Vertex::addEdge(BOP_Index i) 
60 {
61   if (!containsEdge(i))
62     m_edges.push_back(i);
63 }
64
65 /**
66  * Removes an edge index from this vertex.
67  * @param i edge index
68  */
69 void BOP_Vertex::removeEdge(BOP_Index i) 
70 {
71         for(BOP_IT_Indexs it = m_edges.begin();it!=m_edges.end();it++) {
72                 if ((*it)==i) {
73                         m_edges.erase(it);
74                         return;
75                 }
76         }
77 }
78
79 /**
80  * Returns if this vertex contains the specified edge index.
81  * @param i edge index
82  * @return true if this vertex contains the specified edge index, false otherwise
83  */
84 bool BOP_Vertex::containsEdge(BOP_Index i)
85 {
86         int pos=0;
87         for(BOP_IT_Indexs it = m_edges.begin();it!=m_edges.end();pos++,it++) {
88           if ((*it)==i){
89             return true;
90           }
91         }
92         
93         return false;
94 }