![]() System : Linux absol.cf 5.4.0-198-generic #218-Ubuntu SMP Fri Sep 27 20:18:53 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 7.4.33 Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare, Directory : /proc/thread-self/root/usr/lib/llvm-6.0/include/llvm/ADT/ |
Upload File : |
//===- llvm/ADT/ScopeExit.h - Execute code at scope exit --------*- C++ -*-===// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // This file defines the make_scope_exit function, which executes user-defined // cleanup logic at scope exit. // //===----------------------------------------------------------------------===// #ifndef LLVM_ADT_SCOPE_EXIT_H #define LLVM_ADT_SCOPE_EXIT_H #include "llvm/Support/Compiler.h" #include <type_traits> #include <utility> namespace llvm { namespace detail { template <typename Callable> class scope_exit { Callable ExitFunction; public: template <typename Fp> explicit scope_exit(Fp &&F) : ExitFunction(std::forward<Fp>(F)) {} scope_exit(scope_exit &&Rhs) : ExitFunction(std::move(Rhs.ExitFunction)) {} ~scope_exit() { ExitFunction(); } }; } // end namespace detail // 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> LLVM_NODISCARD detail::scope_exit<typename std::decay<Callable>::type> make_scope_exit(Callable &&F) { return detail::scope_exit<typename std::decay<Callable>::type>( std::forward<Callable>(F)); } } // end namespace llvm #endif