OLD | NEW |
1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2015, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 #include "vm/service_event.h" | 5 #include "vm/service_event.h" |
6 | 6 |
7 #include "vm/message_handler.h" | 7 #include "vm/message_handler.h" |
8 | 8 |
9 namespace dart { | 9 namespace dart { |
10 | 10 |
(...skipping 27 matching lines...) Expand all Loading... |
38 ServiceEvent::ServiceEvent(Isolate* isolate, EventKind event_kind) | 38 ServiceEvent::ServiceEvent(Isolate* isolate, EventKind event_kind) |
39 : isolate_(isolate), | 39 : isolate_(isolate), |
40 kind_(event_kind), | 40 kind_(event_kind), |
41 embedder_kind_(NULL), | 41 embedder_kind_(NULL), |
42 embedder_stream_id_(NULL), | 42 embedder_stream_id_(NULL), |
43 breakpoint_(NULL), | 43 breakpoint_(NULL), |
44 top_frame_(NULL), | 44 top_frame_(NULL), |
45 timeline_event_block_(NULL), | 45 timeline_event_block_(NULL), |
46 extension_rpc_(NULL), | 46 extension_rpc_(NULL), |
47 exception_(NULL), | 47 exception_(NULL), |
| 48 reload_error_(NULL), |
48 at_async_jump_(false), | 49 at_async_jump_(false), |
49 inspectee_(NULL), | 50 inspectee_(NULL), |
50 gc_stats_(NULL), | 51 gc_stats_(NULL), |
51 bytes_(NULL), | 52 bytes_(NULL), |
52 bytes_length_(0), | 53 bytes_length_(0), |
53 timestamp_(OS::GetCurrentTimeMillis()) { | 54 timestamp_(OS::GetCurrentTimeMillis()) { |
54 if ((event_kind == ServiceEvent::kPauseStart) && | 55 if ((event_kind == ServiceEvent::kPauseStart) && |
55 !isolate->message_handler()->is_paused_on_start()) { | 56 !isolate->message_handler()->is_paused_on_start()) { |
56 // We will pause on start but the message handler lacks a valid | 57 // We will pause on start but the message handler lacks a valid |
57 // paused timestamp because we haven't paused yet. Use the current time. | 58 // paused timestamp because we haven't paused yet. Use the current time. |
(...skipping 47 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
105 case kIsolateStart: | 106 case kIsolateStart: |
106 return "IsolateStart"; | 107 return "IsolateStart"; |
107 case kIsolateRunnable: | 108 case kIsolateRunnable: |
108 return "IsolateRunnable"; | 109 return "IsolateRunnable"; |
109 case kIsolateExit: | 110 case kIsolateExit: |
110 return "IsolateExit"; | 111 return "IsolateExit"; |
111 case kIsolateUpdate: | 112 case kIsolateUpdate: |
112 return "IsolateUpdate"; | 113 return "IsolateUpdate"; |
113 case kServiceExtensionAdded: | 114 case kServiceExtensionAdded: |
114 return "ServiceExtensionAdded"; | 115 return "ServiceExtensionAdded"; |
| 116 case kIsolateReload: |
| 117 return "IsolateReload"; |
115 case kPauseStart: | 118 case kPauseStart: |
116 return "PauseStart"; | 119 return "PauseStart"; |
117 case kPauseExit: | 120 case kPauseExit: |
118 return "PauseExit"; | 121 return "PauseExit"; |
119 case kPauseBreakpoint: | 122 case kPauseBreakpoint: |
120 return "PauseBreakpoint"; | 123 return "PauseBreakpoint"; |
121 case kPauseInterrupted: | 124 case kPauseInterrupted: |
122 return "PauseInterrupted"; | 125 return "PauseInterrupted"; |
123 case kPauseException: | 126 case kPauseException: |
124 return "PauseException"; | 127 return "PauseException"; |
(...skipping 32 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
157 | 160 |
158 const char* ServiceEvent::stream_id() const { | 161 const char* ServiceEvent::stream_id() const { |
159 switch (kind()) { | 162 switch (kind()) { |
160 case kVMUpdate: | 163 case kVMUpdate: |
161 return Service::vm_stream.id(); | 164 return Service::vm_stream.id(); |
162 | 165 |
163 case kIsolateStart: | 166 case kIsolateStart: |
164 case kIsolateRunnable: | 167 case kIsolateRunnable: |
165 case kIsolateExit: | 168 case kIsolateExit: |
166 case kIsolateUpdate: | 169 case kIsolateUpdate: |
| 170 case kIsolateReload: |
167 case kServiceExtensionAdded: | 171 case kServiceExtensionAdded: |
168 return Service::isolate_stream.id(); | 172 return Service::isolate_stream.id(); |
169 | 173 |
170 case kPauseStart: | 174 case kPauseStart: |
171 case kPauseExit: | 175 case kPauseExit: |
172 case kPauseBreakpoint: | 176 case kPauseBreakpoint: |
173 case kPauseInterrupted: | 177 case kPauseInterrupted: |
174 case kPauseException: | 178 case kPauseException: |
175 case kNone: | 179 case kNone: |
176 case kResume: | 180 case kResume: |
(...skipping 22 matching lines...) Expand all Loading... |
199 default: | 203 default: |
200 UNREACHABLE(); | 204 UNREACHABLE(); |
201 return NULL; | 205 return NULL; |
202 } | 206 } |
203 } | 207 } |
204 | 208 |
205 | 209 |
206 void ServiceEvent::PrintJSON(JSONStream* js) const { | 210 void ServiceEvent::PrintJSON(JSONStream* js) const { |
207 JSONObject jsobj(js); | 211 JSONObject jsobj(js); |
208 PrintJSONHeader(&jsobj); | 212 PrintJSONHeader(&jsobj); |
| 213 if (kind() == kIsolateReload) { |
| 214 if (reload_error_ == NULL) { |
| 215 jsobj.AddProperty("status", "success"); |
| 216 } else { |
| 217 jsobj.AddProperty("status", "failure"); |
| 218 jsobj.AddProperty("reloadError", *(reload_error())); |
| 219 } |
| 220 } |
209 if (kind() == kServiceExtensionAdded) { | 221 if (kind() == kServiceExtensionAdded) { |
210 ASSERT(extension_rpc_ != NULL); | 222 ASSERT(extension_rpc_ != NULL); |
211 jsobj.AddProperty("extensionRPC", extension_rpc_->ToCString()); | 223 jsobj.AddProperty("extensionRPC", extension_rpc_->ToCString()); |
212 } | 224 } |
213 if (kind() == kPauseBreakpoint) { | 225 if (kind() == kPauseBreakpoint) { |
214 JSONArray jsarr(&jsobj, "pauseBreakpoints"); | 226 JSONArray jsarr(&jsobj, "pauseBreakpoints"); |
215 // TODO(rmacnak): If we are paused at more than one breakpoint, | 227 // TODO(rmacnak): If we are paused at more than one breakpoint, |
216 // provide it here. | 228 // provide it here. |
217 if (breakpoint() != NULL) { | 229 if (breakpoint() != NULL) { |
218 jsarr.AddValue(breakpoint()); | 230 jsarr.AddValue(breakpoint()); |
(...skipping 65 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
284 } else { | 296 } else { |
285 jsobj->AddProperty("isolate", isolate()); | 297 jsobj->AddProperty("isolate", isolate()); |
286 } | 298 } |
287 ASSERT(timestamp_ != -1); | 299 ASSERT(timestamp_ != -1); |
288 jsobj->AddPropertyTimeMillis("timestamp", timestamp_); | 300 jsobj->AddPropertyTimeMillis("timestamp", timestamp_); |
289 } | 301 } |
290 | 302 |
291 #endif // !PRODUCT | 303 #endif // !PRODUCT |
292 | 304 |
293 } // namespace dart | 305 } // namespace dart |
OLD | NEW |