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 |