From efb1d8b52a886e9fe36f82abcb0064a89b2e022f Mon Sep 17 00:00:00 2001 From: Glen Mazza Date: Sun, 5 Sep 2004 04:00:52 +0000 Subject: PR: Obtained from: Submitted by: Reviewed by: 1.) AddChildNode(), characters() modified to throw SAXParseException to allow AddChildNode() to do validation of its own. 2.) Better child validation added to PageSequence.java. 3.) Various other code cleanups. git-svn-id: https://svn.apache.org/repos/asf/xmlgraphics/fop/trunk@197903 13f79535-47bb-0310-9956-ffa450edef68 --- src/java/org/apache/fop/fo/pagination/Flow.java | 21 +- .../apache/fop/fo/pagination/LayoutMasterSet.java | 71 +++--- .../org/apache/fop/fo/pagination/PageSequence.java | 251 +++++++++------------ .../org/apache/fop/fo/pagination/RegionBA.java | 2 +- .../org/apache/fop/fo/pagination/RegionEnd.java | 2 + .../pagination/RepeatablePageMasterReference.java | 1 - 6 files changed, 150 insertions(+), 198 deletions(-) (limited to 'src/java/org/apache/fop/fo/pagination') diff --git a/src/java/org/apache/fop/fo/pagination/Flow.java b/src/java/org/apache/fop/fo/pagination/Flow.java index 723911c42..fb1b50802 100644 --- a/src/java/org/apache/fop/fo/pagination/Flow.java +++ b/src/java/org/apache/fop/fo/pagination/Flow.java @@ -34,25 +34,15 @@ import org.apache.fop.layoutmgr.FlowLayoutManager; /** * Class modelling the fo:flow object. + * @todo check need for markerSnapshot, contentWidth */ public class Flow extends FObj { - /** - * PageSequence container - */ - private PageSequence pageSequence; - /** * ArrayList to store snapshot */ private ArrayList markerSnapshot; - /** - * flow-name attribute: indicates the region the content of this - * flow should go to. - */ - protected String flowName; - /** * Content-width of current column area during layout */ @@ -74,16 +64,13 @@ public class Flow extends FObj { protected void addProperties(Attributes attlist) throws SAXParseException { super.addProperties(attlist); - this.pageSequence = (PageSequence) parent; - - flowName = getPropString(PR_FLOW_NAME); + // check flow_name property + String flowName = getPropString(PR_FLOW_NAME); if (flowName == null || flowName.equals("")) { missingPropertyError("flow-name"); } - - // Now done in addChild of page-sequence - //pageSequence.addFlow(this); + getFOInputHandler().startFlow(this); } diff --git a/src/java/org/apache/fop/fo/pagination/LayoutMasterSet.java b/src/java/org/apache/fop/fo/pagination/LayoutMasterSet.java index a0ad061c3..bb8533706 100644 --- a/src/java/org/apache/fop/fo/pagination/LayoutMasterSet.java +++ b/src/java/org/apache/fop/fo/pagination/LayoutMasterSet.java @@ -93,6 +93,42 @@ public class LayoutMasterSet extends FObj { if (childNodes == null) { missingChildElementError("(simple-page-master|page-sequence-master)+"); } + checkRegionNames(); + } + + /** + * Section 7.25.7: check to see that if a region-name is a + * duplicate, that it maps to the same fo region-class. + * @throws SAXParseException if there's a name duplication + */ + private void checkRegionNames() throws SAXParseException { + // (user-entered) region-name to default region map. + Map allRegions = new java.util.HashMap(); + for (Iterator spm = simplePageMasters.values().iterator(); + spm.hasNext();) { + SimplePageMaster simplePageMaster = + (SimplePageMaster)spm.next(); + Map spmRegions = simplePageMaster.getRegions(); + for (Iterator e = spmRegions.values().iterator(); + e.hasNext();) { + Region region = (Region) e.next(); + if (allRegions.containsKey(region.getRegionName())) { + String defaultRegionName = + (String) allRegions.get(region.getRegionName()); + if (!defaultRegionName.equals(region.getDefaultRegionName())) { + throw new SAXParseException("Region-name (" + + region.getRegionName() + + ") is being mapped to multiple " + + "region-classes (" + + defaultRegionName + " and " + + region.getDefaultRegionName() + + ")", locator); + } + } + allRegions.put(region.getRegionName(), + region.getDefaultRegionName()); + } + } } /** @@ -166,41 +202,6 @@ public class LayoutMasterSet extends FObj { return (PageSequenceMaster)this.pageSequenceMasters.get(masterName); } - /** - * Section 7.25.7: check to see that if a region-name is a - * duplicate, that it maps to the same fo region-class. - * @throws SAXParseException if there's a name duplication - */ - public void checkRegionNames() throws SAXParseException { - // (user-entered) region-name to default region map. - Map allRegions = new java.util.HashMap(); - for (Iterator spm = simplePageMasters.values().iterator(); - spm.hasNext();) { - SimplePageMaster simplePageMaster = - (SimplePageMaster)spm.next(); - Map spmRegions = simplePageMaster.getRegions(); - for (Iterator e = spmRegions.values().iterator(); - e.hasNext();) { - Region region = (Region) e.next(); - if (allRegions.containsKey(region.getRegionName())) { - String defaultRegionName = - (String) allRegions.get(region.getRegionName()); - if (!defaultRegionName.equals(region.getDefaultRegionName())) { - throw new SAXParseException("Region-name (" - + region.getRegionName() - + ") is being mapped to multiple " - + "region-classes (" - + defaultRegionName + " and " - + region.getDefaultRegionName() - + ")", locator); - } - } - allRegions.put(region.getRegionName(), - region.getDefaultRegionName()); - } - } - } - /** * Checks whether or not a region name exists in this master set. * @param regionName name of the region diff --git a/src/java/org/apache/fop/fo/pagination/PageSequence.java b/src/java/org/apache/fop/fo/pagination/PageSequence.java index 7a025097f..9e9f54f47 100644 --- a/src/java/org/apache/fop/fo/pagination/PageSequence.java +++ b/src/java/org/apache/fop/fo/pagination/PageSequence.java @@ -27,7 +27,6 @@ import org.xml.sax.Locator; import org.xml.sax.SAXParseException; // FOP -import org.apache.fop.apps.FOPException; import org.apache.fop.fo.FONode; import org.apache.fop.fo.FObj; @@ -38,16 +37,13 @@ import org.apache.fop.fo.FObj; */ public class PageSequence extends FObj { // - // intial-page-number types + // initial-page-number types // public static final int EXPLICIT = 0; public static final int AUTO = 1; public static final int AUTO_EVEN = 2; public static final int AUTO_ODD = 3; - // - // associations - // /** * The parent root object */ @@ -68,11 +64,7 @@ public class PageSequence extends FObj { */ public HashMap flowMap; - // according to communication from Paul Grosso (XSL-List, - // 001228, Number 406), confusion in spec section 6.4.5 about - // multiplicity of fo:flow in XSL 1.0 is cleared up - one (1) - // fo:flow per fo:page-sequence only. -// private boolean isFlowSet = false; +// private boolean isFlowSet = false; // for structure handler private boolean sequenceStarted = false; @@ -113,14 +105,14 @@ public class PageSequence extends FObj { public PageSequenceMaster pageSequenceMaster; /** - * The main content flow for this page-sequence. + * The fo:title object for this page-sequence. */ - private Flow mainFlow = null; + private Title titleFO; /** - * The fo:title object for this page-sequence. + * The fo:flow object for this page-sequence. */ - private Title titleFO; + private Flow mainFlow = null; /** * Create a page sequence FO node. @@ -131,113 +123,13 @@ public class PageSequence extends FObj { super(parent); } - /** - * @see org.apache.fop.fo.FONode#validateChildNode(Locator, String, String) - XSL Content Model: (title?,static-content*,flow) - */ - protected void validateChildNode(Locator loc, String nsURI, String localName) - throws SAXParseException { - if (nsURI == FO_URI) { - if (localName.equals("title")) { - if (titleFO != null) { - tooManyNodesError(loc, "fo:title"); - } else if (flowMap.size() > 0) { - nodesOutOfOrderError(loc, "fo:title", "fo:static-content"); - } else if (mainFlow != null) { - nodesOutOfOrderError(loc, "fo:title", "fo:flow"); - } - } else if (localName.equals("static-content")) { - if (mainFlow != null) { - nodesOutOfOrderError(loc, "fo:static-content", "fo:flow"); - } - } else if (localName.equals("flow")) { - if (mainFlow != null) { - tooManyNodesError(loc, "fo:flow"); - } - } else { - invalidChildError(loc, nsURI, localName); - } - } else { - invalidChildError(loc, nsURI, localName); - } - } - - /** - * Signal end of this xml element. - * This passes the end page sequence to the structure handler - * so it can act upon that. - */ - protected void endOfNode() throws SAXParseException { - if (mainFlow == null) { - missingChildElementError("(title?,static-content*,flow)"); - } - try { - getFOInputHandler().endPageSequence(this); - } catch (FOPException fopex) { - getLogger().error("Error in PageSequence.endOfNode(): " - + fopex.getMessage(), fopex); - } - } - - /** - * @see org.apache.fop.fo.FONode#addChildNode(FONode) - */ - public void addChildNode(FONode child) { - try { - String childName = child.getName(); - if (childName.equals("fo:title")) { - this.titleFO = (Title)child; - } else if (childName.equals("fo:flow")) { - this.mainFlow = (Flow)child; - String flowName = this.mainFlow.getPropString(PR_FLOW_NAME); - if (flowMap.containsKey(flowName)) { - throw new FOPException("flow-name " - + flowName - + " is not unique within an fo:page-sequence"); - } - if (!this.layoutMasterSet.regionNameExists(flowName)) { - getLogger().error("region-name '" - + flowName - + "' doesn't exist in the layout-master-set."); - } - // Don't add main flow to the flow map -// addFlow(mainFlow); - startStructuredPageSequence(); - super.addChildNode(child); // For getChildren - } else if (childName.equals("fo:static-content")) { - String flowName = ((StaticContent)child).getPropString(PR_FLOW_NAME); - if (flowMap.containsKey(flowName)) { - throw new FOPException("flow-name " + flowName - + " is not unique within an fo:page-sequence"); - } - if (!this.layoutMasterSet.regionNameExists(flowName)) { - throw new FOPException("region-name '" + flowName - + "' doesn't exist in the layout-master-set."); - } - flowMap.put(flowName, child); -// addFlow((Flow)child); - startStructuredPageSequence(); - } - } catch (FOPException fopex) { - getLogger().error("Error in PageSequence.addChildNode(): " - + fopex.getMessage(), fopex); - } - } - - /** * @see org.apache.fop.fo.FObj#addProperties */ protected void addProperties(Attributes attlist) throws SAXParseException { super.addProperties(attlist); - this.root = (Root) parent; -// this.root.addPageSequence(this); layoutMasterSet = root.getLayoutMasterSet(); - - // best time to run some checks on LayoutMasterSet - layoutMasterSet.checkRegionNames(); - flowMap = new HashMap(); // we are now on the first page of the page sequence @@ -257,7 +149,7 @@ public class PageSequence extends FObj { this.explicitFirstNumber = (pageStart > 0) ? pageStart : 1; } catch (NumberFormatException nfe) { throw new SAXParseException("\"" + ipnValue - + "\" is not a valid value for initial-page-number", locator); + + "\" is not a valid value for initial-page-number", locator); } } @@ -269,17 +161,17 @@ public class PageSequence extends FObj { this.layoutMasterSet.getPageSequenceMaster(masterName); if (this.pageSequenceMaster == null) { throw new SAXParseException("master-reference '" + masterName - + "' for fo:page-sequence matches no" - + " simple-page-master or page-sequence-master", locator); + + "' for fo:page-sequence matches no" + + " simple-page-master or page-sequence-master", locator); } } // get the 'format' properties this.pageNumberGenerator = new PageNumberGenerator(getPropString(PR_FORMAT), - this.propertyList.get(PR_GROUPING_SEPARATOR).getCharacter(), - this.propertyList.get(PR_GROUPING_SIZE).getNumber().intValue(), - getPropEnum(PR_LETTER_VALUE)); + this.propertyList.get(PR_GROUPING_SEPARATOR).getCharacter(), + this.propertyList.get(PR_GROUPING_SIZE).getNumber().intValue(), + getPropEnum(PR_LETTER_VALUE)); this.forcePageCount = getPropEnum(PR_FORCE_PAGE_COUNT); @@ -291,26 +183,95 @@ public class PageSequence extends FObj { startStructuredPageSequence(); } + /** + * @see org.apache.fop.fo.FONode#validateChildNode(Locator, String, String) + XSL Content Model: (title?,static-content*,flow) + */ + protected void validateChildNode(Locator loc, String nsURI, String localName) + throws SAXParseException { + if (nsURI == FO_URI) { + if (localName.equals("title")) { + if (titleFO != null) { + tooManyNodesError(loc, "fo:title"); + } else if (flowMap.size() > 0) { + nodesOutOfOrderError(loc, "fo:title", "fo:static-content"); + } else if (mainFlow != null) { + nodesOutOfOrderError(loc, "fo:title", "fo:flow"); + } + } else if (localName.equals("static-content")) { + if (mainFlow != null) { + nodesOutOfOrderError(loc, "fo:static-content", "fo:flow"); + } + } else if (localName.equals("flow")) { + if (mainFlow != null) { + tooManyNodesError(loc, "fo:flow"); + } + } else { + invalidChildError(loc, nsURI, localName); + } + } else { + invalidChildError(loc, nsURI, localName); + } + } + + /** + * @see org.apache.fop.fo.FONode#addChildNode(FONode) + * @todo see if addChildNode() should also be called for fo's other than + * fo:flow. + */ + public void addChildNode(FONode child) throws SAXParseException { + int childId = child.getNameId(); + + if (childId == FO_TITLE) { + this.titleFO = (Title) child; + } else if (childId == FO_FLOW) { + this.mainFlow = (Flow) child; + addFlow(mainFlow); + startStructuredPageSequence(); + super.addChildNode(child); // For getChildren + } else if (childId == FO_STATIC_CONTENT) { + addFlow((StaticContent) child); + startStructuredPageSequence(); + } + } + + /** + * Signal end of this xml element. + * This passes the end page sequence to the structure handler + * so it can act upon that. + */ + protected void endOfNode() throws SAXParseException { + if (mainFlow == null) { + missingChildElementError("(title?,static-content*,flow)"); + } + + getFOInputHandler().endPageSequence(this); + } /** * Add a flow or static content, mapped by its flow-name. * The flow-name is used to associate the flow with a region on a page, - * based on the names given to the regions in the page-master used to - * generate that page. + * based on the region-names given to the regions in the page-master + * used to generate that page. */ -// private void addFlow(Flow flow) throws FOPException { -// if (flowMap.containsKey(flow.getFlowName())) { -// throw new FOPException("flow-names must be unique within an fo:page-sequence"); -// } -// if (!this.layoutMasterSet.regionNameExists(flow.getFlowName())) { -// getLogger().error("region-name '" -// + flow.getFlowName() -// + "' doesn't exist in the layout-master-set."); -// } -// flowMap.put(flow.getFlowName(), flow); -// //setIsFlowSet(true); -// } + private void addFlow(Flow flow) throws SAXParseException { + String flowName = flow.getPropString(PR_FLOW_NAME); + + if (hasFlowName(flowName)) { + throw new SAXParseException ("duplicate flow-name \"" + + flowName + + "\" found within fo:page-sequence", flow.locator); + } + if (!layoutMasterSet.regionNameExists(flowName) + && !flowName.equals("xsl-before-float-separator") + && !flowName.equals("xsl-footnote-separator")) { + throw new SAXParseException ("flow-name \"" + + flowName + + "\" could not be mapped to a region-name in the" + + " layout-master-set", flow.locator); + } + } /** * Start the page-sequence logic in the Structured Handler @@ -322,7 +283,6 @@ public class PageSequence extends FObj { } } - /** * Initialize the current page number for the start of the page sequence. */ @@ -667,15 +627,7 @@ public class PageSequence extends FObj { * @return the static content FO node */ public StaticContent getStaticContent(String name) { - return (StaticContent)flowMap.get(name); - } - - /** - * Accessor method for layoutMasterSet - * @return layoutMasterSet for this object - */ - public LayoutMasterSet getLayoutMasterSet() { - return layoutMasterSet; + return (StaticContent) flowMap.get(name); } /** @@ -695,6 +647,17 @@ public class PageSequence extends FObj { return mainFlow; } + /** + * Determine if this PageSequence already has a flow with the given flow-name + * Used for validation of incoming fo:flow or fo:static-content objects + * @param flowName The flow-name to search for + * @return true if flow-name already defined within this page sequence, + * false otherwise + */ + public boolean hasFlowName(String flowName) { + return flowMap.containsKey(flowName); + } + /** * Public accessor for getting the PageSequenceMaster (if any) to which this * PageSequence is attached. diff --git a/src/java/org/apache/fop/fo/pagination/RegionBA.java b/src/java/org/apache/fop/fo/pagination/RegionBA.java index 57273828f..9f61cf93a 100644 --- a/src/java/org/apache/fop/fo/pagination/RegionBA.java +++ b/src/java/org/apache/fop/fo/pagination/RegionBA.java @@ -61,7 +61,7 @@ public abstract class RegionBA extends Region { Region start = getSiblingRegion(FO_REGION_START); if (start != null) { offset = start.getPropLength(PR_EXTENT); - vpRefRect.translate(offset, 0); + vpRefRect.translate(offset, 0); // move (x, y) units } Region end = getSiblingRegion(FO_REGION_END); if (end != null) { diff --git a/src/java/org/apache/fop/fo/pagination/RegionEnd.java b/src/java/org/apache/fop/fo/pagination/RegionEnd.java index 3636dfc7a..bfadeb48b 100644 --- a/src/java/org/apache/fop/fo/pagination/RegionEnd.java +++ b/src/java/org/apache/fop/fo/pagination/RegionEnd.java @@ -58,9 +58,11 @@ public class RegionEnd extends RegionSE { // Depends on extent, precedence and writing mode Rectangle vpRect; if (this.wm == WritingMode.LR_TB || this.wm == WritingMode.RL_TB) { + // Rectangle: x , y (of top left point), width, height vpRect = new Rectangle(reldims.ipd - extent, 0, extent, reldims.bpd); } else { + // Rectangle: x , y (of top left point), width, height vpRect = new Rectangle(reldims.ipd - extent, 0, reldims.bpd, extent); } diff --git a/src/java/org/apache/fop/fo/pagination/RepeatablePageMasterReference.java b/src/java/org/apache/fop/fo/pagination/RepeatablePageMasterReference.java index 3435f1148..32c8a14b0 100644 --- a/src/java/org/apache/fop/fo/pagination/RepeatablePageMasterReference.java +++ b/src/java/org/apache/fop/fo/pagination/RepeatablePageMasterReference.java @@ -50,7 +50,6 @@ public class RepeatablePageMasterReference extends FObj /** * @see org.apache.fop.fo.FObj#addProperties - * @todo need to */ protected void addProperties(Attributes attlist) throws SAXParseException { super.addProperties(attlist); -- cgit v1.2.3