diff options
author | metamuffin <metamuffin@disroot.org> | 2025-09-19 22:27:46 +0200 |
---|---|---|
committer | metamuffin <metamuffin@disroot.org> | 2025-09-19 22:40:39 +0200 |
commit | 402067b8317195fd2bc4ab4d92b5ace94fadb7c0 (patch) | |
tree | 2437c52ae71a11c4d17a6fa4597f8152dae96ddc /server/src/bin | |
parent | 2f311fec691cd7a62fa4f95ee0419089913b5dd8 (diff) | |
download | hurrycurry-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.rs | 77 | ||||
-rw-r--r-- | server/src/bin/graph_summary.rs | 150 |
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(()) -} |