- #12: Support custom printing function in
pr-values, enabling pretty-printed REPL results.
- #66: Add support for a global and local configuration file.
- #63: Make it possible to specify the transport via the command-line client (
- #10: Bind
*e in cloned session.
- #33: Add ability to change value of
- #68: Avoid illegal access warning on JDK 9+ caused by
- #77: Exit cleanly after pressing
ctrl-d in an interactive REPL.
- #13: Catch ThreadDeath exception thrown by interrupt.
- #56: Bind the server by default to
127.0.0.1 instead of to
:: (this turned out to be a security risk).
- #76: Move version-related logic to a dedicated namespace (
- #81: Handle interrupt in interactive session.
- The built-in the CLI generates an
.nrepl-port file on server startup.
- #39: Add a
--connect command-line option allowing you to connect. with the built-in client to an already running nREPL server.
- Add shorthand names for most command-line options.
- Add a
-v/--version command-line option.
- #38: Remove extra newline in REPL output.
--help command-line option.
--bind command-line option.
--middleware command-line options. Extremely useful when starting nREPL using
tools.deps, as this allows you to inject middleware trivially without the need for something like
- Add missing newline after colorized values displayed in the REPL.
- Display connection info when starting the built-in cmd client. This makes it possible for clients like CIDER to parse it and auto-connect to the server. Pretty handy if you're using
clj to start your server.
- #16: Don't change the thread used for form evaluation over time. See #36 for a discussion of the fix. (partial fix)
- The result of
nrepl.server/start-server no longer contains the legacy key
:ss from the days of nREPL 0.0.x. If someone was using it they should switch to
- #28: Echo back missing ns during eval (previously you'd only get an error that a ns is missing, but no mention of the name of that namespace).
- #35: Add constant DCL across evaluations (which means you can now easily hot-load dependencies).
- #34: Treat
nil port as 0 (which assigns a random port).
- #11: Don't read the version string from a resource file (
- #4: Change the project's namespaces. (breaking)
clojure.tools.nrepl is now
nrepl.core, the rest of the namespaces were renamed following the pattern
- #15 Fix for
:unknown-session error and
:no-code error, the correct response of
:status :done is now being returned.
- #26: Recompile the Java classes for Java 8.
- #1: Materially identical to
[org.clojure/tools.nrepl "0.2.13"], but released under
nrepl/nrepl coordinates as part of the migration out of clojure-contrib https://github.com/nrepl/nREPL
clojure.tools/logging is now a normal dependency (it used to be an optional dependency).
- #20: If
start-server is not provided with a
:bind hostname, nREPL will default to binding to the ipv6
:: (as before), but will now always fall back to
localhost. Previously, the ipv4 hostname was only used if
:: could not be resolved; this change ensures that the
localhost fallback is used in networking environments where
:: is resolved successfully, but cannot be bound.
start-server now binds to
:: by default, and falls back to
localhost, avoiding confusion when working in environments that have both IPv4 and IPv6 networking available. (NREPL-83)
clojure.tools.nrepl.middleware.interruptible-eval now accepts optional
column values in order to fix location metadata to defined vars and functions, for more useful stack traces, navigation, etc.
- REPL evaluations now support use of reader conditionals (loading
.cljc files containing reader conditionals has always worked transparently)
clojure.tools.nrepl.middleware.pr-values will not print the contents of
:value response messages if the message contains a
clojure.tools.nrepl.middleware.interruptible-eval are now public.
clojure.tools.nrepl.middleware.interruptible-eval now defines a default thread executor used for all evaluations (unless a different executor is provided to the configuration of
clojure.tools.nrepl.middleware.interruptible-eval/interruptible-eval). This should aid in the development of
interrupt-capable alternative evaluation middlewares/handlers.
- The default bind address used by
clojure.tools.nrepl.server/start-server is now
0.0.0.0. As always, the bind address can be set explicitly via a
:bind keyword argument to that function. This is considered a security bugfix, though technically it may cause breakage if anyone was implicitly relying upon nREPL's socket server to listen on all network interfaces.
ServerSocket created as part of
clojure.tools.nrepl.server/start-server is now configured with
SO_REUSEADDR enabled; this should prevent spurious "address already in use" when quickly bouncing apps that open an nREPL server on a fixed port, etc. (NREPL-67)
- Middlewares may now contribute to the response of the
"describe" operation via an optional
:describe-fn function provided via their descriptors. (NREPL-64)
:ns component of the response to
"load-file" operations is now elided, as it was (usually) incorrect (as a result of reusing
interruptible-eval for handling
load-file operations) (NREPL-68)
- The topological sort ("linearization") applied to middleware provided to start a new nREPL server has been reworked to address certain edge case bugs (NREPL-53)
interruptible-eval no longer incorrectly clobbers a session's
*ns* binding when it processes an
eval message containing an
- Eliminated miscellaneous reflection warnings
- Clients can now signal EOF on
*in* with an empty
:stdin value (NREPL-65)
:version-string is now included in response to a
describe operation (NREPL-63)
- Improve representation of
java.version information in response to a
describe operation (NREPL-62)
- Fixed the source of a reliable per-connection thread leak (NREPL-40)
- Fix printing of lazy sequences so that
*out* bindings are properly preserved (NREPL-45)
clojure.tools.nrepl.middleware.interruptible-eval/evaluate so that a custom
eval function can be provided on a per-message basis (NREPL-50)
- Fix pretty-printing of reference returned by
- nREPL now works with JDK 1.8 (NREPL-56)
- The value of the
java.version system property is now included in the response to a
describe operation (NREPL-57)
- Common session bindings (e.g.
*1, etc) are now set in time for nREPL middleware to access them in the case of an exception being thrown (NREPL-58)
- Now using a queue to maintain
*in*, to avoid intermittent failures due to prior use of
- When loading a file, always bind
*print-length* when generating the
clojure.lang.Compiler/load expression (NREPL-41)
pr-str'ing expressions (presumably for later evaluation)
- session IDs are now properly combined into a set by
- fixes printing of server instances under Clojure 1.3.0+ (nREPL-37)
- fixes incorrect translation between
StringBuilder.append() APIs (NREPL-38)
Never released; initial prototype of "rich content" support that (in part) helped motivate a re-examination of the underlying protocol and design.
- added Clojure 1.3.0 (ALPHA) compatibility
Edit on GitHub
- fixed (hacked) obtaining
clojure.test output when
clojure.test is initially loaded within an nREPL session
- eliminated 1-minute default timeout on expression evaluation
- all standard REPL var bindings are now properly established and maintained within a session