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

Side by Side Diff: web/web_command.dart

Issue 2208243002: Restructured the set up for the compiling function. Also added room for list of additional summarie… (Closed) Base URL: https://github.com/dart-lang/dev_compiler.git@master
Patch Set: Created 4 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 unified diff | Download patch
« web/main.dart ('K') | « web/main.dart ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2016, the Dart project authors. Please see the AUTHORS file 1 // Copyright (c) 2016, 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 @JS()
5 library dev_compiler.web.web_command;
6
4 import 'dart:html' show HttpRequest; 7 import 'dart:html' show HttpRequest;
5 import 'dart:convert' show BASE64; 8 import 'dart:convert' show BASE64;
9 import 'dart:async';
Jacob 2016/08/03 23:58:32 sort imports in alphabetical order.
priscillalee 2016/08/04 16:01:56 Done.
6 10
7 import 'package:analyzer/file_system/file_system.dart' 11 import 'package:analyzer/file_system/file_system.dart'
8 show ResourceProvider, ResourceUriResolver; 12 show ResourceProvider, ResourceUriResolver;
9 import 'package:analyzer/file_system/memory_file_system.dart' 13 import 'package:analyzer/file_system/memory_file_system.dart'
10 show MemoryResourceProvider; 14 show MemoryResourceProvider;
11 import 'package:analyzer/src/context/cache.dart' 15 import 'package:analyzer/src/context/cache.dart'
12 show AnalysisCache, CachePartition; 16 show AnalysisCache, CachePartition;
13 import 'package:analyzer/src/context/context.dart' show AnalysisContextImpl; 17 import 'package:analyzer/src/context/context.dart' show AnalysisContextImpl;
14 import 'package:analyzer/src/generated/engine.dart' 18 import 'package:analyzer/src/generated/engine.dart'
15 show AnalysisContext, AnalysisEngine, TimestampedData; 19 show AnalysisContext, AnalysisEngine, TimestampedData;
16 import 'package:analyzer/src/generated/sdk.dart' 20 import 'package:analyzer/src/generated/sdk.dart'
17 show DartSdk, SdkLibrary, SdkLibraryImpl; 21 show DartSdk, SdkLibrary, SdkLibraryImpl;
18 import 'package:analyzer/src/generated/source.dart' 22 import 'package:analyzer/src/generated/source.dart'
19 show DartUriResolver, Source, SourceFactory, UriKind; 23 show DartUriResolver, Source, SourceFactory, UriKind;
20 import 'package:analyzer/src/summary/idl.dart' show PackageBundle; 24 import 'package:analyzer/src/summary/idl.dart' show PackageBundle;
25 import 'package:analyzer/src/summary/package_bundle_reader.dart'
26 show
27 SummaryDataStore,
28 InSummaryPackageUriResolver,
29 InputPackagesResultProvider;
21 import 'package:analyzer/src/summary/summary_sdk.dart' show SummaryBasedDartSdk; 30 import 'package:analyzer/src/summary/summary_sdk.dart' show SummaryBasedDartSdk;
22 31
23 import 'package:args/command_runner.dart'; 32 import 'package:args/command_runner.dart';
24 33
25 import 'package:dev_compiler/src/analyzer/context.dart' show AnalyzerOptions; 34 import 'package:dev_compiler/src/analyzer/context.dart' show AnalyzerOptions;
26 import 'package:dev_compiler/src/compiler/compiler.dart' 35 import 'package:dev_compiler/src/compiler/compiler.dart'
27 show BuildUnit, CompilerOptions, JSModuleFile, ModuleCompiler; 36 show BuildUnit, CompilerOptions, JSModuleFile, ModuleCompiler;
28 37
38 import 'package:js/js.dart';
39
29 typedef void MessageHandler(Object message); 40 typedef void MessageHandler(Object message);
30 typedef String CompileFn(String dart);
31 typedef void OnLoadFn(CompileFn compile);
32 41
33 /// The command for invoking the modular compiler. 42 /// The command for invoking the modular compiler.
34 class WebCompileCommand extends Command { 43 class WebCompileCommand extends Command {
35 get name => 'compile'; 44 get name => 'compile';
36 get description => 'Compile a set of Dart files into a JavaScript module.'; 45 get description => 'Compile a set of Dart files into a JavaScript module.';
37 final MessageHandler messageHandler; 46 final MessageHandler messageHandler;
38 final OnLoadFn onload;
39 47
40 WebCompileCommand(this.onload, {MessageHandler messageHandler}) 48 WebCompileCommand({MessageHandler messageHandler})
41 : this.messageHandler = messageHandler ?? print { 49 : this.messageHandler = messageHandler ?? print {
42 CompilerOptions.addArguments(argParser); 50 CompilerOptions.addArguments(argParser);
43 AnalyzerOptions.addArguments(argParser); 51 AnalyzerOptions.addArguments(argParser);
44 } 52 }
45 53
46 @override 54 @override
47 void run() { 55 Function run() {
48 var request = new HttpRequest(); 56 return requestSummaries;
Jacob 2016/08/03 23:58:31 Are we really getting anything from implementing C
priscillalee 2016/08/04 16:01:56 I agree. It does seem strange. I don't understand
49
50 request.onReadyStateChange.listen((_) {
51 if (request.readyState == HttpRequest.DONE &&
52 (request.status == 200 || request.status == 0)) {
53 var response = request.responseText;
54 var sdkBytes = BASE64.decode(response);
55 var result = setUpCompile(sdkBytes);
56 onload(result);
57 }
58 });
59
60 request.open('get', 'dart_sdk.sum');
61 request.send();
62 } 57 }
63 58
64 CompileFn setUpCompile(List<int> sdkBytes) { 59 void requestSummaries(
60 String sdkUrl, List<String> summaryUrls, Function callback) {
61 HttpRequest.request(sdkUrl).then((sdkRequest) {
62 var sdkResponse = sdkRequest.responseText;
63 var sdkBytes = BASE64.decode(sdkResponse);
64
65 // Map summary URLs to HttpRequests.
66 var summaryRequests = summaryUrls
67 .map((summary) => new Future(() => HttpRequest.request(summary)));
68
69 Future.wait(summaryRequests).then((summaryResponses) {
70 // Map summary responses to summary bytes.
71 var summaryBytes = summaryResponses
72 .map((response) => BASE64.decode(response.responseText));
73
74 var compileFn = setUpCompile(sdkBytes, summaryBytes);
75 callback(compileFn);
76 });
Jacob 2016/08/03 23:58:31 You should handle if a summary fails to load.
priscillalee 2016/08/04 16:01:56 I added status checks, but should I also throw exc
Jacob 2016/08/04 16:27:48 Ideally you would report the error back to the cal
priscillalee 2016/08/04 17:56:33 Done.
77 });
78 }
79
80 Function setUpCompile(List<int> sdkBytes, List<List<int>> summaryBytes) {
65 var resourceProvider = new MemoryResourceProvider(); 81 var resourceProvider = new MemoryResourceProvider();
82 var resourceUriResolver = new ResourceUriResolver(resourceProvider);
83
66 var packageBundle = new PackageBundle.fromBuffer(sdkBytes); 84 var packageBundle = new PackageBundle.fromBuffer(sdkBytes);
67 var webDartSdk = new SummaryBasedDartSdk.fromBundle( 85 var webDartSdk = new SummaryBasedDartSdk.fromBundle(
68 true, packageBundle, resourceProvider); 86 true, packageBundle, resourceProvider);
87 var sdkResolver = new DartUriResolver(webDartSdk);
69 88
70 var sdkResolver = new DartUriResolver(webDartSdk); 89 var summaryDataStore = new SummaryDataStore([]);
71 var fileResolvers = [new ResourceUriResolver(resourceProvider)]; 90 for (var bytes in summaryBytes) {
91 var summaryBundle = new PackageBundle.fromBuffer(bytes);
92 summaryDataStore.addBundle('', summaryBundle);
93 }
94 var summaryResolver = new InSummaryPackageUriResolver(summaryDataStore);
95
96 var fileResolvers = [summaryResolver, resourceUriResolver];
72 97
73 var compiler = new ModuleCompiler( 98 var compiler = new ModuleCompiler(
74 new AnalyzerOptions(dartSdkPath: '/dart-sdk'), 99 new AnalyzerOptions(dartSdkPath: '/dart-sdk'),
75 sdkResolver: sdkResolver, 100 sdkResolver: sdkResolver,
76 fileResolvers: fileResolvers, 101 fileResolvers: fileResolvers,
77 resourceProvider: resourceProvider); 102 resourceProvider: resourceProvider);
78 103
104 compiler.context.resultProvider =
105 new InputPackagesResultProvider(compiler.context, summaryDataStore);
106
79 var compilerOptions = new CompilerOptions.fromArguments(argResults); 107 var compilerOptions = new CompilerOptions.fromArguments(argResults);
80 108
81 var number = 0; 109 var number = 0;
82 110
83 return (String dart) { 111 var compileFn = (String dart) {
84 // Create a new virtual File that contains the given Dart source. 112 // Create a new virtual File that contains the given Dart source.
85 number++; 113 number++;
86 resourceProvider.newFile("/expression$number.dart", dart); 114 resourceProvider.newFile("/expression$number.dart", dart);
87 115
88 var unit = 116 var unit = new BuildUnit(
89 new BuildUnit("", "", ["file:///expression$number.dart"], null); 117 "", "", ["file:///expression$number.dart"], (source) => "");
Jacob 2016/08/03 23:58:32 what is the fn (source) => "" doing? shouldn't it
Jacob 2016/08/03 23:58:32 nit: put {} around number for clarity. e.g. ${num
priscillalee 2016/08/04 16:01:56 It's the libraryToModule function of a BuildUnit.
priscillalee 2016/08/04 16:01:56 Done.
Jacob 2016/08/04 16:27:48 do that everywhere in the file where $number occur
priscillalee 2016/08/04 17:56:33 Done.
90 118
91 JSModuleFile module = compiler.compile(unit, compilerOptions); 119 JSModuleFile module = compiler.compile(unit, compilerOptions);
92 module.errors.forEach(messageHandler); 120 module.errors.forEach(messageHandler);
93 121
94 if (!module.isValid) throw new CompileErrorException(); 122 if (!module.isValid) throw new CompileErrorException();
95 return module.code; 123 return module.code;
96 }; 124 };
125
126 return allowInterop(compileFn);
97 } 127 }
98 } 128 }
99 129
100 /// Thrown when the input source code has errors. 130 /// Thrown when the input source code has errors.
101 class CompileErrorException implements Exception { 131 class CompileErrorException implements Exception {
102 toString() => '\nPlease fix all errors before compiling (warnings are okay).'; 132 toString() => '\nPlease fix all errors before compiling (warnings are okay).';
103 } 133 }
OLDNEW
« web/main.dart ('K') | « web/main.dart ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698