Skip to content

Hermes Engine inspired "show source" directive for Babel ✨

License

Notifications You must be signed in to change notification settings

nouvist/babel-plugin-show-source

Repository files navigation

babel-plugin-show-source

npm GitHub

Babel plugin for "show source" directive in order to make Function.prototype.toString() always available, even on bytecode JS.

Table of contents

Installation

This module is Babel plugin. That way, assumed you have installed Babel. In order to install this plugin, you could easily install it from NPM registry.

# npm
npm install -D babel-plugin-show-source
# yarn
yarn add -D babel-plugin-show-source
# pnpm
pnpm add -D babel-plugin-show-source

And then, add this module to your Babel config.

// babel.config.js
module.exports = {
  plugins: [
    'babel-plugin-show-source',
    // or with options
    [
      'babel-plugin-show-source',
      {
        removeDirective: true,
      },
    ],
  ],
};

With React Native Hermes

React Native Hermes does have native implementation for it, but it doesn't work as expected just yet. See issue#612. This plugin initiated as alternative to Hermes built in implementation and as temporary solution to it. If you want to use it with Hermes, you should change the directive other than 'show source', otherwise it will conflicting with Hermes and make inconsistent result.

// babel.config.js in React Native project
module.exports = {
  presets: ['module:metro-react-native-babel-preset'],
  plugins: [
    [
      'babel-plugin-show-source',
      {
        directive: 'show source please',
        // change the directive when in use with hermes
      },
    ],
  ],
};

Options

Name Type default Description
removeDirective boolean false remove the directive on the output
removeFunction boolean false return as object with toString() method without the full callable function
directive string 'show source' directive string
property string 'toString' property name

Note: FunctionDeclaration sometimes throw an Error, it is recommended to set removeFunction as true.

Usage

In order to use this plugin, you could simply use the "show source" directive in your function.

function fibonacci(num) {
  'show source';
  // use the specified directive
  if (num <= 2) return 1;
  else return fibonacci(num - 2) + fibonacci(num - 1);
}

License

MIT License

About

Hermes Engine inspired "show source" directive for Babel ✨

Resources

License

Stars

Watchers

Forks

Packages

No packages published