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

F79659-03

coherence/util/processor/ConditionalPut.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_CONDITIONAL_PUT_HPP
00008 #define COH_CONDITIONAL_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/Filter.hpp"
00016 #include "coherence/util/InvocableMap.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::Filter;
00025 using coherence::util::InvocableMap;
00026 
00027 
00028 /**
00029 * ConditionalPut is an EntryProcessor that performs an
00030 * InvocableMap::Entry#setValue operation if the specified condition is
00031 * satisfied.
00032 *
00033 * @author tb  2008.04.28
00034 */
00035 class COH_EXPORT ConditionalPut
00036     : public class_spec<ConditionalPut,
00037         extends<AbstractProcessor>,
00038         implements<PortableObject> >
00039     {
00040     friend class factory<ConditionalPut>;
00041 
00042     // ----- constructors ---------------------------------------------------
00043 
00044     protected:
00045         /**
00046         * Construct a ConditionalPut.
00047         */
00048         ConditionalPut();
00049 
00050         /**
00051         * Construct a ConditionalPut that updates an entry with a new value
00052         * if and only if the filter applied to the entry evaluates to true.
00053         * This processor optionally returns the current value as a result of
00054         * the invocation if it has not been updated (the filter evaluated to
00055         * false).
00056         *
00057         * @param vFilter  the filter to evaluate an entry
00058         * @param ohValue  a value to update an entry with
00059         * @param fReturn  specifies whether or not the processor should
00060         *                 return the current value in case it has not been
00061         *                 updated
00062         */
00063         ConditionalPut(Filter::View vFilter, Object::Holder ohValue,
00064                 bool fReturn = false);
00065 
00066 
00067     // ----- InvocableMap::EntryProcessor interface -------------------------
00068 
00069     public:
00070         /**
00071         * {@inheritDoc}
00072         */
00073         virtual Object::Holder process(
00074                 InvocableMap::Entry::Handle hEntry) const;
00075 
00076         /**
00077         * {@inheritDoc}
00078         */
00079         virtual Map::View processAll(Set::View vsetEntries) const;
00080 
00081 
00082     // ----- PortableObject interface ---------------------------------------
00083 
00084     public:
00085         /**
00086         * {@inheritDoc}
00087         */
00088         virtual void readExternal(PofReader::Handle hIn);
00089 
00090         /**
00091         * {@inheritDoc}
00092         */
00093         virtual void writeExternal(PofWriter::Handle hOut) const;
00094 
00095 
00096     // ----- Object interface -----------------------------------------------
00097 
00098     public:
00099         /**
00100         * {@inheritDoc}
00101         */
00102         virtual bool equals(Object::View v) const;
00103 
00104         /**
00105         * {@inheritDoc}
00106         */
00107         virtual size32_t hashCode() const;
00108 
00109 
00110     // ----- data members ---------------------------------------------------
00111 
00112     protected:
00113         /**
00114         * The underlying filter.
00115         */
00116         FinalView<Filter> f_vFilter;
00117 
00118         /**
00119         * Specifies the new value to update an entry with.
00120         */
00121         FinalHolder<Object> f_hValue;
00122 
00123         /**
00124         * Specifies whether or not a return value is required.
00125         */
00126         bool m_fReturn;
00127     };
00128 
00129 COH_CLOSE_NAMESPACE3
00130 
00131 #endif // COH_CONDITIONAL_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.