|
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