fix regression where paused torrents could not have their queue position changed
This commit is contained in:
parent
ec30a5e9ec
commit
506950001d
|
@ -1,3 +1,4 @@
|
||||||
|
* fix changing queue position of paused torrents (1.1.3 regression)
|
||||||
* fix re-check issue after move_storage
|
* 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
|
||||||
|
|
|
@ -9308,8 +9308,9 @@ namespace libtorrent
|
||||||
|
|
||||||
void torrent::queue_up()
|
void torrent::queue_up()
|
||||||
{
|
{
|
||||||
// fix race conditions on async position change calls (from handler)
|
// finished torrents may not change their queue positions, as it's set to
|
||||||
if(!m_auto_managed || m_abort || is_finished()) return;
|
// -1
|
||||||
|
if (m_abort || is_finished()) return;
|
||||||
|
|
||||||
set_queue_position(queue_position() == 0
|
set_queue_position(queue_position() == 0
|
||||||
? queue_position() : queue_position() - 1);
|
? queue_position() : queue_position() - 1);
|
||||||
|
@ -9324,8 +9325,9 @@ namespace libtorrent
|
||||||
{
|
{
|
||||||
TORRENT_ASSERT(is_single_thread());
|
TORRENT_ASSERT(is_single_thread());
|
||||||
|
|
||||||
// fix race conditions on async position change calls (from handler)
|
// finished torrents may not change their queue positions, as it's set to
|
||||||
if ((!m_auto_managed || m_abort || is_finished()) && p != -1) return;
|
// -1
|
||||||
|
if ((m_abort || is_finished()) && p != -1) return;
|
||||||
|
|
||||||
TORRENT_ASSERT((p == -1) == is_finished()
|
TORRENT_ASSERT((p == -1) == is_finished()
|
||||||
|| (!m_auto_managed && p == -1)
|
|| (!m_auto_managed && p == -1)
|
||||||
|
|
|
@ -393,7 +393,7 @@ TORRENT_TEST(torrent_total_size_zero)
|
||||||
TEST_CHECK(ec);
|
TEST_CHECK(ec);
|
||||||
}
|
}
|
||||||
|
|
||||||
TORRENT_TEST(queue)
|
void test_queue(add_torrent_params p)
|
||||||
{
|
{
|
||||||
lt::settings_pack pack = settings();
|
lt::settings_pack pack = settings();
|
||||||
// we're not testing the hash check, just accept the data we write
|
// we're not testing the hash check, just accept the data we write
|
||||||
|
@ -412,7 +412,6 @@ TORRENT_TEST(queue)
|
||||||
std::vector<char> buf;
|
std::vector<char> buf;
|
||||||
bencode(std::back_inserter(buf), t.generate());
|
bencode(std::back_inserter(buf), t.generate());
|
||||||
boost::shared_ptr<torrent_info> ti = boost::make_shared<torrent_info>(&buf[0], buf.size());
|
boost::shared_ptr<torrent_info> ti = boost::make_shared<torrent_info>(&buf[0], buf.size());
|
||||||
add_torrent_params p;
|
|
||||||
p.ti = ti;
|
p.ti = ti;
|
||||||
p.save_path = ".";
|
p.save_path = ".";
|
||||||
torrents.push_back(ses.add_torrent(p));
|
torrents.push_back(ses.add_torrent(p));
|
||||||
|
@ -503,6 +502,19 @@ TORRENT_TEST(queue)
|
||||||
TEST_EQUAL(torrents[3].queue_position(), 4);
|
TEST_EQUAL(torrents[3].queue_position(), 4);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TORRENT_TEST(queue)
|
||||||
|
{
|
||||||
|
test_queue(add_torrent_params());
|
||||||
|
}
|
||||||
|
|
||||||
|
TORRENT_TEST(queue_paused)
|
||||||
|
{
|
||||||
|
add_torrent_params p;
|
||||||
|
p.flags |= add_torrent_params::flag_paused;
|
||||||
|
p.flags &= ~add_torrent_params::flag_auto_managed;
|
||||||
|
test_queue(p);
|
||||||
|
}
|
||||||
|
|
||||||
TORRENT_TEST(test_move_storage_no_metadata)
|
TORRENT_TEST(test_move_storage_no_metadata)
|
||||||
{
|
{
|
||||||
lt::session ses(settings());
|
lt::session ses(settings());
|
||||||
|
|
Loading…
Reference in New Issue