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

Unified Diff: sdk/lib/_internal/compiler/implementation/apiimpl.dart

Issue 11967010: Internal libraries supported. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 7 years, 11 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 side-by-side diff with in-line comments
Download patch
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..47495ce1cc214543d91686274990d27fe9eb8ec9 100644
--- a/sdk/lib/_internal/compiler/implementation/apiimpl.dart
+++ b/sdk/lib/_internal/compiler/implementation/apiimpl.dart
@@ -89,10 +89,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 +99,31 @@ class Compiler extends leg.Compiler {
handler(null, null, null, message, api.Diagnostic.VERBOSE_INFO);
}
+ /**
+ * Resolves the [uri] into a file resource URI.
+ *
+ * The [importingUri] holds the canonical uri for the library importing [uri]
+ * or [:null:] if [uri] is loaded as the main library. The [importingUri] is
+ * used to grant access to private libraries for platform libraries.
ahe 2013/01/18 11:03:10 Please document that this method is responsible fo
Johnni Winther 2013/01/21 09:27:54 Done.
+ */
+ Uri resolveScriptUri(Uri importingUri, Uri uri, [tree.Node node]) {
ahe 2013/01/18 11:03:10 I like this method.
+ if (uri.scheme == 'dart') {
+ return translateDartUri(importingUri, uri, node);
+ }
+ return translateUri(uri, node);
+ }
+
+ /**
+ * Reads the script designated by [uri].
+ */
leg.Script readScript(Uri uri, [tree.Node node]) {
+ if (!uri.isAbsolute()) throw new ArgumentError(uri);
ahe 2013/01/18 11:03:10 You should be able to report an (internal) error i
Johnni Winther 2013/01/21 09:27:54 Done.
return fileReadingTask.measure(() {
- if (uri.scheme == 'dart') uri = translateDartUri(uri, node);
ahe 2013/01/18 11:03:10 I really like that you got rid of this.
- var translated = translateUri(uri, 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(uri));
} catch (exception) {
if (node != null) {
cancel("$exception", node: node);
@@ -119,7 +132,7 @@ class Compiler extends leg.Compiler {
throw new leg.CompilerCancelledException("$exception");
}
}
- SourceFile sourceFile = new SourceFile(translated.toString(), text);
+ SourceFile sourceFile = new SourceFile(uri.toString(), text);
return new leg.Script(uri, sourceFile);
});
}
@@ -131,9 +144,26 @@ class Compiler extends leg.Compiler {
}
}
- Uri translateDartUri(Uri uri, tree.Node node) {
+ Uri translateDartUri(Uri sourceUri, Uri uri, tree.Node node) {
String path = lookupLibraryPath(uri.path);
- if (path == null || LIBRARIES[uri.path].category == "Internal") {
+ if (LIBRARIES[uri.path] != null &&
ngeoffray 2013/01/16 15:40:57 Store LIBRARIES[uri.path] in a local variable?
Johnni Winther 2013/01/21 09:27:54 Done.
+ LIBRARIES[uri.path].category == "Internal") {
+ bool allowPrivateLibraryAccess = false;
+ if (sourceUri != null) {
+ if (sourceUri.scheme == 'dart' || sourceUri.scheme == 'patch') {
ahe 2013/01/18 11:03:10 What is the patch scheme?
Johnni Winther 2013/01/21 09:27:54 A new scheme used to provide patch libraries with
ahe 2013/01/21 09:39:38 I don't think it is a good idea to invent new sche
Johnni Winther 2013/01/21 09:45:55 Then I'll have to encode it in the path, like dart
ahe 2013/01/21 10:08:25 I was hoping we could get rid of encoding this inf
Johnni Winther 2013/01/21 10:15:15 Then I think I'd rather go back to having no canon
ahe 2013/01/21 10:18:09 SGTM
+ allowPrivateLibraryAccess = true;
+ }
+ if (sourceUri.path.contains('dart/tests/compiler/dart2js_native')) {
+ allowPrivateLibraryAccess = true;
+ }
+ }
+ if (!allowPrivateLibraryAccess) {
+ log('Internal library $uri is not accessible '
ngeoffray 2013/01/16 15:40:57 Why do you log that? Isn't that something that the
ahe 2013/01/18 11:03:10 The user will see an error message like this: fis
Johnni Winther 2013/01/21 09:27:54 Changed to [reportError].
+ '${sourceUri != null ? 'from $sourceUri' : ''}');
+ path = null;
+ }
+ }
+ if (path == null) {
if (node != null) {
reportError(node, 'library not found ${uri}');
} else {

Powered by Google App Engine
This is Rietveld 408576698