|
@@ -19,12 +19,13 @@ import (
|
|
|
"os"
|
|
|
"sync"
|
|
|
|
|
|
- "github.com/campoy/whispering-gophers/util"
|
|
|
+ "code.osinet.fr/fgm/whispering_gophers/util"
|
|
|
)
|
|
|
|
|
|
var (
|
|
|
- peerAddr = flag.String("peer", "", "peer host:port")
|
|
|
- self string
|
|
|
+ listenAddr = flag.String("listen", "", "peer host:port")
|
|
|
+ peerAddr = flag.String("peer", "", "peer host:port")
|
|
|
+ self string
|
|
|
)
|
|
|
|
|
|
type Message struct {
|
|
@@ -35,7 +36,14 @@ type Message struct {
|
|
|
func main() {
|
|
|
flag.Parse()
|
|
|
|
|
|
- l, err := util.Listen()
|
|
|
+ var l net.Listener
|
|
|
+ var err error
|
|
|
+
|
|
|
+ if *listenAddr == "" {
|
|
|
+ l, err = util.ListenOnFirstUsableInterface()
|
|
|
+ } else {
|
|
|
+ l, err = net.Listen("tcp4", *listenAddr)
|
|
|
+ }
|
|
|
if err != nil {
|
|
|
log.Fatal(err)
|
|
|
}
|
|
@@ -62,31 +70,49 @@ type Peers struct {
|
|
|
|
|
|
|
|
|
func (p *Peers) Add(addr string) <-chan Message {
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+ p.mu.Lock()
|
|
|
+ defer p.mu.Unlock()
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ _, ok := p.m[addr]
|
|
|
+ if ok {
|
|
|
+ return nil
|
|
|
+ }
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+ peer := make(chan Message)
|
|
|
+
|
|
|
+ p.m[addr] = peer
|
|
|
+
|
|
|
+ return peer
|
|
|
}
|
|
|
|
|
|
|
|
|
func (p *Peers) Remove(addr string) {
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+ p.mu.Lock()
|
|
|
+ defer p.mu.Unlock()
|
|
|
+
|
|
|
+ delete(p.m, addr)
|
|
|
}
|
|
|
|
|
|
|
|
|
func (p *Peers) List() []chan<- Message {
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
- for {
|
|
|
-
|
|
|
+
|
|
|
+ p.mu.Lock()
|
|
|
+ defer p.mu.Unlock()
|
|
|
+
|
|
|
+ channels := make([]chan<- Message, 0, len(p.m))
|
|
|
+
|
|
|
+
|
|
|
+ for _, v := range p.m {
|
|
|
+
|
|
|
+ channels = append(channels, v)
|
|
|
}
|
|
|
-
|
|
|
+
|
|
|
+ return channels
|
|
|
}
|
|
|
|
|
|
func serve(c net.Conn) {
|
|
@@ -117,6 +143,7 @@ func readInput() {
|
|
|
if err := s.Err(); err != nil {
|
|
|
log.Fatal(err)
|
|
|
}
|
|
|
+ os.Exit(0)
|
|
|
}
|
|
|
|
|
|
func dial(addr string) {
|