mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-08-04 13:13:25 +03:00
0024971: Incomplete interface of NCollection classes
NCollection classes amended to be compatible with TCollection equivalents: - List and Maps: copy constructor is used for placement of new items in collection instead of assignment operator, thus default constructor is not necessary any more for the item class - Constructors with additional argument of element type added in array classes operated by Handle, defined by NCollection_DefineHArray*.hxx, allowing to initialize array immediately by specified value - Non-const methods First() and Last() are added in List class, and method Value() in TListIterator class - Method Append() accepting Handle(HSequence) provided in NCollection_DefineHSequence.hxx - Default implementation of global function IsEqual() is provided as template (using operator ==) Code using lists and maps of sequences is refactored to operate sequence by Handle (since Sequence does not to have public copy constructor). In addition, error checking code is simplified to use macros _Raise_if instead of custom #ifdefs with the same meaning. Comments within declaration of instances of generic classes in CDL removed. Fixed bug in copy constructor of NCollection_BaseVector leading to corrupt data if original vector is empty; simplistic test command for vectors is added.
This commit is contained in:
@@ -160,13 +160,12 @@ void MeshTest_CheckTopology::Perform (Draw_Interpretor& di)
|
||||
if (aMapBndNodes.Contains(n1) && aMapBndNodes.Contains(n2))
|
||||
continue;
|
||||
if (!myMapFaceLinks.Contains(iF)) {
|
||||
//myMapFaceLinks.Add(iF, TColStd_SequenceOfInteger());
|
||||
TColStd_SequenceOfInteger tmpSeq;
|
||||
Handle(TColStd_HSequenceOfInteger) tmpSeq = new TColStd_HSequenceOfInteger;
|
||||
myMapFaceLinks.Add(iF, tmpSeq);
|
||||
}
|
||||
TColStd_SequenceOfInteger& aSeq = myMapFaceLinks.ChangeFromKey(iF);
|
||||
aSeq.Append(n1);
|
||||
aSeq.Append(n2);
|
||||
Handle(TColStd_HSequenceOfInteger)& aSeq = myMapFaceLinks.ChangeFromKey(iF);
|
||||
aSeq->Append(n1);
|
||||
aSeq->Append(n2);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -193,10 +192,10 @@ void MeshTest_CheckTopology::GetFreeLink(const Standard_Integer theFaceIndex,
|
||||
Standard_Integer& theNode1,
|
||||
Standard_Integer& theNode2) const
|
||||
{
|
||||
const TColStd_SequenceOfInteger& aSeq = myMapFaceLinks(theFaceIndex);
|
||||
const Handle(TColStd_HSequenceOfInteger)& aSeq = myMapFaceLinks(theFaceIndex);
|
||||
Standard_Integer aInd = (theLinkIndex-1)*2 + 1;
|
||||
theNode1 = aSeq(aInd);
|
||||
theNode2 = aSeq(aInd+1);
|
||||
theNode1 = aSeq->Value(aInd);
|
||||
theNode2 = aSeq->Value(aInd+1);
|
||||
}
|
||||
|
||||
//=======================================================================
|
||||
|
@@ -18,7 +18,7 @@
|
||||
|
||||
#include <TopoDS_Shape.hxx>
|
||||
#include <NCollection_IndexedDataMap.hxx>
|
||||
#include <TColStd_SequenceOfInteger.hxx>
|
||||
#include <TColStd_HSequenceOfInteger.hxx>
|
||||
#include <TColStd_SequenceOfReal.hxx>
|
||||
#include <Draw_Interpretor.hxx>
|
||||
|
||||
@@ -58,7 +58,7 @@ public:
|
||||
|
||||
//! returns the number free links on a face with the given index
|
||||
Standard_Integer NbFreeLinks(const Standard_Integer theIndex) const
|
||||
{ return myMapFaceLinks(theIndex).Length() / 2; }
|
||||
{ return myMapFaceLinks(theIndex)->Length() / 2; }
|
||||
|
||||
//! gets the numbers of nodes of a free link with the given index
|
||||
//! in the face with the given index
|
||||
@@ -103,7 +103,7 @@ public:
|
||||
|
||||
private:
|
||||
TopoDS_Shape myShape;
|
||||
NCollection_IndexedDataMap<Standard_Integer,TColStd_SequenceOfInteger>
|
||||
NCollection_IndexedDataMap<Standard_Integer,Handle(TColStd_HSequenceOfInteger)>
|
||||
myMapFaceLinks;
|
||||
|
||||
TColStd_SequenceOfInteger myErrors;
|
||||
|
Reference in New Issue
Block a user