Sha256: 0e14b4f059c9a0c654dd84b760b7ba0878296b53cc8b8930d365eac0075ccd0a
Contents?: true
Size: 1.82 KB
Versions: 7
Compression:
Stored size: 1.82 KB
Contents
# frozen_string_literal: true module RuboCop module Cop module Metrics # Checks if the length of a method exceeds some maximum value. # Comment lines can optionally be allowed. # The maximum allowed length is configurable. # # You can set constructs you want to fold with `CountAsOne`. # # Available are: 'array', 'hash', 'heredoc', and 'method_call'. # Each construct will be counted as one line regardless of its actual size. # # NOTE: The `ExcludedMethods` and `IgnoredMethods` configuration is # deprecated and only kept for backwards compatibility. # Please use `AllowedMethods` and `AllowedPatterns` instead. # By default, there are no methods to allowed. # # @example CountAsOne: ['array', 'hash', 'heredoc', 'method_call'] # # def m # array = [ # +1 # 1, # 2 # ] # # hash = { # +1 # key: 'value' # } # # <<~HEREDOC # +1 # Heredoc # content. # HEREDOC # # foo( # +1 # 1, # 2 # ) # end # 4 points # class MethodLength < Base include CodeLength include AllowedMethods include AllowedPattern LABEL = 'Method' def on_def(node) return if allowed_method?(node.method_name) || matches_allowed_pattern?(node.method_name) check_code_length(node) end alias on_defs on_def def on_block(node) return unless node.method?(:define_method) check_code_length(node) end alias on_numblock on_block private def cop_label LABEL end end end end end
Version data entries
7 entries across 7 versions & 1 rubygems