aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJeremias Maerki <jeremias@apache.org>2006-01-19 15:10:14 +0000
committerJeremias Maerki <jeremias@apache.org>2006-01-19 15:10:14 +0000
commit4a34763794b0293bbcf74a08f34d0035aeff61fe (patch)
tree5fbd7a0fd8b310a4ee4343fe697189f9131939eb
parent9a01ca2474cad035c82810d6b541cde6dbd896aa (diff)
downloadxmlgraphics-fop-4a34763794b0293bbcf74a08f34d0035aeff61fe.tar.gz
xmlgraphics-fop-4a34763794b0293bbcf74a08f34d0035aeff61fe.zip
Following a clarification by the XSL FO SG, space traits are only set on the first and last area generated by an FO, and not on every area anymore.
For details, see: http://wiki.apache.org/xmlgraphics-fop/XslFoSpecificationUncertainties/SpaceTraits Note: this change brings another issue in column balancing to light. That's the reason for disabling one of the tests. I wasn't able to find a quick fix there. git-svn-id: https://svn.apache.org/repos/asf/xmlgraphics/fop/trunk@370494 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r--src/java/org/apache/fop/layoutmgr/BlockContainerLayoutManager.java12
-rw-r--r--src/java/org/apache/fop/layoutmgr/BlockLayoutManager.java4
-rw-r--r--src/java/org/apache/fop/layoutmgr/BlockStackingLayoutManager.java34
-rw-r--r--src/java/org/apache/fop/layoutmgr/list/ListBlockLayoutManager.java4
-rw-r--r--src/java/org/apache/fop/layoutmgr/list/ListItemLayoutManager.java4
-rw-r--r--src/java/org/apache/fop/layoutmgr/table/TableLayoutManager.java12
-rw-r--r--status.xml4
-rwxr-xr-xtest/layoutengine/disabled-testcases.xml5
-rw-r--r--test/layoutengine/standard-testcases/block-container_space-before_space-after_1.xml24
-rw-r--r--test/layoutengine/standard-testcases/block-container_space-before_space-after_2.xml29
-rw-r--r--test/layoutengine/standard-testcases/block_space-before_space-after_2.xml24
-rw-r--r--test/layoutengine/standard-testcases/block_space-before_space-after_4.xml20
-rw-r--r--test/layoutengine/standard-testcases/block_space-before_space-after_6.xml6
-rw-r--r--test/layoutengine/standard-testcases/list-block_space-before_space-after_1.xml34
-rw-r--r--test/layoutengine/standard-testcases/table_space-before_space-after_1.xml32
-rw-r--r--test/layoutengine/standard-testcases/table_space-before_space-after_2.xml29
16 files changed, 69 insertions, 208 deletions
diff --git a/src/java/org/apache/fop/layoutmgr/BlockContainerLayoutManager.java b/src/java/org/apache/fop/layoutmgr/BlockContainerLayoutManager.java
index 455a7d8fc..658a92e0d 100644
--- a/src/java/org/apache/fop/layoutmgr/BlockContainerLayoutManager.java
+++ b/src/java/org/apache/fop/layoutmgr/BlockContainerLayoutManager.java
@@ -129,8 +129,8 @@ public class BlockContainerLayoutManager extends BlockStackingLayoutManager
this.discardBorderAfter = false;
this.discardPaddingBefore = false;
this.discardPaddingAfter = false;
- this.effSpaceBefore = foSpaceBefore;
- this.effSpaceAfter = foSpaceAfter;
+ this.effSpaceBefore = null;
+ this.effSpaceAfter = null;
}
/** @return the content IPD */
@@ -241,17 +241,19 @@ public class BlockContainerLayoutManager extends BlockStackingLayoutManager
LinkedList contentList = new LinkedList();
LinkedList returnList = new LinkedList();
- if (!bBreakBeforeServed) {
+ if (!breakBeforeServed) {
try {
if (addKnuthElementsForBreakBefore(returnList, context)) {
return returnList;
}
} finally {
- bBreakBeforeServed = true;
+ breakBeforeServed = true;
}
}
- addKnuthElementsForSpaceBefore(returnList, alignment);
+ if (!firstVisibleMarkServed) {
+ addKnuthElementsForSpaceBefore(returnList, alignment);
+ }
addKnuthElementsForBorderPaddingBefore(returnList, !firstVisibleMarkServed);
firstVisibleMarkServed = true;
diff --git a/src/java/org/apache/fop/layoutmgr/BlockLayoutManager.java b/src/java/org/apache/fop/layoutmgr/BlockLayoutManager.java
index 0db92b30f..a303f18fd 100644
--- a/src/java/org/apache/fop/layoutmgr/BlockLayoutManager.java
+++ b/src/java/org/apache/fop/layoutmgr/BlockLayoutManager.java
@@ -110,8 +110,8 @@ public class BlockLayoutManager extends BlockStackingLayoutManager
this.discardBorderAfter = false;
this.discardPaddingBefore = false;
this.discardPaddingAfter = false;
- this.effSpaceBefore = foSpaceBefore;
- this.effSpaceAfter = foSpaceAfter;
+ this.effSpaceBefore = null;
+ this.effSpaceAfter = null;
}
/**
diff --git a/src/java/org/apache/fop/layoutmgr/BlockStackingLayoutManager.java b/src/java/org/apache/fop/layoutmgr/BlockStackingLayoutManager.java
index c09ae8ae5..eb7a2599c 100644
--- a/src/java/org/apache/fop/layoutmgr/BlockStackingLayoutManager.java
+++ b/src/java/org/apache/fop/layoutmgr/BlockStackingLayoutManager.java
@@ -55,7 +55,7 @@ public abstract class BlockStackingLayoutManager extends AbstractLayoutManager
/** Only used to store the original list when createUnitElements is called */
protected LinkedList storedList = null;
/** Indicates whether break before has been served or not */
- protected boolean bBreakBeforeServed = false;
+ protected boolean breakBeforeServed = false;
/** Indicates whether the first visible mark has been returned by this LM, yet */
protected boolean firstVisibleMarkServed = false;
/** Reference IPD available */
@@ -235,17 +235,19 @@ public abstract class BlockStackingLayoutManager extends AbstractLayoutManager
LinkedList contentList = new LinkedList();
LinkedList returnList = new LinkedList();
- if (!bBreakBeforeServed) {
+ if (!breakBeforeServed) {
try {
if (addKnuthElementsForBreakBefore(returnList, context)) {
return returnList;
}
} finally {
- bBreakBeforeServed = true;
+ breakBeforeServed = true;
}
}
- addKnuthElementsForSpaceBefore(returnList, alignment);
+ if (!firstVisibleMarkServed) {
+ addKnuthElementsForSpaceBefore(returnList, alignment);
+ }
addKnuthElementsForBorderPaddingBefore(returnList, !firstVisibleMarkServed);
firstVisibleMarkServed = true;
@@ -316,18 +318,10 @@ public abstract class BlockStackingLayoutManager extends AbstractLayoutManager
// blocks
contentList.add(new BreakElement(
new Position(this), KnuthElement.INFINITE, context));
- /*
- contentList.add(new KnuthPenalty(0,
- KnuthElement.INFINITE, false,
- new Position(this), false));
- */
} else if (!((ListElement) contentList.getLast()).isGlue()) {
// add a null penalty to allow a break between blocks
contentList.add(new BreakElement(
new Position(this), 0, context));
- /*
- contentList.add(new KnuthPenalty(0, 0, false,
- new Position(this), false));*/
} else {
// the last element in contentList is a glue;
// it is a feasible breakpoint, there is no need to add
@@ -763,22 +757,6 @@ public abstract class BlockStackingLayoutManager extends AbstractLayoutManager
* @param context the layout context
*/
protected void addPendingMarks(LayoutContext context) {
- SpaceProperty spaceBefore = getSpaceBeforeProperty();
- if (spaceBefore != null
- && !(spaceBefore.getMinimum(this).getLength().getValue(this) == 0
- && spaceBefore.getMaximum(this).getLength().getValue(this) == 0)) {
- context.addPendingBeforeMark(new SpaceElement(getAuxiliaryPosition(), spaceBefore,
- RelSide.BEFORE,
- true, false, this));
- }
- SpaceProperty spaceAfter = getSpaceAfterProperty();
- if (spaceAfter != null
- && !(spaceAfter.getMinimum(this).getLength().getValue(this) == 0
- && spaceAfter.getMaximum(this).getLength().getValue(this) == 0)) {
- context.addPendingAfterMark(new SpaceElement(getAuxiliaryPosition(), spaceAfter,
- RelSide.AFTER,
- false, true, this));
- }
CommonBorderPaddingBackground borderAndPadding = getBorderPaddingBackground();
if (borderAndPadding != null) {
if (borderAndPadding.getBorderBeforeWidth(false) > 0) {
diff --git a/src/java/org/apache/fop/layoutmgr/list/ListBlockLayoutManager.java b/src/java/org/apache/fop/layoutmgr/list/ListBlockLayoutManager.java
index dcedfdbcb..e23639e0d 100644
--- a/src/java/org/apache/fop/layoutmgr/list/ListBlockLayoutManager.java
+++ b/src/java/org/apache/fop/layoutmgr/list/ListBlockLayoutManager.java
@@ -109,8 +109,8 @@ public class ListBlockLayoutManager extends BlockStackingLayoutManager
this.discardBorderAfter = false;
this.discardPaddingBefore = false;
this.discardPaddingAfter = false;
- this.effSpaceBefore = foSpaceBefore;
- this.effSpaceAfter = foSpaceAfter;
+ this.effSpaceBefore = null;
+ this.effSpaceAfter = null;
}
/** @see org.apache.fop.layoutmgr.BlockStackingLayoutManager */
diff --git a/src/java/org/apache/fop/layoutmgr/list/ListItemLayoutManager.java b/src/java/org/apache/fop/layoutmgr/list/ListItemLayoutManager.java
index 2dd7020a7..c402f37ae 100644
--- a/src/java/org/apache/fop/layoutmgr/list/ListItemLayoutManager.java
+++ b/src/java/org/apache/fop/layoutmgr/list/ListItemLayoutManager.java
@@ -168,8 +168,8 @@ public class ListItemLayoutManager extends BlockStackingLayoutManager
this.discardBorderAfter = false;
this.discardPaddingBefore = false;
this.discardPaddingAfter = false;
- this.effSpaceBefore = foSpaceBefore;
- this.effSpaceAfter = foSpaceAfter;
+ this.effSpaceBefore = null;
+ this.effSpaceAfter = null;
}
/** @see org.apache.fop.layoutmgr.LayoutManager */
diff --git a/src/java/org/apache/fop/layoutmgr/table/TableLayoutManager.java b/src/java/org/apache/fop/layoutmgr/table/TableLayoutManager.java
index 5bfab332e..9aea85080 100644
--- a/src/java/org/apache/fop/layoutmgr/table/TableLayoutManager.java
+++ b/src/java/org/apache/fop/layoutmgr/table/TableLayoutManager.java
@@ -126,8 +126,8 @@ public class TableLayoutManager extends BlockStackingLayoutManager
this.discardBorderAfter = false;
this.discardPaddingBefore = false;
this.discardPaddingAfter = false;
- this.effSpaceBefore = foSpaceBefore;
- this.effSpaceAfter = foSpaceAfter;
+ this.effSpaceBefore = null;
+ this.effSpaceAfter = null;
}
/** @return half the value of border-separation.block-progression-dimension. */
@@ -145,13 +145,13 @@ public class TableLayoutManager extends BlockStackingLayoutManager
LinkedList returnList = new LinkedList();
- if (!bBreakBeforeServed) {
+ if (!breakBeforeServed) {
try {
if (addKnuthElementsForBreakBefore(returnList, context)) {
return returnList;
}
} finally {
- bBreakBeforeServed = true;
+ breakBeforeServed = true;
}
}
@@ -202,7 +202,9 @@ public class TableLayoutManager extends BlockStackingLayoutManager
}
}
- addKnuthElementsForSpaceBefore(returnList, alignment);
+ if (!firstVisibleMarkServed) {
+ addKnuthElementsForSpaceBefore(returnList, alignment);
+ }
if (getTable().isSeparateBorderModel()) {
addKnuthElementsForBorderPaddingBefore(returnList, !firstVisibleMarkServed);
diff --git a/status.xml b/status.xml
index 37d891f97..612d116f6 100644
--- a/status.xml
+++ b/status.xml
@@ -27,6 +27,10 @@
<changes>
<release version="FOP Trunk">
+ <action context="Code" dev="JM" type="fix">
+ Following a clarification by the XSL FO SG, space traits are only set on the
+ first and last area generated by an FO, and not on every area anymore.
+ </action>
<action context="Code" dev="JM" type="add">
New feature: "Intermediate format" (IF). The IF is basically the XML dialect
written by the area tree renderer (XMLRenderer). A new parser for this format
diff --git a/test/layoutengine/disabled-testcases.xml b/test/layoutengine/disabled-testcases.xml
index 684e5c4c1..78ef2a7eb 100755
--- a/test/layoutengine/disabled-testcases.xml
+++ b/test/layoutengine/disabled-testcases.xml
@@ -260,6 +260,11 @@
content to disappear.</description>
</testcase>
<testcase>
+ <name>Column Balancing problems</name>
+ <file>region-body_column-count_bug36356.xml</file>
+ <description>Column balancing doesn't work as expected.</description>
+ </testcase>
+ <testcase>
<name>No background-images on table-body</name>
<file>table-body_background-image.xml</file>
<description>The backgrounds of table-body, table-header,
diff --git a/test/layoutengine/standard-testcases/block-container_space-before_space-after_1.xml b/test/layoutengine/standard-testcases/block-container_space-before_space-after_1.xml
index 37b7b87c2..5397d516e 100644
--- a/test/layoutengine/standard-testcases/block-container_space-before_space-after_1.xml
+++ b/test/layoutengine/standard-testcases/block-container_space-before_space-after_1.xml
@@ -75,38 +75,20 @@ Two blocks, testing conditionality="discard".
<box w="14400"/>
<box w="14400"/>
- <penalty w="0" p="INF"/>
- <glue w="10000" y="0" z="10000"/>
<penalty w="0" p="0"/>
- <glue w="-30000" y="0" z="-30000"/>
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="20000" y="0" z="20000"/>
<box w="14400"/>
- <penalty w="0" p="INF"/>
- <glue w="10000" y="0" z="10000"/>
<penalty w="0" p="0"/>
- <glue w="-30000" y="0" z="-30000"/>
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="20000" y="0" z="20000"/>
<box w="14400"/>
<!-- skip three more lines -->
- <skip>8</skip>
- <skip>8</skip>
- <skip>8</skip>
+ <skip>2</skip>
+ <skip>2</skip>
+ <skip>2</skip>
- <penalty w="0" p="INF"/>
- <glue w="10000" y="0" z="10000"/>
<penalty w="0" p="0"/>
- <glue w="-30000" y="0" z="-30000"/>
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="20000" y="0" z="20000"/>
<box w="14400"/>
<box w="14400"/>
diff --git a/test/layoutengine/standard-testcases/block-container_space-before_space-after_2.xml b/test/layoutengine/standard-testcases/block-container_space-before_space-after_2.xml
index d742b3e85..8ed83492e 100644
--- a/test/layoutengine/standard-testcases/block-container_space-before_space-after_2.xml
+++ b/test/layoutengine/standard-testcases/block-container_space-before_space-after_2.xml
@@ -18,13 +18,13 @@
<testcase>
<info>
<p>
- This test checks block-level space properties. Demonstrates that spaces are repeated on every generated area.
+ This test checks block-level space properties. Demonstrates that spaces are only on the first (or last) generated area.
</p>
</info>
<fo>
<fo:root xmlns:fo="http://www.w3.org/1999/XSL/Format" xmlns:svg="http://www.w3.org/2000/svg">
<fo:layout-master-set>
- <fo:simple-page-master master-name="normal" page-width="5in" page-height="30pt">
+ <fo:simple-page-master master-name="normal" page-width="5in" page-height="28pt">
<fo:region-body/>
</fo:simple-page-master>
</fo:layout-master-set>
@@ -46,42 +46,23 @@
<box w="0"/>
<penalty w="0" p="INF"/>
<glue w="5000"/>
+
<box w="10000"/>
<penalty w="0" p="0"/>
- <glue w="-5000"/>
-
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="5000"/>
<box w="10000"/>
<penalty w="0" p="0"/>
- <glue w="-5000"/>
-
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="5000"/>
<box w="10000"/>
<penalty w="0" p="0"/>
- <glue w="-5000"/>
-
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="5000"/>
<box w="10000"/>
<penalty w="0" p="0"/>
- <glue w="-5000"/>
-
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="5000"/>
<box w="10000"/>
<skip>3</skip>
</element-list>
<eval expected="3" xpath="count(//pageViewport)"/>
<eval expected="5000" xpath="//pageViewport[@nr=1]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before"/>
- <eval expected="5000" xpath="//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before"/>
- <eval expected="5000" xpath="//pageViewport[@nr=3]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before"/>
+ <true xpath="not(boolean(//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before))"/>
+ <true xpath="not(boolean(//pageViewport[@nr=3]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before))"/>
<eval expected="1" xpath="count(//pageViewport[@nr=1]/page/regionViewport/regionBody/mainReference/span/flow/block)"/>
<eval expected="1" xpath="count(//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block)"/>
<eval expected="1" xpath="count(//pageViewport[@nr=3]/page/regionViewport/regionBody/mainReference/span/flow/block)"/>
diff --git a/test/layoutengine/standard-testcases/block_space-before_space-after_2.xml b/test/layoutengine/standard-testcases/block_space-before_space-after_2.xml
index 0676277f9..4b2d67212 100644
--- a/test/layoutengine/standard-testcases/block_space-before_space-after_2.xml
+++ b/test/layoutengine/standard-testcases/block_space-before_space-after_2.xml
@@ -71,38 +71,20 @@ Two blocks, testing conditionality="discard".
<box w="14400"/>
<box w="14400"/>
- <penalty w="0" p="INF"/>
- <glue w="10000" y="0" z="10000"/>
<penalty w="0" p="0"/>
- <glue w="-30000" y="0" z="-30000"/>
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="20000" y="0" z="20000"/>
<box w="14400"/>
- <penalty w="0" p="INF"/>
- <glue w="10000" y="0" z="10000"/>
<penalty w="0" p="0"/>
- <glue w="-30000" y="0" z="-30000"/>
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="20000" y="0" z="20000"/>
<box w="14400"/>
<!-- skip three more lines -->
- <skip>8</skip>
- <skip>8</skip>
- <skip>8</skip>
+ <skip>2</skip>
+ <skip>2</skip>
+ <skip>2</skip>
- <penalty w="0" p="INF"/>
- <glue w="10000" y="0" z="10000"/>
<penalty w="0" p="0"/>
- <glue w="-30000" y="0" z="-30000"/>
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="20000" y="0" z="20000"/>
<box w="14400"/>
<box w="14400"/>
diff --git a/test/layoutengine/standard-testcases/block_space-before_space-after_4.xml b/test/layoutengine/standard-testcases/block_space-before_space-after_4.xml
index 3d4fb9f58..d00e18cb4 100644
--- a/test/layoutengine/standard-testcases/block_space-before_space-after_4.xml
+++ b/test/layoutengine/standard-testcases/block_space-before_space-after_4.xml
@@ -18,13 +18,13 @@
<testcase>
<info>
<p>
- This test checks block-level space properties. Demonstrates that spaces are repeated on every generated area.
+ This test checks block-level space properties. Demonstrates that space-before is only on the first generated area.
</p>
</info>
<fo>
<fo:root xmlns:fo="http://www.w3.org/1999/XSL/Format" xmlns:svg="http://www.w3.org/2000/svg">
<fo:layout-master-set>
- <fo:simple-page-master master-name="normal" page-width="5in" page-height="30pt">
+ <fo:simple-page-master master-name="normal" page-width="5in" page-height="28pt">
<fo:region-body/>
</fo:simple-page-master>
</fo:layout-master-set>
@@ -48,30 +48,22 @@
<glue w="5000"/>
<box w="10000"/>
<penalty w="0" p="0"/>
- <glue w="-5000"/>
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="5000"/>
<box w="10000"/>
<penalty w="0" p="0"/>
- <glue w="-5000"/>
<!-- skip two more lines -->
- <skip>6</skip>
- <skip>6</skip>
+ <skip>2</skip>
+ <skip>2</skip>
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="5000"/>
<box w="10000"/>
<skip>3</skip>
</element-list>
<eval expected="3" xpath="count(//pageViewport)"/>
<eval expected="5000" xpath="//pageViewport[@nr=1]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before"/>
- <eval expected="5000" xpath="//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before"/>
- <eval expected="5000" xpath="//pageViewport[@nr=3]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before"/>
+ <true xpath="not(boolean(//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before))"/>
+ <true xpath="not(boolean(//pageViewport[@nr=3]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before))"/>
<eval expected="1" xpath="count(//pageViewport[@nr=1]/page/regionViewport/regionBody/mainReference/span/flow/block)"/>
<eval expected="1" xpath="count(//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block)"/>
<eval expected="1" xpath="count(//pageViewport[@nr=3]/page/regionViewport/regionBody/mainReference/span/flow/block)"/>
diff --git a/test/layoutengine/standard-testcases/block_space-before_space-after_6.xml b/test/layoutengine/standard-testcases/block_space-before_space-after_6.xml
index 7b6737252..b21963bed 100644
--- a/test/layoutengine/standard-testcases/block_space-before_space-after_6.xml
+++ b/test/layoutengine/standard-testcases/block_space-before_space-after_6.xml
@@ -78,12 +78,6 @@
<penalty w="0" p="0"/>
- <glue w="-10000"/>
-
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="10000"/>
-
<box w="14400"/>
<skip>3</skip>
diff --git a/test/layoutengine/standard-testcases/list-block_space-before_space-after_1.xml b/test/layoutengine/standard-testcases/list-block_space-before_space-after_1.xml
index 82af9d20d..2219cdfa1 100644
--- a/test/layoutengine/standard-testcases/list-block_space-before_space-after_1.xml
+++ b/test/layoutengine/standard-testcases/list-block_space-before_space-after_1.xml
@@ -108,48 +108,24 @@ Two blocks, testing conditionality="discard".
<box w="28800"/>
- <penalty w="0" p="INF"/>
- <glue w="10000"/>
<penalty w="0" p="0"/>
- <glue w="-30000"/>
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="20000"/>
<box w="14400"/>
- <penalty w="0" p="INF"/>
- <glue w="10000"/>
<penalty w="0" p="0"/>
- <glue w="-30000"/>
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="20000"/>
<box w="14400"/>
<!-- skip three more lines -->
- <skip>8</skip>
- <skip>8</skip>
- <skip>8</skip>
+ <skip>2</skip>
+ <skip>2</skip>
+ <skip>2</skip>
- <penalty w="0" p="INF"/>
- <glue w="10000"/>
<penalty w="0" p="0"/>
- <glue w="-30000"/>
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="20000"/>
<box w="28800"/> <!-- end of first list item -->
- <penalty w="0" p="INF"/>
- <glue w="10000"/>
<penalty w="0" p="0"/>
- <glue w="-30000"/>
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="20000"/>
<box w="14400"/> <!-- second list-item -->
@@ -203,8 +179,8 @@ Two blocks, testing conditionality="discard".
<!-- 1: retain -->
<eval expected="20000" xpath="//pageViewport[@nr=1]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before"/>
- <eval expected="10000" xpath="//pageViewport[@nr=1]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-after"/>
- <eval expected="20000" xpath="//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before"/>
+ <true xpath="not(boolean(//pageViewport[@nr=1]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-after))"/>
+ <true xpath="not(boolean(//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before))"/>
<!-- the following space is eliminated/collapsed through space resolution -->
<true xpath="not(boolean(//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-after))"/>
<eval expected="10000" xpath="//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block[2]/@space-before"/>
diff --git a/test/layoutengine/standard-testcases/table_space-before_space-after_1.xml b/test/layoutengine/standard-testcases/table_space-before_space-after_1.xml
index 430d8689a..c151d293f 100644
--- a/test/layoutengine/standard-testcases/table_space-before_space-after_1.xml
+++ b/test/layoutengine/standard-testcases/table_space-before_space-after_1.xml
@@ -96,40 +96,22 @@ Two blocks, testing conditionality="discard".
<box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="10000"/>
<penalty w="14400"/> <!-- p is not of interest here -->
- <glue w="-30000"/>
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="20000"/>
<box w="28800"/>
- <penalty w="0" p="INF"/>
- <glue w="10000"/>
<penalty w="0" p="0"/>
- <glue w="-30000"/>
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="20000"/>
<box w="14400"/>
<!-- skip three more lines -->
- <skip>8</skip>
- <skip>8</skip>
- <skip>8</skip>
- <skip>8</skip>
- <skip>8</skip>
+ <skip>2</skip>
+ <skip>2</skip>
+ <skip>2</skip>
+ <skip>2</skip>
+ <skip>2</skip>
- <penalty w="0" p="INF"/>
- <glue w="10000"/>
<penalty w="0" p="0"/>
- <glue w="-30000"/>
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="20000"/>
<box w="28800"/> <!-- end of table -->
@@ -185,8 +167,8 @@ Two blocks, testing conditionality="discard".
<!-- 1: retain -->
<eval expected="20000" xpath="//pageViewport[@nr=1]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before"/>
- <eval expected="10000" xpath="//pageViewport[@nr=1]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-after"/>
- <eval expected="20000" xpath="//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before"/>
+ <true xpath="not(boolean(//pageViewport[@nr=1]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-after))"/>
+ <true xpath="not(boolean(//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before))"/>
<!-- the following space is eliminated/collapsed through space resolution -->
<true xpath="not(boolean(//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-after))"/>
<eval expected="10000" xpath="//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block[2]/@space-before"/>
diff --git a/test/layoutengine/standard-testcases/table_space-before_space-after_2.xml b/test/layoutengine/standard-testcases/table_space-before_space-after_2.xml
index 2e136a5cd..5b889b538 100644
--- a/test/layoutengine/standard-testcases/table_space-before_space-after_2.xml
+++ b/test/layoutengine/standard-testcases/table_space-before_space-after_2.xml
@@ -18,13 +18,13 @@
<testcase>
<info>
<p>
- This test checks space properties on table. Demonstrates that spaces are repeated on every generated area.
+ This test checks space properties on table. Demonstrates that spaces are only on the first (or last) generated area.
</p>
</info>
<fo>
<fo:root xmlns:fo="http://www.w3.org/1999/XSL/Format" xmlns:svg="http://www.w3.org/2000/svg">
<fo:layout-master-set>
- <fo:simple-page-master master-name="normal" page-width="5in" page-height="30pt">
+ <fo:simple-page-master master-name="normal" page-width="5in" page-height="28pt">
<fo:region-body/>
</fo:simple-page-master>
</fo:layout-master-set>
@@ -57,42 +57,23 @@
<box w="0"/>
<penalty w="0" p="INF"/>
<glue w="5000"/>
+
<box w="10000"/>
<penalty w="0" p="0"/>
- <glue w="-5000"/>
-
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="5000"/>
<box w="10000"/>
<penalty w="0" p="0"/>
- <glue w="-5000"/>
-
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="5000"/>
<box w="10000"/>
<penalty w="0" p="0"/>
- <glue w="-5000"/>
-
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="5000"/>
<box w="10000"/>
<penalty w="0" p="0"/>
- <glue w="-5000"/>
-
- <box w="0"/>
- <penalty w="0" p="INF"/>
- <glue w="5000"/>
<box w="10000"/>
<skip>3</skip>
</element-list>
<eval expected="3" xpath="count(//pageViewport)"/>
<eval expected="5000" xpath="//pageViewport[@nr=1]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before"/>
- <eval expected="5000" xpath="//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before"/>
- <eval expected="5000" xpath="//pageViewport[@nr=3]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before"/>
+ <true xpath="not(boolean(//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before))"/>
+ <true xpath="not(boolean(//pageViewport[@nr=3]/page/regionViewport/regionBody/mainReference/span/flow/block[1]/@space-before))"/>
<eval expected="1" xpath="count(//pageViewport[@nr=1]/page/regionViewport/regionBody/mainReference/span/flow/block)"/>
<eval expected="1" xpath="count(//pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block)"/>
<eval expected="1" xpath="count(//pageViewport[@nr=3]/page/regionViewport/regionBody/mainReference/span/flow/block)"/>