All files / src deferred.ts

100% Statements 9/9
100% Branches 0/0
100% Functions 5/5
100% Lines 9/9

Press n or j to go to the next uncovered block, b, p or k for the previous block.

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                          7x 7x 7x   7x   3x 3x     2x 2x     4x                
/*!
 * Copyright (c) Microsoft. All rights reserved.
 * Licensed under the MIT license. See LICENSE file in the project.
 */
import type { Deferred } from './interfaces/Deferred.js'
/**
 * Represents a deferred object, which can be resolved
/*
 
/**
 * Creates a new deferred promise
 * @returns Promise
 */
export function deferred<T>(): Deferred<T> {
	let resolveFn: any
	let rejectFn: any
	const myPromise = new Promise<T>((resolve, reject) => {
		resolveFn = resolve
		rejectFn = reject
	})
 
	return {
		resolve(...args: any[]) {
			resolveFn.call(null, ...args)
			return myPromise
		},
		reject(...args: any[]) {
			rejectFn.call(null, ...args)
			return myPromise
		},
		get promise() {
			return myPromise
		},
	} as Deferred<T>
}