mirror of
https://git.dev.opencascade.org/repos/occt.git
synced 2025-08-14 13:30:48 +03:00
Integration of OCCT 6.5.0 from SVN
This commit is contained in:
83
src/RWStepShape/RWStepShape_RWGeometricCurveSet.cxx
Executable file
83
src/RWStepShape/RWStepShape_RWGeometricCurveSet.cxx
Executable file
@@ -0,0 +1,83 @@
|
||||
|
||||
#include <RWStepShape_RWGeometricCurveSet.ixx>
|
||||
#include <StepShape_HArray1OfGeometricSetSelect.hxx>
|
||||
#include <StepShape_GeometricSetSelect.hxx>
|
||||
|
||||
|
||||
#include <Interface_EntityIterator.hxx>
|
||||
|
||||
|
||||
#include <StepShape_GeometricCurveSet.hxx>
|
||||
|
||||
|
||||
RWStepShape_RWGeometricCurveSet::RWStepShape_RWGeometricCurveSet () {}
|
||||
|
||||
void RWStepShape_RWGeometricCurveSet::ReadStep
|
||||
(const Handle(StepData_StepReaderData)& data,
|
||||
const Standard_Integer num,
|
||||
Handle(Interface_Check)& ach,
|
||||
const Handle(StepShape_GeometricCurveSet)& ent) const
|
||||
{
|
||||
|
||||
|
||||
// --- Number of Parameter Control ---
|
||||
|
||||
if (!data->CheckNbParams(num,2,ach,"geometric_curve_set")) return;
|
||||
|
||||
// --- inherited field : name ---
|
||||
|
||||
Handle(TCollection_HAsciiString) aName;
|
||||
//szv#4:S4163:12Mar99 `Standard_Boolean stat1 =` not needed
|
||||
data->ReadString (num,1,"name",ach,aName);
|
||||
|
||||
// --- inherited field : elements ---
|
||||
|
||||
Handle(StepShape_HArray1OfGeometricSetSelect) aElements;
|
||||
StepShape_GeometricSetSelect aElementsItem;
|
||||
Standard_Integer nsub2;
|
||||
if (data->ReadSubList (num,2,"elements",ach,nsub2)) {
|
||||
Standard_Integer nb2 = data->NbParams(nsub2);
|
||||
aElements = new StepShape_HArray1OfGeometricSetSelect (1, nb2);
|
||||
for (Standard_Integer i2 = 1; i2 <= nb2; i2 ++) {
|
||||
//szv#4:S4163:12Mar99 `Standard_Boolean stat2 =` not needed
|
||||
if (data->ReadEntity (nsub2,i2,"elements",ach,aElementsItem))
|
||||
aElements->SetValue(i2,aElementsItem);
|
||||
}
|
||||
}
|
||||
|
||||
//--- Initialisation of the read entity ---
|
||||
|
||||
|
||||
ent->Init(aName, aElements);
|
||||
}
|
||||
|
||||
|
||||
void RWStepShape_RWGeometricCurveSet::WriteStep
|
||||
(StepData_StepWriter& SW,
|
||||
const Handle(StepShape_GeometricCurveSet)& ent) const
|
||||
{
|
||||
|
||||
// --- inherited field name ---
|
||||
|
||||
SW.Send(ent->Name());
|
||||
|
||||
// --- inherited field elements ---
|
||||
|
||||
SW.OpenSub();
|
||||
for (Standard_Integer i2 = 1; i2 <= ent->NbElements(); i2 ++) {
|
||||
SW.Send(ent->ElementsValue(i2).Value());
|
||||
}
|
||||
SW.CloseSub();
|
||||
}
|
||||
|
||||
|
||||
void RWStepShape_RWGeometricCurveSet::Share(const Handle(StepShape_GeometricCurveSet)& ent, Interface_EntityIterator& iter) const
|
||||
{
|
||||
|
||||
Standard_Integer nbElem1 = ent->NbElements();
|
||||
for (Standard_Integer is1=1; is1<=nbElem1; is1 ++) {
|
||||
iter.GetOneItem(ent->ElementsValue(is1).Value());
|
||||
}
|
||||
|
||||
}
|
||||
|
Reference in New Issue
Block a user