Loading...
Searching...
No Matches
SpatialRestrictionVisitor.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/dataaccess/query/SpatialRestrictionVisitor.h
22
23 \brief A visitor that retrieves spatial restrictions from a Query hierarchy.
24*/
25
26#ifndef __TERRALIB_DATAACCESS_INTERNAL_SPATIALRESTRICTIONVISITOR_H
27#define __TERRALIB_DATAACCESS_INTERNAL_SPATIALRESTRICTIONVISITOR_H
28
29// TerraLib
30#include "../../geometry/Enums.h"
31#include "QueryVisitor.h"
32
33// Boost
34#include <boost/noncopyable.hpp>
35
36// STL
37#include <map>
38#include <string>
39#include <vector>
40
41namespace te
42{
43// Forward declaration
44 namespace gm
45 {
46 class Geometry;
47 }
48
49 namespace da
50 {
51 /*!
52 \struct SpatialRestriction
53
54 \brief A struct that represents a spatial restriction.
55 */
57 {
58 /*! \brief Default constructor. */
60
61 /*! \brief Destructor. */
63
64 std::size_t m_index; //!< Internal index of the spatial restriction.
65 te::gm::SpatialRelation m_type; //!< The spatial restriction type.
66 te::gm::Geometry* m_geometry; //!< The geometry of the spatial restriction.
67 std::string m_pname; //!< The property name of the spatial restriction.
68 bool m_isFromEnvelope; //!< A flag that indicates if the spatial restriction uses an envelope.
69 const Function* m_function; //!< The function that represents the spatial restriction.
70 };
71
72 /*!
73 \class SpatialRestrictionVisitor
74
75 \brief A visitor for retrieves spatial restrictions from a Query hierarchy.
76 */
77 class TEDATAACCESSEXPORT SpatialRestrictionVisitor : public QueryVisitor, public boost::noncopyable
78 {
79 public:
80
81 /*! \brief Default constructor. */
83
84 /*! \brief Virtual destructor. */
86
87 virtual void visit(const Expression& visited) {}
88 virtual void visit(const DataSetName& visited) {}
89 virtual void visit(const FromItem& visited) {}
90 virtual void visit(const Function& visited);
91 virtual void visit(const Insert& visited) {}
92 virtual void visit(const Join& visited) {}
93 virtual void visit(const JoinCondition& visited) {}
94 virtual void visit(const JoinConditionOn& visited) {}
95 virtual void visit(const JoinConditionUsing& visited) {}
96 virtual void visit(const Like& visited) {}
97 virtual void visit(const Literal& visited) {}
98 virtual void visit(const LiteralBool& visited) {}
99 virtual void visit(const LiteralByteArray& visited) {}
100 virtual void visit(const LiteralDateTime& visited) {}
101 virtual void visit(const LiteralDouble& visited) {}
102 virtual void visit(const LiteralEnvelope& visited) {}
103 virtual void visit(const LiteralGeom& visited) {}
104 virtual void visit(const LiteralInt16& visited) {}
105 virtual void visit(const LiteralInt32& visited) {}
106 virtual void visit(const LiteralInt64& visited) {}
107 virtual void visit(const LiteralString& visited) {}
108 virtual void visit(const PropertyName& visited) {}
109 virtual void visit(const Query& visited) {}
110 virtual void visit(const Select& visited);
111 virtual void visit(const SelectExpression& visited) {}
112 virtual void visit(const SubSelect& visited) {}
113 virtual void visit(const In& visited) {}
114 virtual void visit(const Cast& visited) {}
115
117
118 const std::vector<te::da::SpatialRestriction*>& getSpatialRestrictions() const;
119
120 protected:
121
122 virtual void initialize();
123
125
127
128 bool isFromEnvelope(const Function& f) const;
129
131
132 std::string getPropertyName(const Function& f) const;
133
135
136 protected:
137
138 std::map<std::string, te::gm::SpatialRelation> m_spatialFunctions; //!< A map of spatial restriction functions.
139 std::size_t m_index; //!< An internal visitor index.
140 std::vector<te::da::SpatialRestriction*> m_spatialRestrictions; //!< The set of spatial restrictions.
141 };
142
143 } // end namespace da
144} // end namespace te
145
146#endif // __TERRALIB_DATAACCESS_INTERNAL_SPATIALRESTRICTIONVISITOR_H
A visitor interface for the Query hierarchy.
Cast a expression function.
Definition: Cast.h:47
A class that models the name of a dataset used in a From clause.
Definition: DataSetName.h:44
This is an abstract class that models a query expression.
Definition: Expression.h:48
An abstract class that models a source of data in a query.
Definition: FromItem.h:51
A class that models a Function expression.
Definition: Function.h:48
A class that represents the IN operator.
Definition: In.h:53
The Insert object can add the return of a select object.
Definition: Insert.h:51
JoinConditionOn is a boolean expression and it specifies which items in a join are considered to matc...
JoinConditionUsing class can be used to model a USING clause in a Join.
A condition to be used in a Join clause.
Definition: JoinCondition.h:45
A Join clause combines two FromItems.
Definition: Join.h:51
It is intended to encode a character string comparison operator with pattern matching.
Definition: Like.h:44
This class models a bool Literal value.
Definition: LiteralBool.h:44
A class that models a literal for ByteArray values.
A class that models a literal for Date and Time values.
A class that models a literal for double values.
Definition: LiteralDouble.h:44
A class that models a literal for Envelope values.
A class that models a literal for Geometry values.
Definition: LiteralGeom.h:47
This class models a string Literal value.
Definition: LiteralString.h:47
This class models a literal value.
Definition: Literal.h:54
A class that models the name of any property of an object.
Definition: PropertyName.h:51
A visitor interface for the Query hierarchy.
Definition: QueryVisitor.h:48
A Query is independent from the data source language/dialect.
Definition: Query.h:47
A Select can be used as a source of information in another query.
A Select models a query to be used when retrieving data from a DataSource.
Definition: Select.h:67
A visitor for retrieves spatial restrictions from a Query hierarchy.
std::size_t m_index
An internal visitor index.
te::gm::SpatialRelation getSpatialRelation(const Function &f) const
virtual void visit(const JoinConditionOn &visited)
virtual void visit(const Join &visited)
virtual void visit(const Expression &visited)
virtual void visit(const LiteralEnvelope &visited)
virtual void visit(const LiteralByteArray &visited)
virtual void visit(const Literal &visited)
virtual void visit(const Like &visited)
virtual void visit(const Cast &visited)
virtual void visit(const LiteralBool &visited)
virtual void visit(const Select &visited)
virtual void visit(const LiteralDateTime &visited)
virtual void visit(const LiteralInt16 &visited)
std::map< std::string, te::gm::SpatialRelation > m_spatialFunctions
A map of spatial restriction functions.
virtual void visit(const LiteralString &visited)
virtual void visit(const Query &visited)
virtual void visit(const Insert &visited)
std::string getPropertyName(const Function &f) const
virtual void visit(const LiteralDouble &visited)
SpatialRestrictionVisitor()
Default constructor.
virtual void visit(const Function &visited)
virtual void visit(const DataSetName &visited)
virtual void visit(const FromItem &visited)
virtual ~SpatialRestrictionVisitor()
Virtual destructor.
virtual void visit(const PropertyName &visited)
virtual void visit(const JoinConditionUsing &visited)
const std::vector< te::da::SpatialRestriction * > & getSpatialRestrictions() const
virtual void visit(const JoinCondition &visited)
std::vector< te::da::SpatialRestriction * > m_spatialRestrictions
The set of spatial restrictions.
virtual void visit(const In &visited)
virtual void visit(const LiteralGeom &visited)
virtual void visit(const LiteralInt32 &visited)
virtual void visit(const SelectExpression &visited)
void addSpatialRestriction(const Function &f)
bool isSpatialRestrictionFunction(const Function &f) const
te::gm::Geometry * getGeometryRestriction(const Function &f) const
virtual void visit(const LiteralInt64 &visited)
virtual void visit(const SubSelect &visited)
bool isFromEnvelope(const Function &f) const
A Select can be used as a source of information in another query.
Definition: SubSelect.h:50
Geometry is the root class of the geometries hierarchy, it follows OGC and ISO standards.
Definition: Geometry.h:78
SpatialRelation
Spatial relations between geometric objects.
Definition: Enums.h:128
TerraLib.
A struct that represents a spatial restriction.
const Function * m_function
The function that represents the spatial restriction.
bool m_isFromEnvelope
A flag that indicates if the spatial restriction uses an envelope.
te::gm::SpatialRelation m_type
The spatial restriction type.
std::size_t m_index
Internal index of the spatial restriction.
SpatialRestriction()
Default constructor.
std::string m_pname
The property name of the spatial restriction.
te::gm::Geometry * m_geometry
The geometry of the spatial restriction.
~SpatialRestriction()
Destructor.
#define TEDATAACCESSEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:97