Mercurial > vim
diff src/channel.c @ 10309:88331ee68367 v8.0.0050
commit https://github.com/vim/vim/commit/01688ad545ff0809ddad5c8fa6b149dc5d67312b
Author: Bram Moolenaar <Bram@vim.org>
Date: Thu Oct 27 20:00:07 2016 +0200
patch 8.0.0050
Problem: An exiting job is detected with a large latency.
Solution: Check for pending job more often. (Ozaki Kiichi) Change the
double loop in mch_inchar() into one.
author | Christian Brabandt <cb@256bit.org> |
---|---|
date | Thu, 27 Oct 2016 20:15:04 +0200 |
parents | c5c15c818bda |
children | 471b87c3b67d |
line wrap: on
line diff
--- a/src/channel.c +++ b/src/channel.c @@ -4643,8 +4643,8 @@ job_stop_on_exit(void) } /* - * Return TRUE when there is any job that might exit, which means - * job_check_ended() should be called once in a while. + * Return TRUE when there is any job that has an exit callback and might exit, + * which means job_check_ended() should be called more often. */ int has_pending_job(void) @@ -4652,7 +4652,11 @@ has_pending_job(void) job_T *job; for (job = first_job; job != NULL; job = job->jv_next) - if (job_still_alive(job)) + /* Only should check if the channel has been closed, if the channel is + * open the job won't exit. */ + if (job->jv_status == JOB_STARTED && job->jv_exit_cb != NULL + && (job->jv_channel == NULL + || !channel_still_useful(job->jv_channel))) return TRUE; return FALSE; }