class RuboCop::Cop::Layout::SpaceInLambdaLiteral

a = -> (x, y) { x + y }
# good
a = ->(x, y) { x + y }
# bad
@example EnforcedStyle: require_space
a = ->(x, y) { x + y }
# good
a = -> (x, y) { x + y }
# bad
@example EnforcedStyle: require_no_space (default)
brace in lambda literals.
This cop checks for spaces between -> and opening parameter

def args?(lambda_node)

def args?(lambda_node)
  _call, args, _body = *lambda_node.parent
  !args.children.empty?
end

def arrow_form?(lambda_node)

def arrow_form?(lambda_node)
  lambda_node.loc.selector.source == ARROW
end

def arrow_lambda_with_args?(node)

def arrow_lambda_with_args?(node)
  lambda_node?(node) && arrow_form?(node) && args?(node)
end

def autocorrect(lambda_node)

def autocorrect(lambda_node)
  children = lambda_node.parent.children
  lambda do |corrector|
    if style == :require_space
      corrector.insert_before(children[1].source_range, ' ')
    else
      space_range = range_between(children[0].source_range.end_pos,
                                  children[1].source_range.begin_pos)
      corrector.remove(space_range)
    end
  end
end

def lambda_node?(node)

def lambda_node?(node)
  receiver, call = *node
  receiver.nil? && call == :lambda
end

def on_send(node)

def on_send(node)
  return unless arrow_lambda_with_args?(node)
  if style == :require_space && !space_after_arrow?(node)
    add_offense(node,
                location: node.parent.loc.expression,
                message: MSG_REQUIRE_SPACE)
  elsif style == :require_no_space && space_after_arrow?(node)
    add_offense(node,
                location: node.parent.loc.expression,
                message: MSG_REQUIRE_NO_SPACE)
  end
end

def space_after_arrow?(lambda_node)

def space_after_arrow?(lambda_node)
  arrow = lambda_node.parent.children[0]
  parentheses = lambda_node.parent.children[1]
  parentheses.source_range.begin_pos - arrow.source_range.end_pos > 0
end