lib/rubocop/cop/style/multiline_array_brace_layout.rb



# frozen_string_literal: true

module RuboCop
  module Cop
    module Style
      # This cop checks that the closing brace in an array literal is either
      # on the same line as the last array element, or a new line.
      #
      # When using the `symmetrical` (default) style:
      #
      # If an array's opening brace is on the same line as the first element
      # of the array, then the closing brace should be on the same line as
      # the last element of the array.
      #
      # If an array's opening brace is on the line above the first element
      # of the array, then the closing brace should be on the line below
      # the last element of the array.
      #
      # When using the `new_line` style:
      #
      # The closing brace of a multi-line array literal must be on the line
      # after the last element of the array.
      #
      # When using the `same_line` style:
      #
      # The closing brace of a multi-line array literal must be on the same
      # line as the last element of the array.
      #
      # @example
      #
      #     # symmetrical: bad
      #     # new_line: good
      #     # same_line: bad
      #     [ :a,
      #       :b
      #     ]
      #
      #     # symmetrical: bad
      #     # new_line: bad
      #     # same_line: good
      #     [
      #       :a,
      #       :b ]
      #
      #     # symmetrical: good
      #     # new_line: bad
      #     # same_line: good
      #     [ :a,
      #       :b ]
      #
      #     # symmetrical: good
      #     # new_line: good
      #     # same_line: bad
      #     [
      #       :a,
      #       :b
      #     ]
      class MultilineArrayBraceLayout < Cop
        include MultilineLiteralBraceLayout

        SAME_LINE_MESSAGE = 'Closing array brace must be on the same line as ' \
          'the last array element when opening brace is on the same line as ' \
          'the first array element.'.freeze

        NEW_LINE_MESSAGE = 'Closing array brace must be on the line after ' \
          'the last array element when opening brace is on a separate line ' \
          'from the first array element.'.freeze

        ALWAYS_NEW_LINE_MESSAGE = 'Closing array brace must be on the line ' \
          'after the last array element.'.freeze

        ALWAYS_SAME_LINE_MESSAGE = 'Closing array brace must be on the same ' \
          'line as teh last array element.'.freeze

        def on_array(node)
          check_brace_layout(node)
        end
      end
    end
  end
end