aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJeroen van Rijn <Kelimion@users.noreply.github.com>2024-07-09 20:03:50 +0200
committerJeroen van Rijn <Kelimion@users.noreply.github.com>2024-07-10 14:25:18 +0200
commit8dc4eca4d2940500de30dfb8fd2ec25f7c31eba7 (patch)
treeb9cf2536dbdbc0f2aed935e1e43825e51ce50841
parent34c6868e7836cc24cca1c8fed84bfc5af20e8843 (diff)
Allow using precompiled .res file.
-rw-r--r--src/build_settings.cpp9
-rw-r--r--src/linker.cpp45
-rw-r--r--src/main.cpp6
3 files changed, 34 insertions, 26 deletions
diff --git a/src/build_settings.cpp b/src/build_settings.cpp
index 28ca0f088..4d3e20a7a 100644
--- a/src/build_settings.cpp
+++ b/src/build_settings.cpp
@@ -1805,10 +1805,11 @@ gb_internal bool init_build_paths(String init_filename) {
#if defined(GB_SYSTEM_WINDOWS)
if (bc->metrics.os == TargetOs_windows) {
if (bc->resource_filepath.len > 0) {
- bc->build_paths[BuildPath_RC] = path_from_string(ha, bc->resource_filepath);
- bc->build_paths[BuildPath_RES] = path_from_string(ha, bc->resource_filepath);
- bc->build_paths[BuildPath_RC].ext = copy_string(ha, STR_LIT("rc"));
- bc->build_paths[BuildPath_RES].ext = copy_string(ha, STR_LIT("res"));
+ bc->build_paths[BuildPath_RES] = path_from_string(ha, bc->resource_filepath);
+ if (!string_ends_with(bc->resource_filepath, str_lit(".res"))) {
+ bc->build_paths[BuildPath_RC] = path_from_string(ha, bc->resource_filepath);
+ bc->build_paths[BuildPath_RC].ext = copy_string(ha, STR_LIT("rc"));
+ }
}
if (bc->pdb_filepath.len > 0) {
diff --git a/src/linker.cpp b/src/linker.cpp
index 890a74e5a..ac3e32851 100644
--- a/src/linker.cpp
+++ b/src/linker.cpp
@@ -305,30 +305,35 @@ gb_internal i32 linker_stage(LinkerData *gen) {
defer (gb_free(heap_allocator(), windows_sdk_bin_path.text));
if (!build_context.use_lld) { // msvc
- String res_path = {};
+ 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("\""));
defer (gb_free(heap_allocator(), res_path.text));
+ defer (gb_free(heap_allocator(), rc_path.text));
- // TODO(Jeroen): Add ability to reuse .res file instead of recompiling, if `-resource:file.res` is given.
if (build_context.has_resource) {
- String temp_res_path = path_to_string(heap_allocator(), build_context.build_paths[BuildPath_RES]);
- res_path = concatenate3_strings(heap_allocator(), str_lit("\""), temp_res_path, str_lit("\""));
- gb_free(heap_allocator(), temp_res_path.text);
-
- String temp_rc_path = path_to_string(heap_allocator(), build_context.build_paths[BuildPath_RC]);
- String rc_path = concatenate3_strings(heap_allocator(), str_lit("\""), temp_rc_path, str_lit("\""));
- gb_free(heap_allocator(), temp_rc_path.text);
- defer (gb_free(heap_allocator(), rc_path.text));
-
- result = system_exec_command_line_app("msvc-link",
- "\"%.*src.exe\" /nologo /fo %.*s %.*s",
- LIT(windows_sdk_bin_path),
- LIT(res_path),
- LIT(rc_path)
- );
-
- if (result) {
- return result;
+ if (temp_rc_path == "") {
+ debugf("Using precompiled resource %.*s\n", LIT(res_path));
+ } else {
+ debugf("Compiling resource %.*s\n", LIT(res_path));
+
+ result = system_exec_command_line_app("msvc-link",
+ "\"%.*src.exe\" /nologo /fo %.*s %.*s",
+ LIT(windows_sdk_bin_path),
+ LIT(res_path),
+ LIT(rc_path)
+ );
+
+ if (result) {
+ return result;
+ }
}
+ } else {
+ res_path = {};
}
String linker_name = str_lit("link.exe");
diff --git a/src/main.cpp b/src/main.cpp
index 7763ccd23..e6a0aecf0 100644
--- a/src/main.cpp
+++ b/src/main.cpp
@@ -1452,8 +1452,9 @@ gb_internal bool parse_build_flags(Array<String> args) {
String path = value.value_string;
path = string_trim_whitespace(path);
if (is_build_flag_path_valid(path)) {
- if(!string_ends_with(path, str_lit(".rc"))) {
- gb_printf_err("Invalid -resource path %.*s, missing .rc\n", LIT(path));
+ bool is_resource = string_ends_with(path, str_lit(".rc")) || string_ends_with(path, str_lit(".res"));
+ if(!is_resource) {
+ gb_printf_err("Invalid -resource path %.*s, missing .rc or .res file\n", LIT(path));
bad_flags = true;
break;
} else if (!gb_file_exists((const char *)path.text)) {
@@ -2552,6 +2553,7 @@ gb_internal void print_show_help(String const arg0, String const &command) {
print_usage_line(2, "[Windows only]");
print_usage_line(2, "Defines the resource file for the executable.");
print_usage_line(2, "Example: -resource:path/to/file.rc");
+ print_usage_line(2, "or: -resource:path/to/file.res for a precompiled one.");
print_usage_line(0, "");
print_usage_line(1, "-pdb-name:<filepath>");