Package org.apache.poi.ss.formula
Class OperationEvaluationContext
- java.lang.Object
- 
- org.apache.poi.ss.formula.OperationEvaluationContext
 
- 
 public final class OperationEvaluationContext extends Object Contains all the contextual information required to evaluate an operation within a formulaFor POI internal use only 
- 
- 
Field SummaryFields Modifier and Type Field Description static FreeRefFunctionUDF
 - 
Constructor SummaryConstructors Constructor Description OperationEvaluationContext(WorkbookEvaluator bookEvaluator, EvaluationWorkbook workbook, int sheetIndex, int srcRowNum, int srcColNum, org.apache.poi.ss.formula.EvaluationTracker tracker, boolean isSingleValue, DependencyTracker dependencyTracker, Object ref, int[] offset)
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description static CellReferenceapplyR1C1Reference(CellReference anchorReference, String relativeReference)voidclearFunctionStack()Clear function scope stack.voidclearOffsetRefPrecedent()voidcreateOffsetRefPrecedent(ValueEval precedent)voidenterFunction(int funcId)Call when entering a function, used to examine current scope is in an aggregate function or not.FreeRefFunctionfindUserDefinedFunction(String functionName)ValueEvalgetArea3DEval(Area3DPtg aptg)ValueEvalgetArea3DEval(Area3DPxg aptg)ValueEvalgetAreaEval(int firstRowIndex, int firstColumnIndex, int lastRowIndex, int lastColumnIndex, boolean row1Rel, boolean col1Rel, boolean row2Rel, boolean col2Rel)ValueEvalgetAreaValueEval(int firstRowIndex, int firstColumnIndex, int lastRowIndex, int lastColumnIndex, Object[][] tokens)intgetColumnIndex()static OperationEvaluationContextgetContext()ObjectgetDependent()ValueEvalgetDynamicReference(String workbookName, String sheetName, String refStrPart1, String refStrPart2, boolean isA1Style)Resolves a cell or area reference dynamically.EvaluationNamegetName(String name, int contextSheetIndex)ValueEvalgetNameXEval(NameXPtg nameXPtg)ValueEvalgetNameXEval(NameXPxg nameXPxg)intgetPtgIndex()ValueEvalgetRef3DEval(Ref3DPtg rptg)ValueEvalgetRef3DEval(Ref3DPxg rptg)ValueEvalgetRefEval(int rowIndex, int columnIndex, boolean rowRel, boolean colRel)SheetRangeEvaluatorgetRefEvaluatorForCurrentSheet()intgetRowIndex()intgetSheetIndex()EvaluationWorkbookgetWorkbook()WorkbookEvaluatorgetWorkbookEvaluator()booleanisArraymode()booleanisArrayValue()Returns current scope is need an array value.booleanisEvalNameFormula()Returns whether evaluating the DefinedName formula.booleanisSingleValue()default truevoidleaveFunction()Call when leaving a function, used for examine current scope is in an aggregate function or not.voidsetArrayMode(boolean value)static voidsetContext(OperationEvaluationContext value)voidsetEvalNameFormula(boolean evalNameFormula)Sets to indicate evaluating the DefinedName formula(evaluation result might be different from that of a cell formula) Default: falsevoidsetPtgIndex(int index)
 
- 
- 
- 
Field Detail- 
UDFpublic static final FreeRefFunction UDF 
 
- 
 - 
Constructor Detail- 
OperationEvaluationContextpublic OperationEvaluationContext(WorkbookEvaluator bookEvaluator, EvaluationWorkbook workbook, int sheetIndex, int srcRowNum, int srcColNum, org.apache.poi.ss.formula.EvaluationTracker tracker, boolean isSingleValue, DependencyTracker dependencyTracker, Object ref, int[] offset) 
 
- 
 - 
Method Detail- 
enterFunctionpublic void enterFunction(int funcId) Call when entering a function, used to examine current scope is in an aggregate function or not.- Parameters:
- funcId- the function id
- Since:
- 5.8.0
 
 - 
leaveFunctionpublic void leaveFunction() Call when leaving a function, used for examine current scope is in an aggregate function or not.- Since:
- 5.8.0
 
 - 
isArrayValuepublic boolean isArrayValue() Returns current scope is need an array value.- Since:
- 5.8.0
 
 - 
clearFunctionStackpublic void clearFunctionStack() Clear function scope stack.- Since:
- 5.8.0
 
 - 
isArraymodepublic boolean isArraymode() 
 - 
setArrayModepublic void setArrayMode(boolean value) 
 - 
getWorkbookpublic EvaluationWorkbook getWorkbook() 
 - 
getRowIndexpublic int getRowIndex() 
 - 
getColumnIndexpublic int getColumnIndex() 
 - 
getRefEvaluatorForCurrentSheetpublic SheetRangeEvaluator getRefEvaluatorForCurrentSheet() 
 - 
getDynamicReferencepublic ValueEval getDynamicReference(String workbookName, String sheetName, String refStrPart1, String refStrPart2, boolean isA1Style) Resolves a cell or area reference dynamically.- Parameters:
- workbookName- the name of the workbook containing the reference. If- nullthe current workbook is assumed. Note - to evaluate formulas which use multiple workbooks, a- CollaboratingWorkbooksEnvironmentmust be set up.
- sheetName- the name of the sheet containing the reference. May be- null(when- workbookNameis also null) in which case the current workbook and sheet is assumed.
- refStrPart1- the single cell reference or first part of the area reference. Must not be- null.
- refStrPart2- the second part of the area reference. For single cell references this parameter must be- null
- isA1Style- specifies the format for- refStrPart1and- refStrPart2. Pass- truefor 'A1' style and- falsefor 'R1C1' style.
- Returns:
- a RefEvalorAreaEval
- Throws:
- IllegalStateException- If invalid parameters are provided
 
 - 
clearOffsetRefPrecedentpublic void clearOffsetRefPrecedent() 
 - 
createOffsetRefPrecedentpublic void createOffsetRefPrecedent(ValueEval precedent) 
 - 
findUserDefinedFunctionpublic FreeRefFunction findUserDefinedFunction(String functionName) 
 - 
getRefEvalpublic ValueEval getRefEval(int rowIndex, int columnIndex, boolean rowRel, boolean colRel) 
 - 
getAreaEvalpublic ValueEval getAreaEval(int firstRowIndex, int firstColumnIndex, int lastRowIndex, int lastColumnIndex, boolean row1Rel, boolean col1Rel, boolean row2Rel, boolean col2Rel) 
 - 
getWorkbookEvaluatorpublic WorkbookEvaluator getWorkbookEvaluator() 
 - 
getAreaValueEvalpublic ValueEval getAreaValueEval(int firstRowIndex, int firstColumnIndex, int lastRowIndex, int lastColumnIndex, Object[][] tokens) 
 - 
getSheetIndexpublic int getSheetIndex() 
 - 
isSingleValuepublic boolean isSingleValue() default true- Returns:
- flag indicating whether evaluation should "unwrap" the result to a single value based on the context row/column
 
 - 
applyR1C1Referencepublic static CellReference applyR1C1Reference(CellReference anchorReference, String relativeReference) 
 - 
getPtgIndexpublic int getPtgIndex() 
 - 
setPtgIndexpublic void setPtgIndex(int index) 
 - 
getNamepublic EvaluationName getName(String name, int contextSheetIndex) 
 - 
getDependentpublic Object getDependent() 
 - 
setEvalNameFormulapublic void setEvalNameFormula(boolean evalNameFormula) Sets to indicate evaluating the DefinedName formula(evaluation result might be different from that of a cell formula) Default: false- Parameters:
- evalNameFormula-
- Since:
- 5.7.0
 
 - 
isEvalNameFormulapublic boolean isEvalNameFormula() Returns whether evaluating the DefinedName formula.- Returns:
- Since:
- 5.7.0
 
 - 
setContextpublic static void setContext(OperationEvaluationContext value) 
 - 
getContextpublic static OperationEvaluationContext getContext() 
 
- 
 
-