This commit is contained in:
Brevven 2025-01-13 21:36:18 -08:00
parent 13b901511d
commit a28d6cc985

View file

@ -2,6 +2,7 @@
-- This file will be overwritten in mod zipfiles, edit bzlib/data-util.lua -- This file will be overwritten in mod zipfiles, edit bzlib/data-util.lua
-- WARNING WARNING WARNING -- WARNING WARNING WARNING
local futil = require("util")
local me = require("me") local me = require("me")
local util = {} local util = {}
@ -117,6 +118,15 @@ function util.contains(table, sought)
return false return false
end end
-- copies a recipe, giving the copy a new name
function util.copy_recipe(recipe_name, new_recipe_name)
if data.raw.recipe[recipe_name] then
new_recipe = futil.table.deepcopy(data.raw.recipe[recipe_name])
new_recipe.name = new_recipe_name
data:extend({new_recipe})
end
end
-- Add the gleba rock. If it exists, still add resource to mine from it -- Add the gleba rock. If it exists, still add resource to mine from it
function util.add_gleba_rock(resource, amount_min, amount_max) function util.add_gleba_rock(resource, amount_min, amount_max)
if (not data.raw.planet.gleba or if (not data.raw.planet.gleba or
@ -368,6 +378,30 @@ function util.use_fluid_mining_final()
util.remove_raw("technology", "uranium-mining") util.remove_raw("technology", "uranium-mining")
end end
-- Add vacuum if it hasn't been added yet
function util.add_vacuum()
if not data.raw.fluid.vacuum then
data:extend({
{
type = "fluid",
name = "vacuum",
icons = { util.vacuum_icon, },
visualization_color = util.vacuum_vis,
subgroup = "fluid",
order = "d[vacuum]",
default_temperature = 1500,
max_temperature = 2000,
gas_temperature = 0,
heat_capacity = "0.01kJ",
base_color = {0.9, 0.9, 0.9},
flow_color = {0.8, 0.8, 0.9},
auto_barrel = false,
},
})
end
end
-- If Hot metals mod is enabled, mark these metals as hot -- If Hot metals mod is enabled, mark these metals as hot
function util.add_hot_metals(metals) function util.add_hot_metals(metals)
if HotMetals and HotMetals.items then if HotMetals and HotMetals.items then
@ -1093,9 +1127,6 @@ function multiply_recipe(recipe, multiple)
else else
recipe.energy_required = 0.5 * multiple -- 0.5 is factorio default recipe.energy_required = 0.5 * multiple -- 0.5 is factorio default
end end
if recipe.result_count then
recipe.result_count = recipe.result_count * multiple
end
if recipe.results then if recipe.results then
for i, result in pairs(recipe.results) do for i, result in pairs(recipe.results) do
if result.name then if result.name then
@ -1112,10 +1143,22 @@ function multiply_recipe(recipe, multiple)
end end
end end
end end
if not recipe.results and not recipe.result_count then multiply_ingredients(recipe, multiple)
-- implicit one item result
recipe.result_count = multiple
end end
end
-- multiply the ingredient cost of a recipe
function util.multiply_ingredients(recipe_name, multiple, options)
if not should_force(options) and bypass(recipe_name) then return end
if data.raw.recipe[recipe_name] then
me.add_modified(recipe_name)
prepare_redo_recycling(recipe_name)
multiply_ingredients(data.raw.recipe[recipe_name], multiple)
end
end
function multiply_ingredients(recipe, multiple)
if recipe then
if recipe.ingredients then if recipe.ingredients then
for i, ingredient in pairs(recipe.ingredients) do for i, ingredient in pairs(recipe.ingredients) do
if ingredient.name then if ingredient.name then
@ -1276,6 +1319,13 @@ function add_time(recipe, amount)
end end
end end
-- Set localised name
function util.set_localised_name(recipe_name, localised_name)
if data.raw.recipe[recipe_name] then
data.raw.recipe[recipe_name].localised_name = localised_name
end
end
-- Set recipe category -- Set recipe category
function util.set_category(recipe_name, category, options) function util.set_category(recipe_name, category, options)
if not should_force(options) and bypass(recipe_name) then return end if not should_force(options) and bypass(recipe_name) then return end
@ -1466,12 +1516,14 @@ function util.add_minable_result(t, name, result)
if data.raw[t] and data.raw[t][name] and data.raw[t][name].minable then if data.raw[t] and data.raw[t][name] and data.raw[t][name].minable then
if data.raw[t][name].minable.result and not data.raw[t][name].minable.results then if data.raw[t][name].minable.result and not data.raw[t][name].minable.results then
data.raw[t][name].minable.results = { data.raw[t][name].minable.results = {
{data.raw[t][name].minable.result ,data.raw[t][name].minable.count}} util.item(data.raw[t][name].minable.result ,data.raw[t][name].minable.count)}
data.raw[t][name].minable.result = nil data.raw[t][name].minable.result = nil
data.raw[t][name].minable.result_count = nil data.raw[t][name].minable.result_count = nil
end end
if data.raw[t][name].minable.results then if data.raw[t][name].minable.results then
table.insert(data.raw[t][name].minable.results, result) table.insert(data.raw[t][name].minable.results, result)
else
data.raw[t][name].minable.results = {result}
end end
end end
end end