61 .cache_bytes = 1 << 20,
67 std::vector<std::unique_ptr<CBlockFileInfo>> files;
68 files.reserve(files_count);
69 std::vector<std::pair<int, const CBlockFileInfo*>> files_info;
70 files_info.reserve(files_count);
71 for (
int i = 0; i < files_count; i++) {
73 files.push_back(std::make_unique<CBlockFileInfo>(std::move(*file_info)));
74 files_info.emplace_back(i, files.back().get());
82 std::vector<std::unique_ptr<CBlockIndex>> blocks;
83 blocks.reserve(blocks_count);
84 std::vector<const CBlockIndex*> blocks_info;
85 blocks_info.reserve(blocks_count);
86 for (
int i = 0; i < blocks_count; i++) {
88 blocks.push_back(std::make_unique<CBlockIndex>(std::move(header)));
89 blocks.back()->phashBlock = &g_block_hash;
90 blocks_info.push_back(blocks.back().get());
94 block_index.WriteBatchSync(files_info, files_count - 1, blocks_info);
99 for (
const auto& [n, file_info]: files_info) {
100 assert(block_index.ReadBlockFileInfo(n, info));
101 assert(info == *file_info);
106 assert(block_index.ReadLastBlockFile(last_block_file));
107 assert(last_block_file == files_count - 1);
111 block_index.WriteReindexing(
true);
112 block_index.ReadReindexing(reindexing);
114 block_index.WriteReindexing(
false);
115 block_index.ReadReindexing(reindexing);
121 block_index.WriteFlag(flag_name,
true);
122 block_index.ReadFlag(flag_name, flag_value);
124 block_index.WriteFlag(flag_name,
false);
125 block_index.ReadFlag(flag_name, flag_value);
131 const auto inserter = [&](
const uint256&) {
132 return blocks.back().get();
RecursiveMutex cs_main
Mutex to guard access to validation specific variables, such as reading or changing the chainstate.