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.
ChainedExtractor
ExternalizableHelper.DecoratedMultiBufferReadBuffer, ExternalizableHelper.DefaultObjectStreamFactory, ExternalizableHelper.FormatAwareCompressor, ExternalizableHelper.IntDecoratedObject, ExternalizableHelper.Shielded, ExternalizableHelper.ShieldedDataOutputStream, ExternalizableHelper.ShieldedInputStream, ExternalizableHelper.ShieldedObjectOutputStream, ExternalizableHelper.ShieldedOutputStream, ExternalizableHelper.SimpleXmlBeanClassCache, ExternalizableHelper.Stats, ExternalizableHelper.XmlBeanClassCache
Base.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, VALUE
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_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, isCanonicallyEquatable
asBinary, calculatePackedLength, calculatePackedLength, checkObjectInputFilter, convertUTF, decodeExpiry, decorate, decorate, decorate, decorate, decorate, decorateBinary, encodeExpiry, ensureSerializer, extractIntDecoration, fromBinary, fromBinary, fromBinary, fromBinary, fromBinary, fromBinary, fromByteArray, fromByteArray, getClass, getDecoration, getDecoration, getDecorations, getDeltaCompressor, getInputStream, getNewObjectInput, getObjectInput, getObjectOutput, getObjectStreamFactory, getOutputStream, getShieldedOutputStream, getStreamFormat, getUndecorated, getUndecorated, isDecorated, isDecorated, isIntDecorated, isIntDecorated, isResolving, isSerializable, isSerializerCompatible, isVersionCompatible, isVersionCompatible, loadClass, loadResource, main, makeTrint, readBigDecimal, readBigInteger, readBooleanArray, readByteArray, readCollection, readDate, readDoubleArray, readExternalizableLite, readExternalizableLite, readFloatArray, readInt, readInt, readIntArray2d, readLong, readLong, readMap, readMap, readObject, readObject, readSafeUTF, readSafeUTF, readSerializable, readSerializable, readStringArray, readTime, readTimestamp, readTrint, readUnsignedTrint, readUTF, readXmlBean, readXmlSerializable, readXmlSerializable, realize, removeIntDecoration, removeIntDecoration, replace, reportIncompatibleSerializers, setObjectStreamFactory, toBinary, toBinary, toByteArray, toByteArray, toByteArray, toLiteBinary, toLong, undecorate, undecorate, validateBufferSize, 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, writeXmlSerializable
countBits, countBits, countBits, indexOfLSB, indexOfLSB, indexOfLSB, indexOfMSB, indexOfMSB, indexOfMSB, rotateLeft, rotateLeft, rotateLeft, rotateRight, rotateRight, rotateRight, toBitString, toBitString, toBitString, toBytes, toBytes, toBytes, toBytes, toInt, toInt, toLong
azzert, 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, getThreadFactory, getTimeZone, getUpTimeMillis, hashCode, hexValue, indentString, indentString, isDecimal, isHex, isLogEcho, isOctal, log, log, log, log, log, makeInteger, makeLong, makeThread, 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, wait
clone, finalize, getClass, notify, notifyAll, wait, wait, wait
andThen, apply, applyAsDouble, applyAsInt, applyAsLong, compose, fromKey, getTarget, identity, identityCast, of
andThen, compose
comparing, comparing, comparingDouble, comparingInt, comparingLong, naturalOrder, nullsFirst, nullsLast, reversed, reverseOrder, thenComparing, thenComparing, thenComparing, thenComparingDouble, thenComparingInt, thenComparingLong
public 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 sName
just 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()
ValueExtractor
A 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 com.oracle.coherence.common.base.CanonicallyNamed
getCanonicalName
in interface ValueExtractor<T,E>
getCanonicalName
in class AbstractExtractor<T,E>
null
public 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 Comparator
equals
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 ExternalizableLite
in
- 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 ExternalizableLite
out
- 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 PortableObject
in
- 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 PortableObject
out
- the PofWriter to which to write the object's stateIOException
- if an I/O error occurs