| OLD | NEW |
| 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, 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 library reexport_handled_test; | 5 library reexport_handled_test; |
| 6 | 6 |
| 7 import "package:expect/expect.dart"; | 7 import "package:expect/expect.dart"; |
| 8 import 'mock_compiler.dart'; | 8 import 'mock_compiler.dart'; |
| 9 import '../../../sdk/lib/_internal/compiler/implementation/elements/elements.dar
t' | 9 import '../../../sdk/lib/_internal/compiler/implementation/elements/elements.dar
t' |
| 10 show Element, | 10 show Element, |
| (...skipping 10 matching lines...) Expand all Loading... |
| 21 library reexporting; | 21 library reexporting; |
| 22 export 'exporting.dart'; | 22 export 'exporting.dart'; |
| 23 '''; | 23 '''; |
| 24 | 24 |
| 25 void main() { | 25 void main() { |
| 26 var compiler = new MockCompiler(); | 26 var compiler = new MockCompiler(); |
| 27 compiler.registerSource(exportingLibraryUri, EXPORTING_LIBRARY_SOURCE); | 27 compiler.registerSource(exportingLibraryUri, EXPORTING_LIBRARY_SOURCE); |
| 28 compiler.registerSource(reexportingLibraryUri, REEXPORTING_LIBRARY_SOURCE); | 28 compiler.registerSource(reexportingLibraryUri, REEXPORTING_LIBRARY_SOURCE); |
| 29 | 29 |
| 30 // Load exporting library before the reexporting library. | 30 // Load exporting library before the reexporting library. |
| 31 var exportingLibrary = compiler.libraryLoader.loadLibrary( | 31 compiler.libraryLoader.loadLibrary( |
| 32 exportingLibraryUri, null, exportingLibraryUri); | 32 exportingLibraryUri, null, exportingLibraryUri).then((exportingLibrary) { |
| 33 Expect.isTrue(exportingLibrary.exportsHandled); | 33 Expect.isTrue(exportingLibrary.exportsHandled); |
| 34 var foo = findInExports(exportingLibrary, 'foo'); | 34 var foo = findInExports(exportingLibrary, 'foo'); |
| 35 Expect.isNotNull(foo); | 35 Expect.isNotNull(foo); |
| 36 Expect.isTrue(foo.isField()); | 36 Expect.isTrue(foo.isField()); |
| 37 | 37 |
| 38 // Load reexporting library when exports are handled on the exporting library. | 38 // Load reexporting library when exports are handled on the exporting librar
y. |
| 39 var reexportingLibrary = compiler.libraryLoader.loadLibrary( | 39 return compiler.libraryLoader.loadLibrary( |
| 40 reexportingLibraryUri, null, reexportingLibraryUri); | 40 reexportingLibraryUri, null, reexportingLibraryUri); |
| 41 foo = findInExports(reexportingLibrary, 'foo'); | 41 }).then((reexportingLibrary) { |
| 42 Expect.isNotNull(foo); | 42 var foo = findInExports(reexportingLibrary, 'foo'); |
| 43 Expect.isTrue(foo.isField()); | 43 Expect.isNotNull(foo); |
| 44 Expect.isTrue(foo.isField()); |
| 45 }); |
| 44 } | 46 } |
| 45 | 47 |
| 46 Element findInExports(LibraryElement library, String name) { | 48 Element findInExports(LibraryElement library, String name) { |
| 47 for (var export in library.exports) { | 49 for (var export in library.exports) { |
| 48 if (export.name.slowToString() == name) { | 50 if (export.name.slowToString() == name) { |
| 49 return export; | 51 return export; |
| 50 } | 52 } |
| 51 } | 53 } |
| 52 return null; | 54 return null; |
| 53 } | 55 } |
| OLD | NEW |