patch 8.1.1933: the eval.c file is too big
Problem:    The eval.c file is too big.
Solution:   Move code related to variables to evalvars.c. (Yegappan
            Lakshmanan, closes #4868)
			
			
This commit is contained in:
		
							
								
								
									
										2
									
								
								Filelist
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								Filelist
									
									
									
									
									
								
							| @ -35,6 +35,7 @@ SRC_ALL =	\ | |||||||
| 		src/edit.c \ | 		src/edit.c \ | ||||||
| 		src/eval.c \ | 		src/eval.c \ | ||||||
| 		src/evalfunc.c \ | 		src/evalfunc.c \ | ||||||
|  | 		src/evalvars.c \ | ||||||
| 		src/ex_cmdidxs.h \ | 		src/ex_cmdidxs.h \ | ||||||
| 		src/ex_cmds.c \ | 		src/ex_cmds.c \ | ||||||
| 		src/ex_cmds.h \ | 		src/ex_cmds.h \ | ||||||
| @ -188,6 +189,7 @@ SRC_ALL =	\ | |||||||
| 		src/proto/edit.pro \ | 		src/proto/edit.pro \ | ||||||
| 		src/proto/eval.pro \ | 		src/proto/eval.pro \ | ||||||
| 		src/proto/evalfunc.pro \ | 		src/proto/evalfunc.pro \ | ||||||
|  | 		src/proto/evalvars.pro \ | ||||||
| 		src/proto/ex_cmds.pro \ | 		src/proto/ex_cmds.pro \ | ||||||
| 		src/proto/ex_cmds2.pro \ | 		src/proto/ex_cmds2.pro \ | ||||||
| 		src/proto/ex_docmd.pro \ | 		src/proto/ex_docmd.pro \ | ||||||
|  | |||||||
| @ -722,6 +722,7 @@ OBJ = \ | |||||||
| 	$(OUTDIR)/edit.o \ | 	$(OUTDIR)/edit.o \ | ||||||
| 	$(OUTDIR)/eval.o \ | 	$(OUTDIR)/eval.o \ | ||||||
| 	$(OUTDIR)/evalfunc.o \ | 	$(OUTDIR)/evalfunc.o \ | ||||||
|  | 	$(OUTDIR)/evalvars.o \ | ||||||
| 	$(OUTDIR)/ex_cmds.o \ | 	$(OUTDIR)/ex_cmds.o \ | ||||||
| 	$(OUTDIR)/ex_cmds2.o \ | 	$(OUTDIR)/ex_cmds2.o \ | ||||||
| 	$(OUTDIR)/ex_docmd.o \ | 	$(OUTDIR)/ex_docmd.o \ | ||||||
|  | |||||||
| @ -42,6 +42,7 @@ SRC =	arabic.c						\ | |||||||
| 	edit.c							\ | 	edit.c							\ | ||||||
| 	eval.c							\ | 	eval.c							\ | ||||||
| 	evalfunc.c						\ | 	evalfunc.c						\ | ||||||
|  | 	evalvars.c						\ | ||||||
| 	ex_cmds.c						\ | 	ex_cmds.c						\ | ||||||
| 	ex_cmds2.c						\ | 	ex_cmds2.c						\ | ||||||
| 	ex_docmd.c						\ | 	ex_docmd.c						\ | ||||||
|  | |||||||
| @ -731,6 +731,7 @@ OBJ = \ | |||||||
| 	$(OUTDIR)\edit.obj \ | 	$(OUTDIR)\edit.obj \ | ||||||
| 	$(OUTDIR)\eval.obj \ | 	$(OUTDIR)\eval.obj \ | ||||||
| 	$(OUTDIR)\evalfunc.obj \ | 	$(OUTDIR)\evalfunc.obj \ | ||||||
|  | 	$(OUTDIR)\evalvars.obj \ | ||||||
| 	$(OUTDIR)\ex_cmds.obj \ | 	$(OUTDIR)\ex_cmds.obj \ | ||||||
| 	$(OUTDIR)\ex_cmds2.obj \ | 	$(OUTDIR)\ex_cmds2.obj \ | ||||||
| 	$(OUTDIR)\ex_docmd.obj \ | 	$(OUTDIR)\ex_docmd.obj \ | ||||||
| @ -1486,6 +1487,8 @@ $(OUTDIR)/eval.obj:	$(OUTDIR) eval.c  $(INCL) | |||||||
|  |  | ||||||
| $(OUTDIR)/evalfunc.obj:	$(OUTDIR) evalfunc.c  $(INCL) | $(OUTDIR)/evalfunc.obj:	$(OUTDIR) evalfunc.c  $(INCL) | ||||||
|  |  | ||||||
|  | $(OUTDIR)/evalvars.obj:	$(OUTDIR) evalvars.c  $(INCL) | ||||||
|  |  | ||||||
| $(OUTDIR)/ex_cmds.obj:	$(OUTDIR) ex_cmds.c  $(INCL) | $(OUTDIR)/ex_cmds.obj:	$(OUTDIR) ex_cmds.c  $(INCL) | ||||||
|  |  | ||||||
| $(OUTDIR)/ex_cmds2.obj:	$(OUTDIR) ex_cmds2.c  $(INCL) | $(OUTDIR)/ex_cmds2.obj:	$(OUTDIR) ex_cmds2.c  $(INCL) | ||||||
| @ -1771,6 +1774,7 @@ proto.h: \ | |||||||
| 	proto/edit.pro \ | 	proto/edit.pro \ | ||||||
| 	proto/eval.pro \ | 	proto/eval.pro \ | ||||||
| 	proto/evalfunc.pro \ | 	proto/evalfunc.pro \ | ||||||
|  | 	proto/evalvars.pro \ | ||||||
| 	proto/ex_cmds.pro \ | 	proto/ex_cmds.pro \ | ||||||
| 	proto/ex_cmds2.pro \ | 	proto/ex_cmds2.pro \ | ||||||
| 	proto/ex_docmd.pro \ | 	proto/ex_docmd.pro \ | ||||||
|  | |||||||
| @ -309,7 +309,8 @@ ALL_LIBS = $(LIBS) $(GUI_LIB_DIR) $(GUI_LIB) \ | |||||||
|  |  | ||||||
| SRC =	arabic.c arglist.c autocmd.c beval.c blob.c blowfish.c buffer.c \ | SRC =	arabic.c arglist.c autocmd.c beval.c blob.c blowfish.c buffer.c \ | ||||||
| 	change.c charset.c cmdexpand.c cmdhist.c crypt.c crypt_zip.c \ | 	change.c charset.c cmdexpand.c cmdhist.c crypt.c crypt_zip.c \ | ||||||
| 	debugger.c dict.c diff.c digraph.c edit.c eval.c evalfunc.c ex_cmds.c \ | 	debugger.c dict.c diff.c digraph.c edit.c eval.c evalfunc.c \ | ||||||
|  | 	evalvars.c ex_cmds.c \ | ||||||
| 	ex_cmds2.c ex_docmd.c ex_eval.c ex_getln.c if_cscope.c if_xcmdsrv.c \ | 	ex_cmds2.c ex_docmd.c ex_eval.c ex_getln.c if_cscope.c if_xcmdsrv.c \ | ||||||
| 	fileio.c findfile.c fold.c getchar.c hardcopy.c hashtab.c highlight.c \ | 	fileio.c findfile.c fold.c getchar.c hardcopy.c hashtab.c highlight.c \ | ||||||
| 	indent.c insexpand.c json.c list.c main.c map.c mark.c menu.c mbyte.c \ | 	indent.c insexpand.c json.c list.c main.c map.c mark.c menu.c mbyte.c \ | ||||||
| @ -326,7 +327,8 @@ SRC =	arabic.c arglist.c autocmd.c beval.c blob.c blowfish.c buffer.c \ | |||||||
| OBJ = 	arabic.obj arglist.obj autocmd.obj beval.obj blob.obj blowfish.obj \ | OBJ = 	arabic.obj arglist.obj autocmd.obj beval.obj blob.obj blowfish.obj \ | ||||||
| 	buffer.obj change.obj charset.obj cmdexpand.obj cmdhist.obj \ | 	buffer.obj change.obj charset.obj cmdexpand.obj cmdhist.obj \ | ||||||
| 	crypt.obj crypt_zip.obj debugger.obj dict.obj diff.obj digraph.obj \ | 	crypt.obj crypt_zip.obj debugger.obj dict.obj diff.obj digraph.obj \ | ||||||
| 	edit.obj eval.obj evalfunc.obj ex_cmds.obj ex_cmds2.obj ex_docmd.obj \ | 	edit.obj eval.obj evalfunc.obj evalvars.obj ex_cmds.obj ex_cmds2.obj \ | ||||||
|  | 	ex_docmd.obj \ | ||||||
| 	ex_eval.obj ex_getln.obj if_cscope.obj if_xcmdsrv.obj fileio.obj \ | 	ex_eval.obj ex_getln.obj if_cscope.obj if_xcmdsrv.obj fileio.obj \ | ||||||
| 	findfile.obj fold.obj getchar.obj hardcopy.obj hashtab.obj \ | 	findfile.obj fold.obj getchar.obj hardcopy.obj hashtab.obj \ | ||||||
| 	highlight.obj indent.obj insexpand.obj json.obj list.obj main.obj \ | 	highlight.obj indent.obj insexpand.obj json.obj list.obj main.obj \ | ||||||
| @ -569,6 +571,10 @@ evalfunc.obj : evalfunc.c vim.h [.auto]config.h feature.h os_unix.h \ | |||||||
|  ascii.h keymap.h term.h macros.h option.h structs.h \ |  ascii.h keymap.h term.h macros.h option.h structs.h \ | ||||||
|  regexp.h gui.h beval.h [.proto]gui_beval.pro alloc.h ex_cmds.h spell.h \ |  regexp.h gui.h beval.h [.proto]gui_beval.pro alloc.h ex_cmds.h spell.h \ | ||||||
|  proto.h globals.h version.h |  proto.h globals.h version.h | ||||||
|  | evalvars.obj : evalvars.c vim.h [.auto]config.h feature.h os_unix.h \ | ||||||
|  |  ascii.h keymap.h term.h macros.h option.h structs.h \ | ||||||
|  |  regexp.h gui.h beval.h [.proto]gui_beval.pro alloc.h ex_cmds.h spell.h \ | ||||||
|  |  proto.h globals.h version.h | ||||||
| ex_cmds.obj : ex_cmds.c vim.h [.auto]config.h feature.h os_unix.h \ | ex_cmds.obj : ex_cmds.c vim.h [.auto]config.h feature.h os_unix.h \ | ||||||
|  ascii.h keymap.h term.h macros.h structs.h regexp.h \ |  ascii.h keymap.h term.h macros.h structs.h regexp.h \ | ||||||
|  gui.h beval.h [.proto]gui_beval.pro option.h ex_cmds.h proto.h \ |  gui.h beval.h [.proto]gui_beval.pro option.h ex_cmds.h proto.h \ | ||||||
|  | |||||||
							
								
								
									
										10
									
								
								src/Makefile
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								src/Makefile
									
									
									
									
									
								
							| @ -1596,6 +1596,7 @@ BASIC_SRC = \ | |||||||
| 	edit.c \ | 	edit.c \ | ||||||
| 	eval.c \ | 	eval.c \ | ||||||
| 	evalfunc.c \ | 	evalfunc.c \ | ||||||
|  | 	evalvars.c \ | ||||||
| 	ex_cmds.c \ | 	ex_cmds.c \ | ||||||
| 	ex_cmds2.c \ | 	ex_cmds2.c \ | ||||||
| 	ex_docmd.c \ | 	ex_docmd.c \ | ||||||
| @ -1725,6 +1726,7 @@ OBJ_COMMON = \ | |||||||
| 	objects/edit.o \ | 	objects/edit.o \ | ||||||
| 	objects/eval.o \ | 	objects/eval.o \ | ||||||
| 	objects/evalfunc.o \ | 	objects/evalfunc.o \ | ||||||
|  | 	objects/evalvars.o \ | ||||||
| 	objects/ex_cmds.o \ | 	objects/ex_cmds.o \ | ||||||
| 	objects/ex_cmds2.o \ | 	objects/ex_cmds2.o \ | ||||||
| 	objects/ex_docmd.o \ | 	objects/ex_docmd.o \ | ||||||
| @ -1867,6 +1869,7 @@ PRO_AUTO = \ | |||||||
| 	edit.pro \ | 	edit.pro \ | ||||||
| 	eval.pro \ | 	eval.pro \ | ||||||
| 	evalfunc.pro \ | 	evalfunc.pro \ | ||||||
|  | 	evalvars.pro \ | ||||||
| 	ex_cmds.pro \ | 	ex_cmds.pro \ | ||||||
| 	ex_cmds2.pro \ | 	ex_cmds2.pro \ | ||||||
| 	ex_docmd.pro \ | 	ex_docmd.pro \ | ||||||
| @ -3052,6 +3055,9 @@ objects/eval.o: eval.c | |||||||
| objects/evalfunc.o: evalfunc.c | objects/evalfunc.o: evalfunc.c | ||||||
| 	$(CCC) -o $@ evalfunc.c | 	$(CCC) -o $@ evalfunc.c | ||||||
|  |  | ||||||
|  | objects/evalvars.o: evalvars.c | ||||||
|  | 	$(CCC) -o $@ evalvars.c | ||||||
|  |  | ||||||
| objects/ex_cmds.o: ex_cmds.c | objects/ex_cmds.o: ex_cmds.c | ||||||
| 	$(CCC) -o $@ ex_cmds.c | 	$(CCC) -o $@ ex_cmds.c | ||||||
|  |  | ||||||
| @ -3570,6 +3576,10 @@ objects/evalfunc.o: evalfunc.c vim.h protodef.h auto/config.h feature.h os_unix. | |||||||
|  auto/osdef.h ascii.h keymap.h term.h macros.h option.h beval.h \ |  auto/osdef.h ascii.h keymap.h term.h macros.h option.h beval.h \ | ||||||
|  proto/gui_beval.pro structs.h regexp.h gui.h alloc.h ex_cmds.h spell.h \ |  proto/gui_beval.pro structs.h regexp.h gui.h alloc.h ex_cmds.h spell.h \ | ||||||
|  proto.h globals.h version.h |  proto.h globals.h version.h | ||||||
|  | objects/evalvars.o: evalvars.c vim.h protodef.h auto/config.h feature.h \ | ||||||
|  |  os_unix.h auto/osdef.h ascii.h keymap.h term.h macros.h option.h beval.h \ | ||||||
|  |  proto/gui_beval.pro structs.h regexp.h gui.h alloc.h ex_cmds.h spell.h \ | ||||||
|  |  proto.h globals.h | ||||||
| objects/ex_cmds.o: ex_cmds.c vim.h protodef.h auto/config.h feature.h os_unix.h \ | objects/ex_cmds.o: ex_cmds.c vim.h protodef.h auto/config.h feature.h os_unix.h \ | ||||||
|  auto/osdef.h ascii.h keymap.h term.h macros.h option.h beval.h \ |  auto/osdef.h ascii.h keymap.h term.h macros.h option.h beval.h \ | ||||||
|  proto/gui_beval.pro structs.h regexp.h gui.h alloc.h ex_cmds.h spell.h \ |  proto/gui_beval.pro structs.h regexp.h gui.h alloc.h ex_cmds.h spell.h \ | ||||||
|  | |||||||
| @ -34,6 +34,7 @@ debugger.c	| vim script debugger | |||||||
| diff.c		| diff mode (vimdiff) | diff.c		| diff mode (vimdiff) | ||||||
| eval.c		| expression evaluation | eval.c		| expression evaluation | ||||||
| evalfunc.c	| built-in functions | evalfunc.c	| built-in functions | ||||||
|  | evalvars.c	| vim variables | ||||||
| fileio.c	| reading and writing files | fileio.c	| reading and writing files | ||||||
| findfile.c	| search for files in 'path' | findfile.c	| search for files in 'path' | ||||||
| fold.c		| folding | fold.c		| folding | ||||||
|  | |||||||
							
								
								
									
										1907
									
								
								src/eval.c
									
									
									
									
									
								
							
							
						
						
									
										1907
									
								
								src/eval.c
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										125
									
								
								src/evalfunc.c
									
									
									
									
									
								
							
							
						
						
									
										125
									
								
								src/evalfunc.c
									
									
									
									
									
								
							| @ -155,14 +155,11 @@ static void f_getqflist(typval_T *argvars, typval_T *rettv); | |||||||
| static void f_getreg(typval_T *argvars, typval_T *rettv); | static void f_getreg(typval_T *argvars, typval_T *rettv); | ||||||
| static void f_getregtype(typval_T *argvars, typval_T *rettv); | static void f_getregtype(typval_T *argvars, typval_T *rettv); | ||||||
| static void f_gettabinfo(typval_T *argvars, typval_T *rettv); | static void f_gettabinfo(typval_T *argvars, typval_T *rettv); | ||||||
| static void f_gettabvar(typval_T *argvars, typval_T *rettv); |  | ||||||
| static void f_gettabwinvar(typval_T *argvars, typval_T *rettv); |  | ||||||
| static void f_gettagstack(typval_T *argvars, typval_T *rettv); | static void f_gettagstack(typval_T *argvars, typval_T *rettv); | ||||||
| static void f_getwininfo(typval_T *argvars, typval_T *rettv); | static void f_getwininfo(typval_T *argvars, typval_T *rettv); | ||||||
| static void f_getwinpos(typval_T *argvars, typval_T *rettv); | static void f_getwinpos(typval_T *argvars, typval_T *rettv); | ||||||
| static void f_getwinposx(typval_T *argvars, typval_T *rettv); | static void f_getwinposx(typval_T *argvars, typval_T *rettv); | ||||||
| static void f_getwinposy(typval_T *argvars, typval_T *rettv); | static void f_getwinposy(typval_T *argvars, typval_T *rettv); | ||||||
| static void f_getwinvar(typval_T *argvars, typval_T *rettv); |  | ||||||
| static void f_glob(typval_T *argvars, typval_T *rettv); | static void f_glob(typval_T *argvars, typval_T *rettv); | ||||||
| static void f_globpath(typval_T *argvars, typval_T *rettv); | static void f_globpath(typval_T *argvars, typval_T *rettv); | ||||||
| static void f_glob2regpat(typval_T *argvars, typval_T *rettv); | static void f_glob2regpat(typval_T *argvars, typval_T *rettv); | ||||||
| @ -293,10 +290,7 @@ static void f_setloclist(typval_T *argvars, typval_T *rettv); | |||||||
| static void f_setpos(typval_T *argvars, typval_T *rettv); | static void f_setpos(typval_T *argvars, typval_T *rettv); | ||||||
| static void f_setqflist(typval_T *argvars, typval_T *rettv); | static void f_setqflist(typval_T *argvars, typval_T *rettv); | ||||||
| static void f_setreg(typval_T *argvars, typval_T *rettv); | static void f_setreg(typval_T *argvars, typval_T *rettv); | ||||||
| static void f_settabvar(typval_T *argvars, typval_T *rettv); |  | ||||||
| static void f_settabwinvar(typval_T *argvars, typval_T *rettv); |  | ||||||
| static void f_settagstack(typval_T *argvars, typval_T *rettv); | static void f_settagstack(typval_T *argvars, typval_T *rettv); | ||||||
| static void f_setwinvar(typval_T *argvars, typval_T *rettv); |  | ||||||
| #ifdef FEAT_CRYPT | #ifdef FEAT_CRYPT | ||||||
| static void f_sha256(typval_T *argvars, typval_T *rettv); | static void f_sha256(typval_T *argvars, typval_T *rettv); | ||||||
| #endif /* FEAT_CRYPT */ | #endif /* FEAT_CRYPT */ | ||||||
| @ -5314,58 +5308,6 @@ f_gettabinfo(typval_T *argvars, typval_T *rettv) | |||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * "gettabvar()" function |  | ||||||
|  */ |  | ||||||
|     static void |  | ||||||
| f_gettabvar(typval_T *argvars, typval_T *rettv) |  | ||||||
| { |  | ||||||
|     win_T	*oldcurwin; |  | ||||||
|     tabpage_T	*tp, *oldtabpage; |  | ||||||
|     dictitem_T	*v; |  | ||||||
|     char_u	*varname; |  | ||||||
|     int		done = FALSE; |  | ||||||
|  |  | ||||||
|     rettv->v_type = VAR_STRING; |  | ||||||
|     rettv->vval.v_string = NULL; |  | ||||||
|  |  | ||||||
|     varname = tv_get_string_chk(&argvars[1]); |  | ||||||
|     tp = find_tabpage((int)tv_get_number_chk(&argvars[0], NULL)); |  | ||||||
|     if (tp != NULL && varname != NULL) |  | ||||||
|     { |  | ||||||
| 	/* Set tp to be our tabpage, temporarily.  Also set the window to the |  | ||||||
| 	 * first window in the tabpage, otherwise the window is not valid. */ |  | ||||||
| 	if (switch_win(&oldcurwin, &oldtabpage, |  | ||||||
| 		tp == curtab || tp->tp_firstwin == NULL ? firstwin |  | ||||||
| 					    : tp->tp_firstwin, tp, TRUE) == OK) |  | ||||||
| 	{ |  | ||||||
| 	    /* look up the variable */ |  | ||||||
| 	    /* Let gettabvar({nr}, "") return the "t:" dictionary. */ |  | ||||||
| 	    v = find_var_in_ht(&tp->tp_vars->dv_hashtab, 't', varname, FALSE); |  | ||||||
| 	    if (v != NULL) |  | ||||||
| 	    { |  | ||||||
| 		copy_tv(&v->di_tv, rettv); |  | ||||||
| 		done = TRUE; |  | ||||||
| 	    } |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	/* restore previous notion of curwin */ |  | ||||||
| 	restore_win(oldcurwin, oldtabpage, TRUE); |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     if (!done && argvars[2].v_type != VAR_UNKNOWN) |  | ||||||
| 	copy_tv(&argvars[2], rettv); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * "gettabwinvar()" function |  | ||||||
|  */ |  | ||||||
|     static void |  | ||||||
| f_gettabwinvar(typval_T *argvars, typval_T *rettv) |  | ||||||
| { |  | ||||||
|     getwinvar(argvars, rettv, 1); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * "gettagstack()" function |  * "gettagstack()" function | ||||||
|  */ |  */ | ||||||
| @ -5624,15 +5566,6 @@ f_getwinposy(typval_T *argvars UNUSED, typval_T *rettv) | |||||||
| #endif | #endif | ||||||
| } | } | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * "getwinvar()" function |  | ||||||
|  */ |  | ||||||
|     static void |  | ||||||
| f_getwinvar(typval_T *argvars, typval_T *rettv) |  | ||||||
| { |  | ||||||
|     getwinvar(argvars, rettv, 0); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * "glob()" function |  * "glob()" function | ||||||
|  */ |  */ | ||||||
| @ -10242,55 +10175,6 @@ free_lstval: | |||||||
|     rettv->vval.v_number = 0; |     rettv->vval.v_number = 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * "settabvar()" function |  | ||||||
|  */ |  | ||||||
|     static void |  | ||||||
| f_settabvar(typval_T *argvars, typval_T *rettv) |  | ||||||
| { |  | ||||||
|     tabpage_T	*save_curtab; |  | ||||||
|     tabpage_T	*tp; |  | ||||||
|     char_u	*varname, *tabvarname; |  | ||||||
|     typval_T	*varp; |  | ||||||
|  |  | ||||||
|     rettv->vval.v_number = 0; |  | ||||||
|  |  | ||||||
|     if (check_secure()) |  | ||||||
| 	return; |  | ||||||
|  |  | ||||||
|     tp = find_tabpage((int)tv_get_number_chk(&argvars[0], NULL)); |  | ||||||
|     varname = tv_get_string_chk(&argvars[1]); |  | ||||||
|     varp = &argvars[2]; |  | ||||||
|  |  | ||||||
|     if (varname != NULL && varp != NULL && tp != NULL) |  | ||||||
|     { |  | ||||||
| 	save_curtab = curtab; |  | ||||||
| 	goto_tabpage_tp(tp, FALSE, FALSE); |  | ||||||
|  |  | ||||||
| 	tabvarname = alloc(STRLEN(varname) + 3); |  | ||||||
| 	if (tabvarname != NULL) |  | ||||||
| 	{ |  | ||||||
| 	    STRCPY(tabvarname, "t:"); |  | ||||||
| 	    STRCPY(tabvarname + 2, varname); |  | ||||||
| 	    set_var(tabvarname, varp, TRUE); |  | ||||||
| 	    vim_free(tabvarname); |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
| 	/* Restore current tabpage */ |  | ||||||
| 	if (valid_tabpage(save_curtab)) |  | ||||||
| 	    goto_tabpage_tp(save_curtab, FALSE, FALSE); |  | ||||||
|     } |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * "settabwinvar()" function |  | ||||||
|  */ |  | ||||||
|     static void |  | ||||||
| f_settabwinvar(typval_T *argvars, typval_T *rettv) |  | ||||||
| { |  | ||||||
|     setwinvar(argvars, rettv, 1); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * "settagstack()" function |  * "settagstack()" function | ||||||
|  */ |  */ | ||||||
| @ -10347,15 +10231,6 @@ f_settagstack(typval_T *argvars, typval_T *rettv) | |||||||
| 	rettv->vval.v_number = 0; | 	rettv->vval.v_number = 0; | ||||||
| } | } | ||||||
|  |  | ||||||
| /* |  | ||||||
|  * "setwinvar()" function |  | ||||||
|  */ |  | ||||||
|     static void |  | ||||||
| f_setwinvar(typval_T *argvars, typval_T *rettv) |  | ||||||
| { |  | ||||||
|     setwinvar(argvars, rettv, 0); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| #ifdef FEAT_CRYPT | #ifdef FEAT_CRYPT | ||||||
| /* | /* | ||||||
|  * "sha256({string})" function |  * "sha256({string})" function | ||||||
|  | |||||||
							
								
								
									
										1946
									
								
								src/evalvars.c
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1946
									
								
								src/evalvars.c
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -1547,6 +1547,10 @@ EXTERN char e_re_damg[]	INIT(= N_("E43: Damaged match string")); | |||||||
| EXTERN char e_re_corr[]	INIT(= N_("E44: Corrupted regexp program")); | EXTERN char e_re_corr[]	INIT(= N_("E44: Corrupted regexp program")); | ||||||
| EXTERN char e_readonly[]	INIT(= N_("E45: 'readonly' option is set (add ! to override)")); | EXTERN char e_readonly[]	INIT(= N_("E45: 'readonly' option is set (add ! to override)")); | ||||||
| #ifdef FEAT_EVAL | #ifdef FEAT_EVAL | ||||||
|  | EXTERN char e_undefvar[]	INIT(= N_("E121: Undefined variable: %s")); | ||||||
|  | EXTERN char e_letwrong[]	INIT(= N_("E734: Wrong variable type for %s=")); | ||||||
|  | EXTERN char e_illvar[]		INIT(= N_("E461: Illegal variable name: %s")); | ||||||
|  | EXTERN char e_cannot_mod[]	INIT(= N_("E995: Cannot modify existing variable")); | ||||||
| EXTERN char e_readonlyvar[]	INIT(= N_("E46: Cannot change read-only variable \"%s\"")); | EXTERN char e_readonlyvar[]	INIT(= N_("E46: Cannot change read-only variable \"%s\"")); | ||||||
| EXTERN char e_readonlysbx[]	INIT(= N_("E794: Cannot set variable in the sandbox: \"%s\"")); | EXTERN char e_readonlysbx[]	INIT(= N_("E794: Cannot set variable in the sandbox: \"%s\"")); | ||||||
| EXTERN char e_emptykey[]	INIT(= N_("E713: Cannot use empty key for Dictionary")); | EXTERN char e_emptykey[]	INIT(= N_("E713: Cannot use empty key for Dictionary")); | ||||||
|  | |||||||
| @ -112,6 +112,7 @@ extern int _stricoll(char *a, char *b); | |||||||
| # ifdef FEAT_VIMINFO | # ifdef FEAT_VIMINFO | ||||||
| # include "viminfo.pro" | # include "viminfo.pro" | ||||||
| # endif | # endif | ||||||
|  | # include "evalvars.pro" | ||||||
|  |  | ||||||
| /* These prototypes cannot be produced automatically. */ | /* These prototypes cannot be produced automatically. */ | ||||||
| int smsg(const char *, ...) | int smsg(const char *, ...) | ||||||
|  | |||||||
| @ -1,4 +1,6 @@ | |||||||
| /* eval.c */ | /* eval.c */ | ||||||
|  | varnumber_T num_divide(varnumber_T n1, varnumber_T n2); | ||||||
|  | varnumber_T num_modulus(varnumber_T n1, varnumber_T n2); | ||||||
| void eval_init(void); | void eval_init(void); | ||||||
| void eval_clear(void); | void eval_clear(void); | ||||||
| void set_internal_string_var(char_u *name, char_u *value); | void set_internal_string_var(char_u *name, char_u *value); | ||||||
| @ -17,6 +19,10 @@ int skip_expr(char_u **pp); | |||||||
| char_u *eval_to_string(char_u *arg, char_u **nextcmd, int convert); | char_u *eval_to_string(char_u *arg, char_u **nextcmd, int convert); | ||||||
| char_u *eval_to_string_safe(char_u *arg, char_u **nextcmd, int use_sandbox); | char_u *eval_to_string_safe(char_u *arg, char_u **nextcmd, int use_sandbox); | ||||||
| varnumber_T eval_to_number(char_u *expr); | varnumber_T eval_to_number(char_u *expr); | ||||||
|  | void list_vim_vars(int *first); | ||||||
|  | void list_script_vars(int *first); | ||||||
|  | int is_vimvarht(hashtab_T *ht); | ||||||
|  | int is_compatht(hashtab_T *ht); | ||||||
| void prepare_vimvar(int idx, typval_T *save_tv); | void prepare_vimvar(int idx, typval_T *save_tv); | ||||||
| void restore_vimvar(int idx, typval_T *save_tv); | void restore_vimvar(int idx, typval_T *save_tv); | ||||||
| list_T *eval_spell_expr(char_u *badword, char_u *expr); | list_T *eval_spell_expr(char_u *badword, char_u *expr); | ||||||
| @ -27,18 +33,13 @@ varnumber_T call_func_retnr(char_u *func, int argc, typval_T *argv); | |||||||
| void *call_func_retstr(char_u *func, int argc, typval_T *argv); | void *call_func_retstr(char_u *func, int argc, typval_T *argv); | ||||||
| void *call_func_retlist(char_u *func, int argc, typval_T *argv); | void *call_func_retlist(char_u *func, int argc, typval_T *argv); | ||||||
| int eval_foldexpr(char_u *arg, int *cp); | int eval_foldexpr(char_u *arg, int *cp); | ||||||
| void ex_let(exarg_T *eap); |  | ||||||
| void ex_const(exarg_T *eap); |  | ||||||
| void list_hashtable_vars(hashtab_T *ht, char *prefix, int empty, int *first); |  | ||||||
| char_u *get_lval(char_u *name, typval_T *rettv, lval_T *lp, int unlet, int skip, int flags, int fne_flags); | char_u *get_lval(char_u *name, typval_T *rettv, lval_T *lp, int unlet, int skip, int flags, int fne_flags); | ||||||
| void clear_lval(lval_T *lp); | void clear_lval(lval_T *lp); | ||||||
|  | void set_var_lval(lval_T *lp, char_u *endp, typval_T *rettv, int copy, int is_const, char_u *op); | ||||||
| void *eval_for_line(char_u *arg, int *errp, char_u **nextcmdp, int skip); | void *eval_for_line(char_u *arg, int *errp, char_u **nextcmdp, int skip); | ||||||
| int next_for_item(void *fi_void, char_u *arg); | int next_for_item(void *fi_void, char_u *arg); | ||||||
| void free_for_info(void *fi_void); | void free_for_info(void *fi_void); | ||||||
| void set_context_for_expression(expand_T *xp, char_u *arg, cmdidx_T cmdidx); | void set_context_for_expression(expand_T *xp, char_u *arg, cmdidx_T cmdidx); | ||||||
| void ex_unlet(exarg_T *eap); |  | ||||||
| void ex_lockvar(exarg_T *eap); |  | ||||||
| int do_unlet(char_u *name, int forceit); |  | ||||||
| void del_menutrans_vars(void); | void del_menutrans_vars(void); | ||||||
| char_u *get_user_var_name(expand_T *xp, int idx); | char_u *get_user_var_name(expand_T *xp, int idx); | ||||||
| int pattern_match(char_u *pat, char_u *text, int ic); | int pattern_match(char_u *pat, char_u *text, int ic); | ||||||
| @ -62,7 +63,9 @@ char_u *string_quote(char_u *str, int function); | |||||||
| int string2float(char_u *text, float_T *value); | int string2float(char_u *text, float_T *value); | ||||||
| pos_T *var2fpos(typval_T *varp, int dollar_lnum, int *fnum); | pos_T *var2fpos(typval_T *varp, int dollar_lnum, int *fnum); | ||||||
| int list2fpos(typval_T *arg, pos_T *posp, int *fnump, colnr_T *curswantp); | int list2fpos(typval_T *arg, pos_T *posp, int *fnump, colnr_T *curswantp); | ||||||
|  | int get_env_len(char_u **arg); | ||||||
| int get_id_len(char_u **arg); | int get_id_len(char_u **arg); | ||||||
|  | int get_name_len(char_u **arg, char_u **alias, int evaluate, int verbose); | ||||||
| char_u *find_name_end(char_u *arg, char_u **expr_start, char_u **expr_end, int flags); | char_u *find_name_end(char_u *arg, char_u **expr_start, char_u **expr_end, int flags); | ||||||
| int eval_isnamec(int c); | int eval_isnamec(int c); | ||||||
| int eval_isnamec1(int c); | int eval_isnamec1(int c); | ||||||
| @ -98,18 +101,9 @@ char_u *tv_get_string_buf_chk(typval_T *varp, char_u *buf); | |||||||
| dictitem_T *find_var(char_u *name, hashtab_T **htp, int no_autoload); | dictitem_T *find_var(char_u *name, hashtab_T **htp, int no_autoload); | ||||||
| dictitem_T *find_var_in_ht(hashtab_T *ht, int htname, char_u *varname, int no_autoload); | dictitem_T *find_var_in_ht(hashtab_T *ht, int htname, char_u *varname, int no_autoload); | ||||||
| hashtab_T *find_var_ht(char_u *name, char_u **varname); | hashtab_T *find_var_ht(char_u *name, char_u **varname); | ||||||
| char_u *get_var_value(char_u *name); |  | ||||||
| void new_script_vars(scid_T id); | void new_script_vars(scid_T id); | ||||||
| void init_var_dict(dict_T *dict, dictitem_T *dict_var, int scope); | void init_var_dict(dict_T *dict, dictitem_T *dict_var, int scope); | ||||||
| void unref_var_dict(dict_T *dict); | void unref_var_dict(dict_T *dict); | ||||||
| void vars_clear(hashtab_T *ht); |  | ||||||
| void vars_clear_ext(hashtab_T *ht, int free_val); |  | ||||||
| void set_var(char_u *name, typval_T *tv, int copy); |  | ||||||
| int var_check_ro(int flags, char_u *name, int use_gettext); |  | ||||||
| int var_check_fixed(int flags, char_u *name, int use_gettext); |  | ||||||
| int var_check_func_name(char_u *name, int new_var); |  | ||||||
| int var_check_lock(int lock, char_u *name, int use_gettext); |  | ||||||
| int valid_varname(char_u *varname); |  | ||||||
| void copy_tv(typval_T *from, typval_T *to); | void copy_tv(typval_T *from, typval_T *to); | ||||||
| int item_copy(typval_T *from, typval_T *to, int deep, int copyID); | int item_copy(typval_T *from, typval_T *to, int deep, int copyID); | ||||||
| void get_user_input(typval_T *argvars, typval_T *rettv, int inputdialog, int secret); | void get_user_input(typval_T *argvars, typval_T *rettv, int inputdialog, int secret); | ||||||
| @ -119,8 +113,7 @@ void ex_execute(exarg_T *eap); | |||||||
| win_T *find_win_by_nr(typval_T *vp, tabpage_T *tp); | win_T *find_win_by_nr(typval_T *vp, tabpage_T *tp); | ||||||
| win_T *find_win_by_nr_or_id(typval_T *vp); | win_T *find_win_by_nr_or_id(typval_T *vp); | ||||||
| win_T *find_tabwin(typval_T *wvp, typval_T *tvp, tabpage_T **ptp); | win_T *find_tabwin(typval_T *wvp, typval_T *tvp, tabpage_T **ptp); | ||||||
| void getwinvar(typval_T *argvars, typval_T *rettv, int off); | char_u *find_option_end(char_u **arg, int *opt_flags); | ||||||
| void setwinvar(typval_T *argvars, typval_T *rettv, int off); |  | ||||||
| char_u *autoload_name(char_u *name); | char_u *autoload_name(char_u *name); | ||||||
| int script_autoload(char_u *name, int reload); | int script_autoload(char_u *name, int reload); | ||||||
| void last_set_msg(sctx_T script_ctx); | void last_set_msg(sctx_T script_ctx); | ||||||
| @ -128,7 +121,6 @@ void reset_v_option_vars(void); | |||||||
| void assert_error(garray_T *gap); | void assert_error(garray_T *gap); | ||||||
| int typval_compare(typval_T *typ1, typval_T *typ2, exptype_T type, int type_is, int ic); | int typval_compare(typval_T *typ1, typval_T *typ2, exptype_T type, int type_is, int ic); | ||||||
| char_u *typval_tostring(typval_T *arg); | char_u *typval_tostring(typval_T *arg); | ||||||
| int var_exists(char_u *var); |  | ||||||
| int modify_fname(char_u *src, int tilde_file, int *usedlen, char_u **fnamep, char_u **bufp, int *fnamelen); | int modify_fname(char_u *src, int tilde_file, int *usedlen, char_u **fnamep, char_u **bufp, int *fnamelen); | ||||||
| char_u *do_string_sub(char_u *str, char_u *pat, char_u *sub, typval_T *expr, char_u *flags); | char_u *do_string_sub(char_u *str, char_u *pat, char_u *sub, typval_T *expr, char_u *flags); | ||||||
| void filter_map(typval_T *argvars, typval_T *rettv, int map); | void filter_map(typval_T *argvars, typval_T *rettv, int map); | ||||||
|  | |||||||
							
								
								
									
										29
									
								
								src/proto/evalvars.pro
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								src/proto/evalvars.pro
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,29 @@ | |||||||
|  | /* evalvars.c */ | ||||||
|  | void ex_let(exarg_T *eap); | ||||||
|  | void ex_const(exarg_T *eap); | ||||||
|  | int ex_let_vars(char_u *arg_start, typval_T *tv, int copy, int semicolon, int var_count, int is_const, char_u *op); | ||||||
|  | char_u *skip_var_list(char_u *arg, int *var_count, int *semicolon); | ||||||
|  | void list_hashtable_vars(hashtab_T *ht, char *prefix, int empty, int *first); | ||||||
|  | void ex_unlet(exarg_T *eap); | ||||||
|  | void ex_lockvar(exarg_T *eap); | ||||||
|  | int do_unlet(char_u *name, int forceit); | ||||||
|  | int get_var_tv(char_u *name, int len, typval_T *rettv, dictitem_T **dip, int verbose, int no_autoload); | ||||||
|  | char_u *get_var_value(char_u *name); | ||||||
|  | void vars_clear(hashtab_T *ht); | ||||||
|  | void vars_clear_ext(hashtab_T *ht, int free_val); | ||||||
|  | void delete_var(hashtab_T *ht, hashitem_T *hi); | ||||||
|  | void set_var(char_u *name, typval_T *tv, int copy); | ||||||
|  | void set_var_const(char_u *name, typval_T *tv, int copy, int is_const); | ||||||
|  | int var_check_ro(int flags, char_u *name, int use_gettext); | ||||||
|  | int var_check_fixed(int flags, char_u *name, int use_gettext); | ||||||
|  | int var_check_func_name(char_u *name, int new_var); | ||||||
|  | int var_check_lock(int lock, char_u *name, int use_gettext); | ||||||
|  | int valid_varname(char_u *varname); | ||||||
|  | int var_exists(char_u *var); | ||||||
|  | void f_gettabvar(typval_T *argvars, typval_T *rettv); | ||||||
|  | void f_gettabwinvar(typval_T *argvars, typval_T *rettv); | ||||||
|  | void f_getwinvar(typval_T *argvars, typval_T *rettv); | ||||||
|  | void f_settabvar(typval_T *argvars, typval_T *rettv); | ||||||
|  | void f_settabwinvar(typval_T *argvars, typval_T *rettv); | ||||||
|  | void f_setwinvar(typval_T *argvars, typval_T *rettv); | ||||||
|  | /* vim: set ft=c : */ | ||||||
| @ -761,6 +761,8 @@ static char *(features[]) = | |||||||
|  |  | ||||||
| static int included_patches[] = | static int included_patches[] = | ||||||
| {   /* Add new patch number below this line */ | {   /* Add new patch number below this line */ | ||||||
|  | /**/ | ||||||
|  |     1933, | ||||||
| /**/ | /**/ | ||||||
|     1932, |     1932, | ||||||
| /**/ | /**/ | ||||||
|  | |||||||
| @ -2003,6 +2003,8 @@ typedef int sock_T; | |||||||
| #define VAR_TYPE_CHANNEL    9 | #define VAR_TYPE_CHANNEL    9 | ||||||
| #define VAR_TYPE_BLOB	    10 | #define VAR_TYPE_BLOB	    10 | ||||||
|  |  | ||||||
|  | #define DICT_MAXNEST 100	/* maximum nesting of lists and dicts */ | ||||||
|  |  | ||||||
| #ifdef FEAT_CLIPBOARD | #ifdef FEAT_CLIPBOARD | ||||||
|  |  | ||||||
| /* VIM_ATOM_NAME is the older Vim-specific selection type for X11.  Still | /* VIM_ATOM_NAME is the older Vim-specific selection type for X11.  Still | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user