1 /*
   2  * reserved comment block
   3  * DO NOT REMOVE OR ALTER!
   4  */
   5 /*
   6  * The Apache Software License, Version 1.1
   7  *
   8  *
   9  * Copyright (c) 2001, 2002 The Apache Software Foundation.  All rights
  10  * reserved.
  11  *
  12  * Redistribution and use in source and binary forms, with or without
  13  * modification, are permitted provided that the following conditions
  14  * are met:
  15  *
  16  * 1. Redistributions of source code must retain the above copyright
  17  *    notice, this list of conditions and the following disclaimer.
  18  *
  19  * 2. Redistributions in binary form must reproduce the above copyright
  20  *    notice, this list of conditions and the following disclaimer in
  21  *    the documentation and/or other materials provided with the
  22  *    distribution.
  23  *
  24  * 3. The end-user documentation included with the redistribution,
  25  *    if any, must include the following acknowledgment:
  26  *       "This product includes software developed by the
  27  *        Apache Software Foundation (http://www.apache.org/)."
  28  *    Alternately, this acknowledgment may appear in the software itself,
  29  *    if and wherever such third-party acknowledgments normally appear.
  30  *
  31  * 4. The names "Xerces" and "Apache Software Foundation" must
  32  *    not be used to endorse or promote products derived from this
  33  *    software without prior written permission. For written
  34  *    permission, please contact apache@apache.org.
  35  *
  36  * 5. Products derived from this software may not be called "Apache",
  37  *    nor may "Apache" appear in their name, without prior written
  38  *    permission of the Apache Software Foundation.
  39  *
  40  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
  41  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  42  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  43  * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
  44  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  45  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  46  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
  47  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  48  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  49  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  50  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  51  * SUCH DAMAGE.
  52  * ====================================================================
  53  *
  54  * This software consists of voluntary contributions made by many
  55  * individuals on behalf of the Apache Software Foundation and was
  56  * originally based on software copyright (c) 2001, International
  57  * Business Machines, Inc., http://www.apache.org.  For more
  58  * information on the Apache Software Foundation, please see
  59  * <http://www.apache.org/>.
  60  */
  61 
  62 package com.sun.org.apache.xerces.internal.impl.xs.opti;
  63 
  64 import org.w3c.dom.Attr;
  65 import org.w3c.dom.DOMException;
  66 import org.w3c.dom.Document;
  67 import org.w3c.dom.Element;
  68 import org.w3c.dom.Node;
  69 import org.w3c.dom.TypeInfo;
  70 
  71 /**
  72  * This class represents a single attribute.
  73  *
  74  * @author Rahul Srivastava, Sun Microsystems Inc.
  75  *
  76  * @version $Id: AttrImpl.java,v 1.5 2010-11-01 04:40:01 joehw Exp $
  77  */
  78 public class AttrImpl extends NodeImpl
  79                       implements Attr {
  80 
  81     Element element;
  82     String value;
  83 
  84     /** Default Constructor */
  85     public AttrImpl() {
  86         nodeType = Node.ATTRIBUTE_NODE;
  87     }
  88 
  89     /**
  90      * Constructs an attribute.
  91      *
  92      * @param element Element which owns this attribute
  93      * @param prefix The QName prefix.
  94      * @param localpart The QName localpart.
  95      * @param rawname The QName rawname.
  96      * @param uri The uri binding for the associated prefix.
  97      * @param value The value of the attribute.
  98      */
  99     public AttrImpl(Element element, String prefix, String localpart, String rawname, String uri, String value) {
 100         super(prefix, localpart, rawname, uri, Node.ATTRIBUTE_NODE);
 101         this.element = element;
 102         this.value = value;
 103     }
 104 
 105     public String getName() {
 106         return rawname;
 107     }
 108 
 109     public boolean getSpecified() {
 110         return true;
 111     }
 112 
 113     public String getValue() {
 114         return value;
 115     }
 116 
 117     public String getNodeValue() {
 118         return getValue();
 119     }
 120 
 121     public Element getOwnerElement() {
 122         return element;
 123     }
 124 
 125     public Document getOwnerDocument() {
 126         return element.getOwnerDocument();
 127     }
 128 
 129     public void setValue(String value) throws DOMException {
 130         this.value = value;
 131     }
 132 
 133     /**
 134      * @since DOM Level 3
 135      */
 136     public boolean isId(){
 137         return false;
 138     }
 139 
 140     /**
 141      * Method getSchemaTypeInfo.
 142      * @return TypeInfo
 143      */
 144     public TypeInfo getSchemaTypeInfo(){
 145       return null;
 146     }
 147 
 148     /** NON-DOM method for debugging convenience */
 149     public String toString() {
 150         return getName() + "=" + "\"" + getValue() + "\"";
 151     }
 152 }