up
This commit is contained in:
		
							parent
							
								
									88a35dae23
								
							
						
					
					
						commit
						e63d66ffae
					
				
					 1 changed files with 133 additions and 14 deletions
				
			
		
							
								
								
									
										147
									
								
								data-util.lua
									
										
									
									
									
								
							
							
						
						
									
										147
									
								
								data-util.lua
									
										
									
									
									
								
							|  | @ -111,11 +111,16 @@ function util.add_effect(technology_name, effect) | |||
|   end | ||||
| end | ||||
| 
 | ||||
| -- Add an effect to a given technology to unlock recipe | ||||
| function util.add_unlock(technology_name, recipe) | ||||
|   util.add_effect(technology_name, {type="unlock-recipe", recipe=recipe}) | ||||
| end | ||||
| 
 | ||||
| -- remove recipe unlock effect from a given technology | ||||
| function util.remove_recipe_effect(technology_name, recipe_name) | ||||
|   local technology = data.raw.technology[technology_name] | ||||
|   local index = -1 | ||||
|   if technology then | ||||
|   if technology and technology.effects then | ||||
|     for i, effect in pairs(technology.effects) do | ||||
|       if effect.type == "unlock-recipe" and effect.recipe == recipe_name then | ||||
|         index = i | ||||
|  | @ -144,6 +149,14 @@ function util.set_enabled(recipe_name, enabled) | |||
|   end | ||||
| end | ||||
| 
 | ||||
| function util.set_hidden(recipe_name) | ||||
|   if data.raw.recipe[recipe_name] then | ||||
|     if data.raw.recipe[recipe_name].normal then data.raw.recipe[recipe_name].normal.hidden = true end | ||||
|     if data.raw.recipe[recipe_name].expensive then data.raw.recipe[recipe_name].expensive.hidden = true end | ||||
|     if not data.raw.recipe[recipe_name].normal then data.raw.recipe[recipe_name].hidden = true end | ||||
|   end | ||||
| end | ||||
| 
 | ||||
| -- Add a given quantity of ingredient to a given recipe | ||||
| function util.add_or_add_to_ingredient(recipe_name, ingredient, quantity) | ||||
|   if me.bypass[recipe_name] then return end | ||||
|  | @ -183,7 +196,6 @@ function add_ingredient(recipe, ingredient, quantity, is_fluid) | |||
|   if recipe ~= nil and recipe.ingredients ~= nil then | ||||
|     for i, existing in pairs(recipe.ingredients) do | ||||
|       if existing[1] == ingredient or existing.name == ingredient then | ||||
|         log("Not adding "..ingredient.." -- duplicate") | ||||
|         return | ||||
|       end | ||||
|     end | ||||
|  | @ -270,28 +282,78 @@ function add_product(recipe, product) | |||
|   end | ||||
| end | ||||
| 
 | ||||
| -- Get the amount of the ingredient, will check base/normal not expensive | ||||
| function util.get_ingredient_amount(recipe_name, ingredient_name) | ||||
|   local recipe = data.raw.recipe[recipe_name] | ||||
|   if recipe then | ||||
|     if recipe.normal and recipe.normal.ingredients then | ||||
|       for i, ingredient in pairs(recipe.normal.ingredients) do | ||||
|         if ingredient[1] == ingredient_name then return ingredient[2] end | ||||
|         if ingredient.name == ingredient_name then return ingredient.amount end | ||||
|       end | ||||
|     elseif recipe.ingredients then | ||||
|       for i, ingredient in pairs(recipe.ingredients) do | ||||
|         if ingredient[1] == ingredient_name then return ingredient[2] end | ||||
|         if ingredient.name == ingredient_name then return ingredient.amount end | ||||
|       end | ||||
|     end | ||||
|     return 1 | ||||
|   end | ||||
|   return 0 | ||||
| end | ||||
| 
 | ||||
| -- Get the amount of the result, will check base/normal not expensive | ||||
| function util.get_amount(recipe_name, product) | ||||
|   if not product then product = recipe_name end | ||||
|   local recipe = data.raw.recipe[recipe_name] | ||||
|   if recipe then | ||||
|     if recipe.normal and recipe.normal.results then | ||||
|       for i, result in pairs(recipe.normal.results) do | ||||
|         if result[1] == product then return result[2] end | ||||
|         if result.name == product then return result.amount end | ||||
|       end | ||||
|     elseif recipe.normal and recipe.normal.result_count then | ||||
|       return recipe.normal.result_count | ||||
|     elseif recipe.results then | ||||
|       for i, result in pairs(recipe.results) do | ||||
|         if result[1] == product then return result[2] end | ||||
|         if result.name == product then return result.amount end | ||||
|       end | ||||
|     elseif recipe.result_count then | ||||
|       return recipe.result_count | ||||
|     end | ||||
|     return 1 | ||||
|   end | ||||
|   return 0 | ||||
| end | ||||
| 
 | ||||
| -- Replace one ingredient with another in a recipe | ||||
| function util.replace_ingredient(recipe_name, old, new) | ||||
| function util.replace_ingredient(recipe_name, old, new, amount) | ||||
|   if me.bypass[recipe_name] then return end | ||||
|   if data.raw.recipe[recipe_name] and (data.raw.item[new] or data.raw.fluid[new]) then | ||||
|     me.add_modified(recipe_name) | ||||
|     replace_ingredient(data.raw.recipe[recipe_name], old, new) | ||||
|     replace_ingredient(data.raw.recipe[recipe_name].normal, old, new) | ||||
|     replace_ingredient(data.raw.recipe[recipe_name].expensive, old, new) | ||||
|     replace_ingredient(data.raw.recipe[recipe_name], old, new, amount) | ||||
|     replace_ingredient(data.raw.recipe[recipe_name].normal, old, new, amount) | ||||
|     replace_ingredient(data.raw.recipe[recipe_name].expensive, old, new, amount) | ||||
|   end | ||||
| end | ||||
| 
 | ||||
| function replace_ingredient(recipe, old, new) | ||||
| function replace_ingredient(recipe, old, new, amount) | ||||
| 	if recipe ~= nil and recipe.ingredients ~= nil then | ||||
|     for i, existing in pairs(recipe.ingredients) do | ||||
|       if existing[1] == new or existing.name == new then | ||||
|         log("Not adding "..new.." -- duplicate") | ||||
|         return | ||||
|       end | ||||
|     end | ||||
| 		for i, ingredient in pairs(recipe.ingredients) do  | ||||
| 			if ingredient.name == old then ingredient.name = new end | ||||
| 			if ingredient[1] == old then ingredient[1] = new end | ||||
| 			if ingredient.name == old then  | ||||
|         ingredient.name = new  | ||||
|         if amount then ingredient.amount = amount end | ||||
|       end | ||||
| 			if ingredient[1] == old then  | ||||
|         ingredient[1] = new | ||||
|         if amount then ingredient[2] = amount end | ||||
|       end | ||||
| 		end | ||||
| 	end | ||||
| end | ||||
|  | @ -338,7 +400,6 @@ function replace_some_ingredient(recipe, old, old_amount, new, new_amount, is_fl | |||
| 	if recipe ~= nil and recipe.ingredients ~= nil then | ||||
|     for i, existing in pairs(recipe.ingredients) do | ||||
|       if existing[1] == new or existing.name == new then | ||||
|         log("Not adding "..new.." -- duplicate") | ||||
|         return | ||||
|       end | ||||
|     end | ||||
|  | @ -354,6 +415,46 @@ function replace_some_ingredient(recipe, old, old_amount, new, new_amount, is_fl | |||
| 	end | ||||
| end | ||||
| 
 | ||||
| -- set the amount of a product.  | ||||
| function util.set_product_amount(recipe_name, product, amount) | ||||
|   me.add_modified(recipe_name) | ||||
|   if data.raw.recipe[recipe_name] then | ||||
|     if me.bypass[recipe_name] then return end | ||||
|     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].expensive, product, amount) | ||||
| 	end | ||||
| end | ||||
| 
 | ||||
| function set_product_amount(recipe, product, amount) | ||||
|   if recipe then | ||||
|     if recipe.result_count then | ||||
|       recipe.result_count = amount | ||||
|     end | ||||
|     if recipe.results then | ||||
|       for i, result in pairs(recipe.results) do | ||||
|         if result.name == product then | ||||
|           if result.amount then | ||||
|             result.amount = amount | ||||
|           end | ||||
|           if result.amount_min ~= nil then | ||||
|             result.amount_min =  nil | ||||
|             result.amount_max =  nil | ||||
|             result.amount = amount | ||||
|           end | ||||
|         end | ||||
|         if result[1] == product then | ||||
|           result[2] = amount | ||||
|         end | ||||
|       end | ||||
|     end | ||||
|     if not recipe.results and not recipe.result_count then | ||||
|       -- implicit one item result | ||||
|       recipe.result_count = amount | ||||
|     end | ||||
|   end | ||||
| end | ||||
| 
 | ||||
| -- multiply the cost, energy, and results of a recipe by a multiple | ||||
| function util.multiply_recipe(recipe_name, multiple) | ||||
|   me.add_modified(recipe_name) | ||||
|  | @ -510,6 +611,25 @@ function util.remove_raw(t, name) | |||
|   end | ||||
| end | ||||
| 
 | ||||
| -- Set energy required | ||||
| function util.set_recipe_time(recipe_name, time) | ||||
|   me.add_modified(recipe_name) | ||||
|   if data.raw.recipe[recipe_name] then | ||||
|     if me.bypass[recipe_name] then return end | ||||
|     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].expensive, time) | ||||
| 	end | ||||
| end | ||||
| 
 | ||||
| function set_recipe_time(recipe, time) | ||||
|   if recipe then | ||||
|     if recipe.energy_required then | ||||
|       recipe.energy_required = time | ||||
|     end | ||||
|   end | ||||
| end | ||||
| 
 | ||||
| -- Multiply energy required | ||||
| function util.multiply_time(recipe_name, factor) | ||||
|   me.add_modified(recipe_name) | ||||
|  | @ -551,7 +671,7 @@ end | |||
| -- Set recipe category | ||||
| function util.set_category(recipe_name, category) | ||||
|   if me.bypass[recipe_name] then return end | ||||
|   if data.raw.recipe[recipe_name] then | ||||
|   if data.raw.recipe[recipe_name] and data.raw["recipe-category"][category] then | ||||
|     me.add_modified(recipe_name) | ||||
|     data.raw.recipe[recipe_name].category = category | ||||
|   end | ||||
|  | @ -601,10 +721,9 @@ end | |||
| 
 | ||||
| -- Add crafting category to an entity | ||||
| function util.add_crafting_category(entity_type, entity, category) | ||||
|    if data.raw[entity_type][entity] then | ||||
|    if data.raw[entity_type][entity] and data.raw["recipe-category"][category] then | ||||
|       for i, existing in pairs(data.raw[entity_type][entity].crafting_categories) do | ||||
|         if existing == category then | ||||
|           log(entity.." not adding "..category.." -- duplicate") | ||||
|           return | ||||
|         end | ||||
|       end | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Brevven
						Brevven