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