All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
CppPluginEngine.h
Go to the documentation of this file.
1 /* Copyright (C) 2001-2009 National Institute For Space Research (INPE) - Brazil.
2 
3  This file is part of the TerraLib - a Framework for building GIS enabled applications.
4 
5  TerraLib is free software: you can redistribute it and/or modify
6  it under the terms of the GNU Lesser General Public License as published by
7  the Free Software Foundation, either version 3 of the License,
8  or (at your option) any later version.
9 
10  TerraLib is distributed in the hope that it will be useful,
11  but WITHOUT ANY WARRANTY; without even the implied warranty of
12  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13  GNU Lesser General Public License for more details.
14 
15  You should have received a copy of the GNU Lesser General Public License
16  along with TerraLib. See COPYING. If not, write to
17  TerraLib Team at <terralib-team@terralib.org>.
18  */
19 
20 /*!
21  \file terralib/plugin/CppPluginEngine.h
22 
23  \brief A plugin engine for plugins written in C++.
24  */
25 
26 #ifndef __TERRALIB_PLUGIN_INTERNAL_CPPPLUGINENGINE_H
27 #define __TERRALIB_PLUGIN_INTERNAL_CPPPLUGINENGINE_H
28 
29 // TerraLib
30 #include "AbstractPluginEngine.h"
31 #include "Config.h"
32 
33 // STL
34 #include <string>
35 #include <vector>
36 
37 namespace te
38 {
39  namespace plugin
40  {
41  /*!
42  \class CppPluginEngine
43 
44  \brief A plugin engine for plugins written in C++.
45 
46  \ingroup plugin
47 
48  \sa Plugin, PluginInfo, PluginEngineFactory, PluginEngine
49  */
51  {
52  public:
53 
54  /*! Default construtor. */
56 
57  /*! \brief Destructor. */
59 
60  AbstractPlugin* load(const PluginInfo& pInfo);
61 
62  void unload(AbstractPlugin* plugin);
63 
64  /*!
65  \brief This method will help to form the library name wich contains the plugin.
66 
67  This method may append a prefix and suffix that are platform dependent
68  and also the build mode: DEBUG or RELEASE.
69  */
70  static std::string getPluginFileName(const std::string& libName);
71 
72  /*!
73  \brief It returns the default plugins libraries search directories.
74 
75  This method will generate directory paths for the sub-directories ".", "lib", "win32", "win64" and the macro TE_DEFAULT_PLUGINS_DIR within:
76  <ul>
77  <li> The current execution directory.</li>
78  <li> The enviromental variable with a name defined by the macro TE_DIR_ENVIRONMENT_VARIABLE</li>
79  <li> The enviromental variable "TERRALIB_DIR"</li>
80  <li> The macro TE_PLUGINS_PATH.
81  <li> Directories listed by the environmental variable LD_LIBRARY_PATH.</li>
82  <li> Directories listed by the environmental variable PATH.</li>
83  </ul>
84 
85  \param dirs The default plugin libraries search directories (the absolute path) or an empty string if none is found.
86  */
87  static void getDefaultDirs( std::vector< std::string >& dirs );
88 
89  protected :
90 
91  std::vector< std::string > m_defaultSearchDirs; //!< The default plugin libraries search directories.
92  };
93 
94  } // end namespace plugin
95 } // end namespace te
96 
97 #endif // __TERRALIB_PLUGIN_INTERNAL_CPPPLUGINENGINE_H
98 
The basic information about a plugin.
Definition: PluginInfo.h:61
#define TEPLUGINEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:151
std::vector< std::string > m_defaultSearchDirs
The default plugin libraries search directories.
An abstract class for TerraLib Plugins.
Configuration flags for the TerraLib Plugin module.
An abstract class for plugin engines.
An abstract class for plugin engines.