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

F79659-03

coherence/util/aggregator/CompositeAggregator.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_COMPOSITE_AGGREGATOR_HPP
00008 #define COH_COMPOSITE_AGGREGATOR_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 
00017 COH_OPEN_NAMESPACE3(coherence,util,aggregator)
00018 
00019 using coherence::io::pof::PofReader;
00020 using coherence::io::pof::PofWriter;
00021 using coherence::io::pof::PortableObject;
00022 
00023 
00024 /**
00025 * CompositeAggregator provides an ability to execute a collection of
00026 * aggregators against the same subset of the entries in an InvocableMap,
00027 * resulting in a list of corresponding aggregation results. The size of the
00028 * returned list will always be equal to the length of the aggregators' array.
00029 *
00030 * @author djl  2008.05.16
00031 */
00032 class COH_EXPORT CompositeAggregator
00033     : public class_spec<CompositeAggregator,
00034         extends<Object>,
00035         implements<PortableObject, InvocableMap::EntryAggregator> >
00036     {
00037     friend class factory<CompositeAggregator>;
00038 
00039     // ----- factory methods ------------------------------------------------
00040 
00041     public:
00042          /**
00043          * Default constructor (necessary for the PortableObject interface).
00044          */
00045          static CompositeAggregator::Handle create();
00046 
00047          /**
00048          * Create an instance of CompositeAggregator based on a specified
00049          * array of coherence::util::InvocableMap::EntryAggregator.
00050          *
00051          * @param vaAggregator  an array of EntryAggregator objects; must
00052          *                      contain not less than two aggregators
00053          */
00054          static CompositeAggregator::Handle create(
00055                  ObjectArray::View vaAggregator);
00056 
00057 
00058     // ----- constructors ---------------------------------------------------
00059 
00060     protected:
00061         /**
00062         * @internal
00063         */
00064         CompositeAggregator();
00065 
00066         /**
00067         * @internal
00068         */
00069         CompositeAggregator(ObjectArray::View vaAggregator);
00070 
00071     private:
00072         /**
00073         * Blocked copy constructor.
00074         */
00075         CompositeAggregator(const CompositeAggregator&);
00076 
00077 
00078     // ----- InvocableMap::EntryAggregator interface ------------------------
00079 
00080     public:
00081         /**
00082         * {@inheritDoc}
00083         */
00084         virtual Object::Holder aggregate(Set::View vSetEntries);
00085 
00086 
00087     // ----- PortableObject interface ---------------------------------------
00088 
00089     public:
00090         /**
00091         * {@inheritDoc}
00092         */
00093         virtual void readExternal(PofReader::Handle hIn);
00094 
00095         /**
00096         * {@inheritDoc}
00097         */
00098         virtual void writeExternal(PofWriter::Handle hOut) const;
00099 
00100 
00101     // ----- Object interface -----------------------------------------------
00102 
00103     public:
00104         /**
00105         * {@inheritDoc}
00106         */
00107         virtual bool equals(Object::View v) const;
00108 
00109         /**
00110         * {@inheritDoc}
00111         */
00112         virtual size32_t hashCode() const;
00113 
00114         /**
00115         * {@inheritDoc}
00116         */
00117         virtual TypedHandle<const String> toString() const;
00118 
00119 
00120     // ----- data member accessors ------------------------------------------
00121 
00122     public:
00123         /**
00124         * Determine the ValueExtractor whose values this aggregator is
00125         * aggregating.
00126         *
00127         * @return the ValueExtractor used by this aggregator
00128         */
00129         virtual ObjectArray::View getAggregators() const;
00130 
00131 
00132     // ----- data members ---------------------------------------------------
00133 
00134     protected:
00135         /**
00136         * The underlying EntryAggregator array.
00137         */
00138         FinalView<ObjectArray> f_vaAggregator;
00139     };
00140 
00141 COH_CLOSE_NAMESPACE3
00142 
00143 #endif // COH_COMPOSITE_AGGREGATOR_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.