forked from TrueCloudLab/neoneo-go
Merge pull request #481 from nspcc-dev/core-fix-init-corner-cases
Fix init corner cases
This commit is contained in:
commit
f686069f37
1 changed files with 20 additions and 13 deletions
|
@ -101,6 +101,10 @@ func (bc *Blockchain) init() error {
|
|||
return err
|
||||
}
|
||||
bc.headerList = NewHeaderHashList(genesisBlock.Hash())
|
||||
err = bc.store.Put(storage.SYSCurrentHeader.Bytes(), hashAndIndexToBytes(genesisBlock.Hash(), genesisBlock.Index))
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
return bc.storeBlock(genesisBlock)
|
||||
}
|
||||
if ver != version {
|
||||
|
@ -131,6 +135,9 @@ func (bc *Blockchain) init() error {
|
|||
if err != nil {
|
||||
return err
|
||||
}
|
||||
if bc.storedHeaderCount == 0 && currHeaderHeight == 0 {
|
||||
bc.headerList.Add(currHeaderHash)
|
||||
}
|
||||
|
||||
// There is a high chance that the Node is stopped before the next
|
||||
// batch of 2000 headers was stored. Via the currentHeaders stored we can sync
|
||||
|
@ -146,6 +153,7 @@ func (bc *Blockchain) init() error {
|
|||
return err
|
||||
}
|
||||
targetHash = genesisBlock.Hash()
|
||||
bc.headerList.Add(targetHash)
|
||||
}
|
||||
headers := make([]*Header, 0)
|
||||
|
||||
|
@ -157,7 +165,6 @@ func (bc *Blockchain) init() error {
|
|||
headers = append(headers, header)
|
||||
hash = header.PrevHash
|
||||
}
|
||||
|
||||
headerSliceReverse(headers)
|
||||
for _, h := range headers {
|
||||
if !h.Verify() {
|
||||
|
@ -266,7 +273,7 @@ func (bc *Blockchain) AddHeaders(headers ...*Header) (err error) {
|
|||
}
|
||||
|
||||
if oldlen != headerList.Len() {
|
||||
updateHeaderHeightMetric(headerList.Len()-1)
|
||||
updateHeaderHeightMetric(headerList.Len() - 1)
|
||||
if err = bc.store.PutBatch(batch); err != nil {
|
||||
return
|
||||
}
|
||||
|
@ -492,6 +499,7 @@ func (bc *Blockchain) persist() error {
|
|||
if err != nil {
|
||||
return err
|
||||
}
|
||||
if persisted > 0 {
|
||||
bHeight, err := storage.CurrentBlockHeight(bc.store)
|
||||
if err != nil {
|
||||
return err
|
||||
|
@ -503,7 +511,6 @@ func (bc *Blockchain) persist() error {
|
|||
if err != nil {
|
||||
return err
|
||||
}
|
||||
if persisted > 0 {
|
||||
log.WithFields(log.Fields{
|
||||
"persistedBlocks": diff,
|
||||
"persistedKeys": persisted,
|
||||
|
|
Loading…
Reference in a new issue