mirror of
https://github.com/vim/vim.git
synced 2025-09-25 03:54:15 -04:00
patch 8.0.0851: 'smartindent' is used even when 'indentexpr' is set
Problem: 'smartindent' is used even when 'indentexpr' is set. Solution: Ignore 'smartindent' when 'indentexpr' is set. (Hirohito Higashi)
This commit is contained in:
@@ -626,6 +626,9 @@ open_line(
|
|||||||
int do_si = (!p_paste && curbuf->b_p_si
|
int do_si = (!p_paste && curbuf->b_p_si
|
||||||
# ifdef FEAT_CINDENT
|
# ifdef FEAT_CINDENT
|
||||||
&& !curbuf->b_p_cin
|
&& !curbuf->b_p_cin
|
||||||
|
# endif
|
||||||
|
# ifdef FEAT_EVAL
|
||||||
|
&& *curbuf->b_p_inde == NUL
|
||||||
# endif
|
# endif
|
||||||
);
|
);
|
||||||
int no_si = FALSE; /* reset did_si afterwards */
|
int no_si = FALSE; /* reset did_si afterwards */
|
||||||
|
@@ -1,3 +1,4 @@
|
|||||||
|
" Tests for smartindent
|
||||||
|
|
||||||
" Tests for not doing smart indenting when it isn't set.
|
" Tests for not doing smart indenting when it isn't set.
|
||||||
function! Test_nosmartindent()
|
function! Test_nosmartindent()
|
||||||
@@ -12,3 +13,29 @@ function! Test_nosmartindent()
|
|||||||
call assert_equal(" #test", getline(1))
|
call assert_equal(" #test", getline(1))
|
||||||
enew! | close
|
enew! | close
|
||||||
endfunction
|
endfunction
|
||||||
|
|
||||||
|
function MyIndent()
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
" When 'indentexpr' is set, setting 'si' has no effect.
|
||||||
|
function Test_smartindent_has_no_effect()
|
||||||
|
new
|
||||||
|
exe "normal! i\<Tab>one\<Esc>"
|
||||||
|
set noautoindent
|
||||||
|
set smartindent
|
||||||
|
set indentexpr=
|
||||||
|
exe "normal! Gotwo\<Esc>"
|
||||||
|
call assert_equal("\ttwo", getline("$"))
|
||||||
|
|
||||||
|
set indentexpr=MyIndent
|
||||||
|
exe "normal! Gothree\<Esc>"
|
||||||
|
call assert_equal("three", getline("$"))
|
||||||
|
|
||||||
|
delfunction! MyIndent
|
||||||
|
set autoindent&
|
||||||
|
set smartindent&
|
||||||
|
set indentexpr&
|
||||||
|
bwipe!
|
||||||
|
endfunction
|
||||||
|
|
||||||
|
" vim: shiftwidth=2 sts=2 expandtab
|
||||||
|
@@ -769,6 +769,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
851,
|
||||||
/**/
|
/**/
|
||||||
850,
|
850,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user