From 5812e5473c869e851c2b9d57c0ec73dafa9fcb1c Mon Sep 17 00:00:00 2001 From: mckaygerhard Date: Mon, 24 Jul 2023 14:27:52 -0400 Subject: [PATCH] mods - hudbars+hbarmor+hunger - detection of original mods * detection of original mods and bypass build-in own features * optimize loading of hubar for armor, bad initialization * real check player becouse of wrong implementation at engine --- mods/hudbars/init.lua | 316 ++++++++++++++++++++++++------------------ 1 file changed, 178 insertions(+), 138 deletions(-) diff --git a/mods/hudbars/init.lua b/mods/hudbars/init.lua index 9987ea9..ca8c2d5 100644 --- a/mods/hudbars/init.lua +++ b/mods/hudbars/init.lua @@ -65,6 +65,9 @@ hbarmor.autohide = true hb.settings = {} +hb.hba = minetest.get_modpath("hbarmor") +hb.hbh = minetest.get_modpath("hbhunger") + function hb.load_setting(sname, stype, defaultval, valid_values) local sval if stype == "string" then @@ -99,39 +102,43 @@ end -- Load default settings dofile(minetest.get_modpath("hudbars").."/default_settings.lua") --- due lackof global hbhunger these need to be first -hbhunger.get_hunger_raw = function(player) - local inv = player:get_inventory() - if not inv then return nil end - local hgp = inv:get_stack("hunger", 1):get_count() - if hgp == 0 then - hgp = 21 - inv:set_stack("hunger", 1, ItemStack({name=":", count=hgp})) - else - hgp = hgp +if not hb.hbh then + + -- due lackof global hbhunger these need to be first + hbhunger.get_hunger_raw = function(player) + local inv = player:get_inventory() + if not inv then return nil end + local hgp = inv:get_stack("hunger", 1):get_count() + if hgp == 0 then + hgp = 21 + inv:set_stack("hunger", 1, ItemStack({name=":", count=hgp})) + else + hgp = hgp + end + return hgp-1 end - return hgp-1 + + hbhunger.set_hunger_raw = function(player) + local inv = player:get_inventory() + local name = player:get_player_name() + local value = hbhunger.hunger[name] + if not inv or not value then return nil end + if value > hbhunger.SAT_MAX then value = hbhunger.SAT_MAX end + if value < 0 then value = 0 end + + inv:set_stack("hunger", 1, ItemStack({name=":", count=value+1})) + + return true + end + + -- Load hunger management function for food and mod handling + dofile(minetest.get_modpath("hudbars").."/hunger.lua") + dofile(minetest.get_modpath("hudbars").."/register_foods.lua") + end -hbhunger.set_hunger_raw = function(player) - local inv = player:get_inventory() - local name = player:get_player_name() - local value = hbhunger.hunger[name] - if not inv or not value then return nil end - if value > hbhunger.SAT_MAX then value = hbhunger.SAT_MAX end - if value < 0 then value = 0 end - - inv:set_stack("hunger", 1, ItemStack({name=":", count=value+1})) - - return true -end - --- Load hunger management function for food and mod handling -dofile(minetest.get_modpath("hudbars").."/hunger.lua") -dofile(minetest.get_modpath("hudbars").."/register_foods.lua") - local function player_exists(player) - return player ~= nil and minetest.is_player(player) + return player ~= nil and (type(player) == "userdata") end local must_hide = function(playername, arm) @@ -600,8 +607,12 @@ if minetest.settings:get_bool("enable_damage") or hb.settings.forceload_default_ end hb.register_hudbar("health", 0xFFFFFF, S("Health"), { bar = "hudbars_bar_health.png", icon = hicon, bgicon = nil }, hb.settings.hp_player_maximun, hb.settings.hp_player_maximun, false) hb.register_hudbar("breath", 0xFFFFFF, S("Breath"), { bar = "hudbars_bar_breath.png", icon = bicon, bgicon = nil }, hb.settings.br_player_maximun, hb.settings.br_player_maximun, false) - hb.register_hudbar("armor", 0xFFFFFF, S("Armor"), { bar = "hbarmor_bar.png", icon = aicon, bgicon = nil }, 0, 100, hbarmor.autohide, N("@1: @2%"), { order = { "label", "value" } } ) - hb.register_hudbar("satiation", 0xFFFFFF, S("Satiation"), { bar = "hbhunger_bar.png", icon = sicon, bgicon = nil }, hbhunger.SAT_INIT, hbhunger.SAT_MAX, false, nil, { format_value = "%02d", format_max_value = "%02d" }) + if not hb.hba then + hb.register_hudbar("armor", 0xFFFFFF, S("Armor"), { bar = "hbarmor_bar.png", icon = aicon, bgicon = nil }, 0, 100, hbarmor.autohide, N("@1: @2%"), { order = { "label", "value" } } ) + end + if not hb.hbh then + hb.register_hudbar("satiation", 0xFFFFFF, S("Satiation"), { bar = "hbhunger_bar.png", icon = sicon, bgicon = nil }, hbhunger.SAT_INIT, hbhunger.SAT_MAX, false, nil, { format_value = "%02d", format_max_value = "%02d" }) + end end local function hide_builtin(player) @@ -611,71 +622,66 @@ local function hide_builtin(player) player:hud_set_flags(flags) end -function hbarmor.get_armor(player) - if not player or not armor.def then - return false - end - local name = player:get_player_name() - local def = armor.def[name] or nil - if def and def.state and def.count then - hbarmor.set_armor(name, def.state, def.count) - else - minetest.log("error", "[hudbars] Call to hbarmor.get_armor returned with false!") - return false - end - return true -end +if not hb.hba then -function hbarmor.set_armor(player_name, ges_state, items) - local max_items = 4 - if items == 5 then max_items = items end - local max = max_items * 65535 - local lvl = max - ges_state - lvl = lvl/max - if ges_state == 0 and items == 0 then lvl = 0 end + function hbarmor.get_armor(player) + if not player or not armor.def then + return false + end + local name = player:get_player_name() + local def = armor.def[name] or nil + if def and def.state and def.count then + hbarmor.set_armor(name, def.state, def.count) + else + minetest.log("error", "[hudbars] Call to hbarmor.get_armor returned with false!") + return false + end + return true + end + + function hbarmor.set_armor(player_name, ges_state, items) + local max_items = 4 + if items == 5 then max_items = items end + local max = max_items * 65535 + local lvl = max - ges_state + lvl = lvl/max + if ges_state == 0 and items == 0 then lvl = 0 end + + hbarmor.armor[player_name] = math.max(0, math.min(lvl* (items * (100 / max_items)), 100)) + end - hbarmor.armor[player_name] = math.max(0, math.min(lvl* (items * (100 / max_items)), 100)) end local function custom_hud(player) local name = player:get_player_name() if minetest.settings:get_bool("enable_damage") or hb.settings.forceload_default_hudbars then - local arm = tonumber(hbarmor.armor[name]) - if not arm then arm = 0 end - - local hbhide - if minetest.settings:get_bool("enable_damage") then - hbhide = false - else - hbhide = true - end - local hahide - if hbarmor.autohide then - hahide = must_hide(name, arm) - else - hahide = false - end - local sahide = true local hp = player:get_hp() local hp_max = hb.settings.hp_player_maximun + local hide_hp = not minetest.settings:get_bool("enable_damage") or true if player:get_properties().hp_max then player:set_properties({hp_max = hb.settings.hp_player_maximun}) end - hb.init_hudbar(player, "health", math.min(hp, hp_max), hp_max, hbhide) + hb.init_hudbar(player, "health", math.min(hp, hp_max), hp_max, hide_hp) local breath = player:get_breath() local breath_max = hb.settings.br_player_maximun local hide_breath if player:get_properties().breath_max then player:set_properties({breath_max = hb.settings.br_player_maximun}) end if breath >= breath_max and hb.settings.autohide_breath == true then hide_breath = true else hide_breath = false end - hb.init_hudbar(player, "breath", math.min(breath, breath_max), breath_max, hide_breath or hbhide) + hb.init_hudbar(player, "breath", math.min(breath, breath_max), breath_max, hide_breath) - hbarmor.get_armor(player) - arm = tonumber(hbarmor.armor[name]) - hb.init_hudbar(player, "armor", arm_printable(arm), 100, hahide) - - if hb.settings.forceload_default_hudbars then sahide = false end - hb.init_hudbar(player, "satiation", hbhunger.get_hunger_raw(player), nil, sahide) + if not hb.hba then + local arm = tonumber(hbarmor.armor[name]) + if not arm then arm = 0 end + local hide_ar = hbarmor.autohide and must_hide(name, arm) + hbarmor.get_armor(player) + arm = tonumber(hbarmor.armor[name]) + hb.init_hudbar(player, "armor", arm_printable(arm), 100, hide_ar) + end + + if not hb.hbh then + hb.init_hudbar(player, "satiation", hbhunger.get_hunger_raw(player), nil, (not hb.settings.forceload_default_hudbars) ) + end end end @@ -688,15 +694,9 @@ end -- update built-in HUD bars local function update_hud(player) - local lplayer = player_exists(player) - if not lplayer then return end - local name = player:get_player_name() + local name = player:get_player_name() -- player checks are already made before call this function if not name then return end - local larmor = hbarmor.armor[name] - if not larmor then return end - local arm = tonumber(larmor) - if not arm then arm = 0; hbarmor.armor[name] = 0 end - + -- loading only if need or force loading if minetest.settings:get_bool("enable_damage") then if hb.settings.forceload_default_hudbars then @@ -714,23 +714,30 @@ local function update_hud(player) --health update_health(player) -- armor - if hbarmor.autohide then - if must_hide(name, arm) then - hb.hide_hudbar(player, "armor") + if not hb.hba then + local larmor = hbarmor.armor[name] + local arm = tonumber(larmor) + if not arm then arm = 0; hbarmor.armor[name] = 0 end + if hbarmor.autohide then + if must_hide(name, arm) then + hb.hide_hudbar(player, "armor") + else + hb.change_hudbar(player, "armor", arm_printable(arm)) + hb.unhide_hudbar(player, "armor") + end else hb.change_hudbar(player, "armor", arm_printable(arm)) hb.unhide_hudbar(player, "armor") end - else - hb.change_hudbar(player, "armor", arm_printable(arm)) - hb.unhide_hudbar(player, "armor") end -- hunger - local h_out = tonumber(hbhunger.hunger_out[name]) - local h = tonumber(hbhunger.hunger[name]) - if h_out ~= h then - hbhunger.hunger_out[name] = h - hb.change_hudbar(player, "satiation", h) + if not hb.hbh then + local h_out = tonumber(hbhunger.hunger_out[name]) + local h = tonumber(hbhunger.hunger[name]) + if h_out ~= h then + hbhunger.hunger_out[name] = h + hb.change_hudbar(player, "satiation", h) + end end elseif hb.settings.forceload_default_hudbars then update_health(player) @@ -748,35 +755,59 @@ minetest.register_on_player_hpchange(function(player) end) minetest.register_on_respawnplayer(function(player) - update_health(player) + if not player_exists(player) then return end + local name = player:get_player_name() - hbhunger.hunger[name] = hbhunger.SAT_INIT - hbhunger.set_hunger_raw(player) - hbhunger.exhaustion[name] = 0 + update_health(player) + if not hb.hbh then + hbhunger.hunger[name] = hbhunger.SAT_INIT + hbhunger.set_hunger_raw(player) + hbhunger.exhaustion[name] = 0 + end hb.hide_hudbar(player, "breath") end) minetest.register_on_joinplayer(function(player) + if not player_exists(player) then return end + local name = player:get_player_name() local inv = player:get_inventory() - inv:set_size("hunger",1) - hbhunger.hunger[name] = hbhunger.get_hunger_raw(player) - hbhunger.hunger_out[name] = hbhunger.hunger[name] - hbhunger.exhaustion[name] = 0 - hbhunger.poisonings[name] = 0 + if not hb.hbh then + inv:set_size("hunger",1) + hbhunger.hunger[name] = hbhunger.get_hunger_raw(player) + hbhunger.hunger_out[name] = hbhunger.hunger[name] + hbhunger.exhaustion[name] = 0 + hbhunger.poisonings[name] = 0 + end hide_builtin(player) custom_hud(player) hb.players[name] = player - hbarmor.player_active[name] = true - hbhunger.set_hunger_raw(player) + if not hb.hba then + hbarmor.player_active[name] = true + end + if not hb.hbh then + hbhunger.set_hunger_raw(player) + end end) minetest.register_on_leaveplayer(function(player) + if not player_exists(player) then return end + local name = player:get_player_name() hb.players[name] = nil - hbarmor.player_active[name] = false + if not hb.hba then + hbarmor.player_active[name] = false + end end) +local modresult = "" + +if hb.hba then modresult = modresult .. " without build-in hbarmor" end +if hb.hbh then modresult = modresult .. " without build-in hbhunger" end + +minetest.log("[MOD] hudbars"..modresult.." loaded" ) + + local main_timer = 0 local timer = 0 local timer2 = 0 @@ -793,44 +824,53 @@ minetest.register_globalstep(function(dtime) for _, player in pairs(hb.players) do update_hud(player) end - -- update all hud elements - for _,player in ipairs(minetest.get_connected_players()) do - local name = player:get_player_name() - if hbarmor.player_active[name] == true then - hbarmor.get_armor(player) - update_hud(player) + if not hb.hba then + -- update all hud elements + for _,player in ipairs(minetest.get_connected_players()) do + if player_exists(player) then + local name = player:get_player_name() + if hbarmor.player_active[name] == true then + hbarmor.get_armor(player) + update_hud(player) + end + end end end - end end - -- satiaton are internal properties, so update live (not hb) player properties - if timer > 4 or timer2 > hbhunger.HUNGER_TICK then - for _,player in ipairs(minetest.get_connected_players()) do - local name = player:get_player_name() - local h = tonumber(hbhunger.hunger[name]) - local hp = player:get_hp() - if timer > 4 then - if h > hbhunger.SAT_HEAL and hp > 0 and player:get_breath() > 0 then - player:set_hp(hp+1) -- heal player by 1 hp if not dead and satiation is > hbhunger.SAT_HEAL - elseif h <= 1 then - if hp-1 >= 0 then player:set_hp(hp-1) end -- or damage player by 1 hp if satiation is < 2 + if not hb.hbh then + -- satiaton are internal properties, so update live (not hb) player properties + if timer > 4 or timer2 > hbhunger.HUNGER_TICK then + for _,player in ipairs(minetest.get_connected_players()) do + if player_exists(player) then + local name = player:get_player_name() + local h = tonumber(hbhunger.hunger[name]) + local hp = player:get_hp() + if timer > 4 then + if h > hbhunger.SAT_HEAL and hp > 0 and player:get_breath() > 0 then + player:set_hp(hp+1) -- heal player by 1 hp if not dead and satiation is > hbhunger.SAT_HEAL + elseif h <= 1 then + if hp-1 >= 0 then player:set_hp(hp-1) end -- or damage player by 1 hp if satiation is < 2 + end + end + if timer2 > hbhunger.HUNGER_TICK then + if h > 0 then + h = h-1 -- lower satiation by 1 point after xx seconds + hbhunger.hunger[name] = h + hbhunger.set_hunger_raw(player) + end + end + -- still do not update all hud elements cos we have 2 loops + local controls = player:get_player_control() + if controls.up or controls.down or controls.left or controls.right then + hbhunger.handle_node_actions(nil, nil, player) -- Determine if the player is walking + end end end - if timer2 > hbhunger.HUNGER_TICK then - if h > 0 then - h = h-1 -- lower satiation by 1 point after xx seconds - hbhunger.hunger[name] = h - hbhunger.set_hunger_raw(player) - end - end - -- still do not update all hud elements cos we have 2 loops - local controls = player:get_player_control() - if controls.up or controls.down or controls.left or controls.right then - hbhunger.handle_node_actions(nil, nil, player) -- Determine if the player is walking - end end end if timer > 4 then timer = 0 end if timer2 > hbhunger.HUNGER_TICK then timer2 = 0 end end) + +