p2p/discover: fix pending replies iteration
Range expressions capture the length of the slice once before the first iteration. A range expression cannot be used here since the loop modifies the slice variable (including length changes).
This commit is contained in:
parent
643eda5c2d
commit
7ea131d4ff
|
@ -253,7 +253,8 @@ func (t *udp) loop() {
|
||||||
|
|
||||||
case reply := <-t.replies:
|
case reply := <-t.replies:
|
||||||
// run matching callbacks, remove if they return false.
|
// run matching callbacks, remove if they return false.
|
||||||
for i, p := range pending {
|
for i := 0; i < len(pending); i++ {
|
||||||
|
p := pending[i]
|
||||||
if reply.from == p.from && reply.ptype == p.ptype && p.callback(reply.data) {
|
if reply.from == p.from && reply.ptype == p.ptype && p.callback(reply.data) {
|
||||||
p.errc <- nil
|
p.errc <- nil
|
||||||
copy(pending[i:], pending[i+1:])
|
copy(pending[i:], pending[i+1:])
|
||||||
|
|
Loading…
Reference in New Issue