Loading...
Searching...
No Matches
ST_IsValid.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/ST_IsValid.h
22
23 \brief Spatial is valid operator.
24*/
25
26#ifndef __TERRALIB_DATAACCESS_INTERNAL_ST_ISVALID_H
27#define __TERRALIB_DATAACCESS_INTERNAL_ST_ISVALID_H
28
29// TerraLib
30#include "Function.h"
31#include "FunctionNames.h"
32
33namespace te
34{
35
36 // Forward declarations
37 namespace gm { class Geometry; }
38
39 namespace da
40 {
41 /*!
42 \class ST_IsValid
43
44 \brief Spatial is valid operator.
45
46 This function is just a syntatic-suggar.
47
48 \sa Function
49 */
51 {
52 public:
53
55
56 /*!
57 \brief Constructor.
58
59 \param g The geometry literal.
60 */
62
63 /*!
64 \brief Constructor.
65
66 \param prop The geometry property name.
67 */
69
70 /*!
71 \brief Constructor.
72
73 \param g The geometry literal.
74 \param p Precision.
75 */
76 ST_IsValid(const te::gm::Geometry& g, const bool& p);
77
78 /*!
79 \brief Constructor.
80
81 \param prop The geometry property name.
82 \param p Precision.
83 */
84 ST_IsValid(const te::da::PropertyName& prop, const bool& p);
85
86 /*!
87 \brief Constructor.
88
89 \param e The expression.
90 \param p Precision.
91 */
93
94 /*!
95 \brief Constructor.
96
97 \param e The expression.
98 \param p Precision.
99 */
100 ST_IsValid(const Expression& e, const bool& p);
101
102 /*! \brief Destructor. */
104
105 /*! Assignment operator. */
107
108 /*! \brief It creates a new copy of this expression. */
110 };
111
112 } // end namespace da
113} // end namespace te
114
115#endif // __TERRALIB_DATAACCESS_INTERNAL_ST_ISVALID_H
116
#define TE_DEFINE_VISITABLE
Definition: BaseVisitable.h:75
A static class with global function name definitions.
This is an abstract class that models a query expression.
Definition: Expression.h:48
A class that models a Function expression.
Definition: Function.h:48
A class that models the name of any property of an object.
Definition: PropertyName.h:51
Spatial is valid operator.
Definition: ST_IsValid.h:51
ST_IsValid(const te::da::PropertyName &prop, const bool &p)
Constructor.
TE_DEFINE_VISITABLE ST_IsValid(const te::gm::Geometry &g)
Constructor.
ST_IsValid & operator=(const ST_IsValid &rhs)
Expression * clone() const
It creates a new copy of this expression.
~ST_IsValid()
Destructor.
ST_IsValid(const Expression &e, const bool &p)
Constructor.
ST_IsValid(const Expression &e)
Constructor.
ST_IsValid(const te::da::PropertyName &prop)
Constructor.
ST_IsValid(const te::gm::Geometry &g, const bool &p)
Constructor.
Geometry is the root class of the geometries hierarchy, it follows OGC and ISO standards.
Definition: Geometry.h:78
TerraLib.
Symbology Encoding functions.
#define TEDATAACCESSEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:97