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

Unified Diff: sdk/lib/_internal/compiler/implementation/resolution/members.dart

Issue 11304021: Add NativeEnqueuer to work with the Enqueuer. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 8 years, 1 month 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/resolution/members.dart
diff --git a/sdk/lib/_internal/compiler/implementation/resolution/members.dart b/sdk/lib/_internal/compiler/implementation/resolution/members.dart
index af90b8e4dd1e9bdff3b6365c4455809e0ec2525a..224fee1c556b7913c0861e08e9a7514d356b5a15 100644
--- a/sdk/lib/_internal/compiler/implementation/resolution/members.dart
+++ b/sdk/lib/_internal/compiler/implementation/resolution/members.dart
@@ -1761,6 +1761,12 @@ class ResolverVisitor extends CommonResolverVisitor<Element> {
} else if (!selector.applies(target, compiler)) {
warnArgumentMismatch(node, target);
}
+
+ if (target != null &&
+ target.kind == ElementKind.FOREIGN &&
+ selector.name == const SourceString('JS')) {
+ world.nativeEnqueuer.registerJsCall(node, this);
+ }
}
// TODO(ngeoffray): Warn if target is null and the send is
@@ -1777,6 +1783,15 @@ class ResolverVisitor extends CommonResolverVisitor<Element> {
[target.name]);
}
+ /// Callback for native enqueuer to parse a type. Returns [:null:] on error.
+ DartType resolveTypeFromString(String typeName) {
+ Element element = scope.lookup(new SourceString(typeName));
+ if (element == null) return null;
+ if (element is! ClassElement) return null;
+ element.ensureResolved(compiler);
+ return element.computeType(compiler);
+ }
+
visitSendSet(SendSet node) {
Element target = resolveSend(node);
Element setter = target;

Powered by Google App Engine
This is Rietveld 408576698