filter out `nil` values when iterating peers
Iterating peers should only yield peers present in registry, otherwise `nil` pointers are returned and depending on comparison function it will break, see #6149.
This commit is contained in:
parent
885989f3df
commit
95aed2b220
|
@ -652,12 +652,12 @@ iterator peers*[A, B](pool: PeerPool[A, B],
|
||||||
## All peers will be sorted by equation `>`(Peer1, Peer2), so biggest values
|
## All peers will be sorted by equation `>`(Peer1, Peer2), so biggest values
|
||||||
## will be first.
|
## will be first.
|
||||||
var sorted = initHeapQueue[PeerIndex]()
|
var sorted = initHeapQueue[PeerIndex]()
|
||||||
for i in 0 ..< len(pool.storage):
|
for peerIdx in pool.registry.values():
|
||||||
if pool.storage[i].peerType in filter:
|
if pool.storage[peerIdx.data].peerType in filter:
|
||||||
sorted.push(PeerIndex(data: i, cmp: pool.cmp))
|
sorted.push(peerIdx)
|
||||||
while len(sorted) > 0:
|
while len(sorted) > 0:
|
||||||
let pindex = sorted.pop().data
|
let peerIdx = sorted.pop()
|
||||||
yield pool.storage[pindex].data
|
yield pool.storage[peerIdx.data].data
|
||||||
|
|
||||||
iterator availablePeers*[A, B](pool: PeerPool[A, B],
|
iterator availablePeers*[A, B](pool: PeerPool[A, B],
|
||||||
filter = {PeerType.Incoming,
|
filter = {PeerType.Incoming,
|
||||||
|
@ -667,13 +667,13 @@ iterator availablePeers*[A, B](pool: PeerPool[A, B],
|
||||||
## All peers will be sorted by equation `>`(Peer1, Peer2), so biggest values
|
## All peers will be sorted by equation `>`(Peer1, Peer2), so biggest values
|
||||||
## will be first.
|
## will be first.
|
||||||
var sorted = initHeapQueue[PeerIndex]()
|
var sorted = initHeapQueue[PeerIndex]()
|
||||||
for i in 0 ..< len(pool.storage):
|
for peerIdx in pool.registry.values():
|
||||||
if (PeerFlags.Acquired notin pool.storage[i].flags) and
|
if (PeerFlags.Acquired notin pool.storage[peerIdx.data].flags) and
|
||||||
(pool.storage[i].peerType in filter):
|
(pool.storage[peerIdx.data].peerType in filter):
|
||||||
sorted.push(PeerIndex(data: i, cmp: pool.cmp))
|
sorted.push(peerIdx)
|
||||||
while len(sorted) > 0:
|
while len(sorted) > 0:
|
||||||
let pindex = sorted.pop().data
|
let peerIdx = sorted.pop()
|
||||||
yield pool.storage[pindex].data
|
yield pool.storage[peerIdx.data].data
|
||||||
|
|
||||||
iterator acquiredPeers*[A, B](pool: PeerPool[A, B],
|
iterator acquiredPeers*[A, B](pool: PeerPool[A, B],
|
||||||
filter = {PeerType.Incoming,
|
filter = {PeerType.Incoming,
|
||||||
|
@ -683,13 +683,13 @@ iterator acquiredPeers*[A, B](pool: PeerPool[A, B],
|
||||||
## All peers will be sorted by equation `>`(Peer1, Peer2), so biggest values
|
## All peers will be sorted by equation `>`(Peer1, Peer2), so biggest values
|
||||||
## will be first.
|
## will be first.
|
||||||
var sorted = initHeapQueue[PeerIndex]()
|
var sorted = initHeapQueue[PeerIndex]()
|
||||||
for i in 0 ..< len(pool.storage):
|
for peerIdx in pool.registry.values():
|
||||||
if (PeerFlags.Acquired in pool.storage[i].flags) and
|
if (PeerFlags.Acquired in pool.storage[peerIdx.data].flags) and
|
||||||
(pool.storage[i].peerType in filter):
|
(pool.storage[peerIdx.data].peerType in filter):
|
||||||
sorted.push(PeerIndex(data: i, cmp: pool.cmp))
|
sorted.push(peerIdx)
|
||||||
while len(sorted) > 0:
|
while len(sorted) > 0:
|
||||||
let pindex = sorted.pop().data
|
let peerIdx = sorted.pop()
|
||||||
yield pool.storage[pindex].data
|
yield pool.storage[peerIdx.data].data
|
||||||
|
|
||||||
proc `[]`*[A, B](pool: PeerPool[A, B], key: B): A {.inline, raises: [KeyError].} =
|
proc `[]`*[A, B](pool: PeerPool[A, B], key: B): A {.inline, raises: [KeyError].} =
|
||||||
## Retrieve peer with key ``key`` from PeerPool ``pool``.
|
## Retrieve peer with key ``key`` from PeerPool ``pool``.
|
||||||
|
|
Loading…
Reference in New Issue