summaryrefslogtreecommitdiff
path: root/node_modules/autoprefixer/lib/old-selector.js
diff options
context:
space:
mode:
authorPhilipp Tanlak <philipp.tanlak@gmail.com>2025-11-24 20:54:57 +0100
committerPhilipp Tanlak <philipp.tanlak@gmail.com>2025-11-24 20:57:48 +0100
commitb1e2c8fd5cb5dfa46bc440a12eafaf56cd844b1c (patch)
tree49d360fd6cbc6a2754efe93524ac47ff0fbe0f7d /node_modules/autoprefixer/lib/old-selector.js
Docs
Diffstat (limited to 'node_modules/autoprefixer/lib/old-selector.js')
-rw-r--r--node_modules/autoprefixer/lib/old-selector.js67
1 files changed, 67 insertions, 0 deletions
diff --git a/node_modules/autoprefixer/lib/old-selector.js b/node_modules/autoprefixer/lib/old-selector.js
new file mode 100644
index 0000000..ca98d07
--- /dev/null
+++ b/node_modules/autoprefixer/lib/old-selector.js
@@ -0,0 +1,67 @@
+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()
+ }
+
+ /**
+ * 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
+ }
+
+ /**
+ * 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
+ }
+}
+
+module.exports = OldSelector