Module: ngircd.git Branch: master Commit: 175f0af979bfdb6dfde1535dd7de6a452cf98e32 URL: http://ngircd.barton.de/cgi-bin/gitweb.cgi?p=ngircd.git&a=commit;h=175f0...
Author: Alexander Barton alex@barton.de Date: Mon Jan 5 12:58:37 2009 +0100
Clean up channel allocation table on shutdown/restart.
Silly bug: the condition of a while() loop in the Channel_Exit() function used the wrong variable and therefore got never executed ...
This bug is in the code since the beginning (see commit bb19cfda in 2002); shame on me!
---
src/ngircd/channel.c | 7 +++---- 1 files changed, 3 insertions(+), 4 deletions(-)
diff --git a/src/ngircd/channel.c b/src/ngircd/channel.c index ba5e725..9a59712 100644 --- a/src/ngircd/channel.c +++ b/src/ngircd/channel.c @@ -1,6 +1,6 @@ /* * ngIRCd -- The Next Generation IRC Daemon - * Copyright (c)2001-2008 by Alexander Barton (alex@barton.de) + * Copyright (c)2001-2009 Alexander Barton (alex@barton.de) * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -174,10 +174,9 @@ Channel_Exit( void )
/* Free Channel allocation table */ cl2chan = My_Cl2Chan; - while( c ) - { + while (cl2chan) { cl2chan_next = cl2chan->next; - free( cl2chan ); + free(cl2chan); cl2chan = cl2chan_next; } } /* Channel_Exit */