From 4ff5ebe6c61a9588dc955d6b8c31092958d53c7e Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E7=84=A1=E5=B8=B8?= <3142324836@qq.com> Date: Sun, 1 Dec 2024 00:11:50 +0800 Subject: [PATCH] Fixed audio extractor job terminate --- src/ui/misc/AudioExtractor.cpp | 2 +- src/ui/misc/MainThreadPool.cpp | 8 +++++++- src/ui/misc/MainThreadPool.h | 1 + 3 files changed, 9 insertions(+), 2 deletions(-) diff --git a/src/ui/misc/AudioExtractor.cpp b/src/ui/misc/AudioExtractor.cpp index b53b4eb1..87938de9 100644 --- a/src/ui/misc/AudioExtractor.cpp +++ b/src/ui/misc/AudioExtractor.cpp @@ -157,7 +157,7 @@ void AudioExtractor::extractAsync(const void* ticket, /** Exists */ if (it != this->templist.end()) { if (auto ptrJob = dynamic_cast(it->second.job.get())) { - ptrJob->stopNow(); + MainThreadPool::getInstance()->stopJob(ptrJob); it->second.data = data; } } diff --git a/src/ui/misc/MainThreadPool.cpp b/src/ui/misc/MainThreadPool.cpp index ceb80f1b..9baac6ad 100644 --- a/src/ui/misc/MainThreadPool.cpp +++ b/src/ui/misc/MainThreadPool.cpp @@ -1,5 +1,7 @@ #include "MainThreadPool.h" +#define JOB_STOP_TIMEOUT 30000 + MainThreadPool::MainThreadPool() { this->pool = std::make_unique(); } @@ -9,7 +11,7 @@ MainThreadPool::~MainThreadPool() { } void MainThreadPool::stopAll() { - this->pool->removeAllJobs(true, 30000, nullptr); + this->pool->removeAllJobs(true, JOB_STOP_TIMEOUT, nullptr); } void MainThreadPool::runJob(const Job& job) { @@ -21,6 +23,10 @@ void MainThreadPool::runJob( this->pool->addJob(job, deleteJobWhenFinished); } +void MainThreadPool::stopJob(juce::ThreadPoolJob* job) { + this->pool->removeJob(job, true, JOB_STOP_TIMEOUT); +} + MainThreadPool* MainThreadPool::getInstance() { return MainThreadPool::instance ? MainThreadPool::instance : (MainThreadPool::instance = new MainThreadPool{}); diff --git a/src/ui/misc/MainThreadPool.h b/src/ui/misc/MainThreadPool.h index e96a6c5a..67f35526 100644 --- a/src/ui/misc/MainThreadPool.h +++ b/src/ui/misc/MainThreadPool.h @@ -11,6 +11,7 @@ class MainThreadPool final : private juce::DeletedAtShutdown { using Job = std::function; void runJob(const Job& job); void runJob(juce::ThreadPoolJob* job, bool deleteJobWhenFinished); + void stopJob(juce::ThreadPoolJob* job); private: std::unique_ptr pool = nullptr;