Sha256: a63308a2a4910969ff36dda8b06a496092e25fc15612cd5c82dd154fb955d14e
Contents?: true
Size: 1.78 KB
Versions: 3
Compression:
Stored size: 1.78 KB
Contents
# frozen_string_literal: true module RuboCop module Cop module Metrics # This cop checks if the length of a block exceeds some maximum value. # Comment lines can optionally be ignored. # The maximum allowed length is configurable. # The cop can be configured to ignore blocks passed to certain methods. # # 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'] # # something do # array = [ # +1 # 1, # 2 # ] # # hash = { # +3 # key: 'value' # } # # msg = <<~HEREDOC # +1 # Heredoc # content. # HEREDOC # end # 5 points class BlockLength < Cop include TooManyLines LABEL = 'Block' def on_block(node) return if excluded_method?(node) return if node.class_constructor? check_code_length(node) end private def excluded_method?(node) node_receiver = node.receiver&.source&.gsub(/\s+/, '') node_method = String(node.method_name) excluded_methods.any? do |config| receiver, method = config.split('.') unless method method = receiver receiver = node_receiver end method == node_method && receiver == node_receiver end end def excluded_methods cop_config['ExcludedMethods'] || [] end def cop_label LABEL end end end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
rubocop-0.88.0 | lib/rubocop/cop/metrics/block_length.rb |
rubocop-0.87.1 | lib/rubocop/cop/metrics/block_length.rb |
rubocop-0.87.0 | lib/rubocop/cop/metrics/block_length.rb |