Commit 02510dd8 authored by Kris Giesing's avatar Kris Giesing

Allow run_mojo --android to specify location of flutter engine

parent 0e290946
...@@ -70,7 +70,8 @@ class RunMojoCommand extends FlutterCommand { ...@@ -70,7 +70,8 @@ class RunMojoCommand extends FlutterCommand {
BuildConfiguration _getCurrentHostConfig() { BuildConfiguration _getCurrentHostConfig() {
BuildConfiguration result; BuildConfiguration result;
TargetPlatform target = getCurrentHostPlatformAsTarget(); TargetPlatform target = argResults['android'] ?
TargetPlatform.android : getCurrentHostPlatformAsTarget();
for (BuildConfiguration config in buildConfigurations) { for (BuildConfiguration config in buildConfigurations) {
if (config.targetPlatform == target) { if (config.targetPlatform == target) {
result = config; result = config;
...@@ -87,20 +88,25 @@ class RunMojoCommand extends FlutterCommand { ...@@ -87,20 +88,25 @@ class RunMojoCommand extends FlutterCommand {
final String command = useDevtools ? _getDevtoolsPath() : _getMojoShellPath(); final String command = useDevtools ? _getDevtoolsPath() : _getMojoShellPath();
args.add(command); args.add(command);
BuildConfiguration config = _getCurrentHostConfig();
if (argResults['android']) { if (argResults['android']) {
args.add('--android'); args.add('--android');
final String cloudStorageBaseUrl = ArtifactStore.getCloudStorageBaseUrl('android-arm');
final String appPath = _makePathAbsolute(bundlePath); final String appPath = _makePathAbsolute(bundlePath);
final String appName = path.basename(appPath); final String appName = path.basename(appPath);
final String appDir = path.dirname(appPath); final String appDir = path.dirname(appPath);
args.add('http://app/$appName'); args.add('http://app/$appName');
args.add('--map-origin=http://app/=$appDir'); args.add('--map-origin=http://app/=$appDir');
if (config == null || config.type == BuildType.prebuilt) {
final String cloudStorageBaseUrl = ArtifactStore.getCloudStorageBaseUrl('android-arm');
args.add('--map-origin=http://flutter/=$cloudStorageBaseUrl'); args.add('--map-origin=http://flutter/=$cloudStorageBaseUrl');
} else {
args.add('--map-origin=http://flutter/=${config.buildDir}');
}
args.add('--url-mappings=mojo:flutter=http://flutter/flutter.mojo'); args.add('--url-mappings=mojo:flutter=http://flutter/flutter.mojo');
} else { } else {
final String appPath = _makePathAbsolute(bundlePath); final String appPath = _makePathAbsolute(bundlePath);
String flutterPath; String flutterPath;
BuildConfiguration config = _getCurrentHostConfig();
if (config == null || config.type == BuildType.prebuilt) { if (config == null || config.type == BuildType.prebuilt) {
Artifact artifact = ArtifactStore.getArtifact(type: ArtifactType.mojo, targetPlatform: TargetPlatform.linux); Artifact artifact = ArtifactStore.getArtifact(type: ArtifactType.mojo, targetPlatform: TargetPlatform.linux);
flutterPath = _makePathAbsolute(await ArtifactStore.getPath(artifact)); flutterPath = _makePathAbsolute(await ArtifactStore.getPath(artifact));
......
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