From b41f31e4206c1df89362b1a1bb836018de0109a8 Mon Sep 17 00:00:00 2001 From: Elliot Winkler Date: Sat, 18 Jun 2011 16:30:00 -0600 Subject: [PATCH] If running a task for a guard and it borks, don't swallow the error but print the backtrace --- lib/guard.rb | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/lib/guard.rb b/lib/guard.rb index 86fc87e..59e5dae 100644 --- a/lib/guard.rb +++ b/lib/guard.rb @@ -59,11 +59,13 @@ module Guard # fire it if his work leads to a system failure def supervised_task(guard, task_to_supervise, *args) guard.send(task_to_supervise, *args) - rescue Exception - UI.error("#{guard.class.name} guard failed to achieve its <#{task_to_supervise.to_s}> command: #{$!}") + rescue Exception => err + UI.error("#{guard.class.name} guard failed to achieve its <#{task_to_supervise.to_s}> command: #{err}") + warn "#{err.class}: #{err.message}" + warn err.backtrace.join("\n") guards.delete guard UI.info("Guard #{guard.class.name} has just been fired") - return $! + return err end def run