Sha256: 7f6bb291b64960423206f275020219b3402bc8df402622007d9bb96dce07871c

Contents?: true

Size: 1.94 KB

Versions: 52

Compression:

Stored size: 1.94 KB

Contents

# frozen_string_literal: true

module RuboCop
  module Cop
    module Style
      # If the `else` branch of a conditional consists solely of an `if` node,
      # it can be combined with the `else` to become an `elsif`.
      # This helps to keep the nesting level from getting too deep.
      #
      # @example
      #   # bad
      #   if condition_a
      #     action_a
      #   else
      #     if condition_b
      #       action_b
      #     else
      #       action_c
      #     end
      #   end
      #
      #   # good
      #   if condition_a
      #     action_a
      #   elsif condition_b
      #     action_b
      #   else
      #     action_c
      #   end
      #
      # @example AllowIfModifier: false (default)
      #   # bad
      #   if condition_a
      #     action_a
      #   else
      #     action_b if condition_b
      #   end
      #
      #   # good
      #   if condition_a
      #     action_a
      #   elsif condition_b
      #     action_b
      #   end
      #
      # @example AllowIfModifier: true
      #   # good
      #   if condition_a
      #     action_a
      #   else
      #     action_b if condition_b
      #   end
      #
      #   # good
      #   if condition_a
      #     action_a
      #   elsif condition_b
      #     action_b
      #   end
      #
      class IfInsideElse < Cop
        MSG = 'Convert `if` nested inside `else` to `elsif`.'

        def on_if(node)
          return if node.ternary? || node.unless?

          else_branch = node.else_branch

          return unless else_branch&.if_type? && else_branch&.if?
          return if allow_if_modifier_in_else_branch?(else_branch)

          add_offense(else_branch, location: :keyword)
        end

        private

        def allow_if_modifier_in_else_branch?(else_branch)
          allow_if_modifier? && else_branch&.modifier_form?
        end

        def allow_if_modifier?
          cop_config['AllowIfModifier']
        end
      end
    end
  end
end

Version data entries

52 entries across 33 versions & 5 rubygems

Version Path
grape-extra_validators-2.0.0 vendor/bundle/ruby/2.6.0/gems/rubocop-0.79.0/lib/rubocop/cop/style/if_inside_else.rb
rubocop-0.89.0 lib/rubocop/cop/style/if_inside_else.rb
files.com-1.0.1 vendor/bundle/ruby/2.5.0/gems/rubocop-0.85.1/lib/rubocop/cop/style/if_inside_else.rb
rbhint-0.85.1.rc1 lib/rubocop/cop/style/if_inside_else.rb
rubocop-0.85.1 lib/rubocop/cop/style/if_inside_else.rb
rbhint-0.8.5.rc1 lib/rubocop/cop/style/if_inside_else.rb
rubocop-0.85.0 lib/rubocop/cop/style/if_inside_else.rb
rubocop-0.84.0 lib/rubocop/cop/style/if_inside_else.rb
rubocop-0.83.0 lib/rubocop/cop/style/if_inside_else.rb
rubocop-0.82.0 lib/rubocop/cop/style/if_inside_else.rb
rubocop-0.81.0 lib/rubocop/cop/style/if_inside_else.rb
rubocop-0.80.1 lib/rubocop/cop/style/if_inside_else.rb
rubocop-0.80.0 lib/rubocop/cop/style/if_inside_else.rb
grape-extra_validators-1.0.0 vendor/bundle/ruby/2.4.0/gems/rubocop-0.79.0/lib/rubocop/cop/style/if_inside_else.rb
grape-extra_validators-1.0.0 vendor/bundle/ruby/2.6.0/gems/rubocop-0.79.0/lib/rubocop/cop/style/if_inside_else.rb
rubocop-0.79.0 lib/rubocop/cop/style/if_inside_else.rb
rubocop-0.78.0 lib/rubocop/cop/style/if_inside_else.rb
zuora_connect_ui-0.10.0 vendor/ruby/2.6.0/gems/rubocop-0.75.1/lib/rubocop/cop/style/if_inside_else.rb
zuora_connect_ui-0.10.0 vendor/ruby/2.6.0/gems/rubocop-0.74.0/lib/rubocop/cop/style/if_inside_else.rb
zuora_connect_ui-0.10.0 vendor/ruby/2.6.0/gems/rubocop-0.76.0/lib/rubocop/cop/style/if_inside_else.rb