You are viewing a plain text version of this content. The canonical link for it is here.
Posted to fop-commits@xmlgraphics.apache.org by jo...@locus.apache.org on 2000/06/22 02:25:52 UTC

cvs commit: xml-fop/src/org/apache/fop/fo/flow ListBlock.java Table.java TableBody.java TableCell.java TableRow.java

jordan      00/06/21 17:25:50

  Modified:    src/org/apache/fop/fo/flow ListBlock.java Table.java
                        TableBody.java TableCell.java TableRow.java
  Log:
  added id support (required for internal-links)
  
  Revision  Changes    Path
  1.10      +207 -202  xml-fop/src/org/apache/fop/fo/flow/ListBlock.java
  
  Index: ListBlock.java
  ===================================================================
  RCS file: /home/cvs/xml-fop/src/org/apache/fop/fo/flow/ListBlock.java,v
  retrieving revision 1.9
  retrieving revision 1.10
  diff -u -r1.9 -r1.10
  --- ListBlock.java	2000/06/14 02:00:37	1.9
  +++ ListBlock.java	2000/06/22 00:25:44	1.10
  @@ -1,202 +1,207 @@
  -/*-- $Id: ListBlock.java,v 1.9 2000/06/14 02:00:37 arved Exp $ -- 
  -
  - ============================================================================
  -                   The Apache Software License, Version 1.1
  - ============================================================================
  - 
  -    Copyright (C) 1999 The Apache Software Foundation. All rights reserved.
  - 
  - Redistribution and use in source and binary forms, with or without modifica-
  - tion, are permitted provided that the following conditions are met:
  - 
  - 1. Redistributions of  source code must  retain the above copyright  notice,
  -    this list of conditions and the following disclaimer.
  - 
  - 2. Redistributions in binary form must reproduce the above copyright notice,
  -    this list of conditions and the following disclaimer in the documentation
  -    and/or other materials provided with the distribution.
  - 
  - 3. The end-user documentation included with the redistribution, if any, must
  -    include  the following  acknowledgment:  "This product includes  software
  -    developed  by the  Apache Software Foundation  (http://www.apache.org/)."
  -    Alternately, this  acknowledgment may  appear in the software itself,  if
  -    and wherever such third-party acknowledgments normally appear.
  - 
  - 4. The names "FOP" and  "Apache Software Foundation"  must not be used to
  -    endorse  or promote  products derived  from this  software without  prior
  -    written permission. For written permission, please contact
  -    apache@apache.org.
  - 
  - 5. Products  derived from this software may not  be called "Apache", nor may
  -    "Apache" appear  in their name,  without prior written permission  of the
  -    Apache Software Foundation.
  - 
  - THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
  - INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  - FITNESS  FOR A PARTICULAR  PURPOSE ARE  DISCLAIMED.  IN NO  EVENT SHALL  THE
  - APACHE SOFTWARE  FOUNDATION  OR ITS CONTRIBUTORS  BE LIABLE FOR  ANY DIRECT,
  - INDIRECT, INCIDENTAL, SPECIAL,  EXEMPLARY, OR CONSEQUENTIAL  DAMAGES (INCLU-
  - DING, BUT NOT LIMITED TO, PROCUREMENT  OF SUBSTITUTE GOODS OR SERVICES; LOSS
  - OF USE, DATA, OR  PROFITS; OR BUSINESS  INTERRUPTION)  HOWEVER CAUSED AND ON
  - ANY  THEORY OF LIABILITY,  WHETHER  IN CONTRACT,  STRICT LIABILITY,  OR TORT
  - (INCLUDING  NEGLIGENCE OR  OTHERWISE) ARISING IN  ANY WAY OUT OF THE  USE OF
  - THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  - 
  - This software  consists of voluntary contributions made  by many individuals
  - on  behalf of the Apache Software  Foundation and was  originally created by
  - James Tauber <jt...@jtauber.com>. For more  information on the Apache 
  - Software Foundation, please see <http://www.apache.org/>.
  - 
  - */
  -
  -package org.apache.fop.fo.flow;
  -
  -// FOP
  -import org.apache.fop.fo.*;
  -import org.apache.fop.fo.properties.*;
  -import org.apache.fop.datatypes.*;
  -import org.apache.fop.layout.Area;
  -import org.apache.fop.layout.BlockArea;
  -import org.apache.fop.layout.FontState;
  -import org.apache.fop.apps.FOPException;
  -
  -// Java
  -import java.util.Enumeration;
  -
  -public class ListBlock extends FObj {
  -
  -    public static class Maker extends FObj.Maker {
  -	public FObj make(FObj parent, PropertyList propertyList)
  -	    throws FOPException {
  -	    return new ListBlock(parent, propertyList);
  -	}
  -    }
  -
  -    public static FObj.Maker maker() {
  -	return new ListBlock.Maker();
  -    }
  -
  -    FontState fs;
  -    int align;
  -    int alignLast;
  -    int breakBefore;
  -    int breakAfter;
  -    int lineHeight;
  -    int startIndent;
  -    int endIndent;
  -    int spaceBefore;
  -    int spaceAfter;
  -    int provisionalDistanceBetweenStarts;
  -    int provisionalLabelSeparation;
  -    int spaceBetweenListRows = 0;
  -    ColorType backgroundColor;
  -
  -    public ListBlock(FObj parent, PropertyList propertyList) {
  -	super(parent, propertyList);
  -	this.name = "fo:list-block";
  -    }
  -
  -    public Status layout(Area area) throws FOPException {
  -	if (this.marker == START) {
  -	    String fontFamily =
  -		this.properties.get("font-family").getString(); 
  -	    String fontStyle =
  -		this.properties.get("font-style").getString(); 
  -	    String fontWeight =
  -		this.properties.get("font-weight").getString(); 
  -	    int fontSize =
  -		this.properties.get("font-size").getLength().mvalue(); 
  -	    
  -	    this.fs = new FontState(area.getFontInfo(), fontFamily,
  -				    fontStyle, fontWeight, fontSize);
  -	    
  -	    this.align = this.properties.get("text-align").getEnum(); 
  -	    this.alignLast =
  -		this.properties.get("text-align-last").getEnum(); 
  -	    this.lineHeight =
  -		this.properties.get("line-height").getLength().mvalue(); 
  -	    this.startIndent =
  -		this.properties.get("start-indent").getLength().mvalue(); 
  -	    this.endIndent =
  -		this.properties.get("end-indent").getLength().mvalue();
  -	    this.spaceBefore =
  -		this.properties.get("space-before.optimum").getLength().mvalue();
  -	    this.spaceAfter =
  -		this.properties.get("space-after.optimum").getLength().mvalue();
  -	    this.provisionalDistanceBetweenStarts =
  -		this.properties.get("provisional-distance-between-starts").getLength().mvalue();
  -	    this.provisionalLabelSeparation =
  -		this.properties.get("provisional-label-separation").getLength().mvalue(); 
  -	    this.spaceBetweenListRows = 0; // not used at present
  -	    this.backgroundColor =
  -		this.properties.get("background-color").getColorType();
  -	    
  -	    this.marker = 0;
  -
  -	    if (area instanceof BlockArea) {
  -		area.end();
  -	    }
  -
  -	    if (spaceBefore != 0) {
  -		area.addDisplaySpace(spaceBefore);
  -	    }
  -
  -	    if (this.isInListBody) {
  -		startIndent += bodyIndent + distanceBetweenStarts;
  -		bodyIndent = startIndent;
  -	    }
  -
  -	    if (this.isInTableCell) {
  -		startIndent += forcedStartOffset;
  -		endIndent += area.getAllocationWidth() - forcedWidth -
  -		    forcedStartOffset;
  -	    }
  -	}
  -
  -	BlockArea blockArea =
  -	    new BlockArea(fs, area.getAllocationWidth(),
  -			  area.spaceLeft(), startIndent, endIndent, 0,
  -			  align, alignLast, lineHeight);
  -	blockArea.setPage(area.getPage());
  -	blockArea.setBackgroundColor(backgroundColor);
  -	blockArea.start();
  -        
  -        blockArea.setAbsoluteHeight(area.getAbsoluteHeight());
  -
  -	int numChildren = this.children.size();
  -	for (int i = this.marker; i < numChildren; i++) {
  -	    if (!(children.elementAt(i) instanceof ListItem)) {
  -		System.err.println("WARNING: This version of FOP requires list-items inside list-blocks");
  -		return new Status(Status.OK);
  -	    }
  -	    ListItem listItem = (ListItem) children.elementAt(i);
  -	    listItem.setDistanceBetweenStarts(this.provisionalDistanceBetweenStarts);
  -	    listItem.setLabelSeparation(this.provisionalLabelSeparation);
  -	    listItem.setBodyIndent(this.bodyIndent);
  -	    Status status;
  -	    if ((status = listItem.layout(blockArea)).isIncomplete()) {
  -		this.marker = i;
  -		blockArea.end();
  -		area.addChild(blockArea);
  -		area.increaseHeight(blockArea.getHeight());
  -                area.setAbsoluteHeight(blockArea.getAbsoluteHeight()); 
  -		return status;
  -	    }
  -	}
  -
  -	blockArea.end();
  -	area.addChild(blockArea);
  -	area.increaseHeight(blockArea.getHeight());
  -        area.setAbsoluteHeight(blockArea.getAbsoluteHeight());
  -
  -	if (spaceAfter != 0) {
  -	    area.addDisplaySpace(spaceAfter);
  -	}
  -
  -	if (area instanceof BlockArea) {
  -	    area.start();
  -	}
  -	
  -	return new Status(Status.OK);
  -    }
  -}
  +/*-- $Id: ListBlock.java,v 1.10 2000/06/22 00:25:44 jordan Exp $ -- 
  +
  + ============================================================================
  +                   The Apache Software License, Version 1.1
  + ============================================================================
  + 
  +    Copyright (C) 1999 The Apache Software Foundation. All rights reserved.
  + 
  + Redistribution and use in source and binary forms, with or without modifica-
  + tion, are permitted provided that the following conditions are met:
  + 
  + 1. Redistributions of  source code must  retain the above copyright  notice,
  +    this list of conditions and the following disclaimer.
  + 
  + 2. Redistributions in binary form must reproduce the above copyright notice,
  +    this list of conditions and the following disclaimer in the documentation
  +    and/or other materials provided with the distribution.
  + 
  + 3. The end-user documentation included with the redistribution, if any, must
  +    include  the following  acknowledgment:  "This product includes  software
  +    developed  by the  Apache Software Foundation  (http://www.apache.org/)."
  +    Alternately, this  acknowledgment may  appear in the software itself,  if
  +    and wherever such third-party acknowledgments normally appear.
  + 
  + 4. The names "FOP" and  "Apache Software Foundation"  must not be used to
  +    endorse  or promote  products derived  from this  software without  prior
  +    written permission. For written permission, please contact
  +    apache@apache.org.
  + 
  + 5. Products  derived from this software may not  be called "Apache", nor may
  +    "Apache" appear  in their name,  without prior written permission  of the
  +    Apache Software Foundation.
  + 
  + THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
  + INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  + FITNESS  FOR A PARTICULAR  PURPOSE ARE  DISCLAIMED.  IN NO  EVENT SHALL  THE
  + APACHE SOFTWARE  FOUNDATION  OR ITS CONTRIBUTORS  BE LIABLE FOR  ANY DIRECT,
  + INDIRECT, INCIDENTAL, SPECIAL,  EXEMPLARY, OR CONSEQUENTIAL  DAMAGES (INCLU-
  + DING, BUT NOT LIMITED TO, PROCUREMENT  OF SUBSTITUTE GOODS OR SERVICES; LOSS
  + OF USE, DATA, OR  PROFITS; OR BUSINESS  INTERRUPTION)  HOWEVER CAUSED AND ON
  + ANY  THEORY OF LIABILITY,  WHETHER  IN CONTRACT,  STRICT LIABILITY,  OR TORT
  + (INCLUDING  NEGLIGENCE OR  OTHERWISE) ARISING IN  ANY WAY OUT OF THE  USE OF
  + THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  + 
  + This software  consists of voluntary contributions made  by many individuals
  + on  behalf of the Apache Software  Foundation and was  originally created by
  + James Tauber <jt...@jtauber.com>. For more  information on the Apache 
  + Software Foundation, please see <http://www.apache.org/>.
  + 
  + */
  +
  +package org.apache.fop.fo.flow;
  +
  +// FOP
  +import org.apache.fop.fo.*;
  +import org.apache.fop.fo.properties.*;
  +import org.apache.fop.datatypes.*;
  +import org.apache.fop.layout.Area;
  +import org.apache.fop.layout.BlockArea;
  +import org.apache.fop.layout.FontState;
  +import org.apache.fop.apps.FOPException;
  +
  +// Java
  +import java.util.Enumeration;
  +
  +public class ListBlock extends FObj {
  +
  +    public static class Maker extends FObj.Maker {
  +	public FObj make(FObj parent, PropertyList propertyList)
  +	    throws FOPException {
  +	    return new ListBlock(parent, propertyList);
  +	}
  +    }
  +
  +    public static FObj.Maker maker() {
  +	return new ListBlock.Maker();
  +    }
  +
  +    FontState fs;
  +    int align;
  +    int alignLast;
  +    int breakBefore;
  +    int breakAfter;
  +    int lineHeight;
  +    int startIndent;
  +    int endIndent;
  +    int spaceBefore;
  +    int spaceAfter;
  +    int provisionalDistanceBetweenStarts;
  +    int provisionalLabelSeparation;
  +    int spaceBetweenListRows = 0;
  +    ColorType backgroundColor;
  +
  +    public ListBlock(FObj parent, PropertyList propertyList) {
  +	super(parent, propertyList);
  +	this.name = "fo:list-block";
  +    }
  +
  +    public Status layout(Area area) throws FOPException {
  +	if (this.marker == START) {
  +	    String fontFamily =
  +		this.properties.get("font-family").getString(); 
  +	    String fontStyle =
  +		this.properties.get("font-style").getString(); 
  +	    String fontWeight =
  +		this.properties.get("font-weight").getString(); 
  +	    int fontSize =
  +		this.properties.get("font-size").getLength().mvalue(); 
  +	    
  +	    this.fs = new FontState(area.getFontInfo(), fontFamily,
  +				    fontStyle, fontWeight, fontSize);
  +	    
  +	    this.align = this.properties.get("text-align").getEnum(); 
  +	    this.alignLast =
  +		this.properties.get("text-align-last").getEnum(); 
  +	    this.lineHeight =
  +		this.properties.get("line-height").getLength().mvalue(); 
  +	    this.startIndent =
  +		this.properties.get("start-indent").getLength().mvalue(); 
  +	    this.endIndent =
  +		this.properties.get("end-indent").getLength().mvalue();
  +	    this.spaceBefore =
  +		this.properties.get("space-before.optimum").getLength().mvalue();
  +	    this.spaceAfter =
  +		this.properties.get("space-after.optimum").getLength().mvalue();
  +	    this.provisionalDistanceBetweenStarts =
  +		this.properties.get("provisional-distance-between-starts").getLength().mvalue();
  +	    this.provisionalLabelSeparation =
  +		this.properties.get("provisional-label-separation").getLength().mvalue(); 
  +	    this.spaceBetweenListRows = 0; // not used at present
  +	    this.backgroundColor =
  +		this.properties.get("background-color").getColorType();
  +	    
  +	    this.marker = 0;
  +
  +	    if (area instanceof BlockArea) {
  +		area.end();
  +	    }
  +
  +	    if (spaceBefore != 0) {
  +		area.addDisplaySpace(spaceBefore);
  +	    }
  +
  +	    if (this.isInListBody) {
  +		startIndent += bodyIndent + distanceBetweenStarts;
  +		bodyIndent = startIndent;
  +	    }
  +
  +	    if (this.isInTableCell) {
  +		startIndent += forcedStartOffset;
  +		endIndent += area.getAllocationWidth() - forcedWidth -
  +		    forcedStartOffset;
  +	    }
  +
  +             // initialize id                       
  +            String id = this.properties.get("id").getString();            
  +            area.getIDReferences().initializeID(id,area); 
  +	}        
  +
  +	BlockArea blockArea =
  +	    new BlockArea(fs, area.getAllocationWidth(),
  +			  area.spaceLeft(), startIndent, endIndent, 0,
  +			  align, alignLast, lineHeight);
  +	blockArea.setPage(area.getPage());
  +	blockArea.setBackgroundColor(backgroundColor);
  +	blockArea.start();
  +        
  +        blockArea.setAbsoluteHeight(area.getAbsoluteHeight());
  +        blockArea.setIDReferences(area.getIDReferences());
  +
  +	int numChildren = this.children.size();
  +	for (int i = this.marker; i < numChildren; i++) {
  +	    if (!(children.elementAt(i) instanceof ListItem)) {
  +		System.err.println("WARNING: This version of FOP requires list-items inside list-blocks");
  +		return new Status(Status.OK);
  +	    }
  +	    ListItem listItem = (ListItem) children.elementAt(i);
  +	    listItem.setDistanceBetweenStarts(this.provisionalDistanceBetweenStarts);
  +	    listItem.setLabelSeparation(this.provisionalLabelSeparation);
  +	    listItem.setBodyIndent(this.bodyIndent);
  +	    Status status;
  +	    if ((status = listItem.layout(blockArea)).isIncomplete()) {
  +		this.marker = i;
  +		blockArea.end();
  +		area.addChild(blockArea);
  +		area.increaseHeight(blockArea.getHeight());
  +                area.setAbsoluteHeight(blockArea.getAbsoluteHeight()); 
  +		return status;
  +	    }
  +	}
  +
  +	blockArea.end();
  +	area.addChild(blockArea);
  +	area.increaseHeight(blockArea.getHeight());
  +        area.setAbsoluteHeight(blockArea.getAbsoluteHeight());
  +
  +	if (spaceAfter != 0) {
  +	    area.addDisplaySpace(spaceAfter);
  +	}
  +
  +	if (area instanceof BlockArea) {
  +	    area.start();
  +	}
  +	
  +	return new Status(Status.OK);
  +    }
  +}
  
  
  
  1.12      +271 -264  xml-fop/src/org/apache/fop/fo/flow/Table.java
  
  Index: Table.java
  ===================================================================
  RCS file: /home/cvs/xml-fop/src/org/apache/fop/fo/flow/Table.java,v
  retrieving revision 1.11
  retrieving revision 1.12
  diff -u -r1.11 -r1.12
  --- Table.java	2000/06/14 01:58:31	1.11
  +++ Table.java	2000/06/22 00:25:45	1.12
  @@ -1,264 +1,271 @@
  -/*-- $Id: Table.java,v 1.11 2000/06/14 01:58:31 arved Exp $ -- 
  -
  - ============================================================================
  -                   The Apache Software License, Version 1.1
  - ============================================================================
  - 
  -    Copyright (C) 1999 The Apache Software Foundation. All rights reserved.
  - 
  - Redistribution and use in source and binary forms, with or without modifica-
  - tion, are permitted provided that the following conditions are met:
  - 
  - 1. Redistributions of  source code must  retain the above copyright  notice,
  -    this list of conditions and the following disclaimer.
  - 
  - 2. Redistributions in binary form must reproduce the above copyright notice,
  -    this list of conditions and the following disclaimer in the documentation
  -    and/or other materials provided with the distribution.
  - 
  - 3. The end-user documentation included with the redistribution, if any, must
  -    include  the following  acknowledgment:  "This product includes  software
  -    developed  by the  Apache Software Foundation  (http://www.apache.org/)."
  -    Alternately, this  acknowledgment may  appear in the software itself,  if
  -    and wherever such third-party acknowledgments normally appear.
  - 
  - 4. The names "FOP" and  "Apache Software Foundation"  must not be used to
  -    endorse  or promote  products derived  from this  software without  prior
  -    written permission. For written permission, please contact
  -    apache@apache.org.
  - 
  - 5. Products  derived from this software may not  be called "Apache", nor may
  -    "Apache" appear  in their name,  without prior written permission  of the
  -    Apache Software Foundation.
  - 
  - THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
  - INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  - FITNESS  FOR A PARTICULAR  PURPOSE ARE  DISCLAIMED.  IN NO  EVENT SHALL  THE
  - APACHE SOFTWARE  FOUNDATION  OR ITS CONTRIBUTORS  BE LIABLE FOR  ANY DIRECT,
  - INDIRECT, INCIDENTAL, SPECIAL,  EXEMPLARY, OR CONSEQUENTIAL  DAMAGES (INCLU-
  - DING, BUT NOT LIMITED TO, PROCUREMENT  OF SUBSTITUTE GOODS OR SERVICES; LOSS
  - OF USE, DATA, OR  PROFITS; OR BUSINESS  INTERRUPTION)  HOWEVER CAUSED AND ON
  - ANY  THEORY OF LIABILITY,  WHETHER  IN CONTRACT,  STRICT LIABILITY,  OR TORT
  - (INCLUDING  NEGLIGENCE OR  OTHERWISE) ARISING IN  ANY WAY OUT OF THE  USE OF
  - THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  - 
  - This software  consists of voluntary contributions made  by many individuals
  - on  behalf of the Apache Software  Foundation and was  originally created by
  - James Tauber <jt...@jtauber.com>. For more  information on the Apache 
  - Software Foundation, please see <http://www.apache.org/>.
  - 
  - */
  -
  -package org.apache.fop.fo.flow;
  -
  -// FOP
  -import org.apache.fop.fo.*;
  -import org.apache.fop.fo.properties.*;
  -import org.apache.fop.layout.*;
  -import org.apache.fop.datatypes.*;
  -import org.apache.fop.apps.FOPException;
  -
  -// Java
  -import java.util.Vector;
  -
  -public class Table extends FObj {
  -	
  -    public static class Maker extends FObj.Maker {
  -	public FObj make(FObj parent, PropertyList propertyList)
  -	    throws FOPException {
  -	    return new Table(parent, propertyList);
  -	}
  -    }
  -
  -    public static FObj.Maker maker() {
  -	return new Table.Maker();
  -    }
  -
  -    FontState fs;
  -    int breakBefore;
  -    int breakAfter;
  -    int spaceBefore;
  -    int spaceAfter;
  -    ColorType backgroundColor;
  -    int width;
  -    int height;
  -    ColorType borderColor;
  -    int borderWidth;
  -    int borderStyle;
  -    
  -
  -    Vector columns = new Vector();
  -    int currentColumnNumber = 0;
  -
  -    AreaContainer areaContainer;
  -
  -    public Table(FObj parent, PropertyList propertyList) {
  -	super(parent, propertyList);
  -	this.name = "fo:table";
  -    }
  -
  -    public Status layout(Area area) throws FOPException {
  -	if (this.marker == BREAK_AFTER) {
  -	    return new Status(Status.OK);
  -	}
  -
  -	if (this.marker == START) {
  -	    String fontFamily =
  -		this.properties.get("font-family").getString(); 
  -	    String fontStyle =
  -		this.properties.get("font-style").getString(); 
  -	    String fontWeight =
  -		this.properties.get("font-weight").getString(); 
  -	    int fontSize =
  -		this.properties.get("font-size").getLength().mvalue(); 
  -	    
  -	    this.fs = new FontState(area.getFontInfo(), fontFamily, 
  -				    fontStyle, fontWeight, fontSize);  
  -	    this.breakBefore =
  -		this.properties.get("break-before").getEnum(); 
  -	    this.breakAfter =
  -		this.properties.get("break-after").getEnum(); 
  -	    this.spaceBefore =
  -		this.properties.get("space-before.optimum").getLength().mvalue();  
  -	    this.spaceAfter =
  -		this.properties.get("space-after.optimum").getLength().mvalue(); 
  -	    this.backgroundColor =
  -		this.properties.get("background-color").getColorType();
  -	    this.width =
  -		this.properties.get("width").getLength().mvalue();
  -	    this.height =
  -		this.properties.get("height").getLength().mvalue();
  -            
  -	    this.borderColor =
  -		this.properties.get("border-color").getColorType();
  -	    this.borderWidth =
  -		this.properties.get("border-width").getLength().mvalue();
  -	    this.borderStyle =
  -		this.properties.get("border-style").getEnum();
  -
  -	    if (area instanceof BlockArea) {
  -		area.end();
  -	    }
  -
  -	    this.marker = 0;
  -
  -	    if (breakBefore == BreakBefore.PAGE) {
  -		return new Status(Status.FORCE_PAGE_BREAK);
  -	    }
  -
  -	    if (breakBefore == BreakBefore.ODD_PAGE) {
  -		return new Status(Status.FORCE_PAGE_BREAK_ODD);
  -	    }
  -	
  -	    if (breakBefore == BreakBefore.EVEN_PAGE) {
  -		return new Status(Status.FORCE_PAGE_BREAK_EVEN);
  -	    }
  -	}
  -
  -	if ((spaceBefore != 0) && (this.marker ==0)) {
  -	    area.addDisplaySpace(spaceBefore);
  -	}
  -
  -	this.areaContainer =
  -	    new AreaContainer(fs, 0, 0, area.getAllocationWidth(), 
  -                          area.spaceLeft(), Position.STATIC);
  -	areaContainer.setPage(area.getPage());
  -	areaContainer.setBackgroundColor(backgroundColor);
  -        areaContainer.setBorderStyle(borderStyle, borderStyle, borderStyle, borderStyle); 
  -        areaContainer.setBorderWidth(borderWidth, borderWidth, borderWidth, borderWidth); 
  -        areaContainer.setBorderColor(borderColor, borderColor, borderColor, borderColor); 
  -	areaContainer.start();
  -
  -        areaContainer.setAbsoluteHeight(area.getAbsoluteHeight());
  -
  -	// added by Eric Schaeffer
  -	currentColumnNumber = 0;
  -        int offset = 0;
  -
  -	int numChildren = this.children.size();
  -	for (int i = this.marker; i < numChildren; i++) {
  -	    FONode fo = (FONode) children.elementAt(i);
  -	    if (fo instanceof TableColumn) {
  -		TableColumn c = (TableColumn) fo;
  -		int num = c.getColumnNumber();
  -		if (num == 0) {
  -		    num = currentColumnNumber + 1;
  -		}
  -		currentColumnNumber = num;
  -		if (num > columns.size()) {
  -		    columns.setSize(num);
  -		}
  -		columns.setElementAt(c, num-1);
  -                c.setColumnOffset(offset);
  -		fo.layout(areaContainer);
  -                offset += c.getColumnWidth();
  -	    } else if (fo instanceof TableBody) {
  -		if (columns.size() == 0) {
  -		    System.err.println("WARNING: current implementation of tables requires a table-column for each column, indicating column-width");
  -		    return new Status(Status.OK);
  -		}
  -		
  -		((TableBody) fo).setColumns(columns);
  -
  -		Status status;
  -		if ((status = fo.layout(areaContainer)).isIncomplete()) {
  -		    this.marker = i;
  -		    if ((i != 0) && (status.getCode() == Status.AREA_FULL_NONE)) {
  -			status = new Status(Status.AREA_FULL_SOME);
  -		    }
  -		    //areaContainer.end();
  -		    area.addChild(areaContainer);
  -		    area.increaseHeight(areaContainer.getHeight());
  -                    area.setAbsoluteHeight(areaContainer.getAbsoluteHeight()); 
  -		    return status;
  -		}
  -	    }
  -	}
  -        if (height != 0)
  -          areaContainer.setHeight(height);
  -
  -	for (int i = 0; i < numChildren; i++) {
  -	    FONode fo = (FONode) children.elementAt(i);
  -	    if (fo instanceof TableColumn) {
  -		((TableColumn)fo).setHeight(areaContainer.getHeight());
  -	    }
  -	}
  -
  -	areaContainer.end();
  -	area.addChild(areaContainer);
  -
  -	/* should this be combined into above? */
  -	area.increaseHeight(areaContainer.getHeight());
  -
  -        area.setAbsoluteHeight(areaContainer.getAbsoluteHeight()); 
  -        
  -	if (spaceAfter != 0) {
  -	    area.addDisplaySpace(spaceAfter);
  -	}
  -
  -	if (area instanceof BlockArea) {
  -	    area.start();
  -	}
  -
  -	if (breakAfter == BreakAfter.PAGE) {
  -	    this.marker = BREAK_AFTER;
  -	    return new Status(Status.FORCE_PAGE_BREAK);
  -	}
  -
  -	if (breakAfter == BreakAfter.ODD_PAGE) {
  -	    this.marker = BREAK_AFTER;
  -	    return new Status(Status.FORCE_PAGE_BREAK_ODD);
  -	}
  -	
  -	if (breakAfter == BreakAfter.EVEN_PAGE) {
  -	    this.marker = BREAK_AFTER;
  -	    return new Status(Status.FORCE_PAGE_BREAK_EVEN);
  -	}
  -
  -	return new Status(Status.OK);
  -    }
  -
  -    public int getAreaHeight() {
  -	return areaContainer.getHeight();
  -    }
  -}
  +/*-- $Id: Table.java,v 1.12 2000/06/22 00:25:45 jordan Exp $ -- 
  +
  + ============================================================================
  +                   The Apache Software License, Version 1.1
  + ============================================================================
  + 
  +    Copyright (C) 1999 The Apache Software Foundation. All rights reserved.
  + 
  + Redistribution and use in source and binary forms, with or without modifica-
  + tion, are permitted provided that the following conditions are met:
  + 
  + 1. Redistributions of  source code must  retain the above copyright  notice,
  +    this list of conditions and the following disclaimer.
  + 
  + 2. Redistributions in binary form must reproduce the above copyright notice,
  +    this list of conditions and the following disclaimer in the documentation
  +    and/or other materials provided with the distribution.
  + 
  + 3. The end-user documentation included with the redistribution, if any, must
  +    include  the following  acknowledgment:  "This product includes  software
  +    developed  by the  Apache Software Foundation  (http://www.apache.org/)."
  +    Alternately, this  acknowledgment may  appear in the software itself,  if
  +    and wherever such third-party acknowledgments normally appear.
  + 
  + 4. The names "FOP" and  "Apache Software Foundation"  must not be used to
  +    endorse  or promote  products derived  from this  software without  prior
  +    written permission. For written permission, please contact
  +    apache@apache.org.
  + 
  + 5. Products  derived from this software may not  be called "Apache", nor may
  +    "Apache" appear  in their name,  without prior written permission  of the
  +    Apache Software Foundation.
  + 
  + THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
  + INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  + FITNESS  FOR A PARTICULAR  PURPOSE ARE  DISCLAIMED.  IN NO  EVENT SHALL  THE
  + APACHE SOFTWARE  FOUNDATION  OR ITS CONTRIBUTORS  BE LIABLE FOR  ANY DIRECT,
  + INDIRECT, INCIDENTAL, SPECIAL,  EXEMPLARY, OR CONSEQUENTIAL  DAMAGES (INCLU-
  + DING, BUT NOT LIMITED TO, PROCUREMENT  OF SUBSTITUTE GOODS OR SERVICES; LOSS
  + OF USE, DATA, OR  PROFITS; OR BUSINESS  INTERRUPTION)  HOWEVER CAUSED AND ON
  + ANY  THEORY OF LIABILITY,  WHETHER  IN CONTRACT,  STRICT LIABILITY,  OR TORT
  + (INCLUDING  NEGLIGENCE OR  OTHERWISE) ARISING IN  ANY WAY OUT OF THE  USE OF
  + THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  + 
  + This software  consists of voluntary contributions made  by many individuals
  + on  behalf of the Apache Software  Foundation and was  originally created by
  + James Tauber <jt...@jtauber.com>. For more  information on the Apache 
  + Software Foundation, please see <http://www.apache.org/>.
  + 
  + */
  +
  +package org.apache.fop.fo.flow;
  +
  +// FOP
  +import org.apache.fop.fo.*;
  +import org.apache.fop.fo.properties.*;
  +import org.apache.fop.layout.*;
  +import org.apache.fop.datatypes.*;
  +import org.apache.fop.apps.FOPException;
  +
  +// Java
  +import java.util.Vector;
  +
  +public class Table extends FObj {
  +	
  +    public static class Maker extends FObj.Maker {
  +	public FObj make(FObj parent, PropertyList propertyList)
  +	    throws FOPException {
  +	    return new Table(parent, propertyList);
  +	}
  +    }
  +
  +    public static FObj.Maker maker() {
  +	return new Table.Maker();
  +    }
  +
  +    FontState fs;
  +    int breakBefore;
  +    int breakAfter;
  +    int spaceBefore;
  +    int spaceAfter;
  +    ColorType backgroundColor;
  +    int width;
  +    int height;
  +    ColorType borderColor;
  +    int borderWidth;
  +    int borderStyle;
  +    
  +
  +    Vector columns = new Vector();
  +    int currentColumnNumber = 0;
  +
  +    AreaContainer areaContainer;
  +
  +    public Table(FObj parent, PropertyList propertyList) {
  +	super(parent, propertyList);
  +	this.name = "fo:table";
  +    }
  +
  +    public Status layout(Area area) throws FOPException {
  +	if (this.marker == BREAK_AFTER) {
  +	    return new Status(Status.OK);
  +	}
  +
  +	if (this.marker == START) {
  +	    String fontFamily =
  +		this.properties.get("font-family").getString(); 
  +	    String fontStyle =
  +		this.properties.get("font-style").getString(); 
  +	    String fontWeight =
  +		this.properties.get("font-weight").getString(); 
  +	    int fontSize =
  +		this.properties.get("font-size").getLength().mvalue(); 
  +	    
  +	    this.fs = new FontState(area.getFontInfo(), fontFamily, 
  +				    fontStyle, fontWeight, fontSize);  
  +	    this.breakBefore =
  +		this.properties.get("break-before").getEnum(); 
  +	    this.breakAfter =
  +		this.properties.get("break-after").getEnum(); 
  +	    this.spaceBefore =
  +		this.properties.get("space-before.optimum").getLength().mvalue();  
  +	    this.spaceAfter =
  +		this.properties.get("space-after.optimum").getLength().mvalue(); 
  +	    this.backgroundColor =
  +		this.properties.get("background-color").getColorType();
  +	    this.width =
  +		this.properties.get("width").getLength().mvalue();
  +	    this.height =
  +		this.properties.get("height").getLength().mvalue();
  +            
  +	    this.borderColor =
  +		this.properties.get("border-color").getColorType();
  +	    this.borderWidth =
  +		this.properties.get("border-width").getLength().mvalue();
  +	    this.borderStyle =
  +		this.properties.get("border-style").getEnum();
  +
  +	    if (area instanceof BlockArea) {
  +		area.end();
  +	    }
  +
  +	    this.marker = 0;
  +
  +	    if (breakBefore == BreakBefore.PAGE) {
  +		return new Status(Status.FORCE_PAGE_BREAK);
  +	    }
  +
  +	    if (breakBefore == BreakBefore.ODD_PAGE) {
  +		return new Status(Status.FORCE_PAGE_BREAK_ODD);
  +	    }
  +	
  +	    if (breakBefore == BreakBefore.EVEN_PAGE) {
  +		return new Status(Status.FORCE_PAGE_BREAK_EVEN);
  +	    }
  +	}
  +
  +	if ((spaceBefore != 0) && (this.marker ==0)) {
  +	    area.addDisplaySpace(spaceBefore);
  +	}
  +
  +        if ( marker==0 ) {
  +            // initialize id                       
  +            String id = this.properties.get("id").getString();            
  +            area.getIDReferences().initializeID(id,area);                        
  +        }
  +
  +	this.areaContainer =
  +	    new AreaContainer(fs, 0, 0, area.getAllocationWidth(), 
  +                          area.spaceLeft(), Position.STATIC);
  +	areaContainer.setPage(area.getPage());
  +	areaContainer.setBackgroundColor(backgroundColor);
  +        areaContainer.setBorderStyle(borderStyle, borderStyle, borderStyle, borderStyle); 
  +        areaContainer.setBorderWidth(borderWidth, borderWidth, borderWidth, borderWidth); 
  +        areaContainer.setBorderColor(borderColor, borderColor, borderColor, borderColor); 
  +	areaContainer.start();
  +
  +        areaContainer.setAbsoluteHeight(area.getAbsoluteHeight());
  +        areaContainer.setIDReferences(area.getIDReferences());
  +
  +	// added by Eric Schaeffer
  +	currentColumnNumber = 0;
  +        int offset = 0;
  +
  +	int numChildren = this.children.size();
  +	for (int i = this.marker; i < numChildren; i++) {
  +	    FONode fo = (FONode) children.elementAt(i);
  +	    if (fo instanceof TableColumn) {
  +		TableColumn c = (TableColumn) fo;
  +		int num = c.getColumnNumber();
  +		if (num == 0) {
  +		    num = currentColumnNumber + 1;
  +		}
  +		currentColumnNumber = num;
  +		if (num > columns.size()) {
  +		    columns.setSize(num);
  +		}
  +		columns.setElementAt(c, num-1);
  +                c.setColumnOffset(offset);
  +		fo.layout(areaContainer);
  +                offset += c.getColumnWidth();
  +	    } else if (fo instanceof TableBody) {
  +		if (columns.size() == 0) {
  +		    System.err.println("WARNING: current implementation of tables requires a table-column for each column, indicating column-width");
  +		    return new Status(Status.OK);
  +		}
  +		
  +		((TableBody) fo).setColumns(columns);
  +
  +		Status status;
  +		if ((status = fo.layout(areaContainer)).isIncomplete()) {
  +		    this.marker = i;
  +		    if ((i != 0) && (status.getCode() == Status.AREA_FULL_NONE)) {
  +			status = new Status(Status.AREA_FULL_SOME);
  +		    }
  +		    //areaContainer.end();
  +		    area.addChild(areaContainer);
  +		    area.increaseHeight(areaContainer.getHeight());
  +                    area.setAbsoluteHeight(areaContainer.getAbsoluteHeight()); 
  +		    return status;
  +		}
  +	    }
  +	}
  +        if (height != 0)
  +          areaContainer.setHeight(height);
  +
  +	for (int i = 0; i < numChildren; i++) {
  +	    FONode fo = (FONode) children.elementAt(i);
  +	    if (fo instanceof TableColumn) {
  +		((TableColumn)fo).setHeight(areaContainer.getHeight());
  +	    }
  +	}
  +
  +	areaContainer.end();
  +	area.addChild(areaContainer);
  +
  +	/* should this be combined into above? */
  +	area.increaseHeight(areaContainer.getHeight());
  +
  +        area.setAbsoluteHeight(areaContainer.getAbsoluteHeight()); 
  +        
  +	if (spaceAfter != 0) {
  +	    area.addDisplaySpace(spaceAfter);
  +	}
  +
  +	if (area instanceof BlockArea) {
  +	    area.start();
  +	}
  +
  +	if (breakAfter == BreakAfter.PAGE) {
  +	    this.marker = BREAK_AFTER;
  +	    return new Status(Status.FORCE_PAGE_BREAK);
  +	}
  +
  +	if (breakAfter == BreakAfter.ODD_PAGE) {
  +	    this.marker = BREAK_AFTER;
  +	    return new Status(Status.FORCE_PAGE_BREAK_ODD);
  +	}
  +	
  +	if (breakAfter == BreakAfter.EVEN_PAGE) {
  +	    this.marker = BREAK_AFTER;
  +	    return new Status(Status.FORCE_PAGE_BREAK_EVEN);
  +	}
  +
  +	return new Status(Status.OK);
  +    }
  +
  +    public int getAreaHeight() {
  +	return areaContainer.getHeight();
  +    }
  +}
  
  
  
  1.12      +193 -186  xml-fop/src/org/apache/fop/fo/flow/TableBody.java
  
  Index: TableBody.java
  ===================================================================
  RCS file: /home/cvs/xml-fop/src/org/apache/fop/fo/flow/TableBody.java,v
  retrieving revision 1.11
  retrieving revision 1.12
  diff -u -r1.11 -r1.12
  --- TableBody.java	2000/06/14 01:59:32	1.11
  +++ TableBody.java	2000/06/22 00:25:45	1.12
  @@ -1,186 +1,193 @@
  -/*-- $Id: TableBody.java,v 1.11 2000/06/14 01:59:32 arved Exp $ -- 
  -
  - ============================================================================
  -                   The Apache Software License, Version 1.1
  - ============================================================================
  - 
  -    Copyright (C) 1999 The Apache Software Foundation. All rights reserved.
  - 
  - Redistribution and use in source and binary forms, with or without modifica-
  - tion, are permitted provided that the following conditions are met:
  - 
  - 1. Redistributions of  source code must  retain the above copyright  notice,
  -    this list of conditions and the following disclaimer.
  - 
  - 2. Redistributions in binary form must reproduce the above copyright notice,
  -    this list of conditions and the following disclaimer in the documentation
  -    and/or other materials provided with the distribution.
  - 
  - 3. The end-user documentation included with the redistribution, if any, must
  -    include  the following  acknowledgment:  "This product includes  software
  -    developed  by the  Apache Software Foundation  (http://www.apache.org/)."
  -    Alternately, this  acknowledgment may  appear in the software itself,  if
  -    and wherever such third-party acknowledgments normally appear.
  - 
  - 4. The names "FOP" and  "Apache Software Foundation"  must not be used to
  -    endorse  or promote  products derived  from this  software without  prior
  -    written permission. For written permission, please contact
  -    apache@apache.org.
  - 
  - 5. Products  derived from this software may not  be called "Apache", nor may
  -    "Apache" appear  in their name,  without prior written permission  of the
  -    Apache Software Foundation.
  - 
  - THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
  - INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  - FITNESS  FOR A PARTICULAR  PURPOSE ARE  DISCLAIMED.  IN NO  EVENT SHALL  THE
  - APACHE SOFTWARE  FOUNDATION  OR ITS CONTRIBUTORS  BE LIABLE FOR  ANY DIRECT,
  - INDIRECT, INCIDENTAL, SPECIAL,  EXEMPLARY, OR CONSEQUENTIAL  DAMAGES (INCLU-
  - DING, BUT NOT LIMITED TO, PROCUREMENT  OF SUBSTITUTE GOODS OR SERVICES; LOSS
  - OF USE, DATA, OR  PROFITS; OR BUSINESS  INTERRUPTION)  HOWEVER CAUSED AND ON
  - ANY  THEORY OF LIABILITY,  WHETHER  IN CONTRACT,  STRICT LIABILITY,  OR TORT
  - (INCLUDING  NEGLIGENCE OR  OTHERWISE) ARISING IN  ANY WAY OUT OF THE  USE OF
  - THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  - 
  - This software  consists of voluntary contributions made  by many individuals
  - on  behalf of the Apache Software  Foundation and was  originally created by
  - James Tauber <jt...@jtauber.com>. For more  information on the Apache 
  - Software Foundation, please see <http://www.apache.org/>.
  - 
  - */
  -
  -package org.apache.fop.fo.flow;
  -
  -// FOP
  -import org.apache.fop.fo.*;
  -import org.apache.fop.fo.properties.*;
  -import org.apache.fop.datatypes.*;
  -import org.apache.fop.layout.*;
  -import org.apache.fop.apps.FOPException;
  -
  -// Java
  -import java.util.Vector;
  -
  -public class TableBody extends FObj {
  -	
  -    public static class Maker extends FObj.Maker {
  -	public FObj make(FObj parent, PropertyList propertyList)
  -	    throws FOPException {
  -	    return new TableBody(parent, propertyList);
  -	}
  -    }
  -
  -    public static FObj.Maker maker() {
  -	return new TableBody.Maker();
  -    }
  -
  -    FontState fs;
  -    int spaceBefore;
  -    int spaceAfter;
  -    ColorType backgroundColor;
  -
  -    Vector columns;
  -
  -    AreaContainer areaContainer;
  -
  -    public TableBody(FObj parent, PropertyList propertyList) {
  -	super(parent, propertyList);
  -	this.name = "fo:table-body";
  -    }
  -
  -    public void setColumns(Vector columns) {
  -	this.columns = columns;
  -    }
  -
  -    public Status layout(Area area) throws FOPException {
  -	if (this.marker == BREAK_AFTER) {
  -	    return new Status(Status.OK);
  -	}
  -
  -	if (this.marker == START) {
  -	    String fontFamily =
  -		this.properties.get("font-family").getString(); 
  -	    String fontStyle =
  -		this.properties.get("font-style").getString(); 
  -	    String fontWeight =
  -		this.properties.get("font-weight").getString(); 
  -	    int fontSize =
  -		this.properties.get("font-size").getLength().mvalue(); 
  -	    
  -	    this.fs = new FontState(area.getFontInfo(), fontFamily, 
  -				    fontStyle, fontWeight, fontSize);  
  -	    this.spaceBefore =
  -		this.properties.get("space-before.optimum").getLength().mvalue();  
  -	    this.spaceAfter =
  -		this.properties.get("space-after.optimum").getLength().mvalue(); 
  -	    this.backgroundColor =
  -		this.properties.get("background-color").getColorType();
  -
  -	    if (area instanceof BlockArea) {
  -		area.end();
  -	    }
  -
  -	    //if (this.isInListBody) {
  -	    //startIndent += bodyIndent + distanceBetweenStarts;
  -	    //}
  -
  -	    this.marker = 0;
  -
  -	}
  -
  -	if ((spaceBefore != 0) && (this.marker ==0)) {
  -	    area.addDisplaySpace(spaceBefore);
  -	}
  -
  -	this.areaContainer =
  -	    new AreaContainer(fs, -area.borderWidthLeft, -area.borderWidthTop, area.getAllocationWidth(), 
  -			  area.spaceLeft(), Position.RELATIVE);
  -	areaContainer.setPage(area.getPage());
  -	areaContainer.setBackgroundColor(backgroundColor);
  -	areaContainer.start();
  -
  -        areaContainer.setAbsoluteHeight(area.getAbsoluteHeight());
  -
  -	int numChildren = this.children.size();
  -	for (int i = this.marker; i < numChildren; i++) {
  -	    TableRow row = (TableRow) children.elementAt(i);
  -
  -	    row.setColumns(columns);
  -
  -	    Status status;
  -	    if ((status = row.layout(areaContainer)).isIncomplete()) {
  -		this.marker = i;
  -		if ((i != 0) && (status.getCode() == Status.AREA_FULL_NONE)) {
  -		    status = new Status(Status.AREA_FULL_SOME);
  -		}
  -    	        area.addChild(areaContainer);
  -		//areaContainer.end();
  -
  -		area.increaseHeight(areaContainer.getHeight());
  -                area.setAbsoluteHeight(areaContainer.getAbsoluteHeight());
  -		return status;
  -	    }
  -	}
  -	area.addChild(areaContainer);
  -	areaContainer.end();
  -
  -	/* should this be combined into above? */
  -	area.increaseHeight(areaContainer.getHeight());
  -
  -        area.setAbsoluteHeight(areaContainer.getAbsoluteHeight());
  -
  -	if (spaceAfter != 0) {
  -	    area.addDisplaySpace(spaceAfter);
  -	}
  -
  -	if (area instanceof BlockArea) {
  -	    area.start();
  -	}
  -
  -	return new Status(Status.OK);
  -    }
  -
  -    public int getAreaHeight() {
  -	return areaContainer.getHeight();
  -    }
  -}
  +/*-- $Id: TableBody.java,v 1.12 2000/06/22 00:25:45 jordan Exp $ -- 
  +
  + ============================================================================
  +                   The Apache Software License, Version 1.1
  + ============================================================================
  + 
  +    Copyright (C) 1999 The Apache Software Foundation. All rights reserved.
  + 
  + Redistribution and use in source and binary forms, with or without modifica-
  + tion, are permitted provided that the following conditions are met:
  + 
  + 1. Redistributions of  source code must  retain the above copyright  notice,
  +    this list of conditions and the following disclaimer.
  + 
  + 2. Redistributions in binary form must reproduce the above copyright notice,
  +    this list of conditions and the following disclaimer in the documentation
  +    and/or other materials provided with the distribution.
  + 
  + 3. The end-user documentation included with the redistribution, if any, must
  +    include  the following  acknowledgment:  "This product includes  software
  +    developed  by the  Apache Software Foundation  (http://www.apache.org/)."
  +    Alternately, this  acknowledgment may  appear in the software itself,  if
  +    and wherever such third-party acknowledgments normally appear.
  + 
  + 4. The names "FOP" and  "Apache Software Foundation"  must not be used to
  +    endorse  or promote  products derived  from this  software without  prior
  +    written permission. For written permission, please contact
  +    apache@apache.org.
  + 
  + 5. Products  derived from this software may not  be called "Apache", nor may
  +    "Apache" appear  in their name,  without prior written permission  of the
  +    Apache Software Foundation.
  + 
  + THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
  + INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  + FITNESS  FOR A PARTICULAR  PURPOSE ARE  DISCLAIMED.  IN NO  EVENT SHALL  THE
  + APACHE SOFTWARE  FOUNDATION  OR ITS CONTRIBUTORS  BE LIABLE FOR  ANY DIRECT,
  + INDIRECT, INCIDENTAL, SPECIAL,  EXEMPLARY, OR CONSEQUENTIAL  DAMAGES (INCLU-
  + DING, BUT NOT LIMITED TO, PROCUREMENT  OF SUBSTITUTE GOODS OR SERVICES; LOSS
  + OF USE, DATA, OR  PROFITS; OR BUSINESS  INTERRUPTION)  HOWEVER CAUSED AND ON
  + ANY  THEORY OF LIABILITY,  WHETHER  IN CONTRACT,  STRICT LIABILITY,  OR TORT
  + (INCLUDING  NEGLIGENCE OR  OTHERWISE) ARISING IN  ANY WAY OUT OF THE  USE OF
  + THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  + 
  + This software  consists of voluntary contributions made  by many individuals
  + on  behalf of the Apache Software  Foundation and was  originally created by
  + James Tauber <jt...@jtauber.com>. For more  information on the Apache 
  + Software Foundation, please see <http://www.apache.org/>.
  + 
  + */
  +
  +package org.apache.fop.fo.flow;
  +
  +// FOP
  +import org.apache.fop.fo.*;
  +import org.apache.fop.fo.properties.*;
  +import org.apache.fop.datatypes.*;
  +import org.apache.fop.layout.*;
  +import org.apache.fop.apps.FOPException;
  +
  +// Java
  +import java.util.Vector;
  +
  +public class TableBody extends FObj {
  +	
  +    public static class Maker extends FObj.Maker {
  +	public FObj make(FObj parent, PropertyList propertyList)
  +	    throws FOPException {
  +	    return new TableBody(parent, propertyList);
  +	}
  +    }
  +
  +    public static FObj.Maker maker() {
  +	return new TableBody.Maker();
  +    }
  +
  +    FontState fs;
  +    int spaceBefore;
  +    int spaceAfter;
  +    ColorType backgroundColor;
  +
  +    Vector columns;
  +
  +    AreaContainer areaContainer;
  +
  +    public TableBody(FObj parent, PropertyList propertyList) {
  +	super(parent, propertyList);
  +	this.name = "fo:table-body";
  +    }
  +
  +    public void setColumns(Vector columns) {
  +	this.columns = columns;
  +    }
  +
  +    public Status layout(Area area) throws FOPException {
  +	if (this.marker == BREAK_AFTER) {
  +	    return new Status(Status.OK);
  +	}
  +
  +	if (this.marker == START) {
  +	    String fontFamily =
  +		this.properties.get("font-family").getString(); 
  +	    String fontStyle =
  +		this.properties.get("font-style").getString(); 
  +	    String fontWeight =
  +		this.properties.get("font-weight").getString(); 
  +	    int fontSize =
  +		this.properties.get("font-size").getLength().mvalue(); 
  +	    
  +	    this.fs = new FontState(area.getFontInfo(), fontFamily, 
  +				    fontStyle, fontWeight, fontSize);  
  +	    this.spaceBefore =
  +		this.properties.get("space-before.optimum").getLength().mvalue();  
  +	    this.spaceAfter =
  +		this.properties.get("space-after.optimum").getLength().mvalue(); 
  +	    this.backgroundColor =
  +		this.properties.get("background-color").getColorType();
  +
  +	    if (area instanceof BlockArea) {
  +		area.end();
  +	    }
  +
  +	    //if (this.isInListBody) {
  +	    //startIndent += bodyIndent + distanceBetweenStarts;
  +	    //}
  +
  +	    this.marker = 0;
  +
  +	}
  +
  +	if ((spaceBefore != 0) && (this.marker ==0)) {
  +	    area.addDisplaySpace(spaceBefore);
  +	}
  +
  +        if ( marker==0 ) {
  +            // initialize id                       
  +            String id = this.properties.get("id").getString();            
  +            area.getIDReferences().initializeID(id,area);                        
  +        }
  +
  +	this.areaContainer =
  +	    new AreaContainer(fs, -area.borderWidthLeft, -area.borderWidthTop, area.getAllocationWidth(), 
  +			  area.spaceLeft(), Position.RELATIVE);
  +	areaContainer.setPage(area.getPage());
  +	areaContainer.setBackgroundColor(backgroundColor);
  +	areaContainer.start();
  +
  +        areaContainer.setAbsoluteHeight(area.getAbsoluteHeight());
  +        areaContainer.setIDReferences(area.getIDReferences());
  +
  +	int numChildren = this.children.size();
  +	for (int i = this.marker; i < numChildren; i++) {
  +	    TableRow row = (TableRow) children.elementAt(i);
  +
  +	    row.setColumns(columns);
  +
  +	    Status status;
  +	    if ((status = row.layout(areaContainer)).isIncomplete()) {
  +		this.marker = i;
  +		if ((i != 0) && (status.getCode() == Status.AREA_FULL_NONE)) {
  +		    status = new Status(Status.AREA_FULL_SOME);
  +		}
  +    	        area.addChild(areaContainer);
  +		//areaContainer.end();
  +
  +		area.increaseHeight(areaContainer.getHeight());
  +                area.setAbsoluteHeight(areaContainer.getAbsoluteHeight());
  +		return status;
  +	    }
  +	}
  +	area.addChild(areaContainer);
  +	areaContainer.end();
  +
  +	/* should this be combined into above? */
  +	area.increaseHeight(areaContainer.getHeight());
  +
  +        area.setAbsoluteHeight(areaContainer.getAbsoluteHeight());
  +
  +	if (spaceAfter != 0) {
  +	    area.addDisplaySpace(spaceAfter);
  +	}
  +
  +	if (area instanceof BlockArea) {
  +	    area.start();
  +	}
  +
  +	return new Status(Status.OK);
  +    }
  +
  +    public int getAreaHeight() {
  +	return areaContainer.getHeight();
  +    }
  +}
  
  
  
  1.13      +219 -212  xml-fop/src/org/apache/fop/fo/flow/TableCell.java
  
  Index: TableCell.java
  ===================================================================
  RCS file: /home/cvs/xml-fop/src/org/apache/fop/fo/flow/TableCell.java,v
  retrieving revision 1.12
  retrieving revision 1.13
  diff -u -r1.12 -r1.13
  --- TableCell.java	2000/06/14 01:59:11	1.12
  +++ TableCell.java	2000/06/22 00:25:45	1.13
  @@ -1,212 +1,219 @@
  -/*-- $Id: TableCell.java,v 1.12 2000/06/14 01:59:11 arved Exp $ -- 
  -
  - ============================================================================
  -                   The Apache Software License, Version 1.1
  - ============================================================================
  - 
  -    Copyright (C) 1999 The Apache Software Foundation. All rights reserved.
  - 
  - Redistribution and use in source and binary forms, with or without modifica-
  - tion, are permitted provided that the following conditions are met:
  - 
  - 1. Redistributions of  source code must  retain the above copyright  notice,
  -    this list of conditions and the following disclaimer.
  - 
  - 2. Redistributions in binary form must reproduce the above copyright notice,
  -    this list of conditions and the following disclaimer in the documentation
  -    and/or other materials provided with the distribution.
  - 
  - 3. The end-user documentation included with the redistribution, if any, must
  -    include  the following  acknowledgment:  "This product includes  software
  -    developed  by the  Apache Software Foundation  (http://www.apache.org/)."
  -    Alternately, this  acknowledgment may  appear in the software itself,  if
  -    and wherever such third-party acknowledgments normally appear.
  - 
  - 4. The names "FOP" and  "Apache Software Foundation"  must not be used to
  -    endorse  or promote  products derived  from this  software without  prior
  -    written permission. For written permission, please contact
  -    apache@apache.org.
  - 
  - 5. Products  derived from this software may not  be called "Apache", nor may
  -    "Apache" appear  in their name,  without prior written permission  of the
  -    Apache Software Foundation.
  - 
  - THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
  - INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  - FITNESS  FOR A PARTICULAR  PURPOSE ARE  DISCLAIMED.  IN NO  EVENT SHALL  THE
  - APACHE SOFTWARE  FOUNDATION  OR ITS CONTRIBUTORS  BE LIABLE FOR  ANY DIRECT,
  - INDIRECT, INCIDENTAL, SPECIAL,  EXEMPLARY, OR CONSEQUENTIAL  DAMAGES (INCLU-
  - DING, BUT NOT LIMITED TO, PROCUREMENT  OF SUBSTITUTE GOODS OR SERVICES; LOSS
  - OF USE, DATA, OR  PROFITS; OR BUSINESS  INTERRUPTION)  HOWEVER CAUSED AND ON
  - ANY  THEORY OF LIABILITY,  WHETHER  IN CONTRACT,  STRICT LIABILITY,  OR TORT
  - (INCLUDING  NEGLIGENCE OR  OTHERWISE) ARISING IN  ANY WAY OUT OF THE  USE OF
  - THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  - 
  - This software  consists of voluntary contributions made  by many individuals
  - on  behalf of the Apache Software  Foundation and was  originally created by
  - James Tauber <jt...@jtauber.com>. For more  information on the Apache 
  - Software Foundation, please see <http://www.apache.org/>.
  - 
  - */
  -package org.apache.fop.fo.flow;
  -
  -// FOP
  -import org.apache.fop.fo.*;
  -import org.apache.fop.fo.properties.*;
  -import org.apache.fop.layout.*;
  -import org.apache.fop.apps.FOPException;
  -import org.apache.fop.datatypes.*;
  -
  -public class TableCell extends FObj {
  -
  -    public static class Maker extends FObj.Maker {
  -	public FObj make(FObj parent, PropertyList propertyList)
  -	    throws FOPException {
  -	    return new TableCell(parent, propertyList);
  -	}
  -    }
  -
  -    public static FObj.Maker maker() {
  -	return new TableCell.Maker();
  -    }
  -
  -    int spaceBefore;
  -    int spaceAfter;
  -    ColorType backgroundColor;
  -
  -    FontState fs;
  -    ColorType borderColor;
  -    int borderWidth;
  -    int borderStyle;
  -    int paddingTop;
  -    int paddingBottom;
  -    int paddingLeft;
  -    int paddingRight;
  -    int position;
  -    
  -    protected int startOffset;
  -    protected int width;
  -    protected int height = 0;
  -
  -    AreaContainer areaContainer;
  -
  -    public TableCell(FObj parent, PropertyList propertyList) {
  -	super(parent, propertyList);
  -	this.name = "fo:table-cell";
  -    }
  -
  -    public void setStartOffset(int offset) {
  -	startOffset = offset;
  -    }
  -
  -    public void setWidth(int width) {
  -	this.width = width;
  -    }
  -
  -    public Status layout(Area area) throws FOPException {
  -	if (this.marker == BREAK_AFTER) {
  -	    return new Status(Status.OK);
  -	}
  -
  -	if (this.marker == START) {
  -	    String fontFamily =
  -		this.properties.get("font-family").getString(); 
  -	    String fontStyle =
  -		this.properties.get("font-style").getString(); 
  -	    String fontWeight =
  -		this.properties.get("font-weight").getString(); 
  -	    int fontSize =
  -		this.properties.get("font-size").getLength().mvalue(); 
  -	    
  -	    this.fs = new FontState(area.getFontInfo(), fontFamily, 
  -				    fontStyle, fontWeight, fontSize);  
  -	    this.borderColor =
  -		this.properties.get("border-color").getColorType();
  -	    this.borderWidth =
  -		this.properties.get("border-width").getLength().mvalue();
  -	    this.borderStyle =
  -		this.properties.get("border-style").getEnum();
  -	    this.paddingTop =
  -		this.properties.get("padding").getLength().mvalue();
  -            this.paddingLeft = this.paddingTop;
  -            this.paddingRight = this.paddingTop;
  -            this.paddingBottom = this.paddingTop;
  -            if (this.paddingTop == 0) {
  -	      this.paddingTop =
  -		  this.properties.get("padding-top").getLength().mvalue();
  -	      this.paddingLeft =
  -		  this.properties.get("padding-left").getLength().mvalue();
  -	      this.paddingBottom =
  -		  this.properties.get("padding-bottom").getLength().mvalue();
  -	      this.paddingRight =
  -		  this.properties.get("padding-right").getLength().mvalue();
  -            }
  -	    
  -	    this.spaceBefore =
  -		this.properties.get("space-before.optimum").getLength().mvalue();  
  -	    this.spaceAfter =
  -		this.properties.get("space-after.optimum").getLength().mvalue(); 
  -	    this.backgroundColor =
  -		this.properties.get("background-color").getColorType();
  -
  -	    if (area instanceof BlockArea) {
  -		area.end();
  -	    }
  -
  -	    //if (this.isInListBody) {
  -	    //startIndent += bodyIndent + distanceBetweenStarts;
  -	    //}
  -
  -	    this.marker = 0;
  -
  -	}
  -
  -	if ((spaceBefore != 0) && (this.marker ==0)) {
  -	    area.addDisplaySpace(spaceBefore);
  -	}
  -
  -	this.areaContainer =
  -	    new AreaContainer(fs, startOffset - area.borderWidthLeft,
  -                              - area.borderWidthTop,
  -                          width, area.spaceLeft(), Position.RELATIVE);
  -	areaContainer.setPage(area.getPage());
  -	areaContainer.setPadding(paddingTop, paddingLeft, paddingBottom,
  -			     paddingRight);
  -	areaContainer.setBackgroundColor(backgroundColor);
  -        areaContainer.setBorderStyle(borderStyle, borderStyle, borderStyle, borderStyle); 
  -        areaContainer.setBorderWidth(borderWidth, borderWidth, borderWidth, borderWidth); 
  -        areaContainer.setBorderColor(borderColor, borderColor, borderColor, borderColor); 
  -	areaContainer.start();
  -
  -        areaContainer.setAbsoluteHeight(area.getAbsoluteHeight());
  -        areaContainer.setTableCellXOffset(startOffset);
  -	int numChildren = this.children.size();
  -	for (int i = this.marker; i < numChildren; i++) {
  -	    FObj fo = (FObj) children.elementAt(i);
  -	    fo.setIsInTableCell();
  -	    fo.forceWidth(width);
  -	    Status status;
  -	    if ((status = fo.layout(areaContainer)).isIncomplete()) {
  -		this.marker = i;
  -		if ((i == 0) && (status.getCode() == Status.AREA_FULL_NONE)) {
  -		    return new Status(Status.AREA_FULL_NONE);
  -		} else {
  -		    return new Status(Status.AREA_FULL_SOME);
  -		}
  -	    }
  -	}
  -	areaContainer.end();
  -	area.addChild(areaContainer);
  -
  -	return new Status(Status.OK);
  -    }
  -
  -    public int getHeight() {
  -	return areaContainer.getHeight();;
  -    }
  -    
  -    public void setHeight(int height) {
  -	areaContainer.setMaxHeight(height);
  -	areaContainer.setHeight(height);
  -    }
  -}
  +/*-- $Id: TableCell.java,v 1.13 2000/06/22 00:25:45 jordan Exp $ -- 
  +
  + ============================================================================
  +                   The Apache Software License, Version 1.1
  + ============================================================================
  + 
  +    Copyright (C) 1999 The Apache Software Foundation. All rights reserved.
  + 
  + Redistribution and use in source and binary forms, with or without modifica-
  + tion, are permitted provided that the following conditions are met:
  + 
  + 1. Redistributions of  source code must  retain the above copyright  notice,
  +    this list of conditions and the following disclaimer.
  + 
  + 2. Redistributions in binary form must reproduce the above copyright notice,
  +    this list of conditions and the following disclaimer in the documentation
  +    and/or other materials provided with the distribution.
  + 
  + 3. The end-user documentation included with the redistribution, if any, must
  +    include  the following  acknowledgment:  "This product includes  software
  +    developed  by the  Apache Software Foundation  (http://www.apache.org/)."
  +    Alternately, this  acknowledgment may  appear in the software itself,  if
  +    and wherever such third-party acknowledgments normally appear.
  + 
  + 4. The names "FOP" and  "Apache Software Foundation"  must not be used to
  +    endorse  or promote  products derived  from this  software without  prior
  +    written permission. For written permission, please contact
  +    apache@apache.org.
  + 
  + 5. Products  derived from this software may not  be called "Apache", nor may
  +    "Apache" appear  in their name,  without prior written permission  of the
  +    Apache Software Foundation.
  + 
  + THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
  + INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  + FITNESS  FOR A PARTICULAR  PURPOSE ARE  DISCLAIMED.  IN NO  EVENT SHALL  THE
  + APACHE SOFTWARE  FOUNDATION  OR ITS CONTRIBUTORS  BE LIABLE FOR  ANY DIRECT,
  + INDIRECT, INCIDENTAL, SPECIAL,  EXEMPLARY, OR CONSEQUENTIAL  DAMAGES (INCLU-
  + DING, BUT NOT LIMITED TO, PROCUREMENT  OF SUBSTITUTE GOODS OR SERVICES; LOSS
  + OF USE, DATA, OR  PROFITS; OR BUSINESS  INTERRUPTION)  HOWEVER CAUSED AND ON
  + ANY  THEORY OF LIABILITY,  WHETHER  IN CONTRACT,  STRICT LIABILITY,  OR TORT
  + (INCLUDING  NEGLIGENCE OR  OTHERWISE) ARISING IN  ANY WAY OUT OF THE  USE OF
  + THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  + 
  + This software  consists of voluntary contributions made  by many individuals
  + on  behalf of the Apache Software  Foundation and was  originally created by
  + James Tauber <jt...@jtauber.com>. For more  information on the Apache 
  + Software Foundation, please see <http://www.apache.org/>.
  + 
  + */
  +package org.apache.fop.fo.flow;
  +
  +// FOP
  +import org.apache.fop.fo.*;
  +import org.apache.fop.fo.properties.*;
  +import org.apache.fop.layout.*;
  +import org.apache.fop.apps.FOPException;
  +import org.apache.fop.datatypes.*;
  +
  +public class TableCell extends FObj {
  +
  +    public static class Maker extends FObj.Maker {
  +	public FObj make(FObj parent, PropertyList propertyList)
  +	    throws FOPException {
  +	    return new TableCell(parent, propertyList);
  +	}
  +    }
  +
  +    public static FObj.Maker maker() {
  +	return new TableCell.Maker();
  +    }
  +
  +    int spaceBefore;
  +    int spaceAfter;
  +    ColorType backgroundColor;
  +
  +    FontState fs;
  +    ColorType borderColor;
  +    int borderWidth;
  +    int borderStyle;
  +    int paddingTop;
  +    int paddingBottom;
  +    int paddingLeft;
  +    int paddingRight;
  +    int position;
  +    
  +    protected int startOffset;
  +    protected int width;
  +    protected int height = 0;
  +
  +    AreaContainer areaContainer;
  +
  +    public TableCell(FObj parent, PropertyList propertyList) {
  +	super(parent, propertyList);
  +	this.name = "fo:table-cell";
  +    }
  +
  +    public void setStartOffset(int offset) {
  +	startOffset = offset;
  +    }
  +
  +    public void setWidth(int width) {
  +	this.width = width;
  +    }
  +
  +    public Status layout(Area area) throws FOPException {
  +	if (this.marker == BREAK_AFTER) {
  +	    return new Status(Status.OK);
  +	}
  +
  +	if (this.marker == START) {
  +	    String fontFamily =
  +		this.properties.get("font-family").getString(); 
  +	    String fontStyle =
  +		this.properties.get("font-style").getString(); 
  +	    String fontWeight =
  +		this.properties.get("font-weight").getString(); 
  +	    int fontSize =
  +		this.properties.get("font-size").getLength().mvalue(); 
  +	    
  +	    this.fs = new FontState(area.getFontInfo(), fontFamily, 
  +				    fontStyle, fontWeight, fontSize);  
  +	    this.borderColor =
  +		this.properties.get("border-color").getColorType();
  +	    this.borderWidth =
  +		this.properties.get("border-width").getLength().mvalue();
  +	    this.borderStyle =
  +		this.properties.get("border-style").getEnum();
  +	    this.paddingTop =
  +		this.properties.get("padding").getLength().mvalue();
  +            this.paddingLeft = this.paddingTop;
  +            this.paddingRight = this.paddingTop;
  +            this.paddingBottom = this.paddingTop;
  +            if (this.paddingTop == 0) {
  +	      this.paddingTop =
  +		  this.properties.get("padding-top").getLength().mvalue();
  +	      this.paddingLeft =
  +		  this.properties.get("padding-left").getLength().mvalue();
  +	      this.paddingBottom =
  +		  this.properties.get("padding-bottom").getLength().mvalue();
  +	      this.paddingRight =
  +		  this.properties.get("padding-right").getLength().mvalue();
  +            }
  +	    
  +	    this.spaceBefore =
  +		this.properties.get("space-before.optimum").getLength().mvalue();  
  +	    this.spaceAfter =
  +		this.properties.get("space-after.optimum").getLength().mvalue(); 
  +	    this.backgroundColor =
  +		this.properties.get("background-color").getColorType();
  +
  +	    if (area instanceof BlockArea) {
  +		area.end();
  +	    }
  +
  +	    //if (this.isInListBody) {
  +	    //startIndent += bodyIndent + distanceBetweenStarts;
  +	    //}
  +
  +	    this.marker = 0;
  +
  +	}
  +
  +	if ((spaceBefore != 0) && (this.marker ==0)) {
  +	    area.addDisplaySpace(spaceBefore);
  +	}
  +
  +        if ( marker==0 ) {
  +            // initialize id                       
  +            String id = this.properties.get("id").getString();            
  +            area.getIDReferences().initializeID(id,area);                        
  +        }
  +
  +	this.areaContainer =
  +	    new AreaContainer(fs, startOffset - area.borderWidthLeft,
  +                              - area.borderWidthTop,
  +                          width, area.spaceLeft(), Position.RELATIVE);
  +	areaContainer.setPage(area.getPage());
  +	areaContainer.setPadding(paddingTop, paddingLeft, paddingBottom,
  +			     paddingRight);
  +	areaContainer.setBackgroundColor(backgroundColor);
  +        areaContainer.setBorderStyle(borderStyle, borderStyle, borderStyle, borderStyle); 
  +        areaContainer.setBorderWidth(borderWidth, borderWidth, borderWidth, borderWidth); 
  +        areaContainer.setBorderColor(borderColor, borderColor, borderColor, borderColor); 
  +	areaContainer.start();
  +
  +        areaContainer.setAbsoluteHeight(area.getAbsoluteHeight());
  +        areaContainer.setIDReferences(area.getIDReferences());
  +        areaContainer.setTableCellXOffset(startOffset);
  +	int numChildren = this.children.size();
  +	for (int i = this.marker; i < numChildren; i++) {
  +	    FObj fo = (FObj) children.elementAt(i);
  +	    fo.setIsInTableCell();
  +	    fo.forceWidth(width);
  +	    Status status;
  +	    if ((status = fo.layout(areaContainer)).isIncomplete()) {
  +		this.marker = i;
  +		if ((i == 0) && (status.getCode() == Status.AREA_FULL_NONE)) {
  +		    return new Status(Status.AREA_FULL_NONE);
  +		} else {
  +		    return new Status(Status.AREA_FULL_SOME);
  +		}
  +	    }
  +	}
  +	areaContainer.end();
  +	area.addChild(areaContainer);
  +
  +	return new Status(Status.OK);
  +    }
  +
  +    public int getHeight() {
  +	return areaContainer.getHeight();;
  +    }
  +    
  +    public void setHeight(int height) {
  +	areaContainer.setMaxHeight(height);
  +	areaContainer.setHeight(height);
  +    }
  +}
  
  
  
  1.14      +232 -225  xml-fop/src/org/apache/fop/fo/flow/TableRow.java
  
  Index: TableRow.java
  ===================================================================
  RCS file: /home/cvs/xml-fop/src/org/apache/fop/fo/flow/TableRow.java,v
  retrieving revision 1.13
  retrieving revision 1.14
  diff -u -r1.13 -r1.14
  --- TableRow.java	2000/06/14 01:58:53	1.13
  +++ TableRow.java	2000/06/22 00:25:45	1.14
  @@ -1,225 +1,232 @@
  -/*-- $Id: TableRow.java,v 1.13 2000/06/14 01:58:53 arved Exp $ -- 
  -
  - ============================================================================
  -                   The Apache Software License, Version 1.1
  - ============================================================================
  - 
  -    Copyright (C) 1999 The Apache Software Foundation. All rights reserved.
  - 
  - Redistribution and use in source and binary forms, with or without modifica-
  - tion, are permitted provided that the following conditions are met:
  - 
  - 1. Redistributions of  source code must  retain the above copyright  notice,
  -    this list of conditions and the following disclaimer.
  - 
  - 2. Redistributions in binary form must reproduce the above copyright notice,
  -    this list of conditions and the following disclaimer in the documentation
  -    and/or other materials provided with the distribution.
  - 
  - 3. The end-user documentation included with the redistribution, if any, must
  -    include  the following  acknowledgment:  "This product includes  software
  -    developed  by the  Apache Software Foundation  (http://www.apache.org/)."
  -    Alternately, this  acknowledgment may  appear in the software itself,  if
  -    and wherever such third-party acknowledgments normally appear.
  - 
  - 4. The names "FOP" and  "Apache Software Foundation"  must not be used to
  -    endorse  or promote  products derived  from this  software without  prior
  -    written permission. For written permission, please contact
  -    apache@apache.org.
  - 
  - 5. Products  derived from this software may not  be called "Apache", nor may
  -    "Apache" appear  in their name,  without prior written permission  of the
  -    Apache Software Foundation.
  - 
  - THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
  - INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  - FITNESS  FOR A PARTICULAR  PURPOSE ARE  DISCLAIMED.  IN NO  EVENT SHALL  THE
  - APACHE SOFTWARE  FOUNDATION  OR ITS CONTRIBUTORS  BE LIABLE FOR  ANY DIRECT,
  - INDIRECT, INCIDENTAL, SPECIAL,  EXEMPLARY, OR CONSEQUENTIAL  DAMAGES (INCLU-
  - DING, BUT NOT LIMITED TO, PROCUREMENT  OF SUBSTITUTE GOODS OR SERVICES; LOSS
  - OF USE, DATA, OR  PROFITS; OR BUSINESS  INTERRUPTION)  HOWEVER CAUSED AND ON
  - ANY  THEORY OF LIABILITY,  WHETHER  IN CONTRACT,  STRICT LIABILITY,  OR TORT
  - (INCLUDING  NEGLIGENCE OR  OTHERWISE) ARISING IN  ANY WAY OUT OF THE  USE OF
  - THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  - 
  - This software  consists of voluntary contributions made  by many individuals
  - on  behalf of the Apache Software  Foundation and was  originally created by
  - James Tauber <jt...@jtauber.com>. For more  information on the Apache 
  - Software Foundation, please see <http://www.apache.org/>.
  - 
  - */
  -
  -package org.apache.fop.fo.flow;
  -
  -// FOP
  -import org.apache.fop.fo.*;
  -import org.apache.fop.fo.properties.*;
  -import org.apache.fop.datatypes.*;
  -import org.apache.fop.layout.*;
  -import org.apache.fop.apps.FOPException;
  -
  -// Java
  -import java.util.Vector;
  -
  -public class TableRow extends FObj {
  -	
  -    public static class Maker extends FObj.Maker {
  -	public FObj make(FObj parent, PropertyList propertyList)
  -	    throws FOPException {
  -	    return new TableRow(parent, propertyList);
  -	}
  -    }
  -
  -    public static FObj.Maker maker() {
  -	return new TableRow.Maker();
  -    }
  -
  -    FontState fs;
  -    int spaceBefore;
  -    int spaceAfter;
  -    ColorType backgroundColor;
  -    
  -    ColorType borderColor;
  -    int borderWidth;
  -    int borderStyle;
  -
  -    int widthOfCellsSoFar = 0;
  -    int largestCellHeight = 0;
  -
  -    Vector columns;
  -
  -    AreaContainer areaContainer;
  -
  -    public TableRow(FObj parent, PropertyList propertyList) {
  -	super(parent, propertyList);
  -	this.name = "fo:table-row";
  -    }
  -
  -    public void setColumns(Vector columns) {
  -	this.columns = columns;
  -    }
  -
  -    public Status layout(Area area) throws FOPException {
  -	if (this.marker == BREAK_AFTER) {
  -	    return new Status(Status.OK);
  -	}
  -
  -	if (this.marker == START) {
  -	    String fontFamily =
  -		this.properties.get("font-family").getString(); 
  -	    String fontStyle =
  -		this.properties.get("font-style").getString(); 
  -	    String fontWeight =
  -		this.properties.get("font-weight").getString(); 
  -	    int fontSize =
  -		this.properties.get("font-size").getLength().mvalue(); 
  -	    
  -	    this.fs = new FontState(area.getFontInfo(), fontFamily, 
  -				    fontStyle, fontWeight, fontSize);  
  -	    this.spaceBefore =
  -		this.properties.get("space-before.optimum").getLength().mvalue();  
  -	    this.spaceAfter =
  -		this.properties.get("space-after.optimum").getLength().mvalue(); 
  -	    this.backgroundColor =
  -		this.properties.get("background-color").getColorType();
  -	    this.borderColor =
  -		this.properties.get("border-color").getColorType();
  -	    this.borderWidth =
  -		this.properties.get("border-width").getLength().mvalue();
  -	    this.borderStyle =
  -		this.properties.get("border-style").getEnum();
  -
  -	    if (area instanceof BlockArea) {
  -		area.end();
  -	    }
  -
  -	    this.marker = 0;
  -
  -	}
  -
  -	if ((spaceBefore != 0) && (this.marker ==0)) {
  -	    area.addDisplaySpace(spaceBefore);
  -	}
  -
  -	this.areaContainer =
  -	    new AreaContainer(fs, -area.borderWidthLeft, -area.borderWidthTop, 
  -                           area.getAllocationWidth(), 
  -			  area.spaceLeft(), Position.RELATIVE);
  -	areaContainer.setPage(area.getPage());
  -	areaContainer.setBackgroundColor(backgroundColor);
  -        areaContainer.setBorderStyle(borderStyle, borderStyle, borderStyle, borderStyle); 
  -        areaContainer.setBorderWidth(borderWidth, borderWidth, borderWidth, borderWidth); 
  -        areaContainer.setBorderColor(borderColor, borderColor, borderColor, borderColor); 
  -	areaContainer.start();
  -
  -        areaContainer.setAbsoluteHeight(area.getAbsoluteHeight());
  -
  -	int numChildren = this.children.size();
  -	if (numChildren != columns.size()) {
  -	    System.err.println("WARNING: Number of children under table-row not equal to number of table-columns");
  -	    return new Status(Status.OK);
  -	}
  -
  -	// added by Eric Schaeffer
  -	widthOfCellsSoFar = 0;
  -	largestCellHeight = 0;
  -
  -	for (int i = this.marker; i < numChildren; i++) {
  -	    TableCell cell = (TableCell) children.elementAt(i);
  -
  -	    //if (this.isInListBody) {
  -	    //fo.setIsInListBody();
  -	    //fo.setDistanceBetweenStarts(this.distanceBetweenStarts);
  -	    //fo.setBodyIndent(this.bodyIndent);
  -	    //}
  -
  -	    cell.setStartOffset(widthOfCellsSoFar);
  -	    int width = ((TableColumn) columns.elementAt(i)).getColumnWidth();
  -
  -	    cell.setWidth(width);
  -	    widthOfCellsSoFar += width;
  -
  -	    Status status;
  -	    if ((status = cell.layout(areaContainer)).isIncomplete()) {
  -		this.marker = i;
  -		if ((i != 0) && (status.getCode() == Status.AREA_FULL_NONE)) {
  -		    status = new Status(Status.AREA_FULL_SOME);
  -		}
  -    	        area.addChild(areaContainer);
  -		//areaContainer.end();
  -		area.addDisplaySpace(areaContainer.getHeight());
  -		return status;
  -	    }
  -
  -	    int h = cell.getHeight();
  -	    if (h > largestCellHeight) {
  -		largestCellHeight = h;
  -	    }
  -	}
  -	for (int i = 0; i < numChildren; i++) {
  -	    TableCell cell = (TableCell)children.elementAt(i);
  -            cell.setHeight(largestCellHeight);
  -	}
  -
  -	area.addChild(areaContainer);
  -	areaContainer.end();
  -        area.addDisplaySpace(largestCellHeight);
  -
  -	// bug fix from Eric Schaeffer
  -	//area.increaseHeight(largestCellHeight);
  -
  -	if (spaceAfter != 0) {
  -	    area.addDisplaySpace(spaceAfter);
  -	}
  -
  -	if (area instanceof BlockArea) {
  -	    area.start();
  -	}
  -
  -	return new Status(Status.OK);
  -    }
  -
  -    public int getAreaHeight() {
  -	return areaContainer.getHeight();
  -    }
  -}
  +/*-- $Id: TableRow.java,v 1.14 2000/06/22 00:25:45 jordan Exp $ -- 
  +
  + ============================================================================
  +                   The Apache Software License, Version 1.1
  + ============================================================================
  + 
  +    Copyright (C) 1999 The Apache Software Foundation. All rights reserved.
  + 
  + Redistribution and use in source and binary forms, with or without modifica-
  + tion, are permitted provided that the following conditions are met:
  + 
  + 1. Redistributions of  source code must  retain the above copyright  notice,
  +    this list of conditions and the following disclaimer.
  + 
  + 2. Redistributions in binary form must reproduce the above copyright notice,
  +    this list of conditions and the following disclaimer in the documentation
  +    and/or other materials provided with the distribution.
  + 
  + 3. The end-user documentation included with the redistribution, if any, must
  +    include  the following  acknowledgment:  "This product includes  software
  +    developed  by the  Apache Software Foundation  (http://www.apache.org/)."
  +    Alternately, this  acknowledgment may  appear in the software itself,  if
  +    and wherever such third-party acknowledgments normally appear.
  + 
  + 4. The names "FOP" and  "Apache Software Foundation"  must not be used to
  +    endorse  or promote  products derived  from this  software without  prior
  +    written permission. For written permission, please contact
  +    apache@apache.org.
  + 
  + 5. Products  derived from this software may not  be called "Apache", nor may
  +    "Apache" appear  in their name,  without prior written permission  of the
  +    Apache Software Foundation.
  + 
  + THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED WARRANTIES,
  + INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
  + FITNESS  FOR A PARTICULAR  PURPOSE ARE  DISCLAIMED.  IN NO  EVENT SHALL  THE
  + APACHE SOFTWARE  FOUNDATION  OR ITS CONTRIBUTORS  BE LIABLE FOR  ANY DIRECT,
  + INDIRECT, INCIDENTAL, SPECIAL,  EXEMPLARY, OR CONSEQUENTIAL  DAMAGES (INCLU-
  + DING, BUT NOT LIMITED TO, PROCUREMENT  OF SUBSTITUTE GOODS OR SERVICES; LOSS
  + OF USE, DATA, OR  PROFITS; OR BUSINESS  INTERRUPTION)  HOWEVER CAUSED AND ON
  + ANY  THEORY OF LIABILITY,  WHETHER  IN CONTRACT,  STRICT LIABILITY,  OR TORT
  + (INCLUDING  NEGLIGENCE OR  OTHERWISE) ARISING IN  ANY WAY OUT OF THE  USE OF
  + THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  + 
  + This software  consists of voluntary contributions made  by many individuals
  + on  behalf of the Apache Software  Foundation and was  originally created by
  + James Tauber <jt...@jtauber.com>. For more  information on the Apache 
  + Software Foundation, please see <http://www.apache.org/>.
  + 
  + */
  +
  +package org.apache.fop.fo.flow;
  +
  +// FOP
  +import org.apache.fop.fo.*;
  +import org.apache.fop.fo.properties.*;
  +import org.apache.fop.datatypes.*;
  +import org.apache.fop.layout.*;
  +import org.apache.fop.apps.FOPException;
  +
  +// Java
  +import java.util.Vector;
  +
  +public class TableRow extends FObj {
  +	
  +    public static class Maker extends FObj.Maker {
  +	public FObj make(FObj parent, PropertyList propertyList)
  +	    throws FOPException {
  +	    return new TableRow(parent, propertyList);
  +	}
  +    }
  +
  +    public static FObj.Maker maker() {
  +	return new TableRow.Maker();
  +    }
  +
  +    FontState fs;
  +    int spaceBefore;
  +    int spaceAfter;
  +    ColorType backgroundColor;
  +    
  +    ColorType borderColor;
  +    int borderWidth;
  +    int borderStyle;
  +
  +    int widthOfCellsSoFar = 0;
  +    int largestCellHeight = 0;
  +
  +    Vector columns;
  +
  +    AreaContainer areaContainer;
  +
  +    public TableRow(FObj parent, PropertyList propertyList) {
  +	super(parent, propertyList);
  +	this.name = "fo:table-row";
  +    }
  +
  +    public void setColumns(Vector columns) {
  +	this.columns = columns;
  +    }
  +
  +    public Status layout(Area area) throws FOPException {
  +	if (this.marker == BREAK_AFTER) {
  +	    return new Status(Status.OK);
  +	}
  +
  +	if (this.marker == START) {
  +	    String fontFamily =
  +		this.properties.get("font-family").getString(); 
  +	    String fontStyle =
  +		this.properties.get("font-style").getString(); 
  +	    String fontWeight =
  +		this.properties.get("font-weight").getString(); 
  +	    int fontSize =
  +		this.properties.get("font-size").getLength().mvalue(); 
  +	    
  +	    this.fs = new FontState(area.getFontInfo(), fontFamily, 
  +				    fontStyle, fontWeight, fontSize);  
  +	    this.spaceBefore =
  +		this.properties.get("space-before.optimum").getLength().mvalue();  
  +	    this.spaceAfter =
  +		this.properties.get("space-after.optimum").getLength().mvalue(); 
  +	    this.backgroundColor =
  +		this.properties.get("background-color").getColorType();
  +	    this.borderColor =
  +		this.properties.get("border-color").getColorType();
  +	    this.borderWidth =
  +		this.properties.get("border-width").getLength().mvalue();
  +	    this.borderStyle =
  +		this.properties.get("border-style").getEnum();
  +
  +	    if (area instanceof BlockArea) {
  +		area.end();
  +	    }
  +
  +	    this.marker = 0;
  +
  +	}
  +
  +	if ((spaceBefore != 0) && (this.marker ==0)) {
  +	    area.addDisplaySpace(spaceBefore);
  +	}
  +
  +        if ( marker==0 ) {
  +            // initialize id                       
  +            String id = this.properties.get("id").getString();            
  +            area.getIDReferences().initializeID(id,area);                        
  +        }
  +
  +	this.areaContainer =
  +	    new AreaContainer(fs, -area.borderWidthLeft, -area.borderWidthTop, 
  +                           area.getAllocationWidth(), 
  +			  area.spaceLeft(), Position.RELATIVE);
  +	areaContainer.setPage(area.getPage());
  +	areaContainer.setBackgroundColor(backgroundColor);
  +        areaContainer.setBorderStyle(borderStyle, borderStyle, borderStyle, borderStyle); 
  +        areaContainer.setBorderWidth(borderWidth, borderWidth, borderWidth, borderWidth); 
  +        areaContainer.setBorderColor(borderColor, borderColor, borderColor, borderColor); 
  +	areaContainer.start();
  +
  +        areaContainer.setAbsoluteHeight(area.getAbsoluteHeight());
  +        areaContainer.setIDReferences(area.getIDReferences());
  +
  +	int numChildren = this.children.size();
  +	if (numChildren != columns.size()) {
  +	    System.err.println("WARNING: Number of children under table-row not equal to number of table-columns");
  +	    return new Status(Status.OK);
  +	}
  +
  +	// added by Eric Schaeffer
  +	widthOfCellsSoFar = 0;
  +	largestCellHeight = 0;
  +
  +	for (int i = this.marker; i < numChildren; i++) {
  +	    TableCell cell = (TableCell) children.elementAt(i);
  +
  +	    //if (this.isInListBody) {
  +	    //fo.setIsInListBody();
  +	    //fo.setDistanceBetweenStarts(this.distanceBetweenStarts);
  +	    //fo.setBodyIndent(this.bodyIndent);
  +	    //}
  +
  +	    cell.setStartOffset(widthOfCellsSoFar);
  +	    int width = ((TableColumn) columns.elementAt(i)).getColumnWidth();
  +
  +	    cell.setWidth(width);
  +	    widthOfCellsSoFar += width;
  +
  +	    Status status;
  +	    if ((status = cell.layout(areaContainer)).isIncomplete()) {
  +		this.marker = i;
  +		if ((i != 0) && (status.getCode() == Status.AREA_FULL_NONE)) {
  +		    status = new Status(Status.AREA_FULL_SOME);
  +		}
  +    	        area.addChild(areaContainer);
  +		//areaContainer.end();
  +		area.addDisplaySpace(areaContainer.getHeight());
  +		return status;
  +	    }
  +
  +	    int h = cell.getHeight();
  +	    if (h > largestCellHeight) {
  +		largestCellHeight = h;
  +	    }
  +	}
  +	for (int i = 0; i < numChildren; i++) {
  +	    TableCell cell = (TableCell)children.elementAt(i);
  +            cell.setHeight(largestCellHeight);
  +	}
  +
  +	area.addChild(areaContainer);
  +	areaContainer.end();
  +        area.addDisplaySpace(largestCellHeight);
  +
  +	// bug fix from Eric Schaeffer
  +	//area.increaseHeight(largestCellHeight);
  +
  +	if (spaceAfter != 0) {
  +	    area.addDisplaySpace(spaceAfter);
  +	}
  +
  +	if (area instanceof BlockArea) {
  +	    area.start();
  +	}
  +
  +	return new Status(Status.OK);
  +    }
  +
  +    public int getAreaHeight() {
  +	return areaContainer.getHeight();
  +    }
  +}