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/cjs/syntax/create.cjs | |
| 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/cjs/syntax/create.cjs')
| -rw-r--r-- | vanilla/node_modules/css-tree/cjs/syntax/create.cjs | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/vanilla/node_modules/css-tree/cjs/syntax/create.cjs b/vanilla/node_modules/css-tree/cjs/syntax/create.cjs new file mode 100644 index 0000000..6ed51ea --- /dev/null +++ b/vanilla/node_modules/css-tree/cjs/syntax/create.cjs @@ -0,0 +1,58 @@ +'use strict'; + +const index = require('../tokenizer/index.cjs'); +const create = require('../parser/create.cjs'); +const create$2 = require('../generator/create.cjs'); +const create$3 = require('../convertor/create.cjs'); +const create$1 = require('../walker/create.cjs'); +const Lexer = require('../lexer/Lexer.cjs'); +const mix = require('./config/mix.cjs'); + +function createSyntax(config) { + const parse = create.createParser(config); + const walk = create$1.createWalker(config); + const generate = create$2.createGenerator(config); + const { fromPlainObject, toPlainObject } = create$3.createConvertor(walk); + + const syntax = { + lexer: null, + createLexer: config => new Lexer.Lexer(config, syntax, syntax.lexer.structure), + + tokenize: index.tokenize, + parse, + generate, + + walk, + find: walk.find, + findLast: walk.findLast, + findAll: walk.findAll, + + fromPlainObject, + toPlainObject, + + fork(extension) { + const base = mix({}, config); // copy of config + + return createSyntax( + typeof extension === 'function' + ? extension(base) // TODO: remove Object.assign as second parameter + : mix(base, extension) + ); + } + }; + + syntax.lexer = new Lexer.Lexer({ + generic: config.generic, + cssWideKeywords: config.cssWideKeywords, + units: config.units, + types: config.types, + atrules: config.atrules, + properties: config.properties, + node: config.node + }, syntax); + + return syntax; +} +const createSyntax$1 = config => createSyntax(mix({}, config)); + +module.exports = createSyntax$1; |
