Browse Source

network: use check_headers for binary search

2.9.x
ThomasV 8 years ago
parent
commit
8260dfdbe7
  1. 16
      lib/network.py

16
lib/network.py

@ -815,9 +815,10 @@ class Network(util.DaemonThread):
self.connection_down(interface.server) self.connection_down(interface.server)
interface.request = None interface.request = None
return return
can_connect = interface.blockchain.can_connect(header)
ok = interface.blockchain.check_header(header)
if interface.mode == 'backward': if interface.mode == 'backward':
if can_connect: if ok:
interface.good = height interface.good = height
interface.mode = 'binary' interface.mode = 'binary'
interface.print_error("binary search") interface.print_error("binary search")
@ -831,7 +832,7 @@ class Network(util.DaemonThread):
delta = interface.tip - height delta = interface.tip - height
next_height = max(0, interface.tip - 2 * delta) next_height = max(0, interface.tip - 2 * delta)
elif interface.mode == 'binary': elif interface.mode == 'binary':
if can_connect: if ok:
interface.good = height interface.good = height
else: else:
interface.bad = height interface.bad = height
@ -848,18 +849,19 @@ class Network(util.DaemonThread):
next_height = interface.tip next_height = interface.tip
else: else:
if b is None: if b is None:
b = interface.blockchain.fork(interface.good) b = interface.blockchain.fork(interface.bad)
self.blockchains[interface.good] = b self.blockchains[interface.bad] = b
interface.print_error("catching up on new blockchain", b.filename) interface.print_error("catching up on new blockchain", b.filename)
if b.catch_up is None: if b.catch_up is None:
b.catch_up = interface.server b.catch_up = interface.server
interface.blockchain = b interface.blockchain = b
interface.mode = 'catch_up' interface.mode = 'catch_up'
next_height = interface.good next_height = interface.bad
# todo: garbage collect blockchain objects # todo: garbage collect blockchain objects
self.notify('updated') self.notify('updated')
elif interface.mode == 'catch_up': elif interface.mode == 'catch_up':
can_connect = interface.blockchain.can_connect(header)
if can_connect: if can_connect:
interface.blockchain.save_header(header) interface.blockchain.save_header(header)
next_height = height + 1 if height < interface.tip else None next_height = height + 1 if height < interface.tip else None
@ -985,7 +987,7 @@ class Network(util.DaemonThread):
interface.bad = height interface.bad = height
self.request_header(interface, local_height) self.request_header(interface, local_height)
else: else:
if not interface.blockchain.can_connect(header): if not interface.blockchain.check_header(header):
self.print_error("backward", height) self.print_error("backward", height)
interface.mode = 'backward' interface.mode = 'backward'
interface.bad = height interface.bad = height

Loading…
Cancel
Save