diff options
author | Allan Sandfeld Jensen <allan.jensen@qt.io> | 2021-04-30 15:20:48 +0200 |
---|---|---|
committer | Jüri Valdmann <juri.valdmann@qt.io> | 2021-05-06 19:27:44 +0200 |
commit | a5c7b4d4f16574e35ce36550bda2d45baf345c79 (patch) | |
tree | f4668442049d871763200accd249740c90a98157 /src/core/renderer | |
parent | f5e1fce9998a3eb1790ddb7c1440b47ab508fdfb (diff) |
Make script execution order deterministic
Task-number: QTBUG-77765
Change-Id: I8680a46c62e6a915cbf10c3ae48573cb95f612a5
Reviewed-by: Allan Sandfeld Jensen <allan.jensen@qt.io>
Reviewed-by: Jüri Valdmann <juri.valdmann@qt.io>
Diffstat (limited to 'src/core/renderer')
-rw-r--r-- | src/core/renderer/user_resource_controller.cpp | 9 | ||||
-rw-r--r-- | src/core/renderer/user_resource_controller.h | 2 |
2 files changed, 6 insertions, 5 deletions
diff --git a/src/core/renderer/user_resource_controller.cpp b/src/core/renderer/user_resource_controller.cpp index af1f234ac..89730e83f 100644 --- a/src/core/renderer/user_resource_controller.cpp +++ b/src/core/renderer/user_resource_controller.cpp @@ -198,8 +198,8 @@ void UserResourceController::runScripts(QtWebEngineCore::UserScriptData::Injecti return; const bool isMainFrame = renderFrame->IsMainFrame(); - QList<uint64_t> scriptsToRun = m_frameUserScriptMap.value(globalScriptsIndex).values(); - scriptsToRun.append(m_frameUserScriptMap.value(renderFrame).values()); + QList<uint64_t> scriptsToRun = m_frameUserScriptMap.value(globalScriptsIndex); + scriptsToRun.append(m_frameUserScriptMap.value(renderFrame)); for (uint64_t id : qAsConst(scriptsToRun)) { const QtWebEngineCore::UserScriptData &script = m_scripts.value(id); @@ -346,7 +346,8 @@ void UserResourceController::addScriptForFrame(const QtWebEngineCore::UserScript if (it == m_frameUserScriptMap.end()) it = m_frameUserScriptMap.insert(frame, UserScriptSet()); - (*it).insert(script.scriptId); + if (!(*it).contains(script.scriptId)) + (*it).append(script.scriptId); m_scripts.insert(script.scriptId, script); } @@ -357,7 +358,7 @@ void UserResourceController::removeScriptForFrame(const QtWebEngineCore::UserScr if (it == m_frameUserScriptMap.end()) return; - (*it).remove(script.scriptId); + (*it).removeOne(script.scriptId); m_scripts.remove(script.scriptId); } diff --git a/src/core/renderer/user_resource_controller.h b/src/core/renderer/user_resource_controller.h index 6c79d96fc..37e7175a4 100644 --- a/src/core/renderer/user_resource_controller.h +++ b/src/core/renderer/user_resource_controller.h @@ -91,7 +91,7 @@ private: void runScripts(QtWebEngineCore::UserScriptData::InjectionPoint, blink::WebLocalFrame *); - typedef QSet<uint64_t> UserScriptSet; + typedef QList<uint64_t> UserScriptSet; typedef QHash<const content::RenderFrame *, UserScriptSet> FrameUserScriptMap; FrameUserScriptMap m_frameUserScriptMap; QHash<uint64_t, QtWebEngineCore::UserScriptData> m_scripts; |