Hi
I am creating a PDF in my application using XSL:FO
Following are working perfectly in Windows server but when I deploy in linux
environment, the generation fails.
FOP Version : 0.95
*Config file *
<fonts>
<!-- Windows Dev environment configuration
<font metrics-url="/Arial.xml" kerning="yes"
embed-url="file:///C:/WINDOWS/ Fonts/arial.ttf">
<font-triplet name="Arial" style="normal" weight="normal"/>
<font-triplet name="ArialMT" style="normal" weight="normal"/>
<font-triplet name="arial" style="normal" weight="normal"/>
</font>
<font metrics-url="/ArialB.xml" kerning="yes"
embed-url="file:///C:/WINDOWS/Fonts/arialbd.ttf">
<font-triplet name="Arial" style="normal" weight="bold"/>
<font-triplet name="ArialMT" style="normal" weight="bold"/>
<font-triplet name="arial" style="normal" weight="bold"/>
</font> -->
<!-- UAT Configuration -->
<font metrics-url="/Arial.xml" kerning="yes"
embed-url="/usr/openwin/lib/X11/fonts/TrueType/Arial.ttf">
<font-triplet name="Arial" style="normal" weight="normal"/>
<font-triplet name="ArialMT" style="normal" weight="normal"/>
<font-triplet name="arial" style="normal" weight="normal"/>
</font>
<font metrics-url="/ArialB.xml" kerning="yes"
embed-url="/usr/openwin/lib/X11/fonts/TrueType/Arial-Bold.ttf">
<font-triplet name="Arial" style="normal" weight="bold"/>
<font-triplet name="ArialMT" style="normal" weight="bold"/>
<font-triplet name="arial" style="normal" weight="bold"/>
</font>
<auto-detect/>
</fonts>
*In XSL file*
For Normal display
<fo:block xsl:use-attribute-sets="Arial11"
xmlns:st1="urn:schemas-microsoft-com:office:smarttags">
<fo:leader/>
</fo:block>
For Bold Display
<fo:block xsl:use-attribute-sets="Arial11"
font-weight="bold" xmlns:st1="urn:schemas-microsoft-com:office:smarttags">
<fo:leader/>
</fo:block>
<xsl:attribute-set name="Arial11" >
<xsl:attribute name="font-size">0.95em</xsl:attribute>
<xsl:attribute name="font-family">Arial</xsl:attribute>
<xsl:attribute name="display-align">center</xsl:attribute>
<xsl:attribute name="language">EN-US</xsl:attribute>
</xsl:attribute-set>
*
On Console*
[2008-12-02 12:23:01,915] [pool-1-thread-12] ERROR FopDocumentRenderSystem -
javax.xml.transform.TransformerException: org.xml.sax.SAXException:
Mismatch: page-sequence (http://www.w3.org/1999/XSL/Format) vs. root (
http://www.w3.org/1999/XSL/Format)
Exception in thread "pool-1-thread-12"
com.marsh.itg.ddeepa.services.contract.bobject.exception.LogicExecutionException:
org.xml.sax.SAXException: Mismatch: page-sequence (
http://www.w3.org/1999/XSL/Format) vs. root (
http://www.w3.org/1999/XSL/Format)
at
com..blogic.document.utils.FopDocumentRenderSystem.renderDocument(FopDocumentRenderSystem.java:164)
at
com..blogic.document.utils.RenderSystemDocumentRenderer$RenderSystemInputStreamProvider$1.run(RenderSystemDocumentRenderer.java:75)
at
java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:650)
at
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:675)
at java.lang.Thread.run(Thread.java:595)
Metrics URL is created using the following command
java -cp
./fop-0.95-1.jar:./xmlgraphics-commons-1.3.1.jar:commons-logging-1.0.4.jar:./commons-io-1.3.1.jar
org.apache.fop.fonts.apps.TTFReader -enc ansi
/usr/openwin/lib/X11/fonts/TrueType/Arial.ttf Arial.xml
I tried to generate the file using with and without the -enc option. On
windows I found that only the file created with -enc works. Without the
option I get font error when PDF is generated on Windows and only dots
appear.
The autodetect feature loads all the fonts but substitute with "any" before
displaying.
After dicussion with Jeremias I made the following changes
Since 0.95 doesn't require embed file the new config file looks like
<font embed-url="/usr/openwin/lib/X11/fonts/TrueType/Arial.ttf">
<font-triplet name="Arial" style="normal" weight="normal"/>
<font-triplet name="ArialMT" style="normal" weight="normal"/>
<font-triplet name="arial" style="normal" weight="normal"/>
</font>
After making this change I got the following error
[2008-12-02 14:07:23,467] [pool-1-thread-1] ERROR LazyFont - Failed to read
font metrics file null
java.io.IOException: Cannot load font: failed to create InputStream from
Source for font file /usr/openwin/lib/X11/fonts/TrueType/Arial.ttf
at org.apache.fop.fonts.FontLoader.openFontUri(FontLoader.java:143)
at
org.apache.fop.fonts.truetype.TTFFontLoader.read(TTFFontLoader.java:54)
at org.apache.fop.fonts.FontLoader.getFont(FontLoader.java:164)
at org.apache.fop.fonts.FontLoader.loadFont(FontLoader.java:113)
at org.apache.fop.fonts.LazyFont.load(LazyFont.java:126)
at org.apache.fop.fonts.LazyFont.getAscender(LazyFont.java:233)
at org.apache.fop.fonts.Font.getAscender(Font.java:96)
at
org.apache.fop.layoutmgr.BlockLayoutManager.initialize(BlockLayoutManager.java:87)
at
org.apache.fop.layoutmgr.AbstractLayoutManager.getChildLM(AbstractLayoutManager.java:118)
at
org.apache.fop.layoutmgr.FlowLayoutManager.getNextKnuthElements(FlowLayoutManager.java:77)
at
org.apache.fop.layoutmgr.PageBreaker.getNextKnuthElements(PageBreaker.java:145)
at
org.apache.fop.layoutmgr.AbstractBreaker.getNextBlockList(AbstractBreaker.java:552)
at
org.apache.fop.layoutmgr.PageBreaker.getNextBlockList(PageBreaker.java:137)
at
org.apache.fop.layoutmgr.AbstractBreaker.doLayout(AbstractBreaker.java:302)
at
org.apache.fop.layoutmgr.AbstractBreaker.doLayout(AbstractBreaker.java:264)
at
org.apache.fop.layoutmgr.PageSequenceLayoutManager.activateLayout(PageSequenceLayoutManager.java:106)
at
org.apache.fop.area.AreaTreeHandler.endPageSequence(AreaTreeHandler.java:234)
at
org.apache.fop.fo.pagination.PageSequence.endOfNode(PageSequence.java:123)
at
org.apache.fop.fo.FOTreeBuilder$MainFOHandler.endElement(FOTreeBuilder.java:340)
at
org.apache.fop.fo.FOTreeBuilder.endElement(FOTreeBuilder.java:169)
at
org.apache.xalan.transformer.ResultTreeHandler.endElement(ResultTreeHandler.java:309)
at
org.apache.xalan.templates.ElemLiteralResult.execute(ElemLiteralResult.java:716)
at
org.apache.xalan.transformer.TransformerImpl.executeChildTemplates(TransformerImpl.java:2339)
at
org.apache.xalan.templates.ElemLiteralResult.execute(ElemLiteralResult.java:710)
at
org.apache.xalan.templates.ElemApplyTemplates.transformSelectedNodes(ElemApplyTemplates.java:425)
at
org.apache.xalan.templates.ElemApplyTemplates.execute(ElemApplyTemplates.java:216)
at
org.apache.xalan.transformer.TransformerImpl.executeChildTemplates(TransformerImpl.java:2339)
at
org.apache.xalan.transformer.TransformerImpl.applyTemplateToNode(TransformerImpl.java:2160)
at
org.apache.xalan.transformer.TransformerImpl.transformNode(TransformerImpl.java:1213)
at
org.apache.xalan.transformer.TransformerImpl.transform(TransformerImpl.java:668)
at
org.apache.xalan.transformer.TransformerImpl.transform(TransformerImpl.java:1129)
at
org.apache.xalan.transformer.TransformerImpl.transform(TransformerImpl.java:1107)
at
com.blogic.document.utils.FopDocumentRenderSystem.renderDocument(FopDocumentRenderSystem.java:159)
at
com.blocal.blogic.document.utils.RenderSystemDocumentRenderer$RenderSystemInputStreamProvider$1.run(RenderSystemDocumentRenderer.java:75)
at
java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:650)
at
java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:675)
at java.lang.Thread.run(Thread.java:595)
If I use the auto-detect feature, The PDF gets printed but on console I see
the warning. The Fonts are default Times font
[2008-12-02 14:12:58,331] [pool-1-thread-3] WARN FontInfo - Font
'Arial,normal,400' not found. Substituting with 'any,normal,400'.
I have double checked and am using fop 0.95 in my lib folder.
Any help will be appreciated.
Thanks
Ashish