From 7a99a7008c0807fb6b9dff230d45847a584e6de9 Mon Sep 17 00:00:00 2001 From: Max Kellermann Date: Mon, 22 May 2023 14:44:32 +0200 Subject: [PATCH] util/ScopeExit: use std::exchange() --- src/util/ScopeExit.hxx | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/src/util/ScopeExit.hxx b/src/util/ScopeExit.hxx index 8dc0e2c70..a53282676 100644 --- a/src/util/ScopeExit.hxx +++ b/src/util/ScopeExit.hxx @@ -43,9 +43,8 @@ public: explicit ScopeExitGuard(F &&f) noexcept:F(std::forward(f)) {} ScopeExitGuard(ScopeExitGuard &&src) noexcept - :F(std::move(src)), enabled(src.enabled) { - src.enabled = false; - } + :F(std::move(src)), + enabled(std::exchange(src.enabled, false)) {} /* destructors are "noexcept" by default; this explicit "noexcept" declaration allows the destructor to throw if