From bffba51feada00d1eb450f3c6055525d44fc92db Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=D0=90=D0=BD=D1=82=D0=BE=D0=BD=20=D0=92=D0=B0=D0=BB=D0=B5?= =?UTF-8?q?=D0=BD=D1=82=D0=B8=D0=BD=D0=BE=D0=B2=D0=B8=D1=87=20=D0=A0=D1=83?= =?UTF-8?q?=D1=81=D0=B0=D0=BD=D0=BE=D0=B2?= Date: Thu, 11 Jun 2020 18:35:30 +0500 Subject: [PATCH] [Fix #8132] Fix the problem with Naming/MethodName: EnforcedStyle: camelCase and _ or i variables. --- CHANGELOG.md | 3 ++- lib/rubocop/cop/mixin/configurable_naming.rb | 2 +- spec/rubocop/cop/naming/variable_name_spec.rb | 8 ++++++++ 3 files changed, 11 insertions(+), 2 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index facf79141455..e06aaace665a 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -8,7 +8,7 @@ * [#8113](https://github.com/rubocop-hq/rubocop/pull/8113): Let `expect_offense` templates add variable-length whitespace with `_{foo}`. ([@eugeneius][]) ### Bug fixes - +* [#8132](https://github.com/rubocop-hq/rubocop/issues/8132): Fix the problem with `Naming/MethodName: EnforcedStyle: camelCase` and `_` or `i` variables. ([@avrusanov][]) * [#8115](https://github.com/rubocop-hq/rubocop/issues/8115): Fix false negative for `Lint::FormatParameterMismatch` when argument contains formatting. ([@andrykonchin][]) * [#8124](https://github.com/rubocop-hq/rubocop/issues/8124): Fix a false positive for `Lint/FormatParameterMismatch` when using named parameters with escaped `%`. ([@koic][]) @@ -4585,3 +4585,4 @@ [@ric2b]: https://github.com/ric2b [@burnettk]: https://github.com/burnettk [@andrykonchin]: https://github.com/andrykonchin +[@avrusanov]: https://github.com/avrusanov diff --git a/lib/rubocop/cop/mixin/configurable_naming.rb b/lib/rubocop/cop/mixin/configurable_naming.rb index e9829a077a8a..49734795aa87 100644 --- a/lib/rubocop/cop/mixin/configurable_naming.rb +++ b/lib/rubocop/cop/mixin/configurable_naming.rb @@ -9,7 +9,7 @@ module ConfigurableNaming FORMATS = { snake_case: /^@{0,2}[\da-z_]+[!?=]?$/, - camelCase: /^@{0,2}_?[a-z][\da-zA-Z]+[!?=]?$/ + camelCase: /^@{0,2}(?:_|_?[a-z][\da-zA-Z]*)[!?=]?$/ }.freeze end end diff --git a/spec/rubocop/cop/naming/variable_name_spec.rb b/spec/rubocop/cop/naming/variable_name_spec.rb index f7f4798fed86..5513771c36d4 100644 --- a/spec/rubocop/cop/naming/variable_name_spec.rb +++ b/spec/rubocop/cop/naming/variable_name_spec.rb @@ -17,6 +17,14 @@ it 'accepts assignment with indexing of self' do expect_no_offenses('self[:a] = b') end + + it 'accepts local variables marked as unused' do + expect_no_offenses('_ = 1') + end + + it 'accepts one symbol size local variables' do + expect_no_offenses('i = 1') + end end context 'when configured for snake_case' do