summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2019-01-08 00:31:51 +0300
committerAndrei Karas <akaras@inbox.ru>2019-01-08 00:31:51 +0300
commit62e260303a026d9846a95656a71d410b29d2e6a9 (patch)
tree120754d5c517db9c9ac1da99266a00a954db66fb
parent3c478103d2172d7aa7a22c8fcb48afc02925bd53 (diff)
downloadevol-hercules-62e260303a026d9846a95656a71d410b29d2e6a9.tar.gz
evol-hercules-62e260303a026d9846a95656a71d410b29d2e6a9.tar.bz2
evol-hercules-62e260303a026d9846a95656a71d410b29d2e6a9.tar.xz
evol-hercules-62e260303a026d9846a95656a71d410b29d2e6a9.zip
Drop support for client protocol version 19.s20190123
-rw-r--r--src/elogin/parse.c4
-rw-r--r--src/emap/clif.c102
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();
}