Module: ActiveSupport::Dependencies::Loadable
- Defined in:
- lib/active_support/dependencies.rb
Overview
Object includes this module.
Class Method Summary collapse
-
.exclude_from(base) ⇒ Object
:nodoc:.
Instance Method Summary collapse
- #load(file, wrap = false) ⇒ Object
- #load_dependency(file) ⇒ Object
- #require(file) ⇒ Object
- #require_dependency(file_name, message = "No such file to load -- %s") ⇒ Object
- #require_or_load(file_name) ⇒ Object
-
#unloadable(const_desc) ⇒ Object
Mark the given constant as unloadable.
Class Method Details
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, = "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, ) 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 |