On 26 April 2016, Bram Moolenaar <b...@moolenaar.net> wrote: > > James McCoy wrote: > > > On Mon, Apr 25, 2016 at 11:06:43PM +0200, Bram Moolenaar wrote: > > > > > > Andrew Stewart wrote: > > > > > > > This handler gets called just about immediately, as expected, but > > > > a:message is always 'DETACH', not the diff output. And then a few > > > > seconds later the exit handler echoes its E906 error. > > > > > > This works. But the script should use "out_cb": > > > > > > func! OutHandler(channel, msg) > > > echomsg a:msg > > > endfunc > > > let cmd = 'diff -u /tmp/a /tmp/b' > > > let job = job_start(cmd, {'out_cb': 'OutHandler'}) > > > > > > The echo statements overwrite each other, "DETACH" is the last one. Use > > > ":messages" to see what happened before this. > > > > Why is Vim injecting "DETACH" into the output? The netbeans code uses > > is because that's part of the established protocol, but why is that > > being imposed on every other user of channels? > > Yeah, I was also wondering if we need it.
Some way to test for EOF would be more useful, IMO. Not quite the same thing as a close callback. /lcd > At least when there is a close callback it doesn't make sense. > > I would think that normally the job will send some terminator. > Otherwise, one can add a close callback if one needs to know the > channel is done reading. Would there be any reason to add DETACH? > > Previously the close callback didn't work properly. I fixed that now. > > > Also, the help implies that this is only done for channels > > representing a socket, not ones that are used for a simple > > job_start() with a process: > > > > On read error or ch_close(), when using a socket with RAW or NL > > mode, the string "DETACH\n" is sent, if still possible. The > > channel will then be inactive. > > The documentation is wrong. -- -- You received this message from the "vim_dev" maillist. Do not top-post! Type your reply below the text you are replying to. For more information, visit http://www.vim.org/maillist.php --- You received this message because you are subscribed to the Google Groups "vim_dev" group. To unsubscribe from this group and stop receiving emails from it, send an email to vim_dev+unsubscr...@googlegroups.com. For more options, visit https://groups.google.com/d/optout.