mirror of
https://github.com/libp2p/go-libp2p-peerstore.git
synced 2025-01-14 02:30:05 +08:00
334bc6f886
* update go-libp2p-core and fix tests for new minimum key size. This slows down the test but terribly. * switch to go-multiaddr-fmt * update the datastore * update gogo/protobuf
63 lines
1.1 KiB
Go
63 lines
1.1 KiB
Go
package addr
|
|
|
|
import (
|
|
"bytes"
|
|
|
|
ma "github.com/multiformats/go-multiaddr"
|
|
mafmt "github.com/multiformats/go-multiaddr-fmt"
|
|
manet "github.com/multiformats/go-multiaddr-net"
|
|
)
|
|
|
|
func isFDCostlyTransport(a ma.Multiaddr) bool {
|
|
return mafmt.TCP.Matches(a)
|
|
}
|
|
|
|
type AddrList []ma.Multiaddr
|
|
|
|
func (al AddrList) Len() int {
|
|
return len(al)
|
|
}
|
|
|
|
func (al AddrList) Swap(i, j int) {
|
|
al[i], al[j] = al[j], al[i]
|
|
}
|
|
|
|
func (al AddrList) Less(i, j int) bool {
|
|
a := al[i]
|
|
b := al[j]
|
|
|
|
// dial localhost addresses next, they should fail immediately
|
|
lba := manet.IsIPLoopback(a)
|
|
lbb := manet.IsIPLoopback(b)
|
|
if lba {
|
|
if !lbb {
|
|
return true
|
|
}
|
|
}
|
|
|
|
// dial utp and similar 'non-fd-consuming' addresses first
|
|
fda := isFDCostlyTransport(a)
|
|
fdb := isFDCostlyTransport(b)
|
|
if !fda {
|
|
if fdb {
|
|
return true
|
|
}
|
|
|
|
// if neither consume fd's, assume equal ordering
|
|
return false
|
|
}
|
|
|
|
// if 'b' doesnt take a file descriptor
|
|
if !fdb {
|
|
return false
|
|
}
|
|
|
|
// if 'b' is loopback and both take file descriptors
|
|
if lbb {
|
|
return false
|
|
}
|
|
|
|
// for the rest, just sort by bytes
|
|
return bytes.Compare(a.Bytes(), b.Bytes()) > 0
|
|
}
|