mirror of
https://github.com/monero-project/monero.git
synced 2024-11-17 08:17:37 +00:00
Merge pull request #8003
75d05b9
download: fix leak (moneromooo-monero)
This commit is contained in:
commit
e7d571c526
1 changed files with 9 additions and 1 deletions
|
@ -53,7 +53,7 @@ namespace tools
|
|||
|
||||
download_thread_control(const std::string &path, const std::string &uri, std::function<void(const std::string&, const std::string&, bool)> result_cb, std::function<bool(const std::string&, const std::string&, size_t, ssize_t)> progress_cb):
|
||||
path(path), uri(uri), result_cb(result_cb), progress_cb(progress_cb), stop(false), stopped(false), success(false) {}
|
||||
~download_thread_control() { if (thread.joinable()) thread.detach(); }
|
||||
~download_thread_control() { if (thread.joinable()) { thread.detach(); thread = {}; } }
|
||||
};
|
||||
|
||||
static void download_thread(download_async_handle control)
|
||||
|
@ -293,9 +293,13 @@ namespace tools
|
|||
{
|
||||
boost::lock_guard<boost::mutex> lock(control->mutex);
|
||||
if (control->stopped)
|
||||
{
|
||||
control->thread = {};
|
||||
return true;
|
||||
}
|
||||
}
|
||||
control->thread.join();
|
||||
control->thread = {};
|
||||
return true;
|
||||
}
|
||||
|
||||
|
@ -305,10 +309,14 @@ namespace tools
|
|||
{
|
||||
boost::lock_guard<boost::mutex> lock(control->mutex);
|
||||
if (control->stopped)
|
||||
{
|
||||
control->thread = {};
|
||||
return true;
|
||||
}
|
||||
control->stop = true;
|
||||
}
|
||||
control->thread.join();
|
||||
control->thread = {};
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue