From ee1220b0ca4b8d4e4b10ec1f758284bf79fe8061 Mon Sep 17 00:00:00 2001 From: Dennis Friis Date: Wed, 2 Apr 2008 15:17:26 +0000 Subject: patch derived from stable ea, that fixes duping and zero stacking --- src/map/pc.c | 6 ++++++ src/map/trade.c | 6 ++++++ 2 files changed, 12 insertions(+) diff --git a/src/map/pc.c b/src/map/pc.c index 4e702c0..f5458e4 100644 --- a/src/map/pc.c +++ b/src/map/pc.c @@ -2908,6 +2908,12 @@ int pc_dropitem(struct map_session_data *sd,int n,int amount) { nullpo_retr(1, sd); + if(n < 0 || n >= MAX_INVENTORY) + return 0; + + if(amount <= 0) + return 0; + if (sd->status.inventory[n].nameid <= 0 || sd->status.inventory[n].amount < amount || sd->trade_partner != 0 || sd->vender_id != 0 || diff --git a/src/map/trade.c b/src/map/trade.c index da43d67..8bf2cb2 100644 --- a/src/map/trade.c +++ b/src/map/trade.c @@ -27,6 +27,12 @@ void trade_traderequest(struct map_session_data *sd,int target_id) return; } } + if (target_sd->npc_id) + { + //Trade fails if you are using an NPC. + clif_tradestart(sd, 2); + return; + } if((target_sd->trade_partner !=0) || (sd->trade_partner !=0)) { trade_tradecancel(sd); //person is in another trade } -- cgit v1.2.3-60-g2f50