Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright (c) 2017, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2017, 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 fasta.analyzer_loader; | 5 library fasta.analyzer_loader; |
| 6 | 6 |
| 7 import 'package:front_end/physical_file_system.dart'; | 7 import 'package:front_end/physical_file_system.dart'; |
| 8 import 'package:kernel/ast.dart' show Program; | 8 import 'package:kernel/ast.dart' show Program; |
| 9 | 9 |
| 10 import 'package:front_end/src/fasta/builder/builder.dart' show LibraryBuilder; | 10 import 'package:front_end/src/fasta/builder/builder.dart' show LibraryBuilder; |
| 11 | 11 |
| 12 import 'package:front_end/src/fasta/target_implementation.dart' | 12 import 'package:front_end/src/fasta/target_implementation.dart' |
| 13 show TargetImplementation; | 13 show TargetImplementation; |
| 14 | 14 |
| 15 import 'package:front_end/src/fasta/source/source_class_builder.dart' | 15 import 'package:front_end/src/fasta/source/source_class_builder.dart' |
| 16 show SourceClassBuilder; | 16 show SourceClassBuilder; |
| 17 | 17 |
| 18 import 'package:front_end/src/fasta/source/source_loader.dart' | 18 import 'package:front_end/src/fasta/source/source_loader.dart' |
| 19 show SourceLoader; | 19 show SourceLoader; |
| 20 | 20 |
| 21 import 'package:analyzer/src/fasta/element_store.dart' show ElementStore; | 21 import 'package:analyzer/src/fasta/element_store.dart' show ElementStore; |
| 22 | 22 |
| 23 import 'analyzer_diet_listener.dart' show AnalyzerDietListener; | 23 import 'analyzer_diet_listener.dart' show AnalyzerDietListener; |
| 24 | 24 |
| 25 import 'package:kernel/core_types.dart' show CoreTypes; | |
| 26 | |
| 25 class AnalyzerLoader<L> extends SourceLoader<L> { | 27 class AnalyzerLoader<L> extends SourceLoader<L> { |
| 26 ElementStore elementStore; | 28 ElementStore elementStore; |
| 27 | 29 |
| 28 AnalyzerLoader(TargetImplementation target) | 30 AnalyzerLoader(TargetImplementation target) |
| 29 : super(PhysicalFileSystem.instance, target); | 31 : super(PhysicalFileSystem.instance, target); |
| 30 | 32 |
| 31 @override | 33 @override |
| 32 void computeHierarchy(Program program) { | 34 void computeHierarchy(Program program) { |
| 33 elementStore = new ElementStore(coreLibrary, builders); | 35 elementStore = new ElementStore(coreLibrary, builders); |
| 34 ticker.logMs("Built analyzer element model."); | 36 ticker.logMs("Built analyzer element model."); |
| 37 coreTypes = new CoreTypes(program); | |
|
ahe
2017/05/29 14:08:46
Add:
ticker.logMs("Computed core types");
scheglov
2017/05/30 00:06:10
I will, but I'm curious what the purpose of this l
ahe
2017/05/30 09:35:14
The only way to tell if no time is being spent com
scheglov
2017/05/30 16:10:21
I will not argue with this, you're right Observato
| |
| 35 } | 38 } |
| 36 | 39 |
| 37 @override | 40 @override |
| 38 AnalyzerDietListener createDietListener(LibraryBuilder library) { | 41 AnalyzerDietListener createDietListener(LibraryBuilder library) { |
| 39 return new AnalyzerDietListener(library, elementStore); | 42 return new AnalyzerDietListener(library, elementStore); |
| 40 } | 43 } |
| 41 | 44 |
| 42 @override | 45 @override |
| 43 void checkOverrides(List<SourceClassBuilder> sourceClasses) { | 46 void checkOverrides(List<SourceClassBuilder> sourceClasses) { |
| 44 // Not implemented yet. Requires [hierarchy]. | 47 // Not implemented yet. Requires [hierarchy]. |
| 45 } | 48 } |
| 46 } | 49 } |
| OLD | NEW |