T - the type of the value to extract fromE - the type of value that will be extractedpublic class UniversalExtractor<T,E> extends AbstractExtractor<T,E> implements ValueExtractor<T,E>, ExternalizableLite, PortableObject
 Either a property or method based extractor based on parameters passed to
 constructor UniversalExtractor(String, Object[], int).
 Generally, the name value passed to the UniversalExtractor constructor
 represents a property unless sName value ends in METHOD_SUFFIX,
 "()",
 then this instance is a reflection based method extractor.
 Special cases are described in the constructor documentation.
 
 AbstractExtractor.equals(Object) and AbstractExtractor.hashCode()
 describe how this Extractor can be equivalent to other ValueExtractor
 implementations.
ChainedExtractorExternalizableHelper.DecoratedMultiBufferReadBuffer, ExternalizableHelper.DefaultObjectStreamFactory, ExternalizableHelper.FormatAwareCompressor, ExternalizableHelper.IntDecoratedObject, ExternalizableHelper.Shielded, ExternalizableHelper.ShieldedDataOutputStream, ExternalizableHelper.ShieldedInputStream, ExternalizableHelper.ShieldedObjectOutputStream, ExternalizableHelper.ShieldedOutputStream, ExternalizableHelper.SimpleXmlBeanClassCache, ExternalizableHelper.Stats, ExternalizableHelper.XmlBeanClassCacheBase.LoggingWriter, Base.StackFrame| Modifier and Type | Field and Description | 
|---|---|
static String[] | 
BEAN_ACCESSOR_PREFIXES
JavaBean accessor prefixes. 
 | 
protected Object[] | 
m_aoParam
The parameter array. 
 | 
protected String | 
m_sName
A method or property name. 
 | 
protected String | 
m_sNameCanon
Canonical name for this extractor. 
 | 
static String | 
METHOD_SUFFIX
If  
m_sName ends with this suffix, it represents a method name. | 
KEY, m_nTarget, VALUECHUNK_SIZE, CHUNK_THRESHOLD, CONVERTER_FROM_BINARY, CONVERTER_STRIP_INTDECO, CONVERTER_TO_BINARY, DECO_APP_1, DECO_APP_2, DECO_APP_3, DECO_CUSTOM, DECO_EXPIRY, DECO_ID_MAX, DECO_ID_MIN, DECO_JCACHE, DECO_JCACHE_SYNTHETIC, DECO_MEMCACHED, DECO_PUSHREP, DECO_QUEUE_METADATA, DECO_RSVD_1, DECO_RSVD_2, DECO_STORE, DECO_TOPLINK, DECO_TX, DECO_VALUE, DECO_WLS, EMPTY_BINARY_ARRAY, FMT_B_ARRAY, FMT_BIN_DECO, FMT_BIN_EXT_DECO, FMT_BINARY, FMT_BOOLEAN, FMT_BYTE, FMT_DECIMAL, FMT_DOUBLE, FMT_EXT, FMT_FLOAT, FMT_IDO, FMT_INT, FMT_INTEGER, FMT_LONG, FMT_NONE, FMT_NULL, FMT_OBJ_EXT, FMT_OBJ_SER, FMT_OPT, FMT_OPT_DOUBLE, FMT_OPT_INT, FMT_OPT_LONG, FMT_SHORT, FMT_STRING, FMT_UNKNOWN, FMT_XML_BEAN, FMT_XML_SER, FORCE_RESOLVING_STREAMS, MAX_DECO_HEADER_BYTES, PROPERTY_CONFIG, s_streamfactory, s_tloInEHDeserialize, TRINT_DOMAIN_SPAN, TRINT_MAX_VALUE, TRINT_MAX_VARIANCE, USE_POF_STREAMS, USE_XMLBEAN_CLASS_CACHE, XMLBEAN_CLASS_CACHE| Constructor and Description | 
|---|
UniversalExtractor()
Default constructor (necessary for the ExternalizableLite interface). 
 | 
UniversalExtractor(String sName)
Construct a UniversalExtractor based on syntax of  
sName. | 
UniversalExtractor(String sName,
                  Object[] aoParam)
Construct a UniversalExtractor based on a name and optional
 parameters. 
 | 
UniversalExtractor(String sName,
                  Object[] aoParam,
                  int nTarget)
Construct a UniversalExtractor based on a name, optional
 parameters and the entry extraction target. 
 | 
| Modifier and Type | Method and Description | 
|---|---|
static <T,E> ValueExtractor<T,E> | 
createExtractor(String sNames)
Return a ValueExtractor representing dot separated list of property
 and/or method names. 
 | 
boolean | 
equals(Object o)
Compare the  
UniversalExtractor with another object to determine equality. | 
E | 
extract(T oTarget)
Extract from target using reflection or map access. 
 | 
protected E | 
extractComplex(T oTarget)
Extract from target using reflection or map access. 
 | 
String | 
getCanonicalName()
Return the canonical name for this extractor. 
 | 
String | 
getMethodName()
Return the method name that this extractor is configured to invoke. 
 | 
String | 
getName()
Return the name passed into  
UniversalExtractor(String). | 
Object[] | 
getParameters()
Return the array of arguments used to invoke the method. 
 | 
String | 
getPropertyName()
Return the property name of this extractor. 
 | 
int | 
hashCode()
HashCode value is hashCode of non-null  
canonical name;
 otherwise, it is the hashCode of sName passed to {#link UniversalExtractor(String)}. | 
protected void | 
init()
Called in constructor and deserializers. 
 | 
boolean | 
isMethodExtractor()
Return true if this a method extractor. 
 | 
boolean | 
isPropertyExtractor()
Return true if this is a Property extractor. 
 | 
void | 
readExternal(DataInput in)
Restore the contents of this object by loading the object's state from
 the passed DataInput object. 
 | 
void | 
readExternal(PofReader in)
Restore the contents of a user type instance by reading its state using
 the specified PofReader object. 
 | 
String | 
toString()
Provide a human-readable description of this  
UniversalExtractor object. | 
void | 
writeExternal(DataOutput out)
Save the contents of this object by storing the object's state into
 the passed DataOutput object. 
 | 
void | 
writeExternal(PofWriter out)
Save the contents of a POF user type instance by writing its state using
 the specified PofWriter object. 
 | 
compare, compareEntries, extractFromEntry, extractOriginalFromEntry, getTarget, isCanonicallyEquatableasBinary, calculatePackedLength, calculatePackedLength, checkObjectInputFilter, checkObjectInputFilter, checkObjectInputFilter, convertUTF, decodeExpiry, decorate, decorate, decorate, decorate, decorate, decorateBinary, encodeExpiry, ensureSerializer, extractIntDecoration, fromBinary, fromBinary, fromBinary, fromBinary, fromBinary, fromBinary, fromByteArray, fromByteArray, getClass, getConfigSerialFilter, getConfigSerialFilterFactory, getDecoration, getDecoration, getDecorations, getDeltaCompressor, getInputStream, getNewObjectInput, getObjectInput, getObjectInputFilter, getObjectOutput, getObjectStreamFactory, getOutputStream, getShieldedOutputStream, getStreamFormat, getUndecorated, getUndecorated, isDecorated, isDecorated, isIntDecorated, isIntDecorated, isPatchCompatible, isPatchCompatible, isResolving, isSerializable, isSerializerCompatible, isVersionCompatible, isVersionCompatible, isVersionCompatible, isVersionCompatible, isVersionCompatible, isVersionCompatible, loadClass, loadResource, main, makeTrint, readBigDecimal, readBigInteger, readBooleanArray, readBooleanArray, readByteArray, readCharArray, readCharArray, readCollection, readDate, readDoubleArray, readDoubleArray, readExternalizableLite, readExternalizableLite, readFloatArray, readFloatArray, readInt, readInt, readIntArray, readIntArray, readIntArray2d, readLargeBooleanArray, readLargeByteArray, readLargeCharArray, readLargeDoubleArray, readLargeFloatArray, readLargeIntArray, readLargeLongArray, readLargeObjectArray, readLargeStringArray, readLong, readLong, readLongArray, readLongArray, readMap, readMap, readObject, readObject, readObjectArray, readObjectArray, readSafeUTF, readSafeUTF, readSerializable, readSerializable, readStringArray, readStringArray, readTime, readTimestamp, readTrint, readUnsignedTrint, readUTF, readXmlBean, readXmlSerializable, readXmlSerializable, realize, removeIntDecoration, removeIntDecoration, replace, reportIncompatibleSerializers, setObjectStreamFactory, toBinary, toBinary, toBinary, toByteArray, toByteArray, toByteArray, toLiteBinary, toLong, undecorate, undecorate, validateBufferSize, validateLoadArray, validateLoadClass, writeBigDecimal, writeBigInteger, writeBooleanArray, writeByteArray, writeCollection, writeDate, writeDoubleArray, writeExternalizableLite, writeFloatArray, writeInt, writeInt, writeIntArray2d, writeLong, writeLong, writeMap, writeObject, writeSafeUTF, writeSafeUTF, writeSerializable, writeStringArray, writeTime, writeTimestamp, writeTrint, writeTrint, writeUTF, writeXmlBean, writeXmlSerializablecountBits, countBits, countBits, indexOfLSB, indexOfLSB, indexOfLSB, indexOfMSB, indexOfMSB, indexOfMSB, rotateLeft, rotateLeft, rotateLeft, rotateRight, rotateRight, rotateRight, toBitString, toBitString, toBitString, toBytes, toBytes, toBytes, toBytes, toInt, toInt, toLongazzert, azzert, azzert, azzertFailed, breakLines, breakLines, capitalize, checkNotEmpty, checkNotNull, checkRange, computeSafeWaitTime, decimalValue, dup, dup, ensureBigDecimal, ensureClassLoader, ensureRuntimeException, ensureRuntimeException, equals, equalsDeep, err, err, err, err, err, escape, formatDateTime, getCallerStackFrame, getCommonMonitor, getCommonMonitor, getCommonMonitor, getContextClassLoader, getContextClassLoader, getDeepMessage, getErr, getLastSafeTimeMillis, getLog, getMaxDecDigits, getMaxHexDigits, getOriginalException, getOut, getProcessRandom, getRandom, getRandomBinary, getRandomBinary, getRandomString, getSafeTimeMillis, getStackFrame, getStackFrames, getStackTrace, getStackTrace, getStackTrace, getThreadFactory, getTimeZone, getUpTimeMillis, hashCode, hexValue, indentString, indentString, isDecimal, isHex, isLogEcho, isOctal, log, log, log, log, log, makeInteger, makeLong, makeThread, mergeArray, mergeBooleanArray, mergeByteArray, mergeCharArray, mergeDoubleArray, mergeFloatArray, mergeIntArray, mergeLongArray, mod, mod, octalValue, out, out, out, out, out, pad, parseBandwidth, parseBandwidth, parseDelimitedString, parseHex, parseHex, parseMemorySize, parseMemorySize, parsePercentage, parseTime, parseTime, parseTimeNanos, parseTimeNanos, printStackTrace, randomize, randomize, randomize, randomize, read, read, read, read, read, read, read, replace, setErr, setLog, setLogEcho, setOut, sleep, toBandwidthString, toBandwidthString, toCharEscape, toCrc, toCrc, toCrc, toCrc, toCrc, toDecString, toDelimitedString, toDelimitedString, toDelimitedString, toDelimitedString, toHex, toHex, toHexDump, toHexEscape, toHexEscape, toHexEscape, toHexEscape, toHexString, toMemorySizeString, toMemorySizeString, toQuotedCharEscape, toQuotedStringEscape, toSqlString, toString, toString, toStringEscape, toUnicodeEscape, trace, trace, trace, trace, trace, trace, trace, trace, trace, truncateString, truncateString, waitclone, finalize, getClass, notify, notifyAll, wait, wait, waitandThen, apply, applyAsDouble, applyAsInt, applyAsLong, compose, fromKey, getTarget, identity, identityCast, ofandThen, composecomparing, comparing, comparingDouble, comparingInt, comparingLong, naturalOrder, nullsFirst, nullsLast, reversed, reverseOrder, thenComparing, thenComparing, thenComparing, thenComparingDouble, thenComparingInt, thenComparingLongpublic static final String[] BEAN_ACCESSOR_PREFIXES
public static final String METHOD_SUFFIX
m_sName ends with this suffix, it represents a method name.protected String m_sName
protected Object[] m_aoParam
protected transient String m_sNameCanon
Note: subclasses are responsible for initialization and POF and/or Lite serialization of this field.
public UniversalExtractor()
public UniversalExtractor(String sName)
sName.
 
 If sName does not end in METHOD_SUFFIX,
 "()", this extractor is a property extractor. If sName is prefixed with
 one of the BEAN_ACCESSOR_PREFIXES and ends in the METHOD_SUFFIX,
 this extractor is a property extractor. Otherwise,
 if the sName just ends in {#link #METHOD_SUFFIX},
 this extractor is considered a method extractor.
sName - a method or property namepublic UniversalExtractor(String sName, Object[] aoParam)
 If sName does not end in METHOD_SUFFIX, "()",
 and has no aoParams,this extractor is a property extractor.
 If sName is prefixed with
 one of the BEAN_ACCESSOR_PREFIXES, ends in METHOD_SUFFIX
 and has no aoParams,this extractor is a property extractor.
 Otherwise, if the sNamejust ends in {#link #METHOD_SUFFIX},
 this extractor is considered a method extractor.
sName - a method or property nameaoParam - the array of arguments to be used in the method
                 invocation; may be nullIllegalArgumentException - when sName does not end in
                                  METHOD_SUFFIX and aoParam array length is one or more.public UniversalExtractor(String sName, Object[] aoParam, int nTarget)
 If sName does not end in METHOD_SUFFIX, "()",
 this extractor is a property extractor. If sName is prefixed with
 one of the BEAN_ACCESSOR_PREFIXES and ends in METHOD_SUFFIX,
 this extractor is a property extractor. If the sName
 just ends in METHOD_SUFFIX, this extractor is considered a method
 extractor.
sName - a method or property nameaoParam - the array of arguments to be used in the method
                 invocation; may be nullnTarget - one of the AbstractExtractor.VALUE or AbstractExtractor.KEY valuesIllegalArgumentException - when sName does not end in
                                  METHOD_SUFFIX and aoParam array length is one or more.public E extract(T oTarget)
 If name is a property, reflection accessor method lookup on T fails and
 oTarget is an instance Map, use canonical name to get value from
 target.
extract in interface ValueExtractor<T,E>extract in class AbstractExtractor<T,E>oTarget - the targetpublic String getCanonicalName()
ValueExtractorA canonical name uniquely identifies what is to be extracted, but not how it is to be extracted. Thus two different extractor implementations with the same non-null canonical name are considered to be equal, and should reflect this in their implementations of hashCode and equals.
 Canonical names for properties are designated by their property name in camel case,
 for instance a Java Bean with method getFooBar would have a property named fooBar,
 and would have fooBar as its canonical name.
 
Canonical names for zero-arg method invocations are the method name followed by ().
 Dots in a canonical name delimit one or more property/method accesses represented by a chaining
 ValueExtractor such as ChainedExtractor or
 PofExtractor(Class, PofNavigator, String).
 
 There is currently no canonical name format for methods which take parameters and
 as such they must return a canonical name of null.
getCanonicalName in interface CanonicallyNamedgetCanonicalName in interface ValueExtractor<T,E>getCanonicalName in class AbstractExtractor<T,E>nullpublic boolean equals(Object o)
UniversalExtractor with another object to determine equality.
 
 AbstractExtractor.equals(Object) contract takes precedence when applicable,
 falling back to implementation specific equals.
 
Two UniversalExtractor objects, re1 and re2 are considered equal if re1.extract(o) equals re2.extract(o) for all values of o.
equals in interface ValueExtractor<T,E>equals in interface Comparatorequals in class AbstractExtractor<T,E>o - the reference object with which to comparetrue iff this UniversalExtractor and the passed object are
         equivalentpublic int hashCode()
canonical name;
 otherwise, it is the hashCode of sName passed to {#link UniversalExtractor(String)}.hashCode in interface ValueExtractor<T,E>hashCode in class AbstractExtractor<T,E>public String toString()
UniversalExtractor object.protected void init()
public String getMethodName()
isMethodExtractor(), return
 the method name to be invoked. If a property extractor, return the likely JavaBean accessor
 method name.public String getName()
UniversalExtractor(String).public String getPropertyName()
public boolean isPropertyExtractor()
public boolean isMethodExtractor()
public Object[] getParameters()
protected E extractComplex(T oTarget) throws InvocationTargetException, IllegalAccessException
T fails and
 T is an instance Map, use canonical name to get value from
 target. If successful, cache the reflection computation.oTarget - the targetInvocationTargetException - if reflection method lookup failsIllegalAccessException - if reflection method lookup failspublic static <T,E> ValueExtractor<T,E> createExtractor(String sNames)
T - the type of the value to extract fromE - the type of value that will be extractedsNames - dot-delimited property and/or methods name(s)UniversalExtractor if only one name in parameter; otherwise, return
 a ChainedExtractor with a UniversalExtractor for each name.public void readExternal(DataInput in) throws IOException
readExternal in interface ExternalizableLitein - the DataInput stream to read data from in order to restore
            the state of this objectIOException - if an I/O exception occursNotActiveException - if the object is not in its initial
            state, and therefore cannot be deserialized intopublic void writeExternal(DataOutput out) throws IOException
writeExternal in interface ExternalizableLiteout - the DataOutput stream to write the state of this object toIOException - if an I/O exception occurspublic void readExternal(PofReader in) throws IOException
readExternal in interface PortableObjectin - the PofReader from which to read the object's stateIOException - if an I/O error occurspublic void writeExternal(PofWriter out) throws IOException
writeExternal in interface PortableObjectout - the PofWriter to which to write the object's stateIOException - if an I/O error occurs