|
@ -339,6 +339,13 @@ h256s BlockChain::import(bytes const& _block, OverlayDB const& _db) |
|
|
#endif |
|
|
#endif |
|
|
// All ok - insert into DB
|
|
|
// All ok - insert into DB
|
|
|
{ |
|
|
{ |
|
|
|
|
|
// ensure parent is cached for later addition.
|
|
|
|
|
|
// TODO: this is a bit horrible would be better refactored into an enveloping UpgradableGuard
|
|
|
|
|
|
// together with an "ensureCachedWithUpdatableLock(l)" method.
|
|
|
|
|
|
// This is safe in practice since the caches don't get flushed nearly often enough to be
|
|
|
|
|
|
// done here.
|
|
|
|
|
|
details(bi.parentHash); |
|
|
|
|
|
|
|
|
WriteGuard l(x_details); |
|
|
WriteGuard l(x_details); |
|
|
m_details[newHash] = BlockDetails((unsigned)pd.number + 1, td, bi.parentHash, {}); |
|
|
m_details[newHash] = BlockDetails((unsigned)pd.number + 1, td, bi.parentHash, {}); |
|
|
m_details[bi.parentHash].children.push_back(newHash); |
|
|
m_details[bi.parentHash].children.push_back(newHash); |
|
@ -455,14 +462,14 @@ h256s BlockChain::import(bytes const& _block, OverlayDB const& _db) |
|
|
|
|
|
|
|
|
h256s BlockChain::treeRoute(h256 const& _from, h256 const& _to, h256* o_common, bool _pre, bool _post) const |
|
|
h256s BlockChain::treeRoute(h256 const& _from, h256 const& _to, h256* o_common, bool _pre, bool _post) const |
|
|
{ |
|
|
{ |
|
|
// cdebug << "treeRoute" << _from.abridged() << "..." << _to.abridged();
|
|
|
cdebug << "treeRoute" << _from.abridged() << "..." << _to.abridged(); |
|
|
if (!_from || !_to) |
|
|
if (!_from || !_to) |
|
|
return h256s(); |
|
|
return h256s(); |
|
|
h256s ret; |
|
|
h256s ret; |
|
|
h256s back; |
|
|
h256s back; |
|
|
unsigned fn = details(_from).number; |
|
|
unsigned fn = details(_from).number; |
|
|
unsigned tn = details(_to).number; |
|
|
unsigned tn = details(_to).number; |
|
|
// cdebug << "treeRoute" << fn << "..." << tn;
|
|
|
cdebug << "treeRoute" << fn << "..." << tn; |
|
|
h256 from = _from; |
|
|
h256 from = _from; |
|
|
while (fn > tn) |
|
|
while (fn > tn) |
|
|
{ |
|
|
{ |
|
@ -470,7 +477,7 @@ h256s BlockChain::treeRoute(h256 const& _from, h256 const& _to, h256* o_common, |
|
|
ret.push_back(from); |
|
|
ret.push_back(from); |
|
|
from = details(from).parent; |
|
|
from = details(from).parent; |
|
|
fn--; |
|
|
fn--; |
|
|
// cdebug << "from:" << fn << _from.abridged();
|
|
|
cdebug << "from:" << fn << _from.abridged(); |
|
|
} |
|
|
} |
|
|
h256 to = _to; |
|
|
h256 to = _to; |
|
|
while (fn < tn) |
|
|
while (fn < tn) |
|
@ -479,12 +486,14 @@ h256s BlockChain::treeRoute(h256 const& _from, h256 const& _to, h256* o_common, |
|
|
back.push_back(to); |
|
|
back.push_back(to); |
|
|
to = details(to).parent; |
|
|
to = details(to).parent; |
|
|
tn--; |
|
|
tn--; |
|
|
// cdebug << "to:" << tn << _to.abridged();
|
|
|
cdebug << "to:" << tn << _to.abridged(); |
|
|
} |
|
|
} |
|
|
while (from != to) |
|
|
while (from != to) |
|
|
{ |
|
|
{ |
|
|
assert(from); |
|
|
if (!from) |
|
|
assert(to); |
|
|
assert(from); |
|
|
|
|
|
if (!to) |
|
|
|
|
|
assert(to); |
|
|
from = details(from).parent; |
|
|
from = details(from).parent; |
|
|
to = details(to).parent; |
|
|
to = details(to).parent; |
|
|
if (_pre) |
|
|
if (_pre) |
|
|