Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

BugZilla 67646 - allow append rows to streaming workbooks #600

Open
wants to merge 8 commits into
base: trunk
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -40,3 +40,9 @@ lib/

# Compiled module-info class-files
/poi*/src/*/java9/*.class

.DS_Store

.project

.classpath
2 changes: 1 addition & 1 deletion build.gradle
Original file line number Diff line number Diff line change
Expand Up @@ -100,7 +100,7 @@ allprojects {
// apply plugin: 'eclipse'
apply plugin: 'idea'

version = '5.2.5-SNAPSHOT'
Copy link
Contributor

@pjfanning pjfanning Feb 27, 2024

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why can't the PR just change code related to the title of the PR? - all other stuff must be reverted

version = '5.2.5-patched'
}

/**
Expand Down
1 change: 1 addition & 0 deletions poi-ooxml-lite-agent/bin/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
/main/
1 change: 1 addition & 0 deletions poi-ooxml/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
/bin/
Original file line number Diff line number Diff line change
Expand Up @@ -51,14 +51,14 @@ public int getLastRowNum() {
*/
@Override
public boolean isRowHidden(int rowIndex) {
SXSSFRow row = _xs.getRow(rowIndex);
SXSSFRow row = (SXSSFRow) _xs.getRow(rowIndex);
if (row == null) return false;
return row.getZeroHeight();
}

@Override
public EvaluationCell getCell(int rowIndex, int columnIndex) {
SXSSFRow row = _xs.getRow(rowIndex);
SXSSFRow row = (SXSSFRow) _xs.getRow(rowIndex);
if (row == null) {
if (rowIndex <= _xs.getLastFlushedRowNum()) {
throw new SXSSFFormulaEvaluator.RowFlushedException(rowIndex, _xs.getLastFlushedRowNum());
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,7 @@ public class SXSSFSheet implements Sheet, OoxmlSheetExtensions {
protected SheetDataWriter _writer;
private int _randomAccessWindowSize = SXSSFWorkbook.DEFAULT_WINDOW_SIZE;
protected AutoSizeColumnTracker _autoSizeColumnTracker;
private int outlineLevelRow;
private int lastFlushedRowNumber = -1;
private boolean allFlushed;
private int leftMostColumn = SpreadsheetVersion.EXCEL2007.getLastColumnIndex();
Expand Down Expand Up @@ -215,8 +216,13 @@ public void removeRow(Row row) {
* @return Row representing the rownumber or null if its not defined on the sheet
*/
@Override
public SXSSFRow getRow(int rownum) {
Copy link

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This might break user code.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

-1 this cannot be changed

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

However, this is compatible with the interface

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

ok - we might be able to change this but it would need to be in a major release - eg POI 6.0.0

return _rows.get(rownum);
public Row getRow(int rownum) {
Row row = _rows.get(rownum);
// BugZilla 67646: allow reading all the content
if (row == null) {
row = _sh.getRow(rownum);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

use spaces not tabs

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I will change my IDE settings

}
return row;
}

/**
Expand Down Expand Up @@ -249,7 +255,8 @@ public int getFirstRowNum() {
*/
@Override
public int getLastRowNum() {
return _rows.isEmpty() ? -1 : _rows.lastKey();
// BugZilla 67646 allow append
return _rows.isEmpty() ? _sh.getLastRowNum() : _rows.lastKey();
}

/**
Expand Down Expand Up @@ -1264,7 +1271,7 @@ public void setColumnGroupCollapsed(int columnNumber, boolean collapsed) {
*/
@Override
public void groupColumn(int fromColumn, int toColumn) {
_sh.groupColumn(fromColumn, toColumn);
_sh.groupColumn(fromColumn,toColumn);
}

/**
Expand Down Expand Up @@ -1317,14 +1324,16 @@ public void ungroupColumn(int fromColumn, int toColumn) {
*/
@Override
public void groupRow(int fromRow, int toRow) {
int maxLevelRow = -1;
for(SXSSFRow row : _rows.subMap(fromRow, toRow + 1).values()){
final int level = row.getOutlineLevel() + 1;
int level = row.getOutlineLevel() + 1;
row.setOutlineLevel(level);
maxLevelRow = Math.max(maxLevelRow, level);

if(level > outlineLevelRow) {
outlineLevelRow = level;
}
}

setWorksheetOutlineLevelRowIfNecessary((short) Math.min(Short.MAX_VALUE, maxLevelRow));
setWorksheetOutlineLevelRow();
}

/**
Expand All @@ -1344,16 +1353,19 @@ public void groupRow(int fromRow, int toRow) {
public void setRowOutlineLevel(int rownum, int level) {
SXSSFRow row = _rows.get(rownum);
row.setOutlineLevel(level);
setWorksheetOutlineLevelRowIfNecessary((short) Math.min(Short.MAX_VALUE, level));
if(level > 0 && level > outlineLevelRow) {
outlineLevelRow = level;
setWorksheetOutlineLevelRow();
}
}

private void setWorksheetOutlineLevelRowIfNecessary(final short levelRow) {
private void setWorksheetOutlineLevelRow() {
CTWorksheet ct = _sh.getCTWorksheet();
CTSheetFormatPr pr = ct.isSetSheetFormatPr() ?
ct.getSheetFormatPr() :
ct.addNewSheetFormatPr();
if(levelRow > _sh.getSheetFormatPrOutlineLevelRow()) {
pr.setOutlineLevelRow(levelRow);
if(outlineLevelRow > 0) {
pr.setOutlineLevelRow((short)outlineLevelRow);
}
}

Expand All @@ -1375,7 +1387,7 @@ public void ungroupRow(int fromRow, int toRow) {
*
* @param row start row of a grouped range of rows (0-based)
* @param collapse whether to expand/collapse the detail rows
* @throws IllegalStateException if collapse is false as this is not implemented for SXSSF.
* @throws RuntimeException if collapse is false as this is not implemented for SXSSF.
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

revert this

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Sorry, forgot the java doc to fix

*/
@Override
public void setRowGroupCollapsed(int row, boolean collapse) {
Expand All @@ -1391,15 +1403,15 @@ public void setRowGroupCollapsed(int row, boolean collapse) {
* @param rowIndex the zero based row index to collapse
*/
private void collapseRow(int rowIndex) {
SXSSFRow row = getRow(rowIndex);
SXSSFRow row = (SXSSFRow) getRow(rowIndex);
if(row == null) {
throw new IllegalArgumentException("Invalid row number("+ rowIndex + "). Row does not exist.");
} else {
int startRow = findStartOfRowOutlineGroup(rowIndex);

// Hide all the columns until the end of the group
int lastRow = writeHidden(row, startRow);
SXSSFRow lastRowObj = getRow(lastRow);
SXSSFRow lastRowObj = (SXSSFRow) getRow(lastRow);
if (lastRowObj != null) {
lastRowObj.setCollapsed(true);
} else {
Expand Down Expand Up @@ -1431,12 +1443,12 @@ private int findStartOfRowOutlineGroup(int rowIndex) {

private int writeHidden(SXSSFRow xRow, int rowIndex) {
int level = xRow.getOutlineLevel();
SXSSFRow currRow = getRow(rowIndex);
SXSSFRow currRow = (SXSSFRow) getRow(rowIndex);
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Now that you've changed getRow to return Row - how can we just cast to SXSSFRow? Couldn't this now also be an XSSFRow?

Copy link
Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Agree, actually the reference to SXSSFRow is not needed here, instead Row would be fine.


while (currRow != null && currRow.getOutlineLevel() >= level) {
currRow.setHidden(true);
rowIndex++;
currRow = getRow(rowIndex);
currRow = (SXSSFRow) getRow(rowIndex);
}
return rowIndex;
}
Expand Down Expand Up @@ -2172,6 +2184,11 @@ public void setTabColor(int colorIndex){
pr.setTabColor(color);
}

/**
* This method is not yet supported.
*
* @throws UnsupportedOperationException this method is not yet supported
*/
@NotImplemented
@Override
public void shiftColumns(int startColumn, int endColumn, int n){
Expand Down
2 changes: 2 additions & 0 deletions poi-scratchpad/bin/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
/main/
/test/
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

all these gitignore changes should be removed - you can update your own user .gitignore but we don't need these in svn - POI is not a Git project - it is an svn project

1 change: 1 addition & 0 deletions poi/.gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
/bin/