保誠-保戶業務員媒合平台
HelenHuang
2022-06-09 9bdb95c9e34cef640534e5e5a1e2225a80442000
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
declare namespace onetime {
    interface Options {
        /**
        Throw an error when called more than once.
 
        @default false
        */
        throw?: boolean;
    }
}
 
declare const onetime: {
    /**
    Ensure a function is only called once. When called multiple times it will return the return value from the first call.
 
    @param fn - Function that should only be called once.
    @returns A function that only calls `fn` once.
 
    @example
    ```
    import onetime = require('onetime');
 
    let i = 0;
 
    const foo = onetime(() => ++i);
 
    foo(); //=> 1
    foo(); //=> 1
    foo(); //=> 1
 
    onetime.callCount(foo); //=> 3
    ```
    */
    <ArgumentsType extends unknown[], ReturnType>(
        fn: (...arguments: ArgumentsType) => ReturnType,
        options?: onetime.Options
    ): (...arguments: ArgumentsType) => ReturnType;
 
    /**
    Get the number of times `fn` has been called.
 
    @param fn - Function to get call count from.
    @returns A number representing how many times `fn` has been called.
 
    @example
    ```
    import onetime = require('onetime');
 
    const foo = onetime(() => {});
    foo();
    foo();
    foo();
 
    console.log(onetime.callCount(foo));
    //=> 3
    ```
    */
    callCount(fn: (...arguments: any[]) => unknown): number;
 
    // TODO: Remove this for the next major release
    default: typeof onetime;
};
 
export = onetime;