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

Unified Diff: pkg/front_end/test/src/incremental/mock_sdk.dart

Issue 2993093003: Add support for SDK outline in KernelDriver. (Closed)
Patch Set: Created 3 years, 4 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/front_end/test/src/incremental/mock_sdk.dart
diff --git a/pkg/front_end/test/src/incremental/mock_sdk.dart b/pkg/front_end/test/src/incremental/mock_sdk.dart
index b005e2606c37c7b1676149e5e7c9c04d014257c7..c378242c85f28f4fb041fa5541c45ba39100ad83 100644
--- a/pkg/front_end/test/src/incremental/mock_sdk.dart
+++ b/pkg/front_end/test/src/incremental/mock_sdk.dart
@@ -4,20 +4,45 @@
import 'package:front_end/memory_file_system.dart';
-/// Create SDK libraries which are used by Fasta to perform kernel generation.
-/// Return the mapping from the simple names of these library to the URIs
-/// in the given [fileSystem]. The root of the SDK is `file:///sdk`.
-Map<String, Uri> createSdkFiles(MemoryFileSystem fileSystem) {
- Map<String, Uri> dartLibraries = {};
+final _ASYNC = r'''
Siggi Cherem (dart-lang) 2017/08/05 03:22:47 Yay - thank you, even with syntax highlighting, ha
+library dart.async;
- void addSdkLibrary(String name, String contents) {
- String path = '$name/$name.dart';
- Uri uri = Uri.parse('file:///sdk/lib/$path');
- fileSystem.entityForUri(uri).writeAsStringSync(contents);
- dartLibraries[name] = uri;
- }
+class Future<T> {
+ factory Future(computation()) => null;
+ factory Future.delayed(Duration duration, [T computation()]) => null;
+ factory Future.microtask(FutureOr<T> computation()) => null;
+ factory Future.value([value]) => null;
+
+ static Future<List<T>> wait<T>(Iterable<Future<T>> futures) => null;
+ Future<R> then<R>(FutureOr<R> onValue(T value)) => null;
+
+ Future<T> whenComplete(action());
+}
+
+
+class FutureOr<T> {}
+class Stream<T> {}
+abstract class StreamIterator<T> {}
+
+abstract class Completer<T> {
+ factory Completer() => null;
+ factory Completer.sync() => null;
+ Future<T> get future;
+ void complete([FutureOr<T> value]);
+ void completeError(Object error, [StackTrace stackTrace]);
+ bool get isCompleted;
+}
+
+class _StreamIterator<T> implements StreamIterator<T> {}
+class _AsyncStarStreamController {}
+Object _asyncStackTraceHelper(Function async_op) { }
+Function _asyncThenWrapperHelper(continuation) {}
+Function _asyncErrorWrapperHelper(continuation) {}
+Future _awaitHelper(
+ object, Function thenCallback, Function errorCallback, var awaiter) {}
+''';
- addSdkLibrary('core', r'''
+final _CORE = r'''
library dart.core;
import 'dart:_internal';
import 'dart:async';
@@ -200,45 +225,49 @@ external bool identical(Object a, Object b);
void print(Object o) {}
abstract class _SyncIterable implements Iterable {}
-''');
-
- addSdkLibrary('async', r'''
-library dart.async;
+''';
-class Future<T> {
- factory Future(computation()) => null;
- factory Future.delayed(Duration duration, [T computation()]) => null;
- factory Future.microtask(FutureOr<T> computation()) => null;
- factory Future.value([value]) => null;
+/// Create SDK libraries which are used by Fasta to perform kernel generation.
+/// Return the mapping from the simple names of these library to the URIs
+/// in the given [fileSystem]. The root of the SDK is `file:///sdk`.
+Map<String, Uri> createSdkFiles(MemoryFileSystem fileSystem) {
+ Map<String, Uri> dartLibraries = {};
- static Future<List<T>> wait<T>(Iterable<Future<T>> futures) => null;
- Future<R> then<R>(FutureOr<R> onValue(T value)) => null;
+ void addSdkLibrary(String name, String contents) {
+ String path = '$name/$name.dart';
+ Uri uri = Uri.parse('file:///sdk/lib/$path');
+ fileSystem.entityForUri(uri).writeAsStringSync(contents);
+ dartLibraries[name] = uri;
+ }
- Future<T> whenComplete(action());
+ fileSystem.entityForUri(Uri.parse('file:///sdk/')).createDirectory();
+
+ fileSystem
+ .entityForUri(Uri.parse('file:///sdk/lib/libraries.json'))
+ .writeAsStringSync(r'''
+{
+ "libraries": {
+ "core": "core/core.dart",
+ "async": "async/async.dart",
+ "collection": "collection/collection.dart",
+ "convert": "convert/convert.dart",
+ "developer": "developer/developer.dart",
+ "io": "io/io.dart",
+ "isolate": "isolate/isolate.dart",
+ "math": "math/math.dart",
+ "mirrors": "mirrors/mirrors.dart",
+ "nativewrappers": "nativewrappers/nativewrappers.dart",
+ "profiler": "profiler/profiler.dart",
+ "typed_data": "typed_data/typed_data.dart",
+ "_builtin": "_builtin/_builtin.dart",
+ "_internal": "_internal/_internal.dart"
+ }
}
+''');
+ addSdkLibrary('core', _CORE);
-class FutureOr<T> {}
-class Stream<T> {}
-abstract class StreamIterator<T> {}
-
-abstract class Completer<T> {
- factory Completer() => null;
- factory Completer.sync() => null;
- Future<T> get future;
- void complete([FutureOr<T> value]);
- void completeError(Object error, [StackTrace stackTrace]);
- bool get isCompleted;
-}
-
-class _StreamIterator<T> implements StreamIterator<T> {}
-class _AsyncStarStreamController {}
-Object _asyncStackTraceHelper(Function async_op) { }
-Function _asyncThenWrapperHelper(continuation) {}
-Function _asyncErrorWrapperHelper(continuation) {}
-Future _awaitHelper(
- object, Function thenCallback, Function errorCallback, var awaiter) {}
-''');
+ addSdkLibrary('async', _ASYNC);
addSdkLibrary('collection', 'library dart.collection;');
addSdkLibrary('convert', 'library dart.convert;');
@@ -253,7 +282,6 @@ external double sin(num radians);
addSdkLibrary('nativewrappers', 'library dart.nativewrappers;');
addSdkLibrary('profiler', 'library dart.profiler;');
addSdkLibrary('typed_data', 'library dart.typed_data;');
- addSdkLibrary('vmservice_io', 'library dart.vmservice_io;');
addSdkLibrary('_builtin', 'library dart._builtin;');
addSdkLibrary('_internal', '''
library dart._internal;
@@ -263,7 +291,6 @@ class ExternalName {
const ExternalName(this.name);
}
''');
- addSdkLibrary('_vmservice', 'library dart._vmservice;');
return dartLibraries;
}

Powered by Google App Engine
This is Rietveld 408576698