Sha256: c72c5cfa5cdec320499acfbd8f93724ee55d49790b77a4d59c8d905bfd9a329d
Contents?: true
Size: 1.47 KB
Versions: 45
Compression:
Stored size: 1.47 KB
Contents
# frozen_string_literal: true module RuboCop module Cop module Layout # This cop checks whether the end statement of a do..end block # is on its own line. # # @example # # bad # blah do |i| # foo(i) end # # # good # blah do |i| # foo(i) # end # # # bad # blah { |i| # foo(i) } # # # good # blah { |i| # foo(i) # } class BlockEndNewline < Cop include Alignment MSG = 'Expression at %<line>d, %<column>d should be on its own line.' def on_block(node) return if node.single_line? # If the end is on its own line, there is no offense return if begins_its_line?(node.loc.end) add_offense(node, location: :end) end def autocorrect(node) lambda do |corrector| corrector.replace(delimiter_range(node), "\n#{node.loc.end.source}#{offset(node)}") end end private def message(node) format(MSG, line: node.loc.end.line, column: node.loc.end.column + 1) end def delimiter_range(node) Parser::Source::Range.new(node.loc.expression.source_buffer, node.children.last.loc.expression.end_pos, node.loc.expression.end_pos) end end end end end
Version data entries
45 entries across 26 versions & 3 rubygems