Skip to content

Commit

Permalink
fix: corrected var/# parsing in template
Browse files Browse the repository at this point in the history
Closes #2084
  • Loading branch information
mhevery committed Jun 5, 2015
1 parent ab8eb4f commit a418397
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 17 deletions.
22 changes: 10 additions & 12 deletions modules/angular2/src/change_detection/parser/parser.ts
Original file line number Diff line number Diff line change
Expand Up @@ -538,19 +538,17 @@ class _ParseAST {
this.optionalCharacter($COLON);
var name = null;
var expression = null;
if (this.next !== EOF) {
if (keyIsVar) {
if (this.optionalOperator("=")) {
name = this.expectTemplateBindingKey();
} else {
name = '\$implicit';
}
} else if (!this.peekKeywordVar()) {
var start = this.inputIndex;
var ast = this.parsePipe();
var source = this.input.substring(start, this.inputIndex);
expression = new ASTWithSource(ast, source, this.location);
if (keyIsVar) {
if (this.optionalOperator("=")) {
name = this.expectTemplateBindingKey();
} else {
name = '\$implicit';
}
} else if (this.next !== EOF && !this.peekKeywordVar()) {
var start = this.inputIndex;
var ast = this.parsePipe();
var source = this.input.substring(start, this.inputIndex);
expression = new ASTWithSource(ast, source, this.location);
}
ListWrapper.push(bindings, new TemplateBinding(key, keyIsVar, name, expression));
if (!this.optionalCharacter($SEMICOLON)) {
Expand Down
16 changes: 11 additions & 5 deletions modules/angular2/test/change_detection/parser/parser_spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -447,7 +447,7 @@ export function main() {
function keyValues(templateBindings) {
return ListWrapper.map(templateBindings, (binding) => {
if (binding.keyIsVar) {
return '#' + binding.key + (isBlank(binding.name) ? '' : '=' + binding.name);
return '#' + binding.key + (isBlank(binding.name) ? '=null' : '=' + binding.name);
} else {
return binding.key + (isBlank(binding.expression) ? '' : `=${binding.expression}`)
}
Expand All @@ -471,7 +471,7 @@ export function main() {
expect(bindings).toEqual([]);
});

iit('should parse a string without a value', () => {
it('should parse a string without a value', () => {
var bindings = parseTemplateBindings('a');
expect(keys(bindings)).toEqual(['a']);
});
Expand Down Expand Up @@ -508,7 +508,7 @@ export function main() {

it('should detect names as value', () => {
var bindings = parseTemplateBindings("a:#b");
expect(keyValues(bindings)).toEqual(['a', '#b']);
expect(keyValues(bindings)).toEqual(['a', '#b=\$implicit']);
});

it('should allow space and colon as separators', () => {
Expand Down Expand Up @@ -540,10 +540,16 @@ export function main() {

it('should support var/# notation', () => {
var bindings = parseTemplateBindings("var i");
expect(keyValues(bindings)).toEqual(['#i']);
expect(keyValues(bindings)).toEqual(['#i=\$implicit']);

bindings = parseTemplateBindings("#i");
expect(keyValues(bindings)).toEqual(['#i']);
expect(keyValues(bindings)).toEqual(['#i=\$implicit']);

bindings = parseTemplateBindings("var a; var b");
expect(keyValues(bindings)).toEqual(['#a=\$implicit', '#b=\$implicit']);

bindings = parseTemplateBindings("#a; #b;");
expect(keyValues(bindings)).toEqual(['#a=\$implicit', '#b=\$implicit']);

bindings = parseTemplateBindings("var i-a = k-a");
expect(keyValues(bindings)).toEqual(['#i-a=k-a']);
Expand Down

0 comments on commit a418397

Please sign in to comment.