aboutsummaryrefslogtreecommitdiffstats
path: root/eth/handler.go
diff options
context:
space:
mode:
authorJeffrey Wilcke <jeffrey@ethereum.org>2015-05-26 19:31:29 +0800
committerJeffrey Wilcke <jeffrey@ethereum.org>2015-05-26 19:31:29 +0800
commit0de13b0bbac4d5b63c46c055aaf3d47beb84e602 (patch)
tree41afc5a39511986eef58d8787adf8ad55a20d241 /eth/handler.go
parent5044eb4b26616adbf2d263d5ff46ecc3e4dddc26 (diff)
parenteafdc1f8e371fd698da33491a01799393249729a (diff)
downloaddexon-0de13b0bbac4d5b63c46c055aaf3d47beb84e602.tar
dexon-0de13b0bbac4d5b63c46c055aaf3d47beb84e602.tar.gz
dexon-0de13b0bbac4d5b63c46c055aaf3d47beb84e602.tar.bz2
dexon-0de13b0bbac4d5b63c46c055aaf3d47beb84e602.tar.lz
dexon-0de13b0bbac4d5b63c46c055aaf3d47beb84e602.tar.xz
dexon-0de13b0bbac4d5b63c46c055aaf3d47beb84e602.tar.zst
dexon-0de13b0bbac4d5b63c46c055aaf3d47beb84e602.zip
Merge pull request #1102 from karalabe/maintain-block-origins
eth, eth/downloader: surface downloaded block origin, drop on error
Diffstat (limited to 'eth/handler.go')
-rw-r--r--eth/handler.go12
1 files changed, 6 insertions, 6 deletions
diff --git a/eth/handler.go b/eth/handler.go
index 9117a70de..777a9c7c0 100644
--- a/eth/handler.go
+++ b/eth/handler.go
@@ -92,13 +92,13 @@ func NewProtocolManager(protocolVersion, networkId int, mux *event.TypeMux, txpo
return manager
}
-func (pm *ProtocolManager) removePeer(peer *peer) {
+func (pm *ProtocolManager) removePeer(id string) {
// Unregister the peer from the downloader
- pm.downloader.UnregisterPeer(peer.id)
+ pm.downloader.UnregisterPeer(id)
// Remove the peer from the Ethereum peer set too
- glog.V(logger.Detail).Infoln("Removing peer", peer.id)
- if err := pm.peers.Unregister(peer.id); err != nil {
+ glog.V(logger.Detail).Infoln("Removing peer", id)
+ if err := pm.peers.Unregister(id); err != nil {
glog.V(logger.Error).Infoln("Removal failed:", err)
}
}
@@ -148,7 +148,7 @@ func (pm *ProtocolManager) handle(p *peer) error {
glog.V(logger.Error).Infoln("Addition failed:", err)
return err
}
- defer pm.removePeer(p)
+ defer pm.removePeer(p.id)
if err := pm.downloader.RegisterPeer(p.id, p.recentHash, p.requestHashes, p.requestBlocks); err != nil {
return err
@@ -315,7 +315,7 @@ func (self *ProtocolManager) handleMsg(p *peer) error {
if _, err := self.chainman.InsertChain(types.Blocks{request.Block}); err != nil {
glog.V(logger.Error).Infoln("removed peer (", p.id, ") due to block error")
- self.removePeer(p)
+ self.removePeer(p.id)
return nil
}