patch 9.1.1044: Vim9: Patch 9.1.1014 causes regressions

Problem:  Vim9: Patch 9.1.1014 causes regressions
Solution: revert it for now

This reverts commit 57f0119358 since this
causes some regressions:
https://github.com/vim/vim/pull/16440#issuecomment-2600235629

So revert "patch 9.1.1014: Vim9: variable not found in transitive
import" for now.

Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
Christian Brabandt
2025-01-21 22:17:50 +01:00
parent e2a0471851
commit d9a1f267ba
7 changed files with 13 additions and 95 deletions

View File

@ -1,4 +1,4 @@
*options.txt* For Vim version 9.1. Last change: 2025 Jan 20 *options.txt* For Vim version 9.1. Last change: 2025 Jan 21
VIM REFERENCE MANUAL by Bram Moolenaar VIM REFERENCE MANUAL by Bram Moolenaar
@ -5582,7 +5582,6 @@ A jump table for the options with a short description can be found at |Q_op|.
command recursion, see |E169|. command recursion, see |E169|.
See also |:function|. See also |:function|.
Also used for maximum depth of callback functions. Also used for maximum depth of callback functions.
Also used for maximum depth of import. See |:import-cycle|.
*'maxmapdepth'* *'mmd'* *E223* *'maxmapdepth'* *'mmd'* *E223*
'maxmapdepth' 'mmd' number (default 1000) 'maxmapdepth' 'mmd' number (default 1000)

View File

@ -4148,7 +4148,6 @@ E1041 vim9.txt /*E1041*
E1042 vim9.txt /*E1042* E1042 vim9.txt /*E1042*
E1043 vim9.txt /*E1043* E1043 vim9.txt /*E1043*
E1044 vim9.txt /*E1044* E1044 vim9.txt /*E1044*
E1045 vim9.txt /*E1045*
E1047 vim9.txt /*E1047* E1047 vim9.txt /*E1047*
E1048 vim9.txt /*E1048* E1048 vim9.txt /*E1048*
E1049 vim9.txt /*E1049* E1049 vim9.txt /*E1049*

View File

@ -1,4 +1,4 @@
*vim9.txt* For Vim version 9.1. Last change: 2025 Jan 19 *vim9.txt* For Vim version 9.1. Last change: 2025 Jan 21
VIM REFERENCE MANUAL by Bram Moolenaar VIM REFERENCE MANUAL by Bram Moolenaar
@ -2052,14 +2052,13 @@ prefixing the function with |<SID>| you should use|<ScriptCmd>|. For example:
> >
noremap ,a <ScriptCmd>:call s:that.OtherFunc()<CR> noremap ,a <ScriptCmd>:call s:that.OtherFunc()<CR>
< <
*:import-cycle* *E1045* *:import-cycle*
The `import` commands are executed when encountered. It can be nested up to The `import` commands are executed when encountered. If script A imports
'maxfuncdepth' levels deep. If script A imports script B, and B (directly or script B, and B (directly or indirectly) imports A, this will be skipped over.
indirectly) imports A, this will be skipped over. At this point items in A At this point items in A after "import B" will not have been processed and
after "import B" will not have been processed and defined yet. Therefore defined yet. Therefore cyclic imports can exist and not result in an error
cyclic imports can exist and not result in an error directly, but may result directly, but may result in an error for items in A after "import B" not being
in an error for items in A after "import B" not being defined. This does not defined. This does not apply to autoload imports, see the next section.
apply to autoload imports, see the next section.
Importing an autoload script ~ Importing an autoload script ~

View File

@ -2738,8 +2738,7 @@ EXTERN char e_invalid_command_after_export[]
INIT(= N_("E1043: Invalid command after :export")); INIT(= N_("E1043: Invalid command after :export"));
EXTERN char e_export_with_invalid_argument[] EXTERN char e_export_with_invalid_argument[]
INIT(= N_("E1044: Export with invalid argument")); INIT(= N_("E1044: Export with invalid argument"));
EXTERN char e_import_nesting_too_deep[] // E1045 not used
INIT(= N_("E1045: Import nesting too deep"));
// E1046 not used // E1046 not used
EXTERN char e_syntax_error_in_import_str[] EXTERN char e_syntax_error_in_import_str[]
INIT(= N_("E1047: Syntax error in import: %s")); INIT(= N_("E1047: Syntax error in import: %s"));

View File

@ -3662,73 +3662,7 @@ def Test_extend_imported_class()
v9.CheckScriptSuccess(lines) v9.CheckScriptSuccess(lines)
enddef enddef
" Test for multi level import def Test_abstract_class()
def Test_multi_level_import_normal()
var lines =<< trim END
vim9script
export class Property
public var value: string
endclass
END
writefile(lines, 'aa.vim', 'D')
lines =<< trim END
vim9script
import './aa.vim'
export class View
var content = aa.Property.new('')
endclass
END
writefile(lines, 'bb.vim', 'D')
lines =<< trim END
vim9script
import './bb.vim'
class MyView extends bb.View
def new(value: string)
this.content.value = value
enddef
endclass
var myView = MyView.new('This should be ok')
END
v9.CheckScriptSuccess(lines)
enddef
" Test for multi level import
def Test_multi_level_import_nest_over()
var lines =<< trim END
vim9script
import './xbb.vim'
export class Property
public var value: string
endclass
END
writefile(lines, 'xaa.vim', 'D')
lines =<< trim END
vim9script
import './xaa.vim'
export class View
var content = aa.Property.new('')
endclass
END
writefile(lines, 'xbb.vim', 'D')
lines =<< trim END
vim9script
set maxfuncdepth=100
import './xbb.vim'
class MyView extends bb.View
def new(value: string)
this.content.value = value
enddef
endclass
var myView = MyView.new('This should be ok')
END
v9.CheckSourceFailure(lines, 'E1045: Import nesting too deep', 3)
enddef
def Test_abtstract_class()
var lines =<< trim END var lines =<< trim END
vim9script vim9script
abstract class Base abstract class Base

View File

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

View File

@ -778,7 +778,6 @@ get_script_item_idx(
static imported_T * static imported_T *
find_imported_in_script(char_u *name, size_t len, int sid) find_imported_in_script(char_u *name, size_t len, int sid)
{ {
static int nesting = 0;
scriptitem_T *si; scriptitem_T *si;
int idx; int idx;
@ -793,19 +792,6 @@ find_imported_in_script(char_u *name, size_t len, int sid)
: STRLEN(import->imp_name) == len : STRLEN(import->imp_name) == len
&& STRNCMP(name, import->imp_name, len) == 0) && STRNCMP(name, import->imp_name, len) == 0)
return import; return import;
else
{
if (nesting >= p_mfd)
{
emsg(_(e_import_nesting_too_deep));
return NULL;
}
++nesting;
import = find_imported_in_script(name, len, import->imp_sid);
--nesting;
if (import != NULL)
return import;
}
} }
return NULL; return NULL;
} }