0021762: Integration of new Boolean Operation algorithm to OCCT.
[occt.git] / src / BOP / BOP_ConnexityBlock.cxx
1 // Created on: 2001-04-13
2 // Created by: Peter KURNEV
3 // Copyright (c) 2001-2012 OPEN CASCADE SAS
4 //
5 // The content of this file is subject to the Open CASCADE Technology Public
6 // License Version 6.5 (the "License"). You may not use the content of this file
7 // except in compliance with the License. Please obtain a copy of the License
8 // at http://www.opencascade.org and read it completely before using this file.
9 //
10 // The Initial Developer of the Original Code is Open CASCADE S.A.S., having its
11 // main offices at: 1, place des Freres Montgolfier, 78280 Guyancourt, France.
12 //
13 // The Original Code and all software distributed under the License is
14 // distributed on an "AS IS" basis, without warranty of any kind, and the
15 // Initial Developer hereby disclaims all such warranties, including without
16 // limitation, any warranties of merchantability, fitness for a particular
17 // purpose or non-infringement. Please see the License for the specific terms
18 // and conditions governing the rights and limitations under the License.
19
20
21
22 #include <BOP_ConnexityBlock.ixx>
23
24 #include <TopTools_ListIteratorOfListOfShape.hxx>
25
26 #include <TopoDS_Shape.hxx>
27
28 //=======================================================================
29 // function: BOP_ConnexityBlock::BOP_ConnexityBlock
30 // purpose: 
31 //=======================================================================
32 BOP_ConnexityBlock::BOP_ConnexityBlock()
33 :
34   myRegularity(Standard_False)
35 {}
36 //=======================================================================
37 // function: SetRegularity
38 // purpose: 
39 //=======================================================================
40   void BOP_ConnexityBlock::SetRegularity (const Standard_Boolean aFlag)
41 {
42   myRegularity=aFlag;
43 }
44 //=======================================================================
45 // function: IsRegular
46 // purpose: 
47 //=======================================================================
48   Standard_Boolean BOP_ConnexityBlock::IsRegular ()const
49 {
50   return myRegularity;
51 }
52 //=======================================================================
53 // function: SetShapes
54 // purpose: 
55 //=======================================================================
56   void BOP_ConnexityBlock::SetShapes(const TopTools_ListOfShape& anEdges)
57 {
58   myShapes.Clear();
59   TopTools_ListIteratorOfListOfShape anIt(anEdges);
60   for (; anIt.More(); anIt.Next()) {
61     const TopoDS_Shape& anE=anIt.Value();
62     myShapes.Append(anE);
63   }
64 }
65
66 //=======================================================================
67 // function: SetShapes
68 // purpose: 
69 //=======================================================================
70   void BOP_ConnexityBlock::SetShapes(const TopTools_IndexedMapOfOrientedShape& anEdges)
71 {
72   myShapes.Clear();
73   Standard_Integer i, aNb;
74
75   aNb=anEdges.Extent();
76   for (i=1; i<=aNb; i++) {
77     const TopoDS_Shape& anE=anEdges(i);
78     myShapes.Append(anE);
79   }
80 }
81
82 //=======================================================================
83 // function: Shapes
84 // purpose: 
85 //=======================================================================
86   const TopTools_ListOfShape& BOP_ConnexityBlock::Shapes()const
87 {
88   return myShapes;
89 }