From 3eb94ec81b72b14f72a1f6ce5c9aa24476df755a Mon Sep 17 00:00:00 2001 From: Carl Dong Date: Wed, 25 Nov 2020 11:05:23 -0500 Subject: sync: Use decltype(auto) return type for WITH_LOCK Now that we're using C++17, we can use the decltype(auto) return type (available since C++14) for functions and lambda expressions. As demonstrated in this commit, this can simplify cases where previously the compiler failed to deduce the correct return type. Just for reference, for the "assign to ref" cases fixed here, there are 3 possible solutions: - Return a pointer and immediately deref as used before this commit - Make sure the function/lambda returns declspec(auto) as used after this commit - Class& i = WITH_LOCK(..., return std::ref(...)); ----- References: 1. https://en.cppreference.com/w/cpp/language/function#Return_type_deduction 2. https://en.cppreference.com/w/cpp/language/template_argument_deduction#Other_contexts 3. https://en.cppreference.com/w/cpp/language/auto 4. https://en.cppreference.com/w/cpp/language/decltype Explanations: 1. https://stackoverflow.com/a/21369192 2. https://stackoverflow.com/a/21369170 3. Item 3 in Effective Modern C++ (Scott Meyers) via jnewbery --- src/sync.h | 17 ++++++++++++++++- 1 file changed, 16 insertions(+), 1 deletion(-) (limited to 'src/sync.h') diff --git a/src/sync.h b/src/sync.h index 0948083c7f..faabec2c2d 100644 --- a/src/sync.h +++ b/src/sync.h @@ -256,7 +256,22 @@ using DebugLock = UniqueLock decltype(auto) { LOCK(cs); code; }() class CSemaphore { -- cgit v1.2.3