continued cmd_set
[NeonServV5.git] / ChanUser.c
index 7366c83be0b7e83ce8f4ce5e64b07f90aa0ca3f1..69fc006621744b3d91061f134c6560490e8c8817 100644 (file)
@@ -10,11 +10,13 @@ struct ChanUser* addChanUser(struct ChanNode *chan, struct UserNode *user) {
         perror("malloc() failed");
         return NULL;
     }
+    chanuser->flags = 0;
     chanuser->user = user;
     chanuser->chan = chan;
 
     chanuser->next_user = chan->user;
     chan->user = chanuser;
+    chan->usercount++;
 
     chanuser->next_chan = user->channel;
     user->channel = chanuser;
@@ -73,6 +75,7 @@ void delChanUser(struct ChanUser *chanuser, int freeChanUser) {
     last = NULL;
     for(cchanuser = chanuser->chan->user; cchanuser; cchanuser = cchanuser->next_user) {
         if(cchanuser == chanuser) {
+            chanuser->chan->usercount--;
             if(last) 
                 last->next_user = chanuser->next_user;
             else
@@ -90,13 +93,14 @@ void delChanUser(struct ChanUser *chanuser, int freeChanUser) {
     }
 }
 
-void removeChanUserFromLists(struct ChanUser *chanuser, int remove_from_userlist, int remove_from_channellist int freeChanUser) {
+void removeChanUserFromLists(struct ChanUser *chanuser, int remove_from_userlist, int remove_from_channellist, int freeChanUser) {
     struct ChanUser *cchanuser, *last;
     if(remove_from_userlist) {
         //remove it from the channel's user-list
         last = NULL;
         for(cchanuser = chanuser->chan->user; cchanuser; cchanuser = cchanuser->next_user) {
             if(cchanuser == chanuser) {
+                chanuser->chan->usercount--;
                 if(last) 
                     last->next_user = chanuser->next_user;
                 else