Bug 51504 - avoid NPE when DefaultRowHeight or DefaultColumnWidth records are missing

git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1147049 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Yegor Kozlov 2011-07-15 09:18:09 +00:00
parent 673891cc9e
commit a58d9dd33b
5 changed files with 47 additions and 11 deletions

View File

@ -34,6 +34,7 @@
<changes> <changes>
<release version="3.8-beta4" date="2011-??-??"> <release version="3.8-beta4" date="2011-??-??">
<action dev="poi-developers" type="fix">51504 - avoid NPE when DefaultRowHeight or DefaultColumnWidth records are missing</action>
<action dev="poi-developers" type="fix">51502 - Correct Subtotal function javadoc entry</action> <action dev="poi-developers" type="fix">51502 - Correct Subtotal function javadoc entry</action>
<action dev="poi-developers" type="add">Support for hyperlinks in SXSSF</action> <action dev="poi-developers" type="add">Support for hyperlinks in SXSSF</action>
<action dev="poi-developers" type="fix">49933 - Word 6/95 documents with sections cause ArrayIndexOutOfBoundsException</action> <action dev="poi-developers" type="fix">49933 - Word 6/95 documents with sections cause ArrayIndexOutOfBoundsException</action>

View File

@ -65,12 +65,12 @@ import org.apache.poi.hssf.record.aggregates.DataValidityTable;
import org.apache.poi.hssf.record.aggregates.MergedCellsTable; import org.apache.poi.hssf.record.aggregates.MergedCellsTable;
import org.apache.poi.hssf.record.aggregates.PageSettingsBlock; import org.apache.poi.hssf.record.aggregates.PageSettingsBlock;
import org.apache.poi.hssf.record.aggregates.RecordAggregate; import org.apache.poi.hssf.record.aggregates.RecordAggregate;
import org.apache.poi.hssf.record.aggregates.RowRecordsAggregate;
import org.apache.poi.hssf.record.aggregates.WorksheetProtectionBlock;
import org.apache.poi.hssf.record.aggregates.RecordAggregate.PositionTrackingVisitor; import org.apache.poi.hssf.record.aggregates.RecordAggregate.PositionTrackingVisitor;
import org.apache.poi.hssf.record.aggregates.RecordAggregate.RecordVisitor; import org.apache.poi.hssf.record.aggregates.RecordAggregate.RecordVisitor;
import org.apache.poi.ss.formula.FormulaShifter; import org.apache.poi.hssf.record.aggregates.RowRecordsAggregate;
import org.apache.poi.hssf.record.aggregates.WorksheetProtectionBlock;
import org.apache.poi.hssf.util.PaneInformation; import org.apache.poi.hssf.util.PaneInformation;
import org.apache.poi.ss.formula.FormulaShifter;
import org.apache.poi.ss.util.CellRangeAddress; import org.apache.poi.ss.util.CellRangeAddress;
import org.apache.poi.util.Internal; import org.apache.poi.util.Internal;
import org.apache.poi.util.POILogFactory; import org.apache.poi.util.POILogFactory;
@ -110,8 +110,8 @@ public final class InternalSheet {
protected PrintGridlinesRecord printGridlines = null; protected PrintGridlinesRecord printGridlines = null;
protected GridsetRecord gridset = null; protected GridsetRecord gridset = null;
private GutsRecord _gutsRecord; private GutsRecord _gutsRecord;
protected DefaultColWidthRecord defaultcolwidth = null; protected DefaultColWidthRecord defaultcolwidth = new DefaultColWidthRecord();
protected DefaultRowHeightRecord defaultrowheight = null; protected DefaultRowHeightRecord defaultrowheight = new DefaultRowHeightRecord();
private PageSettingsBlock _psBlock; private PageSettingsBlock _psBlock;
/** /**
@ -753,7 +753,7 @@ public final class InternalSheet {
* subsequent calls will return values in (physical) sequence or NULL when you get to the end. * subsequent calls will return values in (physical) sequence or NULL when you get to the end.
* *
* @return Array of CellValueRecordInterface representing the remaining value records * @return Array of CellValueRecordInterface representing the remaining value records
* @deprecated use {@link #getValueIterator()} instead * @deprecated use {@link #getCellValueIterator()} instead
*/ */
@Deprecated @Deprecated
public CellValueRecordInterface[] getValueRecords() { public CellValueRecordInterface[] getValueRecords() {
@ -934,7 +934,7 @@ public final class InternalSheet {
DefaultRowHeightRecord retval = new DefaultRowHeightRecord(); DefaultRowHeightRecord retval = new DefaultRowHeightRecord();
retval.setOptionFlags(( short ) 0); retval.setOptionFlags(( short ) 0);
retval.setRowHeight(( short ) 0xff); retval.setRowHeight(DefaultRowHeightRecord.DEFAULT_ROW_HEIGHT);
return retval; return retval;
} }
@ -955,7 +955,7 @@ public final class InternalSheet {
*/ */
private static DefaultColWidthRecord createDefaultColWidth() { private static DefaultColWidthRecord createDefaultColWidth() {
DefaultColWidthRecord retval = new DefaultColWidthRecord(); DefaultColWidthRecord retval = new DefaultColWidthRecord();
retval.setColWidth(( short ) 8); retval.setColWidth(DefaultColWidthRecord.DEFAULT_COLUMN_WIDTH);
return retval; return retval;
} }

View File

@ -32,8 +32,14 @@ public final class DefaultColWidthRecord extends StandardRecord {
public final static short sid = 0x0055; public final static short sid = 0x0055;
private int field_1_col_width; private int field_1_col_width;
/**
* The default column width is 8 characters
*/
public final static int DEFAULT_COLUMN_WIDTH = 0x0008;
public DefaultColWidthRecord() public DefaultColWidthRecord()
{ {
field_1_col_width = DEFAULT_COLUMN_WIDTH;
} }
public DefaultColWidthRecord(RecordInputStream in) public DefaultColWidthRecord(RecordInputStream in)

View File

@ -38,8 +38,15 @@ public final class DefaultRowHeightRecord
private short field_1_option_flags; private short field_1_option_flags;
private short field_2_row_height; private short field_2_row_height;
/**
* The default row height for empty rows is 255 twips (255 / 20 == 12.75 points)
*/
public static final short DEFAULT_ROW_HEIGHT = 0xFF;
public DefaultRowHeightRecord() public DefaultRowHeightRecord()
{ {
field_1_option_flags = 0x0000;
field_2_row_height = DEFAULT_ROW_HEIGHT;
} }
public DefaultRowHeightRecord(RecordInputStream in) public DefaultRowHeightRecord(RecordInputStream in)

View File

@ -736,6 +736,28 @@ public final class TestHSSFSheet extends BaseTestSheet {
assertEquals(40000, sh.getColumnWidth(0)); assertEquals(40000, sh.getColumnWidth(0));
} }
public void testDefaultColumnWidth() {
HSSFWorkbook wb = HSSFTestDataSamples.openSampleWorkbook( "12843-1.xls" );
HSSFSheet sheet = wb.getSheetAt( 7 );
// shall not be NPE
assertEquals(8, sheet.getDefaultColumnWidth());
assertEquals(8*256, sheet.getColumnWidth(0));
assertEquals(0xFF, sheet.getDefaultRowHeight());
wb = HSSFTestDataSamples.openSampleWorkbook( "34775.xls" );
// second and third sheets miss DefaultColWidthRecord
for(int i = 1; i <= 2; i++){
int dw = wb.getSheetAt( i ).getDefaultColumnWidth();
assertEquals(8, dw);
int cw = wb.getSheetAt( i ).getColumnWidth(0);
assertEquals(8*256, cw);
assertEquals(0xFF, sheet.getDefaultRowHeight());
}
}
/** /**
* Some utilities write Excel files without the ROW records. * Some utilities write Excel files without the ROW records.
* Excel, ooo, and google docs are OK with this. * Excel, ooo, and google docs are OK with this.