Lebab transpiles your ES5 code to ES6/ES7. It does exactly the opposite of what Babel does. If you want to understand what Lebab exactly does, try the live demo.
Install it using npm:
$ npm install -g lebabConvert your old-fashioned code using the lebab cli tool,
enabling a specific transformation:
$ lebab es5.js -o es6.js --transform letOr transform an entire directory of files in-place:
# .js files only
$ lebab --replace src/js/ --transform arrow
# For other file extensions, use explicit globbing
$ lebab --replace 'src/js/**/*.jsx' --transform arrowFor all the possible values for --transform option
see the detailed docs below or use --help from command line.
The recommended way of using Lebab is to apply one transform at a time, read what exactly the transform does and what are its limitations, apply it for your code and inspect the diff carefully.
These transforms can be applied with relatively high confidence. They use pretty straight-forward and strict rules for changing the code. The resulting code should be almost 100% equivalent of the original code.
-  arrow - callbacks to arrow functions
-  Converts bound functions like function(){}.bind(this)
-  not applied to unbound functions that use this
-  not applied to functions that use arguments
-  not applied to object properties (use obj-methodtransform)
-  converts immediate return { return x; }to=> x
-  does not remove that = thisassignments
- BUG fails with immediately returning functions that have methods invoked
 
-  Converts bound functions like 
-  for-of - for loop to for-of loop
-  uses name itemfor loop variable when loop body begins withvar item = array[i];
- does not work when no such alias defined at the start of loop body
-  LIMITATION requires let/const variables (run the lettransform first)
 
-  uses name 
-  arg-spread - use of apply() to spread operator
-  recognizes obj.method.apply(obj, args)
-  recognizes func.apply(undefined, args)
 
-  recognizes 
-  obj-method - function values in object to methods
- LIMITATION does not convert named function expressions
- does not convert arrow-functions
 
-  obj-shorthand - {foo: foo}to{foo}-  ignores numeric and NaNproperties
- does not convert string properties
 
-  ignores numeric and 
-  no-strict - removal of "use strict"directives-  does not touch stuff like x = "use strict";
 
-  does not touch stuff like 
-  commonjs - CommonJS module definition to ES6 modules
-  converts var foo = require("foo")toimport foo from "foo"
-  converts var bar = require("foo").bartoimport {bar} from "foo"
-  converts var {bar} = require("foo")toimport {bar} from "foo"
-  only handles require()calls invardeclarations
-  does not ensure that imported variable is treated as const
-  converts module.exports = <anything>toexport default <anything>
-  converts exports.foo = function(){}toexport function foo(){}
-  converts exports.Foo = class {}toexport class Foo {}
-  converts exports.foo = 123toexport var foo = 123
-  converts exports.foo = bartoexport {bar as foo}
- does not check if named export conflicts with existing variable names
- does not recognize imports/exports inside nested blocks/functions
 
-  converts 
-  exponent - Math.pow()to**operator (ES7)- Full support for all new syntax from ES7
 
-  multi-var - single var x,y;declaration to multiplevar x; var y;(refactor)- Not related to any new syntax feature
- EXPERIMENT to see if Lebab could be a more generic refactoring helper
 
These transforms should be applied with caution. They either use heuristics which can't guarantee that the resulting code is equivalent of the original code, or they have significant bugs which can result in breaking your code.
-  let - vartolet/const-  never modified variables are converted to const
- properly recognizes block-scoping
-  splits single var declaration to multiple let/constdeclarations if needed
- recognizes vars defined/assigned using destructuring
- vars that conflict with block-scoping are not converted
- repeated declarations of the same var are not converted
-  existing let/constare not converted
- BUG fails with repeated variable definitions that use destructuring
- BUG fails with closure over a loop variable
- BUG fails when function closes over variable declared after function is called
 
-  never modified variables are converted to 
-  class - function/prototypes to classes
-  recognizes Foo.prototype.method = function(){ ... };
-  recognizes Foo.prototype = { ...methods... };
-  recognizes static methods like Foo.method = function(){ ... };
-  recognizes getters/setters defined with Object.defineProperty()
- does not recognize classes without methods
- no support for extending classes
- LIMITATION does not support namespaced classes
 
-  recognizes 
-  template - string concatenation to template strings
-  converts variables and arbitrary expressions to ${...}
- BUG removes indentation of multi-line strings
-  LIMITATION ignores difference between .toString()and.valueOf()
 
-  converts variables and arbitrary expressions to 
-  default-param - default parameters instead of a = a || 2-  recognizes a = a || 2
-  recognizes a = a ? a : 2
-  recognizes a = a === undefined ? 2 : a
-  recognizes a = typeof a === 'undefined' ? 2 : a
-  LIMITATION transforming a = a || 2does not produce strictly equivalent code
 
-  recognizes 
-  includes - array.indexOf(foo) !== -1toarray.includes(foo)(ES7)- works for both strings and arrays
-  converts !== -1toarray.includes(foo)
-  converts === -1to!array.includes(foo)
-  recognizes all kinds of comparisons >= 0,> -1, etc
-  recognizes both indexOf() != -1and-1 != indexOf()
- LIMITATION does not detect that indexOf() is called on an actual Array or String.
 
Simply import and call lebab.transform():
import lebab from 'lebab';
const {code, warnings} = lebab.transform('var f = function(){};', ['let', 'arrow']);
console.log(code); // -> "const f = () => {};"The warnings will be an array of objects like:
[
  {line: 12, msg: 'Unable to transform var', type: 'let'},
  {line: 45, msg: 'Can not use arguments in arrow function', type: 'arrow'},
]Most of the time there won't be any warnings and the array will be empty.
Alternatively one can use Lebab through plugins in the following editors:
Which feature should Lebab implement next? Let us know by creating an issue or voicing your opinion in existing one.
Want to contribute? Read how Lebab looks for patterns in syntax trees.