fix(compiler): have CSS parser support nested parentheses inside functions

Closes #7580
This commit is contained in:
Tero Parviainen 2016-03-13 10:56:20 +02:00 committed by Misko Hevery
parent 4d6da7b1a7
commit ceac045a7f
2 changed files with 11 additions and 2 deletions

View File

@ -459,8 +459,14 @@ export class CssScanner {
scanCssValueFunction(): CssToken { scanCssValueFunction(): CssToken {
var start = this.index; var start = this.index;
var startingColumn = this.column; var startingColumn = this.column;
while (this.peek != $EOF && this.peek != $RPAREN) { var parenBalance = 1;
while (this.peek != $EOF && parenBalance > 0) {
this.advance(); this.advance();
if (this.peek == $LPAREN) {
parenBalance++;
} else if (this.peek == $RPAREN) {
parenBalance--;
}
} }
var strValue = this.input.substring(start, this.index); var strValue = this.input.substring(start, this.index);
return new CssToken(start, startingColumn, this.line, CssTokenType.Identifier, strValue); return new CssToken(start, startingColumn, this.line, CssTokenType.Identifier, strValue);

View File

@ -206,6 +206,7 @@ export function main() {
background: url(matias.css); background: url(matias.css);
animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060); animation-timing-function: cubic-bezier(0.755, 0.050, 0.855, 0.060);
height: calc(100% - 50px); height: calc(100% - 50px);
background-image: linear-gradient( 45deg, rgba(100, 0, 0, 0.5), black );
} }
`; `;
@ -213,12 +214,14 @@ export function main() {
expect(ast.rules.length).toEqual(1); expect(ast.rules.length).toEqual(1);
var defs = (<CssSelectorRuleAST>ast.rules[0]).block.entries; var defs = (<CssSelectorRuleAST>ast.rules[0]).block.entries;
expect(defs.length).toEqual(3); expect(defs.length).toEqual(4);
assertTokens((<CssDefinitionAST>defs[0]).value.tokens, ['url', '(', 'matias.css', ')']); assertTokens((<CssDefinitionAST>defs[0]).value.tokens, ['url', '(', 'matias.css', ')']);
assertTokens((<CssDefinitionAST>defs[1]).value.tokens, assertTokens((<CssDefinitionAST>defs[1]).value.tokens,
['cubic-bezier', '(', '0.755, 0.050, 0.855, 0.060', ')']); ['cubic-bezier', '(', '0.755, 0.050, 0.855, 0.060', ')']);
assertTokens((<CssDefinitionAST>defs[2]).value.tokens, ['calc', '(', '100% - 50px', ')']); assertTokens((<CssDefinitionAST>defs[2]).value.tokens, ['calc', '(', '100% - 50px', ')']);
assertTokens((<CssDefinitionAST>defs[3]).value.tokens,
['linear-gradient', '(', '45deg, rgba(100, 0, 0, 0.5), black', ')']);
}); });
it('should parse un-named block-level CSS values', () => { it('should parse un-named block-level CSS values', () => {