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

Side by Side Diff: pkg/analyzer/lib/src/fasta/analyzer_loader.dart

Issue 2904203003: Don't recreate CoreTypes in transformers. Pass it in. (Closed)
Patch Set: Create CoreTypes in AnalyzerLoader. Created 3 years, 6 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
OLDNEW
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 }
OLDNEW
« no previous file with comments | « no previous file | pkg/front_end/lib/src/fasta/fasta.dart » ('j') | pkg/front_end/lib/src/fasta/fasta.dart » ('J')

Powered by Google App Engine
This is Rietveld 408576698