|
1 | 1 | var parse5 = require('parse5') |
2 | 2 | var parser = new parse5.Parser(null, { locationInfo: true }) |
3 | 3 | var cache = require('lru-cache')(100) |
| 4 | +var SourceNode = require('source-map').SourceNode |
| 5 | +var SourceMapGenerator = require('source-map').SourceMapGenerator |
| 6 | +var splitRE = /\n\r|\n|\r/g |
4 | 7 |
|
5 | | -module.exports = function (content) { |
| 8 | +module.exports = function (content, filename) { |
6 | 9 |
|
7 | | - var output = cache.get(content) |
| 10 | + var cacheKey = filename + 'XXX' + content |
| 11 | + var output = cache.get(cacheKey) |
8 | 12 | if (output) return output |
9 | 13 |
|
10 | 14 | output = { |
@@ -73,54 +77,37 @@ module.exports = function (content) { |
73 | 77 |
|
74 | 78 | var start = node.childNodes[0].__location.start |
75 | 79 | var end = node.childNodes[node.childNodes.length - 1].__location.end |
76 | | - |
77 | | - var result |
78 | | - if (type === 'script') { |
79 | | - result = |
80 | | - commentScript(content.slice(0, start), lang) + |
81 | | - content.slice(start, end) + |
82 | | - commentScript(content.slice(end), lang) + |
83 | | - // workaround for Webpack eval-source-map bug |
84 | | - // https://github.com/webpack/webpack/pull/1816 |
85 | | - '\n/* generated by vue-loader */\n' |
86 | | - } else { |
87 | | - result = content.slice(start, end).trim() |
88 | | - } |
| 80 | + var result = content.slice(start, end) |
| 81 | + var lineOffset = content.slice(0, start).split(splitRE).length - 1 |
| 82 | + var map = new SourceMapGenerator() |
| 83 | + map.setSourceContent(filename, content) |
| 84 | + |
| 85 | + result.split(splitRE).forEach(function (line, index) { |
| 86 | + map.addMapping({ |
| 87 | + source: filename, |
| 88 | + original: { |
| 89 | + line: index + 1 + lineOffset, |
| 90 | + column: 0 |
| 91 | + }, |
| 92 | + generated: { |
| 93 | + line: index + 1, |
| 94 | + column: 0 |
| 95 | + } |
| 96 | + }) |
| 97 | + }) |
89 | 98 |
|
90 | 99 | output[type].push({ |
91 | 100 | lang: lang, |
92 | 101 | scoped: scoped, |
93 | | - content: result |
| 102 | + content: result, |
| 103 | + map: map.toJSON() |
94 | 104 | }) |
95 | 105 | }) |
96 | 106 |
|
97 | | - cache.set(content, output) |
| 107 | + cache.set(cacheKey, output) |
98 | 108 | return output |
99 | 109 | } |
100 | 110 |
|
101 | | -function commentScript (content, lang) { |
102 | | - return content |
103 | | - .split(/\n\r|\n|\r/g) |
104 | | - .map(function (line) { |
105 | | - if (line.trim() === '') { |
106 | | - return line |
107 | | - } |
108 | | - |
109 | | - switch (lang) { |
110 | | - case 'coffee': |
111 | | - case 'coffee-jsx': |
112 | | - case 'coffee-redux': |
113 | | - return '# ' + line |
114 | | - case 'purs': |
115 | | - case 'ulmus': |
116 | | - return '-- ' + line |
117 | | - default: |
118 | | - return '// ' + line |
119 | | - } |
120 | | - }) |
121 | | - .join('\n') |
122 | | -} |
123 | | - |
124 | 111 | function getAttribute (node, name) { |
125 | 112 | if (node.attrs) { |
126 | 113 | var i = node.attrs.length |
|
0 commit comments