aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSimon Pepping <spepping@apache.org>2006-05-19 15:10:44 +0000
committerSimon Pepping <spepping@apache.org>2006-05-19 15:10:44 +0000
commit276670d6bbb7cf51f8f8365675335f4ac945209e (patch)
tree00c0da5e3a75f667f2ea7085929b2475a8228f02
parent5db46401762875432068ec08a6558213b80d540f (diff)
downloadxmlgraphics-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
-rw-r--r--src/java/org/apache/fop/layoutmgr/InlineKnuthSequence.java4
-rw-r--r--src/java/org/apache/fop/layoutmgr/inline/InlineStackingLayoutManager.java10
-rw-r--r--test/layoutengine/standard-testcases/inline_letter-spacing_3.xml60
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&#xA0;</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>