summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorKevin Chabowski <kevin@kch42.de>2014-03-25 13:30:20 +0100
committerKevin Chabowski <kevin@kch42.de>2014-03-25 13:30:20 +0100
commit74f01b3117ae49d2d42facc362d8c932f5769d9d (patch)
treeec5ca7f202966a865c44a73831b2a6c3f2affba2
parent07ab116456823b92e9c8963eaca5a6ae648390ec (diff)
downloadsimplechat-74f01b3117ae49d2d42facc362d8c932f5769d9d.tar.gz
simplechat-74f01b3117ae49d2d42facc362d8c932f5769d9d.tar.bz2
simplechat-74f01b3117ae49d2d42facc362d8c932f5769d9d.zip
We need the room too when joining
-rw-r--r--buddy.go5
-rw-r--r--rooms.go6
2 files changed, 8 insertions, 3 deletions
diff --git a/buddy.go b/buddy.go
index 0d1fb0c..750e424 100644
--- a/buddy.go
+++ b/buddy.go
@@ -3,8 +3,13 @@ package main
type Buddy struct {
Nick string
Receive chan Message
+ room *Room
}
func NewBuddy(nick string, room *Room) *Buddy {
// TODO: Implement me!
}
+
+func (b *Buddy) Leave() {
+ b.room.Leave(b.Nick)
+}
diff --git a/rooms.go b/rooms.go
index 6a5accd..e7512ee 100644
--- a/rooms.go
+++ b/rooms.go
@@ -42,7 +42,7 @@ func (r *Room) Broadcast() {
var rooms = make(map[string]Room)
-func Join(room, nick string) (*Buddy, error) {
+func Join(room, nick string) (*Buddy, *Room, error) {
r, ok := rooms[room]
if !ok {
r = NewRoom()
@@ -50,11 +50,11 @@ func Join(room, nick string) (*Buddy, error) {
}
if _, there := r.Buddies[nick]; there {
- return nil, errors.New("Nickname is already in use")
+ return nil, room, errors.New("Nickname is already in use")
}
if len(r.Buddies) >= *perroom {
- return nil, errors.New("Room is full")
+ return nil, room, errors.New("Room is full")
}
r.Messages <- Message{