Skip to content

Commit

Permalink
Merge pull request #4484 from clemahieu/ledger_successor_simplify
Browse files Browse the repository at this point in the history
Simplify the nano::ledger::successor function to make its implementation more obvious.
  • Loading branch information
clemahieu authored Mar 15, 2024
2 parents 77a3512 + 5681836 commit 2d08704
Show file tree
Hide file tree
Showing 15 changed files with 57 additions and 60 deletions.
14 changes: 7 additions & 7 deletions nano/core_test/ledger.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -256,7 +256,7 @@ TEST (ledger, process_receive)
ASSERT_EQ (nano::dev::constants.genesis_amount - 25, ledger.account_balance (transaction, key2.pub));
ASSERT_EQ (nano::dev::constants.genesis_amount - 25, ledger.weight (key3.pub));
ASSERT_FALSE (ledger.rollback (transaction, hash4));
ASSERT_TRUE (store.block.successor (transaction, hash2).is_zero ());
ASSERT_FALSE (ledger.successor (transaction, hash2));
ASSERT_EQ (25, ledger.account_balance (transaction, nano::dev::genesis_key.pub));
ASSERT_EQ (25, ledger.account_receivable (transaction, key2.pub));
ASSERT_EQ (nano::dev::constants.genesis_amount - 50, ledger.account_balance (transaction, key2.pub));
Expand Down Expand Up @@ -1175,9 +1175,9 @@ TEST (ledger, successor)
node1.work_generate_blocking (*send1);
auto transaction (node1.store.tx_begin_write ());
ASSERT_EQ (nano::block_status::progress, node1.ledger.process (transaction, send1));
ASSERT_EQ (*send1, *node1.ledger.successor (transaction, nano::qualified_root (nano::root (0), nano::dev::genesis->hash ())));
ASSERT_EQ (*nano::dev::genesis, *node1.ledger.successor (transaction, nano::dev::genesis->qualified_root ()));
ASSERT_EQ (nullptr, node1.ledger.successor (transaction, nano::qualified_root (0)));
ASSERT_EQ (*send1, *node1.ledger.block (transaction, node1.ledger.successor (transaction, nano::qualified_root (nano::root (0), nano::dev::genesis->hash ())).value ()));
ASSERT_EQ (*nano::dev::genesis, *node1.ledger.block (transaction, node1.ledger.successor (transaction, nano::dev::genesis->qualified_root ()).value ()));
ASSERT_FALSE (node1.ledger.successor (transaction, nano::qualified_root (0)));
}

TEST (ledger, fail_change_old)
Expand Down Expand Up @@ -3139,7 +3139,7 @@ TEST (ledger, state_rollback_send)
ASSERT_EQ (nano::dev::constants.genesis_amount, ledger.account_balance (transaction, nano::dev::genesis_key.pub));
ASSERT_EQ (nano::dev::constants.genesis_amount, ledger.weight (nano::dev::genesis_key.pub));
ASSERT_FALSE (store.pending.exists (transaction, nano::pending_key (nano::dev::genesis_key.pub, send1->hash ())));
ASSERT_TRUE (store.block.successor (transaction, nano::dev::genesis->hash ()).is_zero ());
ASSERT_FALSE (ledger.successor (transaction, nano::dev::genesis->hash ()));
ASSERT_EQ (store.account.count (transaction), ledger.cache.account_count);
}

Expand Down Expand Up @@ -4006,8 +4006,8 @@ TEST (ledger, successor_epoch)
ASSERT_EQ (nano::block_status::progress, node1.ledger.process (transaction, change));
ASSERT_EQ (nano::block_status::progress, node1.ledger.process (transaction, send2));
ASSERT_EQ (nano::block_status::progress, node1.ledger.process (transaction, epoch_open));
ASSERT_EQ (*change, *node1.ledger.successor (transaction, change->qualified_root ()));
ASSERT_EQ (*epoch_open, *node1.ledger.successor (transaction, epoch_open->qualified_root ()));
ASSERT_EQ (*change, *node1.ledger.block (transaction, node1.ledger.successor (transaction, change->qualified_root ()).value ()));
ASSERT_EQ (*epoch_open, *node1.ledger.block (transaction, node1.ledger.successor (transaction, epoch_open->qualified_root ()).value ()));
ASSERT_EQ (nano::epoch::epoch_1, epoch_open->sideband ().details.epoch);
ASSERT_EQ (nano::epoch::epoch_0, epoch_open->sideband ().source_epoch); // Not used for epoch state blocks
}
Expand Down
2 changes: 1 addition & 1 deletion nano/nano_node/entry.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1588,7 +1588,7 @@ int main (int argc, char * const * argv)
calculated_representative = block->representative_field ().value ();
}
// Retrieving successor block hash
hash = node->store.block.successor (transaction, hash);
hash = node->ledger.successor (transaction, hash).value_or (0);
// Retrieving block data
if (!hash.is_zero ())
{
Expand Down
3 changes: 2 additions & 1 deletion nano/node/blockprocessor.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -155,7 +155,8 @@ void nano::block_processor::force (std::shared_ptr<nano::block> const & block_a)
void nano::block_processor::rollback_competitor (store::write_transaction const & transaction, nano::block const & block)
{
auto hash = block.hash ();
auto successor = node.ledger.successor (transaction, block.qualified_root ());
auto successor_hash = node.ledger.successor (transaction, block.qualified_root ());
auto successor = successor_hash ? node.ledger.block (transaction, successor_hash.value ()) : nullptr;
if (successor != nullptr && successor->hash () != hash)
{
// Replace our block with the winner and roll back any dependent blocks
Expand Down
2 changes: 1 addition & 1 deletion nano/node/bootstrap/bootstrap_bulk_pull.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -376,7 +376,7 @@ void nano::bulk_pull_server::set_current_end ()
{
node->logger.debug (nano::log::type::bulk_pull_server, "Bulk pull request for block hash: {}", request->start.to_string ());

current = ascending () ? node->store.block.successor (transaction, request->start.as_block_hash ()) : request->start.as_block_hash ();
current = ascending () ? node->ledger.successor (transaction, request->start.as_block_hash ()).value_or (0) : request->start.as_block_hash ();
include_start = true;
}
else
Expand Down
6 changes: 3 additions & 3 deletions nano/node/json_handler.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1956,7 +1956,7 @@ void nano::json_handler::chain (bool successors)
entry.put ("", hash.to_string ());
blocks.push_back (std::make_pair ("", entry));
}
hash = successors ? node.store.block.successor (transaction, hash) : block_l->previous ();
hash = successors ? node.ledger.successor (transaction, hash).value_or (0) : block_l->previous ();
}
else
{
Expand Down Expand Up @@ -2665,7 +2665,7 @@ void nano::json_handler::account_history ()
--count;
}
}
hash = reverse ? node.store.block.successor (transaction, hash) : block->previous ();
hash = reverse ? node.ledger.successor (transaction, hash).value_or (0) : block->previous ();
block = node.ledger.block (transaction, hash);
}
response_l.add_child ("history", history);
Expand Down Expand Up @@ -3698,7 +3698,7 @@ void nano::json_handler::republish ()
}
}
}
hash = node.store.block.successor (transaction, hash);
hash = node.ledger.successor (transaction, hash).value_or (0);
}
node.network.flood_block_many (std::move (republish_bundle), nullptr, 25);
response_l.put ("success", ""); // obsolete
Expand Down
18 changes: 4 additions & 14 deletions nano/node/request_aggregator.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -246,24 +246,14 @@ std::pair<std::vector<std::shared_ptr<nano::block>>, std::vector<std::shared_ptr
if (block == nullptr && !root.is_zero ())
{
// Search for block root
auto successor (ledger.store.block.successor (transaction, root.as_block_hash ()));

// Search for account root
if (successor.is_zero ())
{
auto info = ledger.account_info (transaction, root.as_account ());
if (info)
{
successor = info->open_block;
}
}
if (!successor.is_zero ())
auto successor = ledger.successor (transaction, root.as_block_hash ());
if (successor)
{
auto successor_block = ledger.block (transaction, successor);
auto successor_block = ledger.block (transaction, successor.value ());
debug_assert (successor_block != nullptr);
block = std::move (successor_block);
// 5. Votes in cache for successor
auto find_successor_votes (local_votes.votes (root, successor));
auto find_successor_votes (local_votes.votes (root, successor.value ()));
if (!find_successor_votes.empty ())
{
cached_votes.insert (cached_votes.end (), find_successor_votes.begin (), find_successor_votes.end ());
Expand Down
2 changes: 1 addition & 1 deletion nano/node/scheduler/priority.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ bool nano::scheduler::priority::activate (nano::account const & account_a, store
if (conf_info.height < info->block_count)
{
debug_assert (conf_info.frontier != info->head);
auto hash = conf_info.height == 0 ? info->open_block : node.store.block.successor (transaction, conf_info.frontier);
auto hash = conf_info.height == 0 ? info->open_block : node.ledger.successor (transaction, conf_info.frontier).value_or (0);
auto block = node.ledger.block (transaction, hash);
debug_assert (block != nullptr);
if (node.ledger.dependents_confirmed (transaction, *block))
Expand Down
8 changes: 4 additions & 4 deletions nano/qt/qt.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -693,7 +693,7 @@ nano_qt::block_viewer::block_viewer (nano_qt::wallet & wallet_a) :
std::string contents;
block_l->serialize_json (contents);
block->setPlainText (contents.c_str ());
auto successor_l (this->wallet.node.store.block.successor (transaction, hash_l));
auto successor_l = this->wallet.node.ledger.successor (transaction, hash_l).value_or (0);
successor->setText (successor_l.to_string ().c_str ());
}
else
Expand Down Expand Up @@ -737,13 +737,13 @@ void nano_qt::block_viewer::rebroadcast_action (nano::block_hash const & hash_a)
if (block != nullptr)
{
wallet.node.network.flood_block (block);
auto successor (wallet.node.store.block.successor (transaction, hash_a));
if (!successor.is_zero ())
auto successor = wallet.node.ledger.successor (transaction, hash_a);
if (successor)
{
done = false;
wallet.node.workers.add_timed_task (std::chrono::steady_clock::now () + std::chrono::seconds (1), [this, successor] () {
this->wallet.application.postEvent (&this->wallet.processor, new eventloop_event ([this, successor] () {
rebroadcast_action (successor);
rebroadcast_action (successor.value ());
}));
});
}
Expand Down
40 changes: 18 additions & 22 deletions nano/secure/ledger.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1245,46 +1245,42 @@ void nano::ledger::update_account (store::write_transaction const & transaction_
}
}

std::shared_ptr<nano::block> nano::ledger::successor (store::transaction const & transaction_a, nano::qualified_root const & root_a)
std::optional<nano::block_hash> nano::ledger::successor (store::transaction const & transaction_a, nano::qualified_root const & root_a) const noexcept
{
nano::block_hash successor (0);
auto get_from_previous = false;
if (root_a.previous ().is_zero ())
if (!root_a.previous ().is_zero ())
{
return store.block.successor (transaction_a, root_a.previous ());
}
else
{
auto info = account_info (transaction_a, root_a.root ().as_account ());
if (info)
{
successor = info->open_block;
return info.value ().open_block;
}
else
{
get_from_previous = true;
return std::nullopt;
}
}
else
{
get_from_previous = true;
}
}

if (get_from_previous)
{
successor = store.block.successor (transaction_a, root_a.previous ());
}
std::shared_ptr<nano::block> result;
if (!successor.is_zero ())
{
result = block (transaction_a, successor);
}
debug_assert (successor.is_zero () || result != nullptr);
return result;
std::optional<nano::block_hash> nano::ledger::successor (store::transaction const & transaction, nano::block_hash const & hash) const noexcept
{
return successor (transaction, { hash, hash });
}

std::shared_ptr<nano::block> nano::ledger::forked_block (store::transaction const & transaction_a, nano::block const & block_a)
{
debug_assert (!block_exists (transaction_a, block_a.hash ()));
auto root (block_a.root ());
debug_assert (block_exists (transaction_a, root.as_block_hash ()) || store.account.exists (transaction_a, root.as_account ()));
auto result = block (transaction_a, store.block.successor (transaction_a, root.as_block_hash ()));
std::shared_ptr<nano::block> result;
auto successor_l = successor (transaction_a, root.as_block_hash ());
if (successor_l)
{
result = block (transaction_a, successor_l.value ());
}
if (result == nullptr)
{
auto info = account_info (transaction_a, root.as_account ());
Expand Down
3 changes: 2 additions & 1 deletion nano/secure/ledger.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -51,7 +51,8 @@ class ledger final
nano::uint128_t account_balance (store::transaction const &, nano::account const &, bool = false);
nano::uint128_t account_receivable (store::transaction const &, nano::account const &, bool = false);
nano::uint128_t weight (nano::account const &);
std::shared_ptr<nano::block> successor (store::transaction const &, nano::qualified_root const &);
std::optional<nano::block_hash> successor (store::transaction const &, nano::qualified_root const &) const noexcept;
std::optional<nano::block_hash> successor (store::transaction const & transaction, nano::block_hash const & hash) const noexcept;
std::shared_ptr<nano::block> forked_block (store::transaction const &, nano::block const &);
std::shared_ptr<nano::block> head_block (store::transaction const &, nano::account const &);
bool block_confirmed (store::transaction const &, nano::block_hash const &) const;
Expand Down
3 changes: 2 additions & 1 deletion nano/store/block.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
#include <nano/store/iterator.hpp>

#include <functional>
#include <optional>

namespace nano
{
Expand All @@ -28,7 +29,7 @@ class block
public:
virtual void put (store::write_transaction const &, nano::block_hash const &, nano::block const &) = 0;
virtual void raw_put (store::write_transaction const &, std::vector<uint8_t> const &, nano::block_hash const &) = 0;
virtual nano::block_hash successor (store::transaction const &, nano::block_hash const &) const = 0;
virtual std::optional<nano::block_hash> successor (store::transaction const &, nano::block_hash const &) const = 0;
virtual void successor_clear (store::write_transaction const &, nano::block_hash const &) = 0;
virtual std::shared_ptr<nano::block> get (store::transaction const &, nano::block_hash const &) const = 0;
virtual std::shared_ptr<nano::block> random (store::transaction const &) = 0;
Expand Down
6 changes: 5 additions & 1 deletion nano/store/lmdb/block.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ void nano::store::lmdb::block::raw_put (store::write_transaction const & transac
store.release_assert_success (status);
}

nano::block_hash nano::store::lmdb::block::successor (store::transaction const & transaction_a, nano::block_hash const & hash_a) const
std::optional<nano::block_hash> nano::store::lmdb::block::successor (store::transaction const & transaction_a, nano::block_hash const & hash_a) const
{
nano::store::lmdb::db_val value;
block_raw_get (transaction_a, hash_a, value);
Expand All @@ -67,6 +67,10 @@ nano::block_hash nano::store::lmdb::block::successor (store::transaction const &
{
result.clear ();
}
if (result.is_zero ())
{
return std::nullopt;
}
return result;
}

Expand Down
2 changes: 1 addition & 1 deletion nano/store/lmdb/block.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@ class block : public nano::store::block
explicit block (nano::store::lmdb::component & store_a);
void put (store::write_transaction const & transaction_a, nano::block_hash const & hash_a, nano::block const & block_a) override;
void raw_put (store::write_transaction const & transaction_a, std::vector<uint8_t> const & data, nano::block_hash const & hash_a) override;
nano::block_hash successor (store::transaction const & transaction_a, nano::block_hash const & hash_a) const override;
std::optional<nano::block_hash> successor (store::transaction const & transaction_a, nano::block_hash const & hash_a) const override;
void successor_clear (store::write_transaction const & transaction_a, nano::block_hash const & hash_a) override;
std::shared_ptr<nano::block> get (store::transaction const & transaction_a, nano::block_hash const & hash_a) const override;
std::shared_ptr<nano::block> random (store::transaction const & transaction_a) override;
Expand Down
6 changes: 5 additions & 1 deletion nano/store/rocksdb/block.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,7 @@ void nano::store::rocksdb::block::raw_put (store::write_transaction const & tran
store.release_assert_success (status);
}

nano::block_hash nano::store::rocksdb::block::successor (store::transaction const & transaction_a, nano::block_hash const & hash_a) const
std::optional<nano::block_hash> nano::store::rocksdb::block::successor (store::transaction const & transaction_a, nano::block_hash const & hash_a) const
{
nano::store::rocksdb::db_val value;
block_raw_get (transaction_a, hash_a, value);
Expand All @@ -67,6 +67,10 @@ nano::block_hash nano::store::rocksdb::block::successor (store::transaction cons
{
result.clear ();
}
if (result.is_zero ())
{
return std::nullopt;
}
return result;
}

Expand Down
2 changes: 1 addition & 1 deletion nano/store/rocksdb/block.hpp
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ class block : public nano::store::block
explicit block (nano::store::rocksdb::component & store_a);
void put (store::write_transaction const & transaction_a, nano::block_hash const & hash_a, nano::block const & block_a) override;
void raw_put (store::write_transaction const & transaction_a, std::vector<uint8_t> const & data, nano::block_hash const & hash_a) override;
nano::block_hash successor (store::transaction const & transaction_a, nano::block_hash const & hash_a) const override;
std::optional<nano::block_hash> successor (store::transaction const & transaction_a, nano::block_hash const & hash_a) const override;
void successor_clear (store::write_transaction const & transaction_a, nano::block_hash const & hash_a) override;
std::shared_ptr<nano::block> get (store::transaction const & transaction_a, nano::block_hash const & hash_a) const override;
std::shared_ptr<nano::block> random (store::transaction const & transaction_a) override;
Expand Down

0 comments on commit 2d08704

Please sign in to comment.