From 3c139ca3336ed3ff5fc343fa3d96716513263901 Mon Sep 17 00:00:00 2001 From: Chocobo1 Date: Sat, 1 Jul 2023 13:37:50 +0800 Subject: [PATCH 1/3] Fix potential use-after-move The evaluation order for function parameters is unspecified in C++. https://stackoverflow.com/questions/2934904/order-of-evaluation-in-c-function-parameters Fix up 1b2ff0f6f8f93c4e3d3aff38359b1b2037a13378. --- src/base/bittorrent/sessionimpl.cpp | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/src/base/bittorrent/sessionimpl.cpp b/src/base/bittorrent/sessionimpl.cpp index 043ae3c4a..33c8624ad 100644 --- a/src/base/bittorrent/sessionimpl.cpp +++ b/src/base/bittorrent/sessionimpl.cpp @@ -6091,7 +6091,8 @@ void SessionImpl::processTrackerStatuses() #if (QT_VERSION < QT_VERSION_CHECK(6, 0, 0)) updatedTrackerEntries[trackerEntry.url] = std::move(trackerEntry); #else - updatedTrackerEntries.emplace(trackerEntry.url, std::move(trackerEntry)); + const QString url = trackerEntry.url; + updatedTrackerEntries.emplace(url, std::move(trackerEntry)); #endif } From 8655e483365425ca64f6ed99451a8ba356437ff5 Mon Sep 17 00:00:00 2001 From: Chocobo1 Date: Sat, 1 Jul 2023 13:46:37 +0800 Subject: [PATCH 2/3] Use move construct for shared pointers --- src/base/bittorrent/customstorage.cpp | 2 +- src/base/bittorrent/sessionimpl.cpp | 2 +- src/base/digest32.h | 2 +- 3 files changed, 3 insertions(+), 3 deletions(-) diff --git a/src/base/bittorrent/customstorage.cpp b/src/base/bittorrent/customstorage.cpp index 2d25e45a3..d6f25cd1b 100644 --- a/src/base/bittorrent/customstorage.cpp +++ b/src/base/bittorrent/customstorage.cpp @@ -92,7 +92,7 @@ bool CustomDiskIOThread::async_write(lt::storage_index_t storage, const lt::peer , const char *buf, std::shared_ptr diskObserver , std::function handler, lt::disk_job_flags_t flags) { - return m_nativeDiskIO->async_write(storage, peerRequest, buf, diskObserver, std::move(handler), flags); + return m_nativeDiskIO->async_write(storage, peerRequest, buf, std::move(diskObserver), std::move(handler), flags); } void CustomDiskIOThread::async_hash(lt::storage_index_t storage, lt::piece_index_t piece diff --git a/src/base/bittorrent/sessionimpl.cpp b/src/base/bittorrent/sessionimpl.cpp index 33c8624ad..75756181b 100644 --- a/src/base/bittorrent/sessionimpl.cpp +++ b/src/base/bittorrent/sessionimpl.cpp @@ -1318,7 +1318,7 @@ void SessionImpl::processNextResumeData(ResumeSessionContext *context) std::shared_ptr ti = resumeData.ltAddTorrentParams.ti; resumeData = *loadPreferredResumeDataResult; if (!resumeData.ltAddTorrentParams.ti) - resumeData.ltAddTorrentParams.ti = ti; + resumeData.ltAddTorrentParams.ti = std::move(ti); } } } diff --git a/src/base/digest32.h b/src/base/digest32.h index 1be904a2f..b1c903c62 100644 --- a/src/base/digest32.h +++ b/src/base/digest32.h @@ -84,7 +84,7 @@ private: class Data; explicit Digest32(QSharedDataPointer dataPtr) - : m_dataPtr {dataPtr} + : m_dataPtr {std::move(dataPtr)} { } From 715a4f3eb63244bce7e466cce020cc04d503c52e Mon Sep 17 00:00:00 2001 From: Chocobo1 Date: Sat, 1 Jul 2023 13:47:15 +0800 Subject: [PATCH 3/3] Use move construct for large data --- src/base/bittorrent/customstorage.cpp | 4 ++-- src/base/bittorrent/portforwarderimpl.cpp | 2 +- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/src/base/bittorrent/customstorage.cpp b/src/base/bittorrent/customstorage.cpp index d6f25cd1b..7d746da78 100644 --- a/src/base/bittorrent/customstorage.cpp +++ b/src/base/bittorrent/customstorage.cpp @@ -141,7 +141,7 @@ void CustomDiskIOThread::async_check_files(lt::storage_index_t storage, const lt , std::function handler) { handleCompleteFiles(storage, m_storageData[storage].savePath); - m_nativeDiskIO->async_check_files(storage, resume_data, links, std::move(handler)); + m_nativeDiskIO->async_check_files(storage, resume_data, std::move(links), std::move(handler)); } void CustomDiskIOThread::async_stop_torrent(lt::storage_index_t storage, std::function handler) @@ -170,7 +170,7 @@ void CustomDiskIOThread::async_delete_files(lt::storage_index_t storage, lt::rem void CustomDiskIOThread::async_set_file_priority(lt::storage_index_t storage, lt::aux::vector priorities , std::function)> handler) { - m_nativeDiskIO->async_set_file_priority(storage, priorities + m_nativeDiskIO->async_set_file_priority(storage, std::move(priorities) , [=, handler = std::move(handler)](const lt::storage_error &error, const lt::aux::vector &priorities) { m_storageData[storage].filePriorities = priorities; diff --git a/src/base/bittorrent/portforwarderimpl.cpp b/src/base/bittorrent/portforwarderimpl.cpp index 7dcb11201..803682f27 100644 --- a/src/base/bittorrent/portforwarderimpl.cpp +++ b/src/base/bittorrent/portforwarderimpl.cpp @@ -67,7 +67,7 @@ void PortForwarderImpl::setPorts(const QString &profile, QSet ports) { const QSet oldForwardedPorts = std::accumulate(m_portProfiles.cbegin(), m_portProfiles.cend(), QSet()); - m_portProfiles[profile] = ports; + m_portProfiles[profile] = std::move(ports); const QSet newForwardedPorts = std::accumulate(m_portProfiles.cbegin(), m_portProfiles.cend(), QSet()); m_provider->removeMappedPorts(oldForwardedPorts - newForwardedPorts);