743 lines
		
	
	
		
			24 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
		
		
			
		
	
	
			743 lines
		
	
	
		
			24 KiB
		
	
	
	
		
			Markdown
		
	
	
	
	
	
| 
								 | 
							
								# Source Map
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								[](https://travis-ci.org/mozilla/source-map)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								[](https://www.npmjs.com/package/source-map)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								This is a library to generate and consume the source map format
							 | 
						||
| 
								 | 
							
								[described here][format].
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								[format]: https://docs.google.com/document/d/1U1RGAehQwRypUTovF1KRlpiOFze0b-_2gc6fAH0KY0k/edit
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								## Use with Node
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    $ npm install source-map
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								## Use on the Web
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    <script src="https://raw.githubusercontent.com/mozilla/source-map/master/dist/source-map.min.js" defer></script>
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								--------------------------------------------------------------------------------
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								<!-- `npm run toc` to regenerate the Table of Contents -->
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								<!-- START doctoc generated TOC please keep comment here to allow auto update -->
							 | 
						||
| 
								 | 
							
								<!-- DON'T EDIT THIS SECTION, INSTEAD RE-RUN doctoc TO UPDATE -->
							 | 
						||
| 
								 | 
							
								## Table of Contents
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								- [Examples](#examples)
							 | 
						||
| 
								 | 
							
								  - [Consuming a source map](#consuming-a-source-map)
							 | 
						||
| 
								 | 
							
								  - [Generating a source map](#generating-a-source-map)
							 | 
						||
| 
								 | 
							
								    - [With SourceNode (high level API)](#with-sourcenode-high-level-api)
							 | 
						||
| 
								 | 
							
								    - [With SourceMapGenerator (low level API)](#with-sourcemapgenerator-low-level-api)
							 | 
						||
| 
								 | 
							
								- [API](#api)
							 | 
						||
| 
								 | 
							
								  - [SourceMapConsumer](#sourcemapconsumer)
							 | 
						||
| 
								 | 
							
								    - [new SourceMapConsumer(rawSourceMap)](#new-sourcemapconsumerrawsourcemap)
							 | 
						||
| 
								 | 
							
								    - [SourceMapConsumer.prototype.computeColumnSpans()](#sourcemapconsumerprototypecomputecolumnspans)
							 | 
						||
| 
								 | 
							
								    - [SourceMapConsumer.prototype.originalPositionFor(generatedPosition)](#sourcemapconsumerprototypeoriginalpositionforgeneratedposition)
							 | 
						||
| 
								 | 
							
								    - [SourceMapConsumer.prototype.generatedPositionFor(originalPosition)](#sourcemapconsumerprototypegeneratedpositionfororiginalposition)
							 | 
						||
| 
								 | 
							
								    - [SourceMapConsumer.prototype.allGeneratedPositionsFor(originalPosition)](#sourcemapconsumerprototypeallgeneratedpositionsfororiginalposition)
							 | 
						||
| 
								 | 
							
								    - [SourceMapConsumer.prototype.hasContentsOfAllSources()](#sourcemapconsumerprototypehascontentsofallsources)
							 | 
						||
| 
								 | 
							
								    - [SourceMapConsumer.prototype.sourceContentFor(source[, returnNullOnMissing])](#sourcemapconsumerprototypesourcecontentforsource-returnnullonmissing)
							 | 
						||
| 
								 | 
							
								    - [SourceMapConsumer.prototype.eachMapping(callback, context, order)](#sourcemapconsumerprototypeeachmappingcallback-context-order)
							 | 
						||
| 
								 | 
							
								  - [SourceMapGenerator](#sourcemapgenerator)
							 | 
						||
| 
								 | 
							
								    - [new SourceMapGenerator([startOfSourceMap])](#new-sourcemapgeneratorstartofsourcemap)
							 | 
						||
| 
								 | 
							
								    - [SourceMapGenerator.fromSourceMap(sourceMapConsumer)](#sourcemapgeneratorfromsourcemapsourcemapconsumer)
							 | 
						||
| 
								 | 
							
								    - [SourceMapGenerator.prototype.addMapping(mapping)](#sourcemapgeneratorprototypeaddmappingmapping)
							 | 
						||
| 
								 | 
							
								    - [SourceMapGenerator.prototype.setSourceContent(sourceFile, sourceContent)](#sourcemapgeneratorprototypesetsourcecontentsourcefile-sourcecontent)
							 | 
						||
| 
								 | 
							
								    - [SourceMapGenerator.prototype.applySourceMap(sourceMapConsumer[, sourceFile[, sourceMapPath]])](#sourcemapgeneratorprototypeapplysourcemapsourcemapconsumer-sourcefile-sourcemappath)
							 | 
						||
| 
								 | 
							
								    - [SourceMapGenerator.prototype.toString()](#sourcemapgeneratorprototypetostring)
							 | 
						||
| 
								 | 
							
								  - [SourceNode](#sourcenode)
							 | 
						||
| 
								 | 
							
								    - [new SourceNode([line, column, source[, chunk[, name]]])](#new-sourcenodeline-column-source-chunk-name)
							 | 
						||
| 
								 | 
							
								    - [SourceNode.fromStringWithSourceMap(code, sourceMapConsumer[, relativePath])](#sourcenodefromstringwithsourcemapcode-sourcemapconsumer-relativepath)
							 | 
						||
| 
								 | 
							
								    - [SourceNode.prototype.add(chunk)](#sourcenodeprototypeaddchunk)
							 | 
						||
| 
								 | 
							
								    - [SourceNode.prototype.prepend(chunk)](#sourcenodeprototypeprependchunk)
							 | 
						||
| 
								 | 
							
								    - [SourceNode.prototype.setSourceContent(sourceFile, sourceContent)](#sourcenodeprototypesetsourcecontentsourcefile-sourcecontent)
							 | 
						||
| 
								 | 
							
								    - [SourceNode.prototype.walk(fn)](#sourcenodeprototypewalkfn)
							 | 
						||
| 
								 | 
							
								    - [SourceNode.prototype.walkSourceContents(fn)](#sourcenodeprototypewalksourcecontentsfn)
							 | 
						||
| 
								 | 
							
								    - [SourceNode.prototype.join(sep)](#sourcenodeprototypejoinsep)
							 | 
						||
| 
								 | 
							
								    - [SourceNode.prototype.replaceRight(pattern, replacement)](#sourcenodeprototypereplacerightpattern-replacement)
							 | 
						||
| 
								 | 
							
								    - [SourceNode.prototype.toString()](#sourcenodeprototypetostring)
							 | 
						||
| 
								 | 
							
								    - [SourceNode.prototype.toStringWithSourceMap([startOfSourceMap])](#sourcenodeprototypetostringwithsourcemapstartofsourcemap)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								<!-- END doctoc generated TOC please keep comment here to allow auto update -->
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								## Examples
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								### Consuming a source map
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								var rawSourceMap = {
							 | 
						||
| 
								 | 
							
								  version: 3,
							 | 
						||
| 
								 | 
							
								  file: 'min.js',
							 | 
						||
| 
								 | 
							
								  names: ['bar', 'baz', 'n'],
							 | 
						||
| 
								 | 
							
								  sources: ['one.js', 'two.js'],
							 | 
						||
| 
								 | 
							
								  sourceRoot: 'http://example.com/www/js/',
							 | 
						||
| 
								 | 
							
								  mappings: 'CAAC,IAAI,IAAM,SAAUA,GAClB,OAAOC,IAAID;CCDb,IAAI,IAAM,SAAUE,GAClB,OAAOA'
							 | 
						||
| 
								 | 
							
								};
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var smc = new SourceMapConsumer(rawSourceMap);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								console.log(smc.sources);
							 | 
						||
| 
								 | 
							
								// [ 'http://example.com/www/js/one.js',
							 | 
						||
| 
								 | 
							
								//   'http://example.com/www/js/two.js' ]
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								console.log(smc.originalPositionFor({
							 | 
						||
| 
								 | 
							
								  line: 2,
							 | 
						||
| 
								 | 
							
								  column: 28
							 | 
						||
| 
								 | 
							
								}));
							 | 
						||
| 
								 | 
							
								// { source: 'http://example.com/www/js/two.js',
							 | 
						||
| 
								 | 
							
								//   line: 2,
							 | 
						||
| 
								 | 
							
								//   column: 10,
							 | 
						||
| 
								 | 
							
								//   name: 'n' }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								console.log(smc.generatedPositionFor({
							 | 
						||
| 
								 | 
							
								  source: 'http://example.com/www/js/two.js',
							 | 
						||
| 
								 | 
							
								  line: 2,
							 | 
						||
| 
								 | 
							
								  column: 10
							 | 
						||
| 
								 | 
							
								}));
							 | 
						||
| 
								 | 
							
								// { line: 2, column: 28 }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								smc.eachMapping(function (m) {
							 | 
						||
| 
								 | 
							
								  // ...
							 | 
						||
| 
								 | 
							
								});
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								### Generating a source map
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								In depth guide:
							 | 
						||
| 
								 | 
							
								[**Compiling to JavaScript, and Debugging with Source Maps**](https://hacks.mozilla.org/2013/05/compiling-to-javascript-and-debugging-with-source-maps/)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### With SourceNode (high level API)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								function compile(ast) {
							 | 
						||
| 
								 | 
							
								  switch (ast.type) {
							 | 
						||
| 
								 | 
							
								  case 'BinaryExpression':
							 | 
						||
| 
								 | 
							
								    return new SourceNode(
							 | 
						||
| 
								 | 
							
								      ast.location.line,
							 | 
						||
| 
								 | 
							
								      ast.location.column,
							 | 
						||
| 
								 | 
							
								      ast.location.source,
							 | 
						||
| 
								 | 
							
								      [compile(ast.left), " + ", compile(ast.right)]
							 | 
						||
| 
								 | 
							
								    );
							 | 
						||
| 
								 | 
							
								  case 'Literal':
							 | 
						||
| 
								 | 
							
								    return new SourceNode(
							 | 
						||
| 
								 | 
							
								      ast.location.line,
							 | 
						||
| 
								 | 
							
								      ast.location.column,
							 | 
						||
| 
								 | 
							
								      ast.location.source,
							 | 
						||
| 
								 | 
							
								      String(ast.value)
							 | 
						||
| 
								 | 
							
								    );
							 | 
						||
| 
								 | 
							
								  // ...
							 | 
						||
| 
								 | 
							
								  default:
							 | 
						||
| 
								 | 
							
								    throw new Error("Bad AST");
							 | 
						||
| 
								 | 
							
								  }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var ast = parse("40 + 2", "add.js");
							 | 
						||
| 
								 | 
							
								console.log(compile(ast).toStringWithSourceMap({
							 | 
						||
| 
								 | 
							
								  file: 'add.js'
							 | 
						||
| 
								 | 
							
								}));
							 | 
						||
| 
								 | 
							
								// { code: '40 + 2',
							 | 
						||
| 
								 | 
							
								//   map: [object SourceMapGenerator] }
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### With SourceMapGenerator (low level API)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								var map = new SourceMapGenerator({
							 | 
						||
| 
								 | 
							
								  file: "source-mapped.js"
							 | 
						||
| 
								 | 
							
								});
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								map.addMapping({
							 | 
						||
| 
								 | 
							
								  generated: {
							 | 
						||
| 
								 | 
							
								    line: 10,
							 | 
						||
| 
								 | 
							
								    column: 35
							 | 
						||
| 
								 | 
							
								  },
							 | 
						||
| 
								 | 
							
								  source: "foo.js",
							 | 
						||
| 
								 | 
							
								  original: {
							 | 
						||
| 
								 | 
							
								    line: 33,
							 | 
						||
| 
								 | 
							
								    column: 2
							 | 
						||
| 
								 | 
							
								  },
							 | 
						||
| 
								 | 
							
								  name: "christopher"
							 | 
						||
| 
								 | 
							
								});
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								console.log(map.toString());
							 | 
						||
| 
								 | 
							
								// '{"version":3,"file":"source-mapped.js","sources":["foo.js"],"names":["christopher"],"mappings":";;;;;;;;;mCAgCEA"}'
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								## API
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Get a reference to the module:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								// Node.js
							 | 
						||
| 
								 | 
							
								var sourceMap = require('source-map');
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// Browser builds
							 | 
						||
| 
								 | 
							
								var sourceMap = window.sourceMap;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// Inside Firefox
							 | 
						||
| 
								 | 
							
								const sourceMap = require("devtools/toolkit/sourcemap/source-map.js");
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								### SourceMapConsumer
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								A SourceMapConsumer instance represents a parsed source map which we can query
							 | 
						||
| 
								 | 
							
								for information about the original file positions by giving it a file position
							 | 
						||
| 
								 | 
							
								in the generated source.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### new SourceMapConsumer(rawSourceMap)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								The only parameter is the raw source map (either as a string which can be
							 | 
						||
| 
								 | 
							
								`JSON.parse`'d, or an object). According to the spec, source maps have the
							 | 
						||
| 
								 | 
							
								following attributes:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `version`: Which version of the source map spec this map is following.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `sources`: An array of URLs to the original source files.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `names`: An array of identifiers which can be referenced by individual
							 | 
						||
| 
								 | 
							
								  mappings.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `sourceRoot`: Optional. The URL root from which all sources are relative.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `sourcesContent`: Optional. An array of contents of the original source files.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `mappings`: A string of base64 VLQs which contain the actual mappings.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `file`: Optional. The generated filename this source map is associated with.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								var consumer = new sourceMap.SourceMapConsumer(rawSourceMapJsonData);
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceMapConsumer.prototype.computeColumnSpans()
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Compute the last column for each generated mapping. The last column is
							 | 
						||
| 
								 | 
							
								inclusive.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								// Before:
							 | 
						||
| 
								 | 
							
								consumer.allGeneratedPositionsFor({ line: 2, source: "foo.coffee" })
							 | 
						||
| 
								 | 
							
								// [ { line: 2,
							 | 
						||
| 
								 | 
							
								//     column: 1 },
							 | 
						||
| 
								 | 
							
								//   { line: 2,
							 | 
						||
| 
								 | 
							
								//     column: 10 },
							 | 
						||
| 
								 | 
							
								//   { line: 2,
							 | 
						||
| 
								 | 
							
								//     column: 20 } ]
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								consumer.computeColumnSpans();
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								// After:
							 | 
						||
| 
								 | 
							
								consumer.allGeneratedPositionsFor({ line: 2, source: "foo.coffee" })
							 | 
						||
| 
								 | 
							
								// [ { line: 2,
							 | 
						||
| 
								 | 
							
								//     column: 1,
							 | 
						||
| 
								 | 
							
								//     lastColumn: 9 },
							 | 
						||
| 
								 | 
							
								//   { line: 2,
							 | 
						||
| 
								 | 
							
								//     column: 10,
							 | 
						||
| 
								 | 
							
								//     lastColumn: 19 },
							 | 
						||
| 
								 | 
							
								//   { line: 2,
							 | 
						||
| 
								 | 
							
								//     column: 20,
							 | 
						||
| 
								 | 
							
								//     lastColumn: Infinity } ]
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceMapConsumer.prototype.originalPositionFor(generatedPosition)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Returns the original source, line, and column information for the generated
							 | 
						||
| 
								 | 
							
								source's line and column positions provided. The only argument is an object with
							 | 
						||
| 
								 | 
							
								the following properties:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `line`: The line number in the generated source.  Line numbers in
							 | 
						||
| 
								 | 
							
								  this library are 1-based (note that the underlying source map
							 | 
						||
| 
								 | 
							
								  specification uses 0-based line numbers -- this library handles the
							 | 
						||
| 
								 | 
							
								  translation).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `column`: The column number in the generated source.  Column numbers
							 | 
						||
| 
								 | 
							
								  in this library are 0-based.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `bias`: Either `SourceMapConsumer.GREATEST_LOWER_BOUND` or
							 | 
						||
| 
								 | 
							
								  `SourceMapConsumer.LEAST_UPPER_BOUND`. Specifies whether to return the closest
							 | 
						||
| 
								 | 
							
								  element that is smaller than or greater than the one we are searching for,
							 | 
						||
| 
								 | 
							
								  respectively, if the exact element cannot be found.  Defaults to
							 | 
						||
| 
								 | 
							
								  `SourceMapConsumer.GREATEST_LOWER_BOUND`.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								and an object is returned with the following properties:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `source`: The original source file, or null if this information is not
							 | 
						||
| 
								 | 
							
								  available.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `line`: The line number in the original source, or null if this information is
							 | 
						||
| 
								 | 
							
								  not available.  The line number is 1-based.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `column`: The column number in the original source, or null if this
							 | 
						||
| 
								 | 
							
								  information is not available.  The column number is 0-based.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `name`: The original identifier, or null if this information is not available.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								consumer.originalPositionFor({ line: 2, column: 10 })
							 | 
						||
| 
								 | 
							
								// { source: 'foo.coffee',
							 | 
						||
| 
								 | 
							
								//   line: 2,
							 | 
						||
| 
								 | 
							
								//   column: 2,
							 | 
						||
| 
								 | 
							
								//   name: null }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								consumer.originalPositionFor({ line: 99999999999999999, column: 999999999999999 })
							 | 
						||
| 
								 | 
							
								// { source: null,
							 | 
						||
| 
								 | 
							
								//   line: null,
							 | 
						||
| 
								 | 
							
								//   column: null,
							 | 
						||
| 
								 | 
							
								//   name: null }
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceMapConsumer.prototype.generatedPositionFor(originalPosition)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Returns the generated line and column information for the original source,
							 | 
						||
| 
								 | 
							
								line, and column positions provided. The only argument is an object with
							 | 
						||
| 
								 | 
							
								the following properties:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `source`: The filename of the original source.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `line`: The line number in the original source.  The line number is
							 | 
						||
| 
								 | 
							
								  1-based.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `column`: The column number in the original source.  The column
							 | 
						||
| 
								 | 
							
								  number is 0-based.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								and an object is returned with the following properties:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `line`: The line number in the generated source, or null.  The line
							 | 
						||
| 
								 | 
							
								  number is 1-based.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `column`: The column number in the generated source, or null.  The
							 | 
						||
| 
								 | 
							
								  column number is 0-based.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								consumer.generatedPositionFor({ source: "example.js", line: 2, column: 10 })
							 | 
						||
| 
								 | 
							
								// { line: 1,
							 | 
						||
| 
								 | 
							
								//   column: 56 }
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceMapConsumer.prototype.allGeneratedPositionsFor(originalPosition)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Returns all generated line and column information for the original source, line,
							 | 
						||
| 
								 | 
							
								and column provided. If no column is provided, returns all mappings
							 | 
						||
| 
								 | 
							
								corresponding to a either the line we are searching for or the next closest line
							 | 
						||
| 
								 | 
							
								that has any mappings. Otherwise, returns all mappings corresponding to the
							 | 
						||
| 
								 | 
							
								given line and either the column we are searching for or the next closest column
							 | 
						||
| 
								 | 
							
								that has any offsets.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								The only argument is an object with the following properties:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `source`: The filename of the original source.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `line`: The line number in the original source.  The line number is
							 | 
						||
| 
								 | 
							
								  1-based.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `column`: Optional. The column number in the original source.  The
							 | 
						||
| 
								 | 
							
								  column number is 0-based.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								and an array of objects is returned, each with the following properties:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `line`: The line number in the generated source, or null.  The line
							 | 
						||
| 
								 | 
							
								  number is 1-based.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `column`: The column number in the generated source, or null.  The
							 | 
						||
| 
								 | 
							
								  column number is 0-based.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								consumer.allGeneratedpositionsfor({ line: 2, source: "foo.coffee" })
							 | 
						||
| 
								 | 
							
								// [ { line: 2,
							 | 
						||
| 
								 | 
							
								//     column: 1 },
							 | 
						||
| 
								 | 
							
								//   { line: 2,
							 | 
						||
| 
								 | 
							
								//     column: 10 },
							 | 
						||
| 
								 | 
							
								//   { line: 2,
							 | 
						||
| 
								 | 
							
								//     column: 20 } ]
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceMapConsumer.prototype.hasContentsOfAllSources()
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Return true if we have the embedded source content for every source listed in
							 | 
						||
| 
								 | 
							
								the source map, false otherwise.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								In other words, if this method returns `true`, then
							 | 
						||
| 
								 | 
							
								`consumer.sourceContentFor(s)` will succeed for every source `s` in
							 | 
						||
| 
								 | 
							
								`consumer.sources`.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								// ...
							 | 
						||
| 
								 | 
							
								if (consumer.hasContentsOfAllSources()) {
							 | 
						||
| 
								 | 
							
								  consumerReadyCallback(consumer);
							 | 
						||
| 
								 | 
							
								} else {
							 | 
						||
| 
								 | 
							
								  fetchSources(consumer, consumerReadyCallback);
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								// ...
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceMapConsumer.prototype.sourceContentFor(source[, returnNullOnMissing])
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Returns the original source content for the source provided. The only
							 | 
						||
| 
								 | 
							
								argument is the URL of the original source file.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								If the source content for the given source is not found, then an error is
							 | 
						||
| 
								 | 
							
								thrown. Optionally, pass `true` as the second param to have `null` returned
							 | 
						||
| 
								 | 
							
								instead.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								consumer.sources
							 | 
						||
| 
								 | 
							
								// [ "my-cool-lib.clj" ]
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								consumer.sourceContentFor("my-cool-lib.clj")
							 | 
						||
| 
								 | 
							
								// "..."
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								consumer.sourceContentFor("this is not in the source map");
							 | 
						||
| 
								 | 
							
								// Error: "this is not in the source map" is not in the source map
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								consumer.sourceContentFor("this is not in the source map", true);
							 | 
						||
| 
								 | 
							
								// null
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceMapConsumer.prototype.eachMapping(callback, context, order)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Iterate over each mapping between an original source/line/column and a
							 | 
						||
| 
								 | 
							
								generated line/column in this source map.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `callback`: The function that is called with each mapping. Mappings have the
							 | 
						||
| 
								 | 
							
								  form `{ source, generatedLine, generatedColumn, originalLine, originalColumn,
							 | 
						||
| 
								 | 
							
								  name }`
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `context`: Optional. If specified, this object will be the value of `this`
							 | 
						||
| 
								 | 
							
								  every time that `callback` is called.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `order`: Either `SourceMapConsumer.GENERATED_ORDER` or
							 | 
						||
| 
								 | 
							
								  `SourceMapConsumer.ORIGINAL_ORDER`. Specifies whether you want to iterate over
							 | 
						||
| 
								 | 
							
								  the mappings sorted by the generated file's line/column order or the
							 | 
						||
| 
								 | 
							
								  original's source/line/column order, respectively. Defaults to
							 | 
						||
| 
								 | 
							
								  `SourceMapConsumer.GENERATED_ORDER`.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								consumer.eachMapping(function (m) { console.log(m); })
							 | 
						||
| 
								 | 
							
								// ...
							 | 
						||
| 
								 | 
							
								// { source: 'illmatic.js',
							 | 
						||
| 
								 | 
							
								//   generatedLine: 1,
							 | 
						||
| 
								 | 
							
								//   generatedColumn: 0,
							 | 
						||
| 
								 | 
							
								//   originalLine: 1,
							 | 
						||
| 
								 | 
							
								//   originalColumn: 0,
							 | 
						||
| 
								 | 
							
								//   name: null }
							 | 
						||
| 
								 | 
							
								// { source: 'illmatic.js',
							 | 
						||
| 
								 | 
							
								//   generatedLine: 2,
							 | 
						||
| 
								 | 
							
								//   generatedColumn: 0,
							 | 
						||
| 
								 | 
							
								//   originalLine: 2,
							 | 
						||
| 
								 | 
							
								//   originalColumn: 0,
							 | 
						||
| 
								 | 
							
								//   name: null }
							 | 
						||
| 
								 | 
							
								// ...
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								### SourceMapGenerator
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								An instance of the SourceMapGenerator represents a source map which is being
							 | 
						||
| 
								 | 
							
								built incrementally.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### new SourceMapGenerator([startOfSourceMap])
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								You may pass an object with the following properties:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `file`: The filename of the generated source that this source map is
							 | 
						||
| 
								 | 
							
								  associated with.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `sourceRoot`: A root for all relative URLs in this source map.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `skipValidation`: Optional. When `true`, disables validation of mappings as
							 | 
						||
| 
								 | 
							
								  they are added. This can improve performance but should be used with
							 | 
						||
| 
								 | 
							
								  discretion, as a last resort. Even then, one should avoid using this flag when
							 | 
						||
| 
								 | 
							
								  running tests, if possible.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								var generator = new sourceMap.SourceMapGenerator({
							 | 
						||
| 
								 | 
							
								  file: "my-generated-javascript-file.js",
							 | 
						||
| 
								 | 
							
								  sourceRoot: "http://example.com/app/js/"
							 | 
						||
| 
								 | 
							
								});
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceMapGenerator.fromSourceMap(sourceMapConsumer)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Creates a new `SourceMapGenerator` from an existing `SourceMapConsumer` instance.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `sourceMapConsumer` The SourceMap.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								var generator = sourceMap.SourceMapGenerator.fromSourceMap(consumer);
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceMapGenerator.prototype.addMapping(mapping)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Add a single mapping from original source line and column to the generated
							 | 
						||
| 
								 | 
							
								source's line and column for this source map being created. The mapping object
							 | 
						||
| 
								 | 
							
								should have the following properties:
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `generated`: An object with the generated line and column positions.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `original`: An object with the original line and column positions.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `source`: The original source file (relative to the sourceRoot).
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `name`: An optional original token name for this mapping.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								generator.addMapping({
							 | 
						||
| 
								 | 
							
								  source: "module-one.scm",
							 | 
						||
| 
								 | 
							
								  original: { line: 128, column: 0 },
							 | 
						||
| 
								 | 
							
								  generated: { line: 3, column: 456 }
							 | 
						||
| 
								 | 
							
								})
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceMapGenerator.prototype.setSourceContent(sourceFile, sourceContent)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Set the source content for an original source file.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `sourceFile` the URL of the original source file.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `sourceContent` the content of the source file.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								generator.setSourceContent("module-one.scm",
							 | 
						||
| 
								 | 
							
								                           fs.readFileSync("path/to/module-one.scm"))
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceMapGenerator.prototype.applySourceMap(sourceMapConsumer[, sourceFile[, sourceMapPath]])
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Applies a SourceMap for a source file to the SourceMap.
							 | 
						||
| 
								 | 
							
								Each mapping to the supplied source file is rewritten using the
							 | 
						||
| 
								 | 
							
								supplied SourceMap. Note: The resolution for the resulting mappings
							 | 
						||
| 
								 | 
							
								is the minimum of this map and the supplied map.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `sourceMapConsumer`: The SourceMap to be applied.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `sourceFile`: Optional. The filename of the source file.
							 | 
						||
| 
								 | 
							
								  If omitted, sourceMapConsumer.file will be used, if it exists.
							 | 
						||
| 
								 | 
							
								  Otherwise an error will be thrown.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `sourceMapPath`: Optional. The dirname of the path to the SourceMap
							 | 
						||
| 
								 | 
							
								  to be applied. If relative, it is relative to the SourceMap.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  This parameter is needed when the two SourceMaps aren't in the same
							 | 
						||
| 
								 | 
							
								  directory, and the SourceMap to be applied contains relative source
							 | 
						||
| 
								 | 
							
								  paths. If so, those relative source paths need to be rewritten
							 | 
						||
| 
								 | 
							
								  relative to the SourceMap.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								  If omitted, it is assumed that both SourceMaps are in the same directory,
							 | 
						||
| 
								 | 
							
								  thus not needing any rewriting. (Supplying `'.'` has the same effect.)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceMapGenerator.prototype.toString()
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Renders the source map being generated to a string.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								generator.toString()
							 | 
						||
| 
								 | 
							
								// '{"version":3,"sources":["module-one.scm"],"names":[],"mappings":"...snip...","file":"my-generated-javascript-file.js","sourceRoot":"http://example.com/app/js/"}'
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								### SourceNode
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								SourceNodes provide a way to abstract over interpolating and/or concatenating
							 | 
						||
| 
								 | 
							
								snippets of generated JavaScript source code, while maintaining the line and
							 | 
						||
| 
								 | 
							
								column information associated between those snippets and the original source
							 | 
						||
| 
								 | 
							
								code. This is useful as the final intermediate representation a compiler might
							 | 
						||
| 
								 | 
							
								use before outputting the generated JS and source map.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### new SourceNode([line, column, source[, chunk[, name]]])
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `line`: The original line number associated with this source node, or null if
							 | 
						||
| 
								 | 
							
								  it isn't associated with an original line.  The line number is 1-based.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `column`: The original column number associated with this source node, or null
							 | 
						||
| 
								 | 
							
								  if it isn't associated with an original column.  The column number
							 | 
						||
| 
								 | 
							
								  is 0-based.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `source`: The original source's filename; null if no filename is provided.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `chunk`: Optional. Is immediately passed to `SourceNode.prototype.add`, see
							 | 
						||
| 
								 | 
							
								  below.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `name`: Optional. The original identifier.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								var node = new SourceNode(1, 2, "a.cpp", [
							 | 
						||
| 
								 | 
							
								  new SourceNode(3, 4, "b.cpp", "extern int status;\n"),
							 | 
						||
| 
								 | 
							
								  new SourceNode(5, 6, "c.cpp", "std::string* make_string(size_t n);\n"),
							 | 
						||
| 
								 | 
							
								  new SourceNode(7, 8, "d.cpp", "int main(int argc, char** argv) {}\n"),
							 | 
						||
| 
								 | 
							
								]);
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceNode.fromStringWithSourceMap(code, sourceMapConsumer[, relativePath])
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Creates a SourceNode from generated code and a SourceMapConsumer.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `code`: The generated code
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `sourceMapConsumer` The SourceMap for the generated code
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `relativePath` The optional path that relative sources in `sourceMapConsumer`
							 | 
						||
| 
								 | 
							
								  should be relative to.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								var consumer = new SourceMapConsumer(fs.readFileSync("path/to/my-file.js.map", "utf8"));
							 | 
						||
| 
								 | 
							
								var node = SourceNode.fromStringWithSourceMap(fs.readFileSync("path/to/my-file.js"),
							 | 
						||
| 
								 | 
							
								                                              consumer);
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceNode.prototype.add(chunk)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Add a chunk of generated JS to this source node.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `chunk`: A string snippet of generated JS code, another instance of
							 | 
						||
| 
								 | 
							
								   `SourceNode`, or an array where each member is one of those things.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								node.add(" + ");
							 | 
						||
| 
								 | 
							
								node.add(otherNode);
							 | 
						||
| 
								 | 
							
								node.add([leftHandOperandNode, " + ", rightHandOperandNode]);
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceNode.prototype.prepend(chunk)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Prepend a chunk of generated JS to this source node.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `chunk`: A string snippet of generated JS code, another instance of
							 | 
						||
| 
								 | 
							
								   `SourceNode`, or an array where each member is one of those things.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								node.prepend("/** Build Id: f783haef86324gf **/\n\n");
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceNode.prototype.setSourceContent(sourceFile, sourceContent)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Set the source content for a source file. This will be added to the
							 | 
						||
| 
								 | 
							
								`SourceMap` in the `sourcesContent` field.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `sourceFile`: The filename of the source file
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `sourceContent`: The content of the source file
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								node.setSourceContent("module-one.scm",
							 | 
						||
| 
								 | 
							
								                      fs.readFileSync("path/to/module-one.scm"))
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceNode.prototype.walk(fn)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Walk over the tree of JS snippets in this node and its children. The walking
							 | 
						||
| 
								 | 
							
								function is called once for each snippet of JS and is passed that snippet and
							 | 
						||
| 
								 | 
							
								the its original associated source's line/column location.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `fn`: The traversal function.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								var node = new SourceNode(1, 2, "a.js", [
							 | 
						||
| 
								 | 
							
								  new SourceNode(3, 4, "b.js", "uno"),
							 | 
						||
| 
								 | 
							
								  "dos",
							 | 
						||
| 
								 | 
							
								  [
							 | 
						||
| 
								 | 
							
								    "tres",
							 | 
						||
| 
								 | 
							
								    new SourceNode(5, 6, "c.js", "quatro")
							 | 
						||
| 
								 | 
							
								  ]
							 | 
						||
| 
								 | 
							
								]);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								node.walk(function (code, loc) { console.log("WALK:", code, loc); })
							 | 
						||
| 
								 | 
							
								// WALK: uno { source: 'b.js', line: 3, column: 4, name: null }
							 | 
						||
| 
								 | 
							
								// WALK: dos { source: 'a.js', line: 1, column: 2, name: null }
							 | 
						||
| 
								 | 
							
								// WALK: tres { source: 'a.js', line: 1, column: 2, name: null }
							 | 
						||
| 
								 | 
							
								// WALK: quatro { source: 'c.js', line: 5, column: 6, name: null }
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceNode.prototype.walkSourceContents(fn)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Walk over the tree of SourceNodes. The walking function is called for each
							 | 
						||
| 
								 | 
							
								source file content and is passed the filename and source content.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `fn`: The traversal function.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								var a = new SourceNode(1, 2, "a.js", "generated from a");
							 | 
						||
| 
								 | 
							
								a.setSourceContent("a.js", "original a");
							 | 
						||
| 
								 | 
							
								var b = new SourceNode(1, 2, "b.js", "generated from b");
							 | 
						||
| 
								 | 
							
								b.setSourceContent("b.js", "original b");
							 | 
						||
| 
								 | 
							
								var c = new SourceNode(1, 2, "c.js", "generated from c");
							 | 
						||
| 
								 | 
							
								c.setSourceContent("c.js", "original c");
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var node = new SourceNode(null, null, null, [a, b, c]);
							 | 
						||
| 
								 | 
							
								node.walkSourceContents(function (source, contents) { console.log("WALK:", source, ":", contents); })
							 | 
						||
| 
								 | 
							
								// WALK: a.js : original a
							 | 
						||
| 
								 | 
							
								// WALK: b.js : original b
							 | 
						||
| 
								 | 
							
								// WALK: c.js : original c
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceNode.prototype.join(sep)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Like `Array.prototype.join` except for SourceNodes. Inserts the separator
							 | 
						||
| 
								 | 
							
								between each of this source node's children.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `sep`: The separator.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								var lhs = new SourceNode(1, 2, "a.rs", "my_copy");
							 | 
						||
| 
								 | 
							
								var operand = new SourceNode(3, 4, "a.rs", "=");
							 | 
						||
| 
								 | 
							
								var rhs = new SourceNode(5, 6, "a.rs", "orig.clone()");
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								var node = new SourceNode(null, null, null, [ lhs, operand, rhs ]);
							 | 
						||
| 
								 | 
							
								var joinedNode = node.join(" ");
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceNode.prototype.replaceRight(pattern, replacement)
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Call `String.prototype.replace` on the very right-most source snippet. Useful
							 | 
						||
| 
								 | 
							
								for trimming white space from the end of a source node, etc.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `pattern`: The pattern to replace.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								* `replacement`: The thing to replace the pattern with.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								// Trim trailing white space.
							 | 
						||
| 
								 | 
							
								node.replaceRight(/\s*$/, "");
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceNode.prototype.toString()
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Return the string representation of this source node. Walks over the tree and
							 | 
						||
| 
								 | 
							
								concatenates all the various snippets together to one string.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								var node = new SourceNode(1, 2, "a.js", [
							 | 
						||
| 
								 | 
							
								  new SourceNode(3, 4, "b.js", "uno"),
							 | 
						||
| 
								 | 
							
								  "dos",
							 | 
						||
| 
								 | 
							
								  [
							 | 
						||
| 
								 | 
							
								    "tres",
							 | 
						||
| 
								 | 
							
								    new SourceNode(5, 6, "c.js", "quatro")
							 | 
						||
| 
								 | 
							
								  ]
							 | 
						||
| 
								 | 
							
								]);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								node.toString()
							 | 
						||
| 
								 | 
							
								// 'unodostresquatro'
							 | 
						||
| 
								 | 
							
								```
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#### SourceNode.prototype.toStringWithSourceMap([startOfSourceMap])
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								Returns the string representation of this tree of source nodes, plus a
							 | 
						||
| 
								 | 
							
								SourceMapGenerator which contains all the mappings between the generated and
							 | 
						||
| 
								 | 
							
								original sources.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								The arguments are the same as those to `new SourceMapGenerator`.
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								```js
							 | 
						||
| 
								 | 
							
								var node = new SourceNode(1, 2, "a.js", [
							 | 
						||
| 
								 | 
							
								  new SourceNode(3, 4, "b.js", "uno"),
							 | 
						||
| 
								 | 
							
								  "dos",
							 | 
						||
| 
								 | 
							
								  [
							 | 
						||
| 
								 | 
							
								    "tres",
							 | 
						||
| 
								 | 
							
								    new SourceNode(5, 6, "c.js", "quatro")
							 | 
						||
| 
								 | 
							
								  ]
							 | 
						||
| 
								 | 
							
								]);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								node.toStringWithSourceMap({ file: "my-output-file.js" })
							 | 
						||
| 
								 | 
							
								// { code: 'unodostresquatro',
							 | 
						||
| 
								 | 
							
								//   map: [object SourceMapGenerator] }
							 | 
						||
| 
								 | 
							
								```
							 |