summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorgeniusdex geniusdex@31f1291d-b8d6-0310-a050-a5561fc1590b <geniusdex geniusdex@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864>2008-01-26 10:50:44 +0000
committergeniusdex geniusdex@31f1291d-b8d6-0310-a050-a5561fc1590b <geniusdex geniusdex@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864>2008-01-26 10:50:44 +0000
commitba7e2d8440ad1936f33e0c017d1d202b7008b147 (patch)
tree1ba1850514a1f1f41e80435488eb394eb8962fbc /src
parent3e977708beb1cd13a0c66f2bdfb6f1303ab5e588 (diff)
BUILD : 1.7.21 (1363) BUGS : 842 NOTES : Fixed yet another memory leak; it wass cs_akick this time
git-svn-id: svn://svn.anope.org/anope/trunk@1363 31f1291d-b8d6-0310-a050-a5561fc1590b git-svn-id: http://anope.svn.sourceforge.net/svnroot/anope/trunk@1078 5417fbe8-f217-4b02-8779-1006273d7864
Diffstat (limited to 'src')
-rw-r--r--src/core/cs_akick.c11
1 files changed, 11 insertions, 0 deletions
diff --git a/src/core/cs_akick.c b/src/core/cs_akick.c
index c6b98f1c9..b3c15cd6f 100644
--- a/src/core/cs_akick.c
+++ b/src/core/cs_akick.c
@@ -209,6 +209,7 @@ int do_akick(User * u)
NickAlias *na = findnick(mask);
NickCore *nc = NULL;
char *nick, *user, *host;
+ int freemask = 0;
if (readonly) {
notice_lang(s_ChanServ, u, CHAN_AKICK_DISABLED);
@@ -219,6 +220,7 @@ int do_akick(User * u)
split_usermask(mask, &nick, &user, &host);
mask =
scalloc(strlen(nick) + strlen(user) + strlen(host) + 3, 1);
+ freemask = 1;
sprintf(mask, "%s!%s@%s", nick, user, host);
free(nick);
free(user);
@@ -235,6 +237,8 @@ int do_akick(User * u)
if (ircd->except) {
if (is_excepted_mask(ci, mask) == 1) {
notice_lang(s_ChanServ, u, CHAN_EXCEPTED, mask, chan);
+ if (freemask)
+ free(mask);
return MOD_CONT;
}
}
@@ -247,6 +251,8 @@ int do_akick(User * u)
notice_lang(s_ChanServ, u, CHAN_AKICK_ALREADY_EXISTS,
(akick->flags & AK_ISNICK) ? akick->u.nc->
display : akick->u.mask, chan);
+ if (freemask)
+ free(mask);
return MOD_CONT;
}
}
@@ -255,6 +261,8 @@ int do_akick(User * u)
* the entire list. We simply add new entries at the end. */
if (ci->akickcount >= CSAutokickMax) {
notice_lang(s_ChanServ, u, CHAN_AKICK_REACHED_LIMIT, CSAutokickMax);
+ if (freemask)
+ free(mask);
return MOD_CONT;
}
ci->akickcount++;
@@ -308,6 +316,9 @@ int do_akick(User * u)
if (count)
notice_lang(s_ChanServ, u, CHAN_AKICK_ENFORCE_DONE, chan,
count);
+
+ if (freemask)
+ free(mask);
} else if (stricmp(cmd, "STICK") == 0) {
NickAlias *na;