Sha256: d904fe3821e32952e15dc89c7a12784a08b35531483150fc99ecec4d2d32b8ce
Contents?: true
Size: 1.44 KB
Versions: 3
Compression:
Stored size: 1.44 KB
Contents
# frozen_string_literal: true require 'set' require_relative 'base_detector' module Reek module SmellDetectors # # 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 < BaseDetector def self.contexts # :nodoc: [:class, :module] end # # Checks whether the given class or module declares any class variables. # # @return [Array<SmellWarning>] # def sniff class_variables_in_context.map do |variable, occurences| lines = occurences.map(&:line) smell_warning( context: context, 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. # def class_variables_in_context context.local_nodes([:cvar, :cvasgn, :cvdecl]).group_by(&:name) end end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
reek-4.8.2 | lib/reek/smell_detectors/class_variable.rb |
reek-4.8.1 | lib/reek/smell_detectors/class_variable.rb |
reek-4.8.0 | lib/reek/smell_detectors/class_variable.rb |