Class: RuboCop::Cop::Registry
- Inherits:
-
Object
- Object
- RuboCop::Cop::Registry
- Defined in:
- lib/rubocop/cop/registry.rb
Overview
Registry that tracks all cops by their badge and department.
Instance Method Summary collapse
- #==(other) ⇒ Object
- #contains_cop_matching?(names) ⇒ Boolean
- #cops ⇒ Object
-
#departments ⇒ Array<Symbol>
List of departments for current cops.
- #each(&block) ⇒ Object
- #enabled(config, only) ⇒ Object
- #enlist(cop) ⇒ Object
- #find_by_cop_name(cop_name) ⇒ Class?
-
#initialize(cops = []) ⇒ Registry
constructor
A new instance of Registry.
- #length ⇒ Object
- #names ⇒ Object
-
#qualified_cop_name(name, path) ⇒ String
Convert a user provided cop name into a properly namespaced name.
- #select(&block) ⇒ Object
- #sort! ⇒ Object
- #to_h ⇒ Hash{String => Array<Class>}
-
#with_department(department) ⇒ Registry
Cops for that specific department.
-
#without_department(department) ⇒ Registry
Cops not for a specific department.
Constructor Details
#initialize(cops = []) ⇒ Registry
Returns a new instance of Registry.
25 26 27 28 29 30 31 |
# File 'lib/rubocop/cop/registry.rb', line 25 def initialize(cops = []) @registry = {} @departments = {} @cops_by_cop_name = Hash.new { |hash, key| hash[key] = [] } cops.each { |cop| enlist(cop) } end |
Instance Method Details
#==(other) ⇒ Object
130 131 132 |
# File 'lib/rubocop/cop/registry.rb', line 130 def ==(other) cops == other.cops end |
#contains_cop_matching?(names) ⇒ Boolean
58 59 60 |
# File 'lib/rubocop/cop/registry.rb', line 58 def contains_cop_matching?(names) cops.any? { |cop| cop.match?(names) } end |
#cops ⇒ Object
112 113 114 |
# File 'lib/rubocop/cop/registry.rb', line 112 def cops @registry.values end |
#departments ⇒ Array<Symbol>
Returns list of departments for current cops.
41 42 43 |
# File 'lib/rubocop/cop/registry.rb', line 41 def departments @departments.keys end |
#each(&block) ⇒ Object
144 145 146 |
# File 'lib/rubocop/cop/registry.rb', line 144 def each(&block) cops.each(&block) end |
#enabled(config, only) ⇒ Object
120 121 122 123 124 |
# File 'lib/rubocop/cop/registry.rb', line 120 def enabled(config, only) select do |cop| config.for_cop(cop).fetch('Enabled') || only.include?(cop.cop_name) end end |
#enlist(cop) ⇒ Object
33 34 35 36 37 38 |
# File 'lib/rubocop/cop/registry.rb', line 33 def enlist(cop) @registry[cop.badge] = cop @departments[cop.department] ||= [] @departments[cop.department] << cop @cops_by_cop_name[cop.cop_name] << cop end |
#find_by_cop_name(cop_name) ⇒ Class?
150 151 152 |
# File 'lib/rubocop/cop/registry.rb', line 150 def find_by_cop_name(cop_name) @cops_by_cop_name[cop_name].first end |
#length ⇒ Object
116 117 118 |
# File 'lib/rubocop/cop/registry.rb', line 116 def length @registry.size end |
#names ⇒ Object
126 127 128 |
# File 'lib/rubocop/cop/registry.rb', line 126 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
94 95 96 97 98 99 100 101 102 103 104 105 |
# File 'lib/rubocop/cop/registry.rb', line 94 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
140 141 142 |
# File 'lib/rubocop/cop/registry.rb', line 140 def select(&block) cops.select(&block) end |
#sort! ⇒ Object
134 135 136 137 138 |
# File 'lib/rubocop/cop/registry.rb', line 134 def sort! @registry = Hash[@registry.sort_by { |badge, _| badge.cop_name }] self end |
#to_h ⇒ Hash{String => Array<Class>}
108 109 110 |
# File 'lib/rubocop/cop/registry.rb', line 108 def to_h @cops_by_cop_name end |
#with_department(department) ⇒ Registry
Returns Cops for that specific department.
46 47 48 |
# File 'lib/rubocop/cop/registry.rb', line 46 def with_department(department) with(@departments.fetch(department, [])) end |
#without_department(department) ⇒ Registry
Returns Cops not for a specific department.
51 52 53 54 55 56 |
# File 'lib/rubocop/cop/registry.rb', line 51 def without_department(department) without_department = @departments.dup without_department.delete(department) with(without_department.values.flatten) end |