add some mapgen stuff

This commit is contained in:
FaceDeer 2022-08-03 19:22:41 -06:00
parent 69aac15eb3
commit bb6cb4efa1
5 changed files with 119 additions and 39 deletions

View File

@ -1,9 +1,19 @@
local S = minetest.get_translator(minetest.get_current_modname())
df_dependencies.register_leafdecay = default.register_leafdecay
df_dependencies.after_place_leaves = default.after_place_leaves
if minetest.get_modpath("default") then
df_dependencies.register_leafdecay = default.register_leafdecay
df_dependencies.after_place_leaves = default.after_place_leaves
else
--TODO
end
df_dependencies.bucket_register_liquid = bucket.register_liquid
df_dependencies.mods_required.bucket = true
if minetest.get_modpath("bucket") then
df_dependencies.bucket_register_liquid = bucket.register_liquid
else
-- TODO
end
-- Note that a circular table reference will result in a crash, TODO: guard against that.
@ -21,6 +31,10 @@ local function deep_copy(table_in)
return table_out
end
df_dependencies.mods_required.stairs = true
df_dependencies.mods_required.moreblocks = true
df_dependencies.mods_required.doors = true
df_dependencies.register_all_stairs = function(name, override_def)
local mod = minetest.get_current_modname()
@ -57,6 +71,7 @@ df_dependencies.register_all_fences = function (name, override_def)
local burntime = override_def.burntime
if minetest.get_modpath("default") then
default.register_fence(material .. "_fence", {
description = S("@1 Fence", node_def.description),
texture = override_def.texture or node_def.tiles[1],
@ -94,6 +109,9 @@ df_dependencies.register_all_fences = function (name, override_def)
groups = deep_copy(node_def.groups or {}), -- the default register_fence_rail function modifies the groups table passed in, so send a copy instead to be on the safe side.
sounds = node_def.sounds
})
else
-- TODO
end
if minetest.get_modpath("doors") then
doors.register_fencegate(material .. "_fence_gate", {
@ -111,5 +129,8 @@ df_dependencies.register_all_fences = function (name, override_def)
burntime = burntime * 2, -- ignoring four sticks
})
end
else
-- TODO
end
end

View File

@ -1,7 +1,7 @@
df_dependencies = {}
local modpath = minetest.get_modpath(minetest.get_current_modname())
local mods_required = {}
df_dependencies.mods_required = {}
df_dependencies.select_required = function(def)
local count = 0
@ -9,7 +9,7 @@ df_dependencies.select_required = function(def)
local ret
for mod, item in pairs(def) do
total = total + 1
mods_required[mod] = true
df_dependencies.mods_required[mod] = true
if minetest.get_modpath(mod) then
count = count + 1
ret = item
@ -34,7 +34,7 @@ dofile(modpath.."/sounds.lua")
dofile(modpath.."/helper_functions.lua")
dofile(modpath.."/misc.lua")
minetest.debug(dump(mods_required))
minetest.debug(dump(df_dependencies.mods_required))
-- This mod is meant to only exist at initialization time. Other mods should make copies of anything it points to for their own use.
minetest.after(1, function() df_dependencies = nil end)

View File

@ -38,3 +38,52 @@ df_dependencies.texture_stone = select_required({default="default_stone.png", mc
df_dependencies.texture_wood = select_required({default="default_wood.png", mcl_core="default_wood.png"})
df_dependencies.texture_mineral_coal = select_required({default="default_mineral_coal.png", mcl_core="mcl_core_coal_ore.png"}) -- MCL's coal texture isn't transparent, but is only used with gas seeps and should work fine that way
df_dependencies.texture_glass_bottle = select_required({vessels="vessels_glass_bottle.png", mcl_potions="mcl_potions_potion_bottle.png"})
df_dependencies.mods_required.mcl_vars = true
df_dependencies.mods_required.mcl_worlds = true
df_dependencies.mods_required.mcl_strongholds = true
if minetest.get_modpath("mcl_vars") then
local prefix = "dfcaverns_"
-- NOTE: These defaults are from df_caverns' config. Update them if those change.
local lowest_elevation = tonumber(minetest.settings:get(prefix.."sunless_sea_min")) or -2512
if minetest.settings:get_bool(prefix.."enable_oil_sea", true) then
lowest_elevation = (tonumber(minetest.settings:get(prefix.."oil_sea_level")) or -2700)
end
if minetest.settings:get_bool(prefix.."enable_lava_sea", true) then
lowest_elevation = (tonumber(minetest.settings:get(prefix.."lava_sea_level")) or -2900)
end
if minetest.settings:get_bool(prefix.."enable_underworld", true) then
lowest_elevation = (tonumber(minetest.settings:get(prefix.."underworld_level")) or -3200)
end
if minetest.settings:get_bool(prefix.."enable_primordial", true) then
lowest_elevation = (tonumber(minetest.settings:get(prefix.."primordial_min")) or -4032)
end
lowest_elevation = lowest_elevation - 193 -- add a little buffer space
local old_overworld_min = mcl_vars.mg_overworld_min -- rememeber this for weather control
mcl_vars.mg_overworld_min = lowest_elevation
mcl_vars.mg_bedrock_overworld_min = mcl_vars.mg_overworld_min
mcl_vars.mg_lava_overworld_max = mcl_vars.mg_overworld_min + 10
mcl_vars.mg_end_max = mcl_vars.mg_overworld_min - 2000
-- Important note. This doesn't change the values for the various ores and mobs and biomes and whatnot that have already been registered.
-- to keep things consistent, add dependencies to
if minetest.get_modpath("mcl_worlds") then
mcl_worlds.has_weather = function(pos)
-- Weather in the Overworld. No weather in the deep caverns
return pos.y <= mcl_vars.mg_overworld_max and pos.y >= old_overworld_min
end
end
dofile(minetest.get_modpath(minetest.get_current_modname()).."/ores.lua")
-- never mind - add dependency on mcl_strongholds and these will get generated before overworld_min gets changed.
--if minetest.get_modpath("mcl_structures") and minetest.get_modpath("mcl_strongholds") then
-- local elevation_delta = old_overworld_min - lowest_elevation
-- local strongholds = mcl_structures.get_structure_data("stronghold")
-- mcl_structures.register_structure_data("stronghold", strongholds)
--end
end

8
df_dependencies/ores.lua Normal file
View File

@ -0,0 +1,8 @@
-- copied from mcl_mapgen_core with tweaked altitudes to cover the added depth
if minetest.settings:get_bool("mcl_generate_ores", true) then
end

View File

@ -3,6 +3,8 @@ local S = minetest.get_translator(minetest.get_current_modname())
local select_required = df_dependencies.select_required
local select_optional = df_dependencies.select_optional
df_dependencies.mods_required.mcl_sounds = true
if minetest.get_modpath("default") then
df_dependencies.sound_dirt = default.node_sound_dirt_defaults
df_dependencies.sound_glass = default.node_sound_glass_defaults