Class: RuboCop::Config
Relationships & Source Files | |
Namespace Children | |
Classes:
| |
Super Chains via Extension / Inclusion / Inheritance | |
Class Chain:
self,
SimpleForwardable
|
|
Instance Chain:
self,
FileFinder ,
PathUtil
|
|
Inherits: | Object |
Defined in: | lib/rubocop/config.rb |
Overview
This class represents the configuration of the RuboCop application and all its cops. A Config is associated with a YAML configuration file from which it was read. Several different Configs can be used during a run of the rubocop program, if files in several directories are inspected.
Constant Summary
-
DEFAULT_RAILS_VERSION =
# File 'lib/rubocop/config.rb', line 205.0
-
EMPTY_CONFIG =
# File 'lib/rubocop/config.rb', line 19{}.freeze
PathUtil
- Included
Class Method Summary
Instance Attribute Summary
- #active_support_extensions_enabled? ⇒ Boolean readonly
- #disabled_new_cops? ⇒ Boolean readonly
- #enabled_new_cops? ⇒ Boolean readonly
-
#internal? ⇒ Boolean
readonly
True if this is a config file that is shipped with RuboCop.
- #loaded_path readonly
-
#possibly_include_hidden? ⇒ Boolean
readonly
Returns true if there’s a chance that an Include pattern matches hidden files, false if that’s definitely not possible.
- #string_literals_frozen_by_default? ⇒ Boolean readonly
Instance Method Summary
- #add_excludes_from_higher_level(highest_config)
- #allowed_camel_case_file?(file) ⇒ Boolean
-
#base_dir_for_path_parameters
Paths specified in configuration files starting with .rubocop are relative to the directory where that file is.
- #bundler_lock_file_path ⇒ String?
- #check
- #clusivity_config_for_badge?(badge) ⇒ Boolean Internal use only Internal use only
- #cop_enabled?(name) ⇒ Boolean
- #deprecation_check
- #file_to_exclude?(file) ⇒ Boolean
- #file_to_include?(file) ⇒ Boolean
- #for_all_cops
-
#for_badge(badge) ⇒ Config
Note: the 'Enabled' attribute is same as that returned by
for_cop
. -
#for_cop(cop) ⇒ Config
Note: the 'Enabled' attribute is calculated according to the department’s and 'AllCops' configuration; other attributes are not inherited.
-
#for_department(department_name) ⇒ Config
Note: the 'Enabled' attribute will be present only if specified at the department’s level.
-
#for_enabled_cop(cop) ⇒ Config, Hash
If the given cop is enabled, returns its configuration hash.
-
#gem_versions_in_target
Returns target’s locked gem versions (i.e.
- #inspect Internal use only
- #loaded_features
- #make_excludes_absolute
- #parser_engine
- #path_relative_to_config(path)
- #patterns_to_exclude
- #patterns_to_include
- #pending_cops
- #signature
- #smart_loaded_path
- #target_rails_version
- #to_s
- #validate_after_resolution
- #department_of(qualified_cop_name) private
- #enable_cop?(qualified_cop_name, cop_options) ⇒ Boolean private
- #gem_version_to_major_minor_float(gem_version) ⇒ Float private
- #read_gem_versions_from_target_lockfile private
- #read_rails_version_from_bundler_lock_file ⇒ Float? private
- #target_rails_version_from_bundler_lock_file ⇒ Float? private
FileFinder
- Included
PathUtil
- Included
#absolute? | Returns true for an absolute Unix or Windows path. |
#glob? | Returns true for a glob. |
#hidden_dir?, #hidden_file?, #hidden_file_in_not_hidden_dir?, | |
#match_path? | Metrics/CyclomaticComplexity, Metrics/PerceivedComplexity. |
#maybe_hidden_file? | Loose check to reduce memory allocations. |
#relative_path, #smart_path |
Constructor Details
.new(hash = RuboCop::ConfigLoader.default_configuration, loaded_path = nil) ⇒ Config
# File 'lib/rubocop/config.rb', line 31
def initialize(hash = RuboCop::ConfigLoader.default_configuration, loaded_path = nil) @loaded_path = loaded_path @for_cop = Hash.new do |h, cop| cop_name = cop.respond_to?(:cop_name) ? cop.cop_name : cop qualified_cop_name = Cop::Registry.qualified_cop_name(cop_name, loaded_path) = self[qualified_cop_name].dup || {} ['Enabled'] = enable_cop?(qualified_cop_name, ) h[cop] = h[cop_name] = end @hash = hash @validator = ConfigValidator.new(self) @badge_config_cache = {}.compare_by_identity @clusivity_config_exists_cache = {} end
Class Method Details
.create(hash, path, check: true)
[ GitHub ]Instance Attribute Details
#active_support_extensions_enabled? ⇒ Boolean
(readonly)
[ GitHub ]
# File 'lib/rubocop/config.rb', line 179
def active_support_extensions_enabled? for_all_cops['ActiveSupportExtensionsEnabled'] end
#disabled_new_cops? ⇒ Boolean
(readonly)
[ GitHub ]
# File 'lib/rubocop/config.rb', line 171
def disabled_new_cops? for_all_cops['NewCops'] == 'disable' end
#enabled_new_cops? ⇒ Boolean
(readonly)
[ GitHub ]
# File 'lib/rubocop/config.rb', line 175
def enabled_new_cops? for_all_cops['NewCops'] == 'enable' end
#internal? ⇒ Boolean
(readonly)
True if this is a config file that is shipped with RuboCop
# File 'lib/rubocop/config.rb', line 77
def internal? base_config_path = File. (File.join(ConfigLoader::RUBOCOP_HOME, 'config')) File. (loaded_path).start_with?(base_config_path) end
#loaded_path (readonly)
[ GitHub ]# File 'lib/rubocop/config.rb', line 21
attr_reader :loaded_path
#string_literals_frozen_by_default? ⇒ Boolean
(readonly)
[ GitHub ]
# File 'lib/rubocop/config.rb', line 183
def string_literals_frozen_by_default? for_all_cops['StringLiteralsFrozenByDefault'] end
Instance Method Details
#add_excludes_from_higher_level(highest_config)
[ GitHub ]# File 'lib/rubocop/config.rb', line 94
def add_excludes_from_higher_level(highest_config) return unless highest_config.for_all_cops['Exclude'] excludes = for_all_cops['Exclude'] ||= [] highest_config.for_all_cops['Exclude'].each do |path| unless path.is_a?(Regexp) || absolute?(path) path = File.join(File.dirname(highest_config.loaded_path), path) end excludes << path unless excludes.include?(path) end end
#allowed_camel_case_file?(file) ⇒ Boolean
# File 'lib/rubocop/config.rb', line 206
def allowed_camel_case_file?(file) # Gemspecs are allowed to have dashes because that fits with bundler best # practices in the case when the gem is nested under a namespace (e.g., # `bundler-console` conveys `Bundler::Console`). return true if File.extname(file) == '.gemspec' file_to_include?(file) do |pattern, relative_path, absolute_path| /[A-Z]/.match?(pattern.to_s) && (match_path?(pattern, relative_path) || match_path?(pattern, absolute_path)) end end
#base_dir_for_path_parameters
Paths specified in configuration files starting with .rubocop are relative to the directory where that file is. Paths in other config files are relative to the current directory. This is so that paths in config/default.yml, for example, are not relative to RuboCop’s config directory since that wouldn’t work.
# File 'lib/rubocop/config.rb', line 250
def base_dir_for_path_parameters @base_dir_for_path_parameters ||= if loaded_path && File.basename(loaded_path).start_with?('.rubocop') && loaded_path != File.join(Dir.home, ConfigLoader::DOTFILE) File. (File.dirname(loaded_path)) else Dir.pwd end end
#bundler_lock_file_path ⇒ String?
# File 'lib/rubocop/config.rb', line 280
def bundler_lock_file_path return nil unless loaded_path base_path = base_dir_for_path_parameters ['Gemfile.lock', 'gems.locked'].each do |file_name| path = find_file_upwards(file_name, base_path) return path if path end nil end
#check
[ GitHub ]# File 'lib/rubocop/config.rb', line 52
def check deprecation_check { || warn("#{loaded_path} - #{}") } @validator.validate make_excludes_absolute self end
#clusivity_config_for_badge?(badge) ⇒ Boolean
#cop_enabled?(name) ⇒ Boolean
# File 'lib/rubocop/config.rb', line 167
def cop_enabled?(name) !!for_cop(name)['Enabled'] end
#department_of(qualified_cop_name) (private)
[ GitHub ]# File 'lib/rubocop/config.rb', line 359
def department_of(qualified_cop_name) *cop_department, _ = qualified_cop_name.split('/') return nil if cop_department.empty? self[cop_department.join('/')] end
#deprecation_check
[ GitHub ]# File 'lib/rubocop/config.rb', line 106
def deprecation_check %w[Exclude Include].each do |key| plural = "#{key}s" next unless for_all_cops[plural] for_all_cops[key] = for_all_cops[plural] # Stay backwards compatible. for_all_cops.delete(plural) yield "AllCops/#{plural} was renamed to AllCops/#{key}" end end
#enable_cop?(qualified_cop_name, cop_options) ⇒ Boolean
(private)
# File 'lib/rubocop/config.rb', line 347
def enable_cop?(qualified_cop_name, ) # If the cop is explicitly enabled or `Lint/Syntax`, the other checks can be skipped. return true if ['Enabled'] == true || qualified_cop_name == 'Lint/Syntax' department = department_of(qualified_cop_name) cop_enabled = .fetch('Enabled') { !for_all_cops['DisabledByDefault'] } return true if cop_enabled == 'override_department' return false if department && department['Enabled'] == false cop_enabled end
#file_to_exclude?(file) ⇒ Boolean
# File 'lib/rubocop/config.rb', line 228
def file_to_exclude?(file) file = File. (file) patterns_to_exclude.any? { |pattern| match_path?(pattern, file) } end
#file_to_include?(file) ⇒ Boolean
# File 'lib/rubocop/config.rb', line 187
def file_to_include?(file) relative_file_path = path_relative_to_config(file) # Optimization to quickly decide if the given file is hidden (on the top # level) and cannot be matched by any pattern. is_hidden = relative_file_path.start_with?('.') && !relative_file_path.start_with?('..') return false if is_hidden && !possibly_include_hidden? absolute_file_path = File. (file) patterns_to_include.any? do |pattern| if block_given? yield pattern, relative_file_path, absolute_file_path else match_path?(pattern, relative_file_path) || match_path?(pattern, absolute_file_path) end end end
#for_all_cops
[ GitHub ]# File 'lib/rubocop/config.rb', line 163
def for_all_cops @for_all_cops ||= self['AllCops'] || {} end
#for_badge(badge) ⇒ Config
Note: the 'Enabled' attribute is same as that returned by for_cop
#for_cop(cop) ⇒ Config
Note: the 'Enabled' attribute is calculated according to the department’s and 'AllCops' configuration; other attributes are not inherited.
# File 'lib/rubocop/config.rb', line 120
def for_cop(cop) @for_cop[cop] end
#for_department(department_name) ⇒ Config
Note: the 'Enabled' attribute will be present only if specified at the department’s level
#for_enabled_cop(cop) ⇒ Config
, Hash
If the given cop is enabled, returns its configuration hash. Otherwise, returns an empty hash.
# File 'lib/rubocop/config.rb', line 127
def for_enabled_cop(cop) cop_enabled?(cop) ? for_cop(cop) : EMPTY_CONFIG end
#gem_version_to_major_minor_float(gem_version) ⇒ Float
(private)
# File 'lib/rubocop/config.rb', line 334
def gem_version_to_major_minor_float(gem_version) segments = gem_version.segments Float("#{segments[0]}.#{segments[1]}") end
#gem_versions_in_target
Returns target’s locked gem versions (i.e. from Gemfile.lock or gems.locked)
# File 'lib/rubocop/config.rb', line 305
def gem_versions_in_target @gem_versions_in_target ||= read_gem_versions_from_target_lockfile end
#inspect
# File 'lib/rubocop/config.rb', line 309
def inspect # :nodoc: "#<#{self.class.name}:#{object_id} @loaded_path=#{loaded_path}>" end
#loaded_features
[ GitHub ]# File 'lib/rubocop/config.rb', line 48
def loaded_features @loaded_features ||= ConfigLoader.loaded_features end
#make_excludes_absolute
[ GitHub ]# File 'lib/rubocop/config.rb', line 82
def make_excludes_absolute each_key do |key| dig(key, 'Exclude')&.map! do |exclude_elem| if exclude_elem.is_a?(String) && !absolute?(exclude_elem) File. (File.join(base_dir_for_path_parameters, exclude_elem)) else exclude_elem end end end end
#parser_engine
[ GitHub ]# File 'lib/rubocop/config.rb', line 260
def parser_engine @parser_engine ||= for_all_cops.fetch('ParserEngine', :parser_whitequark).to_sym end
#path_relative_to_config(path)
[ GitHub ]# File 'lib/rubocop/config.rb', line 241
def path_relative_to_config(path) relative_path(path, base_dir_for_path_parameters) end
#patterns_to_exclude
[ GitHub ]# File 'lib/rubocop/config.rb', line 237
def patterns_to_exclude for_all_cops['Exclude'] || [] end
#patterns_to_include
[ GitHub ]# File 'lib/rubocop/config.rb', line 233
def patterns_to_include for_all_cops['Include'] || [] end
#pending_cops
[ GitHub ]# File 'lib/rubocop/config.rb', line 291
def pending_cops keys.each_with_object([]) do |qualified_cop_name, pending_cops| department = department_of(qualified_cop_name) next if department && department['Enabled'] == false = self[qualified_cop_name] next unless ['Enabled'] == 'pending' pending_cops << CopConfig.new(qualified_cop_name, ) end end
#read_gem_versions_from_target_lockfile (private)
[ GitHub ]# File 'lib/rubocop/config.rb', line 340
def read_gem_versions_from_target_lockfile lockfile_path = bundler_lock_file_path return nil unless lockfile_path Lockfile.new(lockfile_path).gem_versions end
#read_rails_version_from_bundler_lock_file ⇒ Float
? (private)
# File 'lib/rubocop/config.rb', line 321
def read_rails_version_from_bundler_lock_file return nil unless gem_versions_in_target # Look for `railties` instead of `rails`, to support apps that only use a subset of `rails` # See https://github.com/rubocop/rubocop/pull/11289 rails_version_in_target = gem_versions_in_target['railties'] return nil unless rails_version_in_target gem_version_to_major_minor_float(rails_version_in_target) end
#signature
[ GitHub ]# File 'lib/rubocop/config.rb', line 72
def signature @signature ||= Digest::SHA1.hexdigest(to_s) end
#smart_loaded_path
[ GitHub ]# File 'lib/rubocop/config.rb', line 275
def smart_loaded_path PathUtil.smart_path(@loaded_path) end
#target_rails_version
[ GitHub ]# File 'lib/rubocop/config.rb', line 264
def target_rails_version @target_rails_version ||= if for_all_cops['TargetRailsVersion'] for_all_cops['TargetRailsVersion'].to_f elsif target_rails_version_from_bundler_lock_file target_rails_version_from_bundler_lock_file else DEFAULT_RAILS_VERSION end end
#target_rails_version_from_bundler_lock_file ⇒ Float
? (private)
# File 'lib/rubocop/config.rb', line 316
def target_rails_version_from_bundler_lock_file @target_rails_version_from_bundler_lock_file ||= read_rails_version_from_bundler_lock_file end
#to_s
[ GitHub ]# File 'lib/rubocop/config.rb', line 68
def to_s @to_s ||= @hash.to_s end
#validate_after_resolution
[ GitHub ]# File 'lib/rubocop/config.rb', line 59
def validate_after_resolution @validator.validate_after_resolution self end