|
1 | | -#include <msgpack.hpp> |
2 | 1 | #include "subscriber.h" |
3 | 2 | #include "rbevents.h" |
4 | | -#include "mpparser.h" |
5 | | - |
6 | | - |
7 | | -static QVariantList parseMsgpackObjectArray(const msgpack::object_array&); |
8 | | -static QVariantMap parseMsgpackObjectMap(const msgpack::object_map&); |
9 | | -static QList<RBKit::EventPtr> parseEventCollection(const QVariantList&); |
10 | | - |
11 | | - |
12 | | -static QVariant parseMsgpackObject(const msgpack::object& obj) |
13 | | -{ |
14 | | - switch (obj.type) { |
15 | | - case msgpack::type::ARRAY : |
16 | | - return QVariant(parseMsgpackObjectArray(obj.via.array)); |
17 | | - case msgpack::type::MAP : |
18 | | - return QVariant(parseMsgpackObjectMap(obj.via.map)); |
19 | | - |
20 | | - case msgpack::type::RAW : |
21 | | - return QVariant(RBKit::StringUtil::rawToQString(obj)); |
22 | | - case msgpack::type::DOUBLE : |
23 | | - return QVariant(obj.via.dec); |
24 | | - case msgpack::type::POSITIVE_INTEGER : |
25 | | - return QVariant((unsigned long long int)(obj.via.u64)); |
26 | | - case msgpack::type::NIL : |
27 | | - return QVariant(""); |
28 | | - |
29 | | - default: |
30 | | - qDebug() << "throwing error while parsing event" << obj.type; |
31 | | - throw "unknown object type"; |
32 | | - } |
33 | | -} |
34 | | - |
35 | | -// NOTE: This can be improved with the version that hemant is writing for GCStats. |
36 | | -static QVariantMap parseMsgpackObjectMap(const msgpack::object_map& obj) |
37 | | -{ |
38 | | - QVariantMap map; |
39 | | - |
40 | | - msgpack::object_kv* list = obj.ptr; |
41 | | - for (uint32_t iter = 0; iter != obj.size; ++iter) { |
42 | | - msgpack::object key = list->key; |
43 | | - msgpack::object val = list->val; |
44 | | - |
45 | | - // qDebug() << key.type << val.type; |
46 | | - |
47 | | - QString keyStr = RBKit::StringUtil::rawToQString(key); |
48 | | - map[keyStr] = parseMsgpackObject(val); |
49 | | - |
50 | | - ++list; |
51 | | - } |
52 | | - |
53 | | - return map; |
54 | | -} |
55 | | - |
56 | | -RBKit::EventDataBase* RBKit::makeEventFromQVariantMap(const QVariantMap &map) { |
57 | | - QDateTime timestamp = QDateTime::fromMSecsSinceEpoch(map["timestamp"].toULongLong()); |
58 | | - auto eventType = static_cast<RBKit::EventType>( map["event_type"].toInt() ); |
59 | | - |
60 | | - RBKit::EventDataBase* event(nullptr); |
61 | | - switch (eventType) { |
62 | | - case RBKit::EtObjCreated: |
63 | | - { |
64 | | - auto object = RBKit::payloadToObject(map["payload"].toMap()); |
65 | | - event = new RBKit::EvtNewObject(timestamp, eventType, object); |
66 | | - } |
67 | | - break; |
68 | | - |
69 | | - case RBKit::EtObjDestroyed: |
70 | | - // event = new RBKit::EvtDelObject(timestamp, eventType, map["payload"].toMap()); |
71 | | - break; |
72 | | - |
73 | | - case RBKit::EtGcStats: |
74 | | - event = new RBKit::EvtGcStats(timestamp, eventType, map["payload"].toMap()); |
75 | | - break; |
76 | | - |
77 | | - case RBKit::EtGcStart: |
78 | | - event = new RBKit::EvtGcStart(timestamp, eventType); |
79 | | - break; |
80 | | - |
81 | | - case RBKit::EtGcStartM: |
82 | | - event = new RBKit::EvtGcStartM(timestamp, eventType); |
83 | | - break; |
84 | | - |
85 | | - case RBKit::EtGcEndS: |
86 | | - event = new RBKit::EvtGcStop(timestamp, eventType); |
87 | | - break; |
88 | | - |
89 | | - case RBKit::EtObjectSpaceDump: |
90 | | - { |
91 | | - auto objects = RBKit::payloadToObjects(map["payload"].toList()); |
92 | | - event = new RBKit::EvtObjectDump(timestamp, eventType, objects); |
93 | | - } |
94 | | - break; |
95 | | - |
96 | | - case RBKit::EtEventCollection: |
97 | | - { |
98 | | - auto events = parseEventCollection(map["payload"].toList()); |
99 | | - event = new RBKit::EvtCollection(timestamp, eventType, events); |
100 | | - } |
101 | | - break; |
102 | | - |
103 | | - default: |
104 | | - qDebug() << "Unable to parse event of type: " << eventType; |
105 | | - } |
106 | | - |
107 | | - return event; |
108 | | -} |
109 | | - |
110 | | - |
111 | | -static QVariantList parseMsgpackObjectArray(const msgpack::object_array& array) |
112 | | -{ |
113 | | - QVariantList objList; |
114 | | - |
115 | | - for (uint32_t iter = 0; iter != array.size; ++iter) { |
116 | | - objList.append(parseMsgpackObject(array.ptr[iter])); |
117 | | - } |
118 | | - |
119 | | - return objList; |
120 | | -} |
121 | | - |
122 | | - |
123 | | -RBKit::EventDataBase* RBKit::parseEvent(const QByteArray& message) |
124 | | -{ |
125 | | - msgpack::unpacked unpackedMessage; |
126 | | - msgpack::unpack(&unpackedMessage, message.data(), message.size()); |
127 | | - |
128 | | - msgpack::object_map obj = unpackedMessage.get().via.map; |
129 | | - |
130 | | - QVariantMap map = parseMsgpackObjectMap(obj); |
131 | | - return makeEventFromQVariantMap(map); |
132 | | -} |
133 | | - |
134 | | -static QList<RBKit::EventPtr> parseEventCollection(const QVariantList& list) |
135 | | -{ |
136 | | - QList<RBKit::EventPtr> events; |
137 | | - |
138 | | - for (auto& eventMap : list) { |
139 | | - auto event = RBKit::makeEventFromQVariantMap(eventMap.toMap()); |
140 | | - events.append(RBKit::EventPtr(event)); |
141 | | - } |
142 | | - |
143 | | - return events; |
144 | | -} |
145 | 3 |
|
146 | 4 |
|
147 | 5 | // ============================== different events ============================== |
@@ -231,9 +89,11 @@ void RBKit::EvtObjectDump::process(Subscriber& processor) const |
231 | 89 | } |
232 | 90 |
|
233 | 91 | RBKit::EvtCollection::EvtCollection(QDateTime ts, RBKit::EventType eventType, |
234 | | - QList<RBKit::EventPtr> _events) |
| 92 | + QList<RBKit::EventPtr> _events, |
| 93 | + quint64 _counter) |
235 | 94 | : EventDataBase(ts, eventType) |
236 | 95 | , events(_events) |
| 96 | + , messageCounter(_counter) |
237 | 97 | {} |
238 | 98 |
|
239 | 99 | void RBKit::EvtCollection::process(Subscriber& processor) const |
|
0 commit comments