Index: sdk/lib/_internal/pub/lib/src/barback/load_all_transformers.dart |
diff --git a/sdk/lib/_internal/pub/lib/src/barback/load_all_transformers.dart b/sdk/lib/_internal/pub/lib/src/barback/load_all_transformers.dart |
index 18bf853d4262d8f5e6644cfd32df034ab2f914b1..51b8dbf43b3a030b90244a9bc421160e08f6832d 100644 |
--- a/sdk/lib/_internal/pub/lib/src/barback/load_all_transformers.dart |
+++ b/sdk/lib/_internal/pub/lib/src/barback/load_all_transformers.dart |
@@ -6,19 +6,15 @@ library pub.load_all_transformers; |
import 'dart:async'; |
-import 'package:barback/barback.dart'; |
- |
import '../log.dart' as log; |
import '../package_graph.dart'; |
import '../utils.dart'; |
import 'asset_environment.dart'; |
import 'barback_server.dart'; |
-import 'dart2js_transformer.dart'; |
-import 'excluding_transformer.dart'; |
import 'rewrite_import_transformer.dart'; |
-import 'transformer_config.dart'; |
+import 'transformer_cache.dart'; |
import 'transformer_id.dart'; |
-import 'transformer_isolate.dart'; |
+import 'transformer_loader.dart'; |
import 'transformers_needed_by_transformers.dart'; |
/// Loads all transformers depended on by packages in [environment]. |
@@ -50,7 +46,7 @@ Future loadAllTransformers(AssetEnvironment environment, |
var packagesThatUseTransformers = |
_packagesThatUseTransformers(environment.graph); |
- var loader = new _TransformerLoader(environment, transformerServer); |
+ var loader = new TransformerLoader(environment, transformerServer); |
// Add a rewrite transformer for each package, so that we can resolve |
// "package:" imports while loading transformers. |
@@ -60,10 +56,17 @@ Future loadAllTransformers(AssetEnvironment environment, |
} |
environment.barback.updateTransformers(r'$pub', [[rewrite]]); |
+ var cache = new TransformerCache.load(environment); |
+ |
+ var i = 0; |
return Future.forEach(phasedTransformers, (phase) { |
+ i++; |
+ |
+ var snapshotPath = cache.snapshotPath(phase, i); |
+ |
/// Load all the transformers in [phase], then add them to the appropriate |
/// locations in the transformer graphs of the packages that use them. |
- return loader.load(phase).then((_) { |
+ return loader.load(phase, snapshot: snapshotPath).then((_) { |
// Only update packages that use transformers in [phase]. |
var packagesToUpdate = unionAll(phase.map((id) => |
packagesThatUseTransformers[id])); |
@@ -80,6 +83,8 @@ Future loadAllTransformers(AssetEnvironment environment, |
})); |
}); |
}).then((_) { |
+ cache.save(); |
+ |
/// Reset the transformers for each package to get rid of [rewrite], which |
/// is no longer needed. |
return Future.wait(environment.graph.packages.values.map((package) { |
@@ -146,111 +151,3 @@ Map<TransformerId, Set<String>> _packagesThatUseTransformers( |
} |
return results; |
} |
- |
-/// A class that loads transformers defined in specific files. |
-class _TransformerLoader { |
- final AssetEnvironment _environment; |
- |
- final BarbackServer _transformerServer; |
- |
- final _isolates = new Map<TransformerId, TransformerIsolate>(); |
- |
- final _transformers = new Map<TransformerConfig, Set<Transformer>>(); |
- |
- /// The packages that use each transformer id. |
- /// |
- /// Used for error reporting. |
- final _transformerUsers = new Map<TransformerId, Set<String>>(); |
- |
- _TransformerLoader(this._environment, this._transformerServer) { |
- for (var package in _environment.graph.packages.values) { |
- for (var config in unionAll(package.pubspec.transformers)) { |
- _transformerUsers.putIfAbsent(config.id, () => new Set<String>()) |
- .add(package.name); |
- } |
- } |
- } |
- |
- /// Loads a transformer plugin isolate that imports the transformer libraries |
- /// indicated by [ids]. |
- /// |
- /// Once the returned future completes, transformer instances from this |
- /// isolate can be created using [transformersFor] or [transformersForPhase]. |
- /// |
- /// This will skip any ids that have already been loaded. |
- Future load(Iterable<TransformerId> ids) { |
- ids = ids.where((id) => !_isolates.containsKey(id)).toList(); |
- if (ids.isEmpty) return new Future.value(); |
- |
- return log.progress("Loading ${toSentence(ids)} transformers", () { |
- return TransformerIsolate.spawn(_environment, _transformerServer, ids); |
- }).then((isolate) { |
- for (var id in ids) { |
- _isolates[id] = isolate; |
- } |
- }); |
- } |
- |
- /// Instantiates and returns all transformers in the library indicated by |
- /// [config] with the given configuration. |
- /// |
- /// If this is called before the library has been loaded into an isolate via |
- /// [load], it will return an empty set. |
- Future<Set<Transformer>> transformersFor(TransformerConfig config) { |
- if (_transformers.containsKey(config)) { |
- return new Future.value(_transformers[config]); |
- } else if (_isolates.containsKey(config.id)) { |
- return _isolates[config.id].create(config).then((transformers) { |
- if (transformers.isNotEmpty) { |
- _transformers[config] = transformers; |
- return transformers; |
- } |
- |
- var message = "No transformers"; |
- if (config.configuration.isNotEmpty) { |
- message += " that accept configuration"; |
- } |
- |
- var location; |
- if (config.id.path == null) { |
- location = 'package:${config.id.package}/transformer.dart or ' |
- 'package:${config.id.package}/${config.id.package}.dart'; |
- } else { |
- location = 'package:$config.dart'; |
- } |
- |
- var users = toSentence(ordered(_transformerUsers[config.id])); |
- fail("$message were defined in $location,\n" |
- "required by $users."); |
- }); |
- } else if (config.id.package != '\$dart2js') { |
- return new Future.value(new Set()); |
- } |
- |
- var transformer; |
- try { |
- transformer = new Dart2JSTransformer.withSettings(_environment, |
- new BarbackSettings(config.configuration, _environment.mode)); |
- } on FormatException catch (error, stackTrace) { |
- fail(error.message, error, stackTrace); |
- } |
- |
- // Handle any exclusions. |
- _transformers[config] = new Set.from( |
- [ExcludingTransformer.wrap(transformer, config)]); |
- return new Future.value(_transformers[config]); |
- } |
- |
- /// Loads all transformers defined in each phase of [phases]. |
- /// |
- /// If any library hasn't yet been loaded via [load], it will be ignored. |
- Future<List<Set<Transformer>>> transformersForPhases( |
- Iterable<Set<TransformerConfig>> phases) { |
- return Future.wait(phases.map((phase) { |
- return waitAndPrintErrors(phase.map(transformersFor)).then(unionAll); |
- })).then((phases) { |
- // Return a growable list so that callers can add phases. |
- return phases.toList(); |
- }); |
- } |
-} |