aboutsummaryrefslogtreecommitdiffstats
path: root/eth
diff options
context:
space:
mode:
Diffstat (limited to 'eth')
-rw-r--r--eth/downloader/downloader.go5
-rw-r--r--eth/downloader/events.go6
2 files changed, 7 insertions, 4 deletions
diff --git a/eth/downloader/downloader.go b/eth/downloader/downloader.go
index 4db689f73..58d19254c 100644
--- a/eth/downloader/downloader.go
+++ b/eth/downloader/downloader.go
@@ -415,7 +415,8 @@ func (d *Downloader) syncWithPeer(p *peerConnection, hash common.Hash, td *big.I
if err != nil {
d.mux.Post(FailedEvent{err})
} else {
- d.mux.Post(DoneEvent{})
+ latest := d.lightchain.CurrentHeader()
+ d.mux.Post(DoneEvent{latest})
}
}()
if p.version < 62 {
@@ -1369,7 +1370,6 @@ func (d *Downloader) processHeaders(origin uint64, pivot uint64, td *big.Int) er
}
// Otherwise split the chunk of headers into batches and process them
gotHeaders = true
-
for len(headers) > 0 {
// Terminate if something failed in between processing chunks
select {
@@ -1432,7 +1432,6 @@ func (d *Downloader) processHeaders(origin uint64, pivot uint64, td *big.Int) er
headers = headers[limit:]
origin += uint64(limit)
}
-
// Update the highest block number we know if a higher one is found.
d.syncStatsLock.Lock()
if d.syncStatsChainHeight < origin {
diff --git a/eth/downloader/events.go b/eth/downloader/events.go
index 64905b8f2..25255a3a7 100644
--- a/eth/downloader/events.go
+++ b/eth/downloader/events.go
@@ -16,6 +16,10 @@
package downloader
-type DoneEvent struct{}
+import "github.com/ethereum/go-ethereum/core/types"
+
+type DoneEvent struct {
+ Latest *types.Header
+}
type StartEvent struct{}
type FailedEvent struct{ Err error }