125 lines
3.4 KiB
TypeScript
125 lines
3.4 KiB
TypeScript
import fs from "fs";
|
|
import upath from "upath";
|
|
import { overridesFolder, sharedDestDirectory } from "../../../globals";
|
|
import { Quest, QuestBook, QuestLines as QuestLine } from "../../../types/bqQuestBook";
|
|
|
|
const questLocation = "config/betterquesting/DefaultQuests.json";
|
|
const langFileLocation = "resources/questbook/lang";
|
|
|
|
function escapeString(string: string) {
|
|
return string.replace(/%/g, "%%").replace(/\n/g, "%n");
|
|
}
|
|
|
|
function transformKeyPairs(
|
|
database: { [key: string]: Quest } | { [key: string]: QuestLine },
|
|
namespace: string,
|
|
lines: string[],
|
|
) {
|
|
Object.keys(database).forEach((key) => {
|
|
const storeKey = key.replace(/:10/g, "");
|
|
const item = database[key];
|
|
|
|
const properties = item["properties:10"]["betterquesting:10"];
|
|
if (properties["name:8"] !== "Gap") {
|
|
const titleKey = `nomifactory.quest.${namespace}.${storeKey}.title`;
|
|
const descKey = `nomifactory.quest.${namespace}.${storeKey}.desc`;
|
|
|
|
// Push lang file lines.
|
|
lines.push(
|
|
`# ${namespace} ${storeKey}`,
|
|
`${titleKey}=${escapeString(properties["name:8"])}`,
|
|
`${descKey}=${escapeString(properties["desc:8"])}`,
|
|
"",
|
|
);
|
|
|
|
properties["name:8"] = titleKey;
|
|
properties["desc:8"] = descKey;
|
|
} else {
|
|
properties["name:8"] = "";
|
|
properties["desc:8"] = "";
|
|
}
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Trimming all that results in almost half the size of the original JSON file.
|
|
*
|
|
* Interesting, huh?
|
|
*/
|
|
const uselessProps = {
|
|
"simultaneous:1": 0,
|
|
"ismain:1": 0,
|
|
"repeat_relative:1": 1,
|
|
"globalshare:1": 0,
|
|
"repeattime:3": -1,
|
|
"issilent:1": 0,
|
|
"snd_complete:8": "minecraft:entity.player.levelup",
|
|
"snd_update:8": "minecraft:entity.player.levelup",
|
|
"tasklogic:8": "AND",
|
|
"questlogic:8": "AND",
|
|
"visibility:8": "NORMAL",
|
|
"partysinglereward:1": 0,
|
|
"lockedprogress:1": 0,
|
|
"OreDict:8": "",
|
|
"Damage:2": 0,
|
|
"Count:3": 0,
|
|
"autoclaim:1": 0,
|
|
"autoConsume:1": 0,
|
|
"consume:1": 0,
|
|
"groupDetect:1": 0,
|
|
"ignoreNBT:1": 0,
|
|
"index:3": 0,
|
|
"partialMatch:1": 1,
|
|
"ignoresview:1": 0,
|
|
};
|
|
|
|
function stripUselessMetadata(object: unknown) {
|
|
Object.keys(object).forEach((propName) => {
|
|
const prop = object[propName];
|
|
if (prop === uselessProps[propName]) {
|
|
return delete object[propName];
|
|
}
|
|
|
|
if (typeof prop === "object") {
|
|
if (Array.isArray(prop) && prop.length === 0) {
|
|
return delete object[propName];
|
|
}
|
|
|
|
stripUselessMetadata(prop);
|
|
|
|
if (Object.keys(prop).length === 0) {
|
|
return delete object[propName];
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
/**
|
|
* Extract lang entries from the quest book and transform the database.
|
|
*/
|
|
export default async function transformQuestBook(): Promise<void> {
|
|
const questDatabasePath = upath.join(sharedDestDirectory, overridesFolder, questLocation);
|
|
const questLangLocation = upath.join(sharedDestDirectory, overridesFolder, langFileLocation);
|
|
|
|
const questBook: QuestBook = JSON.parse((await fs.promises.readFile(questDatabasePath)).toString());
|
|
|
|
// Traverse through the quest book and rewrite titles/descriptions.
|
|
// Extract title/desc pairs into a lang file.
|
|
const lines: string[] = [];
|
|
|
|
// Quest lines.
|
|
transformKeyPairs(questBook["questLines:9"], "line", lines);
|
|
|
|
// Quests themselves.
|
|
transformKeyPairs(questBook["questDatabase:9"], "db", lines);
|
|
|
|
// Write lang file.
|
|
await fs.promises.mkdir(questLangLocation, { recursive: true });
|
|
await fs.promises.writeFile(upath.join(questLangLocation, "en_us.lang"), lines.join("\n"));
|
|
|
|
// Strip useless metadata.
|
|
stripUselessMetadata(questBook);
|
|
|
|
return fs.promises.writeFile(questDatabasePath, JSON.stringify(questBook));
|
|
}
|