| OLD | NEW | 
|---|
| 1 /* | 1 /* | 
| 2  * This file is part of Adblock Plus <http://adblockplus.org/>, | 2  * This file is part of Adblock Plus <http://adblockplus.org/>, | 
| 3  * Copyright (C) 2006-2013 Eyeo GmbH | 3  * Copyright (C) 2006-2013 Eyeo GmbH | 
| 4  * | 4  * | 
| 5  * Adblock Plus is free software: you can redistribute it and/or modify | 5  * Adblock Plus is free software: you can redistribute it and/or modify | 
| 6  * it under the terms of the GNU General Public License version 3 as | 6  * it under the terms of the GNU General Public License version 3 as | 
| 7  * published by the Free Software Foundation. | 7  * published by the Free Software Foundation. | 
| 8  * | 8  * | 
| 9  * Adblock Plus is distributed in the hope that it will be useful, | 9  * Adblock Plus is distributed in the hope that it will be useful, | 
| 10  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 10  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
| 11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 11  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
| 12  * GNU General Public License for more details. | 12  * GNU General Public License for more details. | 
| 13  * | 13  * | 
| 14  * You should have received a copy of the GNU General Public License | 14  * You should have received a copy of the GNU General Public License | 
| 15  * along with Adblock Plus.  If not, see <http://www.gnu.org/licenses/>. | 15  * along with Adblock Plus.  If not, see <http://www.gnu.org/licenses/>. | 
| 16  */ | 16  */ | 
| 17 | 17 | 
| 18 if (require("info").platform == "chromium" && "webNavigation" in chrome) | 18 if (require("info").platform == "chromium" && "webNavigation" in chrome) | 
| 19 { | 19 { | 
| 20   var tabsLoading = {}; | 20   var tabsLoading = new TabMap(); | 
| 21 | 21 | 
| 22   chrome.webNavigation.onCreatedNavigationTarget.addListener(function(details) | 22   ext.webNavigation.onCreatedNavigationTarget.addListener(function(details) | 
| 23   { | 23   { | 
| 24     if (isFrameWhitelisted(details.sourceTabId, details.sourceFrameId)) | 24     if (isFrameWhitelisted(details.sourceTab, details.sourceFrameId)) | 
| 25       return; | 25       return; | 
| 26 | 26 | 
| 27     var openerUrl = getFrameUrl(details.sourceTabId, details.sourceFrameId); | 27     var openerUrl = getFrameUrl(details.sourceTab, details.sourceFrameId); | 
| 28     if (!openerUrl) | 28     if (!openerUrl) | 
| 29     { | 29     { | 
| 30       // We don't know the opener tab | 30       // We don't know the opener tab | 
| 31       return; | 31       return; | 
| 32     } | 32     } | 
| 33     tabsLoading[details.tabId] = openerUrl; | 33     tabsLoading.set(details.tab, openerUrl); | 
| 34 | 34 | 
| 35     checkPotentialPopup(details.tabId, details.url, openerUrl); | 35     checkPotentialPopup(details.tab, openerUrl); | 
| 36   }); | 36   }); | 
| 37 | 37 | 
| 38   chrome.tabs.onUpdated.addListener(function(tabId, changeInfo, tab) | 38   ext.tabs.onCompleted.addListener(function(tab) | 
| 39   { | 39   { | 
| 40     if (!(tabId in tabsLoading)) | 40     if (!tabsLoading.has(tab)) | 
| 41     { | 41     { | 
| 42       // Not a pop-up we've previously seen | 42       // Not a pop-up we've previously seen | 
| 43       return; | 43       return; | 
| 44     } | 44     } | 
| 45 | 45 | 
| 46     if ("url" in changeInfo) | 46     checkPotentialPopup(tab, tabsLoading.get(tab)); | 
| 47       checkPotentialPopup(tabId, tab.url, tabsLoading[tabId]); |  | 
| 48 | 47 | 
| 49     if ("status" in changeInfo && changeInfo.status == "complete" && tab.url != 
    "about:blank") | 48     if (tab.url != "about:blank") | 
| 50       delete tabsLoading[tabId]; | 49       tabsLoading.delete(tab); | 
| 51   }); | 50   }); | 
| 52 } | 51 } | 
| 53 | 52 | 
| 54 function checkPotentialPopup(tabId, url, opener) | 53 function checkPotentialPopup(tab, openerUrl) | 
| 55 { | 54 { | 
| 56   var requestHost = extractHostFromURL(url); | 55   var requestHost = extractHostFromURL(tab.url); | 
| 57   var documentHost = extractHostFromURL(opener); | 56   var documentHost = extractHostFromURL(openerUrl); | 
| 58   var thirdParty = isThirdParty(requestHost, documentHost); | 57   var thirdParty = isThirdParty(requestHost, documentHost); | 
| 59   var filter = defaultMatcher.matchesAny(url || "about:blank", "POPUP", document
    Host, thirdParty); | 58   var filter = defaultMatcher.matchesAny(tab.url || "about:blank", "POPUP", docu
    mentHost, thirdParty); | 
| 60   if (filter instanceof BlockingFilter) | 59   if (filter instanceof BlockingFilter) | 
| 61     chrome.tabs.remove(tabId); | 60     tab.close(); | 
| 62 } | 61 } | 
| OLD | NEW | 
|---|