fixed FormulaParser to correctly process defined names with underscore, see bugzilla 49725
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@984823 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
988a5583dd
commit
8f4aff0e1a
@ -34,6 +34,7 @@
|
|||||||
|
|
||||||
<changes>
|
<changes>
|
||||||
<release version="3.7-beta3" date="2010-??-??">
|
<release version="3.7-beta3" date="2010-??-??">
|
||||||
|
<action dev="POI-DEVELOPERS" type="fix">49725 - fixed FormulaParser to correctly process defined names with underscore</action>
|
||||||
<action dev="POI-DEVELOPERS" type="add">48526 - added implementation for RANDBETWEEN()</action>
|
<action dev="POI-DEVELOPERS" type="add">48526 - added implementation for RANDBETWEEN()</action>
|
||||||
<action dev="POI-DEVELOPERS" type="fix">49725 - avoid exception in OperandResolver.parseDouble when input is minus ("-")</action>
|
<action dev="POI-DEVELOPERS" type="fix">49725 - avoid exception in OperandResolver.parseDouble when input is minus ("-")</action>
|
||||||
<action dev="POI-DEVELOPERS" type="fix">49723 - fixed OperandResolver to correctly handle inputs with leading decimal place</action>
|
<action dev="POI-DEVELOPERS" type="fix">49723 - fixed OperandResolver to correctly handle inputs with leading decimal place</action>
|
||||||
|
@ -665,7 +665,7 @@ public final class FormulaParser {
|
|||||||
hasDigits = true;
|
hasDigits = true;
|
||||||
} else if (Character.isLetter(ch)) {
|
} else if (Character.isLetter(ch)) {
|
||||||
hasLetters = true;
|
hasLetters = true;
|
||||||
} else if (ch =='$') {
|
} else if (ch =='$' || ch =='_') {
|
||||||
//
|
//
|
||||||
} else {
|
} else {
|
||||||
break;
|
break;
|
||||||
|
@ -271,6 +271,50 @@ public final class TestFormulaParser extends TestCase {
|
|||||||
cell.setCellFormula("Cash_Flow!A1");
|
cell.setCellFormula("Cash_Flow!A1");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** bug 49725, defined names with underscore */
|
||||||
|
public void testNamesWithUnderscore() {
|
||||||
|
HSSFWorkbook wb = new HSSFWorkbook(); //or new XSSFWorkbook();
|
||||||
|
HSSFSheet sheet = wb.createSheet("NamesWithUnderscore");
|
||||||
|
|
||||||
|
HSSFName nm;
|
||||||
|
|
||||||
|
nm = wb.createName();
|
||||||
|
nm.setNameName("DA6_LEO_WBS_Number");
|
||||||
|
nm.setRefersToFormula("33");
|
||||||
|
|
||||||
|
nm = wb.createName();
|
||||||
|
nm.setNameName("DA6_LEO_WBS_Name");
|
||||||
|
nm.setRefersToFormula("33");
|
||||||
|
|
||||||
|
nm = wb.createName();
|
||||||
|
nm.setNameName("A1_");
|
||||||
|
nm.setRefersToFormula("22");
|
||||||
|
|
||||||
|
nm = wb.createName();
|
||||||
|
nm.setNameName("_A1");
|
||||||
|
nm.setRefersToFormula("11");
|
||||||
|
|
||||||
|
nm = wb.createName();
|
||||||
|
nm.setNameName("A_1");
|
||||||
|
nm.setRefersToFormula("44");
|
||||||
|
|
||||||
|
nm = wb.createName();
|
||||||
|
nm.setNameName("A_1_");
|
||||||
|
nm.setRefersToFormula("44");
|
||||||
|
|
||||||
|
HSSFRow row = sheet.createRow(0);
|
||||||
|
HSSFCell cell = row.createCell(0);
|
||||||
|
|
||||||
|
cell.setCellFormula("DA6_LEO_WBS_Number*2");
|
||||||
|
assertEquals("DA6_LEO_WBS_Number*2", cell.getCellFormula());
|
||||||
|
|
||||||
|
cell.setCellFormula("(A1_*_A1+A_1)/A_1_");
|
||||||
|
assertEquals("(A1_*_A1+A_1)/A_1_", cell.getCellFormula());
|
||||||
|
|
||||||
|
cell.setCellFormula("INDEX(DA6_LEO_WBS_Name,MATCH($A3,DA6_LEO_WBS_Number,0))");
|
||||||
|
assertEquals("INDEX(DA6_LEO_WBS_Name,MATCH($A3,DA6_LEO_WBS_Number,0))", cell.getCellFormula());
|
||||||
|
}
|
||||||
|
|
||||||
// bug 38396 : Formula with exponential numbers not parsed correctly.
|
// bug 38396 : Formula with exponential numbers not parsed correctly.
|
||||||
public void testExponentialParsing() {
|
public void testExponentialParsing() {
|
||||||
confirmTokenClasses("1.3E21/2", NumberPtg.class, IntPtg.class, DividePtg.class);
|
confirmTokenClasses("1.3E21/2", NumberPtg.class, IntPtg.class, DividePtg.class);
|
||||||
|
Loading…
Reference in New Issue
Block a user