#include <TDF_Label.hxx>
-#include <boost/smart_ptr/shared_ptr.hpp>
+#include <memory>
#include <map>
#include <list>
{
TDF_Label myLab; ///< label of the feature in the document
/// All attributes of the object identified by the attribute ID
- std::map<std::string, boost::shared_ptr<ModelAPI_Attribute> > myAttrs;
+ std::map<std::string, std::shared_ptr<ModelAPI_Attribute> > myAttrs;
/// needed here to emit signal that object changed on change of the attribute
ObjectPtr myObject;
/// Defines the name of the feature visible by the user in the object browser
MODEL_EXPORT virtual void setName(const std::string& theName);
/// Returns the attribute that references to another document
- MODEL_EXPORT virtual boost::shared_ptr<ModelAPI_AttributeDocRef> document(const std::string& theID);
+ MODEL_EXPORT virtual std::shared_ptr<ModelAPI_AttributeDocRef> document(const std::string& theID);
/// Returns the attribute that contains real value with double precision
- MODEL_EXPORT virtual boost::shared_ptr<ModelAPI_AttributeDouble> real(const std::string& theID);
+ MODEL_EXPORT virtual std::shared_ptr<ModelAPI_AttributeDouble> real(const std::string& theID);
/// Returns the attribute that contains integer value
- MODEL_EXPORT virtual boost::shared_ptr<ModelAPI_AttributeInteger>
+ MODEL_EXPORT virtual std::shared_ptr<ModelAPI_AttributeInteger>
integer(const std::string& theID);
/// Returns the attribute that contains reference to a feature
- MODEL_EXPORT virtual boost::shared_ptr<ModelAPI_AttributeReference>
+ MODEL_EXPORT virtual std::shared_ptr<ModelAPI_AttributeReference>
reference(const std::string& theID);
/// Returns the attribute that contains selection to a shape
- MODEL_EXPORT virtual boost::shared_ptr<ModelAPI_AttributeSelection>
+ MODEL_EXPORT virtual std::shared_ptr<ModelAPI_AttributeSelection>
selection(const std::string& theID);
/// Returns the attribute that contains selection to a shape
- MODEL_EXPORT virtual boost::shared_ptr<ModelAPI_AttributeSelectionList>
+ MODEL_EXPORT virtual std::shared_ptr<ModelAPI_AttributeSelectionList>
selectionList(const std::string& theID);
/// Returns the attribute that contains reference to an attribute of a feature
- MODEL_EXPORT virtual boost::shared_ptr<ModelAPI_AttributeRefAttr>
+ MODEL_EXPORT virtual std::shared_ptr<ModelAPI_AttributeRefAttr>
refattr(const std::string& theID);
/// Returns the attribute that contains list of references to features
- MODEL_EXPORT virtual boost::shared_ptr<ModelAPI_AttributeRefList>
+ MODEL_EXPORT virtual std::shared_ptr<ModelAPI_AttributeRefList>
reflist(const std::string& theID);
/// Returns the attribute that contains boolean value
- MODEL_EXPORT virtual boost::shared_ptr<ModelAPI_AttributeBoolean>
+ MODEL_EXPORT virtual std::shared_ptr<ModelAPI_AttributeBoolean>
boolean(const std::string& theID);
/// Returns the attribute that contains real value with double precision
- MODEL_EXPORT virtual boost::shared_ptr<ModelAPI_AttributeString>
+ MODEL_EXPORT virtual std::shared_ptr<ModelAPI_AttributeString>
string(const std::string& theID);
/// Returns the generic attribute by identifier
/// \param theID identifier of the attribute
- MODEL_EXPORT virtual boost::shared_ptr<ModelAPI_Attribute> attribute(const std::string& theID);
+ MODEL_EXPORT virtual std::shared_ptr<ModelAPI_Attribute> attribute(const std::string& theID);
/// Returns all attributes of the feature of the given type
/// or all attributes if "theType" is empty
- MODEL_EXPORT virtual std::list<boost::shared_ptr<ModelAPI_Attribute> >
+ MODEL_EXPORT virtual std::list<std::shared_ptr<ModelAPI_Attribute> >
attributes(const std::string& theType);
/// Returns all attributes ids of the feature of the given type
/// or all attributes if "theType" is empty
/// Identifier by the id (not fast, iteration by map)
/// \param theAttr attribute already created in this data
- MODEL_EXPORT virtual const std::string& id(const boost::shared_ptr<ModelAPI_Attribute>& theAttr);
+ MODEL_EXPORT virtual const std::string& id(const std::shared_ptr<ModelAPI_Attribute>& theAttr);
/// Returns true if data belongs to same features
- MODEL_EXPORT virtual bool isEqual(const boost::shared_ptr<ModelAPI_Data>& theData);
+ MODEL_EXPORT virtual bool isEqual(const std::shared_ptr<ModelAPI_Data>& theData);
/// Returns true if it is correctly connected t othe data model
MODEL_EXPORT virtual bool isValid();
myObject = theObject;
}
+ /// Erases all the data from the data model
MODEL_EXPORT virtual void erase();
- /// Makes feature must be updated later (on rebuild). Normally the Updater must call it
- /// in case of not-automatic update to true
- MODEL_EXPORT virtual void mustBeUpdated(const bool theFlag);
+ /// Stores the state of the object to execute it later accordingly
+ MODEL_EXPORT virtual void execState(const ModelAPI_ExecState theState);
- /// Returns true if feature must be updated (re-executed) on rebuild
- MODEL_EXPORT virtual bool mustBeUpdated();
+ /// Returns the state of the latest execution of the feature
+ MODEL_EXPORT virtual ModelAPI_ExecState execState();
+
+ /// Registers error during the execution, causes the ExecutionFailed state
+ MODEL_EXPORT virtual void setError(const std::string& theError);
/// Returns the identifier of feature-owner, unique in this document
MODEL_EXPORT virtual int featureId() const;
+ // returns all objects referenced to this
+ MODEL_EXPORT virtual const std::set<AttributePtr>& refsToMe() {return myRefsToMe;}
+
private:
// removes all information about back references
- inline void eraseBackReferences() {myRefsToMe.clear();}
+ void eraseBackReferences();
// adds a back reference (with identifier which attribute references to this object
void addBackReference(FeaturePtr theFeature, std::string theAttrID);
- // returns all objects referenced to this
- const std::set<AttributePtr>& refsToMe() {return myRefsToMe;}
// returns all references by attributes of this data
// \param the returned list of pairs: id of referenced attribute and list of referenced objects
void referencesToObjects(std::list<std::pair<std::string, std::list<ObjectPtr> > >& theRefs);