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:
Nick Burch 2014-07-25 10:22:21 +00:00
parent 25f32c90ae
commit 846a1f84a2
3 changed files with 44 additions and 27 deletions

View File

@ -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());

View File

@ -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) {

View File

@ -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));