From daa1a35fc3a658c2e5bc49174e6ea73f6361c6ed Mon Sep 17 00:00:00 2001 From: Nuckyz <61953774+Nuckyz@users.noreply.github.com> Date: Fri, 24 May 2024 08:23:41 -0300 Subject: [PATCH] Factories are called with a `this` --- src/webpack/patchWebpack.ts | 8 ++++---- src/webpack/wreq.d.ts | 2 +- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/src/webpack/patchWebpack.ts b/src/webpack/patchWebpack.ts index 7aaa4e329..075a5a624 100644 --- a/src/webpack/patchWebpack.ts +++ b/src/webpack/patchWebpack.ts @@ -281,7 +281,7 @@ function patchFactory(id: PropertyKey, factory: ModuleFactory) { if (!patch.all) patches.splice(i--, 1); } - const patchedFactory: PatchedModuleFactory = (module, exports, require) => { + const patchedFactory: PatchedModuleFactory = function (module, exports, require) { for (const moduleFactories of allModuleFactories) { Object.defineProperty(moduleFactories, id, { value: patchedFactory.$$vencordOriginal, @@ -297,17 +297,17 @@ function patchFactory(id: PropertyKey, factory: ModuleFactory) { logger.error("WebpackRequire was not initialized, running modules without patches instead."); } - return void originalFactory(module, exports, require); + return void originalFactory.call(this, module, exports, require); } try { - factory(module, exports, require); + factory.call(this, module, exports, require); } catch (err) { // Just rethrow Discord errors if (factory === originalFactory) throw err; logger.error("Error in patched module", err); - return void originalFactory(module, exports, require); + return void originalFactory.call(this, module, exports, require); } // Webpack sometimes sets the value of module.exports directly, so assign exports to it to make sure we properly handle it diff --git a/src/webpack/wreq.d.ts b/src/webpack/wreq.d.ts index c86fa1c49..c810c5a56 100644 --- a/src/webpack/wreq.d.ts +++ b/src/webpack/wreq.d.ts @@ -13,7 +13,7 @@ export type Module = { }; /** exports can be anything, however initially it is always an empty object */ -export type ModuleFactory = (module: Module, exports: ModuleExports, require: WebpackRequire) => void; +export type ModuleFactory = (this: ModuleExports, module: Module, exports: ModuleExports, require: WebpackRequire) => void; export type AsyncModuleBody = ( handleDependencies: (deps: Promise[]) => Promise & (() => void)