diff --git a/src/java/org/apache/poi/hssf/model/Sheet.java b/src/java/org/apache/poi/hssf/model/Sheet.java index 34063aee1d..c8e2e33826 100644 --- a/src/java/org/apache/poi/hssf/model/Sheet.java +++ b/src/java/org/apache/poi/hssf/model/Sheet.java @@ -105,7 +105,7 @@ public final class Sheet implements Model { private static POILogger log = POILogFactory.getLogger(Sheet.class); - private List records; + private List _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(128); + List records = new ArrayList(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 clonedRecords = new ArrayList(records.size()); - for (int i = 0; i < records.size(); i++) { - RecordBase rb = records.get(i); + List clonedRecords = new ArrayList(_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(32); + List records = new ArrayList(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 true 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 getRecords() - { - return records; + public List 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 null 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 true 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 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 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 temp = new ArrayList(); - 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); } diff --git a/src/testcases/org/apache/poi/hssf/model/TestSheet.java b/src/testcases/org/apache/poi/hssf/model/TestSheet.java index c68a5f8772..68ff2f6599 100644 --- a/src/testcases/org/apache/poi/hssf/model/TestSheet.java +++ b/src/testcases/org/apache/poi/hssf/model/TestSheet.java @@ -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;