Module: ActiveSupport::Dependencies

Defined in:
lib/active_support/dependencies.rb,
lib/active_support/dependencies/interlock.rb

Overview

:nodoc:

Defined Under Namespace

Modules: RequireDependency Classes: Interlock

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Attribute Details

#_autoloaded_tracked_classesObject

If reloading is enabled, this private set holds autoloaded classes tracked by the descendants tracker. It is populated by an on_load callback in the main autoloader. Used to clear state.



61
62
63
# File 'lib/active_support/dependencies.rb', line 61

def _autoloaded_tracked_classes
  @_autoloaded_tracked_classes
end

#_eager_load_pathsObject

This is a private set that collects all eager load paths during bootstrap. Useful for Zeitwerk integration. The public interface to push custom directories to this collection from applications or engines is config.eager_load_paths.



55
56
57
# File 'lib/active_support/dependencies.rb', line 55

def _eager_load_paths
  @_eager_load_paths
end

#autoload_once_pathsObject

The array of directories from which we autoload and never reload, even if reloading is enabled. The public interface to push directories to this collection from applications or engines is config.autoload_once_paths.



48
49
50
# File 'lib/active_support/dependencies.rb', line 48

def autoload_once_paths
  @autoload_once_paths
end

#autoload_pathsObject

The array of directories from which we autoload and reload, if reloading is enabled. The public interface to push directories to this collection from applications or engines is config.autoload_paths.

This collection is allowed to have intersection with autoload_once_paths. Common directories are not reloaded.



42
43
44
# File 'lib/active_support/dependencies.rb', line 42

def autoload_paths
  @autoload_paths
end

#autoloaderObject

If reloading is enabled, this private attribute stores the main autoloader of a Rails application. It is ‘nil` otherwise.

The public interface for this autoloader is ‘Rails.autoloaders.main`.



68
69
70
# File 'lib/active_support/dependencies.rb', line 68

def autoloader
  @autoloader
end

#interlockObject

Returns the value of attribute interlock.



9
10
11
# File 'lib/active_support/dependencies.rb', line 9

def interlock
  @interlock
end

Class Method Details

.clearObject

Private method that reloads constants autoloaded by the main autoloader.

Rails.application.reloader.reload! is the public interface for application reload. That involves more things, like deleting unloaded classes from the internal state of the descendants tracker, or reloading routes.



75
76
77
78
79
80
# File 'lib/active_support/dependencies.rb', line 75

def self.clear
  unload_interlock do
    _autoloaded_tracked_classes.clear
    autoloader.reload
  end
end

.eager_load?(path) ⇒ Boolean

Private method that helps configuring the autoloaders.

Returns:

  • (Boolean)


93
94
95
# File 'lib/active_support/dependencies.rb', line 93

def self.eager_load?(path)
  _eager_load_paths.member?(path)
end

.load_interlock(&block) ⇒ Object

Execute the supplied block while holding an exclusive lock, preventing any other thread from being inside a #run_interlock block at the same time.



23
24
25
# File 'lib/active_support/dependencies.rb', line 23

def self.load_interlock(&block)
  interlock.loading(&block)
end

.run_interlock(&block) ⇒ Object

Execute the supplied block without interference from any concurrent loads.



16
17
18
# File 'lib/active_support/dependencies.rb', line 16

def self.run_interlock(&block)
  interlock.running(&block)
end

.search_for_file(relpath) ⇒ Object

Private method used by require_dependency.



83
84
85
86
87
88
89
90
# File 'lib/active_support/dependencies.rb', line 83

def self.search_for_file(relpath)
  relpath += ".rb" unless relpath.end_with?(".rb")
  autoload_paths.each do |autoload_path|
    abspath = File.join(autoload_path, relpath)
    return abspath if File.file?(abspath)
  end
  nil
end

.unload_interlock(&block) ⇒ Object

Execute the supplied block while holding an exclusive lock, preventing any other thread from being inside a #run_interlock block at the same time.



30
31
32
# File 'lib/active_support/dependencies.rb', line 30

def self.unload_interlock(&block)
  interlock.unloading(&block)
end