Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/hipstersmoothie/compose-tiny

A very tiny and fast compose function.
https://github.com/hipstersmoothie/compose-tiny

Last synced: 2 months ago
JSON representation

A very tiny and fast compose function.

Awesome Lists containing this project

README

        



compose-tiny


A very tiny and fast compose function.


[![CircleCI](https://img.shields.io/circleci/project/github/hipstersmoothie/compose-tiny/master.svg?style=for-the-badge)](https://circleci.com/gh/hipstersmoothie/compose-tiny/tree/master) [![Codecov](https://img.shields.io/codecov/c/github/hipstersmoothie/compose-tiny.svg?style=for-the-badge)](https://codecov.io/gh/hipstersmoothie/compose-tiny) [![npm](https://img.shields.io/npm/v/compose-tiny.svg?style=for-the-badge)](https://www.npmjs.com/package/compose-tiny) [![bundle size](http://img.badgesize.io/hipstersmoothie/compose-tiny/master/index.js.svg?style=for-the-badge)](https://www.npmjs.com/package/compose-tiny) [![code style: prettier](https://img.shields.io/badge/code_style-prettier-ff69b4.svg?style=for-the-badge)](https://github.com/prettier/prettier)

> Function composition is an act or mechanism to combine simple functions to build more complicated ones.

`compose-tiny` aims to provide a simple function for composition at the smallest possible size and the fasted possible speed. It's TypeScript friendly too!

## Installation

```sh
npm install compose-tiny
```

## Usage

```js
const compose = require('compose-tiny');

const add = x => x + 2;
const sqr = x => x ** 2;

const blastOff = compose(
x => `🚀 ${x} 🚀`
sqr,
add
);

blastOff(2);
```

Output:

```sh
🚀 16 🚀
```

## Multiple Arguments

The first function in the composition can take multiple arguments.

```js
const compose = require('compose-tiny');

const add = x => x + 2;
const sqr = x => x ** 2;

const blastOff = compose(
sqr,
add,
(x, y, z) => (x + y) * z
);

blastOff(1, 2, 4);
```

## Performance

NOTE: bundlephobia measures all package files

| NAME | OPS/SEC | RELATIVE MARGIN OF ERROR | SAMPLE SIZE | BUNDLE SIZE |
| ---------------- | -------- | --------------------------------------------- | ----------- | ---------------------------------------------------------- |
| compose-tiny | 1108,413 | ± 0.72% | 187 | [112 B](https://bundlephobia.com/result?p=compose-tiny) |
| squad | 105,070 | ± 0.62% | 185 | [517 B](https://bundlephobia.com/result?p=squad) |
| just-compose | 46,964 | ± 1.88% | 181 | [334 B](https://bundlephobia.com/result?p=just-compose) |
| chain-function | 22,556 | ± 0.50% | 187 | [341 B](https://bundlephobia.com/result?p=chain-function) |
| compose-function | 20,817 | ± 0.49% | 186 | [1.2 kB](https://bundlephobia.com/result?p=compose-function) |
| fj-compose | 8,581 | ± 0.61% | 184 | [334 B](https://bundlephobia.com/result?p=fj-compose) |
| compose-funcs | 356 | ± 1.58% | 176 | [594 B](https://bundlephobia.com/result?p=compose-funcs) |

To rerun this benchmark

```sh
node benchmark
```