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.message =~ /You have a nil object when you didn't expect it/) ||
        (e.message =~ /undefined method `.*?' for nil:NilClass/) || (e.message =~ /^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)