fix(compiler): have CSS parser support nested parentheses inside functions
Closes #7580
This commit is contained in:
parent
4d6da7b1a7
commit
ceac045a7f
|
@ -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);
|
||||||
|
|
|
@ -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', () => {
|
||||||
|
|
Loading…
Reference in New Issue