Skip to content

Commit

Permalink
internal: drain channel when stopping timer (#165)
Browse files Browse the repository at this point in the history
  • Loading branch information
peterjan committed Jun 7, 2024
1 parent 3563813 commit b6076d9
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 3 deletions.
18 changes: 16 additions & 2 deletions internal/smux/session.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,14 @@ func (tm *tryMutex) TryLock(t time.Duration) bool {
default:
}
timer := time.NewTimer(t)
defer timer.Stop()
defer func() {
if !timer.Stop() {
select {
case <-timer.C:
default:
}
}
}()
select {
case <-tm.lock:
return true
Expand Down Expand Up @@ -149,7 +156,14 @@ func (s *Session) AcceptStream() (*Stream, error) {
var deadline <-chan time.Time
if d, ok := s.deadline.Load().(time.Time); ok && !d.IsZero() {
timer := time.NewTimer(time.Until(d))
defer timer.Stop()
defer func() {
if !timer.Stop() {
select {
case <-timer.C:
default:
}
}
}()
deadline = timer.C
}
select {
Expand Down
9 changes: 8 additions & 1 deletion internal/smux/stream.go
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,14 @@ func (s *Stream) Read(b []byte) (n int, err error) {
var deadline <-chan time.Time
if d, ok := s.readDeadline.Load().(time.Time); ok && !d.IsZero() {
timer := time.NewTimer(time.Until(d))
defer timer.Stop()
defer func() {
if !timer.Stop() {
select {
case <-timer.C:
default:
}
}
}()
deadline = timer.C
}

Expand Down

0 comments on commit b6076d9

Please sign in to comment.