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

F79659-03

coherence/util/processor/VersionedPut.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_HPP
00008 #define COH_VERSIONED_PUT_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/Versionable.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::Versionable;
00026 
00027 
00028 /**
00029 * VersionedPut is an EntryProcessor that assumes that entry values implement
00030 * Versionable interface and performs an InvocableMap::Entry#setValue
00031 * operation if and only if the version of the specified value matches to the
00032 * version of the current value. In case of the match, the VersionedPut will
00033 * increment the version indicator before the value is updated.
00034 *
00035 * @author tb  2008.04.28
00036 */
00037 class COH_EXPORT VersionedPut
00038     : public class_spec<VersionedPut,
00039         extends<AbstractProcessor>,
00040         implements<PortableObject> >
00041     {
00042     friend class factory<VersionedPut>;
00043 
00044     // ----- constructors ---------------------------------------------------
00045 
00046     protected:
00047         /**
00048         * Construct a VersionedPut.
00049         */
00050         VersionedPut();
00051 
00052         /**
00053         * Construct a VersionedPut that updates an entry with a new value if
00054         * and only if the version of the new value matches to the version of
00055         * the current entry's value. This processor optionally returns the
00056         * current value as a result of the invocation if it has not been
00057         * updated (the versions did not match).
00058         *
00059         * @param hValue        a value to update an entry with
00060         * @param fAllowInsert  specifies whether or not an insert should be
00061         *                      allowed (no currently existing value)
00062         * @param fReturn       specifies whether or not the processor should
00063         *                      return the current value in case it has not
00064         *                      been updated
00065         */
00066         VersionedPut(Versionable::Handle hValue, 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                 Versionable::Holder ohValueNew,
00121                 bool fInsert,
00122                 bool fReturn) const;
00123 
00124 
00125     // ----- data members ---------------------------------------------------
00126 
00127     protected:
00128         /**
00129         * Specifies the new value to update an entry with.
00130         */
00131         mutable FinalHandle<Versionable> f_hValue;
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_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.