Commit b43bd0b1 authored by Matt Perry's avatar Matt Perry

Merge pull request #1365 from mpcomplete/apk2

Support local paths to third-party jars in flutter apk.
parents 9862605f 6610b7ea
...@@ -328,9 +328,10 @@ class ArtifactStore { ...@@ -328,9 +328,10 @@ class ArtifactStore {
File cachedFile = new File( File cachedFile = new File(
path.join(cacheDir.path, url.pathSegments[url.pathSegments.length-1])); path.join(cacheDir.path, url.pathSegments[url.pathSegments.length-1]));
if (!cachedFile.existsSync()) { if (!cachedFile.existsSync()) {
try {
await _downloadFileToCache(url, cachedFile); await _downloadFileToCache(url, cachedFile);
if (!cachedFile.existsSync()) { } catch (e) {
logging.severe('Unable to fetch third-party artifact: $url'); logging.severe('Failed to fetch third-party artifact: $url: $e');
throw new ProcessExit(2); throw new ProcessExit(2);
} }
} }
......
...@@ -194,16 +194,17 @@ class ApkCommand extends FlutterCommand { ...@@ -194,16 +194,17 @@ class ApkCommand extends FlutterCommand {
continue; continue;
components.services.addAll(serviceConfig['services']); components.services.addAll(serviceConfig['services']);
for (String jar in serviceConfig['jars']) { for (String jar in serviceConfig['jars']) {
// Jar might refer to an android SDK jar, or URL to download.
if (jar.startsWith("android-sdk:")) { if (jar.startsWith("android-sdk:")) {
// Jar is something shipped in the standard android SDK.
jar = jar.replaceAll('android-sdk:', '${components.androidSdk.path}/'); jar = jar.replaceAll('android-sdk:', '${components.androidSdk.path}/');
components.jars.add(new File(jar)); components.jars.add(new File(jar));
} else if (jar.startsWith("http")) { } else if (jar.startsWith("http")) {
// Jar is a URL to download.
String cachePath = await ArtifactStore.getThirdPartyFile(jar, service); String cachePath = await ArtifactStore.getThirdPartyFile(jar, service);
components.jars.add(new File(cachePath)); components.jars.add(new File(cachePath));
} else { } else {
logging.severe('Service depends on a jar in an unrecognized format: $jar'); // Assume jar is a path relative to the service's root dir.
throw new ProcessExit(2); components.jars.add(new File(path.join(serviceRoot, jar)));
} }
} }
} }
......
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