Commit abce025
committed
fix: shell catch nil pointer dereference
When a command expression itself panics (not a shell exit code
failure), RadPanic.ShellResult is nil. The catch handler was
unconditionally dereferencing it, causing a nil pointer crash.
Now checks ShellResult != nil before dereferencing. When nil,
assigns the error value to target variables (matching how
assignment catch handlers work) so the catch block can still
access the error.1 parent 6837175 commit abce025
File tree
2 files changed
+26
-2
lines changed- core
- testing/snapshots/control_flow
2 files changed
+26
-2
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
51 | 51 | | |
52 | 52 | | |
53 | 53 | | |
54 | | - | |
55 | | - | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
56 | 65 | | |
57 | 66 | | |
58 | 67 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
0 commit comments