packer/rpc: cleaner way to keep the seq number in MuxConn high

This commit is contained in:
Mitchell Hashimoto 2013-12-12 10:23:37 -08:00
parent 64e6897739
commit 916053b278
1 changed files with 5 additions and 6 deletions

View File

@ -163,6 +163,11 @@ func (m *MuxConn) openStream(id uint32) (*Stream, error) {
m.mu.Lock()
defer m.mu.Unlock()
// Make sure we attempt to use the next biggest stream ID
if id >= m.curId {
m.curId = id + 1
}
// We have to check this again because there is a time period
// above where we couldn't lost this lock.
if stream, ok := m.streams[id]; ok {
@ -302,12 +307,6 @@ func (m *MuxConn) loop() {
m.mu.Lock()
delete(m.streams, stream.id)
// Make sure we attempt to use the next biggest stream ID
if stream.id >= m.curId {
m.curId = stream.id + 1
}
m.mu.Unlock()
default:
log.Printf("[ERR] Fin received for stream %d in state: %d", id, stream.state)