diff options
author | Sebastian <sebasjm@gmail.com> | 2024-02-12 15:54:49 -0300 |
---|---|---|
committer | Sebastian <sebasjm@gmail.com> | 2024-02-12 16:05:51 -0300 |
commit | 86194c61457f2e2e534cd05071bde9633e205ad3 (patch) | |
tree | 2eb7794af5b6575680a259fb066bc698d7a71ed0 /packages/taler-wallet-core/src/util/promiseUtils.ts | |
parent | 975a087956c8c392801515db4b6809a368b83e20 (diff) | |
download | wallet-core-86194c61457f2e2e534cd05071bde9633e205ad3.tar.gz wallet-core-86194c61457f2e2e534cd05071bde9633e205ad3.tar.bz2 wallet-core-86194c61457f2e2e534cd05071bde9633e205ad3.zip |
add more info when wallet-core is not available
Diffstat (limited to 'packages/taler-wallet-core/src/util/promiseUtils.ts')
-rw-r--r-- | packages/taler-wallet-core/src/util/promiseUtils.ts | 17 |
1 files changed, 12 insertions, 5 deletions
diff --git a/packages/taler-wallet-core/src/util/promiseUtils.ts b/packages/taler-wallet-core/src/util/promiseUtils.ts index df4cc343b..d152a12f4 100644 --- a/packages/taler-wallet-core/src/util/promiseUtils.ts +++ b/packages/taler-wallet-core/src/util/promiseUtils.ts @@ -23,6 +23,7 @@ export interface OpenedPromise<T> { promise: Promise<T>; resolve: (val: T) => void; reject: (err: any) => void; + lastError?: any; } /** @@ -33,16 +34,22 @@ export interface OpenedPromise<T> { */ export function openPromise<T>(): OpenedPromise<T> { let resolve: ((x?: any) => void) | null = null; - let reject: ((reason?: any) => void) | null = null; + let promiseReject: ((reason?: any) => void) | null = null; const promise = new Promise<T>((res, rej) => { resolve = res; - reject = rej; + promiseReject = rej; }); - if (!(resolve && reject)) { + if (!(resolve && promiseReject)) { // Never happens, unless JS implementation is broken - throw Error(); + throw Error("JS implementation is broken"); } - return { resolve, reject, promise }; + const result: OpenedPromise<T> = { resolve, reject: promiseReject, promise }; + function saveLastError(reason?: any) { + result.lastError = reason; + promiseReject!(reason); + } + result.reject = saveLastError; + return result; } export class AsyncCondition { |