| 1 | // Created on: 2003-12-11 |
| 2 | // Created by: Peter KURNEV |
| 3 | // Copyright (c) 2003-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 <BOPTools_PaveBlockMapHasher.ixx> |
| 23 | |
| 24 | #include <BOPTools_Pave.hxx> |
| 25 | #include <BOPTools_PaveBlock.hxx> |
| 26 | |
| 27 | //======================================================================= |
| 28 | //function : HashCode |
| 29 | //purpose : |
| 30 | //======================================================================= |
| 31 | Standard_Integer BOPTools_PaveBlockMapHasher::HashCode(const BOPTools_PaveBlock& aPB, |
| 32 | const Standard_Integer aUpper) |
| 33 | { |
| 34 | Standard_Integer aS, nV1, nV2, nE; |
| 35 | // |
| 36 | nV1=aPB.Pave1().Index(); |
| 37 | nV2=aPB.Pave2().Index(); |
| 38 | nE=aPB.OriginalEdge(); |
| 39 | aS=nV1+nV2+nE; |
| 40 | return aS%aUpper; |
| 41 | } |
| 42 | |
| 43 | //======================================================================= |
| 44 | //function :IsEqual |
| 45 | //purpose : |
| 46 | //======================================================================= |
| 47 | Standard_Boolean BOPTools_PaveBlockMapHasher::IsEqual(const BOPTools_PaveBlock& aPB1, |
| 48 | const BOPTools_PaveBlock& aPB2) |
| 49 | { |
| 50 | return aPB1.IsEqual(aPB2); |
| 51 | } |