mirror of
https://github.com/ergochat/ergo.git
synced 2025-01-08 19:22:53 +01:00
swap refcounting friends for iteration
This commit is contained in:
parent
9e471b5b5d
commit
86d4cae141
@ -120,12 +120,6 @@ func (channel *Channel) Join(client *Client, key string) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
client.channels.Add(channel)
|
client.channels.Add(channel)
|
||||||
|
|
||||||
for member := range channel.members {
|
|
||||||
client.AddFriend(member)
|
|
||||||
member.AddFriend(client)
|
|
||||||
}
|
|
||||||
|
|
||||||
channel.Reply(RplJoin(client, channel))
|
channel.Reply(RplJoin(client, channel))
|
||||||
channel.GetTopic(client)
|
channel.GetTopic(client)
|
||||||
channel.Names(client)
|
channel.Names(client)
|
||||||
@ -286,11 +280,6 @@ func (channel *Channel) Notice(client *Client, message string) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (channel *Channel) Quit(client *Client) {
|
func (channel *Channel) Quit(client *Client) {
|
||||||
for member := range channel.members {
|
|
||||||
client.RemoveFriend(member)
|
|
||||||
member.RemoveFriend(client)
|
|
||||||
}
|
|
||||||
|
|
||||||
channel.members.Remove(client)
|
channel.members.Remove(client)
|
||||||
client.channels.Remove(channel)
|
client.channels.Remove(channel)
|
||||||
}
|
}
|
||||||
|
@ -18,7 +18,6 @@ type Client struct {
|
|||||||
channels ChannelSet
|
channels ChannelSet
|
||||||
ctime time.Time
|
ctime time.Time
|
||||||
flags map[UserMode]bool
|
flags map[UserMode]bool
|
||||||
friends map[*Client]uint
|
|
||||||
hasQuit bool
|
hasQuit bool
|
||||||
hops uint
|
hops uint
|
||||||
hostname string
|
hostname string
|
||||||
@ -40,7 +39,6 @@ func NewClient(server *Server, conn net.Conn) *Client {
|
|||||||
channels: make(ChannelSet),
|
channels: make(ChannelSet),
|
||||||
ctime: now,
|
ctime: now,
|
||||||
flags: make(map[UserMode]bool),
|
flags: make(map[UserMode]bool),
|
||||||
friends: make(map[*Client]uint),
|
|
||||||
hostname: AddrLookupHostname(conn.RemoteAddr()),
|
hostname: AddrLookupHostname(conn.RemoteAddr()),
|
||||||
phase: server.InitPhase(),
|
phase: server.InitPhase(),
|
||||||
server: server,
|
server: server,
|
||||||
@ -137,7 +135,6 @@ func (client *Client) Idle() {
|
|||||||
func (client *Client) Register() {
|
func (client *Client) Register() {
|
||||||
client.phase = Normal
|
client.phase = Normal
|
||||||
client.loginTimer.Stop()
|
client.loginTimer.Stop()
|
||||||
client.AddFriend(client)
|
|
||||||
client.Touch()
|
client.Touch()
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -228,15 +225,15 @@ func (c *Client) String() string {
|
|||||||
return c.Id()
|
return c.Id()
|
||||||
}
|
}
|
||||||
|
|
||||||
func (client *Client) AddFriend(friend *Client) {
|
func (client *Client) Friends() ClientSet {
|
||||||
client.friends[friend] += 1
|
friends := make(ClientSet)
|
||||||
}
|
friends.Add(client)
|
||||||
|
for channel := range client.channels {
|
||||||
func (client *Client) RemoveFriend(friend *Client) {
|
for member := range channel.members {
|
||||||
client.friends[friend] -= 1
|
friends.Add(member)
|
||||||
if client.friends[friend] <= 0 {
|
|
||||||
delete(client.friends, friend)
|
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
return friends
|
||||||
}
|
}
|
||||||
|
|
||||||
func (client *Client) ChangeNickname(nickname string) {
|
func (client *Client) ChangeNickname(nickname string) {
|
||||||
@ -245,7 +242,7 @@ func (client *Client) ChangeNickname(nickname string) {
|
|||||||
|
|
||||||
client.nick = nickname
|
client.nick = nickname
|
||||||
|
|
||||||
for friend := range client.friends {
|
for friend := range client.Friends() {
|
||||||
friend.Reply(reply)
|
friend.Reply(reply)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -256,14 +253,13 @@ func (client *Client) Quit(message string) {
|
|||||||
}
|
}
|
||||||
client.hasQuit = true
|
client.hasQuit = true
|
||||||
client.Reply(RplError(client.server, client.Nick()))
|
client.Reply(RplError(client.server, client.Nick()))
|
||||||
|
friends := client.Friends()
|
||||||
|
friends.Remove(client)
|
||||||
client.Destroy()
|
client.Destroy()
|
||||||
|
|
||||||
if len(client.friends) > 0 {
|
if len(friends) > 0 {
|
||||||
reply := RplQuit(client, message)
|
reply := RplQuit(client, message)
|
||||||
for friend := range client.friends {
|
for friend := range friends {
|
||||||
if friend == client {
|
|
||||||
continue
|
|
||||||
}
|
|
||||||
friend.Reply(reply)
|
friend.Reply(reply)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user