babel-plugin-curry-all v2.0.2
babel-plugin-curry-all
This plugin transform all your normal functions to curried functions so they are easily composable because each function only takes one argument. This requires functional programming knowledge and being familiar with currying, how to use it on javascript and how to call actually curried functions.
Please note that functions are actually curried, not magically curried. 
This means that, if you are familiar with functions curried Ramda style this ones are not of that kind. This is more in line with sanctuary
Curried functions are invoked this way:
sum (1) (2)If you find calling curried functions awkward you may be interested on my other
babel plugin, all-curried which transforms all function calls to calls to curried functions.
Example
In
function sum3(a,b,c){
  return a + b + c
}Out
"use strict";
function sum3(a){
  return b => c => {
    return a + b + c
  }
}Installation
$ npm install babel-plugin-curry-allUsage
Via .babelrc (Recommended)
.babelrc
{
  "plugins": ["curry-all"]
}Via CLI
$ babel --plugins curry-all script.jsVia Node API
require("babel-core").transform("code", {
  plugins: ["curry-all"]
});Dev comments
This plugin is built using livescript, so you need to
understand it if you want to contribute to the source code.
Test are also on livescript, but they are directly executed by the livescript interpreter. There is a build:test npm command to compile them down to javascript if you need to review the generated code.