@@ -499,6 +499,7 @@ static void f_ceil(typval_T *argvars, typval_T *rettv);
499499static void f_ch_close(typval_T *argvars, typval_T *rettv);
500500static void f_ch_evalexpr(typval_T *argvars, typval_T *rettv);
501501static void f_ch_evalraw(typval_T *argvars, typval_T *rettv);
502+ static void f_ch_getbufnr(typval_T *argvars, typval_T *rettv);
502503# ifdef FEAT_JOB
503504static void f_ch_getjob(typval_T *argvars, typval_T *rettv);
504505# endif
@@ -8195,6 +8196,7 @@ static struct fst
81958196 {"ch_close", 1, 1, f_ch_close},
81968197 {"ch_evalexpr", 2, 3, f_ch_evalexpr},
81978198 {"ch_evalraw", 2, 3, f_ch_evalraw},
8199+ {"ch_getbufnr", 2, 2, f_ch_getbufnr},
81988200# ifdef FEAT_JOB
81998201 {"ch_getjob", 1, 1, f_ch_getjob},
82008202# endif
@@ -10227,13 +10229,6 @@ get_job_options(typval_T *tv, jobopt_T *opt, int supported)
1022710229 return FAIL;
1022810230 }
1022910231
10230- for (part = PART_OUT; part <= PART_IN; ++part)
10231- if (opt->jo_io[part] == JIO_BUFFER && opt->jo_io_name[part] == NULL)
10232- {
10233- EMSG(_("E915: Missing name for buffer"));
10234- return FAIL;
10235- }
10236-
1023710232 return OK;
1023810233}
1023910234#endif
@@ -10278,6 +10273,33 @@ f_ch_close(typval_T *argvars, typval_T *rettv UNUSED)
1027810273 }
1027910274}
1028010275
10276+ /*
10277+ * "ch_getbufnr()" function
10278+ */
10279+ static void
10280+ f_ch_getbufnr(typval_T *argvars, typval_T *rettv)
10281+ {
10282+ channel_T *channel = get_channel_arg(&argvars[0]);
10283+
10284+ rettv->vval.v_number = -1;
10285+ if (channel != NULL)
10286+ {
10287+ char_u *what = get_tv_string(&argvars[1]);
10288+ int part;
10289+
10290+ if (STRCMP(what, "err") == 0)
10291+ part = PART_ERR;
10292+ else if (STRCMP(what, "out") == 0)
10293+ part = PART_OUT;
10294+ else if (STRCMP(what, "in") == 0)
10295+ part = PART_IN;
10296+ else
10297+ part = PART_SOCK;
10298+ if (channel->ch_part[part].ch_buffer != NULL)
10299+ rettv->vval.v_number = channel->ch_part[part].ch_buffer->b_fnum;
10300+ }
10301+ }
10302+
1028110303# ifdef FEAT_JOB
1028210304/*
1028310305 * "ch_getjob()" function
0 commit comments