1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-05-01 10:26:12 +03:00
occt/src/IGESGraph/IGESGraph_ToolNominalSize.cxx
abv 42cf5bc1ca 0024002: Overall code and build procedure refactoring -- automatic
Automatic upgrade of OCCT code by command "occt_upgrade . -nocdl":
- WOK-generated header files from inc and sources from drv are moved to src
- CDL files removed
- All packages are converted to nocdlpack
2015-07-12 07:42:38 +03:00

160 lines
5.8 KiB
C++

// Created by: CKY / Contract Toubro-Larsen
// 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 <IGESData_DirChecker.hxx>
#include <IGESData_Dump.hxx>
#include <IGESData_IGESDumper.hxx>
#include <IGESData_IGESReaderData.hxx>
#include <IGESData_IGESWriter.hxx>
#include <IGESData_ParamCursor.hxx>
#include <IGESData_ParamReader.hxx>
#include <IGESGraph_NominalSize.hxx>
#include <IGESGraph_ToolNominalSize.hxx>
#include <Interface_Check.hxx>
#include <Interface_CopyTool.hxx>
#include <Interface_EntityIterator.hxx>
#include <Interface_Macros.hxx>
#include <Interface_ShareTool.hxx>
#include <Message_Messenger.hxx>
#include <Standard_DomainError.hxx>
#include <TCollection_HAsciiString.hxx>
IGESGraph_ToolNominalSize::IGESGraph_ToolNominalSize () { }
void IGESGraph_ToolNominalSize::ReadOwnParams
(const Handle(IGESGraph_NominalSize)& ent,
const Handle(IGESData_IGESReaderData)& /*IR*/, IGESData_ParamReader& PR) const
{
//Standard_Boolean st; //szv#4:S4163:12Mar99 not needed
Standard_Integer nbPropertyValues;
Standard_Real nominalSizeValue;
Handle(TCollection_HAsciiString) nominalSizeName;
Handle(TCollection_HAsciiString) standardName;
// Reading nbPropertyValues(Integer)
PR.ReadInteger(PR.Current(), "No. of property values", nbPropertyValues); //szv#4:S4163:12Mar99 `st=` not needed
if ( (nbPropertyValues != 2) && (nbPropertyValues != 3) )
PR.AddFail("No. of Property values : Value is not 2/3");
// Reading nominalSizeValue(Real)
PR.ReadReal (PR.Current(), "Nominal size value", nominalSizeValue); //szv#4:S4163:12Mar99 `st=` not needed
// Reading nominalSizeName(String)
PR.ReadText (PR.Current(), "Nominal size name", nominalSizeName); //szv#4:S4163:12Mar99 `st=` not needed
if ( PR.NbParams() >= PR.CurrentNumber() )
{
Standard_Integer num = PR.CurrentNumber();
if ( PR.ParamType(num) == Interface_ParamText )
// Reading standardName(String)
PR.ReadText (PR.Current(), "Name of relevant engg. standard",
standardName); //szv#4:S4163:12Mar99 `st=` not needed
}
DirChecker(ent).CheckTypeAndForm(PR.CCheck(),ent);
ent->Init
(nbPropertyValues, nominalSizeValue, nominalSizeName, standardName);
}
void IGESGraph_ToolNominalSize::WriteOwnParams
(const Handle(IGESGraph_NominalSize)& ent, IGESData_IGESWriter& IW) const
{
IW.Send( ent->NbPropertyValues() );
IW.Send( ent->NominalSizeValue() );
IW.Send( ent->NominalSizeName() );
if (ent->HasStandardName() )
IW.Send( ent->StandardName() ); // optionnal
}
void IGESGraph_ToolNominalSize::OwnShared
(const Handle(IGESGraph_NominalSize)& /*ent*/, Interface_EntityIterator& /*iter*/) const
{
}
void IGESGraph_ToolNominalSize::OwnCopy
(const Handle(IGESGraph_NominalSize)& another,
const Handle(IGESGraph_NominalSize)& ent, Interface_CopyTool& /*TC*/) const
{
Standard_Integer nbPropertyValues;
Standard_Real nominalSizeValue;
Handle(TCollection_HAsciiString) nominalSizeName;
Handle(TCollection_HAsciiString) standardName;
nbPropertyValues = another->NbPropertyValues();
nominalSizeValue = another->NominalSizeValue();
nominalSizeName = new TCollection_HAsciiString(another->NominalSizeName());
if (another->HasStandardName()) standardName =
new TCollection_HAsciiString(another->StandardName());
ent->Init(nbPropertyValues, nominalSizeValue, nominalSizeName, standardName);
}
Standard_Boolean IGESGraph_ToolNominalSize::OwnCorrect
(const Handle(IGESGraph_NominalSize)& ent) const
{
Standard_Integer nbp = 2;
if (ent->HasStandardName()) nbp = 3;
Standard_Boolean res = ( ent->NbPropertyValues() != nbp);
if (res) ent->Init
(nbp,ent->NominalSizeValue(),ent->NominalSizeName(),ent->StandardName());
return res; // nbpropertyvalues=2/3 selon standard
}
IGESData_DirChecker IGESGraph_ToolNominalSize::DirChecker
(const Handle(IGESGraph_NominalSize)& /*ent*/) const
{
IGESData_DirChecker DC (406, 13);
DC.Structure(IGESData_DefVoid);
DC.LineFont(IGESData_DefVoid);
DC.LineWeight(IGESData_DefVoid);
DC.Color(IGESData_DefVoid);
DC.BlankStatusIgnored();
DC.UseFlagIgnored();
DC.HierarchyStatusIgnored();
return DC;
}
void IGESGraph_ToolNominalSize::OwnCheck
(const Handle(IGESGraph_NominalSize)& ent,
const Interface_ShareTool& , Handle(Interface_Check)& ach) const
{
Standard_Integer nbp = 2;
if (ent->HasStandardName()) nbp = 3;
if ( ent->NbPropertyValues() != nbp) ach->AddFail
("No. of Property values : Value != 2/3 according Standard Name Status");
}
void IGESGraph_ToolNominalSize::OwnDump
(const Handle(IGESGraph_NominalSize)& ent, const IGESData_IGESDumper& /*dumper*/,
const Handle(Message_Messenger)& S, const Standard_Integer /*level*/) const
{
S << "IGESGraph_NominalSize" << endl;
S << "No. of property values : " << ent->NbPropertyValues() << endl;
S << "Nominal size value : " << ent->NominalSizeValue() << endl;
S << "Nominal size name : ";
IGESData_DumpString(S,ent->NominalSizeName());
S << endl;
S << "Name of relevant engineering standard : ";
IGESData_DumpString(S,ent->StandardName());
S << endl;
}