|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |
java.lang.Object org.apache.poi.ss.formula.ptg.Ptg
public abstract class Ptg
Ptg represents a syntactic token in a formula. 'PTG' is an acronym for 'parse thing'. Originally, the name referred to the single byte identifier at the start of the token, but in POI, Ptg encapsulates the whole formula token (initial byte + value data).
Ptgs are logically arranged in a tree representing the structure of the parsed formula. However, in BIFF files Ptgs are written/read in Reverse-Polish Notation order. The RPN ordering also simplifies formula evaluation logic, so POI mostly accesses Ptgs in the same way.
Field Summary | |
---|---|
static byte |
CLASS_ARRAY
|
static byte |
CLASS_REF
|
static byte |
CLASS_VALUE
|
static Ptg[] |
EMPTY_PTG_ARRAY
|
Constructor Summary | |
---|---|
Ptg()
|
Method Summary | |
---|---|
static Ptg |
createPtg(LittleEndianInput in)
|
static boolean |
doesFormulaReferToDeletedCell(Ptg[] ptgs)
|
abstract byte |
getDefaultOperandClass()
|
static int |
getEncodedSize(Ptg[] ptgs)
This method will return the same result as getEncodedSizeWithoutArrayData(Ptg[])
if there are no array tokens present. |
static int |
getEncodedSizeWithoutArrayData(Ptg[] ptgs)
Used to calculate value that should be encoded at the start of the encoded Ptg token array; |
byte |
getPtgClass()
|
char |
getRVAType()
Debug / diagnostic method to get this token's 'operand class' type. |
abstract int |
getSize()
|
abstract boolean |
isBaseToken()
|
static Ptg[] |
readTokens(int size,
LittleEndianInput in)
Reads size bytes of the input stream, to create an array of Ptgs. |
static int |
serializePtgs(Ptg[] ptgs,
byte[] array,
int offset)
Writes the ptgs to the data buffer, starting at the specified offset. |
void |
setClass(byte thePtgClass)
|
abstract java.lang.String |
toFormulaString()
return a string representation of this token alone |
java.lang.String |
toString()
Overridden toString method to ensure object hash is not printed. |
abstract void |
write(LittleEndianOutput out)
|
Methods inherited from class java.lang.Object |
---|
clone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait |
Field Detail |
---|
public static final Ptg[] EMPTY_PTG_ARRAY
public static final byte CLASS_REF
public static final byte CLASS_VALUE
public static final byte CLASS_ARRAY
Constructor Detail |
---|
public Ptg()
Method Detail |
---|
public static Ptg[] readTokens(int size, LittleEndianInput in)
public static Ptg createPtg(LittleEndianInput in)
public static int getEncodedSize(Ptg[] ptgs)
getEncodedSizeWithoutArrayData(Ptg[])
if there are no array tokens present.
public static int getEncodedSizeWithoutArrayData(Ptg[] ptgs)
public static int serializePtgs(Ptg[] ptgs, byte[] array, int offset)
public abstract int getSize()
public abstract void write(LittleEndianOutput out)
public abstract java.lang.String toFormulaString()
public java.lang.String toString()
toString
in class java.lang.Object
public final void setClass(byte thePtgClass)
public final byte getPtgClass()
public final char getRVAType()
public abstract byte getDefaultOperandClass()
public abstract boolean isBaseToken()
false
if this token is classified as 'reference', 'value', or 'array'public static boolean doesFormulaReferToDeletedCell(Ptg[] ptgs)
|
|||||||||
PREV CLASS NEXT CLASS | FRAMES NO FRAMES | ||||||||
SUMMARY: NESTED | FIELD | CONSTR | METHOD | DETAIL: FIELD | CONSTR | METHOD |