DOM_Element.hpp
上传用户:huihehuasu
上传日期:2007-01-10
资源大小:6948k
文件大小:19k
源码类别:

xml/soap/webservice

开发平台:

C/C++

  1. /*
  2.  * The Apache Software License, Version 1.1
  3.  *
  4.  * Copyright (c) 1999-2001 The Apache Software Foundation.  All rights
  5.  * reserved.
  6.  *
  7.  * Redistribution and use in source and binary forms, with or without
  8.  * modification, are permitted provided that the following conditions
  9.  * are met:
  10.  *
  11.  * 1. Redistributions of source code must retain the above copyright
  12.  *    notice, this list of conditions and the following disclaimer.
  13.  *
  14.  * 2. Redistributions in binary form must reproduce the above copyright
  15.  *    notice, this list of conditions and the following disclaimer in
  16.  *    the documentation and/or other materials provided with the
  17.  *    distribution.
  18.  *
  19.  * 3. The end-user documentation included with the redistribution,
  20.  *    if any, must include the following acknowledgment:
  21.  *       "This product includes software developed by the
  22.  *        Apache Software Foundation (http://www.apache.org/)."
  23.  *    Alternately, this acknowledgment may appear in the software itself,
  24.  *    if and wherever such third-party acknowledgments normally appear.
  25.  *
  26.  * 4. The names "Xerces" and "Apache Software Foundation" must
  27.  *    not be used to endorse or promote products derived from this
  28.  *    software without prior written permission. For written
  29.  *    permission, please contact apache@apache.org.
  30.  *
  31.  * 5. Products derived from this software may not be called "Apache",
  32.  *    nor may "Apache" appear in their name, without prior written
  33.  *    permission of the Apache Software Foundation.
  34.  *
  35.  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
  36.  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  37.  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  38.  * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
  39.  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  40.  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  41.  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
  42.  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  43.  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  44.  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  45.  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  46.  * SUCH DAMAGE.
  47.  * ====================================================================
  48.  *
  49.  * This software consists of voluntary contributions made by many
  50.  * individuals on behalf of the Apache Software Foundation, and was
  51.  * originally based on software copyright (c) 1999, International
  52.  * Business Machines, Inc., http://www.ibm.com .  For more information
  53.  * on the Apache Software Foundation, please see
  54.  * <http://www.apache.org/>.
  55.  */
  56. /*
  57.  * $Log: DOM_Element.hpp,v $
  58.  * Revision 1.9  2001/05/11 13:25:20  tng
  59.  * Copyright update.
  60.  *
  61.  * Revision 1.8  2001/05/03 19:17:26  knoaman
  62.  * TraverseSchema Part II.
  63.  *
  64.  * Revision 1.7  2000/03/02 19:53:55  roddey
  65.  * This checkin includes many changes done while waiting for the
  66.  * 1.1.0 code to be finished. I can't list them all here, but a list is
  67.  * available elsewhere.
  68.  *
  69.  * Revision 1.6  2000/02/24 20:11:27  abagchi
  70.  * Swat for removing Log from API docs
  71.  *
  72.  * Revision 1.5  2000/02/17 17:47:24  andyh
  73.  * Update Doc++ API comments
  74.  * NameSpace update to track W3C
  75.  * Changes were made by Chih Hsiang Chou
  76.  *
  77.  * Revision 1.4  2000/02/06 07:47:29  rahulj
  78.  * Year 2K copyright swat.
  79.  *
  80.  * Revision 1.3  2000/01/05 01:16:07  andyh
  81.  * DOM Level 2 core, namespace support added.
  82.  *
  83.  * Revision 1.2  1999/12/21 07:47:06  robweir
  84.  * Patches to support Xalan, where we need to create a
  85.  * "special" DOM with subclassed Nodes.
  86.  *
  87.  * 1. Export the NodeImpl-derived classes
  88.  * 2. Ensure that their constructors have at least protected access
  89.  *
  90.  * Revision 1.1.1.1  1999/11/09 01:08:57  twl
  91.  * Initial checkin
  92.  *
  93.  * Revision 1.3  1999/11/08 20:44:17  rahul
  94.  * Swat for adding in Product name and CVS comment log variable.
  95.  *
  96.  */
  97. #ifndef DOM_Element_HEADER_GUARD_
  98. #define DOM_Element_HEADER_GUARD_
  99. #include <util/XercesDefs.hpp>
  100. #include <dom/DOM_Node.hpp>
  101. class DOM_Attr;
  102. class DOM_NodeList;
  103. class ElementImpl;
  104. /**
  105.  * By far the vast majority of objects (apart from text) that authors
  106.  * encounter when traversing a document are <code>DOM_Element</code> nodes.
  107.  *
  108.  * Assume the following XML document:&lt;elementExample id="demo"&gt;
  109.  * &lt;subelement1/&gt;
  110.  * &lt;subelement2&gt;&lt;subsubelement/&gt;&lt;/subelement2&gt;
  111.  * &lt;/elementExample&gt;
  112.  * <p>When represented using DOM, the top node is an <code>DOM_Element</code> node
  113.  * for "elementExample", which contains two child <code>DOM_Element</code> nodes,
  114.  * one for "subelement1" and one for "subelement2". "subelement1" contains no
  115.  * child nodes.
  116.  * <p>Elements may have attributes associated with them; since the
  117.  * <code>DOM_Element</code> interface inherits from <code>DOM_Node</code>, the generic
  118.  *  <code>DOM_Node</code> interface method <code>getAttributes</code> may be used
  119.  * to retrieve the set of all attributes for an element.  There are methods on
  120.  *  the <code>DOM_Element</code> interface to retrieve either an <code>DOM_Attr</code>
  121.  *  object by name or an attribute value by name. In XML, where an attribute
  122.  * value may contain entity references, an <code>DOM_Attr</code> object should be
  123.  * retrieved to examine the possibly fairly complex sub-tree representing the
  124.  * attribute value. On the other hand, in HTML, where all attributes have
  125.  * simple string values, methods to directly access an attribute value can
  126.  * safely be used as a convenience.
  127.  */
  128. class CDOM_EXPORT DOM_Element: public DOM_Node {
  129. private:
  130. public:
  131.     /** @name Constructors and assignment operator */
  132.     //@{
  133.     /**
  134.     * Default constructor for DOM_Element.  The resulting object does not
  135.     * refer to an actual Element node; it will compare == to 0, and is similar
  136.     * to a null object reference variable in Java.  It may subsequently be
  137.     * assigned to refer to an actual Element node.
  138.     * <p>
  139.     * New comment nodes are created by DOM_Document::createElement().
  140.       *
  141.       */
  142.     DOM_Element();
  143.     /**
  144.       * Copy constructor.  Creates a new <code>DOM_Element</code> that refers to the
  145.       * same underlying actual element as the original.
  146.       *
  147.       * @param other The object to be copied
  148.       */
  149.     DOM_Element(const DOM_Element &other);
  150.     /**
  151.       * Assignment operator.
  152.       *
  153.       * @param other The object to be copied.
  154.       */
  155.     DOM_Element & operator = (const DOM_Element &other);
  156.     /**
  157.       * Assignment operator.  This overloaded variant is provided for
  158.       *   the sole purpose of setting a DOM_Node reference variable to
  159.       *   zero.  Nulling out a reference variable in this way will decrement
  160.       *   the reference count on the underlying Node object that the variable
  161.       *   formerly referenced.  This effect is normally obtained when reference
  162.       *   variable goes out of scope, but zeroing them can be useful for
  163.       *   global instances, or for local instances that will remain in scope
  164.       *   for an extended time,  when the storage belonging to the underlying
  165.       *   node needs to be reclaimed.
  166.       *
  167.       * @param val.  Only a value of 0, or null, is allowed.
  168.       */
  169.     DOM_Element & operator = (const DOM_NullPtr *val);
  170.     //@}
  171.     /** @name Destructor. */
  172.     //@{
  173.  /**
  174.       * Destructor.  The object being destroyed is the reference
  175.       * object, not the underlying Element itself.
  176.   *
  177.   */
  178.     ~DOM_Element();
  179.     //@}
  180.     /** @name Getter functions. */
  181.     //@{
  182.   /**
  183.    * The name of the element.
  184.    *
  185.    * For example, in: &lt;elementExample
  186.    * id="demo"&gt;  ... &lt;/elementExample&gt; , <code>tagName</code> has
  187.    * the value <code>"elementExample"</code>. Note that this is
  188.    * case-preserving in XML, as are all of the operations of the DOM.
  189.    */
  190.   DOMString         getTagName() const;
  191.   /**
  192.    * Retrieves an attribute value by name.
  193.    *
  194.    * @param name The name of the attribute to retrieve.
  195.    * @return The <code>DOM_Attr</code> value as a string, or the empty  string if
  196.    *   that attribute does not have a specified or default value.
  197.    */
  198.   DOMString         getAttribute(const DOMString &name) const;
  199.   /**
  200.    * Retrieves an <code>DOM_Attr</code> node by name.
  201.    *
  202.    * @param name The name (<CODE>nodeName</CODE>) of the attribute to retrieve.
  203.    * @return The <code>DOM_Attr</code> node with the specified name (<CODE>nodeName</CODE>) or
  204.    *   <code>null</code> if there is no such attribute.
  205.    */
  206.   DOM_Attr        getAttributeNode(const DOMString &name) const;
  207.   /**
  208.    * Returns a <code>NodeList</code> of all descendant elements with a given
  209.    * tag name, in the order in which they would be encountered in a preorder
  210.    * traversal of the <code>DOM_Element</code> tree.
  211.    *
  212.    * @param name The name of the tag to match on. The special value "*"
  213.    *   matches all tags.
  214.    * @return A list of matching <code>DOM_Element</code> nodes.
  215.    */
  216.   DOM_NodeList    getElementsByTagName(const DOMString &name) const;
  217.   //@}
  218.   /** @name Set functions. */
  219.   //@{
  220.   /**
  221.    * Adds a new attribute.
  222.    *
  223.    * If an attribute with that name is already present
  224.    * in the element, its value is changed to be that of the value parameter.
  225.    * This value is a simple string, it is not parsed as it is being set. So
  226.    * any markup (such as syntax to be recognized as an entity reference) is
  227.    * treated as literal text, and needs to be appropriately escaped by the
  228.    * implementation when it is written out. In order to assign an attribute
  229.    * value that contains entity references, the user must create an
  230.    * <code>DOM_Attr</code> node plus any <code>Text</code> and
  231.    * <code>EntityReference</code> nodes, build the appropriate subtree, and
  232.    * use <code>setAttributeNode</code> to assign it as the value of an
  233.    * attribute.
  234.    * @param name The name of the attribute to create or alter.
  235.    * @param value Value to set in string form.
  236.    * @exception DOMException
  237.    *   INVALID_CHARACTER_ERR: Raised if the specified name contains an
  238.    *   illegal character.
  239.    *   <br>NO_MODIFICATION_ALLOWED_ERR: Raised if this node is readonly.
  240.    */
  241.    void             setAttribute(const DOMString &name,
  242.                                  const DOMString &value);
  243.    /**
  244.     * Adds a new attribute.
  245.     *
  246.     * If an attribute with that name (<CODE>nodeName</CODE>) is already present
  247.     * in the element, it is replaced by the new one.
  248.     * @param newAttr The <code>DOM_Attr</code> node to add to the attribute list.
  249.     * @return If the <code>newAttr</code> attribute replaces an existing
  250.     *   attribute, the replaced
  251.     *   <code>DOM_Attr</code> node is returned, otherwise <code>null</code> is
  252.     *   returned.
  253.     * @exception DOMException
  254.     *   WRONG_DOCUMENT_ERR: Raised if <code>newAttr</code> was created from a
  255.     *   different document than the one that created the element.
  256.     *   <br>NO_MODIFICATION_ALLOWED_ERR: Raised if this node is readonly.
  257.     *   <br>INUSE_ATTRIBUTE_ERR: Raised if <code>newAttr</code> is already an
  258.     *   attribute of another <code>DOM_Element</code> object. The DOM user must
  259.     *   explicitly clone <code>DOM_Attr</code> nodes to re-use them in other
  260.     *   elements.
  261.     */
  262.    DOM_Attr        setAttributeNode(DOM_Attr newAttr);
  263.    //@}
  264.    /** @name Functions which modify the Element. */
  265.    //@{
  266.   /**
  267.    * Removes the specified attribute node.
  268.    * If the removed <CODE>DOM_Attr</CODE>
  269.    *   has a default value it is immediately replaced. The replacing attribute
  270.    *   has the same namespace URI and local name, as well as the original prefix,
  271.    *   when applicable.
  272.    *
  273.    * @param oldAttr The <code>DOM_Attr</code> node to remove from the attribute
  274.    *   list.
  275.    * @return The <code>DOM_Attr</code> node that was removed.
  276.    * @exception DOMException
  277.    *   NO_MODIFICATION_ALLOWED_ERR: Raised if this node is readonly.
  278.    *   <br>NOT_FOUND_ERR: Raised if <code>oldAttr</code> is not an attribute
  279.    *   of the element.
  280.    */
  281.   DOM_Attr        removeAttributeNode(DOM_Attr oldAttr);
  282.   /**
  283.    * Removes an attribute by name.
  284.    *
  285.    * If the removed attribute
  286.    *   is known to have a default value, an attribute immediately appears
  287.    *   containing the default value as well as the corresponding namespace URI,
  288.    *   local name, and prefix when applicable.<BR>To remove an attribute by local
  289.    *   name and namespace URI, use the <CODE>removeAttributeNS</CODE> method.
  290.    * @param name The name of the attribute to remove.
  291.    * @exception DOMException
  292.    *   NO_MODIFICATION_ALLOWED_ERR: Raised if this node is readonly.
  293.    */
  294.   void              removeAttribute(const DOMString &name);
  295.   //@}
  296.   /** @name Functions introduced in DOM Level 2. */
  297.   //@{
  298.   /**
  299.    * Retrieves an attribute value by local name and namespace URI.
  300.    *
  301.    * <p><b>"Experimental - subject to change"</b></p>
  302.    *
  303.    * @param namespaceURI The <em>namespace URI</em> of
  304.    *    the attribute to retrieve.
  305.    * @param localName The <em>local name</em> of the
  306.    *    attribute to retrieve.
  307.    * @return The <code>DOM_Attr</code> value as a string, or an <CODE>null</CODE> if
  308.    *    that attribute does not have a specified or default value.
  309.    */
  310.   DOMString         getAttributeNS(const DOMString &namespaceURI,
  311. const DOMString &localName) const;
  312.   /**
  313.    * Adds a new attribute. If an attribute with the same
  314.    * local name and namespace URI is already present on the element, its prefix
  315.    * is changed to be the prefix part of the <CODE>qualifiedName</CODE>, and
  316.    * its value is changed to be the <CODE>value</CODE> parameter. This value is
  317.    * a simple string, it is not parsed as it is being set. So any markup (such
  318.    * as syntax to be recognized as an entity reference) is treated as literal
  319.    * text, and needs to be appropriately escaped by the implementation when it
  320.    * is written out. In order to assign an attribute value that contains entity
  321.    * references, the user must create an <CODE>DOM_Attr</CODE>
  322.    * node plus any <CODE>DOM_Text</CODE> and <CODE>DOM_EntityReference</CODE>
  323.    * nodes, build the appropriate subtree, and use
  324.    * <CODE>setAttributeNodeNS</CODE> or <CODE>setAttributeNode</CODE> to assign
  325.    * it as the value of an attribute.
  326.    *
  327.    * <p><b>"Experimental - subject to change"</b></p>
  328.    *
  329.    * @param namespaceURI The <em>namespace URI</em> of
  330.    *    the attribute to create or alter.
  331.    * @param qualifiedName The <em>qualified name</em> of the
  332.    *    attribute to create or alter.
  333.    * @param value The value to set in string form.
  334.    * @exception DOMException
  335.    *   INVALID_CHARACTER_ERR: Raised if the specified qualified name contains an
  336.    *   illegal character.
  337.    *   <br>NO_MODIFICATION_ALLOWED_ERR: Raised if this node is readonly.
  338.    * <br>
  339.    *   NAMESPACE_ERR: Raised if the <CODE>qualifiedName</CODE> is
  340.    *        malformed, if the <CODE>qualifiedName</CODE> has a prefix and the
  341.    *        <CODE>namespaceURI</CODE> is <CODE>null</CODE> or an empty string,
  342.    *        if the <CODE>qualifiedName</CODE> has a prefix that is "xml" and the
  343.    *        <CODE>namespaceURI</CODE> is different from
  344.    *        "http://www.w3.org/XML/1998/namespace", if the
  345.    *        <CODE>qualifiedName</CODE> has a prefix that is "xmlns" and the
  346.    *        <CODE>namespaceURI</CODE> is different from
  347.    *        "http://www.w3.org/2000/xmlns/", or if the
  348.    *        <CODE>qualifiedName</CODE> is "xmlns" and the
  349.    *        <CODE>namespaceURI</CODE> is different from
  350.    *        "http://www.w3.org/2000/xmlns/".
  351.    */
  352.    void             setAttributeNS(const DOMString &namespaceURI,
  353. const DOMString &qualifiedName, const DOMString &value);
  354.   /**
  355.    * Removes an attribute by local name and namespace URI. If the
  356.    * removed attribute has a default value it is immediately replaced.
  357.    * The replacing attribute has the same namespace URI and local name, as well as
  358.    * the original prefix.
  359.    *
  360.    * <p><b>"Experimental - subject to change"</b></p>
  361.    *
  362.    * @param namespaceURI The <em>namespace URI</em> of
  363.    *    the attribute to remove.
  364.    * @param localName The <em>local name</em> of the
  365.    *    attribute to remove.
  366.    * @exception DOMException
  367.    *   NO_MODIFICATION_ALLOWED_ERR: Raised if this node is readonly.
  368.    */
  369.   void              removeAttributeNS(const DOMString &namespaceURI,
  370. const DOMString &localName);
  371.   /**
  372.    * Retrieves an <code>DOM_Attr</code> node by local name and namespace URI.
  373.    *
  374.    * <p><b>"Experimental - subject to change"</b></p>
  375.    *
  376.    * @param namespaceURI The <em>namespace URI</em> of
  377.    *    the attribute to retrieve.
  378.    * @param localName The <em>local name</em> of the
  379.    *    attribute to retrieve.
  380.    * @return The <code>DOM_Attr</code> node with the specified attribute local
  381.    *    name and namespace URI or <code>null</code> if there is no such attribute.
  382.    */
  383.   DOM_Attr        getAttributeNodeNS(const DOMString &namespaceURI,
  384. const DOMString &localName) const;
  385.    /**
  386.     * Adds a new attribute.
  387.     *
  388.     * If an attribute with that local name and namespace URI is already present
  389.     * in the element, it is replaced by the new one.
  390.     *
  391.     * <p><b>"Experimental - subject to change"</b></p>
  392.     *
  393.     * @param newAttr The <code>DOM_Attr</code> node to add to the attribute list.
  394.     * @return If the <code>newAttr</code> attribute replaces an existing
  395.     *    attribute with the same <em>local name</em> and <em>namespace URI</em>,
  396.     *    the replaced <code>DOM_Attr</code> node is
  397.     *    returned, otherwise <code>null</code> is returned.
  398.     * @exception DOMException
  399.     *   WRONG_DOCUMENT_ERR: Raised if <code>newAttr</code> was created from a
  400.     *   different document than the one that created the element.
  401.     *   <br>NO_MODIFICATION_ALLOWED_ERR: Raised if this node is readonly.
  402.     *   <br>INUSE_ATTRIBUTE_ERR: Raised if <code>newAttr</code> is already an
  403.     *   attribute of another <code>DOM_Element</code> object. The DOM user must
  404.     *   explicitly clone <code>DOM_Attr</code> nodes to re-use them in other
  405.     *   elements.
  406.     */
  407.    DOM_Attr        setAttributeNodeNS(DOM_Attr newAttr);
  408.   /**
  409.    * Returns a <code>DOM_NodeList</code> of all the <code>DOM_Element</code>s
  410.    * with a given local name and namespace URI in the order in which they
  411.    * would be encountered in a preorder traversal of the
  412.    * <code>DOM_Document</code> tree, starting from this node.
  413.    *
  414.    * <p><b>"Experimental - subject to change"</b></p>
  415.    *
  416.    * @param namespaceURI The <em>namespace URI</em> of
  417.    *    the elements to match on. The special value "*" matches all
  418.    *    namespaces.
  419.    * @param localName The <em>local name</em> of the
  420.    *    elements to match on. The special value "*" matches all local names.
  421.    * @return A new <code>DOM_NodeList</code> object containing all the matched
  422.    *    <code>DOM_Element</code>s.
  423.    */
  424.   DOM_NodeList    getElementsByTagNameNS(const DOMString &namespaceURI,
  425. const DOMString &localName) const;
  426.   //@}
  427.   protected:
  428.      DOM_Element(ElementImpl *impl);
  429.      friend class DOM_Document;
  430.      friend class DOM_Attr;
  431.      friend class TraverseSchema;
  432. };
  433. #endif