diff options
3 files changed, 77 insertions, 12 deletions
diff --git a/src/java/org/apache/fop/layoutmgr/LayoutManagerMapping.java b/src/java/org/apache/fop/layoutmgr/LayoutManagerMapping.java index ce323de84..a1a3c06fc 100644 --- a/src/java/org/apache/fop/layoutmgr/LayoutManagerMapping.java +++ b/src/java/org/apache/fop/layoutmgr/LayoutManagerMapping.java @@ -270,9 +270,7 @@ public class LayoutManagerMapping implements LayoutManagerMaker { public static class InlineLayoutManagerMaker extends Maker { public void make(FONode node, List lms) { - if (node.getChildNodes() != null) { - lms.add(new InlineLayoutManager((InlineLevel) node)); - } + lms.add(new InlineLayoutManager((InlineLevel) node)); } } diff --git a/src/java/org/apache/fop/layoutmgr/inline/InlineLayoutManager.java b/src/java/org/apache/fop/layoutmgr/inline/InlineLayoutManager.java index e9b6c19ec..ec7734377 100755 --- a/src/java/org/apache/fop/layoutmgr/inline/InlineLayoutManager.java +++ b/src/java/org/apache/fop/layoutmgr/inline/InlineLayoutManager.java @@ -30,7 +30,6 @@ import org.apache.fop.area.inline.InlineArea; import org.apache.fop.area.inline.InlineBlockParent; import org.apache.fop.area.inline.InlineParent; import org.apache.fop.datatypes.Length; -import org.apache.fop.fo.Constants; import org.apache.fop.fo.flow.Inline; import org.apache.fop.fo.flow.InlineLevel; import org.apache.fop.fo.flow.Leader; @@ -44,6 +43,7 @@ import org.apache.fop.fonts.FontTriplet; import org.apache.fop.layoutmgr.BlockKnuthSequence; import org.apache.fop.layoutmgr.BlockLevelLayoutManager; import org.apache.fop.layoutmgr.BreakElement; +import org.apache.fop.layoutmgr.InlineKnuthSequence; import org.apache.fop.layoutmgr.KnuthBox; import org.apache.fop.layoutmgr.KnuthSequence; import org.apache.fop.layoutmgr.LayoutContext; @@ -108,7 +108,7 @@ public class InlineLayoutManager extends InlineStackingLayoutManager { } private Inline getInlineFO() { - return (Inline)fobj; + return (Inline) fobj; } /** {@inheritDoc} */ @@ -379,6 +379,24 @@ public class InlineLayoutManager extends InlineStackingLayoutManager { setFinished(true); log.trace(trace); + + if (returnList.size() == 0) { + /* + * if the FO itself is empty, but has an id specified + * or associated fo:markers, then we still need a dummy + * sequence to register its position in the area tree + */ + if (fobj.hasId() || fobj.hasMarkers()) { + InlineKnuthSequence emptySeq = new InlineKnuthSequence(); + emptySeq.add(new KnuthInlineBox( + 0, + alignmentContext, + notifyPos(getAuxiliaryPosition()), + true)); + returnList.add(emptySeq); + } + } + return returnList.size() == 0 ? null : returnList; } @@ -394,8 +412,6 @@ public class InlineLayoutManager extends InlineStackingLayoutManager { public void addAreas(PositionIterator parentIter, LayoutContext context) { - Position lastPos = null; - addId(); setChildContext(new LayoutContext(context)); // Store current value @@ -420,7 +436,8 @@ public class InlineLayoutManager extends InlineStackingLayoutManager { // layout context given to the other LMs. LinkedList positionList = new LinkedList(); NonLeafPosition pos = null; - LayoutManager lastLM = null; // last child LM in this iterator + LayoutManager lastLM = null;// last child LM in this iterator + Position lastPos = null; while (parentIter.hasNext()) { pos = (NonLeafPosition) parentIter.next(); if (pos != null && pos.getPosition() != null) { @@ -556,10 +573,10 @@ public class InlineLayoutManager extends InlineStackingLayoutManager { /** {@inheritDoc} */ protected void addId() { - if (fobj instanceof Inline) { - getPSLM().addIDToPage(getInlineFO().getId()); - } + getPSLM().addIDToPage(fobj.getId()); } + public String toString() { + return (this.getClass().getName() + "[fobj=" + fobj.toString() + "]"); + } } - diff --git a/test/layoutengine/standard-testcases/page-number-citation_empty-inline.xml b/test/layoutengine/standard-testcases/page-number-citation_empty-inline.xml new file mode 100644 index 000000000..eb6a32ad8 --- /dev/null +++ b/test/layoutengine/standard-testcases/page-number-citation_empty-inline.xml @@ -0,0 +1,50 @@ +<?xml version="1.0" encoding="UTF-8"?> +<!-- + Licensed to the Apache Software Foundation (ASF) under one or more + contributor license agreements. See the NOTICE file distributed with + this work for additional information regarding copyright ownership. + The ASF licenses this file to You 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 a page-number-citation for an empty fo:inline (see Bugzilla 42748). + </p> + </info> + <fo> + <fo:root xmlns:fo="http://www.w3.org/1999/XSL/Format"> + <fo:layout-master-set> + <fo:simple-page-master master-name="normal" page-width="5in" page-height="20in" + margin="20pt"> + <fo:region-body background-color="yellow"/> + </fo:simple-page-master> + </fo:layout-master-set> + <fo:page-sequence id="page-sequence1" master-reference="normal" white-space-collapse="true"> + <fo:flow flow-name="xsl-region-body"> + <fo:block> + <fo:block>text<fo:inline id="empty-inline1" />text</fo:block> + </fo:block> + </fo:flow> + </fo:page-sequence> + <fo:page-sequence master-reference="normal"> + <fo:flow flow-name="xsl-region-body" font-size="8pt"> + <fo:block><fo:page-number-citation ref-id="empty-inline1" /></fo:block> + </fo:flow> + </fo:page-sequence> + </fo:root> + </fo> + <checks> + <true fail-msg="no ID for empty inline" xpath="'1' = //pageViewport[@nr=2]/page/regionViewport/regionBody/mainReference/span/flow/block[1]"/> + </checks> +</testcase> |