summaryrefslogtreecommitdiff
path: root/src/map/npc.c
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2014-11-29 17:57:23 +0300
committerAndrei Karas <akaras@inbox.ru>2014-11-29 17:57:23 +0300
commitf518402fc06a3bc4824af47e6c979ce649326cf4 (patch)
treead85be5ef125756946229694ead74091c44bdb80 /src/map/npc.c
parentf013f783501bb92d88133d7ac9a7be6501d0dd8e (diff)
downloadevol-hercules-f518402fc06a3bc4824af47e6c979ce649326cf4.tar.gz
evol-hercules-f518402fc06a3bc4824af47e6c979ce649326cf4.tar.bz2
evol-hercules-f518402fc06a3bc4824af47e6c979ce649326cf4.tar.xz
evol-hercules-f518402fc06a3bc4824af47e6c979ce649326cf4.zip
Add checking for npc activate distance.
Diffstat (limited to 'src/map/npc.c')
-rw-r--r--src/map/npc.c24
1 files changed, 21 insertions, 3 deletions
diff --git a/src/map/npc.c b/src/map/npc.c
index 3eabaa9..62dccfe 100644
--- a/src/map/npc.c
+++ b/src/map/npc.c
@@ -15,7 +15,9 @@
#include "../../../map/pc.h"
#include "map/data/mapd.h"
+#include "map/data/npcd.h"
#include "map/struct/mapdext.h"
+#include "map/struct/npcdext.h"
#include "map/npc.h"
struct npc_data* enpc_checknear(struct map_session_data* sd, struct block_list* bl)
@@ -39,13 +41,29 @@ struct npc_data* enpc_checknear(struct map_session_data* sd, struct block_list*
if (nd->class_ < 0) //Class-less npc, enable click from anywhere.
return nd;
- if (bl->m != sd->bl.m ||
- bl->x < sd->bl.x - AREA_SIZE - 1 || bl->x > sd->bl.x + AREA_SIZE + 1 ||
- bl->y < sd->bl.y - AREA_SIZE - 1 || bl->y > sd->bl.y + AREA_SIZE + 1)
+ const int npcX = bl->x;
+ const int npcY = bl->y;
+ const int x = sd->bl.x;
+ const int y = sd->bl.y;
+
+ if (bl->m != sd->bl.m
+ || npcX < x - AREA_SIZE - 1 || npcX > x + AREA_SIZE + 1
+ || npcY < y - AREA_SIZE - 1 || npcY > y + AREA_SIZE + 1)
{
return NULL;
}
+ struct NpcdExt *data = npcd_get(nd);
+ if (data)
+ {
+ const int size = data->areaSize;
+ if (npcX < x - size || npcX > x + size
+ || npcY < y - size || npcY > y + size)
+ {
+ return NULL;
+ }
+ }
+
return nd;
}