X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModelAPI%2FModelAPI_Feature.h;h=5572bc08d4147cf49467f2fdc5563ed1ba473ab1;hb=9b6fa5ea0662642f58e278af3798f4dc9ddd0acf;hp=269471f84f9404277236c65c621970f087295e49;hpb=4b5410d157f6aab17772617fcaa09c5d660d13e9;p=modules%2Fshaper.git diff --git a/src/ModelAPI/ModelAPI_Feature.h b/src/ModelAPI/ModelAPI_Feature.h index 269471f84..5572bc08d 100644 --- a/src/ModelAPI/ModelAPI_Feature.h +++ b/src/ModelAPI/ModelAPI_Feature.h @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D + // File: ModelAPI_Feature.hxx // Created: 21 Mar 2014 // Author: Mikhail PONIKAROV @@ -7,29 +9,14 @@ #include #include -#include -#include -#include -#include -#include -#include -#include -#include -#include -#include #include #include -#include -#include +#include #include #include -class ModelAPI_Data; -class ModelAPI_Document; -class ModelAPI_Result; - /**\class ModelAPI_Feature * \ingroup DataModel * \brief Feature function that represents the particular functionality @@ -38,20 +25,20 @@ class ModelAPI_Result; class ModelAPI_Feature : public ModelAPI_Object { ///< list of current results of this feature - std::list > myResults; + std::list > myResults; public: /// Returns the unique kind of a feature (like "Point") virtual const std::string& getKind() = 0; /// Returns the group identifier of all features - static std::string group() + inline static std::string group() { static std::string MY_GROUP = "Features"; return MY_GROUP; } /// Returns document this feature belongs to - virtual boost::shared_ptr document() const + virtual std::shared_ptr document() const { return ModelAPI_Object::document(); } @@ -62,23 +49,34 @@ class ModelAPI_Feature : public ModelAPI_Object return group(); } - /// Request for initialization of data model of the feature: adding all attributes - virtual void initAttributes() = 0; - /// Computes or recomputes the results virtual void execute() = 0; + /// Computes the attribute value on the base of other attributes if the value can be computed + /// \param theAttributeId an attribute index to be computed + /// \return a boolean value about it is computed + virtual bool compute(const std::string& theAttributeId) { return false; }; + + /// Registers error during the execution, causes the ExecutionFailed state + virtual void setError(const std::string& theError) { + data()->setError(theError); + } + /// returns the current results of the feature - MODELAPI_EXPORT const std::list >& results(); + MODELAPI_EXPORT const std::list >& results(); /// returns the first result in the list or NULL reference - MODELAPI_EXPORT boost::shared_ptr firstResult(); + MODELAPI_EXPORT std::shared_ptr firstResult(); + /// returns the last result in the list or NULL reference + MODELAPI_EXPORT std::shared_ptr lastResult(); /// sets the alone result - MODELAPI_EXPORT void setResult(const boost::shared_ptr& theResult); + MODELAPI_EXPORT void setResult(const std::shared_ptr& theResult); /// sets the result by index (zero based), results before this must be set before - MODELAPI_EXPORT void setResult(const boost::shared_ptr& theResult, + MODELAPI_EXPORT void setResult(const std::shared_ptr& theResult, const int theIndex); /// removes the result from the feature - MODELAPI_EXPORT void removeResult(const boost::shared_ptr& theResult); + MODELAPI_EXPORT void removeResult(const std::shared_ptr& theResult); + /// removes all results starting from the gived index (zero-based) + MODELAPI_EXPORT void removeResults(const int theSinceIndex); /// removes all results from the feature MODELAPI_EXPORT void eraseResults(); /// removes all fields from this feature: results, data, etc @@ -96,73 +94,75 @@ class ModelAPI_Feature : public ModelAPI_Object } /// Must return document where the new feature must be added to - /// By default it is current document - MODELAPI_EXPORT virtual boost::shared_ptr documentToAdd(); + /// By default it is null document: it is added to the document this method is called to + MODELAPI_EXPORT virtual std::shared_ptr documentToAdd(); /// To virtually destroy the fields of successors MODELAPI_EXPORT virtual ~ModelAPI_Feature(); - MODELAPI_EXPORT static boost::shared_ptr feature(ObjectPtr theObject); + /// Returns the feature by the object (result). + MODELAPI_EXPORT static std::shared_ptr feature(ObjectPtr theObject); // // Helper methods, aliases for data()->method() // ----------------------------------------------------------------------------------------------- + /// Returns the name stored in the attribute inline std::string name() { return data()->name(); } - - inline boost::shared_ptr boolean(const std::string& theID) + /// Returns the Boolean attribute by the identifier + inline std::shared_ptr boolean(const std::string& theID) { return data()->boolean(theID); } - - inline boost::shared_ptr document(const std::string& theID) + /// Returns the document reference attribute + inline std::shared_ptr document(const std::string& theID) { return data()->document(theID); } - - inline boost::shared_ptr real(const std::string& theID) + /// Returns the real attribute by the identifier + inline std::shared_ptr real(const std::string& theID) { return data()->real(theID); } - - inline boost::shared_ptr integer(const std::string& theID) + /// Returns the integer attribute by the identifier + inline std::shared_ptr integer(const std::string& theID) { return data()->integer(theID); } - - inline boost::shared_ptr refattr(const std::string& theID) + /// Returns the reference attribute by the identifier + inline std::shared_ptr refattr(const std::string& theID) { return data()->refattr(theID); } - - inline boost::shared_ptr reference(const std::string& theID) + /// Returns the reference attribute by the identifier + inline std::shared_ptr reference(const std::string& theID) { return data()->reference(theID); } - - inline boost::shared_ptr reflist(const std::string& theID) + /// Returns the list of references attribute by the identifier + inline std::shared_ptr reflist(const std::string& theID) { return data()->reflist(theID); } - - inline boost::shared_ptr selection(const std::string& theID) + /// Returns the shape selection attribute by the identifier + inline std::shared_ptr selection(const std::string& theID) { return data()->selection(theID); } - - inline boost::shared_ptr selectionList(const std::string& theID) + /// Returns the list of shape selections attribute by the identifier + inline std::shared_ptr selectionList(const std::string& theID) { return data()->selectionList(theID); } - - inline boost::shared_ptr string(const std::string& theID) + /// Returns the string attribute by the identifier + inline std::shared_ptr string(const std::string& theID) { return data()->string(theID); } - - inline boost::shared_ptr attribute(const std::string& theID) + /// Returns the attribute by the identifier + inline std::shared_ptr attribute(const std::string& theID) { return data()->attribute(theID); } @@ -170,7 +170,7 @@ class ModelAPI_Feature : public ModelAPI_Object }; //! Pointer on feature object -typedef boost::shared_ptr FeaturePtr; +typedef std::shared_ptr FeaturePtr; #endif