parent
f3b3ccb79d
commit
11c20db477
|
@ -2,7 +2,7 @@
|
|||
* @name BDFDB
|
||||
* @author DevilBro
|
||||
* @authorId 278543574059057154
|
||||
* @version 3.4.2
|
||||
* @version 3.4.1
|
||||
* @description Required Library for DevilBro's Plugins
|
||||
* @invite Jx3TjNS
|
||||
* @donate https://www.paypal.me/MircoWittrien
|
||||
|
@ -2258,54 +2258,52 @@ module.exports = (_ => {
|
|||
if (!module[methodName]) module[methodName] = _ => {return null};
|
||||
let patches = module[methodName].BDFDB_Patches || {};
|
||||
for (let type in patchMethods) {
|
||||
const internalData = (Object.entries(InternalData.LibraryModules).find(n => n && n[0] && LibraryModules[n[0]] == module && n[1] && n[1]._originalModule && n[1]._mappedItems[methodName]) || [])[1];
|
||||
const name = internalData && internalData[0] || config.name || (module.constructor ? (module.constructor.displayName || module.constructor.name) : "module");
|
||||
try {
|
||||
if (!patches[type]) {
|
||||
const originalMethod = module[methodName].__originalFunction || module[methodName];
|
||||
const mainCancel = BdApi.Patcher[type](Internal.name, internalData && internalData._originalModule || module, internalData && internalData._mappedItems[methodName] || methodName, function(...args) {
|
||||
let callInsteadAfterwards = false, stopInsteadCall = false;
|
||||
const data = {
|
||||
component: module,
|
||||
methodArguments: args[1],
|
||||
returnValue: args[2],
|
||||
originalMethod: originalMethod,
|
||||
originalMethodName: methodName
|
||||
};
|
||||
if (type == "instead") {
|
||||
data.callOriginalMethod = _ => data.returnValue = data.originalMethod.apply(this && this !== window ? this : {}, data.methodArguments);
|
||||
data.callOriginalMethodAfterwards = _ => (callInsteadAfterwards = true, data.returnValue);
|
||||
data.stopOriginalMethodCall = _ => stopInsteadCall = true;
|
||||
}
|
||||
if (args[0] != module) data.instance = args[0] || {props: args[1][0]};
|
||||
for (let priority in patches[type].plugins) for (let id in BDFDB.ObjectUtils.sort(patches[type].plugins[priority])) {
|
||||
let tempReturn = BDFDB.TimeUtils.suppress(patches[type].plugins[priority][id], `"${type}" callback of ${methodName} in ${name}`, {name: patches[type].plugins[priority][id].pluginName, version: patches[type].plugins[priority][id].pluginVersion})(data);
|
||||
if (type != "before" && tempReturn !== undefined) data.returnValue = tempReturn;
|
||||
}
|
||||
if (type == "instead" && callInsteadAfterwards && !stopInsteadCall) BDFDB.TimeUtils.suppress(data.callOriginalMethod, `originalMethod of ${methodName} in ${name}`, {name: "Discord"})();
|
||||
|
||||
if (type != "before") return (methodName == "render" || methodName == "type") && data.returnValue === undefined ? null : data.returnValue;
|
||||
});
|
||||
module[methodName].BDFDB_Patches = patches;
|
||||
patches[type] = {plugins: {}, cancel: _ => {
|
||||
if (!config.noCache) BDFDB.ArrayUtils.remove(Internal.patchCancels, patches[type].cancel, true);
|
||||
delete patches[type];
|
||||
if (!config.noCache && BDFDB.ObjectUtils.isEmpty(patches)) delete module[methodName].BDFDB_Patches;
|
||||
mainCancel();
|
||||
}};
|
||||
if (!config.noCache) {
|
||||
if (!BDFDB.ArrayUtils.is(Internal.patchCancels)) Internal.patchCancels = [];
|
||||
Internal.patchCancels.push(patches[type].cancel);
|
||||
if (!patches[type]) {
|
||||
const originalMethod = module[methodName].__originalFunction || module[methodName];
|
||||
const internalData = (Object.entries(InternalData.LibraryModules).find(n => n && n[0] && LibraryModules[n[0]] == module && n[1] && n[1]._originalModule && n[1]._mappedItems[methodName]) || [])[1];
|
||||
const name = internalData && internalData[0] || config.name || (module.constructor ? (module.constructor.displayName || module.constructor.name) : "module");
|
||||
const mainCancel = BdApi.Patcher[type](Internal.name, internalData && internalData._originalModule || module, internalData && internalData._mappedItems[methodName] || methodName, function(...args) {
|
||||
let callInsteadAfterwards = false, stopInsteadCall = false;
|
||||
const data = {
|
||||
component: module,
|
||||
methodArguments: args[1],
|
||||
returnValue: args[2],
|
||||
originalMethod: originalMethod,
|
||||
originalMethodName: methodName
|
||||
};
|
||||
if (type == "instead") {
|
||||
data.callOriginalMethod = _ => data.returnValue = data.originalMethod.apply(this && this !== window ? this : {}, data.methodArguments);
|
||||
data.callOriginalMethodAfterwards = _ => (callInsteadAfterwards = true, data.returnValue);
|
||||
data.stopOriginalMethodCall = _ => stopInsteadCall = true;
|
||||
}
|
||||
if (args[0] != module) data.instance = args[0] || {props: args[1][0]};
|
||||
for (let priority in patches[type].plugins) for (let id in BDFDB.ObjectUtils.sort(patches[type].plugins[priority])) {
|
||||
let tempReturn = BDFDB.TimeUtils.suppress(patches[type].plugins[priority][id], `"${type}" callback of ${methodName} in ${name}`, {name: patches[type].plugins[priority][id].pluginName, version: patches[type].plugins[priority][id].pluginVersion})(data);
|
||||
if (type != "before" && tempReturn !== undefined) data.returnValue = tempReturn;
|
||||
}
|
||||
if (type == "instead" && callInsteadAfterwards && !stopInsteadCall) BDFDB.TimeUtils.suppress(data.callOriginalMethod, `originalMethod of ${methodName} in ${name}`, {name: "Discord"})();
|
||||
|
||||
if (type != "before") return (methodName == "render" || methodName == "type") && data.returnValue === undefined ? null : data.returnValue;
|
||||
});
|
||||
module[methodName].BDFDB_Patches = patches;
|
||||
patches[type] = {plugins: {}, cancel: _ => {
|
||||
if (!config.noCache) BDFDB.ArrayUtils.remove(Internal.patchCancels, patches[type].cancel, true);
|
||||
delete patches[type];
|
||||
if (!config.noCache && BDFDB.ObjectUtils.isEmpty(patches)) delete module[methodName].BDFDB_Patches;
|
||||
mainCancel();
|
||||
}};
|
||||
if (!config.noCache) {
|
||||
if (!BDFDB.ArrayUtils.is(Internal.patchCancels)) Internal.patchCancels = [];
|
||||
Internal.patchCancels.push(patches[type].cancel);
|
||||
}
|
||||
if (!patches[type].plugins[patchPriority]) patches[type].plugins[patchPriority] = {};
|
||||
patches[type].plugins[patchPriority][pluginId] = (...args) => {
|
||||
if (config.once || !plugin.started) cancel();
|
||||
return patchMethods[type](...args);
|
||||
};
|
||||
patches[type].plugins[patchPriority][pluginId].pluginName = pluginName;
|
||||
patches[type].plugins[patchPriority][pluginId].pluginVersion = pluginVersion;
|
||||
} catch (err) {BDFDB.LogUtils.error(["Could not patch Component!", `"${type}" Patch of ${methodName} in ${name}`, err], plugin);}
|
||||
}
|
||||
if (!patches[type].plugins[patchPriority]) patches[type].plugins[patchPriority] = {};
|
||||
patches[type].plugins[patchPriority][pluginId] = (...args) => {
|
||||
if (config.once || !plugin.started) cancel();
|
||||
return patchMethods[type](...args);
|
||||
};
|
||||
patches[type].plugins[patchPriority][pluginId].pluginName = pluginName;
|
||||
patches[type].plugins[patchPriority][pluginId].pluginVersion = pluginVersion;
|
||||
}
|
||||
}
|
||||
if (BDFDB.ObjectUtils.is(plugin) && !config.once && !config.noCache) {
|
||||
|
|
Loading…
Reference in New Issue