パッケージの詳細

babel-plugin-source-map-support

chocolateboy504.3kArtistic-2.02.2.0

A Babel plugin which automatically makes stack traces source-map aware

babel-plugin, source-map, sourcemap, source-maps

readme

Build Status NPM Version

NAME

babel-plugin-source-map-support - a Babel plugin which automatically makes stack traces source-map aware

INSTALL

$ npm install source-map-support --save
$ npm install babel-plugin-source-map-support --save-dev

SYNOPSIS

$ cat test.js

import foo from 'foo';
import bar from 'bar';

foo(bar);

$ babel --plugins source-map-support test.js

import 'source-map-support/register';
import foo from 'foo';
import bar from 'bar';

foo(bar);

DESCRIPTION

This is a Babel plugin which prepends the following statement to source files:

import 'source-map-support/register';

In conjunction with the source-map-support module, which must be installed separately, this statement hooks into the v8 stack-trace API to translate call sites in the transpiled code back to their corresponding locations in the original code.

Note: this only works in environments which support the v8 stack-trace API (e.g. Node.js and Chrome), though it's harmless in other environments.

The source-map-support module only needs to be registered in the top-level file(s) of an application, but it no-ops if it has already been loaded, so there's no harm in registering it in every file.

You probably don't want to use this plugin when compiling code for the web because you probably don't want to bundle source-maps and the source-map-support module in minified code. An easy way to limit the plugin's scope to development/test builds is to use Babel's env option, e.g.:

{
    env: {
        development: {
            sourceMaps: 'inline',
            plugins: ['source-map-support', ...]
        }
    },

    presets: [ ... ]
}

Note that source-maps don't need to be inlined in each file. They can be externalised by using the { sourceMaps: true } option. This adds a link to the bottom of each file which points to its generated source-map, e.g.:

{
    env: {
        development: {
            sourceMaps: true,
            plugins: ['source-map-support', ...]
        }
    },
}
// index.js footer:
//# sourceMappingURL=index.js.map

DEVELOPMENT

## NPM Scripts The following NPM scripts are available: - build - compile the plugin and save it to the dist directory - build:doc - generate the README's TOC (table of contents) - clean - remove the dist directory and other build artifacts - rebuild - clean the build artifacts and recompile the code - test - rebuild the plugin and run the test suite - test:debug - run the test script in debug mode, which dumps each transformed test case - test:prod - run the test suite in production mode - test:run - run the test suite

COMPATIBILITY

SEE ALSO

VERSION

2.2.0

AUTHOR

chocolateboy

COPYRIGHT AND LICENSE

Copyright © 2015-2022 by chocolateboy.

This module is free software; you can redistribute it and/or modify it under the terms of the Artistic License 2.0.

更新履歴

2.2.0 - 2022-06-22

  • bump dependencies
  • build: migrate from bili -> rollup

2.1.3 - 2020-08-31

  • bump dependencies
  • documentation tweaks

2.1.2 - 2020-06-09

  • bump dependencies

2.1.1 - 2019-07-11

  • document the supported Babel version

2.1.0 - 2019-07-11

  • update dependencies (closes #7, #13, #14)
  • drop support for unsupported Node.js versions
  • clarify the use of external source-maps
  • build clean-up
  • documentation tweaks

2.0.1 - 2018-02-28

  • build the release target in production mode
  • documentation tweaks

2.0.0 - 2018-02-20

Breaking Changes

  • add support for Babel >= 7.x
  • drop support for Babel 6.x

1.0.0 - 2017-07-27

Breaking Changes

  • add support for Babel >= 6.x (thanks, gajus and mariodu)
  • drop support for Babel 5.x

Changes

  • build: migrate from Grunt to Gulp
  • test:
    • migrate from Mocha to AVA
    • compare the generated source code rather than the AST

0.0.1 - 2015-09-16

  • initial release