Module: ActiveSupport::Dependencies::Loadable

Defined in:
lib/active_support/dependencies.rb

Overview

Object includes this module.

Class Method Summary collapse

Instance Method Summary collapse

Class Method Details

.exclude_from(base) ⇒ Object

:nodoc:



194
195
196
# File 'lib/active_support/dependencies.rb', line 194

def self.exclude_from(base)
  base.class_eval { define_method(:load, Kernel.instance_method(:load)) }
end

Instance Method Details

#load(file, wrap = false) ⇒ Object



221
222
223
224
225
# File 'lib/active_support/dependencies.rb', line 221

def load(file, wrap = false)
  result = false
  load_dependency(file) { result = super }
  result
end

#load_dependency(file) ⇒ Object



210
211
212
213
214
215
216
217
218
219
# File 'lib/active_support/dependencies.rb', line 210

def load_dependency(file)
  if Dependencies.load? && ActiveSupport::Dependencies.constant_watch_stack.watching?
    Dependencies.new_constants_in(Object) { yield }
  else
    yield
  end
rescue Exception => exception  # errors from loading file
  exception.blame_file! file if exception.respond_to? :blame_file!
  raise
end

#require(file) ⇒ Object



227
228
229
230
231
# File 'lib/active_support/dependencies.rb', line 227

def require(file)
  result = false
  load_dependency(file) { result = super }
  result
end

#require_dependency(file_name, message = "No such file to load -- %s") ⇒ Object



202
203
204
205
206
207
208
# File 'lib/active_support/dependencies.rb', line 202

def require_dependency(file_name, message = "No such file to load -- %s")
  unless file_name.is_a?(String)
    raise ArgumentError, "the file name must be a String -- you passed #{file_name.inspect}"
  end

  Dependencies.depend_on(file_name, message)
end

#require_or_load(file_name) ⇒ Object



198
199
200
# File 'lib/active_support/dependencies.rb', line 198

def require_or_load(file_name)
  Dependencies.require_or_load(file_name)
end

#unloadable(const_desc) ⇒ Object

Mark the given constant as unloadable. Unloadable constants are removed each time dependencies are cleared.

Note that marking a constant for unloading need only be done once. Setup or init scripts may list each unloadable constant that may need unloading; each constant will be removed for every subsequent clear, as opposed to for the first clear.

The provided constant descriptor may be a (non-anonymous) module or class, or a qualified constant name as a string or symbol.

Returns true if the constant was not previously marked for unloading, false otherwise.



246
247
248
# File 'lib/active_support/dependencies.rb', line 246

def unloadable(const_desc)
  Dependencies.mark_for_unload const_desc
end