1
0
mirror of https://git.dev.opencascade.org/repos/occt.git synced 2025-05-26 11:05:31 +03:00
occt/src/IGESDefs/IGESDefs_ToolAttributeTable.cxx
abv 0ebe5b0a7f 0031501: Foundation Classes, Message_Printer - remove theToPutEndl argument -- preparation
Operators << for Handle(Message_Messenger) are removed; their use is replaced by use of Message_Messenger::StreamBuffer
Message_Messenger has been replaced by Standard_OStream within Interface_InterfaceModel,IFSelect,IGES,STEP dump interfaces.
2020-05-09 17:22:13 +03:00

355 lines
12 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_HArray1OfIGESEntity.hxx>
#include <IGESData_IGESDumper.hxx>
#include <IGESData_IGESReaderData.hxx>
#include <IGESData_IGESWriter.hxx>
#include <IGESData_ParamCursor.hxx>
#include <IGESData_ParamReader.hxx>
#include <IGESDefs_AttributeDef.hxx>
#include <IGESDefs_AttributeTable.hxx>
#include <IGESDefs_ToolAttributeTable.hxx>
#include <Interface_Check.hxx>
#include <Interface_CopyTool.hxx>
#include <Interface_EntityIterator.hxx>
#include <Interface_HArray1OfHAsciiString.hxx>
#include <Interface_Macros.hxx>
#include <Interface_ShareTool.hxx>
#include <Message_Messenger.hxx>
#include <Standard_DomainError.hxx>
#include <TCollection_HAsciiString.hxx>
#include <TColStd_HArray1OfInteger.hxx>
#include <TColStd_HArray1OfReal.hxx>
#include <TColStd_HArray2OfTransient.hxx>
IGESDefs_ToolAttributeTable::IGESDefs_ToolAttributeTable () { }
void IGESDefs_ToolAttributeTable::ReadOwnParams
(const Handle(IGESDefs_AttributeTable)& ent,
const Handle(IGESData_IGESReaderData)& IR, IGESData_ParamReader& PR) const
{
Standard_Integer nr = 1;
Standard_Integer j;
Standard_Boolean st = Standard_True;
Handle(IGESDefs_AttributeDef) ab = ent->Definition(); // formerly loaded
Handle(TColStd_HArray2OfTransient) list2;
if (ab.IsNull()) {
PR.AddFail("No Attribute Definition as Structure");
return;
}
Standard_Integer na = ab->NbAttributes();
if (ent->FormNumber() == 1)
st = PR.ReadInteger(PR.Current(),"No. of rows",nr);
if (st) list2 = new TColStd_HArray2OfTransient(1,na,1,nr);
// AttributeDef repeated once (Form 0) or <nr> times (Form 1)
for (Standard_Integer k = 1; k <= nr; k ++)
{
for (Standard_Integer i = 1; i <= na; i ++)
{
Standard_Integer avc = ab->AttributeValueCount(i);
Standard_Integer atype = ab->AttributeValueDataType(i);
switch (atype)
{
case 0 :
for (j = 1; j <= avc; j ++)
PR.SetCurrentNumber(PR.CurrentNumber() + 1); // skip
break;
case 1 : {
Handle(TColStd_HArray1OfInteger) attrInt = new TColStd_HArray1OfInteger(1,avc);
list2->SetValue(i,k,attrInt);
Standard_Integer item;
for (j = 1; j <= avc; j ++) {
//st = PR.ReadInteger(PR.Current(),"Value",item); //szv#4:S4163:12Mar99 moved in if
if (PR.ReadInteger(PR.Current(),"Value",item))
attrInt->SetValue(j,item);
}
}
break;
case 2 : {
Handle(TColStd_HArray1OfReal) attrReal = new TColStd_HArray1OfReal(1,avc);
list2->SetValue(i,k,attrReal);
Standard_Real item;
for (j = 1; j <= avc; j ++) {
//st = PR.ReadReal(PR.Current(),"Value",item); //szv#4:S4163:12Mar99 moved in if
if (PR.ReadReal(PR.Current(),"Value",item))
attrReal->SetValue(j,item);
}
}
break;
case 3 : {
Handle(Interface_HArray1OfHAsciiString) attrStr = new Interface_HArray1OfHAsciiString(1,avc);
list2->SetValue(i,k,attrStr);
Handle(TCollection_HAsciiString) item;
for (j = 1; j <= avc; j ++) {
//st = PR.ReadText(PR.Current(),"Value",item); //szv#4:S4163:12Mar99 moved in if
if (PR.ReadText(PR.Current(),"Value",item))
attrStr->SetValue(j,item);
}
}
break;
case 4 : {
Handle(IGESData_HArray1OfIGESEntity) attrEnt = new IGESData_HArray1OfIGESEntity(1,avc);
list2->SetValue(i,k,attrEnt);
Handle(IGESData_IGESEntity) item;
for (j = 1; j <= avc; j ++) {
//st = PR.ReadEntity(IR,PR.Current(),"Value",item); //szv#4:S4163:12Mar99 moved in if
if (PR.ReadEntity(IR,PR.Current(),"Value",item))
attrEnt->SetValue(j,item);
}
}
break;
case 5 :
for (j = 1; j <= avc; j ++)
PR.SetCurrentNumber(PR.CurrentNumber() + 1); // skip
break;
case 6 : { // Here item takes value 0 or 1
Handle(TColStd_HArray1OfInteger) attrInt = new TColStd_HArray1OfInteger(1,avc);
list2->SetValue(i,k,attrInt);
Standard_Integer item;
for (j = 1; j <= avc; j ++) {
//st = PR.ReadInteger(PR.Current(),"Value",item); //szv#4:S4163:12Mar99 moved in if
if (PR.ReadInteger(PR.Current(),"Value",item))
attrInt->SetValue(j,item);
}
}
break;
default : break;
}
}
}
DirChecker(ent).CheckTypeAndForm(PR.CCheck(),ent);
ent->Init(list2);
}
void IGESDefs_ToolAttributeTable::WriteOwnParams
(const Handle(IGESDefs_AttributeTable)& ent, IGESData_IGESWriter& IW) const
{
Handle(IGESDefs_AttributeDef) ab = ent->Definition();
Standard_Integer nr = ent->NbRows();
Standard_Integer na = ent->NbAttributes();
if (ent->FormNumber() == 1) IW.Send(nr);
for (Standard_Integer k = 1; k <= nr; k ++)
{
for (Standard_Integer i = 1; i <= na; i ++)
{
Standard_Integer count = ab->AttributeValueCount(i);
for (Standard_Integer j = 1;j <= count; j++)
{
switch(ab->AttributeValueDataType(i))
{
case 0 : IW.SendVoid(); break;
case 1 : IW.Send(ent->AttributeAsInteger(i,k,j)); break;
case 2 : IW.Send(ent->AttributeAsReal (i,k,j)); break;
case 3 : IW.Send(ent->AttributeAsString (i,k,j)); break;
case 4 : IW.Send(ent->AttributeAsEntity (i,k,j)); break;
case 5 : IW.SendVoid(); break;
case 6 : IW.SendBoolean(ent->AttributeAsLogical(i,k,j)); break;
default : break;
}
}
}
}
}
void IGESDefs_ToolAttributeTable::OwnShared
(const Handle(IGESDefs_AttributeTable)& ent, Interface_EntityIterator& iter) const
{
Handle(IGESDefs_AttributeDef) ab = ent->Definition();
Standard_Integer na = ent->NbAttributes();
Standard_Integer nr = ent->NbRows();
for (Standard_Integer k = 1; k <= nr; k ++)
{
for (Standard_Integer i = 1; i <= na; i ++)
{
if (ab->AttributeValueDataType(i) != 4) continue;
Standard_Integer avc = ab->AttributeValueCount(i);
for (Standard_Integer j = 1; j <= avc; j ++)
iter.GetOneItem(ent->AttributeAsEntity(i,k,j));
}
}
}
void IGESDefs_ToolAttributeTable::OwnCopy
(const Handle(IGESDefs_AttributeTable)& another,
const Handle(IGESDefs_AttributeTable)& ent, Interface_CopyTool& TC) const
{
Standard_Integer j = 1;
Handle(IGESDefs_AttributeDef) ab = another->Definition();
Standard_Integer na = another->NbAttributes();
Standard_Integer nr = another->NbRows();
Handle(TColStd_HArray2OfTransient) list2 =
new TColStd_HArray2OfTransient(1,na,1,nr);
for (Standard_Integer k = 1; k <= nr; k ++)
{
for (Standard_Integer i = 1; i <= na; i ++)
{
Standard_Integer avc = ab->AttributeValueCount(i);
Standard_Integer atype = ab->AttributeValueDataType(i);
switch (atype)
{
case 0 : //// list2->SetValue(i,k,NULL); par defaut
break;
case 1 : {
DeclareAndCast(TColStd_HArray1OfInteger,otherInt,
another->AttributeList(i,k));
Handle(TColStd_HArray1OfInteger) attrInt =
new TColStd_HArray1OfInteger (1,avc);
list2->SetValue(i,k,attrInt);
for (j = 1; j <= avc; j++)
attrInt->SetValue(j,otherInt->Value(j));
}
break;
case 2 : {
DeclareAndCast(TColStd_HArray1OfReal,otherReal,
another->AttributeList(i,k));
Handle(TColStd_HArray1OfReal) attrReal =
new TColStd_HArray1OfReal (1,avc);
list2->SetValue(i,k,attrReal);
for (j = 1; j <= avc; j++)
attrReal->SetValue(j,otherReal->Value(j));
}
break;
case 3 : {
DeclareAndCast(Interface_HArray1OfHAsciiString,otherStr,
another->AttributeList(i,k));
Handle(Interface_HArray1OfHAsciiString) attrStr =
new Interface_HArray1OfHAsciiString (1,avc);
list2->SetValue(i,k,attrStr);
for (j = 1; j <= avc; j++)
attrStr->SetValue
(j,new TCollection_HAsciiString(otherStr->Value(j)));
}
break;
case 4 : {
DeclareAndCast(IGESData_HArray1OfIGESEntity,otherEnt,
another->AttributeList(i,k));
Handle(IGESData_HArray1OfIGESEntity) attrEnt =
new IGESData_HArray1OfIGESEntity (1,avc);
list2->SetValue(i,k,attrEnt);
for (j = 1; j <= avc; j++)
attrEnt->SetValue(j,GetCasted(IGESData_IGESEntity,
TC.Transferred(otherEnt->Value(j))));
}
break;
case 5 : ///// list2->SetValue(i,k,NULL); par defaut
break;
case 6 :{ // Here item takes value 0 or 1
DeclareAndCast(TColStd_HArray1OfInteger,otherInt,
another->AttributeList(i,k));
Handle(TColStd_HArray1OfInteger) attrInt =
new TColStd_HArray1OfInteger (1,avc);
list2->SetValue(i,k,attrInt);
for (j = 1; j <= avc; j++)
attrInt->SetValue(j,otherInt->Value(j));
}
break;
default : break;
}
}
}
ent->Init(list2);
}
IGESData_DirChecker IGESDefs_ToolAttributeTable::DirChecker
(const Handle(IGESDefs_AttributeTable)& /* ent */ ) const
{
IGESData_DirChecker DC(422,0,1);
DC.Structure(IGESData_DefReference);
DC.GraphicsIgnored();
DC.BlankStatusIgnored();
DC.HierarchyStatusIgnored();
return DC;
}
void IGESDefs_ToolAttributeTable::OwnCheck
(const Handle(IGESDefs_AttributeTable)& ent,
const Interface_ShareTool& , Handle(Interface_Check)& ach) const
{
if (ent->Definition().IsNull()) {
if (ent->HasStructure()) ach->AddFail
("Structure in Directory Entry is not an Attribute Definition Table");
else ach->AddFail("No Attribute Definition defined");
}
if (ent->FormNumber() == 0 && ent->NbRows() != 1)
ach->AddFail("Form 0 with several Rows");
if (ent->NbAttributes() != ent->Definition()->NbAttributes())
ach->AddFail("Mismatch between Definition (Structure) and Content");
}
void IGESDefs_ToolAttributeTable::OwnDump
(const Handle(IGESDefs_AttributeTable)& ent, const IGESData_IGESDumper& dumper,
Standard_OStream& S, const Standard_Integer level) const
{
S << "IGESDefs_AttributeTable\n";
Handle(IGESDefs_AttributeDef) ab = ent->Definition();
Standard_Integer na = ent->NbAttributes();
Standard_Integer nr = ent->NbRows();
if (ent->FormNumber() == 1)
S << "Number of Rows (i.e. complete sets of Attributes) : " << nr << "\n";
else S << "One set of Attributes\n";
S << "Number of defined Attributes : " << na << "\n";
if (level <= 4) S <<
" [ structure : see Structure in Directory Entry; content : level > 4 ]\n";
else
for (Standard_Integer k = 1; k <= nr; k ++)
{
for (Standard_Integer i = 1; i <= na; i ++)
{
Standard_Integer avc = ab->AttributeValueCount(i);
S << "[At.no."<<i<<" Row:"<<k<<"]";
switch (ab->AttributeValueDataType(i)) {
case 0 : S << " (Void) "; break;
case 1 : S << " Integer"; break;
case 2 : S << " Real "; break;
case 3 : S << " String "; break;
case 4 : S << " Entity "; break;
case 5 : S << " (Not used)"; break;
case 6 : S << " Logical"; break;
default : break;
}
S << " :";
for (Standard_Integer j = 1;j <= avc; j++) {
S << " ";
switch(ab->AttributeValueDataType(i)) {
case 1 : S << ent->AttributeAsInteger(i,k,j); break;
case 2 : S << ent->AttributeAsReal (i,k,j); break;
case 3 : IGESData_DumpString(S,ent->AttributeAsString (i,k,j));
break;
case 4 : dumper.Dump(ent->AttributeAsEntity (i,k,j),S,level-5);
break;
case 6 : S << (ent->AttributeAsLogical(i,k,j) ? "True" : "False");
break;
default : break;
}
}
S << "\n";
}
}
S << std::endl;
}