0
0
mirror of https://github.com/vim/vim.git synced 2025-09-18 02:53:56 -04:00

patch 9.0.2183: Maximum callback depth is not configurable

Problem:  Maximum callback depth is not configurable.
Solution: Revert patch 9.0.2103.  Set 'maxfuncdepth' in test.
          (zeertzjq)

fixes: #13732
closes: #13736

Signed-off-by: zeertzjq <zeertzjq@outlook.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
zeertzjq 2023-12-21 16:59:26 +01:00 committed by Christian Brabandt
parent 632b38b45f
commit fe583b1e59
No known key found for this signature in database
GPG Key ID: F3F92DA383FDDE09
5 changed files with 10 additions and 9 deletions

View File

@ -1,4 +1,4 @@
*message.txt* For Vim version 9.0. Last change: 2023 Nov 08
*message.txt* For Vim version 9.0. Last change: 2023 Dec 20
VIM REFERENCE MANUAL by Bram Moolenaar
@ -135,8 +135,6 @@ This happens when an Ex command executes an Ex command that executes an Ex
command, etc. The limit is 200 or the value of 'maxfuncdepth', whatever is
larger. When it's more there probably is an endless loop. Probably a
|:execute| or |:source| command is involved.
Can also happen with a recursive callback function (|job-callback|).
A limit of 20 is used here.
*E254*
Cannot allocate color {name} ~

View File

@ -1,4 +1,4 @@
*options.txt* For Vim version 9.0. Last change: 2023 Dec 16
*options.txt* For Vim version 9.0. Last change: 2023 Dec 20
VIM REFERENCE MANUAL by Bram Moolenaar
@ -5477,6 +5477,7 @@ A jump table for the options with a short description can be found at |Q_op|.
Increasing this limit above 200 also changes the maximum for Ex
command recursion, see |E169|.
See also |:function|.
Also used for maximum depth of callback functions.
*'maxmapdepth'* *'mmd'* *E223*
'maxmapdepth' 'mmd' number (default 1000)

View File

@ -4206,10 +4206,13 @@ func Test_popupwin_with_error()
endfunc
func Test_popup_close_callback_recursive()
set maxfuncdepth=20
" this invokes the callback recursively
let winid = popup_create('something', #{callback: 'popup_close'})
redraw
call assert_fails('call popup_close(winid)', 'E169')
call assert_fails('call popup_close(winid)', 'E169:')
set maxfuncdepth&
endfunc
" vim: shiftwidth=2 sts=2

View File

@ -14,9 +14,6 @@
#include "vim.h"
#if defined(FEAT_EVAL) || defined(PROTO)
#define MAX_CALLBACK_DEPTH 20
/*
* All user-defined functions are found in this hashtable.
*/
@ -3603,7 +3600,7 @@ call_callback(
if (callback->cb_name == NULL || *callback->cb_name == NUL)
return FAIL;
if (callback_depth > MAX_CALLBACK_DEPTH)
if (callback_depth > p_mfd)
{
emsg(_(e_command_too_recursive));
return FAIL;

View File

@ -704,6 +704,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
2183,
/**/
2182,
/**/