summaryrefslogtreecommitdiff
path: root/src/map/clan.c
diff options
context:
space:
mode:
authorAndrei Karas <akaras@inbox.ru>2018-02-08 22:39:28 +0300
committerAndrei Karas <akaras@inbox.ru>2018-02-08 22:41:48 +0300
commitda1b096806c868b1e9f4a82b88d05a6b032c1a63 (patch)
tree848f3e978f1c89ee2ac2b9ce12562741f84c8938 /src/map/clan.c
parent19c94017a31d86f7848085162ffb741770975128 (diff)
downloadhercules-da1b096806c868b1e9f4a82b88d05a6b032c1a63.tar.gz
hercules-da1b096806c868b1e9f4a82b88d05a6b032c1a63.tar.bz2
hercules-da1b096806c868b1e9f4a82b88d05a6b032c1a63.tar.xz
hercules-da1b096806c868b1e9f4a82b88d05a6b032c1a63.zip
Fix different clan issues.
Add missing online check for clan members. Clean sd pointer after clan member went offline.
Diffstat (limited to 'src/map/clan.c')
-rw-r--r--src/map/clan.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/src/map/clan.c b/src/map/clan.c
index b67726b37..6855e449d 100644
--- a/src/map/clan.c
+++ b/src/map/clan.c
@@ -103,7 +103,7 @@ struct map_session_data *clan_getonlinesd(struct clan *c)
int i;
nullpo_retr(NULL, c);
- ARR_FIND(0, VECTOR_LENGTH(c->members), i, VECTOR_INDEX(c->members, i).sd != NULL);
+ ARR_FIND(0, VECTOR_LENGTH(c->members), i, (VECTOR_INDEX(c->members, i).sd != NULL && VECTOR_INDEX(c->members, i).online == 1));
return (i < VECTOR_LENGTH(c->members)) ? VECTOR_INDEX(c->members, i).sd : NULL;
}
@@ -294,6 +294,7 @@ void clan_member_online(struct map_session_data *sd, bool first)
if (c->kick_time > 0 && inactivity > c->kick_time) {
if (m->online == 1) {
m->online = 0;
+ m->sd = NULL;
c->connect_member--;
c->member_count--;
}
@@ -306,6 +307,7 @@ void clan_member_online(struct map_session_data *sd, bool first)
return;
}
+ m->sd = sd;
m->online = 1;
m->last_login = sd->status.last_login;
}
@@ -403,6 +405,7 @@ void clan_member_offline(struct map_session_data *sd)
if (i != INDEX_NOT_FOUND && VECTOR_INDEX(c->members, i).online == 1) {
// Only if it is online, because unit->free is called twice
VECTOR_INDEX(c->members, i).online = 0;
+ VECTOR_INDEX(c->members, i).sd = NULL;
c->connect_member--;
}
clif->clan_onlinecount(c);