Update Ref3DPxg to support multi-sheet ranges too, for #55906
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@1613376 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
0dde805ec7
commit
8f4fac46ee
@ -17,7 +17,9 @@
|
|||||||
|
|
||||||
package org.apache.poi.ss.formula.ptg;
|
package org.apache.poi.ss.formula.ptg;
|
||||||
|
|
||||||
|
import org.apache.poi.ss.formula.SheetIdentifier;
|
||||||
import org.apache.poi.ss.formula.SheetNameFormatter;
|
import org.apache.poi.ss.formula.SheetNameFormatter;
|
||||||
|
import org.apache.poi.ss.formula.SheetRangeIdentifier;
|
||||||
import org.apache.poi.ss.util.CellReference;
|
import org.apache.poi.ss.util.CellReference;
|
||||||
import org.apache.poi.util.LittleEndianOutput;
|
import org.apache.poi.util.LittleEndianOutput;
|
||||||
|
|
||||||
@ -31,21 +33,28 @@ import org.apache.poi.util.LittleEndianOutput;
|
|||||||
*/
|
*/
|
||||||
public final class Ref3DPxg extends RefPtgBase implements Pxg {
|
public final class Ref3DPxg extends RefPtgBase implements Pxg {
|
||||||
private int externalWorkbookNumber = -1;
|
private int externalWorkbookNumber = -1;
|
||||||
private String sheetName;
|
private String firstSheetName;
|
||||||
|
private String lastSheetName;
|
||||||
|
|
||||||
public Ref3DPxg(int externalWorkbookNumber, String sheetName, String cellref) {
|
public Ref3DPxg(int externalWorkbookNumber, SheetIdentifier sheetName, String cellref) {
|
||||||
this(externalWorkbookNumber, sheetName, new CellReference(cellref));
|
this(externalWorkbookNumber, sheetName, new CellReference(cellref));
|
||||||
}
|
}
|
||||||
public Ref3DPxg(int externalWorkbookNumber, String sheetName, CellReference c) {
|
public Ref3DPxg(int externalWorkbookNumber, SheetIdentifier sheetName, CellReference c) {
|
||||||
super(c);
|
super(c);
|
||||||
this.externalWorkbookNumber = externalWorkbookNumber;
|
this.externalWorkbookNumber = externalWorkbookNumber;
|
||||||
this.sheetName = sheetName;
|
|
||||||
|
this.firstSheetName = sheetName.getSheetIdentifier().getName();
|
||||||
|
if (sheetName instanceof SheetRangeIdentifier) {
|
||||||
|
this.lastSheetName = ((SheetRangeIdentifier)sheetName).getLastSheetIdentifier().getName();
|
||||||
|
} else {
|
||||||
|
this.lastSheetName = null;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public Ref3DPxg(String sheetName, String cellref) {
|
public Ref3DPxg(SheetIdentifier sheetName, String cellref) {
|
||||||
this(sheetName, new CellReference(cellref));
|
this(sheetName, new CellReference(cellref));
|
||||||
}
|
}
|
||||||
public Ref3DPxg(String sheetName, CellReference c) {
|
public Ref3DPxg(SheetIdentifier sheetName, CellReference c) {
|
||||||
this(-1, sheetName, c);
|
this(-1, sheetName, c);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -58,7 +67,11 @@ public final class Ref3DPxg extends RefPtgBase implements Pxg {
|
|||||||
sb.append("workbook=").append(getExternalWorkbookNumber());
|
sb.append("workbook=").append(getExternalWorkbookNumber());
|
||||||
sb.append("] ");
|
sb.append("] ");
|
||||||
}
|
}
|
||||||
sb.append("sheet=").append(getSheetName());
|
sb.append("sheet=").append(firstSheetName);
|
||||||
|
if (lastSheetName != null) {
|
||||||
|
sb.append(" : ");
|
||||||
|
sb.append("sheet=").append(lastSheetName);
|
||||||
|
}
|
||||||
sb.append(" ! ");
|
sb.append(" ! ");
|
||||||
sb.append(formatReferenceAsString());
|
sb.append(formatReferenceAsString());
|
||||||
sb.append("]");
|
sb.append("]");
|
||||||
@ -68,12 +81,18 @@ public final class Ref3DPxg extends RefPtgBase implements Pxg {
|
|||||||
public int getExternalWorkbookNumber() {
|
public int getExternalWorkbookNumber() {
|
||||||
return externalWorkbookNumber;
|
return externalWorkbookNumber;
|
||||||
}
|
}
|
||||||
public String getSheetName() {
|
public String getSheetName() { // TODO Rename to getFirstSheetName
|
||||||
return sheetName;
|
return firstSheetName;
|
||||||
|
}
|
||||||
|
public String getLastSheetName() {
|
||||||
|
return lastSheetName;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void setSheetName(String sheetName) {
|
public void setSheetName(String sheetName) { // TODO Rename to setFirstSheetName
|
||||||
this.sheetName = sheetName;
|
this.firstSheetName = sheetName;
|
||||||
|
}
|
||||||
|
public void setLastSheetName(String sheetName) {
|
||||||
|
this.lastSheetName = sheetName;
|
||||||
}
|
}
|
||||||
|
|
||||||
public String format2DRefAsString() {
|
public String format2DRefAsString() {
|
||||||
@ -87,8 +106,12 @@ public final class Ref3DPxg extends RefPtgBase implements Pxg {
|
|||||||
sb.append(externalWorkbookNumber);
|
sb.append(externalWorkbookNumber);
|
||||||
sb.append(']');
|
sb.append(']');
|
||||||
}
|
}
|
||||||
if (sheetName != null) {
|
if (firstSheetName != null) {
|
||||||
SheetNameFormatter.appendFormat(sb, sheetName);
|
SheetNameFormatter.appendFormat(sb, firstSheetName);
|
||||||
|
}
|
||||||
|
if (lastSheetName != null) {
|
||||||
|
sb.append(':');
|
||||||
|
SheetNameFormatter.appendFormat(sb, lastSheetName);
|
||||||
}
|
}
|
||||||
sb.append('!');
|
sb.append('!');
|
||||||
sb.append(formatReferenceAsString());
|
sb.append(formatReferenceAsString());
|
||||||
|
@ -192,13 +192,11 @@ public final class XSSFEvaluationWorkbook implements FormulaRenderingWorkbook, E
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
public Ptg get3DReferencePtg(CellReference cell, SheetIdentifier sheet) {
|
public Ptg get3DReferencePtg(CellReference cell, SheetIdentifier sheet) {
|
||||||
String sheetName = sheet._sheetIdentifier.getName();
|
|
||||||
|
|
||||||
if (sheet._bookName != null) {
|
if (sheet._bookName != null) {
|
||||||
int bookIndex = resolveBookIndex(sheet._bookName);
|
int bookIndex = resolveBookIndex(sheet._bookName);
|
||||||
return new Ref3DPxg(bookIndex, sheetName, cell);
|
return new Ref3DPxg(bookIndex, sheet, cell);
|
||||||
} else {
|
} else {
|
||||||
return new Ref3DPxg(sheetName, cell);
|
return new Ref3DPxg(sheet, cell);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
public Ptg get3DReferencePtg(AreaReference area, SheetIdentifier sheet) {
|
public Ptg get3DReferencePtg(AreaReference area, SheetIdentifier sheet) {
|
||||||
|
@ -283,19 +283,17 @@ public final class TestXSSFFormulaParser {
|
|||||||
|
|
||||||
|
|
||||||
// Check things parse as expected:
|
// Check things parse as expected:
|
||||||
// TODO Fix it so that the Pxgs get the second sheet too!
|
|
||||||
|
|
||||||
|
|
||||||
// SUM to one cell over 3 workbooks, relative reference
|
// SUM to one cell over 3 workbooks, relative reference
|
||||||
ptgs = parse(fpb, "SUM(Sheet1:Sheet3!A1)");
|
ptgs = parse(fpb, "SUM(Sheet1:Sheet3!A1)");
|
||||||
assertEquals(2, ptgs.length);
|
assertEquals(2, ptgs.length);
|
||||||
if (wb instanceof HSSFWorkbook) {
|
if (wb instanceof HSSFWorkbook) {
|
||||||
assertEquals(Ref3DPtg.class, ptgs[0].getClass());
|
assertEquals(Ref3DPtg.class, ptgs[0].getClass());
|
||||||
assertEquals("Sheet1:Sheet3!A1", toFormulaString(ptgs[0], fpb));
|
|
||||||
} else {
|
} else {
|
||||||
assertEquals(Ref3DPxg.class, ptgs[0].getClass());
|
assertEquals(Ref3DPxg.class, ptgs[0].getClass());
|
||||||
assertEquals("Sheet1!A1", toFormulaString(ptgs[0], fpb));
|
|
||||||
}
|
}
|
||||||
|
assertEquals("Sheet1:Sheet3!A1", toFormulaString(ptgs[0], fpb));
|
||||||
assertEquals(AttrPtg.class, ptgs[1].getClass());
|
assertEquals(AttrPtg.class, ptgs[1].getClass());
|
||||||
assertEquals("SUM", toFormulaString(ptgs[1], fpb));
|
assertEquals("SUM", toFormulaString(ptgs[1], fpb));
|
||||||
|
|
||||||
@ -304,12 +302,11 @@ public final class TestXSSFFormulaParser {
|
|||||||
ptgs = parse(fpb, "MAX(Sheet1:Sheet3!A$1)");
|
ptgs = parse(fpb, "MAX(Sheet1:Sheet3!A$1)");
|
||||||
assertEquals(2, ptgs.length);
|
assertEquals(2, ptgs.length);
|
||||||
if (wb instanceof HSSFWorkbook) {
|
if (wb instanceof HSSFWorkbook) {
|
||||||
assertEquals(Ref3DPtg.class, ptgs[0].getClass());
|
assertEquals(Ref3DPtg.class, ptgs[0].getClass());
|
||||||
assertEquals("Sheet1:Sheet3!A$1", toFormulaString(ptgs[0], fpb));
|
|
||||||
} else {
|
} else {
|
||||||
assertEquals(Ref3DPxg.class, ptgs[0].getClass());
|
assertEquals(Ref3DPxg.class, ptgs[0].getClass());
|
||||||
assertEquals("Sheet1!A$1", toFormulaString(ptgs[0], fpb));
|
|
||||||
}
|
}
|
||||||
|
assertEquals("Sheet1:Sheet3!A$1", toFormulaString(ptgs[0], fpb));
|
||||||
assertEquals(FuncVarPtg.class, ptgs[1].getClass());
|
assertEquals(FuncVarPtg.class, ptgs[1].getClass());
|
||||||
assertEquals("MAX", toFormulaString(ptgs[1], fpb));
|
assertEquals("MAX", toFormulaString(ptgs[1], fpb));
|
||||||
|
|
||||||
@ -318,12 +315,11 @@ public final class TestXSSFFormulaParser {
|
|||||||
ptgs = parse(fpb, "MIN(Sheet1:Sheet3!$A$1)");
|
ptgs = parse(fpb, "MIN(Sheet1:Sheet3!$A$1)");
|
||||||
assertEquals(2, ptgs.length);
|
assertEquals(2, ptgs.length);
|
||||||
if (wb instanceof HSSFWorkbook) {
|
if (wb instanceof HSSFWorkbook) {
|
||||||
assertEquals(Ref3DPtg.class, ptgs[0].getClass());
|
assertEquals(Ref3DPtg.class, ptgs[0].getClass());
|
||||||
assertEquals("Sheet1:Sheet3!$A$1", toFormulaString(ptgs[0], fpb));
|
|
||||||
} else {
|
} else {
|
||||||
assertEquals(Ref3DPxg.class, ptgs[0].getClass());
|
assertEquals(Ref3DPxg.class, ptgs[0].getClass());
|
||||||
assertEquals("Sheet1!$A$1", toFormulaString(ptgs[0], fpb));
|
|
||||||
}
|
}
|
||||||
|
assertEquals("Sheet1:Sheet3!$A$1", toFormulaString(ptgs[0], fpb));
|
||||||
assertEquals(FuncVarPtg.class, ptgs[1].getClass());
|
assertEquals(FuncVarPtg.class, ptgs[1].getClass());
|
||||||
assertEquals("MIN", toFormulaString(ptgs[1], fpb));
|
assertEquals("MIN", toFormulaString(ptgs[1], fpb));
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user