All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
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 
33 #include <string>
34 
35 namespace te
36 {
37  namespace rp
38  {
39  /*!
40  \class Module
41 
42  \brief This singleton defines the TerraLib Raster Processing module entry.
43  */
44  class TERPEXPORT Module : public te::common::Singleton<Module>
45  {
47 
48  public :
49 
50  /*!
51  \brief Returns the last log string generated by this module.
52  */
53  static const std::string& getLastLogStr() { return m_lastLogString; };
54 
55  /*!
56  \brief Set the last log string generated by this module.
57  */
58  static void setLastLogStr( const std::string& errorStr ) { m_lastLogString = errorStr; };
59 
60  protected:
61 
62  /*! \brief The singleton constructor is not callable outside the class. */
63  Module();
64 
65  /* \brief Destructor. */
66  ~Module();
67 
68  private:
69 
70  /*!
71  \brief This is the startup function for the TerraLib Raster Processing module.
72 
73  \note This method doesn't perform operations for this module.
74  */
75  static void initialize();
76 
77  /*!
78  \brief This is the cleanup function for the TerraLib DataType module.
79 
80  \note This method doesn't perform operations for this module.
81  */
82  static void finalize();
83 
84  private:
85 
86  static const Module& sm_module; //!< Just to make a static initialization.
87 
88  static std::string m_lastLogString; //!< The last error string generated by this module.
89  };
90 
91  } // end namespace rp
92 } // end namespace te
93 
94 #endif // __TERRALIB_DATATYPE_INTERNAL_MODULE_H
95 
This singleton defines the TerraLib Raster Processing module entry.
Definition: Module.h:44
static const std::string & getLastLogStr()
Returns the last log string generated by this module.
Definition: Module.h:53
static const Module & sm_module
Just to make a static initialization.
Definition: Module.h:86
static std::string m_lastLogString
The last error string generated by this module.
Definition: Module.h:88
#define TERPEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:141
Configuration flags for the Raster Processing module of TerraLib.
static void setLastLogStr(const std::string &errorStr)
Set the last log string generated by this module.
Definition: Module.h:58
Template support for singleton pattern.
Definition: Singleton.h:100