From: Simon Steiner Date: Wed, 16 Dec 2015 13:46:42 +0000 (+0000) Subject: FOP-2552: TrueType in AFP adding extra slash to end of font uri X-Git-Tag: fop-2_1~20 X-Git-Url: https://source.dussan.org/?a=commitdiff_plain;h=7c9270c7ba0af0c4f6bb038d4b53fe6ad239c8c9;p=xmlgraphics-fop.git FOP-2552: TrueType in AFP adding extra slash to end of font uri git-svn-id: https://svn.apache.org/repos/asf/xmlgraphics/fop/trunk@1720357 13f79535-47bb-0310-9956-ffa450edef68 --- diff --git a/src/foschema/fop-configuration.xsd b/src/foschema/fop-configuration.xsd index d3c0b3885..bd1c20d08 100644 --- a/src/foschema/fop-configuration.xsd +++ b/src/foschema/fop-configuration.xsd @@ -290,6 +290,7 @@ + diff --git a/src/java/org/apache/fop/afp/AFPResourceManager.java b/src/java/org/apache/fop/afp/AFPResourceManager.java index d4df8daab..f5910d7d9 100644 --- a/src/java/org/apache/fop/afp/AFPResourceManager.java +++ b/src/java/org/apache/fop/afp/AFPResourceManager.java @@ -338,7 +338,8 @@ public class AFPResourceManager { AFPResourceAccessor accessor = charSet.getResourceAccessor(); if (afpFont.getFontType() == FontType.TRUETYPE) { - createIncludedResource(afpFont.getFontName(), accessor.resolveURI("."), accessor, + createIncludedResource(afpFont.getFontName(), + ((AFPFontConfig.AFPTrueTypeFont) afpFont).getUri(), accessor, ResourceObject.TYPE_OBJECT_CONTAINER, true, ((AFPFontConfig.AFPTrueTypeFont) afpFont).getTTC()); } else { @@ -414,12 +415,7 @@ public class AFPResourceManager { ActiveEnvironmentGroup.setupTruetypeMDR(res, false); ObjectContainer oc = factory.createObjectContainer(); - InputStream is; - try { - is = accessor.createInputStream(new URI(".")); - } catch (URISyntaxException e) { - throw new IOException(e); - } + InputStream is = accessor.createInputStream(uri); if (ttc != null) { oc.setData(extractTTC(ttc, is)); diff --git a/src/java/org/apache/fop/render/afp/AFPFontConfig.java b/src/java/org/apache/fop/render/afp/AFPFontConfig.java index 341123331..35b2cc3f5 100644 --- a/src/java/org/apache/fop/render/afp/AFPFontConfig.java +++ b/src/java/org/apache/fop/render/afp/AFPFontConfig.java @@ -364,41 +364,45 @@ public final class AFPFontConfig implements FontConfig { static final class TrueTypeFontConfig extends AFPFontConfigData { private String characterset; private String subfont; + private String fontUri; private TrueTypeFontConfig(List triplets, String type, String codePage, String encoding, String characterset, String name, String subfont, boolean embeddable, String uri) { - super(triplets, type, codePage, encoding, name, embeddable, uri); + super(triplets, type, codePage, encoding, name, embeddable, null); this.characterset = characterset; this.subfont = subfont; + this.fontUri = uri; } @Override AFPFontInfo getFontInfo(InternalResourceResolver resourceResolver, AFPEventProducer eventProducer) throws IOException { - Typeface tf; try { - tf = new LazyFont(new EmbedFontInfo( - new FontUris(new URI(uri), null) + Typeface tf = new LazyFont(new EmbedFontInfo( + new FontUris(new URI(fontUri), null) , false, true, null, subfont), resourceResolver, false).getRealFont(); + + AFPResourceAccessor accessor = getAccessor(resourceResolver); + CharacterSet characterSet = CharacterSetBuilder.getDoubleByteInstance().build(characterset, + super.codePage, super.encoding, tf, accessor, eventProducer); + OutlineFont font = new AFPTrueTypeFont(super.name, super.embeddable, characterSet, + eventProducer, subfont, new URI(fontUri)); + return getFontInfo(font, this); } catch (URISyntaxException e) { throw new IOException(e); } - AFPResourceAccessor accessor = getAccessor(resourceResolver); - CharacterSet characterSet = CharacterSetBuilder.getDoubleByteInstance().build(characterset, super.codePage, - super.encoding, tf, accessor, eventProducer); - OutlineFont font = new AFPTrueTypeFont(super.name, super.embeddable, characterSet, - eventProducer, subfont); - return getFontInfo(font, this); } } public static class AFPTrueTypeFont extends OutlineFont { private String ttc; + private URI uri; public AFPTrueTypeFont(String name, boolean embeddable, CharacterSet charSet, AFPEventProducer eventProducer, - String ttc) { + String ttc, URI uri) { super(name, embeddable, charSet, eventProducer); this.ttc = ttc; + this.uri = uri; } public FontType getFontType() { @@ -408,6 +412,10 @@ public final class AFPFontConfig implements FontConfig { public String getTTC() { return ttc; } + + public URI getUri() { + return uri; + } } static final class OutlineFontConfig extends AFPFontConfigData { diff --git a/test/java/org/apache/fop/render/afp/AFPTrueTypeTestCase.java b/test/java/org/apache/fop/render/afp/AFPTrueTypeTestCase.java index 6e6bbfe94..333a23983 100644 --- a/test/java/org/apache/fop/render/afp/AFPTrueTypeTestCase.java +++ b/test/java/org/apache/fop/render/afp/AFPTrueTypeTestCase.java @@ -24,6 +24,9 @@ import java.io.ByteArrayOutputStream; import java.io.File; import java.io.IOException; import java.io.InputStream; +import java.io.OutputStream; +import java.net.URI; +import java.net.URISyntaxException; import javax.xml.transform.Result; import javax.xml.transform.Source; @@ -40,17 +43,22 @@ import org.xml.sax.SAXException; import static org.mockito.Mockito.mock; import static org.mockito.Mockito.when; +import org.apache.xmlgraphics.io.Resource; +import org.apache.xmlgraphics.io.ResourceResolver; + import org.apache.fop.afp.AFPPaintingState; import org.apache.fop.afp.AFPResourceManager; import org.apache.fop.afp.DataStream; import org.apache.fop.afp.Factory; import org.apache.fop.afp.fonts.FopCharacterSet; import org.apache.fop.afp.modca.PageObject; +import org.apache.fop.apps.EnvironmentalProfileFactory; import org.apache.fop.apps.FOUserAgent; import org.apache.fop.apps.Fop; import org.apache.fop.apps.FopConfParser; import org.apache.fop.apps.FopFactory; import org.apache.fop.apps.FopFactoryBuilder; +import org.apache.fop.apps.io.ResourceResolverFactory; import org.apache.fop.fonts.EmbeddingMode; import org.apache.fop.fonts.FontInfo; import org.apache.fop.fonts.FontTriplet; @@ -60,8 +68,10 @@ import org.apache.fop.render.intermediate.IFException; import junit.framework.Assert; public class AFPTrueTypeTestCase { + private String font; + @Test - public void testAFPTrueType() throws IOException, SAXException, TransformerException { + public void testAFPTrueType() throws IOException, SAXException, TransformerException, URISyntaxException { String fopxconf = "\n" + " \n" + " \n" @@ -88,7 +98,9 @@ public class AFPTrueTypeTestCase { + ""; FopFactoryBuilder confBuilder = new FopConfParser( - new ByteArrayInputStream(fopxconf.getBytes()), new File(".").toURI()).getFopFactoryBuilder(); + new ByteArrayInputStream(fopxconf.getBytes()), + EnvironmentalProfileFactory.createRestrictedIO(new URI("."), + new MyResourceResolver())).getFopFactoryBuilder(); FopFactory fopFactory = confBuilder.build(); FOUserAgent foUserAgent = fopFactory.newFOUserAgent(); ByteArrayOutputStream bos = new ByteArrayOutputStream(); @@ -131,6 +143,22 @@ public class AFPTrueTypeTestCase { + "END DOCUMENT DOC00001\n"; Assert.assertEquals(sb.toString(), format); + Assert.assertEquals("test/resources/fonts/ttf/DejaVuLGCSerif.ttf", font); + } + + class MyResourceResolver implements ResourceResolver { + private ResourceResolver defaultResourceResolver = ResourceResolverFactory.createDefaultResourceResolver(); + public Resource getResource(URI uri) throws IOException { + if (!"tmp".equals(uri.getScheme())) { + font = uri.getPath(); + uri = new File(".", uri.getPath()).toURI(); + } + return defaultResourceResolver.getResource(uri); + } + + public OutputStream getOutputStream(URI uri) throws IOException { + return defaultResourceResolver.getOutputStream(uri); + } } @Test @@ -174,7 +202,7 @@ public class AFPTrueTypeTestCase { MultiByteFont font = new MultiByteFont(null, EmbeddingMode.AUTO); font.setWidthArray(new int[100]); f.addMetrics("any", new AFPFontConfig.AFPTrueTypeFont("", true, - new FopCharacterSet("", "UTF-16BE", "", font, null, null), null, null)); + new FopCharacterSet("", "UTF-16BE", "", font, null, null), null, null, null)); return f; } }