mirror of
https://github.com/Vendicated/Vencord.git
synced 2025-01-26 17:26:22 +00:00
Test mapMangledModule with new api
This commit is contained in:
parent
f6dbcb7709
commit
e93562b95b
9 changed files with 49 additions and 23 deletions
|
@ -65,7 +65,7 @@ export function getUserSettingDefinition<T = any>(group: string, name: string):
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@link getUserSettingDefinition}, lazy.
|
* Lazy version of {@link getUserSettingDefinition}
|
||||||
*
|
*
|
||||||
* Get the definition for a setting.
|
* Get the definition for a setting.
|
||||||
*
|
*
|
||||||
|
|
|
@ -56,7 +56,7 @@ function ReplacementComponent({ module, match, replacement, setReplacementError
|
||||||
const [compileResult, setCompileResult] = React.useState<[boolean, string]>();
|
const [compileResult, setCompileResult] = React.useState<[boolean, string]>();
|
||||||
|
|
||||||
const [patchedCode, matchResult, diff] = React.useMemo(() => {
|
const [patchedCode, matchResult, diff] = React.useMemo(() => {
|
||||||
const src: string = fact.toString().replaceAll("\n", "");
|
const src = String(fact).replaceAll("\n", "");
|
||||||
|
|
||||||
try {
|
try {
|
||||||
new RegExp(match);
|
new RegExp(match);
|
||||||
|
|
|
@ -111,14 +111,14 @@ export async function loadLazyChunks() {
|
||||||
|
|
||||||
Webpack.factoryListeners.add(factory => {
|
Webpack.factoryListeners.add(factory => {
|
||||||
let isResolved = false;
|
let isResolved = false;
|
||||||
searchAndLoadLazyChunks(factory.toString()).then(() => isResolved = true);
|
searchAndLoadLazyChunks(String(factory)).then(() => isResolved = true);
|
||||||
|
|
||||||
chunksSearchPromises.push(() => isResolved);
|
chunksSearchPromises.push(() => isResolved);
|
||||||
});
|
});
|
||||||
|
|
||||||
for (const factoryId in wreq.m) {
|
for (const factoryId in wreq.m) {
|
||||||
let isResolved = false;
|
let isResolved = false;
|
||||||
searchAndLoadLazyChunks(wreq.m[factoryId].toString()).then(() => isResolved = true);
|
searchAndLoadLazyChunks(String(wreq.m[factoryId])).then(() => isResolved = true);
|
||||||
|
|
||||||
chunksSearchPromises.push(() => isResolved);
|
chunksSearchPromises.push(() => isResolved);
|
||||||
}
|
}
|
||||||
|
|
|
@ -33,10 +33,8 @@ async function runReporter() {
|
||||||
await Promise.all(Webpack.webpackSearchHistory.map(async ([searchType, args]) => {
|
await Promise.all(Webpack.webpackSearchHistory.map(async ([searchType, args]) => {
|
||||||
args = [...args];
|
args = [...args];
|
||||||
|
|
||||||
let result: any;
|
let result = null as any;
|
||||||
try {
|
try {
|
||||||
let result = null as any;
|
|
||||||
|
|
||||||
switch (searchType) {
|
switch (searchType) {
|
||||||
case "webpackDependantLazy":
|
case "webpackDependantLazy":
|
||||||
case "webpackDependantLazyComponent": {
|
case "webpackDependantLazyComponent": {
|
||||||
|
@ -45,13 +43,12 @@ async function runReporter() {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case "extractAndLoadChunks": {
|
case "extractAndLoadChunks": {
|
||||||
const [code, matcher] = args;
|
const extractAndLoadChunks = args.shift();
|
||||||
result = true;
|
|
||||||
|
|
||||||
/* result = await Webpack.extractAndLoadChunks(code, matcher);
|
result = await extractAndLoadChunks();
|
||||||
if (result === false) {
|
if (result === false) {
|
||||||
result = null;
|
result = null;
|
||||||
} */
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -65,6 +62,14 @@ async function runReporter() {
|
||||||
|
|
||||||
if (findResult[SYM_PROXY_INNER_GET] != null) {
|
if (findResult[SYM_PROXY_INNER_GET] != null) {
|
||||||
result = findResult[SYM_PROXY_INNER_VALUE];
|
result = findResult[SYM_PROXY_INNER_VALUE];
|
||||||
|
|
||||||
|
if (result != null && searchType === "mapMangledModule") {
|
||||||
|
for (const innerMap in result) {
|
||||||
|
if (result[innerMap][SYM_PROXY_INNER_GET] != null) {
|
||||||
|
throw new Error("Webpack Find Fail");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (findResult[SYM_LAZY_COMPONENT_INNER] != null) {
|
if (findResult[SYM_LAZY_COMPONENT_INNER] != null) {
|
||||||
|
@ -77,7 +82,7 @@ async function runReporter() {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (result == null) {
|
if (result == null) {
|
||||||
throw "a rock at ben shapiro";
|
throw new Error("Webpack Find Fail");
|
||||||
}
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
let logMessage = searchType;
|
let logMessage = searchType;
|
||||||
|
@ -99,23 +104,44 @@ async function runReporter() {
|
||||||
parsedArgs === args &&
|
parsedArgs === args &&
|
||||||
["waitFor", "find", "findComponent", "webpackDependantLazy", "webpackDependantLazyComponent"].includes(searchType)
|
["waitFor", "find", "findComponent", "webpackDependantLazy", "webpackDependantLazyComponent"].includes(searchType)
|
||||||
) {
|
) {
|
||||||
let filter = parsedArgs[0].toString();
|
let filter = String(parsedArgs[0]);
|
||||||
if (filter.length > 150) {
|
if (filter.length > 150) {
|
||||||
filter = filter.slice(0, 147) + "...";
|
filter = filter.slice(0, 147) + "...";
|
||||||
}
|
}
|
||||||
|
|
||||||
logMessage += `(${filter})`;
|
logMessage += `(${filter})`;
|
||||||
} else if (searchType === "extractAndLoadChunks") {
|
} else if (searchType === "extractAndLoadChunks") {
|
||||||
|
const [code, matcher] = parsedArgs;
|
||||||
|
|
||||||
let regexStr: string;
|
let regexStr: string;
|
||||||
if (parsedArgs[1] === Webpack.DefaultExtractAndLoadChunksRegex) {
|
if (matcher === Webpack.DefaultExtractAndLoadChunksRegex) {
|
||||||
regexStr = "DefaultExtractAndLoadChunksRegex";
|
regexStr = "DefaultExtractAndLoadChunksRegex";
|
||||||
} else {
|
} else {
|
||||||
regexStr = parsedArgs[1].toString();
|
regexStr = String(matcher);
|
||||||
}
|
}
|
||||||
|
|
||||||
logMessage += `([${parsedArgs[0].map((arg: any) => `"${arg}"`).join(", ")}], ${regexStr})`;
|
logMessage += `(${JSON.stringify(code)}, ${regexStr})`;
|
||||||
|
} else if (searchType === "mapMangledModule") {
|
||||||
|
const [code, mappers] = parsedArgs;
|
||||||
|
|
||||||
|
const parsedFailedMappers = Object.entries<any>(mappers)
|
||||||
|
.filter(([key]) => result == null || result[key][SYM_PROXY_INNER_GET] != null)
|
||||||
|
.map(([key, filter]) => {
|
||||||
|
let parsedFilter: string;
|
||||||
|
|
||||||
|
if (filter.$$vencordProps != null) {
|
||||||
|
const filterName = filter.$$vencordProps[0];
|
||||||
|
parsedFilter = `${filterName}(${filter.$$vencordProps.slice(1).map((arg: any) => JSON.stringify(arg)).join(", ")})`;
|
||||||
|
} else {
|
||||||
|
parsedFilter = String(filter).slice(0, 147) + "...";
|
||||||
|
}
|
||||||
|
|
||||||
|
return [key, parsedFilter];
|
||||||
|
});
|
||||||
|
|
||||||
|
logMessage += `(${JSON.stringify(code)}, {\n${parsedFailedMappers.map(([key, parsedFilter]) => `\t${key}: ${parsedFilter}`).join(",\n")}\n})`;
|
||||||
} else {
|
} else {
|
||||||
logMessage += `(${filterName.length ? `${filterName}(` : ""}${parsedArgs.map(arg => `"${arg}"`).join(", ")})${filterName.length ? ")" : ""}`;
|
logMessage += `(${filterName.length ? `${filterName}(` : ""}${parsedArgs.map(arg => JSON.stringify(arg)).join(", ")})${filterName.length ? ")" : ""}`;
|
||||||
}
|
}
|
||||||
|
|
||||||
ReporterLogger.log("Webpack Find Fail:", logMessage);
|
ReporterLogger.log("Webpack Find Fail:", logMessage);
|
||||||
|
|
|
@ -10,5 +10,5 @@ import { extractAndLoadChunksLazy, findByProps } from "@webpack";
|
||||||
export const cl = classNameFactory("vc-decor-");
|
export const cl = classNameFactory("vc-decor-");
|
||||||
export const DecorationModalStyles = findByProps("modalFooterShopButton");
|
export const DecorationModalStyles = findByProps("modalFooterShopButton");
|
||||||
|
|
||||||
export const requireAvatarDecorationModal = extractAndLoadChunksLazy([".COLLECTIBLES_SHOP_FULLSCREEN&&"]);
|
export const requireAvatarDecorationModal = extractAndLoadChunksLazy(".COLLECTIBLES_SHOP_FULLSCREEN&&");
|
||||||
export const requireCreateStickerModal = extractAndLoadChunksLazy(["stickerInspected]:"]);
|
export const requireCreateStickerModal = extractAndLoadChunksLazy("stickerInspected]:");
|
||||||
|
|
|
@ -160,7 +160,7 @@ function initWs(isManual = false) {
|
||||||
return reply("Expected exactly one 'find' matches, found " + keys.length);
|
return reply("Expected exactly one 'find' matches, found " + keys.length);
|
||||||
|
|
||||||
const mod = candidates[keys[0]];
|
const mod = candidates[keys[0]];
|
||||||
let src = String(mod.original ?? mod).replaceAll("\n", "");
|
let src = String(mod).replaceAll("\n", "");
|
||||||
|
|
||||||
if (src.startsWith("function(")) {
|
if (src.startsWith("function(")) {
|
||||||
src = "0," + src;
|
src = "0," + src;
|
||||||
|
|
|
@ -111,7 +111,7 @@ interface ProfileModalProps {
|
||||||
const ColorPicker = findComponentByCode<ColorPickerProps>(".Messages.USER_SETTINGS_PROFILE_COLOR_SELECT_COLOR", ".BACKGROUND_PRIMARY)");
|
const ColorPicker = findComponentByCode<ColorPickerProps>(".Messages.USER_SETTINGS_PROFILE_COLOR_SELECT_COLOR", ".BACKGROUND_PRIMARY)");
|
||||||
const ProfileModal = findComponentByCode<ProfileModalProps>('"ProfileCustomizationPreview"');
|
const ProfileModal = findComponentByCode<ProfileModalProps>('"ProfileCustomizationPreview"');
|
||||||
|
|
||||||
const requireColorPicker = extractAndLoadChunksLazy(["USER_SETTINGS_PROFILE_COLOR_DEFAULT_BUTTON.format"], /createPromise:\(\)=>\i\.\i\("?(.+?)"?\).then\(\i\.bind\(\i,"?(.+?)"?\)\)/);
|
const requireColorPicker = extractAndLoadChunksLazy("USER_SETTINGS_PROFILE_COLOR_DEFAULT_BUTTON.format", /createPromise:\(\)=>\i\.\i\("?(.+?)"?\).then\(\i\.bind\(\i,"?(.+?)"?\)\)/);
|
||||||
|
|
||||||
export default definePlugin({
|
export default definePlugin({
|
||||||
name: "FakeProfileThemes",
|
name: "FakeProfileThemes",
|
||||||
|
|
|
@ -33,7 +33,7 @@ interface ColorPickerWithSwatchesProps {
|
||||||
const ColorPicker = findComponentByCode<ColorPickerProps>(".Messages.USER_SETTINGS_PROFILE_COLOR_SELECT_COLOR", ".BACKGROUND_PRIMARY)");
|
const ColorPicker = findComponentByCode<ColorPickerProps>(".Messages.USER_SETTINGS_PROFILE_COLOR_SELECT_COLOR", ".BACKGROUND_PRIMARY)");
|
||||||
const ColorPickerWithSwatches = findExportedComponent<ColorPickerWithSwatchesProps>("ColorPicker", "CustomColorPicker");
|
const ColorPickerWithSwatches = findExportedComponent<ColorPickerWithSwatchesProps>("ColorPicker", "CustomColorPicker");
|
||||||
|
|
||||||
export const requireSettingsMenu = extractAndLoadChunksLazy(['name:"UserSettings"'], /createPromise:.{0,20}Promise\.all\((\[\i\.\i\("?.+?"?\).+?\])\).then\(\i\.bind\(\i,"?(.+?)"?\)\).{0,50}"UserSettings"/);
|
export const requireSettingsMenu = extractAndLoadChunksLazy('name:"UserSettings"', /createPromise:.{0,20}Promise\.all\((\[\i\.\i\("?.+?"?\).+?\])\).then\(\i\.bind\(\i,"?(.+?)"?\)\).{0,50}"UserSettings"/);
|
||||||
|
|
||||||
const cl = classNameFactory("vc-pindms-modal-");
|
const cl = classNameFactory("vc-pindms-modal-");
|
||||||
|
|
||||||
|
|
|
@ -782,7 +782,7 @@ export function extractAndLoadChunksLazy(code: string | string[], matcher: RegEx
|
||||||
});
|
});
|
||||||
|
|
||||||
if (IS_REPORTER) {
|
if (IS_REPORTER) {
|
||||||
webpackSearchHistory.push(["extractAndLoadChunks", [extractAndLoadChunks]]);
|
webpackSearchHistory.push(["extractAndLoadChunks", [extractAndLoadChunks, code, matcher]]);
|
||||||
}
|
}
|
||||||
|
|
||||||
return extractAndLoadChunks;
|
return extractAndLoadChunks;
|
||||||
|
|
Loading…
Reference in a new issue