1
0
Fork 0
mirror of https://github.com/transmission/transmission synced 2025-01-19 13:30:24 +00:00

refactor: remove tr_runInEventThread() temp data structs (#3528)

* refactor: remove port_forwarding_data

* refactor: remove "struct rename_data"
This commit is contained in:
Charles Kerr 2022-07-27 02:07:44 -05:00 committed by GitHub
parent 0e7ef51d5c
commit 78b24b594b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 43 additions and 76 deletions

View file

@ -2341,24 +2341,9 @@ tr_bandwidth& tr_session::getBandwidthGroup(std::string_view name)
**** ****
***/ ***/
struct port_forwarding_data
{
bool enabled;
struct tr_shared* shared;
};
static void setPortForwardingEnabled(struct port_forwarding_data* const data)
{
tr_sharedTraversalEnable(data->shared, data->enabled);
tr_free(data);
}
void tr_sessionSetPortForwardingEnabled(tr_session* session, bool enabled) void tr_sessionSetPortForwardingEnabled(tr_session* session, bool enabled)
{ {
auto* const d = tr_new0(struct port_forwarding_data, 1); tr_runInEventThread(session, tr_sharedTraversalEnable, session->shared, enabled);
d->shared = session->shared;
d->enabled = enabled;
tr_runInEventThread(session, setPortForwardingEnabled, d);
} }
bool tr_sessionIsPortForwardingEnabled(tr_session const* session) bool tr_sessionIsPortForwardingEnabled(tr_session const* session)

View file

@ -7,7 +7,6 @@
#include <array> #include <array>
#include <cerrno> // EINVAL #include <cerrno> // EINVAL
#include <climits> /* INT_MAX */ #include <climits> /* INT_MAX */
#include <cmath>
#include <csignal> /* signal() */ #include <csignal> /* signal() */
#include <ctime> #include <ctime>
#include <map> #include <map>
@ -2506,10 +2505,10 @@ static void torrentSetQueued(tr_torrent* tor, bool queued)
**** ****
***/ ***/
static bool renameArgsAreValid(char const* oldpath, char const* newname) static bool renameArgsAreValid(std::string_view oldpath, std::string_view newname)
{ {
return !tr_str_is_empty(oldpath) && !tr_str_is_empty(newname) && strcmp(newname, ".") != 0 && strcmp(newname, "..") != 0 && return !std::empty(oldpath) && !std::empty(newname) && newname != "."sv && newname != ".."sv &&
strchr(newname, TR_PATH_DELIMITER) == nullptr; !tr_strvContains(newname, TR_PATH_DELIMITER);
} }
static auto renameFindAffectedFiles(tr_torrent const* tor, std::string_view oldpath) static auto renameFindAffectedFiles(tr_torrent const* tor, std::string_view oldpath)
@ -2530,7 +2529,7 @@ static auto renameFindAffectedFiles(tr_torrent const* tor, std::string_view oldp
return indices; return indices;
} }
static int renamePath(tr_torrent* tor, char const* oldpath, char const* newname) static int renamePath(tr_torrent* tor, std::string_view oldpath, std::string_view newname)
{ {
int err = 0; int err = 0;
@ -2573,13 +2572,17 @@ static int renamePath(tr_torrent* tor, char const* oldpath, char const* newname)
return err; return err;
} }
static void renameTorrentFileString(tr_torrent* tor, char const* oldpath, char const* newname, tr_file_index_t file_index) static void renameTorrentFileString(
tr_torrent* tor,
std::string_view oldpath,
std::string_view newname,
tr_file_index_t file_index)
{ {
auto name = std::string{}; auto name = std::string{};
auto const subpath = std::string_view{ tor->fileSubpath(file_index) }; auto const subpath = std::string_view{ tor->fileSubpath(file_index) };
auto const oldpath_len = strlen(oldpath); auto const oldpath_len = std::size(oldpath);
if (strchr(oldpath, TR_PATH_DELIMITER) == nullptr) if (!tr_strvContains(oldpath, TR_PATH_DELIMITER))
{ {
if (oldpath_len >= std::size(subpath)) if (oldpath_len >= std::size(subpath))
{ {
@ -2615,18 +2618,13 @@ static void renameTorrentFileString(tr_torrent* tor, char const* oldpath, char c
} }
} }
struct rename_data static void torrentRenamePath(
tr_torrent* const tor,
std::string oldpath, // NOLINT performance-unnecessary-value-param
std::string newname, // NOLINT performance-unnecessary-value-param
tr_torrent_rename_done_func callback,
void* const callback_user_data)
{ {
tr_torrent* tor;
char* oldpath;
char* newname;
tr_torrent_rename_done_func callback;
void* callback_user_data;
};
static void torrentRenamePath(struct rename_data* data)
{
auto* const tor = data->tor;
TR_ASSERT(tr_isTorrent(tor)); TR_ASSERT(tr_isTorrent(tor));
/*** /***
@ -2634,42 +2632,31 @@ static void torrentRenamePath(struct rename_data* data)
***/ ***/
int error = 0; int error = 0;
char const* const oldpath = data->oldpath;
char const* const newname = data->newname;
if (!renameArgsAreValid(oldpath, newname)) if (!renameArgsAreValid(oldpath, newname))
{ {
error = EINVAL; error = EINVAL;
} }
else else if (auto const file_indices = renameFindAffectedFiles(tor, oldpath); std::empty(file_indices))
{ {
auto const file_indices = renameFindAffectedFiles(tor, oldpath); error = EINVAL;
if (std::empty(file_indices)) }
else if ((error = renamePath(tor, oldpath, newname)) == 0)
{
/* update tr_info.files */
for (auto const& file_index : file_indices)
{ {
error = EINVAL; renameTorrentFileString(tor, oldpath, newname, file_index);
} }
else
/* update tr_info.name if user changed the toplevel */
if (std::size(file_indices) == tor->fileCount() && !tr_strvContains(oldpath, '/'))
{ {
error = renamePath(tor, oldpath, newname); tor->setName(newname);
if (error == 0)
{
/* update tr_info.files */
for (auto const& file_index : file_indices)
{
renameTorrentFileString(tor, oldpath, newname, file_index);
}
/* update tr_info.name if user changed the toplevel */
if (std::size(file_indices) == tor->fileCount() && strchr(oldpath, '/') == nullptr)
{
tor->setName(newname);
}
tor->markEdited();
tor->setDirty();
}
} }
tor->markEdited();
tor->setDirty();
} }
/*** /***
@ -2679,15 +2666,10 @@ static void torrentRenamePath(struct rename_data* data)
tor->markChanged(); tor->markChanged();
/* callback */ /* callback */
if (data->callback != nullptr) if (callback != nullptr)
{ {
(*data->callback)(tor, data->oldpath, data->newname, error, data->callback_user_data); (*callback)(tor, oldpath.c_str(), newname.c_str(), error, callback_user_data);
} }
/* cleanup */
tr_free(data->oldpath);
tr_free(data->newname);
tr_free(data);
} }
void tr_torrent::renamePath( void tr_torrent::renamePath(
@ -2696,14 +2678,14 @@ void tr_torrent::renamePath(
tr_torrent_rename_done_func callback, tr_torrent_rename_done_func callback,
void* callback_user_data) void* callback_user_data)
{ {
auto* const data = tr_new0(struct rename_data, 1); tr_runInEventThread(
data->tor = this; this->session,
data->oldpath = tr_strvDup(oldpath); torrentRenamePath,
data->newname = tr_strvDup(newname); this,
data->callback = callback; std::string{ oldpath },
data->callback_user_data = callback_user_data; std::string{ newname },
callback,
tr_runInEventThread(this->session, torrentRenamePath, data); callback_user_data);
} }
void tr_torrentRenamePath( void tr_torrentRenamePath(