diff --git a/doc/script_commands.txt b/doc/script_commands.txt index 574709e8266..567089fb888 100644 --- a/doc/script_commands.txt +++ b/doc/script_commands.txt @@ -5603,6 +5603,9 @@ item in his/her inventory, while the autoequip function will equip the given item ID when this is looted. The option parameter of the autoequip is 1 or 0, 1 to turn it on, and 0 to turn it off. +equip() returns 1 if the item was successfully equipped and 0 if the +item failed to equip. + Examples: //This will equip a 1104 (falchion) on the character if this is in the diff --git a/src/map/script.c b/src/map/script.c index ff5f44f5fda..01de724585d 100644 --- a/src/map/script.c +++ b/src/map/script.c @@ -16473,21 +16473,28 @@ static BUILDIN(unequip) static BUILDIN(equip) { - int nameid=0,i; + int nameid = 0, i; struct item_data *item_data; struct map_session_data *sd = script->rid2sd(st); - if (sd == NULL) - return false; - nameid=script_getnum(st,2); - if((item_data = itemdb->exists(nameid)) == NULL) - { - ShowError("wrong item ID : equipitem(%d)\n",nameid); + if (sd == NULL) { + script_pushint(st, 0); + return true; + } + + nameid = script_getnum(st, 2); + if ((item_data = itemdb->exists(nameid)) == NULL) { + ShowError("buildin_equip: Invalid Item ID (%d).\n",nameid); + script_pushint(st, 0); return false; } + ARR_FIND(0, sd->status.inventorySize, i, sd->status.inventory[i].nameid == nameid && sd->status.inventory[i].equip == 0); + if (i < sd->status.inventorySize) - pc->equipitem(sd, i, item_data->equip); + script_pushint(st, pc->equipitem(sd, i, item_data->equip)); + else + script_pushint(st, 0); return true; }