updated for version 7.0171
This commit is contained in:
		| @ -1,9 +1,10 @@ | |||||||
| " Vim Plugin: 	Edit the file with an existing Vim if possible | " Vim Plugin: 	Edit the file with an existing Vim if possible | ||||||
| " Maintainer:	Bram Moolenaar | " Maintainer:	Bram Moolenaar | ||||||
| " Last Change:	2005 Dec 11 | " Last Change:	2005 Dec 15 | ||||||
|  |  | ||||||
| " This is a plugin, drop it in your (Unix) ~/.vim/plugin or (Win32) | " This is a plugin, drop it in your (Unix) ~/.vim/plugin or (Win32) | ||||||
| " $VIM/vimfiles/plugin directory. | " $VIM/vimfiles/plugin directory.  Or make a symbolic link, so that you | ||||||
|  | " automatically use the latest version. | ||||||
|  |  | ||||||
| " This plugin serves two purposes: | " This plugin serves two purposes: | ||||||
| " 1. On startup, if we were invoked with one file name argument and the file | " 1. On startup, if we were invoked with one file name argument and the file | ||||||
| @ -43,13 +44,15 @@ func s:EditElsewhere(filename) | |||||||
|       endif |       endif | ||||||
|       call remote_expr(servername, "foreground()") |       call remote_expr(servername, "foreground()") | ||||||
|  |  | ||||||
|       " Make sure the file is visible in a window (not hidden). |       if remote_expr(servername, "exists('*EditExisting')") | ||||||
|       " If v:swapcommand exists and is set, send it to the server. | 	" Make sure the file is visible in a window (not hidden). | ||||||
|       if exists("v:swapcommand") | 	" If v:swapcommand exists and is set, send it to the server. | ||||||
| 	let c = substitute(v:swapcommand, "'", "''", "g") | 	if exists("v:swapcommand") | ||||||
| 	call remote_expr(servername, "EditExisting('" . fname_esc . "', '" . c . "')") | 	  let c = substitute(v:swapcommand, "'", "''", "g") | ||||||
|       else | 	  call remote_expr(servername, "EditExisting('" . fname_esc . "', '" . c . "')") | ||||||
| 	call remote_expr(servername, "EditExisting('" . fname_esc . "', '')") | 	else | ||||||
|  | 	  call remote_expr(servername, "EditExisting('" . fname_esc . "', '')") | ||||||
|  | 	endif | ||||||
|       endif |       endif | ||||||
|  |  | ||||||
|       if !(has('vim_starting') && has('gui_running') && has('gui_win32')) |       if !(has('vim_starting') && has('gui_running') && has('gui_win32')) | ||||||
|  | |||||||
| @ -2,7 +2,7 @@ | |||||||
| " Language:	sed | " Language:	sed | ||||||
| " Maintainer:	Haakon Riiser <hakonrk@fys.uio.no> | " Maintainer:	Haakon Riiser <hakonrk@fys.uio.no> | ||||||
| " URL:		http://folk.uio.no/hakonrk/vim/syntax/sed.vim | " URL:		http://folk.uio.no/hakonrk/vim/syntax/sed.vim | ||||||
| " Last Change:	2003 May 11 | " Last Change:	2005 Dec 15 | ||||||
|  |  | ||||||
| " For version 5.x: Clear all syntax items | " For version 5.x: Clear all syntax items | ||||||
| " For version 6.x: Quit when a syntax file was already loaded | " For version 6.x: Quit when a syntax file was already loaded | ||||||
| @ -21,7 +21,7 @@ syn match sedAddress	"\d\+\~\d\+" | |||||||
| syn region sedAddress   matchgroup=Special start="[{,;]\s*/\(\\/\)\="lc=1 skip="[^\\]\(\\\\\)*\\/" end="/I\=" contains=sedTab,sedRegexpMeta | syn region sedAddress   matchgroup=Special start="[{,;]\s*/\(\\/\)\="lc=1 skip="[^\\]\(\\\\\)*\\/" end="/I\=" contains=sedTab,sedRegexpMeta | ||||||
| syn region sedAddress   matchgroup=Special start="^\s*/\(\\/\)\=" skip="[^\\]\(\\\\\)*\\/" end="/I\=" contains=sedTab,sedRegexpMeta | syn region sedAddress   matchgroup=Special start="^\s*/\(\\/\)\=" skip="[^\\]\(\\\\\)*\\/" end="/I\=" contains=sedTab,sedRegexpMeta | ||||||
| syn match sedComment	"^\s*#.*$" | syn match sedComment	"^\s*#.*$" | ||||||
| syn match sedFunction	"[dDgGhHlnNpPqx=]\s*\($\|;\)" contains=sedSemicolon,sedWhitespace | syn match sedFunction	"[dDgGhHlnNpPqQx=]\s*\($\|;\)" contains=sedSemicolon,sedWhitespace | ||||||
| syn match sedLabel	":[^;]*" | syn match sedLabel	":[^;]*" | ||||||
| syn match sedLineCont	"^\(\\\\\)*\\$" contained | syn match sedLineCont	"^\(\\\\\)*\\$" contained | ||||||
| syn match sedLineCont	"[^\\]\(\\\\\)*\\$"ms=e contained | syn match sedLineCont	"[^\\]\(\\\\\)*\\$"ms=e contained | ||||||
|  | |||||||
| @ -681,6 +681,7 @@ goto_buffer(eap, start, dir, count) | |||||||
| 	/* Quitting means closing the split window, nothing else. */ | 	/* Quitting means closing the split window, nothing else. */ | ||||||
| 	win_close(curwin, TRUE); | 	win_close(curwin, TRUE); | ||||||
| 	swap_exists_action = SEA_NONE; | 	swap_exists_action = SEA_NONE; | ||||||
|  | 	swap_exists_did_quit = TRUE; | ||||||
|  |  | ||||||
| #  if defined(FEAT_AUTOCMD) && defined(FEAT_EVAL) | #  if defined(FEAT_AUTOCMD) && defined(FEAT_EVAL) | ||||||
| 	/* Restore the error/interrupt/exception state if not discarded by a | 	/* Restore the error/interrupt/exception state if not discarded by a | ||||||
| @ -719,6 +720,7 @@ handle_swap_exists(old_curbuf) | |||||||
| 	 * buffer.  If that buffer is gone or the same as the current one, | 	 * buffer.  If that buffer is gone or the same as the current one, | ||||||
| 	 * open a new, empty buffer. */ | 	 * open a new, empty buffer. */ | ||||||
| 	swap_exists_action = SEA_NONE;	/* don't want it again */ | 	swap_exists_action = SEA_NONE;	/* don't want it again */ | ||||||
|  | 	swap_exists_did_quit = TRUE; | ||||||
| 	close_buffer(curwin, curbuf, DOBUF_UNLOAD); | 	close_buffer(curwin, curbuf, DOBUF_UNLOAD); | ||||||
| 	if (!buf_valid(old_curbuf) || old_curbuf == curbuf) | 	if (!buf_valid(old_curbuf) || old_curbuf == curbuf) | ||||||
| 	    old_curbuf = buflist_new(NULL, NULL, 1L, BLN_CURBUF | BLN_LISTED); | 	    old_curbuf = buflist_new(NULL, NULL, 1L, BLN_CURBUF | BLN_LISTED); | ||||||
| @ -4402,6 +4404,7 @@ ex_buffer_all(eap) | |||||||
| 		win_close(curwin, TRUE); | 		win_close(curwin, TRUE); | ||||||
| 		--open_wins; | 		--open_wins; | ||||||
| 		swap_exists_action = SEA_NONE; | 		swap_exists_action = SEA_NONE; | ||||||
|  | 		swap_exists_did_quit = TRUE; | ||||||
|  |  | ||||||
| # if defined(FEAT_AUTOCMD) && defined(FEAT_EVAL) | # if defined(FEAT_AUTOCMD) && defined(FEAT_EVAL) | ||||||
| 		/* Restore the error/interrupt/exception state if not | 		/* Restore the error/interrupt/exception state if not | ||||||
|  | |||||||
| @ -2108,7 +2108,7 @@ op_colon(oap) | |||||||
| } | } | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Handle the "gy" operator: call 'operatorfunc'. |  * Handle the "g@" operator: call 'operatorfunc'. | ||||||
|  */ |  */ | ||||||
| /*ARGSUSED*/ | /*ARGSUSED*/ | ||||||
|     void |     void | ||||||
| @ -7724,7 +7724,7 @@ nv_g_cmd(cap) | |||||||
|      *	 "gu"	    Change text to lower case. |      *	 "gu"	    Change text to lower case. | ||||||
|      *	 "gU"	    Change text to upper case. |      *	 "gU"	    Change text to upper case. | ||||||
|      *   "g?"	    rot13 encoding |      *   "g?"	    rot13 encoding | ||||||
|      *   "gy"	    call 'operatorfunc' |      *   "g@"	    call 'operatorfunc' | ||||||
|      */ |      */ | ||||||
|     case 'q': |     case 'q': | ||||||
|     case 'w': |     case 'w': | ||||||
| @ -7734,7 +7734,7 @@ nv_g_cmd(cap) | |||||||
|     case 'u': |     case 'u': | ||||||
|     case 'U': |     case 'U': | ||||||
|     case '?': |     case '?': | ||||||
|     case 'y': |     case '@': | ||||||
| 	nv_operator(cap); | 	nv_operator(cap); | ||||||
| 	break; | 	break; | ||||||
|  |  | ||||||
|  | |||||||
| @ -3539,7 +3539,7 @@ mch_call_shell(cmd, options) | |||||||
|     int		pty_slave_fd = -1; |     int		pty_slave_fd = -1; | ||||||
|     char	*tty_name; |     char	*tty_name; | ||||||
| # endif | # endif | ||||||
|     int		fd_toshell[2];	    /* for pipes */ |     int		fd_toshell[2];		/* for pipes */ | ||||||
|     int		fd_fromshell[2]; |     int		fd_fromshell[2]; | ||||||
|     int		pipe_error = FALSE; |     int		pipe_error = FALSE; | ||||||
| # ifdef HAVE_SETENV | # ifdef HAVE_SETENV | ||||||
| @ -3548,19 +3548,21 @@ mch_call_shell(cmd, options) | |||||||
|     static char	envbuf_Rows[20]; |     static char	envbuf_Rows[20]; | ||||||
|     static char	envbuf_Columns[20]; |     static char	envbuf_Columns[20]; | ||||||
| # endif | # endif | ||||||
|     int		did_settmode = FALSE; /* TRUE when settmode(TMODE_RAW) called */ |     int		did_settmode = FALSE;	/* settmode(TMODE_RAW) called */ | ||||||
|  |  | ||||||
|     out_flush(); |     out_flush(); | ||||||
|     if (options & SHELL_COOKED) |     if (options & SHELL_COOKED) | ||||||
| 	settmode(TMODE_COOK);		/* set to normal mode */ | 	settmode(TMODE_COOK);		/* set to normal mode */ | ||||||
|  |  | ||||||
|     /* |  | ||||||
|      * 1: find number of arguments |  | ||||||
|      * 2: separate them and built argv[] |  | ||||||
|      */ |  | ||||||
|     newcmd = vim_strsave(p_sh); |     newcmd = vim_strsave(p_sh); | ||||||
|     if (newcmd == NULL)		/* out of memory */ |     if (newcmd == NULL)		/* out of memory */ | ||||||
| 	goto error; | 	goto error; | ||||||
|  |  | ||||||
|  |     /* | ||||||
|  |      * Do this loop twice: | ||||||
|  |      * 1: find number of arguments | ||||||
|  |      * 2: separate them and build argv[] | ||||||
|  |      */ | ||||||
|     for (i = 0; i < 2; ++i) |     for (i = 0; i < 2; ++i) | ||||||
|     { |     { | ||||||
| 	p = newcmd; | 	p = newcmd; | ||||||
| @ -3655,6 +3657,7 @@ mch_call_shell(cmd, options) | |||||||
| # ifdef __BEOS__ | # ifdef __BEOS__ | ||||||
| 	beos_cleanup_read_thread(); | 	beos_cleanup_read_thread(); | ||||||
| # endif | # endif | ||||||
|  |  | ||||||
| 	if ((pid = fork()) == -1)	/* maybe we should use vfork() */ | 	if ((pid = fork()) == -1)	/* maybe we should use vfork() */ | ||||||
| 	{ | 	{ | ||||||
| 	    MSG_PUTS(_("\nCannot fork\n")); | 	    MSG_PUTS(_("\nCannot fork\n")); | ||||||
| @ -3728,17 +3731,24 @@ mch_call_shell(cmd, options) | |||||||
| 	    { | 	    { | ||||||
|  |  | ||||||
| # ifdef HAVE_SETSID | # ifdef HAVE_SETSID | ||||||
| 		(void)setsid(); | 		/* Create our own process group, so that the child and all its | ||||||
|  | 		 * children can be kill()ed.  Don't do this when using pipes, | ||||||
|  | 		 * because stdin is not a tty, we would loose /dev/tty. */ | ||||||
|  | 		if (p_stmp) | ||||||
|  | 		    (void)setsid(); | ||||||
| # endif | # endif | ||||||
| # ifdef FEAT_GUI | # ifdef FEAT_GUI | ||||||
| 		/* push stream discipline modules */ | 		if (pty_slave_fd >= 0) | ||||||
| 		if (options & SHELL_COOKED) | 		{ | ||||||
| 		    SetupSlavePTY(pty_slave_fd); | 		    /* push stream discipline modules */ | ||||||
|  | 		    if (options & SHELL_COOKED) | ||||||
|  | 			SetupSlavePTY(pty_slave_fd); | ||||||
| #  ifdef TIOCSCTTY | #  ifdef TIOCSCTTY | ||||||
| 		/* try to become controlling tty (probably doesn't work, | 		    /* Try to become controlling tty (probably doesn't work, | ||||||
| 		 * unless run by root) */ | 		     * unless run by root) */ | ||||||
| 		ioctl(pty_slave_fd, TIOCSCTTY, (char *)NULL); | 		    ioctl(pty_slave_fd, TIOCSCTTY, (char *)NULL); | ||||||
| #  endif | #  endif | ||||||
|  | 		} | ||||||
| # endif | # endif | ||||||
| 		/* Simulate to have a dumb terminal (for now) */ | 		/* Simulate to have a dumb terminal (for now) */ | ||||||
| # ifdef HAVE_SETENV | # ifdef HAVE_SETENV | ||||||
| @ -3895,7 +3905,7 @@ mch_call_shell(cmd, options) | |||||||
| 		old_State = State; | 		old_State = State; | ||||||
| 		State = EXTERNCMD;	/* don't redraw at window resize */ | 		State = EXTERNCMD;	/* don't redraw at window resize */ | ||||||
|  |  | ||||||
| 		if (options & SHELL_WRITE && toshell_fd >= 0) | 		if ((options & SHELL_WRITE) && toshell_fd >= 0) | ||||||
| 		{ | 		{ | ||||||
| 		    /* Fork a process that will write the lines to the | 		    /* Fork a process that will write the lines to the | ||||||
| 		     * external program. */ | 		     * external program. */ | ||||||
| @ -3976,6 +3986,8 @@ mch_call_shell(cmd, options) | |||||||
| 		     * Don't do this when filtering and terminal is in cooked | 		     * Don't do this when filtering and terminal is in cooked | ||||||
| 		     * mode, the shell command will handle the I/O.  Avoids | 		     * mode, the shell command will handle the I/O.  Avoids | ||||||
| 		     * that a typed password is echoed for ssh or gpg command. | 		     * that a typed password is echoed for ssh or gpg command. | ||||||
|  | 		     * Don't get characters when the child has already | ||||||
|  | 		     * finished (wait_pid == 0). | ||||||
| 		     * Don't get extra characters when we already have one. | 		     * Don't get extra characters when we already have one. | ||||||
| 		     * Don't read characters unless we didn't get output for a | 		     * Don't read characters unless we didn't get output for a | ||||||
| 		     * while, avoids that ":r !ls" eats typeahead. | 		     * while, avoids that ":r !ls" eats typeahead. | ||||||
| @ -3989,6 +4001,7 @@ mch_call_shell(cmd, options) | |||||||
| 						    || gui.in_use | 						    || gui.in_use | ||||||
| #endif | #endif | ||||||
| 						    ) | 						    ) | ||||||
|  | 			    && wait_pid == 0 | ||||||
| 			    && (ta_len > 0 | 			    && (ta_len > 0 | ||||||
| 				|| (noread_cnt > 4 | 				|| (noread_cnt > 4 | ||||||
| 				    && (len = ui_inchar(ta_buf, | 				    && (len = ui_inchar(ta_buf, | ||||||
| @ -4207,6 +4220,11 @@ mch_call_shell(cmd, options) | |||||||
| 			    break; | 			    break; | ||||||
| 		    } | 		    } | ||||||
|  |  | ||||||
|  | 		    /* If we already detected the child has finished break the | ||||||
|  | 		     * loop now. */ | ||||||
|  | 		    if (wait_pid == pid) | ||||||
|  | 			break; | ||||||
|  |  | ||||||
| 		    /* | 		    /* | ||||||
| 		     * Check if the child still exists, before checking for | 		     * Check if the child still exists, before checking for | ||||||
| 		     * typed characters (otherwise we would loose typeahead). | 		     * typed characters (otherwise we would loose typeahead). | ||||||
| @ -4219,10 +4237,14 @@ mch_call_shell(cmd, options) | |||||||
| 		    if ((wait_pid == (pid_t)-1 && errno == ECHILD) | 		    if ((wait_pid == (pid_t)-1 && errno == ECHILD) | ||||||
| 			    || (wait_pid == pid && WIFEXITED(status))) | 			    || (wait_pid == pid && WIFEXITED(status))) | ||||||
| 		    { | 		    { | ||||||
|  | 			/* Don't break the loop yet, try reading more | ||||||
|  | 			 * characters from "fromshell_fd" first.  When using | ||||||
|  | 			 * pipes there might still be something to read and | ||||||
|  | 			 * then we'll break the loop at the "break" above. */ | ||||||
| 			wait_pid = pid; | 			wait_pid = pid; | ||||||
| 			break; |  | ||||||
| 		    } | 		    } | ||||||
| 		    wait_pid = 0; | 		    else | ||||||
|  | 			wait_pid = 0; | ||||||
| 		} | 		} | ||||||
| finished: | finished: | ||||||
| 		p_more = p_more_save; | 		p_more = p_more_save; | ||||||
|  | |||||||
| @ -2419,7 +2419,8 @@ get_tagfname(first, buf) | |||||||
| 					      , TRUE, found_tagfile_cb, NULL); | 					      , TRUE, found_tagfile_cb, NULL); | ||||||
| 	    hf_idx = 0; | 	    hf_idx = 0; | ||||||
| 	} | 	} | ||||||
| 	else if (hf_idx >= tag_fnames.ga_len) |  | ||||||
|  | 	if (hf_idx >= tag_fnames.ga_len) | ||||||
| 	{ | 	{ | ||||||
| 	    /* Not found in 'runtimepath', use 'helpfile', if it exists and | 	    /* Not found in 'runtimepath', use 'helpfile', if it exists and | ||||||
| 	     * wasn't used yet, replacing "help.txt" with "tags". */ | 	     * wasn't used yet, replacing "help.txt" with "tags". */ | ||||||
|  | |||||||
| @ -1201,7 +1201,7 @@ typedef enum | |||||||
| #define OP_FOLDDEL	24	/* "zd" delete folds */ | #define OP_FOLDDEL	24	/* "zd" delete folds */ | ||||||
| #define OP_FOLDDELREC	25	/* "zD" delete folds recursively */ | #define OP_FOLDDELREC	25	/* "zD" delete folds recursively */ | ||||||
| #define OP_FORMAT2	26	/* "gw" format operator, keeps cursor pos */ | #define OP_FORMAT2	26	/* "gw" format operator, keeps cursor pos */ | ||||||
| #define OP_FUNCTION	27	/* "gy" call 'operatorfunc' */ | #define OP_FUNCTION	27	/* "g@" call 'operatorfunc' */ | ||||||
|  |  | ||||||
| /* | /* | ||||||
|  * Motion types, used for operators and for yank/delete registers. |  * Motion types, used for operators and for yank/delete registers. | ||||||
|  | |||||||
| @ -146,16 +146,18 @@ char osver[] = ""; | |||||||
| #if !defined(CYGWIN) && (defined(CYGWIN32) || defined(__CYGWIN__) || defined(__CYGWIN32__)) | #if !defined(CYGWIN) && (defined(CYGWIN32) || defined(__CYGWIN__) || defined(__CYGWIN32__)) | ||||||
| # define CYGWIN | # define CYGWIN | ||||||
| #endif | #endif | ||||||
| #if defined(MSDOS) || defined(WIN32) || defined(OS2) || defined(CYGWIN) | #if defined(MSDOS) || defined(WIN32) || defined(OS2) | ||||||
| # define BIN_READ(yes)  ((yes) ? "rb" : "rt") | # define BIN_READ(yes)  ((yes) ? "rb" : "rt") | ||||||
| # define BIN_WRITE(yes) ((yes) ? "wb" : "wt") | # define BIN_WRITE(yes) ((yes) ? "wb" : "wt") | ||||||
| # define BIN_CREAT(yes) ((yes) ? (O_CREAT|O_BINARY) : O_CREAT) | # define BIN_CREAT(yes) ((yes) ? (O_CREAT|O_BINARY) : O_CREAT) | ||||||
| # define BIN_ASSIGN(fp, yes) setmode(fileno(fp), (yes) ? O_BINARY : O_TEXT) | # define BIN_ASSIGN(fp, yes) setmode(fileno(fp), (yes) ? O_BINARY : O_TEXT) | ||||||
| # if defined(CYGWIN) | # define PATH_SEP '\\' | ||||||
| #  define PATH_SEP '/' | #elif defined(CYGWIN) | ||||||
| # else | # define BIN_READ(yes)  ((yes) ? "rb" : "rt") | ||||||
| #  define PATH_SEP '\\' | # define BIN_WRITE(yes) ((yes) ? "wb" : "w") | ||||||
| # endif | # define BIN_CREAT(yes) ((yes) ? (O_CREAT|O_BINARY) : O_CREAT) | ||||||
|  | # define BIN_ASSIGN(fp, yes) ((yes) ? (void) setmode(fileno(fp), O_BINARY) : (void) (fp)) | ||||||
|  | # define PATH_SEP '/' | ||||||
| #else | #else | ||||||
| # ifdef VMS | # ifdef VMS | ||||||
| #  define BIN_READ(dummy)  "r" | #  define BIN_READ(dummy)  "r" | ||||||
|  | |||||||
		Reference in New Issue
	
	Block a user