| Left: | ||
| Right: |
| LEFT | RIGHT |
|---|---|
| 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 |
| 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 "use strict"; | 18 "use strict"; |
| 19 | 19 |
| 20 let typeMap = { | 20 const typeMap = { |
| 21 "img": "IMAGE", | 21 "img": "IMAGE", |
| 22 "input": "IMAGE", | 22 "input": "IMAGE", |
| 23 "picture": "IMAGE", | 23 "picture": "IMAGE", |
| 24 "audio": "MEDIA", | 24 "audio": "MEDIA", |
| 25 "video": "MEDIA", | 25 "video": "MEDIA", |
| 26 "frame": "SUBDOCUMENT", | 26 "frame": "SUBDOCUMENT", |
| 27 "iframe": "SUBDOCUMENT", | 27 "iframe": "SUBDOCUMENT", |
| 28 "object": "OBJECT", | 28 "object": "OBJECT", |
| 29 "embed": "OBJECT" | 29 "embed": "OBJECT" |
| 30 }; | 30 }; |
| (...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 75 } | 75 } |
| 76 | 76 |
| 77 return urls; | 77 return urls; |
| 78 } | 78 } |
| 79 | 79 |
| 80 function getURLsFromMediaElement(element) | 80 function getURLsFromMediaElement(element) |
| 81 { | 81 { |
| 82 let urls = getURLsFromAttributes(element); | 82 let urls = getURLsFromAttributes(element); |
| 83 | 83 |
| 84 for (let child of element.children) | 84 for (let child of element.children) |
| 85 { | |
| 85 if (child.localName == "source" || child.localName == "track") | 86 if (child.localName == "source" || child.localName == "track") |
| 86 urls.push.apply(urls, getURLsFromAttributes(child)); | 87 urls.push.apply(urls, getURLsFromAttributes(child)); |
| 88 } | |
| 87 | 89 |
| 88 if (element.poster) | 90 if (element.poster) |
| 89 urls.push(element.poster); | 91 urls.push(element.poster); |
| 90 | 92 |
| 91 return urls; | 93 return urls; |
| 92 } | 94 } |
| 93 | 95 |
| 94 function getURLsFromElement(element) | 96 function getURLsFromElement(element) |
| 95 { | 97 { |
| 96 let urls; | 98 let urls; |
| (...skipping 169 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 266 if (!document.contains(node)) | 268 if (!document.contains(node)) |
| 267 continue; | 269 continue; |
| 268 | 270 |
| 269 // Since querySelectorAll() doesn't consider the root itself | 271 // Since querySelectorAll() doesn't consider the root itself |
| 270 // and since CSS selectors can also match siblings, we have | 272 // and since CSS selectors can also match siblings, we have |
| 271 // to consider the parent node for attribute mutations. | 273 // to consider the parent node for attribute mutations. |
| 272 if (mutation.type == "attributes") | 274 if (mutation.type == "attributes") |
| 273 node = node.parentNode; | 275 node = node.parentNode; |
| 274 | 276 |
| 275 let addNode = true; | 277 let addNode = true; |
| 276 for (let i = 0; i < this.changedNodes.length; i++) | 278 for (let i = 0; i < this.changedNodes.length; i++) |
|
Sebastian Noack
2017/01/16 14:47:40
Wouldn't this cause the the variable i form the ou
kzar
2017/01/16 14:59:07
I don't think that there is a variable i from the
Sebastian Noack
2017/01/16 15:35:54
Never mind, the outer loop is now using for-of, an
kzar
2017/01/17 07:42:44
Acknowledged.
| |
| 277 { | 279 { |
| 278 let previouslyChangedNode = this.changedNodes[i]; | 280 let previouslyChangedNode = this.changedNodes[i]; |
| 279 | 281 |
| 280 // If we are already going to check an ancestor of this node, | 282 // If we are already going to check an ancestor of this node, |
| 281 // we can ignore this node, since it will be considered anyway | 283 // we can ignore this node, since it will be considered anyway |
| 282 // when checking one of its ancestors. | 284 // when checking one of its ancestors. |
| 283 if (previouslyChangedNode.contains(node)) | 285 if (previouslyChangedNode.contains(node)) |
| 284 { | 286 { |
| 285 addNode = false; | 287 addNode = false; |
| 286 break; | 288 break; |
| (...skipping 302 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 589 checkCollapse(event.target); | 591 checkCollapse(event.target); |
| 590 }, true); | 592 }, true); |
| 591 | 593 |
| 592 document.addEventListener("load", event => | 594 document.addEventListener("load", event => |
| 593 { | 595 { |
| 594 let element = event.target; | 596 let element = event.target; |
| 595 if (/^i?frame$/.test(element.localName)) | 597 if (/^i?frame$/.test(element.localName)) |
| 596 checkCollapse(element); | 598 checkCollapse(element); |
| 597 }, true); | 599 }, true); |
| 598 } | 600 } |
| LEFT | RIGHT |