Class: RuboCop::Cop::Style::MultilineHashBraceLayout
- Includes:
- MultilineLiteralBraceLayout
- Defined in:
- lib/rubocop/cop/style/multiline_hash_brace_layout.rb
Overview
This cop checks that the closing brace in a hash literal is either on the same line as the last hash element, or a new line.
When using the ‘symmetrical` (default) style:
If a hash’s opening brace is on the same line as the first element of the hash, then the closing brace should be on the same line as the last element of the hash.
If a hash’s opening brace is on the line above the first element of the hash, then the closing brace should be on the line below the last element of the hash.
When using the ‘new_line` style:
The closing brace of a multi-line hash literal must be on the line after the last element of the hash.
When using the ‘same_line` style:
The closing brace of a multi-line hash literal must be on the same line as the last element of the hash.
Constant Summary collapse
- SAME_LINE_MESSAGE =
'Closing hash brace must be on the same line as ' \ 'the last hash element when opening brace is on the same line as ' \ 'the first hash element.'.freeze
- NEW_LINE_MESSAGE =
'Closing hash brace must be on the line after ' \ 'the last hash element when opening brace is on a separate line ' \ 'from the first hash element.'.freeze
- ALWAYS_NEW_LINE_MESSAGE =
'Closing hash brace must be on the line ' \ 'after the last hash element.'.freeze
- ALWAYS_SAME_LINE_MESSAGE =
'Closing hash brace must be on the same ' \ 'line as the last hash element.'.freeze
Constants included from Util
Util::ASGN_NODES, Util::BYTE_ORDER_MARK, Util::EQUALS_ASGN_NODES, Util::LITERAL_REGEX, Util::OPERATOR_METHODS, Util::SHORTHAND_ASGN_NODES
Instance Attribute Summary
Attributes inherited from Cop
#config, #corrections, #offenses, #processed_source
Instance Method Summary collapse
Methods included from MultilineLiteralBraceLayout
#autocorrect, #check_brace_layout
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
Methods inherited from Cop
#add_offense, all, #config_to_allow_offenses, #config_to_allow_offenses=, #cop_config, cop_name, #cop_name, cop_type, #correct, #debug?, #details, #display_cop_names?, #display_style_guide?, #duplicate_location?, #excluded_file?, #extra_details?, #find_location, #highlights, inherited, #initialize, #join_force?, lint?, match?, #message, #messages, non_rails, #parse, qualified_cop_name, #reference_url, #relevant_file?, #style_guide_url, #target_ruby_version
Methods included from Sexp
Methods included from NodePattern::Macros
#def_node_matcher, #def_node_search, #node_search, #node_search_all, #node_search_body, #node_search_first
Methods included from AutocorrectLogic
#autocorrect?, #autocorrect_enabled?, #autocorrect_requested?, #support_autocorrect?
Methods included from IgnoredNode
#ignore_node, #ignored_node?, #part_of_ignored_node?
Methods included from Util
begins_its_line?, block_length, comment_line?, directions, double_quotes_acceptable?, double_quotes_required?, effective_column, ends_its_line?, escape_string, first_part_of_call_chain, interpret_string_escapes, line_distance, line_range, move_pos, needs_escaping?, numeric_range_size, on_node, operator?, parentheses?, parenthesized_call?, preceed?, range_between, range_with_surrounding_comma, range_with_surrounding_space, same_line?, source_range, strip_quotes, stripped_source_upto, to_string_literal, to_symbol_literal, within_node?
Methods included from PathUtil
absolute?, match_path?, relative_path
Constructor Details
This class inherits a constructor from RuboCop::Cop::Cop
Instance Method Details
#on_hash(node) ⇒ Object
76 77 78 |
# File 'lib/rubocop/cop/style/multiline_hash_brace_layout.rb', line 76 def on_hash(node) check_brace_layout(node) end |