Branch data Line data Source code
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 : :
6 : : #include <script/script_error.h>
7 : :
8 : : #include <string>
9 : :
10 : 257346 : std::string ScriptErrorString(const ScriptError serror)
11 : : {
12 [ + + + + : 257346 : switch (serror)
+ + + + +
+ + + + +
+ + + + +
+ + + + +
+ + + + +
+ + + + +
+ + + + +
+ + + + +
+ + + + +
+ + + + +
+ ]
13 : : {
14 : 1571 : case SCRIPT_ERR_OK:
15 : 1571 : return "No error";
16 : 15903 : case SCRIPT_ERR_EVAL_FALSE:
17 : 15903 : return "Script evaluated without error but finished with a false/empty top stack element";
18 : 1573 : case SCRIPT_ERR_VERIFY:
19 : 1573 : return "Script failed an OP_VERIFY operation";
20 : 2035 : case SCRIPT_ERR_EQUALVERIFY:
21 : 2035 : return "Script failed an OP_EQUALVERIFY operation";
22 : 101 : case SCRIPT_ERR_CHECKMULTISIGVERIFY:
23 : 101 : return "Script failed an OP_CHECKMULTISIGVERIFY operation";
24 : 1544 : case SCRIPT_ERR_CHECKSIGVERIFY:
25 : 1544 : return "Script failed an OP_CHECKSIGVERIFY operation";
26 : 1583 : case SCRIPT_ERR_NUMEQUALVERIFY:
27 : 1583 : return "Script failed an OP_NUMEQUALVERIFY operation";
28 : 417 : case SCRIPT_ERR_SCRIPT_SIZE:
29 : 417 : return "Script is too big";
30 : 1849 : case SCRIPT_ERR_PUSH_SIZE:
31 : 1849 : return "Push value size limit exceeded";
32 : 3668 : case SCRIPT_ERR_OP_COUNT:
33 : 3668 : return "Operation limit exceeded";
34 : 1606 : case SCRIPT_ERR_STACK_SIZE:
35 : 1606 : return "Stack size limit exceeded";
36 : 2514 : case SCRIPT_ERR_SIG_COUNT:
37 : 2514 : return "Signature count negative or greater than pubkey count";
38 : 2458 : case SCRIPT_ERR_PUBKEY_COUNT:
39 : 2458 : return "Pubkey count negative or limit exceeded";
40 : 22039 : case SCRIPT_ERR_BAD_OPCODE:
41 : 22039 : return "Opcode missing or not understood";
42 : 14305 : case SCRIPT_ERR_DISABLED_OPCODE:
43 : 14305 : return "Attempted to use a disabled opcode";
44 : 18122 : case SCRIPT_ERR_INVALID_STACK_OPERATION:
45 : 18122 : return "Operation not valid with the current stack size";
46 : 1709 : case SCRIPT_ERR_INVALID_ALTSTACK_OPERATION:
47 : 1709 : return "Operation not valid with the current altstack size";
48 : 4909 : case SCRIPT_ERR_OP_RETURN:
49 : 4909 : return "OP_RETURN was encountered";
50 : 9651 : case SCRIPT_ERR_UNBALANCED_CONDITIONAL:
51 : 9651 : return "Invalid OP_IF construction";
52 : 2501 : case SCRIPT_ERR_NEGATIVE_LOCKTIME:
53 : 2501 : return "Negative locktime";
54 : 10789 : case SCRIPT_ERR_UNSATISFIED_LOCKTIME:
55 : 10789 : return "Locktime requirement not satisfied";
56 : 18934 : case SCRIPT_ERR_SIG_HASHTYPE:
57 : 18934 : return "Signature hash type missing or not understood";
58 : 5828 : case SCRIPT_ERR_SIG_DER:
59 : 5828 : return "Non-canonical DER signature";
60 : 3725 : case SCRIPT_ERR_MINIMALDATA:
61 : 3725 : return "Data push larger than necessary";
62 : 209 : case SCRIPT_ERR_SIG_PUSHONLY:
63 : 209 : return "Only push operators allowed in signatures";
64 : 15 : case SCRIPT_ERR_SIG_HIGH_S:
65 : 15 : return "Non-canonical signature: S value is unnecessarily high";
66 : 1900 : case SCRIPT_ERR_SIG_NULLDUMMY:
67 : 1900 : return "Dummy CHECKMULTISIG argument must be zero";
68 : 93 : case SCRIPT_ERR_MINIMALIF:
69 : 93 : return "OP_IF/NOTIF argument must be minimal";
70 : 170 : case SCRIPT_ERR_SIG_NULLFAIL:
71 : 170 : return "Signature must be zero for failed CHECK(MULTI)SIG operation";
72 : 5159 : case SCRIPT_ERR_DISCOURAGE_UPGRADABLE_NOPS:
73 : 5159 : return "NOPx reserved for soft-fork upgrades";
74 : 4354 : case SCRIPT_ERR_DISCOURAGE_UPGRADABLE_WITNESS_PROGRAM:
75 : 4354 : return "Witness version reserved for soft-fork upgrades";
76 : 17 : case SCRIPT_ERR_DISCOURAGE_UPGRADABLE_TAPROOT_VERSION:
77 : 17 : return "Taproot version reserved for soft-fork upgrades";
78 : 121 : case SCRIPT_ERR_DISCOURAGE_OP_SUCCESS:
79 : 121 : return "OP_SUCCESSx reserved for soft-fork upgrades";
80 : 11 : case SCRIPT_ERR_DISCOURAGE_UPGRADABLE_PUBKEYTYPE:
81 : 11 : return "Public key version reserved for soft-fork upgrades";
82 : 5908 : case SCRIPT_ERR_PUBKEYTYPE:
83 : 5908 : return "Public key is neither compressed or uncompressed";
84 : 7294 : case SCRIPT_ERR_CLEANSTACK:
85 : 7294 : return "Stack size must be exactly one after execution";
86 : 1704 : case SCRIPT_ERR_WITNESS_PROGRAM_WRONG_LENGTH:
87 : 1704 : return "Witness program has incorrect length";
88 : 25081 : case SCRIPT_ERR_WITNESS_PROGRAM_WITNESS_EMPTY:
89 : 25081 : return "Witness program was passed an empty witness";
90 : 13225 : case SCRIPT_ERR_WITNESS_PROGRAM_MISMATCH:
91 : 13225 : return "Witness program hash mismatch";
92 : 8945 : case SCRIPT_ERR_WITNESS_MALLEATED:
93 : 8945 : return "Witness requires empty scriptSig";
94 : 8 : case SCRIPT_ERR_WITNESS_MALLEATED_P2SH:
95 : 8 : return "Witness requires only-redeemscript scriptSig";
96 : 1293 : case SCRIPT_ERR_WITNESS_UNEXPECTED:
97 : 1293 : return "Witness provided for non-witness script";
98 : 8 : case SCRIPT_ERR_WITNESS_PUBKEYTYPE:
99 : 8 : return "Using non-compressed keys in segwit";
100 : 6402 : case SCRIPT_ERR_SCHNORR_SIG_SIZE:
101 : 6402 : return "Invalid Schnorr signature size";
102 : 292 : case SCRIPT_ERR_SCHNORR_SIG_HASHTYPE:
103 : 292 : return "Invalid Schnorr signature hash type";
104 : 2222 : case SCRIPT_ERR_SCHNORR_SIG:
105 : 2222 : return "Invalid Schnorr signature";
106 : 3055 : case SCRIPT_ERR_TAPROOT_WRONG_CONTROL_SIZE:
107 : 3055 : return "Invalid Taproot control block size";
108 : 22 : case SCRIPT_ERR_TAPSCRIPT_VALIDATION_WEIGHT:
109 : 22 : return "Too much signature validation relative to witness weight";
110 : 12 : case SCRIPT_ERR_TAPSCRIPT_CHECKMULTISIG:
111 : 12 : return "OP_CHECKMULTISIG(VERIFY) is not available in tapscript";
112 : 8 : case SCRIPT_ERR_TAPSCRIPT_MINIMALIF:
113 : 8 : return "OP_IF/NOTIF argument must be minimal in tapscript";
114 : 5 : case SCRIPT_ERR_TAPSCRIPT_EMPTY_PUBKEY:
115 : 5 : return "Empty public key in tapscript";
116 : 1569 : case SCRIPT_ERR_OP_CODESEPARATOR:
117 : 1569 : return "Using OP_CODESEPARATOR in non-witness script";
118 : 6647 : case SCRIPT_ERR_SIG_FINDANDDELETE:
119 : 6647 : return "Signature is found in scriptCode";
120 : 12223 : case SCRIPT_ERR_SCRIPTNUM:
121 : 12223 : return "Script number overflowed or is non-minimally encoded";
122 : : case SCRIPT_ERR_UNKNOWN_ERROR:
123 : : case SCRIPT_ERR_ERROR_COUNT:
124 : : break;
125 : : } // no default case, so the compiler can warn about missing cases
126 : 40 : return "unknown error";
127 : : }
|