Show More
Commit Description:
change to encrypted cookies
Commit Description:
change to encrypted cookies
References:
File last commit:
Show/Diff file:
Action:
node_modules/source-map/README.md
| 742 lines
| 23.5 KiB
| text/x-minidsrc
| MarkdownLexer
|
r789 | # 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] } | ||||
``` | ||||