| OLD | NEW |
| (Empty) |
| 1 // Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file | |
| 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. | |
| 4 | |
| 5 library shelf.util; | |
| 6 | |
| 7 import 'dart:async'; | |
| 8 | |
| 9 import 'package:stack_trace/stack_trace.dart'; | |
| 10 | |
| 11 /// Like [new Future], but avoids around issue 11911 by using [new Future.value] | |
| 12 /// under the covers. | |
| 13 Future newFuture(callback()) => new Future.value().then((_) => callback()); | |
| 14 | |
| 15 /// Like [Future.sync], but wraps the Future in [Chain.track] as well. | |
| 16 Future syncFuture(callback()) => Chain.track(new Future.sync(callback)); | |
| 17 | |
| 18 /// Run [callback] and capture any errors that would otherwise be top-leveled. | |
| 19 /// | |
| 20 /// If [this] is called in a non-root error zone, it will just run [callback] | |
| 21 /// and return the result. Otherwise, it will capture any errors using | |
| 22 /// [runZoned] and pass them to [onError]. | |
| 23 catchTopLevelErrors(callback(), void onError(error, StackTrace stackTrace)) { | |
| 24 if (Zone.current.inSameErrorZone(Zone.ROOT)) { | |
| 25 return runZoned(callback, onError: onError); | |
| 26 } else { | |
| 27 return callback(); | |
| 28 } | |
| 29 } | |
| 30 | |
| 31 /// Returns a [Map] with the values from [original] and the values from | |
| 32 /// [updates]. | |
| 33 /// | |
| 34 /// For keys that are the same between [original] and [updates], the value in | |
| 35 /// [updates] is used. | |
| 36 /// | |
| 37 /// If [updates] is `null` or empty, [original] is returned unchanged. | |
| 38 Map updateMap(Map original, Map updates) { | |
| 39 if (updates == null || updates.isEmpty) return original; | |
| 40 | |
| 41 return new Map.from(original) | |
| 42 ..addAll(updates); | |
| 43 } | |
| OLD | NEW |