Module.h
Go to the documentation of this file.
1 /* Copyright (C) 2008 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/rp/Module.h
22 
23  \brief This singleton defines the TerraLib Raster Processing module entry.
24  */
25 
26 #ifndef __TERRALIB_RP_INTERNAL_MODULE_H
27 #define __TERRALIB_RP_INTERNAL_MODULE_H
28 
29 // TerraLib
30 #include "Config.h"
31 #include "../common/Singleton.h"
32 #include "../common/TerraLib.h"
33 
34 //STL
35 #include <memory>
36 #include <string>
37 
38 namespace te
39 {
40  namespace rp
41  {
42  /*!
43  \class Module
44 
45  \brief This singleton defines the TerraLib Raster Processing module entry.
46  */
47  class TERPEXPORT Module : public te::common::Singleton<Module>
48  {
50 
51  public :
52 
53  /*!
54  \brief Returns the last log string generated by this module.
55  */
56  static const std::string& getLastLogStr() { return m_lastLogString; };
57 
58  /*!
59  \brief Set the last log string generated by this module.
60  */
61  static void setLastLogStr( const std::string& errorStr ) { m_lastLogString = errorStr; };
62 
63  protected:
64 
65  /*! \brief The singleton constructor is not callable outside the class. */
66  Module();
67 
68  /* \brief Destructor. */
69  ~Module();
70 
71  private:
72 
73  /*!
74  \brief This is the startup function for the TerraLib Raster Processing module.
75 
76  \note This method doesn't perform operations for this module.
77  */
78  static void initialize();
79 
80  /*!
81  \brief This is the cleanup function for the TerraLib DataType module.
82 
83  \note This method doesn't perform operations for this module.
84  */
85  static void finalize();
86 
87  private:
88 
89  static const Module& sm_module; //!< Just to make a static initialization.
90 
91  static std::string m_lastLogString; //!< The last error string generated by this module.
92 
93  std::shared_ptr<TerraLib::Module> m_module;
94  };
95 
96  } // end namespace rp
97 } // end namespace te
98 
99 #endif // __TERRALIB_DATATYPE_INTERNAL_MODULE_H
100 
This singleton defines the TerraLib Raster Processing module entry.
Definition: Module.h:47
static const std::string & getLastLogStr()
Returns the last log string generated by this module.
Definition: Module.h:56
static const Module & sm_module
Just to make a static initialization.
Definition: Module.h:89
URI C++ Library.
static std::string m_lastLogString
The last error string generated by this module.
Definition: Module.h:91
#define TERPEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:139
Configuration flags for the Raster Processing module of TerraLib.
std::shared_ptr< TerraLib::Module > m_module
Definition: Module.h:93
static void setLastLogStr(const std::string &errorStr)
Set the last log string generated by this module.
Definition: Module.h:61
Template support for singleton pattern.
Definition: Singleton.h:100