| OLD | NEW |
| 1 // Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2011, 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 // A native method prevents other members from having that name, including | 5 // A native method prevents other members from having that name, including |
| 6 // fields. However, native fields keep their name. The implication: a getter | 6 // fields. However, native fields keep their name. The implication: a getter |
| 7 // for the field must be based on the field's name, not the field's jsname. | 7 // for the field must be based on the field's name, not the field's jsname. |
| 8 | 8 |
| 9 import "package:expect/expect.dart"; | 9 import "package:expect/expect.dart"; |
| 10 import 'dart:_js_helper' show JSName; | 10 import 'dart:_js_helper' show Native, JSName; |
| 11 | 11 |
| 12 class A native "A" { | 12 @Native("A") |
| 13 class A { |
| 13 int key; // jsname is 'key' | 14 int key; // jsname is 'key' |
| 14 int getKey() => key; | 15 int getKey() => key; |
| 15 } | 16 } |
| 16 | 17 |
| 17 class B { | 18 class B { |
| 18 int key; // jsname is not 'key' | 19 int key; // jsname is not 'key' |
| 19 B([this.key = 222]); | 20 B([this.key = 222]); |
| 20 int getKey() => key; | 21 int getKey() => key; |
| 21 } | 22 } |
| 22 | 23 |
| 23 class X native "X" { | 24 @Native("X") |
| 25 class X { |
| 24 @JSName('key') | 26 @JSName('key') |
| 25 int native_key_method() native; | 27 int native_key_method() native; |
| 26 // This should cause B.key to be renamed, but not A.key. | 28 // This should cause B.key to be renamed, but not A.key. |
| 27 | 29 |
| 28 @JSName('key') | 30 @JSName('key') |
| 29 int key() native; | 31 int key() native; |
| 30 } | 32 } |
| 31 | 33 |
| 32 A makeA() native; | 34 A makeA() native; |
| 33 X makeX() native; | 35 X makeX() native; |
| (...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 75 Expect.equals(111, a.getKey()); | 77 Expect.equals(111, a.getKey()); |
| 76 Expect.equals(222, b.getKey()); | 78 Expect.equals(222, b.getKey()); |
| 77 } | 79 } |
| 78 | 80 |
| 79 main() { | 81 main() { |
| 80 setup(); | 82 setup(); |
| 81 | 83 |
| 82 testTyped(); | 84 testTyped(); |
| 83 testDynamic(); | 85 testDynamic(); |
| 84 } | 86 } |
| OLD | NEW |