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 /// An entrypoint used to run portions of fasta and measure its performance. | 5 /// An entrypoint used to run portions of fasta and measure its performance. |
6 library front_end.tool.fasta_perf; | 6 library front_end.tool.fasta_perf; |
7 | 7 |
8 import 'dart:async'; | 8 import 'dart:async'; |
9 import 'dart:io'; | 9 import 'dart:io'; |
10 | 10 |
11 import 'package:analyzer/src/fasta/ast_builder.dart'; | 11 import 'package:analyzer/src/fasta/ast_builder.dart'; |
12 import 'package:front_end/physical_file_system.dart'; | 12 import 'package:front_end/physical_file_system.dart'; |
13 import 'package:front_end/src/fasta/dill/dill_target.dart' show DillTarget; | 13 import 'package:front_end/src/fasta/dill/dill_target.dart' show DillTarget; |
14 import 'package:front_end/src/fasta/kernel/kernel_target.dart' | 14 import 'package:front_end/src/fasta/kernel/kernel_target.dart' |
15 show KernelTarget; | 15 show KernelTarget; |
16 import 'package:front_end/src/fasta/parser.dart'; | 16 import 'package:front_end/src/fasta/parser.dart'; |
17 import 'package:front_end/src/fasta/scanner.dart'; | 17 import 'package:front_end/src/fasta/scanner.dart'; |
18 import 'package:front_end/src/fasta/scanner/io.dart' show readBytesFromFileSync; | 18 import 'package:front_end/src/fasta/scanner/io.dart' show readBytesFromFileSync; |
19 import 'package:front_end/src/fasta/source/directive_listener.dart'; | 19 import 'package:front_end/src/fasta/source/directive_listener.dart'; |
20 import 'package:front_end/src/fasta/ticker.dart' show Ticker; | 20 import 'package:front_end/src/fasta/ticker.dart' show Ticker; |
21 import 'package:front_end/src/fasta/translate_uri.dart' show TranslateUri; | 21 import 'package:front_end/src/fasta/translate_uri.dart' show TranslateUri; |
22 import 'package:front_end/src/fasta/translate_uri.dart'; | 22 import 'package:front_end/src/fasta/translate_uri.dart'; |
23 import 'package:front_end/src/fasta/parser/dart_vm_native.dart' | 23 import 'package:front_end/src/fasta/parser/dart_vm_native.dart' |
24 show skipNativeClause; | 24 show skipNativeClause; |
| 25 import 'package:kernel/ast.dart' show FunctionNode; |
25 | 26 |
26 /// Cumulative total number of chars scanned. | 27 /// Cumulative total number of chars scanned. |
27 int inputSize = 0; | 28 int inputSize = 0; |
28 | 29 |
29 /// Cumulative time spent scanning. | 30 /// Cumulative time spent scanning. |
30 Stopwatch scanTimer = new Stopwatch(); | 31 Stopwatch scanTimer = new Stopwatch(); |
31 | 32 |
32 main(List<String> args) async { | 33 main(List<String> args) async { |
33 // TODO(sigmund): provide sdk folder as well. | 34 // TODO(sigmund): provide sdk folder as well. |
34 if (args.length < 2) { | 35 if (args.length < 2) { |
(...skipping 159 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
194 parser.parseUnit(tokens); | 195 parser.parseUnit(tokens); |
195 } | 196 } |
196 | 197 |
197 // Note: AstBuilder doesn't build compilation-units or classes, only method | 198 // Note: AstBuilder doesn't build compilation-units or classes, only method |
198 // bodies. So this listener is not feature complete. | 199 // bodies. So this listener is not feature complete. |
199 class _PartialAstBuilder extends AstBuilder { | 200 class _PartialAstBuilder extends AstBuilder { |
200 _PartialAstBuilder(Uri uri) : super(null, null, null, null, null, uri); | 201 _PartialAstBuilder(Uri uri) : super(null, null, null, null, null, uri); |
201 | 202 |
202 // Note: this method converts the body to kernel, so we skip that here. | 203 // Note: this method converts the body to kernel, so we skip that here. |
203 @override | 204 @override |
204 finishFunction(formals, asyncModifier, body) {} | 205 finishFunction(FunctionNode function, formals, asyncModifier, body) {} |
205 } | 206 } |
206 | 207 |
207 // Invoke the fasta kernel generator for the program starting in [entryUri] | 208 // Invoke the fasta kernel generator for the program starting in [entryUri] |
208 // TODO(sigmund): update to use the frontend api once fasta is being hit. | 209 // TODO(sigmund): update to use the frontend api once fasta is being hit. |
209 generateKernel(Uri entryUri, | 210 generateKernel(Uri entryUri, |
210 {bool compileSdk: true, bool strongMode: false}) async { | 211 {bool compileSdk: true, bool strongMode: false}) async { |
211 // TODO(sigmund): this is here only to compute the input size, | 212 // TODO(sigmund): this is here only to compute the input size, |
212 // we should extract the input size from the frontend instead. | 213 // we should extract the input size from the frontend instead. |
213 scanReachableFiles(entryUri); | 214 scanReachableFiles(entryUri); |
214 | 215 |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
253 /// Report that metric [name] took [time] micro-seconds to process | 254 /// Report that metric [name] took [time] micro-seconds to process |
254 /// [inputSize] characters. | 255 /// [inputSize] characters. |
255 void report(String name, int time) { | 256 void report(String name, int time) { |
256 var sb = new StringBuffer(); | 257 var sb = new StringBuffer(); |
257 var padding = ' ' * (20 - name.length); | 258 var padding = ' ' * (20 - name.length); |
258 sb.write('$name:$padding $time us, ${time ~/ 1000} ms'); | 259 sb.write('$name:$padding $time us, ${time ~/ 1000} ms'); |
259 var invSpeed = (time * 1000 / inputSize).toStringAsFixed(2); | 260 var invSpeed = (time * 1000 / inputSize).toStringAsFixed(2); |
260 sb.write(', $invSpeed ns/char'); | 261 sb.write(', $invSpeed ns/char'); |
261 print('$sb'); | 262 print('$sb'); |
262 } | 263 } |
OLD | NEW |