ignore_nil {}
DESCRIPTION
ignore_nil lets you happily ignore nil methods on long method chains. Keeps code pretty and much safer than “rescue nil”, since it only catches NoMethodError on nil objects.
ignore_nil {} will either return the last thing evaluated in the block, or nil if a NoMethodError is raised calling a method on a nil object. Any other exceptions raised in the block are not handled, and left for the application to resolve. More details below.
INSTALLATION
as a gem:
sudo gem install ignore_nil
as a plugin:
script/plugin install git://github.com/ssoroka/ignore_nil.git
USAGE
ignore_nil { user.profile.photo }
which is much cleaner than, say,
user && user.profile && user.profile.photo
and much much safer than
user.profile.photo rescue nil
which will eat any error, even if it’s one you really want to see.
TELL ME MORE!
The plugin is really rather simple; here’s the ignore_nil method:
def ignore_nil(&block)
begin
yield
rescue NoMethodError, RuntimeError => e
if (e. =~ /You have a nil object when you didn't expect it/) ||
(e. =~ /undefined method `.*?' for nil:NilClass/) || (e. =~ /^Called id for nil/)
return nil
else
raise e
end
end
end
What’s interesting about this is it catches both NoMethodError and RuntimeError, both of which can occur if a method unexpectedly returned nil and you called a method on it, but ONLY if the error message matches! This means legitimate NoMethodError and RuntimeError messages will not be bothered by ignore_nil, and will still raise in your application as you expect.
I’ve used this in a production application since about mid/late 2008, I’d consider it very stable. Feedback welcome!
AUTHOR
Steven Soroka [@ssoroka](www.twitter.com/ssoroka) [blog.stevensoroka.ca](http://blog.stevensoroka.ca)