Chromium Code Reviews| OLD | NEW |
|---|---|
| 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 * A binding delegate used with Polymer elements that | 6 * A binding delegate used with Polymer elements that |
| 7 * allows for complex binding expressions, including | 7 * allows for complex binding expressions, including |
| 8 * property access, function invocation, | 8 * property access, function invocation, |
| 9 * list/map indexing, and two-way filtering. | 9 * list/map indexing, and two-way filtering. |
| 10 * | 10 * |
| (...skipping 92 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 103 } | 103 } |
| 104 | 104 |
| 105 class _Binding extends Bindable { | 105 class _Binding extends Bindable { |
| 106 final Scope _scope; | 106 final Scope _scope; |
| 107 final _converter; | 107 final _converter; |
| 108 Expression _expr; | 108 Expression _expr; |
| 109 Function _callback; | 109 Function _callback; |
| 110 StreamSubscription _sub; | 110 StreamSubscription _sub; |
| 111 var _value; | 111 var _value; |
| 112 | 112 |
| 113 _Binding(this._expr, this._scope, [this._converter]); | 113 _Binding(this._expr, this._scope, [converter]) |
| 114 : _converter = converter == null ? _identity : converter; | |
| 114 | 115 |
| 115 static _oneTime(Expression expr, Scope scope, [converter]) { | 116 static _oneTime(Expression expr, Scope scope, [converter]) { |
| 116 try { | 117 try { |
| 117 return _convertValue(eval(expr, scope), scope, converter); | 118 var v = eval(expr, scope); |
| 119 return converter == null ? v : converter(v); | |
| 118 } catch (e, s) { | 120 } catch (e, s) { |
| 119 new Completer().completeError( | 121 new Completer().completeError( |
| 120 "Error evaluating expression '$expr': $e", s); | 122 "Error evaluating expression '$expr': $e", s); |
| 121 } | 123 } |
| 122 return null; | 124 return null; |
| 123 } | 125 } |
| 124 | 126 |
| 125 _setValue(v) { | 127 _check(v, {bool skipChanges: false}) { |
|
Siggi Cherem (dart-lang)
2014/05/30 21:36:03
this rename is not necessary, but it makes the cod
justinfagnani
2014/05/30 22:58:33
Please make as few changes as possible, it makes m
Jennifer Messerly
2014/05/30 23:00:56
yeah, sorry about rebase difficulty.
But I just w
| |
| 126 var oldValue = _value; | 128 var oldValue = _value; |
| 127 _value = _convertValue(v, _scope, _converter); | 129 _value = _converter(v); |
| 128 if (_callback != null && oldValue != _value) _callback(_value); | 130 if (!skipChanges && _callback != null && oldValue != _value) { |
| 129 } | 131 _callback(_value); |
| 130 | |
| 131 static _convertValue(v, scope, converter) { | |
| 132 if (v is Comprehension) { | |
| 133 // convert the Comprehension into a list of scopes with the loop | |
| 134 // variable added to the scope | |
| 135 return v.iterable.map((i) => scope.childScope(v.identifier, i)) | |
| 136 .toList(growable: false); | |
| 137 } else { | |
| 138 return converter == null ? v : converter(v); | |
| 139 } | 132 } |
| 140 } | 133 } |
| 141 | 134 |
| 142 get value { | 135 get value { |
| 143 if (_callback != null) return _value; | 136 if (_callback != null) return _value; |
| 144 return _oneTime(_expr, _scope, _converter); | 137 return _oneTime(_expr, _scope, _converter); |
| 145 } | 138 } |
| 146 | 139 |
| 147 set value(v) { | 140 set value(v) { |
| 148 try { | 141 try { |
| 149 var newValue = assign(_expr, v, _scope); | 142 var newValue = assign(_expr, v, _scope); |
| 150 _value = _convertValue(newValue, _scope, _converter); | 143 _check(newValue, skipChanges: true); |
| 151 } catch (e, s) { | 144 } catch (e, s) { |
| 152 new Completer().completeError( | 145 new Completer().completeError( |
| 153 "Error evaluating expression '$_expr': $e", s); | 146 "Error evaluating expression '$_expr': $e", s); |
| 154 } | 147 } |
| 155 } | 148 } |
| 156 | 149 |
| 157 open(callback(value)) { | 150 open(callback(value)) { |
| 158 if (_callback != null) throw new StateError('already open'); | 151 if (_callback != null) throw new StateError('already open'); |
| 159 | 152 |
| 160 _callback = callback; | 153 _callback = callback; |
| 161 final expr = observe(_expr, _scope); | 154 final expr = observe(_expr, _scope); |
| 162 _expr = expr; | 155 _expr = expr; |
| 163 _sub = expr.onUpdate.listen(_setValue)..onError((e, s) { | 156 _sub = expr.onUpdate.listen(_check)..onError((e, s) { |
| 164 new Completer().completeError( | 157 new Completer().completeError( |
| 165 "Error evaluating expression '$expr': $e", s); | 158 "Error evaluating expression '$expr': $e", s); |
| 166 }); | 159 }); |
| 167 try { | 160 try { |
| 168 update(expr, _scope); | 161 update(expr, _scope); |
| 169 _value = _convertValue(expr.currentValue, _scope, _converter); | 162 _check(expr.currentValue, skipChanges: true); |
| 170 } catch (e, s) { | 163 } catch (e, s) { |
| 171 new Completer().completeError( | 164 new Completer().completeError( |
| 172 "Error evaluating expression '$expr': $e", s); | 165 "Error evaluating expression '$expr': $e", s); |
| 173 } | 166 } |
| 174 return _value; | 167 return _value; |
| 175 } | 168 } |
| 176 | 169 |
| 177 void close() { | 170 void close() { |
| 178 if (_callback == null) return; | 171 if (_callback == null) return; |
| 179 | 172 |
| 180 _sub.cancel(); | 173 _sub.cancel(); |
| 181 _sub = null; | 174 _sub = null; |
| 182 _expr = (_expr as ExpressionObserver).expression; | 175 _expr = (_expr as ExpressionObserver).expression; |
| 183 _callback = null; | 176 _callback = null; |
| 184 } | 177 } |
| 185 } | 178 } |
| 179 | |
| 180 _identity(x) => x; | |
| OLD | NEW |