6 #ifndef BITCOIN_SCRIPT_SCRIPT_H
7 #define BITCOIN_SCRIPT_SCRIPT_H
65 return std::vector<unsigned char>(in.begin(), in.end());
241 explicit CScriptNum(
const std::vector<unsigned char>& vch,
bool fRequireMinimal,
244 if (vch.size() > nMaxNumSize) {
247 if (fRequireMinimal && vch.size() > 0) {
254 if ((vch.back() & 0x7f) == 0) {
260 if (vch.size() <= 1 || (vch[vch.size() - 2] & 0x80) == 0) {
309 assert(rhs == 0 || (rhs > 0 &&
m_value <= std::numeric_limits<int64_t>::max() - rhs) ||
310 (rhs < 0 && m_value >= std::numeric_limits<int64_t>::min() - rhs));
317 assert(rhs == 0 || (rhs > 0 &&
m_value >= std::numeric_limits<int64_t>::min() + rhs) ||
318 (rhs < 0 &&
m_value <= std::numeric_limits<int64_t>::max() + rhs));
331 if (
m_value > std::numeric_limits<int>::max())
332 return std::numeric_limits<int>::max();
333 else if (
m_value < std::numeric_limits<int>::min())
334 return std::numeric_limits<int>::min();
340 std::vector<unsigned char>
getvch()
const
345 static std::vector<unsigned char>
serialize(
const int64_t& value)
348 return std::vector<unsigned char>();
350 std::vector<unsigned char> result;
351 const bool neg = value < 0;
352 uint64_t absvalue = neg ? ~static_cast<uint64_t>(value) + 1 :
static_cast<uint64_t
>(value);
356 result.push_back(absvalue & 0xff);
370 if (result.back() & 0x80)
371 result.push_back(neg ? 0x80 : 0);
373 result.back() |= 0x80;
379 static int64_t
set_vch(
const std::vector<unsigned char>& vch)
385 for (
size_t i = 0; i != vch.size(); ++i)
386 result |=
static_cast<int64_t
>(vch[i]) << 8*i;
390 if (vch.back() & 0x80)
391 return -((int64_t)(result & ~(0x80ULL << (8 * (vch.size() - 1)))));
415 if (n == -1 || (n >= 1 && n <= 16))
432 CScript(std::vector<unsigned char>::const_iterator pbegin, std::vector<unsigned char>::const_iterator pend) :
CScriptBase(pbegin, pend) { }
442 explicit CScript(
const std::vector<unsigned char>& b) =
delete;
451 if (opcode < 0 || opcode > 0xff)
452 throw std::runtime_error(
"CScript::operator<<(): invalid opcode");
469 else if (b.size() <= 0xff)
474 else if (b.size() <= 0xffff)
479 insert(
end(), _data, _data +
sizeof(_data));
486 insert(
end(), _data, _data +
sizeof(_data));
508 return (
int)opcode - (int)(
OP_1 - 1);
512 assert(n >= 0 && n <= 16);
535 bool IsWitnessProgram(
int& version, std::vector<unsigned char>& program)
const;
566 std::vector<std::vector<unsigned char> >
stack;
584 template<
typename... Ts>
590 ([&
ret, &cnt] (Ts&& input) {
591 if constexpr (std::is_same_v<std::remove_cv_t<std::remove_reference_t<Ts>>,
CScript>) {
594 ret = std::forward<Ts>(input);
596 ret.insert(
ret.end(), input.begin(), input.end());
603 } (std::forward<Ts>(inputs)), ...);
Serialized script, used inside transaction inputs and outputs.
CScript & operator<<(const std::vector< unsigned char > &b) LIFETIMEBOUND
CScript(const_iterator pbegin, const_iterator pend)
bool IsPayToScriptHash() const
bool IsUnspendable() const
Returns whether the script is guaranteed to fail at execution, regardless of the initial stack.
CScript(const CScriptNum &b)
CScript & operator<<(const CScriptNum &b) LIFETIMEBOUND
CScript & operator<<(const CScript &b)=delete
Delete non-existent operator to defend against future introduction.
CScript & operator<<(opcodetype opcode) LIFETIMEBOUND
SERIALIZE_METHODS(CScript, obj)
CScript(std::vector< unsigned char >::const_iterator pbegin, std::vector< unsigned char >::const_iterator pend)
static int DecodeOP_N(opcodetype opcode)
Encode/decode small integers:
bool IsPayToWitnessScriptHash() const
CScript & operator<<(int64_t b) LIFETIMEBOUND
unsigned int GetSigOpCount(bool fAccurate) const
Pre-version-0.6, Bitcoin always counted CHECKMULTISIGs as 20 sigops.
bool HasValidOps() const
Check if the script contains valid OP_CODES.
CScript(const std::vector< unsigned char > &b)=delete
bool GetOp(const_iterator &pc, opcodetype &opcodeRet) const
CScript(const unsigned char *pbegin, const unsigned char *pend)
CScript & push_int64(int64_t n)
bool GetOp(const_iterator &pc, opcodetype &opcodeRet, std::vector< unsigned char > &vchRet) const
bool IsWitnessProgram(int &version, std::vector< unsigned char > &program) const
static opcodetype EncodeOP_N(int n)
CScriptNum & operator&=(const int64_t &rhs)
CScriptNum operator-(const int64_t &rhs) const
CScriptNum operator+(const int64_t &rhs) const
static std::vector< unsigned char > serialize(const int64_t &value)
CScriptNum operator-(const CScriptNum &rhs) const
CScriptNum & operator+=(const CScriptNum &rhs)
bool operator==(const CScriptNum &rhs) const
bool operator<=(const CScriptNum &rhs) const
bool operator==(const int64_t &rhs) const
bool operator<(const int64_t &rhs) const
CScriptNum(const std::vector< unsigned char > &vch, bool fRequireMinimal, const size_t nMaxNumSize=nDefaultMaxNumSize)
CScriptNum & operator+=(const int64_t &rhs)
static const size_t nDefaultMaxNumSize
CScriptNum operator&(const int64_t &rhs) const
CScriptNum operator&(const CScriptNum &rhs) const
bool operator>=(const int64_t &rhs) const
CScriptNum & operator-=(const CScriptNum &rhs)
bool operator<=(const int64_t &rhs) const
CScriptNum(const int64_t &n)
Numeric opcodes (OP_1ADD, etc) are restricted to operating on 4-byte integers.
CScriptNum & operator=(const int64_t &rhs)
bool operator!=(const int64_t &rhs) const
bool operator>=(const CScriptNum &rhs) const
bool operator>(const int64_t &rhs) const
static int64_t set_vch(const std::vector< unsigned char > &vch)
std::vector< unsigned char > getvch() const
CScriptNum operator-() const
bool operator!=(const CScriptNum &rhs) const
CScriptNum & operator-=(const int64_t &rhs)
CScriptNum & operator&=(const CScriptNum &rhs)
CScriptNum operator+(const CScriptNum &rhs) const
Implements a drop-in replacement for std::vector<T> which stores up to N elements directly (without h...
iterator insert(iterator pos, const T &value)
void push_back(const T &value)
scriptnum_error(const std::string &str)
static void WriteLE16(unsigned char *ptr, uint16_t x)
static void WriteLE32(unsigned char *ptr, uint32_t x)
static constexpr int64_t VALIDATION_WEIGHT_PER_SIGOP_PASSED
static const unsigned int LOCKTIME_THRESHOLD
static const unsigned int MAX_OPCODE
std::string GetOpName(opcodetype opcode)
prevector< 28, unsigned char > CScriptBase
We use a prevector for the script to reduce the considerable memory overhead of vectors in cases wher...
bool CheckMinimalPush(const std::vector< unsigned char > &data, opcodetype opcode)
static const unsigned int MAX_SCRIPT_ELEMENT_SIZE
std::vector< unsigned char > ToByteVector(const T &in)
static const int MAX_SCRIPT_SIZE
opcodetype
Script opcodes.
static constexpr unsigned int MAX_PUBKEYS_PER_MULTI_A
The limit of keys in OP_CHECKSIGADD-based scripts.
bool GetScriptOp(CScriptBase::const_iterator &pc, CScriptBase::const_iterator end, opcodetype &opcodeRet, std::vector< unsigned char > *pvchRet)
static const int MAX_STACK_SIZE
bool IsOpSuccess(const opcodetype &opcode)
Test for OP_SUCCESSx opcodes as defined by BIP342.
static const int MAX_OPS_PER_SCRIPT
static constexpr int64_t VALIDATION_WEIGHT_OFFSET
CScript BuildScript(Ts &&... inputs)
Build a script by concatenating other scripts, or any argument accepted by CScript::operator<<.
static const int MAX_PUBKEYS_PER_MULTISIG
static const uint32_t LOCKTIME_MAX
static constexpr unsigned int ANNEX_TAG
#define READWRITEAS(type, obj)
std::string ToString() const
std::vector< std::vector< unsigned char > > stack