aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorgorhill <rhill@raymondhill.net>2015-09-04 16:30:53 -0400
committergorhill <rhill@raymondhill.net>2015-09-04 16:30:53 -0400
commitb3d243324fa773ff49f5f5725682128d4a454929 (patch)
tree65273a6cd86cc6af8bc9196a86b0eca4439f4a4b
parent9c884789841986e8788b9ea054bc63606fb389a4 (diff)
downloaduBlock-b3d243324fa773ff49f5f5725682128d4a454929.zip
uBlock-b3d243324fa773ff49f5f5725682128d4a454929.tar.gz
uBlock-b3d243324fa773ff49f5f5725682128d4a454929.tar.bz2
this fixes #672
-rw-r--r--src/js/contentscript-end.js50
1 files changed, 33 insertions, 17 deletions
diff --git a/src/js/contentscript-end.js b/src/js/contentscript-end.js
index bceb856..2996839 100644
--- a/src/js/contentscript-end.js
+++ b/src/js/contentscript-end.js
@@ -679,31 +679,47 @@ var uBlockCollapser = (function() {
// Extract all classes: these will be passed to the cosmetic filtering
// engine, and in return we will obtain only the relevant CSS selectors.
+ // https://github.com/gorhill/uBlock/issues/672
+ // http://www.w3.org/TR/2014/REC-html5-20141028/infrastructure.html#space-separated-tokens
+ // http://jsperf.com/enumerate-classes/6
+
var classesFromNodeList = function(nodes) {
if ( !nodes || !nodes.length ) {
return;
}
+
var qq = queriedSelectors;
var ll = lowGenericSelectors;
- var node, v, vv, j;
+ var v, vv, len, c, beg, end;
var i = nodes.length;
+
while ( i-- ) {
- node = nodes[i];
- // http://jsperf.com/enumerate-classes
- // Chromium: classList a bit faster than manually enumerating
- // class names.
- // Firefox: classList quite slower than manually enumerating
- // class names.
- vv = node.classList;
- if ( typeof vv !== 'object' ) { continue; }
- j = vv.length || 0;
- while ( j-- ) {
- v = vv[j];
- if ( typeof v !== 'string' ) { continue; }
- v = '.' + v;
- if ( qq.hasOwnProperty(v) ) { continue; }
- ll.push(v);
- qq[v] = true;
+ vv = nodes[i].className;
+ if ( typeof vv !== 'string' ) { continue; }
+ len = vv.length;
+ beg = 0;
+ for (;;) {
+ // Skip whitespaces
+ while ( beg !== len ) {
+ c = vv.charCodeAt(beg);
+ if ( c !== 0x20 && (c > 0x0D || c < 0x09) ) { break; }
+ beg++;
+ }
+ if ( beg === len ) { break; }
+ end = beg + 1;
+ // Skip non-whitespaces
+ while ( end !== len ) {
+ c = vv.charCodeAt(end);
+ if ( c === 0x20 || (c <= 0x0D && c >= 0x09) ) { break; }
+ end++;
+ }
+ v = '.' + vv.slice(beg, end);
+ if ( qq.hasOwnProperty(v) === false ) {
+ ll.push(v);
+ qq[v] = true;
+ }
+ if ( end === len ) { break; }
+ beg = end + 1;
}
}
};