echo 'DelMe'
endfunc
+def Test_error_reporting()
+ # comment lines at the start of the function
+ let lines =<< trim END
+ " comment
+ def Func()
+ # comment
+ # comment
+ invalid
+ enddef
+ defcompile
+ END
+ call writefile(lines, 'Xdef')
+ try
+ source Xdef
+ catch /E476:/
+ assert_match('Invalid command: invalid', v:exception)
+ assert_match(', line 3$', v:throwpoint)
+ endtry
+
+ # comment lines after the start of the function
+ lines =<< trim END
+ " comment
+ def Func()
+ let x = 1234
+ # comment
+ # comment
+ invalid
+ enddef
+ defcompile
+ END
+ call writefile(lines, 'Xdef')
+ try
+ source Xdef
+ catch /E476:/
+ assert_match('Invalid command: invalid', v:exception)
+ assert_match(', line 4$', v:throwpoint)
+ endtry
+
+ call delete('Xdef')
+enddef
+
def Test_deleted_function()
CheckDefExecFailure([
'let RefMe: func = function("g:DelMe")',
// Save the starting line number.
sourcing_lnum_top = SOURCING_LNUM;
+ // Detect having skipped over comment lines to find the return
+ // type. Add NULL lines to keep the line count correct.
+ sourcing_lnum_off = get_sourced_lnum(eap->getline, eap->cookie);
+ if (SOURCING_LNUM < sourcing_lnum_off)
+ {
+ sourcing_lnum_off -= SOURCING_LNUM;
+ if (ga_grow(&newlines, sourcing_lnum_off) == FAIL)
+ goto erret;
+ while (sourcing_lnum_off-- > 0)
+ ((char_u **)(newlines.ga_data))[newlines.ga_len++] = NULL;
+ }
+
indent = 2;
nesting = 0;
nesting_def[nesting] = (eap->cmdidx == CMD_def);