bypass setting
This commit is contained in:
		
							parent
							
								
									ce9cb905d0
								
							
						
					
					
						commit
						54d6241679
					
				
					 5 changed files with 106 additions and 10 deletions
				
			
		|  | @ -1,4 +1,9 @@ | ||||||
| --------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------- | ||||||
|  | Version: 0.0.5 | ||||||
|  | Date: 2021-06-16 | ||||||
|  |   Features: | ||||||
|  |     - Recipe bypass setting | ||||||
|  | --------------------------------------------------------------------------------------------------- | ||||||
| Version: 0.0.4 | Version: 0.0.4 | ||||||
| Date: 2021-06-15 | Date: 2021-06-15 | ||||||
|   Features: |   Features: | ||||||
|  |  | ||||||
|  | @ -1,12 +1,6 @@ | ||||||
| local util = {} | local util = {} | ||||||
| 
 | 
 | ||||||
| function util.get_setting(name) | util.name = "bzzirconium" | ||||||
|   if settings.startup[name] == nil then |  | ||||||
|     return nil |  | ||||||
|   end |  | ||||||
|   return settings.startup[name].value |  | ||||||
| end |  | ||||||
| 
 |  | ||||||
| 
 | 
 | ||||||
| function util.fe_plus(sub) | function util.fe_plus(sub) | ||||||
|   if mods["FactorioExtended-Plus-"..sub] then |   if mods["FactorioExtended-Plus-"..sub] then | ||||||
|  | @ -18,6 +12,20 @@ function util.use_cermet() | ||||||
|   return util.get_setting("bzzirconium-enable-intermediates") == "yes" |   return util.get_setting("bzzirconium-enable-intermediates") == "yes" | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
|  | function util.get_setting(name) | ||||||
|  |   if settings.startup[name] == nil then | ||||||
|  |     return nil | ||||||
|  |   end | ||||||
|  |   return settings.startup[name].value | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | local bypass = {} | ||||||
|  | if util.get_setting(util.name.."-recipe-bypass") then  | ||||||
|  |   for recipe in string.gmatch(util.get_setting(util.name.."-recipe-bypass"), '[^",%s]+') do | ||||||
|  |     bypass[recipe] = true | ||||||
|  |   end | ||||||
|  | end | ||||||
|  | 
 | ||||||
| function util.get_stack_size(default)  | function util.get_stack_size(default)  | ||||||
|   if mods["Krastorio2"] then |   if mods["Krastorio2"] then | ||||||
|     size = tonumber(krastorio.general.getSafeSettingValue("kr-stack-size")) |     size = tonumber(krastorio.general.getSafeSettingValue("kr-stack-size")) | ||||||
|  | @ -83,6 +91,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 bypass[recipe_name] then return end | ||||||
|   if data.raw.recipe[recipe_name] then |   if data.raw.recipe[recipe_name] then | ||||||
|     add_ingredient(data.raw.recipe[recipe_name], ingredient, quantity) |     add_ingredient(data.raw.recipe[recipe_name], ingredient, quantity) | ||||||
|     add_ingredient(data.raw.recipe[recipe_name].normal, ingredient, quantity) |     add_ingredient(data.raw.recipe[recipe_name].normal, ingredient, quantity) | ||||||
|  | @ -92,6 +101,12 @@ end | ||||||
| 
 | 
 | ||||||
| function add_ingredient(recipe, ingredient, quantity) | function add_ingredient(recipe, ingredient, quantity) | ||||||
|   if recipe ~= nil and recipe.ingredients ~= nil then |   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 | ||||||
|     table.insert(recipe.ingredients, {ingredient, quantity}) |     table.insert(recipe.ingredients, {ingredient, quantity}) | ||||||
|   end |   end | ||||||
| end | end | ||||||
|  | @ -114,6 +129,7 @@ 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) | function util.replace_ingredient(recipe_name, old, new) | ||||||
|  |   if bypass[recipe_name] then return end | ||||||
|   if data.raw.recipe[recipe_name] then |   if data.raw.recipe[recipe_name] then | ||||||
|     replace_ingredient(data.raw.recipe[recipe_name], old, new) |     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].normal, old, new) | ||||||
|  | @ -123,6 +139,12 @@ end | ||||||
| 
 | 
 | ||||||
| function replace_ingredient(recipe, old, new) | function replace_ingredient(recipe, old, new) | ||||||
| 	if recipe ~= nil and recipe.ingredients ~= nil then | 	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  | 		for i, ingredient in pairs(recipe.ingredients) do  | ||||||
| 			if ingredient.name == old then ingredient.name = new end | 			if ingredient.name == old then ingredient.name = new end | ||||||
| 			if ingredient[1] == old then ingredient[1] = new end | 			if ingredient[1] == old then ingredient[1] = new end | ||||||
|  | @ -132,6 +154,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 bypass[recipe_name] then return end | ||||||
|   if data.raw.recipe[recipe_name] then |   if data.raw.recipe[recipe_name] then | ||||||
|     remove_ingredient(data.raw.recipe[recipe_name], old) |     remove_ingredient(data.raw.recipe[recipe_name], old) | ||||||
|     remove_ingredient(data.raw.recipe[recipe_name].normal, old) |     remove_ingredient(data.raw.recipe[recipe_name].normal, old) | ||||||
|  | @ -157,6 +180,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 bypass[recipe_name] then return end | ||||||
|   if data.raw.recipe[recipe_name] then |   if data.raw.recipe[recipe_name] then | ||||||
|     replace_some_ingredient(data.raw.recipe[recipe_name], old, old_amount, new, new_amount) |     replace_some_ingredient(data.raw.recipe[recipe_name], old, old_amount, new, new_amount) | ||||||
|     replace_some_ingredient(data.raw.recipe[recipe_name].normal, old, old_amount, new, new_amount) |     replace_some_ingredient(data.raw.recipe[recipe_name].normal, old, old_amount, new, new_amount) | ||||||
|  | @ -166,6 +190,12 @@ end | ||||||
| 
 | 
 | ||||||
| function replace_some_ingredient(recipe, old, old_amount, new, new_amount) | function replace_some_ingredient(recipe, old, old_amount, new, new_amount) | ||||||
| 	if recipe ~= nil and recipe.ingredients ~= nil then | 	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  | 		for i, ingredient in pairs(recipe.ingredients) do  | ||||||
| 			-- For final fixes | 			-- For final fixes | ||||||
| 			if ingredient.name == old then | 			if ingredient.name == old then | ||||||
|  | @ -180,5 +210,58 @@ function replace_some_ingredient(recipe, old, old_amount, new, new_amount) | ||||||
| 	end | 	end | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
|  | -- multiply the cost, energy, and results of a recipe by a multiple | ||||||
|  | function util.multiply_recipe(recipe_name, multiple) | ||||||
|  |   if bypass[recipe_name] then return end | ||||||
|  |   if data.raw.recipe[recipe_name] then | ||||||
|  |     multiply_recipe(data.raw.recipe[recipe_name], multiple) | ||||||
|  |     multiply_recipe(data.raw.recipe[recipe_name].normal, multiple) | ||||||
|  |     multiply_recipe(data.raw.recipe[recipe_name].expensive, multiple) | ||||||
|  | 	end | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | function multiply_recipe(recipe, multiple) | ||||||
|  |   if recipe then | ||||||
|  |     if recipe.energy_required then | ||||||
|  |       recipe.energy_required = recipe.energy_required * multiple | ||||||
|  |     end | ||||||
|  |     if recipe.result_count then | ||||||
|  |       recipe.result_count = recipe.result_count * multiple | ||||||
|  |     end | ||||||
|  |     if recipe.results then | ||||||
|  |       for i, result in pairs(recipe.results) do | ||||||
|  |         if result.name then | ||||||
|  |           if result.amount then | ||||||
|  |             result.amount = result.amount * multiple | ||||||
|  |           end | ||||||
|  |           if result.amount_min ~= nil then | ||||||
|  |             result.amount_min = result.amount_min * multiple | ||||||
|  |             result.amount_max = result.amount_max * multiple | ||||||
|  |           end | ||||||
|  |           if result.catalyst_amount then | ||||||
|  |             result.catalyst_amount = result.catalyst_amount * multiple | ||||||
|  |           end | ||||||
|  |         end | ||||||
|  |         if result[1] then | ||||||
|  |           result[2] = result[2] * multiple | ||||||
|  |         end | ||||||
|  |       end | ||||||
|  |     end | ||||||
|  |     if not recipe.results and not recipe.result_count then | ||||||
|  |       -- implicit one item result | ||||||
|  |       recipe.result_count = multiple | ||||||
|  |     end | ||||||
|  |     if recipe.ingredients then | ||||||
|  |       for i, ingredient in pairs(recipe.ingredients) do | ||||||
|  |         if ingredient.name then | ||||||
|  |           ingredient.amount = ingredient.amount * multiple | ||||||
|  |         end | ||||||
|  |         if ingredient[1] then | ||||||
|  |           ingredient[2] = ingredient[2] * multiple | ||||||
|  |         end | ||||||
|  |       end | ||||||
|  |     end | ||||||
|  |   end | ||||||
|  | end | ||||||
| 
 | 
 | ||||||
| return util | return util | ||||||
|  |  | ||||||
|  | @ -1,6 +1,6 @@ | ||||||
| { | { | ||||||
|     "name": "bzzirconium", |     "name": "bzzirconium", | ||||||
|     "version": "0.0.4", |     "version": "0.0.5", | ||||||
|     "factorio_version": "1.1", |     "factorio_version": "1.1", | ||||||
|     "title": "Zirconium", |     "title": "Zirconium", | ||||||
|     "author": "Brevven", |     "author": "Brevven", | ||||||
|  |  | ||||||
|  | @ -50,6 +50,8 @@ dirty-water-filtration-zircon=Filter dirty water, giving zircon [item=zircon] an | ||||||
| 
 | 
 | ||||||
| # Settings | # Settings | ||||||
| [mod-setting-name] | [mod-setting-name] | ||||||
|  | bzzirconium-recipe-bypass=Bypass recipes | ||||||
| bzzirconium-enable-intermediates=Enable cermet | bzzirconium-enable-intermediates=Enable cermet | ||||||
| [mod-setting-description] | [mod-setting-description] | ||||||
|  | bzzirconium-recipe-bypass=Skip modifying these recipes (comma-separated list). | ||||||
| bzzirconium-enable-intermediates=Enable cermet, an advanced intermediate made from ceramics and metals. | bzzirconium-enable-intermediates=Enable cermet, an advanced intermediate made from ceramics and metals. | ||||||
|  |  | ||||||
							
								
								
									
										10
									
								
								settings.lua
									
										
									
									
									
								
							
							
						
						
									
										10
									
								
								settings.lua
									
										
									
									
									
								
							|  | @ -1,5 +1,11 @@ | ||||||
| data:extend( | data:extend({ | ||||||
| { |   { | ||||||
|  | 		type = "string-setting", | ||||||
|  | 		name = "bzzirconium-recipe-bypass", | ||||||
|  | 		setting_type = "startup", | ||||||
|  | 		default_value = "", | ||||||
|  |     allow_blank = true, | ||||||
|  | 	}, | ||||||
|   { |   { | ||||||
| 		type = "string-setting", | 		type = "string-setting", | ||||||
| 		name = "bzzirconium-enable-intermediates", | 		name = "bzzirconium-enable-intermediates", | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Brevven
						Brevven