aboutsummaryrefslogtreecommitdiff
path: root/src/linker.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2025-03-26 16:05:21 +0000
committergingerBill <bill@gingerbill.org>2025-03-26 16:05:21 +0000
commitd48e7bb0b89d19a9b5b66b5b6f35852125bd3afe (patch)
treeb748a81e1b5727ea46e1df4e31e749ea936dda88 /src/linker.cpp
parentdb82a49576c8e691cf938f7a2a86446f14b73f7c (diff)
Migrate `ODIN_ANDROID_*` constants to `build_settings.cpp`; `-minimum-os-version:<int>` for `-subtarget:android`
Diffstat (limited to 'src/linker.cpp')
-rw-r--r--src/linker.cpp42
1 files changed, 6 insertions, 36 deletions
diff --git a/src/linker.cpp b/src/linker.cpp
index ea0abc5f3..1e6f045b1 100644
--- a/src/linker.cpp
+++ b/src/linker.cpp
@@ -418,43 +418,13 @@ try_cross_linking:;
} else {
timings_start_section(timings, str_lit("ld-link"));
- String ODIN_ANDROID_NDK_PATH = normalize_path(permanent_allocator(), make_string_c(gb_get_env("ODIN_ANDROID_NDK_PATH", permanent_allocator())), NIX_SEPARATOR_STRING);
- String ODIN_ANDROID_NDK_TOOLCHAIN_PATH = normalize_path(permanent_allocator(), make_string_c(gb_get_env("ODIN_ANDROID_NDK_TOOLCHAIN_PATH", permanent_allocator())), NIX_SEPARATOR_STRING);
-
- int ODIN_ANDROID_API_LEVEL = 34;
- if (char const *found = gb_get_env("ODIN_ANDROID_API_LEVEL", permanent_allocator())) {
- int new_level = atoi(found);
- if (new_level >= 34) {
- ODIN_ANDROID_API_LEVEL = new_level;
- } else {
- gb_printf_err("Warning: Invalid ODIN_ANDROID_API_LEVEL '%s', defaulting to %d\n", found, ODIN_ANDROID_API_LEVEL);
- }
- }
-
- String ODIN_ANDROID_NDK_TOOLCHAIN_LIB_PATH = {};
- String ODIN_ANDROID_NDK_TOOLCHAIN_LIB_LEVEL_PATH = {};
- String ODIN_ANDROID_NDK_TOOLCHAIN_SYSROOT_PATH = {};
-
- if (is_android) {
- if (ODIN_ANDROID_NDK_PATH.len == 0) {
- gb_printf_err("Error: ODIN_ANDROID_NDK_PATH not set");
- return 1;
- }
-
- if (ODIN_ANDROID_NDK_TOOLCHAIN_PATH.len == 0) {
- gb_printf_err("Error: ODIN_ANDROID_NDK_PATH not set");
- return 1;
- }
-
- ODIN_ANDROID_NDK_TOOLCHAIN_LIB_PATH = concatenate_strings(permanent_allocator(), ODIN_ANDROID_NDK_TOOLCHAIN_PATH, str_lit("sysroot/usr/lib/aarch64-linux-android/"));
-
- char buf[32] = {};
- gb_snprintf(buf, gb_size_of(buf), "%d/", ODIN_ANDROID_API_LEVEL);
- ODIN_ANDROID_NDK_TOOLCHAIN_LIB_LEVEL_PATH = concatenate_strings(permanent_allocator(), ODIN_ANDROID_NDK_TOOLCHAIN_LIB_PATH, make_string_c(buf));
-
- ODIN_ANDROID_NDK_TOOLCHAIN_SYSROOT_PATH = concatenate_strings(permanent_allocator(), ODIN_ANDROID_NDK_TOOLCHAIN_PATH, str_lit("sysroot/"));
- }
+ int const ODIN_ANDROID_API_LEVEL = build_context.ODIN_ANDROID_API_LEVEL;
+ String ODIN_ANDROID_NDK_PATH = build_context.ODIN_ANDROID_NDK_PATH;
+ String ODIN_ANDROID_NDK_TOOLCHAIN_PATH = build_context.ODIN_ANDROID_NDK_TOOLCHAIN_PATH;
+ String ODIN_ANDROID_NDK_TOOLCHAIN_LIB_PATH = build_context.ODIN_ANDROID_NDK_TOOLCHAIN_LIB_PATH;
+ String ODIN_ANDROID_NDK_TOOLCHAIN_LIB_LEVEL_PATH = build_context.ODIN_ANDROID_NDK_TOOLCHAIN_LIB_LEVEL_PATH;
+ String ODIN_ANDROID_NDK_TOOLCHAIN_SYSROOT_PATH = build_context.ODIN_ANDROID_NDK_TOOLCHAIN_SYSROOT_PATH;
// Link using `clang`, unless overridden by `ODIN_CLANG_PATH` environment variable.
const char* clang_path = gb_get_env("ODIN_CLANG_PATH", permanent_allocator());