version
This commit is contained in:
		
							parent
							
								
									4b0a15343e
								
							
						
					
					
						commit
						bba553ca6f
					
				
					 4 changed files with 130 additions and 7 deletions
				
			
		|  | @ -25,3 +25,4 @@ Thanks to | ||||||
| - [Sakuro](https://github.com/sakuro) (ja) | - [Sakuro](https://github.com/sakuro) (ja) | ||||||
| - [PlexPt](https://github.com/PlexPt) (zh\_CN) | - [PlexPt](https://github.com/PlexPt) (zh\_CN) | ||||||
| - [S3BA](https://github.com/S3BA-pl) (pl) | - [S3BA](https://github.com/S3BA-pl) (pl) | ||||||
|  | - [x2605](https://github.com/x2605) (ko) | ||||||
|  |  | ||||||
|  | @ -1,4 +1,9 @@ | ||||||
| --------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------- | ||||||
|  | Version: 0.9.1 | ||||||
|  | Date: 2022-01-08 | ||||||
|  |   Features: | ||||||
|  |     - Korean (ko) l10n, thanks to x2605 | ||||||
|  | --------------------------------------------------------------------------------------------------- | ||||||
| Version: 0.9.0 | Version: 0.9.0 | ||||||
| Date: 2022-01-08 | Date: 2022-01-08 | ||||||
|   Features: |   Features: | ||||||
|  |  | ||||||
							
								
								
									
										125
									
								
								data-util.lua
									
										
									
									
									
								
							
							
						
						
									
										125
									
								
								data-util.lua
									
										
									
									
									
								
							|  | @ -17,6 +17,12 @@ else | ||||||
|   util.titanium_plate = "titanium-plate" |   util.titanium_plate = "titanium-plate" | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
|  | if mods["pyrawores"] then  | ||||||
|  |   util.titanium_processing = "titanium-mk01" | ||||||
|  | else | ||||||
|  |   util.titanium_processing = "titanium-processing" | ||||||
|  | end | ||||||
|  | 
 | ||||||
| function util.fe_plus(sub) | function util.fe_plus(sub) | ||||||
|   if mods["FactorioExtended-Plus-"..sub] then |   if mods["FactorioExtended-Plus-"..sub] then | ||||||
|     return true |     return true | ||||||
|  | @ -64,7 +70,7 @@ end | ||||||
| function util.remove_prerequisite(technology_name, prerequisite) | function util.remove_prerequisite(technology_name, prerequisite) | ||||||
|   local technology = data.raw.technology[technology_name] |   local technology = data.raw.technology[technology_name] | ||||||
|   local index = -1 |   local index = -1 | ||||||
|   if technology and data.raw.technology[prerequisite] then |   if technology then | ||||||
|     for i, prereq in pairs(technology.prerequisites) do |     for i, prereq in pairs(technology.prerequisites) do | ||||||
|       if prereq == prerequisite then |       if prereq == prerequisite then | ||||||
|         index = i |         index = i | ||||||
|  | @ -83,8 +89,13 @@ function util.add_effect(technology_name, effect) | ||||||
|   local technology = data.raw.technology[technology_name] |   local technology = data.raw.technology[technology_name] | ||||||
|   if technology then |   if technology then | ||||||
|     if not technology.effects then technology.effects = {} end |     if not technology.effects then technology.effects = {} end | ||||||
|  |     if effect and effect.type == "unlock-recipe" then | ||||||
|  |       if not data.raw.recipe[effect.recipe] then | ||||||
|  |         return | ||||||
|  |       end | ||||||
|       table.insert(technology.effects, effect) |       table.insert(technology.effects, effect) | ||||||
|     end |     end | ||||||
|  |   end | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| -- remove recipe unlock effect from a given technology | -- remove recipe unlock effect from a given technology | ||||||
|  | @ -120,6 +131,29 @@ function util.set_enabled(recipe_name, enabled) | ||||||
|   end |   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 | ||||||
|  |   if data.raw.recipe[recipe_name] and data.raw.item[ingredient] then | ||||||
|  |     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].normal, ingredient, quantity) | ||||||
|  |     add_or_add_to_ingredient(data.raw.recipe[recipe_name].expensive, ingredient, quantity) | ||||||
|  |   end | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | function add_or_add_to_ingredient(recipe, ingredient, quantity) | ||||||
|  |   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 | ||||||
|  |         add_to_ingredient(recipe, ingredient, quantity) | ||||||
|  |         return | ||||||
|  |       end | ||||||
|  |     end | ||||||
|  |     table.insert(recipe.ingredients, {ingredient, quantity}) | ||||||
|  |   end | ||||||
|  | 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 me.bypass[recipe_name] then return end | ||||||
|  | @ -143,6 +177,58 @@ function add_ingredient(recipe, ingredient, quantity) | ||||||
|   end |   end | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
|  | -- Add a given ingredient prototype to a given recipe | ||||||
|  | function util.add_ingredient_raw(recipe_name, ingredient) | ||||||
|  |   if me.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 | ||||||
|  |     me.add_modified(recipe_name) | ||||||
|  |     add_ingredient_raw(data.raw.recipe[recipe_name], ingredient) | ||||||
|  |     add_ingredient_raw(data.raw.recipe[recipe_name].normal, ingredient) | ||||||
|  |     add_ingredient_raw(data.raw.recipe[recipe_name].expensive, ingredient) | ||||||
|  |   end | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | function add_ingredient_raw(recipe, ingredient) | ||||||
|  |   if recipe ~= nil and recipe.ingredients ~= nil then | ||||||
|  |     for i, existing in pairs(recipe.ingredients) do | ||||||
|  |       if ( | ||||||
|  |           (existing[1] and (existing[1] == ingredient[1] or existing[1] == ingredient.name)) or  | ||||||
|  |           (existing.name and (existing.name == ingredient[1] or existing.name == ingredient.name)) | ||||||
|  |       ) then | ||||||
|  |         return | ||||||
|  |       end | ||||||
|  |     end | ||||||
|  |     table.insert(recipe.ingredients, ingredient) | ||||||
|  |   end | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | -- Set an ingredient to a given quantity | ||||||
|  | function util.set_ingredient(recipe_name, ingredient, quantity) | ||||||
|  |   if me.bypass[recipe_name] then return end | ||||||
|  |   if data.raw.recipe[recipe_name] and data.raw.item[ingredient] then | ||||||
|  |     me.add_modified(recipe_name) | ||||||
|  |     set_ingredient(data.raw.recipe[recipe_name], ingredient, quantity) | ||||||
|  |     set_ingredient(data.raw.recipe[recipe_name].normal, ingredient, quantity) | ||||||
|  |     set_ingredient(data.raw.recipe[recipe_name].expensive, ingredient, quantity) | ||||||
|  |   end | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | function set_ingredient(recipe, ingredient, quantity) | ||||||
|  |   if recipe ~= nil and recipe.ingredients ~= nil then | ||||||
|  |     for i, existing in pairs(recipe.ingredients) do | ||||||
|  |       if existing[1] == ingredient  then | ||||||
|  |         existing[2] = quantity | ||||||
|  |         return | ||||||
|  |       elseif existing.name == ingredient then | ||||||
|  |         existing.amount = quantity | ||||||
|  |         existing.amount_min = nil | ||||||
|  |         existing.amount_max = nil | ||||||
|  |         return | ||||||
|  |       end | ||||||
|  |     end | ||||||
|  |     table.insert(recipe.ingredients, {ingredient, quantity}) | ||||||
|  |   end | ||||||
|  | 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) | ||||||
|  | @ -154,9 +240,16 @@ function util.add_product(recipe_name, product) | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| function add_product(recipe, product) | function add_product(recipe, product) | ||||||
|   if recipe ~= nil and recipe.results ~= nil then |   if recipe ~= nil then | ||||||
|  |     if not recipe.normal then | ||||||
|  |       if recipe.results == nil then | ||||||
|  |         recipe.results = {{recipe.result, recipe.result_count and recipe.result_count or 1}} | ||||||
|  |       end | ||||||
|  |       recipe.result = nil | ||||||
|  |       recipe.result_count = nil | ||||||
|       table.insert(recipe.results, product) |       table.insert(recipe.results, product) | ||||||
|     end |     end | ||||||
|  |   end | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
| -- Replace one ingredient with another in a recipe | -- Replace one ingredient with another in a recipe | ||||||
|  | @ -365,6 +458,10 @@ end | ||||||
| 
 | 
 | ||||||
| -- Remove an element of type t and name from data.raw | -- Remove an element of type t and name from data.raw | ||||||
| function util.remove_raw(t, name) | function util.remove_raw(t, name) | ||||||
|  |   if not data.raw[t] then  | ||||||
|  |     log(t.." not found in data.raw") | ||||||
|  |     return | ||||||
|  |   end | ||||||
|   if data.raw[t][name] then |   if data.raw[t][name] then | ||||||
|     for i, elem in pairs(data.raw[t]) do |     for i, elem in pairs(data.raw[t]) do | ||||||
|       if elem.name == name then  |       if elem.name == name then  | ||||||
|  | @ -431,6 +528,26 @@ function util.set_subgroup(recipe_name, subgroup) | ||||||
|   end |   end | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
|  | -- Set recipe icons | ||||||
|  | function util.set_icons(recipe_name, icons) | ||||||
|  |   if me.bypass[recipe_name] then return end | ||||||
|  |   if data.raw.recipe[recipe_name] then | ||||||
|  |     me.add_modified(recipe_name) | ||||||
|  |     data.raw.recipe[recipe_name].icons = icons | ||||||
|  |     data.raw.recipe[recipe_name].icon = nil | ||||||
|  |     data.raw.recipe[recipe_name].icon_size = nil | ||||||
|  |   end | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | -- Set recipe icons | ||||||
|  | function util.set_item_icons(item_name, icons) | ||||||
|  |   if data.raw.recipe[item_name] then | ||||||
|  |     data.raw.recipe[item_name].icons = icons | ||||||
|  |     data.raw.recipe[item_name].icon = nil | ||||||
|  |     data.raw.recipe[item_name].icon_size = nil | ||||||
|  |   end | ||||||
|  | end | ||||||
|  | 
 | ||||||
| function util.set_to_founding(recipe) | function util.set_to_founding(recipe) | ||||||
|   util.set_category(recipe, "founding") |   util.set_category(recipe, "founding") | ||||||
|   util.set_subgroup(recipe, "foundry-intermediate") |   util.set_subgroup(recipe, "foundry-intermediate") | ||||||
|  | @ -441,7 +558,7 @@ function util.add_crafting_category(entity_type, entity, category) | ||||||
|    if data.raw[entity_type][entity] then |    if data.raw[entity_type][entity] then | ||||||
|       for i, existing in pairs(data.raw[entity_type][entity].crafting_categories) do |       for i, existing in pairs(data.raw[entity_type][entity].crafting_categories) do | ||||||
|         if existing == category then |         if existing == category then | ||||||
|           log(entity.." not adding "..new.." -- duplicate") |           log(entity.." not adding "..category.." -- duplicate") | ||||||
|           return |           return | ||||||
|         end |         end | ||||||
|       end |       end | ||||||
|  | @ -465,7 +582,7 @@ function add_to_ingredient(recipe, it, amount) | ||||||
|         return |         return | ||||||
|       end |       end | ||||||
| 			if ingredient[1] == it then | 			if ingredient[1] == it then | ||||||
|         ingredient[2] = ingredients[2] + amount |         ingredient[2] = ingredient[2] + amount | ||||||
|         return |         return | ||||||
|       end |       end | ||||||
| 		end | 		end | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| { | { | ||||||
|     "name": "bzsilicon", |     "name": "bzsilicon", | ||||||
|     "version": "0.9.0", |     "version": "0.9.1", | ||||||
|     "factorio_version": "1.1", |     "factorio_version": "1.1", | ||||||
|     "title": "Silica & Silicon", |     "title": "Silica & Silicon", | ||||||
|     "author": "Brevven", |     "author": "Brevven", | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Brevven
						Brevven