aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGlen Stampoultzis <glens@apache.org>2002-04-10 12:48:00 +0000
committerGlen Stampoultzis <glens@apache.org>2002-04-10 12:48:00 +0000
commit4791b967baa790b4bfaacdc76009491ad1afdd6b (patch)
tree2c4232b742c2d413a07515ac1444d27e7f729fb8
parent403a5ff8a5eaba8003af683e7bd194694edbb298 (diff)
downloadpoi-4791b967baa790b4bfaacdc76009491ad1afdd6b.tar.gz
poi-4791b967baa790b4bfaacdc76009491ad1afdd6b.zip
Bug fix & cleanup
git-svn-id: https://svn.apache.org/repos/asf/jakarta/poi/trunk@352389 13f79535-47bb-0310-9956-ffa450edef68
-rw-r--r--src/documentation/xdocs/todo.xml92
-rw-r--r--src/java/org/apache/poi/hssf/model/Sheet.java18
-rw-r--r--src/java/org/apache/poi/hssf/record/RecordFactory.java6
-rw-r--r--src/java/org/apache/poi/hssf/usermodel/HSSFWorkbook.java3
-rw-r--r--src/testcases/org/apache/poi/hssf/usermodel/TestHSSFSheet.java60
5 files changed, 98 insertions, 81 deletions
diff --git a/src/documentation/xdocs/todo.xml b/src/documentation/xdocs/todo.xml
index ed5307fc91..35ef984a93 100644
--- a/src/documentation/xdocs/todo.xml
+++ b/src/documentation/xdocs/todo.xml
@@ -4,54 +4,54 @@
<todo title="Things To Do for Poi">
- <devs>
- <!-- in strict alphabetical order -->
- <person id="AO" name="Andrew C. Oliver" email="acoliver2@users.sourceforge.net"/>
- <person id="GS" name="Glen Stampoultzis" email="gstamp@iprimus.com.au"/>
- <person id="MJ" name="Marc Johnson" email="mjohnson at apache dot org"/>
- <person id="NKB" name="Nicola Ken Barozzi" email="barozzi@nicolaken.com"/>
- <person id="open" name="Poi Developers" email="poi-dev@jakarta.apache.org"/>
- </devs>
+ <devs>
+ <!-- in strict alphabetical order -->
+ <person id="AO" name="Andrew C. Oliver" email="acoliver2@users.sourceforge.net"/>
+ <person id="GS" name="Glen Stampoultzis" email="gstamp@iprimus.com.au"/>
+ <person id="MJ" name="Marc Johnson" email="mjohnson at apache dot org"/>
+ <person id="NKB" name="Nicola Ken Barozzi" email="barozzi@nicolaken.com"/>
+ <person id="open" name="Poi Developers" email="poi-dev@jakarta.apache.org"/>
+ </devs>
- <actions priority="high">
- <action context="code" assigned-to="NKB">
- Finish HDF
- </action>
- <action context="code" assigned-to="NKB">
- Finish Charts
- </action>
- <action context="code">
- Add Formulas.
- </action>
+ <actions priority="high">
+ <action context="code" assigned-to="NKB">
+ Finish HDF
+ </action>
+ <action context="code" assigned-to="NKB">
+ Finish Charts
+ </action>
+ <action context="code">
+ Add Formulas.
+ </action>
- </actions>
+ </actions>
- <actions priority="medium">
- <action context="code">
- Expose functionality in low level records in higher level API
- </action>
- <action context="code">
- Implement more record types (for other things ... not sure
- what this will mean yet).
- </action>
- <action context="code">
- Implement more record types (for other things ... not sure
- what this will mean yet).
- </action>
- <action context="code">
- Add more dummy checks (for when API user's do things they
- &quot;can't&quot; do)
- </action>
- <action context="code">
- Add support for embedded graphics and stuff like that.
- </action>
- <action context="code">
- Create new adapter object for handling MulBlank, MulRk, Rk
- records.
- </action>
- <action context="code">
- Add a way to copy sheets.
- </action>
- </actions>
+ <actions priority="medium">
+ <action context="code">
+ Expose functionality in low level records in higher level API
+ </action>
+ <action context="code">
+ Implement more record types (for other things ... not sure
+ what this will mean yet).
+ </action>
+ <action context="code">
+ Implement more record types (for other things ... not sure
+ what this will mean yet).
+ </action>
+ <action context="code">
+ Add more dummy checks (for when API user's do things they
+ &quot;can't&quot; do)
+ </action>
+ <action context="code">
+ Add support for embedded graphics and stuff like that.
+ </action>
+ <action context="code">
+ Create new adapter object for handling MulBlank, MulRk, Rk
+ records.
+ </action>
+ <action context="code">
+ Add a way to copy sheets.
+ </action>
+ </actions>
</todo>
diff --git a/src/java/org/apache/poi/hssf/model/Sheet.java b/src/java/org/apache/poi/hssf/model/Sheet.java
index c274da546f..a247e4745f 100644
--- a/src/java/org/apache/poi/hssf/model/Sheet.java
+++ b/src/java/org/apache/poi/hssf/model/Sheet.java
@@ -55,21 +55,17 @@
package org.apache.poi.hssf.model;
-import java.io.OutputStream;
-
import java.util.List;
import java.util.ArrayList;
import java.util.Iterator;
import org.apache.poi.util.POILogFactory;
-import org.apache.poi.hssf
- .record.*; // normally I don't do this, buy we literally mean ALL
+import org.apache.poi.hssf.record.*; // normally I don't do this, buy we literally mean ALL
import org.apache.poi.hssf.record.formula.FormulaUtil;
import org.apache.poi.hssf.record.formula.Ptg;
import org.apache.poi.util.IntList;
import org.apache.poi.util.POILogger;
-import org.apache.poi.hssf.record
- .aggregates.*; // normally I don't do this, buy we literally mean ALL
+import org.apache.poi.hssf.record.aggregates.*; // normally I don't do this, buy we literally mean ALL
/**
* Low level model implementation of a Sheet (one workbook contains many sheets)
@@ -116,7 +112,7 @@ public class Sheet
/**
* Creates new Sheet with no intialization --useless at this point
- * @see #createSheet(List,int,int)
+ * @see #createSheet(List,int)
*/
public Sheet()
@@ -132,7 +128,6 @@ public class Sheet
* is normally called via Workbook.
*
* @param recs array containing those records in the sheet in sequence (normally obtained from RecordFactory)
- * @param sheetnum integer specifying the sheet's number (0,1 or 2 in this release)
* @param offset of the sheet's BOF record
*
* @return Sheet object with all values set to those read from the file
@@ -140,7 +135,7 @@ public class Sheet
* @see org.apache.poi.hssf.model.Workbook
* @see org.apache.poi.hssf.record.Record
*/
- public static Sheet createSheet(List recs, int sheetnum, int offset)
+ public static Sheet createSheet(List recs, int offset)
{
log.logFormatted(log.DEBUG,
"Sheet createSheet (existing file) with %",
@@ -240,15 +235,14 @@ public class Sheet
* only the record offset is assumed to be 0.
*
* @param records array containing those records in the sheet in sequence (normally obtained from RecordFactory)
- * @param sheetnum integer specifying the sheet's number (0,1 or 2 in this release)
* @return Sheet object
*/
- public static Sheet createSheet(List records, int sheetnum)
+ public static Sheet createSheet(List records)
{
log.log(log.DEBUG,
"Sheet createSheet (exisiting file) assumed offset 0");
- return createSheet(records, sheetnum, 0);
+ return createSheet(records);
}
/**
diff --git a/src/java/org/apache/poi/hssf/record/RecordFactory.java b/src/java/org/apache/poi/hssf/record/RecordFactory.java
index 6beca36d25..480c9fbfac 100644
--- a/src/java/org/apache/poi/hssf/record/RecordFactory.java
+++ b/src/java/org/apache/poi/hssf/record/RecordFactory.java
@@ -63,7 +63,6 @@ import java.util.*;
import java.lang.reflect.Constructor;
import org.apache.poi.util.LittleEndian;
-import org.apache.poi.util.HexDump;
/**
* Title: Record Factory<P>
@@ -103,7 +102,7 @@ public class RecordFactory
WindowTwoRecord.class, SelectionRecord.class, ContinueRecord.class,
LabelRecord.class, BlankRecord.class, ColumnInfoRecord.class,
MulRKRecord.class, MulBlankRecord.class, MergeCellsRecord.class,
- FormulaRecord.class
+ FormulaRecord.class, BoolErrRecord.class
};
private static Map recordsMap = recordsToMap(records);
@@ -221,8 +220,9 @@ public class RecordFactory
}
catch (Exception introspectionException)
{
+ introspectionException.printStackTrace();
throw new RecordFormatException(
- "Unable to construct record instance");
+ "Unable to construct record instance, the following exception occured: " + introspectionException.getMessage());
}
if (retval instanceof RKRecord)
{
diff --git a/src/java/org/apache/poi/hssf/usermodel/HSSFWorkbook.java b/src/java/org/apache/poi/hssf/usermodel/HSSFWorkbook.java
index 221f16aed0..a851a1c426 100644
--- a/src/java/org/apache/poi/hssf/usermodel/HSSFWorkbook.java
+++ b/src/java/org/apache/poi/hssf/usermodel/HSSFWorkbook.java
@@ -142,11 +142,10 @@ public class HSSFWorkbook
workbook = Workbook.createWorkbook(records);
setPropertiesFromWorkbook(workbook);
int numRecords = workbook.getNumRecords();
- int sheetnum = 0;
while (numRecords < records.size())
{
- Sheet sheet = Sheet.createSheet(records, sheetnum, numRecords);
+ Sheet sheet = Sheet.createSheet(records);
numRecords += sheet.getNumRecords();
sheet.convertLabelRecords(
diff --git a/src/testcases/org/apache/poi/hssf/usermodel/TestHSSFSheet.java b/src/testcases/org/apache/poi/hssf/usermodel/TestHSSFSheet.java
index 195a33fdde..51901a10bc 100644
--- a/src/testcases/org/apache/poi/hssf/usermodel/TestHSSFSheet.java
+++ b/src/testcases/org/apache/poi/hssf/usermodel/TestHSSFSheet.java
@@ -1,4 +1,3 @@
-
/* ====================================================================
* The Apache Software License, Version 1.1
*
@@ -56,14 +55,13 @@
package org.apache.poi.hssf.usermodel;
import junit.framework.TestCase;
-
-import org.apache.poi.hssf.model.Workbook;
import org.apache.poi.hssf.model.Sheet;
import org.apache.poi.hssf.record.VCenterRecord;
import org.apache.poi.hssf.record.WSBoolRecord;
+import java.io.File;
+import java.io.FileInputStream;
import java.io.FileOutputStream;
-import java.io.FileWriter;
/**
* Tests HSSFSheet. This test case is very incomplete at the moment.
@@ -74,7 +72,7 @@ import java.io.FileWriter;
*/
public class TestHSSFSheet
- extends TestCase
+ extends TestCase
{
public TestHSSFSheet(String s)
{
@@ -86,11 +84,11 @@ public class TestHSSFSheet
*/
public void testBackupRecord()
- throws Exception
+ throws Exception
{
- HSSFWorkbook wb = new HSSFWorkbook();
- HSSFSheet s = wb.createSheet();
- Sheet sheet = s.getSheet();
+ HSSFWorkbook wb = new HSSFWorkbook();
+ HSSFSheet s = wb.createSheet();
+ Sheet sheet = s.getSheet();
assertEquals(true, sheet.getGridsetRecord().getGridset());
s.setGridsPrinted(true);
@@ -102,13 +100,13 @@ public class TestHSSFSheet
*/
public void testVerticallyCenter()
- throws Exception
+ throws Exception
{
- HSSFWorkbook wb = new HSSFWorkbook();
- HSSFSheet s = wb.createSheet();
- Sheet sheet = s.getSheet();
+ HSSFWorkbook wb = new HSSFWorkbook();
+ HSSFSheet s = wb.createSheet();
+ Sheet sheet = s.getSheet();
VCenterRecord record =
- ( VCenterRecord ) sheet.findFirstRecordBySid(VCenterRecord.sid);
+ (VCenterRecord) sheet.findFirstRecordBySid(VCenterRecord.sid);
assertEquals(false, record.getVCenter());
s.setVerticallyCenter(true);
@@ -123,11 +121,11 @@ public class TestHSSFSheet
public void testWSBool()
{
- HSSFWorkbook wb = new HSSFWorkbook();
- HSSFSheet s = wb.createSheet();
- Sheet sheet = s.getSheet();
+ HSSFWorkbook wb = new HSSFWorkbook();
+ HSSFSheet s = wb.createSheet();
+ Sheet sheet = s.getSheet();
WSBoolRecord record =
- ( WSBoolRecord ) sheet.findFirstRecordBySid(WSBoolRecord.sid);
+ (WSBoolRecord) sheet.findFirstRecordBySid(WSBoolRecord.sid);
// Check defaults
assertEquals(true, record.getAlternateExpression());
@@ -167,4 +165,30 @@ public class TestHSSFSheet
assertEquals(true, s.getRowSumsBelow());
assertEquals(true, s.getRowSumsRight());
}
+
+ public void testReadBooleans()
+ throws Exception
+ {
+ HSSFWorkbook workbook = new HSSFWorkbook();
+ HSSFSheet sheet = workbook.createSheet("Test boolean");
+ HSSFRow row = sheet.createRow((short) 2);
+ HSSFCell cell = row.createCell((short) 9);
+ cell.setCellValue(true);
+ cell = row.createCell((short) 11);
+ cell.setCellValue(true);
+ File tempFile = File.createTempFile("bool", "test.xls");
+ FileOutputStream stream = new FileOutputStream(tempFile);
+ workbook.write(stream);
+ stream.close();
+
+ FileInputStream readStream = new FileInputStream(tempFile);
+ workbook = new HSSFWorkbook(readStream);
+ sheet = workbook.getSheetAt(0);
+ row = sheet.getRow(2);
+ stream.close();
+ tempFile.delete();
+ assertEquals(2, row.getPhysicalNumberOfCells());
+
+
+ }
}