aboutsummaryrefslogtreecommitdiff
path: root/server/src/bin
diff options
context:
space:
mode:
authormetamuffin <metamuffin@disroot.org>2025-09-19 22:27:46 +0200
committermetamuffin <metamuffin@disroot.org>2025-09-19 22:40:39 +0200
commit402067b8317195fd2bc4ab4d92b5ace94fadb7c0 (patch)
tree2437c52ae71a11c4d17a6fa4597f8152dae96ddc /server/src/bin
parent2f311fec691cd7a62fa4f95ee0419089913b5dd8 (diff)
downloadhurrycurry-402067b8317195fd2bc4ab4d92b5ace94fadb7c0.tar
hurrycurry-402067b8317195fd2bc4ab4d92b5ace94fadb7c0.tar.bz2
hurrycurry-402067b8317195fd2bc4ab4d92b5ace94fadb7c0.tar.zst
Refactor book part 1
Diffstat (limited to 'server/src/bin')
-rw-r--r--server/src/bin/graph.rs77
-rw-r--r--server/src/bin/graph_summary.rs150
2 files changed, 0 insertions, 227 deletions
diff --git a/server/src/bin/graph.rs b/server/src/bin/graph.rs
deleted file mode 100644
index 000be9e7..00000000
--- a/server/src/bin/graph.rs
+++ /dev/null
@@ -1,77 +0,0 @@
-/*
- Hurry Curry! - a game about cooking
- Copyright (C) 2025 Hurry Curry! Contributors
-
- This program is free software: you can redistribute it and/or modify
- it under the terms of the GNU Affero General Public License as published by
- the Free Software Foundation, version 3 of the License only.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU Affero General Public License for more details.
-
- You should have received a copy of the GNU Affero General Public License
- along with this program. If not, see <https://www.gnu.org/licenses/>.
-
-*/
-use anyhow::Result;
-use hurrycurry_protocol::{Demand, ItemIndex, Recipe, RecipeIndex};
-use hurrycurry_server::data::DataIndex;
-
-#[tokio::main]
-async fn main() -> Result<()> {
- let mut index = DataIndex::default();
- index.reload().await?;
-
- println!("digraph {{");
-
- let (data, _, _) = index.generate("5star").await?;
- for i in 0..data.item_names.len() {
- println!("i{i} [label=\"{}\"]", data.item_name(ItemIndex(i)))
- }
- for (RecipeIndex(ri), recipe) in data.recipes() {
- let (kind, color) = match recipe {
- Recipe::Passive { .. } => ("Passive", "#2bc493"),
- Recipe::Active { .. } => ("Active", "#47c42b"),
- Recipe::Instant { .. } => ("Instant", "#5452d8"),
- };
- println!(
- "r{ri} [label=\"{kind}\\non {}\" shape=box color={color:?} fillcolor={color:?} style=filled]",
- if let Some(tile) = recipe.tile() {
- data.tile_name(tile)
- } else {
- "anything"
- }
- );
- for ItemIndex(input) in recipe.inputs() {
- println!("i{input} -> r{ri}")
- }
- for ItemIndex(output) in recipe.outputs() {
- println!("r{ri} -> i{output}")
- }
- }
-
- for (
- di,
- Demand {
- duration,
- input: ItemIndex(input),
- output,
- points,
- },
- ) in data.demands.iter().enumerate()
- {
- let color = "#c4422b";
- println!(
- "d{di} [label=\"Demand\\ntakes {duration}s\\n{points} points\" shape=box color={color:?} fillcolor={color:?} style=filled]",
- );
- println!("i{input} -> d{di}");
- if let Some(ItemIndex(output)) = output {
- println!("d{di} -> i{output}");
- }
- }
-
- println!("}}");
- Ok(())
-}
diff --git a/server/src/bin/graph_summary.rs b/server/src/bin/graph_summary.rs
deleted file mode 100644
index d22361c0..00000000
--- a/server/src/bin/graph_summary.rs
+++ /dev/null
@@ -1,150 +0,0 @@
-/*
- Hurry Curry! - a game about cooking
- Copyright (C) 2025 Hurry Curry! Contributors
-
- This program is free software: you can redistribute it and/or modify
- it under the terms of the GNU Affero General Public License as published by
- the Free Software Foundation, version 3 of the License only.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU Affero General Public License for more details.
-
- You should have received a copy of the GNU Affero General Public License
- along with this program. If not, see <https://www.gnu.org/licenses/>.
-
-*/
-use anyhow::Result;
-use hurrycurry_protocol::{ItemIndex, Recipe, TileIndex};
-use hurrycurry_server::data::DataIndex;
-use std::collections::HashSet;
-
-#[tokio::main]
-async fn main() -> Result<()> {
- let mut index = DataIndex::default();
- index.reload().await?;
-
- println!("digraph {{");
-
- let (data, sdata, _) = index.generate("5star").await?;
-
- struct Node {
- inputs: Vec<ItemIndex>,
- outputs: Vec<ItemIndex>,
- tool_item: Option<ItemIndex>,
- tool_tile: Option<TileIndex>,
- instant: bool,
- demand: bool,
- }
-
- let map_items = sdata
- .initial_map
- .iter()
- .flat_map(|(_, (_, i))| *i)
- .collect::<HashSet<_>>();
-
- let mut nodes = Vec::new();
- for r in &data.recipes {
- nodes.push(Node {
- inputs: r.inputs(),
- outputs: r.outputs(),
- tool_item: None,
- tool_tile: r.tile(),
- instant: matches!(r, Recipe::Instant { .. }),
- demand: false,
- })
- }
- for d in &data.demands {
- nodes.push(Node {
- demand: true,
- instant: false,
- inputs: vec![d.input],
- outputs: d.output.into_iter().collect(),
- tool_item: None,
- tool_tile: None,
- })
- }
-
- loop {
- let node_count_before = nodes.len();
-
- let mut has_fdeps = vec![false; data.item_names.len()];
- for n in &nodes {
- for ItemIndex(i) in &n.inputs {
- has_fdeps[*i] = true;
- }
- }
- // Remove demand outputs
- for n in &mut nodes {
- n.outputs.retain(|_item| !n.demand);
- }
- // Remove outputs that are not depended on
- for n in &mut nodes {
- n.outputs.retain(|item| n.demand || has_fdeps[item.0])
- }
- // Remove outputs that exist on the map, like pots and plates
- for n in &mut nodes {
- n.outputs.retain(|item| !map_items.contains(item))
- }
- // Convert map item inputs to tools
- for n in &mut nodes {
- n.inputs.retain(|i| {
- if map_items.contains(i) {
- n.tool_item = Some(*i);
- false
- } else {
- true
- }
- })
- }
- // Remove outputless recipes
- nodes.retain(|n| n.demand || !n.outputs.is_empty());
-
- if nodes.len() == node_count_before {
- break;
- }
- }
-
- let mut items = HashSet::<ItemIndex>::new();
- for n in &nodes {
- items.extend(&n.inputs);
- items.extend(&n.outputs);
- }
-
- for ItemIndex(i) in items {
- println!("i{i} [label=\"{}\"]", data.item_name(ItemIndex(i)))
- }
- for (ni, node) in nodes.iter().enumerate() {
- let color = if node.demand {
- "#c4422b"
- } else if node.instant {
- "#5452d8"
- } else {
- "#47c42b"
- };
- println!(
- "r{ni} [label=\"{}\" shape=box color={color:?} fillcolor={color:?} style=filled]",
- if let Some(tool) = node.tool_tile {
- data.tile_name(tool)
- } else if let Some(tool) = node.tool_item {
- data.item_name(tool)
- } else if node.instant {
- "Combine"
- } else if node.demand {
- "Demand"
- } else {
- "Passive"
- }
- );
- for ItemIndex(input) in &node.inputs {
- println!("i{input} -> r{ni}")
- }
- for ItemIndex(output) in &node.outputs {
- println!("r{ni} -> i{output}")
- }
- }
-
- println!("}}");
- Ok(())
-}