diff options
| author | Koichi Sasada <ko1@atdot.net> | 2024-11-06 03:41:59 +0900 |
|---|---|---|
| committer | Koichi Sasada <ko1@atdot.net> | 2024-11-06 11:06:18 +0900 |
| commit | ab7ab9e4508c24b998703824aa9576fb2e092065 (patch) | |
| tree | 27baa0a69fbdc59f54bf0526dde4c8c299ccbf82 /include/ruby/internal/encoding/transcode.h | |
| parent | 4203c70dfa96649bae305350817d7cc3c9bc5888 (diff) | |
`Warning[:strict_unused_block]`
to show unused block warning strictly.
```ruby
class C
def f = nil
end
class D
def f = yield
end
[C.new, D.new].each{|obj| obj.f{}}
```
In this case, `D#f` accepts a block. However `C#f` doesn't
accept a block. There are some cases passing a block with
`obj.f{}` where `obj` is `C` or `D`. To avoid warnings on
such cases, "unused block warning" will be warned only if
there is not same name which accepts a block.
On the above example, `C.new.f{}` doesn't show any warnings
because there is a same name `D#f` which accepts a block.
We call this default behavior as "relax mode".
`strict_unused_block` new warning category changes from
"relax mode" to "strict mode", we don't check same name
methods and `C.new.f{}` will be warned.
[Feature #15554]
Notes
Notes:
Merged: https://github.com/ruby/ruby/pull/12005
Diffstat (limited to 'include/ruby/internal/encoding/transcode.h')
0 files changed, 0 insertions, 0 deletions
