aboutsummaryrefslogtreecommitdiff
path: root/src/utils
diff options
context:
space:
mode:
authorVendicated <vendicated@riseup.net>2022-09-28 22:49:46 +0200
committerVendicated <vendicated@riseup.net>2022-09-28 22:49:46 +0200
commit86c4bb7f8c34003168ac5380a01401fcbeac4013 (patch)
treea8c47a9004bd92261e81ed046d31137d99afaca7 /src/utils
parent0677df781840461f9a0b11ed08a2c9f72a521c84 (diff)
downloadVencord-86c4bb7f8c34003168ac5380a01401fcbeac4013.tar.gz
Vencord-86c4bb7f8c34003168ac5380a01401fcbeac4013.tar.bz2
Vencord-86c4bb7f8c34003168ac5380a01401fcbeac4013.zip
Improve webpack performance (~ 80ms -> 15ms)
Diffstat (limited to 'src/utils')
-rw-r--r--src/utils/patchWebpack.ts25
1 files changed, 22 insertions, 3 deletions
diff --git a/src/utils/patchWebpack.ts b/src/utils/patchWebpack.ts
index ce29c82..0508968 100644
--- a/src/utils/patchWebpack.ts
+++ b/src/utils/patchWebpack.ts
@@ -53,6 +53,18 @@ function patchPush() {
return originalMod(module, exports, require);
}
+ // There are (at the time of writing) 11 modules exporting the window
+ // Make these non enumerable to improve webpack search performance
+ if (module.exports === window) {
+ Object.defineProperty(require.c, id, {
+ value: require.c[id],
+ enumerable: false,
+ configurable: true,
+ writable: true
+ });
+ return;
+ }
+
for (const callback of listeners) {
try {
callback(exports);
@@ -65,10 +77,17 @@ function patchPush() {
if (filter(exports)) {
subscriptions.delete(filter);
callback(exports);
- } else for (const nested in exports) {
- if (exports[nested] && filter(exports[nested])) {
+ } else if (typeof exports === "object") {
+ if (exports.default && filter(exports.default)) {
subscriptions.delete(filter);
- callback(exports[nested]);
+ callback(exports.default);
+ }
+
+ for (const nested in exports) if (nested.length < 3) {
+ if (exports[nested] && filter(exports[nested])) {
+ subscriptions.delete(filter);
+ callback(exports[nested]);
+ }
}
}
} catch (err) {