summaryrefslogtreecommitdiff
path: root/src/task_ld.cc
diff options
context:
space:
mode:
authorBent Bisballe Nyeng <deva@aasimon.org>2025-04-02 21:54:55 +0200
committerBent Bisballe Nyeng <deva@aasimon.org>2025-12-23 18:32:57 +0100
commit4d0fa88d4b189d12005f36b076173d01a0d7bb87 (patch)
tree4fae3689d84c5858630be01d806adb6d142a434c /src/task_ld.cc
parenta43e4eeb6a8c1b0906f5af0b964a301d2ec0321b (diff)
Diffstat (limited to 'src/task_ld.cc')
-rw-r--r--src/task_ld.cc29
1 files changed, 26 insertions, 3 deletions
diff --git a/src/task_ld.cc b/src/task_ld.cc
index c7014ff..2808d78 100644
--- a/src/task_ld.cc
+++ b/src/task_ld.cc
@@ -110,6 +110,7 @@ int TaskLD::runInner()
}
append(args, ld_option(toolchain, ctor::ld_opt::output, targetFile().string()));
+ append(args, to_strings(toolchain, {ctor::toolchain::msvc, ctor::ld_opt::custom, "/nologo"}));
{ // Write flags to file.
std::ofstream flagsStream(flagsFile);
@@ -124,11 +125,33 @@ int TaskLD::runInner()
auto tool = compiler();
const auto& cfg = ctor::get_configuration();
- auto ldflags = cfg.getenv("LDFLAGS");
- if(!ldflags.empty())
+ switch(toolchain)
{
- append(args, ld_option(toolchain, ctor::ld_opt::custom, ldflags));
+ case ctor::toolchain::msvc:
+ switch(outputSystem())
+ {
+ case ctor::output_system::host:
+ tool = cfg.get(ctor::cfg::host_ld, "link.exe");
+ break;
+ case ctor::output_system::build:
+ tool = cfg.get(ctor::cfg::build_ld, "link.exe");
+ break;
+ }
+ break;
+ case ctor::toolchain::gcc:
+ case ctor::toolchain::clang:
+ case ctor::toolchain::any:
+ case ctor::toolchain::none:
+ {
+ auto ldflags = cfg.getenv("LDFLAGS");
+ if(!ldflags.empty())
+ {
+ append(args, ld_option(toolchain, ctor::ld_opt::custom, ldflags));
+ }
+ }
+ break;
}
+
auto res = execute(settings, tool, args, cfg.env, is_self);
if(res != 0)
{