mirror of
https://github.com/monero-project/monero.git
synced 2025-01-27 17:36:59 -05:00
Merge pull request #8924
ffbf9f4 blockchain_and_pool: move to crytonote_core and enforce its usage (jeffro256) d6f86e5 Avoid nullptr dereference when constructing Blockchain and tx_memory_pool (lukas)
This commit is contained in:
commit
6fc67869a1
@ -37,10 +37,7 @@
|
|||||||
#include "common/command_line.h"
|
#include "common/command_line.h"
|
||||||
#include "common/varint.h"
|
#include "common/varint.h"
|
||||||
#include "cryptonote_basic/cryptonote_boost_serialization.h"
|
#include "cryptonote_basic/cryptonote_boost_serialization.h"
|
||||||
#include "cryptonote_core/tx_pool.h"
|
|
||||||
#include "cryptonote_core/cryptonote_core.h"
|
#include "cryptonote_core/cryptonote_core.h"
|
||||||
#include "cryptonote_core/blockchain.h"
|
|
||||||
#include "blockchain_db/blockchain_db.h"
|
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
|
|
||||||
#undef MONERO_DEFAULT_LOG_CATEGORY
|
#undef MONERO_DEFAULT_LOG_CATEGORY
|
||||||
@ -449,9 +446,7 @@ int main(int argc, char* argv[])
|
|||||||
// because unlike blockchain_storage constructor, which takes a pointer to
|
// because unlike blockchain_storage constructor, which takes a pointer to
|
||||||
// tx_memory_pool, Blockchain's constructor takes tx_memory_pool object.
|
// tx_memory_pool, Blockchain's constructor takes tx_memory_pool object.
|
||||||
LOG_PRINT_L0("Initializing source blockchain (BlockchainDB)");
|
LOG_PRINT_L0("Initializing source blockchain (BlockchainDB)");
|
||||||
std::unique_ptr<Blockchain> core_storage;
|
std::unique_ptr<BlockchainAndPool> core_storage = std::make_unique<BlockchainAndPool>();
|
||||||
tx_memory_pool m_mempool(*core_storage);
|
|
||||||
core_storage.reset(new Blockchain(m_mempool));
|
|
||||||
BlockchainDB *db = new_db();
|
BlockchainDB *db = new_db();
|
||||||
if (db == NULL)
|
if (db == NULL)
|
||||||
{
|
{
|
||||||
@ -472,7 +467,7 @@ int main(int argc, char* argv[])
|
|||||||
LOG_PRINT_L0("Error opening database: " << e.what());
|
LOG_PRINT_L0("Error opening database: " << e.what());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
r = core_storage->init(db, net_type);
|
r = core_storage->blockchain.init(db, net_type);
|
||||||
|
|
||||||
CHECK_AND_ASSERT_MES(r, 1, "Failed to initialize source blockchain storage");
|
CHECK_AND_ASSERT_MES(r, 1, "Failed to initialize source blockchain storage");
|
||||||
LOG_PRINT_L0("Source blockchain storage initialized OK");
|
LOG_PRINT_L0("Source blockchain storage initialized OK");
|
||||||
@ -716,7 +711,7 @@ int main(int argc, char* argv[])
|
|||||||
}
|
}
|
||||||
|
|
||||||
done:
|
done:
|
||||||
core_storage->deinit();
|
core_storage->blockchain.deinit();
|
||||||
|
|
||||||
if (opt_show_cache_stats)
|
if (opt_show_cache_stats)
|
||||||
MINFO("cache: txes " << std::to_string(cached_txes*100./total_txes)
|
MINFO("cache: txes " << std::to_string(cached_txes*100./total_txes)
|
||||||
|
@ -31,10 +31,7 @@
|
|||||||
#include <boost/algorithm/string.hpp>
|
#include <boost/algorithm/string.hpp>
|
||||||
#include "common/command_line.h"
|
#include "common/command_line.h"
|
||||||
#include "common/varint.h"
|
#include "common/varint.h"
|
||||||
#include "cryptonote_core/tx_pool.h"
|
|
||||||
#include "cryptonote_core/cryptonote_core.h"
|
#include "cryptonote_core/cryptonote_core.h"
|
||||||
#include "cryptonote_core/blockchain.h"
|
|
||||||
#include "blockchain_db/blockchain_db.h"
|
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
|
|
||||||
#undef MONERO_DEFAULT_LOG_CATEGORY
|
#undef MONERO_DEFAULT_LOG_CATEGORY
|
||||||
@ -129,16 +126,8 @@ int main(int argc, char* argv[])
|
|||||||
// Use Blockchain instead of lower-level BlockchainDB for two reasons:
|
// Use Blockchain instead of lower-level BlockchainDB for two reasons:
|
||||||
// 1. Blockchain has the init() method for easy setup
|
// 1. Blockchain has the init() method for easy setup
|
||||||
// 2. exporter needs to use get_current_blockchain_height(), get_block_id_by_height(), get_block_by_hash()
|
// 2. exporter needs to use get_current_blockchain_height(), get_block_id_by_height(), get_block_by_hash()
|
||||||
//
|
|
||||||
// cannot match blockchain_storage setup above with just one line,
|
|
||||||
// e.g.
|
|
||||||
// Blockchain* core_storage = new Blockchain(NULL);
|
|
||||||
// because unlike blockchain_storage constructor, which takes a pointer to
|
|
||||||
// tx_memory_pool, Blockchain's constructor takes tx_memory_pool object.
|
|
||||||
LOG_PRINT_L0("Initializing source blockchain (BlockchainDB)");
|
LOG_PRINT_L0("Initializing source blockchain (BlockchainDB)");
|
||||||
std::unique_ptr<Blockchain> core_storage;
|
std::unique_ptr<BlockchainAndPool> core_storage = std::make_unique<BlockchainAndPool>();
|
||||||
tx_memory_pool m_mempool(*core_storage);
|
|
||||||
core_storage.reset(new Blockchain(m_mempool));
|
|
||||||
BlockchainDB *db = new_db();
|
BlockchainDB *db = new_db();
|
||||||
if (db == NULL)
|
if (db == NULL)
|
||||||
{
|
{
|
||||||
@ -159,7 +148,7 @@ int main(int argc, char* argv[])
|
|||||||
LOG_PRINT_L0("Error opening database: " << e.what());
|
LOG_PRINT_L0("Error opening database: " << e.what());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
r = core_storage->init(db, net_type);
|
r = core_storage->blockchain.init(db, net_type);
|
||||||
|
|
||||||
CHECK_AND_ASSERT_MES(r, 1, "Failed to initialize source blockchain storage");
|
CHECK_AND_ASSERT_MES(r, 1, "Failed to initialize source blockchain storage");
|
||||||
LOG_PRINT_L0("Source blockchain storage initialized OK");
|
LOG_PRINT_L0("Source blockchain storage initialized OK");
|
||||||
@ -327,7 +316,7 @@ done:
|
|||||||
LOG_PRINT_L0("Average min depth for " << start_txids.size() << " transaction(s): " << cumulative_depth/(float)depths.size());
|
LOG_PRINT_L0("Average min depth for " << start_txids.size() << " transaction(s): " << cumulative_depth/(float)depths.size());
|
||||||
LOG_PRINT_L0("Median min depth for " << start_txids.size() << " transaction(s): " << epee::misc_utils::median(depths));
|
LOG_PRINT_L0("Median min depth for " << start_txids.size() << " transaction(s): " << epee::misc_utils::median(depths));
|
||||||
|
|
||||||
core_storage->deinit();
|
core_storage->blockchain.deinit();
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
CATCH_ENTRY("Depth query error", 1);
|
CATCH_ENTRY("Depth query error", 1);
|
||||||
|
@ -29,7 +29,6 @@
|
|||||||
#include "bootstrap_file.h"
|
#include "bootstrap_file.h"
|
||||||
#include "blocksdat_file.h"
|
#include "blocksdat_file.h"
|
||||||
#include "common/command_line.h"
|
#include "common/command_line.h"
|
||||||
#include "cryptonote_core/tx_pool.h"
|
|
||||||
#include "cryptonote_core/cryptonote_core.h"
|
#include "cryptonote_core/cryptonote_core.h"
|
||||||
#include "blockchain_db/blockchain_db.h"
|
#include "blockchain_db/blockchain_db.h"
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
@ -129,16 +128,8 @@ int main(int argc, char* argv[])
|
|||||||
// Use Blockchain instead of lower-level BlockchainDB for two reasons:
|
// Use Blockchain instead of lower-level BlockchainDB for two reasons:
|
||||||
// 1. Blockchain has the init() method for easy setup
|
// 1. Blockchain has the init() method for easy setup
|
||||||
// 2. exporter needs to use get_current_blockchain_height(), get_block_id_by_height(), get_block_by_hash()
|
// 2. exporter needs to use get_current_blockchain_height(), get_block_id_by_height(), get_block_by_hash()
|
||||||
//
|
|
||||||
// cannot match blockchain_storage setup above with just one line,
|
|
||||||
// e.g.
|
|
||||||
// Blockchain* core_storage = new Blockchain(NULL);
|
|
||||||
// because unlike blockchain_storage constructor, which takes a pointer to
|
|
||||||
// tx_memory_pool, Blockchain's constructor takes tx_memory_pool object.
|
|
||||||
LOG_PRINT_L0("Initializing source blockchain (BlockchainDB)");
|
LOG_PRINT_L0("Initializing source blockchain (BlockchainDB)");
|
||||||
Blockchain* core_storage = NULL;
|
std::unique_ptr<BlockchainAndPool> core_storage = std::make_unique<BlockchainAndPool>();
|
||||||
tx_memory_pool m_mempool(*core_storage);
|
|
||||||
core_storage = new Blockchain(m_mempool);
|
|
||||||
|
|
||||||
BlockchainDB* db = new_db();
|
BlockchainDB* db = new_db();
|
||||||
if (db == NULL)
|
if (db == NULL)
|
||||||
@ -162,9 +153,9 @@ int main(int argc, char* argv[])
|
|||||||
LOG_PRINT_L0("Error opening database: " << e.what());
|
LOG_PRINT_L0("Error opening database: " << e.what());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
r = core_storage->init(db, opt_testnet ? cryptonote::TESTNET : opt_stagenet ? cryptonote::STAGENET : cryptonote::MAINNET);
|
r = core_storage->blockchain.init(db, opt_testnet ? cryptonote::TESTNET : opt_stagenet ? cryptonote::STAGENET : cryptonote::MAINNET);
|
||||||
|
|
||||||
if (core_storage->get_blockchain_pruning_seed() && !opt_blocks_dat)
|
if (core_storage->blockchain.get_blockchain_pruning_seed() && !opt_blocks_dat)
|
||||||
{
|
{
|
||||||
LOG_PRINT_L0("Blockchain is pruned, cannot export");
|
LOG_PRINT_L0("Blockchain is pruned, cannot export");
|
||||||
return 1;
|
return 1;
|
||||||
@ -177,12 +168,12 @@ int main(int argc, char* argv[])
|
|||||||
if (opt_blocks_dat)
|
if (opt_blocks_dat)
|
||||||
{
|
{
|
||||||
BlocksdatFile blocksdat;
|
BlocksdatFile blocksdat;
|
||||||
r = blocksdat.store_blockchain_raw(core_storage, NULL, output_file_path, block_stop);
|
r = blocksdat.store_blockchain_raw(&core_storage->blockchain, NULL, output_file_path, block_stop);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
BootstrapFile bootstrap;
|
BootstrapFile bootstrap;
|
||||||
r = bootstrap.store_blockchain_raw(core_storage, NULL, output_file_path, block_start, block_stop);
|
r = bootstrap.store_blockchain_raw(&core_storage->blockchain, NULL, output_file_path, block_start, block_stop);
|
||||||
}
|
}
|
||||||
CHECK_AND_ASSERT_MES(r, 1, "Failed to export blockchain raw data");
|
CHECK_AND_ASSERT_MES(r, 1, "Failed to export blockchain raw data");
|
||||||
LOG_PRINT_L0("Blockchain raw data exported OK");
|
LOG_PRINT_L0("Blockchain raw data exported OK");
|
||||||
|
@ -35,8 +35,6 @@
|
|||||||
#include "common/command_line.h"
|
#include "common/command_line.h"
|
||||||
#include "common/pruning.h"
|
#include "common/pruning.h"
|
||||||
#include "cryptonote_core/cryptonote_core.h"
|
#include "cryptonote_core/cryptonote_core.h"
|
||||||
#include "cryptonote_core/blockchain.h"
|
|
||||||
#include "blockchain_db/blockchain_db.h"
|
|
||||||
#include "blockchain_db/lmdb/db_lmdb.h"
|
#include "blockchain_db/lmdb/db_lmdb.h"
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
|
|
||||||
@ -562,22 +560,15 @@ int main(int argc, char* argv[])
|
|||||||
// Use Blockchain instead of lower-level BlockchainDB for two reasons:
|
// Use Blockchain instead of lower-level BlockchainDB for two reasons:
|
||||||
// 1. Blockchain has the init() method for easy setup
|
// 1. Blockchain has the init() method for easy setup
|
||||||
// 2. exporter needs to use get_current_blockchain_height(), get_block_id_by_height(), get_block_by_hash()
|
// 2. exporter needs to use get_current_blockchain_height(), get_block_id_by_height(), get_block_by_hash()
|
||||||
//
|
|
||||||
// cannot match blockchain_storage setup above with just one line,
|
|
||||||
// e.g.
|
|
||||||
// Blockchain* core_storage = new Blockchain(NULL);
|
|
||||||
// because unlike blockchain_storage constructor, which takes a pointer to
|
|
||||||
// tx_memory_pool, Blockchain's constructor takes tx_memory_pool object.
|
|
||||||
MINFO("Initializing source blockchain (BlockchainDB)");
|
MINFO("Initializing source blockchain (BlockchainDB)");
|
||||||
std::array<std::unique_ptr<Blockchain>, 2> core_storage;
|
std::array<std::unique_ptr<BlockchainAndPool>, 2> core_storage{
|
||||||
Blockchain *blockchain = NULL;
|
std::make_unique<BlockchainAndPool>(),
|
||||||
tx_memory_pool m_mempool(*blockchain);
|
std::make_unique<BlockchainAndPool>()};
|
||||||
|
|
||||||
boost::filesystem::path paths[2];
|
boost::filesystem::path paths[2];
|
||||||
bool already_pruned = false;
|
bool already_pruned = false;
|
||||||
for (size_t n = 0; n < core_storage.size(); ++n)
|
for (size_t n = 0; n < core_storage.size(); ++n)
|
||||||
{
|
{
|
||||||
core_storage[n].reset(new Blockchain(m_mempool));
|
|
||||||
|
|
||||||
BlockchainDB* db = new_db();
|
BlockchainDB* db = new_db();
|
||||||
if (db == NULL)
|
if (db == NULL)
|
||||||
{
|
{
|
||||||
@ -622,12 +613,12 @@ int main(int argc, char* argv[])
|
|||||||
MERROR("Error opening database: " << e.what());
|
MERROR("Error opening database: " << e.what());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
r = core_storage[n]->init(db, net_type);
|
r = core_storage[n]->blockchain.init(db, net_type);
|
||||||
|
|
||||||
std::string source_dest = n == 0 ? "source" : "pruned";
|
std::string source_dest = n == 0 ? "source" : "pruned";
|
||||||
CHECK_AND_ASSERT_MES(r, 1, "Failed to initialize " << source_dest << " blockchain storage");
|
CHECK_AND_ASSERT_MES(r, 1, "Failed to initialize " << source_dest << " blockchain storage");
|
||||||
MINFO(source_dest << " blockchain storage initialized OK");
|
MINFO(source_dest << " blockchain storage initialized OK");
|
||||||
if (n == 0 && core_storage[0]->get_blockchain_pruning_seed())
|
if (n == 0 && core_storage[0]->blockchain.get_blockchain_pruning_seed())
|
||||||
{
|
{
|
||||||
if (!opt_copy_pruned_database)
|
if (!opt_copy_pruned_database)
|
||||||
{
|
{
|
||||||
@ -637,9 +628,9 @@ int main(int argc, char* argv[])
|
|||||||
already_pruned = true;
|
already_pruned = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
core_storage[0]->deinit();
|
core_storage[0]->blockchain.deinit();
|
||||||
core_storage[0].reset(NULL);
|
core_storage[0].reset(NULL);
|
||||||
core_storage[1]->deinit();
|
core_storage[1]->blockchain.deinit();
|
||||||
core_storage[1].reset(NULL);
|
core_storage[1].reset(NULL);
|
||||||
|
|
||||||
MINFO("Pruning...");
|
MINFO("Pruning...");
|
||||||
|
@ -30,10 +30,7 @@
|
|||||||
#include <boost/filesystem.hpp>
|
#include <boost/filesystem.hpp>
|
||||||
#include "common/command_line.h"
|
#include "common/command_line.h"
|
||||||
#include "serialization/crypto.h"
|
#include "serialization/crypto.h"
|
||||||
#include "cryptonote_core/tx_pool.h"
|
|
||||||
#include "cryptonote_core/cryptonote_core.h"
|
#include "cryptonote_core/cryptonote_core.h"
|
||||||
#include "cryptonote_core/blockchain.h"
|
|
||||||
#include "blockchain_db/blockchain_db.h"
|
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
|
|
||||||
#undef MONERO_DEFAULT_LOG_CATEGORY
|
#undef MONERO_DEFAULT_LOG_CATEGORY
|
||||||
@ -160,9 +157,8 @@ int main(int argc, char* argv[])
|
|||||||
const std::string input = command_line::get_arg(vm, arg_input);
|
const std::string input = command_line::get_arg(vm, arg_input);
|
||||||
|
|
||||||
LOG_PRINT_L0("Initializing source blockchain (BlockchainDB)");
|
LOG_PRINT_L0("Initializing source blockchain (BlockchainDB)");
|
||||||
std::unique_ptr<Blockchain> core_storage;
|
std::unique_ptr<BlockchainAndPool> core_storage = std::make_unique<BlockchainAndPool>();
|
||||||
tx_memory_pool m_mempool(*core_storage);
|
|
||||||
core_storage.reset(new Blockchain(m_mempool));
|
|
||||||
BlockchainDB *db = new_db();
|
BlockchainDB *db = new_db();
|
||||||
if (db == NULL)
|
if (db == NULL)
|
||||||
{
|
{
|
||||||
@ -182,7 +178,7 @@ int main(int argc, char* argv[])
|
|||||||
LOG_PRINT_L0("Error opening database: " << e.what());
|
LOG_PRINT_L0("Error opening database: " << e.what());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
r = core_storage->init(db, net_type);
|
r = core_storage->blockchain.init(db, net_type);
|
||||||
|
|
||||||
CHECK_AND_ASSERT_MES(r, 1, "Failed to initialize source blockchain storage");
|
CHECK_AND_ASSERT_MES(r, 1, "Failed to initialize source blockchain storage");
|
||||||
LOG_PRINT_L0("Source blockchain storage initialized OK");
|
LOG_PRINT_L0("Source blockchain storage initialized OK");
|
||||||
@ -280,7 +276,7 @@ int main(int argc, char* argv[])
|
|||||||
MINFO("Prunable outputs: " << num_prunable_outputs);
|
MINFO("Prunable outputs: " << num_prunable_outputs);
|
||||||
|
|
||||||
LOG_PRINT_L0("Blockchain known spent data pruned OK");
|
LOG_PRINT_L0("Blockchain known spent data pruned OK");
|
||||||
core_storage->deinit();
|
core_storage->blockchain.deinit();
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
CATCH_ENTRY("Error", 1);
|
CATCH_ENTRY("Error", 1);
|
||||||
|
@ -31,9 +31,7 @@
|
|||||||
#include "common/command_line.h"
|
#include "common/command_line.h"
|
||||||
#include "common/varint.h"
|
#include "common/varint.h"
|
||||||
#include "cryptonote_basic/cryptonote_boost_serialization.h"
|
#include "cryptonote_basic/cryptonote_boost_serialization.h"
|
||||||
#include "cryptonote_core/tx_pool.h"
|
|
||||||
#include "cryptonote_core/cryptonote_core.h"
|
#include "cryptonote_core/cryptonote_core.h"
|
||||||
#include "cryptonote_core/blockchain.h"
|
|
||||||
#include "blockchain_db/blockchain_db.h"
|
#include "blockchain_db/blockchain_db.h"
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
|
|
||||||
@ -203,9 +201,8 @@ int main(int argc, char* argv[])
|
|||||||
do_diff = command_line::get_arg(vm, arg_diff);
|
do_diff = command_line::get_arg(vm, arg_diff);
|
||||||
|
|
||||||
LOG_PRINT_L0("Initializing source blockchain (BlockchainDB)");
|
LOG_PRINT_L0("Initializing source blockchain (BlockchainDB)");
|
||||||
std::unique_ptr<Blockchain> core_storage;
|
std::unique_ptr<BlockchainAndPool> core_storage = std::make_unique<BlockchainAndPool>();
|
||||||
tx_memory_pool m_mempool(*core_storage);
|
|
||||||
core_storage.reset(new Blockchain(m_mempool));
|
|
||||||
BlockchainDB *db = new_db();
|
BlockchainDB *db = new_db();
|
||||||
if (db == NULL)
|
if (db == NULL)
|
||||||
{
|
{
|
||||||
@ -225,7 +222,7 @@ int main(int argc, char* argv[])
|
|||||||
LOG_PRINT_L0("Error opening database: " << e.what());
|
LOG_PRINT_L0("Error opening database: " << e.what());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
r = core_storage->init(db, net_type);
|
r = core_storage->blockchain.init(db, net_type);
|
||||||
|
|
||||||
CHECK_AND_ASSERT_MES(r, 1, "Failed to initialize source blockchain storage");
|
CHECK_AND_ASSERT_MES(r, 1, "Failed to initialize source blockchain storage");
|
||||||
LOG_PRINT_L0("Source blockchain storage initialized OK");
|
LOG_PRINT_L0("Source blockchain storage initialized OK");
|
||||||
@ -381,7 +378,7 @@ plot 'stats.csv' index "DATA" using (timecolumn(1,"%Y-%m-%d")):4 with lines, ''
|
|||||||
if (currblks)
|
if (currblks)
|
||||||
doprint();
|
doprint();
|
||||||
|
|
||||||
core_storage->deinit();
|
core_storage->blockchain.deinit();
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
CATCH_ENTRY("Stats reporting error", 1);
|
CATCH_ENTRY("Stats reporting error", 1);
|
||||||
|
@ -31,10 +31,7 @@
|
|||||||
#include <boost/filesystem/path.hpp>
|
#include <boost/filesystem/path.hpp>
|
||||||
#include "common/command_line.h"
|
#include "common/command_line.h"
|
||||||
#include "common/varint.h"
|
#include "common/varint.h"
|
||||||
#include "cryptonote_core/tx_pool.h"
|
|
||||||
#include "cryptonote_core/cryptonote_core.h"
|
#include "cryptonote_core/cryptonote_core.h"
|
||||||
#include "cryptonote_core/blockchain.h"
|
|
||||||
#include "blockchain_db/blockchain_db.h"
|
|
||||||
#include "version.h"
|
#include "version.h"
|
||||||
|
|
||||||
#undef MONERO_DEFAULT_LOG_CATEGORY
|
#undef MONERO_DEFAULT_LOG_CATEGORY
|
||||||
@ -151,9 +148,8 @@ int main(int argc, char* argv[])
|
|||||||
// tx_memory_pool, Blockchain's constructor takes tx_memory_pool object.
|
// tx_memory_pool, Blockchain's constructor takes tx_memory_pool object.
|
||||||
LOG_PRINT_L0("Initializing source blockchain (BlockchainDB)");
|
LOG_PRINT_L0("Initializing source blockchain (BlockchainDB)");
|
||||||
const std::string input = command_line::get_arg(vm, arg_input);
|
const std::string input = command_line::get_arg(vm, arg_input);
|
||||||
std::unique_ptr<Blockchain> core_storage;
|
std::unique_ptr<BlockchainAndPool> core_storage = std::make_unique<BlockchainAndPool>();
|
||||||
tx_memory_pool m_mempool(*core_storage);
|
|
||||||
core_storage.reset(new Blockchain(m_mempool));
|
|
||||||
BlockchainDB* db = new_db();
|
BlockchainDB* db = new_db();
|
||||||
if (db == NULL)
|
if (db == NULL)
|
||||||
{
|
{
|
||||||
@ -174,7 +170,7 @@ int main(int argc, char* argv[])
|
|||||||
LOG_PRINT_L0("Error opening database: " << e.what());
|
LOG_PRINT_L0("Error opening database: " << e.what());
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
r = core_storage->init(db, net_type);
|
r = core_storage->blockchain.init(db, net_type);
|
||||||
|
|
||||||
CHECK_AND_ASSERT_MES(r, 1, "Failed to initialize source blockchain storage");
|
CHECK_AND_ASSERT_MES(r, 1, "Failed to initialize source blockchain storage");
|
||||||
LOG_PRINT_L0("Source blockchain storage initialized OK");
|
LOG_PRINT_L0("Source blockchain storage initialized OK");
|
||||||
@ -185,10 +181,10 @@ int main(int argc, char* argv[])
|
|||||||
std::unordered_map<uint64_t,uint64_t> indices;
|
std::unordered_map<uint64_t,uint64_t> indices;
|
||||||
|
|
||||||
LOG_PRINT_L0("Reading blockchain from " << input);
|
LOG_PRINT_L0("Reading blockchain from " << input);
|
||||||
core_storage->for_all_transactions([&](const crypto::hash &hash, const cryptonote::transaction &tx)->bool
|
core_storage->blockchain.for_all_transactions([&](const crypto::hash &hash, const cryptonote::transaction &tx)->bool
|
||||||
{
|
{
|
||||||
const bool coinbase = tx.vin.size() == 1 && tx.vin[0].type() == typeid(txin_gen);
|
const bool coinbase = tx.vin.size() == 1 && tx.vin[0].type() == typeid(txin_gen);
|
||||||
const uint64_t height = core_storage->get_db().get_tx_block_height(hash);
|
const uint64_t height = core_storage->blockchain.get_db().get_tx_block_height(hash);
|
||||||
|
|
||||||
// create new outputs
|
// create new outputs
|
||||||
for (const auto &out: tx.vout)
|
for (const auto &out: tx.vout)
|
||||||
|
@ -112,13 +112,6 @@ namespace cryptonote
|
|||||||
uint64_t already_generated_coins; //!< the total coins minted after that block
|
uint64_t already_generated_coins; //!< the total coins minted after that block
|
||||||
};
|
};
|
||||||
|
|
||||||
/**
|
|
||||||
* @brief Blockchain constructor
|
|
||||||
*
|
|
||||||
* @param tx_pool a reference to the transaction pool to be kept by the Blockchain
|
|
||||||
*/
|
|
||||||
Blockchain(tx_memory_pool& tx_pool);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief Blockchain destructor
|
* @brief Blockchain destructor
|
||||||
*/
|
*/
|
||||||
@ -1235,6 +1228,13 @@ namespace cryptonote
|
|||||||
// cache for verifying transaction RCT non semantics
|
// cache for verifying transaction RCT non semantics
|
||||||
mutable rct_ver_cache_t m_rct_ver_cache;
|
mutable rct_ver_cache_t m_rct_ver_cache;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Blockchain constructor
|
||||||
|
*
|
||||||
|
* @param tx_pool a reference to the transaction pool to be kept by the Blockchain
|
||||||
|
*/
|
||||||
|
Blockchain(tx_memory_pool& tx_pool);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief collects the keys for all outputs being "spent" as an input
|
* @brief collects the keys for all outputs being "spent" as an input
|
||||||
*
|
*
|
||||||
@ -1608,5 +1608,7 @@ namespace cryptonote
|
|||||||
* @param already_generated_coins total coins mined by the network so far
|
* @param already_generated_coins total coins mined by the network so far
|
||||||
*/
|
*/
|
||||||
void send_miner_notifications(uint64_t height, const crypto::hash &seed_hash, const crypto::hash &prev_id, uint64_t already_generated_coins);
|
void send_miner_notifications(uint64_t height, const crypto::hash &seed_hash, const crypto::hash &prev_id, uint64_t already_generated_coins);
|
||||||
|
|
||||||
|
friend class BlockchainAndPool;
|
||||||
};
|
};
|
||||||
} // namespace cryptonote
|
} // namespace cryptonote
|
||||||
|
58
src/cryptonote_core/blockchain_and_pool.h
Normal file
58
src/cryptonote_core/blockchain_and_pool.h
Normal file
@ -0,0 +1,58 @@
|
|||||||
|
// Copyright (c) 2023, The Monero Project
|
||||||
|
//
|
||||||
|
// All rights reserved.
|
||||||
|
//
|
||||||
|
// Redistribution and use in source and binary forms, with or without
|
||||||
|
// modification, are permitted provided that the following conditions are met:
|
||||||
|
//
|
||||||
|
// 1. Redistributions of source code must retain the above copyright notice,
|
||||||
|
// this list of
|
||||||
|
// conditions and the following disclaimer.
|
||||||
|
//
|
||||||
|
// 2. Redistributions in binary form must reproduce the above copyright notice,
|
||||||
|
// this list
|
||||||
|
// of conditions and the following disclaimer in the documentation and/or
|
||||||
|
// other materials provided with the distribution.
|
||||||
|
//
|
||||||
|
// 3. Neither the name of the copyright holder nor the names of its contributors
|
||||||
|
// may be
|
||||||
|
// used to endorse or promote products derived from this software without
|
||||||
|
// specific prior written permission.
|
||||||
|
//
|
||||||
|
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
|
||||||
|
// AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
|
||||||
|
// IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
|
||||||
|
// ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
|
||||||
|
// LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
|
||||||
|
// CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
|
||||||
|
// SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
|
||||||
|
// INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
|
||||||
|
// CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
|
||||||
|
// ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
||||||
|
// POSSIBILITY OF SUCH DAMAGE.
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
#include <memory>
|
||||||
|
|
||||||
|
#include "blockchain.h"
|
||||||
|
#include "tx_pool.h"
|
||||||
|
|
||||||
|
namespace cryptonote
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* @brief Container for safely constructing Blockchain and tx_memory_pool classes
|
||||||
|
*
|
||||||
|
* The reason for this class existing is that the constructors for both Blockchain and
|
||||||
|
* tx_memory_pool take a reference for tx_memory_pool and Blockchain, respectively. Because of this
|
||||||
|
* circular reference, it is annoying/unsafe to construct these normally. This class guarantees that
|
||||||
|
* we don't make any silly mistakes with pointers / dangling references.
|
||||||
|
*/
|
||||||
|
struct BlockchainAndPool
|
||||||
|
{
|
||||||
|
Blockchain blockchain;
|
||||||
|
tx_memory_pool tx_pool;
|
||||||
|
|
||||||
|
BlockchainAndPool(): blockchain(tx_pool), tx_pool(blockchain) {}
|
||||||
|
};
|
||||||
|
}
|
@ -221,8 +221,9 @@ namespace cryptonote
|
|||||||
|
|
||||||
//-----------------------------------------------------------------------------------------------
|
//-----------------------------------------------------------------------------------------------
|
||||||
core::core(i_cryptonote_protocol* pprotocol):
|
core::core(i_cryptonote_protocol* pprotocol):
|
||||||
m_mempool(m_blockchain_storage),
|
m_bap(),
|
||||||
m_blockchain_storage(m_mempool),
|
m_mempool(m_bap.tx_pool),
|
||||||
|
m_blockchain_storage(m_bap.blockchain),
|
||||||
m_miner(this, [this](const cryptonote::block &b, uint64_t height, const crypto::hash *seed_hash, unsigned int threads, crypto::hash &hash) {
|
m_miner(this, [this](const cryptonote::block &b, uint64_t height, const crypto::hash *seed_hash, unsigned int threads, crypto::hash &hash) {
|
||||||
return cryptonote::get_block_longhash(&m_blockchain_storage, b, hash, height, seed_hash, threads);
|
return cryptonote::get_block_longhash(&m_blockchain_storage, b, hash, height, seed_hash, threads);
|
||||||
}),
|
}),
|
||||||
|
@ -42,8 +42,7 @@
|
|||||||
#include "cryptonote_protocol/enums.h"
|
#include "cryptonote_protocol/enums.h"
|
||||||
#include "common/download.h"
|
#include "common/download.h"
|
||||||
#include "common/command_line.h"
|
#include "common/command_line.h"
|
||||||
#include "tx_pool.h"
|
#include "blockchain_and_pool.h"
|
||||||
#include "blockchain.h"
|
|
||||||
#include "cryptonote_basic/miner.h"
|
#include "cryptonote_basic/miner.h"
|
||||||
#include "cryptonote_basic/connection_context.h"
|
#include "cryptonote_basic/connection_context.h"
|
||||||
#include "warnings.h"
|
#include "warnings.h"
|
||||||
@ -1098,8 +1097,9 @@ namespace cryptonote
|
|||||||
|
|
||||||
uint64_t m_test_drop_download_height = 0; //!< height under which to drop incoming blocks, if doing so
|
uint64_t m_test_drop_download_height = 0; //!< height under which to drop incoming blocks, if doing so
|
||||||
|
|
||||||
tx_memory_pool m_mempool; //!< transaction pool instance
|
BlockchainAndPool m_bap; //! Contains owned instances of Blockchain and tx_memory_pool
|
||||||
Blockchain m_blockchain_storage; //!< Blockchain instance
|
tx_memory_pool& m_mempool; //!< ref to transaction pool instance in m_bap
|
||||||
|
Blockchain& m_blockchain_storage; //!< ref to Blockchain instance in m_bap
|
||||||
|
|
||||||
i_cryptonote_protocol* m_pprotocol; //!< cryptonote protocol instance
|
i_cryptonote_protocol* m_pprotocol; //!< cryptonote protocol instance
|
||||||
|
|
||||||
|
@ -97,14 +97,6 @@ namespace cryptonote
|
|||||||
class tx_memory_pool: boost::noncopyable
|
class tx_memory_pool: boost::noncopyable
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/**
|
|
||||||
* @brief Constructor
|
|
||||||
*
|
|
||||||
* @param bchs a Blockchain class instance, for getting chain info
|
|
||||||
*/
|
|
||||||
tx_memory_pool(Blockchain& bchs);
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @copydoc add_tx(transaction&, tx_verification_context&, bool, bool, uint8_t)
|
* @copydoc add_tx(transaction&, tx_verification_context&, bool, bool, uint8_t)
|
||||||
*
|
*
|
||||||
@ -488,6 +480,13 @@ namespace cryptonote
|
|||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @brief Constructor
|
||||||
|
*
|
||||||
|
* @param bchs a Blockchain class instance, for getting chain info
|
||||||
|
*/
|
||||||
|
tx_memory_pool(Blockchain& bchs);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @brief insert key images into m_spent_key_images
|
* @brief insert key images into m_spent_key_images
|
||||||
*
|
*
|
||||||
@ -676,6 +675,8 @@ private:
|
|||||||
|
|
||||||
//! Next timestamp that a DB check for relayable txes is allowed
|
//! Next timestamp that a DB check for relayable txes is allowed
|
||||||
std::atomic<time_t> m_next_check;
|
std::atomic<time_t> m_next_check;
|
||||||
|
|
||||||
|
friend class BlockchainAndPool;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -30,8 +30,6 @@
|
|||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <math.h>
|
#include <math.h>
|
||||||
#include "cryptonote_core/blockchain.h"
|
|
||||||
#include "cryptonote_core/tx_pool.h"
|
|
||||||
#include "cryptonote_core/cryptonote_core.h"
|
#include "cryptonote_core/cryptonote_core.h"
|
||||||
#include "blockchain_db/testdb.h"
|
#include "blockchain_db/testdb.h"
|
||||||
|
|
||||||
@ -110,9 +108,6 @@ private:
|
|||||||
}
|
}
|
||||||
|
|
||||||
#define PREFIX_WINDOW(hf_version,window) \
|
#define PREFIX_WINDOW(hf_version,window) \
|
||||||
std::unique_ptr<cryptonote::Blockchain> bc; \
|
|
||||||
cryptonote::tx_memory_pool txpool(*bc); \
|
|
||||||
bc.reset(new cryptonote::Blockchain(txpool)); \
|
|
||||||
struct get_test_options { \
|
struct get_test_options { \
|
||||||
const std::pair<uint8_t, uint64_t> hard_forks[3]; \
|
const std::pair<uint8_t, uint64_t> hard_forks[3]; \
|
||||||
const cryptonote::test_options test_options = { \
|
const cryptonote::test_options test_options = { \
|
||||||
@ -121,7 +116,9 @@ private:
|
|||||||
}; \
|
}; \
|
||||||
get_test_options(): hard_forks{std::make_pair(1, (uint64_t)0), std::make_pair((uint8_t)hf_version, (uint64_t)LONG_TERM_BLOCK_WEIGHT_WINDOW), std::make_pair((uint8_t)0, (uint64_t)0)} {} \
|
get_test_options(): hard_forks{std::make_pair(1, (uint64_t)0), std::make_pair((uint8_t)hf_version, (uint64_t)LONG_TERM_BLOCK_WEIGHT_WINDOW), std::make_pair((uint8_t)0, (uint64_t)0)} {} \
|
||||||
} opts; \
|
} opts; \
|
||||||
cryptonote::Blockchain *blockchain = bc.get(); \
|
cryptonote::BlockchainAndPool bap; \
|
||||||
|
cryptonote::Blockchain *blockchain = &bap.blockchain; \
|
||||||
|
cryptonote::Blockchain *bc = blockchain; \
|
||||||
bool r = blockchain->init(new TestDB(), cryptonote::FAKECHAIN, true, &opts.test_options, 0, NULL); \
|
bool r = blockchain->init(new TestDB(), cryptonote::FAKECHAIN, true, &opts.test_options, 0, NULL); \
|
||||||
if (!r) \
|
if (!r) \
|
||||||
{ \
|
{ \
|
||||||
|
@ -143,9 +143,8 @@ namespace
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static std::unique_ptr<cryptonote::Blockchain> init_blockchain(const std::vector<test_event_entry> & events, cryptonote::network_type nettype)
|
static std::unique_ptr<cryptonote::BlockchainAndPool> init_blockchain(const std::vector<test_event_entry> & events, cryptonote::network_type nettype)
|
||||||
{
|
{
|
||||||
std::unique_ptr<cryptonote::Blockchain> bc;
|
|
||||||
v_hardforks_t hardforks;
|
v_hardforks_t hardforks;
|
||||||
cryptonote::test_options test_options_tmp{nullptr, 0};
|
cryptonote::test_options test_options_tmp{nullptr, 0};
|
||||||
const cryptonote::test_options * test_options = &test_options_tmp;
|
const cryptonote::test_options * test_options = &test_options_tmp;
|
||||||
@ -159,10 +158,8 @@ static std::unique_ptr<cryptonote::Blockchain> init_blockchain(const std::vector
|
|||||||
test_options_tmp.hard_forks = hardforks.data();
|
test_options_tmp.hard_forks = hardforks.data();
|
||||||
test_options = &test_options_tmp;
|
test_options = &test_options_tmp;
|
||||||
|
|
||||||
cryptonote::tx_memory_pool txpool(*bc);
|
std::unique_ptr<cryptonote::BlockchainAndPool> bap(new BlockchainAndPool());
|
||||||
bc.reset(new cryptonote::Blockchain(txpool));
|
|
||||||
|
|
||||||
cryptonote::Blockchain *blockchain = bc.get();
|
|
||||||
auto bdb = new TestDB();
|
auto bdb = new TestDB();
|
||||||
|
|
||||||
BOOST_FOREACH(const test_event_entry &ev, events)
|
BOOST_FOREACH(const test_event_entry &ev, events)
|
||||||
@ -177,9 +174,9 @@ static std::unique_ptr<cryptonote::Blockchain> init_blockchain(const std::vector
|
|||||||
bdb->add_block(*blk, 1, 1, 1, 0, 0, blk_hash);
|
bdb->add_block(*blk, 1, 1, 1, 0, 0, blk_hash);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool r = blockchain->init(bdb, nettype, true, test_options, 2, nullptr);
|
bool r = bap->blockchain.init(bdb, nettype, true, test_options, 2, nullptr);
|
||||||
CHECK_AND_ASSERT_THROW_MES(r, "could not init blockchain from events");
|
CHECK_AND_ASSERT_THROW_MES(r, "could not init blockchain from events");
|
||||||
return bc;
|
return bap;
|
||||||
}
|
}
|
||||||
|
|
||||||
void test_generator::get_block_chain(std::vector<block_info>& blockchain, const crypto::hash& head, size_t n) const
|
void test_generator::get_block_chain(std::vector<block_info>& blockchain, const crypto::hash& head, size_t n) const
|
||||||
@ -393,7 +390,7 @@ bool test_generator::construct_block_manually_tx(cryptonote::block& blk, const c
|
|||||||
void test_generator::fill_nonce(cryptonote::block& blk, const difficulty_type& diffic, uint64_t height)
|
void test_generator::fill_nonce(cryptonote::block& blk, const difficulty_type& diffic, uint64_t height)
|
||||||
{
|
{
|
||||||
const cryptonote::Blockchain *blockchain = nullptr;
|
const cryptonote::Blockchain *blockchain = nullptr;
|
||||||
std::unique_ptr<cryptonote::Blockchain> bc;
|
std::unique_ptr<cryptonote::BlockchainAndPool> bap;
|
||||||
|
|
||||||
if (blk.major_version >= RX_BLOCK_VERSION && diffic > 1)
|
if (blk.major_version >= RX_BLOCK_VERSION && diffic > 1)
|
||||||
{
|
{
|
||||||
@ -403,8 +400,8 @@ void test_generator::fill_nonce(cryptonote::block& blk, const difficulty_type& d
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
bc = init_blockchain(*m_events, m_nettype);
|
bap = init_blockchain(*m_events, m_nettype);
|
||||||
blockchain = bc.get();
|
blockchain = &bap->blockchain;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -106,16 +106,9 @@ static uint32_t lcg()
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
struct BlockchainAndPool
|
|
||||||
{
|
|
||||||
cryptonote::tx_memory_pool txpool;
|
|
||||||
cryptonote::Blockchain bc;
|
|
||||||
BlockchainAndPool(): txpool(bc), bc(txpool) {}
|
|
||||||
};
|
|
||||||
|
|
||||||
#define PREFIX_WINDOW(hf_version,window) \
|
#define PREFIX_WINDOW(hf_version,window) \
|
||||||
BlockchainAndPool bap; \
|
cryptonote::BlockchainAndPool bap; \
|
||||||
cryptonote::Blockchain *bc = &bap.bc; \
|
cryptonote::Blockchain *bc = &bap.blockchain; \
|
||||||
struct get_test_options { \
|
struct get_test_options { \
|
||||||
const std::pair<uint8_t, uint64_t> hard_forks[3]; \
|
const std::pair<uint8_t, uint64_t> hard_forks[3]; \
|
||||||
const cryptonote::test_options test_options = { \
|
const cryptonote::test_options test_options = { \
|
||||||
|
@ -30,10 +30,7 @@
|
|||||||
#include "gtest/gtest.h"
|
#include "gtest/gtest.h"
|
||||||
#include "misc_log_ex.h"
|
#include "misc_log_ex.h"
|
||||||
#include "rpc/rpc_handler.h"
|
#include "rpc/rpc_handler.h"
|
||||||
#include "blockchain_db/blockchain_db.h"
|
|
||||||
#include "cryptonote_core/cryptonote_core.h"
|
#include "cryptonote_core/cryptonote_core.h"
|
||||||
#include "cryptonote_core/tx_pool.h"
|
|
||||||
#include "cryptonote_core/blockchain.h"
|
|
||||||
#include "blockchain_db/testdb.h"
|
#include "blockchain_db/testdb.h"
|
||||||
|
|
||||||
static const uint64_t test_distribution[32] = {
|
static const uint64_t test_distribution[32] = {
|
||||||
@ -77,9 +74,6 @@ public:
|
|||||||
|
|
||||||
bool get_output_distribution(uint64_t amount, uint64_t from, uint64_t to, uint64_t &start_height, std::vector<uint64_t> &distribution, uint64_t &base)
|
bool get_output_distribution(uint64_t amount, uint64_t from, uint64_t to, uint64_t &start_height, std::vector<uint64_t> &distribution, uint64_t &base)
|
||||||
{
|
{
|
||||||
std::unique_ptr<cryptonote::Blockchain> bc;
|
|
||||||
cryptonote::tx_memory_pool txpool(*bc);
|
|
||||||
bc.reset(new cryptonote::Blockchain(txpool));
|
|
||||||
struct get_test_options {
|
struct get_test_options {
|
||||||
const std::pair<uint8_t, uint64_t> hard_forks[2];
|
const std::pair<uint8_t, uint64_t> hard_forks[2];
|
||||||
const cryptonote::test_options test_options = {
|
const cryptonote::test_options test_options = {
|
||||||
@ -87,9 +81,9 @@ bool get_output_distribution(uint64_t amount, uint64_t from, uint64_t to, uint64
|
|||||||
};
|
};
|
||||||
get_test_options():hard_forks{std::make_pair((uint8_t)1, (uint64_t)0), std::make_pair((uint8_t)0, (uint64_t)0)}{}
|
get_test_options():hard_forks{std::make_pair((uint8_t)1, (uint64_t)0), std::make_pair((uint8_t)0, (uint64_t)0)}{}
|
||||||
} opts;
|
} opts;
|
||||||
cryptonote::Blockchain *blockchain = bc.get();
|
cryptonote::BlockchainAndPool bap;
|
||||||
bool r = blockchain->init(new TestDB(test_distribution_size), cryptonote::FAKECHAIN, true, &opts.test_options, 0, NULL);
|
bool r = bap.blockchain.init(new TestDB(test_distribution_size), cryptonote::FAKECHAIN, true, &opts.test_options, 0, NULL);
|
||||||
return r && bc->get_output_distribution(amount, from, to, start_height, distribution, base);
|
return r && bap.blockchain.get_output_distribution(amount, from, to, start_height, distribution, base);
|
||||||
}
|
}
|
||||||
|
|
||||||
crypto::hash get_block_hash(uint64_t height)
|
crypto::hash get_block_hash(uint64_t height)
|
||||||
|
@ -50,9 +50,6 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
#define PREFIX_WINDOW(hf_version,window) \
|
#define PREFIX_WINDOW(hf_version,window) \
|
||||||
std::unique_ptr<cryptonote::Blockchain> bc; \
|
|
||||||
cryptonote::tx_memory_pool txpool(*bc); \
|
|
||||||
bc.reset(new cryptonote::Blockchain(txpool)); \
|
|
||||||
struct get_test_options { \
|
struct get_test_options { \
|
||||||
const std::pair<uint8_t, uint64_t> hard_forks[3]; \
|
const std::pair<uint8_t, uint64_t> hard_forks[3]; \
|
||||||
const cryptonote::test_options test_options = { \
|
const cryptonote::test_options test_options = { \
|
||||||
@ -61,7 +58,9 @@ public:
|
|||||||
}; \
|
}; \
|
||||||
get_test_options(): hard_forks{std::make_pair(1, (uint64_t)0), std::make_pair((uint8_t)hf_version, (uint64_t)1), std::make_pair((uint8_t)0, (uint64_t)0)} {} \
|
get_test_options(): hard_forks{std::make_pair(1, (uint64_t)0), std::make_pair((uint8_t)hf_version, (uint64_t)1), std::make_pair((uint8_t)0, (uint64_t)0)} {} \
|
||||||
} opts; \
|
} opts; \
|
||||||
cryptonote::Blockchain *blockchain = bc.get(); \
|
cryptonote::BlockchainAndPool bap; \
|
||||||
|
cryptonote::Blockchain *blockchain = &bap.blockchain; \
|
||||||
|
cryptonote::Blockchain *bc = blockchain; \
|
||||||
bool r = blockchain->init(new TestDB(), cryptonote::FAKECHAIN, true, &opts.test_options, 0, NULL); \
|
bool r = blockchain->init(new TestDB(), cryptonote::FAKECHAIN, true, &opts.test_options, 0, NULL); \
|
||||||
ASSERT_TRUE(r)
|
ASSERT_TRUE(r)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user