| Index: sdk/lib/_internal/pub_generated/lib/src/barback/transformer_loader.dart
|
| diff --git a/sdk/lib/_internal/pub_generated/lib/src/barback/transformer_loader.dart b/sdk/lib/_internal/pub_generated/lib/src/barback/transformer_loader.dart
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..2333e3c65ace37ada9f408cd99b837728211c0bd
|
| --- /dev/null
|
| +++ b/sdk/lib/_internal/pub_generated/lib/src/barback/transformer_loader.dart
|
| @@ -0,0 +1,249 @@
|
| +// Copyright (c) 2014, the Dart project authors. Please see the AUTHORS file
|
| +// for details. All rights reserved. Use of this source code is governed by a
|
| +// BSD-style license that can be found in the LICENSE file.
|
| +
|
| +library pub.barback.transformer_loader;
|
| +
|
| +import 'dart:async';
|
| +
|
| +import 'package:barback/barback.dart';
|
| +
|
| +import '../log.dart' as log;
|
| +import '../utils.dart';
|
| +import 'asset_environment.dart';
|
| +import 'barback_server.dart';
|
| +import 'dart2js_transformer.dart';
|
| +import 'excluding_transformer.dart';
|
| +import 'transformer_config.dart';
|
| +import 'transformer_id.dart';
|
| +import 'transformer_isolate.dart';
|
| +
|
| +/// 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 skips any ids that have already been loaded.
|
| + Future load(Iterable<TransformerId> ids, {String snapshot}) {
|
| + final completer0 = new Completer();
|
| + scheduleMicrotask(() {
|
| + try {
|
| + ids = ids.where(((id) {
|
| + return !_isolates.containsKey(id);
|
| + })).toList();
|
| + join0() {
|
| + new Future.value(
|
| + log.progress("Loading ${toSentence(ids)} transformers", (() {
|
| + return TransformerIsolate.spawn(
|
| + _environment,
|
| + _transformerServer,
|
| + ids,
|
| + snapshot: snapshot);
|
| + }))).then((x0) {
|
| + try {
|
| + var isolate = x0;
|
| + var it0 = ids.iterator;
|
| + break0() {
|
| + completer0.complete();
|
| + }
|
| + var trampoline0;
|
| + continue0() {
|
| + trampoline0 = null;
|
| + if (it0.moveNext()) {
|
| + var id = it0.current;
|
| + _isolates[id] = isolate;
|
| + trampoline0 = continue0;
|
| + do trampoline0(); while (trampoline0 != null);
|
| + } else {
|
| + break0();
|
| + }
|
| + }
|
| + trampoline0 = continue0;
|
| + do trampoline0(); while (trampoline0 != null);
|
| + } catch (e0, s0) {
|
| + completer0.completeError(e0, s0);
|
| + }
|
| + }, onError: completer0.completeError);
|
| + }
|
| + if (ids.isEmpty) {
|
| + completer0.complete(null);
|
| + } else {
|
| + join0();
|
| + }
|
| + } catch (e, s) {
|
| + completer0.completeError(e, s);
|
| + }
|
| + });
|
| + return completer0.future;
|
| + }
|
| +
|
| + /// 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) {
|
| + final completer0 = new Completer();
|
| + scheduleMicrotask(() {
|
| + try {
|
| + join0() {
|
| + join1() {
|
| + var transformer;
|
| + join2() {
|
| + _transformers[config] =
|
| + new Set.from([ExcludingTransformer.wrap(transformer, config)]);
|
| + completer0.complete(_transformers[config]);
|
| + }
|
| + catch0(error, stackTrace) {
|
| + try {
|
| + if (error is FormatException) {
|
| + fail(error.message, error, stackTrace);
|
| + join2();
|
| + } else {
|
| + throw error;
|
| + }
|
| + } catch (error, stackTrace) {
|
| + completer0.completeError(error, stackTrace);
|
| + }
|
| + }
|
| + try {
|
| + transformer = new Dart2JSTransformer.withSettings(
|
| + _environment,
|
| + new BarbackSettings(config.configuration, _environment.mode));
|
| + join2();
|
| + } catch (e0, s0) {
|
| + catch0(e0, s0);
|
| + }
|
| + }
|
| + if (_isolates.containsKey(config.id)) {
|
| + new Future.value(_isolates[config.id].create(config)).then((x0) {
|
| + try {
|
| + var transformers = x0;
|
| + join3() {
|
| + var message = "No transformers";
|
| + join4() {
|
| + var location;
|
| + join5() {
|
| + var users =
|
| + toSentence(ordered(_transformerUsers[config.id]));
|
| + fail(
|
| + "${message} were defined in ${location},\n" "required by ${users}.");
|
| + join1();
|
| + }
|
| + if (config.id.path == null) {
|
| + location =
|
| + 'package:${config.id.package}/transformer.dart or '
|
| + 'package:${config.id.package}/${config.id.package}.dart';
|
| + join5();
|
| + } else {
|
| + location = 'package:${config}.dart';
|
| + join5();
|
| + }
|
| + }
|
| + if (config.configuration.isNotEmpty) {
|
| + message += " that accept configuration";
|
| + join4();
|
| + } else {
|
| + join4();
|
| + }
|
| + }
|
| + if (transformers.isNotEmpty) {
|
| + _transformers[config] = transformers;
|
| + completer0.complete(transformers);
|
| + } else {
|
| + join3();
|
| + }
|
| + } catch (e1, s1) {
|
| + completer0.completeError(e1, s1);
|
| + }
|
| + }, onError: completer0.completeError);
|
| + } else {
|
| + join6() {
|
| + join1();
|
| + }
|
| + if (config.id.package != '\$dart2js') {
|
| + completer0.complete(new Future.value(new Set()));
|
| + } else {
|
| + join6();
|
| + }
|
| + }
|
| + }
|
| + if (_transformers.containsKey(config)) {
|
| + completer0.complete(_transformers[config]);
|
| + } else {
|
| + join0();
|
| + }
|
| + } catch (e, s) {
|
| + completer0.completeError(e, s);
|
| + }
|
| + });
|
| + return completer0.future;
|
| + }
|
| +
|
| + /// 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) {
|
| + final completer0 = new Completer();
|
| + scheduleMicrotask(() {
|
| + try {
|
| + new Future.value(Future.wait(phases.map(((phase) {
|
| + final completer0 = new Completer();
|
| + scheduleMicrotask(() {
|
| + try {
|
| + new Future.value(
|
| + waitAndPrintErrors(phase.map(transformersFor))).then((x0) {
|
| + try {
|
| + var transformers = x0;
|
| + completer0.complete(unionAll(transformers));
|
| + } catch (e0, s0) {
|
| + completer0.completeError(e0, s0);
|
| + }
|
| + }, onError: completer0.completeError);
|
| + } catch (e, s) {
|
| + completer0.completeError(e, s);
|
| + }
|
| + });
|
| + return completer0.future;
|
| + })))).then((x0) {
|
| + try {
|
| + var result = x0;
|
| + completer0.complete(result.toList());
|
| + } catch (e0, s0) {
|
| + completer0.completeError(e0, s0);
|
| + }
|
| + }, onError: completer0.completeError);
|
| + } catch (e, s) {
|
| + completer0.completeError(e, s);
|
| + }
|
| + });
|
| + return completer0.future;
|
| + }
|
| +}
|
|
|