|
@@ -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)
|
|
|
}
|
|
@@ -54,13 +62,16 @@ func main() {
|
|
|
}
|
|
|
}
|
|
|
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
type Peers struct {
|
|
|
m map[string]chan<- Message
|
|
|
mu sync.RWMutex
|
|
|
}
|
|
|
|
|
|
+var peers = Peers{
|
|
|
+ m: make(map[string]chan<- Message),
|
|
|
+}
|
|
|
+
|
|
|
|
|
|
|
|
|
func (p *Peers) Add(addr string) <-chan Message {
|
|
@@ -93,9 +104,15 @@ func (p *Peers) List() []chan<- Message {
|
|
|
}
|
|
|
|
|
|
func broadcast(m Message) {
|
|
|
- for {
|
|
|
-
|
|
|
+
|
|
|
+ for i, peer := range peers.List() {
|
|
|
+
|
|
|
|
|
|
+ select {
|
|
|
+ case peer <- m:
|
|
|
+ default:
|
|
|
+ log.Printf("Sending to peer %d would have blocked.\n", i)
|
|
|
+ }
|
|
|
}
|
|
|
}
|
|
|
|
|
@@ -110,8 +127,8 @@ func serve(c net.Conn) {
|
|
|
return
|
|
|
}
|
|
|
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+ go dial(m.Addr)
|
|
|
fmt.Printf("%#v\n", m)
|
|
|
}
|
|
|
}
|
|
@@ -128,15 +145,24 @@ func readInput() {
|
|
|
if err := s.Err(); err != nil {
|
|
|
log.Fatal(err)
|
|
|
}
|
|
|
+ os.Exit(0)
|
|
|
}
|
|
|
|
|
|
func dial(addr string) {
|
|
|
-
|
|
|
+
|
|
|
+ if addr == self {
|
|
|
+ return
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ ch := peers.Add(addr)
|
|
|
+
|
|
|
+ if ch == nil {
|
|
|
+ return
|
|
|
+ }
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
+
|
|
|
+ defer peers.Remove(addr)
|
|
|
|
|
|
c, err := net.Dial("tcp", addr)
|
|
|
if err != nil {
|