Code cleanup in hssf.model.Sheet. Minor re-formatting and compiler warning fixes.

git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@780792 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Josh Micich 2009-06-01 19:18:43 +00:00
parent 894c1e0653
commit 75c23de122
2 changed files with 118 additions and 173 deletions

View File

@ -105,7 +105,7 @@ public final class Sheet implements Model {
private static POILogger log = POILogFactory.getLogger(Sheet.class);
private List<RecordBase> records;
private List<RecordBase> _records;
protected PrintGridlinesRecord printGridlines = null;
protected GridsetRecord gridset = null;
private GutsRecord _gutsRecord;
@ -117,10 +117,10 @@ public final class Sheet implements Model {
protected ProtectRecord protect = null;
protected ObjectProtectRecord objprotect = null;
protected ScenarioProtectRecord scenprotect = null;
protected PasswordRecord password = null;
protected PasswordRecord _password = null;
protected WindowTwoRecord windowTwo = null;
protected SelectionRecord selection = null;
protected SelectionRecord _selection = null;
/** java object always present, but if empty no BIFF records are written */
private final MergedCellsTable _mergedCellsTable;
/** always present in this POI object, not always written to Excel file */
@ -164,7 +164,8 @@ public final class Sheet implements Model {
_mergedCellsTable = new MergedCellsTable();
RowRecordsAggregate rra = null;
records = new ArrayList<RecordBase>(128);
List<RecordBase> records = new ArrayList<RecordBase>(128);
_records = records; // needed here due to calls to findFirstRecordLocBySid before we're done
int dimsloc = -1;
if (rs.peekNextSid() != BOFRecord.sid) {
@ -292,7 +293,7 @@ public final class Sheet implements Model {
}
else if ( recSid == SelectionRecord.sid )
{
selection = (SelectionRecord) rec;
_selection = (SelectionRecord) rec;
}
else if ( recSid == WindowTwoRecord.sid )
{
@ -312,7 +313,7 @@ public final class Sheet implements Model {
}
else if ( recSid == PasswordRecord.sid )
{
password = (PasswordRecord) rec;
_password = (PasswordRecord) rec;
}
else if ( recSid == GutsRecord.sid )
{
@ -377,9 +378,9 @@ public final class Sheet implements Model {
* belongs to a sheet.
*/
public Sheet cloneSheet() {
List<RecordBase> clonedRecords = new ArrayList<RecordBase>(records.size());
for (int i = 0; i < records.size(); i++) {
RecordBase rb = records.get(i);
List<RecordBase> clonedRecords = new ArrayList<RecordBase>(_records.size());
for (int i = 0; i < _records.size(); i++) {
RecordBase rb = _records.get(i);
if (rb instanceof RecordAggregate) {
((RecordAggregate) rb).visitContainedRecords(new RecordCloner(clonedRecords));
continue;
@ -402,7 +403,7 @@ public final class Sheet implements Model {
}
private Sheet() {
_mergedCellsTable = new MergedCellsTable();
records = new ArrayList<RecordBase>(32);
List<RecordBase> records = new ArrayList<RecordBase>(32);
if (log.check( POILogger.DEBUG ))
log.log(POILogger.DEBUG, "Sheet createsheet from scratch called");
@ -444,12 +445,13 @@ public final class Sheet implements Model {
records.add(_rowsAggregate);
// 'Sheet View Settings'
records.add(windowTwo = createWindowTwo());
selection = createSelection();
records.add(selection);
_selection = createSelection();
records.add(_selection);
records.add(_mergedCellsTable); // MCT comes after 'Sheet View Settings'
records.add(EOFRecord.instance);
_records = records;
if (log.check( POILogger.DEBUG ))
log.log(POILogger.DEBUG, "Sheet createsheet from scratch exit");
}
@ -491,8 +493,7 @@ public final class Sheet implements Model {
return mrt.getNumberOfMergedRegions()-1;
}
public void removeMergedRegion(int index)
{
public void removeMergedRegion(int index) {
//safety checks
MergedCellsTable mrt = getMergedRecords();
if (index >= mrt.getNumberOfMergedRegions()) {
@ -516,7 +517,7 @@ public final class Sheet implements Model {
public ConditionalFormattingTable getConditionalFormattingTable() {
if (condFormatting == null) {
condFormatting = new ConditionalFormattingTable();
RecordOrderer.addNewSheetRecord(records, condFormatting);
RecordOrderer.addNewSheetRecord(_records, condFormatting);
}
return condFormatting;
}
@ -554,8 +555,8 @@ public final class Sheet implements Model {
boolean haveSerializedIndex = false;
for (int k = 0; k < records.size(); k++) {
RecordBase record = records.get(k);
for (int k = 0; k < _records.size(); k++) {
RecordBase record = _records.get(k);
if (record instanceof RecordAggregate) {
RecordAggregate agg = (RecordAggregate) record;
@ -596,8 +597,8 @@ public final class Sheet implements Model {
int result = 0;
// start just after BOF record (INDEX is not present in this list)
for (int j = bofRecordIndex + 1; j < records.size(); j++) {
RecordBase tmpRec = records.get(j);
for (int j = bofRecordIndex + 1; j < _records.size(); j++) {
RecordBase tmpRec = _records.get(j);
if (tmpRec instanceof RowRecordsAggregate) {
break;
}
@ -628,12 +629,10 @@ public final class Sheet implements Model {
}
DimensionsRecord d = _dimensions;
if (col.getColumn() > d.getLastCol())
{
if (col.getColumn() > d.getLastCol()) {
d.setLastCol(( short ) (col.getColumn() + 1));
}
if (col.getColumn() < d.getFirstCol())
{
if (col.getColumn() < d.getFirstCol()) {
d.setFirstCol(col.getColumn());
}
_rowsAggregate.insertCell(col);
@ -690,18 +689,15 @@ public final class Sheet implements Model {
* @param row the row record to be added
*/
public void addRow(RowRecord row)
{
public void addRow(RowRecord row) {
if (log.check( POILogger.DEBUG ))
log.log(POILogger.DEBUG, "addRow ");
DimensionsRecord d = _dimensions;
if (row.getRowNumber() >= d.getLastRow())
{
if (row.getRowNumber() >= d.getLastRow()) {
d.setLastRow(row.getRowNumber() + 1);
}
if (row.getRowNumber() < d.getFirstRow())
{
if (row.getRowNumber() < d.getFirstRow()) {
d.setFirstRow(row.getRowNumber());
}
@ -901,10 +897,11 @@ public final class Sheet implements Model {
retval.setColLevelMax(( short ) 0);
return retval;
}
private GutsRecord getGutsRecord() {
if (_gutsRecord == null) {
GutsRecord result = createGuts();
RecordOrderer.addNewSheetRecord(records, result);
RecordOrderer.addNewSheetRecord(_records, result);
_gutsRecord = result;
}
@ -952,17 +949,14 @@ public final class Sheet implements Model {
}
/**
* get whether gridlines are printed.
* @return true if printed
* @return <code>true</code> if gridlines are printed
*/
public boolean isGridsPrinted()
{
public boolean isGridsPrinted() {
if (gridset == null) {
gridset = createGridset();
//Insert the newlycreated Gridset record at the end of the record (just before the EOF)
int loc = findFirstRecordLocBySid(EOFRecord.sid);
records.add(loc, gridset);
_records.add(loc, gridset);
}
return !gridset.getGridset();
}
@ -971,9 +965,7 @@ public final class Sheet implements Model {
* set whether gridlines printed or not.
* @param value True if gridlines printed.
*/
public void setGridsPrinted(boolean value)
{
public void setGridsPrinted(boolean value) {
gridset.setGridset(!value);
}
@ -988,9 +980,7 @@ public final class Sheet implements Model {
/**
* set the default row height for the sheet (if the rows do not define their own height)
*/
public void setDefaultRowHeight(short dch)
{
public void setDefaultRowHeight(short dch) {
defaultrowheight.setRowHeight(dch);
}
@ -998,9 +988,7 @@ public final class Sheet implements Model {
* get the default row height for the sheet (if the rows do not define their own height)
* @return default row height
*/
public short getDefaultRowHeight()
{
public short getDefaultRowHeight() {
return defaultrowheight.getRowHeight();
}
@ -1012,7 +1000,6 @@ public final class Sheet implements Model {
* @see #setColumnWidth(int, int)
* @return column width in units of 1/256th of a character width
*/
public int getColumnWidth(int columnIndex) {
ColumnInfoRecord ci = _columnInfos.findColumnInfo(columnIndex);
@ -1159,15 +1146,12 @@ public final class Sheet implements Model {
return new SelectionRecord(0, 0);
}
public short getTopRow()
{
public short getTopRow() {
return (windowTwo==null) ? (short) 0 : windowTwo.getTopRow();
}
public void setTopRow(short topRow)
{
if (windowTwo!=null)
{
public void setTopRow(short topRow) {
if (windowTwo!=null) {
windowTwo.setTopRow(topRow);
}
}
@ -1176,7 +1160,7 @@ public final class Sheet implements Model {
* Sets the left column to show in desktop window pane.
* @param leftCol the left column to show in desktop window pane
*/
public void setLeftCol(short leftCol){
public void setLeftCol(short leftCol) {
if (windowTwo!=null) {
windowTwo.setLeftCol(leftCol);
}
@ -1192,13 +1176,11 @@ public final class Sheet implements Model {
* @see org.apache.poi.hssf.record.SelectionRecord
* @return row the active row index
*/
public int getActiveCellRow()
{
if (selection == null)
{
public int getActiveCellRow() {
if (_selection == null) {
return 0;
}
return selection.getActiveCellRow();
return _selection.getActiveCellRow();
}
/**
@ -1207,12 +1189,10 @@ public final class Sheet implements Model {
* @param row the row index
* @see org.apache.poi.hssf.record.SelectionRecord
*/
public void setActiveCellRow(int row)
{
public void setActiveCellRow(int row) {
//shouldn't have a sheet w/o a SelectionRecord, but best to guard anyway
if (selection != null)
{
selection.setActiveCellRow(row);
if (_selection != null) {
_selection.setActiveCellRow(row);
}
}
@ -1221,10 +1201,10 @@ public final class Sheet implements Model {
* @return column of the active cell
*/
public short getActiveCellCol() {
if (selection == null) {
if (_selection == null) {
return 0;
}
return (short)selection.getActiveCellCol();
return (short)_selection.getActiveCellCol();
}
/**
@ -1233,24 +1213,21 @@ public final class Sheet implements Model {
* @param col the column index
* @see org.apache.poi.hssf.record.SelectionRecord
*/
public void setActiveCellCol(short col)
{
public void setActiveCellCol(short col) {
//shouldn't have a sheet w/o a SelectionRecord, but best to guard anyway
if (selection != null)
if (_selection != null)
{
selection.setActiveCellCol(col);
_selection.setActiveCellCol(col);
}
}
public List<RecordBase> getRecords()
{
return records;
public List<RecordBase> getRecords() {
return _records;
}
/**
* Gets the gridset record for this sheet.
*/
public GridsetRecord getGridsetRecord()
{
return gridset;
@ -1259,14 +1236,12 @@ public final class Sheet implements Model {
/**
* Returns the first occurrence of a record matching a particular sid.
*/
public Record findFirstRecordBySid(short sid)
{
public Record findFirstRecordBySid(short sid) {
int ix = findFirstRecordLocBySid(sid);
if (ix < 0) {
return null;
}
return (Record) records.get(ix);
return (Record) _records.get(ix);
}
/**
@ -1275,20 +1250,15 @@ public final class Sheet implements Model {
*
* @param sclRecord The record to set.
*/
public void setSCLRecord(SCLRecord sclRecord)
{
public void setSCLRecord(SCLRecord sclRecord) {
int oldRecordLoc = findFirstRecordLocBySid(SCLRecord.sid);
if (oldRecordLoc == -1)
{
if (oldRecordLoc == -1) {
// Insert it after the window record
int windowRecordLoc = findFirstRecordLocBySid(WindowTwoRecord.sid);
records.add(windowRecordLoc+1, sclRecord);
_records.add(windowRecordLoc+1, sclRecord);
} else {
_records.set(oldRecordLoc, sclRecord);
}
else
{
records.set(oldRecordLoc, sclRecord);
}
}
/**
@ -1299,9 +1269,9 @@ public final class Sheet implements Model {
* is made.
*/
public int findFirstRecordLocBySid( short sid ) { // TODO - remove this method
int max = records.size();
int max = _records.size();
for (int i=0; i< max; i++) {
Object rb = records.get(i);
Object rb = _records.get(i);
if (!(rb instanceof Record)) {
continue;
}
@ -1350,11 +1320,10 @@ public final class Sheet implements Model {
* @param topRow Top row visible in bottom pane
* @param leftmostColumn Left column visible in right pane.
*/
public void createFreezePane(int colSplit, int rowSplit, int topRow, int leftmostColumn )
{
public void createFreezePane(int colSplit, int rowSplit, int topRow, int leftmostColumn) {
int paneLoc = findFirstRecordLocBySid(PaneRecord.sid);
if (paneLoc != -1)
records.remove(paneLoc);
_records.remove(paneLoc);
int loc = findFirstRecordLocBySid(WindowTwoRecord.sid);
PaneRecord pane = new PaneRecord();
@ -1362,21 +1331,16 @@ public final class Sheet implements Model {
pane.setY((short)rowSplit);
pane.setTopRow((short) topRow);
pane.setLeftColumn((short) leftmostColumn);
if (rowSplit == 0)
{
if (rowSplit == 0) {
pane.setTopRow((short)0);
pane.setActivePane((short)1);
}
else if (colSplit == 0)
{
} else if (colSplit == 0) {
pane.setLeftColumn((short)64);
pane.setActivePane((short)2);
}
else
{
} else {
pane.setActivePane((short)0);
}
records.add(loc+1, pane);
_records.add(loc+1, pane);
windowTwo.setFreezePanes(true);
windowTwo.setFreezePanesNoSplit(true);
@ -1399,11 +1363,10 @@ public final class Sheet implements Model {
* @see #PANE_UPPER_LEFT
* @see #PANE_UPPER_RIGHT
*/
public void createSplitPane(int xSplitPos, int ySplitPos, int topRow, int leftmostColumn, int activePane )
{
public void createSplitPane(int xSplitPos, int ySplitPos, int topRow, int leftmostColumn, int activePane) {
int paneLoc = findFirstRecordLocBySid(PaneRecord.sid);
if (paneLoc != -1)
records.remove(paneLoc);
_records.remove(paneLoc);
int loc = findFirstRecordLocBySid(WindowTwoRecord.sid);
PaneRecord r = new PaneRecord();
@ -1412,7 +1375,7 @@ public final class Sheet implements Model {
r.setTopRow((short) topRow);
r.setLeftColumn((short) leftmostColumn);
r.setActivePane((short) activePane);
records.add(loc+1, r);
_records.add(loc+1, r);
windowTwo.setFreezePanes(false);
windowTwo.setFreezePanesNoSplit(false);
@ -1424,7 +1387,7 @@ public final class Sheet implements Model {
/**
* Returns the information regarding the currently configured pane (split or freeze).
* @return null if no pane configured, or the pane information.
* @return <code>null</code> if no pane configured, or the pane information.
*/
public PaneInformation getPaneInformation() {
PaneRecord rec = (PaneRecord)findFirstRecordBySid(PaneRecord.sid);
@ -1435,14 +1398,12 @@ public final class Sheet implements Model {
rec.getLeftColumn(), (byte)rec.getActivePane(), windowTwo.getFreezePanes());
}
public SelectionRecord getSelection()
{
return selection;
public SelectionRecord getSelection() {
return _selection;
}
public void setSelection( SelectionRecord selection )
{
this.selection = selection;
public void setSelection( SelectionRecord selection) {
_selection = selection;
}
/**
@ -1469,32 +1430,30 @@ public final class Sheet implements Model {
return retval;
}
/** Returns the ProtectRecord.
* If one is not contained in the sheet, then one is created.
/**
* @return the ProtectRecord. If one is not contained in the sheet, then one is created.
*/
public ProtectRecord getProtect()
{
public ProtectRecord getProtect() {
if (protect == null) {
protect = new ProtectRecord(false);
// Insert the newly created protect record just before DefaultColWidthRecord
int loc = findFirstRecordLocBySid(DefaultColWidthRecord.sid);
records.add(loc, protect);
_records.add(loc, protect);
}
return protect;
}
/** Returns the PasswordRecord.
* If one is not contained in the sheet, then one is created.
/**
* @return the PasswordRecord. If one is not contained in the sheet, then one is created.
*/
public PasswordRecord getPassword()
{
if (password == null) {
password = createPassword();
public PasswordRecord getPassword() {
if (_password == null) {
_password = createPassword();
//Insert the newly created password record at the end of the record (just before the EOF)
int loc = findFirstRecordLocBySid(EOFRecord.sid);
records.add(loc, password);
_records.add(loc, _password);
}
return password;
return _password;
}
/**
@ -1504,8 +1463,6 @@ public final class Sheet implements Model {
return new PasswordRecord(0x0000);
}
/**
/**
* Sets whether the gridlines are shown in a viewer.
* @param show whether to show gridlines or not
@ -1515,8 +1472,7 @@ public final class Sheet implements Model {
}
/**
* Returns if gridlines are displayed.
* @return whether gridlines are displayed
* @return <code>true</code> if gridlines are displayed
*/
public boolean isDisplayGridlines() {
return windowTwo.getDisplayGridlines();
@ -1577,12 +1533,10 @@ public final class Sheet implements Model {
* @param drawingManager The DrawingManager2 for our workbook
* @param createIfMissing Should one be created if missing?
*/
public int aggregateDrawingRecords(DrawingManager2 drawingManager, boolean createIfMissing)
{
public int aggregateDrawingRecords(DrawingManager2 drawingManager, boolean createIfMissing) {
int loc = findFirstRecordLocBySid(DrawingRecord.sid);
boolean noDrawingRecordsFound = (loc == -1);
if (noDrawingRecordsFound)
{
if (noDrawingRecordsFound) {
if(!createIfMissing) {
// None found, and not allowed to add in
return -1;
@ -1590,35 +1544,29 @@ public final class Sheet implements Model {
EscherAggregate aggregate = new EscherAggregate( drawingManager );
loc = findFirstRecordLocBySid(EscherAggregate.sid);
if (loc == -1)
{
if (loc == -1) {
loc = findFirstRecordLocBySid( WindowTwoRecord.sid );
}
else
{
} else {
getRecords().remove(loc);
}
getRecords().add( loc, aggregate );
return loc;
}
else
List<RecordBase> records = getRecords();
EscherAggregate r = EscherAggregate.createAggregate( records, loc, drawingManager );
int startloc = loc;
while ( loc + 1 < records.size()
&& records.get( loc ) instanceof DrawingRecord
&& records.get( loc + 1 ) instanceof ObjRecord )
{
List<RecordBase> records = getRecords();
EscherAggregate r = EscherAggregate.createAggregate( records, loc, drawingManager );
int startloc = loc;
while ( loc + 1 < records.size()
&& records.get( loc ) instanceof DrawingRecord
&& records.get( loc + 1 ) instanceof ObjRecord )
{
loc += 2;
}
int endloc = loc-1;
for(int i = 0; i < (endloc - startloc + 1); i++)
records.remove(startloc);
records.add(startloc, r);
return startloc;
loc += 2;
}
int endloc = loc-1;
for(int i = 0; i < (endloc - startloc + 1); i++)
records.remove(startloc);
records.add(startloc, r);
return startloc;
}
/**
@ -1626,13 +1574,12 @@ public final class Sheet implements Model {
* For instance the escher aggregates size needs to be calculated before
* serialization so that the dgg record (which occurs first) can be written.
*/
public void preSerialize()
{
for ( Iterator iterator = getRecords().iterator(); iterator.hasNext(); )
{
RecordBase r = (RecordBase) iterator.next();
if (r instanceof EscherAggregate)
r.getRecordSize(); // Trigger flatterning of user model and corresponding update of dgg record.
public void preSerialize() {
for (RecordBase r: getRecords()) {
if (r instanceof EscherAggregate) {
// Trigger flattening of user model and corresponding update of dgg record.
r.getRecordSize();
}
}
}
@ -1640,7 +1587,7 @@ public final class Sheet implements Model {
public PageSettingsBlock getPageSettings() {
if (_psBlock == null) {
_psBlock = new PageSettingsBlock();
RecordOrderer.addNewSheetRecord(records, _psBlock);
RecordOrderer.addNewSheetRecord(_records, _psBlock);
}
return _psBlock;
}
@ -1668,18 +1615,18 @@ public final class Sheet implements Model {
prec.setProtect(true);
pass.setPassword(PasswordRecord.hashPassword(password));
if((objprotect == null && objects) || (scenprotect != null && scenarios)) {
protIdx = records.indexOf( protect );
protIdx = _records.indexOf( protect );
}
if(objprotect == null && objects) {
ObjectProtectRecord rec = createObjectProtect();
rec.setProtect(true);
records.add(protIdx+1,rec);
_records.add(protIdx+1,rec);
objprotect = rec;
}
if(scenprotect == null && scenarios) {
ScenarioProtectRecord srec = createScenarioProtect();
srec.setProtect(true);
records.add(protIdx+2,srec);
_records.add(protIdx+2,srec);
scenprotect = srec;
}
}
@ -1737,12 +1684,10 @@ public final class Sheet implements Model {
recalcRowGutter();
}
private void recalcRowGutter()
{
private void recalcRowGutter() {
int maxLevel = 0;
Iterator iterator = _rowsAggregate.getIterator();
while ( iterator.hasNext() )
{
while (iterator.hasNext()) {
RowRecord rowRecord = (RowRecord) iterator.next();
maxLevel = Math.max(rowRecord.getOutlineLevel(), maxLevel);
}
@ -1757,7 +1702,7 @@ public final class Sheet implements Model {
public DataValidityTable getOrCreateDataValidityTable() {
if (_dataValidityTable == null) {
DataValidityTable result = new DataValidityTable();
RecordOrderer.addNewSheetRecord(records, result);
RecordOrderer.addNewSheetRecord(_records, result);
_dataValidityTable = result;
}
return _dataValidityTable;
@ -1768,8 +1713,8 @@ public final class Sheet implements Model {
*/
public NoteRecord[] getNoteRecords() {
List<NoteRecord> temp = new ArrayList<NoteRecord>();
for(int i=records.size()-1; i>=0; i--) {
RecordBase rec = records.get(i);
for(int i=_records.size()-1; i>=0; i--) {
RecordBase rec = _records.get(i);
if (rec instanceof NoteRecord) {
temp.add((NoteRecord) rec);
}

View File

@ -613,7 +613,7 @@ public final class TestSheet extends TestCase {
try {
sheet = createSheet(inRecs);
} catch (RuntimeException e) {
if (e.getMessage().equals("DimensionsRecord was not found")) {
if ("DimensionsRecord was not found".equals(e.getMessage())) {
throw new AssertionFailedError("Identified bug 46206");
}
throw e;