*/
class ModelAPI_Document
{
- public:
- //! Loads the OCAF document from the file.
- //! \param theFileName full name of the file to load
- //! \param theStudyID identifier of the SALOME study to associate with loaded file
- //! \returns true if file was loaded successfully
- virtual bool load(const char* theFileName) = 0;
-
- //! Saves the OCAF document to the file.
- //! \param theFileName full name of the file to store
- //! \param theResults the result full file names that were stored by "save"
- //! \returns true if file was stored successfully
- virtual bool save(const char* theFileName, std::list<std::string>& theResults) = 0;
+public:
+ //! Returns the kind of the document: "PartSet", "Part", or something else.
+ //! This kind is used for feature buttons enable/disable depending on active document
+ //! (it uses workbench "document" identifier in XML configuration file for this)
+ virtual const std::string& kind() const = 0;
//! Removes document data
virtual void close() = 0;
- //! Starts a new operation (opens a tansaction)
- virtual void startOperation() = 0;
- //! Finishes the previously started operation (closes the transaction)
- virtual void finishOperation() = 0;
- //! Aborts the operation
- virtual void abortOperation() = 0;
- //! Returns true if operation has been started, but not yet finished or aborted
- virtual bool isOperation() = 0;
- //! Returns true if document was modified (since creation/opening)
- virtual bool isModified() = 0;
-
- //! Returns True if there are available Undos
- virtual bool canUndo() = 0;
- //! Undoes last operation
- virtual void undo() = 0;
- //! Returns True if there are available Redos
- virtual bool canRedo() = 0;
- //! Redoes last operation
- virtual void redo() = 0;
-
//! Adds to the document the new feature of the given feature id
//! \param creates feature and puts it in the document (if it is not action)
virtual boost::shared_ptr<ModelAPI_Feature> addFeature(std::string theID) = 0;
//! Removes the feature from the document
- virtual void removeFeature(boost::shared_ptr<ModelAPI_Feature> theFeature) = 0;
+ virtual void removeFeature(boost::shared_ptr<ModelAPI_Feature> theFeature,
+ const bool theCheck = true) = 0;
///! Adds a new sub-document by the identifier, or returns existing one if it is already exist
- virtual boost::shared_ptr<ModelAPI_Document>
- subDocument(std::string theDocID) = 0;
+ virtual boost::shared_ptr<ModelAPI_Document> subDocument(std::string theDocID) = 0;
///! Returns the id of the document
virtual const std::string& id() const = 0;
//! \param theGroupID group that contains an object
//! \param theIndex zero-based index of feature in the group
//! \param theHidden if it is true, it counts also the features that are not in tree
- virtual boost::shared_ptr<ModelAPI_Object>
- object(const std::string& theGroupID, const int theIndex, const bool theHidden = false) = 0;
+ virtual boost::shared_ptr<ModelAPI_Object> object(const std::string& theGroupID,
+ const int theIndex,
+ const bool theHidden = false) = 0;
//! Returns the number of objects in the group of objects
//! If theHidden is true, it counts also the features that are not in tree
virtual boost::shared_ptr<ModelAPI_Feature> feature(
const boost::shared_ptr<ModelAPI_Result>& theResult) = 0;
- protected:
+ ///! Reutrns true is result was conecaled because of usage it by other object
+ virtual bool isConcealed(const boost::shared_ptr<ModelAPI_Object>& theResult) = 0;
+
+protected:
/// Only for SWIG wrapping it is here
MODELAPI_EXPORT ModelAPI_Document()
{