Commit 7b19d08c authored by Alhaad Gokhale's avatar Alhaad Gokhale

Use --devtools flag to run_mojo.

That way we can control if we want to use devtools to run on Linux and
also cleanly separate out the two uses.

R=@jamesr
parent aafce51e
...@@ -15,8 +15,6 @@ import '../process.dart'; ...@@ -15,8 +15,6 @@ import '../process.dart';
final Logger _logging = new Logger('sky_tools.run_mojo'); final Logger _logging = new Logger('sky_tools.run_mojo');
enum _MojoConfig { Debug, Release }
class RunMojoCommand extends Command { class RunMojoCommand extends Command {
final String name = 'run_mojo'; final String name = 'run_mojo';
final String description = 'Run a Flutter app in mojo.'; final String description = 'Run a Flutter app in mojo.';
...@@ -28,7 +26,8 @@ class RunMojoCommand extends Command { ...@@ -28,7 +26,8 @@ class RunMojoCommand extends Command {
argParser.addFlag('mojo-release', negatable: false, help: 'Use Release build of mojo (default)'); argParser.addFlag('mojo-release', negatable: false, help: 'Use Release build of mojo (default)');
argParser.addOption('app', defaultsTo: 'app.flx'); argParser.addOption('app', defaultsTo: 'app.flx');
argParser.addOption('mojo-path', help: 'Path to directory containing mojo_shell and services for Linux and to mojo devtools from Android.'); argParser.addOption('mojo-path', help: 'Path to directory containing mojo_shell and services.');
argParser.addOption('devtools-path', help: 'Path to mojo devtools\' mojo_run command.');
} }
// TODO(abarth): Why not use path.absolute? // TODO(abarth): Why not use path.absolute?
...@@ -40,49 +39,74 @@ class RunMojoCommand extends Command { ...@@ -40,49 +39,74 @@ class RunMojoCommand extends Command {
return file.absolute.path; return file.absolute.path;
} }
Future<int> _runAndroid(String devtoolsPath, _MojoConfig mojoConfig, String appPath, List<String> additionalArgs) { bool _useDevtools() {
String skyViewerUrl = ArtifactStore.getCloudStorageBaseUrl('viewer', 'android-arm'); if (argResults['android'] || argResults['devtools-path'] != null) {
String command = _makePathAbsolute(devtoolsPath); return true;
String appName = path.basename(appPath); }
String appDir = path.dirname(appPath); return false;
String buildFlag = mojoConfig == _MojoConfig.Debug ? '--debug' : '--release'; }
List<String> cmd = [
command, String _getDevtoolsPath() {
'--android', if (argResults['devtools-path'] != null) {
buildFlag, return _makePathAbsolute(argResults['devtools-path']);
'http://app/$appName',
'--map-origin=http://app/=$appDir',
'--map-origin=http://sky_viewer/=$skyViewerUrl',
'--url-mappings=mojo:sky_viewer=http://sky_viewer/sky_viewer.mojo',
];
if (_logging.level <= Level.INFO) {
cmd.add('--verbose');
if (_logging.level <= Level.FINE) {
cmd.add('--verbose');
}
} }
cmd.addAll(additionalArgs); return _makePathAbsolute(path.join(argResults['mojo-path'], 'mojo', 'devtools', 'common', 'mojo_run'));
return runCommandAndStreamOutput(cmd); }
String _getMojoShellPath() {
final mojoBuildType = argResults['mojo-debug'] ? 'Debug' : 'Release';
return _makePathAbsolute(path.join(argResults['mojo-path'], 'out', mojoBuildType, 'mojo_shell'));
} }
Future<int> _runLinux(String mojoPath, _MojoConfig mojoConfig, String appPath, List<String> additionalArgs) async { Future<List<String>> _getShellConfig() async {
Artifact artifact = ArtifactStore.getArtifact(type: ArtifactType.viewer, targetPlatform: TargetPlatform.linux); List<String> args = [];
String viewerPath = _makePathAbsolute(await ArtifactStore.getPath(artifact));
String mojoBuildType = mojoConfig == _MojoConfig.Debug ? 'Debug' : 'Release'; final useDevtools = _useDevtools();
String mojoShellPath = _makePathAbsolute(path.join(mojoPath, 'out', mojoBuildType, 'mojo_shell')); final command = useDevtools ? _getDevtoolsPath() : _getMojoShellPath();
List<String> cmd = [ args.add(command);
mojoShellPath,
'file://${appPath}', if (argResults['android']) {
'--url-mappings=mojo:sky_viewer=file://${viewerPath}' args.add('--android');
]; final skyViewerUrl = ArtifactStore.getCloudStorageBaseUrl('viewer', 'android-arm');
cmd.addAll(additionalArgs); final appPath = _makePathAbsolute(argResults['app']);
return runCommandAndStreamOutput(cmd); final appName = path.basename(appPath);
final appDir = path.dirname(appPath);
args.add('http://app/$appName');
args.add('--map-origin=http://app/=$appDir');
args.add('--map-origin=http://sky_viewer/=$skyViewerUrl');
args.add('--url-mappings=mojo:sky_viewer=http://sky_viewer/sky_viewer.mojo');
} else {
final appPath = _makePathAbsolute(argResults['app']);
Artifact artifact = ArtifactStore.getArtifact(type: ArtifactType.viewer, targetPlatform: TargetPlatform.linux);
final viewerPath = _makePathAbsolute(await ArtifactStore.getPath(artifact));
args.add('file://${appPath}');
args.add('--url-mappings=mojo:sky_viewer=file://${viewerPath}');
}
if (useDevtools) {
final buildFlag = argResults['mojo-debug'] ? '--debug' : '--release';
args.add(buildFlag);
if (_logging.level <= Level.INFO) {
args.add('--verbose');
if (_logging.level <= Level.FINE) {
args.add('--verbose');
}
}
}
if (argResults['checked']) {
args.add('--args-for=mojo:sky_viewer --enable-checked-mode');
}
args.addAll(argResults.rest);
print(args);
return args;
} }
@override @override
Future<int> run() async { Future<int> run() async {
if (argResults['mojo-path'] == null) { if ((argResults['mojo-path'] == null && argResults['devtools-path'] == null) || (argResults['mojo-path'] != null && argResults['devtools-path'] != null)) {
_logging.severe('Must specify --mojo-path.'); _logging.severe('Must specify either --mojo-path or --devtools-path.');
return 1; return 1;
} }
...@@ -90,19 +114,7 @@ class RunMojoCommand extends Command { ...@@ -90,19 +114,7 @@ class RunMojoCommand extends Command {
_logging.severe('Cannot specify both --mojo-debug and --mojo-release'); _logging.severe('Cannot specify both --mojo-debug and --mojo-release');
return 1; return 1;
} }
List<String> args = [];
if (argResults['checked']) {
args.add('--args-for=mojo:sky_viewer --enable-checked-mode');
}
String mojoPath = argResults['mojo-path'];
_MojoConfig mojoConfig = argResults['mojo-debug'] ? _MojoConfig.Debug : _MojoConfig.Release;
String appPath = _makePathAbsolute(argResults['app']);
args.addAll(argResults.rest); return runCommandAndStreamOutput(await _getShellConfig());
if (argResults['android']) {
return _runAndroid(mojoPath, mojoConfig, appPath, args);
} else {
return _runLinux(mojoPath, mojoConfig, appPath, args);
}
} }
} }
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