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

Side by Side Diff: pkg/barback/lib/src/transformer.dart

Issue 243793005: Don't require Transformer methods to return Futures. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 6 years, 8 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
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 library barback.transformer; 5 library barback.transformer;
6 6
7 import 'dart:async'; 7 import 'dart:async';
8 8
9 import 'asset_id.dart'; 9 import 'asset_id.dart';
10 import 'transform.dart'; 10 import 'transform.dart';
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after
52 /// 52 ///
53 /// A concrete example is dart2js. When you run dart2js, it will traverse 53 /// A concrete example is dart2js. When you run dart2js, it will traverse
54 /// all of the imports in your Dart source files and use the contents of all 54 /// all of the imports in your Dart source files and use the contents of all
55 /// of those to generate the final JS. However you still run dart2js "on" a 55 /// of those to generate the final JS. However you still run dart2js "on" a
56 /// single file: the entrypoint Dart file that has your `main()` method. 56 /// single file: the entrypoint Dart file that has your `main()` method.
57 /// This entrypoint file would be the primary input. 57 /// This entrypoint file would be the primary input.
58 /// 58 ///
59 /// If this is not overridden, defaults to allow any asset whose extension 59 /// If this is not overridden, defaults to allow any asset whose extension
60 /// matches one of the ones returned by [allowedExtensions]. If *that* is 60 /// matches one of the ones returned by [allowedExtensions]. If *that* is
61 /// not overridden, allows all assets. 61 /// not overridden, allows all assets.
62 Future<bool> isPrimary(AssetId id) { 62 ///
63 /// This may return either a `bool` or a `Future<bool>`.
Bob Nystrom 2014/04/21 22:32:23 Here too. Make it clear that not returning a futur
nweiz 2014/04/21 22:46:24 Done.
64 isPrimary(AssetId id) {
63 // Allow all files if [primaryExtensions] is not overridden. 65 // Allow all files if [primaryExtensions] is not overridden.
64 if (allowedExtensions == null) return new Future.value(true); 66 if (allowedExtensions == null) return true;
65 67
66 for (var extension in allowedExtensions.split(" ")) { 68 for (var extension in allowedExtensions.split(" ")) {
67 if (id.path.endsWith(extension)) return new Future.value(true); 69 if (id.path.endsWith(extension)) return true;
68 } 70 }
69 71
70 return new Future.value(false); 72 return false;
71 } 73 }
72 74
73 /// Run this transformer on on the primary input specified by [transform]. 75 /// Run this transformer on on the primary input specified by [transform].
74 /// 76 ///
75 /// The [transform] is used by the [Transformer] for two purposes (in 77 /// The [transform] is used by the [Transformer] for two purposes (in
76 /// addition to accessing the primary input). It can call `getInput()` to 78 /// addition to accessing the primary input). It can call `getInput()` to
77 /// request additional input assets. It also calls `addOutput()` to provide 79 /// request additional input assets. It also calls `addOutput()` to provide
78 /// generated assets back to the system. Either can be called multiple times, 80 /// generated assets back to the system. Either can be called multiple times,
79 /// in any order. 81 /// in any order.
80 /// 82 ///
81 /// In other words, a Transformer's job is to find all inputs for a 83 /// In other words, a Transformer's job is to find all inputs for a
82 /// transform, starting at the primary input, then generate all output assets 84 /// transform, starting at the primary input, then generate all output assets
83 /// and yield them back to the transform. 85 /// and yield them back to the transform.
84 Future apply(Transform transform); 86 ///
87 /// This may return a [Future]. If it does, it won't be considered finished
88 /// until that [Future] completes.
Bob Nystrom 2014/04/21 22:32:23 Ditto.
nweiz 2014/04/21 22:46:24 Done.
89 apply(Transform transform);
85 90
86 String toString() => runtimeType.toString().replaceAll("Transformer", ""); 91 String toString() => runtimeType.toString().replaceAll("Transformer", "");
87 } 92 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698