mirror of
https://github.com/AleziaKurdis/overte.git
synced 2025-04-08 13:34:01 +02:00
Merge pull request #15818 from sabrina-shanman/crash_scriptengine_thread
(BUGZ-619) Fix potential crash when ending script on main thread
This commit is contained in:
commit
13615eb9ff
1 changed files with 9 additions and 4 deletions
|
@ -397,15 +397,20 @@ void ScriptEngine::executeOnScriptThread(std::function<void()> function, const Q
|
|||
}
|
||||
|
||||
void ScriptEngine::waitTillDoneRunning() {
|
||||
// Engine should be stopped already, but be defensive
|
||||
stop();
|
||||
|
||||
auto workerThread = thread();
|
||||
|
||||
|
||||
if (workerThread == QThread::currentThread()) {
|
||||
qCWarning(scriptengine) << "ScriptEngine::waitTillDoneRunning called, but the script is on the same thread:" << getFilename();
|
||||
return;
|
||||
}
|
||||
|
||||
if (_isThreaded && workerThread) {
|
||||
// We should never be waiting (blocking) on our own thread
|
||||
assert(workerThread != QThread::currentThread());
|
||||
|
||||
// Engine should be stopped already, but be defensive
|
||||
stop();
|
||||
|
||||
auto startedWaiting = usecTimestampNow();
|
||||
while (workerThread->isRunning()) {
|
||||
// If the final evaluation takes too long, then tell the script engine to stop running
|
||||
|
|
Loading…
Reference in a new issue