diff options
author | Dastgir <dastgirpojee@rocketmail.com> | 2016-01-18 16:48:12 +0530 |
---|---|---|
committer | Asheraf <acheraf1998@gmail.com> | 2018-03-12 18:06:07 +0000 |
commit | 8e8e0a2da0f9696c5965e79237642b3dee36dd78 (patch) | |
tree | df585afc832dbb90887b3940cb11a187bcc4dd92 /src/map/clif.c | |
parent | 6234d9e5a1c7ef248efc743a0e14ec7758f1fdac (diff) | |
download | hercules-8e8e0a2da0f9696c5965e79237642b3dee36dd78.tar.gz hercules-8e8e0a2da0f9696c5965e79237642b3dee36dd78.tar.bz2 hercules-8e8e0a2da0f9696c5965e79237642b3dee36dd78.tar.xz hercules-8e8e0a2da0f9696c5965e79237642b3dee36dd78.zip |
Changed ADD_QUEST packet to structure form
Diffstat (limited to 'src/map/clif.c')
-rw-r--r-- | src/map/clif.c | 39 |
1 files changed, 24 insertions, 15 deletions
diff --git a/src/map/clif.c b/src/map/clif.c index 2c9995835..e996db1f1 100644 --- a/src/map/clif.c +++ b/src/map/clif.c @@ -16224,31 +16224,40 @@ void clif_quest_send_mission(struct map_session_data *sd) /// 02b3 <quest id>.L <active>.B <start time>.L <expire time>.L <mobs>.W { <mob id>.L <mob count>.W <mob name>.24B }*3 void clif_quest_add(struct map_session_data *sd, struct quest *qd) { - int fd; - int i; + int i, len; + uint8 *buf = NULL; + struct packet_quest_add_header *packet = NULL; struct quest_db *qi; nullpo_retv(sd); nullpo_retv(qd); - fd = sd->fd; + qi = quest->db(qd->quest_id); - WFIFOHEAD(fd, packet_len(0x2b3)); - WFIFOW(fd, 0) = 0x2b3; - WFIFOL(fd, 2) = qd->quest_id; - WFIFOB(fd, 6) = qd->state; - WFIFOB(fd, 7) = qd->time - qi->time; - WFIFOL(fd, 11) = qd->time; - WFIFOW(fd, 15) = qi->objectives_count; + Assert_retv(qi->objectives_count < MAX_QUEST_OBJECTIVES); + + len = sizeof(struct packet_quest_add_header) + + MAX_QUEST_OBJECTIVES * sizeof(struct packet_quest_hunt_sub); // >= than the actual length + + buf = aCalloc(1, len); + packet = (struct packet_quest_add_header *)WBUFP(buf, 0); + + packet->PacketType = questAddType; + packet->questID = qd->quest_id; + packet->active = qd->state; + packet->quest_svrTime = qd->time - qi->time; + packet->quest_endTime = qd->time; + packet->count = qi->objectives_count; for (i = 0; i < qi->objectives_count; i++) { struct mob_db *monster; - WFIFOL(fd, i*30+17) = qi->objectives[i].mob; - WFIFOW(fd, i*30+21) = qd->count[i]; + monster = mob->db(qi->objectives[i].mob); - memcpy(WFIFOP(fd, i*30+23), monster->jname, NAME_LENGTH); + packet->objectives[i].mob_id = qi->objectives[i].mob; + packet->objectives[i].huntCount = qd->count[i]; + memcpy(packet->objectives[i].mobName, monster->jname, NAME_LENGTH); } - - WFIFOSET(fd, packet_len(0x2b3)); + clif->send(buf, len, &sd->bl, SELF); + aFree(buf); } /// Notification about a quest being removed (ZC_DEL_QUEST). |