Problem: Vim9: crash when using a partial in the wrong context.
Solution: Don't use an NULL outer pointer. (closes #9706)
v9.CheckScriptFailure(lines, 'E1235:')
enddef
+" Using "idx" from a legacy global function does not work.
+" This caused a crash when called from legacy context.
+func Test_partial_call_fails()
+ let lines =<< trim END
+ vim9script
+
+ var l = ['a', 'b', 'c']
+ def Iter(container: any): any
+ var idx = -1
+ var obj = {state: container}
+ def g:__NextItem__(self: dict<any>): any
+ ++idx
+ return self.state[idx]
+ enddef
+ obj.__next__ = function('g:__NextItem__', [obj])
+ return obj
+ enddef
+
+ var it = Iter(l)
+ echo it.__next__()
+ END
+ call writefile(lines, 'XpartialCall')
+ try
+ source XpartialCall
+ catch /E1248:/
+ endtry
+ call delete('XpartialCall')
+endfunc
+
def Test_cmd_modifier()
tab echo '0'
v9.CheckDefFailure(['5tab echo 3'], 'E16:')
static int included_patches[] =
{ /* Add new patch number below this line */
+/**/
+ 4309,
/**/
4308,
/**/
}
/*
- * Store a value in a list or dict variable.
+ * Store a value in a list, dict or blob variable.
* Returns OK, FAIL or NOTDONE (uncatchable error).
*/
static int
goto failed_early;
if (partial != NULL)
{
- if (partial->pt_outer.out_stack == NULL && current_ectx != NULL)
+ if (partial->pt_outer.out_stack == NULL)
{
- if (current_ectx->ec_outer_ref != NULL
- && current_ectx->ec_outer_ref->or_outer != NULL)
- ectx.ec_outer_ref->or_outer =
+ if (current_ectx != NULL)
+ {
+ if (current_ectx->ec_outer_ref != NULL
+ && current_ectx->ec_outer_ref->or_outer != NULL)
+ ectx.ec_outer_ref->or_outer =
current_ectx->ec_outer_ref->or_outer;
+ }
+ // Should there be an error here?
}
else
{