Commit bf751921 authored by Eric Seidel's avatar Eric Seidel

Merge pull request #971 from eseidelGoogle/apk_res

Add support for bundling apk resources
parents 1e888693 64bec536
...@@ -10,6 +10,7 @@ import 'package:path/path.dart' as path; ...@@ -10,6 +10,7 @@ import 'package:path/path.dart' as path;
import '../artifacts.dart'; import '../artifacts.dart';
import '../base/file_system.dart'; import '../base/file_system.dart';
import '../base/logging.dart'; import '../base/logging.dart';
import '../base/process.dart';
import '../build_configuration.dart'; import '../build_configuration.dart';
import '../device.dart'; import '../device.dart';
import '../runner/flutter_command.dart'; import '../runner/flutter_command.dart';
...@@ -66,19 +67,23 @@ class _ApkBuilder { ...@@ -66,19 +67,23 @@ class _ApkBuilder {
return (_androidJar.existsSync() && _aapt.existsSync() && _zipalign.existsSync()); return (_androidJar.existsSync() && _aapt.existsSync() && _zipalign.existsSync());
} }
void package(File outputApk, File androidManifest, Directory assets, Directory artifacts) { void package(File outputApk, File androidManifest, Directory assets, Directory artifacts, Directory resources) {
_run(_aapt.path, [ List<String> packageArgs = [_aapt.path,
'package', 'package',
'-M', androidManifest.path, '-M', androidManifest.path,
'-A', assets.path, '-A', assets.path,
'-I', _androidJar.path, '-I', _androidJar.path,
'-F', outputApk.path, '-F', outputApk.path,
artifacts.path artifacts.path
]); ];
if (resources.existsSync()) {
packageArgs.addAll(['-S', resources.path]);
}
runCheckedSync(packageArgs);
} }
void sign(File keystore, String keystorePassword, String keyName, File outputApk) { void sign(File keystore, String keystorePassword, String keyName, File outputApk) {
_run(_jarsigner, [ runCheckedSync([_jarsigner,
'-keystore', keystore.path, '-keystore', keystore.path,
'-storepass', keystorePassword, '-storepass', keystorePassword,
outputApk.path, outputApk.path,
...@@ -87,17 +92,7 @@ class _ApkBuilder { ...@@ -87,17 +92,7 @@ class _ApkBuilder {
} }
void align(File unalignedApk, File outputApk) { void align(File unalignedApk, File outputApk) {
_run(_zipalign.path, ['-f', '4', unalignedApk.path, outputApk.path]); runCheckedSync([_zipalign.path, '-f', '4', unalignedApk.path, outputApk.path]);
}
void _run(String command, List<String> args, { String workingDirectory }) {
ProcessResult result = Process.runSync(
command, args, workingDirectory: workingDirectory
);
if (result.exitCode == 0)
return;
stdout.write(result.stdout);
stderr.write(result.stderr);
} }
} }
...@@ -108,6 +103,7 @@ class _ApkComponents { ...@@ -108,6 +103,7 @@ class _ApkComponents {
File classesDex; File classesDex;
File libSkyShell; File libSkyShell;
File keystore; File keystore;
Directory resources;
} }
class ApkCommand extends FlutterCommand { class ApkCommand extends FlutterCommand {
...@@ -168,6 +164,8 @@ class ApkCommand extends FlutterCommand { ...@@ -168,6 +164,8 @@ class ApkCommand extends FlutterCommand {
components.classesDex = new File(artifactPaths[1]); components.classesDex = new File(artifactPaths[1]);
components.libSkyShell = new File(artifactPaths[2]); components.libSkyShell = new File(artifactPaths[2]);
components.keystore = new File(artifactPaths[3]); components.keystore = new File(artifactPaths[3]);
// TODO(eseidel): Should this be configurable from flutter.yaml?
components.resources = new Directory('apk/res');
if (!components.androidSdk.existsSync()) { if (!components.androidSdk.existsSync()) {
logging.severe('Can not locate Android SDK: $androidSdkPath'); logging.severe('Can not locate Android SDK: $androidSdkPath');
...@@ -204,7 +202,7 @@ class ApkCommand extends FlutterCommand { ...@@ -204,7 +202,7 @@ class ApkCommand extends FlutterCommand {
_ApkBuilder builder = new _ApkBuilder(components.androidSdk.path); _ApkBuilder builder = new _ApkBuilder(components.androidSdk.path);
File unalignedApk = new File('${tempDir.path}/app.apk.unaligned'); File unalignedApk = new File('${tempDir.path}/app.apk.unaligned');
builder.package(unalignedApk, components.manifest, assetBuilder.directory, builder.package(unalignedApk, components.manifest, assetBuilder.directory,
artifactBuilder.directory); artifactBuilder.directory, components.resources);
builder.sign(components.keystore, _kKeystorePassword, _kKeystoreKeyName, unalignedApk); builder.sign(components.keystore, _kKeystorePassword, _kKeystoreKeyName, unalignedApk);
File finalApk = new File(argResults['output-file']); File finalApk = new File(argResults['output-file']);
......
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