Index: sdk/lib/_internal/pub/lib/src/dart.dart |
diff --git a/sdk/lib/_internal/pub/lib/src/dart.dart b/sdk/lib/_internal/pub/lib/src/dart.dart |
index b934112bb38a8e8cef9bcb689a094fac63616f64..4c746d1e88faa4372cbdf3d162db15e2f8e2a9a0 100644 |
--- a/sdk/lib/_internal/pub/lib/src/dart.dart |
+++ b/sdk/lib/_internal/pub/lib/src/dart.dart |
@@ -25,11 +25,14 @@ import 'utils.dart'; |
/// true). |
/// |
/// By default, the package root is assumed to be adjacent to [entrypoint], but |
-/// if [packageRoot] is passed that will be used instead. If [provider] is |
-/// omitted, uses a default [SourceFileProvider] that loads directly from the |
-/// filesystem. |
+/// if [packageRoot] is passed that will be used instead. |
+/// |
+/// If [inputProvider] and [diagnosticHandler] are omitted, uses a default |
+/// [compiler.CompilerInputProvider] that loads directly from the filesystem. |
+/// If either is provided, both must be. |
Future<String> compile(String entrypoint, {String packageRoot, |
- bool toDart: false, SourceFileProvider provider}) { |
+ bool toDart: false, compiler.CompilerInputProvider inputProvider, |
+ compiler.DiagnosticHandler diagnosticHandler}) { |
return new Future.sync(() { |
var options = <String>['--categories=Client,Server', '--minify']; |
if (toDart) options.add('--output-type=dart'); |
@@ -37,17 +40,24 @@ Future<String> compile(String entrypoint, {String packageRoot, |
packageRoot = path.join(path.dirname(entrypoint), 'packages'); |
} |
- if (provider == null) { |
- provider = new SourceFileProvider(); |
+ // Must either pass both of these or neither. |
+ if ((inputProvider == null) != (diagnosticHandler == null)) { |
+ throw new ArgumentError("If either inputProvider or diagnosticHandler " |
+ "is passed, then both must be."); |
+ } |
+ |
+ if (inputProvider == null) { |
+ var provider = new SourceFileProvider(); |
+ inputProvider = provider.readStringFromUri; |
+ diagnosticHandler = new FormattingDiagnosticHandler(provider) |
+ .diagnosticHandler; |
} |
return compiler.compile( |
path.toUri(entrypoint), |
path.toUri(appendSlash(_libPath)), |
path.toUri(appendSlash(packageRoot)), |
- provider.readStringFromUri, |
- new FormattingDiagnosticHandler(provider).diagnosticHandler, |
- options); |
+ inputProvider, diagnosticHandler, options); |
}).then((result) { |
if (result != null) return result; |
throw new ApplicationException('Failed to compile "$entrypoint".'); |