Branch data Line data Source code
1 : : // Copyright (c) 2009-2010 Satoshi Nakamoto
2 : : // Copyright (c) 2009-2020 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 : : #include <script/script_error.h>
7 : :
8 : : #include <string>
9 : :
10 : 138256 : std::string ScriptErrorString(const ScriptError serror)
11 : : {
12 [ + + + + : 138256 : switch (serror)
+ + - + +
- + - - +
+ + - + +
+ + + + +
+ + + - +
- + + + +
+ + + + +
+ - + + +
+ + + + +
+ + + + ]
13 : : {
14 : 75178 : case SCRIPT_ERR_OK:
15 : 75178 : return "No error";
16 : 505 : case SCRIPT_ERR_EVAL_FALSE:
17 : 505 : return "Script evaluated without error but finished with a false/empty top stack element";
18 : 26 : case SCRIPT_ERR_VERIFY:
19 : 26 : return "Script failed an OP_VERIFY operation";
20 : 1 : case SCRIPT_ERR_EQUALVERIFY:
21 : 1 : return "Script failed an OP_EQUALVERIFY operation";
22 : 43 : case SCRIPT_ERR_CHECKMULTISIGVERIFY:
23 : 43 : return "Script failed an OP_CHECKMULTISIGVERIFY operation";
24 : 181 : case SCRIPT_ERR_CHECKSIGVERIFY:
25 : 181 : return "Script failed an OP_CHECKSIGVERIFY operation";
26 : 0 : case SCRIPT_ERR_NUMEQUALVERIFY:
27 : 0 : return "Script failed an OP_NUMEQUALVERIFY operation";
28 : 2 : case SCRIPT_ERR_SCRIPT_SIZE:
29 : 2 : return "Script is too big";
30 : 344 : case SCRIPT_ERR_PUSH_SIZE:
31 : 344 : return "Push value size limit exceeded";
32 : 0 : case SCRIPT_ERR_OP_COUNT:
33 : 0 : return "Operation limit exceeded";
34 : 582 : case SCRIPT_ERR_STACK_SIZE:
35 : 582 : return "Stack size limit exceeded";
36 : 0 : case SCRIPT_ERR_SIG_COUNT:
37 : 0 : return "Signature count negative or greater than pubkey count";
38 : 0 : case SCRIPT_ERR_PUBKEY_COUNT:
39 : 0 : return "Pubkey count negative or limit exceeded";
40 : 461 : case SCRIPT_ERR_BAD_OPCODE:
41 : 461 : return "Opcode missing or not understood";
42 : 60 : case SCRIPT_ERR_DISABLED_OPCODE:
43 : 60 : return "Attempted to use a disabled opcode";
44 : 9028 : case SCRIPT_ERR_INVALID_STACK_OPERATION:
45 : 9028 : return "Operation not valid with the current stack size";
46 : 0 : case SCRIPT_ERR_INVALID_ALTSTACK_OPERATION:
47 : 0 : return "Operation not valid with the current altstack size";
48 : 539 : case SCRIPT_ERR_OP_RETURN:
49 : 539 : return "OP_RETURN was encountered";
50 : 47 : case SCRIPT_ERR_UNBALANCED_CONDITIONAL:
51 : 47 : return "Invalid OP_IF construction";
52 : 208 : case SCRIPT_ERR_NEGATIVE_LOCKTIME:
53 : 208 : return "Negative locktime";
54 : 11245 : case SCRIPT_ERR_UNSATISFIED_LOCKTIME:
55 : 11245 : return "Locktime requirement not satisfied";
56 : 32 : case SCRIPT_ERR_SIG_HASHTYPE:
57 : 32 : return "Signature hash type missing or not understood";
58 : 8921 : case SCRIPT_ERR_SIG_DER:
59 : 8921 : return "Non-canonical DER signature";
60 : 14 : case SCRIPT_ERR_MINIMALDATA:
61 : 14 : return "Data push larger than necessary";
62 : 130 : case SCRIPT_ERR_SIG_PUSHONLY:
63 : 130 : return "Only push operators allowed in signatures";
64 : 107 : case SCRIPT_ERR_SIG_HIGH_S:
65 : 107 : return "Non-canonical signature: S value is unnecessarily high";
66 : 73 : case SCRIPT_ERR_SIG_NULLDUMMY:
67 : 73 : return "Dummy CHECKMULTISIG argument must be zero";
68 : 0 : case SCRIPT_ERR_MINIMALIF:
69 : 0 : return "OP_IF/NOTIF argument must be minimal";
70 : 133 : case SCRIPT_ERR_SIG_NULLFAIL:
71 : 133 : return "Signature must be zero for failed CHECK(MULTI)SIG operation";
72 : 0 : case SCRIPT_ERR_DISCOURAGE_UPGRADABLE_NOPS:
73 : 0 : return "NOPx reserved for soft-fork upgrades";
74 : 206 : case SCRIPT_ERR_DISCOURAGE_UPGRADABLE_WITNESS_PROGRAM:
75 : 206 : return "Witness version reserved for soft-fork upgrades";
76 : 502 : case SCRIPT_ERR_DISCOURAGE_UPGRADABLE_TAPROOT_VERSION:
77 : 502 : return "Taproot version reserved for soft-fork upgrades";
78 : 591 : case SCRIPT_ERR_DISCOURAGE_OP_SUCCESS:
79 : 591 : return "OP_SUCCESSx reserved for soft-fork upgrades";
80 : 3 : case SCRIPT_ERR_DISCOURAGE_UPGRADABLE_PUBKEYTYPE:
81 : 3 : return "Public key version reserved for soft-fork upgrades";
82 : 16 : case SCRIPT_ERR_PUBKEYTYPE:
83 : 16 : return "Public key is neither compressed or uncompressed";
84 : 569 : case SCRIPT_ERR_CLEANSTACK:
85 : 569 : return "Stack size must be exactly one after execution";
86 : 86 : case SCRIPT_ERR_WITNESS_PROGRAM_WRONG_LENGTH:
87 : 86 : return "Witness program has incorrect length";
88 : 2251 : case SCRIPT_ERR_WITNESS_PROGRAM_WITNESS_EMPTY:
89 : 2251 : return "Witness program was passed an empty witness";
90 : 24597 : case SCRIPT_ERR_WITNESS_PROGRAM_MISMATCH:
91 : 24597 : return "Witness program hash mismatch";
92 : 46 : case SCRIPT_ERR_WITNESS_MALLEATED:
93 : 46 : return "Witness requires empty scriptSig";
94 : 0 : case SCRIPT_ERR_WITNESS_MALLEATED_P2SH:
95 : 0 : return "Witness requires only-redeemscript scriptSig";
96 : 4 : case SCRIPT_ERR_WITNESS_UNEXPECTED:
97 : 4 : return "Witness provided for non-witness script";
98 : 23 : case SCRIPT_ERR_WITNESS_PUBKEYTYPE:
99 : 23 : return "Using non-compressed keys in segwit";
100 : 28 : case SCRIPT_ERR_SCHNORR_SIG_SIZE:
101 : 28 : return "Invalid Schnorr signature size";
102 : 708 : case SCRIPT_ERR_SCHNORR_SIG_HASHTYPE:
103 : 708 : return "Invalid Schnorr signature hash type";
104 : 87 : case SCRIPT_ERR_SCHNORR_SIG:
105 : 87 : return "Invalid Schnorr signature";
106 : 8 : case SCRIPT_ERR_TAPROOT_WRONG_CONTROL_SIZE:
107 : 8 : return "Invalid Taproot control block size";
108 : 50 : case SCRIPT_ERR_TAPSCRIPT_VALIDATION_WEIGHT:
109 : 50 : return "Too much signature validation relative to witness weight";
110 : 3 : case SCRIPT_ERR_TAPSCRIPT_CHECKMULTISIG:
111 : 3 : return "OP_CHECKMULTISIG(VERIFY) is not available in tapscript";
112 : 5 : case SCRIPT_ERR_TAPSCRIPT_MINIMALIF:
113 : 5 : return "OP_IF/NOTIF argument must be minimal in tapscript";
114 : 307 : case SCRIPT_ERR_OP_CODESEPARATOR:
115 : 307 : return "Using OP_CODESEPARATOR in non-witness script";
116 : 215 : case SCRIPT_ERR_SIG_FINDANDDELETE:
117 : 215 : return "Signature is found in scriptCode";
118 : 91 : case SCRIPT_ERR_UNKNOWN_ERROR:
119 : 91 : case SCRIPT_ERR_ERROR_COUNT:
120 : 91 : default: break;
121 : : }
122 : 91 : return "unknown error";
123 : : }
|