PNG  IHDR;IDATxܻn0K )(pA 7LeG{ §㻢|ذaÆ 6lذaÆ 6lذaÆ 6lom$^yذag5bÆ 6lذaÆ 6lذa{ 6lذaÆ `}HFkm,mӪôô! x|'ܢ˟;E:9&ᶒ}{v]n&6 h_tڠ͵-ҫZ;Z$.Pkž)!o>}leQfJTu іچ\X=8Rن4`Vwl>nG^is"ms$ui?wbs[m6K4O.4%/bC%t Mז -lG6mrz2s%9s@-k9=)kB5\+͂Zsٲ Rn~GRC wIcIn7jJhۛNCS|j08yiHKֶۛkɈ+;SzL/F*\Ԕ#"5m2[S=gnaPeғL lذaÆ 6l^ḵaÆ 6lذaÆ 6lذa; _ذaÆ 6lذaÆ 6lذaÆ RIENDB` class OldSelector { constructor(selector, prefix) { this.prefix = prefix this.prefixed = selector.prefixed(this.prefix) this.regexp = selector.regexp(this.prefix) this.prefixeds = selector .possible() .map(x => [selector.prefixed(x), selector.regexp(x)]) this.unprefixed = selector.name this.nameRegexp = selector.regexp() } /** * Is rule a hack without unprefixed version bottom */ isHack(rule) { let index = rule.parent.index(rule) + 1 let rules = rule.parent.nodes while (index < rules.length) { let before = rules[index].selector if (!before) { return true } if (before.includes(this.unprefixed) && before.match(this.nameRegexp)) { return false } let some = false for (let [string, regexp] of this.prefixeds) { if (before.includes(string) && before.match(regexp)) { some = true break } } if (!some) { return true } index += 1 } return true } /** * Does rule contain an unnecessary prefixed selector */ check(rule) { if (!rule.selector.includes(this.prefixed)) { return false } if (!rule.selector.match(this.regexp)) { return false } if (this.isHack(rule)) { return false } return true } } module.exports = OldSelector