Sha256: d6bd36b58e12fda70e2f9bcc72f1765df676a086aecfdb6cbda802455e5a61d3

Contents?: true

Size: 1.03 KB

Versions: 2

Compression:

Stored size: 1.03 KB

Contents

# Nested Iterators

## Introduction

A `Nested Iterator` occurs when a block contains another block.

## Example

Given

```Ruby
class Duck
  class << self
    def duck_names
      %i!tick trick track!.each do |surname|
        %i!duck!.each do |last_name|
          puts "full name is #{surname} #{last_name}"
        end
      end
    end
  end
end
```

`reek` would report the following warning:

```
test.rb -- 1 warning:
  [5]:Duck#duck_names contains iterators nested 2 deep (NestedIterators)
```

## Current Support in Reek

Nested Iterators reports failing methods only once.
`Object#tap` is ignored by default and thus does not count as iterator.

## Configuration

`Nested Iterators` offers the [Basic Smell Options](Basic-Smell-Options.md), plus:

| Option         | Value       | Effect  |
| ---------------|-------------|---------|
| max_allowed_nesting | integer | The maximum depth of nested iterators. Defaults to 1 |
| ignore_iterators | Array | List of iterators to be excluded from the smell check. Includes only `tap` at the moment|

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
reek-3.4.1 docs/Nested-Iterators.md
reek-3.4.0 docs/Nested-Iterators.md