Skip to content

Commit

Permalink
Implemented cache flushed callbacks in torrent handling.
Browse files Browse the repository at this point in the history
  • Loading branch information
joriscarrier committed Nov 18, 2023
1 parent e36445a commit 51db89b
Show file tree
Hide file tree
Showing 6 changed files with 17 additions and 14 deletions.
5 changes: 3 additions & 2 deletions include/libtorrent/alert_types.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -1888,10 +1888,11 @@ TORRENT_VERSION_NAMESPACE_3
// enabled to let this alert through. The alert is also posted when removing
// a torrent from the session, once the outstanding cache flush is complete
// and the torrent does no longer have any files open.
struct TORRENT_EXPORT cache_flushed_alert final : torrent_alert
struct TORRENT_EXPORT cache_flushed_alert final : torrent_alert, callback_t<cache_flushed_alert>
{
// internal
TORRENT_UNEXPORT cache_flushed_alert(aux::stack_allocator& alloc, torrent_handle const& h);
TORRENT_UNEXPORT cache_flushed_alert(aux::stack_allocator& alloc,
torrent_handle const& h, callback_t<cache_flushed_alert>::type callback = {});

TORRENT_DEFINE_ALERT_PRIO(cache_flushed_alert, 58, alert_priority::high)

Expand Down
4 changes: 2 additions & 2 deletions include/libtorrent/torrent.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -565,7 +565,7 @@ namespace libtorrent {
bool has_error() const { return !!m_error; }
error_code error() const { return m_error; }

void flush_cache();
void flush_cache(callback_t<cache_flushed_alert>::type callback = {});
void pause(pause_flags_t flags = {});
void resume();

Expand Down Expand Up @@ -1309,7 +1309,7 @@ namespace libtorrent {
void on_file_renamed(std::string const& filename
, file_index_t file_idx
, storage_error const& error);
void on_cache_flushed(bool manually_triggered);
void on_cache_flushed(bool manually_triggered, callback_t<cache_flushed_alert>::type callback = {});

// this is used when a torrent is being removed.It synchronizes with the
// disk thread
Expand Down
3 changes: 2 additions & 1 deletion include/libtorrent/torrent_handle.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -88,6 +88,7 @@ namespace aux {
#endif

struct read_piece_alert;
struct cache_flushed_alert;

using status_flags_t = flags::bitfield_flag<std::uint32_t, struct status_flags_tag>;
using add_piece_flags_t = flags::bitfield_flag<std::uint8_t, struct add_piece_flags_tag>;
Expand Down Expand Up @@ -662,7 +663,7 @@ namespace aux {
// more data for the torrent, but you are guaranteed that whatever cached
// data libtorrent had by the time you called
// ``torrent_handle::flush_cache()`` has been written to disk.
void flush_cache() const;
void flush_cache(callback_t<cache_flushed_alert>::type callback = {}) const;

// ``force_recheck`` puts the torrent back in a state where it assumes to
// have no resume data. All peers will be disconnected and the torrent
Expand Down
5 changes: 3 additions & 2 deletions src/alert.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1565,8 +1565,9 @@ namespace {
#endif // TORRENT_ABI_VERSION

cache_flushed_alert::cache_flushed_alert(aux::stack_allocator& alloc
, torrent_handle const& h)
: torrent_alert(alloc, h) {}
, torrent_handle const& h, callback_t<cache_flushed_alert>::type c)
: torrent_alert(alloc, h)
, callback_t<cache_flushed_alert>(std::move(c)) {}

#if TORRENT_ABI_VERSION == 1
anonymous_mode_alert::anonymous_mode_alert(aux::stack_allocator& alloc
Expand Down
10 changes: 5 additions & 5 deletions src/torrent.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -8398,7 +8398,7 @@ namespace {
{
// we need to keep the object alive during this operation
m_ses.disk_thread().async_release_files(m_storage
, std::bind(&torrent::on_cache_flushed, shared_from_this(), false));
, std::bind(&torrent::on_cache_flushed, shared_from_this(), false, nullptr));
m_ses.deferred_submit_jobs();
}

Expand Down Expand Up @@ -9463,7 +9463,7 @@ namespace {
&& !m_session_paused;
}

void torrent::flush_cache()
void torrent::flush_cache(callback_t<cache_flushed_alert>::type callback)
{
TORRENT_ASSERT(is_single_thread());

Expand All @@ -9474,18 +9474,18 @@ namespace {
return;
}
m_ses.disk_thread().async_release_files(m_storage
, std::bind(&torrent::on_cache_flushed, shared_from_this(), true));
, std::bind(&torrent::on_cache_flushed, shared_from_this(), true, callback));
m_ses.deferred_submit_jobs();
}

void torrent::on_cache_flushed(bool const manually_triggered) try
void torrent::on_cache_flushed(bool const manually_triggered, callback_t<cache_flushed_alert>::type callback) try
{
TORRENT_ASSERT(is_single_thread());

if (m_ses.is_aborted()) return;

if (manually_triggered || alerts().should_post<cache_flushed_alert>())
alerts().emplace_alert<cache_flushed_alert>(get_handle());
alerts().emplace_alert<cache_flushed_alert>(get_handle(), callback);
}
catch (...) { handle_exception(); }

Expand Down
4 changes: 2 additions & 2 deletions src/torrent_handle.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -357,9 +357,9 @@ namespace libtorrent {
{ async_call(&torrent::set_sequential_download, sd); }
#endif

void torrent_handle::flush_cache() const
void torrent_handle::flush_cache(callback_t<cache_flushed_alert>::type callback) const
{
async_call(&torrent::flush_cache);
async_call(&torrent::flush_cache, callback);
}

void torrent_handle::set_ssl_certificate(
Expand Down

0 comments on commit 51db89b

Please sign in to comment.