diff options
author | Simon Pepping <spepping@apache.org> | 2006-05-19 15:10:44 +0000 |
---|---|---|
committer | Simon Pepping <spepping@apache.org> | 2006-05-19 15:10:44 +0000 |
commit | 276670d6bbb7cf51f8f8365675335f4ac945209e (patch) | |
tree | 00c0da5e3a75f667f2ea7085929b2475a8228f02 | |
parent | 5db46401762875432068ec08a6558213b80d540f (diff) | |
download | xmlgraphics-fop-276670d6bbb7cf51f8f8365675335f4ac945209e.tar.gz xmlgraphics-fop-276670d6bbb7cf51f8f8365675335f4ac945209e.zip |
An emergency patch to avoid that a non-breaking space at the end of an
fo:inline with padding, followed by another fo:inline, while
text-align is justify, does not cause a NullPointerException due to
InlineStackingLayoutManager.addALetterSpaceTo(). Patch submitted by
Max Berger <max@berger.name>, applied with some modifications. This
patch solves bug 39571.
git-svn-id: https://svn.apache.org/repos/asf/xmlgraphics/fop/trunk@407819 13f79535-47bb-0310-9956-ffa450edef68
3 files changed, 70 insertions, 4 deletions
diff --git a/src/java/org/apache/fop/layoutmgr/InlineKnuthSequence.java b/src/java/org/apache/fop/layoutmgr/InlineKnuthSequence.java index 0e48eb1ae..f66c0d119 100644 --- a/src/java/org/apache/fop/layoutmgr/InlineKnuthSequence.java +++ b/src/java/org/apache/fop/layoutmgr/InlineKnuthSequence.java @@ -140,7 +140,9 @@ public class InlineKnuthSequence extends KnuthSequence { addAll(((InlineLevelLayoutManager) prevBox.getLayoutManager()) .addALetterSpaceTo(oldList)); - if (((KnuthInlineBox) prevBox).isAnchor()) { + // prevBox may not be a KnuthInlineBox; + // this may happen if it is a padding box; see bug 39571. + if ( prevBox instanceof KnuthInlineBox && ((KnuthInlineBox) prevBox).isAnchor()) { // prevBox represents a footnote citation: copy footnote info // from prevBox to the new box KnuthInlineBox newBox = (KnuthInlineBox) getLast(); diff --git a/src/java/org/apache/fop/layoutmgr/inline/InlineStackingLayoutManager.java b/src/java/org/apache/fop/layoutmgr/inline/InlineStackingLayoutManager.java index 515caf578..b31fb8b42 100644 --- a/src/java/org/apache/fop/layoutmgr/inline/InlineStackingLayoutManager.java +++ b/src/java/org/apache/fop/layoutmgr/inline/InlineStackingLayoutManager.java @@ -292,9 +292,13 @@ public class InlineStackingLayoutManager extends AbstractLayoutManager element.setPosition(((NonLeafPosition)element.getPosition()).getPosition()); } - oldList = ((InlineLevelLayoutManager) - element.getLayoutManager()).addALetterSpaceTo(oldList); - + // The last element may not have a layout manager (its position == null); + // this may happen if it is a padding box; see bug 39571. + InlineLevelLayoutManager LM = + (InlineLevelLayoutManager) element.getLayoutManager(); + if (LM != null) { + oldList = LM.addALetterSpaceTo(oldList); + } // "wrap" again the Position stored in each element of oldList oldListIterator = oldList.listIterator(); while (oldListIterator.hasNext()) { diff --git a/test/layoutengine/standard-testcases/inline_letter-spacing_3.xml b/test/layoutengine/standard-testcases/inline_letter-spacing_3.xml new file mode 100644 index 000000000..daa17f026 --- /dev/null +++ b/test/layoutengine/standard-testcases/inline_letter-spacing_3.xml @@ -0,0 +1,60 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!-- + Copyright 2006 The Apache Software Foundation + + Licensed under the Apache License, Version 2.0 (the "License"); + you may not use this file except in compliance with the License. + You may obtain a copy of the License at + + http://www.apache.org/licenses/LICENSE-2.0 + + Unless required by applicable law or agreed to in writing, software + distributed under the License is distributed on an "AS IS" BASIS, + WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + See the License for the specific language governing permissions and + limitations under the License. +--> +<!-- $Id$ --> +<testcase> + <info> + <p> + This test checks that a non-breaking space at the end of an + fo:inline with padding, followed by another fo:inline, while + text-align is justify, does not cause a NullPointerException due + to InlineStackingLayoutManager.addALetterSpaceTo(). + </p> + <p>http://issues.apache.org/bugzilla/show_bug.cgi?id=39571</p> + </info> + <fo> + <fo:root + xmlns:fo="http://www.w3.org/1999/XSL/Format"> + <fo:layout-master-set> + <fo:simple-page-master master-name="small" + page-height="5cm" page-width="15cm" + margin-top="2cm" margin-bottom="2cm" + margin-left="2cm" margin-right="2cm"> + <fo:region-body/> + </fo:simple-page-master> + </fo:layout-master-set> + + <fo:page-sequence master-reference="small"> + <fo:flow flow-name="xsl-region-body" text-align="justify"> + <fo:block language="en" country="US"> + <fo:inline><fo:inline padding-end="1em">non-breaking </fo:inline><fo:inline>space</fo:inline></fo:inline> + </fo:block> + </fo:flow> + </fo:page-sequence> + </fo:root> + </fo> + <checks> + <eval expected="105384" +xpath="//flow/block[1]/lineArea[1]/inlineparent[1]/@ipd" desc="IPD of +containing inline area"/> + <eval expected="73368" +xpath="//flow/block[1]/lineArea[1]/inlineparent[1]/inlineparent[1]/@ipd" +desc="IPD of first contained inline area"/> + <eval expected="73368" +xpath="//flow/block[1]/lineArea[1]/inlineparent[1]/inlineparent[1]/text/@ipd" +desc="IPD of corresponding text area"/> + </checks> +</testcase> |