adbxmlstreamreaderimpl.java
来自「开源的axis2框架的源码。用于开发WEBSERVER」· Java 代码 · 共 1,008 行 · 第 1/3 页
JAVA
1,008 行
/*
* 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.axis2.databinding.utils.reader;
import org.apache.axiom.om.OMAttribute;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.OMNamespace;
import org.apache.axiom.om.impl.util.OMSerializerUtil;
import org.apache.axis2.databinding.ADBBean;
import org.apache.axis2.databinding.utils.BeanUtil;
import org.apache.axis2.databinding.utils.ConverterUtil;
import org.apache.axis2.description.java2wsdl.TypeTable;
import javax.activation.DataHandler;
import javax.xml.namespace.NamespaceContext;
import javax.xml.namespace.QName;
import javax.xml.stream.Location;
import javax.xml.stream.XMLStreamException;
import javax.xml.stream.XMLStreamReader;
import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;
import java.util.Iterator;
/**
* This is the new implementation of the ADBpullaparser. The approach here is simple When the pull
* parser needs to generate events for a particular name-value(s) pair it always handes over
* (delegates) the task to another pull parser which knows how to deal with it The common types of
* name value pairs we'll come across are 1. String name/QName name - String value 2. String
* name/QName name - String[] value 3. OMElementkey - OMElement value 4. QName name/String name -
* ADBBean value 5. QName name/String name - Java bean 5. QName name/String name - Datahandler
* <p/>
* As for the attributes, these are the possible combinations in the array 1. String name/QName name
* - String value 2. OMAttributeKey - OMAttribute
* <p/>
* Note that certain array methods have been deliberately removed to avoid complications. The
* generated code will take the trouble to lay the elements of the array in the correct order
* <p/>
* <p/>
* Hence there will be a parser impl that knows how to handle these types, and this parent parser
* will always delegate these tasks to the child pullparasers in effect this is one huge state
* machine that has only a few states and delegates things down to the child parsers whenever
* possible
* <p/>
*/
public class ADBXMLStreamReaderImpl implements ADBXMLStreamReader {
private Object[] properties;
private Object[] attributes;
private QName elementQName;
//This is to store the QName which are in the typeTable after setting the correct prefix
private HashMap qnameMap = new HashMap();
//we always create a new namespace context
private ADBNamespaceContext namespaceContext = new ADBNamespaceContext();
private Map declaredNamespaceMap = new HashMap();
//states for this pullparser - it can only have four states
private static final int START_ELEMENT_STATE = 0;
private static final int END_ELEMENT_STATE = 1;
private static final int DELEGATED_STATE = 2;
private static final int TEXT_STATE = 3;
//integer field that keeps the state of this
//parser.
private int state = START_ELEMENT_STATE;
//reference to the child reader
private ADBXMLStreamReader childReader;
//current property index
//initialized at zero
private int currentPropertyIndex = 0;
//To keep element formdefault qualified or not
private boolean qualified = false;
//to keep the current types which are in AxisService
private TypeTable typeTable = null;
/*
* we need to pass in a namespace context since when delegated, we've no
* idea of the current namespace context. So it needs to be passed on
* here!
*/
public ADBXMLStreamReaderImpl(QName adbBeansQName,
Object[] properties,
Object[] attributes) {
//validate the lengths, since both the arrays are supposed
//to have
this.properties = properties;
this.elementQName = adbBeansQName;
this.attributes = attributes;
}
public ADBXMLStreamReaderImpl(QName adbBeansQName,
Object[] properties,
Object[] attributes,
TypeTable typeTable,
boolean qualified) {
this(adbBeansQName, properties, attributes);
this.qualified = qualified;
this.typeTable = typeTable;
if(this.typeTable!=null){
Map complexTypeMap = this.typeTable.getComplexSchemaMap();
if(complexTypeMap !=null){
Iterator keys = complexTypeMap.keySet().iterator();
while (keys.hasNext()) {
String key = (String) keys.next();
QName qname = (QName) complexTypeMap.get(key);
if(qname !=null){
String prefix =qname.getPrefix();
if(prefix ==null && "".equals(prefix)){
prefix = OMSerializerUtil.getNextNSPrefix();
}
qname = new QName(qname.getNamespaceURI(),qname.getLocalPart(),prefix);
this.typeTable.getComplexSchemaMap().put(key,qname);
qnameMap.put(qname.getNamespaceURI(),prefix);
addToNsMap(prefix, qname.getNamespaceURI());
}
}
}
}
}
/** add the namespace context */
public void addNamespaceContext(NamespaceContext nsContext) {
// register the namespace context passed in to this
this.namespaceContext.setParentNsContext(nsContext);
}
/**
* we need to split out the calling to the populate namespaces seperately since this needs to be
* done *after* setting the parent namespace context. We cannot assume it will happen at
* construction!
*/
public void init() {
// here we have an extra issue to attend to. we need to look at the
// prefixes and uris (the combination) and populate a hashmap of
// namespaces. The hashmap of namespaces will be used to serve the
// namespace context
populateNamespaceContext();
}
/**
* @param key
* @throws IllegalArgumentException
*/
public Object getProperty(String key) throws IllegalArgumentException {
if (state == START_ELEMENT_STATE || state == END_ELEMENT_STATE) {
if (OPTIMIZATION_ENABLED.equals(key)) {
return Boolean.TRUE;
} else {
return null;
}
} else if (state == TEXT_STATE) {
if (IS_BINARY.equals(key)) {
return Boolean.FALSE;
} else {
return null;
}
} else if (state == DELEGATED_STATE) {
return childReader.getProperty(key);
} else {
return null;
}
}
public void require(int i, String string, String string1)
throws XMLStreamException {
throw new UnsupportedOperationException();
}
/**
* todo implement the right contract for this
*
* @throws XMLStreamException
*/
public String getElementText() throws XMLStreamException {
if (state == DELEGATED_STATE) {
return childReader.getElementText();
} else {
return null;
}
}
/**
* todo implement this
*
* @throws XMLStreamException
*/
public int nextTag() throws XMLStreamException {
return 0;
}
/** @throws XMLStreamException */
public boolean hasNext() throws XMLStreamException {
if (state == DELEGATED_STATE) {
if (childReader.isDone()) {
//the child reader is done. We shouldn't be getting the
//hasnext result from the child pullparser then
return true;
} else {
return childReader.hasNext();
}
} else {
return (state == START_ELEMENT_STATE
|| state == TEXT_STATE);
}
}
public void close() throws XMLStreamException {
//do nothing here - we have no resources to free
}
public String getNamespaceURI(String prefix) {
return namespaceContext.getNamespaceURI(prefix);
}
public boolean isStartElement() {
if (state == START_ELEMENT_STATE) {
return true;
} else if (state == END_ELEMENT_STATE) {
return false;
}
return childReader.isStartElement();
}
public boolean isEndElement() {
if (state == START_ELEMENT_STATE) {
return false;
} else if (state == END_ELEMENT_STATE) {
return true;
}
return childReader.isEndElement();
}
public boolean isCharacters() {
if (state == START_ELEMENT_STATE || state == END_ELEMENT_STATE) {
return false;
}
return childReader.isCharacters();
}
public boolean isWhiteSpace() {
if (state == START_ELEMENT_STATE || state == END_ELEMENT_STATE) {
return false;
}
return childReader.isWhiteSpace();
}
///////////////////////////////////////////////////////////////////////////
/// attribute handling
///////////////////////////////////////////////////////////////////////////
public String getAttributeValue(String nsUri, String localName) {
int attribCount = getAttributeCount();
String returnValue = null;
QName attribQualifiedName;
for (int i = 0; i < attribCount; i++) {
attribQualifiedName = getAttributeName(i);
if (nsUri == null) {
if (localName.equals(attribQualifiedName.getLocalPart())) {
returnValue = getAttributeValue(i);
break;
}
} else {
if (localName.equals(attribQualifiedName.getLocalPart())
&& nsUri.equals(attribQualifiedName.getNamespaceURI())) {
returnValue = getAttributeValue(i);
break;
}
}
}
return returnValue;
}
public int getAttributeCount() {
return (state == DELEGATED_STATE) ?
childReader.getAttributeCount() :
((attributes != null) && (state == START_ELEMENT_STATE) ? attributes.length / 2 :
0);
}
/** @param i */
public QName getAttributeName(int i) {
if (state == DELEGATED_STATE) {
return childReader.getAttributeName(i);
} else if (state == START_ELEMENT_STATE) {
if (attributes == null) {
return null;
} else {
if ((i >= (attributes.length / 2)) || i < 0) { //out of range
return null;
} else {
//get the attribute pointer
Object attribPointer = attributes[i * 2];
//case one - attrib name is null
//this should be the pointer to the OMAttribute then
if (attribPointer == null) {
Object omAttribObj = attributes[(i * 2) + 1];
if (omAttribObj == null ||
!(omAttribObj instanceof OMAttribute)) {
// wrong object set to have in the attrib array -
// this should have been detected by now but just be
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?