Sha256: adf78ee00b1c9420695ef6a752d7ecc0585d48d0984fec48809db7b3d6ce4f8a
Contents?: true
Size: 1.09 KB
Versions: 14
Compression:
Stored size: 1.09 KB
Contents
# encoding: utf-8 # frozen_string_literal: true module RuboCop module Cop module Metrics # This cop checks that the cyclomatic complexity of methods is not higher # than the configured maximum. The cyclomatic complexity is the number of # linearly independent paths through a method. The algorithm counts # decision points and adds one. # # An if statement (or unless or ?:) increases the complexity by one. An # else branch does not, since it doesn't add a decision point. The && # operator (or keyword and) can be converted to a nested if statement, # and ||/or is shorthand for a sequence of ifs, so they also add one. # Loops can be said to have an exit condition, so they add one. class CyclomaticComplexity < Cop include MethodComplexity MSG = 'Cyclomatic complexity for %s is too high. [%d/%d]'.freeze COUNTED_NODES = [:if, :while, :until, :for, :rescue, :when, :and, :or].freeze private def complexity_score_for(_node) 1 end end end end end
Version data entries
14 entries across 14 versions & 2 rubygems