forked from minetest/minetest_game
Bones: Iterate player inventory lists dynamically (#1229)
Avoid hard-coded player inventory lists. Expose `bones.player_inventory_lists` for mods to look up or change, which player inventory lists are being dropped or placed into bones.
This commit is contained in:
parent
094ad004a4
commit
283636bfdb
@ -67,6 +67,15 @@ Beds API
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Bones API
|
||||||
|
---------
|
||||||
|
|
||||||
|
An ordered list of listnames (default: "main", "craft") of the player inventory,
|
||||||
|
that will be placed into bones or dropped on player death can be looked up or changed
|
||||||
|
in `bones.player_inventory_lists`.
|
||||||
|
|
||||||
|
e.g. `table.insert(bones.player_inventory_lists, "backpack")`
|
||||||
|
|
||||||
Creative API
|
Creative API
|
||||||
------------
|
------------
|
||||||
|
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
-- Minetest 0.4 mod: bones
|
-- Minetest 0.4 mod: bones
|
||||||
-- See README.txt for licensing and other information.
|
-- See README.txt for licensing and other information.
|
||||||
|
|
||||||
|
bones = {}
|
||||||
|
|
||||||
local function is_owner(pos, name)
|
local function is_owner(pos, name)
|
||||||
local owner = minetest.get_meta(pos):get_string("owner")
|
local owner = minetest.get_meta(pos):get_string("owner")
|
||||||
if owner == "" or owner == name or minetest.check_player_privs(name, "protection_bypass") then
|
if owner == "" or owner == name or minetest.check_player_privs(name, "protection_bypass") then
|
||||||
@ -165,6 +167,18 @@ local drop = function(pos, itemstack)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local player_inventory_lists = { "main", "craft" }
|
||||||
|
bones.player_inventory_lists = player_inventory_lists
|
||||||
|
|
||||||
|
local function is_all_empty(player_inv)
|
||||||
|
for _, list_name in ipairs(player_inventory_lists) do
|
||||||
|
if not player_inv:is_empty(list_name) then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
minetest.register_on_dieplayer(function(player)
|
minetest.register_on_dieplayer(function(player)
|
||||||
|
|
||||||
local bones_mode = minetest.settings:get("bones_mode") or "bones"
|
local bones_mode = minetest.settings:get("bones_mode") or "bones"
|
||||||
@ -179,8 +193,7 @@ minetest.register_on_dieplayer(function(player)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local player_inv = player:get_inventory()
|
local player_inv = player:get_inventory()
|
||||||
if player_inv:is_empty("main") and
|
if is_all_empty(player_inv) then
|
||||||
player_inv:is_empty("craft") then
|
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -198,19 +211,12 @@ minetest.register_on_dieplayer(function(player)
|
|||||||
end
|
end
|
||||||
|
|
||||||
if bones_mode == "drop" then
|
if bones_mode == "drop" then
|
||||||
|
for _, list_name in ipairs(player_inventory_lists) do
|
||||||
-- drop inventory items
|
for i = 1, player_inv:get_size(list_name) do
|
||||||
for i = 1, player_inv:get_size("main") do
|
drop(pos, player_inv:get_stack(list_name, i))
|
||||||
drop(pos, player_inv:get_stack("main", i))
|
|
||||||
end
|
end
|
||||||
player_inv:set_list("main", {})
|
player_inv:set_list(list_name, {})
|
||||||
|
|
||||||
-- drop crafting grid items
|
|
||||||
for i = 1, player_inv:get_size("craft") do
|
|
||||||
drop(pos, player_inv:get_stack("craft", i))
|
|
||||||
end
|
end
|
||||||
player_inv:set_list("craft", {})
|
|
||||||
|
|
||||||
drop(pos, ItemStack("bones:bones"))
|
drop(pos, ItemStack("bones:bones"))
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
@ -221,20 +227,18 @@ minetest.register_on_dieplayer(function(player)
|
|||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
local inv = meta:get_inventory()
|
local inv = meta:get_inventory()
|
||||||
inv:set_size("main", 8 * 4)
|
inv:set_size("main", 8 * 4)
|
||||||
inv:set_list("main", player_inv:get_list("main"))
|
|
||||||
|
|
||||||
for i = 1, player_inv:get_size("craft") do
|
for _, list_name in ipairs(player_inventory_lists) do
|
||||||
local stack = player_inv:get_stack("craft", i)
|
for i = 1, player_inv:get_size(list_name) do
|
||||||
|
local stack = player_inv:get_stack(list_name, i)
|
||||||
if inv:room_for_item("main", stack) then
|
if inv:room_for_item("main", stack) then
|
||||||
inv:add_item("main", stack)
|
inv:add_item("main", stack)
|
||||||
else
|
else -- no space left
|
||||||
--drop if no space left
|
|
||||||
drop(pos, stack)
|
drop(pos, stack)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
player_inv:set_list(list_name, {})
|
||||||
player_inv:set_list("main", {})
|
end
|
||||||
player_inv:set_list("craft", {})
|
|
||||||
|
|
||||||
meta:set_string("formspec", bones_formspec)
|
meta:set_string("formspec", bones_formspec)
|
||||||
meta:set_string("owner", player_name)
|
meta:set_string("owner", player_name)
|
||||||
|
Loading…
Reference in New Issue
Block a user