fix resume state for paused when torrent was in graceful pause mode

This commit is contained in:
Arvid Norberg 2011-06-05 20:48:00 +00:00
parent f60e88e7f8
commit b8614a36b3
4 changed files with 37 additions and 4 deletions

View File

@ -862,6 +862,14 @@ void handle_alert(libtorrent::session& ses, libtorrent::alert* a
, boost::bind(&handles_t::value_type::second, _1) == h) == files.end()) , boost::bind(&handles_t::value_type::second, _1) == h) == files.end())
ses.remove_torrent(h); ses.remove_torrent(h);
} }
else if (torrent_paused_alert* p = alert_cast<torrent_paused_alert>(a))
{
// write resume data for the finished torrent
// the alert handler for save_resume_data_alert
// will save it to disk
torrent_handle h = p->handle;
h.save_resume_data();
}
} }
static char const* state_str[] = static char const* state_str[] =
@ -1486,9 +1494,6 @@ int main(int argc, char* argv[])
ts.handle.auto_managed(false); ts.handle.auto_managed(false);
ts.handle.pause(torrent_handle::graceful_pause); ts.handle.pause(torrent_handle::graceful_pause);
} }
// the alert handler for save_resume_data_alert
// will save it to disk
if (ts.need_save_resume) ts.handle.save_resume_data();
} }
if (c == 'c' && !handles.empty()) if (c == 'c' && !handles.empty())

View File

@ -1318,6 +1318,12 @@ namespace libtorrent
// if set to true, add tracker URLs loaded from resume // if set to true, add tracker URLs loaded from resume
// data into this torrent instead of replacing them // data into this torrent instead of replacing them
bool m_merge_resume_trackers:1; bool m_merge_resume_trackers:1;
#ifdef TORRENT_DEBUG
public:
// set to false until we've loaded resume data
bool m_resume_data_loaded;
#endif
}; };
} }

View File

@ -3507,6 +3507,7 @@ namespace aux {
if (t->state() == torrent_status::checking_files if (t->state() == torrent_status::checking_files
|| t->state() == torrent_status::queued_for_checking) || t->state() == torrent_status::queued_for_checking)
continue; continue;
TORRENT_ASSERT(t->m_resume_data_loaded);
if (t->is_auto_managed() && !t->has_error()) if (t->is_auto_managed() && !t->has_error())
{ {
// this torrent is auto managed, add it to // this torrent is auto managed, add it to

View File

@ -409,6 +409,9 @@ namespace libtorrent
, m_apply_ip_filter(p.apply_ip_filter) , m_apply_ip_filter(p.apply_ip_filter)
, m_merge_resume_trackers(p.merge_resume_trackers) , m_merge_resume_trackers(p.merge_resume_trackers)
{ {
#ifdef TORRENT_DEBUG
m_resume_data_loaded = false;
#endif
if (!m_apply_ip_filter) ++m_ses.m_non_filtered_torrents; if (!m_apply_ip_filter) ++m_ses.m_non_filtered_torrents;
if (!p.ti || !p.ti->is_valid()) if (!p.ti || !p.ti->is_valid())
@ -1352,6 +1355,10 @@ namespace libtorrent
} }
} }
#ifdef TORRENT_DEBUG
m_resume_data_loaded = true;
#endif
TORRENT_ASSERT(block_size() > 0); TORRENT_ASSERT(block_size() > 0);
int file = 0; int file = 0;
for (file_storage::iterator i = m_torrent_file->files().begin() for (file_storage::iterator i = m_torrent_file->files().begin()
@ -3415,6 +3422,9 @@ namespace libtorrent
} }
if (filter_updated) if (filter_updated)
{ {
// we need to save this new state
m_need_save_resume_data = true;
update_peer_interest(was_finished); update_peer_interest(was_finished);
remove_time_critical_pieces(pieces); remove_time_critical_pieces(pieces);
} }
@ -4789,7 +4799,7 @@ namespace libtorrent
ret["download_rate_limit"] = download_limit(); ret["download_rate_limit"] = download_limit();
ret["max_connections"] = max_connections(); ret["max_connections"] = max_connections();
ret["max_uploads"] = max_uploads(); ret["max_uploads"] = max_uploads();
ret["paused"] = !m_allow_peers; ret["paused"] = is_torrent_paused();
ret["announce_to_dht"] = m_announce_to_dht; ret["announce_to_dht"] = m_announce_to_dht;
ret["announce_to_trackers"] = m_announce_to_trackers; ret["announce_to_trackers"] = m_announce_to_trackers;
ret["announce_to_lsd"] = m_announce_to_lsd; ret["announce_to_lsd"] = m_announce_to_lsd;
@ -6055,6 +6065,10 @@ namespace libtorrent
if (m_auto_managed == a) return; if (m_auto_managed == a) return;
bool checking_files = should_check_files(); bool checking_files = should_check_files();
m_auto_managed = a; m_auto_managed = a;
// we need to save this new state as well
m_need_save_resume_data = true;
// recalculate which torrents should be // recalculate which torrents should be
// paused // paused
m_ses.m_auto_manage_time_scaler = 0; m_ses.m_auto_manage_time_scaler = 0;
@ -6232,6 +6246,9 @@ namespace libtorrent
m_announce_to_trackers = false; m_announce_to_trackers = false;
m_announce_to_lsd = false; m_announce_to_lsd = false;
// we need to save this new state
m_need_save_resume_data = true;
bool prev_graceful = m_graceful_pause_mode; bool prev_graceful = m_graceful_pause_mode;
m_graceful_pause_mode = graceful; m_graceful_pause_mode = graceful;
@ -6382,6 +6399,10 @@ namespace libtorrent
m_announce_to_trackers = true; m_announce_to_trackers = true;
m_announce_to_lsd = true; m_announce_to_lsd = true;
if (!m_ses.is_paused()) m_graceful_pause_mode = false; if (!m_ses.is_paused()) m_graceful_pause_mode = false;
// we need to save this new state
m_need_save_resume_data = true;
do_resume(); do_resume();
} }