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

Unified Diff: packages/analyzer/benchmark/errors_in_all_libraries.dart

Issue 2990843002: Removed fixed dependencies (Closed)
Patch Set: Created 3 years, 5 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 side-by-side diff with in-line comments
Download patch
« no previous file with comments | « packages/analyzer/README.md ('k') | packages/analyzer/doc/support/dart.js » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: packages/analyzer/benchmark/errors_in_all_libraries.dart
diff --git a/packages/analyzer/benchmark/errors_in_all_libraries.dart b/packages/analyzer/benchmark/errors_in_all_libraries.dart
new file mode 100644
index 0000000000000000000000000000000000000000..ad004bf2afc19f3e8e1516dbd99c8bf8ffb462a5
--- /dev/null
+++ b/packages/analyzer/benchmark/errors_in_all_libraries.dart
@@ -0,0 +1,98 @@
+#!/usr/bin/env dart
+// Copyright (c) 2016, the Dart project authors. Please see the AUTHORS file
+// for details. All rights reserved. Use of this source code is governed by a
+// BSD-style license that can be found in the LICENSE file.
+
+/// Resolves this library and everything it transitively imports and generates
+/// errors in all of those libraries. Does this in an infinite loop, starting
+/// from scratch each time, to show how VM warm-up affects things and to make
+/// it easier to connect to this with observatory.
+import 'dart:io';
+
+import 'package:analyzer/dart/element/element.dart';
+import 'package:analyzer/file_system/file_system.dart';
+import 'package:analyzer/file_system/physical_file_system.dart';
+import 'package:analyzer/source/package_map_resolver.dart';
+import 'package:analyzer/src/context/builder.dart';
+import 'package:analyzer/src/dart/sdk/sdk.dart';
+import 'package:analyzer/src/generated/engine.dart';
+import 'package:analyzer/src/generated/source.dart';
+import 'package:analyzer/src/generated/source_io.dart';
+import 'package:analyzer/src/source/source_resource.dart';
+import 'package:path/path.dart' as p;
+
+void main(List<String> args) {
+ // Assumes you have run "pub get" in the analyzer directory itself and uses
+ // that "packages" directory as its package root.
+ var packageRoot =
+ p.normalize(p.join(p.dirname(p.fromUri(Platform.script)), "packages"));
+
+ var best = new Duration(days: 1);
+ while (true) {
+ var start = new DateTime.now();
+ AnalysisEngine.instance.clearCaches();
+
+ AnalysisOptionsImpl options = new AnalysisOptionsImpl();
+ options.strongMode = true;
+ options.strongModeHints = true;
+
+ PhysicalResourceProvider resourceProvider =
+ PhysicalResourceProvider.INSTANCE;
+ FolderBasedDartSdk sdk = new FolderBasedDartSdk(
+ resourceProvider, resourceProvider.getFolder(args[0]));
+ sdk.analysisOptions = options;
+
+ ContextBuilder builder = new ContextBuilder(resourceProvider, null, null);
+ AnalysisContext context = AnalysisEngine.instance.createAnalysisContext();
+ context.sourceFactory = new SourceFactory([
+ new DartUriResolver(sdk),
+ new ResourceUriResolver(resourceProvider),
+ new PackageMapUriResolver(resourceProvider,
+ builder.convertPackagesToMap(builder.createPackageMap(packageRoot)))
+ ]);
+ context.analysisOptions = options;
+
+ var mainSource =
+ new FileSource(resourceProvider.getFile(p.fromUri(Platform.script)));
+ context.applyChanges(new ChangeSet()..addedSource(mainSource));
+
+ var initialLibrary =
+ context.resolveCompilationUnit2(mainSource, mainSource);
+
+ // Walk all of the transitively referenced libraries and compute errors.
+ var errorCount = 0;
+ var allLibraries = _reachableLibraries(initialLibrary.element.library);
+ for (var lib in allLibraries) {
+ for (var unit in lib.units) {
+ var source = unit.source;
+
+ // Skip core libraries.
+ if (source.uri.scheme == 'dart') continue;
+
+ var librarySource = context.getLibrariesContaining(source).single;
+ context.resolveCompilationUnit2(source, librarySource);
+ errorCount += context.computeErrors(source).length;
+ }
+ }
+
+ var elapsed = new DateTime.now().difference(start);
+ print("$elapsed : $errorCount errors ${elapsed < best ? "(best)" : ""}");
+ if (elapsed < best) best = elapsed;
+ }
+}
+
+/// Returns all libraries transitively imported or exported from [start].
+List<LibraryElement> _reachableLibraries(LibraryElement start) {
+ var results = <LibraryElement>[];
+ var seen = new Set();
+ void find(LibraryElement lib) {
+ if (seen.contains(lib)) return;
+ seen.add(lib);
+ results.add(lib);
+ lib.importedLibraries.forEach(find);
+ lib.exportedLibraries.forEach(find);
+ }
+
+ find(start);
+ return results;
+}
« no previous file with comments | « packages/analyzer/README.md ('k') | packages/analyzer/doc/support/dart.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698