diff options
| author | Adam Mathes <adam@adammathes.com> | 2026-02-13 21:34:48 -0800 |
|---|---|---|
| committer | Adam Mathes <adam@adammathes.com> | 2026-02-13 21:34:48 -0800 |
| commit | 76cb9c2a39d477a64824a985ade40507e3bbade1 (patch) | |
| tree | 41e997aa9c6f538d3a136af61dae9424db2005a9 /vanilla/node_modules/css-tree/lib/lexer/trace.js | |
| parent | 819a39a21ac992b1393244a4c283bbb125208c69 (diff) | |
| download | neko-76cb9c2a39d477a64824a985ade40507e3bbade1.tar.gz neko-76cb9c2a39d477a64824a985ade40507e3bbade1.tar.bz2 neko-76cb9c2a39d477a64824a985ade40507e3bbade1.zip | |
feat(vanilla): add testing infrastructure and tests (NK-wjnczv)
Diffstat (limited to 'vanilla/node_modules/css-tree/lib/lexer/trace.js')
| -rw-r--r-- | vanilla/node_modules/css-tree/lib/lexer/trace.js | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/vanilla/node_modules/css-tree/lib/lexer/trace.js b/vanilla/node_modules/css-tree/lib/lexer/trace.js new file mode 100644 index 0000000..959813c --- /dev/null +++ b/vanilla/node_modules/css-tree/lib/lexer/trace.js @@ -0,0 +1,66 @@ +export function getTrace(node) { + function shouldPutToTrace(syntax) { + if (syntax === null) { + return false; + } + + return ( + syntax.type === 'Type' || + syntax.type === 'Property' || + syntax.type === 'Keyword' + ); + } + + function hasMatch(matchNode) { + if (Array.isArray(matchNode.match)) { + // use for-loop for better perfomance + for (let i = 0; i < matchNode.match.length; i++) { + if (hasMatch(matchNode.match[i])) { + if (shouldPutToTrace(matchNode.syntax)) { + result.unshift(matchNode.syntax); + } + + return true; + } + } + } else if (matchNode.node === node) { + result = shouldPutToTrace(matchNode.syntax) + ? [matchNode.syntax] + : []; + + return true; + } + + return false; + } + + let result = null; + + if (this.matched !== null) { + hasMatch(this.matched); + } + + return result; +} + +export function isType(node, type) { + return testNode(this, node, match => match.type === 'Type' && match.name === type); +} + +export function isProperty(node, property) { + return testNode(this, node, match => match.type === 'Property' && match.name === property); +} + +export function isKeyword(node) { + return testNode(this, node, match => match.type === 'Keyword'); +} + +function testNode(match, node, fn) { + const trace = getTrace.call(match, node); + + if (trace === null) { + return false; + } + + return trace.some(fn); +} |
