Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

reset_save_path #7498

Merged
merged 4 commits into from
Aug 24, 2023
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions bindings/python/src/torrent_handle.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -468,6 +468,8 @@ void bind_torrent_handle()
.value("always_replace_files", move_flags_t::always_replace_files)
.value("fail_if_exist", move_flags_t::fail_if_exist)
.value("dont_replace", move_flags_t::dont_replace)
.value("reset_save_path", move_flags_t::reset_save_path)
.value("reset_save_path_unchecked", move_flags_t::reset_save_path_unchecked)
;

#if TORRENT_ABI_VERSION == 1
Expand Down
11 changes: 10 additions & 1 deletion include/libtorrent/storage_defs.hpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/*

Copyright (c) 2023, Vladimir Golovnev
Copyright (c) 2006-2007, 2009, 2013-2014, 2016-2020, 2022, Arvid Norberg
Copyright (c) 2016, 2021, Alden Torres
All rights reserved.
Expand Down Expand Up @@ -110,7 +111,15 @@ namespace libtorrent {

// if any file exist in the target, take those files instead
// of the ones we may have in the source.
dont_replace
dont_replace,

// don't move any source files, just forget about them
// and begin checking files at new save path
reset_save_path,

// don't move any source files, just change save path
// and continue working without any checks
reset_save_path_unchecked
};

#if TORRENT_ABI_VERSION == 1
Expand Down
7 changes: 7 additions & 0 deletions src/storage_utils.cpp
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
/*

Copyright (c) 2023, Vladimir Golovnev
Copyright (c) 2016-2022, Arvid Norberg
Copyright (c) 2017-2018, Alden Torres
Copyright (c) 2017-2018, Steven Siloti
Expand Down Expand Up @@ -199,6 +200,12 @@ namespace libtorrent { namespace aux {
}
}

if (flags == move_flags_t::reset_save_path)
return { status_t::need_full_check, new_save_path };

if (flags == move_flags_t::reset_save_path_unchecked)
return { status_t::no_error, new_save_path };

// indices of all files we ended up copying. These need to be deleted
// later
aux::vector<bool, file_index_t> copied_files(std::size_t(f.num_files()), false);
Expand Down
53 changes: 53 additions & 0 deletions test/test_storage.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1387,6 +1387,48 @@ void test_move_storage_into_self()
, combine_path("_folder3", "test4.tmp")))));
}

template <typename StorageType>
void test_move_storage_reset(move_flags_t const flags)
{
std::string const save_path = current_working_directory();
std::string const test_path = complete("temp_storage2");
delete_dirs(test_path);

aux::session_settings set;
file_storage fs;
std::vector<char> buf;
typename file_pool_type<StorageType>::type fp;
io_context ios;
auto s = setup_torrent<StorageType>(fs, fp, buf, save_path, set);

span<char> const b = {&buf[0], 4};
storage_error se;
TEST_EQUAL(se.ec, boost::system::errc::success);
write(s, set, b, 1_piece, 0, aux::open_mode::write, se);

std::string const root = combine_path(save_path, "temp_storage");
TEST_CHECK(exists(combine_path(root, combine_path("folder2", "test3.tmp"))));
TEST_CHECK(exists(combine_path(root, combine_path("_folder3", "test4.tmp"))));
std::string const root2 = combine_path(test_path, "temp_storage");
TEST_CHECK(!exists(combine_path(root2, combine_path("folder2", "test3.tmp"))));
TEST_CHECK(!exists(combine_path(root2, combine_path("_folder3", "test4.tmp"))));
TEST_EQUAL(se.ec, boost::system::errc::success);

std::string new_path;
status_t ret;
std::tie(ret, new_path) = s->move_storage(test_path, flags, se);
TEST_EQUAL(new_path, test_path);
TEST_EQUAL(se.ec, boost::system::errc::success);
std::cerr << "file: " << se.file() << '\n';
std::cerr << "op: " << int(se.operation) << '\n';
std::cerr << "ec: " << se.ec.message() << '\n';

// the root directory is created, but none of the files are moved
TEST_CHECK(exists(test_path));
TEST_CHECK(!exists(combine_path(root2, combine_path("folder2", "test3.tmp"))));
TEST_CHECK(!exists(combine_path(root2, combine_path("_folder3", "test4.tmp"))));
}

#if TORRENT_HAVE_MMAP || TORRENT_HAVE_MAP_VIEW_OF_FILE
TORRENT_TEST(move_default_storage_to_self)
{
Expand All @@ -1398,6 +1440,11 @@ TORRENT_TEST(move_default_storage_into_self)
test_move_storage_into_self<mmap_storage>();
}

TORRENT_TEST(move_default_storage_reset)
{
test_move_storage_reset<mmap_storage>(move_flags_t::reset_save_path);
test_move_storage_reset<mmap_storage>(move_flags_t::reset_save_path_unchecked);
}
#endif

TORRENT_TEST(move_posix_storage_to_self)
Expand All @@ -1410,6 +1457,12 @@ TORRENT_TEST(move_posix_storage_into_self)
test_move_storage_into_self<posix_storage>();
}

TORRENT_TEST(move_posix_storage_reset)
{
test_move_storage_reset<posix_storage>(move_flags_t::reset_save_path);
test_move_storage_reset<posix_storage>(move_flags_t::reset_save_path_unchecked);
}

TORRENT_TEST(storage_paths_string_pooling)
{
file_storage file_storage;
Expand Down