aboutsummaryrefslogtreecommitdiff
path: root/src/net
diff options
context:
space:
mode:
authorluigi1111 <luigi1111w@gmail.com>2021-09-23 22:06:35 -0500
committerluigi1111 <luigi1111w@gmail.com>2021-09-23 22:06:35 -0500
commit237acd120e0da39913bd7b195e2309eff06d639e (patch)
treeff3f9451fb777ed6b3abdfc4ec7cd37ad086cfbf /src/net
parentMerge pull request #7886 (diff)
parentQuicker resource cleanup on p2p socks timeout (diff)
downloadmonero-237acd120e0da39913bd7b195e2309eff06d639e.tar.xz
Merge pull request #7890
2a8a511 Quicker resource cleanup on p2p socks timeout (Lee *!* Clagett)
Diffstat (limited to 'src/net')
-rw-r--r--src/net/socks.h7
1 files changed, 7 insertions, 0 deletions
diff --git a/src/net/socks.h b/src/net/socks.h
index 739c972ab..506b53195 100644
--- a/src/net/socks.h
+++ b/src/net/socks.h
@@ -201,6 +201,13 @@ namespace socks
std::shared_ptr<client> self_;
void operator()(boost::system::error_code error = boost::system::error_code{});
};
+
+ //! Calls `async_close` on `self` at destruction. NOP if `nullptr`.
+ struct close_on_exit
+ {
+ std::shared_ptr<client> self;
+ ~close_on_exit() { async_close{std::move(self)}(); }
+ };
};
template<typename Handler>