summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2023-07-07 14:28:26 (GMT)
committerKitware Robot <kwrobot@kitware.com>2023-07-07 14:28:36 (GMT)
commit64e66b4be310dd0a5cb2ea61092eb97b8ec4f574 (patch)
tree0a9ac86d1cf15fd3eddf108643b961d1a94a643c
parentc8683029f315b0635a2384dcbb676f706c279ceb (diff)
parent8a07bcc149d9c886cee924d9a68c8001b1011ae3 (diff)
downloadCMake-64e66b4be310dd0a5cb2ea61092eb97b8ec4f574.zip
CMake-64e66b4be310dd0a5cb2ea61092eb97b8ec4f574.tar.gz
CMake-64e66b4be310dd0a5cb2ea61092eb97b8ec4f574.tar.bz2
Merge topic 'msvc-embed-manifest-direct' into release-3.27
8a07bcc149 MSVC: Restore support for non-incremental linking without 'rc' in PATH Acked-by: Kitware Robot <kwrobot@kitware.com> Acked-by: buildbot <buildbot@kitware.com> Merge-request: !8613
-rw-r--r--Source/cmcmd.cxx20
1 files changed, 20 insertions, 0 deletions
diff --git a/Source/cmcmd.cxx b/Source/cmcmd.cxx
index 9929e85..0c8d8db 100644
--- a/Source/cmcmd.cxx
+++ b/Source/cmcmd.cxx
@@ -2502,6 +2502,26 @@ int cmVSLink::LinkIncremental()
int cmVSLink::LinkNonIncremental()
{
+ // The MSVC link tool expects 'rc' to be in the PATH if it needs to embed
+ // manifests, but the user might explicitly set 'CMAKE_RC_COMPILER' instead.
+ // Add its location as a fallback at the end of PATH.
+ if (cmSystemTools::FileIsFullPath(this->RcPath)) {
+ std::string rcDir = cmSystemTools::GetFilenamePath(this->RcPath);
+#ifdef _WIN32
+ std::replace(rcDir.begin(), rcDir.end(), '/', '\\');
+ char const pathSep = ';';
+#else
+ char const pathSep = ':';
+#endif
+ cm::optional<std::string> path = cmSystemTools::GetEnvVar("PATH");
+ if (path) {
+ path = cmStrCat(*path, pathSep, rcDir);
+ } else {
+ path = rcDir;
+ }
+ cmSystemTools::PutEnv(cmStrCat("PATH=", *path));
+ }
+
// Sort out any manifests.
if (this->LinkGeneratesManifest || !this->UserManifests.empty()) {
std::string opt =