Skip to content

Commit

Permalink
Pass an unhandled exception to at_exit block as second argument
Browse files Browse the repository at this point in the history
Follow up crystal-lang#1921

It is better in some ways:

  - it does not need a new exception like `SystemExit`.
  - it does not break compatibility in most cases because block fill up not enough arguments.
  • Loading branch information
makenowjust committed Apr 3, 2018
1 parent 49d722c commit 7d84233
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 3 deletions.
16 changes: 16 additions & 0 deletions spec/std/kernel_spec.cr
Original file line number Diff line number Diff line change
Expand Up @@ -225,4 +225,20 @@ describe "at_exit" do
Unhandled exception: Kaboom!
OUTPUT
end

it "can get unhandled exception in at_exit handler" do
status, _, error = build_and_run <<-CODE
at_exit do |_, ex|
STDERR.puts ex.try &.message
end
raise "Kaboom!"
CODE

status.success?.should be_false
error.should contain <<-OUTPUT
Kaboom!
Unhandled exception: Kaboom!
OUTPUT
end
end
6 changes: 3 additions & 3 deletions src/kernel.cr
Original file line number Diff line number Diff line change
Expand Up @@ -127,7 +127,7 @@ module AtExitHandlers

class_property exception : Exception?

private class_getter(handlers) { [] of Int32 -> }
private class_getter(handlers) { [] of Int32, Exception? -> }

def self.add(handler)
raise "Cannot use at_exit from an at_exit handler" if @@running
Expand All @@ -142,7 +142,7 @@ module AtExitHandlers
# Run the registered handlers in reverse order
while handler = handlers.pop?
begin
handler.call status
handler.call status, exception
rescue handler_ex
STDERR.puts "Error running at_exit handler: #{handler_ex}"
status = 1 if status.zero?
Expand Down Expand Up @@ -180,7 +180,7 @@ end
# ```text
# goodbye cruel world
# ```
def at_exit(&handler : Int32 ->) : Nil
def at_exit(&handler : Int32, Exception? ->) : Nil
AtExitHandlers.add(handler)
end

Expand Down

0 comments on commit 7d84233

Please sign in to comment.