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

F79659-03

coherence/util/extractor/CompositeUpdater.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_COMPOSITE_UPDATER_HPP
00008 #define COH_COMPOSITE_UPDATER_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/ValueUpdater.hpp"
00017 
00018 COH_OPEN_NAMESPACE3(coherence,util,extractor)
00019 
00020 using coherence::io::pof::PortableObject;
00021 using coherence::io::pof::PofReader;
00022 using coherence::io::pof::PofWriter;
00023 
00024 
00025 /**
00026 * A ValueManipulator implementation based on an extractor-updater pair.
00027 *
00028 * @author djl 2008.04.09
00029 *
00030 * @see CompositeUpdater
00031 */
00032 class COH_EXPORT CompositeUpdater
00033     : public class_spec<CompositeUpdater,
00034         extends<Object>,
00035         implements<ValueUpdater, PortableObject> >
00036     {
00037     friend class factory<CompositeUpdater>;
00038 
00039     // ----- constructors ---------------------------------------------------
00040 
00041     protected:
00042         /**
00043         * Construct an empty CompositeUpdater
00044         * (necessary for the PortableObject interface).
00045         */
00046         CompositeUpdater();
00047 
00048         /**
00049         * Construct a CompositeUpdater for a specified method name sequence.
00050         *
00051         * For example: "getAddress. setZip" method name will indicate that the
00052         * "getAddress()" method should be used to extract an Address object,
00053         * which will then be used by the "setZip(String)" call.
00054         *
00055         * @param vsName  a dot-delimited sequence of N method names which results
00056         *                in a CompositeUpdater that is based on an chain of
00057         *                (N-1) ReflectionExtractor objects and a single
00058         *                ReflectionUpdater.
00059         */
00060         CompositeUpdater(String::View vsName);
00061 
00062         /**
00063         * Construct a CompositeUpdater based on the specified extractor and
00064         * updater.
00065         *
00066         * <b>Note:</b> the extractor and updater here are not symmetrical in
00067         * nature: the extractor is used to "drill-down" to the target object,
00068         * while the updater will operate on that extracted object.
00069         *
00070         * @param vExtractor  the ValueExtractor
00071         * @param vUpdater    the ValueUpdater
00072         */
00073         CompositeUpdater(ValueExtractor::View vExtractor,
00074                 ValueUpdater::View vUpdater);
00075 
00076 
00077    // ----- ValueUpdater interface ------------------------------------------
00078 
00079     public:
00080         /**
00081         * {@inheritDoc}
00082         */
00083         virtual void update(Object::Handle hTarget,
00084                 Object::Holder ohValue) const;
00085 
00086 
00087     // ----- PortableObject interface ---------------------------------------
00088 
00089     public:
00090         /**
00091         * {@inheritDoc}
00092         */
00093         virtual void readExternal(PofReader::Handle hIn);
00094 
00095         /**
00096         * {@inheritDoc}
00097         */
00098         virtual void writeExternal(PofWriter::Handle hOut) const;
00099 
00100 
00101     // ----- Object interface -----------------------------------------------
00102 
00103     public:
00104         /**
00105         * {@inheritDoc}
00106         */
00107         virtual TypedHandle<const String> toString() const;
00108 
00109 
00110     // ----- data member accessors ------------------------------------------
00111 
00112     public:
00113         /**
00114         * Retrieve the ValueExtractor part.
00115         *
00116         * @return the ValueExtractor
00117         */
00118         virtual ValueExtractor::View getExtractor() const;
00119 
00120         /**
00121         * Retrieve the ValueUpdator part.
00122         *
00123         * @return the ValueUpdater
00124         */
00125         virtual ValueUpdater::View getUpdater() const;
00126 
00127 
00128     // ----- data members ---------------------------------------------------
00129 
00130     protected:
00131         /**
00132         * The ValueExtractor part.
00133         */
00134         FinalView<ValueExtractor> f_vExtractor;
00135 
00136         /**
00137         * The ValueUpdaterr part.
00138         */
00139         FinalView<ValueUpdater> f_vUpdater;
00140     };
00141 
00142 COH_CLOSE_NAMESPACE3
00143 
00144 #endif // COH_COMPOSITE_UPDATER_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.