summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorBram Moolenaar <Bram@vim.org>2016-03-26 21:00:08 +0100
committerBram Moolenaar <Bram@vim.org>2016-03-26 21:00:08 +0100
commit1473551a4457d4920b235eeeb9f279e196ee7225 (patch)
treebd0515b263f9f2ea82effe2ef09073512078e838
parent8fdd7210479f0c486822ad8934087b4bfd8a4765 (diff)
downloadvim-git-1473551a4457d4920b235eeeb9f279e196ee7225.tar.gz
patch 7.4.1658v7.4.1658
Problem: A plugin does not know when VimEnter autocommands were already triggered. Solution: Add the v:vim_did_enter variable.
-rw-r--r--runtime/doc/autocmd.txt10
-rw-r--r--runtime/doc/eval.txt4
-rw-r--r--src/eval.c1
-rw-r--r--src/main.c3
-rw-r--r--src/testdir/test_alot.vim1
-rw-r--r--src/testdir/test_autocmd.vim8
-rw-r--r--src/version.c2
-rw-r--r--src/vim.h3
8 files changed, 30 insertions, 2 deletions
diff --git a/runtime/doc/autocmd.txt b/runtime/doc/autocmd.txt
index 4de5b1619..5d502f123 100644
--- a/runtime/doc/autocmd.txt
+++ b/runtime/doc/autocmd.txt
@@ -918,7 +918,15 @@ VimEnter After doing all the startup stuff, including
loading .vimrc files, executing the "-c cmd"
arguments, creating all windows and loading
the buffers in them.
- *VimLeave*
+ Just before this event is triggered the
+ |v:vim_did_enter| variable is set, so that you
+ can do: >
+ if v:vim_did_enter
+ call s:init()
+ else
+ au VimEnter * call s:init()
+ endif
+< *VimLeave*
VimLeave Before exiting Vim, just after writing the
.viminfo file. Executed only once, like
VimLeavePre.
diff --git a/runtime/doc/eval.txt b/runtime/doc/eval.txt
index 642f0ad76..e17448125 100644
--- a/runtime/doc/eval.txt
+++ b/runtime/doc/eval.txt
@@ -1762,6 +1762,10 @@ v:version Version number of Vim: Major version number times 100 plus
version 5.0 and 5.1 may have a patch 123, but these are
completely different.
+ *v:vim_did_enter* *vim_did_enter-variable*
+v:vim_did_enter Zero until most of startup is done. It is set to one just
+ before |VimEnter| autocommands are triggered.
+
*v:warningmsg* *warningmsg-variable*
v:warningmsg Last given warning message. It's allowed to set this variable.
diff --git a/src/eval.c b/src/eval.c
index 06f3585b3..c1046955b 100644
--- a/src/eval.c
+++ b/src/eval.c
@@ -372,6 +372,7 @@ static struct vimvar
{VV_NAME("true", VAR_SPECIAL), VV_RO},
{VV_NAME("null", VAR_SPECIAL), VV_RO},
{VV_NAME("none", VAR_SPECIAL), VV_RO},
+ {VV_NAME("vim_did_enter", VAR_NUMBER), VV_RO},
};
/* shorthand */
diff --git a/src/main.c b/src/main.c
index 35c940f6a..91ef66db6 100644
--- a/src/main.c
+++ b/src/main.c
@@ -969,6 +969,9 @@ vim_main2(int argc UNUSED, char **argv UNUSED)
if (p_im)
need_start_insertmode = TRUE;
+#ifdef FEAT_EVAL
+ set_vim_var_nr(VV_VIM_DID_ENTER, 1L);
+#endif
#ifdef FEAT_AUTOCMD
apply_autocmds(EVENT_VIMENTER, NULL, NULL, FALSE, curbuf);
TIME_MSG("VimEnter autocommands");
diff --git a/src/testdir/test_alot.vim b/src/testdir/test_alot.vim
index fcf358b53..06309982a 100644
--- a/src/testdir/test_alot.vim
+++ b/src/testdir/test_alot.vim
@@ -2,6 +2,7 @@
" This makes testing go faster, since Vim doesn't need to restart.
source test_assign.vim
+source test_autocmd.vim
source test_cursor_func.vim
source test_delete.vim
source test_ex_undo.vim
diff --git a/src/testdir/test_autocmd.vim b/src/testdir/test_autocmd.vim
new file mode 100644
index 000000000..12c984888
--- /dev/null
+++ b/src/testdir/test_autocmd.vim
@@ -0,0 +1,8 @@
+" Tests for autocommands
+
+func Test_vim_did_enter()
+ call assert_false(v:vim_did_enter)
+
+ " This script will never reach the main loop, can't check if v:vim_did_enter
+ " becomes one.
+endfunc
diff --git a/src/version.c b/src/version.c
index 6459356ce..62e66ab1f 100644
--- a/src/version.c
+++ b/src/version.c
@@ -749,6 +749,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 1658,
+/**/
1657,
/**/
1656,
diff --git a/src/vim.h b/src/vim.h
index a7443e9a1..a2dc07961 100644
--- a/src/vim.h
+++ b/src/vim.h
@@ -1869,7 +1869,8 @@ typedef int sock_T;
#define VV_TRUE 64
#define VV_NULL 65
#define VV_NONE 66
-#define VV_LEN 67 /* number of v: vars */
+#define VV_VIM_DID_ENTER 67
+#define VV_LEN 68 /* number of v: vars */
/* used for v_number in VAR_SPECIAL */
#define VVAL_FALSE 0L