diff options
author | Wushin <pasekei@gmail.com> | 2015-04-13 21:25:17 -0500 |
---|---|---|
committer | Wushin <pasekei@gmail.com> | 2015-04-13 21:25:17 -0500 |
commit | 0b04c49460a2e0c894c818ae190465fc2607bca8 (patch) | |
tree | 0e1a89b9c1402c2a5b2e1c125034ae8534a53a49 /src/map/script-fun.cpp | |
parent | bf54afff27cd03ed535859009baa0b4c4fa663e9 (diff) | |
parent | 6a22fe4dc257228b28dd67cb35301d44ed6f6060 (diff) | |
download | tmwa-0b04c49460a2e0c894c818ae190465fc2607bca8.tar.gz tmwa-0b04c49460a2e0c894c818ae190465fc2607bca8.tar.bz2 tmwa-0b04c49460a2e0c894c818ae190465fc2607bca8.tar.xz tmwa-0b04c49460a2e0c894c818ae190465fc2607bca8.zip |
Merge pull request #50 from mekolat/heal
remove deprecated percentheal and itemheal
Diffstat (limited to 'src/map/script-fun.cpp')
-rw-r--r-- | src/map/script-fun.cpp | 42 |
1 files changed, 12 insertions, 30 deletions
diff --git a/src/map/script-fun.cpp b/src/map/script-fun.cpp index 8300d38..3b814aa 100644 --- a/src/map/script-fun.cpp +++ b/src/map/script-fun.cpp @@ -402,38 +402,22 @@ static void builtin_heal(ScriptState *st) { int hp, sp; + dumb_ptr<map_session_data> sd = script_rid2sd(st); hp = conv_num(st, &AARG(0)); sp = conv_num(st, &AARG(1)); - pc_heal(script_rid2sd(st), hp, sp); -} -/*========================================== - * - *------------------------------------------ - */ -static -void builtin_itemheal(ScriptState *st) -{ - int hp, sp; - - hp = conv_num(st, &AARG(0)); - sp = conv_num(st, &AARG(1)); - pc_itemheal(script_rid2sd(st), hp, sp); -} - -/*========================================== - * - *------------------------------------------ - */ -static -void builtin_percentheal(ScriptState *st) -{ - int hp, sp; + if(sd != nullptr && (sd->status.hp < 1 && hp > 0)){ + pc_setstand(sd); + if (battle_config.player_invincible_time > interval_t::zero()) + pc_setinvincibletimer(sd, battle_config.player_invincible_time); + clif_resurrection(sd, 1); + } - hp = conv_num(st, &AARG(0)); - sp = conv_num(st, &AARG(1)); - pc_percentheal(script_rid2sd(st), hp, sp); + if(HARG(2) && bool(conv_num(st, &AARG(2))) && hp > 0) + pc_itemheal(sd, hp, sp); + else + pc_heal(sd, hp, sp); } /*========================================== @@ -3126,9 +3110,7 @@ BuiltinFunction builtin_functions[] = BUILTIN(isat, "Mxy"_s, 'i'), BUILTIN(warp, "Mxy"_s, '\0'), BUILTIN(areawarp, "MxyxyMxy"_s, '\0'), - BUILTIN(heal, "ii"_s, '\0'), - BUILTIN(itemheal, "ii"_s, '\0'), - BUILTIN(percentheal, "ii"_s, '\0'), + BUILTIN(heal, "ii?"_s, '\0'), BUILTIN(input, "N"_s, '\0'), BUILTIN(if, "iF*"_s, '\0'), BUILTIN(set, "Ne"_s, '\0'), |