| Index: sdk/lib/_internal/compiler/implementation/apiimpl.dart
|
| diff --git a/sdk/lib/_internal/compiler/implementation/apiimpl.dart b/sdk/lib/_internal/compiler/implementation/apiimpl.dart
|
| index 5fa3e99fc9dacc0506ce5350f6e2c2b8c4b16945..91e9ebf53805bedc7be2a86fe5d12387d9499896 100644
|
| --- a/sdk/lib/_internal/compiler/implementation/apiimpl.dart
|
| +++ b/sdk/lib/_internal/compiler/implementation/apiimpl.dart
|
| @@ -67,6 +67,8 @@ class Compiler extends leg.Compiler {
|
| return options.indexOf(option) >= 0;
|
| }
|
|
|
| + // TODO(johnniwinther): Merge better with [translateDartUri] when
|
| + // [scanBuiltinLibrary] is removed.
|
| String lookupLibraryPath(String dartLibraryName) {
|
| LibraryInfo info = LIBRARIES[dartLibraryName];
|
| if (info == null) return null;
|
| @@ -89,10 +91,7 @@ class Compiler extends leg.Compiler {
|
|
|
| elements.LibraryElement scanBuiltinLibrary(String path) {
|
| Uri uri = libraryRoot.resolve(lookupLibraryPath(path));
|
| - Uri canonicalUri = null;
|
| - if (!path.startsWith("_")) {
|
| - canonicalUri = new Uri.fromComponents(scheme: "dart", path: path);
|
| - }
|
| + Uri canonicalUri = new Uri.fromComponents(scheme: "dart", path: path);
|
| elements.LibraryElement library =
|
| libraryLoader.loadLibrary(uri, null, canonicalUri);
|
| return library;
|
| @@ -102,15 +101,30 @@ class Compiler extends leg.Compiler {
|
| handler(null, null, null, message, api.Diagnostic.VERBOSE_INFO);
|
| }
|
|
|
| - leg.Script readScript(Uri uri, [tree.Node node]) {
|
| + /// See [leg.Compiler.translateResolvedUri].
|
| + Uri translateResolvedUri(elements.LibraryElement importingLibrary,
|
| + Uri resolvedUri, tree.Node node) {
|
| + if (resolvedUri.scheme == 'dart') {
|
| + return translateDartUri(importingLibrary, resolvedUri, node);
|
| + }
|
| + return resolvedUri;
|
| + }
|
| +
|
| + /**
|
| + * Reads the script designated by [readableUri].
|
| + */
|
| + leg.Script readScript(Uri readableUri, [tree.Node node]) {
|
| + if (!readableUri.isAbsolute()) {
|
| + internalError('Relative uri $readableUri provided to readScript(Uri)',
|
| + node: node);
|
| + }
|
| return fileReadingTask.measure(() {
|
| - if (uri.scheme == 'dart') uri = translateDartUri(uri, node);
|
| - var translated = translateUri(uri, node);
|
| + Uri resourceUri = translateUri(readableUri, node);
|
| String text = "";
|
| try {
|
| // TODO(ahe): We expect the future to be complete and call value
|
| // directly. In effect, we don't support truly asynchronous API.
|
| - text = deprecatedFutureValue(provider(translated));
|
| + text = deprecatedFutureValue(provider(resourceUri));
|
| } catch (exception) {
|
| if (node != null) {
|
| cancel("$exception", node: node);
|
| @@ -119,31 +133,67 @@ class Compiler extends leg.Compiler {
|
| throw new leg.CompilerCancelledException("$exception");
|
| }
|
| }
|
| - SourceFile sourceFile = new SourceFile(translated.toString(), text);
|
| - return new leg.Script(uri, sourceFile);
|
| + SourceFile sourceFile = new SourceFile(resourceUri.toString(), text);
|
| + // We use [readableUri] as the URI for the script since need to preserve
|
| + // the scheme in the script because [Script.uri] is used for resolving
|
| + // relative URIs mentioned in the script. See the comment on
|
| + // [LibraryLoader] for more details.
|
| + return new leg.Script(readableUri, sourceFile);
|
| });
|
| }
|
|
|
| - Uri translateUri(Uri uri, tree.Node node) {
|
| - switch (uri.scheme) {
|
| - case 'package': return translatePackageUri(uri, node);
|
| - default: return uri;
|
| + /**
|
| + * Translates a readable URI into a resource URI.
|
| + *
|
| + * See [LibraryLoader] for terminology on URIs.
|
| + */
|
| + Uri translateUri(Uri readableUri, tree.Node node) {
|
| + switch (readableUri.scheme) {
|
| + case 'package': return translatePackageUri(readableUri, node);
|
| + default: return readableUri;
|
| }
|
| }
|
|
|
| - Uri translateDartUri(Uri uri, tree.Node node) {
|
| - String path = lookupLibraryPath(uri.path);
|
| - if (path == null || LIBRARIES[uri.path].category == "Internal") {
|
| + Uri translateDartUri(elements.LibraryElement importingLibrary,
|
| + Uri resolvedUri, tree.Node node) {
|
| + LibraryInfo libraryInfo = LIBRARIES[resolvedUri.path];
|
| + String path = lookupLibraryPath(resolvedUri.path);
|
| + if (libraryInfo != null &&
|
| + libraryInfo.category == "Internal") {
|
| + bool allowInternalLibraryAccess = false;
|
| + if (importingLibrary != null) {
|
| + if (importingLibrary.isPlatformLibrary || importingLibrary.isPatch) {
|
| + allowInternalLibraryAccess = true;
|
| + } else if (importingLibrary.canonicalUri.path.contains(
|
| + 'dart/tests/compiler/dart2js_native')) {
|
| + allowInternalLibraryAccess = true;
|
| + }
|
| + }
|
| + if (!allowInternalLibraryAccess) {
|
| + if (node != null && importingLibrary != null) {
|
| + reportDiagnostic(spanFromNode(node),
|
| + 'Error: Internal library $resolvedUri is not accessible from '
|
| + '${importingLibrary.canonicalUri}.',
|
| + api.Diagnostic.ERROR);
|
| + } else {
|
| + reportDiagnostic(null,
|
| + 'Error: Internal library $resolvedUri is not accessible.',
|
| + api.Diagnostic.ERROR);
|
| + }
|
| + //path = null;
|
| + }
|
| + }
|
| + if (path == null) {
|
| if (node != null) {
|
| - reportError(node, 'library not found ${uri}');
|
| + reportError(node, 'library not found ${resolvedUri}');
|
| } else {
|
| - reportDiagnostic(null, 'library not found ${uri}',
|
| + reportDiagnostic(null, 'library not found ${resolvedUri}',
|
| api.Diagnostic.ERROR);
|
| }
|
| return null;
|
| }
|
| - if (uri.path == 'html' ||
|
| - uri.path == 'io') {
|
| + if (resolvedUri.path == 'html' ||
|
| + resolvedUri.path == 'io') {
|
| // TODO(ahe): Get rid of mockableLibraryUsed when test.dart
|
| // supports this use case better.
|
| mockableLibraryUsed = true;
|
|
|