diff --git a/src/compiler/parser/html-parser.js b/src/compiler/parser/html-parser.js index b574e9c40e..f93c098fa5 100644 --- a/src/compiler/parser/html-parser.js +++ b/src/compiler/parser/html-parser.js @@ -279,7 +279,7 @@ export function parseHTML (html, options) { ) { options.warn( `tag <${stack[i].tag}> has no matching end tag.`, - { start: stack[i].start } + { start: stack[i].start, end: stack[i].end } ) } if (options.end) { diff --git a/src/compiler/parser/index.js b/src/compiler/parser/index.js index 01cbadd1de..0689eb873d 100644 --- a/src/compiler/parser/index.js +++ b/src/compiler/parser/index.js @@ -210,7 +210,7 @@ export function parse ( shouldDecodeNewlinesForHref: options.shouldDecodeNewlinesForHref, shouldKeepComment: options.comments, outputSourceRange: options.outputSourceRange, - start (tag, attrs, unary, start) { + start (tag, attrs, unary, start, end) { // check namespace. // inherit parent ns if there is one const ns = (currentParent && currentParent.ns) || platformGetTagNamespace(tag) @@ -229,6 +229,7 @@ export function parse ( if (process.env.NODE_ENV !== 'production') { if (options.outputSourceRange) { element.start = start + element.end = end element.rawAttrsMap = element.attrsList.reduce((cumulated, attr) => { cumulated[attr.name] = attr return cumulated diff --git a/test/unit/modules/compiler/compiler-options.spec.js b/test/unit/modules/compiler/compiler-options.spec.js index 4b17545bd5..a0cfcdde5c 100644 --- a/test/unit/modules/compiler/compiler-options.spec.js +++ b/test/unit/modules/compiler/compiler-options.spec.js @@ -140,6 +140,11 @@ describe('compile options', () => { expect(compiled.errors[0].end).toBe(17) expect(compiled.errors[1].start).toBe(18) expect(compiled.errors[1].end).toBe(29) + + compiled = compile('