Class: RuboCop::Cop::Layout::BlockEndNewline
- Includes:
- Alignment
- Defined in:
- lib/rubocop/cop/layout/block_end_newline.rb
Overview
This cop checks whether the end statement of a do..end block is on its own line.
Constant Summary collapse
- MSG =
'Expression at %<line>d, %<column>d should be on its own line.'
Constants inherited from Base
Instance Attribute Summary
Attributes inherited from Cop
Attributes inherited from Base
Instance Method Summary collapse
Methods inherited from Cop
#add_offense, all, #corrections, #find_location, #highlights, joining_forces, #messages, #on_investigation_end, #on_new_investigation, #parse, qualified_cop_name, registry, support_autocorrect?, #support_autocorrect?
Methods inherited from Base
#add_global_offense, #add_offense, autocorrect_incompatible_with, badge, callbacks_needed, #callbacks_needed, #config_to_allow_offenses, #config_to_allow_offenses=, #cop_config, cop_name, #cop_name, department, documentation_url, exclude_from_registry, #excluded_file?, #external_dependency_checksum, inherited, #initialize, joining_forces, lint?, match?, #offenses, #on_investigation_end, #on_new_investigation, #on_other_file, #ready, #relevant_file?, support_autocorrect?, support_multiple_source?, #target_rails_version, #target_ruby_version
Methods included from ExcludeLimit
Methods included from AutocorrectLogic
#autocorrect?, #autocorrect_enabled?, #autocorrect_requested?, #correctable?, #disable_uncorrectable?, #safe_autocorrect?
Methods included from IgnoredNode
#ignore_node, #ignored_node?, #part_of_ignored_node?
Methods included from Util
Constructor Details
This class inherits a constructor from RuboCop::Cop::Base
Instance Method Details
#autocorrect(node) ⇒ Object
41 42 43 44 45 46 |
# File 'lib/rubocop/cop/layout/block_end_newline.rb', line 41 def autocorrect(node) lambda do |corrector| corrector.replace(delimiter_range(node), "\n#{node.loc.end.source}#{offset(node)}") end end |
#on_block(node) ⇒ Object
32 33 34 35 36 37 38 39 |
# File 'lib/rubocop/cop/layout/block_end_newline.rb', line 32 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 |