00001
00002
00003
00004
00005
00006
00007 #ifndef COH_PRIORITY_AGGREGATOR_HPP
00008 #define COH_PRIORITY_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/net/AbstractPriorityTask.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::net::AbstractPriorityTask;
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043
00044
00045
00046
00047
00048 class COH_EXPORT PriorityAggregator
00049 : public class_spec<PriorityAggregator,
00050 extends<AbstractPriorityTask>,
00051 implements<InvocableMap::ParallelAwareAggregator> >
00052 {
00053 friend class factory<PriorityAggregator>;
00054
00055
00056
00057 protected:
00058
00059
00060
00061 PriorityAggregator();
00062
00063
00064
00065
00066
00067
00068
00069 PriorityAggregator(
00070 InvocableMap::ParallelAwareAggregator::Handle hAggregator);
00071
00072
00073
00074
00075 public:
00076
00077
00078
00079 virtual Object::Holder aggregate(Set::View vSetEntries);
00080
00081
00082
00083
00084 virtual InvocableMap::EntryAggregator::Handle
00085 getParallelAggregator();
00086
00087
00088
00089
00090 virtual Object::Holder aggregateResults(
00091 Collection::View vCollResults);
00092
00093
00094
00095
00096 public:
00097
00098
00099
00100 virtual void readExternal(PofReader::Handle hIn);
00101
00102
00103
00104
00105 virtual void writeExternal(PofWriter::Handle hOut) const;
00106
00107
00108
00109
00110 public:
00111
00112
00113
00114 virtual TypedHandle<const String> toString() const;
00115
00116
00117
00118
00119 public:
00120
00121
00122
00123
00124
00125 virtual InvocableMap::ParallelAwareAggregator::Handle
00126 getAggregator();
00127
00128
00129
00130
00131
00132
00133 virtual InvocableMap::ParallelAwareAggregator::View
00134 getAggregator() const;
00135
00136
00137
00138
00139 private:
00140
00141
00142
00143 FinalHandle<InvocableMap::ParallelAwareAggregator> f_hAggregator;
00144 };
00145
00146 COH_CLOSE_NAMESPACE3
00147
00148 #endif // COH_PRIORITY_AGGREGATOR_HPP