Skip to content

Latest commit

 

History

History
74 lines (55 loc) · 1.21 KB

File metadata and controls

74 lines (55 loc) · 1.21 KB

babel-plugin-minify-mangle-names

Context- and scope- aware variable renaming.

Example

In

var globalVariableName = 42;
function foo() {
  var longLocalVariableName = 1;
  if (longLocalVariableName) {
    console.log(longLocalVariableName);
  }
}

Out

var globalVariableName = 42;
function foo() {
  var a = 1;
  if (a) {
    console.log(a);
  }
}

Installation

$ npm install babel-plugin-minify-mangle-names

Usage

Via .babelrc (Recommended)

.babelrc

// without options
{
  "plugins": ["minify-mangle-names"]
}

// with options
{
  "plugins": ["minify-mangle-names", { "blacklist": { "foo": true, "bar": true} }]
}

Via CLI

$ babel --plugins minify-mangle-names script.js

Via Node API

require("babel-core").transform("code", {
  plugins: ["minify-mangle-names"]
});

Options

  • blacklist - A plain JS Object with keys as identifier names and values indicating whether to exclude
  • eval - mangle identifiers in scopes accessible by eval
  • keepFnName - prevent mangler from altering function names. Useful for code depending on fn.name
  • keepClassName - prevent mangler from altering class names.