diff --git a/samples/ios/UIKitSample/UIKitSample/CafShapePrs.h b/samples/ios/UIKitSample/UIKitSample/CafShapePrs.h index 3e83986ce3..1215533609 100644 --- a/samples/ios/UIKitSample/UIKitSample/CafShapePrs.h +++ b/samples/ios/UIKitSample/UIKitSample/CafShapePrs.h @@ -23,12 +23,11 @@ #define CafShapePrs_h #include -#include #include #include typedef NCollection_DataMap CafDataMapOfShapeColor; -typedef NCollection_DataMap MapOfPrsForShapes; +typedef NCollection_DataMap MapOfPrsForShapes; //! Interactive object for shape in DECAF document class CafShapePrs : public XCAFPrs_AISObject diff --git a/src/AIS/AIS_ColoredShape.hxx b/src/AIS/AIS_ColoredShape.hxx index 570b0c65e1..2eef2c6abe 100644 --- a/src/AIS/AIS_ColoredShape.hxx +++ b/src/AIS/AIS_ColoredShape.hxx @@ -21,7 +21,6 @@ #include #include #include -#include class StdSelect_BRepOwner; @@ -104,7 +103,7 @@ protected: //! @name override presentation computation protected: - typedef NCollection_IndexedDataMap DataMapOfDrawerCompd; + typedef NCollection_IndexedDataMap DataMapOfDrawerCompd; protected: diff --git a/src/AIS/AIS_ConnectedInteractive.cxx b/src/AIS/AIS_ConnectedInteractive.cxx index 64decc8336..b5ec89afcb 100644 --- a/src/AIS/AIS_ConnectedInteractive.cxx +++ b/src/AIS/AIS_ConnectedInteractive.cxx @@ -30,7 +30,6 @@ #include #include #include -#include IMPLEMENT_STANDARD_RTTIEXT(AIS_ConnectedInteractive,AIS_InteractiveObject) @@ -241,7 +240,7 @@ void AIS_ConnectedInteractive::computeSubShapeSelection (const Handle(SelectMgr_ const Standard_Integer theMode) { typedef NCollection_List SensitiveList; - typedef NCollection_DataMap + typedef NCollection_DataMap Shapes2EntitiesMap; if (!myReference->HasSelection (theMode)) diff --git a/src/AIS/AIS_DataMapOfIOStatus.hxx b/src/AIS/AIS_DataMapOfIOStatus.hxx index 6451e844c3..07f8b5c90f 100644 --- a/src/AIS/AIS_DataMapOfIOStatus.hxx +++ b/src/AIS/AIS_DataMapOfIOStatus.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap AIS_DataMapOfIOStatus; -typedef NCollection_DataMap::Iterator AIS_DataMapIteratorOfDataMapOfIOStatus; +typedef NCollection_DataMap AIS_DataMapOfIOStatus; +typedef NCollection_DataMap::Iterator AIS_DataMapIteratorOfDataMapOfIOStatus; #endif diff --git a/src/AIS/AIS_ViewCube.hxx b/src/AIS/AIS_ViewCube.hxx index 32428cf04f..4244db55ab 100644 --- a/src/AIS/AIS_ViewCube.hxx +++ b/src/AIS/AIS_ViewCube.hxx @@ -640,18 +640,9 @@ protected: protected: - //! Trivial hasher to avoid ambiguity with enumeration type. - struct IntegerHasher - { - static Standard_Integer HashCode (Standard_Integer theValue, Standard_Integer theUpper) { return ::HashCode (theValue, theUpper); } - static Standard_Boolean IsEqual (Standard_Integer theA, Standard_Integer theB) { return theA == theB; } - }; - -protected: - - NCollection_DataMap + NCollection_DataMap myBoxSideLabels; //!< map with box side labels - NCollection_DataMap + NCollection_DataMap myAxesLabels; //!< map with axes labels Handle(Prs3d_ShadingAspect) myBoxEdgeAspect; //!< style for box edges Handle(Prs3d_ShadingAspect) myBoxCornerAspect; //!< style for box corner diff --git a/src/AdvApprox/AdvApprox_ApproxAFunction.hxx b/src/AdvApprox/AdvApprox_ApproxAFunction.hxx index 74f58b76ca..245cc01b09 100644 --- a/src/AdvApprox/AdvApprox_ApproxAFunction.hxx +++ b/src/AdvApprox/AdvApprox_ApproxAFunction.hxx @@ -30,7 +30,6 @@ #include #include #include -#include #include #include #include diff --git a/src/AdvApprox/AdvApprox_SimpleApprox.hxx b/src/AdvApprox/AdvApprox_SimpleApprox.hxx index 757db18ef7..fc014b203b 100644 --- a/src/AdvApprox/AdvApprox_SimpleApprox.hxx +++ b/src/AdvApprox/AdvApprox_SimpleApprox.hxx @@ -24,7 +24,6 @@ #include #include #include -#include #include #include #include diff --git a/src/AppCont/AppCont_ContMatrices_4.cxx b/src/AppCont/AppCont_ContMatrices_4.cxx index 7cc15f2dbc..0c5c3dab67 100644 --- a/src/AppCont/AppCont_ContMatrices_4.cxx +++ b/src/AppCont/AppCont_ContMatrices_4.cxx @@ -1238,7 +1238,7 @@ void VBernstein(const Standard_Integer classe, if (nbpoints > 24) throw Standard_DimensionError("VBernstein: nbpoints > 24"); // math_Matrix VB(classe, nbpoints); - Standard_Integer i, j, k = 0, Som; + Standard_Integer i, j, Som; // 300 = 1+2+ ... +24 points. Som = (Standard_Integer )( 300*((classe-1)*classe/2.-1) + classe * (nbpoints-1)*nbpoints/2.); @@ -1248,7 +1248,6 @@ void VBernstein(const Standard_Integer classe, for (j = 1; j <= nbpoints; j++) { M(i, j) = *tmpVB; tmpVB++; - k++; } } } diff --git a/src/AppCont/AppCont_LeastSquare.hxx b/src/AppCont/AppCont_LeastSquare.hxx index 51300f2903..67bdfb4830 100644 --- a/src/AppCont/AppCont_LeastSquare.hxx +++ b/src/AppCont/AppCont_LeastSquare.hxx @@ -22,7 +22,7 @@ #include #include #include - +#include struct PeriodicityInfo { diff --git a/src/Approx/Approx_ComputeLine.gxx b/src/Approx/Approx_ComputeLine.gxx index 6a6175823c..9e63eb95a9 100644 --- a/src/Approx/Approx_ComputeLine.gxx +++ b/src/Approx/Approx_ComputeLine.gxx @@ -13,7 +13,6 @@ // commercial license or contractual agreement. #include -#include Approx_ParLeastSquareOfMyGradient_hxx #include #include #include @@ -1392,7 +1391,7 @@ Standard_Boolean Approx_ComputeLine::ComputeCurve(const MultiLine& Line, Standard_Boolean Parallel; #endif Standard_Integer myfirstpt = firstpt, mylastpt = lastpt; - Standard_Integer nbp = lastpt-firstpt+1, Kopt = 0; + Standard_Integer nbp = lastpt-firstpt+1; math_Vector Para(firstpt, lastpt); Parameters(Line, firstpt, lastpt, Para); @@ -1427,11 +1426,6 @@ Standard_Boolean Approx_ComputeLine::ComputeCurve(const MultiLine& Line, Tangent1 = LineTool::Tangency(Line, myfirstpt, tabV1); Tangent2 = LineTool::Tangency(Line, mylastpt, tabV2); } - - if (Tangent1) Kopt++; - if (Tangent2) Kopt++; - - if (nbp == 2) { // S il n y a que 2 points, on verifie quand meme que les tangentes sont // alignees. diff --git a/src/ApproxInt/ApproxInt_KnotTools.hxx b/src/ApproxInt/ApproxInt_KnotTools.hxx index b54e81e219..b2bfa6c6b5 100644 --- a/src/ApproxInt/ApproxInt_KnotTools.hxx +++ b/src/ApproxInt/ApproxInt_KnotTools.hxx @@ -14,34 +14,21 @@ #ifndef _ApproxInt_KnotTools_HeaderFile #define _ApproxInt_KnotTools_HeaderFile -#ifndef _Standard_DefineAlloc_HeaderFile #include -#endif -#ifndef _Standard_Macro_HeaderFile #include -#endif - -#ifndef _Standard_Boolean_HeaderFile #include -#endif -#ifndef _Standard_Real_HeaderFile #include -#endif -#ifndef _Standard_Integer_HeaderFile #include -#endif - #include +#include +#include +#include #include #include #include +#include #include -class math_Vector; -template class NCollection_Sequence; -template class NCollection_List; -template class NCollection_Vector; - class IntPatch_WLine; // Corresponds for debug information output. diff --git a/src/Aspect/Aspect_XRAction.hxx b/src/Aspect/Aspect_XRAction.hxx index eb9437f05e..84b9299b3d 100644 --- a/src/Aspect/Aspect_XRAction.hxx +++ b/src/Aspect/Aspect_XRAction.hxx @@ -53,6 +53,6 @@ protected: }; //! Map of actions with action Id as a key. -typedef NCollection_IndexedDataMap Aspect_XRActionMap; +typedef NCollection_IndexedDataMap Aspect_XRActionMap; #endif // _Aspect_XRAction_HeaderFile diff --git a/src/Aspect/Aspect_XRActionSet.hxx b/src/Aspect/Aspect_XRActionSet.hxx index fa5c695dc0..9bbf8b9704 100644 --- a/src/Aspect/Aspect_XRActionSet.hxx +++ b/src/Aspect/Aspect_XRActionSet.hxx @@ -50,6 +50,6 @@ protected: Aspect_XRActionMap myActions; //!< map of actions }; -typedef NCollection_IndexedDataMap Aspect_XRActionSetMap; +typedef NCollection_IndexedDataMap Aspect_XRActionSetMap; #endif // _Aspect_XRActionSet_HeaderFile diff --git a/src/BOPAlgo/BOPAlgo_BuilderFace.cxx b/src/BOPAlgo/BOPAlgo_BuilderFace.cxx index 2154b04c30..59efc80e40 100644 --- a/src/BOPAlgo/BOPAlgo_BuilderFace.cxx +++ b/src/BOPAlgo/BOPAlgo_BuilderFace.cxx @@ -167,7 +167,7 @@ void BOPAlgo_BuilderFace::Perform(const Message_ProgressRange& theRange) void BOPAlgo_BuilderFace::PerformShapesToAvoid(const Message_ProgressRange& theRange) { Standard_Boolean bFound; - Standard_Integer i, iCnt, aNbV, aNbE; + Standard_Integer i, aNbV, aNbE; TopTools_IndexedDataMapOfShapeListOfShape aMVE; TopTools_ListIteratorOfListOfShape aIt; // @@ -175,14 +175,11 @@ void BOPAlgo_BuilderFace::PerformShapesToAvoid(const Message_ProgressRange& theR // Message_ProgressScope aPS(theRange, NULL, 1); // - iCnt=0; for(;;) { if (UserBreak(aPS)) { return; } - - ++iCnt; bFound=Standard_False; // // 1. MEF diff --git a/src/BOPAlgo/BOPAlgo_BuilderSolid.cxx b/src/BOPAlgo/BOPAlgo_BuilderSolid.cxx index 9049bfbceb..1f506a9c2a 100644 --- a/src/BOPAlgo/BOPAlgo_BuilderSolid.cxx +++ b/src/BOPAlgo/BOPAlgo_BuilderSolid.cxx @@ -142,7 +142,7 @@ void BOPAlgo_BuilderSolid::Perform(const Message_ProgressRange& theRange) void BOPAlgo_BuilderSolid::PerformShapesToAvoid(const Message_ProgressRange& theRange) { Standard_Boolean bFound; - Standard_Integer i, iCnt, aNbE, aNbF; + Standard_Integer i, aNbE, aNbF; TopAbs_Orientation aOrE; TopTools_IndexedDataMapOfShapeListOfShape aMEF; TopTools_ListIteratorOfListOfShape aIt; @@ -151,12 +151,10 @@ void BOPAlgo_BuilderSolid::PerformShapesToAvoid(const Message_ProgressRange& the // Message_ProgressScope aPS(theRange, NULL, 1); // - iCnt=0; for(;;) { if (UserBreak(aPS)) { return; } - ++iCnt; bFound=Standard_False; // // 1. MEF diff --git a/src/BOPAlgo/BOPAlgo_Builder_2.cxx b/src/BOPAlgo/BOPAlgo_Builder_2.cxx index f2ebfef171..219f5d9f9a 100644 --- a/src/BOPAlgo/BOPAlgo_Builder_2.cxx +++ b/src/BOPAlgo/BOPAlgo_Builder_2.cxx @@ -549,8 +549,7 @@ void BOPAlgo_Builder::BuildSplitFaces(const Message_ProgressRange& theRange) //======================================================================= typedef NCollection_IndexedDataMap BOPAlgo_IndexedDataMapOfSetListOfShape; + TopTools_ListOfShape> BOPAlgo_IndexedDataMapOfSetListOfShape; static void AddEdgeSet(const TopoDS_Shape& theS, BOPAlgo_IndexedDataMapOfSetListOfShape& theMap, @@ -619,8 +618,7 @@ void BOPAlgo_Builder::FillSameDomainFaces(const Message_ProgressRange& theRange) // Data map of set of edges with all faces having this set NCollection_IndexedDataMap anESetFaces(1, aAllocator); + TopTools_ListOfShape> anESetFaces(1, aAllocator); // Map of planar bounded faces. If such faces have the same Edge set // they are considered Same domain, without additional check. TopTools_MapOfShape aMFPlanar(1, aAllocator); @@ -700,7 +698,7 @@ void BOPAlgo_Builder::FillSameDomainFaces(const Message_ProgressRange& theRange) if (bCheckPlanar && aMFPlanar.Contains(aF2)) { // Consider planar bounded faces as Same Domain without additional check - BOPAlgo_Tools::FillMap(aF1, aF2, aDMSLS, aAllocator); + BOPAlgo_Tools::FillMap(aF1, aF2, aDMSLS, aAllocator); continue; } // Add pair for analysis @@ -736,14 +734,12 @@ void BOPAlgo_Builder::FillSameDomainFaces(const Message_ProgressRange& theRange) { BOPAlgo_PairOfShapeBoolean& aPSB = aVPSB(i); if (aPSB.Flag()) - BOPAlgo_Tools::FillMap - (aPSB.Shape1(), aPSB.Shape2(), aDMSLS, aAllocator); + BOPAlgo_Tools::FillMap(aPSB.Shape1(), aPSB.Shape2(), aDMSLS, aAllocator); } aVPSB.Clear(); // Make blocks of SD faces using the back and forth map - BOPAlgo_Tools::MakeBlocks - (aDMSLS, aMBlocks, aAllocator); + BOPAlgo_Tools::MakeBlocks(aDMSLS, aMBlocks, aAllocator); Message_ProgressScope aPS(aPSOuter.Next(3), "Filling same domain faces map", aMBlocks.Size()); // Fill same domain faces map @@ -1027,7 +1023,7 @@ TopoDS_Face BuildDraftFace(const TopoDS_Face& theFace, TopTools_ListIteratorOfListOfShape aItLEIm(*pLEIm); for (; aItLEIm.More(); aItLEIm.Next()) { - TopoDS_Edge& aSp = TopoDS::Edge(aItLEIm.Value()); + TopoDS_Edge& aSp = TopoDS::Edge(aItLEIm.ChangeValue()); // Check if the split has multi-connected vertices if (!bIsDegenerated && HasMultiConnected(aSp, aVerticesCounter)) diff --git a/src/BOPAlgo/BOPAlgo_MakeConnected.hxx b/src/BOPAlgo/BOPAlgo_MakeConnected.hxx index d00aa05df6..733b4c7057 100644 --- a/src/BOPAlgo/BOPAlgo_MakeConnected.hxx +++ b/src/BOPAlgo/BOPAlgo_MakeConnected.hxx @@ -27,7 +27,6 @@ #include -#include //! BOPAlgo_MakeConnected is the algorithm for making the touching //! shapes connected or glued, i.e. for making the coinciding geometries @@ -321,8 +320,7 @@ protected: //! @name Fields // Results NCollection_DataMap myMaterials; //!< Map of the materials associations + TopTools_ListOfShape> myMaterials; //!< Map of the materials associations //! for the border elements TopTools_DataMapOfShapeListOfShape myOrigins; //!< Map of origins //! (allows tracking the shape's ancestors) diff --git a/src/BOPAlgo/BOPAlgo_PaveFiller.hxx b/src/BOPAlgo/BOPAlgo_PaveFiller.hxx index cd2275d994..a2fb939abf 100644 --- a/src/BOPAlgo/BOPAlgo_PaveFiller.hxx +++ b/src/BOPAlgo/BOPAlgo_PaveFiller.hxx @@ -180,13 +180,11 @@ protected: typedef NCollection_DataMap BOPAlgo_DataMapOfPaveBlockBndBox; + Bnd_Box> BOPAlgo_DataMapOfPaveBlockBndBox; typedef NCollection_DataMap BOPAlgo_DataMapOfPaveBlockListOfInteger; + TColStd_ListOfInteger> BOPAlgo_DataMapOfPaveBlockListOfInteger; typedef NCollection_DataMap , - BOPDS_PairMapHasher> myDistances; //!< Map to store minimal distances between shapes + NCollection_List> + myDistances; //!< Map to store minimal distances between shapes //! which have no real intersections }; diff --git a/src/BOPAlgo/BOPAlgo_PaveFiller_1.cxx b/src/BOPAlgo/BOPAlgo_PaveFiller_1.cxx index 9435f46ec6..e1cb9cfb26 100644 --- a/src/BOPAlgo/BOPAlgo_PaveFiller_1.cxx +++ b/src/BOPAlgo/BOPAlgo_PaveFiller_1.cxx @@ -75,7 +75,7 @@ void BOPAlgo_PaveFiller::PerformVV(const Message_ProgressRange& theRange) // if (myDS->HasInterf(n1, n2)) { - BOPAlgo_Tools::FillMap(n1, n2, aMILI, aAllocator); + BOPAlgo_Tools::FillMap(n1, n2, aMILI, aAllocator); continue; } @@ -91,12 +91,12 @@ void BOPAlgo_PaveFiller::PerformVV(const Message_ProgressRange& theRange) iFlag = BOPTools_AlgoTools::ComputeVV(aV1, aV2, myFuzzyValue); if (!iFlag) { - BOPAlgo_Tools::FillMap(n1, n2, aMILI, aAllocator); + BOPAlgo_Tools::FillMap(n1, n2, aMILI, aAllocator); } } // // 2. Make blocks - BOPAlgo_Tools::MakeBlocks(aMILI, aMBlocks, aAllocator); + BOPAlgo_Tools::MakeBlocks(aMILI, aMBlocks, aAllocator); // // 3. Make vertices NCollection_List::Iterator aItB(aMBlocks); diff --git a/src/BOPAlgo/BOPAlgo_PaveFiller_2.cxx b/src/BOPAlgo/BOPAlgo_PaveFiller_2.cxx index eecb0ff9a3..3678bdf2fe 100644 --- a/src/BOPAlgo/BOPAlgo_PaveFiller_2.cxx +++ b/src/BOPAlgo/BOPAlgo_PaveFiller_2.cxx @@ -229,7 +229,7 @@ void BOPAlgo_PaveFiller::IntersectVE // for all vertices having the same SD vertex. // It will also be used as a Fence map to avoid repeated // intersection of the same SD vertex with edge - NCollection_DataMap aDMVSD; + NCollection_DataMap aDMVSD; // Message_ProgressScope aPSOuter(theRange, NULL, 10); for (i = 1; i <= aNbVE; ++i) { @@ -407,8 +407,7 @@ void BOPAlgo_PaveFiller::SplitPaveBlocks(const TColStd_MapOfInteger& theMEdges, BOPDS_MapOfPair aMPairs; // Map to treat the Common Blocks NCollection_IndexedDataMap aMCBNewPB; + BOPDS_ListOfPaveBlock> aMCBNewPB; // // Map of vertices to init the pave blocks for them TColStd_MapOfInteger aMVerticesToInitPB; @@ -507,7 +506,7 @@ void BOPAlgo_PaveFiller::SplitPaveBlocks(const TColStd_MapOfInteger& theMEdges, const BOPDS_ListOfPaveBlock& aLPBN = aMCBNewPB(i); // // For each group of pave blocks with the same vertices make new common block - NCollection_IndexedDataMap aMInds; + NCollection_IndexedDataMap aMInds; BOPDS_ListIteratorOfListOfPaveBlock aItLPB(aLPBN); for (; aItLPB.More(); aItLPB.Next()) { const Handle(BOPDS_PaveBlock)& aPB = aItLPB.Value(); diff --git a/src/BOPAlgo/BOPAlgo_PaveFiller_3.cxx b/src/BOPAlgo/BOPAlgo_PaveFiller_3.cxx index 0e36f380fb..7dd8b3ee41 100644 --- a/src/BOPAlgo/BOPAlgo_PaveFiller_3.cxx +++ b/src/BOPAlgo/BOPAlgo_PaveFiller_3.cxx @@ -526,7 +526,7 @@ void BOPAlgo_PaveFiller::PerformEE(const Message_ProgressRange& theRange) // 2 myDS->AddInterf(nE1, nE2); // - BOPAlgo_Tools::FillMap(aPB1, aPB2, aMPBLPB, aAllocator); + BOPAlgo_Tools::FillMap(aPB1, aPB2, aMPBLPB, aAllocator); }//case TopAbs_EDGE break; default: @@ -964,8 +964,7 @@ void BOPAlgo_PaveFiller::ForceInterfEE(const Message_ProgressRange& theRange) // Fill the connection map from bounding vertices to pave blocks // having those bounding vertices NCollection_IndexedDataMap aPBMap(1, anAlloc); + BOPDS_ListOfPaveBlock> aPBMap(1, anAlloc); // Fence map of pave blocks BOPDS_MapOfPaveBlock aMPBFence(1, anAlloc); @@ -1147,7 +1146,7 @@ void BOPAlgo_PaveFiller::ForceInterfEE(const Message_ProgressRange& theRange) aPBMap.Clear(); aMPBFence.Clear(); - anAlloc->Reset(); + anAlloc->Reset(false); Message_ProgressScope aPS(aPSOuter.Next(9), "Checking for coinciding edges", aNbPairs); for (Standard_Integer i = 0; i < aNbPairs; i++) @@ -1221,14 +1220,11 @@ void BOPAlgo_PaveFiller::ForceInterfEE(const Message_ProgressRange& theRange) const BOPDS_ListOfPaveBlock& aLPBCB = myDS->CommonBlock(aPB[j])->PaveBlocks(); BOPDS_ListIteratorOfListOfPaveBlock aItLPB(aLPBCB); for (; aItLPB.More(); aItLPB.Next()) - BOPAlgo_Tools::FillMap(aPB[j], aItLPB.Value(), aMPBLPB, anAlloc); + BOPAlgo_Tools::FillMap(aPB[j], aItLPB.Value(), aMPBLPB, anAlloc); } } - BOPAlgo_Tools::FillMap(aPB[0], aPB[1], aMPBLPB, anAlloc); + BOPAlgo_Tools::FillMap(aPB[0], aPB[1], aMPBLPB, anAlloc); } - // Create new common blocks of coinciding pairs. BOPAlgo_Tools::PerformCommonBlocks(aMPBLPB, anAlloc, myDS); } diff --git a/src/BOPAlgo/BOPAlgo_PaveFiller_4.cxx b/src/BOPAlgo/BOPAlgo_PaveFiller_4.cxx index e39b6276a1..22dcacc2cd 100644 --- a/src/BOPAlgo/BOPAlgo_PaveFiller_4.cxx +++ b/src/BOPAlgo/BOPAlgo_PaveFiller_4.cxx @@ -172,7 +172,7 @@ void BOPAlgo_PaveFiller::PerformVF(const Message_ProgressRange& theRange) // // Avoid repeated intersection of the same vertex with face in case // the group of vertices formed a single SD vertex - NCollection_DataMap aMVFPairs; + NCollection_DataMap aMVFPairs; for (; myIterator->More(); myIterator->Next()) { if (UserBreak(aPSOuter)) { diff --git a/src/BOPAlgo/BOPAlgo_PaveFiller_5.cxx b/src/BOPAlgo/BOPAlgo_PaveFiller_5.cxx index 0e4c6ed89f..4602355f31 100644 --- a/src/BOPAlgo/BOPAlgo_PaveFiller_5.cxx +++ b/src/BOPAlgo/BOPAlgo_PaveFiller_5.cxx @@ -573,30 +573,11 @@ Standard_Boolean BOPAlgo_PaveFiller::CheckFacePaves const TColStd_MapOfInteger& aMIFOn, const TColStd_MapOfInteger& aMIFIn) { - Standard_Boolean bRet; - Standard_Integer nV; - TColStd_MapIteratorOfMapOfInteger aIt; - // - bRet=Standard_False; - // - aIt.Initialize(aMIFOn); - for (; aIt.More(); aIt.Next()) { - nV=aIt.Value(); - if (nV==nVx) { - bRet=!bRet; - return bRet; - } + if (aMIFOn.Contains(nVx) || aMIFIn.Contains(nVx)) + { + return true; } - aIt.Initialize(aMIFIn); - for (; aIt.More(); aIt.Next()) { - nV=aIt.Value(); - if (nV==nVx) { - bRet=!bRet; - return bRet; - } - } - // - return bRet; + return false; } //======================================================================= // function: CheckFacePaves @@ -1073,7 +1054,7 @@ void BOPAlgo_PaveFiller::ForceInterfEF(const BOPDS_IndexedMapOfPaveBlock& theMPB aPSOuter.Next(0.7); aPBMap.Clear(); - anAlloc->Reset(); + anAlloc->Reset(false); Message_ProgressScope aPS(aPSOuter.Next(9), "Checking for edges coinciding with faces", aNbEFs); for (Standard_Integer i = 0; i < aNbEFs; i++) diff --git a/src/BOPAlgo/BOPAlgo_PaveFiller_6.cxx b/src/BOPAlgo/BOPAlgo_PaveFiller_6.cxx index 0a89813227..5fd7dc82fa 100644 --- a/src/BOPAlgo/BOPAlgo_PaveFiller_6.cxx +++ b/src/BOPAlgo/BOPAlgo_PaveFiller_6.cxx @@ -281,7 +281,7 @@ void BOPAlgo_PaveFiller::PerformFF(const Message_ProgressRange& theRange) // // Collect all pairs of Edge/Edge interferences to check if // some faces have to be moved to obtain more precise intersection - NCollection_DataMap aEEMap; + NCollection_DataMap aEEMap; const BOPDS_VectorOfInterfEE& aVEEs = myDS->InterfEE(); for (Standard_Integer iEE = 0; iEE < aVEEs.Size(); ++iEE) { @@ -1198,8 +1198,7 @@ void BOPAlgo_PaveFiller::PostTreatFF // Map to store the real tolerance of the common block // and avoid repeated computation of it NCollection_DataMap aMCBTol; + Standard_Real> aMCBTol; // Map to avoid creation of different pave blocks for // the same intersection edge NCollection_DataMap aMEPB; diff --git a/src/BOPAlgo/BOPAlgo_Tools.cxx b/src/BOPAlgo/BOPAlgo_Tools.cxx index 13151f8413..e39ab55efd 100644 --- a/src/BOPAlgo/BOPAlgo_Tools.cxx +++ b/src/BOPAlgo/BOPAlgo_Tools.cxx @@ -119,7 +119,7 @@ void BOPAlgo_Tools::PerformCommonBlocks(BOPDS_IndexedDataMapOfPaveBlockListOfPav } // Make Blocks of the pave blocks NCollection_List aMBlocks(aAllocator); - BOPAlgo_Tools::MakeBlocks(aMPBLPB, aMBlocks, aAllocator); + BOPAlgo_Tools::MakeBlocks(aMPBLPB, aMBlocks, aAllocator); // Use temporary allocator for the local fence map Handle(NCollection_IncAllocator) anAllocTmp = new NCollection_IncAllocator; @@ -132,7 +132,7 @@ void BOPAlgo_Tools::PerformCommonBlocks(BOPDS_IndexedDataMapOfPaveBlockListOfPav continue; // Reset the allocator - anAllocTmp->Reset(); + anAllocTmp->Reset(false); // New common block Handle(BOPDS_CommonBlock) aCB; // Faces of the common block @@ -1068,11 +1068,11 @@ void BOPAlgo_Tools::IntersectVertices(const TopTools_IndexedDataMapOfShapeReal& for (Standard_Integer iPair = 0; iPair < aNbPairs; ++iPair) { const BOPTools_BoxPairSelector::PairIDs& aPair = aPairs[iPair]; - BOPAlgo_Tools::FillMap (aPair.ID1, aPair.ID2, aMILI, anAlloc); + BOPAlgo_Tools::FillMap (aPair.ID1, aPair.ID2, aMILI, anAlloc); } - NCollection_List aBlocks (anAlloc); - BOPAlgo_Tools::MakeBlocks (aMILI, aBlocks, anAlloc); + NCollection_List aBlocks(anAlloc); + BOPAlgo_Tools::MakeBlocks (aMILI, aBlocks, anAlloc); NCollection_List::Iterator itLI (aBlocks); for (; itLI.More(); itLI.Next()) diff --git a/src/BOPAlgo/BOPAlgo_Tools.hxx b/src/BOPAlgo/BOPAlgo_Tools.hxx index ec6cce7908..465edc2731 100644 --- a/src/BOPAlgo/BOPAlgo_Tools.hxx +++ b/src/BOPAlgo/BOPAlgo_Tools.hxx @@ -42,31 +42,31 @@ class BOPAlgo_Tools { public: - //! Makes the chains of the connected elements from the given connexity map - template - static void MakeBlocks(const NCollection_IndexedDataMap, theTypeHasher>& theMILI, - NCollection_List>& theMBlocks, + //! Makes the chains of the connected elements from the given convexity map + template + static void MakeBlocks(const TheMap& theMILI, + TheList& theMBlocks, const Handle(NCollection_BaseAllocator)& theAllocator) { - NCollection_Map aMFence; + NCollection_Map aMFence; Standard_Integer i, aNb = theMILI.Extent(); for (i = 1; i <= aNb; ++i) { - const theType& n = theMILI.FindKey(i); + const typename TheMap::key_type& n = theMILI.FindKey(i); if (!aMFence.Add(n)) continue; // // Start the chain - NCollection_List& aChain = theMBlocks.Append(NCollection_List(theAllocator)); + typename TheList::value_type& aChain = theMBlocks.Append(typename TheList::value_type(theAllocator)); aChain.Append(n); // Look for connected elements - typename NCollection_List::Iterator aItLChain(aChain); + typename TheList::value_type::Iterator aItLChain(aChain); for (; aItLChain.More(); aItLChain.Next()) { - const theType& n1 = aItLChain.Value(); - const NCollection_List& aLI = theMILI.FindFromKey(n1); + const typename TheMap::key_type& n1 = aItLChain.Value(); + const typename TheList::value_type& aLI = theMILI.FindFromKey(n1); // Add connected elements into the chain - typename NCollection_List::Iterator aItLI(aLI); + typename TheList::value_type::Iterator aItLI(aLI); for (; aItLI.More(); aItLI.Next()) { - const theType& n2 = aItLI.Value(); + const typename TheMap::key_type& n2 = aItLI.Value(); if (aMFence.Add(n2)) { aChain.Append(n2); } @@ -76,21 +76,21 @@ public: } //! Fills the map with the connected entities - template - static void FillMap(const theType& n1, - const theType& n2, - NCollection_IndexedDataMap, theTypeHasher>& theMILI, + template + static void FillMap(const TheType& n1, + const TheType& n2, + TheMap& theMILI, const Handle(NCollection_BaseAllocator)& theAllocator) { - NCollection_List *pList1 = theMILI.ChangeSeek(n1); + typename TheMap::value_type *pList1 = theMILI.ChangeSeek(n1); if (!pList1) { - pList1 = &theMILI(theMILI.Add(n1, NCollection_List(theAllocator))); + pList1 = &theMILI(theMILI.Add(n1, NCollection_List(theAllocator))); } pList1->Append(n2); // - NCollection_List *pList2 = theMILI.ChangeSeek(n2); + typename TheMap::value_type*pList2 = theMILI.ChangeSeek(n2); if (!pList2) { - pList2 = &theMILI(theMILI.Add(n2, NCollection_List(theAllocator))); + pList2 = &theMILI(theMILI.Add(n2, typename TheMap::value_type(theAllocator))); } pList2->Append(n1); } diff --git a/src/BOPDS/BOPDS_DS.cxx b/src/BOPDS/BOPDS_DS.cxx index 9ad33e6fdd..d7d693df86 100644 --- a/src/BOPDS/BOPDS_DS.cxx +++ b/src/BOPDS/BOPDS_DS.cxx @@ -965,8 +965,8 @@ void BOPDS_DS::UpdateCommonBlock(const Handle(BOPDS_CommonBlock)& theCB, Standard_Integer nE, iRef, n1, n2; BOPDS_ListIteratorOfListOfPaveBlock aItPB, aItPBCB, aItPBN; BOPDS_ListOfPaveBlock aLPBN; - NCollection_DataMap aMPKLPB; - NCollection_DataMap::Iterator aItMPKLPB; + NCollection_DataMap aMPKLPB; + NCollection_DataMap::Iterator aItMPKLPB; Handle(BOPDS_PaveBlock) aPB; Handle(BOPDS_CommonBlock) aCBx; BOPDS_Pair aPK; diff --git a/src/BOPDS/BOPDS_DataMapOfIntegerListOfPaveBlock.hxx b/src/BOPDS/BOPDS_DataMapOfIntegerListOfPaveBlock.hxx index 6c8a35d70d..630928f1ed 100644 --- a/src/BOPDS/BOPDS_DataMapOfIntegerListOfPaveBlock.hxx +++ b/src/BOPDS/BOPDS_DataMapOfIntegerListOfPaveBlock.hxx @@ -18,6 +18,6 @@ #include #include -typedef NCollection_DataMap BOPDS_DataMapOfIntegerListOfPaveBlock; +typedef NCollection_DataMap BOPDS_DataMapOfIntegerListOfPaveBlock; #endif diff --git a/src/BOPDS/BOPDS_DataMapOfPaveBlockCommonBlock.hxx b/src/BOPDS/BOPDS_DataMapOfPaveBlockCommonBlock.hxx index 0694c8386d..f805274635 100644 --- a/src/BOPDS/BOPDS_DataMapOfPaveBlockCommonBlock.hxx +++ b/src/BOPDS/BOPDS_DataMapOfPaveBlockCommonBlock.hxx @@ -17,10 +17,9 @@ #define BOPDS_DataMapOfPaveBlockCommonBlock_HeaderFile #include -#include #include -typedef NCollection_DataMap BOPDS_DataMapOfPaveBlockCommonBlock; +typedef NCollection_DataMap BOPDS_DataMapOfPaveBlockCommonBlock; typedef BOPDS_DataMapOfPaveBlockCommonBlock::Iterator BOPDS_DataMapIteratorOfDataMapOfPaveBlockCommonBlock; #endif diff --git a/src/BOPDS/BOPDS_DataMapOfPaveBlockListOfInteger.hxx b/src/BOPDS/BOPDS_DataMapOfPaveBlockListOfInteger.hxx index 7fc61c0e08..96a2cdef8b 100644 --- a/src/BOPDS/BOPDS_DataMapOfPaveBlockListOfInteger.hxx +++ b/src/BOPDS/BOPDS_DataMapOfPaveBlockListOfInteger.hxx @@ -16,10 +16,9 @@ #define BOPDS_DataMapOfPaveBlockListOfInteger_HeaderFile #include -#include #include -typedef NCollection_DataMap BOPDS_DataMapOfPaveBlockListOfInteger; +typedef NCollection_DataMap BOPDS_DataMapOfPaveBlockListOfInteger; typedef BOPDS_DataMapOfPaveBlockListOfInteger::Iterator BOPDS_DataMapIteratorOfDataMapOfPaveBlockListOfInteger; #endif diff --git a/src/BOPDS/BOPDS_DataMapOfPaveBlockListOfPaveBlock.hxx b/src/BOPDS/BOPDS_DataMapOfPaveBlockListOfPaveBlock.hxx index fa2f68daec..0d04eb0f54 100644 --- a/src/BOPDS/BOPDS_DataMapOfPaveBlockListOfPaveBlock.hxx +++ b/src/BOPDS/BOPDS_DataMapOfPaveBlockListOfPaveBlock.hxx @@ -16,11 +16,10 @@ #define BOPDS_DataMapOfPaveBlockListOfPaveBlock_HeaderFile #include -#include #include #include -typedef NCollection_DataMap BOPDS_DataMapOfPaveBlockListOfPaveBlock; +typedef NCollection_DataMap BOPDS_DataMapOfPaveBlockListOfPaveBlock; typedef BOPDS_DataMapOfPaveBlockListOfPaveBlock::Iterator BOPDS_DataMapIteratorOfDataMapOfPaveBlockListOfPaveBlock; #endif diff --git a/src/BOPDS/BOPDS_IndexedDataMapOfPaveBlockListOfInteger.hxx b/src/BOPDS/BOPDS_IndexedDataMapOfPaveBlockListOfInteger.hxx index 2236e4d33c..a9bdbfe4cb 100644 --- a/src/BOPDS/BOPDS_IndexedDataMapOfPaveBlockListOfInteger.hxx +++ b/src/BOPDS/BOPDS_IndexedDataMapOfPaveBlockListOfInteger.hxx @@ -16,10 +16,9 @@ #define BOPDS_IndexedDataMapOfPaveBlockListOfInteger_HeaderFile #include -#include #include #include -typedef NCollection_IndexedDataMap BOPDS_IndexedDataMapOfPaveBlockListOfInteger; +typedef NCollection_IndexedDataMap BOPDS_IndexedDataMapOfPaveBlockListOfInteger; #endif diff --git a/src/BOPDS/BOPDS_IndexedDataMapOfPaveBlockListOfPaveBlock.hxx b/src/BOPDS/BOPDS_IndexedDataMapOfPaveBlockListOfPaveBlock.hxx index c8e0382c41..3ce09a5b22 100644 --- a/src/BOPDS/BOPDS_IndexedDataMapOfPaveBlockListOfPaveBlock.hxx +++ b/src/BOPDS/BOPDS_IndexedDataMapOfPaveBlockListOfPaveBlock.hxx @@ -16,10 +16,9 @@ #define BOPDS_IndexedDataMapOfPaveBlockListOfPaveBlock_HeaderFile #include -#include #include #include -typedef NCollection_IndexedDataMap BOPDS_IndexedDataMapOfPaveBlockListOfPaveBlock; +typedef NCollection_IndexedDataMap BOPDS_IndexedDataMapOfPaveBlockListOfPaveBlock; #endif diff --git a/src/BOPDS/BOPDS_IndexedMapOfPaveBlock.hxx b/src/BOPDS/BOPDS_IndexedMapOfPaveBlock.hxx index 8ed5f34858..7b990919bc 100644 --- a/src/BOPDS/BOPDS_IndexedMapOfPaveBlock.hxx +++ b/src/BOPDS/BOPDS_IndexedMapOfPaveBlock.hxx @@ -16,9 +16,8 @@ #define BOPDS_IndexedMapOfPaveBlock_HeaderFile #include -#include #include -typedef NCollection_IndexedMap BOPDS_IndexedMapOfPaveBlock; +typedef NCollection_IndexedMap BOPDS_IndexedMapOfPaveBlock; #endif diff --git a/src/BOPDS/BOPDS_ListOfPaveBlock.hxx b/src/BOPDS/BOPDS_ListOfPaveBlock.hxx index 8692313da8..501686356f 100644 --- a/src/BOPDS/BOPDS_ListOfPaveBlock.hxx +++ b/src/BOPDS/BOPDS_ListOfPaveBlock.hxx @@ -15,9 +15,11 @@ #ifndef BOPDS_ListOfPaveBlock_HeaderFile #define BOPDS_ListOfPaveBlock_HeaderFile -#include +#include +#include class BOPDS_PaveBlock; + typedef NCollection_List BOPDS_ListOfPaveBlock; typedef BOPDS_ListOfPaveBlock::Iterator BOPDS_ListIteratorOfListOfPaveBlock; diff --git a/src/BOPDS/BOPDS_MapOfCommonBlock.hxx b/src/BOPDS/BOPDS_MapOfCommonBlock.hxx index 6ab0203832..21dccc1cd5 100644 --- a/src/BOPDS/BOPDS_MapOfCommonBlock.hxx +++ b/src/BOPDS/BOPDS_MapOfCommonBlock.hxx @@ -16,10 +16,9 @@ #define BOPDS_MapOfCommonBlock_HeaderFile #include -#include #include -typedef NCollection_Map BOPDS_MapOfCommonBlock; +typedef NCollection_Map BOPDS_MapOfCommonBlock; typedef BOPDS_MapOfCommonBlock::Iterator BOPDS_MapIteratorOfMapOfCommonBlock; #endif diff --git a/src/BOPDS/BOPDS_MapOfPair.hxx b/src/BOPDS/BOPDS_MapOfPair.hxx index e9a9e73f23..ac97544045 100644 --- a/src/BOPDS/BOPDS_MapOfPair.hxx +++ b/src/BOPDS/BOPDS_MapOfPair.hxx @@ -16,10 +16,9 @@ #define BOPDS_MapOfPair_HeaderFile #include -#include #include -typedef NCollection_Map BOPDS_MapOfPair; +typedef NCollection_Map BOPDS_MapOfPair; typedef BOPDS_MapOfPair::Iterator BOPDS_MapIteratorOfMapOfPair; #endif diff --git a/src/BOPDS/BOPDS_MapOfPave.hxx b/src/BOPDS/BOPDS_MapOfPave.hxx index d445e38943..22f63dd62c 100644 --- a/src/BOPDS/BOPDS_MapOfPave.hxx +++ b/src/BOPDS/BOPDS_MapOfPave.hxx @@ -16,10 +16,9 @@ #define BOPDS_MapOfPave_HeaderFile #include -#include #include -typedef NCollection_Map BOPDS_MapOfPave; +typedef NCollection_Map BOPDS_MapOfPave; typedef BOPDS_MapOfPave::Iterator BOPDS_MapIteratorOfMapOfPave; #endif diff --git a/src/BOPDS/BOPDS_MapOfPaveBlock.hxx b/src/BOPDS/BOPDS_MapOfPaveBlock.hxx index 784e101104..fb75669f7a 100644 --- a/src/BOPDS/BOPDS_MapOfPaveBlock.hxx +++ b/src/BOPDS/BOPDS_MapOfPaveBlock.hxx @@ -16,10 +16,9 @@ #define BOPDS_MapOfPaveBlock_HeaderFile #include -#include #include -typedef NCollection_Map BOPDS_MapOfPaveBlock; +typedef NCollection_Map BOPDS_MapOfPaveBlock; typedef BOPDS_MapOfPaveBlock::Iterator BOPDS_MapIteratorOfMapOfPaveBlock; #endif diff --git a/src/BOPDS/BOPDS_Pair.hxx b/src/BOPDS/BOPDS_Pair.hxx index e26a7d3fd0..0fbd17002b 100644 --- a/src/BOPDS/BOPDS_Pair.hxx +++ b/src/BOPDS/BOPDS_Pair.hxx @@ -17,6 +17,7 @@ #include #include +#include //! The class is to provide the pair of indices of interfering shapes. @@ -62,12 +63,9 @@ class BOPDS_Pair { (myIndex1 == theOther.myIndex2 && myIndex2 == theOther.myIndex1); } - //! Computes a hash code for this pair, in the range [1, theUpperBound] - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - Standard_Integer HashCode (const Standard_Integer theUpperBound) const + bool operator==(const BOPDS_Pair& theOther) const { - return ::HashCode(myIndex1 + myIndex2, theUpperBound); + return IsEqual(theOther); } protected: @@ -75,4 +73,23 @@ class BOPDS_Pair { Standard_Integer myIndex2; }; +namespace std +{ + template <> + struct hash + { + size_t operator()(const BOPDS_Pair& thePair) const noexcept + { + // Combine two int values into a single hash value. + int aCombination[2]; + thePair.Indices(aCombination[0], aCombination[1]); + if (aCombination[0] > aCombination[1]) + { + std::swap(aCombination[0], aCombination[1]); + } + return opencascade::hashBytes(aCombination, sizeof(aCombination)); + } + }; +} + #endif // _BOPDS_Pair \ No newline at end of file diff --git a/src/BOPDS/BOPDS_PairMapHasher.hxx b/src/BOPDS/BOPDS_PairMapHasher.hxx deleted file mode 100644 index 64d7ec7b6e..0000000000 --- a/src/BOPDS/BOPDS_PairMapHasher.hxx +++ /dev/null @@ -1,53 +0,0 @@ -// Created by: Eugeny MALTCHIKOV -// Copyright (c) 2017 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _BOPDS_PairMapHasher_HeaderFile -#define _BOPDS_PairMapHasher_HeaderFile - -#include -#include - -#include -#include - -class BOPDS_Pair; - -class BOPDS_PairMapHasher -{ -public: - - DEFINE_STANDARD_ALLOC - - //! Computes a hash code for the given pair, in the range [1, theUpperBound] - //! @param thePair the pair which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const BOPDS_Pair& thePair, const Standard_Integer theUpperBound) - { - return thePair.HashCode (theUpperBound); - } - - static Standard_Boolean IsEqual(const BOPDS_Pair& thePair1, - const BOPDS_Pair& thePair2) - { - return thePair1.IsEqual(thePair2); - } - -protected: - -private: - -}; - -#endif // _BOPDS_PairMapHasher_HeaderFile diff --git a/src/BOPDS/BOPDS_Pave.hxx b/src/BOPDS/BOPDS_Pave.hxx index 8d5bcc069c..6a09d57bcc 100644 --- a/src/BOPDS/BOPDS_Pave.hxx +++ b/src/BOPDS/BOPDS_Pave.hxx @@ -103,6 +103,20 @@ private: }; +namespace std +{ + template <> + struct hash + { + size_t operator()(const BOPDS_Pave& thePave) const noexcept + { + size_t aCombination[2]; + aCombination[0] = opencascade::hash(thePave.Index()); + aCombination[1] = opencascade::hash(thePave.Parameter()); + return opencascade::hashBytes(aCombination, sizeof(aCombination)); + } + }; +} #include diff --git a/src/BOPDS/BOPDS_PaveMapHasher.hxx b/src/BOPDS/BOPDS_PaveMapHasher.hxx deleted file mode 100644 index e64a644a8b..0000000000 --- a/src/BOPDS/BOPDS_PaveMapHasher.hxx +++ /dev/null @@ -1,64 +0,0 @@ -// Created by: Eugeny MALTCHIKOV -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _BOPDS_PaveMapHasher_HeaderFile -#define _BOPDS_PaveMapHasher_HeaderFile - -#include -#include - -#include -class BOPDS_Pave; - - - -class BOPDS_PaveMapHasher -{ -public: - - DEFINE_STANDARD_ALLOC - - //! Computes a hash code for the given pave, in the range [1, theUpperBound] - //! @param thePave the pave which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const BOPDS_Pave& thePave, Standard_Integer theUpperBound); - - static Standard_Boolean IsEqual (const BOPDS_Pave& aPave1, const BOPDS_Pave& aPave2); - - - - -protected: - - - - - -private: - - - - - -}; - - -#include - - - - - -#endif // _BOPDS_PaveMapHasher_HeaderFile diff --git a/src/BOPDS/BOPDS_PaveMapHasher.lxx b/src/BOPDS/BOPDS_PaveMapHasher.lxx deleted file mode 100644 index a6fb0b44a8..0000000000 --- a/src/BOPDS/BOPDS_PaveMapHasher.lxx +++ /dev/null @@ -1,35 +0,0 @@ -// Created by: Eugeny MALTCHIKOV -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#include - -//======================================================================= -// function : HashCode -// purpose : -//======================================================================= -inline Standard_Integer BOPDS_PaveMapHasher::HashCode (const BOPDS_Pave& thePave, const Standard_Integer theUpperBound) -{ - return ::HashCode (thePave.Index(), theUpperBound); -} - -//======================================================================= -//function :IsEqual -//purpose : -//======================================================================= -inline - Standard_Boolean BOPDS_PaveMapHasher::IsEqual(const BOPDS_Pave& aPave1, - const BOPDS_Pave& aPave2) -{ - return aPave1.IsEqual(aPave2); -} diff --git a/src/BOPDS/FILES b/src/BOPDS/FILES index d66100a521..f7ce702c13 100644 --- a/src/BOPDS/FILES +++ b/src/BOPDS/FILES @@ -35,8 +35,6 @@ BOPDS_Pave.hxx BOPDS_Pave.lxx BOPDS_PaveBlock.cxx BOPDS_PaveBlock.hxx -BOPDS_PaveMapHasher.hxx -BOPDS_PaveMapHasher.lxx BOPDS_PDS.hxx BOPDS_PIterator.hxx BOPDS_PIteratorSI.hxx @@ -67,7 +65,6 @@ BOPDS_VectorOfPave.hxx BOPDS_VectorOfPoint.hxx BOPDS_VectorOfShapeInfo.hxx BOPDS_Pair.hxx -BOPDS_PairMapHasher.hxx BOPDS_MapOfPair.hxx BOPDS_VectorOfPair.hxx BOPDS_VectorOfVectorOfPair.hxx diff --git a/src/BOPTools/BOPTools_IndexedDataMapOfSetShape.hxx b/src/BOPTools/BOPTools_IndexedDataMapOfSetShape.hxx index a2857d0744..5ad63044fa 100644 --- a/src/BOPTools/BOPTools_IndexedDataMapOfSetShape.hxx +++ b/src/BOPTools/BOPTools_IndexedDataMapOfSetShape.hxx @@ -16,10 +16,9 @@ #define BOPTools_IndexedDataMapOfSetShape_HeaderFile #include -#include #include #include -typedef NCollection_IndexedDataMap BOPTools_IndexedDataMapOfSetShape; +typedef NCollection_IndexedDataMap BOPTools_IndexedDataMapOfSetShape; #endif diff --git a/src/BOPTools/BOPTools_MapOfSet.hxx b/src/BOPTools/BOPTools_MapOfSet.hxx index bea5786138..0a9e80b0bc 100644 --- a/src/BOPTools/BOPTools_MapOfSet.hxx +++ b/src/BOPTools/BOPTools_MapOfSet.hxx @@ -16,11 +16,10 @@ #define BOPTools_MapOfSet_HeaderFile #include -#include #include -typedef NCollection_Map BOPTools_MapOfSet; +typedef NCollection_Map BOPTools_MapOfSet; typedef BOPTools_MapOfSet::Iterator BOPTools_MapIteratorOfMapOfSet; #endif diff --git a/src/BOPTools/BOPTools_Parallel.hxx b/src/BOPTools/BOPTools_Parallel.hxx index 2f34d7bc4e..de87a3a0a5 100644 --- a/src/BOPTools/BOPTools_Parallel.hxx +++ b/src/BOPTools/BOPTools_Parallel.hxx @@ -50,25 +50,6 @@ class BOPTools_Parallel template class ContextFunctor { - //! Auxiliary thread ID hasher. - struct Hasher - { - //! Computes a hash code for the given thread identifier, in the range [1, theUpperBound] - //! @param theThreadId the thread identifier which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const Standard_ThreadId theThreadId, const Standard_Integer theUpperBound) - { - return ::HashCode (theThreadId, theUpperBound); - } - - static Standard_Boolean IsEqual(const Standard_ThreadId theKey1, - const Standard_ThreadId theKey2) - { - return theKey1 == theKey2; - } - }; - public: //! Constructor @@ -116,7 +97,7 @@ class BOPTools_Parallel private: TypeSolverVector& mySolverVector; - mutable NCollection_DataMap, Hasher> myContextMap; + mutable NCollection_DataMap> myContextMap; mutable Standard_Mutex myMutex; }; diff --git a/src/BOPTools/BOPTools_Set.cxx b/src/BOPTools/BOPTools_Set.cxx index d6a146aef0..1c97deac1c 100644 --- a/src/BOPTools/BOPTools_Set.cxx +++ b/src/BOPTools/BOPTools_Set.cxx @@ -21,8 +21,8 @@ #include static - Standard_Integer NormalizedIds(const Standard_Integer aId, - const Standard_Integer aDiv); + size_t NormalizedIds(const size_t aId, + const Standard_Integer aDiv); //======================================================================= //function : @@ -127,15 +127,6 @@ const TopoDS_Shape& BOPTools_Set::Shape()const return myShape; } -//======================================================================= -// function : HashCode -// purpose : -//======================================================================= -Standard_Integer BOPTools_Set::HashCode (const Standard_Integer theUpperBound) const -{ - return ::HashCode (mySum, theUpperBound); -} - //======================================================================= //function : IsEqual //purpose : @@ -177,7 +168,7 @@ Standard_Boolean BOPTools_Set::IsEqual void BOPTools_Set::Add(const TopoDS_Shape& theS, const TopAbs_ShapeEnum theType) { - Standard_Integer aId, aIdN; + size_t aId, aIdN; TopAbs_Orientation aOr; TopExp_Explorer aExp; // @@ -223,7 +214,7 @@ void BOPTools_Set::Add(const TopoDS_Shape& theS, aIt.Initialize(myShapes); for (; aIt.More(); aIt.Next()) { const TopoDS_Shape& aSx=aIt.Value(); - aId=aSx.HashCode(myUpper); + aId = TopTools_ShapeMapHasher{}(aSx) % myUpper + 1; aIdN=NormalizedIds(aId, myNbShapes); mySum+=aIdN; } @@ -232,13 +223,13 @@ void BOPTools_Set::Add(const TopoDS_Shape& theS, // function: NormalizedIds // purpose : //======================================================================= -Standard_Integer NormalizedIds(const Standard_Integer aId, - const Standard_Integer aDiv) +size_t NormalizedIds(const size_t aId, + const Standard_Integer aDiv) { - Standard_Integer aMax, aTresh, aIdRet; + size_t aMax, aTresh, aIdRet; // aIdRet=aId; - aMax=::IntegerLast(); + aMax=SIZE_MAX; aTresh=aMax/aDiv; if (aId>aTresh) { aIdRet=aId%aTresh; diff --git a/src/BOPTools/BOPTools_Set.hxx b/src/BOPTools/BOPTools_Set.hxx index bd6ecd2939..67cb07d82d 100644 --- a/src/BOPTools/BOPTools_Set.hxx +++ b/src/BOPTools/BOPTools_Set.hxx @@ -55,11 +55,12 @@ BOPTools_Set& operator = (const BOPTools_Set& Other) Standard_EXPORT Standard_Boolean IsEqual (const BOPTools_Set& aOther) const; - //! Computes a hash code for this set, in the range [1, theUpperBound] - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - Standard_EXPORT Standard_Integer HashCode (Standard_Integer theUpperBound) const; + bool operator==(const BOPTools_Set& theOther) const + { + return IsEqual(theOther); + } + size_t GetSum() const { return mySum; } protected: @@ -71,22 +72,20 @@ protected: TopTools_ListOfShape myShapes; TopoDS_Shape myShape; Standard_Integer myNbShapes; - Standard_Integer mySum; + size_t mySum; Standard_Integer myUpper; - - -private: - - - - - }; - - - - - +namespace std +{ + template <> + struct hash + { + size_t operator()(const BOPTools_Set& theSet) const noexcept + { + return theSet.GetSum(); + } + }; +} #endif // _BOPTools_Set_HeaderFile diff --git a/src/BOPTools/BOPTools_SetMapHasher.hxx b/src/BOPTools/BOPTools_SetMapHasher.hxx deleted file mode 100644 index 875f0b09ab..0000000000 --- a/src/BOPTools/BOPTools_SetMapHasher.hxx +++ /dev/null @@ -1,64 +0,0 @@ -// Created by: Peter KURNEV -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _BOPTools_SetMapHasher_HeaderFile -#define _BOPTools_SetMapHasher_HeaderFile - -#include -#include - -#include -class BOPTools_Set; - - - -class BOPTools_SetMapHasher -{ -public: - - DEFINE_STANDARD_ALLOC - - //! Computes a hash code for the given set, in the range [1, theUpperBound] - //! @param theSet the set which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const BOPTools_Set& theSet, Standard_Integer theUpperBound); - - static Standard_Boolean IsEqual (const BOPTools_Set& aSet1, const BOPTools_Set& aSet2); - - - - -protected: - - - - - -private: - - - - - -}; - - -#include - - - - - -#endif // _BOPTools_SetMapHasher_HeaderFile diff --git a/src/BOPTools/BOPTools_SetMapHasher.lxx b/src/BOPTools/BOPTools_SetMapHasher.lxx deleted file mode 100644 index 3cdd0c9b6f..0000000000 --- a/src/BOPTools/BOPTools_SetMapHasher.lxx +++ /dev/null @@ -1,35 +0,0 @@ -// Created by: Peter KURNEV -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -//#include - -//======================================================================= -// function : HashCode -// purpose : -//======================================================================= -inline Standard_Integer BOPTools_SetMapHasher::HashCode (const BOPTools_Set& theSet, - const Standard_Integer theUpperBound) -{ - return theSet.HashCode (theUpperBound); -} - -//======================================================================= -//function :IsEqual -//purpose : -//======================================================================= -inline Standard_Boolean BOPTools_SetMapHasher::IsEqual(const BOPTools_Set& theSS1, - const BOPTools_Set& theSS2) -{ - return theSS1.IsEqual(theSS2); -} diff --git a/src/BOPTools/FILES b/src/BOPTools/FILES index 26ade9a944..3e6777deae 100755 --- a/src/BOPTools/FILES +++ b/src/BOPTools/FILES @@ -19,5 +19,3 @@ BOPTools_PairSelector.hxx BOPTools_Parallel.hxx BOPTools_Set.cxx BOPTools_Set.hxx -BOPTools_SetMapHasher.hxx -BOPTools_SetMapHasher.lxx diff --git a/src/BRep/BRep_Builder.cxx b/src/BRep/BRep_Builder.cxx index ab78ac8e0b..d0759d6540 100644 --- a/src/BRep/BRep_Builder.cxx +++ b/src/BRep/BRep_Builder.cxx @@ -356,7 +356,7 @@ static void UpdateCurves(BRep_ListOfCurveRepresentation& lcr, } if (itcr.More()) { - Handle(BRep_CurveRepresentation)& cr = itcr.Value(); + Handle(BRep_CurveRepresentation) cr = itcr.Value(); cr->Continuity(C); } else { @@ -380,7 +380,7 @@ static void UpdatePoints(BRep_ListOfPointRepresentation& lpr, } if (itpr.More()) { - Handle(BRep_PointRepresentation)& pr = itpr.Value(); + Handle(BRep_PointRepresentation) pr = itpr.Value(); pr->Parameter(p); } else { @@ -404,7 +404,7 @@ static void UpdatePoints(BRep_ListOfPointRepresentation& lpr, } if (itpr.More()) { - Handle(BRep_PointRepresentation)& pr = itpr.Value(); + Handle(BRep_PointRepresentation) pr = itpr.Value(); pr->Parameter(p); } else { @@ -430,7 +430,7 @@ static void UpdatePoints(BRep_ListOfPointRepresentation& lpr, } if (itpr.More()) { - Handle(BRep_PointRepresentation)& pr = itpr.Value(); + Handle(BRep_PointRepresentation) pr = itpr.Value(); pr->Parameter(p1); // pr->Parameter(p2); // skv pr->Parameter2(p2); // skv diff --git a/src/BRep/BRep_Tool.cxx b/src/BRep/BRep_Tool.cxx index f4d4c59df4..57b95f7ef0 100644 --- a/src/BRep/BRep_Tool.cxx +++ b/src/BRep/BRep_Tool.cxx @@ -1053,7 +1053,7 @@ void BRep_Tool::SetUVPoints(const TopoDS_Edge& E, BRep_ListIteratorOfListOfCurveRepresentation itcr(TE->Curves()); while (itcr.More()) { - Handle(BRep_CurveRepresentation)& cr = itcr.Value(); + Handle(BRep_CurveRepresentation) cr = itcr.Value(); if (cr->IsCurveOnSurface(S,l)) { if (cr->IsCurveOnClosedSurface() && Eisreversed) { diff --git a/src/BRepAlgo/BRepAlgo_FaceRestrictor.cxx b/src/BRepAlgo/BRepAlgo_FaceRestrictor.cxx index 5ed2ab2e70..05c849b353 100644 --- a/src/BRepAlgo/BRepAlgo_FaceRestrictor.cxx +++ b/src/BRepAlgo/BRepAlgo_FaceRestrictor.cxx @@ -384,7 +384,7 @@ void BRepAlgo_FaceRestrictor::PerformWithCorrection() // Reorientation of all closed wires to the left. //--------------------------------------------------------- for (; it.More(); it.Next()) { - TopoDS_Wire& W = TopoDS::Wire(it.Value()); + TopoDS_Wire& W = TopoDS::Wire(it.ChangeValue()); TopoDS_Shape aLocalShape = myFace.EmptyCopied(); TopoDS_Face NF = TopoDS::Face(aLocalShape); // TopoDS_Face NF = TopoDS::Face(myFace.EmptyCopied()); @@ -402,7 +402,7 @@ void BRepAlgo_FaceRestrictor::PerformWithCorrection() // Classification of wires ones compared to the others. //--------------------------------------------------------- for (it.Initialize(wires) ; it.More(); it.Next()) { - TopoDS_Wire& W1 = TopoDS::Wire(it.Value()); + const TopoDS_Wire& W1 = TopoDS::Wire(it.Value()); TopTools_ListIteratorOfListOfShape it2(wires); if (IsClosed(W1)) { diff --git a/src/BRepAlgo/BRepAlgo_Loop.cxx b/src/BRepAlgo/BRepAlgo_Loop.cxx index 828e9f091e..259da53f1d 100644 --- a/src/BRepAlgo/BRepAlgo_Loop.cxx +++ b/src/BRepAlgo/BRepAlgo_Loop.cxx @@ -572,7 +572,7 @@ void BRepAlgo_Loop::Perform() if (pLCE) { for (itl1.Initialize(*pLCE); itl1.More(); itl1.Next()) { - TopoDS_Edge& E = TopoDS::Edge(itl1.Value()); + TopoDS_Edge& E = TopoDS::Edge(itl1.ChangeValue()); if (!Emap.Add(E)) continue; StoreInMVE(myFace,E,MVE,YaCouture,myVerticesForSubstitute, myTolConf); @@ -585,7 +585,7 @@ void BRepAlgo_Loop::Perform() // => call only once StoreInMVE which should double them TopTools_MapOfShape DejaVu; for (itl.Initialize(myConstEdges); itl.More(); itl.Next()) { - TopoDS_Edge& E = TopoDS::Edge(itl.Value()); + TopoDS_Edge& E = TopoDS::Edge(itl.ChangeValue()); if (DejaVu.Add(E)) StoreInMVE(myFace,E,MVE,YaCouture,myVerticesForSubstitute, myTolConf); } @@ -900,7 +900,7 @@ void BRepAlgo_Loop::WiresToFaces() // Standard_False); TopTools_ListIteratorOfListOfShape it(myNewWires); for (; it.More(); it.Next()) { - FR.Add(TopoDS::Wire(it.Value())); + FR.Add(TopoDS::Wire(it.ChangeValue())); } FR.Perform(); diff --git a/src/BRepApprox/BRepApprox_TheMultiLineOfApprox.hxx b/src/BRepApprox/BRepApprox_TheMultiLineOfApprox.hxx index a8d89f4fb3..1a6fce3bb3 100644 --- a/src/BRepApprox/BRepApprox_TheMultiLineOfApprox.hxx +++ b/src/BRepApprox/BRepApprox_TheMultiLineOfApprox.hxx @@ -21,7 +21,6 @@ #include #include -#include #include #include #include diff --git a/src/BRepBlend/BRepBlend_AppFuncRoot.hxx b/src/BRepBlend/BRepBlend_AppFuncRoot.hxx index ed1c6bd4eb..abefca5b62 100644 --- a/src/BRepBlend/BRepBlend_AppFuncRoot.hxx +++ b/src/BRepBlend/BRepBlend_AppFuncRoot.hxx @@ -20,7 +20,6 @@ #include #include -#include #include #include #include diff --git a/src/BRepBuilderAPI/BRepBuilderAPI_MakeShapeOnMesh.cxx b/src/BRepBuilderAPI/BRepBuilderAPI_MakeShapeOnMesh.cxx index 8f919bfa6e..6e0cb4d822 100644 --- a/src/BRepBuilderAPI/BRepBuilderAPI_MakeShapeOnMesh.cxx +++ b/src/BRepBuilderAPI/BRepBuilderAPI_MakeShapeOnMesh.cxx @@ -22,6 +22,7 @@ #include #include #include +#include namespace { @@ -47,32 +48,30 @@ namespace return Standard_False; } + bool operator==(const Edge& theOther) const + { + return theOther.Idx1 == Idx1 && theOther.Idx2 == Idx2; + } + //! First index. It is lower or equal than the second. Standard_Integer Idx1; //! Second index. Standard_Integer Idx2; }; +} - //! Hasher of Edge structure. - struct EdgeHasher +namespace std +{ + template <> + struct hash { - - //! Returns hash code for the given edge. - static Standard_Integer HashCode(const Edge& theEdge, - const Standard_Integer theUpperBound) + size_t operator()(const Edge& theEdge) const noexcept { - // Circle-based collisions. - return ::HashCode(theEdge.Idx1 * theEdge.Idx1 + theEdge.Idx2 * theEdge.Idx2, theUpperBound); + // Combine two int values into a single hash value. + int aCombination[2]{ theEdge.Idx1, theEdge.Idx2 }; + return opencascade::hashBytes(aCombination, sizeof(aCombination)); } - - //! Returns true if two edges are equal. - static Standard_Boolean IsEqual(const Edge& theEdge1, - const Edge& theEdge2) - { - return theEdge1.Idx1 == theEdge2.Idx1 && theEdge1.Idx2 == theEdge2.Idx2; - } - }; } @@ -115,7 +114,7 @@ void BRepBuilderAPI_MakeShapeOnMesh::Build(const Message_ProgressRange& theRange } // Build shared edges. - NCollection_IndexedDataMap anEdgeToTEgeMap; + NCollection_IndexedDataMap anEdgeToTEgeMap; for (Standard_Integer i = 1; i <= aNbTriangles; ++i) { aPS.Next(); diff --git a/src/BRepCheck/BRepCheck_Face.cxx b/src/BRepCheck/BRepCheck_Face.cxx index b05003f42f..5e6dbd836d 100644 --- a/src/BRepCheck/BRepCheck_Face.cxx +++ b/src/BRepCheck/BRepCheck_Face.cxx @@ -50,14 +50,13 @@ #include #include #include -#include #include IMPLEMENT_STANDARD_RTTIEXT(BRepCheck_Face,BRepCheck_Result) //#include //#include -typedef NCollection_DataMap DataMapOfShapeBox2d; +typedef NCollection_DataMap DataMapOfShapeBox2d; static Standard_Boolean Intersect(const TopoDS_Wire&, const TopoDS_Wire&, diff --git a/src/BRepCheck/BRepCheck_IndexedDataMapOfShapeResult.hxx b/src/BRepCheck/BRepCheck_IndexedDataMapOfShapeResult.hxx index 3d0183689f..8caadefa25 100644 --- a/src/BRepCheck/BRepCheck_IndexedDataMapOfShapeResult.hxx +++ b/src/BRepCheck/BRepCheck_IndexedDataMapOfShapeResult.hxx @@ -19,10 +19,9 @@ #include #include -#include #include -typedef NCollection_IndexedDataMap BRepCheck_IndexedDataMapOfShapeResult; +typedef NCollection_IndexedDataMap BRepCheck_IndexedDataMapOfShapeResult; #endif diff --git a/src/BRepCheck/BRepCheck_Shell.cxx b/src/BRepCheck/BRepCheck_Shell.cxx index d94e5226ad..1b9850abec 100644 --- a/src/BRepCheck/BRepCheck_Shell.cxx +++ b/src/BRepCheck/BRepCheck_Shell.cxx @@ -82,9 +82,9 @@ Standard_EXPORT Standard_Integer BRepCheck_Trace(const Standard_Integer phase) { return BRC_Trace; } -void PrintShape(const TopoDS_Shape& theShape, const Standard_Integer upper) { +void PrintShape(const TopoDS_Shape& theShape) { if (!theShape.IsNull()) { - Standard_Integer code = theShape.HashCode(upper); + size_t code = TopTools_ShapeMapHasher{}(theShape); std::cout << TopAbs::ShapeTypeToString (theShape.ShapeType()) << " : " << code << " " << TopAbs::ShapeOrientationToString(theShape.Orientation()) << std::endl; } diff --git a/src/BRepClass3d/BRepClass3d_MapOfInter.hxx b/src/BRepClass3d/BRepClass3d_MapOfInter.hxx index 26658ba4f6..43ae234236 100644 --- a/src/BRepClass3d/BRepClass3d_MapOfInter.hxx +++ b/src/BRepClass3d/BRepClass3d_MapOfInter.hxx @@ -18,7 +18,6 @@ #define BRepClass3d_MapOfInter_HeaderFile #include -#include #include #include diff --git a/src/BRepFill/BRepFill_DataMapOfNodeDataMapOfShapeShape.hxx b/src/BRepFill/BRepFill_DataMapOfNodeDataMapOfShapeShape.hxx index 1b6ce78b76..b6c63f82ba 100644 --- a/src/BRepFill/BRepFill_DataMapOfNodeDataMapOfShapeShape.hxx +++ b/src/BRepFill/BRepFill_DataMapOfNodeDataMapOfShapeShape.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap BRepFill_DataMapOfNodeDataMapOfShapeShape; -typedef NCollection_DataMap::Iterator BRepFill_DataMapIteratorOfDataMapOfNodeDataMapOfShapeShape; +typedef NCollection_DataMap BRepFill_DataMapOfNodeDataMapOfShapeShape; +typedef NCollection_DataMap::Iterator BRepFill_DataMapIteratorOfDataMapOfNodeDataMapOfShapeShape; #endif diff --git a/src/BRepFill/BRepFill_DataMapOfNodeShape.hxx b/src/BRepFill/BRepFill_DataMapOfNodeShape.hxx index de9e30a89d..726165b769 100644 --- a/src/BRepFill/BRepFill_DataMapOfNodeShape.hxx +++ b/src/BRepFill/BRepFill_DataMapOfNodeShape.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap BRepFill_DataMapOfNodeShape; -typedef NCollection_DataMap::Iterator BRepFill_DataMapIteratorOfDataMapOfNodeShape; +typedef NCollection_DataMap BRepFill_DataMapOfNodeShape; +typedef NCollection_DataMap::Iterator BRepFill_DataMapIteratorOfDataMapOfNodeShape; #endif diff --git a/src/BRepFill/BRepFill_DataMapOfOrientedShapeListOfShape.hxx b/src/BRepFill/BRepFill_DataMapOfOrientedShapeListOfShape.hxx index d5081a77f9..fc02ce704a 100644 --- a/src/BRepFill/BRepFill_DataMapOfOrientedShapeListOfShape.hxx +++ b/src/BRepFill/BRepFill_DataMapOfOrientedShapeListOfShape.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap BRepFill_DataMapOfOrientedShapeListOfShape; -typedef NCollection_DataMap::Iterator BRepFill_DataMapIteratorOfDataMapOfOrientedShapeListOfShape; +typedef NCollection_DataMap BRepFill_DataMapOfOrientedShapeListOfShape; +typedef NCollection_DataMap::Iterator BRepFill_DataMapIteratorOfDataMapOfOrientedShapeListOfShape; #endif diff --git a/src/BRepFill/BRepFill_Evolved.cxx b/src/BRepFill/BRepFill_Evolved.cxx index 76f7c96aa2..43ec222fe2 100644 --- a/src/BRepFill/BRepFill_Evolved.cxx +++ b/src/BRepFill/BRepFill_Evolved.cxx @@ -1953,7 +1953,7 @@ void BRepFill_Evolved::Transfert( BRepFill_Evolved& Vevo, TopTools_ListIteratorOfListOfShape itl; for (itl.Initialize(GenShapes); itl.More(); itl.Next()) { - itl.Value().Move(LS); + itl.ChangeValue().Move(LS); } if (!myMap.IsBound(InitialSpine)) { diff --git a/src/BRepFill/BRepFill_IndexedDataMapOfOrientedShapeListOfShape.hxx b/src/BRepFill/BRepFill_IndexedDataMapOfOrientedShapeListOfShape.hxx index b1b46e3714..1c57f67b76 100644 --- a/src/BRepFill/BRepFill_IndexedDataMapOfOrientedShapeListOfShape.hxx +++ b/src/BRepFill/BRepFill_IndexedDataMapOfOrientedShapeListOfShape.hxx @@ -19,10 +19,9 @@ #include #include -#include #include -typedef NCollection_IndexedDataMap BRepFill_IndexedDataMapOfOrientedShapeListOfShape; +typedef NCollection_IndexedDataMap BRepFill_IndexedDataMapOfOrientedShapeListOfShape; #endif diff --git a/src/BRepFill/BRepFill_OffsetWire.cxx b/src/BRepFill/BRepFill_OffsetWire.cxx index 6db9e9df4d..befe34193c 100644 --- a/src/BRepFill/BRepFill_OffsetWire.cxx +++ b/src/BRepFill/BRepFill_OffsetWire.cxx @@ -1068,8 +1068,8 @@ void BRepFill_OffsetWire::PerformWithBiLo { const TopTools_ListOfShape& listSh = aSubst.Copy(itl.Value()); TopAbs_Orientation SaveOr = itl.Value().Orientation(); - itl.Value() = listSh.First(); - itl.Value().Orientation(SaveOr); + itl.ChangeValue() = listSh.First(); + itl.ChangeValue().Orientation(SaveOr); } } } diff --git a/src/BRepFill/BRepFill_Sweep.cxx b/src/BRepFill/BRepFill_Sweep.cxx index f275ec69b1..bcefa9df55 100644 --- a/src/BRepFill/BRepFill_Sweep.cxx +++ b/src/BRepFill/BRepFill_Sweep.cxx @@ -238,7 +238,7 @@ static Handle(Geom2d_Curve) Couture(const TopoDS_Edge& E, ((*((Handle(BRep_TEdge)*)&E.TShape()))->ChangeCurves()); while (itcr.More()) { - Handle(BRep_CurveRepresentation)& cr = itcr.Value(); + Handle(BRep_CurveRepresentation) cr = itcr.Value(); if (cr->IsCurveOnSurface(S,l)) { Handle(BRep_GCurve) GC (Handle(BRep_GCurve)::DownCast (cr)); if (GC->IsCurveOnClosedSurface() && Eisreversed) diff --git a/src/BRepGProp/BRepGProp_Gauss.hxx b/src/BRepGProp/BRepGProp_Gauss.hxx index 825b15f00e..aeff51845c 100644 --- a/src/BRepGProp/BRepGProp_Gauss.hxx +++ b/src/BRepGProp/BRepGProp_Gauss.hxx @@ -17,7 +17,8 @@ #include #include -class math_Vector; +template class math_VectorBase; +using math_Vector = math_VectorBase; //! Class performs computing of the global inertia properties //! of geometric object in 3D space by adaptive and non-adaptive diff --git a/src/BRepGProp/BRepGProp_VinertGK.hxx b/src/BRepGProp/BRepGProp_VinertGK.hxx index 1593ace13b..c37dae4a8e 100644 --- a/src/BRepGProp/BRepGProp_VinertGK.hxx +++ b/src/BRepGProp/BRepGProp_VinertGK.hxx @@ -20,7 +20,6 @@ #include #include -#include class BRepGProp_Face; class BRepGProp_Domain; class gp_Pln; diff --git a/src/BRepLib/BRepLib.cxx b/src/BRepLib/BRepLib.cxx index 2466e5dab3..e5f5e002cb 100644 --- a/src/BRepLib/BRepLib.cxx +++ b/src/BRepLib/BRepLib.cxx @@ -74,6 +74,7 @@ #include #include #include +#include #include @@ -2235,7 +2236,6 @@ static void EncodeRegularity(const TopoDS_Shape& theShape, TopTools_ListIteratorOfListOfShape It; TopExp_Explorer Ex; TopoDS_Face F1,F2; - Standard_Boolean found; for (Standard_Integer i = 1; i <= M.Extent(); i++){ TopoDS_Edge E = TopoDS::Edge(M.FindKey(i)); if (!theEdgesToEncode.IsEmpty()) @@ -2247,7 +2247,7 @@ static void EncodeRegularity(const TopoDS_Shape& theShape, continue; } - found = Standard_False; + Standard_Boolean found = Standard_False; F1.Nullify(); for (It.Initialize(M.FindFromIndex(i)); It.More() && !found; It.Next()){ if (F1.IsNull()) { F1 = TopoDS::Face(It.Value()); } @@ -2511,12 +2511,6 @@ namespace Node[1] = theNode2; } - //! Computes a hash code for the this link - Standard_Integer HashCode (const Standard_Integer theUpperBound) const - { - return ::HashCode (Node[0] + Node[1], theUpperBound); - } - //! Returns true if this link has the same nodes as the other. Standard_Boolean IsEqual (const Link& theOther) const { @@ -2530,12 +2524,23 @@ namespace return IsEqual (theOther); } }; +} - //! Computes a hash code for the given link - inline Standard_Integer HashCode (const Link& theLink, const Standard_Integer theUpperBound) +namespace std +{ + template <> + struct hash { - return theLink.HashCode (theUpperBound); - } + size_t operator()(const Link& theLink) const noexcept + { + int aCombination[2]{ theLink.Node[0], theLink.Node[1] }; + if (aCombination[0] > aCombination[1]) + { + std::swap(aCombination[0], aCombination[1]); + } + return opencascade::hashBytes(aCombination, sizeof(aCombination)); + } + }; } void BRepLib::UpdateDeflection (const TopoDS_Shape& theShape) @@ -2823,7 +2828,7 @@ void BRepLib::BoundingVertex(const NCollection_List& theLV, // of addition, thus sort the coordinates for stable result Standard_Integer i; NCollection_Array1 aPoints(0, aNb-1); - NCollection_List::Iterator aIt(theLV); + NCollection_List::Iterator aIt(theLV); for (i = 0; aIt.More(); aIt.Next(), ++i) { const TopoDS_Vertex& aVi = *((TopoDS_Vertex*)(&aIt.Value())); gp_Pnt aPi = BRep_Tool::Pnt(aVi); diff --git a/src/BRepLib/BRepLib_FuseEdges.cxx b/src/BRepLib/BRepLib_FuseEdges.cxx index a1b802143c..537c9c3181 100644 --- a/src/BRepLib/BRepLib_FuseEdges.cxx +++ b/src/BRepLib/BRepLib_FuseEdges.cxx @@ -1055,7 +1055,7 @@ Standard_Boolean BRepLib_FuseEdges::UpdatePCurve(const TopoDS_Edge& theOldEdge, iter.Next(); for (; iter.More(); iter.Next()) { - TopoDS_Edge& E = TopoDS::Edge(iter.Value()); + const TopoDS_Edge& E = TopoDS::Edge(iter.Value()); Standard_Real first, last; Handle(Geom2d_Curve) C = BRep_Tool::CurveOnSurface( E, Surf, loc, first, last ); Handle(Geom2d_BoundedCurve) BC = Handle(Geom2d_BoundedCurve)::DownCast(C); diff --git a/src/BRepLib/BRepLib_MakeWire_1.cxx b/src/BRepLib/BRepLib_MakeWire_1.cxx index 7e3f332ecb..e4ad89df93 100644 --- a/src/BRepLib/BRepLib_MakeWire_1.cxx +++ b/src/BRepLib/BRepLib_MakeWire_1.cxx @@ -379,7 +379,7 @@ void BRepLib_MakeWire::CreateNewListOfEdges(const TopTools_ListOfShape& theL, if (IsNewEdge) { TopoDS_Shape NewE = aCE.EmptyCopied(); - NCollection_List::Iterator it(aVList); + NCollection_List::Iterator it(aVList); for (; it.More(); it.Next()) aBB.Add(NewE, it.Value()); theNewEList.Append(TopoDS::Edge(NewE)); diff --git a/src/BRepMAT2d/BRepMAT2d_DataMapOfBasicEltShape.hxx b/src/BRepMAT2d/BRepMAT2d_DataMapOfBasicEltShape.hxx index 94cf836b59..0e2a8422b6 100644 --- a/src/BRepMAT2d/BRepMAT2d_DataMapOfBasicEltShape.hxx +++ b/src/BRepMAT2d/BRepMAT2d_DataMapOfBasicEltShape.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap BRepMAT2d_DataMapOfBasicEltShape; -typedef NCollection_DataMap::Iterator BRepMAT2d_DataMapIteratorOfDataMapOfBasicEltShape; +typedef NCollection_DataMap BRepMAT2d_DataMapOfBasicEltShape; +typedef NCollection_DataMap::Iterator BRepMAT2d_DataMapIteratorOfDataMapOfBasicEltShape; #endif diff --git a/src/BRepMesh/BRepMesh_Edge.hxx b/src/BRepMesh/BRepMesh_Edge.hxx index f0c50b9bf5..c574123755 100644 --- a/src/BRepMesh/BRepMesh_Edge.hxx +++ b/src/BRepMesh/BRepMesh_Edge.hxx @@ -17,6 +17,7 @@ #include #include #include +#include //! Light weighted structure representing link of the mesh. class BRepMesh_Edge : public BRepMesh_OrientedEdge @@ -84,13 +85,28 @@ private: BRepMesh_DegreeOfFreedom myMovability; }; -//! Computes a hash code for the given edge, in the range [1, theUpperBound] -//! @param theEdge the edge which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -inline Standard_Integer HashCode (const BRepMesh_Edge& theEdge, const Standard_Integer theUpperBound) +namespace std { - return theEdge.HashCode (theUpperBound); + template <> + struct hash + { + size_t operator()(const BRepMesh_Edge& theEdge) const noexcept + { + union Combination + { + unsigned short Arr[2]; // Node can be represented as a short + uint32_t Hash; + + } aCombination; + aCombination.Arr[0] = static_cast(theEdge.FirstNode()); + aCombination.Arr[1] = static_cast(theEdge.LastNode()); + if (aCombination.Arr[0] > aCombination.Arr[1]) + { + std::swap(aCombination.Arr[0], aCombination.Arr[1]); + } + return static_cast(aCombination.Hash); + } + }; } #endif diff --git a/src/BRepMesh/BRepMesh_OrientedEdge.hxx b/src/BRepMesh/BRepMesh_OrientedEdge.hxx index 0cc32b0707..bbe306d487 100644 --- a/src/BRepMesh/BRepMesh_OrientedEdge.hxx +++ b/src/BRepMesh/BRepMesh_OrientedEdge.hxx @@ -15,6 +15,7 @@ #define _BRepMesh_OrientedEdge_HeaderFile #include +#include #include //! Light weighted structure representing simple link. @@ -52,14 +53,6 @@ public: return myLastNode; } - //! Computes a hash code for this oriented edge, in the range [1, theUpperBound] - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - Standard_Integer HashCode (const Standard_Integer theUpperBound) const - { - return ::HashCode (myFirstNode + myLastNode, theUpperBound); - } - //! Checks this and other edge for equality. //! @param theOther edge to be checked against this one. //! @return TRUE if edges have the same orientation, FALSE if not. @@ -80,13 +73,24 @@ private: Standard_Integer myLastNode; }; -//! Computes a hash code for the given oriented edge, in the range [1, theUpperBound] -//! @param theOrientedEdge the oriented edge which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -inline Standard_Integer HashCode (const BRepMesh_OrientedEdge& theOrientedEdge, const Standard_Integer theUpperBound) +namespace std { - return theOrientedEdge.HashCode (theUpperBound); + template <> + struct hash + { + size_t operator()(const BRepMesh_OrientedEdge& theOrientedEdge) const noexcept + { + union Combination + { + unsigned short Arr[2]; // Node can be represented as a short + uint32_t Hash; + + } aCombination; + aCombination.Arr[0] = static_cast(theOrientedEdge.FirstNode()); + aCombination.Arr[1] = static_cast(theOrientedEdge.LastNode()); + return static_cast(aCombination.Hash); + } + }; } #endif diff --git a/src/BRepMesh/BRepMesh_Triangle.hxx b/src/BRepMesh/BRepMesh_Triangle.hxx index abc61fd367..fefdd456c5 100644 --- a/src/BRepMesh/BRepMesh_Triangle.hxx +++ b/src/BRepMesh/BRepMesh_Triangle.hxx @@ -19,6 +19,7 @@ #include #include +#include #include @@ -91,14 +92,6 @@ public: myMovability = theMovability; } - //! Computes a hash code for this triangle, in the range [1, theUpperBound] - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - Standard_Integer HashCode (const Standard_Integer theUpperBound) const - { - return ::HashCode (myEdges[0] + myEdges[1] + myEdges[2], theUpperBound); - } - //! Checks for equality with another triangle. //! @param theOther triangle to be checked against this one. //! @return TRUE if equal, FALSE if not. @@ -142,13 +135,18 @@ public: BRepMesh_DegreeOfFreedom myMovability; }; -//! Computes a hash code for the given triangle, in the range [1, theUpperBound] -//! @param theTriangle the triangle which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -inline Standard_Integer HashCode (const BRepMesh_Triangle& theTriangle, const Standard_Integer theUpperBound) +namespace std { - return theTriangle.HashCode (theUpperBound); + template <> + struct hash + { + size_t operator()(const BRepMesh_Triangle& theTriangle) const noexcept + { + int aCombination[3] = { theTriangle.myEdges[0], theTriangle.myEdges[1], theTriangle.myEdges[2] }; + std::sort(aCombination, aCombination + 3); // Sort the numbers in ascending order + return opencascade::hashBytes(aCombination, sizeof(aCombination)); + } + }; } #endif diff --git a/src/BRepMesh/BRepMesh_Vertex.hxx b/src/BRepMesh/BRepMesh_Vertex.hxx index b991817a84..838dd3ebcd 100644 --- a/src/BRepMesh/BRepMesh_Vertex.hxx +++ b/src/BRepMesh/BRepMesh_Vertex.hxx @@ -102,14 +102,6 @@ public: { myMovability = theMovability; } - - //! Computes a hash code for this vertex, in the range [1, theUpperBound] - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - Standard_Integer HashCode(const Standard_Integer theUpperBound) const - { - return ::HashCode(Floor(1e5 * myUV.X()) * Floor(1e5 * myUV.Y()), theUpperBound); - } //! Checks for equality with another vertex. //! @param theOther vertex to be checked against this one. @@ -138,13 +130,16 @@ private: BRepMesh_DegreeOfFreedom myMovability; }; -//! Computes a hash code for the given vertex, in the range [1, theUpperBound] -//! @param theVertex the vertex which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -inline Standard_Integer HashCode (const BRepMesh_Vertex& theVertex, const Standard_Integer theUpperBound) +namespace std { - return theVertex.HashCode (theUpperBound); + template <> + struct hash + { + size_t operator()(const BRepMesh_Vertex& theVertex) const noexcept + { + return std::hash{}((Floor(1e5 * theVertex.Coord().X()) * Floor(1e5 * theVertex.Coord().Y()))); + } + }; } #endif diff --git a/src/BRepMeshData/BRepMeshData_Curve.cxx b/src/BRepMeshData/BRepMeshData_Curve.cxx index a1daaf3af7..e11da7a380 100644 --- a/src/BRepMeshData/BRepMeshData_Curve.cxx +++ b/src/BRepMeshData/BRepMeshData_Curve.cxx @@ -24,8 +24,8 @@ IMPLEMENT_STANDARD_RTTIEXT(BRepMeshData_Curve, IMeshData_Curve) // Purpose : //======================================================================= BRepMeshData_Curve::BRepMeshData_Curve (const Handle (NCollection_IncAllocator)& theAllocator) -: myPoints (NCollection_StdAllocator(theAllocator)), - myParameters (NCollection_StdAllocator(theAllocator)) +: myPoints (NCollection_OccAllocator(theAllocator)), + myParameters (NCollection_OccAllocator(theAllocator)) { } diff --git a/src/BRepMeshData/BRepMeshData_Model.cxx b/src/BRepMeshData/BRepMeshData_Model.cxx index 1731c174e2..260cfbdc1f 100644 --- a/src/BRepMeshData/BRepMeshData_Model.cxx +++ b/src/BRepMeshData/BRepMeshData_Model.cxx @@ -32,7 +32,7 @@ BRepMeshData_Model::BRepMeshData_Model (const TopoDS_Shape& theShape) myDFaces (256, myAllocator), myDEdges (256, myAllocator) { - myAllocator->SetThreadSafe(); + myAllocator->SetThreadSafe(true); } //======================================================================= @@ -59,8 +59,7 @@ Standard_Integer BRepMeshData_Model::FacesNb () const const IMeshData::IFaceHandle& BRepMeshData_Model::AddFace (const TopoDS_Face& theFace) { IMeshData::IFaceHandle aFace (new (myAllocator) BRepMeshData_Face (theFace, myAllocator)); - myDFaces.Append (aFace); - return myDFaces (FacesNb () - 1); + return myDFaces.Append (aFace); } //======================================================================= @@ -88,8 +87,7 @@ Standard_Integer BRepMeshData_Model::EdgesNb () const const IMeshData::IEdgeHandle& BRepMeshData_Model::AddEdge (const TopoDS_Edge& theEdge) { IMeshData::IEdgeHandle aEdge (new (myAllocator) BRepMeshData_Edge (theEdge, myAllocator)); - myDEdges.Append (aEdge); - return myDEdges (EdgesNb () - 1); + return myDEdges.Append (aEdge); } //======================================================================= diff --git a/src/BRepMeshData/BRepMeshData_PCurve.cxx b/src/BRepMeshData/BRepMeshData_PCurve.cxx index cff9950e9a..a3d32bab14 100644 --- a/src/BRepMeshData/BRepMeshData_PCurve.cxx +++ b/src/BRepMeshData/BRepMeshData_PCurve.cxx @@ -29,9 +29,9 @@ BRepMeshData_PCurve::BRepMeshData_PCurve ( const TopAbs_Orientation theOrientation, const Handle (NCollection_IncAllocator)& theAllocator) : IMeshData_PCurve (theDFace, theOrientation), - myPoints2d (NCollection_StdAllocator(theAllocator)), - myParameters (NCollection_StdAllocator(theAllocator)), - myIndices (NCollection_StdAllocator(theAllocator)) + myPoints2d (NCollection_OccAllocator(theAllocator)), + myParameters (NCollection_OccAllocator(theAllocator)), + myIndices (NCollection_OccAllocator(theAllocator)) { } diff --git a/src/BRepOffset/BRepOffset_MakeOffset.cxx b/src/BRepOffset/BRepOffset_MakeOffset.cxx index 5eccbe11f5..df326ec655 100644 --- a/src/BRepOffset/BRepOffset_MakeOffset.cxx +++ b/src/BRepOffset/BRepOffset_MakeOffset.cxx @@ -4720,7 +4720,7 @@ Standard_Boolean BuildShellsCompleteInter(const TopTools_ListOfShape& theLF, const TopoDS_Shape& aFR = aItLR.Value(); // Reset the local allocator - anAllocLoc->Reset(); + anAllocLoc->Reset(false); // Find the last splits of the root face, including the ones // created during MakeVolume operation TopTools_ListOfShape aLFIm(anAllocLoc); @@ -4739,7 +4739,7 @@ Standard_Boolean BuildShellsCompleteInter(const TopTools_ListOfShape& theLF, } // Reset the local allocator - anAllocLoc->Reset(); + anAllocLoc->Reset(false); // It is necessary to rebuild the solids, avoiding internal faces // Map faces to solids TopTools_IndexedDataMapOfShapeListOfShape aDMFS(1, anAllocLoc); @@ -4787,7 +4787,7 @@ Standard_Boolean BuildShellsCompleteInter(const TopTools_ListOfShape& theLF, // aLF.Clear(); aDMFS.Clear(); - anAllocLoc->Reset(); + anAllocLoc->Reset(true); // the result is non-manifold - resolve it comparing normal // directions of the offset faces and original faces @@ -4896,7 +4896,7 @@ const TopTools_ListOfShape& BRepOffset_MakeOffset::Generated (const TopoDS_Shape // Useful only for faces without influence on others. TopTools_ListIteratorOfListOfShape it(myGenerated); for (; it.More(); it.Next()) - it.Value().Reverse(); + it.ChangeValue().Reverse(); } } break; @@ -4951,7 +4951,7 @@ const TopTools_ListOfShape& BRepOffset_MakeOffset::Modified (const TopoDS_Shape& // Useful only for faces without influence on others. TopTools_ListIteratorOfListOfShape it(myGenerated); for (; it.More(); it.Next()) - it.Value().Reverse(); + it.ChangeValue().Reverse(); } } } diff --git a/src/BRepOffset/BRepOffset_SimpleOffset.hxx b/src/BRepOffset/BRepOffset_SimpleOffset.hxx index a5c46ba99d..a533faecbd 100644 --- a/src/BRepOffset/BRepOffset_SimpleOffset.hxx +++ b/src/BRepOffset/BRepOffset_SimpleOffset.hxx @@ -17,13 +17,16 @@ #define _BRepOffset_SimpleOffset_HeaderFile #include -#include #include -#include -#include -#include -#include +#include #include +#include +#include +#include +#include +#include +#include +#include class BRepOffset_SimpleOffset; diff --git a/src/BRepOffset/BRepOffset_Tool.cxx b/src/BRepOffset/BRepOffset_Tool.cxx index 55c7cd3597..45ce024999 100644 --- a/src/BRepOffset/BRepOffset_Tool.cxx +++ b/src/BRepOffset/BRepOffset_Tool.cxx @@ -4016,7 +4016,7 @@ void BRepOffset_Tool::CorrectOrientation(const TopoDS_Shape& SI, // BRepTopAdaptor_FClass2d FC (TopoDS::Face(FI.Oriented(TopAbs_FORWARD)), // Precision::Confusion()); for (itE.Initialize(LOE); itE.More(); itE.Next()) { - TopoDS_Shape& OE = itE.Value(); + TopoDS_Shape& OE = itE.ChangeValue(); if (NewEdges.Contains(OE)) { Handle(Geom2d_Curve) CO2d = BRep_Tool::CurveOnSurface(TopoDS::Edge(OE),OF,f,l); diff --git a/src/BRepOffsetAPI/BRepOffsetAPI_MakeOffset.cxx b/src/BRepOffsetAPI/BRepOffsetAPI_MakeOffset.cxx index 806ae4aa71..9688969ada 100644 --- a/src/BRepOffsetAPI/BRepOffsetAPI_MakeOffset.cxx +++ b/src/BRepOffsetAPI/BRepOffsetAPI_MakeOffset.cxx @@ -235,7 +235,7 @@ static void BuildDomains(TopoDS_Face& myFace, //==================================================== TopTools_ListIteratorOfListOfShape itl(WorkWires); for (; itl.More(); itl.Next()) { - TopoDS_Wire& W = TopoDS::Wire(itl.Value()); + TopoDS_Wire& W = TopoDS::Wire(itl.ChangeValue()); if (W.Closed()){ FR.Add(W); continue; @@ -291,7 +291,7 @@ static void BuildDomains(TopoDS_Face& myFace, // for (TopTools_ListIteratorOfListOfShape itF(Faces); itF.More(); itF.Next()) { TopTools_ListIteratorOfListOfShape itF; for (itF.Initialize(Faces) ; itF.More(); itF.Next()) { - TopoDS_Face& F = TopoDS::Face(itF.Value()); + TopoDS_Face& F = TopoDS::Face(itF.ChangeValue()); BRepAdaptor_Surface S(F,0); Standard_Real Tol = BRep_Tool::Tolerance(F); @@ -299,7 +299,7 @@ static void BuildDomains(TopoDS_Face& myFace, TopTools_ListIteratorOfListOfShape itW(LOW); while (itW.More()) { - TopoDS_Wire& W = TopoDS::Wire(itW.Value()); + const TopoDS_Wire& W = TopoDS::Wire(itW.Value()); //======================================================= // Choice of a point on the wire. + projection on the face. //======================================================= @@ -409,7 +409,7 @@ void BRepOffsetAPI_MakeOffset::Perform(const Standard_Real Offset, for (itOW.Initialize(myLeft); itOW.More(); itOW.Next()) { - BRepFill_OffsetWire& Algo = itOW.Value(); + BRepFill_OffsetWire& Algo = itOW.ChangeValue(); Algo.Perform(Abs(Offset),Alt); if (Algo.IsDone() && !Algo.Shape().IsNull()) { @@ -432,7 +432,7 @@ void BRepOffsetAPI_MakeOffset::Perform(const Standard_Real Offset, for(itOW.Initialize(myRight); itOW.More(); itOW.Next()) { - BRepFill_OffsetWire& Algo = itOW.Value(); + BRepFill_OffsetWire& Algo = itOW.ChangeValue(); Algo.Perform(Offset,Alt); if (Algo.IsDone() && !Algo.Shape().IsNull()) @@ -494,7 +494,7 @@ const TopTools_ListOfShape& BRepOffsetAPI_MakeOffset::Generated Algos = &myRight; } for (itOW.Initialize(*Algos); itOW.More(); itOW.Next()) { - BRepFill_OffsetWire& OW = itOW.Value(); + BRepFill_OffsetWire& OW = itOW.ChangeValue(); TopTools_ListOfShape L; L = OW.GeneratedShapes(S.Oriented(TopAbs_FORWARD)); myGenerated.Append(L); diff --git a/src/BRepOffsetAPI/BRepOffsetAPI_MakeThickSolid.cxx b/src/BRepOffsetAPI/BRepOffsetAPI_MakeThickSolid.cxx index bf8547da4f..47bf68c960 100644 --- a/src/BRepOffsetAPI/BRepOffsetAPI_MakeThickSolid.cxx +++ b/src/BRepOffsetAPI/BRepOffsetAPI_MakeThickSolid.cxx @@ -109,7 +109,7 @@ const TopTools_ListOfShape& BRepOffsetAPI_MakeThickSolid::Modified (const TopoDS // Useful only for faces without influence on others. TopTools_ListIteratorOfListOfShape it(myGenerated); for (; it.More(); it.Next()) - it.Value().Reverse(); + it.ChangeValue().Reverse(); } } else if (myLastUsedAlgo == OffsetAlgo_SIMPLE) diff --git a/src/BRepPrimAPI/BRepPrimAPI_MakeRevolution.hxx b/src/BRepPrimAPI/BRepPrimAPI_MakeRevolution.hxx index 3a3f1c0293..9bb891f3a1 100644 --- a/src/BRepPrimAPI/BRepPrimAPI_MakeRevolution.hxx +++ b/src/BRepPrimAPI/BRepPrimAPI_MakeRevolution.hxx @@ -23,7 +23,6 @@ #include #include -#include class Geom_Curve; class gp_Ax2; diff --git a/src/BSplCLib/BSplCLib.cxx b/src/BSplCLib/BSplCLib.cxx index 6a2aa5f112..1414f5008b 100644 --- a/src/BSplCLib/BSplCLib.cxx +++ b/src/BSplCLib/BSplCLib.cxx @@ -35,6 +35,7 @@ #include #include #include +#include typedef gp_Pnt Pnt; typedef gp_Vec Vec; diff --git a/src/BinMDF/BinMDF_TypeADriverMap.hxx b/src/BinMDF/BinMDF_TypeADriverMap.hxx index 5475891c75..17ef5b19f0 100644 --- a/src/BinMDF/BinMDF_TypeADriverMap.hxx +++ b/src/BinMDF/BinMDF_TypeADriverMap.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DataMap BinMDF_TypeADriverMap; -typedef NCollection_DataMap::Iterator BinMDF_DataMapIteratorOfTypeADriverMap; +typedef NCollection_DataMap BinMDF_TypeADriverMap; +typedef NCollection_DataMap::Iterator BinMDF_DataMapIteratorOfTypeADriverMap; #endif diff --git a/src/BinMDF/BinMDF_TypeIdMap.hxx b/src/BinMDF/BinMDF_TypeIdMap.hxx index fac8d35e8d..4566c2092f 100644 --- a/src/BinMDF/BinMDF_TypeIdMap.hxx +++ b/src/BinMDF/BinMDF_TypeIdMap.hxx @@ -18,12 +18,10 @@ #include #include -#include -#include #include -typedef NCollection_DoubleMap BinMDF_TypeIdMap; -typedef NCollection_DoubleMap::Iterator BinMDF_DoubleMapIteratorOfTypeIdMap; +typedef NCollection_DoubleMap BinMDF_TypeIdMap; +typedef NCollection_DoubleMap::Iterator BinMDF_DoubleMapIteratorOfTypeIdMap; #endif diff --git a/src/BinMNaming/BinMNaming_NamedShapeDriver.cxx b/src/BinMNaming/BinMNaming_NamedShapeDriver.cxx index 1ee3e46d0b..a694a8341e 100644 --- a/src/BinMNaming/BinMNaming_NamedShapeDriver.cxx +++ b/src/BinMNaming/BinMNaming_NamedShapeDriver.cxx @@ -276,7 +276,6 @@ void BinMNaming_NamedShapeDriver::Paste (const Handle(TDF_Attribute)& theSource, if (myIsQuickPart) // enables direct writing of shapes to the stream aDirectStream = theTarget.GetOStream(); - Standard_Integer i = 1; for (TNaming_Iterator SIterator(aSAtt); SIterator.More(); SIterator.Next()) { const TopoDS_Shape& anOldShape = SIterator.OldShape(); const TopoDS_Shape& aNewShape = SIterator.NewShape(); @@ -296,8 +295,6 @@ void BinMNaming_NamedShapeDriver::Paste (const Handle(TDF_Attribute)& theSource, else TranslateTo (aNewShape, theTarget, static_cast(aShapeSet)); } - - i++; } } diff --git a/src/BinObjMgt/BinObjMgt_Persistent.hxx b/src/BinObjMgt/BinObjMgt_Persistent.hxx index 13331a1167..de21ea124f 100644 --- a/src/BinObjMgt/BinObjMgt_Persistent.hxx +++ b/src/BinObjMgt/BinObjMgt_Persistent.hxx @@ -32,7 +32,6 @@ #include #include #include -#include class TCollection_AsciiString; class TCollection_ExtendedString; class TDF_Label; diff --git a/src/BinTObjDrivers/BinTObjDrivers.hxx b/src/BinTObjDrivers/BinTObjDrivers.hxx index db1c7383f1..7fa8d9e78d 100644 --- a/src/BinTObjDrivers/BinTObjDrivers.hxx +++ b/src/BinTObjDrivers/BinTObjDrivers.hxx @@ -18,7 +18,6 @@ #ifndef BinTObjDrivers_HeaderFile #define BinTObjDrivers_HeaderFile -#include #include class BinMDF_ADriverTable; diff --git a/src/BinTObjDrivers/BinTObjDrivers_DocumentRetrievalDriver.hxx b/src/BinTObjDrivers/BinTObjDrivers_DocumentRetrievalDriver.hxx index ced6199898..278f4e5030 100644 --- a/src/BinTObjDrivers/BinTObjDrivers_DocumentRetrievalDriver.hxx +++ b/src/BinTObjDrivers/BinTObjDrivers_DocumentRetrievalDriver.hxx @@ -18,7 +18,6 @@ #ifndef BinTObjDrivers_DocumentRetrievalDriver_HeaderFile #define BinTObjDrivers_DocumentRetrievalDriver_HeaderFile -#include #include #include diff --git a/src/BinTObjDrivers/BinTObjDrivers_DocumentStorageDriver.hxx b/src/BinTObjDrivers/BinTObjDrivers_DocumentStorageDriver.hxx index 8627329665..3c9ad0bfa8 100644 --- a/src/BinTObjDrivers/BinTObjDrivers_DocumentStorageDriver.hxx +++ b/src/BinTObjDrivers/BinTObjDrivers_DocumentStorageDriver.hxx @@ -18,7 +18,6 @@ #ifndef BinTObjDrivers_DocumentStorageDriver_HeaderFile #define BinTObjDrivers_DocumentStorageDriver_HeaderFile -#include #include #include diff --git a/src/BinTObjDrivers/BinTObjDrivers_IntSparseArrayDriver.hxx b/src/BinTObjDrivers/BinTObjDrivers_IntSparseArrayDriver.hxx index 64805a4d02..5d7027b85e 100644 --- a/src/BinTObjDrivers/BinTObjDrivers_IntSparseArrayDriver.hxx +++ b/src/BinTObjDrivers/BinTObjDrivers_IntSparseArrayDriver.hxx @@ -18,7 +18,6 @@ #ifndef BinTObjDrivers_IntSparseArrayDriver_HeaderFile #define BinTObjDrivers_IntSparseArrayDriver_HeaderFile -#include #include class BinTObjDrivers_IntSparseArrayDriver : public BinMDF_ADriver diff --git a/src/BinTObjDrivers/BinTObjDrivers_ModelDriver.hxx b/src/BinTObjDrivers/BinTObjDrivers_ModelDriver.hxx index fcb0c7ca03..ade93ebb0b 100644 --- a/src/BinTObjDrivers/BinTObjDrivers_ModelDriver.hxx +++ b/src/BinTObjDrivers/BinTObjDrivers_ModelDriver.hxx @@ -18,7 +18,6 @@ #ifndef BinTObjDrivers_ModelDriver_HeaderFile #define BinTObjDrivers_ModelDriver_HeaderFile -#include #include class BinTObjDrivers_ModelDriver : public BinMDF_ADriver diff --git a/src/BinTObjDrivers/BinTObjDrivers_ObjectDriver.hxx b/src/BinTObjDrivers/BinTObjDrivers_ObjectDriver.hxx index 07341da005..769a975e70 100644 --- a/src/BinTObjDrivers/BinTObjDrivers_ObjectDriver.hxx +++ b/src/BinTObjDrivers/BinTObjDrivers_ObjectDriver.hxx @@ -19,7 +19,6 @@ #ifndef BinTObjDrivers_ObjectDriver_HeaderFile #define BinTObjDrivers_ObjectDriver_HeaderFile -#include #include class BinTObjDrivers_ObjectDriver : public BinMDF_ADriver diff --git a/src/BinTObjDrivers/BinTObjDrivers_ReferenceDriver.hxx b/src/BinTObjDrivers/BinTObjDrivers_ReferenceDriver.hxx index a9dec24dec..c5f78ee063 100644 --- a/src/BinTObjDrivers/BinTObjDrivers_ReferenceDriver.hxx +++ b/src/BinTObjDrivers/BinTObjDrivers_ReferenceDriver.hxx @@ -19,7 +19,6 @@ #ifndef BinTObjDrivers_ReferenceDriver_HeaderFile #define BinTObjDrivers_ReferenceDriver_HeaderFile -#include #include class BinTObjDrivers_ReferenceDriver : public BinMDF_ADriver diff --git a/src/BinTObjDrivers/BinTObjDrivers_XYZDriver.hxx b/src/BinTObjDrivers/BinTObjDrivers_XYZDriver.hxx index 6e3c315d51..448ea58675 100644 --- a/src/BinTObjDrivers/BinTObjDrivers_XYZDriver.hxx +++ b/src/BinTObjDrivers/BinTObjDrivers_XYZDriver.hxx @@ -19,7 +19,6 @@ #ifndef BinTObjDrivers_XYZDriver_HeaderFile #define BinTObjDrivers_XYZDriver_HeaderFile -#include #include class BinTObjDrivers_XYZDriver : public BinMDF_ADriver diff --git a/src/BinTools/BinTools_ShapeReader.cxx b/src/BinTools/BinTools_ShapeReader.cxx index 336590f90e..8b8ed4dc91 100644 --- a/src/BinTools/BinTools_ShapeReader.cxx +++ b/src/BinTools/BinTools_ShapeReader.cxx @@ -12,14 +12,15 @@ // commercial license or contractual agreement. #include -#include + +#include +#include +#include +#include #include #include #include -#include -#include -#include -#include +#include //======================================================================= //function : BinTools_ShapeReader diff --git a/src/BinTools/BinTools_ShapeReader.hxx b/src/BinTools/BinTools_ShapeReader.hxx index 190d8a9084..baa44fa447 100644 --- a/src/BinTools/BinTools_ShapeReader.hxx +++ b/src/BinTools/BinTools_ShapeReader.hxx @@ -17,11 +17,12 @@ #include #include #include +#include +#include -class TopLoc_Location; class Geom_Curve; -class Geom2d_Curve; class Geom_Surface; +class Geom2d_Curve; class Poly_Polygon3D; class Poly_PolygonOnTriangulation; class Poly_Triangulation; diff --git a/src/BinTools/BinTools_ShapeSet.hxx b/src/BinTools/BinTools_ShapeSet.hxx index 83add9525c..dff48a8eac 100644 --- a/src/BinTools/BinTools_ShapeSet.hxx +++ b/src/BinTools/BinTools_ShapeSet.hxx @@ -183,12 +183,12 @@ private: BinTools_SurfaceSet mySurfaces; BinTools_CurveSet myCurves; BinTools_Curve2dSet myCurves2d; - NCollection_IndexedMap myPolygons2D; - NCollection_IndexedMap myPolygons3D; + NCollection_IndexedMap myPolygons2D; + NCollection_IndexedMap myPolygons3D; NCollection_IndexedDataMap myTriangulations; //!< Contains a boolean flag with information //! to save normals for triangulation - NCollection_IndexedMap myNodes; + NCollection_IndexedMap myNodes; }; #endif // _BinTools_ShapeSet_HeaderFile diff --git a/src/BinTools/BinTools_ShapeSetBase.hxx b/src/BinTools/BinTools_ShapeSetBase.hxx index 9782195bba..24adf243b3 100644 --- a/src/BinTools/BinTools_ShapeSetBase.hxx +++ b/src/BinTools/BinTools_ShapeSetBase.hxx @@ -29,12 +29,6 @@ class gp_Pnt; //! Writes to the stream a gp_Pnt data Standard_OStream& operator << (Standard_OStream& OS, const gp_Pnt& P); -//! Computes a hash code for the given value of the uint64_t type, in range [1, theUpperBound] -inline Standard_Integer HashCode (const uint64_t theValue, const Standard_Integer theUpperBound) -{ - return IntegerHashCode(theValue, 0xffffffffffffffff, theUpperBound); -} - //! A base class for all readers/writers of TopoDS_Shape into/from stream. class BinTools_ShapeSetBase { diff --git a/src/BinTools/BinTools_ShapeWriter.hxx b/src/BinTools/BinTools_ShapeWriter.hxx index f9dc241fa0..0daddae4e6 100644 --- a/src/BinTools/BinTools_ShapeWriter.hxx +++ b/src/BinTools/BinTools_ShapeWriter.hxx @@ -16,7 +16,7 @@ #include #include -#include +#include #include class Geom_Curve; diff --git a/src/Bnd/Bnd_BoundSortBox.hxx b/src/Bnd/Bnd_BoundSortBox.hxx index b83e4f5663..6db19f130e 100644 --- a/src/Bnd/Bnd_BoundSortBox.hxx +++ b/src/Bnd/Bnd_BoundSortBox.hxx @@ -26,7 +26,6 @@ #include #include #include -#include class gp_Pln; diff --git a/src/BndLib/BndLib_AddSurface.cxx b/src/BndLib/BndLib_AddSurface.cxx index b1ba162eac..a5c2c05cfe 100644 --- a/src/BndLib/BndLib_AddSurface.cxx +++ b/src/BndLib/BndLib_AddSurface.cxx @@ -720,7 +720,8 @@ public: myVMin(VMin), myVMax(VMax), myCoordIndx(CoordIndx), - mySign(Sign) + mySign(Sign), + myPenalty(0.) { math_Vector X(1,2); X(1) = UMin; diff --git a/src/CDF/CDF_FWOSDriver.cxx b/src/CDF/CDF_FWOSDriver.cxx index 2b28131c5d..3e5351d118 100644 --- a/src/CDF/CDF_FWOSDriver.cxx +++ b/src/CDF/CDF_FWOSDriver.cxx @@ -157,8 +157,6 @@ TCollection_ExtendedString CDF_FWOSDriver::Concatenate(const TCollection_Extende const TCollection_ExtendedString& aName) { TCollection_ExtendedString ff(aFolder); - ff = ""; - ff += aFolder; PutSlash(ff); ff+=aName; return ff; diff --git a/src/CDM/CDM_DocumentHasher.hxx b/src/CDM/CDM_DocumentHasher.hxx deleted file mode 100644 index bf0edcf76f..0000000000 --- a/src/CDM/CDM_DocumentHasher.hxx +++ /dev/null @@ -1,26 +0,0 @@ -// Created on: 1997-05-06 -// Created by: Jean-Louis Frenkel, Remi Lequette -// Copyright (c) 1997-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef CDM_DocumentHasher_HeaderFile -#define CDM_DocumentHasher_HeaderFile - -#include -#include - -typedef NCollection_DefaultHasher CDM_DocumentHasher; - - -#endif diff --git a/src/CDM/CDM_MapOfDocument.hxx b/src/CDM/CDM_MapOfDocument.hxx index 613ed2642d..d6fd8e4ab4 100644 --- a/src/CDM/CDM_MapOfDocument.hxx +++ b/src/CDM/CDM_MapOfDocument.hxx @@ -17,11 +17,11 @@ #ifndef CDM_MapOfDocument_HeaderFile #define CDM_MapOfDocument_HeaderFile -#include +#include #include -typedef NCollection_Map CDM_MapOfDocument; -typedef NCollection_Map::Iterator CDM_MapIteratorOfMapOfDocument; +typedef NCollection_Map CDM_MapOfDocument; +typedef NCollection_Map::Iterator CDM_MapIteratorOfMapOfDocument; #endif diff --git a/src/CDM/CDM_MetaDataLookUpTable.hxx b/src/CDM/CDM_MetaDataLookUpTable.hxx index b925bad765..2877b5852f 100644 --- a/src/CDM/CDM_MetaDataLookUpTable.hxx +++ b/src/CDM/CDM_MetaDataLookUpTable.hxx @@ -21,8 +21,8 @@ #include class CDM_MetaData; -typedef NCollection_DataMap CDM_MetaDataLookUpTable; -typedef NCollection_DataMap::Iterator CDM_DataMapIteratorOfMetaDataLookUpTable; +typedef NCollection_DataMap CDM_MetaDataLookUpTable; +typedef NCollection_DataMap::Iterator CDM_DataMapIteratorOfMetaDataLookUpTable; #endif diff --git a/src/CDM/FILES b/src/CDM/FILES index 769a0835b5..694470edb8 100644 --- a/src/CDM/FILES +++ b/src/CDM/FILES @@ -4,7 +4,6 @@ CDM_CanCloseStatus.hxx CDM_DataMapIteratorOfMetaDataLookUpTable.hxx CDM_Document.cxx CDM_Document.hxx -CDM_DocumentHasher.hxx CDM_DocumentPointer.hxx CDM_ListIteratorOfListOfDocument.hxx CDM_ListIteratorOfListOfReferences.hxx diff --git a/src/ChFi3d/ChFi3d_Builder.cxx b/src/ChFi3d/ChFi3d_Builder.cxx index f418482696..3159d94e5f 100644 --- a/src/ChFi3d/ChFi3d_Builder.cxx +++ b/src/ChFi3d/ChFi3d_Builder.cxx @@ -236,7 +236,7 @@ void ChFi3d_Builder::Compute() itel.Value()->Spine()->SetErrorStatus(ChFiDS_Ok); try { OCC_CATCH_SIGNALS - PerformSetOfSurf(itel.Value()); + PerformSetOfSurf(itel.ChangeValue()); } catch(Standard_Failure const& anException) { #ifdef OCCT_DEBUG @@ -412,7 +412,7 @@ void ChFi3d_Builder::Compute() } if (!hasresult) { B1.MakeCompound(TopoDS::Compound(myShapeResult)); - for(It.Reset(); It.More(); It.Next()){ + for(It = TColStd_MapIteratorOfMapOfInteger(MapIndSo); It.More(); It.Next()){ Standard_Integer indsol = It.Key(); const TopoDS_Shape& curshape = DStr.Shape(indsol); TopTools_ListIteratorOfListOfShape @@ -440,7 +440,7 @@ void ChFi3d_Builder::Compute() else { done=Standard_False; B1.MakeCompound(TopoDS::Compound(badShape)); - for(It.Reset(); It.More(); It.Next()){ + for(It = TColStd_MapIteratorOfMapOfInteger(MapIndSo); It.More(); It.Next()){ Standard_Integer indsol = It.Key(); const TopoDS_Shape& curshape = DStr.Shape(indsol); TopTools_ListIteratorOfListOfShape diff --git a/src/ChFi3d/ChFi3d_Builder_2.cxx b/src/ChFi3d/ChFi3d_Builder_2.cxx index 2d92b13d23..2f4764c9f0 100644 --- a/src/ChFi3d/ChFi3d_Builder_2.cxx +++ b/src/ChFi3d/ChFi3d_Builder_2.cxx @@ -2550,7 +2550,7 @@ void ChFi3d_Builder::PerformSetOfKPart(Handle(ChFiDS_Stripe)& Stripe, #ifdef OCCT_DEBUG if(ChFi3d_GettraceCHRON()) elspine.Start(); #endif - ChFi3d_PerformElSpine(ILES.Value(),Spine,myConti,tolesp); + ChFi3d_PerformElSpine(ILES.ChangeValue(),Spine,myConti,tolesp); #ifdef OCCT_DEBUG if(ChFi3d_GettraceCHRON()) { elspine.Stop(); } #endif @@ -2559,7 +2559,7 @@ void ChFi3d_Builder::PerformSetOfKPart(Handle(ChFiDS_Stripe)& Stripe, { ChFiDS_ListOfHElSpine& offsetll = Spine->ChangeOffsetElSpines(); for (ILES.Initialize(offsetll); ILES.More(); ILES.Next()) - ChFi3d_PerformElSpine(ILES.Value(),Spine,myConti,tolesp,Standard_True); + ChFi3d_PerformElSpine(ILES.ChangeValue(),Spine,myConti,tolesp,Standard_True); } Spine->SplitDone(Standard_True); } diff --git a/src/ChFi3d/ChFi3d_Builder_C1.cxx b/src/ChFi3d/ChFi3d_Builder_C1.cxx index edad09233a..b1d2cc32b7 100644 --- a/src/ChFi3d/ChFi3d_Builder_C1.cxx +++ b/src/ChFi3d/ChFi3d_Builder_C1.cxx @@ -3673,7 +3673,7 @@ Standard_Boolean ChFi3d_Builder::MoreSurfdata(const Standard_Integer Index) cons ChFiDS_ListIteratorOfListOfStripe It; It.Initialize(myVDataMap(Index)); - Handle(ChFiDS_Stripe)& stripe = It.Value(); + Handle(ChFiDS_Stripe)& stripe = It.ChangeValue(); ChFiDS_SequenceOfSurfData& SeqFil = stripe->ChangeSetOfSurfData()->ChangeSequence(); const TopoDS_Vertex& Vtx = myVDataMap.FindKey(Index); diff --git a/src/ChFi3d/ChFi3d_Builder_C2.cxx b/src/ChFi3d/ChFi3d_Builder_C2.cxx index 3892b686bc..be9864c9a3 100644 --- a/src/ChFi3d/ChFi3d_Builder_C2.cxx +++ b/src/ChFi3d/ChFi3d_Builder_C2.cxx @@ -119,7 +119,7 @@ Standard_Boolean ChFi3d_Builder::PerformTwoCornerbyInter(const Standard_Integer //---------- ChFiDS_ListIteratorOfListOfStripe It; It.Initialize(myVDataMap(Index)); - Handle(ChFiDS_Stripe)& Corner1 = It.Value(); + Handle(ChFiDS_Stripe)& Corner1 = It.ChangeValue(); Standard_Integer Sens1; Standard_Integer IFd1 = ChFi3d_IndexOfSurfData(Vtx,Corner1,Sens1); @@ -130,7 +130,7 @@ Standard_Boolean ChFi3d_Builder::PerformTwoCornerbyInter(const Standard_Integer //the second //---------- It.Next(); - Handle(ChFiDS_Stripe)& Corner2 = It.Value(); + Handle(ChFiDS_Stripe)& Corner2 = It.ChangeValue(); Standard_Integer Sens2; Standard_Integer IFd2; if(Corner2 == Corner1) { @@ -649,7 +649,7 @@ void ChFi3d_Builder::UpdateTolesp() // tolesp = Precision::Infinite(); for (itel.Initialize(myListStripe); itel.More(); itel.Next()) { - Handle(ChFiDS_Stripe)& curStripe = itel.Value(); + Handle(ChFiDS_Stripe)& curStripe = itel.ChangeValue(); Handle(ChFiDS_Spine)& Spine = curStripe->ChangeSpine(); const Standard_Real current_stripe_tolesp = Spine->GetTolesp(); if (tolesp > current_stripe_tolesp) diff --git a/src/ChFi3d/ChFi3d_Builder_CnCrn.cxx b/src/ChFi3d/ChFi3d_Builder_CnCrn.cxx index bc85cab557..8383bad9b6 100644 --- a/src/ChFi3d/ChFi3d_Builder_CnCrn.cxx +++ b/src/ChFi3d/ChFi3d_Builder_CnCrn.cxx @@ -843,7 +843,7 @@ static void RemoveSurfData (const ChFiDS_StripeMap & myVDataMap, CpOnEdge (It.Value(),i,isfirst,Eadj1,Eadj2,compoint); if (compoint) ind=i; } - if (ind>=2) RemoveSD(It.Value(),1,ind-1); + if (ind>=2) RemoveSD(It.ChangeValue(),1,ind-1); } else { ind=num; @@ -854,7 +854,7 @@ static void RemoveSurfData (const ChFiDS_StripeMap & myVDataMap, CpOnEdge (It.Value(),i,isfirst,Eadj1,Eadj2,compoint); if (compoint) ind=i; } - if (indIsPeriodic()) Itl.Value() = ComputeLaw(Els); + if (Els->IsPeriodic()) Itl.ChangeValue() = ComputeLaw(Els); else{ for (; It.More(); It.Next(), Itl.Next()) { Els = It.Value(); Standard_Real uf = Els->FirstParameter(); Standard_Real ul = Els->LastParameter(); if(uf <= W && W <= ul) { - Itl.Value() = ComputeLaw(Els); + Itl.ChangeValue() = ComputeLaw(Els); } } } diff --git a/src/ChFiKPart/ChFiKPart_RstMap.hxx b/src/ChFiKPart/ChFiKPart_RstMap.hxx index 094a46cf5c..db7e47c5f0 100644 --- a/src/ChFiKPart/ChFiKPart_RstMap.hxx +++ b/src/ChFiKPart/ChFiKPart_RstMap.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap ChFiKPart_RstMap; -typedef NCollection_DataMap::Iterator ChFiKPart_DataMapIteratorOfRstMap; +typedef NCollection_DataMap ChFiKPart_RstMap; +typedef NCollection_DataMap::Iterator ChFiKPart_DataMapIteratorOfRstMap; #endif diff --git a/src/DBRep/DBRep_DrawableShape.cxx b/src/DBRep/DBRep_DrawableShape.cxx index 95308e8ee9..55efde50a7 100644 --- a/src/DBRep/DBRep_DrawableShape.cxx +++ b/src/DBRep/DBRep_DrawableShape.cxx @@ -853,7 +853,7 @@ void DBRep_DrawableShape::DisplayHiddenLines(Draw_Display& dis) if (recompute) myHidData.Remove(it); else { - it.Value().DrawOn(dis,myRg1,myRgN,myHid, + it.ChangeValue().DrawOn(dis,myRg1,myRgN,myHid, myConnCol,myIsosCol); if (dis.HasPicked()) { pickshape = it.Value().LastPick(); diff --git a/src/DBRep/DBRep_IsoBuilder.cxx b/src/DBRep/DBRep_IsoBuilder.cxx index 03e442b574..5912ca35c5 100644 --- a/src/DBRep/DBRep_IsoBuilder.cxx +++ b/src/DBRep/DBRep_IsoBuilder.cxx @@ -37,9 +37,6 @@ #include #include -#include -#include - // Providing consistency with intersection tolerance for the linear curves static Standard_Real IntersectorConfusion = Precision::PConfusion(); static Standard_Real IntersectorTangency = Precision::PConfusion(); diff --git a/src/DBRep/DBRep_IsoBuilder.hxx b/src/DBRep/DBRep_IsoBuilder.hxx index b9a2018d60..3bdc9b75e6 100644 --- a/src/DBRep/DBRep_IsoBuilder.hxx +++ b/src/DBRep/DBRep_IsoBuilder.hxx @@ -28,7 +28,6 @@ #include class TopoDS_Face; class DBRep_Face; -class TopTools_OrientedShapeMapHasher; //! Creation of isoparametric curves. class DBRep_IsoBuilder : public Geom2dHatch_Hatcher @@ -54,7 +53,7 @@ public: protected: typedef NCollection_IndexedDataMap - + DataMapOfEdgePCurve; //! Adds to the hatcher the 2D segments connecting the p-curves diff --git a/src/DDF/DDF_Transaction.hxx b/src/DDF/DDF_Transaction.hxx index 2e33afa2f2..ac86f34261 100644 --- a/src/DDF/DDF_Transaction.hxx +++ b/src/DDF/DDF_Transaction.hxx @@ -21,6 +21,7 @@ #include #include #include +#include class TDF_Data; class TDF_Delta; diff --git a/src/DDataStd/DDataStd_BasicCommands.cxx b/src/DDataStd/DDataStd_BasicCommands.cxx index 44d5e01bbd..d2f467ee17 100644 --- a/src/DDataStd/DDataStd_BasicCommands.cxx +++ b/src/DDataStd/DDataStd_BasicCommands.cxx @@ -208,7 +208,7 @@ static Standard_Integer DDataStd_GetInteger (Draw_Interpretor& di, if (Standard_GUID::CheckGUIDFormat(arg[3])) aGuid = Standard_GUID(arg[3]); } - if(Standard_GUID::IsEqual(aGuid, aNullGuid)) { + if(aGuid == aNullGuid) { isdrawname = Standard_True; aGuid = TDataStd_Integer::GetID(); } @@ -253,7 +253,7 @@ static Standard_Integer DDataStd_GetReal (Draw_Interpretor& di, if (Standard_GUID::CheckGUIDFormat(arg[3])) aGuid = Standard_GUID(arg[3]); } - if(Standard_GUID::IsEqual(aGuid, aNullGuid)) { + if(aGuid == aNullGuid) { isdrawname = Standard_True; aGuid = TDataStd_Real::GetID(); } @@ -1478,6 +1478,7 @@ static Standard_Integer DDataStd_GetUTFtoFile (Draw_Interpretor& di, n = aES.ToUTF8CString(aCstr); anOS.write( (char*)&aCstr[0], n); anOS.close(); + Standard::Free(aCstr); return 0; } di << "GetUTF : Data is not extracted to the specified file \n"; diff --git a/src/DE/DE_ConfigurationContext.hxx b/src/DE/DE_ConfigurationContext.hxx index d7abb18196..ad8ad8ac66 100644 --- a/src/DE/DE_ConfigurationContext.hxx +++ b/src/DE/DE_ConfigurationContext.hxx @@ -17,7 +17,7 @@ #include #include -typedef NCollection_DataMap DE_ResourceMap; +typedef NCollection_DataMap DE_ResourceMap; //! Provides convenient interface to resource file //! Allows loading of the resource file and getting attributes' diff --git a/src/DE/DE_Wrapper.cxx b/src/DE/DE_Wrapper.cxx index 16281c2e28..bd9c6c7cac 100644 --- a/src/DE/DE_Wrapper.cxx +++ b/src/DE/DE_Wrapper.cxx @@ -574,7 +574,6 @@ Standard_EXPORT void DE_Wrapper::UpdateLoad(const Standard_Boolean theToForceUpd void DE_Wrapper::sort(const Handle(DE_ConfigurationContext)& theResource) { const TCollection_AsciiString aScope(THE_CONFIGURATION_SCOPE() + '.' + "priority"); - NCollection_List aVendors; for (DE_ConfigurationFormatMap::Iterator aFormatIter(myConfiguration); aFormatIter.More(); aFormatIter.Next()) { diff --git a/src/DE/DE_Wrapper.hxx b/src/DE/DE_Wrapper.hxx index eb5fedb91e..02af4150d8 100644 --- a/src/DE/DE_Wrapper.hxx +++ b/src/DE/DE_Wrapper.hxx @@ -24,8 +24,8 @@ class TopoDS_Shape; class XSControl_WorkSession; class TDocStd_Document; -typedef NCollection_IndexedDataMap DE_ConfigurationVendorMap; -typedef NCollection_DataMap DE_ConfigurationFormatMap; +typedef NCollection_IndexedDataMap DE_ConfigurationVendorMap; +typedef NCollection_DataMap DE_ConfigurationFormatMap; //! The main class for working with CAD file exchange. //! Loads and Saves special CAD transfer property. diff --git a/src/DRAWEXE/DRAWEXE.cxx b/src/DRAWEXE/DRAWEXE.cxx index 401e47d09d..12c5dec943 100644 --- a/src/DRAWEXE/DRAWEXE.cxx +++ b/src/DRAWEXE/DRAWEXE.cxx @@ -167,7 +167,7 @@ static Standard_Integer Pload (Draw_Interpretor& theDI, Standard_Integer theNbArgs, const char** theArgVec) { - NCollection_IndexedMap aPlugins; + NCollection_IndexedMap aPlugins; for (Standard_Integer anArgIter = 1; anArgIter < theNbArgs; ++anArgIter) { TCollection_AsciiString anArg (theArgVec[anArgIter]); @@ -222,7 +222,7 @@ static Standard_Integer Pload (Draw_Interpretor& theDI, } } - for (NCollection_IndexedMap::Iterator aPluginIter (aPlugins); + for (NCollection_IndexedMap::Iterator aPluginIter (aPlugins); aPluginIter.More(); aPluginIter.Next()) { const TCollection_AsciiString& aPlugin = aPluginIter.Value(); diff --git a/src/Draft/Draft_VertexInfo.cxx b/src/Draft/Draft_VertexInfo.cxx index 87f2dac252..b63d48df07 100644 --- a/src/Draft/Draft_VertexInfo.cxx +++ b/src/Draft/Draft_VertexInfo.cxx @@ -98,7 +98,7 @@ Standard_Real& Draft_VertexInfo::ChangeParameter (const TopoDS_Edge& E) myItEd.Initialize(myEdges); for (; myItEd.More(); myItEd.Next(),itp.Next()) { if (myItEd.Value().IsSame(E)) { - return itp.Value(); + return itp.ChangeValue(); } } throw Standard_DomainError(); diff --git a/src/Draw/Draw_Drawable3D.cxx b/src/Draw/Draw_Drawable3D.cxx index cd6fe7e166..b25b18c32e 100644 --- a/src/Draw/Draw_Drawable3D.cxx +++ b/src/Draw/Draw_Drawable3D.cxx @@ -18,14 +18,15 @@ #include #include +#include #include IMPLEMENT_STANDARD_RTTIEXT(Draw_Drawable3D, Standard_Transient) //! Return the map of factory functions. -static NCollection_DataMap& getFactoryMap() +static NCollection_DataMap& getFactoryMap() { - static NCollection_DataMap myToolMap; + static NCollection_DataMap myToolMap; return myToolMap; } diff --git a/src/Draw/Draw_MapOfAsciiString.hxx b/src/Draw/Draw_MapOfAsciiString.hxx index 1e8504cbeb..5b89c76bdf 100644 --- a/src/Draw/Draw_MapOfAsciiString.hxx +++ b/src/Draw/Draw_MapOfAsciiString.hxx @@ -20,7 +20,7 @@ #include #include -typedef NCollection_IndexedMap Draw_MapOfAsciiString; +typedef NCollection_IndexedMap Draw_MapOfAsciiString; #endif diff --git a/src/DrawFairCurve/DrawFairCurve_Batten.hxx b/src/DrawFairCurve/DrawFairCurve_Batten.hxx index 47157efcdf..5acc95be61 100644 --- a/src/DrawFairCurve/DrawFairCurve_Batten.hxx +++ b/src/DrawFairCurve/DrawFairCurve_Batten.hxx @@ -19,7 +19,6 @@ #include -#include #include #include #include diff --git a/src/DrawFairCurve/DrawFairCurve_MinimalVariation.hxx b/src/DrawFairCurve/DrawFairCurve_MinimalVariation.hxx index 9a7ee32804..d922af6d35 100644 --- a/src/DrawFairCurve/DrawFairCurve_MinimalVariation.hxx +++ b/src/DrawFairCurve/DrawFairCurve_MinimalVariation.hxx @@ -20,7 +20,6 @@ #include #include -#include #include #include diff --git a/src/Expr/Expr_MapOfNamedUnknown.hxx b/src/Expr/Expr_MapOfNamedUnknown.hxx index 088e78d6b8..a66989d29f 100644 --- a/src/Expr/Expr_MapOfNamedUnknown.hxx +++ b/src/Expr/Expr_MapOfNamedUnknown.hxx @@ -18,10 +18,9 @@ #define Expr_MapOfNamedUnknown_HeaderFile #include -#include #include -typedef NCollection_IndexedMap Expr_MapOfNamedUnknown; +typedef NCollection_IndexedMap Expr_MapOfNamedUnknown; #endif diff --git a/src/Express/Express_DataMapOfAsciiStringItem.hxx b/src/Express/Express_DataMapOfAsciiStringItem.hxx index 8d2683f467..9a428d686f 100644 --- a/src/Express/Express_DataMapOfAsciiStringItem.hxx +++ b/src/Express/Express_DataMapOfAsciiStringItem.hxx @@ -18,7 +18,6 @@ #include #include -typedef NCollection_DataMap Express_DataMapOfAsciiStringItem; +typedef NCollection_DataMap Express_DataMapOfAsciiStringItem; #endif diff --git a/src/Express/Express_Entity.hxx b/src/Express/Express_Entity.hxx index 76e4043f23..48d8f21a5f 100644 --- a/src/Express/Express_Entity.hxx +++ b/src/Express/Express_Entity.hxx @@ -65,7 +65,7 @@ protected: private: - typedef NCollection_DataMap DataMapOfStringInteger; + typedef NCollection_DataMap DataMapOfStringInteger; //! Create HXX/CXX files from item Standard_EXPORT virtual Standard_Boolean GenerateClass() const Standard_OVERRIDE; diff --git a/src/Extrema/Extrema_FuncPSDist.hxx b/src/Extrema/Extrema_FuncPSDist.hxx index b29931ce62..e418ac060b 100644 --- a/src/Extrema/Extrema_FuncPSDist.hxx +++ b/src/Extrema/Extrema_FuncPSDist.hxx @@ -25,7 +25,8 @@ #include -class math_Vector; +template class math_VectorBase; +using math_Vector = math_VectorBase; //! Functional for search of extremum of the square Euclidean distance between point P and //! surface S, starting from approximate solution (u0, v0). diff --git a/src/FEmTool/FEmTool_Assembly.cxx b/src/FEmTool/FEmTool_Assembly.cxx index 699698212f..e862c27dea 100644 --- a/src/FEmTool/FEmTool_Assembly.cxx +++ b/src/FEmTool/FEmTool_Assembly.cxx @@ -541,7 +541,7 @@ void FEmTool_Assembly::AddConstraint(const Standard_Integer IndexofConstraint, for(i = Aux1->Upper() + 1; i <= Imax; i++) Coeff->SetValue(i, 0.); Iter.Initialize(L); for(i = 1; i < s1; Iter.Next(), i++); - Iter.Value() = Coeff; + Iter.ChangeValue() = Coeff; } else if(Imin > Aux1->Upper() && Imax >= Aux2->Lower()) { // merge new and first segment @@ -550,7 +550,7 @@ void FEmTool_Assembly::AddConstraint(const Standard_Integer IndexofConstraint, for(i = Aux2->Lower(); i <= Aux2->Upper(); i++) Coeff->SetValue(i, Aux2->Value(i)); Iter.Initialize(L); for(i = 1; i < s2; Iter.Next(), i++); - Iter.Value() = Coeff; + Iter.ChangeValue() = Coeff; } else if(Imin > Aux1->Upper() && Imax < Aux2->Lower()) { // inserting new between s1 and s2 @@ -568,7 +568,7 @@ void FEmTool_Assembly::AddConstraint(const Standard_Integer IndexofConstraint, for(i = Aux2->Lower(); i <= Aux2->Upper(); i++) Coeff->SetValue(i, Aux2->Value(i)); Iter.Initialize(L); for(i = 1; i < s1; Iter.Next(), i++); - Iter.Value() = Coeff; + Iter.ChangeValue() = Coeff; Iter.Next(); L.Remove(Iter); } diff --git a/src/Font/Font_FontMgr.cxx b/src/Font/Font_FontMgr.cxx index 4bceb727a0..0e1a3ecbcd 100644 --- a/src/Font/Font_FontMgr.cxx +++ b/src/Font/Font_FontMgr.cxx @@ -942,7 +942,7 @@ void Font_FontMgr::InitFontDataBase() void Font_FontMgr::GetAvailableFontsNames (TColStd_SequenceOfHAsciiString& theFontsNames) const { theFontsNames.Clear(); - for (NCollection_IndexedMap::Iterator aFontIter (myFontMap); + for (Font_FontMap::Iterator aFontIter (myFontMap); aFontIter.More(); aFontIter.Next()) { const Handle(Font_SystemFont)& aFont = aFontIter.Value(); @@ -1138,17 +1138,11 @@ Handle(Font_SystemFont) Font_FontMgr::Font_FontMap::Find (const TCollection_Asci { return FindKey (1); // return any font } - - TCollection_AsciiString aFontName (theFontName); - aFontName.LowerCase(); - for (IndexedMapNode* aNodeIter = (IndexedMapNode* )myData1[::HashCode (aFontName, NbBuckets())]; - aNodeIter != NULL; aNodeIter = (IndexedMapNode* )aNodeIter->Next()) + Handle(Font_SystemFont) aTmpFont = new Font_SystemFont(theFontName); + const int anInd = FindIndex(aTmpFont); + if (anInd > 0) { - const Handle(Font_SystemFont)& aKey = aNodeIter->Key1(); - if (aKey->FontKey().IsEqual (aFontName)) - { - return aKey; - } + return FindKey(anInd); } return Handle(Font_SystemFont)(); } diff --git a/src/Font/Font_FontMgr.hxx b/src/Font/Font_FontMgr.hxx index 137f1db1ce..410a6769b7 100644 --- a/src/Font/Font_FontMgr.hxx +++ b/src/Font/Font_FontMgr.hxx @@ -209,8 +209,22 @@ private: private: + struct FontHasher + { + size_t operator()(const Handle(Font_SystemFont)& theFont) const noexcept + { + return std::hash{}(theFont->FontKey()); + } + + bool operator()(const Handle(Font_SystemFont)& theFont1, + const Handle(Font_SystemFont)& theFont2) const + { + return theFont1->IsEqual(theFont2); + } + }; + //! Map storing registered fonts. - class Font_FontMap : public NCollection_IndexedMap + class Font_FontMap : public NCollection_IndexedMap { public: //! Empty constructor. @@ -220,26 +234,6 @@ private: //! @param theFontName [in] font family to find (or empty string if family name can be ignored) //! @return best match font or NULL if not found Handle(Font_SystemFont) Find (const TCollection_AsciiString& theFontName) const; - - public: - //! Computes a hash code for the system font, in the range [1, theUpperBound]. Based on Font Family, so that the - //! whole family with different aspects can be found within the same bucket of some map - //! @param theHExtendedString the handle referred to extended string which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const Handle (Font_SystemFont) & theSystemFont, - const Standard_Integer theUpperBound) - { - return ::HashCode (theSystemFont->FontKey(), theUpperBound); - } - - //! Matching two instances, for Map interface. - static bool IsEqual (const Handle(Font_SystemFont)& theFont1, - const Handle(Font_SystemFont)& theFont2) - { - return theFont1->IsEqual (theFont2); - } - }; //! Structure defining font alias. diff --git a/src/Font/Font_SystemFont.hxx b/src/Font/Font_SystemFont.hxx index ac3c6fca8b..0736553be3 100644 --- a/src/Font/Font_SystemFont.hxx +++ b/src/Font/Font_SystemFont.hxx @@ -18,6 +18,7 @@ #include #include +#include #include #include @@ -122,21 +123,10 @@ public: Standard_EXPORT TCollection_AsciiString ToString() const; public: - //! Computes a hash code for the system font, in the range [1, theUpperBound]. Based on Font Family, so that the whole - //! family with different aspects can be found within the same bucket of some map - //! @param theSystemFont the system font which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const Handle (Font_SystemFont) & theSystemFont, const Standard_Integer theUpperBound) - { - return ::HashCode (theSystemFont->FontKey(), theUpperBound); - } - //! Matching two instances, for Map interface. - static bool IsEqual (const Handle(Font_SystemFont)& theFont1, - const Handle(Font_SystemFont)& theFont2) + bool operator==(const Font_SystemFont& theFont) const { - return theFont1->IsEqual (theFont2); + return myFontKey.IsEqual(theFont.FontKey()); } private: @@ -149,6 +139,19 @@ private: }; +namespace std +{ + template<> + struct hash + { + size_t operator()(const Handle (Font_SystemFont)& theLink) const noexcept + { + if (theLink.IsNull()) return 0; + return std::hash{}(theLink->FontKey()); + } + }; +}; + DEFINE_STANDARD_HANDLE(Font_SystemFont, Standard_Transient) #endif // _Font_SystemFont_HeaderFile diff --git a/src/Geom2dHatch/Geom2dHatch_Hatchings.hxx b/src/Geom2dHatch/Geom2dHatch_Hatchings.hxx index 8718dd065d..ec9f02b975 100644 --- a/src/Geom2dHatch/Geom2dHatch_Hatchings.hxx +++ b/src/Geom2dHatch/Geom2dHatch_Hatchings.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap Geom2dHatch_Hatchings; -typedef NCollection_DataMap::Iterator Geom2dHatch_DataMapIteratorOfHatchings; +typedef NCollection_DataMap Geom2dHatch_Hatchings; +typedef NCollection_DataMap::Iterator Geom2dHatch_DataMapIteratorOfHatchings; #endif diff --git a/src/Geom2dHatch/Geom2dHatch_MapOfElements.hxx b/src/Geom2dHatch/Geom2dHatch_MapOfElements.hxx index 8d9911077c..334b723194 100644 --- a/src/Geom2dHatch/Geom2dHatch_MapOfElements.hxx +++ b/src/Geom2dHatch/Geom2dHatch_MapOfElements.hxx @@ -18,11 +18,10 @@ #define Geom2dHatch_MapOfElements_HeaderFile #include -#include #include -typedef NCollection_DataMap Geom2dHatch_MapOfElements; -typedef NCollection_DataMap::Iterator Geom2dHatch_DataMapIteratorOfMapOfElements; +typedef NCollection_DataMap Geom2dHatch_MapOfElements; +typedef NCollection_DataMap::Iterator Geom2dHatch_DataMapIteratorOfMapOfElements; #endif diff --git a/src/GeomFill/GeomFill_PolynomialConvertor.cxx b/src/GeomFill/GeomFill_PolynomialConvertor.cxx index 8bbb524127..d0f85b8db7 100644 --- a/src/GeomFill/GeomFill_PolynomialConvertor.cxx +++ b/src/GeomFill/GeomFill_PolynomialConvertor.cxx @@ -25,6 +25,7 @@ #include #include #include +#include GeomFill_PolynomialConvertor::GeomFill_PolynomialConvertor(): Ordre(8), diff --git a/src/GeomInt/GeomInt_LineTool.cxx b/src/GeomInt/GeomInt_LineTool.cxx index f33fedb3f9..81b0c09598 100644 --- a/src/GeomInt/GeomInt_LineTool.cxx +++ b/src/GeomInt/GeomInt_LineTool.cxx @@ -26,7 +26,7 @@ #include #include #include -#include +#include #include #include @@ -418,7 +418,7 @@ Standard_Boolean GeomInt_LineTool:: typedef NCollection_List ListOfInteger; //have to use std::vector, not NCollection_Vector in order to use copy constructor of //ListOfInteger which will be created with specific allocator instance - typedef std::vector > ArrayOfListOfInteger; Standard_Boolean bIsPrevPointOnBoundary, bIsCurrentPointOnBoundary; @@ -445,7 +445,7 @@ Standard_Boolean GeomInt_LineTool:: } // Handle(NCollection_IncAllocator) anIncAlloc = new NCollection_IncAllocator(); - NCollection_StdAllocator anAlloc (anIncAlloc); + NCollection_OccAllocator anAlloc (anIncAlloc); const ListOfInteger aDummy (anIncAlloc); //empty list to be copy constructed from ArrayOfListOfInteger anArrayOfLines (aNbPnts + 1, aDummy, anAlloc); diff --git a/src/GeomInt/GeomInt_TheMultiLineOfWLApprox.hxx b/src/GeomInt/GeomInt_TheMultiLineOfWLApprox.hxx index 619598d096..f990f4ef4d 100644 --- a/src/GeomInt/GeomInt_TheMultiLineOfWLApprox.hxx +++ b/src/GeomInt/GeomInt_TheMultiLineOfWLApprox.hxx @@ -21,7 +21,6 @@ #include #include -#include #include #include #include diff --git a/src/Graphic3d/Graphic3d_CView.hxx b/src/Graphic3d/Graphic3d_CView.hxx index 143b50f4c4..5fe56d4467 100644 --- a/src/Graphic3d/Graphic3d_CView.hxx +++ b/src/Graphic3d/Graphic3d_CView.hxx @@ -36,7 +36,6 @@ #include #include #include -#include #include #include diff --git a/src/Graphic3d/Graphic3d_FrameStatsData.cxx b/src/Graphic3d/Graphic3d_FrameStatsData.cxx index 8c46a42aee..512d02bc89 100644 --- a/src/Graphic3d/Graphic3d_FrameStatsData.cxx +++ b/src/Graphic3d/Graphic3d_FrameStatsData.cxx @@ -30,12 +30,46 @@ Graphic3d_FrameStatsData::Graphic3d_FrameStatsData() Reset(); } +// ======================================================================= +// function : Graphic3d_FrameStatsData +// purpose : +// ======================================================================= +Graphic3d_FrameStatsData::Graphic3d_FrameStatsData(const Graphic3d_FrameStatsData& theOther) : + myCounters(theOther.myCounters), + myTimers(theOther.myTimers), + myTimersMin(theOther.myTimersMin), + myTimersMax(theOther.myTimersMax), + myFps(theOther.myFps), + myFpsCpu(theOther.myFpsCpu), + myFpsImmediate(theOther.myFpsImmediate), + myFpsCpuImmediate(theOther.myFpsCpuImmediate) +{} + +// ======================================================================= +// function : Graphic3d_FrameStatsData +// purpose : +// ======================================================================= +Graphic3d_FrameStatsData::Graphic3d_FrameStatsData(Graphic3d_FrameStatsData&& theOther) noexcept : + myCounters(std::move(theOther.myCounters)), + myTimers(std::move(theOther.myTimers)), + myTimersMin(std::move(theOther.myTimersMin)), + myTimersMax(std::move(theOther.myTimersMax)), + myFps(std::move(theOther.myFps)), + myFpsCpu(std::move(theOther.myFpsCpu)), + myFpsImmediate(std::move(theOther.myFpsImmediate)), + myFpsCpuImmediate(std::move(theOther.myFpsCpuImmediate)) +{} + // ======================================================================= // function : operator= // purpose : // ======================================================================= Graphic3d_FrameStatsData& Graphic3d_FrameStatsData::operator= (const Graphic3d_FrameStatsData& theOther) { + if (&theOther == this) + { + return *this; + } myFps = theOther.myFps; myFpsCpu = theOther.myFpsCpu; myFpsImmediate = theOther.myFpsImmediate; @@ -47,6 +81,27 @@ Graphic3d_FrameStatsData& Graphic3d_FrameStatsData::operator= (const Graphic3d_F return *this; } +// ======================================================================= +// function : operator= +// purpose : +// ======================================================================= +Graphic3d_FrameStatsData& Graphic3d_FrameStatsData::operator=(Graphic3d_FrameStatsData&& theOther) noexcept +{ + if (&theOther == this) + { + return *this; + } + myFps = std::move(theOther.myFps); + myFpsCpu = std::move(theOther.myFpsCpu); + myFpsImmediate = std::move(theOther.myFpsImmediate); + myFpsCpuImmediate = std::move(theOther.myFpsCpuImmediate); + myCounters = std::move(theOther.myCounters); + myTimers = std::move(theOther.myTimers); + myTimersMin = std::move(theOther.myTimersMin); + myTimersMax = std::move(theOther.myTimersMax); + return *this; +} + // ======================================================================= // function : Reset // purpose : diff --git a/src/Graphic3d/Graphic3d_FrameStatsData.hxx b/src/Graphic3d/Graphic3d_FrameStatsData.hxx index 27db098b66..2337037bb5 100644 --- a/src/Graphic3d/Graphic3d_FrameStatsData.hxx +++ b/src/Graphic3d/Graphic3d_FrameStatsData.hxx @@ -61,9 +61,18 @@ public: //! Empty constructor. Standard_EXPORT Graphic3d_FrameStatsData(); + //! Copy constructor. + Standard_EXPORT Graphic3d_FrameStatsData(const Graphic3d_FrameStatsData& theOther); + + //! Move constructor. + Standard_EXPORT Graphic3d_FrameStatsData(Graphic3d_FrameStatsData&& theOther) noexcept; + //! Assignment operator. Standard_EXPORT Graphic3d_FrameStatsData& operator= (const Graphic3d_FrameStatsData& theOther); + //! Assignment with move operator. + Standard_EXPORT Graphic3d_FrameStatsData& operator= (Graphic3d_FrameStatsData&& theOther) noexcept; + //! Reset data. Standard_EXPORT void Reset(); diff --git a/src/Graphic3d/Graphic3d_ShaderAttribute.hxx b/src/Graphic3d/Graphic3d_ShaderAttribute.hxx index 786458d360..5b2b8f3c09 100644 --- a/src/Graphic3d/Graphic3d_ShaderAttribute.hxx +++ b/src/Graphic3d/Graphic3d_ShaderAttribute.hxx @@ -17,6 +17,7 @@ #define _Graphic3d_ShaderAttribute_HeaderFile #include +#include #include //! Describes custom vertex shader attribute. diff --git a/src/HLRAlgo/HLRAlgo_PolyAlgo.cxx b/src/HLRAlgo/HLRAlgo_PolyAlgo.cxx index 31cd6e4dd7..09756abcd6 100644 --- a/src/HLRAlgo/HLRAlgo_PolyAlgo.cxx +++ b/src/HLRAlgo/HLRAlgo_PolyAlgo.cxx @@ -115,7 +115,7 @@ void HLRAlgo_PolyAlgo::Update () for (mySegListIt.Initialize (aPsd->Edges()); mySegListIt.More(); mySegListIt.Next()) { - HLRAlgo_BiPoint& BP = mySegListIt.Value(); + HLRAlgo_BiPoint& BP = mySegListIt.ChangeValue(); HLRAlgo_BiPoint::PointsT& aPoints = BP.Points(); HLRAlgo_BiPoint::IndicesT& theIndices = BP.Indices(); if (aPoints.PntP1.X() < aPoints.PntP2.X()) { xSegmnMin = aPoints.PntP1.X(); xSegmnMax = aPoints.PntP2.X(); } @@ -349,7 +349,7 @@ HLRAlgo_BiPoint::PointsT& HLRAlgo_PolyAlgo::Hide (HLRAlgo_EdgeStatus& theStatus, Standard_Boolean& theOutl, Standard_Boolean& theIntl) { - HLRAlgo_BiPoint& aBP = mySegListIt.Value(); + HLRAlgo_BiPoint& aBP = mySegListIt.ChangeValue(); HLRAlgo_BiPoint::PointsT& aPoints = aBP.Points(); HLRAlgo_BiPoint::IndicesT& anIndices = aBP.Indices(); theStatus = HLRAlgo_EdgeStatus (0.0, (Standard_ShortReal)myTriangle.TolParam, @@ -431,7 +431,7 @@ HLRAlgo_BiPoint::PointsT& HLRAlgo_PolyAlgo::Show ( Standard_Boolean& outl, Standard_Boolean& intl) { - HLRAlgo_BiPoint& BP = mySegListIt.Value(); + HLRAlgo_BiPoint& BP = mySegListIt.ChangeValue(); HLRAlgo_BiPoint::IndicesT& theIndices = BP.Indices(); HLRAlgo_BiPoint::PointsT& aPoints = BP.Points(); Index = theIndices.ShapeIndex; diff --git a/src/HLRAlgo/HLRAlgo_PolyShellData.cxx b/src/HLRAlgo/HLRAlgo_PolyShellData.cxx index 773cb84a22..b5d6ba2836 100644 --- a/src/HLRAlgo/HLRAlgo_PolyShellData.cxx +++ b/src/HLRAlgo/HLRAlgo_PolyShellData.cxx @@ -38,7 +38,7 @@ void HLRAlgo_PolyShellData::UpdateGlobalMinMax(HLRAlgo_PolyData::Box& theBox) HLRAlgo_ListIteratorOfListOfBPoint it; for (it.Initialize(mySegList); it.More(); it.Next()) { - HLRAlgo_BiPoint& BP = it.Value(); + HLRAlgo_BiPoint& BP = it.ChangeValue(); HLRAlgo_BiPoint::PointsT& aPoints = BP.Points(); if (aPoints.PntP1.X() < aPoints.PntP2.X()) { if (theBox.XMin > aPoints.PntP1.X()) theBox.XMin = aPoints.PntP1.X(); diff --git a/src/HLRBRep/HLRBRep_CurveTool.hxx b/src/HLRBRep/HLRBRep_CurveTool.hxx index 147b8659d8..170af95419 100644 --- a/src/HLRBRep/HLRBRep_CurveTool.hxx +++ b/src/HLRBRep/HLRBRep_CurveTool.hxx @@ -22,7 +22,6 @@ #include #include -#include #include #include #include diff --git a/src/HLRBRep/HLRBRep_Data.cxx b/src/HLRBRep/HLRBRep_Data.cxx index 2cebfec692..4507728bd2 100644 --- a/src/HLRBRep/HLRBRep_Data.cxx +++ b/src/HLRBRep/HLRBRep_Data.cxx @@ -1443,7 +1443,7 @@ HLRBRep_Data::HidingStartLevel (const Standard_Integer E, It.Initialize(IL); while(It.More() && Loop) { - HLRAlgo_Interference& Int = It.Value(); + const HLRAlgo_Interference& Int = It.Value(); Standard_Real p = Int.Intersection().Parameter(); if (p < param - tolpar) { switch (Int.Transition()) { diff --git a/src/HLRBRep/HLRBRep_Data.hxx b/src/HLRBRep/HLRBRep_Data.hxx index 121ec30824..e701d2f3f2 100644 --- a/src/HLRBRep/HLRBRep_Data.hxx +++ b/src/HLRBRep/HLRBRep_Data.hxx @@ -31,7 +31,6 @@ #include #include #include -#include #include #include #include diff --git a/src/HLRBRep/HLRBRep_EdgeFaceTool.hxx b/src/HLRBRep/HLRBRep_EdgeFaceTool.hxx index cd7feae0d1..5c0c34be02 100644 --- a/src/HLRBRep/HLRBRep_EdgeFaceTool.hxx +++ b/src/HLRBRep/HLRBRep_EdgeFaceTool.hxx @@ -20,7 +20,6 @@ #include #include -#include class gp_Dir; diff --git a/src/HLRBRep/HLRBRep_EdgeIList.cxx b/src/HLRBRep/HLRBRep_EdgeIList.cxx index b416ea7fe1..9a852e1707 100644 --- a/src/HLRBRep/HLRBRep_EdgeIList.cxx +++ b/src/HLRBRep/HLRBRep_EdgeIList.cxx @@ -116,8 +116,8 @@ ProcessComplex(HLRAlgo_InterferenceList& IL, IL.Remove(It2); } // get the cumulated results - It1.Value().Transition(transTool.Transition()); - It1.Value().BoundaryTransition(transTool.BoundaryTransition()); + It1.ChangeValue().Transition(transTool.Transition()); + It1.ChangeValue().BoundaryTransition(transTool.BoundaryTransition()); } } It1.Next(); diff --git a/src/HLRBRep/HLRBRep_Hider.cxx b/src/HLRBRep/HLRBRep_Hider.cxx index b97392a3f1..54ce4e0e9d 100644 --- a/src/HLRBRep/HLRBRep_Hider.cxx +++ b/src/HLRBRep/HLRBRep_Hider.cxx @@ -141,12 +141,12 @@ void HLRBRep_Hider::Hide(const Standard_Integer FI, Modif = Standard_False; HLRAlgo_ListIteratorOfInterferenceList ItSegHidden1(ILHidden); while(ItSegHidden1.More() && Modif==Standard_False) { - HLRAlgo_Interference& Int1 = ItSegHidden1.Value(); + HLRAlgo_Interference& Int1 = ItSegHidden1.ChangeValue(); Standard_Integer numseg1=Int1.Intersection().SegIndex(); if(numseg1!=0) { HLRAlgo_ListIteratorOfInterferenceList ItSegHidden2(ILHidden); while(ItSegHidden2.More() && Modif==Standard_False) { - HLRAlgo_Interference& Int2 = ItSegHidden2.Value(); + HLRAlgo_Interference& Int2 = ItSegHidden2.ChangeValue(); Standard_Integer numseg2=Int2.Intersection().SegIndex(); if(numseg1+numseg2 == 0) { //--printf("\nHidden Traitement du segment %d %d\n",numseg1,numseg2); fflush(stdout); @@ -216,7 +216,7 @@ void HLRBRep_Hider::Hide(const Standard_Integer FI, while(It.More()) { // process Intersections on the Face // ********************************* - HLRAlgo_Interference& Int = It.Value(); + HLRAlgo_Interference& Int = It.ChangeValue(); TopAbs_State stbef, staft; // read the 3d states Int.Boundary().State3D(stbef,staft); // ****************** @@ -401,7 +401,7 @@ void HLRBRep_Hider::Hide(const Standard_Integer FI, while(It.More()) { // suppress multi-inside Intersections // *********************************** - HLRAlgo_Interference& Int = It.Value(); + const HLRAlgo_Interference& Int = It.Value(); switch (Int.Transition()) { case TopAbs_FORWARD : @@ -585,7 +585,7 @@ void HLRBRep_Hider::Hide(const Standard_Integer FI, while(It.More()) { // suppress multi-inside Intersections // *********************************** - HLRAlgo_Interference& Int = It.Value(); + const HLRAlgo_Interference& Int = It.Value(); switch (Int.Transition()) { case TopAbs_FORWARD : diff --git a/src/HLRBRep/HLRBRep_PolyAlgo.cxx b/src/HLRBRep/HLRBRep_PolyAlgo.cxx index ebcc46fd3a..f7dc633b9d 100644 --- a/src/HLRBRep/HLRBRep_PolyAlgo.cxx +++ b/src/HLRBRep/HLRBRep_PolyAlgo.cxx @@ -2412,7 +2412,7 @@ void HLRBRep_PolyAlgo::CheckFrBackTriangles (HLRAlgo_ListOfBPoint& theList, { for (HLRAlgo_ListIteratorOfListOfBPoint aBPointIter (theList); aBPointIter.More(); aBPointIter.Next()) { - HLRAlgo_BiPoint& BP = aBPointIter.Value(); + HLRAlgo_BiPoint& BP = aBPointIter.ChangeValue(); HLRAlgo_BiPoint::IndicesT& theIndices = BP.Indices(); if (theIndices.FaceConex1 != 0) { @@ -3440,7 +3440,7 @@ TopoDS_Shape HLRBRep_PolyAlgo::OutLinedShape (const TopoDS_Shape& theShape) cons const HLRAlgo_ListOfBPoint& aList = aShell.Value (aShellIter)->Edges(); for (aBPntIter.Initialize (aList); aBPntIter.More(); aBPntIter.Next()) { - HLRAlgo_BiPoint& aBP = aBPntIter.Value(); + HLRAlgo_BiPoint& aBP = aBPntIter.ChangeValue(); if (aBP.IntLine()) { const HLRAlgo_BiPoint::IndicesT& aIndices = aBP.Indices(); diff --git a/src/HLRBRep/HLRBRep_ThePolyhedronOfInterCSurf.hxx b/src/HLRBRep/HLRBRep_ThePolyhedronOfInterCSurf.hxx index 3c43944fb7..6900c0c029 100644 --- a/src/HLRBRep/HLRBRep_ThePolyhedronOfInterCSurf.hxx +++ b/src/HLRBRep/HLRBRep_ThePolyhedronOfInterCSurf.hxx @@ -24,7 +24,6 @@ #include #include #include -#include #include class Standard_OutOfRange; class HLRBRep_SurfaceTool; diff --git a/src/IFSelect/IFSelect_IntParam.hxx b/src/IFSelect/IFSelect_IntParam.hxx index 4d48a064d9..0bd3d56c98 100644 --- a/src/IFSelect/IFSelect_IntParam.hxx +++ b/src/IFSelect/IFSelect_IntParam.hxx @@ -21,6 +21,7 @@ #include #include +#include #include class IFSelect_IntParam; diff --git a/src/IMeshData/IMeshData_Types.hxx b/src/IMeshData/IMeshData_Types.hxx index 5e82a2f12b..dfa716dab7 100644 --- a/src/IMeshData/IMeshData_Types.hxx +++ b/src/IMeshData/IMeshData_Types.hxx @@ -22,7 +22,7 @@ #include #include #include -#include +#include #include #include #include @@ -108,10 +108,10 @@ namespace IMeshData namespace Model { - typedef std::deque > SequenceOfPnt; - typedef std::deque > SequenceOfPnt2d; - typedef std::deque > SequenceOfReal; - typedef std::deque > SequenceOfInteger; + typedef std::deque > SequenceOfPnt; + typedef std::deque > SequenceOfPnt2d; + typedef std::deque > SequenceOfReal; + typedef std::deque > SequenceOfInteger; } // Lists @@ -125,40 +125,20 @@ namespace IMeshData typedef NCollection_CellFilter CircleCellFilter; typedef NCollection_CellFilter VertexCellFilter; - // Data Maps - template - struct WeakEqual - { - static Standard_Boolean IsEqual(const Type* theFirst, - const Type* theSecond) - { - return (theFirst == theSecond); - } + typedef NCollection_Shared > DMapOfShapeInteger; + typedef NCollection_Shared > DMapOfIFacePtrsListOfInteger; + typedef NCollection_Shared > MapOfIEdgePtr; + typedef NCollection_Shared > MapOfIFacePtr; + typedef NCollection_Shared > MapOfOrientedEdges; + typedef NCollection_Shared > MapOfReal; + typedef NCollection_Shared > IDMapOfIFacePtrsListOfIPCurves; + typedef NCollection_Shared > DMapOfIFacePtrsMapOfIEdgePtrs; + typedef NCollection_Shared > IDMapOfLink; + typedef NCollection_Shared > DMapOfIntegerListOfInteger; + typedef NCollection_Shared > MapOfIntegerInteger; + typedef NCollection_Shared > IMapOfReal; - //! Computes a hash code for the given pointer, in the range [1, theUpperBound] - //! @param thePointer the pointer which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const Type* const thePointer, Standard_Integer theUpperBound) - { - return ::HashCode (thePointer, theUpperBound); - } - }; - - typedef NCollection_Shared > DMapOfShapeInteger; - typedef NCollection_Shared > > DMapOfIFacePtrsListOfInteger; - typedef NCollection_Shared > > MapOfIEdgePtr; - typedef NCollection_Shared > > MapOfIFacePtr; - typedef NCollection_Shared > MapOfOrientedEdges; - typedef NCollection_Shared > MapOfReal; - typedef NCollection_Shared > > IDMapOfIFacePtrsListOfIPCurves; - typedef NCollection_Shared > > DMapOfIFacePtrsMapOfIEdgePtrs; - typedef NCollection_Shared > IDMapOfLink; - typedef NCollection_Shared > DMapOfIntegerListOfInteger; - typedef NCollection_Shared > MapOfIntegerInteger; - typedef NCollection_Shared > IMapOfReal; - - typedef NCollection_Shared > Array1OfInteger; + typedef NCollection_Shared > Array1OfInteger; } #endif diff --git a/src/IVtk/IVtk_Types.hxx b/src/IVtk/IVtk_Types.hxx index 5ae46834d9..b1e00f5300 100644 --- a/src/IVtk/IVtk_Types.hxx +++ b/src/IVtk/IVtk_Types.hxx @@ -18,7 +18,6 @@ #include #include -#include #include #include #include diff --git a/src/IVtkDraw/IVtkDraw.cxx b/src/IVtkDraw/IVtkDraw.cxx index a81e03b64b..aedfc709a3 100644 --- a/src/IVtkDraw/IVtkDraw.cxx +++ b/src/IVtkDraw/IVtkDraw.cxx @@ -94,9 +94,25 @@ //================================================================ // TYPE DEFINITIONS //================================================================ +namespace +{ + struct VtkPointerHasher + { + std::size_t operator()(const vtkSmartPointer& thePointer) const + { + return std::hash{}(thePointer.Get()); + } + + bool operator()(const vtkSmartPointer& thePointer1, + const vtkSmartPointer& thePointer2) const + { + return thePointer1 == thePointer2; + } + }; +} typedef NCollection_DoubleMap DoubleMapOfShapesAndNames; -typedef NCollection_DoubleMap, TCollection_AsciiString> DoubleMapOfActorsAndNames; +typedef NCollection_DoubleMap, TCollection_AsciiString, VtkPointerHasher> DoubleMapOfActorsAndNames; typedef IVtkDraw_HighlightAndSelectionPipeline PipelinePtr; diff --git a/src/Image/Image_Texture.hxx b/src/Image/Image_Texture.hxx index 57575a5283..3b3e985171 100644 --- a/src/Image/Image_Texture.hxx +++ b/src/Image/Image_Texture.hxx @@ -76,29 +76,6 @@ public: const TCollection_AsciiString& theFile); public: //! @name hasher interface - - //! Hash value, for Map interface. - static int HashCode (const Handle(Image_Texture)& theTexture, const int theUpper) - { - return !theTexture.IsNull() - ? TCollection_AsciiString::HashCode (theTexture->myTextureId, theUpper) - : 0; - } - - //! Matching two instances, for Map interface. - static Standard_Boolean IsEqual (const Handle(Image_Texture)& theTex1, - const Handle(Image_Texture)& theTex2) - { - if (theTex1.IsNull() != theTex2.IsNull()) - { - return Standard_False; - } - else if (theTex1.IsNull()) - { - return Standard_True; - } - return theTex1->myTextureId.IsEqual (theTex2->myTextureId); - } //! Dumps the content of me into the stream Standard_EXPORT virtual void DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth = -1) const; @@ -127,4 +104,36 @@ protected: }; +namespace std +{ + template<> + struct equal_to + { + bool operator()(const Handle(Image_Texture)& theTex1, + const Handle(Image_Texture)& theTex2) const + { + if (theTex1.IsNull() != theTex2.IsNull()) + { + return Standard_False; + } + else if (theTex1.IsNull()) + { + return Standard_True; + } + return theTex1->TextureId().IsEqual(theTex2->TextureId()); + } + }; + + template<> + struct hash + { + size_t operator()(const Handle(Image_Texture)& theTexture) const noexcept + { + return !theTexture.IsNull() + ? std::hash{}(theTexture->TextureId()) + : 0; + } + }; +} + #endif // _Image_Texture_HeaderFile diff --git a/src/IntPatch/IntPatch_ImpImpIntersection_4.gxx b/src/IntPatch/IntPatch_ImpImpIntersection_4.gxx index c956e6c6cf..369d6334e9 100644 --- a/src/IntPatch/IntPatch_ImpImpIntersection_4.gxx +++ b/src/IntPatch/IntPatch_ImpImpIntersection_4.gxx @@ -20,6 +20,7 @@ #include #include #include +#include //If Abs(a) <= aNulValue then it is considered that a = 0. static const Standard_Real aNulValue = 1.0e-11; @@ -3845,7 +3846,7 @@ IntPatch_ImpImpIntersection::IntStatus IntCyCy(const IntSurf_Quadric& theQuad1, Handle(NCollection_IncAllocator) anAlloc = new NCollection_IncAllocator; for (Standard_Integer aCID = 0; aCID < 2; aCID++) { - anAlloc->Reset(); + anAlloc->Reset(false); NCollection_List aListOfRng(anAlloc); aListOfRng.Append(anURange[aCID][0]); @@ -3860,7 +3861,7 @@ IntPatch_ImpImpIntersection::IntStatus IntCyCy(const IntSurf_Quadric& theQuad1, aListOfRng.Clear(); for (anITrRng.Init(aLstTemp); anITrRng.More(); anITrRng.Next()) { - Bnd_Range& aRng = anITrRng.Value(); + Bnd_Range& aRng = anITrRng.ChangeValue(); aRng.Split(aSplitArr[aSInd], aListOfRng, aPeriod); } } @@ -3868,7 +3869,7 @@ IntPatch_ImpImpIntersection::IntStatus IntCyCy(const IntSurf_Quadric& theQuad1, anITrRng.Init(aListOfRng); for (; anITrRng.More(); anITrRng.Next()) { - Bnd_Range& aCurrRange = anITrRng.Value(); + Bnd_Range& aCurrRange = anITrRng.ChangeValue(); Bnd_Range aBoundR; aBoundR.Add(aUSBou[aCID][0]); @@ -4300,7 +4301,7 @@ Standard_Boolean IntCyCo(const IntSurf_Quadric& Quad1, // aIt.Initialize(aLC); for (; aIt.More(); aIt.Next()) { - IntAna_Curve& curvsol=aIt.Value(); + IntAna_Curve& curvsol=aIt.ChangeValue(); // curvsol.Domain(first, last); firstp = !curvsol.IsFirstOpen(); diff --git a/src/IntPatch/IntPatch_SpecialPoints.hxx b/src/IntPatch/IntPatch_SpecialPoints.hxx index 485adf9e8f..eb7674aeb1 100644 --- a/src/IntPatch/IntPatch_SpecialPoints.hxx +++ b/src/IntPatch/IntPatch_SpecialPoints.hxx @@ -28,7 +28,9 @@ class gp_Vec; class gp_XYZ; class IntPatch_Point; class IntSurf_PntOn2S; -class math_Vector; + +template class math_VectorBase; +using math_Vector = math_VectorBase; class IntPatch_SpecialPoints { diff --git a/src/IntPatch/IntPatch_WLineTool.cxx b/src/IntPatch/IntPatch_WLineTool.cxx index 9132bf33e0..6530d7d4b3 100644 --- a/src/IntPatch/IntPatch_WLineTool.cxx +++ b/src/IntPatch/IntPatch_WLineTool.cxx @@ -1544,7 +1544,7 @@ void IntPatch_WLineTool::JoinWLines(IntPatch_SequenceOfLine& theSlin, } } - anAlloc->Reset(); + anAlloc->Reset(false); NCollection_List aListFC(anAlloc), aListLC(anAlloc); diff --git a/src/IntPolyh/FILES b/src/IntPolyh/FILES index d586b0593d..f1641e8151 100755 --- a/src/IntPolyh/FILES +++ b/src/IntPolyh/FILES @@ -7,7 +7,6 @@ IntPolyh_ArrayOfTangentZones.hxx IntPolyh_ArrayOfTriangles.hxx IntPolyh_Couple.cxx IntPolyh_Couple.hxx -IntPolyh_CoupleMapHasher.hxx IntPolyh_Edge.cxx IntPolyh_Edge.hxx IntPolyh_Intersection.cxx @@ -26,4 +25,4 @@ IntPolyh_StartPoint.hxx IntPolyh_Tools.cxx IntPolyh_Tools.hxx IntPolyh_Triangle.cxx -IntPolyh_Triangle.hxx \ No newline at end of file +IntPolyh_Triangle.hxx diff --git a/src/IntPolyh/IntPolyh_Couple.hxx b/src/IntPolyh/IntPolyh_Couple.hxx index 24770ef677..bb9480d993 100644 --- a/src/IntPolyh/IntPolyh_Couple.hxx +++ b/src/IntPolyh/IntPolyh_Couple.hxx @@ -23,6 +23,7 @@ #include #include +#include //! The class represents the couple of indices with additional //! characteristics such as analyzed flag and an angle.
@@ -93,12 +94,10 @@ public: (myIndex1 == theOther.myIndex2 && myIndex2 == theOther.myIndex1); } - //! Computes a hash code for this couple, in the range [1, theUpperBound] - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - Standard_Integer HashCode (const Standard_Integer theUpperBound) const + //! Returns true if the Couple is equal to + bool operator==(const IntPolyh_Couple& theOther) const { - return ::HashCode (myIndex1 + myIndex2, theUpperBound); + return IsEqual(theOther); } // Dump @@ -115,4 +114,22 @@ private: }; +namespace std +{ + template <> + struct hash + { + size_t operator()(const IntPolyh_Couple& theCouple) const noexcept + { + // Combine two int values into a single hash value. + int aCombination[2]{ theCouple.FirstValue(), theCouple.SecondValue() }; + if (aCombination[0] > aCombination[1]) + { + std::swap(aCombination[0], aCombination[1]); + } + return opencascade::hashBytes(aCombination, sizeof(aCombination)); + } + }; +} + #endif // _IntPolyh_Couple_HeaderFile diff --git a/src/IntPolyh/IntPolyh_CoupleMapHasher.hxx b/src/IntPolyh/IntPolyh_CoupleMapHasher.hxx deleted file mode 100644 index fa40687ed9..0000000000 --- a/src/IntPolyh/IntPolyh_CoupleMapHasher.hxx +++ /dev/null @@ -1,48 +0,0 @@ -// Created by: Eugeny MALTCHIKOV -// Copyright (c) 2017 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _IntPolyh_CoupleMapHasher_HeaderFile -#define _IntPolyh_CoupleMapHasher_HeaderFile - -#include -#include - -class IntPolyh_Couple; - -class IntPolyh_CoupleMapHasher -{ -public: - - //! Computes a hash code for the given couple, in the range [1, theUpperBound] - //! @param theCouple the couple which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const IntPolyh_Couple& theCouple, const Standard_Integer theUpperBound) - { - return theCouple.HashCode (theUpperBound); - } - - static Standard_Boolean IsEqual(const IntPolyh_Couple& theCouple1, - const IntPolyh_Couple& theCouple2) - { - return theCouple1.IsEqual(theCouple2); - } - -protected: - -private: - -}; - -#endif // _IntPolyh_CoupleMapHasher_HeaderFile diff --git a/src/IntPolyh/IntPolyh_Intersection.cxx b/src/IntPolyh/IntPolyh_Intersection.cxx index 0c8b2d59cd..8e26bf0a80 100644 --- a/src/IntPolyh/IntPolyh_Intersection.cxx +++ b/src/IntPolyh/IntPolyh_Intersection.cxx @@ -20,7 +20,6 @@ #include #include -#include #include #include #include @@ -419,7 +418,7 @@ void IntPolyh_Intersection::MergeCouples(IntPolyh_ListOfCouples &anArrayFF, IntPolyh_ListOfCouples &anArrayRR) const { // Fence map to remove from the lists the duplicating elements. - NCollection_Map aFenceMap; + NCollection_Map aFenceMap; // IntPolyh_ListOfCouples* pLists[4] = {&anArrayFF, &anArrayFR, &anArrayRF, &anArrayRR}; for (Standard_Integer i = 0; i < 4; ++i) { diff --git a/src/IntPolyh/IntPolyh_MaillageAffinage.cxx b/src/IntPolyh/IntPolyh_MaillageAffinage.cxx index 1e2300416b..776921378f 100644 --- a/src/IntPolyh/IntPolyh_MaillageAffinage.cxx +++ b/src/IntPolyh/IntPolyh_MaillageAffinage.cxx @@ -47,8 +47,7 @@ typedef NCollection_Array1 IntPolyh_ArrayOfInteger; typedef NCollection_IndexedDataMap IntPolyh_IndexedDataMapOfIntegerListOfInteger; + TColStd_ListOfInteger> IntPolyh_IndexedDataMapOfIntegerListOfInteger; static Standard_Real MyTolerance=10.0e-7; diff --git a/src/IntPolyh/IntPolyh_SectionLine.hxx b/src/IntPolyh/IntPolyh_SectionLine.hxx index 6ceed6368e..c4f03c787c 100644 --- a/src/IntPolyh/IntPolyh_SectionLine.hxx +++ b/src/IntPolyh/IntPolyh_SectionLine.hxx @@ -36,6 +36,11 @@ public: Standard_EXPORT IntPolyh_SectionLine(); Standard_EXPORT IntPolyh_SectionLine(const Standard_Integer nn); + + IntPolyh_SectionLine(const IntPolyh_SectionLine& theOther) + { + Copy(theOther); + } Standard_EXPORT void Init (const Standard_Integer nn); diff --git a/src/IntTools/FILES b/src/IntTools/FILES index 0bd06c732f..abcaf104f5 100644 --- a/src/IntTools/FILES +++ b/src/IntTools/FILES @@ -17,8 +17,6 @@ IntTools_CurveRangeLocalizeData.cxx IntTools_CurveRangeLocalizeData.hxx IntTools_CurveRangeSample.cxx IntTools_CurveRangeSample.hxx -IntTools_CurveRangeSampleMapHasher.hxx -IntTools_DataMapIteratorOfDataMapOfCurveSampleBox.hxx IntTools_DataMapIteratorOfDataMapOfSurfaceSampleBox.hxx IntTools_DataMapOfCurveSampleBox.hxx IntTools_DataMapOfSurfaceSampleBox.hxx @@ -64,7 +62,6 @@ IntTools_SurfaceRangeLocalizeData.lxx IntTools_SurfaceRangeSample.cxx IntTools_SurfaceRangeSample.hxx IntTools_SurfaceRangeSample.lxx -IntTools_SurfaceRangeSampleMapHasher.hxx IntTools_Tools.cxx IntTools_Tools.hxx IntTools_TopolTool.cxx diff --git a/src/IntTools/IntTools_BeanFaceIntersector.cxx b/src/IntTools/IntTools_BeanFaceIntersector.cxx index b5095096eb..aa0318de99 100644 --- a/src/IntTools/IntTools_BeanFaceIntersector.cxx +++ b/src/IntTools/IntTools_BeanFaceIntersector.cxx @@ -2334,7 +2334,7 @@ static void MergeSolutions(const IntTools_ListOfCurveRangeSample& theListCurveRa IntTools_ListOfCurveRangeSample& theListCurveRangeSort, IntTools_ListOfSurfaceRangeSample& theListSurfaceRangeSort) { - NCollection_IndexedMap aMapToAvoid; + NCollection_IndexedMap aMapToAvoid; NCollection_DataMap aCurveIdMap; std::vector aCurveRangeVector; diff --git a/src/IntTools/IntTools_Context.cxx b/src/IntTools/IntTools_Context.cxx index 6c4deb2777..4116dc3436 100644 --- a/src/IntTools/IntTools_Context.cxx +++ b/src/IntTools/IntTools_Context.cxx @@ -125,7 +125,7 @@ IntTools_Context::~IntTools_Context() } mySClassMap.Clear(); - for (NCollection_DataMap::Iterator anIt (myProjPTMap); + for (NCollection_DataMap::Iterator anIt (myProjPTMap); anIt.More(); anIt.Next()) { GeomAPI_ProjectPointOnCurve* pProjPT = anIt.Value(); diff --git a/src/IntTools/IntTools_Context.hxx b/src/IntTools/IntTools_Context.hxx index eebffed2cb..a39b8299b5 100644 --- a/src/IntTools/IntTools_Context.hxx +++ b/src/IntTools/IntTools_Context.hxx @@ -26,7 +26,6 @@ #include #include #include -#include class IntTools_FClass2d; class TopoDS_Face; class GeomAPI_ProjectPointOnSurf; @@ -247,7 +246,7 @@ protected: NCollection_DataMap myProjPSMap; NCollection_DataMap myProjPCMap; NCollection_DataMap mySClassMap; - NCollection_DataMap myProjPTMap; + NCollection_DataMap myProjPTMap; NCollection_DataMap myHatcherMap; NCollection_DataMap myProjSDataMap; NCollection_DataMap myBndBoxDataMap; diff --git a/src/IntTools/IntTools_CurveRangeSample.hxx b/src/IntTools/IntTools_CurveRangeSample.hxx index 5375015feb..c3e0d0b116 100644 --- a/src/IntTools/IntTools_CurveRangeSample.hxx +++ b/src/IntTools/IntTools_CurveRangeSample.hxx @@ -21,6 +21,7 @@ #include #include +#include #include #include @@ -47,6 +48,11 @@ public: return ((myIndex == Other.myIndex) && (GetDepth() == Other.GetDepth())); } + bool operator==(const IntTools_CurveRangeSample& Other) const + { + return IsEqual(Other); + } + Standard_EXPORT IntTools_Range GetRange (const Standard_Real theFirst, const Standard_Real theLast, const Standard_Integer theNbSample) const; Standard_Integer GetRangeIndexDeeper (const Standard_Integer theNbSample) const @@ -60,4 +66,18 @@ private: }; +namespace std +{ + template <> + struct hash + { + size_t operator()(const IntTools_CurveRangeSample& theCurveRangeSample) const noexcept + { + // Combine two int values into a single hash value. + int aCombination[2]{ theCurveRangeSample.GetDepth(), theCurveRangeSample.GetRangeIndex() }; + return opencascade::hashBytes(aCombination, sizeof(aCombination)); + } + }; +} + #endif // _IntTools_CurveRangeSample_HeaderFile diff --git a/src/IntTools/IntTools_CurveRangeSampleMapHasher.hxx b/src/IntTools/IntTools_CurveRangeSampleMapHasher.hxx deleted file mode 100644 index 0a3ca3563f..0000000000 --- a/src/IntTools/IntTools_CurveRangeSampleMapHasher.hxx +++ /dev/null @@ -1,50 +0,0 @@ -// Created on: 2005-10-14 -// Created by: Mikhail KLOKOV -// Copyright (c) 2005-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _IntTools_CurveRangeSampleMapHasher_HeaderFile -#define _IntTools_CurveRangeSampleMapHasher_HeaderFile - -#include -#include -#include -#include - -//! class for range index management of curve -class IntTools_CurveRangeSampleMapHasher -{ -public: - - DEFINE_STANDARD_ALLOC - - //! Computes a hash code for the given key, in the range [1, theUpperBound] - //! @param theKey the key which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const IntTools_CurveRangeSample& theKey, const Standard_Integer theUpperBound) - { - return ::HashCode(theKey.GetDepth(), theUpperBound); - } - - //! Returns True when the two keys are the same. Two - //! same keys must have the same hashcode, the - //! contrary is not necessary. - static Standard_Boolean IsEqual (const IntTools_CurveRangeSample& S1, const IntTools_CurveRangeSample& S2) - { - return S1.IsEqual(S2); - } - -}; - -#endif // _IntTools_CurveRangeSampleMapHasher_HeaderFile diff --git a/src/IntTools/IntTools_DataMapIteratorOfDataMapOfCurveSampleBox.hxx b/src/IntTools/IntTools_DataMapIteratorOfDataMapOfCurveSampleBox.hxx deleted file mode 100644 index e8f1708929..0000000000 --- a/src/IntTools/IntTools_DataMapIteratorOfDataMapOfCurveSampleBox.hxx +++ /dev/null @@ -1,20 +0,0 @@ -// Copyright (c) 2015 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - - -#ifndef IntTools_DataMapIteratorOfDataMapOfCurveSampleBox_HeaderFile -#define IntTools_DataMapIteratorOfDataMapOfCurveSampleBox_HeaderFile - -#include - -#endif diff --git a/src/IntTools/IntTools_DataMapOfCurveSampleBox.hxx b/src/IntTools/IntTools_DataMapOfCurveSampleBox.hxx index b7a66ed193..ca789167ec 100644 --- a/src/IntTools/IntTools_DataMapOfCurveSampleBox.hxx +++ b/src/IntTools/IntTools_DataMapOfCurveSampleBox.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DataMap IntTools_DataMapOfCurveSampleBox; -typedef NCollection_DataMap::Iterator IntTools_DataMapIteratorOfDataMapOfCurveSampleBox; +typedef NCollection_DataMap IntTools_DataMapOfCurveSampleBox; +typedef NCollection_DataMap::Iterator IntTools_DataMapIteratorOfDataMapOfCurveSampleBox; #endif diff --git a/src/IntTools/IntTools_DataMapOfSurfaceSampleBox.hxx b/src/IntTools/IntTools_DataMapOfSurfaceSampleBox.hxx index d716633d60..c6f7c2a8d4 100644 --- a/src/IntTools/IntTools_DataMapOfSurfaceSampleBox.hxx +++ b/src/IntTools/IntTools_DataMapOfSurfaceSampleBox.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DataMap IntTools_DataMapOfSurfaceSampleBox; -typedef NCollection_DataMap::Iterator IntTools_DataMapIteratorOfDataMapOfSurfaceSampleBox; +typedef NCollection_DataMap IntTools_DataMapOfSurfaceSampleBox; +typedef NCollection_DataMap::Iterator IntTools_DataMapIteratorOfDataMapOfSurfaceSampleBox; #endif diff --git a/src/IntTools/IntTools_FaceFace.cxx b/src/IntTools/IntTools_FaceFace.cxx index b95022f00b..d2c99d7acb 100644 --- a/src/IntTools/IntTools_FaceFace.cxx +++ b/src/IntTools/IntTools_FaceFace.cxx @@ -391,7 +391,7 @@ void IntTools_FaceFace::Perform (const TopoDS_Face& aF1, aItP2S.Initialize(myListOfPnts); for (; aItP2S.More(); aItP2S.Next()) { - IntSurf_PntOn2S& aP2S=aItP2S.Value(); + IntSurf_PntOn2S& aP2S=aItP2S.ChangeValue(); aP2S.Parameters(aU1,aV1,aU2,aV2); aP2S.SetValue(aU2,aV2,aU1,aV1); } diff --git a/src/IntTools/IntTools_MapOfCurveSample.hxx b/src/IntTools/IntTools_MapOfCurveSample.hxx index 9377d9a900..434aab2df8 100644 --- a/src/IntTools/IntTools_MapOfCurveSample.hxx +++ b/src/IntTools/IntTools_MapOfCurveSample.hxx @@ -17,11 +17,10 @@ #define IntTools_MapOfCurveSample_HeaderFile #include -#include #include -typedef NCollection_Map IntTools_MapOfCurveSample; -typedef NCollection_Map::Iterator IntTools_MapIteratorOfMapOfCurveSample; +typedef NCollection_Map IntTools_MapOfCurveSample; +typedef NCollection_Map::Iterator IntTools_MapIteratorOfMapOfCurveSample; #endif diff --git a/src/IntTools/IntTools_MapOfSurfaceSample.hxx b/src/IntTools/IntTools_MapOfSurfaceSample.hxx index e7ffe2fbfc..8dd5178336 100644 --- a/src/IntTools/IntTools_MapOfSurfaceSample.hxx +++ b/src/IntTools/IntTools_MapOfSurfaceSample.hxx @@ -17,11 +17,10 @@ #define IntTools_MapOfSurfaceSample_HeaderFile #include -#include #include -typedef NCollection_Map IntTools_MapOfSurfaceSample; -typedef NCollection_Map::Iterator IntTools_MapIteratorOfMapOfSurfaceSample; +typedef NCollection_Map IntTools_MapOfSurfaceSample; +typedef NCollection_Map::Iterator IntTools_MapIteratorOfMapOfSurfaceSample; #endif diff --git a/src/IntTools/IntTools_SurfaceRangeSample.hxx b/src/IntTools/IntTools_SurfaceRangeSample.hxx index 15f86977ff..ce930e70f3 100644 --- a/src/IntTools/IntTools_SurfaceRangeSample.hxx +++ b/src/IntTools/IntTools_SurfaceRangeSample.hxx @@ -90,6 +90,10 @@ IntTools_SurfaceRangeSample& operator = (const IntTools_SurfaceRangeSample& Othe Standard_Integer GetRangeIndexVDeeper (const Standard_Integer theNbSampleV) const; + bool operator==(const IntTools_SurfaceRangeSample& theOther) const + { + return IsEqual(theOther); + } diff --git a/src/IntTools/IntTools_SurfaceRangeSample.lxx b/src/IntTools/IntTools_SurfaceRangeSample.lxx index b962fe7374..9bbec91d10 100644 --- a/src/IntTools/IntTools_SurfaceRangeSample.lxx +++ b/src/IntTools/IntTools_SurfaceRangeSample.lxx @@ -13,6 +13,8 @@ // Alternatively, this file may be used under the terms of Open CASCADE // commercial license or contractual agreement. +#include + inline void IntTools_SurfaceRangeSample::SetRanges(const IntTools_CurveRangeSample& theRangeU, const IntTools_CurveRangeSample& theRangeV) { @@ -138,3 +140,18 @@ inline Standard_Integer IntTools_SurfaceRangeSample::GetRangeIndexVDeeper(const { return myRangeV.GetRangeIndexDeeper(theNbSampleV); } + +namespace std +{ + template <> + struct hash + { + size_t operator()(const IntTools_SurfaceRangeSample& theSurfaceRangeSample) const noexcept + { + // Combine two int values into a single hash value. + size_t aCombination[2]{ std::hash{}(theSurfaceRangeSample.GetSampleRangeU()), + std::hash{}(theSurfaceRangeSample.GetSampleRangeV()) }; + return opencascade::hashBytes(aCombination, sizeof(aCombination)); + } + }; +} diff --git a/src/IntTools/IntTools_SurfaceRangeSampleMapHasher.hxx b/src/IntTools/IntTools_SurfaceRangeSampleMapHasher.hxx deleted file mode 100644 index ae8a35bfe9..0000000000 --- a/src/IntTools/IntTools_SurfaceRangeSampleMapHasher.hxx +++ /dev/null @@ -1,49 +0,0 @@ -// Created on: 2005-10-14 -// Created by: Mikhail KLOKOV -// Copyright (c) 2005-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _IntTools_SurfaceRangeSampleMapHasher_HeaderFile -#define _IntTools_SurfaceRangeSampleMapHasher_HeaderFile - -#include -#include -#include -#include - -class IntTools_SurfaceRangeSampleMapHasher -{ -public: - - DEFINE_STANDARD_ALLOC - - //! Computes a hash code for the given key, in the range [1, theUpperBound] - //! @param theKey the key which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const IntTools_SurfaceRangeSample& theKey, Standard_Integer theUpperBound) - { - return ::HashCode (theKey.GetIndexU() * theKey.GetIndexV(), theUpperBound); - } - - //! Returns True when the two keys are the same. Two - //! same keys must have the same hashcode, the - //! contrary is not necessary. - static Standard_Boolean IsEqual (const IntTools_SurfaceRangeSample& S1, const IntTools_SurfaceRangeSample& S2) - { - return S1.IsEqual(S2); - } - -}; - -#endif // _IntTools_SurfaceRangeSampleMapHasher_HeaderFile diff --git a/src/IntWalk/IntWalk_VectorOfInteger.hxx b/src/IntWalk/IntWalk_VectorOfInteger.hxx index 4de3a4dcdf..fc9a6a5289 100755 --- a/src/IntWalk/IntWalk_VectorOfInteger.hxx +++ b/src/IntWalk/IntWalk_VectorOfInteger.hxx @@ -17,11 +17,11 @@ #define IntWalk_VectorOfInteger_HeaderFile #include -#include +#include // Defines a dynamic vector of integer. -typedef std::vector > +typedef std::vector > IntWalk_VectorOfInteger; #endif diff --git a/src/IntWalk/IntWalk_VectorOfWalkingData.hxx b/src/IntWalk/IntWalk_VectorOfWalkingData.hxx index ec973df27e..bcb1a04dcb 100755 --- a/src/IntWalk/IntWalk_VectorOfWalkingData.hxx +++ b/src/IntWalk/IntWalk_VectorOfWalkingData.hxx @@ -17,7 +17,7 @@ #define IntWalk_VectorOfWalkingData_HeaderFile #include -#include +#include // Defines a dynamic vector of work data. @@ -28,7 +28,7 @@ struct IntWalk_WalkingData Standard_Integer etat; }; -typedef std::vector > +typedef std::vector > IntWalk_VectorOfWalkingData; #endif diff --git a/src/Interface/FILES b/src/Interface/FILES index ca32e3abdb..ac3bf215e2 100755 --- a/src/Interface/FILES +++ b/src/Interface/FILES @@ -66,8 +66,6 @@ Interface_JaggedArray.gxx Interface_LineBuffer.cxx Interface_LineBuffer.hxx Interface_Macros.hxx -Interface_MapAsciiStringHasher.cxx -Interface_MapAsciiStringHasher.hxx Interface_MSG.cxx Interface_MSG.hxx Interface_NodeOfGeneralLib.hxx diff --git a/src/Interface/Interface_DataMapOfTransientInteger.hxx b/src/Interface/Interface_DataMapOfTransientInteger.hxx index 3f543997bc..edf7f57fc8 100644 --- a/src/Interface/Interface_DataMapOfTransientInteger.hxx +++ b/src/Interface/Interface_DataMapOfTransientInteger.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap Interface_DataMapOfTransientInteger; -typedef NCollection_DataMap::Iterator Interface_DataMapIteratorOfDataMapOfTransientInteger; +typedef NCollection_DataMap Interface_DataMapOfTransientInteger; +typedef NCollection_DataMap::Iterator Interface_DataMapIteratorOfDataMapOfTransientInteger; #endif diff --git a/src/Interface/Interface_IndexedMapOfAsciiString.hxx b/src/Interface/Interface_IndexedMapOfAsciiString.hxx index af8352569c..3b64b0cc13 100644 --- a/src/Interface/Interface_IndexedMapOfAsciiString.hxx +++ b/src/Interface/Interface_IndexedMapOfAsciiString.hxx @@ -18,10 +18,9 @@ #define Interface_IndexedMapOfAsciiString_HeaderFile #include -#include #include -typedef NCollection_IndexedMap Interface_IndexedMapOfAsciiString; +typedef NCollection_IndexedMap Interface_IndexedMapOfAsciiString; #endif diff --git a/src/Interface/Interface_MapAsciiStringHasher.cxx b/src/Interface/Interface_MapAsciiStringHasher.cxx deleted file mode 100644 index e7a24f319a..0000000000 --- a/src/Interface/Interface_MapAsciiStringHasher.cxx +++ /dev/null @@ -1,38 +0,0 @@ -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - - -#include -#include - -//======================================================================= -// function : HashCode -// purpose : -//======================================================================= -Standard_Integer Interface_MapAsciiStringHasher::HashCode (const TCollection_AsciiString& theAsciiString, - const Standard_Integer theUpperBound) -{ - return ::HashCode (theAsciiString.ToCString(), theAsciiString.Length(), theUpperBound); -} - -//======================================================================= -//function : IsEqual -//purpose : -//======================================================================= - -Standard_Boolean Interface_MapAsciiStringHasher::IsEqual(const TCollection_AsciiString& K1, - const TCollection_AsciiString& K2) -{ - if(!K1.Length() || !K2.Length()) return Standard_False; - return K1.IsEqual(K2); -} diff --git a/src/Interface/Interface_MapAsciiStringHasher.hxx b/src/Interface/Interface_MapAsciiStringHasher.hxx deleted file mode 100644 index ee0d52e292..0000000000 --- a/src/Interface/Interface_MapAsciiStringHasher.hxx +++ /dev/null @@ -1,66 +0,0 @@ -// Created on: 2003-05-06 -// Created by: Galina KULIKOVA -// Copyright (c) 2003-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _Interface_MapAsciiStringHasher_HeaderFile -#define _Interface_MapAsciiStringHasher_HeaderFile - -#include -#include -#include - -#include -class TCollection_AsciiString; - - - -class Interface_MapAsciiStringHasher -{ -public: - - DEFINE_STANDARD_ALLOC - - //! Computes a hash code for the given ASCII string, in the range [1, theUpperBound] - //! @param theAsciiString the ASCII string which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - Standard_EXPORT static Standard_Integer HashCode (const TCollection_AsciiString& theAsciiString, - Standard_Integer theUpperBound); - - Standard_EXPORT static Standard_Boolean IsEqual (const TCollection_AsciiString& K1, const TCollection_AsciiString& K2); - - - - -protected: - - - - - -private: - - - - - -}; - - - - - - - -#endif // _Interface_MapAsciiStringHasher_HeaderFile diff --git a/src/Interface/Interface_Static.cxx b/src/Interface/Interface_Static.cxx index afa597d56e..84082f7ae5 100644 --- a/src/Interface/Interface_Static.cxx +++ b/src/Interface/Interface_Static.cxx @@ -412,7 +412,7 @@ Handle(TColStd_HSequenceOfHAsciiString) Interface_Static::Items // function : FillMap // purpose : Fills given string-to-string map with all static data //======================================================================= -void Interface_Static::FillMap (NCollection_DataMap& theMap) +void Interface_Static::FillMap (NCollection_DataMap& theMap) { theMap.Clear(); diff --git a/src/Interface/Interface_Static.hxx b/src/Interface/Interface_Static.hxx index 7069c5f361..a6de9ce27a 100644 --- a/src/Interface/Interface_Static.hxx +++ b/src/Interface/Interface_Static.hxx @@ -246,7 +246,7 @@ public: Standard_EXPORT static void Standards(); //! Fills given string-to-string map with all static data - Standard_EXPORT static void FillMap(NCollection_DataMap& theMap); + Standard_EXPORT static void FillMap(NCollection_DataMap& theMap); DEFINE_STANDARD_RTTIEXT(Interface_Static,Interface_TypedValue) diff --git a/src/LocOpe/LocOpe_BuildShape.cxx b/src/LocOpe/LocOpe_BuildShape.cxx index 1d0baf9012..9e02f13b1a 100644 --- a/src/LocOpe/LocOpe_BuildShape.cxx +++ b/src/LocOpe/LocOpe_BuildShape.cxx @@ -243,7 +243,7 @@ void LocOpe_BuildShape::Perform(const TopTools_ListOfShape& L) imbSh.UnBind(itdm.Key()); } else { - for (itdm.Reset(); itdm.More(); itdm.Next()) { + for (itdm.Initialize(imbSh); itdm.More(); itdm.Next()) { TopoDS_Solid newSo; B.MakeSolid(newSo); B.Add(newSo,itdm.Key()); diff --git a/src/LocOpe/LocOpe_Generator.cxx b/src/LocOpe/LocOpe_Generator.cxx index b572dd1885..0c242f62eb 100644 --- a/src/LocOpe/LocOpe_Generator.cxx +++ b/src/LocOpe/LocOpe_Generator.cxx @@ -137,7 +137,6 @@ void LocOpe_Generator::Perform(const Handle(LocOpe_GeneratedShape)& G) TopTools_DataMapOfShapeListOfShape theFFMap; TopTools_MapOfShape toRemove; TopTools_MapIteratorOfMapOfShape itm; - TopTools_DataMapIteratorOfDataMapOfShapeListOfShape itf; // recherche des fusions de faces for (itm.Initialize(GEdg); itm.More(); itm.Next()) { @@ -158,7 +157,7 @@ void LocOpe_Generator::Perform(const Handle(LocOpe_GeneratedShape)& G) if (ToFuse(fac,facbis)) { // On recherche si une face a deja fusionne avec facbis Standard_Boolean facbisfound = Standard_False; - for (itf.Initialize(theFFMap); itf.More(); itf.Next()) { + for (TopTools_DataMapIteratorOfDataMapOfShapeListOfShape itf(theFFMap); itf.More(); itf.Next()) { if (itf.Key().IsSame(fac)) { continue; } @@ -204,8 +203,8 @@ void LocOpe_Generator::Perform(const Handle(LocOpe_GeneratedShape)& G) // a fusionner avec une meme face de base // TopTools_DataMapIteratorOfDataMapOfShapeListOfShape itf(theFFMap); - itf.Initialize(theFFMap); - for (; itf.More(); itf.Next()) { + for (TopTools_DataMapIteratorOfDataMapOfShapeListOfShape itf(theFFMap); itf.More(); itf.Next()) + { for (itl.Initialize(itf.Value()); itl.More(); itl.Next()) { for (exp.Init(itl.Value(),TopAbs_EDGE); exp.More(); exp.Next()) { const TopoDS_Edge& ed = TopoDS::Edge(exp.Current()); @@ -234,7 +233,8 @@ void LocOpe_Generator::Perform(const Handle(LocOpe_GeneratedShape)& G) TopTools_DataMapOfShapeShape DontFuse; TopAbs_Orientation orient,orface; - for (itf.Reset(); itf.More(); itf.Next()) { + for (TopTools_DataMapIteratorOfDataMapOfShapeListOfShape itf(theFFMap); itf.More(); itf.Next()) + { const TopoDS_Face& fac = TopoDS::Face(itf.Key()); for (exp.Init(fac,TopAbs_EDGE); exp.More(); exp.Next()) { const TopoDS_Edge& edg = TopoDS::Edge(exp.Current()); @@ -445,7 +445,8 @@ void LocOpe_Generator::Perform(const Handle(LocOpe_GeneratedShape)& G) TopTools_MapOfShape EdgAdded; // Fusion des faces, ou reconstruction - for (itf.Reset();itf.More(); itf.Next()) { + for (TopTools_DataMapIteratorOfDataMapOfShapeListOfShape itf(theFFMap);itf.More(); itf.Next()) + { const TopoDS_Face& fac = TopoDS::Face(itf.Key()); Standard_Boolean ModFace = Standard_False; TopTools_ListOfShape listofedg; diff --git a/src/LocOpe/LocOpe_Pipe.cxx b/src/LocOpe/LocOpe_Pipe.cxx index bd6def2638..9e1613cb00 100644 --- a/src/LocOpe/LocOpe_Pipe.cxx +++ b/src/LocOpe/LocOpe_Pipe.cxx @@ -109,7 +109,7 @@ LocOpe_Pipe::LocOpe_Pipe(const TopoDS_Wire& Spine, } while (MapFac.Extent() >= 2) { - itm.Reset(); + itm = TopTools_MapIteratorOfMapOfShape(MapFac); TopTools_ListOfShape FacFuse; TopoDS_Face FaceRef = TopoDS::Face(itm.Key()); FacFuse.Append(FaceRef); diff --git a/src/LocOpe/LocOpe_SplitDrafts.cxx b/src/LocOpe/LocOpe_SplitDrafts.cxx index edce77fcf6..cf0829b849 100644 --- a/src/LocOpe/LocOpe_SplitDrafts.cxx +++ b/src/LocOpe/LocOpe_SplitDrafts.cxx @@ -1401,7 +1401,7 @@ static void MakeFace(TopoDS_Face& F, // for (TopTools_ListIteratorOfListOfShape itl(ledg); TopTools_ListIteratorOfListOfShape itl(ledg) ; for ( ; itl.More(); itl.Next()) { - TopoDS_Edge& edg = TopoDS::Edge(itl.Value()); + const TopoDS_Edge& edg = TopoDS::Edge(itl.Value()); Handle(Geom2d_Curve) C2d = BRep_Tool::CurveOnSurface(edg,F,f,l); if (C2d.IsNull()) { BRep_Tool::Range(edg,f,l); @@ -1528,7 +1528,7 @@ static void MakeFace(TopoDS_Face& F, GProp_GProps GP; BRepGProp::SurfaceProperties(NewFace,GP); if (GP.Mass() < 0) { - itl.Value().Reverse(); + itl.ChangeValue().Reverse(); } } if (lwires.Extent() == 1) { diff --git a/src/LocOpe/LocOpe_SplitShape.cxx b/src/LocOpe/LocOpe_SplitShape.cxx index 6922896185..72ed0729f5 100644 --- a/src/LocOpe/LocOpe_SplitShape.cxx +++ b/src/LocOpe/LocOpe_SplitShape.cxx @@ -515,7 +515,7 @@ Standard_Boolean LocOpe_SplitShape::Add(const TopTools_ListOfShape& Lwires, const TopoDS_Wire& aHole = TopoDS::Wire(itl.Value()); for (itlNewF.Initialize(NewFaces); itlNewF.More(); itlNewF.Next()) { - TopoDS_Face& aNewFace = TopoDS::Face(itlNewF.Value()); + TopoDS_Face& aNewFace = TopoDS::Face(itlNewF.ChangeValue()); if (IsInside(aNewFace, aHole)) { BB.Add(aNewFace, aHole); diff --git a/src/LocOpe/LocOpe_Spliter.cxx b/src/LocOpe/LocOpe_Spliter.cxx index 5f282ddf65..ee5e5d8811 100644 --- a/src/LocOpe/LocOpe_Spliter.cxx +++ b/src/LocOpe/LocOpe_Spliter.cxx @@ -112,11 +112,11 @@ void LocOpe_Spliter::Perform(const Handle(LocOpe_WiresOnShape)& PW) } theSubs.Build(myShape); - TopTools_DataMapIteratorOfDataMapOfShapeListOfShape itdesc(myMap); if (theSubs.IsCopied(myShape)) { // on n`a fait que des substitutions de vertex. Donc chaque element // est remplace par lui meme ou par un seul element du meme type. - for (; itdesc.More(); itdesc.Next()) { + for (TopTools_DataMapIteratorOfDataMapOfShapeListOfShape itdesc(myMap); itdesc.More(); itdesc.Next()) + { if (theSubs.IsCopied(itdesc.Key())) { const TopTools_ListOfShape& lsub = theSubs.Copy(itdesc.Key()); #ifdef OCCT_DEBUG @@ -193,7 +193,8 @@ void LocOpe_Spliter::Perform(const Handle(LocOpe_WiresOnShape)& PW) // Mise a jour des descendants - for (itdesc.Reset(); itdesc.More(); itdesc.Next()) { + for (TopTools_DataMapIteratorOfDataMapOfShapeListOfShape itdesc(myMap); itdesc.More(); itdesc.Next()) + { const TopoDS_Shape& sori = itdesc.Key(); const TopoDS_Shape& scib = itdesc.Value().First(); myMap(sori) = theCFace.DescendantShapes(scib); @@ -294,7 +295,8 @@ void LocOpe_Spliter::Perform(const Handle(LocOpe_WiresOnShape)& PW) theSubs.Build(myRes); - for (itdesc.Reset(); itdesc.More(); itdesc.Next()) { + for (TopTools_DataMapIteratorOfDataMapOfShapeListOfShape itdesc(myMap); itdesc.More(); itdesc.Next()) + { TopTools_ListOfShape& ldesc = myMap(itdesc.Key()); TopTools_ListOfShape newdesc; for (itl.Initialize(ldesc); itl.More(); itl.Next()) { @@ -471,7 +473,7 @@ void LocOpe_Spliter::Perform(const Handle(LocOpe_WiresOnShape)& PW) } } if (itms.More()) { - const TopoDS_Shape& fac = itms.Key(); + TopoDS_Shape fac = itms.Key(); for (exp.Init(fac,TopAbs_EDGE); exp.More(); exp.Next()) { if (!Mapebord.Add(exp.Current())) { Mapebord.Remove(exp.Current()); diff --git a/src/MAT/MAT_Arc.hxx b/src/MAT/MAT_Arc.hxx index da7558aae1..8725fdfead 100644 --- a/src/MAT/MAT_Arc.hxx +++ b/src/MAT/MAT_Arc.hxx @@ -21,7 +21,6 @@ #include #include -#include #include #include class MAT_BasicElt; diff --git a/src/MAT/MAT_BasicElt.hxx b/src/MAT/MAT_BasicElt.hxx index 63372345c8..37d2980499 100644 --- a/src/MAT/MAT_BasicElt.hxx +++ b/src/MAT/MAT_BasicElt.hxx @@ -20,7 +20,6 @@ #include #include -#include #include #include class MAT_Arc; diff --git a/src/MAT/MAT_DataMapOfIntegerArc.hxx b/src/MAT/MAT_DataMapOfIntegerArc.hxx index b889ac3a5c..343429574e 100644 --- a/src/MAT/MAT_DataMapOfIntegerArc.hxx +++ b/src/MAT/MAT_DataMapOfIntegerArc.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap MAT_DataMapOfIntegerArc; -typedef NCollection_DataMap::Iterator MAT_DataMapIteratorOfDataMapOfIntegerArc; +typedef NCollection_DataMap MAT_DataMapOfIntegerArc; +typedef NCollection_DataMap::Iterator MAT_DataMapIteratorOfDataMapOfIntegerArc; #endif diff --git a/src/MAT/MAT_DataMapOfIntegerBasicElt.hxx b/src/MAT/MAT_DataMapOfIntegerBasicElt.hxx index adc053a0a3..5b8143f847 100644 --- a/src/MAT/MAT_DataMapOfIntegerBasicElt.hxx +++ b/src/MAT/MAT_DataMapOfIntegerBasicElt.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap MAT_DataMapOfIntegerBasicElt; -typedef NCollection_DataMap::Iterator MAT_DataMapIteratorOfDataMapOfIntegerBasicElt; +typedef NCollection_DataMap MAT_DataMapOfIntegerBasicElt; +typedef NCollection_DataMap::Iterator MAT_DataMapIteratorOfDataMapOfIntegerBasicElt; #endif diff --git a/src/MAT/MAT_DataMapOfIntegerBisector.hxx b/src/MAT/MAT_DataMapOfIntegerBisector.hxx index d4d990c439..b2f4dda8a9 100644 --- a/src/MAT/MAT_DataMapOfIntegerBisector.hxx +++ b/src/MAT/MAT_DataMapOfIntegerBisector.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap MAT_DataMapOfIntegerBisector; -typedef NCollection_DataMap::Iterator MAT_DataMapIteratorOfDataMapOfIntegerBisector; +typedef NCollection_DataMap MAT_DataMapOfIntegerBisector; +typedef NCollection_DataMap::Iterator MAT_DataMapIteratorOfDataMapOfIntegerBisector; #endif diff --git a/src/MAT/MAT_DataMapOfIntegerNode.hxx b/src/MAT/MAT_DataMapOfIntegerNode.hxx index 5bfd7d8227..d11a4c14be 100644 --- a/src/MAT/MAT_DataMapOfIntegerNode.hxx +++ b/src/MAT/MAT_DataMapOfIntegerNode.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap MAT_DataMapOfIntegerNode; -typedef NCollection_DataMap::Iterator MAT_DataMapIteratorOfDataMapOfIntegerNode; +typedef NCollection_DataMap MAT_DataMapOfIntegerNode; +typedef NCollection_DataMap::Iterator MAT_DataMapIteratorOfDataMapOfIntegerNode; #endif diff --git a/src/MAT/MAT_Node.hxx b/src/MAT/MAT_Node.hxx index 74527243ef..fc68f7096b 100644 --- a/src/MAT/MAT_Node.hxx +++ b/src/MAT/MAT_Node.hxx @@ -21,7 +21,6 @@ #include #include -#include #include #include #include diff --git a/src/MAT2d/FILES b/src/MAT2d/FILES index b342dfc4d9..531a6d12d8 100644 --- a/src/MAT2d/FILES +++ b/src/MAT2d/FILES @@ -21,8 +21,6 @@ MAT2d_DataMapOfIntegerConnexion.hxx MAT2d_DataMapOfIntegerPnt2d.hxx MAT2d_DataMapOfIntegerSequenceOfConnexion.hxx MAT2d_DataMapOfIntegerVec2d.hxx -MAT2d_MapBiIntHasher.hxx -MAT2d_MapBiIntHasher.lxx MAT2d_Mat2d.cxx MAT2d_Mat2d.hxx MAT2d_MiniPath.cxx diff --git a/src/MAT2d/MAT2d_BiInt.hxx b/src/MAT2d/MAT2d_BiInt.hxx index 9e8d45315e..5f16ec3dfa 100644 --- a/src/MAT2d/MAT2d_BiInt.hxx +++ b/src/MAT2d/MAT2d_BiInt.hxx @@ -22,7 +22,7 @@ #include #include - +#include //! BiInt is a set of two integers. class MAT2d_BiInt @@ -67,6 +67,19 @@ private: }; +namespace std +{ + template <> + struct hash + { + size_t operator()(const MAT2d_BiInt& theBiInt) const noexcept + { + // Combine two int values into a single hash value. + int aCombination[2]{ theBiInt.FirstIndex(), theBiInt.SecondIndex() }; + return opencascade::hashBytes(aCombination, sizeof(aCombination)); + } + }; +} diff --git a/src/MAT2d/MAT2d_DataMapOfBiIntInteger.hxx b/src/MAT2d/MAT2d_DataMapOfBiIntInteger.hxx index e67f52c6d0..30083e4ff9 100644 --- a/src/MAT2d/MAT2d_DataMapOfBiIntInteger.hxx +++ b/src/MAT2d/MAT2d_DataMapOfBiIntInteger.hxx @@ -18,11 +18,11 @@ #define MAT2d_DataMapOfBiIntInteger_HeaderFile #include -#include +#include #include -typedef NCollection_DataMap MAT2d_DataMapOfBiIntInteger; -typedef NCollection_DataMap::Iterator MAT2d_DataMapIteratorOfDataMapOfBiIntInteger; +typedef NCollection_DataMap MAT2d_DataMapOfBiIntInteger; +typedef NCollection_DataMap::Iterator MAT2d_DataMapIteratorOfDataMapOfBiIntInteger; #endif diff --git a/src/MAT2d/MAT2d_DataMapOfBiIntSequenceOfInteger.hxx b/src/MAT2d/MAT2d_DataMapOfBiIntSequenceOfInteger.hxx index a7307fa161..1a4e3f01a4 100644 --- a/src/MAT2d/MAT2d_DataMapOfBiIntSequenceOfInteger.hxx +++ b/src/MAT2d/MAT2d_DataMapOfBiIntSequenceOfInteger.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap MAT2d_DataMapOfBiIntSequenceOfInteger; -typedef NCollection_DataMap::Iterator MAT2d_DataMapIteratorOfDataMapOfBiIntSequenceOfInteger; +typedef NCollection_DataMap MAT2d_DataMapOfBiIntSequenceOfInteger; +typedef NCollection_DataMap::Iterator MAT2d_DataMapIteratorOfDataMapOfBiIntSequenceOfInteger; #endif diff --git a/src/MAT2d/MAT2d_DataMapOfIntegerBisec.hxx b/src/MAT2d/MAT2d_DataMapOfIntegerBisec.hxx index 94df70c206..03ab156262 100644 --- a/src/MAT2d/MAT2d_DataMapOfIntegerBisec.hxx +++ b/src/MAT2d/MAT2d_DataMapOfIntegerBisec.hxx @@ -18,11 +18,10 @@ #define MAT2d_DataMapOfIntegerBisec_HeaderFile #include -#include #include -typedef NCollection_DataMap MAT2d_DataMapOfIntegerBisec; -typedef NCollection_DataMap::Iterator MAT2d_DataMapIteratorOfDataMapOfIntegerBisec; +typedef NCollection_DataMap MAT2d_DataMapOfIntegerBisec; +typedef NCollection_DataMap::Iterator MAT2d_DataMapIteratorOfDataMapOfIntegerBisec; #endif diff --git a/src/MAT2d/MAT2d_DataMapOfIntegerConnexion.hxx b/src/MAT2d/MAT2d_DataMapOfIntegerConnexion.hxx index c45622ab78..8924e2a332 100644 --- a/src/MAT2d/MAT2d_DataMapOfIntegerConnexion.hxx +++ b/src/MAT2d/MAT2d_DataMapOfIntegerConnexion.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap MAT2d_DataMapOfIntegerConnexion; -typedef NCollection_DataMap::Iterator MAT2d_DataMapIteratorOfDataMapOfIntegerConnexion; +typedef NCollection_DataMap MAT2d_DataMapOfIntegerConnexion; +typedef NCollection_DataMap::Iterator MAT2d_DataMapIteratorOfDataMapOfIntegerConnexion; #endif diff --git a/src/MAT2d/MAT2d_DataMapOfIntegerPnt2d.hxx b/src/MAT2d/MAT2d_DataMapOfIntegerPnt2d.hxx index 69f0fe8b30..0ec2bab133 100644 --- a/src/MAT2d/MAT2d_DataMapOfIntegerPnt2d.hxx +++ b/src/MAT2d/MAT2d_DataMapOfIntegerPnt2d.hxx @@ -18,11 +18,10 @@ #define MAT2d_DataMapOfIntegerPnt2d_HeaderFile #include -#include #include -typedef NCollection_DataMap MAT2d_DataMapOfIntegerPnt2d; -typedef NCollection_DataMap::Iterator MAT2d_DataMapIteratorOfDataMapOfIntegerPnt2d; +typedef NCollection_DataMap MAT2d_DataMapOfIntegerPnt2d; +typedef NCollection_DataMap::Iterator MAT2d_DataMapIteratorOfDataMapOfIntegerPnt2d; #endif diff --git a/src/MAT2d/MAT2d_DataMapOfIntegerSequenceOfConnexion.hxx b/src/MAT2d/MAT2d_DataMapOfIntegerSequenceOfConnexion.hxx index 2da50d1d1f..6072e216a4 100644 --- a/src/MAT2d/MAT2d_DataMapOfIntegerSequenceOfConnexion.hxx +++ b/src/MAT2d/MAT2d_DataMapOfIntegerSequenceOfConnexion.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap MAT2d_DataMapOfIntegerSequenceOfConnexion; -typedef NCollection_DataMap::Iterator MAT2d_DataMapIteratorOfDataMapOfIntegerSequenceOfConnexion; +typedef NCollection_DataMap MAT2d_DataMapOfIntegerSequenceOfConnexion; +typedef NCollection_DataMap::Iterator MAT2d_DataMapIteratorOfDataMapOfIntegerSequenceOfConnexion; #endif diff --git a/src/MAT2d/MAT2d_DataMapOfIntegerVec2d.hxx b/src/MAT2d/MAT2d_DataMapOfIntegerVec2d.hxx index 217b08bb69..f26bc01fe4 100644 --- a/src/MAT2d/MAT2d_DataMapOfIntegerVec2d.hxx +++ b/src/MAT2d/MAT2d_DataMapOfIntegerVec2d.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap MAT2d_DataMapOfIntegerVec2d; -typedef NCollection_DataMap::Iterator MAT2d_DataMapIteratorOfDataMapOfIntegerVec2d; +typedef NCollection_DataMap MAT2d_DataMapOfIntegerVec2d; +typedef NCollection_DataMap::Iterator MAT2d_DataMapIteratorOfDataMapOfIntegerVec2d; #endif diff --git a/src/MAT2d/MAT2d_MapBiIntHasher.hxx b/src/MAT2d/MAT2d_MapBiIntHasher.hxx deleted file mode 100644 index 2678b33043..0000000000 --- a/src/MAT2d/MAT2d_MapBiIntHasher.hxx +++ /dev/null @@ -1,66 +0,0 @@ -// Created on: 1993-11-19 -// Created by: Yves FRICAUD -// Copyright (c) 1993-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _MAT2d_MapBiIntHasher_HeaderFile -#define _MAT2d_MapBiIntHasher_HeaderFile - -#include -#include - -#include -class MAT2d_BiInt; - - - -class MAT2d_MapBiIntHasher -{ -public: - - DEFINE_STANDARD_ALLOC - - //! Computes a hash code for the given key, in the range [1, theUpperBound] - //! @param theKey the key which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const MAT2d_BiInt& theKey, const Standard_Integer theUpperBound); - - static Standard_Boolean IsEqual (const MAT2d_BiInt& Key1, const MAT2d_BiInt& Key2); - - - - -protected: - - - - - -private: - - - - - -}; - - -#include - - - - - -#endif // _MAT2d_MapBiIntHasher_HeaderFile diff --git a/src/MAT2d/MAT2d_MapBiIntHasher.lxx b/src/MAT2d/MAT2d_MapBiIntHasher.lxx deleted file mode 100644 index 1192c2a393..0000000000 --- a/src/MAT2d/MAT2d_MapBiIntHasher.lxx +++ /dev/null @@ -1,38 +0,0 @@ -// Created on: 1993-11-19 -// Created by: Yves FRICAUD -// Copyright (c) 1993-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#include -#include - -//======================================================================= -// function : HashCode -// purpose : -//======================================================================= -inline Standard_Integer MAT2d_MapBiIntHasher::HashCode (const MAT2d_BiInt& theKey, const Standard_Integer theUpperBound) -{ - return TColStd_MapIntegerHasher::HashCode (theKey.FirstIndex(), theUpperBound); -} - -//======================================================================= -//function : IsEqual -//purpose : -//======================================================================= -inline Standard_Boolean MAT2d_MapBiIntHasher::IsEqual -(const MAT2d_BiInt& Key1, - const MAT2d_BiInt& Key2) -{ - return (Key1 == Key2); -} diff --git a/src/MeshVS/FILES b/src/MeshVS/FILES index 594baa595b..ee58253915 100755 --- a/src/MeshVS/FILES +++ b/src/MeshVS/FILES @@ -77,8 +77,6 @@ MeshVS_Tool.cxx MeshVS_Tool.hxx MeshVS_TwoColors.cxx MeshVS_TwoColors.hxx -MeshVS_TwoColorsHasher.hxx MeshVS_TwoNodes.hxx -MeshVS_TwoNodesHasher.hxx MeshVS_VectorPrsBuilder.cxx MeshVS_VectorPrsBuilder.hxx diff --git a/src/MeshVS/MeshVS_DataMapOfColorMapOfInteger.hxx b/src/MeshVS/MeshVS_DataMapOfColorMapOfInteger.hxx index 6ae3a5ecd9..cdee765cfa 100644 --- a/src/MeshVS/MeshVS_DataMapOfColorMapOfInteger.hxx +++ b/src/MeshVS/MeshVS_DataMapOfColorMapOfInteger.hxx @@ -16,11 +16,11 @@ #ifndef MeshVS_DataMapOfColorMapOfInteger_HeaderFile #define MeshVS_DataMapOfColorMapOfInteger_HeaderFile -#include +#include #include #include -typedef NCollection_DataMap MeshVS_DataMapOfColorMapOfInteger; -typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfColorMapOfInteger; +typedef NCollection_DataMap MeshVS_DataMapOfColorMapOfInteger; +typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfColorMapOfInteger; #endif diff --git a/src/MeshVS/MeshVS_DataMapOfHArray1OfSequenceOfInteger.hxx b/src/MeshVS/MeshVS_DataMapOfHArray1OfSequenceOfInteger.hxx index 37bfd1d8e3..a82242d2f8 100644 --- a/src/MeshVS/MeshVS_DataMapOfHArray1OfSequenceOfInteger.hxx +++ b/src/MeshVS/MeshVS_DataMapOfHArray1OfSequenceOfInteger.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DataMap MeshVS_DataMapOfHArray1OfSequenceOfInteger; -typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfHArray1OfSequenceOfInteger; +typedef NCollection_DataMap MeshVS_DataMapOfHArray1OfSequenceOfInteger; +typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfHArray1OfSequenceOfInteger; #endif diff --git a/src/MeshVS/MeshVS_DataMapOfIntegerAsciiString.hxx b/src/MeshVS/MeshVS_DataMapOfIntegerAsciiString.hxx index 4bbe220953..24375e365b 100644 --- a/src/MeshVS/MeshVS_DataMapOfIntegerAsciiString.hxx +++ b/src/MeshVS/MeshVS_DataMapOfIntegerAsciiString.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DataMap MeshVS_DataMapOfIntegerAsciiString; -typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfIntegerAsciiString; +typedef NCollection_DataMap MeshVS_DataMapOfIntegerAsciiString; +typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfIntegerAsciiString; #endif diff --git a/src/MeshVS/MeshVS_DataMapOfIntegerBoolean.hxx b/src/MeshVS/MeshVS_DataMapOfIntegerBoolean.hxx index 8a7a4b7cbe..299aa3d163 100644 --- a/src/MeshVS/MeshVS_DataMapOfIntegerBoolean.hxx +++ b/src/MeshVS/MeshVS_DataMapOfIntegerBoolean.hxx @@ -17,11 +17,10 @@ #define MeshVS_DataMapOfIntegerBoolean_HeaderFile #include -#include #include -typedef NCollection_DataMap MeshVS_DataMapOfIntegerBoolean; -typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfIntegerBoolean; +typedef NCollection_DataMap MeshVS_DataMapOfIntegerBoolean; +typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfIntegerBoolean; #endif diff --git a/src/MeshVS/MeshVS_DataMapOfIntegerColor.hxx b/src/MeshVS/MeshVS_DataMapOfIntegerColor.hxx index 9e60b66694..c771b7c563 100644 --- a/src/MeshVS/MeshVS_DataMapOfIntegerColor.hxx +++ b/src/MeshVS/MeshVS_DataMapOfIntegerColor.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DataMap MeshVS_DataMapOfIntegerColor; -typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfIntegerColor; +typedef NCollection_DataMap MeshVS_DataMapOfIntegerColor; +typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfIntegerColor; #endif diff --git a/src/MeshVS/MeshVS_DataMapOfIntegerMaterial.hxx b/src/MeshVS/MeshVS_DataMapOfIntegerMaterial.hxx index 207d05441a..e5c73d25a5 100644 --- a/src/MeshVS/MeshVS_DataMapOfIntegerMaterial.hxx +++ b/src/MeshVS/MeshVS_DataMapOfIntegerMaterial.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DataMap MeshVS_DataMapOfIntegerMaterial; -typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfIntegerMaterial; +typedef NCollection_DataMap MeshVS_DataMapOfIntegerMaterial; +typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfIntegerMaterial; #endif diff --git a/src/MeshVS/MeshVS_DataMapOfIntegerMeshEntityOwner.hxx b/src/MeshVS/MeshVS_DataMapOfIntegerMeshEntityOwner.hxx index 000fe8ac0c..a48dce07ba 100644 --- a/src/MeshVS/MeshVS_DataMapOfIntegerMeshEntityOwner.hxx +++ b/src/MeshVS/MeshVS_DataMapOfIntegerMeshEntityOwner.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DataMap MeshVS_DataMapOfIntegerMeshEntityOwner; -typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfIntegerMeshEntityOwner; +typedef NCollection_DataMap MeshVS_DataMapOfIntegerMeshEntityOwner; +typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfIntegerMeshEntityOwner; #endif diff --git a/src/MeshVS/MeshVS_DataMapOfIntegerOwner.hxx b/src/MeshVS/MeshVS_DataMapOfIntegerOwner.hxx index a43a7a50d5..f344dd2633 100644 --- a/src/MeshVS/MeshVS_DataMapOfIntegerOwner.hxx +++ b/src/MeshVS/MeshVS_DataMapOfIntegerOwner.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DataMap MeshVS_DataMapOfIntegerOwner; -typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfIntegerOwner; +typedef NCollection_DataMap MeshVS_DataMapOfIntegerOwner; +typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfIntegerOwner; #endif diff --git a/src/MeshVS/MeshVS_DataMapOfIntegerTwoColors.hxx b/src/MeshVS/MeshVS_DataMapOfIntegerTwoColors.hxx index b634e8393d..bc5cdd318d 100644 --- a/src/MeshVS/MeshVS_DataMapOfIntegerTwoColors.hxx +++ b/src/MeshVS/MeshVS_DataMapOfIntegerTwoColors.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DataMap MeshVS_DataMapOfIntegerTwoColors; -typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfIntegerTwoColors; +typedef NCollection_DataMap MeshVS_DataMapOfIntegerTwoColors; +typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfIntegerTwoColors; #endif diff --git a/src/MeshVS/MeshVS_DataMapOfIntegerVector.hxx b/src/MeshVS/MeshVS_DataMapOfIntegerVector.hxx index 0478b4dc91..34bd103854 100644 --- a/src/MeshVS/MeshVS_DataMapOfIntegerVector.hxx +++ b/src/MeshVS/MeshVS_DataMapOfIntegerVector.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DataMap MeshVS_DataMapOfIntegerVector; -typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfIntegerVector; +typedef NCollection_DataMap MeshVS_DataMapOfIntegerVector; +typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfIntegerVector; #endif diff --git a/src/MeshVS/MeshVS_DataMapOfTwoColorsMapOfInteger.hxx b/src/MeshVS/MeshVS_DataMapOfTwoColorsMapOfInteger.hxx index 1f0a426f60..0206ce1dba 100644 --- a/src/MeshVS/MeshVS_DataMapOfTwoColorsMapOfInteger.hxx +++ b/src/MeshVS/MeshVS_DataMapOfTwoColorsMapOfInteger.hxx @@ -16,12 +16,12 @@ #ifndef MeshVS_DataMapOfTwoColorsMapOfInteger_HeaderFile #define MeshVS_DataMapOfTwoColorsMapOfInteger_HeaderFile +#include #include -#include #include -typedef NCollection_DataMap MeshVS_DataMapOfTwoColorsMapOfInteger; -typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfTwoColorsMapOfInteger; +typedef NCollection_DataMap MeshVS_DataMapOfTwoColorsMapOfInteger; +typedef NCollection_DataMap::Iterator MeshVS_DataMapIteratorOfDataMapOfTwoColorsMapOfInteger; #endif diff --git a/src/MeshVS/MeshVS_DataSource.hxx b/src/MeshVS/MeshVS_DataSource.hxx index 7e9828e5e3..8c877c639e 100644 --- a/src/MeshVS/MeshVS_DataSource.hxx +++ b/src/MeshVS/MeshVS_DataSource.hxx @@ -23,7 +23,6 @@ #include #include #include -#include #include #include #include diff --git a/src/MeshVS/MeshVS_DeformedDataSource.hxx b/src/MeshVS/MeshVS_DeformedDataSource.hxx index f0c04c93c2..0d7549d39d 100644 --- a/src/MeshVS/MeshVS_DeformedDataSource.hxx +++ b/src/MeshVS/MeshVS_DeformedDataSource.hxx @@ -25,7 +25,6 @@ #include #include #include -#include #include class gp_Vec; diff --git a/src/MeshVS/MeshVS_ElementalColorPrsBuilder.cxx b/src/MeshVS/MeshVS_ElementalColorPrsBuilder.cxx index 27cad1e550..b5aa0ed895 100644 --- a/src/MeshVS/MeshVS_ElementalColorPrsBuilder.cxx +++ b/src/MeshVS/MeshVS_ElementalColorPrsBuilder.cxx @@ -151,7 +151,7 @@ void MeshVS_ElementalColorPrsBuilder::Build ( const Handle(Prs3d_Presentation)& Standard_Boolean IsExist = Standard_False; for ( MeshVS_DataMapIteratorOfDataMapOfTwoColorsMapOfInteger anIterC2 ( aTwoColorsOfElements ); anIterC2.More() && !IsExist; anIterC2.Next () ) - if ( IsEqual ( anIterC2.Key(), anIterM2.Value() ) ) + if ( anIterC2.Key() == anIterM2.Value() ) { TColStd_MapOfInteger& aChangeValue = (TColStd_MapOfInteger&) anIterC2.Value(); aChangeValue.Add ( aMKey ); diff --git a/src/MeshVS/MeshVS_MapOfTwoNodes.hxx b/src/MeshVS/MeshVS_MapOfTwoNodes.hxx index c22e349bdf..e9a5b77090 100644 --- a/src/MeshVS/MeshVS_MapOfTwoNodes.hxx +++ b/src/MeshVS/MeshVS_MapOfTwoNodes.hxx @@ -16,11 +16,11 @@ #ifndef MeshVS_MapOfTwoNodes_HeaderFile #define MeshVS_MapOfTwoNodes_HeaderFile -#include +#include #include -typedef NCollection_Map MeshVS_MapOfTwoNodes; -typedef NCollection_Map::Iterator MeshVS_MapIteratorOfMapOfTwoNodes; +typedef NCollection_Map MeshVS_MapOfTwoNodes; +typedef NCollection_Map::Iterator MeshVS_MapIteratorOfMapOfTwoNodes; #endif diff --git a/src/MeshVS/MeshVS_SymmetricPairHasher.hxx b/src/MeshVS/MeshVS_SymmetricPairHasher.hxx index 3b3435b916..5058997a8b 100644 --- a/src/MeshVS/MeshVS_SymmetricPairHasher.hxx +++ b/src/MeshVS/MeshVS_SymmetricPairHasher.hxx @@ -15,25 +15,31 @@ #define _MeshVS_SymmetricPairHasher_HeaderFile #include +#include typedef std::pair MeshVS_NodePair; //! Provides symmetric hash methods pair of integers. struct MeshVS_SymmetricPairHasher { - //! Computes a hash code for the node pair, in the range [1, theUpperBound] + //! Computes a hash code for the node pair //! @param theNodePair the node pair which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const MeshVS_NodePair& theNodePair, const Standard_Integer theUpperBound) + //! @return a computed hash code + size_t operator()(const MeshVS_NodePair& theNodePair) const noexcept { - return ::HashCode(theNodePair.first + theNodePair.second, theUpperBound); + // Combine two int values into a single hash value. + int aCombination[2]{ theNodePair.first, theNodePair.second }; + if (aCombination[0] > aCombination[1]) + { + std::swap(aCombination[0], aCombination[1]); + } + return opencascade::hashBytes(aCombination, sizeof(aCombination)); } - static Standard_Boolean IsEqual (const MeshVS_NodePair& thePair1, const MeshVS_NodePair& thePair2) + bool operator()(const MeshVS_NodePair& thePair1, const MeshVS_NodePair& thePair2) const noexcept { return (thePair1.first == thePair2.first && thePair1.second == thePair2.second) - || (thePair1.first == thePair2.second && thePair1.second == thePair2.first); + || (thePair1.first == thePair2.second && thePair1.second == thePair2.first); } }; diff --git a/src/MeshVS/MeshVS_TwoColors.cxx b/src/MeshVS/MeshVS_TwoColors.cxx index ae37617848..ae80b15fd9 100644 --- a/src/MeshVS/MeshVS_TwoColors.cxx +++ b/src/MeshVS/MeshVS_TwoColors.cxx @@ -15,55 +15,6 @@ #include - -//================================================================ -// function : HashCode -// purpose : -//================================================================ -Standard_Integer HashCode (const MeshVS_TwoColors& theKey, const Standard_Integer theUpperBound) -{ -#define MESHPRS_HASH_BYTE(val) { \ - aHash += (val); \ - aHash += (aHash << 10); \ - aHash ^= (aHash >> 6); \ - } - unsigned int aHash = 0; - MESHPRS_HASH_BYTE (theKey.r1) - MESHPRS_HASH_BYTE (theKey.g1) - MESHPRS_HASH_BYTE (theKey.b1) - MESHPRS_HASH_BYTE (theKey.r2) - MESHPRS_HASH_BYTE (theKey.g2) - MESHPRS_HASH_BYTE (theKey.b2) - aHash += (aHash << 3); - aHash ^= (aHash >> 11); - aHash += (aHash << 15); - return HashCode(aHash, theUpperBound); -#undef MESHPRS_HASH_BYTE -} - -//================================================================ -// Function : IsEqual -// Purpose : -//================================================================ -Standard_Boolean IsEqual (const MeshVS_TwoColors& K1, - const MeshVS_TwoColors& K2) -{ - return (((K1.r1 * 256 + K1.g1) * 256 + K1.b1) == - ((K2.r1 * 256 + K2.g1) * 256 + K2.b1) && - ((K1.r2 * 256 + K1.g2) * 256 + K1.b2) == - ((K2.r2 * 256 + K2.g2) * 256 + K2.b2)); -} - -//================================================================ -// Function : operator == -// Purpose : -//================================================================ -Standard_Boolean operator== ( const MeshVS_TwoColors& K1, - const MeshVS_TwoColors& K2 ) -{ - return IsEqual ( K1, K2 ); -} - //================================================================ // Function : BindTwoColors // Purpose : diff --git a/src/MeshVS/MeshVS_TwoColors.hxx b/src/MeshVS/MeshVS_TwoColors.hxx index 8dfa4e067e..1ec5a0af0c 100644 --- a/src/MeshVS/MeshVS_TwoColors.hxx +++ b/src/MeshVS/MeshVS_TwoColors.hxx @@ -18,27 +18,50 @@ #include -typedef struct { +struct MeshVS_TwoColors +{ unsigned int r1 : 8; unsigned int g1 : 8; unsigned int b1 : 8; unsigned int r2 : 8; unsigned int g2 : 8; unsigned int b2 : 8; -} MeshVS_TwoColors; + bool operator==(const MeshVS_TwoColors& TwoColors) const + { + return (((r1 * 256 + g1) * 256 + b1) == + ((TwoColors.r1 * 256 + TwoColors.g1) * 256 + TwoColors.b1) && + ((r2 * 256 + g2) * 256 + b2) == + ((TwoColors.r2 * 256 + TwoColors.g2) * 256 + TwoColors.b2)); + } +}; -//! Computes a hash code for the key, in the range [1, theUpperBound] -//! @param theKey the key which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -Standard_EXPORT Standard_Integer HashCode (const MeshVS_TwoColors& theKey, Standard_Integer theUpperBound); +namespace std +{ + template<> + struct hash + { + size_t operator()(const MeshVS_TwoColors& TwoColors) const noexcept + { + unsigned int aHash = 0; + meshprsHashByte(aHash, TwoColors.r1); + meshprsHashByte(aHash, TwoColors.g1); + meshprsHashByte(aHash, TwoColors.b1); + meshprsHashByte(aHash, TwoColors.r2); + meshprsHashByte(aHash, TwoColors.g2); + meshprsHashByte(aHash, TwoColors.b2); + return std::hash{}(aHash); + } + private: + void meshprsHashByte(unsigned int& theHash, const unsigned int theValues) const noexcept + { + theHash += (theValues); + theHash += (theHash << 10); + theHash ^= (theHash >> 6); + } -Standard_EXPORT Standard_Boolean IsEqual (const MeshVS_TwoColors& K1, - const MeshVS_TwoColors& K2 ); - -Standard_EXPORT Standard_Boolean operator== ( const MeshVS_TwoColors& K1, - const MeshVS_TwoColors& K2 ); + }; +} Standard_EXPORT MeshVS_TwoColors BindTwoColors ( const Quantity_Color&, const Quantity_Color& ); Standard_EXPORT Quantity_Color ExtractColor ( MeshVS_TwoColors&, const Standard_Integer ); diff --git a/src/MeshVS/MeshVS_TwoColorsHasher.hxx b/src/MeshVS/MeshVS_TwoColorsHasher.hxx deleted file mode 100644 index 32f527e143..0000000000 --- a/src/MeshVS/MeshVS_TwoColorsHasher.hxx +++ /dev/null @@ -1,25 +0,0 @@ -// Created on: 2003-10-10 -// Created by: Alexander SOLOVYOV -// Copyright (c) 2003-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef MeshVS_TwoColorsHasher_HeaderFile -#define MeshVS_TwoColorsHasher_HeaderFile - -#include -#include - -typedef NCollection_DefaultHasher MeshVS_TwoColorsHasher; - - -#endif diff --git a/src/MeshVS/MeshVS_TwoNodes.hxx b/src/MeshVS/MeshVS_TwoNodes.hxx index d581d901f3..b838459ea3 100644 --- a/src/MeshVS/MeshVS_TwoNodes.hxx +++ b/src/MeshVS/MeshVS_TwoNodes.hxx @@ -14,12 +14,9 @@ #ifndef MeshVS_TwoNodes_HeaderFile #define MeshVS_TwoNodes_HeaderFile -#ifndef _Standard_HeaderFile #include -#endif -#ifndef _Standard_Macro_HeaderFile #include -#endif +#include //! Structure containing two IDs (of nodes) for using as a key in a map //! (as representation of a mesh link) @@ -30,29 +27,30 @@ struct MeshVS_TwoNodes MeshVS_TwoNodes (Standard_Integer aFirst=0, Standard_Integer aSecond=0) : First(aFirst), Second(aSecond) {} + + bool operator==(const MeshVS_TwoNodes& theTwoNode) const + { + return ((First == theTwoNode.First) && (Second == theTwoNode.Second)) || + ((First == theTwoNode.Second) && (Second == theTwoNode.First)); + } }; -//! Computes a hash code for two nodes, in the range [1, theUpperBound] -//! @param theTwoNodes the object of structure containing two IDs which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -inline Standard_Integer HashCode (const MeshVS_TwoNodes& theTwoNodes, const Standard_Integer theUpperBound) +namespace std { - // symmetrical with respect to theTwoNodes.First and theTwoNodes.Second - const Standard_Integer aKey = theTwoNodes.First + theTwoNodes.Second; - return HashCode (aKey, theUpperBound); -} - -//================================================================ -// Function : operator == -// Purpose : -//================================================================ - -inline Standard_Boolean operator==( const MeshVS_TwoNodes& obj1, - const MeshVS_TwoNodes& obj2 ) -{ - return ( ( obj1.First == obj2.First ) && ( obj1.Second == obj2.Second ) ) || - ( ( obj1.First == obj2.Second ) && ( obj1.Second == obj2.First ) ); + template<> + struct hash + { + size_t operator()(const MeshVS_TwoNodes& theTwoNodes) const noexcept + { + // Combine two int values into a single hash value. + int aCombination[2]{ theTwoNodes.First, theTwoNodes.Second }; + if (aCombination[0] > aCombination[1]) + { + std::swap(aCombination[0], aCombination[1]); + } + return opencascade::hashBytes(aCombination, sizeof(aCombination)); + } + }; } #endif diff --git a/src/MeshVS/MeshVS_TwoNodesHasher.hxx b/src/MeshVS/MeshVS_TwoNodesHasher.hxx deleted file mode 100644 index 3a92e5486c..0000000000 --- a/src/MeshVS/MeshVS_TwoNodesHasher.hxx +++ /dev/null @@ -1,25 +0,0 @@ -// Created on: 2003-10-10 -// Created by: Alexander SOLOVYOV -// Copyright (c) 2003-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef MeshVS_TwoNodesHasher_HeaderFile -#define MeshVS_TwoNodesHasher_HeaderFile - -#include -#include - -typedef NCollection_DefaultHasher MeshVS_TwoNodesHasher; - - -#endif diff --git a/src/Message/Message_Attribute.hxx b/src/Message/Message_Attribute.hxx index e1c2aaaf80..7433654763 100644 --- a/src/Message/Message_Attribute.hxx +++ b/src/Message/Message_Attribute.hxx @@ -15,6 +15,7 @@ #define _Message_Attribute_HeaderFile #include +#include #include DEFINE_STANDARD_HANDLE(Message_Attribute, Standard_Transient) diff --git a/src/Message/Message_AttributeMeter.cxx b/src/Message/Message_AttributeMeter.cxx index e50976c910..d6be5057ef 100644 --- a/src/Message/Message_AttributeMeter.cxx +++ b/src/Message/Message_AttributeMeter.cxx @@ -253,6 +253,6 @@ void Message_AttributeMeter::DumpJson (Standard_OStream& theOStream, anIterator.More(); anIterator.Next()) { OCCT_DUMP_VECTOR_CLASS (theOStream, Message::MetricToString (anIterator.Key()), - 2, anIterator.Value().first, anIterator.Value().second) + 2, anIterator.Value(), anIterator.Value()) } } diff --git a/src/Message/Message_AttributeObject.hxx b/src/Message/Message_AttributeObject.hxx index 86c94b6e41..dbb185be1c 100644 --- a/src/Message/Message_AttributeObject.hxx +++ b/src/Message/Message_AttributeObject.hxx @@ -15,6 +15,7 @@ #define _Message_AttributeObject_HeaderFile #include +#include //! Alert object storing a transient object diff --git a/src/Message/Message_PrinterOStream.hxx b/src/Message/Message_PrinterOStream.hxx index fe69d4ff86..2579d1e21d 100644 --- a/src/Message/Message_PrinterOStream.hxx +++ b/src/Message/Message_PrinterOStream.hxx @@ -18,7 +18,6 @@ #include #include -#include #include class Message_PrinterOStream; diff --git a/src/Message/Message_PrinterToReport.hxx b/src/Message/Message_PrinterToReport.hxx index eb05a60638..9722cfee83 100644 --- a/src/Message/Message_PrinterToReport.hxx +++ b/src/Message/Message_PrinterToReport.hxx @@ -15,7 +15,6 @@ #define _Message_PrinterToReport_HeaderFile #include -#include #include class Message_Report; diff --git a/src/Message/Message_ProgressScope.hxx b/src/Message/Message_ProgressScope.hxx index 1041f401d1..f1167bf0a6 100644 --- a/src/Message/Message_ProgressScope.hxx +++ b/src/Message/Message_ProgressScope.hxx @@ -271,7 +271,7 @@ public: //! @name Preparation methods if (!theName.IsEmpty()) { myIsOwnName = true; - myName = (char* )Standard::Allocate (Standard_Size(theName.Length()) + Standard_Size(1)); + myName = (char* )Standard::AllocateOptimal(Standard_Size(theName.Length()) + Standard_Size(1)); char* aName = (char* )myName; memcpy (aName, theName.ToCString(), theName.Length()); aName[theName.Length()] = '\0'; diff --git a/src/MoniTool/FILES b/src/MoniTool/FILES index 8e1579ecf9..c11833f9c0 100755 --- a/src/MoniTool/FILES +++ b/src/MoniTool/FILES @@ -10,16 +10,11 @@ MoniTool_DataMapOfShapeTransient.hxx MoniTool_DataMapOfTimer.hxx MoniTool_Element.cxx MoniTool_Element.hxx -MoniTool_ElemHasher.cxx -MoniTool_ElemHasher.hxx MoniTool_HSequenceOfElement.hxx MoniTool_IndexedDataMapOfShapeTransient.hxx MoniTool_IntVal.cxx MoniTool_IntVal.hxx MoniTool_Macros.hxx -MoniTool_MTHasher.cxx -MoniTool_MTHasher.hxx -MoniTool_MTHasher.lxx MoniTool_RealVal.cxx MoniTool_RealVal.hxx MoniTool_SequenceOfElement.hxx diff --git a/src/MoniTool/MoniTool_DataMapOfTimer.hxx b/src/MoniTool/MoniTool_DataMapOfTimer.hxx index 5d246c2b44..7c407a03ac 100644 --- a/src/MoniTool/MoniTool_DataMapOfTimer.hxx +++ b/src/MoniTool/MoniTool_DataMapOfTimer.hxx @@ -18,12 +18,12 @@ #define MoniTool_DataMapOfTimer_HeaderFile #include -#include +#include #include class MoniTool_Timer; -typedef NCollection_DataMap MoniTool_DataMapOfTimer; -typedef NCollection_DataMap::Iterator MoniTool_DataMapIteratorOfDataMapOfTimer; +typedef NCollection_DataMap MoniTool_DataMapOfTimer; +typedef NCollection_DataMap::Iterator MoniTool_DataMapIteratorOfDataMapOfTimer; #endif diff --git a/src/MoniTool/MoniTool_ElemHasher.cxx b/src/MoniTool/MoniTool_ElemHasher.cxx deleted file mode 100644 index fa203e6d76..0000000000 --- a/src/MoniTool/MoniTool_ElemHasher.cxx +++ /dev/null @@ -1,33 +0,0 @@ -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - - -#include -#include - -//============================================================================ -// function : HashCode -// purpose : -//============================================================================ -Standard_Integer MoniTool_ElemHasher::HashCode (const Handle (MoniTool_Element) & theElement, - const Standard_Integer theUpperBound) -{ - return ::HashCode(theElement->GetHashCode() - 1, theUpperBound); -} - - Standard_Boolean MoniTool_ElemHasher::IsEqual - (const Handle(MoniTool_Element)& K1, const Handle(MoniTool_Element)& K2) -{ - if (K1.IsNull()) return Standard_False; - return K1->Equates(K2); -} diff --git a/src/MoniTool/MoniTool_ElemHasher.hxx b/src/MoniTool/MoniTool_ElemHasher.hxx deleted file mode 100644 index 694533ce77..0000000000 --- a/src/MoniTool/MoniTool_ElemHasher.hxx +++ /dev/null @@ -1,76 +0,0 @@ -// Created on: 1994-11-04 -// Created by: Christian CAILLET -// Copyright (c) 1994-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _MoniTool_ElemHasher_HeaderFile -#define _MoniTool_ElemHasher_HeaderFile - -#include -#include -#include - -#include -class MoniTool_Element; - - -//! ElemHasher defines HashCode for Element, which is : ask a -//! Element its HashCode ! Because this is the Element itself -//! which brings the HashCode for its Key -//! -//! This class complies to the template given in TCollection by -//! MapHasher itself -class MoniTool_ElemHasher -{ -public: - - DEFINE_STANDARD_ALLOC - - //! Returns hash code for the given element, in the range [1, theUpperBound]. - //! Asks theElement its HashCode, then transforms it to be in the required range. - //! @param theElement the element which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - Standard_EXPORT static Standard_Integer HashCode (const Handle (MoniTool_Element) & theElement, - Standard_Integer theUpperBound); - - //! Returns True if two keys are the same. - //! The test does not work on the Elements themselves but by - //! calling their methods Equates - Standard_EXPORT static Standard_Boolean IsEqual (const Handle(MoniTool_Element)& K1, const Handle(MoniTool_Element)& K2); - - - - -protected: - - - - - -private: - - - - - -}; - - - - - - - -#endif // _MoniTool_ElemHasher_HeaderFile diff --git a/src/MoniTool/MoniTool_Element.cxx b/src/MoniTool/MoniTool_Element.cxx index 12f09f0a21..1f14ed09be 100644 --- a/src/MoniTool/MoniTool_Element.cxx +++ b/src/MoniTool/MoniTool_Element.cxx @@ -18,14 +18,14 @@ IMPLEMENT_STANDARD_RTTIEXT(MoniTool_Element,Standard_Transient) MoniTool_Element::MoniTool_Element() -: thecode(-1) +: thecode(0) { } -void MoniTool_Element::SetHashCode (const Standard_Integer code) +void MoniTool_Element::SetHashCode (const size_t code) { thecode = code; } - Standard_Integer MoniTool_Element::GetHashCode () const + size_t MoniTool_Element::GetHashCode () const { return thecode; } Handle(Standard_Type) MoniTool_Element::ValueType () const diff --git a/src/MoniTool/MoniTool_Element.hxx b/src/MoniTool/MoniTool_Element.hxx index d24b134c07..77d34402b8 100644 --- a/src/MoniTool/MoniTool_Element.hxx +++ b/src/MoniTool/MoniTool_Element.hxx @@ -45,7 +45,7 @@ public: //! Returns the HashCode which has been stored by SetHashCode //! (remark that HashCode could be deferred then be defined by //! sub-classes, the result is the same) - Standard_EXPORT Standard_Integer GetHashCode() const; + Standard_EXPORT size_t GetHashCode() const; //! Specific testof equality : to be defined by each sub-class, //! must be False if Elements have not the same true Type, else @@ -76,14 +76,14 @@ protected: //! Stores the HashCode which corresponds to the Value given to //! create the Mapper - Standard_EXPORT void SetHashCode (const Standard_Integer code); + Standard_EXPORT void SetHashCode (const size_t code); private: - Standard_Integer thecode; + size_t thecode; MoniTool_AttrList theattrib; diff --git a/src/MoniTool/MoniTool_MTHasher.cxx b/src/MoniTool/MoniTool_MTHasher.cxx deleted file mode 100644 index 104769eae8..0000000000 --- a/src/MoniTool/MoniTool_MTHasher.cxx +++ /dev/null @@ -1,14 +0,0 @@ -// Created on: 2001-12-19 -// Created by: Sergey KUUL -// Copyright (c) 2001-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. diff --git a/src/MoniTool/MoniTool_MTHasher.hxx b/src/MoniTool/MoniTool_MTHasher.hxx deleted file mode 100644 index b314702784..0000000000 --- a/src/MoniTool/MoniTool_MTHasher.hxx +++ /dev/null @@ -1,70 +0,0 @@ -// Created on: 2001-12-19 -// Created by: Sergey KUUL -// Copyright (c) 2001-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _MoniTool_MTHasher_HeaderFile -#define _MoniTool_MTHasher_HeaderFile - -#include -#include -#include - -#include - - - -//! The auxiliary class provides hash code for mapping objects -class MoniTool_MTHasher -{ -public: - - DEFINE_STANDARD_ALLOC - - //! Returns hash code for the given string, in the range [1, theUpperBound] - //! @param theString the string which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (Standard_CString theString, Standard_Integer theUpperBound); - - //! Returns True when the two CString are the same. Two - //! same strings must have the same hashcode, the - //! contrary is not necessary. - //! Default Str1 == Str2 - static Standard_Boolean IsEqual (const Standard_CString Str1, const Standard_CString Str2); - - - - -protected: - - - - - -private: - - - - - -}; - - -#include - - - - - -#endif // _MoniTool_MTHasher_HeaderFile diff --git a/src/MoniTool/MoniTool_MTHasher.lxx b/src/MoniTool/MoniTool_MTHasher.lxx deleted file mode 100644 index a39f1c6d9f..0000000000 --- a/src/MoniTool/MoniTool_MTHasher.lxx +++ /dev/null @@ -1,37 +0,0 @@ -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#include - -//======================================================================= -// function : HashCode -// purpose : -//======================================================================= -inline Standard_Integer MoniTool_MTHasher::HashCode (const Standard_CString theString, - const Standard_Integer theUpperBound) -{ - return ::HashCode (theString, theUpperBound); -} - -//======================================================================= -//function : IsEqual -//purpose : -//======================================================================= - -inline Standard_Boolean MoniTool_MTHasher::IsEqual(const Standard_CString Str1, - const Standard_CString Str2) -{ - return ! strcmp(Str1,Str2); -} - - diff --git a/src/MoniTool/MoniTool_TransientElem.cxx b/src/MoniTool/MoniTool_TransientElem.cxx index 57da02ce08..20aeadee41 100644 --- a/src/MoniTool/MoniTool_TransientElem.cxx +++ b/src/MoniTool/MoniTool_TransientElem.cxx @@ -17,13 +17,12 @@ #include #include #include -#include IMPLEMENT_STANDARD_RTTIEXT(MoniTool_TransientElem,MoniTool_Element) MoniTool_TransientElem::MoniTool_TransientElem (const Handle(Standard_Transient)& akey) : theval (akey) -{ SetHashCode ( TColStd_MapTransientHasher::HashCode (akey, IntegerLast() ) ); } +{ SetHashCode ( std::hash{}(akey)); } const Handle(Standard_Transient)& MoniTool_TransientElem::Value () const @@ -37,7 +36,7 @@ MoniTool_TransientElem::MoniTool_TransientElem (const Handle(Standard_Transient) if (other->DynamicType() != DynamicType()) return Standard_False; Handle(MoniTool_TransientElem) another = Handle(MoniTool_TransientElem)::DownCast(other); // return (theval == another->Value()); - return TColStd_MapTransientHasher::IsEqual (theval,another->Value()); + return theval == another->Value(); } Handle(Standard_Type) MoniTool_TransientElem::ValueType () const diff --git a/src/NCollection/FILES b/src/NCollection/FILES index 6e92b94898..d93ebc08fb 100755 --- a/src/NCollection/FILES +++ b/src/NCollection/FILES @@ -3,6 +3,7 @@ NCollection_AccAllocator.hxx NCollection_AliasedArray.hxx NCollection_AlignedAllocator.cxx NCollection_AlignedAllocator.hxx +NCollection_Allocator.hxx NCollection_Array1.hxx NCollection_Array2.hxx NCollection_BaseAllocator.cxx @@ -11,29 +12,21 @@ NCollection_BaseList.cxx NCollection_BaseList.hxx NCollection_BaseMap.cxx NCollection_BaseMap.hxx +NCollection_BasePointerVector.cxx +NCollection_BasePointerVector.hxx NCollection_BaseSequence.cxx NCollection_BaseSequence.hxx -NCollection_BaseVector.cxx -NCollection_BaseVector.hxx NCollection_Buffer.hxx NCollection_CellFilter.hxx NCollection_DataMap.hxx NCollection_DefaultHasher.hxx NCollection_DefineAlloc.hxx -NCollection_DefineArray1.hxx -NCollection_DefineArray2.hxx -NCollection_DefineDataMap.hxx -NCollection_DefineDoubleMap.hxx NCollection_DefineHArray1.hxx NCollection_DefineHArray2.hxx +NCollection_DefineHasher.hxx NCollection_DefineHSequence.hxx -NCollection_DefineIndexedDataMap.hxx -NCollection_DefineIndexedMap.hxx -NCollection_DefineList.hxx -NCollection_DefineMap.hxx -NCollection_DefineSequence.hxx -NCollection_DefineVector.hxx NCollection_DoubleMap.hxx +NCollection_DynamicArray.hxx NCollection_EBTree.hxx NCollection_Haft.h NCollection_Handle.hxx @@ -45,7 +38,9 @@ NCollection_HSequence.hxx NCollection_IncAllocator.cxx NCollection_IncAllocator.hxx NCollection_IndexedDataMap.hxx +NCollection_IndexedIterator.hxx NCollection_IndexedMap.hxx +NCollection_Iterator.hxx NCollection_Lerp.hxx NCollection_List.hxx NCollection_ListNode.hxx @@ -53,12 +48,12 @@ NCollection_LocalArray.hxx NCollection_Map.hxx NCollection_Mat3.hxx NCollection_Mat4.hxx +NCollection_OccAllocator.hxx NCollection_Sequence.hxx NCollection_Shared.hxx NCollection_SparseArray.hxx NCollection_SparseArrayBase.cxx NCollection_SparseArrayBase.hxx -NCollection_StdAllocator.hxx NCollection_StlIterator.hxx NCollection_String.hxx NCollection_TListIterator.hxx diff --git a/src/NCollection/NCollection_AccAllocator.cxx b/src/NCollection/NCollection_AccAllocator.cxx index e7172ccff7..634223a958 100644 --- a/src/NCollection/NCollection_AccAllocator.cxx +++ b/src/NCollection/NCollection_AccAllocator.cxx @@ -127,8 +127,9 @@ void NCollection_AccAllocator::Free(void* theAddress) // If there are no more blocks, reallocate the block to the default size else { + const Standard_Size aRoundSize = (myBlockSize + 3) & ~0x3; Standard_Address aNewAddress = Standard::Reallocate(anAddress, - myBlockSize); + aRoundSize); if (aNewAddress == anAddress) { // Normally, the reallocation keeps the block at the same address @@ -196,7 +197,8 @@ NCollection_AccAllocator::findBlock(const Standard_Address theAddress, Key& theK NCollection_AccAllocator::Block* NCollection_AccAllocator::allocateNewBlock(const Standard_Size theSize) { - Standard_Address anAddress = Standard::Allocate(theSize); + const Standard_Size aRoundSize = (theSize + 3) & ~0x3; + Standard_Address anAddress = Standard::Allocate(aRoundSize); // we depend on the fact that Standard::Allocate always returns // a pointer aligned to a 4 byte boundary mypLastBlock = myBlocks.Bound(getKey(anAddress), diff --git a/src/NCollection/NCollection_AccAllocator.hxx b/src/NCollection/NCollection_AccAllocator.hxx index 239ba351c2..b9aff7b706 100644 --- a/src/NCollection/NCollection_AccAllocator.hxx +++ b/src/NCollection/NCollection_AccAllocator.hxx @@ -64,6 +64,12 @@ public: //! Allocate memory with given size Standard_EXPORT virtual void* Allocate (const size_t theSize) Standard_OVERRIDE; + //! Allocate memory with given size + void* AllocateOptimal(const size_t theSize) Standard_OVERRIDE + { + return Allocate(theSize); + } + //! Free a previously allocated memory; //! memory is returned to the OS when all allocations in some block are freed Standard_EXPORT virtual void Free (void* theAddress) Standard_OVERRIDE; @@ -108,17 +114,18 @@ protected: class Hasher { public: - //! Returns hash code for the given key, in the range [1, theUpperBound] + //! Returns hash code for the given key //! @param theKey the key which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const Key theKey, const Standard_Integer theUpperBound) + //! @return a computed hash code + size_t operator() (const Key theKey) const noexcept { - return ::HashCode (theKey.Value, theUpperBound); + return theKey.Value; } - static Standard_Boolean IsEqual(const Key theOne, const Key theTwo) - { return theOne.Value == theTwo.Value; } + bool operator() (const Key theKey1, const Key theKey2) const noexcept + { + return theKey1.Value == theKey2.Value; + } }; //! Descriptor of a block diff --git a/src/NCollection/NCollection_AlignedAllocator.hxx b/src/NCollection/NCollection_AlignedAllocator.hxx index 1e3187ffee..5ab553a638 100644 --- a/src/NCollection/NCollection_AlignedAllocator.hxx +++ b/src/NCollection/NCollection_AlignedAllocator.hxx @@ -32,6 +32,12 @@ public: //! Allocate memory with given size. Returns NULL on failure. Standard_EXPORT virtual void* Allocate (const size_t theSize) Standard_OVERRIDE; + //! Allocate memory with given size. Returns NULL on failure. + void* AllocateOptimal(const size_t theSize) Standard_OVERRIDE + { + return Allocate(theSize); + } + //! Free a previously allocated memory. Standard_EXPORT virtual void Free (void* thePtr) Standard_OVERRIDE; diff --git a/src/NCollection/NCollection_Allocator.hxx b/src/NCollection/NCollection_Allocator.hxx new file mode 100644 index 0000000000..5d116c47e1 --- /dev/null +++ b/src/NCollection/NCollection_Allocator.hxx @@ -0,0 +1,151 @@ +// Copyright (c) 2023 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _NCollection_Allocator_HeaderFile +#define _NCollection_Allocator_HeaderFile + +#include +#include + +#include + +//! Implements allocator requirements as defined in ISO C++ Standard 2003, section 20.1.5. +/*! The allocator uses a standard OCCT mechanism for memory + allocation and deallocation. It can be used with standard + containers (std::vector, std::map, etc.) to take advantage of OCCT memory optimizations. + + Example of use: + \code + NCollection_Allocator anSAllocator(); + std::list> aList(anSAllocator); + TopoDS_Solid aSolid = BRepPrimAPI_MakeBox(10., 20., 30.); + aList.push_back(aSolid); + \endcode +*/ +template +class NCollection_Allocator +{ +public: + typedef ItemType value_type; + typedef value_type* pointer; + typedef const value_type* const_pointer; + typedef value_type& reference; + typedef const value_type& const_reference; + typedef size_t size_type; + typedef ptrdiff_t difference_type; + + template + struct rebind + { + typedef NCollection_Allocator other; + }; + + //! Constructor. + //! Creates an object using the default Open CASCADE allocation mechanism, i.e., which uses + //! Standard::Allocate() and Standard::Free() underneath. + NCollection_Allocator() noexcept + {} + + //! Constructor. + NCollection_Allocator(const Handle(NCollection_BaseAllocator)&) noexcept + {} + + //! Assignment operator + template + NCollection_Allocator& operator=(const NCollection_Allocator&) noexcept + { + return *this; + } + //! Constructor. + //! Creates an object using the default Open CASCADE allocation mechanism, i.e., which uses + //! Standard::Allocate() and Standard::Free() underneath. + template + NCollection_Allocator(const NCollection_Allocator&) noexcept + {} + + //! Returns an object address. + pointer address(reference theItem) const + { + return &theItem; + } + + //! Returns an object address. + const_pointer address(const_reference theItem) const + { + return &theItem; + } + + //! Allocates memory for theSize objects. + pointer allocate(const size_type theSize, const void* /*hint*/ = 0) const + { + return static_cast(Standard::AllocateOptimal(theSize * sizeof(ItemType))); + } + + //! Frees previously allocated memory. + void deallocate(pointer thePnt, const size_type) const + { + Standard::Free(static_cast(thePnt)); + } + + //! Reallocates memory for theSize objects. + pointer reallocate(pointer thePnt, const size_type theSize) const + { + return static_cast(Standard::Reallocate(thePnt, theSize * sizeof(ItemType))); + } + + //! Constructs an object. + //! Uses placement new operator and copy constructor to construct an object. + template + void construct(_Objty* _Ptr, _Types&&... _Args) + { + ::new ((void*)_Ptr) _Objty(std::forward<_Types>(_Args)...); + } + + //! Destroys the object. + //! Uses the object destructor. + void destroy(pointer thePnt) + { + (void)thePnt; thePnt->~value_type(); + } + + bool operator==(const NCollection_Allocator&) const + { + return true; + } + + template + bool operator==(const NCollection_Allocator&) const noexcept + { + return true; + } + + bool operator!=(const NCollection_Allocator&) const noexcept + { + return false; + } + + template + bool operator!=(const NCollection_Allocator&) const noexcept + { + return false; + } + +}; + +template +bool operator==(const NCollection_Allocator&, const NCollection_Allocator&) +{ + return true; +} + +#endif diff --git a/src/NCollection/NCollection_Array1.hxx b/src/NCollection/NCollection_Array1.hxx index 473f050b64..4dcabc29f5 100644 --- a/src/NCollection/NCollection_Array1.hxx +++ b/src/NCollection/NCollection_Array1.hxx @@ -1,6 +1,4 @@ -// Created on: 2002-04-15 -// Created by: Alexander Kartomin (akm) -// Copyright (c) 2002-2014 OPEN CASCADE SAS +// Copyright (c) 2002-2023 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // @@ -18,10 +16,18 @@ #include #include +#include #include #include -#include +#include +#include +#include +#include + +#include +#include +#include //! The class NCollection_Array1 represents unidimensional arrays of fixed size known at run time. //! The range of the index is user defined. @@ -49,231 +55,218 @@ template class NCollection_Array1 { public: - //! STL-compliant typedef for value type - typedef TheItemType value_type; + //! Memory allocation + DEFINE_STANDARD_ALLOC; + DEFINE_NCOLLECTION_ALLOC; +public: + typedef NCollection_Allocator allocator_type; +public: + // Define various type aliases for convenience + using value_type = TheItemType; + using size_type = size_t; + using difference_type = size_t; + using pointer = TheItemType*; + using const_pointer = const TheItemType*; + using reference = TheItemType&; + using const_reference = const TheItemType&; + + using iterator = NCollection_IndexedIterator; + using const_iterator = NCollection_IndexedIterator; public: - //! Implementation of the Iterator interface. - class Iterator + + // Iterator class + class Iterator : public NCollection_Iterator { public: + using NCollection_Iterator::NCollection_Iterator; - //! Empty constructor - for later Init - Iterator (void) : - myPtrCur (NULL), - myPtrEnd (NULL) + const_reference Value() const { - // + return *NCollection_Iterator::ValueIter(); } - //! Constructor with initialization - Iterator (const NCollection_Array1& theArray, Standard_Boolean theToEnd = Standard_False) : - myPtrEnd (const_cast (&theArray.Last() + 1)) + reference ChangeValue() { - myPtrCur = theToEnd ? myPtrEnd : const_cast (&theArray.First()); + return *NCollection_Iterator::ChangeValueIter(); } + }; - //! Initialisation - void Init (const NCollection_Array1& theArray) - { - myPtrCur = const_cast (&theArray.First()); - myPtrEnd = const_cast (&theArray.Last() + 1); - } - - //! Check end - Standard_Boolean More (void) const - { return myPtrCur < myPtrEnd; } - - //! Increment operator - void Next (void) - { ++myPtrCur; } - - //! Decrement operator - void Previous() - { --myPtrCur; } - - //! Offset operator. - void Offset (ptrdiff_t theOffset) - { myPtrCur += theOffset; } - - //! Difference operator. - ptrdiff_t Differ (const Iterator& theOther) const - { return myPtrCur - theOther.myPtrCur; } - - //! Constant value access - const TheItemType& Value (void) const - { return *myPtrCur; } - - //! Variable value access - TheItemType& ChangeValue (void) const - { return *myPtrCur; } - - //! Performs comparison of two iterators - Standard_Boolean IsEqual (const Iterator& theOther) const - { return myPtrCur == theOther.myPtrCur; } - - private: - TheItemType* myPtrCur; //!< Pointer to the current element in the array - TheItemType* myPtrEnd; //!< Pointer to the past-the-end element in the array - }; // End of the nested class Iterator - - //! Shorthand for a regular iterator type. - typedef NCollection_StlIterator iterator; - - //! Shorthand for a constant iterator type. - typedef NCollection_StlIterator const_iterator; - - //! Returns an iterator pointing to the first element in the array. - iterator begin() const { return Iterator (*this, false); } - - //! Returns an iterator referring to the past-the-end element in the array. - iterator end() const { return Iterator (*this, true); } - - //! Returns a const iterator pointing to the first element in the array. - const_iterator cbegin() const { return Iterator (*this, false); } - - //! Returns a const iterator referring to the past-the-end element in the array. - const_iterator cend() const { return Iterator (*this, true); } - - public: - // ---------- PUBLIC METHODS ------------ - - //! Empty constructor; should be used with caution. - //! @sa methods Resize() and Move(). - NCollection_Array1() - : myLowerBound (1), - myUpperBound (0), - myDeletable (Standard_False), - myData (NULL) + const_iterator begin() const { - // + return const_iterator(*this); } - //! Constructor - NCollection_Array1(const Standard_Integer theLower, - const Standard_Integer theUpper) : - myLowerBound (theLower), - myUpperBound (theUpper), - myDeletable (Standard_True) + iterator begin() { - Standard_RangeError_Raise_if (theUpper < theLower, "NCollection_Array1::Create"); - TheItemType* pBegin = new TheItemType[Length()]; - Standard_OutOfMemory_Raise_if (!pBegin, "NCollection_Array1 : Allocation failed"); + return iterator(*this); + } - myData = pBegin - theLower; + const_iterator cbegin() const + { + return const_iterator(*this); + } + + iterator end() + { + return iterator(mySize, *this); + } + + const_iterator end() const + { + return const_iterator(mySize, *this); + } + + const_iterator cend() const + { + return const_iterator(mySize, *this); + } + +public: + // Constructors + NCollection_Array1() : + myLowerBound(1), + mySize(0) + {} + + explicit NCollection_Array1(const Standard_Integer theLower, + const Standard_Integer theUpper) : + myLowerBound(theLower), + mySize(theUpper - theLower + 1) + { + if (mySize == 0) + { + return; + } + myPointer = myAllocator.allocate(mySize); + myIsOwner = true; + construct(); + } + + explicit NCollection_Array1(const allocator_type& theAlloc, + const Standard_Integer theLower, + const Standard_Integer theUpper) : + myLowerBound(theLower), + mySize(theUpper - theLower + 1), + myPointer(nullptr), + myIsOwner(false), + allocator_type(theAlloc) + { + if (mySize == 0) + { + return; + } + myPointer = myAllocator.allocate(mySize); + myIsOwner = true; + construct(); + } + + explicit NCollection_Array1(const_reference theBegin, + const Standard_Integer theLower, + const Standard_Integer theUpper, + const bool theUseBuffer = true) : + myLowerBound(theLower), + mySize(theUpper - theLower + 1), + myPointer(theUseBuffer ? const_cast(&theBegin) : nullptr), + myIsOwner(!theUseBuffer) + { + if (!myIsOwner) + { + return; + } + myPointer = myAllocator.allocate(mySize); + myIsOwner = true; + construct(); } //! Copy constructor - NCollection_Array1 (const NCollection_Array1& theOther) : - myLowerBound (theOther.Lower()), - myUpperBound (theOther.Upper()), - myDeletable (Standard_True) + NCollection_Array1(const NCollection_Array1& theOther) : + myLowerBound(theOther.myLowerBound), + mySize(theOther.mySize) { - TheItemType* pBegin = new TheItemType[Length()]; - Standard_OutOfMemory_Raise_if (!pBegin, "NCollection_Array1 : Allocation failed"); - myData = pBegin - myLowerBound; - - Assign (theOther); + if (mySize == 0) + { + return; + } + myPointer = myAllocator.allocate(mySize); + myIsOwner = true; + copyConstruct(theOther.myPointer, mySize); } //! Move constructor - NCollection_Array1 (NCollection_Array1&& theOther) - : myLowerBound (theOther.myLowerBound), - myUpperBound (theOther.myUpperBound), - myDeletable (theOther.myDeletable), - myData (theOther.myData) + NCollection_Array1(NCollection_Array1&& theOther) noexcept : + myLowerBound(theOther.myLowerBound), + mySize(theOther.mySize), + myPointer(theOther.myPointer), + myIsOwner(theOther.myIsOwner) { - theOther.myDeletable = false; + theOther.myIsOwner = false; } - //! C array-based constructor. - //! - //! Makes this array to use the buffer pointed by theBegin - //! instead of allocating it dynamically. - //! Argument theBegin should be a reference to the first element - //! of the pre-allocated buffer (usually local C array buffer), - //! with size at least theUpper - theLower + 1 items. - //! - //! Warning: returning array object created using this constructor - //! from function by value will result in undefined behavior - //! if compiler performs return value optimization (this is likely - //! to be true for all modern compilers in release mode). - //! The same happens if array is copied using Move() function - //! or move constructor and target object's lifespan is longer - //! than that of the buffer. - NCollection_Array1 (const TheItemType& theBegin, - const Standard_Integer theLower, - const Standard_Integer theUpper) : - myLowerBound (theLower), - myUpperBound (theUpper), - myDeletable (Standard_False) + virtual ~NCollection_Array1() { - Standard_RangeError_Raise_if (theUpper < theLower, "NCollection_Array1::Create"); - #if (defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6))) - // gcc emits -Warray-bounds warning when NCollection_Array1 is initialized - // from local array with lower index 1 (so that (&theBegin - 1) points out of array bounds). - // NCollection_Array1 initializes myData with a shift to avoid this shift within per-element access. - // It is undesired changing this logic, and -Warray-bounds is not useful here. - #pragma GCC diagnostic push - #pragma GCC diagnostic ignored "-Warray-bounds" - #endif - myData = (TheItemType *) &theBegin - theLower; - #if (defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 6))) - #pragma GCC diagnostic pop - #endif + if (!myIsOwner) + { + return; + } + destroy(); + myAllocator.deallocate(myPointer, mySize); } //! Initialise the items with theValue - void Init (const TheItemType& theValue) + void Init(const_reference theValue) { - TheItemType *pCur = &myData[myLowerBound], *pEnd=&myData[myUpperBound]; - for(; pCur <= pEnd; pCur++) - *pCur = (TheItemType&) theValue; + for (size_t anIter = 0; anIter < mySize; anIter++) + { + myPointer[anIter] = theValue; + } } //! Size query - Standard_Integer Size (void) const - { return Length(); } + Standard_Integer Size() const + { + return Length(); + } + //! Length query (the same) - Standard_Integer Length (void) const - { return (myUpperBound-myLowerBound+1); } + Standard_Integer Length() const + { + return static_cast(mySize); + } //! Return TRUE if array has zero length. - Standard_Boolean IsEmpty() const { return myUpperBound < myLowerBound; } + Standard_Boolean IsEmpty() const + { + return mySize == 0; + } //! Lower bound - Standard_Integer Lower (void) const - { return myLowerBound; } + Standard_Integer Lower() const + { + return myLowerBound; + } + //! Upper bound - Standard_Integer Upper (void) const - { return myUpperBound; } - - //! myDeletable flag - Standard_Boolean IsDeletable (void) const - { return myDeletable; } - - //! IsAllocated flag - for naming compatibility - Standard_Boolean IsAllocated (void) const - { return myDeletable; } + Standard_Integer Upper() const + { + return myLowerBound + static_cast(mySize) - 1; + } //! Copies data of theOther array to this. //! This array should be pre-allocated and have the same length as theOther; //! otherwise exception Standard_DimensionMismatch is thrown. - NCollection_Array1& Assign (const NCollection_Array1& theOther) + NCollection_Array1& Assign(const NCollection_Array1& theOther) { if (&theOther == this) - return *this; - - Standard_DimensionMismatch_Raise_if (Length() != theOther.Length(), "NCollection_Array1::operator="); - if (myData == NULL) { return *this; } - - TheItemType * pMyItem = &myData[myLowerBound]; - TheItemType * const pEndItem = &(theOther.myData)[theOther.myUpperBound]; - TheItemType * pItem = &(theOther.myData)[theOther.myLowerBound]; - while (pItem <= pEndItem) * pMyItem ++ = * pItem ++; + Standard_DimensionMismatch_Raise_if(mySize != theOther.mySize, "NCollection_Array1::operator="); + for (size_t anInd = 0; anInd < mySize; anInd++) + { + myPointer[anInd] = theOther.myPointer[anInd]; + } + // Current implementation disable changing bounds by assigning return *this; } @@ -281,98 +274,134 @@ public: //! This array will borrow all the data from theOther. //! The moved object will keep pointer to the memory buffer and //! range, but it will not free the buffer on destruction. - NCollection_Array1& Move (NCollection_Array1& theOther) + NCollection_Array1& Move(NCollection_Array1&& theOther) noexcept { if (&theOther == this) { return *this; } - - if (myDeletable) + if (myIsOwner) { - delete[] &myData[myLowerBound]; + destroy(); + myAllocator.deallocate(myPointer, mySize); } - myLowerBound = theOther.myLowerBound; - myUpperBound = theOther.myUpperBound; - myDeletable = theOther.myDeletable; - myData = theOther.myData; - - theOther.myDeletable = Standard_False; - + mySize = theOther.mySize; + myPointer = theOther.myPointer; + myIsOwner = theOther.myIsOwner; + theOther.myIsOwner = false; return *this; } + NCollection_Array1& Move(NCollection_Array1& theOther) + { + return Move(std::move(theOther)); + } + //! Assignment operator; @sa Assign() NCollection_Array1& operator= (const NCollection_Array1& theOther) - { - return Assign (theOther); + { + return Assign(theOther); } //! Move assignment operator; @sa Move() - NCollection_Array1& operator= (NCollection_Array1&& theOther) + NCollection_Array1& operator= (NCollection_Array1&& theOther) noexcept { - return Move (theOther); + return Move(std::forward(theOther)); } //! @return first element - const TheItemType& First() const + const_reference First() const { - return myData[myLowerBound]; + return myPointer[0]; } //! @return first element - TheItemType& ChangeFirst() + reference ChangeFirst() { - return myData[myLowerBound]; + return myPointer[0]; } //! @return last element - const TheItemType& Last() const + const_reference Last() const { - return myData[myUpperBound]; + return myPointer[mySize - 1]; } //! @return last element - TheItemType& ChangeLast() + reference ChangeLast() { - return myData[myUpperBound]; + return myPointer[mySize - 1]; } //! Constant value access - const TheItemType& Value (const Standard_Integer theIndex) const + const_reference Value(const Standard_Integer theIndex) const { - Standard_OutOfRange_Raise_if (theIndex < myLowerBound || theIndex > myUpperBound, "NCollection_Array1::Value"); - return myData[theIndex]; + const size_t aPos = theIndex - myLowerBound; + Standard_OutOfRange_Raise_if(aPos >= mySize, "NCollection_Array1::Value"); + return myPointer[aPos]; } //! operator() - alias to Value - const TheItemType& operator() (const Standard_Integer theIndex) const - { return Value (theIndex); } + const_reference operator() (const Standard_Integer theIndex) const + { + return Value(theIndex); + } //! operator[] - alias to Value - const TheItemType& operator[] (Standard_Integer theIndex) const { return Value (theIndex); } + const_reference operator[] (const Standard_Integer theIndex) const + { + return Value(theIndex); + } //! Variable value access - TheItemType& ChangeValue (const Standard_Integer theIndex) + reference ChangeValue(const Standard_Integer theIndex) { - Standard_OutOfRange_Raise_if (theIndex < myLowerBound || theIndex > myUpperBound, "NCollection_Array1::ChangeValue"); - return myData[theIndex]; + const size_t aPos = theIndex - myLowerBound; + Standard_OutOfRange_Raise_if(aPos >= mySize, "NCollection_Array1::ChangeValue"); + return myPointer[aPos]; } //! operator() - alias to ChangeValue - TheItemType& operator() (const Standard_Integer theIndex) - { return ChangeValue (theIndex); } + reference operator() (const Standard_Integer theIndex) + { + return ChangeValue(theIndex); + } //! operator[] - alias to ChangeValue - TheItemType& operator[] (Standard_Integer theIndex) { return ChangeValue (theIndex); } + reference operator[] (const Standard_Integer theIndex) + { + return ChangeValue(theIndex); + } //! Set value - void SetValue (const Standard_Integer theIndex, - const TheItemType& theItem) + void SetValue(const Standard_Integer theIndex, + const value_type& theItem) { - Standard_OutOfRange_Raise_if (theIndex < myLowerBound || theIndex > myUpperBound, "NCollection_Array1::SetValue"); - myData[theIndex] = theItem; + const size_t aPos = theIndex - myLowerBound; + Standard_OutOfRange_Raise_if(aPos >= mySize, "NCollection_Array1::SetValue"); + myPointer[aPos] = theItem; + } + + //! Set value + void SetValue(const Standard_Integer theIndex, + value_type&& theItem) + { + const size_t aPos = theIndex - myLowerBound; + Standard_OutOfRange_Raise_if(aPos >= mySize, "NCollection_Array1::SetValue"); + myPointer[aPos] = std::forward(theItem); + } + + //! Changes the lowest bound. Do not move data + void UpdateLowerBound(const Standard_Integer theLower) + { + myLowerBound = theLower; + } + + //! Changes the upper bound. Do not move data + void UpdateUpperBound(const Standard_Integer theUpper) + { + myLowerBound = myLowerBound - Upper() + theUpper; } //! Resizes the array to specified bounds. @@ -381,61 +410,157 @@ public: //! @param theLower new lower bound of array //! @param theUpper new upper bound of array //! @param theToCopyData flag to copy existing data into new array - void Resize (const Standard_Integer theLower, - const Standard_Integer theUpper, - const Standard_Boolean theToCopyData) + void Resize(const Standard_Integer theLower, + const Standard_Integer theUpper, + const Standard_Boolean theToCopyData) { - Standard_RangeError_Raise_if (theUpper < theLower, "NCollection_Array1::Resize"); - const Standard_Integer anOldLen = Length(); - const Standard_Integer aNewLen = theUpper - theLower + 1; - - TheItemType* aBeginOld = myData != NULL ? &myData[myLowerBound] : NULL; + Standard_RangeError_Raise_if(theUpper < theLower, "NCollection_Array1::Resize"); + const size_t aNewSize = static_cast(theUpper - theLower + 1); + const size_t anOldSize = mySize; + pointer aPrevContPnt = myPointer; + if (aNewSize == anOldSize) + { + myLowerBound = theLower; + return; + } + if (myIsOwner) + { + if (theToCopyData) + destroy(myPointer, aNewSize, mySize); + else + destroy(); + } myLowerBound = theLower; - myUpperBound = theUpper; - if (aNewLen == anOldLen) + mySize = aNewSize; + if (theToCopyData) { - myData = aBeginOld - theLower; - return; + const size_t aMinSize = std::min(aNewSize, anOldSize); + if (myIsOwner) + { + myPointer = myAllocator.reallocate(myPointer, aNewSize); + } + else + { + myPointer = myAllocator.allocate(aNewSize); + copyConstruct(aPrevContPnt, aMinSize); + } + construct(anOldSize, aNewSize); } - - if (!theToCopyData && myDeletable) + else { - delete[] aBeginOld; + if (myIsOwner) + myAllocator.deallocate(aPrevContPnt, mySize); + myPointer = myAllocator.allocate(aNewSize); + construct(); } - TheItemType* aBeginNew = new TheItemType[aNewLen]; - Standard_OutOfMemory_Raise_if (aBeginNew == NULL, "NCollection_Array1 : Allocation failed"); - myData = aBeginNew - theLower; - if (!theToCopyData) - { - myDeletable = Standard_True; - return; - } - - const Standard_Integer aLenCopy = Min (anOldLen, aNewLen); - for (Standard_Integer anIter = 0; anIter < aLenCopy; ++anIter) - { - aBeginNew[anIter] = aBeginOld[anIter]; - } - if (myDeletable) - { - delete[] aBeginOld; - } - myDeletable = Standard_True; + myIsOwner = true; } - //! Destructor - releases the memory - ~NCollection_Array1 (void) - { - if (myDeletable) - delete [] &(myData[myLowerBound]); + bool IsDeletable() const + { + return myIsOwner; + } + + friend iterator; + friend const_iterator; + +protected: + + const_reference at(const size_t theIndex) const + { + Standard_OutOfRange_Raise_if(theIndex >= mySize, "NCollection_Array1::at"); + return myPointer[theIndex]; + } + + reference at(const size_t theIndex) + { + Standard_OutOfRange_Raise_if(theIndex >= mySize, "NCollection_Array1::at"); + return myPointer[theIndex]; + } + +protected: + + template + typename std::enable_if::value, void>::type construct() + { + // Do nothing + } + + template + typename std::enable_if::value, void>::type construct() + { + for (size_t anInd = 0; anInd < mySize; anInd++) + { + myAllocator.construct(myPointer + anInd); + } + } + + template + typename std::enable_if::value, void>::type construct(const size_t, + const size_t) + { + // Do nothing + } + + template + typename std::enable_if::value, void>::type construct(const size_t theFrom, + const size_t theTo) + { + for (size_t anInd = theFrom; anInd < theTo; anInd++) + { + myAllocator.construct(myPointer + anInd); + } + } + + template + typename std::enable_if::value, void>::type destroy() + { + // Do nothing + } + + template + typename std::enable_if::value, void>::type destroy() + { + for (size_t anInd = 0; anInd < mySize; anInd++) + { + myAllocator.destroy(myPointer + anInd); + } + } + + template + typename std::enable_if::value, void>::type destroy(pointer, + const size_t, + const size_t) + { + // Do nothing + } + + template + typename std::enable_if::value, void>::type destroy(pointer theWhat, + const size_t theFrom, + const size_t theTo) + { + for (size_t anInd = theFrom; anInd < theTo; anInd++) + { + myAllocator.destroy(theWhat + anInd); + } + } + + void copyConstruct(const pointer theFrom, + const size_t theCount) + { + for (size_t anInd = 0; anInd < theCount; anInd++) + { + myAllocator.construct(myPointer + anInd, theFrom[anInd]); + } } - protected: // ---------- PROTECTED FIELDS ----------- - Standard_Integer myLowerBound; - Standard_Integer myUpperBound; - Standard_Boolean myDeletable; //!< Flag showing who allocated the array - TheItemType* myData; //!< Pointer to '0'th array item + Standard_Integer myLowerBound; + size_t mySize; + pointer myPointer = nullptr; + bool myIsOwner = false; + allocator_type myAllocator; }; #endif diff --git a/src/NCollection/NCollection_Array2.hxx b/src/NCollection/NCollection_Array2.hxx index a06d435c74..3071eb93a4 100644 --- a/src/NCollection/NCollection_Array2.hxx +++ b/src/NCollection/NCollection_Array2.hxx @@ -18,14 +18,16 @@ #include #include +#include #include +#include #include // *********************************************** Template for Array2 class /** -* Purpose: The class Array2 represents bi-dimensional arrays -* of fixed size known at run time. +* Purpose: The class Array2 represents bi-dimensional arrays +* of fixed size known at run time. * The ranges of indices are user defined. * * Class allocates one 1D array storing full data (all Rows and Columns) @@ -34,268 +36,276 @@ * Warning: Programs clients of such class must be independent * of the range of the first element. Then, a C++ for * loop must be written like this -* +* * for (i = A.LowerRow(); i <= A.UpperRow(); i++) * for (j = A.LowerCol(); j <= A.UpperCol(); j++) -*/ +*/ template -class NCollection_Array2 +class NCollection_Array2 : public NCollection_Array1 { public: - //! STL-compliant typedef for value type - typedef TheItemType value_type; + //! Memory allocation + DEFINE_STANDARD_ALLOC; + DEFINE_NCOLLECTION_ALLOC; +public: + typedef NCollection_Allocator allocator_type; +public: + + // Define various type aliases for convenience + using value_type = typename NCollection_Array1::value_type; + using size_type = typename NCollection_Array1::size_type; + using difference_type = typename NCollection_Array1::difference_type; + using pointer = typename NCollection_Array1::pointer; + using const_pointer = typename NCollection_Array1::const_pointer; + using reference = typename NCollection_Array1::reference; + using const_reference = typename NCollection_Array1::const_reference; + + using iterator = typename NCollection_Array1::iterator; + using const_iterator = typename NCollection_Array1::const_iterator; + + static int BeginPosition(Standard_Integer theRowLower, + Standard_Integer /*theRowUpper*/, + Standard_Integer theColLower, + Standard_Integer theColUpper) + { + // Calculate the offset for the beginning position + return theColLower + (theRowLower * (theColUpper - theColLower + 1)); + } + + static int LastPosition(Standard_Integer theRowLower, + Standard_Integer theRowUpper, + Standard_Integer theColLower, + Standard_Integer theColUpper) + { + return ((theRowUpper - theRowLower + 1) * (theColUpper - theColLower + 1)) + theColLower + (theRowLower * (theColUpper - theColLower + 1)) - 1; + } public: - // **************** Implementation of the Iterator interface. - class Iterator - { - public: - //! Empty constructor - for later Init - Iterator (void) : - myCurrent (0), - mySize (0), - myArray (NULL) {} - //! Constructor with initialisation - Iterator (const NCollection_Array2& theArray) : - myCurrent (0), - mySize (theArray.Length()), - myArray ((NCollection_Array2 *) &theArray) {} - //! Initialisation - void Init (const NCollection_Array2& theArray) - { - myCurrent = 0; - mySize = theArray.Length(); - myArray = (NCollection_Array2 *) &theArray; - } - //! Check end - Standard_Boolean More (void) const - { return (myCurrent < mySize); } - //! Make step - void Next (void) - { myCurrent++; } - //! Constant value access - const TheItemType& Value (void) const - { return myArray->myStart[myCurrent]; } - //! Variable value access - TheItemType& ChangeValue (void) const - { return myArray->myStart[myCurrent]; } - private: - Standard_Integer myCurrent; //!< Index of the current item - Standard_Integer mySize; //!< Total amount of items - NCollection_Array2* myArray; //!< Pointer to the array being iterated - }; // End of nested class Iterator - - public: // ---------- PUBLIC METHODS ------------ //! Empty constructor; should be used with caution. //! @sa methods Resize() and Move(). - NCollection_Array2() - : myLowerRow (1), - myUpperRow (0), - myLowerCol (1), - myUpperCol (0), - myData (NULL), - myStart (NULL), - myDeletable(false) - { - // - } + NCollection_Array2() : + NCollection_Array1(), + myLowerRow(1), + mySizeRow(0), + myLowerCol(1), + mySizeCol(0) + {} //! Constructor NCollection_Array2(const Standard_Integer theRowLower, const Standard_Integer theRowUpper, const Standard_Integer theColLower, const Standard_Integer theColUpper) : - myLowerRow (theRowLower), - myUpperRow (theRowUpper), - myLowerCol (theColLower), - myUpperCol (theColUpper), - myDeletable (Standard_True) - { Allocate(); } + NCollection_Array1(BeginPosition(theRowLower, theRowUpper, theColLower, theColUpper), + LastPosition(theRowLower, theRowUpper, theColLower, theColUpper)), + myLowerRow(theRowLower), + mySizeRow(theRowUpper - theRowLower + 1), + myLowerCol(theColLower), + mySizeCol(theColUpper - theColLower + 1) + {} + + //! Constructor + explicit NCollection_Array2(const allocator_type& theAlloc, + const Standard_Integer theRowLower, + const Standard_Integer theRowUpper, + const Standard_Integer theColLower, + const Standard_Integer theColUpper) : + NCollection_Array1(theAlloc, + BeginPosition(theRowLower, theRowUpper, theColLower, theColUpper), + LastPosition(theRowLower, theRowUpper, theColLower, theColUpper)), + myLowerRow(theRowLower), + mySizeRow(theRowUpper - theRowLower + 1), + myLowerCol(theColLower), + mySizeCol(theColUpper - theColLower + 1) + {} //! Copy constructor - NCollection_Array2 (const NCollection_Array2& theOther) : - myLowerRow (theOther.LowerRow()), - myUpperRow (theOther.UpperRow()), - myLowerCol (theOther.LowerCol()), - myUpperCol (theOther.UpperCol()), - myDeletable (Standard_True) - { - Allocate(); - *this = theOther; - } + NCollection_Array2(const NCollection_Array2& theOther) : + NCollection_Array1(theOther), + myLowerRow(theOther.LowerRow()), + mySizeRow(theOther.NbRows()), + myLowerCol(theOther.LowerCol()), + mySizeCol(theOther.NbColumns()) + {} //! Move constructor - NCollection_Array2 (NCollection_Array2&& theOther) - : myLowerRow (theOther.myLowerRow), - myUpperRow (theOther.myUpperRow), - myLowerCol (theOther.myLowerRow), - myUpperCol (theOther.myUpperCol), - myData (theOther.myData), - myStart (theOther.myStart), - myDeletable(theOther.myDeletable) - { - theOther.myStart = NULL; - theOther.myData = NULL; - theOther.myDeletable = false; - } + NCollection_Array2(NCollection_Array2&& theOther) noexcept: + NCollection_Array1(std::forward(theOther)), + myLowerRow(theOther.LowerRow()), + mySizeRow(theOther.NbRows()), + myLowerCol(theOther.LowerCol()), + mySizeCol(theOther.NbColumns()) + {} //! C array-based constructor - NCollection_Array2(const TheItemType& theBegin, - const Standard_Integer theRowLower, - const Standard_Integer theRowUpper, - const Standard_Integer theColLower, - const Standard_Integer theColUpper) : - myLowerRow (theRowLower), - myUpperRow (theRowUpper), - myLowerCol (theColLower), - myUpperCol (theColUpper), - myDeletable (Standard_False) - { - myStart = (TheItemType *) &theBegin; - Allocate(); - } - - //! Initialise the values - void Init (const TheItemType& theValue) - { - TheItemType *pCur, *pEnd=myStart+Size(); - for(pCur = myStart; pCur(theBegin, + BeginPosition(theRowLower, theRowUpper, theColLower, theColUpper), + LastPosition(theRowLower, theRowUpper, theColLower, theColUpper)), + myLowerRow(theRowLower), + mySizeRow(theRowUpper - theRowLower + 1), + myLowerCol(theColLower), + mySizeCol(theColUpper - theColLower + 1) + {} //! Size (number of items) - Standard_Integer Size (void) const - { return Length(); } + Standard_Integer Size() const + { + return Length(); + } //! Length (number of items) - Standard_Integer Length (void) const - { return NbRows() * NbColumns(); } + Standard_Integer Length() const + { + return NbRows() * NbColumns(); + } //! Returns number of rows - Standard_Integer NbRows() const { return myUpperRow - myLowerRow + 1; } + Standard_Integer NbRows() const + { + return static_cast(mySizeRow); + } //! Returns number of columns - Standard_Integer NbColumns() const { return myUpperCol - myLowerCol + 1; } + Standard_Integer NbColumns() const + { + return static_cast(mySizeCol); + } //! Returns length of the row, i.e. number of columns - Standard_Integer RowLength() const { return NbColumns(); } + Standard_Integer RowLength() const + { + return NbColumns(); + } //! Returns length of the column, i.e. number of rows - Standard_Integer ColLength() const { return NbRows(); } + Standard_Integer ColLength() const + { + return NbRows(); + } //! LowerRow - Standard_Integer LowerRow (void) const - { return myLowerRow; } + Standard_Integer LowerRow() const + { + return myLowerRow; + } //! UpperRow - Standard_Integer UpperRow (void) const - { return myUpperRow; } + Standard_Integer UpperRow() const + { + return myLowerRow + static_cast(mySizeRow) - 1; + } //! LowerCol - Standard_Integer LowerCol (void) const - { return myLowerCol; } + Standard_Integer LowerCol() const + { + return myLowerCol; + } //! UpperCol - Standard_Integer UpperCol (void) const - { return myUpperCol; } - - //! myDeletable flag - Standard_Boolean IsDeletable (void) const - { return myDeletable; } + Standard_Integer UpperCol() const + { + return myLowerCol + static_cast(mySizeCol) - 1; + } //! Assignment - NCollection_Array2& Assign (const NCollection_Array2& theOther) - { + NCollection_Array2& Assign(const NCollection_Array2& theOther) + { if (&theOther == this) + { return *this; - Standard_DimensionMismatch_Raise_if (Length() != theOther.Length(), "NCollection_Array2::operator="); - TheItemType * pMyItem = myStart; - TheItemType * pItem = theOther.myStart; - const Standard_Integer iSize = Length(); - for (Standard_Integer i=0; i < iSize; i++, pItem++, pMyItem++) - *pMyItem = *pItem; - return *this; + } + NCollection_Array1::Assign(theOther); + return *this; + } + + + //! Move assignment. + //! This array will borrow all the data from theOther. + //! The moved object will be left uninitialized and should not be used anymore. + NCollection_Array2& Move(NCollection_Array2&& theOther) + { + if (&theOther == this) + { + return *this; + } + NCollection_Array1::Move(theOther); + myLowerRow = theOther.myLowerRow; + mySizeRow = theOther.mySizeRow; + myLowerCol = theOther.myLowerCol; + mySizeCol = theOther.mySizeCol; + return *this; } //! Move assignment. //! This array will borrow all the data from theOther. //! The moved object will be left uninitialized and should not be used anymore. - NCollection_Array2& Move (NCollection_Array2& theOther) + NCollection_Array2& Move(NCollection_Array2& theOther) { - if (&theOther == this) - { - return *this; - } - - if (myDeletable) - { - delete[] myStart; - } - if (myData != NULL) - { - delete[] &(myData[myLowerRow]); - } - - myLowerRow = theOther.myLowerRow; - myUpperRow = theOther.myUpperRow; - myLowerCol = theOther.myLowerRow; - myUpperCol = theOther.myUpperCol; - myData = theOther.myData; - myStart = theOther.myStart; - myDeletable = theOther.myDeletable; - - theOther.myStart = NULL; - theOther.myData = NULL; - theOther.myDeletable = Standard_False; - return *this; + return Move(std::move(theOther)); } //! Assignment operator NCollection_Array2& operator= (const NCollection_Array2& theOther) - { - return Assign (theOther); + { + return Assign(theOther); } //! Move assignment operator; @sa Move() NCollection_Array2& operator= (NCollection_Array2&& theOther) { - return Move (theOther); + return Move(std::forward(theOther)); } //! Constant value access - const TheItemType& Value (const Standard_Integer theRow, - const Standard_Integer theCol) const + const_reference Value(const Standard_Integer theRow, + const Standard_Integer theCol) const { - Standard_OutOfRange_Raise_if (theRow < myLowerRow || theRow > myUpperRow || - theCol < myLowerCol || theCol > myUpperCol, "NCollection_Array2::Value"); - return myData[theRow][theCol]; + const size_t aPos = (theRow - myLowerRow) * mySizeCol + (theCol - myLowerCol); + return NCollection_Array1::at(aPos); } //! operator() - alias to ChangeValue - const TheItemType& operator() (const Standard_Integer theRow, - const Standard_Integer theCol) const - { return Value (theRow,theCol); } + const_reference operator() (const Standard_Integer theRow, + const Standard_Integer theCol) const + { + const size_t aPos = (theRow - myLowerRow) * mySizeCol + (theCol - myLowerCol); + return NCollection_Array1::at(aPos); + } //! Variable value access - TheItemType& ChangeValue (const Standard_Integer theRow, - const Standard_Integer theCol) + reference ChangeValue(const Standard_Integer theRow, + const Standard_Integer theCol) { - Standard_OutOfRange_Raise_if (theRow < myLowerRow || theRow > myUpperRow || - theCol < myLowerCol || theCol > myUpperCol, "NCollection_Array2::ChangeValue"); - return myData[theRow][theCol]; + const size_t aPos = (theRow - myLowerRow) * mySizeCol + (theCol - myLowerCol); + return NCollection_Array1::at(aPos); } //! operator() - alias to ChangeValue - TheItemType& operator() (const Standard_Integer theRow, - const Standard_Integer theCol) - { return ChangeValue (theRow,theCol); } + reference operator() (const Standard_Integer theRow, + const Standard_Integer theCol) + { + return ChangeValue(theRow, theCol); + } //! SetValue - void SetValue (const Standard_Integer theRow, - const Standard_Integer theCol, - const TheItemType& theItem) + void SetValue(const Standard_Integer theRow, + const Standard_Integer theCol, + const TheItemType& theItem) { - Standard_OutOfRange_Raise_if (theRow < myLowerRow || theRow > myUpperRow || - theCol < myLowerCol || theCol > myUpperCol, "NCollection_Array2::SetValue"); - myData[theRow][theCol] = theItem; + const size_t aPos = (theRow - myLowerRow) * mySizeCol + (theCol - myLowerCol); + NCollection_Array1::at(aPos) = theItem; + } + + //! SetValue + void SetValue(const Standard_Integer theRow, + const Standard_Integer theCol, + TheItemType&& theItem) + { + const size_t aPos = (theRow - myLowerRow) * mySizeCol + (theCol - myLowerCol); + NCollection_Array1::at(aPos) = std::forward(theItem); } //! Resizes the array to specified bounds. @@ -306,131 +316,56 @@ public: //! @param theColLower new lower Column of array //! @param theColUpper new upper Column of array //! @param theToCopyData flag to copy existing data into new array - void Resize (Standard_Integer theRowLower, - Standard_Integer theRowUpper, - Standard_Integer theColLower, - Standard_Integer theColUpper, - Standard_Boolean theToCopyData) + void Resize(Standard_Integer theRowLower, + Standard_Integer theRowUpper, + Standard_Integer theColLower, + Standard_Integer theColUpper, + Standard_Boolean theToCopyData) { - Standard_RangeError_Raise_if (theRowUpper < theRowLower - || theColUpper < theColLower, "NCollection_Array2::Resize"); - const Standard_Integer anOldNbRows = NbRows(); - const Standard_Integer anOldNbCols = NbColumns(); - const Standard_Integer aLowerRowOld = myLowerRow; - const Standard_Integer aLowerColOld = myLowerCol; - const Standard_Integer aNewNbRows = theRowUpper - theRowLower + 1; - const Standard_Integer aNewNbCols = theColUpper - theColLower + 1; - - TheItemType* aStartOld = myStart; - TheItemType** aTableOld = myData != NULL ? myData + aLowerRowOld : NULL; + Standard_RangeError_Raise_if(theRowUpper < theRowLower || + theColUpper < theColLower, "NCollection_Array2::Resize"); myLowerRow = theRowLower; - myUpperRow = theRowUpper; myLowerCol = theColLower; - myUpperCol = theColUpper; - if (aNewNbRows == anOldNbRows - && aNewNbCols == anOldNbCols) - { - if (myLowerCol != aLowerColOld) - { - fillIndexTable (aTableOld); - } - myData = aTableOld - myLowerRow; - return; - } - - if (myDeletable - && !theToCopyData) - { - delete[] aStartOld; - } - delete[] aTableOld; - - const Standard_Boolean wasDeletable = myDeletable; - myDeletable = Standard_True; - Allocate(); if (!theToCopyData) { + NCollection_Array1::Resize(BeginPosition(theRowLower, theRowUpper, theColLower, theColUpper), + LastPosition(theRowLower, theRowUpper, theColLower, theColUpper), + false); + mySizeRow = theRowUpper - theRowLower + 1; + mySizeCol = theColUpper - theColLower + 1; return; } - - const Standard_Integer aNbRowsToCopy = Min (anOldNbRows, aNewNbRows); - const Standard_Integer aNbColsToCopy = Min (anOldNbCols, aNewNbCols); - for (Standard_Integer aRowIter = 0; aRowIter < aNbRowsToCopy; ++aRowIter) + NCollection_Array1 aTmpMovedCopy(std::move(*this)); + TheItemType* anOldPointer = &aTmpMovedCopy.ChangeFirst(); + NCollection_Array1::Resize(BeginPosition(theRowLower, theRowUpper, theColLower, theColUpper), + LastPosition(theRowLower, theRowUpper, theColLower, theColUpper), + false); + const size_t aNewNbRows = theRowUpper - theRowLower + 1; + const size_t aNewNbCols = theColUpper - theColLower + 1; + const size_t aNbRowsToCopy = std::min(mySizeRow, aNewNbRows); + const size_t aNbColsToCopy = std::min(mySizeCol, aNewNbCols); + mySizeRow = aNewNbRows; + mySizeCol = aNewNbCols; + size_t aOldInter = 0; + for (size_t aRowIter = 0; aRowIter < aNbRowsToCopy; ++aRowIter) { - for (Standard_Integer aColIter = 0; aColIter < aNbColsToCopy; ++aColIter) + for (size_t aColIter = 0; aColIter < aNbColsToCopy; ++aColIter) { - myStart[size_t(aRowIter) * size_t(aNewNbCols) + size_t(aColIter)] = aStartOld[size_t(aRowIter) * size_t(anOldNbCols) + size_t(aColIter)]; + NCollection_Array1::at(aRowIter * aNewNbCols + aColIter) = std::move(anOldPointer[aOldInter++]); } } - - if (wasDeletable) - { - delete[] aStartOld; - } } - //! Destructor - releases the memory - ~NCollection_Array2 (void) - { - if (myDeletable) delete [] myStart; - if (myData != NULL) - { - delete[] &(myData[myLowerRow]); - } - } - - private: - // ----------- PRIVATE METHODS ----------- - - //! Allocate memory for the array, set up indirection table - void Allocate (void) - { - const Standard_Integer aNbRows = NbRows(); - const Standard_Integer aNbCols = NbColumns(); - Standard_RangeError_Raise_if (aNbRows <= 0 || aNbCols <= 0, "NCollection_Array2::Allocate"); - if (myDeletable) - { - // allocation of the data in the array - myStart = new TheItemType[size_t(aNbRows) * size_t(aNbCols)]; - Standard_OutOfMemory_Raise_if (!myStart, "NCollection_Array2 : Allocation failed"); - } - // else myStart is set to the beginning of the given array - - TheItemType** pTable = new TheItemType* [aNbRows]; - Standard_OutOfMemory_Raise_if (!pTable, "NCollection_Array2 : Allocation failed"); - fillIndexTable (pTable); - } - - //! Fill index table for accessing array elements. - void fillIndexTable (TheItemType** theTable) - { - // Items of table point to the 0th items in the rows of the array - TheItemType* aRow = myStart - myLowerCol; - const Standard_Integer aNbRows = NbRows(); - const Standard_Size aNbCols = NbColumns(); - for (Standard_Integer aRowIter = 0; aRowIter < aNbRows; ++aRowIter) - { - theTable[aRowIter] = aRow; - aRow += aNbCols; - } - - // Set myData to the 0th row pointer of the table - myData = theTable - myLowerRow; - } - - protected: +protected: // ---------- PROTECTED FIELDS ----------- Standard_Integer myLowerRow; - Standard_Integer myUpperRow; + size_t mySizeRow; Standard_Integer myLowerCol; - Standard_Integer myUpperCol; - - TheItemType** myData; //!< Pointer to the row pointers table - TheItemType* myStart; //!< Pointer to the memory array - Standard_Boolean myDeletable; //!< Flag showing who allocated the array + size_t mySizeCol; // ----------- FRIEND CLASSES ------------ - friend class Iterator; + friend iterator; + friend const_iterator; }; diff --git a/src/NCollection/NCollection_BaseAllocator.cxx b/src/NCollection/NCollection_BaseAllocator.cxx index d536b0b7b8..d7f3be1781 100644 --- a/src/NCollection/NCollection_BaseAllocator.cxx +++ b/src/NCollection/NCollection_BaseAllocator.cxx @@ -1,6 +1,4 @@ -// Created on: 2002-04-12 -// Created by: Alexander KARTOMIN (akm) -// Copyright (c) 2002-2014 OPEN CASCADE SAS +/// Copyright (c) 2002-2023 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // @@ -15,271 +13,43 @@ #include -#include -#include -#include -#include -#include -#include -#include - - IMPLEMENT_STANDARD_RTTIEXT(NCollection_BaseAllocator,Standard_Transient) //======================================================================= //function : Allocate //purpose : Standard allocation //======================================================================= +void* NCollection_BaseAllocator::Allocate(const size_t theSize) +{ + return Standard::Allocate(theSize); +} -void* NCollection_BaseAllocator::Allocate(const size_t size) -{ - return Standard::Allocate(size); +//======================================================================= +//function : AllocateOptimal +//purpose : Optimal allocation +//======================================================================= +void* NCollection_BaseAllocator::AllocateOptimal(const size_t theSize) +{ + return Standard::AllocateOptimal(theSize); } //======================================================================= //function : Free //purpose : Standard deallocation //======================================================================= - -void NCollection_BaseAllocator::Free(void *anAddress) -{ - if (anAddress) Standard::Free(anAddress); +void NCollection_BaseAllocator::Free(void* theAddress) +{ + Standard::Free(theAddress); } //======================================================================= //function : CommonBaseAllocator //purpose : Creates the only one BaseAllocator //======================================================================= - const Handle(NCollection_BaseAllocator)& NCollection_BaseAllocator::CommonBaseAllocator(void) { - static Handle(NCollection_BaseAllocator) pAllocator = + static Handle(NCollection_BaseAllocator) THE_SINGLETON_ALLOC = new NCollection_BaseAllocator; - return pAllocator; -} - -namespace -{ - // global variable to ensure that allocator will be created during loading the library - static Handle(NCollection_BaseAllocator) theAllocInit = NCollection_BaseAllocator::CommonBaseAllocator(); - - //! Structure for collecting statistics about blocks of one size - struct StorageInfo - { - Standard_Size roundSize; - int nbAlloc; - int nbFree; - StorageInfo() : roundSize(0), nbAlloc(0), nbFree(0) {} - StorageInfo(Standard_Size theSize) : roundSize(theSize), nbAlloc(0), nbFree(0) {} - }; - - //! Static data map (block_size -> StorageInfo) - static NCollection_DataMap& StorageMap() - { - static NCollection_IncAllocator TheAlloc; - static NCollection_DataMap TheMap (1, & TheAlloc); - return TheMap; - } - - //! Static data map (address -> AllocationID) - static NCollection_DataMap& StorageIDMap() - { - static NCollection_IncAllocator TheAlloc; - static NCollection_DataMap TheMap (1, & TheAlloc); - return TheMap; - } - - //! Static map (AllocationID) - static NCollection_Map& StorageIDSet() - { - static NCollection_IncAllocator TheAlloc; - static NCollection_Map TheMap (1, & TheAlloc); - return TheMap; - } - - // dummy function for break point - inline void place_for_break_point () {} - - //! Static value of the current allocation ID. It provides unique numbering of allocation events. - static Standard_Size CurrentID = 0; -} - -//======================================================================= -/** - * Exported value to set the block size for which it is required - * collecting alive allocation IDs. - * The method NCollection_BaseAllocator::PrintMemUsageStatistics - * dumps all alive IDs into the file alive.d in the current directory. - */ -//======================================================================= -Standard_EXPORT Standard_Size& StandardCallBack_CatchSize() -{ - static Standard_Size Value = 0; - return Value; -} - -//======================================================================= -/** - * Exported value to set the allocation ID for which it is required - * to set a breakpoint on the moment of allocation or freeing. - * See the method NCollection_BaseAllocator::StandardCallBack - * where the value StandardCallBack_CatchID() is compared to the current ID. - * There you can place a break point at the stub assignment statement "a =". - */ -//======================================================================= -Standard_EXPORT Standard_Size& StandardCallBack_CatchID() -{ - static Standard_Size Value = 0; - return Value; -} - -//======================================================================= -/** - * Exported function to reset the callback system to the initial state - */ -//======================================================================= -Standard_EXPORT void StandardCallBack_Reset() -{ - StorageMap().Clear(); - StorageIDMap().Clear(); - StorageIDSet().Clear(); - CurrentID = 0; - StandardCallBack_CatchSize() = 0; - StandardCallBack_CatchID() = 0; -} - -//======================================================================= -//function : StandardCallBack -//purpose : Callback function to register alloc/free calls -//======================================================================= - -void NCollection_BaseAllocator::StandardCallBack - (const Standard_Boolean theIsAlloc, - const Standard_Address theStorage, - const Standard_Size theRoundSize, - const Standard_Size /*theSize*/) -{ - static Standard_Mutex aMutex; - aMutex.Lock(); - // statistics by storage size - NCollection_DataMap& aStMap = StorageMap(); - if (!aStMap.IsBound(theRoundSize)) - { - StorageInfo aEmpty(theRoundSize); - aStMap.Bind(theRoundSize, aEmpty); - } - StorageInfo& aInfo = aStMap(theRoundSize); - if (theIsAlloc) - aInfo.nbAlloc++; - else - aInfo.nbFree++; - - if (theRoundSize == StandardCallBack_CatchSize()) - { - // statistics by alive objects - NCollection_DataMap& aStIDMap = StorageIDMap(); - NCollection_Map& aStIDSet = StorageIDSet(); - if (theIsAlloc) - { - aStIDMap.Bind(theStorage, ++CurrentID); - aStIDSet.Add(CurrentID); - if (CurrentID == StandardCallBack_CatchID()) - { - // Place for break point for allocation of investigated ID - place_for_break_point(); - } - } - else - { - if (aStIDMap.IsBound(theStorage)) - { - Standard_Size anID = aStIDMap(theStorage); - aStIDSet.Remove(anID); - if (anID == StandardCallBack_CatchID()) - { - // Place for break point for freeing of investigated ID - place_for_break_point(); - } - } - } - } - - aMutex.Unlock(); -} - -//======================================================================= -//function : PrintMemUsageStatistics -//purpose : Prints memory usage statistics cumulated by StandardCallBack -//======================================================================= - -void NCollection_BaseAllocator::PrintMemUsageStatistics() -{ - // sort by roundsize - NCollection_List aColl; - NCollection_List::Iterator itLst; - NCollection_DataMap::Iterator itMap(StorageMap()); - for (; itMap.More(); itMap.Next()) - { - for (itLst.Init(aColl); itLst.More(); itLst.Next()) - if (itMap.Value().roundSize < itLst.Value().roundSize) - break; - if (itLst.More()) - aColl.InsertBefore(itMap.Value(), itLst); - else - aColl.Append(itMap.Value()); - } - Standard_Size aTotAlloc = 0; - Standard_Size aTotLeft = 0; - - // print - std::ofstream aFileOut ("memstat.d", std::ios_base::trunc | std::ios_base::out); - if (!aFileOut.is_open()) - { - std::cout << "failure writing file memstat.d" << std::endl; - return; - } - aFileOut.imbue (std::locale ("C")); - - // header - aFileOut << std::setw(20) << "BlockSize" << ' ' - << std::setw(12) << "NbAllocated" << ' ' - << std::setw(12) << "NbLeft" << ' ' - << std::setw(20) << "Allocated" << ' ' - << std::setw(20) << "Left" << '\n'; - - // body - for (itLst.Init(aColl); itLst.More(); itLst.Next()) - { - const StorageInfo& aInfo = itLst.Value(); - Standard_Integer nbLeft = aInfo.nbAlloc - aInfo.nbFree; - Standard_Size aSizeAlloc = aInfo.nbAlloc * aInfo.roundSize; - Standard_Size aSizeLeft = nbLeft * aInfo.roundSize; - - aFileOut << std::setw(20) << aInfo.roundSize << ' ' - << std::setw(12) << aInfo.nbAlloc << ' ' - << std::setw(12) << nbLeft << ' ' - << std::setw(20) << aSizeAlloc << ' ' - << std::setw(20) << aSizeLeft << '\n'; - - aTotAlloc += aSizeAlloc; - aTotLeft += aSizeLeft; - } - - // footer - aFileOut << std::setw(20) << "Total:" << ' ' - << std::setw(12) << "" << ' ' - << std::setw(12) << "" << ' ' - << std::setw(20) << aTotAlloc << ' ' - << std::setw(20) << aTotLeft << '\n'; - - if (!StorageIDSet().IsEmpty()) - { - aFileOut << "Alive allocation numbers of size=" << StandardCallBack_CatchSize() << '\n'; - for (NCollection_Map::Iterator itMap1(StorageIDSet()); itMap1.More(); itMap1.Next()) - { - aFileOut << itMap1.Key() << '\n'; - } - } - aFileOut.close(); + return THE_SINGLETON_ALLOC; } diff --git a/src/NCollection/NCollection_BaseAllocator.hxx b/src/NCollection/NCollection_BaseAllocator.hxx index 7d6448e4d8..0bc0f40804 100644 --- a/src/NCollection/NCollection_BaseAllocator.hxx +++ b/src/NCollection/NCollection_BaseAllocator.hxx @@ -1,6 +1,6 @@ // Created on: 2002-04-12 // Created by: Alexander KARTOMIN (akm) -// Copyright (c) 2002-2014 OPEN CASCADE SAS +// Copyright (c) 2002-2023 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // @@ -27,10 +27,8 @@ #ifndef NCollection_BaseAllocator_HeaderFile #define NCollection_BaseAllocator_HeaderFile +#include #include -#include -#include - /** * Purpose: Basic class for memory allocation wizards. @@ -43,14 +41,15 @@ * inaccessible. To create the BaseAllocator use the method * CommonBaseAllocator. * Note that this object is managed by Handle. -*/ +*/ class NCollection_BaseAllocator : public Standard_Transient { public: // ---------- PUBLIC METHODS ------------ - Standard_EXPORT virtual void* Allocate (const size_t size); - Standard_EXPORT virtual void Free (void * anAddress); - + Standard_EXPORT virtual void* Allocate (const size_t theSize); + Standard_EXPORT virtual void* AllocateOptimal(const size_t theSize); + Standard_EXPORT virtual void Free (void* theAddress); + //! CommonBaseAllocator //! This method is designed to have the only one BaseAllocator (to avoid //! useless copying of collections). However one can use operator new to @@ -58,29 +57,18 @@ class NCollection_BaseAllocator : public Standard_Transient Standard_EXPORT static const Handle(NCollection_BaseAllocator)& CommonBaseAllocator(void); - //! Callback function to register alloc/free calls - Standard_EXPORT static void StandardCallBack - (const Standard_Boolean theIsAlloc, - const Standard_Address theStorage, - const Standard_Size theRoundSize, - const Standard_Size theSize); - - //! Prints memory usage statistics cumulated by StandardCallBack - Standard_EXPORT static void PrintMemUsageStatistics(); - - protected: +protected: //! Constructor - prohibited - NCollection_BaseAllocator(void) {} + NCollection_BaseAllocator() {} - private: +private: //! Copy constructor - prohibited - NCollection_BaseAllocator(const NCollection_BaseAllocator&); + NCollection_BaseAllocator(const NCollection_BaseAllocator&) = delete; - public: +public: // ---------- CasCade RunTime Type Information DEFINE_STANDARD_RTTIEXT(NCollection_BaseAllocator,Standard_Transient) }; - DEFINE_STANDARD_HANDLE(NCollection_BaseAllocator,Standard_Transient) #endif diff --git a/src/NCollection/NCollection_BaseMap.cxx b/src/NCollection/NCollection_BaseMap.cxx index c18c219fcb..7f32f332b3 100644 --- a/src/NCollection/NCollection_BaseMap.cxx +++ b/src/NCollection/NCollection_BaseMap.cxx @@ -39,13 +39,11 @@ Standard_Boolean NCollection_BaseMap::BeginResize return Standard_False; } data1 = (NCollection_ListNode **) - myAllocator->Allocate((N+1)*sizeof(NCollection_ListNode *)); - memset(data1, 0, (N+1)*sizeof(NCollection_ListNode *)); + Standard::Allocate((N+1)*sizeof(NCollection_ListNode *)); if (isDouble) { data2 = (NCollection_ListNode **) - myAllocator->Allocate((N+1)*sizeof(NCollection_ListNode *)); - memset(data2, 0, (N+1)*sizeof(NCollection_ListNode *)); + Standard::Allocate((N+1)*sizeof(NCollection_ListNode *)); } else data2 = NULL; @@ -65,9 +63,9 @@ void NCollection_BaseMap::EndResize { (void )theNbBuckets; // obsolete parameter if (myData1) - myAllocator->Free(myData1); - if (myData2) - myAllocator->Free(myData2); + Standard::Free(myData1); + if (myData2 && isDouble) + Standard::Free(myData2); myNbBuckets = N; myData1 = data1; myData2 = data2; @@ -84,32 +82,34 @@ void NCollection_BaseMap::Destroy (NCollection_DelMapNode fDel, { if (!IsEmpty()) { - Standard_Integer i; - NCollection_ListNode** data = (NCollection_ListNode**) myData1; - NCollection_ListNode *p,*q; - for (i = 0; i <= NbBuckets(); i++) + const int aNbBuckets = NbBuckets(); + for (int anInd = 0; anInd <= aNbBuckets; anInd++) { - if (data[i]) + if (myData1[anInd]) { - p = data[i]; - while (p) + NCollection_ListNode* aCur = myData1[anInd]; + while (aCur) { - q = (NCollection_ListNode*)p->Next(); - fDel (p, myAllocator); - p = q; + NCollection_ListNode* aNext = aCur->Next(); + fDel (aCur, myAllocator); + aCur = aNext; } - data[i] = NULL; + myData1[anInd] = nullptr; } } + if (myData2) + { + memset(myData2, 0, (aNbBuckets + 1) * sizeof(NCollection_ListNode*)); + } } mySize = 0; if (doReleaseMemory) { - if (myData1) - myAllocator->Free(myData1); - if (isDouble && myData2) - myAllocator->Free(myData2); + if (myData1) + Standard::Free(myData1); + if (myData2) + Standard::Free(myData2); myData1 = myData2 = NULL; } } diff --git a/src/NCollection/NCollection_BaseMap.hxx b/src/NCollection/NCollection_BaseMap.hxx index 62b34536b2..2e6b7f4471 100644 --- a/src/NCollection/NCollection_BaseMap.hxx +++ b/src/NCollection/NCollection_BaseMap.hxx @@ -159,14 +159,28 @@ public: //! Constructor NCollection_BaseMap (const Standard_Integer NbBuckets, const Standard_Boolean single, - const Handle(NCollection_BaseAllocator)& theAllocator) - : myData1(NULL), + const Handle(NCollection_BaseAllocator)& theAllocator) : + myAllocator(theAllocator.IsNull() ? NCollection_BaseAllocator::CommonBaseAllocator() : theAllocator), + myData1(NULL), myData2(NULL), myNbBuckets(NbBuckets), mySize(0), isDouble(!single) + {} + + //! Move Constructor + NCollection_BaseMap(NCollection_BaseMap&& theOther) noexcept : + myAllocator(theOther.myAllocator), + myData1(theOther.myData1), + myData2(theOther.myData2), + myNbBuckets(theOther.myNbBuckets), + mySize(theOther.mySize), + isDouble(theOther.isDouble) { - myAllocator = (theAllocator.IsNull() ? NCollection_BaseAllocator::CommonBaseAllocator() : theAllocator); + theOther.myData1 = nullptr; + theOther.myData1 = nullptr; + theOther.mySize = 0; + theOther.myNbBuckets = 0; } //! Destructor @@ -212,9 +226,17 @@ public: std::swap (myData2, theOther.myData2); std::swap (myNbBuckets, theOther.myNbBuckets); std::swap (mySize, theOther.mySize); - //std::swap (isDouble, theOther.isDouble); } + //! Move operator + NCollection_BaseMap& operator=(NCollection_BaseMap&&) noexcept = delete; + + //! Copy Constructor + NCollection_BaseMap(const NCollection_BaseMap&) = delete; + + //! Assign operator + NCollection_BaseMap& operator=(const NCollection_BaseMap&) = delete; + protected: // --------- PROTECTED FIELDS ----------- Handle(NCollection_BaseAllocator) myAllocator; @@ -225,7 +247,7 @@ public: // ---------- PRIVATE FIELDS ------------ Standard_Integer myNbBuckets; Standard_Integer mySize; - Standard_Boolean isDouble; + const Standard_Boolean isDouble; // ---------- FRIEND CLASSES ------------ friend class Iterator; diff --git a/src/NCollection/NCollection_BasePointerVector.cxx b/src/NCollection/NCollection_BasePointerVector.cxx new file mode 100644 index 0000000000..55a3439448 --- /dev/null +++ b/src/NCollection/NCollection_BasePointerVector.cxx @@ -0,0 +1,145 @@ +// Copyright (c) 2023 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#include + +#include +#include + +//======================================================================= +//function : NCollection_BasePointerVector +//purpose : +//======================================================================= +NCollection_BasePointerVector::NCollection_BasePointerVector(const NCollection_BasePointerVector& theOther) : + mySize(theOther.mySize), + myCapacity(theOther.myCapacity) +{ + if (myCapacity > 0) + { + myArray = myAllocator.allocate(myCapacity); + memcpy(myArray, theOther.myArray, Size() * sizeof(void*)); + } +} + +//======================================================================= +//function : NCollection_BasePointerVector +//purpose : +//======================================================================= +NCollection_BasePointerVector::NCollection_BasePointerVector(NCollection_BasePointerVector&& theOther) noexcept : + mySize(std::move(theOther.mySize)), + myCapacity(std::move(theOther.myCapacity)), + myArray(std::move(theOther.myArray)) +{ + theOther.myCapacity = 0; + theOther.mySize = 0; + theOther.myArray = nullptr; +} + +//======================================================================= +//function : Append +//purpose : +//======================================================================= +void NCollection_BasePointerVector::Append (const void* thePnt) +{ + if (mySize == myCapacity) + { + if (myCapacity == 0) + { + myCapacity = 8; // the most optimal initial value + } + else + { + myCapacity <<= 1; + } + myArray = myAllocator.reallocate(myArray, myCapacity); + } + myArray[mySize++] = (void*)thePnt; +} + +//======================================================================= +//function : SetValue +//purpose : +//======================================================================= +void NCollection_BasePointerVector::SetValue (const size_t theInd, const void* thePnt) +{ + if (theInd >= myCapacity) + { + if (myCapacity == 0) + { + myCapacity = 8; // the most optimal initial value + } + while (myCapacity < theInd) + { + myCapacity <<= 1; + } + myArray = myAllocator.reallocate(myArray, myCapacity); + memset(myArray + mySize, 0, (theInd - mySize) * sizeof(void**)); + mySize = theInd; + } + myArray[theInd] = (void*)thePnt; +} + +//======================================================================= +//function : clear +//purpose : +//======================================================================= +void NCollection_BasePointerVector::clear() +{ + if (myCapacity > 0) + { + myAllocator.deallocate(myArray, myCapacity); + } + myArray = nullptr; + myCapacity = 0; +} + +//======================================================================= +//function : operator= +//purpose : +//======================================================================= +NCollection_BasePointerVector& NCollection_BasePointerVector::operator=(const NCollection_BasePointerVector& theOther) +{ + if (this == &theOther) + { + return *this; + } + mySize = theOther.mySize; + if (myCapacity < theOther.myCapacity) + { + clear(); + myCapacity = theOther.myCapacity; + myArray = myAllocator.allocate(myCapacity); + } + memcpy(myArray, theOther.myArray, mySize * sizeof(void*)); + return *this; +} + +//======================================================================= +//function : operator= +//purpose : +//======================================================================= +NCollection_BasePointerVector& NCollection_BasePointerVector::operator=(NCollection_BasePointerVector&& theOther) noexcept +{ + if (this == &theOther) + { + return *this; + } + clear(); + mySize = std::move(theOther.mySize); + myCapacity = std::move(theOther.myCapacity); + myArray = std::move(theOther.myArray); + theOther.myCapacity = 0; + theOther.mySize = 0; + theOther.myArray = nullptr; + return *this; +} \ No newline at end of file diff --git a/src/NCollection/NCollection_BasePointerVector.hxx b/src/NCollection/NCollection_BasePointerVector.hxx new file mode 100644 index 0000000000..866eb73e49 --- /dev/null +++ b/src/NCollection/NCollection_BasePointerVector.hxx @@ -0,0 +1,107 @@ +// Copyright (c) 2023 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef NCollection_BasePointerVector_HeaderFile +#define NCollection_BasePointerVector_HeaderFile + +#include + +#include +#include + +//! Simplified class for vector of pointers of void. +//! Offers basic functionality to scalable inserts, +//! resizes and erasing last. +//! +//! Control of processing values of pointers out-of-scope +//! and should be controlled externally. +//! Especially, copy operation should post-process elements of pointers to make deep copy. +class NCollection_BasePointerVector +{ +public: + //! Memory allocation + DEFINE_STANDARD_ALLOC + DEFINE_NCOLLECTION_ALLOC + +public: + + //! Default constructor + NCollection_BasePointerVector() {} + + //! Copy data from another vector + Standard_EXPORT NCollection_BasePointerVector(const NCollection_BasePointerVector& theOther); + + //! Move data from another vector + Standard_EXPORT NCollection_BasePointerVector(NCollection_BasePointerVector&& theOther) noexcept; + + //! Destroy container + ~NCollection_BasePointerVector() { clear(); } + + //! Checks for an empty status + bool IsEmpty() const { return mySize == 0; } + + //! Gets used size + size_t Size() const { return mySize; } + + //! Gets available capacity + size_t Capacity() const { return myCapacity; } + + //! Erases last element, decrements size. + void RemoveLast() { mySize--; } + + //! Resets the size + void Clear(const bool theReleaseMemory = false) + { + if (theReleaseMemory) + clear(); + mySize = 0; + } + +public: + + //! Gets array, can be null + void** GetArray() const { return myArray; } + + //! Gets value by index, no acess validation + void* Value (const size_t theInd) const { return myArray[theInd]; } + +public: + + //! Inserts new element at the end, increase size, + //! if capacity is not enough, call resize. + Standard_EXPORT void Append (const void* thePnt); + + //! Updates value of existed element, + //! If index more then size, increase size of container, + //! in this case capacity can be updated. + Standard_EXPORT void SetValue (const size_t theInd, const void* thePnt); + + //! Copy vector + Standard_EXPORT NCollection_BasePointerVector& operator= (const NCollection_BasePointerVector& theOther); + + //! Move vector + Standard_EXPORT NCollection_BasePointerVector& operator= (NCollection_BasePointerVector&& theOther) noexcept; + +private: + + //! Deallocate array + Standard_EXPORT void clear(); + +private: + size_t mySize = 0; //!< Used length of vector + size_t myCapacity = 0; //!< Allocated vector size + void** myArray = nullptr; //! Array of pointers + NCollection_Allocator myAllocator; +}; + +#endif diff --git a/src/NCollection/NCollection_BaseVector.cxx b/src/NCollection/NCollection_BaseVector.cxx deleted file mode 100755 index ba7f790021..0000000000 --- a/src/NCollection/NCollection_BaseVector.cxx +++ /dev/null @@ -1,149 +0,0 @@ -// Created on: 2002-04-24 -// Created by: Alexander GRIGORIEV -// Copyright (c) 2002-2013 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#include - -#include - -//======================================================================= -//function : initV -//purpose : Initialisation of iterator by a vector -//======================================================================= - -void NCollection_BaseVector::Iterator::initV (const NCollection_BaseVector& theVector, Standard_Boolean theToEnd) -{ - myVector = &theVector; - - if (theVector.myNBlocks == 0) - { - myCurIndex = 0; - myEndIndex = 0; - myICurBlock = 0; - myIEndBlock = 0; - } - else - { - myIEndBlock = theVector.myNBlocks - 1; - myEndIndex = theVector.myData[myIEndBlock].Length; - - myICurBlock = !theToEnd ? 0 : myIEndBlock; - myCurIndex = !theToEnd ? 0 : myEndIndex; - } -} - -//======================================================================= -//function : allocMemBlocks -//purpose : -//======================================================================= - -NCollection_BaseVector::MemBlock* NCollection_BaseVector - ::allocMemBlocks (const Standard_Integer theCapacity, - MemBlock* theSource, - const Standard_Integer theSourceSize) -{ - MemBlock* aData = (MemBlock* )myAllocator->Allocate (theCapacity * sizeof(MemBlock)); - - // copy content from source array - Standard_Integer aCapacity = 0; - if (theSource != NULL) - { - memcpy (aData, theSource, theSourceSize * sizeof(MemBlock)); - aCapacity = theSourceSize; - myAllocator->Free (theSource); - } - - // Nullify newly allocated blocks - if (aCapacity < theCapacity) - { - memset (&aData[aCapacity], 0, (theCapacity - aCapacity) * sizeof(MemBlock)); - } - return aData; -} - -//======================================================================= -//function : Clear -//purpose : -//======================================================================= - -void NCollection_BaseVector::Clear() -{ - if (myLength > 0) - { - for (Standard_Integer anItemIter = 0; anItemIter < myCapacity; ++anItemIter) - { - myInitBlocks (*this, myData[anItemIter], 0, 0); - } - myLength = 0; - myNBlocks = 0; - } -} - -//======================================================================= -//function : expandV -//purpose : returns the pointer where the new data item is supposed to be put -//======================================================================= - -void* NCollection_BaseVector::expandV (const Standard_Integer theIndex) -{ - const Standard_Integer aNewLength = theIndex + 1; - if (myNBlocks > 0) - { - // Take the last array in the vector of arrays - MemBlock& aLastBlock = myData[myNBlocks - 1]; - Standard_RangeError_Raise_if (theIndex < aLastBlock.FirstIndex, - "NColelction_BaseVector::expandV"); - Standard_Integer anIndLastBlock = theIndex - aLastBlock.FirstIndex; - // Is there still room for 1 item in the last array? - if (anIndLastBlock < aLastBlock.Size) - { - myLength = aNewLength; - aLastBlock.Length = anIndLastBlock + 1; - return aLastBlock.findV (anIndLastBlock, myItemSize); - } - myLength = aLastBlock.FirstIndex + aLastBlock.Size; - } - - // There is no room in the last array - // or the whole vector is not yet initialised. - // Initialise a new array, but before that check whether it is available within myCapacity. - const Standard_Integer nNewBlock = myNBlocks + 1 + (theIndex - myLength) / myIncrement; - if (myCapacity < nNewBlock) - { - // Reallocate the array myData - do myCapacity += GetCapacity(myIncrement); while (myCapacity <= nNewBlock); - - myData = allocMemBlocks (myCapacity, myData, myNBlocks); - } - if (myNBlocks > 0) - { - // Change length of old last block to myIncrement - MemBlock& aLastBlock = myData[myNBlocks - 1]; - aLastBlock.Length = myIncrement; - } - - // Initialise new blocks - MemBlock* aNewBlock = &myData[myNBlocks++]; - myInitBlocks (*this, *aNewBlock, myLength, myIncrement); - while (myNBlocks < nNewBlock) - { - aNewBlock->Length = myIncrement; - myLength += myIncrement; - aNewBlock = &myData[myNBlocks++]; - myInitBlocks (*this, *aNewBlock, myLength, myIncrement); - } - aNewBlock->Length = aNewLength - myLength; - myLength = aNewLength; - return aNewBlock->findV (theIndex - aNewBlock->FirstIndex, myItemSize); -} diff --git a/src/NCollection/NCollection_BaseVector.hxx b/src/NCollection/NCollection_BaseVector.hxx deleted file mode 100755 index 26a41c7d7f..0000000000 --- a/src/NCollection/NCollection_BaseVector.hxx +++ /dev/null @@ -1,237 +0,0 @@ -// Created on: 2002-04-24 -// Created by: Alexander GRIGORIEV -// Copyright (c) 2002-2013 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef NCollection_BaseVector_HeaderFile -#define NCollection_BaseVector_HeaderFile - -#include -#include -#include -#include - -// this value defines the number of blocks that are reserved -// when the capacity of vector is increased -inline Standard_Integer GetCapacity (const Standard_Integer theIncrement) -{ - return Max(theIncrement/8, 1); -} - -//! Class NCollection_BaseVector - base for NCollection_Vector template -class NCollection_BaseVector -{ -public: - //! Memory allocation - DEFINE_STANDARD_ALLOC - DEFINE_NCOLLECTION_ALLOC - -protected: - - // Auxiliary structure for memory blocks - struct MemBlock - { - - public: - - //! @param theIndex Item index in the block - //! @param theItemSize Element size in bytes - //! @return the address of specified item in this memory block - void* findV (const Standard_Integer theIndex, - const size_t theItemSize) const - { - return (char* )DataPtr + size_t(theIndex) * theItemSize; - } - - public: - - void* DataPtr; //!< block of elements - Standard_Integer FirstIndex; //!< index of the first element (among all memory blocks in collection) - Standard_Integer Length; - Standard_Integer Size; - - }; - - //! Base class for Iterator implementation - class Iterator - { - protected: - Iterator() - : myVector (nullptr), - myICurBlock (0), - myIEndBlock (0), - myCurIndex (0), - myEndIndex (0) {} - - Iterator (const NCollection_BaseVector& theVector, Standard_Boolean theToEnd = Standard_False) - { - initV (theVector, theToEnd); - } - - Standard_EXPORT void initV (const NCollection_BaseVector& theVector, Standard_Boolean theToEnd = Standard_False); - - Standard_Boolean moreV() const - { - return (myICurBlock < myIEndBlock || myCurIndex < myEndIndex); - } - - void nextV() - { - if (++myCurIndex >= myVector->myData[myICurBlock].Length - && myICurBlock < myIEndBlock) - { - ++myICurBlock; - myCurIndex = 0; - } - } - - void prevV() - { - if (--myCurIndex < 0 && myICurBlock > 0) - { - --myICurBlock; - myCurIndex = myVector->myData[myICurBlock].Length - 1; - } - } - - void offsetV (Standard_Integer theOffset) - { - const Standard_Integer anIndex = myCurIndex + myICurBlock * myVector->myIncrement + theOffset; - myICurBlock = anIndex / myVector->myIncrement; - myCurIndex = anIndex % myVector->myIncrement; - if (myICurBlock > myIEndBlock) - { - // make sure that iterator produced by Offset() - // is equal to the end() iterator - --myICurBlock; - myCurIndex += myVector->myIncrement; - } - } - - Standard_Integer differV (const Iterator& theOther) const - { - return (myCurIndex - theOther.myCurIndex) + (myICurBlock - theOther.myICurBlock) * myVector->myIncrement; - } - - const MemBlock* curBlockV() const - { - return &myVector->myData[myICurBlock]; - } - - protected: - const NCollection_BaseVector* myVector; //!< the Master vector - Standard_Integer myICurBlock; //!< # of the current block - Standard_Integer myIEndBlock; - Standard_Integer myCurIndex; //!< Index in the current block - Standard_Integer myEndIndex; - }; - -protected: //! @name Block initializer - - typedef void (*initMemBlocks_t) (NCollection_BaseVector& theVector, - MemBlock& theBlock, - const Standard_Integer theFirst, - const Standard_Integer theSize); - - //! Allocate memory for array of memory blocks. - //! @param theCapacity Number of memory blocks in array - //! @param theSource Original array of memory blocks, will be automatically deallocated - //! @param theSourceSize Number of memory blocks in original array - Standard_EXPORT MemBlock* allocMemBlocks (const Standard_Integer theCapacity, - MemBlock* theSource = NULL, - const Standard_Integer theSourceSize = 0); - -protected: //! @name protected methods - - //! Empty constructor - NCollection_BaseVector (const Handle(NCollection_BaseAllocator)& theAllocator, - initMemBlocks_t theInitBlocks, - const size_t theSize, - const Standard_Integer theInc) - : myItemSize (theSize), - myIncrement (theInc), - myLength (0), - myCapacity (GetCapacity (myIncrement)), - myNBlocks (0), - myInitBlocks (theInitBlocks) - { - myAllocator = (theAllocator.IsNull() ? NCollection_BaseAllocator::CommonBaseAllocator() : theAllocator); - myData = allocMemBlocks (myCapacity); - } - - //! Copy constructor - NCollection_BaseVector (const Handle(NCollection_BaseAllocator)& theAllocator, - initMemBlocks_t theInitBlocks, - const NCollection_BaseVector& theOther) - : myItemSize (theOther.myItemSize), - myIncrement (theOther.myIncrement), - myLength (theOther.myLength), - myCapacity (GetCapacity(myIncrement) + theOther.myLength / theOther.myIncrement), - myNBlocks (theOther.myLength == 0 ? 0 : 1 + (theOther.myLength - 1)/theOther.myIncrement), - myInitBlocks (theInitBlocks) - { - myAllocator = (theAllocator.IsNull() ? NCollection_BaseAllocator::CommonBaseAllocator() : theAllocator); - myData = allocMemBlocks (myCapacity); - } - - //! Destructor - virtual ~NCollection_BaseVector() {} - - //! @return pointer to memory where to put the new item - Standard_EXPORT void* expandV (const Standard_Integer theIndex); - - //! Locate the memory holding the desired value - inline void* findV (const Standard_Integer theIndex) const - { - Standard_OutOfRange_Raise_if (theIndex < 0 || theIndex >= myLength, - "NCollection_BaseVector::findV"); - const Standard_Integer aBlock = theIndex / myIncrement; - return myData[aBlock].findV (theIndex - aBlock * myIncrement, myItemSize); - } - -public: //! @name public API - - //! Empty the vector of its objects - Standard_EXPORT void Clear(); - // to set the size of increment dynamically - void SetIncrement(const Standard_Integer aIncrement) { - if (aIncrement > 0) { - if (!myIncrement) { - myIncrement=aIncrement; - } - } - } - - //! Returns attached allocator - const Handle(NCollection_BaseAllocator)& Allocator() const - { - return myAllocator; - } - -protected: //! @name Protected fields - - Handle(NCollection_BaseAllocator) myAllocator; - size_t myItemSize; - Standard_Integer myIncrement; - Standard_Integer myLength; - Standard_Integer myCapacity; - Standard_Integer myNBlocks; - MemBlock* myData; - initMemBlocks_t myInitBlocks; - -protected: - - friend class Iterator; -}; - -#endif // NCollection_BaseVector_HeaderFile diff --git a/src/NCollection/NCollection_CellFilter.hxx b/src/NCollection/NCollection_CellFilter.hxx index f57a94273a..1663456b03 100644 --- a/src/NCollection/NCollection_CellFilter.hxx +++ b/src/NCollection/NCollection_CellFilter.hxx @@ -18,9 +18,9 @@ #include #include +#include #include #include -#include //! Auxiliary enumeration serving as responce from method Inspect enum NCollection_CellFilter_Action @@ -112,8 +112,8 @@ enum NCollection_CellFilter_Action template class NCollection_CellFilter { public: - typedef TYPENAME Inspector::Target Target; - typedef TYPENAME Inspector::Point Point; + typedef typename Inspector::Target Target; + typedef typename Inspector::Point Point; public: @@ -317,40 +317,33 @@ protected: return Standard_True; } - //! Returns hash code for this cell, in the range [1, theUpperBound] - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - Standard_Integer HashCode (const Standard_Integer theUpperBound) const + bool operator==(const Cell& theOther) const { - // number of bits per each dimension in the hash code - const std::size_t aDim = index.Size(); - const std::size_t aShiftBits = (BITS (Cell_IndexType) - 1) / aDim; - std::size_t aCode = 0; - - for (std::size_t i = 0; i < aDim; ++i) - { - aCode = (aCode << aShiftBits) ^ std::size_t(index[i]); - } - - return ::HashCode(aCode, theUpperBound); + return IsEqual(theOther); } public: NCollection_LocalArray index; ListNode *Objects; }; - - //! Returns hash code for the given cell, in the range [1, theUpperBound] - //! @param theCell the cell object which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - friend Standard_Integer HashCode (const Cell& theCell, const Standard_Integer theUpperBound) - { - return theCell.HashCode (theUpperBound); - } - friend Standard_Boolean IsEqual (const Cell &aCell1, const Cell &aCell2) - { return aCell1.IsEqual(aCell2); } + struct CellHasher + { + size_t operator()(const Cell& theCell) const noexcept + { + // number of bits per each dimension in the hash code + const std::size_t aDim = theCell.index.Size(); + return opencascade::hashBytes(&theCell.index[0], static_cast(aDim * sizeof(Cell_IndexType))); + } + + bool operator()(const Cell& theCell1, + const Cell& theCell2) const noexcept + { + return theCell1 == theCell2; + } + }; + + typedef NCollection_Map CellMap; protected: @@ -498,7 +491,7 @@ protected: protected: Standard_Integer myDim; Handle(NCollection_BaseAllocator) myAllocator; - NCollection_Map myCells; + CellMap myCells; NCollection_Array1 myCellSize; }; diff --git a/src/NCollection/NCollection_DataMap.hxx b/src/NCollection/NCollection_DataMap.hxx index ba22e36d42..37463820a3 100644 --- a/src/NCollection/NCollection_DataMap.hxx +++ b/src/NCollection/NCollection_DataMap.hxx @@ -23,6 +23,9 @@ #include #include +#include + +#include /** * Purpose: The DataMap is a Map to store keys with associated @@ -65,6 +68,27 @@ public: NCollection_TListNode (theItem, theNext), myKey(theKey) {} + //! Constructor with 'Next' + DataMapNode (const TheKeyType& theKey, + TheItemType&& theItem, + NCollection_ListNode* theNext) : + NCollection_TListNode (std::forward(theItem), theNext), + myKey(theKey) + {} + //! Constructor with 'Next' + DataMapNode (TheKeyType&& theKey, + const TheItemType& theItem, + NCollection_ListNode* theNext) : + NCollection_TListNode (theItem, theNext), + myKey(std::forward(theKey)) + {} + //! Constructor with 'Next' + DataMapNode (TheKeyType&& theKey, + TheItemType&& theItem, + NCollection_ListNode* theNext) : + NCollection_TListNode (std::forward(theItem), theNext), + myKey(std::forward(theKey)) + {} //! Key const TheKeyType& Key (void) const @@ -151,7 +175,19 @@ public: //! Copy constructor NCollection_DataMap (const NCollection_DataMap& theOther) : NCollection_BaseMap (theOther.NbBuckets(), Standard_True, theOther.myAllocator) - { *this = theOther; } + { + const int anExt = theOther.Extent(); + if (anExt <= 0) + return; + ReSize(anExt - 1); + for (Iterator anIter(theOther); anIter.More(); anIter.Next()) + Bind(anIter.Key(), anIter.Value()); + } + + //! Move constructor + NCollection_DataMap(NCollection_DataMap&& theOther) noexcept : + NCollection_BaseMap(std::forward(theOther)) + {} //! Exchange the content of two maps without re-allocations. //! Notice that allocators will be swapped as well! @@ -185,6 +221,15 @@ public: return Assign (theOther); } + //! Move operator + NCollection_DataMap& operator= (NCollection_DataMap&& theOther) noexcept + { + if (this == &theOther) + return *this; + exchangeMapsData(theOther); + return *this; + } + //! ReSize void ReSize (const Standard_Integer N) { @@ -197,15 +242,14 @@ public: { DataMapNode** olddata = (DataMapNode**) myData1; DataMapNode *p, *q; - Standard_Integer i,k; - for (i = 0; i <= NbBuckets(); i++) + for (int i = 0; i <= NbBuckets(); i++) { if (olddata[i]) { p = olddata[i]; while (p) { - k = Hasher::HashCode(p->Key(),newBuck); + const size_t k = HashCode(p->Key(),newBuck); q = (DataMapNode*) p->Next(); p->Next() = newdata[k]; newdata[k] = p; @@ -220,49 +264,172 @@ public: //! Bind binds Item to Key in map. //! @param theKey key to add/update - //! @param theItem new item; overrides value previously bound to the key, if any + //! @param theItem new item; overrides value previously bound to the key //! @return Standard_True if Key was not bound already Standard_Boolean Bind (const TheKeyType& theKey, const TheItemType& theItem) { if (Resizable()) ReSize(Extent()); - DataMapNode** data = (DataMapNode**)myData1; - Standard_Integer k = Hasher::HashCode (theKey, NbBuckets()); - DataMapNode* p = data[k]; - while (p) + size_t aHash; + DataMapNode* aNode; + if (lookup(theKey, aNode, aHash)) { - if (Hasher::IsEqual(p->Key(), theKey)) - { - p->ChangeValue() = theItem; - return Standard_False; - } - p = (DataMapNode *) p->Next(); + aNode->ChangeValue() = theItem; + return Standard_False; } - data[k] = new (this->myAllocator) DataMapNode (theKey, theItem, data[k]); + DataMapNode** data = (DataMapNode**)myData1; + data[aHash] = new (this->myAllocator) DataMapNode (theKey, theItem, data[aHash]); Increment(); return Standard_True; } - //! Bound binds Item to Key in map. Returns modifiable Item + //! Bind binds Item to Key in map. + //! @param theKey key to add/update + //! @param theItem new item; overrides value previously bound to the key + //! @return Standard_True if Key was not bound already + Standard_Boolean Bind (TheKeyType&& theKey, const TheItemType& theItem) + { + if (Resizable()) + ReSize(Extent()); + size_t aHash; + DataMapNode* aNode; + if (lookup(theKey, aNode, aHash)) + { + aNode->ChangeValue() = theItem; + return Standard_False; + } + DataMapNode** data = (DataMapNode**)myData1; + data[aHash] = new (this->myAllocator) DataMapNode (std::forward(theKey), theItem, data[aHash]); + Increment(); + return Standard_True; + } + + //! Bind binds Item to Key in map. + //! @param theKey key to add/update + //! @param theItem new item; overrides value previously bound to the key + //! @return Standard_True if Key was not bound already + Standard_Boolean Bind (const TheKeyType& theKey, TheItemType&& theItem) + { + if (Resizable()) + ReSize(Extent()); + size_t aHash; + DataMapNode* aNode; + if (lookup(theKey, aNode, aHash)) + { + aNode->ChangeValue() = std::forward(theItem); + return Standard_False; + } + DataMapNode** data = (DataMapNode**)myData1; + data[aHash] = new (this->myAllocator) DataMapNode (theKey, std::forward(theItem), data[aHash]); + Increment(); + return Standard_True; + } + + //! Bind binds Item to Key in map. + //! @param theKey key to add/update + //! @param theItem new item; overrides value previously bound to the key + //! @return Standard_True if Key was not bound already + Standard_Boolean Bind (TheKeyType&& theKey, TheItemType&& theItem) + { + if (Resizable()) + ReSize(Extent()); + size_t aHash; + DataMapNode* aNode; + if (lookup(theKey, aNode, aHash)) + { + aNode->ChangeValue() = theItem; + return Standard_False; + } + DataMapNode** data = (DataMapNode**)myData1; + data[aHash] = new (this->myAllocator) DataMapNode (std::forward(theKey), + std::forward(theItem), data[aHash]); + Increment(); + return Standard_True; + } + + //! Bound binds Item to Key in map. + //! @param theKey key to add/update + //! @param theItem new item; overrides value previously bound to the key + //! @return pointer to modifiable Item TheItemType* Bound (const TheKeyType& theKey, const TheItemType& theItem) { if (Resizable()) ReSize(Extent()); - DataMapNode** data = (DataMapNode**)myData1; - Standard_Integer k = Hasher::HashCode (theKey, NbBuckets()); - DataMapNode* p = data[k]; - while (p) + size_t aHash; + DataMapNode* aNode; + if (lookup(theKey, aNode, aHash)) { - if (Hasher::IsEqual(p->Key(), theKey)) - { - p->ChangeValue() = theItem; - return &p->ChangeValue(); - } - p = (DataMapNode*)p->Next(); + aNode->ChangeValue() = theItem; + return &aNode->ChangeValue(); } - data[k] = new (this->myAllocator) DataMapNode (theKey, theItem, data[k]); + DataMapNode** data = (DataMapNode**)myData1; + data[aHash] = new (this->myAllocator) DataMapNode (theKey, theItem, data[aHash]); Increment(); - return &data[k]->ChangeValue(); + return &data[aHash]->ChangeValue(); + } + + //! Bound binds Item to Key in map. + //! @param theKey key to add/update + //! @param theItem new item; overrides value previously bound to the key + //! @return pointer to modifiable Item + TheItemType* Bound (TheKeyType&& theKey, const TheItemType& theItem) + { + if (Resizable()) + ReSize(Extent()); + size_t aHash; + DataMapNode* aNode; + if (lookup(theKey, aNode, aHash)) + { + aNode->ChangeValue() = theItem; + return &aNode->ChangeValue(); + } + DataMapNode** data = (DataMapNode**)myData1; + data[aHash] = new (this->myAllocator) DataMapNode (std::forward(theKey), theItem, data[aHash]); + Increment(); + return &data[aHash]->ChangeValue(); + } + + //! Bound binds Item to Key in map. + //! @param theKey key to add/update + //! @param theItem new item; overrides value previously bound to the key + //! @return pointer to modifiable Item + TheItemType* Bound (const TheKeyType& theKey, TheItemType&& theItem) + { + if (Resizable()) + ReSize(Extent()); + size_t aHash; + DataMapNode* aNode; + if (lookup(theKey, aNode, aHash)) + { + aNode->ChangeValue() = std::forward(theItem); + return &aNode->ChangeValue(); + } + DataMapNode** data = (DataMapNode**)myData1; + data[aHash] = new (this->myAllocator) DataMapNode (theKey, std::forward(theItem), data[aHash]); + Increment(); + return &data[aHash]->ChangeValue(); + } + + //! Bound binds Item to Key in map. + //! @param theKey key to add/update + //! @param theItem new item; overrides value previously bound to the key + //! @return pointer to modifiable Item + TheItemType* Bound (TheKeyType&& theKey, TheItemType&& theItem) + { + if (Resizable()) + ReSize(Extent()); + size_t aHash; + DataMapNode* aNode; + if (lookup(theKey, aNode, aHash)) + { + aNode->ChangeValue() = std::forward(theItem); + return &aNode->ChangeValue(); + } + DataMapNode** data = (DataMapNode**)myData1; + data[aHash] = new (this->myAllocator) DataMapNode (std::forward(theKey), + std::forward(theItem), data[aHash]); + Increment(); + return &data[aHash]->ChangeValue(); } //! IsBound @@ -278,12 +445,12 @@ public: if (IsEmpty()) return Standard_False; DataMapNode** data = (DataMapNode**) myData1; - Standard_Integer k = Hasher::HashCode(theKey,NbBuckets()); + const size_t k = HashCode(theKey,NbBuckets()); DataMapNode* p = data[k]; DataMapNode* q = NULL; while (p) { - if (Hasher::IsEqual(p->Key(), theKey)) + if (IsEqual(p->Key(), theKey)) { Decrement(); if (q) @@ -361,20 +528,20 @@ public: //! Clear data. If doReleaseMemory is false then the table of //! buckets is not released and will be reused. - void Clear(const Standard_Boolean doReleaseMemory = Standard_True) + void Clear(const Standard_Boolean doReleaseMemory = Standard_False) { Destroy (DataMapNode::delNode, doReleaseMemory); } //! Clear data and reset allocator void Clear (const Handle(NCollection_BaseAllocator)& theAllocator) { - Clear(); + Clear(theAllocator != this->myAllocator); this->myAllocator = ( ! theAllocator.IsNull() ? theAllocator : NCollection_BaseAllocator::CommonBaseAllocator() ); } //! Destructor virtual ~NCollection_DataMap (void) - { Clear(); } + { Clear(true); } //! Size Standard_Integer Size(void) const @@ -382,23 +549,60 @@ public: protected: - // ---------- PROTECTED METHODS ---------- - //! Lookup for particular key in map. Returns true if key is found and - //! thepNode points to binded node. Returns false if key is not found, - //! thehNode value is this case is not usable. - Standard_Boolean lookup(const TheKeyType& theKey,DataMapNode*& thepNode) const + + //! Lookup for particular key in map. + //! @param[in] theKey key to compute hash + //! @param[out] theNode the detected node with equal key. Can be null. + //! @return true if key is found + Standard_Boolean lookup(const TheKeyType& theKey,DataMapNode*& theNode) const { if (IsEmpty()) return Standard_False; // Not found - for (thepNode = (DataMapNode*)myData1[Hasher::HashCode(theKey, NbBuckets())]; - thepNode; thepNode = (DataMapNode*)thepNode->Next()) + for (theNode = (DataMapNode*)myData1[HashCode(theKey, NbBuckets())]; + theNode; theNode = (DataMapNode*)theNode->Next()) { - if (Hasher::IsEqual(thepNode->Key(), theKey)) + if (IsEqual(theNode->Key(), theKey)) return Standard_True; } return Standard_False; // Not found } + //! Lookup for particular key in map. + //! @param[in] theKey key to compute hash + //! @param[out] theNode the detected node with equal key. Can be null. + //! @param[out] theHash computed bounded hash code for current key. + //! @return true if key is found + Standard_Boolean lookup(const TheKeyType& theKey, DataMapNode*& theNode, size_t& theHash) const + { + theHash = HashCode(theKey, NbBuckets()); + if (IsEmpty()) + return Standard_False; // Not found + for (theNode = (DataMapNode*)myData1[theHash]; + theNode; theNode = (DataMapNode*)theNode->Next()) + { + if (IsEqual(theNode->Key(), theKey)) + { + return Standard_True; + } + } + return Standard_False; // Not found + } + + bool IsEqual(const TheKeyType& theKey1, + const TheKeyType& theKey2) const + { + return myHasher(theKey1, theKey2); + } + + size_t HashCode(const TheKeyType& theKey, + const int theUpperBound) const + { + return myHasher(theKey) % theUpperBound + 1; + } + +private: + + Hasher myHasher; }; #endif diff --git a/src/NCollection/NCollection_DefaultHasher.hxx b/src/NCollection/NCollection_DefaultHasher.hxx index 6cbbf90de0..4007ea2739 100644 --- a/src/NCollection/NCollection_DefaultHasher.hxx +++ b/src/NCollection/NCollection_DefaultHasher.hxx @@ -15,72 +15,95 @@ #ifndef NCollection_DefaultHasher_HeaderFile #define NCollection_DefaultHasher_HeaderFile -#include - -//======================================================================= -//function : HashCode_Proxy -//purpose : Function is required to call the global function HashCode. -//======================================================================= - -//! Returns hash code for the given key, in the range [1, theUpperBound] -//! @tparam TheKeyType the type of the given key -//! @param theKey the key which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -template -inline Standard_Integer HashCode_Proxy (const TheKeyType& theKey, const Standard_Integer theUpperBound) -{ - return HashCode (theKey, theUpperBound); -} - -//======================================================================= -//function : IsEqual -//purpose : Default implementation of IsEqual via operator == -//======================================================================= - -template -inline Standard_Boolean IsEqual (const TheKeyType& theKey1, - const TheKeyType& theKey2) -{ - return theKey1 == theKey2; -} - -//======================================================================= -//function : IsEqual_Proxy -//purpose : Function is required to call the global function IsEqual. -//======================================================================= - -template -inline Standard_Boolean IsEqual_Proxy (const TheKeyType& theKey1, - const TheKeyType& theKey2) -{ - return IsEqual (theKey1, theKey2); -} +#include +#include +#include /** * Purpose: The DefaultHasher is a Hasher that is used by - * default in NCollection maps. + * default in NCollection maps. * To compute the hash code of the key is used the * global function HashCode. * To compare two keys is used the global function * IsEqual. */ -template class NCollection_DefaultHasher { -public: - //! Returns hash code for the given key, in the range [1, theUpperBound] - //! @param theKey the key which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const TheKeyType& theKey, const Standard_Integer theUpperBound) +template +DEFINE_HASHER(NCollection_DefaultHasher, TheKeyType, std::hash, std::equal_to) + + +#define DEFINE_DEFAULT_HASHER_PURE(TheKeyType) \ +template <> struct NCollection_DefaultHasher \ +{ \ + size_t operator()(const TheKeyType theKey) const noexcept \ + { \ + return static_cast(theKey); \ + } \ + \ + bool operator() (const TheKeyType theK1, \ + const TheKeyType theK2) const noexcept \ + { \ + return theK1 == theK2; \ + } \ +}; + +/// Explicit specialization for bool. +DEFINE_DEFAULT_HASHER_PURE(bool) + +/// Explicit specialization for char. +DEFINE_DEFAULT_HASHER_PURE(char) + +/// Explicit specialization for signed char. +DEFINE_DEFAULT_HASHER_PURE(signed char) + +/// Explicit specialization for unsigned char. +DEFINE_DEFAULT_HASHER_PURE(unsigned char) + +/// Explicit specialization for wchar_t. +DEFINE_DEFAULT_HASHER_PURE(wchar_t) + +/// Explicit specialization for char16_t. +DEFINE_DEFAULT_HASHER_PURE(char16_t) + +/// Explicit specialization for char32_t. +DEFINE_DEFAULT_HASHER_PURE(char32_t) + +/// Explicit specialization for short. +DEFINE_DEFAULT_HASHER_PURE(short) + +/// Explicit specialization for int. +DEFINE_DEFAULT_HASHER_PURE(int) + +/// Explicit specialization for long. +DEFINE_DEFAULT_HASHER_PURE(long) + +/// Explicit specialization for long long. +DEFINE_DEFAULT_HASHER_PURE(long long) + +/// Explicit specialization for unsigned short. +DEFINE_DEFAULT_HASHER_PURE(unsigned short) + +/// Explicit specialization for unsigned int. +DEFINE_DEFAULT_HASHER_PURE(unsigned int) + +/// Explicit specialization for unsigned long. +DEFINE_DEFAULT_HASHER_PURE(unsigned long) + +/// Explicit specialization for unsigned long long. +DEFINE_DEFAULT_HASHER_PURE(unsigned long long) + +/// Explicit specialization for pointer. +template +struct NCollection_DefaultHasher +{ + size_t operator()(const TheKeyType* theKey) const noexcept { - return HashCode_Proxy (theKey, theUpperBound); + return static_cast(reinterpret_cast(theKey)); } - // - static Standard_Boolean IsEqual(const TheKeyType& theKey1, - const TheKeyType& theKey2) { - return IsEqual_Proxy(theKey1, theKey2); + bool operator() (const TheKeyType* theK1, const TheKeyType* theK2) const noexcept + { + return theK1 == theK2; } }; diff --git a/src/NCollection/NCollection_DefineArray1.hxx b/src/NCollection/NCollection_DefineArray1.hxx deleted file mode 100644 index 74636946c3..0000000000 --- a/src/NCollection/NCollection_DefineArray1.hxx +++ /dev/null @@ -1,47 +0,0 @@ -// Created on: 2002-04-15 -// Created by: Alexander Kartomin (akm) -// Copyright (c) 2002-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -// Automatically created from NCollection_Array1.hxx by GAWK -// Purpose: The class Array2 represents unidimensional arrays -// of fixed size known at run time. -// The range of the index is user defined. -// An array1 can be constructed with a "C array". -// This functionality is useful to call methods expecting -// an Array1. It allows to carry the bounds inside the arrays. -// Examples: Item tab[100]; // An example with a C array -// Array1OfItem ttab (tab[0],1,100); -// Array1OfItem tttab (ttab(10),10,20); // a slice of ttab -// If you want to reindex an array from 1 to Length do : -// Array1 tab1(tab(tab.Lower()),1,tab.Length()); -// Warning: Programs client of such a class must be independent -// of the range of the first element. Then, a C++ for -// loop must be written like this -// for (i = A.Lower(); i <= A.Upper(); i++) -// Changes: In comparison to TCollection the flag isAllocated was -// renamed into myDeletable (alike in the Array2). For naming -// compatibility the method IsAllocated remained in class along -// with IsDeletable. - -#ifndef NCollection_DefineArray1_HeaderFile -#define NCollection_DefineArray1_HeaderFile - -#include - -// *********************************************** Template for Array1 class - -#define DEFINE_ARRAY1(_ClassName_, _BaseCollection_, TheItemType) \ -typedef NCollection_Array1 _ClassName_; - -#endif diff --git a/src/NCollection/NCollection_DefineArray2.hxx b/src/NCollection/NCollection_DefineArray2.hxx deleted file mode 100644 index 00d32af4bd..0000000000 --- a/src/NCollection/NCollection_DefineArray2.hxx +++ /dev/null @@ -1,36 +0,0 @@ -// Created on: 2002-04-15 -// Created by: Alexander Kartomin (akm) -// Copyright (c) 2002-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -// Automatically created from NCollection_Array2.hxx by GAWK -// Purpose: The class Array2 represents bi-dimensional arrays -// of fixed size known at run time. -// The ranges of indices are user defined. -// Warning: Programs clients of such class must be independent -// of the range of the first element. Then, a C++ for -// loop must be written like this -// for (i = A.LowerRow(); i <= A.UpperRow(); i++) -// for (j = A.LowerCol(); j <= A.UpperCol(); j++) - -#ifndef NCollection_DefineArray2_HeaderFile -#define NCollection_DefineArray2_HeaderFile - -#include - -// *********************************************** Template for Array2 class - -#define DEFINE_ARRAY2(_ClassName_, _BaseCollection_, TheItemType) \ -typedef NCollection_Array2 _ClassName_; - -#endif diff --git a/src/NCollection/NCollection_DefineDataMap.hxx b/src/NCollection/NCollection_DefineDataMap.hxx deleted file mode 100644 index 4c90ecb86e..0000000000 --- a/src/NCollection/NCollection_DefineDataMap.hxx +++ /dev/null @@ -1,39 +0,0 @@ -// Created on: 2002-04-24 -// Created by: Alexander KARTOMIN (akm) -// Copyright (c) 2002-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -// Purpose: The DataMap is a Map to store keys with associated -// Items. See Map from NCollection for a discussion -// about the number of buckets. -// The DataMap can be seen as an extended array where -// the Keys are the indices. For this reason the -// operator () is defined on DataMap to fetch an Item -// from a Key. So the following syntax can be used : -// anItem = aMap(aKey); -// aMap(aKey) = anItem; -// This analogy has its limit. aMap(aKey) = anItem -// can be done only if aKey was previously bound to -// an item in the map. - -#ifndef NCollection_DefineDataMap_HeaderFile -#define NCollection_DefineDataMap_HeaderFile - -#include - -// *********************************************** Class DataMap ************* - -#define DEFINE_DATAMAP(_ClassName_, _BaseCollection_, TheKeyType, TheItemType) \ -typedef NCollection_DataMap _ClassName_; - -#endif diff --git a/src/NCollection/NCollection_DefineDoubleMap.hxx b/src/NCollection/NCollection_DefineDoubleMap.hxx deleted file mode 100644 index e6a1188a6e..0000000000 --- a/src/NCollection/NCollection_DefineDoubleMap.hxx +++ /dev/null @@ -1,31 +0,0 @@ -// Created on: 2002-04-24 -// Created by: Alexander KARTOMIN (akm) -// Copyright (c) 2002-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -// Purpose: The DoubleMap is used to bind pairs (Key1,Key2) -// and retrieve them in linear time. -// See Map from NCollection for a discussion about the number -// of buckets - -#ifndef NCollection_DefineDoubleMap_HeaderFile -#define NCollection_DefineDoubleMap_HeaderFile - -#include - -// *********************************************** Class DoubleMap ************ - -#define DEFINE_DOUBLEMAP(_ClassName_, _BaseCollection_, TheKey1Type, TheKey2Type) \ -typedef NCollection_DoubleMap _ClassName_; - -#endif diff --git a/src/NCollection/NCollection_DefineHArray1.hxx b/src/NCollection/NCollection_DefineHArray1.hxx index d1da5ee2f8..3ce18913dc 100644 --- a/src/NCollection/NCollection_DefineHArray1.hxx +++ b/src/NCollection/NCollection_DefineHArray1.hxx @@ -19,13 +19,12 @@ #define NCollection_DefineHArray1_HeaderFile #include -#include #include // Declaration of Array1 class managed by Handle #define DEFINE_HARRAY1(HClassName, _Array1Type_) \ -class HClassName : public _Array1Type_, public Standard_Transient { \ +class HClassName : public _Array1Type_, public Standard_Transient { \ public: \ DEFINE_STANDARD_ALLOC \ DEFINE_NCOLLECTION_ALLOC \ @@ -37,15 +36,18 @@ class HClassName : public _Array1Type_, public Standard_Transient { const Standard_Integer theUpper, \ const _Array1Type_::value_type& theValue) : \ _Array1Type_ (theLower,theUpper) { Init (theValue); } \ + explicit HClassName (const typename _Array1Type_::value_type& theBegin, \ + const Standard_Integer theLower, \ + const Standard_Integer theUpper, \ + const bool) : \ + _Array1Type_ (theBegin,theLower,theUpper) {} \ HClassName (const _Array1Type_& theOther) : _Array1Type_(theOther) {} \ const _Array1Type_& Array1 () const { return *this; } \ _Array1Type_& ChangeArray1 () { return *this; } \ - DEFINE_STANDARD_RTTI_INLINE(HClassName,Standard_Transient) \ + DEFINE_STANDARD_RTTI_INLINE(HClassName,Standard_Transient) \ }; \ DEFINE_STANDARD_HANDLE (HClassName, Standard_Transient) -#define IMPLEMENT_HARRAY1(HClassName) - - +#define IMPLEMENT_HARRAY1(HClassName) #endif diff --git a/src/NCollection/NCollection_DefineHArray2.hxx b/src/NCollection/NCollection_DefineHArray2.hxx index 1f35b90c0c..17123daaae 100644 --- a/src/NCollection/NCollection_DefineHArray2.hxx +++ b/src/NCollection/NCollection_DefineHArray2.hxx @@ -19,7 +19,6 @@ #define NCollection_DefineHArray2_HeaderFile #include -#include #include // Declaration of Array2 class managed by Handle diff --git a/src/NCollection/NCollection_DefineHSequence.hxx b/src/NCollection/NCollection_DefineHSequence.hxx index 9973d9b866..05aa83ed9d 100644 --- a/src/NCollection/NCollection_DefineHSequence.hxx +++ b/src/NCollection/NCollection_DefineHSequence.hxx @@ -19,7 +19,6 @@ #define NCollection_DefineHSequence_HeaderFile #include -#include #include // Declaration of Sequence class managed by Handle diff --git a/src/NCollection/NCollection_DefineHasher.hxx b/src/NCollection/NCollection_DefineHasher.hxx new file mode 100644 index 0000000000..23e518d163 --- /dev/null +++ b/src/NCollection/NCollection_DefineHasher.hxx @@ -0,0 +1,32 @@ +// Copyright (c) 2023 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef NCollection_DefineHasher_HeaderFile +#define NCollection_DefineHasher_HeaderFile + +#define DEFINE_HASHER(HasherName, TheKeyType, HashFunctor, EqualFunctor) \ +struct HasherName : protected HashFunctor, EqualFunctor \ +{ \ + size_t operator()(const TheKeyType& theKey) const noexcept \ + { \ + return HashFunctor::operator()(theKey); \ + } \ + \ + bool operator() (const TheKeyType& theK1, \ + const TheKeyType& theK2) const noexcept \ + { \ + return EqualFunctor::operator()(theK1, theK2); \ + } \ +}; + +#endif diff --git a/src/NCollection/NCollection_DefineIndexedDataMap.hxx b/src/NCollection/NCollection_DefineIndexedDataMap.hxx deleted file mode 100644 index aa75b384da..0000000000 --- a/src/NCollection/NCollection_DefineIndexedDataMap.hxx +++ /dev/null @@ -1,41 +0,0 @@ -// Created on: 2002-04-24 -// Created by: Alexander KARTOMIN (akm) -// Copyright (c) 2002-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -// Purpose: An indexed map is used to store keys and to bind -// an index to them. Each new key stored in the map -// gets an index. Index are incremented as keys are -// stored in the map. A key can be found by the index -// and an index by the key. No key but the last can -// be removed so the indices are in the range 1.. -// Extent. An Item is stored with each key. -// This class is similar to IndexedMap from -// NCollection with the Item as a new feature. Note -// the important difference on the operator (). In -// the IndexedMap this operator returns the Key. In -// the IndexedDataMap this operator returns the Item. -// See the class Map from NCollection for a -// discussion about the number of buckets. - -#ifndef NCollection_DefineIndexedDataMap_HeaderFile -#define NCollection_DefineIndexedDataMap_HeaderFile - -#include - -// *********************************************** Class IndexedDataMap ****** - -#define DEFINE_INDEXEDDATAMAP(_ClassName_, _BaseCollection_, TheKeyType, TheItemType) \ -typedef NCollection_IndexedDataMap _ClassName_; - -#endif diff --git a/src/NCollection/NCollection_DefineIndexedMap.hxx b/src/NCollection/NCollection_DefineIndexedMap.hxx deleted file mode 100644 index 77c40504ce..0000000000 --- a/src/NCollection/NCollection_DefineIndexedMap.hxx +++ /dev/null @@ -1,35 +0,0 @@ -// Created on: 2002-04-24 -// Created by: Alexander KARTOMIN (akm) -// Copyright (c) 2002-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -// Purpose: An indexed map is used to store keys and to bind -// an index to them. Each new key stored in the map -// gets an index. Index are incremented as keys are -// stored in the map. A key can be found by the index -// and an index by the key. No key but the last can -// be removed so the indices are in the range 1..Extent. -// See the class Map from NCollection for a -// discussion about the number of buckets. - -#ifndef NCollection_DefineIndexedMap_HeaderFile -#define NCollection_DefineIndexedMap_HeaderFile - -#include - -// *********************************************** Class IndexedMap *********** - -#define DEFINE_INDEXEDMAP(_ClassName_, _BaseCollection_, TheKeyType) \ -typedef NCollection_IndexedMap _ClassName_; - -#endif diff --git a/src/NCollection/NCollection_DefineList.hxx b/src/NCollection/NCollection_DefineList.hxx deleted file mode 100644 index ab6c28175b..0000000000 --- a/src/NCollection/NCollection_DefineList.hxx +++ /dev/null @@ -1,32 +0,0 @@ -// Created on: 2002-04-17 -// Created by: Alexander Kartomin (akm) -// Copyright (c) 2002-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -// Automatically created from NCollection_List.hxx by GAWK -// Purpose: Simple list to link items together keeping the first -// and the last one. -// Inherits BaseList, adding the data item to each node. - - -#ifndef NCollection_DefineList_HeaderFile -#define NCollection_DefineList_HeaderFile - -#include - -// **************************************** Template for List class ******** - -#define DEFINE_LIST(_ClassName_, _BaseCollection_, TheItemType) \ -typedef NCollection_List _ClassName_; - -#endif diff --git a/src/NCollection/NCollection_DefineMap.hxx b/src/NCollection/NCollection_DefineMap.hxx deleted file mode 100644 index d4ecbb5b1a..0000000000 --- a/src/NCollection/NCollection_DefineMap.hxx +++ /dev/null @@ -1,47 +0,0 @@ -// Created on: 2002-04-23 -// Created by: Alexander KARTOMIN (akm) -// Copyright (c) 2002-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -// Purpose: Single hashed Map. This Map is used to store and -// retrieve keys in linear time. -// The ::Iterator class can be used to explore the -// content of the map. It is not wise to iterate and -// modify a map in parallel. -// To compute the hashcode of the key the function -// ::HashCode must be defined in the global namespace -// To compare two keys the function ::IsEqual must be -// defined in the global namespace. -// The performance of a Map is conditioned by its -// number of buckets that should be kept greater to -// the number of keys. This map has an automatic -// management of the number of buckets. It is resized -// when the number of Keys becomes greater than the -// number of buckets. -// If you have a fair idea of the number of objects -// you can save on automatic resizing by giving a -// number of buckets at creation or using the ReSize -// method. This should be consider only for crucial -// optimisation issues. - -#ifndef NCollection_DefineMap_HeaderFile -#define NCollection_DefineMap_HeaderFile - -#include - -// *********************************************** Class Map ***************** - -#define DEFINE_MAP(_ClassName_, _BaseCollection_, TheKeyType) \ -typedef NCollection_Map _ClassName_; - -#endif diff --git a/src/NCollection/NCollection_DefineSequence.hxx b/src/NCollection/NCollection_DefineSequence.hxx deleted file mode 100644 index 3d7414e427..0000000000 --- a/src/NCollection/NCollection_DefineSequence.hxx +++ /dev/null @@ -1,31 +0,0 @@ -// Created on: 2002-03-28 -// Created by: Alexander GRIGORIEV -// Copyright (c) 2002-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -// Automatically created from NCollection_Sequence.hxx by GAWK -// Purpose: Definition of a sequence of elements indexed by -// an Integer in range of 1..n - - -#ifndef NCollection_DefineSequence_HeaderFile -#define NCollection_DefineSequence_HeaderFile - -#include - -// **************************************** Template for Sequence class ******** - -#define DEFINE_SEQUENCE(_ClassName_, _BaseCollection_, TheItemType) \ -typedef NCollection_Sequence _ClassName_; - -#endif diff --git a/src/NCollection/NCollection_DefineVector.hxx b/src/NCollection/NCollection_DefineVector.hxx deleted file mode 100644 index 7d8cafc57d..0000000000 --- a/src/NCollection/NCollection_DefineVector.hxx +++ /dev/null @@ -1,44 +0,0 @@ -// Created on: 2002-04-23 -// Created by: Alexander GRIGORIEV -// Copyright (c) 2002-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -// Automatically created from NCollection_Vector.hxx by GAWK - - -#ifndef NCollection_DefineVector_HeaderFile -#define NCollection_DefineVector_HeaderFile - -#include - -// Class NCollection_Vector (dynamic array of objects) -// This class is similar to NCollection_Array1 though the indices always start -// at 0 (in Array1 the first index must be specified) -// The Vector is always created with 0 length. It can be enlarged by two means: -// 1. Calling the method Append (val) - then "val" is added to the end of the -// vector (the vector length is incremented) -// 2. Calling the method SetValue (i, val) - if "i" is greater than or equal -// to the current length of the vector, the vector is enlarged to accomo- -// The methods Append and SetValue return a non-const reference to the copied -// object inside the vector. This reference is guaranteed to be valid until -// the vector is destroyed. It can be used to access the vector member directly -// or to pass its address to other data structures. -// The vector iterator remembers the length of the vector at the moment of the -// creation or initialisation of the iterator. Therefore the iteration begins -// at index 0 and stops at the index equal to (remembered_length-1). It is OK -// to enlarge the vector during the iteration. - -#define DEFINE_VECTOR(_ClassName_, _BaseCollection_, TheItemType) \ -typedef NCollection_Vector _ClassName_; - -#endif diff --git a/src/NCollection/NCollection_DoubleMap.hxx b/src/NCollection/NCollection_DoubleMap.hxx index 397d675be5..28404c47a0 100644 --- a/src/NCollection/NCollection_DoubleMap.hxx +++ b/src/NCollection/NCollection_DoubleMap.hxx @@ -157,8 +157,8 @@ public: { TheKey1Type aKey1 = anIter.Key1(); TheKey2Type aKey2 = anIter.Key2(); - Standard_Integer iK1 = Hasher1::HashCode (aKey1, NbBuckets()); - Standard_Integer iK2 = Hasher2::HashCode (aKey2, NbBuckets()); + const size_t iK1 = HashCode1 (aKey1, NbBuckets()); + const size_t iK2 = HashCode2 (aKey2, NbBuckets()); DoubleMapNode * pNode = new (this->myAllocator) DoubleMapNode (aKey1, aKey2, myData1[iK1], myData2[iK2]); @@ -187,16 +187,15 @@ public: if (myData1) { DoubleMapNode *p, *q; - Standard_Integer i, iK1, iK2; - for (i = 0; i <= NbBuckets(); i++) + for (int i = 0; i <= NbBuckets(); i++) { if (myData1[i]) { p = (DoubleMapNode *) myData1[i]; while (p) { - iK1 = Hasher1::HashCode (p->Key1(), newBuck); - iK2 = Hasher2::HashCode (p->Key2(), newBuck); + const size_t iK1 = HashCode1 (p->Key1(), newBuck); + const size_t iK2 = HashCode2 (p->Key2(), newBuck); q = (DoubleMapNode*) p->Next(); p->Next() = ppNewData1[iK1]; p->Next2() = (DoubleMapNode*)ppNewData2[iK2]; @@ -216,20 +215,20 @@ public: { if (Resizable()) ReSize(Extent()); - Standard_Integer iK1 = Hasher1::HashCode (theKey1, NbBuckets()); - Standard_Integer iK2 = Hasher2::HashCode (theKey2, NbBuckets()); + const size_t iK1 = HashCode1 (theKey1, NbBuckets()); + const size_t iK2 = HashCode2 (theKey2, NbBuckets()); DoubleMapNode * pNode; pNode = (DoubleMapNode *) myData1[iK1]; while (pNode) { - if (Hasher1::IsEqual (pNode->Key1(), theKey1)) + if (IsEqual1 (pNode->Key1(), theKey1)) throw Standard_MultiplyDefined("NCollection_DoubleMap:Bind"); pNode = (DoubleMapNode *) pNode->Next(); } pNode = (DoubleMapNode *) myData2[iK2]; while (pNode) { - if (Hasher2::IsEqual (pNode->Key2(), theKey2)) + if (IsEqual2 (pNode->Key2(), theKey2)) throw Standard_MultiplyDefined("NCollection_DoubleMap:Bind"); pNode = (DoubleMapNode *) pNode->Next(); } @@ -246,13 +245,13 @@ public: { if (IsEmpty()) return Standard_False; - Standard_Integer iK1 = Hasher1::HashCode (theKey1, NbBuckets()); - Standard_Integer iK2 = Hasher2::HashCode (theKey2, NbBuckets()); + const size_t iK1 = HashCode1 (theKey1, NbBuckets()); + const size_t iK2 = HashCode2 (theKey2, NbBuckets()); DoubleMapNode * pNode1, * pNode2; pNode1 = (DoubleMapNode *) myData1[iK1]; while (pNode1) { - if (Hasher1::IsEqual(pNode1->Key1(), theKey1)) + if (IsEqual1(pNode1->Key1(), theKey1)) break; pNode1 = (DoubleMapNode *) pNode1->Next(); } @@ -261,7 +260,7 @@ public: pNode2 = (DoubleMapNode *) myData2[iK2]; while (pNode2) { - if (Hasher2::IsEqual(pNode2->Key2(), theKey2)) + if (IsEqual2(pNode2->Key2(), theKey2)) break; pNode2 = (DoubleMapNode *) pNode2->Next(); } @@ -276,12 +275,12 @@ public: { if (IsEmpty()) return Standard_False; - Standard_Integer iK1 = Hasher1::HashCode (theKey1, NbBuckets()); + const size_t iK1 = HashCode1 (theKey1, NbBuckets()); DoubleMapNode * pNode1; pNode1 = (DoubleMapNode *) myData1[iK1]; while (pNode1) { - if (Hasher1::IsEqual(pNode1->Key1(), theKey1)) + if (IsEqual1(pNode1->Key1(), theKey1)) return Standard_True; pNode1 = (DoubleMapNode *) pNode1->Next(); } @@ -293,12 +292,12 @@ public: { if (IsEmpty()) return Standard_False; - Standard_Integer iK2 = Hasher2::HashCode (theKey2, NbBuckets()); + const size_t iK2 = HashCode2 (theKey2, NbBuckets()); DoubleMapNode * pNode2; pNode2 = (DoubleMapNode *) myData2[iK2]; while (pNode2) { - if (Hasher2::IsEqual(pNode2->Key2(), theKey2)) + if (IsEqual2(pNode2->Key2(), theKey2)) return Standard_True; pNode2 = (DoubleMapNode *) pNode2->Next2(); } @@ -310,20 +309,20 @@ public: { if (IsEmpty()) return Standard_False; - Standard_Integer iK1 = Hasher1::HashCode (theKey1, NbBuckets()); + const size_t iK1 = HashCode1 (theKey1, NbBuckets()); DoubleMapNode * p1, * p2, * q1, *q2; q1 = q2 = NULL; p1 = (DoubleMapNode *) myData1[iK1]; while (p1) { - if (Hasher1::IsEqual (p1->Key1(), theKey1)) + if (IsEqual1 (p1->Key1(), theKey1)) { // remove from the data1 if (q1) q1->Next() = p1->Next(); else myData1[iK1] = (DoubleMapNode*) p1->Next(); - Standard_Integer iK2 = Hasher2::HashCode (p1->Key2(), NbBuckets()); + const size_t iK2 = HashCode2 (p1->Key2(), NbBuckets()); p2 = (DoubleMapNode *) myData2[iK2]; while (p2) { @@ -355,20 +354,22 @@ public: { if (IsEmpty()) return Standard_False; - Standard_Integer iK2 = Hasher2::HashCode (theKey2, NbBuckets()); + const size_t iK2 = HashCode2 (theKey2, NbBuckets()); DoubleMapNode * p1, * p2, * q1, *q2; q1 = q2 = NULL; p2 = (DoubleMapNode *) myData2[iK2]; while (p2) { - if (Hasher2::IsEqual (p2->Key2(), theKey2)) + if (IsEqual2 (p2->Key2(), theKey2)) { // remove from the data2 if (q2) - q2->Next() = p2->Next(); + { + q2->Next2() = p2->Next2(); + } else myData2[iK2] = (DoubleMapNode*) p2->Next2(); - Standard_Integer iK1 = Hasher1::HashCode (p2->Key1(), NbBuckets()); + const size_t iK1 = HashCode1 (p2->Key1(), NbBuckets()); p1 = (DoubleMapNode *) myData1[iK1]; while (p1) { @@ -426,10 +427,10 @@ public: //! @return pointer to Key2 or NULL if Key1 is not found const TheKey2Type* Seek1 (const TheKey1Type& theKey1) const { - for (DoubleMapNode* aNode1 = !IsEmpty() ? (DoubleMapNode* )myData1[Hasher1::HashCode (theKey1, NbBuckets())] : NULL; + for (DoubleMapNode* aNode1 = !IsEmpty() ? (DoubleMapNode* )myData1[HashCode1 (theKey1, NbBuckets())] : NULL; aNode1 != NULL; aNode1 = (DoubleMapNode* )aNode1->Next()) { - if (Hasher1::IsEqual (aNode1->Key1(), theKey1)) + if (IsEqual1 (aNode1->Key1(), theKey1)) { return &aNode1->Key2(); } @@ -468,10 +469,10 @@ public: //! @return pointer to Key1 if Key2 has been found const TheKey1Type* Seek2 (const TheKey2Type& theKey2) const { - for (DoubleMapNode* aNode2 = !IsEmpty() ? (DoubleMapNode* )myData2[Hasher2::HashCode (theKey2, NbBuckets())] : NULL; + for (DoubleMapNode* aNode2 = !IsEmpty() ? (DoubleMapNode* )myData2[HashCode2 (theKey2, NbBuckets())] : NULL; aNode2 != NULL; aNode2 = (DoubleMapNode* )aNode2->Next2()) { - if (Hasher2::IsEqual (aNode2->Key2(), theKey2)) + if (IsEqual2 (aNode2->Key2(), theKey2)) { return &aNode2->Key1(); } @@ -481,24 +482,54 @@ public: //! Clear data. If doReleaseMemory is false then the table of //! buckets is not released and will be reused. - void Clear(const Standard_Boolean doReleaseMemory = Standard_True) + void Clear(const Standard_Boolean doReleaseMemory = Standard_False) { Destroy (DoubleMapNode::delNode, doReleaseMemory); } //! Clear data and reset allocator void Clear (const Handle(NCollection_BaseAllocator)& theAllocator) { - Clear(); + Clear(true); this->myAllocator = ( ! theAllocator.IsNull() ? theAllocator : NCollection_BaseAllocator::CommonBaseAllocator() ); } //! Destructor ~NCollection_DoubleMap (void) - { Clear(); } + { Clear(true); } //! Size Standard_Integer Size(void) const { return Extent(); } +protected: + + bool IsEqual1(const TheKey1Type& theKey1, + const TheKey1Type& theKey2) const + { + return myHasher1(theKey1, theKey2); + } + + size_t HashCode1(const TheKey1Type& theKey, + const int theUpperBound) const + { + return myHasher1(theKey) % theUpperBound + 1; + } + + bool IsEqual2(const TheKey2Type& theKey1, + const TheKey2Type& theKey2) const + { + return myHasher2(theKey1, theKey2); + } + + size_t HashCode2(const TheKey2Type& theKey, + const int theUpperBound) const + { + return myHasher2(theKey) % theUpperBound + 1; + } + +protected: + + Hasher1 myHasher1; + Hasher2 myHasher2; }; #endif diff --git a/src/NCollection/NCollection_DynamicArray.hxx b/src/NCollection/NCollection_DynamicArray.hxx new file mode 100644 index 0000000000..5c7ebc655b --- /dev/null +++ b/src/NCollection/NCollection_DynamicArray.hxx @@ -0,0 +1,510 @@ +// Copyright (c) 2002-2023 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef NCollection_DynamicArray_HeaderFile +#define NCollection_DynamicArray_HeaderFile + +#include "NCollection_Allocator.hxx" +#include "NCollection_BasePointerVector.hxx" +#include +#include +#include +#include + +#include +#include +#include +#include +#include +#include +#include + +#include +#include + +//! Class NCollection_DynamicArray (dynamic array of objects) +//! +//! The array's indices always start at 0. +//! +//! The Vector is always created with 0 length. It can be enlarged by two means: +//! 1. Calling the method Append (val) - then "val" is added to the end of the +//! vector (the vector length is incremented) +//! 2. Calling the method SetValue (i, val) - if "i" is greater than or equal +//! to the current length of the vector, the vector is enlarged to accomo- +//! date this index +//! +//! The methods Append and SetValue return a non-const reference to the copied +//! object inside the vector. This reference is guaranteed to be valid until +//! the vector is destroyed. It can be used to access the vector member directly +//! or to pass its address to other data structures. +//! +//! The vector iterator remembers the length of the vector at the moment of the +//! creation or initialisation of the iterator. Therefore the iteration begins +//! at index 0 and stops at the index equal to (remembered_length-1). It is OK +//! to enlarge the vector during the iteration. +template +class NCollection_DynamicArray +{ +public: + //! Memory allocation + DEFINE_STANDARD_ALLOC; + DEFINE_NCOLLECTION_ALLOC; +public: + typedef NCollection_OccAllocator allocator_type; + typedef NCollection_BasePointerVector vector; +public: + + // Define various type aliases for convenience + using value_type = TheItemType; + using size_type = size_t; + using difference_type = size_t; + using pointer = TheItemType*; + using const_pointer = TheItemType&; + using reference = TheItemType&; + using const_reference = const TheItemType&; + +public: + + using iterator = NCollection_IndexedIterator; + using const_iterator = NCollection_IndexedIterator; + +public: + + // Iterator class + class Iterator : public NCollection_Iterator + { + public: + using NCollection_Iterator::NCollection_Iterator; + + const_reference Value() const + { + return *NCollection_Iterator::ValueIter(); + } + + reference ChangeValue() + { + return *NCollection_Iterator::ChangeValueIter(); + } + }; + + const_iterator begin() const + { + return const_iterator(*this); + } + + iterator begin() + { + return iterator(*this); + } + + const_iterator cbegin() const + { + return const_iterator(*this); + } + + iterator end() + { + return iterator(myUsedSize, *this); + } + + const_iterator end() const + { + return const_iterator(myUsedSize, *this); + } + + const_iterator cend() const + { + return const_iterator(myUsedSize, *this); + } + +public: //! @name public methods + + NCollection_DynamicArray(const Standard_Integer theIncrement = 256) : + myContainer(), + myAlloc(), + myInternalSize(theIncrement), + myUsedSize(0) + {} + + // Constructor taking an allocator + explicit NCollection_DynamicArray(const Standard_Integer theIncrement, + const Handle(NCollection_BaseAllocator)& theAllocator) : + myContainer(), + myAlloc(allocator_type(theAllocator)), + myInternalSize(theIncrement), + myUsedSize(0) + {} + + // Constructor taking an allocator + explicit NCollection_DynamicArray(const Standard_Integer theIncrement, + const allocator_type& theAllocator) : + myContainer(), + myAlloc(theAllocator), + myInternalSize(theIncrement), + myUsedSize(0) + {} + + //! Copy constructor + NCollection_DynamicArray(const NCollection_DynamicArray& theOther) : + myContainer(theOther.myContainer), + myAlloc(theOther.myAlloc), + myInternalSize(theOther.myInternalSize), + myUsedSize(theOther.myUsedSize) + { + copyDate(); + } + + NCollection_DynamicArray(NCollection_DynamicArray&& theOther) noexcept : + myContainer(std::move(theOther.myContainer)), + myAlloc(theOther.myAlloc), + myInternalSize(theOther.myInternalSize), + myUsedSize(theOther.myUsedSize) + { + theOther.myUsedSize = 0; + } + + ~NCollection_DynamicArray() + { + Clear(true); + } + + //! Total number of items + Standard_Integer Length() const + { + return static_cast(myUsedSize); + } + + //! Total number of items in the vector + Standard_Integer Size() const + { + return Length(); + } + + //! Method for consistency with other collections. + //! @return Lower bound (inclusive) for iteration. + Standard_Integer Lower() const + { + return 0; + } + + //! Method for consistency with other collections. + //! @return Upper bound (inclusive) for iteration. + Standard_Integer Upper() const + { + return Length() - 1; + } + + //! Empty query + Standard_Boolean IsEmpty() const + { + return myUsedSize == 0; + } + + //! Assignment to the collection of the same type + NCollection_DynamicArray& Assign(const NCollection_DynamicArray& theOther, + const bool theOwnAllocator = true) + { + if (&theOther == this) + { + return *this; + } + if (!theOwnAllocator) + { + Clear(myAlloc != theOther.myAlloc); + myAlloc = theOther.myAlloc; + } + else + { + Clear(false); + } + myContainer = theOther.myContainer; + myInternalSize = theOther.myInternalSize; + myUsedSize = theOther.myUsedSize; + copyDate(); + return *this; + } + + NCollection_DynamicArray& Assign(NCollection_DynamicArray&& theOther) + { + if (&theOther == this) + { + return *this; + } + Clear(true); + myContainer = std::move(theOther.myContainer); + myAlloc = theOther.myAlloc; + myInternalSize = theOther.myInternalSize; + myUsedSize = theOther.myUsedSize; + theOther.myUsedSize = 0; + return *this; + } + + //! Assignment operator + NCollection_DynamicArray& operator= (const NCollection_DynamicArray& theOther) + { + return Assign(theOther, false); + } + + //! Assignment operator + NCollection_DynamicArray& operator= (NCollection_DynamicArray&& theOther) + { + return Assign(std::forward(theOther)); + } + + //! Append + reference Append(const TheItemType& theValue) + { + if (myUsedSize >= availableSize()) + { + expandArray(); + } + pointer aPnt = &at(myUsedSize++); + myAlloc.construct(aPnt, theValue); + return *aPnt; + } + + //! Append + reference Append(TheItemType&& theValue) + { + if (myUsedSize >= availableSize()) + { + expandArray(); + } + pointer aPnt = &at(myUsedSize++); + myAlloc.construct(aPnt, std::forward(theValue)); + return *aPnt; + } + + void EraseLast() + { + if (myUsedSize == 0) + { + return; + } + TheItemType* aLastElem = &ChangeLast(); + myAlloc.destroy(aLastElem); + myUsedSize--; + } + + //! Appends an empty value and returns the reference to it + reference Appended() + { + if (myUsedSize >= availableSize()) + { + expandArray(); + } + pointer aPnt = &at(myUsedSize++); + myAlloc.construct(aPnt); + return *aPnt; + } + + //! Operator() - query the const value + const_reference operator() (const Standard_Integer theIndex) const + { + return Value(theIndex); + } + + //! Operator[] - query the const value + const_reference operator[] (const Standard_Integer theIndex) const + { + return Value(theIndex); + } + + //! Operator[] - query the const value + const_reference operator[] (const size_t theIndex) const + { + return at(theIndex); + } + + const_reference Value(const Standard_Integer theIndex) const + { + return at(static_cast(theIndex)); + } + + //! @return first element + const_reference First() const + { + return getArray()[0][0]; + } + + //! @return first element + reference ChangeFirst() + { + return getArray()[0][0]; + } + + //! @return last element + const_reference Last() const + { + return at(myUsedSize - 1); + } + + //! @return last element + reference ChangeLast() + { + return at(myUsedSize - 1); + } + + //! Operator() - query the value + reference operator() (const Standard_Integer theIndex) + { + return ChangeValue(theIndex); + } + + //! Operator[] - query the value + reference operator[] (const Standard_Integer theIndex) + { + return ChangeValue(theIndex); + } + + //! Operator[] - query the value + reference operator[] (const size_t theIndex) + { + return at(theIndex); + } + + reference ChangeValue(const Standard_Integer theIndex) + { + return at(static_cast(theIndex)); + } + + //! SetValue () - set or append a value + reference SetValue(const Standard_Integer theIndex, + const TheItemType& theValue) + { + const size_t aBlockInd = static_cast(theIndex / myInternalSize); + const size_t anIndex = static_cast(theIndex); + for (size_t aInd = myContainer.Size(); aInd <= aBlockInd; aInd++) + { + expandArray(); + } + if (myUsedSize <= anIndex) + { + for (; myUsedSize < anIndex; myUsedSize++) + { + pointer aPnt = &at(myUsedSize); + myAlloc.construct(aPnt); + } + myUsedSize++; + } + pointer aPnt = &at(anIndex); + myAlloc.construct(aPnt, theValue); + return *aPnt; + } + + //! SetValue () - set or append a value + reference SetValue(const Standard_Integer theIndex, + TheItemType&& theValue) + { + const size_t aBlockInd = static_cast(theIndex / myInternalSize); + const size_t anIndex = static_cast(theIndex); + for (size_t aInd = myContainer.Size(); aInd <= aBlockInd; aInd++) + { + expandArray(); + } + if (myUsedSize <= anIndex) + { + for (; myUsedSize < anIndex; myUsedSize++) + { + pointer aPnt = &at(myUsedSize); + myAlloc.construct(aPnt); + } + myUsedSize++; + } + pointer aPnt = &at(anIndex); + myAlloc.construct(aPnt, std::forward(theValue)); + return *aPnt; + } + + void Clear(const bool theReleaseMemory = false) + { + size_t aUsedSize = 0; + for (size_t aBlockInd = 0; aBlockInd < myContainer.Size(); aBlockInd++) + { + TheItemType* aCurStart = getArray()[aBlockInd]; + for (size_t anElemInd = 0; anElemInd < myInternalSize && aUsedSize < myUsedSize; anElemInd++, aUsedSize++) + { + aCurStart[anElemInd].~TheItemType(); + } + if (theReleaseMemory) + myAlloc.deallocate(aCurStart, myInternalSize); + } + if (theReleaseMemory) + myContainer.Clear(theReleaseMemory); + myUsedSize = 0; + } + + void SetIncrement(const Standard_Integer theIncrement) + { + if (myUsedSize != 0) + { + return; + } + myInternalSize = static_cast(theIncrement); + } + + friend iterator; + friend const_iterator; + +protected: + + size_t availableSize() const + { + return myContainer.Size() * myInternalSize; + } + + TheItemType* expandArray() + { + TheItemType* aNewBlock = myAlloc.allocate(myInternalSize); + myContainer.Append(aNewBlock); + return aNewBlock; + } + + reference at(const size_t theInd) + { + return getArray()[theInd / myInternalSize][theInd % myInternalSize]; + } + + const_reference at(const size_t theInd) const + { + return getArray()[theInd / myInternalSize][theInd % myInternalSize]; + } + + void copyDate() + { + size_t aUsedSize = 0; + for (size_t aBlockInd = 0; aBlockInd < myContainer.Size(); aBlockInd++) + { + TheItemType* aCurStart = getArray()[aBlockInd]; + TheItemType* aNewBlock = myAlloc.allocate(myInternalSize); + for (size_t anElemInd = 0; anElemInd < myInternalSize && aUsedSize < myUsedSize; anElemInd++, aUsedSize++) + { + pointer aPnt = &aNewBlock[anElemInd]; + myAlloc.construct(aPnt, aCurStart[anElemInd]); + } + getArray()[aBlockInd] = aNewBlock; + } + } + + //! Wrapper to extract array + TheItemType** getArray() const { return (TheItemType**) myContainer.GetArray(); } + +protected: + + vector myContainer; + allocator_type myAlloc; + size_t myInternalSize; + size_t myUsedSize; +}; + +#endif // NCollection_DynamicArray_HeaderFile diff --git a/src/NCollection/NCollection_EBTree.hxx b/src/NCollection/NCollection_EBTree.hxx index 5e10239a19..9b631d3cd0 100644 --- a/src/NCollection/NCollection_EBTree.hxx +++ b/src/NCollection/NCollection_EBTree.hxx @@ -38,7 +38,7 @@ template class NCollection_EBTree { public: typedef NCollection_UBTree UBTree; - typedef TYPENAME UBTree::TreeNode TreeNode; + typedef typename UBTree::TreeNode TreeNode; // ---------- PUBLIC METHODS ---------- /** diff --git a/src/NCollection/NCollection_HeapAllocator.hxx b/src/NCollection/NCollection_HeapAllocator.hxx index d18c726df9..947e772b22 100644 --- a/src/NCollection/NCollection_HeapAllocator.hxx +++ b/src/NCollection/NCollection_HeapAllocator.hxx @@ -28,6 +28,7 @@ class NCollection_HeapAllocator : public NCollection_BaseAllocator public: // ---------- PUBLIC METHODS ---------- Standard_EXPORT virtual void* Allocate (const Standard_Size theSize) Standard_OVERRIDE; + void* AllocateOptimal(const Standard_Size theSize) Standard_OVERRIDE { return Allocate(theSize); } Standard_EXPORT virtual void Free (void * anAddress) Standard_OVERRIDE; Standard_EXPORT static const Handle(NCollection_HeapAllocator)& diff --git a/src/NCollection/NCollection_IncAllocator.cxx b/src/NCollection/NCollection_IncAllocator.cxx index 35ce1f6248..c4d12ca98f 100644 --- a/src/NCollection/NCollection_IncAllocator.cxx +++ b/src/NCollection/NCollection_IncAllocator.cxx @@ -1,6 +1,4 @@ -// Created on: 2002-04-12 -// Created by: Alexander GRIGORIEV -// Copyright (c) 2002-2014 OPEN CASCADE SAS +// Copyright (c) 2002-2023 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // @@ -14,445 +12,248 @@ // commercial license or contractual agreement. #include -#include -#include + #include #include -#include -#include -#include +#include -IMPLEMENT_STANDARD_RTTIEXT(NCollection_IncAllocator,NCollection_BaseAllocator) +IMPLEMENT_STANDARD_RTTIEXT(NCollection_IncAllocator, NCollection_BaseAllocator) namespace { + // Bounds for checking block size level + static constexpr unsigned THE_SMALL_BOUND_BLOCK_SIZE = NCollection_IncAllocator::THE_DEFAULT_BLOCK_SIZE * 16; // 196 KB + static constexpr unsigned THE_MEDIUM_BOUND_BLOCK_SIZE = NCollection_IncAllocator::THE_DEFAULT_BLOCK_SIZE * 64; // 786 KB + static constexpr unsigned THE_LARGE_BOUND_BLOCK_SIZE = NCollection_IncAllocator::THE_DEFAULT_BLOCK_SIZE * 1024; // 12 MB - inline size_t IMEM_SIZE (const size_t theSize) + //======================================================================= + //function : computeLevel + //purpose : + //======================================================================= + NCollection_IncAllocator::IBlockSizeLevel computeLevel(const unsigned int theSize) { - return (theSize - 1) / sizeof(NCollection_IncAllocator::aligned_t) + 1; + if (theSize < NCollection_IncAllocator::THE_DEFAULT_BLOCK_SIZE) + { + return NCollection_IncAllocator::IBlockSizeLevel::Min; + } + else if (theSize < THE_SMALL_BOUND_BLOCK_SIZE) + { + return NCollection_IncAllocator::IBlockSizeLevel::Small; + } + else if (theSize < THE_MEDIUM_BOUND_BLOCK_SIZE) + { + return NCollection_IncAllocator::IBlockSizeLevel::Medium; + } + else if (theSize < THE_LARGE_BOUND_BLOCK_SIZE) + { + return NCollection_IncAllocator::IBlockSizeLevel::Large; + } + else + { + return NCollection_IncAllocator::IBlockSizeLevel::Max; + } } - - inline size_t IMEM_ALIGN (const void* theAddress) - { - return sizeof(NCollection_IncAllocator::aligned_t) * IMEM_SIZE (size_t(theAddress)); - } - - #define IMEM_FREE(p_bl) (size_t(p_bl->p_end_block - p_bl->p_free_space)) - -#ifdef OCCT_DEBUG - // auxiliary dummy function used to get a place where break point can be set - inline void place_for_breakpoint() {} -#endif -} - -#define MaxLookup 16 - -static Standard_Boolean IS_DEBUG = Standard_False; - -//======================================================================= -/** - * Static data map (address -> AllocatorID) - */ -//======================================================================= -static NCollection_DataMap& StorageIDMap() -{ - static NCollection_DataMap TheMap; - return TheMap; } //======================================================================= -/** - * Static map (AllocatorID) - */ -//======================================================================= -static NCollection_Map& StorageIDSet() -{ - static NCollection_Map TheMap; - return TheMap; -} - -//======================================================================= -//function : IncAllocator_SetDebugFlag -//purpose : Turn on/off debugging of memory allocation -//======================================================================= - -Standard_EXPORT void IncAllocator_SetDebugFlag(const Standard_Boolean theDebug) -{ - IS_DEBUG = theDebug; -} - -#ifdef OCCT_DEBUG - -//======================================================================= -/** - * Static value of the current allocation ID. It provides unique - * numbering of allocators. - */ -//======================================================================= -static Standard_Size CurrentID = 0; -static Standard_Size CATCH_ID = 0; - -//======================================================================= -//function : Debug_Create -//purpose : Store the allocator address in the internal maps -//======================================================================= - -static void Debug_Create(Standard_Address theAlloc) -{ - static Standard_Mutex aMutex; - aMutex.Lock(); - StorageIDMap().Bind(theAlloc, ++CurrentID); - StorageIDSet().Add(CurrentID); - if (CurrentID == CATCH_ID) - place_for_breakpoint(); - aMutex.Unlock(); -} - -//======================================================================= -//function : Debug_Destroy -//purpose : Forget the allocator address from the internal maps -//======================================================================= - -static void Debug_Destroy(Standard_Address theAlloc) -{ - static Standard_Mutex aMutex; - aMutex.Lock(); - if (StorageIDMap().IsBound(theAlloc)) - { - Standard_Size anID = StorageIDMap()(theAlloc); - StorageIDSet().Remove(anID); - StorageIDMap().UnBind(theAlloc); - } - aMutex.Unlock(); -} - -#endif /* OCCT_DEBUG */ - -//======================================================================= -//function : IncAllocator_PrintAlive -//purpose : Outputs the alive numbers to the file inc_alive.d -//======================================================================= - -Standard_EXPORT void IncAllocator_PrintAlive() -{ - if (StorageIDSet().IsEmpty()) - { - return; - } - - std::ofstream aFileOut ("inc_alive.d", std::ios_base::trunc | std::ios_base::out); - if (!aFileOut.is_open()) - { - std::cout << "failure writing file inc_alive.d" << std::endl; - return; - } - aFileOut.imbue (std::locale ("C")); - aFileOut << std::fixed << std::setprecision(1); - - aFileOut << "Alive IncAllocators (number, size in Kb)\n"; - Standard_Size aTotSize = 0; - Standard_Integer nbAlloc = 0; - for (NCollection_DataMap::Iterator itMap (StorageIDMap()); - itMap.More(); itMap.Next()) - { - const NCollection_IncAllocator* anAlloc = static_cast(itMap.Key()); - Standard_Size anID = itMap.Value(); - Standard_Size aSize = anAlloc->GetMemSize(); - aTotSize += aSize; - nbAlloc++; - aFileOut << std::setw(20) << anID << ' ' - << std::setw(20) << (double(aSize) / 1024.0) - << '\n'; - } - aFileOut << "Total:\n" - << std::setw(20) << nbAlloc << ' ' - << std::setw(20) << (double(aTotSize) / 1024.0) - << '\n'; - aFileOut.close(); -} - -//======================================================================= -//function : NCollection_IncAllocator() +//function : NCollection_IncAllocator //purpose : Constructor //======================================================================= +NCollection_IncAllocator::NCollection_IncAllocator(const size_t theDefaultSize) : + myBlockSize(static_cast(theDefaultSize < THE_MINIMUM_BLOCK_SIZE ? THE_DEFAULT_BLOCK_SIZE : theDefaultSize)) +{} -NCollection_IncAllocator::NCollection_IncAllocator (size_t theBlockSize) -: myMutex (NULL) +//======================================================================= +//function : SetThreadSafe +//purpose : Constructor +//======================================================================= +void NCollection_IncAllocator::SetThreadSafe (const bool theIsThreadSafe) { -#ifdef ALLOC_TRACK_USAGE - printf ("\n..NCollection_IncAllocator: Created (%x)\n",this); -#endif -#ifdef OCCT_DEBUG - if (IS_DEBUG) - Debug_Create(this); -#endif - const size_t aDefault = DefaultBlockSize; - const size_t aSize = IMEM_SIZE(sizeof(IBlock)) + - IMEM_SIZE((theBlockSize > 2*sizeof(IBlock)) ? theBlockSize : aDefault); - IBlock * const aBlock = (IBlock *) malloc (aSize * sizeof(aligned_t)); - myFirstBlock = aBlock; - mySize = aSize - IMEM_SIZE(sizeof(IBlock)); - myMemSize = aSize * sizeof(aligned_t); - if (aBlock == NULL) - throw Standard_OutOfMemory("NCollection_IncAllocator: out of memory"); - aBlock -> p_free_space = (aligned_t *) IMEM_ALIGN (&aBlock[1]); - aBlock -> p_end_block = ((aligned_t *) aBlock) + aSize; - aBlock -> p_next = NULL; + if(theIsThreadSafe) + { + if (!myMutex) + { + myMutex = new Standard_Mutex; + } + } + else + { + delete myMutex; + myMutex = nullptr; + } } //======================================================================= //function : ~NCollection_IncAllocator //purpose : Destructor //======================================================================= - -NCollection_IncAllocator::~NCollection_IncAllocator () +NCollection_IncAllocator::~NCollection_IncAllocator() { + clean(); delete myMutex; -#ifdef OCCT_DEBUG - if (IS_DEBUG) - Debug_Destroy(this); -#endif - Clean(); - free (myFirstBlock); } //======================================================================= -//function : SetThreadSafe -//purpose : +//function : AllocateOptimal +//purpose : allocate a memory //======================================================================= -void NCollection_IncAllocator::SetThreadSafe (bool theIsThreadSafe) +void* NCollection_IncAllocator::AllocateOptimal(const size_t theSize) { - if (myMutex == NULL - && theIsThreadSafe) + Standard_Mutex::Sentry aLock(myMutex); + // Allocating using general block + IBlock* aBlock = nullptr; + // Use allocated blocks + if (myAllocationHeap && myAllocationHeap->AvailableSize >= theSize) { - myMutex = new Standard_Mutex(); + aBlock = myAllocationHeap; } - else if (!theIsThreadSafe) + else // Allocate new general block { - delete myMutex; - myMutex = NULL; + if (++myBlockCount % 5 == 0) // increase count before checking + { + increaseBlockSize(); + } + if (myBlockSize < theSize) + { + myBlockSize = static_cast(theSize); + } + void* aBufferBlock = Standard::AllocateOptimal(myBlockSize + sizeof(IBlock)); + aBlock = new (aBufferBlock) IBlock(aBufferBlock, myBlockSize); + aBlock->NextBlock = myAllocationHeap; + aBlock->NextOrderedBlock = myOrderedBlocks; + myOrderedBlocks = aBlock; + myAllocationHeap = aBlock; } + void* aRes = aBlock->CurPointer; + aBlock->CurPointer += theSize; + aBlock->AvailableSize -= theSize; + if (aBlock->AvailableSize < 16) + { + myAllocationHeap = aBlock->NextBlock; + aBlock->NextBlock = myUsedHeap; + myUsedHeap = aBlock; + } + else + { + IBlock* aBlockIter = aBlock->NextBlock; + IBlock* aBlockToReplaceAfter = nullptr; + while (aBlockIter) // Search new sorted position + { + if (aBlockIter->AvailableSize > aBlock->AvailableSize) + { + aBlockToReplaceAfter = aBlockIter; + aBlockIter = aBlockIter->NextBlock; + continue; + } + break; + } + if (aBlockToReplaceAfter) // Update list order + { + IBlock* aNext = aBlockToReplaceAfter->NextBlock; + aBlockToReplaceAfter->NextBlock = aBlock; + myAllocationHeap = aBlock->NextBlock; + aBlock->NextBlock = aNext; + } + } + return aRes; } //======================================================================= //function : Allocate -//purpose : allocate a memory -//remark : returns NULL if allocation fails +//purpose : Allocate a memory //======================================================================= - -void * NCollection_IncAllocator::Allocate (const size_t aSize) +void* NCollection_IncAllocator::Allocate(const size_t theSize) { - aligned_t * aResult = NULL; - const size_t cSize = aSize ? IMEM_SIZE(aSize) : 0; - - Standard_Mutex::Sentry aLock (myMutex); - if (cSize > mySize) { - /* If the requested size exceeds normal allocation size, allocate - a separate block and place it as the head of the list */ - aResult = (aligned_t *) allocateNewBlock (cSize+1); - if (aResult) - myFirstBlock -> p_free_space = myFirstBlock -> p_end_block; - else - throw Standard_OutOfMemory("NCollection_IncAllocator: out of memory"); - } else - if (cSize <= IMEM_FREE(myFirstBlock)) { - /* If the requested size fits into the free space in the 1st block */ - aResult = myFirstBlock -> allocateInBlock (cSize); - } else { - /* Search for a block in the list with enough free space */ - int aMaxLookup = MaxLookup; /* limit the number of blocks to query */ - IBlock * aCurrentBlock = myFirstBlock -> p_next; - while (aCurrentBlock && aMaxLookup--) { - if (cSize <= IMEM_FREE(aCurrentBlock)) { - aResult = aCurrentBlock -> allocateInBlock (cSize); - break; - } - aCurrentBlock = aCurrentBlock -> p_next; - } - if (aResult == NULL) { - /* There is no available block with enough free space. Create a new - one and place it in the head of the list */ - aResult = (aligned_t *) allocateNewBlock (mySize); - if (aResult) - myFirstBlock -> p_free_space = aResult + cSize; - else - { - const size_t aDefault = IMEM_SIZE(DefaultBlockSize); - if (cSize > aDefault) - throw Standard_OutOfMemory("NCollection_IncAllocator: out of memory"); - else - { - aResult = (aligned_t *) allocateNewBlock (aDefault); - if (aResult) - myFirstBlock -> p_free_space = aResult + cSize; - else - throw Standard_OutOfMemory("NCollection_IncAllocator: out of memory"); - } - } - } - } - return aResult; + return AllocateOptimal(theSize); } //======================================================================= -//function : Reallocate +//function : clean //purpose : //======================================================================= - -void * NCollection_IncAllocator::Reallocate (void * theAddress, - const size_t oldSize, - const size_t newSize) +void NCollection_IncAllocator::clean() { -// Check that the dummy parameters are OK - if (theAddress == NULL || oldSize == 0) - return Allocate (newSize); - - const size_t cOldSize = IMEM_SIZE(oldSize); - const size_t cNewSize = newSize ? IMEM_SIZE(newSize) : 0; - aligned_t * anAddress = (aligned_t *) theAddress; - - Standard_Mutex::Sentry aLock (myMutex); -// We check only the LAST allocation to do the real extension/contraction - if (anAddress + cOldSize == myFirstBlock -> p_free_space) { - myFirstBlock -> p_free_space = anAddress; -// If the new size fits into the memory block => OK -// This also includes any case of contraction - if (cNewSize <= IMEM_FREE(myFirstBlock)) { - myFirstBlock -> p_free_space += cNewSize; - return anAddress; - } - } -// In case of contraction of non-terminating allocation, do nothing - else if (cOldSize >= cNewSize) - return anAddress; -// Extension of non-terminated allocation if there is enough room in the -// current memory block - if (cNewSize <= IMEM_FREE(myFirstBlock)) { - aligned_t * aResult = myFirstBlock -> allocateInBlock (cNewSize); - if (aResult) - for (unsigned i = 0; i < cOldSize; i++) - aResult[i] = anAddress[i]; - return aResult; - } - -// This is either of the cases: -// - extension of non-terminating allocation, or -// - extension of terminating allocation when the new size is too big -// In both cases create a new memory block, allocate memory and copy there -// the reallocated memory. - size_t cMaxSize = mySize > cNewSize ? mySize : cNewSize; - aligned_t * aResult = (aligned_t *) allocateNewBlock (cMaxSize); - if (aResult) { - myFirstBlock -> p_free_space = aResult + cNewSize; - for (unsigned i = 0; i < cOldSize; i++) - aResult[i] = anAddress[i]; - } - else + Standard_Mutex::Sentry aLock(myMutex); + IBlock* aHeapIter = myOrderedBlocks; + while (aHeapIter) { - throw Standard_OutOfMemory("NCollection_IncAllocator: out of memory"); + IBlock* aCur = aHeapIter; + aHeapIter = aHeapIter->NextOrderedBlock; + Standard::Free(aCur); } - return aResult; + myOrderedBlocks = nullptr; + myAllocationHeap = nullptr; + myUsedHeap = nullptr; + myBlockCount = 0; + myBlockSize = THE_DEFAULT_BLOCK_SIZE; } //======================================================================= -//function : Free +//function : increaseBlockSize //purpose : //======================================================================= - -void NCollection_IncAllocator::Free (void *) -{} - -//======================================================================= -//function : Clean -//purpose : -//======================================================================= - -void NCollection_IncAllocator::Clean () +void NCollection_IncAllocator::increaseBlockSize() { -#ifdef ALLOC_TRACK_USAGE - printf ("\n..NCollection_IncAllocator: Memory size to clean:%8.1f kB (%x)\n", - double(GetMemSize())/1024, this); -#endif - IBlock * aBlock = myFirstBlock; - if (aBlock) { - aBlock -> p_free_space = (aligned_t *) &aBlock[1]; - aBlock = aBlock -> p_next; - while (aBlock) { - IBlock * aNext = aBlock -> p_next; - free (aBlock); - aBlock = aNext; - } - myFirstBlock -> p_next = NULL; + switch (computeLevel(myBlockSize)) + { + case NCollection_IncAllocator::IBlockSizeLevel::Min: + myBlockSize *= 8; + break; + case NCollection_IncAllocator::IBlockSizeLevel::Small: + myBlockSize *= 4; + break; + case NCollection_IncAllocator::IBlockSizeLevel::Medium: + myBlockSize *= 2; + break; + case NCollection_IncAllocator::IBlockSizeLevel::Large: + myBlockSize = static_cast(std::lround(myBlockSize * 1.5)); + break; + case NCollection_IncAllocator::IBlockSizeLevel::Max: + break; } - myMemSize = 0; +} + +//======================================================================= +//function : resetBlock +//purpose : +//======================================================================= +void NCollection_IncAllocator::resetBlock(IBlock* theBlock) const +{ + theBlock->AvailableSize = theBlock->AvailableSize + (theBlock->CurPointer - (reinterpret_cast(theBlock) + sizeof(IBlock))); + theBlock->CurPointer = reinterpret_cast(theBlock) + sizeof(IBlock); } //======================================================================= //function : Reset //purpose : //======================================================================= - -void NCollection_IncAllocator::Reset (const Standard_Boolean doReleaseMem) +void NCollection_IncAllocator::Reset(const Standard_Boolean theReleaseMemory) { - Standard_Mutex::Sentry aLock (myMutex); - if (doReleaseMem) - Clean(); - else { - Standard_Integer aBlockCount(0); - IBlock * aBlock = myFirstBlock; - while (aBlock) - if (aBlockCount++ < MaxLookup) { - aBlock -> p_free_space = (aligned_t *) &aBlock[1]; - if (aBlockCount < MaxLookup) - aBlock = aBlock -> p_next; - else { - IBlock * aNext = aBlock -> p_next; - aBlock -> p_next = NULL; - aBlock = aNext; - } - } else { - IBlock * aNext = aBlock -> p_next; - myMemSize -= (aBlock -> p_end_block - (aligned_t *) aBlock) * sizeof (aligned_t); - free (aBlock); - aBlock = aNext; - } + if (theReleaseMemory) + { + clean(); + return; } + Standard_Mutex::Sentry aLock(myMutex); + IBlock* aHeapIter = myOrderedBlocks; + while (aHeapIter) + { + IBlock* aCur = aHeapIter; + aHeapIter = aHeapIter->NextOrderedBlock; + aCur->NextBlock = aHeapIter; + resetBlock(aCur); // reset size and pointer + } + myAllocationHeap = myOrderedBlocks; + myUsedHeap = nullptr; } //======================================================================= -//function : GetMemSize -//purpose : diagnostic utility -//======================================================================= - -size_t NCollection_IncAllocator::GetMemSize () const -{ -// size_t aResult = 0; -// IBlock * aBlock = myFirstBlock; -// while (aBlock) { -// aResult += (aBlock -> p_end_block - (aligned_t *) aBlock); -// aBlock = aBlock -> p_next; -// } -// return aResult * sizeof (aligned_t); - return myMemSize; -} - -//======================================================================= -//function : allocateNewBlock +//function : IBlockSmall::IBlockSmall //purpose : //======================================================================= - -void * NCollection_IncAllocator::allocateNewBlock (const size_t cSize) -{ - aligned_t * aResult = 0L; - const size_t aSz = cSize + IMEM_SIZE(sizeof(IBlock)); - IBlock * aBlock = (IBlock *) malloc (aSz * sizeof(aligned_t)); - if (aBlock) { - aBlock -> p_end_block = ((aligned_t *)aBlock) + aSz; - aBlock -> p_next = myFirstBlock; - myFirstBlock = aBlock; - aResult = (aligned_t *) IMEM_ALIGN(&aBlock[1]); - myMemSize += aSz * sizeof(aligned_t); - } - return aResult; -} +NCollection_IncAllocator::IBlock::IBlock(void* thePointer, + const size_t theSize) : + CurPointer(static_cast(thePointer) + sizeof(IBlock)), + AvailableSize(theSize) +{} diff --git a/src/NCollection/NCollection_IncAllocator.hxx b/src/NCollection/NCollection_IncAllocator.hxx index 7dfe560af5..0993d552a6 100644 --- a/src/NCollection/NCollection_IncAllocator.hxx +++ b/src/NCollection/NCollection_IncAllocator.hxx @@ -1,6 +1,4 @@ -// Created on: 2002-04-12 -// Created by: Alexander GRIGORIEV -// Copyright (c) 2002-2014 OPEN CASCADE SAS +// Copyright (c) 2002-2023 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // @@ -15,8 +13,12 @@ #ifndef NCollection_IncAllocator_HeaderFile #define NCollection_IncAllocator_HeaderFile - + #include +#include +#include + +#include class Standard_Mutex; @@ -46,11 +48,7 @@ class Standard_Mutex; */ class NCollection_IncAllocator : public NCollection_BaseAllocator { - public: - // The type defining the alignement of allocated objects - typedef void * aligned_t; - - // ---------- PUBLIC METHODS ---------- +public: //! Constructor. //! Note that this constructor does NOT setup mutex for using allocator concurrently from different threads, @@ -61,84 +59,97 @@ class NCollection_IncAllocator : public NCollection_BaseAllocator //! platform for the repeated operations (and thus multiple allocations) //! because Low Fragmentation Heap is not going to be used for these allocations, //! leading to memory fragmentation and eventual performance slow down. - Standard_EXPORT NCollection_IncAllocator (size_t theBlockSize = DefaultBlockSize); + Standard_EXPORT NCollection_IncAllocator (const size_t theBlockSize = THE_DEFAULT_BLOCK_SIZE); //! Setup mutex for thread-safe allocations. - Standard_EXPORT void SetThreadSafe (bool theIsThreadSafe = true); + Standard_EXPORT void SetThreadSafe (const bool theIsThreadSafe = true); //! Allocate memory with given size. Returns NULL on failure - Standard_EXPORT virtual void* Allocate (const size_t size) Standard_OVERRIDE; + Standard_EXPORT void* Allocate(const size_t size) Standard_OVERRIDE; + + //! Allocate memory with given size. Returns NULL on failure + Standard_EXPORT void* AllocateOptimal(const size_t size) Standard_OVERRIDE; //! Free a previously allocated memory. Does nothing - Standard_EXPORT virtual void Free (void *anAddress) Standard_OVERRIDE; - - //! Diagnostic method, returns the total allocated size - Standard_EXPORT size_t GetMemSize () const; + void Free(void*) Standard_OVERRIDE + { + // Do nothing + } //! Destructor (calls Clean() internally) - Standard_EXPORT ~NCollection_IncAllocator (); - - //! Reallocation: it is always allowed but is only efficient with the - //! last allocated item - Standard_EXPORT void * Reallocate (void * anAddress, - const size_t oldSize, - const size_t newSize); + Standard_EXPORT ~NCollection_IncAllocator(); //! Re-initialize the allocator so that the next Allocate call should //! start allocating in the very beginning as though the allocator is just //! constructed. Warning: make sure that all previously allocated data are //! no more used in your code! - //! @param doReleaseMem + //! @param theReleaseMemory //! True - release all previously allocated memory, False - preserve it //! for future allocations. - Standard_EXPORT void Reset (const Standard_Boolean - doReleaseMem=Standard_True); + Standard_EXPORT void Reset(const bool theReleaseMemory = false); - //! Default size for the memory blocks - 12KB - static const size_t DefaultBlockSize = 12300; +private: + // Prohibited methods + NCollection_IncAllocator(const NCollection_IncAllocator&) = delete; + NCollection_IncAllocator& operator = (const NCollection_IncAllocator&) = delete; - protected: - struct IBlock; +public: + + //! Forward list to keep multi-time allocated pointers. + //! On Reset operation objects will be reused. + struct IBlock + { + IBlock(void* thePointer, + const size_t theSize); + + char* CurPointer; + size_t AvailableSize; + IBlock* NextBlock = nullptr; //! Pointer to next sorted block + IBlock* NextOrderedBlock = nullptr; //! Pointer to next ordered block + }; + + //! Description ability to next growing size each 5-th new block + enum class IBlockSizeLevel : unsigned short + { + Min = 0, // x8 growing + Small, // x4 growing + Medium, // x2 growing + Large, // x1.5 growing + Max // no growing + }; + +protected: + + //! Increases size according current block size level + void increaseBlockSize(); + + //! Resets available size and CurPointer field + void resetBlock(IBlock* theBlock) const; //! Flush all previously allocated data. All pointers returned by //! Allocate() become invalid -- be very careful with this - Standard_EXPORT void Clean (); + void clean(); - //! Allocate a new block and return a pointer to it - //! ** only for internal usage ** - void * allocateNewBlock (const size_t cSize); +public: - private: - // Prohibited methods - NCollection_IncAllocator (const NCollection_IncAllocator&); - NCollection_IncAllocator& operator = (const NCollection_IncAllocator&); + static constexpr size_t THE_DEFAULT_BLOCK_SIZE = 1024 * 12; - protected: - // ----- PROTECTED CLASS IBlock ------- - struct IBlock { - aligned_t * allocateInBlock (const size_t cSize) - { - aligned_t * aResult = p_free_space; - p_free_space += cSize; - return aResult; - } - aligned_t * p_free_space; - aligned_t * p_end_block; - struct IBlock * p_next; - }; - protected: - // --------- PROTECTED FIELDS --------- - Standard_Mutex* myMutex; - IBlock * myFirstBlock; - size_t mySize; - size_t myMemSize; + static constexpr size_t THE_MINIMUM_BLOCK_SIZE = 1024 * 2; - public: -// Declaration of CASCADE RTTI - DEFINE_STANDARD_RTTIEXT(NCollection_IncAllocator,NCollection_BaseAllocator) +private: + unsigned int myBlockSize; //!< Block size to incremental allocations + unsigned int myBlockCount = 0; //!< Count of created blocks + Standard_Mutex* myMutex = nullptr; //!< Thread-safety mutex + IBlock* myAllocationHeap = nullptr; //!< Sorted list for allocations + IBlock* myUsedHeap = nullptr; //!< Sorted list for store empty blocks + IBlock* myOrderedBlocks = nullptr; //!< Ordered list for store growing size blocks + +public: + // Declaration of CASCADE RTTI + DEFINE_STANDARD_RTTIEXT(NCollection_IncAllocator, NCollection_BaseAllocator) }; // Definition of HANDLE object using Standard_DefineHandle.hxx -DEFINE_STANDARD_HANDLE (NCollection_IncAllocator, NCollection_BaseAllocator) +DEFINE_STANDARD_HANDLE(NCollection_IncAllocator, NCollection_BaseAllocator) #endif diff --git a/src/NCollection/NCollection_IndexedDataMap.hxx b/src/NCollection/NCollection_IndexedDataMap.hxx index c3a7f4b0dc..eb3052d629 100644 --- a/src/NCollection/NCollection_IndexedDataMap.hxx +++ b/src/NCollection/NCollection_IndexedDataMap.hxx @@ -24,6 +24,7 @@ #include #include +#include /** * Purpose: An indexed map is used to store keys and to bind @@ -54,6 +55,7 @@ public: typedef TheKeyType key_type; //! STL-compliant typedef for value type typedef TheItemType value_type; + typedef Hasher hasher; private: //! Adaptation of the TListNode to the INDEXEDDatamap @@ -68,8 +70,34 @@ private: : NCollection_TListNode(theItem,theNext1), myKey1 (theKey1), myIndex (theIndex) - { - } + {} + //! Constructor with 'Next' + IndexedDataMapNode (TheKeyType&& theKey1, + const Standard_Integer theIndex, + const TheItemType& theItem, + NCollection_ListNode* theNext1) + : NCollection_TListNode(theItem,theNext1), + myKey1 (std::forward(theKey1)), + myIndex (theIndex) + {} + //! Constructor with 'Next' + IndexedDataMapNode (const TheKeyType& theKey1, + const Standard_Integer theIndex, + TheItemType&& theItem, + NCollection_ListNode* theNext1) + : NCollection_TListNode(std::forward(theItem),theNext1), + myKey1 (theKey1), + myIndex (theIndex) + {} + //! Constructor with 'Next' + IndexedDataMapNode (TheKeyType&& theKey1, + const Standard_Integer theIndex, + TheItemType&& theItem, + NCollection_ListNode* theNext1) + : NCollection_TListNode(std::forward(theItem),theNext1), + myKey1 (std::forward(theKey1)), + myIndex (theIndex) + {} //! Key1 TheKeyType& Key1() { return myKey1; } //! Index @@ -165,18 +193,23 @@ private: // ---------- PUBLIC METHODS ------------ //! Empty constructor. - NCollection_IndexedDataMap() : NCollection_BaseMap (1, Standard_False, Handle(NCollection_BaseAllocator)()) {} + NCollection_IndexedDataMap() : NCollection_BaseMap (1, true, Handle(NCollection_BaseAllocator)()) {} //! Constructor explicit NCollection_IndexedDataMap (const Standard_Integer theNbBuckets, const Handle(NCollection_BaseAllocator)& theAllocator = 0L) - : NCollection_BaseMap (theNbBuckets, Standard_False, theAllocator) {} + : NCollection_BaseMap (theNbBuckets, true, theAllocator) {} //! Copy constructor NCollection_IndexedDataMap (const NCollection_IndexedDataMap& theOther) - : NCollection_BaseMap (theOther.NbBuckets(), Standard_False, theOther.myAllocator) + : NCollection_BaseMap (theOther.NbBuckets(), true, theOther.myAllocator) { *this = theOther; } + //! Move constructor + NCollection_IndexedDataMap(NCollection_IndexedDataMap&& theOther) noexcept : + NCollection_BaseMap(std::forward(theOther)) + {} + //! Exchange the content of two maps without re-allocations. //! Notice that allocators will be swapped as well! void Exchange (NCollection_IndexedDataMap& theOther) @@ -200,7 +233,7 @@ private: { const TheKeyType& aKey1 = theOther.FindKey (anIndexIter); const TheItemType& anItem = theOther.FindFromIndex(anIndexIter); - const Standard_Integer iK1 = Hasher::HashCode (aKey1, NbBuckets()); + const size_t iK1 = HashCode (aKey1, NbBuckets()); IndexedDataMapNode* pNode = new (this->myAllocator) IndexedDataMapNode (aKey1, anIndexIter, anItem, myData1[iK1]); myData1[iK1] = pNode; myData2[anIndexIter - 1] = pNode; @@ -216,6 +249,15 @@ private: return Assign (theOther); } + //! Move operator + NCollection_IndexedDataMap& operator= (NCollection_IndexedDataMap&& theOther) noexcept + { + if (this == &theOther) + return *this; + exchangeMapsData(theOther); + return *this; + } + //! ReSize void ReSize (const Standard_Integer N) { @@ -226,7 +268,6 @@ private: { if (myData1) { - memcpy (ppNewData2, myData2, sizeof(IndexedDataMapNode*) * Extent()); for (Standard_Integer aBucketIter = 0; aBucketIter <= NbBuckets(); ++aBucketIter) { if (myData1[aBucketIter]) @@ -234,7 +275,7 @@ private: IndexedDataMapNode* p = (IndexedDataMapNode *) myData1[aBucketIter]; while (p) { - const Standard_Integer iK1 = Hasher::HashCode (p->Key1(), newBuck); + const size_t iK1 = HashCode (p->Key1(), newBuck); IndexedDataMapNode* q = (IndexedDataMapNode* )p->Next(); p->Next() = ppNewData1[iK1]; ppNewData1[iK1] = p; @@ -243,7 +284,8 @@ private: } } } - EndResize (N, newBuck, ppNewData1, ppNewData2); + EndResize (N, newBuck, ppNewData1, (NCollection_ListNode**) + Standard::Reallocate(myData2, (newBuck + 1) * sizeof(NCollection_ListNode*))); } } @@ -257,40 +299,98 @@ private: { ReSize(Extent()); } - - const Standard_Integer iK1 = Hasher::HashCode (theKey1, NbBuckets()); - IndexedDataMapNode* pNode = (IndexedDataMapNode* )myData1[iK1]; - while (pNode) + IndexedDataMapNode* aNode; + size_t aHash; + if (lookup(theKey1, aNode, aHash)) { - if (Hasher::IsEqual (pNode->Key1(), theKey1)) - { - return pNode->Index(); - } - pNode = (IndexedDataMapNode *) pNode->Next(); + return aNode->Index(); } - const Standard_Integer aNewIndex = Increment(); - pNode = new (this->myAllocator) IndexedDataMapNode (theKey1, aNewIndex, theItem, myData1[iK1]); - myData1[iK1] = pNode; - myData2[aNewIndex - 1] = pNode; + aNode = new (this->myAllocator) IndexedDataMapNode (theKey1, aNewIndex, theItem, myData1[aHash]); + myData1[aHash] = aNode; + myData2[aNewIndex - 1] = aNode; + return aNewIndex; + } + + //! Returns the Index of already bound Key or appends new Key with specified Item value. + //! @param theKey1 Key to search (and to bind, if it was not bound already) + //! @param theItem Item value to set for newly bound Key; ignored if Key was already bound + //! @return index of Key + Standard_Integer Add (TheKeyType&& theKey1, const TheItemType& theItem) + { + if (Resizable()) + { + ReSize(Extent()); + } + IndexedDataMapNode* aNode; + size_t aHash; + if (lookup(theKey1, aNode, aHash)) + { + return aNode->Index(); + } + const Standard_Integer aNewIndex = Increment(); + aNode = new (this->myAllocator) IndexedDataMapNode (std::forward(theKey1), aNewIndex, theItem, myData1[aHash]); + myData1[aHash] = aNode; + myData2[aNewIndex - 1] = aNode; + return aNewIndex; + } + + //! Returns the Index of already bound Key or appends new Key with specified Item value. + //! @param theKey1 Key to search (and to bind, if it was not bound already) + //! @param theItem Item value to set for newly bound Key; ignored if Key was already bound + //! @return index of Key + Standard_Integer Add (const TheKeyType& theKey1, TheItemType&& theItem) + { + if (Resizable()) + { + ReSize(Extent()); + } + IndexedDataMapNode* aNode; + size_t aHash; + if (lookup(theKey1, aNode, aHash)) + { + return aNode->Index(); + } + const Standard_Integer aNewIndex = Increment(); + aNode = new (this->myAllocator) IndexedDataMapNode (theKey1, aNewIndex, std::forward(theItem), myData1[aHash]); + myData1[aHash] = aNode; + myData2[aNewIndex - 1] = aNode; + return aNewIndex; + } + + //! Returns the Index of already bound Key or appends new Key with specified Item value. + //! @param theKey1 Key to search (and to bind, if it was not bound already) + //! @param theItem Item value to set for newly bound Key; ignored if Key was already bound + //! @return index of Key + Standard_Integer Add (TheKeyType&& theKey1, TheItemType&& theItem) + { + if (Resizable()) + { + ReSize(Extent()); + } + IndexedDataMapNode* aNode; + size_t aHash; + if (lookup(theKey1, aNode, aHash)) + { + return aNode->Index(); + } + const Standard_Integer aNewIndex = Increment(); + aNode = new (this->myAllocator) IndexedDataMapNode (std::forward(theKey1), aNewIndex, + std::forward(theItem), myData1[aHash]); + myData1[aHash] = aNode; + myData2[aNewIndex - 1] = aNode; return aNewIndex; } //! Contains Standard_Boolean Contains (const TheKeyType& theKey1) const { - if (IsEmpty()) - return Standard_False; - Standard_Integer iK1 = Hasher::HashCode (theKey1, NbBuckets()); - IndexedDataMapNode * pNode1; - pNode1 = (IndexedDataMapNode *) myData1[iK1]; - while (pNode1) + IndexedDataMapNode* aNode; + if (lookup(theKey1, aNode)) { - if (Hasher::IsEqual(pNode1->Key1(), theKey1)) - return Standard_True; - pNode1 = (IndexedDataMapNode *) pNode1->Next(); + return true; } - return Standard_False; + return false; } //! Substitute @@ -303,44 +403,40 @@ private: "Index is out of range"); // check if theKey1 is not already in the map - const Standard_Integer iK1 = Hasher::HashCode (theKey1, NbBuckets()); - IndexedDataMapNode* p = (IndexedDataMapNode *) myData1[iK1]; - while (p) + size_t aHash; + IndexedDataMapNode* aNode; + if (lookup(theKey1, aNode, aHash)) { - if (Hasher::IsEqual (p->Key1(), theKey1)) + if (aNode->Index() != theIndex) { - if (p->Index() != theIndex) - { - throw Standard_DomainError ("NCollection_IndexedDataMap::Substitute : " - "Attempt to substitute existing key"); - } - p->Key1() = theKey1; - p->ChangeValue() = theItem; - return; + throw Standard_DomainError("NCollection_IndexedDataMap::Substitute : " + "Attempt to substitute existing key"); } - p = (IndexedDataMapNode *) p->Next(); + aNode->Key1() = theKey1; + aNode->ChangeValue() = theItem; + return; } // Find the node for the index I - p = (IndexedDataMapNode* )myData2[theIndex - 1]; + aNode = (IndexedDataMapNode* )myData2[theIndex - 1]; // remove the old key - const Standard_Integer iK = Hasher::HashCode (p->Key1(), NbBuckets()); + const size_t iK = HashCode (aNode->Key1(), NbBuckets()); IndexedDataMapNode * q = (IndexedDataMapNode *) myData1[iK]; - if (q == p) - myData1[iK] = (IndexedDataMapNode *) p->Next(); + if (q == aNode) + myData1[iK] = (IndexedDataMapNode *)aNode->Next(); else { - while (q->Next() != p) + while (q->Next() != aNode) q = (IndexedDataMapNode *) q->Next(); - q->Next() = p->Next(); + q->Next() = aNode->Next(); } // update the node - p->Key1() = theKey1; - p->ChangeValue() = theItem; - p->Next() = myData1[iK1]; - myData1[iK1] = p; + aNode->Key1() = theKey1; + aNode->ChangeValue() = theItem; + aNode->Next() = myData1[aHash]; + myData1[aHash] = aNode; } //! Swaps two elements with the given indices. @@ -373,7 +469,7 @@ private: myData2[aLastIndex - 1] = NULL; // remove the key - const Standard_Integer iK1 = Hasher::HashCode (p->Key1(), NbBuckets()); + const size_t iK1 = HashCode (p->Key1(), NbBuckets()); IndexedDataMapNode* q = (IndexedDataMapNode *) myData1[iK1]; if (q == p) myData1[iK1] = (IndexedDataMapNode *) p->Next(); @@ -444,15 +540,10 @@ private: //! FindIndex Standard_Integer FindIndex(const TheKeyType& theKey1) const { - if (IsEmpty()) return 0; - IndexedDataMapNode* pNode1 = (IndexedDataMapNode* )myData1[Hasher::HashCode(theKey1,NbBuckets())]; - while (pNode1) + IndexedDataMapNode* aNode; + if (lookup(theKey1, aNode)) { - if (Hasher::IsEqual (pNode1->Key1(), theKey1)) - { - return pNode1->Index(); - } - pNode1 = (IndexedDataMapNode*) pNode1->Next(); + return aNode->Index(); } return 0; } @@ -461,15 +552,10 @@ private: const TheItemType& FindFromKey(const TheKeyType& theKey1) const { Standard_NoSuchObject_Raise_if (IsEmpty(), "NCollection_IndexedDataMap::FindFromKey"); - - IndexedDataMapNode* pNode1 = (IndexedDataMapNode* )myData1[Hasher::HashCode(theKey1,NbBuckets())]; - while (pNode1) + IndexedDataMapNode* aNode; + if (lookup(theKey1, aNode)) { - if (Hasher::IsEqual (pNode1->Key1(), theKey1)) - { - return pNode1->Value(); - } - pNode1 = (IndexedDataMapNode*) pNode1->Next(); + return aNode->Value(); } throw Standard_NoSuchObject("NCollection_IndexedDataMap::FindFromKey"); } @@ -478,15 +564,10 @@ private: TheItemType& ChangeFromKey (const TheKeyType& theKey1) { Standard_NoSuchObject_Raise_if (IsEmpty(), "NCollection_IndexedDataMap::ChangeFromKey"); - - IndexedDataMapNode* pNode1 = (IndexedDataMapNode* )myData1[Hasher::HashCode(theKey1,NbBuckets())]; - while (pNode1) + IndexedDataMapNode* aNode; + if (lookup(theKey1, aNode)) { - if (Hasher::IsEqual (pNode1->Key1(), theKey1)) - { - return pNode1->ChangeValue(); - } - pNode1 = (IndexedDataMapNode*) pNode1->Next(); + return aNode->ChangeValue(); } throw Standard_NoSuchObject("NCollection_IndexedDataMap::ChangeFromKey"); } @@ -496,27 +577,18 @@ private: const TheItemType* Seek(const TheKeyType& theKey1) const { return const_cast< NCollection_IndexedDataMap * >( this )->ChangeSeek(theKey1); - //NCollection_IndexedDataMap *pMap=(NCollection_IndexedDataMap *)this; - //return pMap->ChangeSeek(theKey1); } //! ChangeSeek returns modifiable pointer to Item by Key. Returns //! NULL if Key was not found. TheItemType* ChangeSeek (const TheKeyType& theKey1) { - if (!IsEmpty()) + IndexedDataMapNode* aNode; + if (lookup(theKey1, aNode)) { - IndexedDataMapNode* pNode1 = (IndexedDataMapNode* )myData1[Hasher::HashCode(theKey1,NbBuckets())]; - while (pNode1) - { - if (Hasher::IsEqual (pNode1->Key1(), theKey1)) - { - return &pNode1->ChangeValue(); - } - pNode1 = (IndexedDataMapNode*) pNode1->Next(); - } + return &aNode->ChangeValue(); } - return 0L; + return nullptr; } //! Find value for key with copying. @@ -524,46 +596,91 @@ private: Standard_Boolean FindFromKey (const TheKeyType& theKey1, TheItemType& theValue) const { - if (IsEmpty()) + IndexedDataMapNode* aNode; + if (lookup(theKey1, aNode)) { - return Standard_False; - } - for (IndexedDataMapNode* aNode = (IndexedDataMapNode* )myData1[Hasher::HashCode (theKey1, NbBuckets())]; - aNode != NULL; aNode = (IndexedDataMapNode* )aNode->Next()) - { - if (Hasher::IsEqual (aNode->Key1(), theKey1)) - { theValue = aNode->Value(); return Standard_True; - } } return Standard_False; } //! Clear data. If doReleaseMemory is false then the table of //! buckets is not released and will be reused. - void Clear(const Standard_Boolean doReleaseMemory = Standard_True) + void Clear(const Standard_Boolean doReleaseMemory = Standard_False) { Destroy (IndexedDataMapNode::delNode, doReleaseMemory); } //! Clear data and reset allocator void Clear (const Handle(NCollection_BaseAllocator)& theAllocator) { - Clear(); + Clear(theAllocator != this->myAllocator); this->myAllocator = ( ! theAllocator.IsNull() ? theAllocator : NCollection_BaseAllocator::CommonBaseAllocator() ); } //! Destructor virtual ~NCollection_IndexedDataMap (void) - { Clear(); } + { Clear(true); } //! Size Standard_Integer Size(void) const { return Extent(); } - private: - // ----------- PRIVATE METHODS ----------- +protected: + //! Lookup for particular key in map. + //! @param[in] theKey key to compute hash + //! @param[out] theNode the detected node with equal key. Can be null. + //! @param[out] theHash computed bounded hash code for current key. + //! @return true if key is found + Standard_Boolean lookup(const TheKeyType& theKey, IndexedDataMapNode*& theNode, size_t& theHash) const + { + theHash = HashCode(theKey, NbBuckets()); + if (IsEmpty()) + return Standard_False; // Not found + for (theNode = (IndexedDataMapNode*)myData1[theHash]; + theNode; theNode = (IndexedDataMapNode*)theNode->Next()) + { + if (IsEqual(theNode->Key1(), theKey)) + return Standard_True; + } + return Standard_False; // Not found + } + + //! Lookup for particular key in map. + //! @param[in] theKey key to compute hash + //! @param[out] theNode the detected node with equal key. Can be null. + //! @return true if key is found + Standard_Boolean lookup(const TheKeyType& theKey, IndexedDataMapNode*& theNode) const + { + if (IsEmpty()) + return Standard_False; // Not found + for (theNode = (IndexedDataMapNode*)myData1[HashCode(theKey, NbBuckets())]; + theNode; theNode = (IndexedDataMapNode*)theNode->Next()) + { + if (IsEqual(theNode->Key1(), theKey)) + { + return Standard_True; + } + } + return Standard_False; // Not found + } + + bool IsEqual(const TheKeyType& theKey1, + const TheKeyType& theKey2) const + { + return myHasher(theKey1, theKey2); + } + + size_t HashCode(const TheKeyType& theKey, + const int theUpperBound) const + { + return myHasher(theKey) % theUpperBound + 1; + } + +protected: + + Hasher myHasher; }; #endif diff --git a/src/NCollection/NCollection_IndexedIterator.hxx b/src/NCollection/NCollection_IndexedIterator.hxx new file mode 100644 index 0000000000..fbc6bbd5a3 --- /dev/null +++ b/src/NCollection/NCollection_IndexedIterator.hxx @@ -0,0 +1,232 @@ +// Copyright (c) 2023 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef NCollection_IndexedIterator_HeaderFile +#define NCollection_IndexedIterator_HeaderFile + +#include +#include + +//! Helper class that allows to use NCollection iterators as STL iterators. +//! NCollection iterator can be extended to STL iterator of any category by +//! adding necessary methods: STL forward iterator requires IsEqual method, +//! STL bidirectional iterator requires Previous method, and STL random access +//! iterator requires Offset and Differ methods. See NCollection_Vector as +//! example of declaring custom STL iterators. +template +class NCollection_IndexedIterator +{ +public: + + // Since C++20 inheritance from std::iterator is deprecated, so define predefined types manually: + using iterator_category = Category; + using value_type = ItemType; + using difference_type = ptrdiff_t; + using pointer = typename std::conditional::type; + using reference = typename std::conditional::type; + + //! Default constructor + NCollection_IndexedIterator() : myIndex(0), myIndexedMap(nullptr) + {} + + //! Constructor from NCollection_Indexed*Map + NCollection_IndexedIterator(const BaseIndexedMap& theMap) : + myIndex(0), myIndexedMap((&const_cast(theMap))) + {} + + //! Constructor from NCollection_Indexed*Map + NCollection_IndexedIterator(const size_t theIndex, const BaseIndexedMap& theMap) : + myIndex(theIndex), myIndexedMap(&const_cast(theMap)) + {} + + //! Cast from non-const variant to const one + NCollection_IndexedIterator(const NCollection_IndexedIterator& theOther) : + myIndex(theOther.myIndex), myIndexedMap(theOther.myIndexedMap) + {} + + //! Assignment of non-const iterator to const one + NCollection_IndexedIterator& operator= (const NCollection_IndexedIterator& theOther) + { + myIndex = theOther.myIndex; + myIndexedMap = theOther.myIndexedMap; + return *this; + } + +protected: //! @name methods related to forward STL iterator + + // Note: Here we use SFINAE (Substitution failure is not an error) to choose + // an appropriate method based on template arguments (at instantiation time). + + template + typename std::enable_if::type Reference() const + { + return myIndexedMap->at(myIndex); + } + + template + typename std::enable_if::type Reference() const + { + return myIndexedMap->at(myIndex); + } + +public: //! @name methods related to forward STL iterator + + //! Test for equality + bool operator== (const NCollection_IndexedIterator& theOther) const + { + return myIndexedMap == theOther.myIndexedMap && + myIndex == theOther.myIndex; + } + + template + bool operator== (const NCollection_IndexedIterator& theOther) const + { + return myIndexedMap == theOther.myIndexedMap && + myIndex == theOther.myIndex; + } + + template + bool operator!= (const NCollection_IndexedIterator& theOther) const + { + return myIndexedMap != theOther.myIndexedMap || + myIndex != theOther.myIndex; + } + + //! Test for inequality + bool operator!= (const NCollection_IndexedIterator& theOther) const + { + return !(*this == theOther); + } + + //! Get reference to current item + typename NCollection_IndexedIterator::reference operator*() const + { + return Reference(); + } + + //! Dereferencing operator + typename NCollection_IndexedIterator::pointer operator->() const + { + return &Reference(); + } + + //! Prefix increment + NCollection_IndexedIterator& operator++() + { + myIndex++; + return *this; + } + + //! Postfix increment + NCollection_IndexedIterator operator++(int) + { + const NCollection_IndexedIterator theOld(*this); + ++(*this); + return theOld; + } + +public: //! @name methods related to bidirectional STL iterator + + //! Prefix decrement + NCollection_IndexedIterator& operator--() + { + Standard_STATIC_ASSERT((opencascade::std::is_same::value || + opencascade::std::is_same::value)); + myIndex--; + return *this; + } + + //! Postfix decrement + NCollection_IndexedIterator operator--(int) + { + NCollection_IndexedIterator theOld(*this); + --(*this); + return theOld; + } + +public: //! @name methods related to random access STL iterator + + //! Move forward + NCollection_IndexedIterator& operator+= (typename NCollection_IndexedIterator::difference_type theOffset) + { + Standard_STATIC_ASSERT((opencascade::std::is_same::value)); + myIndex += theOffset; + return *this; + } + + //! Addition + NCollection_IndexedIterator operator+ (typename NCollection_IndexedIterator::difference_type theOffset) const + { + NCollection_IndexedIterator aTemp(*this); + return aTemp += theOffset; + } + + //! Move backward + NCollection_IndexedIterator& operator-= (typename NCollection_IndexedIterator::difference_type theOffset) + { + return *this += -theOffset; + } + + //! Decrease + NCollection_IndexedIterator operator- (typename NCollection_IndexedIterator::difference_type theOffset) const + { + NCollection_IndexedIterator aTemp(*this); + return aTemp += -theOffset; + } + + //! Difference + typename NCollection_IndexedIterator::difference_type operator- (const NCollection_IndexedIterator& theOther) const + { + Standard_STATIC_ASSERT((opencascade::std::is_same::value)); + return myIndex - theOther.myIndex; + } + + //! Get item at offset from current + typename NCollection_IndexedIterator::reference operator[] (typename NCollection_IndexedIterator::difference_type theOffset) const + { + return *(*this + theOffset); + } + + //! Comparison + bool operator< (const NCollection_IndexedIterator& theOther) const + { + return (*this - theOther) < 0; + } + + //! Comparison + bool operator> (const NCollection_IndexedIterator& theOther) const + { + return theOther < *this; + } + + //! Comparison + bool operator<= (const NCollection_IndexedIterator& theOther) const + { + return !(theOther < *this); + } + + //! Comparison + bool operator>= (const NCollection_IndexedIterator& theOther) const + { + return !(*this < theOther); + } + + friend class NCollection_IndexedIterator; + +private: + //! NCollection iterator + size_t myIndex; + BaseIndexedMap* myIndexedMap; +}; + +#endif // NCollection_IndexedIterator_HeaderFile diff --git a/src/NCollection/NCollection_IndexedMap.hxx b/src/NCollection/NCollection_IndexedMap.hxx index 875068d83c..83d28baec3 100644 --- a/src/NCollection/NCollection_IndexedMap.hxx +++ b/src/NCollection/NCollection_IndexedMap.hxx @@ -55,8 +55,14 @@ protected: NCollection_ListNode* theNext1) : NCollection_TListNode (theKey1, theNext1), myIndex (theIndex) - { - } + {} + //! Constructor with 'Next' + IndexedMapNode (TheKeyType&& theKey1, + const Standard_Integer theIndex, + NCollection_ListNode* theNext1) + : NCollection_TListNode (std::forward(theKey1), theNext1), + myIndex (theIndex) + {} //! Key1 TheKeyType& Key1() { return this->ChangeValue(); } @@ -125,18 +131,23 @@ protected: // ---------- PUBLIC METHODS ------------ //! Empty constructor. - NCollection_IndexedMap() : NCollection_BaseMap (1, Standard_False, Handle(NCollection_BaseAllocator)()) {} + NCollection_IndexedMap() : NCollection_BaseMap (1, true, Handle(NCollection_BaseAllocator)()) {} //! Constructor explicit NCollection_IndexedMap (const Standard_Integer theNbBuckets, const Handle(NCollection_BaseAllocator)& theAllocator=0L) - : NCollection_BaseMap (theNbBuckets, Standard_False, theAllocator) {} + : NCollection_BaseMap (theNbBuckets, true, theAllocator) {} //! Copy constructor NCollection_IndexedMap (const NCollection_IndexedMap& theOther) - : NCollection_BaseMap (theOther.NbBuckets(), Standard_False, theOther.myAllocator) + : NCollection_BaseMap (theOther.NbBuckets(), true, theOther.myAllocator) { *this = theOther; } + //! Move constructor + NCollection_IndexedMap(NCollection_IndexedMap&& theOther) noexcept : + NCollection_BaseMap(std::forward(theOther)) + {} + //! Exchange the content of two maps without re-allocations. //! Notice that allocators will be swapped as well! void Exchange (NCollection_IndexedMap& theOther) @@ -159,7 +170,7 @@ protected: for (Standard_Integer anIndexIter = 1; anIndexIter <= anExt; ++anIndexIter) { const TheKeyType& aKey1 = theOther.FindKey (anIndexIter); - const Standard_Integer iK1 = Hasher::HashCode (aKey1, NbBuckets()); + const size_t iK1 = HashCode (aKey1, NbBuckets()); IndexedMapNode* pNode = new (this->myAllocator) IndexedMapNode (aKey1, anIndexIter, myData1[iK1]); myData1[iK1] = pNode; myData2[anIndexIter - 1] = pNode; @@ -175,6 +186,15 @@ protected: return Assign (theOther); } + //! Move operator + NCollection_IndexedMap& operator= (NCollection_IndexedMap&& theOther) noexcept + { + if (this == &theOther) + return *this; + exchangeMapsData(theOther); + return *this; + } + //! ReSize void ReSize (const Standard_Integer theExtent) { @@ -185,7 +205,6 @@ protected: { if (myData1) { - memcpy (ppNewData2, myData2, sizeof(IndexedMapNode*) * Extent()); for (Standard_Integer aBucketIter = 0; aBucketIter <= NbBuckets(); ++aBucketIter) { if (myData1[aBucketIter]) @@ -193,7 +212,7 @@ protected: IndexedMapNode* p = (IndexedMapNode* )myData1[aBucketIter]; while (p) { - const Standard_Integer iK1 = Hasher::HashCode (p->Key1(), newBuck); + const size_t iK1 = HashCode (p->Key1(), newBuck); IndexedMapNode* q = (IndexedMapNode* )p->Next(); p->Next() = ppNewData1[iK1]; ppNewData1[iK1] = p; @@ -202,7 +221,8 @@ protected: } } } - EndResize (theExtent, newBuck, ppNewData1, ppNewData2); + EndResize (theExtent, newBuck, ppNewData1, (NCollection_ListNode**) + Standard::Reallocate(myData2, (newBuck + 1) * sizeof(NCollection_ListNode*))); } } @@ -213,40 +233,45 @@ protected: { ReSize (Extent()); } - - Standard_Integer iK1 = Hasher::HashCode (theKey1, NbBuckets()); - IndexedMapNode* pNode = (IndexedMapNode* )myData1[iK1]; - while (pNode) + IndexedMapNode* aNode; + size_t aHash; + if (lookup(theKey1, aNode, aHash)) { - if (Hasher::IsEqual (pNode->Key1(), theKey1)) - { - return pNode->Index(); - } - pNode = (IndexedMapNode *) pNode->Next(); + return aNode->Index(); } - const Standard_Integer aNewIndex = Increment(); - pNode = new (this->myAllocator) IndexedMapNode (theKey1, aNewIndex, myData1[iK1]); - myData1[iK1] = pNode; - myData2[aNewIndex - 1] = pNode; + aNode = new (this->myAllocator) IndexedMapNode (theKey1, aNewIndex, myData1[aHash]); + myData1[aHash] = aNode; + myData2[aNewIndex - 1] = aNode; + return aNewIndex; + } + + //! Add + Standard_Integer Add (TheKeyType&& theKey1) + { + if (Resizable()) + { + ReSize(Extent()); + } + size_t aHash; + IndexedMapNode* aNode; + if (lookup(theKey1, aNode, aHash)) + { + return aNode->Index(); + } + const Standard_Integer aNewIndex = Increment(); + aNode = new (this->myAllocator) IndexedMapNode(std::forward(theKey1), + aNewIndex, myData1[aHash]); + myData1[aHash] = aNode; + myData2[aNewIndex - 1] = aNode; return aNewIndex; } //! Contains Standard_Boolean Contains (const TheKeyType& theKey1) const { - if (IsEmpty()) - return Standard_False; - Standard_Integer iK1 = Hasher::HashCode (theKey1, NbBuckets()); - IndexedMapNode * pNode1; - pNode1 = (IndexedMapNode *) myData1[iK1]; - while (pNode1) - { - if (Hasher::IsEqual(pNode1->Key1(), theKey1)) - return Standard_True; - pNode1 = (IndexedMapNode *) pNode1->Next(); - } - return Standard_False; + IndexedMapNode* p; + return lookup(theKey1, p); } //! Substitute @@ -258,42 +283,37 @@ protected: "Index is out of range"); // check if theKey1 is not already in the map - Standard_Integer iK1 = Hasher::HashCode (theKey1, NbBuckets()); - IndexedMapNode* p = (IndexedMapNode *) myData1[iK1]; - while (p) + IndexedMapNode* aNode; + size_t aHash; + if (lookup(theKey1, aNode, aHash)) { - if (Hasher::IsEqual (p->Key1(), theKey1)) + if (aNode->Index() != theIndex) { - if (p->Index() != theIndex) - { - throw Standard_DomainError ("NCollection_IndexedMap::Substitute : " - "Attempt to substitute existing key"); - } - p->Key1() = theKey1; - return; + throw Standard_DomainError ("NCollection_IndexedMap::Substitute : " + "Attempt to substitute existing key"); } - p = (IndexedMapNode *) p->Next(); + aNode->Key1() = theKey1; + return; } - // Find the node for the index I - p = (IndexedMapNode* )myData2[theIndex - 1]; + aNode = (IndexedMapNode* )myData2[theIndex - 1]; // remove the old key - Standard_Integer iK = Hasher::HashCode (p->Key1(), NbBuckets()); + const size_t iK = HashCode (aNode->Key1(), NbBuckets()); IndexedMapNode * q = (IndexedMapNode *) myData1[iK]; - if (q == p) - myData1[iK] = (IndexedMapNode *) p->Next(); + if (q == aNode) + myData1[iK] = (IndexedMapNode *) aNode->Next(); else { - while (q->Next() != p) + while (q->Next() != aNode) q = (IndexedMapNode *) q->Next(); - q->Next() = p->Next(); + q->Next() = aNode->Next(); } // update the node - p->Key1() = theKey1; - p->Next() = myData1[iK1]; - myData1[iK1] = p; + aNode->Key1() = theKey1; + aNode->Next() = myData1[aHash]; + myData1[aHash] = aNode; } //! Swaps two elements with the given indices. @@ -326,7 +346,7 @@ protected: myData2[aLastIndex - 1] = NULL; // remove the key - Standard_Integer iK1 = Hasher::HashCode (p->Key1(), NbBuckets()); + const size_t iK1 = HashCode (p->Key1(), NbBuckets()); IndexedMapNode* q = (IndexedMapNode *) myData1[iK1]; if (q == p) myData1[iK1] = (IndexedMapNode *) p->Next(); @@ -383,39 +403,90 @@ protected: //! FindIndex Standard_Integer FindIndex(const TheKeyType& theKey1) const { - if (IsEmpty()) return 0; - IndexedMapNode* pNode1 = (IndexedMapNode* )myData1[Hasher::HashCode(theKey1,NbBuckets())]; - while (pNode1) + IndexedMapNode* aNode; + if (lookup(theKey1, aNode)) { - if (Hasher::IsEqual (pNode1->Key1(), theKey1)) - { - return pNode1->Index(); - } - pNode1 = (IndexedMapNode*) pNode1->Next(); + return aNode->Index(); } return 0; } //! Clear data. If doReleaseMemory is false then the table of //! buckets is not released and will be reused. - void Clear(const Standard_Boolean doReleaseMemory = Standard_True) + void Clear(const Standard_Boolean doReleaseMemory = Standard_False) { Destroy (IndexedMapNode::delNode, doReleaseMemory); } //! Clear data and reset allocator void Clear (const Handle(NCollection_BaseAllocator)& theAllocator) { - Clear(); + Clear(theAllocator != this->myAllocator); this->myAllocator = ( ! theAllocator.IsNull() ? theAllocator : NCollection_BaseAllocator::CommonBaseAllocator() ); } //! Destructor virtual ~NCollection_IndexedMap (void) - { Clear(); } + { Clear(true); } //! Size Standard_Integer Size(void) const { return Extent(); } + +protected: + + //! Lookup for particular key in map. + //! @param[in] theKey key to compute hash + //! @param[out] theNode the detected node with equal key. Can be null. + //! @param[out] theHash computed bounded hash code for current key. + //! @return true if key is found + Standard_Boolean lookup(const TheKeyType& theKey, IndexedMapNode*& theNode, size_t& theHash) const + { + theHash = HashCode(theKey, NbBuckets()); + if (IsEmpty()) + return Standard_False; // Not found + for (theNode = (IndexedMapNode*)myData1[theHash]; + theNode; theNode = (IndexedMapNode*)theNode->Next()) + { + if (IsEqual(theNode->Key1(), theKey)) + return Standard_True; + } + return Standard_False; // Not found + } + + //! Lookup for particular key in map. + //! @param[in] theKey key to compute hash + //! @param[out] theNode the detected node with equal key. Can be null. + //! @return true if key is found + Standard_Boolean lookup(const TheKeyType& theKey, IndexedMapNode*& theNode) const + { + if (IsEmpty()) + return Standard_False; // Not found + for (theNode = (IndexedMapNode*)myData1[HashCode(theKey, NbBuckets())]; + theNode; theNode = (IndexedMapNode*)theNode->Next()) + { + if (IsEqual(theNode->Key1(), theKey)) + { + return Standard_True; + } + } + return Standard_False; // Not found + } + + bool IsEqual(const TheKeyType& theKey1, + const TheKeyType& theKey2) const + { + return myHasher(theKey1, theKey2); + } + + size_t HashCode(const TheKeyType& theKey, + const int theUpperBound) const + { + return myHasher(theKey) % theUpperBound + 1; + } + +protected: + + Hasher myHasher; }; #endif diff --git a/src/NCollection/NCollection_Iterator.hxx b/src/NCollection/NCollection_Iterator.hxx new file mode 100644 index 0000000000..ec4481ae40 --- /dev/null +++ b/src/NCollection/NCollection_Iterator.hxx @@ -0,0 +1,127 @@ +// Copyright (c) 2023 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef NCollection_Iterator_HeaderFile +#define NCollection_Iterator_HeaderFile + +#include +#include + +//! Helper class that allows to use NCollection iterators as STL iterators. +//! NCollection iterator can be extended to STL iterator of any category by +//! adding necessary methods: STL forward iterator requires IsEqual method, +//! STL bidirectional iterator requires Previous method, and STL random access +//! iterator requires Offset and Differ methods. See NCollection_Vector as +//! example of declaring custom STL iterators. +template +class NCollection_Iterator +{ +public: + + NCollection_Iterator() : myCur(typename Container::iterator()), myLast(typename Container::iterator()) {} + + NCollection_Iterator(const NCollection_Iterator& theOther) : myCur(theOther.myCur), myLast(theOther.myLast) {} + + NCollection_Iterator(const Container& theList) : myCur(const_cast(theList).begin()), myLast(const_cast(theList).end()) {} + + NCollection_Iterator(const Container& theList, const typename Container::iterator& theOther) + : myCur(theOther), myLast(const_cast(theList).end()) {} + + NCollection_Iterator(const Container& theList, typename Container::iterator&& theOther) + : myCur(theOther), myLast(const_cast(theList).end()) + {} + + ~NCollection_Iterator() {} + + void Init(Container& theList) + { + myCur = theList.begin(); + myLast = theList.end(); + } + + void Init(const Container& theList) + { + Init(const_cast(theList)); + } + + virtual bool More() const + { + return myCur != myLast; + } + + void Initialize(Container& theList) + { + Init(theList); + } + + void Initialize(const Container& theList) + { + Init(theList); + } + + const typename Container::iterator& ValueIter() const + { + return myCur; + } + + typename Container::iterator& ChangeValueIter() + { + return myCur; + } + + const typename Container::iterator& EndIter() const + { + return myLast; + } + + typename Container::iterator& ChangeEndIter() + { + return myLast; + } + + virtual void Next() + { + ++(myCur); + } + + bool operator==(const NCollection_Iterator& theOther) { return myLast == theOther.myLast && myCur == theOther.myCur; } + + bool operator!=(const NCollection_Iterator& theOther) { return myLast != theOther.myLast || myCur != theOther.myCur; } + + NCollection_Iterator& operator=(const NCollection_Iterator& theOther) + { + if (this != &theOther) + { + myLast = theOther.myLast; + myCur = theOther.myCur; + } + return *this; + } + + NCollection_Iterator& operator=(NCollection_Iterator&& theOther) + { + if (this != &theOther) + { + myLast = std::move(theOther.myLast); + myCur = std::move(theOther.myCur); + } + return *this; + } + +private: + typename Container::iterator myCur; + typename Container::iterator myLast; +}; + + +#endif // NCollection_Iterator_HeaderFile diff --git a/src/NCollection/NCollection_List.hxx b/src/NCollection/NCollection_List.hxx index 418d65eaae..ceb220b0b4 100644 --- a/src/NCollection/NCollection_List.hxx +++ b/src/NCollection/NCollection_List.hxx @@ -68,7 +68,14 @@ public: NCollection_List (const NCollection_List& theOther) : NCollection_BaseList(theOther.myAllocator) { - Assign (theOther); + appendList(theOther.PFirst()); + } + + //! Move constructor + NCollection_List(NCollection_List&& theOther) noexcept : + NCollection_BaseList(theOther.myAllocator) + { + this->operator=(std::forward(theOther)); } //! Size - Number of items @@ -92,6 +99,22 @@ public: return Assign (theOther); } + //! Move operator + NCollection_List& operator= (NCollection_List&& theOther) noexcept + { + if (this == &theOther) + { + return *this; + } + Clear(theOther.myAllocator); + myFirst = theOther.myFirst; + myLast = theOther.myLast; + myLength = theOther.myLength; + theOther.myFirst = theOther.myLast = nullptr; + theOther.myLength = 0; + return *this; + } + //! Clear this list void Clear (const Handle(NCollection_BaseAllocator)& theAllocator=0L) { @@ -136,6 +159,14 @@ public: return ((ListNode *) PLast())->ChangeValue(); } + //! Append one item at the end + TheItemType& Append (TheItemType&& theItem) + { + ListNode * pNew = new (this->myAllocator) ListNode(std::forward(theItem)); + PAppend(pNew); + return ((ListNode *) PLast())->ChangeValue(); + } + //! Append one item at the end and output iterator //! pointing at the appended item void Append (const TheItemType& theItem, Iterator& theIter) @@ -144,6 +175,14 @@ public: PAppend(pNew, theIter); } + //! Append one item at the end and output iterator + //! pointing at the appended item + void Append (TheItemType&& theItem, Iterator& theIter) + { + ListNode * pNew = new (this->myAllocator) ListNode(std::forward(theItem)); + PAppend(pNew, theIter); + } + //! Append another list at the end. //! After this operation, theOther list will be cleared. void Append (NCollection_List& theOther) @@ -172,6 +211,14 @@ public: return ((ListNode *) PFirst())->ChangeValue(); } + //! Prepend one item at the beginning + TheItemType& Prepend (TheItemType&& theItem) + { + ListNode * pNew = new (this->myAllocator) ListNode(std::forward(theItem)); + PPrepend(pNew); + return ((ListNode *) PFirst())->ChangeValue(); + } + //! Prepend another list at the beginning void Prepend (NCollection_List& theOther) { @@ -227,6 +274,15 @@ public: return pNew -> ChangeValue(); } + //! InsertBefore + TheItemType& InsertBefore (TheItemType&& theItem, + Iterator& theIter) + { + ListNode * pNew = new (this->myAllocator) ListNode(std::forward(theItem)); + PInsertBefore (pNew, theIter); + return pNew -> ChangeValue(); + } + //! InsertBefore void InsertBefore (NCollection_List& theOther, Iterator& theIter) @@ -257,6 +313,15 @@ public: return pNew -> ChangeValue(); } + //! InsertAfter + TheItemType& InsertAfter (TheItemType&& theItem, + Iterator& theIter) + { + ListNode * pNew = new (this->myAllocator) ListNode(std::forward(theItem)); + PInsertAfter (pNew, theIter); + return pNew -> ChangeValue(); + } + //! InsertAfter void InsertAfter (NCollection_List& theOther, Iterator& theIter) diff --git a/src/NCollection/NCollection_Map.hxx b/src/NCollection/NCollection_Map.hxx index 339f1da6a7..ca7f0135b3 100644 --- a/src/NCollection/NCollection_Map.hxx +++ b/src/NCollection/NCollection_Map.hxx @@ -22,6 +22,7 @@ #include #include +#include /** * Purpose: Single hashed Map. This Map is used to store and @@ -58,6 +59,7 @@ class NCollection_Map : public NCollection_BaseMap public: //! STL-compliant typedef for key type typedef TheKeyType key_type; + typedef Hasher hasher; public: //! Adaptation of the TListNode to the map notations @@ -68,6 +70,10 @@ public: MapNode (const TheKeyType& theKey, NCollection_ListNode* theNext) : NCollection_TListNode (theKey, theNext) {} + //! Constructor with 'Next' + MapNode (TheKeyType&& theKey, + NCollection_ListNode* theNext) : + NCollection_TListNode (std::forward(theKey), theNext) {} //! Key const TheKeyType& Key (void) { return this->Value(); } @@ -127,9 +133,21 @@ public: : NCollection_BaseMap (theNbBuckets, Standard_True, theAllocator) {} //! Copy constructor - NCollection_Map (const NCollection_Map& theOther) : - NCollection_BaseMap (theOther.NbBuckets(), Standard_True, theOther.myAllocator) - { *this = theOther; } + NCollection_Map(const NCollection_Map& theOther) : + NCollection_BaseMap(theOther.NbBuckets(), Standard_True, theOther.myAllocator) + { + const int anExt = theOther.Extent(); + if (anExt <= 0) + return; + ReSize(anExt - 1); + for (Iterator anIter(theOther); anIter.More(); anIter.Next()) + Add(anIter.Key()); + } + + //! Move constructor + NCollection_Map (NCollection_Map&& theOther) noexcept : + NCollection_BaseMap (std::forward(theOther)) + {} //! Exchange the content of two maps without re-allocations. //! Notice that allocators will be swapped as well! @@ -163,6 +181,15 @@ public: return Assign(theOther); } + //! Move operator + NCollection_Map& operator= (NCollection_Map&& theOther) noexcept + { + if (this == &theOther) + return *this; + exchangeMapsData(theOther); + return *this; + } + //! ReSize void ReSize (const Standard_Integer N) { @@ -175,15 +202,14 @@ public: { MapNode** olddata = (MapNode**) myData1; MapNode *p, *q; - Standard_Integer i,k; - for (i = 0; i <= NbBuckets(); i++) + for (int i = 0; i <= NbBuckets(); i++) { if (olddata[i]) { p = olddata[i]; while (p) { - k = Hasher::HashCode(p->Key(),newBuck); + const size_t k = HashCode(p->Key(),newBuck); q = (MapNode*) p->Next(); p->Next() = newdata[k]; newdata[k] = p; @@ -197,58 +223,80 @@ public: } //! Add - Standard_Boolean Add(const TheKeyType& K) + Standard_Boolean Add(const TheKeyType& theKey) { if (Resizable()) ReSize(Extent()); - MapNode** data = (MapNode**)myData1; - Standard_Integer k = Hasher::HashCode(K,NbBuckets()); - MapNode* p = data[k]; - while (p) + MapNode* aNode; + size_t aHash; + if (lookup(theKey, aNode, aHash)) { - if (Hasher::IsEqual(p->Key(),K)) - return Standard_False; - p = (MapNode *) p->Next(); + return Standard_False; } - data[k] = new (this->myAllocator) MapNode(K,data[k]); + MapNode** data = (MapNode**)myData1; + data[aHash] = new (this->myAllocator) MapNode(theKey,data[aHash]); + Increment(); + return Standard_True; + } + + //! Add + Standard_Boolean Add(TheKeyType&& theKey) + { + if (Resizable()) + ReSize(Extent()); + MapNode* aNode; + size_t aHash; + if (lookup(theKey, aNode, aHash)) + { + return Standard_False; + } + MapNode** data = (MapNode**)myData1; + data[aHash] = new (this->myAllocator) MapNode(std::forward(theKey),data[aHash]); Increment(); return Standard_True; } //! Added: add a new key if not yet in the map, and return //! reference to either newly added or previously existing object - const TheKeyType& Added(const TheKeyType& K) + const TheKeyType& Added(const TheKeyType& theKey) { if (Resizable()) ReSize(Extent()); - MapNode** data = (MapNode**)myData1; - Standard_Integer k = Hasher::HashCode(K,NbBuckets()); - MapNode* p = data[k]; - while (p) + MapNode* aNode; + size_t aHash; + if (lookup(theKey, aNode, aHash)) { - if (Hasher::IsEqual(p->Key(),K)) - return p->Key(); - p = (MapNode *) p->Next(); + return aNode->Key(); } - data[k] = new (this->myAllocator) MapNode(K,data[k]); + MapNode** data = (MapNode**)myData1; + data[aHash] = new (this->myAllocator) MapNode(theKey,data[aHash]); Increment(); - return data[k]->Key(); + return data[aHash]->Key(); + } + + //! Added: add a new key if not yet in the map, and return + //! reference to either newly added or previously existing object + const TheKeyType& Added(TheKeyType&& theKey) + { + if (Resizable()) + ReSize(Extent()); + MapNode* aNode; + size_t aHash; + if (lookup(theKey, aNode, aHash)) + { + return aNode->Key(); + } + MapNode** data = (MapNode**)myData1; + data[aHash] = new (this->myAllocator) MapNode(std::forward(theKey),data[aHash]); + Increment(); + return data[aHash]->Key(); } //! Contains - Standard_Boolean Contains(const TheKeyType& K) const + Standard_Boolean Contains(const TheKeyType& theKey) const { - if (IsEmpty()) - return Standard_False; - MapNode** data = (MapNode**) myData1; - MapNode* p = data[Hasher::HashCode(K,NbBuckets())]; - while (p) - { - if (Hasher::IsEqual(p->Key(),K)) - return Standard_True; - p = (MapNode *) p->Next(); - } - return Standard_False; + MapNode* p; + return lookup(theKey, p); } //! Remove @@ -257,12 +305,12 @@ public: if (IsEmpty()) return Standard_False; MapNode** data = (MapNode**) myData1; - Standard_Integer k = Hasher::HashCode(K,NbBuckets()); + const size_t k = HashCode(K,NbBuckets()); MapNode* p = data[k]; MapNode* q = NULL; while (p) { - if (Hasher::IsEqual(p->Key(),K)) + if (IsEqual(p->Key(),K)) { Decrement(); if (q) @@ -281,20 +329,20 @@ public: //! Clear data. If doReleaseMemory is false then the table of //! buckets is not released and will be reused. - void Clear(const Standard_Boolean doReleaseMemory = Standard_True) + void Clear(const Standard_Boolean doReleaseMemory = Standard_False) { Destroy (MapNode::delNode, doReleaseMemory); } //! Clear data and reset allocator void Clear (const Handle(NCollection_BaseAllocator)& theAllocator) { - Clear(); + Clear(theAllocator != this->myAllocator); this->myAllocator = ( ! theAllocator.IsNull() ? theAllocator : NCollection_BaseAllocator::CommonBaseAllocator() ); } //! Destructor virtual ~NCollection_Map (void) - { Clear(); } + { Clear(true); } //! Size Standard_Integer Size(void) const @@ -590,7 +638,60 @@ public: return anOldExtent != Extent(); } - //!@} +protected: + + //! Lookup for particular key in map. + //! @param[in] theKey key to compute hash + //! @param[out] theNode the detected node with equal key. Can be null. + //! @param[out] theHash computed bounded hash code for current key. + //! @return true if key is found + Standard_Boolean lookup(const TheKeyType& theKey, MapNode*& theNode, size_t& theHash) const + { + theHash = HashCode(theKey, NbBuckets()); + if (IsEmpty()) + return Standard_False; // Not found + for (theNode = (MapNode*)myData1[theHash]; + theNode; theNode = (MapNode*)theNode->Next()) + { + if (IsEqual(theNode->Key(), theKey)) + return Standard_True; + } + return Standard_False; // Not found + } + + //! Lookup for particular key in map. + //! @param[in] theKey key to compute hash + //! @param[out] theNode the detected node with equal key. Can be null. + //! @return true if key is found + Standard_Boolean lookup(const TheKeyType& theKey, MapNode*& theNode) const + { + if (IsEmpty()) + return Standard_False; // Not found + for (theNode = (MapNode*)myData1[HashCode(theKey, NbBuckets())]; + theNode; theNode = (MapNode*)theNode->Next()) + { + if (IsEqual(theNode->Key(), theKey)) + { + return Standard_True; + } + } + return Standard_False; // Not found + } + + bool IsEqual(const TheKeyType& theKey1, + const TheKeyType& theKey2) const + { + return myHasher(theKey1, theKey2); + } + + size_t HashCode(const TheKeyType& theKey, + const int theUpperBound) const + { + return myHasher(theKey) % theUpperBound + 1; + } +protected: + + Hasher myHasher; }; #endif diff --git a/src/NCollection/NCollection_OccAllocator.hxx b/src/NCollection/NCollection_OccAllocator.hxx new file mode 100644 index 0000000000..3d5e674cc7 --- /dev/null +++ b/src/NCollection/NCollection_OccAllocator.hxx @@ -0,0 +1,215 @@ +// Copyright (c) 2023 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _NCollection_OccAllocator_HeaderFile +#define _NCollection_OccAllocator_HeaderFile + +#include +#include + +#include + +//! Implements allocator requirements as defined in ISO C++ Standard 2003, section 20.1.5. +/*! The allocator uses a standard OCCT mechanism for memory + allocation and deallocation. It can be used with standard + containers (std::vector, std::map, etc.) to take advantage of OCCT memory optimizations. + + Example of use: + \code + NCollection_OccAllocator anSAllocator(); + std::list> aList(anSAllocator); + TopoDS_Solid aSolid = BRepPrimAPI_MakeBox(10., 20., 30.); + aList.push_back(aSolid); + \endcode +*/ +template +class NCollection_OccAllocator +{ +public: + + typedef ItemType value_type; + typedef value_type* pointer; + typedef const value_type* const_pointer; + typedef value_type& reference; + typedef const value_type& const_reference; + typedef size_t size_type; + typedef ptrdiff_t difference_type; + typedef std::false_type propagate_on_container_move_assignment; // std::false_type + + template + struct rebind + { + typedef NCollection_OccAllocator other; + }; + + //! Constructor. + //! Creates an object using the default Open CASCADE allocation mechanism, i.e., which uses + //! Standard::Allocate() and Standard::Free() underneath. + NCollection_OccAllocator() : + myAllocator(nullptr) + {} + + //! Constructor. + NCollection_OccAllocator(const Handle(NCollection_BaseAllocator)& theAlloc) : + myAllocator(theAlloc) + {} + + //! Constructor. + NCollection_OccAllocator(Handle(NCollection_BaseAllocator)&& theAlloc) : + myAllocator(theAlloc) + {} + + //! Constructor. + NCollection_OccAllocator(const NCollection_OccAllocator& theOther) : + myAllocator(theOther.myAllocator) + {} + + //! Constructor. + NCollection_OccAllocator(NCollection_OccAllocator&& theOther) noexcept : + myAllocator(theOther.myAllocator) + {} + + //! Assignment operator + NCollection_OccAllocator& operator=(const NCollection_OccAllocator& theOther) + { + myAllocator = theOther.myAllocator; + return *this; + } + + //! Assignment operator + NCollection_OccAllocator& operator=(NCollection_OccAllocator&& theOther) noexcept + { + myAllocator = theOther.myAllocator; + return *this; + } + + //! Assignment operator + template + NCollection_OccAllocator& operator=(const NCollection_OccAllocator& theOther) + { + myAllocator = theOther.myAllocator; + return *this; + } + + //! Constructor. + //! Creates an object using the default Open CASCADE allocation mechanism, i.e., which uses + //! Standard::Allocate() and Standard::Free() underneath. + template + NCollection_OccAllocator(const NCollection_OccAllocator& theOther) : + myAllocator(theOther.Allocator()) + {} + + void SetAllocator(const Handle(NCollection_BaseAllocator)& theAlloc) + { + myAllocator = theAlloc; + } + + const Handle(NCollection_BaseAllocator)& Allocator() const + { + return myAllocator; + } + + //! Allocates memory for theSize objects. + pointer allocate(size_type theSize, const void* = 0) + { + return static_cast (myAllocator.IsNull() ? + Standard::AllocateOptimal(theSize * sizeof(ItemType)) : + myAllocator->AllocateOptimal(theSize * sizeof(ItemType))); + } + + //! Template version of function Free(), nullifies the argument pointer + //! @param thePtr - previously allocated memory block to be freed + template + void deallocate(T* thePnt, size_type) + { + myAllocator.IsNull() ? + Standard::Free(thePnt) : + myAllocator->Free(thePnt); + } + + //! Frees previously allocated memory. + void deallocate(pointer thePnt, size_type) + { + myAllocator.IsNull() ? + Standard::Free(thePnt) : + myAllocator->Free(thePnt); + } + + //! Constructs an object. + //! Uses placement new operator and copy constructor to construct an object. + template + void construct(_Objty* _Ptr, _Types&&... _Args) + { + ::new ((void*)_Ptr) _Objty(std::forward<_Types>(_Args)...); + } + + //! Returns an object address. + pointer address(reference theItem) const + { + return &theItem; + } + + //! Returns an object address. + const_pointer address(const_reference theItem) const + { + return &theItem; + } + + //! Destroys the object. + //! Uses the object destructor. + template + void destroy(_Uty* _Ptr) + { + (void)_Ptr; _Ptr->~_Uty(); + } + + //! Estimate maximum array size + size_t max_size() const noexcept + { + return ((size_t)(-1) / sizeof(ItemType)); + } + + bool operator==(const NCollection_OccAllocator& theOther) const + { + return theOther.Allocator() == myAllocator; + } + + template + bool operator==(const NCollection_OccAllocator& theOther) const + { + return theOther.Allocator() == myAllocator; + } + + bool operator!=(const NCollection_OccAllocator& theOther) const + { + return theOther.Allocator() != myAllocator; + } + + template + bool operator!=(const NCollection_OccAllocator& theOther) const + { + return theOther.Allocator() != myAllocator; + } + +private: + + Handle(NCollection_BaseAllocator) myAllocator; +}; + +template +bool operator==(const NCollection_OccAllocator& theFirst, const NCollection_OccAllocator& theSecond) +{ + return theFirst.Allocator() == theSecond.Allocator(); +} + +#endif diff --git a/src/NCollection/NCollection_Sequence.hxx b/src/NCollection/NCollection_Sequence.hxx index 55ef23b88c..de95374fb6 100644 --- a/src/NCollection/NCollection_Sequence.hxx +++ b/src/NCollection/NCollection_Sequence.hxx @@ -21,6 +21,7 @@ #include #include +#include /** * Purpose: Definition of a sequence of elements indexed by @@ -42,6 +43,10 @@ public: Node (const TheItemType& theItem) : NCollection_SeqNode () { myValue = theItem; } + //! Constructor + Node (TheItemType&& theItem) : + NCollection_SeqNode () + { myValue = std::forward(theItem); } //! Constant value access const TheItemType& Value () const { return myValue; } //! Variable value access @@ -118,7 +123,14 @@ public: NCollection_Sequence (const NCollection_Sequence& theOther) : NCollection_BaseSequence(theOther.myAllocator) { - Assign (theOther); + appendSeq((const Node*)theOther.myFirstItem); + } + + //! Move constructor + NCollection_Sequence(NCollection_Sequence&& theOther) noexcept : + NCollection_BaseSequence(theOther.myAllocator) + { + this->operator=(std::forward(theOther)); } //! Number of items @@ -190,6 +202,28 @@ public: return Assign (theOther); } + //! Move operator + NCollection_Sequence& operator= (NCollection_Sequence&& theOther) noexcept + { + if (this == &theOther) + { + return *this; + } + Clear(theOther.myAllocator); + myFirstItem = theOther.myFirstItem; + myLastItem = theOther.myLastItem; + myCurrentItem = theOther.myCurrentItem; + myCurrentIndex = theOther.myCurrentIndex; + mySize = theOther.mySize; + + theOther.myFirstItem = nullptr; + theOther.myLastItem = nullptr; + theOther.myCurrentItem = nullptr; + theOther.myCurrentIndex = 0; + theOther.mySize = 0; + return *this; + } + //! Remove one item void Remove (Iterator& thePosition) { RemoveSeq (thePosition, delNode); } @@ -207,6 +241,10 @@ public: void Append (const TheItemType& theItem) { PAppend (new (this->myAllocator) Node (theItem)); } + //! Append one item + void Append (TheItemType&& theItem) + { PAppend (new (this->myAllocator) Node (std::forward(theItem))); } + //! Append another sequence (making it empty) void Append (NCollection_Sequence& theSeq) { @@ -230,6 +268,10 @@ public: void Prepend (const TheItemType& theItem) { PPrepend (new (this->myAllocator) Node (theItem)); } + //! Prepend one item + void Prepend (TheItemType&& theItem) + { PPrepend (new (this->myAllocator) Node (std::forward(theItem))); } + //! Prepend another sequence (making it empty) void Prepend (NCollection_Sequence& theSeq) { @@ -254,6 +296,11 @@ public: const TheItemType& theItem) { InsertAfter (theIndex-1, theItem); } + //! InsertBefore theIndex theItem + void InsertBefore (const Standard_Integer theIndex, + TheItemType&& theItem) + { InsertAfter (theIndex-1, theItem); } + //! InsertBefore theIndex another sequence (making it empty) void InsertBefore (const Standard_Integer theIndex, NCollection_Sequence& theSeq) @@ -264,6 +311,11 @@ public: const TheItemType& theItem) { PInsertAfter (thePosition, new (this->myAllocator) Node (theItem)); } + //! InsertAfter the position of iterator + void InsertAfter (Iterator& thePosition, + TheItemType&& theItem) + { PInsertAfter (thePosition, new (this->myAllocator) Node (theItem)); } + //! InsertAfter theIndex another sequence (making it empty) void InsertAfter (const Standard_Integer theIndex, NCollection_Sequence& theSeq) @@ -292,6 +344,14 @@ public: PInsertAfter (theIndex, new (this->myAllocator) Node (theItem)); } + //! InsertAfter theIndex theItem + void InsertAfter (const Standard_Integer theIndex, + TheItemType&& theItem) + { + Standard_OutOfRange_Raise_if (theIndex < 0 || theIndex > mySize, "NCollection_Sequence::InsertAfter"); + PInsertAfter (theIndex, new (this->myAllocator) Node (theItem)); + } + //! Split in two sequences void Split (const Standard_Integer theIndex, NCollection_Sequence& theSeq) { diff --git a/src/NCollection/NCollection_SparseArrayBase.hxx b/src/NCollection/NCollection_SparseArrayBase.hxx index ce5087d63b..b5308bfcbe 100644 --- a/src/NCollection/NCollection_SparseArrayBase.hxx +++ b/src/NCollection/NCollection_SparseArrayBase.hxx @@ -72,7 +72,7 @@ private: typedef unsigned char Cell; //!< type of items used to hold bits //! Number of bits in each cell - static Standard_Size BitsPerCell() { return sizeof(Cell) * 8/*BITSPERBYTE*/; } + static Standard_Size BitsPerCell() { return sizeof(Cell) * 8; } public: diff --git a/src/NCollection/NCollection_StdAllocator.hxx b/src/NCollection/NCollection_StdAllocator.hxx deleted file mode 100755 index 4aea7f21a5..0000000000 --- a/src/NCollection/NCollection_StdAllocator.hxx +++ /dev/null @@ -1,177 +0,0 @@ -// Author: Roman Lygin, 2012. -// This file is in the Public Domain and thus can freely be used for any purpose. -// The author disclaims any rights and liabilities. - -#ifndef _NCollection_StdAllocator_HeaderFile -#define _NCollection_StdAllocator_HeaderFile - -#include - -#if _MSC_VER - //Workaround for false "unreferenced parameter" warning in destroy(). - #pragma warning (push) - #pragma warning (disable: 4100) -#endif - -//! Implements allocator requirements as defined in ISO C++ Standard 2003, section 20.1.5. -/*! The allocator uses instance of the NCollection_BaseAllocator (sub)class for memory - allocation/deallocation. The allocator can be used with standard - containers (std::vector, std::map, etc) to take advantage of NCollection_IncAllocator - which implements memory region concept, and hence to increase performance in specific - cases. - - The underlying NCollection_BaseAllocator instance can be received using the Allocator() - method. - - Example of use: - \code - Handle(NCollection_IncAllocator) anIncAlloc = new NCollection_IncAllocator(); - NCollection_StdAllocator aSAlloc (anIncAlloc); - std::list > aL (aSAlloc); - TopoDS_Solid aSolid = BRepPrimAPI_MakeBox (10., 20., 30.); - aL.push_back (aSolid); - \endcode -*/ -template -class NCollection_StdAllocator { -public: - typedef T value_type; - typedef value_type* pointer; - typedef const value_type* const_pointer; - typedef value_type& reference; - typedef const value_type& const_reference; - typedef size_t size_type; - typedef ptrdiff_t difference_type; - template struct rebind { - typedef NCollection_StdAllocator other; - }; - - //! Constructor. - /*! Creates an object using default Open CASCADE allocation mechanism, i.e. which uses - Standard::Allocate() and Standard::Free() underneath. - */ - NCollection_StdAllocator() - { myAlloc = NCollection_BaseAllocator::CommonBaseAllocator(); } - - //! Constructor. - /*! Saves \a theAlloc as an underlying allocator instance.*/ - NCollection_StdAllocator( const Handle(NCollection_BaseAllocator)& theAlloc) - { myAlloc = theAlloc; } - - //! Copy constructor. - /*! Copies Allocator() from \a Y.*/ - template NCollection_StdAllocator( const NCollection_StdAllocator& Y) - { myAlloc = Y.Allocator(); } - - //! Assignment operator - template NCollection_StdAllocator& operator= (const NCollection_StdAllocator& Y) - { myAlloc = Y.Allocator(); return *this; } - - //! Returns an object address. - /*! Returns &x.*/ - pointer address( reference x ) const { return &x; } - - //! Returns an object address. - /*! Returns &x.*/ - const_pointer address( const_reference x ) const { return &x; } - - //! Allocates memory for \a n objects. - /*! Uses underlying allocator to allocate memory.*/ - pointer allocate( size_type n, const void* /*hint*/ = 0 ) - { return pointer( myAlloc->Allocate( n * sizeof( value_type ))); } - - //! Frees previously allocated memory. - /*! Uses underlying allocator to deallocate memory.*/ - void deallocate( pointer p, size_type ) { myAlloc->Free( p ); } - - //! Returns the largest value for which method allocate might succeed. - size_type max_size() const - { - size_type aMax = static_cast( -1 ) / sizeof( value_type ); - return aMax; - } - - //! Constructs an object. - /*! Uses placement new operator and copy constructor to construct an object.*/ - void construct( pointer p, const_reference val ) - { new( static_cast( p )) value_type( val ); } - - //! Destroys the object. - /*! Uses object destructor.*/ - void destroy( pointer p ) { p->~value_type(); } - - //! Returns an underlying NCollection_BaseAllocator instance. - /*! Returns an object specified in the constructor.*/ - const Handle(NCollection_BaseAllocator)& Allocator() const { return myAlloc; } - -protected: - Handle(NCollection_BaseAllocator) myAlloc; -}; - -#if _MSC_VER - #pragma warning (pop) -#endif - - -//! Implements specialization NCollection_StdAllocator. -/*! Specialization is of low value and should normally be avoided in favor of a typed specialization. - - Example of use: - \code - Handle(NCollection_IncAllocator) anIncAlloc = new NCollection_IncAllocator(); - NCollection_StdAllocator aVAlloc (anIncAlloc); - std::vector > aV3 (aVAlloc); - aV3.push_back (10.); - \endcode -*/ -template<> -class NCollection_StdAllocator { -public: - typedef void* pointer; - typedef const void* const_pointer; - typedef void value_type; - template struct rebind { - typedef NCollection_StdAllocator other; - }; - - //! Constructor. - /*! Creates an object using default Open CASCADE allocation mechanism, i.e. which uses - Standard::Allocate() and Standard::Free() underneath. - */ - NCollection_StdAllocator() - { myAlloc = NCollection_BaseAllocator::CommonBaseAllocator(); } - - //! Constructor. - /*! Saves \a theAlloc as an underlying allocator instance.*/ - NCollection_StdAllocator( const Handle(NCollection_BaseAllocator)& theAlloc) - { myAlloc = theAlloc; } - - //! Constructor. - /*! Copies Allocator() from \a X.*/ - NCollection_StdAllocator( const NCollection_StdAllocator& X) { myAlloc = X.myAlloc; } - - //! Returns an underlying NCollection_BaseAllocator instance. - /*! Returns an object specified in the constructor.*/ - const Handle(NCollection_BaseAllocator)& Allocator() const { return myAlloc; } - - //! Assignment operator - NCollection_StdAllocator& operator=(const NCollection_StdAllocator& X) - { - myAlloc = X.myAlloc; - return *this; - } - -protected: - Handle(NCollection_BaseAllocator) myAlloc; -}; - -template -inline bool operator==( const NCollection_StdAllocator& X, const NCollection_StdAllocator& Y) -{ return !!(X.Allocator() == Y.Allocator()); } - -template -inline bool operator!=( const NCollection_StdAllocator& X, const NCollection_StdAllocator& Y) -{ return !(X == Y); } - - -#endif diff --git a/src/NCollection/NCollection_TListNode.hxx b/src/NCollection/NCollection_TListNode.hxx index 2bbe687fa3..4a0ef6072a 100644 --- a/src/NCollection/NCollection_TListNode.hxx +++ b/src/NCollection/NCollection_TListNode.hxx @@ -17,6 +17,7 @@ #define NCollection_TListNode_HeaderFile #include +#include /** * Purpose: Abstract list node class. Used by BaseList @@ -30,6 +31,9 @@ template class NCollection_TListNode NCollection_TListNode (const TheItemType& theItem, NCollection_ListNode* theNext=NULL) : NCollection_ListNode (theNext), myValue(theItem) { } + NCollection_TListNode (TheItemType&& theItem, + NCollection_ListNode* theNext=NULL) : + NCollection_ListNode (theNext), myValue(std::forward(theItem)) { } //! Constant value access const TheItemType& Value () const { return myValue; } //! Variable value access diff --git a/src/NCollection/NCollection_UBTreeFiller.hxx b/src/NCollection/NCollection_UBTreeFiller.hxx index 04e7b39c15..d2ad00555e 100644 --- a/src/NCollection/NCollection_UBTreeFiller.hxx +++ b/src/NCollection/NCollection_UBTreeFiller.hxx @@ -48,7 +48,7 @@ template class NCollection_UBTreeFiller //! UBTree algorithm typedef NCollection_UBTree UBTree; - typedef TYPENAME UBTree::TreeNode UBTreeNode; + typedef typename UBTree::TreeNode UBTreeNode; // ---------- PUBLIC METHODS ---------- @@ -198,7 +198,7 @@ Standard_Integer NCollection_UBTreeFiller::CheckTree template Standard_Real NCollection_UBTreeFiller::checkNode - (const TYPENAME NCollection_UBTree::TreeNode& theNode, + (const typename NCollection_UBTree::TreeNode& theNode, const Standard_Integer theLength, Standard_Integer& theNumber) { diff --git a/src/NCollection/NCollection_Vector.hxx b/src/NCollection/NCollection_Vector.hxx index 6ef85c74ac..6386b03b52 100755 --- a/src/NCollection/NCollection_Vector.hxx +++ b/src/NCollection/NCollection_Vector.hxx @@ -16,12 +16,11 @@ #ifndef NCollection_Vector_HeaderFile #define NCollection_Vector_HeaderFile -#include -#include +#include //! Class NCollection_Vector (dynamic array of objects) //! -//! This class is similar to NCollection_Array1 though the indices always start +//! This class is similar to NCollection_Vector though the indices always start //! at 0 (in Array1 the first index must be specified) //! //! The Vector is always created with 0 length. It can be enlarged by two means: @@ -41,351 +40,6 @@ //! at index 0 and stops at the index equal to (remembered_length-1). It is OK //! to enlarge the vector during the iteration. template -class NCollection_Vector : public NCollection_BaseVector -{ -public: - //! STL-compliant typedef for value type - typedef TheItemType value_type; - -public: - - //! Nested class Iterator - class Iterator : public NCollection_BaseVector::Iterator - { - public: - - //! Empty constructor - for later Init - Iterator() {} - - //! Constructor with initialisation - Iterator (const NCollection_Vector& theVector, Standard_Boolean theToEnd = Standard_False) - : NCollection_BaseVector::Iterator (theVector, theToEnd) {} - - //! Initialisation - void Init (const NCollection_Vector& theVector) - { - initV (theVector); - } - - //! Check end - Standard_Boolean More() const - { - return moreV(); - } - - //! Increment operator. - void Next() - { - nextV(); - } - - //! Decrement operator. - void Previous() - { - prevV(); - } - - //! Offset operator. - void Offset (ptrdiff_t theOffset) - { - offsetV (static_cast(theOffset)); - } - - // Workaround for a bug (endless compilation) occurred in MS Visual Studio 2019 / Win32 / Release configuration - // with DISABLED Whole Program Optimization (as it is by default in OCCT). The problem is - // at the line std::stable_sort(aPairList.begin(), aPairList.end(), BRepExtrema_CheckPair_Comparator); - // of BRepExtrema_DistShapeShape.cxx source file. - // To enable Whole Program Optimization use command line keys: /GL for compiler and /LTCG for linker. - // Remove this workaround after the bug in VS2019 will be fixed (see OCCT bug #0031628). -#if defined (_MSC_VER) && (_MSC_VER >= 1920) && !defined (_WIN64) && !defined (_DEBUG) - __declspec(noinline) __declspec(deprecated("TODO remove this workaround for VS2019 compiler hanging bug")) -#endif - //! Difference operator. - ptrdiff_t Differ (const Iterator& theOther) const - { - return differV (theOther); - } - - //! Constant value access - const TheItemType& Value() const - { - return ((const TheItemType* )curBlockV()->DataPtr)[myCurIndex]; - } - - //! Variable value access - TheItemType& ChangeValue() const - { - return ((TheItemType* )curBlockV()->DataPtr)[myCurIndex]; - } - - //! Performs comparison of two iterators. - Standard_Boolean IsEqual (const Iterator& theOther) const - { - return myVector == theOther.myVector - && myCurIndex == theOther.myCurIndex - && myEndIndex == theOther.myEndIndex - && myICurBlock == theOther.myICurBlock - && myIEndBlock == theOther.myIEndBlock; - } - }; - - //! Shorthand for a regular iterator type. - typedef NCollection_StlIterator iterator; - - //! Shorthand for a constant iterator type. - typedef NCollection_StlIterator const_iterator; - - //! Returns an iterator pointing to the first element in the vector. - iterator begin() const { return Iterator (*this, false); } - - //! Returns an iterator referring to the past-the-end element in the vector. - iterator end() const { return Iterator (*this, true); } - - //! Returns a const iterator pointing to the first element in the vector. - const_iterator cbegin() const { return Iterator (*this, false); } - - //! Returns a const iterator referring to the past-the-end element in the vector. - const_iterator cend() const { return Iterator (*this, true); } - -public: //! @name public methods - - //! Constructor - explicit NCollection_Vector (const Standard_Integer theIncrement = 256, - const Handle(NCollection_BaseAllocator)& theAlloc = NULL) : - NCollection_BaseVector (theAlloc, initMemBlocks, sizeof(TheItemType), theIncrement) - {} - - //! Copy constructor - NCollection_Vector (const NCollection_Vector& theOther) : - NCollection_BaseVector (theOther.myAllocator, initMemBlocks, theOther) - { - copyData (theOther); - } - - //! Destructor - virtual ~NCollection_Vector() - { - for (Standard_Integer anItemIter = 0; anItemIter < myCapacity; ++anItemIter) - { - initMemBlocks (*this, myData[anItemIter], 0, 0); - } - this->myAllocator->Free (myData); - } - - //! Total number of items - Standard_Integer Length() const - { - return myLength; - } - - //! Total number of items in the vector - Standard_Integer Size() const - { - return myLength; - } - - //! Method for consistency with other collections. - //! @return Lower bound (inclusive) for iteration. - Standard_Integer Lower() const - { - return 0; - } - - //! Method for consistency with other collections. - //! @return Upper bound (inclusive) for iteration. - Standard_Integer Upper() const - { - return myLength - 1; - } - - //! Empty query - Standard_Boolean IsEmpty() const - { - return (myLength == 0); - } - - //! Assignment to the collection of the same type - inline void Assign (const NCollection_Vector& theOther, - const Standard_Boolean theOwnAllocator = Standard_True); - - //! Assignment operator - NCollection_Vector& operator= (const NCollection_Vector& theOther) - { - Assign (theOther, Standard_False); - return *this; - } - - //! Append - TheItemType& Append (const TheItemType& theValue) - { - TheItemType& anAppended = *(TheItemType* )expandV (myLength); - anAppended = theValue; - return anAppended; - } - - //! Appends an empty value and returns the reference to it - TheItemType& Appended () - { - TheItemType& anAppended = *(TheItemType* )expandV (myLength); - return anAppended; - } - - //! Operator() - query the const value - const TheItemType& operator() (const Standard_Integer theIndex) const - { - return Value (theIndex); - } - - //! Operator[] - query the const value - const TheItemType& operator[] (Standard_Integer theIndex) const { return Value (theIndex); } - - const TheItemType& Value (const Standard_Integer theIndex) const - { - return *(const TheItemType* )findV (theIndex); - } - - //! @return first element - const TheItemType& First() const - { - return *(const TheItemType* )findV (Lower()); - } - - //! @return first element - TheItemType& ChangeFirst() - { - return *(TheItemType* )findV (Lower()); - } - - //! @return last element - const TheItemType& Last() const - { - return *(const TheItemType* )findV (Upper()); - } - - //! @return last element - TheItemType& ChangeLast() - { - return *(TheItemType* )findV (Upper()); - } - - //! Operator() - query the value - TheItemType& operator() (const Standard_Integer theIndex) - { - return ChangeValue (theIndex); - } - - //! Operator[] - query the value - TheItemType& operator[] ( Standard_Integer theIndex) { return ChangeValue (theIndex); } - - TheItemType& ChangeValue (const Standard_Integer theIndex) - { - return *(TheItemType* )findV (theIndex); - } - - //! SetValue () - set or append a value - TheItemType& SetValue (const Standard_Integer theIndex, - const TheItemType& theValue) - { - Standard_OutOfRange_Raise_if (theIndex < 0, "NCollection_Vector::SetValue"); - TheItemType* const aVecValue = (TheItemType* )(theIndex < myLength ? findV (theIndex) : expandV (theIndex)); - *aVecValue = theValue; - return *aVecValue; - } - -private: //! @name private methods - - void copyData (const NCollection_Vector& theOther) - { - Standard_Integer iBlock = 0; - /*NCollection_Vector::*/Iterator anIter (theOther); - for (Standard_Integer aLength = 0; aLength < myLength; aLength += myIncrement) - { - MemBlock& aBlock = myData[iBlock]; - initMemBlocks (*this, aBlock, aLength, myIncrement); - Standard_Integer anItemIter = 0; - for (; anItemIter < myIncrement; ++anItemIter) - { - if (!anIter.More()) - { - break; - } - - ((TheItemType* )aBlock.DataPtr)[anItemIter] = anIter.Value(); - anIter.Next(); - } - aBlock.Length = anItemIter; - iBlock++; - } - } - - //! Method to initialize memory block content - static void initMemBlocks (NCollection_BaseVector& theVector, - NCollection_BaseVector::MemBlock& theBlock, - const Standard_Integer theFirst, - const Standard_Integer theSize) - { - NCollection_Vector& aSelf = static_cast (theVector); - Handle(NCollection_BaseAllocator)& anAllocator = aSelf.myAllocator; - - // release current content - if (theBlock.DataPtr != NULL) - { - for (Standard_Integer anItemIter = 0; anItemIter < theBlock.Size; ++anItemIter) - { - ((TheItemType* )theBlock.DataPtr)[anItemIter].~TheItemType(); - } - anAllocator->Free (theBlock.DataPtr); - theBlock.DataPtr = NULL; - } - - // allocate new content if requested - if (theSize > 0) - { - theBlock.DataPtr = anAllocator->Allocate (theSize * sizeof(TheItemType)); - for (Standard_Integer anItemIter = 0; anItemIter < theSize; ++anItemIter) - { - new (&((TheItemType* )theBlock.DataPtr)[anItemIter]) TheItemType; - } - } - theBlock.FirstIndex = theFirst; - theBlock.Size = theSize; - theBlock.Length = 0; - } - - friend class Iterator; - -}; - -//! Assignment to the collection of the same type -template inline -void NCollection_Vector::Assign (const NCollection_Vector& theOther, - const Standard_Boolean theOwnAllocator) -{ - if (this == &theOther) - { - return; - } - - // destroy current data using current allocator - for (Standard_Integer anItemIter = 0; anItemIter < myCapacity; ++anItemIter) - { - initMemBlocks (*this, myData[anItemIter], 0, 0); - } - this->myAllocator->Free (myData); - - // allocate memory blocks with new allocator - if (!theOwnAllocator) - { - this->myAllocator = theOther.myAllocator; - } - myIncrement = theOther.myIncrement; - myLength = theOther.myLength; - myNBlocks = (myLength == 0) ? 0 : (1 + (myLength - 1)/myIncrement); - myCapacity = GetCapacity (myIncrement) + myLength / myIncrement; - myData = allocMemBlocks (myCapacity); - - // copy data - copyData (theOther); -} +using NCollection_Vector = NCollection_DynamicArray; #endif // NCollection_Vector_HeaderFile diff --git a/src/NCollection/NCollection_WinHeapAllocator.hxx b/src/NCollection/NCollection_WinHeapAllocator.hxx index 3a10fd226e..ed76f281c3 100644 --- a/src/NCollection/NCollection_WinHeapAllocator.hxx +++ b/src/NCollection/NCollection_WinHeapAllocator.hxx @@ -44,6 +44,9 @@ public: //! Allocate memory Standard_EXPORT virtual void* Allocate (const Standard_Size theSize) Standard_OVERRIDE; + //! Allocate memory + void* AllocateOptimal(const Standard_Size theSize) Standard_OVERRIDE { return Allocate(theSize); } + //! Release memory Standard_EXPORT virtual void Free (void* theAddress) Standard_OVERRIDE; diff --git a/src/OSD/OSD.cxx b/src/OSD/OSD.cxx index c150fe7e87..a2fbb7d05b 100644 --- a/src/OSD/OSD.cxx +++ b/src/OSD/OSD.cxx @@ -14,6 +14,8 @@ #include +#include + //======================================================================= //function : RealToCString //purpose : diff --git a/src/OSD/OSD_FileSystem.hxx b/src/OSD/OSD_FileSystem.hxx index d88f91f74d..6bf4c38c56 100644 --- a/src/OSD/OSD_FileSystem.hxx +++ b/src/OSD/OSD_FileSystem.hxx @@ -16,6 +16,7 @@ #include #include +#include //! Base interface for a file stream provider. //! It is intended to be implemented for specific file protocol. diff --git a/src/OSD/OSD_MemInfo.hxx b/src/OSD/OSD_MemInfo.hxx index 6545ade300..ea2c4e48cb 100644 --- a/src/OSD/OSD_MemInfo.hxx +++ b/src/OSD/OSD_MemInfo.hxx @@ -16,7 +16,6 @@ #ifndef OSD_MemInfo_HeaderFile #define OSD_MemInfo_HeaderFile -#include #include //! This class provide information about memory utilized by current process. diff --git a/src/OSD/OSD_SharedLibrary.cxx b/src/OSD/OSD_SharedLibrary.cxx index b4adda843d..9748d00049 100644 --- a/src/OSD/OSD_SharedLibrary.cxx +++ b/src/OSD/OSD_SharedLibrary.cxx @@ -20,6 +20,8 @@ #include #include +#include + #ifdef __some_crappy_system__ /* * Values for 'mode' argument in dlopen(). diff --git a/src/OSD/OSD_SharedLibrary.hxx b/src/OSD/OSD_SharedLibrary.hxx index 212d25766b..eb5fd6c9b3 100644 --- a/src/OSD/OSD_SharedLibrary.hxx +++ b/src/OSD/OSD_SharedLibrary.hxx @@ -20,7 +20,6 @@ #include #include -#include #include #include #include diff --git a/src/OSD/OSD_ThreadFunction.hxx b/src/OSD/OSD_ThreadFunction.hxx index 9b30d160b2..e327183e73 100644 --- a/src/OSD/OSD_ThreadFunction.hxx +++ b/src/OSD/OSD_ThreadFunction.hxx @@ -16,7 +16,6 @@ #ifndef OSD_ThreadFunction_HeaderFile #define OSD_ThreadFunction_HeaderFile -#include //! Typedef for prototype of function to be used as main function of a thread. //! diff --git a/src/OpenGl/OpenGl_LayerList.hxx b/src/OpenGl/OpenGl_LayerList.hxx index db90dc0bf7..442364334d 100644 --- a/src/OpenGl/OpenGl_LayerList.hxx +++ b/src/OpenGl/OpenGl_LayerList.hxx @@ -134,6 +134,7 @@ protected: class OpenGl_LayerStack { public: + typedef NCollection_Array1::const_iterator const_iterator; typedef NCollection_Array1::iterator iterator; //! Reallocate internal buffer of the stack. @@ -148,7 +149,7 @@ protected: else { NCollection_Array1 aDummy; - myStackSpace.Move (aDummy); + myStackSpace.Move (std::move(aDummy)); myBackPtr = iterator(); } } @@ -164,11 +165,14 @@ protected: void Push (const OpenGl_Layer* theLayer) { (*myBackPtr++) = theLayer; } //! Returns iterator to the origin of the stack. - iterator Origin() const { return myStackSpace.IsEmpty() ? iterator() : myStackSpace.begin(); } + const_iterator Origin() const { return myStackSpace.IsEmpty() ? const_iterator() : myStackSpace.begin(); } //! Returns iterator to the back of the stack (after last item added). iterator Back() const { return myBackPtr; } + //! Returns iterator to the origin of the stack. + iterator Origin() { return myStackSpace.IsEmpty() ? iterator() : myStackSpace.begin(); } + //! Returns true if nothing has been pushed into the stack. Standard_Boolean IsEmpty() const { return Back() == Origin(); } diff --git a/src/OpenGl/OpenGl_SceneGeometry.cxx b/src/OpenGl/OpenGl_SceneGeometry.cxx index a8ceb444b2..9586e35e8a 100644 --- a/src/OpenGl/OpenGl_SceneGeometry.cxx +++ b/src/OpenGl/OpenGl_SceneGeometry.cxx @@ -156,12 +156,12 @@ void OpenGl_RaytraceGeometry::Clear() BVH_Geometry::BVH_Geometry::Clear(); std::vector > anEmptySources; + NCollection_OccAllocator > anEmptySources; Sources.swap (anEmptySources); std::vector > anEmptyMaterials; + NCollection_OccAllocator > anEmptyMaterials; Materials.swap (anEmptyMaterials); } diff --git a/src/OpenGl/OpenGl_SceneGeometry.hxx b/src/OpenGl/OpenGl_SceneGeometry.hxx index 05705962f5..35298bf60d 100644 --- a/src/OpenGl/OpenGl_SceneGeometry.hxx +++ b/src/OpenGl/OpenGl_SceneGeometry.hxx @@ -19,7 +19,7 @@ #include #include #include -#include +#include #include #include @@ -187,11 +187,11 @@ public: //! Array of properties of light sources. std::vector > Sources; + NCollection_OccAllocator > Sources; //! Array of 'front' material properties. std::vector > Materials; + NCollection_OccAllocator > Materials; //! Global ambient from all light sources. BVH_Vec4f Ambient; @@ -217,7 +217,7 @@ public: void ClearMaterials() { std::vector > anEmptyMaterials; + NCollection_OccAllocator > anEmptyMaterials; Materials.swap (anEmptyMaterials); diff --git a/src/PCDM/PCDM_ReaderFilter.hxx b/src/PCDM/PCDM_ReaderFilter.hxx index 38ee609ff4..fc64068e4c 100644 --- a/src/PCDM/PCDM_ReaderFilter.hxx +++ b/src/PCDM/PCDM_ReaderFilter.hxx @@ -17,6 +17,7 @@ #include #include #include +#include #include class PCDM_ReaderFilter; diff --git a/src/Plate/Plate_Plate.hxx b/src/Plate/Plate_Plate.hxx index 0a0594836c..dcee5a5012 100644 --- a/src/Plate/Plate_Plate.hxx +++ b/src/Plate/Plate_Plate.hxx @@ -22,7 +22,6 @@ #include #include -#include #include #include #include diff --git a/src/Plugin/Plugin_MapOfFunctions.hxx b/src/Plugin/Plugin_MapOfFunctions.hxx index b863b6197b..cd8b9ddaaa 100644 --- a/src/Plugin/Plugin_MapOfFunctions.hxx +++ b/src/Plugin/Plugin_MapOfFunctions.hxx @@ -21,8 +21,8 @@ #include #include -typedef NCollection_DataMap Plugin_MapOfFunctions; -typedef NCollection_DataMap::Iterator Plugin_DataMapIteratorOfMapOfFunctions; +typedef NCollection_DataMap Plugin_MapOfFunctions; +typedef NCollection_DataMap::Iterator Plugin_DataMapIteratorOfMapOfFunctions; #endif diff --git a/src/Poly/Poly_MakeLoops.cxx b/src/Poly/Poly_MakeLoops.cxx index 8bf6c3e282..471c73aefe 100644 --- a/src/Poly/Poly_MakeLoops.cxx +++ b/src/Poly/Poly_MakeLoops.cxx @@ -171,7 +171,7 @@ Standard_Integer Poly_MakeLoops::Perform() { Standard_Integer aIndexS = myStartIndices.Top(); - aTempAlloc->Reset(); + aTempAlloc->Reset(false); NCollection_IndexedMap aContour (100, aTempAlloc); Standard_Integer aStartNumber = findContour (aIndexS, aContour, aTempAlloc, aTempAlloc1); #ifdef OCCT_DEBUG @@ -264,7 +264,7 @@ Standard_Integer Poly_MakeLoops::findContour // collect the list of links from this node able to participate // in this contour - theTempAlloc1->Reset(); + theTempAlloc1->Reset(false); NCollection_List aLstIndS (theTempAlloc1); const ListOfLink& aLinks = myHelper->GetAdjacentLinks (aLastNode); Poly_MakeLoops::ListOfLink::Iterator itLinks (aLinks); diff --git a/src/Poly/Poly_MakeLoops.hxx b/src/Poly/Poly_MakeLoops.hxx index 25f6539cf9..337ae81927 100644 --- a/src/Poly/Poly_MakeLoops.hxx +++ b/src/Poly/Poly_MakeLoops.hxx @@ -21,6 +21,8 @@ #include #include #include +#include +#include /** @@ -70,6 +72,31 @@ public: { return node1 == 0 || node2 == 0; } + + bool operator==(const Link& theOther) const + { + return (theOther.node1 == node1 && theOther.node2 == node2) || + (theOther.node1 == node2 && theOther.node2 == node1); + } + }; + + struct Hasher + { + size_t operator()(const Poly_MakeLoops::Link& theLink) const noexcept + { + // Combine two int values into a single hash value. + int aCombination[2]{ theLink.node1, theLink.node2 }; + if (aCombination[0] > aCombination[1]) + { + std::swap(aCombination[0], aCombination[1]); + } + return opencascade::hashBytes(aCombination, sizeof(aCombination)); + } + + bool operator()(const Poly_MakeLoops::Link& theLink1, const Poly_MakeLoops::Link& theLink2) const noexcept + { + return theLink1 == theLink2; + } }; // Define the Loop as a list of links @@ -242,32 +269,13 @@ private: // FIELDS const Helper* myHelper; - Handle(NCollection_BaseAllocator) myAlloc; - NCollection_IndexedMap myMapLink; + Handle(NCollection_BaseAllocator) myAlloc; + NCollection_IndexedMap myMapLink; NCollection_Sequence myLoops; HeapOfInteger myStartIndices; TColStd_PackedMapOfInteger myHangIndices; }; -//! Computes a hash code for the given link, in the range [1, theUpperBound] -//! @param theLink the link which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -inline Standard_Integer HashCode (const Poly_MakeLoops::Link& theLink, const Standard_Integer theUpperBound) -{ - return HashCode (theLink.node1 + theLink.node2, theUpperBound); -} - -/** - * IsEqual method is needed for maps - */ -inline Standard_Boolean IsEqual(const Poly_MakeLoops::Link& theKey1, - const Poly_MakeLoops::Link& theKey2) -{ - return ((theKey1.node1 == theKey2.node1 && theKey1.node2 == theKey2.node2) || - (theKey1.node1 == theKey2.node2 && theKey1.node2 == theKey2.node1)); -} - /** * Implementation for 3D space */ @@ -357,4 +365,27 @@ private: Standard_Boolean myRightWay; }; + +namespace std +{ + template <> + struct hash + { + size_t operator()(const Poly_MakeLoops::Link& theLink) const noexcept + { + return Poly_MakeLoops::Hasher{}(theLink); + } + }; + + template<> + struct equal_to + { + bool operator()(const Poly_MakeLoops::Link& theLink1, + const Poly_MakeLoops::Link& theLink2) const noexcept + { + return theLink1 == theLink2; + } + }; +} + #endif diff --git a/src/Poly/Poly_MergeNodesTool.cxx b/src/Poly/Poly_MergeNodesTool.cxx index 40778ad17f..ce4423479b 100644 --- a/src/Poly/Poly_MergeNodesTool.cxx +++ b/src/Poly/Poly_MergeNodesTool.cxx @@ -14,6 +14,7 @@ #include #include +#include #include @@ -87,30 +88,38 @@ void Poly_MergeNodesTool::MergedNodesMap::SetMergeTolerance (double theTolerance // function : MergedNodesMap::hashCode // purpose : // ======================================================================= -inline int Poly_MergeNodesTool::MergedNodesMap::vec3iHashCode (const Poly_MergeNodesTool::MergedNodesMap::CellVec3i& theVec, - const int theUpper) +inline size_t Poly_MergeNodesTool::MergedNodesMap::vec3iHashCode (const Poly_MergeNodesTool::MergedNodesMap::CellVec3i& theVec, + const int theUpper) { // copied from NCollection_CellFilter - const uint64_t aShiftBits = (BITS(int64_t)-1) / 3; + constexpr uint64_t aShiftBits = (CHAR_BIT * sizeof(int64_t)-1) / 3; uint64_t aHashCode = 0; aHashCode = (aHashCode << aShiftBits) ^ theVec[0]; aHashCode = (aHashCode << aShiftBits) ^ theVec[1]; aHashCode = (aHashCode << aShiftBits) ^ theVec[2]; - return IntegerHashCode(aHashCode, 0x7fffffffffffffff, theUpper); + return aHashCode % theUpper + 1; } // ======================================================================= // function : MergedNodesMap::hashCode // purpose : // ======================================================================= -inline int Poly_MergeNodesTool::MergedNodesMap::hashCode (const NCollection_Vec3& thePos, - const NCollection_Vec3& theNorm, - const int theUpper) const +inline size_t Poly_MergeNodesTool::MergedNodesMap::hashCode (const NCollection_Vec3& thePos, + const NCollection_Vec3& theNorm, + const int theUpper) const { (void )theNorm; if (myInvTol <= 0.0f) { - return ::HashCode (::HashCodes ((Standard_CString )&thePos, sizeof(NCollection_Vec3)), theUpper); + // compute DJB2 hash of a string + const size_t aLength = sizeof(NCollection_Vec3); + unsigned int aHashCode = 0; + const Standard_Character* c = (Standard_CString )&thePos; + for (size_t i = 0; i < aLength; ++i, ++c) + { + aHashCode = ((aHashCode << 5) + aHashCode) ^ (*c); + } + return aHashCode % theUpper + 1; } const CellVec3i anIndex = vec3ToCell (thePos); @@ -190,7 +199,7 @@ inline bool Poly_MergeNodesTool::MergedNodesMap::Bind (int& theIndex, } DataMapNode** aData = (DataMapNode** )myData1; - const int aHash = hashCode (thePos, theNorm, NbBuckets()); + const size_t aHash = hashCode (thePos, theNorm, NbBuckets()); for (DataMapNode* aNodeIter = aData[aHash]; aNodeIter != NULL; aNodeIter = (DataMapNode* )aNodeIter->Next()) { @@ -214,7 +223,7 @@ inline bool Poly_MergeNodesTool::MergedNodesMap::Bind (int& theIndex, for (int aNeigIter = 0; aNeigIter < 26; ++aNeigIter) { const CellVec3i anIndex = anIndexCnt + THE_NEIGHBRS[aNeigIter]; - const int aHashEx = vec3iHashCode (anIndex, NbBuckets()); + const size_t aHashEx = vec3iHashCode (anIndex, NbBuckets()); for (DataMapNode* aNodeIter = aData[aHashEx]; aNodeIter != NULL; aNodeIter = (DataMapNode* )aNodeIter->Next()) { @@ -249,7 +258,7 @@ inline void Poly_MergeNodesTool::MergedNodesMap::ReSize (const int theSize) { for (DataMapNode* anOldNodeIter = anOldData[anOldBuckIter]; anOldNodeIter != NULL; ) { - const Standard_Integer aNewHash = hashCode (anOldNodeIter->Key(), aNbNewBuck); + const size_t aNewHash = hashCode (anOldNodeIter->Key(), aNbNewBuck); DataMapNode* aNextNode = (DataMapNode* )anOldNodeIter->Next(); anOldNodeIter->Next() = aNewData[aNewHash]; aNewData[aNewHash] = anOldNodeIter; diff --git a/src/Poly/Poly_MergeNodesTool.hxx b/src/Poly/Poly_MergeNodesTool.hxx index 20f1c83f53..4bc807a7e0 100644 --- a/src/Poly/Poly_MergeNodesTool.hxx +++ b/src/Poly/Poly_MergeNodesTool.hxx @@ -16,6 +16,7 @@ #include #include +#include //! Auxiliary tool for merging triangulation nodes for visualization purposes. //! Tool tries to merge all nodes within input triangulation, but split the ones on sharp corners at specified angle. @@ -280,16 +281,16 @@ private: } //! Hash code for integer vec3. - Standard_EXPORT static int vec3iHashCode (const Poly_MergeNodesTool::MergedNodesMap::CellVec3i& theVec, - const int theUpper); + Standard_EXPORT static size_t vec3iHashCode (const Poly_MergeNodesTool::MergedNodesMap::CellVec3i& theVec, + const int theUpper); //! Compute hash code. - Standard_EXPORT int hashCode (const NCollection_Vec3& thePos, - const NCollection_Vec3& theNorm, - const int theUpper) const; + Standard_EXPORT size_t hashCode (const NCollection_Vec3& thePos, + const NCollection_Vec3& theNorm, + const int theUpper) const; //! Compute hash code. - int hashCode (const Vec3AndNormal& theKey, const int theUpper) const + size_t hashCode (const Vec3AndNormal& theKey, const int theUpper) const { return hashCode (theKey.Pos, theKey.Norm, theUpper); } @@ -317,17 +318,12 @@ private: //! Hasher for merging equal elements (with pre-sorted indexes). struct MergedElemHasher { - static int HashCode (const NCollection_Vec4& theVec, const int theUpper) + size_t operator()(const NCollection_Vec4& theVec) const { - unsigned int aHashCode = 0; - aHashCode = aHashCode ^ ::HashCode (theVec[0], theUpper); - aHashCode = aHashCode ^ ::HashCode (theVec[1], theUpper); - aHashCode = aHashCode ^ ::HashCode (theVec[2], theUpper); - aHashCode = aHashCode ^ ::HashCode (theVec[3], theUpper); - return ((aHashCode & 0x7fffffff) % theUpper) + 1; + return opencascade::hashBytes(&theVec[0], 4 * sizeof(int)); } - static bool IsEqual (const NCollection_Vec4& theKey1, const NCollection_Vec4& theKey2) + bool operator()(const NCollection_Vec4& theKey1, const NCollection_Vec4& theKey2) const { return theKey1.IsEqual (theKey2); } diff --git a/src/QABugs/QABugs_11.cxx b/src/QABugs/QABugs_11.cxx index 56fd7ad067..7c95a8b9e0 100644 --- a/src/QABugs/QABugs_11.cxx +++ b/src/QABugs/QABugs_11.cxx @@ -1188,6 +1188,7 @@ static Standard_Integer OCC369(Draw_Interpretor& di, Standard_Integer argc, cons } #include +#include static Standard_Integer OCC524 (Draw_Interpretor& di, Standard_Integer argc, const char ** argv) { if(argc != 9){ diff --git a/src/QABugs/QABugs_14.cxx b/src/QABugs/QABugs_14.cxx index 2db1f5baf4..59efb0ec7d 100644 --- a/src/QABugs/QABugs_14.cxx +++ b/src/QABugs/QABugs_14.cxx @@ -845,7 +845,6 @@ static Standard_Integer OCC1919_set (Draw_Interpretor& di, Standard_Integer argc } #include #include -#include static Standard_Integer OCC1919_real (Draw_Interpretor& di, Standard_Integer argc, const char ** argv) { if (argc == 4) { diff --git a/src/QABugs/QABugs_20.cxx b/src/QABugs/QABugs_20.cxx index b5e84f0ed2..cd3769d074 100644 --- a/src/QABugs/QABugs_20.cxx +++ b/src/QABugs/QABugs_20.cxx @@ -2624,7 +2624,7 @@ static Standard_Integer OCC29289(Draw_Interpretor&, Standard_Integer , const cha Standard_Boolean IsSameGuid (const Standard_GUID& aGuidNull, const Standard_GUID& aGuid2) { Standard_Boolean isSame (Standard_False); - if(Standard_GUID::IsEqual(aGuidNull, aGuid2)) { + if(aGuidNull == aGuid2) { aGuid2.ShallowDump(std::cout); isSame = Standard_True; } else { diff --git a/src/QADNaming/QADNaming.hxx b/src/QADNaming/QADNaming.hxx index e814905c8f..81a20db898 100644 --- a/src/QADNaming/QADNaming.hxx +++ b/src/QADNaming/QADNaming.hxx @@ -24,7 +24,6 @@ #include #include #include -#include #include class TopoDS_Shape; class TDF_Data; diff --git a/src/QANCollection/QANCollection_Alloc.cxx b/src/QANCollection/QANCollection_Alloc.cxx index 13ab7f28b2..64bb06da0d 100644 --- a/src/QANCollection/QANCollection_Alloc.cxx +++ b/src/QANCollection/QANCollection_Alloc.cxx @@ -16,7 +16,7 @@ #include #include -#include +#include #include #include @@ -36,7 +36,7 @@ static Standard_Integer QANColStdAllocator1(Draw_Interpretor& di, Standard_Integ //type definitions typedef Handle(Standard_Transient) elem_type; - typedef NCollection_StdAllocator allocator_type; + typedef NCollection_OccAllocator allocator_type; Standard_STATIC_ASSERT (sizeof (allocator_type::value_type) == sizeof (elem_type)); Standard_STATIC_ASSERT (sizeof (allocator_type::pointer) == sizeof (void*)); Standard_STATIC_ASSERT (sizeof (allocator_type::const_pointer) == sizeof (void*)); @@ -71,8 +71,8 @@ static Standard_Integer QANColStdAllocator2(Draw_Interpretor& di, Standard_Integ { //typed allocator - NCollection_StdAllocator aSAlloc (anIncAlloc); - std::list > aL (aSAlloc); + NCollection_OccAllocator aSAlloc (anIncAlloc); + std::list > aL (aSAlloc); aL.push_back (2); if ( aL.size() == size_t (1) ) { di << "Test1 : OK\n"; @@ -81,8 +81,8 @@ static Standard_Integer QANColStdAllocator2(Draw_Interpretor& di, Standard_Integ } //type cast - NCollection_StdAllocator aCAlloc; - std::vector > aV (aCAlloc); + NCollection_OccAllocator aCAlloc; + std::vector > aV (aCAlloc); aV.push_back (1); if ( aV.size() == size_t (1) ) { di << "Test2 : OK\n"; @@ -91,8 +91,8 @@ static Standard_Integer QANColStdAllocator2(Draw_Interpretor& di, Standard_Integ } //using void-specialization allocator - NCollection_StdAllocator aVAlloc; - std::vector > aV2 (aVAlloc); + NCollection_OccAllocator aVAlloc; + std::vector > aV2 (aVAlloc); aV2.resize (10); aV2.push_back (-1); @@ -108,7 +108,7 @@ static Standard_Integer QANColStdAllocator2(Draw_Interpretor& di, Standard_Integ } else { di << "Test4 : Error\n"; } - NCollection_StdAllocator anIAlloc (anIncAlloc); + NCollection_OccAllocator anIAlloc (anIncAlloc); if ( aSAlloc == anIAlloc ) { di << "Test5 : OK\n"; } else { diff --git a/src/QANCollection/QANCollection_DataMapOfRealPnt.hxx b/src/QANCollection/QANCollection_DataMapOfRealPnt.hxx index d521cac8fd..b201176b41 100644 --- a/src/QANCollection/QANCollection_DataMapOfRealPnt.hxx +++ b/src/QANCollection/QANCollection_DataMapOfRealPnt.hxx @@ -17,11 +17,10 @@ #define QANCollection_DataMapOfRealPnt_HeaderFile #include -#include #include -typedef NCollection_DataMap QANCollection_DataMapOfRealPnt; -typedef NCollection_DataMap::Iterator QANCollection_DataMapIteratorOfDataMapOfRealPnt; +typedef NCollection_DataMap QANCollection_DataMapOfRealPnt; +typedef NCollection_DataMap::Iterator QANCollection_DataMapIteratorOfDataMapOfRealPnt; #endif diff --git a/src/QANCollection/QANCollection_DoubleMapOfRealInteger.hxx b/src/QANCollection/QANCollection_DoubleMapOfRealInteger.hxx index 23d8ab5f78..07736ee0d9 100644 --- a/src/QANCollection/QANCollection_DoubleMapOfRealInteger.hxx +++ b/src/QANCollection/QANCollection_DoubleMapOfRealInteger.hxx @@ -17,12 +17,10 @@ #define QANCollection_DoubleMapOfRealInteger_HeaderFile #include -#include -#include #include -typedef NCollection_DoubleMap QANCollection_DoubleMapOfRealInteger; -typedef NCollection_DoubleMap::Iterator QANCollection_DoubleMapIteratorOfDoubleMapOfRealInteger; +typedef NCollection_DoubleMap QANCollection_DoubleMapOfRealInteger; +typedef NCollection_DoubleMap::Iterator QANCollection_DoubleMapIteratorOfDoubleMapOfRealInteger; #endif diff --git a/src/QANCollection/QANCollection_Handle.cxx b/src/QANCollection/QANCollection_Handle.cxx index b77bea8f78..89c593e63d 100644 --- a/src/QANCollection/QANCollection_Handle.cxx +++ b/src/QANCollection/QANCollection_Handle.cxx @@ -16,7 +16,7 @@ #include #include -#include +#include #include #include #include diff --git a/src/QANCollection/QANCollection_IndexedDataMapOfRealPnt.hxx b/src/QANCollection/QANCollection_IndexedDataMapOfRealPnt.hxx index ce0500d9e1..33c03c6828 100644 --- a/src/QANCollection/QANCollection_IndexedDataMapOfRealPnt.hxx +++ b/src/QANCollection/QANCollection_IndexedDataMapOfRealPnt.hxx @@ -17,10 +17,9 @@ #define QANCollection_IndexedDataMapOfRealPnt_HeaderFile #include -#include #include -typedef NCollection_IndexedDataMap QANCollection_IndexedDataMapOfRealPnt; +typedef NCollection_IndexedDataMap QANCollection_IndexedDataMapOfRealPnt; #endif diff --git a/src/QANCollection/QANCollection_Perf.cxx b/src/QANCollection/QANCollection_Perf.cxx index 95b08578ad..4803ec82b1 100644 --- a/src/QANCollection/QANCollection_Perf.cxx +++ b/src/QANCollection/QANCollection_Perf.cxx @@ -46,38 +46,50 @@ // So must be defined ::HashCode and ::IsEqual too #include +#define DEFINE_ARRAY1(_ClassName_, _BaseCollection_, TheItemType) \ +typedef NCollection_Array1 _ClassName_; + ////////////////////////////////DEFINE_ARRAY1(QANCollection_Array1,QANCollection_BaseCol,ItemType) ////////////////////////////////DEFINE_HARRAY1(QANCollection_HArray1,QANCollection_Array1) DEFINE_ARRAY1(QANCollection_Array1Perf,QANCollection_BaseColPerf,ItemType) DEFINE_HARRAY1(QANCollection_HArray1Perf,QANCollection_Array1Perf) #include +#define DEFINE_ARRAY2(_ClassName_, _BaseCollection_, TheItemType) \ +typedef NCollection_Array2 _ClassName_; ////////////////////////////////DEFINE_ARRAY2(QANCollection_Array2,QANCollection_BaseCol,ItemType) ////////////////////////////////DEFINE_HARRAY2(QANCollection_HArray2,QANCollection_Array2) DEFINE_ARRAY2(QANCollection_Array2Perf,QANCollection_BaseColPerf,ItemType) DEFINE_HARRAY2(QANCollection_HArray2Perf,QANCollection_Array2Perf) - -#include -#include -#include -#include -#include ////////////////////////////////DEFINE_MAP(QANCollection_Map,QANCollection_Key1BaseCol,Key1Type) ////////////////////////////////DEFINE_DATAMAP(QANCollection_DataMap,QANCollection_BaseCol,Key1Type,ItemType) ////////////////////////////////DEFINE_DOUBLEMAP(QANCollection_DoubleMap,QANCollection_Key2BaseCol,Key1Type,Key2Type) ////////////////////////////////DEFINE_INDEXEDMAP(QANCollection_IndexedMap,QANCollection_Key1BaseCol,Key1Type) ////////////////////////////////DEFINE_INDEXEDDATAMAP(QANCollection_IDMap,QANCollection_BaseCol,Key1Type,ItemType) +#define DEFINE_DATAMAP(_ClassName_, _BaseCollection_, TheKeyType, TheItemType) \ +typedef NCollection_DataMap _ClassName_; +#define DEFINE_DOUBLEMAP(_ClassName_, _BaseCollection_, TheKey1Type, TheKey2Type) \ +typedef NCollection_DoubleMap _ClassName_; +#define DEFINE_INDEXEDDATAMAP(_ClassName_, _BaseCollection_, TheKeyType, TheItemType) \ +typedef NCollection_IndexedDataMap _ClassName_; +#define DEFINE_INDEXEDMAP(_ClassName_, _BaseCollection_, TheKeyType) \ +typedef NCollection_IndexedMap _ClassName_; +#define DEFINE_MAP(_ClassName_, _BaseCollection_, TheKeyType) \ +typedef NCollection_Map _ClassName_; DEFINE_MAP(QANCollection_MapPerf,QANCollection_Key1BaseColPerf,Key1Type) DEFINE_DATAMAP(QANCollection_DataMapPerf,QANCollection_BaseColPerf,Key1Type,ItemType) DEFINE_DOUBLEMAP(QANCollection_DoubleMapPerf,QANCollection_Key2BaseColPerf,Key1Type,Key2Type) DEFINE_INDEXEDMAP(QANCollection_IndexedMapPerf,QANCollection_Key1BaseColPerf,Key1Type) DEFINE_INDEXEDDATAMAP(QANCollection_IDMapPerf,QANCollection_BaseColPerf,Key1Type,ItemType) -#include ////////////////////////////////DEFINE_LIST(QANCollection_List,QANCollection_BaseCol,ItemType) +#define DEFINE_LIST(_ClassName_, _BaseCollection_, TheItemType) \ +typedef NCollection_List _ClassName_; DEFINE_LIST(QANCollection_ListPerf,QANCollection_BaseColPerf,ItemType) #include +#define DEFINE_SEQUENCE(_ClassName_, _BaseCollection_, TheItemType) \ +typedef NCollection_Sequence _ClassName_; ////////////////////////////////DEFINE_SEQUENCE(QANCollection_Sequence,QANCollection_BaseCol,ItemType) ////////////////////////////////DEFINE_HSEQUENCE(QANCollection_HSequence,QANCollection_Sequence) DEFINE_SEQUENCE(QANCollection_SequencePerf,QANCollection_BaseColPerf,ItemType) diff --git a/src/QANCollection/QANCollection_Test.cxx b/src/QANCollection/QANCollection_Test.cxx index b484cafb13..40cc1f261a 100644 --- a/src/QANCollection/QANCollection_Test.cxx +++ b/src/QANCollection/QANCollection_Test.cxx @@ -27,65 +27,68 @@ #include #include +#include #define ItemType gp_Pnt #define Key1Type Standard_Real #define Key2Type Standard_Integer #include +#define DEFINE_ARRAY1(_ClassName_, _BaseCollection_, TheItemType) \ +typedef NCollection_Array1 _ClassName_; ////////////////////////////////DEFINE_ARRAY1(QANCollection_Array1,QANCollection_BaseCol,ItemType) ////////////////////////////////DEFINE_HARRAY1(QANCollection_HArray1,QANCollection_Array1) DEFINE_ARRAY1(QANCollection_Array1Func,QANCollection_BaseColFunc,ItemType) DEFINE_HARRAY1(QANCollection_HArray1Func,QANCollection_Array1Func) #include +#define DEFINE_ARRAY2(_ClassName_, _BaseCollection_, TheItemType) \ +typedef NCollection_Array2 _ClassName_; ////////////////////////////////DEFINE_ARRAY2(QANCollection_Array2,QANCollection_BaseCol,ItemType) ////////////////////////////////DEFINE_HARRAY2(QANCollection_HArray2,QANCollection_Array2) DEFINE_ARRAY2(QANCollection_Array2Func,QANCollection_BaseColFunc,ItemType) DEFINE_HARRAY2(QANCollection_HArray2Func,QANCollection_Array2Func) -#include -#include -#include -#include -#include + ////////////////////////////////DEFINE_MAP(QANCollection_Map,QANCollection_Key1BaseCol,Key1Type) ////////////////////////////////DEFINE_DATAMAP(QANCollection_DataMap,QANCollection_BaseCol,Key1Type,ItemType) ////////////////////////////////DEFINE_DOUBLEMAP(QANCollection_DoubleMap,QANCollection_Key2BaseCol,Key1Type,Key2Type) ////////////////////////////////DEFINE_INDEXEDMAP(QANCollection_IndexedMap,QANCollection_Key1BaseCol,Key1Type) ////////////////////////////////DEFINE_INDEXEDDATAMAP(QANCollection_IDMap,QANCollection_BaseCol,Key1Type,ItemType) +#include +#include +#include +#define DEFINE_DATAMAP(_ClassName_, _BaseCollection_, TheKeyType, TheItemType) \ +typedef NCollection_DataMap _ClassName_; +#define DEFINE_DOUBLEMAP(_ClassName_, _BaseCollection_, TheKey1Type, TheKey2Type) \ +typedef NCollection_DoubleMap _ClassName_; +#define DEFINE_INDEXEDDATAMAP(_ClassName_, _BaseCollection_, TheKeyType, TheItemType) \ +typedef NCollection_IndexedDataMap _ClassName_; +#define DEFINE_INDEXEDMAP(_ClassName_, _BaseCollection_, TheKeyType) \ +typedef NCollection_IndexedMap _ClassName_; +#define DEFINE_MAP(_ClassName_, _BaseCollection_, TheKeyType) \ +typedef NCollection_Map _ClassName_; DEFINE_MAP(QANCollection_MapFunc,QANCollection_Key1BaseColFunc,Key1Type) DEFINE_DATAMAP(QANCollection_DataMapFunc,QANCollection_BaseColFunc,Key1Type,ItemType) DEFINE_DOUBLEMAP(QANCollection_DoubleMapFunc,QANCollection_Key2BaseColFunc,Key1Type,Key2Type) DEFINE_INDEXEDMAP(QANCollection_IndexedMapFunc,QANCollection_Key1BaseColFunc,Key1Type) DEFINE_INDEXEDDATAMAP(QANCollection_IDMapFunc,QANCollection_BaseColFunc,Key1Type,ItemType) -#include ////////////////////////////////DEFINE_LIST(QANCollection_List,QANCollection_BaseCol,ItemType) +#define DEFINE_LIST(_ClassName_, _BaseCollection_, TheItemType) \ +typedef NCollection_List _ClassName_; +DEFINE_LIST(QANCollection_ListPerf,QANCollection_BaseColPerf,ItemType) DEFINE_LIST(QANCollection_ListFunc,QANCollection_BaseColFunc,ItemType) #include +#include +#define DEFINE_SEQUENCE(_ClassName_, _BaseCollection_, TheItemType) \ +typedef NCollection_Sequence _ClassName_; ////////////////////////////////DEFINE_SEQUENCE(QANCollection_Sequence,QANCollection_BaseCol,ItemType) ////////////////////////////////DEFINE_HSEQUENCE(QANCollection_HSequence,QANCollection_Sequence) DEFINE_SEQUENCE(QANCollection_SequenceFunc,QANCollection_BaseColFunc,ItemType) DEFINE_HSEQUENCE(QANCollection_HSequenceFunc,QANCollection_SequenceFunc) -// HashCode and IsEquel must be defined for key types of maps - -//! Computes a hash code for the point, in the range [1, theUpperBound] -//! @param thePoint the point which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -Standard_Integer HashCode (const gp_Pnt& thePoint, int theUpperBound) -{ - return HashCode (thePoint.X(), theUpperBound); -} - -Standard_Boolean IsEqual(const gp_Pnt& theP1, const gp_Pnt& theP2) -{ - return theP1.IsEqual(theP2,gp::Resolution()); -} - ////////////////////////////////void printCollection (QANCollection_Key1BaseCol& aColl, template void printCollection (Coll& aColl, const char * str) diff --git a/src/Quantity/FILES b/src/Quantity/FILES index a566c8fe02..ff72f3eafc 100755 --- a/src/Quantity/FILES +++ b/src/Quantity/FILES @@ -2,10 +2,8 @@ Quantity_Array1OfColor.hxx Quantity_Color.cxx Quantity_Color.hxx Quantity_ColorTable.pxx -Quantity_ColorHasher.hxx Quantity_ColorRGBA.cxx Quantity_ColorRGBA.hxx -Quantity_ColorRGBAHasher.hxx Quantity_Date.cxx Quantity_Date.hxx Quantity_DateDefinitionError.hxx diff --git a/src/Quantity/Quantity_Color.hxx b/src/Quantity/Quantity_Color.hxx index 15451507b3..7cc6b58653 100644 --- a/src/Quantity/Quantity_Color.hxx +++ b/src/Quantity/Quantity_Color.hxx @@ -19,6 +19,7 @@ #include #include #include +#include #include #include @@ -379,4 +380,19 @@ private: }; +namespace std +{ + template <> + struct hash + { + std::size_t operator()(const Quantity_Color& theColor) const noexcept + { + unsigned char aByteArr[3] = { static_cast(255 * theColor.Red()), + static_cast(255 * theColor.Green()), + static_cast(255 * theColor.Blue()) }; + return opencascade::hashBytes(aByteArr, sizeof(aByteArr)); + } + }; +} + #endif // _Quantity_Color_HeaderFile diff --git a/src/Quantity/Quantity_ColorHasher.hxx b/src/Quantity/Quantity_ColorHasher.hxx deleted file mode 100644 index 87010e6b80..0000000000 --- a/src/Quantity/Quantity_ColorHasher.hxx +++ /dev/null @@ -1,62 +0,0 @@ -// Created on: 2016-12-13 -// Copyright (c) 2016 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _Quantity_ColorHasher_HeaderFile -#define _Quantity_ColorHasher_HeaderFile - -#include - -//! Hasher of Quantity_Color. -struct Quantity_ColorHasher -{ - //! Returns hash code for the given RGB color, in the range [1, theUpperBound] - //! @param theColor the RGB color object which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing range must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const Quantity_Color& theColor, - const Standard_Integer theUpperBound) - { - Standard_Integer aRed = Standard_Integer (255 * theColor.Red()); - Standard_Integer aGreen = Standard_Integer (255 * theColor.Green()); - Standard_Integer aBlue = Standard_Integer (255 * theColor.Blue()); - - unsigned int aHash = 0; - - updateHash (aHash, aRed); - updateHash (aHash, aGreen); - updateHash (aHash, aBlue); - aHash += (aHash << 3); - aHash ^= (aHash >> 11); - aHash += (aHash << 15); - - return IntegerHashCode(aHash, 0x7fff, theUpperBound); - } - - //! Returns true if two colors are equal. - static Standard_Boolean IsEqual (const Quantity_Color& theColor1, - const Quantity_Color& theColor2) - { - return theColor1 == theColor2; - } - -protected: - static void updateHash (unsigned int& theHash, const Standard_Integer theValue) - { - theHash += theValue; - theHash += (theHash << 10); - theHash ^= (theHash >> 6); - } -}; - -#endif diff --git a/src/Quantity/Quantity_ColorRGBA.hxx b/src/Quantity/Quantity_ColorRGBA.hxx index ccdc6e6b37..85ad4a4951 100644 --- a/src/Quantity/Quantity_ColorRGBA.hxx +++ b/src/Quantity/Quantity_ColorRGBA.hxx @@ -173,4 +173,20 @@ private: }; +namespace std +{ + template <> + struct hash + { + std::size_t operator()(const Quantity_ColorRGBA& theColor) const noexcept + { + const Quantity_Color& anRGB = theColor.GetRGB(); + unsigned char aByteArr[4] = { static_cast(100 * theColor.Alpha()), + static_cast(255 * anRGB.Red()), + static_cast(255 * anRGB.Green()), + static_cast(255 * anRGB.Blue()) }; + return opencascade::hashBytes(aByteArr, sizeof(aByteArr)); + } + }; +} #endif // _Quantity_ColorRGBA_HeaderFile diff --git a/src/Quantity/Quantity_ColorRGBAHasher.hxx b/src/Quantity/Quantity_ColorRGBAHasher.hxx deleted file mode 100644 index c7c776c018..0000000000 --- a/src/Quantity/Quantity_ColorRGBAHasher.hxx +++ /dev/null @@ -1,48 +0,0 @@ -// Copyright (c) 2017 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _Quantity_ColorRGBAHasher_HeaderFile -#define _Quantity_ColorRGBAHasher_HeaderFile - -#include -#include - -//! Hasher of Quantity_ColorRGBA. -struct Quantity_ColorRGBAHasher -{ - - //! Returns hash code for the given RGBA color, in the range [1, theUpperBound] - //! @param theColor the RGBA color object which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const Quantity_ColorRGBA& theColor, - const Standard_Integer theUpperBound) - { - const NCollection_Vec4& aColor = theColor; - uint32_t aColor32 = (uint32_t(aColor.a() * 255.0f) << 24) - + (uint32_t(aColor.b() * 255.0f) << 16) - + (uint32_t(aColor.g() * 255.0f) << 8) - + uint32_t(aColor.r() * 255.0f); - return ::HashCode(aColor32, theUpperBound); - } - - //! Returns true if two colors are equal. - static Standard_Boolean IsEqual (const Quantity_ColorRGBA& theColor1, - const Quantity_ColorRGBA& theColor2) - { - return theColor1 == theColor2; - } - -}; - -#endif // _Quantity_ColorRGBAHasher_HeaderFile diff --git a/src/RWGltf/RWGltf_CafWriter.cxx b/src/RWGltf/RWGltf_CafWriter.cxx index 24b0e35b3f..aa86708d39 100644 --- a/src/RWGltf/RWGltf_CafWriter.cxx +++ b/src/RWGltf/RWGltf_CafWriter.cxx @@ -626,7 +626,7 @@ bool RWGltf_CafWriter::writeBinData (const Handle(TDocStd_Document)& theDocument }; // dispatch faces - NCollection_DataMap aMergedFaces; + NCollection_DataMap aMergedFaces; for (XCAFPrs_DocumentExplorer aDocExplorer (theDocument, theRootLabels, XCAFPrs_DocumentExplorerFlags_OnlyLeafNodes); aDocExplorer.More() && aPSentryBin.More(); aDocExplorer.Next()) { diff --git a/src/RWGltf/RWGltf_CafWriter.hxx b/src/RWGltf/RWGltf_CafWriter.hxx index be5d05f637..b2cfa9ba91 100644 --- a/src/RWGltf/RWGltf_CafWriter.hxx +++ b/src/RWGltf/RWGltf_CafWriter.hxx @@ -357,25 +357,35 @@ protected: TopoDS_Shape Shape; XCAFPrs_Style Style; - RWGltf_StyledShape() {} - explicit RWGltf_StyledShape (const TopoDS_Shape& theShape) : Shape (theShape) {} - explicit RWGltf_StyledShape (const TopoDS_Shape& theShape, - const XCAFPrs_Style& theStyle) : Shape (theShape), Style (theStyle) {} - public: - //! Computes a hash code. - static Standard_Integer HashCode (const RWGltf_StyledShape& theShape, Standard_Integer theUpperBound) + RWGltf_StyledShape() + {} + explicit RWGltf_StyledShape(const TopoDS_Shape& theShape) : Shape(theShape) + {} + explicit RWGltf_StyledShape(const TopoDS_Shape& theShape, + const XCAFPrs_Style& theStyle) : Shape(theShape), Style(theStyle) + {} + bool operator==(const RWGltf_StyledShape& theStyledShape) const { - return theShape.Shape.HashCode (theUpperBound); - } - //! Equality comparison. - static Standard_Boolean IsEqual (const RWGltf_StyledShape& theS1, const RWGltf_StyledShape& theS2) - { - return theS1.Shape.IsSame (theS2.Shape) - && theS1.Style.IsEqual(theS2.Style); + return Shape.IsSame(theStyledShape.Shape) + && Style.IsEqual(theStyledShape.Style); } }; - typedef NCollection_IndexedDataMap ShapeToGltfFaceMap; + struct Hasher + { + size_t operator()(const RWGltf_StyledShape& theShape) const noexcept + { + return std::hash{}(theShape.Shape); + } + + bool operator()(const RWGltf_StyledShape& theShape1, + const RWGltf_StyledShape& theShape2) const noexcept + { + return theShape1 == theShape2; + } + }; + + typedef NCollection_IndexedDataMap ShapeToGltfFaceMap; protected: diff --git a/src/RWGltf/RWGltf_GltfJsonParser.hxx b/src/RWGltf/RWGltf_GltfJsonParser.hxx index 5cd3fd2e99..0d26a02717 100644 --- a/src/RWGltf/RWGltf_GltfJsonParser.hxx +++ b/src/RWGltf/RWGltf_GltfJsonParser.hxx @@ -399,7 +399,7 @@ protected: private: - NCollection_DataMap myChildren; + NCollection_DataMap myChildren; const RWGltf_JsonValue* myRoot; }; diff --git a/src/RWGltf/RWGltf_GltfMaterialMap.cxx b/src/RWGltf/RWGltf_GltfMaterialMap.cxx index d3c8cee6c7..e6361982e8 100644 --- a/src/RWGltf/RWGltf_GltfMaterialMap.cxx +++ b/src/RWGltf/RWGltf_GltfMaterialMap.cxx @@ -207,7 +207,7 @@ void RWGltf_GltfMaterialMap::FlushGlbBufferViews (RWGltf_GltfOStreamWriter* theW Standard_Integer& theBuffViewId) { #ifdef HAVE_RAPIDJSON - for (NCollection_IndexedDataMap::Iterator aBufViewIter (myImageMap); + for (NCollection_IndexedDataMap::Iterator aBufViewIter (myImageMap); aBufViewIter.More(); aBufViewIter.Next()) { RWGltf_GltfBufferView& aBuffView = aBufViewIter.ChangeValue(); @@ -241,7 +241,7 @@ void RWGltf_GltfMaterialMap::FlushGlbImages (RWGltf_GltfOStreamWriter* theWriter { #ifdef HAVE_RAPIDJSON bool isStarted = false; - for (NCollection_IndexedDataMap::Iterator aBufViewIter (myImageMap); + for (NCollection_IndexedDataMap::Iterator aBufViewIter (myImageMap); aBufViewIter.More(); aBufViewIter.Next()) { const Handle(Image_Texture)& aTexture = aBufViewIter.Key(); diff --git a/src/RWGltf/RWGltf_GltfMaterialMap.hxx b/src/RWGltf/RWGltf_GltfMaterialMap.hxx index 357d5586b7..fe86036d09 100644 --- a/src/RWGltf/RWGltf_GltfMaterialMap.hxx +++ b/src/RWGltf/RWGltf_GltfMaterialMap.hxx @@ -105,8 +105,8 @@ protected: protected: RWGltf_GltfOStreamWriter* myWriter; - NCollection_IndexedDataMap myImageMap; - NCollection_Map myTextureMap; + NCollection_IndexedDataMap myImageMap; + NCollection_Map myTextureMap; Standard_Integer myDefSamplerId; diff --git a/src/RWGltf/RWGltf_GltfSceneNodeMap.hxx b/src/RWGltf/RWGltf_GltfSceneNodeMap.hxx index c6743fe2b2..abb548be5b 100644 --- a/src/RWGltf/RWGltf_GltfSceneNodeMap.hxx +++ b/src/RWGltf/RWGltf_GltfSceneNodeMap.hxx @@ -18,7 +18,7 @@ #include //! Indexed map of scene nodes with custom search algorithm. -class RWGltf_GltfSceneNodeMap : public NCollection_IndexedMap +class RWGltf_GltfSceneNodeMap : public NCollection_IndexedMap { public: @@ -32,15 +32,9 @@ public: { return 0; } - - for (IndexedMapNode* aNode1Iter = (IndexedMapNode* )myData1[::HashCode (theNodeId, NbBuckets())]; aNode1Iter != NULL; aNode1Iter = (IndexedMapNode* )aNode1Iter->Next()) - { - if (::IsEqual (aNode1Iter->Key1().Id, theNodeId)) - { - return aNode1Iter->Index(); - } - } - return 0; + XCAFPrs_DocumentNode aDocNode; + aDocNode.Id = theNodeId; + return NCollection_IndexedMap::FindIndex(aDocNode); } }; diff --git a/src/RWMesh/RWMesh_MaterialMap.hxx b/src/RWMesh/RWMesh_MaterialMap.hxx index 13aea517b3..397cab564f 100644 --- a/src/RWMesh/RWMesh_MaterialMap.hxx +++ b/src/RWMesh/RWMesh_MaterialMap.hxx @@ -87,10 +87,9 @@ protected: TCollection_AsciiString myFileName; //!< output glTF file path TCollection_AsciiString myShortFileNameBase; //!< output glTF file name without extension TCollection_AsciiString myKeyPrefix; //!< prefix for generated keys - NCollection_DoubleMap + NCollection_DoubleMap myStyles; //!< map of processed styles - NCollection_Map + NCollection_Map myImageFailMap; //!< map of images failed to be copied XCAFPrs_Style myDefaultStyle; //!< default material definition to be used for nodes with only color defined Standard_Integer myNbMaterials; //!< number of registered materials diff --git a/src/RWObj/RWObj_ObjMaterialMap.hxx b/src/RWObj/RWObj_ObjMaterialMap.hxx index fd9df2e218..359a3403d0 100644 --- a/src/RWObj/RWObj_ObjMaterialMap.hxx +++ b/src/RWObj/RWObj_ObjMaterialMap.hxx @@ -14,6 +14,7 @@ #ifndef _RWObj_ObjMaterialMap_HeaderFiler #define _RWObj_ObjMaterialMap_HeaderFiler +#include #include //! Material MTL file writer for OBJ export. @@ -39,7 +40,7 @@ public: private: FILE* myFile; - NCollection_DataMap myImageMap; + NCollection_DataMap myImageMap; }; diff --git a/src/RWObj/RWObj_Reader.hxx b/src/RWObj/RWObj_Reader.hxx index 920cb73cd3..4b91d68bd2 100644 --- a/src/RWObj/RWObj_Reader.hxx +++ b/src/RWObj/RWObj_Reader.hxx @@ -29,6 +29,7 @@ #include #include #include +#include #include @@ -241,14 +242,13 @@ protected: //! Hasher for 3 ordered integers. struct ObjVec3iHasher { - static Standard_Integer HashCode (const Graphic3d_Vec3i& theKey, - const Standard_Integer theUpper) + std::size_t operator()(const Graphic3d_Vec3i& theKey) const noexcept { - return ::HashCode (::HashCodes ((Standard_CString )&theKey, sizeof(Graphic3d_Vec3i)), theUpper); + return opencascade::hashBytes(&theKey[0], 3 * sizeof(int)); } - static Standard_Boolean IsEqual (const Graphic3d_Vec3i& theKey1, - const Graphic3d_Vec3i& theKey2) + bool operator()(const Graphic3d_Vec3i& theKey1, + const Graphic3d_Vec3i& theKey2) const noexcept { return theKey1[0] == theKey2[0] && theKey1[1] == theKey2[1] diff --git a/src/Resource/Resource_DataMapOfAsciiStringAsciiString.hxx b/src/Resource/Resource_DataMapOfAsciiStringAsciiString.hxx index 9cd00eaebf..264c45b40a 100644 --- a/src/Resource/Resource_DataMapOfAsciiStringAsciiString.hxx +++ b/src/Resource/Resource_DataMapOfAsciiStringAsciiString.hxx @@ -20,8 +20,8 @@ #include #include -typedef NCollection_DataMap Resource_DataMapOfAsciiStringAsciiString; -typedef NCollection_DataMap::Iterator Resource_DataMapIteratorOfDataMapOfAsciiStringAsciiString; +typedef NCollection_DataMap Resource_DataMapOfAsciiStringAsciiString; +typedef NCollection_DataMap::Iterator Resource_DataMapIteratorOfDataMapOfAsciiStringAsciiString; #endif diff --git a/src/Resource/Resource_DataMapOfAsciiStringExtendedString.hxx b/src/Resource/Resource_DataMapOfAsciiStringExtendedString.hxx index 7b1e3b672d..7bcc2458d4 100644 --- a/src/Resource/Resource_DataMapOfAsciiStringExtendedString.hxx +++ b/src/Resource/Resource_DataMapOfAsciiStringExtendedString.hxx @@ -21,8 +21,8 @@ #include #include -typedef NCollection_DataMap Resource_DataMapOfAsciiStringExtendedString; -typedef NCollection_DataMap::Iterator Resource_DataMapIteratorOfDataMapOfAsciiStringExtendedString; +typedef NCollection_DataMap Resource_DataMapOfAsciiStringExtendedString; +typedef NCollection_DataMap::Iterator Resource_DataMapIteratorOfDataMapOfAsciiStringExtendedString; #endif diff --git a/src/Resource/Resource_Manager.hxx b/src/Resource/Resource_Manager.hxx index 64bf32abc3..0072a4c71f 100644 --- a/src/Resource/Resource_Manager.hxx +++ b/src/Resource/Resource_Manager.hxx @@ -28,7 +28,6 @@ #include #include #include -#include class Resource_Manager; diff --git a/src/STEPCAFControl/STEPCAFControl_DataMapOfLabelExternFile.hxx b/src/STEPCAFControl/STEPCAFControl_DataMapOfLabelExternFile.hxx index 42156faf4a..0173910716 100644 --- a/src/STEPCAFControl/STEPCAFControl_DataMapOfLabelExternFile.hxx +++ b/src/STEPCAFControl/STEPCAFControl_DataMapOfLabelExternFile.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DataMap STEPCAFControl_DataMapOfLabelExternFile; -typedef NCollection_DataMap::Iterator STEPCAFControl_DataMapIteratorOfDataMapOfLabelExternFile; +typedef NCollection_DataMap STEPCAFControl_DataMapOfLabelExternFile; +typedef NCollection_DataMap::Iterator STEPCAFControl_DataMapIteratorOfDataMapOfLabelExternFile; #endif diff --git a/src/STEPCAFControl/STEPCAFControl_DataMapOfLabelShape.hxx b/src/STEPCAFControl/STEPCAFControl_DataMapOfLabelShape.hxx index 22e1b2a81e..c84b8b9756 100644 --- a/src/STEPCAFControl/STEPCAFControl_DataMapOfLabelShape.hxx +++ b/src/STEPCAFControl/STEPCAFControl_DataMapOfLabelShape.hxx @@ -17,11 +17,11 @@ #define STEPCAFControl_DataMapOfLabelShape_HeaderFile #include -#include +#include #include -typedef NCollection_DataMap STEPCAFControl_DataMapOfLabelShape; -typedef NCollection_DataMap::Iterator STEPCAFControl_DataMapIteratorOfDataMapOfLabelShape; +typedef NCollection_DataMap STEPCAFControl_DataMapOfLabelShape; +typedef NCollection_DataMap::Iterator STEPCAFControl_DataMapIteratorOfDataMapOfLabelShape; #endif diff --git a/src/STEPCAFControl/STEPCAFControl_DataMapOfPDExternFile.hxx b/src/STEPCAFControl/STEPCAFControl_DataMapOfPDExternFile.hxx index c995f867b5..c7a275f156 100644 --- a/src/STEPCAFControl/STEPCAFControl_DataMapOfPDExternFile.hxx +++ b/src/STEPCAFControl/STEPCAFControl_DataMapOfPDExternFile.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DataMap STEPCAFControl_DataMapOfPDExternFile; -typedef NCollection_DataMap::Iterator STEPCAFControl_DataMapIteratorOfDataMapOfPDExternFile; +typedef NCollection_DataMap STEPCAFControl_DataMapOfPDExternFile; +typedef NCollection_DataMap::Iterator STEPCAFControl_DataMapIteratorOfDataMapOfPDExternFile; #endif diff --git a/src/STEPCAFControl/STEPCAFControl_DataMapOfSDRExternFile.hxx b/src/STEPCAFControl/STEPCAFControl_DataMapOfSDRExternFile.hxx index 0ebb2725e4..7b786b5ec0 100644 --- a/src/STEPCAFControl/STEPCAFControl_DataMapOfSDRExternFile.hxx +++ b/src/STEPCAFControl/STEPCAFControl_DataMapOfSDRExternFile.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DataMap STEPCAFControl_DataMapOfSDRExternFile; -typedef NCollection_DataMap::Iterator STEPCAFControl_DataMapIteratorOfDataMapOfSDRExternFile; +typedef NCollection_DataMap STEPCAFControl_DataMapOfSDRExternFile; +typedef NCollection_DataMap::Iterator STEPCAFControl_DataMapIteratorOfDataMapOfSDRExternFile; #endif diff --git a/src/STEPConstruct/FILES b/src/STEPConstruct/FILES index 95b83dc3f4..8395ba5ff6 100755 --- a/src/STEPConstruct/FILES +++ b/src/STEPConstruct/FILES @@ -14,9 +14,6 @@ STEPConstruct_ExternRefs.cxx STEPConstruct_ExternRefs.hxx STEPConstruct_Part.cxx STEPConstruct_Part.hxx -STEPConstruct_PointHasher.cxx -STEPConstruct_PointHasher.hxx -STEPConstruct_PointHasher.lxx STEPConstruct_Styles.cxx STEPConstruct_Styles.hxx STEPConstruct_Tool.cxx diff --git a/src/STEPConstruct/STEPConstruct_DataMapOfAsciiStringTransient.hxx b/src/STEPConstruct/STEPConstruct_DataMapOfAsciiStringTransient.hxx index d4b3fe232b..6cfa8739e3 100644 --- a/src/STEPConstruct/STEPConstruct_DataMapOfAsciiStringTransient.hxx +++ b/src/STEPConstruct/STEPConstruct_DataMapOfAsciiStringTransient.hxx @@ -21,8 +21,8 @@ #include #include -typedef NCollection_DataMap STEPConstruct_DataMapOfAsciiStringTransient; -typedef NCollection_DataMap::Iterator STEPConstruct_DataMapIteratorOfDataMapOfAsciiStringTransient; +typedef NCollection_DataMap STEPConstruct_DataMapOfAsciiStringTransient; +typedef NCollection_DataMap::Iterator STEPConstruct_DataMapIteratorOfDataMapOfAsciiStringTransient; #endif diff --git a/src/STEPConstruct/STEPConstruct_DataMapOfPointTransient.hxx b/src/STEPConstruct/STEPConstruct_DataMapOfPointTransient.hxx index 029bcb40b8..6a538693f5 100644 --- a/src/STEPConstruct/STEPConstruct_DataMapOfPointTransient.hxx +++ b/src/STEPConstruct/STEPConstruct_DataMapOfPointTransient.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap STEPConstruct_DataMapOfPointTransient; -typedef NCollection_DataMap::Iterator STEPConstruct_DataMapIteratorOfDataMapOfPointTransient; +typedef NCollection_DataMap STEPConstruct_DataMapOfPointTransient; +typedef NCollection_DataMap::Iterator STEPConstruct_DataMapIteratorOfDataMapOfPointTransient; #endif diff --git a/src/STEPConstruct/STEPConstruct_PointHasher.cxx b/src/STEPConstruct/STEPConstruct_PointHasher.cxx deleted file mode 100644 index a01480f88b..0000000000 --- a/src/STEPConstruct/STEPConstruct_PointHasher.cxx +++ /dev/null @@ -1,29 +0,0 @@ -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - - -#include -#include - -//======================================================================= -//function : IsEqual -//purpose : -//======================================================================= -Standard_Boolean STEPConstruct_PointHasher::IsEqual(const gp_Pnt& point1, - const gp_Pnt& point2) -{ - if(Abs(point1.X()-point2.X()) > Epsilon(point1.X())) return Standard_False; - if(Abs(point1.Y()-point2.Y()) > Epsilon(point1.Y())) return Standard_False; - if(Abs(point1.Z()-point2.Z()) > Epsilon(point1.Z())) return Standard_False; - return Standard_True; -} diff --git a/src/STEPConstruct/STEPConstruct_PointHasher.hxx b/src/STEPConstruct/STEPConstruct_PointHasher.hxx deleted file mode 100644 index 6713485624..0000000000 --- a/src/STEPConstruct/STEPConstruct_PointHasher.hxx +++ /dev/null @@ -1,68 +0,0 @@ -// Created on: 2003-01-15 -// Created by: data exchange team -// Copyright (c) 2003-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _STEPConstruct_PointHasher_HeaderFile -#define _STEPConstruct_PointHasher_HeaderFile - -#include -#include - -#include -class gp_Pnt; - - - -class STEPConstruct_PointHasher -{ -public: - - DEFINE_STANDARD_ALLOC - - //! Computes a hash code for the point, in the range [1, theUpperBound] - //! @param thePoint the point which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const gp_Pnt& thePoint, const Standard_Integer theUpperBound); - - //! Returns True when the two keys are the same. Two - //! same keys must have the same hashcode, the - //! contrary is not necessary. - Standard_EXPORT static Standard_Boolean IsEqual (const gp_Pnt& Point1, const gp_Pnt& Point2); - - - - -protected: - - - - - -private: - - - - - -}; - - -#include - - - - - -#endif // _STEPConstruct_PointHasher_HeaderFile diff --git a/src/STEPConstruct/STEPConstruct_PointHasher.lxx b/src/STEPConstruct/STEPConstruct_PointHasher.lxx deleted file mode 100644 index 1e2e907af8..0000000000 --- a/src/STEPConstruct/STEPConstruct_PointHasher.lxx +++ /dev/null @@ -1,31 +0,0 @@ -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -//======================================================================= -// function : HashCode -// purpose : -//======================================================================= -inline Standard_Integer STEPConstruct_PointHasher::HashCode (const gp_Pnt& thePoint, - const Standard_Integer theUpperBound) -{ - union - { - Standard_Real R[3]; - Standard_Integer I[6]; - } U; - - thePoint.Coord (U.R[0], U.R[1], U.R[2]); - - return ::HashCode (U.I[0] / 23 + U.I[1] / 19 + U.I[2] / 17 + U.I[3] / 13 + U.I[4] / 11 + U.I[5] / 7, theUpperBound); - // return ::HashCode((U.I[0]>>4)+(U.I[1]>>3)+(U.I[2]>>2)+(U.I[3]>>1)+(U.I[4]>>4)+(U.I[5]>>3),theUpperBound); -} diff --git a/src/SelectMgr/SelectMgr_BVHThreadPool.hxx b/src/SelectMgr/SelectMgr_BVHThreadPool.hxx index 3dd7afd0ad..c96c1f8c60 100644 --- a/src/SelectMgr/SelectMgr_BVHThreadPool.hxx +++ b/src/SelectMgr/SelectMgr_BVHThreadPool.hxx @@ -45,9 +45,15 @@ public: myPool(nullptr), myMutex(), myToCatchFpe (Standard_False) - { + {} - } + + BVHThread(const BVHThread& theOther) + : OSD_Thread(theOther), + myPool(theOther.myPool), + myMutex(), + myToCatchFpe(theOther.myToCatchFpe) + {} //! Returns mutex used for BVH building Standard_Mutex& BVHMutex() diff --git a/src/SelectMgr/SelectMgr_IndexedDataMapOfOwnerCriterion.hxx b/src/SelectMgr/SelectMgr_IndexedDataMapOfOwnerCriterion.hxx index fbb8a344af..fbd8f99dd1 100644 --- a/src/SelectMgr/SelectMgr_IndexedDataMapOfOwnerCriterion.hxx +++ b/src/SelectMgr/SelectMgr_IndexedDataMapOfOwnerCriterion.hxx @@ -19,9 +19,8 @@ #include #include -#include #include -typedef NCollection_IndexedDataMap SelectMgr_IndexedDataMapOfOwnerCriterion; +typedef NCollection_IndexedDataMap SelectMgr_IndexedDataMapOfOwnerCriterion; #endif diff --git a/src/SelectMgr/SelectMgr_SelectionImageFiller.hxx b/src/SelectMgr/SelectMgr_SelectionImageFiller.hxx index 90a7277ec1..9fc46d2849 100644 --- a/src/SelectMgr/SelectMgr_SelectionImageFiller.hxx +++ b/src/SelectMgr/SelectMgr_SelectionImageFiller.hxx @@ -18,7 +18,6 @@ #include #include #include -#include class SelectMgr_ViewerSelector; @@ -76,7 +75,7 @@ protected: Image_PixMap* myImage; SelectMgr_ViewerSelector* myMainSel; math_BullardGenerator myBullardGenerator; - NCollection_Map myUniqueColors; + NCollection_Map myUniqueColors; }; #endif diff --git a/src/ShapeAnalysis/ShapeAnalysis.cxx b/src/ShapeAnalysis/ShapeAnalysis.cxx index 5517a17b35..2b88674808 100644 --- a/src/ShapeAnalysis/ShapeAnalysis.cxx +++ b/src/ShapeAnalysis/ShapeAnalysis.cxx @@ -111,12 +111,7 @@ Standard_Real ShapeAnalysis::AdjustToPeriod(const Standard_Real Val, template static inline void ReverseSeq (HSequence& Seq) { - Standard_Integer j=Seq.Length(); - for(Standard_Integer i=1; i=j) break; - Seq.Exchange(i,j); - j--; - } + Seq.Reverse(); } //======================================================================= //function : TotCross2D diff --git a/src/ShapeExtend/ShapeExtend_DataMapOfTransientListOfMsg.hxx b/src/ShapeExtend/ShapeExtend_DataMapOfTransientListOfMsg.hxx index cf6f27caff..5e3e2a29bf 100644 --- a/src/ShapeExtend/ShapeExtend_DataMapOfTransientListOfMsg.hxx +++ b/src/ShapeExtend/ShapeExtend_DataMapOfTransientListOfMsg.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap ShapeExtend_DataMapOfTransientListOfMsg; -typedef NCollection_DataMap::Iterator ShapeExtend_DataMapIteratorOfDataMapOfTransientListOfMsg; +typedef NCollection_DataMap ShapeExtend_DataMapOfTransientListOfMsg; +typedef NCollection_DataMap::Iterator ShapeExtend_DataMapIteratorOfDataMapOfTransientListOfMsg; #endif diff --git a/src/ShapeFix/ShapeFix_EdgeConnect.cxx b/src/ShapeFix/ShapeFix_EdgeConnect.cxx index fbabd618b0..e2ff4a7033 100644 --- a/src/ShapeFix/ShapeFix_EdgeConnect.cxx +++ b/src/ShapeFix/ShapeFix_EdgeConnect.cxx @@ -165,9 +165,9 @@ void ShapeFix_EdgeConnect::Build () for ( theLIterator.Initialize( theList ); theLIterator.More(); theLIterator.Next() ) { - TopoDS_Vertex& theVertex = TopoDS::Vertex( theLIterator.Value() ); + const TopoDS_Vertex& theVertex = TopoDS::Vertex( theLIterator.Value() ); theLIterator.Next(); - TopoDS_Edge& theEdge = TopoDS::Edge( theLIterator.Value() ); + TopoDS_Edge& theEdge = TopoDS::Edge( theLIterator.ChangeValue() ); // Determine usage of curve bound points TopoDS_Vertex theStart, theEnd; @@ -240,9 +240,9 @@ void ShapeFix_EdgeConnect::Build () for ( theLIterator.Initialize( theList ); theLIterator.More(); theLIterator.Next() ) { - TopoDS_Vertex& theVertex = TopoDS::Vertex( theLIterator.Value() ); + const TopoDS_Vertex& theVertex = TopoDS::Vertex( theLIterator.Value() ); theLIterator.Next(); - TopoDS_Edge& theEdge = TopoDS::Edge( theLIterator.Value() ); + TopoDS_Edge& theEdge = TopoDS::Edge( theLIterator.ChangeValue() ); // Determine usage of old vertices TopoDS_Vertex theStart, theEnd; diff --git a/src/Standard/FILES b/src/Standard/FILES index e6e14a2f42..e3465f7568 100755 --- a/src/Standard/FILES +++ b/src/Standard/FILES @@ -1,7 +1,6 @@ Standard.cxx Standard.hxx Standard_AbortiveTransaction.hxx -Standard_Address.hxx Standard_ArrayStreamBuffer.hxx Standard_ArrayStreamBuffer.cxx Standard_Assert.hxx @@ -17,6 +16,7 @@ Standard_ConstructionError.hxx Standard_Copy.tcl Standard_CString.cxx Standard_CString.hxx +Standard_CStringHasher.hxx Standard_DefineAlloc.hxx Standard_DefineException.hxx Standard_DefineHandle.hxx @@ -29,8 +29,6 @@ Standard_Dump.hxx Standard_ErrorHandler.cxx Standard_ErrorHandler.hxx Standard_ExtCharacter.hxx -Standard_ExtString.cxx -Standard_ExtString.hxx Standard_Failure.cxx Standard_Failure.hxx Standard_WarningDisableFunctionCast.hxx @@ -38,6 +36,8 @@ Standard_GUID.cxx Standard_GUID.hxx Standard_Handle.hxx Standard_HandlerStatus.hxx +Standard_HashUtils.hxx +Standard_HashUtils.lxx Standard_ImmutableObject.hxx Standard_Integer.hxx Standard_IStream.hxx @@ -45,16 +45,11 @@ Standard_JmpBuf.hxx Standard_LicenseError.hxx Standard_LicenseNotFound.hxx Standard_Macro.hxx -Standard_math.cxx -Standard_math.hxx +Standard_MemoryUtils.hxx Standard_MMgrOpt.cxx Standard_MMgrOpt.hxx -Standard_MMgrRaw.cxx -Standard_MMgrRaw.hxx Standard_MMgrRoot.cxx Standard_MMgrRoot.hxx -Standard_MMgrTBBalloc.cxx -Standard_MMgrTBBalloc.hxx Standard_MultiplyDefined.hxx Standard_Mutex.cxx Standard_Mutex.hxx @@ -83,9 +78,7 @@ Standard_ReadBuffer.hxx Standard_ReadLineBuffer.hxx Standard_Real.cxx Standard_Real.hxx -Standard_ShortReal.cxx Standard_ShortReal.hxx -Standard_Size.hxx Standard_SStream.hxx Standard_StackTrace.cxx Standard_Std.hxx @@ -101,7 +94,6 @@ Standard_TypeDef.hxx Standard_TypeMismatch.hxx Standard_Underflow.hxx Standard_UUID.hxx -Standard_values.h Standard_Version.hxx Standard_WarningsDisable.hxx -Standard_WarningsRestore.hxx \ No newline at end of file +Standard_WarningsRestore.hxx diff --git a/src/Standard/Standard.cxx b/src/Standard/Standard.cxx index bc601165c6..49bafea57d 100644 --- a/src/Standard/Standard.cxx +++ b/src/Standard/Standard.cxx @@ -1,7 +1,4 @@ -// Created on: 2005-03-15 -// Created by: Peter KURNEV -// Copyright (c) 1998-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS +// Copyright (c) 1999-2023 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // @@ -14,26 +11,70 @@ // Alternatively, this file may be used under the terms of Open CASCADE // commercial license or contractual agreement. - #include -#include -#include -#include -#include + +#include #include + #if(defined(_WIN32) || defined(__WIN32__)) - #include - #include - #include +#include +#include +#include #endif #if defined(_MSC_VER) || defined(__ANDROID__) || defined(__QNX__) - #include +#include #elif (defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 1)) && (defined(__i386) || defined(__x86_64))) - #include +#include #else - extern "C" int posix_memalign (void** thePtr, size_t theAlign, size_t theSize); +extern "C" int posix_memalign(void** thePtr, size_t theAlign, size_t theSize); +#endif + +// Temp define, after it will be part of CMake +#define OCCT_MMGT_OPT_NATIVE + +namespace +{ + static Standard::AllocatorType& allocatorTypeInstance() + { + static Standard::AllocatorType aType = +#ifdef OCCT_MMGT_OPT_FLEXIBLE + Standard::AllocatorType::NATIVE; +#elif defined OCCT_MMGT_OPT_NATIVE + Standard::AllocatorType::NATIVE; +#elif defined OCCT_MMGT_OPT_TBB + Standard::AllocatorType::TBB; +#elif defined OCCT_MMGT_OPT_JEMALLOC + Standard::AllocatorType::JEMALLOC; +#endif + return aType; + } +} + +#ifdef OCCT_MMGT_OPT_JEMALLOC +#define JEMALLOC_NO_DEMANGLE +#include +#endif // OCCT_MMGT_OPT_JEMALLOC + +// Available macros definition +// - OCCT_MMGT_OPT_FLEXIBLE, modifiable in real time +// - OCCT_MMGT_OPT_TBB, using tbb::scalable_allocator +// - OCCT_MMGT_OPT_NATIVE, using native calloc, free +// - OCCT_MMGT_OPT_JEMALLOC, using external jecalloc, jefree +#ifdef OCCT_MMGT_OPT_FLEXIBLE +#include +#include + + // paralleling with Intel TBB +#ifdef HAVE_TBB +#pragma comment (lib, "tbbmalloc.lib") +#include +#else +#define scalable_malloc malloc +#define scalable_calloc calloc +#define scalable_realloc realloc +#define scalable_free free #endif // There is no support for environment variables in UWP @@ -45,270 +86,437 @@ #ifndef OCCT_MMGT_OPT_DEFAULT #define OCCT_MMGT_OPT_DEFAULT 0 #endif - -//======================================================================= -//class : Standard_MMgrFactory -//purpose : Container for pointer to memory manager; -// used to construct appropriate memory manager according -// to environment settings, and to ensure destruction upon exit -//======================================================================= -class Standard_MMgrFactory +namespace { -public: - static Standard_MMgrRoot* GetMMgr(); - ~Standard_MMgrFactory(); + /** + * Implementation of raw OCC memory manager which uses standard C + * functions: malloc (or calloc), free and realloc + * without any optimization + */ + class Standard_MMgrRaw : public Standard_MMgrRoot + { + public: + //! Constructor; if theToClear is True, the memory will be nullified + //! upon allocation. + Standard_MMgrRaw(const Standard_Boolean theToClear = Standard_False) + { + myClear = theToClear; + } -private: - Standard_MMgrFactory(); - Standard_MMgrFactory (const Standard_MMgrFactory&); - Standard_MMgrFactory& operator= (const Standard_MMgrFactory&); + //! Allocate theSize bytes + Standard_Address Allocate(const Standard_Size theSize) override + { + // we use ?: operator instead of if() since it is faster :-) + Standard_Address aPtr = (myClear ? calloc(theSize, sizeof(char)) : + malloc(theSize)); + if (!aPtr) + throw Standard_OutOfMemory("Standard_MMgrRaw::Allocate(): malloc failed"); + return aPtr; + } -private: - Standard_MMgrRoot* myFMMgr; -}; + //! Reallocate thePtr to the size theSize. + //! The new pointer is returned. + Standard_Address Reallocate(Standard_Address thePtr, + const Standard_Size theSize) override + { + Standard_Address newStorage = (Standard_Address)realloc(thePtr, theSize); + if (!newStorage) + throw Standard_OutOfMemory("Standard_MMgrRaw::Reallocate(): realloc failed"); + // Note that it is not possible to ensure that additional memory + // allocated by realloc will be cleared (so as to satisfy myClear mode); + // in order to do that we would need using memset... + return newStorage; + } -//======================================================================= -//function : Standard_MMgrFactory -//purpose : Check environment variables and create appropriate memory manager -//======================================================================= + //! Free allocated memory. The pointer is nullified. + void Free(Standard_Address thePtr) override + { + free(thePtr); + } -Standard_MMgrFactory::Standard_MMgrFactory() -: myFMMgr (NULL) -{ -/*#if defined(_MSC_VER) && (_MSC_VER > 1400) - // Turn ON thread-safe C locale globally to avoid side effects by setlocale() calls between threads. - // After this call all following _configthreadlocale() will be ignored assuming - // Notice that this is MSVCRT feature - on POSIX systems xlocale API (uselocale instead of setlocale) - // should be used explicitly to ensure thread-safety! + protected: + Standard_Boolean myClear; //! Option to nullify allocated memory + }; - // This is not well documented call because _ENABLE_PER_THREAD_LOCALE_GLOBAL flag is defined but not implemented for some reason. - // -1 will set global locale flag to force _ENABLE_PER_THREAD_LOCALE_GLOBAL + _ENABLE_PER_THREAD_LOCALE_NEW behaviour - // although there NO way to turn it off again and following calls will have no effect (locale will be changed only for current thread). - _configthreadlocale (-1); -#endif*/ + //! Implementation of OCC memory manager which uses Intel TBB + //! scalable allocator. + //! + //! On configurations where TBB is not available standard RTL functions + //! malloc() / free() are used. + class Standard_MMgrTBBalloc : public Standard_MMgrRoot + { + public: + //! Constructor; if theClear is True, the memory will be nullified + //! upon allocation. + Standard_MMgrTBBalloc(const Standard_Boolean theClear = Standard_False) + { + myClear = theClear; + } - // Check basic assumption. - // If assertion happens, then OCCT should be corrected for compatibility with such CPU architecture. - Standard_STATIC_ASSERT(sizeof(Standard_Utf8Char) == 1); - Standard_STATIC_ASSERT(sizeof(short) == 2); - Standard_STATIC_ASSERT(sizeof(Standard_Utf16Char) == 2); - Standard_STATIC_ASSERT(sizeof(Standard_Utf32Char) == 4); + //! Allocate theSize bytes + Standard_Address Allocate(const Standard_Size theSize) override + { + // we use ?: operator instead of if() since it is faster :-) + Standard_Address aPtr = (myClear ? scalable_calloc(theSize, sizeof(char)) : + scalable_malloc(theSize)); + if (!aPtr) + throw Standard_OutOfMemory("Standard_MMgrTBBalloc::Allocate(): malloc failed"); + return aPtr; + } + + //! Reallocate thePtr to the size theSize. + //! The new pointer is returned. + Standard_Address Reallocate(Standard_Address thePtr, + const Standard_Size theSize) override + { + Standard_Address newStorage = (Standard_Address)scalable_realloc(thePtr, theSize); + if (!newStorage) + throw Standard_OutOfMemory("Standard_MMgrTBBalloc::Reallocate(): realloc failed"); + // Note that it is not possible to ensure that additional memory + // allocated by realloc will be cleared (so as to satisfy myClear mode); + // in order to do that we would need using memset... + return newStorage; + } + + //! Free allocated memory + void Free(Standard_Address thePtr) override + { + scalable_free(thePtr); + } + + protected: + Standard_Boolean myClear; //! Option to nullify allocated memory + }; + + //======================================================================= + //class : Standard_MMgrFactory + //purpose : Container for pointer to memory manager; + // used to construct appropriate memory manager according + // to environment settings, and to ensure destruction upon exit + //======================================================================= + class Standard_MMgrFactory + { + public: + static Standard_MMgrRoot* GetMMgr(); + ~Standard_MMgrFactory(); + + private: + Standard_MMgrFactory(); + Standard_MMgrFactory(const Standard_MMgrFactory&); + Standard_MMgrFactory& operator= (const Standard_MMgrFactory&); + + private: + Standard_MMgrRoot* myFMMgr; + }; + + //======================================================================= + //function : Standard_MMgrFactory + //purpose : Check environment variables and create appropriate memory manager + //======================================================================= + + Standard_MMgrFactory::Standard_MMgrFactory() + : myFMMgr(NULL) + { + /*#if defined(_MSC_VER) && (_MSC_VER > 1400) + // Turn ON thread-safe C locale globally to avoid side effects by setlocale() calls between threads. + // After this call all following _configthreadlocale() will be ignored assuming + // Notice that this is MSVCRT feature - on POSIX systems xlocale API (uselocale instead of setlocale) + // should be used explicitly to ensure thread-safety! + + // This is not well documented call because _ENABLE_PER_THREAD_LOCALE_GLOBAL flag is defined but not implemented for some reason. + // -1 will set global locale flag to force _ENABLE_PER_THREAD_LOCALE_GLOBAL + _ENABLE_PER_THREAD_LOCALE_NEW behaviour + // although there NO way to turn it off again and following calls will have no effect (locale will be changed only for current thread). + _configthreadlocale (-1); + #endif*/ + + // Check basic assumption. + // If assertion happens, then OCCT should be corrected for compatibility with such CPU architecture. + Standard_STATIC_ASSERT(sizeof(Standard_Utf8Char) == 1); + Standard_STATIC_ASSERT(sizeof(short) == 2); + Standard_STATIC_ASSERT(sizeof(Standard_Utf16Char) == 2); + Standard_STATIC_ASSERT(sizeof(Standard_Utf32Char) == 4); #ifdef _WIN32 - Standard_STATIC_ASSERT(sizeof(Standard_WideChar) == sizeof(Standard_Utf16Char)); + Standard_STATIC_ASSERT(sizeof(Standard_WideChar) == sizeof(Standard_Utf16Char)); #endif - char* aVar; - aVar = getenv ("MMGT_OPT"); - Standard_Integer anAllocId = (aVar ? atoi (aVar): OCCT_MMGT_OPT_DEFAULT); + char* aVar; + aVar = getenv("MMGT_OPT"); + Standard_Integer anAllocId = (aVar ? atoi(aVar) : OCCT_MMGT_OPT_DEFAULT); #if defined(HAVE_TBB) && defined(_M_IX86) - if (anAllocId == 2) - { - // CR25396: Check if SSE2 instructions are supported on 32-bit x86 processor on Windows platform, - // if not then use MMgrRaw instead of MMgrTBBalloc. - // It is to avoid runtime crash when running on a CPU - // that supports SSE but does not support SSE2 (some modifications of AMD Sempron). - static const DWORD _SSE2_FEATURE_BIT(0x04000000); - DWORD volatile dwFeature; - _asm + if (anAllocId == 2) { - push eax - push ebx - push ecx - push edx + // CR25396: Check if SSE2 instructions are supported on 32-bit x86 processor on Windows platform, + // if not then use MMgrRaw instead of MMgrTBBalloc. + // It is to avoid runtime crash when running on a CPU + // that supports SSE but does not support SSE2 (some modifications of AMD Sempron). + static const DWORD _SSE2_FEATURE_BIT(0x04000000); + DWORD volatile dwFeature; + _asm + { + push eax + push ebx + push ecx + push edx - // get the CPU feature bits - mov eax, 1 - cpuid - mov dwFeature, edx + // get the CPU feature bits + mov eax, 1 + cpuid + mov dwFeature, edx - pop edx - pop ecx - pop ebx - pop eax + pop edx + pop ecx + pop ebx + pop eax + } + if ((dwFeature & _SSE2_FEATURE_BIT) == 0) + anAllocId = 0; } - if ((dwFeature & _SSE2_FEATURE_BIT) == 0) - anAllocId = 0; - } #endif - aVar = getenv ("MMGT_CLEAR"); - Standard_Boolean toClear = (aVar ? (atoi (aVar) != 0) : Standard_True); + aVar = getenv("MMGT_CLEAR"); + Standard_Boolean toClear = (aVar ? (atoi(aVar) != 0) : Standard_True); - // on Windows (actual for XP and 2000) activate low fragmentation heap - // for CRT heap in order to get best performance. - // Environment variable MMGT_LFH can be used to switch off this action (if set to 0) + // on Windows (actual for XP and 2000) activate low fragmentation heap + // for CRT heap in order to get best performance. + // Environment variable MMGT_LFH can be used to switch off this action (if set to 0) #if defined(_MSC_VER) - aVar = getenv ("MMGT_LFH"); - if ( aVar == NULL || atoi (aVar) != 0 ) - { - ULONG aHeapInfo = 2; - HANDLE aCRTHeap = (HANDLE)_get_heap_handle(); - HeapSetInformation (aCRTHeap, HeapCompatibilityInformation, &aHeapInfo, sizeof(aHeapInfo)); - } + aVar = getenv("MMGT_LFH"); + if (aVar == NULL || atoi(aVar) != 0) + { + ULONG aHeapInfo = 2; + HANDLE aCRTHeap = (HANDLE)_get_heap_handle(); + HeapSetInformation(aCRTHeap, HeapCompatibilityInformation, &aHeapInfo, sizeof(aHeapInfo)); + } #endif - switch (anAllocId) - { - case 1: // OCCT optimized memory allocator + switch (anAllocId) { - aVar = getenv ("MMGT_MMAP"); - Standard_Boolean bMMap = (aVar ? (atoi (aVar) != 0) : Standard_True); - aVar = getenv ("MMGT_CELLSIZE"); - Standard_Integer aCellSize = (aVar ? atoi (aVar) : 200); - aVar = getenv ("MMGT_NBPAGES"); - Standard_Integer aNbPages = (aVar ? atoi (aVar) : 1000); - aVar = getenv ("MMGT_THRESHOLD"); - Standard_Integer aThreshold = (aVar ? atoi (aVar) : 40000); - myFMMgr = new Standard_MMgrOpt (toClear, bMMap, aCellSize, aNbPages, aThreshold); - break; + case 1: // OCCT optimized memory allocator + { + aVar = getenv("MMGT_MMAP"); + Standard_Boolean bMMap = (aVar ? (atoi(aVar) != 0) : Standard_True); + aVar = getenv("MMGT_CELLSIZE"); + Standard_Integer aCellSize = (aVar ? atoi(aVar) : 200); + aVar = getenv("MMGT_NBPAGES"); + Standard_Integer aNbPages = (aVar ? atoi(aVar) : 1000); + aVar = getenv("MMGT_THRESHOLD"); + Standard_Integer aThreshold = (aVar ? atoi(aVar) : 40000); + myFMMgr = new Standard_MMgrOpt(toClear, bMMap, aCellSize, aNbPages, aThreshold); + break; + } + case 2: // TBB memory allocator + myFMMgr = new Standard_MMgrTBBalloc(toClear); + break; + case 0: + default: // system default memory allocator + myFMMgr = new Standard_MMgrRaw(toClear); } - case 2: // TBB memory allocator - myFMMgr = new Standard_MMgrTBBalloc (toClear); - break; - case 0: - default: // system default memory allocator - myFMMgr = new Standard_MMgrRaw (toClear); + allocatorTypeInstance() = static_cast(anAllocId); + } + + //======================================================================= + //function : ~Standard_MMgrFactory + //purpose : + //======================================================================= + + Standard_MMgrFactory::~Standard_MMgrFactory() + { + if (myFMMgr) + myFMMgr->Purge(Standard_True); + } + + //======================================================================= + // function: GetMMgr + // + // This static function has a purpose to wrap static holder for memory + // manager instance. + // + // Wrapping holder inside a function is needed to ensure that it will + // be initialized not later than the first call to memory manager (that + // would be impossible to guarantee if holder was static variable on + // global or file scope, because memory manager may be called from + // constructors of other static objects). + // + // Note that at the same time we could not guarantee that the holder + // object is destroyed after last call to memory manager, since that + // last call may be from static Handle() object which has been initialized + // dynamically during program execution rather than in its constructor. + // + // Therefore holder currently does not call destructor of the memory manager + // but only its method Purge() with Standard_True. + // + // To free the memory completely, we probably could use compiler-specific + // pragmas (such as '#pragma fini' on SUN Solaris and '#pragma init_seg' on + // WNT MSVC++) to put destructing function in code segment that is called + // after destructors of other (even static) objects. However, this is not + // done by the moment since it is compiler-dependent and there is no guarantee + // that some other object calling memory manager is not placed also in that segment... + // + // Note that C runtime function atexit() could not help in this problem + // since its behaviour is the same as for destructors of static objects + // (see ISO 14882:1998 "Programming languages -- C++" 3.6.3) + // + // The correct approach to deal with the problem would be to have memory manager + // to properly control its memory allocation and caching free blocks so + // as to release all memory as soon as it is returned to it, and probably + // even delete itself if all memory it manages has been released and + // last call to method Purge() was with True. + // + // Note that one possible method to control memory allocations could + // be counting calls to Allocate() and Free()... + // + //======================================================================= + Standard_MMgrRoot* Standard_MMgrFactory::GetMMgr() + { + static Standard_MMgrFactory aFactory; + return aFactory.myFMMgr; } } +#endif // OCCT_MMGT_OPT_FLEXIBLE //======================================================================= -//function : ~Standard_MMgrFactory -//purpose : +//function : Allocate +//purpose : //======================================================================= - -Standard_MMgrFactory::~Standard_MMgrFactory() +Standard::AllocatorType Standard::GetAllocatorType() { - if ( myFMMgr ) - myFMMgr->Purge(Standard_True); -} - -//======================================================================= -// function: GetMMgr -// -// This static function has a purpose to wrap static holder for memory -// manager instance. -// -// Wrapping holder inside a function is needed to ensure that it will -// be initialized not later than the first call to memory manager (that -// would be impossible to guarantee if holder was static variable on -// global or file scope, because memory manager may be called from -// constructors of other static objects). -// -// Note that at the same time we could not guarantee that the holder -// object is destroyed after last call to memory manager, since that -// last call may be from static Handle() object which has been initialized -// dynamically during program execution rather than in its constructor. -// -// Therefore holder currently does not call destructor of the memory manager -// but only its method Purge() with Standard_True. -// -// To free the memory completely, we probably could use compiler-specific -// pragmas (such as '#pragma fini' on SUN Solaris and '#pragma init_seg' on -// WNT MSVC++) to put destructing function in code segment that is called -// after destructors of other (even static) objects. However, this is not -// done by the moment since it is compiler-dependent and there is no guarantee -// that some other object calling memory manager is not placed also in that segment... -// -// Note that C runtime function atexit() could not help in this problem -// since its behaviour is the same as for destructors of static objects -// (see ISO 14882:1998 "Programming languages -- C++" 3.6.3) -// -// The correct approach to deal with the problem would be to have memory manager -// to properly control its memory allocation and caching free blocks so -// as to release all memory as soon as it is returned to it, and probably -// even delete itself if all memory it manages has been released and -// last call to method Purge() was with True. -// -// Note that one possible method to control memory allocations could -// be counting calls to Allocate() and Free()... -// -//======================================================================= -Standard_MMgrRoot* Standard_MMgrFactory::GetMMgr() -{ - static Standard_MMgrFactory aFactory; - return aFactory.myFMMgr; + return allocatorTypeInstance(); } //======================================================================= //function : Allocate -//purpose : +//purpose : //======================================================================= - -Standard_Address Standard::Allocate(const Standard_Size size) +Standard_Address Standard::Allocate(const Standard_Size theSize) { - return Standard_MMgrFactory::GetMMgr()->Allocate(size); +#ifdef OCCT_MMGT_OPT_FLEXIBLE + return Standard_MMgrFactory::GetMMgr()->Allocate(theSize); +#elif defined OCCT_MMGT_OPT_NATIVE + Standard_Address aPtr = calloc(theSize, sizeof(char)); + if (!aPtr) + throw Standard_OutOfMemory("Standard_MMgrRaw::Allocate(): malloc failed"); + return aPtr; +#elif defined OCCT_MMGT_OPT_JEMALLOC + Standard_Address aPtr = je_calloc(theSize, sizeof(char)); + if (!aPtr) + throw Standard_OutOfMemory("Standard_MMgrRaw::Allocate(): malloc failed"); + return aPtr; +#endif // OCCT_MMGT_OPT_FLEXIBLE +} + +//======================================================================= +//function : AllocateOptimal +//purpose : +//======================================================================= +Standard_Address Standard::AllocateOptimal(const Standard_Size theSize) +{ +#ifdef OCCT_MMGT_OPT_FLEXIBLE + return Standard_MMgrFactory::GetMMgr()->Allocate(theSize); +#elif defined OCCT_MMGT_OPT_NATIVE + return malloc(theSize); +#elif defined OCCT_MMGT_OPT_JEMALLOC + return je_malloc(theSize); +#endif } //======================================================================= //function : Free -//purpose : +//purpose : //======================================================================= - -void Standard::Free (Standard_Address theStorage) +void Standard::Free(Standard_Address theStorage) { +#ifdef OCCT_MMGT_OPT_FLEXIBLE Standard_MMgrFactory::GetMMgr()->Free(theStorage); +#elif defined OCCT_MMGT_OPT_NATIVE + free(theStorage); +#elif defined OCCT_MMGT_OPT_JEMALLOC + return je_free(theStorage); +#endif } //======================================================================= //function : Reallocate -//purpose : +//purpose : //======================================================================= - -Standard_Address Standard::Reallocate (Standard_Address theStorage, - const Standard_Size theSize) +Standard_Address Standard::Reallocate(Standard_Address theStorage, + const Standard_Size theSize) { - return Standard_MMgrFactory::GetMMgr()->Reallocate (theStorage, theSize); + // Note that it is not possible to ensure that additional memory + // allocated by realloc will be cleared (so as to satisfy myClear mode); + // in order to do that we would need using memset.. +#ifdef OCCT_MMGT_OPT_FLEXIBLE + return Standard_MMgrFactory::GetMMgr()->Reallocate(theStorage, theSize); +#elif defined OCCT_MMGT_OPT_NATIVE + Standard_Address aNewStorage = (Standard_Address)realloc(theStorage, theSize); + if (!aNewStorage) + throw Standard_OutOfMemory("Standard_MMgrRaw::Reallocate(): realloc failed"); + return aNewStorage; +#elif defined OCCT_MMGT_OPT_JEMALLOC + Standard_Address newStorage = (Standard_Address)je_realloc(theStorage, theSize); + if (!newStorage) + throw Standard_OutOfMemory("Standard_MMgrRaw::Reallocate(): realloc failed"); + return newStorage; +#endif } //======================================================================= //function : Purge -//purpose : +//purpose : //======================================================================= - Standard_Integer Standard::Purge() { +#ifdef OCCT_MMGT_OPT_FLEXIBLE return Standard_MMgrFactory::GetMMgr()->Purge(); +#else + return true; +#endif // OCCT_MMGT_OPT_FLEXIBLE } //======================================================================= //function : AllocateAligned //purpose : //======================================================================= - -Standard_Address Standard::AllocateAligned (const Standard_Size theSize, - const Standard_Size theAlign) +Standard_Address Standard::AllocateAligned(const Standard_Size theSize, + const Standard_Size theAlign) { +#if defined(OCCT_MMGT_OPT_FLEXIBLE) || defined(OCCT_MMGT_OPT_NATIVE) #if defined(_MSC_VER) - return _aligned_malloc (theSize, theAlign); + return _aligned_malloc(theSize, theAlign); #elif defined(__ANDROID__) || defined(__QNX__) - return memalign (theAlign, theSize); + return memalign(theAlign, theSize); #elif (defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 1)) && (defined(__i386) || defined(__x86_64))) - return _mm_malloc (theSize, theAlign); + return _mm_malloc(theSize, theAlign); #else void* aPtr; - if (posix_memalign (&aPtr, theAlign, theSize)) + if (posix_memalign(&aPtr, theAlign, theSize)) { return NULL; } return aPtr; #endif +#elif defined OCCT_MMGT_OPT_JEMALLOC + return je_aligned_alloc(theAlign, theSize); +#endif } //======================================================================= //function : FreeAligned //purpose : //======================================================================= - -void Standard::FreeAligned (Standard_Address thePtrAligned) +void Standard::FreeAligned(Standard_Address thePtrAligned) { +#if defined(OCCT_MMGT_OPT_FLEXIBLE) || defined(OCCT_MMGT_OPT_NATIVE) #if defined(_MSC_VER) - _aligned_free (thePtrAligned); + _aligned_free(thePtrAligned); #elif defined(__ANDROID__) || defined(__QNX__) - free (thePtrAligned); + free(thePtrAligned); #elif (defined(__GNUC__) && (__GNUC__ > 4 || (__GNUC__ == 4 && __GNUC_MINOR__ >= 1)) && (defined(__i386) || defined(__x86_64))) - _mm_free (thePtrAligned); + _mm_free(thePtrAligned); #else - free (thePtrAligned); + free(thePtrAligned); +#endif +#elif defined OCCT_MMGT_OPT_JEMALLOC + return je_free(thePtrAligned); #endif } diff --git a/src/Standard/Standard.hxx b/src/Standard/Standard.hxx index 8d0fb3a1a6..c9671f68ff 100644 --- a/src/Standard/Standard.hxx +++ b/src/Standard/Standard.hxx @@ -18,11 +18,8 @@ #define _Standard_HeaderFile #include -#include -#include #include - //! The package Standard provides global memory allocator and other basic //! services used by other OCCT components. @@ -32,10 +29,25 @@ public: DEFINE_STANDARD_ALLOC + //! Enumiration of possible allocator types + enum class AllocatorType + { + NATIVE = 0, + OPT = 1, + TBB = 2, + JEMALLOC = 3 + }; + + //! Returns default allocator type + Standard_EXPORT static AllocatorType GetAllocatorType(); //! Allocates memory blocks - //! aSize - bytes to allocate - Standard_EXPORT static Standard_Address Allocate (const Standard_Size aSize); + //! theSize - bytes to allocate + Standard_EXPORT static Standard_Address Allocate (const Standard_Size theSize); + + //! Allocates memory blocks + //! theSize - bytes to allocate + Standard_EXPORT static Standard_Address AllocateOptimal (const Standard_Size theSize); //! Deallocates memory blocks //! @param thePtr - previously allocated memory block to be freed @@ -51,9 +63,9 @@ public: } //! Reallocates memory blocks - //! aStorage - previously allocated memory block - //! aNewSize - new size in bytes - Standard_EXPORT static Standard_Address Reallocate (const Standard_Address aStorage, const Standard_Size aNewSize); + //! theStorage - previously allocated memory block + //! theNewSize - new size in bytes + Standard_EXPORT static Standard_Address Reallocate (const Standard_Address theStorage, const Standard_Size theNewSize); //! Allocates aligned memory blocks. //! Should be used with CPU instructions which require specific alignment. @@ -104,8 +116,4 @@ public: }; -// include definition of handle to make it always visible -// (put at the and of the file due to cyclic dependency between headers) -#include - #endif // _Standard_HeaderFile diff --git a/src/Standard/Standard_Address.hxx b/src/Standard/Standard_Address.hxx deleted file mode 100644 index 2919d451e9..0000000000 --- a/src/Standard/Standard_Address.hxx +++ /dev/null @@ -1,47 +0,0 @@ -// Copyright (c) 1998-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _Standard_Address_HeaderFile -#define _Standard_Address_HeaderFile - -#include - -//! Returns a hash code of the given memory pointer -//! @param thePointer the memory pointer which hash code it to be computed -//! @param theUpperBound the upper bound of the range a resulting hash code must be within -//! @return a value of a computed hash code, in range [1, UpperBound] -inline Standard_Integer HashCode (const void* const thePointer, const Standard_Integer theUpperBound) -{ - union - { - const void* L; - Standard_Integer I[2]; - } U; - - U.I[0] = 0; - U.I[1] = 0; - U.L = thePointer; - - return HashCode (U.I[0] ^ U.I[1], theUpperBound); -} - -//============================================================================ -// IsEqual : Returns Standard_True if two CString have the same value -//============================================================================ - -inline Standard_Boolean IsEqual(const Standard_Address One - ,const Standard_Address Two) -{ return One == Two; } - -#endif diff --git a/src/Standard/Standard_CString.cxx b/src/Standard/Standard_CString.cxx index f73d6b6940..c62acd7a53 100755 --- a/src/Standard/Standard_CString.cxx +++ b/src/Standard/Standard_CString.cxx @@ -24,36 +24,6 @@ #include #include -//============================================================================ -// function : HashCode -// purpose : -//============================================================================ -Standard_Integer HashCode (const Standard_CString theString, const Standard_Integer theUpperBound) -{ - const Standard_Integer aLength = static_cast (strlen (theString)); - - return HashCode (theString, aLength, theUpperBound); -} - -//============================================================================ -// function : HashCodes -// purpose : -//============================================================================ -Standard_Integer HashCodes (const Standard_CString theString, const Standard_Integer theLength) -{ - // compute DJB2 hash of a string - unsigned int hash = 0; - const Standard_Character* c = theString; - - for (Standard_Integer i = 0; i < theLength; ++i, ++c) - { - /* hash = hash * 33 ^ c */ - hash = ((hash << 5) + hash) ^ (*c); - } - - return static_cast(hash); -} - //====================================================================== // Locale-independent equivalents of C functions dealing with conversion // of string to real and vice-versa @@ -89,13 +59,6 @@ Standard_Integer HashCodes (const Standard_CString theString, const Standard_Int #define vfprintf_l(theFile, theLocale, theFormat, theArgPtr) vfprintf(theFile, theFormat, theArgPtr) #endif -/* -double Strtod (const char* theStr, char** theNextPtr) -{ - return strtod_l (theStr, theNextPtr, Standard_CLocaleSentry::GetCLocale()); -} -*/ - double Atof (const char* theStr) { return Strtod (theStr, NULL); diff --git a/src/Standard/Standard_CString.hxx b/src/Standard/Standard_CString.hxx index 4f5b353618..0b05b7899b 100644 --- a/src/Standard/Standard_CString.hxx +++ b/src/Standard/Standard_CString.hxx @@ -36,33 +36,7 @@ // C++ only definitions #ifdef __cplusplus -#include - -//! Returns bounded hash code for the null-terminated string, in the range [1, theUpperBound] -//! @param theString the null-terminated string which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -Standard_EXPORT Standard_Integer HashCode (Standard_CString theString, Standard_Integer theUpperBound); - -//! Returns 32-bit hash code for the first theLen characters in the string theStr. -//! The result is unbound (may be not only positive, but also negative) -//! @param theString the string which hash code is to be computed -//! @param theLength the length of the given string -//! @return a computed hash code of the given string -Standard_EXPORT Standard_Integer HashCodes (Standard_CString theString, Standard_Integer theLength); - -//! Returns bounded hash code for the first theLength characters in the string theString, in the range [1, theUpperBound] -//! @param theString the string which hash code is to be computed -//! @param theLength the length of the initial substring of the given string which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code of the given string -inline Standard_Integer HashCode (const Standard_CString theString, - const Standard_Integer theLength, - const Standard_Integer theUpperBound) -{ -// return (Abs( HashCodes( Value , Len ) ) % Upper ) + 1 ; - return HashCode (HashCodes (theString, theLength), theUpperBound); -} +#include //! Returns Standard_True if two strings are equal inline Standard_Boolean IsEqual (const Standard_CString theOne, const Standard_CString theTwo) diff --git a/src/Standard/Standard_CStringHasher.hxx b/src/Standard/Standard_CStringHasher.hxx new file mode 100644 index 0000000000..893e8d36a1 --- /dev/null +++ b/src/Standard/Standard_CStringHasher.hxx @@ -0,0 +1,45 @@ +// Copyright (c) 2023 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _Standard_CStringHasher_HeaderFile +#define _Standard_CStringHasher_HeaderFile + +#include +#include +#include + +#include + +class Standard_CStringHasher +{ +public: + + size_t operator()(const Standard_CString& theString) const noexcept + { + const int aLen = static_cast(strlen(theString)); + if (aLen < 4) + { + return opencascade::FNVHash::hash_combine(*theString, aLen); + } + return opencascade::hashBytes(theString, aLen); + } + + bool operator()(const Standard_CString& theString1, + const Standard_CString& theString2) const noexcept + { + return strcmp(theString1, theString2) == 0; + } + +}; + +#endif diff --git a/src/Standard/Standard_ExtString.cxx b/src/Standard/Standard_ExtString.cxx deleted file mode 100644 index 94ca59fea3..0000000000 --- a/src/Standard/Standard_ExtString.cxx +++ /dev/null @@ -1,34 +0,0 @@ -// Copyright (c) 1998-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#include -#include - -//============================================================================ -// function : HashCode -// purpose : -//============================================================================ -Standard_Integer HashCode (const Standard_ExtString theExtString, const Standard_Integer theUpperBound) -{ - // compute SDBM hash of an ext string - unsigned int hash = 0; - - for (const Standard_ExtCharacter* c = theExtString; *c; ++c) - { - /* hash = hash * 33 ^ c */ - hash = (*c) + (hash << 6) + (hash << 16) - hash; - } - - return HashCode (hash, theUpperBound); -} diff --git a/src/Standard/Standard_ExtString.hxx b/src/Standard/Standard_ExtString.hxx deleted file mode 100644 index 2953de8912..0000000000 --- a/src/Standard/Standard_ExtString.hxx +++ /dev/null @@ -1,33 +0,0 @@ -// Copyright (c) 1998-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -//============================================================================ -//==== Title: Standard_ExtString.hxx -//==== -//==== Implementation: This is a primitive type implementadef with typedef -//==== typedef short* Standard_ExtString; -//============================================================================ - -#ifndef _Standard_ExtString_HeaderFile -#define _Standard_ExtString_HeaderFile - -#include - -//! Computes a hash code for the given wide character string, in the range [1, theUpperBound] -//! @param theExtString the wide character string which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -Standard_EXPORT Standard_Integer HashCode (Standard_ExtString theExtString, Standard_Integer theUpperBound); - -#endif diff --git a/src/Standard/Standard_GUID.cxx b/src/Standard/Standard_GUID.cxx index 6383445f88..1f158e83c2 100644 --- a/src/Standard/Standard_GUID.cxx +++ b/src/Standard/Standard_GUID.cxx @@ -387,30 +387,3 @@ void Standard_GUID::ShallowDump(Standard_OStream& aStream) const ToCString(sguid); aStream << sguid; } - -//============================================================================ -// function : HashCode -// purpose : -//============================================================================ -Standard_Integer Standard_GUID::HashCode (const Standard_GUID& theGuid, const Standard_Integer theUpperBound) -{ - return theGuid.Hash (theUpperBound); -} - -Standard_Integer Standard_GUID::Hash(const Standard_Integer Upper) const -{ - if (Upper < 1){ - throw Standard_RangeError("Standard_GUID::Hash: Try to apply HashCode method with negative or null argument."); - } - - char sguid[Standard_GUID_SIZE_ALLOC]; - ToCString(sguid); - - return ::HashCode(sguid,Upper); -} - -Standard_Boolean Standard_GUID::IsEqual(const Standard_GUID& aGuid1,const Standard_GUID& aGuid2) -{ - return (aGuid1 == aGuid2); -} - diff --git a/src/Standard/Standard_GUID.hxx b/src/Standard/Standard_GUID.hxx index 148e511161..2d5a6109f2 100644 --- a/src/Standard/Standard_GUID.hxx +++ b/src/Standard/Standard_GUID.hxx @@ -104,32 +104,12 @@ void operator = (const Standard_UUID& uid) //! Check the format of a GUID string. //! It checks the size, the position of the '-' and the correct size of fields. Standard_EXPORT static Standard_Boolean CheckGUIDFormat (const Standard_CString aGuid); - - //! Hash function for GUID. - Standard_EXPORT Standard_Integer Hash (const Standard_Integer Upper) const; - - //! Computes a hash code for the given GUID of the Standard_Integer type, in the range [1, theUpperBound] - //! @param theGUID the GUID which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - Standard_EXPORT static Standard_Integer HashCode (const Standard_GUID& theGUID, Standard_Integer theUpperBound); - - //! Returns True when the two GUID are the same. - Standard_EXPORT static Standard_Boolean IsEqual (const Standard_GUID& string1, const Standard_GUID& string2); - - - - -protected: - - - + template + friend struct std::hash; private: - - Standard_Integer my32b; Standard_ExtCharacter my16b1; Standard_ExtCharacter my16b2; @@ -140,12 +120,38 @@ private: Standard_Byte my8b4; Standard_Byte my8b5; Standard_Byte my8b6; - - }; - +namespace std +{ + template <> + struct hash + { + size_t operator()(const Standard_GUID& theGUID) const noexcept + { + struct GUID + { + Standard_Integer my32b; + Standard_ExtCharacter my16b1; + Standard_ExtCharacter my16b2; + Standard_ExtCharacter my16b3; + Standard_Byte my8b1; + Standard_Byte my8b2; + Standard_Byte my8b3; + Standard_Byte my8b4; + Standard_Byte my8b5; + Standard_Byte my8b6; + }; + GUID aGUID{ theGUID.my32b, theGUID.my16b1, + theGUID.my16b2, theGUID.my16b3, + theGUID.my8b1, theGUID.my8b2, + theGUID.my8b3, theGUID.my8b4, + theGUID.my8b5, theGUID.my8b6 }; + return opencascade::hashBytes(&aGUID, sizeof(GUID)); + } + }; +} diff --git a/src/Standard/Standard_Handle.hxx b/src/Standard/Standard_Handle.hxx index 6c212951b3..db2d94319a 100644 --- a/src/Standard/Standard_Handle.hxx +++ b/src/Standard/Standard_Handle.hxx @@ -14,7 +14,6 @@ #ifndef _Standard_Handle_HeaderFile #define _Standard_Handle_HeaderFile -#include #include #include #include @@ -399,14 +398,18 @@ namespace opencascade { //! Define Handle() macro #define Handle(Class) opencascade::handle -//! Computes a hash code for the standard handle, in the range [1, theUpperBound] -//! @param theHandle the handle which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -template -Standard_Integer HashCode (const Handle (TheTransientType) & theHandle, const Standard_Integer theUpperBound) +#include + +namespace std { - return ::HashCode (theHandle.get(), theUpperBound); + template + struct hash + { + size_t operator()(const Handle(TheTransientType)& theHandle) const noexcept + { + return static_cast(reinterpret_cast(theHandle.get())); + } + }; } //! For compatibility with previous versions of OCCT, define Handle_Class alias for opencascade::handle. diff --git a/src/Standard/Standard_HashUtils.hxx b/src/Standard/Standard_HashUtils.hxx new file mode 100644 index 0000000000..40b613fcab --- /dev/null +++ b/src/Standard/Standard_HashUtils.hxx @@ -0,0 +1,120 @@ +// Copyright (c) 2023 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _Standard_HashUtils_HeaderFile +#define _Standard_HashUtils_HeaderFile + +#include + +#include +#include +#include +#include + +namespace opencascade +{ + //! Implementation of Murmur hash with autodetect of sizeof(size_t). + //! + //! The default value for the seed is optimal for general cases at a certain hash size. + namespace MurmurHash + { + uint32_t MurmurHash2A(const void* theKey, int theLen, uint32_t theSeed); + uint64_t MurmurHash64A(const void* theKey, int theLen, uint64_t theSeed); + + template + typename std::enable_if::type + hash_combine(const T1& theValue, const int theLen = sizeof(T1), const T theSeed = 0xA329F1D3A586ULL) + { + return MurmurHash::MurmurHash64A(&theValue, theLen, theSeed); + } + + template + typename std::enable_if::type + hash_combine(const T1& theValue, const int theLen = sizeof(T1), const T theSeed = 0xc70f6907U) + { + return static_cast(MurmurHash::MurmurHash2A(&theValue, theLen, theSeed)); + } + + template + constexpr typename std::enable_if::type optimalSeed() + { + return 0xA329F1D3A586ULL; + } + + template + constexpr typename std::enable_if::type optimalSeed() + { + return static_cast(0xc70f6907U); + } + }; + + //! Implementation of FNV-1a with autodetect of sizeof(size_t). + //! This function should work on unsigned char, otherwise it does not + //! correctly implement the FNV-1a algorithm. + //! The existing behaviour is retained for backwards compatibility. + //! + //! The default value for the seed is optimal for general cases at a certain hash size. + namespace FNVHash + { + uint32_t FNVHash1A(const void* theKey, int theLen, uint32_t theSeed); + uint64_t FNVHash64A(const void* theKey, int theLen, uint64_t theSeed); + + template + static typename std::enable_if::type + hash_combine(const T1& theValue, const int theLen = sizeof(T1), const T theSeed = 14695981039346656037ULL) + { + return FNVHash::FNVHash64A(&theValue, theLen, theSeed); + } + + template + static typename std::enable_if::type + hash_combine(const T1& theValue, const int theLen = sizeof(T1), const T theSeed = 2166136261U) + { + return static_cast(FNVHash::FNVHash1A(&theValue, theLen, theSeed)); + } + + template + constexpr typename std::enable_if::type optimalSeed() + { + return 14695981039346656037ULL; + } + + template + constexpr typename std::enable_if::type optimalSeed() + { + return static_cast(2166136261U); + } + }; + + template + T hash(const T1 theValue) noexcept + { + return opencascade::MurmurHash::hash_combine(theValue); + } + + template + T hashBytes(const T1* theKey, int theLen) + { + return opencascade::MurmurHash::hash_combine(*theKey, theLen); + } + + template + T hash_combine(const T1 theValue, const int theLen, const T theSeed) + { + return opencascade::MurmurHash::hash_combine(theValue, theLen, theSeed); + } +} + +#include + +#endif diff --git a/src/Standard/Standard_HashUtils.lxx b/src/Standard/Standard_HashUtils.lxx new file mode 100644 index 0000000000..49834986d2 --- /dev/null +++ b/src/Standard/Standard_HashUtils.lxx @@ -0,0 +1,159 @@ +// Copyright (c) 2023 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#include + +namespace opencascade +{ +namespace MurmurHash +{ +namespace MurmurHashUtils +{ + inline uint64_t shift_mix(uint64_t theV) + { + return theV ^ (theV >> 47); + } + + // Loads n bytes, where 1 <= n < 8. + inline uint64_t load_bytes(const char* thePnt, int theNb) + { + uint64_t aRes = 0; + --theNb; + do + aRes = (aRes << 8) + static_cast(thePnt[theNb]); + while (--theNb >= 0); + return aRes; + } + template + inline T unaligned_load(const char* thePnt) + { + T aRes; + memcpy(&aRes, thePnt, sizeof(aRes)); + return aRes; + } +} + +//======================================================================= +//function : MurmurHash64A +//purpose : +//======================================================================= +inline uint64_t MurmurHash64A(const void* theKey, int theLen, uint64_t theSeed) +{ + static constexpr uint64_t aMul = (((uint64_t)0xc6a4a793UL) << 32UL) + + (uint64_t)0x5bd1e995UL; + const char* const aBuf = static_cast(theKey); + + // Remove the bytes not divisible by the sizeof(uint64_t). This + // allows the main loop to process the data as 64-bit integers. + const uint64_t aLenAligned = theLen & ~(uint64_t)0x7; + const char* const anEnd = aBuf + aLenAligned; + uint64_t aHash = theSeed ^ (theLen * aMul); + for (const char* aPnt = aBuf; aPnt != anEnd; aPnt += 8) + { + const uint64_t aData = MurmurHashUtils::shift_mix(MurmurHashUtils::unaligned_load(aPnt) * aMul) * aMul; + aHash ^= aData; + aHash *= aMul; + } + if ((theLen & 0x7) != 0) + { + const uint64_t data = MurmurHashUtils::load_bytes(anEnd, theLen & 0x7); + aHash ^= data; + aHash *= aMul; + } + aHash = MurmurHashUtils::shift_mix(aHash) * aMul; + aHash = MurmurHashUtils::shift_mix(aHash); + return aHash; +} + +//======================================================================= +//function : MurmurHash2A +//purpose : +//======================================================================= +inline uint32_t MurmurHash2A(const void* theKey, int theLen, uint32_t theSeed) +{ + const uint32_t aMul = 0x5bd1e995; + uint32_t aHash = theSeed ^ theLen; + const char* aBuf = static_cast(theKey); + + // Mix 4 bytes at a time into the hash. + while (theLen >= 4) + { + uint32_t aKey = MurmurHashUtils::unaligned_load(aBuf); + aKey *= aMul; + aKey ^= aKey >> 24; + aKey *= aMul; + aHash *= aMul; + aHash ^= aKey; + aBuf += 4; + theLen -= 4; + } + + uint32_t aKey; + // Handle the last few bytes of the input array. + switch (theLen) + { + case 3: + aKey = static_cast(aBuf[2]); + aHash ^= aKey << 16; + Standard_FALLTHROUGH + case 2: + aKey = static_cast(aBuf[1]); + aHash ^= aKey << 8; + Standard_FALLTHROUGH + case 1: + aKey = static_cast(aBuf[0]); + aHash ^= aKey; + aHash *= aMul; + }; + + // Do a few final mixes of the hash. + aHash ^= aHash >> 13; + aHash *= aMul; + aHash ^= aHash >> 15; + return aHash; +} +} // MurmurHash + +namespace FNVHash +{ +//======================================================================= +//function : FNVHash1A +//purpose : +//======================================================================= +inline uint32_t FNVHash1A(const void* theKey, int theLen, uint32_t theSeed) +{ + const char* cptr = static_cast(theKey); + for (; theLen; --theLen) + { + theSeed ^= static_cast(*cptr++); + theSeed *= static_cast(16777619UL); + } + return theSeed; +} + +//======================================================================= +//function : FNVHash64A +//purpose : +//======================================================================= +inline uint64_t FNVHash64A(const void* theKey, int theLen, uint64_t theSeed) +{ + const char* cptr = static_cast(theKey); + for (; theLen; --theLen) + { + theSeed ^= static_cast(*cptr++); + theSeed *= static_cast(1099511628211ULL); + } + return theSeed; +} +} // FNVHash +} // opencascade diff --git a/src/Standard/Standard_Integer.hxx b/src/Standard/Standard_Integer.hxx index 9858ce7f41..d629b87c06 100755 --- a/src/Standard/Standard_Integer.hxx +++ b/src/Standard/Standard_Integer.hxx @@ -17,7 +17,8 @@ #include #include -#include + +#include // =============== // Inline methods @@ -78,102 +79,19 @@ inline Standard_Integer Square(const Standard_Integer Value) // ------------------------------------------------------------------ // IntegerFirst : Returns the minimum value of an integer // ------------------------------------------------------------------ -inline Standard_Integer IntegerFirst() +constexpr Standard_Integer IntegerFirst() { return INT_MIN; } // ------------------------------------------------------------------ // IntegerLast : Returns the maximum value of an integer // ------------------------------------------------------------------ -inline Standard_Integer IntegerLast() +constexpr Standard_Integer IntegerLast() { return INT_MAX; } // ------------------------------------------------------------------ // IntegerSize : Returns the size in digits of an integer // ------------------------------------------------------------------ -inline Standard_Integer IntegerSize() -{ return BITS(Standard_Integer); } - - -//! Computes a hash code for the given value of some integer type, in range [1, theUpperBound] -//! @tparam TheInteger the type of the integer which hash code is to be computed -//! @param theValue the value of the TheInteger type which hash code is to be computed -//! @param theMask the mask for the last bits of the value that are used in the computation of a hash code -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in range [1, theUpperBound] -template -typename opencascade::std::enable_if::value, Standard_Integer>::type -IntegerHashCode (const TheInteger theValue, - const typename opencascade::disable_deduction::type theMask, - const Standard_Integer theUpperBound) -{ - return static_cast ((theValue & theMask) % theUpperBound + 1); -} - -//! Computes a hash code for the given value of the Standard_Integer type, in range [1, theUpperBound] -//! @param theValue the value of the Standard_Integer type which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in range [1, theUpperBound] -inline Standard_Integer HashCode (const Standard_Integer theValue, - const Standard_Integer theUpperBound) -{ - // return (Abs (theMe) % theUpper) + 1; - return IntegerHashCode(theValue, IntegerLast(), theUpperBound); -} - -// ------------------------------------------------------------------ -// IsEqual : Returns Standard_True if two integers are equal -// ------------------------------------------------------------------ -inline Standard_Boolean IsEqual (const Standard_Integer theOne, - const Standard_Integer theTwo) -{ - return theOne == theTwo; -} - -//! Computes a hash value for the given unsigned integer, in range [1, theUpperBound] -//! @param theValue the unsigned integer which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a hash value computed for the given unsigned integer, in range [1, theUpperBound] -inline Standard_Integer HashCode (const unsigned int theValue, const Standard_Integer theUpperBound) -{ - return ::HashCode (static_cast (theValue), theUpperBound); -} - -//! Computes a hash code for the given value of the "long long int" type, in range [1, theUpperBound] -//! @param theValue the value of the "long long int" type which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in range [1, theUpperBound] -inline Standard_Integer HashCode (const long long int theValue, const Standard_Integer theUpperBound) -{ - return IntegerHashCode(theValue, 0x7fffffffffffffff, theUpperBound); -} - -#if (defined(_LP64) || defined(__LP64__) || defined(_WIN64)) || defined(__APPLE__) - -//! Computes a hash code for the given value of the Standard_Utf32Char type, in the range [1, theUpperBound] -//! @tparam TheUtf32Char the type of the given value (it is Standard_Utf32Char, -//! and must not be the same as "unsigned int", because the overload of the HashCode function -//! for "unsigned int" type is already presented in Standard_Integer.hxx) -//! @param theValue the value of the Standard_Utf32Char type which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -template -typename opencascade::std::enable_if::value - && opencascade::std::is_same::value, - Standard_Integer>::type -HashCode (const TheUtf32Char theValue, const Standard_Integer theUpperBound) -{ - return IntegerHashCode (theValue, IntegerLast(), theUpperBound); -} - -// ------------------------------------------------------------------ -// IsEqual : Returns Standard_True if two integers are equal -// ------------------------------------------------------------------ -inline Standard_Boolean IsEqual (const Standard_Utf32Char theOne, - const Standard_Utf32Char theTwo) -{ - return theOne == theTwo; -} - -#endif +constexpr Standard_Integer IntegerSize() +{ return CHAR_BIT * sizeof(Standard_Integer); } #endif diff --git a/src/Standard/Standard_MMgrRaw.cxx b/src/Standard/Standard_MMgrRaw.cxx deleted file mode 100644 index 83ec139446..0000000000 --- a/src/Standard/Standard_MMgrRaw.cxx +++ /dev/null @@ -1,75 +0,0 @@ -// Created on: 2005-03-15 -// Created by: Peter KURNEV -// Copyright (c) 2005-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#include -#include - -//======================================================================= -//function : Standard_MMgrRaw -//purpose : -//======================================================================= - -Standard_MMgrRaw::Standard_MMgrRaw(const Standard_Boolean aClear) -{ - myClear = aClear; -} - -//======================================================================= -//function : Allocate -//purpose : -//======================================================================= - -Standard_Address Standard_MMgrRaw::Allocate(const Standard_Size aSize) -{ - // the size is rounded up to 4 since some OCC classes - // (e.g. TCollection_AsciiString) assume memory to be double word-aligned - const Standard_Size aRoundSize = (aSize + 3) & ~0x3; - // we use ?: operator instead of if() since it is faster :-) - Standard_Address aPtr = ( myClear ? calloc(aRoundSize, sizeof(char)) : - malloc(aRoundSize) ); - if ( ! aPtr ) - throw Standard_OutOfMemory("Standard_MMgrRaw::Allocate(): malloc failed"); - return aPtr; -} - -//======================================================================= -//function : Free -//purpose : -//======================================================================= - -void Standard_MMgrRaw::Free(Standard_Address theStorage) -{ - free(theStorage); -} - -//======================================================================= -//function : Reallocate -//purpose : -//======================================================================= - -Standard_Address Standard_MMgrRaw::Reallocate(Standard_Address theStorage, - const Standard_Size theSize) -{ - // the size is rounded up to 4 since some OCC classes - // (e.g. TCollection_AsciiString) assume memory to be double word-aligned - const Standard_Size aRoundSize = (theSize + 3) & ~0x3; - Standard_Address newStorage = (Standard_Address)realloc(theStorage, aRoundSize); - if ( ! newStorage ) - throw Standard_OutOfMemory("Standard_MMgrRaw::Reallocate(): realloc failed"); - // Note that it is not possible to ensure that additional memory - // allocated by realloc will be cleared (so as to satisfy myClear mode); - // in order to do that we would need using memset... - return newStorage; -} diff --git a/src/Standard/Standard_MMgrRaw.hxx b/src/Standard/Standard_MMgrRaw.hxx deleted file mode 100644 index f301372b2d..0000000000 --- a/src/Standard/Standard_MMgrRaw.hxx +++ /dev/null @@ -1,49 +0,0 @@ -// Created on: 2005-03-15 -// Created by: Peter KURNEV -// Copyright (c) 2005-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _Standard_MMgrRaw_HeaderFile -#define _Standard_MMgrRaw_HeaderFile - -#include - -/** -* Implementation of raw OCC memory manager which uses standard C -* functions: malloc (or calloc), free and realloc -* without any optimization -*/ - -class Standard_MMgrRaw : public Standard_MMgrRoot -{ - public: - //! Constructor; if aClear is True, the memory will be nullified - //! upon allocation. - Standard_EXPORT Standard_MMgrRaw(const Standard_Boolean aClear=Standard_False); - - //! Allocate aSize bytes - Standard_EXPORT virtual Standard_Address Allocate(const Standard_Size aSize); - - //! Reallocate aPtr to the size aSize. - //! The new pointer is returned. - Standard_EXPORT virtual Standard_Address Reallocate(Standard_Address thePtr, - const Standard_Size theSize); - - //! Free allocated memory. The pointer is nullified. - Standard_EXPORT virtual void Free (Standard_Address thePtr); - - protected: - Standard_Boolean myClear; //! Option to nullify allocated memory -}; - -#endif diff --git a/src/Standard/Standard_MMgrTBBalloc.cxx b/src/Standard/Standard_MMgrTBBalloc.cxx deleted file mode 100644 index 8c7a2df17a..0000000000 --- a/src/Standard/Standard_MMgrTBBalloc.cxx +++ /dev/null @@ -1,87 +0,0 @@ -// Created on: 2010-03-15 -// Created by: Sergey KUUL -// Copyright (c) 2010-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#include -#include - -// paralleling with Intel TBB -#ifdef HAVE_TBB -#pragma comment (lib, "tbbmalloc.lib") -#include -using namespace tbb; -#else -#define scalable_malloc malloc -#define scalable_calloc calloc -#define scalable_realloc realloc -#define scalable_free free -#endif - -//======================================================================= -//function : Standard_MMgrTBBalloc -//purpose : -//======================================================================= - -Standard_MMgrTBBalloc::Standard_MMgrTBBalloc(const Standard_Boolean aClear) -{ - myClear = aClear; -} - -//======================================================================= -//function : Allocate -//purpose : -//======================================================================= - -Standard_Address Standard_MMgrTBBalloc::Allocate(const Standard_Size aSize) -{ - // the size is rounded up to 4 since some OCC classes - // (e.g. TCollection_AsciiString) assume memory to be double word-aligned - const Standard_Size aRoundSize = (aSize + 3) & ~0x3; - // we use ?: operator instead of if() since it is faster :-) - Standard_Address aPtr = ( myClear ? scalable_calloc(aRoundSize, sizeof(char)) : - scalable_malloc(aRoundSize) ); - if ( ! aPtr ) - throw Standard_OutOfMemory("Standard_MMgrTBBalloc::Allocate(): malloc failed"); - return aPtr; -} - -//======================================================================= -//function : Free -//purpose : -//======================================================================= - -void Standard_MMgrTBBalloc::Free (Standard_Address theStorage) -{ - scalable_free (theStorage); -} - -//======================================================================= -//function : Reallocate -//purpose : -//======================================================================= - -Standard_Address Standard_MMgrTBBalloc::Reallocate (Standard_Address theStorage, - const Standard_Size theSize) -{ - // the size is rounded up to 4 since some OCC classes - // (e.g. TCollection_AsciiString) assume memory to be double word-aligned - const Standard_Size aRoundSize = (theSize + 3) & ~0x3; - Standard_Address newStorage = (Standard_Address)scalable_realloc(theStorage, aRoundSize); - if ( ! newStorage ) - throw Standard_OutOfMemory("Standard_MMgrTBBalloc::Reallocate(): realloc failed"); - // Note that it is not possible to ensure that additional memory - // allocated by realloc will be cleared (so as to satisfy myClear mode); - // in order to do that we would need using memset... - return newStorage; -} diff --git a/src/Standard/Standard_MMgrTBBalloc.hxx b/src/Standard/Standard_MMgrTBBalloc.hxx deleted file mode 100644 index 3c6ce08546..0000000000 --- a/src/Standard/Standard_MMgrTBBalloc.hxx +++ /dev/null @@ -1,50 +0,0 @@ -// Created on: 2010-03-15 -// Created by: Sergey KUUL -// Copyright (c) 2010-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _Standard_MMgrTBBalloc_HeaderFile -#define _Standard_MMgrTBBalloc_HeaderFile - -#include - -//! -//! Implementation of OCC memory manager which uses Intel TBB -//! scalable allocator. -//! -//! On configurations where TBB is not available standard RTL functions -//! malloc() / free() are used. - -class Standard_MMgrTBBalloc : public Standard_MMgrRoot -{ - public: - //! Constructor; if aClear is True, the memory will be nullified - //! upon allocation. - Standard_EXPORT Standard_MMgrTBBalloc(const Standard_Boolean aClear=Standard_False); - - //! Allocate aSize bytes - Standard_EXPORT virtual Standard_Address Allocate(const Standard_Size aSize); - - //! Reallocate aPtr to the size aSize. - //! The new pointer is returned. - Standard_EXPORT virtual Standard_Address Reallocate (Standard_Address thePtr, - const Standard_Size theSize); - - //! Free allocated memory - Standard_EXPORT virtual void Free (Standard_Address thePtr); - - protected: - Standard_Boolean myClear; //! Option to nullify allocated memory -}; - -#endif diff --git a/src/Standard/Standard_MemoryUtils.hxx b/src/Standard/Standard_MemoryUtils.hxx new file mode 100644 index 0000000000..21a5622c41 --- /dev/null +++ b/src/Standard/Standard_MemoryUtils.hxx @@ -0,0 +1,62 @@ +// Copyright (c) 2023 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _Standard_MemoryUtils_HeaderFile +#define _Standard_MemoryUtils_HeaderFile + +#include +#include + +#include + +namespace opencascade +{ + template< class T, class... Args > + std::shared_ptr make_shared(Args&&... theArgs) + { + return std::allocate_shared, Args...>(NCollection_Allocator(), + std::forward(theArgs)...); + } + + template< class T, class... Args > + std::shared_ptr make_oshared(const Handle(NCollection_BaseAllocator)& theAlloc, + Args&&... theArgs) + { + return std::allocate_shared, Args...>(NCollection_OccAllocator(theAlloc), + std::forward(theArgs)...); + } + + template< class T, class... Args > + std::shared_ptr make_oshared(const NCollection_OccAllocator& theAlloc, + Args&&... theArgs) + { + return std::allocate_shared, Args...>(theAlloc, + std::forward(theArgs)...); + } + + template< class T, class... Args > + std::shared_ptr make_oshared(NCollection_OccAllocator&& theAlloc, + Args&&... theArgs) + { + return std::allocate_shared, Args...>(std::forward(>theAlloc), + std::forward(theArgs)...); + } + + template + std::unique_ptr make_unique(Args&&... theArgs) + { + return std::unique_ptr(new T(std::forward(theArgs)...)); + } +} + +#endif diff --git a/src/Standard/Standard_PrimitiveTypes.hxx b/src/Standard/Standard_PrimitiveTypes.hxx index 96393da3b2..bef7be9099 100644 --- a/src/Standard/Standard_PrimitiveTypes.hxx +++ b/src/Standard/Standard_PrimitiveTypes.hxx @@ -26,7 +26,5 @@ #include #include #include -#include -#include #endif diff --git a/src/Standard/Standard_Real.cxx b/src/Standard/Standard_Real.cxx index f43762aeed..51721d48d7 100644 --- a/src/Standard/Standard_Real.cxx +++ b/src/Standard/Standard_Real.cxx @@ -20,28 +20,6 @@ static const Standard_Real ACosLimit = 1. + Epsilon(1.); -//============================================================================ -// function : HashCode -// purpose : -//============================================================================ -Standard_Integer HashCode (const Standard_Real theReal, const Standard_Integer theUpperBound) -{ - if (theUpperBound < 1) - { - throw Standard_RangeError ("Try to apply HashCode method with negative or null argument."); - } - union - { - Standard_Real R; - Standard_Integer I[2]; - } U; - - // U.R = Abs(me); // Treat me = -0.0 ADN 27/11/97 - U.R = theReal; - - return HashCode (U.I[0] ^ U.I[1], theUpperBound); -} - //------------------------------------------------------------------- // ACos : Returns the value of the arc cosine of a real //------------------------------------------------------------------- diff --git a/src/Standard/Standard_Real.hxx b/src/Standard/Standard_Real.hxx index 43a95d717d..f185568f51 100644 --- a/src/Standard/Standard_Real.hxx +++ b/src/Standard/Standard_Real.hxx @@ -16,9 +16,16 @@ #define _Standard_Real_HeaderFile #include +#include #include -#include -#include + +#ifdef _MSC_VER +#ifndef _USE_MATH_DEFINES +#define _USE_MATH_DEFINES +#endif +#include +#endif + #include // =============================================== @@ -31,12 +38,6 @@ // Methods implemented in Standard_Real.cxx // ================================== -//! Computes a hash code for the given real, in the range [1, theUpperBound] -//! @param theReal the real value which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -Standard_EXPORT Standard_Integer HashCode (Standard_Real theReal, Standard_Integer theUpperBound); - Standard_EXPORT Standard_Real ACos (const Standard_Real ); Standard_EXPORT Standard_Real ACosApprox (const Standard_Real ); Standard_EXPORT Standard_Real ASin (const Standard_Real ); @@ -56,7 +57,7 @@ Standard_EXPORT Standard_Real Sqrt (const Standard_Real ); //------------------------------------------------------------------- // RealSmall : Returns the smallest positive real //------------------------------------------------------------------- -inline Standard_Real RealSmall() +constexpr Standard_Real RealSmall() { return DBL_MIN; } //------------------------------------------------------------------- @@ -84,60 +85,60 @@ inline Standard_Boolean IsEqual (const Standard_Real Value1, //------------------------------------------------------------------- // RealDigit : Returns the number of digits of precision in a real //------------------------------------------------------------------- -inline Standard_Integer RealDigits() +constexpr Standard_Integer RealDigits() { return DBL_DIG; } //------------------------------------------------------------------- // RealEpsilon : Returns the minimum positive real such that // 1.0 + x is not equal to 1.0 //------------------------------------------------------------------- -inline Standard_Real RealEpsilon() +constexpr Standard_Real RealEpsilon() { return DBL_EPSILON; } //------------------------------------------------------------------- // RealFirst : Returns the minimum negative value of a real //------------------------------------------------------------------- -inline Standard_Real RealFirst() +constexpr Standard_Real RealFirst() { return -DBL_MAX; } //------------------------------------------------------------------- // RealFirst10Exp : Returns the minimum value of exponent(base 10) of // a real. //------------------------------------------------------------------- -inline Standard_Integer RealFirst10Exp() +constexpr Standard_Integer RealFirst10Exp() { return DBL_MIN_10_EXP; } //------------------------------------------------------------------- // RealLast : Returns the maximum value of a real //------------------------------------------------------------------- -inline Standard_Real RealLast() +constexpr Standard_Real RealLast() { return DBL_MAX; } //------------------------------------------------------------------- // RealLast10Exp : Returns the maximum value of exponent(base 10) of // a real. //------------------------------------------------------------------- -inline Standard_Integer RealLast10Exp() +constexpr Standard_Integer RealLast10Exp() { return DBL_MAX_10_EXP; } //------------------------------------------------------------------- // RealMantissa : Returns the size in bits of the matissa part of a // real. //------------------------------------------------------------------- -inline Standard_Integer RealMantissa() +constexpr Standard_Integer RealMantissa() { return DBL_MANT_DIG; } //------------------------------------------------------------------- // RealRadix : Returns the radix of exponent representation //------------------------------------------------------------------- -inline Standard_Integer RealRadix() +constexpr Standard_Integer RealRadix() { return FLT_RADIX; } //------------------------------------------------------------------- // RealSize : Returns the size in bits of an integer //------------------------------------------------------------------- -inline Standard_Integer RealSize() -{ return BITS(Standard_Real); } +constexpr Standard_Integer RealSize() +{ return CHAR_BIT * sizeof(Standard_Real); } diff --git a/src/Standard/Standard_ShortReal.cxx b/src/Standard/Standard_ShortReal.cxx deleted file mode 100644 index f3c123e13c..0000000000 --- a/src/Standard/Standard_ShortReal.cxx +++ /dev/null @@ -1,36 +0,0 @@ -// Copyright (c) 1998-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#include -#include - -//============================================================================ -// function : HashCode -// purpose : -//============================================================================ -Standard_Integer HashCode (const Standard_ShortReal theShortReal, const Standard_Integer theUpperBound) -{ - if (theUpperBound < 1) - { - throw Standard_RangeError ("Try to apply HashCode method with negative or null argument."); - } - union - { - Standard_ShortReal R; - Standard_Integer I; - } U; - U.R = theShortReal; - - return HashCode (U.I, theUpperBound); -} diff --git a/src/Standard/Standard_ShortReal.hxx b/src/Standard/Standard_ShortReal.hxx index 81d07405eb..34230ca469 100644 --- a/src/Standard/Standard_ShortReal.hxx +++ b/src/Standard/Standard_ShortReal.hxx @@ -16,9 +16,9 @@ #define _Standard_ShortReal_HeaderFile #include +#include #include -#include #include // *********************************** // @@ -31,7 +31,7 @@ //------------------------------------------------------------------- // ShortRealSmall : Returns the smallest positive ShortReal //------------------------------------------------------------------- -inline Standard_ShortReal ShortRealSmall() +constexpr Standard_ShortReal ShortRealSmall() { return FLT_MIN; } //------------------------------------------------------------------- @@ -47,14 +47,14 @@ inline Standard_ShortReal Abs(const Standard_ShortReal Value) //------------------------------------------------------------------- // ShortRealDigit : Returns the number of digits of precision in a ShortReal //------------------------------------------------------------------- -inline Standard_Integer ShortRealDigits() +constexpr Standard_Integer ShortRealDigits() { return FLT_DIG; } //------------------------------------------------------------------- // ShortRealEpsilon : Returns the minimum positive ShortReal such that // 1.0 + x is not equal to 1.0 //------------------------------------------------------------------- -inline Standard_ShortReal ShortRealEpsilon() +constexpr Standard_ShortReal ShortRealEpsilon() { return FLT_EPSILON; } //------------------------------------------------------------------- @@ -68,40 +68,40 @@ inline Standard_ShortReal ShortRealFirst() // ShortRealFirst10Exp : Returns the minimum value of exponent(base 10) of // a ShortReal. //------------------------------------------------------------------- -inline Standard_Integer ShortRealFirst10Exp() +constexpr Standard_Integer ShortRealFirst10Exp() { return FLT_MIN_10_EXP; } //------------------------------------------------------------------- // ShortRealLast : Returns the maximum value of a ShortReal //------------------------------------------------------------------- -inline Standard_ShortReal ShortRealLast() +constexpr Standard_ShortReal ShortRealLast() { return FLT_MAX; } //------------------------------------------------------------------- // ShortRealLast10Exp : Returns the maximum value of exponent(base 10) of // a ShortReal. //------------------------------------------------------------------- -inline Standard_Integer ShortRealLast10Exp() +constexpr Standard_Integer ShortRealLast10Exp() { return FLT_MAX_10_EXP; } //------------------------------------------------------------------- // ShortRealMantissa : Returns the size in bits of the matissa part of a // ShortReal. //------------------------------------------------------------------- -inline Standard_Integer ShortRealMantissa() +constexpr Standard_Integer ShortRealMantissa() { return FLT_MANT_DIG; } //------------------------------------------------------------------- // ShortRealRadix : Returns the radix of exponent representation //------------------------------------------------------------------- -inline Standard_Integer ShortRealRadix() +constexpr Standard_Integer ShortRealRadix() { return FLT_RADIX; } //------------------------------------------------------------------- // ShortRealSize : Returns the size in bits of an integer //------------------------------------------------------------------- -inline Standard_Integer ShortRealSize() -{ return BITS(Standard_ShortReal); } +constexpr Standard_Integer ShortRealSize() +{ return CHAR_BIT * sizeof(Standard_ShortReal); } //------------------------------------------------------------------- // Max : Returns the maximum value of two ShortReals @@ -129,29 +129,6 @@ inline Standard_ShortReal Min (const Standard_ShortReal Val1, } } -// =============================================== -// Methods from Standard_Entity class which are redefined: -// - Hascode -// - IsEqual -// =============================================== - -// ================================== -// Methods implemented in Standard_ShortReal.cxx -// ================================== - -//! Computes a hash code for the given short real, in the range [1, theUpperBound] -//! @param theShortReal the short real value which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -Standard_EXPORT Standard_Integer HashCode (Standard_ShortReal theShortReal, Standard_Integer theUpperBound); - -//------------------------------------------------------------------- -// IsEqual : Returns Standard_True if two ShortReals are equal -//------------------------------------------------------------------- -inline Standard_Boolean IsEqual (const Standard_ShortReal Value1, - const Standard_ShortReal Value2) -{ return Abs((Value1 - Value2)) < ShortRealSmall(); } - #endif diff --git a/src/Standard/Standard_Size.hxx b/src/Standard/Standard_Size.hxx deleted file mode 100644 index e8d8e8d4ef..0000000000 --- a/src/Standard/Standard_Size.hxx +++ /dev/null @@ -1,54 +0,0 @@ -// Created on: 2006-08-22 -// Created by: Alexander GRIGORIEV -// Copyright (c) 2006-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _Standard_Size_HeaderFile -#define _Standard_Size_HeaderFile - -#include - -// msv 26.05.2009: add HashCode and IsEqual functions - -//! Computes a hash code for the given value of the Standard_Size type, in the range [1, theUpperBound] -//! @tparam TheSize the type of the given value (it is Standard_Size, -//! and must not be the same as "unsigned int", because the overload of the HashCode function -//! for "unsigned int" type is already presented in Standard_Integer.hxx) -//! @param theValue the value of the Standard_Size type which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -template -typename opencascade::std::enable_if::value - && opencascade::std::is_same::value, - Standard_Integer>::type -HashCode (const TheSize theValue, const Standard_Integer theUpperBound) -{ - Standard_Size aKey = ~theValue + (theValue << 18); - aKey ^= (aKey >> 31); - aKey *= 21; - aKey ^= (aKey >> 11); - aKey += (aKey << 6); - aKey ^= (aKey >> 22); - return IntegerHashCode(aKey, IntegerLast(), theUpperBound); -} - -// ------------------------------------------------------------------ -// IsEqual : Returns Standard_True if two values are equal -// ------------------------------------------------------------------ -inline Standard_Boolean IsEqual(const Standard_Size One, - const Standard_Size Two) -{ - return One == Two; -} - -#endif diff --git a/src/Standard/Standard_ThreadId.hxx b/src/Standard/Standard_ThreadId.hxx index b4d06260ee..9cdd9a4765 100644 --- a/src/Standard/Standard_ThreadId.hxx +++ b/src/Standard/Standard_ThreadId.hxx @@ -16,7 +16,6 @@ #ifndef Standard_ThreadId_HeaderFile #define Standard_ThreadId_HeaderFile -#include // Platform-independent definition of the thread identifier type typedef Standard_Size Standard_ThreadId; diff --git a/src/Standard/Standard_Transient.cxx b/src/Standard/Standard_Transient.cxx index 09455a9278..fa71956bfa 100644 --- a/src/Standard/Standard_Transient.cxx +++ b/src/Standard/Standard_Transient.cxx @@ -1,5 +1,5 @@ // Copyright (c) 1998-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS +// Copyright (c) 1999-2023 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // @@ -12,17 +12,12 @@ // Alternatively, this file may be used under the terms of Open CASCADE // commercial license or contractual agreement. -#include #include -#include + +#include #include #include -void Standard_Transient::Delete() const -{ - delete this; -} - const Handle(Standard_Type)& Standard_Transient::get_type_descriptor () { return opencascade::type_instance::get(); @@ -71,15 +66,3 @@ Standard_Transient* Standard_Transient::This() const throw Standard_ProgramError("Attempt to create handle to object created in stack, not yet constructed, or destroyed"); return const_cast (this); } - -// Increment reference counter -void Standard_Transient::IncrementRefCounter() const -{ - Standard_Atomic_Increment (&myRefCount_); -} - -// Decrement reference counter -Standard_Integer Standard_Transient::DecrementRefCounter() const -{ - return Standard_Atomic_Decrement(&myRefCount_); -} diff --git a/src/Standard/Standard_Transient.hxx b/src/Standard/Standard_Transient.hxx index dd0f58dad1..024c631d27 100644 --- a/src/Standard/Standard_Transient.hxx +++ b/src/Standard/Standard_Transient.hxx @@ -1,5 +1,5 @@ // Copyright (c) 1998-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS +// Copyright (c) 1999-2023 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // @@ -19,9 +19,12 @@ #include #include +#include + class Standard_Type; -namespace opencascade { +namespace opencascade +{ template class handle; } @@ -48,15 +51,12 @@ public: //! Destructor must be virtual virtual ~Standard_Transient() {} - //! Memory deallocator for transient classes - Standard_EXPORT virtual void Delete() const; - public: //!@name Support of run-time type information (RTTI) typedef void base_type; - static const char* get_type_name () { return "Standard_Transient"; } + static constexpr const char* get_type_name () { return "Standard_Transient"; } //! Returns type descriptor of Standard_Transient class Standard_EXPORT static const opencascade::handle& get_type_descriptor (); @@ -90,34 +90,35 @@ public: //!@name Reference counting, for use by handle<> //! Get the reference counter of this object - Standard_Integer GetRefCount() const { return myRefCount_; } + inline Standard_Integer GetRefCount() const noexcept { return myRefCount_; } //! Increments the reference counter of this object - Standard_EXPORT void IncrementRefCounter() const; + inline void IncrementRefCounter() noexcept + { + myRefCount_.operator++(); + } //! Decrements the reference counter of this object; //! returns the decremented value - Standard_EXPORT Standard_Integer DecrementRefCounter() const; + inline Standard_Integer DecrementRefCounter() noexcept + { + return myRefCount_.operator--(); + } + + //! Memory deallocator for transient classes + virtual void Delete() const + { + delete this; + } private: //! Reference counter. //! Note use of underscore, aimed to reduce probability //! of conflict with names of members of derived classes. - mutable volatile Standard_Integer myRefCount_; + std::atomic_int myRefCount_; }; - -//! Computes a hash code for the given transient object, in the range [1, theUpperBound] -//! @param theTransientObject the transient object which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -inline Standard_Integer HashCode (const Standard_Transient* const theTransientObject, - const Standard_Integer theUpperBound) -{ - return ::HashCode (static_cast (theTransientObject), theUpperBound); -} - //! Definition of Handle_Standard_Transient as typedef for compatibility typedef opencascade::handle Handle_Standard_Transient; diff --git a/src/Standard/Standard_Type.cxx b/src/Standard/Standard_Type.cxx index 546cbafa85..6321deab29 100644 --- a/src/Standard/Standard_Type.cxx +++ b/src/Standard/Standard_Type.cxx @@ -15,29 +15,20 @@ #include #include +#include -#include +#include IMPLEMENT_STANDARD_RTTIEXT(Standard_Type,Standard_Transient) //============================================================================ -namespace { -static Standard_CString copy_string (const char* theString) -{ - size_t aLength = strlen (theString); - char* aResult = static_cast (Standard::Allocate (aLength + 1)); - strncpy (aResult, theString, aLength + 1); //including null-character - return aResult; -} -} - -Standard_Type::Standard_Type (const char* theSystemName, +Standard_Type::Standard_Type (const std::type_info& theInfo, const char* theName, Standard_Size theSize, const Handle(Standard_Type)& theParent) : - mySystemName(copy_string (theSystemName)), - myName(copy_string (theName)), + myInfo(theInfo), + myName(theName), mySize(theSize), myParent(theParent) { @@ -70,25 +61,8 @@ void Standard_Type::Print (Standard_OStream& AStream) const //============================================================================ namespace { - // Value-based hasher for plain C string (char*) - struct CStringHasher - { - //! Computes a hash code of the given Standard_CString, in the range [1, theUpperBound] - //! @param theKey the key which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const Standard_CString& theKey, const Standard_Integer theUpperBound) - { - return ::HashCode (theKey, theUpperBound); - } - static bool IsEqual (const Standard_CString& theKey1, const Standard_CString& theKey2) - { - return ! strcmp (theKey1, theKey2); - } - }; - // Map of string to type - typedef NCollection_DataMap registry_type; + typedef std::unordered_map registry_type; // Registry is made static in the function to ensure that it gets // initialized by the time of first access @@ -102,7 +76,7 @@ namespace { Handle(Standard_Type) theType = STANDARD_TYPE(Standard_Transient); } -Standard_Type* Standard_Type::Register (const char* theSystemName, const char* theName, +Standard_Type* Standard_Type::Register (const std::type_info& theInfo, const char* theName, Standard_Size theSize, const Handle(Standard_Type)& theParent) { // Access to registry is protected by mutex; it should not happen often because @@ -113,17 +87,15 @@ Standard_Type* Standard_Type::Register (const char* theSystemName, const char* t // return existing descriptor if already in the registry registry_type& aRegistry = GetRegistry(); Standard_Type* aType = 0; - if (aRegistry.Find (theSystemName, aType)) - return aType; + auto anIter = aRegistry.find(theInfo); + if (anIter != aRegistry.end()) + return anIter->second; // else create a new descriptor - aType = new Standard_Type (theSystemName, theName, theSize, theParent); + aType = new Standard_Type (theInfo, theName, theSize, theParent); // then add it to registry and return (the reference to the handle stored in the registry) - aRegistry.Bind (aType->mySystemName, aType); - -// std::cout << "Registering " << theSystemName << ": " << aRegistry.Extent() << std::endl; - + aRegistry.emplace(theInfo, aType); return aType; } @@ -131,9 +103,5 @@ Standard_Type::~Standard_Type () { // remove descriptor from the registry registry_type& aRegistry = GetRegistry(); - Standard_ASSERT(aRegistry.UnBind (mySystemName), "Standard_Type::~Standard_Type() cannot find itself in registry",); - -// std::cout << "Unregistering " << mySystemName << ": " << aRegistry.Extent() << std::endl; - Standard::Free (mySystemName); - Standard::Free (myName); + Standard_ASSERT(aRegistry.erase(myInfo) > 0, "Standard_Type::~Standard_Type() cannot find itself in registry",); } diff --git a/src/Standard/Standard_Type.hxx b/src/Standard/Standard_Type.hxx index 65b6826a81..6608b757e9 100644 --- a/src/Standard/Standard_Type.hxx +++ b/src/Standard/Standard_Type.hxx @@ -21,6 +21,7 @@ #include #include +#include // Auxiliary tools to check at compile time that class declared as base in // DEFINE_STANDARD_RTTI* macro is actually a base class. @@ -146,7 +147,7 @@ class Standard_Type : public Standard_Transient public: //! Returns the system type name of the class (typeinfo.name) - Standard_CString SystemName() const { return mySystemName; } + Standard_CString SystemName() const { return myInfo.name(); } //! Returns the given name of the class type (get_type_name) Standard_CString Name() const { return myName; } @@ -181,14 +182,14 @@ public: //! Register a type; returns either new or existing descriptor. //! - //! @param theSystemName name of the class as returned by typeid(class).name() + //! @param theInfo object stores system name of the class //! @param theName name of the class to be stored in Name field //! @param theSize size of the class instance //! @param theParent base class in the Transient hierarchy //! //! Note that this function is intended for use by opencascade::type_instance only. Standard_EXPORT static - Standard_Type* Register (const char* theSystemName, const char* theName, + Standard_Type* Register (const std::type_info& theInfo, const char* theName, Standard_Size theSize, const Handle(Standard_Type)& theParent); //! Destructor removes the type from the registry @@ -200,11 +201,11 @@ public: private: //! Constructor is private - Standard_Type (const char* theSystemName, const char* theName, + Standard_Type (const std::type_info& theInfo, const char* theName, Standard_Size theSize, const Handle(Standard_Type)& theParent); private: - Standard_CString mySystemName; //!< System name of the class (typeinfo.name) + std::type_index myInfo; //!< Object to store system name of the class Standard_CString myName; //!< Given name of the class Standard_Size mySize; //!< Size of the class instance, in bytes Handle(Standard_Type) myParent; //!< Type descriptor of parent class @@ -252,7 +253,7 @@ namespace opencascade { // static variable inside function ensures that descriptors // are initialized in correct sequence static Handle(Standard_Type) anInstance = - Standard_Type::Register (typeid(T).name(), T::get_type_name(), sizeof(T), + Standard_Type::Register (typeid(T), T::get_type_name(), sizeof(T), type_instance::get()); return anInstance; } diff --git a/src/Standard/Standard_math.cxx b/src/Standard/Standard_math.cxx deleted file mode 100644 index c711d4a450..0000000000 --- a/src/Standard/Standard_math.cxx +++ /dev/null @@ -1,46 +0,0 @@ -// Copyright (c) 1998-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#include - -// MSVC versions prior to 12 did not provided acosh, asinh, atanh functions in standard library -#if defined(_MSC_VER) && (_MSC_VER < 1800) - -Standard_EXPORT double __cdecl acosh( double X) -{ - double res; - res = log(X + sqrt(X * X - 1)); - return res; -}; -Standard_EXPORT double __cdecl asinh( double X) -{ - double res; -// Modified by Sergey KHROMOV - Mon Nov 11 16:27:11 2002 Begin -// Correction of the formula to avoid numerical problems. -// res = log(X + sqrt(X * X + 1)); - if (X > 0.) - res = log(X + sqrt(X * X + 1)); - else - res = -log(sqrt(X * X + 1) - X); -// Modified by Sergey KHROMOV - Mon Nov 11 16:27:13 2002 End - return res; -}; -Standard_EXPORT double __cdecl atanh( double X) -{ - double res; - res = log((1 + X) / (1 - X)) / 2; - return res; -}; - -#endif diff --git a/src/Standard/Standard_math.hxx b/src/Standard/Standard_math.hxx deleted file mode 100644 index a2eb9790a3..0000000000 --- a/src/Standard/Standard_math.hxx +++ /dev/null @@ -1,40 +0,0 @@ -// Copyright (c) 1991-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef Standard_math_HeaderFile -#define Standard_math_HeaderFile - -#ifndef _Standard_Macro_HeaderFile -#include -#endif - -#ifdef _MSC_VER - -#ifndef _USE_MATH_DEFINES -#define _USE_MATH_DEFINES -#endif - -#include - -// MSVC versions prior to 12 did not provided acosh, asinh, atanh functions in standard library -#if _MSC_VER < 1800 -Standard_EXPORT double __cdecl acosh ( double ); -Standard_EXPORT double __cdecl asinh ( double ); -Standard_EXPORT double __cdecl atanh ( double ); -#endif - -#endif /* _MSC_VER */ - - -#endif diff --git a/src/Standard/Standard_values.h b/src/Standard/Standard_values.h deleted file mode 100644 index 8d397dd84e..0000000000 --- a/src/Standard/Standard_values.h +++ /dev/null @@ -1,40 +0,0 @@ -/* - Copyright (c) 1991-1999 Matra Datavision - Copyright (c) 1999-2014 OPEN CASCADE SAS - - This file is part of Open CASCADE Technology software library. - - This library is free software; you can redistribute it and/or modify it under - the terms of the GNU Lesser General Public License version 2.1 as published - by the Free Software Foundation, with special exception defined in the file - OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT - distribution for complete text of the license and disclaimer of any warranty. - - Alternatively, this file may be used under the terms of Open CASCADE - commercial license or contractual agreement. -*/ - -#ifndef _Standard_values_HeaderFile -# define _Standard_values_HeaderFile - -#if defined(_MSC_VER) -# include -#else -# include -#endif - -#if defined (__hpux) || defined (HPUX) -# ifdef MAXINT -# undef MAXINT -# endif -#endif - -#ifndef BITSPERBYTE -# define BITSPERBYTE CHAR_BIT -#endif -#ifndef BITS -# define BITS(type) (BITSPERBYTE * sizeof(type)) -#endif - -#endif - diff --git a/src/StdObjMgt/StdObjMgt_MapOfInstantiators.hxx b/src/StdObjMgt/StdObjMgt_MapOfInstantiators.hxx index 87142c0003..619d5fd12f 100644 --- a/src/StdObjMgt/StdObjMgt_MapOfInstantiators.hxx +++ b/src/StdObjMgt/StdObjMgt_MapOfInstantiators.hxx @@ -21,16 +21,14 @@ class StdObjMgt_MapOfInstantiators : public NCollection_DataMap + StdObjMgt_Persistent::Instantiator> { public: template void Bind (const TCollection_AsciiString& theTypeName) { NCollection_DataMap + StdObjMgt_Persistent::Instantiator> ::Bind (theTypeName, Persistent::template Instantiate); } diff --git a/src/StdStorage/StdStorage_MapOfRoots.hxx b/src/StdStorage/StdStorage_MapOfRoots.hxx index 89401fd5a7..ccd8ec19d1 100644 --- a/src/StdStorage/StdStorage_MapOfRoots.hxx +++ b/src/StdStorage/StdStorage_MapOfRoots.hxx @@ -19,7 +19,7 @@ #include #include -typedef NCollection_IndexedDataMap StdStorage_MapOfRoots; -typedef NCollection_IndexedDataMap::Iterator StdStorage_DataMapIteratorOfMapOfRoots; +typedef NCollection_IndexedDataMap StdStorage_MapOfRoots; +typedef NCollection_IndexedDataMap::Iterator StdStorage_DataMapIteratorOfMapOfRoots; #endif // StdStorage_MapOfRoots_HeaderFile diff --git a/src/StdStorage/StdStorage_MapOfTypes.hxx b/src/StdStorage/StdStorage_MapOfTypes.hxx index b6acbe346b..d52a5e444d 100644 --- a/src/StdStorage/StdStorage_MapOfTypes.hxx +++ b/src/StdStorage/StdStorage_MapOfTypes.hxx @@ -21,7 +21,7 @@ #include #include -typedef NCollection_IndexedDataMap StdStorage_MapOfTypes; +typedef NCollection_IndexedDataMap StdStorage_MapOfTypes; #endif diff --git a/src/StepData/StepData_FreeFormEntity.cxx b/src/StepData/StepData_FreeFormEntity.cxx index 04acffa1b4..56c8395d02 100644 --- a/src/StepData/StepData_FreeFormEntity.cxx +++ b/src/StepData/StepData_FreeFormEntity.cxx @@ -86,14 +86,15 @@ void StepData_FreeFormEntity::SetStepType (const Standard_CString typenam) e1 = e1->Next(); } // d abord effacer les next en cours ... - NCollection_DataMap::Iterator iter(dic); - for (; iter.More(); iter.Next()) { + for (NCollection_DataMap::Iterator iter(dic); + iter.More(); iter.Next()) { e1 = GetCasted(StepData_FreeFormEntity,iter.Value()); if (!e1.IsNull()) e1->SetNext(e2); } // ... puis les remettre dans l ordre e1.Nullify(); - for (iter.Reset(); iter.More(); iter.Next()) { + for (NCollection_DataMap::Iterator iter(dic); + iter.More(); iter.Next()) { e2 = GetCasted(StepData_FreeFormEntity,iter.Value()); if (!e1.IsNull()) e1->SetNext(e2); e1 = e2; diff --git a/src/StepToTopoDS/FILES b/src/StepToTopoDS/FILES index 26c27041ad..5d6ef2b87e 100644 --- a/src/StepToTopoDS/FILES +++ b/src/StepToTopoDS/FILES @@ -3,8 +3,6 @@ StepToTopoDS.hxx StepToTopoDS_Builder.cxx StepToTopoDS_Builder.hxx StepToTopoDS_BuilderError.hxx -StepToTopoDS_CartesianPointHasher.cxx -StepToTopoDS_CartesianPointHasher.hxx StepToTopoDS_DataMapIteratorOfDataMapOfRI.hxx StepToTopoDS_DataMapIteratorOfDataMapOfRINames.hxx StepToTopoDS_DataMapIteratorOfDataMapOfTRI.hxx @@ -23,8 +21,6 @@ StepToTopoDS_NMTool.hxx StepToTopoDS_PointEdgeMap.hxx StepToTopoDS_PointPair.cxx StepToTopoDS_PointPair.hxx -StepToTopoDS_PointPairHasher.cxx -StepToTopoDS_PointPairHasher.hxx StepToTopoDS_PointVertexMap.hxx StepToTopoDS_Root.cxx StepToTopoDS_Root.hxx diff --git a/src/StepToTopoDS/StepToTopoDS_CartesianPointHasher.cxx b/src/StepToTopoDS/StepToTopoDS_CartesianPointHasher.cxx deleted file mode 100644 index 6deba8805d..0000000000 --- a/src/StepToTopoDS/StepToTopoDS_CartesianPointHasher.cxx +++ /dev/null @@ -1,42 +0,0 @@ -// Created on: 1993-08-30 -// Created by: Martine LANGLOIS -// Copyright (c) 1993-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - - -#include -#include - -//======================================================================= -// function : HashCode -// purpose : -//======================================================================= -Standard_Integer StepToTopoDS_CartesianPointHasher::HashCode (const Handle (StepGeom_CartesianPoint) - & theCartesianPoint, - const Standard_Integer theUpperBound) -{ - return ::HashCode (theCartesianPoint, theUpperBound); -} - -//======================================================================= -//function : IsEqual -//purpose : -//======================================================================= - -Standard_Boolean StepToTopoDS_CartesianPointHasher::IsEqual - (const Handle(StepGeom_CartesianPoint)& K1, - const Handle(StepGeom_CartesianPoint)& K2) -{ - return (K1 == K2); -} diff --git a/src/StepToTopoDS/StepToTopoDS_CartesianPointHasher.hxx b/src/StepToTopoDS/StepToTopoDS_CartesianPointHasher.hxx deleted file mode 100644 index 4c8a8bbc22..0000000000 --- a/src/StepToTopoDS/StepToTopoDS_CartesianPointHasher.hxx +++ /dev/null @@ -1,68 +0,0 @@ -// Created on: 1993-08-30 -// Created by: Martine LANGLOIS -// Copyright (c) 1993-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _StepToTopoDS_CartesianPointHasher_HeaderFile -#define _StepToTopoDS_CartesianPointHasher_HeaderFile - -#include -#include -#include - -#include -class StepGeom_CartesianPoint; - - - -class StepToTopoDS_CartesianPointHasher -{ -public: - - DEFINE_STANDARD_ALLOC - - //! Computes a hash code for the cartesian point, in the range [1, theUpperBound] - //! @param theCartesianPoint the cartesian point which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - Standard_EXPORT static Standard_Integer HashCode (const Handle (StepGeom_CartesianPoint) & theCartesianPoint, - Standard_Integer theUpperBound); - - //! Returns True when the two CartesianPoint are the same - Standard_EXPORT static Standard_Boolean IsEqual (const Handle(StepGeom_CartesianPoint)& K1, const Handle(StepGeom_CartesianPoint)& K2); - - - - -protected: - - - - - -private: - - - - - -}; - - - - - - - -#endif // _StepToTopoDS_CartesianPointHasher_HeaderFile diff --git a/src/StepToTopoDS/StepToTopoDS_DataMapOfRI.hxx b/src/StepToTopoDS/StepToTopoDS_DataMapOfRI.hxx index 064fc50aa7..68837f6d99 100644 --- a/src/StepToTopoDS/StepToTopoDS_DataMapOfRI.hxx +++ b/src/StepToTopoDS/StepToTopoDS_DataMapOfRI.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap StepToTopoDS_DataMapOfRI; -typedef NCollection_DataMap::Iterator StepToTopoDS_DataMapIteratorOfDataMapOfRI; +typedef NCollection_DataMap StepToTopoDS_DataMapOfRI; +typedef NCollection_DataMap::Iterator StepToTopoDS_DataMapIteratorOfDataMapOfRI; #endif diff --git a/src/StepToTopoDS/StepToTopoDS_DataMapOfRINames.hxx b/src/StepToTopoDS/StepToTopoDS_DataMapOfRINames.hxx index b9cf814562..3510dbfa0e 100644 --- a/src/StepToTopoDS/StepToTopoDS_DataMapOfRINames.hxx +++ b/src/StepToTopoDS/StepToTopoDS_DataMapOfRINames.hxx @@ -21,8 +21,8 @@ #include #include -typedef NCollection_DataMap StepToTopoDS_DataMapOfRINames; -typedef NCollection_DataMap::Iterator StepToTopoDS_DataMapIteratorOfDataMapOfRINames; +typedef NCollection_DataMap StepToTopoDS_DataMapOfRINames; +typedef NCollection_DataMap::Iterator StepToTopoDS_DataMapIteratorOfDataMapOfRINames; #endif diff --git a/src/StepToTopoDS/StepToTopoDS_DataMapOfTRI.hxx b/src/StepToTopoDS/StepToTopoDS_DataMapOfTRI.hxx index 5b001f4425..f473281b2e 100644 --- a/src/StepToTopoDS/StepToTopoDS_DataMapOfTRI.hxx +++ b/src/StepToTopoDS/StepToTopoDS_DataMapOfTRI.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap StepToTopoDS_DataMapOfTRI; -typedef NCollection_DataMap::Iterator StepToTopoDS_DataMapIteratorOfDataMapOfTRI; +typedef NCollection_DataMap StepToTopoDS_DataMapOfTRI; +typedef NCollection_DataMap::Iterator StepToTopoDS_DataMapIteratorOfDataMapOfTRI; #endif diff --git a/src/StepToTopoDS/StepToTopoDS_PointEdgeMap.hxx b/src/StepToTopoDS/StepToTopoDS_PointEdgeMap.hxx index d5f1784166..1c32a82e1e 100644 --- a/src/StepToTopoDS/StepToTopoDS_PointEdgeMap.hxx +++ b/src/StepToTopoDS/StepToTopoDS_PointEdgeMap.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap StepToTopoDS_PointEdgeMap; -typedef NCollection_DataMap::Iterator StepToTopoDS_DataMapIteratorOfPointEdgeMap; +typedef NCollection_DataMap StepToTopoDS_PointEdgeMap; +typedef NCollection_DataMap::Iterator StepToTopoDS_DataMapIteratorOfPointEdgeMap; #endif diff --git a/src/StepToTopoDS/StepToTopoDS_PointPair.cxx b/src/StepToTopoDS/StepToTopoDS_PointPair.cxx index add5804ed3..65cafd8617 100644 --- a/src/StepToTopoDS/StepToTopoDS_PointPair.cxx +++ b/src/StepToTopoDS/StepToTopoDS_PointPair.cxx @@ -17,7 +17,6 @@ #include #include -#include //======================================================================= //function : StepToTopoDS_PointPair diff --git a/src/StepToTopoDS/StepToTopoDS_PointPair.hxx b/src/StepToTopoDS/StepToTopoDS_PointPair.hxx index ecbbc0bd91..a4dbdcb118 100644 --- a/src/StepToTopoDS/StepToTopoDS_PointPair.hxx +++ b/src/StepToTopoDS/StepToTopoDS_PointPair.hxx @@ -23,7 +23,6 @@ class StepGeom_CartesianPoint; - //! Stores a pair of Points from step class StepToTopoDS_PointPair { @@ -34,9 +33,21 @@ public: Standard_EXPORT StepToTopoDS_PointPair(const Handle(StepGeom_CartesianPoint)& P1, const Handle(StepGeom_CartesianPoint)& P2); + const Handle(StepGeom_CartesianPoint)& GetPoint1() const + { + return myP1; + } -friend class StepToTopoDS_PointPairHasher; + const Handle(StepGeom_CartesianPoint)& GetPoint2() const + { + return myP2; + } + bool operator==(const StepToTopoDS_PointPair& thePointPair) const + { + return (((myP1 == thePointPair.myP1) && (myP2 == thePointPair.myP2)) || + ((myP1 == thePointPair.myP2) && (myP2 == thePointPair.myP1))); + } protected: @@ -54,6 +65,25 @@ private: }; +namespace std +{ + template <> + struct hash + { + size_t operator()(const StepToTopoDS_PointPair& thePointPair) const noexcept + { + // Combine two int values into a single hash value. + size_t aCombination[2]; + aCombination[0] = std::hash{}(thePointPair.GetPoint1()); + aCombination[1] = std::hash{}(thePointPair.GetPoint2()); + if (aCombination[0] > aCombination[1]) + { + std::swap(aCombination[0], aCombination[1]); + } + return opencascade::hashBytes(aCombination, sizeof(aCombination)); + } + }; +} diff --git a/src/StepToTopoDS/StepToTopoDS_PointPairHasher.cxx b/src/StepToTopoDS/StepToTopoDS_PointPairHasher.cxx deleted file mode 100644 index 22324ec390..0000000000 --- a/src/StepToTopoDS/StepToTopoDS_PointPairHasher.cxx +++ /dev/null @@ -1,44 +0,0 @@ -// Created on: 1993-08-06 -// Created by: Martine LANGLOIS -// Copyright (c) 1993-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - - -#include -#include -#include - -//======================================================================= -// function : HashCode -// purpose : -//======================================================================= -Standard_Integer StepToTopoDS_PointPairHasher::HashCode (const StepToTopoDS_PointPair& thePointPair, - const Standard_Integer theUpperBound) -{ - return ::HashCode (::HashCode (thePointPair.myP1, theUpperBound) + ::HashCode (thePointPair.myP2, theUpperBound), - theUpperBound); -} - -//======================================================================= -//function : IsEqual -//purpose : -//======================================================================= - -Standard_Boolean StepToTopoDS_PointPairHasher::IsEqual - (const StepToTopoDS_PointPair& P1, - const StepToTopoDS_PointPair& P2) -{ - return (((P1.myP1 == P2.myP1) && (P1.myP2 == P2.myP2)) || - ((P1.myP1 == P2.myP2) && (P1.myP2 == P2.myP1))); -} diff --git a/src/StepToTopoDS/StepToTopoDS_PointPairHasher.hxx b/src/StepToTopoDS/StepToTopoDS_PointPairHasher.hxx deleted file mode 100644 index efc515a772..0000000000 --- a/src/StepToTopoDS/StepToTopoDS_PointPairHasher.hxx +++ /dev/null @@ -1,66 +0,0 @@ -// Created on: 1993-08-06 -// Created by: Martine LANGLOIS -// Copyright (c) 1993-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _StepToTopoDS_PointPairHasher_HeaderFile -#define _StepToTopoDS_PointPairHasher_HeaderFile - -#include -#include - -#include -class StepToTopoDS_PointPair; - - - -class StepToTopoDS_PointPairHasher -{ -public: - - DEFINE_STANDARD_ALLOC - - //! Computes a hash code for the point pair, in the range [1, theUpperBound] - //! @param thePointPair the point pair which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - Standard_EXPORT static Standard_Integer HashCode (const StepToTopoDS_PointPair& thePointPair, Standard_Integer theUpperBound); - - //! Returns True when the two PointPair are the same - Standard_EXPORT static Standard_Boolean IsEqual (const StepToTopoDS_PointPair& K1, const StepToTopoDS_PointPair& K2); - - - - -protected: - - - - - -private: - - - - - -}; - - - - - - - -#endif // _StepToTopoDS_PointPairHasher_HeaderFile diff --git a/src/StepToTopoDS/StepToTopoDS_PointVertexMap.hxx b/src/StepToTopoDS/StepToTopoDS_PointVertexMap.hxx index 75cba0c08c..024fb765da 100644 --- a/src/StepToTopoDS/StepToTopoDS_PointVertexMap.hxx +++ b/src/StepToTopoDS/StepToTopoDS_PointVertexMap.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap StepToTopoDS_PointVertexMap; -typedef NCollection_DataMap::Iterator StepToTopoDS_DataMapIteratorOfPointVertexMap; +typedef NCollection_DataMap StepToTopoDS_PointVertexMap; +typedef NCollection_DataMap::Iterator StepToTopoDS_DataMapIteratorOfPointVertexMap; #endif diff --git a/src/Storage/Storage_MapOfCallBack.hxx b/src/Storage/Storage_MapOfCallBack.hxx index 079eba5f66..3d67aea007 100644 --- a/src/Storage/Storage_MapOfCallBack.hxx +++ b/src/Storage/Storage_MapOfCallBack.hxx @@ -21,8 +21,8 @@ #include #include -typedef NCollection_DataMap Storage_MapOfCallBack; -typedef NCollection_DataMap::Iterator Storage_DataMapIteratorOfMapOfCallBack; +typedef NCollection_DataMap Storage_MapOfCallBack; +typedef NCollection_DataMap::Iterator Storage_DataMapIteratorOfMapOfCallBack; #endif diff --git a/src/Storage/Storage_MapOfPers.hxx b/src/Storage/Storage_MapOfPers.hxx index cbde1b89a9..412561bb0b 100644 --- a/src/Storage/Storage_MapOfPers.hxx +++ b/src/Storage/Storage_MapOfPers.hxx @@ -21,8 +21,8 @@ #include #include -typedef NCollection_DataMap Storage_MapOfPers; -typedef NCollection_DataMap::Iterator Storage_DataMapIteratorOfMapOfPers; +typedef NCollection_DataMap Storage_MapOfPers; +typedef NCollection_DataMap::Iterator Storage_DataMapIteratorOfMapOfPers; #endif diff --git a/src/Storage/Storage_PType.hxx b/src/Storage/Storage_PType.hxx index 9a90b69cbf..ccf8b21127 100644 --- a/src/Storage/Storage_PType.hxx +++ b/src/Storage/Storage_PType.hxx @@ -21,7 +21,7 @@ #include #include -typedef NCollection_IndexedDataMap Storage_PType; +typedef NCollection_IndexedDataMap Storage_PType; #endif diff --git a/src/Storage/Storage_Schema.cxx b/src/Storage/Storage_Schema.cxx index bb617809b0..06fc5c0670 100644 --- a/src/Storage/Storage_Schema.cxx +++ b/src/Storage/Storage_Schema.cxx @@ -718,75 +718,80 @@ void Storage_Schema::Clear() const // containing migration types table: oldtype - newtype //======================================================================= Standard_Boolean Storage_Schema::CheckTypeMigration( - const TCollection_AsciiString& oldName, - TCollection_AsciiString& newName) + const TCollection_AsciiString& oldName, + TCollection_AsciiString& newName) { static Standard_Boolean isChecked(Standard_False); static DataMapOfAStringAString aDMap; Standard_Boolean aMigration(Standard_False); - - if(!isChecked) { + + if (!isChecked) + { isChecked = Standard_True; -// TCollection_AsciiString aFileName = getenv("CSF_MIGRATION_TYPES"); + // TCollection_AsciiString aFileName = getenv("CSF_MIGRATION_TYPES"); OSD_Environment csf(TCollection_AsciiString("CSF_MIGRATION_TYPES")); TCollection_AsciiString aFileName = csf.Value(); - if(aFileName.Length() > 0) { - OSD_Path aPath(aFileName,OSD_Default); - OSD_File aFile; - aFile.SetPath(aPath); - if(aFile.Exists()) { - OSD_Protection aProt(OSD_R,OSD_R,OSD_R,OSD_R); - aFile.Open(OSD_ReadOnly, aProt); - if(aFile.IsOpen() && aFile.IsReadable()) { - TCollection_AsciiString aLine; - Standard_Integer aNbReaded(0); - for (;;) { - aFile.ReadLine(aLine, 80, aNbReaded); - if(aFile.IsAtEnd() || !aNbReaded) { - aFile.Close(); - break; - } + OSD_File aFile; + OSD_Path aPath(aFileName, OSD_Default); + aFile.SetPath(aPath); + if (aFile.Exists()) + { + OSD_Protection aProt(OSD_R, OSD_R, OSD_R, OSD_R); + aFile.Open(OSD_ReadOnly, aProt); + if (aFile.IsOpen() && aFile.IsReadable()) + { + TCollection_AsciiString aLine; + Standard_Integer aNbReaded(0); + for (;;) + { + aFile.ReadLine(aLine, 80, aNbReaded); + if (aFile.IsAtEnd() || !aNbReaded) + { + aFile.Close(); + break; + } #ifdef OCCT_DEBUG - std::cout << "Storage_Sheme:: Line: = " << aLine <(strlen(theString))); memcpy (mystring, theString, mylength); - mystring[mylength] = '\0'; } @@ -79,36 +60,28 @@ TCollection_AsciiString::TCollection_AsciiString (const Standard_CString theStri // ---------------------------------------------------------------------------- TCollection_AsciiString::TCollection_AsciiString (const Standard_CString theString, const Standard_Integer theLen) -: mystring (NULL), - mylength (0) { if (theString == NULL) { throw Standard_NullObject ("TCollection_AsciiString(): NULL pointer passed to constructor"); } - - for (; mylength < theLen && theString[mylength] != '\0'; ++mylength) {} - mystring = Allocate (mylength + 1); + int aLength = 0; + for (; aLength < theLen && theString[aLength] != '\0'; ++aLength) {} + allocate (aLength); memcpy (mystring, theString, mylength); - mystring[mylength] = '\0'; } // ---------------------------------------------------------------------------- // Create an asciistring from a Standard_Character // ---------------------------------------------------------------------------- TCollection_AsciiString::TCollection_AsciiString(const Standard_Character aChar) - : mystring(0) { if ( aChar != '\0' ) { - mylength = 1; - mystring = Allocate(2); + allocate(1); mystring[0] = aChar; - mystring[1] = '\0'; } else { - mylength = 0; - mystring = Allocate(mylength+1); - mystring[mylength] = '\0'; + allocate(0); } } @@ -118,50 +91,59 @@ TCollection_AsciiString::TCollection_AsciiString(const Standard_Character aChar) TCollection_AsciiString::TCollection_AsciiString(const Standard_Integer length, const Standard_Character filler ) { - mystring = Allocate(length+1); - mylength = length; - for (int i = 0 ; i < length ; i++) mystring[i] = filler; - mystring[length] = '\0'; + allocate(length); + memset(mystring, filler, length); } // ---------------------------------------------------------------------------- // Create an AsciiString from an Integer // ---------------------------------------------------------------------------- TCollection_AsciiString::TCollection_AsciiString(const Standard_Integer aValue) - : mystring(0) { char t [13]; - mylength = Sprintf( t,"%d",aValue); - mystring = Allocate(mylength+1); + allocate(Sprintf(t, "%d", aValue)); memcpy (mystring, t, mylength); - mystring[mylength] = '\0'; } // ---------------------------------------------------------------------------- // Create an asciistring from a real // ---------------------------------------------------------------------------- TCollection_AsciiString::TCollection_AsciiString(const Standard_Real aValue) - : mystring(0) { char t [50]; - mylength = Sprintf( t,"%g",aValue); - mystring = Allocate(mylength+1); + allocate(Sprintf(t, "%g", aValue)); memcpy (mystring, t, mylength); - mystring[mylength] = '\0'; } // ---------------------------------------------------------------------------- // Create an asciistring from an asciistring // ---------------------------------------------------------------------------- TCollection_AsciiString::TCollection_AsciiString (const TCollection_AsciiString& theString) -: mystring (Allocate (theString.mylength + 1)), - mylength (theString.mylength) { + allocate(theString.mylength); if (mylength != 0) { memcpy (mystring, theString.mystring, mylength); } - mystring[mylength] = '\0'; +} + +//======================================================================= +//function : TCollection_AsciiString +//purpose : +//======================================================================= +TCollection_AsciiString::TCollection_AsciiString(TCollection_AsciiString&& theOther) Standard_Noexcept +{ + if (theOther.mystring == THE_DEFAULT_CHAR_STRING) + { + allocate(0); + } + else + { + mystring = theOther.mystring; + mylength = theOther.mylength; + } + theOther.mylength = 0; + theOther.mystring = THE_DEFAULT_CHAR_STRING; } // ---------------------------------------------------------------------------- @@ -169,16 +151,13 @@ TCollection_AsciiString::TCollection_AsciiString (const TCollection_AsciiString& // ---------------------------------------------------------------------------- TCollection_AsciiString::TCollection_AsciiString (const TCollection_AsciiString& theString, const Standard_Character theChar) -: mystring (NULL), - mylength (theString.mylength + 1) { - mystring = Allocate (mylength + 1); + allocate (theString.mylength + 1); if (theString.mylength != 0) { memcpy (mystring, theString.mystring, theString.mylength); } mystring[mylength - 1] = theChar; - mystring[mylength] = '\0'; } // ---------------------------------------------------------------------------- @@ -186,11 +165,9 @@ TCollection_AsciiString::TCollection_AsciiString (const TCollection_AsciiString& // ---------------------------------------------------------------------------- TCollection_AsciiString::TCollection_AsciiString (const TCollection_AsciiString& theString1, const Standard_CString theString2) -: mystring (0) { const Standard_Integer aStr2Len = Standard_Integer (theString2 ? strlen (theString2) : 0); - mylength = theString1.mylength + aStr2Len; - mystring = Allocate (mylength + 1); + allocate (theString1.mylength + aStr2Len); if (theString1.mylength != 0) { memcpy (mystring, theString1.mystring, theString1.mylength); @@ -199,7 +176,6 @@ TCollection_AsciiString::TCollection_AsciiString (const TCollection_AsciiString& { memcpy (mystring + theString1.mylength, theString2, aStr2Len); } - mystring[mylength] = '\0'; } // ---------------------------------------------------------------------------- @@ -207,10 +183,8 @@ TCollection_AsciiString::TCollection_AsciiString (const TCollection_AsciiString& // ---------------------------------------------------------------------------- TCollection_AsciiString::TCollection_AsciiString (const TCollection_AsciiString& theString1, const TCollection_AsciiString& theString2) -: mystring (0), - mylength (theString1.mylength + theString2.mylength) { - mystring = Allocate (mylength + 1); + allocate (theString1.mylength + theString2.mylength); if (theString1.mylength) { memcpy (mystring, theString1.mystring, theString1.mylength); @@ -219,30 +193,25 @@ TCollection_AsciiString::TCollection_AsciiString (const TCollection_AsciiString& { memcpy (mystring + theString1.mylength, theString2.mystring, theString2.mylength); } - mystring[mylength] = '\0'; } //--------------------------------------------------------------------------- // Create an asciistring from an ExtendedString //--------------------------------------------------------------------------- TCollection_AsciiString::TCollection_AsciiString(const TCollection_ExtendedString& astring, - const Standard_Character replaceNonAscii) -: mystring (0) + const Standard_Character replaceNonAscii) { if (replaceNonAscii) { - mylength = astring.Length(); - mystring = Allocate(mylength+1); + allocate(astring.Length()); for(int i = 0; i < mylength; i++) { Standard_ExtCharacter c = astring.Value(i+1); mystring[i] = ( IsAnAscii(c) ? ToCharacter(c) : replaceNonAscii ); } - mystring[mylength] = '\0'; } else { // create UTF-8 string - mylength = astring.LengthOfCString(); - mystring = Allocate(mylength+1); + allocate(astring.LengthOfCString()); astring.ToUTF8CString(mystring); } } @@ -251,16 +220,13 @@ TCollection_AsciiString::TCollection_AsciiString(const TCollection_ExtendedStrin // Create an TCollection_AsciiString from a Standard_WideChar //--------------------------------------------------------------------------- TCollection_AsciiString::TCollection_AsciiString (const Standard_WideChar* theStringUtf) -: mystring (NULL), - mylength (0) { + int aLength = 0; for (NCollection_UtfWideIter anIter (theStringUtf); *anIter != 0; ++anIter) { - mylength += anIter.AdvanceBytesUtf8(); + aLength += anIter.AdvanceBytesUtf8(); } - - mystring = Allocate (mylength + 1); - mystring[mylength] = '\0'; + allocate (aLength); NCollection_UtfWideIter anIterRead (theStringUtf); for (Standard_Utf8Char* anIterWrite = mystring; *anIterRead != 0; ++anIterRead) { @@ -294,10 +260,8 @@ void TCollection_AsciiString::AssignCat(const Standard_Real other) void TCollection_AsciiString::AssignCat(const Standard_Character other) { if (other != '\0') { - mystring = Reallocate (mystring, mylength + 2); - mystring[mylength] = other ; - mylength += 1; - mystring[mylength] = '\0'; + reallocate (mylength + 1); + mystring[mylength - 1] = other; } } @@ -314,10 +278,9 @@ void TCollection_AsciiString::AssignCat (const Standard_CString theOther) Standard_Integer anOtherLen = Standard_Integer (strlen (theOther)); if (anOtherLen != 0) { - const Standard_Integer aNewLen = mylength + anOtherLen; - mystring = Reallocate (mystring, aNewLen + 1); - memcpy (mystring + mylength, theOther, anOtherLen + 1); - mylength = aNewLen; + const Standard_Integer anOldLength = mylength; + reallocate (mylength + anOtherLen); + memcpy (mystring + anOldLength, theOther, anOtherLen + 1); } } @@ -328,10 +291,9 @@ void TCollection_AsciiString::AssignCat (const TCollection_AsciiString& theOther { if (theOther.mylength != 0) { - const Standard_Integer aNewLen = mylength + theOther.mylength; - mystring = Reallocate (mystring, aNewLen + 1); - memcpy (mystring + mylength, theOther.mystring, theOther.mylength + 1); - mylength = aNewLen; + const Standard_Integer anOldLength = mylength; + reallocate(mylength + theOther.mylength); + memcpy (mystring + anOldLength, theOther.mystring, theOther.mylength + 1); } } @@ -384,13 +346,7 @@ void TCollection_AsciiString::ChangeAll(const Standard_Character aChar, // ---------------------------------------------------------------------------- void TCollection_AsciiString::Clear() { - if ( mylength > 0 ) - { - Free (mystring); - mylength = 0; - mystring = Allocate(mylength+1); - mystring[mylength] = '\0'; - } + deallocate(); } // ---------------------------------------------------------------------------- @@ -398,14 +354,19 @@ void TCollection_AsciiString::Clear() // ---------------------------------------------------------------------------- void TCollection_AsciiString::Copy(const Standard_CString fromwhere) { - if (fromwhere) { - mylength = Standard_Integer( strlen( fromwhere )); - mystring = Reallocate (mystring, mylength + 1); - memcpy (mystring, fromwhere, mylength + 1); + if (fromwhere == mystring) + { + return; } - else { + if (fromwhere && fromwhere[0] != '\0') + { + reallocate (static_cast(strlen(fromwhere))); + memcpy (mystring, fromwhere, mylength); + } + else + { mylength = 0; - mystring[mylength] = '\0'; + mystring = THE_DEFAULT_CHAR_STRING; } } @@ -414,22 +375,51 @@ void TCollection_AsciiString::Copy(const Standard_CString fromwhere) // ---------------------------------------------------------------------------- void TCollection_AsciiString::Copy(const TCollection_AsciiString& fromwhere) { - if (fromwhere.mystring) { - mylength = fromwhere.mylength; - mystring = Reallocate (mystring, mylength + 1); - memcpy (mystring, fromwhere.mystring, mylength + 1); + if (&fromwhere == this) + { + return; } - else { + if (fromwhere.mystring && fromwhere.mylength > 0) + { + reallocate (fromwhere.mylength); + memcpy (mystring, fromwhere.mystring, mylength); + } + else if (mystring != THE_DEFAULT_CHAR_STRING) + { mylength = 0; mystring[mylength] = '\0'; } } +//======================================================================= +//function : Move +//purpose : +//======================================================================= +void TCollection_AsciiString::Move(TCollection_AsciiString&& theOther) +{ + if (&theOther == this) + { + return; + } + if (mystring != THE_DEFAULT_CHAR_STRING) + { + Standard::Free(mystring); + } + mystring = theOther.mystring; + mylength = theOther.mylength; + theOther.mystring = THE_DEFAULT_CHAR_STRING; + theOther.mylength = 0; +} + // ---------------------------------------------------------------------------- // Swap // ---------------------------------------------------------------------------- void TCollection_AsciiString::Swap (TCollection_AsciiString& theOther) { + if (&theOther == this) + { + return; + } std::swap (mystring, theOther.mystring); std::swap (mylength, theOther.mylength); } @@ -439,9 +429,7 @@ void TCollection_AsciiString::Swap (TCollection_AsciiString& theOther) // ---------------------------------------------------------------------------- TCollection_AsciiString::~TCollection_AsciiString() { - if (mystring) - Free (mystring); - mystring = 0L; + deallocate (); } // ---------------------------------------------------------------------------- @@ -493,14 +481,13 @@ void TCollection_AsciiString::Insert(const Standard_Integer where, if (where > mylength + 1 ) throw Standard_OutOfRange("TCollection_AsciiString::Insert : Parameter where is too big"); if (where < 1) throw Standard_OutOfRange("TCollection_AsciiString::Insert : Parameter where is too small"); - mystring = Reallocate (mystring, mylength + 2); - if (where != mylength +1) { - for (int i=mylength-1; i >= where-1; i--) + const int anOldLength = mylength; + reallocate (mylength + 1); + if (where != anOldLength +1) { + for (int i= anOldLength -1; i >= where-1; i--) mystring[i+1] = mystring[i]; } mystring[where-1] = what; - mylength++; - mystring[mylength] = '\0'; } // ---------------------------------------------------------------------------- @@ -511,19 +498,15 @@ void TCollection_AsciiString::Insert(const Standard_Integer where, { if (where <= mylength + 1 && where > 0) { if(what) { - Standard_Integer whatlength = Standard_Integer( strlen( what ) ); - Standard_Integer newlength = mylength + whatlength; - - mystring = Reallocate (mystring, newlength + 1); - if (where != mylength +1) { - for (int i=mylength-1; i >= where-1; i--) + const Standard_Integer whatlength = Standard_Integer( strlen( what ) ); + const int anOldLength = mylength; + reallocate (mylength + whatlength); + if (where != anOldLength +1) { + for (int i= anOldLength -1; i >= where-1; i--) mystring[i+whatlength] = mystring[i]; } for (int i=0; i < whatlength; i++) mystring[where-1+i] = what[i]; - - mylength = newlength; - mystring[mylength] = '\0'; } } else { @@ -540,21 +523,17 @@ void TCollection_AsciiString::Insert(const Standard_Integer where, { Standard_CString swhat = what.mystring; if (where <= mylength + 1) { - Standard_Integer whatlength = what.mylength; + const Standard_Integer whatlength = what.mylength; if(whatlength) { - Standard_Integer newlength = mylength + whatlength; - - mystring = Reallocate (mystring, newlength + 1); + const int anOldLength = mylength; + reallocate (mylength + whatlength); - if (where != mylength +1) { - for (int i=mylength-1; i >= where-1; i--) + if (where != anOldLength +1) { + for (int i= anOldLength -1; i >= where-1; i--) mystring[i+whatlength] = mystring[i]; } for (int i=0; i < whatlength; i++) mystring[where-1+i] = swhat[i]; - - mylength = newlength; - mystring[mylength] = '\0'; } } else { @@ -805,10 +784,9 @@ void TCollection_AsciiString::LeftJustify(const Standard_Integer Width, const Standard_Character Filler) { if (Width > mylength) { - mystring = Reallocate (mystring, Width + 1); - for (int i = mylength; i < Width ; i++) mystring[i] = Filler; - mylength = Width; - mystring[mylength] = '\0'; + const int anOldLength = mylength; + reallocate (Width); + for (int i = anOldLength; i < Width ; i++) mystring[i] = Filler; } else if (Width < 0) { throw Standard_NegativeValue(); @@ -910,10 +888,8 @@ void TCollection_AsciiString::Read(Standard_IStream& astream) astream.width( oldWidth ); // put to string - mylength = Standard_Integer( strlen( buffer )); - mystring = Reallocate (mystring, mylength + 1); + reallocate (Standard_Integer(strlen(buffer))); memcpy (mystring, buffer, mylength); - mystring[mylength] = '\0'; } @@ -962,7 +938,6 @@ void TCollection_AsciiString::RemoveAll(const Standard_Character what, } } mylength = c; - mystring[mylength] = '\0'; } // ---------------------------------------------------------------------------- @@ -975,7 +950,6 @@ void TCollection_AsciiString::RemoveAll(const Standard_Character what) for (int i=0; i < mylength; i++) if (mystring[i] != what) mystring[c++] = mystring[i]; mylength = c; - mystring[mylength] = '\0'; } // ---------------------------------------------------------------------------- @@ -1017,16 +991,13 @@ void TCollection_AsciiString::RightAdjust () void TCollection_AsciiString::RightJustify(const Standard_Integer Width, const Standard_Character Filler) { - Standard_Integer i ; - Standard_Integer k ; if (Width > mylength) { - mystring = Reallocate (mystring, Width + 1); - - for ( i = mylength-1, k = Width-1 ; i >= 0 ; i--, k--) + const int anOldLength = mylength; + reallocate (Width); + int i, k; + for ( i = anOldLength-1, k = Width-1 ; i >= 0 ; i--, k--) mystring[k] = mystring[i]; for(; k >= 0 ; k--) mystring[k] = Filler; - mylength = Width; - mystring[mylength] = '\0'; } else if (Width < 0) { throw Standard_NegativeValue(); @@ -1145,12 +1116,10 @@ void TCollection_AsciiString::SetValue(const Standard_Integer where, Standard_Integer size = Standard_Integer( what ? strlen( what ) : 0 ); size += (where - 1); if (size >= mylength) { - mystring = Reallocate (mystring, size + 1); - mylength = size; + reallocate (size); } for (int i = where-1; i < size; i++) mystring[i] = what[i-(where-1)]; - mystring[mylength] = '\0'; } else { throw Standard_OutOfRange("TCollection_AsciiString::SetValue : " @@ -1169,12 +1138,10 @@ void TCollection_AsciiString::SetValue(const Standard_Integer where, Standard_CString swhat = what.mystring; size += (where - 1); if (size >= mylength) { - mystring = Reallocate (mystring, size + 1); - mylength = size; + reallocate (size); } for (int i = where-1; i < size; i++) mystring[i] = swhat[i-(where-1)]; - mystring[mylength] = '\0'; } else { throw Standard_OutOfRange("TCollection_AsciiString::SetValue : " @@ -1182,21 +1149,6 @@ void TCollection_AsciiString::SetValue(const Standard_Integer where, } } -// ---------------------------------------------------------------------------- -// Split -// Private -// ---------------------------------------------------------------------------- -void TCollection_AsciiString::Split(const Standard_Integer where, - TCollection_AsciiString& res) -{ - if (where >= 0 && where <= mylength) { - res = &mystring[where] ; - Trunc(where); - return ; - } - throw Standard_OutOfRange("TCollection_AsciiString::Split index"); - return ; -} // ---------------------------------------------------------------------------- // Split @@ -1212,39 +1164,6 @@ TCollection_AsciiString TCollection_AsciiString::Split throw Standard_OutOfRange("TCollection_AsciiString::Split index"); } -// ---------------------------------------------------------------------------- -// SubString -// Private -// ---------------------------------------------------------------------------- -void TCollection_AsciiString::SubString(const Standard_Integer FromIndex, - const Standard_Integer ToIndex, - TCollection_AsciiString& res) const -{ - - if (ToIndex > mylength || FromIndex <= 0 || FromIndex > ToIndex ) - { - throw Standard_OutOfRange(); - } - - Standard_Integer newlength = ToIndex-FromIndex+1; - res.mystring =Reallocate (res.mystring, newlength + 1); - memcpy (res.mystring, mystring + FromIndex - 1, newlength); - res.mystring[newlength] = '\0'; - res.mylength = newlength; - return ; -} - -// ---------------------------------------------------------------------------- -// Token -// Private -// ---------------------------------------------------------------------------- -void TCollection_AsciiString::Token(const Standard_CString separators, - const Standard_Integer whichone, - TCollection_AsciiString& res)const -{ - res = Token( separators , whichone ) ; -} - // ---------------------------------------------------------------------------- // Token // ---------------------------------------------------------------------------- @@ -1344,3 +1263,65 @@ Standard_Character TCollection_AsciiString::Value } throw Standard_OutOfRange("TCollection_AsciiString::Value : parameter where"); } + +//======================================================================= +//function : allocate +//purpose : +//======================================================================= +void TCollection_AsciiString::allocate(const int theLength) +{ + mylength = theLength; + if (theLength == 0) + { + mystring = THE_DEFAULT_CHAR_STRING; + } + else + { + const Standard_Size aRoundSize = (theLength + 4) & ~0x3; + mystring = static_cast( + Standard::AllocateOptimal(aRoundSize)); + mystring[mylength] = '\0'; + } +} + +//======================================================================= +//function : reallocate +//purpose : +//======================================================================= +void TCollection_AsciiString::reallocate(const int theLength) +{ + if (theLength != 0) + { + if (mystring == THE_DEFAULT_CHAR_STRING) + { + const Standard_Size aRoundSize = (theLength + 4) & ~0x3; + mystring = static_cast( + Standard::AllocateOptimal(aRoundSize)); + } + else + { + mystring = static_cast( + Standard::Reallocate(mystring, theLength + 1)); + } + mystring[theLength] = '\0'; + } + if (mystring != THE_DEFAULT_CHAR_STRING) + { + mystring[theLength] = '\0'; + } + mylength = theLength; +} + +//======================================================================= +//function : deallocate +//purpose : +//======================================================================= +void TCollection_AsciiString::deallocate() +{ + if (mystring != THE_DEFAULT_CHAR_STRING) + { + Standard::Free(mystring); + } + mylength = 0; + mystring = THE_DEFAULT_CHAR_STRING; +} diff --git a/src/TCollection/TCollection_AsciiString.hxx b/src/TCollection/TCollection_AsciiString.hxx index 0e5d2ff82a..b017ef4857 100644 --- a/src/TCollection/TCollection_AsciiString.hxx +++ b/src/TCollection/TCollection_AsciiString.hxx @@ -75,13 +75,7 @@ public: Standard_EXPORT TCollection_AsciiString(const TCollection_AsciiString& astring); //! Move constructor - TCollection_AsciiString (TCollection_AsciiString&& theOther) Standard_Noexcept - : mystring (theOther.mystring), - mylength (theOther.mylength) - { - theOther.mystring = NULL; - theOther.mylength = 0; - } + Standard_EXPORT TCollection_AsciiString (TCollection_AsciiString&& theOther) Standard_Noexcept; //! Initializes a AsciiString with copy of another AsciiString //! concatenated with the message character. @@ -268,17 +262,27 @@ void operator = (const Standard_CString fromwhere) //! Used as operator = //! Example: aString = anotherString; Standard_EXPORT void Copy (const TCollection_AsciiString& fromwhere); -void operator = (const TCollection_AsciiString& fromwhere) -{ - Copy(fromwhere); -} + + //! Copy assignment operator + TCollection_AsciiString& operator= (const TCollection_AsciiString& theOther) + { + Copy(theOther); + return *this; + } + + //! Moves string without reallocations + Standard_EXPORT void Move (TCollection_AsciiString&& theOther); + + //! Move assignment operator + TCollection_AsciiString& operator= (TCollection_AsciiString&& theOther) noexcept + { + Move(std::forward(theOther)); + return *this; + } //! Exchange the data of two strings (without reallocating memory). Standard_EXPORT void Swap (TCollection_AsciiString& theOther); - //! Move assignment operator - TCollection_AsciiString& operator= (TCollection_AsciiString&& theOther) Standard_Noexcept { Swap (theOther); return *this; } - //! Frees memory allocated by AsciiString. Standard_EXPORT ~TCollection_AsciiString(); @@ -670,12 +674,10 @@ friend Standard_EXPORT Standard_IStream& operator >> (Standard_IStream& astream, //! aString.Value(2) returns 'e' Standard_EXPORT Standard_Character Value (const Standard_Integer where) const; - //! Computes a hash code for the given ASCII string, in the range [1, theUpperBound]. + //! Computes a hash code for the given ASCII string //! Returns the same integer value as the hash function for TCollection_ExtendedString - //! @param theAsciiString the ASCII string which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const TCollection_AsciiString& theAsciiString, Standard_Integer theUpperBound); + //! @return a computed hash code + size_t HashCode() const; //! Returns True when the two strings are the same. //! (Just for HashCode for AsciiString) @@ -694,17 +696,19 @@ friend class TCollection_HAsciiString; private: - Standard_EXPORT void Split (const Standard_Integer where, TCollection_AsciiString& result); - - Standard_EXPORT void SubString (const Standard_Integer FromIndex, const Standard_Integer ToIndex, TCollection_AsciiString& result) const; - - Standard_EXPORT void Token (const Standard_CString separators, const Standard_Integer whichone, TCollection_AsciiString& result) const; + //! Internal wrapper to allocate on stack or heap + void allocate(const int theLength); + + //! Internal wrapper to reallocate on stack or heap + void reallocate(const int theLength); + + //! Internal wrapper to deallocate on stack + void deallocate(); private: - Standard_PCharacter mystring; //!< NULL-terminated string - Standard_Integer mylength; //!< length in bytes (excluding terminating NULL symbol) - + Standard_PCharacter mystring{}; //!< NULL-terminated string + Standard_Integer mylength{}; //!< length in bytes (excluding terminating NULL symbol) }; #include diff --git a/src/TCollection/TCollection_AsciiString.lxx b/src/TCollection/TCollection_AsciiString.lxx index 2eef2fd155..056e24382c 100644 --- a/src/TCollection/TCollection_AsciiString.lxx +++ b/src/TCollection/TCollection_AsciiString.lxx @@ -14,19 +14,23 @@ #include #include +#include +#include "TCollection_AsciiString.hxx" // definition global methods for using in NCollection -//! Computes a hash code for the given ASCII string, in the range [1, theUpperBound] -//! @param theAsciiString the ASCII string which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -inline Standard_Integer HashCode (const TCollection_AsciiString& theAsciiString, const Standard_Integer theUpperBound) +namespace std { - return TCollection_AsciiString::HashCode (theAsciiString, theUpperBound); + template <> + struct hash + { + size_t operator()(const TCollection_AsciiString& theString) const + { + return theString.HashCode(); + } + }; } - //------------------------------------------------------------------------ // IsEqual //------------------------------------------------------------------------ @@ -36,8 +40,6 @@ inline Standard_Boolean IsEqual(const TCollection_AsciiString& string1, return TCollection_AsciiString::IsEqual(string1,string2); } - - // ---------------------------------------------------------------------------- // ToCString // ---------------------------------------------------------------------------- @@ -83,10 +85,13 @@ inline TCollection_AsciiString TCollection_AsciiString::Cat(const Standard_Real // function : HashCode // purpose : //============================================================================ -inline Standard_Integer TCollection_AsciiString::HashCode (const TCollection_AsciiString& theAsciiString, - const Standard_Integer theUpperBound) +inline size_t TCollection_AsciiString::HashCode() const { - return ::HashCode (theAsciiString.ToCString(), theAsciiString.Length(), theUpperBound); + if (mylength < 4) + { + return opencascade::FNVHash::hash_combine(*mystring, mylength); + } + return opencascade::hashBytes(mystring, mylength); } diff --git a/src/TCollection/TCollection_ExtendedString.cxx b/src/TCollection/TCollection_ExtendedString.cxx index 2a83bab603..c87bedcdfd 100644 --- a/src/TCollection/TCollection_ExtendedString.cxx +++ b/src/TCollection/TCollection_ExtendedString.cxx @@ -23,20 +23,7 @@ namespace { - //! Allocate string buffer (automatically adding extra symbol for NULL-termination). - static Standard_ExtCharacter* allocateExtChars (const Standard_Size theLength) - { - return (Standard_ExtCharacter* )Standard::Allocate ((theLength + 1) * sizeof(Standard_ExtCharacter)); - } - - //! Re-allocate string buffer (automatically adding extra symbol for NULL-termination). - static Standard_ExtCharacter* reallocateExtChars (Standard_Address theAddr, - const Standard_Size theLength) - { - return (Standard_ExtCharacter* )Standard::Reallocate (theAddr, (theLength + 1) * sizeof(Standard_ExtCharacter)); - } - - static const Standard_ExtCharacter NULL_EXTSTRING[1] = {0}; + static Standard_ExtCharacter THE_DEFAULT_EXT_CHAR_STRING[1] = {0}; //! Returns the number of 16-bit code units in Unicode string template @@ -57,7 +44,12 @@ namespace Standard_Integer& theLength) { theLength = nbSymbols (theUtfString); - Standard_ExtCharacter* aString = allocateExtChars (theLength); + if (theLength == 0) + { + return THE_DEFAULT_EXT_CHAR_STRING; + } + const Standard_Size aRoundSize = (((theLength + 1) * sizeof(Standard_ExtCharacter)) + 3) & ~0x3; + Standard_ExtCharacter* aString = static_cast(Standard::AllocateOptimal(aRoundSize)); NCollection_UtfWideIter anIterRead (theUtfString); for (Standard_ExtCharacter* anIterWrite = aString; *anIterRead != 0; ++anIterRead) { @@ -73,7 +65,12 @@ namespace Standard_Integer& theLength) { for (theLength = 0; theUtfString[theLength] != 0; ++theLength) {} - Standard_ExtCharacter* aString = allocateExtChars (theLength); + if (theLength == 0) + { + return THE_DEFAULT_EXT_CHAR_STRING; + } + const Standard_Size aRoundSize = (((theLength + 1) * sizeof(Standard_ExtCharacter)) + 3) & ~0x3; + Standard_ExtCharacter* aString = static_cast(Standard::AllocateOptimal(aRoundSize)); const Standard_Integer aSize = theLength * sizeof(Standard_ExtCharacter); memcpy (aString, theUtfString, aSize); aString[theLength] = 0; @@ -86,10 +83,8 @@ namespace // Create an empty ExtendedString // ---------------------------------------------------------------------------- TCollection_ExtendedString::TCollection_ExtendedString() -: mystring (allocateExtChars (0)), - mylength (0) { - mystring[0] = 0; + allocate(0); } //---------------------------------------------------------------------------- @@ -97,9 +92,7 @@ TCollection_ExtendedString::TCollection_ExtendedString() //---------------------------------------------------------------------------- TCollection_ExtendedString::TCollection_ExtendedString (const Standard_CString theString, - const Standard_Boolean isMultiByte) -: mystring (NULL), - mylength (0) + const Standard_Boolean isMultiByte) { if (theString == NULL) { @@ -108,30 +101,28 @@ TCollection_ExtendedString::TCollection_ExtendedString if (isMultiByte) { - mylength = nbSymbols (theString); - mystring = allocateExtChars (mylength); + allocate(nbSymbols(theString)); mystring[mylength] = 0; if (ConvertToUnicode (theString)) { return; } + reallocate((int)strlen(theString)); + } + else + { + allocate((int)strlen(theString)); } - - mylength = (int)strlen(theString); - mystring = reallocateExtChars (mystring, mylength); for (int aCharIter = 0; aCharIter < mylength; ++aCharIter) { mystring[aCharIter] = ToExtCharacter (theString[aCharIter]); } - mystring[mylength] = 0; } //--------------------------------------------------------------------------- // Create an ExtendedString from an ExtString //-------------------------------------------------------------------------- TCollection_ExtendedString::TCollection_ExtendedString (const Standard_ExtString theString) -: mystring (NULL), - mylength (0) { if (theString == NULL) { @@ -139,18 +130,14 @@ TCollection_ExtendedString::TCollection_ExtendedString (const Standard_ExtString } for (mylength = 0; theString[mylength] != 0; ++mylength) {} - mystring = allocateExtChars (mylength); - const Standard_Integer aSizeBytes = mylength * sizeof(Standard_ExtCharacter); - memcpy (mystring, theString, aSizeBytes); - mystring[mylength] = 0; + allocate (mylength); + memcpy (mystring, theString, mylength * sizeof(Standard_ExtCharacter)); } // ---------------------------------------------------------------------------- // TCollection_ExtendedString // ---------------------------------------------------------------------------- TCollection_ExtendedString::TCollection_ExtendedString (const Standard_WideChar* theStringUtf) -: mystring (NULL), - mylength (0) { if (theStringUtf == NULL) { @@ -166,17 +153,14 @@ TCollection_ExtendedString::TCollection_ExtendedString (const Standard_WideChar* TCollection_ExtendedString::TCollection_ExtendedString (const Standard_Character aChar) { - if ( aChar != '\0' ) { - mylength = 1; - mystring = allocateExtChars (1); + if ( aChar != '\0' ) + { + allocate(1); mystring[0] = ToExtCharacter(aChar); - mystring[1] = 0; } - else { - // mystring = 0L; - mylength = 0; - mystring = allocateExtChars (0); - mystring[0] = 0; + else + { + allocate(0); } } @@ -186,10 +170,8 @@ TCollection_ExtendedString::TCollection_ExtendedString TCollection_ExtendedString::TCollection_ExtendedString (const Standard_ExtCharacter aChar) { - mylength = 1; - mystring = allocateExtChars (1); + allocate(1); mystring[0] = aChar; - mystring[1] = 0; } // ---------------------------------------------------------------------------- @@ -199,10 +181,8 @@ TCollection_ExtendedString::TCollection_ExtendedString (const Standard_Integer length, const Standard_ExtCharacter filler ) { - mystring = allocateExtChars (length); - mylength = length; + allocate(length); for (int i = 0 ; i < length ; i++) mystring[i] = filler; - mystring[mylength] = 0; } // ---------------------------------------------------------------------------- @@ -214,10 +194,8 @@ TCollection_ExtendedString::TCollection_ExtendedString union {int bid ; char t [13];} CHN ; Sprintf(&CHN.t[0],"%d",aValue); - mylength = (int)strlen(CHN.t); - mystring = allocateExtChars (mylength); + allocate((int)strlen(CHN.t)); for (int i = 0 ; i < mylength ; i++) mystring[i] = ToExtCharacter(CHN.t[i]); - mystring[mylength] = 0; } // ---------------------------------------------------------------------------- @@ -229,23 +207,37 @@ TCollection_ExtendedString::TCollection_ExtendedString union {int bid ; char t [50];} CHN ; Sprintf(&CHN.t[0],"%g",aValue); - mylength = (int)strlen( CHN.t ); - mystring = allocateExtChars (mylength); + allocate((int)strlen(CHN.t)); for (int i = 0 ; i < mylength ; i++) mystring[i] = ToExtCharacter(CHN.t[i]); - mystring[mylength] = 0; } //----------------------------------------------------------------------------- // create an extendedstring from an extendedstring // ---------------------------------------------------------------------------- TCollection_ExtendedString::TCollection_ExtendedString - (const TCollection_ExtendedString& astring) + (const TCollection_ExtendedString& theOther) { - const Standard_Integer aSizeBytes = astring.mylength * sizeof(Standard_ExtCharacter); - mylength = astring.mylength; - mystring = allocateExtChars (astring.mylength); - memcpy (mystring, astring.mystring, aSizeBytes); - mystring[mylength] = 0; + allocate(theOther.mylength); + memcpy(mystring, theOther.mystring, mylength * sizeof(Standard_ExtCharacter)); +} + +//======================================================================= +//function : TCollection_ExtendedString +//purpose : +//======================================================================= +TCollection_ExtendedString::TCollection_ExtendedString (TCollection_ExtendedString&& theOther) noexcept +{ + if (theOther.mystring == THE_DEFAULT_EXT_CHAR_STRING) + { + allocate(0); + } + else + { + mystring = theOther.mystring; + mylength = theOther.mylength; + } + theOther.mystring = THE_DEFAULT_EXT_CHAR_STRING; + theOther.mylength = 0; } //--------------------------------------------------------------------------- @@ -255,22 +247,17 @@ TCollection_ExtendedString::TCollection_ExtendedString (const TCollection_AsciiString& theString, const Standard_Boolean isMultiByte) { - mylength = nbSymbols (theString.ToCString()); - mystring = allocateExtChars (mylength); - mystring[mylength] = 0; + allocate(nbSymbols (theString.ToCString())); if (isMultiByte && ConvertToUnicode (theString.ToCString())) { return; } - - mylength = theString.Length(); - mystring = reallocateExtChars (mystring, mylength); + reallocate(theString.Length()); Standard_CString aCString = theString.ToCString(); for (Standard_Integer aCharIter = 0; aCharIter <= mylength; ++aCharIter) { mystring[aCharIter] = ToExtCharacter (aCString[aCharIter]); } - mystring[mylength] = 0; } // ---------------------------------------------------------------------------- @@ -284,19 +271,9 @@ void TCollection_ExtendedString::AssignCat (const TCollection_ExtendedString& th } const Standard_Integer anOtherLength = theOther.mylength; - const Standard_Integer aNewlength = mylength + anOtherLength; - if (mystring != NULL) - { - mystring = reallocateExtChars (mystring, aNewlength); - memcpy (mystring + mylength, theOther.mystring, anOtherLength * sizeof(Standard_ExtCharacter)); - } - else - { - mystring = allocateExtChars (aNewlength); - memcpy (mystring, theOther.mystring, anOtherLength * sizeof(Standard_ExtCharacter)); - } - mylength = aNewlength; - mystring[mylength] = 0; + const Standard_Integer anOldLength = mylength; + reallocate(mylength + anOtherLength); + memcpy (mystring + anOldLength, theOther.mystring, anOtherLength * sizeof(Standard_ExtCharacter)); } // ---------------------------------------------------------------------------- @@ -306,10 +283,8 @@ void TCollection_ExtendedString::AssignCat(const Standard_Utf16Char theChar) { if (theChar != '\0') { - mystring = reallocateExtChars(mystring, mylength + 1); - mystring[mylength] = theChar; - mylength += 1; - mystring[mylength] = '\0'; + reallocate(mylength + 1); + mystring[mylength - 1] = theChar; } } @@ -342,45 +317,55 @@ void TCollection_ExtendedString::ChangeAll(const Standard_ExtCharacter aChar, // ---------------------------------------------------------------------------- void TCollection_ExtendedString::Clear() { - if (mylength == 0) - { - return; - } - - Standard::Free (mystring); - mylength = 0; - mystring = allocateExtChars (mylength); - mystring[0] = 0; + deallocate(); } // ---------------------------------------------------------------------------- // Copy // ---------------------------------------------------------------------------- -void TCollection_ExtendedString::Copy (const TCollection_ExtendedString& fromwhere) +void TCollection_ExtendedString::Copy(const TCollection_ExtendedString& fromwhere) { - - if (fromwhere.mystring) { - const Standard_Integer newlength = fromwhere.mylength; - const Standard_Integer aSizeBytes = newlength * sizeof(Standard_ExtCharacter); - if (mystring != NULL) - { - mystring = reallocateExtChars (mystring, newlength); - } - else { - mystring = allocateExtChars (newlength); - } - mylength = newlength; - memcpy (mystring, fromwhere.mystring, aSizeBytes); + if (&fromwhere == this) + { + return; + } + if (fromwhere.mystring && fromwhere.mylength > 0) + { + reallocate (fromwhere.mylength); + memcpy (mystring, fromwhere.mystring, mylength * sizeof(Standard_ExtCharacter)); + } + else if (mystring != THE_DEFAULT_EXT_CHAR_STRING) + { + mylength = 0; mystring[mylength] = 0; } +} + +//======================================================================= +//function : Move +//purpose : +//======================================================================= +void TCollection_ExtendedString::Move(TCollection_ExtendedString&& theOther) +{ + if (&theOther == this) + { + return; + } + if (theOther.mystring == THE_DEFAULT_EXT_CHAR_STRING) + { + reallocate(0); + } else { - if (mystring != 0) + if (mystring != THE_DEFAULT_EXT_CHAR_STRING) { - mylength = 0; - mystring[0] = 0; + Standard::Free(mystring); } + mystring = theOther.mystring; + mylength = theOther.mylength; } + theOther.mystring = THE_DEFAULT_EXT_CHAR_STRING; + theOther.mylength = 0; } // ---------------------------------------------------------------------------- @@ -388,7 +373,11 @@ void TCollection_ExtendedString::Copy (const TCollection_ExtendedString& fromwhe // ---------------------------------------------------------------------------- void TCollection_ExtendedString::Swap (TCollection_ExtendedString& theOther) { - std::swap (mystring, theOther.mystring); + if (&theOther == this) + { + return; + } + std::swap(mystring, theOther.mystring); std::swap (mylength, theOther.mylength); } @@ -397,8 +386,7 @@ void TCollection_ExtendedString::Swap (TCollection_ExtendedString& theOther) // ---------------------------------------------------------------------------- TCollection_ExtendedString::~TCollection_ExtendedString() { - if (mystring) Standard::Free(mystring); - mystring = 0L; + deallocate (); } //---------------------------------------------------------------------------- @@ -413,21 +401,12 @@ void TCollection_ExtendedString::Insert(const Standard_Integer where, if (where < 0) throw Standard_OutOfRange("TCollection_ExtendedString::Insert : " "Parameter where is negative"); - - if (mystring != NULL) - { - mystring = reallocateExtChars (mystring, mylength + 1); - } - else { - mystring = allocateExtChars (mylength + 1); - } - if (where != mylength +1) { - for (int i=mylength-1; i >= where-1; i--) + reallocate(mylength + 1); + if (where != mylength) { + for (int i=mylength-2; i >= where-1; i--) mystring[i+1] = mystring[i]; } mystring[where-1] = what; - mylength++; - mystring[mylength] = 0; } // ---------------------------------------------------------------------------- @@ -440,23 +419,14 @@ void TCollection_ExtendedString::Insert(const Standard_Integer where, if (where <= mylength + 1) { Standard_Integer whatlength = what.mylength; if(whatlength) { - Standard_Integer newlength = mylength + whatlength; - - if (mystring) { - mystring = reallocateExtChars (mystring, newlength); - } - else { - mystring = allocateExtChars (newlength); - } - if (where != mylength +1) { - for (int i=mylength-1; i >= where-1; i--) + const int anOldLength = mylength; + reallocate(mylength + whatlength); + if (where != anOldLength +1) { + for (int i=anOldLength-1; i >= where-1; i--) mystring[i+whatlength] = mystring[i]; } for (int i=0; i < whatlength; i++) mystring[where-1+i] = swhat[i]; - - mylength = newlength; - mystring[mylength] = 0; } } else { @@ -728,17 +698,10 @@ void TCollection_ExtendedString::SetValue Standard_ExtString swhat = what.mystring; size += (where - 1); if (size >= mylength){ - if (mystring) { - mystring = reallocateExtChars (mystring, size); - } - else { - mystring = allocateExtChars (size); - } - mylength = size; + reallocate(size); } for (int i = where-1; i < size; i++) mystring[i] = swhat[i-(where-1)]; - mystring[mylength] = '\0'; } else throw Standard_OutOfRange("TCollection_ExtendedString::SetValue : " @@ -766,13 +729,17 @@ TCollection_ExtendedString TCollection_ExtendedString::Token (const Standard_ExtString separators, const Standard_Integer whichone) const { - TCollection_ExtendedString res; + if (mylength == 0) + { + return TCollection_ExtendedString(); + } + TCollection_ExtendedString res(mylength, 0); if (!separators) throw Standard_NullObject("TCollection_ExtendedString::Token : " "parameter 'separators'"); int i,j,k,l; - Standard_PExtCharacter buftmp = allocateExtChars (mylength); + Standard_PExtCharacter buftmp = res.mystring; Standard_ExtCharacter aSep; Standard_Boolean isSepFound = Standard_False, otherSepFound; @@ -823,13 +790,13 @@ TCollection_ExtendedString TCollection_ExtendedString::Token } } - if (i < whichone) { - buftmp[0] = 0; - Standard::Free(buftmp); + if (i < whichone) + { + res.mylength = 0; + res.mystring[0] = 0; } - else { - Standard::Free(res.mystring); - res.mystring = buftmp; + else + { for ( res.mylength=0; buftmp[res.mylength]; ++res.mylength ); res.mystring[res.mylength] = '\0'; } @@ -841,8 +808,7 @@ TCollection_ExtendedString TCollection_ExtendedString::Token // ---------------------------------------------------------------------------- Standard_ExtString TCollection_ExtendedString::ToExtString() const { - if(mystring) return mystring; - return NULL_EXTSTRING; + return mystring; } // ---------------------------------------------------------------------------- @@ -931,3 +897,64 @@ Standard_Integer TCollection_ExtendedString::ToUTF8CString(Standard_PCharacter& *anIterWrite = '\0'; return Standard_Integer(anIterWrite - theCString); } + +//======================================================================= +//function : allocate +//purpose : +//======================================================================= +void TCollection_ExtendedString::allocate(const int theLength) +{ + mylength = theLength; + if (theLength == 0) + { + mystring = THE_DEFAULT_EXT_CHAR_STRING; + } + else + { + const Standard_Size aRoundSize = (((theLength + 1) * sizeof(Standard_ExtCharacter)) + 3) & ~0x3; + mystring = static_cast( + Standard::AllocateOptimal(aRoundSize)); + mystring[mylength] = '\0'; + } +} + +//======================================================================= +//function : reallocate +//purpose : +//======================================================================= +void TCollection_ExtendedString::reallocate(const int theLength) +{ + if (theLength != 0) + { + if (mystring == THE_DEFAULT_EXT_CHAR_STRING) + { + const Standard_Size aRoundSize = (((theLength + 1) * sizeof(Standard_ExtCharacter)) + 3) & ~0x3; + mystring = static_cast(Standard::AllocateOptimal(aRoundSize)); + } + else + { + mystring = static_cast( + Standard::Reallocate(mystring, (theLength + 1) * sizeof(Standard_ExtCharacter))); + } + mystring[theLength] = 0; + } + if (mystring != THE_DEFAULT_EXT_CHAR_STRING) + { + mystring[theLength] = 0; + } + mylength = theLength; +} + +//======================================================================= +//function : deallocate +//purpose : +//======================================================================= +void TCollection_ExtendedString::deallocate() +{ + if (mystring != THE_DEFAULT_EXT_CHAR_STRING) + { + Standard::Free(mystring); + } + mylength = 0; + mystring = THE_DEFAULT_EXT_CHAR_STRING; +} diff --git a/src/TCollection/TCollection_ExtendedString.hxx b/src/TCollection/TCollection_ExtendedString.hxx index f71869ac6f..d23d2983ac 100644 --- a/src/TCollection/TCollection_ExtendedString.hxx +++ b/src/TCollection/TCollection_ExtendedString.hxx @@ -25,7 +25,6 @@ #include #include #include -#include #include #include #include @@ -99,13 +98,7 @@ public: Standard_EXPORT TCollection_ExtendedString(const TCollection_ExtendedString& astring); //! Move constructor - TCollection_ExtendedString (TCollection_ExtendedString&& theOther) Standard_Noexcept - : mystring (theOther.mystring), - mylength (theOther.mylength) - { - theOther.mystring = NULL; - theOther.mylength = 0; - } + Standard_EXPORT TCollection_ExtendedString (TCollection_ExtendedString&& theOther) Standard_Noexcept; //! Creation by converting an Ascii string to an extended //! string. The string is treated as having UTF-8 coding. @@ -145,17 +138,27 @@ TCollection_ExtendedString operator + (const TCollection_ExtendedString& other) //! Copy to . //! Used as operator = Standard_EXPORT void Copy (const TCollection_ExtendedString& fromwhere); -void operator = (const TCollection_ExtendedString& fromwhere) -{ - Copy(fromwhere); -} + + //! Copy assignment operator + TCollection_ExtendedString& operator= (const TCollection_ExtendedString& theOther) + { + Copy(theOther); + return *this; + } + + //! Moves string without reallocations + Standard_EXPORT void Move (TCollection_ExtendedString&& theOther); + + //! Move assignment operator + TCollection_ExtendedString& operator= (TCollection_ExtendedString&& theOther) noexcept + { + Move(std::forward(theOther)); + return *this; + } //! Exchange the data of two strings (without reallocating memory). Standard_EXPORT void Swap (TCollection_ExtendedString& theOther); - //! Move assignment operator - TCollection_ExtendedString& operator= (TCollection_ExtendedString&& theOther) Standard_Noexcept { Swap (theOther); return *this; } - //! Frees memory allocated by ExtendedString. Standard_EXPORT ~TCollection_ExtendedString(); @@ -331,16 +334,18 @@ friend Standard_EXPORT Standard_OStream& operator << (Standard_OStream& astream, //! the bounds of this extended string. Standard_EXPORT Standard_ExtCharacter Value (const Standard_Integer where) const; - //! Returns a hashed value for the extended string within the range 1 .. theUpper. + //! Returns a hashed value for the extended string. //! Note: if string is ASCII, the computed value is the same as the value computed with the HashCode function on a //! TCollection_AsciiString string composed with equivalent ASCII characters. - //! @param theString the extended string which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const TCollection_ExtendedString& theString, - const Standard_Integer theUpperBound) + //! @return a computed hash code + size_t HashCode () const { - return ::HashCode (theString.ToExtString(), theUpperBound); + const int aSize = mylength * sizeof(Standard_ExtCharacter); + if (mylength < 2) + { + return opencascade::FNVHash::hash_combine(*mystring, aSize); + } + return opencascade::hashBytes(mystring, aSize); } //! Returns true if the characters in this extended @@ -365,23 +370,33 @@ friend Standard_EXPORT Standard_OStream& operator << (Standard_OStream& astream, private: //! Returns true if the input CString was successfully converted to UTF8 coding. - Standard_EXPORT Standard_Boolean ConvertToUnicode (const Standard_CString astring); + Standard_Boolean ConvertToUnicode (const Standard_CString astring); + + //! Internal wrapper to allocate on stack or heap + void allocate(const int theLength); + + //! Internal wrapper to reallocate on stack or heap + void reallocate(const int theLength); + + //! Internal wrapper to deallocate on stack + void deallocate(); private: - Standard_PExtCharacter mystring; //!< NULL-terminated string - Standard_Integer mylength; //!< length in 16-bit code units (excluding terminating NULL symbol) - + Standard_PExtCharacter mystring{}; //!< NULL-terminated string + Standard_Integer mylength{}; //!< length in 16-bit code units (excluding terminating NULL symbol) }; -//! Computes a hash code for the given extended string, in the range [1, theUpperBound] -//! @param theExtendedString the extended string which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -inline Standard_Integer HashCode (const TCollection_ExtendedString& theExtendedString, - const Standard_Integer theUpperBound) +namespace std { - return TCollection_ExtendedString::HashCode (theExtendedString, theUpperBound); + template <> + struct hash + { + size_t operator()(const TCollection_ExtendedString& theString) const + { + return theString.HashCode(); + } + }; } #endif // _TCollection_ExtendedString_HeaderFile diff --git a/src/TCollection/TCollection_HAsciiString.hxx b/src/TCollection/TCollection_HAsciiString.hxx index 51ef876ef7..ed66eec3e6 100644 --- a/src/TCollection/TCollection_HAsciiString.hxx +++ b/src/TCollection/TCollection_HAsciiString.hxx @@ -66,6 +66,11 @@ public: //! Initializes a HAsciiString with a AsciiString. Standard_EXPORT TCollection_HAsciiString(const TCollection_AsciiString& aString); + + //! Initializes a HAsciiString with a AsciiString. + TCollection_HAsciiString(TCollection_AsciiString&& theString) noexcept : + myString(std::move(theString)) + {} //! Initializes a HAsciiString with a HAsciiString. Standard_EXPORT TCollection_HAsciiString(const Handle(TCollection_HAsciiString)& aString); diff --git a/src/TCollection/TCollection_HAsciiString.lxx b/src/TCollection/TCollection_HAsciiString.lxx index f097751cf4..e5a92d89ce 100644 --- a/src/TCollection/TCollection_HAsciiString.lxx +++ b/src/TCollection/TCollection_HAsciiString.lxx @@ -41,3 +41,27 @@ inline const TCollection_AsciiString& TCollection_HAsciiString::String() const // ---------------------------------------------------------------------------- inline Standard_CString TCollection_HAsciiString::ToCString() const { return myString.ToCString(); } + +namespace std +{ + template <> + struct hash + { + size_t operator()(const Handle(TCollection_HAsciiString)& theString) const + { + if (theString.IsNull()) return 0; + return std::hash{}(theString->String()); + } + }; + + template<> + struct equal_to + { + bool operator()(const Handle(TCollection_HAsciiString)& theString1, + const Handle(TCollection_HAsciiString)& theString2) const + { + return theString1 == theString2 || + (!theString1.IsNull() && !theString2.IsNull() && theString1->String() == theString2->String()); + } + }; +} diff --git a/src/TCollection/TCollection_HExtendedString.hxx b/src/TCollection/TCollection_HExtendedString.hxx index 6c5a7a3460..a1527b218a 100644 --- a/src/TCollection/TCollection_HExtendedString.hxx +++ b/src/TCollection/TCollection_HExtendedString.hxx @@ -64,8 +64,13 @@ public: //! and filled with . This is useful for buffers. Standard_EXPORT TCollection_HExtendedString(const Standard_Integer length, const Standard_ExtCharacter filler); - //! Initializes a HExtendedString with a HExtendedString. + //! Initializes a HExtendedString with a ExtendedString. Standard_EXPORT TCollection_HExtendedString(const TCollection_ExtendedString& aString); + + //! Initializes a HExtendedString with a ExtendedString. + TCollection_HExtendedString(TCollection_ExtendedString&& theString) noexcept : + myString(std::move(theString)) + {} //! Initializes a HExtendedString with an HAsciiString. Standard_EXPORT TCollection_HExtendedString(const Handle(TCollection_HAsciiString)& aString); @@ -218,10 +223,29 @@ private: }; +namespace std +{ + template <> + struct hash + { + size_t operator()(const Handle(TCollection_HExtendedString)& theString) const + { + if (theString.IsNull()) return 0; + return std::hash{}(theString->String()); + } + }; + template<> + struct equal_to + { + bool operator()(const Handle(TCollection_HExtendedString)& theString1, + const Handle(TCollection_HExtendedString)& theString2) const + { + return theString1 == theString2 || + (!theString1.IsNull() && !theString2.IsNull() && theString1->String() == theString2->String()); - - - + } + }; +} #endif // _TCollection_HExtendedString_HeaderFile diff --git a/src/TDF/FILES b/src/TDF/FILES index b6f97ecf00..61744e3479 100755 --- a/src/TDF/FILES +++ b/src/TDF/FILES @@ -82,7 +82,6 @@ TDF_LabelIndexedMap.hxx TDF_LabelIntegerMap.hxx TDF_LabelList.hxx TDF_LabelMap.hxx -TDF_LabelMapHasher.hxx TDF_LabelNode.cxx TDF_LabelNode.hxx TDF_LabelNodePtr.hxx diff --git a/src/TDF/TDF_AttributeDataMap.hxx b/src/TDF/TDF_AttributeDataMap.hxx index b679eea2e1..49630919b2 100644 --- a/src/TDF/TDF_AttributeDataMap.hxx +++ b/src/TDF/TDF_AttributeDataMap.hxx @@ -17,11 +17,10 @@ #define TDF_AttributeDataMap_HeaderFile #include -#include #include -typedef NCollection_DataMap TDF_AttributeDataMap; -typedef NCollection_DataMap::Iterator TDF_DataMapIteratorOfAttributeDataMap; +typedef NCollection_DataMap TDF_AttributeDataMap; +typedef NCollection_DataMap::Iterator TDF_DataMapIteratorOfAttributeDataMap; #endif diff --git a/src/TDF/TDF_AttributeDoubleMap.hxx b/src/TDF/TDF_AttributeDoubleMap.hxx index acbc467847..6338f07100 100644 --- a/src/TDF/TDF_AttributeDoubleMap.hxx +++ b/src/TDF/TDF_AttributeDoubleMap.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DoubleMap TDF_AttributeDoubleMap; -typedef NCollection_DoubleMap::Iterator TDF_DoubleMapIteratorOfAttributeDoubleMap; +typedef NCollection_DoubleMap TDF_AttributeDoubleMap; +typedef NCollection_DoubleMap::Iterator TDF_DoubleMapIteratorOfAttributeDoubleMap; #endif diff --git a/src/TDF/TDF_AttributeIndexedMap.hxx b/src/TDF/TDF_AttributeIndexedMap.hxx index 3f785b6dfb..4be5d176f4 100644 --- a/src/TDF/TDF_AttributeIndexedMap.hxx +++ b/src/TDF/TDF_AttributeIndexedMap.hxx @@ -16,11 +16,10 @@ #ifndef TDF_AttributeIndexedMap_HeaderFile #define TDF_AttributeIndexedMap_HeaderFile -#include #include class TDF_Attribute; -typedef NCollection_IndexedMap TDF_AttributeIndexedMap; +typedef NCollection_IndexedMap TDF_AttributeIndexedMap; #endif diff --git a/src/TDF/TDF_AttributeMap.hxx b/src/TDF/TDF_AttributeMap.hxx index 2046c845e7..b6c8d781b4 100644 --- a/src/TDF/TDF_AttributeMap.hxx +++ b/src/TDF/TDF_AttributeMap.hxx @@ -17,11 +17,10 @@ #define TDF_AttributeMap_HeaderFile #include -#include #include -typedef NCollection_Map TDF_AttributeMap; -typedef NCollection_Map::Iterator TDF_MapIteratorOfAttributeMap; +typedef NCollection_Map TDF_AttributeMap; +typedef NCollection_Map::Iterator TDF_MapIteratorOfAttributeMap; #endif diff --git a/src/TDF/TDF_CopyTool.cxx b/src/TDF/TDF_CopyTool.cxx index c355d3a97f..7ed56a2c10 100644 --- a/src/TDF/TDF_CopyTool.cxx +++ b/src/TDF/TDF_CopyTool.cxx @@ -28,6 +28,7 @@ #include #include #include +#include //======================================================================= //function : Copy diff --git a/src/TDF/TDF_DerivedAttribute.cxx b/src/TDF/TDF_DerivedAttribute.cxx index 1a852bcc5f..93deb07ea0 100644 --- a/src/TDF/TDF_DerivedAttribute.cxx +++ b/src/TDF/TDF_DerivedAttribute.cxx @@ -15,6 +15,7 @@ #include #include +#include #include namespace TDF_DerivedAttributeGlobals @@ -35,16 +36,16 @@ namespace TDF_DerivedAttributeGlobals return THE_CREATORS_LIST; } //! Global map of the string-type of derived attribute -> instance of such attribute - static NCollection_DataMap& Attributes() + static NCollection_DataMap& Attributes() { - static NCollection_DataMap THE_DERIVED; + static NCollection_DataMap THE_DERIVED; return THE_DERIVED; } //! Global map of the string-type of derived attribute -> type name to identify this attribute - static NCollection_DataMap& Types() + static NCollection_DataMap& Types() { - static NCollection_DataMap THE_DERIVED_TYPES; + static NCollection_DataMap THE_DERIVED_TYPES; return THE_DERIVED_TYPES; } @@ -154,7 +155,7 @@ void TDF_DerivedAttribute::Attributes (NCollection_List& { Standard_Mutex::Sentry aSentry (TDF_DerivedAttributeGlobals::Mutex()); Initialize(); - NCollection_DataMap::Iterator anAttrIter; + NCollection_DataMap::Iterator anAttrIter; for (anAttrIter.Initialize (TDF_DerivedAttributeGlobals::Attributes()); anAttrIter.More(); anAttrIter.Next()) { theList.Append (anAttrIter.Value()); diff --git a/src/TDF/TDF_GUIDProgIDMap.hxx b/src/TDF/TDF_GUIDProgIDMap.hxx index ebb4be6cee..ded17627dc 100644 --- a/src/TDF/TDF_GUIDProgIDMap.hxx +++ b/src/TDF/TDF_GUIDProgIDMap.hxx @@ -20,8 +20,8 @@ #include #include -typedef NCollection_DoubleMap TDF_GUIDProgIDMap; -typedef NCollection_DoubleMap::Iterator TDF_DoubleMapIteratorOfGUIDProgIDMap; +typedef NCollection_DoubleMap TDF_GUIDProgIDMap; +typedef NCollection_DoubleMap::Iterator TDF_DoubleMapIteratorOfGUIDProgIDMap; #endif diff --git a/src/TDF/TDF_IDMap.hxx b/src/TDF/TDF_IDMap.hxx index 51f3f2ad53..905210fa14 100644 --- a/src/TDF/TDF_IDMap.hxx +++ b/src/TDF/TDF_IDMap.hxx @@ -19,8 +19,8 @@ #include #include -typedef NCollection_Map TDF_IDMap; -typedef NCollection_Map::Iterator TDF_MapIteratorOfIDMap; +typedef NCollection_Map TDF_IDMap; +typedef NCollection_Map::Iterator TDF_MapIteratorOfIDMap; #endif diff --git a/src/TDF/TDF_Label.hxx b/src/TDF/TDF_Label.hxx index 0cadd9d69f..fc0a6d66e9 100644 --- a/src/TDF/TDF_Label.hxx +++ b/src/TDF/TDF_Label.hxx @@ -259,8 +259,9 @@ friend class TDF_ChildIterator; friend class TDF_Attribute; friend class TDF_AttributeIterator; friend class TDF_Data; -friend class TDF_LabelMapHasher; +template +friend struct std::hash; protected: diff --git a/src/TDF/TDF_Label.lxx b/src/TDF/TDF_Label.lxx index befb84940b..118ea23cb8 100644 --- a/src/TDF/TDF_Label.lxx +++ b/src/TDF/TDF_Label.lxx @@ -23,6 +23,18 @@ #include #include +namespace std +{ + template<> + struct hash + { + size_t operator()(const TDF_Label& theNode) const + { + return std::hash{}(theNode.myLabelNode); + } + }; +} + inline TDF_Label::TDF_Label() :myLabelNode(NULL) {} diff --git a/src/TDF/TDF_LabelDataMap.hxx b/src/TDF/TDF_LabelDataMap.hxx index d428d85b65..10462f131c 100644 --- a/src/TDF/TDF_LabelDataMap.hxx +++ b/src/TDF/TDF_LabelDataMap.hxx @@ -17,11 +17,10 @@ #define TDF_LabelDataMap_HeaderFile #include -#include #include -typedef NCollection_DataMap TDF_LabelDataMap; -typedef NCollection_DataMap::Iterator TDF_DataMapIteratorOfLabelDataMap; +typedef NCollection_DataMap TDF_LabelDataMap; +typedef NCollection_DataMap::Iterator TDF_DataMapIteratorOfLabelDataMap; #endif diff --git a/src/TDF/TDF_LabelDoubleMap.hxx b/src/TDF/TDF_LabelDoubleMap.hxx index 1c6213b3b7..eed89a6a1c 100644 --- a/src/TDF/TDF_LabelDoubleMap.hxx +++ b/src/TDF/TDF_LabelDoubleMap.hxx @@ -16,11 +16,11 @@ #ifndef TDF_LabelDoubleMap_HeaderFile #define TDF_LabelDoubleMap_HeaderFile -#include +#include #include -typedef NCollection_DoubleMap TDF_LabelDoubleMap; -typedef NCollection_DoubleMap::Iterator TDF_DoubleMapIteratorOfLabelDoubleMap; +typedef NCollection_DoubleMap TDF_LabelDoubleMap; +typedef NCollection_DoubleMap::Iterator TDF_DoubleMapIteratorOfLabelDoubleMap; #endif diff --git a/src/TDF/TDF_LabelIndexedMap.hxx b/src/TDF/TDF_LabelIndexedMap.hxx index 8aba7f2dff..53554bfc41 100644 --- a/src/TDF/TDF_LabelIndexedMap.hxx +++ b/src/TDF/TDF_LabelIndexedMap.hxx @@ -16,10 +16,9 @@ #ifndef TDF_LabelIndexedMap_HeaderFile #define TDF_LabelIndexedMap_HeaderFile -#include #include -typedef NCollection_IndexedMap TDF_LabelIndexedMap; +typedef NCollection_IndexedMap TDF_LabelIndexedMap; #endif diff --git a/src/TDF/TDF_LabelIntegerMap.hxx b/src/TDF/TDF_LabelIntegerMap.hxx index 2b16c742c7..a9f31c691c 100644 --- a/src/TDF/TDF_LabelIntegerMap.hxx +++ b/src/TDF/TDF_LabelIntegerMap.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DataMap TDF_LabelIntegerMap; -typedef NCollection_DataMap::Iterator TDF_DataMapIteratorOfLabelIntegerMap; +typedef NCollection_DataMap TDF_LabelIntegerMap; +typedef NCollection_DataMap::Iterator TDF_DataMapIteratorOfLabelIntegerMap; #endif diff --git a/src/TDF/TDF_LabelMap.hxx b/src/TDF/TDF_LabelMap.hxx index cf928d1285..aeb1ff73bb 100644 --- a/src/TDF/TDF_LabelMap.hxx +++ b/src/TDF/TDF_LabelMap.hxx @@ -17,11 +17,10 @@ #define TDF_LabelMap_HeaderFile #include -#include #include -typedef NCollection_Map TDF_LabelMap; -typedef NCollection_Map::Iterator TDF_MapIteratorOfLabelMap; +typedef NCollection_Map TDF_LabelMap; +typedef NCollection_Map::Iterator TDF_MapIteratorOfLabelMap; #endif diff --git a/src/TDF/TDF_LabelMapHasher.hxx b/src/TDF/TDF_LabelMapHasher.hxx deleted file mode 100644 index 9084d15c2f..0000000000 --- a/src/TDF/TDF_LabelMapHasher.hxx +++ /dev/null @@ -1,43 +0,0 @@ -// Created by: DAUTRY Philippe -// Copyright (c) 1997-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _TDF_LabelMapHasher_HeaderFile -#define _TDF_LabelMapHasher_HeaderFile - -#include - -//! A label hasher for label maps. -class TDF_LabelMapHasher -{ -public: - //! Computes a hash code for the given label, in the range [1, theUpperBound] - //! @param theLabel the label which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode(const TDF_Label& theLabel, const Standard_Integer theUpperBound) - { - return ::HashCode(theLabel.myLabelNode, theUpperBound); - } - - //! Returns True when the two keys are the same. Two - //! same keys must have the same hashcode, the - //! contrary is not necessary. - static Standard_Boolean IsEqual(const TDF_Label& aLab1, const TDF_Label& aLab2) - { - return aLab1.IsEqual(aLab2); - } -}; - -#endif // _TDF_LabelMapHasher_HeaderFile diff --git a/src/TDataStd/TDataStd_DataMapOfStringByte.hxx b/src/TDataStd/TDataStd_DataMapOfStringByte.hxx index cca3c899b6..94575850f4 100644 --- a/src/TDataStd/TDataStd_DataMapOfStringByte.hxx +++ b/src/TDataStd/TDataStd_DataMapOfStringByte.hxx @@ -20,8 +20,8 @@ #include #include -typedef NCollection_DataMap TDataStd_DataMapOfStringByte; -typedef NCollection_DataMap::Iterator TDataStd_DataMapIteratorOfDataMapOfStringByte; +typedef NCollection_DataMap TDataStd_DataMapOfStringByte; +typedef NCollection_DataMap::Iterator TDataStd_DataMapIteratorOfDataMapOfStringByte; #endif diff --git a/src/TDataStd/TDataStd_DataMapOfStringHArray1OfInteger.hxx b/src/TDataStd/TDataStd_DataMapOfStringHArray1OfInteger.hxx index ece7a88275..522350d7f9 100644 --- a/src/TDataStd/TDataStd_DataMapOfStringHArray1OfInteger.hxx +++ b/src/TDataStd/TDataStd_DataMapOfStringHArray1OfInteger.hxx @@ -21,8 +21,8 @@ #include #include -typedef NCollection_DataMap TDataStd_DataMapOfStringHArray1OfInteger; -typedef NCollection_DataMap::Iterator TDataStd_DataMapIteratorOfDataMapOfStringHArray1OfInteger; +typedef NCollection_DataMap TDataStd_DataMapOfStringHArray1OfInteger; +typedef NCollection_DataMap::Iterator TDataStd_DataMapIteratorOfDataMapOfStringHArray1OfInteger; #endif diff --git a/src/TDataStd/TDataStd_DataMapOfStringHArray1OfReal.hxx b/src/TDataStd/TDataStd_DataMapOfStringHArray1OfReal.hxx index c6c702a5e1..d090a80383 100644 --- a/src/TDataStd/TDataStd_DataMapOfStringHArray1OfReal.hxx +++ b/src/TDataStd/TDataStd_DataMapOfStringHArray1OfReal.hxx @@ -21,8 +21,8 @@ #include #include -typedef NCollection_DataMap TDataStd_DataMapOfStringHArray1OfReal; -typedef NCollection_DataMap::Iterator TDataStd_DataMapIteratorOfDataMapOfStringHArray1OfReal; +typedef NCollection_DataMap TDataStd_DataMapOfStringHArray1OfReal; +typedef NCollection_DataMap::Iterator TDataStd_DataMapIteratorOfDataMapOfStringHArray1OfReal; #endif diff --git a/src/TDataStd/TDataStd_DataMapOfStringReal.hxx b/src/TDataStd/TDataStd_DataMapOfStringReal.hxx index 942e20040c..b6fccc40bc 100644 --- a/src/TDataStd/TDataStd_DataMapOfStringReal.hxx +++ b/src/TDataStd/TDataStd_DataMapOfStringReal.hxx @@ -20,8 +20,8 @@ #include #include -typedef NCollection_DataMap TDataStd_DataMapOfStringReal; -typedef NCollection_DataMap::Iterator TDataStd_DataMapIteratorOfDataMapOfStringReal; +typedef NCollection_DataMap TDataStd_DataMapOfStringReal; +typedef NCollection_DataMap::Iterator TDataStd_DataMapIteratorOfDataMapOfStringReal; #endif diff --git a/src/TDataStd/TDataStd_DataMapOfStringString.hxx b/src/TDataStd/TDataStd_DataMapOfStringString.hxx index 7738b8cc5f..64b79d3285 100644 --- a/src/TDataStd/TDataStd_DataMapOfStringString.hxx +++ b/src/TDataStd/TDataStd_DataMapOfStringString.hxx @@ -20,8 +20,8 @@ #include #include -typedef NCollection_DataMap TDataStd_DataMapOfStringString; -typedef NCollection_DataMap::Iterator TDataStd_DataMapIteratorOfDataMapOfStringString; +typedef NCollection_DataMap TDataStd_DataMapOfStringString; +typedef NCollection_DataMap::Iterator TDataStd_DataMapIteratorOfDataMapOfStringString; #endif diff --git a/src/TDocStd/TDocStd_Document.hxx b/src/TDocStd/TDocStd_Document.hxx index 4e0c752b31..3e025c7ebf 100644 --- a/src/TDocStd/TDocStd_Document.hxx +++ b/src/TDocStd/TDocStd_Document.hxx @@ -24,7 +24,6 @@ #include #include #include -#include #include class TDF_Data; class TDF_Delta; diff --git a/src/TDocStd/TDocStd_LabelIDMapDataMap.hxx b/src/TDocStd/TDocStd_LabelIDMapDataMap.hxx index 1d3029a7fc..bbfa7c6411 100644 --- a/src/TDocStd/TDocStd_LabelIDMapDataMap.hxx +++ b/src/TDocStd/TDocStd_LabelIDMapDataMap.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap TDocStd_LabelIDMapDataMap; -typedef NCollection_DataMap::Iterator TDocStd_DataMapIteratorOfLabelIDMapDataMap; +typedef NCollection_DataMap TDocStd_LabelIDMapDataMap; +typedef NCollection_DataMap::Iterator TDocStd_DataMapIteratorOfLabelIDMapDataMap; #endif diff --git a/src/TFunction/TFunction_DataMapOfGUIDDriver.hxx b/src/TFunction/TFunction_DataMapOfGUIDDriver.hxx index 44b0da4e42..5ef65c958a 100644 --- a/src/TFunction/TFunction_DataMapOfGUIDDriver.hxx +++ b/src/TFunction/TFunction_DataMapOfGUIDDriver.hxx @@ -21,8 +21,8 @@ #include #include -typedef NCollection_DataMap TFunction_DataMapOfGUIDDriver; -typedef NCollection_DataMap::Iterator TFunction_DataMapIteratorOfDataMapOfGUIDDriver; +typedef NCollection_DataMap TFunction_DataMapOfGUIDDriver; +typedef NCollection_DataMap::Iterator TFunction_DataMapIteratorOfDataMapOfGUIDDriver; #endif diff --git a/src/TFunction/TFunction_DataMapOfLabelListOfLabel.hxx b/src/TFunction/TFunction_DataMapOfLabelListOfLabel.hxx index c542ad488d..3b5f6a921a 100644 --- a/src/TFunction/TFunction_DataMapOfLabelListOfLabel.hxx +++ b/src/TFunction/TFunction_DataMapOfLabelListOfLabel.hxx @@ -18,11 +18,10 @@ #define TFunction_DataMapOfLabelListOfLabel_HeaderFile #include -#include #include -typedef NCollection_DataMap TFunction_DataMapOfLabelListOfLabel; -typedef NCollection_DataMap::Iterator TFunction_DataMapIteratorOfDataMapOfLabelListOfLabel; +typedef NCollection_DataMap TFunction_DataMapOfLabelListOfLabel; +typedef NCollection_DataMap::Iterator TFunction_DataMapIteratorOfDataMapOfLabelListOfLabel; #endif diff --git a/src/TFunction/TFunction_DoubleMapOfIntegerLabel.hxx b/src/TFunction/TFunction_DoubleMapOfIntegerLabel.hxx index 6bc3969967..81b6748543 100644 --- a/src/TFunction/TFunction_DoubleMapOfIntegerLabel.hxx +++ b/src/TFunction/TFunction_DoubleMapOfIntegerLabel.hxx @@ -19,12 +19,10 @@ #include #include -#include -#include #include -typedef NCollection_DoubleMap TFunction_DoubleMapOfIntegerLabel; -typedef NCollection_DoubleMap::Iterator TFunction_DoubleMapIteratorOfDoubleMapOfIntegerLabel; +typedef NCollection_DoubleMap TFunction_DoubleMapOfIntegerLabel; +typedef NCollection_DoubleMap::Iterator TFunction_DoubleMapIteratorOfDoubleMapOfIntegerLabel; #endif diff --git a/src/TNaming/FILES b/src/TNaming/FILES index 36aa6d0e57..f81ec9c88c 100644 --- a/src/TNaming/FILES +++ b/src/TNaming/FILES @@ -33,7 +33,6 @@ TNaming_Name.hxx TNaming_NamedShape.cxx TNaming_NamedShape.hxx TNaming_NamedShape.lxx -TNaming_NamedShapeHasher.hxx TNaming_NameType.hxx TNaming_Naming.cxx TNaming_Naming.hxx diff --git a/src/TNaming/TNaming_Localizer.cxx b/src/TNaming/TNaming_Localizer.cxx index 5f789a0ead..d969d0ce3b 100644 --- a/src/TNaming/TNaming_Localizer.cxx +++ b/src/TNaming/TNaming_Localizer.cxx @@ -156,7 +156,7 @@ const TopTools_MapOfShape& TNaming_Localizer::SubShapes (const TopoDS_Shape& // Standard_Boolean Found = Standard_False; for (; itS.More(); itS.Next(),itSS.Next()) { if (In.IsSame(itS.Value())) { - TopTools_MapOfShape& SubShapes = itSS.Value(); + TopTools_MapOfShape& SubShapes = itSS.ChangeValue(); for (TopExp_Explorer exp(In,TS); exp.More(); exp.Next()) { const TopoDS_Shape& SS = exp.Current(); if (SubShapes.Contains(SS)) { @@ -201,7 +201,7 @@ const TopTools_IndexedDataMapOfShapeListOfShape& TNaming_Localizer::Ancestors //----------------------- // Ancetres existent. //----------------------- - TopTools_IndexedDataMapOfShapeListOfShape& Anc = itA.Value(); + TopTools_IndexedDataMapOfShapeListOfShape& Anc = itA.ChangeValue(); TopExp_Explorer exp(In,TS); #ifdef OCCT_DEBUG diff --git a/src/TNaming/TNaming_MapOfNamedShape.hxx b/src/TNaming/TNaming_MapOfNamedShape.hxx index 490512b3e9..5f7ce92dc8 100644 --- a/src/TNaming/TNaming_MapOfNamedShape.hxx +++ b/src/TNaming/TNaming_MapOfNamedShape.hxx @@ -17,11 +17,11 @@ #ifndef TNaming_MapOfNamedShape_HeaderFile #define TNaming_MapOfNamedShape_HeaderFile -#include +#include #include -typedef NCollection_Map TNaming_MapOfNamedShape; -typedef NCollection_Map::Iterator TNaming_MapIteratorOfMapOfNamedShape; +typedef NCollection_Map TNaming_MapOfNamedShape; +typedef NCollection_Map::Iterator TNaming_MapIteratorOfMapOfNamedShape; #endif diff --git a/src/TNaming/TNaming_NamedShapeHasher.hxx b/src/TNaming/TNaming_NamedShapeHasher.hxx deleted file mode 100644 index 1c2dcc68cb..0000000000 --- a/src/TNaming/TNaming_NamedShapeHasher.hxx +++ /dev/null @@ -1,26 +0,0 @@ -// Created on: 1997-03-17 -// Created by: Yves FRICAUD -// Copyright (c) 1997-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef TNaming_NamedShapeHasher_HeaderFile -#define TNaming_NamedShapeHasher_HeaderFile - -#include -#include - -typedef NCollection_DefaultHasher TNaming_NamedShapeHasher; - - -#endif diff --git a/src/TObj/FILES b/src/TObj/FILES index 7203231057..f6f9f643e6 100755 --- a/src/TObj/FILES +++ b/src/TObj/FILES @@ -5,7 +5,6 @@ TObj_Assistant.cxx TObj_Assistant.hxx TObj_CheckModel.cxx TObj_CheckModel.hxx -TObj_Common.hxx TObj_Container.hxx TObj_DeletingMode.hxx TObj_HiddenPartition.cxx diff --git a/src/TObj/TObj_Application.hxx b/src/TObj/TObj_Application.hxx index 933ee7e5a9..096ae58ea0 100644 --- a/src/TObj/TObj_Application.hxx +++ b/src/TObj/TObj_Application.hxx @@ -19,7 +19,6 @@ #define TObj_Application_HeaderFile #include -#include #include #include diff --git a/src/TObj/TObj_Assistant.cxx b/src/TObj/TObj_Assistant.cxx index d4ad4136b6..b8565a2c25 100644 --- a/src/TObj/TObj_Assistant.cxx +++ b/src/TObj/TObj_Assistant.cxx @@ -17,7 +17,6 @@ #include -#include #include #include #include diff --git a/src/TObj/TObj_Assistant.hxx b/src/TObj/TObj_Assistant.hxx index 702cc1c4dd..b26bb7772f 100644 --- a/src/TObj/TObj_Assistant.hxx +++ b/src/TObj/TObj_Assistant.hxx @@ -18,7 +18,6 @@ #ifndef TObj_Assistant_HeaderFile #define TObj_Assistant_HeaderFile -#include #include #include diff --git a/src/TObj/TObj_Common.hxx b/src/TObj/TObj_Common.hxx deleted file mode 100644 index 3f6a057758..0000000000 --- a/src/TObj/TObj_Common.hxx +++ /dev/null @@ -1,50 +0,0 @@ -// Created on: 2004-11-22 -// Created by: Pavel TELKOV -// Copyright (c) 2004-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -// The original implementation Copyright: (C) RINA S.p.A - -// Purpose: This header file collects basic definitions -// to be included in most of sources - -#ifndef TObj_Common_HeaderFile -#define TObj_Common_HeaderFile - -//! Basic CASCADE definitions -#include -#include - -//! Methods inline implementation for HExtendedString - -//! Computes a hash code for the given handle referred to extended string, in the range [1, theUpperBound] -//! @param theHExtendedString the handle referred to extended string which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -inline Standard_Integer HashCode (const Handle (TCollection_HExtendedString) & theHExtendedString, - const Standard_Integer theUpperBound) -{ - return TCollection_ExtendedString::HashCode (theHExtendedString->String(), theUpperBound); -} - -inline Standard_Boolean IsEqual (const Handle(TCollection_HExtendedString)& theStr1, - const Handle(TCollection_HExtendedString)& theStr2) -{ - return TCollection_ExtendedString::IsEqual(theStr1->String(),theStr2->String()); -} - -#endif - -#ifdef _MSC_VER -#pragma once -#endif diff --git a/src/TObj/TObj_Container.hxx b/src/TObj/TObj_Container.hxx index 6deb360d76..f87f293348 100644 --- a/src/TObj/TObj_Container.hxx +++ b/src/TObj/TObj_Container.hxx @@ -23,7 +23,6 @@ #include #include -#include #include typedef NCollection_DataMap TObj_DataMapOfNameLabel; diff --git a/src/TObj/TObj_Object.hxx b/src/TObj/TObj_Object.hxx index 9807246962..2a54499227 100644 --- a/src/TObj/TObj_Object.hxx +++ b/src/TObj/TObj_Object.hxx @@ -18,7 +18,6 @@ #ifndef TObj_Object_HeaderFile #define TObj_Object_HeaderFile -#include #include #include @@ -30,6 +29,8 @@ class TObj_Persistence; class TObj_ObjectIterator; class TObj_TNameContainer; class TCollection_HExtendedString; +class TCollection_HAsciiString; + #include #include #include diff --git a/src/TObj/TObj_ObjectIterator.hxx b/src/TObj/TObj_ObjectIterator.hxx index 129dfbfa2b..4cbdf7fb16 100644 --- a/src/TObj/TObj_ObjectIterator.hxx +++ b/src/TObj/TObj_ObjectIterator.hxx @@ -18,7 +18,8 @@ #ifndef TObj_ObjectIterator_HeaderFile #define TObj_ObjectIterator_HeaderFile -#include +#include +#include class TObj_Object; diff --git a/src/TObj/TObj_TIntSparseArray.hxx b/src/TObj/TObj_TIntSparseArray.hxx index 49d0017b38..f45c6d758b 100644 --- a/src/TObj/TObj_TIntSparseArray.hxx +++ b/src/TObj/TObj_TIntSparseArray.hxx @@ -18,7 +18,6 @@ #ifndef TObj_TIntSparseArray_HeaderFile #define TObj_TIntSparseArray_HeaderFile -#include #include #include diff --git a/src/TObj/TObj_TObject.hxx b/src/TObj/TObj_TObject.hxx index 0ce7c8c785..286f479007 100644 --- a/src/TObj/TObj_TObject.hxx +++ b/src/TObj/TObj_TObject.hxx @@ -18,7 +18,6 @@ #ifndef TObj_TObject_HeaderFile #define TObj_TObject_HeaderFile -#include #include #include diff --git a/src/TObj/TObj_TReference.hxx b/src/TObj/TObj_TReference.hxx index cd1c32e594..abdf0e8516 100644 --- a/src/TObj/TObj_TReference.hxx +++ b/src/TObj/TObj_TReference.hxx @@ -18,7 +18,6 @@ #ifndef TObj_TReference_HeaderFile #define TObj_TReference_HeaderFile -#include #include #include diff --git a/src/TObj/TObj_TXYZ.hxx b/src/TObj/TObj_TXYZ.hxx index 341b6913cc..234411808d 100644 --- a/src/TObj/TObj_TXYZ.hxx +++ b/src/TObj/TObj_TXYZ.hxx @@ -18,7 +18,6 @@ #ifndef TObj_TXYZ_HeaderFile #define TObj_TXYZ_HeaderFile -#include #include #include diff --git a/src/TPrsStd/TPrsStd_DataMapOfGUIDDriver.hxx b/src/TPrsStd/TPrsStd_DataMapOfGUIDDriver.hxx index faea7db1b5..13e4833fd5 100644 --- a/src/TPrsStd/TPrsStd_DataMapOfGUIDDriver.hxx +++ b/src/TPrsStd/TPrsStd_DataMapOfGUIDDriver.hxx @@ -21,8 +21,8 @@ #include #include -typedef NCollection_DataMap TPrsStd_DataMapOfGUIDDriver; -typedef NCollection_DataMap::Iterator TPrsStd_DataMapIteratorOfDataMapOfGUIDDriver; +typedef NCollection_DataMap TPrsStd_DataMapOfGUIDDriver; +typedef NCollection_DataMap::Iterator TPrsStd_DataMapIteratorOfDataMapOfGUIDDriver; #endif diff --git a/src/TopLoc/FILES b/src/TopLoc/FILES index febf3afb81..3df6b5b0af 100644 --- a/src/TopLoc/FILES +++ b/src/TopLoc/FILES @@ -7,7 +7,6 @@ TopLoc_Location.cxx TopLoc_Location.hxx TopLoc_Location.lxx TopLoc_MapIteratorOfMapOfLocation.hxx -TopLoc_MapLocationHasher.hxx TopLoc_MapOfLocation.hxx TopLoc_SListNodeOfItemLocation.cxx TopLoc_SListNodeOfItemLocation.hxx diff --git a/src/TopLoc/TopLoc_IndexedMapOfLocation.hxx b/src/TopLoc/TopLoc_IndexedMapOfLocation.hxx index 44c10c3239..b604ad0923 100644 --- a/src/TopLoc/TopLoc_IndexedMapOfLocation.hxx +++ b/src/TopLoc/TopLoc_IndexedMapOfLocation.hxx @@ -18,10 +18,9 @@ #define TopLoc_IndexedMapOfLocation_HeaderFile #include -#include #include -typedef NCollection_IndexedMap TopLoc_IndexedMapOfLocation; +typedef NCollection_IndexedMap TopLoc_IndexedMapOfLocation; #endif diff --git a/src/TopLoc/TopLoc_Location.cxx b/src/TopLoc/TopLoc_Location.cxx index 7949e4708c..29ec3bee28 100644 --- a/src/TopLoc/TopLoc_Location.cxx +++ b/src/TopLoc/TopLoc_Location.cxx @@ -23,8 +23,6 @@ #include #include -static const gp_Trsf TheIdentity; - //======================================================================= //function : TopLoc_Location //purpose : constructor Identity @@ -51,7 +49,7 @@ TopLoc_Location::TopLoc_Location (const Handle(TopLoc_Datum3D)& D) TopLoc_Location::TopLoc_Location(const gp_Trsf& T) { Handle(TopLoc_Datum3D) D = new TopLoc_Datum3D(T); - myItems.Construct(TopLoc_ItemLocation(D,1)); + myItems.Construct(TopLoc_ItemLocation(D, 1)); } //======================================================================= @@ -61,8 +59,9 @@ TopLoc_Location::TopLoc_Location(const gp_Trsf& T) const gp_Trsf& TopLoc_Location::Transformation() const { + static const gp_Trsf THE_IDENTITY_TRSF; if (IsIdentity()) - return TheIdentity; + return THE_IDENTITY_TRSF; else return myItems.Value().myTrsf; } @@ -166,39 +165,6 @@ TopLoc_Location TopLoc_Location::Powered (const Standard_Integer pwr) const else return Inverted().Powered(-pwr); } -//======================================================================= -// function : HashCode -// purpose : -//======================================================================= -Standard_Integer TopLoc_Location::HashCode (const Standard_Integer theUpperBound) const -{ - // the HashCode computed for a Location is the bitwise exclusive or - // of values computed for each element of the list - // to compute this value, the depth of the element is computed - // the depth is the position of the element in the list - // this depth is multiplied by 3 - // each element is an elementary Datum raised to a Power - // the Power is bitwise left shifted by depth - // this is added to the HashCode of the Datum - // this value is biwise rotated by depth - // the use of depth avoids getting the same result for two permutated lists. - - Standard_Integer depth = 0; - unsigned int h = 0; - TopLoc_SListOfItemLocation items = myItems; - while (items.More()) - { - depth += 3; - unsigned int i = ::HashCode (items.Value().myDatum, theUpperBound); - const Standard_Integer aClampedDepth = depth % 32; - unsigned int j = ((i + items.Value().myPower) << aClampedDepth); - j = j >> (32 - aClampedDepth) | j << aClampedDepth; - h ^= j; - items.Next (); - } - return ::HashCode (h, theUpperBound); -} - //======================================================================= //function : IsEqual //purpose : operator == diff --git a/src/TopLoc/TopLoc_Location.hxx b/src/TopLoc/TopLoc_Location.hxx index 7bab1f9630..8cb2c4a9d0 100644 --- a/src/TopLoc/TopLoc_Location.hxx +++ b/src/TopLoc/TopLoc_Location.hxx @@ -114,10 +114,9 @@ Standard_NODISCARD TopLoc_Location operator/ (const TopLoc_Location& Other) cons Standard_NODISCARD Standard_EXPORT TopLoc_Location Powered (const Standard_Integer pwr) const; //! Returns a hashed value for this local coordinate system. This value is used, with map tables, to store and - //! retrieve the object easily, and is in the range [1, theUpperBound]. - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - Standard_EXPORT Standard_Integer HashCode (Standard_Integer theUpperBound) const; + //! retrieve the object easily + //! @return a computed hash code + size_t HashCode () const; //! Returns true if this location and the location Other //! have the same elementary data, i.e. contain the same @@ -172,23 +171,6 @@ private: }; - #include - -//! Computes a hash code for the given location, in the range [1, theUpperBound] -//! @param theLocation the location which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -inline Standard_Integer HashCode (const TopLoc_Location& theLocation, const Standard_Integer theUpperBound) -{ - return theLocation.HashCode (theUpperBound); -} - -inline void ShallowDump(const TopLoc_Location& me,Standard_OStream& S) { - me.ShallowDump(S); -} - - - #endif // _TopLoc_Location_HeaderFile diff --git a/src/TopLoc/TopLoc_Location.lxx b/src/TopLoc/TopLoc_Location.lxx index 894a8e96f4..f228dea024 100644 --- a/src/TopLoc/TopLoc_Location.lxx +++ b/src/TopLoc/TopLoc_Location.lxx @@ -15,6 +15,7 @@ // commercial license or contractual agreement. #include +#include #include //======================================================================= @@ -68,4 +69,48 @@ inline const Handle(TopLoc_Datum3D)& TopLoc_Location::FirstDatum()const return (*(TopLoc_Location*) &(myItems.Tail())); } +//======================================================================= +// function : HashCode +// purpose : +//======================================================================= +inline size_t TopLoc_Location::HashCode() const +{ + // Hashing base on IsEqual function + if (myItems.IsEmpty()) + { + return 0; + } + size_t aHash = opencascade::MurmurHash::optimalSeed(); + TopLoc_SListOfItemLocation items = myItems; + size_t aCombined[3]; + while (items.More()) + { + aCombined[0] = std::hash{}(items.Value().myDatum); + aCombined[1] = opencascade::hash(items.Value().myPower); + aCombined[2] = aHash; + aHash = opencascade::hashBytes(aCombined, sizeof(aCombined)); + items.Next(); + } + return aHash; +} +//======================================================================= +// function : ShallowDump +// purpose : +//======================================================================= +inline void ShallowDump(const TopLoc_Location& me, Standard_OStream& S) +{ + me.ShallowDump(S); +} + +namespace std +{ + template <> + struct hash + { + size_t operator()(const TopLoc_Location& theLocation) const + { + return theLocation.HashCode(); + } + }; +} diff --git a/src/TopLoc/TopLoc_MapLocationHasher.hxx b/src/TopLoc/TopLoc_MapLocationHasher.hxx deleted file mode 100644 index f751a675ed..0000000000 --- a/src/TopLoc/TopLoc_MapLocationHasher.hxx +++ /dev/null @@ -1,26 +0,0 @@ -// Created on: 1990-12-19 -// Created by: Christophe MARION -// Copyright (c) 1990-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef TopLoc_MapLocationHasher_HeaderFile -#define TopLoc_MapLocationHasher_HeaderFile - -#include -#include - -typedef NCollection_DefaultHasher TopLoc_MapLocationHasher; - - -#endif diff --git a/src/TopLoc/TopLoc_MapOfLocation.hxx b/src/TopLoc/TopLoc_MapOfLocation.hxx index 9d9873b8b0..38f4b9b7c7 100644 --- a/src/TopLoc/TopLoc_MapOfLocation.hxx +++ b/src/TopLoc/TopLoc_MapOfLocation.hxx @@ -17,11 +17,11 @@ #ifndef TopLoc_MapOfLocation_HeaderFile #define TopLoc_MapOfLocation_HeaderFile -#include +#include #include -typedef NCollection_Map TopLoc_MapOfLocation; -typedef NCollection_Map::Iterator TopLoc_MapIteratorOfMapOfLocation; +typedef NCollection_Map TopLoc_MapOfLocation; +typedef NCollection_Map::Iterator TopLoc_MapIteratorOfMapOfLocation; #endif diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_Area1dBuilder.cxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_Area1dBuilder.cxx index 6d04335a6e..56732fa7b3 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_Area1dBuilder.cxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_Area1dBuilder.cxx @@ -118,7 +118,7 @@ void TopOpeBRepBuild_Area1dBuilder::InitAreaBuilder Loopinside = Standard_False; for (AreaIter.Initialize(myArea); AreaIter.More(); AreaIter.Next()) { - TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); + const TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); if ( aArea.IsEmpty() ) continue; state = CompareLoopWithListOfLoop(LC,L,aArea,TopOpeBRepBuild_BLOCK); if (state == TopAbs_UNKNOWN) Atomize(state,TopAbs_IN); @@ -127,7 +127,7 @@ void TopOpeBRepBuild_Area1dBuilder::InitAreaBuilder } // end of Area scan if ( Loopinside ) { - TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); + TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.ChangeValue(); ADD_Loop_TO_LISTOFLoop(L,aArea,(void*)("IN, to current area")); } else if ( ! Loopinside ) { @@ -150,7 +150,7 @@ void TopOpeBRepBuild_Area1dBuilder::InitAreaBuilder Loopinside = Standard_False; for (AreaIter.Initialize(myArea); AreaIter.More(); AreaIter.Next() ) { - TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); + TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.ChangeValue(); if ( aArea.IsEmpty() ) continue; state = CompareLoopWithListOfLoop(LC,L,aArea,TopOpeBRepBuild_ANYLOOP); if (state == TopAbs_UNKNOWN) Atomize(state,TopAbs_IN); @@ -159,7 +159,7 @@ void TopOpeBRepBuild_Area1dBuilder::InitAreaBuilder } // end of Area scan if ( Loopinside) { - TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); + TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.ChangeValue(); Standard_Boolean allShape = Standard_True; TopOpeBRepBuild_ListOfLoop removedLoops; LoopIter.Initialize(aArea); @@ -175,7 +175,7 @@ void TopOpeBRepBuild_Area1dBuilder::InitAreaBuilder allShape = allShape && curL->IsShape(); REM_Loop_FROM_LISTOFLoop - (LoopIter,AreaIter.Value(),(void*)("loop of cur. area, cur. area")); + (LoopIter,AreaIter.ChangeValue(),(void*)("loop of cur. area, cur. area")); } else { LoopIter.Next(); diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_Area1dBuilder.hxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_Area1dBuilder.hxx index ebdb57325b..ee701ef6e0 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_Area1dBuilder.hxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_Area1dBuilder.hxx @@ -24,7 +24,6 @@ #include #include #include -#include class TopOpeBRepBuild_PaveSet; class TopOpeBRepBuild_PaveClassifier; class TopOpeBRepBuild_LoopSet; diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_Area2dBuilder.cxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_Area2dBuilder.cxx index 6cd9cef09e..f44a6fe831 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_Area2dBuilder.cxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_Area2dBuilder.cxx @@ -85,7 +85,7 @@ void TopOpeBRepBuild_Area2dBuilder::InitAreaBuilder Loopinside = Standard_False; for (AreaIter.Initialize(myArea); AreaIter.More(); AreaIter.Next()) { - TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); + TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.ChangeValue(); if ( aArea.IsEmpty() ) continue; state = CompareLoopWithListOfLoop(LC,L,aArea,TopOpeBRepBuild_BLOCK ); if (state == TopAbs_UNKNOWN) Atomize(state,TopAbs_IN); @@ -94,7 +94,7 @@ void TopOpeBRepBuild_Area2dBuilder::InitAreaBuilder } // end of Area scan if ( Loopinside ) { - TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); + TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.ChangeValue(); ADD_Loop_TO_LISTOFLoop(L,aArea,(void*)("IN, to current area")); } else if ( ! Loopinside ) { @@ -117,7 +117,7 @@ void TopOpeBRepBuild_Area2dBuilder::InitAreaBuilder Loopinside = Standard_False; for (AreaIter.Initialize(myArea); AreaIter.More(); AreaIter.Next() ) { - TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); + TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.ChangeValue(); if ( aArea.IsEmpty() ) continue; state = CompareLoopWithListOfLoop(LC,L,aArea,TopOpeBRepBuild_ANYLOOP); if (state == TopAbs_UNKNOWN) Atomize(state,TopAbs_IN); @@ -126,7 +126,7 @@ void TopOpeBRepBuild_Area2dBuilder::InitAreaBuilder } // end of Area scan if ( Loopinside) { - TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); + TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.ChangeValue(); Standard_Boolean allShape = Standard_True; TopOpeBRepBuild_ListOfLoop removedLoops; LoopIter.Initialize(aArea); @@ -142,7 +142,7 @@ void TopOpeBRepBuild_Area2dBuilder::InitAreaBuilder allShape = allShape && curL->IsShape(); REM_Loop_FROM_LISTOFLoop - (LoopIter,AreaIter.Value(),(void*)("loop of cur. area, cur. area")); + (LoopIter,AreaIter.ChangeValue(),(void*)("loop of cur. area, cur. area")); } else { LoopIter.Next(); diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_Area3dBuilder.cxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_Area3dBuilder.cxx index 3d13659941..fbcd3bac78 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_Area3dBuilder.cxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_Area3dBuilder.cxx @@ -80,7 +80,7 @@ void TopOpeBRepBuild_Area3dBuilder::InitAreaBuilder Loopinside = Standard_False; for (AreaIter.Initialize(myArea); AreaIter.More(); AreaIter.Next()) { - TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); + TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.ChangeValue(); if ( aArea.IsEmpty() ) continue; state = CompareLoopWithListOfLoop(LC,L,aArea,TopOpeBRepBuild_BLOCK ); if (state == TopAbs_UNKNOWN) Atomize(state,TopAbs_IN); @@ -89,7 +89,7 @@ void TopOpeBRepBuild_Area3dBuilder::InitAreaBuilder } // end of Area scan if ( Loopinside ) { - TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); + TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.ChangeValue(); ADD_Loop_TO_LISTOFLoop(L,aArea,(void*)("IN, to current area")); } else if ( ! Loopinside ) { @@ -112,7 +112,7 @@ void TopOpeBRepBuild_Area3dBuilder::InitAreaBuilder Loopinside = Standard_False; for (AreaIter.Initialize(myArea); AreaIter.More(); AreaIter.Next() ) { - TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); + TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.ChangeValue(); if ( aArea.IsEmpty() ) continue; state = CompareLoopWithListOfLoop(LC,L,aArea,TopOpeBRepBuild_ANYLOOP); if (state == TopAbs_UNKNOWN) Atomize(state,TopAbs_IN); @@ -121,7 +121,7 @@ void TopOpeBRepBuild_Area3dBuilder::InitAreaBuilder } // end of Area scan if ( Loopinside) { - TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); + TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.ChangeValue(); Standard_Boolean allShape = Standard_True; TopOpeBRepBuild_ListOfLoop removedLoops; LoopIter.Initialize(aArea); @@ -138,7 +138,7 @@ void TopOpeBRepBuild_Area3dBuilder::InitAreaBuilder allShape = allShape && curL->IsShape(); REM_Loop_FROM_LISTOFLoop - (LoopIter,AreaIter.Value(),(void*)("loop of cur. area, cur. area")); + (LoopIter,AreaIter.ChangeValue(),(void*)("loop of cur. area, cur. area")); } else { LoopIter.Next(); diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_AreaBuilder.cxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_AreaBuilder.cxx index ff352553c0..0340722828 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_AreaBuilder.cxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_AreaBuilder.cxx @@ -154,7 +154,7 @@ void TopOpeBRepBuild_AreaBuilder::InitAreaBuilder Loopinside = Standard_False; for (AreaIter.Initialize(myArea); AreaIter.More(); AreaIter.Next()) { - TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); + const TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); if ( aArea.IsEmpty() ) continue; state = CompareLoopWithListOfLoop(LC,L,aArea,TopOpeBRepBuild_BLOCK ); if (state == TopAbs_UNKNOWN) Atomize(state,TopAbs_IN); @@ -163,7 +163,7 @@ void TopOpeBRepBuild_AreaBuilder::InitAreaBuilder } // end of Area scan if ( Loopinside ) { - TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); + TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.ChangeValue(); ADD_Loop_TO_LISTOFLoop(L,aArea,(void*)("IN, to current area")); } else if ( ! Loopinside ) { @@ -186,7 +186,7 @@ void TopOpeBRepBuild_AreaBuilder::InitAreaBuilder Loopinside = Standard_False; for (AreaIter.Initialize(myArea); AreaIter.More(); AreaIter.Next() ) { - TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); + const TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); if ( aArea.IsEmpty() ) continue; state = CompareLoopWithListOfLoop(LC,L,aArea,TopOpeBRepBuild_ANYLOOP); if (state == TopAbs_UNKNOWN) Atomize(state,TopAbs_IN); @@ -195,7 +195,7 @@ void TopOpeBRepBuild_AreaBuilder::InitAreaBuilder } // end of Area scan if ( Loopinside) { - TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.Value(); + TopOpeBRepBuild_ListOfLoop& aArea = AreaIter.ChangeValue(); Standard_Boolean allShape = Standard_True; TopOpeBRepBuild_ListOfLoop removedLoops; LoopIter.Initialize(aArea); @@ -211,7 +211,7 @@ void TopOpeBRepBuild_AreaBuilder::InitAreaBuilder allShape = allShape && curL->IsShape(); REM_Loop_FROM_LISTOFLoop - (LoopIter,AreaIter.Value(),(void*)("loop of cur. area, cur. area")); + (LoopIter,AreaIter.ChangeValue(),(void*)("loop of cur. area, cur. area")); } else { LoopIter.Next(); diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_AreaBuilder.hxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_AreaBuilder.hxx index b57c66b30e..61f239f2de 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_AreaBuilder.hxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_AreaBuilder.hxx @@ -28,7 +28,6 @@ #include #include #include -#include class TopOpeBRepBuild_LoopSet; class TopOpeBRepBuild_LoopClassifier; class TopOpeBRepBuild_Loop; diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_BuildEdges.cxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_BuildEdges.cxx index 5bdb161264..a0dbf89c82 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_BuildEdges.cxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_BuildEdges.cxx @@ -71,7 +71,7 @@ void TopOpeBRepBuild_Builder::BuildEdges(const Standard_Integer iC,const Handle( TopTools_ListIteratorOfListOfShape It(EL); Standard_Integer inewC = -1; for (; It.More(); It.Next()) { - TopoDS_Edge& newEdge = TopoDS::Edge(It.Value()); + TopoDS_Edge& newEdge = TopoDS::Edge(It.ChangeValue()); myBuildTool.RecomputeCurves(curC,TopoDS::Edge(anEdge),newEdge,inewC,HDS); if (inewC != -1) ChangeNewEdges(inewC).Append(newEdge); } @@ -80,7 +80,7 @@ void TopOpeBRepBuild_Builder::BuildEdges(const Standard_Integer iC,const Handle( } else { for (It.Initialize(EL);It.More();It.Next()) { - TopoDS_Edge& newEdge = TopoDS::Edge(It.Value()); + TopoDS_Edge& newEdge = TopoDS::Edge(It.ChangeValue()); myBuildTool.UpdateEdge(anEdge,newEdge); } } diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_Builder.cxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_Builder.cxx index 4125bdbb15..5a8fa32eb4 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_Builder.cxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_Builder.cxx @@ -669,7 +669,7 @@ Standard_Boolean TopOpeBRepBuild_Builder::IsShapeOf(const TopoDS_Shape& s,const Standard_Boolean TopOpeBRepBuild_Builder::Contains(const TopoDS_Shape& S,const TopTools_ListOfShape& L) { for (TopTools_ListIteratorOfListOfShape it(L); it.More(); it.Next() ) { - TopoDS_Shape& SL = it.Value(); + const TopoDS_Shape& SL = it.Value(); Standard_Boolean issame = SL.IsSame(S); if ( issame ) return Standard_True; } diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_Builder.hxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_Builder.hxx index 43e21a2228..5b0efdb379 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_Builder.hxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_Builder.hxx @@ -46,7 +46,6 @@ #include #include #include -#include class TopOpeBRepDS_HDataStructure; class TopOpeBRepTool_ShapeExplorer; class TopOpeBRepBuild_ShapeSet; diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_Builder1.cxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_Builder1.cxx index 20d732fbd2..7e9ab79f5d 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_Builder1.cxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_Builder1.cxx @@ -181,7 +181,7 @@ void TopOpeBRepBuild_Builder1::MergeKPart() TopTools_ListIteratorOfListOfShape its(Merged(myShape1,myState1)); for (; its.More(); its.Next()) { - CorrectResult2d(its.Value()); + CorrectResult2d(its.ChangeValue()); } } @@ -1369,7 +1369,7 @@ Standard_Integer TopOpeBRepBuild_Builder1::PerformPieceOn2D (const TopoDS_Shape& // we are looking for the same piece as aPieceObj among aPartOnTool TopTools_ListIteratorOfListOfShape anItTool(aPartOnTool); for (k=1; anItTool.More(); anItTool.Next(), k++) { - TopoDS_Shape& aPieceTool=anItTool.Value(); + TopoDS_Shape& aPieceTool=anItTool.ChangeValue(); aPieceTool.Orientation(anEdgeTool.Orientation()); Standard_Boolean aIsSameCnd, IsDegFlag; diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_Builder1.hxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_Builder1.hxx index 344f90aea5..48c8e310f4 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_Builder1.hxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_Builder1.hxx @@ -132,7 +132,7 @@ private: TopoDS_Shape mySDFaceToFill; TopoDS_Shape myBaseFaceToFill; TopTools_IndexedDataMapOfShapeListOfShape myMapOfEdgeFaces; - NCollection_DataMap myMapOfEdgeWithFaceState; + NCollection_DataMap myMapOfEdgeWithFaceState; TopTools_IndexedMapOfShape myProcessedPartsOut2d; TopTools_IndexedMapOfShape myProcessedPartsON2d; TopTools_IndexedMapOfShape mySplitsONtoKeep; diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_CompositeClassifier.hxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_CompositeClassifier.hxx index cbf0d031c8..9ee30b050a 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_CompositeClassifier.hxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_CompositeClassifier.hxx @@ -21,7 +21,6 @@ #include #include -#include #include #include class TopOpeBRepBuild_BlockBuilder; diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_CorrectFace2d.hxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_CorrectFace2d.hxx index 4f3534007e..214c934f40 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_CorrectFace2d.hxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_CorrectFace2d.hxx @@ -25,7 +25,6 @@ #include #include #include -#include #include class TopoDS_Edge; class gp_Pnt2d; diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_End.cxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_End.cxx index 871ef9b261..4d85cce540 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_End.cxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_End.cxx @@ -258,7 +258,7 @@ void TopOpeBRepBuild_Builder::End() // TopAbs_State state = myState1; TopTools_ListOfShape& ls = ChangeMerged(myShape1,myState1); for (TopTools_ListIteratorOfListOfShape itls(ls);itls.More();itls.Next()) { - TopoDS_Shape& SFE = itls.Value(); + TopoDS_Shape& SFE = itls.ChangeValue(); TopOpeBRepTool_FuseEdges FE(SFE); // avoid fusing old edges diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_GridFF.cxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_GridFF.cxx index 7112add40f..2e012b6ae6 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_GridFF.cxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_GridFF.cxx @@ -474,7 +474,7 @@ static Standard_Boolean FUN_validF1edge(const TopoDS_Shape& F) // les faces construites (LOFS) prennent l'orientation originale de FF TopAbs_Orientation odsFF = myDataStructure->Shape(iFF).Orientation(); - for(TopTools_ListIteratorOfListOfShape itt(LOFS);itt.More();itt.Next()) itt.Value().Orientation(odsFF); + for(TopTools_ListIteratorOfListOfShape itt(LOFS);itt.More();itt.Next()) itt.ChangeValue().Orientation(odsFF); TopTools_ListIteratorOfListOfShape it1; for (it1.Initialize(LF1); it1.More(); it1.Next()) { diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_GridSS.cxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_GridSS.cxx index 59250b94fb..d95807c9d5 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_GridSS.cxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_GridSS.cxx @@ -620,7 +620,7 @@ Standard_EXPORT void FUNBUILD_ORIENTLOFS(TopOpeBRepBuild_Builder& B, TopTools_ListOfShape& LOFS) { for (TopTools_ListIteratorOfListOfShape it(LOFS);it.More();it.Next()) { - TopoDS_Shape& f = it.Value(); + TopoDS_Shape& f = it.ChangeValue(); Standard_Boolean of1,of2; FUNBUILD_ANCESTORRANKGET(B,f,of1,of2); TopAbs_Orientation orif = f.Orientation(); Standard_Boolean r12 = B.Reverse(TB1,TB2); Standard_Boolean r21 = B.Reverse(TB2,TB1); diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_HBuilder.cxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_HBuilder.cxx index a5b37062a2..bb2c046bd8 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_HBuilder.cxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_HBuilder.cxx @@ -353,13 +353,13 @@ void TopOpeBRepBuild_HBuilder::MakeEdgeAncestorMap() its.Initialize(los); if(re == 1) for(; its.More(); its.Next()) { - TopoDS_Shape& SecEdg = its.Value(); + const TopoDS_Shape& SecEdg = its.Value(); if(!mySectEdgeDSEdges1.IsBound(SecEdg)) mySectEdgeDSEdges1.Bind(SecEdg, ei); } else if(re == 2) for(; its.More(); its.Next()) { - TopoDS_Shape& SecEdg = its.Value(); + const TopoDS_Shape& SecEdg = its.Value(); if(!mySectEdgeDSEdges2.IsBound(SecEdg)) mySectEdgeDSEdges2.Bind(SecEdg,ei); } diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_Section.cxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_Section.cxx index 020074919f..f37edb72b2 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_Section.cxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_Section.cxx @@ -506,7 +506,7 @@ void TopOpeBRepBuild_Builder::SplitSectionEdges() } TopTools_ListIteratorOfListOfShape itlon(lon); for(;itlon.More();itlon.Next()) { - TopoDS_Edge& eon = TopoDS::Edge(itlon.Value()); + TopoDS_Edge& eon = TopoDS::Edge(itlon.ChangeValue()); Standard_Real f,l; Standard_Boolean hasPC = FC2D_HasCurveOnSurface(eon,F); if (hasPC) continue; #ifdef OCCT_DEBUG diff --git a/src/TopOpeBRepBuild/TopOpeBRepBuild_ShellFaceSet.hxx b/src/TopOpeBRepBuild/TopOpeBRepBuild_ShellFaceSet.hxx index c4af95cdb6..00a7618fa4 100644 --- a/src/TopOpeBRepBuild/TopOpeBRepBuild_ShellFaceSet.hxx +++ b/src/TopOpeBRepBuild/TopOpeBRepBuild_ShellFaceSet.hxx @@ -22,7 +22,6 @@ #include #include -#include #include #include class TopoDS_Shape; diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_Check.cxx b/src/TopOpeBRepDS/TopOpeBRepDS_Check.cxx index 0302e68634..1f48dcfef7 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_Check.cxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_Check.cxx @@ -119,7 +119,7 @@ Standard_Boolean TopOpeBRepDS_Check::ChkIntgInterf it1.Initialize(LI); Standard_Boolean IsOK = Standard_True; while (it1.More() ) { - Handle(TopOpeBRepDS_Interference)& I1 = it1.Value(); + Handle(TopOpeBRepDS_Interference) I1 = it1.Value(); IsOK = IsOK && CheckDS(I1->Support(), I1->SupportType()); IsOK = IsOK && CheckDS(I1->Geometry(), I1->GeometryType()); it1.Next(); @@ -375,7 +375,7 @@ Standard_Boolean CheckEdgeParameter(const Handle(TopOpeBRepDS_HDataStructure)& m const TopOpeBRepDS_ListOfInterference& LI = DS.ShapeInterferences(i); it1.Initialize(LI); while (it1.More() ) { - Handle(TopOpeBRepDS_Interference)& I1 = it1.Value(); + Handle(TopOpeBRepDS_Interference) I1 = it1.Value(); Handle(TopOpeBRepDS_EdgeVertexInterference) EVI = Handle(TopOpeBRepDS_EdgeVertexInterference)::DownCast(I1); if(!EVI.IsNull()) { @@ -425,11 +425,11 @@ Standard_OStream& TopOpeBRepDS_Check::PrintIntg(Standard_OStream& OS) PrintMap(myMapPointStatus, "Point", OS); //display of the topology - TopOpeBRepDS_DataMapIteratorOfDataMapOfCheckStatus DMI(myMapShapeStatus); TopOpeBRepDS_DataMapOfCheckStatus MapVertex, MapEdge, MapWire, MapFace, MapSolid; Standard_Integer i; // different Map keep their index of myMapShapeStatus - for(DMI.Reset();DMI.More();DMI.Next()) { + for(TopOpeBRepDS_DataMapIteratorOfDataMapOfCheckStatus DMI(myMapShapeStatus); DMI.More();DMI.Next()) + { i = DMI.Key(); const TopoDS_Shape& S =myHDS->Shape(i); switch(S.ShapeType()) { @@ -485,12 +485,13 @@ Standard_OStream& TopOpeBRepDS_Check::PrintElts(TopOpeBRepDS_DataMapOfCheckStatu Standard_Boolean& b, Standard_OStream& OS) { - TopOpeBRepDS_DataMapIteratorOfDataMapOfCheckStatus DMI(MapStat); Standard_Boolean bb = !b; b = Standard_True; Standard_Integer i; TopOpeBRepDS_CheckStatus s; - for(DMI.Reset();DMI.More();DMI.Next()) { + for(TopOpeBRepDS_DataMapIteratorOfDataMapOfCheckStatus DMI(MapStat); + DMI.More();DMI.Next()) + { s = DMI.Value(); i = DMI.Key(); if(s == Stat) { diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_DataMapOfCheckStatus.hxx b/src/TopOpeBRepDS/TopOpeBRepDS_DataMapOfCheckStatus.hxx index 49b58f388b..51cddc616e 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_DataMapOfCheckStatus.hxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_DataMapOfCheckStatus.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap TopOpeBRepDS_DataMapOfCheckStatus; -typedef NCollection_DataMap::Iterator TopOpeBRepDS_DataMapIteratorOfDataMapOfCheckStatus; +typedef NCollection_DataMap TopOpeBRepDS_DataMapOfCheckStatus; +typedef NCollection_DataMap::Iterator TopOpeBRepDS_DataMapIteratorOfDataMapOfCheckStatus; #endif diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_DataMapOfIntegerListOfInterference.hxx b/src/TopOpeBRepDS/TopOpeBRepDS_DataMapOfIntegerListOfInterference.hxx index 227b4c8839..ca0af039ea 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_DataMapOfIntegerListOfInterference.hxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_DataMapOfIntegerListOfInterference.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap TopOpeBRepDS_DataMapOfIntegerListOfInterference; -typedef NCollection_DataMap::Iterator TopOpeBRepDS_DataMapIteratorOfDataMapOfIntegerListOfInterference; +typedef NCollection_DataMap TopOpeBRepDS_DataMapOfIntegerListOfInterference; +typedef NCollection_DataMap::Iterator TopOpeBRepDS_DataMapIteratorOfDataMapOfIntegerListOfInterference; #endif diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_DataMapOfInterferenceListOfInterference.hxx b/src/TopOpeBRepDS/TopOpeBRepDS_DataMapOfInterferenceListOfInterference.hxx index 3a504ee62d..964e3cd543 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_DataMapOfInterferenceListOfInterference.hxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_DataMapOfInterferenceListOfInterference.hxx @@ -18,11 +18,10 @@ #define TopOpeBRepDS_DataMapOfInterferenceListOfInterference_HeaderFile #include -#include #include -typedef NCollection_DataMap TopOpeBRepDS_DataMapOfInterferenceListOfInterference; -typedef NCollection_DataMap::Iterator TopOpeBRepDS_DataMapIteratorOfDataMapOfInterferenceListOfInterference; +typedef NCollection_DataMap TopOpeBRepDS_DataMapOfInterferenceListOfInterference; +typedef NCollection_DataMap::Iterator TopOpeBRepDS_DataMapIteratorOfDataMapOfInterferenceListOfInterference; #endif diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_DataMapOfInterferenceShape.hxx b/src/TopOpeBRepDS/TopOpeBRepDS_DataMapOfInterferenceShape.hxx index 721ed280bd..0e958f9d0f 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_DataMapOfInterferenceShape.hxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_DataMapOfInterferenceShape.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap TopOpeBRepDS_DataMapOfInterferenceShape; -typedef NCollection_DataMap::Iterator TopOpeBRepDS_DataMapIteratorOfDataMapOfInterferenceShape; +typedef NCollection_DataMap TopOpeBRepDS_DataMapOfInterferenceShape; +typedef NCollection_DataMap::Iterator TopOpeBRepDS_DataMapIteratorOfDataMapOfInterferenceShape; #endif diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_DoubleMapOfIntegerShape.hxx b/src/TopOpeBRepDS/TopOpeBRepDS_DoubleMapOfIntegerShape.hxx index 559a973f6f..e45bb55088 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_DoubleMapOfIntegerShape.hxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_DoubleMapOfIntegerShape.hxx @@ -17,12 +17,11 @@ #ifndef TopOpeBRepDS_DoubleMapOfIntegerShape_HeaderFile #define TopOpeBRepDS_DoubleMapOfIntegerShape_HeaderFile -#include #include #include -typedef NCollection_DoubleMap TopOpeBRepDS_DoubleMapOfIntegerShape; -typedef NCollection_DoubleMap::Iterator TopOpeBRepDS_DoubleMapIteratorOfDoubleMapOfIntegerShape; +typedef NCollection_DoubleMap,TopTools_ShapeMapHasher> TopOpeBRepDS_DoubleMapOfIntegerShape; +typedef TopOpeBRepDS_DoubleMapOfIntegerShape::Iterator TopOpeBRepDS_DoubleMapIteratorOfDoubleMapOfIntegerShape; #endif diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_EIR.cxx b/src/TopOpeBRepDS/TopOpeBRepDS_EIR.cxx index 278bd8723c..4e66fa56a8 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_EIR.cxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_EIR.cxx @@ -54,7 +54,7 @@ static void FDS_reduceONFACEinterferences(TopOpeBRepDS_ListOfInterference& LI, TopOpeBRepDS_ListIteratorOfListOfInterference it1; // set hasONFACE = True if LI contains interfs with (ON,FACE) transition(s). Standard_Boolean hasONFACE = Standard_False; for (it1.Initialize(LI); it1.More(); it1.Next() ) { - Handle(TopOpeBRepDS_Interference)& I1 = it1.Value(); + Handle(TopOpeBRepDS_Interference)& I1 = it1.ChangeValue(); TopOpeBRepDS_Kind GT1,ST1; Standard_Integer G1,S1; FDS_data(I1,GT1,G1,ST1,S1); if ( GT1 == TopOpeBRepDS_POINT ) { hasONFACE = FUN_hasStateShape(I1->Transition(),TopAbs_ON,TopAbs_FACE); @@ -66,7 +66,7 @@ static void FDS_reduceONFACEinterferences(TopOpeBRepDS_ListOfInterference& LI, // LI has (ON,FACE) : remove all other interf (POINT,(not(ON,FACE))) it1.Initialize(LI); while( it1.More() ) { - Handle(TopOpeBRepDS_Interference)& I1 = it1.Value(); + Handle(TopOpeBRepDS_Interference)& I1 = it1.ChangeValue(); TopOpeBRepDS_Kind GT1,ST1; Standard_Integer G1,S1; FDS_data(I1,GT1,G1,ST1,S1); if ( GT1 == TopOpeBRepDS_POINT ) { hasONFACE = FUN_hasStateShape(I1->Transition(),TopAbs_ON,TopAbs_FACE); diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_EXPORT.cxx b/src/TopOpeBRepDS/TopOpeBRepDS_EXPORT.cxx index cb67638f1c..c36ce2dc2c 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_EXPORT.cxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_EXPORT.cxx @@ -1718,7 +1718,7 @@ Standard_EXPORT void FUN_ds_completeforSE8(const Handle(TopOpeBRepDS_HDataStruct if (redu2d) { // {I1d=(Tr(Esd),vG,Esd), I2d=(Tr(F),vG,E)} TopOpeBRepDS_ListIteratorOfListOfInterference it(l2dFE); TopOpeBRepDS_ListOfInterference al2dFE; while (it.More()) { - Handle(TopOpeBRepDS_Interference)& I2dFE = it.Value(); + Handle(TopOpeBRepDS_Interference)& I2dFE = it.ChangeValue(); TopOpeBRepDS_Transition newT2d; Standard_Boolean ok = FUN_ds_redu2d1d(BDS,ISE,I2dFE,l1dE, newT2d); if (!ok) {it.Next(); continue;} I2dFE->ChangeTransition() = newT2d; al2dFE.Append(I2dFE); diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_FIR.cxx b/src/TopOpeBRepDS/TopOpeBRepDS_FIR.cxx index f3e7f76686..0e578f4959 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_FIR.cxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_FIR.cxx @@ -39,7 +39,7 @@ Standard_Boolean FUN_isPonF(const TopOpeBRepDS_ListOfInterference& LIF,const gp_ TopOpeBRepDS_ListIteratorOfListOfInterference itF(LIF); for (;itF.More();itF.Next()) { - Handle(TopOpeBRepDS_Interference)& IF = itF.Value(); FDS_data(IF,GT1,G1,ST1,S1); + Handle(TopOpeBRepDS_Interference) IF = itF.Value(); FDS_data(IF,GT1,G1,ST1,S1); const TopoDS_Face& F = TopoDS::Face(BDS.Shape(S1)); TopAbs_Orientation oEinF; Standard_Boolean edonfa = FUN_tool_orientEinFFORWARD(E,F,oEinF ); if ( edonfa ) Pok = Standard_True; @@ -70,7 +70,7 @@ Standard_Boolean FUN_findPonF(const TopoDS_Edge& E,const TopOpeBRepDS_DataStruct for (;itI.More();itI.Next()) { Standard_Boolean pardef = Standard_False; - Handle(TopOpeBRepDS_Interference)& I = itI.Value(); FDS_data(I,GT1,G1,ST1,S1); + Handle(TopOpeBRepDS_Interference)& I = itI.ChangeValue(); FDS_data(I,GT1,G1,ST1,S1); Handle(TopOpeBRepDS_CurvePointInterference) CPI (Handle(TopOpeBRepDS_CurvePointInterference)::DownCast(I)); Handle(TopOpeBRepDS_ShapeShapeInterference) SSI (Handle(TopOpeBRepDS_ShapeShapeInterference)::DownCast(I)); if (!CPI.IsNull()) { @@ -216,7 +216,7 @@ void FUN_GmapS(TopOpeBRepDS_ListOfInterference& LI, const TopOpeBRepDS_DataStruc mosd.Clear(); TopOpeBRepDS_Kind GT1,ST1;Standard_Integer G1,S1; for (TopOpeBRepDS_ListIteratorOfListOfInterference it1(LI);it1.More();it1.Next()) { - Handle(TopOpeBRepDS_Interference)& I1=it1.Value(); FDS_data(I1,GT1,G1,ST1,S1); + Handle(TopOpeBRepDS_Interference)& I1=it1.ChangeValue(); FDS_data(I1,GT1,G1,ST1,S1); if ( GT1 != MDSke || ST1 != MDSkf ) continue; const TopoDS_Shape& SG1 = BDS.Shape(G1); TopOpeBRepDS_ShapeData thedata; diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_MapOfCurve.hxx b/src/TopOpeBRepDS/TopOpeBRepDS_MapOfCurve.hxx index 1206864a9c..ad1799c73f 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_MapOfCurve.hxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_MapOfCurve.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap TopOpeBRepDS_MapOfCurve; -typedef NCollection_DataMap::Iterator TopOpeBRepDS_DataMapIteratorOfMapOfCurve; +typedef NCollection_DataMap TopOpeBRepDS_MapOfCurve; +typedef NCollection_DataMap::Iterator TopOpeBRepDS_DataMapIteratorOfMapOfCurve; #endif diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_MapOfIntegerShapeData.hxx b/src/TopOpeBRepDS/TopOpeBRepDS_MapOfIntegerShapeData.hxx index 6dd5be6afd..92a4c038ae 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_MapOfIntegerShapeData.hxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_MapOfIntegerShapeData.hxx @@ -18,11 +18,10 @@ #define TopOpeBRepDS_MapOfIntegerShapeData_HeaderFile #include -#include #include -typedef NCollection_DataMap TopOpeBRepDS_MapOfIntegerShapeData; -typedef NCollection_DataMap::Iterator TopOpeBRepDS_DataMapIteratorOfMapOfIntegerShapeData; +typedef NCollection_DataMap TopOpeBRepDS_MapOfIntegerShapeData; +typedef NCollection_DataMap::Iterator TopOpeBRepDS_DataMapIteratorOfMapOfIntegerShapeData; #endif diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_MapOfPoint.hxx b/src/TopOpeBRepDS/TopOpeBRepDS_MapOfPoint.hxx index 939735ed4f..cf768bae5b 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_MapOfPoint.hxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_MapOfPoint.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap TopOpeBRepDS_MapOfPoint; -typedef NCollection_DataMap::Iterator TopOpeBRepDS_DataMapIteratorOfMapOfPoint; +typedef NCollection_DataMap TopOpeBRepDS_MapOfPoint; +typedef NCollection_DataMap::Iterator TopOpeBRepDS_DataMapIteratorOfMapOfPoint; #endif diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_MapOfSurface.hxx b/src/TopOpeBRepDS/TopOpeBRepDS_MapOfSurface.hxx index aa7404a33d..a73c04045b 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_MapOfSurface.hxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_MapOfSurface.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap TopOpeBRepDS_MapOfSurface; -typedef NCollection_DataMap::Iterator TopOpeBRepDS_DataMapIteratorOfMapOfSurface; +typedef NCollection_DataMap TopOpeBRepDS_MapOfSurface; +typedef NCollection_DataMap::Iterator TopOpeBRepDS_DataMapIteratorOfMapOfSurface; #endif diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_Marker.hxx b/src/TopOpeBRepDS/TopOpeBRepDS_Marker.hxx index e1b9ae3086..90a735722d 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_Marker.hxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_Marker.hxx @@ -23,7 +23,6 @@ #include #include #include -#include class TopOpeBRepDS_Marker; diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_ProcessEdgeInterferences.cxx b/src/TopOpeBRepDS/TopOpeBRepDS_ProcessEdgeInterferences.cxx index c217ab605d..5190c9f175 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_ProcessEdgeInterferences.cxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_ProcessEdgeInterferences.cxx @@ -125,7 +125,7 @@ Standard_EXPORT Standard_Integer FUN_unkeepEinterferences TopOpeBRepDS_ListIteratorOfListOfInterference it1(LI); while (it1.More() ) { - Handle(TopOpeBRepDS_Interference)& I1 = it1.Value(); + Handle(TopOpeBRepDS_Interference)& I1 = it1.ChangeValue(); Standard_Boolean k1 = ::FUN_keepEinterference(BDS,I1,E); if ( !k1 ) { LI.Remove(it1); @@ -234,7 +234,7 @@ Standard_EXPORT void FUN_unkeepEsymetrictransitions it1.Initialize(LI); while (it1.More() ) { Standard_Boolean it1toremove = Standard_False; - Handle(TopOpeBRepDS_Interference)& I1 = it1.Value(); + Handle(TopOpeBRepDS_Interference)& I1 = it1.ChangeValue(); TopOpeBRepDS_Kind GT1,ST1; Standard_Integer G1,S1; FDS_data(I1,GT1,G1,ST1,S1); TopAbs_ShapeEnum tsb1,tsa1; Standard_Integer isb1,isa1; ::FDS_Tdata(I1,tsb1,isb1,tsa1,isa1); const TopOpeBRepDS_Transition T1 = I1->Transition(); @@ -304,7 +304,7 @@ Standard_EXPORT void FUN_orderFFsamedomain it1.Initialize(LI); while (it1.More() ) { - Handle(TopOpeBRepDS_Interference)& I1 = it1.Value(); + Handle(TopOpeBRepDS_Interference)& I1 = it1.ChangeValue(); TopOpeBRepDS_Kind GT1,ST1; Standard_Integer G1,S1; FDS_data(I1,GT1,G1,ST1,S1); TopAbs_ShapeEnum tsb1,tsa1; Standard_Integer isb1,isa1; FDS_Tdata(I1,tsb1,isb1,tsa1,isa1); // I1->Transition(); @@ -346,7 +346,7 @@ Standard_EXPORT void FUN_orderSTATETRANSonG it1.Initialize(LI); while (it1.More() ) { - Handle(TopOpeBRepDS_Interference)& I1 = it1.Value(); + Handle(TopOpeBRepDS_Interference)& I1 = it1.ChangeValue(); TopOpeBRepDS_Kind GT1,ST1; Standard_Integer G1,S1; TopAbs_ShapeEnum tsb1,tsa1; Standard_Integer isb1,isa1; FDS_Idata(I1,tsb1,isb1,tsa1,isa1,GT1,G1,ST1,S1); const TopOpeBRepDS_Transition& T1 = I1->Transition(); @@ -404,7 +404,7 @@ Standard_EXPORT void FUN_resolveEUNKNOWN // process interferences of LI with UNKNOWN transition for (it1.Initialize(LI); it1.More(); it1.Next() ) { - Handle(TopOpeBRepDS_Interference)& I1 = it1.Value(); + Handle(TopOpeBRepDS_Interference)& I1 = it1.ChangeValue(); const TopOpeBRepDS_Transition& T1 = I1->Transition(); Standard_Boolean isunk = T1.IsUnknown(); if (!isunk) continue; diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_ProcessFaceInterferences.cxx b/src/TopOpeBRepDS/TopOpeBRepDS_ProcessFaceInterferences.cxx index c4011210c7..06f4565127 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_ProcessFaceInterferences.cxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_ProcessFaceInterferences.cxx @@ -152,7 +152,7 @@ Standard_EXPORT void FUN_unkeepFdoubleGBoundinterferences it1.Initialize(LI); while (it1.More() ) { - Handle(TopOpeBRepDS_Interference)& I1 = it1.Value(); + Handle(TopOpeBRepDS_Interference)& I1 = it1.ChangeValue(); TopOpeBRepDS_Kind GT1,ST1; Standard_Integer G1,S1; const TopOpeBRepDS_Transition& T1 = I1->Transition(); Standard_Boolean isunk1 = T1.IsUnknown(); @@ -217,7 +217,7 @@ Standard_EXPORT void FUN_resolveFUNKNOWN // process interferences of LI with UNKNOWN transition for (it1.Initialize(LI); it1.More(); it1.Next() ) { - Handle(TopOpeBRepDS_Interference)& I1 = it1.Value(); + Handle(TopOpeBRepDS_Interference)& I1 = it1.ChangeValue(); const TopOpeBRepDS_Transition& T1 = I1->Transition(); Standard_Boolean isunk = T1.IsUnknown(); if (!isunk) continue; diff --git a/src/TopOpeBRepDS/TopOpeBRepDS_ProcessInterferencesTool.cxx b/src/TopOpeBRepDS/TopOpeBRepDS_ProcessInterferencesTool.cxx index 068670c4a9..b01351798b 100644 --- a/src/TopOpeBRepDS/TopOpeBRepDS_ProcessInterferencesTool.cxx +++ b/src/TopOpeBRepDS/TopOpeBRepDS_ProcessInterferencesTool.cxx @@ -329,7 +329,7 @@ Standard_EXPORT void FUN_reducedoublons // process interferences of LI with VERTEX geometry it1.Initialize(LI); while (it1.More() ) { - Handle(TopOpeBRepDS_Interference)& I1 = it1.Value(); + Handle(TopOpeBRepDS_Interference)& I1 = it1.ChangeValue(); const TopOpeBRepDS_Transition& T1 = I1->Transition(); TopOpeBRepDS_Kind GT1,ST1; Standard_Integer G1,S1; FDS_data(I1,GT1,G1,ST1,S1); TopAbs_ShapeEnum tsb1,tsa1; Standard_Integer isb1,isa1; @@ -403,7 +403,7 @@ Standard_EXPORT void FUN_unkeepUNKNOWN it1.Initialize(LI); while (it1.More() ) { - Handle(TopOpeBRepDS_Interference)& I1 = it1.Value(); + Handle(TopOpeBRepDS_Interference)& I1 = it1.ChangeValue(); const TopOpeBRepDS_Transition& T1 = I1->Transition(); Standard_Boolean isunk = T1.IsUnknown(); @@ -541,7 +541,7 @@ static Standard_Boolean FUN_find3dISEsameISF(const Handle(TopOpeBRepDS_Interfere TopAbs_ShapeEnum SB1,SA1; Standard_Integer IB1,IA1; FDS_Tdata(I1,SB1,IB1,SA1,IA1); while ( it2.More()){ - Handle(TopOpeBRepDS_Interference)& I2 = it2.Value(); + Handle(TopOpeBRepDS_Interference)& I2 = it2.ChangeValue(); TopAbs_Orientation O2 = I2->Transition().Orientation(TopAbs_IN); TopOpeBRepDS_Kind GT2,ST2; Standard_Integer G2,S2; FDS_data(I2,GT2,G2,ST2,S2); TopAbs_ShapeEnum SB2,SA2; Standard_Integer IB2,IA2; FDS_Tdata(I2,SB2,IB2,SA2,IA2); diff --git a/src/TopOpeBRepTool/TopOpeBRepTool_DataMapOfOrientedShapeC2DF.hxx b/src/TopOpeBRepTool/TopOpeBRepTool_DataMapOfOrientedShapeC2DF.hxx index 166bd70ebc..bda4096b0a 100644 --- a/src/TopOpeBRepTool/TopOpeBRepTool_DataMapOfOrientedShapeC2DF.hxx +++ b/src/TopOpeBRepTool/TopOpeBRepTool_DataMapOfOrientedShapeC2DF.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap TopOpeBRepTool_DataMapOfOrientedShapeC2DF; -typedef NCollection_DataMap::Iterator TopOpeBRepTool_DataMapIteratorOfDataMapOfOrientedShapeC2DF; +typedef NCollection_DataMap TopOpeBRepTool_DataMapOfOrientedShapeC2DF; +typedef NCollection_DataMap::Iterator TopOpeBRepTool_DataMapIteratorOfDataMapOfOrientedShapeC2DF; #endif diff --git a/src/TopOpeBRepTool/TopOpeBRepTool_FuseEdges.cxx b/src/TopOpeBRepTool/TopOpeBRepTool_FuseEdges.cxx index 9b9b8a202d..fef60f4ae2 100644 --- a/src/TopOpeBRepTool/TopOpeBRepTool_FuseEdges.cxx +++ b/src/TopOpeBRepTool/TopOpeBRepTool_FuseEdges.cxx @@ -904,7 +904,7 @@ Standard_Boolean TopOpeBRepTool_FuseEdges::UpdatePCurve(const TopoDS_Edge& theOl iter.Next(); for (; iter.More(); iter.Next()) { - TopoDS_Edge& E = TopoDS::Edge(iter.Value()); + const TopoDS_Edge& E = TopoDS::Edge(iter.Value()); Standard_Real first, last; Handle(Geom2d_Curve) C = BRep_Tool::CurveOnSurface( E, Surf, loc, first, last ); Handle(Geom2d_BoundedCurve) BC = Handle(Geom2d_BoundedCurve)::DownCast(C); diff --git a/src/TopOpeBRepTool/TopOpeBRepTool_IndexedDataMapOfShapeBox.hxx b/src/TopOpeBRepTool/TopOpeBRepTool_IndexedDataMapOfShapeBox.hxx index bb6417f5b9..7570e991ad 100644 --- a/src/TopOpeBRepTool/TopOpeBRepTool_IndexedDataMapOfShapeBox.hxx +++ b/src/TopOpeBRepTool/TopOpeBRepTool_IndexedDataMapOfShapeBox.hxx @@ -19,10 +19,9 @@ #include #include -#include #include -typedef NCollection_IndexedDataMap TopOpeBRepTool_IndexedDataMapOfShapeBox; +typedef NCollection_IndexedDataMap TopOpeBRepTool_IndexedDataMapOfShapeBox; #endif diff --git a/src/TopOpeBRepTool/TopOpeBRepTool_IndexedDataMapOfShapeBox2d.hxx b/src/TopOpeBRepTool/TopOpeBRepTool_IndexedDataMapOfShapeBox2d.hxx index 1fc2e23f99..d03a486f8f 100644 --- a/src/TopOpeBRepTool/TopOpeBRepTool_IndexedDataMapOfShapeBox2d.hxx +++ b/src/TopOpeBRepTool/TopOpeBRepTool_IndexedDataMapOfShapeBox2d.hxx @@ -19,10 +19,9 @@ #include #include -#include #include -typedef NCollection_IndexedDataMap TopOpeBRepTool_IndexedDataMapOfShapeBox2d; +typedef NCollection_IndexedDataMap TopOpeBRepTool_IndexedDataMapOfShapeBox2d; #endif diff --git a/src/TopTools/FILES b/src/TopTools/FILES index 747e21c1fd..cc01db47cc 100644 --- a/src/TopTools/FILES +++ b/src/TopTools/FILES @@ -47,10 +47,7 @@ TopTools_MapOfOrientedShape.hxx TopTools_MapOfShape.hxx TopTools_MutexForShapeProvider.cxx TopTools_MutexForShapeProvider.hxx -TopTools_OrientedShapeMapHasher.hxx -TopTools_OrientedShapeMapHasher.lxx TopTools_SequenceOfShape.hxx TopTools_ShapeMapHasher.hxx -TopTools_ShapeMapHasher.lxx TopTools_ShapeSet.cxx TopTools_ShapeSet.hxx diff --git a/src/TopTools/TopTools_DataMapOfIntegerListOfShape.hxx b/src/TopTools/TopTools_DataMapOfIntegerListOfShape.hxx index 5813ef773f..4c57ef42db 100644 --- a/src/TopTools/TopTools_DataMapOfIntegerListOfShape.hxx +++ b/src/TopTools/TopTools_DataMapOfIntegerListOfShape.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap TopTools_DataMapOfIntegerListOfShape; -typedef NCollection_DataMap::Iterator TopTools_DataMapIteratorOfDataMapOfIntegerListOfShape; +typedef NCollection_DataMap TopTools_DataMapOfIntegerListOfShape; +typedef NCollection_DataMap::Iterator TopTools_DataMapIteratorOfDataMapOfIntegerListOfShape; #endif diff --git a/src/TopTools/TopTools_DataMapOfIntegerShape.hxx b/src/TopTools/TopTools_DataMapOfIntegerShape.hxx index d6503c6df4..666312ac8f 100644 --- a/src/TopTools/TopTools_DataMapOfIntegerShape.hxx +++ b/src/TopTools/TopTools_DataMapOfIntegerShape.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap TopTools_DataMapOfIntegerShape; -typedef NCollection_DataMap::Iterator TopTools_DataMapIteratorOfDataMapOfIntegerShape; +typedef NCollection_DataMap TopTools_DataMapOfIntegerShape; +typedef NCollection_DataMap::Iterator TopTools_DataMapIteratorOfDataMapOfIntegerShape; #endif diff --git a/src/TopTools/TopTools_DataMapOfOrientedShapeInteger.hxx b/src/TopTools/TopTools_DataMapOfOrientedShapeInteger.hxx index ff7325c207..0220b044f0 100644 --- a/src/TopTools/TopTools_DataMapOfOrientedShapeInteger.hxx +++ b/src/TopTools/TopTools_DataMapOfOrientedShapeInteger.hxx @@ -19,11 +19,10 @@ #include #include -#include #include -typedef NCollection_DataMap TopTools_DataMapOfOrientedShapeInteger; -typedef NCollection_DataMap::Iterator TopTools_DataMapIteratorOfDataMapOfOrientedShapeInteger; +typedef NCollection_DataMap TopTools_DataMapOfOrientedShapeInteger; +typedef NCollection_DataMap::Iterator TopTools_DataMapIteratorOfDataMapOfOrientedShapeInteger; #endif diff --git a/src/TopTools/TopTools_DataMapOfOrientedShapeShape.hxx b/src/TopTools/TopTools_DataMapOfOrientedShapeShape.hxx index 7ac0f777bd..dfd145d005 100644 --- a/src/TopTools/TopTools_DataMapOfOrientedShapeShape.hxx +++ b/src/TopTools/TopTools_DataMapOfOrientedShapeShape.hxx @@ -18,11 +18,10 @@ #define TopTools_DataMapOfOrientedShapeShape_HeaderFile #include -#include #include -typedef NCollection_DataMap TopTools_DataMapOfOrientedShapeShape; -typedef NCollection_DataMap::Iterator TopTools_DataMapIteratorOfDataMapOfOrientedShapeShape; +typedef NCollection_DataMap TopTools_DataMapOfOrientedShapeShape; +typedef NCollection_DataMap::Iterator TopTools_DataMapIteratorOfDataMapOfOrientedShapeShape; #endif diff --git a/src/TopTools/TopTools_IndexedDataMapOfShapeAddress.hxx b/src/TopTools/TopTools_IndexedDataMapOfShapeAddress.hxx index bbe20a935f..570a6b190b 100644 --- a/src/TopTools/TopTools_IndexedDataMapOfShapeAddress.hxx +++ b/src/TopTools/TopTools_IndexedDataMapOfShapeAddress.hxx @@ -18,7 +18,6 @@ #define TopTools_IndexedDataMapOfShapeAddress_HeaderFile #include -#include #include #include diff --git a/src/TopTools/TopTools_IndexedMapOfOrientedShape.hxx b/src/TopTools/TopTools_IndexedMapOfOrientedShape.hxx index bd5ea4c3e5..ff3974f35e 100644 --- a/src/TopTools/TopTools_IndexedMapOfOrientedShape.hxx +++ b/src/TopTools/TopTools_IndexedMapOfOrientedShape.hxx @@ -18,10 +18,9 @@ #define TopTools_IndexedMapOfOrientedShape_HeaderFile #include -#include #include -typedef NCollection_IndexedMap TopTools_IndexedMapOfOrientedShape; +typedef NCollection_IndexedMap TopTools_IndexedMapOfOrientedShape; #endif diff --git a/src/TopTools/TopTools_MapOfOrientedShape.hxx b/src/TopTools/TopTools_MapOfOrientedShape.hxx index 44071c9672..b8987c9f2e 100644 --- a/src/TopTools/TopTools_MapOfOrientedShape.hxx +++ b/src/TopTools/TopTools_MapOfOrientedShape.hxx @@ -18,11 +18,10 @@ #define TopTools_MapOfOrientedShape_HeaderFile #include -#include #include -typedef NCollection_Map TopTools_MapOfOrientedShape; -typedef NCollection_Map::Iterator TopTools_MapIteratorOfMapOfOrientedShape; +typedef NCollection_Map TopTools_MapOfOrientedShape; +typedef NCollection_Map::Iterator TopTools_MapIteratorOfMapOfOrientedShape; #endif diff --git a/src/TopTools/TopTools_OrientedShapeMapHasher.hxx b/src/TopTools/TopTools_OrientedShapeMapHasher.hxx deleted file mode 100644 index e4dfca99b2..0000000000 --- a/src/TopTools/TopTools_OrientedShapeMapHasher.hxx +++ /dev/null @@ -1,69 +0,0 @@ -// Created on: 1993-08-30 -// Created by: Modelistation -// Copyright (c) 1993-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _TopTools_OrientedShapeMapHasher_HeaderFile -#define _TopTools_OrientedShapeMapHasher_HeaderFile - -#include -#include - -#include -class TopoDS_Shape; - - - -class TopTools_OrientedShapeMapHasher -{ -public: - - DEFINE_STANDARD_ALLOC - - //! Computes a hash code for the given shape, in the range [1, theUpperBound] - //! @param theShape the shape which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const TopoDS_Shape& theShape, const Standard_Integer theUpperBound); - - //! Returns True when the two keys are equal. Two same - //! keys must have the same hashcode, the contrary is - //! not necessary. - static Standard_Boolean IsEqual (const TopoDS_Shape& S1, const TopoDS_Shape& S2); - - - - -protected: - - - - - -private: - - - - - -}; - - -#include - - - - - -#endif // _TopTools_OrientedShapeMapHasher_HeaderFile diff --git a/src/TopTools/TopTools_OrientedShapeMapHasher.lxx b/src/TopTools/TopTools_OrientedShapeMapHasher.lxx deleted file mode 100644 index 6fb47100bd..0000000000 --- a/src/TopTools/TopTools_OrientedShapeMapHasher.lxx +++ /dev/null @@ -1,37 +0,0 @@ -// Created on: 1993-01-14 -// Created by: Remi LEQUETTE -// Copyright (c) 1993-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#include - -//======================================================================= -// function : HashCode -// purpose : -//======================================================================= -inline Standard_Integer TopTools_OrientedShapeMapHasher::HashCode (const TopoDS_Shape& theShape, - const Standard_Integer theUpperBound) -{ - return theShape.HashCode (theUpperBound); -} - -//======================================================================= -//function : IsEqual -//purpose : -//======================================================================= -inline Standard_Boolean TopTools_OrientedShapeMapHasher::IsEqual - (const TopoDS_Shape& S1, const TopoDS_Shape& S2) -{ - return S1.IsEqual(S2); -} diff --git a/src/TopTools/TopTools_ShapeMapHasher.hxx b/src/TopTools/TopTools_ShapeMapHasher.hxx index ba47758975..7899e32a31 100644 --- a/src/TopTools/TopTools_ShapeMapHasher.hxx +++ b/src/TopTools/TopTools_ShapeMapHasher.hxx @@ -17,52 +17,26 @@ #ifndef _TopTools_ShapeMapHasher_HeaderFile #define _TopTools_ShapeMapHasher_HeaderFile +#include #include #include -class TopoDS_Shape; - - //! Hash tool, used for generating maps of shapes in topology. -class TopTools_ShapeMapHasher +class TopTools_ShapeMapHasher { public: - DEFINE_STANDARD_ALLOC - - //! Computes a hash code for the given shape, in the range [1, theUpperBound] - //! @param theShape the shape which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const TopoDS_Shape& theShape, Standard_Integer theUpperBound); - - //! Returns True when the two keys are the same. Two - //! same keys must have the same hashcode, the - //! contrary is not necessary. - static Standard_Boolean IsEqual (const TopoDS_Shape& S1, const TopoDS_Shape& S2); - - - - -protected: - - - - - -private: - - - + DEFINE_STANDARD_ALLOC; + size_t operator()(const TopoDS_Shape& theShape) const noexcept + { + return std::hash{}(theShape); + } + bool operator()(const TopoDS_Shape& S1, const TopoDS_Shape& S2) const noexcept + { + return S1.IsSame(S2); + } }; - -#include - - - - - #endif // _TopTools_ShapeMapHasher_HeaderFile diff --git a/src/TopTools/TopTools_ShapeMapHasher.lxx b/src/TopTools/TopTools_ShapeMapHasher.lxx deleted file mode 100644 index a3789d085b..0000000000 --- a/src/TopTools/TopTools_ShapeMapHasher.lxx +++ /dev/null @@ -1,37 +0,0 @@ -// Created on: 1993-01-14 -// Created by: Remi LEQUETTE -// Copyright (c) 1993-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#include - -//======================================================================= -// function : HashCode -// purpose : -//======================================================================= -inline Standard_Integer TopTools_ShapeMapHasher::HashCode (const TopoDS_Shape& theShape, - const Standard_Integer theUpperBound) -{ - return theShape.HashCode (theUpperBound); -} - -//======================================================================= -//function : IsEqual -//purpose : -//======================================================================= -inline Standard_Boolean TopTools_ShapeMapHasher::IsEqual - (const TopoDS_Shape& S1, const TopoDS_Shape& S2) -{ - return S1.IsSame(S2); -} diff --git a/src/TopoDS/FILES b/src/TopoDS/FILES index 1fd91a9eea..cc0d9a6ae4 100644 --- a/src/TopoDS/FILES +++ b/src/TopoDS/FILES @@ -6,13 +6,9 @@ TopoDS_Builder.cxx TopoDS_Builder.hxx TopoDS_Builder.lxx TopoDS_Compound.hxx -TopoDS_Compound.lxx TopoDS_CompSolid.hxx -TopoDS_CompSolid.lxx TopoDS_Edge.hxx -TopoDS_Edge.lxx TopoDS_Face.hxx -TopoDS_Face.lxx TopoDS_FrozenShape.hxx TopoDS_HShape.cxx TopoDS_HShape.hxx @@ -25,9 +21,7 @@ TopoDS_LockedShape.hxx TopoDS_Shape.cxx TopoDS_Shape.hxx TopoDS_Shell.hxx -TopoDS_Shell.lxx TopoDS_Solid.hxx -TopoDS_Solid.lxx TopoDS_TCompound.cxx TopoDS_TCompound.hxx TopoDS_TCompound.lxx @@ -56,8 +50,6 @@ TopoDS_TWire.hxx TopoDS_TWire.lxx TopoDS_UnCompatibleShapes.hxx TopoDS_Vertex.hxx -TopoDS_Vertex.lxx TopoDS_Wire.hxx -TopoDS_Wire.lxx TopoDS_AlertWithShape.cxx TopoDS_AlertWithShape.hxx diff --git a/src/TopoDS/TopoDS_CompSolid.hxx b/src/TopoDS/TopoDS_CompSolid.hxx index e042fdaffb..92a7a728a0 100644 --- a/src/TopoDS/TopoDS_CompSolid.hxx +++ b/src/TopoDS/TopoDS_CompSolid.hxx @@ -17,12 +17,8 @@ #ifndef _TopoDS_CompSolid_HeaderFile #define _TopoDS_CompSolid_HeaderFile -#include -#include - #include - //! Describes a composite solid which //! - references an underlying composite solid with the //! potential to be given a location and an orientation @@ -38,32 +34,20 @@ public: DEFINE_STANDARD_ALLOC - //! Constructs an Undefined CompSolid. - TopoDS_CompSolid(); - - - - -protected: - - - - - -private: - - - - - + TopoDS_CompSolid() {} }; - -#include - - - - +namespace std +{ + template <> + struct hash + { + size_t operator()(const TopoDS_CompSolid& theShape) const + { + return std::hash{}(theShape); + } + }; +} #endif // _TopoDS_CompSolid_HeaderFile diff --git a/src/TopoDS/TopoDS_CompSolid.lxx b/src/TopoDS/TopoDS_CompSolid.lxx deleted file mode 100644 index e4d4a88483..0000000000 --- a/src/TopoDS/TopoDS_CompSolid.lxx +++ /dev/null @@ -1,24 +0,0 @@ -// Created on: 1991-04-16 -// Created by: Remi LEQUETTE -// Copyright (c) 1991-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -//======================================================================= -//function : TopoDS_CompSolid -//purpose : -//======================================================================= - -inline TopoDS_CompSolid::TopoDS_CompSolid () -{ -} diff --git a/src/TopoDS/TopoDS_Compound.hxx b/src/TopoDS/TopoDS_Compound.hxx index 639ddd7311..3aa0148a36 100644 --- a/src/TopoDS/TopoDS_Compound.hxx +++ b/src/TopoDS/TopoDS_Compound.hxx @@ -17,12 +17,8 @@ #ifndef _TopoDS_Compound_HeaderFile #define _TopoDS_Compound_HeaderFile -#include -#include - #include - //! Describes a compound which //! - references an underlying compound with the //! potential to be given a location and an orientation @@ -38,32 +34,20 @@ public: DEFINE_STANDARD_ALLOC - //! Constructs an Undefined Compound. - TopoDS_Compound(); - - - - -protected: - - - - - -private: - - - - - + TopoDS_Compound() {} }; - -#include - - - - +namespace std +{ + template <> + struct hash + { + size_t operator()(const TopoDS_Compound& theShape) const + { + return std::hash{}(theShape); + } + }; +} #endif // _TopoDS_Compound_HeaderFile diff --git a/src/TopoDS/TopoDS_Compound.lxx b/src/TopoDS/TopoDS_Compound.lxx deleted file mode 100644 index 687ded5b5e..0000000000 --- a/src/TopoDS/TopoDS_Compound.lxx +++ /dev/null @@ -1,24 +0,0 @@ -// Created on: 1991-04-16 -// Created by: Remi LEQUETTE -// Copyright (c) 1991-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -//======================================================================= -//function : TopoDS_Compound -//purpose : -//======================================================================= - -inline TopoDS_Compound::TopoDS_Compound () -{ -} diff --git a/src/TopoDS/TopoDS_Edge.hxx b/src/TopoDS/TopoDS_Edge.hxx index 934dbd141b..0454c01f4c 100644 --- a/src/TopoDS/TopoDS_Edge.hxx +++ b/src/TopoDS/TopoDS_Edge.hxx @@ -17,12 +17,8 @@ #ifndef _TopoDS_Edge_HeaderFile #define _TopoDS_Edge_HeaderFile -#include -#include - #include - //! Describes an edge which //! - references an underlying edge with the potential to //! be given a location and an orientation @@ -37,32 +33,20 @@ public: DEFINE_STANDARD_ALLOC - //! Undefined Edge. - TopoDS_Edge(); - - - - -protected: - - - - - -private: - - - - - + TopoDS_Edge() {} }; - -#include - - - - +namespace std +{ + template <> + struct hash + { + size_t operator()(const TopoDS_Edge& theShape) const + { + return std::hash{}(theShape); + } + }; +} #endif // _TopoDS_Edge_HeaderFile diff --git a/src/TopoDS/TopoDS_Edge.lxx b/src/TopoDS/TopoDS_Edge.lxx deleted file mode 100644 index 24530288db..0000000000 --- a/src/TopoDS/TopoDS_Edge.lxx +++ /dev/null @@ -1,24 +0,0 @@ -// Created on: 1991-04-16 -// Created by: Remi LEQUETTE -// Copyright (c) 1991-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -//======================================================================= -//function : TopoDS_Edge -//purpose : Empty Constructor -//======================================================================= - -inline TopoDS_Edge::TopoDS_Edge () -{ -} diff --git a/src/TopoDS/TopoDS_Face.hxx b/src/TopoDS/TopoDS_Face.hxx index 6ed9083c53..127284c424 100644 --- a/src/TopoDS/TopoDS_Face.hxx +++ b/src/TopoDS/TopoDS_Face.hxx @@ -17,12 +17,8 @@ #ifndef _TopoDS_Face_HeaderFile #define _TopoDS_Face_HeaderFile -#include -#include - #include - //! Describes a face which //! - references an underlying face with the potential to //! be given a location and an orientation @@ -36,32 +32,20 @@ public: DEFINE_STANDARD_ALLOC - //! Undefined Face. - TopoDS_Face(); - - - - -protected: - - - - - -private: - - - - - + TopoDS_Face() {} }; - -#include - - - - +namespace std +{ + template <> + struct hash + { + size_t operator()(const TopoDS_Face& theShape) const + { + return std::hash{}(theShape); + } + }; +} #endif // _TopoDS_Face_HeaderFile diff --git a/src/TopoDS/TopoDS_Face.lxx b/src/TopoDS/TopoDS_Face.lxx deleted file mode 100644 index ed77a8eadb..0000000000 --- a/src/TopoDS/TopoDS_Face.lxx +++ /dev/null @@ -1,24 +0,0 @@ -// Created on: 1991-04-16 -// Created by: Remi LEQUETTE -// Copyright (c) 1991-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -//======================================================================= -//function : TopoDS_Face -//purpose : -//======================================================================= - -inline TopoDS_Face::TopoDS_Face () -{ -} diff --git a/src/TopoDS/TopoDS_Shape.cxx b/src/TopoDS/TopoDS_Shape.cxx index c78121649b..deda205a8b 100644 --- a/src/TopoDS/TopoDS_Shape.cxx +++ b/src/TopoDS/TopoDS_Shape.cxx @@ -22,18 +22,6 @@ #include #include -//======================================================================= -// function : HashCode -// purpose : -//======================================================================= -Standard_Integer TopoDS_Shape::HashCode (const Standard_Integer theUpperBound) const -{ - // PKV - const Standard_Integer aHS = ::HashCode (myTShape.get(), theUpperBound); - const Standard_Integer aHL = myLocation.HashCode (theUpperBound); - return ::HashCode (aHS ^ aHL, theUpperBound); -} - //======================================================================= //function : DumpJson //purpose : diff --git a/src/TopoDS/TopoDS_Shape.hxx b/src/TopoDS/TopoDS_Shape.hxx index 12b5918cc7..4933134650 100644 --- a/src/TopoDS/TopoDS_Shape.hxx +++ b/src/TopoDS/TopoDS_Shape.hxx @@ -20,6 +20,7 @@ #include #include #include +#include // resolve name collisions with X11 headers #ifdef Convex @@ -279,12 +280,6 @@ public: Standard_Boolean IsNotEqual (const TopoDS_Shape& theOther) const { return !IsEqual (theOther); } Standard_Boolean operator != (const TopoDS_Shape& theOther) const { return IsNotEqual (theOther); } - //! Returns a hashed value denoting . This value is in the range [1, theUpperBound]. It is computed from the - //! TShape and the Location. The Orientation is not used. - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - Standard_EXPORT Standard_Integer HashCode (Standard_Integer theUpperBound) const; - //! Replace by a new Shape with the same //! Orientation and Location and a new TShape with the //! same geometry and no sub-shapes. @@ -313,13 +308,18 @@ private: }; -//! Computes a hash code for the given shape, in the range [1, theUpperBound] -//! @param theShape the shape which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -inline Standard_Integer HashCode (const TopoDS_Shape& theShape, const Standard_Integer theUpperBound) +namespace std { - return theShape.HashCode (theUpperBound); + template <> + struct hash + { + size_t operator()(const TopoDS_Shape& theShape) const noexcept + { + const size_t aHL = std::hash{}(theShape.Location()); + return aHL == 0 ? opencascade::hash(theShape.TShape().get()) + : opencascade::MurmurHash::hash_combine(theShape.TShape().get(), sizeof(void*), aHL); + } + }; } #endif // _TopoDS_Shape_HeaderFile diff --git a/src/TopoDS/TopoDS_Shell.hxx b/src/TopoDS/TopoDS_Shell.hxx index a422f2c355..e6d443973f 100644 --- a/src/TopoDS/TopoDS_Shell.hxx +++ b/src/TopoDS/TopoDS_Shell.hxx @@ -17,12 +17,8 @@ #ifndef _TopoDS_Shell_HeaderFile #define _TopoDS_Shell_HeaderFile -#include -#include - #include - //! Describes a shell which //! - references an underlying shell with the potential to //! be given a location and an orientation @@ -36,32 +32,20 @@ public: DEFINE_STANDARD_ALLOC - //! Constructs an Undefined Shell. - TopoDS_Shell(); - - - - -protected: - - - - - -private: - - - - - + TopoDS_Shell() {} }; - -#include - - - - +namespace std +{ + template <> + struct hash + { + size_t operator()(const TopoDS_Shell& theShape) const + { + return std::hash{}(theShape); + } + }; +} #endif // _TopoDS_Shell_HeaderFile diff --git a/src/TopoDS/TopoDS_Shell.lxx b/src/TopoDS/TopoDS_Shell.lxx deleted file mode 100644 index f357a4567a..0000000000 --- a/src/TopoDS/TopoDS_Shell.lxx +++ /dev/null @@ -1,24 +0,0 @@ -// Created on: 1991-04-16 -// Created by: Remi LEQUETTE -// Copyright (c) 1991-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -//======================================================================= -//function : TopoDS_Shell -//purpose : -//======================================================================= - -inline TopoDS_Shell::TopoDS_Shell () -{ -} diff --git a/src/TopoDS/TopoDS_Solid.hxx b/src/TopoDS/TopoDS_Solid.hxx index c21397c448..3ddc46bc2f 100644 --- a/src/TopoDS/TopoDS_Solid.hxx +++ b/src/TopoDS/TopoDS_Solid.hxx @@ -17,12 +17,8 @@ #ifndef _TopoDS_Solid_HeaderFile #define _TopoDS_Solid_HeaderFile -#include -#include - #include - //! Describes a solid shape which //! - references an underlying solid shape with the //! potential to be given a location and an orientation @@ -37,32 +33,20 @@ public: DEFINE_STANDARD_ALLOC - //! Constructs an Undefined Solid. - TopoDS_Solid(); - - - - -protected: - - - - - -private: - - - - - + TopoDS_Solid() {} }; - -#include - - - - +namespace std +{ + template <> + struct hash + { + size_t operator()(const TopoDS_Solid& theShape) const + { + return std::hash{}(theShape); + } + }; +} #endif // _TopoDS_Solid_HeaderFile diff --git a/src/TopoDS/TopoDS_Solid.lxx b/src/TopoDS/TopoDS_Solid.lxx deleted file mode 100644 index cf2e324999..0000000000 --- a/src/TopoDS/TopoDS_Solid.lxx +++ /dev/null @@ -1,24 +0,0 @@ -// Created on: 1991-04-16 -// Created by: Remi LEQUETTE -// Copyright (c) 1991-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -//======================================================================= -//function : TopoDS_Solid -//purpose : -//======================================================================= - -inline TopoDS_Solid::TopoDS_Solid () -{ -} diff --git a/src/TopoDS/TopoDS_Vertex.hxx b/src/TopoDS/TopoDS_Vertex.hxx index fdc778db02..361990ec1a 100644 --- a/src/TopoDS/TopoDS_Vertex.hxx +++ b/src/TopoDS/TopoDS_Vertex.hxx @@ -17,12 +17,8 @@ #ifndef _TopoDS_Vertex_HeaderFile #define _TopoDS_Vertex_HeaderFile -#include -#include - #include - //! Describes a vertex which //! - references an underlying vertex with the potential //! to be given a location and an orientation @@ -37,32 +33,20 @@ public: DEFINE_STANDARD_ALLOC - //! Undefined Vertex. - TopoDS_Vertex(); - - - - -protected: - - - - - -private: - - - - - + TopoDS_Vertex() {} }; - -#include - - - - +namespace std +{ + template <> + struct hash + { + size_t operator()(const TopoDS_Vertex& theShape) const + { + return std::hash{}(theShape); + } + }; +} #endif // _TopoDS_Vertex_HeaderFile diff --git a/src/TopoDS/TopoDS_Vertex.lxx b/src/TopoDS/TopoDS_Vertex.lxx deleted file mode 100644 index b7c1ceeb11..0000000000 --- a/src/TopoDS/TopoDS_Vertex.lxx +++ /dev/null @@ -1,24 +0,0 @@ -// Created on: 1991-04-12 -// Created by: Remi LEQUETTE -// Copyright (c) 1991-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -//======================================================================= -//function : TopoDS_Vertex -//purpose : -//======================================================================= - -inline TopoDS_Vertex::TopoDS_Vertex() -{ -} diff --git a/src/TopoDS/TopoDS_Wire.hxx b/src/TopoDS/TopoDS_Wire.hxx index 73c973822e..a2d2c3667a 100644 --- a/src/TopoDS/TopoDS_Wire.hxx +++ b/src/TopoDS/TopoDS_Wire.hxx @@ -17,12 +17,8 @@ #ifndef _TopoDS_Wire_HeaderFile #define _TopoDS_Wire_HeaderFile -#include -#include - #include - //! Describes a wire which //! - references an underlying wire with the potential to //! be given a location and an orientation @@ -36,32 +32,20 @@ public: DEFINE_STANDARD_ALLOC - //! Undefined Wire. - TopoDS_Wire(); - - - - -protected: - - - - - -private: - - - - - + TopoDS_Wire() {} }; - -#include - - - - +namespace std +{ + template <> + struct hash + { + size_t operator()(const TopoDS_Wire& theShape) const + { + return std::hash{}(theShape); + } + }; +} #endif // _TopoDS_Wire_HeaderFile diff --git a/src/TopoDS/TopoDS_Wire.lxx b/src/TopoDS/TopoDS_Wire.lxx deleted file mode 100644 index 485597d8dd..0000000000 --- a/src/TopoDS/TopoDS_Wire.lxx +++ /dev/null @@ -1,24 +0,0 @@ -// Created on: 1991-04-16 -// Created by: Remi LEQUETTE -// Copyright (c) 1991-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -//======================================================================= -//function : TopoDS_Wire -//purpose : -//======================================================================= - -inline TopoDS_Wire::TopoDS_Wire () -{ -} diff --git a/src/Transfer/FILES b/src/Transfer/FILES index 2fff748cd3..8f8f66a948 100644 --- a/src/Transfer/FILES +++ b/src/Transfer/FILES @@ -1,4 +1,3 @@ -Transfer_Actor.gxx Transfer_ActorDispatch.cxx Transfer_ActorDispatch.hxx Transfer_ActorOfFinderProcess.cxx @@ -21,18 +20,15 @@ Transfer_Finder.cxx Transfer_Finder.hxx Transfer_FinderProcess.cxx Transfer_FinderProcess.hxx -Transfer_FindHasher.cxx Transfer_FindHasher.hxx Transfer_HSequenceOfBinder.hxx Transfer_HSequenceOfFinder.hxx -Transfer_Iterator.gxx Transfer_IteratorOfProcessForFinder.hxx Transfer_IteratorOfProcessForFinder_0.cxx Transfer_IteratorOfProcessForTransient.hxx Transfer_IteratorOfProcessForTransient_0.cxx Transfer_MapContainer.cxx Transfer_MapContainer.hxx -Transfer_Mapper.gxx Transfer_MultipleBinder.cxx Transfer_MultipleBinder.hxx Transfer_ProcessForFinder.hxx @@ -61,7 +57,6 @@ Transfer_TransferMapOfProcessForFinder.hxx Transfer_TransferMapOfProcessForTransient.hxx Transfer_TransferOutput.cxx Transfer_TransferOutput.hxx -Transfer_TransferProcess.gxx Transfer_TransientListBinder.cxx Transfer_TransientListBinder.hxx Transfer_TransientMapper.hxx diff --git a/src/Transfer/Transfer_Actor.gxx b/src/Transfer/Transfer_Actor.gxx deleted file mode 100644 index 8d08e7e9d0..0000000000 --- a/src/Transfer/Transfer_Actor.gxx +++ /dev/null @@ -1,69 +0,0 @@ -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -//#include - -// TheStart : Handle(Standard_Transient) ou (Transfer_Finder) - - - -Transfer_Actor::Transfer_Actor () { } - - - Standard_Boolean Transfer_Actor::Recognize (const TheStart& /*start*/) - { return Standard_True; } - - Handle(Transfer_Binder) Transfer_Actor::Transferring - (const TheStart& /*start*/, - const Handle(Transfer_TransferProcess)& /*TP*/, - const Message_ProgressRange& /*theProgress*/) - { return NullResult(); } - - - Handle(Transfer_SimpleBinderOfTransient) - Transfer_Actor::TransientResult - (const Handle(Standard_Transient)& res) const -{ - Handle(Transfer_SimpleBinderOfTransient) binder; - if (res.IsNull()) return binder; - binder = new Transfer_SimpleBinderOfTransient; - binder->SetResult (res); - return binder; -} - - - Handle(Transfer_Binder) Transfer_Actor::NullResult () const -{ - Handle(Transfer_Binder) binder; - return binder; -} - - - void Transfer_Actor::SetNext - (const Handle(Transfer_Actor)& next) -{ - if (thenext == next) return; - if (thenext.IsNull()) thenext = next; - else if (thenext->IsLast()) { next->SetNext(thenext); thenext = next; } - else thenext->SetNext(next); -} - - Handle(Transfer_Actor) Transfer_Actor::Next () const - { return thenext; } - - void Transfer_Actor::SetLast (const Standard_Boolean mode) - { thelast = mode; } - - - Standard_Boolean Transfer_Actor::IsLast () const - { return thelast; } diff --git a/src/Transfer/Transfer_ActorOfProcessForFinder_0.cxx b/src/Transfer/Transfer_ActorOfProcessForFinder_0.cxx index 74f6e4285d..e9140b1d80 100644 --- a/src/Transfer/Transfer_ActorOfProcessForFinder_0.cxx +++ b/src/Transfer/Transfer_ActorOfProcessForFinder_0.cxx @@ -16,35 +16,114 @@ #include -#include - -#include #include +#include +#include +#include +#include +#include #include #include -#include -#include #include -#include +#include #include -#include +#include -#define TheStart Handle(Transfer_Finder) -#define TheStart_hxx -#define TheMapHasher Transfer_FindHasher -#define TheMapHasher_hxx -#define Handle_TheList Handle(Transfer_HSequenceOfFinder) -#define TheList Transfer_HSequenceOfFinder -#define TheList_hxx -#define Transfer_TransferMap Transfer_TransferMapOfProcessForFinder -#define Transfer_TransferMap_hxx -#define Transfer_Iterator Transfer_IteratorOfProcessForFinder -#define Transfer_Iterator_hxx -#define Transfer_Actor Transfer_ActorOfProcessForFinder -#define Transfer_Actor_hxx -#define Handle_Transfer_Actor Handle(Transfer_ActorOfProcessForFinder) -#define Transfer_TransferProcess Transfer_ProcessForFinder -#define Transfer_TransferProcess_hxx -#define Handle_Transfer_TransferProcess Handle(Transfer_ProcessForFinder) -#include +//======================================================================= +// Function: Transfer_ActorOfProcessForFinder +// Purpose : +//======================================================================= +Transfer_ActorOfProcessForFinder::Transfer_ActorOfProcessForFinder() { } +//======================================================================= +// Function: Recognize +// Purpose : +//======================================================================= +Standard_Boolean Transfer_ActorOfProcessForFinder::Recognize(const Handle(Transfer_Finder)& /*start*/) +{ + return Standard_True; +} + +//======================================================================= +// Function: Transferring +// Purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ActorOfProcessForFinder::Transferring +(const Handle(Transfer_Finder)& /*start*/, + const Handle(Transfer_ProcessForFinder)& /*TP*/, + const Message_ProgressRange& /*theProgress*/) +{ + return NullResult(); +} + +//======================================================================= +// Function: TransientResult +// Purpose : +//======================================================================= +Handle(Transfer_SimpleBinderOfTransient) +Transfer_ActorOfProcessForFinder::TransientResult +(const Handle(Standard_Transient)& res) const +{ + Handle(Transfer_SimpleBinderOfTransient) binder; + if (res.IsNull()) return binder; + binder = new Transfer_SimpleBinderOfTransient; + binder->SetResult(res); + return binder; +} + +//======================================================================= +// Function: NullResult +// Purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ActorOfProcessForFinder::NullResult() const +{ + Handle(Transfer_Binder) binder; + return binder; +} + +//======================================================================= +// Function: SetNext +// Purpose : +//======================================================================= +void Transfer_ActorOfProcessForFinder::SetNext +(const Handle(Transfer_ActorOfProcessForFinder)& next) +{ + if (thenext == next) + return; + if (thenext.IsNull()) + thenext = next; + else if (thenext->IsLast()) + { + next->SetNext(thenext); + thenext = next; + } + else + thenext->SetNext(next); +} + +//======================================================================= +// Function: Next +// Purpose : +//======================================================================= +Handle(Transfer_ActorOfProcessForFinder) Transfer_ActorOfProcessForFinder::Next() const +{ + return thenext; +} + +//======================================================================= +// Function: SetLast +// Purpose : +//======================================================================= +void Transfer_ActorOfProcessForFinder::SetLast(const Standard_Boolean mode) +{ + thelast = mode; +} + +//======================================================================= +// Function: IsLast +// Purpose : +//======================================================================= +Standard_Boolean Transfer_ActorOfProcessForFinder::IsLast() const +{ + return thelast; +} diff --git a/src/Transfer/Transfer_ActorOfProcessForTransient_0.cxx b/src/Transfer/Transfer_ActorOfProcessForTransient_0.cxx index d69b1f1bfa..5c476b7a05 100644 --- a/src/Transfer/Transfer_ActorOfProcessForTransient_0.cxx +++ b/src/Transfer/Transfer_ActorOfProcessForTransient_0.cxx @@ -16,33 +16,117 @@ #include -#include - -#include #include #include -#include -#include -#include +#include +#include #include +#include +#include #include +#include -#define TheStart Handle(Standard_Transient) -#define TheStart_hxx -#define TheMapHasher TColStd_MapTransientHasher -#define TheMapHasher_hxx -#define Handle_TheList Handle(TColStd_HSequenceOfTransient) -#define TheList TColStd_HSequenceOfTransient -#define TheList_hxx -#define Transfer_TransferMap Transfer_TransferMapOfProcessForTransient -#define Transfer_TransferMap_hxx -#define Transfer_Iterator Transfer_IteratorOfProcessForTransient -#define Transfer_Iterator_hxx -#define Transfer_Actor Transfer_ActorOfProcessForTransient -#define Transfer_Actor_hxx -#define Handle_Transfer_Actor Handle(Transfer_ActorOfProcessForTransient) -#define Transfer_TransferProcess Transfer_ProcessForTransient -#define Transfer_TransferProcess_hxx -#define Handle_Transfer_TransferProcess Handle(Transfer_ProcessForTransient) -#include +//======================================================================= +// Function: Transfer_ActorOfProcessForTransient +// Purpose : +//======================================================================= +Transfer_ActorOfProcessForTransient::Transfer_ActorOfProcessForTransient() +{} + + +//======================================================================= +// Function: Recognize +// Purpose : +//======================================================================= +Standard_Boolean Transfer_ActorOfProcessForTransient::Recognize(const Handle(Standard_Transient)& /*start*/) +{ + return Standard_True; +} + +//======================================================================= +// Function: Transferring +// Purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ActorOfProcessForTransient::Transferring +(const Handle(Standard_Transient)& /*start*/, + const Handle(Transfer_ProcessForTransient)& /*TP*/, + const Message_ProgressRange& /*theProgress*/) +{ + return NullResult(); +} + +//======================================================================= +// Function: TransientResult +// Purpose : +//======================================================================= +Handle(Transfer_SimpleBinderOfTransient) +Transfer_ActorOfProcessForTransient::TransientResult +(const Handle(Standard_Transient)& res) const +{ + Handle(Transfer_SimpleBinderOfTransient) binder; + if (res.IsNull()) return binder; + binder = new Transfer_SimpleBinderOfTransient; + binder->SetResult(res); + return binder; +} + +//======================================================================= +// Function: NullResult +// Purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ActorOfProcessForTransient::NullResult() const +{ + Handle(Transfer_Binder) binder; + return binder; +} + +//======================================================================= +// Function: SetNext +// Purpose : +//======================================================================= +void Transfer_ActorOfProcessForTransient::SetNext +(const Handle(Transfer_ActorOfProcessForTransient)& next) +{ + if (thenext == next) + return; + if (thenext.IsNull()) + thenext = next; + else if (thenext->IsLast()) + { + next->SetNext(thenext); + thenext = next; + } + else + thenext->SetNext(next); +} + + +//======================================================================= +// Function: Next +// Purpose : +//======================================================================= +Handle(Transfer_ActorOfProcessForTransient) Transfer_ActorOfProcessForTransient::Next() const +{ + return thenext; +} + + +//======================================================================= +// Function: SetLast +// Purpose : +//======================================================================= +void Transfer_ActorOfProcessForTransient::SetLast(const Standard_Boolean mode) +{ + thelast = mode; +} + + +//======================================================================= +// Function: IsLast +// Purpose : +//======================================================================= +Standard_Boolean Transfer_ActorOfProcessForTransient::IsLast() const +{ + return thelast; +} diff --git a/src/Transfer/Transfer_FindHasher.cxx b/src/Transfer/Transfer_FindHasher.cxx deleted file mode 100644 index 1bcf614d3c..0000000000 --- a/src/Transfer/Transfer_FindHasher.cxx +++ /dev/null @@ -1,34 +0,0 @@ -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - - -#include -#include - - -//============================================================================ -// function : HashCode -// purpose : -//============================================================================ -Standard_Integer Transfer_FindHasher::HashCode (const Handle (Transfer_Finder) & theFinder, - const Standard_Integer theUpperBound) -{ - return ::HashCode (theFinder->GetHashCode() - 1, theUpperBound); -} - - Standard_Boolean Transfer_FindHasher::IsEqual - (const Handle(Transfer_Finder)& K1, const Handle(Transfer_Finder)& K2) -{ - if (K1.IsNull()) return Standard_False; - return K1->Equates(K2); -} diff --git a/src/Transfer/Transfer_FindHasher.hxx b/src/Transfer/Transfer_FindHasher.hxx index f217c3180d..e210c1e9be 100644 --- a/src/Transfer/Transfer_FindHasher.hxx +++ b/src/Transfer/Transfer_FindHasher.hxx @@ -19,59 +19,33 @@ #include #include +#include #include -#include -class Transfer_Finder; - - //! FindHasher defines HashCode for Finder, which is : ask a //! Finder its HashCode ! Because this is the Finder itself which //! brings the HashCode for its Key //! //! This class complies to the template given in TCollection by //! MapHasher itself -class Transfer_FindHasher +class Transfer_FindHasher { public: - - DEFINE_STANDARD_ALLOC - - - //! Returns hash code for the given finder, in the range [1, theUpperBound]. - //! Asks the finder its hash code, then transforms it to be in the required range - //! @param theFinder the finder which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - Standard_EXPORT static Standard_Integer HashCode (const Handle (Transfer_Finder) & theFinder, - Standard_Integer theUpperBound); + size_t operator()(const Handle(Transfer_Finder)& theFinder) const + { + return theFinder->GetHashCode(); + } //! Returns True if two keys are the same. //! The test does not work on the Finders themselves but by //! calling their methods Equates - Standard_EXPORT static Standard_Boolean IsEqual (const Handle(Transfer_Finder)& K1, const Handle(Transfer_Finder)& K2); - - - - -protected: - - - - - -private: - - - - + bool operator() (const Handle(Transfer_Finder)& theK1, + const Handle(Transfer_Finder)& theK2) const + { + if (theK1.IsNull()) return false; + return theK1->Equates(theK2); + } }; - - - - - - #endif // _Transfer_FindHasher_HeaderFile diff --git a/src/Transfer/Transfer_Finder.cxx b/src/Transfer/Transfer_Finder.cxx index 1fba56d936..515da7c968 100644 --- a/src/Transfer/Transfer_Finder.cxx +++ b/src/Transfer/Transfer_Finder.cxx @@ -21,10 +21,10 @@ IMPLEMENT_STANDARD_RTTIEXT(Transfer_Finder,Standard_Transient) -void Transfer_Finder::SetHashCode (const Standard_Integer code) +void Transfer_Finder::SetHashCode (const size_t code) { thecode = code; } - Standard_Integer Transfer_Finder::GetHashCode () const + size_t Transfer_Finder::GetHashCode () const { return thecode; } Handle(Standard_Type) Transfer_Finder::ValueType () const diff --git a/src/Transfer/Transfer_Finder.hxx b/src/Transfer/Transfer_Finder.hxx index 5ced95799e..8fc07fade4 100644 --- a/src/Transfer/Transfer_Finder.hxx +++ b/src/Transfer/Transfer_Finder.hxx @@ -45,7 +45,7 @@ public: //! Returns the HashCode which has been stored by SetHashCode //! (remark that HashCode could be deferred then be defined by //! sub-classes, the result is the same) - Standard_EXPORT Standard_Integer GetHashCode() const; + Standard_EXPORT size_t GetHashCode() const; //! Specific testof equality : to be defined by each sub-class, //! must be False if Finders have not the same true Type, else @@ -151,14 +151,14 @@ protected: //! Stores the HashCode which corresponds to the Value given to //! create the Mapper - Standard_EXPORT void SetHashCode (const Standard_Integer code); + Standard_EXPORT void SetHashCode (const size_t code); private: - Standard_Integer thecode; + size_t thecode; NCollection_DataMap theattrib; diff --git a/src/Transfer/Transfer_Iterator.gxx b/src/Transfer/Transfer_Iterator.gxx deleted file mode 100644 index 04c8d1b1a2..0000000000 --- a/src/Transfer/Transfer_Iterator.gxx +++ /dev/null @@ -1,73 +0,0 @@ -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -// Transfer_Iterator.gxx -#include - - -// TheStart est suppose Handle(Standard_Transient) ou (Transfer_Finder) -// Il a servi a instancier TheList qui est une HSequence - - -Transfer_Iterator::Transfer_Iterator (const Standard_Boolean withstarts) - : Transfer_TransferIterator () -{ if (withstarts) thestarts = new TheList(); } - - - void Transfer_Iterator::Add - (const Handle(Transfer_Binder)& binder) -{ - if (!thestarts.IsNull()) throw Standard_NoSuchObject("Transfer_Iterator : Add, Starting Object required not provided"); - AddItem(binder); -} - - void Transfer_Iterator::Add - (const Handle(Transfer_Binder)& binder, const TheStart& start) -{ - AddItem(binder); - if (!thestarts.IsNull()) thestarts->Append(start); -} - - void Transfer_Iterator::Filter - (const Handle(TheList)& list, const Standard_Boolean keep) -{ - if (list.IsNull() || thestarts.IsNull()) return; - Standard_Integer i, j, nb = thestarts->Length(); - if (nb == 0) return; - Handle(Transfer_Binder) factice; - Transfer_TransferMap amap (nb); - for (i = 1; i <= nb; i ++) { - j = amap.Add (thestarts->Value(i),factice); - SelectItem (j,!keep); - } - -// Comparaison - nb = list->Length(); - for (i = 1; i <= nb; i ++) { - j = amap.FindIndex (list->Value(i)); - if (j > 0) SelectItem (j,keep); - } -} - - Standard_Boolean Transfer_Iterator::HasStarting () const - { return (!thestarts.IsNull()); } - - const TheStart& Transfer_Iterator::Starting () const -{ -// if (thecurr == 0 || thecurr > themaxi) throw Standard_NoSuchObject -// ("TransferIterator : Starting"); -// if (theselect->Value(thecurr) == 0) throw Standard_NoSuchObject -// ("TransferIterator : Starting"); - if (thestarts.IsNull()) throw Standard_NoSuchObject("TransferIterator : No Starting defined at all"); - return thestarts->Value(thecurr); -} diff --git a/src/Transfer/Transfer_IteratorOfProcessForFinder_0.cxx b/src/Transfer/Transfer_IteratorOfProcessForFinder_0.cxx index a985812876..24abf1ffcc 100644 --- a/src/Transfer/Transfer_IteratorOfProcessForFinder_0.cxx +++ b/src/Transfer/Transfer_IteratorOfProcessForFinder_0.cxx @@ -23,24 +23,80 @@ #include #include #include - -#define TheStart Handle(Transfer_Finder) -#define TheStart_hxx -#define TheMapHasher Transfer_FindHasher -#define TheMapHasher_hxx -#define Handle_TheList Handle(Transfer_HSequenceOfFinder) -#define TheList Transfer_HSequenceOfFinder -#define TheList_hxx -#define Transfer_TransferMap Transfer_TransferMapOfProcessForFinder -#define Transfer_TransferMap_hxx -#define Transfer_Iterator Transfer_IteratorOfProcessForFinder -#define Transfer_Iterator_hxx -#define Transfer_Actor Transfer_ActorOfProcessForFinder -#define Transfer_Actor_hxx -#define Handle_Transfer_Actor Handle(Transfer_ActorOfProcessForFinder) -#define Transfer_TransferProcess Transfer_ProcessForFinder -#define Transfer_TransferProcess_hxx -#define Handle_Transfer_TransferProcess Handle(Transfer_ProcessForFinder) -#include +//======================================================================= +// Function: Transfer_IteratorOfProcessForFinder +// Purpose : +//======================================================================= +Transfer_IteratorOfProcessForFinder::Transfer_IteratorOfProcessForFinder(const Standard_Boolean withstarts) + : Transfer_TransferIterator() +{ + if (withstarts) thestarts = new Transfer_HSequenceOfFinder(); +} + +//======================================================================= +// Function: Add +// Purpose : +//======================================================================= +void Transfer_IteratorOfProcessForFinder::Add +(const Handle(Transfer_Binder)& binder) +{ + if (!thestarts.IsNull()) throw Standard_NoSuchObject("Transfer_IteratorOfProcessForFinder : Add, Starting Object required not provided"); + AddItem(binder); +} + +//======================================================================= +// Function: Add +// Purpose : +//======================================================================= +void Transfer_IteratorOfProcessForFinder::Add +(const Handle(Transfer_Binder)& binder, const Handle(Transfer_Finder)& start) +{ + AddItem(binder); + if (!thestarts.IsNull()) thestarts->Append(start); +} + +//======================================================================= +// Function: Filter +// Purpose : +//======================================================================= +void Transfer_IteratorOfProcessForFinder::Filter +(const Handle(Transfer_HSequenceOfFinder)& list, const Standard_Boolean keep) +{ + if (list.IsNull() || thestarts.IsNull()) return; + Standard_Integer i, j, nb = thestarts->Length(); + if (nb == 0) return; + Handle(Transfer_Binder) factice; + Transfer_TransferMapOfProcessForFinder amap(nb); + for (i = 1; i <= nb; i++) { + j = amap.Add(thestarts->Value(i), factice); + SelectItem(j, !keep); + } + + // Comparison + nb = list->Length(); + for (i = 1; i <= nb; i++) { + j = amap.FindIndex(list->Value(i)); + if (j > 0) SelectItem(j, keep); + } +} + +//======================================================================= +// Function: HasStarting +// Purpose : +//======================================================================= +Standard_Boolean Transfer_IteratorOfProcessForFinder::HasStarting() const +{ + return (!thestarts.IsNull()); +} + +//======================================================================= +// Function: Starting +// Purpose : +//======================================================================= +const Handle(Transfer_Finder)& Transfer_IteratorOfProcessForFinder::Starting() const +{ + if (thestarts.IsNull()) throw Standard_NoSuchObject("TransferIterator : No Starting defined at all"); + return thestarts->Value(thecurr); +} diff --git a/src/Transfer/Transfer_IteratorOfProcessForTransient_0.cxx b/src/Transfer/Transfer_IteratorOfProcessForTransient_0.cxx index 49332227d9..67c4a5d25d 100644 --- a/src/Transfer/Transfer_IteratorOfProcessForTransient_0.cxx +++ b/src/Transfer/Transfer_IteratorOfProcessForTransient_0.cxx @@ -22,24 +22,81 @@ #include #include #include - -#define TheStart Handle(Standard_Transient) -#define TheStart_hxx -#define TheMapHasher TColStd_MapTransientHasher -#define TheMapHasher_hxx -#define Handle_TheList Handle(TColStd_HSequenceOfTransient) -#define TheList TColStd_HSequenceOfTransient -#define TheList_hxx -#define Transfer_TransferMap Transfer_TransferMapOfProcessForTransient -#define Transfer_TransferMap_hxx -#define Transfer_Iterator Transfer_IteratorOfProcessForTransient -#define Transfer_Iterator_hxx -#define Transfer_Actor Transfer_ActorOfProcessForTransient -#define Transfer_Actor_hxx -#define Handle_Transfer_Actor Handle(Transfer_ActorOfProcessForTransient) -#define Transfer_TransferProcess Transfer_ProcessForTransient -#define Transfer_TransferProcess_hxx -#define Handle_Transfer_TransferProcess Handle(Transfer_ProcessForTransient) -#include +//======================================================================= +//function : Transfer_IteratorOfProcessForTransient +//purpose : +//======================================================================= +Transfer_IteratorOfProcessForTransient::Transfer_IteratorOfProcessForTransient(const Standard_Boolean withstarts) + : Transfer_TransferIterator() +{ + if (withstarts) thestarts = new TColStd_HSequenceOfTransient(); +} +//======================================================================= +//function : Add +//purpose : +//======================================================================= +void Transfer_IteratorOfProcessForTransient::Add +(const Handle(Transfer_Binder)& binder) +{ + if (!thestarts.IsNull()) throw Standard_NoSuchObject("Transfer_IteratorOfProcessForTransient : Add, Starting Object required not provided"); + AddItem(binder); +} + +//======================================================================= +//function : Add +//purpose : +//======================================================================= +void Transfer_IteratorOfProcessForTransient::Add +(const Handle(Transfer_Binder)& binder, const Handle(Standard_Transient)& start) +{ + AddItem(binder); + if (!thestarts.IsNull()) thestarts->Append(start); +} + +//======================================================================= +//function : Filter +//purpose : +//======================================================================= +void Transfer_IteratorOfProcessForTransient::Filter +(const Handle(TColStd_HSequenceOfTransient)& list, const Standard_Boolean keep) +{ + if (list.IsNull() || thestarts.IsNull()) return; + Standard_Integer i, j, nb = thestarts->Length(); + if (nb == 0) return; + Handle(Transfer_Binder) factice; + Transfer_TransferMapOfProcessForTransient amap(nb); + for (i = 1; i <= nb; i++) + { + j = amap.Add(thestarts->Value(i), factice); + SelectItem(j, !keep); + } + + // Comparison + nb = list->Length(); + for (i = 1; i <= nb; i++) + { + j = amap.FindIndex(list->Value(i)); + if (j > 0) SelectItem(j, keep); + } +} + +//======================================================================= +//function : HasStarting +//purpose : +//======================================================================= +Standard_Boolean Transfer_IteratorOfProcessForTransient::HasStarting() const +{ + return (!thestarts.IsNull()); +} + +//======================================================================= +//function : Starting +//purpose : +//======================================================================= +const Handle(Standard_Transient)& Transfer_IteratorOfProcessForTransient::Starting() const +{ + if (thestarts.IsNull()) throw Standard_NoSuchObject("TransferIterator : No Starting defined at all"); + return thestarts->Value(thecurr); +} diff --git a/src/Transfer/Transfer_Mapper.gxx b/src/Transfer/Transfer_Mapper.gxx deleted file mode 100644 index f446f0eeb3..0000000000 --- a/src/Transfer/Transfer_Mapper.gxx +++ /dev/null @@ -1,41 +0,0 @@ -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -//#include -#include - - -Transfer_Mapper::Transfer_Mapper (const TheKey& akey) - : theval (akey) -{ SetHashCode ( TheHasher::HashCode (akey, IntegerLast() ) ); } - - - const TheKey& Transfer_Mapper::Value () const - { return theval; } - - Standard_Boolean Transfer_Mapper::Equates - (const Handle(Transfer_Finder)& other) const -{ - if (other.IsNull()) return Standard_False; - if (GetHashCode() != other->GetHashCode()) return Standard_False; - if (other->DynamicType() != DynamicType()) return Standard_False; - Handle(Transfer_Mapper) another = Handle(Transfer_Mapper)::DownCast(other); -// return (theval == another->Value()); - return TheHasher::IsEqual (theval,another->Value()); -} - - Handle(Standard_Type) Transfer_Mapper::ValueType () const - { return TheInfo::Type(theval); } - - Standard_CString Transfer_Mapper::ValueTypeName () const - { return TheInfo::TypeName(theval); } diff --git a/src/Transfer/Transfer_ProcessForFinder_0.cxx b/src/Transfer/Transfer_ProcessForFinder_0.cxx index 12e7a379c6..0cc4e32e88 100644 --- a/src/Transfer/Transfer_ProcessForFinder_0.cxx +++ b/src/Transfer/Transfer_ProcessForFinder_0.cxx @@ -16,38 +16,1245 @@ #include -#include - -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include #include -#include #include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include -#define TheStart Handle(Transfer_Finder) -#define TheStart_hxx -#define TheMapHasher Transfer_FindHasher -#define TheMapHasher_hxx -#define Handle_TheList Handle(Transfer_HSequenceOfFinder) -#define TheList Transfer_HSequenceOfFinder -#define TheList_hxx -#define Transfer_TransferMap Transfer_TransferMapOfProcessForFinder -#define Transfer_TransferMap_hxx -#define Transfer_Iterator Transfer_IteratorOfProcessForFinder -#define Transfer_Iterator_hxx -#define Transfer_Actor Transfer_ActorOfProcessForFinder -#define Transfer_Actor_hxx -#define Handle_Transfer_Actor Handle(Transfer_ActorOfProcessForFinder) -#define Transfer_TransferProcess Transfer_ProcessForFinder -#define Transfer_TransferProcess_hxx -#define Handle_Transfer_TransferProcess Handle(Transfer_ProcessForFinder) -#include +//======================================================================= +//function : Transfer_ProcessForFinder +//purpose : +//======================================================================= +Transfer_ProcessForFinder::Transfer_ProcessForFinder(const Standard_Integer nb) + : themap(nb) +{ + theerrh = Standard_True; + therootm = Standard_False; + thelevel = 0; therootl = 0; + themessenger = Message::DefaultMessenger(); + thetrace = 0; + theindex = 0; +} +//======================================================================= +//function : Transfer_ProcessForFinder +//purpose : +//======================================================================= +Transfer_ProcessForFinder::Transfer_ProcessForFinder(const Handle(Message_Messenger)& messenger, + const Standard_Integer nb) + : themap(nb) +{ + theerrh = Standard_True; + therootm = Standard_False; + thelevel = 0; therootl = 0; + SetMessenger(messenger); + thetrace = 1; + theindex = 0; +} + +//======================================================================= +//function : Clear +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::Clear() +{ + thelevel = 0; therootl = 0; + theroots.Clear(); + themap.Clear(); + theindex = 0; thelastobj.Nullify(); thelastbnd.Nullify(); +} + +//======================================================================= +//function : Clean +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::Clean() +{ + Standard_Integer i, nb = NbMapped(); + Standard_Integer j, unb = 0; + for (i = 1; i <= nb; i++) + { + if (themap(i).IsNull()) unb++; + } + if (unb == 0) return; + + // Redo the map -> offsets + TColStd_Array1OfInteger unbs(1, nb); unbs.Init(0); + Transfer_TransferMapOfProcessForFinder newmap(nb * 2); + for (i = 1; i <= nb; i++) + { + Handle(Transfer_Finder) ent = Mapped(i); + Handle(Transfer_Binder) bnd = MapItem(i); + if (bnd.IsNull()) continue; + j = newmap.Add(ent, bnd); + unbs.SetValue(i, j); + } + themap.Assign(newmap); + + // Update Root List + TColStd_IndexedMapOfInteger aNewRoots; + for (i = 1; i <= theroots.Extent(); i++) + { + j = theroots.FindKey(i); + Standard_Integer k = unbs.Value(j); + if (k) aNewRoots.Add(k); + } + theroots.Clear(); + theroots = aNewRoots; + + // The rest: cleaning + thelastobj.Nullify(); + thelastbnd.Nullify(); + theindex = 0; +} + +//======================================================================= +//function : Resize +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::Resize(const Standard_Integer nb) +{ + if (nb > themap.NbBuckets()) themap.ReSize(nb); +} + +//======================================================================= +//function : SetActor +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::SetActor(const Handle(Transfer_ActorOfProcessForFinder)& actor) +{ + if (theactor == actor) return; + if (theactor.IsNull()) theactor = actor; + else if (actor.IsNull()) theactor = actor; + else if (theactor->IsLast()) { actor->SetNext(theactor); theactor = actor; } + else theactor->SetNext(actor); +} + +//======================================================================= +//function : Actor +//purpose : +//======================================================================= +Handle(Transfer_ActorOfProcessForFinder) Transfer_ProcessForFinder::Actor() const +{ + return theactor; +} + +//======================================================================= +//function : Find +//purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ProcessForFinder::Find(const Handle(Transfer_Finder)& start) const +{ + if (thelastobj == start) + { + if (theindex > 0) return thelastbnd; + } + Standard_Integer index = themap.FindIndex(start); + if (index > 0) + { + const Handle(Transfer_Binder)& binder = themap.FindFromIndex(index); + return binder; + } + return Handle(Transfer_Binder)(); +} + +//======================================================================= +//function : IsBound +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForFinder::IsBound(const Handle(Transfer_Finder)& start) const +{ + Handle(Transfer_Binder) binder = Find(start); + if (binder.IsNull()) return Standard_False; + return binder->HasResult(); +} + +//======================================================================= +//function : IsAlreadyUsed +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForFinder::IsAlreadyUsed(const Handle(Transfer_Finder)& start) const +{ + Handle(Transfer_Binder) binder = Find(start); + if (binder.IsNull()) + { + StartTrace(binder, start, thelevel, 4); + throw Transfer_TransferFailure("TransferProcess : IsAlreadyUsed, transfer not done cannot be used..."); + } + return (binder->Status() == Transfer_StatusUsed); +} + +//======================================================================= +//function : FindAndMask +//purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ProcessForFinder::FindAndMask(const Handle(Transfer_Finder)& start) +{ + if (thelastobj == start) + { + if (theindex > 0) return thelastbnd; + } + thelastobj = start; + theindex = themap.FindIndex(start); + if (theindex > 0) thelastbnd = themap.FindFromIndex(theindex); + else thelastbnd.Nullify(); + return thelastbnd; +} + +//======================================================================= +//function : Bind +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::Bind(const Handle(Transfer_Finder)& start, + const Handle(Transfer_Binder)& binder) +{ + if (binder.IsNull()) return; + Handle(Transfer_Binder) former = FindAndMask(start); + if (!former.IsNull()) + { + // We admit VoidBinder: then we resume our Check + if (former->DynamicType() == STANDARD_TYPE(Transfer_VoidBinder)) + { + binder->Merge(former); + themap(theindex) = binder; + } + else if (former->Status() == Transfer_StatusUsed) + { + StartTrace(former, start, thelevel, 4); + throw Transfer_TransferFailure("TransferProcess : Bind, already Bound"); + } + else + { + if (thetrace > 2) StartTrace(former, start, thelevel, 5); + binder->CCheck()->GetMessages(former->Check()); + } + } + if (theindex == 0 || thelastbnd.IsNull()) + { + if (theindex == 0) theindex = themap.Add(start, binder); + else themap(theindex) = binder; + thelastbnd = binder; + } + else + { + thelastbnd = binder; + themap(theindex) = binder; + } +} + +//======================================================================= +//function : Rebind +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::Rebind(const Handle(Transfer_Finder)& start, + const Handle(Transfer_Binder)& binder) +{ + Bind(start, binder); +} + +//======================================================================= +//function : Unbind +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForFinder::Unbind(const Handle(Transfer_Finder)& start) +{ + Handle(Transfer_Binder) former = FindAndMask(start); + if (theindex == 0) return Standard_False; + if (former.IsNull()) return Standard_False; + if (former->DynamicType() == STANDARD_TYPE(Transfer_VoidBinder)) return Standard_True; + themap(theindex) = thelastbnd; + if (theroots.Contains(theindex)) + { + TColStd_IndexedMapOfInteger aNewRoots; + for (Standard_Integer i = 1; i <= theroots.Extent(); i++) + if (theindex != theroots.FindKey(i)) + aNewRoots.Add(theroots.FindKey(i)); + + theroots.Clear(); + theroots = aNewRoots; + } + + thelastobj.Nullify(); + thelastbnd.Nullify(); + theindex = 0; + return Standard_True; +} + +//======================================================================= +//function : FindElseBind +//purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ProcessForFinder::FindElseBind(const Handle(Transfer_Finder)& start) +{ + Handle(Transfer_Binder) binder = FindAndMask(start); + if (!binder.IsNull()) return binder; + binder = new Transfer_VoidBinder; + Bind(start, binder); + return binder; +} + +//======================================================================= +//function : SetMessenger +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::SetMessenger(const Handle(Message_Messenger)& messenger) +{ + if (messenger.IsNull()) + themessenger = Message::DefaultMessenger(); + else + themessenger = messenger; +} + +//======================================================================= +//function : Messenger +//purpose : +//======================================================================= +Handle(Message_Messenger) Transfer_ProcessForFinder::Messenger() const +{ + return themessenger; +} + +//======================================================================= +//function : SetTraceLevel +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::SetTraceLevel(const Standard_Integer tracelev) +{ + thetrace = tracelev; +} + +//======================================================================= +//function : TraceLevel +//purpose : +//======================================================================= +Standard_Integer Transfer_ProcessForFinder::TraceLevel() const +{ + return thetrace; +} + +//======================================================================= +//function : SendFail +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::SendFail(const Handle(Transfer_Finder)& start, + const Message_Msg& amsg) +{ + AddFail(start, amsg); +} + +//======================================================================= +//function : SendWarning +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::SendWarning(const Handle(Transfer_Finder)& start, + const Message_Msg& amsg) +{ + AddWarning(start, amsg); +} + +//======================================================================= +//function : SendMsg +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::SendMsg(const Handle(Transfer_Finder)& start, + const Message_Msg& amsg) +{ + Handle(Transfer_Binder) binder = FindAndMask(start); + if (binder.IsNull()) + { + binder = new Transfer_VoidBinder; + Bind(start, binder); + } + // Feeds the trace: Causing rule (user messages) + if (thetrace > 0) + { + StartTrace(binder, start, thelevel, 6); + Message_Messenger::StreamBuffer aSender = themessenger->SendInfo(); + aSender << amsg.Value(); + if (amsg.IsEdited() && thetrace > 2) + aSender << " [from: " << amsg.Original() << "]"; + aSender << std::endl; + } +} + +//======================================================================= +//function : AddFail +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::AddFail(const Handle(Transfer_Finder)& start, + const Standard_CString mess, + const Standard_CString orig) +{ + Handle(Transfer_Binder) binder = FindAndMask(start); + if (binder.IsNull()) + { + binder = new Transfer_VoidBinder; + Bind(start, binder); + } + binder->AddFail(mess, orig); + if (thetrace > 0) + { + StartTrace(binder, start, thelevel, 1); + Message_Messenger::StreamBuffer aSender = themessenger->SendFail(); + aSender << " --> Fail : " << mess; + if (orig[0] != '\0' && thetrace > 2) aSender << " [from: " << orig << "]"; + aSender << std::endl; + } +} + +//======================================================================= +//function : AddError +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::AddError(const Handle(Transfer_Finder)& start, + const Standard_CString mess, + const Standard_CString orig) +{ + AddFail(start, mess, orig); +} + +//======================================================================= +//function : AddFail +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::AddFail(const Handle(Transfer_Finder)& start, + const Message_Msg& amsg) +{ + if (amsg.IsEdited()) AddFail(start, TCollection_AsciiString(amsg.Value()).ToCString(), + TCollection_AsciiString(amsg.Original()).ToCString()); + else AddFail(start, TCollection_AsciiString(amsg.Value()).ToCString()); +} + +//======================================================================= +//function : AddWarning +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::AddWarning(const Handle(Transfer_Finder)& start, + const Standard_CString mess, + const Standard_CString orig) +{ + Handle(Transfer_Binder) binder = FindAndMask(start); + if (binder.IsNull()) + { + binder = new Transfer_VoidBinder; + Bind(start, binder); + } + binder->AddWarning(mess, orig); + if (thetrace > 1) + { + StartTrace(binder, start, thelevel, 2); + Message_Messenger::StreamBuffer aSender = themessenger->SendWarning(); + aSender << " --> Warning : " << mess; + if (orig[0] != '\0' && thetrace > 2) aSender << " [from: " << orig << "]"; + aSender << std::endl; + } +} + +//======================================================================= +//function : AddWarning +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::AddWarning(const Handle(Transfer_Finder)& start, + const Message_Msg& amsg) +{ + if (amsg.IsEdited()) AddWarning(start, TCollection_AsciiString(amsg.Value()).ToCString(), + TCollection_AsciiString(amsg.Original()).ToCString()); + else AddWarning(start, TCollection_AsciiString(amsg.Value()).ToCString()); +} + +//======================================================================= +//function : Mend +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::Mend(const Handle(Transfer_Finder)& start, + const Standard_CString pref) +{ + Handle(Transfer_Binder) binder = FindAndMask(start); + if (binder.IsNull()) return; // rien a faire ... + Handle(Interface_Check) ach = binder->CCheck(); + ach->Mend(pref); +} + +//======================================================================= +//function : Check +//purpose : +//======================================================================= +Handle(Interface_Check) Transfer_ProcessForFinder::Check(const Handle(Transfer_Finder)& start) const +{ + const Handle(Transfer_Binder)& binder = Find(start); + if (binder.IsNull()) + { + Handle(Interface_Check) check; + return check; + } + return binder->Check(); +} + +//======================================================================= +//function : BindTransient +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::BindTransient(const Handle(Transfer_Finder)& start, + const Handle(Standard_Transient)& res) +{ + if (res.IsNull()) return; + Handle(Transfer_Binder) former = Find(start); + Handle(Transfer_SimpleBinderOfTransient) binder = + Handle(Transfer_SimpleBinderOfTransient)::DownCast(former); + // Binding sur place ? + if (!binder.IsNull()) + { + if (binder->Status() == Transfer_StatusVoid) { binder->SetResult(res); return; } + } + // Otherwise, redo + binder = new Transfer_SimpleBinderOfTransient; + binder->SetResult(res); + if (former.IsNull()) Bind(start, binder); + else Rebind(start, binder); +} + +//======================================================================= +//function : FindTransient +//purpose : +//======================================================================= +const Handle(Standard_Transient)& Transfer_ProcessForFinder::FindTransient +(const Handle(Transfer_Finder)& start) const +{ + static const Handle(Standard_Transient) aDummy; + Handle(Transfer_SimpleBinderOfTransient) binder = + Handle(Transfer_SimpleBinderOfTransient)::DownCast(Find(start)); + if (binder.IsNull()) return aDummy; + if (!binder->HasResult()) return aDummy; + return binder->Result(); +} + +//======================================================================= +//function : BindMultiple +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::BindMultiple(const Handle(Transfer_Finder)& start) +{ + Handle(Transfer_Binder) binder = FindAndMask(start); + if (!binder.IsNull()) + { + if (!binder->IsKind(STANDARD_TYPE(Transfer_MultipleBinder))) + { + StartTrace(thelastbnd, start, thelevel, 4); + throw Transfer_TransferFailure("TransferProcess : BindMultiple"); + } + } + else Bind(start, new Transfer_MultipleBinder); +} + +//======================================================================= +//function : AddMultiple +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::AddMultiple(const Handle(Transfer_Finder)& start, + const Handle(Standard_Transient)& res) +{ + Handle(Transfer_Binder) binder = FindAndMask(start); + Handle(Transfer_MultipleBinder) multr = + Handle(Transfer_MultipleBinder)::DownCast(binder); + if (multr.IsNull()) + { + StartTrace(binder, start, thelevel, 4); + if (binder.IsNull()) throw Transfer_TransferFailure("TransferProcess : AddMultiple, nothing bound"); + else throw Transfer_TransferFailure("TransferProcess : AddMultiple, Binder not a MultipleBinder"); + } + multr->AddResult(res); +} + +//======================================================================= +//function : FindTypedTransient +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForFinder::FindTypedTransient +(const Handle(Transfer_Finder)& start, const Handle(Standard_Type)& atype, + Handle(Standard_Transient)& val) const +{ + return GetTypedTransient(Find(start), atype, val); +} + +//======================================================================= +//function : GetTypedTransient +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForFinder::GetTypedTransient +(const Handle(Transfer_Binder)& binder, const Handle(Standard_Type)& atype, + Handle(Standard_Transient)& val) const +{ + return Transfer_SimpleBinderOfTransient::GetTypedResult(binder, atype, val); +} + +//======================================================================= +//function : NbMapped +//purpose : +//======================================================================= +Standard_Integer Transfer_ProcessForFinder::NbMapped() const +{ + return themap.Extent(); +} + +//======================================================================= +//function : Mapped +//purpose : +//======================================================================= +const Handle(Transfer_Finder)& Transfer_ProcessForFinder::Mapped(const Standard_Integer num) const +{ + return themap.FindKey(num); +} + +//======================================================================= +//function : MapIndex +//purpose : +//======================================================================= +Standard_Integer Transfer_ProcessForFinder::MapIndex(const Handle(Transfer_Finder)& start) const +{ + return themap.FindIndex(start); +} + +//======================================================================= +//function : MapItem +//purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ProcessForFinder::MapItem(const Standard_Integer num) const +{ + Handle(Transfer_Binder) binder = themap.FindFromIndex(num); + return binder; +} + +//======================================================================= +//function : SetRoot +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::SetRoot(const Handle(Transfer_Finder)& start) +{ + Standard_Integer index = MapIndex(start); + if (index == 0) + { + return; + } + theroots.Add(index); + if (thetrace > 2) StartTrace(MapItem(index), start, thelevel, 3); +} + +//======================================================================= +//function : SetRootManagement +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::SetRootManagement(const Standard_Boolean stat) +{ + therootm = stat; +} + +//======================================================================= +//function : NbRoots +//purpose : +//======================================================================= +Standard_Integer Transfer_ProcessForFinder::NbRoots() const +{ + return theroots.Extent(); +} + +//======================================================================= +//function : Root +//purpose : +//======================================================================= +const Handle(Transfer_Finder)& Transfer_ProcessForFinder::Root(const Standard_Integer num) const +{ + Standard_Integer ind = 0; + if (num > 0 && num <= theroots.Extent()) ind = theroots.FindKey(num); + return themap.FindKey(ind); +} + +//======================================================================= +//function : RootItem +//purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ProcessForFinder::RootItem(const Standard_Integer num) const +{ + Standard_Integer ind = 0; + if (num > 0 && num <= theroots.Extent()) ind = theroots.FindKey(num); + return themap.FindFromIndex(ind); +} + +//======================================================================= +//function : RootIndex +//purpose : +//======================================================================= +Standard_Integer Transfer_ProcessForFinder::RootIndex(const Handle(Transfer_Finder)& start) const +{ + Standard_Integer index = MapIndex(start); + if (index == 0) return 0; + return theroots.FindIndex(index); +} + +//======================================================================= +//function : NestingLevel +//purpose : +//======================================================================= +Standard_Integer Transfer_ProcessForFinder::NestingLevel() const +{ + return thelevel; +} + +//======================================================================= +//function : ResetNestingLevel +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::ResetNestingLevel() +{ + thelevel = 0; +} + +//======================================================================= +//function : Recognize +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForFinder::Recognize(const Handle(Transfer_Finder)& start) const +{ + Handle(Transfer_ActorOfProcessForFinder) actor = theactor; + // We scan the Next until we have a Result + while (!actor.IsNull()) + { + if (actor->Recognize(start)) return Standard_True; + actor = actor->Next(); + } + return Standard_False; +} + +//======================================================================= +//function : Transferring +//purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ProcessForFinder::Transferring(const Handle(Transfer_Finder)& start, + const Message_ProgressRange& theProgress) +{ + Handle(Transfer_Binder) former = FindAndMask(start); + // Transfer already done with Result? + + // We consider that this new Transfer request therefore corresponds to a + // additional use: note "AlreadyUsed", therefore non-modifiable result + if (!former.IsNull()) + { + if (former->HasResult()) + { + former->SetAlreadyUsed(); + return former; + } + // Initial State: perhaps already done... or infeasible! + Message_Messenger::StreamBuffer aSender = themessenger->SendInfo(); + Transfer_StatusExec statex = former->StatusExec(); + switch (statex) + { + case Transfer_StatusInitial: + break; + case Transfer_StatusDone: + aSender << " .. and Transfer done" << std::endl; + return former; + case Transfer_StatusRun: + former->SetStatusExec(Transfer_StatusLoop); + return former; + case Transfer_StatusError: + if (thetrace) + { + aSender << " *** Transfer in Error Status :" << std::endl; + StartTrace(former, start, thelevel, 0); + } + else StartTrace(former, start, thelevel, 4); + throw Transfer_TransferFailure("TransferProcess : Transfer in Error Status"); + case Transfer_StatusLoop: + if (thetrace) + { + aSender << " *** Transfer Head of Dead Loop :" << std::endl; + StartTrace(former, start, thelevel, 0); + } + else StartTrace(former, start, thelevel, 4); + throw Transfer_TransferDeadLoop("TransferProcess : Transfer at Head of a Dead Loop"); + } + former->SetStatusExec(Transfer_StatusRun); + } +#ifdef TRANSLOG + std::cout << " GO .." << std::endl; +#endif + + Handle(Transfer_Binder) binder; + Standard_Boolean newbind = Standard_False; + if (theerrh) + { + Message_Messenger::StreamBuffer aSender = themessenger->SendInfo(); + + // Transfer under protection for exceptions (for notification in fact + Standard_Integer oldlev = thelevel; + try + { + OCC_CATCH_SIGNALS + binder = TransferProduct(start, theProgress); + } + + // Exceptions to catch up on: they are not all the same + catch (Transfer_TransferDeadLoop const&) + { + if (binder.IsNull()) + { + aSender << " *** Dead Loop with no Result" << std::endl; + if (thetrace) StartTrace(binder, start, thelevel - 1, 0); + binder = new Transfer_VoidBinder; + Bind(start, binder); newbind = Standard_True; + } + else if (binder->StatusExec() == Transfer_StatusLoop) + { + if (thetrace) + { + aSender << " *** Dead Loop : Finding head of Loop :" << std::endl; + StartTrace(binder, start, thelevel - 1, 0); + } + else StartTrace(binder, start, thelevel - 1, 4); + throw Transfer_TransferFailure("TransferProcess : Head of Dead Loop"); + // In other words, we change the exception (we exit the loop) + } + else + { + if (thetrace) + { + aSender << " *** Dead Loop : Actor in Loop :" << std::endl; + StartTrace(binder, start, thelevel - 1, 0); + } + } + binder->AddFail("Transfer in dead Loop"); + thelevel = oldlev; + } + catch (Standard_Failure const& anException) + { + if (binder.IsNull()) + { + aSender << " *** Exception Raised with no Result" << std::endl; + binder = new Transfer_VoidBinder; + Bind(start, binder); newbind = Standard_True; + } + binder->AddFail("Transfer stopped by exception raising"); + if (thetrace) + { + aSender << " *** Raised : " << anException.GetMessageString() << std::endl; + StartTrace(binder, start, thelevel - 1, 4); + } + thelevel = oldlev; + } + } + + // Unprotected transfer (thus, dbx by hand in case of crash by Raise) + else binder = TransferProduct(start, theProgress); + + if (theProgress.UserBreak()) + return Handle(Transfer_Binder)(); + + // Conclusion: Note in the Map + + if (!newbind && !binder.IsNull()) + { + if (former.IsNull()) + { + // Maybe did Bind himself... check if not do it + if (!IsBound(start)) Bind(start, binder); + else + { + Rebind(start, binder); + } + } + else Rebind(start, binder); + } + else + { + if (!former.IsNull()) former->SetStatusExec(Transfer_StatusDone); //+ + return Handle(Transfer_Binder)(); + } + + // Manage Roots (if provided) + + if (therootl >= thelevel) + { + therootl = 0; + if (therootm && binder->Status() != Transfer_StatusVoid) + { + SetRoot(start); + } + } + return thelastbnd; +} + + +//======================================================================= +//function : TransferProduct +//purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ProcessForFinder::TransferProduct +(const Handle(Transfer_Finder)& start, + const Message_ProgressRange& theProgress) +{ + thelevel++; // if decrements and == 0, root transfer + Handle(Transfer_Binder) binder; + Handle(Transfer_ActorOfProcessForFinder) actor = theactor; + + // We scan the Next until we have a Result + Message_ProgressScope aScope(theProgress, NULL, 1, true); + while (!actor.IsNull()) + { + if (actor->Recognize(start)) binder = actor->Transferring(start, this, aScope.Next()); + else binder.Nullify(); + if (!binder.IsNull()) break; + actor = actor->Next(); + } + if (aScope.UserBreak()) + return Handle(Transfer_Binder)(); + + if (binder.IsNull()) + { + if (thelevel > 0) thelevel--; + return binder; + } + // Root level management (.. take a closer look..) + if (therootl == 0 && binder->StatusExec() == Transfer_StatusDone) + therootl = thelevel - 1; + + if (thelevel > 0) thelevel--; + return binder; +} + +//======================================================================= +//function : Transfer +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForFinder::Transfer(const Handle(Transfer_Finder)& start, + const Message_ProgressRange& theProgress) +{ + Handle(Transfer_Binder) binder = Transferring(start, theProgress); + return (!binder.IsNull()); +} + +//======================================================================= +//function : SetErrorHandle +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::SetErrorHandle(const Standard_Boolean err) +{ + theerrh = err; +} + +//======================================================================= +//function : ErrorHandle +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForFinder::ErrorHandle() const +{ + return theerrh; +} + +//======================================================================= +//function : StartTrace +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::StartTrace(const Handle(Transfer_Binder)& binder, + const Handle(Transfer_Finder)& start, + const Standard_Integer level, + const Standard_Integer mode) const +{ + Message_Messenger::StreamBuffer aSender = themessenger->SendInfo(); + // ### Fail (Roots:50) -- Start start->DynamicType() + // ### Fail (Roots:50) -- Start id:#label.. Type:start->DynamicType() + if (thetrace > 3) + { // Internal to be switch when searching bug (trace >= 4) + if (mode == 1) aSender << " ### Fail"; + if (mode == 2) aSender << " ### Warning"; + if (mode == 3) aSender << " ### New Root n0 " << theroots.Extent(); + if (mode == 4) aSender << " ### Exception"; + if (mode == 5) aSender << " ### Substitution"; + if (mode == 6) aSender << " ### Information"; + if (level > 1) + aSender << " (nested)"; + if (mode >= 0 && mode != 3) + aSender << " at " << theroots.Extent() << " Roots"; + } + if (!start.IsNull()) PrintTrace(start, aSender); + + if (!binder.IsNull()) + { + Handle(Transfer_Binder) bnd = binder; + Standard_Boolean hasres = Standard_False; + while (!bnd.IsNull()) + { + if (bnd->Status() != Transfer_StatusVoid) + { + if (!hasres) + aSender << "\n --- Result Type : "; + else + aSender << " , "; + aSender << bnd->ResultTypeName(); + hasres = Standard_True; + } + bnd = bnd->NextResult(); + } + if (!hasres && mode > 2) + { + aSender << "\n --- No Result recorded"; + } + } + aSender << std::endl; +} + +//======================================================================= +//function : PrintTrace +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::PrintTrace(const Handle(Transfer_Finder)& start, Standard_OStream& S) const +{ + if (!start.IsNull()) S << " Type:" << start->DynamicType()->Name(); +} + +//======================================================================= +//function : IsLooping +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForFinder::IsLooping +(const Standard_Integer alevel) const +{ + return alevel > NbMapped(); +} + +//======================================================================= +//function : RootResult +//purpose : +//======================================================================= +Transfer_IteratorOfProcessForFinder Transfer_ProcessForFinder::RootResult(const Standard_Boolean withstart) const +{ + Transfer_IteratorOfProcessForFinder iter(withstart); + Standard_Integer max = theroots.Extent(); + for (Standard_Integer j = 1; j <= max; j++) + { + Standard_Integer i = theroots.FindKey(j); + Handle(Transfer_Binder) binder = MapItem(i); + if (binder.IsNull()) continue; + if (withstart) iter.Add(binder, Mapped(i)); + else iter.Add(binder); + } + return iter; +} + +//======================================================================= +//function : CompleteResult +//purpose : +//======================================================================= +Transfer_IteratorOfProcessForFinder Transfer_ProcessForFinder::CompleteResult +(const Standard_Boolean withstart) const +{ + Transfer_IteratorOfProcessForFinder iter(withstart); + Standard_Integer max = NbMapped(); + for (Standard_Integer i = 1; i <= max; i++) + { + Handle(Transfer_Binder) binder = MapItem(i); + if (binder.IsNull()) continue; + if (withstart) iter.Add(binder, Mapped(i)); + else iter.Add(binder); + } + return iter; +} + +//======================================================================= +//function : AbnormalResult +//purpose : +//======================================================================= +Transfer_IteratorOfProcessForFinder Transfer_ProcessForFinder::AbnormalResult() const +{ + Transfer_IteratorOfProcessForFinder iter(Standard_True); + Standard_Integer max = NbMapped(); + for (Standard_Integer i = 1; i <= max; i++) + { + Handle(Transfer_Binder) binder = MapItem(i); + if (binder.IsNull()) continue; + Transfer_StatusExec statex = binder->StatusExec(); + if (statex != Transfer_StatusInitial && statex != Transfer_StatusDone) + iter.Add(binder, Mapped(i)); // we note the "not normal" cases + } + return iter; +} + +//======================================================================= +//function : CheckList +//purpose : +//======================================================================= +Interface_CheckIterator Transfer_ProcessForFinder::CheckList +(const Standard_Boolean erronly) const +{ + Interface_CheckIterator list; + Standard_Integer num, max = NbMapped(); + for (Standard_Integer i = 1; i <= max; i++) + { + Handle(Transfer_Binder) binder = MapItem(i); + if (binder.IsNull()) continue; + Transfer_StatusExec statex = binder->StatusExec(); + Handle(Interface_Check) check = binder->Check(); + if (statex != Transfer_StatusInitial && statex != Transfer_StatusDone && + !check->HasFailed()) + check->AddFail("Transfer in Abnormal Status (!= Initial or Done)"); + if (!check->HasFailed() && (erronly || check->NbWarnings() == 0)) continue; + const Handle(Transfer_Finder)& ent = Mapped(i); + num = CheckNum(ent); + if (num == 0) num = i; + check->SetEntity(ent); + list.Add(check, num); + } + return list; +} + +//======================================================================= +//function : ResultOne +//purpose : +//======================================================================= +Transfer_IteratorOfProcessForFinder Transfer_ProcessForFinder::ResultOne(const Handle(Transfer_Finder)& start, + const Standard_Integer level, + const Standard_Boolean withstart) const +{ + Transfer_IteratorOfProcessForFinder iter(withstart); + Standard_Integer max = NbMapped(); + Standard_Integer ind = MapIndex(start); + if (ind == 0) return iter; + Standard_Integer i1 = (level == 0 ? ind : 1); + Standard_Integer i2 = (level == 0 ? ind : max); + Handle(TColStd_HArray1OfInteger) map = new TColStd_HArray1OfInteger(i1, i2, 0); + + for (Standard_Integer i = i1; i <= i2; i++) + { + ind = map->Value(i); + if (ind == 0) continue; + Handle(Transfer_Binder) binder = MapItem(i); + if (binder.IsNull()) continue; + if (withstart) iter.Add(binder, Mapped(ind)); + else iter.Add(binder); + } + return iter; +} + +//======================================================================= +//function : CheckListOne +//purpose : +//======================================================================= +Interface_CheckIterator Transfer_ProcessForFinder::CheckListOne +(const Handle(Transfer_Finder)& start, const Standard_Integer level, + const Standard_Boolean erronly) const +{ + Interface_CheckIterator list; + Standard_Integer max = NbMapped(); + Standard_Integer num, ind = MapIndex(start); + if (ind == 0) return list; + Standard_Integer i1 = (level == 0 ? ind : 1); + Standard_Integer i2 = (level == 0 ? ind : max); + Handle(TColStd_HArray1OfInteger) map = new TColStd_HArray1OfInteger(i1, i2, 0); + + for (Standard_Integer i = i1; i <= i2; i++) + { + ind = map->Value(i); + if (ind == 0) continue; + Handle(Transfer_Binder) binder = MapItem(ind); + if (binder.IsNull()) continue; + Transfer_StatusExec statex = binder->StatusExec(); + Handle(Interface_Check) check = binder->Check(); + if (statex != Transfer_StatusInitial && statex != Transfer_StatusDone && + !check->HasFailed()) + check->AddFail("Transfer in Abnormal Status (!= Initial or Done)"); + if (!check->HasFailed() && (erronly || check->NbWarnings() == 0)) continue; + const Handle(Transfer_Finder)& ent = Mapped(ind); + num = CheckNum(ent); if (num == 0) num = ind; + check->SetEntity(ent); + list.Add(check, num); + } + return list; +} + +//======================================================================= +//function : IsCheckListEmpty +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForFinder::IsCheckListEmpty +(const Handle(Transfer_Finder)& start, const Standard_Integer level, + const Standard_Boolean erronly) const +{ + Standard_Integer max = NbMapped(); + Standard_Integer ind = MapIndex(start); + if (ind == 0) return Standard_False; + Standard_Integer i1 = (level == 0 ? ind : 1); + Standard_Integer i2 = (level == 0 ? ind : max); + Handle(TColStd_HArray1OfInteger) map = new TColStd_HArray1OfInteger(i1, i2, 0); + + for (Standard_Integer i = i1; i <= i2; i++) + { + ind = map->Value(i); + if (ind == 0) continue; + Handle(Transfer_Binder) binder = MapItem(ind); + if (binder.IsNull()) continue; + + Transfer_StatusExec statex = binder->StatusExec(); + Handle(Interface_Check) check = binder->Check(); + if (statex != Transfer_StatusInitial && statex != Transfer_StatusDone) + return Standard_False; + if (check->HasFailed() || (!erronly && check->NbWarnings() > 0)) return Standard_False; + } + return Standard_True; +} + +//======================================================================= +//function : RemoveResult +//purpose : +//======================================================================= +void Transfer_ProcessForFinder::RemoveResult(const Handle(Transfer_Finder)& start, + const Standard_Integer level, + const Standard_Boolean /*compute*/) +{ + Standard_Integer max = NbMapped(); + Standard_Integer ind = MapIndex(start); + if (ind == 0) return; + Standard_Integer i1 = (level == 0 ? ind : 1); + Standard_Integer i2 = (level == 0 ? ind : max); + Handle(TColStd_HArray1OfInteger) map = new TColStd_HArray1OfInteger(i1, i2, 0); + + Standard_Integer i; + for (i = i1; i <= i2; i++) + { + ind = map->Value(i); + if (ind == 0) continue; + Handle(Transfer_Binder) binder = MapItem(ind); + if (binder.IsNull()) continue; + } +} + +//======================================================================= +//function : CheckNum +//purpose : +//======================================================================= +Standard_Integer Transfer_ProcessForFinder::CheckNum(const Handle(Transfer_Finder)&) const +{ + return 0; +} diff --git a/src/Transfer/Transfer_ProcessForTransient_0.cxx b/src/Transfer/Transfer_ProcessForTransient_0.cxx index 9b3049527d..4611b27642 100644 --- a/src/Transfer/Transfer_ProcessForTransient_0.cxx +++ b/src/Transfer/Transfer_ProcessForTransient_0.cxx @@ -16,36 +16,1245 @@ #include -#include - -#include -#include -#include -#include -#include -#include -#include -#include -#include #include #include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include +#include + +//======================================================================= +//function : Transfer_ProcessForTransient +//purpose : +//======================================================================= +Transfer_ProcessForTransient::Transfer_ProcessForTransient(const Standard_Integer nb) + : themap(nb) +{ + theerrh = Standard_True; + therootm = Standard_False; + thelevel = 0; therootl = 0; + themessenger = Message::DefaultMessenger(); + thetrace = 0; + theindex = 0; +} + +//======================================================================= +//function : Transfer_ProcessForTransient +//purpose : +//======================================================================= +Transfer_ProcessForTransient::Transfer_ProcessForTransient(const Handle(Message_Messenger)& messenger, + const Standard_Integer nb) + : themap(nb) +{ + theerrh = Standard_True; + therootm = Standard_False; + thelevel = 0; therootl = 0; + SetMessenger(messenger); + thetrace = 1; + theindex = 0; +} + +//======================================================================= +//function : Clear +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::Clear() +{ + thelevel = 0; therootl = 0; + theroots.Clear(); + themap.Clear(); + theindex = 0; thelastobj.Nullify(); thelastbnd.Nullify(); +} + +//======================================================================= +//function : Clean +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::Clean() +{ + Standard_Integer i, nb = NbMapped(); + Standard_Integer j, unb = 0; + for (i = 1; i <= nb; i++) + { + if (themap(i).IsNull()) unb++; + } + if (unb == 0) return; + + // Redo the map -> offsets + TColStd_Array1OfInteger unbs(1, nb); unbs.Init(0); + Transfer_TransferMapOfProcessForTransient newmap(nb * 2); + for (i = 1; i <= nb; i++) + { + Handle(Standard_Transient) ent = Mapped(i); + Handle(Transfer_Binder) bnd = MapItem(i); + if (bnd.IsNull()) continue; + j = newmap.Add(ent, bnd); + unbs.SetValue(i, j); + } + themap.Assign(newmap); + + // Update Root List + TColStd_IndexedMapOfInteger aNewRoots; + for (i = 1; i <= theroots.Extent(); i++) + { + j = theroots.FindKey(i); + Standard_Integer k = unbs.Value(j); + if (k) aNewRoots.Add(k); + } + theroots.Clear(); + theroots = aNewRoots; + + // The rest: cleaning + thelastobj.Nullify(); + thelastbnd.Nullify(); + theindex = 0; +} + +//======================================================================= +//function : Resize +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::Resize(const Standard_Integer nb) +{ + if (nb > themap.NbBuckets()) themap.ReSize(nb); +} + +//======================================================================= +//function : SetActor +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::SetActor(const Handle(Transfer_ActorOfProcessForTransient)& actor) +{ + if (theactor == actor) return; + if (theactor.IsNull()) theactor = actor; + else if (actor.IsNull()) theactor = actor; + else if (theactor->IsLast()) + { + actor->SetNext(theactor); theactor = actor; + } + else theactor->SetNext(actor); +} + +//======================================================================= +//function : Actor +//purpose : +//======================================================================= +Handle(Transfer_ActorOfProcessForTransient) Transfer_ProcessForTransient::Actor() const +{ + return theactor; +} + +//======================================================================= +//function : Find +//purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ProcessForTransient::Find(const Handle(Standard_Transient)& start) const +{ + if (thelastobj == start) + { + if (theindex > 0) return thelastbnd; + } + Standard_Integer index = themap.FindIndex(start); + if (index > 0) + { + const Handle(Transfer_Binder)& binder = themap.FindFromIndex(index); + return binder; + } + return Handle(Transfer_Binder)(); +} + +//======================================================================= +//function : IsBound +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForTransient::IsBound(const Handle(Standard_Transient)& start) const +{ + Handle(Transfer_Binder) binder = Find(start); + if (binder.IsNull()) return Standard_False; + return binder->HasResult(); +} + +//======================================================================= +//function : IsAlreadyUsed +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForTransient::IsAlreadyUsed(const Handle(Standard_Transient)& start) const +{ + Handle(Transfer_Binder) binder = Find(start); + if (binder.IsNull()) + { + StartTrace(binder, start, thelevel, 4); + throw Transfer_TransferFailure("TransferProcess : IsAlreadyUsed, transfer not done cannot be used..."); + } + return (binder->Status() == Transfer_StatusUsed); +} + +//======================================================================= +//function : FindAndMask +//purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ProcessForTransient::FindAndMask(const Handle(Standard_Transient)& start) +{ + if (thelastobj == start) + { + if (theindex > 0) return thelastbnd; + } + thelastobj = start; + theindex = themap.FindIndex(start); + if (theindex > 0) thelastbnd = themap.FindFromIndex(theindex); + else thelastbnd.Nullify(); + return thelastbnd; +} + +//======================================================================= +//function : Bind +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::Bind(const Handle(Standard_Transient)& start, + const Handle(Transfer_Binder)& binder) +{ + if (binder.IsNull()) return; + Handle(Transfer_Binder) former = FindAndMask(start); + if (!former.IsNull()) + { + // We admit VoidBinder: then we resume our Check + if (former->DynamicType() == STANDARD_TYPE(Transfer_VoidBinder)) + { + binder->Merge(former); + themap(theindex) = binder; + } + else if (former->Status() == Transfer_StatusUsed) + { + StartTrace(former, start, thelevel, 4); + throw Transfer_TransferFailure("TransferProcess : Bind, already Bound"); + } + else + { + if (thetrace > 2) StartTrace(former, start, thelevel, 5); + binder->CCheck()->GetMessages(former->Check()); + } + } + if (theindex == 0 || thelastbnd.IsNull()) + { + if (theindex == 0) theindex = themap.Add(start, binder); + else themap(theindex) = binder; + thelastbnd = binder; + } + else + { + thelastbnd = binder; + themap(theindex) = binder; + } +} + +//======================================================================= +//function : Rebind +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::Rebind(const Handle(Standard_Transient)& start, + const Handle(Transfer_Binder)& binder) +{ + Bind(start, binder); +} + +//======================================================================= +//function : Unbind +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForTransient::Unbind(const Handle(Standard_Transient)& start) +{ + Handle(Transfer_Binder) former = FindAndMask(start); + if (theindex == 0) return Standard_False; + if (former.IsNull()) return Standard_False; + if (former->DynamicType() == STANDARD_TYPE(Transfer_VoidBinder)) return Standard_True; + themap(theindex) = thelastbnd; + if (theroots.Contains(theindex)) + { + TColStd_IndexedMapOfInteger aNewRoots; + for (Standard_Integer i = 1; i <= theroots.Extent(); i++) + if (theindex != theroots.FindKey(i)) + aNewRoots.Add(theroots.FindKey(i)); + + theroots.Clear(); + theroots = aNewRoots; + } + + thelastobj.Nullify(); + thelastbnd.Nullify(); + theindex = 0; + return Standard_True; +} + +//======================================================================= +//function : FindElseBind +//purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ProcessForTransient::FindElseBind(const Handle(Standard_Transient)& start) +{ + Handle(Transfer_Binder) binder = FindAndMask(start); + if (!binder.IsNull()) return binder; + binder = new Transfer_VoidBinder; + Bind(start, binder); + return binder; +} + +//======================================================================= +//function : SetMessenger +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::SetMessenger(const Handle(Message_Messenger)& messenger) +{ + if (messenger.IsNull()) + themessenger = Message::DefaultMessenger(); + else + themessenger = messenger; +} + +//======================================================================= +//function : Messenger +//purpose : +//======================================================================= +Handle(Message_Messenger) Transfer_ProcessForTransient::Messenger() const +{ + return themessenger; +} + +//======================================================================= +//function : SetTraceLevel +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::SetTraceLevel(const Standard_Integer tracelev) +{ + thetrace = tracelev; +} + +//======================================================================= +//function : TraceLevel +//purpose : +//======================================================================= +Standard_Integer Transfer_ProcessForTransient::TraceLevel() const +{ + return thetrace; +} + +//======================================================================= +//function : SendFail +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::SendFail(const Handle(Standard_Transient)& start, + const Message_Msg& amsg) +{ + AddFail(start, amsg); +} + +//======================================================================= +//function : SendWarning +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::SendWarning(const Handle(Standard_Transient)& start, + const Message_Msg& amsg) +{ + AddWarning(start, amsg); +} + +//======================================================================= +//function : SendMsg +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::SendMsg(const Handle(Standard_Transient)& start, + const Message_Msg& amsg) +{ + Handle(Transfer_Binder) binder = FindAndMask(start); + if (binder.IsNull()) + { + binder = new Transfer_VoidBinder; + Bind(start, binder); + } + // Feeds the trace: Causing rule (user messages) + if (thetrace > 0) + { + StartTrace(binder, start, thelevel, 6); + Message_Messenger::StreamBuffer aSender = themessenger->SendInfo(); + aSender << amsg.Value(); + if (amsg.IsEdited() && thetrace > 2) + aSender << " [from: " << amsg.Original() << "]"; + aSender << std::endl; + } +} + +//======================================================================= +//function : AddFail +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::AddFail(const Handle(Standard_Transient)& start, + const Standard_CString mess, + const Standard_CString orig) +{ + Handle(Transfer_Binder) binder = FindAndMask(start); + if (binder.IsNull()) + { + binder = new Transfer_VoidBinder; + Bind(start, binder); + } + binder->AddFail(mess, orig); + if (thetrace > 0) + { + StartTrace(binder, start, thelevel, 1); + Message_Messenger::StreamBuffer aSender = themessenger->SendFail(); + aSender << " --> Fail : " << mess; + if (orig[0] != '\0' && thetrace > 2) aSender << " [from: " << orig << "]"; + aSender << std::endl; + } +} + +//======================================================================= +//function : AddError +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::AddError(const Handle(Standard_Transient)& start, + const Standard_CString mess, + const Standard_CString orig) +{ + AddFail(start, mess, orig); +} + +//======================================================================= +//function : AddFail +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::AddFail(const Handle(Standard_Transient)& start, + const Message_Msg& amsg) +{ + if (amsg.IsEdited()) AddFail(start, TCollection_AsciiString(amsg.Value()).ToCString(), + TCollection_AsciiString(amsg.Original()).ToCString()); + else AddFail(start, TCollection_AsciiString(amsg.Value()).ToCString()); +} + +//======================================================================= +//function : AddWarning +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::AddWarning(const Handle(Standard_Transient)& start, + const Standard_CString mess, + const Standard_CString orig) +{ + Handle(Transfer_Binder) binder = FindAndMask(start); + if (binder.IsNull()) + { + binder = new Transfer_VoidBinder; + Bind(start, binder); + } + binder->AddWarning(mess, orig); + if (thetrace > 1) + { + StartTrace(binder, start, thelevel, 2); + Message_Messenger::StreamBuffer aSender = themessenger->SendWarning(); + aSender << " --> Warning : " << mess; + if (orig[0] != '\0' && thetrace > 2) aSender << " [from: " << orig << "]"; + aSender << std::endl; + } +} + +//======================================================================= +//function : AddWarning +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::AddWarning(const Handle(Standard_Transient)& start, + const Message_Msg& amsg) +{ + if (amsg.IsEdited()) AddWarning(start, TCollection_AsciiString(amsg.Value()).ToCString(), + TCollection_AsciiString(amsg.Original()).ToCString()); + else AddWarning(start, TCollection_AsciiString(amsg.Value()).ToCString()); +} + +//======================================================================= +//function : Mend +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::Mend(const Handle(Standard_Transient)& start, + const Standard_CString pref) +{ + Handle(Transfer_Binder) binder = FindAndMask(start); + if (binder.IsNull()) return; + Handle(Interface_Check) ach = binder->CCheck(); + ach->Mend(pref); +} + +//======================================================================= +//function : Check +//purpose : +//======================================================================= +Handle(Interface_Check) Transfer_ProcessForTransient::Check(const Handle(Standard_Transient)& start) const +{ + const Handle(Transfer_Binder)& binder = Find(start); + if (binder.IsNull()) + { + Handle(Interface_Check) check; + return check; + } + return binder->Check(); +} + +//======================================================================= +//function : BindTransient +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::BindTransient(const Handle(Standard_Transient)& start, + const Handle(Standard_Transient)& res) +{ + if (res.IsNull()) return; + Handle(Transfer_Binder) former = Find(start); + Handle(Transfer_SimpleBinderOfTransient) binder = + Handle(Transfer_SimpleBinderOfTransient)::DownCast(former); + if (!binder.IsNull()) + { + if (binder->Status() == Transfer_StatusVoid) + { + binder->SetResult(res); return; + } + } + binder = new Transfer_SimpleBinderOfTransient; + binder->SetResult(res); + if (former.IsNull()) Bind(start, binder); + else Rebind(start, binder); +} + +//======================================================================= +//function : FindTransient +//purpose : +//======================================================================= +const Handle(Standard_Transient)& Transfer_ProcessForTransient::FindTransient +(const Handle(Standard_Transient)& start) const +{ + static const Handle(Standard_Transient) aDummy; + Handle(Transfer_SimpleBinderOfTransient) binder = + Handle(Transfer_SimpleBinderOfTransient)::DownCast(Find(start)); + if (binder.IsNull()) return aDummy; + if (!binder->HasResult()) return aDummy; + return binder->Result(); +} + +//======================================================================= +//function : BindMultiple +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::BindMultiple(const Handle(Standard_Transient)& start) +{ + Handle(Transfer_Binder) binder = FindAndMask(start); + if (!binder.IsNull()) + { + if (!binder->IsKind(STANDARD_TYPE(Transfer_MultipleBinder))) + { + StartTrace(thelastbnd, start, thelevel, 4); + throw Transfer_TransferFailure("TransferProcess : BindMultiple"); + } + } + else Bind(start, new Transfer_MultipleBinder); +} + +//======================================================================= +//function : AddMultiple +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::AddMultiple(const Handle(Standard_Transient)& start, + const Handle(Standard_Transient)& res) +{ + Handle(Transfer_Binder) binder = FindAndMask(start); + Handle(Transfer_MultipleBinder) multr = + Handle(Transfer_MultipleBinder)::DownCast(binder); + if (multr.IsNull()) + { + StartTrace(binder, start, thelevel, 4); + if (binder.IsNull()) throw Transfer_TransferFailure("TransferProcess : AddMultiple, nothing bound"); + else throw Transfer_TransferFailure("TransferProcess : AddMultiple, Binder not a MultipleBinder"); + } + multr->AddResult(res); +} + +//======================================================================= +//function : FindTypedTransient +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForTransient::FindTypedTransient +(const Handle(Standard_Transient)& start, const Handle(Standard_Type)& atype, + Handle(Standard_Transient)& val) const +{ + return GetTypedTransient(Find(start), atype, val); +} + +//======================================================================= +//function : GetTypedTransient +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForTransient::GetTypedTransient +(const Handle(Transfer_Binder)& binder, const Handle(Standard_Type)& atype, + Handle(Standard_Transient)& val) const +{ + return Transfer_SimpleBinderOfTransient::GetTypedResult(binder, atype, val); +} + +//======================================================================= +//function : NbMapped +//purpose : +//======================================================================= +Standard_Integer Transfer_ProcessForTransient::NbMapped() const +{ + return themap.Extent(); +} + +//======================================================================= +//function : Mapped +//purpose : +//======================================================================= +const Handle(Standard_Transient)& Transfer_ProcessForTransient::Mapped(const Standard_Integer num) const +{ + return themap.FindKey(num); +} + +//======================================================================= +//function : MapIndex +//purpose : +//======================================================================= +Standard_Integer Transfer_ProcessForTransient::MapIndex(const Handle(Standard_Transient)& start) const +{ + return themap.FindIndex(start); +} + +//======================================================================= +//function : MapItem +//purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ProcessForTransient::MapItem(const Standard_Integer num) const +{ + Handle(Transfer_Binder) binder = themap.FindFromIndex(num); + return binder; +} + +//======================================================================= +//function : SetRoot +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::SetRoot(const Handle(Standard_Transient)& start) +{ + Standard_Integer index = MapIndex(start); + if (index == 0) + { + return; + } + + theroots.Add(index); + if (thetrace > 2) StartTrace(MapItem(index), start, thelevel, 3); +} + +//======================================================================= +//function : SetRootManagement +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::SetRootManagement(const Standard_Boolean stat) +{ + therootm = stat; +} + +//======================================================================= +//function : NbRoots +//purpose : +//======================================================================= +Standard_Integer Transfer_ProcessForTransient::NbRoots() const +{ + return theroots.Extent(); +} + +//======================================================================= +//function : Root +//purpose : +//======================================================================= +const Handle(Standard_Transient)& Transfer_ProcessForTransient::Root(const Standard_Integer num) const +{ + Standard_Integer ind = 0; + if (num > 0 && num <= theroots.Extent()) ind = theroots.FindKey(num); + return themap.FindKey(ind); +} + +//======================================================================= +//function : RootItem +//purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ProcessForTransient::RootItem(const Standard_Integer num) const +{ + Standard_Integer ind = 0; + if (num > 0 && num <= theroots.Extent()) ind = theroots.FindKey(num); + return themap.FindFromIndex(ind); +} + +//======================================================================= +//function : RootIndex +//purpose : +//======================================================================= +Standard_Integer Transfer_ProcessForTransient::RootIndex(const Handle(Standard_Transient)& start) const +{ + Standard_Integer index = MapIndex(start); + if (index == 0) return 0; + return theroots.FindIndex(index); +} + +//======================================================================= +//function : NestingLevel +//purpose : +//======================================================================= +Standard_Integer Transfer_ProcessForTransient::NestingLevel() const +{ + return thelevel; +} + +//======================================================================= +//function : ResetNestingLevel +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::ResetNestingLevel() +{ + thelevel = 0; +} + +//======================================================================= +//function : Recognize +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForTransient::Recognize(const Handle(Standard_Transient)& start) const +{ + Handle(Transfer_ActorOfProcessForTransient) actor = theactor; + // We scan the Next until we have a Result + while (!actor.IsNull()) + { + if (actor->Recognize(start)) return Standard_True; + actor = actor->Next(); + } + return Standard_False; +} + +//======================================================================= +//function : Transferring +//purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ProcessForTransient::Transferring(const Handle(Standard_Transient)& start, + const Message_ProgressRange& theProgress) +{ + Handle(Transfer_Binder) former = FindAndMask(start); + // We consider that this new Transfer request therefore corresponds to a + // additional use: note "AlreadyUsed", therefore non-modifiable result + if (!former.IsNull()) + { + if (former->HasResult()) + { + former->SetAlreadyUsed(); + return former; + } + + Message_Messenger::StreamBuffer aSender = themessenger->SendInfo(); + Transfer_StatusExec statex = former->StatusExec(); + switch (statex) + { + case Transfer_StatusInitial: + break; + case Transfer_StatusDone: + aSender << " .. and Transfer done" << std::endl; + return former; + case Transfer_StatusRun: + former->SetStatusExec(Transfer_StatusLoop); + return former; + case Transfer_StatusError: + if (thetrace) + { + aSender << " *** Transfer in Error Status :" << std::endl; + StartTrace(former, start, thelevel, 0); + } + else StartTrace(former, start, thelevel, 4); + throw Transfer_TransferFailure("TransferProcess : Transfer in Error Status"); + case Transfer_StatusLoop: + if (thetrace) + { + aSender << " *** Transfer Head of Dead Loop :" << std::endl; + StartTrace(former, start, thelevel, 0); + } + else StartTrace(former, start, thelevel, 4); + throw Transfer_TransferDeadLoop("TransferProcess : Transfer at Head of a Dead Loop"); + } + former->SetStatusExec(Transfer_StatusRun); + } + + Handle(Transfer_Binder) binder; + Standard_Boolean newbind = Standard_False; + if (theerrh) + { + Message_Messenger::StreamBuffer aSender = themessenger->SendInfo(); + + // Transfer under protection for exceptions (for notification in fact) + Standard_Integer oldlev = thelevel; + try + { + OCC_CATCH_SIGNALS + binder = TransferProduct(start, theProgress); + } + + // Exceptions to catch up on: they are not all the same + catch (Transfer_TransferDeadLoop const&) + { + if (binder.IsNull()) + { + aSender << " *** Dead Loop with no Result" << std::endl; + if (thetrace) StartTrace(binder, start, thelevel - 1, 0); + binder = new Transfer_VoidBinder; + Bind(start, binder); newbind = Standard_True; + } + else if (binder->StatusExec() == Transfer_StatusLoop) + { + if (thetrace) + { + aSender << " *** Dead Loop : Finding head of Loop :" << std::endl; + StartTrace(binder, start, thelevel - 1, 0); + } + else StartTrace(binder, start, thelevel - 1, 4); + throw Transfer_TransferFailure("TransferProcess : Head of Dead Loop"); + // In other words, we change the exception (we exit the loop) + } + else + { + if (thetrace) + { + aSender << " *** Dead Loop : Actor in Loop :" << std::endl; + StartTrace(binder, start, thelevel - 1, 0); + } + } + binder->AddFail("Transfer in dead Loop"); + thelevel = oldlev; + } + catch (Standard_Failure const& anException) + { + if (binder.IsNull()) + { + aSender << " *** Exception Raised with no Result" << std::endl; + binder = new Transfer_VoidBinder; + Bind(start, binder); newbind = Standard_True; + } + binder->AddFail("Transfer stopped by exception raising"); + if (thetrace) + { + aSender << " *** Raised : " << anException.GetMessageString() << std::endl; + StartTrace(binder, start, thelevel - 1, 4); + } + thelevel = oldlev; + } + } + + // Unprotected transfer (thus, dbx by hand in case of crash by Raise) + else binder = TransferProduct(start, theProgress); + + if (theProgress.UserBreak()) + return Handle(Transfer_Binder)(); + + if (!newbind && !binder.IsNull()) + { + if (former.IsNull()) + { + if (!IsBound(start)) Bind(start, binder); + else + { + Rebind(start, binder); + } + } + else Rebind(start, binder); + } + else + { + if (!former.IsNull()) former->SetStatusExec(Transfer_StatusDone); //+ + return Handle(Transfer_Binder)(); // Binder Null ... que faire d autre ? + } + + if (therootl >= thelevel) + { + therootl = 0; + if (therootm && binder->Status() != Transfer_StatusVoid) + { + SetRoot(start); + } + } + return thelastbnd; +} + + +//======================================================================= +//function : TransferProduct +//purpose : +//======================================================================= +Handle(Transfer_Binder) Transfer_ProcessForTransient::TransferProduct +(const Handle(Standard_Transient)& start, + const Message_ProgressRange& theProgress) +{ + thelevel++; + Handle(Transfer_Binder) binder; + Handle(Transfer_ActorOfProcessForTransient) actor = theactor; + + // We scan the Next until we have a Result + Message_ProgressScope aScope(theProgress, NULL, 1, true); + while (!actor.IsNull()) + { + if (actor->Recognize(start)) binder = actor->Transferring(start, this, aScope.Next()); + else binder.Nullify(); + if (!binder.IsNull()) break; + actor = actor->Next(); + } + if (aScope.UserBreak()) + return Handle(Transfer_Binder)(); + + if (binder.IsNull()) + { + if (thelevel > 0) thelevel--; + return binder; + } + if (therootl == 0 && binder->StatusExec() == Transfer_StatusDone) + therootl = thelevel - 1; + + if (thelevel > 0) thelevel--; + return binder; +} + +//======================================================================= +//function : Transfer +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForTransient::Transfer(const Handle(Standard_Transient)& start, + const Message_ProgressRange& theProgress) +{ + Handle(Transfer_Binder) binder = Transferring(start, theProgress); + return (!binder.IsNull()); +} + +//======================================================================= +//function : SetErrorHandle +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::SetErrorHandle(const Standard_Boolean err) +{ + theerrh = err; +} + +//======================================================================= +//function : ErrorHandle +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForTransient::ErrorHandle() const +{ + return theerrh; +} + +//======================================================================= +//function : StartTrace +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::StartTrace(const Handle(Transfer_Binder)& binder, + const Handle(Standard_Transient)& start, + const Standard_Integer level, + const Standard_Integer mode) const +{ + Message_Messenger::StreamBuffer aSender = themessenger->SendInfo(); + // ### Fail (Roots:50) -- Start start->DynamicType() + // ### Fail (Roots:50) -- Start id:#label.. Type:start->DynamicType() + if (thetrace > 3) + { // Internal to be switch when searching bug (trace >= 4) + if (mode == 1) aSender << " ### Fail"; + if (mode == 2) aSender << " ### Warning"; + if (mode == 3) aSender << " ### New Root n0 " << theroots.Extent(); + if (mode == 4) aSender << " ### Exception"; + if (mode == 5) aSender << " ### Substitution"; + if (mode == 6) aSender << " ### Information"; + if (level > 1) + aSender << " (nested)"; + if (mode >= 0 && mode != 3) + aSender << " at " << theroots.Extent() << " Roots"; + } + if (!start.IsNull()) PrintTrace(start, aSender); + + if (!binder.IsNull()) + { + Handle(Transfer_Binder) bnd = binder; + Standard_Boolean hasres = Standard_False; + while (!bnd.IsNull()) + { + if (bnd->Status() != Transfer_StatusVoid) + { + if (!hasres) + aSender << "\n --- Result Type : "; + else + aSender << " , "; + aSender << bnd->ResultTypeName(); + hasres = Standard_True; + } + bnd = bnd->NextResult(); + } + if (!hasres && mode > 2) + { + aSender << "\n --- No Result recorded"; + } + } + aSender << std::endl; +} + +//======================================================================= +//function : PrintTrace +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::PrintTrace(const Handle(Standard_Transient)& start, Standard_OStream& S) const +{ + if (!start.IsNull()) S << " Type:" << start->DynamicType()->Name(); +} + +//======================================================================= +//function : IsLooping +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForTransient::IsLooping +(const Standard_Integer alevel) const +{ + return alevel > NbMapped(); +} + +//======================================================================= +//function : RootResult +//purpose : +//======================================================================= +Transfer_IteratorOfProcessForTransient Transfer_ProcessForTransient::RootResult(const Standard_Boolean withstart) const +{ + Transfer_IteratorOfProcessForTransient iter(withstart); + Standard_Integer max = theroots.Extent(); + for (Standard_Integer j = 1; j <= max; j++) + { + Standard_Integer i = theroots.FindKey(j); + Handle(Transfer_Binder) binder = MapItem(i); + if (binder.IsNull()) continue; + if (withstart) iter.Add(binder, Mapped(i)); + else iter.Add(binder); + } + return iter; +} + +//======================================================================= +//function : CompleteResult +//purpose : +//======================================================================= +Transfer_IteratorOfProcessForTransient Transfer_ProcessForTransient::CompleteResult +(const Standard_Boolean withstart) const +{ + Transfer_IteratorOfProcessForTransient iter(withstart); + Standard_Integer max = NbMapped(); + for (Standard_Integer i = 1; i <= max; i++) + { + Handle(Transfer_Binder) binder = MapItem(i); + if (binder.IsNull()) continue; + if (withstart) iter.Add(binder, Mapped(i)); + else iter.Add(binder); + } + return iter; +} + +//======================================================================= +//function : AbnormalResult +//purpose : +//======================================================================= +Transfer_IteratorOfProcessForTransient Transfer_ProcessForTransient::AbnormalResult() const +{ + Transfer_IteratorOfProcessForTransient iter(Standard_True); + Standard_Integer max = NbMapped(); + for (Standard_Integer i = 1; i <= max; i++) + { + Handle(Transfer_Binder) binder = MapItem(i); + if (binder.IsNull()) continue; + Transfer_StatusExec statex = binder->StatusExec(); + if (statex != Transfer_StatusInitial && statex != Transfer_StatusDone) + iter.Add(binder, Mapped(i)); + } + return iter; +} + +//======================================================================= +//function : CheckList +//purpose : +//======================================================================= +Interface_CheckIterator Transfer_ProcessForTransient::CheckList +(const Standard_Boolean erronly) const +{ + Interface_CheckIterator list; + Standard_Integer num, max = NbMapped(); + for (Standard_Integer i = 1; i <= max; i++) + { + Handle(Transfer_Binder) binder = MapItem(i); + if (binder.IsNull()) continue; + Transfer_StatusExec statex = binder->StatusExec(); + Handle(Interface_Check) check = binder->Check(); + if (statex != Transfer_StatusInitial && statex != Transfer_StatusDone && + !check->HasFailed()) + check->AddFail("Transfer in Abnormal Status (!= Initial or Done)"); + if (!check->HasFailed() && (erronly || check->NbWarnings() == 0)) continue; + const Handle(Standard_Transient)& ent = Mapped(i); + num = CheckNum(ent); + if (num == 0) num = i; + check->SetEntity(ent); + list.Add(check, num); + } + return list; +} + +//======================================================================= +//function : ResultOne +//purpose : +//======================================================================= +Transfer_IteratorOfProcessForTransient Transfer_ProcessForTransient::ResultOne(const Handle(Standard_Transient)& start, + const Standard_Integer level, + const Standard_Boolean withstart) const +{ + Transfer_IteratorOfProcessForTransient iter(withstart); + Standard_Integer max = NbMapped(); + Standard_Integer ind = MapIndex(start); + if (ind == 0) return iter; + Standard_Integer i1 = (level == 0 ? ind : 1); + Standard_Integer i2 = (level == 0 ? ind : max); + Handle(TColStd_HArray1OfInteger) map = new TColStd_HArray1OfInteger(i1, i2, 0); + + for (Standard_Integer i = i1; i <= i2; i++) + { + ind = map->Value(i); + if (ind == 0) continue; + Handle(Transfer_Binder) binder = MapItem(i); + if (binder.IsNull()) continue; + if (withstart) iter.Add(binder, Mapped(ind)); + else iter.Add(binder); + } + return iter; +} + +//======================================================================= +//function : CheckListOne +//purpose : +//======================================================================= +Interface_CheckIterator Transfer_ProcessForTransient::CheckListOne +(const Handle(Standard_Transient)& start, const Standard_Integer level, + const Standard_Boolean erronly) const +{ + Interface_CheckIterator list; + Standard_Integer max = NbMapped(); + Standard_Integer num, ind = MapIndex(start); + if (ind == 0) return list; + Standard_Integer i1 = (level == 0 ? ind : 1); + Standard_Integer i2 = (level == 0 ? ind : max); + Handle(TColStd_HArray1OfInteger) map = new TColStd_HArray1OfInteger(i1, i2, 0); + + for (Standard_Integer i = i1; i <= i2; i++) + { + ind = map->Value(i); + if (ind == 0) continue; + Handle(Transfer_Binder) binder = MapItem(ind); + if (binder.IsNull()) continue; + Transfer_StatusExec statex = binder->StatusExec(); + Handle(Interface_Check) check = binder->Check(); + if (statex != Transfer_StatusInitial && statex != Transfer_StatusDone && + !check->HasFailed()) + check->AddFail("Transfer in Abnormal Status (!= Initial or Done)"); + if (!check->HasFailed() && (erronly || check->NbWarnings() == 0)) continue; + const Handle(Standard_Transient)& ent = Mapped(ind); + num = CheckNum(ent); if (num == 0) num = ind; + check->SetEntity(ent); + list.Add(check, num); + } + return list; +} + +//======================================================================= +//function : IsCheckListEmpty +//purpose : +//======================================================================= +Standard_Boolean Transfer_ProcessForTransient::IsCheckListEmpty +(const Handle(Standard_Transient)& start, const Standard_Integer level, + const Standard_Boolean erronly) const +{ + Standard_Integer max = NbMapped(); + Standard_Integer ind = MapIndex(start); + if (ind == 0) return Standard_False; + Standard_Integer i1 = (level == 0 ? ind : 1); + Standard_Integer i2 = (level == 0 ? ind : max); + Handle(TColStd_HArray1OfInteger) map = new TColStd_HArray1OfInteger(i1, i2, 0); + + for (Standard_Integer i = i1; i <= i2; i++) + { + ind = map->Value(i); + if (ind == 0) continue; + Handle(Transfer_Binder) binder = MapItem(ind); + if (binder.IsNull()) continue; + + Transfer_StatusExec statex = binder->StatusExec(); + Handle(Interface_Check) check = binder->Check(); + if (statex != Transfer_StatusInitial && statex != Transfer_StatusDone) + return Standard_False; + if (check->HasFailed() || (!erronly && check->NbWarnings() > 0)) return Standard_False; + } + return Standard_True; +} + +//======================================================================= +//function : RemoveResult +//purpose : +//======================================================================= +void Transfer_ProcessForTransient::RemoveResult(const Handle(Standard_Transient)& start, + const Standard_Integer level, + const Standard_Boolean /*compute*/) +{ + //if (compute) ComputeScopes(); + Standard_Integer max = NbMapped(); + Standard_Integer ind = MapIndex(start); + if (ind == 0) return; + Standard_Integer i1 = (level == 0 ? ind : 1); + Standard_Integer i2 = (level == 0 ? ind : max); + Handle(TColStd_HArray1OfInteger) map = new TColStd_HArray1OfInteger(i1, i2, 0); + + Standard_Integer i; + for (i = i1; i <= i2; i++) + { + ind = map->Value(i); + if (ind == 0) continue; + Handle(Transfer_Binder) binder = MapItem(ind); + if (binder.IsNull()) continue; + } +} + +//======================================================================= +//function : CheckNum +//purpose : +//======================================================================= +Standard_Integer Transfer_ProcessForTransient::CheckNum(const Handle(Standard_Transient)&) const +{ + return 0; +} -#define TheStart Handle(Standard_Transient) -#define TheStart_hxx -#define TheMapHasher TColStd_MapTransientHasher -#define TheMapHasher_hxx -#define Handle_TheList Handle(TColStd_HSequenceOfTransient) -#define TheList TColStd_HSequenceOfTransient -#define TheList_hxx -#define Transfer_TransferMap Transfer_TransferMapOfProcessForTransient -#define Transfer_TransferMap_hxx -#define Transfer_Iterator Transfer_IteratorOfProcessForTransient -#define Transfer_Iterator_hxx -#define Transfer_Actor Transfer_ActorOfProcessForTransient -#define Transfer_Actor_hxx -#define Handle_Transfer_Actor Handle(Transfer_ActorOfProcessForTransient) -#define Transfer_TransferProcess Transfer_ProcessForTransient -#define Transfer_TransferProcess_hxx -#define Handle_Transfer_TransferProcess Handle(Transfer_ProcessForTransient) -#include diff --git a/src/Transfer/Transfer_TransferMapOfProcessForTransient.hxx b/src/Transfer/Transfer_TransferMapOfProcessForTransient.hxx index 94128b57cc..4d26530b60 100644 --- a/src/Transfer/Transfer_TransferMapOfProcessForTransient.hxx +++ b/src/Transfer/Transfer_TransferMapOfProcessForTransient.hxx @@ -18,9 +18,8 @@ #define _Transfer_TransferMapOfProcessForTransient_HeaderFile #include -#include #include -typedef NCollection_IndexedDataMap Transfer_TransferMapOfProcessForTransient; +typedef NCollection_IndexedDataMap Transfer_TransferMapOfProcessForTransient; #endif // _Transfer_TransferMapOfProcessForTransient_HeaderFile diff --git a/src/Transfer/Transfer_TransferProcess.gxx b/src/Transfer/Transfer_TransferProcess.gxx deleted file mode 100644 index 80ce908e43..0000000000 --- a/src/Transfer/Transfer_TransferProcess.gxx +++ /dev/null @@ -1,1556 +0,0 @@ -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -// DCE 21.01.99 S3767 Display original messages only -// if the level is greater than 2 - -//#include -// Class generique - -// TheStart est suppose Handle(Standard_Transient) ou (Transfer_Finder) -// Il doit offrir : "==" , .IsNull() , ->DynamicType() - -#include -#include - -#include -#include -#include -#include - -#include -#include -#include -#include -#include -#include - -#include -#include -#include -#include - - -//#define TRANSLOG // debug - -static Handle(Standard_Transient) nultrans; // pour retour const&(Null) ... -static Handle(Transfer_Binder) nulbinder; - - -//======================================================================= -//function : Transfer_TransferProcess -//purpose : -//======================================================================= - -Transfer_TransferProcess::Transfer_TransferProcess (const Standard_Integer nb) - : themap (nb) -{ - theerrh = Standard_True; - therootm = Standard_False; - thelevel = 0; therootl = 0; - themessenger = Message::DefaultMessenger(); - thetrace = 0; -// theroots = new TColStd_HSequenceOfInteger (); - theindex = 0; -} - - -//======================================================================= -//function : Transfer_TransferProcess -//purpose : -//======================================================================= - -Transfer_TransferProcess::Transfer_TransferProcess(const Handle(Message_Messenger)& messenger, - const Standard_Integer nb) - : themap (nb) -{ - theerrh = Standard_True; - therootm = Standard_False; - thelevel = 0; therootl = 0; - SetMessenger (messenger); - thetrace = 1; -// theroots = new TColStd_HSequenceOfInteger (); - theindex = 0; -} - - void Transfer_TransferProcess::Clear () -{ - thelevel = 0; therootl = 0; - theroots.Clear(); - themap.Clear(); - theindex = 0; thelastobj.Nullify(); thelastbnd.Nullify(); -} - - void Transfer_TransferProcess::Clean () -{ - Standard_Integer i, nb = NbMapped(); - Standard_Integer j,unb = 0; - for (i = 1; i <= nb; i ++) { - if (themap(i).IsNull()) unb ++; - } - if (unb == 0) return; - -// Refaire la map -> decalages - TColStd_Array1OfInteger unbs (1,nb); unbs.Init(0); - Transfer_TransferMap newmap (nb*2); - for (i = 1; i <= nb; i ++) { - TheStart ent = Mapped(i); - Handle(Transfer_Binder) bnd = MapItem(i); - if (bnd.IsNull()) continue; - j = newmap.Add (ent,bnd); - unbs.SetValue (i,j); - } - themap.Assign (newmap); - - // Update La liste des racines - TColStd_IndexedMapOfInteger aNewRoots; - for( i=1; i<= theroots.Extent(); i++ ) { - j = theroots.FindKey(i); - Standard_Integer k = unbs.Value(j); - if ( k ) aNewRoots.Add ( k ); - } - theroots.Clear(); - theroots = aNewRoots; - -// Le reste : nettoyage - thelastobj.Nullify(); - thelastbnd.Nullify(); - theindex = 0; -} - - -//======================================================================= -//function : Resize -//purpose : -//======================================================================= - -void Transfer_TransferProcess::Resize (const Standard_Integer nb) -{ - if (nb > themap.NbBuckets()) themap.ReSize(nb); -} - - -//======================================================================= -//function : SetActor -//purpose : -//======================================================================= - -void Transfer_TransferProcess::SetActor(const Handle(Transfer_Actor)& actor) -{ - if (theactor == actor) return; - if (theactor.IsNull()) theactor = actor; - else if (actor.IsNull()) theactor = actor; // declenche RAZ - else if (theactor->IsLast()) { actor->SetNext(theactor); theactor = actor; } - else theactor->SetNext(actor); -} - - -//======================================================================= -//function : Actor -//purpose : -//======================================================================= - -Handle(Transfer_Actor) Transfer_TransferProcess::Actor () const -{ - return theactor; -} - - -// ######################################################################## -// .... MAPPING .... - -// ## ## ## Actions Generales sur Binders ## ## ## -// ## ## ## Consultations ## ## ## - - -// ## ## Find ## ## - -//======================================================================= -//function : Find -//purpose : -//======================================================================= - -Handle(Transfer_Binder) Transfer_TransferProcess::Find (const TheStart& start) const -// const Standard_Integer categ) const -{ - if (thelastobj == start) { - //if (theindex > 0) return thelastbnd->Search(categ); //skl - if (theindex > 0) return thelastbnd; //skl - } - Standard_Integer index = themap.FindIndex (start); - if (index > 0) { - const Handle(Transfer_Binder)& binder = themap.FindFromIndex(index); - //if (binder.IsNull()) //skl - return binder; - //return binder->Search(categ); //skl - } - return nulbinder; -} - -// ## ## IsBound ## ## - -//======================================================================= -//function : IsBound -//purpose : -//======================================================================= - -Standard_Boolean Transfer_TransferProcess::IsBound(const TheStart& start) const -// const Standard_Integer categ) const -{ - Handle(Transfer_Binder) binder = Find(start); //,categ); skl - if (binder.IsNull()) return Standard_False; - return binder->HasResult(); -} - -// ## ## IsAlreadyUsed ## ## - -//======================================================================= -//function : IsAlreadyUsed -//purpose : -//======================================================================= - -Standard_Boolean Transfer_TransferProcess::IsAlreadyUsed(const TheStart& start) const -// const Standard_Integer categ) const -{ - Handle(Transfer_Binder) binder = Find(start); //,categ); skl - if (binder.IsNull()) { - StartTrace (binder,start,thelevel,4); - throw Transfer_TransferFailure("TransferProcess : IsAlreadyUsed, transfer not done cannot be used..."); - } - return (binder->Status() == Transfer_StatusUsed); -} - - -// ## ## FindAndMask (private) ## ## - -//======================================================================= -//function : FindAndMask -//purpose : -//======================================================================= - -Handle(Transfer_Binder) Transfer_TransferProcess::FindAndMask(const TheStart& start) -// const Standard_Integer categ) -{ - if (thelastobj == start) { - if (theindex > 0) return thelastbnd; //skl ->Search(categ); - } - thelastobj = start; - theindex = themap.FindIndex (start); - if (theindex > 0) thelastbnd = themap.FindFromIndex(theindex); - else thelastbnd.Nullify(); - //if (thelastbnd.IsNull()) skl - return thelastbnd; - //return thelastbnd->Search(categ); //skl -} - - -// ## ## ## Modifications ## ## ## - - -//======================================================================= -//function : Bind -//purpose : -//======================================================================= - -void Transfer_TransferProcess::Bind (const TheStart& start, - const Handle(Transfer_Binder)& binder) -// const Standard_Integer categ) -{ - if (binder.IsNull()) return; - Handle(Transfer_Binder) former = FindAndMask(start);//,categ);skl - if (!former.IsNull()) { -// On admet VoidBinder : alors on reprend son Check - if (former->DynamicType() == STANDARD_TYPE(Transfer_VoidBinder)) { - binder->Merge(former); - //binder->SetCategory(categ); //skl - themap(theindex) = binder; // Substitution - } - else if (former->Status() == Transfer_StatusUsed) { - StartTrace (former,start,thelevel,4); - throw Transfer_TransferFailure("TransferProcess : Bind, already Bound"); - } - else { - if (thetrace > 2) StartTrace (former,start,thelevel,5); - binder->CCheck()->GetMessages (former->Check()); - } - } - //binder->SetCategory(categ); //skl - if (theindex == 0 || thelastbnd.IsNull()) { - if (theindex == 0) theindex = themap.Add(start,binder); // Nouveau - else themap(theindex) = binder; // idem en fait - thelastbnd = binder; - } - else { //skl - //binder->AddResult(thelastbnd); - thelastbnd = binder; - themap(theindex) = binder; - } -/*skl else if (thelastbnd->Category() == categ) { // Substitue cette categorie - binder->Next(Standard_False)->SetNext(thelastbnd->Next(Standard_True),Standard_True); - thelastbnd = binder; - themap(theindex) = binder; - } else { - thelastbnd->AddNext (binder,categ,Standard_True); - } */ -} - - -//======================================================================= -//function : Rebind -//purpose : -//======================================================================= - -void Transfer_TransferProcess::Rebind (const TheStart& start, - const Handle(Transfer_Binder)& binder) -// const Standard_Integer categ) -{ - Bind(start,binder); //,categ);skl - // entre les deux, les differences allaient s amenuisant - // au debut, on criait si pas encore Bound (idiot) - // ne restait plus comme difference que le test StatusUsed sur Rebind, - // tandis que Bind refusait des lors qu il y avait un resultat - // -> a present, Bind s aligne sur Rebind -} - - -//======================================================================= -//function : Unbind -//purpose : -//======================================================================= - -Standard_Boolean Transfer_TransferProcess::Unbind(const TheStart& start) -// const Standard_Integer categ) -{ - Handle(Transfer_Binder) former = FindAndMask(start);//,categ);skl - if (theindex == 0) return Standard_False; - if (former.IsNull()) return Standard_False; - if (former->DynamicType() == STANDARD_TYPE(Transfer_VoidBinder)) return Standard_True; - //const Interface_Check& ach = thelastbnd->Check(); - //Handle(Transfer_Binder) newbinder = thelastbnd->RemoveNext(categ);skl - //if (newbinder != thelastbnd)skl - themap(theindex) = thelastbnd;// = newbinder;skl - if(theroots.Contains(theindex)) { - TColStd_IndexedMapOfInteger aNewRoots; - for(Standard_Integer i = 1; i <= theroots.Extent(); i++) - if(theindex!= theroots.FindKey(i)) - aNewRoots.Add(theroots.FindKey(i)); - - theroots.Clear(); - theroots = aNewRoots; - } - - thelastobj.Nullify(); - thelastbnd.Nullify(); - theindex = 0; - return Standard_True; -} - - -//======================================================================= -//function : FindElseBind -//purpose : -//======================================================================= - -Handle(Transfer_Binder) Transfer_TransferProcess::FindElseBind(const TheStart& start) -// const Standard_Integer categ) -{ - Handle(Transfer_Binder) binder = FindAndMask (start);//,categ);skl - if (!binder.IsNull()) return binder; - binder = new Transfer_VoidBinder; - Bind(start,binder);//,categ);skl - return binder; -} - - -// ## ## ## Messages associes ## ## ## - -//======================================================================= -//function : SetMessenger -//purpose : -//======================================================================= - -void Transfer_TransferProcess::SetMessenger (const Handle(Message_Messenger)& messenger) -{ - if ( messenger.IsNull() ) - themessenger = Message::DefaultMessenger(); - else - themessenger = messenger; -} - -//======================================================================= -//function : Messenger -//purpose : -//======================================================================= - -Handle(Message_Messenger) Transfer_TransferProcess::Messenger () const -{ - return themessenger; -} - -//======================================================================= -//function : SetTraceLevel -//purpose : -//======================================================================= - -void Transfer_TransferProcess::SetTraceLevel (const Standard_Integer tracelev) -{ - thetrace = tracelev; -} - -//======================================================================= -//function : TraceLevel -//purpose : -//======================================================================= - -Standard_Integer Transfer_TransferProcess::TraceLevel () const -{ - return thetrace; -} - -//======================================================================= -//function : SendFail -//purpose : -//======================================================================= - -void Transfer_TransferProcess::SendFail(const TheStart& start, - const Message_Msg& amsg) -{ - AddFail(start,amsg); -} - - -//======================================================================= -//function : SendWarning -//purpose : -//======================================================================= - -void Transfer_TransferProcess::SendWarning(const TheStart& start, - const Message_Msg& amsg) -{ - AddWarning(start,amsg); -} - - -//======================================================================= -//function : SendMsg -//purpose : -//======================================================================= - -void Transfer_TransferProcess::SendMsg(const TheStart& start, - const Message_Msg& amsg) -{ - Handle(Transfer_Binder) binder = FindAndMask(start); - if (binder.IsNull()) { - binder = new Transfer_VoidBinder; - Bind (start,binder); - } - // Alimente la trace : Regle causant (user messages) - if (thetrace > 0) { - StartTrace (binder,start,thelevel,6); - Message_Messenger::StreamBuffer aSender = themessenger->SendInfo(); - aSender << amsg.Value(); - if (amsg.IsEdited()&&thetrace>2) - aSender << " [from: " << amsg.Original() << "]"; - aSender << std::endl; - } -} - - -//======================================================================= -//function : AddFail -//purpose : -//======================================================================= - -void Transfer_TransferProcess::AddFail(const TheStart& start, - const Standard_CString mess, - const Standard_CString orig) -{ - Handle(Transfer_Binder) binder = FindAndMask(start); - if (binder.IsNull()) { - binder = new Transfer_VoidBinder; - Bind (start,binder); - } - binder->AddFail (mess,orig); - if (thetrace > 0) { - StartTrace (binder,start,thelevel,1); - Message_Messenger::StreamBuffer aSender = themessenger->SendFail(); - aSender << " --> Fail : " << mess; - if (orig[0] != '\0'&&thetrace>2) aSender << " [from: " << orig << "]"; - aSender << std::endl; - } -} - - -//======================================================================= -//function : AddError -//purpose : -//======================================================================= - -void Transfer_TransferProcess::AddError(const TheStart& start, - const Standard_CString mess, - const Standard_CString orig) -{ - AddFail (start,mess,orig); -} - - -//======================================================================= -//function : AddFail -//purpose : -//======================================================================= - -void Transfer_TransferProcess::AddFail(const TheStart& start, - const Message_Msg& amsg) -{ - if (amsg.IsEdited()) AddFail (start,TCollection_AsciiString(amsg.Value()).ToCString(), - TCollection_AsciiString(amsg.Original()).ToCString()); - else AddFail (start,TCollection_AsciiString(amsg.Value()).ToCString()); -} - - -//======================================================================= -//function : AddWarning -//purpose : -//======================================================================= - -void Transfer_TransferProcess::AddWarning(const TheStart& start, - const Standard_CString mess, - const Standard_CString orig) -{ - Handle(Transfer_Binder) binder = FindAndMask(start); - if (binder.IsNull()) { - binder = new Transfer_VoidBinder; - Bind (start,binder); - } - binder->AddWarning(mess,orig); - if (thetrace > 1) { - StartTrace (binder,start,thelevel,2); - Message_Messenger::StreamBuffer aSender = themessenger->SendWarning(); - aSender << " --> Warning : " << mess; - if (orig[0] != '\0'&&thetrace>2) aSender << " [from: " << orig << "]"; - aSender << std::endl; - } -} - - -//======================================================================= -//function : AddWarning -//purpose : -//======================================================================= - -void Transfer_TransferProcess::AddWarning(const TheStart& start, - const Message_Msg& amsg) -{ - if (amsg.IsEdited()) AddWarning (start,TCollection_AsciiString(amsg.Value()).ToCString(), - TCollection_AsciiString(amsg.Original()).ToCString()); - else AddWarning (start,TCollection_AsciiString(amsg.Value()).ToCString()); -} - - -//======================================================================= -//function : Mend -//purpose : -//======================================================================= - -void Transfer_TransferProcess::Mend(const TheStart& start, - const Standard_CString pref) -{ - Handle(Transfer_Binder) binder = FindAndMask(start); - if (binder.IsNull()) return; // rien a faire ... - Handle(Interface_Check) ach = binder->CCheck(); - ach->Mend (pref); -} - - -//======================================================================= -//function : Check -//purpose : -//======================================================================= - -Handle(Interface_Check) Transfer_TransferProcess::Check(const TheStart& start) const -{ - const Handle(Transfer_Binder)& binder = Find(start); - if (binder.IsNull()) { - Handle(Interface_Check) check; - return check; - } - return binder->Check(); -} - -/*skl -void Transfer_TransferProcess::AddCaseName(const TheStart& start, - const Standard_CString casename) -{ - AddCaseValue (start, new TCollection_HAsciiString (casename)); -} - - -void Transfer_TransferProcess::AddCaseValue(const TheStart& start, - const Handle(Standard_Transient)& caseval) -{ - Handle(Transfer_Binder) binder = FindAndMask(start); - if (binder.IsNull()) { - binder = new Transfer_VoidBinder; - Bind (start,binder); - } - binder->AddCaseValue (caseval); -} - - -Handle(TColStd_HSequenceOfTransient) Transfer_TransferProcess::CaseList - (const TheStart& start) const -{ - Handle(TColStd_HSequenceOfTransient) list; - const Handle(Transfer_Binder)& binder = Find(start); - if (binder.IsNull()) return list; - return binder->CaseList(); -} - -Standard_Integer Transfer_TransferProcess::NextItemWithAttribute - (const Standard_CString name, const Standard_Integer num0) const -{ - Standard_Integer num, nb = NbMapped(); - for (num = num0+1; num <= nb; num ++) { - Handle(Transfer_Binder) bnd = MapItem (num); - if (bnd.IsNull()) continue; - if (!bnd->Attribute(name).IsNull()) return num; - } - return 0; -} - - -Interface_ParamType Transfer_TransferProcess::AttributeType - (const Standard_CString name) const -{ - Interface_ParamType aty, res = Interface_ParamVoid; - Standard_Integer num, nb = NbMapped(); - for (num = 1; num <= nb; num ++) { - Handle(Transfer_Binder) bnd = MapItem (num); - if (bnd.IsNull()) continue; - aty = bnd->AttributeType(name); - if (aty == Interface_ParamVoid) continue; - if (res == Interface_ParamVoid) res = aty; - else if (res != aty) return Interface_ParamMisc; - } - return res; -} - -Handle(Dico_DictionaryOfInteger) Transfer_TransferProcess::Attributes - (const Standard_CString rootname) const -{ - Handle(Dico_DictionaryOfInteger) list = new Dico_DictionaryOfInteger; - Standard_Integer num, nb = NbMapped(); - for (num = 1; num <= nb; num ++) { - Handle(Transfer_Binder) bnd = MapItem (num); - if (bnd.IsNull()) continue; - Handle(Dico_DictionaryOfTransient) atr = bnd->AttrList(); - if (atr.IsNull()) continue; - Dico_IteratorOfDictionaryOfTransient iatr(atr,rootname); - for (; iatr.More(); iatr.Next()) { - TCollection_AsciiString name = iatr.Name(); - Standard_Boolean deja; - Standard_Integer& nbval = list->NewItem (name.ToCString(),deja); - if (!deja) nbval = 0; - nbval ++; - } - - } - return list; -} -skl*/ - - -// ## ## ## Actions sur Types Privilegies ## ## ## -// ## ## ## (Transient) ## ## ## - -// Bind associe un objet a un objet resultat; or la Map associe un Objet a un -// Binder (qui designe son resultat) -// *Transient travaillent avec un SimpleBinderOfTransient -// si deja la, on considere son resultat -// sinon, on cree un Binder du bon type - - -//======================================================================= -//function : BindTransient -//purpose : -//======================================================================= - -void Transfer_TransferProcess::BindTransient(const TheStart& start, - const Handle(Standard_Transient)& res) -// const Standard_Integer categ) -{ - if (res.IsNull()) return; - Handle(Transfer_Binder) former = Find(start);//,categ);skl - Handle(Transfer_SimpleBinderOfTransient) binder = - Handle(Transfer_SimpleBinderOfTransient)::DownCast(former); -// Binding sur place ? - if (!binder.IsNull()) { - if (binder->Status() == Transfer_StatusVoid) { binder->SetResult(res); return; } - } -// Sinon, refaire - binder = new Transfer_SimpleBinderOfTransient; - binder->SetResult (res); - if (former.IsNull()) Bind(start,binder);//,categ);skl - else Rebind(start,binder);//,categ);skl -} - - -//======================================================================= -//function : FindTransient -//purpose : -//======================================================================= - -const Handle(Standard_Transient)& Transfer_TransferProcess::FindTransient - (const TheStart& start) const -{ - Handle(Transfer_SimpleBinderOfTransient) binder = - Handle(Transfer_SimpleBinderOfTransient)::DownCast(Find(start)); - if (binder.IsNull()) return nultrans; - if (!binder->HasResult()) return nultrans; - return binder->Result(); -} - - -// Binding Multiple : D abord le declarer par BindMultiple (si pas deja fait) -// Puis ajouter les termes par AddMultiple - -//======================================================================= -//function : BindMultiple -//purpose : -//======================================================================= - -void Transfer_TransferProcess::BindMultiple(const TheStart& start) -// const Standard_Integer categ) -{ - Handle(Transfer_Binder) binder = FindAndMask (start);//,categ);skl - if (!binder.IsNull()) { - if (!binder->IsKind(STANDARD_TYPE(Transfer_MultipleBinder))) { - StartTrace (thelastbnd,start,thelevel,4); - throw Transfer_TransferFailure("TransferProcess : BindMultiple"); - } - } - else Bind(start,new Transfer_MultipleBinder);//,categ);skl -} - - -//======================================================================= -//function : AddMultiple -//purpose : -//======================================================================= - -void Transfer_TransferProcess::AddMultiple(const TheStart& start, - const Handle(Standard_Transient)& res) -// const Standard_Integer categ) -{ - Handle(Transfer_Binder) binder = FindAndMask(start);//,categ);skl - Handle(Transfer_MultipleBinder) multr = - Handle(Transfer_MultipleBinder)::DownCast(binder); - if (multr.IsNull()) { - StartTrace (binder,start,thelevel,4); - if (binder.IsNull()) throw Transfer_TransferFailure("TransferProcess : AddMultiple, nothing bound"); - else throw Transfer_TransferFailure("TransferProcess : AddMultiple, Binder not a MultipleBinder"); - } - multr->AddResult(res); -} - - -//======================================================================= -//function : FindTypedTransient -//purpose : -//======================================================================= - -Standard_Boolean Transfer_TransferProcess::FindTypedTransient - (const TheStart& start, const Handle(Standard_Type)& atype, - Handle(Standard_Transient)& val) const -{ - return GetTypedTransient (Find(start),atype,val); -} - - -//======================================================================= -//function : GetTypedTransient -//purpose : -//======================================================================= - -Standard_Boolean Transfer_TransferProcess::GetTypedTransient - (const Handle(Transfer_Binder)& binder, const Handle(Standard_Type)& atype, - Handle(Standard_Transient)& val) const -{ - return Transfer_SimpleBinderOfTransient::GetTypedResult(binder,atype,val); -} - - -// ## ## ## ## ## Acces Atomique ## ## ## ## ## -// (ne gere pas le scope mais donne acces aux categories) - -//======================================================================= -//function : NbMapped -//purpose : -//======================================================================= - -Standard_Integer Transfer_TransferProcess::NbMapped () const -{ - return themap.Extent(); -} - - -//======================================================================= -//function : Mapped -//purpose : -//======================================================================= - -const TheStart& Transfer_TransferProcess::Mapped(const Standard_Integer num) const -{ - return themap.FindKey(num); -} - - -//======================================================================= -//function : MapIndex -//purpose : -//======================================================================= - -Standard_Integer Transfer_TransferProcess::MapIndex(const TheStart& start) const -{ - return themap.FindIndex(start); -} - - -//======================================================================= -//function : MapItem -//purpose : -//======================================================================= - -Handle(Transfer_Binder) Transfer_TransferProcess::MapItem(const Standard_Integer num) const -// const Standard_Integer categ) const -{ - Handle(Transfer_Binder) binder = themap.FindFromIndex(num); - //sklif (binder.IsNull()) - return binder; - //sklreturn binder->Search (categ); -} - - -// ######################################################################## -// .... ROOT MANAGEMENT .... - -//======================================================================= -//function : SetRoot -//purpose : -//======================================================================= - -void Transfer_TransferProcess::SetRoot (const TheStart& start) -{ - Standard_Integer index = MapIndex(start); - if (index == 0) { - //StartTrace (thelastbnd,start,thelevel,4); - //throw Transfer_TransferFailure("TransferProcess : SetRoot"); - return; - } - - theroots.Add(index); - if (thetrace > 2) StartTrace (MapItem(index),start,thelevel,3); -} - - -//======================================================================= -//function : SetRootManagement -//purpose : -//======================================================================= - -void Transfer_TransferProcess::SetRootManagement(const Standard_Boolean stat) -{ - therootm = stat; -} - - -//======================================================================= -//function : NbRoots -//purpose : -//======================================================================= - -Standard_Integer Transfer_TransferProcess::NbRoots () const -{ - return theroots.Extent(); -} - - -//======================================================================= -//function : Root -//purpose : -//======================================================================= - -const TheStart& Transfer_TransferProcess::Root(const Standard_Integer num) const -{ - Standard_Integer ind = 0; - if (num > 0 && num <= theroots.Extent()) ind = theroots.FindKey(num); - return themap.FindKey (ind); -} - - -//======================================================================= -//function : RootItem -//purpose : -//======================================================================= - -Handle(Transfer_Binder) Transfer_TransferProcess::RootItem(const Standard_Integer num) const -// const Standard_Integer categ) const -{ - Standard_Integer ind = 0; - if (num > 0 && num <= theroots.Extent()) ind = theroots.FindKey(num); - return themap.FindFromIndex(ind);//->Search(categ);skl -} - - -//======================================================================= -//function : RootIndex -//purpose : -//======================================================================= - -Standard_Integer Transfer_TransferProcess::RootIndex(const TheStart& start) const -{ - Standard_Integer index = MapIndex(start); - if (index == 0) return 0; - return theroots.FindIndex(index); -} - - -//======================================================================= -//function : NestingLevel -//purpose : -//======================================================================= - -Standard_Integer Transfer_TransferProcess::NestingLevel () const -{ - return thelevel; -} - - -//======================================================================= -//function : ResetNestingLevel -//purpose : -//======================================================================= - -void Transfer_TransferProcess::ResetNestingLevel () -{ - thelevel = 0; -} - - -// ######################################################################## -// .... SCOPE MANAGEMENT .... - - -//====================================================================== -//Purpose : gka TRJ9 for writing SDR for solid -// Check if binder has already been bound to the result binder. -//====================================================================== - -// static Standard_Boolean Contains(const Handle(Transfer_Binder)& resbinder, -// const Handle(Transfer_Binder)& addbinder) -// { -// Handle(Transfer_Binder) tmpbind = resbinder; -// for ( ; ! tmpbind.IsNull(); tmpbind = tmpbind->NextResult() ) -// if ( tmpbind == addbinder ) return Standard_True; -// return Standard_False; -// } - -// ######################################################################## -// .... AUTOMATISMES DE TRANSFERT .... - -// ## ## ## ## ## Fonctions de Base ## ## ## ## ## - - -//======================================================================= -//function : Recognize -//purpose : -//======================================================================= - -Standard_Boolean Transfer_TransferProcess::Recognize(const TheStart& start) const -{ - Handle(Transfer_Actor) actor = theactor; - // On balaie les Next jusqu a avoir un Resultat - while (!actor.IsNull()) { - if (actor->Recognize (start)) return Standard_True; - actor = actor->Next(); - } - return Standard_False; -} - - -//======================================================================= -//function : Transferring -//purpose : -//======================================================================= - -Handle(Transfer_Binder) Transfer_TransferProcess::Transferring(const TheStart& start, - const Message_ProgressRange& theProgress) -{ - // Map deja alimentee ? - Handle(Transfer_Binder) former = FindAndMask(start); - - // .... Transfert deja effectue avec Resultat ? .... - - // On considere que cette nouvelle demande de Transfert correspond donc a une - // utilisation en plus : noter "AlreadyUsed", donc resultat non modifiable - if (!former.IsNull()) { - if (former->HasResult()) { - former->SetAlreadyUsed(); - return former; - } - //} - - // .... Etat Initial : peut-etre deja fait ... ou infaisable ! - - Message_Messenger::StreamBuffer aSender = themessenger->SendInfo(); - //if (!former.IsNull()) { - Transfer_StatusExec statex = former->StatusExec(); - switch (statex) { - case Transfer_StatusInitial : // Transfert prepare a faire - break; - case Transfer_StatusDone : // Transfert deja fait -//#ifdef TRANSLOG - aSender << " .. and Transfer done" << std::endl; -//#endif -// if (former->HasResult()) former->SetAlreadyUsed(); - return former; - case Transfer_StatusRun : // ca y est, on boucle - former->SetStatusExec(Transfer_StatusLoop); - return former; - case Transfer_StatusError : // pas propre, ca ... - if (thetrace) { - aSender << " *** Transfer in Error Status :" << std::endl; - StartTrace (former, start, thelevel,0); -// (*themessenger->Out()) << flush; - } - else StartTrace (former, start,thelevel,4); - throw Transfer_TransferFailure("TransferProcess : Transfer in Error Status"); - case Transfer_StatusLoop : // la boucle est bouclee ... - if (thetrace) { - aSender << " *** Transfer Head of Dead Loop :" << std::endl; - StartTrace (former, start, thelevel,0); -// (*themessenger->Out()) << flush; - } - else StartTrace (former, start,thelevel,4); - throw Transfer_TransferDeadLoop("TransferProcess : Transfer at Head of a Dead Loop"); - } -#ifdef TRANSLOG - std::cout << "Transfer,level "<SetStatusExec(Transfer_StatusRun); - } -#ifdef TRANSLOG - std::cout << " GO .." << std::endl; -#endif - - Handle(Transfer_Binder) binder; - Standard_Boolean newbind = Standard_False; - if (theerrh) { - Message_Messenger::StreamBuffer aSender = themessenger->SendInfo(); - - // Transfert sous protection pour les exceptions (pour notification en fait) - Standard_Integer oldlev = thelevel; - try { - OCC_CATCH_SIGNALS - binder = TransferProduct(start, theProgress); - } - - // ... Exceptions a Rattraper : elles ne se ressemblent pas toutes ... ! - catch (Transfer_TransferDeadLoop const&) { - if (binder.IsNull()) { - aSender << " *** Dead Loop with no Result" << std::endl; - if (thetrace) StartTrace (binder, start, thelevel-1,0); - binder = new Transfer_VoidBinder; - Bind (start,binder); newbind = Standard_True; - } else if (binder->StatusExec() == Transfer_StatusLoop) { - if (thetrace) { - aSender << " *** Dead Loop : Finding head of Loop :" << std::endl; - StartTrace (binder, start, thelevel-1,0); - } - else StartTrace (binder, start,thelevel-1,4); - throw Transfer_TransferFailure("TransferProcess : Head of Dead Loop"); -// Autrement dit, on change d exception (on est sorti de la boucle) - } else { - if (thetrace) { - aSender << " *** Dead Loop : Actor in Loop :" << std::endl; - StartTrace (binder, start, thelevel-1,0); - } - } - binder->AddFail("Transfer in dead Loop"); - thelevel = oldlev; - } - catch (Standard_Failure const& anException) { - if (binder.IsNull()) { - aSender << " *** Exception Raised with no Result" << std::endl; - binder = new Transfer_VoidBinder; - Bind (start,binder); newbind = Standard_True; - } - binder->AddFail("Transfer stopped by exception raising"); - if (thetrace) { - aSender << " *** Raised : " << anException.GetMessageString() << std::endl; - StartTrace (binder, start, thelevel-1,4); - } - thelevel = oldlev; - } - } - -// Transfert non protege (ainsi, dbx a la main en cas de plantage par Raise) - else binder = TransferProduct(start, theProgress); - - if (theProgress.UserBreak()) - return Handle(Transfer_Binder)(); - -// .... Conclusion : Noter dans la Map .... - - if (!newbind && !binder.IsNull()) { - if (former.IsNull()) { -// Peut-etre a fait lui meme Bind ... verifier sinon le faire - if (!IsBound(start)) Bind(start,binder); // resultat = categorie 0 - else { // gka TRJ9 for writing SDR for solid -// Handle(Transfer_Binder) tmpbind = Find(start); -// if(!Contains(binder,tmpbind)) -// binder->AddResult(tmpbind); - Rebind(start,binder); // test_pattern.sat - } - } - else Rebind(start,binder); -// (du coup, vaut ) -#ifdef TRANSLOG - std::cout << " ... OK" << std::endl; -#endif - } - else { - //= by ABV: 5 Oct 97: nothing generated, but former can be in run state - drop it - //= ASK: may be set it to StatusInitial ? - if ( ! former.IsNull() ) former->SetStatusExec ( Transfer_StatusDone ); //+ - return nulbinder; // Binder Null ... que faire d autre ? - } - -// .... Gerer les Racines (si prevu) .... - - if (therootl >= thelevel) { - therootl = 0; - if (therootm && binder->Status() != Transfer_StatusVoid) { - SetRoot (start); - } - } - return thelastbnd; -} - -// ## ## TransferProduct : Action proprement dite ## ## - - Handle(Transfer_Binder) Transfer_TransferProcess::TransferProduct - (const TheStart& start, - const Message_ProgressRange& theProgress) -{ - thelevel ++; // si decremente et == 0, transfert racine - Handle(Transfer_Binder) binder; - Handle(Transfer_Actor) actor = theactor; - -// On balaie les Next jusqu a avoir un Resultat - Message_ProgressScope aScope (theProgress, NULL, 1, true); - while (!actor.IsNull()) { - if (actor->Recognize (start)) binder = actor->Transferring(start,this, aScope.Next()); - else binder.Nullify(); - if (!binder.IsNull()) break; - actor = actor->Next(); - } - if (aScope.UserBreak()) - return Handle(Transfer_Binder)(); - - if (binder.IsNull()) { -// if (thetrace) { -// aSender << "Transfer has produced no Result" < 0) thelevel --; - return binder; - } -// Gestion du niveau racine (.. a regarder de pres ..) - if (therootl == 0 && binder->StatusExec() == Transfer_StatusDone) - therootl = thelevel - 1; - - if (thelevel > 0) thelevel --; - return binder; -} - - -//======================================================================= -//function : Transfer -//purpose : -//======================================================================= - -Standard_Boolean Transfer_TransferProcess::Transfer(const TheStart& start, - const Message_ProgressRange& theProgress) -{ - Handle(Transfer_Binder) binder = Transferring(start, theProgress); - return (!binder.IsNull()); -} - - -// ######################################################################### -// .... Error Handling + Trace .... - -// trace : 1 pour Fail et Exception , 2 pour Root et Warning - - -//======================================================================= -//function : SetErrorHandle -//purpose : -//======================================================================= - -void Transfer_TransferProcess::SetErrorHandle(const Standard_Boolean err) -{ - theerrh = err; -} // traite par Transferring - - -//======================================================================= -//function : ErrorHandle -//purpose : -//======================================================================= - -Standard_Boolean Transfer_TransferProcess::ErrorHandle() const -{ - return theerrh; -} - -//======================================================================= -//function : StartTrace -//purpose : -//======================================================================= - -void Transfer_TransferProcess::StartTrace(const Handle(Transfer_Binder)& binder, - const TheStart& start, - const Standard_Integer level, - const Standard_Integer mode) const -{ - Message_Messenger::StreamBuffer aSender = themessenger->SendInfo(); - // ### Fail (Roots:50) -- Start start->DynamicType() - // ### Fail (Roots:50) -- Start id:#label.. Type:start->DynamicType() - if (thetrace > 3) { // Internal to be switch when searching bug (trace >= 4) - if (mode == 1) aSender << " ### Fail"; - if (mode == 2) aSender << " ### Warning"; - if (mode == 3) aSender << " ### New Root n0 " << theroots.Extent(); - if (mode == 4) aSender << " ### Exception"; - if (mode == 5) aSender << " ### Substitution"; - if (mode == 6) aSender << " ### Information"; - if (level > 1) - aSender << " (nested)"; // " at nesting Level:"<= 0 && mode != 3) - aSender << " at " << theroots.Extent() << " Roots"; - } - if (!start.IsNull()) PrintTrace (start,aSender); -//// sout << endl; - - if (!binder.IsNull()) { // old: if IsNull sout <Status() != Transfer_StatusVoid) { -// --- Result Type: binder->ResultType() --- Binder : binder->DynamicType(); - if (!hasres) - aSender << "\n --- Result Type : "; - else - aSender << " , "; - aSender << bnd->ResultTypeName(); -// CKY 9-JAN-1999: waiting for XSTEP Kernel message (not IGES_2075) -/* Message_Msg Msg2075("IGES_2075"); - Msg2075.AddString(bnd->ResultTypeName()); - Msg2075.TraceEver(); */ - hasres = Standard_True; - } - bnd = bnd->NextResult(); - } - if (!hasres && mode > 2) { - aSender << "\n --- No Result recorded"; -// CKY 9-JAN-1999 : waiting for XSTEP Kernel message -// (not IGES_2075, no reference to specifically TopoDS_Shape) -/* Message_Msg Msg2075("IGES_2075"); - Msg2075.AddString("No TopoDS_Shape"); - Msg2075.TraceEver(); */ - } -//old if (isused) sout << " -- (Already Used in another Transfer)"; - } - aSender << std::endl; -} - - -//======================================================================= -//function : PrintTrace -//purpose : -//======================================================================= - -void Transfer_TransferProcess::PrintTrace(const TheStart& start, Standard_OStream& S) const -{ - if (!start.IsNull()) S <<" Type:" << start->DynamicType()->Name(); -} - - -//======================================================================= -//function : IsLooping -//purpose : -//======================================================================= - -Standard_Boolean Transfer_TransferProcess::IsLooping - (const Standard_Integer alevel) const - { return alevel > NbMapped(); } - - - -// ######################################################################### -// .... RESULTATS .... - - -// ## ## RootResult : Les Racines ## ## - - -//======================================================================= -//function : RootResult -//purpose : -//======================================================================= - -Transfer_Iterator Transfer_TransferProcess::RootResult(const Standard_Boolean withstart) const -{ - Transfer_Iterator iter(withstart); - Standard_Integer max = theroots.Extent(); - for (Standard_Integer j = 1; j <= max; j ++) { - Standard_Integer i = theroots.FindKey(j); - Handle(Transfer_Binder) binder = MapItem(i); - if (binder.IsNull()) continue; - if (withstart) iter.Add (binder,Mapped(i)); - else iter.Add (binder); - } - return iter; -} - - -// ## ## CompleteResult : Tous les Resultats ## ## - -//======================================================================= -//function : CompleteResult -//purpose : -//======================================================================= - -Transfer_Iterator Transfer_TransferProcess::CompleteResult - (const Standard_Boolean withstart) const -{ - Transfer_Iterator iter(withstart); - Standard_Integer max = NbMapped(); - for (Standard_Integer i = 1; i <= max; i ++) { - Handle(Transfer_Binder) binder = MapItem(i); - if (binder.IsNull()) continue; - if (withstart) iter.Add (binder,Mapped(i)); - else iter.Add (binder); - } - return iter; -} - - -// ## ## AbnormalResult : Transferts a probleme ## ## -//======================================================================= -//function : AbnormalResult -//purpose : -//======================================================================= - -Transfer_Iterator Transfer_TransferProcess::AbnormalResult() const -{ - Transfer_Iterator iter(Standard_True); - Standard_Integer max = NbMapped(); - for (Standard_Integer i = 1; i <= max; i ++) { - Handle(Transfer_Binder) binder = MapItem(i); - if (binder.IsNull()) continue; - Transfer_StatusExec statex = binder->StatusExec(); - if (statex != Transfer_StatusInitial && statex != Transfer_StatusDone) - iter.Add (binder,Mapped(i)); // on note les cas "pas normaux" - } - return iter; -} - - -// ## ## ## CheckList : les messages ## ## ## -//======================================================================= -//function : CheckList -//purpose : -//======================================================================= - -Interface_CheckIterator Transfer_TransferProcess::CheckList - (const Standard_Boolean erronly) const -{ - Interface_CheckIterator list; - Standard_Integer num, max = NbMapped(); - for (Standard_Integer i = 1; i <= max; i ++) { - Handle(Transfer_Binder) binder = MapItem(i); - if (binder.IsNull()) continue; - Transfer_StatusExec statex = binder->StatusExec(); - Handle(Interface_Check) check = binder->Check(); - if (statex != Transfer_StatusInitial && statex != Transfer_StatusDone && - !check->HasFailed()) - check->AddFail("Transfer in Abnormal Status (!= Initial or Done)"); - if (!check->HasFailed() && (erronly || check->NbWarnings() == 0)) continue; - const TheStart& ent = Mapped(i); - num = CheckNum(ent); - if (num == 0) num = i; - check->SetEntity(ent); - list.Add(check,num); - } - return list; -} - - -// ######################################################################### -// .... RESULTATS PAR ENTITE .... - -//======================================================================= -//function : ResultOne -//purpose : -//======================================================================= - -Transfer_Iterator Transfer_TransferProcess::ResultOne(const TheStart& start, - const Standard_Integer level, - const Standard_Boolean withstart) const -{ - Transfer_Iterator iter(withstart); - Standard_Integer max = NbMapped(); - Standard_Integer ind = MapIndex (start); - if (ind == 0) return iter; - Standard_Integer i1 = (level == 0 ? ind : 1); - Standard_Integer i2 = (level == 0 ? ind : max); - Handle(TColStd_HArray1OfInteger) map = new TColStd_HArray1OfInteger (i1,i2,0); - //MarkScoped (ind,level,map); - - for (Standard_Integer i = i1; i <= i2; i ++) { - ind = map->Value(i); - if (ind == 0) continue; - Handle(Transfer_Binder) binder = MapItem(i); - if (binder.IsNull()) continue; - if (withstart) iter.Add (binder,Mapped(ind)); - else iter.Add (binder); - } - return iter; -} - - -//======================================================================= -//function : CheckListOne -//purpose : -//======================================================================= - -Interface_CheckIterator Transfer_TransferProcess::CheckListOne - (const TheStart& start,const Standard_Integer level, - const Standard_Boolean erronly) const -{ - Interface_CheckIterator list; - Standard_Integer max = NbMapped(); - Standard_Integer num, ind = MapIndex (start); - if (ind == 0) return list; - Standard_Integer i1 = (level == 0 ? ind : 1); - Standard_Integer i2 = (level == 0 ? ind : max); - Handle(TColStd_HArray1OfInteger) map = new TColStd_HArray1OfInteger (i1,i2,0); - //MarkScoped (ind,level,map); - - for (Standard_Integer i = i1; i <= i2; i ++) { - ind = map->Value(i); - if (ind == 0) continue; - Handle(Transfer_Binder) binder = MapItem(ind); - if (binder.IsNull()) continue; - Transfer_StatusExec statex = binder->StatusExec(); - Handle(Interface_Check) check = binder->Check(); - if (statex != Transfer_StatusInitial && statex != Transfer_StatusDone && - !check->HasFailed()) - check->AddFail("Transfer in Abnormal Status (!= Initial or Done)"); - if (!check->HasFailed() && (erronly || check->NbWarnings() == 0)) continue; - const TheStart& ent = Mapped(ind); - num = CheckNum(ent); if (num == 0) num = ind; - check->SetEntity(ent); - list.Add(check,num); - } - return list; -} - - -//======================================================================= -//function : IsCheckListEmpty -//purpose : -//======================================================================= - -Standard_Boolean Transfer_TransferProcess::IsCheckListEmpty - (const TheStart& start, const Standard_Integer level, - const Standard_Boolean erronly) const -{ - Standard_Integer max = NbMapped(); - Standard_Integer ind = MapIndex (start); - if (ind == 0) return Standard_False; - Standard_Integer i1 = (level == 0 ? ind : 1); - Standard_Integer i2 = (level == 0 ? ind : max); - Handle(TColStd_HArray1OfInteger) map = new TColStd_HArray1OfInteger (i1,i2,0); -// MarkScoped (ind,level,map); - - for (Standard_Integer i = i1; i <= i2; i ++) { - ind = map->Value(i); - if (ind == 0) continue; - Handle(Transfer_Binder) binder = MapItem(ind); - if (binder.IsNull()) continue; - - Transfer_StatusExec statex = binder->StatusExec(); - Handle(Interface_Check) check = binder->Check(); - if (statex != Transfer_StatusInitial && statex != Transfer_StatusDone) - return Standard_False; - if (check->HasFailed() || (!erronly && check->NbWarnings() > 0)) return Standard_False; - } - return Standard_True; -} - - -//======================================================================= -//function : RemoveResult -//purpose : -//======================================================================= - -void Transfer_TransferProcess::RemoveResult(const TheStart& start, - const Standard_Integer level, - const Standard_Boolean /*compute*/) -{ - //if (compute) ComputeScopes(); - Standard_Integer max = NbMapped(); - Standard_Integer ind = MapIndex (start); - if (ind == 0) return; - Standard_Integer i1 = (level == 0 ? ind : 1); - Standard_Integer i2 = (level == 0 ? ind : max); - Handle(TColStd_HArray1OfInteger) map = new TColStd_HArray1OfInteger (i1,i2,0); -// MarkScoped (ind,level,map); - - Standard_Integer i; // svv Jan11 2000 : porting on DEC - for (i = i1; i <= i2; i ++) { - ind = map->Value(i); - if (ind == 0) continue; - Handle(Transfer_Binder) binder = MapItem(ind); - if (binder.IsNull()) continue; -// Standard_Boolean cayest = binder->SetNbUserScopes (-1); -// if (cayest) themap(ind) = nulbinder; // RAZ ! - } - -//pdn commented for (i = NbRoots(); i > 0; i --) -// if (theroots.Value(i) == ind) theroots.Remove(i); -} - - -Standard_Integer Transfer_TransferProcess::CheckNum(const TheStart& ) const -{ - return 0; -} - diff --git a/src/Transfer/Transfer_TransientMapper.hxx b/src/Transfer/Transfer_TransientMapper.hxx index 0910523fc5..acd99d2b7a 100644 --- a/src/Transfer/Transfer_TransientMapper.hxx +++ b/src/Transfer/Transfer_TransientMapper.hxx @@ -21,7 +21,6 @@ #include #include -#include class Standard_Transient; class Transfer_DataInfo; class Transfer_Finder; diff --git a/src/Transfer/Transfer_TransientMapper_0.cxx b/src/Transfer/Transfer_TransientMapper_0.cxx index c323d31bd0..6b0f6436f8 100644 --- a/src/Transfer/Transfer_TransientMapper_0.cxx +++ b/src/Transfer/Transfer_TransientMapper_0.cxx @@ -17,28 +17,57 @@ #include #include - #include #include #include - +//======================================================================= +//function : Transfer_TransientMapper +//purpose : +//======================================================================= +Transfer_TransientMapper::Transfer_TransientMapper(const Handle(Standard_Transient)& akey) + : theval(akey) +{ + SetHashCode(std::hash{}(akey)); +} +//======================================================================= +//function : Value +//purpose : +//======================================================================= +const Handle(Standard_Transient)& Transfer_TransientMapper::Value() const +{ + return theval; +} +//======================================================================= +//function : Equates +//purpose : +//======================================================================= +Standard_Boolean Transfer_TransientMapper::Equates +(const Handle(Transfer_Finder)& other) const +{ + if (other.IsNull()) return Standard_False; + if (GetHashCode() != other->GetHashCode()) return Standard_False; + if (other->DynamicType() != DynamicType()) return Standard_False; + Handle(Transfer_TransientMapper) another = Handle(Transfer_TransientMapper)::DownCast(other); + return theval == another->Value(); +} +//======================================================================= +//function : ValueType +//purpose : +//======================================================================= +Handle(Standard_Type) Transfer_TransientMapper::ValueType() const +{ + return Transfer_DataInfo::Type(theval); +} - - - - -#define TheKey Handle(Standard_Transient) -#define TheKey_hxx -#define TheHasher TColStd_MapTransientHasher -#define TheHasher_hxx -#define TheInfo Transfer_DataInfo -#define TheInfo_hxx -#define Transfer_Mapper Transfer_TransientMapper -#define Transfer_Mapper_hxx -#define Handle_Transfer_Mapper Handle(Transfer_TransientMapper) -#include - +//======================================================================= +//function : ValueTypeName +//purpose : +//======================================================================= +Standard_CString Transfer_TransientMapper::ValueTypeName() const +{ + return Transfer_DataInfo::TypeName(theval); +} diff --git a/src/TransferBRep/FILES b/src/TransferBRep/FILES index 039db07c1d..9a470b5a4f 100644 --- a/src/TransferBRep/FILES +++ b/src/TransferBRep/FILES @@ -3,8 +3,6 @@ TransferBRep.hxx TransferBRep_BinderOfShape.cxx TransferBRep_BinderOfShape.hxx TransferBRep_HSequenceOfTransferResultInfo.hxx -TransferBRep_OrientedShapeMapper.hxx -TransferBRep_OrientedShapeMapper_0.cxx TransferBRep_Reader.cxx TransferBRep_Reader.hxx TransferBRep_SequenceOfTransferResultInfo.hxx diff --git a/src/TransferBRep/TransferBRep_OrientedShapeMapper.hxx b/src/TransferBRep/TransferBRep_OrientedShapeMapper.hxx deleted file mode 100644 index 03f5b220ad..0000000000 --- a/src/TransferBRep/TransferBRep_OrientedShapeMapper.hxx +++ /dev/null @@ -1,89 +0,0 @@ -// Created on: 1994-10-03 -// Created by: Christian CAILLET -// Copyright (c) 1994-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#ifndef _TransferBRep_OrientedShapeMapper_HeaderFile -#define _TransferBRep_OrientedShapeMapper_HeaderFile - -#include -#include - -#include -#include -#include -#include -#include -class TopoDS_Shape; -class TopTools_OrientedShapeMapHasher; -class TransferBRep_ShapeInfo; -class Transfer_Finder; - - -class TransferBRep_OrientedShapeMapper; -DEFINE_STANDARD_HANDLE(TransferBRep_OrientedShapeMapper, Transfer_Finder) - - -class TransferBRep_OrientedShapeMapper : public Transfer_Finder -{ - -public: - - - //! Creates a Mapper with a Value. This Value can then not be - //! changed. It is used by the Hasher to compute the HashCode, - //! which will then be stored for an immediate reading. - Standard_EXPORT TransferBRep_OrientedShapeMapper(const TopoDS_Shape& akey); - - //! Returns the contained value - Standard_EXPORT const TopoDS_Shape& Value() const; - - //! Specific testof equality : defined as False if has - //! not the same true Type, else contents are compared (by - //! C++ operator ==) - Standard_EXPORT Standard_Boolean Equates (const Handle(Transfer_Finder)& other) const Standard_OVERRIDE; - - //! Returns the Type of the Value. By default, returns the - //! DynamicType of , but can be redefined - Standard_EXPORT virtual Handle(Standard_Type) ValueType() const Standard_OVERRIDE; - - //! Returns the name of the Type of the Value. Default is name - //! of ValueType, unless it is for a non-handled object - Standard_EXPORT virtual Standard_CString ValueTypeName() const Standard_OVERRIDE; - - - - - DEFINE_STANDARD_RTTI_INLINE(TransferBRep_OrientedShapeMapper,Transfer_Finder) - -protected: - - - - -private: - - - TopoDS_Shape theval; - - -}; - - - - - - - -#endif // _TransferBRep_OrientedShapeMapper_HeaderFile diff --git a/src/TransferBRep/TransferBRep_OrientedShapeMapper_0.cxx b/src/TransferBRep/TransferBRep_OrientedShapeMapper_0.cxx deleted file mode 100644 index 84cb6c24d0..0000000000 --- a/src/TransferBRep/TransferBRep_OrientedShapeMapper_0.cxx +++ /dev/null @@ -1,45 +0,0 @@ -// Created on: 1994-10-03 -// Created by: Christian CAILLET -// Copyright (c) 1994-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#include - -#include - -#include -#include -#include -#include - - - - - - - - - - -#define TheKey TopoDS_Shape -#define TheKey_hxx -#define TheHasher TopTools_OrientedShapeMapHasher -#define TheHasher_hxx -#define TheInfo TransferBRep_ShapeInfo -#define TheInfo_hxx -#define Transfer_Mapper TransferBRep_OrientedShapeMapper -#define Transfer_Mapper_hxx -#define Handle_Transfer_Mapper Handle(TransferBRep_OrientedShapeMapper) -#include - diff --git a/src/TransferBRep/TransferBRep_ShapeMapper_0.cxx b/src/TransferBRep/TransferBRep_ShapeMapper_0.cxx index a7e4c00609..2174ee8fde 100644 --- a/src/TransferBRep/TransferBRep_ShapeMapper_0.cxx +++ b/src/TransferBRep/TransferBRep_ShapeMapper_0.cxx @@ -23,23 +23,52 @@ #include #include - +//======================================================================= +//function : TransferBRep_ShapeMapper +//purpose : +//======================================================================= +TransferBRep_ShapeMapper::TransferBRep_ShapeMapper(const TopoDS_Shape& akey) + : theval(akey) +{ + SetHashCode(TopTools_ShapeMapHasher{}(akey)); +} +//======================================================================= +//function : Value +//purpose : +//======================================================================= +const TopoDS_Shape& TransferBRep_ShapeMapper::Value() const +{ + return theval; +} +//======================================================================= +//function : Equates +//purpose : +//======================================================================= +Standard_Boolean TransferBRep_ShapeMapper::Equates(const Handle(Transfer_Finder)& other) const +{ + if (other.IsNull()) return Standard_False; + if (GetHashCode() != other->GetHashCode()) return Standard_False; + if (other->DynamicType() != DynamicType()) return Standard_False; + Handle(TransferBRep_ShapeMapper) another = Handle(TransferBRep_ShapeMapper)::DownCast(other); + return TopTools_ShapeMapHasher{}(theval, another->Value()); +} +//======================================================================= +//function : ValueType +//purpose : +//======================================================================= +Handle(Standard_Type) TransferBRep_ShapeMapper::ValueType() const +{ + return TransferBRep_ShapeInfo::Type(theval); +} - - - - -#define TheKey TopoDS_Shape -#define TheKey_hxx -#define TheHasher TopTools_ShapeMapHasher -#define TheHasher_hxx -#define TheInfo TransferBRep_ShapeInfo -#define TheInfo_hxx -#define Transfer_Mapper TransferBRep_ShapeMapper -#define Transfer_Mapper_hxx -#define Handle_Transfer_Mapper Handle(TransferBRep_ShapeMapper) -#include - +//======================================================================= +//function : ValueTypeName +//purpose : +//======================================================================= +Standard_CString TransferBRep_ShapeMapper::ValueTypeName() const +{ + return TransferBRep_ShapeInfo::TypeName(theval); +} diff --git a/src/V3d/V3d_View.cxx b/src/V3d/V3d_View.cxx index 8497cfc596..7658ea7984 100644 --- a/src/V3d/V3d_View.cxx +++ b/src/V3d/V3d_View.cxx @@ -3801,7 +3801,7 @@ void V3d_View::DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth OCCT_DUMP_FIELD_VALUE_POINTER (theOStream, MyViewer) for (V3d_ListOfLight::Iterator anIterator (myActiveLights); anIterator.More(); anIterator.Next()) { - class Handle(Graphic3d_CLight)& anActiveLight = anIterator.Value(); + class Handle(Graphic3d_CLight)& anActiveLight = anIterator.ChangeValue(); OCCT_DUMP_FIELD_VALUE_POINTER (theOStream, anActiveLight) } OCCT_DUMP_FIELD_VALUES_DUMPED (theOStream, theDepth, &myDefaultViewAxis) diff --git a/src/ViewerTest/ViewerTest_DoubleMapOfInteractiveAndName.hxx b/src/ViewerTest/ViewerTest_DoubleMapOfInteractiveAndName.hxx index 44522f932b..d04acedc47 100644 --- a/src/ViewerTest/ViewerTest_DoubleMapOfInteractiveAndName.hxx +++ b/src/ViewerTest/ViewerTest_DoubleMapOfInteractiveAndName.hxx @@ -19,11 +19,10 @@ #include #include -#include #include class AIS_InteractiveObject; -typedef NCollection_DoubleMap ViewerTest_DoubleMapOfInteractiveAndName; -typedef NCollection_DoubleMap::Iterator ViewerTest_DoubleMapIteratorOfDoubleMapOfInteractiveAndName; +typedef NCollection_DoubleMap ViewerTest_DoubleMapOfInteractiveAndName; +typedef NCollection_DoubleMap::Iterator ViewerTest_DoubleMapIteratorOfDoubleMapOfInteractiveAndName; #endif diff --git a/src/ViewerTest/ViewerTest_ViewerCommands.cxx b/src/ViewerTest/ViewerTest_ViewerCommands.cxx index 83a3fbabc7..2124453e20 100644 --- a/src/ViewerTest/ViewerTest_ViewerCommands.cxx +++ b/src/ViewerTest/ViewerTest_ViewerCommands.cxx @@ -153,26 +153,33 @@ static TCollection_AsciiString getModuleCanvasId() } #endif -static Handle(ViewerTest_Window)& VT_GetWindow() +namespace { - static Handle(ViewerTest_Window) aWindow; - return aWindow; -} + static Handle(ViewerTest_Window)& VT_GetWindow() + { + static Handle(ViewerTest_Window) aWindow; + return aWindow; + } -static Handle(Aspect_DisplayConnection)& GetDisplayConnection() -{ - static Handle(Aspect_DisplayConnection) aDisplayConnection; - return aDisplayConnection; -} + static Handle(Aspect_DisplayConnection)& GetDisplayConnection() + { + static Handle(Aspect_DisplayConnection) aDisplayConnection; + return aDisplayConnection; + } -static void SetDisplayConnection (const Handle(Aspect_DisplayConnection)& theDisplayConnection) -{ - GetDisplayConnection() = theDisplayConnection; -} + using ViewerTest_ViewerCommandsViewMap = NCollection_DoubleMap ; + using ViewerTest_ViewerCommandsInteractiveContextMap = NCollection_DoubleMap ; + using ViewerTest_ViewerCommandsGraphicDriverMap = NCollection_DoubleMap ; -NCollection_DoubleMap ViewerTest_myViews; -static NCollection_DoubleMap ViewerTest_myContexts; -static NCollection_DoubleMap ViewerTest_myDrivers; + static void SetDisplayConnection(const Handle(Aspect_DisplayConnection)& theDisplayConnection) + { + GetDisplayConnection() = theDisplayConnection; + } + + static ViewerTest_ViewerCommandsViewMap ViewerTest_myViews; + static ViewerTest_ViewerCommandsInteractiveContextMap ViewerTest_myContexts; + static ViewerTest_ViewerCommandsGraphicDriverMap ViewerTest_myDrivers; +} static struct { @@ -184,10 +191,10 @@ static struct //! Sets the gradient filling for a background in a default viewer. void SetDefaultGradient() { - for (NCollection_DoubleMap::Iterator aCtxIter (ViewerTest_myContexts); + for (ViewerTest_ViewerCommandsInteractiveContextMap::Iterator aCtxIter (ViewerTest_myContexts); aCtxIter.More(); aCtxIter.Next()) { - const Handle (V3d_Viewer)& aViewer = aCtxIter.Value()->CurrentViewer(); + const Handle (V3d_Viewer)& aViewer = aCtxIter.Key2()->CurrentViewer(); aViewer->SetDefaultBgGradientColors (GradientColor1, GradientColor2, FillMethod); } } @@ -195,10 +202,10 @@ static struct //! Sets the color used for filling a background in a default viewer. void SetDefaultColor() { - for (NCollection_DoubleMap::Iterator aCtxIter (ViewerTest_myContexts); + for (ViewerTest_ViewerCommandsInteractiveContextMap::Iterator aCtxIter (ViewerTest_myContexts); aCtxIter.More(); aCtxIter.Next()) { - const Handle (V3d_Viewer)& aViewer = aCtxIter.Value()->CurrentViewer(); + const Handle (V3d_Viewer)& aViewer = aCtxIter.Key2()->CurrentViewer(); aViewer->SetDefaultBackgroundColor (FlatColor); } } @@ -404,10 +411,10 @@ Handle(AIS_InteractiveContext) FindContextByView (const Handle(V3d_View)& theVie { Handle(AIS_InteractiveContext) anAISContext; - for (NCollection_DoubleMap::Iterator + for (ViewerTest_ViewerCommandsInteractiveContextMap::Iterator anIter (ViewerTest_myContexts); anIter.More(); anIter.Next()) { - if (anIter.Value()->CurrentViewer() == theView->Viewer()) + if (anIter.Key2()->CurrentViewer() == theView->Viewer()) return anIter.Key2(); } return anAISContext; @@ -424,14 +431,14 @@ Standard_Boolean IsWindowOverlapped (const Standard_Integer thePxLeft, const Standard_Integer thePxBottom, TCollection_AsciiString& theViewId) { - for(NCollection_DoubleMap ::Iterator + for(ViewerTest_ViewerCommandsViewMap::Iterator anIter(ViewerTest_myViews); anIter.More(); anIter.Next()) { Standard_Integer aTop = 0, aLeft = 0, aRight = 0, aBottom = 0; - anIter.Value()->Window()->Position(aLeft, aTop, aRight, aBottom); + anIter.Key2()->Window()->Position(aLeft, aTop, aRight, aBottom); if ((thePxLeft >= aLeft && thePxLeft <= aRight && thePxTop >= aTop && thePxTop <= aBottom) || (thePxLeft >= aLeft && thePxLeft <= aRight && thePxBottom >= aTop && thePxBottom <= aBottom) || (thePxRight >= aLeft && thePxRight <= aRight && thePxTop >= aTop && thePxTop <= aBottom) || @@ -653,10 +660,10 @@ TCollection_AsciiString ViewerTest::ViewerInit (const ViewerTest_VinitParams& th // If it's the single view, we first look for empty context if (ViewerTest_myViews.IsEmpty() && !ViewerTest_myContexts.IsEmpty()) { - NCollection_DoubleMap ::Iterator + ViewerTest_ViewerCommandsInteractiveContextMap::Iterator anIter(ViewerTest_myContexts); if (anIter.More()) - ViewerTest::SetAISContext (anIter.Value()); + ViewerTest::SetAISContext (anIter.Key2()); a3DViewer = ViewerTest::GetAISContext()->CurrentViewer(); } else if (ViewerTest_myContexts.IsBound1(aViewNames.GetViewerName())) @@ -805,7 +812,7 @@ TCollection_AsciiString ViewerTest::ViewerInit (const ViewerTest_VinitParams& th //============================================================================== void ViewerTest::RedrawAllViews() { - NCollection_DoubleMap::Iterator aViewIt(ViewerTest_myViews); + ViewerTest_ViewerCommandsViewMap::Iterator aViewIt(ViewerTest_myViews); for (; aViewIt.More(); aViewIt.Next()) { const Handle(V3d_View)& aView = aViewIt.Key2(); @@ -1455,10 +1462,10 @@ static int VHLRType (Draw_Interpretor& , Standard_Integer argc, const char** arg #if defined(_WIN32) || defined(HAVE_XLIB) static TCollection_AsciiString FindViewIdByWindowHandle (Aspect_Drawable theWindowHandle) { - for (NCollection_DoubleMap::Iterator + for (ViewerTest_ViewerCommandsViewMap::Iterator anIter(ViewerTest_myViews); anIter.More(); anIter.Next()) { - Aspect_Drawable aWindowHandle = anIter.Value()->Window()->NativeHandle(); + Aspect_Drawable aWindowHandle = anIter.Key2()->Window()->NativeHandle(); if (aWindowHandle == theWindowHandle) return anIter.Key1(); } @@ -1572,12 +1579,12 @@ void ViewerTest::RemoveView (const TCollection_AsciiString& theViewName, const S { if (ViewerTest_myViews.Extent() > 1) { - for (NCollection_DoubleMap ::Iterator anIter (ViewerTest_myViews); + for (ViewerTest_ViewerCommandsViewMap::Iterator anIter (ViewerTest_myViews); anIter.More(); anIter.Next()) { if (anIter.Key1() != theViewName) { - ActivateView (anIter.Value(), true); + ActivateView (anIter.Key2(), true); break; } } @@ -1594,7 +1601,8 @@ void ViewerTest::RemoveView (const TCollection_AsciiString& theViewName, const S } } - // Delete view + // Delete view, name will be removed too + const TCollection_AsciiString aCopyString(theViewName); ViewerTest_myViews.UnBind1(theViewName); if (!aView->Window().IsNull()) { @@ -1616,11 +1624,11 @@ void ViewerTest::RemoveView (const TCollection_AsciiString& theViewName, const S { // Remove driver if there is no viewers that use it Standard_Boolean isRemoveDriver = Standard_True; - for(NCollection_DoubleMap::Iterator + for(ViewerTest_ViewerCommandsInteractiveContextMap::Iterator anIter(ViewerTest_myContexts); anIter.More(); anIter.Next()) { if (aCurrentContext != anIter.Key2() && - aCurrentContext->CurrentViewer()->Driver() == anIter.Value()->CurrentViewer()->Driver()) + aCurrentContext->CurrentViewer()->Driver() == anIter.Key2()->CurrentViewer()->Driver()) { isRemoveDriver = Standard_False; break; @@ -1639,7 +1647,7 @@ void ViewerTest::RemoveView (const TCollection_AsciiString& theViewName, const S ViewerTest_myContexts.UnBind2(aCurrentContext); } } - Message::SendInfo() << "3D View - " << theViewName << " was deleted.\n"; + Message::SendInfo() << "3D View - " << aCopyString << " was deleted.\n"; if (ViewerTest_EventManager::ToExitOnCloseView()) { Draw_Interprete ("exit"); @@ -1663,7 +1671,7 @@ static int VClose (Draw_Interpretor& /*theDi*/, if (anArg.IsEqual ("ALL") || anArg.IsEqual ("*")) { - for (NCollection_DoubleMap::Iterator anIter (ViewerTest_myViews); + for (ViewerTest_ViewerCommandsViewMap::Iterator anIter (ViewerTest_myViews); anIter.More(); anIter.Next()) { aViewList.Append (anIter.Key1()); @@ -1808,13 +1816,13 @@ static int VViewList (Draw_Interpretor& theDi, Standard_Integer theArgsNb, const theDi << theArgVec[0] <<":\n"; } - for (NCollection_DoubleMap ::Iterator aDriverIter (ViewerTest_myDrivers); + for (ViewerTest_ViewerCommandsGraphicDriverMap::Iterator aDriverIter (ViewerTest_myDrivers); aDriverIter.More(); aDriverIter.Next()) { if (isTreeView) theDi << aDriverIter.Key1() << ":\n"; - for (NCollection_DoubleMap ::Iterator + for (ViewerTest_ViewerCommandsInteractiveContextMap::Iterator aContextIter(ViewerTest_myContexts); aContextIter.More(); aContextIter.Next()) { if (aContextIter.Key1().Search(aDriverIter.Key1()) != -1) @@ -1825,7 +1833,7 @@ static int VViewList (Draw_Interpretor& theDi, Standard_Integer theArgsNb, const theDi << " " << aContextName.Split(aDriverIter.Key1().Length() + 1) << ":\n"; } - for (NCollection_DoubleMap ::Iterator aViewIter (ViewerTest_myViews); + for (ViewerTest_ViewerCommandsViewMap::Iterator aViewIter (ViewerTest_myViews); aViewIter.More(); aViewIter.Next()) { if (aViewIter.Key1().Search(aContextIter.Key1()) != -1) @@ -1833,7 +1841,7 @@ static int VViewList (Draw_Interpretor& theDi, Standard_Integer theArgsNb, const TCollection_AsciiString aViewName(aViewIter.Key1()); if (isTreeView) { - if (aViewIter.Value() == ViewerTest::CurrentView()) + if (aViewIter.Key2() == ViewerTest::CurrentView()) theDi << " " << aViewName.Split(aContextIter.Key1().Length() + 1) << "(*)\n"; else theDi << " " << aViewName.Split(aContextIter.Key1().Length() + 1) << "\n"; @@ -2370,7 +2378,7 @@ static void VProcessEvents (ClientData theDispX, int) { Display* aDispX = (Display* )theDispX; Handle(Aspect_DisplayConnection) aDispConn; - for (NCollection_DoubleMap::Iterator + for (ViewerTest_ViewerCommandsGraphicDriverMap::Iterator aDriverIter (ViewerTest_myDrivers); aDriverIter.More(); aDriverIter.Next()) { const Handle(Aspect_DisplayConnection)& aDispConnTmp = aDriverIter.Key2()->GetDisplayConnection(); @@ -8277,7 +8285,7 @@ namespace aPrs->RemoveClipPlane (aClipPlane); } - for (NCollection_DoubleMap::Iterator aViewIt(ViewerTest_myViews); + for (ViewerTest_ViewerCommandsViewMap::Iterator aViewIt(ViewerTest_myViews); aViewIt.More(); aViewIt.Next()) { const Handle(V3d_View)& aView = aViewIt.Key2(); @@ -12755,10 +12763,10 @@ static int VManipulator (Draw_Interpretor& theDi, } if (!aViewAffinity.IsNull()) { - for (NCollection_DoubleMap ::Iterator anIter (ViewerTest_myViews); + for (ViewerTest_ViewerCommandsViewMap::Iterator anIter (ViewerTest_myViews); anIter.More(); anIter.Next()) { - ViewerTest::GetAISContext()->SetViewAffinity (aManipulator, anIter.Value(), false); + ViewerTest::GetAISContext()->SetViewAffinity (aManipulator, anIter.Key2(), false); } ViewerTest::GetAISContext()->SetViewAffinity (aManipulator, aViewAffinity, true); } diff --git a/src/VrmlData/VrmlData_Node.cxx b/src/VrmlData/VrmlData_Node.cxx index d4a85824aa..31a48c2151 100644 --- a/src/VrmlData/VrmlData_Node.cxx +++ b/src/VrmlData/VrmlData_Node.cxx @@ -48,15 +48,6 @@ Standard_Boolean IsEqual (const Handle(VrmlData_Node)& theOne, return aResult; } -//======================================================================= -// function : HashCode -// purpose : Global method -//======================================================================= -Standard_Integer HashCode (const Handle (VrmlData_Node) & theNode, const Standard_Integer theUpperBound) -{ - return (theNode->Name () == NULL ? 1 : HashCode (theNode->Name (), theUpperBound)); -} - //======================================================================= //function : VrmlData_Node //purpose : diff --git a/src/VrmlData/VrmlData_Node.hxx b/src/VrmlData/VrmlData_Node.hxx index fed5337283..695633d04c 100644 --- a/src/VrmlData/VrmlData_Node.hxx +++ b/src/VrmlData/VrmlData_Node.hxx @@ -19,7 +19,8 @@ #include #include #include -#include +#include +#include #include #define VRMLDATA_LCOMPARE(aa, bb) \ @@ -198,13 +199,34 @@ class VrmlData_Node : public Standard_Transient // Definition of HANDLE object using Standard_DefineHandle.hxx DEFINE_STANDARD_HANDLE (VrmlData_Node, Standard_Transient) -//! Computes a hash code for the given VRML node, in the range [1, theUpperBound] -//! @param theNode the VRML node which hash code is to be computed -//! @param theUpperBound the upper bound of the range a computing hash code must be within -//! @return a computed hash code, in the range [1, theUpperBound] -Standard_EXPORT Standard_Integer HashCode (const Handle (VrmlData_Node) & theNode, Standard_Integer theUpperBound); -Standard_EXPORT Standard_Boolean IsEqual (const Handle(VrmlData_Node)& theOne, - const Handle(VrmlData_Node)& theTwo); +Standard_EXPORT Standard_Boolean IsEqual(const Handle(VrmlData_Node)& theOne, + const Handle(VrmlData_Node)& theTwo); + +namespace std +{ + template <> + struct hash + { + size_t operator()(const Handle(VrmlData_Node)& theNode) const + { + if (!theNode->Name()) + { + return 1; + } + return Standard_CStringHasher{}(theNode->Name()); + } + }; + + template<> + struct equal_to + { + bool operator()(const Handle(VrmlData_Node)& theNode1, + const Handle(VrmlData_Node)& theNode2) const noexcept + { + return IsEqual(theNode1, theNode2); + } + }; +} #endif diff --git a/src/WNT/WNT_WClass.hxx b/src/WNT/WNT_WClass.hxx index 55808add07..e7d1e4d6c8 100644 --- a/src/WNT/WNT_WClass.hxx +++ b/src/WNT/WNT_WClass.hxx @@ -22,9 +22,9 @@ #if defined(_WIN32) && !defined(OCCT_UWP) #include -#include #include #include +#include #include //! This class defines a Windows NT window class. diff --git a/src/XCAFDimTolObjects/XCAFDimTolObjects_DataMapOfToleranceDatum.hxx b/src/XCAFDimTolObjects/XCAFDimTolObjects_DataMapOfToleranceDatum.hxx index 0a8fe8a6d7..af71e9449d 100644 --- a/src/XCAFDimTolObjects/XCAFDimTolObjects_DataMapOfToleranceDatum.hxx +++ b/src/XCAFDimTolObjects/XCAFDimTolObjects_DataMapOfToleranceDatum.hxx @@ -19,8 +19,7 @@ #include #include #include -#include -typedef NCollection_DataMap XCAFDimTolObjects_DataMapOfToleranceDatum; +typedef NCollection_DataMap XCAFDimTolObjects_DataMapOfToleranceDatum; #endif \ No newline at end of file diff --git a/src/XCAFDoc/XCAFDoc_AssemblyItemId.hxx b/src/XCAFDoc/XCAFDoc_AssemblyItemId.hxx index 2d30806f02..ef3036ea60 100644 --- a/src/XCAFDoc/XCAFDoc_AssemblyItemId.hxx +++ b/src/XCAFDoc/XCAFDoc_AssemblyItemId.hxx @@ -80,25 +80,10 @@ public: //! Dumps the content of me into the stream Standard_EXPORT virtual void DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth = -1) const; - struct Hasher + bool operator==(const XCAFDoc_AssemblyItemId& theOther) const { - - //! Computes a hash code for the given value of the XCAFDoc_AssemblyItemId, in range [1, theUpperBound] - //! @param theAssemblyItemId the value of the XCAFDoc_AssemblyItemId type which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in range [1, theUpperBound] - static Standard_Integer HashCode (const XCAFDoc_AssemblyItemId& theAssemblyItemId, - const Standard_Integer theUpperBound) - { - return ::HashCode (theAssemblyItemId.ToString(), theUpperBound); - } - - static int IsEqual(const XCAFDoc_AssemblyItemId& theItem1, - const XCAFDoc_AssemblyItemId& theItem2) - { - return theItem1.IsEqual(theItem2); - } - }; + return IsEqual(theOther); + } private: @@ -106,4 +91,17 @@ private: }; +namespace std +{ + + template<> + struct hash + { + size_t operator()(const XCAFDoc_AssemblyItemId& theAssemblyItemId) const + { + return std::hash{}(theAssemblyItemId.ToString()); + } + }; + +} #endif // _XCAFDoc_AssemblyItemId_HeaderFile diff --git a/src/XCAFDoc/XCAFDoc_DimTolTool.cxx b/src/XCAFDoc/XCAFDoc_DimTolTool.cxx index b396f408dd..4ad3778ed6 100644 --- a/src/XCAFDoc/XCAFDoc_DimTolTool.cxx +++ b/src/XCAFDoc/XCAFDoc_DimTolTool.cxx @@ -965,7 +965,7 @@ const Standard_GUID& XCAFDoc_DimTolTool::ID() const //purpose : //======================================================================= void XCAFDoc_DimTolTool::GetGDTPresentations(NCollection_IndexedDataMap& theGDTLabelToShape) const + TopoDS_Shape>& theGDTLabelToShape) const { TDF_LabelSequence aGDTs; GetDimensionLabels(aGDTs); @@ -1017,7 +1017,7 @@ void XCAFDoc_DimTolTool::GetGDTPresentations(NCollection_IndexedDataMap& theGDTLabelToPrs) +void XCAFDoc_DimTolTool::SetGDTPresentations(NCollection_IndexedDataMap& theGDTLabelToPrs) { for (Standard_Integer i = 1; i <= theGDTLabelToPrs.Extent(); i++) { diff --git a/src/XCAFDoc/XCAFDoc_DimTolTool.hxx b/src/XCAFDoc/XCAFDoc_DimTolTool.hxx index 78380f0853..ea4b34436f 100644 --- a/src/XCAFDoc/XCAFDoc_DimTolTool.hxx +++ b/src/XCAFDoc/XCAFDoc_DimTolTool.hxx @@ -26,7 +26,6 @@ #include #include #include -#include class XCAFDoc_ShapeTool; class TDF_Label; @@ -237,12 +236,12 @@ public: Standard_EXPORT void Lock(const TDF_Label& theViewL) const; //! fill the map GDT label -> shape presentation - Standard_EXPORT void GetGDTPresentations(NCollection_IndexedDataMap& theGDTLabelToShape) const; + Standard_EXPORT void GetGDTPresentations(NCollection_IndexedDataMap& theGDTLabelToShape) const; //! Set shape presentation for GDT labels according to given map (theGDTLabelToPrs) //! theGDTLabelToPrsName map is an additional argument, can be used to set presentation names. //! If label is not in the theGDTLabelToPrsName map, the presentation name will be empty - Standard_EXPORT void SetGDTPresentations(NCollection_IndexedDataMap& theGDTLabelToPrs); + Standard_EXPORT void SetGDTPresentations(NCollection_IndexedDataMap& theGDTLabelToPrs); //! Unlock the given GDT. Standard_EXPORT void Unlock(const TDF_Label& theViewL) const; diff --git a/src/XCAFPrs/XCAFPrs_AISObject.cxx b/src/XCAFPrs/XCAFPrs_AISObject.cxx index e890665988..1e05ac79f4 100644 --- a/src/XCAFPrs/XCAFPrs_AISObject.cxx +++ b/src/XCAFPrs/XCAFPrs_AISObject.cxx @@ -138,7 +138,7 @@ void XCAFPrs_AISObject::DispatchStyles (const Standard_Boolean theToSyncStyles) // collect sub-shapes with the same style into compounds BRep_Builder aBuilder; - NCollection_IndexedDataMap aStyleGroups; + NCollection_IndexedDataMap aStyleGroups; for (XCAFPrs_DataMapIteratorOfIndexedDataMapOfShapeStyle aStyledShapeIter (aSettings); aStyledShapeIter.More(); aStyledShapeIter.Next()) { @@ -160,7 +160,7 @@ void XCAFPrs_AISObject::DispatchStyles (const Standard_Boolean theToSyncStyles) aSettings.Clear(); // assign custom aspects - for (NCollection_IndexedDataMap::Iterator aStyleGroupIter (aStyleGroups); + for (NCollection_IndexedDataMap::Iterator aStyleGroupIter (aStyleGroups); aStyleGroupIter.More(); aStyleGroupIter.Next()) { const TopoDS_Compound& aComp = aStyleGroupIter.Value(); diff --git a/src/XCAFPrs/XCAFPrs_DataMapOfStyleShape.hxx b/src/XCAFPrs/XCAFPrs_DataMapOfStyleShape.hxx index 7576a7985a..ceecaa7b23 100644 --- a/src/XCAFPrs/XCAFPrs_DataMapOfStyleShape.hxx +++ b/src/XCAFPrs/XCAFPrs_DataMapOfStyleShape.hxx @@ -20,8 +20,8 @@ #include #include -typedef NCollection_DataMap XCAFPrs_DataMapOfStyleShape; -typedef NCollection_DataMap::Iterator XCAFPrs_DataMapIteratorOfDataMapOfStyleShape; +typedef NCollection_DataMap XCAFPrs_DataMapOfStyleShape; +typedef NCollection_DataMap::Iterator XCAFPrs_DataMapIteratorOfDataMapOfStyleShape; #endif diff --git a/src/XCAFPrs/XCAFPrs_DataMapOfStyleTransient.hxx b/src/XCAFPrs/XCAFPrs_DataMapOfStyleTransient.hxx index 6520c85f42..b901e619b0 100644 --- a/src/XCAFPrs/XCAFPrs_DataMapOfStyleTransient.hxx +++ b/src/XCAFPrs/XCAFPrs_DataMapOfStyleTransient.hxx @@ -20,8 +20,8 @@ #include #include -typedef NCollection_DataMap XCAFPrs_DataMapOfStyleTransient; -typedef NCollection_DataMap::Iterator XCAFPrs_DataMapIteratorOfDataMapOfStyleTransient; +typedef NCollection_DataMap XCAFPrs_DataMapOfStyleTransient; +typedef NCollection_DataMap::Iterator XCAFPrs_DataMapIteratorOfDataMapOfStyleTransient; #endif diff --git a/src/XCAFPrs/XCAFPrs_DocumentNode.hxx b/src/XCAFPrs/XCAFPrs_DocumentNode.hxx index 68bf1dfe15..b8789e031e 100644 --- a/src/XCAFPrs/XCAFPrs_DocumentNode.hxx +++ b/src/XCAFPrs/XCAFPrs_DocumentNode.hxx @@ -37,20 +37,22 @@ struct XCAFPrs_DocumentNode public: // Methods for hash map - //! Return hash code based on node string identifier. - static Standard_Integer HashCode (const XCAFPrs_DocumentNode& theNode, - const Standard_Integer theN) + bool operator==(const XCAFPrs_DocumentNode& theOther) const { - return ::HashCode (theNode.Id, theN); + return Id == theOther.Id; } - - //! Return TRUE if two document nodes has the same string identifier. - static Standard_Boolean IsEqual (const XCAFPrs_DocumentNode& theNode1, - const XCAFPrs_DocumentNode& theNode2) - { - return theNode1.Id == theNode2.Id; - } - }; +namespace std +{ + template <> + struct hash + { + size_t operator()(const XCAFPrs_DocumentNode& theDocumentNode) const + { + return std::hash{}(theDocumentNode.Id); + } + }; +} + #endif // _XCAFPrs_DocumentNode_HeaderFile diff --git a/src/XCAFPrs/XCAFPrs_Style.hxx b/src/XCAFPrs/XCAFPrs_Style.hxx index 22c9664548..ac3f8e549e 100644 --- a/src/XCAFPrs/XCAFPrs_Style.hxx +++ b/src/XCAFPrs/XCAFPrs_Style.hxx @@ -19,8 +19,8 @@ #include #include #include -#include #include +#include //! Represents a set of styling settings applicable to a (sub)shape class XCAFPrs_Style @@ -130,38 +130,8 @@ public: return IsEqual (theOther); } - //! Computes a hash code for the given set of styling settings, in the range [1, theUpperBound] - //! @param theStyle the set of styling settings which hash code is to be computed - //! @param theUpperBound the upper bound of the range a computing hash code must be within - //! @return a computed hash code, in the range [1, theUpperBound] - static Standard_Integer HashCode (const XCAFPrs_Style& theStyle, const Standard_Integer theUpperBound) - { - if (!theStyle.myIsVisible) - { - return 1; - } - - Standard_Integer aHashCode = 0; - if (theStyle.myHasColorSurf) - { - aHashCode = aHashCode ^ Quantity_ColorRGBAHasher::HashCode (theStyle.myColorSurf, theUpperBound); - } - if (theStyle.myHasColorCurv) - { - aHashCode = aHashCode ^ Quantity_ColorHasher::HashCode (theStyle.myColorCurv, theUpperBound); - } - if (!theStyle.myMaterial.IsNull()) - { - aHashCode = aHashCode ^ ::HashCode (theStyle.myMaterial, theUpperBound); - } - return ::HashCode (aHashCode, theUpperBound); - } - - //! Returns True when the two keys are the same. - static Standard_Boolean IsEqual (const XCAFPrs_Style& theS1, const XCAFPrs_Style& theS2) - { - return theS1.IsEqual (theS2); - } + template + friend struct std::hash; //! Dumps the content of me into the stream Standard_EXPORT void DumpJson (Standard_OStream& theOStream, Standard_Integer theDepth = -1) const; @@ -177,4 +147,34 @@ protected: }; +namespace std +{ + template <> + struct hash + { + size_t operator()(const XCAFPrs_Style& theStyle) const + { + if (!theStyle.myIsVisible) + { + return 1; + } + size_t aCombination[3]; + int aCount = 0; + if (theStyle.myHasColorSurf) + { + aCombination[aCount++] = std::hash{}(theStyle.myColorSurf); + } + if (theStyle.myHasColorCurv) + { + aCombination[aCount++] = std::hash{}(theStyle.myColorCurv); + } + if (!theStyle.myMaterial.IsNull()) + { + aCombination[aCount++] = std::hash{}(theStyle.myMaterial); + } + return aCount > 0 ? opencascade::hashBytes(aCombination, sizeof(size_t) * aCount) : 0; + } + }; +} + #endif // _XCAFPrs_Style_HeaderFile diff --git a/src/XDEDRAW/XDEDRAW.cxx b/src/XDEDRAW/XDEDRAW.cxx index 71561d359e..df4c0a2da9 100644 --- a/src/XDEDRAW/XDEDRAW.cxx +++ b/src/XDEDRAW/XDEDRAW.cxx @@ -944,7 +944,7 @@ private: } private: - NCollection_Map + NCollection_Map myNameMap; //!< names map to handle collisions Handle(TDocStd_Document) myDoc; //!< document TCollection_AsciiString myDocName; //!< document name diff --git a/src/XSDRAWSTLVRML/XSDRAWSTLVRML_CoordsMap.hxx b/src/XSDRAWSTLVRML/XSDRAWSTLVRML_CoordsMap.hxx index 05f130df44..509d05936f 100644 --- a/src/XSDRAWSTLVRML/XSDRAWSTLVRML_CoordsMap.hxx +++ b/src/XSDRAWSTLVRML/XSDRAWSTLVRML_CoordsMap.hxx @@ -17,11 +17,10 @@ #define XSDRAWSTLVRML_CoordsMap_HeaderFile #include -#include #include -typedef NCollection_DataMap XSDRAWSTLVRML_CoordsMap; -typedef NCollection_DataMap::Iterator XSDRAWSTLVRML_DataMapIteratorOfCoordsMap; +typedef NCollection_DataMap XSDRAWSTLVRML_CoordsMap; +typedef NCollection_DataMap::Iterator XSDRAWSTLVRML_DataMapIteratorOfCoordsMap; #endif diff --git a/src/XSDRAWSTLVRML/XSDRAWSTLVRML_DataSource.hxx b/src/XSDRAWSTLVRML/XSDRAWSTLVRML_DataSource.hxx index 656d0dce07..ca59eac486 100644 --- a/src/XSDRAWSTLVRML/XSDRAWSTLVRML_DataSource.hxx +++ b/src/XSDRAWSTLVRML/XSDRAWSTLVRML_DataSource.hxx @@ -24,7 +24,6 @@ #include #include #include -#include #include #include diff --git a/src/XSDRAWSTLVRML/XSDRAWSTLVRML_DataSource3D.hxx b/src/XSDRAWSTLVRML/XSDRAWSTLVRML_DataSource3D.hxx index 13b7b3877b..aac3345e67 100644 --- a/src/XSDRAWSTLVRML/XSDRAWSTLVRML_DataSource3D.hxx +++ b/src/XSDRAWSTLVRML/XSDRAWSTLVRML_DataSource3D.hxx @@ -27,7 +27,6 @@ #include #include #include -#include #include diff --git a/src/XSDRAWSTLVRML/XSDRAWSTLVRML_ElemNodesMap.hxx b/src/XSDRAWSTLVRML/XSDRAWSTLVRML_ElemNodesMap.hxx index c1f3c6e574..65445ec081 100644 --- a/src/XSDRAWSTLVRML/XSDRAWSTLVRML_ElemNodesMap.hxx +++ b/src/XSDRAWSTLVRML/XSDRAWSTLVRML_ElemNodesMap.hxx @@ -17,11 +17,10 @@ #define XSDRAWSTLVRML_ElemNodesMap_HeaderFile #include -#include #include -typedef NCollection_DataMap XSDRAWSTLVRML_ElemNodesMap; -typedef NCollection_DataMap::Iterator XSDRAWSTLVRML_DataMapIteratorOfElemNodesMap; +typedef NCollection_DataMap XSDRAWSTLVRML_ElemNodesMap; +typedef NCollection_DataMap::Iterator XSDRAWSTLVRML_DataMapIteratorOfElemNodesMap; #endif diff --git a/src/XmlMDF/XmlMDF_MapOfDriver.hxx b/src/XmlMDF/XmlMDF_MapOfDriver.hxx index de6ebd1ae2..a60f8ee14b 100644 --- a/src/XmlMDF/XmlMDF_MapOfDriver.hxx +++ b/src/XmlMDF/XmlMDF_MapOfDriver.hxx @@ -20,8 +20,8 @@ #include #include -typedef NCollection_DataMap XmlMDF_MapOfDriver; -typedef NCollection_DataMap::Iterator XmlMDF_DataMapIteratorOfMapOfDriver; +typedef NCollection_DataMap XmlMDF_MapOfDriver; +typedef NCollection_DataMap::Iterator XmlMDF_DataMapIteratorOfMapOfDriver; #endif diff --git a/src/XmlMDF/XmlMDF_TypeADriverMap.hxx b/src/XmlMDF/XmlMDF_TypeADriverMap.hxx index 028473053a..b4ddd1cb5e 100644 --- a/src/XmlMDF/XmlMDF_TypeADriverMap.hxx +++ b/src/XmlMDF/XmlMDF_TypeADriverMap.hxx @@ -18,11 +18,10 @@ #include #include -#include #include -typedef NCollection_DataMap XmlMDF_TypeADriverMap; -typedef NCollection_DataMap::Iterator XmlMDF_DataMapIteratorOfTypeADriverMap; +typedef NCollection_DataMap XmlMDF_TypeADriverMap; +typedef NCollection_DataMap::Iterator XmlMDF_DataMapIteratorOfTypeADriverMap; #endif diff --git a/src/XmlTObjDrivers/XmlTObjDrivers.hxx b/src/XmlTObjDrivers/XmlTObjDrivers.hxx index af3d4b060f..9f816b21f6 100644 --- a/src/XmlTObjDrivers/XmlTObjDrivers.hxx +++ b/src/XmlTObjDrivers/XmlTObjDrivers.hxx @@ -18,7 +18,6 @@ #ifndef XmlTObjDrivers_HeaderFile #define XmlTObjDrivers_HeaderFile -#include #include class XmlMDF_ADriverTable; diff --git a/src/XmlTObjDrivers/XmlTObjDrivers_DocumentRetrievalDriver.hxx b/src/XmlTObjDrivers/XmlTObjDrivers_DocumentRetrievalDriver.hxx index 43fb21757d..291b22da42 100644 --- a/src/XmlTObjDrivers/XmlTObjDrivers_DocumentRetrievalDriver.hxx +++ b/src/XmlTObjDrivers/XmlTObjDrivers_DocumentRetrievalDriver.hxx @@ -18,7 +18,6 @@ #ifndef XmlTObjDrivers_DocumentRetrievalDriver_HeaderFile #define XmlTObjDrivers_DocumentRetrievalDriver_HeaderFile -#include #include #include diff --git a/src/XmlTObjDrivers/XmlTObjDrivers_DocumentStorageDriver.hxx b/src/XmlTObjDrivers/XmlTObjDrivers_DocumentStorageDriver.hxx index 544bb4d4dc..39cea7bcf2 100644 --- a/src/XmlTObjDrivers/XmlTObjDrivers_DocumentStorageDriver.hxx +++ b/src/XmlTObjDrivers/XmlTObjDrivers_DocumentStorageDriver.hxx @@ -18,7 +18,6 @@ #ifndef XmlTObjDrivers_DocumentStorageDriver_HeaderFile #define XmlTObjDrivers_DocumentStorageDriver_HeaderFile -#include #include #include diff --git a/src/XmlTObjDrivers/XmlTObjDrivers_ObjectDriver.hxx b/src/XmlTObjDrivers/XmlTObjDrivers_ObjectDriver.hxx index 4a04cfb2a3..a2bced0c6c 100644 --- a/src/XmlTObjDrivers/XmlTObjDrivers_ObjectDriver.hxx +++ b/src/XmlTObjDrivers/XmlTObjDrivers_ObjectDriver.hxx @@ -19,7 +19,6 @@ #ifndef XmlTObjDrivers_ObjectDriver_HeaderFile #define XmlTObjDrivers_ObjectDriver_HeaderFile -#include #include class XmlTObjDrivers_ObjectDriver : public XmlMDF_ADriver diff --git a/src/gp/gp_Pnt.hxx b/src/gp/gp_Pnt.hxx index 09667d182d..f16c906e9e 100644 --- a/src/gp/gp_Pnt.hxx +++ b/src/gp/gp_Pnt.hxx @@ -214,6 +214,39 @@ private: }; +namespace std +{ + template <> + struct hash + { + size_t operator()(const gp_Pnt& thePnt) const noexcept + { + union + { + Standard_Real R[3]; + Standard_Integer I[6]; + } U; + + thePnt.Coord(U.R[0], U.R[1], U.R[2]); + + return std::hash{}(U.I[0] / 23 + U.I[1] / 19 + U.I[2] / 17 + U.I[3] / 13 + U.I[4] / 11 + U.I[5] / 7); + } + }; + + template<> + struct equal_to + { + bool operator()(const gp_Pnt& thePnt1, + const gp_Pnt& thePnt2) const noexcept + { + if (Abs(thePnt1.X() - thePnt2.X()) > Epsilon(thePnt2.X())) return false; + if (Abs(thePnt1.Y() - thePnt2.Y()) > Epsilon(thePnt2.Y())) return false; + if (Abs(thePnt1.Z() - thePnt2.Z()) > Epsilon(thePnt2.Z())) return false; + return true; + } + }; +} + #include #include #include diff --git a/src/math/FILES b/src/math/FILES index c371253135..d1c626a2ba 100755 --- a/src/math/FILES +++ b/src/math/FILES @@ -74,7 +74,6 @@ math_GlobOptMin.hxx math_Householder.cxx math_Householder.hxx math_Householder.lxx -math_IntegerVector.cxx math_IntegerVector.hxx math_Jacobi.cxx math_Jacobi.hxx @@ -122,5 +121,6 @@ math_Uzawa.cxx math_Uzawa.hxx math_Uzawa.lxx math_ValueAndWeight.hxx -math_Vector.cxx +math_VectorBase.hxx +math_VectorBase.lxx math_Vector.hxx diff --git a/src/math/math_IntegerVector.cxx b/src/math/math_IntegerVector.cxx deleted file mode 100644 index 60541a3e95..0000000000 --- a/src/math/math_IntegerVector.cxx +++ /dev/null @@ -1,336 +0,0 @@ -// Copyright (c) 1997-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#include - -#include -#include - -math_IntegerVector::math_IntegerVector(const Standard_Integer theFirst, const Standard_Integer theLast) -: myLocArray (theLast - theFirst + 1), - Array (myLocArray[0], theFirst, theLast) -{ - // -} - -math_IntegerVector::math_IntegerVector(const Standard_Integer theFirst, - const Standard_Integer theLast, - const Standard_Integer theInitialValue) -: myLocArray (theLast - theFirst + 1), - Array (myLocArray[0], theFirst, theLast) -{ - Array.Init(theInitialValue); -} - -math_IntegerVector::math_IntegerVector(const Standard_Integer* theTab, - const Standard_Integer theFirst, - const Standard_Integer theLast) -: Array (*theTab, theFirst, theLast) -{ - Standard_RangeError_Raise_if(theFirst > theLast, " "); -} - -void math_IntegerVector::Init(const Standard_Integer theInitialValue) -{ - Array.Init(theInitialValue); -} - -math_IntegerVector::math_IntegerVector (const math_IntegerVector& theOther) -: myLocArray (theOther.Length()), - Array (myLocArray[0], theOther.Lower(), theOther.Upper()) -{ - memcpy (&myLocArray[0], &theOther.Array.First(), sizeof(Standard_Integer) * theOther.Length()); -} - -void math_IntegerVector::SetFirst(const Standard_Integer theFirst) -{ - Array.Resize (theFirst, Array.Upper() - Array.Lower() + theFirst, Standard_False); -} - -Standard_Real math_IntegerVector::Norm() const -{ - Standard_Real Result = 0; - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Result = Result + Array(Index) * Array(Index); - } - return Sqrt(Result); -} - -Standard_Real math_IntegerVector::Norm2() const -{ - Standard_Real Result = 0; - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Result = Result + Array(Index) * Array(Index); - } - return Result; -} - -Standard_Integer math_IntegerVector::Max() const -{ - Standard_Integer I=0; - Standard_Real X = RealFirst(); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - if(Array(Index) > X) - { - X = Array(Index); - I = Index; - } - } - return I; -} - -Standard_Integer math_IntegerVector::Min() const -{ - Standard_Integer I=0; - Standard_Real X = RealLast(); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - if(Array(Index) < X) - { - X = Array(Index); - I = Index; - } - } - return I; -} - -void math_IntegerVector::Invert() -{ - Standard_Integer J; - Standard_Integer Temp; - - for(Standard_Integer Index = Lower(); Index <= Lower() + Length() / 2 ; Index++) - { - J = Upper() + Lower() - Index; - Temp = Array(Index); - Array(Index) = Array(J); - Array(J) = Temp; - } -} - -math_IntegerVector math_IntegerVector::Inverse() const -{ - math_IntegerVector Result = *this; - Result.Invert(); - return Result; -} - -void math_IntegerVector::Set(const Standard_Integer theI1, - const Standard_Integer theI2, - const math_IntegerVector &theV) -{ - Standard_DimensionError_Raise_if((theI1 < Lower()) || (theI2 > Upper()) || - (theI1 > theI2) || (theI2 - theI1 + 1 != theV.Length()), " "); - - Standard_Integer I = theV.Lower(); - for(Standard_Integer Index = theI1; Index <= theI2; Index++) - { - Array(Index) = theV.Array(I); - I++; - } -} - -void math_IntegerVector::Multiply(const Standard_Integer theRight) -{ - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Array(Index) = Array(Index) * theRight; - } -} - -void math_IntegerVector::Add(const math_IntegerVector& theRight) -{ - Standard_DimensionError_Raise_if(Length() != theRight.Length(), " "); - - Standard_Integer I = theRight.Lower(); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Array(Index) = Array(Index) + theRight.Array(I); - I++; - } -} - -void math_IntegerVector::Subtract(const math_IntegerVector& theRight) -{ - Standard_DimensionError_Raise_if(Length() != theRight.Length(), " "); - Standard_Integer I = theRight.Lower(); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Array(Index) = Array(Index) - theRight.Array(I); - I++; - } -} - -math_IntegerVector math_IntegerVector::Slice(const Standard_Integer theI1, - const Standard_Integer theI2) const -{ - Standard_DimensionError_Raise_if((theI1 < Lower()) || (theI1 > Upper()) || - (theI2 < Lower()) || (theI2 > Upper()), " "); - - if(theI2 >= theI1) - { - math_IntegerVector Result(theI1, theI2); - for(Standard_Integer Index = theI1; Index <= theI2; Index++) - { - Result.Array(Index) = Array(Index); - } - return Result; - } - else - { - math_IntegerVector Result(theI2, theI1); - for(Standard_Integer Index = theI1; Index >= theI2; Index--) - { - Result.Array(Index) = Array(Index); - } - return Result; - } -} - -Standard_Integer math_IntegerVector::Multiplied (const math_IntegerVector& theRight) const -{ - Standard_Integer Result = 0; - - Standard_DimensionError_Raise_if(Length() != theRight.Length(), " "); - - Standard_Integer I = theRight.Lower(); - for(Standard_Integer Index = 0; Index < Length(); Index++) - { - Result = Result + Array(Index) * theRight.Array(I); - I++; - } - return Result; -} - -math_IntegerVector math_IntegerVector::Multiplied (const Standard_Integer theRight)const -{ - math_IntegerVector Result(Lower(), Upper()); - - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Result.Array(Index) = Array(Index) * theRight; - } - return Result; -} - -math_IntegerVector math_IntegerVector::TMultiplied (const Standard_Integer theRight) const -{ - math_IntegerVector Result(Lower(), Upper()); - - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Result.Array(Index) = Array(Index) * theRight; - } - return Result; -} - -math_IntegerVector math_IntegerVector::Added (const math_IntegerVector& theRight) const -{ - Standard_DimensionError_Raise_if(Length() != theRight.Length(), " "); - - math_IntegerVector Result(Lower(), Upper()); - - Standard_Integer I = theRight.Lower(); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Result.Array(Index) = Array(Index) + theRight.Array(I); - I++; - } - return Result; -} - -math_IntegerVector math_IntegerVector::Opposite() -{ - math_IntegerVector Result(Lower(), Upper()); - - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Result.Array(Index) = - Array(Index); - } - return Result; -} - -math_IntegerVector math_IntegerVector::Subtracted (const math_IntegerVector& theRight) const -{ - Standard_DimensionError_Raise_if(Length() != theRight.Length(), " "); - - math_IntegerVector Result(Lower(), Upper()); - - Standard_Integer I = theRight.Lower(); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Result.Array(Index) = Array(Index) - theRight.Array(I); - I++; - } - return Result; -} - -void math_IntegerVector::Add (const math_IntegerVector& theLeft, const math_IntegerVector& theRight) -{ - Standard_DimensionError_Raise_if((Length() != theRight.Length()) || - (theRight.Length() != theLeft.Length()), " "); - - Standard_Integer I = theLeft.Lower(); - Standard_Integer J = theRight.Lower(); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Array(Index) = theLeft.Array(I) + theRight.Array(J); - I++; - J++; - } -} - -void math_IntegerVector::Subtract (const math_IntegerVector& theLeft, - const math_IntegerVector& theRight) -{ - Standard_DimensionError_Raise_if((Length() != theRight.Length()) || - (theRight.Length() != theLeft.Length()), " "); - - Standard_Integer I = theLeft.Lower(); - Standard_Integer J = theRight.Lower(); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Array(Index) = theLeft.Array(I) - theRight.Array(J); - I++; - J++; - } -} - -void math_IntegerVector::Multiply(const Standard_Integer theLeft, const math_IntegerVector& theRight) -{ - Standard_DimensionError_Raise_if((Length() != theRight.Length()), " "); - for(Standard_Integer I = Lower(); I <= Upper(); I++) - { - Array(I) = theLeft * theRight.Array(I); - } -} - -math_IntegerVector& math_IntegerVector::Initialized(const math_IntegerVector& theOther) -{ - Standard_DimensionError_Raise_if(Length() != theOther.Length(), " "); - memmove (&Array.ChangeFirst(), &theOther.Array.First(), sizeof(Standard_Integer) * Array.Length()); - return *this; -} - -void math_IntegerVector::Dump(Standard_OStream& theO) const -{ - theO << "math_IntegerVector of Range = " << Length() << "\n"; - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - theO << "math_IntegerVector(" << Index << ") = " << Array(Index) << "\n"; - } -} diff --git a/src/math/math_IntegerVector.hxx b/src/math/math_IntegerVector.hxx index 3ff5d0f017..d7b3f2c37a 100644 --- a/src/math/math_IntegerVector.hxx +++ b/src/math/math_IntegerVector.hxx @@ -15,13 +15,7 @@ #ifndef _math_IntegerVector_HeaderFile #define _math_IntegerVector_HeaderFile -#include -#include - -// resolve name collisions with X11 headers -#ifdef Opposite - #undef Opposite -#endif +#include //! This class implements the real IntegerVector abstract data type. //! IntegerVectors can have an arbitrary range which must be define at @@ -52,221 +46,7 @@ //! V3 = V1; // --> will raise DimensionError; //! V1.Add(V3) // --> will raise DimensionError; //! @endcode -class math_IntegerVector -{ -public: - - DEFINE_STANDARD_ALLOC - - //! constructs an IntegerVector in the range [Lower..Upper] - Standard_EXPORT math_IntegerVector(const Standard_Integer theFirst, const Standard_Integer theLast); - - //! constructs an IntegerVector in the range [Lower..Upper] - //! with all the elements set to theInitialValue. - Standard_EXPORT math_IntegerVector(const Standard_Integer theFirst, const Standard_Integer theLast, const Standard_Integer theInitialValue); - - //! Initialize an IntegerVector with all the elements - //! set to theInitialValue. - Standard_EXPORT void Init(const Standard_Integer theInitialValue); - - //! constructs an IntegerVector in the range [Lower..Upper] - //! which share the "c array" theTab. - Standard_EXPORT math_IntegerVector(const Standard_Integer* theTab, const Standard_Integer theFirst, const Standard_Integer theLast); - - //! constructs a copy for initialization. - //! An exception is raised if the lengths of the IntegerVectors - //! are different. - Standard_EXPORT math_IntegerVector(const math_IntegerVector& theOther); - - //! returns the length of an IntegerVector - inline Standard_Integer Length() const - { - return Array.Length(); - } - - //! returns the value of the Lower index of an IntegerVector. - inline Standard_Integer Lower() const - { - return Array.Lower(); - } - - //! returns the value of the Upper index of an IntegerVector. - inline Standard_Integer Upper() const - { - return Array.Upper(); - } - - //! returns the value of the norm of an IntegerVector. - Standard_EXPORT Standard_Real Norm() const; - - //! returns the value of the square of the norm of an IntegerVector. - Standard_EXPORT Standard_Real Norm2() const; - - //! returns the value of the Index of the maximum element of an IntegerVector. - Standard_EXPORT Standard_Integer Max() const; - - //! returns the value of the Index of the minimum element of an IntegerVector. - Standard_EXPORT Standard_Integer Min() const; - - //! inverses an IntegerVector. - Standard_EXPORT void Invert(); - - //! returns the inverse IntegerVector of an IntegerVector. - Standard_EXPORT math_IntegerVector Inverse() const; - - //! sets an IntegerVector from "theI1" to "theI2" to the IntegerVector "theV"; - //! An exception is raised if "theI1" is less than "LowerIndex" or "theI2" is greater than "UpperIndex" or "theI1" is greater than "theI2". - //! An exception is raised if "theI2-theI1+1" is different from the Length of "theV". - Standard_EXPORT void Set(const Standard_Integer theI1, const Standard_Integer theI2, const math_IntegerVector& theV); - - //! slices the values of the IntegerVector between "theI1" and "theI2": - //! Example: [2, 1, 2, 3, 4, 5] becomes [2, 4, 3, 2, 1, 5] between 2 and 5. - //! An exception is raised if "theI1" is less than "LowerIndex" or "theI2" is greater than "UpperIndex". - Standard_EXPORT math_IntegerVector Slice(const Standard_Integer theI1, const Standard_Integer theI2) const; - - //! returns the product of an IntegerVector by an integer value. - Standard_EXPORT void Multiply(const Standard_Integer theRight); - - void operator *=(const Standard_Integer theRight) - { - Multiply(theRight); - } - - //! returns the product of an IntegerVector by an integer value. - Standard_NODISCARD Standard_EXPORT math_IntegerVector Multiplied(const Standard_Integer theRight) const; - - Standard_NODISCARD math_IntegerVector operator*(const Standard_Integer theRight) const - { - return Multiplied(theRight); - } - - //! returns the product of a vector and a real value. - Standard_NODISCARD Standard_EXPORT math_IntegerVector TMultiplied(const Standard_Integer theRight) const; - - friend inline math_IntegerVector operator* (const Standard_Integer theLeft, const math_IntegerVector& theRight) - { - return theRight.Multiplied(theLeft); - } - - //! adds the IntegerVector "theRight" to an IntegerVector. - //! An exception is raised if the IntegerVectors have not the same length. - //! An exception is raised if the lengths are not equal. - Standard_EXPORT void Add(const math_IntegerVector& theRight); - - void operator +=(const math_IntegerVector& theRight) - { - Add(theRight); - } - - //! adds the IntegerVector "theRight" to an IntegerVector. - //! An exception is raised if the IntegerVectors have not the same length. - //! An exception is raised if the lengths are not equal. - Standard_NODISCARD Standard_EXPORT math_IntegerVector Added(const math_IntegerVector& theRight) const; - - Standard_NODISCARD math_IntegerVector operator+(const math_IntegerVector& theRight) const - { - return Added(theRight); - } - - //! sets an IntegerVector to the sum of the IntegerVector - //! "theLeft" and the IntegerVector "theRight". - //! An exception is raised if the lengths are different. - Standard_EXPORT void Add(const math_IntegerVector& theLeft, const math_IntegerVector& theRight); - - //! sets an IntegerVector to the substraction of "theRight" from "theLeft". - //! An exception is raised if the IntegerVectors have not the same length. - Standard_EXPORT void Subtract(const math_IntegerVector& theLeft, const math_IntegerVector& theRight); - - //! accesses the value of index theNum of an IntegerVector. - const Standard_Integer& Value (const Standard_Integer theNum) const - { - return Array(theNum); - } - - //! accesses (in read or write mode) the value of index theNum of an IntegerVector. - inline Standard_Integer& Value (const Standard_Integer theNum) - { - return Array(theNum); - } - - const Standard_Integer& operator()(const Standard_Integer theNum) const - { - return Value(theNum); - } - - Standard_Integer& operator()(const Standard_Integer theNum) - { - return Value(theNum); - } - - //! Initialises an IntegerVector by copying "theOther". - //! An exception is raised if the Lengths are different. - Standard_EXPORT math_IntegerVector& Initialized(const math_IntegerVector& theOther); - - math_IntegerVector& operator=(const math_IntegerVector& theOther) - { - return Initialized(theOther); - } - - //! returns the inner product of 2 IntegerVectors. - //! An exception is raised if the lengths are not equal. - Standard_NODISCARD Standard_EXPORT Standard_Integer Multiplied(const math_IntegerVector& theRight) const; - - Standard_NODISCARD Standard_Integer operator*(const math_IntegerVector& theRight) const - { - return Multiplied(theRight); - } - - //! returns the opposite of an IntegerVector. - Standard_EXPORT math_IntegerVector Opposite(); - - math_IntegerVector operator-() - { - return Opposite(); - } - - //! returns the subtraction of "theRight" from "me". - //! An exception is raised if the IntegerVectors have not the same length. - Standard_EXPORT void Subtract(const math_IntegerVector& theRight); - - void operator-=(const math_IntegerVector& theRight) - { - Subtract(theRight); - } - - //! returns the subtraction of "theRight" from "me". - //! An exception is raised if the IntegerVectors have not the same length. - Standard_NODISCARD Standard_EXPORT math_IntegerVector Subtracted(const math_IntegerVector& theRight) const; - - Standard_NODISCARD math_IntegerVector operator-(const math_IntegerVector& theRight) const - { - return Subtracted(theRight); - } - - //! returns the multiplication of an integer by an IntegerVector. - Standard_EXPORT void Multiply(const Standard_Integer theLeft,const math_IntegerVector& theRight); - - //! Prints on the stream theO information on the current state of the object. - //! Is used to redefine the operator <<. - Standard_EXPORT void Dump(Standard_OStream& theO) const; - - friend inline Standard_OStream& operator<<(Standard_OStream& theO, const math_IntegerVector& theVec) - { - theVec.Dump(theO); - return theO; - } - -protected: - - //! is used internally to set the Lower value of the IntegerVector. - void SetFirst(const Standard_Integer theFirst); - -private: - - NCollection_LocalArray myLocArray; - NCollection_Array1 Array; - -}; +using math_IntegerVector = math_VectorBase; #endif diff --git a/src/math/math_Matrix.cxx b/src/math/math_Matrix.cxx index 5fa865e747..9d05df4251 100644 --- a/src/math/math_Matrix.cxx +++ b/src/math/math_Matrix.cxx @@ -12,9 +12,10 @@ // Alternatively, this file may be used under the terms of Open CASCADE // commercial license or contractual agreement. +#include #include -#include +#include #include #include #include @@ -644,6 +645,15 @@ math_Vector math_Matrix::Multiplied(const math_Vector& Right)const return Result; } +//================================================================ +// Function : operator* +// Purpose : +//================================================================ +math_VectorBase<> math_Matrix::operator* (const math_VectorBase<>& Right) const +{ + return Multiplied(Right); +} + math_Matrix& math_Matrix::Initialized(const math_Matrix& Other) { Standard_DimensionError_Raise_if ((RowNumber() != Other.RowNumber()) diff --git a/src/math/math_Matrix.hxx b/src/math/math_Matrix.hxx index 3373a44a46..d3d6feeba8 100644 --- a/src/math/math_Matrix.hxx +++ b/src/math/math_Matrix.hxx @@ -19,9 +19,9 @@ #include #include +#include #include -#include #include // resolve name collisions with X11 headers @@ -29,6 +29,8 @@ #undef Opposite #endif +template class math_VectorBase; + //! This class implements the real matrix abstract data type. //! Matrixes can have an arbitrary range which must be defined //! at the declaration and cannot be changed after this declaration @@ -74,6 +76,7 @@ public: DEFINE_STANDARD_ALLOC + friend class math_VectorBase<>; //! Constructs a non-initialized matrix of range [LowerRow..UpperRow, //! LowerCol..UpperCol] @@ -278,24 +281,24 @@ Standard_NODISCARD math_Matrix operator- (const math_Matrix& Right) const //! An exception is raised if the dimensions are different. //! An exception is raises if is inferior to the lower //! row of the matrix or is superior to the upper row. - Standard_EXPORT void SetRow (const Standard_Integer Row, const math_Vector& V); + Standard_EXPORT void SetRow (const Standard_Integer Row, const math_VectorBase<>& V); //! Sets the column of index Col of a matrix to the vector . //! An exception is raised if the dimensions are different. //! An exception is raises if is inferior to the lower //! column of the matrix or is superior to the upper //! column. - Standard_EXPORT void SetCol (const Standard_Integer Col, const math_Vector& V); + Standard_EXPORT void SetCol (const Standard_Integer Col, const math_VectorBase<>& V); //! Sets the diagonal of a matrix to the value . //! An exception is raised if the matrix is not square. Standard_EXPORT void SetDiag (const Standard_Real Value); //! Returns the row of index Row of a matrix. - Standard_EXPORT math_Vector Row (const Standard_Integer Row) const; + Standard_EXPORT math_VectorBase<> Row (const Standard_Integer Row) const; //! Returns the column of index of a matrix. - Standard_EXPORT math_Vector Col (const Standard_Integer Col) const; + Standard_EXPORT math_VectorBase<> Col (const Standard_Integer Col) const; //! Swaps the rows of index Row1 and Row2. //! An exception is raised if or is out of range. @@ -322,7 +325,7 @@ Standard_NODISCARD math_Matrix operator- (const math_Matrix& Right) const //! Computes a matrix as the product of 2 vectors. //! An exception is raised if the dimensions are different. //! = * . - Standard_EXPORT void Multiply (const math_Vector& Left, const math_Vector& Right); + Standard_EXPORT void Multiply (const math_VectorBase<>& Left, const math_VectorBase<>& Right); //! Computes a matrix as the product of 2 matrixes. //! An exception is raised if the dimensions are different. @@ -374,11 +377,8 @@ Standard_NODISCARD math_Matrix operator* (const math_Matrix& Right) const //! Returns the product of a matrix by a vector. //! An exception is raised if the dimensions are different. - Standard_NODISCARD Standard_EXPORT math_Vector Multiplied (const math_Vector& Right) const; -Standard_NODISCARD math_Vector operator* (const math_Vector& Right) const -{ - return Multiplied(Right); -} + Standard_NODISCARD Standard_EXPORT math_VectorBase<> Multiplied (const math_VectorBase<>& Right) const; + Standard_NODISCARD Standard_EXPORT math_VectorBase<> operator* (const math_VectorBase<>& Right) const; //! Returns the opposite of a matrix. //! An exception is raised if the dimensions are different. @@ -392,10 +392,6 @@ math_Matrix operator-() //! Is used to redefine the operator <<. Standard_EXPORT void Dump (Standard_OStream& o) const; - -friend class math_Vector; - - protected: @@ -409,7 +405,7 @@ protected: //! The new lower row of the matrix is set to //! and the new lower column of the matrix is set to the column //! of range . - void SetLower (const Standard_Integer LowerRow, const Standard_Integer LowerCol); + void SetLower (const Standard_Integer LowerRow, const Standard_Integer LowerCol); diff --git a/src/math/math_Matrix.lxx b/src/math/math_Matrix.lxx index e61b206eef..a5397716eb 100644 --- a/src/math/math_Matrix.lxx +++ b/src/math/math_Matrix.lxx @@ -15,7 +15,6 @@ // lpa le 29/10/91 #include -#include inline Standard_OStream& operator<<(Standard_OStream& o, const math_Matrix& mat) diff --git a/src/math/math_Recipes.hxx b/src/math/math_Recipes.hxx index 50a79acb97..8c6a100f03 100644 --- a/src/math/math_Recipes.hxx +++ b/src/math/math_Recipes.hxx @@ -17,8 +17,11 @@ #include -class math_IntegerVector; -class math_Vector; +#include + +template class math_VectorBase; +using math_IntegerVector = math_VectorBase; +using math_Vector = math_VectorBase; class math_Matrix; const Standard_Integer math_Status_UserAborted = -1; diff --git a/src/math/math_Vector.cxx b/src/math/math_Vector.cxx deleted file mode 100644 index b57bbe39d5..0000000000 --- a/src/math/math_Vector.cxx +++ /dev/null @@ -1,502 +0,0 @@ -// Copyright (c) 1997-1999 Matra Datavision -// Copyright (c) 1999-2014 OPEN CASCADE SAS -// -// This file is part of Open CASCADE Technology software library. -// -// This library is free software; you can redistribute it and/or modify it under -// the terms of the GNU Lesser General Public License version 2.1 as published -// by the Free Software Foundation, with special exception defined in the file -// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT -// distribution for complete text of the license and disclaimer of any warranty. -// -// Alternatively, this file may be used under the terms of Open CASCADE -// commercial license or contractual agreement. - -#include - -#include -#include - -#include -#include -#include -#include - -math_Vector::math_Vector(const Standard_Integer theLower, const Standard_Integer theUpper) -: myLocArray (theUpper - theLower + 1), - Array (myLocArray[0], theLower, theUpper) -{ - // -} - -math_Vector::math_Vector(const Standard_Integer theLower, - const Standard_Integer theUpper, - const Standard_Real theInitialValue) -: myLocArray (theUpper - theLower + 1), - Array (myLocArray[0], theLower, theUpper) -{ - Array.Init(theInitialValue); -} - -math_Vector::math_Vector(const Standard_Real* theTab, - const Standard_Integer theLower, - const Standard_Integer theUpper) -: Array (*theTab, theLower, theUpper) -{ - Standard_RangeError_Raise_if ((theLower > theUpper), "math_Vector() - invalid dimensions"); -} - -math_Vector::math_Vector (const gp_XY& theOther) -: myLocArray (2), - Array (myLocArray[0], 1,2) -{ - Array(1) = theOther.X(); - Array(2) = theOther.Y(); -} - -math_Vector::math_Vector (const gp_XYZ& theOther) -: myLocArray (3), - Array (myLocArray[0], 1, 3) -{ - Array(1) = theOther.X(); - Array(2) = theOther.Y(); - Array(3) = theOther.Z(); -} - -void math_Vector::Init(const Standard_Real theInitialValue) -{ - Array.Init(theInitialValue); -} - -math_Vector::math_Vector (const math_Vector& theOther) -: myLocArray (theOther.Length()), - Array (myLocArray[0], theOther.Lower(), theOther.Upper()) -{ - memcpy (&myLocArray[0], &theOther.Array.First(), sizeof(Standard_Real) * theOther.Length()); -} - -void math_Vector::SetLower(const Standard_Integer theLower) -{ - Array.Resize (theLower, Array.Upper() - Array.Lower() + theLower, Standard_False); -} - -Standard_Real math_Vector::Norm() const -{ - Standard_Real Result = 0; - - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Result = Result + Array(Index) * Array(Index); - } - return Sqrt(Result); -} - -Standard_Real math_Vector::Norm2() const -{ - Standard_Real Result = 0; - - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Result = Result + Array(Index) * Array(Index); - } - return Result; -} - -Standard_Integer math_Vector::Max() const -{ - Standard_Integer I=0; - Standard_Real X = RealFirst(); - - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - if(Array(Index) > X) - { - X = Array(Index); - I = Index; - } - } - return I; -} - -Standard_Integer math_Vector::Min() const -{ - Standard_Integer I=0; - Standard_Real X = RealLast(); - - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - if(Array(Index) < X) - { - X = Array(Index); - I = Index; - } - } - return I; -} - -void math_Vector::Set(const Standard_Integer theI1, - const Standard_Integer theI2, - const math_Vector &theV) -{ - Standard_RangeError_Raise_if ((theI1 < Lower()) || (theI2 > Upper()) - || (theI1 > theI2) || (theI2 - theI1 + 1 != theV.Length()), - "math_Vector::Set() - invalid indices"); - - Standard_Integer I = theV.Lower(); - for(Standard_Integer Index = theI1; Index <= theI2; Index++) - { - Array(Index) = theV.Array(I); - I++; - } -} - -void math_Vector::Normalize() -{ - Standard_Real Result = Norm(); - Standard_NullValue_Raise_if ((Result <= RealEpsilon()), - "math_Vector::Normalize() - vector has zero norm"); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Array(Index) = Array(Index) / Result; - } -} - -math_Vector math_Vector::Normalized() const -{ - math_Vector Result = *this; - - Result.Normalize(); - return Result; -} - -void math_Vector::Invert() -{ - for(Standard_Integer Index = Lower(); Index <= (Lower() + Length()) >> 1 ; Index++) - { - Standard_Integer J = Upper() + Lower() - Index; - Standard_Real aTemp = Array(Index); - Array(Index) = Array(J); - Array(J) = aTemp; - } -} - -math_Vector math_Vector::Inverse() const -{ - math_Vector Result = *this; - Result.Invert(); - return Result; -} - -math_Vector math_Vector::Multiplied(const Standard_Real theRight) const -{ - math_Vector Result (Lower(), Upper()); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Result.Array(Index) = Array(Index) * theRight; - } - return Result; -} - -math_Vector math_Vector::TMultiplied(const Standard_Real theRight) const -{ - math_Vector Result (Lower(), Upper()); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Result.Array(Index) = Array(Index) * theRight; - } - return Result; -} - -void math_Vector::Multiply(const Standard_Real theRight) -{ - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Array(Index) = Array(Index) * theRight; - } -} - -void math_Vector::Divide(const Standard_Real theRight) -{ - Standard_DivideByZero_Raise_if (Abs(theRight) <= RealEpsilon(), - "math_Vector::Divide() - devisor is zero"); - - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Array(Index) = Array(Index) / theRight; - } -} - -math_Vector math_Vector::Divided (const Standard_Real theRight) const -{ - Standard_DivideByZero_Raise_if (Abs(theRight) <= RealEpsilon(), - "math_Vector::Divided() - devisor is zero"); - math_Vector temp = Multiplied(1./theRight); - return temp; -} - -void math_Vector::Add(const math_Vector& theRight) -{ - Standard_DimensionError_Raise_if (Length() != theRight.Length(), - "math_Vector::Add() - input vector has wrong dimensions"); - - Standard_Integer I = theRight.Lower(); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Array(Index) = Array(Index) + theRight.Array(I); - I++; - } -} - -math_Vector math_Vector::Added(const math_Vector& theRight) const -{ - Standard_DimensionError_Raise_if (Length() != theRight.Length(), - "math_Vector::Added() - input vector has wrong dimensions"); - - math_Vector Result (Lower(), Upper()); - - Standard_Integer I = theRight.Lower(); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Result.Array(Index) = Array(Index) + theRight.Array(I); - I++; - } - return Result; -} - -void math_Vector::Subtract(const math_Vector& theRight) -{ - Standard_DimensionError_Raise_if (Length() != theRight.Length(), - "math_Vector::Subtract() - input vector has wrong dimensions"); - - Standard_Integer I = theRight.Lower(); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Array(Index) = Array(Index) - theRight.Array(I); - I++; - } -} - -math_Vector math_Vector::Subtracted (const math_Vector& theRight) const -{ - Standard_DimensionError_Raise_if (Length() != theRight.Length(), - "math_Vector::Subtracted() - input vector has wrong dimensions"); - - math_Vector Result(Lower(), Upper()); - - Standard_Integer I = theRight.Lower(); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Result.Array(Index) = Array(Index) - theRight.Array(I); - I++; - } - return Result; -} - -math_Vector math_Vector::Slice(const Standard_Integer theI1, const Standard_Integer theI2) const -{ - Standard_RangeError_Raise_if ((theI1 < Lower()) || (theI1 > Upper()) || (theI2 < Lower()) || (theI2 > Upper()), - "math_Vector::Slice() - invalid indices"); - - if(theI2 >= theI1) - { - math_Vector Result(theI1, theI2); - for(Standard_Integer Index = theI1; Index <= theI2; Index++) - { - Result.Array(Index) = Array(Index); - } - return Result; - } - else - { - math_Vector Result(theI2, theI1); - for(Standard_Integer Index = theI1; Index >= theI2; Index--) - { - Result.Array(Index) = Array(Index); - } - return Result; - } -} - -void math_Vector::Add (const math_Vector& theLeft, const math_Vector& theRight) -{ - Standard_DimensionError_Raise_if ((Length() != theRight.Length()) || (theRight.Length() != theLeft.Length()), - "math_Vector::Add() - input vectors have wrong dimensions"); - - Standard_Integer I = theLeft.Lower(); - Standard_Integer J = theRight.Lower(); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Array(Index) = theLeft.Array(I) + theRight.Array(J); - I++; - J++; - } -} - -void math_Vector::Subtract (const math_Vector& theLeft, const math_Vector& theRight) -{ - Standard_DimensionError_Raise_if ((Length() != theRight.Length()) || (theRight.Length() != theLeft.Length()), - "math_Vector::Subtract() - input vectors have wrong dimensions"); - - Standard_Integer I = theLeft.Lower(); - Standard_Integer J = theRight.Lower(); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Array(Index) = theLeft.Array(I) - theRight.Array(J); - I++; - J++; - } -} - -void math_Vector::Multiply(const math_Matrix& theLeft, const math_Vector& theRight) -{ - Standard_DimensionError_Raise_if ((Length() != theLeft.RowNumber()) - || (theLeft.ColNumber() != theRight.Length()), - "math_Vector::Multiply() - input matrix and/or vector have wrong dimensions"); - - Standard_Integer Index = Lower(); - for(Standard_Integer I = theLeft.LowerRowIndex; I <= theLeft.UpperRowIndex; I++) - { - Array(Index) = 0.0; - Standard_Integer K = theRight.Lower(); - for(Standard_Integer J = theLeft.LowerColIndex; J <= theLeft.UpperColIndex; J++) - { - Array(Index) = Array(Index) + theLeft.Array(I, J) * theRight.Array(K); - K++; - } - Index++; - } -} - -void math_Vector::Multiply(const math_Vector& theLeft, const math_Matrix& theRight) -{ - Standard_DimensionError_Raise_if ((Length() != theRight.ColNumber()) - || (theLeft.Length() != theRight.RowNumber()), - "math_Vector::Multiply() - input matrix and/or vector have wrong dimensions"); - - Standard_Integer Index = Lower(); - for(Standard_Integer J = theRight.LowerColIndex; J <= theRight.UpperColIndex; J++) - { - Array(Index) = 0.0; - Standard_Integer K = theLeft.Lower(); - for(Standard_Integer I = theRight.LowerRowIndex; I <= theRight.UpperRowIndex; I++) - { - Array(Index) = Array(Index) + theLeft.Array(K) * theRight.Array(I, J); - K++; - } - Index++; - } -} - -void math_Vector::TMultiply(const math_Matrix& theTLeft, const math_Vector& theRight) -{ - Standard_DimensionError_Raise_if ((Length() != theTLeft.ColNumber()) - || (theTLeft.RowNumber() != theRight.Length()), - "math_Vector::TMultiply() - input matrix and/or vector have wrong dimensions"); - - Standard_Integer Index = Lower(); - for(Standard_Integer I = theTLeft.LowerColIndex; I <= theTLeft.UpperColIndex; I++) - { - Array(Index) = 0.0; - Standard_Integer K = theRight.Lower(); - for(Standard_Integer J = theTLeft.LowerRowIndex; J <= theTLeft.UpperRowIndex; J++) - { - Array(Index) = Array(Index) + theTLeft.Array(J, I) * theRight.Array(K); - K++; - } - Index++; - } -} - -void math_Vector::TMultiply(const math_Vector& theLeft, const math_Matrix& theTRight) -{ - Standard_DimensionError_Raise_if ((Length() != theTRight.RowNumber()) - || (theLeft.Length() != theTRight.ColNumber()), - "math_Vector::TMultiply() - input matrix and/or vector have wrong dimensions"); - - Standard_Integer Index = Lower(); - for(Standard_Integer J = theTRight.LowerRowIndex; J <= theTRight.UpperRowIndex; J++) - { - Array(Index) = 0.0; - Standard_Integer K = theLeft.Lower(); - for(Standard_Integer I = theTRight.LowerColIndex; - I <= theTRight.UpperColIndex; I++) - { - Array(Index) = Array(Index) + theLeft.Array(K) * theTRight.Array(J, I); - K++; - } - Index++; - } -} - -Standard_Real math_Vector::Multiplied(const math_Vector& theRight) const -{ - Standard_Real Result = 0; - - Standard_DimensionError_Raise_if (Length() != theRight.Length(), - "math_Vector::Multiplied() - input vector has wrong dimensions"); - - Standard_Integer I = theRight.Lower(); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Result = Result + Array(Index) * theRight.Array(I); - I++; - } - return Result; -} - -math_Vector math_Vector::Opposite() -{ - math_Vector Result(Lower(), Upper()); - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - Result.Array(Index) = - Array(Index); - } - return Result; -} - -math_Vector math_Vector::Multiplied(const math_Matrix& theRight)const -{ - Standard_DimensionError_Raise_if (Length() != theRight.RowNumber(), - "math_Vector::Multiplied() - input matrix has wrong dimensions"); - - math_Vector Result(theRight.LowerColIndex, theRight.UpperColIndex); - for(Standard_Integer J2 = theRight.LowerColIndex; J2 <= theRight.UpperColIndex; J2++) - { - Result.Array(J2) = 0.0; - Standard_Integer theI2 = theRight.LowerRowIndex; - for(Standard_Integer I = Lower(); I <= Upper(); I++) - { - Result.Array(J2) = Result.Array(J2) + Array(I) * theRight.Array(theI2, J2); - theI2++; - } - } - return Result; -} - -void math_Vector::Multiply(const Standard_Real theLeft, const math_Vector& theRight) -{ - Standard_DimensionError_Raise_if ((Length() != theRight.Length()), - "math_Vector::Multiply() - input vector has wrong dimensions"); - for(Standard_Integer I = Lower(); I <= Upper(); I++) - { - Array(I) = theLeft * theRight.Array(I); - } -} - -math_Vector& math_Vector::Initialized(const math_Vector& theOther) -{ - Standard_DimensionError_Raise_if (Length() != theOther.Length(), - "math_Vector::Initialized() - input vector has wrong dimensions"); - memmove (&Array.ChangeFirst(), &theOther.Array.First(), sizeof(Standard_Real) * Array.Length()); - return *this; -} - -void math_Vector::Dump(Standard_OStream& theO) const -{ - theO << "math_Vector of Length = " << Length() << "\n"; - for(Standard_Integer Index = Lower(); Index <= Upper(); Index++) - { - theO << "math_Vector(" << Index << ") = " << Array(Index) << "\n"; - } -} - diff --git a/src/math/math_Vector.hxx b/src/math/math_Vector.hxx index 15b86ccd34..7e19a1f2d4 100644 --- a/src/math/math_Vector.hxx +++ b/src/math/math_Vector.hxx @@ -15,17 +15,7 @@ #ifndef _math_Vector_HeaderFile #define _math_Vector_HeaderFile -#include -#include -#include -#include - -// resolve name collisions with X11 headers -#ifdef Opposite - #undef Opposite -#endif - -class math_Matrix; +#include //! This class implements the real vector abstract data type. //! Vectors can have an arbitrary range which must be defined at @@ -55,292 +45,6 @@ class math_Matrix; //! V3 = V1; // --> will raise DimensionError; //! V1.Add(V3) // --> will raise DimensionError; //! @endcode -class math_Vector -{ -public: - - DEFINE_STANDARD_ALLOC - - //! Constructs a non-initialized vector in the range [theLower..theUpper] - //! "theLower" and "theUpper" are the indexes of the lower and upper bounds of the constructed vector. - Standard_EXPORT math_Vector(const Standard_Integer theLower, const Standard_Integer theUpper); - - //! Constructs a vector in the range [theLower..theUpper] - //! whose values are all initialized with the value "theInitialValue" - Standard_EXPORT math_Vector(const Standard_Integer theLower, const Standard_Integer theUpper, const Standard_Real theInitialValue); - - //! Constructs a vector in the range [theLower..theUpper] - //! with the "c array" theTab. - Standard_EXPORT math_Vector(const Standard_Real* theTab, const Standard_Integer theLower, const Standard_Integer theUpper); - - //! Constructor for converting gp_XY to math_Vector - Standard_EXPORT math_Vector(const gp_XY& Other); - - //! Constructor for converting gp_XYZ to math_Vector - Standard_EXPORT math_Vector(const gp_XYZ& Other); - - //! Initialize all the elements of a vector with "theInitialValue". - Standard_EXPORT void Init(const Standard_Real theInitialValue); - - //! Constructs a copy for initialization. - //! An exception is raised if the lengths of the vectors are different. - Standard_EXPORT math_Vector(const math_Vector& theOther); - - //! Returns the length of a vector - inline Standard_Integer Length() const - { - return Array.Length(); - } - - //! Returns the value of the theLower index of a vector. - inline Standard_Integer Lower() const - { - return Array.Lower(); - } - - //! Returns the value of the theUpper index of a vector. - inline Standard_Integer Upper() const - { - return Array.Upper(); - } - - //! Returns the value or the square of the norm of this vector. - Standard_EXPORT Standard_Real Norm() const; - - //! Returns the value of the square of the norm of a vector. - Standard_EXPORT Standard_Real Norm2() const; - - //! Returns the value of the "Index" of the maximum element of a vector. - Standard_EXPORT Standard_Integer Max() const; - - //! Returns the value of the "Index" of the minimum element of a vector. - Standard_EXPORT Standard_Integer Min() const; - - //! Normalizes this vector (the norm of the result - //! is equal to 1.0) and assigns the result to this vector - //! Exceptions - //! Standard_NullValue if this vector is null (i.e. if its norm is - //! less than or equal to Standard_Real::RealEpsilon(). - Standard_EXPORT void Normalize(); - - //! Normalizes this vector (the norm of the result - //! is equal to 1.0) and creates a new vector - //! Exceptions - //! Standard_NullValue if this vector is null (i.e. if its norm is - //! less than or equal to Standard_Real::RealEpsilon(). - Standard_NODISCARD Standard_EXPORT math_Vector Normalized() const; - - //! Inverts this vector and assigns the result to this vector. - Standard_EXPORT void Invert(); - - //! Inverts this vector and creates a new vector. - Standard_EXPORT math_Vector Inverse() const; - - //! sets a vector from "theI1" to "theI2" to the vector "theV"; - //! An exception is raised if "theI1" is less than "LowerIndex" or "theI2" is greater than "UpperIndex" or "theI1" is greater than "theI2". - //! An exception is raised if "theI2-theI1+1" is different from the "Length" of "theV". - Standard_EXPORT void Set(const Standard_Integer theI1, const Standard_Integer theI2, const math_Vector& theV); - - //!Creates a new vector by inverting the values of this vector - //! between indexes "theI1" and "theI2". - //! If the values of this vector were (1., 2., 3., 4.,5., 6.), - //! by slicing it between indexes 2 and 5 the values - //! of the resulting vector are (1., 5., 4., 3., 2., 6.) - Standard_EXPORT math_Vector Slice(const Standard_Integer theI1, const Standard_Integer theI2) const; - - //! returns the product of a vector and a real value. - Standard_EXPORT void Multiply(const Standard_Real theRight); - - void operator *=(const Standard_Real theRight) - { - Multiply(theRight); - } - - //! returns the product of a vector and a real value. - Standard_NODISCARD Standard_EXPORT math_Vector Multiplied(const Standard_Real theRight) const; - - Standard_NODISCARD math_Vector operator*(const Standard_Real theRight) const - { - return Multiplied(theRight); - } - - //! returns the product of a vector and a real value. - Standard_NODISCARD Standard_EXPORT math_Vector TMultiplied(const Standard_Real theRight) const; - - friend inline math_Vector operator* (const Standard_Real theLeft, const math_Vector& theRight) - { - return theRight.Multiplied(theLeft); - } - - //! divides a vector by the value "theRight". - //! An exception is raised if "theRight" = 0. - Standard_EXPORT void Divide(const Standard_Real theRight); - - void operator /=(const Standard_Real theRight) - { - Divide(theRight); - } - - //! divides a vector by the value "theRight". - //! An exception is raised if "theRight" = 0. - Standard_NODISCARD Standard_EXPORT math_Vector Divided(const Standard_Real theRight) const; - - Standard_NODISCARD math_Vector operator/(const Standard_Real theRight) const - { - return Divided(theRight); - } - - //! adds the vector "theRight" to a vector. - //! An exception is raised if the vectors have not the same length. - //! Warning - //! In order to avoid time-consuming copying of vectors, it - //! is preferable to use operator += or the function Add whenever possible. - Standard_EXPORT void Add(const math_Vector& theRight); - - void operator +=(const math_Vector& theRight) - { - Add(theRight); - } - - //! adds the vector theRight to a vector. - //! An exception is raised if the vectors have not the same length. - //! An exception is raised if the lengths are not equal. - Standard_NODISCARD Standard_EXPORT math_Vector Added(const math_Vector& theRight) const; - - Standard_NODISCARD math_Vector operator+(const math_Vector& theRight) const - { - return Added(theRight); - } - - //! sets a vector to the product of the vector "theLeft" - //! with the matrix "theRight". - Standard_EXPORT void Multiply(const math_Vector& theLeft, const math_Matrix& theRight); - - //!sets a vector to the product of the matrix "theLeft" - //! with the vector "theRight". - Standard_EXPORT void Multiply(const math_Matrix& theLeft, const math_Vector& theRight); - - //! sets a vector to the product of the transpose - //! of the matrix "theTLeft" by the vector "theRight". - Standard_EXPORT void TMultiply(const math_Matrix& theTLeft, const math_Vector& theRight); - - //! sets a vector to the product of the vector - //! "theLeft" by the transpose of the matrix "theTRight". - Standard_EXPORT void TMultiply(const math_Vector& theLeft, const math_Matrix& theTRight); - - //! sets a vector to the sum of the vector "theLeft" - //! and the vector "theRight". - //! An exception is raised if the lengths are different. - Standard_EXPORT void Add(const math_Vector& theLeft, const math_Vector& theRight); - - //! sets a vector to the Subtraction of the - //! vector theRight from the vector theLeft. - //! An exception is raised if the vectors have not the same length. - //! Warning - //! In order to avoid time-consuming copying of vectors, it - //! is preferable to use operator -= or the function - //! Subtract whenever possible. - Standard_EXPORT void Subtract(const math_Vector& theLeft,const math_Vector& theRight); - - //! accesses the value of index "theNum" of a vector. - const Standard_Real& Value (const Standard_Integer theNum) const - { - return Array(theNum); - } - - //! accesses (in read or write mode) the value of index "theNum" of a vector. - inline Standard_Real& Value (const Standard_Integer theNum) - { - return Array(theNum); - } - - const Standard_Real& operator()(const Standard_Integer theNum) const - { - return Value(theNum); - } - - Standard_Real& operator()(const Standard_Integer theNum) - { - return Value(theNum); - } - - //! Initialises a vector by copying "theOther". - //! An exception is raised if the Lengths are different. - Standard_EXPORT math_Vector& Initialized(const math_Vector& theOther); - - math_Vector& operator=(const math_Vector& theOther) - { - return Initialized(theOther); - } - - //! returns the inner product of 2 vectors. - //! An exception is raised if the lengths are not equal. - Standard_NODISCARD Standard_EXPORT Standard_Real Multiplied(const math_Vector& theRight) const; - Standard_NODISCARD Standard_Real operator*(const math_Vector& theRight) const - { - return Multiplied(theRight); - } - - //! returns the product of a vector by a matrix. - Standard_NODISCARD Standard_EXPORT math_Vector Multiplied(const math_Matrix& theRight) const; - - Standard_NODISCARD math_Vector operator*(const math_Matrix& theRight) const - { - return Multiplied(theRight); - } - - //! returns the opposite of a vector. - Standard_EXPORT math_Vector Opposite(); - - math_Vector operator-() - { - return Opposite(); - } - - //! returns the subtraction of "theRight" from "me". - //! An exception is raised if the vectors have not the same length. - Standard_EXPORT void Subtract(const math_Vector& theRight); - - void operator-=(const math_Vector& theRight) - { - Subtract(theRight); - } - - //! returns the subtraction of "theRight" from "me". - //! An exception is raised if the vectors have not the same length. - Standard_NODISCARD Standard_EXPORT math_Vector Subtracted(const math_Vector& theRight) const; - - Standard_NODISCARD math_Vector operator-(const math_Vector& theRight) const - { - return Subtracted(theRight); - } - - //! returns the multiplication of a real by a vector. - //! "me" = "theLeft" * "theRight" - Standard_EXPORT void Multiply(const Standard_Real theLeft,const math_Vector& theRight); - - //! Prints information on the current state of the object. - //! Is used to redefine the operator <<. - Standard_EXPORT void Dump(Standard_OStream& theO) const; - - friend inline Standard_OStream& operator<<(Standard_OStream& theO, const math_Vector& theVec) - { - theVec.Dump(theO); - return theO; - } - - friend class math_Matrix; - -protected: - - //! Is used internally to set the "theLower" value of the vector. - void SetLower(const Standard_Integer theLower); - -private: - - NCollection_LocalArray myLocArray; - NCollection_Array1 Array; - -}; +using math_Vector = math_VectorBase; #endif diff --git a/src/math/math_VectorBase.hxx b/src/math/math_VectorBase.hxx new file mode 100644 index 0000000000..cdb20cab62 --- /dev/null +++ b/src/math/math_VectorBase.hxx @@ -0,0 +1,352 @@ +// Copyright (c) 1997-1999 Matra Datavision +// Copyright (c) 1999-2023 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#ifndef _math_VectorBase_HeaderFile +#define _math_VectorBase_HeaderFile + +#include +#include +#include + +// resolve name collisions with X11 headers +#ifdef Opposite +#undef Opposite +#endif + +#include + +#include + +//! This class implements the real vector abstract data type. +//! Vectors can have an arbitrary range which must be defined at +//! the declaration and cannot be changed after this declaration. +//! @code +//! math_VectorBase V1(-3, 5); // a vector with range [-3..5] +//! @endcode +//! +//! Vector are copied through assignment: +//! @code +//! math_VectorBase V2( 1, 9); +//! .... +//! V2 = V1; +//! V1(1) = 2.0; // the vector V2 will not be modified. +//! @endcode +//! +//! The Exception RangeError is raised when trying to access outside +//! the range of a vector : +//! @code +//! V1(11) = 0.0 // --> will raise RangeError; +//! @endcode +//! +//! The Exception DimensionError is raised when the dimensions of two +//! vectors are not compatible : +//! @code +//! math_VectorBase V3(1, 2); +//! V3 = V1; // --> will raise DimensionError; +//! V1.Add(V3) // --> will raise DimensionError; +//! @endcode +template +class math_VectorBase +{ + static const int THE_BUFFER_SIZE = 32; + +public: + //! Memory allocation + DEFINE_STANDARD_ALLOC; + DEFINE_NCOLLECTION_ALLOC; +public: + + //! Constructs a non-initialized vector in the range [theLower..theUpper] + //! "theLower" and "theUpper" are the indexes of the lower and upper bounds of the constructed vector. + inline math_VectorBase(const Standard_Integer theLower, const Standard_Integer theUpper); + + //! Constructs a vector in the range [theLower..theUpper] + //! whose values are all initialized with the value "theInitialValue" + inline math_VectorBase(const Standard_Integer theLower, const Standard_Integer theUpper, const TheItemType theInitialValue); + + //! Constructs a vector in the range [theLower..theUpper] + //! whose values are all initialized with the value "theInitialValue" + inline math_VectorBase(const TheItemType* theTab, const Standard_Integer theLower, const Standard_Integer theUpper); + + //! Constructor for converting gp_XY to math_VectorBase + inline math_VectorBase(const gp_XY& Other); + + //! Constructor for converting gp_XYZ to math_VectorBase + inline math_VectorBase(const gp_XYZ& Other); + + //! Initialize all the elements of a vector with "theInitialValue". + void Init(const TheItemType theInitialValue); + + //! Constructs a copy for initialization. + //! An exception is raised if the lengths of the vectors are different. + inline math_VectorBase(const math_VectorBase& theOther); + + //! Returns the length of a vector + inline Standard_Integer Length() const + { + return Array.Length(); + } + + //! Returns the lower index of the vector + inline Standard_Integer Lower() const + { + return Array.Lower(); + } + + //! Returns the upper index of the vector + inline Standard_Integer Upper() const + { + return Array.Upper(); + } + + //! Returns the value or the square of the norm of this vector. + inline Standard_Real Norm() const; + + //! Returns the value of the square of the norm of a vector. + inline Standard_Real Norm2() const; + + //! Returns the index of the maximum element of a vector. (first found) + inline Standard_Integer Max() const; + + //! Returns the index of the minimum element of a vector. (first found) + inline Standard_Integer Min() const; + + //! Normalizes this vector (the norm of the result + //! is equal to 1.0) and assigns the result to this vector + //! Exceptions + //! Standard_NullValue if this vector is null (i.e. if its norm is + //! less than or equal to Standard_Real::RealEpsilon(). + inline void Normalize(); + + //! Normalizes this vector (the norm of the result + //! is equal to 1.0) and creates a new vector + //! Exceptions + //! Standard_NullValue if this vector is null (i.e. if its norm is + //! less than or equal to Standard_Real::RealEpsilon(). + Standard_NODISCARD inline math_VectorBase Normalized() const; + + //! Inverts this vector and assigns the result to this vector. + inline void Invert(); + + //! Inverts this vector and creates a new vector. + inline math_VectorBase Inverse() const; + + //! sets a vector from "theI1" to "theI2" to the vector "theV"; + //! An exception is raised if "theI1" is less than "LowerIndex" or "theI2" is greater than "UpperIndex" or "theI1" is greater than "theI2". + //! An exception is raised if "theI2-theI1+1" is different from the "Length" of "theV". + inline void Set(const Standard_Integer theI1, const Standard_Integer theI2, const math_VectorBase& theV); + + //!Creates a new vector by inverting the values of this vector + //! between indexes "theI1" and "theI2". + //! If the values of this vector were (1., 2., 3., 4.,5., 6.), + //! by slicing it between indexes 2 and 5 the values + //! of the resulting vector are (1., 5., 4., 3., 2., 6.) + inline math_VectorBase Slice(const Standard_Integer theI1, const Standard_Integer theI2) const; + + //! Updates current vector by multiplying each element on current value. + inline void Multiply(const TheItemType theRight); + + void operator *=(const TheItemType theRight) + { + Multiply(theRight); + } + + //! returns the product of a vector and a real value. + Standard_NODISCARD inline math_VectorBase Multiplied(const TheItemType theRight) const; + + Standard_NODISCARD math_VectorBase operator*(const TheItemType theRight) const + { + return Multiplied(theRight); + } + + //! returns the product of a vector and a real value. + Standard_NODISCARD inline math_VectorBase TMultiplied(const TheItemType theRight) const; + + friend inline math_VectorBase operator* (const TheItemType theLeft, const math_VectorBase& theRight) + { + return theRight.Multiplied(theLeft); + } + + //! divides a vector by the value "theRight". + //! An exception is raised if "theRight" = 0. + inline void Divide(const TheItemType theRight); + + void operator /=(const TheItemType theRight) + { + Divide(theRight); + } + + //! Returns new vector as dividing current vector with the value "theRight". + //! An exception is raised if "theRight" = 0. + Standard_NODISCARD inline math_VectorBase Divided(const TheItemType theRight) const; + + Standard_NODISCARD math_VectorBase operator/(const TheItemType theRight) const + { + return Divided(theRight); + } + + //! adds the vector "theRight" to a vector. + //! An exception is raised if the vectors have not the same length. + //! Warning + //! In order to avoid time-consuming copying of vectors, it + //! is preferable to use operator += or the function Add whenever possible. + inline void Add(const math_VectorBase& theRight); + + void operator +=(const math_VectorBase& theRight) + { + Add(theRight); + } + + //! Returns new vector as adding curent vector with the value "theRight". + //! An exception is raised if the vectors have not the same length. + //! An exception is raised if the lengths are not equal. + Standard_NODISCARD inline math_VectorBase Added(const math_VectorBase& theRight) const; + + Standard_NODISCARD math_VectorBase operator+(const math_VectorBase& theRight) const + { + return Added(theRight); + } + + //! sets a vector to the product of the vector "theLeft" + //! with the matrix "theRight". + inline void Multiply(const math_VectorBase& theLeft, const math_Matrix& theRight); + + //!sets a vector to the product of the matrix "theLeft" + //! with the vector "theRight". + inline void Multiply(const math_Matrix& theLeft, const math_VectorBase& theRight); + + //! sets a vector to the product of the transpose + //! of the matrix "theTLeft" by the vector "theRight". + inline void TMultiply(const math_Matrix& theTLeft, const math_VectorBase& theRight); + + //! sets a vector to the product of the vector + //! "theLeft" by the transpose of the matrix "theTRight". + inline void TMultiply(const math_VectorBase& theLeft, const math_Matrix& theTRight); + + //! sets a vector to the sum of the vector "theLeft" + //! and the vector "theRight". + //! An exception is raised if the lengths are different. + inline void Add(const math_VectorBase& theLeft, const math_VectorBase& theRight); + + //! sets a vector to the Subtraction of the + //! vector theRight from the vector theLeft. + //! An exception is raised if the vectors have not the same length. + //! Warning + //! In order to avoid time-consuming copying of vectors, it + //! is preferable to use operator -= or the function + //! Subtract whenever possible. + inline void Subtract(const math_VectorBase& theLeft, const math_VectorBase& theRight); + + //! accesses the value of index "theNum" of a vector. + const TheItemType& Value(const Standard_Integer theNum) const + { + return Array(theNum); + } + + //! accesses (in read or write mode) the value of index "theNum" of a vector. + inline TheItemType& Value(const Standard_Integer theNum) + { + return Array(theNum); + } + + const TheItemType& operator()(const Standard_Integer theNum) const + { + return Value(theNum); + } + + TheItemType& operator()(const Standard_Integer theNum) + { + return Value(theNum); + } + + //! Initialises a vector by copying "theOther". + //! An exception is raised if the Lengths are different. + inline math_VectorBase& Initialized(const math_VectorBase& theOther); + + math_VectorBase& operator=(const math_VectorBase& theOther) + { + return Initialized(theOther); + } + + //! returns the inner product of 2 vectors. + //! An exception is raised if the lengths are not equal. + Standard_NODISCARD inline TheItemType Multiplied(const math_VectorBase& theRight) const; + Standard_NODISCARD inline TheItemType operator*(const math_VectorBase& theRight) const + { + return Multiplied(theRight); + } + + //! returns the product of a vector by a matrix. + Standard_NODISCARD inline math_VectorBase Multiplied(const math_Matrix& theRight) const; + + Standard_NODISCARD math_VectorBase operator*(const math_Matrix& theRight) const + { + return Multiplied(theRight); + } + + //! returns the opposite of a vector. + inline math_VectorBase Opposite(); + + math_VectorBase operator-() + { + return Opposite(); + } + + //! returns the subtraction of "theRight" from "me". + //! An exception is raised if the vectors have not the same length. + inline void Subtract(const math_VectorBase& theRight); + + void operator-=(const math_VectorBase& theRight) + { + Subtract(theRight); + } + + //! returns the subtraction of "theRight" from "me". + //! An exception is raised if the vectors have not the same length. + Standard_NODISCARD inline math_VectorBase Subtracted(const math_VectorBase& theRight) const; + + Standard_NODISCARD math_VectorBase operator-(const math_VectorBase& theRight) const + { + return Subtracted(theRight); + } + + //! returns the multiplication of a real by a vector. + //! "me" = "theLeft" * "theRight" + inline void Multiply(const TheItemType theLeft, const math_VectorBase& theRight); + + //! Prints information on the current state of the object. + //! Is used to redefine the operator <<. + inline void Dump(Standard_OStream& theO) const; + + friend inline Standard_OStream& operator<<(Standard_OStream& theO, const math_VectorBase& theVec) + { + theVec.Dump(theO); + return theO; + } + + friend class math_Matrix; + +protected: + + //! Is used internally to set the "theLower" value of the vector. + inline void SetLower(const Standard_Integer theLower); + +private: + std::array myBuffer; + NCollection_Array1 Array; +}; + +#include + +#endif diff --git a/src/math/math_VectorBase.lxx b/src/math/math_VectorBase.lxx new file mode 100644 index 0000000000..5d010f6aec --- /dev/null +++ b/src/math/math_VectorBase.lxx @@ -0,0 +1,524 @@ +// Copyright (c) 1997-1999 Matra Datavision +// Copyright (c) 1999-2023 OPEN CASCADE SAS +// +// This file is part of Open CASCADE Technology software library. +// +// This library is free software; you can redistribute it and/or modify it under +// the terms of the GNU Lesser General Public License version 2.1 as published +// by the Free Software Foundation, with special exception defined in the file +// OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT +// distribution for complete text of the license and disclaimer of any warranty. +// +// Alternatively, this file may be used under the terms of Open CASCADE +// commercial license or contractual agreement. + +#include +#include +#include +#include + +#include + +template +math_VectorBase::math_VectorBase(const Standard_Integer theLower, + const Standard_Integer theUpper) : + Array(*myBuffer.data(), theLower, theUpper, (theUpper - theLower + 1 <= math_VectorBase::THE_BUFFER_SIZE)) +{} + +template +math_VectorBase::math_VectorBase(const Standard_Integer theLower, + const Standard_Integer theUpper, + const TheItemType theInitialValue) : + Array(*myBuffer.data(), theLower, theUpper, (theUpper - theLower + 1 <= math_VectorBase::THE_BUFFER_SIZE)) +{ + Array.Init(theInitialValue); +} + +template +math_VectorBase::math_VectorBase(const TheItemType* theTab, + const Standard_Integer theLower, + const Standard_Integer theUpper) : + Array(*theTab, theLower, theUpper) +{} + +template +math_VectorBase::math_VectorBase(const gp_XY& theOther) : + Array(*myBuffer.data(), 1, 2) +{ + Array(1) = static_cast(theOther.X()); + Array(2) = static_cast(theOther.Y()); +} + +template +math_VectorBase::math_VectorBase(const gp_XYZ& theOther) : + Array(*myBuffer.data(), 1, 3) +{ + Array(1) = static_cast(theOther.X()); + Array(2) = static_cast(theOther.Y()); + Array(3) = static_cast(theOther.Z()); +} + +template +void math_VectorBase::Init(const TheItemType theInitialValue) +{ + Array.Init(theInitialValue); +} + +template +math_VectorBase::math_VectorBase(const math_VectorBase& theOther) : + Array(theOther.Array) +{} + +template +void math_VectorBase::SetLower(const Standard_Integer theLower) +{ + Array.UpdateLowerBound(theLower); +} + +template +Standard_Real math_VectorBase::Norm() const +{ + Standard_Real Result = 0; + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + Result = Result + Array(Index) * Array(Index); + } + return Sqrt(Result); +} + +template +Standard_Real math_VectorBase::Norm2() const +{ + Standard_Real Result = 0; + + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + Result = Result + Array(Index) * Array(Index); + } + return Result; +} + +template +Standard_Integer math_VectorBase::Max() const +{ + Standard_Integer I = 0; + Standard_Real X = RealFirst(); + + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + if (Array(Index) > X) + { + X = Array(Index); + I = Index; + } + } + return I; +} + +template +Standard_Integer math_VectorBase::Min() const +{ + Standard_Integer I = 0; + Standard_Real X = RealLast(); + + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + if (Array(Index) < X) + { + X = Array(Index); + I = Index; + } + } + return I; +} + +template +void math_VectorBase::Set(const Standard_Integer theI1, + const Standard_Integer theI2, + const math_VectorBase& theV) +{ + Standard_RangeError_Raise_if((theI1 < Lower()) || (theI2 > Upper()) \ + || (theI1 > theI2) || (theI2 - theI1 + 1 != theV.Length()), \ + "math_VectorBase::Set() - invalid indices"); + Standard_Integer I = theV.Lower(); + for (Standard_Integer Index = theI1; Index <= theI2; Index++) + { + Array(Index) = theV.Array(I); + I++; + } +} + +template +void math_VectorBase::Normalize() +{ + Standard_Real Result = Norm(); + Standard_NullValue_Raise_if((Result <= RealEpsilon()), \ + "math_VectorBase::Normalize() - vector has zero norm"); + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + Array(Index) = Array(Index) / Result; + } +} + +template +math_VectorBase math_VectorBase::Normalized() const +{ + math_VectorBase Result = *this; + Result.Normalize(); + return Result; +} + +template +void math_VectorBase::Invert() +{ + for (Standard_Integer Index = Lower(); Index <= (Lower() + Length()) >> 1; Index++) + { + Standard_Integer J = Upper() + Lower() - Index; + TheItemType aTemp = Array(Index); + Array(Index) = Array(J); + Array(J) = aTemp; + } +} + +template +math_VectorBase math_VectorBase::Inverse() const +{ + math_VectorBase Result = *this; + Result.Invert(); + return Result; +} + +template +math_VectorBase math_VectorBase::Multiplied(const TheItemType theRight) const +{ + math_VectorBase Result(Lower(), Upper()); + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + Result.Array(Index) = Array(Index) * theRight; + } + return Result; +} + +template +math_VectorBase math_VectorBase::TMultiplied(const TheItemType theRight) const +{ + math_VectorBase Result(Lower(), Upper()); + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + Result.Array(Index) = Array(Index) * theRight; + } + return Result; +} + +template +void math_VectorBase::Multiply(const TheItemType theRight) +{ + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + Array(Index) = Array(Index) * theRight; + } +} + +template +void math_VectorBase::Divide(const TheItemType theRight) +{ + Standard_DivideByZero_Raise_if(Abs(theRight) <= RealEpsilon(), \ + "math_VectorBase::Divide() - devisor is zero"); + + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + Array(Index) = Array(Index) / theRight; + } +} + +template +math_VectorBase math_VectorBase::Divided(const TheItemType theRight) const +{ + Standard_DivideByZero_Raise_if(Abs(theRight) <= RealEpsilon(), \ + "math_VectorBase::Divided() - devisor is zero"); + math_VectorBase temp = Multiplied(1. / theRight); + return temp; +} + +template +void math_VectorBase::Add(const math_VectorBase& theRight) +{ + Standard_DimensionError_Raise_if(Length() != theRight.Length(), \ + "math_VectorBase::Add() - input vector has wrong dimensions"); + + Standard_Integer I = theRight.Lower(); + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + Array(Index) = Array(Index) + theRight.Array(I); + I++; + } +} + +template +math_VectorBase math_VectorBase::Added(const math_VectorBase& theRight) const +{ + Standard_DimensionError_Raise_if(Length() != theRight.Length(), \ + "math_VectorBase::Added() - input vector has wrong dimensions"); + + math_VectorBase Result(Lower(), Upper()); + + Standard_Integer I = theRight.Lower(); + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + Result.Array(Index) = Array(Index) + theRight.Array(I); + I++; + } + return Result; +} + +template +void math_VectorBase::Subtract(const math_VectorBase& theRight) +{ + Standard_DimensionError_Raise_if(Length() != theRight.Length(), \ + "math_VectorBase::Subtract() - input vector has wrong dimensions"); + + Standard_Integer I = theRight.Lower(); + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + Array(Index) = Array(Index) - theRight.Array(I); + I++; + } +} + +template +math_VectorBase math_VectorBase::Subtracted(const math_VectorBase& theRight) const +{ + Standard_DimensionError_Raise_if(Length() != theRight.Length(), \ + "math_VectorBase::Subtracted() - input vector has wrong dimensions"); + + math_VectorBase Result(Lower(), Upper()); + + Standard_Integer I = theRight.Lower(); + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + Result.Array(Index) = Array(Index) - theRight.Array(I); + I++; + } + return Result; +} + +template +math_VectorBase math_VectorBase::Slice(const Standard_Integer theI1, const Standard_Integer theI2) const +{ + Standard_RangeError_Raise_if((theI1 < Lower()) || (theI1 > Upper()) || (theI2 < Lower()) || (theI2 > Upper()), \ + "math_VectorBase::Slice() - invalid indices"); + + if (theI2 >= theI1) + { + math_VectorBase Result(theI1, theI2); + for (Standard_Integer Index = theI1; Index <= theI2; Index++) + { + Result.Array(Index) = Array(Index); + } + return Result; + } + else + { + math_VectorBase Result(theI2, theI1); + for (Standard_Integer Index = theI1; Index >= theI2; Index--) + { + Result.Array(Index) = Array(Index); + } + return Result; + } +} + +template +void math_VectorBase::Add(const math_VectorBase& theLeft, const math_VectorBase& theRight) +{ + Standard_DimensionError_Raise_if((Length() != theRight.Length()) || (theRight.Length() != theLeft.Length()), \ + "math_VectorBase::Add() - input vectors have wrong dimensions"); + + Standard_Integer I = theLeft.Lower(); + Standard_Integer J = theRight.Lower(); + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + Array(Index) = theLeft.Array(I) + theRight.Array(J); + I++; + J++; + } +} + +template +void math_VectorBase::Subtract(const math_VectorBase& theLeft, const math_VectorBase& theRight) +{ + Standard_DimensionError_Raise_if((Length() != theRight.Length()) || (theRight.Length() != theLeft.Length()), \ + "math_VectorBase::Subtract() - input vectors have wrong dimensions"); + + Standard_Integer I = theLeft.Lower(); + Standard_Integer J = theRight.Lower(); + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + Array(Index) = theLeft.Array(I) - theRight.Array(J); + I++; + J++; + } +} + +template +void math_VectorBase::Multiply(const math_Matrix& theLeft, const math_VectorBase& theRight) +{ + Standard_DimensionError_Raise_if((Length() != theLeft.RowNumber()) \ + || (theLeft.ColNumber() != theRight.Length()), \ + "math_VectorBase::Multiply() - input matrix and /or vector have wrong dimensions"); + + Standard_Integer Index = Lower(); + for (Standard_Integer I = theLeft.LowerRowIndex; I <= theLeft.UpperRowIndex; I++) + { + Array(Index) = 0.0; + Standard_Integer K = theRight.Lower(); + for (Standard_Integer J = theLeft.LowerColIndex; J <= theLeft.UpperColIndex; J++) + { + Array(Index) = Array(Index) + theLeft.Array(I, J) * theRight.Array(K); + K++; + } + Index++; + } +} + +template +void math_VectorBase::Multiply(const math_VectorBase& theLeft, const math_Matrix& theRight) +{ + Standard_DimensionError_Raise_if((Length() != theRight.ColNumber()) \ + || (theLeft.Length() != theRight.RowNumber()), \ + "math_VectorBase::Multiply() - input matrix and /or vector have wrong dimensions"); + + Standard_Integer Index = Lower(); + for (Standard_Integer J = theRight.LowerColIndex; J <= theRight.UpperColIndex; J++) + { + Array(Index) = 0.0; + Standard_Integer K = theLeft.Lower(); + for (Standard_Integer I = theRight.LowerRowIndex; I <= theRight.UpperRowIndex; I++) + { + Array(Index) = Array(Index) + theLeft.Array(K) * theRight.Array(I, J); + K++; + } + Index++; + } +} + +template +void math_VectorBase::TMultiply(const math_Matrix& theTLeft, const math_VectorBase& theRight) +{ + Standard_DimensionError_Raise_if((Length() != theTLeft.ColNumber()) \ + || (theTLeft.RowNumber() != theRight.Length()), \ + "math_VectorBase::TMultiply() - input matrix and /or vector have wrong dimensions"); + + Standard_Integer Index = Lower(); + for (Standard_Integer I = theTLeft.LowerColIndex; I <= theTLeft.UpperColIndex; I++) + { + Array(Index) = 0.0; + Standard_Integer K = theRight.Lower(); + for (Standard_Integer J = theTLeft.LowerRowIndex; J <= theTLeft.UpperRowIndex; J++) + { + Array(Index) = Array(Index) + theTLeft.Array(J, I) * theRight.Array(K); + K++; + } + Index++; + } +} + +template +void math_VectorBase::TMultiply(const math_VectorBase& theLeft, const math_Matrix& theTRight) +{ + Standard_DimensionError_Raise_if((Length() != theTRight.RowNumber()) \ + || (theLeft.Length() != theTRight.ColNumber()), \ + "math_VectorBase::TMultiply() - input matrix and /or vector have wrong dimensions"); + + Standard_Integer Index = Lower(); + for (Standard_Integer J = theTRight.LowerRowIndex; J <= theTRight.UpperRowIndex; J++) + { + Array(Index) = 0.0; + Standard_Integer K = theLeft.Lower(); + for (Standard_Integer I = theTRight.LowerColIndex; + I <= theTRight.UpperColIndex; I++) + { + Array(Index) = Array(Index) + theLeft.Array(K) * theTRight.Array(J, I); + K++; + } + Index++; + } +} + +template +TheItemType math_VectorBase::Multiplied(const math_VectorBase& theRight) const +{ + Standard_Real Result = 0; + + Standard_DimensionError_Raise_if(Length() != theRight.Length(), \ + "math_VectorBase::Multiplied() - input vector has wrong dimensions"); + + Standard_Integer I = theRight.Lower(); + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + Result = Result + Array(Index) * theRight.Array(I); + I++; + } + return Result; +} + +template +math_VectorBase math_VectorBase::Opposite() +{ + math_VectorBase Result(Lower(), Upper()); + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + Result.Array(Index) = -Array(Index); + } + return Result; +} + +template +math_VectorBase math_VectorBase::Multiplied(const math_Matrix& theRight)const +{ + Standard_DimensionError_Raise_if(Length() != theRight.RowNumber(), \ + "math_VectorBase::Multiplied() - input matrix has wrong dimensions"); + + math_VectorBase Result(theRight.LowerColIndex, theRight.UpperColIndex); + for (Standard_Integer J2 = theRight.LowerColIndex; J2 <= theRight.UpperColIndex; J2++) + { + Result.Array(J2) = 0.0; + Standard_Integer theI2 = theRight.LowerRowIndex; + for (Standard_Integer I = Lower(); I <= Upper(); I++) + { + Result.Array(J2) = Result.Array(J2) + Array(I) * theRight.Array(theI2, J2); + theI2++; + } + } + return Result; +} + +template +void math_VectorBase::Multiply(const TheItemType theLeft, const math_VectorBase& theRight) +{ + Standard_DimensionError_Raise_if((Length() != theRight.Length()), \ + "math_VectorBase::Multiply() - input vector has wrong dimensions"); + for (Standard_Integer I = Lower(); I <= Upper(); I++) + { + Array(I) = theLeft * theRight.Array(I); + } +} + +template +math_VectorBase& math_VectorBase::Initialized(const math_VectorBase& theOther) +{ + Standard_DimensionError_Raise_if(Length() != theOther.Length(), \ + "math_VectorBase::Initialized() - input vector has wrong dimensions"); + memmove(&Array.ChangeFirst(), &theOther.Array.First(), sizeof(TheItemType) * Array.Length()); + return *this; +} + +template +void math_VectorBase::Dump(Standard_OStream& theO) const +{ + theO << "math_Vector of Length = " << Length() << "\n"; + for (Standard_Integer Index = Lower(); Index <= Upper(); Index++) + { + theO << "math_Vector(" << Index << ") = " << Array(Index) << "\n"; + } +} diff --git a/tests/bugs/caf/bug31546 b/tests/bugs/caf/bug31546 index bf12fa13eb..527efefeae 100644 --- a/tests/bugs/caf/bug31546 +++ b/tests/bugs/caf/bug31546 @@ -10,8 +10,10 @@ Close D # make the first open/close iteration before checking memory because some filled structures # are cleared on start of the next open (like mySections in DocumentRetrievalDriver) -Open $docname D -Close D +for {set i 1} {$i < 3} {incr i} { + Open $docname D + Close D +} puts "Executing Load / Close in cycle to see if allocated heap memory grows" set listmem {} diff --git a/tests/bugs/fclasses/bug7287_6 b/tests/bugs/fclasses/bug7287_6 index 25588729d3..67bfe29496 100755 --- a/tests/bugs/fclasses/bug7287_6 +++ b/tests/bugs/fclasses/bug7287_6 @@ -1,4 +1,4 @@ -puts "TODO ?CR33225 Linux: Checking trend failed: mean delta per step = 7408.0, sigma = 2737.917456754312, expected delta = 0" +puts "TODO ?CR33225 Linux: Checking trend failed: mean delta per step =" puts "TODO ?OCC7287 Linux: Tcl Exception: Memory leak detected" puts "TODO ?OCC7287 Linux: TEST INCOMPLETE" puts "TODO ?OCC7287 MacOS: Tcl Exception: Memory leak detected" diff --git a/tests/bugs/xde/bug23570 b/tests/bugs/xde/bug23570 index 30a302b9a4..b189eba234 100644 --- a/tests/bugs/xde/bug23570 +++ b/tests/bugs/xde/bug23570 @@ -8,7 +8,7 @@ puts "" set info [param write.surfacecurve.mode] -set result1 [regexp {\-\-\- Type : Enum \[in 0-1\] 0:Off 1:On , alpha: +(.*):0 +(.*):1 +\n\-\-\-} $info full alpha_0 alpha_1] +set result1 [regexp {\-\-\- Type : Enum \[in 0-1\] 0:Off 1:On , alpha: +(.*):[0-9] +(.*):[0-9] +\n\-\-\-} $info full alpha_0 alpha_1] if { ${result1} == 0 } { puts "Error: bad message or regexp" diff --git a/tools/MessageModel/MessageModel_ItemRoot.cxx b/tools/MessageModel/MessageModel_ItemRoot.cxx index 7f424e4c1b..96a2313b83 100644 --- a/tools/MessageModel/MessageModel_ItemRoot.cxx +++ b/tools/MessageModel/MessageModel_ItemRoot.cxx @@ -29,8 +29,8 @@ void MessageModel_ItemRoot::SetReport (const int theRowId, const Handle(Message_ if (aRowId == theRowId) break; } - aReportsIt.Value().myReport = theReport; - aReportsIt.Value().myDescription = theReportDescription; + aReportsIt.ChangeValue().myReport = theReport; + aReportsIt.ChangeValue().myDescription = theReportDescription; } // ======================================================================= diff --git a/tools/View/View_Viewer.cxx b/tools/View/View_Viewer.cxx index f2d8dac73c..5ba225ad8e 100644 --- a/tools/View/View_Viewer.cxx +++ b/tools/View/View_Viewer.cxx @@ -16,7 +16,6 @@ #include #include -#include // ======================================================================= // function : CreateView