Sha256: 724b1a8a219c5616dff09f2f07be4b434ac580d10ede5b3b9f48d96977a92dcd

Contents?: true

Size: 1.41 KB

Versions: 6

Compression:

Stored size: 1.41 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, occurrences|
          lines = occurrences.map(&:line)
          smell_warning(
            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

6 entries across 6 versions & 1 rubygems

Version Path
reek-6.4.0 lib/reek/smell_detectors/class_variable.rb
reek-6.3.0 lib/reek/smell_detectors/class_variable.rb
reek-6.2.0 lib/reek/smell_detectors/class_variable.rb
reek-6.1.4 lib/reek/smell_detectors/class_variable.rb
reek-6.1.3 lib/reek/smell_detectors/class_variable.rb
reek-6.1.2 lib/reek/smell_detectors/class_variable.rb