Skip to content

Commit aa13baa

Browse files
TeTpaAkaest31
authored andcommittedJun 13, 2015
Add minetest.register_on_player_hpchange
1 parent e50aa4e commit aa13baa

File tree

5 files changed

+61
-0
lines changed

5 files changed

+61
-0
lines changed
 

‎builtin/game/register.lua

+28
Original file line numberDiff line numberDiff line change
@@ -407,6 +407,34 @@ local function make_registration_wrap(reg_fn_name, clear_fn_name)
407407
return list
408408
end
409409

410+
core.registered_on_player_hpchanges = { modifiers = { }, loggers = { } }
411+
function core.registered_on_player_hpchange(player, hp_change)
412+
local last = false
413+
for i = #core.registered_on_player_hpchanges.modifiers, 1, -1 do
414+
local func = core.registered_on_player_hpchanges.modifiers[i]
415+
hp_change, last = func(player, hp_change)
416+
if type(hp_change) ~= "number" then
417+
local debuginfo = debug.getinfo(func)
418+
error("The register_on_hp_changes function has to return a number at " ..
419+
debuginfo.short_src .. " line " .. debuginfo.linedefined)
420+
end
421+
if last then
422+
break
423+
end
424+
end
425+
for i, func in ipairs(core.registered_on_player_hpchanges.loggers) do
426+
func(player, hp_change)
427+
end
428+
return hp_change
429+
end
430+
function core.register_on_player_hpchange(func, modifier)
431+
if modifier then
432+
table.insert(core.registered_on_player_hpchanges.modifiers, func)
433+
else
434+
table.insert(core.registered_on_player_hpchanges.loggers, func)
435+
end
436+
end
437+
410438
core.registered_biomes = make_registration_wrap("register_biome", "clear_registered_biomes")
411439
core.registered_ores = make_registration_wrap("register_ore", "clear_registered_ores")
412440
core.registered_decorations = make_registration_wrap("register_decoration", "clear_registered_decorations")

‎doc/lua_api.txt

+7
Original file line numberDiff line numberDiff line change
@@ -1785,6 +1785,13 @@ Call these functions only at load time!
17851785
the puncher to the punched.
17861786
* `damage` - number that represents the damage calculated by the engine
17871787
* should return `true` to prevent the default damage mechanism
1788+
* `minetest.register_on_player_hpchange(func(player, hp_change), modifier)`
1789+
* Called when the player gets damaged or healed
1790+
* `player`: ObjectRef of the player
1791+
* `hp_change`: the amount of change. Negative when it is damage.
1792+
* `modifier`: when true, the function should return the actual hp_change.
1793+
Note: modifiers only get a temporary hp_change that can be modified by later modifiers.
1794+
modifiers can return true as a second argument to stop the execution of further functions.
17881795
* `minetest.register_on_respawnplayer(func(ObjectRef))`
17891796
* Called when player is to be respawned
17901797
* Called _before_ repositioning of player occurs

‎src/content_sao.cpp

+6
Original file line numberDiff line numberDiff line change
@@ -1125,6 +1125,12 @@ void PlayerSAO::setHP(s16 hp)
11251125
{
11261126
s16 oldhp = m_player->hp;
11271127

1128+
s16 hp_change = m_env->getScriptIface()->on_player_hpchange(this,
1129+
hp - oldhp);
1130+
if (hp_change == 0)
1131+
return;
1132+
hp = oldhp + hp_change;
1133+
11281134
if (hp < 0)
11291135
hp = 0;
11301136
else if (hp > PLAYER_MAX_HP)

‎src/script/cpp_api/s_player.cpp

+19
Original file line numberDiff line numberDiff line change
@@ -69,6 +69,25 @@ bool ScriptApiPlayer::on_punchplayer(ServerActiveObject *player,
6969
return lua_toboolean(L, -1);
7070
}
7171

72+
s16 ScriptApiPlayer::on_player_hpchange(ServerActiveObject *player,
73+
s16 hp_change)
74+
{
75+
SCRIPTAPI_PRECHECKHEADER
76+
77+
// Get core.registered_on_player_hpchange
78+
lua_getglobal(L, "core");
79+
lua_getfield(L, -1, "registered_on_player_hpchange");
80+
lua_remove(L, -2);
81+
82+
objectrefGetOrCreate(L, player);
83+
lua_pushnumber(L, hp_change);
84+
if (lua_pcall(L, 2, 1, m_errorhandler))
85+
scriptError();
86+
hp_change = lua_tointeger(L, -1);
87+
lua_pop(L, -1);
88+
return hp_change;
89+
}
90+
7291
bool ScriptApiPlayer::on_respawnplayer(ServerActiveObject *player)
7392
{
7493
SCRIPTAPI_PRECHECKHEADER

‎src/script/cpp_api/s_player.h

+1
Original file line numberDiff line numberDiff line change
@@ -43,6 +43,7 @@ class ScriptApiPlayer
4343
bool on_punchplayer(ServerActiveObject *player,
4444
ServerActiveObject *hitter, float time_from_last_punch,
4545
const ToolCapabilities *toolcap, v3f dir, s16 damage);
46+
s16 on_player_hpchange(ServerActiveObject *player, s16 hp_change);
4647
void on_playerReceiveFields(ServerActiveObject *player,
4748
const std::string &formname, const StringMap &fields);
4849
};

0 commit comments

Comments
 (0)
Please sign in to comment.