Integrate into vanilla
This commit is contained in:
		
							parent
							
								
									9181598e38
								
							
						
					
					
						commit
						6652ec2b86
					
				
					 5 changed files with 126 additions and 1 deletions
				
			
		
							
								
								
									
										1
									
								
								data-final-fixes.lua
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								data-final-fixes.lua
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1 @@ | |||
| -- require("silicon-recipe-final") | ||||
							
								
								
									
										1
									
								
								data-updates.lua
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								data-updates.lua
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1 @@ | |||
| require("recipe-updates") | ||||
|  | @ -9,6 +9,6 @@ | |||
|     "dependencies": [ | ||||
| 	    "base >= 0.18" | ||||
|     ], | ||||
|     "description": "Adds simple Silica and Silicon to the game." | ||||
|     "description": "Adds simple Silica and Silicon to the game, along with basic fiber optics." | ||||
| } | ||||
| 
 | ||||
|  |  | |||
							
								
								
									
										37
									
								
								recipe-updates.lua
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										37
									
								
								recipe-updates.lua
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,37 @@ | |||
| local util = require("__bzsilicon__.util"); | ||||
| 
 | ||||
| util.remove_ingredient("concrete", "stone-brick"); | ||||
| util.add_ingredient("concrete", "silica", 25); | ||||
| util.add_prerequisite("concrete", "silica-processing") | ||||
| 
 | ||||
| util.replace_some_ingredient("processing-unit", "electronic-circuit", "silicon", 10) | ||||
| util.add_prerequisite("advanced-electronics-2", "silicon-processing") | ||||
| 
 | ||||
| util.replace_some_ingredient("solar-panel", "electronic-circuit", "silicon", 10) | ||||
| util.add_prerequisite("solar-energy", "silicon-processing") | ||||
| 
 | ||||
| util.replace_ingredient("effectivity-module", "electronic-circuit", "silicon") | ||||
| util.replace_ingredient("productivity-module", "electronic-circuit", "silicon") | ||||
| util.replace_ingredient("speed-module", "electronic-circuit", "silicon") | ||||
| util.add_prerequisite("modules", "silicon-processing") | ||||
| 
 | ||||
| util.replace_ingredient("beacon", "copper-cable", "optical-fiber") | ||||
| util.add_prerequisite("effect-transmission", "fiber-optics") | ||||
| 
 | ||||
| 
 | ||||
| -- Circuit network changes | ||||
| util.replace_ingredient("green-wire", "copper-cable", "optical-fiber") | ||||
| util.replace_ingredient("green-wire", "electronic-circuit", "silicon") | ||||
| util.replace_ingredient("red-wire", "copper-cable", "optical-fiber") | ||||
| util.replace_ingredient("red-wire", "electronic-circuit", "silicon") | ||||
| 
 | ||||
| util.add_ingredient("arithmetic-combinator", "silicon", 1); | ||||
| util.add_ingredient("arithmetic-combinator", "optical-fiber", 1); | ||||
| util.add_ingredient("constant-combinator", "silicon", 1); | ||||
| util.add_ingredient("constant-combinator", "optical-fiber", 1); | ||||
| util.add_ingredient("decider-combinator", "silicon", 1); | ||||
| util.add_ingredient("decider-combinator", "optical-fiber", 1); | ||||
| util.add_ingredient("programmable-speaker", "optical-fiber", 1); | ||||
| 
 | ||||
| util.add_prerequisite("circuit-network", "fiber-optics") | ||||
| util.add_prerequisite("circuit-network", "silicon-processing") | ||||
							
								
								
									
										86
									
								
								util.lua
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										86
									
								
								util.lua
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,86 @@ | |||
| local util = {} | ||||
| 
 | ||||
| -- Add a prerequisite to a given technology | ||||
| function util.add_prerequisite(technology_name, prerequisite) | ||||
|   technology = data.raw.technology[technology_name] | ||||
| 	table.insert(technology.prerequisites, prerequisite) | ||||
| end | ||||
| 
 | ||||
| -- Add a given quantity of ingredient to a given recipe | ||||
| function util.add_ingredient(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].expensive, ingredient, quantity) | ||||
| end | ||||
| 
 | ||||
| function add_ingredient(recipe, ingredient, quantity) | ||||
|   if recipe ~= nil and recipe.ingredients ~= nil then | ||||
|     table.insert(recipe.ingredients, {ingredient, quantity}) | ||||
|   end | ||||
| end | ||||
| 
 | ||||
| -- Replace one ingredien with another in a recipe | ||||
| function util.replace_ingredient(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].expensive, old, new) | ||||
| end | ||||
| 
 | ||||
| function replace_ingredient(recipe, old, new) | ||||
| 	if recipe ~= nil and recipe.ingredients ~= nil then | ||||
| 		for i, ingredient in pairs(recipe.ingredients) do  | ||||
| 			-- For final fixes | ||||
| 			if ingredient.name == old then ingredient.name = new end | ||||
| 			-- For updates | ||||
| 			if ingredient[1] == old then ingredient[1] = new end | ||||
| 		end | ||||
| 	end | ||||
| end | ||||
| 
 | ||||
| -- Remove an ingredient from a recipe | ||||
| function util.remove_ingredient(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].expensive, old) | ||||
| end | ||||
| 
 | ||||
| function remove_ingredient(recipe, old) | ||||
|   index = -1 | ||||
| 	if recipe ~= nil and recipe.ingredients ~= nil then | ||||
| 		for i, ingredient in pairs(recipe.ingredients) do  | ||||
|       if ingredient.name == old or ingredient[1] == old then | ||||
|         index = i | ||||
|         break | ||||
|       end | ||||
|     end | ||||
|     if index > -1 then | ||||
|       table.remove(recipe.ingredients, index) | ||||
|     end | ||||
|   end | ||||
| end | ||||
| 
 | ||||
| 
 | ||||
| -- Replace an amount of an ingredient in a recipe. Keep at least 1 of old. | ||||
| function util.replace_some_ingredient(recipe_name, old, new, amount) | ||||
|   replace_some_ingredient(data.raw.recipe[recipe_name], old, new, amount) | ||||
|   replace_some_ingredient(data.raw.recipe[recipe_name].normal, old, new, amount) | ||||
|   replace_some_ingredient(data.raw.recipe[recipe_name].expensive, old, new, amount) | ||||
| end | ||||
| 
 | ||||
| function replace_some_ingredient(recipe, old, new, amount) | ||||
| 	if recipe ~= nil and recipe.ingredients ~= nil then | ||||
| 		for i, ingredient in pairs(recipe.ingredients) do  | ||||
| 			-- For final fixes | ||||
| 			if ingredient.name == old then | ||||
|         ingredient.amount = math.max(1, ingredient.amount - amount) | ||||
|       end | ||||
| 			-- For updates | ||||
| 			if ingredient[1] == old then | ||||
|         ingredient[2] = math.max(1, ingredient[2] - amount) | ||||
|       end | ||||
| 		end | ||||
|     add_ingredient(recipe, new, amount) | ||||
| 	end | ||||
| end | ||||
| 
 | ||||
| return util | ||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Brevven
						Brevven