up
This commit is contained in:
		
							parent
							
								
									9955fe7626
								
							
						
					
					
						commit
						f5925bb78e
					
				
					 1 changed files with 86 additions and 36 deletions
				
			
		
							
								
								
									
										122
									
								
								data-util.lua
									
										
									
									
									
								
							
							
						
						
									
										122
									
								
								data-util.lua
									
										
									
									
									
								
							|  | @ -23,14 +23,6 @@ else | ||||||
|   util.titanium_processing = "titanium-processing" |   util.titanium_processing = "titanium-processing" | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| allbypass = {} |  | ||||||
| log("BZZ" .. me.name) |  | ||||||
| -- if get_setting("bz-recipe-bypass") then  |  | ||||||
| --   for recipe in string.gmatch(me.get_setting("bz-recipe-bypass"), '[^",%s]+') do |  | ||||||
| --     allbypass[recipe] = true |  | ||||||
| --   end |  | ||||||
| -- end |  | ||||||
| 
 |  | ||||||
| function get_setting(name) | function get_setting(name) | ||||||
|   if settings.startup[name] == nil then |   if settings.startup[name] == nil then | ||||||
|     return nil |     return nil | ||||||
|  | @ -38,6 +30,14 @@ function get_setting(name) | ||||||
|   return settings.startup[name].value |   return settings.startup[name].value | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
|  | allbypass = {} | ||||||
|  | if get_setting("bz-recipe-bypass") then  | ||||||
|  |   for recipe in string.gmatch(me.get_setting("bz-recipe-bypass"), '[^",%s]+') do | ||||||
|  |     allbypass[recipe] = true | ||||||
|  |   end | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
| function bypass(recipe_name)  | function bypass(recipe_name)  | ||||||
|   if me.bypass[recipe_name] then return true end |   if me.bypass[recipe_name] then return true end | ||||||
|   if allbypass[recipe_name] then return true end |   if allbypass[recipe_name] then return true end | ||||||
|  | @ -180,7 +180,7 @@ end | ||||||
| 
 | 
 | ||||||
| -- Add a given quantity of ingredient to a given recipe | -- Add a given quantity of ingredient to a given recipe | ||||||
| function util.add_or_add_to_ingredient(recipe_name, ingredient, quantity) | function util.add_or_add_to_ingredient(recipe_name, ingredient, quantity) | ||||||
|   if me.bypass[recipe_name] then return end |   if bypass(recipe_name) then return end | ||||||
|   if data.raw.recipe[recipe_name] and data.raw.item[ingredient] then |   if data.raw.recipe[recipe_name] and data.raw.item[ingredient] then | ||||||
|     me.add_modified(recipe_name) |     me.add_modified(recipe_name) | ||||||
|     add_or_add_to_ingredient(data.raw.recipe[recipe_name], ingredient, quantity) |     add_or_add_to_ingredient(data.raw.recipe[recipe_name], ingredient, quantity) | ||||||
|  | @ -203,7 +203,7 @@ end | ||||||
| 
 | 
 | ||||||
| -- Add a given quantity of ingredient to a given recipe | -- Add a given quantity of ingredient to a given recipe | ||||||
| function util.add_ingredient(recipe_name, ingredient, quantity) | function util.add_ingredient(recipe_name, ingredient, quantity) | ||||||
|   if me.bypass[recipe_name] then return end |   if bypass(recipe_name) then return end | ||||||
|   local is_fluid = not not data.raw.fluid[ingredient] |   local is_fluid = not not data.raw.fluid[ingredient] | ||||||
|   if data.raw.recipe[recipe_name] and (data.raw.item[ingredient] or is_fluid) then |   if data.raw.recipe[recipe_name] and (data.raw.item[ingredient] or is_fluid) then | ||||||
|     me.add_modified(recipe_name) |     me.add_modified(recipe_name) | ||||||
|  | @ -230,7 +230,7 @@ end | ||||||
| 
 | 
 | ||||||
| -- Add a given ingredient prototype to a given recipe | -- Add a given ingredient prototype to a given recipe | ||||||
| function util.add_ingredient_raw(recipe_name, ingredient) | function util.add_ingredient_raw(recipe_name, ingredient) | ||||||
|   if me.bypass[recipe_name] then return end |   if bypass(recipe_name) then return end | ||||||
|   if data.raw.recipe[recipe_name] and (data.raw.item[ingredient.name] or data.raw.item[ingredient[1]]) then |   if data.raw.recipe[recipe_name] and (data.raw.item[ingredient.name] or data.raw.item[ingredient[1]]) then | ||||||
|     me.add_modified(recipe_name) |     me.add_modified(recipe_name) | ||||||
|     add_ingredient_raw(data.raw.recipe[recipe_name], ingredient) |     add_ingredient_raw(data.raw.recipe[recipe_name], ingredient) | ||||||
|  | @ -255,7 +255,7 @@ end | ||||||
| 
 | 
 | ||||||
| -- Set an ingredient to a given quantity | -- Set an ingredient to a given quantity | ||||||
| function util.set_ingredient(recipe_name, ingredient, quantity) | function util.set_ingredient(recipe_name, ingredient, quantity) | ||||||
|   if me.bypass[recipe_name] then return end |   if bypass(recipe_name) then return end | ||||||
|   if data.raw.recipe[recipe_name] and data.raw.item[ingredient] then |   if data.raw.recipe[recipe_name] and data.raw.item[ingredient] then | ||||||
|     me.add_modified(recipe_name) |     me.add_modified(recipe_name) | ||||||
|     set_ingredient(data.raw.recipe[recipe_name], ingredient, quantity) |     set_ingredient(data.raw.recipe[recipe_name], ingredient, quantity) | ||||||
|  | @ -283,7 +283,7 @@ end | ||||||
| -- Add a given quantity of product to a given recipe.  | -- Add a given quantity of product to a given recipe.  | ||||||
| -- Only works for recipes with multiple products | -- Only works for recipes with multiple products | ||||||
| function util.add_product(recipe_name, product) | function util.add_product(recipe_name, product) | ||||||
|   if me.bypass[recipe_name] then return end |   if bypass(recipe_name) then return end | ||||||
|   if data.raw.recipe[recipe_name] and (data.raw.item[product[1]] or data.raw.item[product.name]) then |   if data.raw.recipe[recipe_name] and (data.raw.item[product[1]] or data.raw.item[product.name]) then | ||||||
|     add_product(data.raw.recipe[recipe_name], product) |     add_product(data.raw.recipe[recipe_name], product) | ||||||
|     add_product(data.raw.recipe[recipe_name].normal, product) |     add_product(data.raw.recipe[recipe_name].normal, product) | ||||||
|  | @ -350,17 +350,18 @@ function util.get_amount(recipe_name, product) | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| -- Replace one ingredient with another in a recipe | -- Replace one ingredient with another in a recipe | ||||||
| function util.replace_ingredient(recipe_name, old, new, amount) | --    Use amount to set an amount. If that amount is a multiplier instead of an exact amount, set multiply true. | ||||||
|   if me.bypass[recipe_name] then return end | function util.replace_ingredient(recipe_name, old, new, amount, multiply) | ||||||
|  |   if bypass(recipe_name) then return end | ||||||
|   if data.raw.recipe[recipe_name] and (data.raw.item[new] or data.raw.fluid[new]) then |   if data.raw.recipe[recipe_name] and (data.raw.item[new] or data.raw.fluid[new]) then | ||||||
|     me.add_modified(recipe_name) |     me.add_modified(recipe_name) | ||||||
|     replace_ingredient(data.raw.recipe[recipe_name], old, new, amount) |     replace_ingredient(data.raw.recipe[recipe_name], old, new, amount, multiply) | ||||||
|     replace_ingredient(data.raw.recipe[recipe_name].normal, old, new, amount) |     replace_ingredient(data.raw.recipe[recipe_name].normal, old, new, amount, multiply) | ||||||
|     replace_ingredient(data.raw.recipe[recipe_name].expensive, old, new, amount) |     replace_ingredient(data.raw.recipe[recipe_name].expensive, old, new, amount, multiply) | ||||||
|   end |   end | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| function replace_ingredient(recipe, old, new, amount) | function replace_ingredient(recipe, old, new, amount, multiply) | ||||||
| 	if recipe ~= nil and recipe.ingredients ~= nil then | 	if recipe ~= nil and recipe.ingredients ~= nil then | ||||||
|     for i, existing in pairs(recipe.ingredients) do |     for i, existing in pairs(recipe.ingredients) do | ||||||
|       if existing[1] == new or existing.name == new then |       if existing[1] == new or existing.name == new then | ||||||
|  | @ -370,11 +371,23 @@ function replace_ingredient(recipe, old, new, amount) | ||||||
| 		for i, ingredient in pairs(recipe.ingredients) do  | 		for i, ingredient in pairs(recipe.ingredients) do  | ||||||
| 			if ingredient.name == old then  | 			if ingredient.name == old then  | ||||||
|         ingredient.name = new  |         ingredient.name = new  | ||||||
|         if amount then ingredient.amount = amount end |         if amount then | ||||||
|  |           if multiply then | ||||||
|  |             ingredient.amount = amount * ingredient.amount | ||||||
|  |           else | ||||||
|  |             ingredient.amount = amount | ||||||
|  |           end | ||||||
|  |         end | ||||||
|       end |       end | ||||||
| 			if ingredient[1] == old then  | 			if ingredient[1] == old then  | ||||||
|         ingredient[1] = new |         ingredient[1] = new | ||||||
|         if amount then ingredient[2] = amount end |         if amount then | ||||||
|  |           if multiply then | ||||||
|  |             ingredient[2] = amount * ingredient[2] | ||||||
|  |           else | ||||||
|  |             ingredient[2] = amount | ||||||
|  |           end | ||||||
|  |         end | ||||||
|       end |       end | ||||||
| 		end | 		end | ||||||
| 	end | 	end | ||||||
|  | @ -382,7 +395,7 @@ end | ||||||
| 
 | 
 | ||||||
| -- Remove an ingredient from a recipe | -- Remove an ingredient from a recipe | ||||||
| function util.remove_ingredient(recipe_name, old) | function util.remove_ingredient(recipe_name, old) | ||||||
|   if me.bypass[recipe_name] then return end |   if bypass(recipe_name) then return end | ||||||
|   if data.raw.recipe[recipe_name] then |   if data.raw.recipe[recipe_name] then | ||||||
|     me.add_modified(recipe_name) |     me.add_modified(recipe_name) | ||||||
|     remove_ingredient(data.raw.recipe[recipe_name], old) |     remove_ingredient(data.raw.recipe[recipe_name], old) | ||||||
|  | @ -408,7 +421,7 @@ end | ||||||
| 
 | 
 | ||||||
| -- Replace an amount of an ingredient in a recipe. Keep at least 1 of old. | -- Replace an amount of an ingredient in a recipe. Keep at least 1 of old. | ||||||
| function util.replace_some_ingredient(recipe_name, old, old_amount, new, new_amount) | function util.replace_some_ingredient(recipe_name, old, old_amount, new, new_amount) | ||||||
|   if me.bypass[recipe_name] then return end |   if bypass(recipe_name) then return end | ||||||
|   local is_fluid = not not data.raw.fluid[new] |   local is_fluid = not not data.raw.fluid[new] | ||||||
|   if data.raw.recipe[recipe_name] and (data.raw.item[new] or is_fluid) then |   if data.raw.recipe[recipe_name] and (data.raw.item[new] or is_fluid) then | ||||||
|     me.add_modified(recipe_name) |     me.add_modified(recipe_name) | ||||||
|  | @ -441,7 +454,7 @@ end | ||||||
| function util.set_product_amount(recipe_name, product, amount) | function util.set_product_amount(recipe_name, product, amount) | ||||||
|   me.add_modified(recipe_name) |   me.add_modified(recipe_name) | ||||||
|   if data.raw.recipe[recipe_name] then |   if data.raw.recipe[recipe_name] then | ||||||
|     if me.bypass[recipe_name] then return end |     if bypass(recipe_name) then return end | ||||||
|     set_product_amount(data.raw.recipe[recipe_name], product, amount) |     set_product_amount(data.raw.recipe[recipe_name], product, amount) | ||||||
|     set_product_amount(data.raw.recipe[recipe_name].normal, product, amount) |     set_product_amount(data.raw.recipe[recipe_name].normal, product, amount) | ||||||
|     set_product_amount(data.raw.recipe[recipe_name].expensive, product, amount) |     set_product_amount(data.raw.recipe[recipe_name].expensive, product, amount) | ||||||
|  | @ -481,7 +494,7 @@ end | ||||||
| function util.multiply_recipe(recipe_name, multiple) | function util.multiply_recipe(recipe_name, multiple) | ||||||
|   me.add_modified(recipe_name) |   me.add_modified(recipe_name) | ||||||
|   if data.raw.recipe[recipe_name] then |   if data.raw.recipe[recipe_name] then | ||||||
|     if me.bypass[recipe_name] then return end |     if bypass(recipe_name) then return end | ||||||
|     multiply_recipe(data.raw.recipe[recipe_name], multiple) |     multiply_recipe(data.raw.recipe[recipe_name], multiple) | ||||||
|     multiply_recipe(data.raw.recipe[recipe_name].normal, multiple) |     multiply_recipe(data.raw.recipe[recipe_name].normal, multiple) | ||||||
|     multiply_recipe(data.raw.recipe[recipe_name].expensive, multiple) |     multiply_recipe(data.raw.recipe[recipe_name].expensive, multiple) | ||||||
|  | @ -554,7 +567,7 @@ end | ||||||
| function util.remove_product(recipe_name, old) | function util.remove_product(recipe_name, old) | ||||||
|   me.add_modified(recipe_name) |   me.add_modified(recipe_name) | ||||||
|   if data.raw.recipe[recipe_name] then |   if data.raw.recipe[recipe_name] then | ||||||
|     if me.bypass[recipe_name] then return end |     if bypass(recipe_name) then return end | ||||||
|     remove_product(data.raw.recipe[recipe_name], old) |     remove_product(data.raw.recipe[recipe_name], old) | ||||||
|     remove_product(data.raw.recipe[recipe_name].normal, old) |     remove_product(data.raw.recipe[recipe_name].normal, old) | ||||||
|     remove_product(data.raw.recipe[recipe_name].expensive, old) |     remove_product(data.raw.recipe[recipe_name].expensive, old) | ||||||
|  | @ -577,7 +590,7 @@ function remove_product(recipe, old) | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| function util.set_main_product(recipe_name, product) | function util.set_main_product(recipe_name, product) | ||||||
|   if me.bypass[recipe_name] then return end |   if bypass(recipe_name) then return end | ||||||
|   if data.raw.recipe[recipe_name] then |   if data.raw.recipe[recipe_name] then | ||||||
|     set_main_product(data.raw.recipe[recipe_name], product) |     set_main_product(data.raw.recipe[recipe_name], product) | ||||||
|     set_main_product(data.raw.recipe[recipe_name].normal, product) |     set_main_product(data.raw.recipe[recipe_name].normal, product) | ||||||
|  | @ -593,7 +606,7 @@ end | ||||||
| 
 | 
 | ||||||
| -- Replace one product with another in a recipe | -- Replace one product with another in a recipe | ||||||
| function util.replace_product(recipe_name, old, new) | function util.replace_product(recipe_name, old, new) | ||||||
|   if me.bypass[recipe_name] then return end |   if bypass(recipe_name) then return end | ||||||
|   if data.raw.recipe[recipe_name] then |   if data.raw.recipe[recipe_name] then | ||||||
|     replace_product(data.raw.recipe[recipe_name], old, new) |     replace_product(data.raw.recipe[recipe_name], old, new) | ||||||
|     replace_product(data.raw.recipe[recipe_name].normal, old, new) |     replace_product(data.raw.recipe[recipe_name].normal, old, new) | ||||||
|  | @ -639,7 +652,7 @@ end | ||||||
| function util.set_recipe_time(recipe_name, time) | function util.set_recipe_time(recipe_name, time) | ||||||
|   me.add_modified(recipe_name) |   me.add_modified(recipe_name) | ||||||
|   if data.raw.recipe[recipe_name] then |   if data.raw.recipe[recipe_name] then | ||||||
|     if me.bypass[recipe_name] then return end |     if bypass(recipe_name) then return end | ||||||
|     set_recipe_time(data.raw.recipe[recipe_name], time) |     set_recipe_time(data.raw.recipe[recipe_name], time) | ||||||
|     set_recipe_time(data.raw.recipe[recipe_name].normal, time) |     set_recipe_time(data.raw.recipe[recipe_name].normal, time) | ||||||
|     set_recipe_time(data.raw.recipe[recipe_name].expensive, time) |     set_recipe_time(data.raw.recipe[recipe_name].expensive, time) | ||||||
|  | @ -658,7 +671,7 @@ end | ||||||
| function util.multiply_time(recipe_name, factor) | function util.multiply_time(recipe_name, factor) | ||||||
|   me.add_modified(recipe_name) |   me.add_modified(recipe_name) | ||||||
|   if data.raw.recipe[recipe_name] then |   if data.raw.recipe[recipe_name] then | ||||||
|     if me.bypass[recipe_name] then return end |     if bypass(recipe_name) then return end | ||||||
|     multiply_time(data.raw.recipe[recipe_name], factor) |     multiply_time(data.raw.recipe[recipe_name], factor) | ||||||
|     multiply_time(data.raw.recipe[recipe_name].normal, factor) |     multiply_time(data.raw.recipe[recipe_name].normal, factor) | ||||||
|     multiply_time(data.raw.recipe[recipe_name].expensive, factor) |     multiply_time(data.raw.recipe[recipe_name].expensive, factor) | ||||||
|  | @ -677,7 +690,7 @@ end | ||||||
| function util.add_time(recipe_name, amount) | function util.add_time(recipe_name, amount) | ||||||
|   me.add_modified(recipe_name) |   me.add_modified(recipe_name) | ||||||
|   if data.raw.recipe[recipe_name] then |   if data.raw.recipe[recipe_name] then | ||||||
|     if me.bypass[recipe_name] then return end |     if bypass(recipe_name) then return end | ||||||
|     add_time(data.raw.recipe[recipe_name], amount) |     add_time(data.raw.recipe[recipe_name], amount) | ||||||
|     add_time(data.raw.recipe[recipe_name].normal, amount) |     add_time(data.raw.recipe[recipe_name].normal, amount) | ||||||
|     add_time(data.raw.recipe[recipe_name].expensive, amount) |     add_time(data.raw.recipe[recipe_name].expensive, amount) | ||||||
|  | @ -694,7 +707,7 @@ end | ||||||
| 
 | 
 | ||||||
| -- Set recipe category | -- Set recipe category | ||||||
| function util.set_category(recipe_name, category) | function util.set_category(recipe_name, category) | ||||||
|   if me.bypass[recipe_name] then return end |   if bypass(recipe_name) then return end | ||||||
|   if data.raw.recipe[recipe_name] and data.raw["recipe-category"][category] then |   if data.raw.recipe[recipe_name] and data.raw["recipe-category"][category] then | ||||||
|     me.add_modified(recipe_name) |     me.add_modified(recipe_name) | ||||||
|     data.raw.recipe[recipe_name].category = category |     data.raw.recipe[recipe_name].category = category | ||||||
|  | @ -703,7 +716,7 @@ end | ||||||
| 
 | 
 | ||||||
| -- Set recipe subgroup | -- Set recipe subgroup | ||||||
| function util.set_subgroup(recipe_name, subgroup) | function util.set_subgroup(recipe_name, subgroup) | ||||||
|   if me.bypass[recipe_name] then return end |   if bypass(recipe_name) then return end | ||||||
|   if data.raw.recipe[recipe_name] then |   if data.raw.recipe[recipe_name] then | ||||||
|     me.add_modified(recipe_name) |     me.add_modified(recipe_name) | ||||||
|     data.raw.recipe[recipe_name].subgroup = subgroup |     data.raw.recipe[recipe_name].subgroup = subgroup | ||||||
|  | @ -712,7 +725,7 @@ end | ||||||
| 
 | 
 | ||||||
| -- Set item subgroup | -- Set item subgroup | ||||||
| function util.set_item_subgroup(item, subgroup) | function util.set_item_subgroup(item, subgroup) | ||||||
|   if me.bypass[item] then return end |   if bypass(item) then return end | ||||||
|   if data.raw.item[item] and data.raw["item-subgroup"][subgroup] then |   if data.raw.item[item] and data.raw["item-subgroup"][subgroup] then | ||||||
|     data.raw.item[item].subgroup = subgroup |     data.raw.item[item].subgroup = subgroup | ||||||
|   end |   end | ||||||
|  | @ -720,7 +733,7 @@ end | ||||||
| 
 | 
 | ||||||
| -- Set recipe icons | -- Set recipe icons | ||||||
| function util.set_icons(recipe_name, icons) | function util.set_icons(recipe_name, icons) | ||||||
|   if me.bypass[recipe_name] then return end |   if bypass(recipe_name) then return end | ||||||
|   if data.raw.recipe[recipe_name] then |   if data.raw.recipe[recipe_name] then | ||||||
|     me.add_modified(recipe_name) |     me.add_modified(recipe_name) | ||||||
|     data.raw.recipe[recipe_name].icons = icons |     data.raw.recipe[recipe_name].icons = icons | ||||||
|  | @ -779,7 +792,7 @@ function add_to_ingredient(recipe, it, amount) | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| function util.add_to_product(recipe, product, amount) | function util.add_to_product(recipe, product, amount) | ||||||
|   if me.bypass[recipe] then return end |   if bypass(recipe) then return end | ||||||
|   if data.raw.recipe[recipe] then |   if data.raw.recipe[recipe] then | ||||||
|     add_to_product(data.raw.recipe[recipe], product, amount) |     add_to_product(data.raw.recipe[recipe], product, amount) | ||||||
|     add_to_product(data.raw.recipe[recipe].normal, product, amount) |     add_to_product(data.raw.recipe[recipe].normal, product, amount) | ||||||
|  | @ -892,4 +905,41 @@ function util.create_list() | ||||||
|   end |   end | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
|  | function util.replace_ingredients_prior_to(tech, old, new, multiplier) | ||||||
|  |   if not data.raw.technology[tech] then | ||||||
|  |     log("Not replacing ingredient "..old.." with "..new.." because tech "..tech.." was not found") | ||||||
|  |     return | ||||||
|  |   end | ||||||
|  |   for i, recipe in pairs(data.raw.recipe) do | ||||||
|  |     if recipe.enabled then | ||||||
|  |       util.replace_ingredient(recipe.name, old, new, multiplier, true) | ||||||
|  |     end | ||||||
|  |   end | ||||||
|  |   if data.raw.technology[tech].prerequisites then | ||||||
|  |     for i, prerequisite in pairs(data.raw.technology[tech].prerequisites) do | ||||||
|  |       replace_ingredients_prior_to(prerequisite, old, new, multiplier) | ||||||
|  |     end | ||||||
|  |   end | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | function replace_ingredients_prior_to(tech, old, new, multiplier) | ||||||
|  |   local technology = data.raw.technology[tech] | ||||||
|  |   if technology then | ||||||
|  |     if technology.effects then | ||||||
|  |       for i, effect in pairs(technology.effects) do | ||||||
|  |         if effect.type == "unlock-recipe" then | ||||||
|  |           -- log("BZZZ replacing " .. effect.recipe) | ||||||
|  |           util.replace_ingredient(effect.recipe, old, new, multiplier, true) | ||||||
|  |         end | ||||||
|  |       end | ||||||
|  |     end | ||||||
|  |     if technology.prerequisites then | ||||||
|  |       for i, prerequisite in pairs(technology.prerequisites) do | ||||||
|  |         -- log("BZZZ checking " .. prerequisite) | ||||||
|  |         replace_ingredients_prior_to(prerequisite, old, new, multiplier) | ||||||
|  |       end | ||||||
|  |     end | ||||||
|  |   end | ||||||
|  | end | ||||||
|  | 
 | ||||||
| return util | return util | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Brevven
						Brevven