Bug 52233: Do not make the XSSFSheet invalid during write(), I could not find out why the ColsArray was set to null in the write() method. By removing this the writing of the sheet does not invalidate the Workbook any more and makes the test case work fine.
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1513916 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
2834048155
commit
17f3b2cb26
@ -87,7 +87,7 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
private Map<Integer, CTCellFormula> sharedFormulas;
|
private Map<Integer, CTCellFormula> sharedFormulas;
|
||||||
private TreeMap<String,XSSFTable> tables;
|
private TreeMap<String,XSSFTable> tables;
|
||||||
private List<CellRangeAddress> arrayFormulas;
|
private List<CellRangeAddress> arrayFormulas;
|
||||||
private XSSFDataValidationHelper dataValidationHelper;
|
private XSSFDataValidationHelper dataValidationHelper;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates new XSSFSheet - called by XSSFWorkbook to create a sheet from scratch.
|
* Creates new XSSFSheet - called by XSSFWorkbook to create a sheet from scratch.
|
||||||
@ -153,7 +153,7 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
tables.put( p.getPackageRelationship().getId(), (XSSFTable)p );
|
tables.put( p.getPackageRelationship().getId(), (XSSFTable)p );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Process external hyperlinks for the sheet, if there are any
|
// Process external hyperlinks for the sheet, if there are any
|
||||||
initHyperlinks();
|
initHyperlinks();
|
||||||
}
|
}
|
||||||
@ -170,12 +170,12 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation") //YK: getXYZArray() array accessors are deprecated in xmlbeans with JDK 1.5 support
|
@SuppressWarnings("deprecation") //YK: getXYZArray() array accessors are deprecated in xmlbeans with JDK 1.5 support
|
||||||
private void initRows(CTWorksheet worksheet) {
|
private void initRows(CTWorksheet worksheetParam) {
|
||||||
_rows = new TreeMap<Integer, XSSFRow>();
|
_rows = new TreeMap<Integer, XSSFRow>();
|
||||||
tables = new TreeMap<String, XSSFTable>();
|
tables = new TreeMap<String, XSSFTable>();
|
||||||
sharedFormulas = new HashMap<Integer, CTCellFormula>();
|
sharedFormulas = new HashMap<Integer, CTCellFormula>();
|
||||||
arrayFormulas = new ArrayList<CellRangeAddress>();
|
arrayFormulas = new ArrayList<CellRangeAddress>();
|
||||||
for (CTRow row : worksheet.getSheetData().getRowArray()) {
|
for (CTRow row : worksheetParam.getSheetData().getRowArray()) {
|
||||||
XSSFRow r = new XSSFRow(row, this);
|
XSSFRow r = new XSSFRow(row, this);
|
||||||
_rows.put(r.getRowNum(), r);
|
_rows.put(r.getRowNum(), r);
|
||||||
}
|
}
|
||||||
@ -426,7 +426,7 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
}
|
}
|
||||||
return drawing;
|
return drawing;
|
||||||
}
|
}
|
||||||
|
|
||||||
protected CTDrawing getCTDrawing() {
|
protected CTDrawing getCTDrawing() {
|
||||||
return worksheet.getDrawing();
|
return worksheet.getDrawing();
|
||||||
}
|
}
|
||||||
@ -480,7 +480,7 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
} else {
|
} else {
|
||||||
if(pane.isSetYSplit()) pane.unsetYSplit();
|
if(pane.isSetYSplit()) pane.unsetYSplit();
|
||||||
}
|
}
|
||||||
|
|
||||||
pane.setState(STPaneState.FROZEN);
|
pane.setState(STPaneState.FROZEN);
|
||||||
if (rowSplit == 0) {
|
if (rowSplit == 0) {
|
||||||
pane.setTopLeftCell(new CellReference(0, leftmostColumn).formatAsString());
|
pane.setTopLeftCell(new CellReference(0, leftmostColumn).formatAsString());
|
||||||
@ -1015,16 +1015,16 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
public boolean getProtect() {
|
public boolean getProtect() {
|
||||||
return worksheet.isSetSheetProtection() && sheetProtectionEnabled();
|
return worksheet.isSetSheetProtection() && sheetProtectionEnabled();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Enables sheet protection and sets the password for the sheet.
|
* Enables sheet protection and sets the password for the sheet.
|
||||||
* Also sets some attributes on the {@link CTSheetProtection} that correspond to
|
* Also sets some attributes on the {@link CTSheetProtection} that correspond to
|
||||||
* the default values used by Excel
|
* the default values used by Excel
|
||||||
*
|
*
|
||||||
* @param password to set for protection. Pass <code>null</code> to remove protection
|
* @param password to set for protection. Pass <code>null</code> to remove protection
|
||||||
*/
|
*/
|
||||||
public void protectSheet(String password) {
|
public void protectSheet(String password) {
|
||||||
|
|
||||||
if(password != null) {
|
if(password != null) {
|
||||||
CTSheetProtection sheetProtection = worksheet.addNewSheetProtection();
|
CTSheetProtection sheetProtection = worksheet.addNewSheetProtection();
|
||||||
sheetProtection.xsetPassword(stringToExcelPassword(password));
|
sheetProtection.xsetPassword(stringToExcelPassword(password));
|
||||||
@ -1039,7 +1039,7 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
/**
|
/**
|
||||||
* Converts a String to a {@link STUnsignedShortHex} value that contains the {@link PasswordRecord#hashPassword(String)}
|
* Converts a String to a {@link STUnsignedShortHex} value that contains the {@link PasswordRecord#hashPassword(String)}
|
||||||
* value in hexadecimal format
|
* value in hexadecimal format
|
||||||
*
|
*
|
||||||
* @param password the password string you wish convert to an {@link STUnsignedShortHex}
|
* @param password the password string you wish convert to an {@link STUnsignedShortHex}
|
||||||
* @return {@link STUnsignedShortHex} that contains Excel hashed password in Hex format
|
* @return {@link STUnsignedShortHex} that contains Excel hashed password in Hex format
|
||||||
*/
|
*/
|
||||||
@ -1048,7 +1048,7 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
hexPassword.setStringValue(String.valueOf(HexDump.shortToHex(PasswordRecord.hashPassword(password))).substring(2));
|
hexPassword.setStringValue(String.valueOf(HexDump.shortToHex(PasswordRecord.hashPassword(password))).substring(2));
|
||||||
return hexPassword;
|
return hexPassword;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the logical row ( 0-based). If you ask for a row that is not
|
* Returns the logical row ( 0-based). If you ask for a row that is not
|
||||||
* defined you get a null. This is to say row 4 represents the fifth row on a sheet.
|
* defined you get a null. This is to say row 4 represents the fifth row on a sheet.
|
||||||
@ -1220,7 +1220,7 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
worksheet.setColsArray(0,ctCols);
|
worksheet.setColsArray(0,ctCols);
|
||||||
setSheetFormatPrOutlineLevelCol();
|
setSheetFormatPrOutlineLevelCol();
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Do not leave the width attribute undefined (see #52186).
|
* Do not leave the width attribute undefined (see #52186).
|
||||||
*/
|
*/
|
||||||
@ -1539,7 +1539,7 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
|
|
||||||
/**
|
/**
|
||||||
* Whether Excel will be asked to recalculate all formulas when the
|
* Whether Excel will be asked to recalculate all formulas when the
|
||||||
* workbook is opened.
|
* workbook is opened.
|
||||||
*/
|
*/
|
||||||
public boolean getForceFormulaRecalculation() {
|
public boolean getForceFormulaRecalculation() {
|
||||||
if(worksheet.isSetSheetCalcPr()) {
|
if(worksheet.isSetSheetCalcPr()) {
|
||||||
@ -1548,7 +1548,7 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return an iterator of the PHYSICAL rows. Meaning the 3rd element may not
|
* @return an iterator of the PHYSICAL rows. Meaning the 3rd element may not
|
||||||
* be the third row if say for instance the second row is undefined.
|
* be the third row if say for instance the second row is undefined.
|
||||||
@ -2409,10 +2409,11 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
*
|
*
|
||||||
* @param toprow the top row to show in desktop window pane
|
* @param toprow the top row to show in desktop window pane
|
||||||
* @param leftcol the left column to show in desktop window pane
|
* @param leftcol the left column to show in desktop window pane
|
||||||
*
|
*
|
||||||
* @deprecated Use the version of showInPane() with ints as there can be more than 32767 rows.
|
* @deprecated Use the version of showInPane() with ints as there can be more than 32767 rows.
|
||||||
*/
|
*/
|
||||||
public void showInPane(short toprow, short leftcol) {
|
@Deprecated
|
||||||
|
public void showInPane(short toprow, short leftcol) {
|
||||||
showInPane((int)toprow, (int)leftcol);
|
showInPane((int)toprow, (int)leftcol);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2691,11 +2692,11 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
|
|
||||||
if(worksheet.sizeOfColsArray() == 1) {
|
if(worksheet.sizeOfColsArray() == 1) {
|
||||||
CTCols col = worksheet.getColsArray(0);
|
CTCols col = worksheet.getColsArray(0);
|
||||||
if(col.sizeOfColArray() == 0) {
|
if(col.sizeOfColArray() != 0) {
|
||||||
worksheet.setColsArray(null);
|
|
||||||
} else {
|
|
||||||
setColWidthAttribute(col);
|
setColWidthAttribute(col);
|
||||||
}
|
} /*else {
|
||||||
|
remove, see Bug 52233: worksheet.setColsArray(null);
|
||||||
|
}*/
|
||||||
}
|
}
|
||||||
|
|
||||||
// Now re-generate our CTHyperlinks, if needed
|
// Now re-generate our CTHyperlinks, if needed
|
||||||
@ -3109,7 +3110,7 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
public DataValidationHelper getDataValidationHelper() {
|
public DataValidationHelper getDataValidationHelper() {
|
||||||
return dataValidationHelper;
|
return dataValidationHelper;
|
||||||
}
|
}
|
||||||
|
|
||||||
@SuppressWarnings("deprecation") //YK: getXYZArray() array accessors are deprecated in xmlbeans with JDK 1.5 support
|
@SuppressWarnings("deprecation") //YK: getXYZArray() array accessors are deprecated in xmlbeans with JDK 1.5 support
|
||||||
public List<XSSFDataValidation> getDataValidations() {
|
public List<XSSFDataValidation> getDataValidations() {
|
||||||
List<XSSFDataValidation> xssfValidations = new ArrayList<XSSFDataValidation>();
|
List<XSSFDataValidation> xssfValidations = new ArrayList<XSSFDataValidation>();
|
||||||
@ -3117,7 +3118,7 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
if( dataValidations!=null && dataValidations.getCount() > 0 ) {
|
if( dataValidations!=null && dataValidations.getCount() > 0 ) {
|
||||||
for (CTDataValidation ctDataValidation : dataValidations.getDataValidationArray()) {
|
for (CTDataValidation ctDataValidation : dataValidations.getDataValidationArray()) {
|
||||||
CellRangeAddressList addressList = new CellRangeAddressList();
|
CellRangeAddressList addressList = new CellRangeAddressList();
|
||||||
|
|
||||||
@SuppressWarnings("unchecked")
|
@SuppressWarnings("unchecked")
|
||||||
List<String> sqref = ctDataValidation.getSqref();
|
List<String> sqref = ctDataValidation.getSqref();
|
||||||
for (String stRef : sqref) {
|
for (String stRef : sqref) {
|
||||||
@ -3138,7 +3139,7 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void addValidationData(DataValidation dataValidation) {
|
public void addValidationData(DataValidation dataValidation) {
|
||||||
XSSFDataValidation xssfDataValidation = (XSSFDataValidation)dataValidation;
|
XSSFDataValidation xssfDataValidation = (XSSFDataValidation)dataValidation;
|
||||||
CTDataValidations dataValidations = worksheet.getDataValidations();
|
CTDataValidations dataValidations = worksheet.getDataValidations();
|
||||||
if( dataValidations==null ) {
|
if( dataValidations==null ) {
|
||||||
dataValidations = worksheet.addNewDataValidations();
|
dataValidations = worksheet.addNewDataValidations();
|
||||||
@ -3164,7 +3165,7 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
XSSFName name = wb.getBuiltInName(XSSFName.BUILTIN_FILTER_DB, sheetIndex);
|
XSSFName name = wb.getBuiltInName(XSSFName.BUILTIN_FILTER_DB, sheetIndex);
|
||||||
if (name == null) {
|
if (name == null) {
|
||||||
name = wb.createBuiltInName(XSSFName.BUILTIN_FILTER_DB, sheetIndex);
|
name = wb.createBuiltInName(XSSFName.BUILTIN_FILTER_DB, sheetIndex);
|
||||||
name.getCTName().setHidden(true);
|
name.getCTName().setHidden(true);
|
||||||
CellReference r1 = new CellReference(getSheetName(), range.getFirstRow(), range.getFirstColumn(), true, true);
|
CellReference r1 = new CellReference(getSheetName(), range.getFirstRow(), range.getFirstColumn(), true, true);
|
||||||
CellReference r2 = new CellReference(null, range.getLastRow(), range.getLastColumn(), true, true);
|
CellReference r2 = new CellReference(null, range.getLastRow(), range.getLastColumn(), true, true);
|
||||||
String fmla = r1.formatAsString() + ":" + r2.formatAsString();
|
String fmla = r1.formatAsString() + ":" + r2.formatAsString();
|
||||||
@ -3173,7 +3174,7 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
|
|
||||||
return new XSSFAutoFilter(this);
|
return new XSSFAutoFilter(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a new Table, and associates it with this Sheet
|
* Creates a new Table, and associates it with this Sheet
|
||||||
*/
|
*/
|
||||||
@ -3181,21 +3182,21 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
if(! worksheet.isSetTableParts()) {
|
if(! worksheet.isSetTableParts()) {
|
||||||
worksheet.addNewTableParts();
|
worksheet.addNewTableParts();
|
||||||
}
|
}
|
||||||
|
|
||||||
CTTableParts tblParts = worksheet.getTableParts();
|
CTTableParts tblParts = worksheet.getTableParts();
|
||||||
CTTablePart tbl = tblParts.addNewTablePart();
|
CTTablePart tbl = tblParts.addNewTablePart();
|
||||||
|
|
||||||
// Table numbers need to be unique in the file, not just
|
// Table numbers need to be unique in the file, not just
|
||||||
// unique within the sheet. Find the next one
|
// unique within the sheet. Find the next one
|
||||||
int tableNumber = getPackagePart().getPackage().getPartsByContentType(XSSFRelation.TABLE.getContentType()).size() + 1;
|
int tableNumber = getPackagePart().getPackage().getPartsByContentType(XSSFRelation.TABLE.getContentType()).size() + 1;
|
||||||
XSSFTable table = (XSSFTable)createRelationship(XSSFRelation.TABLE, XSSFFactory.getInstance(), tableNumber);
|
XSSFTable table = (XSSFTable)createRelationship(XSSFRelation.TABLE, XSSFFactory.getInstance(), tableNumber);
|
||||||
tbl.setId(table.getPackageRelationship().getId());
|
tbl.setId(table.getPackageRelationship().getId());
|
||||||
|
|
||||||
tables.put(tbl.getId(), table);
|
tables.put(tbl.getId(), table);
|
||||||
|
|
||||||
return table;
|
return table;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns any tables associated with this Sheet
|
* Returns any tables associated with this Sheet
|
||||||
*/
|
*/
|
||||||
@ -3222,8 +3223,8 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
color.setIndexed(colorIndex);
|
color.setIndexed(colorIndex);
|
||||||
pr.setTabColor(color);
|
pr.setTabColor(color);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public CellRangeAddress getRepeatingRows() {
|
public CellRangeAddress getRepeatingRows() {
|
||||||
return getRepeatingRowsOrColums(true);
|
return getRepeatingRowsOrColums(true);
|
||||||
}
|
}
|
||||||
@ -3238,24 +3239,24 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
setRepeatingRowsAndColumns(rowRangeRef, columnRangeRef);
|
setRepeatingRowsAndColumns(rowRangeRef, columnRangeRef);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
public void setRepeatingColumns(CellRangeAddress columnRangeRef) {
|
public void setRepeatingColumns(CellRangeAddress columnRangeRef) {
|
||||||
CellRangeAddress rowRangeRef = getRepeatingRows();
|
CellRangeAddress rowRangeRef = getRepeatingRows();
|
||||||
setRepeatingRowsAndColumns(rowRangeRef, columnRangeRef);
|
setRepeatingRowsAndColumns(rowRangeRef, columnRangeRef);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
private void setRepeatingRowsAndColumns(
|
private void setRepeatingRowsAndColumns(
|
||||||
CellRangeAddress rowDef, CellRangeAddress colDef) {
|
CellRangeAddress rowDef, CellRangeAddress colDef) {
|
||||||
int col1 = -1;
|
int col1 = -1;
|
||||||
int col2 = -1;
|
int col2 = -1;
|
||||||
int row1 = -1;
|
int row1 = -1;
|
||||||
int row2 = -1;
|
int row2 = -1;
|
||||||
|
|
||||||
if (rowDef != null) {
|
if (rowDef != null) {
|
||||||
row1 = rowDef.getFirstRow();
|
row1 = rowDef.getFirstRow();
|
||||||
row2 = rowDef.getLastRow();
|
row2 = rowDef.getLastRow();
|
||||||
if ((row1 == -1 && row2 != -1)
|
if ((row1 == -1 && row2 != -1)
|
||||||
|| row1 < -1 || row2 < -1 || row1 > row2) {
|
|| row1 < -1 || row2 < -1 || row1 > row2) {
|
||||||
throw new IllegalArgumentException("Invalid row range specification");
|
throw new IllegalArgumentException("Invalid row range specification");
|
||||||
}
|
}
|
||||||
@ -3263,13 +3264,13 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
if (colDef != null) {
|
if (colDef != null) {
|
||||||
col1 = colDef.getFirstColumn();
|
col1 = colDef.getFirstColumn();
|
||||||
col2 = colDef.getLastColumn();
|
col2 = colDef.getLastColumn();
|
||||||
if ((col1 == -1 && col2 != -1)
|
if ((col1 == -1 && col2 != -1)
|
||||||
|| col1 < -1 || col2 < -1 || col1 > col2) {
|
|| col1 < -1 || col2 < -1 || col1 > col2) {
|
||||||
throw new IllegalArgumentException(
|
throw new IllegalArgumentException(
|
||||||
"Invalid column range specification");
|
"Invalid column range specification");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int sheetIndex = getWorkbook().getSheetIndex(this);
|
int sheetIndex = getWorkbook().getSheetIndex(this);
|
||||||
|
|
||||||
boolean removeAll = rowDef == null && colDef == null;
|
boolean removeAll = rowDef == null && colDef == null;
|
||||||
@ -3304,16 +3305,16 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
|
|
||||||
private static String getReferenceBuiltInRecord(
|
private static String getReferenceBuiltInRecord(
|
||||||
String sheetName, int startC, int endC, int startR, int endR) {
|
String sheetName, int startC, int endC, int startR, int endR) {
|
||||||
// Excel example for built-in title:
|
// Excel example for built-in title:
|
||||||
// 'second sheet'!$E:$F,'second sheet'!$2:$3
|
// 'second sheet'!$E:$F,'second sheet'!$2:$3
|
||||||
|
|
||||||
CellReference colRef =
|
CellReference colRef =
|
||||||
new CellReference(sheetName, 0, startC, true, true);
|
new CellReference(sheetName, 0, startC, true, true);
|
||||||
CellReference colRef2 =
|
CellReference colRef2 =
|
||||||
new CellReference(sheetName, 0, endC, true, true);
|
new CellReference(sheetName, 0, endC, true, true);
|
||||||
CellReference rowRef =
|
CellReference rowRef =
|
||||||
new CellReference(sheetName, startR, 0, true, true);
|
new CellReference(sheetName, startR, 0, true, true);
|
||||||
CellReference rowRef2 =
|
CellReference rowRef2 =
|
||||||
new CellReference(sheetName, endR, 0, true, true);
|
new CellReference(sheetName, endR, 0, true, true);
|
||||||
|
|
||||||
String escapedName = SheetNameFormatter.format(sheetName);
|
String escapedName = SheetNameFormatter.format(sheetName);
|
||||||
@ -3323,15 +3324,15 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
|
|
||||||
if(startC == -1 && endC == -1) {
|
if(startC == -1 && endC == -1) {
|
||||||
} else {
|
} else {
|
||||||
c = escapedName + "!$" + colRef.getCellRefParts()[2]
|
c = escapedName + "!$" + colRef.getCellRefParts()[2]
|
||||||
+ ":$" + colRef2.getCellRefParts()[2];
|
+ ":$" + colRef2.getCellRefParts()[2];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (startR == -1 && endR == -1) {
|
if (startR == -1 && endR == -1) {
|
||||||
|
|
||||||
} else if (!rowRef.getCellRefParts()[1].equals("0")
|
} else if (!rowRef.getCellRefParts()[1].equals("0")
|
||||||
&& !rowRef2.getCellRefParts()[1].equals("0")) {
|
&& !rowRef2.getCellRefParts()[1].equals("0")) {
|
||||||
r = escapedName + "!$" + rowRef.getCellRefParts()[1]
|
r = escapedName + "!$" + rowRef.getCellRefParts()[1]
|
||||||
+ ":$" + rowRef2.getCellRefParts()[1];
|
+ ":$" + rowRef2.getCellRefParts()[1];
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3361,16 +3362,16 @@ public class XSSFSheet extends POIXMLDocumentPart implements Sheet {
|
|||||||
int maxColIndex = SpreadsheetVersion.EXCEL2007.getLastColumnIndex();
|
int maxColIndex = SpreadsheetVersion.EXCEL2007.getLastColumnIndex();
|
||||||
for (String part : parts) {
|
for (String part : parts) {
|
||||||
CellRangeAddress range = CellRangeAddress.valueOf(part);
|
CellRangeAddress range = CellRangeAddress.valueOf(part);
|
||||||
if ((range.getFirstColumn() == 0
|
if ((range.getFirstColumn() == 0
|
||||||
&& range.getLastColumn() == maxColIndex)
|
&& range.getLastColumn() == maxColIndex)
|
||||||
|| (range.getFirstColumn() == -1
|
|| (range.getFirstColumn() == -1
|
||||||
&& range.getLastColumn() == -1)) {
|
&& range.getLastColumn() == -1)) {
|
||||||
if (rows) {
|
if (rows) {
|
||||||
return range;
|
return range;
|
||||||
}
|
}
|
||||||
} else if (range.getFirstRow() == 0
|
} else if (range.getFirstRow() == 0
|
||||||
&& range.getLastRow() == maxRowIndex
|
&& range.getLastRow() == maxRowIndex
|
||||||
|| (range.getFirstRow() == -1
|
|| (range.getFirstRow() == -1
|
||||||
&& range.getLastRow() == -1)) {
|
&& range.getLastRow() == -1)) {
|
||||||
if (!rows) {
|
if (!rows) {
|
||||||
return range;
|
return range;
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
|
|
||||||
package org.apache.poi.xssf.usermodel;
|
package org.apache.poi.xssf.usermodel;
|
||||||
|
|
||||||
|
import java.io.ByteArrayOutputStream;
|
||||||
import java.io.File;
|
import java.io.File;
|
||||||
import java.io.FileOutputStream;
|
import java.io.FileOutputStream;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
@ -25,9 +26,18 @@ import java.util.zip.CRC32;
|
|||||||
|
|
||||||
import org.apache.poi.POIXMLProperties;
|
import org.apache.poi.POIXMLProperties;
|
||||||
import org.apache.poi.hssf.HSSFTestDataSamples;
|
import org.apache.poi.hssf.HSSFTestDataSamples;
|
||||||
import org.apache.poi.openxml4j.opc.*;
|
import org.apache.poi.openxml4j.opc.ContentTypes;
|
||||||
|
import org.apache.poi.openxml4j.opc.OPCPackage;
|
||||||
|
import org.apache.poi.openxml4j.opc.PackagePart;
|
||||||
|
import org.apache.poi.openxml4j.opc.PackagePartName;
|
||||||
|
import org.apache.poi.openxml4j.opc.PackagingURIHelper;
|
||||||
import org.apache.poi.openxml4j.opc.internal.PackagePropertiesPart;
|
import org.apache.poi.openxml4j.opc.internal.PackagePropertiesPart;
|
||||||
import org.apache.poi.ss.usermodel.*;
|
import org.apache.poi.ss.usermodel.BaseTestWorkbook;
|
||||||
|
import org.apache.poi.ss.usermodel.CellStyle;
|
||||||
|
import org.apache.poi.ss.usermodel.Font;
|
||||||
|
import org.apache.poi.ss.usermodel.IndexedColors;
|
||||||
|
import org.apache.poi.ss.usermodel.RichTextString;
|
||||||
|
import org.apache.poi.ss.usermodel.Sheet;
|
||||||
import org.apache.poi.util.TempFile;
|
import org.apache.poi.util.TempFile;
|
||||||
import org.apache.poi.xssf.XSSFITestDataProvider;
|
import org.apache.poi.xssf.XSSFITestDataProvider;
|
||||||
import org.apache.poi.xssf.XSSFTestDataSamples;
|
import org.apache.poi.xssf.XSSFTestDataSamples;
|
||||||
@ -111,6 +121,8 @@ public final class TestXSSFWorkbook extends BaseTestWorkbook {
|
|||||||
sheet1 = workbook.getSheetAt(0);
|
sheet1 = workbook.getSheetAt(0);
|
||||||
assertEquals(1.2, sheet1.getRow(0).getCell(0).getNumericCellValue(), 0.0001);
|
assertEquals(1.2, sheet1.getRow(0).getCell(0).getNumericCellValue(), 0.0001);
|
||||||
assertEquals("hello world", sheet1.getRow(1).getCell(0).getRichStringCellValue().getString());
|
assertEquals("hello world", sheet1.getRow(1).getCell(0).getRichStringCellValue().getString());
|
||||||
|
|
||||||
|
pkg.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testExisting() throws Exception {
|
public void testExisting() throws Exception {
|
||||||
@ -128,6 +140,7 @@ public final class TestXSSFWorkbook extends BaseTestWorkbook {
|
|||||||
assertTrue(wbPart.hasRelationships());
|
assertTrue(wbPart.hasRelationships());
|
||||||
assertEquals(6, wbPart.getRelationships().size());
|
assertEquals(6, wbPart.getRelationships().size());
|
||||||
|
|
||||||
|
pkg.close();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void testGetCellStyleAt(){
|
public void testGetCellStyleAt(){
|
||||||
@ -357,7 +370,7 @@ public final class TestXSSFWorkbook extends BaseTestWorkbook {
|
|||||||
assertEquals("Numbers", wb.getSheetName(0));
|
assertEquals("Numbers", wb.getSheetName(0));
|
||||||
assertEquals("Chart", wb.getSheetName(1));
|
assertEquals("Chart", wb.getSheetName(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Problems with the count of the number of styles
|
* Problems with the count of the number of styles
|
||||||
* coming out wrong
|
* coming out wrong
|
||||||
@ -448,4 +461,24 @@ public final class TestXSSFWorkbook extends BaseTestWorkbook {
|
|||||||
assertEquals(IndexedColors.RED.index,
|
assertEquals(IndexedColors.RED.index,
|
||||||
sh.getCTWorksheet().getSheetPr().getTabColor().getIndexed());
|
sh.getCTWorksheet().getSheetPr().getTabColor().getIndexed());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void testColumnWidthPOI52233() throws Exception {
|
||||||
|
XSSFWorkbook workbook = new XSSFWorkbook();
|
||||||
|
XSSFSheet sheet = workbook.createSheet();
|
||||||
|
XSSFRow row = sheet.createRow(0);
|
||||||
|
XSSFCell cell = row.createCell(0);
|
||||||
|
cell.setCellValue("hello world");
|
||||||
|
assertEquals("hello world", workbook.getSheetAt(0).getRow(0).getCell(0).getStringCellValue());
|
||||||
|
assertEquals(2048, workbook.getSheetAt(0).getColumnWidth(0)); // <-works
|
||||||
|
|
||||||
|
ByteArrayOutputStream stream = new ByteArrayOutputStream();
|
||||||
|
try {
|
||||||
|
workbook.write(stream);
|
||||||
|
} finally {
|
||||||
|
stream.close();
|
||||||
|
}
|
||||||
|
|
||||||
|
assertEquals("hello world", workbook.getSheetAt(0).getRow(0).getCell(0).getStringCellValue());
|
||||||
|
assertEquals(2048, workbook.getSheetAt(0).getColumnWidth(0)); // <- did throw IndexOutOfBoundsException before fixing the bug
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user