diff options
author | scivision <scivision@users.noreply.github.com> | 2023-09-18 03:01:40 (GMT) |
---|---|---|
committer | Brad King <brad.king@kitware.com> | 2023-09-18 20:35:10 (GMT) |
commit | f5ff17fcf29170541805e7fc7f4a74252fe39b10 (patch) | |
tree | eef38695bb40d69488305fd618a85afb424a7e02 /Source | |
parent | d007eb70468437cb7a1f30d160f3b97263cbc087 (diff) | |
download | CMake-f5ff17fcf29170541805e7fc7f4a74252fe39b10.zip CMake-f5ff17fcf29170541805e7fc7f4a74252fe39b10.tar.gz CMake-f5ff17fcf29170541805e7fc7f4a74252fe39b10.tar.bz2 |
Source: Remove redundant FileIsSymlink checks
Replace `FileExists || FileIsSymlink` with `PathExists`.
The latter does not resolve symlinks, so this is OK for use
with broken symlinks, files, and directories.
Diffstat (limited to 'Source')
-rw-r--r-- | Source/cmFileCommand.cxx | 3 | ||||
-rw-r--r-- | Source/cmake.cxx | 2 | ||||
-rw-r--r-- | Source/cmcmd.cxx | 12 |
3 files changed, 7 insertions, 10 deletions
diff --git a/Source/cmFileCommand.cxx b/Source/cmFileCommand.cxx index 49a0e89..93bed9a 100644 --- a/Source/cmFileCommand.cxx +++ b/Source/cmFileCommand.cxx @@ -3020,8 +3020,7 @@ bool HandleCreateLinkCommand(std::vector<std::string> const& args, } // Check if the new file already exists and remove it. - if ((cmSystemTools::FileExists(newFileName) || - cmSystemTools::FileIsSymlink(newFileName)) && + if (cmSystemTools::PathExists(newFileName) && !cmSystemTools::RemoveFile(newFileName)) { std::ostringstream e; e << "Failed to create link '" << newFileName diff --git a/Source/cmake.cxx b/Source/cmake.cxx index 1d8a847..1fa0cbe 100644 --- a/Source/cmake.cxx +++ b/Source/cmake.cxx @@ -3264,7 +3264,7 @@ int cmake::CheckBuildSystem() // If any byproduct of makefile generation is missing we must re-run. cmList products{ mf.GetDefinition("CMAKE_MAKEFILE_PRODUCTS") }; for (auto const& p : products) { - if (!(cmSystemTools::FileExists(p) || cmSystemTools::FileIsSymlink(p))) { + if (!cmSystemTools::PathExists(p)) { if (verbose) { cmSystemTools::Stdout( cmStrCat("Re-run cmake, missing byproduct: ", p, '\n')); diff --git a/Source/cmcmd.cxx b/Source/cmcmd.cxx index 431ffbf..3dcfbf1 100644 --- a/Source/cmcmd.cxx +++ b/Source/cmcmd.cxx @@ -1018,8 +1018,8 @@ int cmcmd::ExecuteCMakeCommand(std::vector<std::string> const& args, // Complain if the -f option was not given and // either file does not exist or // file could not be removed and still exists - bool file_exists_or_forced_remove = cmSystemTools::FileExists(arg) || - cmSystemTools::FileIsSymlink(arg) || force; + bool file_exists_or_forced_remove = + cmSystemTools::PathExists(arg) || force; if (cmSystemTools::FileIsDirectory(arg)) { if (!cmRemoveDirectory(arg, recursive)) { return_value = 1; @@ -1239,8 +1239,7 @@ int cmcmd::ExecuteCMakeCommand(std::vector<std::string> const& args, // supporting them. if (args[1] == "create_symlink" && args.size() == 4) { std::string const& destinationFileName = args[3]; - if ((cmSystemTools::FileExists(destinationFileName) || - cmSystemTools::FileIsSymlink(destinationFileName)) && + if (cmSystemTools::PathExists(destinationFileName) && !cmSystemTools::RemoveFile(destinationFileName)) { std::string emsg = cmSystemTools::GetLastSystemError(); std::cerr << "failed to create symbolic link '" << destinationFileName @@ -1266,8 +1265,7 @@ int cmcmd::ExecuteCMakeCommand(std::vector<std::string> const& args, return 1; } - if ((cmSystemTools::FileExists(destinationFileName) || - cmSystemTools::FileIsSymlink(destinationFileName)) && + if (cmSystemTools::PathExists(destinationFileName) && !cmSystemTools::RemoveFile(destinationFileName)) { std::string emsg = cmSystemTools::GetLastSystemError(); std::cerr << "failed to create hard link '" << destinationFileName @@ -1750,7 +1748,7 @@ int cmcmd::SymlinkExecutable(std::vector<std::string> const& args) cmsys::Status cmcmd::SymlinkInternal(std::string const& file, std::string const& link) { - if (cmSystemTools::FileExists(link) || cmSystemTools::FileIsSymlink(link)) { + if (cmSystemTools::PathExists(link)) { cmSystemTools::RemoveFile(link); } std::string linktext = cmSystemTools::GetFilenameName(file); |