From b2b0f0db39f806be2df64fc50a3f1849e04bd8a6 Mon Sep 17 00:00:00 2001 From: Charles Kerr Date: Sun, 5 Mar 2023 23:42:52 -0600 Subject: [PATCH] fix: crash in curl_easy_pause() (#5161) --- libtransmission/web.cc | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/libtransmission/web.cc b/libtransmission/web.cc index ea38bb841..343318510 100644 --- a/libtransmission/web.cc +++ b/libtransmission/web.cc @@ -351,6 +351,8 @@ public: return; } + impl.paused_easy_handles.erase(easy_); + if (auto const url = tr_urlParse(options.url); url) { curl_easy_reset(easy); @@ -462,7 +464,7 @@ public: // again when the transfer is unpaused. if (task->impl.mediator.clamp(*tag, bytes_used) < bytes_used) { - task->impl.paused_easy_handles.emplace(tr_time_msec(), task->easy()); + task->impl.paused_easy_handles.emplace(task->easy(), tr_time_msec()); return CURL_WRITEFUNC_PAUSE; } @@ -601,9 +603,9 @@ public: for (auto it = std::begin(paused); it != std::end(paused);) { - if (it->first + BandwidthPauseMsec < now) + if (it->second + BandwidthPauseMsec < now) { - curl_easy_pause(it->second, CURLPAUSE_CONT); + curl_easy_pause(it->first, CURLPAUSE_CONT); it = paused.erase(it); } else @@ -777,7 +779,7 @@ public: static inline auto curl_init_flag = std::once_flag{}; - std::multimap paused_easy_handles; + std::map paused_easy_handles; static void curlInit() {