mirror of
https://github.com/minetest/minetest_game.git
synced 2025-01-24 14:20:19 +01:00
fixes as per code review completed (3)
This commit is contained in:
parent
eeec7d6be0
commit
5141c96c01
@ -6,8 +6,10 @@
|
|||||||
-- Load support for MT game translation.
|
-- Load support for MT game translation.
|
||||||
local S = minetest.get_translator("bones")
|
local S = minetest.get_translator("bones")
|
||||||
|
|
||||||
local theoretical_max_slots = minetest.settings:get("bones_max_slots") or 15 * 10
|
local bones_max_slots = minetest.settings:get("bones_max_slots") or 15 * 10
|
||||||
local dead_player_callbacks={}
|
local dead_player_callbacks={}
|
||||||
|
-- we're going to display no less than 4*8 slots, we'll also provide at least 4*8 slots in bones
|
||||||
|
local min_inv_size = 4 * 8
|
||||||
|
|
||||||
bones = {}
|
bones = {}
|
||||||
|
|
||||||
@ -32,15 +34,15 @@ end
|
|||||||
|
|
||||||
local function get_bones_formspec_for_size(numitems)
|
local function get_bones_formspec_for_size(numitems)
|
||||||
--the absolute minimum is 4*8
|
--the absolute minimum is 4*8
|
||||||
if numitems <= 4 * 8 then
|
if numitems <= min_inv_size then
|
||||||
return get_bones_formspec_wh(8, 4)
|
return get_bones_formspec_wh(8, 4)
|
||||||
end
|
end
|
||||||
--if we're over 4*8, but below 4*15 we make it 4 rows and adjust the column count to make everything fit
|
--if we're over 4*8, but below 4*15 we make it 4 rows and adjust the column count to make everything fit
|
||||||
if numitems <= 4 * 15 then
|
if numitems <= 4 * 15 then
|
||||||
return get_bones_formspec_wh(math.floor((numitems + 3) / 4), 4)
|
return get_bones_formspec_wh(math.ceil(numitems / 4), 4)
|
||||||
end
|
end
|
||||||
--if we're over 4*15 we'll make 15 columns and adjust the row count to make everything fit
|
--if we're over 4*15 we'll make 15 columns and adjust the row count to make everything fit
|
||||||
return get_bones_formspec_wh(15, math.floor ((numitems + 14) / 15))
|
return get_bones_formspec_wh(15, math.ceil(numitems / 15))
|
||||||
end
|
end
|
||||||
|
|
||||||
local share_bones_time = tonumber(minetest.settings:get("share_bones_time")) or 1200
|
local share_bones_time = tonumber(minetest.settings:get("share_bones_time")) or 1200
|
||||||
@ -267,7 +269,7 @@ minetest.register_on_dieplayer(function(player)
|
|||||||
bones_meta = minetest.get_meta(bones_pos)
|
bones_meta = minetest.get_meta(bones_pos)
|
||||||
bones_inv = bones_meta:get_inventory()
|
bones_inv = bones_meta:get_inventory()
|
||||||
--make it so big that anything reasonable will for sure fit inside
|
--make it so big that anything reasonable will for sure fit inside
|
||||||
bones_inv:set_size("main", theoretical_max_slots)
|
bones_inv:set_size("main", bones_max_slots)
|
||||||
else
|
else
|
||||||
bones_mode = "drop"
|
bones_mode = "drop"
|
||||||
bones_pos = nil
|
bones_pos = nil
|
||||||
@ -283,45 +285,46 @@ minetest.register_on_dieplayer(function(player)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local bones_conclusion
|
local log_message
|
||||||
local public_conclusion
|
local chat_message
|
||||||
|
|
||||||
if not bones_pos then
|
if bones_pos then
|
||||||
drop(player_pos, ItemStack("bones:bones"))
|
if dropped then
|
||||||
if not dropped then
|
log_message = "Inventory partially dropped"
|
||||||
bones_conclusion = "No bones placed"
|
chat_message = "@1 died at @2, and partially dropped their inventory."
|
||||||
public_conclusion = S("@1 died at @2.", player_name, pos_string)
|
|
||||||
else
|
else
|
||||||
bones_conclusion = "Inventory dropped"
|
log_message = "Bones placed"
|
||||||
public_conclusion = S("@1 died at @2, and dropped their inventory.", player_name, pos_string)
|
chat_message = "@1 died at @2, and bones were placed."
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if not dropped then
|
drop(player_pos, ItemStack("bones:bones"))
|
||||||
bones_conclusion = "Bones placed"
|
if dropped then
|
||||||
public_conclusion = S("@1 died at @2, and bones were placed.", player_name, pos_string)
|
log_message = "Inventory dropped"
|
||||||
|
chat_message = "@1 died at @2, and dropped their inventory."
|
||||||
else
|
else
|
||||||
bones_conclusion = "Inventory partially dropped"
|
log_message = "No bones placed"
|
||||||
public_conclusion = S("@1 died at @2, and partially dropped their inventory.", player_name, pos_string)
|
chat_message = "@1 died at @2."
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if bones_position_message then
|
if bones_position_message then
|
||||||
minetest.chat_send_player(player_name, public_conclusion)
|
chat_message = S(chat_message, player_name, pos_string)
|
||||||
|
minetest.chat_send_player(player_name, chat_message)
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.log("action", player_name .. " dies at " .. pos_string .. ". " .. bones_conclusion)
|
minetest.log("action", player_name .. " dies at " .. pos_string .. ". " .. log_message)
|
||||||
|
|
||||||
if bones_inv then
|
if bones_inv then
|
||||||
local inv_size = theoretical_max_slots
|
local inv_size = bones_max_slots
|
||||||
for i = 1, theoretical_max_slots do
|
for i = 1, bones_max_slots do
|
||||||
local stack = bones_inv:get_stack("main", i)
|
local stack = bones_inv:get_stack("main", i)
|
||||||
if stack:get_count() == 0 then
|
if stack:get_count() == 0 then
|
||||||
inv_size = i - 1
|
inv_size = i - 1
|
||||||
break
|
break
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if inv_size <= 4 * 8 then
|
if inv_size <= min_inv_size then
|
||||||
bones_inv:set_size("main", 4 * 8)
|
bones_inv:set_size("main", min_inv_size)
|
||||||
else
|
else
|
||||||
bones_inv:set_size("main", inv_size)
|
bones_inv:set_size("main", inv_size)
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user