-
Notifications
You must be signed in to change notification settings - Fork 1
Expand file tree
/
Copy patherrors.go
More file actions
126 lines (103 loc) · 3.09 KB
/
errors.go
File metadata and controls
126 lines (103 loc) · 3.09 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
package kernel
var (
ErrKernelInstantiate = &kernelError{"Failed to instantiate btck object"}
ErrKernelIndexOutOfBounds = &kernelError{"Index out of bounds"}
ErrVerifyScriptVerifyTxInputIndex = &ScriptVerifyError{"Transaction input index out of range"}
ErrVerifyScriptVerifyInvalidFlags = &ScriptVerifyError{"Invalid script verification flags"}
ErrVerifyScriptVerifyInvalidFlagsCombination = &ScriptVerifyError{"Invalid combination of script verification flags"}
ErrVerifyScriptVerifySpentOutputsRequired = &ScriptVerifyError{"Spent outputs required for verification"}
)
// check panics if ptr is nil, otherwise returns ptr unchanged; used when C calls are not expected to return null
func check[T any](ptr T) T {
if any(ptr) == nil {
panic(ErrKernelInstantiate)
}
return ptr
}
type KernelError interface {
Error() string
isKernelError()
}
type kernelError struct {
Msg string
}
func (e *kernelError) Error() string {
return e.Msg
}
func (e *kernelError) isKernelError() {}
// InternalError is returned when a call to the underlying library fails.
type InternalError struct {
Msg string
}
func (e *InternalError) Error() string {
return e.Msg
}
func (e *InternalError) isKernelError() {}
type SerializationError struct {
Msg string
}
func (e *SerializationError) Error() string {
return e.Msg
}
func (e *SerializationError) isKernelError() {}
// ScriptVerifyError represents errors that prevent script verification from executing.
type ScriptVerifyError struct {
Msg string
}
func (e *ScriptVerifyError) Error() string {
return "Script verification failed: " + e.Msg
}
func (e *ScriptVerifyError) isKernelError() {}
// BlockValidationError represents a block or header validation failure with detailed state information.
type BlockValidationError struct {
State *BlockValidationState
}
func (e *BlockValidationError) Error() string {
if e.State == nil {
return "Block validation failed"
}
mode := e.State.ValidationMode()
result := e.State.ValidationResult()
return "Block validation failed: mode=" + validationModeString(mode) + ", result=" + blockValidationResultString(result)
}
func (e *BlockValidationError) isKernelError() {}
// GetState returns the validation state containing detailed error information.
func (e *BlockValidationError) GetState() *BlockValidationState {
return e.State
}
func validationModeString(mode ValidationMode) string {
switch mode {
case ValidationStateValid:
return "valid"
case ValidationStateInvalid:
return "invalid"
case ValidationStateError:
return "error"
default:
return "unknown"
}
}
func blockValidationResultString(result BlockValidationResult) string {
switch result {
case BlockResultUnset:
return "unset"
case BlockConsensus:
return "consensus"
case BlockCachedInvalid:
return "cached_invalid"
case BlockInvalidHeader:
return "invalid_header"
case BlockMutated:
return "mutated"
case BlockMissingPrev:
return "missing_prev"
case BlockInvalidPrev:
return "invalid_prev"
case BlockTimeFuture:
return "time_future"
case BlockHeaderLowWork:
return "header_low_work"
default:
return "unknown"
}
}