summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornash <nash@13f79535-47bb-0310-9956-ffa450edef68>2010-09-26 21:49:03 +0000
committernash <nash@13f79535-47bb-0310-9956-ffa450edef68>2010-09-26 21:49:03 +0000
commit0abd78da7ad3d708dade1b6d5a8a50736dfffc25 (patch)
tree5a280b6d67c2e68997cdbdf229de0b15e450fdff
parent3ec9ac7605408a7c6e16af8940e104405a826beb (diff)
TUSCANY-3689: Fix corruption of XML document when transformed from XMLStreamReader to NodeInfo
git-svn-id: http://svn.us.apache.org/repos/asf/tuscany@1001528 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r--sca-java-1.x/branches/sca-java-1.6.1/modules/databinding-saxon/src/main/java/org/apache/tuscany/sca/databinding/saxon/XMLStreamReader2NodeInfoTransformer.java86
-rw-r--r--sca-java-1.x/branches/sca-java-1.6.1/modules/databinding-saxon/src/main/resources/META-INF/services/org.apache.tuscany.sca.databinding.PullTransformer1
2 files changed, 87 insertions, 0 deletions
diff --git a/sca-java-1.x/branches/sca-java-1.6.1/modules/databinding-saxon/src/main/java/org/apache/tuscany/sca/databinding/saxon/XMLStreamReader2NodeInfoTransformer.java b/sca-java-1.x/branches/sca-java-1.6.1/modules/databinding-saxon/src/main/java/org/apache/tuscany/sca/databinding/saxon/XMLStreamReader2NodeInfoTransformer.java
new file mode 100644
index 0000000000..27256bd9a3
--- /dev/null
+++ b/sca-java-1.x/branches/sca-java-1.6.1/modules/databinding-saxon/src/main/java/org/apache/tuscany/sca/databinding/saxon/XMLStreamReader2NodeInfoTransformer.java
@@ -0,0 +1,86 @@
+/*
+ * 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.tuscany.sca.databinding.saxon;
+
+import javax.xml.stream.XMLStreamReader;
+import javax.xml.transform.dom.DOMSource;
+
+import net.sf.saxon.Configuration;
+import net.sf.saxon.event.Builder;
+import net.sf.saxon.om.NodeInfo;
+
+import org.apache.tuscany.sca.databinding.DataPipe;
+import org.apache.tuscany.sca.databinding.PullTransformer;
+import org.apache.tuscany.sca.databinding.TransformationContext;
+import org.apache.tuscany.sca.databinding.TransformationException;
+import org.apache.tuscany.sca.databinding.impl.BaseTransformer;
+import org.apache.tuscany.sca.databinding.xml.SAX2DOMPipe;
+import org.apache.tuscany.sca.databinding.xml.StAX2SAXAdapter;
+import org.w3c.dom.Node;
+import org.xml.sax.ContentHandler;
+
+/**
+ * Transforms an XMLStreamReader to a NodeInfo object needed by Saxon parser.
+ *
+ * Any namespaces that are defined are deleted, because otherwise
+ * the SaxonB parser does not work
+ *
+ * @version $Rev: 671701 $ $Date: 2008-06-26 02:29:06 +0100 (Thu, 26 Jun 2008) $
+ */
+public class XMLStreamReader2NodeInfoTransformer extends BaseTransformer<XMLStreamReader, NodeInfo> implements
+ PullTransformer<XMLStreamReader, NodeInfo> {
+
+ private StAX2SAXAdapter stax2sax = new StAX2SAXAdapter(false);
+ private SAX2DOMPipe sax2dom = new SAX2DOMPipe();
+
+ public NodeInfo transform(XMLStreamReader source, TransformationContext context) {
+ Configuration configuration = SaxonDataBindingHelper.CURR_EXECUTING_CONFIG;
+ if (configuration == null) {
+ configuration = new Configuration();
+ }
+
+ NodeInfo docInfo = null;
+ try {
+ DataPipe<ContentHandler, Node> pipe = sax2dom.newInstance();
+ stax2sax.parse(source, pipe.getSink());
+ Node node = pipe.getResult();
+ source.close();
+ docInfo = Builder.build(new DOMSource(node), null, configuration);
+ } catch (Exception e) {
+ throw new TransformationException(e);
+ }
+ return docInfo;
+ }
+
+ @Override
+ protected Class<XMLStreamReader> getSourceType() {
+ return XMLStreamReader.class;
+ }
+
+ @Override
+ protected Class<NodeInfo> getTargetType() {
+ return NodeInfo.class;
+ }
+
+ @Override
+ public int getWeight() {
+ return 10;
+ }
+
+}
diff --git a/sca-java-1.x/branches/sca-java-1.6.1/modules/databinding-saxon/src/main/resources/META-INF/services/org.apache.tuscany.sca.databinding.PullTransformer b/sca-java-1.x/branches/sca-java-1.6.1/modules/databinding-saxon/src/main/resources/META-INF/services/org.apache.tuscany.sca.databinding.PullTransformer
index 4d927ce53d..111e2e28d0 100644
--- a/sca-java-1.x/branches/sca-java-1.6.1/modules/databinding-saxon/src/main/resources/META-INF/services/org.apache.tuscany.sca.databinding.PullTransformer
+++ b/sca-java-1.x/branches/sca-java-1.6.1/modules/databinding-saxon/src/main/resources/META-INF/services/org.apache.tuscany.sca.databinding.PullTransformer
@@ -32,3 +32,4 @@ org.apache.tuscany.sca.databinding.saxon.ItemList2ObjectTransformer;source=org.a
org.apache.tuscany.sca.databinding.saxon.ItemList2ObjectTransformer;source=org.apache.tuscany.sca.databinding.saxon.collection.ItemList,target=java:array,weight=1000
org.apache.tuscany.sca.databinding.saxon.NodeInfo2JavaArrayTransformer;source=net.sf.saxon.om.NodeInfo,target=java:array,weight=1000
org.apache.tuscany.sca.databinding.saxon.Value2JavaArrayTransformer;source=net.sf.saxon.value.Value,target=java:array,weight=1000
+org.apache.tuscany.sca.databinding.saxon.XMLStreamReader2NodeInfoTransformer;source=javax.xml.stream.XMLStreamReader,target=net.sf.saxon.om.NodeInfo,weight=2000