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 }