1 // Created on: 1992-09-22
2 // Created by: Gilles DEBARBOUILLE
3 // Copyright (c) 1992-1999 Matra Datavision
4 // Copyright (c) 1999-2014 OPEN CASCADE SAS
6 // This file is part of Open CASCADE Technology software library.
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.
14 // Alternatively, this file may be used under the terms of Open CASCADE
15 // commercial license or contractual agreement.
17 #ifndef _MAT_ListOfBisector_HeaderFile
18 #define _MAT_ListOfBisector_HeaderFile
20 #include <Standard.hxx>
21 #include <Standard_Type.hxx>
23 #include <Standard_Integer.hxx>
24 #include <Standard_Transient.hxx>
25 #include <Standard_Boolean.hxx>
26 class MAT_TListNodeOfListOfBisector;
30 class MAT_ListOfBisector;
31 DEFINE_STANDARD_HANDLE(MAT_ListOfBisector, Standard_Transient)
34 class MAT_ListOfBisector : public Standard_Transient
40 Standard_EXPORT MAT_ListOfBisector();
42 Standard_EXPORT void First();
44 Standard_EXPORT void Last();
46 Standard_EXPORT void Init (const Handle(MAT_Bisector)& aniten);
48 Standard_EXPORT void Next();
50 Standard_EXPORT void Previous();
52 Standard_EXPORT Standard_Boolean More() const;
54 Standard_EXPORT Handle(MAT_Bisector) Current() const;
56 Standard_EXPORT void Current (const Handle(MAT_Bisector)& anitem) const;
58 Standard_EXPORT Handle(MAT_Bisector) FirstItem() const;
60 Standard_EXPORT Handle(MAT_Bisector) LastItem() const;
62 Standard_EXPORT Handle(MAT_Bisector) PreviousItem() const;
64 Standard_EXPORT Handle(MAT_Bisector) NextItem() const;
66 Standard_Integer Number() const;
68 Standard_Integer Index() const;
70 Standard_EXPORT Handle(MAT_Bisector) Brackets (const Standard_Integer anindex);
71 Handle(MAT_Bisector) operator() (const Standard_Integer anindex)
73 return Brackets(anindex);
76 Standard_EXPORT void Unlink();
78 Standard_EXPORT void LinkBefore (const Handle(MAT_Bisector)& anitem);
80 Standard_EXPORT void LinkAfter (const Handle(MAT_Bisector)& anitem);
82 Standard_EXPORT void FrontAdd (const Handle(MAT_Bisector)& anitem);
84 Standard_EXPORT void BackAdd (const Handle(MAT_Bisector)& anitem);
86 Standard_EXPORT void Permute();
88 Standard_EXPORT void Loop() const;
90 Standard_EXPORT Standard_Boolean IsEmpty() const;
92 Standard_EXPORT void Dump (const Standard_Integer ashift, const Standard_Integer alevel);
97 DEFINE_STANDARD_RTTI_INLINE(MAT_ListOfBisector,Standard_Transient)
107 Handle(MAT_TListNodeOfListOfBisector) thefirstnode;
108 Handle(MAT_TListNodeOfListOfBisector) thelastnode;
109 Handle(MAT_TListNodeOfListOfBisector) thecurrentnode;
110 Standard_Integer thecurrentindex;
111 Standard_Integer thenumberofitems;
116 #define Item Handle(MAT_Bisector)
117 #define Item_hxx <MAT_Bisector.hxx>
118 #define MAT_TListNode MAT_TListNodeOfListOfBisector
119 #define MAT_TListNode_hxx <MAT_TListNodeOfListOfBisector.hxx>
120 #define Handle_MAT_TListNode Handle(MAT_TListNodeOfListOfBisector)
121 #define MAT_TList MAT_ListOfBisector
122 #define MAT_TList_hxx <MAT_ListOfBisector.hxx>
123 #define Handle_MAT_TList Handle(MAT_ListOfBisector)
125 #include <MAT_TList.lxx>
130 #undef MAT_TListNode_hxx
131 #undef Handle_MAT_TListNode
134 #undef Handle_MAT_TList
139 #endif // _MAT_ListOfBisector_HeaderFile