From fb38876194130c7518790c116886186fc1d0e37f Mon Sep 17 00:00:00 2001 From: Romain Menke <11521496+romainmenke@users.noreply.github.com> Date: Mon, 12 Aug 2024 12:41:08 +0200 Subject: [PATCH] fix: erroneous trailing combinators in pseudos --- src/__tests__/comments.mjs | 25 +++++++++++++++++++++++++ src/parser.js | 2 +- 2 files changed, 26 insertions(+), 1 deletion(-) diff --git a/src/__tests__/comments.mjs b/src/__tests__/comments.mjs index 4365458..1b1dffe 100644 --- a/src/__tests__/comments.mjs +++ b/src/__tests__/comments.mjs @@ -33,12 +33,37 @@ test('multiple comments and other things', 'h1/*test*/h2/*test*/.test/*test*/', }); test('ending in comment', ".bar /* comment 3 */", (t, tree) => { + t.is(tree.nodes[0].nodes.length, 1); let classname = tree.nodes[0].nodes[0]; t.deepEqual(classname.type, 'class', 'should have a tag'); t.deepEqual(classname.spaces.after, ' '); t.deepEqual(classname.raws.spaces.after, ' /* comment 3 */'); }); +test('ending in comment and whitespace', ".bar /* comment 3 */ ", (t, tree) => { + t.is(tree.nodes[0].nodes.length, 1); + let classname = tree.nodes[0].nodes[0]; + t.deepEqual(classname.type, 'class', 'should have a tag'); + t.deepEqual(classname.spaces.after, ' '); + t.deepEqual(classname.raws.spaces.after, ' /* comment 3 */ '); +}); + +test('ending in comment in a pseudo', ":is(.bar /* comment 3 */)", (t, tree) => { + t.is(tree.nodes[0].nodes[0].nodes[0].nodes.length, 1); + let classname = tree.nodes[0].nodes[0].nodes[0].nodes[0]; + t.deepEqual(classname.type, 'class', 'should have a tag'); + t.deepEqual(classname.spaces.after, ' '); + t.deepEqual(classname.raws.spaces.after, ' /* comment 3 */'); +}); + +test('ending in comment and whitespace in a pseudo', ":is(.bar /* comment 3 */ )", (t, tree) => { + t.is(tree.nodes[0].nodes[0].nodes[0].nodes.length, 1); + let classname = tree.nodes[0].nodes[0].nodes[0].nodes[0]; + t.deepEqual(classname.type, 'class', 'should have a tag'); + t.deepEqual(classname.spaces.after, ' '); + t.deepEqual(classname.raws.spaces.after, ' /* comment 3 */ '); +}); + test('comments in selector list', 'h2, /*test*/ h4', (t, tree) => { t.deepEqual(tree.nodes[0].nodes[0].type, 'tag'); t.deepEqual(tree.nodes[0].nodes[0].value, 'h2'); diff --git a/src/parser.js b/src/parser.js index 4815c6e..e50ea08 100644 --- a/src/parser.js +++ b/src/parser.js @@ -525,7 +525,7 @@ export default class Parser { // We need to decide between a space that's a descendant combinator and meaningless whitespace at the end of a selector. let nextSigTokenPos = this.locateNextMeaningfulToken(this.position); - if (nextSigTokenPos < 0 || this.tokens[nextSigTokenPos][TOKEN.TYPE] === tokens.comma) { + if (nextSigTokenPos < 0 || this.tokens[nextSigTokenPos][TOKEN.TYPE] === tokens.comma || this.tokens[nextSigTokenPos][TOKEN.TYPE] === tokens.closeParenthesis) { let nodes = this.parseWhitespaceEquivalentTokens(nextSigTokenPos); if (nodes.length > 0) { let last = this.current.last;