summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authormetamuffin <metamuffin@disroot.org>2024-06-26 14:17:04 +0200
committermetamuffin <metamuffin@disroot.org>2024-06-26 14:17:04 +0200
commitafa01c33c1600a81aa430e109d5455d75e2e51e7 (patch)
tree065d7560dc3b01e31fab92fb69e2095c565204a3
parent00c54b4594cd58504a7c93ac953ae6fe9f13c19a (diff)
downloadhurrycurry-afa01c33c1600a81aa430e109d5455d75e2e51e7.tar
hurrycurry-afa01c33c1600a81aa430e109d5455d75e2e51e7.tar.bz2
hurrycurry-afa01c33c1600a81aa430e109d5455d75e2e51e7.tar.zst
export recipe functions
-rw-r--r--data/recipes/default.ts58
1 files changed, 30 insertions, 28 deletions
diff --git a/data/recipes/default.ts b/data/recipes/default.ts
index 4efdb16a..f0a9ef6b 100644
--- a/data/recipes/default.ts
+++ b/data/recipes/default.ts
@@ -18,7 +18,7 @@
//? Is is a good idea? Probably not.
-interface Recipe {
+export interface Recipe {
tile?: string,
inputs: (string | null)[],
outputs: (string | null)[],
@@ -28,8 +28,8 @@ interface Recipe {
warn?: boolean
}
-const all_items = new Set<string>()
-function auto_trash() {
+export const all_items = new Set<string>()
+export function auto_trash() {
for (const ifull of all_items) {
let [i, ic] = get_container(ifull)
if (i == "plate") continue
@@ -46,7 +46,7 @@ function auto_trash() {
}
}
-function out(r: Recipe) {
+export function out(r: Recipe) {
r.inputs.forEach(i => i ? all_items.add(i) : void 0)
r.outputs.forEach(i => i ? all_items.add(i) : void 0)
r.inputs = r.inputs.filter(e => e)
@@ -54,39 +54,39 @@ function out(r: Recipe) {
console.log(`- ${JSON.stringify(r).replaceAll("\"active\"", "!active").replaceAll("\"passive\"", "!passive").replaceAll("\"instant\"", "!instant")}`);
}
-function cut(from: string, to?: string, to2?: string) {
+export function cut(from: string, to?: string, to2?: string) {
out({ action: "active", duration: 2, tile: "cuttingboard", inputs: [from], outputs: [to ?? ("sliced-" + from), to2 ?? null] })
}
-function cook(from: string, to?: string) {
+export function cook(from: string, to?: string) {
const i = from.endsWith("-pot") ? from : from + "-pot"
const o = (to ?? ("cooked-" + from)) + "-pot"
if (!from.endsWith("-pot")) out({ action: "instant", inputs: ["pot", from], outputs: [i] })
out({ action: "passive", duration: 20, revert_duration: 40, tile: "stove", inputs: [i], outputs: [o] })
out({ action: "passive", duration: 5, revert_duration: 10, tile: "stove", inputs: [o], outputs: ["burned-pot"], warn: true })
}
-function process(from: string, to?: string) {
+export function process(from: string, to?: string) {
const i = from + "-foodprocessor"
const o = (to ?? (from + "-juice")) + "-foodprocessor"
out({ action: "instant", inputs: ["foodprocessor", from], outputs: [i] })
out({ action: "active", duration: 3, inputs: [i], outputs: [o] })
}
-function bake(from: string, to?: string) {
+export function bake(from: string, to?: string) {
const o = (to ?? ("cooked-" + from))
out({ action: "passive", duration: 25, tile: "oven", inputs: [from], outputs: [o] })
out({ action: "passive", duration: 15, revert_duration: 20, tile: "oven", inputs: [o], outputs: ["burned"], warn: true })
}
-function crate(item: string) {
+export function crate(item: string) {
out({ action: "instant", tile: item + "-crate", inputs: [], outputs: [item], })
}
-function get_container(ifull: string): [string, string | null] {
+export function get_container(ifull: string): [string, string | null] {
const iparts = ifull.split("-")
const ic = iparts.pop()
if (ic && iparts.length && ["pot", "plate", "foodprocessor"].includes(ic)) return [iparts.join("-"), ic]
return [ifull, null]
}
-function combine(container: string, ...inputs: string[]) {
+export function combine(container: string, ...inputs: string[]) {
const open = inputs.map(ifull => {
const [i, ic] = get_container(ifull)
out({ action: "instant", inputs: [container, ifull], outputs: [i + "-" + container, ic] })
@@ -117,27 +117,29 @@ function combine(container: string, ...inputs: string[]) {
}
}
-out({ action: "active", duration: 2, tile: "sink", inputs: ["dirty-plate"], outputs: ["plate"] })
+if (import.meta.main) {
+ out({ action: "active", duration: 2, tile: "sink", inputs: ["dirty-plate"], outputs: ["plate"] })
-crate("tomato")
-crate("raw-steak")
-crate("flour")
-crate("leek")
+ crate("tomato")
+ crate("raw-steak")
+ crate("flour")
+ crate("leek")
-cut("tomato")
+ cut("tomato")
-cook("raw-steak", "steak")
+ cook("raw-steak", "steak")
-process("flour", "dough")
-out({ action: "instant", inputs: ["dough-foodprocessor"], outputs: ["foodprocessor", "dough"] })
-bake("dough", "bread")
-cut("bread", "bread-slice", "bread-slice")
+ process("flour", "dough")
+ out({ action: "instant", inputs: ["dough-foodprocessor"], outputs: ["foodprocessor", "dough"] })
+ bake("dough", "bread")
+ cut("bread", "bread-slice", "bread-slice")
-process("tomato")
-combine("pot", "leek", "tomato-juice-foodprocessor")
-cook("leek-tomato-juice-pot", "tomato-soup")
-out({ action: "instant", inputs: ["tomato-soup-pot", "plate"], outputs: ["pot", "tomato-soup-plate"] })
+ process("tomato")
+ combine("pot", "leek", "tomato-juice-foodprocessor")
+ cook("leek-tomato-juice-pot", "tomato-soup")
+ out({ action: "instant", inputs: ["tomato-soup-pot", "plate"], outputs: ["pot", "tomato-soup-plate"] })
-combine("plate", "steak-pot", "sliced-tomato", "bread-slice")
+ combine("plate", "steak-pot", "sliced-tomato", "bread-slice")
-auto_trash()
+ auto_trash()
+}