6 #ifndef BITCOIN_SCRIPT_SCRIPT_H 7 #define BITCOIN_SCRIPT_SCRIPT_H 23 static const unsigned int MAX_SCRIPT_ELEMENT_SIZE = 520;
26 static const int MAX_OPS_PER_SCRIPT = 201;
29 static const int MAX_PUBKEYS_PER_MULTISIG = 20;
32 static const int MAX_SCRIPT_SIZE = 10000;
35 static const int MAX_STACK_SIZE = 1000;
39 static const unsigned int LOCKTIME_THRESHOLD = 500000000;
44 return std::vector<unsigned char>(in.begin(), in.end());
188 static const unsigned int MAX_OPCODE =
OP_NOP10;
217 explicit CScriptNum(
const std::vector<unsigned char>& vch,
bool fRequireMinimal,
220 if (vch.size() > nMaxNumSize) {
223 if (fRequireMinimal && vch.size() > 0) {
230 if ((vch.back() & 0x7f) == 0) {
236 if (vch.size() <= 1 || (vch[vch.size() - 2] & 0x80) == 0) {
273 assert(
m_value != std::numeric_limits<int64_t>::min());
285 assert(rhs == 0 || (rhs > 0 &&
m_value <= std::numeric_limits<int64_t>::max() - rhs) ||
286 (rhs < 0 && m_value >= std::numeric_limits<int64_t>::min() - rhs));
293 assert(rhs == 0 || (rhs > 0 &&
m_value >= std::numeric_limits<int64_t>::min() + rhs) ||
294 (rhs < 0 &&
m_value <= std::numeric_limits<int64_t>::max() + rhs));
307 if (
m_value > std::numeric_limits<int>::max())
308 return std::numeric_limits<int>::max();
309 else if (
m_value < std::numeric_limits<int>::min())
310 return std::numeric_limits<int>::min();
314 std::vector<unsigned char>
getvch()
const 319 static std::vector<unsigned char>
serialize(
const int64_t& value)
322 return std::vector<unsigned char>();
324 std::vector<unsigned char> result;
325 const bool neg = value < 0;
326 uint64_t absvalue = neg ? -value : value;
330 result.push_back(absvalue & 0xff);
344 if (result.back() & 0x80)
345 result.push_back(neg ? 0x80 : 0);
347 result.back() |= 0x80;
353 static int64_t
set_vch(
const std::vector<unsigned char>& vch)
359 for (
size_t i = 0; i != vch.size(); ++i)
360 result |= static_cast<int64_t>(vch[i]) << 8*i;
364 if (vch.back() & 0x80)
365 return -((int64_t)(result & ~(0x80ULL << (8 * (vch.size() - 1)))));
389 if (n == -1 || (n >= 1 && n <= 16))
406 CScript(std::vector<unsigned char>::const_iterator pbegin, std::vector<unsigned char>::const_iterator pend) :
CScriptBase(pbegin, pend) { }
411 template <
typename Stream,
typename Operation>
441 if (opcode < 0 || opcode > 0xff)
442 throw std::runtime_error(
"CScript::operator<<(): invalid opcode");
453 CScript& operator<<(const std::vector<unsigned char>& b)
459 else if (b.size() <= 0xff)
464 else if (b.size() <= 0xffff)
468 WriteLE16(_data, b.size());
469 insert(
end(), _data, _data +
sizeof(_data));
475 WriteLE32(_data, b.size());
476 insert(
end(), _data, _data +
sizeof(_data));
486 assert(!
"Warning: Pushing a CScript onto a CScript with << is probably not intended, use + to concatenate!");
507 assert(opcode >=
OP_1 && opcode <=
OP_16);
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;
587 #endif // BITCOIN_SCRIPT_SCRIPT_H
unsigned int GetSigOpCount(bool fAccurate) const
Pre-version-0.6, Bitcoin always counted CHECKMULTISIGs as 20 sigops.
static int64_t set_vch(const std::vector< unsigned char > &vch)
static int DecodeOP_N(opcodetype opcode)
Encode/decode small integers:
iterator insert(iterator pos, const T &value)
bool GetOp(const_iterator &pc, opcodetype &opcodeRet, std::vector< unsigned char > &vchRet) const
bool operator<(const int64_t &rhs) const
virtual ~CReserveScript()
CScriptNum(const int64_t &n)
Numeric opcodes (OP_1ADD, etc) are restricted to operating on 4-byte integers.
bool IsPayToScriptHash() const
CScriptNum & operator-=(const int64_t &rhs)
UniValue ret(UniValue::VARR)
CScriptNum operator &(const int64_t &rhs) const
CScript & push_int64(int64_t n)
std::vector< std::vector< unsigned char > > stack
bool HasValidOps() const
Check if the script contains valid OP_CODES.
bool IsWitnessProgram(int &version, std::vector< unsigned char > &program) const
friend CScript operator+(const CScript &a, const CScript &b)
bool operator<=(const int64_t &rhs) const
#define READWRITEAS(type, obj)
CScriptNum & operator=(const int64_t &rhs)
CScript(const std::vector< unsigned char > &b)
static std::vector< unsigned char > serialize(const int64_t &value)
const char * GetOpName(opcodetype opcode)
CScriptNum & operator+=(const CScriptNum &rhs)
bool IsUnspendable() const
Returns whether the script is guaranteed to fail at execution, regardless of the initial stack...
CScript & operator<<(const CScriptNum &b)
CScript & operator<<(opcodetype opcode)
void push_back(const T &value)
opcodetype
Script opcodes.
CScript(const CScriptNum &b)
bool operator==(const CScriptNum &rhs) const
CScript & operator<<(const CScript &b)
CScriptNum operator+(const int64_t &rhs) const
static const size_t nDefaultMaxNumSize
bool operator!=(const int64_t &rhs) const
CScriptNum operator-() const
prevector< 28, unsigned char > CScriptBase
We use a prevector for the script to reduce the considerable memory overhead of vectors in cases wher...
bool operator>=(const CScriptNum &rhs) const
CScriptNum operator+(const CScriptNum &rhs) const
CScript(const unsigned char *pbegin, const unsigned char *pend)
std::vector< unsigned char > getvch() const
scriptnum_error(const std::string &str)
CScriptNum(const std::vector< unsigned char > &vch, bool fRequireMinimal, const size_t nMaxNumSize=nDefaultMaxNumSize)
bool operator>(const int64_t &rhs) const
CScriptNum & operator &=(const CScriptNum &rhs)
Implements a drop-in replacement for std::vector<T> which stores up to N elements directly (without h...
bool GetScriptOp(CScriptBase::const_iterator &pc, CScriptBase::const_iterator end, opcodetype &opcodeRet, std::vector< unsigned char > *pvchRet)
void reserve(size_type new_capacity)
CScriptNum & operator-=(const CScriptNum &rhs)
CScriptNum operator-(const CScriptNum &rhs) const
CScriptNum operator-(const int64_t &rhs) const
CScript(const_iterator pbegin, const_iterator pend)
static opcodetype EncodeOP_N(int n)
Serialized script, used inside transaction inputs and outputs.
CScript & operator+=(const CScript &b)
bool GetOp(const_iterator &pc, opcodetype &opcodeRet) const
CScript & operator<<(int64_t b)
virtual void KeepScript()
CScriptNum & operator+=(const int64_t &rhs)
void SerializationOp(Stream &s, Operation ser_action)
std::string ToString() const
CScript(std::vector< unsigned char >::const_iterator pbegin, std::vector< unsigned char >::const_iterator pend)
bool operator==(const int64_t &rhs) const
bool operator>=(const int64_t &rhs) const
bool IsPayToWitnessScriptHash() const
bool operator!=(const CScriptNum &rhs) const
std::vector< unsigned char > ToByteVector(const T &in)
bool operator<=(const CScriptNum &rhs) const