aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJurica Bradaric <jbradaric@gmail.com>2019-10-13 00:04:41 +0200
committerJurica Bradaric <jbradaric@gmail.com>2019-10-13 11:54:54 +0200
commit76f548a4765a95ee728ec65b84b8032170b483eb (patch)
tree4a81046e4b77ad8ef7fe59dd72cb1ed3268dd8d9 /src
parent3b894b1cb18a9d4e399ab5b55004767f63a384c3 (diff)
downloadrneovim-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.c39
-rw-r--r--src/nvim/testdir/test_let.vim9
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