mirror of
https://github.com/libp2p/go-libp2p-peerstore.git
synced 2025-01-16 02:50:07 +08:00
read/write protocol lock
This commit is contained in:
parent
b496ee5433
commit
af2cb17f80
10
peerstore.go
10
peerstore.go
@ -21,7 +21,7 @@ type peerstore struct {
|
|||||||
PeerMetadata
|
PeerMetadata
|
||||||
|
|
||||||
// lock for protocol information, separate from datastore lock
|
// lock for protocol information, separate from datastore lock
|
||||||
protolock sync.Mutex
|
protolock sync.RWMutex
|
||||||
internedProtocols map[string]string
|
internedProtocols map[string]string
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -142,8 +142,8 @@ func (ps *peerstore) getProtocolMap(p peer.ID) (map[string]struct{}, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (ps *peerstore) GetProtocols(p peer.ID) ([]string, error) {
|
func (ps *peerstore) GetProtocols(p peer.ID) ([]string, error) {
|
||||||
ps.protolock.Lock()
|
ps.protolock.RLock()
|
||||||
defer ps.protolock.Unlock()
|
defer ps.protolock.RUnlock()
|
||||||
pmap, err := ps.getProtocolMap(p)
|
pmap, err := ps.getProtocolMap(p)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
@ -158,8 +158,8 @@ func (ps *peerstore) GetProtocols(p peer.ID) ([]string, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func (ps *peerstore) SupportsProtocols(p peer.ID, protos ...string) ([]string, error) {
|
func (ps *peerstore) SupportsProtocols(p peer.ID, protos ...string) ([]string, error) {
|
||||||
ps.protolock.Lock()
|
ps.protolock.RLock()
|
||||||
defer ps.protolock.Unlock()
|
defer ps.protolock.RUnlock()
|
||||||
pmap, err := ps.getProtocolMap(p)
|
pmap, err := ps.getProtocolMap(p)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
|
Loading…
Reference in New Issue
Block a user