X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=lib%2FcreaDevManagerLib%2FmodelCDMMain.h;h=d028487404e97f36190ad0975ad90eebdda826bb;hb=741b9c1d03c7984f7ac4a39188e2bb114471f579;hp=6a104704912fcd57bd2a7413ff27db38550be98d;hpb=e2223b619fa37daaf6103b34b39e789efc1a0b94;p=crea.git diff --git a/lib/creaDevManagerLib/modelCDMMain.h b/lib/creaDevManagerLib/modelCDMMain.h index 6a10470..d028487 100644 --- a/lib/creaDevManagerLib/modelCDMMain.h +++ b/lib/creaDevManagerLib/modelCDMMain.h @@ -36,17 +36,50 @@ #define MODELCDMMAIN_H_ #include +#include +#include +#include + +#include "modelCDMIProjectTreeNode.h" #include "modelCDMProject.h" +/** + * Class representing the model of the project manager. + */ class modelCDMMain { public: + /** + * Default constructor. + */ modelCDMMain(); + /** + * Destructor. + */ ~modelCDMMain(); - const modelCDMProject* GetProject() const; + /** + * Retrieves the current active project. + * @return Reference to the current active project, if there's no active project NULL is returned. + */ + modelCDMProject* GetProject() const; + /** + * Retrieves the map of all the nodes inside the current active project. + * @return Map with ids and node reference of the project. + */ + std::map< wxCDMTreeItemId, modelCDMIProjectTreeNode* >& GetModelElements(); + + /** + * Creates a new project and sets it as the current active project. This method creates a new project model and also creates a project in the system. + * @param name Name of the new project. + * @param location Path where the project is to be created. + * @param result Result message. + * @param author Default Package Authors' names. + * @param description Description of the default package. + * @return True if the operation was successful. + */ bool CreateProject( const std::string& name, const std::string& location, @@ -54,19 +87,43 @@ public: const std::string& author = "unknown", const std::string& description = "no description" ); + /** + * Opens an existing project given the source or the binaries folder. + * @param path Path to the project source or binaries folder. + * @param result Result message. + * @return True if the operation was successful. + */ bool OpenProject( const std::string& path, std::string*& result ); + /** + * Refreshes the currently active project structure. + * @param result Result message. + * @return True if the operation was successful. + */ bool RefreshProject( std::string*& result ); + /** + * Closes the currently active project. This method deletes the project model but doesn't erase the project from the system. + * @param result Result message. + * @return True if the operation was successful. + */ bool CloseProject( std::string*& result ); + private: + /** + * Currently active project reference. + */ modelCDMProject* project; + /** + * Map of all the elements of the currently active project and their IDs. + */ + std::map< wxCDMTreeItemId, modelCDMIProjectTreeNode* > modelElements; };