Sha256: 8e65aba46ad06d7fd6d1bca7a9633a1e9b613261ed3da5eb83090c8f423d999b
Contents?: true
Size: 1.73 KB
Versions: 4
Compression:
Stored size: 1.73 KB
Contents
# frozen_string_literal: true require 'set' require_relative 'smell_detector' require_relative 'smell_warning' module Reek module Smells # # Class variables form part of the global runtime state, and as such make # it easy for one part of the system to accidentally or inadvertently # depend on another part of the system. So the system becomes more prone to # problems where changing something over here breaks something over there. # In particular, class variables can make it hard to set up tests (because # the context of the test includes all global state). # # See {file:docs/Class-Variable.md} for details. class ClassVariable < SmellDetector def self.contexts # :nodoc: [:class, :module] end # # Checks whether the given class or module declares any class variables. # # @return [Array<SmellWarning>] # def sniff(ctx) class_variables_in(ctx.exp).map do |variable, lines| smell_warning( context: ctx, lines: lines, message: "declares the class variable #{variable}", parameters: { name: variable.to_s }) end end # # Collects the names of the class variables declared and/or used # in the given module. # # :reek:TooManyStatements: { max_statements: 7 } # :reek:FeatureEnvy def class_variables_in(ast) result = Hash.new { |hash, key| hash[key] = [] } collector = proc do |cvar_node| result[cvar_node.name].push(cvar_node.line) end [:cvar, :cvasgn, :cvdecl].each do |stmt_type| ast.each_node(stmt_type, [:class, :module], &collector) end result end end end end
Version data entries
4 entries across 4 versions & 1 rubygems
Version | Path |
---|---|
reek-4.4.0 | lib/reek/smells/class_variable.rb |
reek-4.3.0 | lib/reek/smells/class_variable.rb |
reek-4.2.5 | lib/reek/smells/class_variable.rb |
reek-4.2.4 | lib/reek/smells/class_variable.rb |