aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/org/apache/fop/apps/StreamRenderer.java18
-rw-r--r--src/org/apache/fop/extensions/Outline.java5
-rw-r--r--src/org/apache/fop/fo/FOTreeBuilder.java12
-rw-r--r--src/org/apache/fop/fo/pagination/Root.java4
-rw-r--r--src/org/apache/fop/render/pdf/PDFRenderer.java18
5 files changed, 41 insertions, 16 deletions
diff --git a/src/org/apache/fop/apps/StreamRenderer.java b/src/org/apache/fop/apps/StreamRenderer.java
index d18ddd6cd..1c22a2e45 100644
--- a/src/org/apache/fop/apps/StreamRenderer.java
+++ b/src/org/apache/fop/apps/StreamRenderer.java
@@ -82,6 +82,11 @@ public class StreamRenderer {
*/
private IDReferences idReferences = new IDReferences();
+ /**
+ * The list of extensions.
+ */
+ private Vector extensions = new Vector();
+
private Logger log;
public StreamRenderer(OutputStream outputStream, Renderer renderer) {
@@ -97,6 +102,10 @@ public class StreamRenderer {
return idReferences;
}
+ public void addExtension(ExtensionObj ext) {
+ extensions.addElement(ext);
+ }
+
public void startRenderer()
throws SAXException {
pageCount = 0;
@@ -169,6 +178,15 @@ public class StreamRenderer {
AreaTree a = new AreaTree(this);
a.setFontInfo(fontInfo);
+ for(Enumeration e = extensions.elements(); e.hasMoreElements(); ) {
+ ExtensionObj ext = (ExtensionObj)e.nextElement();
+ try {
+ ext.format(a);
+ } catch (FOPException fope) {
+ throw new SAXException(fope);
+ }
+ }
+
try {
pageSequence.format(a);
} catch (FOPException e) {
diff --git a/src/org/apache/fop/extensions/Outline.java b/src/org/apache/fop/extensions/Outline.java
index 136bc2155..e9c8a0ca2 100644
--- a/src/org/apache/fop/extensions/Outline.java
+++ b/src/org/apache/fop/extensions/Outline.java
@@ -11,7 +11,6 @@ import org.apache.fop.fo.*;
import org.apache.fop.pdf.PDFGoTo;
import org.apache.fop.pdf.PDFAction;
import org.apache.fop.datatypes.IDReferences;
-import org.apache.fop.messaging.MessageHandler;
import java.util.*;
@@ -53,11 +52,11 @@ public class Outline extends ExtensionObj {
_externalDestination =
this.properties.get("external-destination").getString();
if (_externalDestination != null &&!_externalDestination.equals("")) {
- MessageHandler.errorln("WARNING: fox:outline external-destination not supported currently.");
+ log.warn("fox:outline external-destination not supported currently.");
}
if (_internalDestination == null || _internalDestination.equals("")) {
- MessageHandler.errorln("WARNING: fox:outline requires an internal-destination.");
+ log.warn("fox:outline requires an internal-destination.");
}
for (FONode node = getParent(); node != null;
diff --git a/src/org/apache/fop/fo/FOTreeBuilder.java b/src/org/apache/fop/fo/FOTreeBuilder.java
index 8b9d8e955..72ac6f146 100644
--- a/src/org/apache/fop/fo/FOTreeBuilder.java
+++ b/src/org/apache/fop/fo/FOTreeBuilder.java
@@ -14,6 +14,7 @@ import org.apache.fop.apps.StreamRenderer;
import org.apache.fop.fo.pagination.Root;
import org.apache.fop.system.BufferManager;
import org.apache.fop.fo.pagination.PageSequence;
+import org.apache.fop.extensions.ExtensionObj;
import org.apache.log.Logger;
@@ -159,8 +160,13 @@ public class FOTreeBuilder extends DefaultHandler implements TreeBuilder {
// mark-fop@inomial.com - tell the stream renderer to render
// this page-sequence
//
- if(currentFObj instanceof PageSequence)
+ if(currentFObj instanceof PageSequence) {
streamRenderer.render((PageSequence) currentFObj);
+ } else if(currentFObj instanceof ExtensionObj) {
+ if(!(currentFObj.getParent() instanceof ExtensionObj)) {
+ streamRenderer.addExtension((ExtensionObj)currentFObj);
+ }
+ }
currentFObj = (FObj)currentFObj.getParent();
}
@@ -246,12 +252,12 @@ public class FOTreeBuilder extends DefaultHandler implements TreeBuilder {
*
* @param areaTree the area tree to format into
*/
- public void format(AreaTree areaTree) throws FOPException {
+/* public void format(AreaTree areaTree) throws FOPException {
log.info("formatting FOs into areas");
this.bufferManager.readComplete();
((Root)this.rootFObj).format(areaTree);
}
-
+*/
public void reset() {
currentFObj = null;
rootFObj = null;
diff --git a/src/org/apache/fop/fo/pagination/Root.java b/src/org/apache/fop/fo/pagination/Root.java
index 7f054162a..eecfb57b3 100644
--- a/src/org/apache/fop/fo/pagination/Root.java
+++ b/src/org/apache/fop/fo/pagination/Root.java
@@ -101,7 +101,7 @@ public class Root extends FObj {
public void setLayoutMasterSet(LayoutMasterSet layoutMasterSet) {
this.layoutMasterSet = layoutMasterSet;
}
-
+/*
public void format(AreaTree areaTree) throws FOPException {
// log.debug(" Root[" + marker + "] ");
if (layoutMasterSet == null) {
@@ -118,5 +118,5 @@ public class Root extends FObj {
}
}
}
-
+*/
}
diff --git a/src/org/apache/fop/render/pdf/PDFRenderer.java b/src/org/apache/fop/render/pdf/PDFRenderer.java
index b76b1b77d..d411ceecd 100644
--- a/src/org/apache/fop/render/pdf/PDFRenderer.java
+++ b/src/org/apache/fop/render/pdf/PDFRenderer.java
@@ -122,6 +122,8 @@ public class PDFRenderer extends PrintRenderer {
*/
protected Hashtable options;
+ protected Vector extensions = null;
+
/**
* create the PDF renderer
*/
@@ -152,6 +154,7 @@ public class PDFRenderer extends PrintRenderer {
public void stopRenderer(OutputStream stream)
throws IOException {
+ renderRootExtensions(extensions);
FontSetup.addToResources(this.pdfDoc, fontInfo);
pdfDoc.outputTrailer(stream);
}
@@ -686,10 +689,10 @@ public class PDFRenderer extends PrintRenderer {
this.pdfDoc.setIDReferences(idReferences);
this.renderPage(page);
- //FontSetup.addToResources(this.pdfDoc, fontInfo);
-
- // TODO: this needs to be implemented
- renderRootExtensions(page);
+ Vector exts = page.getExtensions();
+ if(exts != null) {
+ extensions = exts;
+ }
// log.debug("writing out PDF");
this.pdfDoc.output(outputStream);
@@ -797,10 +800,9 @@ public class PDFRenderer extends PrintRenderer {
return rs;
}
- protected void renderRootExtensions(Page page) {
- Vector v = page.getExtensions();
- if (v != null) {
- Enumeration e = v.elements();
+ protected void renderRootExtensions(Vector exts) {
+ if (exts != null) {
+ Enumeration e = exts.elements();
while (e.hasMoreElements()) {
ExtensionObj ext = (ExtensionObj)e.nextElement();
if (ext instanceof Outline) {