| 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-2016 Eyeo GmbH | 3 * Copyright (C) 2006-2016 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 316 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 327 }, | 327 }, |
| 328 | 328 |
| 329 disconnect: function() | 329 disconnect: function() |
| 330 { | 330 { |
| 331 this.document.removeEventListener("DOMContentLoaded", this.trace); | 331 this.document.removeEventListener("DOMContentLoaded", this.trace); |
| 332 this.observer.disconnect(); | 332 this.observer.disconnect(); |
| 333 clearTimeout(this.timeout); | 333 clearTimeout(this.timeout); |
| 334 } | 334 } |
| 335 }; | 335 }; |
| 336 | 336 |
| 337 function enforceStyleSheetRules(style) | |
| 338 { | |
| 339 style.id = id; | |
| 340 injectJS( | |
| 341 function(id) | |
| 342 { | |
| 343 var style = document.getElementById(id) || | |
| 344 document.documentElement.shadowRoot.getElementById(id); | |
| 345 style.removeAttribute("id"); | |
| 346 | |
| 347 Object.defineProperty(style.sheet, "disabled", | |
|
Sebastian Noack
2016/08/04 20:44:23
Where did the code go, that addressed deleteRule a
kzar
2016/08/05 11:01:57
This review is based upon the changes in a couple
| |
| 348 {value: false, enumerable: true}); | |
| 349 | |
| 350 for (var i = 0; i < style.sheet.rules.length; i += 1) | |
| 351 Object.defineProperty(style.sheet.rules[i].style, "display", | |
|
Sebastian Noack
2016/08/04 20:44:23
How about overriding style.sheet.rules (and sheet.
kzar
2016/08/05 11:01:57
Cool idea, but I actually had to overwrite the get
| |
| 352 {value: "none", enumerable: true}); | |
| 353 }, id | |
| 354 ); | |
| 355 } | |
| 356 | |
| 337 function reinjectStyleSheetWhenRemoved(document, style) | 357 function reinjectStyleSheetWhenRemoved(document, style) |
| 338 { | 358 { |
| 339 if (!MutationObserver) | 359 if (!MutationObserver) |
| 340 return null; | 360 return null; |
| 341 | 361 |
| 342 var rules = style.sheet.rules; | 362 var rules = style.sheet.rules; |
| 343 var parentNode = style.parentNode; | 363 var parentNode = style.parentNode; |
| 344 var observer = new MutationObserver(function() | 364 var observer = new MutationObserver(function() |
| 345 { | 365 { |
| 346 if (style.parentNode != parentNode) | 366 if (style.parentNode != parentNode) |
| 347 { | 367 { |
| 348 parentNode.appendChild(style); | 368 parentNode.appendChild(style); |
| 349 | 369 |
| 350 if (style.sheet.rules.length == 0) | 370 if (style.sheet.rules.length == 0) |
| 351 { | 371 { |
| 352 for (var i = 0; i < rules.length; i += 1) | 372 for (var i = 0; i < rules.length; i += 1) |
| 353 style.sheet.addRule(rules[i].selectorText, "display: none !important;" ); | 373 style.sheet.addRule(rules[i].selectorText); |
| 354 | 374 |
| 355 style.id = id; | 375 enforceStyleSheetRules(style); |
| 356 injectJS( | |
| 357 function(id) | |
| 358 { | |
| 359 var style = document.getElementById(id) || | |
| 360 document.documentElement.shadowRoot.getElementById(id); | |
| 361 style.removeAttribute("id"); | |
| 362 Object.defineProperty(style.sheet, "disabled", | |
| 363 {value: false, enumerable: true}); | |
| 364 }, id | |
| 365 ); | |
| 366 } | 376 } |
| 367 } | 377 } |
| 368 }); | 378 }); |
| 369 | 379 |
| 370 observer.observe(parentNode, {childList: true}); | 380 observer.observe(parentNode, {childList: true}); |
| 371 return observer; | 381 return observer; |
| 372 } | 382 } |
| 373 | 383 |
| 374 function injectJS(f) | 384 function injectJS(f) |
| 375 { | 385 { |
| (...skipping 212 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 588 } | 598 } |
| 589 | 599 |
| 590 // Safari only allows 8192 primitive selectors to be injected at once[1], we | 600 // Safari only allows 8192 primitive selectors to be injected at once[1], we |
| 591 // therefore chunk the inserted selectors into groups of 200 to be safe. | 601 // therefore chunk the inserted selectors into groups of 200 to be safe. |
| 592 // (Chrome also has a limit, larger... but we're not certain exactly what it | 602 // (Chrome also has a limit, larger... but we're not certain exactly what it |
| 593 // is! Edge apparently has no such limit.) | 603 // is! Edge apparently has no such limit.) |
| 594 // [1] - https://github.com/WebKit/webkit/blob/1cb2227f6b2a1035f7bdc46e5ab69 debb75fc1de/Source/WebCore/css/RuleSet.h#L68 | 604 // [1] - https://github.com/WebKit/webkit/blob/1cb2227f6b2a1035f7bdc46e5ab69 debb75fc1de/Source/WebCore/css/RuleSet.h#L68 |
| 595 for (var i = 0; i < selectors.length; i += SELECTOR_GROUP_SIZE) | 605 for (var i = 0; i < selectors.length; i += SELECTOR_GROUP_SIZE) |
| 596 { | 606 { |
| 597 var selector = selectors.slice(i, i + SELECTOR_GROUP_SIZE).join(", "); | 607 var selector = selectors.slice(i, i + SELECTOR_GROUP_SIZE).join(", "); |
| 598 style.sheet.addRule(selector, "display: none !important;"); | 608 style.sheet.addRule(selector); |
| 599 } | 609 } |
| 610 enforceStyleSheetRules(style); | |
| 600 }; | 611 }; |
| 601 | 612 |
| 602 var updateStylesheet = function() | 613 var updateStylesheet = function() |
| 603 { | 614 { |
| 604 var selectors = null; | 615 var selectors = null; |
| 605 var CSSPropertyFiltersLoaded = false; | 616 var CSSPropertyFiltersLoaded = false; |
| 606 | 617 |
| 607 var checkLoaded = function() | 618 var checkLoaded = function() |
| 608 { | 619 { |
| 609 if (!selectors || !CSSPropertyFiltersLoaded) | 620 if (!selectors || !CSSPropertyFiltersLoaded) |
| (...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 685 }, true); | 696 }, true); |
| 686 | 697 |
| 687 return updateStylesheet; | 698 return updateStylesheet; |
| 688 } | 699 } |
| 689 | 700 |
| 690 if (document instanceof HTMLDocument) | 701 if (document instanceof HTMLDocument) |
| 691 { | 702 { |
| 692 checkSitekey(); | 703 checkSitekey(); |
| 693 window.updateStylesheet = init(document); | 704 window.updateStylesheet = init(document); |
| 694 } | 705 } |
| OLD | NEW |