Sha256: bb8a175f2a474d61f6f48447fad2b4b2e6b41d4786415221377e50bda3d2807d

Contents?: true

Size: 1.78 KB

Versions: 11

Compression:

Stored size: 1.78 KB

Contents

# encoding: utf-8

module RuboCop
  module Cop
    module Lint
      # This cop checks for assignments in the conditions of
      # if/while/until.
      class AssignmentInCondition < Cop
        include SafeAssignment

        MSG = 'Assignment in condition - you probably meant to use `==`.'
        ASGN_TYPES = [:begin, *EQUALS_ASGN_NODES, :send]

        def on_if(node)
          check(node)
        end

        def on_while(node)
          check(node)
        end

        def on_until(node)
          check(node)
        end

        private

        def check(node)
          condition, = *node

          # assignments inside blocks are not what we're looking for
          return if condition.type == :block
          traverse_node(condition, ASGN_TYPES) do |asgn_node|
            if asgn_node.type == :send
              _receiver, method_name, *_args = *asgn_node
              next :skip_children if method_name != :[]=
            end

            # skip safe assignment nodes if safe assignment is allowed
            if safe_assignment_allowed? && safe_assignment?(asgn_node)
              next :skip_children
            end

            # assignment nodes from shorthand ops like ||= don't have operator
            if asgn_node.type != :begin && asgn_node.loc.operator
              add_offense(asgn_node, :operator)
            end
          end
        end

        # each_node/visit_descendants_with_types with :skip_children
        def traverse_node(node, types, &block)
          result = yield node if types.include?(node.type)
          # return to skip all descendant nodes
          return if result == :skip_children
          node.children.each do |child|
            traverse_node(child, types, &block) if child.is_a?(Astrolabe::Node)
          end
        end
      end
    end
  end
end

Version data entries

11 entries across 11 versions & 1 rubygems

Version Path
rubocop-0.35.1 lib/rubocop/cop/lint/assignment_in_condition.rb
rubocop-0.35.0 lib/rubocop/cop/lint/assignment_in_condition.rb
rubocop-0.34.2 lib/rubocop/cop/lint/assignment_in_condition.rb
rubocop-0.34.1 lib/rubocop/cop/lint/assignment_in_condition.rb
rubocop-0.34.0 lib/rubocop/cop/lint/assignment_in_condition.rb
rubocop-0.33.0 lib/rubocop/cop/lint/assignment_in_condition.rb
rubocop-0.32.1 lib/rubocop/cop/lint/assignment_in_condition.rb
rubocop-0.32.0 lib/rubocop/cop/lint/assignment_in_condition.rb
rubocop-0.31.0 lib/rubocop/cop/lint/assignment_in_condition.rb
rubocop-0.30.1 lib/rubocop/cop/lint/assignment_in_condition.rb
rubocop-0.30.0 lib/rubocop/cop/lint/assignment_in_condition.rb