![JAR search and dependency download from the Maven repository](/logo.png)
org.apache.xerces.util.AttributesProxy Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of xercesImpl Show documentation
Show all versions of xercesImpl Show documentation
Xerces2 is the next generation of high performance, fully compliant XML parsers in the Apache Xerces family.
This new version of Xerces introduces the Xerces Native Interface (XNI), a complete framework for building
parser components and configurations that is extremely modular and easy to program. The Apache Xerces2 parser is
the reference implementation of XNI but other parser components, configurations, and parsers can be written
using the Xerces Native Interface. For complete design and implementation documents, refer to the XNI Manual.
Xerces2 is a fully conforming XML Schema 1.0 processor. A partial experimental implementation of the XML Schema
1.1 Structures and Datatypes Working Drafts (December 2009) and an experimental implementation of the XML Schema
Definition Language (XSD): Component Designators (SCD) Candidate Recommendation (January 2010) are provided for
evaluation. For more information, refer to the XML Schema page. Xerces2 also provides a complete implementation
of the Document Object Model Level 3 Core and Load/Save W3C Recommendations and provides a complete
implementation of the XML Inclusions (XInclude) W3C Recommendation. It also provides support for OASIS XML
Catalogs v1.1. Xerces2 is able to parse documents written according to the XML 1.1 Recommendation, except that
it does not yet provide an option to enable normalization checking as described in section 2.13 of this
specification. It also handles namespaces according to the XML Namespaces 1.1 Recommendation, and will correctly
serialize XML 1.1 documents if the DOM level 3 load/save APIs are in use.
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.xerces.util;
import org.apache.xerces.impl.Constants;
import org.apache.xerces.xni.XMLAttributes;
import org.xml.sax.AttributeList;
import org.xml.sax.ext.Attributes2;
/**
* Wraps {@link XMLAttributes} and makes it look like
* {@link AttributeList} and {@link Attributes2}.
*
* @author Arnaud Le Hors, IBM
* @author Andy Clark, IBM
*
* @version $Id: AttributesProxy.java 449487 2006-09-24 21:11:28Z mrglavas $
*/
public final class AttributesProxy
implements AttributeList, Attributes2 {
//
// Data
//
/** XML attributes. */
private XMLAttributes fAttributes;
//
// Constructors
//
public AttributesProxy(XMLAttributes attributes) {
fAttributes = attributes;
}
//
// Public methods
//
/** Sets the XML attributes to be wrapped. */
public void setAttributes(XMLAttributes attributes) {
fAttributes = attributes;
} // setAttributes(XMLAttributes)
public XMLAttributes getAttributes() {
return fAttributes;
}
/*
* Attributes methods
*/
public int getLength() {
return fAttributes.getLength();
}
public String getQName(int index) {
return fAttributes.getQName(index);
}
public String getURI(int index) {
// This hides the fact that internally we use null instead of empty string
// SAX requires the URI to be a string or an empty string
String uri = fAttributes.getURI(index);
return uri != null ? uri : XMLSymbols.EMPTY_STRING;
}
public String getLocalName(int index) {
return fAttributes.getLocalName(index);
}
public String getType(int i) {
return fAttributes.getType(i);
}
public String getType(String name) {
return fAttributes.getType(name);
}
public String getType(String uri, String localName) {
return uri.equals(XMLSymbols.EMPTY_STRING) ?
fAttributes.getType(null, localName) :
fAttributes.getType(uri, localName);
}
public String getValue(int i) {
return fAttributes.getValue(i);
}
public String getValue(String name) {
return fAttributes.getValue(name);
}
public String getValue(String uri, String localName) {
return uri.equals(XMLSymbols.EMPTY_STRING) ?
fAttributes.getValue(null, localName) :
fAttributes.getValue(uri, localName);
}
public int getIndex(String qName) {
return fAttributes.getIndex(qName);
}
public int getIndex(String uri, String localPart) {
return uri.equals(XMLSymbols.EMPTY_STRING) ?
fAttributes.getIndex(null, localPart) :
fAttributes.getIndex(uri, localPart);
}
/*
* Attributes2 methods
*/
public boolean isDeclared(int index) {
if (index < 0 || index >= fAttributes.getLength()) {
throw new ArrayIndexOutOfBoundsException(index);
}
return Boolean.TRUE.equals(
fAttributes.getAugmentations(index).getItem(
Constants.ATTRIBUTE_DECLARED));
}
public boolean isDeclared(String qName) {
int index = getIndex(qName);
if (index == -1) {
throw new IllegalArgumentException(qName);
}
return Boolean.TRUE.equals(
fAttributes.getAugmentations(index).getItem(
Constants.ATTRIBUTE_DECLARED));
}
public boolean isDeclared(String uri, String localName) {
int index = getIndex(uri, localName);
if (index == -1) {
throw new IllegalArgumentException(localName);
}
return Boolean.TRUE.equals(
fAttributes.getAugmentations(index).getItem(
Constants.ATTRIBUTE_DECLARED));
}
public boolean isSpecified(int index) {
if (index < 0 || index >= fAttributes.getLength()) {
throw new ArrayIndexOutOfBoundsException(index);
}
return fAttributes.isSpecified(index);
}
public boolean isSpecified(String qName) {
int index = getIndex(qName);
if (index == -1) {
throw new IllegalArgumentException(qName);
}
return fAttributes.isSpecified(index);
}
public boolean isSpecified(String uri, String localName) {
int index = getIndex(uri, localName);
if (index == -1) {
throw new IllegalArgumentException(localName);
}
return fAttributes.isSpecified(index);
}
/*
* AttributeList methods
*/
public String getName(int i) {
return fAttributes.getQName(i);
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy