Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

function-composer

Package Overview
Dependencies
Maintainers
1
Versions
5
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

function-composer

Compose functions with multiple type signatures

  • 0.2.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
7
Maintainers
1
Weekly downloads
 
Created
Source

function-composer

Compose functions with multiple type signatures.

Features:

  • Compose multiple functions with different signatures into one.
  • Type-checking of input arguments.
  • Automatic type conversion of arguments.

Supported environments: node.js, Chrome, Firefox, Safari, Opera, IE9+.

Load

Install via npm:

npm install function-composer

Usage

Example usage:

var compose = require('function-composer');

// compose a new function
var fn = compose({
  'number': function (a) {
    return 'a is a number';
  },
  'number, boolean': function (a, b) {
    return 'a is a number, b is a boolean';
  },
  'number, number': function (a, b) {
    return 'a is a number, b is a number';
  }
});

// use the function
console.log(fn(2, true));      // outputs 'a is a number, b is a boolean'
console.log(fn(2));            // outputs 'a is a number'

// calling the function with a non-supported type signature will throw an error
try {
  fn('hello world');
}
catch (err) {
  console.log(err.toString()); // outputs: 'TypeError: Wrong function signature'
}

Performance

Type checking input arguments adds some overhead to a function. For very small functions this overhead can be larger than the function execution itself is, but for any non-trivial function the overhead is typically small to neglectable. You need to keep in mind though that you probably would have to do the type checking done by function-composer anyway.

API

Construction

compose(signatures: Object.<string, function>) : function
compose(name: string, signatures: Object.<string, function>) : function

Properties

  • compose.tests: Object
    A map with type checking tests. Add custom types like:

    function Person(...) {
      ...
    }
    
    compose.tests['Person'] = function (x) {
      return x instanceof Person;
    };
    
  • compose.conversions: Array
    An Array with built-in conversions. Empty by default. Can be used for example to defined conversions from boolean to number. For example:

    compose.conversions.push({
      from: 'boolean',
      to: 'number',
      convert: function (x) {
        return +x;
    });
    

Roadmap

Version 1

  • Extend function signatures:
    • Any type arguments like '*, boolean'
    • Ellipsis like 'string, ...'
    • Optional arguments like 'number?, array'
    • Multiple types per argument like number | string, number'
  • Create a good benchmark, to get insight in the overhead.

Version 2

  • Extend function signatures:
    • Constants like '"linear" | "cubic"'.
    • Object definitions like '{name: string, age: number}'
    • Object definitions like 'Object.<string, Person>'
    • Array definitions like 'Array.<Person>'

Minify

To generate the minified version of the library, run:

npm run minify

Keywords

FAQs

Package last updated on 23 Oct 2014

Did you know?

Socket

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
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc