aboutsummaryrefslogtreecommitdiffstats
path: root/src/java/org/apache/fop/fo/flow/table/TableColumn.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/java/org/apache/fop/fo/flow/table/TableColumn.java')
-rw-r--r--src/java/org/apache/fop/fo/flow/table/TableColumn.java243
1 files changed, 243 insertions, 0 deletions
diff --git a/src/java/org/apache/fop/fo/flow/table/TableColumn.java b/src/java/org/apache/fop/fo/flow/table/TableColumn.java
new file mode 100644
index 000000000..aa2dfcb0a
--- /dev/null
+++ b/src/java/org/apache/fop/fo/flow/table/TableColumn.java
@@ -0,0 +1,243 @@
+/*
+ * 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$ */
+
+package org.apache.fop.fo.flow.table;
+
+// XML
+import org.xml.sax.Locator;
+
+import org.apache.fop.apps.FOPException;
+import org.apache.fop.datatypes.Length;
+import org.apache.fop.fo.FONode;
+import org.apache.fop.fo.PropertyList;
+import org.apache.fop.fo.ValidationException;
+import org.apache.fop.fo.expr.PropertyException;
+import org.apache.fop.fo.properties.CommonBorderPaddingBackground;
+import org.apache.fop.fo.properties.Property;
+import org.apache.fop.fo.properties.TableColLength;
+
+/**
+ * Class modelling the fo:table-column object.
+ */
+public class TableColumn extends TableFObj {
+ // The value of properties relevant for fo:table-column.
+ private CommonBorderPaddingBackground commonBorderPaddingBackground;
+ private int columnNumber;
+ private Length columnWidth;
+ private int numberColumnsRepeated;
+ private int numberColumnsSpanned;
+ // Unused but valid items, commented out for performance:
+ // private int visibility;
+ // End of property values
+
+ private boolean implicitColumn;
+ private PropertyList pList = null;
+
+ /**
+ * @param parent FONode that is the parent of this object
+ */
+ public TableColumn(FONode parent) {
+ this(parent, false);
+ }
+
+ /**
+ * @param parent FONode that is the parent of this object
+ * @param implicit true if this table-column has automatically been created (does not
+ * correspond to an explicit fo:table-column in the input document)
+ */
+ public TableColumn(FONode parent, boolean implicit) {
+ super(parent);
+ this.implicitColumn = implicit;
+ }
+
+
+ /**
+ * {@inheritDoc}
+ */
+ public void bind(PropertyList pList) throws FOPException {
+ commonBorderPaddingBackground = pList.getBorderPaddingBackgroundProps();
+ columnNumber = pList.get(PR_COLUMN_NUMBER).getNumeric().getValue();
+ columnWidth = pList.get(PR_COLUMN_WIDTH).getLength();
+ numberColumnsRepeated = pList.get(PR_NUMBER_COLUMNS_REPEATED)
+ .getNumeric().getValue();
+ numberColumnsSpanned = pList.get(PR_NUMBER_COLUMNS_SPANNED)
+ .getNumeric().getValue();
+ super.bind(pList);
+
+ if (numberColumnsRepeated <= 0) {
+ throw new PropertyException("number-columns-repeated must be 1 or bigger, "
+ + "but got " + numberColumnsRepeated);
+ }
+ if (numberColumnsSpanned <= 0) {
+ throw new PropertyException("number-columns-spanned must be 1 or bigger, "
+ + "but got " + numberColumnsSpanned);
+ }
+
+ /* check for unspecified width and replace with default of
+ * proportional-column-width(1), in case of fixed table-layout
+ * warn only for explicit columns
+ */
+ if (columnWidth.getEnum() == EN_AUTO) {
+ if (!this.implicitColumn && !getTable().isAutoLayout()) {
+ log.warn("table-layout=\"fixed\" and column-width unspecified "
+ + "=> falling back to proportional-column-width(1)");
+ }
+ columnWidth = new TableColLength(1.0, this);
+ }
+
+ /* in case of explicit columns, from-table-column()
+ * can be used on descendants of the table-cells, so
+ * we need a reference to the column's property list
+ * (cleared in Table.endOfNode())
+ */
+ if (!this.implicitColumn) {
+ this.pList = pList;
+ }
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected void startOfNode() throws FOPException {
+ getFOEventHandler().startColumn(this);
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ protected void endOfNode() throws FOPException {
+ getFOEventHandler().endColumn(this);
+ }
+
+ /**
+ * {@inheritDoc}
+ * XSL Content Model: empty
+ */
+ protected void validateChildNode(Locator loc,
+ String nsURI, String localName)
+ throws ValidationException {
+ invalidChildError(loc, nsURI, localName);
+ }
+
+ /**
+ * @return the Common Border, Padding, and Background Properties.
+ */
+ public CommonBorderPaddingBackground getCommonBorderPaddingBackground() {
+ return commonBorderPaddingBackground;
+ }
+
+ /**
+ * @return the "column-width" property.
+ */
+ public Length getColumnWidth() {
+ return columnWidth;
+ }
+
+ /**
+ * Sets the column width.
+ * @param columnWidth the column width
+ */
+ public void setColumnWidth(Length columnWidth) {
+ this.columnWidth = columnWidth;
+ }
+
+ /**
+ * @return the "column-number" property.
+ */
+ public int getColumnNumber() {
+ return columnNumber;
+ }
+
+ /**
+ * Used for setting the column-number for an implicit column
+ * @param columnNumber
+ */
+ protected void setColumnNumber(int columnNumber) {
+ this.columnNumber = columnNumber;
+ }
+
+ /** @return value for number-columns-repeated. */
+ public int getNumberColumnsRepeated() {
+ return numberColumnsRepeated;
+ }
+
+ /** @return value for number-columns-spanned. */
+ public int getNumberColumnsSpanned() {
+ return numberColumnsSpanned;
+ }
+
+ /** {@inheritDoc} */
+ public String getLocalName() {
+ return "table-column";
+ }
+
+ /** {@inheritDoc} */
+ public int getNameId() {
+ return FO_TABLE_COLUMN;
+ }
+
+ /**
+ * Indicates whether this table-column has been created as
+ * default column for this table in case no table-columns
+ * have been defined.
+ * Note that this only used to provide better
+ * user feedback (see ColumnSetup).
+ * @return true if this table-column has been created as default column
+ */
+ public boolean isImplicitColumn() {
+ return implicitColumn;
+ }
+
+ /** {@inheritDoc} */
+ public String toString() {
+ StringBuffer sb = new StringBuffer("fo:table-column");
+ sb.append(" column-number=").append(getColumnNumber());
+ if (getNumberColumnsRepeated() > 1) {
+ sb.append(" number-columns-repeated=")
+ .append(getNumberColumnsRepeated());
+ }
+ if (getNumberColumnsSpanned() > 1) {
+ sb.append(" number-columns-spanned=")
+ .append(getNumberColumnsSpanned());
+ }
+ sb.append(" column-width=").append(getColumnWidth());
+ return sb.toString();
+ }
+
+ /**
+ * Retrieve a property value through its Id; used by
+ * from-table-column() function
+ *
+ * @param propId the id for the property to retrieve
+ * @return the requested Property
+ * @throws PropertyException
+ */
+ public Property getProperty(int propId) throws PropertyException {
+ return this.pList.get(propId);
+ }
+
+ /**
+ * Clear the reference to the PropertyList (retained for
+ * from-table-column())
+ */
+ protected void releasePropertyList() {
+ this.pList = null;
+ }
+
+}