diff options
-rw-r--r-- | src/java/org/apache/fop/apps/Driver.java | 65 | ||||
-rw-r--r-- | src/java/org/apache/fop/servlet/FopPrintServlet.java | 20 | ||||
-rw-r--r-- | test/java/org/apache/fop/BasicDriverTestCase.java | 32 |
3 files changed, 21 insertions, 96 deletions
diff --git a/src/java/org/apache/fop/apps/Driver.java b/src/java/org/apache/fop/apps/Driver.java index 2a765c74e..97715b25a 100644 --- a/src/java/org/apache/fop/apps/Driver.java +++ b/src/java/org/apache/fop/apps/Driver.java @@ -37,18 +37,11 @@ import org.apache.fop.render.awt.AWTRenderer; /** * Primary class that drives overall FOP process. * <P> - * The simplest way to use this is to instantiate it with the - * InputSource and OutputStream, then set the renderer desired, and - * calling run(); + * JAXP is the standard method of embedding FOP in Java programs. + * Please check our embedding page (http://xml.apache.org/fop/embedding.html) + * for samples (these are also available within the distribution in + * FOP_DIR\examples\embedding) * <P> - * 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(); - * </PRE> * If necessary, calling classes can call into the lower level * methods to setup and * render. Methods within FOUserAgent can be called to set the @@ -64,15 +57,6 @@ import org.apache.fop.render.awt.AWTRenderer; * is called. The invocation of the method is * render(Parser, InputSource). * <P> - * A third possibility may be used to build the FO Tree, namely - * calling getContentHandler() and firing the SAX events yourself. - * This will work either for DOM Tree input or SAX. See the embed - * examples on the FOP web page for more details or in the - * examples\embedding directory of the main distribution for more details. - * <P> - * Once the FO Tree is built, the format() and render() methods may be - * called in that order. - * <P> * Here is an example use of Driver which outputs to AWT: * * <PRE> @@ -94,11 +78,6 @@ public class Driver implements Constants { private int renderType = NOT_SET; /** - * the source of the FO file - */ - private InputSource source; - - /** * the stream to use to output the results of the renderer */ private OutputStream stream; @@ -130,9 +109,8 @@ public class Driver implements Constants { * @param source InputSource to take the XSL-FO input from * @param stream Target output stream */ - public Driver(InputSource source, OutputStream stream) { + public Driver(OutputStream stream) { this(); - this.source = source; this.stream = stream; } @@ -159,7 +137,6 @@ public class Driver implements Constants { * The output stream is cleared. The renderer is cleared. */ public synchronized void reset() { - source = null; stream = null; if (treeBuilder != null) { treeBuilder.reset(); @@ -206,15 +183,6 @@ public class Driver implements Constants { } /** - * Set the source for the FO document. This can be a normal SAX - * InputSource, or an DocumentInputSource containing a DOM document. - * @see DocumentInputSource - */ - public void setInputSource(InputSource source) { - this.source = source; - } - - /** * Method to set the rendering type desired. Must be one of * <ul> * <li>Driver.RENDER_PDF</li> @@ -330,27 +298,4 @@ public class Driver implements Constants { throw new FOPException(e); } } - - /** - * Runs the formatting and rendering process using the previously set - * parser, input source, renderer and output stream. - * If no parser was set, get a default SAX parser. - * @throws IOException in case of IO errors. - * @throws FOPException if anything else goes wrong. - */ - public synchronized void run() throws IOException, FOPException { - if (!isInitialized()) { - initialize(); - } - - if (renderType == NOT_SET) { - renderType = RENDER_PDF; - } - - if (source == null) { - throw new FOPException("InputSource is not set."); - } - - render(FOFileHandler.createParser(), source); - } } diff --git a/src/java/org/apache/fop/servlet/FopPrintServlet.java b/src/java/org/apache/fop/servlet/FopPrintServlet.java index 301a70242..e83ce85c6 100644 --- a/src/java/org/apache/fop/servlet/FopPrintServlet.java +++ b/src/java/org/apache/fop/servlet/FopPrintServlet.java @@ -110,7 +110,7 @@ public class FopPrintServlet extends HttpServlet { if (foParam != null) { InputStream file = new java.io.FileInputStream(foParam); - renderFO(new InputSource(file), response); + renderFO(file, response); } else if ((xmlParam != null) && (xsltParam != null)) { renderXML(new File(xmlParam), new File(xsltParam), response); } else { @@ -135,13 +135,25 @@ public class FopPrintServlet extends HttpServlet { * @param response Response to write to * @throws ServletException In case of a problem */ - public void renderFO(InputSource foFile, + public void renderFO(InputStream foFile, HttpServletResponse response) throws ServletException { try { - Driver driver = new Driver(foFile, null); + Driver driver = new Driver(); driver.setRenderer(Driver.RENDER_PRINT); - driver.run(); + // Setup JAXP + TransformerFactory factory = TransformerFactory.newInstance(); + Transformer transformer = factory.newTransformer(); //identity transformer + + // Setup input for XSLT transformation + Source src = new StreamSource(foFile); + + // Resulting SAX events (the generated FO) must be piped through to FOP + Result res = new SAXResult(driver.getContentHandler()); + + // Start XSLT transformation and FOP processing + transformer.transform(src, res); + reportOK (response); } catch (Exception ex) { throw new ServletException(ex); diff --git a/test/java/org/apache/fop/BasicDriverTestCase.java b/test/java/org/apache/fop/BasicDriverTestCase.java index d591d6602..5f722fbc1 100644 --- a/test/java/org/apache/fop/BasicDriverTestCase.java +++ b/test/java/org/apache/fop/BasicDriverTestCase.java @@ -54,38 +54,6 @@ public class BasicDriverTestCase extends AbstractFOPTestCase { super(name); } - /** - * Tests Driver with its special constructor for FO-->PDF conversion. - * @throws Exception if anything fails - */ - public void testFO2PDFWithConstructorSetup() throws Exception { - File foFile = new File(getBaseDir(), "test/xml/bugtests/block.fo"); - ByteArrayOutputStream baout = new ByteArrayOutputStream(); - Driver driver = new Driver( - new InputSource(foFile.toURL().toExternalForm()), - baout); - - driver.setRenderer(Driver.RENDER_PDF); - driver.run(); - assertTrue("Generated PDF has zero length", baout.size() > 0); - } - - /** - * Tests Driver with InputSource and OutputStream. - * @throws Exception if anything fails - */ - public void testFO2PDFWithInputSource() throws Exception { - File foFile = new File(getBaseDir(), "test/xml/bugtests/block.fo"); - ByteArrayOutputStream baout = new ByteArrayOutputStream(); - Driver driver = new Driver(); - - driver.setInputSource(new InputSource(foFile.toURL().toExternalForm())); - driver.setOutputStream(baout); - driver.setRenderer(Driver.RENDER_PDF); - driver.run(); - assertTrue("Generated PDF has zero length", baout.size() > 0); - } - private Document loadDocument(File foFile) throws TransformerException { TransformerFactory factory = TransformerFactory.newInstance(); |