aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/java/org/apache/fop/rtf/renderer/BuilderContext.java263
-rw-r--r--src/java/org/apache/fop/rtf/renderer/FoUnitsConverter.java63
-rw-r--r--src/java/org/apache/fop/rtf/renderer/RTFHandler.java135
-rw-r--r--src/java/org/apache/fop/rtf/renderer/TableAttributesConverter.java371
-rw-r--r--src/java/org/apache/fop/rtf/renderer/TableContext.java110
5 files changed, 475 insertions, 467 deletions
diff --git a/src/java/org/apache/fop/rtf/renderer/BuilderContext.java b/src/java/org/apache/fop/rtf/renderer/BuilderContext.java
index 00e41c524..6d530b274 100644
--- a/src/java/org/apache/fop/rtf/renderer/BuilderContext.java
+++ b/src/java/org/apache/fop/rtf/renderer/BuilderContext.java
@@ -1,4 +1,5 @@
/*
+ * $Id$
* ============================================================================
* The Apache Software License, Version 1.1
* ============================================================================
@@ -50,7 +51,8 @@
package org.apache.fop.rtf.renderer;
import java.util.Stack;
-import org.apache.fop.rtf.rtflib.rtfdoc.*;
+import org.apache.fop.rtf.rtflib.rtfdoc.IRtfOptions;
+import org.apache.fop.rtf.rtflib.rtfdoc.RtfContainer;
/** A BuilderContext holds context information when building an RTF document
@@ -64,136 +66,133 @@ import org.apache.fop.rtf.rtflib.rtfdoc.*;
*/
-class BuilderContext
-{
- /** stack of RtfContainers */
- private final Stack m_containers = new Stack();
-
- /** stack of TableContexts */
- private final Stack m_tableContexts = new Stack();
-
- /** stack of IBuilders */
- private final Stack m_builders = new Stack();
-
- /** Rtf options */
- IRtfOptions m_options;
-
- BuilderContext(IRtfOptions rtfOptions)
- {
- m_options = rtfOptions;
- }
-
- /** find first object of given class from top of stack s
- * @return null if not found
- */
- private Object getObjectFromStack(Stack s,Class desiredClass)
- {
- Object result = null;
- final Stack copy = (Stack)s.clone();
- while(!copy.isEmpty()) {
- final Object o = copy.pop();
- if(desiredClass.isAssignableFrom(o.getClass())) {
- result = o;
- break;
- }
- }
- return result;
- }
-
- /* find the "nearest" IBuilder of given class /
- Object getBuilder(Class builderClass,boolean required)
- throws Exception
- {
- final IBuilder result = (IBuilder)getObjectFromStack(m_builders,builderClass);
- if(result == null && required) {
- throw new Exception(
- "IBuilder of class '" + builderClass.getName() + "' not found on builders stack"
- );
- }
- return result;
- }*/
-
- /** find the "nearest" container that implements the given interface on our stack
- * @param required if true, ConverterException is thrown if no container found
- * @param forWhichBuilder used in error message if container not found
- */
- RtfContainer getContainer(Class containerClass,boolean required,Object /*IBuilder*/ forWhichBuilder) throws Exception
- {
- // TODO what to do if the desired container is not at the top of the stack?
- // close top-of-stack container?
- final RtfContainer result = (RtfContainer)getObjectFromStack(m_containers,containerClass);
-
- if(result == null && required) {
- throw new Exception(
- "No RtfContainer of class '" + containerClass.getName()
- + "' available for '" + forWhichBuilder.getClass().getName() + "' builder"
- );
- }
-
- return result;
- }
-
- /** push an RtfContainer on our stack */
- void pushContainer(RtfContainer c)
- {
- m_containers.push(c);
- }
-
- /** in some cases an RtfContainer must be replaced by another one on the stack.
- * this happens when handling nested fo:blocks for example: after handling a nested block
- * the enclosing block must switch to a new paragraph container to handle what follows the nested block.
- * TODO: what happens to elements that are "more on top" than oldC on the stack? shouldn't they be closed
- * or something?
- */
- void replaceContainer(RtfContainer oldC,RtfContainer newC)
- throws Exception
- {
- // treating the Stack as a Vector allows such manipulations (yes, I hear you screaming ;-)
- final int index = m_containers.indexOf(oldC);
- if(index < 0) throw new Exception("container to replace not found:" + oldC);
- m_containers.setElementAt(newC,index);
- }
-
- /** pop the topmost RtfContainer from our stack */
- void popContainer()
- {
- m_containers.pop();
- }
-
- /* push an IBuilder to our stack /
- void pushBuilder(IBuilder b)
- {
- m_builders.push(b);
- }*/
-
- /** pop the topmost IBuilder from our stack and return previous builder on stack
- * @return null if builders stack is empty
-
- IBuilder popBuilderAndGetPreviousOne()
- {
- IBuilder result = null;
- m_builders.pop();
- if(!m_builders.isEmpty()) {
- result = (IBuilder)m_builders.peek();
- }
- return result;
- }
+class BuilderContext {
+ /** stack of RtfContainers */
+ private final Stack m_containers = new Stack();
+
+ /** stack of TableContexts */
+ private final Stack m_tableContexts = new Stack();
+
+ /** stack of IBuilders */
+ private final Stack m_builders = new Stack();
+
+ /** Rtf options */
+ IRtfOptions m_options;
+
+ BuilderContext(IRtfOptions rtfOptions) {
+ m_options = rtfOptions;
+ }
+
+ /** find first object of given class from top of stack s
+ * @return null if not found
+ */
+ private Object getObjectFromStack(Stack s, Class desiredClass) {
+ Object result = null;
+ final Stack copy = (Stack)s.clone();
+ while (!copy.isEmpty()) {
+ final Object o = copy.pop();
+ if (desiredClass.isAssignableFrom(o.getClass())) {
+ result = o;
+ break;
+ }
+ }
+ return result;
+ }
+
+ /* find the "nearest" IBuilder of given class /
+ Object getBuilder(Class builderClass,boolean required)
+ throws Exception
+ {
+ final IBuilder result = (IBuilder)getObjectFromStack(m_builders,builderClass);
+ if(result == null && required) {
+ throw new Exception(
+ "IBuilder of class '" + builderClass.getName() + "' not found on builders stack"
+ );
+ }
+ return result;
+ }*/
+
+ /** find the "nearest" container that implements the given interface on our stack
+ * @param required if true, ConverterException is thrown if no container found
+ * @param forWhichBuilder used in error message if container not found
+ */
+ RtfContainer getContainer(Class containerClass, boolean required,
+ Object /*IBuilder*/ forWhichBuilder) throws Exception {
+ // TODO what to do if the desired container is not at the top of the stack?
+ // close top-of-stack container?
+ final RtfContainer result = (RtfContainer)getObjectFromStack(m_containers,
+ containerClass);
+
+ if (result == null && required) {
+ throw new Exception(
+ "No RtfContainer of class '" + containerClass.getName()
+ + "' available for '" + forWhichBuilder.getClass().getName() + "' builder"
+ );
+ }
+
+ return result;
+ }
+
+ /** push an RtfContainer on our stack */
+ void pushContainer(RtfContainer c) {
+ m_containers.push(c);
+ }
+
+ /**
+ * In some cases an RtfContainer must be replaced by another one on the
+ * stack. This happens when handling nested fo:blocks for example: after
+ * handling a nested block the enclosing block must switch to a new
+ * paragraph container to handle what follows the nested block.
+ * TODO: what happens to elements that are "more on top" than oldC on the
+ * stack? shouldn't they be closed or something?
+ */
+ void replaceContainer(RtfContainer oldC, RtfContainer newC)
+ throws Exception {
+ // treating the Stack as a Vector allows such manipulations (yes, I hear you screaming ;-)
+ final int index = m_containers.indexOf(oldC);
+ if (index < 0) {
+ throw new Exception("container to replace not found:" + oldC);
+ }
+ m_containers.setElementAt(newC, index);
+ }
+
+ /** pop the topmost RtfContainer from our stack */
+ void popContainer() {
+ m_containers.pop();
+ }
+
+ /* push an IBuilder to our stack /
+ void pushBuilder(IBuilder b)
+ {
+ m_builders.push(b);
+ }*/
+
+ /** pop the topmost IBuilder from our stack and return previous builder on stack
+ * @return null if builders stack is empty
+
+ IBuilder popBuilderAndGetPreviousOne()
+ {
+ IBuilder result = null;
+ m_builders.pop();
+ if(!m_builders.isEmpty()) {
+ result = (IBuilder)m_builders.peek();
+ }
+ return result;
+ }
*/
- /** return the current TableContext */
- TableContext getTableContext()
- {
- return (TableContext)m_tableContexts.peek();
- }
-
- /** push a TableContext to our stack */
- void pushTableContext(TableContext tc)
- {
- m_tableContexts.push(tc);
- }
-
- /** pop a TableContext from our stack */
- void popTableContext()
- {
- m_tableContexts.pop();
- }
+ /** return the current TableContext */
+ TableContext getTableContext() {
+ return (TableContext)m_tableContexts.peek();
+ }
+
+ /** push a TableContext to our stack */
+ void pushTableContext(TableContext tc) {
+ m_tableContexts.push(tc);
+ }
+
+ /** pop a TableContext from our stack */
+ void popTableContext() {
+ m_tableContexts.pop();
+ }
+
} \ No newline at end of file
diff --git a/src/java/org/apache/fop/rtf/renderer/FoUnitsConverter.java b/src/java/org/apache/fop/rtf/renderer/FoUnitsConverter.java
index 99bec8fd4..5451c71ca 100644
--- a/src/java/org/apache/fop/rtf/renderer/FoUnitsConverter.java
+++ b/src/java/org/apache/fop/rtf/renderer/FoUnitsConverter.java
@@ -1,4 +1,5 @@
/*
+ * $Id$
* ============================================================================
* The Apache Software License, Version 1.1
* ============================================================================
@@ -49,7 +50,8 @@
*/
package org.apache.fop.rtf.renderer;
-import java.util.*;
+import java.util.Map;
+import java.util.HashMap;
//FOP
import org.apache.fop.apps.FOPException;
@@ -65,8 +67,7 @@ import org.apache.fop.apps.FOPException;
* for the JFOR project and is now integrated into FOP.
*/
-class FoUnitsConverter
-{
+class FoUnitsConverter {
private static final FoUnitsConverter m_instance = new FoUnitsConverter();
/** points to twips: 1 twip is 1/20 of a point */
@@ -81,41 +82,38 @@ class FoUnitsConverter
/** conversion factors keyed by xsl:fo units names */
private static final Map m_twipFactors = new HashMap();
static {
- m_twipFactors.put("mm",new Float(MM_TO_TWIPS));
- m_twipFactors.put("cm",new Float(CM_TO_TWIPS));
- m_twipFactors.put("pt",new Float(POINT_TO_TWIPS));
- m_twipFactors.put("in",new Float(IN_TO_TWIPS));
+ m_twipFactors.put("mm", new Float(MM_TO_TWIPS));
+ m_twipFactors.put("cm", new Float(CM_TO_TWIPS));
+ m_twipFactors.put("pt", new Float(POINT_TO_TWIPS));
+ m_twipFactors.put("in", new Float(IN_TO_TWIPS));
}
/** singleton pattern */
- private FoUnitsConverter()
- {
+ private FoUnitsConverter() {
}
/** singleton pattern */
- static FoUnitsConverter getInstance()
- {
+ static FoUnitsConverter getInstance() {
return m_instance;
}
/** convert given value to RTF units
* @param foValue a value like "12mm"
* TODO: tested with "mm" units only, needs work to comply with FO spec
- * Why does it search for period instead of simply breaking last two
+ * Why does it search for period instead of simply breaking last two
* Characters into another units string? - Chris
*/
float convertToTwips(String foValue)
- throws FOPException
- {
+ throws FOPException {
foValue = foValue.trim();
// break value into number and units
final StringBuffer number = new StringBuffer();
final StringBuffer units = new StringBuffer();
- for(int i=0; i < foValue.length(); i++) {
+ for (int i = 0; i < foValue.length(); i++) {
final char c = foValue.charAt(i);
- if(Character.isDigit(c) || c == '.') {
+ if (Character.isDigit(c) || c == '.') {
number.append(c);
} else {
// found the end of the digits
@@ -124,29 +122,31 @@ class FoUnitsConverter
}
}
- return numberToTwips(number.toString(),units.toString());
+ return numberToTwips(number.toString(), units.toString());
}
/** convert given value to twips according to given units */
- private float numberToTwips(String number,String units)
- throws FOPException
- {
+ private float numberToTwips(String number, String units)
+ throws FOPException {
float result = 0;
// convert number to integer
try {
- if(number != null && number.trim().length() > 0) {
+ if (number != null && number.trim().length() > 0) {
result = Float.valueOf(number).floatValue();
}
- } catch(Exception e) {
- throw new FOPException("number format error: cannot convert '" + number + "' to float value");
+ } catch (Exception e) {
+ throw new FOPException("number format error: cannot convert '"
+ + number + "' to float value");
}
// find conversion factor
- if(units != null && units.trim().length() > 0) {
+ if (units != null && units.trim().length() > 0) {
final Float factor = (Float)m_twipFactors.get(units.toLowerCase());
- if(factor == null) throw new FOPException("conversion factor not found for '" + units + "' units");
+ if (factor == null) {
+ throw new FOPException("conversion factor not found for '" + units + "' units");
+ }
result *= factor.floatValue();
}
@@ -154,20 +154,19 @@ class FoUnitsConverter
}
/** convert a font size given in points like "12pt" */
- int convertFontSize(String size)
- throws FOPException
- {
+ int convertFontSize(String size) throws FOPException {
size = size.trim();
final String FONT_SUFFIX = "pt";
- if(!size.endsWith(FONT_SUFFIX)) {
- throw new FOPException("Invalid font size '" + size + "', must end with '" + FONT_SUFFIX + "'");
+ if (!size.endsWith(FONT_SUFFIX)) {
+ throw new FOPException("Invalid font size '" + size + "', must end with '"
+ + FONT_SUFFIX + "'");
}
float result = 0;
- size = size.substring(0,size.length() - FONT_SUFFIX.length());
+ size = size.substring(0, size.length() - FONT_SUFFIX.length());
try {
result = (Float.valueOf(size).floatValue());
- } catch(Exception e) {
+ } catch (Exception e) {
throw new FOPException("Invalid font size value '" + size + "'");
}
diff --git a/src/java/org/apache/fop/rtf/renderer/RTFHandler.java b/src/java/org/apache/fop/rtf/renderer/RTFHandler.java
index cb38defab..c900aad06 100644
--- a/src/java/org/apache/fop/rtf/renderer/RTFHandler.java
+++ b/src/java/org/apache/fop/rtf/renderer/RTFHandler.java
@@ -103,12 +103,12 @@ public class RTFHandler extends FOInputHandler {
private RtfFile rtfFile;
private final OutputStream os;
- private final Logger log=new ConsoleLogger();
+ private final Logger log = new ConsoleLogger();
private RtfSection sect;
private RtfDocumentArea docArea;
private RtfParagraph para;
private boolean warned = false;
- private BuilderContext m_context=new BuilderContext(null);
+ private BuilderContext m_context = new BuilderContext(null);
private static final String ALPHA_WARNING = "WARNING: RTF renderer is "
+ "veryveryalpha at this time, see class org.apache.fop.rtf.renderer.RTFHandler";
@@ -205,7 +205,9 @@ public class RTFHandler extends FOInputHandler {
attrBlockFontSize(bl, rtfAttr);
attrBlockFontWeight(bl, rtfAttr);
- IRtfParagraphContainer pc=(IRtfParagraphContainer)m_context.getContainer(IRtfParagraphContainer.class,true,null);
+ IRtfParagraphContainer pc =
+ (IRtfParagraphContainer)m_context.getContainer
+ (IRtfParagraphContainer.class, true, null);
para = pc.newParagraph(rtfAttr);
m_context.pushContainer(para);
@@ -213,9 +215,7 @@ public class RTFHandler extends FOInputHandler {
// FIXME could we throw Exception in all FOInputHandler events?
log.error("startBlock: " + ioe.getMessage());
throw new Error("IOException: " + ioe);
- }
- catch(Exception e)
- {
+ } catch (Exception e) {
log.error("startBlock: " + e.getMessage());
throw new Error("Exception: " + e);
}
@@ -235,15 +235,14 @@ public class RTFHandler extends FOInputHandler {
public void startTable(Table tbl) {
// create an RtfTable in the current table container
TableContext tableContext = new TableContext(m_context);
- RtfAttributes atts=new RtfAttributes();
+ RtfAttributes atts = new RtfAttributes();
- try
- {
- final IRtfTableContainer tc = (IRtfTableContainer)m_context.getContainer(IRtfTableContainer.class,true,null);
+ try {
+ final IRtfTableContainer tc =
+ (IRtfTableContainer)m_context.getContainer(IRtfTableContainer.class,
+ true, null);
m_context.pushContainer(tc.newTable(atts, tableContext));
- }
- catch(Exception e)
- {
+ } catch (Exception e) {
log.error("startTable:" + e.getMessage());
throw new Error(e.getMessage());
}
@@ -265,14 +264,11 @@ public class RTFHandler extends FOInputHandler {
*/
public void startColumn(TableColumn tc) {
- try
- {
- Integer iWidth=new Integer(tc.getColumnWidth()/1000);
- m_context.getTableContext().setNextColumnWidth(iWidth.toString()+"pt");
- m_context.getTableContext().setNextColumnRowSpanning(new Integer(0),null);
- }
- catch(Exception e)
- {
+ try {
+ Integer iWidth = new Integer(tc.getColumnWidth() / 1000);
+ m_context.getTableContext().setNextColumnWidth(iWidth.toString() + "pt");
+ m_context.getTableContext().setNextColumnRowSpanning(new Integer(0), null);
+ } catch (Exception e) {
log.error("startColumn: " + e.getMessage());
throw new Error(e.getMessage());
}
@@ -284,7 +280,7 @@ public class RTFHandler extends FOInputHandler {
* @param th TableColumn that is ending;
*/
- public void endColumn(TableColumn tc){
+ public void endColumn(TableColumn tc) {
}
/**
@@ -315,15 +311,13 @@ public class RTFHandler extends FOInputHandler {
* @see org.apache.fop.fo.FOInputHandler#startBody(TableBody)
*/
public void startBody(TableBody tb) {
- try
- {
- RtfAttributes atts=TableAttributesConverter.convertRowAttributes (tb.properties, null, null);
+ try {
+ RtfAttributes atts = TableAttributesConverter.convertRowAttributes (tb.properties,
+ null, null);
- RtfTable tbl = (RtfTable)m_context.getContainer(RtfTable.class,true,this);
+ RtfTable tbl = (RtfTable)m_context.getContainer(RtfTable.class, true, this);
tbl.setHeaderAttribs(atts);
- }
- catch(Exception e)
- {
+ } catch (Exception e) {
log.error("startBody: " + e.getMessage());
throw new Error(e.getMessage());
}
@@ -333,13 +327,10 @@ public class RTFHandler extends FOInputHandler {
* @see org.apache.fop.fo.FOInputHandler#endBody(TableBody)
*/
public void endBody(TableBody tb) {
- try
- {
- RtfTable tbl = (RtfTable)m_context.getContainer(RtfTable.class,true,this);
- tbl.setHeaderAttribs( null );
- }
- catch(Exception e)
- {
+ try {
+ RtfTable tbl = (RtfTable)m_context.getContainer(RtfTable.class, true, this);
+ tbl.setHeaderAttribs(null);
+ } catch (Exception e) {
log.error("endBody: " + e.getMessage());
throw new Error(e.getMessage());
}
@@ -349,22 +340,21 @@ public class RTFHandler extends FOInputHandler {
* @see org.apache.fop.fo.FOInputHandler#startRow(TableRow)
*/
public void startRow(TableRow tr) {
- try
- {
+ try {
// create an RtfTableRow in the current RtfTable
- final RtfTable tbl = (RtfTable)m_context.getContainer(RtfTable.class,true,null);
+ final RtfTable tbl = (RtfTable)m_context.getContainer(RtfTable.class,
+ true, null);
RtfAttributes tblAttribs = tbl.getRtfAttributes();
RtfAttributes tblRowAttribs = new RtfAttributes();
- RtfAttributes atts=TableAttributesConverter.convertRowAttributes(tr.properties,null,tbl.getHeaderAttribs());
+ RtfAttributes atts = TableAttributesConverter.convertRowAttributes(tr.properties,
+ null, tbl.getHeaderAttribs());
- m_context.pushContainer(tbl.newTableRow( atts ));
+ m_context.pushContainer(tbl.newTableRow(atts));
// reset column iteration index to correctly access column widths
m_context.getTableContext().selectFirstColumn();
- }
- catch(Exception e)
- {
+ } catch (Exception e) {
log.error("startRow: " + e.getMessage());
throw new Error(e.getMessage());
}
@@ -382,46 +372,44 @@ public class RTFHandler extends FOInputHandler {
* @see org.apache.fop.fo.FOInputHandler#startCell(TableCell)
*/
public void startCell(TableCell tc) {
- try
- {
- TableContext tctx=m_context.getTableContext();
- final RtfTableRow row = (RtfTableRow)m_context.getContainer(RtfTableRow.class,true,null);
+ try {
+ TableContext tctx = m_context.getTableContext();
+ final RtfTableRow row = (RtfTableRow)m_context.getContainer(RtfTableRow.class,
+ true, null);
//while the current column is in row-spanning, act as if
//a vertical merged cell would have been specified.
- while(tctx.getNumberOfColumns()>tctx.getColumnIndex() && tctx.getColumnRowSpanningNumber().intValue()>0)
- {
- row.newTableCellMergedVertically((int)tctx.getColumnWidth(),tctx.getColumnRowSpanningAttrs());
+ while (tctx.getNumberOfColumns() > tctx.getColumnIndex()
+ && tctx.getColumnRowSpanningNumber().intValue() > 0) {
+ row.newTableCellMergedVertically((int)tctx.getColumnWidth(),
+ tctx.getColumnRowSpanningAttrs());
tctx.selectNextColumn();
}
//get the width of the currently started cell
- float width=tctx.getColumnWidth();
+ float width = tctx.getColumnWidth();
// create an RtfTableCell in the current RtfTableRow
- RtfAttributes atts=TableAttributesConverter.convertCellAttributes(tc.properties,null);
- RtfTableCell cell=row.newTableCell((int)width, atts);
+ RtfAttributes atts = TableAttributesConverter.convertCellAttributes(tc.properties,
+ null);
+ RtfTableCell cell = row.newTableCell((int)width, atts);
//process number-rows-spanned attribute
- Property p=null;
- if ((p=tc.properties.get("number-rows-spanned")) != null && false)
- {
+ Property p = null;
+ if ((p = tc.properties.get("number-rows-spanned")) != null && false) {
// Start vertical merge
cell.setVMerge(RtfTableCell.MERGE_START);
// set the number of rows spanned
- tctx.setCurrentColumnRowSpanning(new Integer(p.getNumber().intValue()), cell.getRtfAttributes());
- }
- else
- {
- tctx.setCurrentColumnRowSpanning(new Integer(1),null);
+ tctx.setCurrentColumnRowSpanning(new Integer(p.getNumber().intValue()),
+ cell.getRtfAttributes());
+ } else {
+ tctx.setCurrentColumnRowSpanning(new Integer(1), null);
}
m_context.pushContainer(cell);
- }
- catch(Exception e)
- {
+ } catch (Exception e) {
log.error("startCell: " + e.getMessage());
throw new Error(e.getMessage());
}
@@ -564,18 +552,17 @@ public class RTFHandler extends FOInputHandler {
}
}
- private void attrBlockFontSize(Block bl, RtfAttributes rtfAttr){
- int fopValue = bl.properties.get("font-size").getLength().getValue()/500;
- rtfAttr.set("fs",fopValue);
+ private void attrBlockFontSize(Block bl, RtfAttributes rtfAttr) {
+ int fopValue = bl.properties.get("font-size").getLength().getValue() / 500;
+ rtfAttr.set("fs", fopValue);
}
- private void attrBlockFontWeight(Block bl, RtfAttributes rtfAttr){
+ private void attrBlockFontWeight(Block bl, RtfAttributes rtfAttr) {
String fopValue = bl.properties.get("font-weight").getString();
- if(fopValue=="bold" || fopValue=="700"){
- rtfAttr.set("b",1);
- }
- else{
- rtfAttr.set("b",0);
+ if (fopValue == "bold" || fopValue == "700") {
+ rtfAttr.set("b", 1);
+ } else {
+ rtfAttr.set("b", 0);
}
}
diff --git a/src/java/org/apache/fop/rtf/renderer/TableAttributesConverter.java b/src/java/org/apache/fop/rtf/renderer/TableAttributesConverter.java
index 49f7bb669..00a56bfb6 100644
--- a/src/java/org/apache/fop/rtf/renderer/TableAttributesConverter.java
+++ b/src/java/org/apache/fop/rtf/renderer/TableAttributesConverter.java
@@ -1,4 +1,5 @@
/*
+ * $Id$
* ============================================================================
* The Apache Software License, Version 1.1
* ============================================================================
@@ -67,7 +68,6 @@ import org.apache.fop.fo.ColorTypeProperty;
import org.apache.fop.fo.NumberProperty;
import org.apache.fop.datatypes.ColorType;
-import org.xml.sax.Attributes;
import org.apache.fop.rtf.rtflib.rtfdoc.RtfAttributes;
import org.apache.fop.rtf.rtflib.rtfdoc.ITableAttributes;
import org.apache.fop.rtf.rtflib.rtfdoc.RtfColorTable;
@@ -89,7 +89,7 @@ import org.apache.fop.rtf.rtflib.rtfdoc.RtfColorTable;
public class TableAttributesConverter {
- static Logger log=new ConsoleLogger();
+ private static Logger log = new ConsoleLogger();
//////////////////////////////////////////////////
// @@ Construction
@@ -120,87 +120,84 @@ public class TableAttributesConverter {
Property p;
EnumProperty ep;
- RtfColorTable colorTable=RtfColorTable.getInstance();
+ RtfColorTable colorTable = RtfColorTable.getInstance();
- RtfAttributes attrib=null;
+ RtfAttributes attrib = null;
- if(defProps!=null)
- {
- attrib=convertCellAttributes(defProps,null);
- }
- else
- {
- attrib=new RtfAttributes();
+ if (defProps != null) {
+ attrib = convertCellAttributes(defProps, null);
+ } else {
+ attrib = new RtfAttributes();
}
- boolean isBorderPresent=false;
+ boolean isBorderPresent = false;
// Cell background color
- if ((p=props.getNearestSpecified("background-color"))!=null)
- {
- ColorType color=p.getColorType();
- if(color!=null)
- {
- if(color.getAlpha()!=0
- || color.getRed()!=0
- || color.getGreen()!=0
- || color.getBlue()!=0)
- {
+ if ((p = props.getNearestSpecified("background-color")) != null) {
+ ColorType color = p.getColorType();
+ if (color != null) {
+ if (color.getAlpha() != 0
+ || color.getRed() != 0
+ || color.getGreen() != 0
+ || color.getBlue() != 0) {
attrib.set(
ITableAttributes.CELL_COLOR_BACKGROUND,
RTFHandler.convertFOPColorToRTF(color));
}
- }
- else
- {
+ } else {
log.warn("Named color '" + p.toString() + "' not found. ");
}
}
// Cell borders :
- if ((p=props.getExplicit("border-color"))!=null){
- ListProperty listprop=(ListProperty)p;
- ColorType color=null;
- if(listprop.getList().get(0) instanceof NCnameProperty){
- color=new ColorType(((NCnameProperty)listprop.getList().get(0)).getNCname());
- }
- else if(listprop.getList().get(0) instanceof ColorTypeProperty){
- color=((ColorTypeProperty)listprop.getList().get(0)).getColorType();
+ if ((p = props.getExplicit("border-color")) != null) {
+ ListProperty listprop = (ListProperty)p;
+ ColorType color = null;
+ if (listprop.getList().get(0) instanceof NCnameProperty) {
+ color = new ColorType(((NCnameProperty)listprop.getList().get(0)).getNCname());
+ } else if (listprop.getList().get(0) instanceof ColorTypeProperty) {
+ color = ((ColorTypeProperty)listprop.getList().get(0)).getColorType();
}
attrib.set(
BorderAttributesConverter.BORDER_COLOR,
- colorTable.getColorNumber((int)color.getRed(),(int)color.getGreen(),(int)color.getBlue()).intValue());
+ colorTable.getColorNumber((int)color.getRed(), (int)color.getGreen(),
+ (int)color.getBlue()).intValue());
}
- if ((p=props.getExplicit("border-top-color"))!=null){
- ColorType color=p.getColorType();
+ if ((p = props.getExplicit("border-top-color")) != null) {
+ ColorType color = p.getColorType();
attrib.set(
BorderAttributesConverter.BORDER_COLOR,
- colorTable.getColorNumber((int)color.getRed(),(int)color.getGreen(),(int)color.getBlue()).intValue());
+ colorTable.getColorNumber((int)color.getRed(), (int)color.getGreen(),
+ (int)color.getBlue()).intValue());
}
- if((p=props.getExplicit("border-bottom-color"))!=null){
- ColorType color=p.getColorType();
+ if ((p = props.getExplicit("border-bottom-color")) != null) {
+ ColorType color = p.getColorType();
attrib.set(
BorderAttributesConverter.BORDER_COLOR,
- colorTable.getColorNumber((int)color.getRed(),(int)color.getGreen(),(int)color.getBlue()).intValue());
+ colorTable.getColorNumber((int)color.getRed(), (int)color.getGreen(),
+ (int)color.getBlue()).intValue());
}
- if((p=props.getExplicit("border-left-color"))!=null){
- ColorType color=p.getColorType();
+ if ((p = props.getExplicit("border-left-color")) != null) {
+ ColorType color = p.getColorType();
attrib.set(
BorderAttributesConverter.BORDER_COLOR,
- colorTable.getColorNumber((int)color.getRed(),(int)color.getGreen(),(int)color.getBlue()).intValue());
+ colorTable.getColorNumber((int)color.getRed(), (int)color.getGreen(),
+ (int)color.getBlue()).intValue());
}
- if((p=props.getExplicit("border-right-color"))!=null){
- ColorType color=p.getColorType();
+ if ((p = props.getExplicit("border-right-color")) != null) {
+ ColorType color = p.getColorType();
attrib.set(
BorderAttributesConverter.BORDER_COLOR,
- colorTable.getColorNumber((int)color.getRed(),(int)color.getGreen(),(int)color.getBlue()).intValue());
+ colorTable.getColorNumber((int)color.getRed(), (int)color.getGreen(),
+ (int)color.getBlue()).intValue());
}
// Border styles do not inherit from parent
- if((p=props.get("border-style"))!=null){
- log.warn("border-style not implemented. Please use border-style-left, ...-right, ...-top or ...-bottom");
+ if ((p = props.get("border-style")) != null) {
+ log.warn("border-style not implemented. Please use border-style-left, "
+ + "...-right, ...-top or ...-bottom");
/*
attrib.set(ITableAttributes.CELL_BORDER_LEFT, "\\"+convertAttributetoRtf(e.getEnum()));
attrib.set(ITableAttributes.CELL_BORDER_RIGHT, "\\"+convertAttributetoRtf(e.getEnum()));
@@ -209,46 +206,51 @@ public class TableAttributesConverter {
isBorderPresent=true;
*/
}
- ep=(EnumProperty)props.get("border-top-style");
- if(ep!=null && ep.getEnum()!=Constants.NONE){
- attrib.set(ITableAttributes.CELL_BORDER_TOP, "\\"+convertAttributetoRtf(ep.getEnum()));
- isBorderPresent=true;
+ ep = (EnumProperty)props.get("border-top-style");
+ if (ep != null && ep.getEnum() != Constants.NONE) {
+ attrib.set(ITableAttributes.CELL_BORDER_TOP, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ isBorderPresent = true;
}
- ep=(EnumProperty)props.get("border-bottom-style");
- if(ep!=null && ep.getEnum()!=Constants.NONE){
- attrib.set(ITableAttributes.CELL_BORDER_BOTTOM,"\\"+convertAttributetoRtf(ep.getEnum()));
- isBorderPresent=true;
+ ep = (EnumProperty)props.get("border-bottom-style");
+ if (ep != null && ep.getEnum() != Constants.NONE) {
+ attrib.set(ITableAttributes.CELL_BORDER_BOTTOM, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ isBorderPresent = true;
}
- ep=(EnumProperty)props.get("border-left-style");
- if(ep!=null && ep.getEnum()!=Constants.NONE){
- attrib.set(ITableAttributes.CELL_BORDER_LEFT, "\\"+convertAttributetoRtf(ep.getEnum()));
- isBorderPresent=true;
+ ep = (EnumProperty)props.get("border-left-style");
+ if (ep != null && ep.getEnum() != Constants.NONE) {
+ attrib.set(ITableAttributes.CELL_BORDER_LEFT, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ isBorderPresent = true;
}
- ep=(EnumProperty)props.get("border-right-style");
- if(ep!=null && ep.getEnum()!=Constants.NONE){
- attrib.set(ITableAttributes.CELL_BORDER_RIGHT, "\\"+convertAttributetoRtf(ep.getEnum()));
- isBorderPresent=true;
+ ep = (EnumProperty)props.get("border-right-style");
+ if (ep != null && ep.getEnum() != Constants.NONE) {
+ attrib.set(ITableAttributes.CELL_BORDER_RIGHT, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ isBorderPresent = true;
}
- if((p=props.get("border-width"))!=null) {
- ListProperty listprop=(ListProperty)p;
- LengthProperty lengthprop=(LengthProperty)listprop.getList().get(0);
+ if ((p = props.get("border-width")) != null) {
+ ListProperty listprop = (ListProperty)p;
+ LengthProperty lengthprop = (LengthProperty)listprop.getList().get(0);
- Float f=new Float(lengthprop.getLength().getValue()/1000f);
+ Float f = new Float(lengthprop.getLength().getValue() / 1000f);
String sValue = f.toString() + "pt";
- attrib.set(BorderAttributesConverter.BORDER_WIDTH, (int)FoUnitsConverter.getInstance().convertToTwips(sValue));
- }
- else if(isBorderPresent){
+ attrib.set(BorderAttributesConverter.BORDER_WIDTH,
+ (int)FoUnitsConverter.getInstance().convertToTwips(sValue));
+ } else if (isBorderPresent) {
//if not defined, set default border width
//note 20 twips = 1 point
- attrib.set(BorderAttributesConverter.BORDER_WIDTH, (int)FoUnitsConverter.getInstance().convertToTwips("1pt"));
+ attrib.set(BorderAttributesConverter.BORDER_WIDTH,
+ (int)FoUnitsConverter.getInstance().convertToTwips("1pt"));
}
// Column spanning :
- NumberProperty n=(NumberProperty)props.get("number-columns-spanned");
- if(n!=null && n.getNumber().intValue()>1) {
+ NumberProperty n = (NumberProperty)props.get("number-columns-spanned");
+ if (n != null && n.getNumber().intValue() > 1) {
attrib.set(ITableAttributes.COLUMN_SPAN, n.getNumber().intValue());
}
@@ -266,141 +268,172 @@ public class TableAttributesConverter {
*
* @throws ConverterException On convertion error
*/
- static RtfAttributes convertRowAttributes(PropertyList props, PropertyList defProps, RtfAttributes rtfatts)
+ static RtfAttributes convertRowAttributes(PropertyList props,
+ PropertyList defProps, RtfAttributes rtfatts)
throws FOPException {
Property p;
EnumProperty ep;
- RtfColorTable colorTable=RtfColorTable.getInstance();
+ RtfColorTable colorTable = RtfColorTable.getInstance();
- RtfAttributes attrib=null;
+ RtfAttributes attrib = null;
- if(defProps!=null)
- {
- attrib=convertRowAttributes(defProps,null,rtfatts);
- }
- else
- {
- if(rtfatts==null)
- attrib=new RtfAttributes();
- else
- attrib=rtfatts;
+ if (defProps != null) {
+ attrib = convertRowAttributes(defProps, null, rtfatts);
+ } else {
+ if (rtfatts == null) {
+ attrib = new RtfAttributes();
+ } else {
+ attrib = rtfatts;
+ }
}
String attrValue;
- boolean isBorderPresent=false;
+ boolean isBorderPresent = false;
//need to set a default width
//check for keep-together row attribute
- if ((p=props.get("keep-together.within-page"))!=null){
+ if ((p = props.get("keep-together.within-page")) != null) {
attrib.set(ITableAttributes.ROW_KEEP_TOGETHER);
}
- if ((p=props.get("keep-together"))!=null){
+ if ((p = props.get("keep-together")) != null) {
attrib.set(ITableAttributes.ROW_KEEP_TOGETHER);
}
//Check for keep-with-next row attribute.
- if ((p=props.get("keep-together"))!=null){
+ if ((p = props.get("keep-together")) != null) {
attrib.set(ITableAttributes.ROW_KEEP_WITH_NEXT);
}
//Check for keep-with-previous row attribute.
- if ((p=props.get("keep-with-previous"))!=null){
+ if ((p = props.get("keep-with-previous")) != null) {
attrib.set(ITableAttributes.ROW_KEEP_WITH_PREVIOUS);
}
//Check for height row attribute.
- if ((p=props.get("height"))!=null){
- Float f=new Float(p.getLength().getValue()/1000);
+ if ((p = props.get("height")) != null) {
+ Float f = new Float(p.getLength().getValue() / 1000);
attrValue = f.toString() + "pt";
- attrib.set(ITableAttributes.ROW_HEIGHT, (int)FoUnitsConverter.getInstance().convertToTwips(attrValue));
- }
-
- /* to write a border to a side of a cell one must write the directional side (ie. left, right) and the inside value
- * if one needs to be taken out ie if the cell lies on the edge of a table or not, the offending value will be taken out
- * by RtfTableRow. This is because you can't say BORDER_TOP and BORDER_HORIZONTAL if the cell lies at the
- * top of the table. Similarly using BORDER_BOTTOM and BORDER_HORIZONTAL will not work if the cell lies at th
- * bottom of the table. The same rules apply for left right and vertical.
-
- * Also, the border type must be written after every control word. Thus it is implemented that the border type is the value
- * of the border place.
+ attrib.set(ITableAttributes.ROW_HEIGHT,
+ (int)FoUnitsConverter.getInstance().convertToTwips(attrValue));
+ }
+
+ /* to write a border to a side of a cell one must write the directional
+ * side (ie. left, right) and the inside value if one needs to be taken
+ * out ie if the cell lies on the edge of a table or not, the offending
+ * value will be taken out by RtfTableRow. This is because you can't
+ * say BORDER_TOP and BORDER_HORIZONTAL if the cell lies at the top of
+ * the table. Similarly using BORDER_BOTTOM and BORDER_HORIZONTAL will
+ * not work if the cell lies at th bottom of the table. The same rules
+ * apply for left right and vertical.
+
+ * Also, the border type must be written after every control word. Thus
+ * it is implemented that the border type is the value of the border
+ * place.
*/
- if((p=props.get("border-style"))!=null){
- log.warn("border-style not implemented. Please use border-style-left, ...-right, ...-top or ...-bottom");
-
-// attrValue = new String(AbstractBuilder.getValue( attrs, "border-style", defAttrs ));
-// attrib.set(ITableAttributes.ROW_BORDER_LEFT,"\\"+BorderAttributesConverter.convertAttributetoRtf(attrValue));
-// attrib.set(ITableAttributes.ROW_BORDER_RIGHT,"\\"+BorderAttributesConverter.convertAttributetoRtf(attrValue));
-// attrib.set(ITableAttributes.ROW_BORDER_HORIZONTAL,"\\"+BorderAttributesConverter.convertAttributetoRtf(attrValue));
-// attrib.set(ITableAttributes.ROW_BORDER_VERTICAL,"\\"+BorderAttributesConverter.convertAttributetoRtf(attrValue));
-// attrib.set(ITableAttributes.ROW_BORDER_BOTTOM,"\\"+BorderAttributesConverter.convertAttributetoRtf(attrValue));
-// attrib.set(ITableAttributes.ROW_BORDER_TOP,"\\"+BorderAttributesConverter.convertAttributetoRtf(attrValue));
-// isBorderPresent=true;
- }
- ep=(EnumProperty)props.get("border-top-style");
- if(ep!=null && ep.getEnum()!=Constants.NONE){
- attrib.set(ITableAttributes.ROW_BORDER_TOP, "\\"+convertAttributetoRtf(ep.getEnum()));
- attrib.set(ITableAttributes.ROW_BORDER_HORIZONTAL,"\\"+convertAttributetoRtf(ep.getEnum()));
- isBorderPresent=true;
- }
- ep=(EnumProperty)props.get("border-bottom-style");
- if(ep!=null && ep.getEnum()!=Constants.NONE){
- attrib.set(ITableAttributes.ROW_BORDER_BOTTOM, "\\"+convertAttributetoRtf(ep.getEnum()));
- attrib.set(ITableAttributes.ROW_BORDER_HORIZONTAL,"\\"+convertAttributetoRtf(ep.getEnum()));
- isBorderPresent=true;
- }
- ep=(EnumProperty)props.get("border-left-style");
- if(ep!=null && ep.getEnum()!=Constants.NONE){
- attrib.set(ITableAttributes.ROW_BORDER_LEFT, "\\"+convertAttributetoRtf(ep.getEnum()));
- attrib.set(ITableAttributes.ROW_BORDER_VERTICAL, "\\"+convertAttributetoRtf(ep.getEnum()));
- isBorderPresent=true;
- }
- ep=(EnumProperty)props.get("border-right-style");
- if(ep!=null && ep.getEnum()!=Constants.NONE){
- attrib.set(ITableAttributes.ROW_BORDER_RIGHT, "\\"+convertAttributetoRtf(ep.getEnum()));
- attrib.set(ITableAttributes.ROW_BORDER_VERTICAL, "\\"+convertAttributetoRtf(ep.getEnum()));
- isBorderPresent=true;
- }
- ep=(EnumProperty)props.get("border-horizontal-style");
- if(ep!=null && ep.getEnum()!=Constants.NONE){
- attrib.set(ITableAttributes.ROW_BORDER_HORIZONTAL, "\\"+convertAttributetoRtf(ep.getEnum()));
- attrib.set(ITableAttributes.ROW_BORDER_TOP, "\\"+convertAttributetoRtf(ep.getEnum()));
- attrib.set(ITableAttributes.ROW_BORDER_BOTTOM, "\\"+convertAttributetoRtf(ep.getEnum()));
- isBorderPresent=true;
- }
- ep=(EnumProperty)props.get("border-vertical-style");
- if(ep!=null && ep.getEnum()!=Constants.NONE){
- attrib.set(ITableAttributes.ROW_BORDER_VERTICAL, "\\"+convertAttributetoRtf(ep.getEnum()));
- attrib.set(ITableAttributes.ROW_BORDER_LEFT, "\\"+convertAttributetoRtf(ep.getEnum()));
- attrib.set(ITableAttributes.ROW_BORDER_RIGHT, "\\"+convertAttributetoRtf(ep.getEnum()));
+ if ((p = props.get("border-style")) != null) {
+ log.warn("border-style not implemented. Please use border-style-left, "
+ + "...-right, ...-top or ...-bottom");
+/*
+ attrValue = new String(AbstractBuilder.getValue( attrs, "border-style", defAttrs ));
+ attrib.set(ITableAttributes.ROW_BORDER_LEFT,"\\"
+ + BorderAttributesConverter.convertAttributetoRtf(attrValue));
+ attrib.set(ITableAttributes.ROW_BORDER_RIGHT,"\\"
+ + BorderAttributesConverter.convertAttributetoRtf(attrValue));
+ attrib.set(ITableAttributes.ROW_BORDER_HORIZONTAL,"\\"
+ + BorderAttributesConverter.convertAttributetoRtf(attrValue));
+ attrib.set(ITableAttributes.ROW_BORDER_VERTICAL,"\\"
+ + BorderAttributesConverter.convertAttributetoRtf(attrValue));
+ attrib.set(ITableAttributes.ROW_BORDER_BOTTOM,"\\"
+ + BorderAttributesConverter.convertAttributetoRtf(attrValue));
+ attrib.set(ITableAttributes.ROW_BORDER_TOP,"\\"
+ + BorderAttributesConverter.convertAttributetoRtf(attrValue));
isBorderPresent=true;
- }
-
- if((p=props.get("border-width"))!=null){
- ListProperty listprop=(ListProperty)p;
- LengthProperty lengthprop=(LengthProperty)listprop.getList().get(0);
-
- Float f=new Float(lengthprop.getLength().getValue()/1000f);
+*/
+ }
+ ep = (EnumProperty)props.get("border-top-style");
+ if (ep != null && ep.getEnum() != Constants.NONE) {
+ attrib.set(ITableAttributes.ROW_BORDER_TOP, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ attrib.set(ITableAttributes.ROW_BORDER_HORIZONTAL, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ isBorderPresent = true;
+ }
+ ep = (EnumProperty)props.get("border-bottom-style");
+ if (ep != null && ep.getEnum() != Constants.NONE) {
+ attrib.set(ITableAttributes.ROW_BORDER_BOTTOM, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ attrib.set(ITableAttributes.ROW_BORDER_HORIZONTAL, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ isBorderPresent = true;
+ }
+ ep = (EnumProperty)props.get("border-left-style");
+ if (ep != null && ep.getEnum() != Constants.NONE) {
+ attrib.set(ITableAttributes.ROW_BORDER_LEFT, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ attrib.set(ITableAttributes.ROW_BORDER_VERTICAL, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ isBorderPresent = true;
+ }
+ ep = (EnumProperty)props.get("border-right-style");
+ if (ep != null && ep.getEnum() != Constants.NONE) {
+ attrib.set(ITableAttributes.ROW_BORDER_RIGHT, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ attrib.set(ITableAttributes.ROW_BORDER_VERTICAL, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ isBorderPresent = true;
+ }
+ ep = (EnumProperty)props.get("border-horizontal-style");
+ if (ep != null && ep.getEnum() != Constants.NONE) {
+ attrib.set(ITableAttributes.ROW_BORDER_HORIZONTAL, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ attrib.set(ITableAttributes.ROW_BORDER_TOP, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ attrib.set(ITableAttributes.ROW_BORDER_BOTTOM, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ isBorderPresent = true;
+ }
+ ep = (EnumProperty)props.get("border-vertical-style");
+ if (ep != null && ep.getEnum() != Constants.NONE) {
+ attrib.set(ITableAttributes.ROW_BORDER_VERTICAL, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ attrib.set(ITableAttributes.ROW_BORDER_LEFT, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ attrib.set(ITableAttributes.ROW_BORDER_RIGHT, "\\"
+ + convertAttributetoRtf(ep.getEnum()));
+ isBorderPresent = true;
+ }
+
+ if ((p = props.get("border-width")) != null) {
+ ListProperty listprop = (ListProperty)p;
+ LengthProperty lengthprop = (LengthProperty)listprop.getList().get(0);
+
+ Float f = new Float(lengthprop.getLength().getValue() / 1000f);
String sValue = f.toString() + "pt";
- attrib.set(BorderAttributesConverter.BORDER_WIDTH, (int)FoUnitsConverter.getInstance().convertToTwips(sValue));
- }
- else if(isBorderPresent){
+ attrib.set(BorderAttributesConverter.BORDER_WIDTH,
+ (int)FoUnitsConverter.getInstance().convertToTwips(sValue));
+ } else if (isBorderPresent) {
//if not defined, set default border width
//note 20 twips = 1 point
- attrib.set(BorderAttributesConverter.BORDER_WIDTH, (int)FoUnitsConverter.getInstance().convertToTwips("1pt"));
+ attrib.set(BorderAttributesConverter.BORDER_WIDTH,
+ (int)FoUnitsConverter.getInstance().convertToTwips("1pt"));
}
return attrib;
}
-
+ /**
+ *
+ * @param iBorderStyle the border style to be converted
+ * @return String with the converted border style
+ */
public static String convertAttributetoRtf(int iBorderStyle) {
// Added by Normand Masse
// "solid" is interpreted like "thin"
- if (iBorderStyle==Constants.SOLID) {
+ if (iBorderStyle == Constants.SOLID) {
return BorderAttributesConverter.BORDER_SINGLE_THICKNESS;
/* } else if (iBorderStyle==Constants.THIN) {
return BorderAttributesConverter.BORDER_SINGLE_THICKNESS;
@@ -408,11 +441,11 @@ public class TableAttributesConverter {
return BorderAttributesConverter.BORDER_DOUBLE_THICKNESS;
} else if (iBorderStyle==Constants. value.equals("shadowed")) {
return BorderAttributesConverter.BORDER_SHADOWED;*/
- } else if (iBorderStyle==Constants.DOUBLE) {
+ } else if (iBorderStyle == Constants.DOUBLE) {
return BorderAttributesConverter.BORDER_DOUBLE;
- } else if (iBorderStyle==Constants.DOTTED) {
+ } else if (iBorderStyle == Constants.DOTTED) {
return BorderAttributesConverter.BORDER_DOTTED;
- } else if (iBorderStyle==Constants.DASHED) {
+ } else if (iBorderStyle == Constants.DASHED) {
return BorderAttributesConverter.BORDER_DASH;
/* } else if (iBorderStyle==Constants value.equals("hairline")) {
return BorderAttributesConverter.BORDER_HAIRLINE;*/
diff --git a/src/java/org/apache/fop/rtf/renderer/TableContext.java b/src/java/org/apache/fop/rtf/renderer/TableContext.java
index 088da98a9..cd281f17b 100644
--- a/src/java/org/apache/fop/rtf/renderer/TableContext.java
+++ b/src/java/org/apache/fop/rtf/renderer/TableContext.java
@@ -1,4 +1,5 @@
/*
+ * $Id$
* ============================================================================
* The Apache Software License, Version 1.1
* ============================================================================
@@ -49,7 +50,7 @@
*/
package org.apache.fop.rtf.renderer;
-import java.util.*;
+import java.util.ArrayList;
import org.apache.avalon.framework.logger.ConsoleLogger;
import org.apache.avalon.framework.logger.Logger;
@@ -69,9 +70,8 @@ import org.apache.fop.rtf.rtflib.interfaces.ITableColumnsInfo;
* is now integrated into FOP.
*/
-class TableContext implements ITableColumnsInfo
-{
- private final Logger log=new ConsoleLogger();
+class TableContext implements ITableColumnsInfo {
+ private final Logger log = new ConsoleLogger();
private final BuilderContext m_context;
private final ArrayList m_colWidths = new ArrayList();
private int m_colIndex;
@@ -92,64 +92,53 @@ class TableContext implements ITableColumnsInfo
* For this purpose the attributes of a cell are stored in this array, as soon
* as a number-rows-spanned attribute has been found.
*/
- private final ArrayList m_colRowSpanningAttrs = new ArrayList(); //Added by Peter Herweg on 2002-06-29
+ private final ArrayList m_colRowSpanningAttrs = new ArrayList();
- private boolean m_bNextRowBelongsToHeader=false;
+ private boolean m_bNextRowBelongsToHeader = false;
- public void setNextRowBelongsToHeader(boolean bNextRowBelongsToHeader)
- {
- m_bNextRowBelongsToHeader=bNextRowBelongsToHeader;
+ public void setNextRowBelongsToHeader(boolean bNextRowBelongsToHeader) {
+ m_bNextRowBelongsToHeader = bNextRowBelongsToHeader;
}
- public boolean getNextRowBelongsToHeader()
- {
- return m_bNextRowBelongsToHeader;
- }
+ public boolean getNextRowBelongsToHeader() {
+ return m_bNextRowBelongsToHeader;
+ }
- TableContext(BuilderContext ctx)
- {
+ TableContext(BuilderContext ctx) {
m_context = ctx;
}
void setNextColumnWidth(String strWidth)
- throws Exception
- {
-
- m_colWidths.add( new Float(FoUnitsConverter.getInstance().convertToTwips(strWidth)));
+ throws Exception {
+ m_colWidths.add(new Float(FoUnitsConverter.getInstance().convertToTwips(strWidth)));
}
//Added by Peter Herweg on 2002-06-29
- RtfAttributes getColumnRowSpanningAttrs()
- {
+ RtfAttributes getColumnRowSpanningAttrs() {
return (RtfAttributes)m_colRowSpanningAttrs.get(m_colIndex);
}
//Added by Peter Herweg on 2002-06-29
- Integer getColumnRowSpanningNumber()
- {
+ Integer getColumnRowSpanningNumber() {
return (Integer)m_colRowSpanningNumber.get(m_colIndex);
}
//Added by Peter Herweg on 2002-06-29
void setCurrentColumnRowSpanning(Integer iRowSpanning, RtfAttributes attrs)
- throws Exception
- {
+ throws Exception {
- if(m_colIndex<m_colRowSpanningNumber.size())
- {
+ if (m_colIndex < m_colRowSpanningNumber.size()) {
m_colRowSpanningNumber.set(m_colIndex, iRowSpanning);
m_colRowSpanningAttrs.set(m_colIndex, attrs);
- }
- else
- {
+ } else {
m_colRowSpanningNumber.add(iRowSpanning);
m_colRowSpanningAttrs.add(m_colIndex, attrs);
}
}
//Added by Peter Herweg on 2002-06-29
- public void setNextColumnRowSpanning(Integer iRowSpanning, RtfAttributes attrs)
- {
+ public void setNextColumnRowSpanning(Integer iRowSpanning,
+ RtfAttributes attrs) {
m_colRowSpanningNumber.add(iRowSpanning);
m_colRowSpanningAttrs.add(m_colIndex, attrs);
}
@@ -160,47 +149,50 @@ class TableContext implements ITableColumnsInfo
* It decreases all values in m_colRowSpanningNumber by 1. If a value
* reaches 0 row-spanning is finished, and the value won't be decreased anymore.
*/
- public void decreaseRowSpannings()
- {
- for(int z=0;z<m_colRowSpanningNumber.size();++z)
- {
- Integer i=(Integer)m_colRowSpanningNumber.get(z);
+ public void decreaseRowSpannings() {
+ for (int z = 0; z < m_colRowSpanningNumber.size(); ++z) {
+ Integer i = (Integer)m_colRowSpanningNumber.get(z);
- if(i.intValue()>0)
- i=new Integer(i.intValue()-1);
+ if (i.intValue() > 0) {
+ i = new Integer(i.intValue() - 1);
+ }
- m_colRowSpanningNumber.set(z,i);
+ m_colRowSpanningNumber.set(z, i);
- if(i.intValue()==0)
- m_colRowSpanningAttrs.set(z,null);
+ if (i.intValue() == 0) {
+ m_colRowSpanningAttrs.set(z, null);
+ }
}
}
- /** reset the column iteration index, meant to be called when creating a new row
- * The 'public' modifier has been added by Boris Poudérous for 'number-columns-spanned' processing
+ /**
+ * Reset the column iteration index, meant to be called when creating a new row
+ * The 'public' modifier has been added by Boris Poudérous for
+ * 'number-columns-spanned' processing
*/
- public void selectFirstColumn()
- {
+ public void selectFirstColumn() {
m_colIndex = 0;
}
- /** increment the column iteration index
- * The 'public' modifier has been added by Boris Poudérous for 'number-columns-spanned' processing
+ /**
+ * Increment the column iteration index
+ * The 'public' modifier has been added by Boris Poudérous for
+ * 'number-columns-spanned' processing
*/
- public void selectNextColumn()
- {
+ public void selectNextColumn() {
m_colIndex++;
}
- /** get current column width according to column iteration index
- * @return INVALID_COLUMN_WIDTH if we cannot find the value
- * The 'public' modifier has been added by Boris Poudérous for 'number-columns-spanned' processing
+ /**
+ * Get current column width according to column iteration index
+ * @return INVALID_COLUMN_WIDTH if we cannot find the value
+ * The 'public' modifier has been added by Boris Poudérous for
+ * 'number-columns-spanned' processing
*/
- public float getColumnWidth()
- {
+ public float getColumnWidth() {
try {
return ((Float)m_colWidths.get(m_colIndex)).floatValue();
- } catch (IndexOutOfBoundsException ex) {
+ } catch (IndexOutOfBoundsException ex) {
// this code contributed by Trembicki-Guy, Ed <GuyE@DNB.com>
log.warn("fo:table-column width not defined, using " + INVALID_COLUM_WIDTH);
return INVALID_COLUM_WIDTH;
@@ -208,15 +200,13 @@ class TableContext implements ITableColumnsInfo
}
/** Added by Boris Poudérous on 07/22/2002 */
- public int getColumnIndex()
- {
+ public int getColumnIndex() {
return m_colIndex;
}
/** - end - */
/** Added by Boris Poudérous on 07/22/2002 */
- public int getNumberOfColumns()
- {
+ public int getNumberOfColumns() {
return m_colWidths.size();
}
/** - end - */