0024023: Revamp the OCCT Handle -- downcast (automatic)
[occt.git] / src / TopOpeBRepDS / TopOpeBRepDS_SurfaceIterator.cxx
1 // Created on: 1994-06-07
2 // Created by: Jean Yves LEBEY
3 // Copyright (c) 1994-1999 Matra Datavision
4 // Copyright (c) 1999-2014 OPEN CASCADE SAS
5 //
6 // This file is part of Open CASCADE Technology software library.
7 //
8 // This library is free software; you can redistribute it and/or modify it under
9 // the terms of the GNU Lesser General Public License version 2.1 as published
10 // by the Free Software Foundation, with special exception defined in the file
11 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
12 // distribution for complete text of the license and disclaimer of any warranty.
13 //
14 // Alternatively, this file may be used under the terms of Open CASCADE
15 // commercial license or contractual agreement.
16
17 #include <TopOpeBRepDS_Interference.hxx>
18
19 #include <TopOpeBRepDS_SurfaceIterator.ixx>
20
21 //=======================================================================
22 //function : TopOpeBRepDS_SurfaceIterator
23 //purpose  : 
24 //=======================================================================
25
26 TopOpeBRepDS_SurfaceIterator::TopOpeBRepDS_SurfaceIterator
27   (const TopOpeBRepDS_ListOfInterference& L) :
28   TopOpeBRepDS_InterferenceIterator(L)
29 {
30   TopOpeBRepDS_InterferenceIterator::GeometryKind(TopOpeBRepDS_SURFACE);
31 }
32
33 //=======================================================================
34 //function : Current
35 //purpose  : 
36 //=======================================================================
37
38 Standard_Integer  TopOpeBRepDS_SurfaceIterator::Current()const 
39 {
40   Handle(TopOpeBRepDS_Interference) i = Value();
41   Standard_Integer g = i->Geometry();
42   return g;
43 }
44
45
46 //=======================================================================
47 //function : Orientation
48 //purpose  : 
49 //=======================================================================
50
51 TopAbs_Orientation TopOpeBRepDS_SurfaceIterator::Orientation
52   (const TopAbs_State S) const 
53 {
54   Handle(TopOpeBRepDS_Interference) i = Value();
55   const TopOpeBRepDS_Transition& t = i->Transition();
56   TopAbs_Orientation o = t.Orientation(S);
57   return o;
58 }