diff options
author | Bram Moolenaar <Bram@vim.org> | 2008-01-12 16:12:10 +0000 |
---|---|---|
committer | Bram Moolenaar <Bram@vim.org> | 2008-01-12 16:12:10 +0000 |
commit | 1f14d57a487a2b1018cc7cbaa8d7d81c80293274 (patch) | |
tree | 5f64d0a9645c879a217c265416d0d66e2b80812f /src/normal.c | |
parent | 56cefaf15ad4bc7bc32b544dfcfd14f712482a3b (diff) | |
download | vim-git-1f14d57a487a2b1018cc7cbaa8d7d81c80293274.tar.gz |
updated for version 7.1-220v7.1.220
Diffstat (limited to 'src/normal.c')
-rw-r--r-- | src/normal.c | 51 |
1 files changed, 39 insertions, 12 deletions
diff --git a/src/normal.c b/src/normal.c index e310a3725..d5e8ead2a 100644 --- a/src/normal.c +++ b/src/normal.c @@ -150,6 +150,7 @@ static void nv_pipe __ARGS((cmdarg_T *cap)); static void nv_bck_word __ARGS((cmdarg_T *cap)); static void nv_wordcmd __ARGS((cmdarg_T *cap)); static void nv_beginline __ARGS((cmdarg_T *cap)); +static void adjust_cursor __ARGS((oparg_T *oap)); #ifdef FEAT_VISUAL static void adjust_for_sel __ARGS((cmdarg_T *cap)); static int unadjust_for_sel __ARGS((void)); @@ -6567,12 +6568,8 @@ nv_brace(cap) clearopbeep(cap->oap); else { - /* Don't leave the cursor on the NUL past a line */ - if (curwin->w_cursor.col > 0 && gchar_cursor() == NUL) - { - --curwin->w_cursor.col; - cap->oap->inclusive = TRUE; - } + /* Don't leave the cursor on the NUL past end of line. */ + adjust_cursor(cap->oap); #ifdef FEAT_VIRTUALEDIT curwin->w_cursor.coladd = 0; #endif @@ -8408,12 +8405,9 @@ nv_wordcmd(cap) else n = fwd_word(cap->count1, cap->arg, cap->oap->op_type != OP_NOP); - /* Don't leave the cursor on the NUL past a line */ - if (n != FAIL && curwin->w_cursor.col > 0 && gchar_cursor() == NUL) - { - --curwin->w_cursor.col; - cap->oap->inclusive = TRUE; - } + /* Don't leave the cursor on the NUL past the end of line. */ + if (n != FAIL) + adjust_cursor(cap->oap); if (n == FAIL && cap->oap->op_type == OP_NOP) clearopbeep(cap->oap); @@ -8430,6 +8424,39 @@ nv_wordcmd(cap) } /* + * Used after a movement command: If the cursor ends up on the NUL after the + * end of the line, may move it back to the last character and make the motion + * inclusive. + */ + static void +adjust_cursor(oap) + oparg_T *oap; +{ + /* The cursor cannot remain on the NUL when: + * - the column is > 0 + * - not in Visual mode or 'selection' is "o" + * - 'virtualedit' is not "all" and not "onemore". + */ + if (curwin->w_cursor.col > 0 && gchar_cursor() == NUL +#ifdef FEAT_VISUAL + && (!VIsual_active || *p_sel == 'o') +#endif +#ifdef FEAT_VIRTUALEDIT + && !virtual_active() && (ve_flags & VE_ONEMORE) == 0 +#endif + ) + { + --curwin->w_cursor.col; +#ifdef FEAT_MBYTE + /* prevent cursor from moving on the trail byte */ + if (has_mbyte) + mb_adjust_cursor(); +#endif + oap->inclusive = TRUE; + } +} + +/* * "0" and "^" commands. * cap->arg is the argument for beginline(). */ |