1 // Copyright (c) 1999-2014 OPEN CASCADE SAS
3 // This file is part of Open CASCADE Technology software library.
5 // This library is free software; you can redistribute it and/or modify it under
6 // the terms of the GNU Lesser General Public License version 2.1 as published
7 // by the Free Software Foundation, with special exception defined in the file
8 // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT
9 // distribution for complete text of the license and disclaimer of any warranty.
11 // Alternatively, this file may be used under the terms of Open CASCADE
12 // commercial license or contractual agreement.
15 #include <Standard_Type.hxx>
16 #include <StepGeom_CompositeCurve.hxx>
17 #include <StepGeom_CompositeCurveSegment.hxx>
18 #include <TCollection_HAsciiString.hxx>
20 IMPLEMENT_STANDARD_RTTIEXT(StepGeom_CompositeCurve,StepGeom_BoundedCurve)
22 StepGeom_CompositeCurve::StepGeom_CompositeCurve () {}
24 void StepGeom_CompositeCurve::Init(
25 const Handle(TCollection_HAsciiString)& aName,
26 const Handle(StepGeom_HArray1OfCompositeCurveSegment)& aSegments,
27 const StepData_Logical aSelfIntersect)
29 // --- classe own fields ---
31 selfIntersect = aSelfIntersect;
32 // --- classe inherited fields ---
33 StepRepr_RepresentationItem::Init(aName);
37 void StepGeom_CompositeCurve::SetSegments(const Handle(StepGeom_HArray1OfCompositeCurveSegment)& aSegments)
42 Handle(StepGeom_HArray1OfCompositeCurveSegment) StepGeom_CompositeCurve::Segments() const
47 Handle(StepGeom_CompositeCurveSegment) StepGeom_CompositeCurve::SegmentsValue(const Standard_Integer num) const
49 return segments->Value(num);
52 Standard_Integer StepGeom_CompositeCurve::NbSegments () const
54 if (segments.IsNull()) return 0;
55 return segments->Length();
58 void StepGeom_CompositeCurve::SetSelfIntersect(const StepData_Logical aSelfIntersect)
60 selfIntersect = aSelfIntersect;
63 StepData_Logical StepGeom_CompositeCurve::SelfIntersect() const