Browse Source

SPR-7621 - AbstractStaxContentHandler sets NamespaceContext on every start/end element

git-svn-id: https://src.springframework.org/svn/spring-framework/trunk@3745 50f2f4bb-b051-0410-bef5-90022cba6387
pull/1/head
Arjen Poutsma 16 years ago
parent
commit
2eabb640f5
  1. 4
      org.springframework.core/src/main/java/org/springframework/util/xml/SimpleNamespaceContext.java
  2. 20
      org.springframework.core/src/main/java/org/springframework/util/xml/StaxStreamContentHandler.java

4
org.springframework.core/src/main/java/org/springframework/util/xml/SimpleNamespaceContext.java

@ -1,5 +1,5 @@ @@ -1,5 +1,5 @@
/*
* Copyright 2002-2009 the original author or authors.
* Copyright 2002-2010 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
@ -117,7 +117,7 @@ public class SimpleNamespaceContext implements NamespaceContext { @@ -117,7 +117,7 @@ public class SimpleNamespaceContext implements NamespaceContext {
*
* @return the declared prefixes
*/
public Iterator getBoundPrefixes() {
public Iterator<String> getBoundPrefixes() {
return prefixToNamespaceUri.keySet().iterator();
}

20
org.springframework.core/src/main/java/org/springframework/util/xml/StaxStreamContentHandler.java

@ -90,15 +90,17 @@ class StaxStreamContentHandler extends AbstractStaxContentHandler { @@ -90,15 +90,17 @@ class StaxStreamContentHandler extends AbstractStaxContentHandler {
protected void startElementInternal(QName name, Attributes attributes, SimpleNamespaceContext namespaceContext)
throws XMLStreamException {
streamWriter.writeStartElement(name.getPrefix(), name.getLocalPart(), name.getNamespaceURI());
String defaultNamespaceUri = namespaceContext.getNamespaceURI("");
if (StringUtils.hasLength(defaultNamespaceUri)) {
streamWriter.writeNamespace("", defaultNamespaceUri);
streamWriter.setDefaultNamespace(defaultNamespaceUri);
}
for (Iterator iterator = namespaceContext.getBoundPrefixes(); iterator.hasNext();) {
String prefix = (String) iterator.next();
streamWriter.writeNamespace(prefix, namespaceContext.getNamespaceURI(prefix));
streamWriter.setPrefix(prefix, namespaceContext.getNamespaceURI(prefix));
if (namespaceContext != null) {
String defaultNamespaceUri = namespaceContext.getNamespaceURI("");
if (StringUtils.hasLength(defaultNamespaceUri)) {
streamWriter.writeNamespace("", defaultNamespaceUri);
streamWriter.setDefaultNamespace(defaultNamespaceUri);
}
for (Iterator<String> iterator = namespaceContext.getBoundPrefixes(); iterator.hasNext();) {
String prefix = iterator.next();
streamWriter.writeNamespace(prefix, namespaceContext.getNamespaceURI(prefix));
streamWriter.setPrefix(prefix, namespaceContext.getNamespaceURI(prefix));
}
}
for (int i = 0; i < attributes.getLength(); i++) {
QName attrName = toQName(attributes.getURI(i), attributes.getQName(i));

Loading…
Cancel
Save