DataSource.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/ado/DataSource.h
22 
23  \brief Implementation of the data source class for the ADO driver.
24 */
25 
26 #ifndef __TERRALIB_ADO_INTERNAL_DATASOURCE_H
27 #define __TERRALIB_ADO_INTERNAL_DATASOURCE_H
28 
29 // TerraLib
30 #include "../dataaccess/datasource/DataSource.h"
31 #include "../dataaccess/datasource/DataSourceCapabilities.h"
32 #include "Config.h"
33 
34 // BOOST
35 #include <boost/thread/locks.hpp>
36 #include <boost/thread/mutex.hpp>
37 
38 // ADO
39 #import "msado15.dll" \
40  no_namespace rename("EOF", "EndOfFile")
41 #import "msadox.dll"
42 
43 
44 namespace te
45 {
46  namespace gm { class GeometryProperty; }
47 
48  namespace ado
49  {
50  // Forward declaration
51  class ConnectionPool;
52  struct VersionInfo;
53 
54  /*!
55  \class DataSource
56 
57  \brief The ADO driver.
58 
59  \sa te::da::DataSource, te::da::DataSourceFactory, te::da::DataSourceManager, DataSourceFactory
60  */
62  {
63  public:
64 
65  DataSource();
66 
67  ~DataSource();
68 
69  std::string getType() const;
70 
71  const std::map<std::string, std::string>& getConnectionInfo() const;
72 
73  void setConnectionInfo(const std::map<std::string, std::string>& connInfo);
74 
75  std::auto_ptr<te::da::DataSourceTransactor> getTransactor();
76 
77  void open();
78 
79  void close();
80 
81  bool isOpened() const;
82 
83  bool isValid() const;
84 
85  const te::da::DataSourceCapabilities& getCapabilities() const;
86 
87  const te::da::SQLDialect* getDialect() const;
88 
89  const std::map<std::string, std::string>& getGeomColumns() const;
90 
91  void registerGeometryColumn(const std::string& datasetName,
92  const std::string& geomColName);
93 
94  bool isGeometryColumn(const std::string& datasetName,
95  const std::string& colName) const;
96 
97  protected:
98 
99  void create(const std::map<std::string, std::string>& dsInfo);
100 
101  void drop(const std::map<std::string, std::string>& dsInfo);
102 
103  bool exists(const std::map<std::string, std::string>& dsInfo);
104 
105  std::vector<std::string> getDataSourceNames(const std::map<std::string, std::string>& dsInfo);
106 
107  std::vector<te::common::CharEncoding> getEncodings(const std::map<std::string, std::string>& dsInfo);
108 
109  void loadGeometryColumnsCache(_ConnectionPtr& adoConn);
110 
111  private:
112 
113  std::map<std::string, std::string> m_connInfo; //!< Connection information.
114  std::map<std::string, std::string> m_geomColumns; //!< The list of geometry columns.
115  std::string m_currentSchema; //!< The default schema used when no one is provided.
116  mutable boost::mutex m_mtx;
118 
119  static te::da::DataSourceCapabilities sm_capabilities; //!< ADO capabilities.
121  };
122 
123 
124  } // end namespace pgis
125 } // end namespace te
126 
127 #endif // __TERRALIB_ADO_INTERNAL_DATASOURCE_H
boost::mutex m_mtx
Definition: DataSource.h:116
Geometric property.
static te::da::DataSourceCapabilities sm_capabilities
ADO capabilities.
Definition: DataSource.h:119
std::string m_currentSchema
The default schema used when no one is provided.
Definition: DataSource.h:115
#define TEADOEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:130
It represents the SQL query dialect accepted by a given data source.
Definition: SQLDialect.h:55
Configuration flags for the TerraLib ADO Data Access driver.
std::map< std::string, std::string > m_geomColumns
The list of geometry columns.
Definition: DataSource.h:114
A class that represents the known capabilities of a specific data source, i.e. this class informs all...
static te::da::SQLDialect * sm_dialect
Definition: DataSource.h:120
An abstract class for data providers like a DBMS, Web Services or a regular file. ...
Definition: DataSource.h:118
URI C++ Library.
std::map< std::string, std::string > m_connInfo
Connection information.
Definition: DataSource.h:113
The ADO driver.
Definition: DataSource.h:61