class RuboCop::Cop::Style::Not


x = !something
# good
x = (not something)
# bad - parentheses are required because of op precedence
@example
This cop checks for uses of the keyword ‘not` instead of `!`.

def correct_opposite_method(corrector, range, child)

def correct_opposite_method(corrector, range, child)
  corrector.remove(range)
  corrector.replace(child.loc.selector, OPPOSITE_METHODS[child.method_name].to_s)
end

def correct_with_parens(corrector, range, node)

def correct_with_parens(corrector, range, node)
  corrector.replace(range, '!(')
  corrector.insert_after(node, ')')
end

def correct_without_parens(corrector, range)

def correct_without_parens(corrector, range)
  corrector.replace(range, '!')
end

def on_send(node)

def on_send(node)
  return unless node.prefix_not?
  add_offense(node.loc.selector) do |corrector|
    range = range_with_surrounding_space(range: node.loc.selector, side: :right)
    if opposite_method?(node.receiver)
      correct_opposite_method(corrector, range, node.receiver)
    elsif requires_parens?(node.receiver)
      correct_with_parens(corrector, range, node)
    else
      correct_without_parens(corrector, range)
    end
  end
end

def opposite_method?(child)

def opposite_method?(child)
  child.send_type? && OPPOSITE_METHODS.key?(child.method_name)
end

def requires_parens?(child)

def requires_parens?(child)
  child.and_type? || child.or_type? ||
    (child.send_type? && child.binary_operation?) ||
    (child.if_type? && child.ternary?)
end