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

F79659-03

coherence/util/processor/VersionedPutAll.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_VERSIONED_PUT_ALL_HPP
00008 #define COH_VERSIONED_PUT_ALL_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/InvocableMap.hpp"
00016 #include "coherence/util/Map.hpp"
00017 #include "coherence/util/processor/AbstractProcessor.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::InvocableMap;
00025 using coherence::util::Map;
00026 
00027 
00028 /**
00029 * VersionedPutAll is an EntryProcessor that assumes that entry values
00030 * implement Versionable interface and performs an
00031 * InvocableMap::Entry#setValue operation only for entries whose versions
00032 * match to versions of the corresponding current values. In case of the
00033 * match, the VersionedPutAll will increment the version indicator before
00034 * each value is updated.
00035 *
00036 * @author tb  2008.04.28
00037 */
00038 class COH_EXPORT VersionedPutAll
00039     : public class_spec<VersionedPutAll,
00040         extends<AbstractProcessor>,
00041         implements<PortableObject> >
00042     {
00043     friend class factory<VersionedPutAll>;
00044 
00045     // ----- constructors ---------------------------------------------------
00046 
00047     protected:
00048         /**
00049         * Construct a VersionedPutAll.
00050         */
00051         VersionedPutAll();
00052 
00053         /**
00054         * Construct a VersionedPutAll processor that updates an entry with a
00055         * new value if and only if the version of the new value matches to
00056         * the version of the current entry's value (which must exist). This
00057         * processor optionally returns a map of entries that have not been
00058         * updated (the versions did not match).
00059         *
00060         * @param vMap          a map of values to update entries with
00061         * @param fAllowInsert  specifies whether or not an insert should be
00062         *                      allowed (no currently existing value)
00063         * @param fReturn       specifies whether or not the processor should
00064         *                      return the entries that have not been updated
00065         */
00066         VersionedPutAll(Map::View vMap, bool fAllowInsert = false,
00067                 bool fReturn = false);
00068 
00069 
00070     // ----- InvocableMap::EntryProcessor interface -------------------------
00071 
00072     public:
00073         /**
00074         * {@inheritDoc}
00075         */
00076         virtual Object::Holder process(InvocableMap::Entry::Handle hEntry) const;
00077 
00078         /**
00079         * {@inheritDoc}
00080         */
00081         virtual Map::View processAll(Set::View vsetEntries) const;
00082 
00083 
00084     // ----- PortableObject interface ---------------------------------------
00085 
00086     public:
00087         /**
00088         * {@inheritDoc}
00089         */
00090         virtual void readExternal(PofReader::Handle hIn);
00091 
00092         /**
00093         * {@inheritDoc}
00094         */
00095         virtual void writeExternal(PofWriter::Handle hOut) const;
00096 
00097 
00098     // ----- Object interface -----------------------------------------------
00099 
00100     public:
00101         /**
00102         * {@inheritDoc}
00103         */
00104         virtual bool equals(Object::View v) const;
00105 
00106         /**
00107         * {@inheritDoc}
00108         */
00109         virtual size32_t hashCode() const;
00110 
00111 
00112     // ----- helper functions -----------------------------------------------
00113 
00114     protected:
00115         /**
00116         * Process the given entry.
00117         */
00118         virtual Object::Holder processEntry(
00119             InvocableMap::Entry::Handle hEntry,
00120             Map::View vMap,
00121             bool fInsert,
00122             bool fReturn) const;
00123 
00124 
00125     // ----- data members ---------------------------------------------------
00126 
00127     protected:
00128         /**
00129         * Specifies the map of new values.
00130         */
00131         FinalView<Map> f_vMap;
00132 
00133         /**
00134         * Specifies whether or not an insert is allowed.
00135         */
00136         bool m_fInsert;
00137 
00138         /**
00139         * Specifies whether or not a return value is required.
00140         */
00141         bool m_fReturn;
00142     };
00143 
00144 COH_CLOSE_NAMESPACE3
00145 
00146 #endif // COH_VERSIONED_PUT_ALL_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.