Class: RuboCop::Cop::Registry

Inherits:
Object
  • Object
show all
Defined in:
lib/rubocop/cop/registry.rb

Overview

Registry that tracks all cops by their badge and department.

Instance Method Summary collapse

Constructor Details

#initialize(cops = []) ⇒ Registry

Returns a new instance of Registry.



25
26
27
28
29
30
# File 'lib/rubocop/cop/registry.rb', line 25

def initialize(cops = [])
  @registry    = {}
  @departments = {}

  cops.each { |cop| enlist(cop) }
end

Instance Method Details

#==(other) ⇒ Object



126
127
128
# File 'lib/rubocop/cop/registry.rb', line 126

def ==(other)
  cops == other.cops
end

#contains_cop_matching?(names) ⇒ Boolean

Returns:

  • (Boolean)


56
57
58
# File 'lib/rubocop/cop/registry.rb', line 56

def contains_cop_matching?(names)
  cops.any? { |cop| cop.match?(names) }
end

#copsObject



108
109
110
# File 'lib/rubocop/cop/registry.rb', line 108

def cops
  @registry.values
end

#departmentsArray<Symbol>

Returns list of departments for current cops.

Returns:

  • (Array<Symbol>)

    list of departments for current cops.



39
40
41
# File 'lib/rubocop/cop/registry.rb', line 39

def departments
  @departments.keys
end

#each(&block) ⇒ Object



140
141
142
# File 'lib/rubocop/cop/registry.rb', line 140

def each(&block)
  cops.each(&block)
end

#enabled(config, only) ⇒ Object



116
117
118
119
120
# File 'lib/rubocop/cop/registry.rb', line 116

def enabled(config, only)
  select do |cop|
    config.cop_enabled?(cop) || only.include?(cop.cop_name)
  end
end

#enlist(cop) ⇒ Object



32
33
34
35
36
# File 'lib/rubocop/cop/registry.rb', line 32

def enlist(cop)
  @registry[cop.badge] = cop
  @departments[cop.department] ||= []
  @departments[cop.department] << cop
end

#lengthObject



112
113
114
# File 'lib/rubocop/cop/registry.rb', line 112

def length
  @registry.size
end

#namesObject



122
123
124
# File 'lib/rubocop/cop/registry.rb', line 122

def names
  cops.map(&:cop_name)
end

#qualified_cop_name(name, path) ⇒ String

Note:

Emits a warning if the provided name has an incorrect namespace

Convert a user provided cop name into a properly namespaced name

Examples:

gives back a correctly qualified cop name


cops = RuboCop::Cop::Cop.all
cops.qualified_cop_name('Style/IndentArray') # => 'Style/IndentArray'

fixes incorrect namespaces


cops = RuboCop::Cop::Cop.all
cops.qualified_cop_name('Lint/IndentArray') # => 'Style/IndentArray'

namespaces bare cop identifiers


cops = RuboCop::Cop::Cop.all
cops.qualified_cop_name('IndentArray') # => 'IndentArray'

passes back unrecognized cop names


cops = RuboCop::Cop::Cop.all
cops.qualified_cop_name('NotACop') # => 'NotACop'

Parameters:

  • name (String)

    Cop name extracted from config

  • path (String)

    Path of file that ‘name` was extracted from

Returns:

  • (String)

    Qualified cop name

Raises:

  • (AmbiguousCopName)

    if a bare identifier with two possible namespaces is provided



91
92
93
94
95
96
97
98
99
100
101
102
# File 'lib/rubocop/cop/registry.rb', line 91

def qualified_cop_name(name, path)
  badge = Badge.parse(name)
  return name if registered?(badge)

  potential_badges = qualify_badge(badge)

  case potential_badges.size
  when 0 then name # No namespace found. Deal with it later in caller.
  when 1 then resolve_badge(badge, potential_badges.first, path)
  else raise AmbiguousCopName.new(badge, path, potential_badges)
  end
end

#select(&block) ⇒ Object



136
137
138
# File 'lib/rubocop/cop/registry.rb', line 136

def select(&block)
  cops.select(&block)
end

#sort!Object



130
131
132
133
134
# File 'lib/rubocop/cop/registry.rb', line 130

def sort!
  @registry = Hash[@registry.sort_by { |badge, _| badge.cop_name }]

  self
end

#to_hObject



104
105
106
# File 'lib/rubocop/cop/registry.rb', line 104

def to_h
  cops.group_by(&:cop_name)
end

#with_department(department) ⇒ Registry

Returns Cops for that specific department.

Returns:

  • (Registry)

    Cops for that specific department.



44
45
46
# File 'lib/rubocop/cop/registry.rb', line 44

def with_department(department)
  with(@departments.fetch(department, []))
end

#without_department(department) ⇒ Registry

Returns Cops not for a specific department.

Returns:

  • (Registry)

    Cops not for a specific department.



49
50
51
52
53
54
# File 'lib/rubocop/cop/registry.rb', line 49

def without_department(department)
  without_department = @departments.dup
  without_department.delete(department)

  with(without_department.values.flatten)
end