To: vim_dev@googlegroups.com Subject: Patch 7.4.212 Fcc: outbox From: Bram Moolenaar <Bram@moolenaar.net> Mime-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit ------------ Patch 7.4.212 (after 7.4.200) Problem: Now that the +visual feature is always enabled the #ifdefs for it are not useful. Solution: Remove the checks for FEAT_VISUAL. Files: src/buffer.c, src/charset.c, src/edit.c, src/eval.c, src/ex_cmds.c, src/ex_docmd.c, src/fold.c, src/getchar.c, src/gui.c, src/gui_mac.c, src/gui_w48.c, src/main.c, src/mark.c, src/menu.c, src/misc2.c, src/move.c, src/netbeans.c, src/normal.c, src/ops.c, src/option.c, src/os_msdos.c, src/os_qnx.c, src/quickfix.c, src/regexp.c, src/regexp_nfa.c, src/screen.c, src/search.c, src/spell.c, src/syntax.c, src/term.c, src/ui.c, src/undo.c, src/version.c, src/window.c, src/feature.h, src/globals.h, src/option.h, src/os_win32.h, src/structs.h *** ../vim-7.4.211/src/buffer.c 2014-03-12 18:55:52.100906804 +0100 --- src/buffer.c 2014-03-23 13:01:39.843144050 +0100 *************** *** 1432,1441 **** curwin->w_alt_fnum = curbuf->b_fnum; /* remember alternate file */ buflist_altfpos(curwin); /* remember curpos */ - #ifdef FEAT_VISUAL /* Don't restart Select mode after switching to another buffer. */ VIsual_reselect = FALSE; - #endif /* close_windows() or apply_autocmds() may change curbuf */ prevbuf = curbuf; --- 1432,1439 ---- *** ../vim-7.4.211/src/charset.c 2013-02-06 16:20:01.000000000 +0100 --- src/charset.c 2014-03-23 13:02:19.467144657 +0100 *************** *** 1380,1389 **** && (State & NORMAL) && !wp->w_p_list && !virtual_active() ! #ifdef FEAT_VISUAL ! && !(VIsual_active ! && (*p_sel == 'e' || ltoreq(*pos, VIsual))) ! #endif ) *cursor = vcol + incr - 1; /* cursor at end */ else --- 1380,1386 ---- && (State & NORMAL) && !wp->w_p_list && !virtual_active() ! && !(VIsual_active && (*p_sel == 'e' || ltoreq(*pos, VIsual))) ) *cursor = vcol + incr - 1; /* cursor at end */ else *************** *** 1463,1469 **** } #endif - #if defined(FEAT_VISUAL) || defined(PROTO) /* * Get the leftmost and rightmost virtual column of pos1 and pos2. * Used for Visual block mode. --- 1460,1465 ---- *************** *** 1500,1506 **** else *right = to1; } - #endif /* * skipwhite: skip over ' ' and '\t'. --- 1496,1501 ---- *** ../vim-7.4.211/src/edit.c 2014-02-22 23:03:48.712901208 +0100 --- src/edit.c 2014-03-23 13:03:11.951145462 +0100 *************** *** 220,228 **** #ifdef FEAT_RIGHTLEFT static void ins_ctrl_ __ARGS((void)); #endif - #ifdef FEAT_VISUAL static int ins_start_select __ARGS((int c)); - #endif static void ins_insert __ARGS((int replaceState)); static void ins_ctrl_o __ARGS((void)); static void ins_shift __ARGS((int c, int lastc)); --- 220,226 ---- *************** *** 932,938 **** } #endif - #ifdef FEAT_VISUAL /* * If 'keymodel' contains "startsel", may start selection. If it * does, a CTRL-O and c will be stuffed, we need to get these --- 930,935 ---- *************** *** 940,946 **** */ if (ins_start_select(c)) continue; - #endif /* * The big switch to handle a character in insert mode. --- 937,942 ---- *************** *** 6900,6906 **** else if (cc != NUL) ++curwin->w_cursor.col; /* put cursor back on the NUL */ - #ifdef FEAT_VISUAL /* <C-S-Right> may have started Visual mode, adjust the position for * deleted characters. */ if (VIsual_active && VIsual.lnum == curwin->w_cursor.lnum) --- 6896,6901 ---- *************** *** 6910,6921 **** if (VIsual.col > len) { VIsual.col = len; ! # ifdef FEAT_VIRTUALEDIT VIsual.coladd = 0; ! # endif } } - #endif } } did_ai = FALSE; --- 6905,6915 ---- if (VIsual.col > len) { VIsual.col = len; ! #ifdef FEAT_VIRTUALEDIT VIsual.coladd = 0; ! #endif } } } } did_ai = FALSE; *************** *** 8112,8120 **** int need_redraw = FALSE; int regname; int literally = 0; - #ifdef FEAT_VISUAL int vis_active = VIsual_active; - #endif /* * If we are going to wait for a character, show a '"'. --- 8106,8112 ---- *************** *** 8218,8228 **** if (need_redraw || stuff_empty()) edit_unputchar(); - #ifdef FEAT_VISUAL /* Disallow starting Visual mode here, would get a weird mode. */ if (!vis_active && VIsual_active) end_visual_mode(); - #endif } /* --- 8210,8218 ---- *************** *** 8419,8429 **** #endif ) && (restart_edit == NUL ! || (gchar_cursor() == NUL ! #ifdef FEAT_VISUAL ! && !VIsual_active ! #endif ! )) #ifdef FEAT_RIGHTLEFT && !revins_on #endif --- 8409,8415 ---- #endif ) && (restart_edit == NUL ! || (gchar_cursor() == NUL && !VIsual_active)) #ifdef FEAT_RIGHTLEFT && !revins_on #endif *************** *** 8525,8531 **** } #endif - #ifdef FEAT_VISUAL /* * If 'keymodel' contains "startsel", may start selection. * Returns TRUE when a CTRL-O and other keys stuffed. --- 8511,8516 ---- *************** *** 8581,8587 **** } return FALSE; } - #endif /* * <Insert> key in Insert mode: toggle insert/replace mode. --- 8566,8571 ---- *** ../vim-7.4.211/src/eval.c 2014-02-24 03:31:55.816738026 +0100 --- src/eval.c 2014-03-23 13:03:56.419146143 +0100 *************** *** 11833,11844 **** { case MLINE: buf[0] = 'V'; break; case MCHAR: buf[0] = 'v'; break; - #ifdef FEAT_VISUAL case MBLOCK: buf[0] = Ctrl_V; sprintf((char *)buf + 1, "%ld", reglen + 1); break; - #endif } rettv->v_type = VAR_STRING; rettv->vval.v_string = vim_strsave(buf); --- 11833,11842 ---- *************** *** 12552,12560 **** #ifdef FEAT_VIRTUALEDIT "virtualedit", #endif - #ifdef FEAT_VISUAL "visual", - #endif #ifdef FEAT_VISUALEXTRA "visualextra", #endif --- 12550,12556 ---- *************** *** 14397,14403 **** buf[1] = NUL; buf[2] = NUL; - #ifdef FEAT_VISUAL if (VIsual_active) { if (VIsual_select) --- 14393,14398 ---- *************** *** 14405,14413 **** else buf[0] = VIsual_mode; } ! else ! #endif ! if (State == HITRETURN || State == ASKMORE || State == SETWSIZE || State == CONFIRM) { buf[0] = 'r'; --- 14400,14406 ---- else buf[0] = VIsual_mode; } ! else if (State == HITRETURN || State == ASKMORE || State == SETWSIZE || State == CONFIRM) { buf[0] = 'r'; *************** *** 16756,16762 **** case 'V': case 'l': /* line-wise selection */ yank_type = MLINE; break; - #ifdef FEAT_VISUAL case 'b': case Ctrl_V: /* block-wise selection */ yank_type = MBLOCK; if (VIM_ISDIGIT(stropt[1])) --- 16749,16754 ---- *************** *** 16766,16772 **** --stropt; } break; - #endif } } --- 16758,16763 ---- *************** *** 18769,18775 **** typval_T *argvars UNUSED; typval_T *rettv UNUSED; { - #ifdef FEAT_VISUAL char_u str[2]; rettv->v_type = VAR_STRING; --- 18760,18765 ---- *************** *** 18780,18786 **** /* A non-zero number or non-empty string argument: reset mode. */ if (non_zero_arg(&argvars[0])) curbuf->b_visual_mode_eval = NUL; - #endif } /* --- 18770,18775 ---- *************** *** 19154,19167 **** return NULL; if (name[0] == '.') /* cursor */ return &curwin->w_cursor; - #ifdef FEAT_VISUAL if (name[0] == 'v' && name[1] == NUL) /* Visual start */ { if (VIsual_active) return &VIsual; return &curwin->w_cursor; } - #endif if (name[0] == '\'') /* mark */ { pp = getmark_buf_fnum(curbuf, name[1], FALSE, fnum); --- 19143,19154 ---- *** ../vim-7.4.211/src/ex_cmds.c 2014-03-19 17:41:20.390105580 +0100 --- src/ex_cmds.c 2014-03-23 13:04:09.359146341 +0100 *************** *** 3274,3286 **** goto theend; } - #ifdef FEAT_VISUAL /* * End Visual mode before switching to another buffer, so the text can be * copied into the GUI selection buffer. */ reset_VIsual(); - #endif #ifdef FEAT_AUTOCMD if ((command != NULL || newlnum > (linenr_T)0) --- 3274,3284 ---- *** ../vim-7.4.211/src/ex_docmd.c 2014-03-12 21:28:09.481046816 +0100 --- src/ex_docmd.c 2014-03-23 13:04:47.975146933 +0100 *************** *** 8577,8586 **** beginline(BL_SOL | BL_FIX); } - #if defined(FEAT_VISUAL) if (VIsual_active) end_visual_mode(); - #endif switch (eap->cmdidx) { --- 8577,8584 ---- *************** *** 8991,9001 **** RedrawingDisabled = 0; p_lz = FALSE; update_topline(); ! update_screen(eap->forceit ? CLEAR : ! #ifdef FEAT_VISUAL ! VIsual_active ? INVERTED : ! #endif ! 0); #ifdef FEAT_TITLE if (need_maketitle) maketitle(); --- 8989,8995 ---- RedrawingDisabled = 0; p_lz = FALSE; update_topline(); ! update_screen(eap->forceit ? CLEAR : VIsual_active ? INVERTED : 0); #ifdef FEAT_TITLE if (need_maketitle) maketitle(); *************** *** 9030,9040 **** status_redraw_all(); else status_redraw_curbuf(); ! update_screen( ! # ifdef FEAT_VISUAL ! VIsual_active ? INVERTED : ! # endif ! 0); RedrawingDisabled = r; p_lz = p; out_flush(); --- 9024,9030 ---- status_redraw_all(); else status_redraw_curbuf(); ! update_screen(VIsual_active ? INVERTED : 0); RedrawingDisabled = r; p_lz = p; out_flush(); *** ../vim-7.4.211/src/fold.c 2013-11-05 07:12:59.000000000 +0100 --- src/fold.c 2014-03-23 13:05:14.775147344 +0100 *************** *** 430,440 **** } if (done == DONE_NOTHING) EMSG(_(e_nofold)); - #ifdef FEAT_VISUAL /* Force a redraw to remove the Visual highlighting. */ if (had_visual) redraw_curbuf_later(INVERTED); - #endif } /* openFold() {{{2 */ --- 430,438 ---- *************** *** 807,817 **** if (!did_one) { EMSG(_(e_nofold)); - #ifdef FEAT_VISUAL /* Force a redraw to remove the Visual highlighting. */ if (had_visual) redraw_curbuf_later(INVERTED); - #endif } else /* Deleting markers may make cursor column invalid. */ --- 805,813 ---- *************** *** 1065,1071 **** } /* foldAdjustVisual() {{{2 */ - #ifdef FEAT_VISUAL /* * Adjust the Visual area to include any fold at the start or end completely. */ --- 1061,1066 ---- *************** *** 1103,1109 **** #endif } } - #endif /* cursor_foldstart() {{{2 */ /* --- 1098,1103 ---- *** ../vim-7.4.211/src/getchar.c 2014-03-12 20:17:47.748982126 +0100 --- src/getchar.c 2014-03-23 13:05:45.383147813 +0100 *************** *** 870,876 **** c = read_redo(FALSE, old_redo); } - #ifdef FEAT_VISUAL if (c == 'v') /* redo Visual */ { VIsual = curwin->w_cursor; --- 870,875 ---- *************** *** 880,886 **** redo_VIsual_busy = TRUE; c = read_redo(FALSE, old_redo); } - #endif /* try to enter the count (in place of a previous count) */ if (count) --- 879,884 ---- *************** *** 1162,1168 **** return typebuf.tb_maplen == 0; } - #if defined(FEAT_VISUAL) || defined(PROTO) /* * Return the number of characters that are mapped (or not typed). */ --- 1160,1165 ---- *************** *** 1171,1177 **** { return typebuf.tb_maplen; } - #endif /* * remove "len" characters from typebuf.tb_buf[typebuf.tb_off + offset] --- 1168,1173 ---- *************** *** 2443,2449 **** idx = get_menu_index(current_menu, local_State); if (idx != MENU_INDEX_INVALID) { - # ifdef FEAT_VISUAL /* * In Select mode and a Visual mode menu * is used: Switch to Visual mode --- 2439,2444 ---- *************** *** 2457,2463 **** (void)ins_typebuf(K_SELECT_STRING, REMAP_NONE, 0, TRUE, FALSE); } - # endif ins_typebuf(current_menu->strings[idx], current_menu->noremap[idx], 0, TRUE, --- 2452,2457 ---- *************** *** 2516,2522 **** break; } - #ifdef FEAT_VISUAL /* * In Select mode and a Visual mode mapping is used: * Switch to Visual mode temporarily. Append K_SELECT --- 2510,2515 ---- *************** *** 2529,2535 **** (void)ins_typebuf(K_SELECT_STRING, REMAP_NONE, 0, TRUE, FALSE); } - #endif #ifdef FEAT_EVAL /* Copy the values from *mp that are used, because --- 2522,2527 ---- *** ../vim-7.4.211/src/gui.c 2013-06-30 17:41:48.000000000 +0200 --- src/gui.c 2014-03-23 13:05:57.623148000 +0100 *************** *** 3132,3142 **** */ if (!mouse_has(checkfor) || checkfor == MOUSE_COMMAND) { - #ifdef FEAT_VISUAL /* Don't do modeless selection in Visual mode. */ if (checkfor != MOUSE_NONEF && VIsual_active && (State & NORMAL)) return; - #endif /* * When 'mousemodel' is "popup", shift-left is translated to right. --- 3132,3140 ---- *** ../vim-7.4.211/src/gui_mac.c 2013-05-06 04:06:04.000000000 +0200 --- src/gui_mac.c 2014-03-23 13:06:30.143148498 +0100 *************** *** 1068,1078 **** } */ - - #ifdef FEAT_VISUAL reset_VIsual(); - #endif - fnames = new_fnames_from_AEDesc(&theList, &numFiles, &error); if (error) --- 1068,1074 ---- *************** *** 1142,1148 **** /* Update the screen display */ update_screen(NOT_VALID); ! #ifdef FEAT_VISUAL /* Select the text if possible */ if (gotPosition) { --- 1138,1144 ---- /* Update the screen display */ update_screen(NOT_VALID); ! /* Select the text if possible */ if (gotPosition) { *************** *** 1160,1166 **** VIsual.col = 0; } } ! #endif setcursor(); out_flush(); --- 1156,1162 ---- VIsual.col = 0; } } ! setcursor(); out_flush(); *** ../vim-7.4.211/src/gui_w48.c 2014-03-19 12:37:18.537826062 +0100 --- src/gui_w48.c 2014-03-23 13:06:44.959148725 +0100 *************** *** 3708,3716 **** DragQueryPoint(hDrop, &pt); MapWindowPoints(s_hwnd, s_textArea, &pt, 1); - # ifdef FEAT_VISUAL reset_VIsual(); - # endif fnames = (char_u **)alloc(cFiles * sizeof(char_u *)); --- 3708,3714 ---- *** ../vim-7.4.211/src/main.c 2014-01-14 12:57:00.000000000 +0100 --- src/main.c 2014-03-23 13:07:21.771149289 +0100 *************** *** 1057,1065 **** if (!cmdwin && !noexmode && SETJMP(x_jump_env)) { State = NORMAL; - # ifdef FEAT_VISUAL VIsual_active = FALSE; - # endif got_int = TRUE; need_wait_return = FALSE; global_busy = FALSE; --- 1057,1063 ---- *************** *** 1096,1106 **** check_timestamps(FALSE); if (need_wait_return) /* if wait_return still needed ... */ wait_return(FALSE); /* ... call it now */ ! if (need_start_insertmode && goto_im() ! #ifdef FEAT_VISUAL ! && !VIsual_active ! #endif ! ) { need_start_insertmode = FALSE; stuffReadbuff((char_u *)"i"); /* start insert mode next */ --- 1094,1100 ---- check_timestamps(FALSE); if (need_wait_return) /* if wait_return still needed ... */ wait_return(FALSE); /* ... call it now */ ! if (need_start_insertmode && goto_im() && !VIsual_active) { need_start_insertmode = FALSE; stuffReadbuff((char_u *)"i"); /* start insert mode next */ *************** *** 1202,1208 **** diff_need_scrollbind = FALSE; } #endif ! #if defined(FEAT_FOLDING) && defined(FEAT_VISUAL) /* Include a closed fold completely in the Visual area. */ foldAdjustVisual(); #endif --- 1196,1202 ---- diff_need_scrollbind = FALSE; } #endif ! #if defined(FEAT_FOLDING) /* Include a closed fold completely in the Visual area. */ foldAdjustVisual(); #endif *************** *** 1228,1239 **** update_topline(); validate_cursor(); - #ifdef FEAT_VISUAL if (VIsual_active) update_curbuf(INVERTED);/* update inverted part */ ! else ! #endif ! if (must_redraw) update_screen(0); else if (redraw_cmdline || clear_cmdline) showmode(); --- 1222,1230 ---- update_topline(); validate_cursor(); if (VIsual_active) update_curbuf(INVERTED);/* update inverted part */ ! else if (must_redraw) update_screen(0); else if (redraw_cmdline || clear_cmdline) showmode(); *** ../vim-7.4.211/src/mark.c 2013-11-03 00:20:46.000000000 +0100 --- src/mark.c 2014-03-23 13:08:03.011149921 +0100 *************** *** 98,104 **** return OK; } - #ifdef FEAT_VISUAL if (c == '<' || c == '>') { if (c == '<') --- 98,103 ---- *************** *** 110,116 **** curbuf->b_visual.vi_mode = 'v'; return OK; } - #endif #ifndef EBCDIC if (c > 'z') /* some islower() and isupper() cannot handle --- 109,114 ---- *************** *** 340,348 **** int *fnum; { pos_T *posp; - #ifdef FEAT_VISUAL pos_T *startp, *endp; - #endif static pos_T pos_copy; posp = NULL; --- 338,344 ---- *************** *** 403,409 **** curwin->w_cursor = pos; listcmd_busy = slcb; } - #ifdef FEAT_VISUAL else if (c == '<' || c == '>') /* start/end of visual area */ { startp = &buf->b_visual.vi_start; --- 399,404 ---- *************** *** 428,434 **** #endif } } - #endif else if (ASCII_ISLOWER(c)) /* normal named mark */ { posp = &(buf->b_namedm[c - 'a']); --- 423,428 ---- *************** *** 757,766 **** show_one_mark(']', arg, &curbuf->b_op_end, NULL, TRUE); show_one_mark('^', arg, &curbuf->b_last_insert, NULL, TRUE); show_one_mark('.', arg, &curbuf->b_last_change, NULL, TRUE); - #ifdef FEAT_VISUAL show_one_mark('<', arg, &curbuf->b_visual.vi_start, NULL, TRUE); show_one_mark('>', arg, &curbuf->b_visual.vi_end, NULL, TRUE); - #endif show_one_mark(-1, arg, NULL, NULL, FALSE); } --- 751,758 ---- *************** *** 892,901 **** case '.': curbuf->b_last_change.lnum = 0; break; case '[': curbuf->b_op_start.lnum = 0; break; case ']': curbuf->b_op_end.lnum = 0; break; - #ifdef FEAT_VISUAL case '<': curbuf->b_visual.vi_start.lnum = 0; break; case '>': curbuf->b_visual.vi_end.lnum = 0; break; - #endif case ' ': break; default: EMSG2(_(e_invarg2), p); return; --- 884,891 ---- *************** *** 1085,1095 **** one_adjust_nodel(&(curbuf->b_changelist[i].lnum)); #endif - #ifdef FEAT_VISUAL /* Visual area */ one_adjust_nodel(&(curbuf->b_visual.vi_start.lnum)); one_adjust_nodel(&(curbuf->b_visual.vi_end.lnum)); - #endif #ifdef FEAT_QUICKFIX /* quickfix marks */ --- 1075,1083 ---- *************** *** 1136,1149 **** if (win->w_tagstack[i].fmark.fnum == fnum) one_adjust_nodel(&(win->w_tagstack[i].fmark.mark.lnum)); - #ifdef FEAT_VISUAL /* the displayed Visual area */ if (win->w_old_cursor_lnum != 0) { one_adjust_nodel(&(win->w_old_cursor_lnum)); one_adjust_nodel(&(win->w_old_visual_lnum)); } - #endif /* topline and cursor position for windows with the same buffer * other than the current window */ --- 1124,1135 ---- *************** *** 1260,1270 **** col_adjust(&(curbuf->b_changelist[i])); #endif - #ifdef FEAT_VISUAL /* Visual area */ col_adjust(&(curbuf->b_visual.vi_start)); col_adjust(&(curbuf->b_visual.vi_end)); - #endif /* previous context mark */ col_adjust(&(curwin->w_pcmark)); --- 1246,1254 ---- *** ../vim-7.4.211/src/menu.c 2011-04-11 15:17:21.000000000 +0200 --- src/menu.c 2014-03-23 13:08:19.091150168 +0100 *************** *** 1640,1646 **** idx = MENU_INDEX_INSERT; else if (state & CMDLINE) idx = MENU_INDEX_CMDLINE; - #ifdef FEAT_VISUAL else if (VIsual_active) { if (VIsual_select) --- 1640,1645 ---- *************** *** 1648,1654 **** else idx = MENU_INDEX_VISUAL; } - #endif else if (state == HITRETURN || state == ASKMORE) idx = MENU_INDEX_CMDLINE; else if (finish_op) --- 1647,1652 ---- *************** *** 1811,1824 **** static int get_menu_mode() { - #ifdef FEAT_VISUAL if (VIsual_active) { if (VIsual_select) return MENU_INDEX_SELECT; return MENU_INDEX_VISUAL; } - #endif if (State & INSERT) return MENU_INDEX_INSERT; if ((State & CMDLINE) || State == ASKMORE || State == HITRETURN) --- 1809,1820 ---- *** ../vim-7.4.211/src/misc2.c 2014-02-23 23:38:58.824760280 +0100 --- src/misc2.c 2014-03-23 13:08:56.927150748 +0100 *************** *** 31,39 **** if (virtual_op != MAYBE) return virtual_op; return (ve_flags == VE_ALL - # ifdef FEAT_VISUAL || ((ve_flags & VE_BLOCK) && VIsual_active && VIsual_mode == Ctrl_V) - # endif || ((ve_flags & VE_INSERT) && (State & INSERT))); } --- 31,37 ---- *************** *** 149,157 **** one_more = (State & INSERT) || restart_edit != NUL - #ifdef FEAT_VISUAL || (VIsual_active && *p_sel != 'o') - #endif #ifdef FEAT_VIRTUALEDIT || ((ve_flags & VE_ONEMORE) && wcol < MAXCOL) #endif --- 147,153 ---- *************** *** 570,578 **** * - in Visual mode and 'selection' isn't "old" * - 'virtualedit' is set */ if ((State & INSERT) || restart_edit - #ifdef FEAT_VISUAL || (VIsual_active && *p_sel != 'o') - #endif #ifdef FEAT_VIRTUALEDIT || (ve_flags & VE_ONEMORE) #endif --- 566,572 ---- *************** *** 627,635 **** adjust_cursor_col() { if (curwin->w_cursor.col > 0 - # ifdef FEAT_VISUAL && (!VIsual_active || *p_sel == 'o') - # endif && gchar_cursor() == NUL) --curwin->w_cursor.col; } --- 621,627 ---- *************** *** 3290,3306 **** { if (State & NORMAL) { - #ifdef FEAT_VISUAL if (VIsual_active) { if (VIsual_select) return SELECTMODE; return VISUAL; } ! else ! #endif ! if (finish_op) ! return OP_PENDING; } return State; } --- 3282,3295 ---- { if (State & NORMAL) { if (VIsual_active) { if (VIsual_select) return SELECTMODE; return VISUAL; } ! else if (finish_op) ! return OP_PENDING; } return State; } *************** *** 3738,3744 **** } if (finish_op) return SHAPE_IDX_O; - #ifdef FEAT_VISUAL if (VIsual_active) { if (*p_sel == 'e') --- 3727,3732 ---- *************** *** 3746,3752 **** else return SHAPE_IDX_V; } - #endif return SHAPE_IDX_N; } #endif --- 3734,3739 ---- *** ../vim-7.4.211/src/move.c 2014-02-11 18:58:05.102320947 +0100 --- src/move.c 2014-03-23 13:09:16.535151048 +0100 *************** *** 2857,2873 **** win_T *old_curwin = curwin; buf_T *old_curbuf = curbuf; int restart_edit_save; - # ifdef FEAT_VISUAL int old_VIsual_select = VIsual_select; int old_VIsual_active = VIsual_active; - # endif /* * loop through the cursorbound windows */ - # ifdef FEAT_VISUAL VIsual_select = VIsual_active = 0; - # endif for (curwin = firstwin; curwin; curwin = curwin->w_next) { curbuf = curwin->w_buffer; --- 2857,2869 ---- *************** *** 2916,2925 **** /* * reset current-window */ - # ifdef FEAT_VISUAL VIsual_select = old_VIsual_select; VIsual_active = old_VIsual_active; - # endif curwin = old_curwin; curbuf = old_curbuf; } --- 2912,2919 ---- *** ../vim-7.4.211/src/netbeans.c 2012-06-20 19:56:18.000000000 +0200 --- src/netbeans.c 2014-03-23 13:09:29.163151241 +0100 *************** *** 2232,2242 **** nb_set_curbuf(buf->bufp); - #ifdef FEAT_VISUAL /* Don't want Visual mode now. */ if (VIsual_active) end_visual_mode(); - #endif #ifdef NBDEBUG s = args; #endif --- 2232,2240 ---- *** ../vim-7.4.211/src/normal.c 2014-03-12 17:41:59.128838878 +0100 --- src/normal.c 2014-03-23 15:07:40.435259900 +0100 *************** *** 14,20 **** #include "vim.h" - #ifdef FEAT_VISUAL /* * The Visual area is remembered for reselection. */ --- 14,19 ---- *************** *** 24,30 **** static int VIsual_mode_orig = NUL; /* saved Visual mode */ static int restart_VIsual_select = 0; - #endif #ifdef FEAT_EVAL static void set_vcount_ca __ARGS((cmdarg_T *cap, int *set_prevcount)); --- 23,28 ---- *************** *** 37,43 **** static int find_command __ARGS((int cmdchar)); static void op_colon __ARGS((oparg_T *oap)); static void op_function __ARGS((oparg_T *oap)); ! #if defined(FEAT_MOUSE) && defined(FEAT_VISUAL) static void find_start_of_word __ARGS((pos_T *)); static void find_end_of_word __ARGS((pos_T *)); static int get_mouse_class __ARGS((char_u *p)); --- 35,41 ---- static int find_command __ARGS((int cmdchar)); static void op_colon __ARGS((oparg_T *oap)); static void op_function __ARGS((oparg_T *oap)); ! #if defined(FEAT_MOUSE) static void find_start_of_word __ARGS((pos_T *)); static void find_end_of_word __ARGS((pos_T *)); static int get_mouse_class __ARGS((char_u *p)); *************** *** 48,56 **** static int checkclearopq __ARGS((oparg_T *oap)); static void clearop __ARGS((oparg_T *oap)); static void clearopbeep __ARGS((oparg_T *oap)); - #ifdef FEAT_VISUAL static void unshift_special __ARGS((cmdarg_T *cap)); - #endif #ifdef FEAT_CMDL_INFO static void del_from_showcmd __ARGS((int)); #endif --- 46,52 ---- *************** *** 117,141 **** #ifdef FEAT_VREPLACE static void nv_vreplace __ARGS((cmdarg_T *cap)); #endif - #ifdef FEAT_VISUAL static void v_swap_corners __ARGS((int cmdchar)); - #endif static void nv_replace __ARGS((cmdarg_T *cap)); static void n_swapchar __ARGS((cmdarg_T *cap)); static void nv_cursormark __ARGS((cmdarg_T *cap, int flag, pos_T *pos)); - #ifdef FEAT_VISUAL static void v_visop __ARGS((cmdarg_T *cap)); - #endif static void nv_subst __ARGS((cmdarg_T *cap)); static void nv_abbrev __ARGS((cmdarg_T *cap)); static void nv_optrans __ARGS((cmdarg_T *cap)); static void nv_gomark __ARGS((cmdarg_T *cap)); static void nv_pcmark __ARGS((cmdarg_T *cap)); static void nv_regname __ARGS((cmdarg_T *cap)); - #ifdef FEAT_VISUAL static void nv_visual __ARGS((cmdarg_T *cap)); static void n_start_visual_mode __ARGS((int c)); - #endif static void nv_window __ARGS((cmdarg_T *cap)); static void nv_suspend __ARGS((cmdarg_T *cap)); static void nv_g_cmd __ARGS((cmdarg_T *cap)); --- 113,131 ---- *************** *** 155,165 **** 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)); static void nv_select __ARGS((cmdarg_T *cap)); - #endif static void nv_goto __ARGS((cmdarg_T *cap)); static void nv_normal __ARGS((cmdarg_T *cap)); static void nv_esc __ARGS((cmdarg_T *oap)); --- 145,153 ---- *************** *** 248,271 **** {Ctrl_N, nv_down, NV_STS, FALSE}, {Ctrl_O, nv_ctrlo, 0, 0}, {Ctrl_P, nv_up, NV_STS, FALSE}, - #ifdef FEAT_VISUAL {Ctrl_Q, nv_visual, 0, FALSE}, - #else - {Ctrl_Q, nv_ignore, 0, 0}, - #endif {Ctrl_R, nv_redo, 0, 0}, {Ctrl_S, nv_ignore, 0, 0}, {Ctrl_T, nv_tagpop, NV_NCW, 0}, {Ctrl_U, nv_halfpage, 0, 0}, - #ifdef FEAT_VISUAL {Ctrl_V, nv_visual, 0, FALSE}, {'V', nv_visual, 0, FALSE}, {'v', nv_visual, 0, FALSE}, - #else - {Ctrl_V, nv_error, 0, 0}, - {'V', nv_error, 0, 0}, - {'v', nv_error, 0, 0}, - #endif {Ctrl_W, nv_window, 0, 0}, {Ctrl_X, nv_addsub, 0, 0}, {Ctrl_Y, nv_scroll_line, 0, FALSE}, --- 236,249 ---- *************** *** 427,435 **** {K_HELP, nv_help, NV_NCW, 0}, {K_F1, nv_help, NV_NCW, 0}, {K_XF1, nv_help, NV_NCW, 0}, - #ifdef FEAT_VISUAL {K_SELECT, nv_select, 0, 0}, - #endif #ifdef FEAT_GUI {K_VER_SCROLLBAR, nv_ver_scrollbar, 0, 0}, {K_HOR_SCROLLBAR, nv_hor_scrollbar, 0, 0}, --- 405,411 ---- *************** *** 579,589 **** #ifdef FEAT_CMDL_INFO int need_flushbuf; /* need to call out_flush() */ #endif - #ifdef FEAT_VISUAL pos_T old_pos; /* cursor position before command */ int mapped_len; static int old_mapped_len = 0; - #endif int idx; #ifdef FEAT_EVAL int set_prevcount = FALSE; --- 555,563 ---- *************** *** 643,651 **** } #endif - #ifdef FEAT_VISUAL mapped_len = typebuf_maplen(); - #endif State = NORMAL_BUSY; #ifdef USE_ON_FLY_SCROLL --- 617,623 ---- *************** *** 666,672 **** c = safe_vgetc(); LANGMAP_ADJUST(c, TRUE); - #ifdef FEAT_VISUAL /* * If a mapping was started in Visual or Select mode, remember the length * of the mapping. This is used below to not return to Insert mode for as --- 638,643 ---- *************** *** 677,688 **** else if (old_mapped_len || (VIsual_active && mapped_len == 0 && typebuf_maplen() > 0)) old_mapped_len = typebuf_maplen(); - #endif if (c == NUL) c = K_ZERO; - #ifdef FEAT_VISUAL /* * In Select mode, typed text replaces the selection. */ --- 648,657 ---- *************** *** 703,718 **** msg_nowait = TRUE; /* don't delay going to insert mode */ old_mapped_len = 0; /* do go to Insert mode */ } - #endif #ifdef FEAT_CMDL_INFO need_flushbuf = add_to_showcmd(c); #endif getcount: - #ifdef FEAT_VISUAL if (!(VIsual_active && VIsual_select)) - #endif { /* * Handle a count before a command and compute ca.count0. --- 672,684 ---- *************** *** 856,862 **** goto normal_end; #endif - #ifdef FEAT_VISUAL /* * In Visual/Select mode, a few keys are handled in a special way. */ --- 822,827 ---- *************** *** 892,898 **** } } } - #endif #ifdef FEAT_RIGHTLEFT if (curwin->w_p_rl && KeyTyped && !KeyStuffed --- 857,862 ---- *************** *** 930,940 **** && !Recording && !Exec_reg) || ((ca.cmdchar == 'a' || ca.cmdchar == 'i') ! && (oap->op_type != OP_NOP ! #ifdef FEAT_VISUAL ! || VIsual_active ! #endif ! )))) { int *cp; int repl = FALSE; /* get character for replace mode */ --- 894,900 ---- && !Recording && !Exec_reg) || ((ca.cmdchar == 'a' || ca.cmdchar == 'i') ! && (oap->op_type != OP_NOP || VIsual_active)))) { int *cp; int repl = FALSE; /* get character for replace mode */ *************** *** 1168,1174 **** msg_col = 0; } - #ifdef FEAT_VISUAL old_pos = curwin->w_cursor; /* remember where cursor was */ /* When 'keymodel' contains "startsel" some keys start Select/Visual --- 1128,1133 ---- *************** *** 1188,1194 **** mod_mask &= ~MOD_MASK_SHIFT; } } - #endif /* * Execute the command! --- 1147,1152 ---- *************** *** 1220,1231 **** #endif } - #ifdef FEAT_VISUAL /* Get the length of mapped chars again after typing a count, second * character or "z333<cr>". */ if (old_mapped_len > 0) old_mapped_len = typebuf_maplen(); - #endif /* * If an operation is pending, handle it... --- 1178,1187 ---- *************** *** 1247,1257 **** if ( ((p_smd && msg_silent == 0 && (restart_edit != 0 - #ifdef FEAT_VISUAL || (VIsual_active && old_pos.lnum == curwin->w_cursor.lnum && old_pos.col == curwin->w_cursor.col) - #endif ) && (clear_cmdline || redraw_cmdline) --- 1203,1211 ---- *************** *** 1259,1267 **** && !msg_nowait && KeyTyped) || (restart_edit != 0 - #ifdef FEAT_VISUAL && !VIsual_active - #endif && (msg_scroll || emsg_on_display))) && oap->regname == 0 --- 1213,1219 ---- *************** *** 1368,1403 **** * May switch from Visual to Select mode after CTRL-O command. */ if ( oap->op_type == OP_NOP - #ifdef FEAT_VISUAL && ((restart_edit != 0 && !VIsual_active && old_mapped_len == 0) || restart_VIsual_select == 1) - #else - && restart_edit != 0 - #endif && !(ca.retval & CA_COMMAND_BUSY) && stuff_empty() && oap->regname == 0) { - #ifdef FEAT_VISUAL if (restart_VIsual_select == 1) { VIsual_select = TRUE; showmode(); restart_VIsual_select = 0; } ! #endif ! if (restart_edit != 0 ! #ifdef FEAT_VISUAL ! && !VIsual_active && old_mapped_len == 0 ! #endif ! ) (void)edit(restart_edit, FALSE, 1L); } - #ifdef FEAT_VISUAL if (restart_VIsual_select == 2) restart_VIsual_select = 1; - #endif /* Save count before an operator for next time. */ opcount = ca.opcount; --- 1320,1343 ---- * May switch from Visual to Select mode after CTRL-O command. */ if ( oap->op_type == OP_NOP && ((restart_edit != 0 && !VIsual_active && old_mapped_len == 0) || restart_VIsual_select == 1) && !(ca.retval & CA_COMMAND_BUSY) && stuff_empty() && oap->regname == 0) { if (restart_VIsual_select == 1) { VIsual_select = TRUE; showmode(); restart_VIsual_select = 0; } ! if (restart_edit != 0 && !VIsual_active && old_mapped_len == 0) (void)edit(restart_edit, FALSE, 1L); } if (restart_VIsual_select == 2) restart_VIsual_select = 1; /* Save count before an operator for next time. */ opcount = ca.opcount; *************** *** 1437,1451 **** int empty_region_error; int restart_edit_save; - #ifdef FEAT_VISUAL /* The visual area is remembered for redo */ static int redo_VIsual_mode = NUL; /* 'v', 'V', or Ctrl-V */ static linenr_T redo_VIsual_line_count; /* number of lines */ static colnr_T redo_VIsual_vcol; /* number of cols or end column */ static long redo_VIsual_count; /* count for Visual operator */ ! # ifdef FEAT_VIRTUALEDIT int include_line_break = FALSE; - # endif #endif #if defined(FEAT_CLIPBOARD) --- 1377,1389 ---- int empty_region_error; int restart_edit_save; /* The visual area is remembered for redo */ static int redo_VIsual_mode = NUL; /* 'v', 'V', or Ctrl-V */ static linenr_T redo_VIsual_line_count; /* number of lines */ static colnr_T redo_VIsual_vcol; /* number of cols or end column */ static long redo_VIsual_count; /* count for Visual operator */ ! #ifdef FEAT_VIRTUALEDIT int include_line_break = FALSE; #endif #if defined(FEAT_CLIPBOARD) *************** *** 1459,1468 **** if ((clip_star.available || clip_plus.available) && oap->op_type != OP_NOP && !gui_yank - # ifdef FEAT_VISUAL && VIsual_active && !redo_VIsual_busy - # endif && oap->regname == 0) clip_auto_select(); #endif --- 1397,1404 ---- *************** *** 1471,1483 **** /* * If an operation is pending, handle it... */ ! if ((finish_op ! #ifdef FEAT_VISUAL ! || VIsual_active ! #endif ! ) && oap->op_type != OP_NOP) { - #ifdef FEAT_VISUAL oap->is_VIsual = VIsual_active; if (oap->motion_force == 'V') oap->motion_type = MLINE; --- 1407,1414 ---- /* * If an operation is pending, handle it... */ ! if ((finish_op || VIsual_active) && oap->op_type != OP_NOP) { oap->is_VIsual = VIsual_active; if (oap->motion_force == 'V') oap->motion_type = MLINE; *************** *** 1501,1517 **** VIsual_select = FALSE; VIsual_reselect = FALSE; } - #endif /* Only redo yank when 'y' flag is in 'cpoptions'. */ /* Never redo "zf" (define fold). */ if ((vim_strchr(p_cpo, CPO_YANK) != NULL || oap->op_type != OP_YANK) - #ifdef FEAT_VISUAL && ((!VIsual_active || oap->motion_force) /* Also redo Operator-pending Visual mode mappings */ || (VIsual_active && cap->cmdchar == ':' && oap->op_type != OP_COLON)) - #endif && cap->cmdchar != 'D' #ifdef FEAT_FOLDING && oap->op_type != OP_FOLD --- 1432,1445 ---- *************** *** 1554,1560 **** } } - #ifdef FEAT_VISUAL if (redo_VIsual_busy) { /* Redo of an operation on a Visual area. Use the same size from --- 1482,1487 ---- *************** *** 1639,1645 **** if (VIsual_mode == 'V') oap->start.col = 0; } - #endif /* FEAT_VISUAL */ /* * Set oap->start to the first position of the operated text, oap->end --- 1566,1571 ---- *************** *** 1690,1696 **** virtual_op = virtual_active(); #endif - #ifdef FEAT_VISUAL if (VIsual_active || redo_VIsual_busy) { if (VIsual_mode == Ctrl_V) /* block mode */ --- 1616,1621 ---- *************** *** 1826,1834 **** { oap->motion_type = MCHAR; if (VIsual_mode != Ctrl_V && *ml_get_pos(&(oap->end)) == NUL ! # ifdef FEAT_VIRTUALEDIT && (include_line_break || !virtual_op) ! # endif ) { oap->inclusive = FALSE; --- 1751,1759 ---- { oap->motion_type = MCHAR; if (VIsual_mode != Ctrl_V && *ml_get_pos(&(oap->end)) == NUL ! #ifdef FEAT_VIRTUALEDIT && (include_line_break || !virtual_op) ! #endif ) { oap->inclusive = FALSE; *************** *** 1840,1848 **** { ++oap->end.lnum; oap->end.col = 0; ! # ifdef FEAT_VIRTUALEDIT oap->end.coladd = 0; ! # endif ++oap->line_count; } else --- 1765,1773 ---- { ++oap->end.lnum; oap->end.col = 0; ! #ifdef FEAT_VIRTUALEDIT oap->end.coladd = 0; ! #endif ++oap->line_count; } else *************** *** 1868,1877 **** if (!gui_yank) { VIsual_active = FALSE; ! # ifdef FEAT_MOUSE setmouse(); mouse_dragging = 0; ! # endif if (mode_displayed) clear_cmdline = TRUE; /* unshow visual mode later */ #ifdef FEAT_CMDL_INFO --- 1793,1802 ---- if (!gui_yank) { VIsual_active = FALSE; ! #ifdef FEAT_MOUSE setmouse(); mouse_dragging = 0; ! #endif if (mode_displayed) clear_cmdline = TRUE; /* unshow visual mode later */ #ifdef FEAT_CMDL_INFO *************** *** 1886,1892 **** redraw_curbuf_later(INVERTED); } } - #endif #ifdef FEAT_MBYTE /* Include the trailing byte of a multi-byte char. */ --- 1811,1816 ---- *************** *** 1921,1936 **** empty_region_error = (oap->empty && vim_strchr(p_cpo, CPO_EMPTYREGION) != NULL); - #ifdef FEAT_VISUAL /* Force a redraw when operating on an empty Visual region, when * 'modifiable is off or creating a fold. */ if (oap->is_VIsual && (oap->empty || !curbuf->b_p_ma ! # ifdef FEAT_FOLDING || oap->op_type == OP_FOLD ! # endif )) redraw_curbuf_later(INVERTED); - #endif /* * If the end of an operator is in column one while oap->motion_type --- 1845,1858 ---- empty_region_error = (oap->empty && vim_strchr(p_cpo, CPO_EMPTYREGION) != NULL); /* Force a redraw when operating on an empty Visual region, when * 'modifiable is off or creating a fold. */ if (oap->is_VIsual && (oap->empty || !curbuf->b_p_ma ! #ifdef FEAT_FOLDING || oap->op_type == OP_FOLD ! #endif )) redraw_curbuf_later(INVERTED); /* * If the end of an operator is in column one while oap->motion_type *************** *** 1943,1952 **** && oap->inclusive == FALSE && !(cap->retval & CA_NO_ADJ_OP_END) && oap->end.col == 0 - #ifdef FEAT_VISUAL && (!oap->is_VIsual || *p_sel == 'o') && !oap->block_mode - #endif && oap->line_count > 1) { oap->end_adjusted = TRUE; /* remember that we did this */ --- 1865,1872 ---- *************** *** 1971,1981 **** { case OP_LSHIFT: case OP_RSHIFT: ! op_shift(oap, TRUE, ! #ifdef FEAT_VISUAL ! oap->is_VIsual ? (int)cap->count1 : ! #endif ! 1); auto_format(FALSE, TRUE); break; --- 1891,1897 ---- { case OP_LSHIFT: case OP_RSHIFT: ! op_shift(oap, TRUE, oap->is_VIsual ? (int)cap->count1 : 1); auto_format(FALSE, TRUE); break; *************** *** 1988,2002 **** beep_flush(); else { ! (void)do_join(oap->line_count, oap->op_type == OP_JOIN, TRUE, TRUE); auto_format(FALSE, TRUE); } break; case OP_DELETE: - #ifdef FEAT_VISUAL VIsual_reselect = FALSE; /* don't reselect now */ - #endif if (empty_region_error) { vim_beep(); --- 1904,1917 ---- beep_flush(); else { ! (void)do_join(oap->line_count, oap->op_type == OP_JOIN, ! TRUE, TRUE); auto_format(FALSE, TRUE); } break; case OP_DELETE: VIsual_reselect = FALSE; /* don't reselect now */ if (empty_region_error) { vim_beep(); *************** *** 2026,2034 **** break; case OP_CHANGE: - #ifdef FEAT_VISUAL VIsual_reselect = FALSE; /* don't reselect now */ - #endif if (empty_region_error) { vim_beep(); --- 1941,1947 ---- *************** *** 2126,2134 **** case OP_INSERT: case OP_APPEND: - #ifdef FEAT_VISUAL VIsual_reselect = FALSE; /* don't reselect now */ - #endif #ifdef FEAT_VISUALEXTRA if (empty_region_error) { --- 2039,2045 ---- *************** *** 2158,2166 **** break; case OP_REPLACE: - #ifdef FEAT_VISUAL VIsual_reselect = FALSE; /* don't reselect now */ - #endif #ifdef FEAT_VISUALEXTRA if (empty_region_error) #endif --- 2069,2075 ---- *************** *** 2220,2228 **** { curwin->w_cursor = old_cursor; } - #ifdef FEAT_VISUAL oap->block_mode = FALSE; - #endif clearop(oap); } } --- 2129,2135 ---- *************** *** 2235,2245 **** oparg_T *oap; { stuffcharReadbuff(':'); - #ifdef FEAT_VISUAL if (oap->is_VIsual) stuffReadbuff((char_u *)"'<,'>"); else - #endif { /* * Make the range look nice, so it can be repeated. --- 2142,2150 ---- *************** *** 2404,2417 **** pos_T save_cursor; #endif win_T *old_curwin = curwin; - #ifdef FEAT_VISUAL static pos_T orig_cursor; colnr_T leftcol, rightcol; pos_T end_visual; int diff; int old_active = VIsual_active; int old_mode = VIsual_mode; - #endif int regname; #if defined(FEAT_FOLDING) --- 2309,2320 ---- *************** *** 2432,2446 **** if (!gui.in_use) #endif { - #ifdef FEAT_VISUAL if (VIsual_active) { if (!mouse_has(MOUSE_VISUAL)) return FALSE; } ! else ! #endif ! if (State == NORMAL && !mouse_has(MOUSE_NORMAL)) return FALSE; } --- 2335,2346 ---- if (!gui.in_use) #endif { if (VIsual_active) { if (!mouse_has(MOUSE_VISUAL)) return FALSE; } ! else if (State == NORMAL && !mouse_has(MOUSE_NORMAL)) return FALSE; } *************** *** 2509,2522 **** } } - #ifndef FEAT_VISUAL - /* - * ALT is only used for starting/extending Visual mode. - */ - if ((mod_mask & MOD_MASK_ALT)) - return FALSE; - #endif - /* * CTRL right mouse button does CTRL-T */ --- 2409,2414 ---- *************** *** 2586,2592 **** return FALSE; } - #ifdef FEAT_VISUAL /* * If visual was active, yank the highlighted text and put it * before the mouse pointer position. --- 2478,2483 ---- *************** *** 2607,2613 **** do_always = TRUE; /* ignore 'mouse' setting next time */ return FALSE; } - #endif /* * The rest is below jump_to_mouse() */ --- 2498,2503 ---- *************** *** 2761,2767 **** { /* First set the cursor position before showing the popup * menu. */ - #ifdef FEAT_VISUAL if (VIsual_active) { pos_T m_pos; --- 2651,2656 ---- *************** *** 2800,2815 **** } else jump_flags = MOUSE_MAY_STOP_VIS; - #endif } if (jump_flags) { jump_flags = jump_to_mouse(jump_flags, NULL, which_button); ! update_curbuf( ! #ifdef FEAT_VISUAL ! VIsual_active ? INVERTED : ! #endif ! VALID); setcursor(); out_flush(); /* Update before showing popup menu */ } --- 2689,2699 ---- } else jump_flags = MOUSE_MAY_STOP_VIS; } if (jump_flags) { jump_flags = jump_to_mouse(jump_flags, NULL, which_button); ! update_curbuf(VIsual_active ? INVERTED : VALID); setcursor(); out_flush(); /* Update before showing popup menu */ } *************** *** 2832,2838 **** } } - #ifdef FEAT_VISUAL if ((State & (NORMAL | INSERT)) && !(mod_mask & (MOD_MASK_SHIFT | MOD_MASK_CTRL))) { --- 2716,2721 ---- *************** *** 2872,2878 **** jump_flags |= MOUSE_MAY_VIS; } } - #endif /* * If an operator is pending, ignore all drags and releases until the --- 2755,2760 ---- *************** *** 2941,2947 **** } #endif - #ifdef FEAT_VISUAL /* Set global flag that we are extending the Visual area with mouse * dragging; temporarily minimize 'scrolloff'. */ if (VIsual_active && is_drag && p_so) --- 2823,2828 ---- *************** *** 3040,3046 **** */ else if ((State & INSERT) && VIsual_active) stuffcharReadbuff(Ctrl_O); - #endif /* * Middle mouse click: Put text before cursor. --- 2921,2926 ---- *************** *** 3118,3128 **** */ else if ((mod_mask & MOD_MASK_SHIFT)) { ! if (State & INSERT ! #ifdef FEAT_VISUAL ! || (VIsual_active && VIsual_select) ! #endif ! ) stuffcharReadbuff(Ctrl_O); if (which_button == MOUSE_LEFT) stuffcharReadbuff('*'); --- 2998,3004 ---- */ else if ((mod_mask & MOD_MASK_SHIFT)) { ! if ((State & INSERT) || (VIsual_active && VIsual_select)) stuffcharReadbuff(Ctrl_O); if (which_button == MOUSE_LEFT) stuffcharReadbuff('*'); *************** *** 3153,3159 **** # endif } #endif - #ifdef FEAT_VISUAL else if ((mod_mask & MOD_MASK_MULTI_CLICK) && (State & (NORMAL | INSERT)) && mouse_has(MOUSE_VISUAL)) { --- 3029,3034 ---- *************** *** 3267,3278 **** || (VIsual_active && p_smd && msg_silent == 0 && (!old_active || VIsual_mode != old_mode))) redraw_cmdline = TRUE; - #endif return moved; } - #ifdef FEAT_VISUAL /* * Move "pos" back to the start of the word it's in. */ --- 3142,3151 ---- *************** *** 3372,3381 **** return 1; return c; } - #endif /* FEAT_VISUAL */ #endif /* FEAT_MOUSE */ - #if defined(FEAT_VISUAL) || defined(PROTO) /* * Check if highlighting for visual mode is possible, give a warning message * if not. --- 3245,3252 ---- *************** *** 3468,3474 **** VIsual_reselect = FALSE; } } - #endif /* FEAT_VISUAL */ #if defined(FEAT_BEVAL) static int find_is_eval_item __ARGS((char_u *ptr, int *colp, int *nbp, int dir)); --- 3339,3344 ---- *************** *** 3802,3812 **** checkclearopq(oap) oparg_T *oap; { ! if (oap->op_type == OP_NOP ! #ifdef FEAT_VISUAL ! && !VIsual_active ! #endif ! ) return FALSE; clearopbeep(oap); return TRUE; --- 3672,3678 ---- checkclearopq(oap) oparg_T *oap; { ! if (oap->op_type == OP_NOP && !VIsual_active) return FALSE; clearopbeep(oap); return TRUE; *************** *** 3830,3836 **** beep_flush(); } - #ifdef FEAT_VISUAL /* * Remove the shift modifier from a special key. */ --- 3696,3701 ---- *************** *** 3849,3866 **** } cap->cmdchar = simplify_key(cap->cmdchar, &mod_mask); } - #endif #if defined(FEAT_CMDL_INFO) || defined(PROTO) /* * Routines for displaying a partly typed command */ ! #ifdef FEAT_VISUAL /* need room for size of Visual area */ ! # define SHOWCMD_BUFLEN SHOWCMD_COLS + 1 + 30 ! #else ! # define SHOWCMD_BUFLEN SHOWCMD_COLS + 1 ! #endif static char_u showcmd_buf[SHOWCMD_BUFLEN]; static char_u old_showcmd_buf[SHOWCMD_BUFLEN]; /* For push_showcmd() */ static int showcmd_is_clear = TRUE; --- 3714,3726 ---- } cap->cmdchar = simplify_key(cap->cmdchar, &mod_mask); } #if defined(FEAT_CMDL_INFO) || defined(PROTO) /* * Routines for displaying a partly typed command */ ! #define SHOWCMD_BUFLEN SHOWCMD_COLS + 1 + 30 static char_u showcmd_buf[SHOWCMD_BUFLEN]; static char_u old_showcmd_buf[SHOWCMD_BUFLEN]; /* For push_showcmd() */ static int showcmd_is_clear = TRUE; *************** *** 3874,3880 **** if (!p_sc) return; - #ifdef FEAT_VISUAL if (VIsual_active && !char_avail()) { int cursor_bot = lt(VIsual, curwin->w_cursor); --- 3734,3739 ---- *************** *** 3960,3966 **** showcmd_visual = TRUE; } else - #endif { showcmd_buf[0] = NUL; showcmd_visual = FALSE; --- 3819,3824 ---- *************** *** 4203,4212 **** int want_hor; win_T *old_curwin = curwin; buf_T *old_curbuf = curbuf; - #ifdef FEAT_VISUAL int old_VIsual_select = VIsual_select; int old_VIsual_active = VIsual_active; - #endif colnr_T tgt_leftcol = curwin->w_leftcol; long topline; long y; --- 4061,4068 ---- *************** *** 4223,4231 **** /* * loop through the scrollbound windows and scroll accordingly */ - #ifdef FEAT_VISUAL VIsual_select = VIsual_active = 0; - #endif for (curwin = firstwin; curwin; curwin = curwin->w_next) { curbuf = curwin->w_buffer; --- 4079,4085 ---- *************** *** 4280,4289 **** /* * reset current-window */ - #ifdef FEAT_VISUAL VIsual_select = old_VIsual_select; VIsual_active = old_VIsual_active; - #endif curwin = old_curwin; curbuf = old_curbuf; } --- 4134,4141 ---- *************** *** 5239,5249 **** if (checkclearop(cap->oap)) break; - # ifdef FEAT_VISUAL if (VIsual_active && get_visual_text(cap, &ptr, &len) == FAIL) return; - # endif if (ptr == NULL) { pos_T pos = curwin->w_cursor; --- 5091,5099 ---- *************** *** 5411,5422 **** /* * Ignore 'Q' in Visual mode, just give a beep. */ - #ifdef FEAT_VISUAL if (VIsual_active) vim_beep(); ! else ! #endif ! if (!checkclearop(cap->oap)) do_exmode(FALSE); } --- 5261,5269 ---- /* * Ignore 'Q' in Visual mode, just give a beep. */ if (VIsual_active) vim_beep(); ! else if (!checkclearop(cap->oap)) do_exmode(FALSE); } *************** *** 5430,5440 **** int old_p_im; int cmd_result; - #ifdef FEAT_VISUAL if (VIsual_active) nv_operator(cap); else - #endif { if (cap->oap->op_type != OP_NOP) { --- 5277,5285 ---- *************** *** 5494,5508 **** nv_ctrlg(cap) cmdarg_T *cap; { - #ifdef FEAT_VISUAL if (VIsual_active) /* toggle Selection/Visual mode */ { VIsual_select = !VIsual_select; showmode(); } ! else ! #endif ! if (!checkclearop(cap->oap)) /* print full name if count given or :cd used */ fileinfo((int)cap->count0, FALSE, TRUE); } --- 5339,5350 ---- nv_ctrlg(cap) cmdarg_T *cap; { if (VIsual_active) /* toggle Selection/Visual mode */ { VIsual_select = !VIsual_select; showmode(); } ! else if (!checkclearop(cap->oap)) /* print full name if count given or :cd used */ fileinfo((int)cap->count0, FALSE, TRUE); } *************** *** 5514,5527 **** nv_ctrlh(cap) cmdarg_T *cap; { - #ifdef FEAT_VISUAL if (VIsual_active && VIsual_select) { cap->cmdchar = 'x'; /* BS key behaves like 'x' in Select mode */ v_visop(cap); } else - #endif nv_left(cap); } --- 5356,5367 ---- *************** *** 5558,5564 **** nv_ctrlo(cap) cmdarg_T *cap; { - #ifdef FEAT_VISUAL if (VIsual_active && VIsual_select) { VIsual_select = FALSE; --- 5398,5403 ---- *************** *** 5566,5572 **** restart_VIsual_select = 2; /* restart Select mode later */ } else - #endif { cap->count1 = -cap->count1; nv_pcmark(cap); --- 5405,5410 ---- *************** *** 5675,5684 **** */ if (cmdchar == ']' || cmdchar == Ctrl_RSB || cmdchar == 'K') { - #ifdef FEAT_VISUAL if (VIsual_active && get_visual_text(cap, &ptr, &n) == FAIL) return; - #endif if (checkclearopq(cap->oap)) return; } --- 5513,5520 ---- *************** *** 5872,5878 **** vim_free(buf); } - #if defined(FEAT_VISUAL) || defined(PROTO) /* * Get visually selected text, within one line only. * Returns FAIL if more than one line selected. --- 5708,5713 ---- *************** *** 5917,5923 **** reset_VIsual_and_resel(); return OK; } - #endif /* * CTRL-T: backwards in tag stack --- 5752,5757 ---- *************** *** 6040,6050 **** cmdarg_T *cap; { long n; ! #ifdef FEAT_VISUAL ! int PAST_LINE; ! #else ! # define PAST_LINE 0 ! #endif if (mod_mask & (MOD_MASK_SHIFT | MOD_MASK_CTRL)) { --- 5874,5880 ---- cmdarg_T *cap; { long n; ! int past_line; if (mod_mask & (MOD_MASK_SHIFT | MOD_MASK_CTRL)) { *************** *** 6057,6081 **** cap->oap->motion_type = MCHAR; cap->oap->inclusive = FALSE; ! #ifdef FEAT_VISUAL ! PAST_LINE = (VIsual_active && *p_sel != 'o'); ! # ifdef FEAT_VIRTUALEDIT /* ! * In virtual mode, there's no such thing as "PAST_LINE", as lines are ! * (theoretically) infinitely long. */ if (virtual_active()) ! PAST_LINE = 0; ! # endif #endif for (n = cap->count1; n > 0; --n) { ! if ((!PAST_LINE && oneright() == FAIL) ! #ifdef FEAT_VISUAL ! || (PAST_LINE && *ml_get_cursor() == NUL) ! #endif ) { /* --- 5887,5907 ---- cap->oap->motion_type = MCHAR; cap->oap->inclusive = FALSE; ! past_line = (VIsual_active && *p_sel != 'o'); ! #ifdef FEAT_VIRTUALEDIT /* ! * In virtual edit mode, there's no such thing as "past_line", as lines ! * are (theoretically) infinitely long. */ if (virtual_active()) ! past_line = 0; #endif for (n = cap->count1; n > 0; --n) { ! if ((!past_line && oneright() == FAIL) ! || (past_line && *ml_get_cursor() == NUL) ) { /* *************** *** 6123,6148 **** } break; } ! #ifdef FEAT_VISUAL ! else if (PAST_LINE) { curwin->w_set_curswant = TRUE; ! # ifdef FEAT_VIRTUALEDIT if (virtual_active()) oneright(); else ! # endif { ! # ifdef FEAT_MBYTE if (has_mbyte) curwin->w_cursor.col += (*mb_ptr2len)(ml_get_cursor()); else ! # endif ++curwin->w_cursor.col; } } - #endif } #ifdef FEAT_FOLDING if (n != cap->count1 && (fdo_flags & FDO_HOR) && KeyTyped --- 5949,5972 ---- } break; } ! else if (past_line) { curwin->w_set_curswant = TRUE; ! #ifdef FEAT_VIRTUALEDIT if (virtual_active()) oneright(); else ! #endif { ! #ifdef FEAT_MBYTE if (has_mbyte) curwin->w_cursor.col += (*mb_ptr2len)(ml_get_cursor()); else ! #endif ++curwin->w_cursor.col; } } } #ifdef FEAT_FOLDING if (n != cap->count1 && (fdo_flags & FDO_HOR) && KeyTyped *************** *** 6503,6511 **** else curwin->w_cursor.coladd = 0; #endif - #ifdef FEAT_VISUAL adjust_for_sel(cap); - #endif #ifdef FEAT_FOLDING if ((fdo_flags & FDO_HOR) && KeyTyped && cap->oap->op_type == OP_NOP) foldOpenCursor(); --- 6327,6333 ---- *************** *** 6754,6760 **** int dir = (cap->cmdchar == ']' && cap->nchar == 'p') ? FORWARD : BACKWARD; int regname = cap->oap->regname; - #ifdef FEAT_VISUAL int was_visual = VIsual_active; int line_count = curbuf->b_ml.ml_line_count; pos_T start, end; --- 6576,6581 ---- *************** *** 6766,6779 **** end = equalpos(start,VIsual) ? curwin->w_cursor : VIsual; curwin->w_cursor = (dir == BACKWARD ? start : end); } - #endif # ifdef FEAT_CLIPBOARD adjust_clip_reg(®name); # endif prep_redo_cmd(cap); do_put(regname, dir, cap->count1, PUT_FIXINDENT); - #ifdef FEAT_VISUAL if (was_visual) { VIsual = start; --- 6587,6598 ---- *************** *** 6802,6808 **** redraw_later(SOME_VALID); } } - #endif } } --- 6621,6626 ---- *************** *** 6936,6944 **** #ifdef FEAT_VIRTUALEDIT curwin->w_cursor.coladd = 0; #endif - #ifdef FEAT_VISUAL adjust_for_sel(cap); - #endif } } #ifdef FEAT_FOLDING --- 6754,6760 ---- *************** *** 7027,7037 **** nv_undo(cap) cmdarg_T *cap; { ! if (cap->oap->op_type == OP_LOWER ! #ifdef FEAT_VISUAL ! || VIsual_active ! #endif ! ) { /* translate "<Visual>u" to "<Visual>gu" and "guu" to "gugu" */ cap->cmdchar = 'g'; --- 6843,6849 ---- nv_undo(cap) cmdarg_T *cap; { ! if (cap->oap->op_type == OP_LOWER || VIsual_active) { /* translate "<Visual>u" to "<Visual>gu" and "guu" to "gugu" */ cap->cmdchar = 'g'; *************** *** 7089,7095 **** return; } - #ifdef FEAT_VISUAL /* Visual mode "r" */ if (VIsual_active) { --- 6901,6906 ---- *************** *** 7105,7111 **** nv_operator(cap); return; } - #endif #ifdef FEAT_VIRTUALEDIT /* Break tabs, etc. */ --- 6916,6921 ---- *************** *** 7273,7279 **** } } - #ifdef FEAT_VISUAL /* * 'o': Exchange start and end of Visual area. * 'O': same, but in block mode exchange left and right corners. --- 7083,7088 ---- *************** *** 7326,7332 **** curwin->w_set_curswant = TRUE; } } - #endif /* FEAT_VISUAL */ /* * "R" (cap->arg is FALSE) and "gR" (cap->arg is TRUE). --- 7135,7140 ---- *************** *** 7335,7341 **** nv_Replace(cap) cmdarg_T *cap; { - #ifdef FEAT_VISUAL if (VIsual_active) /* "R" is replace lines */ { cap->cmdchar = 'c'; --- 7143,7148 ---- *************** *** 7344,7352 **** VIsual_mode = 'V'; nv_operator(cap); } ! else ! #endif ! if (!checkclearopq(cap->oap)) { if (!curbuf->b_p_ma) EMSG(_(e_modifiable)); --- 7151,7157 ---- VIsual_mode = 'V'; nv_operator(cap); } ! else if (!checkclearopq(cap->oap)) { if (!curbuf->b_p_ma) EMSG(_(e_modifiable)); *************** *** 7369,7384 **** nv_vreplace(cap) cmdarg_T *cap; { - # ifdef FEAT_VISUAL if (VIsual_active) { cap->cmdchar = 'r'; cap->nchar = cap->extra_char; nv_replace(cap); /* Do same as "r" in Visual mode for now */ } ! else ! # endif ! if (!checkclearopq(cap->oap)) { if (!curbuf->b_p_ma) EMSG(_(e_modifiable)); --- 7174,7186 ---- nv_vreplace(cap) cmdarg_T *cap; { if (VIsual_active) { cap->cmdchar = 'r'; cap->nchar = cap->extra_char; nv_replace(cap); /* Do same as "r" in Visual mode for now */ } ! else if (!checkclearopq(cap->oap)) { if (!curbuf->b_p_ma) EMSG(_(e_modifiable)); *************** *** 7525,7531 **** curwin->w_set_curswant = TRUE; } - #ifdef FEAT_VISUAL /* * Handle commands that are operators in Visual mode. */ --- 7327,7332 ---- *************** *** 7550,7556 **** cap->cmdchar = *(vim_strchr(trans, cap->cmdchar) + 1); nv_operator(cap); } - #endif /* * "s" and "S" commands. --- 7351,7356 ---- *************** *** 7559,7565 **** nv_subst(cap) cmdarg_T *cap; { - #ifdef FEAT_VISUAL if (VIsual_active) /* "vs" and "vS" are the same as "vc" */ { if (cap->cmdchar == 'S') --- 7359,7364 ---- *************** *** 7571,7577 **** nv_operator(cap); } else - #endif nv_optrans(cap); } --- 7370,7375 ---- *************** *** 7585,7596 **** if (cap->cmdchar == K_DEL || cap->cmdchar == K_KDEL) cap->cmdchar = 'x'; /* DEL key behaves like 'x' */ - #ifdef FEAT_VISUAL /* in Visual mode these commands are operators */ if (VIsual_active) v_visop(cap); else - #endif nv_optrans(cap); } --- 7383,7392 ---- *************** *** 7758,7764 **** clearopbeep(cap->oap); } - #ifdef FEAT_VISUAL /* * Handle "v", "V" and "CTRL-V" commands. * Also for "gh", "gH" and "g^H" commands: Always start Select mode, cap->arg --- 7554,7559 ---- *************** *** 7950,7956 **** } } - #endif /* FEAT_VISUAL */ /* * CTRL-W: Window commands --- 7745,7750 ---- *************** *** 7975,7984 **** cmdarg_T *cap; { clearop(cap->oap); - #ifdef FEAT_VISUAL if (VIsual_active) end_visual_mode(); /* stop Visual mode */ - #endif do_cmdline_cmd((char_u *)"st"); } --- 7769,7776 ---- *************** *** 7990,7998 **** cmdarg_T *cap; { oparg_T *oap = cap->oap; - #ifdef FEAT_VISUAL pos_T tpos; - #endif int i; int flag = FALSE; --- 7782,7788 ---- *************** *** 8025,8031 **** do_cmdline_cmd((char_u *)"%s//~/&"); break; - #ifdef FEAT_VISUAL /* * "gv": Reselect the previous Visual area. If Visual already active, * exchange previous and current Visual area. --- 7815,7820 ---- *************** *** 8126,8132 **** cap->arg = TRUE; nv_visual(cap); break; - #endif /* FEAT_VISUAL */ /* "gn", "gN" visually select next/previous search match * "gn" selects next match --- 7915,7920 ---- *************** *** 8134,8142 **** */ case 'N': case 'n': - #ifdef FEAT_VISUAL if (!current_search(cap->count1, cap->nchar == 'n')) - #endif clearopbeep(oap); break; --- 7922,7928 ---- *************** *** 8258,8266 **** && vim_iswhite(ptr[curwin->w_cursor.col])) --curwin->w_cursor.col; curwin->w_set_curswant = TRUE; - #ifdef FEAT_VISUAL adjust_for_sel(cap); - #endif } break; --- 8044,8050 ---- *************** *** 8657,8667 **** cmdarg_T *cap; { /* In Visual mode and typing "gUU" triggers an operator */ ! if (cap->oap->op_type == OP_UPPER ! #ifdef FEAT_VISUAL ! || VIsual_active ! #endif ! ) { /* translate "gUU" to "gUgU" */ cap->cmdchar = 'g'; --- 8441,8447 ---- cmdarg_T *cap; { /* In Visual mode and typing "gUU" triggers an operator */ ! if (cap->oap->op_type == OP_UPPER || VIsual_active) { /* translate "gUU" to "gUgU" */ cap->cmdchar = 'g'; *************** *** 8683,8693 **** nv_tilde(cap) cmdarg_T *cap; { ! if (!p_to ! #ifdef FEAT_VISUAL ! && !VIsual_active ! #endif ! && cap->oap->op_type != OP_TILDE) n_swapchar(cap); else nv_operator(cap); --- 8463,8469 ---- nv_tilde(cap) cmdarg_T *cap; { ! if (!p_to && !VIsual_active && cap->oap->op_type != OP_TILDE) n_swapchar(cap); else nv_operator(cap); *************** *** 8906,8914 **** clearopbeep(cap->oap); else { - #ifdef FEAT_VISUAL adjust_for_sel(cap); - #endif #ifdef FEAT_FOLDING if ((fdo_flags & FDO_HOR) && KeyTyped && cap->oap->op_type == OP_NOP) foldOpenCursor(); --- 8682,8688 ---- *************** *** 8931,8939 **** * - '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 --- 8705,8711 ---- *************** *** 8968,8974 **** one-character line). */ } - #ifdef FEAT_VISUAL /* * In exclusive Visual mode, may include the last character. */ --- 8740,8745 ---- *************** *** 8979,8989 **** if (VIsual_active && cap->oap->inclusive && *p_sel == 'e' && gchar_cursor() != NUL && lt(VIsual, curwin->w_cursor)) { ! # ifdef FEAT_MBYTE if (has_mbyte) inc_cursor(); else ! # endif ++curwin->w_cursor.col; cap->oap->inclusive = FALSE; } --- 8750,8760 ---- if (VIsual_active && cap->oap->inclusive && *p_sel == 'e' && gchar_cursor() != NUL && lt(VIsual, curwin->w_cursor)) { ! #ifdef FEAT_MBYTE if (has_mbyte) inc_cursor(); else ! #endif ++curwin->w_cursor.col; cap->oap->inclusive = FALSE; } *************** *** 9044,9050 **** } } - #endif /* * "G", "gg", CTRL-END, CTRL-HOME. --- 8815,8820 ---- *************** *** 9095,9107 **** if (cmdwin_type != 0) cmdwin_result = Ctrl_C; #endif - #ifdef FEAT_VISUAL if (VIsual_active) { end_visual_mode(); /* stop Visual */ redraw_curbuf_later(INVERTED); } - #endif /* CTRL-\ CTRL-G restarts Insert mode when 'insertmode' is set. */ if (cap->nchar == Ctrl_G && p_im) restart_edit = 'a'; --- 8865,8875 ---- *************** *** 9132,9140 **** #ifdef FEAT_CMDWIN && cmdwin_type == 0 #endif - #ifdef FEAT_VISUAL && !VIsual_active - #endif && no_reason) MSG(_("Type :quit<Enter> to exit Vim")); --- 8900,8906 ---- *************** *** 9152,9158 **** #endif } - #ifdef FEAT_VISUAL if (VIsual_active) { end_visual_mode(); /* stop Visual */ --- 8918,8923 ---- *************** *** 9160,9169 **** curwin->w_set_curswant = TRUE; redraw_curbuf_later(INVERTED); } ! else ! #endif ! if (no_reason) ! vim_beep(); clearop(cap->oap); /* A CTRL-C is often used at the start of a menu. When 'insertmode' is --- 8925,8932 ---- curwin->w_set_curswant = TRUE; redraw_curbuf_later(INVERTED); } ! else if (no_reason) ! vim_beep(); clearop(cap->oap); /* A CTRL-C is often used at the start of a menu. When 'insertmode' is *************** *** 9187,9206 **** if (cap->cmdchar == K_INS || cap->cmdchar == K_KINS) cap->cmdchar = 'i'; - #ifdef FEAT_VISUAL /* in Visual mode "A" and "I" are an operator */ if (VIsual_active && (cap->cmdchar == 'A' || cap->cmdchar == 'I')) v_visop(cap); /* in Visual mode and after an operator "a" and "i" are for text objects */ ! else ! #endif ! if ((cap->cmdchar == 'a' || cap->cmdchar == 'i') ! && (cap->oap->op_type != OP_NOP ! #ifdef FEAT_VISUAL ! || VIsual_active ! #endif ! )) { #ifdef FEAT_TEXTOBJ nv_object(cap); --- 8950,8962 ---- if (cap->cmdchar == K_INS || cap->cmdchar == K_KINS) cap->cmdchar = 'i'; /* in Visual mode "A" and "I" are an operator */ if (VIsual_active && (cap->cmdchar == 'A' || cap->cmdchar == 'I')) v_visop(cap); /* in Visual mode and after an operator "a" and "i" are for text objects */ ! else if ((cap->cmdchar == 'a' || cap->cmdchar == 'i') ! && (cap->oap->op_type != OP_NOP || VIsual_active)) { #ifdef FEAT_TEXTOBJ nv_object(cap); *************** *** 9467,9478 **** nv_join(cap) cmdarg_T *cap; { - #ifdef FEAT_VISUAL if (VIsual_active) /* join the visual lines */ nv_operator(cap); ! else ! #endif ! if (!checkclearop(cap->oap)) { if (cap->count0 <= 1) cap->count0 = 2; /* default for join is two lines! */ --- 9223,9231 ---- nv_join(cap) cmdarg_T *cap; { if (VIsual_active) /* join the visual lines */ nv_operator(cap); ! else if (!checkclearop(cap->oap)) { if (cap->count0 <= 1) cap->count0 = 2; /* default for join is two lines! */ *************** *** 9495,9506 **** nv_put(cap) cmdarg_T *cap; { - #ifdef FEAT_VISUAL int regname = 0; void *reg1 = NULL, *reg2 = NULL; int empty = FALSE; int was_visual = FALSE; - #endif int dir; int flags = 0; --- 9248,9257 ---- *************** *** 9526,9532 **** if (cap->cmdchar == 'g') flags |= PUT_CURSEND; - #ifdef FEAT_VISUAL if (VIsual_active) { /* Putting in Visual mode: The put text replaces the selected --- 9277,9282 ---- *************** *** 9536,9549 **** */ was_visual = TRUE; regname = cap->oap->regname; ! # ifdef FEAT_CLIPBOARD adjust_clip_reg(®name); ! # endif if (regname == 0 || regname == '"' || VIM_ISDIGIT(regname) || regname == '-' ! # ifdef FEAT_CLIPBOARD || (clip_unnamed && (regname == '*' || regname == '+')) ! # endif ) { --- 9286,9299 ---- */ was_visual = TRUE; regname = cap->oap->regname; ! #ifdef FEAT_CLIPBOARD adjust_clip_reg(®name); ! #endif if (regname == 0 || regname == '"' || VIM_ISDIGIT(regname) || regname == '-' ! #ifdef FEAT_CLIPBOARD || (clip_unnamed && (regname == '*' || regname == '+')) ! #endif ) { *************** *** 9591,9600 **** /* May have been reset in do_put(). */ VIsual_active = TRUE; } - #endif do_put(cap->oap->regname, dir, cap->count1, flags); - #ifdef FEAT_VISUAL /* If a register was saved, put it back now. */ if (reg2 != NULL) put_register(regname, reg2); --- 9341,9348 ---- *************** *** 9621,9627 **** coladvance((colnr_T)MAXCOL); } } - #endif auto_format(FALSE, TRUE); } } --- 9369,9374 ---- *************** *** 9642,9652 **** } else #endif - #ifdef FEAT_VISUAL if (VIsual_active) /* switch start and end of visual */ v_swap_corners(cap->cmdchar); else - #endif n_opencmd(cap); } --- 9389,9397 ---- *** ../vim-7.4.211/src/ops.c 2014-03-19 18:57:27.730175565 +0100 --- src/ops.c 2014-03-23 15:08:16.095260447 +0100 *************** *** 57,65 **** char_u **y_array; /* pointer to array of line pointers */ linenr_T y_size; /* number of lines in y_array */ char_u y_type; /* MLINE, MCHAR or MBLOCK */ - #ifdef FEAT_VISUAL colnr_T y_width; /* only set if y_type == MBLOCK */ - #endif } y_regs[NUM_REGISTERS]; static struct yankreg *y_current; /* ptr to current yankreg */ --- 57,63 ---- *************** *** 107,123 **** static int yank_copy_line __ARGS((struct block_def *bd, long y_idx)); #ifdef FEAT_CLIPBOARD static void copy_yank_reg __ARGS((struct yankreg *reg)); - # if defined(FEAT_VISUAL) || defined(FEAT_EVAL) static void may_set_selection __ARGS((void)); - # endif #endif static void dis_msg __ARGS((char_u *p, int skip_esc)); #if defined(FEAT_COMMENTS) || defined(PROTO) static char_u *skip_comment __ARGS((char_u *line, int process, int include_space, int *is_comment)); #endif - #ifdef FEAT_VISUAL static void block_prep __ARGS((oparg_T *oap, struct block_def *, linenr_T, int)); - #endif #if defined(FEAT_CLIPBOARD) || defined(FEAT_EVAL) static void str_to_reg __ARGS((struct yankreg *y_ptr, int type, char_u *str, long len, long blocklen)); #endif --- 105,117 ---- *************** *** 187,193 **** return i; } - #if defined(FEAT_VISUAL) || defined(PROTO) /* * Return TRUE if operator "op" always works on whole lines. */ --- 181,186 ---- *************** *** 197,203 **** { return opchars[op][2]; } - #endif /* * Get first operator command character. --- 190,195 ---- *************** *** 232,249 **** long i; int first_char; char_u *s; - #ifdef FEAT_VISUAL int block_col = 0; - #endif if (u_save((linenr_T)(oap->start.lnum - 1), (linenr_T)(oap->end.lnum + 1)) == FAIL) return; - #ifdef FEAT_VISUAL if (oap->block_mode) block_col = curwin->w_cursor.col; - #endif for (i = oap->line_count; --i >= 0; ) { --- 224,237 ---- *************** *** 272,286 **** foldOpenCursor(); #endif - #ifdef FEAT_VISUAL if (oap->block_mode) { curwin->w_cursor.lnum = oap->start.lnum; curwin->w_cursor.col = block_col; } ! else ! #endif ! if (curs_top) /* put cursor on first line, for ">>" */ { curwin->w_cursor.lnum = oap->start.lnum; beginline(BL_SOL | BL_FIX); /* shift_line() may have set cursor.col */ --- 260,271 ---- foldOpenCursor(); #endif if (oap->block_mode) { curwin->w_cursor.lnum = oap->start.lnum; curwin->w_cursor.col = block_col; } ! else if (curs_top) /* put cursor on first line, for ">>" */ { curwin->w_cursor.lnum = oap->start.lnum; beginline(BL_SOL | BL_FIX); /* shift_line() may have set cursor.col */ *************** *** 733,746 **** * there is no change still need to remove the Visual highlighting. */ if (last_changed != 0) changed_lines(first_changed, 0, - #ifdef FEAT_VISUAL oap->is_VIsual ? start_lnum + oap->line_count : - #endif last_changed + 1, 0L); - #ifdef FEAT_VISUAL else if (oap->is_VIsual) redraw_curbuf_later(INVERTED); - #endif if (oap->line_count > p_report) { --- 718,727 ---- *************** *** 948,954 **** } #endif - #if defined(FEAT_VISUAL) || defined(PROTO) /* * Obtain the contents of a "normal" register. The register is made empty. * The returned pointer has allocated memory, use put_register() later. --- 929,934 ---- *************** *** 1016,1025 **** *y_current = *(struct yankreg *)reg; vim_free(reg); ! # ifdef FEAT_CLIPBOARD /* Send text written to clipboard register to the clipboard. */ may_set_selection(); ! # endif } void --- 996,1005 ---- *y_current = *(struct yankreg *)reg; vim_free(reg); ! #ifdef FEAT_CLIPBOARD /* Send text written to clipboard register to the clipboard. */ may_set_selection(); ! #endif } void *************** *** 1034,1040 **** vim_free(reg); *y_current = tmp; } - #endif #if defined(FEAT_MOUSE) || defined(PROTO) /* --- 1014,1019 ---- *************** *** 1634,1643 **** int n; linenr_T lnum; char_u *ptr; - #ifdef FEAT_VISUAL char_u *newp, *oldp; struct block_def bd; - #endif linenr_T old_lcount = curbuf->b_ml.ml_line_count; int did_yank = FALSE; int orig_regname = oap->regname; --- 1613,1620 ---- *************** *** 1670,1679 **** * delete linewise. Don't do this for the change command or Visual mode. */ if ( oap->motion_type == MCHAR - #ifdef FEAT_VISUAL && !oap->is_VIsual && !oap->block_mode - #endif && oap->line_count > 1 && oap->motion_force == NUL && oap->op_type == OP_DELETE) --- 1647,1654 ---- *************** *** 1787,1793 **** } } - #ifdef FEAT_VISUAL /* * block mode delete */ --- 1762,1767 ---- *************** *** 1838,1846 **** oap->end.lnum + 1, 0L); oap->line_count = 0; /* no lines deleted */ } ! else ! #endif ! if (oap->motion_type == MLINE) { if (oap->op_type == OP_CHANGE) { --- 1812,1818 ---- oap->end.lnum + 1, 0L); oap->line_count = 0; /* no lines deleted */ } ! else if (oap->motion_type == MLINE) { if (oap->op_type == OP_CHANGE) { *************** *** 1924,1936 **** return FAIL; /* if 'cpoptions' contains '$', display '$' at end of change */ ! if ( vim_strchr(p_cpo, CPO_DOLLAR) != NULL && oap->op_type == OP_CHANGE && oap->end.lnum == curwin->w_cursor.lnum ! #ifdef FEAT_VISUAL ! && !oap->is_VIsual ! #endif ! ) display_dollar(oap->end.col - !oap->inclusive); n = oap->end.col - oap->start.col + 1 - !oap->inclusive; --- 1896,1905 ---- return FAIL; /* if 'cpoptions' contains '$', display '$' at end of change */ ! if ( vim_strchr(p_cpo, CPO_DOLLAR) != NULL && oap->op_type == OP_CHANGE && oap->end.lnum == curwin->w_cursor.lnum ! && !oap->is_VIsual) display_dollar(oap->end.col - !oap->inclusive); n = oap->end.col - oap->start.col + 1 - !oap->inclusive; *************** *** 1967,1977 **** } else { ! (void)del_bytes((long)n, !virtual_op, oap->op_type == OP_DELETE ! #ifdef FEAT_VISUAL ! && !oap->is_VIsual ! #endif ! ); } } else /* delete characters between lines */ --- 1936,1943 ---- } else { ! (void)del_bytes((long)n, !virtual_op, ! oap->op_type == OP_DELETE && !oap->is_VIsual); } } else /* delete characters between lines */ *************** *** 2008,2018 **** { /* delete from start of line until op_end */ curwin->w_cursor.col = 0; ! (void)del_bytes((long)n, !virtual_op, oap->op_type == OP_DELETE ! #ifdef FEAT_VISUAL ! && !oap->is_VIsual ! #endif ! ); curwin->w_cursor = curpos; /* restore curwin->w_cursor */ } if (curwin->w_cursor.lnum < curbuf->b_ml.ml_line_count) --- 1974,1981 ---- { /* delete from start of line until op_end */ curwin->w_cursor.col = 0; ! (void)del_bytes((long)n, !virtual_op, ! oap->op_type == OP_DELETE && !oap->is_VIsual); curwin->w_cursor = curpos; /* restore curwin->w_cursor */ } if (curwin->w_cursor.lnum < curbuf->b_ml.ml_line_count) *************** *** 2025,2038 **** #ifdef FEAT_VIRTUALEDIT setmarks: #endif - #ifdef FEAT_VISUAL if (oap->block_mode) { curbuf->b_op_end.lnum = oap->end.lnum; curbuf->b_op_end.col = oap->start.col; } else - #endif curbuf->b_op_end = oap->start; curbuf->b_op_start = oap->start; --- 1988,1999 ---- *************** *** 2318,2326 **** oparg_T *oap; { pos_T pos; - #ifdef FEAT_VISUAL struct block_def bd; - #endif int did_change = FALSE; if (u_save((linenr_T)(oap->start.lnum - 1), --- 2279,2285 ---- *************** *** 2328,2334 **** return; pos = oap->start; - #ifdef FEAT_VISUAL if (oap->block_mode) /* Visual block mode */ { for (; pos.lnum <= oap->end.lnum; ++pos.lnum) --- 2287,2292 ---- *************** *** 2340,2346 **** one_change = swapchars(oap->op_type, &pos, bd.textlen); did_change |= one_change; ! # ifdef FEAT_NETBEANS_INTG if (netbeans_active() && one_change) { char_u *ptr = ml_get_buf(curbuf, pos.lnum, FALSE); --- 2298,2304 ---- one_change = swapchars(oap->op_type, &pos, bd.textlen); did_change |= one_change; ! #ifdef FEAT_NETBEANS_INTG if (netbeans_active() && one_change) { char_u *ptr = ml_get_buf(curbuf, pos.lnum, FALSE); *************** *** 2350,2362 **** netbeans_inserted(curbuf, pos.lnum, bd.textcol, &ptr[bd.textcol], bd.textlen); } ! # endif } if (did_change) changed_lines(oap->start.lnum, 0, oap->end.lnum + 1, 0L); } else /* not block mode */ - #endif { if (oap->motion_type == MLINE) { --- 2308,2319 ---- netbeans_inserted(curbuf, pos.lnum, bd.textcol, &ptr[bd.textcol], bd.textlen); } ! #endif } if (did_change) changed_lines(oap->start.lnum, 0, oap->end.lnum + 1, 0L); } else /* not block mode */ { if (oap->motion_type == MLINE) { *************** *** 2412,2422 **** } } - #ifdef FEAT_VISUAL if (!did_change && oap->is_VIsual) /* No change: need to remove the Visual selection */ redraw_curbuf_later(INVERTED); - #endif /* * Set '[ and '] marks. --- 2369,2377 ---- *************** *** 3018,3027 **** if ( oap->motion_type == MCHAR && oap->start.col == 0 && !oap->inclusive - #ifdef FEAT_VISUAL && (!oap->is_VIsual || *p_sel == 'o') && !oap->block_mode - #endif && oap->end.col == 0 && yanklines > 1) { --- 2973,2980 ---- *************** *** 3032,3040 **** y_current->y_size = yanklines; y_current->y_type = yanktype; /* set the yank register type */ - #ifdef FEAT_VISUAL y_current->y_width = 0; - #endif y_current->y_array = (char_u **)lalloc_clear((long_u)(sizeof(char_u *) * yanklines), TRUE); --- 2985,2991 ---- *************** *** 3047,3053 **** y_idx = 0; lnum = oap->start.lnum; - #ifdef FEAT_VISUAL if (oap->block_mode) { /* Visual block mode */ --- 2998,3003 ---- *************** *** 3057,3075 **** if (curwin->w_curswant == MAXCOL && y_current->y_width > 0) y_current->y_width--; } - #endif for ( ; lnum <= yankendlnum; lnum++, y_idx++) { switch (y_current->y_type) { - #ifdef FEAT_VISUAL case MBLOCK: block_prep(oap, &bd, lnum, FALSE); if (yank_copy_line(&bd, y_idx) == FAIL) goto fail; break; - #endif case MLINE: if ((y_current->y_array[y_idx] = --- 3007,3022 ---- *************** *** 3206,3214 **** if (mess) /* Display message about yank? */ { if (yanktype == MCHAR - #ifdef FEAT_VISUAL && !oap->block_mode - #endif && yanklines == 1) yanklines = 0; /* Some versions of Vi use ">=" here, some don't... */ --- 3153,3159 ---- *************** *** 3218,3234 **** update_topline_redraw(); if (yanklines == 1) { - #ifdef FEAT_VISUAL if (oap->block_mode) MSG(_("block of 1 line yanked")); else - #endif MSG(_("1 line yanked")); } - #ifdef FEAT_VISUAL else if (oap->block_mode) smsg((char_u *)_("block of %ld lines yanked"), yanklines); - #endif else smsg((char_u *)_("%ld lines yanked"), yanklines); } --- 3163,3175 ---- *************** *** 3239,3249 **** */ curbuf->b_op_start = oap->start; curbuf->b_op_end = oap->end; ! if (yanktype == MLINE ! #ifdef FEAT_VISUAL ! && !oap->block_mode ! #endif ! ) { curbuf->b_op_start.col = 0; curbuf->b_op_end.col = MAXCOL; --- 3180,3186 ---- */ curbuf->b_op_start = oap->start; curbuf->b_op_end = oap->end; ! if (yanktype == MLINE && !oap->block_mode) { curbuf->b_op_start.col = 0; curbuf->b_op_end.col = MAXCOL; *************** *** 3380,3386 **** long i; /* index in y_array[] */ int y_type; long y_size; - #ifdef FEAT_VISUAL int oldlen; long y_width = 0; colnr_T vcol; --- 3317,3322 ---- *************** *** 3388,3394 **** int incr = 0; long j; struct block_def bd; - #endif char_u **y_array = NULL; long nr_lines = 0; pos_T new_cursor; --- 3324,3329 ---- *************** *** 3497,3510 **** get_yank_register(regname, FALSE); y_type = y_current->y_type; - #ifdef FEAT_VISUAL y_width = y_current->y_width; - #endif y_size = y_current->y_size; y_array = y_current->y_array; } - #ifdef FEAT_VISUAL if (y_type == MLINE) { if (flags & PUT_LINE_SPLIT) --- 3432,3442 ---- *************** *** 3535,3541 **** curbuf->b_op_start = curwin->w_cursor; /* default for '[ mark */ curbuf->b_op_end = curwin->w_cursor; /* default for '] mark */ } - #endif if (flags & PUT_LINE) /* :put command or "p" in Visual line mode. */ y_type = MLINE; --- 3467,3472 ---- *************** *** 3547,3553 **** goto end; } - #ifdef FEAT_VISUAL if (y_type == MBLOCK) { lnum = curwin->w_cursor.lnum + y_size + 1; --- 3478,3483 ---- *************** *** 3556,3564 **** if (u_save(curwin->w_cursor.lnum - 1, lnum) == FAIL) goto end; } ! else ! #endif ! if (y_type == MLINE) { lnum = curwin->w_cursor.lnum; #ifdef FEAT_FOLDING --- 3486,3492 ---- if (u_save(curwin->w_cursor.lnum - 1, lnum) == FAIL) goto end; } ! else if (y_type == MLINE) { lnum = curwin->w_cursor.lnum; #ifdef FEAT_FOLDING *************** *** 3610,3616 **** lnum = curwin->w_cursor.lnum; col = curwin->w_cursor.col; - #ifdef FEAT_VISUAL /* * Block mode */ --- 3538,3543 ---- *************** *** 3792,3798 **** curwin->w_cursor.lnum = lnum; } else - #endif { /* * Character or Line mode --- 3719,3724 ---- *************** *** 3866,3882 **** curwin->w_cursor.col += (colnr_T)(totlen - 1); } } - #ifdef FEAT_VISUAL if (VIsual_active) lnum++; ! #endif ! } while ( ! #ifdef FEAT_VISUAL ! VIsual_active && lnum <= curbuf->b_visual.vi_end.lnum ! #else ! FALSE /* stop after 1 paste */ ! #endif ! ); curbuf->b_op_end = curwin->w_cursor; /* For "CTRL-O p" in Insert mode, put cursor after last char */ --- 3792,3800 ---- curwin->w_cursor.col += (colnr_T)(totlen - 1); } } if (VIsual_active) lnum++; ! } while (VIsual_active && lnum <= curbuf->b_visual.vi_end.lnum); curbuf->b_op_end = curwin->w_cursor; /* For "CTRL-O p" in Insert mode, put cursor after last char */ *************** *** 4038,4046 **** if (regname == '=') vim_free(y_array); - #ifdef FEAT_VISUAL VIsual_active = FALSE; - #endif /* If the cursor is past the end of the line put it at the end. */ adjust_cursor_eol(); --- 3956,3962 ---- *************** *** 4729,4739 **** return; curwin->w_cursor = oap->start; - #ifdef FEAT_VISUAL if (oap->is_VIsual) /* When there is no change: need to remove the Visual selection */ redraw_curbuf_later(INVERTED); - #endif /* Set '[ mark at the start of the formatted area */ curbuf->b_op_start = oap->start; --- 4645,4653 ---- *************** *** 4765,4771 **** saved_cursor.lnum = 0; } - #ifdef FEAT_VISUAL if (oap->is_VIsual) { win_T *wp; --- 4679,4684 ---- *************** *** 4783,4789 **** } } } - #endif } #if defined(FEAT_EVAL) || defined(PROTO) --- 4696,4701 ---- *************** *** 4794,4804 **** op_formatexpr(oap) oparg_T *oap; { - # ifdef FEAT_VISUAL if (oap->is_VIsual) /* When there is no change: need to remove the Visual selection */ redraw_curbuf_later(INVERTED); - # endif if (fex_format(oap->start.lnum, oap->line_count, NUL) != 0) /* As documented: when 'formatexpr' returns non-zero fall back to --- 4706,4714 ---- *************** *** 5238,5244 **** return FALSE; } - #ifdef FEAT_VISUAL /* * prepare a few things for block mode yank/delete/tilde * --- 5148,5153 ---- *************** *** 5397,5403 **** bdp->textcol = (colnr_T) (pstart - line); bdp->textstart = pstart; } - #endif /* FEAT_VISUAL */ #ifdef FEAT_RIGHTLEFT static void reverse_line __ARGS((char_u *s)); --- 5306,5311 ---- *************** *** 5748,5766 **** str = skipwhite(skiptowhite(str)); if (STRNCMP(str, "CHAR", 4) == 0) y_current->y_type = MCHAR; - #ifdef FEAT_VISUAL else if (STRNCMP(str, "BLOCK", 5) == 0) y_current->y_type = MBLOCK; - #endif else y_current->y_type = MLINE; /* get the block width; if it's missing we get a zero, which is OK */ str = skipwhite(skiptowhite(str)); - #ifdef FEAT_VISUAL y_current->y_width = getdigits(&str); - #else - (void)getdigits(&str); - #endif } while (!(eof = viminfo_readline(virp)) --- 5656,5668 ---- *************** *** 5868,5878 **** case MCHAR: type = (char_u *)"CHAR"; break; - #ifdef FEAT_VISUAL case MBLOCK: type = (char_u *)"BLOCK"; break; - #endif default: sprintf((char *)IObuff, _("E574: Unknown register type %d"), y_regs[i].y_type); --- 5770,5778 ---- *************** *** 5886,5898 **** fprintf(fp, "\"%c", c); if (c == execreg_lastc) fprintf(fp, "@"); ! fprintf(fp, "\t%s\t%d\n", type, ! #ifdef FEAT_VISUAL ! (int)y_regs[i].y_width ! #else ! 0 ! #endif ! ); /* If max_num_lines < 0, then we save ALL the lines in the register */ if (max_num_lines > 0 && num_lines > max_num_lines) --- 5786,5792 ---- fprintf(fp, "\"%c", c); if (c == execreg_lastc) fprintf(fp, "@"); ! fprintf(fp, "\t%s\t%d\n", type, (int)y_regs[i].y_width); /* If max_num_lines < 0, then we save ALL the lines in the register */ if (max_num_lines > 0 && num_lines > max_num_lines) *************** *** 6039,6048 **** { struct yankreg *old_y_previous, *old_y_current; pos_T old_cursor; - #ifdef FEAT_VISUAL pos_T old_visual; int old_visual_mode; - #endif colnr_T old_curswant; int old_set_curswant; pos_T old_op_start, old_op_end; --- 5933,5940 ---- *************** *** 6063,6072 **** old_set_curswant = curwin->w_set_curswant; old_op_start = curbuf->b_op_start; old_op_end = curbuf->b_op_end; - #ifdef FEAT_VISUAL old_visual = VIsual; old_visual_mode = VIsual_mode; - #endif clear_oparg(&oa); oa.regname = (cbd == &clip_plus ? '+' : '*'); oa.op_type = OP_YANK; --- 5955,5962 ---- *************** *** 6084,6093 **** curwin->w_set_curswant = old_set_curswant; curbuf->b_op_start = old_op_start; curbuf->b_op_end = old_op_end; - #ifdef FEAT_VISUAL VIsual = old_visual; VIsual_mode = old_visual_mode; - #endif } else { --- 5974,5981 ---- *************** *** 6190,6196 **** } - # if defined(FEAT_VISUAL) || defined(FEAT_EVAL) /* * If we have written to a clipboard register, send the text to the clipboard. */ --- 6078,6083 ---- *************** *** 6208,6214 **** clip_gen_set_selection(&clip_plus); } } - # endif #endif /* FEAT_CLIPBOARD || PROTO */ --- 6095,6100 ---- *************** *** 6273,6282 **** if (y_current->y_array != NULL) { - #ifdef FEAT_VISUAL if (reglen != NULL && y_current->y_type == MBLOCK) *reglen = y_current->y_width; - #endif return y_current->y_type; } return MAUTO; --- 6159,6166 ---- *************** *** 6454,6464 **** get_yank_register(name, TRUE); if (!y_append && !must_append) free_yank_all(); - #ifndef FEAT_VISUAL - /* Just in case - make sure we don't use MBLOCK */ - if (yank_type == MBLOCK) - yank_type = MAUTO; - #endif str_to_reg(y_current, yank_type, str, len, block_len); # ifdef FEAT_CLIPBOARD --- 6338,6343 ---- *************** *** 6496,6504 **** int append = FALSE; /* append to last line in register */ char_u *s; char_u **pp; - #ifdef FEAT_VISUAL long maxlen; - #endif if (y_ptr->y_array == NULL) /* NULL means empty register */ y_ptr->y_size = 0; --- 6375,6381 ---- *************** *** 6539,6547 **** pp[lnum] = y_ptr->y_array[lnum]; vim_free(y_ptr->y_array); y_ptr->y_array = pp; - #ifdef FEAT_VISUAL maxlen = 0; - #endif /* * Find the end of each line and save it into the array. --- 6416,6422 ---- *************** *** 6552,6561 **** if (str[i] == '\n') break; i -= start; /* i is now length of line */ - #ifdef FEAT_VISUAL if (i > maxlen) maxlen = i; - #endif if (append) { --lnum; --- 6427,6434 ---- *************** *** 6585,6596 **** } y_ptr->y_type = type; y_ptr->y_size = lnum; - # ifdef FEAT_VISUAL if (type == MBLOCK) y_ptr->y_width = (blocklen < 0 ? maxlen - 1 : blocklen); else y_ptr->y_width = 0; - # endif } #endif /* FEAT_CLIPBOARD || FEAT_EVAL || PROTO */ --- 6458,6467 ---- *************** *** 6684,6695 **** long word_count_cursor = 0; int eol_size; long last_check = 100000L; - #ifdef FEAT_VISUAL long line_count_selected = 0; pos_T min_pos, max_pos; oparg_T oparg; struct block_def bd; - #endif /* * Compute the length of the file in characters. --- 6555,6564 ---- *************** *** 6705,6711 **** else eol_size = 1; - #ifdef FEAT_VISUAL if (VIsual_active) { if (lt(VIsual, curwin->w_cursor)) --- 6574,6579 ---- *************** *** 6749,6755 **** } line_count_selected = max_pos.lnum - min_pos.lnum + 1; } - #endif for (lnum = 1; lnum <= curbuf->b_ml.ml_line_count; ++lnum) { --- 6617,6622 ---- *************** *** 6762,6768 **** last_check = byte_count + 100000L; } - #ifdef FEAT_VISUAL /* Do extra processing for VIsual mode. */ if (VIsual_active && lnum >= min_pos.lnum && lnum <= max_pos.lnum) --- 6629,6634 ---- *************** *** 6773,6785 **** switch (VIsual_mode) { case Ctrl_V: ! # ifdef FEAT_VIRTUALEDIT virtual_op = virtual_active(); ! # endif block_prep(&oparg, &bd, lnum, 0); ! # ifdef FEAT_VIRTUALEDIT virtual_op = MAYBE; ! # endif s = bd.textstart; len = (long)bd.textlen; break; --- 6639,6651 ---- switch (VIsual_mode) { case Ctrl_V: ! #ifdef FEAT_VIRTUALEDIT virtual_op = virtual_active(); ! #endif block_prep(&oparg, &bd, lnum, 0); ! #ifdef FEAT_VIRTUALEDIT virtual_op = MAYBE; ! #endif s = bd.textstart; len = (long)bd.textlen; break; *************** *** 6811,6817 **** } } else - #endif { /* In non-visual mode, check for the line the cursor is on */ if (lnum == curwin->w_cursor.lnum) --- 6677,6682 ---- *************** *** 6833,6839 **** if (!curbuf->b_p_eol && curbuf->b_p_bin) byte_count -= eol_size; - #ifdef FEAT_VISUAL if (VIsual_active) { if (VIsual_mode == Ctrl_V && curwin->w_curswant < MAXCOL) --- 6698,6703 ---- *************** *** 6864,6870 **** byte_count_cursor, byte_count); } else - #endif { p = ml_get_curline(); validate_virtcol(); --- 6728,6733 ---- *** ../vim-7.4.211/src/option.c 2014-03-12 18:55:52.100906804 +0100 --- src/option.c 2014-03-23 13:28:12.359168452 +0100 *************** *** 1629,1639 **** #endif SCRIPTID_INIT}, {"keymodel", "km", P_STRING|P_VI_DEF|P_COMMA|P_NODUP, - #ifdef FEAT_VISUAL (char_u *)&p_km, PV_NONE, - #else - (char_u *)NULL, PV_NONE, - #endif {(char_u *)"", (char_u *)0L} SCRIPTID_INIT}, {"keywordprg", "kp", P_STRING|P_EXPAND|P_VI_DEF|P_SECURE, (char_u *)&p_kp, PV_KP, --- 1629,1635 ---- *************** *** 2190,2208 **** (char_u *)&p_secure, PV_NONE, {(char_u *)FALSE, (char_u *)0L} SCRIPTID_INIT}, {"selection", "sel", P_STRING|P_VI_DEF, - #ifdef FEAT_VISUAL (char_u *)&p_sel, PV_NONE, - #else - (char_u *)NULL, PV_NONE, - #endif {(char_u *)"inclusive", (char_u *)0L} SCRIPTID_INIT}, {"selectmode", "slm", P_STRING|P_VI_DEF|P_COMMA|P_NODUP, - #ifdef FEAT_VISUAL (char_u *)&p_slm, PV_NONE, - #else - (char_u *)NULL, PV_NONE, - #endif {(char_u *)"", (char_u *)0L} SCRIPTID_INIT}, {"sessionoptions", "ssop", P_STRING|P_VI_DEF|P_COMMA|P_NODUP, #ifdef FEAT_SESSION --- 2186,2196 ---- *************** *** 2979,2991 **** static char *(p_wak_values[]) = {"yes", "menu", "no", NULL}; #endif static char *(p_mousem_values[]) = {"extend", "popup", "popup_setpos", "mac", NULL}; - #ifdef FEAT_VISUAL static char *(p_sel_values[]) = {"inclusive", "exclusive", "old", NULL}; static char *(p_slm_values[]) = {"mouse", "key", "cmd", NULL}; - #endif - #ifdef FEAT_VISUAL static char *(p_km_values[]) = {"startsel", "stopsel", NULL}; - #endif #ifdef FEAT_BROWSE static char *(p_bsdir_values[]) = {"current", "last", "buffer", NULL}; #endif --- 2967,2975 ---- *************** *** 6578,6584 **** } #endif - #ifdef FEAT_VISUAL /* 'selection' */ else if (varp == &p_sel) { --- 6562,6567 ---- *************** *** 6593,6599 **** if (check_opt_strings(p_slm, p_slm_values, TRUE) != OK) errmsg = e_invarg; } - #endif #ifdef FEAT_BROWSE /* 'browsedir' */ --- 6576,6581 ---- *************** *** 6605,6611 **** } #endif - #ifdef FEAT_VISUAL /* 'keymodel' */ else if (varp == &p_km) { --- 6587,6592 ---- *************** *** 6617,6623 **** km_startsel = (vim_strchr(p_km, 'a') != NULL); } } - #endif /* 'mousemodel' */ else if (varp == &p_mousem) --- 6598,6603 ---- *** ../vim-7.4.211/src/os_msdos.c 2013-05-06 04:06:04.000000000 +0200 --- src/os_msdos.c 2014-03-23 13:28:24.855168644 +0100 *************** *** 2270,2278 **** default: case 'L': type = MLINE; break; case 'C': type = MCHAR; break; - #ifdef FEAT_VISUAL case 'B': type = MBLOCK; break; - #endif } } --- 2270,2276 ---- *************** *** 2799,2807 **** default: case MLINE: clip_sel_type = "L"; break; case MCHAR: clip_sel_type = "C"; break; - #ifdef FEAT_VISUAL case MBLOCK: clip_sel_type = "B"; break; - #endif } movedata( --- 2797,2803 ---- *** ../vim-7.4.211/src/os_qnx.c 2011-09-21 19:48:08.000000000 +0200 --- src/os_qnx.c 2014-03-23 13:28:38.815168858 +0100 *************** *** 78,86 **** default: /* fallthrough to line type */ case 'L': type = MLINE; break; case 'C': type = MCHAR; break; - #ifdef FEAT_VISUAL case 'B': type = MBLOCK; break; - #endif } is_type_set = TRUE; } --- 78,84 ---- *************** *** 143,151 **** default: /* fallthrough to MLINE */ case MLINE: *vim_clip = 'L'; break; case MCHAR: *vim_clip = 'C'; break; - #ifdef FEAT_VISUAL case MBLOCK: *vim_clip = 'B'; break; - #endif } vim_strncpy(text_clip, str, len); --- 141,147 ---- *** ../vim-7.4.211/src/quickfix.c 2014-03-12 19:41:37.096948866 +0100 --- src/quickfix.c 2014-03-23 13:28:50.907169043 +0100 *************** *** 2347,2355 **** else height = QF_WINHEIGHT; - #ifdef FEAT_VISUAL reset_VIsual_and_resel(); /* stop Visual mode */ - #endif #ifdef FEAT_GUI need_mouse_correct = TRUE; #endif --- 2347,2353 ---- *** ../vim-7.4.211/src/regexp.c 2013-11-21 17:12:55.000000000 +0100 --- src/regexp.c 2014-03-23 13:29:14.495169404 +0100 *************** *** 4179,4187 **** - (*mb_head_off)(regline, reginput - 1), reg_buf); return -1; } - #endif ! #ifdef FEAT_VISUAL static int reg_match_visual __ARGS((void)); /* --- 4179,4186 ---- - (*mb_head_off)(regline, reginput - 1), reg_buf); return -1; } #endif ! static int reg_match_visual __ARGS((void)); /* *************** *** 4258,4264 **** } return TRUE; } - #endif #define ADVANCE_REGINPUT() mb_ptr_adv(reginput) --- 4257,4262 ---- *************** *** 4440,4448 **** break; case RE_VISUAL: - #ifdef FEAT_VISUAL if (!reg_match_visual()) - #endif status = RA_NOMATCH; break; --- 4438,4444 ---- *** ../vim-7.4.211/src/regexp_nfa.c 2013-11-28 14:20:11.000000000 +0100 --- src/regexp_nfa.c 2014-03-23 13:29:31.367169663 +0100 *************** *** 6403,6416 **** break; case NFA_VISUAL: - #ifdef FEAT_VISUAL result = reg_match_visual(); if (result) { add_here = TRUE; add_state = t->state->out; } - #endif break; case NFA_MOPEN1: --- 6403,6414 ---- *** ../vim-7.4.211/src/screen.c 2013-12-11 15:51:54.000000000 +0100 --- src/screen.c 2014-03-23 13:32:10.787172106 +0100 *************** *** 446,453 **** #endif } - #if defined(FEAT_RUBY) || defined(FEAT_PERL) || defined(FEAT_VISUAL) || \ - (defined(FEAT_CLIPBOARD) && defined(FEAT_X11)) || defined(PROTO) /* * update all windows that are editing the current buffer */ --- 446,451 ---- *************** *** 458,464 **** redraw_curbuf_later(type); update_screen(type); } - #endif /* * update_screen() --- 456,461 ---- *************** *** 596,609 **** && curwin->w_botfill == curwin->w_old_botfill #endif && curwin->w_topline == curwin->w_lines[0].wl_lnum) - #ifdef FEAT_VISUAL || (type == INVERTED && VIsual_active && curwin->w_old_cursor_lnum == curwin->w_cursor.lnum && curwin->w_old_visual_mode == VIsual_mode && (curwin->w_valid & VALID_VIRTCOL) && curwin->w_old_curswant == curwin->w_curswant) - #endif )) curwin->w_redr_type = type; --- 593,604 ---- *************** *** 1030,1039 **** updating. 0 when no mid area updating. */ int bot_start = 999;/* first row of the bot area that needs updating. 999 when no bot area updating */ - #ifdef FEAT_VISUAL int scrolled_down = FALSE; /* TRUE when scrolled down when w_topline got smaller a bit */ - #endif #ifdef FEAT_SEARCH_EXTRA matchitem_T *cur; /* points to the match list */ int top_to_mod = FALSE; /* redraw above mod_top */ --- 1025,1032 ---- *************** *** 1354,1362 **** /* Need to update rows that are new, stop at the * first one that scrolled down. */ top_end = i; - #ifdef FEAT_VISUAL scrolled_down = TRUE; - #endif /* Move the entries that were scrolled, disable * the entries for the lines to be redrawn. */ --- 1347,1353 ---- *************** *** 1513,1519 **** type = NOT_VALID; } - #ifdef FEAT_VISUAL /* check if we are updating or removing the inverted part */ if ((VIsual_active && buf == curwin->w_buffer) || (wp->w_old_cursor_lnum != 0 && type != NOT_VALID)) --- 1504,1509 ---- *************** *** 1708,1714 **** wp->w_old_visual_lnum = 0; wp->w_old_visual_col = 0; } - #endif /* FEAT_VISUAL */ #if defined(FEAT_SYN_HL) || defined(FEAT_SEARCH_EXTRA) /* reset got_int, otherwise regexp won't work */ --- 1698,1703 ---- *************** *** 2670,2676 **** * 6. set highlighting for the Visual area an other text. * If all folded lines are in the Visual area, highlight the line. */ - #ifdef FEAT_VISUAL if (VIsual_active && wp->w_buffer == curwin->w_buffer) { if (ltoreq(curwin->w_cursor, VIsual)) --- 2659,2664 ---- *************** *** 2718,2724 **** } } } - #endif #ifdef FEAT_SYN_HL /* Show 'cursorcolumn' in the fold line. */ --- 2706,2711 ---- *************** *** 2876,2885 **** int fromcol, tocol; /* start/end of inverting */ int fromcol_prev = -2; /* start of inverting after cursor */ int noinvcur = FALSE; /* don't invert the cursor */ - #ifdef FEAT_VISUAL pos_T *top, *bot; int lnum_in_visual_area = FALSE; - #endif pos_T pos; long v; --- 2863,2870 ---- *************** *** 3090,3096 **** */ fromcol = -10; tocol = MAXCOL; - #ifdef FEAT_VISUAL if (VIsual_active && wp->w_buffer == curwin->w_buffer) { /* Visual is after curwin->w_cursor */ --- 3075,3080 ---- *************** *** 3183,3191 **** /* * handle 'incsearch' and ":s///c" highlighting */ ! else ! #endif /* FEAT_VISUAL */ ! if (highlight_match && wp == curwin && lnum >= curwin->w_cursor.lnum && lnum <= curwin->w_cursor.lnum + search_match_lines) --- 3167,3173 ---- /* * handle 'incsearch' and ":s///c" highlighting */ ! else if (highlight_match && wp == curwin && lnum >= curwin->w_cursor.lnum && lnum <= curwin->w_cursor.lnum + search_match_lines) *************** *** 3324,3330 **** mb_ptr_adv(ptr); } - #if defined(FEAT_SYN_HL) || defined(FEAT_VIRTUALEDIT) || defined(FEAT_VISUAL) /* When: * - 'cuc' is set, or * - 'colorcolumn' is set, or --- 3306,3311 ---- *************** *** 3333,3359 **** * the end of the line may be before the start of the displayed part. */ if (vcol < v && ( ! # ifdef FEAT_SYN_HL ! wp->w_p_cuc ! || draw_color_col ! # if defined(FEAT_VIRTUALEDIT) || defined(FEAT_VISUAL) ! || ! # endif ! # endif ! # ifdef FEAT_VIRTUALEDIT ! virtual_active() ! # ifdef FEAT_VISUAL ! || ! # endif ! # endif ! # ifdef FEAT_VISUAL ! (VIsual_active && wp->w_buffer == curwin->w_buffer) ! # endif ! )) { vcol = v; } - #endif /* Handle a character that's not completely on the screen: Put ptr at * that character but skip the first few screen characters. */ --- 3314,3329 ---- * the end of the line may be before the start of the displayed part. */ if (vcol < v && ( ! #ifdef FEAT_SYN_HL ! wp->w_p_cuc || draw_color_col || ! #endif ! #ifdef FEAT_VIRTUALEDIT ! virtual_active() || ! #endif ! (VIsual_active && wp->w_buffer == curwin->w_buffer))) { vcol = v; } /* Handle a character that's not completely on the screen: Put ptr at * that character but skip the first few screen characters. */ *************** *** 4500,4508 **** && ((wp->w_p_list && lcs_eol > 0) || ((fromcol >= 0 || fromcol_prev >= 0) && tocol > vcol - #ifdef FEAT_VISUAL && VIsual_mode != Ctrl_V - #endif && ( # ifdef FEAT_RIGHTLEFT wp->w_p_rl ? (col >= 0) : --- 4470,4476 ---- *************** *** 4854,4864 **** #endif if (lcs_eol == lcs_eol_one && ((area_attr != 0 && vcol == fromcol - #ifdef FEAT_VISUAL && (VIsual_mode != Ctrl_V || lnum == VIsual.lnum || lnum == curwin->w_cursor.lnum) - #endif && c == NUL) #ifdef FEAT_SEARCH_EXTRA /* highlight 'hlsearch' match at end of line */ --- 4822,4830 ---- *************** *** 9659,9668 **** do_mode = ((p_smd && msg_silent == 0) && ((State & INSERT) || restart_edit ! #ifdef FEAT_VISUAL ! || VIsual_active ! #endif ! )); if (do_mode || Recording) { /* --- 9625,9631 ---- do_mode = ((p_smd && msg_silent == 0) && ((State & INSERT) || restart_edit ! || VIsual_active)); if (do_mode || Recording) { /* *************** *** 9790,9796 **** if ((State & INSERT) && p_paste) MSG_PUTS_ATTR(_(" (paste)"), attr); - #ifdef FEAT_VISUAL if (VIsual_active) { char *p; --- 9753,9758 ---- *************** *** 9810,9816 **** } MSG_PUTS_ATTR(_(p), attr); } - #endif MSG_PUTS_ATTR(" --", attr); } --- 9772,9777 ---- *************** *** 9839,9849 **** msg_clr_cmdline(); #ifdef FEAT_CMDL_INFO - # ifdef FEAT_VISUAL /* In Visual mode the size of the selected area must be redrawn. */ if (VIsual_active) clear_showcmd(); - # endif /* If the last window has no status line, the ruler is after the mode * message and must be redrawn */ --- 9800,9808 ---- *** ../vim-7.4.211/src/search.c 2014-01-14 21:31:30.000000000 +0100 --- src/search.c 2014-03-23 13:34:46.351174489 +0100 *************** *** 506,512 **** #endif /* ! * lowest level search function. * Search for 'count'th occurrence of pattern 'pat' in direction 'dir'. * Start at position 'pos' and return the found position in 'pos'. * --- 506,512 ---- #endif /* ! * Lowest level search function. * Search for 'count'th occurrence of pattern 'pat' in direction 'dir'. * Start at position 'pos' and return the found position in 'pos'. * *************** *** 3198,3204 **** cls_bigword = bigword; clearpos(&start_pos); - #ifdef FEAT_VISUAL /* Correct cursor when 'selection' is exclusive */ if (VIsual_active && *p_sel == 'e' && lt(VIsual, curwin->w_cursor)) dec_cursor(); --- 3198,3203 ---- *************** *** 3208,3214 **** * character, select the word and/or white space under the cursor. */ if (!VIsual_active || equalpos(curwin->w_cursor, VIsual)) - #endif { /* * Go to start of current word or white space. --- 3207,3212 ---- *************** *** 3245,3251 **** include_white = TRUE; } - #ifdef FEAT_VISUAL if (VIsual_active) { /* should do something when inclusive == FALSE ! */ --- 3243,3248 ---- *************** *** 3253,3259 **** redraw_curbuf_later(INVERTED); /* update the inversion */ } else - #endif { oap->start = start_pos; oap->motion_type = MCHAR; --- 3250,3255 ---- *************** *** 3267,3273 **** while (count > 0) { inclusive = TRUE; - #ifdef FEAT_VISUAL if (VIsual_active && lt(curwin->w_cursor, VIsual)) { /* --- 3263,3268 ---- *************** *** 3288,3294 **** } } else - #endif { /* * Move cursor forward one word and/or white area. --- 3283,3288 ---- *************** *** 3334,3351 **** back_in_line(); if (cls() == 0 && curwin->w_cursor.col > 0) { - #ifdef FEAT_VISUAL if (VIsual_active) VIsual = curwin->w_cursor; else - #endif oap->start = curwin->w_cursor; } } curwin->w_cursor = pos; /* put cursor back at end */ } - #ifdef FEAT_VISUAL if (VIsual_active) { if (*p_sel == 'e' && inclusive && ltoreq(VIsual, curwin->w_cursor)) --- 3328,3342 ---- *************** *** 3357,3363 **** } } else - #endif oap->inclusive = inclusive; return OK; --- 3348,3353 ---- *************** *** 3384,3390 **** pos = start_pos; findsent(FORWARD, 1L); /* Find start of next sentence. */ - #ifdef FEAT_VISUAL /* * When the Visual area is bigger than one character: Extend it. */ --- 3374,3379 ---- *************** *** 3471,3477 **** } return OK; } - #endif /* * If the cursor started on a blank, check if it is just before the start --- 3460,3465 ---- *************** *** 3521,3527 **** find_first_blank(&start_pos); } - #ifdef FEAT_VISUAL if (VIsual_active) { /* Avoid getting stuck with "is" on a single space before a sentence. */ --- 3509,3514 ---- *************** *** 3534,3540 **** redraw_curbuf_later(INVERTED); /* update the inversion */ } else - #endif { /* include a newline after the sentence, if there is one */ if (incl(&curwin->w_cursor) == -1) --- 3521,3526 ---- *************** *** 3574,3582 **** /* * If we start on '(', '{', ')', '}', etc., use the whole block inclusive. */ - #ifdef FEAT_VISUAL if (!VIsual_active || equalpos(VIsual, curwin->w_cursor)) - #endif { setpcmark(); if (what == '{') /* ignore indent */ --- 3560,3566 ---- *************** *** 3587,3593 **** /* cursor on '(' or '{', move cursor just after it */ ++curwin->w_cursor.col; } - #ifdef FEAT_VISUAL else if (lt(VIsual, curwin->w_cursor)) { old_start = VIsual; --- 3571,3576 ---- *************** *** 3595,3601 **** } else old_end = VIsual; - #endif /* * Search backwards for unclosed '(', '{', etc.. --- 3578,3583 ---- *************** *** 3641,3647 **** if (decl(&curwin->w_cursor) != 0) break; } - #ifdef FEAT_VISUAL /* * In Visual mode, when the resulting area is not bigger than what we * started with, extend it to the next block, and then exclude again. --- 3623,3628 ---- *************** *** 3666,3676 **** curwin->w_cursor = *end_pos; } else - #endif break; } - #ifdef FEAT_VISUAL if (VIsual_active) { if (*p_sel == 'e') --- 3647,3655 ---- *************** *** 3683,3689 **** showmode(); } else - #endif { oap->start = start_pos; oap->motion_type = MCHAR; --- 3662,3667 ---- *************** *** 3807,3823 **** old_pos = curwin->w_cursor; old_end = curwin->w_cursor; /* remember where we started */ old_start = old_end; - #ifdef FEAT_VISUAL if (!VIsual_active || *p_sel == 'e') - #endif decl(&old_end); /* old_end is inclusive */ /* * If we start on "<aaa>" select that block. */ - #ifdef FEAT_VISUAL if (!VIsual_active || equalpos(VIsual, curwin->w_cursor)) - #endif { setpcmark(); --- 3785,3797 ---- *************** *** 3843,3849 **** old_end = curwin->w_cursor; } } - #ifdef FEAT_VISUAL else if (lt(VIsual, curwin->w_cursor)) { old_start = VIsual; --- 3817,3822 ---- *************** *** 3851,3857 **** } else old_end = VIsual; - #endif again: /* --- 3824,3829 ---- *************** *** 3951,3957 **** } } - #ifdef FEAT_VISUAL if (VIsual_active) { /* If the end is before the start there is no text between tags, select --- 3923,3928 ---- *************** *** 3966,3972 **** showmode(); } else - #endif { oap->start = start_pos; oap->motion_type = MCHAR; --- 3937,3942 ---- *************** *** 4010,4016 **** start_lnum = curwin->w_cursor.lnum; - #ifdef FEAT_VISUAL /* * When visual area is more than one line: extend it. */ --- 3980,3985 ---- *************** *** 4064,4070 **** curwin->w_cursor.col = 0; return retval; } - #endif /* * First move back to the start_lnum of the paragraph or white lines --- 4033,4038 ---- *************** *** 4136,4142 **** while (start_lnum > 1 && linewhite(start_lnum - 1)) --start_lnum; - #ifdef FEAT_VISUAL if (VIsual_active) { /* Problem: when doing "Vipipip" nothing happens in a single white --- 4104,4109 ---- *************** *** 4149,4155 **** showmode(); } else - #endif { oap->start.lnum = start_lnum; oap->start.col = 0; --- 4116,4121 ---- *************** *** 4247,4253 **** int col_end; int col_start = curwin->w_cursor.col; int inclusive = FALSE; - #ifdef FEAT_VISUAL int vis_empty = TRUE; /* Visual selection <= 1 char */ int vis_bef_curs = FALSE; /* Visual starts before cursor */ int inside_quotes = FALSE; /* Looks like "i'" done before */ --- 4213,4218 ---- *************** *** 4331,4347 **** } } else - #endif ! if (line[col_start] == quotechar ! #ifdef FEAT_VISUAL ! || !vis_empty ! #endif ! ) { int first_col = col_start; - #ifdef FEAT_VISUAL if (!vis_empty) { if (vis_bef_curs) --- 4296,4306 ---- } } else ! if (line[col_start] == quotechar || !vis_empty) { int first_col = col_start; if (!vis_empty) { if (vis_bef_curs) *************** *** 4349,4355 **** else first_col = find_prev_quote(line, col_start, quotechar, NULL); } ! #endif /* The cursor is on a quote, we don't know if it's the opening or * closing quote. Search from the start of the line to find out. * Also do this when there is a Visual area, a' may leave the cursor --- 4308,4314 ---- else first_col = find_prev_quote(line, col_start, quotechar, NULL); } ! /* The cursor is on a quote, we don't know if it's the opening or * closing quote. Search from the start of the line to find out. * Also do this when there is a Visual area, a' may leave the cursor *************** *** 4406,4419 **** /* Set start position. After vi" another i" must include the ". * For v2i" include the quotes. */ ! if (!include && count < 2 ! #ifdef FEAT_VISUAL ! && (vis_empty || !inside_quotes) ! #endif ! ) ++col_start; curwin->w_cursor.col = col_start; - #ifdef FEAT_VISUAL if (VIsual_active) { /* Set the start of the Visual area when the Visual area was empty, we --- 4365,4373 ---- /* Set start position. After vi" another i" must include the ". * For v2i" include the quotes. */ ! if (!include && count < 2 && (vis_empty || !inside_quotes)) ++col_start; curwin->w_cursor.col = col_start; if (VIsual_active) { /* Set the start of the Visual area when the Visual area was empty, we *************** *** 4433,4439 **** } } else - #endif { oap->start = curwin->w_cursor; oap->motion_type = MCHAR; --- 4387,4392 ---- *************** *** 4441,4454 **** /* Set end position. */ curwin->w_cursor.col = col_end; ! if ((include || count > 1 ! #ifdef FEAT_VISUAL ! /* After vi" another i" must include the ". */ || (!vis_empty && inside_quotes) - #endif ) && inc_cursor() == 2) inclusive = TRUE; - #ifdef FEAT_VISUAL if (VIsual_active) { if (vis_empty || vis_bef_curs) --- 4394,4403 ---- /* Set end position. */ curwin->w_cursor.col = col_end; ! if ((include || count > 1 /* After vi" another i" must include the ". */ || (!vis_empty && inside_quotes) ) && inc_cursor() == 2) inclusive = TRUE; if (VIsual_active) { if (vis_empty || vis_bef_curs) *************** *** 4480,4486 **** } } else - #endif { /* Set inclusive and other oap's flags. */ oap->inclusive = inclusive; --- 4429,4434 ---- *************** *** 4491,4497 **** #endif /* FEAT_TEXTOBJ */ - #if defined(FEAT_VISUAL) || defined(PROTO) static int is_one_char __ARGS((char_u *pattern)); /* --- 4439,4444 ---- *************** *** 4690,4696 **** vim_regfree(regmatch.regprog); return result; } - #endif /* FEAT_VISUAL */ #if defined(FEAT_LISP) || defined(FEAT_CINDENT) || defined(FEAT_TEXTOBJ) \ || defined(PROTO) --- 4637,4642 ---- *** ../vim-7.4.211/src/spell.c 2014-03-08 16:13:39.123462070 +0100 --- src/spell.c 2014-03-23 13:35:15.195174931 +0100 *************** *** 10191,10197 **** if (no_spell_checking(curwin)) return; - #ifdef FEAT_VISUAL if (VIsual_active) { /* Use the Visually selected text as the bad word. But reject --- 10191,10196 ---- *************** *** 10209,10218 **** ++badlen; end_visual_mode(); } ! else ! #endif ! /* Find the start of the badly spelled word. */ ! if (spell_move_to(curwin, FORWARD, TRUE, TRUE, NULL) == 0 || curwin->w_cursor.col > prev_cursor.col) { /* No bad word or it starts after the cursor: use the word under the --- 10208,10215 ---- ++badlen; end_visual_mode(); } ! /* Find the start of the badly spelled word. */ ! else if (spell_move_to(curwin, FORWARD, TRUE, TRUE, NULL) == 0 || curwin->w_cursor.col > prev_cursor.col) { /* No bad word or it starts after the cursor: use the word under the *** ../vim-7.4.211/src/syntax.c 2013-11-28 18:53:47.000000000 +0100 --- src/syntax.c 2014-03-23 13:35:30.379175164 +0100 *************** *** 6837,6846 **** CENT("SignColumn term=standout ctermbg=Grey ctermfg=DarkBlue", "SignColumn term=standout ctermbg=Grey ctermfg=DarkBlue guibg=Grey guifg=DarkBlue"), #endif - #ifdef FEAT_VISUAL CENT("Visual term=reverse", "Visual term=reverse guibg=LightGrey"), - #endif #ifdef FEAT_DIFF CENT("DiffAdd term=bold ctermbg=LightBlue", "DiffAdd term=bold ctermbg=LightBlue guibg=LightBlue"), --- 6837,6844 ---- *************** *** 6927,6936 **** CENT("SignColumn term=standout ctermbg=DarkGrey ctermfg=Cyan", "SignColumn term=standout ctermbg=DarkGrey ctermfg=Cyan guibg=Grey guifg=Cyan"), #endif - #ifdef FEAT_VISUAL CENT("Visual term=reverse", "Visual term=reverse guibg=DarkGrey"), - #endif #ifdef FEAT_DIFF CENT("DiffAdd term=bold ctermbg=DarkBlue", "DiffAdd term=bold ctermbg=DarkBlue guibg=DarkBlue"), --- 6925,6932 ---- *** ../vim-7.4.211/src/term.c 2014-03-19 14:01:53.153903819 +0100 --- src/term.c 2014-03-23 13:35:43.519175365 +0100 *************** *** 3456,3467 **** return; } - # ifdef FEAT_VISUAL if (VIsual_active) checkfor = MOUSE_VISUAL; ! else ! # endif ! if (State == HITRETURN || State == ASKMORE || State == SETWSIZE) checkfor = MOUSE_RETURN; else if (State & INSERT) checkfor = MOUSE_INSERT; --- 3456,3464 ---- return; } if (VIsual_active) checkfor = MOUSE_VISUAL; ! else if (State == HITRETURN || State == ASKMORE || State == SETWSIZE) checkfor = MOUSE_RETURN; else if (State & INSERT) checkfor = MOUSE_INSERT; *** ../vim-7.4.211/src/ui.c 2013-07-13 20:57:08.000000000 +0200 --- src/ui.c 2014-03-23 13:36:15.459175855 +0100 *************** *** 2610,2622 **** if (on_sep_line) return IN_SEP_LINE; #endif - #ifdef FEAT_VISUAL if (flags & MOUSE_MAY_STOP_VIS) { end_visual_mode(); redraw_curbuf_later(INVERTED); /* delete the inversion */ } - #endif #if defined(FEAT_CMDWIN) && defined(FEAT_CLIPBOARD) /* Continue a modeless selection in another window. */ if (cmdwin_type != 0 && row < W_WINROW(curwin)) --- 2610,2620 ---- *************** *** 2686,2717 **** } #endif - #ifdef FEAT_VISUAL /* Before jumping to another buffer, or moving the cursor for a left * click, stop Visual mode. */ if (VIsual_active && (wp->w_buffer != curwin->w_buffer || (!on_status_line ! # ifdef FEAT_VERTSPLIT && !on_sep_line ! # endif ! # ifdef FEAT_FOLDING && ( ! # ifdef FEAT_RIGHTLEFT wp->w_p_rl ? col < W_WIDTH(wp) - wp->w_p_fdc : ! # endif col >= wp->w_p_fdc ! # ifdef FEAT_CMDWIN + (cmdwin_type == 0 && wp == curwin ? 0 : 1) - # endif - ) # endif && (flags & MOUSE_MAY_STOP_VIS)))) { end_visual_mode(); redraw_curbuf_later(INVERTED); /* delete the inversion */ } - #endif #ifdef FEAT_CMDWIN if (cmdwin_type != 0 && wp != curwin) { --- 2684,2713 ---- } #endif /* Before jumping to another buffer, or moving the cursor for a left * click, stop Visual mode. */ if (VIsual_active && (wp->w_buffer != curwin->w_buffer || (!on_status_line ! #ifdef FEAT_VERTSPLIT && !on_sep_line ! #endif ! #ifdef FEAT_FOLDING && ( ! # ifdef FEAT_RIGHTLEFT wp->w_p_rl ? col < W_WIDTH(wp) - wp->w_p_fdc : ! # endif col >= wp->w_p_fdc ! # ifdef FEAT_CMDWIN + (cmdwin_type == 0 && wp == curwin ? 0 : 1) # endif + ) + #endif && (flags & MOUSE_MAY_STOP_VIS)))) { end_visual_mode(); redraw_curbuf_later(INVERTED); /* delete the inversion */ } #ifdef FEAT_CMDWIN if (cmdwin_type != 0 && wp != curwin) { *************** *** 2801,2814 **** #endif else /* keep_window_focus must be TRUE */ { - #ifdef FEAT_VISUAL /* before moving the cursor for a left click, stop Visual mode */ if (flags & MOUSE_MAY_STOP_VIS) { end_visual_mode(); redraw_curbuf_later(INVERTED); /* delete the inversion */ } - #endif #if defined(FEAT_CMDWIN) && defined(FEAT_CLIPBOARD) /* Continue a modeless selection in another window. */ --- 2797,2808 ---- *************** *** 2933,2939 **** if (mouse_comp_pos(curwin, &row, &col, &curwin->w_cursor.lnum)) mouse_past_bottom = TRUE; - #ifdef FEAT_VISUAL /* Start Visual mode before coladvance(), for when 'sel' != "old" */ if ((flags & MOUSE_MAY_VIS) && !VIsual_active) { --- 2927,2932 ---- *************** *** 2947,2953 **** if (p_smd && msg_silent == 0) redraw_cmdline = TRUE; /* show visual mode later */ } - #endif curwin->w_curswant = col; curwin->w_set_curswant = FALSE; /* May still have been TRUE */ --- 2940,2945 ---- *** ../vim-7.4.211/src/undo.c 2014-03-12 16:51:35.060792541 +0100 --- src/undo.c 2014-03-23 13:37:05.435176620 +0100 *************** *** 532,540 **** /* save named marks and Visual marks for undo */ mch_memmove(uhp->uh_namedm, curbuf->b_namedm, sizeof(pos_T) * NMARKS); - #ifdef FEAT_VISUAL uhp->uh_visual = curbuf->b_visual; - #endif curbuf->b_u_newhead = uhp; if (curbuf->b_u_oldhead == NULL) --- 532,538 ---- *************** *** 1014,1029 **** /* Assume NMARKS will stay the same. */ for (i = 0; i < NMARKS; ++i) serialize_pos(uhp->uh_namedm[i], fp); - #ifdef FEAT_VISUAL serialize_visualinfo(&uhp->uh_visual, fp); - #else - { - visualinfo_T info; - - memset(&info, 0, sizeof(visualinfo_T)); - serialize_visualinfo(&info, fp); - } - #endif put_time(fp, uhp->uh_time); /* Optional fields. */ --- 1012,1018 ---- *************** *** 1082,1095 **** uhp->uh_flags = get2c(fp); for (i = 0; i < NMARKS; ++i) unserialize_pos(&uhp->uh_namedm[i], fp); - #ifdef FEAT_VISUAL unserialize_visualinfo(&uhp->uh_visual, fp); - #else - { - visualinfo_T info; - unserialize_visualinfo(&info, fp); - } - #endif uhp->uh_time = get8ctime(fp); /* Optional fields. */ --- 1071,1077 ---- *************** *** 2406,2414 **** int old_flags; int new_flags; pos_T namedm[NMARKS]; - #ifdef FEAT_VISUAL visualinfo_T visualinfo; - #endif int empty_buffer; /* buffer became empty */ u_header_T *curhead = curbuf->b_u_curhead; --- 2388,2394 ---- *************** *** 2430,2438 **** * save marks before undo/redo */ mch_memmove(namedm, curbuf->b_namedm, sizeof(pos_T) * NMARKS); - #ifdef FEAT_VISUAL visualinfo = curbuf->b_visual; - #endif curbuf->b_op_start.lnum = curbuf->b_ml.ml_line_count; curbuf->b_op_start.col = 0; curbuf->b_op_end.lnum = 0; --- 2410,2416 ---- *************** *** 2602,2614 **** curbuf->b_namedm[i] = curhead->uh_namedm[i]; curhead->uh_namedm[i] = namedm[i]; } - #ifdef FEAT_VISUAL if (curhead->uh_visual.vi_start.lnum != 0) { curbuf->b_visual = curhead->uh_visual; curhead->uh_visual = visualinfo; } - #endif /* * If the cursor is only off by one line, put it at the same position as --- 2580,2590 ---- *** ../vim-7.4.211/src/version.c 2014-03-22 13:29:57.693846167 +0100 --- src/version.c 2014-03-23 15:01:49.719254526 +0100 *************** *** 642,656 **** #else "-virtualedit", #endif - #ifdef FEAT_VISUAL "+visual", ! # ifdef FEAT_VISUALEXTRA "+visualextra", - # else - "-visualextra", - # endif #else ! "-visual", #endif #ifdef FEAT_VIMINFO "+viminfo", --- 642,652 ---- #else "-virtualedit", #endif "+visual", ! #ifdef FEAT_VISUALEXTRA "+visualextra", #else ! "-visualextra", #endif #ifdef FEAT_VIMINFO "+viminfo", *** ../vim-7.4.211/src/window.c 2014-01-10 15:53:09.000000000 +0100 --- src/window.c 2014-03-23 13:38:17.767177729 +0100 *************** *** 130,138 **** case Ctrl_S: case 's': CHECK_CMDWIN - #ifdef FEAT_VISUAL reset_VIsual_and_resel(); /* stop Visual mode */ - #endif #ifdef FEAT_QUICKFIX /* When splitting the quickfix window open a new buffer in it, * don't replicate the quickfix buffer. */ --- 130,136 ---- *************** *** 150,158 **** case Ctrl_V: case 'v': CHECK_CMDWIN - # ifdef FEAT_VISUAL reset_VIsual_and_resel(); /* stop Visual mode */ - # endif # ifdef FEAT_QUICKFIX /* When splitting the quickfix window open a new buffer in it, * don't replicate the quickfix buffer. */ --- 148,154 ---- *************** *** 170,178 **** case Ctrl_HAT: case '^': CHECK_CMDWIN - #ifdef FEAT_VISUAL reset_VIsual_and_resel(); /* stop Visual mode */ - #endif STRCPY(cbuf, "split #"); if (Prenum) vim_snprintf((char *)cbuf + 7, sizeof(cbuf) - 7, --- 166,172 ---- *************** *** 184,192 **** case Ctrl_N: case 'n': CHECK_CMDWIN - #ifdef FEAT_VISUAL reset_VIsual_and_resel(); /* stop Visual mode */ - #endif #ifdef FEAT_QUICKFIX newwindow: #endif --- 178,184 ---- *************** *** 206,223 **** /* quit current window */ case Ctrl_Q: case 'q': - #ifdef FEAT_VISUAL reset_VIsual_and_resel(); /* stop Visual mode */ - #endif do_cmdline_cmd((char_u *)"quit"); break; /* close current window */ case Ctrl_C: case 'c': - #ifdef FEAT_VISUAL reset_VIsual_and_resel(); /* stop Visual mode */ - #endif do_cmdline_cmd((char_u *)"close"); break; --- 198,211 ---- *************** *** 226,234 **** case Ctrl_Z: case 'z': CHECK_CMDWIN - #ifdef FEAT_VISUAL reset_VIsual_and_resel(); /* stop Visual mode */ - #endif do_cmdline_cmd((char_u *)"pclose"); break; --- 214,220 ---- *************** *** 248,256 **** case Ctrl_O: case 'o': CHECK_CMDWIN - #ifdef FEAT_VISUAL reset_VIsual_and_resel(); /* stop Visual mode */ - #endif do_cmdline_cmd((char_u *)"only"); break; --- 234,240 ---- *************** *** 399,416 **** case Ctrl_R: case 'r': CHECK_CMDWIN - #ifdef FEAT_VISUAL reset_VIsual_and_resel(); /* stop Visual mode */ - #endif win_rotate(FALSE, (int)Prenum1); /* downwards */ break; /* rotate windows upwards */ case 'R': CHECK_CMDWIN - #ifdef FEAT_VISUAL reset_VIsual_and_resel(); /* stop Visual mode */ - #endif win_rotate(TRUE, (int)Prenum1); /* upwards */ break; --- 383,396 ---- *************** *** 499,507 **** case ']': case Ctrl_RSB: CHECK_CMDWIN - #ifdef FEAT_VISUAL reset_VIsual_and_resel(); /* stop Visual mode */ - #endif if (Prenum) postponed_split = Prenum; else --- 479,485 ---- *************** *** 612,620 **** #endif case ']': case Ctrl_RSB: - #ifdef FEAT_VISUAL reset_VIsual_and_resel(); /* stop Visual mode */ - #endif if (Prenum) postponed_split = Prenum; else --- 590,596 ---- *************** *** 3726,3734 **** { tabpage_T *tp = curtab; - #ifdef FEAT_VISUAL reset_VIsual_and_resel(); /* stop Visual mode */ - #endif #ifdef FEAT_AUTOCMD if (trigger_leave_autocmds) { --- 3702,3708 ---- *************** *** 4029,4040 **** return; #endif - #ifdef FEAT_VISUAL if (wp->w_buffer != curbuf) reset_VIsual_and_resel(); else if (VIsual_active) wp->w_cursor = curwin->w_cursor; - #endif #ifdef FEAT_GUI need_mouse_correct = TRUE; --- 4003,4012 ---- *************** *** 6037,6043 **** long count; linenr_T *file_lnum; { - # ifdef FEAT_VISUAL if (VIsual_active) { int len; --- 6009,6014 ---- *************** *** 6048,6054 **** return find_file_name_in_path(ptr, len, FNAME_MESS|FNAME_EXP|FNAME_REL, count, curbuf->b_ffname); } - # endif return file_name_at_cursor(FNAME_MESS|FNAME_HYP|FNAME_EXP|FNAME_REL, count, file_lnum); --- 6019,6024 ---- *** ../vim-7.4.211/src/feature.h 2014-03-12 17:56:42.960852421 +0100 --- src/feature.h 2014-03-23 13:39:02.003178407 +0100 *************** *** 214,220 **** * +visual Visual mode - now always included. * +visualextra Extra features for Visual mode (mostly block operators). */ - #define FEAT_VISUAL #ifdef FEAT_NORMAL # define FEAT_VISUALEXTRA #endif --- 214,219 ---- *************** *** 1138,1150 **** #ifdef FEAT_GUI # ifndef FEAT_CLIPBOARD # define FEAT_CLIPBOARD - # ifndef FEAT_VISUAL - # define FEAT_VISUAL - # endif # endif #endif ! #if defined(FEAT_NORMAL) && defined(FEAT_VISUAL) \ && (defined(UNIX) || defined(VMS)) \ && defined(WANT_X11) && defined(HAVE_X11) # define FEAT_XCLIPBOARD --- 1137,1146 ---- #ifdef FEAT_GUI # ifndef FEAT_CLIPBOARD # define FEAT_CLIPBOARD # endif #endif ! #if defined(FEAT_NORMAL) \ && (defined(UNIX) || defined(VMS)) \ && defined(WANT_X11) && defined(HAVE_X11) # define FEAT_XCLIPBOARD *** ../vim-7.4.211/src/globals.h 2014-02-22 23:03:48.712901208 +0100 --- src/globals.h 2014-03-23 13:39:17.407178643 +0100 *************** *** 662,668 **** /* set to TRUE when "-s" commandline argument * used for ex */ - #ifdef FEAT_VISUAL EXTERN pos_T VIsual; /* start position of active Visual selection */ EXTERN int VIsual_active INIT(= FALSE); /* whether Visual mode is active */ --- 662,667 ---- *************** *** 677,683 **** EXTERN int redo_VIsual_busy INIT(= FALSE); /* TRUE when redoing Visual */ - #endif #ifdef FEAT_MOUSE /* --- 676,681 ---- *************** *** 1178,1188 **** EXTERN int fill_diff INIT(= '-'); #endif - #ifdef FEAT_VISUAL /* Whether 'keymodel' contains "stopsel" and "startsel". */ EXTERN int km_stopsel INIT(= FALSE); EXTERN int km_startsel INIT(= FALSE); - #endif #ifdef FEAT_CMDWIN EXTERN int cedit_key INIT(= -1); /* key value of 'cedit' option */ --- 1176,1184 ---- *** ../vim-7.4.211/src/option.h 2014-03-12 18:55:52.104906804 +0100 --- src/option.h 2014-03-23 13:39:30.991178851 +0100 *************** *** 572,580 **** EXTERN char_u *p_isp; /* 'isprint' */ EXTERN int p_js; /* 'joinspaces' */ EXTERN char_u *p_kp; /* 'keywordprg' */ - #ifdef FEAT_VISUAL EXTERN char_u *p_km; /* 'keymodel' */ - #endif #ifdef FEAT_LANGMAP EXTERN char_u *p_langmap; /* 'langmap'*/ #endif --- 572,578 ---- *************** *** 681,690 **** #endif EXTERN char_u *p_sections; /* 'sections' */ EXTERN int p_secure; /* 'secure' */ - #ifdef FEAT_VISUAL EXTERN char_u *p_sel; /* 'selection' */ EXTERN char_u *p_slm; /* 'selectmode' */ - #endif #ifdef FEAT_SESSION EXTERN char_u *p_ssop; /* 'sessionoptions' */ EXTERN unsigned ssop_flags; --- 679,686 ---- *** ../vim-7.4.211/src/os_win32.h 2013-09-25 19:13:32.000000000 +0200 --- src/os_win32.h 2014-03-23 13:39:49.819179139 +0100 *************** *** 68,74 **** #endif #define USE_FNAME_CASE /* adjust case of file names */ ! #if !defined(FEAT_CLIPBOARD) && defined(FEAT_VISUAL) && defined(FEAT_MOUSE) # define FEAT_CLIPBOARD /* include clipboard support */ #endif #if defined(__DATE__) && defined(__TIME__) --- 68,74 ---- #endif #define USE_FNAME_CASE /* adjust case of file names */ ! #if !defined(FEAT_CLIPBOARD) && defined(FEAT_MOUSE) # define FEAT_CLIPBOARD /* include clipboard support */ #endif #if defined(__DATE__) && defined(__TIME__) *** ../vim-7.4.211/src/structs.h 2014-03-12 18:55:52.104906804 +0100 --- src/structs.h 2014-03-23 13:40:19.175179589 +0100 *************** *** 346,354 **** #endif int uh_flags; /* see below */ pos_T uh_namedm[NMARKS]; /* marks before undo/after redo */ - #ifdef FEAT_VISUAL visualinfo_T uh_visual; /* Visual areas before undo/after redo */ - #endif time_t uh_time; /* timestamp when the change was made */ long uh_save_nr; /* set when the file was saved after the changes in this block */ --- 346,352 ---- *************** *** 1406,1417 **** pos_T b_namedm[NMARKS]; /* current named marks (mark.c) */ - #ifdef FEAT_VISUAL /* These variables are set when VIsual_active becomes FALSE */ visualinfo_T b_visual; ! # ifdef FEAT_EVAL int b_visual_mode_eval; /* b_visual.vi_mode for visualmode() */ - # endif #endif pos_T b_last_cursor; /* cursor position when last unloading this --- 1404,1413 ---- pos_T b_namedm[NMARKS]; /* current named marks (mark.c) */ /* These variables are set when VIsual_active becomes FALSE */ visualinfo_T b_visual; ! #ifdef FEAT_EVAL int b_visual_mode_eval; /* b_visual.vi_mode for visualmode() */ #endif pos_T b_last_cursor; /* cursor position when last unloading this *************** *** 1980,1986 **** time through cursupdate() to the current virtual column */ - #ifdef FEAT_VISUAL /* * the next six are used to update the visual part */ --- 1976,1981 ---- *************** *** 1991,1997 **** linenr_T w_old_visual_lnum; /* last known start of visual part */ colnr_T w_old_visual_col; /* last known start of visual part */ colnr_T w_old_curswant; /* last known value of Curswant */ - #endif /* * "w_topline", "w_leftcol" and "w_skipcol" specify the offsets for --- 1986,1991 ---- *************** *** 2293,2302 **** (inclusive) */ int empty; /* op_start and op_end the same (only used by do_change()) */ - #ifdef FEAT_VISUAL int is_VIsual; /* operator on Visual area */ int block_mode; /* current operator is Visual block mode */ - #endif colnr_T start_vcol; /* start col for block mode operator */ colnr_T end_vcol; /* end col for block mode operator */ #ifdef FEAT_AUTOCMD --- 2287,2294 ---- *** ../vim-7.4.211/src/version.c 2014-03-22 13:29:57.693846167 +0100 --- src/version.c 2014-03-23 15:01:49.719254526 +0100 *************** *** 740,741 **** --- 736,739 ---- { /* Add new patch number below this line */ + /**/ + 212, /**/ -- If all you have is a hammer, everything looks like a nail. When your hammer is C++, everything begins to look like a thumb. -- Steve Hoflich, comp.lang.c++ /// Bram Moolenaar -- Bram@Moolenaar.net -- http://www.Moolenaar.net \\\ /// sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ \\\ \\\ an exciting new programming language -- http://www.Zimbu.org /// \\\ help me help AIDS victims -- http://ICCF-Holland.org ///