1 // Copyright (C) 2007-2024 CEA, EDF, OPEN CASCADE
3 // Copyright (C) 2003-2007 OPEN CASCADE, EADS/CCR, LIP6, CEA/DEN,
4 // CEDRAT, EDF R&D, LEG, PRINCIPIA R&D, BUREAU VERITAS
6 // This library is free software; you can redistribute it and/or
7 // modify it under the terms of the GNU Lesser General Public
8 // License as published by the Free Software Foundation; either
9 // version 2.1 of the License, or (at your option) any later version.
11 // This library is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 // Lesser General Public License for more details.
16 // You should have received a copy of the GNU Lesser General Public
17 // License along with this library; if not, write to the Free Software
18 // Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20 // See http://www.salome-platform.org/ or email : webmaster.salome@opencascade.com
23 // File: GEOMAlgo_PassKey.hxx
25 // Author: Peter KURNEV
28 #ifndef _GEOMAlgo_PassKey_HeaderFile
29 #define _GEOMAlgo_PassKey_HeaderFile
31 #include <Basics_OCCTVersion.hxx>
33 #include <Standard.hxx>
34 #include <Standard_Macro.hxx>
35 #include <Standard_Integer.hxx>
36 #include <Standard_Boolean.hxx>
38 #include <TColStd_ListOfInteger.hxx>
39 #include <TColStd_IndexedMapOfInteger.hxx>
41 //=======================================================================
42 //class : GEOMAlgo_PassKey
44 //=======================================================================
45 class GEOMAlgo_PassKey {
51 virtual ~GEOMAlgo_PassKey();
54 GEOMAlgo_PassKey(const GEOMAlgo_PassKey& Other);
57 GEOMAlgo_PassKey& Assign(const GEOMAlgo_PassKey& Other) ;
59 GEOMAlgo_PassKey& operator =(const GEOMAlgo_PassKey& Other) {
67 void SetIds(const Standard_Integer aI1) ;
70 void SetIds(const Standard_Integer aI1,
71 const Standard_Integer aI2) ;
74 void SetIds(const Standard_Integer aI1,
75 const Standard_Integer aI2,
76 const Standard_Integer aI3) ;
79 void SetIds(const Standard_Integer aI1,
80 const Standard_Integer aI2,
81 const Standard_Integer aI3,
82 const Standard_Integer aI4) ;
85 void SetIds(const TColStd_ListOfInteger& aLS) ;
88 Standard_Integer NbIds() const;
91 Standard_Boolean IsEqual(const GEOMAlgo_PassKey& aOther) const;
93 #if OCC_VERSION_LARGE < 0x07080000
95 Standard_Integer HashCode(const Standard_Integer Upper) const;
99 bool operator==(const GEOMAlgo_PassKey& theOther) const
101 return IsEqual(theOther);
105 size_t GetSum() const { return (size_t)mySum; }
108 Standard_Integer Id(const Standard_Integer aIndex) const;
111 void Dump(const Standard_Integer aHex = 0) const;
114 Standard_Integer myNbIds;
115 Standard_Integer mySum;
116 TColStd_IndexedMapOfInteger myMap;
122 struct hash<GEOMAlgo_PassKey>
124 size_t operator()(const GEOMAlgo_PassKey& thePK) const noexcept
126 return thePK.GetSum();