Module: ActiveSupport::Dependencies::Loadable

Defined in:
activesupport/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



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

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

Instance Method Details

#load(file, wrap = false) ⇒ Object



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

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

#load_dependency(file) ⇒ Object



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

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



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

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

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



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

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



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

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.



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

def unloadable(const_desc)
  Dependencies.mark_for_unload const_desc
end