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

F79659-03

coherence/util/processor/NumberMultiplier.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_MULTIPLIER_HPP
00008 #define COH_NUMBER_MULTIPLIER_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 NumberMultiplier entry processor is used to multiply a property value
00028 * of a Number type.  Supported types are: Byte, Short, Integer, Long,
00029 * Float, Double, BigInteger and BigDecimal.
00030 *
00031 * @author tb  2008.04.28
00032 */
00033 class COH_EXPORT NumberMultiplier
00034     : public class_spec<NumberMultiplier,
00035         extends<PropertyProcessor> >
00036     {
00037     friend class factory<NumberMultiplier>;
00038 
00039     // ----- constructors ---------------------------------------------------
00040 
00041     protected:
00042         /**
00043         * Construct an NumberMultiplier processor.
00044         */
00045         NumberMultiplier();
00046 
00047         /**
00048         * Construct an NumberMultiplier processor that will increment a
00049         * property value by a specified amount, returning either the old or
00050         * the new value as specified. The type of the vNumFactor parameter
00051         * will dictate the type of the original and the new value.
00052         *
00053         * @param vManipulator       the ValueManipulator; could be null
00054         * @param vNumFactor         the Number representing the magnitude and
00055         *                           sign of the increment
00056         * @param fPostFactor  pass  true to return the value as it was
00057         *                           before it was incremented, or pass false
00058         *                           to return the value as it is after it is
00059         *                           incremented
00060         */
00061         NumberMultiplier(ValueManipulator::View vManipulator,
00062                 Number::View vNumFactor, bool fPostFactor);
00063 
00064 
00065     // ----- InvocableMap::EntryProcessor interface -------------------------
00066 
00067     public:
00068         /**
00069         * {@inheritDoc}
00070         */
00071         virtual Object::Holder process(InvocableMap::Entry::Handle hEntry) const;
00072 
00073 
00074     // ----- PortableObject interface ---------------------------------------
00075 
00076     public:
00077         /**
00078         * {@inheritDoc}
00079         */
00080         virtual void readExternal(PofReader::Handle hIn);
00081 
00082         /**
00083         * {@inheritDoc}
00084         */
00085         virtual void writeExternal(PofWriter::Handle hOut) const;
00086 
00087 
00088     // ----- Describable interface ------------------------------------------
00089 
00090     public:
00091         /**
00092         * {@inheritDoc}
00093         */
00094         virtual String::View getDescription() const;
00095 
00096 
00097     // ----- data members ---------------------------------------------------
00098 
00099     protected:
00100         /**
00101         * The number to multiply by.
00102         */
00103         FinalView<Number> f_vNumFactor;
00104 
00105         /**
00106         * Whether to return the value before it was multiplied
00107         * ("post-factor") or after it is multiplied ("pre-factor").
00108         */
00109         bool m_fPostFactor;
00110     };
00111 
00112 COH_CLOSE_NAMESPACE3
00113 
00114 #endif // COH_NUMBER_MULTIPLIER_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.