aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/nvim/change.c9
-rw-r--r--src/nvim/change.h13
-rw-r--r--src/nvim/insexpand.c3
3 files changed, 15 insertions, 10 deletions
diff --git a/src/nvim/change.c b/src/nvim/change.c
index 27749576d7..31962b52ce 100644
--- a/src/nvim/change.c
+++ b/src/nvim/change.c
@@ -1071,6 +1071,7 @@ bool copy_indent(int size, char *src)
/// OPENLINE_KEEPTRAIL keep trailing spaces
/// OPENLINE_MARKFIX adjust mark positions after the line break
/// OPENLINE_COM_LIST format comments with list or 2nd line indent
+/// OPENLINE_FORCE_INDENT set indent from second_line_indent, ignore 'autoindent'
///
/// "second_line_indent": indent for after ^^D in Insert mode or if flag
/// OPENLINE_COM_LIST
@@ -1162,9 +1163,11 @@ bool open_line(int dir, int flags, int second_line_indent, bool *did_do_comment)
trunc_line = true;
}
- // If 'autoindent' and/or 'smartindent' is set, try to figure out what
- // indent to use for the new line.
- if (curbuf->b_p_ai || do_si) {
+ if ((flags & OPENLINE_FORCE_INDENT)) {
+ newindent = second_line_indent;
+ } else if (curbuf->b_p_ai || do_si) {
+ // If 'autoindent' and/or 'smartindent' is set, try to figure out what
+ // indent to use for the new line.
// count white space on current line
newindent = indent_size_ts(saved_line, curbuf->b_p_ts, curbuf->b_p_vts_array);
if (newindent == 0 && !(flags & OPENLINE_COM_LIST)) {
diff --git a/src/nvim/change.h b/src/nvim/change.h
index bd1094d57e..084d66c51f 100644
--- a/src/nvim/change.h
+++ b/src/nvim/change.h
@@ -7,12 +7,13 @@
/// flags for open_line()
enum {
- OPENLINE_DELSPACES = 0x01, ///< delete spaces after cursor
- OPENLINE_DO_COM = 0x02, ///< format comments
- OPENLINE_KEEPTRAIL = 0x04, ///< keep trailing spaces
- OPENLINE_MARKFIX = 0x08, ///< fix mark positions
- OPENLINE_COM_LIST = 0x10, ///< format comments with list/2nd line indent
- OPENLINE_FORMAT = 0x20, ///< formatting long comment
+ OPENLINE_DELSPACES = 0x01, ///< delete spaces after cursor
+ OPENLINE_DO_COM = 0x02, ///< format comments
+ OPENLINE_KEEPTRAIL = 0x04, ///< keep trailing spaces
+ OPENLINE_MARKFIX = 0x08, ///< fix mark positions
+ OPENLINE_COM_LIST = 0x10, ///< format comments with list/2nd line indent
+ OPENLINE_FORMAT = 0x20, ///< formatting long comment
+ OPENLINE_FORCE_INDENT = 0x40, ///< use second_line_indent without indent logic
};
#ifdef INCLUDE_GENERATED_DECLARATIONS
diff --git a/src/nvim/insexpand.c b/src/nvim/insexpand.c
index fdae0d7327..0c06447233 100644
--- a/src/nvim/insexpand.c
+++ b/src/nvim/insexpand.c
@@ -3833,6 +3833,7 @@ static void ins_compl_expand_multiple(char *str)
{
char *start = str;
char *curr = str;
+ int base_indent = get_indent();
while (*curr != NUL) {
if (*curr == '\n') {
// Insert the text chunk before newline
@@ -3841,7 +3842,7 @@ static void ins_compl_expand_multiple(char *str)
}
// Handle newline
- open_line(FORWARD, OPENLINE_KEEPTRAIL, false, NULL);
+ open_line(FORWARD, OPENLINE_KEEPTRAIL | OPENLINE_FORCE_INDENT, base_indent, NULL);
start = curr + 1;
}
curr++;