eth/downloader: fetch the block hashes on the fly, when needed
This commit is contained in:
		| @@ -80,7 +80,7 @@ type Downloader struct { | |||||||
|  |  | ||||||
| 	// Statistics | 	// Statistics | ||||||
| 	importStart time.Time // Instance when the last blocks were taken from the cache | 	importStart time.Time // Instance when the last blocks were taken from the cache | ||||||
| 	importQueue []common.Hash // Hashes of the previously taken blocks to check import progress | 	importQueue []*Block  // Previously taken blocks to check import progress | ||||||
| 	importDone  int       // Number of taken blocks already imported from the last batch | 	importDone  int       // Number of taken blocks already imported from the last batch | ||||||
| 	importLock  sync.Mutex | 	importLock  sync.Mutex | ||||||
|  |  | ||||||
| @@ -136,7 +136,7 @@ func (d *Downloader) Stats() (pending int, cached int, importing int, estimate t | |||||||
| 	d.importLock.Lock() | 	d.importLock.Lock() | ||||||
| 	defer d.importLock.Unlock() | 	defer d.importLock.Unlock() | ||||||
|  |  | ||||||
| 	for len(d.importQueue) > 0 && d.hasBlock(d.importQueue[0]) { | 	for len(d.importQueue) > 0 && d.hasBlock(d.importQueue[0].RawBlock.Hash()) { | ||||||
| 		d.importQueue = d.importQueue[1:] | 		d.importQueue = d.importQueue[1:] | ||||||
| 		d.importDone++ | 		d.importDone++ | ||||||
| 	} | 	} | ||||||
| @@ -229,13 +229,9 @@ func (d *Downloader) Synchronise(id string, hash common.Hash) error { | |||||||
| func (d *Downloader) TakeBlocks() []*Block { | func (d *Downloader) TakeBlocks() []*Block { | ||||||
| 	blocks := d.queue.TakeBlocks() | 	blocks := d.queue.TakeBlocks() | ||||||
| 	if len(blocks) > 0 { | 	if len(blocks) > 0 { | ||||||
| 		hashes := make([]common.Hash, len(blocks)) |  | ||||||
| 		for i, block := range blocks { |  | ||||||
| 			hashes[i] = block.RawBlock.Hash() |  | ||||||
| 		} |  | ||||||
| 		d.importLock.Lock() | 		d.importLock.Lock() | ||||||
| 		d.importStart = time.Now() | 		d.importStart = time.Now() | ||||||
| 		d.importQueue = hashes | 		d.importQueue = blocks | ||||||
| 		d.importDone = 0 | 		d.importDone = 0 | ||||||
| 		d.importLock.Unlock() | 		d.importLock.Unlock() | ||||||
| 	} | 	} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user