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

Side by Side Diff: sdk/lib/_internal/pub_generated/asset/dart/serialize/get_input_transform.dart

Issue 937243002: Revert "Revert "Use native async/await support in pub."" (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 5 years, 10 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 | Annotate | Revision Log
OLDNEW
(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 pub.asset.serialize.get_input_transform;
6
7 import 'dart:async';
8 import 'dart:convert';
9
10 import 'package:barback/barback.dart';
11
12 import '../utils.dart';
13
14 /// A mixin for transforms that support [getInput] and the associated suite of
15 /// methods.
16 abstract class GetInputTransform {
17 Future<Asset> getInput(AssetId id);
18
19 Future<String> readInputAsString(AssetId id, {Encoding encoding}) {
20 if (encoding == null) encoding = UTF8;
21 return getInput(id).then((input) =>
22 input.readAsString(encoding: encoding));
23 }
24
25 Stream<List<int>> readInput(AssetId id) =>
26 futureStream(getInput(id).then((input) => input.read()));
27
28 Future<bool> hasInput(AssetId id) {
29 return getInput(id).then((_) => true).catchError((error) {
30 if (error is AssetNotFoundException && error.id == id) return false;
31 throw error;
32 });
33 }
34 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698