#include #include #include #include #include #include #include #include #include //======================================================================= //function : MDataStd_ExpressionStorageDriver //purpose : //======================================================================= MDataStd_ExpressionStorageDriver::MDataStd_ExpressionStorageDriver(const Handle(CDM_MessageDriver)& theMsgDriver):MDF_ASDriver(theMsgDriver) { } //======================================================================= //function : VersionNumber //purpose : //======================================================================= Standard_Integer MDataStd_ExpressionStorageDriver::VersionNumber() const { return 0; } //======================================================================= //function : SourceType //purpose : //======================================================================= Handle(Standard_Type) MDataStd_ExpressionStorageDriver::SourceType() const { return STANDARD_TYPE(TDataStd_Expression);} //======================================================================= //function : NewEmpty //purpose : //======================================================================= Handle(PDF_Attribute) MDataStd_ExpressionStorageDriver::NewEmpty() const { return new PDataStd_Expression; } //======================================================================= //function : Paste //purpose : //======================================================================= void MDataStd_ExpressionStorageDriver::Paste(const Handle(TDF_Attribute)& Source, const Handle(PDF_Attribute)& Target, const Handle(MDF_SRelocationTable)& RelocTable) const { Handle(TDataStd_Expression) S = Handle(TDataStd_Expression)::DownCast (Source); Handle(PDataStd_Expression) T = Handle(PDataStd_Expression)::DownCast (Target); Handle(PCollection_HExtendedString) Expression = new PCollection_HExtendedString (S->Name()); T->SetName (Expression); Handle(TDF_Attribute) TV; Handle(PDF_Attribute) PV; Standard_Integer nbvar = S->GetVariables().Extent(); if (nbvar <= 0) return; Handle(PDF_HAttributeArray1) PVARS = new PDF_HAttributeArray1 (1, nbvar); TDF_ListIteratorOfAttributeList it; Standard_Integer index = 0; for (it.Initialize(S->GetVariables());it.More();it.Next()) { index++; TV = it.Value(); if(!RelocTable->HasRelocation (TV, PV)) { Standard_NoSuchObject::Raise("MDataStd_ExpressionStorageDriver::Paste"); } PVARS->SetValue (index,PV); } T->SetVariables (PVARS); }