peer: ensure the chanMsgStream for a channel exists on peer d/c
This commit is contained in:
parent
c47408119e
commit
0377a4f99d
14
peer.go
14
peer.go
@ -441,6 +441,9 @@ func (c *chanMsgStream) Stop() {
|
|||||||
// TODO(roasbeef): signal too?
|
// TODO(roasbeef): signal too?
|
||||||
|
|
||||||
close(c.quit)
|
close(c.quit)
|
||||||
|
|
||||||
|
// Wake up the msgConsumer is we've been signalled to exit.
|
||||||
|
c.msgCond.Signal()
|
||||||
}
|
}
|
||||||
|
|
||||||
// msgConsumer is the main goroutine that streams messages from the peer's
|
// msgConsumer is the main goroutine that streams messages from the peer's
|
||||||
@ -454,6 +457,17 @@ func (c *chanMsgStream) msgConsumer() {
|
|||||||
c.msgCond.L.Lock()
|
c.msgCond.L.Lock()
|
||||||
for len(c.msgs) == 0 {
|
for len(c.msgs) == 0 {
|
||||||
c.msgCond.Wait()
|
c.msgCond.Wait()
|
||||||
|
|
||||||
|
// If we were woke up in order to exit, then we'll do
|
||||||
|
// so. Otherwise, we'll check the message queue for any
|
||||||
|
// new items.
|
||||||
|
select {
|
||||||
|
case <-c.quit:
|
||||||
|
peerLog.Tracef("Update stream for "+
|
||||||
|
"ChannelID(%x) exiting", c.cid[:])
|
||||||
|
return
|
||||||
|
default:
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Grab the message off the front of the queue, shifting the
|
// Grab the message off the front of the queue, shifting the
|
||||||
|
Loading…
Reference in New Issue
Block a user