onetime

WebJar for onetime

License

License

MIT
Categories

Categories

Net
GroupId

GroupId

org.webjars.npm
ArtifactId

ArtifactId

onetime
Last Version

Last Version

5.1.2
Release Date

Release Date

Type

Type

jar
Description

Description

onetime
WebJar for onetime
Project URL

Project URL

https://www.webjars.org
Source Code Management

Source Code Management

https://github.com/sindresorhus/onetime

Download onetime

How to add to project

<!-- https://jarcasting.com/artifacts/org.webjars.npm/onetime/ -->
<dependency>
    <groupId>org.webjars.npm</groupId>
    <artifactId>onetime</artifactId>
    <version>5.1.2</version>
</dependency>
// https://jarcasting.com/artifacts/org.webjars.npm/onetime/
implementation 'org.webjars.npm:onetime:5.1.2'
// https://jarcasting.com/artifacts/org.webjars.npm/onetime/
implementation ("org.webjars.npm:onetime:5.1.2")
'org.webjars.npm:onetime:jar:5.1.2'
<dependency org="org.webjars.npm" name="onetime" rev="5.1.2">
  <artifact name="onetime" type="jar" />
</dependency>
@Grapes(
@Grab(group='org.webjars.npm', module='onetime', version='5.1.2')
)
libraryDependencies += "org.webjars.npm" % "onetime" % "5.1.2"
[org.webjars.npm/onetime "5.1.2"]

Dependencies

compile (1)

Group / Artifact Type Version
org.webjars.npm : mimic-fn jar [2.1.0,3)

Project Modules

There are no modules declared in this project.

onetime Build Status

Ensure a function is only called once

When called multiple times it will return the return value from the first call.

Unlike the module once, this one isn't naughty and extending Function.prototype.

Install

$ npm install onetime

Usage

const onetime = require('onetime');

let i = 0;

const foo = onetime(() => ++i);

foo(); //=> 1
foo(); //=> 1
foo(); //=> 1

onetime.callCount(foo); //=> 3
const onetime = require('onetime');

const foo = onetime(() => {}, {throw: true});

foo();

foo();
//=> Error: Function `foo` can only be called once

API

onetime(fn, options?)

Returns a function that only calls fn once.

fn

Type: Function

Function that should only be called once.

options

Type: object

throw

Type: boolean
Default: false

Throw an error when called more than once.

onetime.callCount(fn)

Returns a number representing how many times fn has been called.

Note: It throws an error if you pass in a function that is not wrapped by onetime.

const onetime = require('onetime');

const foo = onetime(() => {});

foo();
foo();
foo();

console.log(onetime.callCount(foo));
//=> 3

fn

Type: Function

Function to get call count from.

onetime for enterprise

Available as part of the Tidelift Subscription.

The maintainers of onetime and thousands of other packages are working with Tidelift to deliver commercial support and maintenance for the open source dependencies you use to build your applications. Save time, reduce risk, and improve code health, while paying the maintainers of the exact dependencies you use. Learn more.

Versions

Version
5.1.2
5.1.0
2.0.1
2.0.0
1.1.0
1.0.0