0022922: Clean up warnings on uninitialized / unused variables
[occt.git] / src / ShapeBuild / ShapeBuild_ReShape.cxx
1 //    abv 28.04.99 S4137: ading method Apply for work on all types of shapes
2
3 #include <ShapeBuild_ReShape.ixx>
4
5 #include <TopoDS_Shell.hxx>
6 #include <TopoDS_Solid.hxx>
7 #include <TopoDS_Compound.hxx>
8 #include <TopoDS_Iterator.hxx>
9 #include <TopExp_Explorer.hxx>
10 #include <BRep_Builder.hxx>
11 #include <ShapeExtend.hxx>
12 #include <ShapeBuild_Edge.hxx>
13 #include <TopoDS.hxx>
14
15 //=======================================================================
16 //function : ShapeBuild_ReShape
17 //purpose  : 
18 //=======================================================================
19
20 ShapeBuild_ReShape::ShapeBuild_ReShape()
21 {
22 }
23
24 //=======================================================================
25 //function : Apply
26 //purpose  : 
27 //=======================================================================
28
29 TopoDS_Shape ShapeBuild_ReShape::Apply (const TopoDS_Shape& shape,
30                                         const TopAbs_ShapeEnum until,
31                                         const Standard_Integer buildmode) 
32 {
33   return BRepTools_ReShape::Apply (shape,until,buildmode);
34 }
35
36 //=======================================================================
37 //function : Apply
38 //purpose  : 
39 //=======================================================================
40
41 TopoDS_Shape ShapeBuild_ReShape::Apply (const TopoDS_Shape& shape,
42                                         const TopAbs_ShapeEnum until) 
43 {
44   myStatus = ShapeExtend::EncodeStatus ( ShapeExtend_OK );
45   if ( shape.IsNull() ) return shape;
46
47   // apply direct replacement
48   TopoDS_Shape newsh = Value ( shape );
49   
50   // if shape removed, return NULL
51   if ( newsh.IsNull() ) {
52     myStatus = ShapeExtend::EncodeStatus ( ShapeExtend_DONE2 );
53     return newsh;
54   }
55   
56   // if shape replaced, apply modifications to the result recursively 
57   Standard_Boolean aConsLoc = ModeConsiderLocation();
58   if ( (aConsLoc && ! newsh.IsPartner (shape)) || 
59       (!aConsLoc &&! newsh.IsSame ( shape )) ) {
60   
61     TopoDS_Shape res = Apply ( newsh, until );
62     myStatus |= ShapeExtend::EncodeStatus ( ShapeExtend_DONE1 );
63     return res;
64   }
65
66   TopAbs_ShapeEnum st = shape.ShapeType();
67   if ( st >= until ) return newsh;    // critere d arret
68   if(st == TopAbs_VERTEX || st == TopAbs_SHAPE)
69     return shape;
70   // define allowed types of components
71
72   BRep_Builder B;
73   
74   TopoDS_Shape result = shape.EmptyCopied();
75   TopAbs_Orientation orient = shape.Orientation(); //JR/Hp: or -> orient
76   result.Orientation(TopAbs_FORWARD); // protect against INTERNAL or EXTERNAL shapes
77   Standard_Boolean modif = Standard_False;
78   Standard_Integer locStatus = myStatus;
79   
80   // apply recorded modifications to subshapes
81   for ( TopoDS_Iterator it(shape,Standard_False); it.More(); it.Next() ) {
82     TopoDS_Shape sh = it.Value();
83     newsh = Apply ( sh, until );
84     if ( newsh != sh ) {
85       if ( ShapeExtend::DecodeStatus ( myStatus, ShapeExtend_DONE4 ) )
86         locStatus |= ShapeExtend::EncodeStatus ( ShapeExtend_DONE4 );
87       modif = 1;
88     }
89     if ( newsh.IsNull() ) {
90       locStatus |= ShapeExtend::EncodeStatus ( ShapeExtend_DONE4 );
91       continue;
92     }
93     locStatus |= ShapeExtend::EncodeStatus ( ShapeExtend_DONE3 );
94     if ( st == TopAbs_COMPOUND || newsh.ShapeType() == sh.ShapeType()) { //fix for SAMTECH bug OCC322 about abcense internal vertices after sewing.
95       B.Add ( result, newsh );
96       continue;
97     }
98     Standard_Integer nitems = 0;
99     for ( TopoDS_Iterator subit(newsh); subit.More(); subit.Next(), nitems++ ) {
100       TopoDS_Shape subsh = subit.Value();
101       if ( subsh.ShapeType() == sh.ShapeType() ) B.Add ( result, subsh );
102       else locStatus |= ShapeExtend::EncodeStatus ( ShapeExtend_FAIL1 );
103     }
104     if ( ! nitems ) locStatus |= ShapeExtend::EncodeStatus ( ShapeExtend_FAIL1 );
105   }
106   if ( ! modif ) return shape;
107
108   // restore Range on edge broken by EmptyCopied()
109   if ( st == TopAbs_EDGE ) {
110     ShapeBuild_Edge sbe;
111     sbe.CopyRanges ( TopoDS::Edge ( result ), TopoDS::Edge ( shape ));
112   }
113   result.Orientation(orient);
114   myStatus = locStatus;
115   Replace ( shape, result );
116   return result;
117 }
118
119 //=======================================================================
120 //function : Status
121 //purpose  : 
122 //=======================================================================
123
124 Standard_Integer ShapeBuild_ReShape::Status(const TopoDS_Shape& ashape,
125                                             TopoDS_Shape& newsh,
126                                             const Standard_Boolean last) 
127 {
128   return BRepTools_ReShape::Status(ashape,newsh,last);
129 }
130
131 //=======================================================================
132 //function : Status
133 //purpose  : 
134 //=======================================================================
135
136 Standard_Boolean ShapeBuild_ReShape::Status (const ShapeExtend_Status status) const
137 {
138   return ShapeExtend::DecodeStatus ( myStatus, status );
139 }