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, 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, isResolving, isSerializable, isSerializerCompatible, 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, 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