From 427ea70402ee6f87ab04b54295215571f52c738c Mon Sep 17 00:00:00 2001 From: scarf Date: Tue, 12 Sep 2023 13:13:30 +0900 Subject: [PATCH] feat: apply `NUTRIENT_OVERRIDE` for recipes --- src/crafting.cpp | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/src/crafting.cpp b/src/crafting.cpp index 751733d31d41..1717f19d805c 100644 --- a/src/crafting.cpp +++ b/src/crafting.cpp @@ -1027,6 +1027,7 @@ void complete_craft( player &p, item &craft, const bench_location & ) const int batch_size = craft.charges; std::list &used = craft.components; const double relative_rot = craft.get_relative_rot(); + const bool ignore_component = making.has_flag( flag_NUTRIENT_OVERRIDE ); // Set up the new item, and assign an inventory letter if available std::vector newits = making.create_results( batch_size ); @@ -1079,10 +1080,15 @@ void complete_craft( player &p, item &craft, const bench_location & ) food_contained.unset_flag( flag ); } - // Don't store components for things made by charges, - // Don't store components for things that can't be uncrafted. - if( recipe_dictionary::get_uncraft( making.result() ) && !food_contained.count_by_charges() && - making.is_reversible() ) { + // Don't store components for things that ignores components (e.g wow 'conjured bread') + if( ignore_component ) { + food_contained.set_flag( flag_NUTRIENT_OVERRIDE ); + } else if( recipe_dictionary::get_uncraft( making.result() ) && + !food_contained.count_by_charges() && + making.is_reversible() ) { + // Don't store components for things made by charges, + // Don't store components for things that can't be uncrafted. + // Setting this for items counted by charges gives only problems: // those items are automatically merged everywhere (map/vehicle/inventory), // which would either lose this information or merge it somehow.