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

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: code review fixes 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 f4d43e517453376079a78eee7f87381546285da6..126d7c4b21501ef4faed55644153febe44c3bc2b 100644
--- a/sdk/lib/_internal/compiler/implementation/resolution/members.dart
+++ b/sdk/lib/_internal/compiler/implementation/resolution/members.dart
@@ -1735,6 +1735,10 @@ class ResolverVisitor extends CommonResolverVisitor<Element> {
} else if (!selector.applies(target, compiler)) {
warnArgumentMismatch(node, target);
}
+
+ if (selector.name == const SourceString('JS')) {
ngeoffray 2012/11/15 12:49:57 Add a target.kind == ElementKind.FOREIGN. Otherwis
+ world.nativeEnqueuer.registerJsCall(node, this);
+ }
}
// TODO(ngeoffray): Warn if target is null and the send is
@@ -1751,6 +1755,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