UNPKG

react-scripts

Version:
504 lines (417 loc) 49.5 kB
'use strict'; exports.__esModule = true; var _declaration = require('./declaration'); var _declaration2 = _interopRequireDefault(_declaration); var _tokenize = require('./tokenize'); var _tokenize2 = _interopRequireDefault(_tokenize); var _comment = require('./comment'); var _comment2 = _interopRequireDefault(_comment); var _atRule = require('./at-rule'); var _atRule2 = _interopRequireDefault(_atRule); var _root = require('./root'); var _root2 = _interopRequireDefault(_root); var _rule = require('./rule'); var _rule2 = _interopRequireDefault(_rule); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } var Parser = function () { function Parser(input) { _classCallCheck(this, Parser); this.input = input; this.pos = 0; this.root = new _root2.default(); this.current = this.root; this.spaces = ''; this.semicolon = false; this.root.source = { input: input, start: { line: 1, column: 1 } }; } Parser.prototype.tokenize = function tokenize() { this.tokens = (0, _tokenize2.default)(this.input); }; Parser.prototype.loop = function loop() { var token = void 0; while (this.pos < this.tokens.length) { token = this.tokens[this.pos]; switch (token[0]) { case 'word': case ':': this.word(); break; case '}': this.end(token); break; case 'comment': this.comment(token); break; case 'at-word': this.atrule(token); break; case '{': this.emptyRule(token); break; default: this.spaces += token[1]; break; } this.pos += 1; } this.endFile(); }; Parser.prototype.comment = function comment(token) { var node = new _comment2.default(); this.init(node, token[2], token[3]); node.source.end = { line: token[4], column: token[5] }; var text = token[1].slice(2, -2); if (/^\s*$/.test(text)) { node.text = ''; node.raws.left = text; node.raws.right = ''; } else { var match = text.match(/^(\s*)([^]*[^\s])(\s*)$/); node.text = match[2]; node.raws.left = match[1]; node.raws.right = match[3]; } }; Parser.prototype.emptyRule = function emptyRule(token) { var node = new _rule2.default(); this.init(node, token[2], token[3]); node.selector = ''; node.raws.between = ''; this.current = node; }; Parser.prototype.word = function word() { var token = void 0; var end = false; var type = null; var colon = false; var bracket = null; var brackets = 0; var start = this.pos; this.pos += 1; while (this.pos < this.tokens.length) { token = this.tokens[this.pos]; type = token[0]; if (type === '(') { if (!bracket) bracket = token; brackets += 1; } else if (brackets === 0) { if (type === ';') { if (colon) { this.decl(this.tokens.slice(start, this.pos + 1)); return; } else { break; } } else if (type === '{') { this.rule(this.tokens.slice(start, this.pos + 1)); return; } else if (type === '}') { this.pos -= 1; end = true; break; } else if (type === ':') { colon = true; } } else if (type === ')') { brackets -= 1; if (brackets === 0) bracket = null; } this.pos += 1; } if (this.pos === this.tokens.length) { this.pos -= 1; end = true; } if (brackets > 0) this.unclosedBracket(bracket); if (end && colon) { while (this.pos > start) { token = this.tokens[this.pos][0]; if (token !== 'space' && token !== 'comment') break; this.pos -= 1; } this.decl(this.tokens.slice(start, this.pos + 1)); return; } this.unknownWord(start); }; Parser.prototype.rule = function rule(tokens) { tokens.pop(); var node = new _rule2.default(); this.init(node, tokens[0][2], tokens[0][3]); node.raws.between = this.spacesFromEnd(tokens); this.raw(node, 'selector', tokens); this.current = node; }; Parser.prototype.decl = function decl(tokens) { var node = new _declaration2.default(); this.init(node); var last = tokens[tokens.length - 1]; if (last[0] === ';') { this.semicolon = true; tokens.pop(); } if (last[4]) { node.source.end = { line: last[4], column: last[5] }; } else { node.source.end = { line: last[2], column: last[3] }; } while (tokens[0][0] !== 'word') { node.raws.before += tokens.shift()[1]; } node.source.start = { line: tokens[0][2], column: tokens[0][3] }; node.prop = ''; while (tokens.length) { var type = tokens[0][0]; if (type === ':' || type === 'space' || type === 'comment') { break; } node.prop += tokens.shift()[1]; } node.raws.between = ''; var token = void 0; while (tokens.length) { token = tokens.shift(); if (token[0] === ':') { node.raws.between += token[1]; break; } else { node.raws.between += token[1]; } } if (node.prop[0] === '_' || node.prop[0] === '*') { node.raws.before += node.prop[0]; node.prop = node.prop.slice(1); } node.raws.between += this.spacesFromStart(tokens); this.precheckMissedSemicolon(tokens); for (var i = tokens.length - 1; i > 0; i--) { token = tokens[i]; if (token[1] === '!important') { node.important = true; var string = this.stringFrom(tokens, i); string = this.spacesFromEnd(tokens) + string; if (string !== ' !important') node.raws.important = string; break; } else if (token[1] === 'important') { var cache = tokens.slice(0); var str = ''; for (var j = i; j > 0; j--) { var _type = cache[j][0]; if (str.trim().indexOf('!') === 0 && _type !== 'space') { break; } str = cache.pop()[1] + str; } if (str.trim().indexOf('!') === 0) { node.important = true; node.raws.important = str; tokens = cache; } } if (token[0] !== 'space' && token[0] !== 'comment') { break; } } this.raw(node, 'value', tokens); if (node.value.indexOf(':') !== -1) this.checkMissedSemicolon(tokens); }; Parser.prototype.atrule = function atrule(token) { var node = new _atRule2.default(); node.name = token[1].slice(1); if (node.name === '') { this.unnamedAtrule(node, token); } this.init(node, token[2], token[3]); var last = false; var open = false; var params = []; this.pos += 1; while (this.pos < this.tokens.length) { token = this.tokens[this.pos]; if (token[0] === ';') { node.source.end = { line: token[2], column: token[3] }; this.semicolon = true; break; } else if (token[0] === '{') { open = true; break; } else if (token[0] === '}') { this.end(token); break; } else { params.push(token); } this.pos += 1; } if (this.pos === this.tokens.length) { last = true; } node.raws.between = this.spacesFromEnd(params); if (params.length) { node.raws.afterName = this.spacesFromStart(params); this.raw(node, 'params', params); if (last) { token = params[params.length - 1]; node.source.end = { line: token[4], column: token[5] }; this.spaces = node.raws.between; node.raws.between = ''; } } else { node.raws.afterName = ''; node.params = ''; } if (open) { node.nodes = []; this.current = node; } }; Parser.prototype.end = function end(token) { if (this.current.nodes && this.current.nodes.length) { this.current.raws.semicolon = this.semicolon; } this.semicolon = false; this.current.raws.after = (this.current.raws.after || '') + this.spaces; this.spaces = ''; if (this.current.parent) { this.current.source.end = { line: token[2], column: token[3] }; this.current = this.current.parent; } else { this.unexpectedClose(token); } }; Parser.prototype.endFile = function endFile() { if (this.current.parent) this.unclosedBlock(); if (this.current.nodes && this.current.nodes.length) { this.current.raws.semicolon = this.semicolon; } this.current.raws.after = (this.current.raws.after || '') + this.spaces; }; // Helpers Parser.prototype.init = function init(node, line, column) { this.current.push(node); node.source = { start: { line: line, column: column }, input: this.input }; node.raws.before = this.spaces; this.spaces = ''; if (node.type !== 'comment') this.semicolon = false; }; Parser.prototype.raw = function raw(node, prop, tokens) { var token = void 0, type = void 0; var length = tokens.length; var value = ''; var clean = true; for (var i = 0; i < length; i += 1) { token = tokens[i]; type = token[0]; if (type === 'comment' || type === 'space' && i === length - 1) { clean = false; } else { value += token[1]; } } if (!clean) { var raw = tokens.reduce(function (all, i) { return all + i[1]; }, ''); node.raws[prop] = { value: value, raw: raw }; } node[prop] = value; }; Parser.prototype.spacesFromEnd = function spacesFromEnd(tokens) { var lastTokenType = void 0; var spaces = ''; while (tokens.length) { lastTokenType = tokens[tokens.length - 1][0]; if (lastTokenType !== 'space' && lastTokenType !== 'comment') break; spaces = tokens.pop()[1] + spaces; } return spaces; }; Parser.prototype.spacesFromStart = function spacesFromStart(tokens) { var next = void 0; var spaces = ''; while (tokens.length) { next = tokens[0][0]; if (next !== 'space' && next !== 'comment') break; spaces += tokens.shift()[1]; } return spaces; }; Parser.prototype.stringFrom = function stringFrom(tokens, from) { var result = ''; for (var i = from; i < tokens.length; i++) { result += tokens[i][1]; } tokens.splice(from, tokens.length - from); return result; }; Parser.prototype.colon = function colon(tokens) { var brackets = 0; var token = void 0, type = void 0, prev = void 0; for (var i = 0; i < tokens.length; i++) { token = tokens[i]; type = token[0]; if (type === '(') { brackets += 1; } else if (type === ')') { brackets -= 1; } else if (brackets === 0 && type === ':') { if (!prev) { this.doubleColon(token); } else if (prev[0] === 'word' && prev[1] === 'progid') { continue; } else { return i; } } prev = token; } return false; }; // Errors Parser.prototype.unclosedBracket = function unclosedBracket(bracket) { throw this.input.error('Unclosed bracket', bracket[2], bracket[3]); }; Parser.prototype.unknownWord = function unknownWord(start) { var token = this.tokens[start]; throw this.input.error('Unknown word', token[2], token[3]); }; Parser.prototype.unexpectedClose = function unexpectedClose(token) { throw this.input.error('Unexpected }', token[2], token[3]); }; Parser.prototype.unclosedBlock = function unclosedBlock() { var pos = this.current.source.start; throw this.input.error('Unclosed block', pos.line, pos.column); }; Parser.prototype.doubleColon = function doubleColon(token) { throw this.input.error('Double colon', token[2], token[3]); }; Parser.prototype.unnamedAtrule = function unnamedAtrule(node, token) { throw this.input.error('At-rule without name', token[2], token[3]); }; Parser.prototype.precheckMissedSemicolon = function precheckMissedSemicolon(tokens) { // Hook for Safe Parser tokens; }; Parser.prototype.checkMissedSemicolon = function checkMissedSemicolon(tokens) { var colon = this.colon(tokens); if (colon === false) return; var founded = 0; var token = void 0; for (var j = colon - 1; j >= 0; j--) { token = tokens[j]; if (token[0] !== 'space') { founded += 1; if (founded === 2) break; } } throw this.input.error('Missed semicolon', token[2], token[3]); }; return Parser; }(); exports.default = Parser; module.exports = exports['default']; //# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["parser.es6"],"names":[],"mappings":";;;;AAAA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;AACA;;;;;;;;IAEqB,M;AAEjB,oBAAY,KAAZ,EAAmB;AAAA;;AACf,aAAK,KAAL,GAAa,KAAb;;AAEA,aAAK,GAAL,GAAiB,CAAjB;AACA,aAAK,IAAL,GAAiB,oBAAjB;AACA,aAAK,OAAL,GAAiB,KAAK,IAAtB;AACA,aAAK,MAAL,GAAiB,EAAjB;AACA,aAAK,SAAL,GAAiB,KAAjB;;AAEA,aAAK,IAAL,CAAU,MAAV,GAAmB,EAAE,YAAF,EAAS,OAAO,EAAE,MAAM,CAAR,EAAW,QAAQ,CAAnB,EAAhB,EAAnB;AACH;;qBAED,Q,uBAAW;AACP,aAAK,MAAL,GAAc,wBAAU,KAAK,KAAf,CAAd;AACH,K;;qBAED,I,mBAAO;AACH,YAAI,cAAJ;AACA,eAAQ,KAAK,GAAL,GAAW,KAAK,MAAL,CAAY,MAA/B,EAAwC;AACpC,oBAAQ,KAAK,MAAL,CAAY,KAAK,GAAjB,CAAR;;AAEA,oBAAS,MAAM,CAAN,CAAT;AACA,qBAAK,MAAL;AACA,qBAAK,GAAL;AACI,yBAAK,IAAL;AACA;;AAEJ,qBAAK,GAAL;AACI,yBAAK,GAAL,CAAS,KAAT;AACA;;AAEJ,qBAAK,SAAL;AACI,yBAAK,OAAL,CAAa,KAAb;AACA;;AAEJ,qBAAK,SAAL;AACI,yBAAK,MAAL,CAAY,KAAZ;AACA;;AAEJ,qBAAK,GAAL;AACI,yBAAK,SAAL,CAAe,KAAf;AACA;;AAEJ;AACI,yBAAK,MAAL,IAAe,MAAM,CAAN,CAAf;AACA;AAxBJ;;AA2BA,iBAAK,GAAL,IAAY,CAAZ;AACH;AACD,aAAK,OAAL;AACH,K;;qBAED,O,oBAAQ,K,EAAO;AACX,YAAI,OAAO,uBAAX;AACA,aAAK,IAAL,CAAU,IAAV,EAAgB,MAAM,CAAN,CAAhB,EAA0B,MAAM,CAAN,CAA1B;AACA,aAAK,MAAL,CAAY,GAAZ,GAAkB,EAAE,MAAM,MAAM,CAAN,CAAR,EAAkB,QAAQ,MAAM,CAAN,CAA1B,EAAlB;;AAEA,YAAI,OAAO,MAAM,CAAN,EAAS,KAAT,CAAe,CAAf,EAAkB,CAAC,CAAnB,CAAX;AACA,YAAK,QAAQ,IAAR,CAAa,IAAb,CAAL,EAA0B;AACtB,iBAAK,IAAL,GAAkB,EAAlB;AACA,iBAAK,IAAL,CAAU,IAAV,GAAkB,IAAlB;AACA,iBAAK,IAAL,CAAU,KAAV,GAAkB,EAAlB;AACH,SAJD,MAIO;AACH,gBAAI,QAAQ,KAAK,KAAL,CAAW,yBAAX,CAAZ;AACA,iBAAK,IAAL,GAAkB,MAAM,CAAN,CAAlB;AACA,iBAAK,IAAL,CAAU,IAAV,GAAkB,MAAM,CAAN,CAAlB;AACA,iBAAK,IAAL,CAAU,KAAV,GAAkB,MAAM,CAAN,CAAlB;AACH;AACJ,K;;qBAED,S,sBAAU,K,EAAO;AACb,YAAI,OAAO,oBAAX;AACA,aAAK,IAAL,CAAU,IAAV,EAAgB,MAAM,CAAN,CAAhB,EAA0B,MAAM,CAAN,CAA1B;AACA,aAAK,QAAL,GAAgB,EAAhB;AACA,aAAK,IAAL,CAAU,OAAV,GAAoB,EAApB;AACA,aAAK,OAAL,GAAe,IAAf;AACH,K;;qBAED,I,mBAAO;AACH,YAAI,cAAJ;AACA,YAAI,MAAW,KAAf;AACA,YAAI,OAAW,IAAf;AACA,YAAI,QAAW,KAAf;AACA,YAAI,UAAW,IAAf;AACA,YAAI,WAAW,CAAf;;AAEA,YAAI,QAAQ,KAAK,GAAjB;AACA,aAAK,GAAL,IAAY,CAAZ;AACA,eAAQ,KAAK,GAAL,GAAW,KAAK,MAAL,CAAY,MAA/B,EAAwC;AACpC,oBAAQ,KAAK,MAAL,CAAY,KAAK,GAAjB,CAAR;AACA,mBAAQ,MAAM,CAAN,CAAR;;AAEA,gBAAK,SAAS,GAAd,EAAoB;AAChB,oBAAK,CAAC,OAAN,EAAgB,UAAU,KAAV;AAChB,4BAAY,CAAZ;AAEH,aAJD,MAIO,IAAK,aAAa,CAAlB,EAAsB;AACzB,oBAAK,SAAS,GAAd,EAAoB;AAChB,wBAAK,KAAL,EAAa;AACT,6BAAK,IAAL,CAAU,KAAK,MAAL,CAAY,KAAZ,CAAkB,KAAlB,EAAyB,KAAK,GAAL,GAAW,CAApC,CAAV;AACA;AACH,qBAHD,MAGO;AACH;AACH;AAEJ,iBARD,MAQO,IAAK,SAAS,GAAd,EAAoB;AACvB,yBAAK,IAAL,CAAU,KAAK,MAAL,CAAY,KAAZ,CAAkB,KAAlB,EAAyB,KAAK,GAAL,GAAW,CAApC,CAAV;AACA;AAEH,iBAJM,MAIA,IAAK,SAAS,GAAd,EAAoB;AACvB,yBAAK,GAAL,IAAY,CAAZ;AACA,0BAAM,IAAN;AACA;AAEH,iBALM,MAKA,IAAK,SAAS,GAAd,EAAoB;AACvB,4BAAQ,IAAR;AACH;AAEJ,aAtBM,MAsBA,IAAK,SAAS,GAAd,EAAoB;AACvB,4BAAY,CAAZ;AACA,oBAAK,aAAa,CAAlB,EAAsB,UAAU,IAAV;AACzB;;AAED,iBAAK,GAAL,IAAY,CAAZ;AACH;AACD,YAAK,KAAK,GAAL,KAAa,KAAK,MAAL,CAAY,MAA9B,EAAuC;AACnC,iBAAK,GAAL,IAAY,CAAZ;AACA,kBAAM,IAAN;AACH;;AAED,YAAK,WAAW,CAAhB,EAAoB,KAAK,eAAL,CAAqB,OAArB;;AAEpB,YAAK,OAAO,KAAZ,EAAoB;AAChB,mBAAQ,KAAK,GAAL,GAAW,KAAnB,EAA2B;AACvB,wBAAQ,KAAK,MAAL,CAAY,KAAK,GAAjB,EAAsB,CAAtB,CAAR;AACA,oBAAK,UAAU,OAAV,IAAqB,UAAU,SAApC,EAAgD;AAChD,qBAAK,GAAL,IAAY,CAAZ;AACH;AACD,iBAAK,IAAL,CAAU,KAAK,MAAL,CAAY,KAAZ,CAAkB,KAAlB,EAAyB,KAAK,GAAL,GAAW,CAApC,CAAV;AACA;AACH;;AAED,aAAK,WAAL,CAAiB,KAAjB;AACH,K;;qBAED,I,iBAAK,M,EAAQ;AACT,eAAO,GAAP;;AAEA,YAAI,OAAO,oBAAX;AACA,aAAK,IAAL,CAAU,IAAV,EAAgB,OAAO,CAAP,EAAU,CAAV,CAAhB,EAA8B,OAAO,CAAP,EAAU,CAAV,CAA9B;;AAEA,aAAK,IAAL,CAAU,OAAV,GAAoB,KAAK,aAAL,CAAmB,MAAnB,CAApB;AACA,aAAK,GAAL,CAAS,IAAT,EAAe,UAAf,EAA2B,MAA3B;AACA,aAAK,OAAL,GAAe,IAAf;AACH,K;;qBAED,I,iBAAK,M,EAAQ;AACT,YAAI,OAAO,2BAAX;AACA,aAAK,IAAL,CAAU,IAAV;;AAEA,YAAI,OAAO,OAAO,OAAO,MAAP,GAAgB,CAAvB,CAAX;AACA,YAAK,KAAK,CAAL,MAAY,GAAjB,EAAuB;AACnB,iBAAK,SAAL,GAAiB,IAAjB;AACA,mBAAO,GAAP;AACH;AACD,YAAK,KAAK,CAAL,CAAL,EAAe;AACX,iBAAK,MAAL,CAAY,GAAZ,GAAkB,EAAE,MAAM,KAAK,CAAL,CAAR,EAAiB,QAAQ,KAAK,CAAL,CAAzB,EAAlB;AACH,SAFD,MAEO;AACH,iBAAK,MAAL,CAAY,GAAZ,GAAkB,EAAE,MAAM,KAAK,CAAL,CAAR,EAAiB,QAAQ,KAAK,CAAL,CAAzB,EAAlB;AACH;;AAED,eAAQ,OAAO,CAAP,EAAU,CAAV,MAAiB,MAAzB,EAAkC;AAC9B,iBAAK,IAAL,CAAU,MAAV,IAAoB,OAAO,KAAP,GAAe,CAAf,CAApB;AACH;AACD,aAAK,MAAL,CAAY,KAAZ,GAAoB,EAAE,MAAM,OAAO,CAAP,EAAU,CAAV,CAAR,EAAsB,QAAQ,OAAO,CAAP,EAAU,CAAV,CAA9B,EAApB;;AAEA,aAAK,IAAL,GAAY,EAAZ;AACA,eAAQ,OAAO,MAAf,EAAwB;AACpB,gBAAI,OAAO,OAAO,CAAP,EAAU,CAAV,CAAX;AACA,gBAAK,SAAS,GAAT,IAAgB,SAAS,OAAzB,IAAoC,SAAS,SAAlD,EAA8D;AAC1D;AACH;AACD,iBAAK,IAAL,IAAa,OAAO,KAAP,GAAe,CAAf,CAAb;AACH;;AAED,aAAK,IAAL,CAAU,OAAV,GAAoB,EAApB;;AAEA,YAAI,cAAJ;AACA,eAAQ,OAAO,MAAf,EAAwB;AACpB,oBAAQ,OAAO,KAAP,EAAR;;AAEA,gBAAK,MAAM,CAAN,MAAa,GAAlB,EAAwB;AACpB,qBAAK,IAAL,CAAU,OAAV,IAAqB,MAAM,CAAN,CAArB;AACA;AACH,aAHD,MAGO;AACH,qBAAK,IAAL,CAAU,OAAV,IAAqB,MAAM,CAAN,CAArB;AACH;AACJ;;AAED,YAAK,KAAK,IAAL,CAAU,CAAV,MAAiB,GAAjB,IAAwB,KAAK,IAAL,CAAU,CAAV,MAAiB,GAA9C,EAAoD;AAChD,iBAAK,IAAL,CAAU,MAAV,IAAoB,KAAK,IAAL,CAAU,CAAV,CAApB;AACA,iBAAK,IAAL,GAAY,KAAK,IAAL,CAAU,KAAV,CAAgB,CAAhB,CAAZ;AACH;AACD,aAAK,IAAL,CAAU,OAAV,IAAqB,KAAK,eAAL,CAAqB,MAArB,CAArB;AACA,aAAK,uBAAL,CAA6B,MAA7B;;AAEA,aAAM,IAAI,IAAI,OAAO,MAAP,GAAgB,CAA9B,EAAiC,IAAI,CAArC,EAAwC,GAAxC,EAA8C;AAC1C,oBAAQ,OAAO,CAAP,CAAR;AACA,gBAAK,MAAM,CAAN,MAAa,YAAlB,EAAiC;AAC7B,qBAAK,SAAL,GAAiB,IAAjB;AACA,oBAAI,SAAS,KAAK,UAAL,CAAgB,MAAhB,EAAwB,CAAxB,CAAb;AACA,yBAAS,KAAK,aAAL,CAAmB,MAAnB,IAA6B,MAAtC;AACA,oBAAK,WAAW,aAAhB,EAAgC,KAAK,IAAL,CAAU,SAAV,GAAsB,MAAtB;AAChC;AAEH,aAPD,MAOO,IAAI,MAAM,CAAN,MAAa,WAAjB,EAA8B;AACjC,oBAAI,QAAQ,OAAO,KAAP,CAAa,CAAb,CAAZ;AACA,oBAAI,MAAQ,EAAZ;AACA,qBAAM,IAAI,IAAI,CAAd,EAAiB,IAAI,CAArB,EAAwB,GAAxB,EAA8B;AAC1B,wBAAI,QAAO,MAAM,CAAN,EAAS,CAAT,CAAX;AACA,wBAAK,IAAI,IAAJ,GAAW,OAAX,CAAmB,GAAnB,MAA4B,CAA5B,IAAiC,UAAS,OAA/C,EAAyD;AACrD;AACH;AACD,0BAAM,MAAM,GAAN,GAAY,CAAZ,IAAiB,GAAvB;AACH;AACD,oBAAK,IAAI,IAAJ,GAAW,OAAX,CAAmB,GAAnB,MAA4B,CAAjC,EAAqC;AACjC,yBAAK,SAAL,GAAiB,IAAjB;AACA,yBAAK,IAAL,CAAU,SAAV,GAAsB,GAAtB;AACA,6BAAS,KAAT;AACH;AACJ;;AAED,gBAAK,MAAM,CAAN,MAAa,OAAb,IAAwB,MAAM,CAAN,MAAa,SAA1C,EAAsD;AAClD;AACH;AACJ;;AAED,aAAK,GAAL,CAAS,IAAT,EAAe,OAAf,EAAwB,MAAxB;;AAEA,YAAK,KAAK,KAAL,CAAW,OAAX,CAAmB,GAAnB,MAA4B,CAAC,CAAlC,EAAsC,KAAK,oBAAL,CAA0B,MAA1B;AACzC,K;;qBAED,M,mBAAO,K,EAAO;AACV,YAAI,OAAQ,sBAAZ;AACA,aAAK,IAAL,GAAY,MAAM,CAAN,EAAS,KAAT,CAAe,CAAf,CAAZ;AACA,YAAK,KAAK,IAAL,KAAc,EAAnB,EAAwB;AACpB,iBAAK,aAAL,CAAmB,IAAnB,EAAyB,KAAzB;AACH;AACD,aAAK,IAAL,CAAU,IAAV,EAAgB,MAAM,CAAN,CAAhB,EAA0B,MAAM,CAAN,CAA1B;;AAEA,YAAI,OAAS,KAAb;AACA,YAAI,OAAS,KAAb;AACA,YAAI,SAAS,EAAb;;AAEA,aAAK,GAAL,IAAY,CAAZ;AACA,eAAQ,KAAK,GAAL,GAAW,KAAK,MAAL,CAAY,MAA/B,EAAwC;AACpC,oBAAQ,KAAK,MAAL,CAAY,KAAK,GAAjB,CAAR;;AAEA,gBAAK,MAAM,CAAN,MAAa,GAAlB,EAAwB;AACpB,qBAAK,MAAL,CAAY,GAAZ,GAAkB,EAAE,MAAM,MAAM,CAAN,CAAR,EAAkB,QAAQ,MAAM,CAAN,CAA1B,EAAlB;AACA,qBAAK,SAAL,GAAiB,IAAjB;AACA;AACH,aAJD,MAIO,IAAK,MAAM,CAAN,MAAa,GAAlB,EAAwB;AAC3B,uBAAO,IAAP;AACA;AACH,aAHM,MAGA,IAAK,MAAM,CAAN,MAAa,GAAlB,EAAuB;AAC1B,qBAAK,GAAL,CAAS,KAAT;AACA;AACH,aAHM,MAGA;AACH,uBAAO,IAAP,CAAY,KAAZ;AACH;;AAED,iBAAK,GAAL,IAAY,CAAZ;AACH;AACD,YAAK,KAAK,GAAL,KAAa,KAAK,MAAL,CAAY,MAA9B,EAAuC;AACnC,mBAAO,IAAP;AACH;;AAED,aAAK,IAAL,CAAU,OAAV,GAAoB,KAAK,aAAL,CAAmB,MAAnB,CAApB;AACA,YAAK,OAAO,MAAZ,EAAqB;AACjB,iBAAK,IAAL,CAAU,SAAV,GAAsB,KAAK,eAAL,CAAqB,MAArB,CAAtB;AACA,iBAAK,GAAL,CAAS,IAAT,EAAe,QAAf,EAAyB,MAAzB;AACA,gBAAK,IAAL,EAAY;AACR,wBAAQ,OAAO,OAAO,MAAP,GAAgB,CAAvB,CAAR;AACA,qBAAK,MAAL,CAAY,GAAZ,GAAoB,EAAE,MAAM,MAAM,CAAN,CAAR,EAAkB,QAAQ,MAAM,CAAN,CAA1B,EAApB;AACA,qBAAK,MAAL,GAAoB,KAAK,IAAL,CAAU,OAA9B;AACA,qBAAK,IAAL,CAAU,OAAV,GAAoB,EAApB;AACH;AACJ,SATD,MASO;AACH,iBAAK,IAAL,CAAU,SAAV,GAAsB,EAAtB;AACA,iBAAK,MAAL,GAAsB,EAAtB;AACH;;AAED,YAAK,IAAL,EAAY;AACR,iBAAK,KAAL,GAAe,EAAf;AACA,iBAAK,OAAL,GAAe,IAAf;AACH;AACJ,K;;qBAED,G,gBAAI,K,EAAO;AACP,YAAK,KAAK,OAAL,CAAa,KAAb,IAAsB,KAAK,OAAL,CAAa,KAAb,CAAmB,MAA9C,EAAuD;AACnD,iBAAK,OAAL,CAAa,IAAb,CAAkB,SAAlB,GAA8B,KAAK,SAAnC;AACH;AACD,aAAK,SAAL,GAAiB,KAAjB;;AAEA,aAAK,OAAL,CAAa,IAAb,CAAkB,KAAlB,GAA0B,CAAC,KAAK,OAAL,CAAa,IAAb,CAAkB,KAAlB,IAA2B,EAA5B,IAAkC,KAAK,MAAjE;AACA,aAAK,MAAL,GAAc,EAAd;;AAEA,YAAK,KAAK,OAAL,CAAa,MAAlB,EAA2B;AACvB,iBAAK,OAAL,CAAa,MAAb,CAAoB,GAApB,GAA0B,EAAE,MAAM,MAAM,CAAN,CAAR,EAAkB,QAAQ,MAAM,CAAN,CAA1B,EAA1B;AACA,iBAAK,OAAL,GAAe,KAAK,OAAL,CAAa,MAA5B;AACH,SAHD,MAGO;AACH,iBAAK,eAAL,CAAqB,KAArB;AACH;AACJ,K;;qBAED,O,sBAAU;AACN,YAAK,KAAK,OAAL,CAAa,MAAlB,EAA2B,KAAK,aAAL;AAC3B,YAAK,KAAK,OAAL,CAAa,KAAb,IAAsB,KAAK,OAAL,CAAa,KAAb,CAAmB,MAA9C,EAAuD;AACnD,iBAAK,OAAL,CAAa,IAAb,CAAkB,SAAlB,GAA8B,KAAK,SAAnC;AACH;AACD,aAAK,OAAL,CAAa,IAAb,CAAkB,KAAlB,GAA0B,CAAC,KAAK,OAAL,CAAa,IAAb,CAAkB,KAAlB,IAA2B,EAA5B,IAAkC,KAAK,MAAjE;AACH,K;;AAED;;qBAEA,I,iBAAK,I,EAAM,I,EAAM,M,EAAQ;AACrB,aAAK,OAAL,CAAa,IAAb,CAAkB,IAAlB;;AAEA,aAAK,MAAL,GAAc,EAAE,OAAO,EAAE,UAAF,EAAQ,cAAR,EAAT,EAA2B,OAAO,KAAK,KAAvC,EAAd;AACA,aAAK,IAAL,CAAU,MAAV,GAAmB,KAAK,MAAxB;AACA,aAAK,MAAL,GAAc,EAAd;AACA,YAAK,KAAK,IAAL,KAAc,SAAnB,EAA+B,KAAK,SAAL,GAAiB,KAAjB;AAClC,K;;qBAED,G,gBAAI,I,EAAM,I,EAAM,M,EAAQ;AACpB,YAAI,cAAJ;AAAA,YAAW,aAAX;AACA,YAAI,SAAS,OAAO,MAApB;AACA,YAAI,QAAS,EAAb;AACA,YAAI,QAAS,IAAb;AACA,aAAM,IAAI,IAAI,CAAd,EAAiB,IAAI,MAArB,EAA6B,KAAK,CAAlC,EAAsC;AAClC,oBAAQ,OAAO,CAAP,CAAR;AACA,mBAAQ,MAAM,CAAN,CAAR;AACA,gBAAK,SAAS,SAAT,IAAsB,SAAS,OAAT,IAAoB,MAAM,SAAS,CAA9D,EAAkE;AAC9D,wBAAQ,KAAR;AACH,aAFD,MAEO;AACH,yBAAS,MAAM,CAAN,CAAT;AACH;AACJ;AACD,YAAK,CAAC,KAAN,EAAc;AACV,gBAAI,MAAM,OAAO,MAAP,CAAe,UAAC,GAAD,EAAM,CAAN;AAAA,uBAAY,MAAM,EAAE,CAAF,CAAlB;AAAA,aAAf,EAAuC,EAAvC,CAAV;AACA,iBAAK,IAAL,CAAU,IAAV,IAAkB,EAAE,YAAF,EAAS,QAAT,EAAlB;AACH;AACD,aAAK,IAAL,IAAa,KAAb;AACH,K;;qBAED,a,0BAAc,M,EAAQ;AAClB,YAAI,sBAAJ;AACA,YAAI,SAAS,EAAb;AACA,eAAQ,OAAO,MAAf,EAAwB;AACpB,4BAAgB,OAAO,OAAO,MAAP,GAAgB,CAAvB,EAA0B,CAA1B,CAAhB;AACA,gBAAK,kBAAkB,OAAlB,IACD,kBAAkB,SADtB,EACkC;AAClC,qBAAS,OAAO,GAAP,GAAa,CAAb,IAAkB,MAA3B;AACH;AACD,eAAO,MAAP;AACH,K;;qBAED,e,4BAAgB,M,EAAQ;AACpB,YAAI,aAAJ;AACA,YAAI,SAAS,EAAb;AACA,eAAQ,OAAO,MAAf,EAAwB;AACpB,mBAAO,OAAO,CAAP,EAAU,CAAV,CAAP;AACA,gBAAK,SAAS,OAAT,IAAoB,SAAS,SAAlC,EAA8C;AAC9C,sBAAU,OAAO,KAAP,GAAe,CAAf,CAAV;AACH;AACD,eAAO,MAAP;AACH,K;;qBAED,U,uBAAW,M,EAAQ,I,EAAM;AACrB,YAAI,SAAS,EAAb;AACA,aAAM,IAAI,IAAI,IAAd,EAAoB,IAAI,OAAO,MAA/B,EAAuC,GAAvC,EAA6C;AACzC,sBAAU,OAAO,CAAP,EAAU,CAAV,CAAV;AACH;AACD,eAAO,MAAP,CAAc,IAAd,EAAoB,OAAO,MAAP,GAAgB,IAApC;AACA,eAAO,MAAP;AACH,K;;qBAED,K,kBAAM,M,EAAQ;AACV,YAAI,WAAW,CAAf;AACA,YAAI,cAAJ;AAAA,YAAW,aAAX;AAAA,YAAiB,aAAjB;AACA,aAAM,IAAI,IAAI,CAAd,EAAiB,IAAI,OAAO,MAA5B,EAAoC,GAApC,EAA0C;AACtC,oBAAQ,OAAO,CAAP,CAAR;AACA,mBAAQ,MAAM,CAAN,CAAR;;AAEA,gBAAK,SAAS,GAAd,EAAoB;AAChB,4BAAY,CAAZ;AACH,aAFD,MAEO,IAAK,SAAS,GAAd,EAAoB;AACvB,4BAAY,CAAZ;AACH,aAFM,MAEA,IAAK,aAAa,CAAb,IAAkB,SAAS,GAAhC,EAAsC;AACzC,oBAAK,CAAC,IAAN,EAAa;AACT,yBAAK,WAAL,CAAiB,KAAjB;AACH,iBAFD,MAEO,IAAK,KAAK,CAAL,MAAY,MAAZ,IAAsB,KAAK,CAAL,MAAY,QAAvC,EAAkD;AACrD;AACH,iBAFM,MAEA;AACH,2BAAO,CAAP;AACH;AACJ;;AAED,mBAAO,KAAP;AACH;AACD,eAAO,KAAP;AACH,K;;AAED;;qBAEA,e,4BAAgB,O,EAAS;AACrB,cAAM,KAAK,KAAL,CAAW,KAAX,CAAiB,kBAAjB,EAAqC,QAAQ,CAAR,CAArC,EAAiD,QAAQ,CAAR,CAAjD,CAAN;AACH,K;;qBAED,W,wBAAY,K,EAAO;AACf,YAAI,QAAQ,KAAK,MAAL,CAAY,KAAZ,CAAZ;AACA,cAAM,KAAK,KAAL,CAAW,KAAX,CAAiB,cAAjB,EAAiC,MAAM,CAAN,CAAjC,EAA2C,MAAM,CAAN,CAA3C,CAAN;AACH,K;;qBAED,e,4BAAgB,K,EAAO;AACnB,cAAM,KAAK,KAAL,CAAW,KAAX,CAAiB,cAAjB,EAAiC,MAAM,CAAN,CAAjC,EAA2C,MAAM,CAAN,CAA3C,CAAN;AACH,K;;qBAED,a,4BAAgB;AACZ,YAAI,MAAM,KAAK,OAAL,CAAa,MAAb,CAAoB,KAA9B;AACA,cAAM,KAAK,KAAL,CAAW,KAAX,CAAiB,gBAAjB,EAAmC,IAAI,IAAvC,EAA6C,IAAI,MAAjD,CAAN;AACH,K;;qBAED,W,wBAAY,K,EAAO;AACf,cAAM,KAAK,KAAL,CAAW,KAAX,CAAiB,cAAjB,EAAiC,MAAM,CAAN,CAAjC,EAA2C,MAAM,CAAN,CAA3C,CAAN;AACH,K;;qBAED,a,0BAAc,I,EAAM,K,EAAO;AACvB,cAAM,KAAK,KAAL,CAAW,KAAX,CAAiB,sBAAjB,EAAyC,MAAM,CAAN,CAAzC,EAAmD,MAAM,CAAN,CAAnD,CAAN;AACH,K;;qBAED,uB,oCAAwB,M,EAAQ;AAC5B;AACA;AACH,K;;qBAED,oB,iCAAqB,M,EAAQ;AACzB,YAAI,QAAQ,KAAK,KAAL,CAAW,MAAX,CAAZ;AACA,YAAK,UAAU,KAAf,EAAuB;;AAEvB,YAAI,UAAU,CAAd;AACA,YAAI,cAAJ;AACA,aAAM,IAAI,IAAI,QAAQ,CAAtB,EAAyB,KAAK,CAA9B,EAAiC,GAAjC,EAAuC;AACnC,oBAAQ,OAAO,CAAP,CAAR;AACA,gBAAK,MAAM,CAAN,MAAa,OAAlB,EAA4B;AACxB,2BAAW,CAAX;AACA,oBAAK,YAAY,CAAjB,EAAqB;AACxB;AACJ;AACD,cAAM,KAAK,KAAL,CAAW,KAAX,CAAiB,kBAAjB,EAAqC,MAAM,CAAN,CAArC,EAA+C,MAAM,CAAN,CAA/C,CAAN;AACH,K;;;;;kBAhdgB,M","file":"parser.js","sourcesContent":["import Declaration from './declaration';\nimport tokenizer   from './tokenize';\nimport Comment     from './comment';\nimport AtRule      from './at-rule';\nimport Root        from './root';\nimport Rule        from './rule';\n\nexport default class Parser {\n\n    constructor(input) {\n        this.input = input;\n\n        this.pos       = 0;\n        this.root      = new Root();\n        this.current   = this.root;\n        this.spaces    = '';\n        this.semicolon = false;\n\n        this.root.source = { input, start: { line: 1, column: 1 } };\n    }\n\n    tokenize() {\n        this.tokens = tokenizer(this.input);\n    }\n\n    loop() {\n        let token;\n        while ( this.pos < this.tokens.length ) {\n            token = this.tokens[this.pos];\n\n            switch ( token[0] ) {\n            case 'word':\n            case ':':\n                this.word();\n                break;\n\n            case '}':\n                this.end(token);\n                break;\n\n            case 'comment':\n                this.comment(token);\n                break;\n\n            case 'at-word':\n                this.atrule(token);\n                break;\n\n            case '{':\n                this.emptyRule(token);\n                break;\n\n            default:\n                this.spaces += token[1];\n                break;\n            }\n\n            this.pos += 1;\n        }\n        this.endFile();\n    }\n\n    comment(token) {\n        let node = new Comment();\n        this.init(node, token[2], token[3]);\n        node.source.end = { line: token[4], column: token[5] };\n\n        let text = token[1].slice(2, -2);\n        if ( /^\\s*$/.test(text) ) {\n            node.text       = '';\n            node.raws.left  = text;\n            node.raws.right = '';\n        } else {\n            let match = text.match(/^(\\s*)([^]*[^\\s])(\\s*)$/);\n            node.text       = match[2];\n            node.raws.left  = match[1];\n            node.raws.right = match[3];\n        }\n    }\n\n    emptyRule(token) {\n        let node = new Rule();\n        this.init(node, token[2], token[3]);\n        node.selector = '';\n        node.raws.between = '';\n        this.current = node;\n    }\n\n    word() {\n        let token;\n        let end      = false;\n        let type     = null;\n        let colon    = false;\n        let bracket  = null;\n        let brackets = 0;\n\n        let start = this.pos;\n        this.pos += 1;\n        while ( this.pos < this.tokens.length ) {\n            token = this.tokens[this.pos];\n            type  = token[0];\n\n            if ( type === '(' ) {\n                if ( !bracket ) bracket = token;\n                brackets += 1;\n\n            } else if ( brackets === 0 ) {\n                if ( type === ';' ) {\n                    if ( colon ) {\n                        this.decl(this.tokens.slice(start, this.pos + 1));\n                        return;\n                    } else {\n                        break;\n                    }\n\n                } else if ( type === '{' ) {\n                    this.rule(this.tokens.slice(start, this.pos + 1));\n                    return;\n\n                } else if ( type === '}' ) {\n                    this.pos -= 1;\n                    end = true;\n                    break;\n\n                } else if ( type === ':' ) {\n                    colon = true;\n                }\n\n            } else if ( type === ')' ) {\n                brackets -= 1;\n                if ( brackets === 0 ) bracket = null;\n            }\n\n            this.pos += 1;\n        }\n        if ( this.pos === this.tokens.length ) {\n            this.pos -= 1;\n            end = true;\n        }\n\n        if ( brackets > 0 ) this.unclosedBracket(bracket);\n\n        if ( end && colon ) {\n            while ( this.pos > start ) {\n                token = this.tokens[this.pos][0];\n                if ( token !== 'space' && token !== 'comment' ) break;\n                this.pos -= 1;\n            }\n            this.decl(this.tokens.slice(start, this.pos + 1));\n            return;\n        }\n\n        this.unknownWord(start);\n    }\n\n    rule(tokens) {\n        tokens.pop();\n\n        let node = new Rule();\n        this.init(node, tokens[0][2], tokens[0][3]);\n\n        node.raws.between = this.spacesFromEnd(tokens);\n        this.raw(node, 'selector', tokens);\n        this.current = node;\n    }\n\n    decl(tokens) {\n        let node = new Declaration();\n        this.init(node);\n\n        let last = tokens[tokens.length - 1];\n        if ( last[0] === ';' ) {\n            this.semicolon = true;\n            tokens.pop();\n        }\n        if ( last[4] ) {\n            node.source.end = { line: last[4], column: last[5] };\n        } else {\n            node.source.end = { line: last[2], column: last[3] };\n        }\n\n        while ( tokens[0][0] !== 'word' ) {\n            node.raws.before += tokens.shift()[1];\n        }\n        node.source.start = { line: tokens[0][2], column: tokens[0][3] };\n\n        node.prop = '';\n        while ( tokens.length ) {\n            let type = tokens[0][0];\n            if ( type === ':' || type === 'space' || type === 'comment' ) {\n                break;\n            }\n            node.prop += tokens.shift()[1];\n        }\n\n        node.raws.between = '';\n\n        let token;\n        while ( tokens.length ) {\n            token = tokens.shift();\n\n            if ( token[0] === ':' ) {\n                node.raws.between += token[1];\n                break;\n            } else {\n                node.raws.between += token[1];\n            }\n        }\n\n        if ( node.prop[0] === '_' || node.prop[0] === '*' ) {\n            node.raws.before += node.prop[0];\n            node.prop = node.prop.slice(1);\n        }\n        node.raws.between += this.spacesFromStart(tokens);\n        this.precheckMissedSemicolon(tokens);\n\n        for ( let i = tokens.length - 1; i > 0; i-- ) {\n            token = tokens[i];\n            if ( token[1] === '!important' ) {\n                node.important = true;\n                let string = this.stringFrom(tokens, i);\n                string = this.spacesFromEnd(tokens) + string;\n                if ( string !== ' !important' ) node.raws.important = string;\n                break;\n\n            } else if (token[1] === 'important') {\n                let cache = tokens.slice(0);\n                let str   = '';\n                for ( let j = i; j > 0; j-- ) {\n                    let type = cache[j][0];\n                    if ( str.trim().indexOf('!') === 0 && type !== 'space' ) {\n                        break;\n                    }\n                    str = cache.pop()[1] + str;\n                }\n                if ( str.trim().indexOf('!') === 0 ) {\n                    node.important = true;\n                    node.raws.important = str;\n                    tokens = cache;\n                }\n            }\n\n            if ( token[0] !== 'space' && token[0] !== 'comment' ) {\n                break;\n            }\n        }\n\n        this.raw(node, 'value', tokens);\n\n        if ( node.value.indexOf(':') !== -1 ) this.checkMissedSemicolon(tokens);\n    }\n\n    atrule(token) {\n        let node  = new AtRule();\n        node.name = token[1].slice(1);\n        if ( node.name === '' ) {\n            this.unnamedAtrule(node, token);\n        }\n        this.init(node, token[2], token[3]);\n\n        let last   = false;\n        let open   = false;\n        let params = [];\n\n        this.pos += 1;\n        while ( this.pos < this.tokens.length ) {\n            token = this.tokens[this.pos];\n\n            if ( token[0] === ';' ) {\n                node.source.end = { line: token[2], column: token[3] };\n                this.semicolon = true;\n                break;\n            } else if ( token[0] === '{' ) {\n                open = true;\n                break;\n            } else if ( token[0] === '}') {\n                this.end(token);\n                break;\n            } else {\n                params.push(token);\n            }\n\n            this.pos += 1;\n        }\n        if ( this.pos === this.tokens.length ) {\n            last = true;\n        }\n\n        node.raws.between = this.spacesFromEnd(params);\n        if ( params.length ) {\n            node.raws.afterName = this.spacesFromStart(params);\n            this.raw(node, 'params', params);\n            if ( last ) {\n                token = params[params.length - 1];\n                node.source.end   = { line: token[4], column: token[5] };\n                this.spaces       = node.raws.between;\n                node.raws.between = '';\n            }\n        } else {\n            node.raws.afterName = '';\n            node.params         = '';\n        }\n\n        if ( open ) {\n            node.nodes   = [];\n            this.current = node;\n        }\n    }\n\n    end(token) {\n        if ( this.current.nodes && this.current.nodes.length ) {\n            this.current.raws.semicolon = this.semicolon;\n        }\n        this.semicolon = false;\n\n        this.current.raws.after = (this.current.raws.after || '') + this.spaces;\n        this.spaces = '';\n\n        if ( this.current.parent ) {\n            this.current.source.end = { line: token[2], column: token[3] };\n            this.current = this.current.parent;\n        } else {\n            this.unexpectedClose(token);\n        }\n    }\n\n    endFile() {\n        if ( this.current.parent ) this.unclosedBlock();\n        if ( this.current.nodes && this.current.nodes.length ) {\n            this.current.raws.semicolon = this.semicolon;\n        }\n        this.current.raws.after = (this.current.raws.after || '') + this.spaces;\n    }\n\n    // Helpers\n\n    init(node, line, column) {\n        this.current.push(node);\n\n        node.source = { start: { line, column }, input: this.input };\n        node.raws.before = this.spaces;\n        this.spaces = '';\n        if ( node.type !== 'comment' ) this.semicolon = false;\n    }\n\n    raw(node, prop, tokens) {\n        let token, type;\n        let length = tokens.length;\n        let value  = '';\n        let clean  = true;\n        for ( let i = 0; i < length; i += 1 ) {\n            token = tokens[i];\n            type  = token[0];\n            if ( type === 'comment' || type === 'space' && i === length - 1 ) {\n                clean = false;\n            } else {\n                value += token[1];\n            }\n        }\n        if ( !clean ) {\n            let raw = tokens.reduce( (all, i) => all + i[1], '');\n            node.raws[prop] = { value, raw };\n        }\n        node[prop] = value;\n    }\n\n    spacesFromEnd(tokens) {\n        let lastTokenType;\n        let spaces = '';\n        while ( tokens.length ) {\n            lastTokenType = tokens[tokens.length - 1][0];\n            if ( lastTokenType !== 'space' &&\n                lastTokenType !== 'comment' ) break;\n            spaces = tokens.pop()[1] + spaces;\n        }\n        return spaces;\n    }\n\n    spacesFromStart(tokens) {\n        let next;\n        let spaces = '';\n        while ( tokens.length ) {\n            next = tokens[0][0];\n            if ( next !== 'space' && next !== 'comment' ) break;\n            spaces += tokens.shift()[1];\n        }\n        return spaces;\n    }\n\n    stringFrom(tokens, from) {\n        let result = '';\n        for ( let i = from; i < tokens.length; i++ ) {\n            result += tokens[i][1];\n        }\n        tokens.splice(from, tokens.length - from);\n        return result;\n    }\n\n    colon(tokens) {\n        let brackets = 0;\n        let token, type, prev;\n        for ( let i = 0; i < tokens.length; i++ ) {\n            token = tokens[i];\n            type  = token[0];\n\n            if ( type === '(' ) {\n                brackets += 1;\n            } else if ( type === ')' ) {\n                brackets -= 1;\n            } else if ( brackets === 0 && type === ':' ) {\n                if ( !prev ) {\n                    this.doubleColon(token);\n                } else if ( prev[0] === 'word' && prev[1] === 'progid' ) {\n                    continue;\n                } else {\n                    return i;\n                }\n            }\n\n            prev = token;\n        }\n        return false;\n    }\n\n    // Errors\n\n    unclosedBracket(bracket) {\n        throw this.input.error('Unclosed bracket', bracket[2], bracket[3]);\n    }\n\n    unknownWord(start) {\n        let token = this.tokens[start];\n        throw this.input.error('Unknown word', token[2], token[3]);\n    }\n\n    unexpectedClose(token) {\n        throw this.input.error('Unexpected }', token[2], token[3]);\n    }\n\n    unclosedBlock() {\n        let pos = this.current.source.start;\n        throw this.input.error('Unclosed block', pos.line, pos.column);\n    }\n\n    doubleColon(token) {\n        throw this.input.error('Double colon', token[2], token[3]);\n    }\n\n    unnamedAtrule(node, token) {\n        throw this.input.error('At-rule without name', token[2], token[3]);\n    }\n\n    precheckMissedSemicolon(tokens) {\n        // Hook for Safe Parser\n        tokens;\n    }\n\n    checkMissedSemicolon(tokens) {\n        let colon = this.colon(tokens);\n        if ( colon === false ) return;\n\n        let founded = 0;\n        let token;\n        for ( let j = colon - 1; j >= 0; j-- ) {\n            token = tokens[j];\n            if ( token[0] !== 'space' ) {\n                founded += 1;\n                if ( founded === 2 ) break;\n            }\n        }\n        throw this.input.error('Missed semicolon', token[2], token[3]);\n    }\n\n}\n"],"sourceRoot":"/source/"}