aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--poi-ooxml/src/main/java/org/apache/poi/xssf/usermodel/XSSFCell.java5
-rw-r--r--poi-ooxml/src/test/java/org/apache/poi/xssf/usermodel/TestXSSFFormulaParser.java45
-rw-r--r--poi/src/main/java/org/apache/poi/ss/formula/FormulaParser.java13
-rw-r--r--poi/src/main/java/org/apache/poi/ss/formula/ptg/ExternSheetNameResolver.java11
-rw-r--r--poi/src/test/java/org/apache/poi/hssf/model/TestFormulaParser.java8
-rw-r--r--poi/src/test/java/org/apache/poi/ss/usermodel/BaseTestWorkbook.java4
6 files changed, 12 insertions, 74 deletions
diff --git a/poi-ooxml/src/main/java/org/apache/poi/xssf/usermodel/XSSFCell.java b/poi-ooxml/src/main/java/org/apache/poi/xssf/usermodel/XSSFCell.java
index fcdd530be8..a1d33c9600 100644
--- a/poi-ooxml/src/main/java/org/apache/poi/xssf/usermodel/XSSFCell.java
+++ b/poi-ooxml/src/main/java/org/apache/poi/xssf/usermodel/XSSFCell.java
@@ -474,10 +474,7 @@ public final class XSSFCell extends CellBase {
if (wb.getCellFormulaValidation()) {
XSSFEvaluationWorkbook fpb = XSSFEvaluationWorkbook.create(wb);
//validate through the FormulaParser
- Ptg[] ptgs = FormulaParser.parse(formula, fpb, formulaType, wb.getSheetIndex(getSheet()), getRowIndex());
- // Make its format consistent with Excel.
- // eg: "SUM('Sheet1:Sheet2'!A1:B1)" will be trans to "SUM(Sheet1:Sheet2!A1:B1)"
- formula = FormulaRenderer.toFormulaString(fpb, ptgs);
+ FormulaParser.parse(formula, fpb, formulaType, wb.getSheetIndex(getSheet()), getRowIndex());
}
CTCellFormula f;
diff --git a/poi-ooxml/src/test/java/org/apache/poi/xssf/usermodel/TestXSSFFormulaParser.java b/poi-ooxml/src/test/java/org/apache/poi/xssf/usermodel/TestXSSFFormulaParser.java
index 120184b681..7b56cf8965 100644
--- a/poi-ooxml/src/test/java/org/apache/poi/xssf/usermodel/TestXSSFFormulaParser.java
+++ b/poi-ooxml/src/test/java/org/apache/poi/xssf/usermodel/TestXSSFFormulaParser.java
@@ -723,49 +723,4 @@ public final class TestXSSFFormulaParser {
wb.close();
}
-
- @Test
- void testQuotedSheetNamesReference() {
- // quoted sheet names bug fix (https://github.com/apache/poi/pull/267)
- Workbook[] wbs = new Workbook[]{new HSSFWorkbook(), new XSSFWorkbook()};
- for (Workbook wb : wbs) {
- Sheet sheet1 = wb.createSheet("Sheet1");
- Sheet sheet2 = wb.createSheet("Sheet2");
- Sheet sheet3 = wb.createSheet("Sheet 3");
-
- Row tempRow = sheet1.createRow(0);
- tempRow.createCell(0).setCellValue(1);
- tempRow.createCell(1).setCellValue(2);
-
- tempRow = sheet2.createRow(0);
- tempRow.createCell(0).setCellValue(3);
- tempRow.createCell(1).setCellValue(4);
-
- tempRow = sheet3.createRow(0);
- tempRow.createCell(0).setCellValue(5);
- tempRow.createCell(1).setCellValue(6);
-
- Cell cell = tempRow.createCell(2);
-
- // unquoted sheet names
- String formula = "SUM(Sheet1:Sheet2!A1:B1)";
- cell.setCellFormula(formula);
- String cellFormula = cell.getCellFormula();
- assertEquals(formula, cellFormula);
-
- // quoted sheet names with no space
- cell = tempRow.createCell(3);
- formula = "SUM('Sheet1:Sheet2'!A1:B1)";
- cell.setCellFormula(formula);
- cellFormula = cell.getCellFormula();
- assertEquals("SUM(Sheet1:Sheet2!A1:B1)", cellFormula);
-
- // quoted sheet names with space
- cell = tempRow.createCell(4);
- formula = "SUM('Sheet1:Sheet 3'!A1:B1)";
- cell.setCellFormula(formula);
- cellFormula = cell.getCellFormula();
- assertEquals(formula, cellFormula);
- }
- }
}
diff --git a/poi/src/main/java/org/apache/poi/ss/formula/FormulaParser.java b/poi/src/main/java/org/apache/poi/ss/formula/FormulaParser.java
index 8be98c5656..94c88219e9 100644
--- a/poi/src/main/java/org/apache/poi/ss/formula/FormulaParser.java
+++ b/poi/src/main/java/org/apache/poi/ss/formula/FormulaParser.java
@@ -1171,11 +1171,10 @@ public final class FormulaParser {
while(!done) {
sb.appendCodePoint(look);
GetChar();
- switch (look){
- case '\'' :
- GetChar();
- case ':' :
- done = true;
+ if(look == '\'')
+ {
+ Match('\'');
+ done = look != '\'';
}
}
@@ -1201,9 +1200,6 @@ public final class FormulaParser {
sb.appendCodePoint(look);
GetChar();
}
- if (look == '\'') {
- GetChar();
- }
NameIdentifier iden = new NameIdentifier(sb.toString(), false);
SkipWhite();
if (look == '!') {
@@ -1253,7 +1249,6 @@ public final class FormulaParser {
switch(ch) {
case '.': // dot is OK
case '_': // underscore is OK
- case ' ': // space is OK
return true;
}
return false;
diff --git a/poi/src/main/java/org/apache/poi/ss/formula/ptg/ExternSheetNameResolver.java b/poi/src/main/java/org/apache/poi/ss/formula/ptg/ExternSheetNameResolver.java
index 2a90ae6f44..3a35909cc2 100644
--- a/poi/src/main/java/org/apache/poi/ss/formula/ptg/ExternSheetNameResolver.java
+++ b/poi/src/main/java/org/apache/poi/ss/formula/ptg/ExternSheetNameResolver.java
@@ -44,16 +44,7 @@ final class ExternSheetNameResolver {
ExternalSheetRange r = (ExternalSheetRange)externalSheet;
if (! r.getFirstSheetName().equals(r.getLastSheetName())) {
sb.append(':');
- // quote should appear at the beginning and end.
- StringBuilder innerBuilder = new StringBuilder();
- SheetNameFormatter.appendFormat(innerBuilder, r.getLastSheetName());
- char quote = '\'';
- if (innerBuilder.charAt(0) == quote){
- sb.insert(0 , quote);
- sb.append(innerBuilder.substring(1));
- } else {
- sb.append(innerBuilder);
- }
+ SheetNameFormatter.appendFormat(sb, r.getLastSheetName());
}
}
} else {
diff --git a/poi/src/test/java/org/apache/poi/hssf/model/TestFormulaParser.java b/poi/src/test/java/org/apache/poi/hssf/model/TestFormulaParser.java
index 0768cd713e..6c55d18224 100644
--- a/poi/src/test/java/org/apache/poi/hssf/model/TestFormulaParser.java
+++ b/poi/src/test/java/org/apache/poi/hssf/model/TestFormulaParser.java
@@ -535,9 +535,9 @@ final class TestFormulaParser {
assertEquals("'Test Sheet'!A1", formula);
// Now both
- cell.setCellFormula("'Cash_Flow:Test Sheet'!A1");
+ cell.setCellFormula("Cash_Flow:'Test Sheet'!A1");
formula = cell.getCellFormula();
- assertEquals("'Cash_Flow:Test Sheet'!A1", formula);
+ assertEquals("Cash_Flow:'Test Sheet'!A1", formula);
// References to a range (area) of cells:
@@ -553,9 +553,9 @@ final class TestFormulaParser {
assertEquals("'Test Sheet'!A1:B2", formula);
// Now both
- cell.setCellFormula("'Cash_Flow:Test Sheet'!A1:B2");
+ cell.setCellFormula("Cash_Flow:'Test Sheet'!A1:B2");
formula = cell.getCellFormula();
- assertEquals("'Cash_Flow:Test Sheet'!A1:B2", formula);
+ assertEquals("Cash_Flow:'Test Sheet'!A1:B2", formula);
wb.close();
}
diff --git a/poi/src/test/java/org/apache/poi/ss/usermodel/BaseTestWorkbook.java b/poi/src/test/java/org/apache/poi/ss/usermodel/BaseTestWorkbook.java
index 1c952d2a60..eba86eadf3 100644
--- a/poi/src/test/java/org/apache/poi/ss/usermodel/BaseTestWorkbook.java
+++ b/poi/src/test/java/org/apache/poi/ss/usermodel/BaseTestWorkbook.java
@@ -499,11 +499,11 @@ public abstract class BaseTestWorkbook {
/**
- * Test to validate that replacement for removed setRepeatingRowsAnsColumns() methods
+ * Test to validate that replacement for removed setRepeatingRowsAndColumns() methods
* is still working correctly
*/
@Test
- void setRepeatingRowsAnsColumns() throws IOException {
+ void setRepeatingRowsAndColumns() throws IOException {
try (Workbook wb = _testDataProvider.createWorkbook()) {
CellRangeAddress cra = new CellRangeAddress(0, 3, 0, 0);
String expRows = "1:4", expCols = "A:A";