Skip to content

Commit 1b84d9b

Browse files
authored
Merge pull request #681 from holyjak/patch-5
Clarify dev_startup_time w.r.t. already required nss
2 parents 78fd3b7 + 8276ecb commit 1b84d9b

File tree

1 file changed

+7
-2
lines changed

1 file changed

+7
-2
lines changed

content/guides/dev_startup_time.adoc

Lines changed: 7 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -24,12 +24,17 @@ The `compile` function takes a namespace symbol and compiles that namespace and
2424

2525
Subsequently, when any of those compiled namespaces are required, the class file will be loaded, rather than the original `.clj` file. If a source file is updated (and thus newer), it will be loaded instead. Periodically, you will need to re-compile to account for new dependencies or changing code.
2626

27-
One special case is the `user.clj` file loaded automatically by the Clojure runtime, before any other code is loaded. If you are using a `user.clj` in dev, you need to force a reload because it has already been loaded automatically:
27+
NOTE: Compilation happens as a side-effect of loading a namespace, and thus has no effect on already required ones. Use `*compile-files*` with `:reload-all` as suggested below to compile already loaded namespaces.
28+
29+
One special case is the `user.clj` file loaded automatically by the Clojure runtime, before any other code is loaded. (Though this applies equally to compiling any namespace that has already been loaded into the REPL.) If you are using a `user.clj` in dev, you need to force a reload because it has already been loaded automatically:
2830

2931
[source,clojure]
3032
----
31-
(binding [*compile-files* true] (require 'user :reload-all))
33+
(binding [*compile-files* true] ; <1>
34+
(require 'user :reload-all)) ; <2>
3235
----
36+
<1> Tell Clojure to compile any namespace it is loading
37+
<2> Tell Clojure to reload this and all required namespaces
3338

3439
That's it! This technique can substantially reduce your startup time during development, particularly as the number of dependencies you load increases.
3540

0 commit comments

Comments
 (0)