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

Side by Side Diff: lib/observe.dart

Issue 20863002: Introduce boot.js: this finally makes it possible to load and run Todomvc (Closed) Base URL: git@github.com:dart-lang/web-ui.git@master
Patch Set: Created 7 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 unified diff | Download patch
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 /** 5 /**
6 * Helpers for observable objects. 6 * Helpers for observable objects.
7 * Intended for use with `package:mdv_observe`. 7 * Intended for use with `package:mdv_observe`.
8 */ 8 */
9 library polymer.observe; 9 library polymer.observe;
10 10
11 import 'dart:async'; 11 import 'dart:async';
12 // TODO(jmesserly): PathObserver should be in mdv_observe. 12 // TODO(jmesserly): PathObserver should be in mdv_observe.
13 import 'dart:html' show PathObserver; 13 import 'dart:html' show PathObserver;
14 import 'package:observe/observe.dart'; 14 import 'package:observe/observe.dart';
15 15
16 /**
17 * Use `@observable` to make a property observable.
18 * The overhead will be minimal unless they are actually being observed.
19 */
20 const observable = const _ObservableAnnotation();
21
22 /**
23 * The type of the `@observable` annotation.
24 *
25 * Library private because you should be able to use the [observable] field
26 * to get the one and only instance. We could make it public though, if anyone
27 * needs it for some reason.
28 */
29 class _ObservableAnnotation {
30 const _ObservableAnnotation();
31 }
32
33 // Inspired by ArrayReduction at: 16 // Inspired by ArrayReduction at:
34 // https://raw.github.com/rafaelw/ChangeSummary/master/util/array_reduction.js 17 // https://raw.github.com/rafaelw/ChangeSummary/master/util/array_reduction.js
35 // The main difference is we support anything on the rich Dart Iterable API. 18 // The main difference is we support anything on the rich Dart Iterable API.
36 19
37 const _VALUE = const Symbol('value'); 20 const _VALUE = const Symbol('value');
38 21
39 /** 22 /**
40 * Forwards an observable property from one object to another. For example: 23 * Forwards an observable property from one object to another. For example:
41 * 24 *
42 * class MyModel extends ObservableBase { 25 * class MyModel extends ObservableBase {
(...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after
114 97
115 void _reduce() { 98 void _reduce() {
116 _scheduled = false; 99 _scheduled = false;
117 _value = _observers.map((o) => o.value); 100 _value = _observers.map((o) => o.value);
118 notifyChange(new PropertyChangeRecord(_VALUE)); 101 notifyChange(new PropertyChangeRecord(_VALUE));
119 } 102 }
120 103
121 void _scheduleReduce(_) { 104 void _scheduleReduce(_) {
122 if (_scheduled) return; 105 if (_scheduled) return;
123 _scheduled = true; 106 _scheduled = true;
124 queueChangeRecords(_reduce); 107 runAsync(_reduce);
125 } 108 }
126 109
127 _observeItems(int lengthAdjust) { 110 _observeItems(int lengthAdjust) {
128 if (lengthAdjust > 0) { 111 if (lengthAdjust > 0) {
129 for (int i = 0; i < lengthAdjust; i++) { 112 for (int i = 0; i < lengthAdjust; i++) {
130 int len = _observers.length; 113 int len = _observers.length;
131 var pathObs = new PathObserver(list, '$len.$_itemPath'); 114 var pathObs = new PathObserver(list, '$len.$_itemPath');
132 _subs.add(pathObs.values.listen(_scheduleReduce)); 115 _subs.add(pathObs.bindSync(_scheduleReduce));
Jennifer Messerly 2013/07/27 02:18:44 this should be: pathObs.changes.listen(_schedul
Siggi Cherem (dart-lang) 2013/07/30 00:10:29 Done. Thanks, I saw 'values' went away, but didn't
133 _observers.add(pathObs); 116 _observers.add(pathObs);
134 } 117 }
135 } else if (lengthAdjust < 0) { 118 } else if (lengthAdjust < 0) {
136 for (int i = 0; i < -lengthAdjust; i++) { 119 for (int i = 0; i < -lengthAdjust; i++) {
137 _subs.removeLast().cancel(); 120 _subs.removeLast().cancel();
138 } 121 }
139 int len = _observers.length; 122 int len = _observers.length;
140 _observers.removeRange(len + lengthAdjust, len); 123 _observers.removeRange(len + lengthAdjust, len);
141 } 124 }
142 } 125 }
143 126
144 setValueWorkaround(key, value) {} 127 setValueWorkaround(key, value) {}
Jennifer Messerly 2013/07/27 02:18:44 these 2 lines be removed
Siggi Cherem (dart-lang) 2013/07/30 00:10:29 Done.
145 getValueWorkaround(key) => key == _VALUE ? value : null; 128 getValueWorkaround(key) => key == _VALUE ? value : null;
146 } 129 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698