mirror of
https://github.com/kvazar-network/kevacoin.git
synced 2025-01-11 15:48:05 +00:00
Update Linearize tool to support Windows paths
This commit is contained in:
parent
66e5465773
commit
e3c42973b2
@ -3,7 +3,7 @@ Construct a linear, no-fork, best version of the blockchain.
|
|||||||
|
|
||||||
## Step 1: Download hash list
|
## Step 1: Download hash list
|
||||||
|
|
||||||
$ ./linearize-hashes.py linearize.cfg > hashlist.txt
|
$ ./linearize-hashes.py linearize.cfg > hashlist.txt
|
||||||
|
|
||||||
Required configuration file settings for linearize-hashes:
|
Required configuration file settings for linearize-hashes:
|
||||||
* RPC: rpcuser, rpcpassword
|
* RPC: rpcuser, rpcpassword
|
||||||
@ -14,7 +14,7 @@ Optional config file setting for linearize-hashes:
|
|||||||
|
|
||||||
## Step 2: Copy local block data
|
## Step 2: Copy local block data
|
||||||
|
|
||||||
$ ./linearize-data.py linearize.cfg
|
$ ./linearize-data.py linearize.cfg
|
||||||
|
|
||||||
Required configuration file settings:
|
Required configuration file settings:
|
||||||
* "input": bitcoind blocks/ directory containing blkNNNNN.dat
|
* "input": bitcoind blocks/ directory containing blkNNNNN.dat
|
||||||
@ -26,7 +26,7 @@ output.
|
|||||||
|
|
||||||
Optional config file setting for linearize-data:
|
Optional config file setting for linearize-data:
|
||||||
* "netmagic": network magic number
|
* "netmagic": network magic number
|
||||||
* "max_out_sz": maximum output file size (default 1000*1000*1000)
|
* "max_out_sz": maximum output file size (default `1000*1000*1000`)
|
||||||
* "split_timestamp": Split files when a new month is first seen, in addition to
|
* "split_timestamp": Split files when a new month is first seen, in addition to
|
||||||
reaching a maximum file size.
|
reaching a maximum file size.
|
||||||
* "file_timestamp": Set each file's last-modified time to that of the
|
* "file_timestamp": Set each file's last-modified time to that of the
|
||||||
|
@ -12,6 +12,7 @@ import json
|
|||||||
import struct
|
import struct
|
||||||
import re
|
import re
|
||||||
import os
|
import os
|
||||||
|
import os.path
|
||||||
import base64
|
import base64
|
||||||
import httplib
|
import httplib
|
||||||
import sys
|
import sys
|
||||||
@ -115,19 +116,20 @@ class BlockDataCopier:
|
|||||||
self.setFileTime = True
|
self.setFileTime = True
|
||||||
if settings['split_timestamp'] != 0:
|
if settings['split_timestamp'] != 0:
|
||||||
self.timestampSplit = True
|
self.timestampSplit = True
|
||||||
# Extents and cache for out-of-order blocks
|
# Extents and cache for out-of-order blocks
|
||||||
self.blockExtents = {}
|
self.blockExtents = {}
|
||||||
self.outOfOrderData = {}
|
self.outOfOrderData = {}
|
||||||
self.outOfOrderSize = 0 # running total size for items in outOfOrderData
|
self.outOfOrderSize = 0 # running total size for items in outOfOrderData
|
||||||
|
|
||||||
def writeBlock(self, inhdr, blk_hdr, rawblock):
|
def writeBlock(self, inhdr, blk_hdr, rawblock):
|
||||||
if not self.fileOutput and ((self.outsz + self.inLen) > self.maxOutSz):
|
blockSizeOnDisk = len(inhdr) + len(blk_hdr) + len(rawblock)
|
||||||
|
if not self.fileOutput and ((self.outsz + blockSizeOnDisk) > self.maxOutSz):
|
||||||
self.outF.close()
|
self.outF.close()
|
||||||
if self.setFileTime:
|
if self.setFileTime:
|
||||||
os.utime(outFname, (int(time.time()), highTS))
|
os.utime(outFname, (int(time.time()), highTS))
|
||||||
self.outF = None
|
self.outF = None
|
||||||
self.outFname = None
|
self.outFname = None
|
||||||
self.outFn = outFn + 1
|
self.outFn = self.outFn + 1
|
||||||
self.outsz = 0
|
self.outsz = 0
|
||||||
|
|
||||||
(blkDate, blkTS) = get_blk_dt(blk_hdr)
|
(blkDate, blkTS) = get_blk_dt(blk_hdr)
|
||||||
@ -147,7 +149,7 @@ class BlockDataCopier:
|
|||||||
if self.fileOutput:
|
if self.fileOutput:
|
||||||
outFname = self.settings['output_file']
|
outFname = self.settings['output_file']
|
||||||
else:
|
else:
|
||||||
outFname = "%s/blk%05d.dat" % (self.settings['output'], outFn)
|
outFname = os.path.join(self.settings['output'], "blk%05d.dat" % self.outFn)
|
||||||
print("Output file " + outFname)
|
print("Output file " + outFname)
|
||||||
self.outF = open(outFname, "wb")
|
self.outF = open(outFname, "wb")
|
||||||
|
|
||||||
@ -165,7 +167,7 @@ class BlockDataCopier:
|
|||||||
(self.blkCountIn, self.blkCountOut, len(self.blkindex), 100.0 * self.blkCountOut / len(self.blkindex)))
|
(self.blkCountIn, self.blkCountOut, len(self.blkindex), 100.0 * self.blkCountOut / len(self.blkindex)))
|
||||||
|
|
||||||
def inFileName(self, fn):
|
def inFileName(self, fn):
|
||||||
return "%s/blk%05d.dat" % (self.settings['input'], fn)
|
return os.path.join(self.settings['input'], "blk%05d.dat" % fn)
|
||||||
|
|
||||||
def fetchBlock(self, extent):
|
def fetchBlock(self, extent):
|
||||||
'''Fetch block contents from disk given extents'''
|
'''Fetch block contents from disk given extents'''
|
||||||
|
Loading…
Reference in New Issue
Block a user