diff --git a/lib/file.js b/lib/file.js index 0b1de00..2788e6d 100644 --- a/lib/file.js +++ b/lib/file.js @@ -92,12 +92,26 @@ File.prototype = { }; }, + /** + * Returns sourceMap if it exists. null otherwise + * @returns {Object} + */ + getSourceMap: function () { + return this._map ? JSON.parse(this._map.toString()) : null; + }, + + /** + * Returns content joined with EOL. + * @returns {String} + */ + getContent: function () { + return this._content.join(os.EOL); + }, + render: function () { - var content = this._content.join(os.EOL); - if (this._map) { - content = utils.joinContentAndSourceMap(content, this._map, this._opts); - } - return content; + return this._map + ? utils.joinContentAndSourceMap(this.getContent(), this._map, this._opts) + : this.getContent(); } }; diff --git a/lib/utils.js b/lib/utils.js index 0c15a4e..48324d4 100644 --- a/lib/utils.js +++ b/lib/utils.js @@ -11,9 +11,9 @@ module.exports = { * @return {SourceMapConsumer} */ getSourceMap: function (content) { - return Array.isArray(content) - ? getFromLastLine_(content) - : getFromText_(content); + return Array.isArray(content) + ? getFromLastLine_(content) + : getFromText_(content); function getFromLastLine_(lines) { return mkSourceMap(split(lines[lines.length - 1]).sourceMap); @@ -62,9 +62,9 @@ module.exports = { * @return {String} */ joinContentAndSourceMap: function (content, sourceMap, opts) { - if (!(sourceMap instanceof SourceMapGenerator)) { - throw new Error('sourceMap should be an instance of SourceMapGenerator'); - } + sourceMap = sourceMap instanceof SourceMapGenerator + ? sourceMap.toString() + : JSON.stringify(sourceMap); opts = opts || {}; opts.comment = opts.comment || 'inline'; diff --git a/tests/file.test.js b/tests/file.test.js index 5683a98..e10cc1a 100644 --- a/tests/file.test.js +++ b/tests/file.test.js @@ -1,6 +1,6 @@ -var os = require('os'); var format = require('util').format; var sinon = require('sinon'); +var SourceMapConsumer = require('source-map').SourceMapConsumer; var SourceMapGenerator = require('source-map').SourceMapGenerator; var File = require('../lib/file'); var utils = require('../lib/utils'); @@ -16,7 +16,7 @@ describe('File', function () { it('should add a new line to the output', function () { file.writeLine('line 1'); file.writeLine('line 2'); - file.render().should.equal('line 1\nline 2\n'); + file.getContent().should.equal('line 1\nline 2\n'); }); }); @@ -24,7 +24,7 @@ describe('File', function () { it('should add content to the output', function () { file.writeContent('line 1\nline 2'); file.writeContent('line 3\nline 4'); - file.render().should.equal('line 1\nline 2\nline 3\nline 4\n'); + file.getContent().should.equal('line 1\nline 2\nline 3\nline 4\n'); }); }); @@ -32,7 +32,7 @@ describe('File', function () { it('should add content to the output', function () { file.writeFileContent('2.js', 'line 1\nline 2'); file.writeFileContent('2.js', 'line 3\nline 4'); - file.render().should.equal('line 1\nline 2\nline 3\nline 4\n'); + file.getContent().should.equal('line 1\nline 2\nline 3\nline 4\n'); }); }); @@ -42,7 +42,7 @@ describe('File', function () { file.write('2'); file.write('3\n'); file.write('4\n5'); - file.render().should.equal('123\n4\n5'); + file.getContent().should.equal('123\n4\n5'); }); it('should move cursor forward', function () { @@ -70,7 +70,7 @@ describe('File', function () { it('should add content to the output', function () { file.writeFileFragment('2.js', 'line 1\nline 2', 1, 0); file.writeFileFragment('2.js', 'line 3\nline 4', 2, 0); - file.render().should.equal('line 1\nline 2line 3\nline 4'); + file.getContent().should.equal('line 1\nline 2line 3\nline 4'); }); }); }); @@ -84,8 +84,8 @@ describe('File', function () { it('should add a new line to the output', function () { file.writeLine('line 1'); file.writeLine('line 2'); - hasSourceMap(file.render()).should.equal(true); - stripSourceMap(file.render()).should.equal('line 1\nline 2\n'); + + file.getContent().should.equal('line 1\nline 2\n'); }); }); @@ -93,8 +93,8 @@ describe('File', function () { it('should add content to the output', function () { file.writeContent('line 1\nline 2'); file.writeContent('line 3\nline 4'); - hasSourceMap(file.render()).should.equal(true); - stripSourceMap(file.render()).should.equal('line 1\nline 2\nline 3\nline 4\n'); + + file.getContent().should.equal('line 1\nline 2\nline 3\nline 4\n'); }); }); @@ -104,8 +104,8 @@ describe('File', function () { file.write('2'); file.write('3\n'); file.write('4\n5\n'); - hasSourceMap(file.render()).should.equal(true); - stripSourceMap(file.render()).should.equal('123\n4\n5\n'); + + file.getContent().should.equal('123\n4\n5\n'); }); it('should move cursor forward', function () { @@ -134,10 +134,9 @@ describe('File', function () { file.write('_'); file.writeFileFragment('2.js', 'line 1\nline 2', 1, 0); file.writeFileFragment('3.js', 'line 3\nline 4', 2, 3); - hasSourceMap(file.render()).should.equal(true); - stripSourceMap(file.render()).should.equal('_line 1\nline 2line 3\nline 4\n'); - toReadableString(utils.getSourceMap(file.render())).should.equal( + file.getContent().should.equal('_line 1\nline 2line 3\nline 4'); + toReadableString(file.getSourceMap()).should.equal( [ '1, 1 -> 1, 0 2.js', '2, 0 -> 2, 0 2.js', @@ -152,8 +151,7 @@ describe('File', function () { it('should add content to the output', function () { file.writeFileContent('2.js', 'line 1\nline 2'); file.writeFileContent('2.js', 'line 3\nline 4'); - hasSourceMap(file.render()).should.equal(true); - stripSourceMap(file.render()).should.equal('line 1\nline 2\nline 3\nline 4\n'); + file.getContent().should.equal('line 1\nline 2\nline 3\nline 4\n'); }); describe('with existing source map', function() { @@ -164,7 +162,7 @@ describe('File', function () { file.writeFileContent('some-file.js', middleContent); - var pos = utils.getSourceMap(file.render()).originalPositionFor({line: 1, column: 0}); + var pos = getOriginalSourceMapPosition({ line: 1, column: 0 }, file.getSourceMap()); pos.source.should.equal('source.js'); pos.line.should.equal(1); pos.column.should.equal(0); @@ -177,7 +175,7 @@ describe('File', function () { file.writeFileContent('../some/path/some-file.js', middleContent); - var pos = utils.getSourceMap(file.render()).originalPositionFor({line: 1, column: 0}); + var pos = getOriginalSourceMapPosition({ line: 1, column: 0 }, file.getSourceMap()); pos.source.should.equal('../some/other/path/source.js'); }); @@ -188,7 +186,7 @@ describe('File', function () { file.writeFileContent('/some/path/some-file.js', middleContent); - var pos = utils.getSourceMap(file.render()).originalPositionFor({line: 1, column: 0}); + var pos = getOriginalSourceMapPosition({ line: 1, column: 0 }, file.getSourceMap()); pos.source.should.equal('/some/other/path/source.js'); }); @@ -199,7 +197,7 @@ describe('File', function () { file.writeFileContent('/some/path/some-file.js', middleContent); - var pos = utils.getSourceMap(file.render()).originalPositionFor({line: 1, column: 0}); + var pos = getOriginalSourceMapPosition({ line: 1, column: 0 }, file.getSourceMap()); pos.source.should.equal('/other/path/source.js'); }); @@ -222,7 +220,7 @@ describe('File', function () { file.writeFileContent('some-file.js', middleContent); var expected = toReadableString(utils.getSourceMap(middleContent)); - var actual = toReadableString(utils.getSourceMap(file.render())); + var actual = toReadableString(file.getSourceMap()); expected.should.equal(actual); }); @@ -342,19 +340,11 @@ describe('File', function () { }); }); -function hasSourceMap(source) { - var lines = source.split('\n'); - return lines[lines.length - 1].indexOf('//# sourceMappingURL=') === 0; -} - -function stripSourceMap(source) { - var lines = source.split(os.EOL); - lines.pop(); - return lines.join(os.EOL) + '\n'; -} - /// -function toReadableString(consumer) { +function toReadableString(sourceMap) { + var consumer = sourceMap instanceof SourceMapConsumer + ? sourceMap + : new SourceMapConsumer(sourceMap); var pieces = []; consumer.eachMapping(function(mapping) { pieces.push(format('%s, %s -> %s, %s %s', @@ -367,3 +357,7 @@ function toReadableString(consumer) { }); return pieces.join('\n'); } + +function getOriginalSourceMapPosition(position, sourceMap) { + return (new SourceMapConsumer(sourceMap)).originalPositionFor(position); +} diff --git a/tests/utils.test.js b/tests/utils.test.js index 4db3260..b1d1acc 100644 --- a/tests/utils.test.js +++ b/tests/utils.test.js @@ -134,10 +134,10 @@ describe('Utils', function() { result.should.be.equal(['line1', 'line2', SOURCE_MAP_LINE].join(os.EOL)); }); - it('should throw if not a SourceMapGenerator passed', function() { - (function() { - return utils.joinContentAndSourceMap('some-content', SOURCE_MAP_CONSUMER); - }).should.throw(); + it('should be able to take sourceMap without SouceMapGenerator wrapper', function () { + var sourceMap = JSON.parse(SOURCE_MAP_GENERATOR.toString()); + var result = utils.joinContentAndSourceMap(['line1', 'line2'].join(os.EOL), sourceMap); + result.should.be.equal(['line1', 'line2', SOURCE_MAP_LINE].join(os.EOL)); }); it('should throw if source map not passed', function() {