mirror of https://github.com/apache/poi.git
reverted changes accidentally submitted with r692538
git-svn-id: https://svn.apache.org/repos/asf/poi/trunk@692541 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
a175eadfd2
commit
ff3dbad047
|
@ -90,19 +90,9 @@ public final class Index implements Function {
|
|||
}
|
||||
}
|
||||
|
||||
private static ValueEval getValueFromArea(AreaEval ae, int pRowIx, int pColumnIx) throws EvaluationException {
|
||||
private static ValueEval getValueFromArea(AreaEval ae, int rowIx, int columnIx) throws EvaluationException {
|
||||
int width = ae.getWidth();
|
||||
int height = ae.getHeight();
|
||||
int rowIx;
|
||||
int columnIx;
|
||||
if (ae.isRow() && pColumnIx == 0 && pRowIx > 0) {
|
||||
// TODO - explore all these special cases
|
||||
rowIx = 0;
|
||||
columnIx = pRowIx;
|
||||
} else {
|
||||
rowIx = pRowIx;
|
||||
columnIx = pColumnIx;
|
||||
}
|
||||
|
||||
// Slightly irregular logic for bounds checking errors
|
||||
if (rowIx >= height || columnIx >= width) {
|
||||
|
|
|
@ -17,7 +17,6 @@
|
|||
|
||||
package org.apache.poi.hssf.record.formula.functions;
|
||||
|
||||
import org.apache.poi.hssf.record.NumberRecord;
|
||||
import org.apache.poi.hssf.record.formula.eval.AreaEval;
|
||||
import org.apache.poi.hssf.record.formula.eval.BlankEval;
|
||||
import org.apache.poi.hssf.record.formula.eval.BoolEval;
|
||||
|
@ -588,9 +587,7 @@ final class LookupUtils {
|
|||
|
||||
if (lookupValue instanceof BlankEval) {
|
||||
// blank eval can never be found in a lookup array
|
||||
//throw new EvaluationException(ErrorEval.NA);
|
||||
// TODO - investigate this
|
||||
return new NumberLookupComparer(NumberEval.ZERO);
|
||||
throw new EvaluationException(ErrorEval.NA);
|
||||
}
|
||||
if (lookupValue instanceof StringEval) {
|
||||
return new StringLookupComparer((StringEval) lookupValue);
|
||||
|
|
|
@ -60,16 +60,7 @@ public final class Vlookup implements Function {
|
|||
AreaEval tableArray = LookupUtils.resolveTableArrayArg(args[1]);
|
||||
boolean isRangeLookup = LookupUtils.resolveRangeLookupArg(arg3, srcCellRow, srcCellCol);
|
||||
int rowIndex = LookupUtils.lookupIndexOfValue(lookupValue, LookupUtils.createColumnVector(tableArray, 0), isRangeLookup);
|
||||
ValueEval veColIndex;
|
||||
try {
|
||||
veColIndex = OperandResolver.getSingleValue(args[2], srcCellRow, srcCellCol);
|
||||
} catch (EvaluationException e) {
|
||||
// weird translation of errors for the third arg - needs investigation
|
||||
if (e.getErrorEval() == ErrorEval.NA) {
|
||||
return ErrorEval.REF_INVALID;
|
||||
}
|
||||
throw e;
|
||||
}
|
||||
ValueEval veColIndex = OperandResolver.getSingleValue(args[2], srcCellRow, srcCellCol);
|
||||
int colIndex = LookupUtils.resolveRowOrColIndexArg(veColIndex);
|
||||
ValueVector resultCol = createResultColumnVector(tableArray, colIndex);
|
||||
return resultCol.getItem(rowIndex);
|
||||
|
|
Loading…
Reference in New Issue