diff options
Diffstat (limited to 'usr.bin/vim/main.c')
-rw-r--r-- | usr.bin/vim/main.c | 91 |
1 files changed, 72 insertions, 19 deletions
diff --git a/usr.bin/vim/main.c b/usr.bin/vim/main.c index 43d9841e981..eff7a9afaa2 100644 --- a/usr.bin/vim/main.c +++ b/usr.bin/vim/main.c @@ -1,4 +1,4 @@ -/* $OpenBSD: main.c,v 1.1 1996/09/07 21:40:26 downsj Exp $ */ +/* $OpenBSD: main.c,v 1.2 1996/09/21 06:23:05 downsj Exp $ */ /* vi:set ts=4 sw=4: * * VIM - Vi IMproved by Bram Moolenaar @@ -758,7 +758,6 @@ main(argc, argv) if (gui.starting) { gui_start(); - gui.starting = FALSE; full_screen = TRUE; } #endif @@ -792,6 +791,16 @@ main(argc, argv) curbuf->b_p_bin = 1; /* binary file I/O */ } +/* + * "-e errorfile": Load the error file now. + * If the error file can't be read, exit before doing anything else. + */ + if (doqf && qf_init() == FAIL) /* if reading error file fails: exit */ + { + outchar('\n'); + mch_windexit(3); + } + /* Don't set the file name if there was a command in .vimrc that already * loaded the file */ if (curbuf->b_filename == NULL) @@ -815,13 +824,6 @@ main(argc, argv) window_count = 1; /* - * "-e errorfile": Load the error file now. - * If the error file can't be read, exit before doing anything else. - */ - if (doqf && qf_init() == FAIL) /* if reading error file fails: exit */ - mch_windexit(3); - -/* * Start putting things on the screen. * Scroll screen down before drawing over it * Clear screen now, so file message will not be cleared. @@ -872,28 +874,69 @@ main(argc, argv) msg_scroll = FALSE; if (curbuf->b_ml.ml_mfp == NULL) /* failed */ getout(1); + do_modelines(); /* do modelines */ + } + else + { + /* + * Open a buffer for windows that don't have one yet. + * Commands in the .vimrc might have loaded a file or split the window. + * Watch out for autocommands that delete a window. + */ +#ifdef AUTOCMD + /* + * Don't execute Win/Buf Enter/Leave autocommands here + */ + ++autocmd_no_enter; + ++autocmd_no_leave; +#endif + for (curwin = firstwin; curwin != NULL; curwin = curwin->w_next) + { + curbuf = curwin->w_buffer; + if (curbuf->b_ml.ml_mfp == NULL) + { + (void)open_buffer(); /* create memfile and read file */ #ifdef AUTOCMD - apply_autocmds(EVENT_BUFENTER, NULL, NULL); + curwin = firstwin; /* start again */ #endif - do_modelines(); /* do modelines */ + } + mch_breakcheck(); + if (got_int) + { + (void)vgetc(); /* only break the file loading, not the rest */ + break; + } + } +#ifdef AUTOCMD + --autocmd_no_enter; + --autocmd_no_leave; +#endif + curwin = firstwin; + curbuf = curwin->w_buffer; } - /* Only read the file if there is none for the current buffer, a command - * in the .vimrc might have loaded a file */ - else if (curbuf->b_ml.ml_mfp == NULL) - (void)open_buffer(); /* create memfile and read file */ +#ifdef AUTOCMD + apply_autocmds(EVENT_BUFENTER, NULL, NULL); +#endif setpcmark(); /* * When started with "-e errorfile" jump to first error now. */ if (doqf) - qf_jump(0, 0); + qf_jump(0, 0, FALSE); /* * If opened more than one window, start editing files in the other windows. * Make_windows() has already opened the windows. */ +#ifdef AUTOCMD + /* + * Don't execute Win/Buf Enter/Leave autocommands here + */ + ++autocmd_no_enter; + ++autocmd_no_leave; +#endif for (i = 1; i < window_count; ++i) { if (curwin->w_next == NULL) /* just checking */ @@ -907,7 +950,7 @@ main(argc, argv) curwin->w_arg_idx = arg_idx; /* edit file from arg list, if there is one */ (void)do_ecmd(0, arg_idx < arg_count ? arg_files[arg_idx] : NULL, - NULL, NULL, TRUE, (linenr_t)1, FALSE); + NULL, NULL, (linenr_t)1, ECMD_HIDE); if (arg_idx == arg_count - 1) arg_had_last = TRUE; ++arg_idx; @@ -919,7 +962,13 @@ main(argc, argv) break; } } +#ifdef AUTOCMD + --autocmd_no_enter; +#endif win_enter(firstwin, FALSE); /* back to first window */ +#ifdef AUTOCMD + --autocmd_no_leave; +#endif if (window_count > 1) win_equal(curwin, FALSE); /* adjust heights */ @@ -1070,12 +1119,16 @@ getout(r) #endif #ifdef VIMINFO + msg_didany = FALSE; /* Write out the registers, history, marks etc, to the viminfo file */ if (*p_viminfo != NUL) write_viminfo(NULL, FALSE); + if (msg_didany) /* make the user read the error message */ + { + no_wait_return = FALSE; + wait_return(FALSE); + } #endif /* VIMINFO */ - outchar('\r'); - outchar('\n'); mch_windexit(r); } |