Sha256: 05993fe8ab23029e199744f45fa1f3684da87fd404a8411b07cd98b230283a66

Contents?: true

Size: 1.67 KB

Versions: 36

Compression:

Stored size: 1.67 KB

Contents

# frozen_string_literal: true

module RuboCop
  module Cop
    module Lint
      # This cop checks for the use of a return with a value in a context
      # where the value will be ignored. (initialize and setter methods)
      #
      # @example
      #
      #   # bad
      #   def initialize
      #     foo
      #     return :qux if bar?
      #     baz
      #   end
      #
      #   def foo=(bar)
      #     return 42
      #   end
      #
      # @example
      #
      #   # good
      #   def initialize
      #     foo
      #     return if bar?
      #     baz
      #   end
      #
      #   def foo=(bar)
      #     return
      #   end
      class ReturnInVoidContext < Base
        MSG = 'Do not return a value in `%<method>s`.'

        def on_return(return_node)
          return unless return_node.descendants.any?

          context_node = non_void_context(return_node)

          return unless context_node&.def_type?

          method_name = method_name(context_node)

          return unless method_name && void_context_method?(method_name)

          add_offense(return_node.loc.keyword, message: format(message, method: method_name))
        end

        private

        def non_void_context(return_node)
          return_node.each_ancestor(:block, :def, :defs).first
        end

        def method_name(context_node)
          context_node.children.first
        end

        def void_context_method?(method_name)
          method_name == :initialize || setter_method?(method_name)
        end

        def setter_method?(method_name)
          method_name.to_s.end_with?('=') && !AST::Node::COMPARISON_OPERATORS.include?(method_name)
        end
      end
    end
  end
end

Version data entries

36 entries across 36 versions & 6 rubygems

Version Path
scrapbook-0.3.2 vendor/ruby/2.7.0/gems/rubocop-1.26.0/lib/rubocop/cop/lint/return_in_void_context.rb
scrapbook-0.3.1 vendor/ruby/2.7.0/gems/rubocop-1.26.0/lib/rubocop/cop/lint/return_in_void_context.rb
rubocop-1.28.2 lib/rubocop/cop/lint/return_in_void_context.rb
rubocop-1.28.1 lib/rubocop/cop/lint/return_in_void_context.rb
rubocop-1.28.0 lib/rubocop/cop/lint/return_in_void_context.rb
rubocop-1.27.0 lib/rubocop/cop/lint/return_in_void_context.rb
rubocop-1.26.1 lib/rubocop/cop/lint/return_in_void_context.rb
op_connect-0.1.2 vendor/bundle/ruby/3.1.0/gems/rubocop-1.26.0/lib/rubocop/cop/lint/return_in_void_context.rb
rubocop-1.26.0 lib/rubocop/cop/lint/return_in_void_context.rb
rubocop-1.25.1 lib/rubocop/cop/lint/return_in_void_context.rb
rubocop-1.25.0 lib/rubocop/cop/lint/return_in_void_context.rb
phillipug-foodie-0.1.0 .vendor/ruby/3.0.0/gems/rubocop-1.24.0/lib/rubocop/cop/lint/return_in_void_context.rb
rubocop-1.24.1 lib/rubocop/cop/lint/return_in_void_context.rb
rubocop-1.24.0 lib/rubocop/cop/lint/return_in_void_context.rb
rubocop-1.23.0 lib/rubocop/cop/lint/return_in_void_context.rb
rubocop-1.22.3 lib/rubocop/cop/lint/return_in_void_context.rb
rubocop-1.22.2 lib/rubocop/cop/lint/return_in_void_context.rb
rubocop-1.22.1 lib/rubocop/cop/lint/return_in_void_context.rb
rubocop-1.22.0 lib/rubocop/cop/lint/return_in_void_context.rb
rubocop-1.21.0 lib/rubocop/cop/lint/return_in_void_context.rb