Module: RuboCop::Cop::MultilineLiteralBraceLayout
- Includes:
- ConfigurableEnforcedStyle
- Included in:
- Style::MultilineArrayBraceLayout, Style::MultilineHashBraceLayout, Style::MultilineMethodCallBraceLayout, Style::MultilineMethodDefinitionBraceLayout
- Defined in:
- lib/rubocop/cop/mixin/multiline_literal_brace_layout.rb
Overview
Common functionality for checking the closing brace of a literal is either on the same line as the last contained elements, or a new line.
Instance Method Summary collapse
Methods included from ConfigurableEnforcedStyle
#alternative_style, #ambiguous_style_detected, #correct_style_detected, #detected_style, #detected_style=, #no_acceptable_style!, #no_acceptable_style?, #opposite_style_detected, #parameter_name, #style, #style_detected, #supported_styles, #unexpected_style_detected
Instance Method Details
#autocorrect(node) ⇒ Object
26 27 28 29 30 31 32 33 34 35 36 37 38 39 |
# File 'lib/rubocop/cop/mixin/multiline_literal_brace_layout.rb', line 26 def autocorrect(node) if closing_brace_on_same_line?(node) lambda do |corrector| corrector.insert_before(node.loc.end, "\n".freeze) end else lambda do |corrector| corrector.remove(range_with_surrounding_space(node.loc.end, :left)) corrector.insert_after(children(node).last.source_range, node.loc.end.source) end end end |
#check_brace_layout(node) ⇒ Object
11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
# File 'lib/rubocop/cop/mixin/multiline_literal_brace_layout.rb', line 11 def check_brace_layout(node) return unless node.loc.begin # Ignore implicit literals. return if children(node).empty? # Ignore empty literals. # If the last node is or contains a conflicting HEREDOC, we don't want # to adjust the brace layout because this will result in invalid code. return if last_line_heredoc?(children(node).last) case style when :symmetrical then handle_symmetrical(node) when :new_line then handle_new_line(node) when :same_line then handle_same_line(node) end end |