To: vim_dev@googlegroups.com Subject: Patch 7.4.312 Fcc: outbox From: Bram Moolenaar <Bram@moolenaar.net> Mime-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ------------ Patch 7.4.312 Problem: Cannot figure out what argument list is being used for a window. Solution: Add the arglistid() function. (Marcin Szamotulski) Files: runtime/doc/eval.txt, runtime/doc/usr_41.txt, src/eval.c, src/ex_docmd.c, src/globals.h, src/structs.h, src/main.c *** ../vim-7.4.311/runtime/doc/eval.txt 2014-05-28 16:47:11.396174926 +0200 --- runtime/doc/eval.txt 2014-05-28 18:00:06.248213223 +0200 *************** *** 1716,1721 **** --- 1716,1723 ---- append( {lnum}, {list}) Number append lines {list} below line {lnum} argc() Number number of files in the argument list argidx() Number current index in the argument list + arglistid( [{winnr}, [ {tabnr}]]) + Number argument list id argv( {nr}) String {nr} entry of the argument list argv( ) List the argument list asin( {expr}) Float arc sine of {expr} *************** *** 2103,2108 **** --- 2105,2122 ---- argidx() The result is the current index in the argument list. 0 is the first file. argc() - 1 is the last one. See |arglist|. + *arglistid()* + arglistid([{winnr}, [ {tabnr} ]]) + Return the argument list ID. This is a number which + identifies the argument list being used. Zero is used for the + global argument list. + Return zero if the arguments are invalid. + + Without arguments use the current window. + With {winnr} only use this window in the current tab page. + With {winnr} and {tabnr} use the window in the specified tab + page. + *argv()* argv([{nr}]) The result is the {nr}th file in the argument list of the current window. See |arglist|. "argv(0)" is the first one. *** ../vim-7.4.311/runtime/doc/usr_41.txt 2014-03-25 18:23:27.054087691 +0100 --- runtime/doc/usr_41.txt 2014-05-28 18:07:43.096217222 +0200 *************** *** 770,775 **** --- 772,778 ---- Buffers, windows and the argument list: argc() number of entries in the argument list argidx() current position in the argument list + arglistid() get id of the argument list argv() get one entry from the argument list bufexists() check if a buffer exists buflisted() check if a buffer exists and is listed *** ../vim-7.4.311/src/eval.c 2014-05-28 16:47:11.392174926 +0200 --- src/eval.c 2014-05-28 18:11:10.264219035 +0200 *************** *** 463,468 **** --- 463,469 ---- static void f_append __ARGS((typval_T *argvars, typval_T *rettv)); static void f_argc __ARGS((typval_T *argvars, typval_T *rettv)); static void f_argidx __ARGS((typval_T *argvars, typval_T *rettv)); + static void f_arglistid __ARGS((typval_T *argvars, typval_T *rettv)); static void f_argv __ARGS((typval_T *argvars, typval_T *rettv)); #ifdef FEAT_FLOAT static void f_asin __ARGS((typval_T *argvars, typval_T *rettv)); *************** *** 7875,7880 **** --- 7876,7882 ---- {"append", 2, 2, f_append}, {"argc", 0, 0, f_argc}, {"argidx", 0, 0, f_argidx}, + {"arglistid", 0, 2, f_arglistid}, {"argv", 0, 1, f_argv}, #ifdef FEAT_FLOAT {"asin", 1, 1, f_asin}, /* WJMc */ *************** *** 8859,8864 **** --- 8861,8901 ---- } /* + * "arglistid()" function + */ + static void + f_arglistid(argvars, rettv) + typval_T *argvars UNUSED; + typval_T *rettv; + { + win_T *wp; + tabpage_T *tp = NULL; + long n; + + rettv->vval.v_number = -1; + if (argvars[0].v_type != VAR_UNKNOWN) + { + if (argvars[1].v_type != VAR_UNKNOWN) + { + n = get_tv_number(&argvars[1]); + if (n >= 0) + tp = find_tabpage(n); + } + else + tp = curtab; + + if (tp != NULL) + { + wp = find_win_by_nr(&argvars[0], tp); + if (wp != NULL) + rettv->vval.v_number = wp->w_alist->id; + } + } + else + rettv->vval.v_number = curwin->w_alist->id; + } + + /* * "argv(nr)" function */ static void *** ../vim-7.4.311/src/ex_docmd.c 2014-05-07 21:14:42.913299714 +0200 --- src/ex_docmd.c 2014-05-28 18:10:01.696218435 +0200 *************** *** 7211,7216 **** --- 7211,7217 ---- else { curwin->w_alist->al_refcount = 1; + curwin->w_alist->id = ++max_alist_id; alist_init(curwin->w_alist); } } *** ../vim-7.4.311/src/globals.h 2014-05-22 18:14:27.570224664 +0200 --- src/globals.h 2014-05-28 17:56:53.392211534 +0200 *************** *** 601,606 **** --- 601,607 ---- * to this when the window is using the global argument list. */ EXTERN alist_T global_alist; /* global argument list */ + EXTERN int max_alist_id INIT(= 0); /* the previous argument list id */ EXTERN int arg_had_last INIT(= FALSE); /* accessed last file in global_alist */ *** ../vim-7.4.311/src/structs.h 2014-05-13 20:19:53.573808877 +0200 --- src/structs.h 2014-05-28 17:54:18.312210177 +0200 *************** *** 675,680 **** --- 675,681 ---- { garray_T al_ga; /* growarray with the array of file names */ int al_refcount; /* number of windows using this arglist */ + int id; /* id of this arglist */ } alist_T; /* *** ../vim-7.4.311/src/main.c 2014-04-01 19:55:46.252787300 +0200 --- src/main.c 2014-05-28 18:09:32.040218175 +0200 *************** *** 322,327 **** --- 322,328 ---- init_yank(); /* init yank buffers */ alist_init(&global_alist); /* Init the argument list to empty. */ + global_alist.id = 0; /* * Set the default values for the options. *** ../vim-7.4.311/src/version.c 2014-05-28 16:47:11.396174926 +0200 --- src/version.c 2014-05-28 17:25:32.644195071 +0200 *************** *** 736,737 **** --- 736,739 ---- { /* Add new patch number below this line */ + /**/ + 312, /**/ -- hundred-and-one symptoms of being an internet addict: 222. You send more than 20 personal e-mails a day. /// Bram Moolenaar -- Bram@Moolenaar.net -- 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 ///