diff options
author | Vincent Hennebert <vhennebert@apache.org> | 2009-10-20 10:04:09 +0000 |
---|---|---|
committer | Vincent Hennebert <vhennebert@apache.org> | 2009-10-20 10:04:09 +0000 |
commit | 28cd945acabbe23b213d83a4ca2899589a8865a6 (patch) | |
tree | 7e4868247d59cef03bbbfed6b2be0fae32a37e8f | |
parent | 7ed63c2e015d0c31ac7f4499a65cd8fd3ee61af0 (diff) | |
download | xmlgraphics-fop-28cd945acabbe23b213d83a4ca2899589a8865a6.tar.gz xmlgraphics-fop-28cd945acabbe23b213d83a4ca2899589a8865a6.zip |
Fixed checkstyle issues.
Factorized duplicated code into getXMLReader method.
git-svn-id: https://svn.apache.org/repos/asf/xmlgraphics/fop/trunk@827023 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r-- | src/java/org/apache/fop/cli/InputHandler.java | 66 |
1 files changed, 36 insertions, 30 deletions
diff --git a/src/java/org/apache/fop/cli/InputHandler.java b/src/java/org/apache/fop/cli/InputHandler.java index 14811d7fa..ebbee3ad5 100644 --- a/src/java/org/apache/fop/cli/InputHandler.java +++ b/src/java/org/apache/fop/cli/InputHandler.java @@ -19,7 +19,6 @@ package org.apache.fop.cli; -// Imported java.io classes import java.io.File; import java.io.FileNotFoundException; import java.io.InputStream; @@ -40,38 +39,40 @@ import javax.xml.transform.sax.SAXSource; import javax.xml.transform.stream.StreamResult; import javax.xml.transform.stream.StreamSource; +import org.xml.sax.EntityResolver; +import org.xml.sax.InputSource; +import org.xml.sax.SAXException; +import org.xml.sax.XMLReader; + import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; + import org.apache.fop.apps.FOPException; import org.apache.fop.apps.FOUserAgent; import org.apache.fop.apps.Fop; import org.apache.fop.apps.FopFactory; import org.apache.fop.render.awt.viewer.Renderable; -import org.xml.sax.EntityResolver; -import org.xml.sax.InputSource; -import org.xml.sax.SAXException; -import org.xml.sax.XMLReader; /** * Class for handling files input from command line * either with XML and XSLT files (and optionally xsl - * parameters) or FO File input alone + * parameters) or FO File input alone. */ public class InputHandler implements ErrorListener, Renderable { /** original source file */ - protected File sourcefile = null; - private File stylesheet = null; // for XML/XSLT usage - private Vector xsltParams = null; // for XML/XSLT usage - private EntityResolver entityResolver = null; - private URIResolver uriResolver = null; + protected File sourcefile; + private File stylesheet; // for XML/XSLT usage + private Vector xsltParams; // for XML/XSLT usage + private EntityResolver entityResolver; + private URIResolver uriResolver; /** the logger */ protected Log log = LogFactory.getLog(InputHandler.class); /** * Constructor for XML->XSLT->FO input - * + * * @param xmlfile XML file * @param xsltfile XSLT file * @param params Vector of command-line parameters (name, value, @@ -85,7 +86,7 @@ public class InputHandler implements ErrorListener, Renderable { /** * Constructor for XML->XSLT->FO input - * + * * @param xmlfile XML file * @param xsltfile XSLT file * @param params Vector of command-line parameters (name, value, @@ -186,10 +187,7 @@ public class InputHandler implements ErrorListener, Renderable { try { InputSource is = new InputSource(in); is.setSystemId(uri); - SAXParserFactory spf = SAXParserFactory.newInstance(); - spf.setFeature("http://xml.org/sax/features/namespaces", true); - spf.setFeature("http://apache.org/xml/features/xinclude", true); - XMLReader xr = spf.newSAXParser().getXMLReader(); + XMLReader xr = getXMLReader(); if (entityResolver != null) { xr.setEntityResolver(entityResolver); } @@ -209,21 +207,23 @@ public class InputHandler implements ErrorListener, Renderable { } return source; } - + /** - * Create a catalog resolver and use it for XML parsing and XSLT URI resolution + * Creates a catalog resolver and use it for XML parsing and XSLT URI resolution. * Try the Apache Commons Resolver, and if unsuccessful, * try the same built into Java 6 */ - protected void createCatalogResolver() { - String[] classNames = - new String[] {"org.apache.xml.resolver.tools.CatalogResolver", - "com.sun.org.apache.xml.internal.resolver.tools.CatalogResolver"}; + private void createCatalogResolver() { + String[] classNames = new String[] { + "org.apache.xml.resolver.tools.CatalogResolver", + "com.sun.org.apache.xml.internal.resolver.tools.CatalogResolver"}; Class resolverClass = null; for (int i = 0; i < classNames.length && resolverClass == null; ++i) { try { resolverClass = Class.forName(classNames[i]); - } catch (ClassNotFoundException e) { } + } catch (ClassNotFoundException e) { + // No worries + } } if (resolverClass == null) { log.error("Could not find catalog resolver in class path"); @@ -241,7 +241,7 @@ public class InputHandler implements ErrorListener, Renderable { /** * Creates a Source for the selected stylesheet. - * + * * @return the Source for the selected stylesheet or null if there's no stylesheet */ protected Source createXSLTSource() { @@ -250,10 +250,7 @@ public class InputHandler implements ErrorListener, Renderable { if (entityResolver != null) { try { InputSource is = new InputSource(this.stylesheet.getPath()); - SAXParserFactory spf = SAXParserFactory.newInstance(); - spf.setFeature("http://xml.org/sax/features/namespaces", true); - spf.setFeature("http://apache.org/xml/features/xinclude", true); - XMLReader xr = spf.newSAXParser().getXMLReader(); + XMLReader xr = getXMLReader(); xr.setEntityResolver(entityResolver); xslt = new SAXSource(xr, is); } catch (SAXException e) { @@ -262,12 +259,21 @@ public class InputHandler implements ErrorListener, Renderable { // return StreamSource } } - if (xslt == null) + if (xslt == null) { xslt = new StreamSource(this.stylesheet); + } } return xslt; } + private XMLReader getXMLReader() throws ParserConfigurationException, SAXException { + SAXParserFactory spf = SAXParserFactory.newInstance(); + spf.setFeature("http://xml.org/sax/features/namespaces", true); + spf.setFeature("http://apache.org/xml/features/xinclude", true); + XMLReader xr = spf.newSAXParser().getXMLReader(); + return xr; + } + /** * Transforms the input document to the input format expected by FOP using XSLT. * @param result the Result object where the result of the XSL transformation is sent to |