SE compatibility fixes

This commit is contained in:
Simon Brodtmann 2025-10-06 15:21:47 +02:00
parent aecda9e46d
commit 960200bc7a
3 changed files with 29 additions and 105 deletions

View file

@ -8,7 +8,7 @@ util.add_product("jellynut-processing", util.item("jellyskin", 1, .25)) -- in c
util.replace_some_ingredient("se-glass-vulcanite", "sand", 1, "tin-plate", 1) util.replace_some_ingredient("se-glass-vulcanite", "sand", 1, "tin-plate", 1)
util.add_product("se-glass-vulcanite", {type="item", name="tin-plate", amount=1, catalyst_amount=1, probability=0.8}) util.add_product("se-glass-vulcanite", {type="item", name="tin-plate", amount=1, catalyst_amount=1, probability=0.8})
util.set_main_product("se-glass-vulcanite", "glass") util.set_main_product("se-glass-vulcanite", mods["Krastorio2"] and "kr-glass" or "glass")
-- core mining balancing -- core mining balancing
util.add_to_product("se-core-fragment-omni", "tin-ore", -4) util.add_to_product("se-core-fragment-omni", "tin-ore", -4)

View file

@ -504,8 +504,8 @@ function util.se_landfill(params)
category = "hard-recycling", category = "hard-recycling",
order = "z-b-"..params.ore, order = "z-b-"..params.ore,
subgroup = "terrain", subgroup = "terrain",
result = "landfill", results = {{type="item", name="landfill", amount=1}},
ingredients = {{params.ore, 50}}, ingredients = {{type="item", name=params.ore, amount=50}},
} }
}) })
util.add_unlock("se-recycling-facility", lname) util.add_unlock("se-recycling-facility", lname)
@ -584,7 +584,6 @@ end
-- se matter -- se matter
-- params: ore, energy_required, quant_out, quant_in, icon_size, stream_out -- params: ore, energy_required, quant_out, quant_in, icon_size, stream_out
function util.se_matter(params) function util.se_matter(params)
if mods["space-exploration"] > "0.6" then
if not params.quant_in then params.quant_in = params.quant_out end if not params.quant_in then params.quant_in = params.quant_out end
if not params.icon_size then params.icon_size = 64 end if not params.icon_size then params.icon_size = 64 end
local fname = "matter-fusion-"..params.ore local fname = "matter-fusion-"..params.ore
@ -611,15 +610,15 @@ function util.se_matter(params)
energy_required = params.energy_required, energy_required = params.energy_required,
enabled = false, enabled = false,
ingredients = { ingredients = {
{sedata, 1}, {type="item", name=sedata, amount=1},
{type="fluid", name="se-particle-stream", amount=50}, {type="fluid", name="se-particle-stream", amount=50},
{type="fluid", name="se-space-coolant-supercooled", amount=25}, {type="fluid", name="se-space-coolant-supercooled", amount=25},
}, },
results = { results = {
{params.ore, params.quant_out}, {type="item", name=params.ore, amount=params.quant_out},
{"se-contaminated-scrap", 1}, {type="item", name="se-contaminated-scrap", amount=1},
{type=item, name=sedata, amount=1, probability=.99}, {type="item", name=sedata, amount=1, probability=.99},
{type=item, name=sejunk, amount=1, probability=.01}, {type="item", name=sejunk, amount=1, probability=.01},
{type="fluid", name="se-space-coolant-hot", amount=25, ignored_by_stats=25, ignored_by_productivity=25}, {type="fluid", name="se-space-coolant-hot", amount=25, ignored_by_stats=25, ignored_by_productivity=25},
} }
} }
@ -650,13 +649,13 @@ function util.se_matter(params)
energy_required = 30, energy_required = 30,
enabled = false, enabled = false,
ingredients = { ingredients = {
{"se-kr-matter-liberation-data", 1}, {type="item", name="se-kr-matter-liberation-data", amount=1},
{params.ore, params.quant_in}, {type="item", name=params.ore, amount=params.quant_in},
{type="fluid", name="se-particle-stream", amount=50}, {type="fluid", name="se-particle-stream", amount=50},
}, },
results = { results = {
{type=item, name="se-kr-matter-liberation-data", amount=1, probability=.99}, {type="item", name="se-kr-matter-liberation-data", amount=1, probability=.99},
{type=item, name=sejunk, amount=1, probability=.01}, {type="item", name=sejunk, amount=1, probability=.01},
{type="fluid", name="se-particle-stream", amount=params.stream_out, ignored_by_stats=50, ignored_by_productivity=50}, {type="fluid", name="se-particle-stream", amount=params.stream_out, ignored_by_stats=50, ignored_by_productivity=50},
} }
} }
@ -684,7 +683,7 @@ function util.se_matter(params)
{"se-astronomic-science-pack-4", 1}, {"se-astronomic-science-pack-4", 1},
{"se-energy-science-pack-4", 1}, {"se-energy-science-pack-4", 1},
{"se-material-science-pack-4", 1}, {"se-material-science-pack-4", 1},
{"matter-tech-card", 1}, {"kr-matter-tech-card", 1},
{"se-deep-space-science-pack-1", 1}, {"se-deep-space-science-pack-1", 1},
} }
@ -696,7 +695,6 @@ function util.se_matter(params)
util.add_unlock("bz-advanced-stream-production", lname) util.add_unlock("bz-advanced-stream-production", lname)
end end
end end
end
-- deprecated -- deprecated
-- Get the normal prototype for a recipe -- either .normal or the recipe itself -- Get the normal prototype for a recipe -- either .normal or the recipe itself
@ -1119,7 +1117,6 @@ end
function replace_some_product(recipe, old, old_amount, new, new_amount) function replace_some_product(recipe, old, old_amount, new, new_amount)
if recipe ~= nil then if recipe ~= nil then
if recipe.result == new then return end
if recipe.results then if recipe.results then
for i, existing in pairs(recipe.results) do for i, existing in pairs(recipe.results) do
if existing.name == new then if existing.name == new then
@ -1211,10 +1208,6 @@ function set_product_amount(recipe, product, amount)
end end
end end
end end
if not recipe.results and not recipe.result_count then
-- implicit one item result
recipe.result_count = amount
end
end end
end end
@ -1348,10 +1341,6 @@ function replace_product(recipe, old, new, options)
if recipe.main_product == old then if recipe.main_product == old then
recipe.main_product = new recipe.main_product = new
end end
if recipe.result == old then
recipe.result = new
return
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 == old then result.name = new end if result.name == old then result.name = new end
@ -1611,10 +1600,6 @@ end
function add_to_product(recipe, product, amount) function add_to_product(recipe, product, amount)
if recipe ~= nil and recipe.results ~= nil then if recipe ~= nil and recipe.results ~= nil then
if recipe.result == product then
recipe.result_count = recipe.result_count + amount
return
end
for i, result in pairs(recipe.results) do for i, result in pairs(recipe.results) do
if result.name == product then if result.name == product then
result.amount = result.amount + amount result.amount = result.amount + amount
@ -1823,7 +1808,6 @@ function util.sum_products(recipe_name)
-- this is going to end up approximate in some cases, integer division is probs fine -- this is going to end up approximate in some cases, integer division is probs fine
if data.raw.recipe[recipe_name] then if data.raw.recipe[recipe_name] then
local recipe = data.raw.recipe[recipe_name] local recipe = data.raw.recipe[recipe_name]
if not recipe.results then return recipe.result_count end
local sum = 0 local sum = 0
for i, result in pairs(recipe.results) do for i, result in pairs(recipe.results) do
local amt = 0 local amt = 0
@ -1896,12 +1880,14 @@ function util.redo_recycling()
-- Find all recycling recipes that result in armor and make sure not to output more than 1 -- Find all recycling recipes that result in armor and make sure not to output more than 1
for _, recipe in pairs(data.raw.recipe) do for _, recipe in pairs(data.raw.recipe) do
if recipe.name:find("recycling") then if recipe.name:find("recycling") then
for _, product in pairs(recipe.results) do if recipe.results then
if data.raw.armor[product.name] then for _, product in pairs(recipe.results) do
if product.amount then if data.raw.armor[product.name] then
if product.amount > .99 then if product.amount then
product.amount = 1 if product.amount > .99 then
product.extra_count_fraction = nil product.amount = 1
product.extra_count_fraction = nil
end
end end
end end
end end

View file

@ -6,7 +6,6 @@ if mods["space-exploration"] then
se_delivery_cannon_recipes["tin-plate"] = {name= "tin-plate"} se_delivery_cannon_recipes["tin-plate"] = {name= "tin-plate"}
util.se_landfill({ore="tin-ore"}) util.se_landfill({ore="tin-ore"})
if string.sub(mods["space-exploration"], 1, 3) == "0.6" then
util.se_matter({ore="tin-ore", energy_required=1, quant_out=10, stream_out=60}) util.se_matter({ore="tin-ore", energy_required=1, quant_out=10, stream_out=60})
data:extend({ data:extend({
{ {
@ -50,7 +49,7 @@ if string.sub(mods["space-exploration"], 1, 3) == "0.6" then
}, },
energy_required = 45, energy_required = 45,
ingredients = { ingredients = {
{name = mods.Krastorio2 and "enriched-tin" or "tin-ore", amount = 24}, {type = "item", name = mods.Krastorio2 and "enriched-tin" or "tin-ore", amount = 24},
{type = "fluid", name = "se-pyroflux", amount = 10}, {type = "fluid", name = "se-pyroflux", amount = 10},
}, },
enabled = false, enabled = false,
@ -62,7 +61,7 @@ if string.sub(mods["space-exploration"], 1, 3) == "0.6" then
type = "recipe", type = "recipe",
name = "tin-ingot", name = "tin-ingot",
category = "casting", category = "casting",
results = {{"tin-ingot", 1}}, results = {{type = "item", name = "tin-ingot", amount = 1}},
energy_required = 18.75, energy_required = 18.75,
ingredients = { ingredients = {
{type = "fluid", name = "molten-tin", amount = 250}, {type = "fluid", name = "molten-tin", amount = 250},
@ -81,11 +80,11 @@ if string.sub(mods["space-exploration"], 1, 3) == "0.6" then
{icon = "__bztin__/graphics/icons/tin-ingot.png", icon_size = 128, scale = 0.125, shift = {-8, -8}}, {icon = "__bztin__/graphics/icons/tin-ingot.png", icon_size = 128, scale = 0.125, shift = {-8, -8}},
}, },
results = { results = {
{name = "tin-plate", amount = 10}, {type = "item", name = "tin-plate", amount = 10},
}, },
energy_required = 3.75, energy_required = 3.75,
ingredients = { ingredients = {
{name = "tin-ingot", amount = 1} {type = "item", name = "tin-ingot", amount = 1}
}, },
enabled = false, enabled = false,
always_show_made_in = true, always_show_made_in = true,
@ -106,65 +105,4 @@ if string.sub(mods["space-exploration"], 1, 3) == "0.6" then
end end
se_delivery_cannon_recipes["tin-ingot"] = {name= "tin-ingot"} se_delivery_cannon_recipes["tin-ingot"] = {name= "tin-ingot"}
else
data.raw.item["tin-plate"].subgroup = "plates"
if mods["Krastorio2"] then
data:extend({
{
type = "recipe",
name = "enriched-tin-smelting-vulcanite",
category = "smelting",
order = "d[tin-plate]",
energy_required = 18,
enabled = false,
always_show_made_in = true,
allow_as_intermediate = false,
ingredients = {
{name = "enriched-tin", amount = 8},
{name = "se-vulcanite-block", amount = 1},
},
results = {
{name = "tin-plate", amount = 12},
},
icons =
{
{ icon = "__bztin__/graphics/icons/tin-plate.png", icon_size = 128},
{ icon = "__space-exploration-graphics__/graphics/icons/vulcanite-block.png", icon_size = 64, scale=0.25, shift= {-10, -10}},
},
},
})
table.insert(data.raw.technology["se-processing-vulcanite"].effects,
{type = "unlock-recipe", recipe= "enriched-tin-smelting-vulcanite"})
data.raw.recipe["enriched-tin-plate"].order= "d[tin-plate]"
se_delivery_cannon_recipes["enriched-tin"] = {name= "enriched-tin"}
else
data:extend({
{
type = "recipe",
name = "tin-smelting-vulcanite",
category = "smelting",
order = "d[tin-plate]",
energy_required = 18,
enabled = false,
always_show_made_in = true,
allow_as_intermediate = false,
ingredients = {
{name = "tin-ore", amount = 8},
{name = "se-vulcanite-block", amount = 1},
},
results = {
{name = "tin-plate", amount = 12},
},
icons =
{
{ icon = "__bztin__/graphics/icons/tin-plate.png", icon_size = 128},
{ icon = "__space-exploration-graphics__/graphics/icons/vulcanite-block.png", icon_size = 64, scale=0.25, shift= {-10, -10}},
},
},
})
table.insert(data.raw.technology["se-processing-vulcanite"].effects,
{type = "unlock-recipe", recipe= "tin-smelting-vulcanite"})
end
end
end end