45 lines
2.8 KiB
Markdown
45 lines
2.8 KiB
Markdown
|
error-stack-parser.js - Extract meaning from JS Errors
|
||
|
===============
|
||
|
[data:image/s3,"s3://crabby-images/f5a00/f5a0003a88acd9afebb7e2ef18951e4388697d97" alt="Build Status"](https://travis-ci.org/stacktracejs/error-stack-parser)
|
||
|
[data:image/s3,"s3://crabby-images/cc109/cc10930f3f2351679eda93ff2075d869a2054396" alt="Coverage Status"](https://coveralls.io/r/stacktracejs/error-stack-parser?branch=master)
|
||
|
[data:image/s3,"s3://crabby-images/ea09f/ea09f279661e413a036dbbd20223dcae6b9704c2" alt="GitHub license"](https://opensource.org/licenses/MIT)
|
||
|
[data:image/s3,"s3://crabby-images/ac62a/ac62aaad4cc85865d849b00e22936b8d56bd92d0" alt="size with dependencies"](https://github.com/stacktracejs/error-stack-parser/releases)
|
||
|
[data:image/s3,"s3://crabby-images/303c5/303c56ff21541068e8919371322d4f6e94633935" alt="gzip size"](https://github.com/stacktracejs/error-stack-parser/releases)
|
||
|
[data:image/s3,"s3://crabby-images/0516b/0516b07cc9773c967373ac8e221dc7f6bc051639" alt="module format"](https://github.com/stacktracejs/error-stack-parser/releases)
|
||
|
[data:image/s3,"s3://crabby-images/9d771/9d77171f26e59b0f6217f3c604d960ddf111c8f9" alt="code of conduct"](http://todogroup.org/opencodeofconduct/#stacktrace.js/me@eriwen.com)
|
||
|
[data:image/s3,"s3://crabby-images/0c374/0c3742291069de8ecf9030b902a68c152765b9cc" alt="jsDelivr Hits"](https://www.jsdelivr.com/package/npm/error-stack-parser)
|
||
|
|
||
|
Simple, cross-browser [Error](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Error) parser.
|
||
|
This library parses and extracts function names, URLs, line numbers, and column numbers from the given Error's `stack` as
|
||
|
an Array of [StackFrame](http://git.io/stackframe)s.
|
||
|
|
||
|
Once you have parsed out StackFrames, you can do much more interesting things. See [stacktrace-gps](http://git.io/stacktrace-gps).
|
||
|
|
||
|
Note that in IE9 and earlier, `Error` objects don't have enough information to extract much of anything. In IE 10, `Error`s
|
||
|
are given a `stack` once they're `throw`n.
|
||
|
|
||
|
## Browser Support
|
||
|
[data:image/s3,"s3://crabby-images/7343b/7343b096efa59f79fa423a0f97f5994836b1e790" alt="Sauce Test Status"](https://saucelabs.com/u/stacktracejs)
|
||
|
|
||
|
## Usage
|
||
|
```js
|
||
|
ErrorStackParser.parse(new Error('BOOM'));
|
||
|
|
||
|
=> [
|
||
|
StackFrame({functionName: 'foo', args: [], fileName: 'path/to/file.js', lineNumber: 35, columnNumber: 79, isNative: false, isEval: false}),
|
||
|
StackFrame({functionName: 'Bar', fileName: 'https://cdn.somewherefast.com/utils.min.js', lineNumber: 1, columnNumber: 832, isNative: false, isEval: false, isConstructor: true}),
|
||
|
StackFrame(... and so on ...)
|
||
|
]
|
||
|
```
|
||
|
|
||
|
## Installation
|
||
|
```bash
|
||
|
npm install error-stack-parser
|
||
|
bower install error-stack-parser
|
||
|
https://raw.githubusercontent.com/stacktracejs/error-stack-parser/master/dist/error-stack-parser.min.js
|
||
|
```
|
||
|
|
||
|
## Contributing
|
||
|
Want to be listed as a *Contributor*? Start with the [Contributing Guide](.github/CONTRIBUTING.md)!
|
||
|
|