diff options
author | Simon Pepping <spepping@apache.org> | 2010-05-25 09:39:30 +0000 |
---|---|---|
committer | Simon Pepping <spepping@apache.org> | 2010-05-25 09:39:30 +0000 |
commit | 0e7b0816b0e8b30c21bd595d83ac977819fb74d2 (patch) | |
tree | 1a7a1c3b2aede256cd5d5ed814855ad9810a1d22 | |
parent | 67291183b23aaeb4f53e19451d8bf18511cbf676 (diff) | |
download | xmlgraphics-fop-0e7b0816b0e8b30c21bd595d83ac977819fb74d2.tar.gz xmlgraphics-fop-0e7b0816b0e8b30c21bd595d83ac977819fb74d2.zip |
Removing outdated documentation
git-svn-id: https://svn.apache.org/repos/asf/xmlgraphics/fop/trunk@947984 13f79535-47bb-0310-9956-ffa450edef68
19 files changed, 0 insertions, 8912 deletions
diff --git a/src/documentation/content/xdocs/DnI/BookMaker.java b/src/documentation/content/xdocs/DnI/BookMaker.java deleted file mode 100644 index 5a70cb030..000000000 --- a/src/documentation/content/xdocs/DnI/BookMaker.java +++ /dev/null @@ -1,335 +0,0 @@ -/* - * 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$ */ - -// Derived from examples/embedding/java/embedding/ExampleXML2PDF.java -// in FOP-0.20.5 - -//Java -import java.io.File; -import java.io.IOException; -import java.io.OutputStream; -import java.io.FileInputStream; -import java.io.FileOutputStream; - -import java.util.Vector; - -//JAXP -import javax.xml.transform.Transformer; -import javax.xml.transform.TransformerFactory; -import javax.xml.transform.TransformerException; -import javax.xml.transform.Source; -import javax.xml.transform.Result; -import javax.xml.transform.stream.StreamSource; -import javax.xml.transform.stream.StreamResult; -import javax.xml.transform.sax.SAXSource; -import javax.xml.transform.sax.SAXResult; - -import javax.xml.parsers.SAXParserFactory; -import javax.xml.parsers.FactoryConfigurationError; -import javax.xml.parsers.SAXParser; -import javax.xml.parsers.ParserConfigurationException; - -// SAX -import org.xml.sax.InputSource; -import org.xml.sax.XMLReader; -import org.xml.sax.SAXException; -import org.xml.sax.SAXParseException; -import org.xml.sax.ErrorHandler; - -// XML Commons -import org.apache.xml.resolver.tools.CatalogResolver; - -import org.apache.commons.cli.Options; -import org.apache.commons.cli.Option; -import org.apache.commons.cli.OptionGroup; -import org.apache.commons.cli.CommandLine; -import org.apache.commons.cli.HelpFormatter; -import org.apache.commons.cli.Parser; -import org.apache.commons.cli.GnuParser; -import org.apache.commons.cli.ParseException; - -//Avalon -import org.apache.avalon.framework.ExceptionUtil; -import org.apache.avalon.framework.logger.ConsoleLogger; -import org.apache.avalon.framework.logger.Logger; - -//FOP -import org.apache.fop.apps.Driver; -import org.apache.fop.apps.FOPException; -import org.apache.fop.messaging.MessageHandler; - -/** - * This class converts an XML file to PDF using - * JAXP (XSLT) and FOP (XSL:FO). - */ -public class BookMaker implements ErrorHandler { - - private Logger logger; - - private File xmlFile, xsltFile, outFile, pdfFile; - private boolean useCatalog; - private Vector xsltParams = null; - - public BookMaker() { - //Setup logger - logger = new ConsoleLogger(ConsoleLogger.LEVEL_INFO); - } - - /** - * org.xml.sax.ErrorHandler#warning - **/ - public void warning(SAXParseException e) { - logger.warn(e.toString()); - } - - /** - * org.xml.sax.ErrorHandler#error - **/ - public void error(SAXParseException e) { - logger.error(e.toString()); - } - - /** - * org.xml.sax.ErrorHandler#fatalError - **/ - public void fatalError(SAXParseException e) throws SAXException { - logger.error(e.toString()); - throw e; - } - - public void makeBook() - throws IOException, FOPException, TransformerException, - FactoryConfigurationError, - ParserConfigurationException, SAXException { - - OutputStream out = null; - - try { - - Source xmlSource, xsltSource; - Result result; - CatalogResolver resolver = null; - - // Setup entity and URI resolver - if (useCatalog) { - resolver = new CatalogResolver(); - logger.info("Using " + resolver.getClass().getName() - + " as entity/URI resolver"); - } - - //Setup XSLT transformer - TransformerFactory tFactory = TransformerFactory.newInstance(); - if (useCatalog) { - tFactory.setURIResolver(resolver); - } - - //Setup input and xslt sources - if (useCatalog) { - - SAXParser parser; - XMLReader xmlReader; - FileInputStream fis; - InputSource is; - - // throws FactoryConfigurationError - SAXParserFactory sFactory = SAXParserFactory.newInstance(); - sFactory.setNamespaceAware(true); - - // Setup input source - // throws ParserConfigurationException - parser = sFactory.newSAXParser(); - // throws SAXException - xmlReader = parser.getXMLReader(); - logger.info("Using " + xmlReader.getClass().getName() - + " as SAX parser"); - xmlReader.setErrorHandler(this); - xmlReader.setEntityResolver(resolver); - - // Setup SAX source - fis = new FileInputStream(xmlFile); - is = new InputSource(fis); - xmlSource = new SAXSource(xmlReader, is); - - // Setup xslt source - // throws ParserConfigurationException - parser = sFactory.newSAXParser(); - // throws SAXException - xmlReader = parser.getXMLReader(); - logger.info("Using " + xmlReader.getClass().getName() - + " as SAX parser"); - xmlReader.setErrorHandler(this); - xmlReader.setEntityResolver(resolver); - - // Setup SAX source - fis = new FileInputStream(xsltFile); - is = new InputSource(fis); - xsltSource = new SAXSource(xmlReader, is); - - } else { - xmlSource = new StreamSource(xmlFile); - xsltSource = new StreamSource(xsltFile); - } - - // Setup output result - if (pdfFile != null) { - //Setup FOP - MessageHandler.setScreenLogger(logger); - Driver driver = new Driver(); - driver.setLogger(logger); - driver.setRenderer(Driver.RENDER_PDF); - out = new FileOutputStream(pdfFile); - driver.setOutputStream(out); - //Resulting SAX events (the generated FO) - // must be piped through to FOP - result = new SAXResult(driver.getContentHandler()); - } else { - out = new FileOutputStream(outFile); - result = new StreamResult(out); - } - - // Setup the transformer - Transformer transformer - = tFactory.newTransformer(xsltSource); - logger.info("Using " + transformer.getClass().getName() - + " as TrAX transformer"); - - // Set the value of parameters, if any, defined for stylesheet - if (xsltParams != null) { - for (int i = 0; i < xsltParams.size(); i += 2) { - transformer.setParameter - ((String) xsltParams.elementAt(i), - (String) xsltParams.elementAt(i + 1)); - } - } - - //Start XSLT transformation and FOP processing - transformer.transform(xmlSource, result); - - } finally { - if (out != null) { - out.close(); - } - } - } - - private static Options createOptions() { - - Options options = new Options(); - OptionGroup og; - Option o; - - o = new Option("h", "help", false, "Print help"); - options.addOption(o); - - o = new Option("c", "useCatalog", false, "Use catalog"); - options.addOption(o); - - o = new Option("xml", "xmlFile", true, "XML input file"); - o.setArgName("file"); - options.addOption(o); - - o = new Option("xsl", "xslFile", true, "XSLT stylesheet"); - o.setArgName("file"); - options.addOption(o); - - // mutually exclusive output options - og = new OptionGroup(); - o = new Option("out", "outFile", true, "(X)HTML/FO output file"); - o.setArgName("file"); - og.addOption(o); - - o = new Option("pdf", "pdfFile", true, "PDF output file"); - o.setArgName("file"); - og.addOption(o); - - options.addOptionGroup(og); - - o = new Option("p", "parameter", true, - "Parameter for the XSLT transformation"); - o.setArgs(2); - o.setArgName("name value"); - options.addOption(o); - - return options; - } - - public static void main(String[] args) { - - BookMaker app = new BookMaker(); - - try { - - // Setup options - Options options = createOptions(); - - // Parse command line - // GNU parser allow multi-letter short options - Parser parser = new GnuParser(); - CommandLine cl = null; - cl = parser.parse(options, args); - if (cl.hasOption("h")) { - // automatically generate the help statement - HelpFormatter formatter = new HelpFormatter(); - formatter.printHelp("BookMaker", options); - System.exit(0); - } - - //Setup input and output files and parameters - if (cl.hasOption("c")) { - app.useCatalog = true; - } - if (cl.hasOption("xml")) { - app.xmlFile = new File(cl.getOptionValue("xml")); - } - if (cl.hasOption("xsl")) { - app.xsltFile = new File(cl.getOptionValue("xsl")); - } - if (cl.hasOption("out")) { - app.outFile = new File(cl.getOptionValue("out")); - } - if (cl.hasOption("pdf")) { - app.pdfFile = new File(cl.getOptionValue("pdf")); - } - if (cl.hasOption("p")) { - String[] params = cl.getOptionValues("p"); - app.xsltParams = new Vector(); - for (int i = 0; i < params.length; ++i) { - app.xsltParams.addElement(params[i]); - } - } - - app.logger.info("Input: XML (" + app.xmlFile + ")"); - app.logger.info("Stylesheet: " + app.xsltFile); - if (app.pdfFile != null) { - app.logger.info("Output: PDF (" + app.pdfFile + ")"); - } else { - app.logger.info("Output: (X)HTML/FO (" + app.outFile + ")"); - } - app.logger.info(""); - app.logger.info("Transforming..."); - - app.makeBook(); - - app.logger.info("Transforming done"); - } catch (Exception e) { - app.logger.error(ExceptionUtil.printStackTrace(e)); - System.exit(1); - } - } -} diff --git a/src/documentation/content/xdocs/DnI/DnI.xml b/src/documentation/content/xdocs/DnI/DnI.xml deleted file mode 100644 index a4875e5c2..000000000 --- a/src/documentation/content/xdocs/DnI/DnI.xml +++ /dev/null @@ -1,137 +0,0 @@ -<?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$ --> - -<!DOCTYPE book PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" - "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd" [ -<!ENTITY ch.overview SYSTEM "overview.xml"> -<!ENTITY ch.preparation SYSTEM "preparation.xml"> -<!ENTITY ch.fotree SYSTEM "fotree.xml"> -<!ENTITY ch.areatree SYSTEM "areatree.xml"> -<!ENTITY ch.getnextbreakposs SYSTEM "getnextbreakposs.xml"> -<!ENTITY ch.addareas SYSTEM "addareas.xml"> -<!ENTITY ch.rendering SYSTEM "rendering.xml"> -<!ENTITY ch.foptrees SYSTEM "foptrees.xml"> -<!ENTITY ch.properties SYSTEM "properties.xml"> -<!ENTITY ch.fonts SYSTEM "fonts.xml"> -<!ENTITY ch.configuration SYSTEM "configuration.xml"> -]> - -<book> - <bookinfo> - - <title>FOP's Design and Implementation</title> - - <authorgroup> - <author> - <firstname>Simon</firstname> - <surname>Pepping</surname> - <affiliation> - <orgname>FOP team</orgname> - <orgdiv>Apache Software Foundation</orgdiv> - </affiliation> - </author> - <author> - <firstname>Renaud</firstname> - <surname>Richardet</surname> - <affiliation> - <orgname>FOP contributor</orgname> - <orgdiv>Apache Software Foundation</orgdiv> - </affiliation> - </author> - </authorgroup> - - <copyright> - <year>2004</year> - <year>2005</year> - <holder>The Apache Software Foundation</holder> - </copyright> - - <legalnotice> - <para>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 - -<screen> - <ulink url="http://www.apache.org/licenses/LICENSE-2.0">http://www.apache.org/licenses/LICENSE-2.0</ulink> -</screen> - -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.</para> - </legalnotice> - - <revhistory> - <revision> - <revnumber>0.x</revnumber> - <date>2003, 2004</date> - <revremark>Various early, partial versions</revremark> - </revision> - <revision> - <revnumber>1.0</revnumber> - <date>01 August 2004</date> - <revremark>Committed to the FOP code repository</revremark> - </revision> - <revision> - <revnumber>1.0.x</revnumber> - <date>2005</date> - <revremark>Various updates, see the FOP code repository</revremark> - </revision> - </revhistory> - - <abstract> - <simpara>FOP is a Formatting Object Processor of the Apache -project. It aims to provide a standards compliant implementation of -XSL-FO. It understands Unicode, has bidirectional writing -capabilities, and implements a wide range of rendering -formats.</simpara> - - <simpara>FOP is a work in progress. Its code is under continuing -development. This documentation describes the state of the code at the -time the documentation was written. At the time you read this -documentation the code may be different. Note also that different -parts of the documentation were written or revised at different -times.</simpara> - - </abstract> - - </bookinfo> - -&ch.overview; -&ch.preparation; -&ch.fotree; -&ch.areatree; -&ch.getnextbreakposs; -&ch.addareas; -&ch.rendering; -&ch.foptrees; -&ch.properties; -&ch.fonts; -&ch.configuration; - -</book> - -<!-- Local Variables: --> -<!-- current-language-environment: UTF-8 --> -<!-- coding: utf-8 --> -<!-- default-input-method: TeX --> -<!-- End: --> diff --git a/src/documentation/content/xdocs/DnI/Makefile b/src/documentation/content/xdocs/DnI/Makefile deleted file mode 100644 index 4c9d645a8..000000000 --- a/src/documentation/content/xdocs/DnI/Makefile +++ /dev/null @@ -1,128 +0,0 @@ -# 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$ - -BOOK=DnI.xml -CHAPTERS=addareas.xml areatree.xml configuration.xml fonts.xml \ - foptrees.xml fotree.xml getnextbreakposs.xml overview.xml \ - preparation.xml properties.xml rendering.xml -CUSTOM_DOCBOOK_XHTML_STYLESHEET=cust-xhtml-docbook.xsl -CUSTOM_DOCBOOK_HTML_STYLESHEET=cust-html-docbook.xsl -CUSTOM_DOCBOOK_FO_STYLESHEET=cust-fo-docbook.xsl -STYLESHEETS=$(CUSTOM_DOCBOOK_XHTML_STYLESHEET) \ - $(CUSTOM_DOCBOOK_HTML_STYLESHEET) \ - $(CUSTOM_DOCBOOK_FO_STYLESHEET) -BOOKMAKER=BookMaker.java - -# destinations -BUILD_DIR=../../../../../build -BOOKMAKERCLASSPATH=$(BUILD_DIR)/classes -BOOKMAKER_CLASS=$(BOOKMAKERCLASSPATH)/BookMaker.class -DNI_BUILD_DIR=$(BUILD_DIR)/site/DnI -XHTML_DIR=$(DNI_BUILD_DIR)/xhtml -HTML_DIR=$(DNI_BUILD_DIR)/html -PDF_DIR=$(DNI_BUILD_DIR) - -JAVACLASSES=/usr/share/java -LOCALJAVACLASSES=/usr/local/javaclasses -FOPCLASSPATH=$(JAVACLASSES)/fop.jar:$(LOCALJAVACLASSES)/fop.jar -AVALONCLASSPATH=$(JAVACLASSES)/avalon-framework.jar:$(LOCALJAVACLASSES)/avalon-framework.jar -SAXONCLASSPATH=$(JAVACLASSES)/saxon.jar:$(LOCALJAVACLASSES)/saxon.jar -RESOLVERCLASSPATH=$(JAVACLASSES)/xml-commons-resolver.jar:$(LOCALJAVACLASSES)/xml-commons-resolver.jar -XERCESCLASSPATH=$(JAVACLASSES)/xml-apis.jar:$(JAVACLASSES)/xercesImpl.jar:$(LOCALJAVACLASSES)/xml-apis.jar:$(LOCALJAVACLASSES)/xercesImpl.jar -CLICLASSPATH=$(JAVACLASSES)/commons-cli.jar:$(LOCALJAVACLASSES)/commons-cli.jar - -all: xhtml html pdf - -xhtml: $(XHTML_DIR)/DnI-xhtml.xml -html: $(HTML_DIR)/DnI.html -fo: $(PDF_DIR)/DnI.fo -pdf: $(PDF_DIR)/DnI.pdf - -$(XHTML_DIR)/DnI-xhtml.xml: $(BOOK) $(CHAPTERS) $(CUSTOM_DOCBOOK_XHTML_STYLESHEET) $(BOOKMAKER_CLASS) - [ -d $(XHTML_DIR) ] || mkdir -p $(XHTML_DIR) - java $(JAVAFLAGS) \ - -classpath $(XERCESCLASSPATH):$(SAXONCLASSPATH):$(AVALONCLASSPATH):$(RESOLVERCLASSPATH):$(CLICLASSPATH):$(BOOKMAKERCLASSPATH):$(CLASSPATH) \ - BookMaker $(PROGOPTS) --parameter base.dir $(XHTML_DIR)/ -xml $< -xsl $(CUSTOM_DOCBOOK_XHTML_STYLESHEET) -out $@ - -$(HTML_DIR)/DnI.html: $(BOOK) $(CHAPTERS) $(CUSTOM_DOCBOOK_HTML_STYLESHEET) $(BOOKMAKER_CLASS) - [ -d $(HTML_DIR) ] || mkdir -p $(HTML_DIR) - java $(JAVAFLAGS) \ - -classpath $(XERCESCLASSPATH):$(SAXONCLASSPATH):$(AVALONCLASSPATH):$(RESOLVERCLASSPATH):$(CLICLASSPATH):$(BOOKMAKERCLASSPATH):$(CLASSPATH) \ - BookMaker $(PROGOPTS) --parameter base.dir $(HTML_DIR)/ -xml $< -xsl $(CUSTOM_DOCBOOK_HTML_STYLESHEET) -out $@ - -$(PDF_DIR)/DnI.fo: $(BOOK) $(CHAPTERS) $(CUSTOM_DOCBOOK_FO_STYLESHEET) $(BOOKMAKER_CLASS) - [ -d $(PDF_DIR) ] || mkdir -p $(PDF_DIR) - java $(JAVAFLAGS) \ - -classpath $(XERCESCLASSPATH):$(SAXONCLASSPATH):$(AVALONCLASSPATH):$(RESOLVERCLASSPATH):$(CLICLASSPATH):$(BOOKMAKERCLASSPATH):$(CLASSPATH) \ - BookMaker $(PROGOPTS) -xml $< -xsl $(CUSTOM_DOCBOOK_FO_STYLESHEET) -out $@ - -$(PDF_DIR)/DnI.pdf: $(BOOK) $(CHAPTERS) $(CUSTOM_DOCBOOK_FO_STYLESHEET) $(BOOKMAKER_CLASS) - [ -d $(PDF_DIR) ] || mkdir -p $(PDF_DIR) - java $(JAVAFLAGS) \ - -classpath $(XERCESCLASSPATH):$(SAXONCLASSPATH):$(FOPCLASSPATH):$(AVALONCLASSPATH):$(RESOLVERCLASSPATH):$(CLICLASSPATH):$(BOOKMAKERCLASSPATH):$(CLASSPATH) \ - BookMaker $(PROGOPTS) -xml $< -xsl $(CUSTOM_DOCBOOK_FO_STYLESHEET) -pdf $@ - -$(BOOKMAKERCLASSPATH)/%.class: %.java - [ -d $(BOOKMAKERCLASSPATH) ] || mkdir -p $(BOOKMAKERCLASSPATH) - javac -classpath $(FOPCLASSPATH):$(AVALONCLASSPATH):$(RESOLVERCLASSPATH):$(CLICLASSPATH):$(CLASSPATH) \ - -d $(BOOKMAKERCLASSPATH) $< - -############################ distribution file ######################### - -CURRENT_DIR=documentation - -zip: documentation.zip - -documentation.zip: $(BOOK) $(CHAPTERS) $(STYLESHEETS) $(BOOKMAKER) Makefile README - -rm -f $@ - cd .. && zip $(CURRENT_DIR)/$@ ${^:%=$(CURRENT_DIR)/%} - -############################ test section ############################### - -TEST=test.xml -TEST_CHAPTERS=getnextbreakposs.xml overview.xml - -test-saxon.html: $(TEST) $(TEST_CHAPTERS) $(CUSTOM_DOCBOOK_HTML_STYLESHEET) $(BOOKMAKER_CLASS) - java $(JAVAFLAGS) -classpath $(XERCESCLASSPATH):$(SAXONCLASSPATH):$(AVALONCLASSPATH):$(RESOLVERCLASSPATH):$(CLICLASSPATH):$(BOOKMAKERCLASSPATH):$(CLASSPATH) BookMaker $(PROGOPTS) --parameter base.dir $(HTML_DIR)/ -xml $< -xsl $(CUSTOM_DOCBOOK_HTML_STYLESHEET) -out $@ - -test-saxon.xhtml: $(TEST) $(TEST_CHAPTERS) $(CUSTOM_DOCBOOK_XHTML_STYLESHEET) $(BOOKMAKER_CLASS) - java $(JAVAFLAGS) -classpath $(XERCESCLASSPATH):$(SAXONCLASSPATH):$(AVALONCLASSPATH):$(RESOLVERCLASSPATH):$(CLICLASSPATH):$(BOOKMAKERCLASSPATH):$(CLASSPATH) BookMaker $(PROGOPTS) --parameter base.dir $(XHTML_DIR)/ -xml $< -xsl $(CUSTOM_DOCBOOK_XHTML_STYLESHEET) -out $@ - -test-saxon.fo: $(TEST) $(TEST_CHAPTERS) $(CUSTOM_DOCBOOK_FO_STYLESHEET) $(BOOKMAKER_CLASS) - java $(JAVAFLAGS) -classpath $(XERCESCLASSPATH):$(SAXONCLASSPATH):$(AVALONCLASSPATH):$(RESOLVERCLASSPATH):$(CLICLASSPATH):$(BOOKMAKERCLASSPATH):$(CLASSPATH) BookMaker $(PROGOPTS) -xml $< -xsl $(CUSTOM_DOCBOOK_FO_STYLESHEET) -out $@ - -test-saxon.pdf: $(TEST) $(TEST_CHAPTERS) $(CUSTOM_DOCBOOK_FO_STYLESHEET) $(BOOKMAKER_CLASS) - java $(JAVAFLAGS) -classpath $(XERCESCLASSPATH):$(SAXONCLASSPATH):$(FOPCLASSPATH):$(AVALONCLASSPATH):$(RESOLVERCLASSPATH):$(CLICLASSPATH):$(BOOKMAKERCLASSPATH):$(CLASSPATH) BookMaker $(PROGOPTS) -xml $< -xsl $(CUSTOM_DOCBOOK_FO_STYLESHEET) -pdf $@ - -test-saxon-stf.pdf: $(TEST) $(TEST_CHAPTERS) $(CUSTOM_DOCBOOK_FO_STYLESHEET) $(BOOKMAKER_CLASS) - java $(JAVAFLAGS) -classpath $(XERCESCLASSPATH):$(SAXONCLASSPATH):$(FOPCLASSPATH):$(AVALONCLASSPATH):$(RESOLVERCLASSPATH):$(CLICLASSPATH):$(BOOKMAKERCLASSPATH):$(CLASSPATH) XML2PDF_STF $(PROGOPTS) -xml $< -xsl $(CUSTOM_DOCBOOK_FO_STYLESHEET) -pdf $@ - -test-xalan.html: $(TEST) $(TEST_CHAPTERS) $(CUSTOM_DOCBOOK_HTML_STYLESHEET) $(BOOKMAKER_CLASS) - java $(JAVAFLAGS) -classpath $(FOPCLASSPATH):$(AVALONCLASSPATH):$(RESOLVERCLASSPATH):$(CLICLASSPATH):$(BOOKMAKERCLASSPATH):$(CLASSPATH) BookMaker $(PROGOPTS) --parameter base.dir $(HTML_DIR)/ -xml $< -xsl $(CUSTOM_DOCBOOK_HTML_STYLESHEET) -out $@ - -test-xalan.xhtml: $(TEST) $(TEST_CHAPTERS) $(CUSTOM_DOCBOOK_XHTML_STYLESHEET) $(BOOKMAKER_CLASS) - java $(JAVAFLAGS) -classpath $(FOPCLASSPATH):$(AVALONCLASSPATH):$(RESOLVERCLASSPATH):$(CLICLASSPATH):$(BOOKMAKERCLASSPATH):$(CLASSPATH) BookMaker $(PROGOPTS) --parameter base.dir $(XHTML_DIR)/ -xml $< -xsl $(CUSTOM_DOCBOOK_XHTML_STYLESHEET) -out $@ - -test-xalan.fo: $(TEST) $(TEST_CHAPTERS) $(CUSTOM_DOCBOOK_FO_STYLESHEET) $(BOOKMAKER_CLASS) - java $(JAVAFLAGS) -classpath $(FOPCLASSPATH):$(AVALONCLASSPATH):$(RESOLVERCLASSPATH):$(CLICLASSPATH):$(BOOKMAKERCLASSPATH):$(CLASSPATH) BookMaker $(PROGOPTS) -xml $< -xsl $(CUSTOM_DOCBOOK_FO_STYLESHEET) -out $@ - -test-xalan.pdf: $(TEST) $(TEST_CHAPTERS) $(CUSTOM_DOCBOOK_FO_STYLESHEET) $(BOOKMAKER_CLASS) - java $(JAVAFLAGS) -classpath $(FOPCLASSPATH):$(AVALONCLASSPATH):$(RESOLVERCLASSPATH):$(CLICLASSPATH):$(BOOKMAKERCLASSPATH):$(CLASSPATH) BookMaker $(PROGOPTS) -xml $< -xsl $(CUSTOM_DOCBOOK_FO_STYLESHEET) -pdf $@ - -test-xalan-stf.pdf: $(TEST) $(TEST_CHAPTERS) $(CUSTOM_DOCBOOK_FO_STYLESHEET) $(BOOKMAKER_CLASS) - java $(JAVAFLAGS) -classpath $(FOPCLASSPATH):$(AVALONCLASSPATH):$(RESOLVERCLASSPATH):$(CLICLASSPATH):$(BOOKMAKERCLASSPATH):$(CLASSPATH) XML2PDF_STF $(PROGOPTS) -xml $< -xsl $(CUSTOM_DOCBOOK_FO_STYLESHEET) -pdf $@ - diff --git a/src/documentation/content/xdocs/DnI/README b/src/documentation/content/xdocs/DnI/README deleted file mode 100644 index a021880e9..000000000 --- a/src/documentation/content/xdocs/DnI/README +++ /dev/null @@ -1,82 +0,0 @@ -Readme for `FOP's design and implementation' - -This directory contains the documentation entitled `FOP's design and -implementation'. - -The book is structured according to the Docbook XML DTD version 4.2, -top-level element book. - -The top level file is DnI.xml. It calls in the various chapter files. - -The book can be converted to XHTML, HTML and FO using the Docbook XSL -stylesheets. For each of these formats there are customization XSL -stylesheets, which should be called as the main stylesheet of the -conversion. The customization stylesheets were written against version -1.64.1. The customization for FO is rather heavy, and may prove -incompatible with later versions of the docbook stylesheets. Of -course, you can always convert without the customization or with your -own customization. The changes will only affect the layout, not the -content of the book. - -The customization stylesheets for XHTML and HTML use the ability of -the docbook stylesheets to write the resulting files in chunks. It -makes sense to send the conversion result into a separate -directory. If you make both conversions, you must send them to -different directories, as they produce files of the same name. You can -produce the result in a single file by making a small change at the -top of the customization stylesheets: import the stylesheet -docbook.xsl instead of chunk.xsl. - -For the XHTML and HTML conversions I have obtained the best conversion -results using Saxon. I have used FOP-0.20.5 for FO Processor. - -The top-level file assumes that the docbook DTD files are located in -`http://www.oasis-open.org/docbook/xml/4.2/'. The customization -stylesheets assume that the docbook stylesheets are located in -`http://docbook.sourceforge.net/release/xsl/current/'. If you want to -use local files from your XML installation, you must change these -paths at the top of the top-level XML file and of each customization -stylesheet. Alternatively, you can use catalog entries to map the -Public ID for the Docbook DTD and the system id of the docbook XSL -stylesheets to your local paths. - -You can use the included java class BookMaker to generate the various -forms of the documentation. Note that it requires the Jakarta Commons -CLI package. Call BookMaker with the option '--help' to get a short -overview of its usage. Use the included Makefile or Ant build file, or -learn from them how the BookMaker class can be called. - -Unfortunately, I do not know of a standard file system setup for java -jar files. The class paths in the Makefile reflect the java setup of a -Debian Sarge system. Moreover, it allows for the same setup in -/usr/local, for jar files installed locally. If you use the Makefile, -you must edit the class paths to reflect your own java setup. If you -want to use a catalog with the Makefile, you should set the -environment variable PROGOPTS=--useCatalog. I have better results -with Xerces and the catalog resolver; therefore Xerces is placed -before Saxon in the class paths. - -For instructions to use the Ant build file, see the comments at the -top of that file. - -If you do not use a catalog, you can also use Saxon and FOP from the -command line. The following are typical invocations. Here the -classpaths have obvious meanings. JAVAFLAGS are any other options for -java, possibly none. - -java $JAVAFLAGS -cp "$SAXONCLASSPATH:$CLASSPATH" \ - com.icl.saxon.StyleSheet \ - -o ../documentation-xhtml/book-xhtml.xml \ - DnI.xml cust-xhtml-docbook.xsl - -java $JAVAFLAGS -cp "$SAXONCLASSPATH:$CLASSPATH" \ - com.icl.saxon.StyleSheet \ - -o ../documentation-html/book.html \ - DnI.xml cust-html-docbook.xsl - -java $JAVAFLAGS \ - -cp $SAXONCLASSPATH:$FOPCLASSPATH:$AVALONCLASSPATH:$CLASSPATH \ - org.apache.fop.apps.Fop \ - -xml DnI.xml -xsl cust-html-docbook.xsl -pdf book.pdf - -$Id$ diff --git a/src/documentation/content/xdocs/DnI/addareas.xml b/src/documentation/content/xdocs/DnI/addareas.xml deleted file mode 100644 index 3cbbffaba..000000000 --- a/src/documentation/content/xdocs/DnI/addareas.xml +++ /dev/null @@ -1,972 +0,0 @@ -<?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$ --> - -<!-- -<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" - "docbookx.dtd"> - --> - - <chapter> - <title>Phase 2b: The <literal>addAreas</literal> call tree</title> - - <section> - <title>Overview</title> - - <para>This section presents a verbose overview of the -<literal>addAreas</literal> call tree. The following section presents -the Layout Managers in more detail.</para> - - <itemizedlist> - - <listitem> - <simpara>FlowLM receives from its parent LM an iterator with a -single pagebreak. The first belongs to BlockLM1, the second belongs to -BlockLM2. FlowLM itself holds 2 child BPs. The flow consists of two -blocks. FlowLM sets up an iterator with its 2 BPs.</simpara> - </listitem> - - <listitem> - <simpara>BlockLM1 receives from its parent LM the iterator -with those 2 BPs, of which only the first one belongs to it. Its leaf -position is 13. BlockLM itself holds 14 child BPs, which all belong to -a single LineLM. The block consists of 14 lines. BlockLM sets up an -iterator corresponding to the first BP, containing the child BPs -0–13.</simpara> - </listitem> - - <listitem> - <simpara>LineLM receives from its parent LM an iterator with -those 14 BPs. The leaf positions are 3, 6, 11, 12, 13, 16, 19, 21, 23, -24, 25, 26, 27, 28. LineLM itself holds 29 child BPs, which all belong -to a single TextLM. LineLM maintains the position of the next BP in -<literal>vecInlineBreaks</literal>, <literal>iStartPos</literal>. -Initially it is set to 0. For each of its 14 BPs in the iterator, -LineLM sets up an iterator with the child BPs in -<literal>vecInlineBreaks</literal> from <literal>iStartPos</literal> -up to an including the index <literal>iLeafPos</literal> to which the -iterator BP points. Then it <literal>updates</literal> iStartPos to -point to the next child BP. The iterators contain the child BP ranges: -0–3, 4–6, 7–11, 12, 13, 14–16, 17–19, 20–21, 22–23, 24, 25, 26, 27, -28.</simpara> - - <screen>while (parentIter.hasNext()) { - LineBreakPosition lbp = (LineBreakPosition) parentIter.next(); - ... - PositionIterator inlinePosIter = - new BreakPossPosIter(vecInlineBreaks, iStartPos, - lbp.getLeafPos() + 1); - iStartPos = lbp.getLeafPos() + 1; - ... - while ((childLM = inlinePosIter.getNextChildLM()) != null) { - childLM.addAreas(inlinePosIter, lc); - ... - } - ... -} -</screen> - </listitem> - - <listitem> -<simpara>TextLM receives from its parent LM an iterator with the BPs -0–3. The leaf positions are 0, 1, 2, 3. It has itself 47 items in -<literal>vecAreaInfo</literal>. It iterates over the 4 corresponding -AIs, records the start of the first one, counts the word spaces, and -records the end of the last one. This line contains the characters -from 0 up to 13 and has no word spaces.</simpara> - </listitem> - - <listitem> - <simpara>TextLM receives from its parent LM an iterator with -the BPs 4–6. The leaf positions are 5, 7, 8. It iterates over the -three corresponding AIs. This line contains the characters from 13 up -to 26 and has one word space. Note that the AIs 4 and 6 remain unused -because they do not have a corresponding BP. These AIs represent areas -that were too long, and over which the LM backed up.</simpara> - </listitem> - - <listitem> - <simpara>TextLM receives from its parent LM an iterator with -the BPs 7–11. The leaf positions are 11, 12, 13, 14, 15. It iterates -over the five corresponding AIs. This line contains the characters -from 26 up to 40 and has no word spaces. Note that the AIs 9 and 10 -remain unused because they do not have a corresponding BP.</simpara> - </listitem> - - <listitem> - <simpara>TextLM receives from its parent LM an iterator with -the single BP 12. The leaf position is 16. This line contains the -characters from 40 up to 42 and has no word spaces.</simpara> - </listitem> - - <listitem> - <simpara>TextLM receives from its parent LM an iterator with -the single BP 13. The leaf position is 18. This line contains the -characters from 43 up to 60 and has no word spaces. Note that the AI -17 remains unused because it does not have a corresponding BP. Note -also that character 42 has been dropped, because it would be a leading -space.</simpara> - </listitem> - - <listitem> - <simpara>etc. until all 14 line areas are done. LineLM -returns.</simpara> - </listitem> - - <listitem> - <simpara>The second BP in the iterator from FlowLM belongs to -BlockLM2. The loop <literal>while (parentIter.hasNext())</literal> -ends because the LM of the next object is different from the current -LM (<literal>BreakPossPosIter.checkNext()</literal>), and BlockLM1 -returns. FlowLM's loop <literal>while ((childLM = -breakPosIter.getNextChildLM()) != null)</literal> then passes the -iterator to BlockLM2.</simpara> - </listitem> - - <listitem> - <simpara>BlockLM2 receives from its parent LM the iterator with those 2 -BPs. The cursor is at one, because BlockLM1 has used the first object. -Only the second BP belongs to BlockLM2. Its leaf position is -0. BlockLM itself holds 1 child BP, belonging to a LineLM. The block -consists of a single line. BlockLM sets up an iterator corresponding -to the second BP, containing a single child BP.</simpara> - </listitem> - - <listitem> -<simpara>LineLM receives from its parent LM an iterator with that BP. -The leaf position is 1. LineLM itself holds 2 child BPs, one belonging -to a TextLM, the other to <literal>AddLMVisitor$2</literal>. LineLM -sets up an iterator corresponding to the BP, containing its two child -BPs.</simpara> - </listitem> - - <listitem> -<simpara>TextLM receives from its parent LM an iterator with the BPs 0 -and 1, of which only the first belongs to it. Its leaf position is 0. -It iterates over the corresponding AI. This text area contains the -characters from 0 up to 1, i.e. <literal>" "</literal>, and has one -word space. This converted to a space area.</simpara> - </listitem> - - <listitem> - <simpara><literal>AddLMVisitor$2</literal> receives from its -parent LM an iterator with the BPs 0 and 1. The cursor is at one, -because TextLM has used the first object. Only the second BP belongs -to <literal>AddLMVisitor$2</literal>. Its leaf position is -0.</simpara> - </listitem> - - <listitem> - <simpara>This completes the line. LineLM returns.</simpara> - </listitem> - - <listitem> - <simpara>BlockLM2 returns.</simpara> - </listitem> - - <listitem> - <simpara>FlowLM returns.</simpara> - </listitem> - </itemizedlist> - - </section> - - <section> - <title>Detailed overviews</title> - - <section> - <title>PageLM</title> - -<screen> - bbp = { - breakps: instance of org.apache.fop.layoutmgr.BreakPoss(id=1167) - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 0 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.FlowLayoutManager(id=1169) -} - - bbp.breakps.position = { - iLeafPos: 1 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.FlowLayoutManager(id=1169) -} - - list = "[org.apache.fop.layoutmgr.BreakPoss@1aa2c23]" - - list.get(0).position = { - iLeafPos: 1 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.FlowLayoutManager(id=1169) -} - - list.get(0).position.layoutManager = "org.apache.fop.layoutmgr.FlowLayoutManager@6963d0" -</screen> - </section> - - <section> - <title>FlowLM</title> - -<screen> - this = "org.apache.fop.layoutmgr.FlowLayoutManager@6963d0" - - lfp = { - iLeafPos: 1 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.FlowLayoutManager(id=1169) -} - - iStartPos = 0 - - blockBreaks = "[org.apache.fop.layoutmgr.BreakPoss@111bfbc, org.apache.fop.layoutmgr.BreakPoss@4310d0]" - - blockBreaks.get(iStartPos).position = { - iLeafPos: 13 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.BlockLayoutManager(id=1183) -} - - blockBreaks.get(iStartPos).position.layoutManager = "org.apache.fop.layoutmgr.BlockLayoutManager@19e09a4" - - blockBreaks.get(iStartPos+1).position = { - iLeafPos: 0 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.BlockLayoutManager(id=1186) -} - - blockBreaks.get(iStartPos+1).position.layoutManager = "org.apache.fop.layoutmgr.BlockLayoutManager@144b18f" -</screen> - </section> - - <section> - <title>BlockLM1</title> - -<screen> - this = "org.apache.fop.layoutmgr.BlockLayoutManager@19e09a4" - - lfp = { - iLeafPos: 13 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.BlockLayoutManager(id=1183) -} - - iStartPos = 0 - - childBreaks = "[ -org.apache.fop.layoutmgr.BreakPoss@2b249, -org.apache.fop.layoutmgr.BreakPoss@106daba, -org.apache.fop.layoutmgr.BreakPoss@1021f34, -org.apache.fop.layoutmgr.BreakPoss@4eb043, -org.apache.fop.layoutmgr.BreakPoss@163956, -org.apache.fop.layoutmgr.BreakPoss@10e434d, -org.apache.fop.layoutmgr.BreakPoss@16477d9, -org.apache.fop.layoutmgr.BreakPoss@f864fe, -org.apache.fop.layoutmgr.BreakPoss@1ae9aaa, -org.apache.fop.layoutmgr.BreakPoss@2c17f7, -org.apache.fop.layoutmgr.BreakPoss@d9896e, -org.apache.fop.layoutmgr.BreakPoss@1cda59b, -org.apache.fop.layoutmgr.BreakPoss@33788d, -org.apache.fop.layoutmgr.BreakPoss@12fb0af -]" - - childBreaks.get(0).position = { - dAdjust: 0.0 - ipdAdjust: 1.0 - startIndent: 0 - lineHeight: 19200 - baseline: 17000 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 3 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1199) -} - - childBreaks.get(0).position.layoutManager = "org.apache.fop.layoutmgr.LineLayoutManager@c06258" - - childBreaks.get(1).position = { - dAdjust: 0.0 - ipdAdjust: 1.0 - startIndent: 0 - lineHeight: 19200 - baseline: 17000 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 6 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1199) -} - - childBreaks.get(1).position.layoutManager = "org.apache.fop.layoutmgr.LineLayoutManager@c06258" - - childBreaks.get(2).position = { - dAdjust: 0.0 - ipdAdjust: 1.0 - startIndent: 0 - lineHeight: 19200 - baseline: 17000 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 11 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1199) -} - - childBreaks.get(2).position.layoutManager = "org.apache.fop.layoutmgr.LineLayoutManager@c06258" - - childBreaks.get(3).position = { - dAdjust: 7.0 - ipdAdjust: 1.0 - startIndent: 0 - lineHeight: 19200 - baseline: 17000 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 12 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1199) -} - - childBreaks.get(3).position.layoutManager = "org.apache.fop.layoutmgr.LineLayoutManager@c06258" - - childBreaks.get(4).position = { - dAdjust: 0.0 - ipdAdjust: -1.0 - startIndent: 0 - lineHeight: 19200 - baseline: 17000 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 13 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1199) -} - - childBreaks.get(4).position.layoutManager = "org.apache.fop.layoutmgr.LineLayoutManager@c06258" - - childBreaks.get(5).position = { - dAdjust: 0.0 - ipdAdjust: 1.0 - startIndent: 0 - lineHeight: 19200 - baseline: 17000 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 16 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1199) -} - - childBreaks.get(5).position.layoutManager = "org.apache.fop.layoutmgr.LineLayoutManager@c06258" - - childBreaks.get(6).position = { - dAdjust: 0.0 - ipdAdjust: 1.0 - startIndent: 0 - lineHeight: 19200 - baseline: 17000 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 19 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1199) -} - - childBreaks.get(6).position.layoutManager = "org.apache.fop.layoutmgr.LineLayoutManager@c06258" - - childBreaks.get(7).position = { - dAdjust: 0.0 - ipdAdjust: 1.0 - startIndent: 0 - lineHeight: 19200 - baseline: 17000 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 21 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1199) -} - - childBreaks.get(7).position.layoutManager = "org.apache.fop.layoutmgr.LineLayoutManager@c06258" - - childBreaks.get(8).position = { - dAdjust: 0.0 - ipdAdjust: 1.0 - startIndent: 0 - lineHeight: 19200 - baseline: 17000 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 23 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1199) -} - - childBreaks.get(8).position.layoutManager = "org.apache.fop.layoutmgr.LineLayoutManager@c06258" - - childBreaks.get(9).position = { - dAdjust: 0.0 - ipdAdjust: 1.0 - startIndent: 0 - lineHeight: 19200 - baseline: 17000 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 24 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1199) -} - - childBreaks.get(9).position.layoutManager = "org.apache.fop.layoutmgr.LineLayoutManager@c06258" - - childBreaks.get(10).position = { - dAdjust: 0.0 - ipdAdjust: 1.0 - startIndent: 0 - lineHeight: 19200 - baseline: 17000 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 25 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1199) -} - - childBreaks.get(10).position.layoutManager = "org.apache.fop.layoutmgr.LineLayoutManager@c06258" - - childBreaks.get(11).position = { - dAdjust: 0.0 - ipdAdjust: 1.0 - startIndent: 0 - lineHeight: 19200 - baseline: 17000 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 26 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1199) -} - - childBreaks.get(11).position.layoutManager = "org.apache.fop.layoutmgr.LineLayoutManager@c06258" - - childBreaks.get(12).position = { - dAdjust: 0.0 - ipdAdjust: 1.0 - startIndent: 0 - lineHeight: 19200 - baseline: 17000 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 27 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1199) -} - - childBreaks.get(12).position.layoutManager = "org.apache.fop.layoutmgr.LineLayoutManager@c06258" - - childBreaks.get(13).position = { - dAdjust: 0.0 - ipdAdjust: 1.0 - startIndent: 0 - lineHeight: 19200 - baseline: 17000 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 28 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1199) -} - - childBreaks.get(13).position.layoutManager = "org.apache.fop.layoutmgr.LineLayoutManager@c06258" -</screen> - </section> - - <section> - <title>LineLM</title> - -<screen> - this = "org.apache.fop.layoutmgr.LineLayoutManager@c06258" - - lbp = { - dAdjust: 0.0 - ipdAdjust: 1.0 - startIndent: 0 - lineHeight: 19200 - baseline: 17000 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 3 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1199) -} - - iStartPos = 0 - - vecInlineBreaks = "[ -org.apache.fop.layoutmgr.BreakPoss@17e4dee, -org.apache.fop.layoutmgr.BreakPoss@12e7c6a, -org.apache.fop.layoutmgr.BreakPoss@ea5461, -org.apache.fop.layoutmgr.BreakPoss@49cf9f, -org.apache.fop.layoutmgr.BreakPoss@1de0b5e, -org.apache.fop.layoutmgr.BreakPoss@bc5596, -org.apache.fop.layoutmgr.BreakPoss@970c0e, -org.apache.fop.layoutmgr.BreakPoss@987197, -org.apache.fop.layoutmgr.BreakPoss@497904, -org.apache.fop.layoutmgr.BreakPoss@1a7f9dc, -org.apache.fop.layoutmgr.BreakPoss@104e28b, -org.apache.fop.layoutmgr.BreakPoss@1b54362, -org.apache.fop.layoutmgr.BreakPoss@15b0e2c, -org.apache.fop.layoutmgr.BreakPoss@ff9053, -org.apache.fop.layoutmgr.BreakPoss@5c7734, -org.apache.fop.layoutmgr.BreakPoss@96212a, -org.apache.fop.layoutmgr.BreakPoss@5b675e, -org.apache.fop.layoutmgr.BreakPoss@df83e5, -org.apache.fop.layoutmgr.BreakPoss@4c6320, -org.apache.fop.layoutmgr.BreakPoss@ffd135, -org.apache.fop.layoutmgr.BreakPoss@1000bcf, -org.apache.fop.layoutmgr.BreakPoss@754fc, -org.apache.fop.layoutmgr.BreakPoss@15c998a, -org.apache.fop.layoutmgr.BreakPoss@6458a6, -org.apache.fop.layoutmgr.BreakPoss@1f82ab4, -org.apache.fop.layoutmgr.BreakPoss@1bb9696, -org.apache.fop.layoutmgr.BreakPoss@9b6220, -org.apache.fop.layoutmgr.BreakPoss@1474e45, -org.apache.fop.layoutmgr.BreakPoss@63a721 -]" - - vecInlineBreaks.get(0).position = { - iLeafPos: 0 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(0).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(1).position = { - iLeafPos: 1 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(1).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(2).position = { - iLeafPos: 2 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(2).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(3).position = { - iLeafPos: 3 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(3).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(4).position = { - iLeafPos: 5 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(4).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(5).position = { - iLeafPos: 7 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(5).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(6).position = { - iLeafPos: 8 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(6).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(7).position = { - iLeafPos: 11 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(7).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(8).position = { - iLeafPos: 12 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(8).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(9).position = { - iLeafPos: 13 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(9).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(10).position = { - iLeafPos: 14 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(10).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(11).position = { - iLeafPos: 15 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(11).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(12).position = { - iLeafPos: 16 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(12).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(13).position = { - iLeafPos: 18 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(13).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(14).position = { - iLeafPos: 20 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(14).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(15).position = { - iLeafPos: 21 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(15).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(16).position = { - iLeafPos: 22 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(16).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(17).position = { - iLeafPos: 23 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(17).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - vecInlineBreaks.get(18).position = { - iLeafPos: 25 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecInlineBreaks.get(18).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" -</screen> - </section> - - <section> - <title>TextLM</title> - -<screen> - this = "org.apache.fop.layoutmgr.TextLayoutManager@57ea52" - - this.chars = { -w, a, t, e, r, s, t, a, a, t, s, i, n, g, e, n, i, e, u, r, - , m, i, n, i, s, t, e, r, s, p, o, r, t, e, f, e, u, i, l, l, e, - , a, a, n, d, a, c, h, t, s, t, r, e, k, k, e, r, ., - , V, e, r, n, e, d, e, r, l, a, n, d, s, t, e, - , v, a, k, l, i, t, e, r, a, t, u, u, r, - , v, e, r, s, c, h, i, l, l, e, n, d, - , v, e, r, h, o, l, l, a, n, d, s, t, e, - , v, a, k, l, i, t, e, r, a, t, u, u, r, ., - , b, e, s, t, u, u, r, s, t, a, k, e, n, - , l, a, n, d, s, t, a, a, l, - , b, e, l, a, n, g, r, i, j, k, . -} - - tbpNext = { - iLeafPos: 0 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo = "[ -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@107bd0d, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@12922f6, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@1b66b06, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@12c9557, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@9f0d, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@ca3783, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@2a6ff, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@21d23b, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@7124af, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@1f7708, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@1bfbfb8, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@1c3e9ba, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@125d61e, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@10c6cfc, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@c72243, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@19a8416, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@155d3a3, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@1b994de, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@dc9766, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@57e787, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@1217e67, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@1f1bd98, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@1d686c1, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@128edf2, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@1dddba, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@c7e8a7, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@7b4703, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@1732ed2, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@1071521, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@1fc3c84, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@e93999, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@1c486f2, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@1779885, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@be76c7, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@682406, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@115126e, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@6d2380, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@135b1f3, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@35e6e3, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@c9630a, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@185572a, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@11daa0e, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@879860, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@24de7d, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@8b058b, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@1192059, -org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@9ac0f5 -]" - - vecAreaInfo.get(0) = { - iStartIndex: 0 - iBreakIndex: 2 - iWScount: 0 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1304) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(1) = { - iStartIndex: 2 - iBreakIndex: 5 - iWScount: 0 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1308) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(2) = { - iStartIndex: 5 - iBreakIndex: 11 - iWScount: 0 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1310) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(3) = { - iStartIndex: 11 - iBreakIndex: 13 - iWScount: 0 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1312) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(4) = { - iStartIndex: 13 - iBreakIndex: 15 - iWScount: 0 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1314) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(5) = { - iStartIndex: 13 - iBreakIndex: 20 - iWScount: 0 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1316) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(6) = { - iStartIndex: 20 - iBreakIndex: 42 - iWScount: 1 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1318) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(7) = { - iStartIndex: 20 - iBreakIndex: 23 - iWScount: 1 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1320) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(8) = { - iStartIndex: 23 - iBreakIndex: 26 - iWScount: 0 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1322) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(9) = { - iStartIndex: 26 - iBreakIndex: 30 - iWScount: 0 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1324) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(10) = { - iStartIndex: 26 - iBreakIndex: 42 - iWScount: 0 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1326) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(11) = { - iStartIndex: 26 - iBreakIndex: 29 - iWScount: 0 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1328) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(12) = { - iStartIndex: 29 - iBreakIndex: 30 - iWScount: 0 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1330) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(13) = { - iStartIndex: 30 - iBreakIndex: 33 - iWScount: 0 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1332) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(14) = { - iStartIndex: 33 - iBreakIndex: 35 - iWScount: 0 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1334) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(15) = { - iStartIndex: 35 - iBreakIndex: 40 - iWScount: 0 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1336) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(16) = { - iStartIndex: 40 - iBreakIndex: 42 - iWScount: 0 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1338) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(17) = { - iStartIndex: 42 - iBreakIndex: 60 - iWScount: 1 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1340) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} - - vecAreaInfo.get(18) = { - iStartIndex: 43 - iBreakIndex: 60 - iWScount: 0 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1342) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1246) -} -</screen> - </section> - - <section> - <title>BlockLM2</title> - -<screen> - this = "org.apache.fop.layoutmgr.BlockLayoutManager@144b18f" - - lfp = { - iLeafPos: 0 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.BlockLayoutManager(id=1186) -} - - iStartPos = 0 - - childBreaks = "[org.apache.fop.layoutmgr.BreakPoss@145f939]" - - childBreaks.get(0).position = { - dAdjust: 0.0 - ipdAdjust: -1.0 - startIndent: 0 - lineHeight: 14400 - baseline: 12750 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 1 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1377) -} - - childBreaks.get(0).position.layoutManager = "org.apache.fop.layoutmgr.LineLayoutManager@df2d38" -</screen> - </section> - - <section> - <title>LineLM</title> - -<screen> - this = "org.apache.fop.layoutmgr.LineLayoutManager@df2d38" - - lbp = { - dAdjust: 0.0 - ipdAdjust: -1.0 - startIndent: 0 - lineHeight: 14400 - baseline: 12750 - org.apache.fop.layoutmgr.LeafPosition.iLeafPos: 1 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1377) -} - - iStartPos = 0 - - vecInlineBreaks = "[ -org.apache.fop.layoutmgr.BreakPoss@eb67e8, -org.apache.fop.layoutmgr.BreakPoss@f2ea42 -]" - - vecInlineBreaks.get(0).position = { - iLeafPos: 0 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1385) -} - - vecInlineBreaks.get(0).position.layoutManager = "org.apache.fop.layoutmgr.TextLayoutManager@e265d0" - - vecInlineBreaks.get(1).position = { - iLeafPos: 0 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.AddLMVisitor$2(id=1389) -} - - vecInlineBreaks.get(1).position.layoutManager = "org.apache.fop.layoutmgr.AddLMVisitor$2@2f356f" -</screen> - </section> - - <section> - <title>TextLM</title> - -<screen> - this = "org.apache.fop.layoutmgr.TextLayoutManager@e265d0" - - this.chars = { - -} - - tbpNext = { - iLeafPos: 0 - org.apache.fop.layoutmgr.Position.layoutManager: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1385) -} - - vecAreaInfo = "[org.apache.fop.layoutmgr.TextLayoutManager$AreaInfo@996cca]" - - vecAreaInfo.get(0) = { - iStartIndex: 0 - iBreakIndex: 1 - iWScount: 1 - ipdArea: instance of org.apache.fop.traits.MinOptMax(id=1396) - this$0: instance of org.apache.fop.layoutmgr.TextLayoutManager(id=1385) -} -</screen> - </section> - - <section> - <title><literal>AddLMVisitor$2</literal></title> - <simpara>No data</simpara> - </section> - - </section> - </chapter> - -<!-- Local Variables: --> -<!-- current-language-environment: UTF-8 --> -<!-- coding: utf-8 --> -<!-- default-input-method: TeX --> -<!-- End: --> diff --git a/src/documentation/content/xdocs/DnI/areatree.xml b/src/documentation/content/xdocs/DnI/areatree.xml deleted file mode 100644 index 2e8bf1945..000000000 --- a/src/documentation/content/xdocs/DnI/areatree.xml +++ /dev/null @@ -1,390 +0,0 @@ -<?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$ --> - -<!-- -<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" - "docbookx.dtd"> - --> - - <chapter> - <title>Phase 2: Building the Area tree</title> - - <section> - <title>Initiating the layout process</title> - -<para>In the <literal>PageSequence.endOfNode()</literal> method, the -<literal>AreaTreeHandler</literal> object -<literal>foEventHandler</literal>'s method -<literal>endPageSequence</literal> is called. This method constructs a -<literal>PageSequenceLayoutManager</literal> for the -<literal>PageSequence</literal> FO node, which manages all page-related -layout.</para> - -<screen> -org.apache.fop.fo.pagination.PageSequence.endOfNode(): -this.getFOEventHandler().getFOEventHandler().endPageSequence(this): --> foTreeBuilder.getFOEventHandler().endPageSequence(this) --> foEventHandler.endPageSequence(this) (type AreaTreeHandler): -</screen> - -<para>This method creates a new -<literal>PageSequenceLayoutManager</literal> for the -<literal>PageSequence</literal> FO node. The pages in this page sequence -are completely layed out by the -<literal>PageSequenceLayoutManager</literal>, in its -<literal>activateLayout</literal> method. The first step in the layout -process is getting the page setup from the page masters. Then the FO tree -is processed.</para> - -<screen> - [1] org.apache.fop.layoutmgr.PageSequenceLayoutManager.activateLayout (PageLayoutManager.java:211) - [2] org.apache.fop.fo.area.AreaTreeHandler.endPageSequence (AreaTreeHandler.java:242) - [3] org.apache.fop.fo.pagination.PageSequence.endOfNode (PageSequence.java:202) - [4] org.apache.fop.fo.FOTreeBuilder.endElement (FOTreeBuilder.java:292) - ... parser stuff - [13] org.apache.xerces.parsers.AbstractSAXParser.parse (null) - [14] org.apache.xalan.transformer.TransformerIdentityImpl.transform (null) - [15] org.apache.fop.apps.InputHandler.render (InputHandler.java:120) - [16] org.apache.fop.apps.Fop.main (Fop.java:102) -</screen> - -<screen> -main[1] dump pageSLM - pageSLM = { - areaTreeHandler= org.apache.fop.area.AreaTreeHandler (id=79) - areaTreeModel= org.apache.fop.area.RenderPagesModel (id=81) - bFinished= false - bFirstPage= false - bInited= false - childLMiter= org.apache.fop.layoutmgr.LMiter (id=85) - childLMs= java.util.ArrayList (id=89) - curBody= null - curChildLM= null - curFlow= null - curPage= null - currentSimplePageMaster= null - curSpan= null - curSpanColumns= 0 - flowBPD= 0 - flowIPD= 0 - fobj= org.apache.fop.fo.pagination.PageSequence (id=12) - fobjIter= java.util.AbstractList$ListItr (id=90) - isFirstPage= true - markers= null - pageCount= 1 - pageNumberGenerator= null - pageNumberString= null - parentLM= null - staticContentLMs= java.util.HashMap (id=93) -} -</screen> - -<para>The above calling sequence contains one configuration - point. FOP's area tree building process can be modified by - registering a different LayoutManagerMaker with the Area tree - handler. The LayoutManagerMaker controls the creation of Layout - Managers. -<warning> - <simpara>TO BE EXPANDED</simpara> - </warning></para> - - </section> - - <section> - <title>Creating the page and body areas</title> - - <section> - <title>Overview</title> - - <para>Create the layout (<literal>activateLayout</literal>) <itemizedlist spacing="compact"> - <listitem> - <para>First create a new Page Viewport -(<literal>makeNewPage</literal>). <itemizedlist spacing="compact"> - <listitem> - <para>First finish the current page -(<literal>finishPage</literal>).</para> - </listitem> - <listitem> - <para>Then create the new page viewport -(<literal>createPage</literal>). <itemizedlist spacing="compact"> - <listitem> - <para>First get the page master -(<literal>getSimplePageMasterToUse</literal>, -<literal>pageSequence.getPageSequenceMaster</literal> or -<literal>pageSequence.getSimplePageMaster</literal>).</para> - </listitem> - <listitem> - <para>Then get the body -(<literal>currentSimplePageMaster.getRegion</literal>, from -<literal>currentSimplePageMaster</literal>'s -<literal>regions</literal> map).</para> - </listitem> - <listitem> - <para>Then create the page viewport -(<literal>createPageAreas(currentSimplePageMaster)</literal>). -<itemizedlist spacing="compact"> - <listitem> - <para>From the properties of the page -master create the page reference rectangle, a new page, a new -FODimension object, and a CTM object.</para> - </listitem> - <listitem> - <para>For each region in the page master -(in our example we only have a body): <itemizedlist spacing="compact"> - <listitem> - <para>make a region viewport -(<literal>makeRegionViewport</literal>), which involves calculating -the position of the region on the page, using the FODimension and CTM -objects. -</para> - </listitem> - <listitem> - <para>make the reference area -(<literal>makeRegionBodyReferenceArea</literal>, -<literal>makeRegionReferenceArea</literal>).</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - - <para>At this point the page viewport and its region viewports -have been laid out.</para> - - <para> <itemizedlist spacing="compact"> - <listitem> - <simpara>Then create the body's main reference area -(<literal>createBodyMainReferenceArea</literal>).</simpara> - </listitem> - <listitem> - <simpara>Then create a Span -(<literal>createSpan</literal>).</simpara> - </listitem> - <listitem> - <simpara>And get the flowIPD -(curFlow.<literal>getIPD</literal>()).</simpara> - </listitem> - </itemizedlist></para> - - <para>At this point the body has a single span area with a -single flow area without children. -</para> - - </section> - - <section> - <title>Detailed view</title> - - <para>The call stack when creating the region viewports: -<screen> - [1] org.apache.fop.layoutmgr.PageLayoutManager.makeRegionViewport (PageLayoutManager.java:832) - [2] org.apache.fop.layoutmgr.PageLayoutManager.createPageAreas (PageLayoutManager.java:805) - [3] org.apache.fop.layoutmgr.PageLayoutManager.createPage (PageLayoutManager.java:748) - [4] org.apache.fop.layoutmgr.PageLayoutManager.makeNewPage (PageLayoutManager.java:467) - [5] org.apache.fop.layoutmgr.PageLayoutManager.activateLayout (PageLayoutManager.java:220) -</screen> -</para> - -<para>At the end of <literal>createPageAreas</literal> the following -properties of the page have been established:</para> - -<para>The page reference rectangle: -<screen> - pageRefRect = { - x: 56692 - y: 56692 - width: 481891 - height: 728505 - serialVersionUID: -4345857070255674764 -} -</screen> -</para> - -<para>The page reference area: -<screen> - page = { - regionBefore: null - regionStart: null - regionBody: instance of org.apache.fop.area.RegionViewport(id=1279) - regionEnd: null - regionAfter: null - unresolved: null -} -</screen> - -<screen> - page.regionBody = { - region: instance of org.apache.fop.area.BodyRegion(id=1280) - viewArea: instance of java.awt.Rectangle(id=1281) - clip: false - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 0 - org.apache.fop.area.Area.props: null -} -</screen> - -<screen> - page.regionBody.region = { - beforeFloat: null - mainReference: null - footnote: null - columnGap: 18000 - columnCount: 1 - refIPD: 0 - org.apache.fop.area.RegionReference.regionClass: 2 - org.apache.fop.area.RegionReference.ctm: instance of org.apache.fop.area.CTM(id=1282) - org.apache.fop.area.RegionReference.blocks: instance of java.util.ArrayList(id=1283) - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 0 - org.apache.fop.area.Area.props: null -} -</screen> - -<screen> - page.regionBody.viewArea = { - x: 56692 - y: 56692 - width: 481891 - height: 728505 - serialVersionUID: -4345857070255674764 -} -</screen> -</para> - -<para>The <literal>PageViewport</literal> is returned:</para> - -<screen> - curPage = { - page: instance of org.apache.fop.area.Page(id=1261) - viewArea: instance of java.awt.Rectangle(id=1289) - clip: false - pageNumber: null - idReferences: null - unresolved: null - pendingResolved: null - markerFirstStart: null - markerLastStart: null - markerFirstAny: null - markerLastEnd: null - markerLastAny: null -} -</screen> - -<para>When <literal>makeNewPage</literal> returns, the Page -LayoutManager has a Page Viewport and a Body Region object. The layout -dimensions have been calculated:</para> - -<screen> - this = { - pageNumberGenerator: instance of org.apache.fop.fo.pagination.PageNumberGenerator(id=1003) - pageCount: 1 - pageNumberString: "1" - isFirstPage: false - bFirstPage: false - curPage: instance of org.apache.fop.area.PageViewport(id=1288) - curBody: instance of org.apache.fop.area.BodyRegion(id=1280) - curSpan: null - curSpanColumns: 0 - curFlow: null - flowBPD: 728505 - flowIPD: 0 - areaTree: instance of org.apache.fop.area.AreaTree(id=1005) - pageSequence: instance of org.apache.fop.fo.pagination.PageSequence(id=1006) - currentSimplePageMaster: instance of org.apache.fop.fo.pagination.SimplePageMaster(id=1007) - staticContentLMs: instance of java.util.HashMap(id=1008) - lmls: instance of org.apache.fop.layoutmgr.LayoutManagerLS(id=1009) - org.apache.fop.layoutmgr.AbstractLayoutManager.userAgent: instance of org.apache.fop.apps.FOUserAgent(id=1010) - org.apache.fop.layoutmgr.AbstractLayoutManager.parentLM: null - org.apache.fop.layoutmgr.AbstractLayoutManager.fobj: instance of org.apache.fop.fo.pagination.PageSequence(id=1006) - org.apache.fop.layoutmgr.AbstractLayoutManager.foID: null - org.apache.fop.layoutmgr.AbstractLayoutManager.markers: null - org.apache.fop.layoutmgr.AbstractLayoutManager.bFinished: false - org.apache.fop.layoutmgr.AbstractLayoutManager.curChildLM: null - org.apache.fop.layoutmgr.AbstractLayoutManager.childLMiter: instance of org.apache.fop.layoutmgr.LMiter(id=1011) - org.apache.fop.layoutmgr.AbstractLayoutManager.bInited: false -} -</screen> - -<para>The method <literal>createBodyMainReferenceArea()</literal> adds -a <literal>MainReferenceArea</literal> to the body region:</para> - -<screen> - curBody = { - beforeFloat: null - mainReference: instance of org.apache.fop.area.MainReference(id=1293) - footnote: null - columnGap: 18000 - columnCount: 1 - refIPD: 0 - org.apache.fop.area.RegionReference.regionClass: 2 - org.apache.fop.area.RegionReference.ctm: instance of org.apache.fop.area.CTM(id=1282) - org.apache.fop.area.RegionReference.blocks: instance of java.util.ArrayList(id=1283) - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 0 - org.apache.fop.area.Area.props: null -} -</screen> - -<screen> - curBody.mainReference = { - spanAreas: instance of java.util.ArrayList(id=1294) - columnGap: 0 - width: 0 - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 0 - org.apache.fop.area.Area.props: null -} -</screen> - -<screen> - curBody.mainReference.spanAreas = "[]" -</screen> - -<para>After <literal>createSpan(1)</literal>:</para> - -<screen> - curBody.mainReference.spanAreas = "[org.apache.fop.area.Span@1581e80]" -</screen> - -<screen> - curBody.mainReference.spanAreas.get(0) = { - flowAreas: instance of java.util.ArrayList(id=1299) - height: 0 - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 481891 - org.apache.fop.area.Area.props: null -} -</screen> - - </section> - </section> - </chapter> - -<!-- Local Variables: --> -<!-- current-language-environment: UTF-8 --> -<!-- coding: utf-8 --> -<!-- default-input-method: TeX --> -<!-- End: --> diff --git a/src/documentation/content/xdocs/DnI/build.xml b/src/documentation/content/xdocs/DnI/build.xml deleted file mode 100644 index f7c8b98f1..000000000 --- a/src/documentation/content/xdocs/DnI/build.xml +++ /dev/null @@ -1,203 +0,0 @@ -<?xml version="1.0"?> -<!-- - 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. ---> -<!-- =========================================================================== - - * ================== * - | FOP build system | - | DnI subsystem | - * ================== * - - -Building instructions -===================== - -Unfortunately, I do not know of a standard file system setup for java -jar files. The class paths in this Ant build file reflect the java -setup of a Debian Sarge system. If you use this Ant build file, you -must change the appropriate variables to reflect your own java -setup. This can be done in a file build-local.properties. For the relevant -variables and their default values, see below, under the comment `jar -files'. - -If you want to use a catalog, set the property usecatalog to -true. Make sure the file CatalogManager.properties can be found along -the class path. I have better results with Xerces and the catalog -resolver; therefore Xerces is placed before Saxon in the class paths. - -Make sure your current working directory is where this very file is -located. Then give the command `ant' to build all, or `ant target' to -build target. Use the command `ant -projecthelp' for a list of -available commands. - - ====================================================================== --> - -<project name="DnI" default="all" basedir="."> - - <!-- used to set values for testing etc. --> - <!-- build-local.properties is not stored in CVS and overrides values from build.properties --> - <property file="${basedir}/build-local.properties"/> - - <property name="book" value="DnI.xml"/> - <property name="custom_docbook_xhtml_stylesheet" value="cust-xhtml-docbook.xsl"/> - <property name="custom_docbook_html_stylesheet" value="cust-html-docbook.xsl"/> - <property name="custom_docbook_fo_stylesheet" value="cust-fo-docbook.xsl"/> - - <!-- destinations --> - <property name="build_dir" value="../../../../../build"/> - <property name="bookmakerclasspath" value="${build_dir}/classes"/> - <property name="dni_build_dir" value="${build_dir}/site/DnI"/> - <property name="xhtml_dir" value="${dni_build_dir}/xhtml"/> - <property name="pdf_dir" value="${dni_build_dir}"/> - - <!-- jar files --> - <property name="javaclasses" value="/usr/share/java"/> - <!-- the following should be FOP Maintenance --> - <property name="fop-jar" value="${javaclasses}/fop.jar"/> - <property name="avalon-framework-jar" value="${javaclasses}/avalon-framework.jar"/> - <property name="saxon-jar" value="${javaclasses}/saxon.jar"/> - <property name="xml-commons-resolver-jar" value="${javaclasses}/xml-commons-resolver.jar"/> - <property name="xercesImpl-jar" value="${javaclasses}/xercesImpl.jar"/> - <property name="xml-apis-jar" value="${javaclasses}/xml-apis.jar"/> - <property name="commons-cli-jar" value="${javaclasses}/commons-cli.jar"/> - <!-- needed for the CatalogManager.properties file --> - <property name="catalog-manager" value="/etc/xml/resolver"/> - - <path id="transformer-path"> - <pathelement path="${xml-apis-jar}"/> - <pathelement path="${xercesImpl-jar}"/> - <pathelement path="${saxon-jar}"/> - <pathelement path="${avalon-framework-jar}"/> - <pathelement path="${xml-commons-resolver-jar}"/> - <pathelement path="${commons-cli-jar}"/> - <pathelement path="${bookmakerclasspath}"/> - <pathelement path="${catalog-manager}"/> - </path> - - <!-- ================================= - target: all - ================================= --> - <target name="all" depends="html, xhtml, pdf" - description="builds HTML, XHTML and PDF"/> - - <!-- - - - - - - - - - - - - - - - - - - target: bookmaker - - - - - - - - - - - - - - - - - - --> - <target name="bookmaker"> - <echo message="Building Bookmaker"/> - <mkdir dir="${bookmakerclasspath}"/> - <javac srcdir="${basedir}" includes="BookMaker.java" destdir="${bookmakerclasspath}" debug="1"> - <classpath> - <pathelement path="${fop-jar}"/> - <pathelement path="${avalon-framework-jar}"/> - <pathelement path="${xml-commons-resolver-jar}"/> - <pathelement path="${commons-cli-jar}"/> - <pathelement path="${catalog-manager}"/> - </classpath> - </javac> - </target> - - <!-- - - - - - - - - - - - - - - - - - - target: html - - - - - - - - - - - - - - - - - - --> - <target name="html" depends="bookmaker" - description="builds the HTML version"> - <property name="html_dir" value="${dni_build_dir}/html"/> - <property name="usecatalog" value="false"/> - <property name="javaflags" value="-Dno.option=none"/> - <condition property="progopts" value="--useCatalog"> - <istrue value="${usecatalog}"/> - </condition> - <property name="progopts" value=""/> - <echo message="Building HTML"/> - <mkdir dir="${html_dir}"/> - <java className="BookMaker" fork="true" dir="${basedir}"> - <jvmarg value="${javaflags}"/> - <arg line="${progopts} --parameter base.dir ${html_dir}/ -xml ${book} -xsl ${custom_docbook_html_stylesheet} -out ${html_dir}/DnI.html"/> - <classpath refid="transformer-path"/> - </java> - </target> - - <!-- - - - - - - - - - - - - - - - - - - target: xhtml - - - - - - - - - - - - - - - - - - --> - <target name="xhtml" depends="bookmaker" - description="builds the XHTML version"> - <property name="xhtml_dir" value="${dni_build_dir}/xhtml"/> - <property name="usecatalog" value="false"/> - <property name="javaflags" value="-Dno.option=none"/> - <condition property="progopts" value="--useCatalog"> - <istrue value="${usecatalog}"/> - </condition> - <property name="progopts" value=""/> - <echo message="Building XHTML"/> - <mkdir dir="${xhtml_dir}"/> - <java className="BookMaker" fork="true" dir="${basedir}"> - <jvmarg value="${javaflags}"/> - <arg line="${progopts} --parameter base.dir ${xhtml_dir}/ -xml ${book} -xsl ${custom_docbook_xhtml_stylesheet} -out ${xhtml_dir}/DnI-xhtml.xml"/> - <classpath refid="transformer-path"/> - </java> - </target> - - <!-- - - - - - - - - - - - - - - - - - - target: fo - - - - - - - - - - - - - - - - - - --> - <target name="fo" depends="bookmaker" - description="builds the FO file for the printed version"> - <property name="fo_dir" value="${dni_build_dir}"/> - <property name="usecatalog" value="false"/> - <property name="javaflags" value="-Dno.option=none"/> - <condition property="progopts" value="--useCatalog"> - <istrue value="${usecatalog}"/> - </condition> - <property name="progopts" value=""/> - <echo message="Building FO"/> - <mkdir dir="${fo_dir}"/> - <java className="BookMaker" fork="true" dir="${basedir}"> - <jvmarg value="${javaflags}"/> - <arg line="${progopts} -xml ${book} -xsl ${custom_docbook_fo_stylesheet} -out ${fo_dir}/DnI.fo"/> - <classpath refid="transformer-path"/> - </java> - </target> - - <!-- - - - - - - - - - - - - - - - - - - target: pdf - - - - - - - - - - - - - - - - - - --> - <target name="pdf" depends="bookmaker" - description="builds the PDF file of the printed version"> - <property name="pdf_dir" value="${dni_build_dir}"/> - <property name="usecatalog" value="false"/> - <property name="javaflags" value="-Dno.option=none"/> - <condition property="progopts" value="--useCatalog"> - <istrue value="${usecatalog}"/> - </condition> - <property name="progopts" value=""/> - <echo message="Building PDF"/> - <mkdir dir="${pdf_dir}"/> - <java className="BookMaker" fork="true" dir="${basedir}"> - <jvmarg value="${javaflags}"/> - <arg line="${progopts} -xml ${book} -xsl ${custom_docbook_fo_stylesheet} -pdf ${pdf_dir}/DnI.pdf"/> - <classpath> - <pathelement path="${fop-jar}"/> - <!-- note that FOP HEAD is in the transformer path; FOP Maintenance must come first --> - <path refid="transformer-path"/> - </classpath> - </java> - </target> - -</project> - diff --git a/src/documentation/content/xdocs/DnI/configuration.xml b/src/documentation/content/xdocs/DnI/configuration.xml deleted file mode 100644 index 991b05e03..000000000 --- a/src/documentation/content/xdocs/DnI/configuration.xml +++ /dev/null @@ -1,110 +0,0 @@ -<?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$ --> - -<!-- -<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" - "docbookx.dtd"> - --> - -<chapter> - <title>Configuration</title> - - <para>Configuration is based on the <literal>Configurable</literal> -and <literal>Configuration</literal> interfaces of -<literal>avalon</literal>: - -<screen> -org.apache.avalon.framework.configuration.Configurable -org.apache.avalon.framework.configuration.Configuration -</screen> - -A type that implements <literal>Configurable</literal> can be -configured by calling its method <literal>configure(Configuration -configuration)</literal>, where the argument is the -<literal>Configuration</literal> object that holds the user -configuration settings. It can also be configured by calling the -static method <literal>ContainerUtil.configure(object, cfg)</literal> -of the class - -<screen> -ContainerUtil = org.apache.avalon.framework.container.ContainerUtil -</screen> - -This method checks if <literal>object</literal> implements -<literal>Configurable</literal>. If not, no configuration is -attempted.</para> - -<para>The following classes implement <literal>Configurable</literal>: -<itemizedlist spacing="compact"> - <listitem> - <para><literal>render.AbstractRenderer</literal> and its -subclasses (all renderers). Only -<literal>render.pdf.PDFRenderer</literal> and -<literal>render.ps.PSRenderer</literal> have meaningful -implementations of the <literal>configure</literal> method. The -command line module configures each renderer from the user -configuration file with the subconfiguration -<literal>renderers/renderer[@mime=$mimetype]</literal>.</para> - </listitem> - <listitem> - <para><literal>svg.PDFTranscoder</literal></para> - </listitem> - <listitem> - <para><literal>svg.PDFDocumentGraphics2D</literal>. This class -is configured by <literal>svg.PDFTranscoder</literal> via -<literal>ContainerUtil.configure(graphics, this.cfg)</literal>. -</para> - </listitem> - </itemizedlist></para> - -<para>In addition <literal>render.ps.AbstractPSTranscoder</literal> -has a member <literal>Configuration cfg</literal>. It configures -graphics via <literal>ContainerUtil.configure(graphics, -this.cfg)</literal>. The graphics are of type -<literal>render.ps.AbstractPSDocumentGraphics2D</literal>, which does -not implement <literal>Configurable</literal>, so that no -configuration takes place.</para> - -<para><literal>render.pdf.PDFRenderer</literal> and -<literal>svg.PDFDocumentGraphics2D</literal> both call -<literal>fonts.FontSetup.buildFontListFromConfiguration(cfg)</literal> -and -<literal>pdf.PDFFilterList.buildFilterMapFromConfiguration(cfg)</literal>.</para> - -<para>Configuration info is used by: <itemizedlist spacing="compact"> - <listitem> - <para><literal>fonts.FontSetup.buildFontListFromConfiguration(cfg)</literal>. It -uses <literal>fonts/font/font-triplet</literal> from the renderer -subconfiguration.</para> - </listitem> - <listitem> - <para><literal>pdf.PDFFilterList.buildFilterMapFromConfiguration(cfg)</literal>. It -uses <literal>filterList/value</literal> from the renderer -subconfiguration</para> - </listitem> - <listitem> - <para><literal>render.ps.PSRenderer.configure(cfg)</literal>. It -uses <literal>auto-rotate-landscape</literal> as a Boolean. -</para> - </listitem> - </itemizedlist></para> - -</chapter> diff --git a/src/documentation/content/xdocs/DnI/cust-fo-docbook.xsl b/src/documentation/content/xdocs/DnI/cust-fo-docbook.xsl deleted file mode 100644 index 7a58051c2..000000000 --- a/src/documentation/content/xdocs/DnI/cust-fo-docbook.xsl +++ /dev/null @@ -1,535 +0,0 @@ -<?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$ --> - -<xsl:stylesheet - xmlns:xsl="http://www.w3.org/1999/XSL/Transform" - xmlns:fo="http://www.w3.org/1999/XSL/Format" - xmlns="http://www.w3.org/1999/xhtml" - xmlns:l="http://docbook.sourceforge.net/xmlns/l10n/1.0" - version="1.0"> - - <xsl:import - href="http://docbook.sourceforge.net/release/xsl/current/fo/docbook.xsl"/> - - <!-- Add other variable definitions here --> - <xsl:variable name="paper.type" select="'A4'"/> - <xsl:param name="section.autolabel" select="1"/> - <xsl:param name="section.label.includes.component.label" select="1"/> - <xsl:param name="marker.section.level" select="1"/> - <xsl:param name="component.title.several.objects" select="1"/> - <xsl:param name="fop.extensions" select="1"/> - <xsl:param name="draft.mode" select="'no'"/> - <xsl:param name="draft.watermark.image"/> - <!-- Double sided does not produce good headers and footers --> - <xsl:param name="double.sided" select="1"/> - <!-- Add to the section title properties --> - <xsl:attribute-set name="section.title.properties"> - <xsl:attribute name="text-align">start</xsl:attribute> - <xsl:attribute name="hyphenate">false</xsl:attribute> - </xsl:attribute-set> - <!-- Reintroduce the attribute set component.title.properties --> - <xsl:attribute-set name="component.title.properties"> - <xsl:attribute name="keep-with-next.within-column">always</xsl:attribute> - <xsl:attribute name="space-before.optimum"> - <xsl:value-of select="$body.font.master"/> - <xsl:text>pt</xsl:text> - </xsl:attribute> - <xsl:attribute name="space-before.minimum"> - <xsl:value-of select="$body.font.master * 0.8"/> - <xsl:text>pt</xsl:text> - </xsl:attribute> - <xsl:attribute name="space-before.maximum"> - <xsl:value-of select="$body.font.master * 1.2"/> - <xsl:text>pt</xsl:text> - </xsl:attribute> - <xsl:attribute name="text-align">start</xsl:attribute> - <xsl:attribute name="hyphenate">false</xsl:attribute> - </xsl:attribute-set> - <!-- spacing between label and title --> - <xsl:attribute-set name="component.title.label.properties"> - <xsl:attribute name="keep-with-next.within-column">always</xsl:attribute> - <xsl:attribute name="space-after.optimum"> - <xsl:value-of select="$body.font.master"/> - <xsl:text>pt</xsl:text> - </xsl:attribute> - <xsl:attribute name="space-after.minimum"> - <xsl:value-of select="$body.font.master * 0.8"/> - <xsl:text>pt</xsl:text> - </xsl:attribute> - <xsl:attribute name="space-after.maximum"> - <xsl:value-of select="$body.font.master * 1.2"/> - <xsl:text>pt</xsl:text> - </xsl:attribute> - <xsl:attribute name="font-size"> - <xsl:value-of select="$body.font.master * 2.0736"/> - <xsl:text>pt</xsl:text> - </xsl:attribute> - </xsl:attribute-set> - <xsl:attribute-set name="book.titlepage.author.properties"> - <xsl:attribute name="font-size"> - <xsl:value-of select="$body.font.master * 1.728"/> - <xsl:text>pt</xsl:text> - </xsl:attribute> - </xsl:attribute-set> - <xsl:attribute-set name="book.titlepage.affiliation.properties"> - <xsl:attribute name="space-before"> - <xsl:value-of select="$body.font.master * 1.2"/> - <xsl:text>pt</xsl:text> - </xsl:attribute> - <xsl:attribute name="font-style"> - <xsl:text>italic</xsl:text> - </xsl:attribute> - <xsl:attribute name="font-size"> - <xsl:value-of select="$body.font.master * 1.44"/> - <xsl:text>pt</xsl:text> - </xsl:attribute> - <xsl:attribute name="font-weight"> - <xsl:text>normal</xsl:text> - </xsl:attribute> - </xsl:attribute-set> - <!-- No headers and footers on blank pages --> - <xsl:param name="headers.on.blank.pages" select="0"/> - <xsl:param name="footers.on.blank.pages" select="0"/> - <xsl:param name="headers.on.first.pages" select="0"/> - <xsl:param name="header.left.width" - select="'proportional-column-width(1)'"/> - <xsl:param name="header.center.width" - select="'proportional-column-width(5)'"/> - <xsl:param name="header.right.width" - select="'proportional-column-width(1)'"/> - <!-- No left margin for titles --> - <xsl:param name="title.margin.left" select="'0pc'"/> - - <!-- - * Similar to mode object.title.markup - * but call template substitute-markup with the abbreviated title - --> - <xsl:template match="*" mode="object.titleabbrev.markup"> - <xsl:param name="allow-anchors" select="0"/> - <xsl:variable name="template"> - <xsl:apply-templates select="." mode="object.title.template"/> - </xsl:variable> - - <xsl:call-template name="substitute-markup"> - <xsl:with-param name="allow-anchors" select="$allow-anchors"/> - <xsl:with-param name="template" select="$template"/> - <xsl:with-param name="title" select="titleabbrev"/> - </xsl:call-template> - </xsl:template> - - <!-- - * Construct titleabbrev with mode object.titleabbrev.markup - * so that the section label is included - --> - <xsl:template match="section/title - |simplesect/title - |sect1/title - |sect2/title - |sect3/title - |sect4/title - |sect5/title" - mode="titlepage.mode" - priority="2"> - <xsl:variable name="section" select="parent::*"/> - <fo:block keep-with-next.within-column="always"> - <xsl:variable name="id"> - <xsl:call-template name="object.id"> - <xsl:with-param name="object" select="$section"/> - </xsl:call-template> - </xsl:variable> - - <xsl:variable name="level"> - <xsl:call-template name="section.level"> - <xsl:with-param name="node" select="$section"/> - </xsl:call-template> - </xsl:variable> - - <xsl:variable name="marker"> - <xsl:choose> - <xsl:when test="$level <= $marker.section.level">1</xsl:when> - <xsl:otherwise>0</xsl:otherwise> - </xsl:choose> - </xsl:variable> - - <xsl:variable name="title"> - <xsl:apply-templates select="$section" mode="object.title.markup"> - <xsl:with-param name="allow-anchors" select="1"/> - </xsl:apply-templates> - </xsl:variable> - - <xsl:variable name="titleabbrev"> - <xsl:apply-templates select="$section" mode="titleabbrev.markup"/> - </xsl:variable> - - <!-- Use for running head only if actual titleabbrev element --> - <xsl:variable name="titleabbrev.elem"> - <xsl:if test="$section/titleabbrev"> - <xsl:apply-templates select="$section" - mode="object.titleabbrev.markup"/> - </xsl:if> - </xsl:variable> - - <xsl:if test="$passivetex.extensions != 0"> - <fotex:bookmark xmlns:fotex="http://www.tug.org/fotex" - fotex-bookmark-level="{$level + 2}" - fotex-bookmark-label="{$id}"> - <xsl:value-of select="$titleabbrev"/> - </fotex:bookmark> - </xsl:if> - - <xsl:if test="$axf.extensions != 0"> - <xsl:attribute name="axf:outline-level"> - <xsl:value-of select="count(ancestor::*)-1"/> - </xsl:attribute> - <xsl:attribute name="axf:outline-expand">false</xsl:attribute> - <xsl:attribute name="axf:outline-title"> - <xsl:value-of select="$title"/> - </xsl:attribute> - </xsl:if> - - <xsl:call-template name="section.heading"> - <xsl:with-param name="level" select="$level"/> - <xsl:with-param name="title" select="$title"/> - <xsl:with-param name="marker" select="$marker"/> - <xsl:with-param name="titleabbrev" select="$titleabbrev.elem"/> - </xsl:call-template> - </fo:block> - </xsl:template> - - <!-- - * Use the attribute set component.title.properties - * Use mode several.objects.title.markup for actual title - --> - - <xsl:template name="component.title"> - <xsl:param name="node" select="."/> - <xsl:param name="pagewide" select="0"/> - <xsl:variable name="id"> - <xsl:call-template name="object.id"> - <xsl:with-param name="object" select="$node"/> - </xsl:call-template> - </xsl:variable> - <xsl:variable name="title"> - <xsl:apply-templates select="$node" mode="object.title.markup"> - <xsl:with-param name="allow-anchors" select="1"/> - </xsl:apply-templates> - </xsl:variable> - <xsl:variable name="titleabbrev"> - <xsl:apply-templates select="$node" mode="titleabbrev.markup"/> - </xsl:variable> - - <xsl:if test="$passivetex.extensions != 0"> - <fotex:bookmark xmlns:fotex="http://www.tug.org/fotex" - fotex-bookmark-level="2" - fotex-bookmark-label="{$id}"> - <xsl:value-of select="$titleabbrev"/> - </fotex:bookmark> - </xsl:if> - - <fo:block xsl:use-attribute-sets="component.title.properties"> - <xsl:if test="$pagewide != 0"> - <!-- Doesn't work to use 'all' here since not a child of fo:flow --> - <xsl:attribute name="span">inherit</xsl:attribute> - </xsl:if> - <xsl:attribute name="hyphenation-character"> - <xsl:call-template name="gentext"> - <xsl:with-param name="key" select="'hyphenation-character'"/> - </xsl:call-template> - </xsl:attribute> - <xsl:attribute name="hyphenation-push-character-count"> - <xsl:call-template name="gentext"> - <xsl:with-param name="key" - select="'hyphenation-push-character-count'"/> - </xsl:call-template> - </xsl:attribute> - <xsl:attribute name="hyphenation-remain-character-count"> - <xsl:call-template name="gentext"> - <xsl:with-param name="key" - select="'hyphenation-remain-character-count'"/> - </xsl:call-template> - </xsl:attribute> - <xsl:if test="$axf.extensions != 0"> - <xsl:attribute name="axf:outline-level"> - <xsl:value-of select="count($node/ancestor::*)"/> - </xsl:attribute> - <xsl:attribute name="axf:outline-expand">false</xsl:attribute> - <xsl:attribute name="axf:outline-title"> - <xsl:value-of select="$title"/> - </xsl:attribute> - </xsl:if> - <xsl:choose> - <xsl:when test="$component.title.several.objects != 0"> - <xsl:apply-templates select="$node" - mode="several.objects.title.markup"/> - </xsl:when> - <xsl:otherwise> - <xsl:copy-of select="$title"/> - </xsl:otherwise> - </xsl:choose> - </fo:block> - </xsl:template> - - <!-- - * Docbook-XSL's templates only allow a string value - * for the label and title. - * We want label and title in different fo elements. - * Mode several.objects.title.markup - --> - <xsl:template match="chapter" mode="several.objects.title.markup"> - - <fo:block xsl:use-attribute-sets="component.title.label.properties"> - <xsl:call-template name="gentext"> - <xsl:with-param name="key" select="'Chapter'"/> - </xsl:call-template> - <xsl:text> </xsl:text> - <xsl:apply-templates select="." mode="insert.label.markup"> - <xsl:with-param name="label"> - <xsl:apply-templates select="." mode="label.markup"/> - </xsl:with-param> - </xsl:apply-templates> - </fo:block> - - <fo:block> - <xsl:apply-templates select="." mode="insert.title.markup"> - <xsl:with-param name="title"> - <xsl:apply-templates select="." mode="title.markup"> - </xsl:apply-templates> - </xsl:with-param> - </xsl:apply-templates> - </fo:block> - - </xsl:template> - - <!-- - * Modify the header content: - * chapter number, - * section title only on odd pages, - * section number also with abbreviated titles - --> - <xsl:template name="header.content"> - <xsl:param name="pageclass" select="''"/> - <xsl:param name="sequence" select="''"/> - <xsl:param name="position" select="''"/> - <xsl:param name="gentext-key" select="''"/> - - <fo:block> - - <!-- sequence can be odd, even, first, blank --> - <!-- position can be left, center, right --> - <xsl:choose> - <xsl:when test="$sequence = 'blank'"> - <!-- nothing on blank pages --> - </xsl:when> - - <xsl:when test="$sequence = 'first'"> - <!-- nothing for first pages --> - </xsl:when> - - <xsl:when test="$position='left' or $position='right'"> - <!-- only draft on the left and right sides --> - <xsl:call-template name="draft.text"/> - </xsl:when> - - <xsl:when test="($sequence='odd' or $sequence='even') - and $position='center'"> - <xsl:if test="$pageclass != 'titlepage'"> - <xsl:choose> - <xsl:when test="ancestor::book and ($double.sided != 0) - and $sequence='odd'"> - <fo:retrieve-marker retrieve-class-name="section.head.marker" - retrieve-position="first-including-carryover" - retrieve-boundary="page-sequence"/> - </xsl:when> - <xsl:otherwise> - <xsl:apply-templates select="." mode="label.markup"/> - <xsl:text>. </xsl:text> - <xsl:apply-templates select="." mode="titleabbrev.markup"/> - </xsl:otherwise> - </xsl:choose> - </xsl:if> - </xsl:when> - - </xsl:choose> - </fo:block> - </xsl:template> - - <!-- Parametrize the widths of the header components --> - <xsl:template name="header.table"> - <xsl:param name="pageclass" select="''"/> - <xsl:param name="sequence" select="''"/> - <xsl:param name="gentext-key" select="''"/> - - <!-- default is a single table style for all headers --> - <!-- Customize it for different page classes or sequence location --> - - <xsl:choose> - <xsl:when test="$pageclass = 'index'"> - <xsl:attribute name="margin-left">0pt</xsl:attribute> - </xsl:when> - </xsl:choose> - - <xsl:variable name="candidate"> - <fo:table table-layout="fixed" width="100%"> - <xsl:call-template name="head.sep.rule"> - <xsl:with-param name="pageclass" select="$pageclass"/> - <xsl:with-param name="sequence" select="$sequence"/> - <xsl:with-param name="gentext-key" select="$gentext-key"/> - </xsl:call-template> - - <fo:table-column column-number="1" - column-width="{$header.left.width}"/> - <fo:table-column column-number="2" - column-width="{$header.center.width}"/> - <fo:table-column column-number="3" - column-width="{$header.right.width}"/> - <fo:table-body> - <fo:table-row height="14pt"> - <fo:table-cell text-align="left" display-align="before"> - <xsl:if test="$fop.extensions = 0"> - <xsl:attribute name="relative-align">baseline</xsl:attribute> - </xsl:if> - <fo:block> - <xsl:call-template name="header.content"> - <xsl:with-param name="pageclass" select="$pageclass"/> - <xsl:with-param name="sequence" select="$sequence"/> - <xsl:with-param name="position" select="'left'"/> - <xsl:with-param name="gentext-key" select="$gentext-key"/> - </xsl:call-template> - </fo:block> - </fo:table-cell> - <fo:table-cell text-align="center" display-align="before"> - <xsl:if test="$fop.extensions = 0"> - <xsl:attribute name="relative-align">baseline</xsl:attribute> - </xsl:if> - <fo:block> - <xsl:call-template name="header.content"> - <xsl:with-param name="pageclass" select="$pageclass"/> - <xsl:with-param name="sequence" select="$sequence"/> - <xsl:with-param name="position" select="'center'"/> - <xsl:with-param name="gentext-key" select="$gentext-key"/> - </xsl:call-template> - </fo:block> - </fo:table-cell> - <fo:table-cell text-align="right" display-align="before"> - <xsl:if test="$fop.extensions = 0"> - <xsl:attribute name="relative-align">baseline</xsl:attribute> - </xsl:if> - <fo:block> - <xsl:call-template name="header.content"> - <xsl:with-param name="pageclass" select="$pageclass"/> - <xsl:with-param name="sequence" select="$sequence"/> - <xsl:with-param name="position" select="'right'"/> - <xsl:with-param name="gentext-key" select="$gentext-key"/> - </xsl:call-template> - </fo:block> - </fo:table-cell> - </fo:table-row> - </fo:table-body> - </fo:table> - </xsl:variable> - - <!-- Really output a header? --> - <xsl:choose> - <xsl:when test="$pageclass = 'titlepage' and $gentext-key = 'book' - and $sequence='first'"> - <!-- no, book titlepages have no headers at all --> - </xsl:when> - <xsl:when test="($sequence = 'blank' and $headers.on.blank.pages = 0) - or ($sequence = 'first' and $headers.on.first.pages = 0)"> - <!-- no output --> - </xsl:when> - <xsl:otherwise> - <xsl:copy-of select="$candidate"/> - </xsl:otherwise> - </xsl:choose> - </xsl:template> - - <!-- author and affiliation on the titlepage --> - <xsl:template match="author" mode="titlepage.mode"> - <fo:block xsl:use-attribute-sets="book.titlepage.author.properties"> - <xsl:call-template name="anchor"/> - <xsl:call-template name="person.name"/> - </fo:block> - <xsl:apply-templates select="affiliation" mode="titlepage.mode"/> - </xsl:template> - - <xsl:template match="affiliation" mode="titlepage.mode"> - <fo:block xsl:use-attribute-sets="book.titlepage.affiliation.properties"> - <xsl:for-each select="*"> - <xsl:if test="position() != 1"> - <xsl:text>, </xsl:text> - </xsl:if> - <xsl:apply-templates mode="titlepage.mode"/> - </xsl:for-each> - </fo:block> - </xsl:template> - - <!-- - * I am not sure about the purpose of this template; - * in FOP it causes an extra page, which is not blank. - --> - <xsl:template name="book.titlepage.separator"> - <!-- - <fo:block xmlns:fo="http://www.w3.org/1999/XSL/Format" break-after="page"/> ---> - </xsl:template> - - <!-- Add revhistory to the verso page --> - <xsl:template name="book.titlepage.verso"> - <xsl:choose> - <xsl:when test="bookinfo/title"> - <xsl:apply-templates mode="book.titlepage.verso.auto.mode" - select="bookinfo/title"/> - </xsl:when> - <xsl:when test="title"> - <xsl:apply-templates mode="book.titlepage.verso.auto.mode" - select="title"/> - </xsl:when> - </xsl:choose> - - <xsl:apply-templates mode="book.titlepage.verso.auto.mode" - select="bookinfo/corpauthor"/> - <xsl:apply-templates mode="book.titlepage.verso.auto.mode" - select="bookinfo/authorgroup"/> - <xsl:apply-templates mode="book.titlepage.verso.auto.mode" - select="bookinfo/author"/> - <xsl:apply-templates mode="book.titlepage.verso.auto.mode" - select="bookinfo/othercredit"/> - <xsl:apply-templates mode="book.titlepage.verso.auto.mode" - select="bookinfo/pubdate"/> - <xsl:apply-templates mode="book.titlepage.verso.auto.mode" - select="bookinfo/copyright"/> - <xsl:apply-templates mode="book.titlepage.verso.auto.mode" - select="bookinfo/abstract"/> - <xsl:apply-templates mode="book.titlepage.verso.auto.mode" - select="bookinfo/revhistory"/> - <xsl:apply-templates mode="book.titlepage.verso.auto.mode" - select="bookinfo/legalnotice"/> - </xsl:template> - - <xsl:template match="revhistory" mode="book.titlepage.verso.auto.mode"> - <fo:block xsl:use-attribute-sets="book.titlepage.verso.style - normal.para.spacing"> - <xsl:apply-templates select="." mode="book.titlepage.verso.mode"/> - </fo:block> - </xsl:template> - -</xsl:stylesheet> diff --git a/src/documentation/content/xdocs/DnI/cust-html-docbook.xsl b/src/documentation/content/xdocs/DnI/cust-html-docbook.xsl deleted file mode 100644 index 27e723e8b..000000000 --- a/src/documentation/content/xdocs/DnI/cust-html-docbook.xsl +++ /dev/null @@ -1,38 +0,0 @@ -<?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$ --> - -<xsl:stylesheet - xmlns:xsl="http://www.w3.org/1999/XSL/Transform" - version="1.0"> - - <xsl:import - href="http://docbook.sourceforge.net/release/xsl/current/html/chunk.xsl"/> - <!-- Use this import if you do not want chunks --> - <!-- - <xsl:import - href="http://docbook.sourceforge.net/release/xsl/current/html/docbook.xsl"/> ---> - - <xsl:param name="chunk.section.depth" select="2"/> - <xsl:param name="section.autolabel" select="1"/> - <xsl:param name="base.dir" select="'DnI-html/'"/> - -</xsl:stylesheet> diff --git a/src/documentation/content/xdocs/DnI/cust-xhtml-docbook.xsl b/src/documentation/content/xdocs/DnI/cust-xhtml-docbook.xsl deleted file mode 100644 index 019acac20..000000000 --- a/src/documentation/content/xdocs/DnI/cust-xhtml-docbook.xsl +++ /dev/null @@ -1,41 +0,0 @@ -<?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$ --> - -<xsl:stylesheet - xmlns:xsl="http://www.w3.org/1999/XSL/Transform" - xmlns="http://www.w3.org/1999/xhtml" - version="1.0"> - - <xsl:import - href="http://docbook.sourceforge.net/release/xsl/current/xhtml/chunk.xsl"/> - - <!-- Use this import if you do not want chunks --> - <!-- - <xsl:import - href="http://docbook.sourceforge.net/release/xsl/current/xhtml/docbook.xsl"/> ---> - - <xsl:param name="chunker.output.encoding" select="'UTF-8'"/> - <xsl:param name="chunk.section.depth" select="2"/> - <xsl:param name="section.autolabel" select="1"/> - <xsl:param name="base.dir" select="'DnI-xhtml/'"/> - -</xsl:stylesheet> diff --git a/src/documentation/content/xdocs/DnI/fonts.xml b/src/documentation/content/xdocs/DnI/fonts.xml deleted file mode 100644 index f538c3edb..000000000 --- a/src/documentation/content/xdocs/DnI/fonts.xml +++ /dev/null @@ -1,298 +0,0 @@ -<?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$ --> - -<!-- -<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" - "docbookx.dtd"> - --> - - <chapter> - <title>Fonts</title> - - <section> - <title>Font setup</title> - - <para>Terminology: -<itemizedlist> - <listitem> - <simpara>Index, font index: The index of a character in a -font, i.e. the place of the glyph for a character in a font.</simpara> - </listitem> - <listitem> - <simpara>Code point: The same as font index.</simpara> - </listitem> - <listitem> - <simpara>Character value: The two-byte -(<literal>char</literal>) value by which a character is represented in -memory and in Unicode. Note that this only works straightforwardly for -the basal plane (BMP) of Unicode, i.e. for <literal>characters <= -0xFFFF</literal>.</simpara> - </listitem> - <listitem> - <simpara>Unicode code point: The same as the character -value.</simpara> - </listitem> - </itemizedlist></para> - - <para>During compilation for each of the 14 base fonts a class is -generated from the XML font metric files. Each font class contains -the metric information and an encoding table (a -<literal>CodePointMapping</literal> object). The metric information is -static, the encoding table is an object member.</para> - - <para>During compilation also a class -<literal>CodePointMapping</literal> is generated, which contains the -known encodings as static values. For each known encoding it contains -a table as a static final array of int. The array holds an alternation -of font index and character value; in fact it is a mapping from -<literal>table[2i]</literal> to <literal>table[2i+1]</literal>, where -<literal>table[2i]</literal> is the font index and -<literal>table[2i+1]</literal> is the character.</para> - - <para>When an encoding is needed in the process, a -<literal>CodePointMapping</literal> object is created from the -encoding table. It contains a table (<literal>char array</literal>) -called <literal>latin1Map</literal> of the font indices for the -characters of the Latin1 range (<literal>0-0xFF</literal>) in -character value order. It also contains two tables (<literal>char -array</literal>s), called characters and codepoints, for the higher -character values. The table characters contains the character values -in order, and the table codepoints contains the corresponding font -indexes for this encoding in the same order. The characters can be -retrieved from these tables as follows: - -<screen>char <= 0xFF: index = latin1Map[character] -char > 0xFF: - find i such that characters[i] == char; - then index = codepoints[i] -</screen></para> - - <para>In the code the characters are retrieved from the -<literal>CodePointMapping</literal> object with its method -<literal>mapChar(char c)</literal>.</para> - - <para>In FOP's preparation stage the fonts are set up in the -method <literal>Driver.getContentHandler</literal>. It calls the -<literal>renderer</literal>'s method -<literal>setupFontInfo(currentDocument)</literal>. The -<literal>Document</literal> object <literal>currentDocument</literal> -(which is the <literal>foTreeControl</literal> object) is able to -store the font setup info and has methods to access the fonts -registered with it.</para> - -<para>The <literal>PrintRenderer</literal> (PostScript and PDF) then -calls <literal>FontSetup.setup(fontInfo, fontList)</literal>, where -<literal>fontInfo</literal> is <literal>the</literal> Document object -and <literal>fontList</literal> is the list of user configured fonts -registered with the <literal>renderer</literal> in its member -<literal>fontList</literal>. - <screen> - [1] org.apache.fop.fonts.FontSetup.setup (FontSetup.java:98) - [2] org.apache.fop.render.PrintRenderer.setupFontInfo (PrintRenderer.java:77) - [3] org.apache.fop.apps.Driver.getContentHandler (Driver.java:551) - [4] org.apache.fop.apps.Driver.render (Driver.java:602) - [5] org.apache.fop.apps.Driver.render (Driver.java:589) - [6] org.apache.fop.apps.Fop.main (Fop.java:102) -</screen></para> - - <para><literal>FontSetup.setup</literal> takes three actions: -<orderedlist> - <listitem> - <simpara>An object is created for each of the base 14 fonts -and registered with the <literal>fontInfo</literal> object in its -member fonts.</simpara> - </listitem> - <listitem> - <simpara>A series of triplets (family, style, weight) is set -up. To each triplet a font is assigned; this font will be used when a -font with the characteristics of that triplet is requested. The -triplets registered with <literal>fontInfo</literal> in its member -<literal>triplets</literal>. The member <literal>triplets</literal> is -a map which uses a string of the form -<literal>family,style,weight</literal> as a key. There is also a class -<literal>FontTriplet</literal>, which is not used.</simpara> - </listitem> - - <listitem> - <simpara>The user configured fonts are added.</simpara> - </listitem> - </orderedlist></para> - - <para>In the following listing <literal>treeBuilder</literal> is -the tree builder object set up in the preparation stage, and -<literal>foTreeControl</literal> is the document object. The list of -user configured fonts of the <literal>renderer</literal> is empty, and -the list of used fonts is still empty. - -<screen> - treeBuilder.foTreeControl.fonts = "{ - F1=org.apache.fop.fonts.base14.Helvetica@e3c624, - F2=org.apache.fop.fonts.base14.HelveticaOblique@e020c9, - F3=org.apache.fop.fonts.base14.HelveticaBold@13e58d4, - F4=org.apache.fop.fonts.base14.HelveticaBoldOblique@15a6029, - F5=org.apache.fop.fonts.base14.TimesRoman@17494c8, - F6=org.apache.fop.fonts.base14.TimesItalic@1e57e8f, - F7=org.apache.fop.fonts.base14.TimesBold@888e6c, - F8=org.apache.fop.fonts.base14.TimesBoldItalic@d3db51, - F9=org.apache.fop.fonts.base14.Courier@5f6303, - F10=org.apache.fop.fonts.base14.CourierOblique@117f31e, - F11=org.apache.fop.fonts.base14.CourierBold@1d7fbfb, - F12=org.apache.fop.fonts.base14.CourierBoldOblique@5d9084 - F13=org.apache.fop.fonts.base14.Symbol@39e5b5, - F14=org.apache.fop.fonts.base14.ZapfDingbats@1b5998f, -}" -</screen> - -<screen> - treeBuilder.foTreeControl.triplets = "{ - Computer-Modern-Typewriter,normal,400=F9, - Courier,italic,400=F10, - Courier,italic,700=F12, - Courier,normal,400=F9, - Courier,normal,700=F11, - Courier,oblique,400=F10, - Courier,oblique,700=F12, - Helvetica,italic,400=F2, - Helvetica,italic,700=F4, - Helvetica,normal,400=F1, - Helvetica,normal,700=F3, - Helvetica,oblique,400=F2, - Helvetica,oblique,700=F4, - Symbol,normal,400=F13, - Times Roman,italic,400=F6, - Times Roman,italic,700=F8, - Times Roman,normal,400=F5, - Times Roman,normal,700=F7, - Times Roman,oblique,400=F6, - Times Roman,oblique,700=F8, - Times,italic,400=F6, - Times,italic,700=F8, - Times,normal,400=F5, - Times,normal,700=F7, - Times,oblique,400=F6, - Times,oblique,700=F8, - Times-Roman,italic,400=F6, - Times-Roman,italic,700=F8, - Times-Roman,normal,400=F5, - Times-Roman,normal,700=F7, - Times-Roman,oblique,400=F6, - Times-Roman,oblique,700=F8, - ZapfDingbats,normal,400=F14, - any,italic,400=F6, - any,italic,700=F8, - any,normal,400=F5, - any,normal,700=F7, - any,oblique,400=F6, - any,oblique,700=F8, - monospace,italic,400=F10, - monospace,italic,700=F12, - monospace,normal,400=F9, - monospace,normal,700=F11, - monospace,oblique,400=F10, - monospace,oblique,700=F12, - sans-serif,italic,400=F2, - sans-serif,italic,700=F4, - sans-serif,normal,400=F1, - sans-serif,normal,700=F3, - sans-serif,oblique,400=F2, - sans-serif,oblique,700=F4, - serif,italic,400=F6, - serif,italic,700=F8, - serif,normal,400=F5, - serif,normal,700=F7, - serif,oblique,400=F6 - serif,oblique,700=F8, -}" -</screen> - -<screen> - treeBuilder.foTreeControl.atModel.renderer.fontList = null - treeBuilder.foTreeControl.usedFonts = "{}" -</screen></para> - - <para>User configured fonts should be listed in the member -<literal>fontList</literal> of the <literal>renderer</literal>. The -objects in the list are <literal>EmbedFontInfo</literal> objects. They -are created from the path to the metrics file, boolean kerning, the -list of triplets for which this font may be used, the path to the font -file. The triplets are <literal>FontTriplet</literal> objects. The -list may be created from an Avalon configuration object with -<literal>FontSetup.buildFontListFromConfiguration(Configuration -cfg)</literal>.</para> - - <para><literal>>FontSetup.addConfiguredFonts</literal> creates a -<literal>LazyFont</literal> font object from each -<literal>EmbedFontInfo</literal> object. <literal>LazyFont</literal> -fonts are not loaded until they are actually used. This makes it -possible to register a large number of fonts at low cost.</para> - - <para>Font weights are integers between 100 and 900. -<literal>Font.NORMAL</literal> and <literal>Font.BOLD</literal> are -set to 400 and 700, respectively. See -<literal>FontUtil.parseCSS2FontWeight</literal>.</para> - - </section> - - <section> - <title>Classes and interfaces used in the font package</title> - - <screen>IF FontMetrics -SubIF FontDescriptor - -IF MutableFont - -Abstract Class TypeFace: FontMetrics -Classes Courier etc. - -Abstract Class TypeFace: FontMetrics -Abstract Class CustomFont: FontDescriptor, MutableFont -Abstract Class CIDFont, Class SingleByteFont -Class MultiByteFont (sub CIDFont) - -Abstract Class TypeFace: FontMetrics -Abstract Class CustomFont: FontDescriptor, MutableFont -Class SingleByteFont - -Abstract Class TypeFace: FontMetrics -Class LazyFont: FontDescriptor - -Abstract Class TypeFace: FontMetrics -Class FontMetricsMapper, for AWT fonts -</screen> - - <para><literal>SingleByteFont</literal>, -<literal>MultiByteFont</literal>: A font is not really single or -multibyte. Rather the name <literal>SingleByteFont</literal> indicates -that the font does not contain more than 256 glyphs; the -implementation is optimized for this. In -<literal>MultiByteFont</literal> (actually CIDFont Type2) the -implementation is optimized for fonts with an unknown number of -glyphs.</para> - - </section> - - </chapter> - -<!-- Local Variables: --> -<!-- current-language-environment: UTF-8 --> -<!-- coding: utf-8 --> -<!-- default-input-method: TeX --> -<!-- End: --> diff --git a/src/documentation/content/xdocs/DnI/foptrees.xml b/src/documentation/content/xdocs/DnI/foptrees.xml deleted file mode 100644 index 2dbddc57c..000000000 --- a/src/documentation/content/xdocs/DnI/foptrees.xml +++ /dev/null @@ -1,1066 +0,0 @@ -<?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$ --> - -<!-- -<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" - "docbookx.dtd"> - --> - - <chapter> - <title>The trees in FOP</title> - - <section> - <title>Overview</title> - - <orderedlist> - <listitem> - <simpara>The FO document. Each XML document and therefore -also an FO document has a hierarchical structure that can be modeled -as a tree.</simpara> - </listitem> - - <listitem> - <simpara>The FO DOM tree. This tree has the same -hierarchical structure as an FO document, and is often built from an -XML document.</simpara> - </listitem> - </orderedlist> - - <para>FOP can work from either an FO document or an FO DOM tree. -FOP does not build a DOM tree from an FO document.</para> - - <orderedlist continuation="continues"> - <listitem> - <simpara>The FO tree. FOP builds this tree from either the FO document or -the FO DOM tree. The FO nodes in this tree correspond to the -elements in the FO document or the XML nodes in the FO DOM -tree. Note, however, that they are different from DOM tree -nodes.</simpara> - </listitem> - </orderedlist> - - <para>When a sufficient part of the FO tree has been built (in -current FOP the subtree of a PageSequence FO node), the layout process -is started. This process builds three trees.</para> - - <orderedlist continuation="continues"> - <listitem> - <simpara>The LM tree. This tree corresponds closely to the FO -tree because each FO node creates a layout manager. But there are -deviations. For example, a BlockLayoutManager creates a -LineLayoutManager for each consecutive sequence of child FO nodes that -generate inline areas.</simpara> - </listitem> - - <listitem> - <simpara>The BP tree. Each layout manager returns zero or more -BreakPoss to its parent. These BreakPoss are connected to BreakPoss -that the layout manager received from its child layout managers. This -is not a real tree. There are many BP without a parent BP. They are -connected to their siblings by their LM.</simpara> - </listitem> - - <listitem> - <simpara>The Area tree. Using the information stored in the BP -tree and in the LMs connected with the BPs, layout areas are -constructed. These areas are placed within other areas, which is -expressed in a tree hierarchy.</simpara> - </listitem> - </orderedlist> - - </section> - - <section> - <title>The tree of BreakPoss</title> - - <para>Each LM contains a list of BPs belonging to and returned -to it by the childLMs during the <literal>getNextBreakPoss</literal> -stack. These are the BPs that end an area of the childLM. The BP -contains an index <literal>position.iLeafPos</literal>, which connects -it to the BP with that index in the list of BPs of its own LM (the -childLM).</para> - - <para>For example, BlockLM's list <literal>childBreaks</literal> -contains the BPs that end a line (if the childLM is a LineLM). -LineLM's list <literal>vecInlineBreaks</literal> contains the BPs that -were returned to it as possible linebreaks by TextLM (if the childLM -is a TextLM). TextLM's list <literal>vecAreaInfo</literal> contains -<literal>AreaInfo</literal> objects. A BP in BlockLM's list -<literal>childBreaks</literal> belongs e.g. to a LineLM. Its index -<literal>position.iLeafPos</literal> points to the BP with that index -in <literal>vecInlineBreaks</literal> in ListLM. That BP belongs e.g. -to a TextLM, and its index <literal>position.iLeafPos</literal> points -to the <literal>AreaInfo</literal> object with that index in -<literal>vecAreaInfo</literal> in TextLM.</para> - - <screen> - +-----------------+ - LM | bp0 bp1 bp2 bp3 | - +-++--++--++--++--+ - .......................:|..:| :| :| - : +----------+ | :| :| - : | +----------+ :| :+----------------------+ - : | | ........:| :....... | - : | | : | : | - : +----------+---+--+ : +------+------+ : +--------------+------+ - LM | bp0 bp1 bp2 bp3 | LM | bp0 bp1 bp2 | LM | bp0 bp1 bp2 bp3 bp4 | - +-----------------+ +-------------+ +---------------------+ -</screen> - - <para>The BPs are held in a list by the LM shown in front of -them. They are associated with one of the childLMs, which is shown by -the dotted lines. Their member <literal>position.iLeafPos</literal> -connects them with the BP in their LM's list with that index, as shown -by the dashed lines.</para> - - </section> - - - <section> - <title>Example of an FO and area tree</title> - - <section> - <title>The FO file</title> - - <literallayout><![CDATA[<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="simpleA4" - page-height="29.7cm" page-width="21cm" - 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="simpleA4"> - <fo:flow flow-name="xsl-region-body"> - <fo:block font-size="16pt" font-weight="bold" - space-after="5mm">Test FO - </fo:block> - </fo:flow> - </fo:page-sequence> -</fo:root>]]></literallayout> - - </section> - - <section> - <title>The corresponding FO tree</title> - - <para>In the listing below the notation has been shortened; -<literal>.[n]</literal> denotes the nth child, for which the full -notation is <literal>.children.elementData[n]</literal> . A number of -static members are not shown.</para> - - <para>The root: - -<screen> - root = "fo:root at line 2:44" - - root = { - layoutMasterSet: instance of org.apache.fop.fo.pagination.LayoutMasterSet(id=1089) - pageSequences: instance of java.util.ArrayList(id=1102) - runningPageNumberCounter: 0 - foTreeControl: instance of org.apache.fop.apps.Document(id=1103) - org.apache.fop.fo.FObj.propertyListTable: instance of org.apache.fop.fo.Property$Maker[248] (id=1094) - org.apache.fop.fo.FObj.propertyList: instance of org.apache.fop.fo.PropertyList(id=1104) - org.apache.fop.fo.FObj.propMgr: instance of org.apache.fop.fo.PropertyManager(id=1105) - org.apache.fop.fo.FObj.id: null - org.apache.fop.fo.FObj.children: instance of java.util.ArrayList(id=1106) - org.apache.fop.fo.FObj.markers: null - org.apache.fop.fo.FObj.systemId: "file:/path/to/fo-file" - org.apache.fop.fo.FObj.line: 2 - org.apache.fop.fo.FObj.column: 44 - org.apache.fop.fo.FONode.parent: null - org.apache.fop.fo.FONode.name: "fo:root" -} -</screen> -</para> - - <para>The root has no properties; the namespace nodes do not result in -properties: - -<screen> - root.propertyList = "{}" -</screen> -</para> - - <para>The root has two children: - -<screen> - root.children = "[ - fo:layout-master-set at line 3:25 - fo:page-sequence at line 12:49 -]" -</screen> -</para> - - <para>The first child of root is the layout master set: - -<screen> - root.[0] = "fo:layout-master-set at line 3:25" - - root.[0] = { - simplePageMasters: instance of java.util.HashMap(id=1111) - pageSequenceMasters: instance of java.util.HashMap(id=1112) - org.apache.fop.fo.FObj.propertyListTable: instance of org.apache.fop.fo.Property$Maker[248] (id=1094) - org.apache.fop.fo.FObj.propertyList: instance of org.apache.fop.fo.PropertyList(id=1113) - org.apache.fop.fo.FObj.propMgr: instance of org.apache.fop.fo.PropertyManager(id=1114) - org.apache.fop.fo.FObj.id: null - org.apache.fop.fo.FObj.children: instance of java.util.ArrayList(id=1115) - org.apache.fop.fo.FObj.markers: null - org.apache.fop.fo.FObj.systemId: "file:/path/to/fo-file" - org.apache.fop.fo.FObj.line: 3 - org.apache.fop.fo.FObj.column: 25 - org.apache.fop.fo.FONode.parent: instance of org.apache.fop.fo.pagination.Root(id=1088) - org.apache.fop.fo.FONode.name: "fo:layout-master-set" -} - - root.[0].propertyList = "{}" -</screen> -</para> - - <para>The layout master set contains a simple page master: - -<screen> - root.[0].children = "[ - fo:simple-page-master at line 8:28 -]" - - root.[0].[0] = "fo:simple-page-master at line 8:28" - - root.[0].[0] = { - regions: instance of java.util.HashMap(id=1120) - masterName: "simpleA4" - org.apache.fop.fo.FObj.propertyListTable: instance of org.apache.fop.fo.Property$Maker[248] (id=1094) - org.apache.fop.fo.FObj.propertyList: instance of org.apache.fop.fo.PropertyList(id=1122) - org.apache.fop.fo.FObj.propMgr: instance of org.apache.fop.fo.PropertyManager(id=1123) - org.apache.fop.fo.FObj.id: null - org.apache.fop.fo.FObj.children: null - org.apache.fop.fo.FObj.markers: null - org.apache.fop.fo.FObj.systemId: "file:/path/to/fo-file" - org.apache.fop.fo.FObj.line: 8 - org.apache.fop.fo.FObj.column: 28 - org.apache.fop.fo.FONode.parent: instance of org.apache.fop.fo.pagination.LayoutMasterSet(id=1089) - org.apache.fop.fo.FONode.name: "fo:simple-page-master" -} -</screen> -</para> - - <para>The properties of the simple page master: - -<screen> - root.[0].[0].propertyList = "{ - master-name=org.apache.fop.fo.StringProperty@1958bf9 - margin-top=org.apache.fop.fo.LengthProperty@118958e - margin-right=org.apache.fop.fo.LengthProperty@102b2b6 - margin-bottom=org.apache.fop.fo.LengthProperty@22d166 - margin-left=org.apache.fop.fo.LengthProperty@1e1962d - page-width=org.apache.fop.fo.LengthProperty@14a75bb - page-height=org.apache.fop.fo.LengthProperty@17779e3 -}" - - root.[0].[0].propertyList.get("master-name") = { - str: "simpleA4" - org.apache.fop.fo.Property.specVal: null -} - - root.[0].[0].propertyList.get("page-height") = { - length: instance of org.apache.fop.datatypes.FixedLength(id=1329) - org.apache.fop.fo.Property.specVal: null -} - - root.[0].[0].propertyList.get("page-height").length = "841889mpt" -</screen> -</para> - - <para>The simple page master has only one region, the body: - -<screen> - root.[0].[0].regions = "{body=fo:region-body at line 9:24}" -</screen> -</para> - - <para>The region body: - -<screen> - root.[0].[0].regions.get("body") = "fo:region-body at line 9:24" - - root.[0].[0].regions.get("body") = { - backgroundColor: null - org.apache.fop.fo.pagination.Region.layoutMaster: instance of org.apache.fop.fo.pagination.SimplePageMaster(id=1082) - org.apache.fop.fo.pagination.Region.regionName: "xsl-region-body" - org.apache.fop.fo.pagination.Region.overflow: 8 - org.apache.fop.fo.pagination.Region.wm: 49 - org.apache.fop.fo.FObj.propertyListTable: instance of org.apache.fop.fo.Property$Maker[248] (id=1094) - org.apache.fop.fo.FObj.propertyList: instance of org.apache.fop.fo.PropertyList(id=1344) - org.apache.fop.fo.FObj.propMgr: instance of org.apache.fop.fo.PropertyManager(id=1345) - org.apache.fop.fo.FObj.id: null - org.apache.fop.fo.FObj.children: null - org.apache.fop.fo.FObj.markers: null - org.apache.fop.fo.FObj.systemId: "file:/path/to/fo-file" - org.apache.fop.fo.FObj.line: 9 - org.apache.fop.fo.FObj.column: 24 - org.apache.fop.fo.FONode.parent: instance of org.apache.fop.fo.pagination.SimplePageMaster(id=1082) - org.apache.fop.fo.FONode.name: "fo:region-body" -} - - root.[0].[0].regions.get("body").propertyList = "{}" -</screen> -</para> - - <para>The second child of root is the page sequence: - -<screen> - root.[1] = "fo:page-sequence at line 12:49" - - root.[1] = { - root: instance of org.apache.fop.fo.pagination.Root(id=1088) - layoutMasterSet: instance of org.apache.fop.fo.pagination.LayoutMasterSet(id=1089) - flowMap: instance of java.util.HashMap(id=1090) - sequenceStarted: true - ipnValue: "auto" - currentPageNumber: 1 - explicitFirstNumber: 0 - firstPageNumber: 1 - pageNumberGenerator: instance of org.apache.fop.fo.pagination.PageNumberGenerator(id=1074) - forcePageCount: 8 - pageCount: 0 - isForcing: false - pageNumberType: 1 - thisIsFirstPage: true - simplePageMaster: instance of org.apache.fop.fo.pagination.SimplePageMaster(id=1082) - pageSequenceMaster: null - mainFlow: instance of org.apache.fop.fo.pagination.Flow(id=1092) - titleFO: null - org.apache.fop.fo.FObj.propertyListTable: instance of org.apache.fop.fo.Property$Maker[248] (id=1094) - org.apache.fop.fo.FObj.propertyList: instance of org.apache.fop.fo.PropertyList(id=1096) - org.apache.fop.fo.FObj.propMgr: instance of org.apache.fop.fo.PropertyManager(id=1097) - org.apache.fop.fo.FObj.id: null - org.apache.fop.fo.FObj.children: instance of java.util.ArrayList(id=1098) - org.apache.fop.fo.FObj.markers: null - org.apache.fop.fo.FObj.systemId: "file:/path/to/fo-file" - org.apache.fop.fo.FObj.line: 12 - org.apache.fop.fo.FObj.column: 49 - org.apache.fop.fo.FONode.parent: instance of org.apache.fop.fo.pagination.Root(id=1088) - org.apache.fop.fo.FONode.name: "fo:page-sequence" -} -</screen> -</para> - - <para>The page-sequence has one property, the reference to the page master: - -<screen> - root.[1].propertyList = "{ - master-reference=org.apache.fop.fo.StringProperty@104e28b -}" - - root.[1].propertyList.get("master-reference") = { - str: "simpleA4" - org.apache.fop.fo.Property.specVal: null -} -</screen> -</para> - - <para>The page-sequence has one child, the flow: - -<screen> - root.[1].children = "[ - fo:flow at line 13:42 -]" - - root.[1].[0] = "fo:flow at line 13:42" - - root.[1].[0] = { - pageSequence: instance of org.apache.fop.fo.pagination.PageSequence(id=1081) - markerSnapshot: null - flowName: "xsl-region-body" - contentWidth: 0 - org.apache.fop.fo.FObj.propertyListTable: instance of org.apache.fop.fo.Property$Maker[248] (id=1094) - org.apache.fop.fo.FObj.propertyList: instance of org.apache.fop.fo.PropertyList(id=1367) - org.apache.fop.fo.FObj.propMgr: instance of org.apache.fop.fo.PropertyManager(id=1368) - org.apache.fop.fo.FObj.id: null - org.apache.fop.fo.FObj.children: instance of java.util.ArrayList(id=1369) - org.apache.fop.fo.FObj.markers: null - org.apache.fop.fo.FObj.systemId: "file:/path/to/fo-file" - org.apache.fop.fo.FObj.line: 13 - org.apache.fop.fo.FObj.column: 42 - org.apache.fop.fo.FONode.parent: instance of org.apache.fop.fo.pagination.PageSequence(id=1081) - org.apache.fop.fo.FONode.name: "fo:flow" -} -</screen> -</para> - - <para>The flow has one property, the flow name: - -<screen> - root.[1].[0].propertyList = "{ - flow-name=org.apache.fop.fo.StringProperty@6458a6 -}" - - root.[1].[0].propertyList.get("flow-name") = { - str: "xsl-region-body" - org.apache.fop.fo.Property.specVal: null -} -</screen> -</para> - - <para>The flow has one child, a block: - -<screen> - root.children.elementData[1].children.elementData[0].children = "[ - fo:block at line 15:28 -]" - - root.[1].[0].[0] = "fo:block at line 15:28" - - root.[1].[0].[0] = { - align: 0 - alignLast: 0 - breakAfter: 0 - lineHeight: 0 - startIndent: 0 - endIndent: 0 - spaceBefore: 0 - spaceAfter: 0 - textIndent: 0 - keepWithNext: 0 - backgroundColor: null - blockWidows: 0 - blockOrphans: 0 - id: null - span: 59 - wsTreatment: 41 - lfTreatment: 98 - bWScollapse: true - anythingLaidOut: false - firstInlineChild: null - org.apache.fop.fo.FObjMixed.textInfo: instance of org.apache.fop.fo.TextInfo(id=1377) - org.apache.fop.fo.FObj.propertyListTable: instance of org.apache.fop.fo.Property$Maker[248] (id=1094) - org.apache.fop.fo.FObj.propertyList: instance of org.apache.fop.fo.PropertyList(id=1378) - org.apache.fop.fo.FObj.propMgr: instance of org.apache.fop.fo.PropertyManager(id=1379) - org.apache.fop.fo.FObj.id: null - org.apache.fop.fo.FObj.children: instance of java.util.ArrayList(id=1380) - org.apache.fop.fo.FObj.markers: null - org.apache.fop.fo.FObj.systemId: "file:/path/to/fo-file" - org.apache.fop.fo.FObj.line: 15 - org.apache.fop.fo.FObj.column: 28 - org.apache.fop.fo.FONode.parent: instance of org.apache.fop.fo.pagination.Flow(id=1092) - org.apache.fop.fo.FONode.name: "fo:block" -} - - root.[1].[0].[0].propertyList = "{ - font-size=org.apache.fop.fo.LengthProperty@ae4646 - font-weight=org.apache.fop.fo.StringProperty@187b287 - space-after=org.apache.fop.fo.SpaceProperty@1d9e2c7 -}" -</screen> -</para> - - <para>The block has two children: - -<screen> - root.[1].[0].[0].children = "[ - fo:text at line 15:35 - fo:text at line 16:7 -]" - - root.[1].[0].[0].[0] = "fo:text at line 15:35" - - root.[1].[0].[0].[0] = { - ca: instance of char[7] (id=1386) - start: 0 - length: 7 - textInfo: instance of org.apache.fop.fo.TextInfo(id=1377) - lastFOTextProcessed: instance of org.apache.fop.fo.FOText(id=1387) - prevFOTextThisBlock: null - nextFOTextThisBlock: instance of org.apache.fop.fo.FOText(id=1387) - ancestorBlock: instance of org.apache.fop.fo.flow.Block(id=1375) - org.apache.fop.fo.FObj.propertyListTable: instance of org.apache.fop.fo.Property$Maker[248] (id=1094) - org.apache.fop.fo.FObj.propertyList: null - org.apache.fop.fo.FObj.propMgr: null - org.apache.fop.fo.FObj.id: null - org.apache.fop.fo.FObj.children: null - org.apache.fop.fo.FObj.markers: null - org.apache.fop.fo.FObj.systemId: "file:/path/to/fo-file" - org.apache.fop.fo.FObj.line: 15 - org.apache.fop.fo.FObj.column: 35 - org.apache.fop.fo.FONode.parent: instance of org.apache.fop.fo.flow.Block(id=1375) - org.apache.fop.fo.FONode.name: "fo:text" -} -</screen> -</para> - - <para>This text node contains the text "Test FO": - -<screen> - root.[1].[0].[0].[0].ca = { -T, e, s, t, , F, O -} - - root.[1].[0].[0].[1] = "fo:text at line 16:7" - - root.[1].[0].[0].[1] = { - ca: instance of char[1] (id=1390) - start: 0 - length: 1 - textInfo: instance of org.apache.fop.fo.TextInfo(id=1377) - lastFOTextProcessed: instance of org.apache.fop.fo.FOText(id=1387) - prevFOTextThisBlock: instance of org.apache.fop.fo.FOText(id=1384) - nextFOTextThisBlock: null - ancestorBlock: instance of org.apache.fop.fo.flow.Block(id=1375) - org.apache.fop.fo.FObj.propertyListTable: instance of org.apache.fop.fo.Property$Maker[248] (id=1094) - org.apache.fop.fo.FObj.propertyList: null - org.apache.fop.fo.FObj.propMgr: null - org.apache.fop.fo.FObj.id: null - org.apache.fop.fo.FObj.children: null - org.apache.fop.fo.FObj.markers: null - org.apache.fop.fo.FObj.systemId: "file:/path/to/fo-file" - org.apache.fop.fo.FObj.line: 16 - org.apache.fop.fo.FObj.column: 7 - org.apache.fop.fo.FONode.parent: instance of org.apache.fop.fo.flow.Block(id=1375) - org.apache.fop.fo.FONode.name: "fo:text" -} -</screen> -</para> - - <para>This text node contains the text "\n": - -<screen> - root.[1].[0].[0].[1].ca = { -} -</screen> -</para> - </section> - - <section> - <title>The corresponding area tree</title> - - <para><itemizedlist> - <listitem> - <simpara>PageViewport has a Page page and a Rectangle2D -viewArea (reference/viewport pair).</simpara> - </listitem> - <listitem> - <simpara>Page has five RegionViewports.</simpara> - </listitem> - <listitem> - <simpara>RegionViewport has a RegionReference region and a -Rectangle2D viewArea (reference/viewport pair).</simpara> - </listitem> - <listitem> - <simpara>BodyRegion has a MainReference mainReference, a -BeforeFloat beforeFloat, and a Footnote footnote.</simpara> - </listitem> - <listitem> - <simpara>MainReference has a list of Spans.</simpara> - </listitem> - <listitem> - <simpara>Span has a list of Flows.</simpara> - </listitem> - <listitem> - <simpara>Flow has a list of Blocks.</simpara> - </listitem> - <listitem> - <simpara>Block has a list of Blocks or LineAreas.</simpara> - </listitem> - <listitem> - <simpara>LineArea has a list of InlineAreas.</simpara> - </listitem> - <listitem> - <simpara>Text Area (subclass of InlineArea) has text.</simpara> - </listitem> - </itemizedlist></para> - - <para>The structure of the area tree is as follows: - -<screen> -PageViewport -| -+-Page - | - +-RegionViewport - | - +-BodyRegion - | - +-MainReference - | | - | +-Span - | | | - | | +-Flow - | | - | +-Span - | | | - | | +-Flow - | | | - | | +-Block - | | | | - | | | +-LineArea - | | | | - | | | +-TextArea - | | | - | | +-Block - | | - | +-Span - | | | - | | +-Flow - | | - | +-Span - | | | - | | +-Flow - | | - | +-Span - | | - | +-Flow - | - +blocks - | - +CTM -</screen> -</para> - - <para>In the listing below members of an -<literal>arraylist</literal> are indicated by <literal>[n]</literal>, -which stands for <literal>get(n)</literal>. If the -<literal>arraylist</literal> is called <literal>children</literal>, -the word <literal>children</literal> has been omitted, so that -<literal>[n]</literal> then stands for -<literal>children.get(n)</literal>.</para> - - <para>Type: <literal>org.apache.fop.area.PageViewport</literal>: -<screen> - curPage = "PageViewport: page=1" - - curPage = { - page: instance of org.apache.fop.area.Page(id=1394) - viewArea: instance of java.awt.Rectangle(id=1395) - clip: false - pageNumber: "1" - idReferences: null - unresolved: null - pendingResolved: null - markerFirstStart: null - markerLastStart: null - markerFirstAny: null - markerLastEnd: null - markerLastAny: null -} -</screen> -</para> - - <para>Type: <literal>org.apache.fop.area.Page</literal>: -<screen> - curPage.page = { - regionBefore: null - regionStart: null - regionBody: instance of org.apache.fop.area.RegionViewport(id=1397) - regionEnd: null - regionAfter: null - unresolved: null -} -</screen> -</para> - - <para>Type: <literal>org.apache.fop.area.RegionViewport</literal>: -<screen> - curPage.page.regionBody = { - region: instance of org.apache.fop.area.BodyRegion(id=1077) - viewArea: instance of java.awt.Rectangle(id=1399) - clip: false - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 0 - org.apache.fop.area.Area.props: null -} -</screen> -</para> - - <para>Type: <literal>org.apache.fop.area.BodyRegion</literal>: -<screen> - curPage.page.regionBody.region = { - beforeFloat: null - mainReference: instance of org.apache.fop.area.MainReference(id=1401) - footnote: null - columnGap: 18000 - columnCount: 1 - refIPD: 0 - org.apache.fop.area.RegionReference.regionClass: 2 - org.apache.fop.area.RegionReference.ctm: instance of org.apache.fop.area.CTM(id=1402) - org.apache.fop.area.RegionReference.blocks: instance of java.util.ArrayList(id=1403) - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 0 - org.apache.fop.area.Area.props: null -} -</screen> -</para> - - <para>Type: <literal>org.apache.fop.area.MainReference</literal>: -<screen> - curPage.page.regionBody.region.mainReference = { - spanAreas: instance of java.util.ArrayList(id=1405) - columnGap: 0 - width: 0 - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 0 - org.apache.fop.area.Area.props: null -} -</screen> -</para> - - <para>The main reference contains five span areas. Four are -empty. Number 1 contains the text of this page. - -<screen> - curPage.page.regionBody.region.mainReference.spanAreas = "[ - org.apache.fop.area.Span@53c3f5 - org.apache.fop.area.Span@101ac93 - org.apache.fop.area.Span@125d61e - org.apache.fop.area.Span@155d3a3 - org.apache.fop.area.Span@718242 -]" -</screen> -</para> - - <para>Type: <literal>org.apache.fop.area.Span</literal>: -<screen> - curPage.page.regionBody.region.mainReference.spanAreas[0] = { - flowAreas: instance of java.util.ArrayList(id=1409) - height: 0 - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 481891 - org.apache.fop.area.Area.props: null -} -</screen> -</para> - - <screen> - curPage.page.regionBody.region.mainReference.spanAreas[0].flowAreas = "[ - org.apache.fop.area.Flow@e33e18 -]" -</screen> - - <para>Type: <literal>org.apache.fop.area.Flow</literal>: -<screen> - curPage.page.regionBody.region.mainReference.spanAreas[0].flowAreas[0] = { - stacking: 2 - width: 0 - org.apache.fop.area.BlockParent.xOffset: 0 - org.apache.fop.area.BlockParent.yOffset: 0 - org.apache.fop.area.BlockParent.width: 0 - org.apache.fop.area.BlockParent.height: 0 - org.apache.fop.area.BlockParent.children: null - org.apache.fop.area.BlockParent.orientation: 0 - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 481891 - org.apache.fop.area.Area.props: null -} -</screen> -</para> - - <para>Type: <literal>org.apache.fop.area.Span</literal>: -<screen> - curPage.page.regionBody.region.mainReference.spanAreas[1] = { - flowAreas: instance of java.util.ArrayList(id=1412) - height: 0 - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 481891 - org.apache.fop.area.Area.props: null -} -</screen> -</para> - - <screen> - curPage.page.regionBody.region.mainReference.spanAreas[0].flowAreas = "[ - org.apache.fop.area.Flow@e33e18 -]" -</screen> - - <para>Type: <literal>org.apache.fop.area.Flow</literal>: -<screen> - curPage.page.regionBody.region.mainReference.spanAreas[1].flowAreas[0] = { - stacking: 2 - width: 0 - org.apache.fop.area.BlockParent.xOffset: 0 - org.apache.fop.area.BlockParent.yOffset: 0 - org.apache.fop.area.BlockParent.width: 0 - org.apache.fop.area.BlockParent.height: 0 - org.apache.fop.area.BlockParent.children: instance of java.util.ArrayList(id=1416) - org.apache.fop.area.BlockParent.orientation: 0 - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 481891 - org.apache.fop.area.Area.props: null -} -</screen> -</para> - - <screen> - curPage.page.regionBody.region.mainReference.spanAreas[1].flowAreas[0].children = "[ - org.apache.fop.area.Block@61f533 - org.apache.fop.area.Block@12922f6 -]" -</screen> - - <para>Type: <literal>org.apache.fop.area.Block</literal>: -<screen> - curPage.page.regionBody.region.mainReference.spanAreas[1].flowAreas[0].[0] = { - stacking: 2 - positioning: 0 - org.apache.fop.area.BlockParent.xOffset: 0 - org.apache.fop.area.BlockParent.yOffset: 0 - org.apache.fop.area.BlockParent.width: 481891 - org.apache.fop.area.BlockParent.height: 19200 - org.apache.fop.area.BlockParent.children: instance of java.util.ArrayList(id=1419) - org.apache.fop.area.BlockParent.orientation: 0 - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 481891 - org.apache.fop.area.Area.props: null -} -</screen> -</para> - - <screen> - curPage.page.regionBody.region.mainReference.spanAreas[1].flowAreas[0].[0].children = "[ - org.apache.fop.area.LineArea@9f0d -]" -</screen> - - <para>Type: <literal>org.apache.fop.area.LineArea</literal>: -<screen> - curPage.page.regionBody.region.mainReference.spanAreas[1].flowAreas[0].[0].[0] = { - stacking: 0 - startIndent: 0 - length: 0 - lineHeight: 19200 - baseLine: 0 - inlineAreas: instance of java.util.ArrayList(id=1422) - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 0 - org.apache.fop.area.Area.props: null -} -</screen> -</para> - - <screen> - curPage.page.regionBody.region.mainReference.spanAreas[1].flowAreas[0].[0].[0].inlineAreas = "[ - org.apache.fop.area.inline.TextArea@21d23b -]" -</screen> - - <para>Type: <literal>org.apache.fop.area.inline.TextArea</literal>: -<screen> - curPage.page.regionBody.region.mainReference.spanAreas[1].flowAreas[0].[0].[0].inlineAreas[0] = { - text: "Test FO" - iTSadjust: 0 - org.apache.fop.area.inline.InlineArea.height: 14800 - org.apache.fop.area.inline.InlineArea.contentIPD: 59568 - org.apache.fop.area.inline.InlineArea.verticalPosition: 13688 - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 0 - org.apache.fop.area.Area.props: instance of java.util.HashMap(id=1426) -} -</screen> -</para> - - <para> -<screen> - curPage.page.regionBody.region.mainReference.spanAreas[1].flowAreas[0].[0].[0].inlineAreas[0].props = "{ - 4=16000 - 3=F3 - 7=#000000 -}" -</screen> -<variablelist> - <varlistentry> - <term>3</term> - <listitem> - <simpara><literal>org.apache.fop.area.Trait.FONT_NAME</literal></simpara> - </listitem> - </varlistentry> - <varlistentry> - <term>4</term> - <listitem> - <simpara><literal>org.apache.fop.area.Trait.FONT_SIZE</literal></simpara> - </listitem> - </varlistentry> - <varlistentry> - <term>7</term> - <listitem> - <simpara><literal>org.apache.fop.area.Trait.COLOR</literal></simpara> - </listitem> - </varlistentry> - </variablelist> -</para> - - <para>Type: <literal>org.apache.fop.area.Block</literal>: -<screen> - curPage.page.regionBody.region.mainReference.spanAreas[1].flowAreas[0].[1] = { - stacking: 2 - positioning: 0 - org.apache.fop.area.BlockParent.xOffset: 0 - org.apache.fop.area.BlockParent.yOffset: 0 - org.apache.fop.area.BlockParent.width: 0 - org.apache.fop.area.BlockParent.height: 14173 - org.apache.fop.area.BlockParent.children: null - org.apache.fop.area.BlockParent.orientation: 0 - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 0 - org.apache.fop.area.Area.props: null -} -</screen> -</para> - - <para>Type: <literal>org.apache.fop.area.Span</literal>: -<screen> - curPage.page.regionBody.region.mainReference.spanAreas[2] = { - flowAreas: instance of java.util.ArrayList(id=1429) - height: 0 - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 481891 - org.apache.fop.area.Area.props: null -} -</screen> -</para> - - <screen> - curPage.page.regionBody.region.mainReference.spanAreas[2].flowAreas = "[ - org.apache.fop.area.Flow@c72243 -]" -</screen> - - <para>Type: <literal>org.apache.fop.area.Flow</literal>: -<screen> - curPage.page.regionBody.region.mainReference.spanAreas[2].flowAreas[0] = { - stacking: 2 - width: 0 - org.apache.fop.area.BlockParent.xOffset: 0 - org.apache.fop.area.BlockParent.yOffset: 0 - org.apache.fop.area.BlockParent.width: 0 - org.apache.fop.area.BlockParent.height: 0 - org.apache.fop.area.BlockParent.children: null - org.apache.fop.area.BlockParent.orientation: 0 - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 481891 - org.apache.fop.area.Area.props: null -} -</screen> -</para> - - <para>Type: <literal>org.apache.fop.area.Span</literal>: -<screen> - curPage.page.regionBody.region.mainReference.spanAreas[3] = { - flowAreas: instance of java.util.ArrayList(id=1433) - height: 0 - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 481891 - org.apache.fop.area.Area.props: null -} -</screen> -</para> - - <screen> - curPage.page.regionBody.region.mainReference.spanAreas[3].flowAreas = "[ - org.apache.fop.area.Flow@dc9766 -]" -</screen> - - <para>Type: <literal>org.apache.fop.area.Flow</literal>: -<screen> - curPage.page.regionBody.region.mainReference.spanAreas[3].flowAreas[0] = { - stacking: 2 - width: 0 - org.apache.fop.area.BlockParent.xOffset: 0 - org.apache.fop.area.BlockParent.yOffset: 0 - org.apache.fop.area.BlockParent.width: 0 - org.apache.fop.area.BlockParent.height: 0 - org.apache.fop.area.BlockParent.children: null - org.apache.fop.area.BlockParent.orientation: 0 - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 481891 - org.apache.fop.area.Area.props: null -} -</screen> -</para> - - <para>Type: <literal>org.apache.fop.area.Span</literal>: -<screen> - curPage.page.regionBody.region.mainReference.spanAreas[4] = { - flowAreas: instance of java.util.ArrayList(id=1436) - height: 0 - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 481891 - org.apache.fop.area.Area.props: null -} -</screen> -</para> - - <screen> - curPage.page.regionBody.region.mainReference.spanAreas[4].flowAreas = "[ - org.apache.fop.area.Flow@1ec58a -]" -</screen> - - <para>Type: <literal>org.apache.fop.area.Flow</literal>: -<screen> - curPage.page.regionBody.region.mainReference.spanAreas[4].flowAreas[0] = { - stacking: 2 - width: 0 - org.apache.fop.area.BlockParent.xOffset: 0 - org.apache.fop.area.BlockParent.yOffset: 0 - org.apache.fop.area.BlockParent.width: 0 - org.apache.fop.area.BlockParent.height: 0 - org.apache.fop.area.BlockParent.children: null - org.apache.fop.area.BlockParent.orientation: 0 - org.apache.fop.area.Area.areaClass: 0 - org.apache.fop.area.Area.ipd: 481891 - org.apache.fop.area.Area.props: null -} -</screen> -</para> - - <screen> - curPage.page.regionBody.region.blocks = "[]" -</screen> - - <para>Type: <literal>org.apache.fop.area.CTM</literal>: -<screen> - curPage.page.regionBody.region.ctm = { - a: 1.0 - b: 0.0 - c: 0.0 - d: 1.0 - e: 56692.0 - f: 56692.0 - CTM_LRTB: instance of org.apache.fop.area.CTM(id=1439) - CTM_RLTB: instance of org.apache.fop.area.CTM(id=1440) - CTM_TBRL: instance of org.apache.fop.area.CTM(id=1441) -} -</screen> -</para> - - </section> - </section> - - </chapter> - -<!-- Local Variables: --> -<!-- current-language-environment: UTF-8 --> -<!-- coding: utf-8 --> -<!-- default-input-method: TeX --> -<!-- End: --> diff --git a/src/documentation/content/xdocs/DnI/fotree.xml b/src/documentation/content/xdocs/DnI/fotree.xml deleted file mode 100644 index 0b6f5f815..000000000 --- a/src/documentation/content/xdocs/DnI/fotree.xml +++ /dev/null @@ -1,197 +0,0 @@ -<?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$ --> - -<!-- -<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" - "docbookx.dtd"> - --> - - <chapter> - <title>Phase 1: Building the FO tree</title> - - <section> - <title>Creating the FO nodes</title> - - <para>FOP's first task is building a suitable data structure from -the XML input, which is an XML file with formatting objects or a -result tree with formatting objects from an XSLT transformation. One -could call this FOP's data binding. The data structure is an FO tree, -i.e., a tree of FONode objects. The structure of the FO tree exactly -parallels the structure of the XML file or the corresponding DOM tree, -but instead of XML nodes its nodes are objects of type -<literal>org.apache.fop.fo.FONode</literal>. The FO tree is built on -the basis of SAX parser events. The parser is responsible for parsing -the XML document; it calls FOP's callbacks when SAX events -occur.</para> - - <para>FOP's callbacks are implemented by the -<literal>FOTreeBuilder</literal> <literal>treebuilder</literal> -object, which is a SAX content handler. It was constructed in the -preparation phase, and registered with the parser as the content -handler. It has meaningful implementations of the methods -<literal>startDocument</literal>, <literal>endDocument</literal>, -<literal>startElement</literal>, <literal>endElement</literal>, and -<literal>characters</literal>.</para> - - <para><literal>treebuilder</literal> delegates its -<literal>startDocument</literal> and <literal>endDocument</literal> -methods to its <literal>FOTreeHandler</literal> object -<literal>foInputHandler</literal>. <literal>FOTreeHandler</literal> is -a subclas of <literal>FOInputHandler</literal>. -<screen> - treebuilder.foInputHandler = { - runtime: instance of java.lang.Runtime(id=635) - pageCount: 0 - initialMemory: 0 - startTime: 0 - foTreeListeners: instance of java.util.HashSet(id=636) - org.apache.fop.fo.FOInputHandler.foTreeControl: instance of org.apache.fop.apps.Document(id=634) - org.apache.avalon.framework.logger.AbstractLogEnabled.m_logger: instance of org.apache.avalon.framework.logger.ConsoleLogger(id=342) -} -</screen></para> - - <para>The first important task of <literal>treebuilder</literal> is -creating a suitable FO node for each element in the XML document. This -is done in its <literal>startElement</literal> method. Its most -important tool in this process is its <literal>fobjTable</literal> -object. <literal>fobjTable</literal> is a map of maps. For each -namespace supported by FOP it contains a map of local XML element name -to a Node maker object <literal>fobjMaker</literal>, of type -<literal>ElementMapping.Maker</literal>. In addition to the FO -namespace it contains makers for FOP's extensions namespace, the SVG -namespace and Batik's extensions namespace. -<screen> - treebuilder.fobjTable = "{ - http://www.w3.org/1999/XSL/Format={ - static-content=org.apache.fop.fo.FOElementMapping$SC@39e5b5, - table=org.apache.fop.fo.FOElementMapping$Ta@117f31e, - external-graphic=org.apache.fop.fo.FOElementMapping$EG@15a6029, - table-column=org.apache.fop.fo.FOElementMapping$TC@5f6303, - table-and-caption=org.apache.fop.fo.FOElementMapping$TAC@5d9084, - table-footer=org.apache.fop.fo.FOElementMapping$TB@bad8a8, - declarations=org.apache.fop.fo.FOElementMapping$Dec@e61fd1, - wrapper=org.apache.fop.fo.FOElementMapping$W@331059, - page-sequence=org.apache.fop.fo.FOElementMapping$PS@766a24, - single-page-master-reference=org.apache.fop.fo.FOElementMapping$SPMR@32784a, - footnote=org.apache.fop.fo.FOElementMapping$Foot@1774b9b, - multi-switch=org.apache.fop.fo.FOElementMapping$MS@104c575, - bidi-override=org.apache.fop.fo.FOElementMapping$BO@3fa5ac, - layout-master-set=org.apache.fop.fo.FOElementMapping$LMS@95cfbe, - float=org.apache.fop.fo.FOElementMapping$F@179dce4, - list-item=org.apache.fop.fo.FOElementMapping$LI@1950198, - basic-link=org.apache.fop.fo.FOElementMapping$BL@19bb25a, - multi-property-set=org.apache.fop.fo.FOElementMapping$MPS@da6bf4, - table-row=org.apache.fop.fo.FOElementMapping$TR@1e58cb8, - region-end=org.apache.fop.fo.FOElementMapping$RE@179935d, - block=org.apache.fop.fo.FOElementMapping$B@b9e45a, - leader=org.apache.fop.fo.FOElementMapping$L@3ef810, - table-header=org.apache.fop.fo.FOElementMapping$TB@100363, - list-item-body=org.apache.fop.fo.FOElementMapping$LIB@14e8cee, - multi-properties=org.apache.fop.fo.FOElementMapping$MP@67064, - region-after=org.apache.fop.fo.FOElementMapping$RA@bcda2d, - multi-case=org.apache.fop.fo.FOElementMapping$MC@97d01f, - block-container=org.apache.fop.fo.FOElementMapping$BC@e0a386, - title=org.apache.fop.fo.FOElementMapping$T@feb48, - retrieve-marker=org.apache.fop.fo.FOElementMapping$RM@11ff436, - color-profile=org.apache.fop.fo.FOElementMapping$CP@da3a1e, - character=org.apache.fop.fo.FOElementMapping$Ch@11dba45, - simple-page-master=org.apache.fop.fo.FOElementMapping$SPM@b03be0, - page-sequence-master=org.apache.fop.fo.FOElementMapping$PSM@2af081, - footnote-body=org.apache.fop.fo.FOElementMapping$FB@113a53d, - marker=org.apache.fop.fo.FOElementMapping$M@c5495e, - table-body=org.apache.fop.fo.FOElementMapping$TB@53fb57, - inline=org.apache.fop.fo.FOElementMapping$In@19a32e0, - table-cell=org.apache.fop.fo.FOElementMapping$TCell@8238f4, - list-block=org.apache.fop.fo.FOElementMapping$LB@16925b0, - region-start=org.apache.fop.fo.FOElementMapping$RS@297ffb, - table-caption=org.apache.fop.fo.FOElementMapping$TCaption@914f6a, - conditional-page-master-reference=org.apache.fop.fo.FOElementMapping$CPMR@1f4cbee, - list-item-label=org.apache.fop.fo.FOElementMapping$LIL@787d6a, - multi-toggle=org.apache.fop.fo.FOElementMapping$MT@71dc3d, - initial-property-set=org.apache.fop.fo.FOElementMapping$IPS@1326484, - repeatable-page-master-alternatives=org.apache.fop.fo.FOElementMapping$RPMA@16546ef, - repeatable-page-master-reference=org.apache.fop.fo.FOElementMapping$RPMR@1428ea, - flow=org.apache.fop.fo.FOElementMapping$Fl@18a49e0, - page-number=org.apache.fop.fo.FOElementMapping$PN@1f82982, - instream-foreign-object=org.apache.fop.fo.FOElementMapping$IFO@16d2633, - inline-container=org.apache.fop.fo.FOElementMapping$IC@e70e30, - root=org.apache.fop.fo.FOElementMapping$R@154864a, - region-before=org.apache.fop.fo.FOElementMapping$RBefore@3c9217, - region-body=org.apache.fop.fo.FOElementMapping$RB@9b42e6, - page-number-citation=org.apache.fop.fo.FOElementMapping$PNC@14520eb - }, - http://xml.apache.org/fop/extensions={ - bookmarks=org.apache.fop.fo.extensions.ExtensionElementMapping$B@1d7fbfb, - label=org.apache.fop.fo.extensions.ExtensionElementMapping$L@e020c9, - outline=org.apache.fop.fo.extensions.ExtensionElementMapping$O@888e6c - }, - http://www.w3.org/2000/svg={ - <default>=org.apache.fop.fo.extensions.svg.SVGElementMapping$SVGMaker@1742700, - svg=org.apache.fop.fo.extensions.svg.SVGElementMapping$SE@acb158 - }, - http://xml.apache.org/batik/ext={ - <default>=org.apache.fop.fo.extensions.svg.BatikExtensionElementMapping$SVGMaker@1af33d6, - batik=org.apache.fop.fo.extensions.svg.BatikExtensionElementMapping$SE@17431b9 - } - }" -</screen></para> - - <para>The values in this map are objects of subclasses of -<literal>ElementMapping.Maker</literal>. -<literal>ElementMapping.Maker</literal> is a static nested class of -<literal>ElementMapping</literal>. It has no members and a single -object method <literal>FONode make(FONode parent)</literal>. The -subclasses are static nested classes of -<literal>FOElementMapping</literal>. Each subclass has its own -implementation of the <literal>make</literal> method, and returns its -own subclass of FONode. For example, -<literal>FOElementMapping$R</literal> returns a -<literal>org.apache.fop.fo.pagination.Root</literal> object.</para> - - <para><literal>treebuilder</literal> delegates its -<literal>endElement</literal> method to the node's -<literal>end</literal> method, which allows FOP to take appropriate -action at the end of each FO element. The only node type whose -<literal>end</literal> method takes special action, is -<literal>org.apache.fop.fo.pagination.PageSequence</literal>. It hands -control to FOP's next phase, building of the area tree.</para> - - </section> - - <section> - <title>Creating the property values</title> - - <para>Formatting objects have many attributes by which the user -may finetune their behaviour. When the FO tree is built, the -attributes must be converted to properties. This conversion process -must implement XSLT's sometimes complicated rules of default values, -inheritance, shorthand notations etc. This is one of the tasks of the -property subsystem, which is described in its own <link -linkend="ch.properties">chapter</link>.</para> - - </section> - </chapter> - -<!-- Local Variables: --> -<!-- current-language-environment: UTF-8 --> -<!-- coding: utf-8 --> -<!-- default-input-method: TeX --> -<!-- End: --> diff --git a/src/documentation/content/xdocs/DnI/getnextbreakposs.xml b/src/documentation/content/xdocs/DnI/getnextbreakposs.xml deleted file mode 100644 index 3aa84601d..000000000 --- a/src/documentation/content/xdocs/DnI/getnextbreakposs.xml +++ /dev/null @@ -1,1209 +0,0 @@ -<?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$ --> - -<!-- -<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" - "docbookx.dtd"> - --> - - <chapter> - <title>Phase 2a: The <literal>getNextBreakPoss</literal> call -tree</title> - - <section> - <title>Overview</title> - - <para> <itemizedlist spacing="compact"> - <listitem> - <para>Create a new layout context for the children.</para> - </listitem> - <listitem> - <para>Then process the flow: loop until the flow is exhausted -(isFinished()): <itemizedlist spacing="compact"> - <listitem> - <para>Get the next possible breakpoint (getNextBreakPoss). -<itemizedlist spacing="compact"> - <listitem> - <para>Loop until the list of child layout -managers is exhausted: <itemizedlist spacing="compact"> - <listitem> - <para> Get a child layout manager -(AbstractLayoutManager.getChildLM). The current child layout manager -is returned until it is finished. Then the layout manager for the next -child is returned.</para> - </listitem> - <listitem> - <para> Create a new layout context for -the children.</para> - </listitem> - <listitem> - <para> If the child layout manager is -not finished, get the next possible breakpoint -(getNextBreakPoss).</para> - </listitem> - <listitem> - <para> If a breakpoint is returned, -break the loop and return the breakpoint.</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>This finishes a page.</para> - </listitem> - <listitem> - <para>Get the next possible breakpoint -(getNextBreakPoss) (<emphasis>continued</emphasis>) <itemizedlist spacing="compact"> - <listitem> - <para>Loop until the list of child layout -managers is exhausted: (<emphasis>continued</emphasis>) <itemizedlist spacing="compact"> - <listitem> - <para>Else if no breakpoint is returned, -do the next cycle with the next child layout manager.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Mark the layout manager as finished (the -list of child layout managers is exhausted).</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - - <para>At this point a complete (pseudo)tree of possible break -points for a page has been collected.</para> - - </section> - - <section> - <title>How do layout managers get layout managers for the child -FO nodes?</title> - -<para>Child layout managers are created and retrieved in the method -<literal>AbstractLayoutManager.getChildLM</literal>.</para> - -<para>The layout manager gets the layout manager for its next child -from its <literal>LMIter</literal> object -<literal>childLMIter</literal>. This <literal>LMIter</literal> object -contains an iterator over the children of the layout manager's FO -node. It behaves itself as an iterator over the list of layout -managers for the children. It constructs those layout managers when -needed, in its <literal>preLoadNext</literal> method, which calls the -convenience method <literal>preLoadList</literal>. Using the iterator -<literal>fobjIter</literal>, <literal>preLoadList</literal> iterates -through the children of the current FO-Object and preloads the -corresponding LMs -(<literal>LayoutManagerMaker.makeLayoutManagers()</literal>). Thus -<literal>LMIter</literal> has a layout manager for its next child. It -returns this layout manager in the call to its -<literal>next()</literal> method, when the current layout manager -invokes its <literal>getChildLM</literal> method.</para> - -<para><literal>BlockLayoutManager.ProxyLMiter</literal> has -its own subclass of <literal>LMIter</literal>, which implements a -different method of creating child layout managers. See the <link -linkend="sec.blocklm">next -section</link>.</para> - -<para>The method that creates the LMs, -<literal>LayoutManagerMaker.makeLayoutManagers()</literal>, is -implemented by FOP's implementation of the -<literal>LayoutManagerMaker</literal> interface, -<literal>LayoutManagerMapping</literal>. A different LM system can be -hooked into FOP by inserting a different implementation of the -<literal>LayoutManagerMaker</literal> interface. (See -<literal>FOUserAgent.setLayoutManagerMakerOverride</literal>.)</para> - -<para>Also note that <literal>AbstractLayoutManager.getChildLM</literal> itself -does not behave as an iterator. The current child layout manager is -returned until it is finished. One can safely make multiple calls to -<literal>getChildLM</literal>. If the current child layout manager is -unfinished and does nothing in between the calls, it remains -unfinished, and is returned at every call. If the current child layout -manager is finished, the next layout manager is loaded, and, because -it is unfinished, returned at every call. If this is the last child -layout manager and it is finished, then null is returned because in -<literal>LMiter.preLoadNext</literal> -<literal>baseIter.hasNext()</literal> returns false. The latter case -is used in <literal>BlockLayoutManager.getNextBreakPoss</literal>.</para> - -<para>Stack trace: Creating a new layout manager for a child, in -<literal>LMiter.preLoadNext</literal>, in -<literal>AbstractLayoutManager.getChildLM</literal>:</para> - -<screen> - [1] org.apache.fop.layoutmgr.LayoutManagerMapping.makeLayoutManagers(org.apache.fop.fo.FONode, java.util.List) line: 140 - [2] org.apache.fop.layoutmgr.PageSequenceLayoutManager(org.apache.fop.layoutmgr.AbstractLayoutManager).preLoadList(int) line: 399 - [3] org.apache.fop.layoutmgr.PageSequenceLayoutManager(org.apache.fop.layoutmgr.AbstractLayoutManager).preLoadNext(int) line: 409 - [4] org.apache.fop.layoutmgr.LMiter.hasNext() line: 39 - [5] org.apache.fop.layoutmgr.PageSequenceLayoutManager(org.apache.fop.layoutmgr.AbstractLayoutManager).getChildLM() line: 168 - [6] org.apache.fop.layoutmgr.PageSequenceLayoutManager.getNextBreakPoss(org.apache.fop.layoutmgr.LayoutContext) line: 260 - [7] org.apache.fop.layoutmgr.PageSequenceLayoutManager.activateLayout() line: 232 -</screen> - - </section> - - <section id="sec.blocklm"> - <title>Block layout managers and their child layout managers</title> - -<para>Block LMs are different in their treatment of their child -LMs. For this purpose <literal>BlockLayoutManager</literal> defines a -nested class <literal>ProxyLMiter</literal>, which is a subclass of -<literal>LMiter</literal>.</para> - -<para>This proxy is the basic <literal>LMiter</literal> over the -children of the block. If the proxy produces a child LM that does not -generate inline areas, the child LM is added to the list of child LMs -as normal. But if the childLM generates an inline area, a new -<literal>LineLayoutManager</literal> object is created -(<literal>BlockLayoutManager.ProxyLMiter.createLineManager</literal>). This -LM asks the proxy to produce more child LMs. As long as these child -LMs generate inline areas, they are collected by the -<literal>LineLayoutManager</literal> object. Finally, the -<literal>LineLayoutManager</literal> object creates its -<literal>LMiter</literal> object as the -<literal>ListIterator</literal> over the list of collected child -LMs.</para> - - </section> - - <section> - <title>About <literal>getNextBreakPoss</literal> and the list of -child layout managers</title> - -<para>Note that the breakpoint may come from a deeply nested child. Each -layout manager keeps a reference to its current child layout -manager. The whole list is descended again -(<literal>getChildLM</literal>) at the next call to -<literal>getNextBreakPoss</literal>.<warning> - <simpara>TO BE IMPROVED</simpara> - </warning> -</para> - -<para>Stack of layout managers: - <variablelist> - <varlistentry> - <term><literal>PageSequence</literal></term> - <listitem> - <simpara><literal>PageLayoutManager</literal></simpara> - </listitem> - </varlistentry> - <varlistentry> - <term><literal>Flow</literal></term> - <listitem> - <simpara><literal>FlowLayoutManager</literal></simpara> - </listitem> - </varlistentry> - <varlistentry> - <term><literal>Block</literal></term> - <listitem> - <simpara><literal>BlockLayoutManager</literal></simpara> - </listitem> - </varlistentry> - <varlistentry> - <term><literal>Block</literal></term> - <listitem> - <simpara><literal>LineLayoutManager</literal></simpara> - </listitem> - </varlistentry> - <varlistentry> - <term><literal>FOText</literal></term> - <listitem> - <simpara><literal>TextLayoutManager</literal></simpara> - </listitem> - </varlistentry> - </variablelist> -For <literal>BlockLayoutManager</literal> and -<literal>LineLayoutManager</literal> <literal>Block</literal> is the -same, but their <literal>childLMIter</literal> are different: -<literal>BlockLayoutManager$BlockLMiter</literal> vs -<literal>AbstractList$ListItr</literal></para> - -<screen> - [1] org.apache.fop.layoutmgr.TextLayoutManager.getNextBreakPoss (TextLayoutManager.java:270) - [2] org.apache.fop.layoutmgr.LineLayoutManager.getNextBreakPoss (LineLayoutManager.java:212) - [3] org.apache.fop.layoutmgr.BlockLayoutManager.getNextBreakPoss (BlockLayoutManager.java:229) - [4] org.apache.fop.layoutmgr.FlowLayoutManager.getNextBreakPoss (FlowLayoutManager.java:111) - [5] org.apache.fop.layoutmgr.PageLayoutManager.getNextBreakPoss (PageLayoutManager.java:261) - [6] org.apache.fop.layoutmgr.PageLayoutManager.activateLayout (PageLayoutManager.java:228) -</screen> - -<para>A <literal>TextLayoutManager</literal>: -<screen> - this = { - vecAreaInfo: instance of java.util.ArrayList(id=1062) - chars: instance of char[13] (id=1064) - textInfo: instance of org.apache.fop.fo.TextInfo(id=1065) - iAreaStart: 0 - iNextStart: 0 - ipdTotal: null - spaceCharIPD: 4448 - hyphIPD: 5328 - halfWS: instance of org.apache.fop.traits.SpaceVal(id=1066) - iNbSpacesPending: 0 - org.apache.fop.layoutmgr.AbstractLayoutManager.userAgent: instance of org.apache.fop.apps.FOUserAgent(id=1067) - org.apache.fop.layoutmgr.AbstractLayoutManager.parentLM: instance of org.apache.fop.layoutmgr.LineLayoutManager(id=1068) - org.apache.fop.layoutmgr.AbstractLayoutManager.fobj: instance of org.apache.fop.fo.FOText(id=1069) - org.apache.fop.layoutmgr.AbstractLayoutManager.foID: null - org.apache.fop.layoutmgr.AbstractLayoutManager.markers: null - org.apache.fop.layoutmgr.AbstractLayoutManager.bFinished: false - org.apache.fop.layoutmgr.AbstractLayoutManager.curChildLM: null - org.apache.fop.layoutmgr.AbstractLayoutManager.childLMiter: instance of org.apache.fop.layoutmgr.LMiter(id=1070) - org.apache.fop.layoutmgr.AbstractLayoutManager.bInited: true -} -</screen> -</para> - -<para>Text in <literal>fo:text</literal> is handled by a -<literal>TextLayoutManager</literal>. Two routines add the text and -calculate the next possible break.</para> - - </section> - - <section> - <title><literal>LineLayoutManager.getNextBreakPoss</literal></title> - - <section> - <title>Prepare for the main loop</title> - - <itemizedlist spacing="compact"> - <listitem> - <simpara>Create a new empty list of possible line endings, -<literal>vecPossEnd</literal>.</simpara> - </listitem> - <listitem> - <simpara>Retrieve the <literal>ipd</literal> -<literal>availIPD</literal> from the layout context.</simpara> - </listitem> - <listitem> - <simpara>Create a new layout context (inline layout -context) for the child layout managers, based on the layout context -for this layout manager.</simpara> - </listitem> - <listitem> - <simpara>Clear the map of previous - <literal>ipd</literal>s.</simpara> - </listitem> - <listitem> - <simpara>Record the length of -<literal>vecInlineBreaks</literal>, which we can use to find the last -breakposs of the previous line.</simpara> - </listitem> - <listitem> - <simpara>Set <literal>prevBP</literal> to -<literal>null</literal>; <literal>prevBP</literal> contains the last -confirmed breakposs of this line.</simpara> - </listitem> - </itemizedlist> - </section> - - <section> - <title>The main loop over the list of child layout managers</title> - - <para>Loop until the list of child layout managers is -exhausted: <itemizedlist spacing="compact"> - <listitem> - <para>Get a child layout manager -(<literal>AbstractLayoutManager.getChildLM</literal>). The current -child layout manager is returned until it is finished. Then the layout -manager for the next child is returned.</para> - </listitem> - <listitem> - <para>Record the last breakposs.</para> - </listitem> - <listitem> - <para>Record whether the breakposs we are going to -find is the first breakposs of this line.</para> - </listitem> - <listitem> - <para>Record whether it is the first breakposs of -this child layout manager.</para> - </listitem> - <listitem> - <para>Initialize the inline layout context (note that -it is not a new layout context, the same inline layout context is used -by all child layout managers) (method -<literal>InlineStackingLayout.initChildLC</literal>): <itemizedlist spacing="compact"> - <listitem> - <para>Record whether this is a new area; it is a -new area if this is the start of a new line or of a new child -LM.</para> - </listitem> - <listitem> - <para>If this is the start of a new -line <itemizedlist spacing="compact"> - <listitem> - <para>record whether this is the first area -of this child LM,</para> - </listitem> - <listitem> - <para>set the leading space as passed by -argument.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Else if this starts a new child -LM <itemizedlist spacing="compact"> - <listitem> - <para>record that this is the first area,</para> - </listitem> - <listitem> - <para>set the leading space from the previous -BP.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Else set the leading space to - <literal>null</literal>.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Record on the inline layout context whether -leading space is supppressed; it is suppressed if this is the start of -a new line, but not the start of this child LM, and the previous line -was not ended by a forced break.</para> - </listitem> - <listitem> - <para>Retrieve the next breakposs from the current child -LM (<literal>getNextBreakPoss</literal> method of child LM). If it is -not <literal>null</literal>: -<itemizedlist spacing="compact"> - <listitem> - <para>Calculate the <literal>ipd</literal> up to -the previous BP (method -<literal>InlineStackingLayout.updatePrevIPD</literal>): <itemizedlist spacing="compact"> - <listitem> - <para>Take an empty <literal>ipd</literal> - size.</para> - </listitem> - <listitem> - <para>If this starts a new line: <itemizedlist spacing="compact"> - <listitem> - <para>if it has a leading fence, add -leading space (?),</para> - </listitem> - <listitem> - <para>list the <literal>ipd</literal> -for the LM of this BP in the map of previous -<literal>ipd</literal>s.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Else <itemizedlist spacing="compact"> - <listitem> - <para>retrieve the -<literal>ipd</literal> for the LM of this BP in the map of previous -<literal>ipd</literal>s,</para> - </listitem> - <listitem> - <para>if that is -<literal>null</literal> (first BP of this child LM) <itemizedlist spacing="compact"> - <listitem> - <para>retrieve the -<literal>ipd</literal> for the LM of the previous BP in the map of -previous <literal>ipd</literal>s,</para> - </listitem> - <listitem> - <para>add the leading space -of this BP,</para> - </listitem> - <listitem> - <para>add the pending space-end -(stacking size) of the previous BP,</para> - </listitem> - <listitem> - <para>list the -<literal>ipd</literal> for the LM of this BP in the map of previous -<literal>ipd</literal>s.</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Add to the <literal>ipd</literal> the -pending space-end (stacking size) of this BP.</para> - </listitem> - <listitem> - <para>Record whether this BP could end the -line: <itemizedlist spacing="compact"> - <listitem> - <para>if a break may occur after this BP, -record true;</para> - </listitem> - <listitem> - <para>else if this BP is suppressible at a -line break, return false;</para> - </listitem> - <listitem> - <para>else, return whether this is the last -child LM and it is finished, or the next area could start a new -line.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>If this BP could end the line, add trailing -space.</para> - </listitem> - <listitem> - <para>If this BP exceeds the line length -(<literal>bpDim.min > availIPD.max</literal>), <itemizedlist spacing="compact"> - <listitem> - <para>if the text should be justified or if -this is the first BP of this line, <itemizedlist spacing="compact"> - <listitem> - <para>if we are in a hyphenation try, -break the loop; we have exhausted our options and one of the previous -BPs should end the line (<literal>_exit of loop_</literal>);</para> - </listitem> - <listitem> - <para>if this BP could not end the -line, add it to the list of inline breaks, and continue with the next -iteration;</para> - </listitem> - <listitem> - <para>prepare to hyphenate: get the -hyphenation context for the text between the last and this BP (method -<literal>getHyphenContext</literal>): <itemizedlist spacing="compact"> - <listitem> - <para>add this BP to the list of -inline breaks; even though this is not a good BP, we add it to the -list, so that we can retrieve the text between the last and this -BP;</para> - </listitem> - <listitem> - <para>iterate back to the -previous BP in this list;</para> - </listitem> - <listitem> - <para>loop over the following -BPs in this list: <itemizedlist spacing="compact"> - <listitem> - <para>retrieve the text -between the preceding and this BP.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>remove this BP again from -the list of inline breaks.</para> - </listitem> - <listitem> - <para>create a hyphenation -object for the retrieved text, taking the language, country and other -hyphenation properties into account.</para> - </listitem> - <listitem> - <para>create a hyphenation -context object from it, and return that.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>store the hyphenation context -with the inline layout context.</para> - </listitem> - <listitem> - <para>Record on the inline layout -context that we are in a hyphenation try.</para> - </listitem> - <listitem> - <para>reset the child LMs to the -previous BP or to the start of the line.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Else (if text should not be justified -and if this is not the first BP of this line) break the loop; one of -the previous BPs should end the line (<literal>_exit of -loop_</literal>);</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Else (if this BP does not exceed the line -length): <itemizedlist spacing="compact"> - <listitem> - <para>add this BP to the list of inline -breaks,</para> - </listitem> - <listitem> - <para>if this BP could end the line, -<itemizedlist spacing="compact"> - <listitem> - <para>record it as the last confirmed -BP: set prevBP to this BP.</para> - </listitem> - <listitem> - <para>if this BP is a forced line -break, break the loop; this BP (or one of the previous BPs?) should -end the line (<literal>_exit of loop_</literal>).</para> - </listitem> - <listitem> - <para>if this BP may fill the line -length (<literal>bpDim.max >= availIPD.min</literal>), add it to the -list of possible line endings, <literal>vecPossEnd</literal>, with a -cost which is equal to the difference of the optimal values of the -content length and the line length (<literal>Math.abs(availIPD.opt - -bpDim.opt)</literal>).</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>If we are in a hypenation try, and the hyphenation -context has no more hyphenation points, break the loop; this or one of -the previous BPs should end the line (<literal>_exit of -loop_</literal>).</para> - </listitem> - </itemizedlist></para> - </section> - - <section> - <title>After the main loop</title> - - <para>There are five exit points of the main loop: <orderedlist> - <listitem> - <simpara>The last BP in the hyphenation try has exceeded -the line length.</simpara> - </listitem> - <listitem> - <simpara>The last BP has exceeded the line length, and -we cannot get a hyphenation context.</simpara> - </listitem> - <listitem> - <simpara>The last BP has exceeded the line length, and -we do not hyphenate.</simpara> - </listitem> - <listitem> - <simpara>The last BP has not exceeded the line length -but forces a line break.</simpara> - </listitem> - <listitem> - <simpara>We have run out of hyphenation points (and the -last BP has not exceeded the line length).</simpara> - </listitem> - <listitem> - <simpara>Natural end of the while loop: we are through -the list of child layout managers.</simpara> - </listitem> - </orderedlist></para> - -<para>If the last BP has exceeded the line length, it is not in the -list of inline breaks, and prevBP points to the last good break; -otherwise it is in the list of inline breaks, and prevBP points to -it.</para> - - <itemizedlist spacing="compact"> - <listitem> - <para>If we are through the list of child LMs, mark this - LM as finished.</para> - </listitem> - <listitem> - <para>If no BP was produced, return -<literal>null</literal>. (This should concur with being -finished?)</para> - </listitem> - <listitem> - <para>If prevBP is <literal>null</literal>, there is not -last good break; set it to this BP, even though it fails some -criteria: <itemizedlist spacing="compact"> - <listitem> - <para>it has exceeded the line length in the -hyphenation try or we cannot get a hyphenation context,</para> - </listitem> - <listitem> - <para>or it cannot end the line but it is the last -BP of the last child layout manager.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>If this BP is not a forced break, and there are -several possible line breaks, select the best one; make -<literal>prevBP</literal> point to it. (Could this produce the wrong -result if the BP has exceeded the line length and at the same time is -a forced line break? Should <literal>prevBP</literal> be tested for -being a forced break instead?)</para> - </listitem> - <listitem> - <para>If the last BP is not the actual breakpoint -<literal>prevBP</literal> (<literal>bp != prevBP</literal>) and the -material after <literal>prevBP</literal> is not suppressible at the -end of a line, back up to <literal>prevBP</literal> for a proper start -of the next line.</para> - </listitem> - <listitem> - <para>If the text should be justified and the breakpoint -is a forced line break (here <literal>prevBP</literal> is tested) or -this is the last line of the layout manager, set text alignment to -left-aligned.</para> - </listitem> - <listitem> - <para>Make a line break and return the associated - breakposs.</para> - </listitem> - </itemizedlist> - </section> - </section> - - <section> - <title><literal>LineLayoutManager.makeLineBreak</literal></title> - - <para>Arguments are: <itemizedlist spacing="compact"> - <listitem> - <para>index in <literal>vecInlineBreaks</literal> of - line breaking BP of last line,</para> - </listitem> - <listitem> - <para>target line length,</para> - </listitem> - <listitem> - <para>type of text alignment.</para> - </listitem> - </itemizedlist></para> - -<para>Calculate line dimensions. The Line LayoutManager contains the -parameters <literal>lineHeight</literal>, <literal>lead</literal> and -<literal>follow</literal> as members, which it received from its Block -LayoutManager parent at construction. The Blo ckLayoutManager contains -these parameters as members as well, and has received them from a -<literal>TextInfo</literal> object in the method set -<literal>BlockTextInfo</literal>. The <literal>TextInfo</literal> -object has a reference to the <literal>Font</literal> -object. <literal>lead</literal> is the font ascender, -<literal>follow</literal> is the font descender.</para> - -<para>The leading is the difference between -<literal>lineHeight</literal> and font height = ascender + -descender. The leading is split in two halves, one for above, the -other for below the line. The variable <literal>lineLead</literal> is -calculated as the distance from the baseline to the top of the line, -the variable <literal>maxtb</literal> is calculated as the distance -from the baseline to the bottom of the line. The variable -<literal>middlefollow</literal> set equal to <literal>maxtb</literal>. -These parameters correspond to the members <literal>lead</literal>, -<literal>total</literal> and <literal>follow</literal> of the -breakposs. <warning> - <simpara>Find out the exact meaning of these.</simpara> - </warning></para> - - <itemizedlist spacing="compact"> - <listitem> - <para>Loop over the breakposs in - <literal>vecInlineBreaks</literal>: <itemizedlist spacing="compact"> - <listitem> - <para>adjust <literal>lineLead</literal>, -<literal>maxtb</literal> and <literal>middlefollow</literal> if the -corresponding dimension of the BP is larger;</para> - </listitem> - <listitem> - <para>add the <literal>ipd</literal>s; a BP does -not just hold the <literal>ipd</literal> of the area since the -previous BP, but the cumulative <literal>ipd</literal> for all the -areas contributed by its layout manager; therefore care is taken to -add only the <literal>ipd</literal> of the last BP of each LM; more -precisely, the <literal>ipd</literal> of the last BP of the previous -LM is added when the next LM is encountered;</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Add the <literal>ipd</literal> of the last BP.</para> - </listitem> - <listitem> - <para>Resolve the trailing space of the last BP.</para> - </listitem> - <listitem> - <para>Adjust <literal>middlefollow</literal> if it is -smaller than <literal>maxtb - lineHeight</literal>.</para> - </listitem> - <listitem> - <para>Calculate the stretch or shrink factor -<literal>ipdAdjust</literal> for the stretch- and shrinkable elements -in this line: <itemizedlist spacing="compact"> - <listitem> - <para>if content optimum is larger than line - length optimum, <itemizedlist spacing="compact"> - <listitem> - <para>if content minimum is smaller than - line length optimum, <itemizedlist spacing="compact"> - <listitem> - <para>calculate -<literal>ipdAdjust</literal> between 0 and -1, real line length = line -length optimum,</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>else (content minimum is larger than - line length optimum) <itemizedlist spacing="compact"> - <listitem> - <para><literal>ipdAdjust = --1</literal>, real line length = content minimum,</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>else (content optimum is smaller than line - length optimum), <itemizedlist spacing="compact"> - <listitem> - <para>if content maximum is larger than line - length optimum, <itemizedlist spacing="compact"> - <listitem> - <para>calculate -<literal>ipdAdjust</literal> between 0 and 1, real line length = line -length optimum,</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>else (content maximum is smaller than - line length optimum), <itemizedlist spacing="compact"> - <listitem> - <para><literal>ipdAdjust = -1</literal>, real line length = content maximum.</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Calculate the stretch or shrink factor -<literal>dAdjust</literal> for white space and the indent: -<itemizedlist spacing="compact"> - <listitem> - <para>justify: calculate -<literal>dAdjust</literal>,</para> - </listitem> - <listitem> - <para>center or end: calculate the required - indent.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Create a new <literal>LineBreakPosition</literal> -based on this LM, the last BP in <literal>vecInlineBreaks</literal> -and the calculated dimensions; use <literal>lineLead</literal> for the -baseline position and <literal>lineLead + middlefollow</literal> for -the <literal>lineHeight</literal>.</para> - </listitem> - <listitem> - <para>Create a <literal>BreakPoss</literal> from this - <literal>LineBreakPosition</literal> object.</para> - </listitem> - <listitem> - <para>Mark the BP as last if this LM is finished.</para> - </listitem> - <listitem> - <para>Set the stacking size of the BP -(<literal>bpd</literal>) equal to <literal>lineLead + -middlefollow</literal>.</para> - </listitem> - </itemizedlist> - </section> - - <section> - <title>Line LayoutManager, a sequence of breakposs</title> - -<para>The text is: "waterstaatsingenieur ministersportefeuille -aandachtstrekker. Vernederlandste vakliteratuur" etc. It consists of a -few long Dutch words, which can be found in the hyphenation exceptions -in <filename>nl.xml</filename>. The column width is 8cm. This text and -width have been chosen so that they force many hyphenations.</para> - -<para>This text is contained in a single <literal>FOText</literal> -node, and is dealt with by a single Text LayoutManager, which is a -child layout manager for the Line LayoutManager. The Text -LayoutManager maintains a list of area information objects, -<literal>vecAreaInfo</literal>, and the Line LayoutManager maintains a -list of breakposs, <literal>vecInlineBreaks</literal>. Each breakposs -refers to an area, in its <literal>position.iLeafPos</literal> -member.</para> - -<para>During the process of finding suitable line breaks, breakposs -are generated until one is found that exceeds the line length. Then -the Line LayoutManager backs up to the previous BP, either to start a -hyphenation try or to create the line break. When it creates a line -break, the last breakposs, which exceeds the line length, is not added -to the list of inline breaks. When it starts a hyphenation try, the -breakposs is added to that list, and removed again after the text for -hyphenation has been obtained. Each time, the corresponding area info -is left in the list of area information objects. As a consequence the -list <literal>vecAreaInfo</literal> is longer than the list -<literal>vecInlineBreaks</literal>, and some areas have no -corresponding breakposs.</para> - -<screen> -wa-ter-staats-in-ge-nieur mi-nis-ters-por-te-feuil-le aandachtstrekker. -0 2 5 1 1 1 2 2 2 2 3 3 3 4 4 6 - 1 3 5 0 3 6 9 0 3 5 0 2 0 - -text: waterstaatsingenieur wa ter staats in | -AreaInfo: 0: 0-20 (removed) 0: 0-2 1: 2-5 2: 5-11 3: 11-13 | -InlineBreaks: 0 (removed) 0 1 2 3 | - too long, hyphenate, | - back up V - -gen genieur _ministersportefeuille _mi nis | -4: 13-15 5: 13-20 6: 20-42 7: 20-23 8: 23-26 | - 4 5 (removed) 5 6 | -too long, too long, hyphenate | -line break, back up | -back up v - -ters tersportefeuille_ ter s por -9: 26-30 10: 26-42 11: 26-29 12: 29-30 13: 30-33 - 7 (removed) 7 8 9 -too long, too long, hyphenate, hyphenation -line break, back up error -back up - -te feuil | le | _aandachtstrekker. -14: 33-35 15: 35-40 | 16: 40-42 | 17: 42-60 -10 11 | 12 | 13 (removed) - last hyphenpoint, | | too long, - line break v | hyphenation fails, - | line break, - v back up - -aandachtstrekker. | etc. -18: 43-60 | -13 | -too long, | -hyphenation fails, | -first BP, | -line break v -</screen> - -<para>A few remarkable points: <orderedlist> - -<listitem> -<simpara>The first AreaInfo object is removed from the list during backing - up. This is because the previous BP, which is - <literal>null</literal>, does not belong to this child layout - manager, and therefore the whole child LM is reset.</simpara> -</listitem> - -<listitem> -<simpara>The last BP, no. 18, exceeds the line length, but because it is the - first BP of this line, it is accepted for the line break.</simpara> -</listitem> - -<listitem> -<simpara>BP 7 at position 29 falls at a point that is not a good hyphenation - point. This is probably caused by the fact that for this line only - the partial word is subjected to hyphenation. On the previous line - the complete word was subjected to hyphenation, and there was no BP - at position 29.</simpara> -</listitem> - -<listitem> -<simpara>For the word "aandachtstrekker." hyphenation fails - (<literal>hyph == null</literal> is returned). This may be due to - the period not being separated from the word. When the period is - removed, the word is properly broken.</simpara> -</listitem> - </orderedlist></para> - </section> - - <section> - <title><literal>TextLayoutManager.getNextBreakPoss</literal></title> - - <para> <itemizedlist spacing="compact"> - <listitem> - <para>If this is the first call to this Text -LayoutManager, initialize <literal>ipdTotal</literal> and record that -this breakposs is the first in <literal>iFlags</literal>.</para> - </listitem> - <listitem> - <para>If leading spaces must be suppressed, suppress all -leading space characters <literal>U+20</literal>. Return if this -finished the text.</para> - </listitem> - <listitem> - <para>For the remaining leading space characters, -<itemizedlist spacing="compact"> - <listitem> - <para>If this is a space <literal>U+20</literal> - or a non-breaking space <literal>U+A0</literal>, - <itemizedlist spacing="compact"> - <listitem> - <para>count it;</para> - </listitem> - <listitem> - <para>if this is the first character and this - is the first breakposs, <itemizedlist spacing="compact"> - <listitem> - <para>if the context has leading spaces, -add it (or <literal>halfWS</literal>?);</para> - </listitem> - <listitem> - <para>else add it (or -<literal>halfWS</literal>?) to the pending space, and add the pending -space to the <literal>space</literal> ipd.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>add the space width to the word -<literal>ipd</literal>.</para> - </listitem> - <listitem> - <para>set the pending space to - <literal>halfWS</literal>.</para> - </listitem> - <listitem> - <para>if this is a non-breaking space -<literal>U+A0</literal>, register it in -<literal>bSawNonSuppressible</literal>.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Else (other space characters), <itemizedlist spacing="compact"> - <listitem> - <para>register it in - <literal>bSawNonSuppressible</literal>.</para> - </listitem> - <listitem> - <para>add the pending space to the space -<literal>ipd</literal>, and clear the pending space.</para> - </listitem> - <listitem> - <para>add the character width to the word - <literal>ipd</literal>.</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>If this finishes the text, <itemizedlist spacing="compact"> - <listitem> - <para>register whether there were any -nonsuppressible spaces (<literal>bSawNonSuppressible</literal>) in -<literal>iFlags</literal>.</para> - </listitem> - <listitem> - <para>pass all the info to - <literal>makeBreakPoss</literal> and - <literal>_return_</literal> its breakposs.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Else, <itemizedlist spacing="compact"> - <listitem> - <para>add pending space.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>If hypenation is on, get the size of the next - syllable: <itemizedlist spacing="compact"> - <listitem> - <para>get the size of the next syllable, -<itemizedlist spacing="compact"> - <listitem> - <para>if successful, add the flags -<literal>BreakPoss.CAN_BREAK_AFTER</literal> and -<literal>BreakPoss.CAN_BREAK_AFTER</literal> in -<literal>iFlags</literal>,</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>add the syllable length to the word - <literal>ipd</literal>.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Else look for a legal line-break: breakable -white-space and certain characters such as '-' which can serve as word -breaks; don't look for hyphenation points here though, <itemizedlist spacing="compact"> - <listitem> - <para>for all following characters: <itemizedlist spacing="compact"> - <listitem> - <para>If this is a newline character -<literal>U+0A</literal>, or if <literal>textInfo.bWrap</literal> and -this is a breakable space, or if this is one of the linebreak -characters ("-/") and it is the first character or the preceding -character is a letter or a digit, <itemizedlist spacing="compact"> - <listitem> - <para>add the flag -<literal>BreakPoss.CAN_BREAK_AFTER</literal> to -<literal>iFlags</literal>,</para> - </listitem> - <listitem> - <para>if this is not a space - <literal>U+20</literal>, <itemizedlist spacing="compact"> - <listitem> - <para>move the counter to the next - character,</para> - </listitem> - <listitem> - <para>if this is a newline -<literal>U+0A</literal>, add the flag -<literal>BreakPoss.FORCE</literal> to -<literal>iFlags</literal>,</para> - </listitem> - <listitem> - <para>else add the character width -to the word <literal>ipd</literal>.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>if the rest of the text consists -of spaces <literal>U+20</literal>, register that the rest is -suppressible at a line break -(<literal>BreakPoss.REST_ARE_SUPPRESS_AT_LB</literal>) in -<literal>iFlags</literal>,</para> - </listitem> - <listitem> - <para>pass all the info to -<literal>makeBreakPoss</literal> and <literal>_return_</literal> its -breakposs.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Else add the character width to the word - <literal>ipd</literal>,</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>and continue with the cycle for the next - character.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>At the end of the text, pass all the info to -<literal>makeBreakPoss</literal> and <literal>_return_</literal> its -breakposs.</para> - </listitem> - </itemizedlist></para> - </section> - - <section> - <title><literal>TextLayoutManager.makeBreakPoss</literal></title> - - <itemizedlist spacing="compact"> - <listitem> - <para>Make word <literal>ipd</literal> into a - <literal>MinOptMax</literal> object.</para> - </listitem> - <listitem> - <para>Add space <literal>ipd</literal> to it.</para> - </listitem> - <listitem> - <para>Add total <literal>ipd</literal> from previous texts - to it.</para> - </listitem> - <listitem> - <para>Create an <literal>AreaInfo</literal> object for this -text fragment and add it to the vector of <literal>AreaInfo</literal> -objects.</para> - </listitem> - <listitem> - <para>Create a breakposs for this text fragment.</para> - </listitem> - <listitem> - <para>Set the total <literal>ipd</literal> to the current - <literal>ipd</literal>.</para> - </listitem> - <listitem> - <para>If the flags contain -<literal>BreakPoss.HYPHENATED</literal>, set the stacking size to the -<literal>ipd</literal> plus the width of the hyphen character,</para> - </listitem> - <listitem> - <para>Else set the stacking size to the - <literal>ipd</literal>.</para> - </listitem> - <listitem> - <para>Set the non-stacking size to the line height, from the - text info.</para> - </listitem> - <listitem> - <para>Register the descender and ascender with the breakposs -object; this is currently commented out.</para> - </listitem> - <listitem> - <para>If this is the end of the text, <itemizedlist spacing="compact"> - <listitem> - <para>add <literal>BreakPoss.ISLAST</literal> to the - flags,</para> - </listitem> - <listitem> - <para>declare the LM finished.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Register the flags with the breakposs object</para> - </listitem> - <listitem> - <para>Register the pending space or the absence thereof with -the breakposs object.</para> - </listitem> - <listitem> - <para>Register the leading space or the absence thereof with -the breakposs object.</para> - </listitem> - <listitem> - <para>Return the breakposs object.</para> - </listitem> - </itemizedlist> - - </section> - - </chapter> - -<!-- Local Variables: --> -<!-- current-language-environment: UTF-8 --> -<!-- coding: utf-8 --> -<!-- default-input-method: TeX --> -<!-- End: --> diff --git a/src/documentation/content/xdocs/DnI/overview.xml b/src/documentation/content/xdocs/DnI/overview.xml deleted file mode 100644 index d085f713f..000000000 --- a/src/documentation/content/xdocs/DnI/overview.xml +++ /dev/null @@ -1,153 +0,0 @@ -<?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$ --> - -<!-- -<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" - "docbookx.dtd"> - --> - - <chapter> - - <title>Overview</title> - - <para>A FOP process has three stages:<orderedlist> - <listitem> - <simpara> building the FO tree,</simpara> - </listitem> - <listitem> - <simpara>building the Area tree,</simpara> - <orderedlist numeration="loweralpha"> - <listitem> - <simpara>The getNextBreakPoss call tree</simpara> - </listitem> - <listitem> - <simpara>The addAreas call tree</simpara> - </listitem> - <listitem> - <simpara>Finishing the page</simpara> - </listitem> - </orderedlist> - </listitem> - <listitem> - <simpara>rendering the pages.</simpara> - </listitem> - </orderedlist></para> - -<para>These stages are preceded by two other stages:<itemizedlist> - <listitem> - <simpara>0. <emphasis>preparation:</emphasis> the objects for -the FOP process are constructed; this phase may be done by FOP (apps -package), or by the calling application;</simpara> - </listitem> - <listitem> - <simpara>X. <emphasis>parsing:</emphasis> this phase is done -by a SAX parser; FOP's own preparation stage uses a JAXP -SAXParserFactory to call an available SAX parser.</simpara> - </listitem> - </itemizedlist></para> - - <para><emphasis>Stage 0.</emphasis> The preparation stage occurs -before the other stages. When it is completed it starts the parsing -stage by calling the parser's <literal>parse</literal> method.</para> - - <para>The parsing stage and stages 1, 2, 3 run concurrently. Each stage -calls into the following stage at appropriate points in its -process. It is feasible that stages 2 and 3 will run in separate -threads.</para> - - <para><emphasis>Stage X.</emphasis> The parser now takes control. -It parses the FO document or walks over the DOM tree. When it -encounters XML events such as the start or end of the document, the -start or end of an XML element, or character data, it makes a call -back into the FO tree builder.</para> - - <para><emphasis>Stage 1.</emphasis> The FO tree builder now takes -control to create or finish the FO node for which the XML event was -fired. When it is done, it returns control to the parser.</para> - - <para>The end events of a few XML elements invoke further actions -of the FO tree builder. When a page-sequence FO node is finished, the -FO tree builder notifies its tree listeners (of which there usually is -only one, the Area tree builder) of this event. Each listener in turn -takes control to process the page sequence.</para> - - <para><emphasis>Stage 2.</emphasis> The Area tree builder (which -is the tree listener) now takes control to lay out the page sequence -and construct the Area tree for it. This stage is divided in three -substages.</para> - - <para><emphasis>Stage 2a.</emphasis> The (pseudo)tree of possible -break points is created. Each node in the FO tree creates a Layout -Manager of the appropriate type. The resulting tree of Layout Managers -is recursed. Each Layout Manager asks each of its child Layout -Managers in turn to return a possible break point, until all child -Layout Managers are finished. This process is started by the Page -Layout Manager, which is tied to the page-sequence FO node that was -just completed in stage 1. Each time when its current child Layout -Manager returns a possible break point, a complete (pseudo)tree of -possible break points for a page has been collected. The next -substage takes control.</para> - - <para><emphasis>Stage 2b.</emphasis> Now the area tree is -created. The (pseudo)tree of possible break points and their Layout -Managers is recursed. Each possible break point may create an area. It -then calls the possible break points of the child LM that fall in this -area, to create and return their area, and adds those areas to its own -area. This process is started by the Page Layout Manager after the -previous substage has finished. When its possible break point returns -its area, the area tree for the flow of the page is complete.</para> - - <para><emphasis>Stage 2c.</emphasis> The Page Layout Manager adds -the static areas and hands the page to the Area tree builder, which -adds it to the root area. The Area tree builder now inspects the set -of complete pages, and fills in forward references to the page just -finished. Pages which are now complete including the forward -references contained in them, are handed over to the renderer, which -now takes control. When the renderer returns control, the Page Layout -Manager starts again in stage 2a to lay out the next page in the page -sequence.</para> - - <para>When all pages of this page sequence are done, this stage -finishes, and the Area tree builder returns control to the FO tree -builder.</para> - - <para><emphasis>Stage 3.</emphasis> The renderer now takes control -to render the finished pages. When it is done with those pages, it -returns control to the Area tree builder.</para> - - <para>This process model is FOP's default process model. It is -completely configurable, through the objects constructed in the -preparation stage. Stage 1 is configured by the content handler that -is registered with the parser. Stage 2 is configured by the listeners -that are registered with the FO tree builder. The layout process in -stage 2 is also configured by the layout strategy that is registered -with the Area tree builder. [It might be more appropriate to say that -stage 2 is controlled by the tree control object. The actual Area tree -builder is assigned by the layout strategy.] Stage 3 is configured by -the selected renderer or output format.</para> - - </chapter> - -<!-- Local Variables: --> -<!-- current-language-environment: UTF-8 --> -<!-- coding: utf-8 --> -<!-- default-input-method: TeX --> -<!-- End: --> diff --git a/src/documentation/content/xdocs/DnI/preparation.xml b/src/documentation/content/xdocs/DnI/preparation.xml deleted file mode 100644 index bcd0d5631..000000000 --- a/src/documentation/content/xdocs/DnI/preparation.xml +++ /dev/null @@ -1,471 +0,0 @@ -<?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$ --> - -<!-- -<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" - "docbookx.dtd"> - --> - - <chapter> - <title>Phase 0: Preparation</title> - - <para>This chapter describes the structure of FOP as it was in the -first quarter of 2004. In the second quarter of that year the top -level structure was strongly refactored. The new situation is not -described here.</para> - - <section> - <title>The preparation process</title> - - <para>FOP's processing model is the SAX parsing model:<itemizedlist> - <listitem> - <simpara>Construct a suitable content handler object of type -<literal>org.xml.sax.ContentHandler</literal>,</simpara> - </listitem> - <listitem> - <simpara>create a parser of type -<literal>org.xml.sax.XMLReader</literal>,</simpara> - </listitem> - <listitem> - <simpara>register the content handler with the parser,</simpara> - </listitem> - <listitem> - <simpara>call the parser's parse method on the input -source.</simpara> - </listitem> - </itemizedlist></para> - - <para>From there on the parser takes control. For every XML -event it passes control to the appropriate content handler methods. -When these methods return, parsing continues until the next XML event -is encountered. Once the parser has taken control, its content handler -is the only entry point into FOP's data structures and methods.</para> - - <para>The preparatory phase of FOP concerns itself with the -construction of a suitable content handler object, whose methods allow -FOP's process to handle the FO elements reported by the parser and -build the required output document.</para> - - <para>An application may choose to deal with the whole -preparatory phase itself, and then call the parser's -<literal>parse</literal> method.</para> - - <para>The input source may be an FO file, which may be fed to -the <literal>parse</literal> method as a string or as an -<literal>org.xml.sax.InputSource</literal> object. Alternatively, a -DOM document object may be used as input, e.g. the output of an XSLT -processor. In that case:<itemizedlist> - <listitem> - <simpara> the parser should be of type -<literal>org.apache.fop.tools.DocumentReader</literal>,</simpara> - </listitem> - <listitem> - <simpara>the input source should be of type -<literal>org.apache.fop.tools.DocumentInputSource</literal>, created -with the DOM document as the argument of the constructor.</simpara> - </listitem> - </itemizedlist></para> - - <para>The classes <literal>Fop</literal> and -<literal>Driver</literal> contain methods which applications may use -as more convenient entry points into FOP.</para> - - <para>The method <literal>Fop.main</literal> may be called with -the input and output file names as arguments. This is mainly useful -for starting Fop from the command line.</para> - - <para>The class <literal>Driver</literal> contains a method -<literal>getContentHandler</literal>, which can be used to create a -suitable content handler. It also contains three -<literal>render</literal> methods which are convenient entry points -for applications.</para> - - <para>These 4 methods may be invoked on a driver object which -already has the following members: <literal>userAgent</literal>, -<literal>renderer</literal>, <literal>log</literal>, -<literal>stream</literal>. In addition, the driver object may have the -following members: a <literal>TreeBuilder</literal> object having a -member <literal>userAgent</literal>, and a <literal>Document</literal> -object, which may have a member <literal>layoutStrategy</literal>. -Using one's own <literal>TreeBuilder</literal> and -<literal>Document</literal> objects allows one to customize FOP's -behaviour in a major way.</para> - - <para>The <literal>render</literal> methods invoke -<literal>getContentHandler</literal> to create a suitable content -handler. They register it as the content handler of the parser. They -register the member <literal>currentDocument</literal> as a tree -listener to the member <literal>foInputHandler</literal>.</para> - - <para>A suitable <literal>org.xml.sax.ContentHandler</literal> -object for FOP processing is an object of type -<literal>org.apache.fop.fo.FOTreeBuilder</literal> and has the -following structure: -<screen> - treeBuilder - | - +--------------+------------------+ - | | | -foInputHandler userAgent foTreeControl - | | -foTreeControl driver -foTreeListeners: usedFonts - [foTreeControl] triplets - fonts - layoutStrategy -- foTreeControl - areaTree -- atModel, foTreeControl - atModel -- renderer - foInputHandler -</screen> -</para> - - <para>The <literal>driver</literal> and -<literal>renderer</literal> objects are complex objects: -<screen> - driver renderer - | | - treeBuilder foTreeControl - renderer userAgent - foInputHandler fontList - ostream ostream - userAgent - foTreeControl -</screen> -</para> - - </section> - - <section> - <title>A detailed overview of the objects</title> - - <screen> - treeBuilder = { - fobjTable: instance of java.util.HashMap(id=589) - namespaces: instance of java.util.HashSet(id=590) - currentFObj: null - rootFObj: null - foInputHandler: instance of org.apache.fop.fo.FOTreeHandler(id=591) - userAgent: instance of org.apache.fop.apps.FOUserAgent(id=592) - foTreeControl: instance of org.apache.fop.apps.Document(id=593) - class$org$apache$fop$fo$ElementMapping: instance of java.lang.Class(reflected class=org.apache.fop.fo.ElementMapping, id=450) -} -</screen> - - <screen> - treeBuilder.foInputHandler = { - collectStatistics: true - MEM_PROFILE_WITH_GC: false - runtime: instance of java.lang.Runtime(id=595) - pageCount: 0 - initialMemory: 0 - startTime: 0 - foTreeListeners: instance of java.util.HashSet(id=596) - org.apache.fop.fo.FOInputHandler.foTreeControl: instance of org.apache.fop.apps.Document(id=593) - org.apache.avalon.framework.logger.AbstractLogEnabled.m_logger: instance of org.apache.avalon.framework.logger.ConsoleLogger(id=597) -} -</screen> - - <screen> - treeBuilder.foTreeControl = "org.apache.fop.apps.Document@125844f" - treeBuilder.foInputHandler.foTreeListeners = "[org.apache.fop.apps.Document@125844f]" -</screen> - - <screen> - treeBuilder.userAgent = { - log: instance of org.apache.avalon.framework.logger.ConsoleLogger(id=597) - defaults: instance of java.util.HashMap(id=601) - handlers: instance of java.util.HashMap(id=602) - baseURL: "" - pdfEncryptionParams: null - px2mm: 0.35277778 -} -</screen> - - <screen> - treeBuilder.foTreeControl = { - driver: instance of org.apache.fop.apps.Driver(id=587) - usedFonts: instance of java.util.HashMap(id=604) - triplets: instance of java.util.HashMap(id=605) - fonts: instance of java.util.HashMap(id=606) - layoutStrategy: instance of org.apache.fop.layoutmgr.LayoutManagerLS(id=607) - areaTree: instance of org.apache.fop.area.AreaTree(id=608) - atModel: instance of org.apache.fop.area.RenderPagesModel(id=609) - bookmarks: null - idReferences: instance of java.util.HashSet(id=610) - foInputHandler: instance of org.apache.fop.fo.FOTreeHandler(id=591) -} -</screen> - - <screen> - treeBuilder.foTreeControl.driver = { - NOT_SET: 0 - RENDER_PDF: 1 - RENDER_AWT: 2 - RENDER_MIF: 3 - RENDER_XML: 4 - RENDER_PRINT: 5 - RENDER_PCL: 6 - RENDER_PS: 7 - RENDER_TXT: 8 - RENDER_SVG: 9 - RENDER_RTF: 10 - treeBuilder: instance of org.apache.fop.fo.FOTreeBuilder(id=588) - rendererType: 1 - renderer: instance of org.apache.fop.render.pdf.PDFRenderer(id=599) - foInputHandler: instance of org.apache.fop.fo.FOTreeHandler(id=591) - source: null - stream: instance of java.io.BufferedOutputStream(id=600) - reader: null - log: instance of org.apache.avalon.framework.logger.ConsoleLogger(id=597) - userAgent: instance of org.apache.fop.apps.FOUserAgent(id=592) - currentDocument: instance of org.apache.fop.apps.Document(id=593) -} -</screen> - - <screen> - treeBuilder.foTreeControl.areaTree = { - model: instance of org.apache.fop.area.RenderPagesModel(id=609) - atControl: instance of org.apache.fop.apps.Document(id=593) - idLocations: instance of java.util.HashMap(id=615) - resolve: instance of java.util.HashMap(id=616) - treeExtensions: instance of java.util.ArrayList(id=617) -} -</screen> - - <screen> - treeBuilder.foTreeControl.atModel = { - renderer: instance of org.apache.fop.render.pdf.PDFRenderer(id=599) - prepared: instance of java.util.ArrayList(id=618) - pendingExt: instance of java.util.ArrayList(id=619) - endDocExt: instance of java.util.ArrayList(id=620) - org.apache.fop.area.StorePagesModel.pageSequence: null - org.apache.fop.area.StorePagesModel.titles: instance of java.util.ArrayList(id=621) - org.apache.fop.area.StorePagesModel.currSequence: null - org.apache.fop.area.StorePagesModel.extensions: instance of java.util.ArrayList(id=622) -} -</screen> - - <screen> - treeBuilder.foTreeControl.atModel.renderer = { - MIME_TYPE: "application/pdf" - pdfDoc: instance of org.apache.fop.pdf.PDFDocument(id=624) - pages: null - pageReferences: instance of java.util.HashMap(id=625) - pvReferences: instance of java.util.HashMap(id=626) - ostream: instance of java.io.BufferedOutputStream(id=600) - pdfResources: null - currentStream: null - currentContext: null - currentPage: null - currentState: null - currentFontName: "" - currentFontSize: 0 - pageHeight: 0 - filterMap: null - textOpen: false - prevWordY: 0 - prevWordX: 0 - prevWordWidth: 0 - wordAreaPDF: instance of java.lang.StringBuffer(id=627) - BPMarginOffset: 0 - IPMarginOffset: 0 - org.apache.fop.render.PrintRenderer.fontInfo: instance of org.apache.fop.apps.Document(id=593) - org.apache.fop.render.PrintRenderer.fontList: null - org.apache.fop.render.AbstractRenderer.userAgent: instance of org.apache.fop.apps.FOUserAgent(id=592) - org.apache.fop.render.AbstractRenderer.producer: "FOP 1.0dev" - org.apache.fop.render.AbstractRenderer.creator: null - org.apache.fop.render.AbstractRenderer.creationDate: null - org.apache.fop.render.AbstractRenderer.options: instance of java.util.HashMap(id=629) - org.apache.fop.render.AbstractRenderer.currentBPPosition: 0 - org.apache.fop.render.AbstractRenderer.currentIPPosition: 0 - org.apache.fop.render.AbstractRenderer.currentBlockIPPosition: 0 - org.apache.fop.render.AbstractRenderer.containingBPPosition: 0 - org.apache.fop.render.AbstractRenderer.containingIPPosition: 0 - org.apache.avalon.framework.logger.AbstractLogEnabled.m_logger: instance of org.apache.avalon.framework.logger.ConsoleLogger(id=597) -} -</screen> - - <screen> - treeBuilder.foTreeControl.layoutStrategy = { - name: "layoutmgr" - addLMVisitor: null - org.apache.fop.layout.LayoutStrategy.name: "undefined" - org.apache.fop.layout.LayoutStrategy.document: instance of org.apache.fop.apps.Document(id=593) -} -</screen> - - <screen> - treeBuilder.foTreeControl.atModel.renderer.ostream = { - buf: instance of byte[512] (id=632) - count: 15 - java.io.FilterOutputStream.out: instance of java.io.FileOutputStream(id=633) -} -</screen> - - <para>For the members <literal>fontList<literal></literal>, -fonts</literal>, <literal>usedFonts<literal></literal> and -triplets<literal></literal> of treeBuilder.foTreeControl</literal>, -see under Fonts.</para> - </section> - - <section> - <title>A detailed overview of the entry methods</title> - - <para>Already created (e.g. in <literal>Fop.main</literal>): an -object of type <literal>Driver</literal> with the members -<literal>userAgent</literal>, <literal>renderer</literal>, -<literal>log</literal>, <literal>stream</literal>.</para> - - <para>To create <literal>userAgent</literal> one may use -<literal>Driver.getUserAgent</literal>: if <literal>driver</literal> -does not have <literal>userAgent</literal>, create a new -<literal>UserAgent</literal>.</para> - - <para>To create <literal>renderer</literal> one may use one of -three methods:<itemizedlist> - <listitem> - <simpara><literal>setRenderer(int -renderer)</literal></simpara> - </listitem> - <listitem> - <simpara><literal>setRenderer(String -rendererClassName)</literal></simpara> - </listitem> - <listitem> - <simpara><literal>setRenderer(Renderer -renderer)</literal></simpara> - </listitem> - </itemizedlist> All three methods set the FOP version on the -<literal>renderer</literal>, and register <literal>userAgent</literal> -with it, which is obtained using -<literal>Driver.getUserAgent</literal>.</para> - - <para><literal>render(InputHandler inputHandler)</literal>:<itemizedlist> - <listitem> - <simpara>creates <literal>XMLReader parser</literal>, -<literal>InputSource source</literal>;</simpara> - </listitem> - <listitem> - <simpara>calls <literal>render(XMLReader parser, -InputSource source)</literal>.</simpara> - </listitem> - </itemizedlist></para> - - <para><literal>render(org.w3c.dom.Document -document)</literal>:<itemizedlist> - <listitem> - <simpara>creates <literal>DocumentReader reader</literal>, -<literal>DocumentInputSource source</literal>;</simpara> - </listitem> - <listitem> - <simpara>calls <literal>render(XMLReader parser, -InputSource source)</literal>.</simpara> - </listitem> - </itemizedlist></para> - - <para><literal>render(XMLReader parser, InputSource -source)</literal>:<itemizedlist> - <listitem> - <simpara>creates content handler by calling -<literal>getContentHandler()</literal>.</simpara> - </listitem> - <listitem> - <simpara>registers the content handler with the parser.</simpara> - </listitem> - <listitem> - <simpara>Adds <literal>currentDocument</literal> as a tree -listener to <literal>foInputHandler</literal>.</simpara> - </listitem> - <listitem> - <simpara>calls <literal>parser.parse(source)</literal>.</simpara> - </listitem> - </itemizedlist></para> - - <para><literal>getContentHandler()</literal>:<itemizedlist> - <listitem> - <simpara>if driver does not have a -<literal>treeBuilder</literal>, call <literal>initialize()</literal>: -create a new <literal>TreeBuilder</literal>, set the -<literal>UserAgent</literal> on it.</simpara> - </listitem> - <listitem> - <simpara>if driver does not have a -<literal>currentDocument</literal>, create a new -<literal>Document</literal>.</simpara> - </listitem> - <listitem> - <simpara>create a new <literal>FOTreeHandler -foInputHandler</literal> using <literal>currentDocument</literal> as -an argument (<literal>currentDocument</literal> is member -<literal>foTreeControl</literal> in -<literal>foInputHandler</literal>).</simpara> - </listitem> - <listitem> - <simpara>create a new <literal>AreaTree</literal> using <literal>currentDocument</literal> as an argument, and -register it with <literal>currentDocument</literal>.</simpara> - </listitem> - <listitem> - <simpara>create a new <literal>RenderPagesModel</literal> -using <literal>renderer</literal> as an argument, and register it with -<literal>currentDocument</literal> and with -<literal>currentDocument.areaTree</literal>.</simpara> - </listitem> - <listitem> - <simpara>register <literal>currentDocument</literal> with -the <literal>renderer</literal> (<literal>currentDocument</literal> is -member <literal>fontInfo</literal> in <literal>renderer</literal>); -setup <literal>fontList</literal> in -<literal>currentDocument</literal>.</simpara> - </listitem> - <listitem> - <simpara>start the <literal>renderer</literal> with the -<literal>outputstream</literal>.</simpara> - </listitem> - <listitem> - <simpara>register <literal>foInputHandler</literal> with -<literal>currentDocument</literal>.</simpara> - </listitem> - <listitem> - <simpara>if <literal>currentDocument</literal> does not -have a <literal>layoutStrategy</literal>, create a new -<literal>LayoutStrategyLS</literal> for it with -<literal>currentDocument</literal> as an argument.</simpara> - </listitem> - <listitem> - <simpara>register <literal>userAgent</literal>, -<literal>foInputHandler</literal> and -<literal>currentDocument</literal> with <literal>treeBuilder</literal> -(<literal>currentDocument</literal> is member -<literal>foTreeControl</literal> in -<literal>treeBuilder</literal>).</simpara> - </listitem> - <listitem> - <simpara>return <literal>treeBuilder</literal>.</simpara> - </listitem> - </itemizedlist></para> - </section> - </chapter> - -<!-- Local Variables: --> -<!-- current-language-environment: UTF-8 --> -<!-- coding: utf-8 --> -<!-- default-input-method: TeX --> -<!-- End: --> diff --git a/src/documentation/content/xdocs/DnI/properties.xml b/src/documentation/content/xdocs/DnI/properties.xml deleted file mode 100644 index 8193b83e8..000000000 --- a/src/documentation/content/xdocs/DnI/properties.xml +++ /dev/null @@ -1,2456 +0,0 @@ -<?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$ --> - -<!-- -<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" - "docbookx.dtd"> - --> - - <chapter id="ch.properties"> - <title>Properties</title> - -<section> - <title>The basic setup of the property subsystem</title> - - <section> - <title>Property values</title> - -<para>The FO nodes in the FO tree contain property values as specified -by the user. Each property value is represented by a object of type -<literal>org.apache.fop.fo.Property</literal>, or of a subtype -thereof.</para> - -<para>There are various types of property values: -<literal>CharacterProperty</literal>, -<literal>ColorTypeProperty</literal>, -<literal>CondLengthProperty</literal>, -<literal>EnumProperty</literal>, <literal>KeepProperty</literal>, -<literal>LengthPairProperty</literal>, -<literal>LengthProperty</literal>, -<literal>LengthRangeProperty</literal>, -<literal>ListProperty</literal>, <literal>NCnameProperty</literal>, -<literal>NumberProperty</literal>, <literal>NumericProperty</literal>, -<literal>RelativeNumericProperty</literal>, -<literal>StringProperty</literal>. The type -<literal>ToBeImplementedProperty</literal> is used for properties that -are not yet implemented. Some of these types have subtypes: -<literal>AutoLength</literal>, <literal>FixedLength</literal>, -<literal>PercentLength</literal>, <literal>TableColLength</literal> -are subclasses of <literal>LengthProperty</literal>; -<literal>SpaceProperty</literal> is a subclass of -<literal>LengthRangeProperty</literal>. Each of these types is a -subtype of <literal>org.apache.fop.fo.Property</literal>. -</para> - - <para>Property values may implement one or more of the interfaces -defined in the package <literal>org.apache.fop.datatypes</literal>: -<literal>Numeric</literal>, <literal>Length</literal>, -<literal>ColorType</literal></para> - - <para>Some properties actually represent a set of properties, such -as a minimum, an optimum and a maximum. These are represented by a -property value which implements the -<literal>CompoundDatatype</literal> interface. They contain a property -value for each member property.</para> - - </section> - - <section> - <title>The property list of an FO node</title> - - <para>Property values are held by the FO node corresponding to -the fo element on which they are specified by the user. FO nodes -contain a property list of type <literal>PropertyList</literal>, which -extends <literal>HashMap</literal>.</para> - - <para>The property types are known by the property -name as used on the FO element, e.g. <literal>font-size</literal>. For -efficiency of implementation, each type of property type is also known by -an <literal>integer</literal>, the <literal>propID</literal>. The -<literal>propID</literal>s are defined in the interface -<literal>org.apache.fop.fo.Constants</literal>, which gives them a -symbolic name of the form <literal>PR_</literal> + property name in -capitals and spaces replaced by underscores, -e.g. <literal>PR_FONT_SIZE</literal>. Wherever possible, the code uses -the <literal>propID</literal>s instead of the property names.</para> - -<para>When an FO requests a property, it does so by -<literal>propId</literal>. The request is eventually answered by -<literal>PropertyList.getExplicitBaseProp</literal>, but before it can -do so, it has to retrieve the property name from -<literal>FOPropertyMapping.getPropertyName</literal>. A particular -inefficiency as a consequence is found in -<filename>FopPropValFunction.java</filename> and some other classes in -the <literal>fo.expr</literal> package: - -<screen> -return pInfo.getPropertyList().get(FOPropertyMapping.getPropertyId(propName)) -</screen> - -Here <literal>propName</literal> -> <literal>propId</literal> mapping -is done, which later is reverted again.</para> - -<screen> - [1] org.apache.fop.fo.FOPropertyMapping.getPropertyName (FOPropertyMapping.java:486) - [2] org.apache.fop.fo.PropertyList.getExplicitBaseProp (PropertyList.java:230) - [3] org.apache.fop.fo.Property$Maker.findProperty (Property.java:281) - [4] org.apache.fop.fo.Property$Maker.get (Property.java:314) - [5] org.apache.fop.fo.PropertyList.get (PropertyList.java:281) - [6] org.apache.fop.fo.PropertyList.get (PropertyList.java:267) - [7] org.apache.fop.fo.FObj.getProperty (FObj.java:261) -</screen> - - </section> - - <section> - <title>Property makers</title> - - <para>Property value objects are created by a property maker of -type <literal>org.apache.fop.fo.PropertyMaker</literal>, or of a -subtype thereof. For each property type there is a property maker -object, which knows the property type, its default value, and some -other characteristics.</para> - - <para>The types of property makers are: -<literal>CharacterProperty.Maker</literal>, -<literal>ColorTypeProperty.Maker</literal>, -<literal>CompoundPropertyMaker</literal>, -<literal>EnumProperty.Maker</literal>, -<literal>LengthProperty.Maker</literal>, -<literal>ListProperty.Maker</literal>, -<literal>NumberProperty.Maker</literal>, -<literal>StringProperty.Maker</literal>, and -<literal>ToBeImplementedProperty.Maker</literal>.</para> - -<para>The property makers are lazily constructed when the -<literal>FObj</literal> constructor wants to create its static member -<literal>propertyListTable</literal>. The constructor calls -<literal>FOPropertyMapping.getGenericMappings()</literal>, which -constructs and returns -<literal>Property.Maker[Constants.PROPERTY_COUNT+1] -s_generics</literal>. The FObj constructor then copies this array of -<literal>PropertyMaker</literal>s into -<literal>propertyListTable</literal>.</para> - - <para><literal>public static PropertyMaker[] -getGenericMappings()</literal> first creates the shorthand property -makers, so that they can be used in the creation of the makers of the -real properties, and a set of generic property makers, which act as -templates for the real property makers. Next it creates the makers for -all property types. Related property types are grouped, -e.g. <literal>createFontProperties()</literal>.</para> - - <para>An example is the creation of the maker for the -<literal>font-size</literal> property type: - -<screen> - m = new LengthProperty.Maker(PR_FONT_SIZE); - m.setInherited(true); - m.setDefault("12pt"); - m.setPercentBase(LengthBase.INH_FONTSIZE); - addPropertyMaker("font-size", m); -</screen> - -Since <literal>font-size</literal> is a length, its maker is a -<literal>LengthProperty.Maker</literal>. It is inherited, and its -default value is 12 pt. If the user specifies the -<literal>font-size</literal> value as a percentage, then the actual -value is calculated from the <literal>font-size</literal> value -inherited from the parent FO node.</para> - - </section> - - <section> - <title>Shorthand properties</title> - - <section> - <title>Overview</title> - - <para>Shorthand properties are properties which are shorthand -for a number of properties. In other words, they specify the value of -a number of properties in a single attribute. All shorthand properties -can take a list of values, which are space separated in the FO -file. The FO spec specifies how this list of values determines the -values of the properties for which this is the shorthand (the target -properties.). The length of the list of values for a single shorthand -property may vary. For each length the attribution of these values to -the target properties is different.</para> - - <para>When the FO tree is constructed, shorthand property -values are parsed and stored like any other property value. Because -the value can be a list, it is always of type -<literal>ListProperty</literal>.</para> - -<para>The meaning of shorthand properties is only dealt with when the -value of one of the target properties is retrieved. For that purpose -each target property maker knows the shorthand properties that may set -its value, and when the target property value is retrieved, its maker -checks with each of its shorthand property makers if it has a -value. Note that the value of a shorthand property is never retrieved -directly, because shorthand properties have no direct meaning for the -layout.</para> - - <para>When the shorthand property value has been retrieved, -the value for the target property must be extracted from the -list. That is done by a shorthand parser, which implements -<literal>ShorthandParser</literal>. There are two implementing types: -<literal>GenericShorthandParser</literal> and -<literal>BoxPropShorthandParser</literal>. Their method -<literal>convertValueForProperty</literal> knows how each specified value -determines the value of the possible target properties. A shorthand -parser object is added to the shorthand property maker when the maker -is created.</para> - - <para>Note that <literal>CompoundPropertyMaker</literal> also -has a member <literal>shorthandMaker</literal>. I am not sure if this -has anything to do with shorthand properties. It seems more related to -<literal>CompoundPropertyMaker</literal> delegating certain tasks to a -subproperty maker, viz. the one which is the -<literal>shorthandMaker</literal>.</para> - - - </section> - - <section> - <title>Example of a shorthand property</title> - - <para>The property <literal>margin</literal> is shorthand for -the four properties <literal>margin-top</literal>, -<literal>margin-right</literal>, <literal>margin-bottom</literal>, -<literal>margin-left</literal>. Its value can consist of 1 to 4 width -values.</para> - -<para>When the property maker for <literal>margin</literal> is -created, it gets a <literal>BoxPropShorthandParser</literal> as -shorthand parser: -<screen> -m = new ListProperty.Maker(PR_MARGIN); -m.setInherited(false); -m.setDefault(""); -m.setDatatypeParser(new BoxPropShorthandParser()); -m.setPercentBase(LengthBase.BLOCK_WIDTH); -addPropertyMaker("margin", m); -</screen> - -When the property maker for <literal>margin-top</literal> is created, -the <literal>margin</literal> maker is registered with it as a -shorthand maker: -<screen> -m = new LengthProperty.Maker(PR_MARGIN_TOP); -m.setInherited(false); -m.setDefault("0pt"); -m.addShorthand(s_generics[PR_MARGIN]); -m.setPercentBase(LengthBase.BLOCK_WIDTH); -addPropertyMaker("margin-top", m); -</screen> -</para> - - <para>The maker for <literal>border-top-width</literal> has -three shorthands: <literal>border-top</literal>, -<literal>border-width</literal>, and <literal>border</literal>: -<screen> - this.shorthands = instance of org.apache.fop.fo.properties.PropertyMaker[3] (id=772) - this.shorthands[0] = "org.apache.fop.fo.properties.ListProperty$Maker@1e1dadb" - this.shorthands[0].propId = 52 - this.shorthands[1] = "org.apache.fop.fo.properties.ListProperty$Maker@bac9b9" - this.shorthands[1].propId = 56 - this.shorthands[2] = "org.apache.fop.fo.properties.ListProperty$Maker@8ceeea" - this.shorthands[2].propId = 18 -</screen></para> - - </section> - - <section> - <title>Parsing a shorthand property</title> - - <para>The value of a shorthand property is parsed and the value of a -target property is extracted in this call stack: - -<screen> - [1] org.apache.fop.fo.BoxPropShorthandParser.convertValueForProperty (BoxPropShorthandParser.java:80) - [2] org.apache.fop.fo.GenericShorthandParser.getValueForProperty (GenericShorthandParser.java:93) - [3] org.apache.fop.fo.properties.PropertyMaker.getShorthand (PropertyMaker.java:617) - [4] org.apache.fop.fo.properties.PropertyMaker.findProperty (PropertyMaker.java:277) - [5] org.apache.fop.fo.properties.PropertyMaker.get (PropertyMaker.java:305) - [6] org.apache.fop.fo.PropertyList.get (PropertyList.java:282) - [7] org.apache.fop.fo.PropertyList.get (PropertyList.java:268) - [8] org.apache.fop.fo.PropertyManager.getMarginProps (PropertyManager.java:301) -</screen> -</para> - - <para>The extraction proceeds as follows: -<itemizedlist spacing="compact"> - <listitem> - <para><literal>PropertyMaker.getShorthand</literal> -<itemizedlist spacing="compact"> - <listitem> - <para><literal>parser.getValueForProperty(propId, -listprop, propertyMaker, propertyList)</literal>; -<literal>propId</literal> is the ID of the target property, -<literal>listprop</literal> is the shorthand property value, of type -<literal>ListProperty</literal>, which was retrieved <itemizedlist -spacing="compact"> - <listitem> - <para>if the shorthand value is -<literal>inherit</literal>, get the value for the target property from -the parent.</para> - </listitem> - <listitem> - <para>else -<literal>convertValueForProperty(propId, listProperty, maker, -propertyList)</literal> <itemizedlist spacing="compact"> - <listitem> - <para>get from the shorthand list of -values the value that corresponds to the target property</para> - </listitem> - <listitem> - <para>if the retrieved value is not -<literal>null</literal>, convert the property, -<literal>maker.convertShorthandProperty(propertyList, p, -null)</literal> <itemizedlist spacing="compact"> - <listitem> - <para>first try to convert it in -the normal way: <literal>maker.convertProperty(prop, propertyList, -fo)</literal></para> - </listitem> - <listitem> - <para>if this gives a -<literal>null</literal> value, test if the value is an enumerated -value or a keyword; if so, process it.</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - - </section> - - </section> - - <section> - <title>Corresponding properties</title> - - <para>A number of traits can be specified by two alternative -properties, e.g. <literal>border-left-width</literal> and -<literal>border-start-width</literal>. These are called corresponding -properties. One of a pair of corresponding properties is an absolute -property, the other is a relative property. The meaning of the -relative property depends on the writing mode. When the value of a -property is retrieved that has a corresponding property, the value of -that corresponding property should also be taken into account.</para> - - <para>Corresponding properties are registered with the property -maker when it is created: - -<screen> -bwm = new BorderWidthPropertyMaker(PR_BORDER_LEFT_WIDTH); -bwm.useGeneric(genericBorderWidth); -bwm.setBorderStyleId(PR_BORDER_LEFT_STYLE); -bwm.addShorthand(s_generics[PR_BORDER_LEFT]); -bwm.addShorthand(s_generics[PR_BORDER_WIDTH]); -bwm.addShorthand(s_generics[PR_BORDER]); -corr = new CorrespondingPropertyMaker(bwm); -corr.setCorresponding(PR_BORDER_START_WIDTH, PR_BORDER_END_WIDTH, - PR_BORDER_AFTER_WIDTH); -addPropertyMaker("border-left-width", bwm); -</screen> - -There are always three corresponding properties, for the three writing -modes <literal>lr_tb</literal>, <literal>rl_tb</literal>, -<literal>tb_rl</literal>, in this order: - -<screen> - corr = { - baseMaker: instance of org.apache.fop.fo.properties.BorderWidthPropertyMaker(id=702) - lr_tb: 50 - rl_tb: 36 - tb_rl: 22 - useParent: false - relative: false -} -</screen> -</para> - - <para>When a property value is retrieved, the value of the -corresponding property may have priority. This is determined by the -method <literal>corresponding.isCorrespondingForced()</literal>. This -is true if -<itemizedlist spacing="compact"> - <listitem> - <para>this is a relative property</para> - </listitem> - <listitem> - <para>and the corresponding property has been explicitly -specified on this FO node</para> - </listitem> - </itemizedlist> -Relative properties are marked by the fact that their corresponding -property maker has its member <literal>relative</literal> set to -<literal>true</literal>; this is set when the property is -created.</para> - - <para>If the corresponding property has priority, its value is -computed. Otherwise, if the value of the property itself has been -explicitly specified on this FO node, it is used. Otherwise, the -corresponding property is computed. Computation in this connection -means that also the shorthand properties are checked.</para> - -<para>Because shorthand properties only exist for absolute properties, -the values are effectively checked in this order: -<itemizedlist spacing="compact"> - <listitem> - <para>An absolute property <itemizedlist spacing="compact"> - <listitem> - <para>The explicit value of this property.</para> - </listitem> - <listitem> - <para>The explicit value of the corresponding -property.</para> - </listitem> - <listitem> - <para>The value of this property from the shorthand -properties.</para> - </listitem> - </itemizedlist></para> - </listitem> - - <listitem> - <para>A relative property <itemizedlist spacing="compact"> - <listitem> - <para>The explicit value of the corresponding -property.</para> - </listitem> - <listitem> - <para>The explicit value of this property.</para> - </listitem> - <listitem> - <para>The value of the corresponding property from -the shorthand properties.</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist> -</para> - - </section> - - <section> - <title>Mapping between property names, IDs and makers</title> - -<para>The property subsystem is set up in the class -<literal>FOPropertyMapping</literal>. It creates a property maker -object for each property type, and it creates mappings of -the names, IDs and makers of the property types. It holds the -following static maps: - -<screen> -property name <=> property ID => property maker - | | - s_htSubPropNames (<-) s_htGeneric - s_htPropIds (->) -</screen> - -Each type of FObj holds a copy of <literal>s_htGeneric</literal> as -its static member <literal>FObj.propertyListTable</literal>. According -to design documents an FObj type may have its own specific makers for -certain property types. Probably this is the reason that -<literal>FObj</literal> holds its own copy of the list of makers. This -allows subclasses to hold their own modified copy. As far as I know, -this is not currently the case.</para> - -<para>The mappings are filled in the static method - -<screen> - private static void addPropertyMaker(String name, Property.Maker maker) { - s_generics[maker.getPropId()] = maker; - s_htPropNames.put(name, new Integer(maker.getPropId())); - s_htPropIds.put(new Integer(maker.getPropId()), name); - } -</screen> - -which is called for each property type.</para> - -<para>The constants for property IDs are defined in the interface -<literal>org.apache.fop.fo.Constants</literal>: - -<screen> - int PR_ABSOLUTE_POSITION = 1; - int PR_ACTIVE_STATE = 2; - ... - int PR_FONT_SIZE = 94; - ... - int PROPERTY_COUNT = 247; -</screen> -</para> - -<para>Composite properties are defined by a compound number: - -<screen> - int COMPOUND_SHIFT = 9; - int CP_MAXIMUM = 5 << COMPOUND_SHIFT; - int CP_MINIMUM = 6 << COMPOUND_SHIFT; - int CP_OPTIMUM = 7 << COMPOUND_SHIFT; - ... -</screen> -</para> - - <para>Enumerated property values are also defined here: - -<screen> - int ABSOLUTE = 1; - int ABSOLUTE_COLORMETRIC = 2; - ... - int VISIBLE = 105; - int WRAP = 106; -</screen></para> - - <para>For fast access to important characteristic of property -inheritance, <literal>PropertyList</literal> maintains a static array -<literal>boolean[Constants.PROPERTY_COUNT + 1] -inheritableProperty</literal>, which lists for each property type if -it is inherited. It is constructed by asking the maker of each -property type if it is inherited.</para> - -<para>A few members of the array of <literal>PropertyMaker</literal>s -<literal>s_generics</literal>. It is indexed by the -<literal>propID</literal>. Member 0 is <literal>null</literal>, and -serves for unknown property types. Member 1 is for -<literal>absolute-position</literal>, member 94 for -<literal>font-size</literal>. - -<screen> -main[1] print org.apache.fop.fo.FOPropertyMapping.s_generics - org.apache.fop.fo.FOPropertyMapping.s_generics = instance of org.apache.fop.fo.Property$Maker[248] (id=651) -main[1] print org.apache.fop.fo.FOPropertyMapping.s_generics[0] - org.apache.fop.fo.FOPropertyMapping.s_generics[0] = null -main[1] print org.apache.fop.fo.FOPropertyMapping.s_generics[1] - org.apache.fop.fo.FOPropertyMapping.s_generics[1] = "org.apache.fop.fo.EnumProperty$Maker@12884e0" -main[1] print org.apache.fop.fo.FOPropertyMapping.s_generics[94] - org.apache.fop.fo.FOPropertyMapping.s_generics[94] = "org.apache.fop.fo.LengthProperty$Maker@32efa7" -</screen> -</para> - - <para>A few members of the mapping <literal>s_htPropIds</literal> -from <literal>propID</literal> to property name. The -<literal>s_htPropIds</literal> for compound properties are shifted: - -<screen> -main[1] print org.apache.fop.fo.FOPropertyMapping.s_htPropIds - org.apache.fop.fo.FOPropertyMapping.s_htPropIds = "{ - 1=absolute-position - ... - 94=font-size - ... - 247=z-index - 512=block-progression-direction - 1024=conditionality - ... - 5632=within-page - }" -</screen> -</para> - -<para>A few members of the mappings <literal>s_htPropNames</literal> -and <literal>s_htSubPropNames</literal> from property name to -<literal>propID</literal>. The <literal>propIds</literal> for -compound properties are shifted: - -<screen> -main[1] print org.apache.fop.fo.FOPropertyMapping.s_htPropNames - org.apache.fop.fo.FOPropertyMapping.s_htPropNames = "{ - absolute-position=1 - ... - font-size=94 - ... - z-index=247 - }" -</screen> - -<screen> -main[1] print org.apache.fop.fo.FOPropertyMapping.s_htSubPropNames - org.apache.fop.fo.FOPropertyMapping.s_htSubPropNames = "{ - block-progression-direction=512 - conditionality=1024 - ... - within-page=5632 - }" -</screen> -</para> - - </section> - - <section> - <title>Storing the property values based on their -<literal>PropID</literal></title> - - <para>The class <literal>PropertySets</literal> contains a setup -by which property values may be retrieved by their -<literal>PropId</literal> instead of their name. In this setup -<literal>PropertyList</literal> no longer extends -<literal>HashMap</literal> but contains an array of property objects, -called <literal>values</literal>. In order to prevent that each FObj -should contain an array of size -<literal>Constants.PROPERTY_COUNT</literal>, a mapping is setup from a -static array for all FO types and all property types to an index for -the possible properties of an FO type, -<literal>PropertySets.mapping</literal>.</para> - -<para><literal>PropertySets.mapping</literal> is a -<literal>short[Constants.ELEMENT_COUNT+1][]</literal> matrix, which -for each FO type contains a mapping from <literal>PropID</literal> to -a sparse array of indices, which enumerates the properties that are -valid for this FO type.</para> - -<para>For an element <literal>fo:bar</literal> which supports 2 -properties, <literal>foo</literal>, whose <literal>PropID</literal> is -21, and <literal>baz</literal>, whose <literal>PropID</literal> is -137, the array of indices has the values - -<screen> - indices[21] = 1 - indices[137] = 2 -</screen> - -and all other values are 0. Here indices denotes the row in -<literal>mapping</literal> which corresponds to FO type bar.</para> - -<para>The values are indices into the array -<literal>PropertyList.values</literal>, which then looks like this: - -<screen> - values[0] = null // always null. - values[1] = reference to a 'foo' Property instance - values[2] = reference to a 'baz' Property instance -</screen> -</para> - -<para>Example of <literal>PropertySets.mapping</literal>: - -<screen> -PropID -> | 0 1 2 3 4 5 ... (Contants.PR_XXX) -Element | | - v | ------------------|-------------------------------------------------- -FO_BASIC_LINK | 2 0 1 0 2 0 -FO_BIDI_OVERRIDE | 3 0 0 1 2 3 -FO_BLOCK | 2 1 0 0 2 0 -... | .... - | -</screen> -</para> - -<para>A property value of an <literal>FONode</literal> can then be -retrieved as <literal>PropertyList.values[indices[propId]]</literal>, -where <literal>indices = PropertySets.getPropertySet(elementId) = -PropertySets.mapping[elementId].</literal></para> - -<para>The matrix <literal>PropertySets.mapping</literal> is -constructed in the routine -<literal>PropertySets.initialize()</literal>.</para> - -<para>First it constructs the <literal>elements</literal> array. For -each FO type this array contains an <literal>Element</literal> -object. This object contains a list of properties which are valid for -this type of FO, and a list of child <literal>Element</literal> -objects. Each child <literal>Element</literal> object corresponds to -an FO type that may occur as a child of this FO type.</para> - -<para>Then the <literal>for (boolean dirty = true; dirty; )</literal> -loop is executed. It effect is as follows (from an email by Finn -Bock). For each FO type the <literal>BitSet</literal> of allowed -properties is merged with the <literal>BitSet</literal> of allowed -properties of its possible direct children. When for any FO type the -<literal>merge</literal> subroutine modifies its -<literal>BitSet</literal>, it sets the boolean variable -<literal>dirty</literal> to <literal>true</literal> to signal that -another iteration of the loop is required. By iterating over the loop -until no further modifications are made, one makes sure that the -merging process propagates from below to the top, that is, from any FO -type to its farthest possible ancestor. This ensures that every FO -type registers the allowed properties of itself and of all FO types -that may ever appear in its subtree.</para> - -<para>The matrix <literal>PropertySets.mapping</literal> is still not -used in <literal>PropertyList</literal>, and the array -<literal>values</literal> does not yet exist (19 May 2004). The -properties are held by name in <literal>PropertyList</literal>, which -extends <literal>HashMap</literal>.</para> - - </section> - - </section> - - <section id="sec.properties.create"> - <title>Creating a property value</title> - - <section> - <title>General</title> - - <para>A property value is created by the maker for the property type, -in its method -<literal>PropertyMaker.make(PropertyList, String, FObj)</literal>, -where the second argument is the property value as a string: -<itemizedlist spacing="compact"> - <listitem> - <para>If the specified value is <literal>inherit</literal>, -get the property value from the parent FObj.</para> - </listitem> - <listitem> - <para>Else if the value is an enumerated value, the corresponding -property value is retrieved (for each possible enumerated value only -one property value object exists, of type EnumProperty).</para> - </listitem> - <listitem> - <para>If this does not retrieve a property value, <itemizedlist -spacing="compact"> - <listitem> - <para>If the value is a shorthand keyword, it is -converted to the corresponding value.</para> - </listitem> - <listitem> - <para>The value is parsed, and a property value is -created.</para> - </listitem> - <listitem> - <para>The method -<literal>PropertyMaker.convertProperty</literal> is called, which is overridden -in subclasses of PropertyMaker. CompoundPropertyMaker uses this method -to convert the simple property value constructed to a compound -property value: <itemizedlist spacing="compact"> - <listitem> - <para>Make a compound property value based on -default values: <literal>PropertyMaker.makeCompound</literal>, -overridden in CompoundPropertyMaker.</para> - </listitem> - <listitem> - <para>Set all components equal to the -simple property value that is being converted.</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>If this is a compound property maker, convert it to -a compound property as above. (Is this the second time the property -value is converted?)</para> - </listitem> - </itemizedlist> -The property may also record the value as specified in the fo element, -as this may influence the traits of the areas created by this FO node -and FO nodes in the subtree.</para> - -<para>Subclasses of <literal>PropertyMaker</literal> may override this -method. For example, <literal>StringProperty.Maker</literal> has a -much simpler method.</para> - -<para>Attributes of the fo elements are converted to property value -objects in <literal>PropertyList.convertAttributeToProperty</literal>: -<itemizedlist spacing="compact"> - <listitem> - <para>If the property is not a component of a compound -property, <itemizedlist spacing="compact"> - <listitem> - <para>Ask the maker for the property to create the -property value.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Else if the property is a component of a compound -property, <itemizedlist spacing="compact"> - <listitem> - <para>Find the base property by a call to -<literal>Propertylist.findBaseProperty</literal>: <itemizedlist - spacing="compact"> - <listitem> - <para>If the base property value already exists, -return it to <literal>convertAttributeToProperty</literal>.</para> - </listitem> - <listitem> - <para>If the base attribute is also specified -(later) in the list of attributes, retrieve it, ask the maker for the -base property to create the base property value, and return it to -<literal>convertAttributeToProperty</literal>.</para> - </listitem> - <listitem> - <para>Return -null to <literal>convertAttributeToProperty</literal>.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Ask the maker for the subproperty to create the -subproperty value by a call to <literal>PropertyMaker.make(Property, -int, PropertyList, String, FObj)</literal>, where the second argument -is the subproperty ID and the fourth argument is the specified -value. This method is overridden in -<literal>CompoundPropertyMaker</literal>: <itemizedlist -spacing="compact"> - <listitem> - <para>If the base property value does not yet -exist, ask its maker to create it with default values for the -components: <literal>PropertyMaker.makeCompound</literal>, which is -overridden in <literal>CompoundPropertyMaker</literal>: <itemizedlist -spacing="compact"> - <listitem> - <para>Create an empty property value.</para> - </listitem> - <listitem> - <para>Create property values for the -subproperties with default values, and insert them into the compound -property value.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Create the specified subproperty value and -insert it into the compound property value, where it replaces the -default subproperty value.</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>Add the property to the property list. -</para> - </listitem> - </itemizedlist></para> - - </section> - - <section> - <title>Example of a compound property</title> - -<para>In this example we illustrate the case where first the -base attribute of a compound property is specified, and then the -attribute for one of the components.</para> - -<para>First the user specifies the attribute value -<literal>leader-length="120pt"</literal>.</para> - -<para>A simple length property value is constructed first: -<screen> - p.getClass() = "class org.apache.fop.fo.properties.FixedLength" - p = { - millipoints: 120000 - org.apache.fop.fo.properties.Property.specVal: null -} - p = "120000mpt" -</screen></para> - -<para>Then it is converted into a compound property value. First a -compound property with default component values is created: -<screen> - p.getClass() = "class org.apache.fop.fo.properties.LengthRangeProperty" - p = { - minimum: instance of org.apache.fop.fo.properties.FixedLength(id=759) - optimum: instance of org.apache.fop.fo.properties.FixedLength(id=760) - maximum: instance of org.apache.fop.fo.properties.PercentLength(id=761) - bfSet: 0 - bChecked: true - org.apache.fop.fo.properties.Property.specVal: null -} - p = "LengthRange[min:0mpt, max:100.0%, opt:12000mpt]" -</screen> - -Then all components are set equal to the simple property value: -<screen> - prop.getClass() = "class org.apache.fop.fo.properties.LengthRangeProperty" - prop = { - minimum: instance of org.apache.fop.fo.properties.FixedLength(id=744) - optimum: instance of org.apache.fop.fo.properties.FixedLength(id=744) - maximum: instance of org.apache.fop.fo.properties.FixedLength(id=744) - bfSet: 7 - bChecked: true - org.apache.fop.fo.properties.Property.specVal: null -} - prop = "LengthRange[min:120000mpt, max:120000mpt, opt:120000mpt]" -</screen></para> - -<para>The property makers involved: -<screen> - this = "org.apache.fop.fo.properties.LengthRangeProperty$Maker@55a338" - this.subproperties = instance of org.apache.fop.fo.properties.PropertyMaker[11] (id=766) - getSubpropMaker(org.apache.fop.fo.Constants.CP_MINIMUM) = "org.apache.fop.fo.properties.LengthProperty$Maker@955cd5" - getSubpropMaker(org.apache.fop.fo.Constants.CP_MAXIMUM) = "org.apache.fop.fo.properties.LengthProperty$Maker@1bde4" - getSubpropMaker(org.apache.fop.fo.Constants.CP_OPTIMUM) = "org.apache.fop.fo.properties.LengthProperty$Maker@a77106" -</screen></para> - -<para>Stack dump when making the compound property: -<screen> - [1] org.apache.fop.fo.properties.CompoundPropertyMaker.makeCompound (CompoundPropertyMaker.java:258) - [2] org.apache.fop.fo.properties.CompoundPropertyMaker.convertProperty (CompoundPropertyMaker.java:173) - [3] org.apache.fop.fo.properties.LengthRangeProperty$Maker.convertProperty (LengthRangeProperty.java:68) - [4] org.apache.fop.fo.properties.PropertyMaker.make (PropertyMaker.java:392) - [5] org.apache.fop.fo.properties.CompoundPropertyMaker.make (CompoundPropertyMaker.java:206) - [6] org.apache.fop.fo.PropertyList.convertAttributeToProperty (PropertyList.java:418) - [7] org.apache.fop.fo.PropertyList.addAttributesToList (PropertyList.java:374) - [8] org.apache.fop.fo.FObj.addProperties (FObj.java:133) - [9] org.apache.fop.fo.FObj.processNode (FObj.java:96) - [10] org.apache.fop.fo.FOTreeBuilder.startElement (FOTreeBuilder.java:234) -</screen> -</para> - -<para>Subsequently, the user specifies a component, -<literal>leader-length.maximum="200pt"</literal>.</para> - -<para>First the subproperty is constructed as a simple length property: -<screen> - p.getClass() = "class org.apache.fop.fo.properties.FixedLength" - p = { - millipoints: 200000 - org.apache.fop.fo.properties.Property.specVal: null -} - p = "200000mpt" -</screen> -</para> - - <para>Then it is added to the compound property as the component -<literal>maximum</literal>: -<screen> - prop.getClass() = "class org.apache.fop.fo.properties.LengthRangeProperty" - prop = { - minimum: instance of org.apache.fop.fo.properties.FixedLength(id=755) - optimum: instance of org.apache.fop.fo.properties.FixedLength(id=755) - maximum: instance of org.apache.fop.fo.properties.FixedLength(id=767) - bfSet: 7 - bChecked: true - org.apache.fop.fo.properties.Property.specVal: null -} - prop = "LengthRange[min:120000mpt, max:200000mpt, opt:120000mpt]" -</screen> -</para> - -<para>Stack dump when making the property: -<screen> - [1] org.apache.fop.fo.properties.PropertyMaker.make (PropertyMaker.java:378) - [2] org.apache.fop.fo.properties.CompoundPropertyMaker.make (CompoundPropertyMaker.java:235) - [3] org.apache.fop.fo.PropertyList.convertAttributeToProperty (PropertyList.java:423) - [4] org.apache.fop.fo.PropertyList.addAttributesToList (PropertyList.java:374) - [5] org.apache.fop.fo.FObj.addProperties (FObj.java:133) - [6] org.apache.fop.fo.FObj.processNode (FObj.java:96) - [7] org.apache.fop.fo.FOTreeBuilder.startElement (FOTreeBuilder.java:234) -</screen></para> - - </section> - -<section> - <title>Enumerated property values</title> - - <para>The interface <literal>Constants</literal> defines values -for each possible enumerated value of a property: -<screen> - int ABSOLUTE = 1; - int ABSOLUTE_COLORMETRIC = 2; - ... - int VISIBLE = 105; - int WRAP = 106; -</screen></para> - - <para>In <literal>FOPropertyMapping</literal> a property value -object is constructed for each possible enumerated value. See the -<literal>Property</literal> array <literal>enums</literal> and the -method <literal>makeEnumProperty</literal>. During its construction, -each property maker that can have enumerated values gets a member -<literal>enums</literal>, which, for each of its possible enumerated -values, gets a reference to the appropriate enumerated property value -object. See the method <literal>PropertyMaker.addEnum</literal>.</para> - - <para>Example: The properties <literal>hyphenate</literal> and -<literal>precedence</literal> both have the possible value -<literal>true</literal>. Their makers have a reference to the same -property value object: -<screen> - org.apache.fop.fo.FOPropertyMapping.s_generics - [org.apache.fop.fo.Constants.PR_HYPHENATE]. - enums.get("true").hashCode() = 9236202 - org.apache.fop.fo.FOPropertyMapping.s_generics - [org.apache.fop.fo.Constants.PR_PRECEDENCE]. - enums.get("true").hashCode() = 9236202 - org.apache.fop.fo.FOPropertyMapping.s_generics - [org.apache.fop.fo.Constants.PR_HYPHENATE].enums.get("true") = "100" - org.apache.fop.fo.FOPropertyMapping.s_generics - [org.apache.fop.fo.Constants.PR_HYPHENATE].enums.get("true") = { - value: 100 - org.apache.fop.fo.properties.Property.specVal: null -} -</screen></para> - -<para>Example: <literal>leader-pattern="rule"</literal>. -<screen> - this = "org.apache.fop.fo.properties.EnumProperty$Maker@25c828" - this.enums = "{rule=82, use-content=104, dots=21, space=88}" - this.enums.get("rule").getClass() = "class org.apache.fop.fo.properties.EnumProperty" - this.enums.get("rule") = "82" - this.enums.get("rule") = { - value: 82 - org.apache.fop.fo.properties.Property.specVal: null -} -</screen></para> - -<para>The maker's method <literal>checkEnumValues</literal> returns -the appropriate property value object -<literal>enums.get(value)</literal>: <literal>newProp = -"82"</literal>.</para> - - <screen> - [1] org.apache.fop.fo.properties.PropertyMaker.checkEnumValues (PropertyMaker.java:480) - [2] org.apache.fop.fo.properties.EnumProperty$Maker.checkEnumValues (EnumProperty.java:50) - [3] org.apache.fop.fo.properties.PropertyMaker.make (PropertyMaker.java:383) - [4] org.apache.fop.fo.PropertyList.convertAttributeToProperty (PropertyList.java:418) - [5] org.apache.fop.fo.PropertyList.addAttributesToList (PropertyList.java:374) -</screen> - - </section> - -<section> - <title>Example of a property with keywords</title> - -<para>The value of the property <literal>border-top-width</literal> -can be set to a width, but it can also be indicated by one of the -keywords <literal>thin</literal>, <literal>medium</literal> and -<literal>thick</literal>. The width values to which these keywords -correspond are by default set by the implementation. When the property -maker is constructed in <literal>FOPropertyMapping</literal>, it gets -a hash map of keyword values. -<screen> - this = "org.apache.fop.fo.properties.BorderWidthPropertyMaker@1cf4a2c" - this.propId = 55 - this.keywords = "{medium=1pt, thin=0.5pt, thick=2pt}" -} -</screen> -</para> - -<para>The method <literal>checkValueKeywords</literal> returns the -mapped value: <literal>value = "1pt"</literal>. Subsequently a -property value object is created as if that value had been specified. - - <screen> - [1] org.apache.fop.fo.properties.PropertyMaker.checkValueKeywords (PropertyMaker.java:499) - [2] org.apache.fop.fo.properties.PropertyMaker.make (PropertyMaker.java:387) - [3] org.apache.fop.fo.PropertyList.convertAttributeToProperty (PropertyList.java:418) - [4] org.apache.fop.fo.PropertyList.addAttributesToList (PropertyList.java:374) - [5] org.apache.fop.fo.FObj.addProperties (FObj.java:133) -</screen> -</para> - - </section> - - <section> - <title>Parsing a property with an absolute value</title> - - <para>Property values are parsed in -<literal>PropertyParser.parseProperty</literal>: - <screen> - [1] org.apache.fop.fo.expr.PropertyParser.parseProperty (PropertyParser.java:111) - [2] org.apache.fop.fo.expr.PropertyParser.parse (PropertyParser.java:88) - [3] org.apache.fop.fo.properties.PropertyMaker.make (PropertyMaker.java:389) - [4] org.apache.fop.fo.PropertyList.convertAttributeToProperty (PropertyList.java:418) - [5] org.apache.fop.fo.PropertyList.addAttributesToList (PropertyList.java:374) - [6] org.apache.fop.fo.FObj.addProperties (FObj.java:133) -</screen></para> - - <para>Example: <literal><fo:simple-page-master -master-name="simpleA4" margin="4pt"></literal>, property being parsed: -<literal>margin="4pt"</literal>, <literal>propId</literal> = 134.</para> - -<para>The PropertyParser object: -<screen> - this = "org.apache.fop.fo.expr.PropertyParser@8530b8" - this = { - propInfo: instance of org.apache.fop.fo.expr.PropertyInfo(id=729) - org.apache.fop.fo.expr.PropertyTokenizer.currentToken: 0 - org.apache.fop.fo.expr.PropertyTokenizer.currentTokenValue: null - org.apache.fop.fo.expr.PropertyTokenizer.currentUnitLength: 0 - org.apache.fop.fo.expr.PropertyTokenizer.currentTokenStartIndex: 0 - org.apache.fop.fo.expr.PropertyTokenizer.expr: "4pt" - org.apache.fop.fo.expr.PropertyTokenizer.exprIndex: 0 - org.apache.fop.fo.expr.PropertyTokenizer.exprLength: 3 - org.apache.fop.fo.expr.PropertyTokenizer.recognizeOperator: false -} -</screen></para> - - <para>It has a member of type <literal>PropertyInfo</literal>, -which contains contextual information: -<screen> - propInfo = "org.apache.fop.fo.expr.PropertyInfo@1abcc03" - propInfo = { - maker: instance of org.apache.fop.fo.properties.ListProperty$Maker(id=705) - plist: instance of org.apache.fop.fo.PropertyList(id=737) - fo: instance of org.apache.fop.fo.pagination.LayoutMasterSet(id=738) - stkFunction: null -} -</screen> -<literal>fo</literal> is the parent FO.</para> - -<para>The property list of the current FO node: -<screen> - propInfo.plist = { - writingModeTable: null - writingMode: 0 - inheritableProperty: null - parentPropertyList: instance of org.apache.fop.fo.PropertyList(id=743) - namespace: "http://www.w3.org/1999/XSL/Format" - elementName: "fo:simple-page-master" - fobj: instance of org.apache.fop.fo.pagination.SimplePageMaster(id=746) -} -</screen> -The property list up to now: -<screen> - propInfo.plist = "{master-name=simpleA4}" -</screen> -</para> - - <para>Property <literal>master-name</literal>'s maker is -<literal>StringPropertyMaker</literal>, which does not parse its -value.</para> - - <para>PropertyParser.parseProperty <itemizedlist -spacing="compact"> - <listitem> - <para>next(), which scans the next token; at its return: -<screen> - this = { - propInfo: instance of org.apache.fop.fo.expr.PropertyInfo(id=667) - org.apache.fop.fo.expr.PropertyTokenizer.currentToken: 12 - org.apache.fop.fo.expr.PropertyTokenizer.currentTokenValue: "4pt" - org.apache.fop.fo.expr.PropertyTokenizer.currentUnitLength: 2 - org.apache.fop.fo.expr.PropertyTokenizer.currentTokenStartIndex: 0 - org.apache.fop.fo.expr.PropertyTokenizer.expr: "4pt" - org.apache.fop.fo.expr.PropertyTokenizer.exprIndex: 3 - org.apache.fop.fo.expr.PropertyTokenizer.exprLength: 3 - org.apache.fop.fo.expr.PropertyTokenizer.recognizeOperator: true -} -</screen> -i.e. the whole expression is a single token, it is of type -<literal>PropertyTokenizer.TOK_NUMERIC</literal> (= 12), the unit is 2 -chars long.</para> - </listitem> - <listitem> - <para>Loop forever. <itemizedlist -spacing="compact"> - <listitem> - <para>Analyse the expression. Start with -<literal>parseAdditiveExpr</literal> <itemizedlist spacing="compact"> - <listitem> - <para><literal>parseMultiplicativeExpr</literal> -<itemizedlist spacing="compact"> - <listitem> - <para><literal>parseUnaryExpr</literal> -<itemizedlist spacing="compact"> - <listitem> - <para><literal>parsePrimaryExpr</literal>; -the unit may be a relative unit (em) which must be resolved against -the font size <itemizedlist spacing="compact"> - <listitem> - <para>construct a property -value object: -<screen> - prop = "4000mpt" - prop.getClass() = "class org.apache.fop.fo.properties.FixedLength" -</screen></para> - </listitem> - <listitem> - <para><literal>next()</literal>: -scan the next token; -<screen> - this = { - propInfo: instance of org.apache.fop.fo.expr.PropertyInfo(id=729) - org.apache.fop.fo.expr.PropertyTokenizer.currentToken: 0 - org.apache.fop.fo.expr.PropertyTokenizer.currentTokenValue: null - org.apache.fop.fo.expr.PropertyTokenizer.currentUnitLength: 2 - org.apache.fop.fo.expr.PropertyTokenizer.currentTokenStartIndex: 3 - org.apache.fop.fo.expr.PropertyTokenizer.expr: "4pt" - org.apache.fop.fo.expr.PropertyTokenizer.exprIndex: 3 - org.apache.fop.fo.expr.PropertyTokenizer.exprLength: 3 - org.apache.fop.fo.expr.PropertyTokenizer.recognizeOperator: true -} -</screen> -the next token is of type <literal>currentToken = -PropertyTokenizer.TOK_EOF</literal>.</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>If <literal>currentToken = -PropertyTokenizer.TOK_EOF</literal>, break the loop.</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist> -Return the property: <literal>p = "4000mpt"</literal>.</para> - </section> - - </section> - -<section> - <title>Retrieving a property value</title> - - <section> - <title>Overview</title> - - <para>For all FO types the FO spec specifies a large number of -property types for which the user may specify a value in order to -modify the resulting layout of the document. Many of these properties -have a default value, many others inherit their value from the parent -FO if they are not specified. In principle the layout process must -retrieve the value of each possible property type of an FO node in -order to determine the appropriate value of the corresponding -trait.</para> - - <para>Retrieving a property value goes through these steps: -<itemizedlist spacing="compact"> - <listitem> - <para>First determine if the property value was specified -in one or other way. This is done in the method -<literal>propertyMaker.findProperty</literal> <itemizedlist -spacing="compact"> - <listitem> - <para>if this property has a corresponding property -and if the corresponding property is forced, i.e. if this property is -relative and if a value for the corresponding property was explicitly -specified, compute and return it.</para> - </listitem> - <listitem> - <para>else <itemizedlist spacing="compact"> - <listitem> - <para>if a value for this property was -explicitly specified, compute and return it</para> - </listitem> - <listitem> - <para>else if this property has a -corresponding property, compute its value; if it is not null return -it</para> - </listitem> - <listitem> - <para>else if a value for a relevant shorthand -property was specified, compute and return it</para> - </listitem> - <listitem> - <para>else if this property is inheritable, -find it at the parent; this repeats the whole process on the parent, -and possibly its parents, up to the root node; if successful, return -the found property value</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>If no property value is found, a default property -value object is made; the default value is stored in the property -maker as <literal>defaultValue</literal>: <itemizedlist -spacing="compact"> - <listitem> - <para>if the default property value object was -calculated earlier, it was cached as -<literal>defaultProperty</literal>; return it</para> - </listitem> - <listitem> - <para>else make it in the same way as property value -objects are made when the FO tree is constructed, in -<literal>propertyMaker.make</literal>.</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - - <para>Compute corresponding, as used in -<literal>findProperty</literal>, proceeds as follows: <itemizedlist -spacing="compact"> - <listitem> - <para>use parent's property list or this property -list?</para> - </listitem> - <listitem> - <para>check explicit or shorthand for corresponding</para> - </listitem> - <listitem> - <para>convert property</para> - </listitem> - </itemizedlist></para> - -<para><literal>PropertyManager</literal>, -<literal>CommonBorderAndPadding</literal>, -<literal>CommonBackground</literal>, -<literal>CommonMarginBlock</literal>, -<literal>CommonHyphenation</literal> are convenience classes used in -the calculation of the traits. <literal>PropertyManager</literal> has -methods to return objects of these types. A -<literal>CommonBorderAndPadding</literal> object and a -<literal>CommonHyphenation</literal> object are cached. A -<literal>CommonBackground</literal> object and a -<literal>CommonMarginBlock</literal> object are calculated when -requested. Similarly for many other convenience classes -<literal>Common*</literal> for which -<literal>PropertyManager</literal> can return an object. These classes -are in package <literal>fo.properties</literal>. Similar classes -called <literal>*Props</literal> are in package -<literal>traits</literal>. Of these <literal>PropertyManager</literal> -can only return a <literal>BlockProps</literal> object.</para> - - </section> - - <section> - <title>Detailed overview</title> - - <para>The retrieval of a property value is started with a call -to <literal>PropertyList.get(int propId)</literal>, which calls -<literal>PropertyList.get(propId, true, true)</literal>.</para> - -<para><literal>PropertyList.get(int propId, boolean bTryInherit, -boolean bTryDefault)</literal>: -<itemizedlist spacing="compact"> - <listitem> - <para>Find the maker for this property as -<literal>FObj.propertyListTable[propId]</literal>, variable -<literal>propertyMaker</literal></para> - </listitem> - <listitem> - <para><literal>propertyMaker.get(int subpropId, -PropertyList propertyList, boolean bTryInherit, boolean -bTryDefault)</literal> <itemizedlist spacing="compact"> - <listitem> - <para><literal>propertyMaker.findProperty(PropertyList -propertyList, boolean bTryInherit)</literal> <itemizedlist -spacing="compact"> - <listitem> - <para>if corresponding and corresponding is -forced <itemizedlist spacing="compact"> - <listitem> - <para>evaluate condition: -<literal>CorrespondingPropertyMaker.isCorrespondingForced -(PropertyList propertyList)</literal> <itemizedlist spacing="compact"> - <listitem> - <para> <itemizedlist -spacing="compact"> - <listitem> - <para>return false if this is -not a relative property -(<literal>corresponding.relative</literal>)</para> - </listitem> - <listitem> - <para>return true if -corresponding property was explicitly specified on this node or on its -parent, depending on the type of property -(<literal>corresponding.useParent</literal>)</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para><literal>corresponding.compute(PropertyList -propertyList)</literal>; this subroutine and the subroutines it calls -refer to the corresponding property <itemizedlist spacing="compact"> - <listitem> - <para><literal>propertyList.getExplicitOrShorthand(correspondingId)</literal>; -propertyList is that of this node or of the parent, depending on the -type of property (corresponding.useParent) <itemizedlist -spacing="compact"> - <listitem> - <para><literal>propertyList.getExplicitBaseProp(int -correspondingId)</literal> (see below)</para> - </listitem> - <listitem> - <para>if -<literal>(null)</literal> <literal>propertyList.getShorthand(int -correspondingId)</literal> <itemizedlist spacing="compact"> - <listitem> - <para><literal>propertyMaker.getShorthand(this)</literal> -(see below)</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>if <literal>(not -null)</literal> convert property</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>else <itemizedlist spacing="compact"> - <listitem> - <para><literal>propertyList.getExplicitBaseProp(int -propId)</literal> from <literal>propertyList</literal> as a hash map; -note that this requires a conversion from <literal>propId</literal> to -<literal>propName</literal> via <literal>s_htPropNames</literal>; -example: <literal>propertyList = -"{master-name=simpleA4}"</literal></para> - </listitem> - <listitem> - <para>if <literal>(null)</literal> -<literal>propertyMaker.compute(PropertyList propertyList)</literal>: -<itemizedlist spacing="compact"> - <listitem> - <para>if -<literal>(corresponding)</literal> -<literal>corresponding.compute(PropertyList propertyList)</literal>, -as above</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>if <literal>(null)</literal> -<literal>propertyMaker.getShorthand(PropertyList -propertyList)</literal> <itemizedlist spacing="compact"> - <listitem> - <para>if -<literal>(maker.shorthands)</literal> then for each shorthand -<itemizedlist spacing="compact"> - <listitem> - <para><literal>propertyList.getExplicit(int -shorthand.propId)</literal>; a shorthand must be -<literal>ListProperty</literal></para> - </listitem> - <listitem> - <para>if <literal>(not -null)</literal> parse the shorthand property value, -<literal>parser.getValueForProperty(propId, listprop, propertyMaker, -this, propertyList)</literal>; here <literal>propId</literal> is the -<literal>propId</literal> of this property, not of the shorthand; a -shorthand may contain values for several properties, and this method -retrieves the value for the current property; if <literal>(not -null)</literal> return it</para> - </listitem> - </itemizedlist>Note: the first -shorthand property maker in <literal>maker.shorthands</literal> that -returns a good property is used</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>if <literal>(null && -bTryInherit)</literal> -<literal>propertyMaker.findProperty(parentPropertyList, -true)</literal>: the whole process is repeated on the parent, and -possibly its parents, up to the root node.</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>if <literal>(null && bTryDefault)</literal> -<literal>propertyMaker.make(PropertyList propertyList)</literal> -<itemizedlist spacing="compact"> - <listitem> - <para>if there is a cached value, -<literal>defaultProperty</literal>, return it</para> - </listitem> - <listitem> - <para><literal>propertyMaker.make(PropertyList -propertyList, String value, FObj fo)</literal>; -<literal>value</literal> is the default value stored in the property -maker, <literal>fo</literal> is the parent FO <itemizedlist -spacing="compact"> - <listitem> - <para>if default value is -<literal>inherit</literal>, -propertyList.getFromParent(<literal>propId</literal>) -<itemizedlist spacing="compact"> - <listitem> - <para>if -<literal>(parentPropertyList != null)</literal> -<literal>parentPropertyList.get(propId)</literal>; the whole process -is repeated on the parent, and possibly its parents, up to the root -node.</para> - </listitem> - <listitem> - <para><literal>propertyMaker.make(PropertyList -propertyList)</literal>; this seems to create an endless recursion; -<literal>parentPropertyList == null</literal> in the root node.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>else check enumerated values -<literal>propertyMaker.checkEnumValues(value)</literal>: get the -enumerated property from <literal>propertyMaker.enums</literal></para> - </listitem> - <listitem> - <para>if <literal>(null)</literal> -<itemizedlist spacing="compact"> - <listitem> - <para><literal>propertyMaker.checkValueKeywords(String -value)</literal>; check if the value is a keyword in -<literal>propertyMaker.keywords</literal>; if so, substitute the value -with the value for which the keyword stands</para> - </listitem> - <listitem> - <para>parse the value <literal>p = -PropertyParser.parse(pvalue, new PropertyInfo(propertyMaker, -propertyList, fo))</literal></para> - </listitem> - <listitem> - <para>convert the property -<literal>propertyMaker.convertProperty(p, propertyList, -fo)</literal></para> - </listitem> - <listitem> - <para>if <literal>(null)</literal> -throw <literal>org.apache.fop.fo.expr.PropertyException</literal>, -which immediately is catched and rethrown as -<literal>FOPException</literal> (why?)</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>catch <literal>FOPException</literal>; this -means that this method may return a <literal>null</literal> -property</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>catch <literal>FOPException</literal>; this means that -this method may return a <literal>null</literal> property</para> - </listitem> - </itemizedlist></para> - - <para>The call stack at the <literal>findProperty</literal> and -<literal>make</literal>calls is: -<screen> - [1] org.apache.fop.fo.properties.PropertyMaker.findProperty (PropertyMaker.java:240) - [2] org.apache.fop.fo.properties.PropertyMaker.get (PropertyMaker.java:282) - [3] org.apache.fop.fo.PropertyList.get (PropertyList.java:252) - [4] org.apache.fop.fo.PropertyList.get (PropertyList.java:238) - [5] org.apache.fop.fo.FObj.getProperty (FObj.java:163) - [6] org.apache.fop.layoutmgr.PageLayoutManager.createPageAreas (PageLayoutManager.java:745) -</screen> -<screen> - [1] org.apache.fop.fo.properties.PropertyMaker.make (PropertyMaker.java:387) - [2] org.apache.fop.fo.properties.PropertyMaker.make (PropertyMaker.java:369) - [3] org.apache.fop.fo.properties.PropertyMaker.get (PropertyMaker.java:285) - [4] org.apache.fop.fo.PropertyList.get (PropertyList.java:252) - [5] org.apache.fop.fo.PropertyList.get (PropertyList.java:238) - [6] org.apache.fop.fo.FObj.getProperty (FObj.java:163) - [7] org.apache.fop.layoutmgr.PageLayoutManager.createPageAreas (PageLayoutManager.java:745) -</screen> -For properties whose maker is compound property maker: -<screen> - [1] org.apache.fop.fo.properties.PropertyMaker.findProperty (PropertyMaker.java:240) - [2] org.apache.fop.fo.properties.PropertyMaker.get (PropertyMaker.java:282) - [3] org.apache.fop.fo.properties.CompoundPropertyMaker.get (CompoundPropertyMaker.java:146) - [4] org.apache.fop.fo.PropertyList.get (PropertyList.java:252) - [5] org.apache.fop.fo.PropertyList.get (PropertyList.java:238) - [6] org.apache.fop.fo.flow.Leader.getLength (Leader.java:135) - [7] org.apache.fop.layoutmgr.AddLMVisitor.getLeaderAllocIPD (AddLMVisitor.java:305) - [8] org.apache.fop.layoutmgr.AddLMVisitor$2.getAllocationIPD (AddLMVisitor.java:290) - [9] org.apache.fop.layoutmgr.LeafNodeLayoutManager.getNextBreakPoss (LeafNodeLayoutManager.java:143) -</screen></para> - - </section> - - <section> - <title>Examples: Retrieving border and padding values</title> - -<para>In this section we follow in detail how the border and padding -values for the body region are retrieved. The relevant part of the -input FO file is: - -<screen> -<![CDATA[<fo:simple-page-master master-name="simpleA4" margin="4pt"> -<fo:region-body margin="4pt+20%" border="3pt solid black" - border-before-width="2pt" border-right-width="4pt" - border-start-width="inherit"/> -</fo:simple-page-master>]]> -</screen> -</para> - - <para>This section was written after I added the cache to the -look-up of property values.</para> - - <section> - - <title>Retrieving the <literal>margin-top</literal> value on -<literal>region-body</literal></title> - -<para>This what we are retrieving: - -<screen> - propertyList.getFOName() = "fo:region-body" - org.apache.fop.fo.FOPropertyMapping.getPropertyName(propId) = "margin-top" -</screen> - -The margin values are retrieved by the method -<literal>PropertyManager.getMarginProps</literal>. This is the call -stack that leads up to it and on to the retrieval of the value of -<literal>margin-top</literal>: - -<screen> - [1] org.apache.fop.fo.properties.PropertyMaker.findProperty (PropertyMaker.java:240) - [2] org.apache.fop.fo.PropertyList.findProperty (PropertyList.java:289) - [3] org.apache.fop.fo.properties.PropertyMaker.get (PropertyMaker.java:291) - [4] org.apache.fop.fo.PropertyList.get (PropertyList.java:261) - [5] org.apache.fop.fo.PropertyList.get (PropertyList.java:247) - [6] org.apache.fop.fo.PropertyManager.getMarginProps (PropertyManager.java:264) - [7] org.apache.fop.fo.pagination.RegionBody.getViewportRectangle (RegionBody.java:58) - [8] org.apache.fop.layoutmgr.PageLayoutManager.makeRegionViewport (PageLayoutManager.java:811) - [9] org.apache.fop.layoutmgr.PageLayoutManager.createPageAreas (PageLayoutManager.java:784) - [10] org.apache.fop.layoutmgr.PageLayoutManager.createPage (PageLayoutManager.java:721) - [11] org.apache.fop.layoutmgr.PageLayoutManager.makeNewPage (PageLayoutManager.java:441) - [12] org.apache.fop.layoutmgr.PageLayoutManager.doLayout (PageLayoutManager.java:191) -</screen> -</para> - -<para>The retrieval proceeds as follows: -<itemizedlist spacing="compact"> -<listitem> -<para><literal>PropertyList.findProperty</literal>: Is the value in -the cache? No.</para> -</listitem> -<listitem> -<para><literal>PropertyMaker.findProperty</literal>: -<literal>corresponding != null</literal>? No.</para> -</listitem> -<listitem> -<para><literal>PropertyMaker.findProperty</literal>: Is this property -explicitly specified? No.</para> -</listitem> -<listitem> -<para><literal>PropertyMaker.findProperty</literal>: Can the -corresponding property be computed? No, there is no corresponding -property.</para> -</listitem> -<listitem> -<para><literal>PropertyMaker.findProperty</literal>: Is a shorthand -property for this property specified? Yes, <literal>margin</literal> -is a shorthand for it. The property value is retrieved as: -<screen> - listprop = "[(4000mpt +20.0%)]" -</screen> -It is a list property as are all shorthand properties. The -value for <literal>margin-top</literal> is extracted from it as: -<screen> - p = "(4000mpt +20.0%)" -</screen> -</para> -</listitem> -<listitem> -<para><literal>PropertyList.findProperty</literal>: Add the value to -the cache.</para> -</listitem> - </itemizedlist> -</para> - </section> - - <section> - <title>Retrieving the <literal>border-before-style</literal> -value on <literal>region-body</literal></title> - -<para>This what we are retrieving: - -<screen> - propertyList.getFOName() = "fo:region-body" - org.apache.fop.fo.FOPropertyMapping.getPropertyName(propId) = "border-before-style" -</screen> - -The border values are retrieved by the method -<literal>PropertyManager.getBorderAndPadding</literal>. This is the call -stack that leads up to it and on to the retrieval of the value of -<literal>border-before-style</literal>: - -<screen> - [1] org.apache.fop.fo.properties.PropertyMaker.findProperty (PropertyMaker.java:240) - [2] org.apache.fop.fo.PropertyList.findProperty (PropertyList.java:289) - [3] org.apache.fop.fo.properties.PropertyMaker.get (PropertyMaker.java:291) - [4] org.apache.fop.fo.PropertyList.get (PropertyList.java:261) - [5] org.apache.fop.fo.PropertyList.get (PropertyList.java:247) - [6] org.apache.fop.fo.PropertyManager.initBorderInfo (PropertyManager.java:155) - [7] org.apache.fop.fo.PropertyManager.getBorderAndPadding (PropertyManager.java:143) - [8] org.apache.fop.fo.PropertyManager.getMarginProps (PropertyManager.java:289) - [9] org.apache.fop.fo.pagination.RegionBody.getViewportRectangle (RegionBody.java:58) - [10] org.apache.fop.layoutmgr.PageLayoutManager.makeRegionViewport (PageLayoutManager.java:811) - [11] org.apache.fop.layoutmgr.PageLayoutManager.createPageAreas (PageLayoutManager.java:784) - [12] org.apache.fop.layoutmgr.PageLayoutManager.createPage (PageLayoutManager.java:721) - [13] org.apache.fop.layoutmgr.PageLayoutManager.makeNewPage (PageLayoutManager.java:441) - [14] org.apache.fop.layoutmgr.PageLayoutManager.doLayout (PageLayoutManager.java:191) -</screen> -</para> - -<para>The retrieval proceeds as follows: -<itemizedlist spacing="compact"> -<listitem> -<para><literal>PropertyList.findProperty</literal>: Is the value in -the cache? No.</para> -</listitem> -<listitem> -<para><literal>PropertyMaker.findProperty</literal>: -<literal>corresponding != null</literal>, but -<literal>corresponding.isCorrespondingForced()</literal> returns -<literal>false</literal>. The corresponding property is -<literal>border-top-style</literal>, which is not specified: - -<screen> - org.apache.fop.fo.FOPropertyMapping.getPropertyName(correspondingId) = "border-top-style" -</screen> -This is the corresponding property maker: -<screen> - this = { - baseMaker: instance of org.apache.fop.fo.properties.EnumProperty$Maker(id=816) - lr_tb: 54 - rl_tb: 54 - tb_rl: 43 - useParent: false - relative: true -} -</screen> -</para> - </listitem> -<listitem> -<para><literal>PropertyMaker.findProperty</literal>: Is this property -explicitly specified? No.</para> -</listitem> -<listitem> -<para><literal>PropertyMaker.findProperty</literal>: Can the -corresponding property be computed? Yes, it can be derived from the -property <literal>border</literal>, which is a shorthand for the -corresponding property <literal>border-top-style</literal>. The -returned value is <literal>87</literal>, which stands for -<literal>SOLID</literal>.</para> -<para>Note that the shorthand was not used in the -computation of -<literal>corresponding.isCorrespondingForced()</literal>, but it is in -the computation of the specified value of the corresponding -property.</para> -</listitem> -<listitem> -<para><literal>PropertyList.findProperty</literal>: Add the value to -the cache.</para> -</listitem> - </itemizedlist></para> - </section> - - <section> - <title>Retrieving the <literal>border-before-width</literal> -value on <literal>region-body</literal></title> - -<para>This what we are retrieving: - -<screen> - propertyList.getFOName() = "fo:region-body" - org.apache.fop.fo.FOPropertyMapping.getPropertyName(propId) = "border-before-width" -</screen> - -The border values are retrieved by the method -<literal>PropertyManager.getBorderAndPadding</literal>. This is the call -stack that leads up to it and on to the retrieval of the value of -<literal>border-before-width</literal>: - -<screen> -main[1] where - [1] org.apache.fop.fo.properties.PropertyMaker.findProperty (PropertyMaker.java:240) - [2] org.apache.fop.fo.PropertyList.findProperty (PropertyList.java:289) - [3] org.apache.fop.fo.properties.PropertyMaker.get (PropertyMaker.java:291) - [4] org.apache.fop.fo.properties.CompoundPropertyMaker.get (CompoundPropertyMaker.java:146) - [5] org.apache.fop.fo.PropertyList.get (PropertyList.java:261) - [6] org.apache.fop.fo.PropertyList.get (PropertyList.java:247) - [7] org.apache.fop.fo.PropertyManager.initBorderInfo (PropertyManager.java:157) - [8] org.apache.fop.fo.PropertyManager.getBorderAndPadding (PropertyManager.java:143) - [9] org.apache.fop.fo.PropertyManager.getMarginProps (PropertyManager.java:289) - [10] org.apache.fop.fo.pagination.RegionBody.getViewportRectangle (RegionBody.java:58) - [11] org.apache.fop.layoutmgr.PageLayoutManager.makeRegionViewport (PageLayoutManager.java:811) - [12] org.apache.fop.layoutmgr.PageLayoutManager.createPageAreas (PageLayoutManager.java:784) - [13] org.apache.fop.layoutmgr.PageLayoutManager.createPage (PageLayoutManager.java:721) - [14] org.apache.fop.layoutmgr.PageLayoutManager.makeNewPage (PageLayoutManager.java:441) - [15] org.apache.fop.layoutmgr.PageLayoutManager.doLayout (PageLayoutManager.java:191) -</screen> - -The difference with the call stack for -<literal>border-before-style</literal> is that -<literal>border-before-width</literal> is a compound property, with -a <literal>minimum</literal>, an <literal>optimum</literal> and a -<literal>maximum</literal> value. -</para> - -<para>The retrieval proceeds as follows: -<itemizedlist spacing="compact"> -<listitem> -<para><literal>PropertyList.findProperty</literal>: Is the value in -the cache? No.</para> -</listitem> - <listitem> -<para><literal>PropertyMaker.findProperty</literal>: -<literal>corresponding != null</literal>, but -<literal>corresponding.isCorrespondingForced()</literal> returns -<literal>false</literal>. The corresponding property is -<literal>border-top-width</literal>, which is not specified: - -<screen> - org.apache.fop.fo.FOPropertyMapping.getPropertyName(correspondingId) = "border-top-width" -</screen> -</para> - </listitem> - <listitem> - <para><literal>PropertyMaker.findProperty</literal>: Is -this property explicitly specified? Yes. The property value is -retrieved as: -<screen> - p = "CondLength[2000mpt]" -</screen> -The specified value was <literal>2pt</literal>. When this attribute -value was added to the property list, it was converted to a -<literal>CondLength</literal> type. -</para> - </listitem> - -<listitem> -<para><literal>PropertyList.findProperty</literal>: Add the value to -the cache.</para> -</listitem> - </itemizedlist> -</para> - </section> - - <section> - <title>Retrieving the <literal>border-end-width</literal> -value on <literal>region-body</literal></title> - -<para>This what we are retrieving: - -<screen> - propertyList.getFOName() = "fo:region-body" - org.apache.fop.fo.FOPropertyMapping.getPropertyName(propId) = "border-end-width" -</screen> - -The border values are retrieved by the method -<literal>PropertyManager.getBorderAndPadding</literal>. The call stack -that leads up to it and on to the retrieval of the value of -<literal>border-end-width</literal> is identical to the call stack for -<literal>border-before-width</literal>. -</para> - -<para>The retrieval proceeds as follows: -<itemizedlist spacing="compact"> -<listitem> -<para><literal>PropertyList.findProperty</literal>: Is the value in -the cache? No.</para> -</listitem> -<listitem> -<para><literal>PropertyMaker.findProperty</literal>: -<literal>corresponding != null</literal>, and -<literal>corresponding.isCorrespondingForced()</literal> returns -<literal>true</literal>. The corresponding property is -<literal>border-right-width</literal>, which is explicitly specified: - -<screen> - org.apache.fop.fo.FOPropertyMapping.getPropertyName(correspondingId) = "border-right-width" -</screen> -</para> - </listitem> -<listitem> -<para><literal>PropertyMaker.findProperty</literal>: Compute the -corresponding property value. It is retrieved as: -<screen> - p = "CondLength[discard, 4000mpt]" -</screen> -The specified value was <literal>4pt</literal>. When this attribute -value was added to the property list, it was converted to a -<literal>CondLength</literal> type.</para> - </listitem> -<listitem> -<para><literal>PropertyList.findProperty</literal>: Add the value to -the cache.</para> -</listitem> - </itemizedlist> -</para> - </section> - - </section> - - </section> - -<!-- -The implementation before bug 26778: Properties leader-length - -leader-length.maximum="30%" -leader-length.minimum="20%" -leader-length.optimum="25%" - -basePropertyName = "leader-length" -subPropertyName = "maximum" -propId = 124 -subpropId = 2560 - -main[1] where - [1] org.apache.fop.fo.flow.Leader.getLength (Leader.java:167) - [2] org.apache.fop.layoutmgr.AddLMVisitor.getLeaderAllocIPD (AddLMVisitor.java:361) - [3] org.apache.fop.layoutmgr.AddLMVisitor$2.getAllocationIPD (AddLMVisitor.java:342) - [4] org.apache.fop.layoutmgr.LeafNodeLayoutManager.getNextBreakPoss (LeafNodeLayoutManager.java:166) - [5] org.apache.fop.layoutmgr.LineLayoutManager.getNextBreakPoss (LineLayoutManager.java:215) - [6] org.apache.fop.layoutmgr.BlockLayoutManager.getNextBreakPoss (BlockLayoutManager.java:240) - [7] org.apache.fop.layoutmgr.FlowLayoutManager.getNextBreakPoss (FlowLayoutManager.java:111) - [8] org.apache.fop.layoutmgr.PageLayoutManager.getNextBreakPoss (PageLayoutManager.java:261) - [9] org.apache.fop.layoutmgr.PageLayoutManager.doLayout (PageLayoutManager.java:226) - -propId = Constants.PR_LEADER_LENGTH | Constants.CP_MAXIMUM - = 2684 = 124 + 2560 - -In this older implementation the base value is obtained from the -layout context and propagated to the calculation: - -LeafNodeLayoutManager.getNextBreakPoss: - ipd = getAllocationIPD(context.getRefIPD()); -AddLMVisitor.getLeaderAllocIPD: - node.getLength(Constants.PR_LEADER_LENGTH | Constants.CP_MAXIMUM, ipd); -Leader.getLength: - length = (int)(((PercentLength) maxlength).value() * dim); - -This is wrong because it does not find out at which node the property -is specified and from which node the base length should be -obtained. In the new implementation LengthBase contains this -information as member parentFO: -main[1] dump maxlength - maxlength = { - factor: 0.3 - lbase: instance of org.apache.fop.datatypes.LengthBase(id=773) - org.apache.fop.fo.properties.Property.specVal: null -} -main[1] dump maxlength.lbase - maxlength.lbase = { - parentFO: instance of org.apache.fop.fo.flow.Block(id=776) - propertyList: instance of org.apache.fop.fo.PropertyList(id=777) - iBaseType: 3 -} - -Result: -ipd = "MinOptMax: min=67520; opt=84400; max=101280" ---> - - <section> - <title>Percent-based and mixed property values</title> - - <section> - <title>Overview</title> - - <para>Properties may have relative values, expressed as a -percentage. The value is relative to a trait of the layout. Therefore -relative values can only be evaluated when the layout is -created. The FO tree must store them as an expression.</para> - - <para>The FO spec specifies for each property that can have a -relative value, which trait is the basis for the evaluation of the -relative value. FOP maintains that information in the property maker, -in its member <literal>percentBase</literal>. This is set when the -maker is created, see <literal>FOPropertyMapping</literal>.</para> - - <para>When the maker creates a relative property value object, -it stores its own member <literal>percentBase</literal> in the -property as member <literal>iBaseType</literal>. In this way the -property value contains the information that is needed at layout time to -find the trait that is the basis for the calculation of the actual -value.</para> - - <para>The possible values of the member -<literal>percentBase</literal> are listed in class -<literal>LengthBase</literal>. Both the interface -<literal>PercentBase</literal> and the class -<literal>LengthBase</literal> define static constants which are used -as types. The difference is as follows (from an email by Finn Bock, -edited by me): The idea is that the <literal>PercentBase.XXX</literal> -types name the stored values and the <literal>LengthBase.XXX</literal> -types name the algorithms for looking up a base value. Most of the -time these map one-to-one to each other, but for some I imaged that -they would be different. For example, <literal>margin-top</literal> -should really use an algorithm like -<literal>BLOCK_IPD_OR_PAGEHEIGHT</literal>, which would look for -either <literal>PercentBase.BLOCK_IPD</literal> or -<literal>PercentBase.PAGE_HEIGHT</literal>, depending on the FO -element.</para> - - <para>A <literal>LengthBase</literal> object contains a -reference to a parent FO node and a reference to a property list. In -this manner the <literal>LengthBase</literal> value contains the -information that is needed at layout time to locate the FO node or -property list which contains the trait that is the basis for the -calculation of the actual value, irrespective of the FO node at which -the property is resolved.</para> - - <para>The method <literal>LengthBase.getBaselength</literal> -uses the base type, member <literal>iBaseType</literal>, to determine -relative to which layout trait the value should be resolved. If the -trait is a property value, it is retrieved from the property list, in -the usual manner. If it is a layout dimension, it is taken from the -parent FO.</para> - - <para>The interface <literal>Numeric</literal>, which is -implemented by all classes that can participate in numeric operations, -uses the notion of <literal>dimension</literal>, which denotes the -type of numeric: for integers <literal>dimension = 0</literal>, for -lengths <literal>dimension = 1</literal>.</para> - - <para>The constructor of -<literal>RelativeNumericProperty</literal> calculates the dimension of -the new property value object as a combination of the dimensions of -the operands, depending on the operation: -<itemizedlist spacing="compact"> - <listitem> - <para>multiplication adds dimensions: 0+0=0, 0+1=1+0=1,</para> - </listitem> - <listitem> - <para>division subtracts dimensions: 0-0=0, 1-0=1, 1-1=0,</para> - </listitem> - <listitem> - <para>other (addition, subtraction) does not change the -dimensions</para> - </listitem> - </itemizedlist></para> - - <para>A <literal>RelativeProperty</literal> contains the -operation between the operands in its member -<literal>operation</literal>. It is an integer. Names for the possible -integer values are listed as static members of class -<literal>RelativeProperty</literal>.</para> - - <para>Relative and mixed property values are retrieved in the -usual manner. After retrieval they must be resolved against the -relevant layout traits. This happens in the method -<literal>getValue</literal> of <literal>Property</literal> and its -subclasses.</para> - - <para>A <literal>RelativeNumericProperty</literal> is resolved -as follows: <itemizedlist spacing="compact"> - <listitem> - <para><literal>RelativeNumericProperty.getValue</literal> -<itemizedlist spacing="compact"> - <listitem> - <para><literal>RelativeNumericProperty.getNumericValue</literal> -<itemizedlist spacing="compact"> - <listitem> - <para><literal>RelativeNumericProperty.getResolved</literal>. -This evaluates the expression tree by recursion. The nodes in the tree -are <literal>RelativeNumericProperty</literal> objects. The leaf nodes -are <literal>FixedLength</literal> and -<literal>PercentLength</literal> objects. On each node -<literal>getNumericValue</literal> is called. <itemizedlist -spacing="compact"> - <listitem> - <para>The relative numeric property -values call <literal>getResolved</literal> again, which descends the -tree and calls <literal>getNumericValue</literal> on its child -nodes.</para> - </listitem> - <listitem> - <para>The fixed lengths return their -millipoints.</para> - </listitem> - <listitem> - <para>The percent lengths return -<literal>factor * lbase.getBaseLength()</literal> <itemizedlist -spacing="compact"> - <listitem> - <para><literal>factor</literal> is -a member of the percent length object.</para> - </listitem> - <listitem> - <para><literal>LengthBase.getBaselength</literal> -gets the base length from the parent FO <itemizedlist spacing="compact"> - <listitem> - <para><literal>FObj.getLayoutDimension</literal>. -The value is retrieved from the <literal>Map -layoutDimension</literal>. If that does not contain the desired layout -dimension, then its parent is consulted, all the way up to -<literal>fo:root</literal>.</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - - </section> - - <section> - <title>Parsing a mixed property value</title> - - <para>Example: <literal><fo:region-body -margin="4pt+20%"/></literal>, property being parsed: -<literal>margin="4pt+20%"</literal>, <literal>propId</literal> = -134.</para> - -<para><literal>PropertyParser.parseProperty</literal> -<itemizedlist spacing="compact"> - <listitem> - <para><literal>next()</literal>, which scans the next token; -at its return: -<screen> - this = { - propInfo: instance of org.apache.fop.fo.expr.PropertyInfo(id=736) - org.apache.fop.fo.expr.PropertyTokenizer.currentToken: 12 - org.apache.fop.fo.expr.PropertyTokenizer.currentTokenValue: "4pt" - org.apache.fop.fo.expr.PropertyTokenizer.currentUnitLength: 2 - org.apache.fop.fo.expr.PropertyTokenizer.currentTokenStartIndex: 0 - org.apache.fop.fo.expr.PropertyTokenizer.expr: "4pt+20%" - org.apache.fop.fo.expr.PropertyTokenizer.exprIndex: 3 - org.apache.fop.fo.expr.PropertyTokenizer.exprLength: 7 - org.apache.fop.fo.expr.PropertyTokenizer.recognizeOperator: true -} -</screen> -i.e. the whole expression is a single token, it is of type -<literal>PropertyTokenizer.TOK_NUMERIC</literal> (= 12), the unit is -2 chars long.</para> - </listitem> - <listitem> - <para>Loop forever. <itemizedlist spacing="compact"> - <listitem> - <para>Analyse the expression. Start with -<literal>parseAdditiveExpr</literal> <itemizedlist spacing="compact"> - <listitem> - <para><literal>parseMultiplicativeExpr</literal> -<itemizedlist spacing="compact"> - <listitem> - <para><literal>parseUnaryExpr</literal> -<itemizedlist spacing="compact"> - <listitem> - <para><literal>parsePrimaryExpr</literal>; -the unit may be a relative unit (em) which must be resolved against -the font size <itemizedlist spacing="compact"> - <listitem> - <para>construct a property -value object: -<screen> -prop = "4000mpt" -prop.getClass() = "class org.apache.fop.fo.properties.FixedLength" -</screen></para> - </listitem> - <listitem> - <para><literal>next()</literal>: -scan for the next token; -<screen> - this = { - propInfo: instance of org.apache.fop.fo.expr.PropertyInfo(id=736) - org.apache.fop.fo.expr.PropertyTokenizer.currentToken: 8 - org.apache.fop.fo.expr.PropertyTokenizer.currentTokenValue: null - org.apache.fop.fo.expr.PropertyTokenizer.currentUnitLength: 2 - org.apache.fop.fo.expr.PropertyTokenizer.currentTokenStartIndex: 3 - org.apache.fop.fo.expr.PropertyTokenizer.expr: "4pt+20%" - org.apache.fop.fo.expr.PropertyTokenizer.exprIndex: 4 - org.apache.fop.fo.expr.PropertyTokenizer.exprLength: 7 - org.apache.fop.fo.expr.PropertyTokenizer.recognizeOperator: false -} -</screen> -the next token is of type <literal>currentToken = -PropertyTokenizer.TOK_PLUS</literal>.</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para><literal>next()</literal>: -scan for the next token; -<screen> - this = { - propInfo: instance of org.apache.fop.fo.expr.PropertyInfo(id=736) - org.apache.fop.fo.expr.PropertyTokenizer.currentToken: 14 - org.apache.fop.fo.expr.PropertyTokenizer.currentTokenValue: "20%" - org.apache.fop.fo.expr.PropertyTokenizer.currentUnitLength: 2 - org.apache.fop.fo.expr.PropertyTokenizer.currentTokenStartIndex: 4 - org.apache.fop.fo.expr.PropertyTokenizer.expr: "4pt+20%" - org.apache.fop.fo.expr.PropertyTokenizer.exprIndex: 7 - org.apache.fop.fo.expr.PropertyTokenizer.exprLength: 7 - org.apache.fop.fo.expr.PropertyTokenizer.recognizeOperator: true -} -</screen> -the next token is of type <literal>currentToken = -PropertyTokenizer.TOK_PERCENT</literal>. -The currentTokenValue <literal>20%</literal> is analysed:</para> - </listitem> - <listitem> - <para><literal>parseMultiplicativeExpr</literal> -<itemizedlist spacing="compact"> - <listitem> - <para><literal>parseUnaryExpr</literal> -<itemizedlist spacing="compact"> - <listitem> - <para><literal>parsePrimaryExpr</literal> -<itemizedlist spacing="compact"> - <listitem> - <para><literal>propInfo.getPercentBase</literal>: -create a PercentBase property -<itemizedlist spacing="compact"> - <listitem> - <para><literal>propInfo.getFunctionPercentBase</literal> -uses a stack of functions stkFunction, which currently <literal>== -null</literal></para> - </listitem> - <listitem> - <para><literal>if (null) -maker.getPercentBase(fo, plist)</literal>: create and return a -<literal>LengthBase</literal> property, which implements -<literal>PercentBase</literal> -<screen> - pcBase = "org.apache.fop.datatypes.LengthBase@171f189" - pcBase = { - parentFO: instance of org.apache.fop.fo.pagination.SimplePageMaster(id=786) - propertyList: instance of org.apache.fop.fo.PropertyList(id=807) - iBaseType: 5 -} -</screen> -the value of <literal>iBaseType</literal> is derived from -<literal>maker.percentBase == 5 == -LengthBase.BLOCK_WIDTH</literal>.</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para><literal>pcBase.getDimension</literal>; -dimension: type of integer, int → 0, length → 1; used by -<literal>PercentBase</literal> and <literal>NumericProperty</literal>; -<literal>LengthBase</literal> has a dimension of 1</para> - </listitem> - <listitem> - <para>create a -<literal>PercentLength(pcval, pcBase)</literal>: -<screen> - prop = "20.0%" - prop = { - factor: 0.2 - lbase: instance of org.apache.fop.datatypes.LengthBase(id=751) - org.apache.fop.fo.properties.Property.specVal: null -} -</screen> -<literal>factor</literal> comes from <literal>pcval</literal>, -<literal>lbase = pcBase</literal></para> - </listitem> - <listitem> - <para><literal>next()</literal>: -scan for the next token; the next token is of type -<literal>currentToken = PropertyTokenizer.TOK_EOF</literal>.</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>return the <literal>LengthBase</literal> -property value object</para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para><literal>evalAddition(NumericProperty op1, -NumericProperty op2)</literal>. <literal>op1</literal> and -<literal>op2</literal> are now <literal>Numeric</literal>, which is an -interface implemented by <literal>LengthProperty</literal>, of which -<literal>FixedLength</literal> and <literal>PercentLength</literal> -are subclasses: -<screen> -op1 = instance of org.apache.fop.fo.properties.FixedLength(id=744) -op2 = instance of org.apache.fop.fo.properties.PercentLength(id=757) -</screen> <itemizedlist spacing="compact"> - <listitem> - <para><literal>NumericOp.addition</literal> -<itemizedlist spacing="compact"> - <listitem> - <para>Construct a new -<literal>RelativeNumericProperty</literal> by adding the two -properties: -<literal>RelativeNumericProperty(RelativeNumericProperty.ADDITION, -op1, op2)</literal></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist></para> - </listitem> - <listitem> - <para>If <literal>currentToken = -PropertyTokenizer.TOK_EOF</literal>, break the loop.</para> - </listitem> - </itemizedlist></para> - </listitem> - </itemizedlist> -return the <literal>RelativeNumericProperty</literal>: -<screen> - prop = "(4000mpt +20.0%)" - prop = { - operation: 1 - op1: instance of org.apache.fop.fo.properties.FixedLength(id=744) - op2: instance of org.apache.fop.fo.properties.PercentLength(id=757) - dimension: 1 - org.apache.fop.fo.properties.Property.specVal: null -} -</screen> -The value 1 for the operation corresponds to -<literal>RelativeProperty.ADDITION</literal>. The value 1 for the -dimension indicates that this is a length. PropertyList: -<screen> - this = "{margin=[(4000mpt +20.0%)]}" -</screen></para> - </section> - - <section> - <title>Resolving a mixed property value</title> - - <para>Example: Resolving the value of the property -<literal>margin-left</literal> of the FO node -<literal>fo:region-body</literal>. This value was specified as -<literal><fo:region-body margin="4pt+20%"/></literal>. -<literal>margin</literal> is a shorthand property for -<literal>margin-left</literal>.</para> - -<para>The property list of <literal>fo:region-body</literal> reads: -<screen> - this = "{margin=[(4000mpt +20.0%)]}" -</screen> -The retrieved property value is a -<literal>RelativeNumericProperty</literal>: -<screen> - prop = "(4000mpt +20.0%)" - prop = { - operation: 1 - op1: instance of org.apache.fop.fo.properties.FixedLength(id=817) - op2: instance of org.apache.fop.fo.properties.PercentLength(id=818) - dimension: 1 - org.apache.fop.fo.properties.Property.specVal: null -} -</screen> -The value 1 for the operation corresponds to -<literal>RelativeProperty.ADDITION</literal>. The value 1 for the -dimension indicates that this is a length. -<screen> - op2 = "20.0%" - op2 = { - factor: 0.2 - lbase: instance of org.apache.fop.datatypes.LengthBase(id=751) - org.apache.fop.fo.properties.Property.specVal: null -} - lbase = "org.apache.fop.datatypes.LengthBase@171f189" - lbase = { - parentFO: instance of org.apache.fop.fo.pagination.SimplePageMaster(id=786) - propertyList: instance of org.apache.fop.fo.PropertyList(id=807) - iBaseType: 5 -} -</screen> -</para> - -<para>The <literal>RelativeNumericProperty</literal> is resolved in -the method call -<screen> - props.marginLeft = - this.propertyList.get(PR_MARGIN_LEFT).getLength().getValue(); -</screen> -in <literal>PropertyManager.getMarginProps()</literal>. -<literal>getLength()</literal> is a sort of cast; it returns the -property value if it is a length. The <literal>getValue()</literal> -method invoked is -<literal>RelativeNumericProperty.getValue()</literal>. -This calls -<literal>RelativeNumericProperty.getNumericValue()</literal>, which -calls <literal>RelativeNumericProperty.getResolved()</literal>. This -invokes the operation on its two operands, -<literal>NumericOp.addition2</literal>, which invokes -<literal>getNumericValue()</literal> on each -operand. <literal>PercentLength.getNumericValue()</literal> calls -<literal>LengthBase.getBaseLength</literal> on its member -<literal>lbase</literal>.</para> - -<para>Due to its value <literal>iBaseType == 5 == -LengthBase.BLOCK_WIDTH</literal> this invokes -<literal>parentFO.getLayoutDimension(PercentBase.BLOCK_IPD).intValue()</literal> -on its parent FO. The simple page master FO node does not have any -layout dimensions, its member <literal>layoutDimension</literal> is -<literal>null</literal>. Therefore it consults its parent FO. This -goes all the way up to the root FO node.</para> - -<para>The root FO node does have the required layout dimensions, which -are the page dimensions. These have been set on it -by the <literal>PageLayoutManager</literal> when the page was created -in its -method <literal>createPageAreas</literal>: -<screen> -((FObj) fobj.getParent()).setLayoutDimension(PercentBase.BLOCK_IPD,pageWidth) -((FObj) fobj.getParent()).setLayoutDimension(PercentBase.BLOCK_BPD,pageHeight) -PercentBase.BLOCK_IPD = 2, PercentBase.BLOCK_BPD = 3 -</screen> -As a result: -<screen> - layoutDimension = "{2=576000, 3=792000}" - key = "2" - getName() = "fo:root" -</screen> -</para> - -<screen> - [1] org.apache.fop.fo.FObj.getLayoutDimension (FObj.java:241) - [2] org.apache.fop.datatypes.LengthBase.getBaseLength (LengthBase.java:120) - [3] org.apache.fop.fo.properties.PercentLength.getNumericValue (PercentLength.java:82) - [4] org.apache.fop.fo.expr.NumericOp.addition2 (NumericOp.java:52) - [5] org.apache.fop.fo.expr.RelativeNumericProperty.getResolved (RelativeNumericProperty.java:105) - [6] org.apache.fop.fo.expr.RelativeNumericProperty.getNumericValue (RelativeNumericProperty.java:132) - [7] org.apache.fop.fo.expr.RelativeNumericProperty.getValue (RelativeNumericProperty.java:170) - [8] org.apache.fop.fo.PropertyManager.getMarginProps (PropertyManager.java:267) -</screen> - -<para><literal>PercentLength.getNumericValue()</literal> returns the -page width, which is multiplied by the requested factor of 0.2, and -added to the value of the fixed length, 4000. The resulting value is -returned and used for the variable <literal>marginLeft</literal>: - -<screen> - value = 119200.0 - props.marginLeft = 119200 -</screen> -</para> - - </section> - - </section> - -</chapter> - -<!-- Local Variables: --> -<!-- current-language-environment: UTF-8 --> -<!-- coding: utf-8 --> -<!-- default-input-method: TeX --> -<!-- End: --> diff --git a/src/documentation/content/xdocs/DnI/rendering.xml b/src/documentation/content/xdocs/DnI/rendering.xml deleted file mode 100644 index 4f4d963a8..000000000 --- a/src/documentation/content/xdocs/DnI/rendering.xml +++ /dev/null @@ -1,91 +0,0 @@ -<?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$ --> - -<!-- -<!DOCTYPE chapter PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" - "docbookx.dtd"> - --> - -<chapter> - <title>Phase 3: Rendering the pages</title> - - <para>It is the task of the rendering phase to describe the area -tree in the target page description language, so that viewers for that -language can render the pages. Rendering is done page by page. For -each page the rendering system is handed a PageViewport, and it walks -the area subtree below it. For each area it retrieves the traits and -data, and generates the required output.</para> - - <para>The layout of a page is not finished until all forward -references on that page have been resolved. As a consequence pages are -finished out of pagination order. Some renderers support out of -order rendering of pages, -<literal>AbstractRenderer.supportsOutOfOrder()</literal>. If a -renderer does, a finished page is handed over to it -immediately. Otherwise, the layout system keeps finished pages until -all preceding pages are also finished and have been handed over to the -renderer. In principle, the PDF renderer supports out of order -rendering. In current FOP (27 June 2004) this has been disabled -because the support is broken.</para> - - <para>This stack at a deep position, rendering a leader in a block -in a flow in the body region, shows some details of rendering. Note -how the hierarchy of the area tree can be recognized. The lower -frames show how the rendering system is called by the layout system: - -<screen> -main[1] where - [1] org.apache.fop.render.pdf.PDFRenderer.renderLeader (PDFRenderer.java:1,266) - [2] org.apache.fop.render.AbstractRenderer.serveVisitor (AbstractRenderer.java:832) - [3] org.apache.fop.area.inline.Leader.acceptVisitor (Leader.java:118) - [4] org.apache.fop.render.AbstractRenderer.renderLineArea (AbstractRenderer.java:610) - [5] org.apache.fop.render.pdf.PDFRenderer.renderLineArea (PDFRenderer.java:830) - [6] org.apache.fop.render.AbstractRenderer.renderBlocks (AbstractRenderer.java:547) - [7] org.apache.fop.render.AbstractRenderer.renderBlock (AbstractRenderer.java:588) - [8] org.apache.fop.render.pdf.PDFRenderer.renderBlock (PDFRenderer.java:513) - [9] org.apache.fop.render.AbstractRenderer.renderBlocks (AbstractRenderer.java:538) - [10] org.apache.fop.render.AbstractRenderer.renderFlow (AbstractRenderer.java:473) - [11] org.apache.fop.render.AbstractRenderer.renderMainReference (AbstractRenderer.java:456) - [12] org.apache.fop.render.AbstractRenderer.renderBodyRegion (AbstractRenderer.java:392) - [13] org.apache.fop.render.AbstractRenderer.renderRegionViewport (AbstractRenderer.java:338) - [14] org.apache.fop.render.AbstractRenderer.renderPageAreas (AbstractRenderer.java:310) - [15] org.apache.fop.render.pdf.PDFRenderer.renderPage (PDFRenderer.java:471) - [16] org.apache.fop.area.RenderPagesModel.addPage (RenderPagesModel.java:117) - [17] org.apache.fop.area.AreaTree.addPage (AreaTree.java:143) - [18] org.apache.fop.layoutmgr.PageLayoutManager.finishPage (PageLayoutManager.java:532) - [19] org.apache.fop.layoutmgr.PageLayoutManager.doLayout (PageLayoutManager.java:231) -</screen></para> - - <para>Obviously there is a lot to be documented about the rendering -system, and about each renderer separately. Because I do not (yet) -know much about the rendering system, I will have to leave that task -to others. I only add the obvious: Rendering requires precise -programming: spacing and progress calculations, saving and restoring -dimensions, etc. It also requires tracking the state in the output -format.</para> - -</chapter> - -<!-- Local Variables: --> -<!-- current-language-environment: UTF-8 --> -<!-- coding: utf-8 --> -<!-- default-input-method: TeX --> -<!-- End: --> |