class RuboCop::Cop::Rails::SafeNavigation
foo&.bar { |e| e.baz }
foo&.bar(baz)
foo&.bar
# good
foo.try(:bar) { |e| e.baz }
foo.try(:bar, baz)
foo.try(:bar)
foo.try!(:bar) { |e| e.baz }
foo.try!(:bar, baz)
foo.try!(:bar)
# bad
# ConvertTry: true
foo&.bar { |e| e.baz }
foo&.bar(baz)
foo&.bar
foo.try(:bar) { |e| e.baz }
foo.try(:bar, baz)
foo.try(:bar)
# good
foo.try!(:[], 0)
foo.try!(:bar) { |e| e.baz }
foo.try!(:bar, baz)
foo.try!(:bar)
# bad
# ConvertTry: false
@example
target Ruby version is set to 2.3+
to convert ‘try`. It will convert code to use safe navigation if the
This cop converts usages of `try!` to `&.`. It can also be configured
def autocorrect(node)
def autocorrect(node) _receiver, _try, method_node, *params = *node method = method_node.source[1..-1] range = range_between(node.loc.dot.begin_pos, node.loc.expression.end_pos) lambda do |corrector| corrector.replace(range, replacement(method, params)) end end
def on_send(node)
def on_send(node) try_call(node) do |try_method, method_to_try| return if try_method == :try && !cop_config['ConvertTry'] return unless method_to_try.sym_type? method, = *method_to_try return unless method =~ /\w+[=!?]?/ add_offense(node, :expression, format(MSG, try_method)) end end
def replacement(method, params)
def replacement(method, params) new_params = params.map(&:source).join(', ') if method.end_with?('=') "&.#{method[0...-1]} = #{new_params}" elsif params.empty? "&.#{method}" else "&.#{method}(#{new_params})" end end