diff options
author | Jurica Bradaric <jbradaric@gmail.com> | 2019-10-13 00:04:41 +0200 |
---|---|---|
committer | Jurica Bradaric <jbradaric@gmail.com> | 2019-10-13 11:54:54 +0200 |
commit | 76f548a4765a95ee728ec65b84b8032170b483eb (patch) | |
tree | 4a81046e4b77ad8ef7fe59dd72cb1ed3268dd8d9 /src | |
parent | 3b894b1cb18a9d4e399ab5b55004767f63a384c3 (diff) | |
download | rneovim-76f548a4765a95ee728ec65b84b8032170b483eb.tar.gz rneovim-76f548a4765a95ee728ec65b84b8032170b483eb.tar.bz2 rneovim-76f548a4765a95ee728ec65b84b8032170b483eb.zip |
vim-patch:8.1.1729: heredoc with trim not properly handled in function
Problem: Heredoc with trim not properly handled in function.
Solution: Allow for missing indent. (FUJIWARA Takuya, closes vim/vim#4713)
https://github.com/vim/vim/commit/ecaa75b4cea329a3902b8565e028b32279b8322b
Diffstat (limited to 'src')
-rw-r--r-- | src/nvim/eval.c | 39 | ||||
-rw-r--r-- | src/nvim/testdir/test_let.vim | 9 |
2 files changed, 34 insertions, 14 deletions
diff --git a/src/nvim/eval.c b/src/nvim/eval.c index 7db9386937..fd37e1001a 100644 --- a/src/nvim/eval.c +++ b/src/nvim/eval.c @@ -21297,8 +21297,6 @@ void ex_function(exarg_T *eap) bool overwrite = false; int indent; int nesting; - char_u *skip_until = NULL; - char_u *trimmed = NULL; dictitem_T *v; funcdict_T fudi; static int func_nr = 0; /* number for nameless function */ @@ -21308,6 +21306,9 @@ void ex_function(exarg_T *eap) hashitem_T *hi; linenr_T sourcing_lnum_off; linenr_T sourcing_lnum_top; + bool is_heredoc = false; + char_u *skip_until = NULL; + char_u *heredoc_trimmed = NULL; bool show_block = false; bool do_concat = true; @@ -21608,14 +21609,27 @@ void ex_function(exarg_T *eap) } if (skip_until != NULL) { - // Between ":append" and "." and between ":python <<EOF" and "EOF" - // don't check for ":endfunc". - if (trimmed == NULL || STRNCMP(theline, trimmed, STRLEN(trimmed)) == 0) { - p = trimmed == NULL ? theline : theline + STRLEN(trimmed); + // Don't check for ":endfunc" between + // * ":append" and "." + // * ":python <<EOF" and "EOF" + // * ":let {var-name} =<< [trim] {marker}" and "{marker}" + if (heredoc_trimmed == NULL + || (is_heredoc && skipwhite(theline) == theline) + || STRNCMP(theline, heredoc_trimmed, + STRLEN(heredoc_trimmed)) == 0) { + if (heredoc_trimmed == NULL) { + p = theline; + } else if (is_heredoc) { + p = skipwhite(theline) == theline + ? theline : theline + STRLEN(heredoc_trimmed); + } else { + p = theline + STRLEN(heredoc_trimmed); + } if (STRCMP(p, skip_until) == 0) { XFREE_CLEAR(skip_until); - XFREE_CLEAR(trimmed); + XFREE_CLEAR(heredoc_trimmed); do_concat = true; + is_heredoc = false; } } } else { @@ -21723,19 +21737,16 @@ void ex_function(exarg_T *eap) && ((p[0] == 'l' && p[1] == 'e' && (!ASCII_ISALNUM(p[2]) || (p[2] == 't' && !ASCII_ISALNUM(p[3])))))) { - // ":let v =<<" continues until a dot p = skipwhite(arg + 3); if (STRNCMP(p, "trim", 4) == 0) { // Ignore leading white space. p = skipwhite(p + 4); - trimmed = vim_strnsave(theline, (int)(skipwhite(theline) - theline)); - } - if (*p == NUL) { - skip_until = vim_strsave((char_u *)"."); - } else { - skip_until = vim_strnsave(p, (int)(skiptowhite(p) - p)); + heredoc_trimmed = vim_strnsave(theline, + (int)(skipwhite(theline) - theline)); } + skip_until = vim_strnsave(p, (int)(skiptowhite(p) - p)); do_concat = false; + is_heredoc = true; } } diff --git a/src/nvim/testdir/test_let.vim b/src/nvim/testdir/test_let.vim index 66067d3fc0..b5af871ab2 100644 --- a/src/nvim/testdir/test_let.vim +++ b/src/nvim/testdir/test_let.vim @@ -177,6 +177,15 @@ func Test_let_heredoc_fails() call delete('XheredocBadMarker') endfunc +func Test_let_heredoc_trim_no_indent_marker() + let text =<< trim END + Text + with + indent +END + call assert_equal(['Text', 'with', 'indent'], text) +endfunc + " Test for the setting a variable using the heredoc syntax func Test_let_heredoc() let var1 =<< END |