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

F79659-03

coherence/util/processor/NumberIncrementor.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_NUMBER_INCREMENTOR_HPP
00008 #define COH_NUMBER_INCREMENTOR_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/util/InvocableMap.hpp"
00015 #include "coherence/util/processor/PropertyProcessor.hpp"
00016 #include "coherence/util/ValueManipulator.hpp"
00017 
00018 COH_OPEN_NAMESPACE3(coherence,util, processor)
00019 
00020 using coherence::io::pof::PofReader;
00021 using coherence::io::pof::PofWriter;
00022 using coherence::util::InvocableMap;
00023 using coherence::util::ValueManipulator;
00024 
00025 
00026 /**
00027 * The NumberIncrementor entry processor is used to increment a property value
00028 * of a Number type.
00029 *
00030 * @author tb  2008.04.28
00031 */
00032 class COH_EXPORT NumberIncrementor
00033     : public class_spec<NumberIncrementor,
00034         extends<PropertyProcessor> >
00035     {
00036     friend class factory<NumberIncrementor>;
00037 
00038     // ----- constructors ---------------------------------------------------
00039 
00040     protected:
00041         /**
00042         * Construct an NumberIncrementor processor.
00043         */
00044         NumberIncrementor();
00045 
00046         /**
00047         * Construct an NumberIncrementor processor that will increment a
00048         * property value by a specified amount, returning either the old or
00049         * the new value as specified. The type of the numInc parameter will
00050         * dictate the type of the original and the new value.
00051         *
00052         * @param vManipulator    the ValueManipulator; could be NULL
00053         * @param vNumInc         the Number representing the magnitude and
00054         *                        sign of the increment
00055         * @param fPostIncrement  pass true to return the value as it was
00056         *                        before it was incremented, or pass false to
00057         *                        return the value as it is after it is
00058         *                        incremented
00059         */
00060         NumberIncrementor(ValueManipulator::View vManipulator,
00061                 Number::View vNumInc, bool fPostIncrement);
00062 
00063 
00064     // ----- InvocableMap::EntryProcessor interface -------------------------
00065 
00066     public:
00067         /**
00068         * {@inheritDoc}
00069         */
00070         virtual Object::Holder process(InvocableMap::Entry::Handle hEntry) const;
00071 
00072 
00073     // ----- PortableObject interface ---------------------------------------
00074 
00075     public:
00076         /**
00077         * {@inheritDoc}
00078         */
00079         virtual void readExternal(PofReader::Handle hIn);
00080 
00081         /**
00082         * {@inheritDoc}
00083         */
00084         virtual void writeExternal(PofWriter::Handle hOut) const;
00085 
00086 
00087     // ----- Describable interface ------------------------------------------
00088 
00089     public:
00090         /**
00091         * {@inheritDoc}
00092         */
00093         virtual String::View getDescription() const;
00094 
00095 
00096     // ----- constants ------------------------------------------------------
00097 
00098     public:
00099         /**
00100         * The Integer16 value of 0.
00101         */
00102         static Number::View getInteger16Zero();
00103 
00104         /**
00105         * The Integer32 value of 0.
00106         */
00107         static Number::View getInteger32Zero();
00108 
00109         /**
00110         * The Integer64 value of 0.
00111         */
00112         static Number::View getInteger64Zero();
00113 
00114         /**
00115         * The Float32 value of 0.
00116         */
00117         static Number::View getFloat32Zero();
00118 
00119         /**
00120         * The Float64 value of 0.
00121         */
00122         static Number::View getFloat64Zero();
00123 
00124 
00125     // ----- data members ---------------------------------------------------
00126 
00127     protected:
00128         /**
00129         * The number to increment by.
00130         */
00131         FinalView<Number> f_vNumInc;
00132 
00133         /**
00134         * Whether to return the value before it was incremented
00135         * ("post-increment") or after it is incremented ("pre-increment").
00136         */
00137         bool m_fPostInc;
00138     };
00139 
00140 COH_CLOSE_NAMESPACE3
00141 
00142 #endif // COH_NUMBER_INCREMENTOR_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.