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

Side by Side Diff: tests/compiler/dart2js_native/native_wrapping_function3_frog_test.dart

Issue 383413003: Add @Native(...) annotation for native class names. (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Updated cf. comments. Created 6 years, 5 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 unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file
2 // for details. All rights reserved. Use of this source code is governed by a 2 // for details. All rights reserved. Use of this source code is governed by a
3 // BSD-style license that can be found in the LICENSE file. 3 // BSD-style license that can be found in the LICENSE file.
4 4
5 import "package:expect/expect.dart"; 5 import "package:expect/expect.dart";
6 import "dart:_js_helper";
6 7
7 typedef void Callback0(); 8 typedef void Callback0();
8 typedef void Callback1(arg1); 9 typedef void Callback1(arg1);
9 typedef void Callback2(arg1, arg2); 10 typedef void Callback2(arg1, arg2);
10 11
11 class A native "A" { 12 @Native("A")
13 class A {
12 foo1(Callback1 closure, [arg1 = 0]) native; 14 foo1(Callback1 closure, [arg1 = 0]) native;
13 foo2(Callback2 closure, [arg1 = 0, arg2 = 1]) native; 15 foo2(Callback2 closure, [arg1 = 0, arg2 = 1]) native;
14 } 16 }
15 17
16 makeA() native; 18 makeA() native;
17 19
18 void setup() native """ 20 void setup() native """
19 function A() {} 21 function A() {}
20 A.prototype.foo1 = function(closure, arg1) { return closure(arg1); }; 22 A.prototype.foo1 = function(closure, arg1) { return closure(arg1); };
21 A.prototype.foo2 = function(closure, arg1, arg2) { 23 A.prototype.foo2 = function(closure, arg1, arg2) {
(...skipping 12 matching lines...) Expand all
34 Expect.equals(44, a.foo2((arg1, arg2) => arg1 + arg2, 21, 23)); 36 Expect.equals(44, a.foo2((arg1, arg2) => arg1 + arg2, 21, 23));
35 Expect.equals(22, a.foo2((arg1, arg2) => arg1 + arg2, 21)); 37 Expect.equals(22, a.foo2((arg1, arg2) => arg1 + arg2, 21));
36 38
37 A aa = a; 39 A aa = a;
38 Expect.equals(43, aa.foo1((arg1) => arg1, 43)); 40 Expect.equals(43, aa.foo1((arg1) => arg1, 43));
39 Expect.equals(0, aa.foo1((arg1) => arg1)); 41 Expect.equals(0, aa.foo1((arg1) => arg1));
40 42
41 Expect.equals(44, aa.foo2((arg1, arg2) => arg1 + arg2, 21, 23)); 43 Expect.equals(44, aa.foo2((arg1, arg2) => arg1 + arg2, 21, 23));
42 Expect.equals(22, aa.foo2((arg1, arg2) => arg1 + arg2, 21)); 44 Expect.equals(22, aa.foo2((arg1, arg2) => arg1 + arg2, 21));
43 } 45 }
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698