class RuboCop::ConfigStore
Handles caching of configurations and association of inspected ruby files to configurations.
Attributes
validated[R]
validated?[R]
Public Class Methods
new()
click to toggle source
# File lib/rubocop/config_store.rb, line 10 def initialize # @options_config stores a config that is specified in the command line. # This takes precedence over configs located in any directories @options_config = nil # @path_cache maps directories to configuration paths. We search # for .rubocop.yml only if we haven't already found it for the # given directory. @path_cache = {} # @object_cache maps configuration file paths to # configuration objects so we only need to load them once. @object_cache = {} # By default the config is validated before it can be used. @validated = true end
Public Instance Methods
for(file_or_dir)
click to toggle source
for_dir(dir)
click to toggle source
# File lib/rubocop/config_store.rb, line 61 def for_dir(dir) return @options_config if @options_config @path_cache[dir] ||= ConfigLoader.configuration_file_for(dir) path = @path_cache[dir] @object_cache[path] ||= begin print "For #{dir}: " if ConfigLoader.debug? ConfigLoader.configuration_from_file(path, check: validated?) end end
for_file(file)
click to toggle source
# File lib/rubocop/config_store.rb, line 42 def for_file(file) for_dir(File.dirname(file)) end
for_pwd()
click to toggle source
# File lib/rubocop/config_store.rb, line 46 def for_pwd for_dir(Dir.pwd) end
force_default_config!()
click to toggle source
# File lib/rubocop/config_store.rb, line 33 def force_default_config! @options_config = ConfigLoader.default_configuration end
options_config=(options_config)
click to toggle source
# File lib/rubocop/config_store.rb, line 28 def options_config=(options_config) loaded_config = ConfigLoader.load_file(options_config) @options_config = ConfigLoader.merge_with_default(loaded_config, options_config) end
unvalidated()
click to toggle source
# File lib/rubocop/config_store.rb, line 37 def unvalidated @validated = false self end