summaryrefslogtreecommitdiffstats
path: root/Source/cmSystemTools.cxx
diff options
context:
space:
mode:
authorAlex Richardson <Alexander.Richardson@cl.cam.ac.uk>2021-06-17 14:22:34 (GMT)
committerBrad King <brad.king@kitware.com>2021-06-24 14:57:51 (GMT)
commit115ff6a347a96eb77abcd8df5e72e4851dcea414 (patch)
tree925a33815ef6168c56eeec955ac4f356256ddf64 /Source/cmSystemTools.cxx
parent5dfa3ddbe592add43e2985dad772f6aa44d37c0b (diff)
downloadCMake-115ff6a347a96eb77abcd8df5e72e4851dcea414.zip
CMake-115ff6a347a96eb77abcd8df5e72e4851dcea414.tar.gz
CMake-115ff6a347a96eb77abcd8df5e72e4851dcea414.tar.bz2
cmELF: Include the ELF parsing code unconditionally
Now that the ELF definitions are provided on all platforms there is no need to keep the CMake_USE_ELF_PARSER option.
Diffstat (limited to 'Source/cmSystemTools.cxx')
-rw-r--r--Source/cmSystemTools.cxx36
1 files changed, 3 insertions, 33 deletions
diff --git a/Source/cmSystemTools.cxx b/Source/cmSystemTools.cxx
index d6b8208..f082ae8 100644
--- a/Source/cmSystemTools.cxx
+++ b/Source/cmSystemTools.cxx
@@ -20,6 +20,7 @@
#include <cm3p/uv.h>
#include "cmDuration.h"
+#include "cmELF.h"
#include "cmMessageMetadata.h"
#include "cmProcessOutput.h"
#include "cmRange.h"
@@ -46,12 +47,6 @@
# include "cmCryptoHash.h"
#endif
-#if defined(CMake_USE_ELF_PARSER)
-# include "cmELF.h"
-#else
-class cmELF;
-#endif
-
#if defined(CMake_USE_MACH_PARSER)
# include "cmMachO.h"
#endif
@@ -2448,14 +2443,12 @@ void cmSystemTools::MakefileColorEcho(int color, const char* message,
bool cmSystemTools::GuessLibrarySOName(std::string const& fullPath,
std::string& soname)
{
-// For ELF shared libraries use a real parser to get the correct
-// soname.
-#if defined(CMake_USE_ELF_PARSER)
+ // For ELF shared libraries use a real parser to get the correct
+ // soname.
cmELF elf(fullPath.c_str());
if (elf) {
return elf.GetSOName(soname);
}
-#endif
// If the file is not a symlink we have no guess for its soname.
if (!cmSystemTools::FileIsSymlink(fullPath)) {
@@ -2543,14 +2536,6 @@ cm::optional<bool> AdjustRPathELF(std::string const& file,
const AdjustCallback& adjustCallback,
std::string* emsg, bool* changed)
{
-#if !defined(CMake_USE_ELF_PARSER)
- (void)file;
- (void)emptyCallback;
- (void)adjustCallback;
- (void)emsg;
- (void)changed;
- return cm::nullopt; // Cannot handle ELF files.
-#else
if (changed) {
*changed = false;
}
@@ -2678,7 +2663,6 @@ cm::optional<bool> AdjustRPathELF(std::string const& file,
*changed = true;
}
return true;
-#endif
}
std::function<bool(std::string*, const cmELF&)> MakeEmptyCallback(
@@ -2690,16 +2674,11 @@ std::function<bool(std::string*, const cmELF&)> MakeEmptyCallback(
// okay.
return true;
}
-#if defined(CMake_USE_ELF_PARSER)
if (emsg) {
*emsg =
cmStrCat("No valid ELF RPATH or RUNPATH entry exists in the file; ",
elf.GetErrorMessage());
}
-#else
- static_cast<void>(emsg);
- static_cast<void>(elf);
-#endif
return false;
};
}
@@ -3033,12 +3012,6 @@ int cmSystemTools::strverscmp(std::string const& lhs, std::string const& rhs)
static cm::optional<bool> RemoveRPathELF(std::string const& file,
std::string* emsg, bool* removed)
{
-#if !defined(CMake_USE_ELF_PARSER)
- (void)file;
- (void)emsg;
- (void)removed;
- return cm::nullopt; // Cannot handle ELF files.
-#else
if (removed) {
*removed = false;
}
@@ -3177,7 +3150,6 @@ static cm::optional<bool> RemoveRPathELF(std::string const& file,
*removed = true;
}
return true;
-#endif
}
static cm::optional<bool> RemoveRPathXCOFF(std::string const& file,
@@ -3224,7 +3196,6 @@ bool cmSystemTools::RemoveRPath(std::string const& file, std::string* emsg,
bool cmSystemTools::CheckRPath(std::string const& file,
std::string const& newRPath)
{
-#if defined(CMake_USE_ELF_PARSER)
// Parse the ELF binary.
cmELF elf(file.c_str());
if (elf) {
@@ -3247,7 +3218,6 @@ bool cmSystemTools::CheckRPath(std::string const& file,
}
return false;
}
-#endif
#if defined(CMake_USE_XCOFF_PARSER)
// Parse the XCOFF binary.
cmXCOFF xcoff(file.c_str());