aboutsummaryrefslogtreecommitdiffstats
path: root/cmd/utils/cmd.go
diff options
context:
space:
mode:
authorJeffrey Wilcke <jeffrey@ethereum.org>2015-04-13 23:34:34 +0800
committerJeffrey Wilcke <jeffrey@ethereum.org>2015-04-13 23:34:34 +0800
commit5f9346bc7afd64706b3815aec6be2b2650929a6b (patch)
treeff02f1f4f36246e2431b43207f2400b49417e051 /cmd/utils/cmd.go
parentad4891a09a4f7c7fa3e77c5370c01f16a0a3070e (diff)
parent49a513bdebd7c4402b3a7f2f169a31c34f2ca9df (diff)
downloaddexon-5f9346bc7afd64706b3815aec6be2b2650929a6b.tar
dexon-5f9346bc7afd64706b3815aec6be2b2650929a6b.tar.gz
dexon-5f9346bc7afd64706b3815aec6be2b2650929a6b.tar.bz2
dexon-5f9346bc7afd64706b3815aec6be2b2650929a6b.tar.lz
dexon-5f9346bc7afd64706b3815aec6be2b2650929a6b.tar.xz
dexon-5f9346bc7afd64706b3815aec6be2b2650929a6b.tar.zst
dexon-5f9346bc7afd64706b3815aec6be2b2650929a6b.zip
Merge pull request #700 from bas-vk/issue_650
Added blockchain DB versioning support, closes #650
Diffstat (limited to 'cmd/utils/cmd.go')
-rw-r--r--cmd/utils/cmd.go25
1 files changed, 22 insertions, 3 deletions
diff --git a/cmd/utils/cmd.go b/cmd/utils/cmd.go
index a6140d233..7286f5c5e 100644
--- a/cmd/utils/cmd.go
+++ b/cmd/utils/cmd.go
@@ -155,7 +155,11 @@ func ImportChain(chainmgr *core.ChainManager, fn string) error {
chainmgr.Reset()
stream := rlp.NewStream(fh)
- var i int
+ var i, n int
+
+ batchSize := 2500
+ blocks := make(types.Blocks, batchSize)
+
for ; ; i++ {
var b types.Block
if err := stream.Decode(&b); err == io.EOF {
@@ -163,10 +167,25 @@ func ImportChain(chainmgr *core.ChainManager, fn string) error {
} else if err != nil {
return fmt.Errorf("at block %d: %v", i, err)
}
- if err := chainmgr.InsertChain(types.Blocks{&b}); err != nil {
- return fmt.Errorf("invalid block %d: %v", i, err)
+
+ blocks[n] = &b
+ n++
+
+ if n == batchSize {
+ if err := chainmgr.InsertChain(blocks); err != nil {
+ return fmt.Errorf("invalid block %v", err)
+ }
+ n = 0
+ blocks = make(types.Blocks, batchSize)
+ }
+ }
+
+ if n > 0 {
+ if err := chainmgr.InsertChain(blocks[:n]); err != nil {
+ return fmt.Errorf("invalid block %v", err)
}
}
+
fmt.Printf("imported %d blocks\n", i)
return nil
}