aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJeroen van Rijn <Kelimion@users.noreply.github.com>2024-07-10 15:09:13 +0200
committerJeroen van Rijn <Kelimion@users.noreply.github.com>2024-07-10 15:09:13 +0200
commitcc73e06a46cbefd2afa4caa7ef95ba6d9ab64eb9 (patch)
treeab8582b26760c023d37d525f355046aacf93944f /src
parent8dc4eca4d2940500de30dfb8fd2ec25f7c31eba7 (diff)
Allow precompiled resources with -resource:foo.res
And add them to the magic new feature.
Diffstat (limited to 'src')
-rw-r--r--src/cached.cpp11
-rw-r--r--src/linker.cpp11
-rw-r--r--src/path.cpp7
3 files changed, 21 insertions, 8 deletions
diff --git a/src/cached.cpp b/src/cached.cpp
index 02cb1ae96..36927496d 100644
--- a/src/cached.cpp
+++ b/src/cached.cpp
@@ -200,6 +200,17 @@ gb_internal bool try_cached_build(Checker *c, Array<String> const &args) {
}
}
+ // Add Windows resource file to file list, if applicable
+ if (build_context.has_resource) {
+ String res_path = {};
+ if (build_context.build_paths[BuildPath_RC].basename == "") {
+ res_path = path_to_string(heap_allocator(), build_context.build_paths[BuildPath_RES]);
+ } else {
+ res_path = path_to_string(heap_allocator(), build_context.build_paths[BuildPath_RC]);
+ }
+ array_add(&files, res_path);
+ }
+
for (auto const &entry : c->info.load_file_cache) {
auto *cache = entry.value;
if (!cache || !cache->exists) {
diff --git a/src/linker.cpp b/src/linker.cpp
index ac3e32851..046e72d0e 100644
--- a/src/linker.cpp
+++ b/src/linker.cpp
@@ -305,18 +305,13 @@ gb_internal i32 linker_stage(LinkerData *gen) {
defer (gb_free(heap_allocator(), windows_sdk_bin_path.text));
if (!build_context.use_lld) { // msvc
- String temp_res_path = path_to_string(heap_allocator(), build_context.build_paths[BuildPath_RES]);
- String temp_rc_path = path_to_string(heap_allocator(), build_context.build_paths[BuildPath_RC]);
- defer (gb_free(heap_allocator(), temp_res_path.text));
- defer (gb_free(heap_allocator(), temp_rc_path.text));
-
- String res_path = concatenate3_strings(heap_allocator(), str_lit("\""), temp_res_path, str_lit("\""));
- String rc_path = concatenate3_strings(heap_allocator(), str_lit("\""), temp_rc_path, str_lit("\""));
+ String res_path = quote_path(heap_allocator(), build_context.build_paths[BuildPath_RES]);
+ String rc_path = quote_path(heap_allocator(), build_context.build_paths[BuildPath_RC]);
defer (gb_free(heap_allocator(), res_path.text));
defer (gb_free(heap_allocator(), rc_path.text));
if (build_context.has_resource) {
- if (temp_rc_path == "") {
+ if (build_context.build_paths[BuildPath_RC].basename == "") {
debugf("Using precompiled resource %.*s\n", LIT(res_path));
} else {
debugf("Compiling resource %.*s\n", LIT(res_path));
diff --git a/src/path.cpp b/src/path.cpp
index 26ccb7cbf..2c08ddd98 100644
--- a/src/path.cpp
+++ b/src/path.cpp
@@ -152,6 +152,13 @@ gb_internal String path_to_string(gbAllocator a, Path path) {
return res;
}
+gb_internal String quote_path(gbAllocator a, Path path) {
+ String temp = path_to_string(a, path);
+ String quoted = concatenate3_strings(a, str_lit("\""), temp, str_lit("\""));
+ gb_free(a, temp.text);
+ return quoted;
+}
+
// NOTE(Jeroen): Naively turns a Path into a string, then normalizes it using `path_to_full_path`.
gb_internal String path_to_full_path(gbAllocator a, Path path) {
String temp = path_to_string(heap_allocator(), path);