LCOV - code coverage report
Current view: top level - src/node - chainstate.h Coverage Total Hit
Test: fuzz_coverage.info Lines: 100.0 % 1 1
Test Date: 2025-01-22 04:09:46 Functions: - 0 0
Branches: 50.0 % 2 1

             Branch data     Line data    Source code
       1                 :             : // Copyright (c) 2021-2022 The Bitcoin Core developers
       2                 :             : // Distributed under the MIT software license, see the accompanying
       3                 :             : // file COPYING or http://www.opensource.org/licenses/mit-license.php.
       4                 :             : 
       5                 :             : #ifndef BITCOIN_NODE_CHAINSTATE_H
       6                 :             : #define BITCOIN_NODE_CHAINSTATE_H
       7                 :             : 
       8                 :             : #include <util/translation.h>
       9                 :             : #include <validation.h>
      10                 :             : 
      11                 :             : #include <cstdint>
      12                 :             : #include <functional>
      13                 :             : #include <tuple>
      14                 :             : 
      15                 :             : class CTxMemPool;
      16                 :             : 
      17                 :             : namespace kernel {
      18                 :             : struct CacheSizes;
      19                 :             : } // namespace kernel
      20                 :             : 
      21                 :             : namespace node {
      22                 :             : 
      23         [ +  - ]:        4082 : struct ChainstateLoadOptions {
      24                 :             :     CTxMemPool* mempool{nullptr};
      25                 :             :     bool block_tree_db_in_memory{false};
      26                 :             :     bool coins_db_in_memory{false};
      27                 :             :     // Whether to wipe the block tree database when loading it. If set, this
      28                 :             :     // will also set a reindexing flag so any existing block data files will be
      29                 :             :     // scanned and added to the database.
      30                 :             :     bool wipe_block_tree_db{false};
      31                 :             :     // Whether to wipe the chainstate database when loading it. If set, this
      32                 :             :     // will cause the chainstate database to be rebuilt starting from genesis.
      33                 :             :     bool wipe_chainstate_db{false};
      34                 :             :     bool prune{false};
      35                 :             :     //! Setting require_full_verification to true will require all checks at
      36                 :             :     //! check_level (below) to succeed for loading to succeed. Setting it to
      37                 :             :     //! false will skip checks if cache is not big enough to run them, so may be
      38                 :             :     //! helpful for running with a small cache.
      39                 :             :     bool require_full_verification{true};
      40                 :             :     int64_t check_blocks{DEFAULT_CHECKBLOCKS};
      41                 :             :     int64_t check_level{DEFAULT_CHECKLEVEL};
      42                 :             :     std::function<void()> coins_error_cb;
      43                 :             : };
      44                 :             : 
      45                 :             : //! Chainstate load status. Simple applications can just check for the success
      46                 :             : //! case, and treat other cases as errors. More complex applications may want to
      47                 :             : //! try reindexing in the generic failure case, and pass an interrupt callback
      48                 :             : //! and exit cleanly in the interrupted case.
      49                 :             : enum class ChainstateLoadStatus {
      50                 :             :     SUCCESS,
      51                 :             :     FAILURE, //!< Generic failure which reindexing may fix
      52                 :             :     FAILURE_FATAL, //!< Fatal error which should not prompt to reindex
      53                 :             :     FAILURE_INCOMPATIBLE_DB,
      54                 :             :     FAILURE_INSUFFICIENT_DBCACHE,
      55                 :             :     INTERRUPTED,
      56                 :             : };
      57                 :             : 
      58                 :             : //! Chainstate load status code and optional error string.
      59                 :             : using ChainstateLoadResult = std::tuple<ChainstateLoadStatus, bilingual_str>;
      60                 :             : 
      61                 :             : /** This sequence can have 4 types of outcomes:
      62                 :             :  *
      63                 :             :  *  1. Success
      64                 :             :  *  2. Shutdown requested
      65                 :             :  *    - nothing failed but a shutdown was triggered in the middle of the
      66                 :             :  *      sequence
      67                 :             :  *  3. Soft failure
      68                 :             :  *    - a failure that might be recovered from with a reindex
      69                 :             :  *  4. Hard failure
      70                 :             :  *    - a failure that definitively cannot be recovered from with a reindex
      71                 :             :  *
      72                 :             :  *  LoadChainstate returns a (status code, error string) tuple.
      73                 :             :  */
      74                 :             : ChainstateLoadResult LoadChainstate(ChainstateManager& chainman, const kernel::CacheSizes& cache_sizes,
      75                 :             :                                     const ChainstateLoadOptions& options);
      76                 :             : ChainstateLoadResult VerifyLoadedChainstate(ChainstateManager& chainman, const ChainstateLoadOptions& options);
      77                 :             : } // namespace node
      78                 :             : 
      79                 :             : #endif // BITCOIN_NODE_CHAINSTATE_H
        

Generated by: LCOV version 2.0-1