All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
SQLDialect.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/dataaccess/query/SQLDialect.cpp
22 
23  \brief It represents the SQL query dialect accepted by a given data source.
24 */
25 
26 // TerraLib
27 #include "../../common/STLUtils.h"
28 #include "../../common/Translator.h"
29 #include "../Exception.h"
30 #include "SQLDialect.h"
31 #include "SQLFunctionEncoder.h"
32 
34 {
36 }
37 
38 void te::da::SQLDialect::insert(const std::string& funcName, SQLFunctionEncoder* encoder)
39 {
40  if(te::common::GetPValue(m_regFunctions, funcName) != 0)
41  throw Exception(TE_TR("There is already a function registered with the given name!"));
42 
43  m_regFunctions.insert(std::map<std::string, SQLFunctionEncoder*>::value_type(funcName, encoder));
44 }
45 
46 const te::da::SQLFunctionEncoder* te::da::SQLDialect::find(const std::string& funcName) const
47 {
48  return te::common::GetPValue(m_regFunctions, funcName);
49 }
50 
51 std::vector<std::string> te::da::SQLDialect::getRegisteredNames() const
52 {
53  std::vector<std::string> vec;
54 
55  std::map<std::string, te::da::SQLFunctionEncoder*>::const_iterator it= m_regFunctions.begin();
56 
57  while(it != m_regFunctions.end())
58  {
59  vec.push_back(it->first);
60 
61  ++it;
62  }
63 
64  return vec;
65 }
66 
A base class for encoders of SQL function expressions.
V * GetPValue(const std::map< K, V * > &m, const K &k)
It finds for a given key in the map and returns a pointer if something is found or NULL otherwise...
Definition: STLUtils.h:179
const SQLFunctionEncoder * find(const std::string &funcName) const
It searches for an encoder for the given function.
Definition: SQLDialect.cpp:46
It represents the SQL query dialect accepted by a given data source.
#define TE_TR(message)
It marks a string in order to get translated.
Definition: Translator.h:347
void insert(const std::string &funcName, SQLFunctionEncoder *encoder)
It adds a new encoder for a given function.
Definition: SQLDialect.cpp:38
std::map< std::string, SQLFunctionEncoder * > m_regFunctions
A map from the TerraLib general name to a given SQL formatter.
Definition: SQLDialect.h:96
~SQLDialect()
Destructor.
Definition: SQLDialect.cpp:33
std::vector< std::string > getRegisteredNames() const
It gets the all registered names from registed functions.
Definition: SQLDialect.cpp:51
void FreeContents(boost::unordered_map< K, V * > &m)
This function can be applied to a map of pointers. It will delete each pointer in the map...
Definition: BoostUtils.h:55
A base class for encoders of SQL function expressions.