Loading...
Searching...
No Matches
Literal.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/Literal.h
22
23 \brief This class models a literal value.
24*/
25
26#ifndef __TERRALIB_DATAACCESS_INTERNAL_LITERAL_H
27#define __TERRALIB_DATAACCESS_INTERNAL_LITERAL_H
28
29// TerraLib
30#include "Expression.h"
31
32// STL
33#include <memory>
34
35namespace te
36{
37// Forward declaration
38 namespace dt { class AbstractData; }
39
40 namespace da
41 {
42 /*!
43 \class Literal
44
45 \brief This class models a literal value.
46
47 \sa Expression, te::dt::AbstractData,
48 LiteralGeom, LiteralByteArray,
49 LiteralFloat, LiteralDouble,
50 LiteralInt32, LiteralInt64,
51 LiteralString, LiteralDateTime
52 */
54 {
55 public:
56
58
59 /*!
60 \brief Constructor.
61
62 \param value The value to be assigned to the literal. The literal takes its ownership.
63 */
65
66 /*!
67 \brief Constructor.
68
69 \param value The value to be assigned to the literal.
70 */
72
73 /*! \brief Copy constructor. */
74 Literal(const Literal& rhs);
75
76 /*! \brief Virtual destructor. */
77 virtual ~Literal();
78
79 /*! Assignment operator. */
81
82 /*! \brief It creates a new copy of this expression. */
83 Expression* clone() const;
84
85 /*! \brief It returns the value associated to the literal. */
87
88 /*!
89 \brief It sets the value associated to the literal.
90
91 \param v The value to be assigned to the literal. The literal takes its ownership.
92 */
94
95 protected:
96
97 std::unique_ptr<te::dt::AbstractData> m_value;
98 };
99
100 } // end namespace da
101} // end namespace te
102
103#endif // __TERRALIB_DATAACCESS_INTERNAL_LITERAL_H
104
#define TE_DEFINE_VISITABLE
Definition: BaseVisitable.h:75
This is an abstract class that models a query expression.
Definition: Expression.h:48
This class models a literal value.
Definition: Literal.h:54
void setValue(te::dt::AbstractData *v)
It sets the value associated to the literal.
TE_DEFINE_VISITABLE Literal(te::dt::AbstractData *value)
Constructor.
Literal(const te::dt::AbstractData &value)
Constructor.
std::unique_ptr< te::dt::AbstractData > m_value
Definition: Literal.h:97
Expression * clone() const
It creates a new copy of this expression.
virtual ~Literal()
Virtual destructor.
Literal & operator=(const Literal &rhs)
Literal(const Literal &rhs)
Copy constructor.
te::dt::AbstractData * getValue() const
It returns the value associated to the literal.
A base class for values that can be retrieved from the data access module.
Definition: AbstractData.h:56
Auxiliary classes and functions to serialize filter expressions from a XML document.
TerraLib.
#define TEDATAACCESSEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:97