aboutsummaryrefslogtreecommitdiffstats
path: root/src/org/apache/fop/apps
diff options
context:
space:
mode:
Diffstat (limited to 'src/org/apache/fop/apps')
-rw-r--r--src/org/apache/fop/apps/AWTStarter.java47
-rw-r--r--src/org/apache/fop/apps/CommandLineOptions.java498
-rw-r--r--src/org/apache/fop/apps/CommandLineStarter.java54
-rw-r--r--src/org/apache/fop/apps/Driver.java270
-rw-r--r--src/org/apache/fop/apps/ErrorHandler.java59
-rw-r--r--src/org/apache/fop/apps/FOInputHandler.java12
-rw-r--r--src/org/apache/fop/apps/FOPException.java143
-rw-r--r--src/org/apache/fop/apps/Fop.java14
-rw-r--r--src/org/apache/fop/apps/InputHandler.java26
-rw-r--r--src/org/apache/fop/apps/Options.java94
-rw-r--r--src/org/apache/fop/apps/PDFOutputHandler.java354
-rw-r--r--src/org/apache/fop/apps/PrintStarter.java29
-rw-r--r--src/org/apache/fop/apps/Starter.java15
-rw-r--r--src/org/apache/fop/apps/TraxInputHandler.java38
-rw-r--r--src/org/apache/fop/apps/Version.java7
-rw-r--r--src/org/apache/fop/apps/XSLTInputHandler.java39
-rw-r--r--src/org/apache/fop/apps/XTDriver.java436
17 files changed, 1061 insertions, 1074 deletions
diff --git a/src/org/apache/fop/apps/AWTStarter.java b/src/org/apache/fop/apps/AWTStarter.java
index a38edf207..96dc271aa 100644
--- a/src/org/apache/fop/apps/AWTStarter.java
+++ b/src/org/apache/fop/apps/AWTStarter.java
@@ -1,4 +1,5 @@
-/* $Id$
+/*
+ * $Id$
* Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
* For details on use and redistribution please refer to the
* LICENSE file included with these sources.
@@ -6,11 +7,10 @@
package org.apache.fop.apps;
/*
- originally contributed by
- Juergen Verwohlt: Juergen.Verwohlt@jCatalog.com,
- Rainer Steinkuhle: Rainer.Steinkuhle@jCatalog.com,
- Stanislav Gorkhover: Stanislav.Gorkhover@jCatalog.com
-
+ * originally contributed by
+ * Juergen Verwohlt: Juergen.Verwohlt@jCatalog.com,
+ * Rainer Steinkuhle: Rainer.Steinkuhle@jCatalog.com,
+ * Stanislav Gorkhover: Stanislav.Gorkhover@jCatalog.com
*/
import org.apache.fop.messaging.MessageHandler;
import org.apache.fop.viewer.*;
@@ -50,20 +50,20 @@ public class AWTStarter extends CommandLineStarter {
PreviewDialog frame;
AWTRenderer renderer;
- public static String TRANSLATION_PATH = "/org/apache/fop/viewer/resources/";
+ public static String TRANSLATION_PATH =
+ "/org/apache/fop/viewer/resources/";
private Translator resource;
- public AWTStarter (CommandLineOptions commandLineOptions)
- throws FOPException {
+ public AWTStarter(CommandLineOptions commandLineOptions)
+ throws FOPException {
super(commandLineOptions);
init();
}
- private void init () {
+ private void init() {
try {
- UIManager.setLookAndFeel(
- new javax.swing.plaf.metal.MetalLookAndFeel());
+ UIManager.setLookAndFeel(new javax.swing.plaf.metal.MetalLookAndFeel());
} catch (Exception e) {
e.printStackTrace();
}
@@ -73,12 +73,12 @@ public class AWTStarter extends CommandLineStarter {
if (language == null)
language = System.getProperty("user.language");
- resource = getResourceBundle(TRANSLATION_PATH + "resources." +
- language);
+ resource = getResourceBundle(TRANSLATION_PATH + "resources."
+ + language);
- UserMessage.setTranslator(
- getResourceBundle(TRANSLATION_PATH + "messages." +
- language));
+ UserMessage.setTranslator(getResourceBundle(TRANSLATION_PATH
+ + "messages."
+ + language));
resource.setMissingEmphasized(false);
renderer = new AWTRenderer(resource);
@@ -90,13 +90,13 @@ public class AWTStarter extends CommandLineStarter {
}
- public void run () throws FOPException {
+ public void run() throws FOPException {
Driver driver = new Driver();
if (errorDump) {
driver.setErrorDump(true);
}
- //init parser
+ // init parser
frame.progress(resource.getString("Init parser") + " ...");
XMLReader parser = inputHandler.getParser();
@@ -126,7 +126,7 @@ public class AWTStarter extends CommandLineStarter {
} catch (Exception e) {
if (e instanceof FOPException) {
- throw (FOPException) e;
+ throw (FOPException)e;
}
throw new FOPException(e);
}
@@ -134,7 +134,7 @@ public class AWTStarter extends CommandLineStarter {
}
protected PreviewDialog createPreviewDialog(AWTRenderer renderer,
- Translator res) {
+ Translator res) {
PreviewDialog frame = new PreviewDialog(renderer, res);
frame.validate();
@@ -160,11 +160,12 @@ public class AWTStarter extends CommandLineStarter {
URL url = getClass().getResource(path);
in = url.openStream();
} catch (Exception ex) {
- MessageHandler.logln("Can't find URL to: <" + path + "> " +
- ex.getMessage());
+ MessageHandler.logln("Can't find URL to: <" + path + "> "
+ + ex.getMessage());
}
return new SecureResourceBundle(in);
}
+
}
diff --git a/src/org/apache/fop/apps/CommandLineOptions.java b/src/org/apache/fop/apps/CommandLineOptions.java
index 61b78a4d0..c13e65518 100644
--- a/src/org/apache/fop/apps/CommandLineOptions.java
+++ b/src/org/apache/fop/apps/CommandLineOptions.java
@@ -1,4 +1,5 @@
-/* $Id$
+/*
+ * $Id$
* Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
* For details on use and redistribution please refer to the
* LICENSE file included with these sources.
@@ -6,7 +7,7 @@
package org.apache.fop.apps;
-//java
+// java
import java.util.Vector;
import java.io.File;
import java.io.FileNotFoundException;
@@ -17,29 +18,29 @@ import org.apache.fop.configuration.Configuration;
import org.apache.fop.apps.FOPException;
/**
- * Options parses the commandline arguments
+ * Options parses the commandline arguments
*/
public class CommandLineOptions {
/* input / output not set */
private static final int NOT_SET = 0;
- /* input: fo file */
+ /* input: fo file */
private static final int FO_INPUT = 1;
- /* input: xml+xsl file */
+ /* input: xml+xsl file */
private static final int XSLT_INPUT = 2;
- /* output: pdf file */
+ /* output: pdf file */
private static final int PDF_OUTPUT = 1;
- /* output: screen using swing */
+ /* output: screen using swing */
private static final int AWT_OUTPUT = 2;
- /* output: mif file */
+ /* output: mif file */
private static final int MIF_OUTPUT = 3;
- /* output: sent swing rendered file to printer */
+ /* output: sent swing rendered file to printer */
private static final int PRINT_OUTPUT = 4;
- /* output: pcl file */
+ /* output: pcl file */
private static final int PCL_OUTPUT = 5;
- /* output: postscript file */
+ /* output: postscript file */
private static final int PS_OUTPUT = 6;
- /* output: text file */
+ /* output: text file */
private static final int TXT_OUTPUT = 7;
/* System buffers */
@@ -48,29 +49,29 @@ public class CommandLineOptions {
/* System buffers */
private static final int AREA_OUTPUT = 9;
- /* use debug mode*/
+ /* use debug mode */
Boolean errorDump = new Boolean(false);
/* show configuration information */
Boolean dumpConfiguration = new Boolean(false);
- /*suppress any progress information */
+ /* suppress any progress information */
Boolean quiet = new Boolean(false);
/* for area tree XML output, only down to block area level */
Boolean suppressLowLevelAreas = new Boolean(false);
- /* name of user configuration file*/
+ /* name of user configuration file */
File userConfigFile = null;
- /* name of input fo file */
+ /* name of input fo file */
File fofile = null;
- /* name of xsltfile (xslt transformation as input)*/
+ /* name of xsltfile (xslt transformation as input) */
File xsltfile = null;
- /* name of xml file (xslt transformation as input)*/
+ /* name of xml file (xslt transformation as input) */
File xmlfile = null;
- /* name of output file */
+ /* name of output file */
File outfile = null;
/* name of buffer file */
File bufferFile = null;
/* input mode */
int inputmode = NOT_SET;
- /*output mode */
+ /* output mode */
int outputmode = NOT_SET;
/* buffer mode */
int buffermode = NOT_SET;
@@ -79,14 +80,14 @@ public class CommandLineOptions {
private java.util.Hashtable rendererOptions;
- public CommandLineOptions (String [] args) throws FOPException,
- FileNotFoundException {
+ public CommandLineOptions(String[] args)
+ throws FOPException, FileNotFoundException {
boolean optionsParsed = true;
rendererOptions = new java.util.Hashtable();
try {
optionsParsed = parseOptions(args);
if (optionsParsed) {
- checkSettings ();
+ checkSettings();
if (errorDump != null && errorDump.booleanValue()) {
debug();
}
@@ -94,8 +95,7 @@ public class CommandLineOptions {
} catch (FOPException e) {
printUsage();
throw e;
- }
- catch (java.io.FileNotFoundException e) {
+ } catch (java.io.FileNotFoundException e) {
printUsage();
throw e;
}
@@ -103,29 +103,30 @@ public class CommandLineOptions {
}
/**
- * parses the commandline arguments
+ * parses the commandline arguments
* @return true if parse was successful and procesing can continue, false if processing should stop
* @exception FOPException if there was an error in the format of the options
*/
- private boolean parseOptions (String args[]) throws FOPException {
+ private boolean parseOptions(String args[]) throws FOPException {
for (int i = 0; i < args.length; i++) {
if (args[i].equals("-d") || args[i].equals("--full-error-dump")) {
errorDump = new Boolean(true);
- } else if (args[i].equals("-x") || args[i].equals("--dump-config")) {
+ } else if (args[i].equals("-x")
+ || args[i].equals("--dump-config")) {
dumpConfiguration = new Boolean(true);
} else if (args[i].equals("-q") || args[i].equals("--quiet")) {
quiet = new Boolean(true);
} else if (args[i].equals("-c")) {
- if ((i + 1 == args.length) ||
- (args[i + 1].charAt(0) == '-')) {
+ if ((i + 1 == args.length)
+ || (args[i + 1].charAt(0) == '-')) {
throw new FOPException("if you use '-c', you must specify the name of the configuration file");
} else {
- userConfigFile = new File (args[i + 1]);
+ userConfigFile = new File(args[i + 1]);
i++;
}
} else if (args[i].equals("-l")) {
- if ((i + 1 == args.length) ||
- (args[i + 1].charAt(0) == '-')) {
+ if ((i + 1 == args.length)
+ || (args[i + 1].charAt(0) == '-')) {
throw new FOPException("if you use '-l', you must specify a language");
} else {
language = args[i + 1];
@@ -135,17 +136,17 @@ public class CommandLineOptions {
suppressLowLevelAreas = new Boolean(true);
} else if (args[i].equals("-fo")) {
inputmode = FO_INPUT;
- if ((i + 1 == args.length) ||
- (args[i + 1].charAt(0) == '-')) {
+ if ((i + 1 == args.length)
+ || (args[i + 1].charAt(0) == '-')) {
throw new FOPException("you must specify the fo file for the '-fo' option");
} else {
- fofile = new File (args[i + 1]);
+ fofile = new File(args[i + 1]);
i++;
}
} else if (args[i].equals("-xsl")) {
inputmode = XSLT_INPUT;
- if ((i + 1 == args.length) ||
- (args[i + 1].charAt(0) == '-')) {
+ if ((i + 1 == args.length)
+ || (args[i + 1].charAt(0) == '-')) {
throw new FOPException("you must specify the stylesheet file for the '-xsl' option");
} else {
xsltfile = new File(args[i + 1]);
@@ -153,8 +154,8 @@ public class CommandLineOptions {
}
} else if (args[i].equals("-xml")) {
inputmode = XSLT_INPUT;
- if ((i + 1 == args.length) ||
- (args[i + 1].charAt(0) == '-')) {
+ if ((i + 1 == args.length)
+ || (args[i + 1].charAt(0) == '-')) {
throw new FOPException("you must specify the input file for the '-xml' option");
} else {
xmlfile = new File(args[i + 1]);
@@ -164,17 +165,17 @@ public class CommandLineOptions {
setOutputMode(AWT_OUTPUT);
} else if (args[i].equals("-pdf")) {
setOutputMode(PDF_OUTPUT);
- if ((i + 1 == args.length) ||
- (args[i + 1].charAt(0) == '-')) {
+ if ((i + 1 == args.length)
+ || (args[i + 1].charAt(0) == '-')) {
throw new FOPException("you must specify the pdf output file");
} else {
- outfile = new File (args[i + 1]);
+ outfile = new File(args[i + 1]);
i++;
}
} else if (args[i].equals("-mif")) {
setOutputMode(MIF_OUTPUT);
- if ((i + 1 == args.length) ||
- (args[i + 1].charAt(0) == '-')) {
+ if ((i + 1 == args.length)
+ || (args[i + 1].charAt(0) == '-')) {
throw new FOPException("you must specify the mif output file");
} else {
outfile = new File(args[i + 1]);
@@ -182,7 +183,7 @@ public class CommandLineOptions {
}
} else if (args[i].equals("-print")) {
setOutputMode(PRINT_OUTPUT);
- //show print help
+ // show print help
if (i + 1 < args.length) {
if (args[i + 1].equals("help")) {
printUsagePrintOutput();
@@ -191,41 +192,41 @@ public class CommandLineOptions {
}
} else if (args[i].equals("-pcl")) {
setOutputMode(PCL_OUTPUT);
- if ((i + 1 == args.length) ||
- (args[i + 1].charAt(0) == '-')) {
+ if ((i + 1 == args.length)
+ || (args[i + 1].charAt(0) == '-')) {
throw new FOPException("you must specify the pdf output file");
} else {
- outfile = new File (args[i + 1]);
+ outfile = new File(args[i + 1]);
i++;
}
} else if (args[i].equals("-ps")) {
setOutputMode(PS_OUTPUT);
- if ((i + 1 == args.length) ||
- (args[i + 1].charAt(0) == '-')) {
+ if ((i + 1 == args.length)
+ || (args[i + 1].charAt(0) == '-')) {
throw new FOPException("you must specify the PostScript output file");
} else {
- outfile = new File (args[i + 1]);
+ outfile = new File(args[i + 1]);
i++;
}
} else if (args[i].equals("-txt")) {
setOutputMode(TXT_OUTPUT);
- if ((i + 1 == args.length) ||
- (args[i + 1].charAt(0) == '-')) {
+ if ((i + 1 == args.length)
+ || (args[i + 1].charAt(0) == '-')) {
throw new FOPException("you must specify the text output file");
} else {
- outfile = new File (args[i + 1]);
+ outfile = new File(args[i + 1]);
i++;
}
} else if (args[i].charAt(0) != '-') {
if (inputmode == NOT_SET) {
inputmode = FO_INPUT;
- fofile = new File (args[i]);
+ fofile = new File(args[i]);
} else if (outputmode == NOT_SET) {
outputmode = PDF_OUTPUT;
outfile = new File(args[i]);
} else {
- throw new FOPException(
- "Don't know what to do with " + args[i]);
+ throw new FOPException("Don't know what to do with "
+ + args[i]);
}
} else if (args[i].equals("-buf")) {
if (buffermode == NOT_SET) {
@@ -234,21 +235,21 @@ public class CommandLineOptions {
MessageHandler.errorln("ERROR: you can only set one buffer method");
printUsage();
}
- if ((i + 1 == args.length) ||
- (args[i + 1].charAt(0) == '-')) {
+ if ((i + 1 == args.length)
+ || (args[i + 1].charAt(0) == '-')) {
MessageHandler.errorln("ERROR: you must specify the buffer output file");
printUsage();
} else {
- bufferFile = new File (args[i + 1]);
+ bufferFile = new File(args[i + 1]);
i++;
}
} else if (args[i].equals("-at")) {
setOutputMode(AREA_OUTPUT);
- if ((i + 1 == args.length) ||
- (args[i + 1].charAt(0) == '-')) {
+ if ((i + 1 == args.length)
+ || (args[i + 1].charAt(0) == '-')) {
throw new FOPException("you must specify the area-tree output file");
} else {
- outfile = new File (args[i + 1]);
+ outfile = new File(args[i + 1]);
i++;
}
} else {
@@ -257,7 +258,7 @@ public class CommandLineOptions {
}
}
return true;
- } //end parseOptions
+ } // end parseOptions
private void setOutputMode(int mode) throws FOPException {
if (outputmode == NOT_SET) {
@@ -270,8 +271,7 @@ public class CommandLineOptions {
/**
* checks whether all necessary information has been given in a consistent way
*/
- private void checkSettings () throws FOPException,
- FileNotFoundException {
+ private void checkSettings() throws FOPException, FileNotFoundException {
if (inputmode == NOT_SET) {
throw new FOPException("No input file specified");
}
@@ -281,7 +281,7 @@ public class CommandLineOptions {
}
if (inputmode == XSLT_INPUT) {
- //check whether xml *and* xslt file have been set
+ // check whether xml *and* xslt file have been set
if (xmlfile == null) {
throw new FOPException("XML file must be specified for the tranform mode");
}
@@ -289,22 +289,25 @@ public class CommandLineOptions {
throw new FOPException("XSLT file must be specified for the tranform mode");
}
- //warning if fofile has been set in xslt mode
+ // warning if fofile has been set in xslt mode
if (fofile != null) {
- MessageHandler.errorln(
- "WARNING: Can't use fo file with transform mode! Ignoring.\n" +
- "Your input is "+ "\n xmlfile: " +
- xmlfile.getAbsolutePath() + "\nxsltfile: " +
- xsltfile.getAbsolutePath() + "\n fofile: " +
- fofile.getAbsolutePath());
+ MessageHandler.errorln("WARNING: Can't use fo file with transform mode! Ignoring.\n"
+ + "Your input is " + "\n xmlfile: "
+ + xmlfile.getAbsolutePath()
+ + "\nxsltfile: "
+ + xsltfile.getAbsolutePath()
+ + "\n fofile: "
+ + fofile.getAbsolutePath());
}
if (!xmlfile.exists()) {
- throw new FileNotFoundException("xml file " +
- xmlfile.getAbsolutePath() + " not found ");
+ throw new FileNotFoundException("xml file "
+ + xmlfile.getAbsolutePath()
+ + " not found ");
}
if (!xsltfile.exists()) {
- throw new FileNotFoundException("xsl file " +
- xsltfile.getAbsolutePath() + " not found ");
+ throw new FileNotFoundException("xsl file "
+ + xsltfile.getAbsolutePath()
+ + " not found ");
}
} else if (inputmode == FO_INPUT) {
@@ -314,53 +317,54 @@ public class CommandLineOptions {
MessageHandler.errorln("xslt file: " + xsltfile.toString());
}
if (!fofile.exists()) {
- throw new FileNotFoundException("fo file " +
- fofile.getAbsolutePath() + " not found ");
+ throw new FileNotFoundException("fo file "
+ + fofile.getAbsolutePath()
+ + " not found ");
}
}
- }// end checkSettings
+ } // end checkSettings
/**
- * returns the chosen renderer, throws FOPException
+ * returns the chosen renderer, throws FOPException
*/
- public int getRenderer () throws FOPException {
+ public int getRenderer() throws FOPException {
switch (outputmode) {
- case NOT_SET:
- throw new FOPException("Renderer has not been set!");
- case PDF_OUTPUT:
- return Driver.RENDER_PDF;
- case AWT_OUTPUT:
- return Driver.RENDER_AWT;
- case MIF_OUTPUT:
- return Driver.RENDER_MIF;
- case PRINT_OUTPUT:
- return Driver.RENDER_PRINT;
- case PCL_OUTPUT:
- return Driver.RENDER_PCL;
- case PS_OUTPUT:
- return Driver.RENDER_PS;
- case TXT_OUTPUT:
- return Driver.RENDER_TXT;
- case AREA_OUTPUT:
- rendererOptions.put("fineDetail", isCoarseAreaXml());
- return Driver.RENDER_XML;
- default:
- throw new FOPException("Invalid Renderer setting!");
+ case NOT_SET:
+ throw new FOPException("Renderer has not been set!");
+ case PDF_OUTPUT:
+ return Driver.RENDER_PDF;
+ case AWT_OUTPUT:
+ return Driver.RENDER_AWT;
+ case MIF_OUTPUT:
+ return Driver.RENDER_MIF;
+ case PRINT_OUTPUT:
+ return Driver.RENDER_PRINT;
+ case PCL_OUTPUT:
+ return Driver.RENDER_PCL;
+ case PS_OUTPUT:
+ return Driver.RENDER_PS;
+ case TXT_OUTPUT:
+ return Driver.RENDER_TXT;
+ case AREA_OUTPUT:
+ rendererOptions.put("fineDetail", isCoarseAreaXml());
+ return Driver.RENDER_XML;
+ default:
+ throw new FOPException("Invalid Renderer setting!");
}
}
/**
*
- **/
- public InputHandler getInputHandler () {
+ */
+ public InputHandler getInputHandler() {
switch (inputmode) {
- case FO_INPUT:
- return new FOInputHandler(fofile);
- case XSLT_INPUT:
- return new XSLTInputHandler(xmlfile, xsltfile);
- default:
- return new FOInputHandler(fofile);
+ case FO_INPUT:
+ return new FOInputHandler(fofile);
+ case XSLT_INPUT:
+ return new XSLTInputHandler(xmlfile, xsltfile);
+ default:
+ return new FOInputHandler(fofile);
}
}
@@ -370,35 +374,36 @@ public class CommandLineOptions {
public Starter getStarter() throws FOPException {
switch (outputmode) {
- case AWT_OUTPUT:
- try {
- return((Starter) Class.forName(
- "org.apache.fop.apps.AWTStarter").
- getConstructor(
- new Class[]{CommandLineOptions.class}).
- newInstance(new Object[]{this}));
- } catch (Exception e) {
- if (e instanceof FOPException) {
- throw (FOPException) e;
- }
- throw new FOPException("AWTStarter could not be loaded.",e);
+ case AWT_OUTPUT:
+ try {
+ return ((Starter)Class.forName("org.apache.fop.apps.AWTStarter").getConstructor(new Class[] {
+ CommandLineOptions.class
+ }).newInstance(new Object[] {
+ this
+ }));
+ } catch (Exception e) {
+ if (e instanceof FOPException) {
+ throw (FOPException)e;
}
- case PRINT_OUTPUT:
- try {
- return((Starter) Class.forName(
- "org.apache.fop.apps.PrintStarter").
- getConstructor(
- new Class[]{CommandLineOptions.class}).
- newInstance(new Object[]{this}));
- } catch (Exception e) {
- if (e instanceof FOPException) {
- throw (FOPException) e;
- }
- throw new FOPException("PrintStarter could not be loaded.",e);
+ throw new FOPException("AWTStarter could not be loaded.", e);
+ }
+ case PRINT_OUTPUT:
+ try {
+ return ((Starter)Class.forName("org.apache.fop.apps.PrintStarter").getConstructor(new Class[] {
+ CommandLineOptions.class
+ }).newInstance(new Object[] {
+ this
+ }));
+ } catch (Exception e) {
+ if (e instanceof FOPException) {
+ throw (FOPException)e;
}
+ throw new FOPException("PrintStarter could not be loaded.",
+ e);
+ }
- default:
- return new CommandLineStarter(this);
+ default:
+ return new CommandLineStarter(this);
}
}
@@ -426,7 +431,7 @@ public class CommandLineOptions {
return outfile;
}
- public File getUserConfigFile () {
+ public File getUserConfigFile() {
return userConfigFile;
}
@@ -459,132 +464,131 @@ public class CommandLineOptions {
*/
public File getInputFile() {
switch (inputmode) {
- case FO_INPUT:
- return fofile;
- case XSLT_INPUT:
- return xmlfile;
- default:
- return fofile;
+ case FO_INPUT:
+ return fofile;
+ case XSLT_INPUT:
+ return xmlfile;
+ default:
+ return fofile;
}
}
/**
- * shows the commandline syntax including a summary of all available options and some examples
+ * shows the commandline syntax including a summary of all available options and some examples
*/
public static void printUsage() {
- MessageHandler.errorln(
- "\nUSAGE\nFop [options] [-fo|-xml] infile [-xsl file] [-awt|-pdf|-mif|-pcl|-ps|-txt|-at|-print] <outfile>\n" +
- " [OPTIONS] \n" + " -d debug mode \n" +
- " -x dump configuration settings \n" +
- " -q quiet mode \n" +
- " -c cfg.xml use additional configuration file cfg.xml\n" +
- " -l lang the language to use for user information \n" +
- " -s for area tree XML, down to block areas only\n\n" +
- " [INPUT] \n" +
- " infile xsl:fo input file (the same as the next) \n" +
- " -fo infile xsl:fo input file \n" +
- " -xml infile xml input file, must be used together with -xsl \n" +
- " -xsl stylesheet xslt stylesheet \n \n" +
- " [OUTPUT] \n" +
- " outfile input will be rendered as pdf file into outfile \n" +
- " -pdf outfile input will be rendered as pdf file (outfile req'd) \n" +
- " -awt input will be displayed on screen \n" +
- " -mif outfile input will be rendered as mif file (outfile req'd)\n" +
- " -pcl outfile input will be rendered as pcl file (outfile req'd) \n" +
- " -ps outfile input will be rendered as PostScript file (outfile req'd) \n" +
- " -txt outfile input will be rendered as text file (outfile req'd) \n" +
- " -at outfile representation of area tree as XML (outfile req'd) \n" +
- " -print input file will be rendered and sent to the printer \n" +
- " see options with \"-print help\" \n\n" +
- " [Examples]\n" + " Fop foo.fo foo.pdf \n" +
- " Fop -fo foo.fo -pdf foo.pdf (does the same as the previous line)\n" +
- " Fop -xsl foo.xsl -xml foo.xml -pdf foo.pdf\n" +
- " Fop foo.fo -mif foo.mif\n" +
- " Fop foo.fo -print or Fop -print foo.fo \n" + " Fop foo.fo -awt \n");
+ MessageHandler.errorln("\nUSAGE\nFop [options] [-fo|-xml] infile [-xsl file] [-awt|-pdf|-mif|-pcl|-ps|-txt|-at|-print] <outfile>\n"
+ + " [OPTIONS] \n"
+ + " -d debug mode \n"
+ + " -x dump configuration settings \n"
+ + " -q quiet mode \n"
+ + " -c cfg.xml use additional configuration file cfg.xml\n"
+ + " -l lang the language to use for user information \n"
+ + " -s for area tree XML, down to block areas only\n\n"
+ + " [INPUT] \n"
+ + " infile xsl:fo input file (the same as the next) \n"
+ + " -fo infile xsl:fo input file \n"
+ + " -xml infile xml input file, must be used together with -xsl \n"
+ + " -xsl stylesheet xslt stylesheet \n \n"
+ + " [OUTPUT] \n"
+ + " outfile input will be rendered as pdf file into outfile \n"
+ + " -pdf outfile input will be rendered as pdf file (outfile req'd) \n"
+ + " -awt input will be displayed on screen \n"
+ + " -mif outfile input will be rendered as mif file (outfile req'd)\n"
+ + " -pcl outfile input will be rendered as pcl file (outfile req'd) \n"
+ + " -ps outfile input will be rendered as PostScript file (outfile req'd) \n"
+ + " -txt outfile input will be rendered as text file (outfile req'd) \n"
+ + " -at outfile representation of area tree as XML (outfile req'd) \n"
+ + " -print input file will be rendered and sent to the printer \n"
+ + " see options with \"-print help\" \n\n"
+ + " [Examples]\n" + " Fop foo.fo foo.pdf \n"
+ + " Fop -fo foo.fo -pdf foo.pdf (does the same as the previous line)\n"
+ + " Fop -xsl foo.xsl -xml foo.xml -pdf foo.pdf\n"
+ + " Fop foo.fo -mif foo.mif\n"
+ + " Fop foo.fo -print or Fop -print foo.fo \n"
+ + " Fop foo.fo -awt \n");
}
/**
- * shows the options for print output
+ * shows the options for print output
*/
public void printUsagePrintOutput() {
- MessageHandler.errorln(
- "USAGE: -print [-Dstart=i] [-Dend=i] [-Dcopies=i] [-Deven=true|false] " +
- " org.apache.fop.apps.Fop (..) -print \n" +
- "Example:\n" + "java -Dstart=1 -Dend=2 org.apache.Fop.apps.Fop infile.fo -print ");
+ MessageHandler.errorln("USAGE: -print [-Dstart=i] [-Dend=i] [-Dcopies=i] [-Deven=true|false] "
+ + " org.apache.fop.apps.Fop (..) -print \n"
+ + "Example:\n"
+ + "java -Dstart=1 -Dend=2 org.apache.Fop.apps.Fop infile.fo -print ");
}
/**
* debug mode. outputs all commandline settings
*/
- private void debug () {
+ private void debug() {
System.out.print("Input mode: ");
switch (inputmode) {
- case NOT_SET:
- MessageHandler.logln("not set");
- break;
- case FO_INPUT:
- MessageHandler.logln("FO ");
- MessageHandler.logln("fo input file: " + fofile.toString());
- break;
- case XSLT_INPUT:
- MessageHandler.logln("xslt transformation");
- MessageHandler.logln("xml input file: " +
- xmlfile.toString());
- MessageHandler.logln("xslt stylesheet: " +
- xsltfile.toString());
- break;
- default:
- MessageHandler.logln("unknown input type");
+ case NOT_SET:
+ MessageHandler.logln("not set");
+ break;
+ case FO_INPUT:
+ MessageHandler.logln("FO ");
+ MessageHandler.logln("fo input file: " + fofile.toString());
+ break;
+ case XSLT_INPUT:
+ MessageHandler.logln("xslt transformation");
+ MessageHandler.logln("xml input file: " + xmlfile.toString());
+ MessageHandler.logln("xslt stylesheet: " + xsltfile.toString());
+ break;
+ default:
+ MessageHandler.logln("unknown input type");
}
System.out.print("Output mode: ");
switch (outputmode) {
- case NOT_SET:
- MessageHandler.logln("not set");
- break;
- case PDF_OUTPUT:
- MessageHandler.logln("pdf");
- MessageHandler.logln("output file: " + outfile.toString());
- break;
- case AWT_OUTPUT:
- MessageHandler.logln("awt on screen");
- if (outfile != null) {
- MessageHandler.logln("ERROR: awt mode, but outfile is set:");
- MessageHandler.logln("out file: " + outfile.toString());
- }
- break;
- case MIF_OUTPUT:
- MessageHandler.logln("mif");
- MessageHandler.logln("output file: " + outfile.toString());
- break;
- case PRINT_OUTPUT:
- MessageHandler.logln("print directly");
- if (outfile != null) {
- MessageHandler.logln("ERROR: print mode, but outfile is set:");
- MessageHandler.logln("out file: " + outfile.toString());
- }
- break;
- case PCL_OUTPUT:
- MessageHandler.logln("pcl");
- MessageHandler.logln("output file: " + outfile.toString());
- break;
- case PS_OUTPUT:
- MessageHandler.logln("PostScript");
- MessageHandler.logln("output file: " + outfile.toString());
- break;
- case TXT_OUTPUT:
- MessageHandler.logln("txt");
- MessageHandler.logln("output file: " + outfile.toString());
- break;
- default:
- MessageHandler.logln("unknown input type");
+ case NOT_SET:
+ MessageHandler.logln("not set");
+ break;
+ case PDF_OUTPUT:
+ MessageHandler.logln("pdf");
+ MessageHandler.logln("output file: " + outfile.toString());
+ break;
+ case AWT_OUTPUT:
+ MessageHandler.logln("awt on screen");
+ if (outfile != null) {
+ MessageHandler.logln("ERROR: awt mode, but outfile is set:");
+ MessageHandler.logln("out file: " + outfile.toString());
+ }
+ break;
+ case MIF_OUTPUT:
+ MessageHandler.logln("mif");
+ MessageHandler.logln("output file: " + outfile.toString());
+ break;
+ case PRINT_OUTPUT:
+ MessageHandler.logln("print directly");
+ if (outfile != null) {
+ MessageHandler.logln("ERROR: print mode, but outfile is set:");
+ MessageHandler.logln("out file: " + outfile.toString());
+ }
+ break;
+ case PCL_OUTPUT:
+ MessageHandler.logln("pcl");
+ MessageHandler.logln("output file: " + outfile.toString());
+ break;
+ case PS_OUTPUT:
+ MessageHandler.logln("PostScript");
+ MessageHandler.logln("output file: " + outfile.toString());
+ break;
+ case TXT_OUTPUT:
+ MessageHandler.logln("txt");
+ MessageHandler.logln("output file: " + outfile.toString());
+ break;
+ default:
+ MessageHandler.logln("unknown input type");
}
MessageHandler.logln("OPTIONS");
if (userConfigFile != null) {
- MessageHandler.logln("user configuration file: " +
- userConfigFile.toString());
+ MessageHandler.logln("user configuration file: "
+ + userConfigFile.toString());
} else {
MessageHandler.logln("no user configuration file is used [default]");
}
@@ -606,19 +610,21 @@ public class CommandLineOptions {
}
- //debug: create class and output all settings
- public static void main (String args[]) {
+ // debug: create class and output all settings
+ public static void main(String args[]) {
/*
- for (int i = 0; i < args.length; i++) {
- MessageHandler.logln(">"+args[i]+"<");
- }*/
+ * for (int i = 0; i < args.length; i++) {
+ * MessageHandler.logln(">"+args[i]+"<");
+ * }
+ */
try {
- CommandLineOptions options = new CommandLineOptions (args);
+ CommandLineOptions options = new CommandLineOptions(args);
} catch (Exception e) {
e.printStackTrace();
}
- //options.debug();
+ // options.debug();
}
+
}
diff --git a/src/org/apache/fop/apps/CommandLineStarter.java b/src/org/apache/fop/apps/CommandLineStarter.java
index 7565df347..648365826 100644
--- a/src/org/apache/fop/apps/CommandLineStarter.java
+++ b/src/org/apache/fop/apps/CommandLineStarter.java
@@ -1,3 +1,10 @@
+/*
+ * $Id$
+ * Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
+ * For details on use and redistribution please refer to the
+ * LICENSE file included with these sources.
+ */
+
package org.apache.fop.apps;
// SAX
@@ -16,58 +23,55 @@ import org.apache.fop.messaging.MessageHandler;
import org.apache.fop.configuration.Configuration;
/**
- * super class for all classes which start Fop from the commandline
+ * super class for all classes which start Fop from the commandline
*/
public class CommandLineStarter extends Starter {
-
+
CommandLineOptions commandLineOptions;
- boolean errorDump;
-
- public CommandLineStarter (CommandLineOptions commandLineOptions)
- throws FOPException
- {
+ boolean errorDump;
+
+ public CommandLineStarter(CommandLineOptions commandLineOptions)
+ throws FOPException {
this.commandLineOptions = commandLineOptions;
- options.setCommandLineOptions(commandLineOptions);
- errorDump = Configuration.getBooleanValue("debugMode").booleanValue();
- super.setInputHandler(commandLineOptions.getInputHandler());
+ options.setCommandLineOptions(commandLineOptions);
+ errorDump = Configuration.getBooleanValue("debugMode").booleanValue();
+ super.setInputHandler(commandLineOptions.getInputHandler());
}
-
+
/**
* Run the format.
* @exception FOPException if there is an error during processing
*/
- public void run()
- throws FOPException
- {
+ public void run() throws FOPException {
String version = Version.getVersion();
MessageHandler.logln(version);
XMLReader parser = inputHandler.getParser();
setParserFeatures(parser);
-
- Driver driver = new Driver();
- driver.setBufferFile(commandLineOptions.getBufferFile());
+
+ Driver driver = new Driver();
+ driver.setBufferFile(commandLineOptions.getBufferFile());
if (errorDump) {
driver.setErrorDump(true);
}
-
+
try {
driver.setRenderer(commandLineOptions.getRenderer());
- driver.getRenderer().setOptions(commandLineOptions.getRendererOptions());
+ driver.getRenderer().setOptions(commandLineOptions.getRendererOptions());
driver.buildFOTree(parser, inputHandler.getInputSource());
driver.format();
driver.setOutputStream(new FileOutputStream(commandLineOptions.getOutputFile()));
driver.render();
System.exit(0);
} catch (Exception e) {
- if (e instanceof FOPException) {
- throw (FOPException) e;
- }
- throw new FOPException(e);
- }
+ if (e instanceof FOPException) {
+ throw (FOPException)e;
+ }
+ throw new FOPException(e);
+ }
}
-
+
}
diff --git a/src/org/apache/fop/apps/Driver.java b/src/org/apache/fop/apps/Driver.java
index b263e2d99..60c250176 100644
--- a/src/org/apache/fop/apps/Driver.java
+++ b/src/org/apache/fop/apps/Driver.java
@@ -1,4 +1,5 @@
-/* $Id$
+/*
+ * $Id$
* Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
* For details on use and redistribution please refer to the
* LICENSE file included with these sources.
@@ -47,12 +48,11 @@ import java.util.*;
* Here is an example use of Driver which outputs PDF:
*
* <PRE>
- * Driver driver = new Driver(new InputSource (args[0]),
- * new FileOutputStream(args[1]));
- * driver.setRenderer(RENDER_PDF);
- * driver.run();
+ * Driver driver = new Driver(new InputSource (args[0]),
+ * new FileOutputStream(args[1]));
+ * driver.setRenderer(RENDER_PDF);
+ * driver.run();
* </PRE>
-
* If neccessary, calling classes can call into the lower level
* methods to setup and
* render. Methods can be called to set the
@@ -78,76 +78,109 @@ import java.util.*;
* Here is an example use of Driver which outputs to AWT:
*
* <PRE>
- * Driver driver = new Driver();
- * driver.setRenderer(new org.apache.fop.render.awt.AWTRenderer(translator));
- * driver.buildFOTree(parser, fileInputSource(args[0]));
- * driver.format();
- * driver.render();
+ * Driver driver = new Driver();
+ * driver.setRenderer(new org.apache.fop.render.awt.AWTRenderer(translator));
+ * driver.buildFOTree(parser, fileInputSource(args[0]));
+ * driver.format();
+ * driver.render();
* </PRE>
*/
public class Driver {
- /** Render to PDF. OutputStream must be set */
+ /**
+ * Render to PDF. OutputStream must be set
+ */
public static final int RENDER_PDF = 1;
- /** Render to a GUI window. No OutputStream neccessary */
+ /**
+ * Render to a GUI window. No OutputStream neccessary
+ */
public static final int RENDER_AWT = 2;
- /** Render to MIF. OutputStream must be set */
+ /**
+ * Render to MIF. OutputStream must be set
+ */
public static final int RENDER_MIF = 3;
- /** Render to XML. OutputStream must be set */
+ /**
+ * Render to XML. OutputStream must be set
+ */
public static final int RENDER_XML = 4;
- /** Render to PRINT. No OutputStream neccessary */
+ /**
+ * Render to PRINT. No OutputStream neccessary
+ */
public static final int RENDER_PRINT = 5;
- /** Render to PCL. OutputStream must be set */
+ /**
+ * Render to PCL. OutputStream must be set
+ */
public static final int RENDER_PCL = 6;
- /** Render to Postscript. OutputStream must be set */
+ /**
+ * Render to Postscript. OutputStream must be set
+ */
public static final int RENDER_PS = 7;
- /** Render to Text. OutputStream must be set */
+ /**
+ * Render to Text. OutputStream must be set
+ */
public static final int RENDER_TXT = 8;
- /** the FO tree builder */
+ /**
+ * the FO tree builder
+ */
private FOTreeBuilder _treeBuilder;
- /** the area tree that is the result of formatting the FO tree */
+ /**
+ * the area tree that is the result of formatting the FO tree
+ */
private AreaTree _areaTree;
- /** the renderer to use to output the area tree */
+ /**
+ * the renderer to use to output the area tree
+ */
private Renderer _renderer;
- /** the source of the FO file */
+ /**
+ * the source of the FO file
+ */
private InputSource _source;
- /** the stream to use to output the results of the renderer */
+ /**
+ * the stream to use to output the results of the renderer
+ */
private OutputStream _stream;
- /** The XML parser to use when building the FO tree */
+ /**
+ * The XML parser to use when building the FO tree
+ */
private XMLReader _reader;
- /** If true, full error stacks are reported */
+ /**
+ * If true, full error stacks are reported
+ */
private boolean _errorDump = false;
- /** the system resources that FOP will use */
+ /**
+ * the system resources that FOP will use
+ */
private BufferManager _bufferManager;
public static final String getParserClassName() {
String parserClassName = null;
try {
parserClassName = System.getProperty("org.xml.sax.parser");
- } catch(SecurityException se) {
- }
+ } catch (SecurityException se) {}
if (parserClassName == null) {
parserClassName = "org.apache.xerces.parsers.SAXParser";
}
return parserClassName;
}
- /** create a new Driver */
+ /**
+ * create a new Driver
+ */
public Driver() {
_stream = null;
_bufferManager = new BufferManager();
@@ -173,7 +206,7 @@ public class Driver {
}
public boolean hasData() {
- return(_treeBuilder.hasData());
+ return (_treeBuilder.hasData());
}
/**
@@ -221,14 +254,14 @@ public class Driver {
addElementMapping("org.apache.fop.extensions.ExtensionElementMapping");
// add mappings from available services
- Enumeration providers = Service.providers(org.apache.fop.fo.ElementMapping.class);
+ Enumeration providers =
+ Service.providers(org.apache.fop.fo.ElementMapping.class);
if (providers != null) {
- while(providers.hasMoreElements()) {
+ while (providers.hasMoreElements()) {
String str = (String)providers.nextElement();
try {
addElementMapping(str);
- } catch (IllegalArgumentException e) {
- }
+ } catch (IllegalArgumentException e) {}
}
}
}
@@ -236,42 +269,42 @@ public class Driver {
/**
* Set the rendering type to use. Must be one of
* <ul>
- * <li>RENDER_PDF
- * <li>RENDER_AWT
- * <li>RENDER_MIF
- * <li>RENDER_XML
- * <li>RENDER_PCL
- * <li>RENDER_PS
- * <li>RENDER_TXT
+ * <li>RENDER_PDF
+ * <li>RENDER_AWT
+ * <li>RENDER_MIF
+ * <li>RENDER_XML
+ * <li>RENDER_PCL
+ * <li>RENDER_PS
+ * <li>RENDER_TXT
* </ul>
* @param renderer the type of renderer to use
*/
public void setRenderer(int renderer) throws IllegalArgumentException {
switch (renderer) {
- case RENDER_PDF:
- setRenderer(new org.apache.fop.render.pdf.PDFRenderer());
- break;
- case RENDER_AWT:
- throw new IllegalArgumentException("Use renderer form of setRenderer() for AWT");
- case RENDER_PRINT:
- throw new IllegalArgumentException("Use renderer form of setRenderer() for PRINT");
- case RENDER_PCL:
- setRenderer(new org.apache.fop.render.pcl.PCLRenderer());
- break;
- case RENDER_PS:
- setRenderer(new org.apache.fop.render.ps.PSRenderer());
- break;
- case RENDER_TXT:
- setRenderer(new org.apache.fop.render.txt.TXTRenderer());
- break;
- case RENDER_MIF:
- setRenderer(new org.apache.fop.render.mif.MIFRenderer());
- break;
- case RENDER_XML:
- setRenderer(new org.apache.fop.render.xml.XMLRenderer());
- break;
- default:
- throw new IllegalArgumentException("Unknown renderer type");
+ case RENDER_PDF:
+ setRenderer(new org.apache.fop.render.pdf.PDFRenderer());
+ break;
+ case RENDER_AWT:
+ throw new IllegalArgumentException("Use renderer form of setRenderer() for AWT");
+ case RENDER_PRINT:
+ throw new IllegalArgumentException("Use renderer form of setRenderer() for PRINT");
+ case RENDER_PCL:
+ setRenderer(new org.apache.fop.render.pcl.PCLRenderer());
+ break;
+ case RENDER_PS:
+ setRenderer(new org.apache.fop.render.ps.PSRenderer());
+ break;
+ case RENDER_TXT:
+ setRenderer(new org.apache.fop.render.txt.TXTRenderer());
+ break;
+ case RENDER_MIF:
+ setRenderer(new org.apache.fop.render.mif.MIFRenderer());
+ break;
+ case RENDER_XML:
+ setRenderer(new org.apache.fop.render.xml.XMLRenderer());
+ break;
+ default:
+ throw new IllegalArgumentException("Unknown renderer type");
}
}
@@ -306,25 +339,23 @@ public class Driver {
* @see #setRenderer(int)
*/
public void setRenderer(String rendererClassName)
- throws IllegalArgumentException {
+ throws IllegalArgumentException {
try {
- _renderer = (Renderer) Class.forName(
- rendererClassName).newInstance();
+ _renderer =
+ (Renderer)Class.forName(rendererClassName).newInstance();
_renderer.setProducer(Version.getVersion());
} catch (ClassNotFoundException e) {
- throw new IllegalArgumentException("Could not find " +
- rendererClassName);
- }
- catch (InstantiationException e) {
- throw new IllegalArgumentException(
- "Could not instantiate " + rendererClassName);
- }
- catch (IllegalAccessException e) {
- throw new IllegalArgumentException("Could not access " +
- rendererClassName);
- }
- catch (ClassCastException e) {
- throw new IllegalArgumentException(rendererClassName + " is not a renderer");
+ throw new IllegalArgumentException("Could not find "
+ + rendererClassName);
+ } catch (InstantiationException e) {
+ throw new IllegalArgumentException("Could not instantiate "
+ + rendererClassName);
+ } catch (IllegalAccessException e) {
+ throw new IllegalArgumentException("Could not access "
+ + rendererClassName);
+ } catch (ClassCastException e) {
+ throw new IllegalArgumentException(rendererClassName
+ + " is not a renderer");
}
}
@@ -342,25 +373,23 @@ public class Driver {
* add the element mapping with the given class name
*/
public void addElementMapping(String mappingClassName)
- throws IllegalArgumentException {
+ throws IllegalArgumentException {
try {
- ElementMapping mapping = (ElementMapping) Class.forName(
- mappingClassName).newInstance();
+ ElementMapping mapping =
+ (ElementMapping)Class.forName(mappingClassName).newInstance();
addElementMapping(mapping);
} catch (ClassNotFoundException e) {
- throw new IllegalArgumentException("Could not find " +
- mappingClassName);
- }
- catch (InstantiationException e) {
- throw new IllegalArgumentException(
- "Could not instantiate " + mappingClassName);
- }
- catch (IllegalAccessException e) {
- throw new IllegalArgumentException("Could not access " +
- mappingClassName);
- }
- catch (ClassCastException e) {
- throw new IllegalArgumentException(mappingClassName + " is not an ElementMapping");
+ throw new IllegalArgumentException("Could not find "
+ + mappingClassName);
+ } catch (InstantiationException e) {
+ throw new IllegalArgumentException("Could not instantiate "
+ + mappingClassName);
+ } catch (IllegalAccessException e) {
+ throw new IllegalArgumentException("Could not access "
+ + mappingClassName);
+ } catch (ClassCastException e) {
+ throw new IllegalArgumentException(mappingClassName
+ + " is not an ElementMapping");
}
}
@@ -379,21 +408,19 @@ public class Driver {
* Build the formatting object tree using the given SAX Parser and
* SAX InputSource
*/
- public synchronized void buildFOTree(XMLReader parser,
- InputSource source)
- throws FOPException {
+ public synchronized void buildFOTree(XMLReader parser, InputSource source)
+ throws FOPException {
parser.setContentHandler(_treeBuilder);
try {
parser.parse(source);
} catch (SAXException e) {
if (e.getException() instanceof FOPException) {
- throw (FOPException) e.getException();
+ throw (FOPException)e.getException();
} else {
throw new FOPException(e);
}
- }
- catch (IOException e) {
+ } catch (IOException e) {
throw new FOPException(e);
}
}
@@ -402,7 +429,7 @@ public class Driver {
* Build the formatting object tree using the given DOM Document
*/
public synchronized void buildFOTree(Document document)
- throws FOPException {
+ throws FOPException {
try {
DocumentInputSource source = new DocumentInputSource(document);
DocumentReader reader = new DocumentReader();
@@ -410,8 +437,7 @@ public class Driver {
reader.parse(source);
} catch (SAXException e) {
throw new FOPException(e);
- }
- catch (IOException e) {
+ } catch (IOException e) {
throw new FOPException(e);
}
@@ -424,13 +450,13 @@ public class Driver {
if (_errorDump) {
if (e instanceof SAXException) {
e.printStackTrace();
- if (((SAXException) e).getException() != null) {
- ((SAXException) e).getException().printStackTrace();
+ if (((SAXException)e).getException() != null) {
+ ((SAXException)e).getException().printStackTrace();
}
} else if (e instanceof FOPException) {
e.printStackTrace();
- if (((FOPException) e).getException() != null) {
- ((FOPException) e).getException().printStackTrace();
+ if (((FOPException)e).getException() != null) {
+ ((FOPException)e).getException().printStackTrace();
}
} else {
e.printStackTrace();
@@ -447,8 +473,7 @@ public class Driver {
/**
* format the formatting object tree into an area tree
*/
- public synchronized void format()
- throws FOPException {
+ public synchronized void format() throws FOPException {
FontInfo fontInfo = new FontInfo();
_renderer.setupFontInfo(fontInfo);
@@ -461,8 +486,7 @@ public class Driver {
/**
* render the area tree to the output form
*/
- public synchronized void render()
- throws IOException, FOPException {
+ public synchronized void render() throws IOException, FOPException {
_renderer.render(_areaTree, _stream);
}
@@ -470,8 +494,7 @@ public class Driver {
* Runs the formatting and renderering process using the previously set
* inputsource and outputstream
*/
- public synchronized void run()
- throws IOException, FOPException {
+ public synchronized void run() throws IOException, FOPException {
if (_renderer == null) {
setRenderer(RENDER_PDF);
}
@@ -491,11 +514,13 @@ public class Driver {
format();
render();
}
+
}
// code stolen from org.apache.batik.util and modified slightly
// does what sun.misc.Service probably does, but it cannot be relied on.
// hopefully will be part of standard jdk sometime.
+
/**
* This class loads services present in the class path.
*/
@@ -505,7 +530,7 @@ class Service {
public static synchronized Enumeration providers(Class cls) {
ClassLoader cl = cls.getClassLoader();
- String serviceFile = "META-INF/services/"+cls.getName();
+ String serviceFile = "META-INF/services/" + cls.getName();
// System.out.println("File: " + serviceFile);
@@ -528,8 +553,8 @@ class Service {
java.net.URL u = (java.net.URL)e.nextElement();
// System.out.println("URL: " + u);
- InputStream is = u.openStream();
- Reader r = new InputStreamReader(is, "UTF-8");
+ InputStream is = u.openStream();
+ Reader r = new InputStreamReader(is, "UTF-8");
BufferedReader br = new BufferedReader(r);
String line = br.readLine();
@@ -540,7 +565,7 @@ class Service {
if (idx != -1)
line = line.substring(0, idx);
- // Trim whitespace.
+ // Trim whitespace.
line = line.trim();
// If nothing left then loop around...
@@ -551,7 +576,7 @@ class Service {
// System.out.println("Line: " + line);
// Try and load the class
- //Object obj = cl.loadClass(line).newInstance();
+ // Object obj = cl.loadClass(line).newInstance();
// stick it into our vector...
v.add(line);
} catch (Exception ex) {
@@ -565,5 +590,6 @@ class Service {
}
return v.elements();
}
+
}
diff --git a/src/org/apache/fop/apps/ErrorHandler.java b/src/org/apache/fop/apps/ErrorHandler.java
index 79c889897..d559c9357 100644
--- a/src/org/apache/fop/apps/ErrorHandler.java
+++ b/src/org/apache/fop/apps/ErrorHandler.java
@@ -1,54 +1,13 @@
-/*-- $Id$ --
-
- ============================================================================
- 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/>.
-
+/*
+ * $Id$
+ * Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
+ * For details on use and redistribution please refer to the
+ * LICENSE file included with these sources.
*/
+
package org.apache.fop.apps;
-/** not implemented yet */
+/**
+ * not implemented yet
+ */
public interface ErrorHandler {}
diff --git a/src/org/apache/fop/apps/FOInputHandler.java b/src/org/apache/fop/apps/FOInputHandler.java
index 5fd055a4c..f2828dd20 100644
--- a/src/org/apache/fop/apps/FOInputHandler.java
+++ b/src/org/apache/fop/apps/FOInputHandler.java
@@ -1,4 +1,5 @@
-/* $Id$
+/*
+ * $Id$
* Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
* For details on use and redistribution please refer to the
* LICENSE file included with these sources.
@@ -10,10 +11,10 @@ package org.apache.fop.apps;
import org.xml.sax.InputSource;
import org.xml.sax.XMLReader;
-//fop
+// fop
import org.apache.fop.messaging.MessageHandler;
-//java
+// java
import java.io.File;
/**
@@ -22,16 +23,17 @@ import java.io.File;
public class FOInputHandler extends InputHandler {
File fofile;
- public FOInputHandler (File fofile) {
+ public FOInputHandler(File fofile) {
this.fofile = fofile;
}
- public InputSource getInputSource () {
+ public InputSource getInputSource() {
return super.fileInputSource(fofile);
}
public XMLReader getParser() throws FOPException {
return super.createParser();
}
+
}
diff --git a/src/org/apache/fop/apps/FOPException.java b/src/org/apache/fop/apps/FOPException.java
index 765d9eede..f6391ce6c 100644
--- a/src/org/apache/fop/apps/FOPException.java
+++ b/src/org/apache/fop/apps/FOPException.java
@@ -1,6 +1,7 @@
-/*
+/*
+ * $Id$
* Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
- * For details on use and redistribution please refer to the
+ * For details on use and redistribution please refer to the
* LICENSE file included with these sources."
*/
@@ -15,9 +16,9 @@ import org.xml.sax.SAXException;
public class FOPException extends Exception {
private static final String EXCEPTION_SEPARATOR = "\n---------\n";
-
+
private Throwable _exception;
-
+
/**
* create a new FOP Exception
*
@@ -26,86 +27,82 @@ public class FOPException extends Exception {
public FOPException(String message) {
super(message);
}
+
public FOPException(Throwable e) {
super(e.getMessage());
- setException(e);
+ setException(e);
}
-
+
public FOPException(String message, Throwable e) {
super(message);
- setException(e);
+ setException(e);
}
-
- protected void setException(Throwable t)
- {
- _exception = t;
+
+ protected void setException(Throwable t) {
+ _exception = t;
}
-
- public Throwable getException()
- {
- return _exception;
+
+ public Throwable getException() {
+ return _exception;
}
- protected Throwable getRootException()
- {
- Throwable result = _exception;
-
- if (result instanceof SAXException) {
- result = ((SAXException)result).getException();
- }
- if (result instanceof java.lang.reflect.InvocationTargetException) {
- result = ((java.lang.reflect.InvocationTargetException)result).getTargetException();
- }
- if (result != _exception) {
- return result;
- }
- return null;
+ protected Throwable getRootException() {
+ Throwable result = _exception;
+
+ if (result instanceof SAXException) {
+ result = ((SAXException)result).getException();
+ }
+ if (result instanceof java.lang.reflect.InvocationTargetException) {
+ result =
+ ((java.lang.reflect.InvocationTargetException)result).getTargetException();
+ }
+ if (result != _exception) {
+ return result;
+ }
+ return null;
}
-
-
- public void printStackTrace()
- {
- synchronized (System.err) {
- super.printStackTrace();
- if (_exception != null) {
- System.err.println(EXCEPTION_SEPARATOR);
- _exception.printStackTrace();
- }
- if (getRootException() != null) {
- System.err.println(EXCEPTION_SEPARATOR);
- getRootException().printStackTrace();
- }
- }
+
+
+ public void printStackTrace() {
+ synchronized (System.err) {
+ super.printStackTrace();
+ if (_exception != null) {
+ System.err.println(EXCEPTION_SEPARATOR);
+ _exception.printStackTrace();
+ }
+ if (getRootException() != null) {
+ System.err.println(EXCEPTION_SEPARATOR);
+ getRootException().printStackTrace();
+ }
+ }
}
-
- public void printStackTrace(java.io.PrintStream stream)
- {
- synchronized (stream) {
- super.printStackTrace(stream);
- if (_exception != null) {
- stream.println(EXCEPTION_SEPARATOR);
- _exception.printStackTrace(stream);
- }
- if (getRootException() != null) {
- System.err.println(EXCEPTION_SEPARATOR);
- getRootException().printStackTrace(stream);
- }
- }
+
+ public void printStackTrace(java.io.PrintStream stream) {
+ synchronized (stream) {
+ super.printStackTrace(stream);
+ if (_exception != null) {
+ stream.println(EXCEPTION_SEPARATOR);
+ _exception.printStackTrace(stream);
+ }
+ if (getRootException() != null) {
+ System.err.println(EXCEPTION_SEPARATOR);
+ getRootException().printStackTrace(stream);
+ }
+ }
}
-
- public void printStackTrace(java.io.PrintWriter writer)
- {
- synchronized (writer) {
- super.printStackTrace(writer);
- if (_exception != null) {
- writer.println(EXCEPTION_SEPARATOR);
- _exception.printStackTrace(writer);
- }
- if (getRootException() != null) {
- System.err.println(EXCEPTION_SEPARATOR);
- getRootException().printStackTrace(writer);
- }
- }
+
+ public void printStackTrace(java.io.PrintWriter writer) {
+ synchronized (writer) {
+ super.printStackTrace(writer);
+ if (_exception != null) {
+ writer.println(EXCEPTION_SEPARATOR);
+ _exception.printStackTrace(writer);
+ }
+ if (getRootException() != null) {
+ System.err.println(EXCEPTION_SEPARATOR);
+ getRootException().printStackTrace(writer);
+ }
+ }
}
-
+
}
diff --git a/src/org/apache/fop/apps/Fop.java b/src/org/apache/fop/apps/Fop.java
index 801bf8a81..b4ae7d708 100644
--- a/src/org/apache/fop/apps/Fop.java
+++ b/src/org/apache/fop/apps/Fop.java
@@ -1,4 +1,5 @@
-/* $Id$
+/*
+ * $Id$
* Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
* For details on use and redistribution please refer to the
* LICENSE file included with these sources.
@@ -9,21 +10,20 @@ package org.apache.fop.apps;
import org.apache.fop.messaging.MessageHandler;
public class Fop {
- public static void main (String [] args) {
+ public static void main(String[] args) {
CommandLineOptions options = null;
try {
- options = new CommandLineOptions (args);
+ options = new CommandLineOptions(args);
Starter starter = options.getStarter();
starter.run();
} catch (FOPException e) {
- MessageHandler.errorln("ERROR: "+e.getMessage());
+ MessageHandler.errorln("ERROR: " + e.getMessage());
if (options != null && options.isDebugMode().booleanValue()) {
e.printStackTrace();
}
- }
- catch (java.io.FileNotFoundException e) {
- MessageHandler.errorln("ERROR: "+e.getMessage());
+ } catch (java.io.FileNotFoundException e) {
+ MessageHandler.errorln("ERROR: " + e.getMessage());
if (options != null && options.isDebugMode().booleanValue()) {
e.printStackTrace();
}
diff --git a/src/org/apache/fop/apps/InputHandler.java b/src/org/apache/fop/apps/InputHandler.java
index 731e375e9..fe2d7cd7a 100644
--- a/src/org/apache/fop/apps/InputHandler.java
+++ b/src/org/apache/fop/apps/InputHandler.java
@@ -1,4 +1,5 @@
-/* $Id$
+/*
+ * $Id$
* Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
* For details on use and redistribution please refer to the
* LICENSE file included with these sources.
@@ -61,22 +62,19 @@ abstract public class InputHandler {
MessageHandler.logln("using SAX parser " + parserClassName);
try {
- return (XMLReader) Class.forName(
- parserClassName).newInstance();
+ return (XMLReader)Class.forName(parserClassName).newInstance();
} catch (ClassNotFoundException e) {
throw new FOPException(e);
- }
- catch (InstantiationException e) {
- throw new FOPException("Could not instantiate " +
- parserClassName, e);
- }
- catch (IllegalAccessException e) {
- throw new FOPException("Could not access " +
- parserClassName, e);
- }
- catch (ClassCastException e) {
- throw new FOPException(parserClassName + " is not a SAX driver",e);
+ } catch (InstantiationException e) {
+ throw new FOPException("Could not instantiate "
+ + parserClassName, e);
+ } catch (IllegalAccessException e) {
+ throw new FOPException("Could not access " + parserClassName, e);
+ } catch (ClassCastException e) {
+ throw new FOPException(parserClassName + " is not a SAX driver",
+ e);
}
}
+
}
diff --git a/src/org/apache/fop/apps/Options.java b/src/org/apache/fop/apps/Options.java
index 9f65b4c78..a6e16f31b 100644
--- a/src/org/apache/fop/apps/Options.java
+++ b/src/org/apache/fop/apps/Options.java
@@ -1,4 +1,5 @@
-/* $Id$
+/*
+ * $Id$
* Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
* For details on use and redistribution please refer to the
* LICENSE file included with these sources.
@@ -6,100 +7,95 @@
package org.apache.fop.apps;
-//sax
+// sax
import org.xml.sax.InputSource;
-//java
+// java
import java.io.File;
import java.io.InputStream;
-//fop
+// fop
import org.apache.fop.messaging.MessageHandler;
import org.apache.fop.configuration.Configuration;
import org.apache.fop.configuration.ConfigurationReader;
/**
- * Options handles loading of configuration files and
- * additional setting of commandline options
+ * Options handles loading of configuration files and
+ * additional setting of commandline options
*/
public class Options {
boolean errorDump = false;
- public Options () throws FOPException {
+ public Options() throws FOPException {
this.loadStandardConfiguration();
- initOptions ();
+ initOptions();
}
- public Options (File userConfigFile) throws FOPException {
+ public Options(File userConfigFile) throws FOPException {
this();
this.loadUserconfiguration(userConfigFile);
}
- public Options (CommandLineOptions clOptions) throws FOPException
- {
+ public Options(CommandLineOptions clOptions) throws FOPException {
this();
this.setCommandLineOptions(clOptions);
}
- //initializing option settings
- void initOptions () {
+ // initializing option settings
+ void initOptions() {
if (Configuration.getBooleanValue("quiet").booleanValue()) {
MessageHandler.setQuiet(true);
}
if (Configuration.getBooleanValue("debugMode").booleanValue()) {
errorDump = true;
}
- if (Configuration.getBooleanValue(
- "dumpConfiguration").booleanValue()) {
- Configuration.put("dumpConfiguration","true");
+ if (Configuration.getBooleanValue("dumpConfiguration").booleanValue()) {
+ Configuration.put("dumpConfiguration", "true");
Configuration.dumpConfiguration();
}
}
- //setting clOptions
+ // setting clOptions
void setCommandLineOptions(CommandLineOptions clOptions) {
- //load user configuration file,if there is one
+ // load user configuration file,if there is one
File userConfigFile = clOptions.getUserConfigFile();
if (userConfigFile != null) {
this.loadUserconfiguration(userConfigFile);
}
- //debug mode
+ // debug mode
if (clOptions.isDebugMode() != null) {
errorDump = clOptions.isDebugMode().booleanValue();
- Configuration.put("debugMode",new Boolean(errorDump));
+ Configuration.put("debugMode", new Boolean(errorDump));
}
- //show configuration settings
+ // show configuration settings
boolean dumpConfiguration;
if (clOptions.dumpConfiguration() != null) {
- dumpConfiguration =
- clOptions.dumpConfiguration().booleanValue();
+ dumpConfiguration = clOptions.dumpConfiguration().booleanValue();
} else {
- dumpConfiguration = Configuration.getBooleanValue(
- "dumpConfiguration").booleanValue();
+ dumpConfiguration =
+ Configuration.getBooleanValue("dumpConfiguration").booleanValue();
}
if (dumpConfiguration) {
- Configuration.put("dumpConfiguration","true");
+ Configuration.put("dumpConfiguration", "true");
Configuration.dumpConfiguration();
System.exit(0);
}
- //quiet mode
+ // quiet mode
if (clOptions.isQuiet() != null) {
MessageHandler.setQuiet(clOptions.isQuiet().booleanValue());
}
- //set base directory
+ // set base directory
String baseDir = Configuration.getStringValue("baseDir");
if (baseDir == null) {
try {
- baseDir = new File(
- clOptions.getInputFile().getAbsolutePath()).
- getParentFile().toURL().toExternalForm();
+ baseDir =
+ new File(clOptions.getInputFile().getAbsolutePath()).getParentFile().toURL().toExternalForm();
Configuration.put("baseDir", baseDir);
- } catch (Exception e) {
- }
+ } catch (Exception e) {}
}
if (errorDump) {
MessageHandler.logln("base directory: " + baseDir);
@@ -107,7 +103,7 @@ public class Options {
}
/**
- * loads standard configuration file and a user file, if it has been specified
+ * loads standard configuration file and a user file, if it has been specified
*/
public void loadStandardConfiguration() throws FOPException {
String file = "config.xml";
@@ -116,23 +112,21 @@ public class Options {
// Try to use Context Class Loader to load the properties file.
try {
java.lang.reflect.Method getCCL =
- Thread.class.getMethod("getContextClassLoader",
- new Class[0]);
+ Thread.class.getMethod("getContextClassLoader", new Class[0]);
if (getCCL != null) {
ClassLoader contextClassLoader =
- (ClassLoader) getCCL.invoke(
- Thread.currentThread(), new Object[0]);
- configfile =
- contextClassLoader.getResourceAsStream("conf/" +
- file);
+ (ClassLoader)getCCL.invoke(Thread.currentThread(),
+ new Object[0]);
+ configfile = contextClassLoader.getResourceAsStream("conf/"
+ + file);
}
} catch (Exception e) {}
// the entry /conf/config.xml refers to a directory conf which is a sibling of org
if (configfile == null)
configfile =
- ConfigurationReader.class.getResourceAsStream("/conf/"+
- file);
+ ConfigurationReader.class.getResourceAsStream("/conf/"
+ + file);
if (configfile == null) {
throw new FOPException("can't find default configuration file");
}
@@ -140,7 +134,7 @@ public class Options {
MessageHandler.logln("reading default configuration file");
}
ConfigurationReader reader =
- new ConfigurationReader (new InputSource(configfile));
+ new ConfigurationReader(new InputSource(configfile));
if (errorDump) {
reader.setDumpError(true);
}
@@ -153,20 +147,19 @@ public class Options {
}
public void loadUserconfiguration(File userConfigFile) {
- //read user configuration file
+ // read user configuration file
if (userConfigFile != null) {
MessageHandler.logln("reading user configuration file");
- ConfigurationReader reader = new ConfigurationReader (
- InputHandler.fileInputSource(userConfigFile));
+ ConfigurationReader reader =
+ new ConfigurationReader(InputHandler.fileInputSource(userConfigFile));
if (errorDump) {
reader.setDumpError(true);
}
try {
reader.start();
} catch (org.apache.fop.apps.FOPException error) {
- MessageHandler.errorln(
- "Can't find user configuration file " +
- userConfigFile);
+ MessageHandler.errorln("Can't find user configuration file "
+ + userConfigFile);
MessageHandler.errorln("using default values");
if (errorDump) {
reader.dumpError(error);
@@ -174,6 +167,7 @@ public class Options {
}
}
}
+
}
diff --git a/src/org/apache/fop/apps/PDFOutputHandler.java b/src/org/apache/fop/apps/PDFOutputHandler.java
index aadba4b2f..0b39c67c8 100644
--- a/src/org/apache/fop/apps/PDFOutputHandler.java
+++ b/src/org/apache/fop/apps/PDFOutputHandler.java
@@ -1,3 +1,10 @@
+/*
+ * $Id$
+ * Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
+ * For details on use and redistribution please refer to the
+ * LICENSE file included with these sources.
+ */
+
package org.apache.fop.apps;
import org.xml.sax.*;
@@ -6,182 +13,201 @@ import java.io.*;
// FOP
import org.apache.fop.fo.XTFOTreeBuilder;
-import org.apache.fop.fo.XTElementMapping;
+import org.apache.fop.fo.XTElementMapping;
import org.apache.fop.layout.AreaTree;
import org.apache.fop.layout.FontInfo;
import org.apache.fop.render.Renderer;
import org.apache.fop.messaging.MessageHandler;
-//////////////////////////////////////////////////////////////////////////////////////
+// ////////////////////////////////////////////////////////////////////////////////////
+
/**
* A DocumentHandler that writes a PDF representation to an OutputStream.
- *
+ *
* Use with James Clark's XT. Just put FOP on your class path and add
- * <xsl:output method="fop:org.apache.fop.apps.PDFOutputHandler"
- * xmlns:fop="http://www.jclark.com/xt/java"/>
+ * <xsl:output method="fop:org.apache.fop.apps.PDFOutputHandler"
+ * xmlns:fop="http://www.jclark.com/xt/java"/>
* to your stylesheet. Now XT will automatically call FOP.
- *
+ *
*/
-public class PDFOutputHandler extends XTFOTreeBuilder implements OutputDocumentHandler {
-
- /** the area tree that is the result of formatting the FO tree */
- protected AreaTree areaTree;
-
- /** the renderer to use to output the area tree */
- protected Renderer renderer;
-
- /** the PrintWriter to use to output the results of the renderer */
- protected PrintWriter writer;
-
- /** the stream to use to output the results of the renderer */
- protected OutputStream stream;
-
- private boolean keepOpen;
-
- //////////////////////////////////////////////////////////////////////////////////////
- /**
- */
- public PDFOutputHandler() {
- }
-
- //////////////////////////////////////////////////////////////////////////////////////
- /**
- */
- public PDFOutputHandler(OutputStream out) {
- this();
- this.stream = out;
- }
-
- //////////////////////////////////////////////////////////////////////////////////////
- /**
- */
- public DocumentHandler init(Destination dest, AttributeList atts) throws IOException {
- this.stream = dest.getOutputStream("application/pdf", null);
- this.keepOpen = dest.keepOpen();
-
- String version = org.apache.fop.apps.Version.getVersion();
- setRenderer("org.apache.fop.render.pdf.PDFRenderer", version);
- addElementMapping("org.apache.fop.fo.StandardElementMapping");
- addElementMapping("org.apache.fop.svg.SVGElementMapping");
- return this;
- }
-
- //////////////////////////////////////////////////////////////////////////////////////
- /**
- * set the class name of the Renderer to use as well as the
- * producer string for those renderers that can make use of it
- */
- public void setRenderer(String rendererClassName, String producer) {
- this.renderer = createRenderer(rendererClassName);
- this.renderer.setProducer(producer);
- }
-
- //////////////////////////////////////////////////////////////////////////////////////
- /**
- * SAX passthrough, finish rendering the document
- */
- public void endDocument() throws SAXException {
- super.endDocument();
-
- try {
- doFormat();
- doRender();
- } catch (IOException io) {
- throw new SAXException(io);
- } catch (FOPException fop) {
- throw new SAXException(fop);
+public class PDFOutputHandler extends XTFOTreeBuilder
+ implements OutputDocumentHandler {
+
+ /**
+ * the area tree that is the result of formatting the FO tree
+ */
+ protected AreaTree areaTree;
+
+ /**
+ * the renderer to use to output the area tree
+ */
+ protected Renderer renderer;
+
+ /**
+ * the PrintWriter to use to output the results of the renderer
+ */
+ protected PrintWriter writer;
+
+ /**
+ * the stream to use to output the results of the renderer
+ */
+ protected OutputStream stream;
+
+ private boolean keepOpen;
+
+ // ////////////////////////////////////////////////////////////////////////////////////
+
+ /**
+ */
+ public PDFOutputHandler() {}
+
+ // ////////////////////////////////////////////////////////////////////////////////////
+
+ /**
+ */
+ public PDFOutputHandler(OutputStream out) {
+ this();
+ this.stream = out;
+ }
+
+ // ////////////////////////////////////////////////////////////////////////////////////
+
+ /**
+ */
+ public DocumentHandler init(Destination dest,
+ AttributeList atts) throws IOException {
+ this.stream = dest.getOutputStream("application/pdf", null);
+ this.keepOpen = dest.keepOpen();
+
+ String version = org.apache.fop.apps.Version.getVersion();
+ setRenderer("org.apache.fop.render.pdf.PDFRenderer", version);
+ addElementMapping("org.apache.fop.fo.StandardElementMapping");
+ addElementMapping("org.apache.fop.svg.SVGElementMapping");
+ return this;
+ }
+
+ // ////////////////////////////////////////////////////////////////////////////////////
+
+ /**
+ * set the class name of the Renderer to use as well as the
+ * producer string for those renderers that can make use of it
+ */
+ public void setRenderer(String rendererClassName, String producer) {
+ this.renderer = createRenderer(rendererClassName);
+ this.renderer.setProducer(producer);
}
- writer.flush();
- }
-
- //////////////////////////////////////////////////////////////////////////////////////
- /**
- * format the formatting object tree into an area tree
- */
- public void doFormat()
- throws FOPException {
- FontInfo fontInfo = new FontInfo();
- this.renderer.setupFontInfo(fontInfo);
-
- this.areaTree = new AreaTree();
- this.areaTree.setFontInfo(fontInfo);
-
- format(areaTree);
- }
-
- //////////////////////////////////////////////////////////////////////////////////////
- /**
- * render the area tree to the output form
- */
- public void doRender()
- throws IOException,FOPException {
- this.renderer.render(areaTree, this.stream);
- }
-
- //////////////////////////////////////////////////////////////////////////////////////
- /**
- * add the given element mapping.
- *
- * an element mapping maps element names to Java classes
- */
- public void addElementMapping(XTElementMapping mapping) {
- mapping.addToBuilder(this);
- }
-
- //////////////////////////////////////////////////////////////////////////////////////
- /**
- * add the element mapping with the given class name
- */
- public void addElementMapping(String mappingClassName) {
- createElementMapping(mappingClassName).addToBuilder(this);
- }
-
- //////////////////////////////////////////////////////////////////////////////////////
- /**
- * protected method used by addElementMapping(String) to
- * instantiate element mapping class
- */
- protected XTElementMapping createElementMapping(String mappingClassName) {
- MessageHandler.logln("using element mapping " + mappingClassName);
-
- try {
- return (XTElementMapping)
- Class.forName(mappingClassName).newInstance();
- } catch (ClassNotFoundException e) {
- MessageHandler.errorln("Could not find " + mappingClassName);
- } catch (InstantiationException e) {
- MessageHandler.errorln("Could not instantiate "
- + mappingClassName);
- } catch (IllegalAccessException e) {
- MessageHandler.errorln("Could not access " + mappingClassName);
- } catch (ClassCastException e) {
- MessageHandler.errorln(mappingClassName + " is not an element mapping");
+
+ // ////////////////////////////////////////////////////////////////////////////////////
+
+ /**
+ * SAX passthrough, finish rendering the document
+ */
+ public void endDocument() throws SAXException {
+ super.endDocument();
+
+ try {
+ doFormat();
+ doRender();
+ } catch (IOException io) {
+ throw new SAXException(io);
+ } catch (FOPException fop) {
+ throw new SAXException(fop);
+ }
+ writer.flush();
+ }
+
+ // ////////////////////////////////////////////////////////////////////////////////////
+
+ /**
+ * format the formatting object tree into an area tree
+ */
+ public void doFormat() throws FOPException {
+ FontInfo fontInfo = new FontInfo();
+ this.renderer.setupFontInfo(fontInfo);
+
+ this.areaTree = new AreaTree();
+ this.areaTree.setFontInfo(fontInfo);
+
+ format(areaTree);
}
- return null;
- }
-
- //////////////////////////////////////////////////////////////////////////////////////
- /**
- * protected method used by setRenderer(String, String) to
- * instantiate the Renderer class
- */
- protected Renderer createRenderer(String rendererClassName) {
- MessageHandler.logln("using renderer " + rendererClassName);
-
- try {
- return (Renderer)
- Class.forName(rendererClassName).newInstance();
- } catch (ClassNotFoundException e) {
- MessageHandler.errorln("Could not find " + rendererClassName);
- } catch (InstantiationException e) {
- MessageHandler.errorln("Could not instantiate "
- + rendererClassName);
- } catch (IllegalAccessException e) {
- MessageHandler.errorln("Could not access " + rendererClassName);
- } catch (ClassCastException e) {
- MessageHandler.errorln(rendererClassName + " is not a renderer");
+
+ // ////////////////////////////////////////////////////////////////////////////////////
+
+ /**
+ * render the area tree to the output form
+ */
+ public void doRender() throws IOException, FOPException {
+ this.renderer.render(areaTree, this.stream);
}
- return null;
- }
+
+ // ////////////////////////////////////////////////////////////////////////////////////
+
+ /**
+ * add the given element mapping.
+ *
+ * an element mapping maps element names to Java classes
+ */
+ public void addElementMapping(XTElementMapping mapping) {
+ mapping.addToBuilder(this);
+ }
+
+ // ////////////////////////////////////////////////////////////////////////////////////
+
+ /**
+ * add the element mapping with the given class name
+ */
+ public void addElementMapping(String mappingClassName) {
+ createElementMapping(mappingClassName).addToBuilder(this);
+ }
+
+ // ////////////////////////////////////////////////////////////////////////////////////
+
+ /**
+ * protected method used by addElementMapping(String) to
+ * instantiate element mapping class
+ */
+ protected XTElementMapping createElementMapping(String mappingClassName) {
+ MessageHandler.logln("using element mapping " + mappingClassName);
+
+ try {
+ return (XTElementMapping)Class.forName(mappingClassName).newInstance();
+ } catch (ClassNotFoundException e) {
+ MessageHandler.errorln("Could not find " + mappingClassName);
+ } catch (InstantiationException e) {
+ MessageHandler.errorln("Could not instantiate "
+ + mappingClassName);
+ } catch (IllegalAccessException e) {
+ MessageHandler.errorln("Could not access " + mappingClassName);
+ } catch (ClassCastException e) {
+ MessageHandler.errorln(mappingClassName
+ + " is not an element mapping");
+ }
+ return null;
+ }
+
+ // ////////////////////////////////////////////////////////////////////////////////////
+
+ /**
+ * protected method used by setRenderer(String, String) to
+ * instantiate the Renderer class
+ */
+ protected Renderer createRenderer(String rendererClassName) {
+ MessageHandler.logln("using renderer " + rendererClassName);
+
+ try {
+ return (Renderer)Class.forName(rendererClassName).newInstance();
+ } catch (ClassNotFoundException e) {
+ MessageHandler.errorln("Could not find " + rendererClassName);
+ } catch (InstantiationException e) {
+ MessageHandler.errorln("Could not instantiate "
+ + rendererClassName);
+ } catch (IllegalAccessException e) {
+ MessageHandler.errorln("Could not access " + rendererClassName);
+ } catch (ClassCastException e) {
+ MessageHandler.errorln(rendererClassName + " is not a renderer");
+ }
+ return null;
+ }
+
}
diff --git a/src/org/apache/fop/apps/PrintStarter.java b/src/org/apache/fop/apps/PrintStarter.java
index 3d2c52a0d..c50172c4d 100644
--- a/src/org/apache/fop/apps/PrintStarter.java
+++ b/src/org/apache/fop/apps/PrintStarter.java
@@ -1,4 +1,5 @@
-/* $Id$
+/*
+ * $Id$
* Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
* For details on use and redistribution please refer to the
* LICENSE file included with these sources.
@@ -7,9 +8,9 @@
package org.apache.fop.apps;
/*
- originally contributed by
- Stanislav Gorkhover: stanislav.gorkhover@jcatalog.com
- jCatalog Software AG
+ * originally contributed by
+ * Stanislav Gorkhover: stanislav.gorkhover@jcatalog.com
+ * jCatalog Software AG
*/
@@ -43,11 +44,11 @@ import org.apache.fop.messaging.MessageHandler;
*/
public class PrintStarter extends CommandLineStarter {
- public PrintStarter (CommandLineOptions options) throws FOPException {
+ public PrintStarter(CommandLineOptions options) throws FOPException {
super(options);
}
- public void run () throws FOPException {
+ public void run() throws FOPException {
Driver driver = new Driver();
if (errorDump) {
driver.setErrorDump(true);
@@ -69,7 +70,7 @@ public class PrintStarter extends CommandLineStarter {
driver.render();
} catch (Exception e) {
if (e instanceof FOPException) {
- throw (FOPException) e;
+ throw (FOPException)e;
}
throw new FOPException(e);
}
@@ -111,8 +112,7 @@ public class PrintStarter extends CommandLineStarter {
if (str != null) {
try {
mode = Boolean.valueOf(str).booleanValue() ? EVEN : ODD;
- } catch (Exception e) {
- }
+ } catch (Exception e) {}
}
}
@@ -140,14 +140,13 @@ public class PrintStarter extends CommandLineStarter {
Vector numbers = getInvalidPageNumbers();
for (int i = numbers.size() - 1; i > -1; i--)
- tree.getPages().removeElementAt(
- Integer.parseInt((String) numbers.elementAt(i)));
+ tree.getPages().removeElementAt(Integer.parseInt((String)numbers.elementAt(i)));
}
public void renderPage(Page page) {
- pageWidth = (int)((float) page.getWidth() / 1000f);
- pageHeight = (int)((float) page.getHeight() / 1000f);
+ pageWidth = (int)((float)page.getWidth() / 1000f);
+ pageHeight = (int)((float)page.getHeight() / 1000f);
super.renderPage(page);
}
@@ -184,8 +183,8 @@ public class PrintStarter extends CommandLineStarter {
}
- } // class PrintRenderer
-} // class PrintCommandLine
+ } // class PrintRenderer
+} // class PrintCommandLine
diff --git a/src/org/apache/fop/apps/Starter.java b/src/org/apache/fop/apps/Starter.java
index 130e2f1ac..c0882e93f 100644
--- a/src/org/apache/fop/apps/Starter.java
+++ b/src/org/apache/fop/apps/Starter.java
@@ -1,4 +1,5 @@
-/* $Id$
+/*
+ * $Id$
* Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
* For details on use and redistribution please refer to the
* LICENSE file included with these sources.
@@ -28,7 +29,7 @@ public abstract class Starter {
InputHandler inputHandler;
public Starter() throws FOPException {
- options = new Options ();
+ options = new Options();
}
public void setInputHandler(InputHandler inputHandler) {
@@ -37,15 +38,15 @@ public abstract class Starter {
abstract public void run() throws FOPException;
- // setting the parser features
- public void setParserFeatures (XMLReader parser) throws FOPException {
+ // setting the parser features
+ public void setParserFeatures(XMLReader parser) throws FOPException {
try {
parser.setFeature("http://xml.org/sax/features/namespace-prefixes",
true);
} catch (SAXException e) {
- throw new FOPException(
- "Error in setting up parser feature namespace-prefixes\n" +
- "You need a parser which supports SAX version 2",e);
+ throw new FOPException("Error in setting up parser feature namespace-prefixes\n"
+ + "You need a parser which supports SAX version 2", e);
}
}
+
}
diff --git a/src/org/apache/fop/apps/TraxInputHandler.java b/src/org/apache/fop/apps/TraxInputHandler.java
index 0b1e10f43..4cebd7521 100644
--- a/src/org/apache/fop/apps/TraxInputHandler.java
+++ b/src/org/apache/fop/apps/TraxInputHandler.java
@@ -1,4 +1,5 @@
-/* $Id$
+/*
+ * $Id$
* Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
* For details on use and redistribution please refer to the
* LICENSE file included with these sources.
@@ -39,21 +40,21 @@ public class TraxInputHandler extends InputHandler {
File xmlfile, xsltfile;
- public TraxInputHandler (File xmlfile, File xsltfile) {
+ public TraxInputHandler(File xmlfile, File xsltfile) {
this.xmlfile = xmlfile;
this.xsltfile = xsltfile;
}
/**
- * overwrites the method of the super class to return the xmlfile
+ * overwrites the method of the super class to return the xmlfile
*/
- public InputSource getInputSource () {
+ public InputSource getInputSource() {
return fileInputSource(xmlfile);
}
/**
- * overwrites this method of the super class and returns an XMLFilter instead of a
- * simple XMLReader which allows chaining of transformations
+ * overwrites this method of the super class and returns an XMLFilter instead of a
+ * simple XMLReader which allows chaining of transformations
*
*/
public XMLReader getParser() throws FOPException {
@@ -69,21 +70,21 @@ public class TraxInputHandler extends InputHandler {
* @param xsltfile An xslt stylesheet
* @return XMLFilter an XMLFilter which can be chained together with other XMLReaders or XMLFilters
*/
- public static XMLFilter getXMLFilter (File xmlfile,
- File xsltfile) throws FOPException {
+ public static XMLFilter getXMLFilter(File xmlfile,
+ File xsltfile) throws FOPException {
try {
// Instantiate a TransformerFactory.
TransformerFactory tFactory = TransformerFactory.newInstance();
// Determine whether the TransformerFactory supports The use uf SAXSource
// and SAXResult
- if (tFactory.getFeature(SAXSource.FEATURE) &&
- tFactory.getFeature(SAXResult.FEATURE)) {
+ if (tFactory.getFeature(SAXSource.FEATURE)
+ && tFactory.getFeature(SAXResult.FEATURE)) {
// Cast the TransformerFactory to SAXTransformerFactory.
SAXTransformerFactory saxTFactory =
- ((SAXTransformerFactory) tFactory);
+ ((SAXTransformerFactory)tFactory);
// Create an XMLFilter for each stylesheet.
- XMLFilter xmlfilter = saxTFactory.newXMLFilter(
- new StreamSource(xsltfile));
+ XMLFilter xmlfilter =
+ saxTFactory.newXMLFilter(new StreamSource(xsltfile));
// Create an XMLReader.
XMLReader parser = createParser();
@@ -95,17 +96,16 @@ public class TraxInputHandler extends InputHandler {
xmlfilter.setParent(parser);
return xmlfilter;
} else {
- throw new FOPException(
- "Your parser doesn't support the features SAXSource and SAXResult." +
- "\nMake sure you are using a xsl parser which supports TrAX");
+ throw new FOPException("Your parser doesn't support the features SAXSource and SAXResult."
+ + "\nMake sure you are using a xsl parser which supports TrAX");
}
- }
- catch (Exception ex) {
+ } catch (Exception ex) {
if (ex instanceof FOPException) {
- throw (FOPException) ex;
+ throw (FOPException)ex;
}
throw new FOPException(ex);
}
}
+
}
diff --git a/src/org/apache/fop/apps/Version.java b/src/org/apache/fop/apps/Version.java
index cb4e86572..a7d64534b 100644
--- a/src/org/apache/fop/apps/Version.java
+++ b/src/org/apache/fop/apps/Version.java
@@ -1,12 +1,14 @@
-/*
+/*
+ * $Id$
* Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
- * For details on use and redistribution please refer to the
+ * For details on use and redistribution please refer to the
* LICENSE file included with these sources."
*/
package org.apache.fop.apps;
import org.apache.fop.configuration.Configuration;
+
/**
* class representing the version of FOP.
*/
@@ -20,4 +22,5 @@ public class Version {
public static String getVersion() {
return Configuration.getStringValue("version");
}
+
}
diff --git a/src/org/apache/fop/apps/XSLTInputHandler.java b/src/org/apache/fop/apps/XSLTInputHandler.java
index 1169e5870..3b035838a 100644
--- a/src/org/apache/fop/apps/XSLTInputHandler.java
+++ b/src/org/apache/fop/apps/XSLTInputHandler.java
@@ -1,4 +1,5 @@
-/* $Id$
+/*
+ * $Id$
* Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
* For details on use and redistribution please refer to the
* LICENSE file included with these sources.
@@ -30,15 +31,15 @@ public class XSLTInputHandler extends InputHandler {
File xmlfile, xsltfile;
boolean useOldTransform = false;
- public XSLTInputHandler (File xmlfile, File xsltfile) {
+ public XSLTInputHandler(File xmlfile, File xsltfile) {
this.xmlfile = xmlfile;
this.xsltfile = xsltfile;
}
/**
- * overwrites the method of the super class to return the xmlfile
+ * overwrites the method of the super class to return the xmlfile
*/
- public InputSource getInputSource () {
+ public InputSource getInputSource() {
if (useOldTransform) {
try {
java.io.Writer writer;
@@ -87,26 +88,29 @@ public class XSLTInputHandler extends InputHandler {
XMLReader result = null;
try {
// try trax first
- Class transformer = Class.forName("javax.xml.transform.Transformer");
- transformer = Class.forName("org.apache.fop.apps.TraxInputHandler");
- Class[] argTypes = { File.class, File.class };
- Method getFilterMethod =
- transformer.getMethod("getXMLFilter",argTypes);
- File[] args = {xmlfile, xsltfile};
+ Class transformer =
+ Class.forName("javax.xml.transform.Transformer");
+ transformer =
+ Class.forName("org.apache.fop.apps.TraxInputHandler");
+ Class[] argTypes = {
+ File.class, File.class
+ };
+ Method getFilterMethod = transformer.getMethod("getXMLFilter",
+ argTypes);
+ File[] args = {
+ xmlfile, xsltfile
+ };
Object obj = getFilterMethod.invoke(null, args);
if (obj instanceof XMLReader) {
- result = (XMLReader) obj;
+ result = (XMLReader)obj;
}
} catch (ClassNotFoundException ex) {
throw new FOPException(ex);
- }
- catch (InvocationTargetException ex) {
+ } catch (InvocationTargetException ex) {
throw new FOPException(ex);
- }
- catch (IllegalAccessException ex) {
+ } catch (IllegalAccessException ex) {
throw new FOPException(ex);
- }
- catch (NoSuchMethodException ex) {
+ } catch (NoSuchMethodException ex) {
throw new FOPException(ex);
}
// otherwise, use DOM documents via our XSLTransform tool class old style
@@ -117,5 +121,6 @@ public class XSLTInputHandler extends InputHandler {
return result;
}
+
}
diff --git a/src/org/apache/fop/apps/XTDriver.java b/src/org/apache/fop/apps/XTDriver.java
index b069bbabc..0fd8094d2 100644
--- a/src/org/apache/fop/apps/XTDriver.java
+++ b/src/org/apache/fop/apps/XTDriver.java
@@ -1,52 +1,8 @@
-/*-- $Id$ --
-
- ============================================================================
- 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/>.
-
+/*
+ * $Id$
+ * Copyright (C) 2001 The Apache Software Foundation. All rights reserved.
+ * For details on use and redistribution please refer to the
+ * LICENSE file included with these sources.
*/
package org.apache.fop.apps;
@@ -102,41 +58,55 @@ import java.io.*;
* <P>Here is an example use of Driver from CommandLine.java:
*
* <PRE>
- * Driver driver = new Driver();
- * driver.setRenderer("org.apache.fop.render.pdf.PDFRenderer", version);
- * driver.addElementMapping("org.apache.fop.fo.StandardElementMapping");
- * driver.addElementMapping("org.apache.fop.svg.SVGElementMapping");
- * driver.setWriter(new PrintWriter(new FileWriter(args[1])));
- * driver.buildFOTree(parser, fileInputSource(args[0]));
- * driver.format();
- * driver.render();
+ * Driver driver = new Driver();
+ * driver.setRenderer("org.apache.fop.render.pdf.PDFRenderer", version);
+ * driver.addElementMapping("org.apache.fop.fo.StandardElementMapping");
+ * driver.addElementMapping("org.apache.fop.svg.SVGElementMapping");
+ * driver.setWriter(new PrintWriter(new FileWriter(args[1])));
+ * driver.buildFOTree(parser, fileInputSource(args[0]));
+ * driver.format();
+ * driver.render();
* </PRE>
*/
public class XTDriver {
- /** the FO tree builder */
+ /**
+ * the FO tree builder
+ */
protected XTFOTreeBuilder treeBuilder;
- /** the area tree that is the result of formatting the FO tree */
+ /**
+ * the area tree that is the result of formatting the FO tree
+ */
protected AreaTree areaTree;
- /** the renderer to use to output the area tree */
+ /**
+ * the renderer to use to output the area tree
+ */
protected Renderer renderer;
- /** the PrintWriter to use to output the results of the renderer */
+ /**
+ * the PrintWriter to use to output the results of the renderer
+ */
protected PrintWriter writer;
- /** the stream to use to output the results of the renderer */
+ /**
+ * the stream to use to output the results of the renderer
+ */
protected OutputStream stream;
- /** create a new Driver */
+ /**
+ * create a new Driver
+ */
public XTDriver() {
- this.treeBuilder = new XTFOTreeBuilder();
+ this.treeBuilder = new XTFOTreeBuilder();
}
-
- /** set the Renderer to use */
+
+ /**
+ * set the Renderer to use
+ */
public void setRenderer(Renderer renderer) {
- this.renderer = renderer;
+ this.renderer = renderer;
}
/**
@@ -144,8 +114,8 @@ public class XTDriver {
* producer string for those renderers that can make use of it
*/
public void setRenderer(String rendererClassName, String producer) {
- this.renderer = createRenderer(rendererClassName);
- this.renderer.setProducer(producer);
+ this.renderer = createRenderer(rendererClassName);
+ this.renderer.setProducer(producer);
}
/**
@@ -153,38 +123,37 @@ public class XTDriver {
* instantiate the Renderer class
*/
protected Renderer createRenderer(String rendererClassName) {
- MessageHandler.logln("using renderer " + rendererClassName);
-
- try {
- return (Renderer)
- Class.forName(rendererClassName).newInstance();
- } catch (ClassNotFoundException e) {
- MessageHandler.errorln("Could not find " + rendererClassName);
- } catch (InstantiationException e) {
- MessageHandler.errorln("Could not instantiate "
- + rendererClassName);
- } catch (IllegalAccessException e) {
- MessageHandler.errorln("Could not access " + rendererClassName);
- } catch (ClassCastException e) {
- MessageHandler.errorln(rendererClassName + " is not a renderer");
- }
- return null;
+ MessageHandler.logln("using renderer " + rendererClassName);
+
+ try {
+ return (Renderer)Class.forName(rendererClassName).newInstance();
+ } catch (ClassNotFoundException e) {
+ MessageHandler.errorln("Could not find " + rendererClassName);
+ } catch (InstantiationException e) {
+ MessageHandler.errorln("Could not instantiate "
+ + rendererClassName);
+ } catch (IllegalAccessException e) {
+ MessageHandler.errorln("Could not access " + rendererClassName);
+ } catch (ClassCastException e) {
+ MessageHandler.errorln(rendererClassName + " is not a renderer");
+ }
+ return null;
}
-
+
/**
* add the given element mapping.
*
* an element mapping maps element names to Java classes
*/
public void addElementMapping(ElementMapping mapping) {
- mapping.addToBuilder(this.treeBuilder);
+ mapping.addToBuilder(this.treeBuilder);
}
-
+
/**
* add the element mapping with the given class name
*/
public void addElementMapping(String mappingClassName) {
- createElementMapping(mappingClassName).addToBuilder(this.treeBuilder);
+ createElementMapping(mappingClassName).addToBuilder(this.treeBuilder);
}
/**
@@ -192,29 +161,29 @@ public class XTDriver {
* instantiate element mapping class
*/
protected ElementMapping createElementMapping(String mappingClassName) {
- MessageHandler.logln("using element mapping " + mappingClassName);
-
- try {
- return (ElementMapping)
- Class.forName(mappingClassName).newInstance();
- } catch (ClassNotFoundException e) {
- MessageHandler.errorln("Could not find " + mappingClassName);
- } catch (InstantiationException e) {
- MessageHandler.errorln("Could not instantiate "
- + mappingClassName);
- } catch (IllegalAccessException e) {
- MessageHandler.errorln("Could not access " + mappingClassName);
- } catch (ClassCastException e) {
- MessageHandler.errorln(mappingClassName + " is not an element mapping");
- }
- return null;
+ MessageHandler.logln("using element mapping " + mappingClassName);
+
+ try {
+ return (ElementMapping)Class.forName(mappingClassName).newInstance();
+ } catch (ClassNotFoundException e) {
+ MessageHandler.errorln("Could not find " + mappingClassName);
+ } catch (InstantiationException e) {
+ MessageHandler.errorln("Could not instantiate "
+ + mappingClassName);
+ } catch (IllegalAccessException e) {
+ MessageHandler.errorln("Could not access " + mappingClassName);
+ } catch (ClassCastException e) {
+ MessageHandler.errorln(mappingClassName
+ + " is not an element mapping");
+ }
+ return null;
}
/**
* add the element mapping with the given class name
*/
public void addPropertyList(String listClassName) {
- createPropertyList(listClassName).addToBuilder(this.treeBuilder);
+ createPropertyList(listClassName).addToBuilder(this.treeBuilder);
}
/**
@@ -222,22 +191,21 @@ public class XTDriver {
* instantiate list mapping class
*/
protected PropertyListMapping createPropertyList(String listClassName) {
- MessageHandler.logln("using property list mapping " + listClassName);
-
- try {
- return (PropertyListMapping)
- Class.forName(listClassName).newInstance();
- } catch (ClassNotFoundException e) {
- MessageHandler.errorln("Could not find " + listClassName);
- } catch (InstantiationException e) {
- MessageHandler.errorln("Could not instantiate "
- + listClassName);
- } catch (IllegalAccessException e) {
- MessageHandler.errorln("Could not access " + listClassName);
- } catch (ClassCastException e) {
- MessageHandler.errorln(listClassName + " is not an property list");
- }
- return null;
+ MessageHandler.logln("using property list mapping " + listClassName);
+
+ try {
+ return (PropertyListMapping)Class.forName(listClassName).newInstance();
+ } catch (ClassNotFoundException e) {
+ MessageHandler.errorln("Could not find " + listClassName);
+ } catch (InstantiationException e) {
+ MessageHandler.errorln("Could not instantiate " + listClassName);
+ } catch (IllegalAccessException e) {
+ MessageHandler.errorln("Could not access " + listClassName);
+ } catch (ClassCastException e) {
+ MessageHandler.errorln(listClassName
+ + " is not an property list");
+ }
+ return null;
}
/**
@@ -248,116 +216,115 @@ public class XTDriver {
* events but isn't a SAX Parser itself.
*/
public DocumentHandler getDocumentHandler() {
- return this.treeBuilder;
+ return this.treeBuilder;
}
/**
* build the formatting object tree using the given SAX Parser and
* SAX InputSource
*/
- public void buildFOTree(Parser parser, InputSource source)
- throws FOPException {
-
- parser.setDocumentHandler(this.treeBuilder);
- try {
- parser.parse(source);
- } catch (SAXException e) {
- if (e.getException() instanceof FOPException)
- throw (FOPException) e.getException();
- else
- throw new FOPException(e.getMessage());
- } catch (IOException e) {
- throw new FOPException(e.getMessage());
- }
+ public void buildFOTree(Parser parser,
+ InputSource source) throws FOPException {
+
+ parser.setDocumentHandler(this.treeBuilder);
+ try {
+ parser.parse(source);
+ } catch (SAXException e) {
+ if (e.getException() instanceof FOPException)
+ throw (FOPException)e.getException();
+ else
+ throw new FOPException(e.getMessage());
+ } catch (IOException e) {
+ throw new FOPException(e.getMessage());
+ }
}
/**
* build the formatting object tree using the given DOM Document
*/
- public void buildFOTree(Document document)
- throws FOPException {
-
- /* most of this code is modified from John Cowan's */
-
- Node currentNode;
- AttributesImpl currentAtts;
-
- /* temporary array for making Strings into character arrays */
- char[] array = null;
-
- currentAtts = new AttributesImpl();
-
- /* start at the document element */
- currentNode = document;
-
- try {
- while (currentNode != null) {
- switch (currentNode.getNodeType()) {
- case Node.DOCUMENT_NODE:
- this.treeBuilder.startDocument();
- break;
- case Node.CDATA_SECTION_NODE:
- case Node.TEXT_NODE:
- String data = currentNode.getNodeValue();
- int datalen = data.length();
- if (array == null || array.length < datalen) {
- /* if the array isn't big enough, make a new
- one */
- array = new char[datalen];
- }
- data.getChars(0, datalen, array, 0);
- this.treeBuilder.characters(array, 0, datalen);
- break;
- case Node.PROCESSING_INSTRUCTION_NODE:
- this.treeBuilder.processingInstruction(
- currentNode.getNodeName(),
- currentNode.getNodeValue());
- break;
- case Node.ELEMENT_NODE:
- NamedNodeMap map = currentNode.getAttributes();
- currentAtts.clear();
- for (int i = map.getLength() - 1; i >= 0; i--) {
- Attr att = (Attr)map.item(i);
- currentAtts.addAttribute("",
- att.getName(),
- "",
- "CDATA",
- att.getValue());
- }
- this.treeBuilder.startElement(
- "", currentNode.getNodeName(), "", currentAtts);
- break;
- }
-
- Node nextNode = currentNode.getFirstChild();
- if (nextNode != null) {
- currentNode = nextNode;
- continue;
- }
-
- while (currentNode != null) {
- switch (currentNode.getNodeType()) {
- case Node.DOCUMENT_NODE:
- this.treeBuilder.endDocument();
- break;
- case Node.ELEMENT_NODE:
- this.treeBuilder.endElement(
- "", currentNode.getNodeName(), "" );
- break;
- }
-
- nextNode = currentNode.getNextSibling();
- if (nextNode != null) {
- currentNode = nextNode;
- break;
- }
-
- currentNode = currentNode.getParentNode();
- }
- }
- } catch (SAXException e) {
- throw new FOPException(e.getMessage());
- }
+ public void buildFOTree(Document document) throws FOPException {
+
+ /* most of this code is modified from John Cowan's */
+
+ Node currentNode;
+ AttributesImpl currentAtts;
+
+ /* temporary array for making Strings into character arrays */
+ char[] array = null;
+
+ currentAtts = new AttributesImpl();
+
+ /* start at the document element */
+ currentNode = document;
+
+ try {
+ while (currentNode != null) {
+ switch (currentNode.getNodeType()) {
+ case Node.DOCUMENT_NODE:
+ this.treeBuilder.startDocument();
+ break;
+ case Node.CDATA_SECTION_NODE:
+ case Node.TEXT_NODE:
+ String data = currentNode.getNodeValue();
+ int datalen = data.length();
+ if (array == null || array.length < datalen) {
+ /*
+ * if the array isn't big enough, make a new
+ * one
+ */
+ array = new char[datalen];
+ }
+ data.getChars(0, datalen, array, 0);
+ this.treeBuilder.characters(array, 0, datalen);
+ break;
+ case Node.PROCESSING_INSTRUCTION_NODE:
+ this.treeBuilder.processingInstruction(currentNode.getNodeName(),
+ currentNode.getNodeValue());
+ break;
+ case Node.ELEMENT_NODE:
+ NamedNodeMap map = currentNode.getAttributes();
+ currentAtts.clear();
+ for (int i = map.getLength() - 1; i >= 0; i--) {
+ Attr att = (Attr)map.item(i);
+ currentAtts.addAttribute("", att.getName(), "",
+ "CDATA", att.getValue());
+ }
+ this.treeBuilder.startElement("",
+ currentNode.getNodeName(),
+ "", currentAtts);
+ break;
+ }
+
+ Node nextNode = currentNode.getFirstChild();
+ if (nextNode != null) {
+ currentNode = nextNode;
+ continue;
+ }
+
+ while (currentNode != null) {
+ switch (currentNode.getNodeType()) {
+ case Node.DOCUMENT_NODE:
+ this.treeBuilder.endDocument();
+ break;
+ case Node.ELEMENT_NODE:
+ this.treeBuilder.endElement("",
+ currentNode.getNodeName(),
+ "");
+ break;
+ }
+
+ nextNode = currentNode.getNextSibling();
+ if (nextNode != null) {
+ currentNode = nextNode;
+ break;
+ }
+
+ currentNode = currentNode.getParentNode();
+ }
+ }
+ } catch (SAXException e) {
+ throw new FOPException(e.getMessage());
+ }
}
/**
@@ -365,13 +332,13 @@ public class XTDriver {
* (if applicable)
*/
public void setWriter(PrintWriter writer) {
- this.writer = writer;
+ this.writer = writer;
}
/**
- * set the OutputStream to use to output the result of the Renderer
- * (if applicable)
- */
+ * set the OutputStream to use to output the result of the Renderer
+ * (if applicable)
+ */
public void setOutputStream(OutputStream stream) {
this.stream = stream;
}
@@ -379,22 +346,21 @@ public class XTDriver {
/**
* format the formatting object tree into an area tree
*/
- public void format()
- throws FOPException {
- FontInfo fontInfo = new FontInfo();
- this.renderer.setupFontInfo(fontInfo);
+ public void format() throws FOPException {
+ FontInfo fontInfo = new FontInfo();
+ this.renderer.setupFontInfo(fontInfo);
- this.areaTree = new AreaTree();
- this.areaTree.setFontInfo(fontInfo);
+ this.areaTree = new AreaTree();
+ this.areaTree.setFontInfo(fontInfo);
- this.treeBuilder.format(areaTree);
+ this.treeBuilder.format(areaTree);
}
/**
* render the area tree to the output form
*/
- public void render()
- throws IOException, FOPException {
- this.renderer.render(areaTree, this.stream);
+ public void render() throws IOException, FOPException {
+ this.renderer.render(areaTree, this.stream);
}
+
}