Left: | ||
Right: |
OLD | NEW |
---|---|
1 /* | 1 /* |
2 * This file is part of Adblock Plus <https://adblockplus.org/>, | 2 * This file is part of Adblock Plus <https://adblockplus.org/>, |
3 * Copyright (C) 2006-2015 Eyeo GmbH | 3 * Copyright (C) 2006-2015 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 |
(...skipping 11 matching lines...) Expand all Loading... | |
22 let {Services} = Cu.import("resource://gre/modules/Services.jsm", {}); | 22 let {Services} = Cu.import("resource://gre/modules/Services.jsm", {}); |
23 let {FileUtils} = Cu.import("resource://gre/modules/FileUtils.jsm", {}); | 23 let {FileUtils} = Cu.import("resource://gre/modules/FileUtils.jsm", {}); |
24 let {PrivateBrowsingUtils} = Cu.import("resource://gre/modules/PrivateBrowsingUt ils.jsm", {}); | 24 let {PrivateBrowsingUtils} = Cu.import("resource://gre/modules/PrivateBrowsingUt ils.jsm", {}); |
25 | 25 |
26 const MILLISECONDS_IN_SECOND = 1000; | 26 const MILLISECONDS_IN_SECOND = 1000; |
27 const SECONDS_IN_MINUTE = 60; | 27 const SECONDS_IN_MINUTE = 60; |
28 const SECONDS_IN_HOUR = 60 * SECONDS_IN_MINUTE; | 28 const SECONDS_IN_HOUR = 60 * SECONDS_IN_MINUTE; |
29 const SECONDS_IN_DAY = 24 * SECONDS_IN_HOUR; | 29 const SECONDS_IN_DAY = 24 * SECONDS_IN_HOUR; |
30 | 30 |
31 let contentWindow = window.arguments[0]; | 31 let contentWindow = window.arguments[0]; |
32 let windowURI = (window.arguments[1] instanceof Ci.nsIURI ? window.arguments[1] : null); | 32 let windowURI = window.arguments[1]; |
33 if (typeof windowURI == "string") | |
34 windowURI = Services.newURI(windowURI, null, null); | |
35 let browser = window.arguments[2]; | |
33 | 36 |
34 let reportData = new DOMParser().parseFromString("<report></report>", "text/xml" ); | 37 let reportData = new DOMParser().parseFromString("<report></report>", "text/xml" ); |
35 | 38 |
36 // Some helper functions to work with the report data | 39 // Some helper functions to work with the report data |
37 function reportElement(tag) | 40 function reportElement(tag) |
38 { | 41 { |
39 for (let child = reportData.documentElement.firstChild; child; child = child.n extSibling) | 42 for (let child = reportData.documentElement.firstChild; child; child = child.n extSibling) |
40 if (child.nodeType == Node.ELEMENT_NODE && child.tagName == tag) | 43 if (child.nodeType == Node.ELEMENT_NODE && child.tagName == tag) |
41 return child; | 44 return child; |
42 let element = reportData.createElement(tag); | 45 let element = reportData.createElement(tag); |
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
102 }; | 105 }; |
103 | 106 |
104 // | 107 // |
105 // Data collectors | 108 // Data collectors |
106 // | 109 // |
107 | 110 |
108 var reportsListDataSource = | 111 var reportsListDataSource = |
109 { | 112 { |
110 list: [], | 113 list: [], |
111 | 114 |
112 collectData: function(wnd, windowURI, callback) | 115 collectData: function(wnd, windowURI, browser, callback) |
113 { | 116 { |
114 let data = Prefs.recentReports; | 117 let data = Prefs.recentReports; |
115 if (data && "length" in data) | 118 if (data && "length" in data) |
116 { | 119 { |
117 for (let i = 0; i < data.length; i++) | 120 for (let i = 0; i < data.length; i++) |
118 { | 121 { |
119 let entry = data[i]; | 122 let entry = data[i]; |
120 if (typeof entry.reportURL == "string" && entry.reportURL && | 123 if (typeof entry.reportURL == "string" && entry.reportURL && |
121 typeof entry.time == "number" && Date.now() - entry.time < 30*24*60* 60*1000) | 124 typeof entry.time == "number" && Date.now() - entry.time < 30*24*60* 60*1000) |
122 { | 125 { |
(...skipping 62 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
185 }; | 188 }; |
186 | 189 |
187 var requestsDataSource = | 190 var requestsDataSource = |
188 { | 191 { |
189 requests: reportElement("requests"), | 192 requests: reportElement("requests"), |
190 origRequests: [], | 193 origRequests: [], |
191 requestNotifier: null, | 194 requestNotifier: null, |
192 callback: null, | 195 callback: null, |
193 nodeByKey: Object.create(null), | 196 nodeByKey: Object.create(null), |
194 | 197 |
195 collectData: function(wnd, windowURI, callback) | 198 collectData: function(wnd, windowURI, browser, callback) |
196 { | 199 { |
197 let outerWindowID = wnd.QueryInterface(Ci.nsIInterfaceRequestor) | 200 let outerWindowID = wnd.QueryInterface(Ci.nsIInterfaceRequestor) |
198 .getInterface(Ci.nsIDOMWindowUtils) | 201 .getInterface(Ci.nsIDOMWindowUtils) |
199 .outerWindowID; | 202 .outerWindowID; |
200 this.callback = callback; | 203 this.callback = callback; |
201 this.requestNotifier = new RequestNotifier(outerWindowID, this.onRequestFoun d, this); | 204 this.requestNotifier = new RequestNotifier(outerWindowID, this.onRequestFoun d, this); |
202 }, | 205 }, |
203 | 206 |
204 onRequestFound: function(entry, scanComplete) | 207 onRequestFound: function(entry, scanComplete) |
205 { | 208 { |
(...skipping 33 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
239 this.requestNotifier = null; | 242 this.requestNotifier = null; |
240 this.callback(); | 243 this.callback(); |
241 } | 244 } |
242 } | 245 } |
243 }; | 246 }; |
244 | 247 |
245 var filtersDataSource = | 248 var filtersDataSource = |
246 { | 249 { |
247 origFilters: [], | 250 origFilters: [], |
248 | 251 |
249 collectData: function(wnd, windowURI, callback) | 252 collectData: function(wnd, windowURI, browser, callback) |
250 { | 253 { |
251 let outerWindowID = wnd.QueryInterface(Ci.nsIInterfaceRequestor) | 254 let outerWindowID = wnd.QueryInterface(Ci.nsIInterfaceRequestor) |
252 .getInterface(Ci.nsIDOMWindowUtils) | 255 .getInterface(Ci.nsIDOMWindowUtils) |
253 .outerWindowID; | 256 .outerWindowID; |
254 RequestNotifier.getWindowStatistics(outerWindowID, (wndStats) => | 257 RequestNotifier.getWindowStatistics(outerWindowID, (wndStats) => |
255 { | 258 { |
256 if (wndStats) | 259 if (wndStats) |
257 { | 260 { |
258 let filters = reportElement("filters"); | 261 let filters = reportElement("filters"); |
259 for (let f in wndStats.filters) | 262 for (let f in wndStats.filters) |
(...skipping 17 matching lines...) Expand all Loading... | |
277 { | 280 { |
278 subscriptionFilter: function(s) | 281 subscriptionFilter: function(s) |
279 { | 282 { |
280 if (s.disabled || !(s instanceof RegularSubscription)) | 283 if (s.disabled || !(s instanceof RegularSubscription)) |
281 return false; | 284 return false; |
282 if (s instanceof DownloadableSubscription && !/^(http|https|ftp):/i.test(s.u rl)) | 285 if (s instanceof DownloadableSubscription && !/^(http|https|ftp):/i.test(s.u rl)) |
283 return false; | 286 return false; |
284 return true; | 287 return true; |
285 }, | 288 }, |
286 | 289 |
287 collectData: function(wnd, windowURI, callback) | 290 collectData: function(wnd, windowURI, browser, callback) |
288 { | 291 { |
289 let subscriptions = reportElement("subscriptions"); | 292 let subscriptions = reportElement("subscriptions"); |
290 let now = Math.round(Date.now() / 1000); | 293 let now = Math.round(Date.now() / 1000); |
291 for (let i = 0; i < FilterStorage.subscriptions.length; i++) | 294 for (let i = 0; i < FilterStorage.subscriptions.length; i++) |
292 { | 295 { |
293 let subscription = FilterStorage.subscriptions[i]; | 296 let subscription = FilterStorage.subscriptions[i]; |
294 if (!this.subscriptionFilter(subscription)) | 297 if (!this.subscriptionFilter(subscription)) |
295 continue; | 298 continue; |
296 | 299 |
297 let subscriptionXML = appendElement(subscriptions, "subscription", { | 300 let subscriptionXML = appendElement(subscriptions, "subscription", { |
(...skipping 14 matching lines...) Expand all Loading... | |
312 subscriptionXML.setAttribute("hardExpiration", subscription.expires - now); | 315 subscriptionXML.setAttribute("hardExpiration", subscription.expires - now); |
313 subscriptionXML.setAttribute("downloadStatus", subscription.downloadStat us); | 316 subscriptionXML.setAttribute("downloadStatus", subscription.downloadStat us); |
314 } | 317 } |
315 } | 318 } |
316 callback(); | 319 callback(); |
317 } | 320 } |
318 }; | 321 }; |
319 | 322 |
320 var remoteDataSource = | 323 var remoteDataSource = |
321 { | 324 { |
322 collectData: function(wnd, windowURI, callback) | 325 collectData: function(wnd, windowURI, browser, callback) |
323 { | 326 { |
324 let outerWindowID = wnd.QueryInterface(Ci.nsIInterfaceRequestor) | 327 let outerWindowID = wnd.QueryInterface(Ci.nsIInterfaceRequestor) |
325 .getInterface(Ci.nsIDOMWindowUtils) | 328 .getInterface(Ci.nsIDOMWindowUtils) |
326 .outerWindowID; | 329 .outerWindowID; |
327 let dataCollector = require("dataCollector"); | 330 let dataCollector = require("dataCollector"); |
328 let screenshotWidth = screenshotDataSource.getWidth(); | 331 let screenshotWidth = screenshotDataSource.getWidth(); |
329 dataCollector.collectData(outerWindowID, screenshotWidth, data => { | 332 dataCollector.collectData(outerWindowID, screenshotWidth, data => { |
330 screenshotDataSource.setData(data && data.screenshot); | 333 screenshotDataSource.setData(data && data.screenshot); |
331 framesDataSource.setData(windowURI, data && data.opener, data && data.refe rrer, data && data.frames); | 334 framesDataSource.setData(windowURI, data && data.opener, data && data.refe rrer, data && data.frames); |
332 callback(); | 335 callback(); |
(...skipping 240 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
573 let frameXML = appendElement(xmlList, "frame", { | 576 let frameXML = appendElement(xmlList, "frame", { |
574 url: censorURL(frame.url) | 577 url: censorURL(frame.url) |
575 }); | 578 }); |
576 this.addFrames(frame.frames, frameXML); | 579 this.addFrames(frame.frames, frameXML); |
577 } | 580 } |
578 } | 581 } |
579 }; | 582 }; |
580 | 583 |
581 var errorsDataSource = | 584 var errorsDataSource = |
582 { | 585 { |
583 collectData: function(wnd, windowURI, callback) | 586 collectData: function(wnd, windowURI, browser, callback) |
584 { | 587 { |
585 let {addonID} = require("info"); | 588 let {addonID} = require("info"); |
586 addonID = addonID.replace(/[\{\}]/g, ""); | 589 addonID = addonID.replace(/[\{\}]/g, ""); |
587 | 590 |
588 // See https://bugzilla.mozilla.org/show_bug.cgi?id=664695 - starting with | 591 // See https://bugzilla.mozilla.org/show_bug.cgi?id=664695 - starting with |
589 // Gecko 19 this function returns the result, before that it wrote to a | 592 // Gecko 19 this function returns the result, before that it wrote to a |
590 // parameter. | 593 // parameter. |
591 let outparam = {}; | 594 let outparam = {}; |
592 let messages = Cc["@mozilla.org/consoleservice;1"].getService(Ci.nsIConsoleS ervice).getMessageArray(outparam, {}); | 595 let messages = Cc["@mozilla.org/consoleservice;1"].getService(Ci.nsIConsoleS ervice).getMessageArray(outparam, {}); |
593 messages = messages || outparam.value || []; | 596 messages = messages || outparam.value || []; |
(...skipping 54 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
648 } | 651 } |
649 | 652 |
650 callback(); | 653 callback(); |
651 } | 654 } |
652 }; | 655 }; |
653 | 656 |
654 var extensionsDataSource = | 657 var extensionsDataSource = |
655 { | 658 { |
656 data: reportData.createElement("extensions"), | 659 data: reportData.createElement("extensions"), |
657 | 660 |
658 collectData: function(wnd, windowURI, callback) | 661 collectData: function(wnd, windowURI, browser, callback) |
659 { | 662 { |
660 try | 663 try |
661 { | 664 { |
662 let AddonManager = Cu.import("resource://gre/modules/AddonManager.jsm", nu ll).AddonManager; | 665 let AddonManager = Cu.import("resource://gre/modules/AddonManager.jsm", nu ll).AddonManager; |
663 AddonManager.getAddonsByTypes(["extension", "plugin"], function(items) | 666 AddonManager.getAddonsByTypes(["extension", "plugin"], function(items) |
664 { | 667 { |
665 for (let i = 0; i < items.length; i++) | 668 for (let i = 0; i < items.length; i++) |
666 { | 669 { |
667 let item = items[i]; | 670 let item = items[i]; |
668 if (!item.isActive) | 671 if (!item.isActive) |
(...skipping 19 matching lines...) Expand all Loading... | |
688 { | 691 { |
689 if (doExport) | 692 if (doExport) |
690 reportData.documentElement.appendChild(this.data); | 693 reportData.documentElement.appendChild(this.data); |
691 else if (this.data.parentNode) | 694 else if (this.data.parentNode) |
692 this.data.parentNode.removeChild(this.data); | 695 this.data.parentNode.removeChild(this.data); |
693 } | 696 } |
694 }; | 697 }; |
695 | 698 |
696 var subscriptionUpdateDataSource = | 699 var subscriptionUpdateDataSource = |
697 { | 700 { |
698 contentWnd: null, | 701 browser: null, |
699 type: null, | 702 type: null, |
700 outdated: null, | 703 outdated: null, |
701 needUpdate: null, | 704 needUpdate: null, |
702 | 705 |
703 subscriptionFilter: function(s) | 706 subscriptionFilter: function(s) |
704 { | 707 { |
705 if (s instanceof DownloadableSubscription) | 708 if (s instanceof DownloadableSubscription) |
706 return subscriptionsDataSource.subscriptionFilter(s); | 709 return subscriptionsDataSource.subscriptionFilter(s); |
707 else | 710 else |
708 return false; | 711 return false; |
709 }, | 712 }, |
710 | 713 |
711 collectData: function(wnd, windowURI, callback) | 714 collectData: function(wnd, windowURI, browser, callback) |
712 { | 715 { |
713 this.contentWnd = wnd; | 716 this.browser = browser; |
714 let now = Date.now() / MILLISECONDS_IN_SECOND; | 717 let now = Date.now() / MILLISECONDS_IN_SECOND; |
715 let outdatedThreshold = now - 14 * SECONDS_IN_DAY; | 718 let outdatedThreshold = now - 14 * SECONDS_IN_DAY; |
716 let needUpdateThreshold = now - 1 * SECONDS_IN_HOUR; | 719 let needUpdateThreshold = now - 1 * SECONDS_IN_HOUR; |
717 | 720 |
718 this.outdated = []; | 721 this.outdated = []; |
719 this.needUpdate = []; | 722 this.needUpdate = []; |
720 | 723 |
721 let subscriptions = FilterStorage.subscriptions.filter(this.subscriptionFilt er); | 724 let subscriptions = FilterStorage.subscriptions.filter(this.subscriptionFilt er); |
722 for (let i = 0; i < subscriptions.length; i++) | 725 for (let i = 0; i < subscriptions.length; i++) |
723 { | 726 { |
(...skipping 70 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
794 } | 797 } |
795 | 798 |
796 if (filtersRemoved) | 799 if (filtersRemoved) |
797 { | 800 { |
798 // Force the user to reload the page | 801 // Force the user to reload the page |
799 E("updateFixedIssue").hidden = false; | 802 E("updateFixedIssue").hidden = false; |
800 document.documentElement.canAdvance = true; | 803 document.documentElement.canAdvance = true; |
801 | 804 |
802 let nextButton = document.documentElement.getButton("next"); | 805 let nextButton = document.documentElement.getButton("next"); |
803 [nextButton.label, nextButton.accessKey] = Utils.splitLabel(E("updateP age").getAttribute("reloadButtonLabel")); | 806 [nextButton.label, nextButton.accessKey] = Utils.splitLabel(E("updateP age").getAttribute("reloadButtonLabel")); |
804 document.documentElement.addEventListener("wizardnext", function(event ) | 807 document.documentElement.addEventListener("wizardnext", event => |
805 { | 808 { |
806 event.preventDefault(); | 809 event.preventDefault(); |
807 event.stopPropagation(); | 810 event.stopPropagation(); |
808 window.close(); | 811 window.close(); |
809 this.contentWnd.location.reload(); | 812 this.browser.reload(); |
Erik
2016/01/08 04:00:45
the only problem I see with this is that the curre
Wladimir Palant
2016/01/08 13:46:20
Given that it is a specific <browser> element rath
| |
810 }.bind(this), true); | 813 }, true); |
811 } | 814 } |
812 else | 815 else |
813 { | 816 { |
814 this.collectData(null, null, function() {}); | 817 this.collectData(null, null, null, function() {}); |
815 this.needUpdate = []; | 818 this.needUpdate = []; |
816 if (this.outdated.length) | 819 if (this.outdated.length) |
817 { | 820 { |
818 document.documentElement.canRewind = true; | 821 document.documentElement.canRewind = true; |
819 | 822 |
820 this.updatePage(this.type); | 823 this.updatePage(this.type); |
821 this.showPage(); | 824 this.showPage(); |
822 } | 825 } |
823 else | 826 else |
824 { | 827 { |
(...skipping 21 matching lines...) Expand all Loading... | |
846 | 849 |
847 updateOutdated: function() | 850 updateOutdated: function() |
848 { | 851 { |
849 for (let i = 0; i < this.outdated.length; i++) | 852 for (let i = 0; i < this.outdated.length; i++) |
850 Synchronizer.execute(this.outdated[i], true); | 853 Synchronizer.execute(this.outdated[i], true); |
851 } | 854 } |
852 } | 855 } |
853 | 856 |
854 var issuesDataSource = | 857 var issuesDataSource = |
855 { | 858 { |
856 contentWnd: null, | 859 browser: null, |
857 isEnabled: Prefs.enabled, | 860 isEnabled: Prefs.enabled, |
858 whitelistFilter: null, | 861 whitelistFilter: null, |
859 disabledFilters: [], | 862 disabledFilters: [], |
860 disabledSubscriptions: [], | 863 disabledSubscriptions: [], |
861 ownFilters: [], | 864 ownFilters: [], |
862 numSubscriptions: 0, | 865 numSubscriptions: 0, |
863 numAppliedFilters: Infinity, | 866 numAppliedFilters: Infinity, |
864 | 867 |
865 subscriptionFilter: function(s) | 868 subscriptionFilter: function(s) |
866 { | 869 { |
867 if (s instanceof DownloadableSubscription && | 870 if (s instanceof DownloadableSubscription && |
868 s.url != Prefs.subscriptions_exceptionsurl && | 871 s.url != Prefs.subscriptions_exceptionsurl && |
869 s.url != Prefs.subscriptions_antiadblockurl) | 872 s.url != Prefs.subscriptions_antiadblockurl) |
870 { | 873 { |
871 return subscriptionsDataSource.subscriptionFilter(s); | 874 return subscriptionsDataSource.subscriptionFilter(s); |
872 } | 875 } |
873 else | 876 else |
874 return false; | 877 return false; |
875 }, | 878 }, |
876 | 879 |
877 collectData: function(wnd, windowURI, callback) | 880 collectData: function(wnd, windowURI, browser, callback) |
878 { | 881 { |
879 this.contentWnd = wnd; | 882 this.browser = browser; |
880 this.whitelistFilter = Policy.isWhitelisted(windowURI.spec); | 883 this.whitelistFilter = Policy.isWhitelisted(windowURI.spec); |
881 | 884 |
882 if (!this.whitelistFilter && this.isEnabled) | 885 if (!this.whitelistFilter && this.isEnabled) |
883 { | 886 { |
884 // Find disabled filters in active subscriptions matching any of the reque sts | 887 // Find disabled filters in active subscriptions matching any of the reque sts |
885 let disabledMatcher = new CombinedMatcher(); | 888 let disabledMatcher = new CombinedMatcher(); |
886 for (let subscription of FilterStorage.subscriptions) | 889 for (let subscription of FilterStorage.subscriptions) |
887 { | 890 { |
888 if (subscription.disabled) | 891 if (subscription.disabled) |
889 continue; | 892 continue; |
(...skipping 156 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1046 | 1049 |
1047 forceReload: function() | 1050 forceReload: function() |
1048 { | 1051 { |
1049 // User changed configuration, don't allow sending report now - page needs | 1052 // User changed configuration, don't allow sending report now - page needs |
1050 // to be reloaded | 1053 // to be reloaded |
1051 E("issuesOverride").hidden = true; | 1054 E("issuesOverride").hidden = true; |
1052 E("issuesChangeMessage").hidden = false; | 1055 E("issuesChangeMessage").hidden = false; |
1053 document.documentElement.canRewind = false; | 1056 document.documentElement.canRewind = false; |
1054 document.documentElement.canAdvance = true; | 1057 document.documentElement.canAdvance = true; |
1055 | 1058 |
1056 let contentWnd = this.contentWnd; | |
1057 let nextButton = document.documentElement.getButton("next"); | 1059 let nextButton = document.documentElement.getButton("next"); |
1058 [nextButton.label, nextButton.accessKey] = Utils.splitLabel(E("updatePage"). getAttribute("reloadButtonLabel")); | 1060 [nextButton.label, nextButton.accessKey] = Utils.splitLabel(E("updatePage"). getAttribute("reloadButtonLabel")); |
1059 document.documentElement.addEventListener("wizardnext", function(event) | 1061 document.documentElement.addEventListener("wizardnext", event => |
1060 { | 1062 { |
1061 event.preventDefault(); | 1063 event.preventDefault(); |
1062 event.stopPropagation(); | 1064 event.stopPropagation(); |
1063 window.close(); | 1065 window.close(); |
1064 contentWnd.location.reload(); | 1066 this.browser.reload(); |
1065 }, true); | 1067 }, true); |
1066 }, | 1068 }, |
1067 | 1069 |
1068 removeWhitelist: function() | 1070 removeWhitelist: function() |
1069 { | 1071 { |
1070 if (this.whitelistFilter && this.whitelistFilter.subscriptions.length) | 1072 if (this.whitelistFilter && this.whitelistFilter.subscriptions.length) |
1071 this.whitelistFilter.disabled = true; | 1073 this.whitelistFilter.disabled = true; |
1072 E("issuesWhitelistBox").hidden = true; | 1074 E("issuesWhitelistBox").hidden = true; |
1073 this.forceReload(); | 1075 this.forceReload(); |
1074 }, | 1076 }, |
(...skipping 151 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1226 { | 1228 { |
1227 let progressMeter = E("dataCollectorProgress"); | 1229 let progressMeter = E("dataCollectorProgress"); |
1228 progressMeter.mode = "determined"; | 1230 progressMeter.mode = "determined"; |
1229 progressMeter.value = progress; | 1231 progressMeter.value = progress; |
1230 } | 1232 } |
1231 | 1233 |
1232 // Continue with the next data source, asynchronously to allow progress mete r to update | 1234 // Continue with the next data source, asynchronously to allow progress mete r to update |
1233 let dataSource = dataCollectors.shift(); | 1235 let dataSource = dataCollectors.shift(); |
1234 Utils.runAsync(function() | 1236 Utils.runAsync(function() |
1235 { | 1237 { |
1236 dataSource.collectData(contentWindow, windowURI, initNextDataSource); | 1238 dataSource.collectData(contentWindow, windowURI, browser, initNextDataSour ce); |
1237 }); | 1239 }); |
1238 }; | 1240 }; |
1239 | 1241 |
1240 initNextDataSource(); | 1242 initNextDataSource(); |
1241 } | 1243 } |
1242 | 1244 |
1243 function initTypeSelectorPage() | 1245 function initTypeSelectorPage() |
1244 { | 1246 { |
1245 E("progressBar").activeItem = E("typeSelectorHeader"); | 1247 E("progressBar").activeItem = E("typeSelectorHeader"); |
1246 let header = document.getAnonymousElementByAttribute(document.documentElement, "class", "wizard-header"); | 1248 let header = document.getAnonymousElementByAttribute(document.documentElement, "class", "wizard-header"); |
(...skipping 302 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
1549 | 1551 |
1550 function censorURL(url) | 1552 function censorURL(url) |
1551 { | 1553 { |
1552 return url.replace(/([?;&\/#][^?;&\/#]+?=)[^?;&\/#]+/g, "$1*"); | 1554 return url.replace(/([?;&\/#][^?;&\/#]+?=)[^?;&\/#]+/g, "$1*"); |
1553 } | 1555 } |
1554 | 1556 |
1555 function encodeHTML(str) | 1557 function encodeHTML(str) |
1556 { | 1558 { |
1557 return str.replace(/&/g, "&").replace(/</g, "<").replace(/>/g, ">"). replace(/"/g, """); | 1559 return str.replace(/&/g, "&").replace(/</g, "<").replace(/>/g, ">"). replace(/"/g, """); |
1558 } | 1560 } |
OLD | NEW |