// Created on: 2017-06-16 // Created by: Natalia ERMOLAEVA // Copyright (c) 2017 OPEN CASCADE SAS // // This file is part of Open CASCADE Technology software library. // // This library is free software; you can redistribute it and/or modify it under // the terms of the GNU Lesser General Public License version 2.1 as published // by the Free Software Foundation, with special exception defined in the file // OCCT_LGPL_EXCEPTION.txt. Consult the file LICENSE_LGPL_21.txt included in OCCT // distribution for complete text of the license and disclaimer of any warranty. // // Alternatively, this file may be used under the terms of Open CASCADE // commercial license or contractual agreement. #ifndef TInspectorAPI_PluginParameters_H #define TInspectorAPI_PluginParameters_H #include #include #include #include #include #include //! The container of parameters for all possible plugins. It stores list of parameters for each plugin, even //! it was not be loaded yet. There is a map of plugin name into plugin parameters. //! The parameters may be: //! - child of Standard_Transient //! - file name to be opened by the plugin class TInspectorAPI_PluginParameters : public Standard_Transient { public: //! Constructs the container. Standard_EXPORT TInspectorAPI_PluginParameters() {} //! Destructor Standard_EXPORT virtual ~TInspectorAPI_PluginParameters() {} //! Stores the parameters for plugin //! \param thePluginName a plugin name //! \param theParameters a list of parameters //! \param theToActivatePlugin a state whether the plugin should be immediately activated, to be used in a heir Standard_EXPORT virtual void SetParameters (const TCollection_AsciiString& thePluginName, const NCollection_List& theParameters, const Standard_Boolean& theToActivatePlugin = Standard_False); //! Adds a file name for the plugin //! \param thePluginName a plugin name //! \param theFileName a name Standard_EXPORT void AddFileName (const TCollection_AsciiString& thePluginName, const TCollection_AsciiString& theFileName); //! Sets file names for the plugin //! \param thePluginName a plugin name //! \param theFileNames container of names Standard_EXPORT void SetFileNames (const TCollection_AsciiString& thePluginName, const NCollection_List& theFileNames); //! Sets a name of item to be selected in the plugin //! \param thePluginName a plugin name //! \param theItemNames a container of names to be selected Standard_EXPORT void SetSelectedNames (const TCollection_AsciiString& thePluginName, const NCollection_List& theItemNames); //! Sets objects to be selected in the plugin //! \param thePluginName a plugin name //! \param theObjects an objects Standard_EXPORT void SetSelected (const TCollection_AsciiString& thePluginName, const NCollection_List& theObjects); //! Returns true if there are parameters set for the given plugin //! \param thePluginName a plugin name //! \return boolean result Standard_EXPORT bool FindParameters (const TCollection_AsciiString& thePluginName); //! Returns parameters set for the given plugin //! \param thePluginName a plugin name //! \return container of objects Standard_EXPORT const NCollection_List& Parameters (const TCollection_AsciiString& thePluginName); //! Returns true if there are file names set for the given plugin //! \param thePluginName a plugin name //! \return boolean result Standard_EXPORT bool FindFileNames (const TCollection_AsciiString& thePluginName); //! Returns file names set for the given plugin //! \param thePluginName a plugin name //! \return container of names Standard_EXPORT const NCollection_List& FileNames (const TCollection_AsciiString& thePluginName); //! Returns true if there are file names set for the given plugin //! \param thePluginName a plugin name //! \return boolean result Standard_EXPORT bool FindSelectedNames (const TCollection_AsciiString& thePluginName); //! Returns name to be selected in the plugin //! \param thePluginName a plugin name //! \return container of names Standard_EXPORT const NCollection_List& GetSelectedNames ( const TCollection_AsciiString& thePluginName); //! Returns objects set for the given plugin //! \param thePluginName a plugin name //! \return container of objects Standard_EXPORT Standard_Boolean GetSelectedObjects (const TCollection_AsciiString& thePluginName, NCollection_List& theObjects); //! Sets path to a directory for temporary plugin files //! \param thePath a path virtual void SetTemporaryDirectory (const TCollection_AsciiString& thePath) { myTemporaryDirectory = thePath; } //! Returns path to a directory for temporary plugin files //! \return path TCollection_AsciiString GetTemporaryDirectory() const { return myTemporaryDirectory; } //! Returns plugin preferences //! \param thePluginName a plugin name Standard_EXPORT virtual void GetPreferences (const TCollection_AsciiString& thePluginName, TInspectorAPI_PreferencesDataMap& theItem) = 0; //! Stores plugin preferences //! \param thePluginName a plugin name //! \theItem container of plugin preferences values in form: Standard_EXPORT virtual void SetPreferences (const TCollection_AsciiString& thePluginName, const TInspectorAPI_PreferencesDataMap& theItem) = 0; //! Stores plugin preferences into a preferences file Standard_EXPORT virtual void StorePreferences() = 0; //! Converts a Shape parameters excepting TShape into a string value //! \param theShape processed shape //! \return string instance Standard_EXPORT static TCollection_AsciiString ParametersToString (const TopoDS_Shape& theShape); //! Converts a Shape parameters exceptin TShape into a string value //! \param theValue parameters string value (without TShape information) //! \param theShape processed shape Standard_EXPORT static void ParametersToShape (const TCollection_AsciiString& theValue, TopoDS_Shape& theShape); DEFINE_STANDARD_RTTIEXT (TInspectorAPI_PluginParameters, Standard_Transient) private: //! container of parameters NCollection_DataMap > myParameters; //! container of names NCollection_DataMap > myFileNames; //! container of select item names NCollection_DataMap > mySelectedItemNames; //! container of select objects NCollection_DataMap > mySelectedObjects; //! temporary directory for saving plugin preferences TCollection_AsciiString myTemporaryDirectory; }; #endif