| 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 import "dart:_js_helper"; | 
| 5 import "package:expect/expect.dart"; | 6 import "package:expect/expect.dart"; | 
| 6 | 7 | 
| 7 // Verify that native fields on classes are not renamed by the minifier. | 8 // Verify that native fields on classes are not renamed by the minifier. | 
| 8 class A native "A" { | 9 @Native("A") | 
|  | 10 class A { | 
| 9   int myLongPropertyName; | 11   int myLongPropertyName; | 
| 10   int getValue; | 12   int getValue; | 
| 11 | 13 | 
| 12   int method(int z) => myLongPropertyName; | 14   int method(int z) => myLongPropertyName; | 
| 13 } | 15 } | 
| 14 | 16 | 
| 15 | 17 | 
| 16 void setup() native r""" | 18 void setup() native r""" | 
| 17 function getter() { | 19 function getter() { | 
| 18   return ++this.getValue; | 20   return ++this.getValue; | 
| 19 } | 21 } | 
| 20 | 22 | 
| 21 function setter(x) { | 23 function setter(x) { | 
| 22   this.getValue += 10; | 24   this.getValue += 10; | 
| 23 } | 25 } | 
| 24 | 26 | 
| 25 function A(){ | 27 function A(){ | 
| 26   var a = Object.create( | 28   var a = Object.create( | 
| 27       { constructor: { name: 'A'}}, | 29       { constructor: { name: 'A'}}, | 
| 28       { myLongPropertyName: { get: getter, | 30       { myLongPropertyName: { get: getter, | 
| 29                               set: setter, | 31                               set: setter, | 
| 30                               configurable: false, | 32                               configurable: false, | 
| 31                               writeable: false | 33                               writeable: false | 
| 32                             } | 34                             } | 
| 33       }); | 35       }); | 
| 34   a.getValue = 0; | 36   a.getValue = 0; | 
| (...skipping 16 matching lines...) Expand all  Loading... | 
| 51   if (a2 is A) { | 53   if (a2 is A) { | 
| 52     // Inside this 'if' the compiler knows that a2 is an A, so it is tempted | 54     // Inside this 'if' the compiler knows that a2 is an A, so it is tempted | 
| 53     // to access myLongPropertyName directly, using its minified name.  But | 55     // to access myLongPropertyName directly, using its minified name.  But | 
| 54     // renaming of native properties can only work using getters and setters | 56     // renaming of native properties can only work using getters and setters | 
| 55     // that access the original name. | 57     // that access the original name. | 
| 56     a2.myLongPropertyName = 21; | 58     a2.myLongPropertyName = 21; | 
| 57     int gotten = a2.myLongPropertyName; | 59     int gotten = a2.myLongPropertyName; | 
| 58     Expect.equals(11, gotten); | 60     Expect.equals(11, gotten); | 
| 59   } | 61   } | 
| 60 } | 62 } | 
| OLD | NEW | 
|---|