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