aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorXavier Noria <fxn@hashref.com>2014-12-15 10:14:13 +0100
committerXavier Noria <fxn@hashref.com>2014-12-15 10:16:43 +0100
commit5c37c9a5c09f9f09fa5596da07f78519a1719b9f (patch)
tree09914df886e051bacc65adfc3f0c9d047f228c55
parentfdbeda449e3f20fa5e341f452adc99c70d319aec (diff)
downloadrails-5c37c9a5c09f9f09fa5596da07f78519a1719b9f.tar.gz
rails-5c37c9a5c09f9f09fa5596da07f78519a1719b9f.tar.bz2
rails-5c37c9a5c09f9f09fa5596da07f78519a1719b9f.zip
autoloading guide: new section about why Kernel#autoload is not involved [ci skip]
-rw-r--r--guides/source/constant_autoloading_and_reloading.md35
1 files changed, 35 insertions, 0 deletions
diff --git a/guides/source/constant_autoloading_and_reloading.md b/guides/source/constant_autoloading_and_reloading.md
index 40fde8a6ac..e01545e3af 100644
--- a/guides/source/constant_autoloading_and_reloading.md
+++ b/guides/source/constant_autoloading_and_reloading.md
@@ -15,6 +15,8 @@ After reading this guide, you will know:
* How constant reloading works
+* That autoloading is not based on `Kernel#autoload`
+
* Solutions to common autoloading gotchas
--------------------------------------------------------------------------------
@@ -643,6 +645,39 @@ what changed since dependencies between classes makes that really tricky.
Instead, everything is wiped.
+Kernel#autoload isn't Involved
+------------------------------
+
+`Kernel#autoload` provides a lazy way to load constants that is fully integrated
+with the Ruby constant lookup algorithms, dynamic constant API, etc. It is quite
+transparent.
+
+Rails internals make extensive use of it to defer as much work as possible from
+the boot process. But constant autoloading in Rails is **not** implemented with
+`Kernel#autoload`.
+
+One possible implementation based on `Kernel#autoload` would be to walk the
+application tree and issue `autoload` calls that map existing file names to
+their conventional contant name.
+
+There are a number of reasons that prevent Rails from using that implementation.
+
+For example, `Kernel#autoload` is only capable of loading files using `require`,
+so reloading would not be possible. Not only that, it uses an internal `require`
+which is not `Kernel#require`.
+
+Then, it provides no way to remove declarations in case a file is deleted. If a
+constant gets removed with `Module#remove_const` its `autoload` is not triggered
+again. Also, it doesn't support qualified names, so files with namespaces should
+be interpreted during the walk tree to install their own `autoload` calls, but
+those files could have constant references not yet configured.
+
+An implementation based on `Kernel#autoload` would be awesome but, as you see,
+at least as of today it is not possible. Constant autoloading in Rails is
+implemented with `Module#const_missing`, and that's why it has its own contract,
+documented in this guide.
+
+
Common Gotchas
--------------