80 lines
2.1 KiB
JavaScript
80 lines
2.1 KiB
JavaScript
var List = require('../../utils/list');
|
|
var TYPE = require('../../tokenizer').TYPE;
|
|
|
|
var WHITESPACE = TYPE.WhiteSpace;
|
|
var COMMENT = TYPE.Comment;
|
|
var SEMICOLON = TYPE.Semicolon;
|
|
var ATRULE = TYPE.Atrule;
|
|
var LEFTCURLYBRACKET = TYPE.LeftCurlyBracket;
|
|
var RIGHTCURLYBRACKET = TYPE.RightCurlyBracket;
|
|
|
|
function consumeRaw(startToken) {
|
|
return this.Raw(startToken, 0, 0, false, true);
|
|
}
|
|
function consumeRule() {
|
|
return this.tolerantParse(this.Rule, consumeRaw);
|
|
}
|
|
function consumeRawDeclaration(startToken) {
|
|
return this.Raw(startToken, 0, SEMICOLON, true, true);
|
|
}
|
|
function consumeDeclaration() {
|
|
var node = this.tolerantParse(this.Declaration, consumeRawDeclaration);
|
|
|
|
if (this.scanner.tokenType === SEMICOLON) {
|
|
this.scanner.next();
|
|
}
|
|
|
|
return node;
|
|
}
|
|
|
|
module.exports = {
|
|
name: 'Block',
|
|
structure: {
|
|
children: [['Atrule', 'Rule', 'Declaration']]
|
|
},
|
|
parse: function(isDeclaration) {
|
|
var consumer = isDeclaration ? consumeDeclaration : consumeRule;
|
|
|
|
var start = this.scanner.tokenStart;
|
|
var children = new List();
|
|
|
|
this.scanner.eat(LEFTCURLYBRACKET);
|
|
|
|
scan:
|
|
while (!this.scanner.eof) {
|
|
switch (this.scanner.tokenType) {
|
|
case RIGHTCURLYBRACKET:
|
|
break scan;
|
|
|
|
case WHITESPACE:
|
|
case COMMENT:
|
|
this.scanner.next();
|
|
break;
|
|
|
|
case ATRULE:
|
|
children.appendData(this.tolerantParse(this.Atrule, consumeRaw));
|
|
break;
|
|
|
|
default:
|
|
children.appendData(consumer.call(this));
|
|
}
|
|
}
|
|
|
|
if (!this.tolerant || !this.scanner.eof) {
|
|
this.scanner.eat(RIGHTCURLYBRACKET);
|
|
}
|
|
|
|
return {
|
|
type: 'Block',
|
|
loc: this.getLocation(start, this.scanner.tokenStart),
|
|
children: children
|
|
};
|
|
},
|
|
generate: function(processChunk, node) {
|
|
processChunk('{');
|
|
this.each(processChunk, node);
|
|
processChunk('}');
|
|
},
|
|
walkContext: 'block'
|
|
};
|