All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
Module.cpp
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/sqlite/Module.cpp
22 
23  \brief The TerraLib SQLite Data Access driver implements the plugin interface.
24 */
25 
26 // TerraLib
27 #include "../dataaccess/datasource/DataSourceCapabilities.h"
28 #include "../dataaccess/datasource/DataSourceFactory.h"
29 #include "../dataaccess/datasource/DataSourceManager.h"
30 #include "../dataaccess/query/SQLDialect.h"
31 #include "../dataaccess/serialization/xml/Serializer.h"
32 #include "DataSource.h"
33 #include "DataSourceFactory.h"
34 #include "Module.h"
35 
36 // Boost
37 #include <boost/filesystem.hpp>
38 
39 // SQLite
40 #include <sqlite3.h>
41 
42 #ifdef TE_ENABLE_SPATIALITE
43 // SpatiaLite
44 #include <spatialite.h>
45 #endif
46 
47 
49  : te::plugin::Plugin(pluginInfo)
50 {
51 }
52 
54 {
55 }
56 
58 {
59  if(m_initialized)
60  return;
61 
62  sqlite3_config(SQLITE_CONFIG_SERIALIZED);
63 
64  sqlite3_initialize();
65 
66 #ifdef TE_ENABLE_SPATIALITE
67  spatialite_init(0);
68 #endif
69 
70  boost::filesystem::path driverpath(m_pluginInfo.m_folder);
71 
72  boost::filesystem::path capabilitiesFile = driverpath / "spatialite-capabilities.xml";
73 
74  std::auto_ptr<te::da::DataSourceCapabilities> capa(new te::da::DataSourceCapabilities());
75  std::auto_ptr<te::da::SQLDialect> dialect(new te::da::SQLDialect());
76 
77  te::serialize::xml::Read(capabilitiesFile.string(), *capa, *dialect);
78 
79  DataSource::set(capa.release());
80  DataSource::set(dialect.release());
81 
83 
84  m_initialized = true;
85 }
86 
88 {
89  if(!m_initialized)
90  return;
91 
92  te::da::DataSourceManager::getInstance().detachAll("SQLITE");
93 
95 
96  sqlite3_shutdown();
97 
98  m_initialized = false;
99 }
100 
102 
te::da::SQLDialect * dialect
Definition: WFSDialect.h:1
void startup()
Do nothing! Just set plugin as started.
Definition: Module.cpp:57
It represents the SQL query dialect accepted by a given data source.
Definition: SQLDialect.h:55
The TerraLib SQLite Data Access driver implements the plugin interface.
A class that represents the known capabilities of a specific data source, i.e. this class informs all...
TEDATAACCESSEXPORT void Read(const std::string &dialectFileName, te::da::DataSourceCapabilities &capabilities, te::da::SQLDialect &dialect)
Definition: Serializer.cpp:407
Module(const te::plugin::PluginInfo &pluginInfo)
Definition: Module.cpp:48
#define PLUGIN_CALL_BACK_IMPL(PLUGIN_CLASS_NAME)
This macro should be used by C++ plugins in order to declare the exportable/callable DLL function...
Definition: Config.h:57
static void set(te::da::DataSourceCapabilities *capabilities)
Definition: DataSource.cpp:205
static DataSourceManager & getInstance()
It returns a reference to the singleton instance.
A factory for data sources.
void shutdown()
Do nothing! Just set plugin as stopped.
Definition: Module.cpp:87
Implements the DataSource class for the SQLite Data Access Driver.
static void add(const std::string &dsType, FactoryFnctType f)
The basic information about a plugin.
Definition: PluginInfo.h:61
static void remove(const std::string &dsType)
te::da::DataSource * Build()