Skip to content

sindresorhus/mimic-function

Folders and files

NameName
Last commit message
Last commit date

Latest commit

3ee1e62 Â· Oct 28, 2024

History

51 Commits
Oct 28, 2024
Jul 22, 2022
Feb 2, 2018
Aug 27, 2018
Feb 2, 2018
Feb 2, 2018
Nov 5, 2023
May 4, 2024
Apr 7, 2021
Apr 7, 2021
May 4, 2024
Nov 5, 2023
May 4, 2024

Repository files navigation

mimic-function logo

Make a function mimic another one

Useful when you wrap a function in another function and you would like to preserve the original name and other properties.

Install

npm install mimic-function

Usage

import mimicFunction from 'mimic-function';

function foo() {}
foo.unicorn = '🦄';

function wrapper() {
	return foo();
}

console.log(wrapper.name);
//=> 'wrapper'

mimicFunction(wrapper, foo);

console.log(wrapper.name);
//=> 'foo'

console.log(wrapper.unicorn);
//=> '🦄'

console.log(String(wrapper));
//=> '/* Wrapped with wrapper() */\nfunction foo() {}'

API

mimicFunction(to, from, options?)

Modifies the to function to mimic the from function. Returns the to function.

name, displayName, and any other properties of from are copied. The length property is not copied. Prototype, class, and inherited properties are copied.

to.toString() will return the same as from.toString() but prepended with a Wrapped with to() comment.

to

Type: Function

Mimicking function.

from

Type: Function

Function to mimic.

options

Type: object

ignoreNonConfigurable

Type: boolean
Default: false

Skip modifying non-configurable properties instead of throwing an error.

Related