aboutsummaryrefslogtreecommitdiffstats
path: root/src/java/org
diff options
context:
space:
mode:
Diffstat (limited to 'src/java/org')
-rw-r--r--src/java/org/apache/fop/area/AreaTreeParser.java32
1 files changed, 30 insertions, 2 deletions
diff --git a/src/java/org/apache/fop/area/AreaTreeParser.java b/src/java/org/apache/fop/area/AreaTreeParser.java
index 8a6198cb6..ec47d2083 100644
--- a/src/java/org/apache/fop/area/AreaTreeParser.java
+++ b/src/java/org/apache/fop/area/AreaTreeParser.java
@@ -21,6 +21,8 @@ package org.apache.fop.area;
import java.awt.Color;
import java.awt.geom.Rectangle2D;
+import java.io.FileNotFoundException;
+import java.io.IOException;
import java.nio.CharBuffer;
import java.util.List;
import java.util.Map;
@@ -41,6 +43,7 @@ import org.w3c.dom.Document;
import org.xml.sax.Attributes;
import org.xml.sax.ContentHandler;
+import org.xml.sax.Locator;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.AttributesImpl;
import org.xml.sax.helpers.DefaultHandler;
@@ -48,6 +51,7 @@ import org.xml.sax.helpers.DefaultHandler;
import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
+import org.apache.xmlgraphics.image.loader.ImageException;
import org.apache.xmlgraphics.image.loader.ImageInfo;
import org.apache.xmlgraphics.image.loader.ImageManager;
import org.apache.xmlgraphics.image.loader.ImageSessionContext;
@@ -68,6 +72,7 @@ import org.apache.fop.area.inline.SpaceArea;
import org.apache.fop.area.inline.TextArea;
import org.apache.fop.area.inline.Viewport;
import org.apache.fop.area.inline.WordArea;
+import org.apache.fop.events.ResourceEventProducer;
import org.apache.fop.fo.Constants;
import org.apache.fop.fo.ElementMappingRegistry;
import org.apache.fop.fo.expr.PropertyException;
@@ -149,6 +154,7 @@ public class AreaTreeParser {
private Stack delegateStack = new Stack();
private ContentHandler delegate;
private DOMImplementation domImplementation;
+ private Locator locator;
public Handler(AreaTreeModel treeModel, FOUserAgent userAgent,
@@ -224,6 +230,15 @@ public class AreaTreeParser {
}
/** {@inheritDoc} */
+ public void setDocumentLocator(Locator locator) {
+ this.locator = locator;
+ }
+
+ private Locator getLocator() {
+ return this.locator;
+ }
+
+ /** {@inheritDoc} */
public void startElement(String uri, String localName, String qName, Attributes attributes)
throws SAXException {
if (delegate != null) {
@@ -1056,8 +1071,21 @@ public class AreaTreeParser {
= userAgent.getImageSessionContext();
ImageInfo info = manager.getImageInfo(uri, sessionContext);
bkg.setImageInfo(info);
- } catch (Exception e) {
- log.error("Background image not available: " + uri, e);
+ } catch (ImageException e) {
+ ResourceEventProducer eventProducer
+ = ResourceEventProducer.Provider.get(
+ this.userAgent.getEventBroadcaster());
+ eventProducer.imageError(this, uri, e, getLocator());
+ } catch (FileNotFoundException fnfe) {
+ ResourceEventProducer eventProducer
+ = ResourceEventProducer.Provider.get(
+ this.userAgent.getEventBroadcaster());
+ eventProducer.imageNotFound(this, uri, fnfe, getLocator());
+ } catch (IOException ioe) {
+ ResourceEventProducer eventProducer
+ = ResourceEventProducer.Provider.get(
+ this.userAgent.getEventBroadcaster());
+ eventProducer.imageIOError(this, uri, ioe, getLocator());
}
String repeat = attributes.getValue("bkg-repeat");