Skip to content

Set namespace on REPL startupλ︎

The REPL process does not evaluate project code on start-up. If it did and that code had a error, it could prevent the REPL from starting.

The common approach is to require the main namespace for the project, making the functions in that namespace available. This will also make available functions from those namespaces.

Switching to a specific namespace in the REPL allows calling functions by name, without the fully qualified name.

Set namespace via the command lineλ︎

To require and switch to a namespace on startup, use the clojure or clj commands with the --eval option to run the specific commands. The --repl option will ensure the repl starts.

clj --eval "(require 'practicalli.random-clojure-core-function)" --eval "(in-ns 'practicalli.random-clojure-core-function)" --repl

-r or (clojure.main/repl) are the same as using the --repl option

clj -e "(ns (alter-var-root #'*ns* (constantly '" -r
clj -e "(ns (alter-var-root #'*ns* (constantly ' (clojure.main/repl)"

Set namespace with Rebel Readlineλ︎

Set the namespace using Rebel Readline alias from Practicalli Clojure CLI Config

clj -M:lib/rebel -e "(ns (alter-var-root #'*ns* (constantly (find-ns '" -m rebel-readline.main

#object[clojure.lang.Namespace 0x46cf05f7 ""]
[Rebel readline] Type :repl/help for online help info>

The :lib/rebel alias adds the rebel library as a dependency without calling clojure main on the rebel namespace. alter-var-root sets the namespace. The -m flag defines the namespace which Clojure main will run the -main function from, starting the rebel UI on the command line.

The --eval approach will be blocked if used with aliases that set the main namespace, such as :repl/rebel.

Set namespace using an editorλ︎

It is not necessary to set the namespace when evaluating code in a Clojure aware editor. Expressions are evaluated within the scope of the namespace in which they are defined.

Using an editor to evaluate Clojure is much simpler and quicker than using a command line REPL, especially when working with Clojure projects with more than one namespace.