]> source.dussan.org Git - xmlgraphics-fop.git/commitdiff
Space resolution bugfix: Space specifiers didn't collapse when there was not break...
authorJeremias Maerki <jeremias@apache.org>
Wed, 19 Oct 2005 13:04:44 +0000 (13:04 +0000)
committerJeremias Maerki <jeremias@apache.org>
Wed, 19 Oct 2005 13:04:44 +0000 (13:04 +0000)
Test case for space resolution in side regions. This test case showed me the above bug.

git-svn-id: https://svn.apache.org/repos/asf/xmlgraphics/fop/branches/Temp_SpaceResolution@326545 13f79535-47bb-0310-9956-ffa450edef68

src/java/org/apache/fop/layoutmgr/SpaceResolver.java
src/java/org/apache/fop/layoutmgr/StaticContentLayoutManager.java
test/layoutengine/testcases/region_side_space-resolution.xml [new file with mode: 0644]

index 2304d5ac53b31f6c35d24dd7d000b821e1ea1c56..49e4161197cccffd853b55e8c5e559dec57e8f14 100644 (file)
@@ -359,8 +359,8 @@ public class SpaceResolver {
         } else {
             if (isFirst || isLast) {
                 performSpaceResolutionRule1(secondPart, secondPartLengths);
-                performSpaceResolutionRules2to3(secondPart, secondPartLengths);
             }
+            performSpaceResolutionRules2to3(secondPart, secondPartLengths);
         }
     }
     
index b77275fa0ac3ef505fdb56fa3e51d9cccd8cd168..34da18505be6e3328358ccf20c066900fafa5621 100644 (file)
 package org.apache.fop.layoutmgr;
 
 import java.util.LinkedList;
+import java.util.List;
 import java.util.ListIterator;
 
 import org.apache.fop.area.RegionReference;
 import org.apache.fop.area.Area;
 import org.apache.fop.area.Block;
+import org.apache.fop.fo.pagination.PageSequence;
 import org.apache.fop.fo.pagination.SideRegion;
 import org.apache.fop.fo.pagination.StaticContent;
 import org.apache.fop.layoutmgr.inline.InlineLevelLayoutManager;
@@ -251,6 +253,16 @@ public class StaticContentLayoutManager extends BlockStackingLayoutManager {
             this.displayAlign = displayAlign;
         }
 
+        /** @see org.apache.fop.layoutmgr.AbstractBreaker#observeElementList(java.util.List) */
+        protected void observeElementList(List elementList) {
+            String elementListID = getStaticContentFO().getFlowName();
+            String pageSequenceID = ((PageSequence)lm.getParent().getFObj()).getId();
+            if (pageSequenceID != null && pageSequenceID.length() > 0) {
+                elementListID += "-" + pageSequenceID;
+            }
+            ElementListObserver.observe(elementList, "static-content", elementListID);
+        }
+        
         /** @see org.apache.fop.layoutmgr.AbstractBreaker#isPartOverflowRecoveryActivated() */
         protected boolean isPartOverflowRecoveryActivated() {
             //For side regions, this must be disabled because of wanted overflow.
diff --git a/test/layoutengine/testcases/region_side_space-resolution.xml b/test/layoutengine/testcases/region_side_space-resolution.xml
new file mode 100644 (file)
index 0000000..a7e8af0
--- /dev/null
@@ -0,0 +1,64 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<!--
+  Copyright 2005 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 if space resolution works in side regions.
+    </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="5in">
+          <fo:region-body margin-top="50pt"/>
+          <fo:region-before extent="50pt" background-color="yellow"/>
+        </fo:simple-page-master>
+      </fo:layout-master-set>
+      <fo:page-sequence master-reference="normal" white-space-collapse="true">
+        <fo:static-content flow-name="xsl-region-before">
+          <fo:block space-before="1em" space-after="1em">line 1</fo:block>
+          <fo:block space-before="1em" space-after="1em">line 2</fo:block>
+        </fo:static-content>
+        <fo:flow flow-name="xsl-region-body">
+          <fo:block>region-body</fo:block>
+        </fo:flow>
+      </fo:page-sequence>
+    </fo:root>
+  </fo>
+  <checks>
+    <element-list category="static-content" id="xsl-region-before">
+      <box w="0"/> <!-- SpaceHandlingPosition -->
+      <box w="14400"/>
+      
+      <box w="0"/>
+      <penalty w="0" p="INF"/>
+      <glue w="12000"/>
+      
+      <box w="14400"/>
+      
+      <box w="0"/> <!-- SpaceHandlingPosition -->
+      <box w="0"/>
+      <skip>3</skip>
+    </element-list>
+
+    <true xpath="not(boolean(//regionBefore/block[1]/@space-before))"/>
+    <true xpath="not(boolean(//regionBefore/block[1]/@space-after))"/>
+    <eval expected="12000" xpath="//regionBefore/block[2]/@space-before"/>
+    <true xpath="not(boolean(//regionBefore/block[2]/@space-after))"/>
+  </checks>
+</testcase>