Call QPromise::start() early to avoid race condition

PR #22617.
This commit is contained in:
Vladimir Golovnev 2025-04-28 17:26:51 +03:00 committed by sledgehammer999
parent ad4bdc0653
commit c2f2a38582
No known key found for this signature in database
GPG key ID: 6E4A2D025B7CC9A2
4 changed files with 6 additions and 7 deletions

View file

@ -63,10 +63,8 @@ namespace
}
void FileSearcher::search(const PathList &originalFileNames, const Path &savePath
, const Path &downloadPath, const bool forceAppendExt, QPromise<FileSearchResult> promise)
, const Path &downloadPath, const bool forceAppendExt, QPromise<FileSearchResult> &promise)
{
promise.start();
Path usedPath = savePath;
PathList adjustedFileNames = originalFileNames;
const bool found = findInDir(usedPath, adjustedFileNames, (forceAppendExt && downloadPath.isEmpty()));
@ -77,5 +75,4 @@ void FileSearcher::search(const PathList &originalFileNames, const Path &savePat
}
promise.addResult(FileSearchResult {.savePath = usedPath, .fileNames = adjustedFileNames});
promise.finish();
}

View file

@ -49,5 +49,5 @@ public:
using QObject::QObject;
void search(const PathList &originalFileNames, const Path &savePath
, const Path &downloadPath, bool forceAppendExt, QPromise<FileSearchResult> promise);
, const Path &downloadPath, bool forceAppendExt, QPromise<FileSearchResult> &promise);
};

View file

@ -3008,9 +3008,11 @@ QFuture<FileSearchResult> SessionImpl::findIncompleteFiles(const Path &savePath,
{
QPromise<FileSearchResult> promise;
QFuture<FileSearchResult> future = promise.future();
promise.start();
QMetaObject::invokeMethod(m_fileSearcher, [=, this, promise = std::move(promise)]() mutable
{
m_fileSearcher->search(filePaths, savePath, downloadPath, isAppendExtensionEnabled(), std::move(promise));
m_fileSearcher->search(filePaths, savePath, downloadPath, isAppendExtensionEnabled(), promise);
promise.finish();
});
return future;

View file

@ -3055,9 +3055,9 @@ QFuture<std::invoke_result_t<Func>> TorrentImpl::invokeAsync(Func &&func) const
{
QPromise<std::invoke_result_t<Func>> promise;
const auto future = promise.future();
promise.start();
m_session->invokeAsync([func = std::forward<Func>(func), promise = std::move(promise)]() mutable
{
promise.start();
promise.addResult(func());
promise.finish();
});