Sha256: 41ec3d6d3abe972651f60d44145f791d8fa39ae279033fe7cdcd50619f224c2e

Contents?: true

Size: 1.7 KB

Versions: 8

Compression:

Stored size: 1.7 KB

Contents

# encoding: utf-8
# frozen_string_literal: true

module RuboCop
  module Cop
    module Lint
      # This cop checks for nested method definitions.
      #
      # @example
      #   # `bar` definition actually produces methods in the same scope
      #   # as the outer `foo` method. Furthermore, the `bar` method
      #   # will be redefined every time `foo` is invoked.
      #   def foo
      #     def bar
      #     end
      #   end
      #
      class NestedMethodDefinition < Cop
        include OnMethodDef
        extend RuboCop::NodePattern::Macros

        MSG = 'Method definitions must not be nested. ' \
              'Use `lambda` instead.'.freeze

        def on_method_def(node, _method_name, _args, _body)
          find_nested_defs(node) do |nested_def_node|
            add_offense(nested_def_node, :expression)
          end
        end

        def find_nested_defs(node, &block)
          node.each_child_node do |child|
            if child.def_type?
              yield child
            elsif child.defs_type?
              subject, = *child
              next if subject.lvar_type?
              yield child
            elsif !ignored_child?(child)
              find_nested_defs(child, &block)
            end
          end
        end

        private

        def ignored_child?(child)
          eval_call?(child) || class_or_module_or_struct_new_call?(child)
        end

        def_node_matcher :eval_call?, <<-PATTERN
          (block (send _ {:instance_eval :class_eval :module_eval} ...) ...)
        PATTERN

        def_node_matcher :class_or_module_or_struct_new_call?, <<-PATTERN
          (block (send (const nil {:Class :Module :Struct}) :new ...) ...)
        PATTERN
      end
    end
  end
end

Version data entries

8 entries across 8 versions & 2 rubygems

Version Path
fluent-plugin-detect-memb-exceptions-0.0.2 vendor/bundle/ruby/2.0.0/gems/rubocop-0.42.0/lib/rubocop/cop/lint/nested_method_definition.rb
fluent-plugin-detect-memb-exceptions-0.0.1 vendor/bundle/ruby/2.0.0/gems/rubocop-0.42.0/lib/rubocop/cop/lint/nested_method_definition.rb
rubocop-0.43.0 lib/rubocop/cop/lint/nested_method_definition.rb
rubocop-0.42.0 lib/rubocop/cop/lint/nested_method_definition.rb
rubocop-0.41.2 lib/rubocop/cop/lint/nested_method_definition.rb
rubocop-0.41.1 lib/rubocop/cop/lint/nested_method_definition.rb
rubocop-0.41.0 lib/rubocop/cop/lint/nested_method_definition.rb
rubocop-0.40.0 lib/rubocop/cop/lint/nested_method_definition.rb