diff options
author | Maran <maran.hidskes@gmail.com> | 2014-05-12 22:30:21 +0800 |
---|---|---|
committer | Maran <maran.hidskes@gmail.com> | 2014-05-12 22:32:21 +0800 |
commit | 52b664b0aec24bffc040da06bbe8be1d3e7e4ab8 (patch) | |
tree | 1f2d235e6e2b66cb0d05e12bde90017bba2feb0c | |
parent | 8fe0864680b40c3fa5e47775856d8ae1997ba003 (diff) | |
download | dexon-52b664b0aec24bffc040da06bbe8be1d3e7e4ab8.tar dexon-52b664b0aec24bffc040da06bbe8be1d3e7e4ab8.tar.gz dexon-52b664b0aec24bffc040da06bbe8be1d3e7e4ab8.tar.bz2 dexon-52b664b0aec24bffc040da06bbe8be1d3e7e4ab8.tar.lz dexon-52b664b0aec24bffc040da06bbe8be1d3e7e4ab8.tar.xz dexon-52b664b0aec24bffc040da06bbe8be1d3e7e4ab8.tar.zst dexon-52b664b0aec24bffc040da06bbe8be1d3e7e4ab8.zip |
Removed peers from peerlist as soon as they disconnect. Might fix #13
We used to wait for the reaping timer to clean up the peerlist, not any longer
-rw-r--r-- | peer.go | 10 |
1 files changed, 10 insertions, 0 deletions
@@ -2,6 +2,7 @@ package eth import ( "bytes" + "container/list" "fmt" "github.com/ethereum/eth-go/ethchain" "github.com/ethereum/eth-go/ethutil" @@ -515,6 +516,15 @@ func (p *Peer) Stop() { p.writeMessage(ethwire.NewMessage(ethwire.MsgDiscTy, "")) p.conn.Close() } + + // Pre-emptively remove the peer; don't wait for reaping. We already know it's dead if we are here + p.ethereum.peerMut.Lock() + defer p.ethereum.peerMut.Unlock() + eachPeer(p.ethereum.peers, func(peer *Peer, e *list.Element) { + if peer == p { + p.ethereum.peers.Remove(e) + } + }) } func (p *Peer) pushHandshake() error { |