fix re-check issue after move_storage

This commit is contained in:
arvidn 2017-06-13 20:33:46 -04:00 committed by Arvid Norberg
parent 046bb76361
commit 77cc2b4eea
2 changed files with 8 additions and 0 deletions

View File

@ -1,3 +1,4 @@
* fix re-check issue after move_storage
* handle invalid arguments to set_piece_deadline() * handle invalid arguments to set_piece_deadline()
* move_storage did not work for torrents without metadata * move_storage did not work for torrents without metadata
* improve shutdown time by only announcing to trackers whose IP we know * improve shutdown time by only announcing to trackers whose IP we know

View File

@ -1239,6 +1239,8 @@ namespace libtorrent
if (flags == dont_replace && exists(new_path)) if (flags == dont_replace && exists(new_path))
{ {
if (ret == piece_manager::no_error) ret = piece_manager::need_full_check; if (ret == piece_manager::no_error) ret = piece_manager::need_full_check;
// this is a new file, clear our cached version
m_stat_cache.set_dirty(i);
continue; continue;
} }
@ -1250,7 +1252,12 @@ namespace libtorrent
// if the source file doesn't exist. That's not a problem // if the source file doesn't exist. That's not a problem
// we just ignore that file // we just ignore that file
if (e == boost::system::errc::no_such_file_or_directory) if (e == boost::system::errc::no_such_file_or_directory)
{
e.clear(); e.clear();
// the source file doesn't exist, but it may exist at the
// destination, we don't know.
m_stat_cache.set_dirty(i);
}
else if (e else if (e
&& e != boost::system::errc::invalid_argument && e != boost::system::errc::invalid_argument
&& e != boost::system::errc::permission_denied) && e != boost::system::errc::permission_denied)