LCOV - code coverage report
Current view: top level - src/primitives - block.h (source / functions) Coverage Total Hit
Test: test_bitcoin_coverage.info Lines: 100.0 % 50 50
Test Date: 2026-02-13 04:40:47 Functions: 84.8 % 33 28
Branches: 38.9 % 72 28

             Branch data     Line data    Source code
       1                 :             : // Copyright (c) 2009-2010 Satoshi Nakamoto
       2                 :             : // Copyright (c) 2009-present The Bitcoin Core developers
       3                 :             : // Distributed under the MIT software license, see the accompanying
       4                 :             : // file COPYING or http://www.opensource.org/licenses/mit-license.php.
       5                 :             : 
       6                 :             : #ifndef BITCOIN_PRIMITIVES_BLOCK_H
       7                 :             : #define BITCOIN_PRIMITIVES_BLOCK_H
       8                 :             : 
       9                 :             : #include <primitives/transaction.h>
      10                 :             : #include <serialize.h>
      11                 :             : #include <uint256.h>
      12                 :             : #include <util/time.h>
      13                 :             : 
      14                 :             : #include <cstdint>
      15                 :             : #include <string>
      16                 :             : #include <utility>
      17                 :             : #include <vector>
      18                 :             : 
      19                 :             : /** Nodes collect new transactions into a block, hash them into a hash tree,
      20                 :             :  * and scan through nonce values to make the block's hash satisfy proof-of-work
      21                 :             :  * requirements.  When they solve the proof-of-work, they broadcast the block
      22                 :             :  * to everyone and the block is added to the block chain.  The first transaction
      23                 :             :  * in the block is a special one that creates a new coin owned by the creator
      24                 :             :  * of the block.
      25                 :             :  */
      26                 :             : class CBlockHeader
      27                 :             : {
      28                 :             : public:
      29                 :             :     // header
      30                 :             :     int32_t nVersion;
      31                 :             :     uint256 hashPrevBlock;
      32                 :             :     uint256 hashMerkleRoot;
      33                 :             :     uint32_t nTime;
      34                 :             :     uint32_t nBits;
      35                 :             :     uint32_t nNonce;
      36                 :             : 
      37                 :       92480 :     CBlockHeader()
      38                 :       92480 :     {
      39                 :       92480 :         SetNull();
      40                 :       92480 :     }
      41                 :             : 
      42   [ #  #  #  # ]:      774236 :     SERIALIZE_METHODS(CBlockHeader, obj) { READWRITE(obj.nVersion, obj.hashPrevBlock, obj.hashMerkleRoot, obj.nTime, obj.nBits, obj.nNonce); }
      43                 :             : 
      44                 :      128362 :     void SetNull()
      45                 :             :     {
      46                 :      128362 :         nVersion = 0;
      47                 :      128362 :         hashPrevBlock.SetNull();
      48                 :      128362 :         hashMerkleRoot.SetNull();
      49                 :      128362 :         nTime = 0;
      50                 :      128362 :         nBits = 0;
      51                 :      128362 :         nNonce = 0;
      52                 :      128362 :     }
      53                 :             : 
      54                 :         457 :     bool IsNull() const
      55                 :             :     {
      56 [ +  + ][ +  -  :         457 :         return (nBits == 0);
          +  -  +  -  +  
                      - ]
      57                 :             :     }
      58                 :             : 
      59                 :             :     uint256 GetHash() const;
      60                 :             : 
      61                 :       15862 :     NodeSeconds Time() const
      62                 :             :     {
      63                 :       15862 :         return NodeSeconds{std::chrono::seconds{nTime}};
      64                 :             :     }
      65                 :             : 
      66                 :       55047 :     int64_t GetBlockTime() const
      67                 :             :     {
      68         [ +  + ]:       55047 :         return (int64_t)nTime;
      69                 :             :     }
      70                 :             : };
      71                 :             : 
      72                 :             : 
      73   [ +  -  +  -  :       33303 : class CBlock : public CBlockHeader
          +  -  +  -  +  
              - ][ +  + ]
           [ +  -  +  -  
             +  -  +  - ]
           [ #  #  #  # ]
      74                 :             : {
      75                 :             : public:
      76                 :             :     // network and disk
      77                 :             :     std::vector<CTransactionRef> vtx;
      78                 :             : 
      79                 :             :     // Memory-only flags for caching expensive checks
      80                 :             :     mutable bool fChecked;                            // CheckBlock()
      81                 :             :     mutable bool m_checked_witness_commitment{false}; // CheckWitnessCommitment()
      82                 :             :     mutable bool m_checked_merkle_root{false};        // CheckMerkleRoot()
      83                 :             : 
      84                 :       30860 :     CBlock()
      85                 :       30860 :     {
      86                 :       30860 :         SetNull();
      87                 :       30860 :     }
      88                 :             : 
      89                 :           8 :     CBlock(const CBlockHeader &header)
      90                 :           8 :     {
      91                 :           8 :         SetNull();
      92                 :           8 :         *(static_cast<CBlockHeader*>(this)) = header;
      93                 :           8 :     }
      94                 :             : 
      95   [ #  #  #  # ]:      108473 :     SERIALIZE_METHODS(CBlock, obj)
      96                 :             :     {
      97                 :       92985 :         READWRITE(AsBase<CBlockHeader>(obj), obj.vtx);
      98                 :       92983 :     }
      99                 :             : 
     100                 :       35872 :     void SetNull()
     101                 :             :     {
     102                 :       35872 :         CBlockHeader::SetNull();
     103                 :       35872 :         vtx.clear();
     104                 :       35872 :         fChecked = false;
     105                 :       35872 :         m_checked_witness_commitment = false;
     106                 :       35872 :         m_checked_merkle_root = false;
     107                 :       35872 :     }
     108                 :             : 
     109                 :             :     std::string ToString() const;
     110                 :             : };
     111                 :             : 
     112                 :             : /** Describes a place in the block chain to another node such that if the
     113                 :             :  * other node doesn't have the same branch, it can find a recent common trunk.
     114                 :             :  * The further back it is, the further before the fork it may be.
     115                 :             :  */
     116   [ +  -  +  - ]:         991 : struct CBlockLocator
           [ +  -  -  -  
             -  -  -  - ]
           [ +  -  #  #  
             #  #  #  # ]
     117                 :             : {
     118                 :             :     /** Historically CBlockLocator's version field has been written to network
     119                 :             :      * streams as the negotiated protocol version and to disk streams as the
     120                 :             :      * client version, but the value has never been used.
     121                 :             :      *
     122                 :             :      * Hard-code to the highest protocol version ever written to a network stream.
     123                 :             :      * SerParams can be used if the field requires any meaning in the future,
     124                 :             :      **/
     125                 :             :     static constexpr int DUMMY_VERSION = 70016;
     126                 :             : 
     127                 :             :     std::vector<uint256> vHave;
     128                 :             : 
     129                 :             :     CBlockLocator() = default;
     130                 :             : 
     131                 :         214 :     explicit CBlockLocator(std::vector<uint256>&& have) : vHave(std::move(have)) {}
     132                 :             : 
     133                 :         148 :     SERIALIZE_METHODS(CBlockLocator, obj)
     134                 :             :     {
     135                 :          74 :         int nVersion = DUMMY_VERSION;
     136                 :          74 :         READWRITE(nVersion);
     137                 :          74 :         READWRITE(obj.vHave);
     138                 :          74 :     }
     139                 :             : 
     140                 :           5 :     void SetNull()
     141                 :             :     {
     142         [ -  + ]:           6 :         vHave.clear();
     143                 :             :     }
     144                 :             : 
     145                 :         595 :     bool IsNull() const
     146                 :             :     {
     147   [ +  +  +  + ]:         595 :         return vHave.empty();
                 [ #  # ]
     148                 :             :     }
     149                 :             : };
     150                 :             : 
     151                 :             : #endif // BITCOIN_PRIMITIVES_BLOCK_H
        

Generated by: LCOV version 2.0-1