[Lldb-commits] [lldb] [llvm] [LLVM][ADT] Make `scope-exit` CTAD-capable (PR #173131)
Victor Chernyakin via lldb-commits
lldb-commits at lists.llvm.org
Fri Dec 19 18:41:53 PST 2025
https://github.com/localspook updated https://github.com/llvm/llvm-project/pull/173131
>From 23854866e3b630c32657a05be80931656f18254d Mon Sep 17 00:00:00 2001
From: Victor Chernyakin <chernyakin.victor.j at outlook.com>
Date: Fri, 19 Dec 2025 18:20:52 -0800
Subject: [PATCH] [LLVM][ADT] Make `scope-exit` CTAD-capable
---
lldb/source/Plugins/Platform/POSIX/PlatformPOSIX.cpp | 5 ++---
.../Plugins/Platform/Windows/PlatformWindows.cpp | 2 +-
llvm/include/llvm/ADT/ScopeExit.h | 12 +++---------
3 files changed, 6 insertions(+), 13 deletions(-)
diff --git a/lldb/source/Plugins/Platform/POSIX/PlatformPOSIX.cpp b/lldb/source/Plugins/Platform/POSIX/PlatformPOSIX.cpp
index befc28b09d185..555cbfd995781 100644
--- a/lldb/source/Plugins/Platform/POSIX/PlatformPOSIX.cpp
+++ b/lldb/source/Plugins/Platform/POSIX/PlatformPOSIX.cpp
@@ -774,14 +774,13 @@ uint32_t PlatformPOSIX::DoLoadImage(lldb_private::Process *process,
// This will be the address of the storage for paths, if we are using them,
// or nullptr to signal we aren't.
lldb::addr_t path_array_addr = 0x0;
- std::optional<llvm::detail::scope_exit<std::function<void()>>>
- path_array_cleanup;
+ std::optional<llvm::scope_exit<std::function<void()>>> path_array_cleanup;
// This is the address to a buffer large enough to hold the largest path
// conjoined with the library name we're passing in. This is a convenience
// to avoid having to call malloc in the dlopen function.
lldb::addr_t buffer_addr = 0x0;
- std::optional<llvm::detail::scope_exit<std::function<void()>>> buffer_cleanup;
+ std::optional<llvm::scope_exit<std::function<void()>>> buffer_cleanup;
// Set the values into our args and write them to the target:
if (paths != nullptr) {
diff --git a/lldb/source/Plugins/Platform/Windows/PlatformWindows.cpp b/lldb/source/Plugins/Platform/Windows/PlatformWindows.cpp
index c0c26cc5f1954..db2ba368751ea 100644
--- a/lldb/source/Plugins/Platform/Windows/PlatformWindows.cpp
+++ b/lldb/source/Plugins/Platform/Windows/PlatformWindows.cpp
@@ -231,7 +231,7 @@ uint32_t PlatformWindows::DoLoadImage(Process *process,
/* Inject paths parameter into inferior */
lldb::addr_t injected_paths{0x0};
- std::optional<llvm::detail::scope_exit<std::function<void()>>> paths_cleanup;
+ std::optional<llvm::scope_exit<std::function<void()>>> paths_cleanup;
if (paths) {
llvm::SmallVector<llvm::UTF16, 261> search_paths;
diff --git a/llvm/include/llvm/ADT/ScopeExit.h b/llvm/include/llvm/ADT/ScopeExit.h
index 2f13fb65d34d8..04b602a69f7e3 100644
--- a/llvm/include/llvm/ADT/ScopeExit.h
+++ b/llvm/include/llvm/ADT/ScopeExit.h
@@ -15,13 +15,9 @@
#ifndef LLVM_ADT_SCOPEEXIT_H
#define LLVM_ADT_SCOPEEXIT_H
-#include "llvm/Support/Compiler.h"
-
-#include <type_traits>
#include <utility>
namespace llvm {
-namespace detail {
template <typename Callable> class scope_exit {
Callable ExitFunction;
@@ -47,17 +43,15 @@ template <typename Callable> class scope_exit {
}
};
-} // end namespace detail
+template <typename Callable> scope_exit(Callable) -> scope_exit<Callable>;
// Keeps the callable object that is passed in, and execute it at the
// destruction of the returned object (usually at the scope exit where the
// returned object is kept).
//
// Interface is specified by p0052r2.
-template <typename Callable>
-[[nodiscard]] detail::scope_exit<std::decay_t<Callable>>
-make_scope_exit(Callable &&F) {
- return detail::scope_exit<std::decay_t<Callable>>(std::forward<Callable>(F));
+template <typename Callable> [[nodiscard]] auto make_scope_exit(Callable &&F) {
+ return scope_exit(std::forward<Callable>(F));
}
} // end namespace llvm
More information about the lldb-commits
mailing list