C++ Client API Reference for Oracle Coherence
14c (14.1.2.0.0)

F79659-03

coherence/util/extractor/ReflectionExtractor.hpp

00001 /*
00002  * Copyright (c) 2000, 2020, Oracle and/or its affiliates.
00003  *
00004  * Licensed under the Universal Permissive License v 1.0 as shown at
00005  * http://oss.oracle.com/licenses/upl.
00006  */
00007 #ifndef COH_REFLECTION_EXTRACTOR_HPP
00008 #define COH_REFLECTION_EXTRACTOR_HPP
00009 
00010 #include "coherence/lang.ns"
00011 
00012 #include "coherence/io/pof/PofReader.hpp"
00013 #include "coherence/io/pof/PofWriter.hpp"
00014 #include "coherence/util/extractor/AbstractExtractor.hpp"
00015 
00016 COH_OPEN_NAMESPACE3(coherence,util,extractor)
00017 
00018 using coherence::io::pof::PofReader;
00019 using coherence::io::pof::PofWriter;
00020 
00021 
00022 /**
00023 * Reflection-based ValueExtractor implementation.
00024 *
00025 * Local execution of a ReflectionExtractor is dependent upon target class and
00026 * method having been registered with the SystemClassLoader. For cases where
00027 * the registration has not been performed or is not possible locally executable
00028 * C++ extractors may either be custom built, or auto-generated using the
00029 * TypedExtractor<>.
00030 *
00031 * @author djl/mf 2008.03.06
00032 *
00033 * @see ChainedExtractor
00034 * @see TypedExtractor
00035 * @see Method
00036 */
00037 class COH_EXPORT ReflectionExtractor
00038     : public cloneable_spec<ReflectionExtractor,
00039         extends<AbstractExtractor> >
00040     {
00041     friend class factory<ReflectionExtractor>;
00042 
00043     // ----- constructors ---------------------------------------------------
00044 
00045     protected:
00046         /**
00047         * Construct an empty ReflectionExtractor
00048         * (necessary for the PortableObject interface).
00049         */
00050         ReflectionExtractor();
00051 
00052         /**
00053         * Construct a ReflectionExtractor based on a method name, optional
00054         * parameters and the entry extraction target.
00055         *
00056         * @param vsMethod  the name of the method to invoke via reflection
00057         * @param vaParam   the array of arguments to be used in the method
00058         *                  invocation; may be NULL
00059         * @param nTarget   one of the {@link #value} or {@link #key} values
00060         *
00061         * @since Coherence 3.5
00062         */
00063         ReflectionExtractor(String::View vsMethod,
00064                 ObjectArray::View vaParam = NULL, int32_t nTarget = value);
00065 
00066         /**
00067         * Copy constructor.
00068         */
00069         ReflectionExtractor(const ReflectionExtractor& that);
00070 
00071 
00072    // ----- ValueExtractor interface ---------------------------------------
00073 
00074     public:
00075         /**
00076         * {@inheritDoc}
00077         */
00078         virtual Object::Holder extract(Object::Holder ohTarget) const;
00079 
00080 
00081     // ----- PortableObject interface ---------------------------------------
00082 
00083     public:
00084         /**
00085         * {@inheritDoc}
00086         */
00087         virtual void readExternal(PofReader::Handle hIn);
00088 
00089         /**
00090         * {@inheritDoc}
00091         */
00092         virtual void writeExternal(PofWriter::Handle hOut) const;
00093 
00094 
00095     // ----- Object interface -----------------------------------------------
00096 
00097     public:
00098         /**
00099         * {@inheritDoc}
00100         */
00101         virtual bool equals(Object::View v) const;
00102 
00103         /**
00104         * {@inheritDoc}
00105         */
00106         virtual size32_t hashCode() const;
00107 
00108         /**
00109         * {@inheritDoc}
00110         */
00111         virtual TypedHandle<const String> toString() const;
00112 
00113 
00114     // ----- data member accessors ------------------------------------------
00115 
00116     public:
00117         /**
00118         * Determine the name of the method that this extractor is configured
00119         * to invoke.
00120         *
00121         * @return the name of the method to invoke using reflection
00122         */
00123         virtual String::View getMethodName() const;
00124 
00125         /**
00126         * Return the array of arguments used to invoke the method.
00127         *
00128         * @return the array of arguments used to invoke the method
00129         */
00130         virtual ObjectArray::View getParameters() const;
00131 
00132 
00133     // ----- data members ---------------------------------------------------
00134 
00135     protected:
00136         /**
00137         * The name of the method to invoke.
00138         */
00139         FinalView<String> f_vsMethod;
00140 
00141         /**
00142         * The parameter array.
00143         */
00144         FinalView<ObjectArray> f_vaParam;
00145 
00146         /**
00147          * The resolved Method.
00148          */
00149         mutable MemberView<Method> m_vMethod;
00150     };
00151 
00152 COH_CLOSE_NAMESPACE3
00153 
00154 #endif // COH_REFLECTION_EXTRACTOR_HPP
Copyright © 2000, 2025, Oracle and/or its affiliates. Licensed under the Universal Permissive License v 1.0 as shown at https://oss.oracle.com/licenses/upl.