From 3391435f750e9a03da7407ccecd9b3b2f950b601 Mon Sep 17 00:00:00 2001 From: Raymond Hill Date: Mon, 28 Mar 2022 12:11:18 -0400 Subject: [PATCH] Handle `picture > source` elements Related issue: - https://github.com/uBlockOrigin/uBlock-issues/issues/2069 --- src/js/scriptlets/epicker.js | 24 +++++++++++++++++++----- 1 file changed, 19 insertions(+), 5 deletions(-) diff --git a/src/js/scriptlets/epicker.js b/src/js/scriptlets/epicker.js index 25afe465a..758791585 100644 --- a/src/js/scriptlets/epicker.js +++ b/src/js/scriptlets/epicker.js @@ -231,13 +231,12 @@ const resourceURLsFromElement = function(elem) { if ( url !== '' ) { urls.push(url); } return urls; } - { - const s = elem[prop]; - if ( typeof s === 'string' && /^https?:\/\//.test(s) ) { - urls.push(trimFragmentFromURL(s.slice(0, 1024))); - } + const s = elem[prop]; + if ( typeof s === 'string' && /^https?:\/\//.test(s) ) { + urls.push(trimFragmentFromURL(s.slice(0, 1024))); } resourceURLsFromSrcset(elem, urls); + resourceURLsFromPicture(elem, urls); return urls; }; @@ -272,6 +271,20 @@ const resourceURLsFromSrcset = function(elem, out) { } }; +// https://github.com/uBlockOrigin/uBlock-issues/issues/2069#issuecomment-1080600661 +// https://developer.mozilla.org/en-US/docs/Web/HTML/Element/picture +const resourceURLsFromPicture = function(elem, out) { + if ( elem.localName === 'source' ) { return; } + const picture = elem.parentElement; + if ( picture === null || picture.localName !== 'picture' ) { return; } + const sources = picture.querySelectorAll(':scope > source'); + for ( const source of sources ) { + const urls = resourceURLsFromElement(source); + if ( urls.length === 0 ) { continue; } + out.push(...urls); + } +}; + /******************************************************************************/ const netFilterFromUnion = function(patternIn, out) { @@ -364,6 +377,7 @@ const netFilter1stSources = { 'iframe': 'src', 'img': 'src', 'object': 'data', + 'source': 'src', 'video': 'src' };