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

F79659-03

coherence/util/processor/PropertyManipulator.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_PROPERTY_MANIPULATOR_HPP
00008 #define COH_PROPERTY_MANIPULATOR_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/io/pof/PortableObject.hpp"
00015 #include "coherence/util/ValueExtractor.hpp"
00016 #include "coherence/util/ValueManipulator.hpp"
00017 #include "coherence/util/ValueUpdater.hpp"
00018 
00019 COH_OPEN_NAMESPACE3(coherence,util,processor)
00020 
00021 using coherence::io::pof::PofReader;
00022 using coherence::io::pof::PofWriter;
00023 using coherence::io::pof::PortableObject;
00024 using coherence::util::ValueExtractor;
00025 using coherence::util::ValueManipulator;
00026 using coherence::util::ValueUpdater;
00027 
00028 
00029 /**
00030 * PropertyManipulator is a reflection based ValueManipulator implementation
00031 * based on the JavaBean property name conventions.
00032 *
00033 * @author tb  2008.05.06
00034 */
00035 class COH_EXPORT PropertyManipulator
00036     : public class_spec<PropertyManipulator,
00037         extends<Object>,
00038         implements<ValueManipulator, PortableObject> >
00039     {
00040     friend class factory<PropertyManipulator>;
00041 
00042     // ----- constructors ---------------------------------------------------
00043 
00044     protected:
00045         /**
00046         * Construct a PropertyManipulator.
00047         */
00048         PropertyManipulator();
00049 
00050         /**
00051         * Construct a PropertyManipulator for the specified property name.
00052         * <p>
00053         * This constructor assumes that the corresponding property getter
00054         * will have a name of either ("get" + sName) or ("is + sName) and the
00055         * corresponding property setter's name will be ("set + sName).
00056         *
00057         * @param vsName a property name
00058         * @param fUseIs if true, the getter method will be prefixed with "is"
00059         *                rather than "get"
00060         */
00061         PropertyManipulator(String::View vsName, bool fUseIs = false);
00062 
00063 
00064     // ----- ValueManipulator interface -------------------------------------
00065 
00066     public:
00067         /**
00068         * {@inheritDoc}
00069         */
00070         virtual ValueExtractor::View getExtractor() const;
00071 
00072         /**
00073         * {@inheritDoc}
00074         */
00075         virtual ValueUpdater::View getUpdater() const;
00076 
00077 
00078     // ----- internal -------------------------------------------------------
00079 
00080     protected:
00081         /**
00082         * Parse the property name and initialize necessary extractor and
00083         * updator.
00084         */
00085         void init() const;
00086 
00087 
00088     // ----- PortableObject interface ---------------------------------------
00089 
00090     public:
00091         /**
00092         * {@inheritDoc}
00093         */
00094         virtual void readExternal(PofReader::Handle hIn);
00095 
00096         /**
00097         * {@inheritDoc}
00098         */
00099         virtual void writeExternal(PofWriter::Handle hOut) const;
00100 
00101 
00102     // ----- Object interface -----------------------------------------------
00103 
00104     public:
00105         /**
00106         * {@inheritDoc}
00107         */
00108         virtual bool equals(Object::View v) const;
00109 
00110         /**
00111         * {@inheritDoc}
00112         */
00113         virtual size32_t hashCode() const;
00114 
00115 
00116     // ----- data members ---------------------------------------------------
00117 
00118         /**
00119         * The property name, never null.
00120         */
00121         FinalView<String> f_vsName;
00122 
00123         /**
00124         * The getter prefix flag.
00125         */
00126         bool m_fUseIs;
00127 
00128         /**
00129         * A partial ValueExtractor used for composite properties.
00130         */
00131         mutable FinalView<ValueExtractor> f_vExtractorPart;
00132 
00133         /**
00134         * The underlying ValueExtractor.
00135         */
00136         mutable FinalView<ValueExtractor> f_vExtractor;
00137 
00138         /**
00139         * The underlying ValueUpdater.
00140         */
00141         mutable FinalView<ValueUpdater> f_vUpdater;
00142     };
00143 
00144 COH_CLOSE_NAMESPACE3
00145 
00146 #endif // COH_PROPERTY_MANIPULATOR_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.