Socket
Socket
Sign inDemoInstall

fp.macro

Package Overview
Dependencies
47
Maintainers
1
Versions
20
Alerts
File Explorer

Advanced tools

Install Socket

Detect and block malicious and high-risk dependencies

Install

    fp.macro

A zero-runtime functional programming babel macro.


Version published
Weekly downloads
26
increased by73.33%
Maintainers
1
Created
Weekly downloads
 

Changelog

Source

2.0.9 (2022-01-13)

Bug Fixes

  • lock file maintenance (#54) (77d1706)

Readme

Source

fp.macro

npm version Linux macOS Windows compatible Build status Coverage status Dependency status Renovate enabled
Open in Gitpod Buy Me a Coffee PayPal Patreon

A zero-runtime functional programming babel macro.

fp.macro This is a build-time functional programming library that allows you to use high-level collection functions without a production dependency and without the runtime penalty that you have when using a dedicated library.

It does so by exposing a Babel macro that is evaluated at build time by babel-plugin-macros. So in the end you do not have a production dependency anymore, it's all in the generated Babel code.

Install

# npm
$ npm install fp.macro

# Yarn
$ yarn add fp.macro

Usage

Install babel-plugin-macros:

$ npm install babel-plugin-macros

The plugin is best used with the Babel pipeline operator, so optionally install this one as well:

$ npm install @babel/plugin-proposal-pipeline-operator

Then add the plugins to your babel config or create a .babelrc.json file:

{
  "plugins": [
    "babel-plugin-macros",
    ["@babel/plugin-proposal-pipeline-operator", { "proposal": "fsharp" }]
  ]
}

Create a JavaScript file and start mapping collections:

import { filter, join, map, mapValues } from 'fp.macro'

const myMap = map(x => x * 2)

console.log(myMap([1, 2]))
// [2, 4]

// Using pipeline operator
console.log(
  [1, 2, 3]
    |> map(x => x * 2)
    |> filter(x => x > 2)
    |> join(',')
)
// 4,6

console.log(
  { foo: { name: 'foo' }, bar: { name: 'bar' } }
    |> mapValues(x => x.name)
)
// { foo: 'foo', bar: 'bar' }

To run the files, you need to use Babel. You can either compile them using @babel/cli, or run them directly via @babel/node (which is not recommended for production though).

The library is currently in development, so for more insights into the available functions check out the source code.

Contribute

Are you missing something or want to contribute? Feel free to file an issue or a pull request! ⚙️

Support

Hey, I am Sebastian Landwehr, a freelance web developer, and I love developing web apps and open source packages. If you want to support me so that I can keep packages up to date and build more helpful tools, you can donate here:

Buy Me a Coffee  If you want to send me a one time donation. The coffee is pretty good 😊.
PayPal  Also for one time donations if you like PayPal.
Patreon  Here you can support me regularly, which is great so I can steadily work on projects.

Thanks a lot for your support! ❤️

License

MIT License © Sebastian Landwehr

Keywords

FAQs

Last updated on 13 Jan 2022

Did you know?

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc