Sha256: 8e1dc48a002790d914fd782ac93a4adc10222a8e1c9483da4c1a25605d1445cc
Contents?: true
Size: 1.57 KB
Versions: 3
Compression:
Stored size: 1.57 KB
Contents
require_relative 'smell_detector' require_relative 'smell_warning' module Reek module Smells # # A Large Class is a class or module that has a large number of # instance variables, methods or lines of code. # # +TooManyInstanceVariables' reports classes having more than a # configurable number of instance variables. # # See {file:docs/Too-Many-Instance-Variables.md} for details. # @api private class TooManyInstanceVariables < SmellDetector # The name of the config field that sets the maximum number of instance # variables permitted in a class. MAX_ALLOWED_IVARS_KEY = 'max_instance_variables' DEFAULT_MAX_IVARS = 4 def self.smell_category 'LargeClass' end def self.contexts [:class] end def self.default_config super.merge( MAX_ALLOWED_IVARS_KEY => DEFAULT_MAX_IVARS, EXCLUDE_KEY => [] ) end # # Checks +klass+ for too many instance variables. # # @return [Array<SmellWarning>] # def examine_context(ctx) max_allowed_ivars = value(MAX_ALLOWED_IVARS_KEY, ctx, DEFAULT_MAX_IVARS) count = ctx.local_nodes(:ivasgn).map { |ivasgn| ivasgn[1] }.uniq.length return [] if count <= max_allowed_ivars [SmellWarning.new(self, context: ctx.full_name, lines: [ctx.exp.line], message: "has at least #{count} instance variables", parameters: { count: count })] end end end end
Version data entries
3 entries across 3 versions & 1 rubygems
Version | Path |
---|---|
reek-3.3.1 | lib/reek/smells/too_many_instance_variables.rb |
reek-3.3.0 | lib/reek/smells/too_many_instance_variables.rb |
reek-3.2 | lib/reek/smells/too_many_instance_variables.rb |