| 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/src/fasta/dill/dill_target.dart' show DillTarget; | 12 import 'package:front_end/src/fasta/dill/dill_target.dart' show DillTarget; | 
| 13 import 'package:front_end/src/fasta/kernel/kernel_target.dart' | 13 import 'package:front_end/src/fasta/kernel/kernel_target.dart' | 
| 14     show KernelTarget; | 14     show KernelTarget; | 
| 15 import 'package:front_end/src/fasta/parser.dart'; | 15 import 'package:front_end/src/fasta/parser.dart'; | 
| 16 import 'package:front_end/src/fasta/scanner.dart'; | 16 import 'package:front_end/src/fasta/scanner.dart'; | 
| 17 import 'package:front_end/src/fasta/scanner/io.dart' show readBytesFromFileSync; | 17 import 'package:front_end/src/fasta/scanner/io.dart' show readBytesFromFileSync; | 
| 18 import 'package:front_end/src/fasta/source/scope_listener.dart' show Scope; | 18 import 'package:front_end/src/fasta/scope.dart' show Scope; | 
| 19 import 'package:front_end/src/fasta/ticker.dart' show Ticker; | 19 import 'package:front_end/src/fasta/ticker.dart' show Ticker; | 
| 20 import 'package:front_end/src/fasta/translate_uri.dart' show TranslateUri; | 20 import 'package:front_end/src/fasta/translate_uri.dart' show TranslateUri; | 
| 21 import 'package:front_end/src/fasta/translate_uri.dart'; | 21 import 'package:front_end/src/fasta/translate_uri.dart'; | 
| 22 | 22 | 
| 23 /// Cumulative total number of chars scanned. | 23 /// Cumulative total number of chars scanned. | 
| 24 int inputSize = 0; | 24 int inputSize = 0; | 
| 25 | 25 | 
| 26 /// Cumulative time spent scanning. | 26 /// Cumulative time spent scanning. | 
| 27 Stopwatch scanTimer = new Stopwatch(); | 27 Stopwatch scanTimer = new Stopwatch(); | 
| 28 | 28 | 
| (...skipping 258 matching lines...) Expand 10 before | Expand all | Expand 10 after  Loading... | 
| 287 /// Report that metric [name] took [time] micro-seconds to process | 287 /// Report that metric [name] took [time] micro-seconds to process | 
| 288 /// [inputSize] characters. | 288 /// [inputSize] characters. | 
| 289 void report(String name, int time) { | 289 void report(String name, int time) { | 
| 290   var sb = new StringBuffer(); | 290   var sb = new StringBuffer(); | 
| 291   var padding = ' ' * (20 - name.length); | 291   var padding = ' ' * (20 - name.length); | 
| 292   sb.write('$name:$padding $time us, ${time ~/ 1000} ms'); | 292   sb.write('$name:$padding $time us, ${time ~/ 1000} ms'); | 
| 293   var invSpeed = (time * 1000 / inputSize).toStringAsFixed(2); | 293   var invSpeed = (time * 1000 / inputSize).toStringAsFixed(2); | 
| 294   sb.write(', $invSpeed ns/char'); | 294   sb.write(', $invSpeed ns/char'); | 
| 295   print('$sb'); | 295   print('$sb'); | 
| 296 } | 296 } | 
| OLD | NEW | 
|---|