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

Unified Diff: runtime/observatory/lib/src/elements/isolate_ref_wrapper.dart

Issue 2211603002: Centralized event streams (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: Updated observatory_sources Created 4 years, 4 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 side-by-side diff with in-line comments
Download patch
Index: runtime/observatory/lib/src/elements/isolate_ref_wrapper.dart
diff --git a/runtime/observatory/lib/src/elements/isolate_ref_wrapper.dart b/runtime/observatory/lib/src/elements/isolate_ref_wrapper.dart
index 369e68ae431694452aae83f388b9fc407e48be90..73895093580ee37bf51360dfd5fe10bf707c487f 100644
--- a/runtime/observatory/lib/src/elements/isolate_ref_wrapper.dart
+++ b/runtime/observatory/lib/src/elements/isolate_ref_wrapper.dart
@@ -3,11 +3,8 @@
// BSD-style license that can be found in the LICENSE file.
import 'dart:html';
-import 'dart:async';
import 'package:observatory/app.dart';
-import 'package:observatory/models.dart' show IsolateUpdateEvent;
-import 'package:observatory/mocks.dart' show IsolateUpdateEventMock;
import 'package:observatory/service_html.dart' show Isolate;
import 'package:observatory/src/elements/isolate_ref.dart';
import 'package:observatory/src/elements/helpers/tag.dart';
@@ -22,17 +19,13 @@ class IsolateRefElementWrapper extends HtmlElement {
static const tag = const Tag<IsolateRefElementWrapper>('isolate-ref');
- final StreamController<IsolateUpdateEvent> _updatesController =
- new StreamController<IsolateUpdateEvent>();
- Stream<IsolateUpdateEvent> _updates;
- StreamSubscription _subscription;
-
Isolate _isolate;
+
Isolate get ref => _isolate;
- void set ref(Isolate ref) { _isolate = ref; _detached(); _attached(); }
+
+ void set ref(Isolate ref) { _isolate = ref; render(); }
IsolateRefElementWrapper.created() : super.created() {
- _updates = _updatesController.stream.asBroadcastStream();
binder.registerCallback(this);
createShadowRoot();
render();
@@ -41,31 +34,9 @@ class IsolateRefElementWrapper extends HtmlElement {
@override
void attached() {
super.attached();
- _attached();
- }
-
- void _attached() {
- if (ref != null) {
- _subscription = ref.changes.listen((_) {
- _updatesController.add(new IsolateUpdateEventMock(isolate: ref));
- });
- }
render();
}
- @override
- void detached() {
- super.detached();
- _detached();
- }
-
- void _detached() {
- if (_subscription != null) {
- _subscription.cancel();
- _subscription = null;
- }
- }
-
void render() {
shadowRoot.children = [];
if (ref == null) return;
@@ -80,8 +51,9 @@ class IsolateRefElementWrapper extends HtmlElement {
color: #0489c3;
text-decoration: none;
}''',
- new IsolateRefElement(_isolate, _updates,
- queue: ObservatoryApplication.app.queue)
+ new IsolateRefElement(_isolate, app.events, queue: app.queue)
];
}
+
+ ObservatoryApplication get app => ObservatoryApplication.app;
}

Powered by Google App Engine
This is Rietveld 408576698