Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(415)

Side by Side Diff: runtime/bin/vmservice/client/lib/src/observatory/isolate_manager.dart

Issue 185413015: Update the navbar in the observatory (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: new js Created 6 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2013, 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 part of observatory; 5 part of observatory;
6 6
7 /// Collection of isolates which are running in the VM. Updated 7 /// Collection of isolates which are running in the VM. Updated
8 class IsolateManager extends Observable { 8 class IsolateManager extends Observable {
9 ObservatoryApplication _application; 9 ObservatoryApplication _application;
10 ObservatoryApplication get application => _application; 10 ObservatoryApplication get application => _application;
(...skipping 11 matching lines...) Expand all
22 _updateIsolates(response['members']); 22 _updateIsolates(response['members']);
23 } 23 }
24 }); 24 });
25 } 25 }
26 26
27 Isolate getIsolate(String id) { 27 Isolate getIsolate(String id) {
28 Isolate isolate = isolates[id]; 28 Isolate isolate = isolates[id];
29 if (isolate == null) { 29 if (isolate == null) {
30 isolate = new Isolate.fromId(id); 30 isolate = new Isolate.fromId(id);
31 isolates[id] = isolate; 31 isolates[id] = isolate;
32 return isolate; 32 }
33 if (isolate.vmName == null) {
34 // First time we are using this isolate.
35 isolate.refresh();
33 } 36 }
34 return isolate; 37 return isolate;
35 } 38 }
36 39
37 void _updateIsolates(List<Map> members) { 40 void _updateIsolates(List<Map> members) {
38 // Find dead isolates. 41 // Find dead isolates.
39 var deadIsolates = []; 42 var deadIsolates = [];
40 isolates.forEach((k, v) { 43 isolates.forEach((k, v) {
41 if (!_foundIsolateInMembers(k, members)) { 44 if (!_foundIsolateInMembers(k, members)) {
42 deadIsolates.add(k); 45 deadIsolates.add(k);
43 } 46 }
44 }); 47 });
45 // Remove them. 48 // Remove them.
46 deadIsolates.forEach((id) { 49 deadIsolates.forEach((id) {
47 isolates.remove(id); 50 isolates.remove(id);
48 }); 51 });
49 // Add new isolates. 52 // Add new isolates.
50 members.forEach((map) { 53 members.forEach((map) {
51 var id = map['id']; 54 var id = map['id'];
52 var isolate = isolates[id]; 55 var isolate = isolates[id];
53 if (isolate == null) { 56 if (isolate == null) {
54 isolate = new Isolate.fromMap(map); 57 isolate = new Isolate.fromMap(map);
55 isolates[id] = isolate; 58 isolates[id] = isolate;
56 } 59 }
57 isolate.refresh(); 60 isolate.refresh();
58 }); 61 });
59 } 62 }
60 } 63 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698