diff options
author | Bram Moolenaar <Bram@vim.org> | 2022-08-26 21:33:04 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2022-08-26 21:33:04 +0100 |
commit | 0f618386367ba9388e1f50bc665bc1add6c01567 (patch) | |
tree | 577ff6e6e4901d1a7e988d16db0c22d74c404866 | |
parent | 58dcbf1c6586d3873702e035b47829178a91250e (diff) | |
download | vim-git-0f618386367ba9388e1f50bc665bc1add6c01567.tar.gz |
patch 9.0.0282: a nested timout stops the previous timeoutv9.0.0282
Problem: A nested timout stops the previous timeout.
Solution: Ignore any nested timeout.
-rw-r--r-- | src/evalfunc.c | 3 | ||||
-rw-r--r-- | src/regexp.c | 21 | ||||
-rw-r--r-- | src/version.c | 2 |
3 files changed, 22 insertions, 4 deletions
diff --git a/src/evalfunc.c b/src/evalfunc.c index a5f9ee359..d2cc8fc76 100644 --- a/src/evalfunc.c +++ b/src/evalfunc.c @@ -9176,7 +9176,8 @@ do_searchpair( theend: #ifdef FEAT_RELTIME - disable_regexp_timeout(); + if (time_limit > 0) + disable_regexp_timeout(); #endif vim_free(pat2); vim_free(pat3); diff --git a/src/regexp.c b/src/regexp.c index bec046437..8e6e9c440 100644 --- a/src/regexp.c +++ b/src/regexp.c @@ -51,17 +51,32 @@ toggle_Magic(int x) } #ifdef FEAT_RELTIME +static int timeout_nesting = 0; + +/* + * Start a timer that will cause the regexp to abort after "msec". + * This doesn't work well recursively. In case it happens anyway, the first + * set timeout will prevail, nested ones are ignored. + * The caller must make sure there is a matching disable_regexp_timeout() call! + */ void init_regexp_timeout(long msec) { - timeout_flag = start_timeout(msec); + if (timeout_nesting == 0) + timeout_flag = start_timeout(msec); + ++timeout_nesting; } void disable_regexp_timeout(void) { - stop_timeout(); - timeout_flag = &dummy_timeout_flag; + if (timeout_nesting == 0) + iemsg("disable_regexp_timeout() called without active timer"); + else if (--timeout_nesting == 0) + { + stop_timeout(); + timeout_flag = &dummy_timeout_flag; + } } #endif diff --git a/src/version.c b/src/version.c index ae33d6dac..2eb817cf9 100644 --- a/src/version.c +++ b/src/version.c @@ -708,6 +708,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ /**/ + 282, +/**/ 281, /**/ 280, |