diff options
author | EyesOfAHawk <blackoutro2006@gmail.com> | 2019-02-28 21:15:57 +1300 |
---|---|---|
committer | Haru <haru@dotalux.com> | 2019-06-02 14:32:04 +0200 |
commit | 858e732e15c495f3073c8037b9612c6c20390f76 (patch) | |
tree | ab04375d02387f5e3bb81c95fe3d8a8e57fbdadd /src | |
parent | 1ac84c2dd856087a4a72fec95b3322137187637a (diff) | |
download | hercules-858e732e15c495f3073c8037b9612c6c20390f76.tar.gz hercules-858e732e15c495f3073c8037b9612c6c20390f76.tar.bz2 hercules-858e732e15c495f3073c8037b9612c6c20390f76.tar.xz hercules-858e732e15c495f3073c8037b9612c6c20390f76.zip |
Adds BUILDIN(delitemidx), which deletes an item at the given index.
Signed-off-by: Haru <haru@dotalux.com>
Diffstat (limited to 'src')
-rw-r--r-- | src/map/script.c | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/src/map/script.c b/src/map/script.c index 7e6e06376..c7302d0a3 100644 --- a/src/map/script.c +++ b/src/map/script.c @@ -8616,6 +8616,48 @@ static BUILDIN(delitem2) return false; } +/** + * Deletes item at given index. + * delitem(<index>{, <amount{, <account id>}}); + */ +static BUILDIN(delitemidx) +{ + struct map_session_data *sd; + + if (script_hasdata(st, 4)) { + if ((sd = script->id2sd(st, script_getnum(st, 4))) == NULL) { + st->state = END; + return true; + } + } else { + if ((sd = script->rid2sd(st)) == NULL) + return true; + } + + int i = script_getnum(st, 2); + if (i < 0 || i >= sd->status.inventorySize) { + ShowError("buildin_delitemidx: Index (%d) should be from 0-%d.\n", i, sd->status.inventorySize - 1); + st->state = END; + return false; + } + + if (itemdb->exists(sd->status.inventory[i].nameid) == NULL) + ShowWarning("buildin_delitemidx: Deleting invalid Item ID (%d).\n", sd->status.inventory[i].nameid); + + int amount = 0; + if (script_hasdata(st, 3)) { + if ((amount = script_getnum(st, 3)) > sd->status.inventory[i].amount) + amount = sd->status.inventory[i].amount; + } else { + amount = sd->status.inventory[i].amount; + } + + if (amount > 0) + script->buildin_delitem_delete(sd, i, &amount, true); + + return true; +} + /*========================================== * Enables/Disables use of items while in an NPC [Skotlex] *------------------------------------------*/ @@ -25252,6 +25294,7 @@ static void script_parse_builtin(void) BUILDIN_DEF(makeitem2,"viiiiiiii????"), BUILDIN_DEF(delitem,"vi?"), BUILDIN_DEF(delitem2,"viiiiiiii?"), + BUILDIN_DEF(delitemidx, "i??"), BUILDIN_DEF2(enableitemuse,"enable_items",""), BUILDIN_DEF2(disableitemuse,"disable_items",""), BUILDIN_DEF(cutin,"si"), |