summaryrefslogtreecommitdiff
path: root/rubocop/cop
diff options
context:
space:
mode:
authorLin Jen-Shin <godfat@godfat.org>2017-11-22 15:50:36 +0800
committerLin Jen-Shin <godfat@godfat.org>2017-11-22 17:06:57 +0800
commit07d3d44775f6cc5b7a1b768cb4e5b7900d543815 (patch)
tree9b87200493dfc56a64aa6716ff4f03794b8f24c3 /rubocop/cop
parent15edf741a14a53443fb39ecb59888e75697b9c2b (diff)
downloadgitlab-ce-07d3d44775f6cc5b7a1b768cb4e5b7900d543815.tar.gz
Move ModuleWithInstanceVariables to Gitlab namespace
And use .rubocop.yml to exclude paths we don't care, rather than using the cop itself to exclude.
Diffstat (limited to 'rubocop/cop')
-rw-r--r--rubocop/cop/gitlab/module_with_instance_variables.rb63
-rw-r--r--rubocop/cop/module_with_instance_variables.rb82
2 files changed, 63 insertions, 82 deletions
diff --git a/rubocop/cop/gitlab/module_with_instance_variables.rb b/rubocop/cop/gitlab/module_with_instance_variables.rb
new file mode 100644
index 00000000000..5c9cde98512
--- /dev/null
+++ b/rubocop/cop/gitlab/module_with_instance_variables.rb
@@ -0,0 +1,63 @@
+module RuboCop
+ module Cop
+ module Gitlab
+ class ModuleWithInstanceVariables < RuboCop::Cop::Cop
+ MSG = <<~EOL.freeze
+ Do not use instance variables in a module. Please read this
+ for the rationale behind it:
+
+ https://docs.gitlab.com/ee/development/module_with_instance_variables.html
+ EOL
+
+ def on_module(node)
+ check_method_definition(node)
+
+ # Not sure why some module would have an extra begin wrapping around
+ node.each_child_node(:begin) do |begin_node|
+ check_method_definition(begin_node)
+ end
+ end
+
+ private
+
+ def check_method_definition(node)
+ node.each_child_node(:def) do |definition|
+ # We allow this pattern:
+ #
+ # def f
+ # @f ||= true
+ # end
+ if only_ivar_or_assignment?(definition)
+ # We don't allow if any other ivar is used
+ definition.each_descendant(:ivar) do |offense|
+ add_offense(offense, :expression)
+ end
+ # We allow initialize method and single ivar
+ elsif !initialize_method?(definition) && !single_ivar?(definition)
+ definition.each_descendant(:ivar, :ivasgn) do |offense|
+ add_offense(offense, :expression)
+ end
+ end
+ end
+ end
+
+ def only_ivar_or_assignment?(definition)
+ node = definition.child_nodes.last
+
+ definition.child_nodes.size == 2 &&
+ node.or_asgn_type? && node.child_nodes.first.ivasgn_type?
+ end
+
+ def single_ivar?(definition)
+ node = definition.child_nodes.last
+
+ definition.child_nodes.size == 2 && node.ivar_type?
+ end
+
+ def initialize_method?(definition)
+ definition.children.first == :initialize
+ end
+ end
+ end
+ end
+end
diff --git a/rubocop/cop/module_with_instance_variables.rb b/rubocop/cop/module_with_instance_variables.rb
deleted file mode 100644
index f101ae09ad2..00000000000
--- a/rubocop/cop/module_with_instance_variables.rb
+++ /dev/null
@@ -1,82 +0,0 @@
-module RuboCop
- module Cop
- class ModuleWithInstanceVariables < RuboCop::Cop::Cop
- MSG = <<~EOL.freeze
- Do not use instance variables in a module. Please read this
- for the rationale behind it:
-
- https://docs.gitlab.com/ee/development/module_with_instance_variables.html
- EOL
-
- def on_module(node)
- return if
- rails_helper?(node) || rails_mailer?(node) || spec_helper?(node)
-
- check_method_definition(node)
-
- # Not sure why some module would have an extra begin wrapping around
- node.each_child_node(:begin) do |begin_node|
- check_method_definition(begin_node)
- end
- end
-
- private
-
- # We ignore Rails helpers right now because it's hard to workaround it
- def rails_helper?(node)
- node.source_range.source_buffer.name =~
- %r{app/helpers/\w+_helper.rb\z}
- end
-
- # We ignore Rails mailers right now because it's hard to workaround it
- def rails_mailer?(node)
- node.source_range.source_buffer.name =~
- %r{app/mailers/emails/}
- end
-
- # We ignore spec helpers because it usually doesn't matter
- def spec_helper?(node)
- node.source_range.source_buffer.name =~
- %r{spec/support/|features/steps/}
- end
-
- def check_method_definition(node)
- node.each_child_node(:def) do |definition|
- # We allow this pattern:
- #
- # def f
- # @f ||= true
- # end
- if only_ivar_or_assignment?(definition)
- # We don't allow if any other ivar is used
- definition.each_descendant(:ivar) do |offense|
- add_offense(offense, :expression)
- end
- # We allow initialize method and single ivar
- elsif !initialize_method?(definition) && !single_ivar?(definition)
- definition.each_descendant(:ivar, :ivasgn) do |offense|
- add_offense(offense, :expression)
- end
- end
- end
- end
-
- def only_ivar_or_assignment?(definition)
- node = definition.child_nodes.last
-
- definition.child_nodes.size == 2 &&
- node.or_asgn_type? && node.child_nodes.first.ivasgn_type?
- end
-
- def single_ivar?(definition)
- node = definition.child_nodes.last
-
- definition.child_nodes.size == 2 && node.ivar_type?
- end
-
- def initialize_method?(definition)
- definition.children.first == :initialize
- end
- end
- end
-end