class RuboCop::Cop::Style::NestedParenthesizedCalls


method1(foo arg)
# good
@example AllowedMethods: [foo]
method1(method2 arg)
# bad
method1(method2(arg))
# good
@example
These are customizable with ‘AllowedMethods` option.
`respond_to`, and `start_with` methods are allowed by default.
`be_truthy`, `be_within`, `eq`, `eql`, `end_with`, `include`, `match`, `raise_error`,
`be`, `be_a`, `be_an`, `be_between`, `be_falsey`, `be_kind_of`, `be_instance_of`,
of a parenthesized method call.
Checks for unparenthesized method calls in the argument list

def self.autocorrect_incompatible_with

def self.autocorrect_incompatible_with
  [Style::MethodCallWithArgsParentheses]
end

def allowed?(send_node)

def allowed?(send_node)
  send_node.parent.arguments.one? &&
    allowed_method?(send_node.method_name) &&
    send_node.arguments.one?
end

def allowed_omission?(send_node)

def allowed_omission?(send_node)
  !send_node.arguments? || send_node.parenthesized? ||
    send_node.setter_method? || send_node.operator_method? ||
    allowed?(send_node)
end

def autocorrect(corrector, nested)

def autocorrect(corrector, nested)
  first_arg = nested.first_argument.source_range
  last_arg = nested.last_argument.source_range
  leading_space =
    range_with_surrounding_space(first_arg.begin,
                                 side: :left,
                                 whitespace: true,
                                 continuations: true)
  corrector.replace(leading_space, '(')
  corrector.insert_after(last_arg, ')')
end

def on_send(node)

def on_send(node)
  return unless node.parenthesized?
  node.each_child_node(:call) do |nested|
    next if allowed_omission?(nested)
    message = format(MSG, source: nested.source)
    add_offense(nested, message: message) do |corrector|
      autocorrect(corrector, nested)
    end
  end
end