strcpy(user->nick, new_nick);
return 1;
}
- int userListIndex = get_nicklist_entry(*new_nick);
- delUser(user, 0);
+ //delUser(user, 0); //EPIC FAIL! This deletes the user from the channel Userlist -.-
+ //manually remove the user from the old userList
+ int userListIndex = get_nicklist_entry(user->nick[0]);
+ if(userListIndex != -1) {
+ struct UserNode *cuser, *last_user = NULL;
+ for(cuser = userList[userListIndex]; cuser; cuser = cuser->next) {
+ if(cuser == user) {
+ if(last_user)
+ last_user->next = user->next;
+ else
+ userList[userListIndex] = user->next;
+ break;
+ } else
+ last_user = cuser;
+ }
+ }
+ userListIndex = get_nicklist_entry(*new_nick);
strcpy(user->nick, new_nick);
user->next = userList[userListIndex];
userList[userListIndex] = user;