New files from new booleans
[blender.git] / intern / boolop / intern / BOP_Edge.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_Edge.h"
32
33 /**
34  * Constructs a new edge.
35  * @param v1 vertex index
36  * @param v2 vertex index
37  */
38 BOP_Edge::BOP_Edge(BOP_Index v1, BOP_Index v2) 
39 {
40         m_vertexs[0] = v1;
41         m_vertexs[1] = v2;
42 }
43
44 /**
45  * Adds a new face index to this edge.
46  * @param i face index
47  */
48 void BOP_Edge::addFace(BOP_Index i) 
49 {
50         if (!containsFace(i))
51                 m_faces.push_back(i);
52 }
53
54 /**
55  * Returns if this edge contains the specified face index.
56  * @param i face index
57  * @return true if this edge contains the specified face index, false otherwise
58  */
59 bool BOP_Edge::containsFace(BOP_Index i)
60 {
61         int pos=0;
62         for(BOP_IT_Indexs it = m_faces.begin();it!=m_faces.end();pos++,it++) {
63                 if ((*it) == i)
64                 return true;
65         }
66         
67         return false;
68 }
69
70 /**
71  * Replaces an edge vertex index.
72  * @param oldIndex old vertex index
73  * @param newIndex new vertex index
74  */
75 void BOP_Edge::replaceVertexIndex(BOP_Index oldIndex, BOP_Index newIndex) 
76 {
77         if (m_vertexs[0] == oldIndex) m_vertexs[0] = newIndex;
78         else if (m_vertexs[1] == oldIndex) m_vertexs[1] = newIndex;
79 }
80
81