Descriptor for "add-stdin" appears to incorrectly declare :returns "need-input"

Description

This is really a question, more than a claim that the code is wrong. I'm trying to understand middleware descriptors and the example for "add-stdin" isn't making sense to me with respect to the key path '[:handles "stdin" :returns]' which points to a string describing a possible status:

https://github.com/clojure/tools.nrepl/blob/fcac1e13d6f80eb0db28773247a769c1dc9659b1/src/main/clojure/clojure/tools/nrepl/middleware/session.clj#L247

I can't figure out how this middleware could do that, given the only mention is in the function "session-in", which is only seemingly reachable from the "session" middleware.

Environment

None

Activity

Show:

Alex Miller June 26, 2019 at 3:52 AM

All nrepl tickets closed, now managed at https://github.com/nrepl/nrepl

Ian Tegebo June 10, 2016 at 5:05 AM

After some more review, I see that "session-in" sends a response through a transport as a side-effect. However, I'm still confused because it would appear that using "session" without "add-stdin" would still result in responses that contain "need-input".

Won't Fix

Details

Assignee

Reporter

Priority

Created June 8, 2016 at 10:48 PM
Updated June 26, 2019 at 3:52 AM
Resolved June 26, 2019 at 3:52 AM