Sha256: 727c2fc4a9d40a7a77587e0fc4dc752ffbaec5c5df2538d950a1c0005947c766
Contents?: true
Size: 1.54 KB
Versions: 1
Compression:
Stored size: 1.54 KB
Contents
# frozen_string_literal: true module RuboCop module Cop module Metrics # This cop checks if the length a class exceeds some maximum value. # Comment lines can optionally be ignored. # The maximum allowed length is configurable. # # You can set literals you want to fold with `CountAsOne`. # Available are: 'array', 'hash', and 'heredoc'. Each literal # will be counted as one line regardless of its actual size. # # @example CountAsOne: ['array', 'heredoc'] # # class Foo # ARRAY = [ # +1 # 1, # 2 # ] # # HASH = { # +3 # key: 'value' # } # # MSG = <<~HEREDOC # +1 # Heredoc # content. # HEREDOC # end # 5 points # # # NOTE: This cop also applies for `Struct` definitions. class ClassLength < Base include CodeLength def on_class(node) check_code_length(node) end def on_casgn(node) if node.parent&.assignment? block_node = node.parent.children[1] else _scope, _name, block_node = *node end check_code_length(block_node) if block_node.class_definition? end private def message(length, max_length) format('Class has too many lines. [%<length>d/%<max>d]', length: length, max: max_length) end end end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
rubocop-0.93.0 | lib/rubocop/cop/metrics/class_length.rb |