Commit 3e9ceec0 authored by Adam Barth's avatar Adam Barth

Improve sky_tools build so that it works from sky_engine

With this patch, we can switch over to using this command from the build system
in the sky_engine repo.
parent a75e79f0
...@@ -100,16 +100,24 @@ Future<ArchiveFile> _createFile(String key, String assetBase) async { ...@@ -100,16 +100,24 @@ Future<ArchiveFile> _createFile(String key, String assetBase) async {
} }
Future _compileSnapshot({ Future _compileSnapshot({
String compilerPath,
String mainPath, String mainPath,
String packageRoot, String packageRoot,
String snapshotPath String snapshotPath
}) async { }) async {
File compiler = await artifactStore.getPath(Artifact.FlutterCompiler); File compiler = compilerPath == null ?
await Process.run(compiler.path, [ await artifactStore.getPath(Artifact.FlutterCompiler) :
new File(compilerPath);
ProcessResult result = await Process.run(compiler.path, [
mainPath, mainPath,
'--package-root=$packageRoot', '--package-root=$packageRoot',
'--snapshot=$snapshotPath' '--snapshot=$snapshotPath'
]); ]);
if (result.exitCode != 0) {
print(result.stdout);
print(result.stderr);
exit(result.exitCode);
}
} }
Future<ArchiveFile> _createSnapshotFile(String snapshotPath) async { Future<ArchiveFile> _createSnapshotFile(String snapshotPath) async {
...@@ -125,8 +133,9 @@ class BuildCommandHandler extends CommandHandler { ...@@ -125,8 +133,9 @@ class BuildCommandHandler extends CommandHandler {
ArgParser parser = new ArgParser(); ArgParser parser = new ArgParser();
parser.addFlag('help', abbr: 'h', negatable: false); parser.addFlag('help', abbr: 'h', negatable: false);
parser.addOption('asset-base', defaultsTo: 'packages/material_design_icons/icons'); parser.addOption('asset-base', defaultsTo: 'packages/material_design_icons/icons');
parser.addOption('compiler');
parser.addOption('main', defaultsTo: 'lib/main.dart'); parser.addOption('main', defaultsTo: 'lib/main.dart');
parser.addOption('manifest', defaultsTo: 'flutter.yaml'); parser.addOption('manifest');
parser.addOption('output-file', abbr: 'o', defaultsTo: 'app.flx'); parser.addOption('output-file', abbr: 'o', defaultsTo: 'app.flx');
parser.addOption('package-root', defaultsTo: 'packages'); parser.addOption('package-root', defaultsTo: 'packages');
parser.addOption('snapshot', defaultsTo: 'snapshot_blob.bin'); parser.addOption('snapshot', defaultsTo: 'snapshot_blob.bin');
...@@ -149,6 +158,7 @@ class BuildCommandHandler extends CommandHandler { ...@@ -149,6 +158,7 @@ class BuildCommandHandler extends CommandHandler {
String snapshotPath = results['snapshot']; String snapshotPath = results['snapshot'];
await _compileSnapshot( await _compileSnapshot(
compilerPath: results['compiler'],
mainPath: results['main'], mainPath: results['main'],
packageRoot: results['package-root'], packageRoot: results['package-root'],
snapshotPath: snapshotPath); snapshotPath: snapshotPath);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment