// 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 excepting 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