6 #ifndef BITCOIN_CHAIN_H
7 #define BITCOIN_CHAIN_H
79 void AddBlock(
unsigned int nHeightIn, uint64_t nTimeIn) {
80 if (nBlocks==0 || nHeightFirst > nHeightIn)
81 nHeightFirst = nHeightIn;
82 if (nBlocks==0 || nTimeFirst > nTimeIn)
85 if (nHeightIn > nHeightLast)
86 nHeightLast = nHeightIn;
87 if (nTimeIn > nTimeLast)
249 return (int64_t)
nTime;
266 for (
int i = 0; i < nMedianTimeSpan && pindex; i++, pindex = pindex->
pprev)
269 std::sort(pbegin, pend);
270 return pbegin[(pend - pbegin)/2];
275 return strprintf(
"CBlockIndex(pprev=%p, nHeight=%d, merkle=%s, hashBlock=%s)",
335 int _nVersion = s.GetVersion();
369 std::string str =
"CDiskBlockIndex(";
371 str +=
strprintf(
"\n hashBlock=%s, hashPrev=%s)",
386 return vChain.size() > 0 ? vChain[0] :
nullptr;
391 return vChain.size() > 0 ? vChain[vChain.size() - 1] :
nullptr;
396 if (nHeight < 0 || nHeight >= (
int)vChain.size())
403 return (*
this)[pindex->
nHeight] == pindex;
409 return (*
this)[pindex->
nHeight + 1];
416 return vChain.size() - 1;
432 #endif // BITCOIN_CHAIN_H
arith_uint256 nChainWork
(memory only) Total amount of work (expected number of hashes) in the chain up to and including this ...
int32_t nSequenceId
(memory only) Sequential id assigned to distinguish order in which blocks are received.
CBlockIndex * pskip
pointer to the index of some further predecessor of this block
std::vector< CBlockIndex * > vChain
Describes a place in the block chain to another node such that if the other node doesn't have the sam...
descends from failed block
Reserved (was BLOCK_VALID_HEADER).
CBlockIndex * pprev
pointer to the index of the predecessor of this block
uint32_t nStatus
Verification status of this block. See enum BlockStatus.
void AddBlock(unsigned int nHeightIn, uint64_t nTimeIn)
update statistics (does not update nSize)
const CBlockIndex * LastCommonAncestor(const CBlockIndex *pa, const CBlockIndex *pb)
Find the forking point between two chain tips.
An in-memory indexed chain of blocks.
CBlockIndex * operator[](int nHeight) const
Returns the index entry at a particular height in this chain, or nullptr if no such height exists...
All parent headers found, difficulty matches, timestamp >= median previous, checkpoint.
std::string ToString() const
stage after last reached validness failed
Only first tx is coinbase, 2 <= coinbase input script length <= 100, transactions valid...
unsigned int nSize
number of used bytes of block file
FlatFilePos GetUndoPos() const
undo data available in rev*.dat
int nFile
Which # file this block is stored in (blk?????.dat)
FlatFilePos GetBlockPos() const
SERIALIZE_METHODS(CDiskBlockIndex, obj)
static constexpr int64_t TIMESTAMP_WINDOW
Timestamp window used as a grace period by code that compares external timestamps (such as timestamps...
unsigned int nHeightLast
highest height of block in file
unsigned int nChainTx
(memory only) Number of transactions in the chain up to and including this block. ...
unsigned int nUndoSize
number of used bytes in the undo file
std::string ToString() const
static constexpr int nMedianTimeSpan
int64_t GetBlockTimeMax() const
#define VARINT_MODE(obj, mode)
arith_uint256 GetBlockProof(const CBlockIndex &block)
CBlockIndex * Tip() const
Returns the index entry for the tip of this chain, or nullptr if none.
Outputs do not overspend inputs, no double spends, coinbase output ok, no immature coinbase spends...
int Height() const
Return the maximal height in the chain.
unsigned int nTimeMax
(memory only) Maximum nTime in the chain up to and including this block.
uint64_t nTimeFirst
earliest time of block in file
CBlockIndex * Next(const CBlockIndex *pindex) const
Find the successor of a block in this chain, or nullptr if the given index is not found or is the tip...
Scripts & signatures ok. Implies all parents are also at least SCRIPTS.
CBlockHeader GetBlockHeader() const
unsigned int nDataPos
Byte offset within blk?????.dat where this block's data is stored.
uint256 GetBlockHash() const
CBlockIndex(const CBlockHeader &block)
unsigned int nHeightFirst
lowest height of block in file
void BuildSkip()
Build the skiplist pointer for this entry.
const CBlockIndex * FindFork(const CBlockIndex *pindex) const
Find the last common block between this chain and a block index entry.
Used to marshal pointers into hashes for db storage.
CBlockIndex * FindEarliestAtLeast(int64_t nTime, int height) const
Find the earliest block with timestamp equal or greater than the given time and height equal or great...
Parameters that influence chain consensus.
std::string ToString() const
256-bit unsigned big integer.
block data in blk*.data was received with a witness-enforcing client
int64_t GetBlockProofEquivalentTime(const CBlockIndex &to, const CBlockIndex &from, const CBlockIndex &tip, const Consensus::Params &)
Return the time it would take to redo the work difference between from and to, assuming the current h...
unsigned int nUndoPos
Byte offset within rev?????.dat where this block's undo data is stored.
CBlockIndex * Genesis() const
Returns the index entry for the genesis block of this chain, or nullptr if none.
int32_t nVersion
block header
void SetTip(CBlockIndex *pindex)
Set/initialize a chain with a given tip.
CDiskBlockIndex(const CBlockIndex *pindex)
The block chain is a tree shaped structure starting with the genesis block at the root...
bool Contains(const CBlockIndex *pindex) const
Efficiently check whether a block is present in this chain.
unsigned int nBlocks
number of blocks stored in file
std::string ToString() const
bool RaiseValidity(enum BlockStatus nUpTo)
Raise the validity level of this block index entry.
bool IsValid(enum BlockStatus nUpTo=BLOCK_VALID_TRANSACTIONS) const
Check whether this block index entry is valid up to the passed validity level.
uint64_t nTimeLast
latest time of block in file
static constexpr int64_t MAX_FUTURE_BLOCK_TIME
Maximum amount of time that a block timestamp is allowed to exceed the current network-adjusted time ...
CBlockLocator GetLocator(const CBlockIndex *pindex=nullptr) const
Return a CBlockLocator that refers to a block in this chain (by default the tip). ...
int nHeight
height of the entry in the chain. The genesis block has height 0
CBlockIndex * GetAncestor(int height)
Efficiently find an ancestor of this block.
full block available in blk*.dat
SERIALIZE_METHODS(CBlockFileInfo, obj)
int64_t GetBlockTime() const
int64_t GetMedianTimePast() const
static constexpr int64_t MAX_BLOCK_TIME_GAP
Maximum gap between node time and block time used for the "Catching up..." mode in GUI...
unsigned int nTx
Number of transactions in this block.
uint256 GetBlockHash() const
const uint256 * phashBlock
pointer to the hash of the block, if any. Memory is owned by this CBlockIndex
bool HaveTxsDownloaded() const
Check whether this block's and all previous blocks' transactions have been downloaded (and stored to ...