Modify given `err` object to be more useful - adds `at`, `line`, `column`, `place` and `filename` properties and also cleans stack traces.
npm install stacktrace-metadata> Modify given err object to be more useful - adds at, line, column, place and filename properties and also cleans stack traces.
[![code climate][codeclimate-img]][codeclimate-url]
[![code style][standard-img]][standard-url]
[![linux build][travis-img]][travis-url]
[![windows build][appveyor-img]][appveyor-url]
[![code coverage][coverage-img]][coverage-url]
[![dependency status][david-img]][david-url]
[![paypal donate][paypalme-img]][paypalme-url]
You might also be interested in clean-stacktrace.
- Works on Windows and Node.js >= 0.10
- Always normalizes Windows paths to be Unix-style
- Customizable through options
- Cleans stack trace using [clean-stacktrace][], opts.cleanStack: false to disable
- Passing different current working directory to use, opts.cwd, using [clean-stacktrace-relative-paths][]
- Makes paths relative against opts.cwd, opts.relativePaths: false to disable
- Makes stack trace short - top 4, opts.shortStack: false to disable
- Allow hiding the stack trace (making it empty string), opts.showStack: false to enable
- Adds useful properties like line, column and filename, using [clean-stacktrace-metadata][]
_(TOC generated by verb using markdown-toc)_
```
$ npm install stacktrace-metadata --save
or install using yarn
``
$ yarn add stacktrace-metadata
`js`
const stacktraceMetadata = require('stacktrace-metadata')
, line, column, filename and place. By default it cleans stack, makes is short (4 length) and makes paths relative. But all this is controllable through options object. Throws TypeError if error is not an instance of Error.Params
*
error {Error}: real error object, checked against instanceof Error
* options {Object}: optional options object for more control
* options.cleanStack {Boolean}: if false won't clean stack trace from node internals
* options.shortStack {Boolean}: if false full stack traces, otherwise they are just four
* options.showStack {Boolean}: if false the error.stack will be empty string
* options.relativePaths {Boolean}: if false paths in stack traces will be absolute
* options.mapper {Function}: called on each line of the stack with (line, index) signature
* options.cwd {String}: current working directory, default process.cwd()
* returns {Error}: same error object, but modified Example
`js
const metadata = require('stacktrace-metadata')const error = new Error('foo quxie')
error.stack =
Error: foo quxie
const err = metadata(error)console.log(err.line) // => 8
console.log(err.column) // => 10
console.log(err.filename) // => 'alwa.js'
console.log(err.place) // => 'zazz'
console.log(err.at) // => 'zazz (alwa.js:8:10)'
console.log(err.stack)
// =>
// Error: foo quxie
// at zazz (alwa.js:8:10)
// at module.exports (foo.js:6:3)
// at Object. (dush.js:45:3)
`Related
- abbrev-kindof: Use abbreviations for checking type of given value. Like kindof(val, 'soa') to check that value is string, object or array. | kindof(val, 'soa'" class="text-primary hover:underline" target="_blank" rel="noopener noreferrer">homepage to check that value is string, object or array.")
- assert-kindof: Check native type of value and throw AssertionError if not okey. Clean stack traces. Simplicity. Built on [is-kindof][]. | homepage
- clean-stack: Clean up error stack traces | homepage
- clean-stacktrace-metadata: Plugin for clean-stacktrace lib. Parse each line to get additional info like filename, column and line of the error. | clean-stacktrace lib. Parse each line to get additional info like filename, column and line of the error."" class="text-primary hover:underline" target="_blank" rel="noopener noreferrer">homepage
- clean-stacktrace-relative-paths: Meant to be used with [clean-stacktrace][] as mapper function. Makes absolute paths inside stack traces to relative paths. | homepage
- clean-stacktrace: Clean up error stack traces from node internals | homepage
- dush: Microscopic & functional event emitter in ~260 bytes, extensible through plugins. | homepage
- is-kindof: Check type of given javascript value. Support promises, generators, streams, and native types. Built on [kind-of][] lib. | homepageContributing
Pull requests and stars are always welcome. For bugs and feature requests, please create an issue.
Please read the contributing guidelines for advice on opening issues, pull requests, and coding standards.
If you need some help and can spent some cash, feel free to contact me at CodeMentor.io too.In short: If you want to contribute to that project, please follow these things
1. Please DO NOT edit README.md, CHANGELOG.md and .verb.md files. See "Building docs" section.
2. Ensure anything is okey by installing the dependencies and run the tests. See "Running tests" section.
3. Always use
npm run commit to commit changes instead of git commit, because it is interactive and user-friendly. It uses [commitizen][] behind the scenes, which follows Conventional Changelog idealogy.
4. Do NOT bump the version in package.json. For that we use npm run release, which is [standard-version][] and follows Conventional Changelog idealogy.Thanks a lot! :)
Building docs
Documentation and that readme is generated using [verb-generate-readme][], which is a [verb][] generator, so you need to install both of them and then run verb command like that`
$ npm install verbose/verb#dev verb-generate-readme --global && verb
`_Please don't edit the README directly. Any changes to the readme must be made in .verb.md._
Running tests
Clone repository and run the following in that cloned directory`
$ npm install && npm test
``Author
Charlike Mike Reagent+ github/tunnckoCore
+ twitter/tunnckoCore
+ codementor/tunnckoCore
License
Copyright © 2015, 2017, Charlike Mike Reagent. Released under the MIT License.*
_This file was generated by verb-generate-readme, v0.4.3, on March 15, 2017._
_Project scaffolded using [charlike][] cli._
[charlike]: https://github.com/tunnckocore/charlike
[clean-stacktrace-metadata]: https://github.com/tunnckocore/clean-stacktrace-metadata
[clean-stacktrace-relative-paths]: https://github.com/tunnckocore/clean-stacktrace-relative-paths
[clean-stacktrace]: https://github.com/tunnckocore/clean-stacktrace
[commitizen]: https://github.com/commitizen/cz-cli
[is-kindof]: https://github.com/tunnckocore/is-kindof
[kind-of]: https://github.com/jonschlinkert/kind-of
[standard-version]: https://github.com/conventional-changelog/standard-version
[verb-generate-readme]: https://github.com/verbose/verb-generate-readme
[verb]: https://github.com/verbose/verb
[license-url]: https://www.npmjs.com/package/stacktrace-metadata
[license-img]: https://img.shields.io/npm/l/stacktrace-metadata.svg
[downloads-url]: https://www.npmjs.com/package/stacktrace-metadata
[downloads-img]: https://img.shields.io/npm/dt/stacktrace-metadata.svg
[codeclimate-url]: https://codeclimate.com/github/tunnckoCore/stacktrace-metadata
[codeclimate-img]: https://img.shields.io/codeclimate/github/tunnckoCore/stacktrace-metadata.svg
[travis-url]: https://travis-ci.org/tunnckoCore/stacktrace-metadata
[travis-img]: https://img.shields.io/travis/tunnckoCore/stacktrace-metadata/master.svg?label=linux
[appveyor-url]: https://ci.appveyor.com/project/tunnckoCore/stacktrace-metadata
[appveyor-img]: https://img.shields.io/appveyor/ci/tunnckoCore/stacktrace-metadata/master.svg?label=windows
[coverage-url]: https://codecov.io/gh/tunnckoCore/stacktrace-metadata
[coverage-img]: https://img.shields.io/codecov/c/github/tunnckoCore/stacktrace-metadata/master.svg
[david-url]: https://david-dm.org/tunnckoCore/stacktrace-metadata
[david-img]: https://img.shields.io/david/tunnckoCore/stacktrace-metadata.svg
[standard-url]: https://github.com/feross/standard
[standard-img]: https://img.shields.io/badge/code%20style-standard-brightgreen.svg
[paypalme-url]: https://www.paypal.me/tunnckoCore
[paypalme-img]: https://img.shields.io/badge/paypal-donate-brightgreen.svg