diff options
-rw-r--r-- | src/elogin/parse.c | 4 | ||||
-rw-r--r-- | src/emap/clif.c | 102 |
2 files changed, 30 insertions, 76 deletions
diff --git a/src/elogin/parse.c b/src/elogin/parse.c index b6e4b5d..d17434b 100644 --- a/src/elogin/parse.c +++ b/src/elogin/parse.c @@ -35,7 +35,7 @@ void login_parse_version(int fd) clientVersion = RFIFOL(fd, 2); // check for minimal supported version - if (clientVersion < 19) + if (clientVersion < 20) { lclif->login_error(fd, 5); return; @@ -60,7 +60,7 @@ bool elogin_client_login_pre(int *fdPtr, safestrncpy(username, RFIFOP(fd, 6), NAME_LENGTH); int len = (int)safestrnlen(username, NAME_LENGTH); // check for minimal supported version - if (clientVersion < 19) + if (clientVersion < 20) { lclif->login_error(fd, 5); hookStop(); diff --git a/src/emap/clif.c b/src/emap/clif.c index 4892549..d0d3cde 100644 --- a/src/emap/clif.c +++ b/src/emap/clif.c @@ -89,55 +89,26 @@ void eclif_quest_send_list_pre(TBL_PC **sdPtr) return; } - struct SessionExt *data = session_get_bysd(sd); - if (!data) - return; - if (data->clientVersion < 20) + int fd = sd->fd; + int info_len = 4 + 1 + 3 * 4 + 4; + int len = sd->avail_quests * info_len + 8; + WFIFOHEAD(fd, len); + WFIFOW(fd, 0) = 0xb23 + evolPacketOffset; + WFIFOW(fd, 2) = len; + WFIFOL(fd, 4) = sd->avail_quests; + for (int i = 0; i < sd->avail_quests; i++ ) { - int fd = sd->fd; - int i; - int info_len = 15; - int len = sd->avail_quests * info_len + 8; - WFIFOHEAD(fd, len); - WFIFOW(fd, 0) = 0x97a; - WFIFOW(fd, 2) = len; - WFIFOL(fd, 4) = sd->avail_quests; - for (i = 0; i < sd->avail_quests; i++ ) - { - struct quest_db *qi = quest->db(sd->quest_log[i].quest_id); - if (!qi) - continue; - WFIFOL(fd, i * info_len + 8) = sd->quest_log[i].quest_id; - WFIFOB(fd, i * info_len + 12) = sd->quest_log[i].count[0]; // was state - WFIFOL(fd, i * info_len + 13) = sd->quest_log[i].time - qi->time; - WFIFOL(fd, i * info_len + 17) = sd->quest_log[i].time; - WFIFOW(fd, i * info_len + 21) = 0; - } - WFIFOSET(fd, len); - } - else - { // data->clientVersion >= 20 - int fd = sd->fd; - int info_len = 4 + 1 + 3 * 4 + 4; - int len = sd->avail_quests * info_len + 8; - WFIFOHEAD(fd, len); - WFIFOW(fd, 0) = 0xb23 + evolPacketOffset; - WFIFOW(fd, 2) = len; - WFIFOL(fd, 4) = sd->avail_quests; - for (int i = 0; i < sd->avail_quests; i++ ) - { - struct quest_db *qi = quest->db(sd->quest_log[i].quest_id); - if (!qi) - continue; - WFIFOL(fd, i * info_len + 8) = sd->quest_log[i].quest_id; - WFIFOB(fd, i * info_len + 12) = sd->quest_log[i].state; - WFIFOL(fd, i * info_len + 13) = sd->quest_log[i].count[0]; - WFIFOL(fd, i * info_len + 17) = sd->quest_log[i].count[1]; - WFIFOL(fd, i * info_len + 21) = sd->quest_log[i].count[2]; - WFIFOL(fd, i * info_len + 25) = sd->quest_log[i].time; - } - WFIFOSET(fd, len); + struct quest_db *qi = quest->db(sd->quest_log[i].quest_id); + if (!qi) + continue; + WFIFOL(fd, i * info_len + 8) = sd->quest_log[i].quest_id; + WFIFOB(fd, i * info_len + 12) = sd->quest_log[i].state; + WFIFOL(fd, i * info_len + 13) = sd->quest_log[i].count[0]; + WFIFOL(fd, i * info_len + 17) = sd->quest_log[i].count[1]; + WFIFOL(fd, i * info_len + 21) = sd->quest_log[i].count[2]; + WFIFOL(fd, i * info_len + 25) = sd->quest_log[i].time; } + WFIFOSET(fd, len); hookStop(); } @@ -151,7 +122,6 @@ void eclif_quest_add_pre(TBL_PC **sdPtr, void eclif_quest_add(TBL_PC *sd, struct quest *qd) { - // for new client need send here: id, 3 counts, time if (!sd || !qd) { hookStop(); @@ -166,32 +136,16 @@ void eclif_quest_add(TBL_PC *sd, return; } - struct SessionExt *data = session_get_bysd(sd); - if (!data) - return; - if (data->clientVersion < 20) - { - WFIFOHEAD(fd, 107); - WFIFOW(fd, 0) = 0x2b3; - WFIFOL(fd, 2) = qd->quest_id; - WFIFOB(fd, 6) = qd->count[0]; // was state; - WFIFOB(fd, 7) = qd->time - qi->time; - WFIFOL(fd, 11) = qd->time; - WFIFOW(fd, 15) = 0; - WFIFOSET(fd, 107); - } - else - { // data->clientVersion >= 20 - WFIFOHEAD(fd, 23); - WFIFOW(fd, 0) = 0xb24 + evolPacketOffset; - WFIFOL(fd, 2) = qd->quest_id; - WFIFOB(fd, 6) = qd->state; - WFIFOL(fd, 7) = qd->count[0]; - WFIFOL(fd, 11) = qd->count[1]; - WFIFOL(fd, 15) = qd->count[2]; - WFIFOL(fd, 19) = qd->time; - WFIFOSET(fd, 23); - } + WFIFOHEAD(fd, 23); + WFIFOW(fd, 0) = 0xb24 + evolPacketOffset; + WFIFOL(fd, 2) = qd->quest_id; + WFIFOB(fd, 6) = qd->state; + WFIFOL(fd, 7) = qd->count[0]; + WFIFOL(fd, 11) = qd->count[1]; + WFIFOL(fd, 15) = qd->count[2]; + WFIFOL(fd, 19) = qd->time; + WFIFOSET(fd, 23); + hookStop(); } |