1 // ANNA - Anna is Not Nothingness Anymore //
3 // (c) Copyright 2005-2015 Eduardo Ramos Testillano & Francisco Ruiz Rayo //
5 // See project site at http://redmine.teslayout.com/projects/anna-suite //
6 // See accompanying file LICENSE or copy at http://www.teslayout.com/projects/public/anna.LICENSE //
9 #ifndef anna_xml_Attribute_hpp
10 #define anna_xml_Attribute_hpp
12 #include <anna/core/Allocator.hpp>
13 #include <anna/xml/Data.hpp>
24 Cada nodo XML puede tener una serie indeterminada de atributos. Por ejemplo:
28 <INetAddress Address="204.152.65.15" Port="2000"/>
29 <INetAddress Address="204.152.65.47" Port="2002"/>
33 Cada uno de los nodos \em INetAddress tiene dos atributos (\em Address y \em Port).
35 class Attribute : public Data {
38 Devuelve el nombre de este atributo.
39 \return Nombre de este atributo.
41 const char* getName() const throw() { return a_name.c_str(); }
44 * Devuelve el namespace asociado a este atributo. Puede ser NULL.
45 * \return el namespace asociado a este atributo. Puede ser NULL.
47 const Namespace* getNamespace() const throw() { return a_namespace; }
50 * Devuelve el nombre del nodo.
51 * \return El nombre del nodo.
53 const std::string& getNameAsString() const throw() { return a_name; }
56 Devuelve una cadena con toda la informacion relevante de esta instancia.
57 \return Una cadena con toda la informacion relevante de esta instancia.
59 std::string asString() const throw();
63 const Namespace* a_namespace;
65 /* Para evitar que se pueda crear desde el exterior */
66 Attribute() : Data(), a_namespace(NULL) {;}
68 void setName(const char* name) throw() { a_name = name; }
69 void setNamespace(const Namespace* _namespace) throw() { a_namespace = _namespace; }
72 friend class Allocator<Attribute>;