#include <coherence/util/extractor/ReflectionExtractor.hpp>
Inherits AbstractExtractor.
Inherited by TypedExtractor, and TypedExtractor< RH::ValueType::BoxedType, C, M, coherence::lang::BoxHandle< RH::ValueType >, OH >.
Local execution of a ReflectionExtractor is dependent upon target class and method having been registered with the SystemClassLoader. For cases where the registration has not been performed or is not possible locally executable C++ extractors may either be custom built, or auto-generated using the TypedExtractor<>.
Method
Public Types | |||||||||||||
| typedef spec::Handle | Handle | ||||||||||||
| ReflectionExtractor Handle definition. | |||||||||||||
| typedef spec::View | View | ||||||||||||
| ReflectionExtractor View definition. | |||||||||||||
| typedef spec::Holder | Holder | ||||||||||||
| ReflectionExtractor Holder definition. | |||||||||||||
Public Member Functions | |||||||||||||
| virtual Object::Holder | extract (Object::Holder ohTarget) const | ||||||||||||
| Extract the value from the passed object. The returned value may be NULL.
| |||||||||||||
| virtual void | readExternal (PofReader::Handle hIn) | ||||||||||||
| virtual void | writeExternal (PofWriter::Handle hOut) const | ||||||||||||
| virtual bool | equals (Object::View v) const | ||||||||||||
| virtual size32_t | hashCode () const | ||||||||||||
| Return a hash code value for the Object. This method is supported for the benefit of hash-based containers.
The general contract of
The default implementation is identity based.
| |||||||||||||
|
virtual TypedHandle < const String > | toString () const | ||||||||||||
| Output a human-readable description of this Object to the given stream. Note that when overriding this method the return type must be TypedHandle<const String> rather then String::View. These two types are assignment compatible but not equivalent and declaring the override with String::View will not be a compatible override. coherence::lang::operator<<(std::ostream, Object::View) is defined and will call into the toString method, to output Objects. If a managed String object is desired, the COH_TO_STRING macro can be used to build up a String from streamable contents and is generally how toString() will be implemented.
Object::View vKey = ... Object::View vValue = ... std::cout << vKey << " = " << vValue << std::endl; String::View vs = COH_TO_STRING(vKey << " = " << vValue); The COH_TO_STRING macro is also the most common way to implement the toString method. For example:
virtual TypedHandle<const String> Person::toString() const { return COH_TO_STRING("Name: " << f_sName << " SSN: " << f_nSSN); }
| |||||||||||||
| virtual String::View | getMethodName () const | ||||||||||||
| Determine the name of the method that this extractor is configured to invoke. | |||||||||||||
| virtual ObjectArray::View | getParameters () const | ||||||||||||
| Return the array of arguments used to invoke the method. | |||||||||||||
Protected Member Functions | |||||||||||||
| ReflectionExtractor () | |||||||||||||
| Construct an empty ReflectionExtractor (necessary for the PortableObject interface). | |||||||||||||
| ReflectionExtractor (String::View vsMethod, ObjectArray::View vaParam=NULL, int32_t nTarget=value) | |||||||||||||
| Construct a ReflectionExtractor based on a method name, optional parameters and the entry extraction target. | |||||||||||||
| ReflectionExtractor (const ReflectionExtractor &that) | |||||||||||||
| Copy constructor. | |||||||||||||
Protected Attributes | |||||||||||||
| FinalView< String > | f_vsMethod | ||||||||||||
| The name of the method to invoke. | |||||||||||||
| FinalView< ObjectArray > | f_vaParam | ||||||||||||
| The parameter array. | |||||||||||||
| MemberView< Method > | m_vMethod | ||||||||||||
| The resolved Method. | |||||||||||||
| ReflectionExtractor | ( | String::View | vsMethod, | |
| ObjectArray::View | vaParam = NULL, |
|||
| int32_t | nTarget = value | |||
| ) | [protected] |
Construct a ReflectionExtractor based on a method name, optional parameters and the entry extraction target.
| vsMethod | the name of the method to invoke via reflection | |
| vaParam | the array of arguments to be used in the method invocation; may be NULL | |
| nTarget | one of the value or key values |
| virtual String::View getMethodName | ( | ) | const [virtual] |
Determine the name of the method that this extractor is configured to invoke.
| virtual ObjectArray::View getParameters | ( | ) | const [virtual] |
Return the array of arguments used to invoke the method.