diff options
Diffstat (limited to 'src')
8 files changed, 52 insertions, 8 deletions
diff --git a/src/java/org/apache/fop/fonts/FontDetector.java b/src/java/org/apache/fop/fonts/FontDetector.java index 88e4c6e69..8cfb0da12 100644 --- a/src/java/org/apache/fop/fonts/FontDetector.java +++ b/src/java/org/apache/fop/fonts/FontDetector.java @@ -27,10 +27,12 @@ import java.util.List; import org.apache.commons.io.FileUtils; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; + +import org.apache.xmlgraphics.util.ClasspathResource; + import org.apache.fop.apps.FOPException; import org.apache.fop.fonts.autodetect.FontFileFinder; import org.apache.fop.util.LogUtil; -import org.apache.xmlgraphics.util.ClasspathResource; /** * Detector of operating system and classpath fonts @@ -45,17 +47,21 @@ public class FontDetector { private final FontManager fontManager; private final FontAdder fontAdder; private final boolean strict; + private final FontEventListener eventListener; /** * Main constructor * @param manager the font manager * @param adder the font adder * @param strict true if an Exception should be thrown if an error is found. + * @param listener for throwing font related events */ - public FontDetector(FontManager manager, FontAdder adder, boolean strict) { + public FontDetector(FontManager manager, FontAdder adder, boolean strict, + FontEventListener listener) { this.fontManager = manager; this.fontAdder = adder; this.strict = strict; + this.eventListener = listener; } /** @@ -66,7 +72,7 @@ public class FontDetector { public void detect(List<EmbedFontInfo> fontInfoList) throws FOPException { // search in font base if it is defined and // is a directory but don't recurse - FontFileFinder fontFileFinder = new FontFileFinder(); + FontFileFinder fontFileFinder = new FontFileFinder(eventListener); String fontBaseURL = fontManager.getFontBaseURL(); if (fontBaseURL != null) { try { diff --git a/src/java/org/apache/fop/fonts/FontEventAdapter.java b/src/java/org/apache/fop/fonts/FontEventAdapter.java index 77846ee77..85a43393e 100644 --- a/src/java/org/apache/fop/fonts/FontEventAdapter.java +++ b/src/java/org/apache/fop/fonts/FontEventAdapter.java @@ -61,4 +61,9 @@ public class FontEventAdapter implements FontEventListener { getEventProducer().glyphNotAvailable(source, ch, fontName); } + /** {@inheritDoc} */ + public void fontDirectoryNotFound(Object source, String dir) { + getEventProducer().fontDirectoryNotFound(source, dir); + } + } diff --git a/src/java/org/apache/fop/fonts/FontEventListener.java b/src/java/org/apache/fop/fonts/FontEventListener.java index 740a05fdc..5f9e7b6c6 100644 --- a/src/java/org/apache/fop/fonts/FontEventListener.java +++ b/src/java/org/apache/fop/fonts/FontEventListener.java @@ -48,4 +48,10 @@ public interface FontEventListener { */ void glyphNotAvailable(Object source, char ch, String fontName); + /** + * An error occurred trying to find the font directory specified in the config file. + * @param source the event source + * @param dir the directory in the config file + */ + void fontDirectoryNotFound(Object source, String dir); } diff --git a/src/java/org/apache/fop/fonts/FontEventProducer.java b/src/java/org/apache/fop/fonts/FontEventProducer.java index ae4294318..702d3efb6 100644 --- a/src/java/org/apache/fop/fonts/FontEventProducer.java +++ b/src/java/org/apache/fop/fonts/FontEventProducer.java @@ -71,4 +71,12 @@ public interface FontEventProducer extends EventProducer { */ void glyphNotAvailable(Object source, char ch, String fontName); + /** + * An error occurred trying to find the font directory specified in the config file. + * @param source the event sourece + * @param dir the directory in the config file + * @event.severity WARN + */ + void fontDirectoryNotFound(Object source, String dir); + } diff --git a/src/java/org/apache/fop/fonts/FontEventProducer.xml b/src/java/org/apache/fop/fonts/FontEventProducer.xml index 6ea587036..27fd587b1 100644 --- a/src/java/org/apache/fop/fonts/FontEventProducer.xml +++ b/src/java/org/apache/fop/fonts/FontEventProducer.xml @@ -20,4 +20,5 @@ <message key="fontSubstituted">Font "{requested}" not found. Substituting with "{effective}".</message> <message key="fontLoadingErrorAtAutoDetection">Unable to load font file: {fontURL}.[ Reason: {e}]</message> <message key="glyphNotAvailable">Glyph "{ch}" (0x{ch,hex}[, {ch,glyph-name}]) not available in font "{fontName}".</message> + <message key="fontDirectoryNotFound">'{dir}' does not exist or is not a directory.</message> </catalogue> diff --git a/src/java/org/apache/fop/fonts/FontInfoConfigurator.java b/src/java/org/apache/fop/fonts/FontInfoConfigurator.java index 67bb2e295..1f1116990 100644 --- a/src/java/org/apache/fop/fonts/FontInfoConfigurator.java +++ b/src/java/org/apache/fop/fonts/FontInfoConfigurator.java @@ -33,6 +33,7 @@ import org.apache.avalon.framework.configuration.ConfigurationException; import org.apache.commons.io.IOUtils; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; + import org.apache.fop.apps.FOPException; import org.apache.fop.fonts.autodetect.FontFileFinder; import org.apache.fop.fonts.autodetect.FontInfoFinder; @@ -88,7 +89,8 @@ public class FontInfoConfigurator { // native o/s search (autodetect) configuration boolean autodetectFonts = (fontsCfg.getChild("auto-detect", false) != null); if (autodetectFonts) { - FontDetector fontDetector = new FontDetector(fontManager, fontAdder, strict); + FontDetector fontDetector = new FontDetector(fontManager, fontAdder, strict, + listener); fontDetector.detect(fontInfoList); } @@ -139,7 +141,7 @@ public class FontInfoConfigurator { } // add fonts found in directory - FontFileFinder fontFileFinder = new FontFileFinder(recursive ? -1 : 1); + FontFileFinder fontFileFinder = new FontFileFinder(recursive ? -1 : 1, listener); List<URL> fontURLList; try { fontURLList = fontFileFinder.find(directory); diff --git a/src/java/org/apache/fop/fonts/autodetect/FontFileFinder.java b/src/java/org/apache/fop/fonts/autodetect/FontFileFinder.java index 9a0a73e2f..3c1a94f63 100644 --- a/src/java/org/apache/fop/fonts/autodetect/FontFileFinder.java +++ b/src/java/org/apache/fop/fonts/autodetect/FontFileFinder.java @@ -34,6 +34,8 @@ import org.apache.commons.io.filefilter.WildcardFileFilter; import org.apache.commons.logging.Log; import org.apache.commons.logging.LogFactory; +import org.apache.fop.fonts.FontEventListener; + /** * Helps to autodetect/locate available operating system fonts. */ @@ -44,20 +46,24 @@ public class FontFileFinder extends DirectoryWalker implements FontFinder { /** default depth limit of recursion when searching for font files **/ public static final int DEFAULT_DEPTH_LIMIT = -1; + private final FontEventListener eventListener; /** * Default constructor + * @param listener for throwing font related events */ - public FontFileFinder() { - super(getDirectoryFilter(), getFileFilter(), DEFAULT_DEPTH_LIMIT); + public FontFileFinder(FontEventListener listener) { + this(DEFAULT_DEPTH_LIMIT, listener); } /** * Constructor * @param depthLimit recursion depth limit + * @param listener for throwing font related events */ - public FontFileFinder(int depthLimit) { + public FontFileFinder(int depthLimit, FontEventListener listener) { super(getDirectoryFilter(), getFileFilter(), depthLimit); + eventListener = listener; } /** @@ -163,6 +169,12 @@ public class FontFileFinder extends DirectoryWalker implements FontFinder { public List<URL> find(String dir) throws IOException { List<URL> results = new java.util.ArrayList<URL>(); super.walk(new File(dir), results); + File directory = new File(dir); + if (!directory.isDirectory()) { + eventListener.fontDirectoryNotFound(this, dir); + } else { + super.walk(directory, results); + } return results; } } diff --git a/src/java/org/apache/fop/tools/fontlist/FontListMain.java b/src/java/org/apache/fop/tools/fontlist/FontListMain.java index d31da92c2..92c2acffd 100644 --- a/src/java/org/apache/fop/tools/fontlist/FontListMain.java +++ b/src/java/org/apache/fop/tools/fontlist/FontListMain.java @@ -143,6 +143,10 @@ public final class FontListMain { //ignore } + public void fontDirectoryNotFound(Object source, String msg) { + //ignore + } + }; FontListGenerator listGenerator = new FontListGenerator(); |