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

Unified Diff: pkg/smoke/test/codegen/testing_resolver_utils.dart

Issue 194813007: Add codegen support in smoke (Closed) Base URL: https://dart.googlecode.com/svn/branches/bleeding_edge/dart
Patch Set: Created 6 years, 9 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
Index: pkg/smoke/test/codegen/testing_resolver_utils.dart
diff --git a/pkg/smoke/test/codegen/testing_resolver_utils.dart b/pkg/smoke/test/codegen/testing_resolver_utils.dart
new file mode 100644
index 0000000000000000000000000000000000000000..a66b5b6c669d8afc39d07b0c190f4d0376b3713e
--- /dev/null
+++ b/pkg/smoke/test/codegen/testing_resolver_utils.dart
@@ -0,0 +1,97 @@
+// Copyright (c) 2014, 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.
+
+/// Utility functions to test the code generation tools with the resolver.
+// Note, this is just for simple tests, so we restricted the logic to only
+// support root-relative imports. For more sophisticated stuff, you should be
+// using the test helpers in `package:code_transformers`.
+library smoke.test.codegen.testing_resolver_utils;
+
+import 'package:analyzer/src/generated/element.dart';
+import 'package:analyzer/src/generated/engine.dart';
+import 'package:analyzer/src/generated/java_io.dart';
+import 'package:analyzer/src/generated/source.dart';
+import 'package:analyzer/src/generated/sdk_io.dart' show DirectoryBasedDartSdk;
+import 'package:code_transformers/src/dart_sdk.dart' show dartSdkDirectory;
+
+class LibraryProvider {
+ final AnalysisContext _analyzer;
+ final Map<String, Source> _allSources;
+ LibraryProvider(this._analyzer, this._allSources);
+ LibraryElement libraryFor(String uri) =>
+ _analyzer.computeLibraryElement(_allSources[uri]);
+}
+
+LibraryProvider initAnalyzer(Map<String, String> contents) {
+ var analyzer = AnalysisEngine.instance.createAnalysisContext();
+ var options = new AnalysisOptionsImpl()
+ ..cacheSize = 256
+ ..preserveComments = false
+ ..analyzeFunctionBodies = false;
+ analyzer.analysisOptions = options;
+ var sdk = new DirectoryBasedDartSdk(new JavaFile(dartSdkDirectory));
+ sdk.context.analysisOptions = options;
+ var changes = new ChangeSet();
+ var allSources = {};
+ contents.forEach((url, code) {
+ var source = new _SimpleSource(url, code, allSources);
+ allSources[url] = source;
+ changes.addedSource(source);
+ });
+ analyzer.applyChanges(changes);
+
+ analyzer.sourceFactory = new SourceFactory([
+ new DartUriResolver(sdk),
+ new _SimpleUriResolver(allSources)]);
+
+ return new LibraryProvider(analyzer, allSources);
+}
+
+class _SimpleUriResolver implements UriResolver {
+ final Map<String, Source> allSources;
+ _SimpleUriResolver(this.allSources);
+
+ Source resolveAbsolute(Uri uri) => allSources['$uri'];
+
+ Source fromEncoding(UriKind kind, Uri uri) =>
+ throw new UnimplementedError('fromEncoding not implemented');
+
+ Uri restoreAbsolute(Source source) =>
+ throw new UnimplementedError('restoreAbsolute not implemented');
+}
+
+class _SimpleSource extends Source {
+ final String path;
+ final String rawContents;
+ final Map<String, Source> allSources;
+
+ _SimpleSource(this.path, this.rawContents, this.allSources);
+
+ operator ==(other) => other is _SimpleSource &&
+ rawContents == other.rawContents;
+ int get hashCode => rawContents.hashCode;
+
+ bool exists() => true;
+ String get encoding => '$uriKind/$path';
+ String get fullName => path;
+ TimestampedData<String> get contents =>
+ new TimestampedData<String>(modificationStamp, rawContents);
+
+ int get modificationStamp => 1;
+ String get shortName => path;
+ UriKind get uriKind => UriKind.FILE_URI;
+ final bool isInSystemLibrary = false;
+
+ // Since this is just for simple tests we just restricted this mock
+ // to root-relative imports. For more sophisticated stuff, you should be
+ // using the test helpers in `package:code_transformers`.
+ Source resolveRelative(Uri uri) {
+ if (uri.path.startsWith('/')) return allSources['${uri.path}'];
+ throw new UnimplementedError('relative URIs not supported: $uri');
+ }
+
+ void getContentsToReceiver(Source_ContentReceiver receiver) {
+ receiver.accept(rawContents, modificationStamp);
+ }
+}

Powered by Google App Engine
This is Rietveld 408576698