diff options
author | Bram Moolenaar <Bram@vim.org> | 2006-08-16 17:35:00 +0000 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2006-08-16 17:35:00 +0000 |
commit | f30e74c11333c37d777b929ea77f5716cc977d27 (patch) | |
tree | f5f92c2a1804ccd02aa88290d59cd29de0fe788e /src/fileio.c | |
parent | a7ecc563e8af7ed663ed5b174acd89257ea50fba (diff) | |
download | vim-git-f30e74c11333c37d777b929ea77f5716cc977d27.tar.gz |
updated for version 7.0-060v7.0.060
Diffstat (limited to 'src/fileio.c')
-rw-r--r-- | src/fileio.c | 44 |
1 files changed, 32 insertions, 12 deletions
diff --git a/src/fileio.c b/src/fileio.c index 9f24f6943..cde44d6a8 100644 --- a/src/fileio.c +++ b/src/fileio.c @@ -6450,17 +6450,10 @@ buf_reload(buf, orig_mode) int old_ro = buf->b_p_ro; buf_T *savebuf; int saved = OK; -#ifdef FEAT_AUTOCMD aco_save_T aco; /* set curwin/curbuf for "buf" and save some things */ aucmd_prepbuf(&aco, buf); -#else - buf_T *save_curbuf = curbuf; - - curbuf = buf; - curwin->w_buffer = buf; -#endif /* We only want to read the text from the file, not reset the syntax * highlighting, clear marks, diff status, etc. Force the fileformat @@ -6573,14 +6566,9 @@ buf_reload(buf, orig_mode) curbuf->b_p_ro |= old_ro; } -#ifdef FEAT_AUTOCMD /* restore curwin/curbuf and a few other things */ aucmd_restbuf(&aco); /* Careful: autocommands may have made "buf" invalid! */ -#else - curwin->w_buffer = save_curbuf; - curbuf = save_curbuf; -#endif } /*ARGSUSED*/ @@ -8088,6 +8076,7 @@ ex_doautoall(eap) * Search a window for the current buffer. Save the cursor position and * screen offset. * Set "curbuf" and "curwin" to match "buf". + * When FEAT_AUTOCMD is not defined another version is used, see below. */ void aucmd_prepbuf(aco, buf) @@ -8151,6 +8140,7 @@ aucmd_prepbuf(aco, buf) /* * Cleanup after executing autocommands for a (hidden) buffer. * Restore the window as it was (if possible). + * When FEAT_AUTOCMD is not defined another version is used, see below. */ void aucmd_restbuf(aco) @@ -9063,8 +9053,38 @@ theend: return retval; } +#else /* FEAT_AUTOCMD */ + +/* + * Prepare for executing commands for (hidden) buffer "buf". + * This is the non-autocommand version, it simply saves "curbuf" and sets + * "curbuf" and "curwin" to match "buf". + */ + void +aucmd_prepbuf(aco, buf) + aco_save_T *aco; /* structure to save values in */ + buf_T *buf; /* new curbuf */ +{ + aco->save_buf = buf; + curbuf = buf; + curwin->w_buffer = buf; +} + +/* + * Restore after executing commands for a (hidden) buffer. + * This is the non-autocommand version. + */ + void +aucmd_restbuf(aco) + aco_save_T *aco; /* structure holding saved values */ +{ + curbuf = aco->save_buf; + curwin->w_buffer = curbuf; +} + #endif /* FEAT_AUTOCMD */ + #if defined(FEAT_AUTOCMD) || defined(FEAT_WILDIGN) || defined(PROTO) /* * Try matching a filename with a "pattern" ("prog" is NULL), or use the |