From 8e1dc9e0eed868eb6bf7924dd8fa33f7f5f66a57 Mon Sep 17 00:00:00 2001 From: hackademix Date: Sun, 19 Aug 2018 01:30:14 +0200 Subject: [PATCH] Fixed regression: refresh loop on page using requests of type="object" to cache images, stylesheets and other types. --- src/bg/RequestGuard.js | 2 +- src/lib/LastListener.js | 2 -- 2 files changed, 1 insertion(+), 3 deletions(-) diff --git a/src/bg/RequestGuard.js b/src/bg/RequestGuard.js index 38801dea..750e66f1 100644 --- a/src/bg/RequestGuard.js +++ b/src/bg/RequestGuard.js @@ -481,7 +481,7 @@ var RequestGuard = (() => { pending.headersProcessed ? "has been overridden on": "could not process", request); - if (tabId !== -1) { + if (tabId !== -1 && type !== "object") { debug("[WARNING] Reloading %s frame %s of tab %s.", url, frameId, tabId); browser.tabs.executeScript(tabId, { runAt: "document_start", diff --git a/src/lib/LastListener.js b/src/lib/LastListener.js index 6506e32e..b93edbc1 100644 --- a/src/lib/LastListener.js +++ b/src/lib/LastListener.js @@ -20,10 +20,8 @@ class LastListener { let w = (...args) => { if (this.observed.hasListener(w._other)) { this.observed.removeListener(w); - if (this.last !== w) return this.defaultResult; } else if (this.installed) { this.observed.addListener(w._other, ...this.extras); - this.last = w._other; } debug("Running listener", w === ww[0] ? 0 : 1, ...args); return this.installed ? this.listener(...args)