diff options
author | Bram Moolenaar <Bram@vim.org> | 2015-02-03 18:36:44 +0100 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2015-02-03 18:36:44 +0100 |
commit | f2c03d7301d35590a20cc43431950acc3a2f6036 (patch) | |
tree | f9f0ccae6e52b45db76415416809f85281721980 /src/ops.c | |
parent | e71eea801ec779e2d19f4b486313b59de2137a8a (diff) | |
download | vim-git-f2c03d7301d35590a20cc43431950acc3a2f6036.tar.gz |
updated for version 7.4.616v7.4.616
Problem: Cannot insert a tab in front of a block.
Solution: Correctly compute aop->start. (Christian Brabandt)
Diffstat (limited to 'src/ops.c')
-rw-r--r-- | src/ops.c | 23 |
1 files changed, 17 insertions, 6 deletions
@@ -2544,6 +2544,7 @@ op_insert(oap, count1) char_u *firstline, *ins_text; struct block_def bd; int i; + pos_T t1; /* edit() changes this - record it for OP_APPEND */ bd.is_MAX = (curwin->w_curswant == MAXCOL); @@ -2617,8 +2618,16 @@ op_insert(oap, count1) } } + t1 = oap->start; edit(NUL, FALSE, (linenr_T)count1); + /* When a tab was inserted, and the characters in front of the tab + * have been converted to a tab as well, the column of the cursor + * might have actually been reduced, so need to adjust here. */ + if (t1.lnum == curbuf->b_op_start_orig.lnum + && lt(curbuf->b_op_start_orig, t1)) + oap->start = curbuf->b_op_start_orig; + /* If user has moved off this line, we don't know what to do, so do * nothing. * Also don't repeat the insert when Insert mode ended with CTRL-C. */ @@ -2644,10 +2653,11 @@ op_insert(oap, count1) #endif ) { + int t = getviscol2(curbuf->b_op_start_orig.col, + curbuf->b_op_start_orig.coladd); oap->start.col = curbuf->b_op_start_orig.col; - pre_textlen -= getviscol2(oap->start.col, oap->start.coladd) - - oap->start_vcol; - oap->start_vcol = getviscol2(oap->start.col, oap->start.coladd); + pre_textlen -= t - oap->start_vcol; + oap->start_vcol = t; } else if (oap->op_type == OP_APPEND && oap->end.col @@ -2660,12 +2670,13 @@ op_insert(oap, count1) #endif ) { + int t = getviscol2(curbuf->b_op_start_orig.col, + curbuf->b_op_start_orig.coladd); oap->start.col = curbuf->b_op_start_orig.col; /* reset pre_textlen to the value of OP_INSERT */ pre_textlen += bd.textlen; - pre_textlen -= getviscol2(oap->start.col, oap->start.coladd) - - oap->start_vcol; - oap->start_vcol = getviscol2(oap->start.col, oap->start.coladd); + pre_textlen -= t - oap->start_vcol; + oap->start_vcol = t; oap->op_type = OP_INSERT; } } |