1
0
mirror of https://github.com/gorhill/uBlock.git synced 2024-09-03 01:29:39 +02:00

code review

This commit is contained in:
gorhill 2015-11-25 10:05:23 -05:00
parent c34ee1b4b2
commit 05476e9fd3
4 changed files with 27 additions and 10 deletions

View File

@ -3,7 +3,7 @@ e65fbcaa573c028770f1d0afada55672 assets/ublock/redirect-resources.txt
7a04294b44b88baa34cf3e4bfe0e59db assets/ublock/privacy.txt
b2dbf435507aa0262b289c67cbef2142 assets/ublock/filters.txt
146704ad1c0393e342afdb416762c183 assets/ublock/badware.txt
4b3df06f0b27c57cea0006ae559e078b assets/ublock/redirect.txt
d3e766dbd8624423a7e5fea878580ee9 assets/ublock/redirect.txt
e1a6bb625a9ee59cc57f6b77c76108ff assets/ublock/filter-lists.json
f549ce62117ff04b63c177227b5cb288 assets/thirdparties/easylist-downloads.adblockplus.org/easyprivacy.txt
da709032e6b674de08b7561e3f4e552d assets/thirdparties/easylist-downloads.adblockplus.org/easylist.txt

View File

@ -1,4 +1,7 @@
# uBlock Origin -- To redirect blocked resources to friendlier contents.
# uBlock Origin -- To redirect blocked resources to neutered contents.
#
# The redirect tokens reference an entry in the resource library:
# https://github.com/gorhill/uBlock/blob/master/assets/ublock/redirect-resources.txt
||s3.amazonaws.com/homad-global-configs.schneevonmorgen.com/hd-main.js$script,domain=cdnapi.kaltura.com,redirect=hd-main.js
||hgc.svonm.com/hd-main.js$script,domain=cdnapi.kaltura.com,redirect=hd-main.js

View File

@ -130,7 +130,7 @@ RedirectEngine.prototype.fromCompiledRule = function(line) {
RedirectEngine.prototype.compileRuleFromStaticFilter = function(line) {
var matches = this.reFilterParser.exec(line);
if ( matches === null || matches.length !== 4 ) {
return '';
return;
}
var pattern = (matches[1] + matches[2]).replace(/[.+?{}()|[\]\\]/g, '\\$&')
@ -138,7 +138,7 @@ RedirectEngine.prototype.compileRuleFromStaticFilter = function(line) {
.replace(/\*/g, '.*?');
var des = matches[1];
var types = [];
var type;
var redirect = '';
var srcs = [];
var options = matches[3].split(','), option;
@ -151,20 +151,24 @@ RedirectEngine.prototype.compileRuleFromStaticFilter = function(line) {
srcs = option.slice(7).split('|');
continue;
}
// One and only one type must be specified.
if ( option in this.supportedTypes ) {
types.push(option);
if ( type !== undefined ) {
return;
}
type = option;
continue;
}
}
// Need a resource token.
if ( redirect === '' ) {
return '';
return;
}
// Need one single type (not negated).
if ( types.length !== 1 || types[0].charAt(0) === '~' ) {
return '';
// Need one single type -- not negated.
if ( type === undefined || type.charAt(0) === '~' ) {
return;
}
if ( des === '' ) {
@ -179,10 +183,17 @@ RedirectEngine.prototype.compileRuleFromStaticFilter = function(line) {
var i = srcs.length, src;
while ( i-- ) {
src = srcs[i];
if ( src === '' ) {
continue;
}
if ( src.charAt(0) === '~' ) {
continue;
}
out.push(srcs[i] + '\t' + des + '\t' + types[0] + '\t' + pattern + '\t' + redirect);
// Need at least one specific src or des.
if ( src === '*' && des === '*' ) {
continue;
}
out.push(src + '\t' + des + '\t' + type + '\t' + pattern + '\t' + redirect);
}
return out;

View File

@ -2053,6 +2053,9 @@ FilterContainer.prototype.compileToAtomicFilter = function(filterClass, parsed,
}
var redirects = µb.redirectEngine.compileRuleFromStaticFilter(parsed.raw);
if ( Array.isArray(redirects) === false ) {
return;
}
var i = redirects.length;
while ( i-- ) {
out.push('n\v\v\v=>\v' + redirects[i]);