forked from mtcontrib/minetest_hbhunger
Rename global table to “hbhunger”
This commit is contained in:
parent
867d158645
commit
e34e66a989
34
hunger.lua
34
hunger.lua
@ -1,9 +1,9 @@
|
|||||||
-- Keep these for backwards compatibility
|
-- Keep these for backwards compatibility
|
||||||
function hunger.save_hunger(player)
|
function hbhunger.save_hunger(player)
|
||||||
hunger.set_hunger(player)
|
hbhunger.set_hunger(player)
|
||||||
end
|
end
|
||||||
function hunger.load_hunger(player)
|
function hbhunger.load_hunger(player)
|
||||||
hunger.get_hunger(player)
|
hbhunger.get_hunger(player)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Poison player
|
-- Poison player
|
||||||
@ -20,19 +20,19 @@ local function poisenp(tick, time, time_left, player)
|
|||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
function hunger.item_eat(hunger_change, replace_with_item, poisen, heal)
|
function hbhunger.item_eat(hunger_change, replace_with_item, poisen, heal)
|
||||||
return function(itemstack, user, pointed_thing)
|
return function(itemstack, user, pointed_thing)
|
||||||
if itemstack:take_item() ~= nil and user ~= nil then
|
if itemstack:take_item() ~= nil and user ~= nil then
|
||||||
local name = user:get_player_name()
|
local name = user:get_player_name()
|
||||||
local h = tonumber(hunger.hunger[name])
|
local h = tonumber(hbhunger.hunger[name])
|
||||||
local hp = user:get_hp()
|
local hp = user:get_hp()
|
||||||
|
|
||||||
-- Saturation
|
-- Saturation
|
||||||
if h < 30 and hunger_change then
|
if h < 30 and hunger_change then
|
||||||
h = h + hunger_change
|
h = h + hunger_change
|
||||||
if h > 30 then h = 30 end
|
if h > 30 then h = 30 end
|
||||||
hunger.hunger[name] = h
|
hbhunger.hunger[name] = h
|
||||||
hunger.set_hunger(user)
|
hbhunger.set_hunger(user)
|
||||||
end
|
end
|
||||||
-- Healing
|
-- Healing
|
||||||
if hp < 20 and heal then
|
if hp < 20 and heal then
|
||||||
@ -56,7 +56,7 @@ end
|
|||||||
local function overwrite(name, hunger_change, replace_with_item, poisen, heal)
|
local function overwrite(name, hunger_change, replace_with_item, poisen, heal)
|
||||||
local tab = minetest.registered_items[name]
|
local tab = minetest.registered_items[name]
|
||||||
if tab == nil then return end
|
if tab == nil then return end
|
||||||
tab.on_use = hunger.item_eat(hunger_change, replace_with_item, poisen, heal)
|
tab.on_use = hbhunger.item_eat(hunger_change, replace_with_item, poisen, heal)
|
||||||
minetest.registered_items[name] = tab
|
minetest.registered_items[name] = tab
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -363,12 +363,12 @@ if minetest.get_modpath("ferns") ~= nil then
|
|||||||
end
|
end
|
||||||
|
|
||||||
-- player-action based hunger changes
|
-- player-action based hunger changes
|
||||||
function hunger.handle_node_actions(pos, oldnode, player, ext)
|
function hbhunger.handle_node_actions(pos, oldnode, player, ext)
|
||||||
if not player or not player:is_player() then
|
if not player or not player:is_player() then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
local name = player:get_player_name()
|
local name = player:get_player_name()
|
||||||
local exhaus = hunger.exhaustion[name]
|
local exhaus = hbhunger.exhaustion[name]
|
||||||
local new = HUNGER_EXHAUST_PLACE
|
local new = HUNGER_EXHAUST_PLACE
|
||||||
-- placenode event
|
-- placenode event
|
||||||
if not ext then
|
if not ext then
|
||||||
@ -381,14 +381,14 @@ function hunger.handle_node_actions(pos, oldnode, player, ext)
|
|||||||
exhaus = exhaus + new
|
exhaus = exhaus + new
|
||||||
if exhaus > HUNGER_EXHAUST_LVL then
|
if exhaus > HUNGER_EXHAUST_LVL then
|
||||||
exhaus = 0
|
exhaus = 0
|
||||||
local h = tonumber(hunger.hunger[name])
|
local h = tonumber(hbhunger.hunger[name])
|
||||||
h = h - 1
|
h = h - 1
|
||||||
if h < 0 then h = 0 end
|
if h < 0 then h = 0 end
|
||||||
hunger.hunger[name] = h
|
hbhunger.hunger[name] = h
|
||||||
hunger.set_hunger(player)
|
hbhunger.set_hunger(player)
|
||||||
end
|
end
|
||||||
hunger.exhaustion[name] = exhaus
|
hbhunger.exhaustion[name] = exhaus
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_on_placenode(hunger.handle_node_actions)
|
minetest.register_on_placenode(hbhunger.handle_node_actions)
|
||||||
minetest.register_on_dignode(hunger.handle_node_actions)
|
minetest.register_on_dignode(hbhunger.handle_node_actions)
|
||||||
|
44
init.lua
44
init.lua
@ -1,10 +1,10 @@
|
|||||||
if minetest.setting_getbool("enable_damage") then
|
if minetest.setting_getbool("enable_damage") then
|
||||||
|
|
||||||
hunger = {}
|
hbhunger = {}
|
||||||
|
|
||||||
-- HUD statbar values
|
-- HUD statbar values
|
||||||
hunger.hunger = {}
|
hbhunger.hunger = {}
|
||||||
hunger.hunger_out = {}
|
hbhunger.hunger_out = {}
|
||||||
|
|
||||||
-- HUD item ids
|
-- HUD item ids
|
||||||
local hunger_hud = {}
|
local hunger_hud = {}
|
||||||
@ -12,7 +12,7 @@ local hunger_hud = {}
|
|||||||
HUNGER_HUD_TICK = 0.1
|
HUNGER_HUD_TICK = 0.1
|
||||||
|
|
||||||
--Some hunger settings
|
--Some hunger settings
|
||||||
hunger.exhaustion = {} -- Exhaustion is experimental!
|
hbhunger.exhaustion = {} -- Exhaustion is experimental!
|
||||||
|
|
||||||
HUNGER_HUNGER_TICK = 800 -- time in seconds after that 1 hunger point is taken
|
HUNGER_HUNGER_TICK = 800 -- time in seconds after that 1 hunger point is taken
|
||||||
HUNGER_EXHAUST_DIG = 3 -- exhaustion increased this value after digged node
|
HUNGER_EXHAUST_DIG = 3 -- exhaustion increased this value after digged node
|
||||||
@ -29,7 +29,7 @@ if set then
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function custom_hud(player)
|
local function custom_hud(player)
|
||||||
hb.init_hudbar(player, "saturation", hunger.get_hunger(player))
|
hb.init_hudbar(player, "saturation", hbhunger.get_hunger(player))
|
||||||
end
|
end
|
||||||
|
|
||||||
dofile(minetest.get_modpath("hbhunger").."/hunger.lua")
|
dofile(minetest.get_modpath("hbhunger").."/hunger.lua")
|
||||||
@ -41,15 +41,15 @@ hb.register_hudbar("saturation", 0xFFFFFF, "Saturation", { icon = "hbhunger_icon
|
|||||||
local function update_hud(player)
|
local function update_hud(player)
|
||||||
local name = player:get_player_name()
|
local name = player:get_player_name()
|
||||||
--hunger
|
--hunger
|
||||||
local h_out = tonumber(hunger.hunger_out[name])
|
local h_out = tonumber(hbhunger.hunger_out[name])
|
||||||
local h = tonumber(hunger.hunger[name])
|
local h = tonumber(hbhunger.hunger[name])
|
||||||
if h_out ~= h then
|
if h_out ~= h then
|
||||||
hunger.hunger_out[name] = h
|
hbhunger.hunger_out[name] = h
|
||||||
hb.change_hudbar(player, "saturation", h)
|
hb.change_hudbar(player, "saturation", h)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
hunger.get_hunger = function(player)
|
hbhunger.get_hunger = function(player)
|
||||||
local inv = player:get_inventory()
|
local inv = player:get_inventory()
|
||||||
if not inv then return nil end
|
if not inv then return nil end
|
||||||
local hgp = inv:get_stack("hunger", 1):get_count()
|
local hgp = inv:get_stack("hunger", 1):get_count()
|
||||||
@ -62,10 +62,10 @@ hunger.get_hunger = function(player)
|
|||||||
return hgp-1
|
return hgp-1
|
||||||
end
|
end
|
||||||
|
|
||||||
hunger.set_hunger = function(player)
|
hbhunger.set_hunger = function(player)
|
||||||
local inv = player:get_inventory()
|
local inv = player:get_inventory()
|
||||||
local name = player:get_player_name()
|
local name = player:get_player_name()
|
||||||
local value = hunger.hunger[name]
|
local value = hbhunger.hunger[name]
|
||||||
if not inv or not value then return nil end
|
if not inv or not value then return nil end
|
||||||
if value > 30 then value = 30 end
|
if value > 30 then value = 30 end
|
||||||
if value < 0 then value = 0 end
|
if value < 0 then value = 0 end
|
||||||
@ -79,19 +79,19 @@ minetest.register_on_joinplayer(function(player)
|
|||||||
local name = player:get_player_name()
|
local name = player:get_player_name()
|
||||||
local inv = player:get_inventory()
|
local inv = player:get_inventory()
|
||||||
inv:set_size("hunger",1)
|
inv:set_size("hunger",1)
|
||||||
hunger.hunger[name] = hunger.get_hunger(player)
|
hbhunger.hunger[name] = hbhunger.get_hunger(player)
|
||||||
hunger.hunger_out[name] = hunger.hunger[name]
|
hbhunger.hunger_out[name] = hbhunger.hunger[name]
|
||||||
hunger.exhaustion[name] = 0
|
hbhunger.exhaustion[name] = 0
|
||||||
custom_hud(player)
|
custom_hud(player)
|
||||||
hunger.set_hunger(player)
|
hbhunger.set_hunger(player)
|
||||||
end)
|
end)
|
||||||
|
|
||||||
minetest.register_on_respawnplayer(function(player)
|
minetest.register_on_respawnplayer(function(player)
|
||||||
-- reset hunger (and save)
|
-- reset hunger (and save)
|
||||||
local name = player:get_player_name()
|
local name = player:get_player_name()
|
||||||
hunger.hunger[name] = 20
|
hbhunger.hunger[name] = 20
|
||||||
hunger.set_hunger(player)
|
hbhunger.set_hunger(player)
|
||||||
hunger.exhaustion[name] = 0
|
hbhunger.exhaustion[name] = 0
|
||||||
end)
|
end)
|
||||||
|
|
||||||
local main_timer = 0
|
local main_timer = 0
|
||||||
@ -106,7 +106,7 @@ minetest.register_globalstep(function(dtime)
|
|||||||
for _,player in ipairs(minetest.get_connected_players()) do
|
for _,player in ipairs(minetest.get_connected_players()) do
|
||||||
local name = player:get_player_name()
|
local name = player:get_player_name()
|
||||||
|
|
||||||
local h = tonumber(hunger.hunger[name])
|
local h = tonumber(hbhunger.hunger[name])
|
||||||
local hp = player:get_hp()
|
local hp = player:get_hp()
|
||||||
if timer > 4 then
|
if timer > 4 then
|
||||||
-- heal player by 1 hp if not dead and saturation is > 15 (of 30)
|
-- heal player by 1 hp if not dead and saturation is > 15 (of 30)
|
||||||
@ -121,8 +121,8 @@ minetest.register_globalstep(function(dtime)
|
|||||||
if timer2 > HUNGER_HUNGER_TICK then
|
if timer2 > HUNGER_HUNGER_TICK then
|
||||||
if h > 0 then
|
if h > 0 then
|
||||||
h = h-1
|
h = h-1
|
||||||
hunger.hunger[name] = h
|
hbhunger.hunger[name] = h
|
||||||
hunger.set_hunger(player)
|
hbhunger.set_hunger(player)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -132,7 +132,7 @@ minetest.register_globalstep(function(dtime)
|
|||||||
local controls = player:get_player_control()
|
local controls = player:get_player_control()
|
||||||
-- Determine if the player is walking
|
-- Determine if the player is walking
|
||||||
if controls.up or controls.down or controls.left or controls.right then
|
if controls.up or controls.down or controls.left or controls.right then
|
||||||
hunger.handle_node_actions(nil, nil, player)
|
hbhunger.handle_node_actions(nil, nil, player)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user