X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FConfig%2FConfig_ModuleReader.h;h=bef9c61246a6c149cce31154c9c9dc5eb1d2d5a1;hb=04a8a265b25901dd54e34d449f8d0c64304f1e69;hp=911e5d813c8afa10b11f37a859812378cccb5202;hpb=8b78f08d1e6b2e6d57aa73b091579094e4a020d4;p=modules%2Fshaper.git diff --git a/src/Config/Config_ModuleReader.h b/src/Config/Config_ModuleReader.h index 911e5d813..bef9c6124 100644 --- a/src/Config/Config_ModuleReader.h +++ b/src/Config/Config_ModuleReader.h @@ -20,6 +20,7 @@ /*! * \class Config_ModuleReader + * \ingroup Config * \brief Class to process plugins.xml - definition of plugins (scripts, libraries). */ class Config_ModuleReader : public Config_XMLReader @@ -31,38 +32,50 @@ class Config_ModuleReader : public Config_XMLReader }; public: + /// Constructor CONFIG_EXPORT Config_ModuleReader(const char* theEventGenerated = 0); + /// Destructor CONFIG_EXPORT virtual ~Config_ModuleReader(); - + /// Returns map that describes which file contains a feature (the feature is key, the file is value) CONFIG_EXPORT const std::map& featuresInFiles() const; - + /// Returns list of module's xml files + CONFIG_EXPORT const std::set& modulePluginFiles() const; + /// Returns module name: an xml attribute from the root of the plugins.xml: + /// e.g \code \endcode CONFIG_EXPORT std::string getModuleName(); - + /// Detects type of the given plugin and loads it using loadLibrary or loadScript. CONFIG_EXPORT static void loadPlugin(const std::string& thePluginName); /// loads the library with specific name, appends "lib*.dll" or "*.so" depending on the platform CONFIG_EXPORT static void loadLibrary(const std::string& theLibName); /// loads the python module with specified name CONFIG_EXPORT static void loadScript(const std::string& theFileName); - // extends set of modules, which will be used for dependency - // checking (if there is no required module in the set, a plugin will not be loaded) + /*! + * Extends set of modules, used for dependency checking (if there is no + * required module in the set, a plugin will not be loaded) + */ CONFIG_EXPORT static void addDependencyModule(const std::string& theModuleName); protected: - void processNode(xmlNodePtr aNode); - bool processChildren(xmlNodePtr aNode); - + /// Recursively process the given xmlNode + virtual void processNode(xmlNodePtr aNode); + /// Defines if the reader should process children of the given node + virtual bool processChildren(xmlNodePtr aNode); + /// check if dependencies of the given node are in the list of loaded modules bool hasRequiredModules(xmlNodePtr aNode) const; + /// reads info about plugin's features from plugin xml description std::list importPlugin(const std::string& thePluginLibrary, const std::string& thePluginFile); + /// stores information about plugin in the internal cache std::string addPlugin(const std::string& aPluginLibrary, const std::string& aPluginScript, const std::string& aPluginConf); private: - std::map myFeaturesInFiles; - static std::map myPluginTypes; - static std::set myDependencyModules; - const char* myEventGenerated; + std::map myFeaturesInFiles; ///< a feature name is key, a file is value + std::set myPluginFiles; ///< a feature name is key, a file is value + static std::map myPluginTypes; ///< a plugin name is key, a plugin type is value + static std::set myDependencyModules; ///< set of loaded modules + const char* myEventGenerated; ///< gives ability to send Feature_Messages to various listeners }; #endif /* CONFIG_XMLMODULEREADER_H_ */