aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/codegen/font-file.xsl12
1 files changed, 7 insertions, 5 deletions
diff --git a/src/codegen/font-file.xsl b/src/codegen/font-file.xsl
index 184b656e0..96a6f8583 100644
--- a/src/codegen/font-file.xsl
+++ b/src/codegen/font-file.xsl
@@ -14,9 +14,9 @@ file charlist.xml and extracts the WinAnsi code.
extension-element-prefixes="redirect">
<xsl:output method="text" />
-<!-- note that match in xsl:key doesn't like document('charlist.xml'), so the charlist
- must be merged with the source xml at build time by the Xslt task -->
-<xsl:key name="adobe-char-map" match="/font-metrics/font-mappings/map" use="@adobe-name"/>
+
+<!-- Note: this key is used with charlist.xml in a for-each. -->
+<xsl:key name="adobe-char-map" match="map" use="@adobe-name"/>
<xsl:template match="font-metrics">
<xsl:variable name="class-name" select="class-name"/>
@@ -38,8 +38,10 @@ public class <xsl:value-of select="class-name"/> extends Font {
static {
width = new int[256];
-<xsl:for-each select="widths/char"><xsl:variable name="char-name" select="@name"/><xsl:variable name="char-num" select="key('adobe-char-map',$char-name)/@win-ansi"/><xsl:if test="$char-num!='-1'"> width[<xsl:value-of select="$char-num"/>] = <xsl:value-of select="@width"/>;
-</xsl:if></xsl:for-each>
+<xsl:for-each select="widths/char"><xsl:variable name="char-name" select="@name"/><xsl:variable name="char-width" select="@width"/>
+<xsl:for-each select="document('charlist.xml')"><xsl:variable name="char-num" select="key('adobe-char-map',$char-name)/@win-ansi"/>
+<xsl:if test="$char-num!='-1'"> width[<xsl:value-of select="$char-num"/>] = <xsl:value-of select="$char-width"/>;
+</xsl:if></xsl:for-each></xsl:for-each>
}
public String encoding() {