|
|
|
@ -1076,8 +1076,11 @@ func (bc *BlockChain) InsertReceiptChain(blockChain types.Blocks, receiptChain [ |
|
|
|
|
|
|
|
|
|
// Wipe out canonical block data.
|
|
|
|
|
for _, block := range append(deleted, blockChain...) { |
|
|
|
|
rawdb.DeleteBlockWithoutNumber(batch, block.Hash(), block.NumberU64()) |
|
|
|
|
rawdb.DeleteCanonicalHash(batch, block.NumberU64()) |
|
|
|
|
// Always keep genesis block in active database.
|
|
|
|
|
if block.NumberU64() != 0 { |
|
|
|
|
rawdb.DeleteBlockWithoutNumber(batch, block.Hash(), block.NumberU64()) |
|
|
|
|
rawdb.DeleteCanonicalHash(batch, block.NumberU64()) |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
if err := batch.Write(); err != nil { |
|
|
|
|
return 0, err |
|
|
|
@ -1086,8 +1089,11 @@ func (bc *BlockChain) InsertReceiptChain(blockChain types.Blocks, receiptChain [ |
|
|
|
|
|
|
|
|
|
// Wipe out side chain too.
|
|
|
|
|
for _, block := range append(deleted, blockChain...) { |
|
|
|
|
for _, hash := range rawdb.ReadAllHashes(bc.db, block.NumberU64()) { |
|
|
|
|
rawdb.DeleteBlock(batch, hash, block.NumberU64()) |
|
|
|
|
// Always keep genesis block in active database.
|
|
|
|
|
if block.NumberU64() != 0 { |
|
|
|
|
for _, hash := range rawdb.ReadAllHashes(bc.db, block.NumberU64()) { |
|
|
|
|
rawdb.DeleteBlock(batch, hash, block.NumberU64()) |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
} |
|
|
|
|
if err := batch.Write(); err != nil { |
|
|
|
|