mirror of
https://github.com/gorhill/uBlock.git
synced 2024-11-02 00:42:45 +01:00
This commit is contained in:
parent
4f7aab695c
commit
ef84e6d8fd
@ -54,6 +54,13 @@ if (
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// https://issues.adblockplus.org/ticket/5695
|
||||||
|
// - Good idea, adopted: cleaner way to detect user-stylesheet support.
|
||||||
|
vAPI.supportsUserStylesheets =
|
||||||
|
chrome.extensionTypes instanceof Object &&
|
||||||
|
chrome.extensionTypes.CSSOrigin instanceof Object &&
|
||||||
|
'USER' in chrome.extensionTypes.CSSOrigin;
|
||||||
|
|
||||||
var noopFunc = function(){};
|
var noopFunc = function(){};
|
||||||
|
|
||||||
/******************************************************************************/
|
/******************************************************************************/
|
||||||
@ -730,12 +737,7 @@ vAPI.messaging.onPortMessage = (function() {
|
|||||||
var messaging = vAPI.messaging,
|
var messaging = vAPI.messaging,
|
||||||
toAuxPending = {};
|
toAuxPending = {};
|
||||||
|
|
||||||
// https://issues.adblockplus.org/ticket/5695
|
var supportsUserStylesheets = vAPI.supportsUserStylesheets;
|
||||||
// - Good idea, adopted: cleaner way to detect user-stylesheet support.
|
|
||||||
var supportsUserStylesheets =
|
|
||||||
chrome.extensionTypes instanceof Object &&
|
|
||||||
chrome.extensionTypes.CSSOrigin instanceof Object &&
|
|
||||||
'USER' in chrome.extensionTypes.CSSOrigin;
|
|
||||||
|
|
||||||
// Use a wrapper to avoid closure and to allow reuse.
|
// Use a wrapper to avoid closure and to allow reuse.
|
||||||
var CallbackWrapper = function(port, request, timeout) {
|
var CallbackWrapper = function(port, request, timeout) {
|
||||||
|
@ -98,7 +98,8 @@ var fromNetFilter = function(details) {
|
|||||||
var fromCosmeticFilter = function(details) {
|
var fromCosmeticFilter = function(details) {
|
||||||
var match = /^#@?#/.exec(details.rawFilter),
|
var match = /^#@?#/.exec(details.rawFilter),
|
||||||
prefix = match[0],
|
prefix = match[0],
|
||||||
filter = details.rawFilter.slice(prefix.length);
|
filter = details.rawFilter.slice(prefix.length),
|
||||||
|
selector = filter;
|
||||||
|
|
||||||
// With low generic simple cosmetic filters, the class or id prefix
|
// With low generic simple cosmetic filters, the class or id prefix
|
||||||
// character is not part of the compiled data. So we must be ready to
|
// character is not part of the compiled data. So we must be ready to
|
||||||
@ -173,28 +174,29 @@ var fromCosmeticFilter = function(details) {
|
|||||||
switch ( fargs[0] ) {
|
switch ( fargs[0] ) {
|
||||||
case 0: // id-based
|
case 0: // id-based
|
||||||
case 2: // class-based
|
case 2: // class-based
|
||||||
found = prefix + idOrClassPrefix + filter;
|
found = prefix + selector;
|
||||||
break;
|
break;
|
||||||
case 4:
|
case 4:
|
||||||
case 5:
|
case 5:
|
||||||
case 7:
|
case 7:
|
||||||
found = prefix + filter;
|
found = prefix + selector;
|
||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
case 3:
|
case 3:
|
||||||
if ( fargs[2] === filter ) {
|
if ( fargs[2] === selector ) {
|
||||||
found = prefix + filter;
|
found = prefix + selector;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 6:
|
case 6:
|
||||||
case 8:
|
case 8:
|
||||||
case 9:
|
case 9:
|
||||||
|
if ( fargs[3] !== selector ) { break; }
|
||||||
if (
|
if (
|
||||||
fargs[2] === '' ||
|
fargs[2] === '' ||
|
||||||
reHostname.test(fargs[2]) === true ||
|
reHostname.test(fargs[2]) === true ||
|
||||||
reEntity !== undefined && reEntity.test(fargs[2]) === true
|
reEntity !== undefined && reEntity.test(fargs[2]) === true
|
||||||
) {
|
) {
|
||||||
found = fargs[2] + prefix + filter;
|
found = fargs[2] + prefix + selector;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user