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.3.0
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
0
decreased by-100%
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

A function is constructed as:

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

Properties

  • compose.types: Object A map with the object types as key and a type checking test as value. Custom types can be added like:

    function Person(...) {
      ...
    }
    
    compose.types['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;
    });
    

Types

function-composer has the following built-in types:

  • null
  • boolean
  • number
  • string
  • function
  • Array
  • Date
  • RegExp
  • Object
  • * (anytype)

Output

The functions generated with compose({...}) have:

  • A toString() function which returns well readable code, giving insight in what the function exactly does.
  • A property signatures, which holds a map with the (normalized) signatures as key and the original sub-functions as value.

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'
  • Detailed error messages.
  • Create a good benchmark, to get insight in the overhead.
  • Allow conversions not to be able to convert any input (for example string to number is not always possible).

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>'

Test

To test the library, run:

npm test

Minify

To generate the minified version of the library, run:

npm run minify

Keywords

FAQs

Package last updated on 05 Nov 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