mirror of
https://github.com/Equicord/Equicord.git
synced 2025-06-10 15:13:02 -04:00
petpet
This commit is contained in:
parent
8e93c5cb43
commit
9b7ebe4680
2 changed files with 190 additions and 0 deletions
|
@ -129,3 +129,31 @@ export function classes(...classes: string[]) {
|
|||
export function sleep(ms: number): Promise<void> {
|
||||
return new Promise(r => setTimeout(r, ms));
|
||||
}
|
||||
|
||||
/**
|
||||
* Wraps a Function into a try catch block and logs any errors caught
|
||||
* Due to the nature of this function, not all paths return a result.
|
||||
* Thus, for consistency, the returned functions will always return void or Promise<void>
|
||||
*
|
||||
* @param name Name identifying the wrapped function. This will appear in the logged errors
|
||||
* @param func Function (async or sync both work)
|
||||
* @param thisObject Optional thisObject
|
||||
* @returns Wrapped Function
|
||||
*/
|
||||
export function suppressErrors<F extends Function>(name: string, func: F, thisObject?: any): F {
|
||||
return (func.constructor.name === "AsyncFunction"
|
||||
? async function (this: any) {
|
||||
try {
|
||||
await func.apply(thisObject ?? this, arguments);
|
||||
} catch (e) {
|
||||
console.error(`Caught an Error in ${name || "anonymous"}\n`, e);
|
||||
}
|
||||
}
|
||||
: function (this: any) {
|
||||
try {
|
||||
func.apply(thisObject ?? this, arguments);
|
||||
} catch (e) {
|
||||
console.error(`Caught an Error in ${name || "anonymous"}\n`, e);
|
||||
}
|
||||
}) as any as F;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue