mirror of
https://github.com/FaceDeer/dfcaverns.git
synced 2025-01-26 10:00:22 +01:00
12919e9a16
* cave pearls and spindleshrooms (name subject to change) now are things. Not in mapgen yet. * add the wandering "gas wisp" to light up some of the gas-filled caverns * make wisps rarely spawned by gas explosions * revamp spindlestems into a sort of mineral detector, add glowing extract bottles * optimize pngs * add gas wisps to mapgen * add spindlestems to cavern level 1, most level 1 warrens are now lit up * update internal names, adjust mineral detection range * add cave pearls to some level 2 warrens and tunnels * switch experimental simplecrafting_lib support to crafting mod * Pearls don't grow on falling nodes * put spindlestems with goblin caps, make them always grow red when near those * bunch of documentation * add castle coral to replace cave coral, which has been repurposed into column decoration * documentation for cave coral, update some locale text * add a recipe for cooking oil into paraffin * add old bones to the underworld * MIT license for bones_loot * also cook black cap gills into paraffin, they're oily * add salt crystals to the bloodthorn caverns, illuminating the floor * documentation for salt crystals * auto-generate minetestmapper colors. need to update the spindlestem colours manually * add spindlestem to fungiwood caverns too, and increase warren coverage * in anticipation of eventually adding stuff below the Slade, making glowing pit erosion self-limiting. * add a bit of displacement to the underside of the slade layer * Unique images and names for cooking recipes. * revamp bones loot * add softer footsteps for some fungus types * update mapgen_helper * update cave coral screenshot * mention glowing salts in bloodthorn caverns
126 lines
3.6 KiB
Lua
126 lines
3.6 KiB
Lua
-- internationalization boilerplate
|
|
local MP = minetest.get_modpath(minetest.get_current_modname())
|
|
local S, NS = dofile(MP.."/intllib.lua")
|
|
|
|
local dungeon_loot_path = minetest.get_modpath("dungeon_loot")
|
|
|
|
bones_loot = {}
|
|
|
|
local local_loot = {}
|
|
local local_loot_register = function(t)
|
|
if t.name ~= nil then
|
|
t = {t} -- single entry
|
|
end
|
|
for _, loot in ipairs(t) do
|
|
table.insert(local_loot, loot)
|
|
end
|
|
end
|
|
|
|
-- we could do this for the dungeon_loot registered loot table as well,
|
|
-- but best not to meddle in other mods' internals if it can be helped.
|
|
local clean_up_local_loot = function()
|
|
if local_loot == nil then return end
|
|
for i = #local_loot, 1, -1 do
|
|
if not minetest.registered_items[local_loot[i].name] then
|
|
table.remove(local_loot, i)
|
|
end
|
|
end
|
|
end
|
|
|
|
-- Uses same table format as dungeon_loot
|
|
-- eg, {name = "bucket:bucket_water", chance = 0.45, types = {"sandstone", "desert"}},
|
|
-- if dungeon_loot is installed it uses dungeon_loot's registration function directly.
|
|
if dungeon_loot_path then
|
|
bones_loot.register_loot = dungeon_loot.register
|
|
else
|
|
bones_loot.register_loot = local_loot_register
|
|
minetest.after(0, clean_up_local_loot)
|
|
end
|
|
|
|
local get_loot_list = function(pos, loot_type, exclusive_loot_type)
|
|
local loot_table
|
|
if dungeon_loot_path then
|
|
loot_table = dungeon_loot.registered_loot
|
|
else
|
|
loot_table = local_loot
|
|
end
|
|
|
|
local item_list = {}
|
|
local pos_y = pos.y
|
|
for _, loot in ipairs(loot_table) do
|
|
if loot.y == nil or (pos_y >= loot.y[1] and pos_y <= loot.y[2]) then
|
|
if (not exclusive_loot_type and loot.types == nil) or
|
|
(loot.types and table.indexof(loot.types, loot_type) ~= -1) then
|
|
table.insert(item_list, loot)
|
|
end
|
|
end
|
|
end
|
|
|
|
return item_list
|
|
end
|
|
|
|
local shuffle = function(tbl)
|
|
for i = #tbl, 2, -1 do
|
|
local rand = math.random(i)
|
|
tbl[i], tbl[rand] = tbl[rand], tbl[i]
|
|
end
|
|
return tbl
|
|
end
|
|
|
|
-- "exclusive" set to true means that loot table entries without a loot_type won't be considered.
|
|
bones_loot.get_loot = function(pos, loot_type, max_stacks, exclusive_loot_type)
|
|
local item_list = get_loot_list(pos, loot_type, exclusive_loot_type)
|
|
shuffle(item_list)
|
|
|
|
-- apply chances / randomized amounts and collect resulting items
|
|
local items = {}
|
|
for _, loot in ipairs(item_list) do
|
|
if math.random() <= loot.chance then
|
|
local itemdef = minetest.registered_items[loot.name]
|
|
if itemdef then
|
|
local amount = 1
|
|
if loot.count ~= nil then
|
|
amount = math.random(loot.count[1], loot.count[2])
|
|
end
|
|
|
|
if itemdef.tool_capabilities then
|
|
for n = 1, amount do
|
|
local wear = math.random(0.20 * 65535, 0.75 * 65535) -- 20% to 75% wear
|
|
table.insert(items, ItemStack({name = loot.name, wear = wear}))
|
|
max_stacks = max_stacks - 1
|
|
if max_stacks <= 0 then break end
|
|
end
|
|
else
|
|
local stack_max = itemdef.stack_max
|
|
while amount > 0 do
|
|
table.insert(items, ItemStack({name = loot.name, count = math.min(stack_max, amount)}))
|
|
amount = amount - stack_max
|
|
max_stacks = max_stacks - 1
|
|
if max_stacks <= 0 then break end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
if max_stacks <= 0 then break end
|
|
end
|
|
return items
|
|
end
|
|
|
|
bones_loot.place_bones = function(pos, loot_type, max_stacks, infotext, exclusive_loot_type)
|
|
minetest.set_node(pos, {name="bones:bones", param2 = math.random(1,4)-1})
|
|
local meta = minetest.get_meta(pos)
|
|
if infotext == nil then
|
|
infotext = S("Someone's old bones")
|
|
end
|
|
meta:set_string("infotext", infotext)
|
|
|
|
if max_stacks and max_stacks > 0 then
|
|
local loot = bones_loot.get_loot(pos, loot_type, max_stacks, exclusive_loot_type)
|
|
local inv = meta:get_inventory()
|
|
inv:set_size("main", 8 * 4)
|
|
for _, item in ipairs(loot) do
|
|
inv:add_item("main", item)
|
|
end
|
|
end
|
|
end
|