From c4cf4df4f3780e5b406ee56bcf0aa0dd4c6317c7 Mon Sep 17 00:00:00 2001 From: Joe Wang Date: Tue, 27 Jul 2021 19:14:05 +0000 Subject: [PATCH] 8269938: Enhance XML processing passes redux Reviewed-by: naoto, lancea, rhalade, ahgross --- .../internal/parsers/AbstractDOMParser.java | 49 +++---------- .../xml/internal/serializer/ToHTMLStream.java | 29 ++------ .../xml/internal/serializer/ToStream.java | 69 +++---------------- .../serializer/dom3/DOM3TreeWalker.java | 20 +----- .../stream/events/EntityDeclarationImpl.java | 15 ++-- .../events/NotationDeclarationImpl.java | 14 +--- .../classes/jdk/xml/internal/JdkXmlUtils.java | 41 ++++++++--- 7 files changed, 65 insertions(+), 172 deletions(-) diff --git a/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/parsers/AbstractDOMParser.java b/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/parsers/AbstractDOMParser.java index ac3fcfbd891..b10634943c3 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/parsers/AbstractDOMParser.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xerces/internal/parsers/AbstractDOMParser.java @@ -1,5 +1,5 @@ /* - * Copyright (c) 2017, 2019, Oracle and/or its affiliates. All rights reserved. + * Copyright (c) 2017, 2021, Oracle and/or its affiliates. All rights reserved. */ /* * Licensed to the Apache Software Foundation (ASF) under one or more @@ -56,6 +56,7 @@ import com.sun.org.apache.xerces.internal.xs.ElementPSVI; import com.sun.org.apache.xerces.internal.xs.XSTypeDefinition; import java.util.Locale; import java.util.Stack; +import jdk.xml.internal.JdkXmlUtils; import org.w3c.dom.Attr; import org.w3c.dom.CDATASection; import org.w3c.dom.Comment; @@ -84,7 +85,7 @@ import org.xml.sax.SAXException; * @author Andy Clark, IBM * @author Elena Litani, IBM * - * @LastModified: Jan 2019 + * @LastModified: July 2021 */ public class AbstractDOMParser extends AbstractXMLDocumentParser { @@ -2041,17 +2042,8 @@ public class AbstractDOMParser extends AbstractXMLDocumentParser { else { fInternalSubset.append (name); } - fInternalSubset.append (' '); - if (publicId != null) { - fInternalSubset.append ("PUBLIC '"); - fInternalSubset.append (publicId); - fInternalSubset.append ("' '"); - } - else { - fInternalSubset.append ("SYSTEM '"); - } - fInternalSubset.append (literalSystemId); - fInternalSubset.append ("'>\n"); + fInternalSubset.append (JdkXmlUtils.getDTDExternalDecl(publicId, literalSystemId)); + fInternalSubset.append (">\n"); } // NOTE: We only know how to create these nodes for the Xerces @@ -2181,20 +2173,8 @@ public class AbstractDOMParser extends AbstractXMLDocumentParser { if (fInternalSubset != null && !fInDTDExternalSubset) { fInternalSubset.append ("\n"); } @@ -2261,19 +2241,8 @@ public class AbstractDOMParser extends AbstractXMLDocumentParser { if (fInternalSubset != null && !fInDTDExternalSubset) { fInternalSubset.append ("\n"); + fInternalSubset.append (JdkXmlUtils.getDTDExternalDecl(publicId, literalSystemId)); + fInternalSubset.append (">\n"); } // NOTE: We only know how to create these nodes for the Xerces diff --git a/src/java.xml/share/classes/com/sun/org/apache/xml/internal/serializer/ToHTMLStream.java b/src/java.xml/share/classes/com/sun/org/apache/xml/internal/serializer/ToHTMLStream.java index ff838e30fe7..58ef55e43fa 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xml/internal/serializer/ToHTMLStream.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xml/internal/serializer/ToHTMLStream.java @@ -31,6 +31,7 @@ import org.xml.sax.SAXException; import com.sun.org.apache.xml.internal.serializer.utils.MsgKey; import com.sun.org.apache.xml.internal.serializer.utils.Utils; import javax.xml.transform.ErrorListener; +import jdk.xml.internal.JdkXmlUtils; /** * This serializer takes a series of SAX or @@ -41,7 +42,7 @@ import javax.xml.transform.ErrorListener; * because it is used from another package. * * @xsl.usage internal - * @LastModified: June 2021 + * @LastModified: July 2021 */ public final class ToHTMLStream extends ToStream { @@ -679,28 +680,10 @@ public final class ToHTMLStream extends ToStream final java.io.Writer writer = m_writer; try { - writer.write("'); - outputLineSep(); + writer.write("'); + outputLineSep(); } catch(IOException e) { diff --git a/src/java.xml/share/classes/com/sun/org/apache/xml/internal/serializer/ToStream.java b/src/java.xml/share/classes/com/sun/org/apache/xml/internal/serializer/ToStream.java index 126f5d15255..fc01f006e97 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xml/internal/serializer/ToStream.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xml/internal/serializer/ToStream.java @@ -896,16 +896,8 @@ abstract public class ToStream extends SerializerBase { m_writer.write(""); + m_writer.write(JdkXmlUtils.getDTDExternalDecl(publicId, systemId)); + m_writer.write(">"); m_writer.write(m_lineSep, 0, m_lineSepLen); } catch (IOException e) { // TODO Auto-generated catch block @@ -1974,27 +1966,11 @@ abstract public class ToStream extends SerializerBase { final Writer writer = m_writer; writer.write(""); @@ -2002,17 +1978,6 @@ abstract public class ToStream extends SerializerBase { closeDecl = false; // done closing } } - boolean dothis = false; - if (dothis) - { - // at one point this code seemed right, - // but not anymore - Brian M. - if (closeDecl) - { - writer.write('>'); - writer.write(m_lineSep, 0, m_lineSepLen); - } - } } catch (IOException e) { @@ -3577,16 +3542,8 @@ abstract public class ToStream extends SerializerBase { m_writer.write(""); + m_writer.write(JdkXmlUtils.getDTDExternalDecl(pubID, sysID)); + m_writer.write(">"); m_writer.write(m_lineSep, 0, m_lineSepLen); } catch (IOException e) { // TODO Auto-generated catch block @@ -3607,16 +3564,8 @@ abstract public class ToStream extends SerializerBase { m_writer.write(""); m_writer.write(m_lineSep, 0, m_lineSepLen); diff --git a/src/java.xml/share/classes/com/sun/org/apache/xml/internal/serializer/dom3/DOM3TreeWalker.java b/src/java.xml/share/classes/com/sun/org/apache/xml/internal/serializer/dom3/DOM3TreeWalker.java index 519235d463f..2f7d41a1971 100644 --- a/src/java.xml/share/classes/com/sun/org/apache/xml/internal/serializer/dom3/DOM3TreeWalker.java +++ b/src/java.xml/share/classes/com/sun/org/apache/xml/internal/serializer/dom3/DOM3TreeWalker.java @@ -63,7 +63,7 @@ import org.xml.sax.helpers.LocatorImpl; * parameters and filters if any during serialization. * * @xsl.usage internal - * @LastModified: Apr 2021 + * @LastModified: July 2021 */ final class DOM3TreeWalker { @@ -506,23 +506,7 @@ final class DOM3TreeWalker { dtd.append("'); } } diff --git a/src/java.xml/share/classes/jdk/xml/internal/JdkXmlUtils.java b/src/java.xml/share/classes/jdk/xml/internal/JdkXmlUtils.java index 6e0975356cb..210349d5fc0 100644 --- a/src/java.xml/share/classes/jdk/xml/internal/JdkXmlUtils.java +++ b/src/java.xml/share/classes/jdk/xml/internal/JdkXmlUtils.java @@ -367,19 +367,40 @@ public class JdkXmlUtils { } /** - * Returns the character to be used to quote the input content. Between - * single and double quotes, this method returns the one that is not found - * in the input. Returns double quote by default. + * Returns the external declaration for a DTD construct. * - * @param s the input string - * @return returns the quote not found in the input + * @param publicId the public identifier + * @param systemId the system identifier + * @return a DTD external declaration */ - public static char getQuoteChar(String s) { - if (s != null && s.indexOf('"') > -1) { - return '\''; - } else { - return '"'; + public static String getDTDExternalDecl(String publicId, String systemId) { + StringBuilder sb = new StringBuilder(); + if (null != publicId) { + sb.append(" PUBLIC "); + sb.append(quoteString(publicId)); } + + if (null != systemId) { + if (null == publicId) { + sb.append(" SYSTEM "); + } else { + sb.append(" "); + } + + sb.append(quoteString(systemId)); + } + return sb.toString(); + } + + /** + * Returns the input string quoted with double quotes or single ones if + * there is a double quote in the string. + * @param s the input string, can not be null + * @return the quoted string + */ + private static String quoteString(String s) { + char c = (s.indexOf('"') > -1) ? '\'' : '"'; + return c + s + c; } private static XMLReader getXMLReaderWSAXFactory(boolean overrideDefaultParser) {