X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;ds=sidebyside;f=src%2FModel%2FModel_AttributeString.cpp;h=72eb091932cb241b7662ab9bab9047f64196f48a;hb=9c0937c3fce2633ae166b8a70fe43998f4babd1d;hp=8a9d6f0ebcea225222a1361f5842200645c65647;hpb=542c9d721fbef80eb2040ef248fdd431cad2e631;p=modules%2Fshaper.git diff --git a/src/Model/Model_AttributeString.cpp b/src/Model/Model_AttributeString.cpp index 8a9d6f0eb..72eb09193 100644 --- a/src/Model/Model_AttributeString.cpp +++ b/src/Model/Model_AttributeString.cpp @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + // File: Model_AttributeString.cpp // Created: 25 august 2014 // Author: sbh @@ -11,8 +13,6 @@ #include #include #include -#include -#include #include @@ -20,6 +20,8 @@ void Model_AttributeString::setValue(const std::string& theValue) { TCollection_ExtendedString aValue(theValue.c_str()); if (!myIsInitialized || myString->Get() != aValue) { + if (myString.IsNull()) + myString = TDataStd_Name::Set(myLab, TCollection_ExtendedString()); myString->Set(aValue); owner()->data()->sendAttributeUpdated(this); } @@ -27,15 +29,19 @@ void Model_AttributeString::setValue(const std::string& theValue) std::string Model_AttributeString::value() { + if (myString.IsNull()) + return ""; // not initialized return TCollection_AsciiString(myString->Get()).ToCString(); } Model_AttributeString::Model_AttributeString(TDF_Label& theLabel) +{ + myLab = theLabel; + reinit(); +} + +void Model_AttributeString::reinit() { // check the attribute could be already presented in this doc (after load document) - myIsInitialized = theLabel.FindAttribute(TDataStd_Integer::GetID(), myString) == Standard_True; - if (!myIsInitialized) { - // create attribute: not initialized by value yet, just empty string - myString = TDataStd_Name::Set(theLabel, TCollection_ExtendedString()); - } + myIsInitialized = myLab.FindAttribute(TDataStd_Name::GetID(), myString) == Standard_True; }