[
https://issues.apache.org/jira/browse/FOP-2977?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17258427#comment-17258427
]
Kelly H Wilkerson edited comment on FOP-2977 at 1/4/21, 6:58 PM:
-----------------------------------------------------------------
Looks like there's more I need to add to this patch, since with this patch
there are more exceptions if the font has GPOS adjustments. But I haven't
recreated this crash yet to fix it.
{{java.lang.ArrayIndexOutOfBoundsException: Index 3 out of bounds for length 3}}
{{at
org.apache.fop.complexscripts.fonts.GlyphPositioningTable$MarkToLigatureSubtableFormat1.getLigatureAnchor([GlyphPositioningTable.java:974|http://glyphpositioningtable.java:974/])}}
{{at
org.apache.fop.complexscripts.fonts.GlyphPositioningTable$MarkToLigatureSubtable.position([GlyphPositioningTable.java:886|http://glyphpositioningtable.java:886/])}}
{{at
org.apache.fop.complexscripts.fonts.GlyphPositioningState.apply([GlyphPositioningState.java:170|http://glyphpositioningstate.java:170/])}}
{{at
org.apache.fop.complexscripts.fonts.GlyphPositioningSubtable.position([GlyphPositioningSubtable.java:94|http://glyphpositioningsubtable.java:94/])}}
{{at
org.apache.fop.complexscripts.fonts.GlyphPositioningSubtable.position([GlyphPositioningSubtable.java:126|http://glyphpositioningsubtable.java:126/])}}
{{at
org.apache.fop.complexscripts.fonts.GlyphTable$LookupTable.position([GlyphTable.java:675|http://glyphtable.java:675/])}}
{{at
org.apache.fop.complexscripts.fonts.GlyphTable$UseSpec.position([GlyphTable.java:816|http://glyphtable.java:816/])}}
{{at
org.apache.fop.complexscripts.scripts.ScriptProcessor.position([ScriptProcessor.java:191|http://scriptprocessor.java:191/])}}
{{at
org.apache.fop.complexscripts.scripts.ScriptProcessor.position([ScriptProcessor.java:171|http://scriptprocessor.java:171/])}}
{{at
org.apache.fop.complexscripts.fonts.GlyphPositioningTable.position([GlyphPositioningTable.java:239|http://glyphpositioningtable.java:239/])}}
{{at
org.apache.fop.fonts.MultiByteFont.performPositioning([MultiByteFont.java:611|http://multibytefont.java:611/])}}
{{at
org.apache.fop.fonts.LazyFont.performPositioning([LazyFont.java:471|http://lazyfont.java:471/])}}
{{at
org.apache.fop.fonts.Font.performPositioning([Font.java:502|http://font.java:502/])}}
{{at
org.apache.fop.fonts.Font.performPositioning([Font.java:510|http://font.java:510/])}}
{{at
org.apache.fop.fonts.GlyphMapping.processWordMapping([GlyphMapping.java:147|http://glyphmapping.java:147/])}}
{{at
org.apache.fop.fonts.GlyphMapping.doGlyphMapping([GlyphMapping.java:92|http://glyphmapping.java:92/])}}
was (Author: kwilkerson):
Looks like there's more I need to add to this patch, since with this patch
there are more exceptions if the font has GPOS adjustments. But I haven't
recreated this crash yet to fix it.
java.lang.ArrayIndexOutOfBoundsException: Index 3 out of bounds for length 3
at
org.apache.fop.complexscripts.fonts.GlyphPositioningTable$MarkToLigatureSubtableFormat1.getLigatureAnchor(GlyphPositioningTable.java:974)
at
org.apache.fop.complexscripts.fonts.GlyphPositioningTable$MarkToLigatureSubtable.position(GlyphPositioningTable.java:886)
at
org.apache.fop.complexscripts.fonts.GlyphPositioningState.apply(GlyphPositioningState.java:170)
at
org.apache.fop.complexscripts.fonts.GlyphPositioningSubtable.position(GlyphPositioningSubtable.java:94)
at
org.apache.fop.complexscripts.fonts.GlyphPositioningSubtable.position(GlyphPositioningSubtable.java:126)
at
org.apache.fop.complexscripts.fonts.GlyphTable$LookupTable.position(GlyphTable.java:675)
at
org.apache.fop.complexscripts.fonts.GlyphTable$UseSpec.position(GlyphTable.java:816)
at
org.apache.fop.complexscripts.scripts.ScriptProcessor.position(ScriptProcessor.java:191)
at
org.apache.fop.complexscripts.scripts.ScriptProcessor.position(ScriptProcessor.java:171)
at
org.apache.fop.complexscripts.fonts.GlyphPositioningTable.position(GlyphPositioningTable.java:239)
at
org.apache.fop.fonts.MultiByteFont.performPositioning(MultiByteFont.java:611)
at org.apache.fop.fonts.LazyFont.performPositioning(LazyFont.java:471)
at org.apache.fop.fonts.Font.performPositioning(Font.java:502)
at org.apache.fop.fonts.Font.performPositioning(Font.java:510)
at org.apache.fop.fonts.GlyphMapping.processWordMapping(GlyphMapping.java:147)
at org.apache.fop.fonts.GlyphMapping.doGlyphMapping(GlyphMapping.java:92)
> [PATCH] Array index out of bounds with glyph position adjustments and
> surrogate pairs
> -------------------------------------------------------------------------------------
>
> Key: FOP-2977
> URL: https://issues.apache.org/jira/browse/FOP-2977
> Project: FOP
> Issue Type: Bug
> Components: renderer/pdf
> Affects Versions: trunk
> Environment: Windows 10
> Reporter: Kelly H Wilkerson
> Priority: Minor
> Attachments: arrayindex.patch, drawTextWithDX.patch, input.fo
>
>
> Out of bounds happens in org.apache.fop.fonts.GlyphMapping.processWordMapping
> when:
> # There are glyph position adjustments for the font being used
> # There are surrogate pairs in the text that has adjustments
> The font I've used to reproduce the issue so far is Segoe UI Emoji, which
> should be installed on Windows 10 by default.
> input.fo attached to cause the crash.
> I believe I've fixed the crash in the attached patch.
> There's a separate issue demonstrated in the input.fo that the glyphs don't
> render in some cases, even though the font is the same throughout everything.
> But I'd like to make sure my fix for the crash is correct before I dig into
> the rendering issue.
> {code:java}
> org.apache.fop.apps.FOPException: java.lang.ArrayIndexOutOfBoundsException: 3
> javax.xml.transform.TransformerException:
> java.lang.ArrayIndexOutOfBoundsException: 3
> at org.apache.fop.cli.InputHandler.transformTo(InputHandler.java:296)
> at org.apache.fop.cli.InputHandler.renderTo(InputHandler.java:116)
> at org.apache.fop.cli.Main.startFOP(Main.java:183)
> at org.apache.fop.cli.Main.main(Main.java:214)
> Caused by: javax.xml.transform.TransformerException:
> java.lang.ArrayIndexOutOfBoundsException: 3
> at
> com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transform(TransformerImpl.java:737)
> at
> com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transform(TransformerImpl.java:343)
> at org.apache.fop.cli.InputHandler.transformTo(InputHandler.java:293)
> ... 3 more
> Caused by: java.lang.ArrayIndexOutOfBoundsException: 3
> at
> org.apache.fop.fonts.GlyphMapping.processWordMapping(GlyphMapping.java:177)
> at
> org.apache.fop.fonts.GlyphMapping.doGlyphMapping(GlyphMapping.java:92)
> at
> org.apache.fop.layoutmgr.inline.TextLayoutManager.processWord(TextLayoutManager.java:963)
> at
> org.apache.fop.layoutmgr.inline.TextLayoutManager.getNextKnuthElements(TextLayoutManager.java:881)
> at
> org.apache.fop.layoutmgr.inline.LineLayoutManager.collectInlineKnuthElements(LineLayoutManager.java:698)
> at
> org.apache.fop.layoutmgr.inline.LineLayoutManager.getNextKnuthElements(LineLayoutManager.java:627)
> at
> org.apache.fop.layoutmgr.BlockLayoutManager.getNextChildElements(BlockLayoutManager.java:141)
> at
> org.apache.fop.layoutmgr.BlockStackingLayoutManager.getNextKnuthElements(BlockStackingLayoutManager.java:292)
> at
> org.apache.fop.layoutmgr.BlockLayoutManager.getNextKnuthElements(BlockLayoutManager.java:113)
> at
> org.apache.fop.layoutmgr.BlockLayoutManager.getNextKnuthElements(BlockLayoutManager.java:105)
> at
> org.apache.fop.layoutmgr.BlockLayoutManager.getNextChildElements(BlockLayoutManager.java:141)
> at
> org.apache.fop.layoutmgr.BlockStackingLayoutManager.getNextKnuthElements(BlockStackingLayoutManager.java:292)
> at
> org.apache.fop.layoutmgr.BlockLayoutManager.getNextKnuthElements(BlockLayoutManager.java:113)
> at
> org.apache.fop.layoutmgr.BlockLayoutManager.getNextKnuthElements(BlockLayoutManager.java:105)
> at
> org.apache.fop.layoutmgr.FlowLayoutManager.getNextChildElements(FlowLayoutManager.java:223)
> at
> org.apache.fop.layoutmgr.FlowLayoutManager.addChildElements(FlowLayoutManager.java:148)
> at
> org.apache.fop.layoutmgr.FlowLayoutManager.getNextKnuthElements(FlowLayoutManager.java:116)
> at
> org.apache.fop.layoutmgr.FlowLayoutManager.getNextKnuthElements(FlowLayoutManager.java:69)
> at
> org.apache.fop.layoutmgr.PageBreaker.getNextKnuthElements(PageBreaker.java:252)
> at
> org.apache.fop.layoutmgr.AbstractBreaker.getNextBlockList(AbstractBreaker.java:675)
> at
> org.apache.fop.layoutmgr.PageBreaker.getNextBlockList(PageBreaker.java:179)
> at
> org.apache.fop.layoutmgr.PageBreaker.getNextBlockList(PageBreaker.java:159)
> at
> org.apache.fop.layoutmgr.AbstractBreaker.doLayout(AbstractBreaker.java:385)
> at org.apache.fop.layoutmgr.PageBreaker.doLayout(PageBreaker.java:113)
> at
> org.apache.fop.layoutmgr.PageSequenceLayoutManager.activateLayout(PageSequenceLayoutManager.java:143)
> at
> org.apache.fop.area.AreaTreeHandler.endPageSequence(AreaTreeHandler.java:267)
> at
> org.apache.fop.fo.pagination.PageSequence.endOfNode(PageSequence.java:139)
> at
> org.apache.fop.fo.FOTreeBuilder$MainFOHandler.endElement(FOTreeBuilder.java:362)
> at org.apache.fop.fo.FOTreeBuilder.endElement(FOTreeBuilder.java:190)
> at
> com.sun.org.apache.xml.internal.serializer.ToXMLSAXHandler.endElement(ToXMLSAXHandler.java:265)
> at org.apache.xerces.parsers.AbstractSAXParser.endElement(Unknown
> Source)
> at org.apache.xerces.xinclude.XIncludeHandler.endElement(Unknown Source)
> at
> org.apache.xerces.impl.XMLNSDocumentScannerImpl.scanEndElement(Unknown Source)
> at
> org.apache.xerces.impl.XMLDocumentFragmentScannerImpl$FragmentContentDispatcher.dispatch(Unknown
> Source)
> at
> org.apache.xerces.impl.XMLDocumentFragmentScannerImpl.scanDocument(Unknown
> Source)
> at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source)
> at org.apache.xerces.parsers.XML11Configuration.parse(Unknown Source)
> at org.apache.xerces.parsers.XMLParser.parse(Unknown Source)
> at org.apache.xerces.parsers.AbstractSAXParser.parse(Unknown Source)
> at org.apache.xerces.jaxp.SAXParserImpl$JAXPSAXParser.parse(Unknown
> Source)
> at
> com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transformIdentity(TransformerImpl.java:659)
> at
> com.sun.org.apache.xalan.internal.xsltc.trax.TransformerImpl.transform(TransformerImpl.java:728)
> ... 5 more
> {code}
--
This message was sent by Atlassian Jira
(v8.3.4#803005)