mirror of
https://github.com/odin-lang/Odin.git
synced 2026-04-19 04:50:29 +00:00
feat: added a -android-keystore-password option to pass a password for the keystore instead of hardcoding it as android
This commit is contained in:
@@ -554,6 +554,7 @@ struct BuildContext {
|
||||
String ODIN_ANDROID_JAR_SIGNER;
|
||||
String android_keystore;
|
||||
String android_keystore_alias;
|
||||
String android_keystore_password;
|
||||
String android_manifest;
|
||||
};
|
||||
|
||||
@@ -1593,6 +1594,10 @@ gb_internal void init_android_values(bool with_sdk) {
|
||||
gb_printf_err("Error: -android-keystore_alias:<string> has not been set\n");
|
||||
gb_exit(1);
|
||||
}
|
||||
if (bc->android_keystore_password.len == 0) {
|
||||
gb_printf_err("Error: -android-keystore-password:<string> has not been set\n");
|
||||
gb_exit(1);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -172,7 +172,7 @@ i32 bundle_android(String original_init_directory) {
|
||||
gb_string_clear(cmd);
|
||||
|
||||
cmd = gb_string_append_length(cmd, build_context.ODIN_ANDROID_JAR_SIGNER.text, build_context.ODIN_ANDROID_JAR_SIGNER.len);
|
||||
cmd = gb_string_append_fmt(cmd, " -storepass android");
|
||||
cmd = gb_string_append_fmt(cmd, " -storepass \"%.*s\"", LIT(build_context.android_keystore_password));
|
||||
if (build_context.android_keystore.len != 0) {
|
||||
String keystore = normalize_path(temporary_allocator(), build_context.android_keystore, NIX_SEPARATOR_STRING);
|
||||
keystore = substring(keystore, 0, keystore.len - 1);
|
||||
|
||||
@@ -277,6 +277,7 @@ gb_internal void usage(String argv0, String argv1 = {}) {
|
||||
print_usage_line(1, "build Compiles directory of .odin files, as an executable.");
|
||||
print_usage_line(1, " One must contain the program's entry point, all must be in the same package.");
|
||||
print_usage_line(1, "run Same as 'build', but also then runs the newly compiled executable.");
|
||||
print_usage_line(1, "bundle Bundles a directory in a specific layout for that platform.");
|
||||
print_usage_line(1, "check Parses, and type checks a directory of .odin files.");
|
||||
print_usage_line(1, "strip-semicolon Parses, type checks, and removes unneeded semicolons from the entire program.");
|
||||
print_usage_line(1, "test Builds and runs procedures with the attribute @(test) in the initial package.");
|
||||
@@ -411,6 +412,7 @@ enum BuildFlagKind {
|
||||
|
||||
BuildFlag_AndroidKeystore,
|
||||
BuildFlag_AndroidKeystoreAlias,
|
||||
BuildFlag_AndroidKeystorePassword,
|
||||
BuildFlag_AndroidManifest,
|
||||
|
||||
BuildFlag_COUNT,
|
||||
@@ -631,6 +633,7 @@ gb_internal bool parse_build_flags(Array<String> args) {
|
||||
|
||||
add_flag(&build_flags, BuildFlag_AndroidKeystore, str_lit("android-keystore"), BuildFlagParam_String, Command_bundle_android);
|
||||
add_flag(&build_flags, BuildFlag_AndroidKeystoreAlias, str_lit("android-keystore-alias"), BuildFlagParam_String, Command_bundle_android);
|
||||
add_flag(&build_flags, BuildFlag_AndroidKeystorePassword, str_lit("android-keystore-password"), BuildFlagParam_String, Command_bundle_android);
|
||||
add_flag(&build_flags, BuildFlag_AndroidManifest, str_lit("android-manifest"), BuildFlagParam_String, Command_bundle_android);
|
||||
|
||||
|
||||
@@ -1664,6 +1667,11 @@ gb_internal bool parse_build_flags(Array<String> args) {
|
||||
build_context.android_keystore_alias = value.value_string;
|
||||
break;
|
||||
|
||||
case BuildFlag_AndroidKeystorePassword:
|
||||
GB_ASSERT(value.kind == ExactValue_String);
|
||||
build_context.android_keystore_password = value.value_string;
|
||||
break;
|
||||
|
||||
case BuildFlag_AndroidManifest:
|
||||
GB_ASSERT(value.kind == ExactValue_String);
|
||||
build_context.android_manifest = value.value_string;
|
||||
|
||||
Reference in New Issue
Block a user