// 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 StepData_FieldListD::StepData_FieldListD (const Standard_Integer nb) { if (nb > 0) thefields = new StepData_HArray1OfField (1,nb); } void StepData_FieldListD::SetNb (const Standard_Integer nb) { thefields.Nullify(); if (nb > 0) thefields = new StepData_HArray1OfField (1,nb); } Standard_Integer StepData_FieldListD::NbFields () const { return (thefields.IsNull() ? 0 : thefields->Length()); } const StepData_Field& StepData_FieldListD::Field (const Standard_Integer num) const { if (thefields.IsNull()) Standard_OutOfRange::Raise("StepData_FieldListD::Field"); return thefields->Value(num); } StepData_Field& StepData_FieldListD::CField (const Standard_Integer num) { if (thefields.IsNull()) Standard_OutOfRange::Raise("StepData_FieldListD::Field"); return thefields->ChangeValue(num); } void StepData_FieldListD::Destroy () {}