From 75e8d6205e4df305d86f809d5e24298d05d21d5d Mon Sep 17 00:00:00 2001 From: Rich-Harris Date: Sun, 2 Apr 2017 17:54:04 -0400 Subject: [PATCH] better error for bind:value="{{foo}}" - fixes #437 --- src/parse/read/directives.js | 11 +++++++++++ .../parser/samples/error-binding-mustaches/error.json | 8 ++++++++ .../parser/samples/error-binding-mustaches/input.html | 1 + 3 files changed, 20 insertions(+) create mode 100644 test/parser/samples/error-binding-mustaches/error.json create mode 100644 test/parser/samples/error-binding-mustaches/input.html diff --git a/src/parse/read/directives.js b/src/parse/read/directives.js index a52cbfabbabc..28adc3078a92 100644 --- a/src/parse/read/directives.js +++ b/src/parse/read/directives.js @@ -77,6 +77,17 @@ export function readBindingDirective ( parser, start, name ) { const a = parser.index; + if ( parser.eat( '{{' ) ) { + let message = 'bound values should not be wrapped'; + const b = parser.template.indexOf( '}}', a ); + if ( b !== -1 ) { + const value = parser.template.slice( parser.index, b ); + message += ` — use '${value}', not '{{${value}}}'`; + } + + parser.error( message, a ); + } + // this is a bit of a hack so that we can give Acorn something parseable let b; if ( quoteMark ) { diff --git a/test/parser/samples/error-binding-mustaches/error.json b/test/parser/samples/error-binding-mustaches/error.json new file mode 100644 index 000000000000..9d67bfba1a53 --- /dev/null +++ b/test/parser/samples/error-binding-mustaches/error.json @@ -0,0 +1,8 @@ +{ + "message": "bound values should not be wrapped — use 'foo', not '{{foo}}'", + "loc": { + "line": 1, + "column": 19 + }, + "pos": 19 +} \ No newline at end of file diff --git a/test/parser/samples/error-binding-mustaches/input.html b/test/parser/samples/error-binding-mustaches/input.html new file mode 100644 index 000000000000..a334ea705578 --- /dev/null +++ b/test/parser/samples/error-binding-mustaches/input.html @@ -0,0 +1 @@ +