Damien wrote:
> The term_getjob() function is documented to return v:null when something
> wrong happen but Vim always return a job.
>
>
> ```
> diff --git a/src/terminal.c b/src/terminal.c
> index 5a0165814fac..1a62d06c63c1 100644
> --- a/src/terminal.c
> +++ b/src/terminal.c
> @@ -4794,14 +4794,15 @@ f_term_getjob(typval_T *argvars, typval_
> {
> buf_T *buf = term_get_buf(argvars, "term_getjob()");
>
> - rettv->v_type = VAR_JOB;
> - rettv->vval.v_job = NULL;
> - if (buf == NULL)
> - return;
> + rettv->v_type = VAR_SPECIAL;
> + rettv->vval.v_number = VVAL_NULL;
>
> - rettv->vval.v_job = buf->b_term->tl_job;
> - if (rettv->vval.v_job != NULL)
> + if (buf != NULL && buf->b_term->tl_job != NULL)
> + {
> + rettv->v_type = VAR_JOB;
> + rettv->vval.v_job = buf->b_term->tl_job;
> ++rettv->vval.v_job->jv_refcount;
> + }
> }
>
> static int
> ```
>
> I didn't add test because I don't know what is expected but it can easily
> reproduce on Linux:
>
> ```
> let term = term_start('false', {'term_finish': 'close'})
> if term != 0
> call WaitForAssert({-> assert_true(term_getjob(term) is v:null) })
> endif
> ```
Good point, it was not easy to check if term_getjob() was returning a
null job. Your example almost functions as a test.
--
hundred-and-one symptoms of being an internet addict:
36. You miss more than five meals a week downloading the latest games from
Apogee.
/// Bram Moolenaar -- [email protected] -- http://www.Moolenaar.net \\\
/// sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ \\\
\\\ an exciting new programming language -- http://www.Zimbu.org ///
\\\ help me help AIDS victims -- http://ICCF-Holland.org ///
--
--
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 [email protected].
For more options, visit https://groups.google.com/d/optout.