Key.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 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 General Public License for more details.
14 
15  You should have received a copy of the GNU 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 Key.h
22 
23  \brief This class models a key element from an XML Schema.
24 */
25 
26 #ifndef __TERRALIB_XSD_INTERNAL_KEY_H
27 #define __TERRALIB_XSD_INTERNAL_KEY_H
28 
29 // TerraLib
30 #include "IdentityConstraint.h"
31 
32 namespace te
33 {
34  namespace xsd
35  {
36  /*!
37  \class Key
38 
39  \brief This class models a key element from an XML Schema.
40 
41  \note Parent elements: element.
42  */
44  {
45  public:
46 
47  /*!
48  \brief Constructor.
49 
50  \param id It specifies a unique ID for the element. It may be a NULL value.
51  \param name It specifies the name of the key element. It is required a non-NULL value.
52 
53  \note The Key object will take the ownership of the id and name pointers.
54  */
55  Key(std::string* name, Annotation* ann = 0, std::string* id = 0);
56 
57  /*!
58  \brief Copy constructor.
59 
60  \param rhs Right-hand-side object.
61 
62  \todo Implement!
63  */
64  Key(const Key& rhs);
65 
66  /*! \brief Destructor. */
67  ~Key();
68 
69  /*!
70  \brief Assignment operator.
71 
72  \param rhs Right-hand-side object.
73 
74  \return A reference to this object.
75 
76  \todo Implement!
77  */
78  Key& operator=(const Key& rhs);
79 
80  /*!
81  \brief It returns the key name.
82 
83  \return The key name.
84  */
85  std::string* getName() const;
86 
87  /*!
88  \brief It sets the key name.
89 
90  \param name The key name.
91 
92  \note The key will take the ownership of the given name.
93  */
94  void setName(std::string* name);
95 
96  IdentityConstraint* clone() const;
97  };
98 
99  } // end namespace xsd
100 } // end namespace te
101 
102 #endif // __TERRALIB_XSD_INTERNAL_KEY_H
This class models a key element from an XML Schema.
Definition: Key.h:43
URI C++ Library.
This is the base class for XML Schema elements that are related to identity constraint.
#define TEXSDEXPORT
You can use this macro in order to export/import classes and functions from this module.
Definition: Config.h:57
A class that models a XSD annotation element.
Definition: Annotation.h:55
This is the base class for XML Schema elements that are related to identity constraint.