/* * Copyright 2004-2005 The Apache Software Foundation. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ /* $Id$ */ package org.apache.fop.layoutmgr; import java.util.List; import org.apache.fop.fo.FONode; import org.apache.fop.fo.pagination.Flow; import org.apache.fop.fo.pagination.PageSequence; import org.apache.fop.fo.pagination.SideRegion; import org.apache.fop.fo.pagination.StaticContent; import org.apache.fop.area.AreaTreeHandler; import org.apache.fop.area.Block; /** * The interface for all LayoutManager makers */ public interface LayoutManagerMaker { /** * Make LayoutManagers for the node and add them to the list lms. * @param node the FO node for which the LayoutManagers are made * @param lms the list to which the LayoutManagers are added */ public void makeLayoutManagers(FONode node, List lms); /** * Make a specific LayoutManager for the node. * If not exactly one LayoutManagers is available, * an IllegalStateException is thrown. * @param node the FO node for which the LayoutManagers are made * @return The created LayoutManager * @throws IllegalStateException if not exactly one * LayoutManager is available for the requested node */ public LayoutManager makeLayoutManager(FONode node); /** * Make a PageSequenceLayoutManager object. * @param ath the AreaTreeHandler object the PSLM interacts with * @param ps the fo:page-sequence object this PSLM will process * @return The created PageSequenceLayoutManager object */ public PageSequenceLayoutManager makePageSequenceLayoutManager( AreaTreeHandler ath, PageSequence ps); /** * Make a FlowLayoutManager object. * @param pslm the parent PageSequenceLayoutManager object * @param flow the fo:flow object this FLM will process * @return The created FlowLayoutManager object */ public FlowLayoutManager makeFlowLayoutManager( PageSequenceLayoutManager pslm, Flow flow); /** * Make a StaticContentLayoutManager object. * @param pslm the parent PageSequenceLayoutManager object * @param sc the fo:static-content object this SCLM will process * @param reg the side region indicating where the static content * needs to be processed. * @return The created StaticContentLayoutManager object */ public StaticContentLayoutManager makeStaticContentLayoutManager( PageSequenceLayoutManager pslm, StaticContent sc, SideRegion reg); /** * Make a StaticContentLayoutManager object for a footnote-separator. * @param pslm the parent PageSequenceLayoutManager object * @param sc the fo:static-content object this SCLM will process * @param block the Block area this SCLM must add its areas to * @return The created StaticContentLayoutManager object */ public StaticContentLayoutManager makeStaticContentLayoutManager( PageSequenceLayoutManager pslm, StaticContent sc, Block block); }