aboutsummaryrefslogtreecommitdiffstats
path: root/src/org/apache/fop/configuration/ConfigurationReader.java
diff options
context:
space:
mode:
authorfotis <fotis@unknown>2000-12-12 19:18:50 +0000
committerfotis <fotis@unknown>2000-12-12 19:18:50 +0000
commitc6eaec4c8bb1a18dc909bc65c35ede58dd0fcfee (patch)
tree79443dabcc441bf86b8edb6e560773652b055538 /src/org/apache/fop/configuration/ConfigurationReader.java
parent5668bdab96cbfac4b3c6148a48d81986322280f2 (diff)
downloadxmlgraphics-fop-c6eaec4c8bb1a18dc909bc65c35ede58dd0fcfee.tar.gz
xmlgraphics-fop-c6eaec4c8bb1a18dc909bc65c35ede58dd0fcfee.zip
adds hyphenation (Carlos Villegas, Fotis Jannidis) and simple configuration support (F.J.)
git-svn-id: https://svn.apache.org/repos/asf/xmlgraphics/fop/trunk@193861 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'src/org/apache/fop/configuration/ConfigurationReader.java')
-rw-r--r--src/org/apache/fop/configuration/ConfigurationReader.java227
1 files changed, 227 insertions, 0 deletions
diff --git a/src/org/apache/fop/configuration/ConfigurationReader.java b/src/org/apache/fop/configuration/ConfigurationReader.java
new file mode 100644
index 000000000..798a35698
--- /dev/null
+++ b/src/org/apache/fop/configuration/ConfigurationReader.java
@@ -0,0 +1,227 @@
+/*
+
+ ============================================================================
+ The Apache Software License, Version 1.1
+ ============================================================================
+
+ Copyright (C) 1999 The Apache Software Foundation. All rights reserved.
+
+ Redistribution and use in source and binary forms, with or without modifica-
+ tion, are permitted provided that the following conditions are met:
+
+ 1. Redistributions of source code must retain the above copyright notice,
+ this list of conditions and the following disclaimer.
+
+ 2. Redistributions in binary form must reproduce the above copyright notice,
+ this list of conditions and the following disclaimer in the documentation
+ and/or other materials provided with the distribution.
+
+ 3. The end-user documentation included with the redistribution, if any, must
+ include the following acknowledgment: "This product includes software
+ developed by the Apache Software Foundation (http://www.apache.org/)."
+ Alternately, this acknowledgment may appear in the software itself, if
+ and wherever such third-party acknowledgments normally appear.
+
+ 4. The names "Fop" and "Apache Software Foundation" must not be used to
+ endorse or promote products derived from this software without prior
+ written permission. For written permission, please contact
+ apache@apache.org.
+
+ 5. Products derived from this software may not be called "Apache", nor may
+ "Apache" appear in their name, without prior written permission of the
+ Apache Software Foundation.
+
+ THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
+ INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
+ FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
+ APACHE SOFTWARE FOUNDATION OR ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
+ INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLU-
+ DING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
+ OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON
+ ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+ (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
+ THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+ This software consists of voluntary contributions made by many individuals
+ on behalf of the Apache Software Foundation and was originally created by
+ James Tauber <jtauber@jtauber.com>. For more information on the Apache
+ Software Foundation, please see <http://www.apache.org/>.
+
+ */
+
+package org.apache.fop.configuration;
+
+//sax
+import org.xml.sax.helpers.DefaultHandler;
+import org.xml.sax.XMLReader;
+import org.xml.sax.SAXException;
+import java.io.IOException;
+import org.xml.sax.InputSource;
+
+//fop
+import org.apache.fop.messaging.MessageHandler;
+import org.apache.fop.apps.FOPException;
+import org.apache.fop.configuration.AWTConfiguration;
+import org.apache.fop.configuration.PDFConfiguration;
+import org.apache.fop.configuration.StandardConfiguration;
+
+/**
+ * entry class for reading configuration from file and creating a configuration
+ * class. typical use looks like that: <br>
+ *
+ * <code>ConfigurationReader reader = new ConfigurationReader ("config.xml","standard");
+ * try {
+ * reader.start();
+ * } catch (org.apache.fop.apps.FOPException error) {
+ * reader.dumpError(error);
+ * }
+ * </code>
+ * Once the configuration has been setup, the information can be accessed with
+ * the methods of StandardConfiguration.
+ */
+
+public class ConfigurationReader {
+ /** show a full dump on error */
+ private static boolean errorDump = false;
+
+ /** inputsource for configuration file */
+ private InputSource filename;
+
+ private String role ;
+
+ /**
+ * creates a configuration reader
+ * @param filename the file which contains the configuration information
+ * @param role three values are recognized: awt, pdf, standard
+ */
+ public ConfigurationReader (InputSource filename, String role) {
+ this.filename = filename;
+ this.role = role;
+ }
+
+
+ /**
+ * intantiates parser and starts parsing of config file
+ */
+ public void start () throws FOPException {
+ XMLReader parser = createParser();
+
+ if (parser == null) {
+ MessageHandler.errorln("ERROR: Unable to create SAX parser");
+ System.exit(1);
+ }
+
+ // setting the parser features
+ try {
+ parser.setFeature("http://xml.org/sax/features/namespace-prefixes",
+ false);
+ } catch (SAXException e) {
+ MessageHandler.errorln("You need a parser which supports SAX version 2");
+ if (errorDump) {
+ e.printStackTrace();
+ }
+ System.exit(1);
+ }
+ ConfigurationParser configurationParser = new ConfigurationParser();
+ parser.setContentHandler(configurationParser);
+
+ try {
+ parser.parse(filename);
+ if (role.equalsIgnoreCase("standard")) {
+ StandardConfiguration.setup(
+ configurationParser.getConfiguration());
+ } else if (role.equalsIgnoreCase("pdf")) {
+ PDFConfiguration.setup(
+ configurationParser.getConfiguration());
+ } else if (role.equalsIgnoreCase("awt")) {
+ AWTConfiguration.setup(
+ configurationParser.getConfiguration());
+ }
+ } catch (SAXException e) {
+ if (e.getException() instanceof FOPException) {
+ dumpError(e.getException());
+ throw (FOPException) e.getException();
+ } else {
+ dumpError(e);
+ throw new FOPException(e.getMessage());
+ }
+ }
+ catch (IOException e) {
+ dumpError(e);
+ throw new FOPException(e.getMessage());
+ }
+ }
+
+
+ /**
+ * creates a SAX parser, using the value of org.xml.sax.parser
+ * defaulting to org.apache.xerces.parsers.SAXParser
+ *
+ * @return the created SAX parser
+ */
+ static XMLReader createParser() {
+ String parserClassName = System.getProperty("org.xml.sax.parser");
+ if (parserClassName == null) {
+ parserClassName = "org.apache.xerces.parsers.SAXParser";
+ }
+ if (errorDump) {
+ MessageHandler.logln( "configuration reader using SAX parser " +
+ parserClassName);
+ }
+
+ try {
+ return (XMLReader) Class.forName(
+ parserClassName).newInstance();
+ } catch (ClassNotFoundException e) {
+ MessageHandler.errorln("Could not find " + parserClassName);
+ if (errorDump) {
+ e.printStackTrace();
+ }
+ }
+ catch (InstantiationException e) {
+ MessageHandler.errorln("Could not instantiate " +
+ parserClassName);
+ if (errorDump) {
+ e.printStackTrace();
+ }
+ }
+ catch (IllegalAccessException e) {
+ MessageHandler.errorln("Could not access " + parserClassName);
+ if (errorDump) {
+ e.printStackTrace();
+ }
+ }
+ catch (ClassCastException e) {
+ MessageHandler.errorln(parserClassName + " is not a SAX driver");
+ if (errorDump) {
+ e.printStackTrace();
+ }
+ }
+ return null;
+ }
+
+ /**
+ * Dumps an error
+ */
+ public void dumpError(Exception e) {
+ if (errorDump) {
+ if (e instanceof SAXException) {
+ e.printStackTrace();
+ if (((SAXException) e).getException() != null) {
+ ((SAXException) e).getException().printStackTrace();
+ }
+ } else {
+ e.printStackTrace();
+ }
+ }
+ }
+
+ /**
+ * long or short error messages
+ *
+ */
+ public void setDumpError(boolean dumpError) {
+ this.errorDump = errorDump;
+ }
+
+}