aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/codegen/fonts/font-file.xsl12
-rw-r--r--src/java/org/apache/fop/afp/fonts/AFPFont.java7
-rw-r--r--src/java/org/apache/fop/fonts/CustomFont.java11
-rw-r--r--src/java/org/apache/fop/fonts/FontMetrics.java9
-rw-r--r--src/java/org/apache/fop/fonts/LazyFont.java6
-rw-r--r--src/java/org/apache/fop/fonts/MutableFont.java6
-rw-r--r--src/java/org/apache/fop/fonts/truetype/OFFontLoader.java1
-rw-r--r--src/java/org/apache/fop/render/java2d/CustomFontMetricsMapper.java6
-rw-r--r--src/java/org/apache/fop/render/java2d/SystemFontMetricsMapper.java17
-rw-r--r--src/java/org/apache/fop/render/pcl/PCLGraphics2D.java2
-rw-r--r--src/java/org/apache/fop/tools/fontlist/FontListMain.java34
11 files changed, 101 insertions, 10 deletions
diff --git a/src/codegen/fonts/font-file.xsl b/src/codegen/fonts/font-file.xsl
index 8723ed960..42f9281bc 100644
--- a/src/codegen/fonts/font-file.xsl
+++ b/src/codegen/fonts/font-file.xsl
@@ -36,6 +36,7 @@
package org.apache.fop.fonts.base14;
import java.awt.Rectangle;
+import java.net.URI;
<xsl:if test="count(kerning) &gt; 0">
import java.util.Map;
</xsl:if>
@@ -46,6 +47,7 @@ import org.apache.fop.fonts.CodePointMapping;
import org.apache.fop.fonts.Typeface;
public class <xsl:value-of select="class-name"/> extends Base14Font {
+ private final static URI fontFileURI;
private final static String fontName = "<xsl:value-of select="font-name"/>";
private final static String fullName = "<xsl:value-of select="full-name"/>";
private final static Set familyNames;
@@ -69,6 +71,12 @@ public class <xsl:value-of select="class-name"/> extends Base14Font {
private boolean enableKerning = false;
static {
+ URI uri = null;
+ try {
+ uri = new URI("base14:" + fontName.toLowerCase());
+ } catch (java.net.URISyntaxException e) {
+ }
+ fontFileURI = uri;
width = new int[256];
boundingBoxes = new Rectangle[256];
<xsl:apply-templates select="char-metrics"/>
@@ -94,6 +102,10 @@ public class <xsl:value-of select="class-name"/> extends Base14Font {
return encoding;
}
+ public URI getFontURI() {
+ return fontFileURI;
+ }
+
public String getFontName() {
return fontName;
}
diff --git a/src/java/org/apache/fop/afp/fonts/AFPFont.java b/src/java/org/apache/fop/afp/fonts/AFPFont.java
index 99e15a46b..3c84e4aa9 100644
--- a/src/java/org/apache/fop/afp/fonts/AFPFont.java
+++ b/src/java/org/apache/fop/afp/fonts/AFPFont.java
@@ -20,6 +20,7 @@
package org.apache.fop.afp.fonts;
import java.awt.Rectangle;
+import java.net.URI;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
@@ -27,7 +28,6 @@ import java.util.Set;
import org.apache.fop.fonts.FontType;
import org.apache.fop.fonts.Typeface;
-
/**
* All implementations of AFP fonts should extend this base class,
* the object implements the FontMetrics information.
@@ -53,6 +53,11 @@ public abstract class AFPFont extends Typeface {
}
/** {@inheritDoc} */
+ public URI getFontURI() {
+ return null;
+ }
+
+ /** {@inheritDoc} */
public String getFontName() {
return this.name;
}
diff --git a/src/java/org/apache/fop/fonts/CustomFont.java b/src/java/org/apache/fop/fonts/CustomFont.java
index 5c0673b04..fffb429ed 100644
--- a/src/java/org/apache/fop/fonts/CustomFont.java
+++ b/src/java/org/apache/fop/fonts/CustomFont.java
@@ -42,6 +42,7 @@ public abstract class CustomFont extends Typeface
/** Fallback thickness for underline and strikeout when not provided by the font. */
private static final int DEFAULT_LINE_THICKNESS = 50;
+ private URI fontFileURI;
private String fontName;
private String fullName;
private Set<String> familyNames;
@@ -89,6 +90,11 @@ public abstract class CustomFont extends Typeface
/** {@inheritDoc} */
+ public URI getFontURI() {
+ return fontFileURI;
+ }
+
+ /** {@inheritDoc} */
public String getFontName() {
return fontName;
}
@@ -326,6 +332,11 @@ public abstract class CustomFont extends Typeface
/* ---- MutableFont interface ---- */
/** {@inheritDoc} */
+ public void setFontURI(URI uri) {
+ this.fontFileURI = uri;
+ }
+
+ /** {@inheritDoc} */
public void setFontName(String name) {
this.fontName = name;
}
diff --git a/src/java/org/apache/fop/fonts/FontMetrics.java b/src/java/org/apache/fop/fonts/FontMetrics.java
index 159d321f7..ed59cf5af 100644
--- a/src/java/org/apache/fop/fonts/FontMetrics.java
+++ b/src/java/org/apache/fop/fonts/FontMetrics.java
@@ -20,17 +20,22 @@
package org.apache.fop.fonts;
import java.awt.Rectangle;
+import java.net.URI;
import java.util.Map;
import java.util.Set;
-
-
/**
* Main interface for access to font metrics.
*/
public interface FontMetrics {
/**
+ * Returns the URI of the font file from which these metrics were loaded.
+ * @return the font file's URI
+ */
+ URI getFontURI();
+
+ /**
* Returns the "PostScript" font name (Example: "Helvetica-BoldOblique").
* @return the font name
*/
diff --git a/src/java/org/apache/fop/fonts/LazyFont.java b/src/java/org/apache/fop/fonts/LazyFont.java
index a392ae6f4..acce1e0f9 100644
--- a/src/java/org/apache/fop/fonts/LazyFont.java
+++ b/src/java/org/apache/fop/fonts/LazyFont.java
@@ -189,6 +189,12 @@ public class LazyFont extends Typeface implements FontDescriptor, Substitutable,
// ---- FontMetrics interface ----
/** {@inheritDoc} */
+ public URI getFontURI() {
+ load(true);
+ return realFont.getFontURI();
+ }
+
+ /** {@inheritDoc} */
public String getFontName() {
load(true);
return realFont.getFontName();
diff --git a/src/java/org/apache/fop/fonts/MutableFont.java b/src/java/org/apache/fop/fonts/MutableFont.java
index 9ea323ebf..f02eb2b49 100644
--- a/src/java/org/apache/fop/fonts/MutableFont.java
+++ b/src/java/org/apache/fop/fonts/MutableFont.java
@@ -31,6 +31,12 @@ import java.util.Set;
public interface MutableFont {
/**
+ * Sets the URI from which this font is or will be loaded.
+ * @param uri URI from which font is or will be loaded
+ */
+ void setFontURI(URI uri);
+
+ /**
* Sets the "PostScript" font name (Example: "Helvetica-BoldOblique").
* @param name font name
*/
diff --git a/src/java/org/apache/fop/fonts/truetype/OFFontLoader.java b/src/java/org/apache/fop/fonts/truetype/OFFontLoader.java
index 4216cf290..7c8774933 100644
--- a/src/java/org/apache/fop/fonts/truetype/OFFontLoader.java
+++ b/src/java/org/apache/fop/fonts/truetype/OFFontLoader.java
@@ -141,6 +141,7 @@ public class OFFontLoader extends FontLoader {
returnFont = singleFont;
}
+ returnFont.setFontURI(fontFileURI);
returnFont.setFontName(otf.getPostScriptName());
returnFont.setFullName(otf.getFullName());
returnFont.setFamilyNames(otf.getFamilyNames());
diff --git a/src/java/org/apache/fop/render/java2d/CustomFontMetricsMapper.java b/src/java/org/apache/fop/render/java2d/CustomFontMetricsMapper.java
index 8a5f4b117..fcb913d53 100644
--- a/src/java/org/apache/fop/render/java2d/CustomFontMetricsMapper.java
+++ b/src/java/org/apache/fop/render/java2d/CustomFontMetricsMapper.java
@@ -24,6 +24,7 @@ import java.awt.FontFormatException;
import java.awt.Rectangle;
import java.io.IOException;
import java.io.InputStream;
+import java.net.URI;
import java.util.List;
import java.util.Map;
import java.util.Set;
@@ -161,6 +162,11 @@ public class CustomFontMetricsMapper extends Typeface implements FontMetricsMapp
}
/** {@inheritDoc} */
+ public final URI getFontURI() {
+ return typeface.getFontURI();
+ }
+
+ /** {@inheritDoc} */
public final FontType getFontType() {
return typeface.getFontType();
}
diff --git a/src/java/org/apache/fop/render/java2d/SystemFontMetricsMapper.java b/src/java/org/apache/fop/render/java2d/SystemFontMetricsMapper.java
index f922e3f05..9ed323ac4 100644
--- a/src/java/org/apache/fop/render/java2d/SystemFontMetricsMapper.java
+++ b/src/java/org/apache/fop/render/java2d/SystemFontMetricsMapper.java
@@ -21,6 +21,7 @@ package org.apache.fop.render.java2d;
// Java
import java.awt.Rectangle;
+import java.net.URI;
import java.util.Map;
import java.util.Set;
@@ -44,6 +45,8 @@ public class SystemFontMetricsMapper extends Typeface implements FontMetricsMapp
*/
private final Java2DFontMetrics java2DFontMetrics;
+ private final URI fontFileURI;
+
/**
* The java name of the font.
* # Make the family name immutable.
@@ -63,14 +66,24 @@ public class SystemFontMetricsMapper extends Typeface implements FontMetricsMapp
* @param java2DFontMetrics metric calculations delegated to this
*/
public SystemFontMetricsMapper(String family, int style, Java2DFontMetrics java2DFontMetrics) {
+ URI uri;
+ try {
+ uri = new URI("system:" + family.toLowerCase());
+ } catch (java.net.URISyntaxException e) {
+ uri = null;
+ }
+ this.fontFileURI = uri;
this.family = family;
-
this.style = style;
-
this.java2DFontMetrics = java2DFontMetrics;
}
/** {@inheritDoc} */
+ public final URI getFontURI() {
+ return null;
+ }
+
+ /** {@inheritDoc} */
public String getFontName() {
return family;
}
diff --git a/src/java/org/apache/fop/render/pcl/PCLGraphics2D.java b/src/java/org/apache/fop/render/pcl/PCLGraphics2D.java
index 93648e975..d349394c5 100644
--- a/src/java/org/apache/fop/render/pcl/PCLGraphics2D.java
+++ b/src/java/org/apache/fop/render/pcl/PCLGraphics2D.java
@@ -120,7 +120,7 @@ public class PCLGraphics2D extends AbstractGraphics2D {
* @param msg the error message to be displayed
*/
protected void handleUnsupportedFeature(String msg) {
- if (this.FAIL_ON_UNSUPPORTED_FEATURE) {
+ if (FAIL_ON_UNSUPPORTED_FEATURE) {
throw new UnsupportedOperationException(msg);
}
}
diff --git a/src/java/org/apache/fop/tools/fontlist/FontListMain.java b/src/java/org/apache/fop/tools/fontlist/FontListMain.java
index 794f9306f..af9921c4d 100644
--- a/src/java/org/apache/fop/tools/fontlist/FontListMain.java
+++ b/src/java/org/apache/fop/tools/fontlist/FontListMain.java
@@ -24,6 +24,7 @@ import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.OutputStream;
import java.io.PrintStream;
+import java.net.URI;
import java.net.URL;
import java.util.Iterator;
import java.util.List;
@@ -66,6 +67,7 @@ public final class FontListMain {
private FopFactory fopFactory;
+ private boolean verbose;
private File configFile;
private File outputFile;
private String configMime = MimeConstants.MIME_PDF;
@@ -168,22 +170,42 @@ public final class FontListMain {
private void writeToConsole(SortedMap fontFamilies)
throws TransformerConfigurationException, SAXException, IOException {
Iterator iter = fontFamilies.entrySet().iterator();
+ StringBuffer sb = new StringBuffer();
while (iter.hasNext()) {
Map.Entry entry = (Map.Entry)iter.next();
String firstFamilyName = (String)entry.getKey();
- System.out.println(firstFamilyName + ":");
+ sb.append(firstFamilyName);
+ sb.append(':');
+ sb.append('\n');
List list = (List)entry.getValue();
Iterator fonts = list.iterator();
while (fonts.hasNext()) {
FontSpec f = (FontSpec)fonts.next();
- System.out.println(" " + f.getKey() + " " + f.getFamilyNames());
+ sb.append(" ");
+ sb.append(f.getKey());
+ sb.append(' ');
+ sb.append(f.getFamilyNames());
+ if (verbose) {
+ URI uri = f.getFontMetrics().getFontURI();
+ if (uri != null) {
+ sb.append(' ');
+ sb.append('(');
+ sb.append(uri.toString());
+ sb.append(')');
+ }
+ }
+ sb.append('\n');
Iterator triplets = f.getTriplets().iterator();
while (triplets.hasNext()) {
FontTriplet triplet = (FontTriplet)triplets.next();
- System.out.println(" " + triplet.toString());
+ sb.append(" ");
+ sb.append(triplet.toString());
+ sb.append('\n');
}
}
}
+ System.out.print(sb.toString());
+ System.out.flush();
}
private void writeOutput(SortedMap fontFamilies)
@@ -231,7 +253,7 @@ public final class FontListMain {
PrintStream out = System.out;
out.println("USAGE");
out.println(" java [vmargs] " + className
- + " [-c <config-file>] [-f <mime>] [[output-dir|output-file] [font-family]]");
+ + "[-v] [-c <config-file>] [-f <mime>] [[output-dir|output-file] [font-family]]");
out.println();
out.println("PARAMETERS");
out.println(" config-file: an optional FOP configuration file");
@@ -260,6 +282,10 @@ public final class FontListMain {
// @SuppressFBWarnings("DM_EXIT")
System.exit(0);
}
+ if ("-v".equals(args[idx])) {
+ verbose = true;
+ idx += 1;
+ }
if (idx < args.length - 1 && "-c".equals(args[idx])) {
String filename = args[idx + 1];
this.configFile = new File(filename);