Bitcoin Core 31.0.0
P2P Digital Currency
Loading...
Searching...
No Matches
transaction.cpp
Go to the documentation of this file.
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
7
8#include <consensus/amount.h>
9#include <crypto/hex_base.h>
10#include <hash.h>
12#include <script/script.h>
13#include <serialize.h>
14#include <tinyformat.h>
15
16#include <algorithm>
17#include <cassert>
18#include <span>
19#include <stdexcept>
20
21std::string COutPoint::ToString() const
22{
23 return strprintf("COutPoint(%s, %u)", hash.ToString().substr(0,10), n);
24}
25
26CTxIn::CTxIn(COutPoint prevoutIn, CScript scriptSigIn, uint32_t nSequenceIn)
27{
28 prevout = prevoutIn;
29 scriptSig = scriptSigIn;
30 nSequence = nSequenceIn;
31}
32
33CTxIn::CTxIn(Txid hashPrevTx, uint32_t nOut, CScript scriptSigIn, uint32_t nSequenceIn)
34{
35 prevout = COutPoint(hashPrevTx, nOut);
36 scriptSig = scriptSigIn;
37 nSequence = nSequenceIn;
38}
39
40std::string CTxIn::ToString() const
41{
42 std::string str;
43 str += "CTxIn(";
44 str += prevout.ToString();
45 if (prevout.IsNull())
46 str += strprintf(", coinbase %s", HexStr(scriptSig));
47 else
48 str += strprintf(", scriptSig=%s", HexStr(scriptSig).substr(0, 24));
50 str += strprintf(", nSequence=%u", nSequence);
51 str += ")";
52 return str;
53}
54
55CTxOut::CTxOut(const CAmount& nValueIn, CScript scriptPubKeyIn)
56{
57 nValue = nValueIn;
58 scriptPubKey = scriptPubKeyIn;
59}
60
61std::string CTxOut::ToString() const
62{
63 return strprintf("CTxOut(nValue=%d.%08d, scriptPubKey=%s)", nValue / COIN, nValue % COIN, HexStr(scriptPubKey).substr(0, 30));
64}
65
68
70{
71 return Txid::FromUint256((HashWriter{} << TX_NO_WITNESS(*this)).GetHash());
72}
73
75{
76 return std::any_of(vin.begin(), vin.end(), [](const auto& input) {
77 return !input.scriptWitness.IsNull();
78 });
79}
80
82{
83 return Txid::FromUint256((HashWriter{} << TX_NO_WITNESS(*this)).GetHash());
84}
85
87{
88 if (!HasWitness()) {
89 return Wtxid::FromUint256(hash.ToUint256());
90 }
91
92 return Wtxid::FromUint256((HashWriter{} << TX_WITH_WITNESS(*this)).GetHash());
93}
94
97
99{
100 CAmount nValueOut = 0;
101 for (const auto& tx_out : vout) {
102 if (!MoneyRange(tx_out.nValue) || !MoneyRange(nValueOut + tx_out.nValue))
103 throw std::runtime_error(std::string(__func__) + ": value out of range");
104 nValueOut += tx_out.nValue;
105 }
106 assert(MoneyRange(nValueOut));
107 return nValueOut;
108}
109
111{
112 return ::GetSerializeSize(TX_WITH_WITNESS(*this));
113}
114
115std::string CTransaction::ToString() const
116{
117 std::string str;
118 str += strprintf("CTransaction(hash=%s, ver=%u, vin.size=%u, vout.size=%u, nLockTime=%u)\n",
119 GetHash().ToString().substr(0,10),
120 version,
121 vin.size(),
122 vout.size(),
123 nLockTime);
124 for (const auto& tx_in : vin)
125 str += " " + tx_in.ToString() + "\n";
126 for (const auto& tx_in : vin)
127 str += " " + tx_in.scriptWitness.ToString() + "\n";
128 for (const auto& tx_out : vout)
129 str += " " + tx_out.ToString() + "\n";
130 return str;
131}
bool MoneyRange(const CAmount &nValue)
Definition amount.h:27
int64_t CAmount
Amount in satoshis (Can be negative).
Definition amount.h:12
static constexpr CAmount COIN
The amount of satoshis in one BTC.
Definition amount.h:15
An outpoint - a combination of a transaction hash and an index n into its vout.
Definition transaction.h:29
uint32_t n
Definition transaction.h:32
std::string ToString() const
Serialized script, used inside transaction inputs and outputs.
Definition script.h:405
The basic transaction that is broadcasted on the network and contained in blocks.
Txid ComputeHash() const
bool HasWitness() const
const uint32_t nLockTime
unsigned int ComputeTotalSize() const
Calculate the total transaction size in bytes, including witness data.
bool ComputeHasWitness() const
CTransaction(const CMutableTransaction &tx)
Convert a CMutableTransaction into a CTransaction.
const Wtxid m_witness_hash
const std::vector< CTxOut > vout
std::string ToString() const
const bool m_has_witness
Memory only.
Wtxid ComputeWitnessHash() const
CAmount GetValueOut() const
const Txid & GetHash() const LIFETIMEBOUND
const uint32_t version
const std::vector< CTxIn > vin
const Txid hash
uint32_t nSequence
Definition transaction.h:66
static const uint32_t SEQUENCE_FINAL
Setting nSequence to this value for every input in a transaction disables nLockTime/IsFinalTx().
Definition transaction.h:76
std::string ToString() const
CScript scriptSig
Definition transaction.h:65
COutPoint prevout
Definition transaction.h:64
CScript scriptPubKey
CAmount nValue
std::string ToString() const
A writer stream (for serialization) that computes a 256-bit hash.
Definition hash.h:101
static transaction_identifier FromUint256(const uint256 &id)
std::string HexStr(const std::span< const uint8_t > s)
Convert a span of bytes to a lower-case hexadecimal string.
Definition hex_base.cpp:30
Definition common.h:29
static constexpr TransactionSerParams TX_NO_WITNESS
static constexpr TransactionSerParams TX_WITH_WITNESS
A mutable version of CTransaction.
std::vector< CTxOut > vout
Txid GetHash() const
Compute the hash of this CMutableTransaction.
std::vector< CTxIn > vin
#define strprintf
Format arguments and return the string or write to given std::ostream (see tinyformat::format doc for...
transaction_identifier< true > Wtxid
Wtxid commits to all transaction fields including the witness.
transaction_identifier< false > Txid
Txid commits to all transaction fields except the witness.
assert(!tx.IsCoinBase())