mirror of
https://github.com/neovim/neovim.git
synced 2025-02-25 18:55:25 -06:00
vim-patch:9.1.0313: Crash when using heredoc with comment in command block
Problem: Crash when using heredoc with comment in command block.
Solution: Handle a newline more like the end of the line, fix coverity
warning (zeertzjq).
closes: vim/vim#14535
1f5175d9af
This commit is contained in:
parent
617a385142
commit
e81fe387d6
@ -1045,20 +1045,6 @@ char *skiptowhite(const char *p)
|
|||||||
return (char *)p;
|
return (char *)p;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Skip over text until ' ' or '\t' or newline or NUL
|
|
||||||
///
|
|
||||||
/// @param[in] p Text to skip over.
|
|
||||||
///
|
|
||||||
/// @return Pointer to the next whitespace or newline or NUL character.
|
|
||||||
char *skiptowhite_or_nl(const char *p)
|
|
||||||
FUNC_ATTR_NONNULL_ALL FUNC_ATTR_PURE
|
|
||||||
{
|
|
||||||
while (*p != ' ' && *p != '\t' && *p != NL && *p != NUL) {
|
|
||||||
p++;
|
|
||||||
}
|
|
||||||
return (char *)p;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// skiptowhite_esc: Like skiptowhite(), but also skip escaped chars
|
/// skiptowhite_esc: Like skiptowhite(), but also skip escaped chars
|
||||||
///
|
///
|
||||||
/// @param p
|
/// @param p
|
||||||
|
@ -179,8 +179,15 @@ list_T *heredoc_get(exarg_T *eap, char *cmd, bool script_get)
|
|||||||
int text_indent_len = 0;
|
int text_indent_len = 0;
|
||||||
char *text_indent = NULL;
|
char *text_indent = NULL;
|
||||||
char dot[] = ".";
|
char dot[] = ".";
|
||||||
|
bool heredoc_in_string = false;
|
||||||
|
char *line_arg = NULL;
|
||||||
|
char *nl_ptr = vim_strchr(cmd, '\n');
|
||||||
|
|
||||||
if (eap->ea_getline == NULL && vim_strchr(cmd, '\n') == NULL) {
|
if (nl_ptr != NULL) {
|
||||||
|
heredoc_in_string = true;
|
||||||
|
line_arg = nl_ptr + 1;
|
||||||
|
*nl_ptr = NUL;
|
||||||
|
} else if (eap->ea_getline == NULL) {
|
||||||
emsg(_(e_cannot_use_heredoc_here));
|
emsg(_(e_cannot_use_heredoc_here));
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
@ -217,17 +224,11 @@ list_T *heredoc_get(exarg_T *eap, char *cmd, bool script_get)
|
|||||||
}
|
}
|
||||||
|
|
||||||
const char comment_char = '"';
|
const char comment_char = '"';
|
||||||
bool heredoc_in_string = false;
|
|
||||||
char *line_arg = NULL;
|
|
||||||
// The marker is the next word.
|
// The marker is the next word.
|
||||||
if (*cmd != NUL && *cmd != comment_char) {
|
if (*cmd != NUL && *cmd != comment_char) {
|
||||||
marker = skipwhite(cmd);
|
marker = skipwhite(cmd);
|
||||||
char *p = skiptowhite_or_nl(marker);
|
char *p = skiptowhite(marker);
|
||||||
if (*p == NL) {
|
if (*skipwhite(p) != NUL && *skipwhite(p) != comment_char) {
|
||||||
// heredoc in a string
|
|
||||||
line_arg = p + 1;
|
|
||||||
heredoc_in_string = true;
|
|
||||||
} else if (*skipwhite(p) != NUL && *skipwhite(p) != comment_char) {
|
|
||||||
semsg(_(e_trailing_arg), p);
|
semsg(_(e_trailing_arg), p);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
@ -542,6 +542,13 @@ END
|
|||||||
XX
|
XX
|
||||||
call assert_equal(['Line1'], var1)
|
call assert_equal(['Line1'], var1)
|
||||||
|
|
||||||
|
let var1 =<< trim XX " comment
|
||||||
|
Line1
|
||||||
|
Line2
|
||||||
|
Line3
|
||||||
|
XX
|
||||||
|
call assert_equal(['Line1', ' Line2', 'Line3'], var1)
|
||||||
|
|
||||||
" ignore "endfunc"
|
" ignore "endfunc"
|
||||||
let var1 =<< END
|
let var1 =<< END
|
||||||
something
|
something
|
||||||
@ -714,15 +721,27 @@ END
|
|||||||
call CheckScriptFailure(lines, 'E15:')
|
call CheckScriptFailure(lines, 'E15:')
|
||||||
|
|
||||||
" Test for using heredoc in a single string using execute()
|
" Test for using heredoc in a single string using execute()
|
||||||
call assert_equal(["['one', 'two']"],
|
call assert_equal("\n['one', 'two']",
|
||||||
\ execute("let x =<< trim END\n one\n two\nEND\necho x")->split("\n"))
|
\ execute("let x =<< trim END\n one\n two\nEND\necho x"))
|
||||||
call assert_equal(["[' one', ' two']"],
|
call assert_equal("\n['one', ' two']",
|
||||||
\ execute("let x =<< END\n one\n two\nEND\necho x")->split("\n"))
|
\ execute("let x =<< trim END\n one\n two\nEND\necho x"))
|
||||||
|
call assert_equal("\n['one', 'two']",
|
||||||
|
\ execute(" let x =<< trim END\n one\n two\n END\necho x"))
|
||||||
|
call assert_equal("\n['one', ' two']",
|
||||||
|
\ execute(" let x =<< trim END\n one\n two\n END\necho x"))
|
||||||
|
call assert_equal("\n[' one', ' two']",
|
||||||
|
\ execute("let x =<< END\n one\n two\nEND\necho x"))
|
||||||
|
call assert_equal("\n['one', 'two']",
|
||||||
|
\ execute("let x =<< END\none\ntwo\nEND\necho x"))
|
||||||
|
call assert_equal("\n['one', 'two']",
|
||||||
|
\ execute("let x =<< END \" comment\none\ntwo\nEND\necho x"))
|
||||||
let cmd = 'execute("let x =<< END\n one\n two\necho x")'
|
let cmd = 'execute("let x =<< END\n one\n two\necho x")'
|
||||||
call assert_fails(cmd, "E990: Missing end marker 'END'")
|
call assert_fails(cmd, "E990: Missing end marker 'END'")
|
||||||
let cmd = 'execute("let x =<<\n one\n two\necho x")'
|
let cmd = 'execute("let x =<<\n one\n two\necho x")'
|
||||||
call assert_fails(cmd, "E990: Missing end marker ''")
|
call assert_fails(cmd, "E172: Missing marker")
|
||||||
let cmd = 'execute("let x =<< trim\n one\n two\necho x")'
|
let cmd = 'execute("let x =<< trim\n one\n two\necho x")'
|
||||||
|
call assert_fails(cmd, "E172: Missing marker")
|
||||||
|
let cmd = 'execute("let x =<< end\n one\n two\nend\necho x")'
|
||||||
call assert_fails(cmd, "E221: Marker cannot start with lower case letter")
|
call assert_fails(cmd, "E221: Marker cannot start with lower case letter")
|
||||||
let cmd = 'execute("let x =<< eval END\n one\n two{y}\nEND\necho x")'
|
let cmd = 'execute("let x =<< eval END\n one\n two{y}\nEND\necho x")'
|
||||||
call assert_fails(cmd, 'E121: Undefined variable: y')
|
call assert_fails(cmd, 'E121: Undefined variable: y')
|
||||||
|
Loading…
Reference in New Issue
Block a user