blob: e8b7c096452a85de5d48a022fd6d37f0fcb569b9 [file] [log] [blame]
Chris Lattner30fdc8d2010-06-08 16:52:24 +00001//===-- Event.cpp -----------------------------------------------*- C++ -*-===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10// C Includes
11// C++ Includes
Eugene Zelenkoa74f37a2016-03-10 23:57:12 +000012#include <algorithm>
13
Chris Lattner30fdc8d2010-06-08 16:52:24 +000014// Other libraries and framework includes
15// Project includes
Chris Lattner30fdc8d2010-06-08 16:52:24 +000016#include "lldb/Core/Broadcaster.h"
Zachary Turner29cb8682017-03-03 20:57:05 +000017#include "lldb/Core/DumpDataExtractor.h"
Kate Stoneb9c1b512016-09-06 20:57:50 +000018#include "lldb/Core/Event.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000019#include "lldb/Core/State.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000020#include "lldb/Target/Process.h"
Zachary Turner666cc0b2017-03-04 01:30:05 +000021#include "lldb/Utility/DataExtractor.h"
Zachary Turner01c32432017-02-14 19:06:07 +000022#include "lldb/Utility/Endian.h"
Zachary Turner6f9e6902017-03-03 20:56:28 +000023#include "lldb/Utility/Log.h"
Zachary Turnerbf9a7732017-02-02 21:39:50 +000024#include "lldb/Utility/Stream.h"
Chris Lattner30fdc8d2010-06-08 16:52:24 +000025
26using namespace lldb;
27using namespace lldb_private;
28
Todd Fiala75930012016-08-19 04:21:48 +000029#pragma mark -
30#pragma mark Event
31
32//------------------------------------------------------------------
33// Event functions
34//------------------------------------------------------------------
35
Kate Stoneb9c1b512016-09-06 20:57:50 +000036Event::Event(Broadcaster *broadcaster, uint32_t event_type, EventData *data)
37 : m_broadcaster_wp(broadcaster->GetBroadcasterImpl()), m_type(event_type),
38 m_data_sp(data) {}
Greg Clayton1e20f022016-05-12 22:58:52 +000039
Kate Stoneb9c1b512016-09-06 20:57:50 +000040Event::Event(Broadcaster *broadcaster, uint32_t event_type,
41 const EventDataSP &event_data_sp)
42 : m_broadcaster_wp(broadcaster->GetBroadcasterImpl()), m_type(event_type),
43 m_data_sp(event_data_sp) {}
Chris Lattner30fdc8d2010-06-08 16:52:24 +000044
Kate Stoneb9c1b512016-09-06 20:57:50 +000045Event::Event(uint32_t event_type, EventData *data)
46 : m_broadcaster_wp(), m_type(event_type), m_data_sp(data) {}
Greg Clayton1e20f022016-05-12 22:58:52 +000047
Kate Stoneb9c1b512016-09-06 20:57:50 +000048Event::Event(uint32_t event_type, const EventDataSP &event_data_sp)
49 : m_broadcaster_wp(), m_type(event_type), m_data_sp(event_data_sp) {}
Chris Lattner30fdc8d2010-06-08 16:52:24 +000050
Eugene Zelenkoa74f37a2016-03-10 23:57:12 +000051Event::~Event() = default;
Chris Lattner30fdc8d2010-06-08 16:52:24 +000052
Kate Stoneb9c1b512016-09-06 20:57:50 +000053void Event::Dump(Stream *s) const {
54 Broadcaster *broadcaster;
55 Broadcaster::BroadcasterImplSP broadcaster_impl_sp(m_broadcaster_wp.lock());
56 if (broadcaster_impl_sp)
57 broadcaster = broadcaster_impl_sp->GetBroadcaster();
58 else
59 broadcaster = nullptr;
Chris Lattner30fdc8d2010-06-08 16:52:24 +000060
Kate Stoneb9c1b512016-09-06 20:57:50 +000061 if (broadcaster) {
62 StreamString event_name;
63 if (broadcaster->GetEventNames(event_name, m_type, false))
64 s->Printf("%p Event: broadcaster = %p (%s), type = 0x%8.8x (%s), data = ",
65 static_cast<const void *>(this),
66 static_cast<void *>(broadcaster),
67 broadcaster->GetBroadcasterName().GetCString(), m_type,
Zachary Turnerc1564272016-11-16 21:15:24 +000068 event_name.GetData());
Eugene Zelenkoa74f37a2016-03-10 23:57:12 +000069 else
Kate Stoneb9c1b512016-09-06 20:57:50 +000070 s->Printf("%p Event: broadcaster = %p (%s), type = 0x%8.8x, data = ",
71 static_cast<const void *>(this),
72 static_cast<void *>(broadcaster),
73 broadcaster->GetBroadcasterName().GetCString(), m_type);
74 } else
75 s->Printf("%p Event: broadcaster = NULL, type = 0x%8.8x, data = ",
76 static_cast<const void *>(this), m_type);
77
78 if (m_data_sp) {
79 s->PutChar('{');
80 m_data_sp->Dump(s);
81 s->PutChar('}');
82 } else
83 s->Printf("<NULL>");
Chris Lattner30fdc8d2010-06-08 16:52:24 +000084}
85
Kate Stoneb9c1b512016-09-06 20:57:50 +000086void Event::DoOnRemoval() {
87 if (m_data_sp)
88 m_data_sp->DoOnRemoval(this);
Chris Lattner30fdc8d2010-06-08 16:52:24 +000089}
90
Todd Fiala75930012016-08-19 04:21:48 +000091#pragma mark -
92#pragma mark EventData
93
94//------------------------------------------------------------------
95// EventData functions
96//------------------------------------------------------------------
97
Eugene Zelenkoa74f37a2016-03-10 23:57:12 +000098EventData::EventData() = default;
Chris Lattner30fdc8d2010-06-08 16:52:24 +000099
Eugene Zelenkoa74f37a2016-03-10 23:57:12 +0000100EventData::~EventData() = default;
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000101
Kate Stoneb9c1b512016-09-06 20:57:50 +0000102void EventData::Dump(Stream *s) const { s->PutCString("Generic Event Data"); }
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000103
Todd Fiala75930012016-08-19 04:21:48 +0000104#pragma mark -
105#pragma mark EventDataBytes
106
107//------------------------------------------------------------------
108// EventDataBytes functions
109//------------------------------------------------------------------
110
Kate Stoneb9c1b512016-09-06 20:57:50 +0000111EventDataBytes::EventDataBytes() : m_bytes() {}
Todd Fiala75930012016-08-19 04:21:48 +0000112
Kate Stoneb9c1b512016-09-06 20:57:50 +0000113EventDataBytes::EventDataBytes(const char *cstr) : m_bytes() {
114 SetBytesFromCString(cstr);
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000115}
116
Zachary Turner514d8cd2016-09-23 18:06:53 +0000117EventDataBytes::EventDataBytes(llvm::StringRef str) : m_bytes() {
118 SetBytes(str.data(), str.size());
119}
120
Kate Stoneb9c1b512016-09-06 20:57:50 +0000121EventDataBytes::EventDataBytes(const void *src, size_t src_len) : m_bytes() {
122 SetBytes(src, src_len);
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000123}
124
Eugene Zelenkoa74f37a2016-03-10 23:57:12 +0000125EventDataBytes::~EventDataBytes() = default;
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000126
Kate Stoneb9c1b512016-09-06 20:57:50 +0000127const ConstString &EventDataBytes::GetFlavorString() {
128 static ConstString g_flavor("EventDataBytes");
129 return g_flavor;
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000130}
131
Kate Stoneb9c1b512016-09-06 20:57:50 +0000132const ConstString &EventDataBytes::GetFlavor() const {
133 return EventDataBytes::GetFlavorString();
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000134}
135
Kate Stoneb9c1b512016-09-06 20:57:50 +0000136void EventDataBytes::Dump(Stream *s) const {
137 size_t num_printable_chars =
138 std::count_if(m_bytes.begin(), m_bytes.end(), isprint);
139 if (num_printable_chars == m_bytes.size()) {
140 s->Printf("\"%s\"", m_bytes.c_str());
141 } else if (!m_bytes.empty()) {
142 DataExtractor data;
143 data.SetData(m_bytes.data(), m_bytes.size(), endian::InlHostByteOrder());
Zachary Turner29cb8682017-03-03 20:57:05 +0000144 DumpDataExtractor(data, s, 0, eFormatBytes, 1, m_bytes.size(), 32,
145 LLDB_INVALID_ADDRESS, 0, 0);
Kate Stoneb9c1b512016-09-06 20:57:50 +0000146 }
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000147}
148
Kate Stoneb9c1b512016-09-06 20:57:50 +0000149const void *EventDataBytes::GetBytes() const {
150 return (m_bytes.empty() ? nullptr : m_bytes.data());
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000151}
152
Kate Stoneb9c1b512016-09-06 20:57:50 +0000153size_t EventDataBytes::GetByteSize() const { return m_bytes.size(); }
154
155void EventDataBytes::SetBytes(const void *src, size_t src_len) {
156 if (src != nullptr && src_len > 0)
157 m_bytes.assign((const char *)src, src_len);
158 else
159 m_bytes.clear();
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000160}
161
Kate Stoneb9c1b512016-09-06 20:57:50 +0000162void EventDataBytes::SetBytesFromCString(const char *cstr) {
163 if (cstr != nullptr && cstr[0])
164 m_bytes.assign(cstr);
165 else
166 m_bytes.clear();
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000167}
168
Kate Stoneb9c1b512016-09-06 20:57:50 +0000169const void *EventDataBytes::GetBytesFromEvent(const Event *event_ptr) {
170 const EventDataBytes *e = GetEventDataFromEvent(event_ptr);
171 if (e != nullptr)
172 return e->GetBytes();
173 return nullptr;
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000174}
175
Kate Stoneb9c1b512016-09-06 20:57:50 +0000176size_t EventDataBytes::GetByteSizeFromEvent(const Event *event_ptr) {
177 const EventDataBytes *e = GetEventDataFromEvent(event_ptr);
178 if (e != nullptr)
179 return e->GetByteSize();
180 return 0;
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000181}
182
183const EventDataBytes *
Kate Stoneb9c1b512016-09-06 20:57:50 +0000184EventDataBytes::GetEventDataFromEvent(const Event *event_ptr) {
185 if (event_ptr != nullptr) {
186 const EventData *event_data = event_ptr->GetData();
187 if (event_data &&
188 event_data->GetFlavor() == EventDataBytes::GetFlavorString())
189 return static_cast<const EventDataBytes *>(event_data);
190 }
191 return nullptr;
Chris Lattner30fdc8d2010-06-08 16:52:24 +0000192}
193
Kate Stoneb9c1b512016-09-06 20:57:50 +0000194void EventDataBytes::SwapBytes(std::string &new_bytes) {
195 m_bytes.swap(new_bytes);
Caroline Tice969ed3d2011-05-02 20:41:46 +0000196}
Todd Fiala75930012016-08-19 04:21:48 +0000197
198#pragma mark -
199#pragma mark EventStructuredData
200
201//------------------------------------------------------------------
202// EventDataStructuredData definitions
203//------------------------------------------------------------------
204
Kate Stoneb9c1b512016-09-06 20:57:50 +0000205EventDataStructuredData::EventDataStructuredData()
206 : EventData(), m_process_sp(), m_object_sp(), m_plugin_sp() {}
Todd Fiala75930012016-08-19 04:21:48 +0000207
Kate Stoneb9c1b512016-09-06 20:57:50 +0000208EventDataStructuredData::EventDataStructuredData(
209 const ProcessSP &process_sp, const StructuredData::ObjectSP &object_sp,
210 const lldb::StructuredDataPluginSP &plugin_sp)
211 : EventData(), m_process_sp(process_sp), m_object_sp(object_sp),
212 m_plugin_sp(plugin_sp) {}
Todd Fiala75930012016-08-19 04:21:48 +0000213
Kate Stoneb9c1b512016-09-06 20:57:50 +0000214EventDataStructuredData::~EventDataStructuredData() {}
Todd Fiala75930012016-08-19 04:21:48 +0000215
216//------------------------------------------------------------------
217// EventDataStructuredData member functions
218//------------------------------------------------------------------
219
Kate Stoneb9c1b512016-09-06 20:57:50 +0000220const ConstString &EventDataStructuredData::GetFlavor() const {
221 return EventDataStructuredData::GetFlavorString();
Todd Fiala75930012016-08-19 04:21:48 +0000222}
223
Kate Stoneb9c1b512016-09-06 20:57:50 +0000224void EventDataStructuredData::Dump(Stream *s) const {
225 if (!s)
226 return;
Todd Fiala75930012016-08-19 04:21:48 +0000227
Kate Stoneb9c1b512016-09-06 20:57:50 +0000228 if (m_object_sp)
229 m_object_sp->Dump(*s);
Todd Fiala75930012016-08-19 04:21:48 +0000230}
231
Kate Stoneb9c1b512016-09-06 20:57:50 +0000232const ProcessSP &EventDataStructuredData::GetProcess() const {
233 return m_process_sp;
Todd Fiala75930012016-08-19 04:21:48 +0000234}
235
Kate Stoneb9c1b512016-09-06 20:57:50 +0000236const StructuredData::ObjectSP &EventDataStructuredData::GetObject() const {
237 return m_object_sp;
Todd Fiala75930012016-08-19 04:21:48 +0000238}
239
Kate Stoneb9c1b512016-09-06 20:57:50 +0000240const lldb::StructuredDataPluginSP &
241EventDataStructuredData::GetStructuredDataPlugin() const {
242 return m_plugin_sp;
Todd Fiala75930012016-08-19 04:21:48 +0000243}
244
Kate Stoneb9c1b512016-09-06 20:57:50 +0000245void EventDataStructuredData::SetProcess(const ProcessSP &process_sp) {
246 m_process_sp = process_sp;
Todd Fiala75930012016-08-19 04:21:48 +0000247}
248
Kate Stoneb9c1b512016-09-06 20:57:50 +0000249void EventDataStructuredData::SetObject(
250 const StructuredData::ObjectSP &object_sp) {
251 m_object_sp = object_sp;
Todd Fiala75930012016-08-19 04:21:48 +0000252}
253
Kate Stoneb9c1b512016-09-06 20:57:50 +0000254void EventDataStructuredData::SetStructuredDataPlugin(
255 const lldb::StructuredDataPluginSP &plugin_sp) {
256 m_plugin_sp = plugin_sp;
Todd Fiala75930012016-08-19 04:21:48 +0000257}
258
259//------------------------------------------------------------------
260// EventDataStructuredData static functions
261//------------------------------------------------------------------
262
Kate Stoneb9c1b512016-09-06 20:57:50 +0000263const EventDataStructuredData *
264EventDataStructuredData::GetEventDataFromEvent(const Event *event_ptr) {
265 if (event_ptr == nullptr)
266 return nullptr;
Todd Fiala75930012016-08-19 04:21:48 +0000267
Kate Stoneb9c1b512016-09-06 20:57:50 +0000268 const EventData *event_data = event_ptr->GetData();
269 if (!event_data ||
270 event_data->GetFlavor() != EventDataStructuredData::GetFlavorString())
271 return nullptr;
Todd Fiala75930012016-08-19 04:21:48 +0000272
Kate Stoneb9c1b512016-09-06 20:57:50 +0000273 return static_cast<const EventDataStructuredData *>(event_data);
Todd Fiala75930012016-08-19 04:21:48 +0000274}
275
Kate Stoneb9c1b512016-09-06 20:57:50 +0000276ProcessSP EventDataStructuredData::GetProcessFromEvent(const Event *event_ptr) {
277 auto event_data = EventDataStructuredData::GetEventDataFromEvent(event_ptr);
278 if (event_data)
279 return event_data->GetProcess();
280 else
281 return ProcessSP();
Todd Fiala75930012016-08-19 04:21:48 +0000282}
283
284StructuredData::ObjectSP
Kate Stoneb9c1b512016-09-06 20:57:50 +0000285EventDataStructuredData::GetObjectFromEvent(const Event *event_ptr) {
286 auto event_data = EventDataStructuredData::GetEventDataFromEvent(event_ptr);
287 if (event_data)
288 return event_data->GetObject();
289 else
290 return StructuredData::ObjectSP();
Todd Fiala75930012016-08-19 04:21:48 +0000291}
292
293lldb::StructuredDataPluginSP
Kate Stoneb9c1b512016-09-06 20:57:50 +0000294EventDataStructuredData::GetPluginFromEvent(const Event *event_ptr) {
295 auto event_data = EventDataStructuredData::GetEventDataFromEvent(event_ptr);
296 if (event_data)
297 return event_data->GetStructuredDataPlugin();
298 else
299 return StructuredDataPluginSP();
Todd Fiala75930012016-08-19 04:21:48 +0000300}
301
Kate Stoneb9c1b512016-09-06 20:57:50 +0000302const ConstString &EventDataStructuredData::GetFlavorString() {
303 static ConstString s_flavor("EventDataStructuredData");
304 return s_flavor;
Todd Fiala75930012016-08-19 04:21:48 +0000305}