Mercurial > vim
annotate src/edit.c @ 32039:f08ee1b65dbf v9.0.1351
patch 9.0.1351: Dhall files are not recognized
Commit: https://github.com/vim/vim/commit/def5521752abefe12db8cc3111a3b205ad1ac929
Author: Amaan Qureshi <amaanq12@gmail.com>
Date: Fri Feb 24 16:01:54 2023 +0000
patch 9.0.1351: Dhall files are not recognized
Problem: Dhall files are not recognized.
Solution: Add patterns for Dhall files. (Amaan Qureshi, closes https://github.com/vim/vim/issues/12052)
author | Bram Moolenaar <Bram@vim.org> |
---|---|
date | Fri, 24 Feb 2023 17:15:05 +0100 |
parents | d21e867c517e |
children | 55926b4f2246 |
rev | line source |
---|---|
10042
4aead6a9b7a9
commit https://github.com/vim/vim/commit/edf3f97ae2af024708ebb4ac614227327033ca47
Christian Brabandt <cb@256bit.org>
parents:
9852
diff
changeset
|
1 /* vi:set ts=8 sts=4 sw=4 noet: |
7 | 2 * |
3 * VIM - Vi IMproved by Bram Moolenaar | |
4 * | |
5 * Do ":help uganda" in Vim to read copying and usage conditions. | |
6 * Do ":help credits" in Vim to see a list of people who contributed. | |
7 * See README.txt for an overview of the Vim source code. | |
8 */ | |
9 | |
10 /* | |
11 * edit.c: functions for Insert mode | |
12 */ | |
13 | |
14 #include "vim.h" | |
15 | |
16 #define BACKSPACE_CHAR 1 | |
17 #define BACKSPACE_WORD 2 | |
18 #define BACKSPACE_WORD_NOT_SPACE 3 | |
19 #define BACKSPACE_LINE 4 | |
20 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
21 // Set when doing something for completion that may call edit() recursively, |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
22 // which is not allowed. |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
23 static int compl_busy = FALSE; |
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
24 |
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
25 |
7799
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
26 static void ins_ctrl_v(void); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
27 static void insert_special(int, int, int); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
28 static void redo_literal(int c); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
29 static void start_arrow_common(pos_T *end_insert_pos, int change); |
744 | 30 #ifdef FEAT_SPELL |
7799
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
31 static void check_spell_redraw(void); |
221 | 32 #endif |
7799
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
33 static void stop_insert(pos_T *end_insert_pos, int esc, int nomove); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
34 static int echeck_abbr(int); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
35 static void mb_replace_pop_ins(int cc); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
36 static void replace_flush(void); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
37 static void replace_do_bs(int limit_col); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
38 static int del_char_after_col(int limit_col); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
39 static void ins_reg(void); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
40 static void ins_ctrl_g(void); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
41 static void ins_ctrl_hat(void); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
42 static int ins_esc(long *count, int cmdchar, int nomove); |
7 | 43 #ifdef FEAT_RIGHTLEFT |
7799
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
44 static void ins_ctrl_(void); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
45 #endif |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
46 static int ins_start_select(int c); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
47 static void ins_insert(int replaceState); |
32031
e9b8deedab60
patch 9.0.1347: "gr CTRL-O" stays in Insert mode
Bram Moolenaar <Bram@vim.org>
parents:
32009
diff
changeset
|
48 static void ins_ctrl_o(int cmdchar); |
7799
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
49 static void ins_shift(int c, int lastc); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
50 static void ins_del(void); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
51 static int ins_bs(int c, int mode, int *inserted_space_p); |
692 | 52 #if defined(FEAT_GUI_TABLINE) || defined(PROTO) |
7799
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
53 static void ins_tabline(int c); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
54 #endif |
16101
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
55 static void ins_left(void); |
7799
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
56 static void ins_home(int c); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
57 static void ins_end(int c); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
58 static void ins_s_left(void); |
16101
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
59 static void ins_right(void); |
7799
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
60 static void ins_s_right(void); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
61 static void ins_up(int startcol); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
62 static void ins_pageup(void); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
63 static void ins_down(int startcol); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
64 static void ins_pagedown(void); |
7 | 65 #ifdef FEAT_DND |
7799
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
66 static void ins_drop(void); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
67 #endif |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
68 static int ins_tab(void); |
7 | 69 #ifdef FEAT_DIGRAPHS |
7799
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
70 static int ins_digraph(void); |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
71 #endif |
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
72 static int ins_ctrl_ey(int tc); |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
73 #if defined(FEAT_EVAL) |
7799
af3c41a3c53f
commit https://github.com/vim/vim/commit/f28dbcea371b3a35727d91afc90fb90e0527d78a
Christian Brabandt <cb@256bit.org>
parents:
7141
diff
changeset
|
74 static char_u *do_insert_char_pre(int c); |
3390 | 75 #endif |
7 | 76 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
77 static colnr_T Insstart_textlen; // length of line when insert started |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
78 static colnr_T Insstart_blank_vcol; // vcol for first inserted blank |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
79 static int update_Insstart_orig = TRUE; // set Insstart_orig to Insstart |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
80 |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
81 static char_u *last_insert = NULL; // the text of the previous insert, |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
82 // K_SPECIAL and CSI are escaped |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
83 static int last_insert_skip; // nr of chars in front of previous insert |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
84 static int new_insert_skip; // nr of chars in front of current insert |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
85 static int did_restart_edit; // "restart_edit" when calling edit() |
7 | 86 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
87 static int can_cindent; // may do cindenting on this line |
7 | 88 |
89 #ifdef FEAT_RIGHTLEFT | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
90 static int revins_on; // reverse insert mode on |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
91 static int revins_chars; // how much to skip after edit |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
92 static int revins_legal; // was the last char 'legal'? |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
93 static int revins_scol; // start column of revins session |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
94 #endif |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
95 |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
96 static int ins_need_undo; // call u_save() before inserting a |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
97 // char. Set when edit() is called. |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
98 // after that arrow_used is used. |
7 | 99 |
16101
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
100 static int dont_sync_undo = FALSE; // CTRL-G U prevents syncing undo for |
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
101 // the next left/right cursor key |
7 | 102 |
103 /* | |
104 * edit(): Start inserting text. | |
105 * | |
106 * "cmdchar" can be: | |
107 * 'i' normal insert command | |
108 * 'a' normal append command | |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
109 * K_PS bracketed paste |
7 | 110 * 'R' replace command |
111 * 'r' "r<CR>" command: insert one <CR>. Note: count can be > 1, for redo, | |
112 * but still only one <CR> is inserted. The <Esc> is not used for redo. | |
113 * 'g' "gI" command. | |
114 * 'V' "gR" command for Virtual Replace mode. | |
115 * 'v' "gr" command for single character Virtual Replace mode. | |
116 * | |
117 * This function is not called recursively. For CTRL-O commands, it returns | |
118 * and lets the caller handle the Normal-mode command. | |
119 * | |
120 * Return TRUE if a CTRL-O command caused the return (insert mode pending). | |
121 */ | |
122 int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
123 edit( |
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
124 int cmdchar, |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
125 int startln, // if set, insert at start of line |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
126 long count) |
7 | 127 { |
128 int c = 0; | |
129 char_u *ptr; | |
8090
54cfe888c627
commit https://github.com/vim/vim/commit/418f81b5fa400ed59793384f2f3d9df45390f080
Christian Brabandt <cb@256bit.org>
parents:
8003
diff
changeset
|
130 int lastc = 0; |
1869 | 131 int mincol; |
7 | 132 static linenr_T o_lnum = 0; |
133 int i; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
134 int did_backspace = TRUE; // previous char was backspace |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
135 int line_is_white = FALSE; // line is empty before insert |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
136 linenr_T old_topline = 0; // topline before insertion |
7 | 137 #ifdef FEAT_DIFF |
138 int old_topfill = -1; | |
139 #endif | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
140 int inserted_space = FALSE; // just inserted a space |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
141 int replaceState = MODE_REPLACE; |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
142 int nomove = FALSE; // don't move cursor on return |
14019
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
143 #ifdef FEAT_JOB_CHANNEL |
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
144 int cmdchar_todo = cmdchar; |
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
145 #endif |
25074
aa55d6d17625
patch 8.2.3074: popup_atcursor() uses wrong position with concealing
Bram Moolenaar <Bram@vim.org>
parents:
23754
diff
changeset
|
146 #ifdef FEAT_CONCEAL |
aa55d6d17625
patch 8.2.3074: popup_atcursor() uses wrong position with concealing
Bram Moolenaar <Bram@vim.org>
parents:
23754
diff
changeset
|
147 int cursor_line_was_concealed; |
aa55d6d17625
patch 8.2.3074: popup_atcursor() uses wrong position with concealing
Bram Moolenaar <Bram@vim.org>
parents:
23754
diff
changeset
|
148 #endif |
7 | 149 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
150 // Remember whether editing was restarted after CTRL-O. |
603 | 151 did_restart_edit = restart_edit; |
152 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
153 // sleep before redrawing, needed for "CTRL-O :" that results in an |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
154 // error message |
7 | 155 check_for_delay(TRUE); |
156 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
157 // set Insstart_orig to Insstart |
5680 | 158 update_Insstart_orig = TRUE; |
159 | |
7 | 160 #ifdef HAVE_SANDBOX |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
161 // Don't allow inserting in the sandbox. |
7 | 162 if (sandbox != 0) |
163 { | |
25320
1e6da8364a02
patch 8.2.3197: error messages are spread out
Bram Moolenaar <Bram@vim.org>
parents:
25306
diff
changeset
|
164 emsg(_(e_not_allowed_in_sandbox)); |
7 | 165 return FALSE; |
166 } | |
167 #endif | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
168 // Don't allow changes in the buffer while editing the cmdline. The |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
169 // caller of getcmdline() may get confused. |
20118
252d2bb90394
patch 8.2.0614: get ml_get error when deleting a line in 'completefunc'
Bram Moolenaar <Bram@vim.org>
parents:
20069
diff
changeset
|
170 // Don't allow recursive insert mode when busy with completion. |
29014
45c182c4f7e9
patch 8.2.5029: "textlock" is always zero
Bram Moolenaar <Bram@vim.org>
parents:
28942
diff
changeset
|
171 if (textlock != 0 || ins_compl_active() || compl_busy || pum_visible()) |
632 | 172 { |
26883
7f150a4936f2
patch 8.2.3970: error messages are spread out
Bram Moolenaar <Bram@vim.org>
parents:
26813
diff
changeset
|
173 emsg(_(e_not_allowed_to_change_text_or_change_window)); |
844 | 174 return FALSE; |
175 } | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
176 ins_compl_clear(); // clear stuff for CTRL-X mode |
7 | 177 |
11 | 178 /* |
179 * Trigger InsertEnter autocommands. Do not do this for "r<CR>" or "grx". | |
180 */ | |
181 if (cmdchar != 'r' && cmdchar != 'v') | |
182 { | |
4027 | 183 pos_T save_cursor = curwin->w_cursor; |
184 | |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
185 #ifdef FEAT_EVAL |
11 | 186 if (cmdchar == 'R') |
187 ptr = (char_u *)"r"; | |
188 else if (cmdchar == 'V') | |
189 ptr = (char_u *)"v"; | |
190 else | |
191 ptr = (char_u *)"i"; | |
192 set_vim_var_string(VV_INSERTMODE, ptr, 1); | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
193 set_vim_var_string(VV_CHAR, NULL, -1); // clear v:char |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
194 #endif |
14485
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
195 ins_apply_autocmds(EVENT_INSERTENTER); |
4027 | 196 |
23754
c425989fe7ac
patch 8.2.2418: color not changed if ModeMsg highlight is set in InsertEnter
Bram Moolenaar <Bram@vim.org>
parents:
23664
diff
changeset
|
197 // Check for changed highlighting, e.g. for ModeMsg. |
c425989fe7ac
patch 8.2.2418: color not changed if ModeMsg highlight is set in InsertEnter
Bram Moolenaar <Bram@vim.org>
parents:
23664
diff
changeset
|
198 if (need_highlight_changed) |
c425989fe7ac
patch 8.2.2418: color not changed if ModeMsg highlight is set in InsertEnter
Bram Moolenaar <Bram@vim.org>
parents:
23664
diff
changeset
|
199 highlight_changed(); |
c425989fe7ac
patch 8.2.2418: color not changed if ModeMsg highlight is set in InsertEnter
Bram Moolenaar <Bram@vim.org>
parents:
23664
diff
changeset
|
200 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
201 // Make sure the cursor didn't move. Do call check_cursor_col() in |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
202 // case the text was modified. Since Insert mode was not started yet |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
203 // a call to check_cursor_col() may move the cursor, especially with |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
204 // the "A" command, thus set State to avoid that. Also check that the |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
205 // line number is still valid (lines may have been deleted). |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
206 // Do not restore if v:char was set to a non-empty string. |
11121
778c10516955
patch 8.0.0448: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents:
11105
diff
changeset
|
207 if (!EQUAL_POS(curwin->w_cursor, save_cursor) |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
208 #ifdef FEAT_EVAL |
4448 | 209 && *get_vim_var_str(VV_CHAR) == NUL |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
210 #endif |
4448 | 211 && save_cursor.lnum <= curbuf->b_ml.ml_line_count) |
4027 | 212 { |
213 int save_state = State; | |
214 | |
215 curwin->w_cursor = save_cursor; | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
216 State = MODE_INSERT; |
4027 | 217 check_cursor_col(); |
218 State = save_state; | |
219 } | |
11 | 220 } |
221 | |
2378
85b7dc8da5eb
Add the 'concealcursor' option to decide when the cursor line is to be
Bram Moolenaar <bram@vim.org>
parents:
2348
diff
changeset
|
222 #ifdef FEAT_CONCEAL |
25074
aa55d6d17625
patch 8.2.3074: popup_atcursor() uses wrong position with concealing
Bram Moolenaar <Bram@vim.org>
parents:
23754
diff
changeset
|
223 // Check if the cursor line was concealed before changing State. |
aa55d6d17625
patch 8.2.3074: popup_atcursor() uses wrong position with concealing
Bram Moolenaar <Bram@vim.org>
parents:
23754
diff
changeset
|
224 cursor_line_was_concealed = curwin->w_p_cole > 0 |
aa55d6d17625
patch 8.2.3074: popup_atcursor() uses wrong position with concealing
Bram Moolenaar <Bram@vim.org>
parents:
23754
diff
changeset
|
225 && conceal_cursor_line(curwin); |
2378
85b7dc8da5eb
Add the 'concealcursor' option to decide when the cursor line is to be
Bram Moolenaar <bram@vim.org>
parents:
2348
diff
changeset
|
226 #endif |
85b7dc8da5eb
Add the 'concealcursor' option to decide when the cursor line is to be
Bram Moolenaar <bram@vim.org>
parents:
2348
diff
changeset
|
227 |
7 | 228 /* |
229 * When doing a paste with the middle mouse button, Insstart is set to | |
230 * where the paste started. | |
231 */ | |
232 if (where_paste_started.lnum != 0) | |
233 Insstart = where_paste_started; | |
234 else | |
235 { | |
236 Insstart = curwin->w_cursor; | |
237 if (startln) | |
238 Insstart.col = 0; | |
239 } | |
30833
e3d5781c7ec6
patch 9.0.0751: 'scrolloff' does not work well with 'smoothscroll'
Bram Moolenaar <Bram@vim.org>
parents:
30825
diff
changeset
|
240 Insstart_textlen = (colnr_T)linetabsize_str(ml_get_curline()); |
7 | 241 Insstart_blank_vcol = MAXCOL; |
242 if (!did_ai) | |
243 ai_col = 0; | |
244 | |
245 if (cmdchar != NUL && restart_edit == 0) | |
246 { | |
247 ResetRedobuff(); | |
248 AppendNumberToRedobuff(count); | |
249 if (cmdchar == 'V' || cmdchar == 'v') | |
250 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
251 // "gR" or "gr" command |
7 | 252 AppendCharToRedobuff('g'); |
253 AppendCharToRedobuff((cmdchar == 'v') ? 'r' : 'R'); | |
254 } | |
255 else | |
256 { | |
10682
d564e73ff9ee
patch 8.0.0231: bracketed paste mode is not tested
Christian Brabandt <cb@256bit.org>
parents:
10680
diff
changeset
|
257 if (cmdchar == K_PS) |
d564e73ff9ee
patch 8.0.0231: bracketed paste mode is not tested
Christian Brabandt <cb@256bit.org>
parents:
10680
diff
changeset
|
258 AppendCharToRedobuff('a'); |
d564e73ff9ee
patch 8.0.0231: bracketed paste mode is not tested
Christian Brabandt <cb@256bit.org>
parents:
10680
diff
changeset
|
259 else |
d564e73ff9ee
patch 8.0.0231: bracketed paste mode is not tested
Christian Brabandt <cb@256bit.org>
parents:
10680
diff
changeset
|
260 AppendCharToRedobuff(cmdchar); |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
261 if (cmdchar == 'g') // "gI" command |
7 | 262 AppendCharToRedobuff('I'); |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
263 else if (cmdchar == 'r') // "r<CR>" command |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
264 count = 1; // insert only one <CR> |
7 | 265 } |
266 } | |
267 | |
268 if (cmdchar == 'R') | |
269 { | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
270 State = MODE_REPLACE; |
7 | 271 } |
272 else if (cmdchar == 'V' || cmdchar == 'v') | |
273 { | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
274 State = MODE_VREPLACE; |
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
275 replaceState = MODE_VREPLACE; |
7 | 276 orig_line_count = curbuf->b_ml.ml_line_count; |
277 vr_lines_changed = 1; | |
278 } | |
279 else | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
280 State = MODE_INSERT; |
7 | 281 |
28397
d1702731786c
patch 8.2.4723: the ModeChanged autocmd event is inefficient
Bram Moolenaar <Bram@vim.org>
parents:
28375
diff
changeset
|
282 may_trigger_modechanged(); |
7 | 283 stop_insert_mode = FALSE; |
284 | |
25074
aa55d6d17625
patch 8.2.3074: popup_atcursor() uses wrong position with concealing
Bram Moolenaar <Bram@vim.org>
parents:
23754
diff
changeset
|
285 #ifdef FEAT_CONCEAL |
aa55d6d17625
patch 8.2.3074: popup_atcursor() uses wrong position with concealing
Bram Moolenaar <Bram@vim.org>
parents:
23754
diff
changeset
|
286 // Check if the cursor line needs redrawing after changing State. If |
aa55d6d17625
patch 8.2.3074: popup_atcursor() uses wrong position with concealing
Bram Moolenaar <Bram@vim.org>
parents:
23754
diff
changeset
|
287 // 'concealcursor' is "n" it needs to be redrawn without concealing. |
aa55d6d17625
patch 8.2.3074: popup_atcursor() uses wrong position with concealing
Bram Moolenaar <Bram@vim.org>
parents:
23754
diff
changeset
|
288 conceal_check_cursor_line(cursor_line_was_concealed); |
aa55d6d17625
patch 8.2.3074: popup_atcursor() uses wrong position with concealing
Bram Moolenaar <Bram@vim.org>
parents:
23754
diff
changeset
|
289 #endif |
aa55d6d17625
patch 8.2.3074: popup_atcursor() uses wrong position with concealing
Bram Moolenaar <Bram@vim.org>
parents:
23754
diff
changeset
|
290 |
29579
f7a64755dbe9
patch 9.0.0130: cursor position wrong when inserting around virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29566
diff
changeset
|
291 // Need to position cursor again when on a TAB and when on a char with |
f7a64755dbe9
patch 9.0.0130: cursor position wrong when inserting around virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29566
diff
changeset
|
292 // virtual text. |
f7a64755dbe9
patch 9.0.0130: cursor position wrong when inserting around virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29566
diff
changeset
|
293 if (gchar_cursor() == TAB |
f7a64755dbe9
patch 9.0.0130: cursor position wrong when inserting around virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29566
diff
changeset
|
294 #ifdef FEAT_PROP_POPUP |
f7a64755dbe9
patch 9.0.0130: cursor position wrong when inserting around virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29566
diff
changeset
|
295 || curbuf->b_has_textprop |
f7a64755dbe9
patch 9.0.0130: cursor position wrong when inserting around virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29566
diff
changeset
|
296 #endif |
f7a64755dbe9
patch 9.0.0130: cursor position wrong when inserting around virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29566
diff
changeset
|
297 ) |
28363
a9a56b567709
patch 8.2.4707: redrawing could be a bit more efficient
Bram Moolenaar <Bram@vim.org>
parents:
28269
diff
changeset
|
298 curwin->w_valid &= ~(VALID_WROW|VALID_WCOL|VALID_VIRTCOL); |
7 | 299 |
300 /* | |
301 * Enable langmap or IME, indicated by 'iminsert'. | |
302 * Note that IME may enabled/disabled without us noticing here, thus the | |
303 * 'iminsert' value may not reflect what is actually used. It is updated | |
304 * when hitting <Esc>. | |
305 */ | |
306 if (curbuf->b_p_iminsert == B_IMODE_LMAP) | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
307 State |= MODE_LANGMAP; |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
308 #ifdef HAVE_INPUT_METHOD |
7 | 309 im_set_active(curbuf->b_p_iminsert == B_IMODE_IM); |
310 #endif | |
311 | |
312 setmouse(); | |
313 clear_showcmd(); | |
314 #ifdef FEAT_RIGHTLEFT | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
315 // there is no reverse replace mode |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
316 revins_on = (State == MODE_INSERT && p_ri); |
7 | 317 if (revins_on) |
318 undisplay_dollar(); | |
319 revins_chars = 0; | |
320 revins_legal = 0; | |
321 revins_scol = -1; | |
322 #endif | |
10684
83a36d655a74
patch 8.0.0232: paste does not work when 'esckeys' is off
Christian Brabandt <cb@256bit.org>
parents:
10682
diff
changeset
|
323 if (!p_ek) |
18534
7dd83b5325e9
patch 8.1.2261: with modifyOtherKeys set 'noesckeys' doesn't work
Bram Moolenaar <Bram@vim.org>
parents:
18354
diff
changeset
|
324 { |
29069
be6c32395444
patch 8.2.5056: the channel log only contains some of the raw terminal output
Bram Moolenaar <Bram@vim.org>
parents:
29014
diff
changeset
|
325 MAY_WANT_TO_LOG_THIS; |
be6c32395444
patch 8.2.5056: the channel log only contains some of the raw terminal output
Bram Moolenaar <Bram@vim.org>
parents:
29014
diff
changeset
|
326 |
18534
7dd83b5325e9
patch 8.1.2261: with modifyOtherKeys set 'noesckeys' doesn't work
Bram Moolenaar <Bram@vim.org>
parents:
18354
diff
changeset
|
327 // Disable bracketed paste mode, we won't recognize the escape |
7dd83b5325e9
patch 8.1.2261: with modifyOtherKeys set 'noesckeys' doesn't work
Bram Moolenaar <Bram@vim.org>
parents:
18354
diff
changeset
|
328 // sequences. |
10684
83a36d655a74
patch 8.0.0232: paste does not work when 'esckeys' is off
Christian Brabandt <cb@256bit.org>
parents:
10682
diff
changeset
|
329 out_str(T_BD); |
7 | 330 |
18534
7dd83b5325e9
patch 8.1.2261: with modifyOtherKeys set 'noesckeys' doesn't work
Bram Moolenaar <Bram@vim.org>
parents:
18354
diff
changeset
|
331 // Disable modifyOtherKeys, keys with modifiers would cause exiting |
7dd83b5325e9
patch 8.1.2261: with modifyOtherKeys set 'noesckeys' doesn't work
Bram Moolenaar <Bram@vim.org>
parents:
18354
diff
changeset
|
332 // Insert mode. |
31192
dcde141f2d1e
patch 9.0.0930: cannot debug the Kitty keyboard protocol with TermDebug
Bram Moolenaar <Bram@vim.org>
parents:
31166
diff
changeset
|
333 out_str_t_TE(); |
18534
7dd83b5325e9
patch 8.1.2261: with modifyOtherKeys set 'noesckeys' doesn't work
Bram Moolenaar <Bram@vim.org>
parents:
18354
diff
changeset
|
334 } |
7dd83b5325e9
patch 8.1.2261: with modifyOtherKeys set 'noesckeys' doesn't work
Bram Moolenaar <Bram@vim.org>
parents:
18354
diff
changeset
|
335 |
7 | 336 /* |
337 * Handle restarting Insert mode. | |
11073
d2178a6cc9f3
patch 8.0.0425: build errors when building without folding
Christian Brabandt <cb@256bit.org>
parents:
11002
diff
changeset
|
338 * Don't do this for "CTRL-O ." (repeat an insert): In that case we get |
d2178a6cc9f3
patch 8.0.0425: build errors when building without folding
Christian Brabandt <cb@256bit.org>
parents:
11002
diff
changeset
|
339 * here with something in the stuff buffer. |
7 | 340 */ |
341 if (restart_edit != 0 && stuff_empty()) | |
342 { | |
343 /* | |
344 * After a paste we consider text typed to be part of the insert for | |
345 * the pasted text. You can backspace over the pasted text too. | |
346 */ | |
347 if (where_paste_started.lnum) | |
348 arrow_used = FALSE; | |
349 else | |
350 arrow_used = TRUE; | |
351 restart_edit = 0; | |
352 | |
353 /* | |
354 * If the cursor was after the end-of-line before the CTRL-O and it is | |
355 * now at the end-of-line, put it after the end-of-line (this is not | |
356 * correct in very rare cases). | |
357 * Also do this if curswant is greater than the current virtual | |
358 * column. Eg after "^O$" or "^O80|". | |
359 */ | |
360 validate_virtcol(); | |
361 update_curswant(); | |
230 | 362 if (((ins_at_eol && curwin->w_cursor.lnum == o_lnum) |
7 | 363 || curwin->w_curswant > curwin->w_virtcol) |
364 && *(ptr = ml_get_curline() + curwin->w_cursor.col) != NUL) | |
365 { | |
366 if (ptr[1] == NUL) | |
367 ++curwin->w_cursor.col; | |
368 else if (has_mbyte) | |
369 { | |
474 | 370 i = (*mb_ptr2len)(ptr); |
7 | 371 if (ptr[i] == NUL) |
372 curwin->w_cursor.col += i; | |
373 } | |
374 } | |
230 | 375 ins_at_eol = FALSE; |
7 | 376 } |
377 else | |
378 arrow_used = FALSE; | |
379 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
380 // we are in insert mode now, don't need to start it anymore |
7 | 381 need_start_insertmode = FALSE; |
382 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
383 // Need to save the line for undo before inserting the first char. |
7 | 384 ins_need_undo = TRUE; |
385 | |
386 where_paste_started.lnum = 0; | |
387 can_cindent = TRUE; | |
388 #ifdef FEAT_FOLDING | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
389 // The cursor line is not in a closed fold, unless 'insertmode' is set or |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
390 // restarting. |
7 | 391 if (!p_im && did_restart_edit == 0) |
392 foldOpenCursor(); | |
393 #endif | |
394 | |
395 /* | |
396 * If 'showmode' is set, show the current (insert/replace/..) mode. | |
397 * A warning message for changing a readonly file is given here, before | |
398 * actually changing anything. It's put after the mode, if any. | |
399 */ | |
400 i = 0; | |
644 | 401 if (p_smd && msg_silent == 0) |
7 | 402 i = showmode(); |
403 | |
404 if (!p_im && did_restart_edit == 0) | |
1473 | 405 change_warning(i == 0 ? 0 : i + 1); |
7 | 406 |
407 #ifdef CURSOR_SHAPE | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
408 ui_cursor_shape(); // may show different cursor shape |
7 | 409 #endif |
410 #ifdef FEAT_DIGRAPHS | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
411 do_digraph(-1); // clear digraphs |
7 | 412 #endif |
413 | |
603 | 414 /* |
415 * Get the current length of the redo buffer, those characters have to be | |
416 * skipped if we want to get to the inserted characters. | |
417 */ | |
7 | 418 ptr = get_inserted(); |
419 if (ptr == NULL) | |
420 new_insert_skip = 0; | |
421 else | |
422 { | |
423 new_insert_skip = (int)STRLEN(ptr); | |
424 vim_free(ptr); | |
425 } | |
426 | |
427 old_indent = 0; | |
428 | |
429 /* | |
430 * Main loop in Insert mode: repeat until Insert mode is left. | |
431 */ | |
32031
e9b8deedab60
patch 9.0.1347: "gr CTRL-O" stays in Insert mode
Bram Moolenaar <Bram@vim.org>
parents:
32009
diff
changeset
|
432 int did_loop = FALSE; |
e9b8deedab60
patch 9.0.1347: "gr CTRL-O" stays in Insert mode
Bram Moolenaar <Bram@vim.org>
parents:
32009
diff
changeset
|
433 for (;; did_loop = TRUE) |
7 | 434 { |
435 #ifdef FEAT_RIGHTLEFT | |
436 if (!revins_legal) | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
437 revins_scol = -1; // reset on illegal motions |
7 | 438 else |
439 revins_legal = 0; | |
440 #endif | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
441 if (arrow_used) // don't repeat insert when arrow key used |
7 | 442 count = 0; |
443 | |
5680 | 444 if (update_Insstart_orig) |
445 Insstart_orig = Insstart; | |
446 | |
28682
c1591fa6f81a
patch 8.2.4865: :startinsert right after :stopinsert may not work
Bram Moolenaar <Bram@vim.org>
parents:
28644
diff
changeset
|
447 if (stop_insert_mode && !ins_compl_active()) |
7 | 448 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
449 // ":stopinsert" used or 'insertmode' reset |
7 | 450 count = 0; |
451 goto doESCkey; | |
452 } | |
453 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
454 // set curwin->w_curswant for next K_DOWN or K_UP |
7 | 455 if (!arrow_used) |
456 curwin->w_set_curswant = TRUE; | |
457 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
458 // If there is no typeahead may check for timestamps (e.g., for when a |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
459 // menu invoked a shell command). |
7 | 460 if (stuff_empty()) |
461 { | |
462 did_check_timestamps = FALSE; | |
463 if (need_check_timestamps) | |
464 check_timestamps(FALSE); | |
465 } | |
466 | |
467 /* | |
468 * When emsg() was called msg_scroll will have been set. | |
469 */ | |
470 msg_scroll = FALSE; | |
471 | |
472 #ifdef FEAT_GUI | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
473 // When 'mousefocus' is set a mouse movement may have taken us to |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
474 // another window. "need_mouse_correct" may then be set because of an |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
475 // autocommand. |
7 | 476 if (need_mouse_correct) |
477 gui_mouse_correct(); | |
478 #endif | |
479 | |
480 #ifdef FEAT_FOLDING | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
481 // Open fold at the cursor line, according to 'foldopen'. |
7 | 482 if (fdo_flags & FDO_INSERT) |
483 foldOpenCursor(); | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
484 // Close folds where the cursor isn't, according to 'foldclose' |
7 | 485 if (!char_avail()) |
486 foldCheckClose(); | |
487 #endif | |
488 | |
14019
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
489 #ifdef FEAT_JOB_CHANNEL |
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
490 if (bt_prompt(curbuf)) |
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
491 { |
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
492 init_prompt(cmdchar_todo); |
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
493 cmdchar_todo = NUL; |
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
494 } |
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
495 #endif |
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
496 |
7 | 497 /* |
498 * If we inserted a character at the last position of the last line in | |
499 * the window, scroll the window one line up. This avoids an extra | |
500 * redraw. | |
501 * This is detected when the cursor column is smaller after inserting | |
502 * something. | |
503 * Don't do this when the topline changed already, it has | |
504 * already been adjusted (by insertchar() calling open_line())). | |
505 */ | |
506 if (curbuf->b_mod_set | |
507 && curwin->w_p_wrap | |
508 && !did_backspace | |
509 && curwin->w_topline == old_topline | |
510 #ifdef FEAT_DIFF | |
511 && curwin->w_topfill == old_topfill | |
512 #endif | |
513 ) | |
514 { | |
515 mincol = curwin->w_wcol; | |
516 validate_cursor_col(); | |
517 | |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
518 if ( |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
519 #ifdef FEAT_VARTABS |
27426
41e0dcf38521
patch 8.2.4241: some type casts are redundant
Bram Moolenaar <Bram@vim.org>
parents:
27380
diff
changeset
|
520 curwin->w_wcol < mincol - tabstop_at( |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
521 get_nolist_virtcol(), curbuf->b_p_ts, |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
522 curbuf->b_p_vts_array) |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
523 #else |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
524 (int)curwin->w_wcol < mincol - curbuf->b_p_ts |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
525 #endif |
7 | 526 && curwin->w_wrow == W_WINROW(curwin) |
15713
ad8b2c109b22
patch 8.1.0864: cannot have a local value for 'scrolloff' and 'sidescrolloff'
Bram Moolenaar <Bram@vim.org>
parents:
15705
diff
changeset
|
527 + curwin->w_height - 1 - get_scrolloff_value() |
7 | 528 && (curwin->w_cursor.lnum != curwin->w_topline |
529 #ifdef FEAT_DIFF | |
530 || curwin->w_topfill > 0 | |
531 #endif | |
532 )) | |
533 { | |
534 #ifdef FEAT_DIFF | |
535 if (curwin->w_topfill > 0) | |
536 --curwin->w_topfill; | |
537 else | |
538 #endif | |
539 #ifdef FEAT_FOLDING | |
540 if (hasFolding(curwin->w_topline, NULL, &old_topline)) | |
541 set_topline(curwin, old_topline + 1); | |
542 else | |
543 #endif | |
544 set_topline(curwin, curwin->w_topline + 1); | |
545 } | |
546 } | |
547 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
548 // May need to adjust w_topline to show the cursor. |
7 | 549 update_topline(); |
550 | |
551 did_backspace = FALSE; | |
552 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
553 validate_cursor(); // may set must_redraw |
7 | 554 |
555 /* | |
556 * Redraw the display when no characters are waiting. | |
557 * Also shows mode, ruler and positions cursor. | |
558 */ | |
661 | 559 ins_redraw(TRUE); |
7 | 560 |
561 if (curwin->w_p_scb) | |
562 do_check_scrollbind(TRUE); | |
13384
6740c499de13
patch 8.0.1566: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13380
diff
changeset
|
563 |
2250
1bac28a53fae
Add the conceal patch from Vince Negri.
Bram Moolenaar <bram@vim.org>
parents:
2227
diff
changeset
|
564 if (curwin->w_p_crb) |
1bac28a53fae
Add the conceal patch from Vince Negri.
Bram Moolenaar <bram@vim.org>
parents:
2227
diff
changeset
|
565 do_check_cursorbind(); |
7 | 566 update_curswant(); |
567 old_topline = curwin->w_topline; | |
568 #ifdef FEAT_DIFF | |
569 old_topfill = curwin->w_topfill; | |
570 #endif | |
571 | |
572 #ifdef USE_ON_FLY_SCROLL | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
573 dont_scroll = FALSE; // allow scrolling here |
7 | 574 #endif |
31293
ff4473b3fc58
patch 9.0.0980: the keyboard state response may end up in a shell command
Bram Moolenaar <Bram@vim.org>
parents:
31192
diff
changeset
|
575 // May request the keyboard protocol state now. |
ff4473b3fc58
patch 9.0.0980: the keyboard state response may end up in a shell command
Bram Moolenaar <Bram@vim.org>
parents:
31192
diff
changeset
|
576 may_send_t_RK(); |
7 | 577 |
578 /* | |
12960
004bc78c88e6
patch 8.0.1356: using simalt in a GUIEnter autocommand inserts characters
Christian Brabandt <cb@256bit.org>
parents:
12924
diff
changeset
|
579 * Get a character for Insert mode. Ignore K_IGNORE and K_NOP. |
7 | 580 */ |
6673 | 581 if (c != K_CURSORHOLD) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
582 lastc = c; // remember the previous char for CTRL-D |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
583 |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
584 // After using CTRL-G U the next cursor key will not break undo. |
7074
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
585 if (dont_sync_undo == MAYBE) |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
586 dont_sync_undo = TRUE; |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
587 else |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
588 dont_sync_undo = FALSE; |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
589 if (cmdchar == K_PS) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
590 // Got here from normal mode when bracketed paste started. |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
591 c = K_PS; |
32035
d21e867c517e
patch 9.0.1349: "gr" with a count fails
Bram Moolenaar <Bram@vim.org>
parents:
32031
diff
changeset
|
592 else if (cmdchar == 'v' && did_loop && count <= 0) |
32031
e9b8deedab60
patch 9.0.1347: "gr CTRL-O" stays in Insert mode
Bram Moolenaar <Bram@vim.org>
parents:
32009
diff
changeset
|
593 c = ESC; // in case the stuffed Esc was consumed already |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
594 else |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
595 do |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
596 { |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
597 c = safe_vgetc(); |
14035
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
598 |
26598
b3ac5a4dc158
patch 8.2.3828: when opening a terminal from a timer first typed char is lost
Bram Moolenaar <Bram@vim.org>
parents:
26516
diff
changeset
|
599 if (stop_insert_mode |
b3ac5a4dc158
patch 8.2.3828: when opening a terminal from a timer first typed char is lost
Bram Moolenaar <Bram@vim.org>
parents:
26516
diff
changeset
|
600 #ifdef FEAT_TERMINAL |
b3ac5a4dc158
patch 8.2.3828: when opening a terminal from a timer first typed char is lost
Bram Moolenaar <Bram@vim.org>
parents:
26516
diff
changeset
|
601 || (c == K_IGNORE && term_use_loop()) |
b3ac5a4dc158
patch 8.2.3828: when opening a terminal from a timer first typed char is lost
Bram Moolenaar <Bram@vim.org>
parents:
26516
diff
changeset
|
602 #endif |
b3ac5a4dc158
patch 8.2.3828: when opening a terminal from a timer first typed char is lost
Bram Moolenaar <Bram@vim.org>
parents:
26516
diff
changeset
|
603 ) |
14035
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
604 { |
26598
b3ac5a4dc158
patch 8.2.3828: when opening a terminal from a timer first typed char is lost
Bram Moolenaar <Bram@vim.org>
parents:
26516
diff
changeset
|
605 // Insert mode ended, possibly from a callback, or a timer |
b3ac5a4dc158
patch 8.2.3828: when opening a terminal from a timer first typed char is lost
Bram Moolenaar <Bram@vim.org>
parents:
26516
diff
changeset
|
606 // must have opened a terminal window. |
22427
58cdc5d7f143
patch 8.2.1762: when a timer uses :stopinsert completion isn't stopped
Bram Moolenaar <Bram@vim.org>
parents:
22176
diff
changeset
|
607 if (c != K_IGNORE && c != K_NOP) |
58cdc5d7f143
patch 8.2.1762: when a timer uses :stopinsert completion isn't stopped
Bram Moolenaar <Bram@vim.org>
parents:
22176
diff
changeset
|
608 vungetc(c); |
14035
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
609 count = 0; |
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
610 nomove = TRUE; |
22427
58cdc5d7f143
patch 8.2.1762: when a timer uses :stopinsert completion isn't stopped
Bram Moolenaar <Bram@vim.org>
parents:
22176
diff
changeset
|
611 ins_compl_prep(ESC); |
14035
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
612 goto doESCkey; |
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
613 } |
12960
004bc78c88e6
patch 8.0.1356: using simalt in a GUIEnter autocommand inserts characters
Christian Brabandt <cb@256bit.org>
parents:
12924
diff
changeset
|
614 } while (c == K_IGNORE || c == K_NOP); |
7 | 615 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
616 // Don't want K_CURSORHOLD for the second key, e.g., after CTRL-V. |
978 | 617 did_cursorhold = TRUE; |
618 | |
7 | 619 #ifdef FEAT_RIGHTLEFT |
620 if (p_hkmap && KeyTyped) | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
621 c = hkmap(c); // Hebrew mode mapping |
7 | 622 #endif |
623 | |
26468
2fc13817b100
patch 8.2.3764: cannot see any text when window was made zero lines
Bram Moolenaar <Bram@vim.org>
parents:
25967
diff
changeset
|
624 // If the window was made so small that nothing shows, make it at least |
2fc13817b100
patch 8.2.3764: cannot see any text when window was made zero lines
Bram Moolenaar <Bram@vim.org>
parents:
25967
diff
changeset
|
625 // one line and one column when typing. |
2fc13817b100
patch 8.2.3764: cannot see any text when window was made zero lines
Bram Moolenaar <Bram@vim.org>
parents:
25967
diff
changeset
|
626 if (KeyTyped && !KeyStuffed) |
2fc13817b100
patch 8.2.3764: cannot see any text when window was made zero lines
Bram Moolenaar <Bram@vim.org>
parents:
25967
diff
changeset
|
627 win_ensure_size(); |
2fc13817b100
patch 8.2.3764: cannot see any text when window was made zero lines
Bram Moolenaar <Bram@vim.org>
parents:
25967
diff
changeset
|
628 |
659 | 629 /* |
630 * Special handling of keys while the popup menu is visible or wanted | |
897 | 631 * and the cursor is still in the completed word. Only when there is |
632 * a match, skip this when no matches were found. | |
659 | 633 */ |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
634 if (ins_compl_active() |
897 | 635 && pum_wanted() |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
636 && curwin->w_cursor.col >= ins_compl_col() |
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
637 && ins_compl_has_shown_match()) |
659 | 638 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
639 // BS: Delete one character from "compl_leader". |
659 | 640 if ((c == K_BS || c == Ctrl_H) |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
641 && curwin->w_cursor.col > ins_compl_col() |
836 | 642 && (c = ins_compl_bs()) == NUL) |
657 | 643 continue; |
644 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
645 // When no match was selected or it was edited. |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
646 if (!ins_compl_used_match()) |
657 | 647 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
648 // CTRL-L: Add one character from the current match to |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
649 // "compl_leader". Except when at the original match and |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
650 // there is nothing to add, CTRL-L works like CTRL-P then. |
836 | 651 if (c == Ctrl_L |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
652 && (!ctrl_x_mode_line_or_eval() |
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
653 || ins_compl_long_shown_match())) |
659 | 654 { |
655 ins_compl_addfrommatch(); | |
656 continue; | |
657 } | |
658 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
659 // A non-white character that fits in with the current |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
660 // completion: Add to "compl_leader". |
1430 | 661 if (ins_compl_accept_char(c)) |
659 | 662 { |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
663 #if defined(FEAT_EVAL) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
664 // Trigger InsertCharPre. |
3390 | 665 char_u *str = do_insert_char_pre(c); |
666 char_u *p; | |
667 | |
668 if (str != NULL) | |
669 { | |
11127
506f5d8b7d8b
patch 8.0.0451: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents:
11121
diff
changeset
|
670 for (p = str; *p != NUL; MB_PTR_ADV(p)) |
3390 | 671 ins_compl_addleader(PTR2CHAR(p)); |
672 vim_free(str); | |
673 } | |
674 else | |
675 #endif | |
676 ins_compl_addleader(c); | |
659 | 677 continue; |
678 } | |
665 | 679 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
680 // Pressing CTRL-Y selects the current match. When |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
681 // ins_compl_enter_selects() is set the Enter key does the |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
682 // same. |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
683 if ((c == Ctrl_Y || (ins_compl_enter_selects() |
10291
d9bd03a0d70f
commit https://github.com/vim/vim/commit/cbd3bd6cbed5baf418b037b17ad46e339ff59174
Christian Brabandt <cb@256bit.org>
parents:
10289
diff
changeset
|
684 && (c == CAR || c == K_KENTER || c == NL))) |
d9bd03a0d70f
commit https://github.com/vim/vim/commit/cbd3bd6cbed5baf418b037b17ad46e339ff59174
Christian Brabandt <cb@256bit.org>
parents:
10289
diff
changeset
|
685 && stop_arrow() == OK) |
665 | 686 { |
687 ins_compl_delete(); | |
10277
154d5a2e7395
commit https://github.com/vim/vim/commit/472e85970ee3a80abd824bef510df12e9cfe9e96
Christian Brabandt <cb@256bit.org>
parents:
10120
diff
changeset
|
688 ins_compl_insert(FALSE); |
665 | 689 } |
657 | 690 } |
691 } | |
692 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
693 // Prepare for or stop CTRL-X mode. This doesn't do completion, but |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
694 // it does fix up the text when finishing completion. |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
695 ins_compl_init_get_longest(); |
1526 | 696 if (ins_compl_prep(c)) |
657 | 697 continue; |
7 | 698 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
699 // CTRL-\ CTRL-N goes to Normal mode, |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
700 // CTRL-\ CTRL-G goes to mode selected with 'insertmode', |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
701 // CTRL-\ CTRL-O is like CTRL-O but without moving the cursor. |
7 | 702 if (c == Ctrl_BSL) |
703 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
704 // may need to redraw when no more chars available now |
661 | 705 ins_redraw(FALSE); |
7 | 706 ++no_mapping; |
707 ++allow_keys; | |
1389 | 708 c = plain_vgetc(); |
7 | 709 --no_mapping; |
710 --allow_keys; | |
477 | 711 if (c != Ctrl_N && c != Ctrl_G && c != Ctrl_O) |
7 | 712 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
713 // it's something else |
7 | 714 vungetc(c); |
715 c = Ctrl_BSL; | |
716 } | |
717 else if (c == Ctrl_G && p_im) | |
718 continue; | |
719 else | |
720 { | |
477 | 721 if (c == Ctrl_O) |
722 { | |
32031
e9b8deedab60
patch 9.0.1347: "gr CTRL-O" stays in Insert mode
Bram Moolenaar <Bram@vim.org>
parents:
32009
diff
changeset
|
723 ins_ctrl_o(cmdchar); |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
724 ins_at_eol = FALSE; // cursor keeps its column |
477 | 725 nomove = TRUE; |
726 } | |
7 | 727 count = 0; |
728 goto doESCkey; | |
729 } | |
730 } | |
731 | |
732 #ifdef FEAT_DIGRAPHS | |
733 c = do_digraph(c); | |
734 #endif | |
735 | |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
736 if ((c == Ctrl_V || c == Ctrl_Q) && ctrl_x_mode_cmdline()) |
7 | 737 goto docomplete; |
738 if (c == Ctrl_V || c == Ctrl_Q) | |
739 { | |
740 ins_ctrl_v(); | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
741 c = Ctrl_V; // pretend CTRL-V is last typed character |
7 | 742 continue; |
743 } | |
744 | |
17809
59f8948b7590
patch 8.1.1901: the +insert_expand feature is not always available
Bram Moolenaar <Bram@vim.org>
parents:
17775
diff
changeset
|
745 if (cindent_on() && ctrl_x_mode_none()) |
7 | 746 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
747 // A key name preceded by a bang means this key is not to be |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
748 // inserted. Skip ahead to the re-indenting below. |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
749 // A key name preceded by a star means that indenting has to be |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
750 // done before inserting the key. |
7 | 751 line_is_white = inindent(0); |
752 if (in_cinkeys(c, '!', line_is_white)) | |
753 goto force_cindent; | |
754 if (can_cindent && in_cinkeys(c, '*', line_is_white) | |
755 && stop_arrow() == OK) | |
756 do_c_expr_indent(); | |
757 } | |
758 | |
759 #ifdef FEAT_RIGHTLEFT | |
760 if (curwin->w_p_rl) | |
761 switch (c) | |
762 { | |
763 case K_LEFT: c = K_RIGHT; break; | |
764 case K_S_LEFT: c = K_S_RIGHT; break; | |
765 case K_C_LEFT: c = K_C_RIGHT; break; | |
766 case K_RIGHT: c = K_LEFT; break; | |
767 case K_S_RIGHT: c = K_S_LEFT; break; | |
768 case K_C_RIGHT: c = K_C_LEFT; break; | |
769 } | |
770 #endif | |
771 | |
772 /* | |
773 * If 'keymodel' contains "startsel", may start selection. If it | |
774 * does, a CTRL-O and c will be stuffed, we need to get these | |
775 * characters. | |
776 */ | |
777 if (ins_start_select(c)) | |
778 continue; | |
779 | |
780 /* | |
781 * The big switch to handle a character in insert mode. | |
782 */ | |
783 switch (c) | |
784 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
785 case ESC: // End input mode |
7 | 786 if (echeck_abbr(ESC + ABBR_OFF)) |
787 break; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
788 // FALLTHROUGH |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
789 |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
790 case Ctrl_C: // End input mode |
7 | 791 if (c == Ctrl_C && cmdwin_type != 0) |
792 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
793 // Close the cmdline window. |
7 | 794 cmdwin_result = K_IGNORE; |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
795 got_int = FALSE; // don't stop executing autocommands et al. |
929 | 796 nomove = TRUE; |
7 | 797 goto doESCkey; |
798 } | |
14103
d053ec57d886
patch 8.1.0069: cannot handle pressing CTRL-C in a prompt buffer
Christian Brabandt <cb@256bit.org>
parents:
14093
diff
changeset
|
799 #ifdef FEAT_JOB_CHANNEL |
d053ec57d886
patch 8.1.0069: cannot handle pressing CTRL-C in a prompt buffer
Christian Brabandt <cb@256bit.org>
parents:
14093
diff
changeset
|
800 if (c == Ctrl_C && bt_prompt(curbuf)) |
d053ec57d886
patch 8.1.0069: cannot handle pressing CTRL-C in a prompt buffer
Christian Brabandt <cb@256bit.org>
parents:
14093
diff
changeset
|
801 { |
d053ec57d886
patch 8.1.0069: cannot handle pressing CTRL-C in a prompt buffer
Christian Brabandt <cb@256bit.org>
parents:
14093
diff
changeset
|
802 if (invoke_prompt_interrupt()) |
d053ec57d886
patch 8.1.0069: cannot handle pressing CTRL-C in a prompt buffer
Christian Brabandt <cb@256bit.org>
parents:
14093
diff
changeset
|
803 { |
d053ec57d886
patch 8.1.0069: cannot handle pressing CTRL-C in a prompt buffer
Christian Brabandt <cb@256bit.org>
parents:
14093
diff
changeset
|
804 if (!bt_prompt(curbuf)) |
d053ec57d886
patch 8.1.0069: cannot handle pressing CTRL-C in a prompt buffer
Christian Brabandt <cb@256bit.org>
parents:
14093
diff
changeset
|
805 // buffer changed to a non-prompt buffer, get out of |
d053ec57d886
patch 8.1.0069: cannot handle pressing CTRL-C in a prompt buffer
Christian Brabandt <cb@256bit.org>
parents:
14093
diff
changeset
|
806 // Insert mode |
d053ec57d886
patch 8.1.0069: cannot handle pressing CTRL-C in a prompt buffer
Christian Brabandt <cb@256bit.org>
parents:
14093
diff
changeset
|
807 goto doESCkey; |
d053ec57d886
patch 8.1.0069: cannot handle pressing CTRL-C in a prompt buffer
Christian Brabandt <cb@256bit.org>
parents:
14093
diff
changeset
|
808 break; |
d053ec57d886
patch 8.1.0069: cannot handle pressing CTRL-C in a prompt buffer
Christian Brabandt <cb@256bit.org>
parents:
14093
diff
changeset
|
809 } |
d053ec57d886
patch 8.1.0069: cannot handle pressing CTRL-C in a prompt buffer
Christian Brabandt <cb@256bit.org>
parents:
14093
diff
changeset
|
810 } |
d053ec57d886
patch 8.1.0069: cannot handle pressing CTRL-C in a prompt buffer
Christian Brabandt <cb@256bit.org>
parents:
14093
diff
changeset
|
811 #endif |
7 | 812 |
813 #ifdef UNIX | |
814 do_intr: | |
815 #endif | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
816 // when 'insertmode' set, and not halfway a mapping, don't leave |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
817 // Insert mode |
7 | 818 if (goto_im()) |
819 { | |
820 if (got_int) | |
821 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
822 (void)vgetc(); // flush all buffers |
7 | 823 got_int = FALSE; |
824 } | |
825 else | |
6949 | 826 vim_beep(BO_IM); |
7 | 827 break; |
828 } | |
829 doESCkey: | |
830 /* | |
831 * This is the ONLY return from edit()! | |
832 */ | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
833 // Always update o_lnum, so that a "CTRL-O ." that adds a line |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
834 // still puts the cursor back after the inserted text. |
230 | 835 if (ins_at_eol && gchar_cursor() == NUL) |
7 | 836 o_lnum = curwin->w_cursor.lnum; |
837 | |
477 | 838 if (ins_esc(&count, cmdchar, nomove)) |
11 | 839 { |
14985
4ebda55537a5
patch 8.1.0504: when CTRL-C is mapped it triggers InsertLeave
Bram Moolenaar <Bram@vim.org>
parents:
14862
diff
changeset
|
840 // When CTRL-C was typed got_int will be set, with the result |
4ebda55537a5
patch 8.1.0504: when CTRL-C is mapped it triggers InsertLeave
Bram Moolenaar <Bram@vim.org>
parents:
14862
diff
changeset
|
841 // that the autocommands won't be executed. When mapped got_int |
4ebda55537a5
patch 8.1.0504: when CTRL-C is mapped it triggers InsertLeave
Bram Moolenaar <Bram@vim.org>
parents:
14862
diff
changeset
|
842 // is not set, but let's keep the behavior the same. |
4ebda55537a5
patch 8.1.0504: when CTRL-C is mapped it triggers InsertLeave
Bram Moolenaar <Bram@vim.org>
parents:
14862
diff
changeset
|
843 if (cmdchar != 'r' && cmdchar != 'v' && c != Ctrl_C) |
14485
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
844 ins_apply_autocmds(EVENT_INSERTLEAVE); |
993 | 845 did_cursorhold = FALSE; |
7 | 846 return (c == Ctrl_O); |
11 | 847 } |
7 | 848 continue; |
849 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
850 case Ctrl_Z: // suspend when 'insertmode' set |
449 | 851 if (!p_im) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
852 goto normalchar; // insert CTRL-Z as normal char |
10636
3db97def0f35
patch 8.0.0208: internally used commands end up in history
Christian Brabandt <cb@256bit.org>
parents:
10468
diff
changeset
|
853 do_cmdline_cmd((char_u *)"stop"); |
10980
5362b4b6042c
patch 8.0.0379: CTRL-Z and mouse click use CTRL-O unnecessary
Christian Brabandt <cb@256bit.org>
parents:
10952
diff
changeset
|
854 #ifdef CURSOR_SHAPE |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
855 ui_cursor_shape(); // may need to update cursor shape |
10980
5362b4b6042c
patch 8.0.0379: CTRL-Z and mouse click use CTRL-O unnecessary
Christian Brabandt <cb@256bit.org>
parents:
10952
diff
changeset
|
856 #endif |
5362b4b6042c
patch 8.0.0379: CTRL-Z and mouse click use CTRL-O unnecessary
Christian Brabandt <cb@256bit.org>
parents:
10952
diff
changeset
|
857 continue; |
449 | 858 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
859 case Ctrl_O: // execute one command |
502 | 860 #ifdef FEAT_COMPL_FUNC |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
861 if (ctrl_x_mode_omni()) |
449 | 862 goto docomplete; |
863 #endif | |
864 if (echeck_abbr(Ctrl_O + ABBR_OFF)) | |
865 break; | |
32031
e9b8deedab60
patch 9.0.1347: "gr CTRL-O" stays in Insert mode
Bram Moolenaar <Bram@vim.org>
parents:
32009
diff
changeset
|
866 ins_ctrl_o(cmdchar); |
853 | 867 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
868 // don't move the cursor left when 'virtualedit' has "onemore". |
25380
ac88cd21ae88
patch 8.2.3227: 'virtualedit' can only be set globally
Bram Moolenaar <Bram@vim.org>
parents:
25378
diff
changeset
|
869 if (get_ve_flags() & VE_ONEMORE) |
853 | 870 { |
871 ins_at_eol = FALSE; | |
872 nomove = TRUE; | |
873 } | |
449 | 874 count = 0; |
875 goto doESCkey; | |
876 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
877 case K_INS: // toggle insert/replace mode |
464 | 878 case K_KINS: |
879 ins_insert(replaceState); | |
880 break; | |
881 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
882 case K_SELECT: // end of Select mode mapping - ignore |
464 | 883 break; |
884 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
885 case K_HELP: // Help key works like <ESC> <Help> |
449 | 886 case K_F1: |
887 case K_XF1: | |
888 stuffcharReadbuff(K_HELP); | |
889 if (p_im) | |
890 need_start_insertmode = TRUE; | |
891 goto doESCkey; | |
892 | |
893 #ifdef FEAT_NETBEANS_INTG | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
894 case K_F21: // NetBeans command |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
895 ++no_mapping; // don't map the next key hits |
1389 | 896 i = plain_vgetc(); |
449 | 897 --no_mapping; |
898 netbeans_keycommand(i); | |
899 break; | |
900 #endif | |
901 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
902 case K_ZERO: // Insert the previously inserted text. |
7 | 903 case NUL: |
904 case Ctrl_A: | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
905 // For ^@ the trailing ESC will end the insert, unless there is an |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
906 // error. |
7 | 907 if (stuff_inserted(NUL, 1L, (c == Ctrl_A)) == FAIL |
908 && c != Ctrl_A && !p_im) | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
909 goto doESCkey; // quit insert mode |
7 | 910 inserted_space = FALSE; |
911 break; | |
912 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
913 case Ctrl_R: // insert the contents of a register |
7 | 914 ins_reg(); |
915 auto_format(FALSE, TRUE); | |
916 inserted_space = FALSE; | |
917 break; | |
918 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
919 case Ctrl_G: // commands starting with CTRL-G |
7 | 920 ins_ctrl_g(); |
921 break; | |
922 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
923 case Ctrl_HAT: // switch input mode and/or langmap |
449 | 924 ins_ctrl_hat(); |
7 | 925 break; |
926 | |
927 #ifdef FEAT_RIGHTLEFT | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
928 case Ctrl__: // switch between languages |
7 | 929 if (!p_ari) |
930 goto normalchar; | |
931 ins_ctrl_(); | |
932 break; | |
933 #endif | |
934 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
935 case Ctrl_D: // Make indent one shiftwidth smaller. |
17809
59f8948b7590
patch 8.1.1901: the +insert_expand feature is not always available
Bram Moolenaar <Bram@vim.org>
parents:
17775
diff
changeset
|
936 #if defined(FEAT_FIND_ID) |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
937 if (ctrl_x_mode_path_defines()) |
7 | 938 goto docomplete; |
939 #endif | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
940 // FALLTHROUGH |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
941 |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
942 case Ctrl_T: // Make indent one shiftwidth greater. |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
943 if (c == Ctrl_T && ctrl_x_mode_thesaurus()) |
7 | 944 { |
449 | 945 if (has_compl_option(FALSE)) |
946 goto docomplete; | |
947 break; | |
7 | 948 } |
17809
59f8948b7590
patch 8.1.1901: the +insert_expand feature is not always available
Bram Moolenaar <Bram@vim.org>
parents:
17775
diff
changeset
|
949 |
7 | 950 ins_shift(c, lastc); |
951 auto_format(FALSE, TRUE); | |
952 inserted_space = FALSE; | |
953 break; | |
954 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
955 case K_DEL: // delete character under the cursor |
7 | 956 case K_KDEL: |
957 ins_del(); | |
958 auto_format(FALSE, TRUE); | |
959 break; | |
960 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
961 case K_BS: // delete character before the cursor |
28704
e1aff2f300be
patch 8.2.4876: MS-Windows: Shift-BS results in strange char in powershell
Bram Moolenaar <Bram@vim.org>
parents:
28682
diff
changeset
|
962 case K_S_BS: |
7 | 963 case Ctrl_H: |
964 did_backspace = ins_bs(c, BACKSPACE_CHAR, &inserted_space); | |
965 auto_format(FALSE, TRUE); | |
966 break; | |
967 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
968 case Ctrl_W: // delete word before the cursor |
14035
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
969 #ifdef FEAT_JOB_CHANNEL |
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
970 if (bt_prompt(curbuf) && (mod_mask & MOD_MASK_SHIFT) == 0) |
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
971 { |
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
972 // In a prompt window CTRL-W is used for window commands. |
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
973 // Use Shift-CTRL-W to delete a word. |
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
974 stuffcharReadbuff(Ctrl_W); |
14093
a9d94f10ecef
patch 8.1.0064: typing CTRL-W in a prompt buffer shows mode "-- --"
Christian Brabandt <cb@256bit.org>
parents:
14079
diff
changeset
|
975 restart_edit = 'A'; |
14035
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
976 nomove = TRUE; |
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
977 count = 0; |
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
978 goto doESCkey; |
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
979 } |
bccd66fa00c1
patch 8.1.0035: not easy to switch between prompt buffer and other windows
Christian Brabandt <cb@256bit.org>
parents:
14019
diff
changeset
|
980 #endif |
7 | 981 did_backspace = ins_bs(c, BACKSPACE_WORD, &inserted_space); |
982 auto_format(FALSE, TRUE); | |
983 break; | |
984 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
985 case Ctrl_U: // delete all inserted text in current line |
12 | 986 # ifdef FEAT_COMPL_FUNC |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
987 // CTRL-X CTRL-U completes with 'completefunc'. |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
988 if (ctrl_x_mode_function()) |
12 | 989 goto docomplete; |
990 # endif | |
7 | 991 did_backspace = ins_bs(c, BACKSPACE_LINE, &inserted_space); |
992 auto_format(FALSE, TRUE); | |
993 inserted_space = FALSE; | |
994 break; | |
995 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
996 case K_LEFTMOUSE: // mouse keys |
7 | 997 case K_LEFTMOUSE_NM: |
998 case K_LEFTDRAG: | |
999 case K_LEFTRELEASE: | |
1000 case K_LEFTRELEASE_NM: | |
12865
ebb4f6c93598
patch 8.0.1309: cannot use 'balloonexpr' in a terminal
Christian Brabandt <cb@256bit.org>
parents:
12716
diff
changeset
|
1001 case K_MOUSEMOVE: |
7 | 1002 case K_MIDDLEMOUSE: |
1003 case K_MIDDLEDRAG: | |
1004 case K_MIDDLERELEASE: | |
1005 case K_RIGHTMOUSE: | |
1006 case K_RIGHTDRAG: | |
1007 case K_RIGHTRELEASE: | |
1008 case K_X1MOUSE: | |
1009 case K_X1DRAG: | |
1010 case K_X1RELEASE: | |
1011 case K_X2MOUSE: | |
1012 case K_X2DRAG: | |
1013 case K_X2RELEASE: | |
1014 ins_mouse(c); | |
1015 break; | |
1016 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1017 case K_MOUSEDOWN: // Default action for scroll wheel up: scroll up |
2409
0ca06a92adfb
Add support for horizontal scroll wheel. (Bjorn Winckler)
Bram Moolenaar <bram@vim.org>
parents:
2378
diff
changeset
|
1018 ins_mousescroll(MSCR_DOWN); |
7 | 1019 break; |
1020 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1021 case K_MOUSEUP: // Default action for scroll wheel down: scroll down |
2409
0ca06a92adfb
Add support for horizontal scroll wheel. (Bjorn Winckler)
Bram Moolenaar <bram@vim.org>
parents:
2378
diff
changeset
|
1022 ins_mousescroll(MSCR_UP); |
0ca06a92adfb
Add support for horizontal scroll wheel. (Bjorn Winckler)
Bram Moolenaar <bram@vim.org>
parents:
2378
diff
changeset
|
1023 break; |
0ca06a92adfb
Add support for horizontal scroll wheel. (Bjorn Winckler)
Bram Moolenaar <bram@vim.org>
parents:
2378
diff
changeset
|
1024 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1025 case K_MOUSELEFT: // Scroll wheel left |
2409
0ca06a92adfb
Add support for horizontal scroll wheel. (Bjorn Winckler)
Bram Moolenaar <bram@vim.org>
parents:
2378
diff
changeset
|
1026 ins_mousescroll(MSCR_LEFT); |
0ca06a92adfb
Add support for horizontal scroll wheel. (Bjorn Winckler)
Bram Moolenaar <bram@vim.org>
parents:
2378
diff
changeset
|
1027 break; |
0ca06a92adfb
Add support for horizontal scroll wheel. (Bjorn Winckler)
Bram Moolenaar <bram@vim.org>
parents:
2378
diff
changeset
|
1028 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1029 case K_MOUSERIGHT: // Scroll wheel right |
2409
0ca06a92adfb
Add support for horizontal scroll wheel. (Bjorn Winckler)
Bram Moolenaar <bram@vim.org>
parents:
2378
diff
changeset
|
1030 ins_mousescroll(MSCR_RIGHT); |
7 | 1031 break; |
18354
9f51d0cef8da
patch 8.1.2171: mouse support not always available
Bram Moolenaar <Bram@vim.org>
parents:
18265
diff
changeset
|
1032 |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
1033 case K_PS: |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
1034 bracketed_paste(PASTE_INSERT, FALSE, NULL); |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
1035 if (cmdchar == K_PS) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1036 // invoked from normal mode, bail out |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
1037 goto doESCkey; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
1038 break; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
1039 case K_PE: |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1040 // Got K_PE without K_PS, ignore. |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
1041 break; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
1042 |
692 | 1043 #ifdef FEAT_GUI_TABLINE |
1044 case K_TABLINE: | |
1045 case K_TABMENU: | |
1046 ins_tabline(c); | |
1047 break; | |
1048 #endif | |
7 | 1049 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1050 case K_IGNORE: // Something mapped to nothing |
7 | 1051 break; |
1052 | |
27140
a9eeb18e749c
patch 8.2.4099: Vim9: cannot use Vim9 syntax in mapping
Bram Moolenaar <Bram@vim.org>
parents:
27018
diff
changeset
|
1053 case K_COMMAND: // <Cmd>command<CR> |
a9eeb18e749c
patch 8.2.4099: Vim9: cannot use Vim9 syntax in mapping
Bram Moolenaar <Bram@vim.org>
parents:
27018
diff
changeset
|
1054 case K_SCRIPT_COMMAND: // <ScriptCmd>command<CR> |
31406
627d4f236ac8
patch 9.0.1036: undo misbehaves when writing from an insert mode mapping
Bram Moolenaar <Bram@vim.org>
parents:
31293
diff
changeset
|
1055 { |
627d4f236ac8
patch 9.0.1036: undo misbehaves when writing from an insert mode mapping
Bram Moolenaar <Bram@vim.org>
parents:
31293
diff
changeset
|
1056 do_cmdkey_command(c, 0); |
627d4f236ac8
patch 9.0.1036: undo misbehaves when writing from an insert mode mapping
Bram Moolenaar <Bram@vim.org>
parents:
31293
diff
changeset
|
1057 |
22882
be7f52838056
patch 8.2.1988: still in Insert mode when opening terminal popup
Bram Moolenaar <Bram@vim.org>
parents:
22862
diff
changeset
|
1058 #ifdef FEAT_TERMINAL |
31406
627d4f236ac8
patch 9.0.1036: undo misbehaves when writing from an insert mode mapping
Bram Moolenaar <Bram@vim.org>
parents:
31293
diff
changeset
|
1059 if (term_use_loop()) |
627d4f236ac8
patch 9.0.1036: undo misbehaves when writing from an insert mode mapping
Bram Moolenaar <Bram@vim.org>
parents:
31293
diff
changeset
|
1060 // Started a terminal that gets the input, exit Insert mode. |
627d4f236ac8
patch 9.0.1036: undo misbehaves when writing from an insert mode mapping
Bram Moolenaar <Bram@vim.org>
parents:
31293
diff
changeset
|
1061 goto doESCkey; |
22882
be7f52838056
patch 8.2.1988: still in Insert mode when opening terminal popup
Bram Moolenaar <Bram@vim.org>
parents:
22862
diff
changeset
|
1062 #endif |
31406
627d4f236ac8
patch 9.0.1036: undo misbehaves when writing from an insert mode mapping
Bram Moolenaar <Bram@vim.org>
parents:
31293
diff
changeset
|
1063 if (curbuf->b_u_synced) |
627d4f236ac8
patch 9.0.1036: undo misbehaves when writing from an insert mode mapping
Bram Moolenaar <Bram@vim.org>
parents:
31293
diff
changeset
|
1064 // The command caused undo to be synced. Need to save the |
627d4f236ac8
patch 9.0.1036: undo misbehaves when writing from an insert mode mapping
Bram Moolenaar <Bram@vim.org>
parents:
31293
diff
changeset
|
1065 // line for undo before inserting the next char. |
627d4f236ac8
patch 9.0.1036: undo misbehaves when writing from an insert mode mapping
Bram Moolenaar <Bram@vim.org>
parents:
31293
diff
changeset
|
1066 ins_need_undo = TRUE; |
627d4f236ac8
patch 9.0.1036: undo misbehaves when writing from an insert mode mapping
Bram Moolenaar <Bram@vim.org>
parents:
31293
diff
changeset
|
1067 } |
22862
6d50182e7e24
patch 8.2.1978: making a mapping work in all modes is complicated
Bram Moolenaar <Bram@vim.org>
parents:
22858
diff
changeset
|
1068 break; |
6d50182e7e24
patch 8.2.1978: making a mapping work in all modes is complicated
Bram Moolenaar <Bram@vim.org>
parents:
22858
diff
changeset
|
1069 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1070 case K_CURSORHOLD: // Didn't type something for a while. |
14485
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
1071 ins_apply_autocmds(EVENT_CURSORHOLDI); |
661 | 1072 did_cursorhold = TRUE; |
25866
45a8b2b2f652
patch 8.2.3467: CursorHoldI event interferes with "CTRL-G U"
Bram Moolenaar <Bram@vim.org>
parents:
25818
diff
changeset
|
1073 // If CTRL-G U was used apply it to the next typed key. |
45a8b2b2f652
patch 8.2.3467: CursorHoldI event interferes with "CTRL-G U"
Bram Moolenaar <Bram@vim.org>
parents:
25818
diff
changeset
|
1074 if (dont_sync_undo == TRUE) |
45a8b2b2f652
patch 8.2.3467: CursorHoldI event interferes with "CTRL-G U"
Bram Moolenaar <Bram@vim.org>
parents:
25818
diff
changeset
|
1075 dont_sync_undo = MAYBE; |
661 | 1076 break; |
1077 | |
15868
7fad90423bd2
patch 8.1.0941: macros for MS-Windows are inconsistent
Bram Moolenaar <Bram@vim.org>
parents:
15850
diff
changeset
|
1078 #ifdef FEAT_GUI_MSWIN |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1079 // On MS-Windows ignore <M-F4>, we get it when closing the window |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1080 // was cancelled. |
625 | 1081 case K_F4: |
1082 if (mod_mask != MOD_MASK_ALT) | |
1083 goto normalchar; | |
1084 break; | |
1085 #endif | |
1086 | |
7 | 1087 #ifdef FEAT_GUI |
1088 case K_VER_SCROLLBAR: | |
1089 ins_scroll(); | |
1090 break; | |
1091 | |
1092 case K_HOR_SCROLLBAR: | |
1093 ins_horscroll(); | |
1094 break; | |
1095 #endif | |
1096 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1097 case K_HOME: // <Home> |
7 | 1098 case K_KHOME: |
1099 case K_S_HOME: | |
1100 case K_C_HOME: | |
1101 ins_home(c); | |
1102 break; | |
1103 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1104 case K_END: // <End> |
7 | 1105 case K_KEND: |
1106 case K_S_END: | |
1107 case K_C_END: | |
1108 ins_end(c); | |
1109 break; | |
1110 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1111 case K_LEFT: // <Left> |
180 | 1112 if (mod_mask & (MOD_MASK_SHIFT|MOD_MASK_CTRL)) |
1113 ins_s_left(); | |
1114 else | |
16101
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
1115 ins_left(); |
7 | 1116 break; |
1117 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1118 case K_S_LEFT: // <S-Left> |
7 | 1119 case K_C_LEFT: |
1120 ins_s_left(); | |
1121 break; | |
1122 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1123 case K_RIGHT: // <Right> |
180 | 1124 if (mod_mask & (MOD_MASK_SHIFT|MOD_MASK_CTRL)) |
1125 ins_s_right(); | |
1126 else | |
16101
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
1127 ins_right(); |
7 | 1128 break; |
1129 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1130 case K_S_RIGHT: // <S-Right> |
7 | 1131 case K_C_RIGHT: |
1132 ins_s_right(); | |
1133 break; | |
1134 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1135 case K_UP: // <Up> |
665 | 1136 if (pum_visible()) |
1137 goto docomplete; | |
180 | 1138 if (mod_mask & MOD_MASK_SHIFT) |
1139 ins_pageup(); | |
1140 else | |
1141 ins_up(FALSE); | |
7 | 1142 break; |
1143 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1144 case K_S_UP: // <S-Up> |
7 | 1145 case K_PAGEUP: |
1146 case K_KPAGEUP: | |
610 | 1147 if (pum_visible()) |
1148 goto docomplete; | |
7 | 1149 ins_pageup(); |
1150 break; | |
1151 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1152 case K_DOWN: // <Down> |
665 | 1153 if (pum_visible()) |
1154 goto docomplete; | |
180 | 1155 if (mod_mask & MOD_MASK_SHIFT) |
1156 ins_pagedown(); | |
1157 else | |
1158 ins_down(FALSE); | |
7 | 1159 break; |
1160 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1161 case K_S_DOWN: // <S-Down> |
7 | 1162 case K_PAGEDOWN: |
1163 case K_KPAGEDOWN: | |
610 | 1164 if (pum_visible()) |
1165 goto docomplete; | |
7 | 1166 ins_pagedown(); |
1167 break; | |
1168 | |
1169 #ifdef FEAT_DND | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1170 case K_DROP: // drag-n-drop event |
7 | 1171 ins_drop(); |
1172 break; | |
1173 #endif | |
1174 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1175 case K_S_TAB: // When not mapped, use like a normal TAB |
7 | 1176 c = TAB; |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1177 // FALLTHROUGH |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1178 |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1179 case TAB: // TAB or Complete patterns along path |
17809
59f8948b7590
patch 8.1.1901: the +insert_expand feature is not always available
Bram Moolenaar <Bram@vim.org>
parents:
17775
diff
changeset
|
1180 #if defined(FEAT_FIND_ID) |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
1181 if (ctrl_x_mode_path_patterns()) |
7 | 1182 goto docomplete; |
1183 #endif | |
1184 inserted_space = FALSE; | |
1185 if (ins_tab()) | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1186 goto normalchar; // insert TAB as a normal char |
7 | 1187 auto_format(FALSE, TRUE); |
1188 break; | |
1189 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1190 case K_KENTER: // <Enter> |
7 | 1191 c = CAR; |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1192 // FALLTHROUGH |
7 | 1193 case CAR: |
1194 case NL: | |
12477
68d7bc045dbe
patch 8.0.1118: FEAT_WINDOWS adds a lot of #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
12323
diff
changeset
|
1195 #if defined(FEAT_QUICKFIX) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1196 // In a quickfix window a <CR> jumps to the error under the |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1197 // cursor. |
7 | 1198 if (bt_quickfix(curbuf) && c == CAR) |
1199 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1200 if (curwin->w_llist_ref == NULL) // quickfix window |
644 | 1201 do_cmdline_cmd((char_u *)".cc"); |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1202 else // location list window |
644 | 1203 do_cmdline_cmd((char_u *)".ll"); |
7 | 1204 break; |
1205 } | |
1206 #endif | |
1207 if (cmdwin_type != 0) | |
1208 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1209 // Execute the command in the cmdline window. |
7 | 1210 cmdwin_result = CAR; |
1211 goto doESCkey; | |
1212 } | |
14019
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1213 #ifdef FEAT_JOB_CHANNEL |
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1214 if (bt_prompt(curbuf)) |
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1215 { |
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1216 invoke_prompt_callback(); |
14037
afce2005fdc8
patch 8.1.0036: not restoring Insert mode if leaving prompt buffer with mouse
Christian Brabandt <cb@256bit.org>
parents:
14035
diff
changeset
|
1217 if (!bt_prompt(curbuf)) |
afce2005fdc8
patch 8.1.0036: not restoring Insert mode if leaving prompt buffer with mouse
Christian Brabandt <cb@256bit.org>
parents:
14035
diff
changeset
|
1218 // buffer changed to a non-prompt buffer, get out of |
afce2005fdc8
patch 8.1.0036: not restoring Insert mode if leaving prompt buffer with mouse
Christian Brabandt <cb@256bit.org>
parents:
14035
diff
changeset
|
1219 // Insert mode |
14019
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1220 goto doESCkey; |
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1221 break; |
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1222 } |
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1223 #endif |
13772
cc21507ee4b1
patch 8.0.1758: open_line() returns TRUE/FALSE for success/failure
Christian Brabandt <cb@256bit.org>
parents:
13718
diff
changeset
|
1224 if (ins_eol(c) == FAIL && !p_im) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1225 goto doESCkey; // out of memory |
7 | 1226 auto_format(FALSE, FALSE); |
1227 inserted_space = FALSE; | |
1228 break; | |
1229 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1230 case Ctrl_K: // digraph or keyword completion |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
1231 if (ctrl_x_mode_dictionary()) |
7 | 1232 { |
449 | 1233 if (has_compl_option(TRUE)) |
1234 goto docomplete; | |
1235 break; | |
7 | 1236 } |
17809
59f8948b7590
patch 8.1.1901: the +insert_expand feature is not always available
Bram Moolenaar <Bram@vim.org>
parents:
17775
diff
changeset
|
1237 #ifdef FEAT_DIGRAPHS |
7 | 1238 c = ins_digraph(); |
1239 if (c == NUL) | |
1240 break; | |
17809
59f8948b7590
patch 8.1.1901: the +insert_expand feature is not always available
Bram Moolenaar <Bram@vim.org>
parents:
17775
diff
changeset
|
1241 #endif |
7 | 1242 goto normalchar; |
17809
59f8948b7590
patch 8.1.1901: the +insert_expand feature is not always available
Bram Moolenaar <Bram@vim.org>
parents:
17775
diff
changeset
|
1243 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1244 case Ctrl_X: // Enter CTRL-X mode |
464 | 1245 ins_ctrl_x(); |
1246 break; | |
1247 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1248 case Ctrl_RSB: // Tag name completion after ^X |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
1249 if (!ctrl_x_mode_tags()) |
7 | 1250 goto normalchar; |
1251 goto docomplete; | |
1252 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1253 case Ctrl_F: // File name completion after ^X |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
1254 if (!ctrl_x_mode_files()) |
7 | 1255 goto normalchar; |
1256 goto docomplete; | |
477 | 1257 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1258 case 's': // Spelling completion after ^X |
477 | 1259 case Ctrl_S: |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
1260 if (!ctrl_x_mode_spell()) |
477 | 1261 goto normalchar; |
1262 goto docomplete; | |
7 | 1263 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1264 case Ctrl_L: // Whole line completion after ^X |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
1265 if (!ctrl_x_mode_whole_line()) |
7 | 1266 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1267 // CTRL-L with 'insertmode' set: Leave Insert mode |
7 | 1268 if (p_im) |
1269 { | |
1270 if (echeck_abbr(Ctrl_L + ABBR_OFF)) | |
1271 break; | |
1272 goto doESCkey; | |
1273 } | |
1274 goto normalchar; | |
1275 } | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1276 // FALLTHROUGH |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1277 |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1278 case Ctrl_P: // Do previous/next pattern completion |
7 | 1279 case Ctrl_N: |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1280 // if 'complete' is empty then plain ^P is no longer special, |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1281 // but it is under other ^X modes |
7 | 1282 if (*curbuf->b_p_cpt == NUL |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
1283 && (ctrl_x_mode_normal() || ctrl_x_mode_whole_line()) |
26944
8dbdd68627bd
patch 8.2.4001: insert complete code uses global variables
Bram Moolenaar <Bram@vim.org>
parents:
26883
diff
changeset
|
1284 && !compl_status_local()) |
7 | 1285 goto normalchar; |
1286 | |
1287 docomplete: | |
1927 | 1288 compl_busy = TRUE; |
11073
d2178a6cc9f3
patch 8.0.0425: build errors when building without folding
Christian Brabandt <cb@256bit.org>
parents:
11002
diff
changeset
|
1289 #ifdef FEAT_FOLDING |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1290 disable_fold_update++; // don't redraw folds here |
11073
d2178a6cc9f3
patch 8.0.0425: build errors when building without folding
Christian Brabandt <cb@256bit.org>
parents:
11002
diff
changeset
|
1291 #endif |
8224
2baf64fead5e
commit https://github.com/vim/vim/commit/8aefbe0ad5d05ee7225b20024b0f3023286ebd0f
Christian Brabandt <cb@256bit.org>
parents:
8090
diff
changeset
|
1292 if (ins_complete(c, TRUE) == FAIL) |
26944
8dbdd68627bd
patch 8.2.4001: insert complete code uses global variables
Bram Moolenaar <Bram@vim.org>
parents:
26883
diff
changeset
|
1293 compl_status_clear(); |
11073
d2178a6cc9f3
patch 8.0.0425: build errors when building without folding
Christian Brabandt <cb@256bit.org>
parents:
11002
diff
changeset
|
1294 #ifdef FEAT_FOLDING |
8891
d7ba3f9b9ba6
commit https://github.com/vim/vim/commit/429fcfbf9a9275367fe9441a50a3dcd773497d84
Christian Brabandt <cb@256bit.org>
parents:
8362
diff
changeset
|
1295 disable_fold_update--; |
11073
d2178a6cc9f3
patch 8.0.0425: build errors when building without folding
Christian Brabandt <cb@256bit.org>
parents:
11002
diff
changeset
|
1296 #endif |
1927 | 1297 compl_busy = FALSE; |
28856
948877671c54
patch 8.2.4951: smart indenting done when not enabled
Bram Moolenaar <Bram@vim.org>
parents:
28809
diff
changeset
|
1298 can_si = may_do_si(); // allow smartindenting |
7 | 1299 break; |
1300 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1301 case Ctrl_Y: // copy from previous line or scroll down |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1302 case Ctrl_E: // copy from next line or scroll up |
449 | 1303 c = ins_ctrl_ey(c); |
7 | 1304 break; |
1305 | |
1306 default: | |
1307 #ifdef UNIX | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1308 if (c == intr_char) // special interrupt char |
7 | 1309 goto do_intr; |
1310 #endif | |
1311 | |
2845 | 1312 normalchar: |
7 | 1313 /* |
4352 | 1314 * Insert a normal character. |
7 | 1315 */ |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
1316 #if defined(FEAT_EVAL) |
2845 | 1317 if (!p_paste) |
1318 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1319 // Trigger InsertCharPre. |
3390 | 1320 char_u *str = do_insert_char_pre(c); |
1321 char_u *p; | |
1322 | |
1323 if (str != NULL) | |
2845 | 1324 { |
3390 | 1325 if (*str != NUL && stop_arrow() != FAIL) |
2845 | 1326 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1327 // Insert the new value of v:char literally. |
11127
506f5d8b7d8b
patch 8.0.0451: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents:
11121
diff
changeset
|
1328 for (p = str; *p != NUL; MB_PTR_ADV(p)) |
2845 | 1329 { |
3390 | 1330 c = PTR2CHAR(p); |
1331 if (c == CAR || c == K_KENTER || c == NL) | |
1332 ins_eol(c); | |
1333 else | |
1334 ins_char(c); | |
2845 | 1335 } |
3390 | 1336 AppendToRedobuffLit(str, -1); |
2845 | 1337 } |
3390 | 1338 vim_free(str); |
1339 c = NUL; | |
2845 | 1340 } |
1341 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1342 // If the new value is already inserted or an empty string |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1343 // then don't insert any character. |
2845 | 1344 if (c == NUL) |
1345 break; | |
1346 } | |
1347 #endif | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1348 // Try to perform smart-indenting. |
7 | 1349 ins_try_si(c); |
1350 | |
1351 if (c == ' ') | |
1352 { | |
1353 inserted_space = TRUE; | |
1354 if (inindent(0)) | |
1355 can_cindent = FALSE; | |
1356 if (Insstart_blank_vcol == MAXCOL | |
1357 && curwin->w_cursor.lnum == Insstart.lnum) | |
1358 Insstart_blank_vcol = get_nolist_virtcol(); | |
1359 } | |
1360 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1361 // Insert a normal character and check for abbreviations on a |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1362 // special character. Let CTRL-] expand abbreviations without |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1363 // inserting it. |
3448 | 1364 if (vim_iswordc(c) || (!echeck_abbr( |
15595
1ec942f1b648
patch 8.1.0805: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15569
diff
changeset
|
1365 // Add ABBR_OFF for characters above 0x100, this is |
1ec942f1b648
patch 8.1.0805: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15569
diff
changeset
|
1366 // what check_abbr() expects. |
1ec942f1b648
patch 8.1.0805: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15569
diff
changeset
|
1367 (has_mbyte && c >= 0x100) ? (c + ABBR_OFF) : c) |
1ec942f1b648
patch 8.1.0805: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15569
diff
changeset
|
1368 && c != Ctrl_RSB)) |
7 | 1369 { |
1370 insert_special(c, FALSE, FALSE); | |
1371 #ifdef FEAT_RIGHTLEFT | |
1372 revins_legal++; | |
1373 revins_chars++; | |
1374 #endif | |
1375 } | |
1376 | |
1377 auto_format(FALSE, TRUE); | |
1378 | |
1379 #ifdef FEAT_FOLDING | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1380 // When inserting a character the cursor line must never be in a |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1381 // closed fold. |
7 | 1382 foldOpenCursor(); |
1383 #endif | |
1384 break; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1385 } // end of switch (c) |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1386 |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1387 // If typed something may trigger CursorHoldI again. |
8945
a3060addc328
commit https://github.com/vim/vim/commit/245c41070c7f37d52be43cce0cb140bd3ade6c7e
Christian Brabandt <cb@256bit.org>
parents:
8943
diff
changeset
|
1388 if (c != K_CURSORHOLD |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
1389 #ifdef FEAT_COMPL_FUNC |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1390 // but not in CTRL-X mode, a script can't restore the state |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
1391 && ctrl_x_mode_normal() |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
1392 #endif |
8945
a3060addc328
commit https://github.com/vim/vim/commit/245c41070c7f37d52be43cce0cb140bd3ade6c7e
Christian Brabandt <cb@256bit.org>
parents:
8943
diff
changeset
|
1393 ) |
978 | 1394 did_cursorhold = FALSE; |
1395 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1396 // If the cursor was moved we didn't just insert a space |
7 | 1397 if (arrow_used) |
1398 inserted_space = FALSE; | |
1399 | |
17809
59f8948b7590
patch 8.1.1901: the +insert_expand feature is not always available
Bram Moolenaar <Bram@vim.org>
parents:
17775
diff
changeset
|
1400 if (can_cindent && cindent_on() && ctrl_x_mode_normal()) |
7 | 1401 { |
1402 force_cindent: | |
1403 /* | |
1404 * Indent now if a key was typed that is in 'cinkeys'. | |
1405 */ | |
1406 if (in_cinkeys(c, ' ', line_is_white)) | |
1407 { | |
1408 if (stop_arrow() == OK) | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1409 // re-indent the current line |
7 | 1410 do_c_expr_indent(); |
1411 } | |
1412 } | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1413 |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1414 } // for (;;) |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1415 // NOTREACHED |
7 | 1416 } |
1417 | |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
1418 int |
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
1419 ins_need_undo_get(void) |
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
1420 { |
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
1421 return ins_need_undo; |
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
1422 } |
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
1423 |
7 | 1424 /* |
1425 * Redraw for Insert mode. | |
1426 * This is postponed until getting the next character to make '$' in the 'cpo' | |
1427 * option work correctly. | |
1428 * Only redraw when there are no characters available. This speeds up | |
1429 * inserting sequences of characters (e.g., for CTRL-R). | |
1430 */ | |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
1431 void |
16904
9138e2c60bf1
patch 8.1.1453: popup window "moved" property not implemented yet
Bram Moolenaar <Bram@vim.org>
parents:
16768
diff
changeset
|
1432 ins_redraw(int ready) // not busy with something |
7 | 1433 { |
2282
a888ed7ba375
Make updating text for conceal mode simpler. A few compiler warning fixes.
Bram Moolenaar <bram@vim.org>
parents:
2250
diff
changeset
|
1434 #ifdef FEAT_CONCEAL |
a888ed7ba375
Make updating text for conceal mode simpler. A few compiler warning fixes.
Bram Moolenaar <bram@vim.org>
parents:
2250
diff
changeset
|
1435 linenr_T conceal_old_cursor_line = 0; |
a888ed7ba375
Make updating text for conceal mode simpler. A few compiler warning fixes.
Bram Moolenaar <bram@vim.org>
parents:
2250
diff
changeset
|
1436 linenr_T conceal_new_cursor_line = 0; |
a888ed7ba375
Make updating text for conceal mode simpler. A few compiler warning fixes.
Bram Moolenaar <bram@vim.org>
parents:
2250
diff
changeset
|
1437 int conceal_update_lines = FALSE; |
a888ed7ba375
Make updating text for conceal mode simpler. A few compiler warning fixes.
Bram Moolenaar <bram@vim.org>
parents:
2250
diff
changeset
|
1438 #endif |
a888ed7ba375
Make updating text for conceal mode simpler. A few compiler warning fixes.
Bram Moolenaar <bram@vim.org>
parents:
2250
diff
changeset
|
1439 |
5592 | 1440 if (char_avail()) |
1441 return; | |
1442 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1443 // Trigger CursorMoved if the cursor moved. Not when the popup menu is |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1444 // visible, the command might delete it. |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
1445 if (ready && (has_cursormovedI() |
18763
49b78d6465e5
patch 8.1.2371: FEAT_TEXT_PROP is a confusing name
Bram Moolenaar <Bram@vim.org>
parents:
18717
diff
changeset
|
1446 # ifdef FEAT_PROP_POPUP |
16904
9138e2c60bf1
patch 8.1.1453: popup window "moved" property not implemented yet
Bram Moolenaar <Bram@vim.org>
parents:
16768
diff
changeset
|
1447 || popup_visible |
9138e2c60bf1
patch 8.1.1453: popup window "moved" property not implemented yet
Bram Moolenaar <Bram@vim.org>
parents:
16768
diff
changeset
|
1448 # endif |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
1449 # if defined(FEAT_CONCEAL) |
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
1450 || curwin->w_p_cole > 0 |
5592 | 1451 # endif |
1452 ) | |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
1453 && !EQUAL_POS(last_cursormoved, curwin->w_cursor) |
17809
59f8948b7590
patch 8.1.1901: the +insert_expand feature is not always available
Bram Moolenaar <Bram@vim.org>
parents:
17775
diff
changeset
|
1454 && !pum_visible()) |
5592 | 1455 { |
1456 # ifdef FEAT_SYN_HL | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1457 // Need to update the screen first, to make sure syntax |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1458 // highlighting is correct after making a change (e.g., inserting |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1459 // a "(". The autocommand may also require a redraw, so it's done |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1460 // again below, unfortunately. |
5592 | 1461 if (syntax_present(curwin) && must_redraw) |
1462 update_screen(0); | |
2282
a888ed7ba375
Make updating text for conceal mode simpler. A few compiler warning fixes.
Bram Moolenaar <bram@vim.org>
parents:
2250
diff
changeset
|
1463 # endif |
5592 | 1464 if (has_cursormovedI()) |
8003
94798af62c56
commit https://github.com/vim/vim/commit/f068dcafcfe0c8018e5a559c50769ca1364bd9a5
Christian Brabandt <cb@256bit.org>
parents:
7817
diff
changeset
|
1465 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1466 // Make sure curswant is correct, an autocommand may call |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1467 // getcurpos(). |
8003
94798af62c56
commit https://github.com/vim/vim/commit/f068dcafcfe0c8018e5a559c50769ca1364bd9a5
Christian Brabandt <cb@256bit.org>
parents:
7817
diff
changeset
|
1468 update_curswant(); |
14485
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
1469 ins_apply_autocmds(EVENT_CURSORMOVEDI); |
8003
94798af62c56
commit https://github.com/vim/vim/commit/f068dcafcfe0c8018e5a559c50769ca1364bd9a5
Christian Brabandt <cb@256bit.org>
parents:
7817
diff
changeset
|
1470 } |
18763
49b78d6465e5
patch 8.1.2371: FEAT_TEXT_PROP is a confusing name
Bram Moolenaar <Bram@vim.org>
parents:
18717
diff
changeset
|
1471 #ifdef FEAT_PROP_POPUP |
16904
9138e2c60bf1
patch 8.1.1453: popup window "moved" property not implemented yet
Bram Moolenaar <Bram@vim.org>
parents:
16768
diff
changeset
|
1472 if (popup_visible) |
9138e2c60bf1
patch 8.1.1453: popup window "moved" property not implemented yet
Bram Moolenaar <Bram@vim.org>
parents:
16768
diff
changeset
|
1473 popup_check_cursor_pos(); |
9138e2c60bf1
patch 8.1.1453: popup window "moved" property not implemented yet
Bram Moolenaar <Bram@vim.org>
parents:
16768
diff
changeset
|
1474 #endif |
5592 | 1475 # ifdef FEAT_CONCEAL |
1476 if (curwin->w_p_cole > 0) | |
1477 { | |
1478 conceal_old_cursor_line = last_cursormoved.lnum; | |
1479 conceal_new_cursor_line = curwin->w_cursor.lnum; | |
1480 conceal_update_lines = TRUE; | |
1481 } | |
1482 # endif | |
1483 last_cursormoved = curwin->w_cursor; | |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
1484 } |
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
1485 |
25967
46205b125fbd
patch 8.2.3517: TextChanged does not trigger after TextChangedI
Bram Moolenaar <Bram@vim.org>
parents:
25866
diff
changeset
|
1486 // Trigger TextChangedI if b_changedtick_i differs. |
5592 | 1487 if (ready && has_textchangedI() |
25967
46205b125fbd
patch 8.2.3517: TextChanged does not trigger after TextChangedI
Bram Moolenaar <Bram@vim.org>
parents:
25866
diff
changeset
|
1488 && curbuf->b_last_changedtick_i != CHANGEDTICK(curbuf) |
17809
59f8948b7590
patch 8.1.1901: the +insert_expand feature is not always available
Bram Moolenaar <Bram@vim.org>
parents:
17775
diff
changeset
|
1489 && !pum_visible()) |
5592 | 1490 { |
14079
b5e43a048878
patch 8.1.0057: popup menu displayed wrong when using autocmd
Christian Brabandt <cb@256bit.org>
parents:
14071
diff
changeset
|
1491 aco_save_T aco; |
14485
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
1492 varnumber_T tick = CHANGEDTICK(curbuf); |
14463
3b87daa5c37a
patch 8.1.0245: calling setline() in TextChangedI autocmd breaks undo
Christian Brabandt <cb@256bit.org>
parents:
14457
diff
changeset
|
1493 |
31293
ff4473b3fc58
patch 9.0.0980: the keyboard state response may end up in a shell command
Bram Moolenaar <Bram@vim.org>
parents:
31192
diff
changeset
|
1494 // Save and restore curwin and curbuf, in case the autocmd changes |
ff4473b3fc58
patch 9.0.0980: the keyboard state response may end up in a shell command
Bram Moolenaar <Bram@vim.org>
parents:
31192
diff
changeset
|
1495 // them. |
14079
b5e43a048878
patch 8.1.0057: popup menu displayed wrong when using autocmd
Christian Brabandt <cb@256bit.org>
parents:
14071
diff
changeset
|
1496 aucmd_prepbuf(&aco, curbuf); |
13240
5ed6e4a25925
patch 8.0.1494: no autocmd triggered in Insert mode with visible popup menu
Christian Brabandt <cb@256bit.org>
parents:
13238
diff
changeset
|
1497 apply_autocmds(EVENT_TEXTCHANGEDI, NULL, NULL, FALSE, curbuf); |
14079
b5e43a048878
patch 8.1.0057: popup menu displayed wrong when using autocmd
Christian Brabandt <cb@256bit.org>
parents:
14071
diff
changeset
|
1498 aucmd_restbuf(&aco); |
25967
46205b125fbd
patch 8.2.3517: TextChanged does not trigger after TextChangedI
Bram Moolenaar <Bram@vim.org>
parents:
25866
diff
changeset
|
1499 curbuf->b_last_changedtick_i = CHANGEDTICK(curbuf); |
14485
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
1500 if (tick != CHANGEDTICK(curbuf)) // see ins_apply_autocmds() |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
1501 u_save(curwin->w_cursor.lnum, |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
1502 (linenr_T)(curwin->w_cursor.lnum + 1)); |
13240
5ed6e4a25925
patch 8.0.1494: no autocmd triggered in Insert mode with visible popup menu
Christian Brabandt <cb@256bit.org>
parents:
13238
diff
changeset
|
1503 } |
5ed6e4a25925
patch 8.0.1494: no autocmd triggered in Insert mode with visible popup menu
Christian Brabandt <cb@256bit.org>
parents:
13238
diff
changeset
|
1504 |
25967
46205b125fbd
patch 8.2.3517: TextChanged does not trigger after TextChangedI
Bram Moolenaar <Bram@vim.org>
parents:
25866
diff
changeset
|
1505 // Trigger TextChangedP if b_changedtick_pum differs. When the popupmenu |
46205b125fbd
patch 8.2.3517: TextChanged does not trigger after TextChangedI
Bram Moolenaar <Bram@vim.org>
parents:
25866
diff
changeset
|
1506 // closes TextChangedI will need to trigger for backwards compatibility, |
46205b125fbd
patch 8.2.3517: TextChanged does not trigger after TextChangedI
Bram Moolenaar <Bram@vim.org>
parents:
25866
diff
changeset
|
1507 // thus use different b_last_changedtick* variables. |
13240
5ed6e4a25925
patch 8.0.1494: no autocmd triggered in Insert mode with visible popup menu
Christian Brabandt <cb@256bit.org>
parents:
13238
diff
changeset
|
1508 if (ready && has_textchangedP() |
5ed6e4a25925
patch 8.0.1494: no autocmd triggered in Insert mode with visible popup menu
Christian Brabandt <cb@256bit.org>
parents:
13238
diff
changeset
|
1509 && curbuf->b_last_changedtick_pum != CHANGEDTICK(curbuf) |
5ed6e4a25925
patch 8.0.1494: no autocmd triggered in Insert mode with visible popup menu
Christian Brabandt <cb@256bit.org>
parents:
13238
diff
changeset
|
1510 && pum_visible()) |
5ed6e4a25925
patch 8.0.1494: no autocmd triggered in Insert mode with visible popup menu
Christian Brabandt <cb@256bit.org>
parents:
13238
diff
changeset
|
1511 { |
14079
b5e43a048878
patch 8.1.0057: popup menu displayed wrong when using autocmd
Christian Brabandt <cb@256bit.org>
parents:
14071
diff
changeset
|
1512 aco_save_T aco; |
14485
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
1513 varnumber_T tick = CHANGEDTICK(curbuf); |
14079
b5e43a048878
patch 8.1.0057: popup menu displayed wrong when using autocmd
Christian Brabandt <cb@256bit.org>
parents:
14071
diff
changeset
|
1514 |
31293
ff4473b3fc58
patch 9.0.0980: the keyboard state response may end up in a shell command
Bram Moolenaar <Bram@vim.org>
parents:
31192
diff
changeset
|
1515 // Save and restore curwin and curbuf, in case the autocmd changes |
ff4473b3fc58
patch 9.0.0980: the keyboard state response may end up in a shell command
Bram Moolenaar <Bram@vim.org>
parents:
31192
diff
changeset
|
1516 // them. |
14079
b5e43a048878
patch 8.1.0057: popup menu displayed wrong when using autocmd
Christian Brabandt <cb@256bit.org>
parents:
14071
diff
changeset
|
1517 aucmd_prepbuf(&aco, curbuf); |
13240
5ed6e4a25925
patch 8.0.1494: no autocmd triggered in Insert mode with visible popup menu
Christian Brabandt <cb@256bit.org>
parents:
13238
diff
changeset
|
1518 apply_autocmds(EVENT_TEXTCHANGEDP, NULL, NULL, FALSE, curbuf); |
14079
b5e43a048878
patch 8.1.0057: popup menu displayed wrong when using autocmd
Christian Brabandt <cb@256bit.org>
parents:
14071
diff
changeset
|
1519 aucmd_restbuf(&aco); |
13240
5ed6e4a25925
patch 8.0.1494: no autocmd triggered in Insert mode with visible popup menu
Christian Brabandt <cb@256bit.org>
parents:
13238
diff
changeset
|
1520 curbuf->b_last_changedtick_pum = CHANGEDTICK(curbuf); |
14485
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
1521 if (tick != CHANGEDTICK(curbuf)) // see ins_apply_autocmds() |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
1522 u_save(curwin->w_cursor.lnum, |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
1523 (linenr_T)(curwin->w_cursor.lnum + 1)); |
13240
5ed6e4a25925
patch 8.0.1494: no autocmd triggered in Insert mode with visible popup menu
Christian Brabandt <cb@256bit.org>
parents:
13238
diff
changeset
|
1524 } |
5592 | 1525 |
28375
e466fdbe0699
patch 8.2.4713: plugins cannot track text scrolling
Bram Moolenaar <Bram@vim.org>
parents:
28369
diff
changeset
|
1526 if (ready) |
31166
a86ee6c0309e
patch 9.0.0917: the WinScrolled autocommand event is not enough
Bram Moolenaar <Bram@vim.org>
parents:
31103
diff
changeset
|
1527 may_trigger_win_scrolled_resized(); |
28375
e466fdbe0699
patch 8.2.4713: plugins cannot track text scrolling
Bram Moolenaar <Bram@vim.org>
parents:
28369
diff
changeset
|
1528 |
18098
a2870e6f5b45
patch 8.1.2044: no easy way to process postponed work
Bram Moolenaar <Bram@vim.org>
parents:
17809
diff
changeset
|
1529 // Trigger SafeState if nothing is pending. |
a2870e6f5b45
patch 8.1.2044: no easy way to process postponed work
Bram Moolenaar <Bram@vim.org>
parents:
17809
diff
changeset
|
1530 may_trigger_safestate(ready |
a2870e6f5b45
patch 8.1.2044: no easy way to process postponed work
Bram Moolenaar <Bram@vim.org>
parents:
17809
diff
changeset
|
1531 && !ins_compl_active() |
a2870e6f5b45
patch 8.1.2044: no easy way to process postponed work
Bram Moolenaar <Bram@vim.org>
parents:
17809
diff
changeset
|
1532 && !pum_visible()); |
a2870e6f5b45
patch 8.1.2044: no easy way to process postponed work
Bram Moolenaar <Bram@vim.org>
parents:
17809
diff
changeset
|
1533 |
15436
29f3d59bb6f0
patch 8.1.0726: redrawing specifically for conceal feature
Bram Moolenaar <Bram@vim.org>
parents:
15416
diff
changeset
|
1534 #if defined(FEAT_CONCEAL) |
5592 | 1535 if ((conceal_update_lines |
1536 && (conceal_old_cursor_line != conceal_new_cursor_line | |
1537 || conceal_cursor_line(curwin))) | |
1538 || need_cursor_line_redraw) | |
1539 { | |
1540 if (conceal_old_cursor_line != conceal_new_cursor_line) | |
15436
29f3d59bb6f0
patch 8.1.0726: redrawing specifically for conceal feature
Bram Moolenaar <Bram@vim.org>
parents:
15416
diff
changeset
|
1541 redrawWinline(curwin, conceal_old_cursor_line); |
29f3d59bb6f0
patch 8.1.0726: redrawing specifically for conceal feature
Bram Moolenaar <Bram@vim.org>
parents:
15416
diff
changeset
|
1542 redrawWinline(curwin, conceal_new_cursor_line == 0 |
29f3d59bb6f0
patch 8.1.0726: redrawing specifically for conceal feature
Bram Moolenaar <Bram@vim.org>
parents:
15416
diff
changeset
|
1543 ? curwin->w_cursor.lnum : conceal_new_cursor_line); |
5592 | 1544 curwin->w_valid &= ~VALID_CROW; |
15436
29f3d59bb6f0
patch 8.1.0726: redrawing specifically for conceal feature
Bram Moolenaar <Bram@vim.org>
parents:
15416
diff
changeset
|
1545 need_cursor_line_redraw = FALSE; |
29f3d59bb6f0
patch 8.1.0726: redrawing specifically for conceal feature
Bram Moolenaar <Bram@vim.org>
parents:
15416
diff
changeset
|
1546 } |
29f3d59bb6f0
patch 8.1.0726: redrawing specifically for conceal feature
Bram Moolenaar <Bram@vim.org>
parents:
15416
diff
changeset
|
1547 #endif |
29f3d59bb6f0
patch 8.1.0726: redrawing specifically for conceal feature
Bram Moolenaar <Bram@vim.org>
parents:
15416
diff
changeset
|
1548 if (must_redraw) |
29f3d59bb6f0
patch 8.1.0726: redrawing specifically for conceal feature
Bram Moolenaar <Bram@vim.org>
parents:
15416
diff
changeset
|
1549 update_screen(0); |
29f3d59bb6f0
patch 8.1.0726: redrawing specifically for conceal feature
Bram Moolenaar <Bram@vim.org>
parents:
15416
diff
changeset
|
1550 else if (clear_cmdline || redraw_cmdline) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1551 showmode(); // clear cmdline and show mode |
5592 | 1552 showruler(FALSE); |
1553 setcursor(); | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1554 emsg_on_display = FALSE; // may remove error message now |
7 | 1555 } |
1556 | |
1557 /* | |
1558 * Handle a CTRL-V or CTRL-Q typed in Insert mode. | |
1559 */ | |
1560 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
1561 ins_ctrl_v(void) |
7 | 1562 { |
1563 int c; | |
2811 | 1564 int did_putchar = FALSE; |
7 | 1565 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1566 // may need to redraw when no more chars available now |
661 | 1567 ins_redraw(FALSE); |
7 | 1568 |
1569 if (redrawing() && !char_avail()) | |
2811 | 1570 { |
7 | 1571 edit_putchar('^', TRUE); |
2811 | 1572 did_putchar = TRUE; |
1573 } | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1574 AppendToRedobuff((char_u *)CTRL_V_STR); // CTRL-V |
7 | 1575 |
1576 add_to_showcmd_c(Ctrl_V); | |
1577 | |
23076
5fbac68bda23
patch 8.2.2084: CTRL-V U doesn't work to enter a Unicode character
Bram Moolenaar <Bram@vim.org>
parents:
22882
diff
changeset
|
1578 // Do not change any modifyOtherKeys ESC sequence to a normal key for |
5fbac68bda23
patch 8.2.2084: CTRL-V U doesn't work to enter a Unicode character
Bram Moolenaar <Bram@vim.org>
parents:
22882
diff
changeset
|
1579 // CTRL-SHIFT-V. |
5fbac68bda23
patch 8.2.2084: CTRL-V U doesn't work to enter a Unicode character
Bram Moolenaar <Bram@vim.org>
parents:
22882
diff
changeset
|
1580 c = get_literal(mod_mask & MOD_MASK_SHIFT); |
2811 | 1581 if (did_putchar) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1582 // when the line fits in 'columns' the '^' is at the start of the next |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1583 // line and will not removed by the redraw |
2811 | 1584 edit_unputchar(); |
7 | 1585 clear_showcmd(); |
18717
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1586 |
7 | 1587 insert_special(c, FALSE, TRUE); |
1588 #ifdef FEAT_RIGHTLEFT | |
1589 revins_chars++; | |
1590 revins_legal++; | |
1591 #endif | |
1592 } | |
1593 | |
1594 /* | |
18717
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1595 * After getting an ESC or CSI for a literal key: If the typeahead buffer |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1596 * contains a modifyOtherKeys sequence then decode it and return the result. |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1597 * Otherwise return "c". |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1598 * Note that this doesn't wait for characters, they must be in the typeahead |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1599 * buffer already. |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1600 */ |
25567
0082503ff2ff
patch 8.2.3320: some local functions are not static
Bram Moolenaar <Bram@vim.org>
parents:
25380
diff
changeset
|
1601 static int |
18717
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1602 decodeModifyOtherKeys(int c) |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1603 { |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1604 char_u *p = typebuf.tb_buf + typebuf.tb_off; |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1605 int idx; |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1606 int form = 0; |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1607 int argidx = 0; |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1608 int arg[2] = {0, 0}; |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1609 |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1610 // Recognize: |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1611 // form 0: {lead}{key};{modifier}u |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1612 // form 1: {lead}27;{modifier};{key}~ |
23664
aa8fa32cdca3
patch 8.2.2374: accessing uninitialized memory in test_undo
Bram Moolenaar <Bram@vim.org>
parents:
23076
diff
changeset
|
1613 if (typebuf.tb_len >= 4 && (c == CSI || (c == ESC && *p == '['))) |
18717
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1614 { |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1615 idx = (*p == '['); |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1616 if (p[idx] == '2' && p[idx + 1] == '7' && p[idx + 2] == ';') |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1617 { |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1618 form = 1; |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1619 idx += 3; |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1620 } |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1621 while (idx < typebuf.tb_len && argidx < 2) |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1622 { |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1623 if (p[idx] == ';') |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1624 ++argidx; |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1625 else if (VIM_ISDIGIT(p[idx])) |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1626 arg[argidx] = arg[argidx] * 10 + (p[idx] - '0'); |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1627 else |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1628 break; |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1629 ++idx; |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1630 } |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1631 if (idx < typebuf.tb_len |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1632 && p[idx] == (form == 1 ? '~' : 'u') |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1633 && argidx == 1) |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1634 { |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1635 // Match, consume the code. |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1636 typebuf.tb_off += idx + 1; |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1637 typebuf.tb_len -= idx + 1; |
19627
6b1564fcab92
patch 8.2.0370: the typebuf_was_filled flag is sometimes not reset
Bram Moolenaar <Bram@vim.org>
parents:
19151
diff
changeset
|
1638 #if defined(FEAT_CLIENTSERVER) || defined(FEAT_EVAL) |
6b1564fcab92
patch 8.2.0370: the typebuf_was_filled flag is sometimes not reset
Bram Moolenaar <Bram@vim.org>
parents:
19151
diff
changeset
|
1639 if (typebuf.tb_len == 0) |
6b1564fcab92
patch 8.2.0370: the typebuf_was_filled flag is sometimes not reset
Bram Moolenaar <Bram@vim.org>
parents:
19151
diff
changeset
|
1640 typebuf_was_filled = FALSE; |
6b1564fcab92
patch 8.2.0370: the typebuf_was_filled flag is sometimes not reset
Bram Moolenaar <Bram@vim.org>
parents:
19151
diff
changeset
|
1641 #endif |
18717
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1642 |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1643 mod_mask = decode_modifiers(arg[!form]); |
20727
5ffe112b1afd
patch 8.2.0916: mapping with partly modifyOtherKeys code does not work
Bram Moolenaar <Bram@vim.org>
parents:
20237
diff
changeset
|
1644 c = merge_modifyOtherKeys(arg[form], &mod_mask); |
18717
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1645 } |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1646 } |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1647 |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1648 return c; |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1649 } |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1650 |
14d2a210fab1
patch 8.1.2350: other text for CTRL-V in Insert mode with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18709
diff
changeset
|
1651 /* |
7 | 1652 * Put a character directly onto the screen. It's not stored in a buffer. |
1653 * Used while handling CTRL-K, CTRL-V, etc. in Insert mode. | |
1654 */ | |
1655 static int pc_status; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1656 #define PC_STATUS_UNSET 0 // pc_bytes was not set |
26771
fc859aea8cec
patch 8.2.3914: various spelling mistakes in comments
Bram Moolenaar <Bram@vim.org>
parents:
26598
diff
changeset
|
1657 #define PC_STATUS_RIGHT 1 // right half of double-wide char |
fc859aea8cec
patch 8.2.3914: various spelling mistakes in comments
Bram Moolenaar <Bram@vim.org>
parents:
26598
diff
changeset
|
1658 #define PC_STATUS_LEFT 2 // left half of double-wide char |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1659 #define PC_STATUS_SET 3 // pc_bytes was filled |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1660 static char_u pc_bytes[MB_MAXBYTES + 1]; // saved bytes |
7 | 1661 static int pc_attr; |
1662 static int pc_row; | |
1663 static int pc_col; | |
1664 | |
1665 void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
1666 edit_putchar(int c, int highlight) |
7 | 1667 { |
1668 int attr; | |
1669 | |
31545
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1670 if (ScreenLines == NULL) |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1671 return; |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1672 |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1673 update_topline(); // just in case w_topline isn't valid |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1674 validate_cursor(); |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1675 if (highlight) |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1676 attr = HL_ATTR(HLF_8); |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1677 else |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1678 attr = 0; |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1679 pc_row = W_WINROW(curwin) + curwin->w_wrow; |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1680 pc_col = curwin->w_wincol; |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1681 pc_status = PC_STATUS_UNSET; |
7 | 1682 #ifdef FEAT_RIGHTLEFT |
31545
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1683 if (curwin->w_p_rl) |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1684 { |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1685 pc_col += curwin->w_width - 1 - curwin->w_wcol; |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1686 if (has_mbyte) |
7 | 1687 { |
31545
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1688 int fix_col = mb_fix_col(pc_col, pc_row); |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1689 |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1690 if (fix_col != pc_col) |
7 | 1691 { |
31545
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1692 screen_putchar(' ', pc_row, fix_col, attr); |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1693 --curwin->w_wcol; |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1694 pc_status = PC_STATUS_RIGHT; |
7 | 1695 } |
1696 } | |
31545
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1697 } |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1698 else |
7 | 1699 #endif |
31545
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1700 { |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1701 pc_col += curwin->w_wcol; |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1702 if (mb_lefthalve(pc_row, pc_col)) |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1703 pc_status = PC_STATUS_LEFT; |
7 | 1704 } |
31545
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1705 |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1706 // save the character to be able to put it back |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1707 if (pc_status == PC_STATUS_UNSET) |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1708 { |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1709 screen_getbytes(pc_row, pc_col, pc_bytes, &pc_attr); |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1710 pc_status = PC_STATUS_SET; |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1711 } |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1712 screen_putchar(c, pc_row, pc_col, attr); |
7 | 1713 } |
1714 | |
27018
268f6a3511df
patch 8.2.4038: various code not used when features are disabled
Bram Moolenaar <Bram@vim.org>
parents:
26944
diff
changeset
|
1715 #if defined(FEAT_JOB_CHANNEL) || defined(PROTO) |
14019
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1716 /* |
22095
2cc0de1e05a6
patch 8.2.1597: the channel source file is too big
Bram Moolenaar <Bram@vim.org>
parents:
22091
diff
changeset
|
1717 * Set the insert start position for when using a prompt buffer. |
22077
335365fcbb60
patch 8.2.1588: cannot read back the prompt of a prompt buffer
Bram Moolenaar <Bram@vim.org>
parents:
20727
diff
changeset
|
1718 */ |
22095
2cc0de1e05a6
patch 8.2.1597: the channel source file is too big
Bram Moolenaar <Bram@vim.org>
parents:
22091
diff
changeset
|
1719 void |
2cc0de1e05a6
patch 8.2.1597: the channel source file is too big
Bram Moolenaar <Bram@vim.org>
parents:
22091
diff
changeset
|
1720 set_insstart(linenr_T lnum, int col) |
14019
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1721 { |
22095
2cc0de1e05a6
patch 8.2.1597: the channel source file is too big
Bram Moolenaar <Bram@vim.org>
parents:
22091
diff
changeset
|
1722 Insstart.lnum = lnum; |
2cc0de1e05a6
patch 8.2.1597: the channel source file is too big
Bram Moolenaar <Bram@vim.org>
parents:
22091
diff
changeset
|
1723 Insstart.col = col; |
2cc0de1e05a6
patch 8.2.1597: the channel source file is too big
Bram Moolenaar <Bram@vim.org>
parents:
22091
diff
changeset
|
1724 Insstart_orig = Insstart; |
2cc0de1e05a6
patch 8.2.1597: the channel source file is too big
Bram Moolenaar <Bram@vim.org>
parents:
22091
diff
changeset
|
1725 Insstart_textlen = Insstart.col; |
2cc0de1e05a6
patch 8.2.1597: the channel source file is too big
Bram Moolenaar <Bram@vim.org>
parents:
22091
diff
changeset
|
1726 Insstart_blank_vcol = MAXCOL; |
2cc0de1e05a6
patch 8.2.1597: the channel source file is too big
Bram Moolenaar <Bram@vim.org>
parents:
22091
diff
changeset
|
1727 arrow_used = FALSE; |
14019
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1728 } |
27018
268f6a3511df
patch 8.2.4038: various code not used when features are disabled
Bram Moolenaar <Bram@vim.org>
parents:
26944
diff
changeset
|
1729 #endif |
14019
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1730 |
dc67449d648c
patch 8.1.0027: difficult to make a plugin that feeds a line to a job
Christian Brabandt <cb@256bit.org>
parents:
14004
diff
changeset
|
1731 /* |
7 | 1732 * Undo the previous edit_putchar(). |
1733 */ | |
1734 void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
1735 edit_unputchar(void) |
7 | 1736 { |
1737 if (pc_status != PC_STATUS_UNSET && pc_row >= msg_scrolled) | |
1738 { | |
1739 if (pc_status == PC_STATUS_RIGHT) | |
1740 ++curwin->w_wcol; | |
1741 if (pc_status == PC_STATUS_RIGHT || pc_status == PC_STATUS_LEFT) | |
15400
ac5542aadd9c
patch 8.1.0708: third argument for redrawWinline() is always FALSE
Bram Moolenaar <Bram@vim.org>
parents:
15382
diff
changeset
|
1742 redrawWinline(curwin, curwin->w_cursor.lnum); |
7 | 1743 else |
1744 screen_puts(pc_bytes, pc_row - msg_scrolled, pc_col, pc_attr); | |
1745 } | |
1746 } | |
1747 | |
1748 /* | |
30659
ea16b081493d
patch 9.0.0664: bad redrawing with spell checking, using "C" and "$" in 'cpo'
Bram Moolenaar <Bram@vim.org>
parents:
30645
diff
changeset
|
1749 * Called when "$" is in 'cpoptions': display a '$' at the end of the changed |
ea16b081493d
patch 9.0.0664: bad redrawing with spell checking, using "C" and "$" in 'cpo'
Bram Moolenaar <Bram@vim.org>
parents:
30645
diff
changeset
|
1750 * text. Only works when cursor is in the line that changes. |
7 | 1751 */ |
1752 void | |
29757
beab53bb989e
patch 9.0.0218: reading before the start of the line
Bram Moolenaar <Bram@vim.org>
parents:
29732
diff
changeset
|
1753 display_dollar(colnr_T col_arg) |
7 | 1754 { |
29757
beab53bb989e
patch 9.0.0218: reading before the start of the line
Bram Moolenaar <Bram@vim.org>
parents:
29732
diff
changeset
|
1755 colnr_T col = col_arg < 0 ? 0 : col_arg; |
7 | 1756 colnr_T save_col; |
1757 | |
1758 if (!redrawing()) | |
1759 return; | |
1760 | |
1761 cursor_off(); | |
1762 save_col = curwin->w_cursor.col; | |
1763 curwin->w_cursor.col = col; | |
1764 if (has_mbyte) | |
1765 { | |
1766 char_u *p; | |
1767 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1768 // If on the last byte of a multi-byte move to the first byte. |
7 | 1769 p = ml_get_curline(); |
1770 curwin->w_cursor.col -= (*mb_head_off)(p, p + col); | |
1771 } | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1772 curs_columns(FALSE); // recompute w_wrow and w_wcol |
12515
972ea22c946f
patch 8.0.1136: W_WIDTH() is always the same
Christian Brabandt <cb@256bit.org>
parents:
12513
diff
changeset
|
1773 if (curwin->w_wcol < curwin->w_width) |
7 | 1774 { |
1775 edit_putchar('$', FALSE); | |
1776 dollar_vcol = curwin->w_virtcol; | |
1777 } | |
1778 curwin->w_cursor.col = save_col; | |
1779 } | |
1780 | |
1781 /* | |
1782 * Call this function before moving the cursor from the normal insert position | |
1783 * in insert mode. | |
1784 */ | |
18135
1868ec23360e
patch 8.1.2062: the mouse code is spread out
Bram Moolenaar <Bram@vim.org>
parents:
18098
diff
changeset
|
1785 void |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
1786 undisplay_dollar(void) |
7 | 1787 { |
31545
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1788 if (dollar_vcol < 0) |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1789 return; |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1790 |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1791 dollar_vcol = -1; |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
1792 redrawWinline(curwin, curwin->w_cursor.lnum); |
7 | 1793 } |
1794 | |
1795 /* | |
1796 * Truncate the space at the end of a line. This is to be used only in an | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
1797 * insert mode. It handles fixing the replace stack for MODE_REPLACE and |
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
1798 * MODE_VREPLACE modes. |
7 | 1799 */ |
1800 void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
1801 truncate_spaces(char_u *line) |
7 | 1802 { |
1803 int i; | |
1804 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1805 // find start of trailing white space |
11129
f4ea50924c6d
patch 8.0.0452: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents:
11127
diff
changeset
|
1806 for (i = (int)STRLEN(line) - 1; i >= 0 && VIM_ISWHITE(line[i]); i--) |
7 | 1807 { |
1808 if (State & REPLACE_FLAG) | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1809 replace_join(0); // remove a NUL from the replace stack |
7 | 1810 } |
1811 line[i + 1] = NUL; | |
1812 } | |
1813 | |
1814 /* | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
1815 * Backspace the cursor until the given column. Handles MODE_REPLACE and |
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
1816 * MODE_VREPLACE modes correctly. May also be used when not in insert mode at |
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
1817 * all. Will attempt not to go before "col" even when there is a composing |
1782 | 1818 * character. |
7 | 1819 */ |
1820 void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
1821 backspace_until_column(int col) |
7 | 1822 { |
1823 while ((int)curwin->w_cursor.col > col) | |
1824 { | |
1825 curwin->w_cursor.col--; | |
1826 if (State & REPLACE_FLAG) | |
1782 | 1827 replace_do_bs(col); |
1828 else if (!del_char_after_col(col)) | |
1829 break; | |
1830 } | |
1831 } | |
1832 | |
1833 /* | |
1834 * Like del_char(), but make sure not to go before column "limit_col". | |
1835 * Only matters when there are composing characters. | |
1836 * Return TRUE when something was deleted. | |
1837 */ | |
1838 static int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
1839 del_char_after_col(int limit_col UNUSED) |
1782 | 1840 { |
1841 if (enc_utf8 && limit_col >= 0) | |
1842 { | |
1869 | 1843 colnr_T ecol = curwin->w_cursor.col + 1; |
1782 | 1844 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1845 // Make sure the cursor is at the start of a character, but |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1846 // skip forward again when going too far back because of a |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1847 // composing character. |
1782 | 1848 mb_adjust_cursor(); |
1796 | 1849 while (curwin->w_cursor.col < (colnr_T)limit_col) |
1782 | 1850 { |
1851 int l = utf_ptr2len(ml_get_cursor()); | |
1852 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1853 if (l == 0) // end of line |
1782 | 1854 break; |
1855 curwin->w_cursor.col += l; | |
1856 } | |
1857 if (*ml_get_cursor() == NUL || curwin->w_cursor.col == ecol) | |
1858 return FALSE; | |
1869 | 1859 del_bytes((long)((int)ecol - curwin->w_cursor.col), FALSE, TRUE); |
1782 | 1860 } |
1861 else | |
1862 (void)del_char(FALSE); | |
1863 return TRUE; | |
1864 } | |
7 | 1865 |
1866 /* | |
1867 * Next character is interpreted literally. | |
1868 * A one, two or three digit decimal number is interpreted as its byte value. | |
1869 * If one or two digits are entered, the next character is given to vungetc(). | |
1870 * For Unicode a character > 255 may be returned. | |
23076
5fbac68bda23
patch 8.2.2084: CTRL-V U doesn't work to enter a Unicode character
Bram Moolenaar <Bram@vim.org>
parents:
22882
diff
changeset
|
1871 * If "noReduceKeys" is TRUE do not change any modifyOtherKeys ESC sequence |
5fbac68bda23
patch 8.2.2084: CTRL-V U doesn't work to enter a Unicode character
Bram Moolenaar <Bram@vim.org>
parents:
22882
diff
changeset
|
1872 * into a normal key, return ESC. |
7 | 1873 */ |
1874 int | |
23076
5fbac68bda23
patch 8.2.2084: CTRL-V U doesn't work to enter a Unicode character
Bram Moolenaar <Bram@vim.org>
parents:
22882
diff
changeset
|
1875 get_literal(int noReduceKeys) |
7 | 1876 { |
1877 int cc; | |
1878 int nc; | |
1879 int i; | |
1880 int hex = FALSE; | |
1881 int octal = FALSE; | |
1882 int unicode = 0; | |
1883 | |
1884 if (got_int) | |
1885 return Ctrl_C; | |
1886 | |
1887 #ifdef FEAT_GUI | |
1888 /* | |
1889 * In GUI there is no point inserting the internal code for a special key. | |
1890 * It is more useful to insert the string "<KEY>" instead. This would | |
1891 * probably be useful in a text window too, but it would not be | |
1892 * vi-compatible (maybe there should be an option for it?) -- webb | |
1893 */ | |
1894 if (gui.in_use) | |
28644
0c63014c2513
patch 8.2.4846: termcodes test fails
Bram Moolenaar <Bram@vim.org>
parents:
28457
diff
changeset
|
1895 { |
7 | 1896 ++allow_keys; |
28644
0c63014c2513
patch 8.2.4846: termcodes test fails
Bram Moolenaar <Bram@vim.org>
parents:
28457
diff
changeset
|
1897 if (noReduceKeys) |
0c63014c2513
patch 8.2.4846: termcodes test fails
Bram Moolenaar <Bram@vim.org>
parents:
28457
diff
changeset
|
1898 ++no_reduce_keys; |
0c63014c2513
patch 8.2.4846: termcodes test fails
Bram Moolenaar <Bram@vim.org>
parents:
28457
diff
changeset
|
1899 } |
7 | 1900 #endif |
1901 #ifdef USE_ON_FLY_SCROLL | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1902 dont_scroll = TRUE; // disallow scrolling here |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1903 #endif |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1904 ++no_mapping; // don't map the next key hits |
7 | 1905 cc = 0; |
1906 i = 0; | |
1907 for (;;) | |
1908 { | |
1389 | 1909 nc = plain_vgetc(); |
23076
5fbac68bda23
patch 8.2.2084: CTRL-V U doesn't work to enter a Unicode character
Bram Moolenaar <Bram@vim.org>
parents:
22882
diff
changeset
|
1910 if ((nc == ESC || nc == CSI) && !noReduceKeys) |
5fbac68bda23
patch 8.2.2084: CTRL-V U doesn't work to enter a Unicode character
Bram Moolenaar <Bram@vim.org>
parents:
22882
diff
changeset
|
1911 nc = decodeModifyOtherKeys(nc); |
5fbac68bda23
patch 8.2.2084: CTRL-V U doesn't work to enter a Unicode character
Bram Moolenaar <Bram@vim.org>
parents:
22882
diff
changeset
|
1912 |
27350
63179e8300f8
patch 8.2.4203: entering a character with CTRL-V may include modifiers
Bram Moolenaar <Bram@vim.org>
parents:
27140
diff
changeset
|
1913 if ((mod_mask & ~MOD_MASK_SHIFT) != 0) |
63179e8300f8
patch 8.2.4203: entering a character with CTRL-V may include modifiers
Bram Moolenaar <Bram@vim.org>
parents:
27140
diff
changeset
|
1914 // A character with non-Shift modifiers should not be a valid |
63179e8300f8
patch 8.2.4203: entering a character with CTRL-V may include modifiers
Bram Moolenaar <Bram@vim.org>
parents:
27140
diff
changeset
|
1915 // character for i_CTRL-V_digit. |
63179e8300f8
patch 8.2.4203: entering a character with CTRL-V may include modifiers
Bram Moolenaar <Bram@vim.org>
parents:
27140
diff
changeset
|
1916 break; |
63179e8300f8
patch 8.2.4203: entering a character with CTRL-V may include modifiers
Bram Moolenaar <Bram@vim.org>
parents:
27140
diff
changeset
|
1917 |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
1918 if ((State & MODE_CMDLINE) == 0 && MB_BYTE2LEN_CHECK(nc) == 1) |
7 | 1919 add_to_showcmd(nc); |
1920 if (nc == 'x' || nc == 'X') | |
1921 hex = TRUE; | |
1922 else if (nc == 'o' || nc == 'O') | |
1923 octal = TRUE; | |
1924 else if (nc == 'u' || nc == 'U') | |
1925 unicode = nc; | |
1926 else | |
1927 { | |
15595
1ec942f1b648
patch 8.1.0805: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15569
diff
changeset
|
1928 if (hex || unicode != 0) |
7 | 1929 { |
1930 if (!vim_isxdigit(nc)) | |
1931 break; | |
1932 cc = cc * 16 + hex2nr(nc); | |
1933 } | |
1934 else if (octal) | |
1935 { | |
1936 if (nc < '0' || nc > '7') | |
1937 break; | |
1938 cc = cc * 8 + nc - '0'; | |
1939 } | |
1940 else | |
1941 { | |
1942 if (!VIM_ISDIGIT(nc)) | |
1943 break; | |
1944 cc = cc * 10 + nc - '0'; | |
1945 } | |
1946 | |
1947 ++i; | |
1948 } | |
1949 | |
15595
1ec942f1b648
patch 8.1.0805: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15569
diff
changeset
|
1950 if (cc > 255 && unicode == 0) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1951 cc = 255; // limit range to 0-255 |
7 | 1952 nc = 0; |
1953 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1954 if (hex) // hex: up to two chars |
7 | 1955 { |
1956 if (i >= 2) | |
1957 break; | |
1958 } | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1959 else if (unicode) // Unicode: up to four or eight chars |
7 | 1960 { |
1961 if ((unicode == 'u' && i >= 4) || (unicode == 'U' && i >= 8)) | |
1962 break; | |
1963 } | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1964 else if (i >= 3) // decimal or octal: up to three chars |
7 | 1965 break; |
1966 } | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1967 if (i == 0) // no number entered |
7 | 1968 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1969 if (nc == K_ZERO) // NUL is stored as NL |
7 | 1970 { |
1971 cc = '\n'; | |
1972 nc = 0; | |
1973 } | |
1974 else | |
1975 { | |
1976 cc = nc; | |
1977 nc = 0; | |
1978 } | |
1979 } | |
1980 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1981 if (cc == 0) // NUL is stored as NL |
7 | 1982 cc = '\n'; |
221 | 1983 if (enc_dbcs && (cc & 0xff) == 0) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1984 cc = '?'; // don't accept an illegal DBCS char, the NUL in the |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
1985 // second byte will cause trouble! |
7 | 1986 |
1987 --no_mapping; | |
1988 #ifdef FEAT_GUI | |
1989 if (gui.in_use) | |
28644
0c63014c2513
patch 8.2.4846: termcodes test fails
Bram Moolenaar <Bram@vim.org>
parents:
28457
diff
changeset
|
1990 { |
7 | 1991 --allow_keys; |
28644
0c63014c2513
patch 8.2.4846: termcodes test fails
Bram Moolenaar <Bram@vim.org>
parents:
28457
diff
changeset
|
1992 if (noReduceKeys) |
0c63014c2513
patch 8.2.4846: termcodes test fails
Bram Moolenaar <Bram@vim.org>
parents:
28457
diff
changeset
|
1993 --no_reduce_keys; |
0c63014c2513
patch 8.2.4846: termcodes test fails
Bram Moolenaar <Bram@vim.org>
parents:
28457
diff
changeset
|
1994 } |
7 | 1995 #endif |
1996 if (nc) | |
27350
63179e8300f8
patch 8.2.4203: entering a character with CTRL-V may include modifiers
Bram Moolenaar <Bram@vim.org>
parents:
27140
diff
changeset
|
1997 { |
7 | 1998 vungetc(nc); |
27350
63179e8300f8
patch 8.2.4203: entering a character with CTRL-V may include modifiers
Bram Moolenaar <Bram@vim.org>
parents:
27140
diff
changeset
|
1999 // A character typed with i_CTRL-V_digit cannot have modifiers. |
63179e8300f8
patch 8.2.4203: entering a character with CTRL-V may include modifiers
Bram Moolenaar <Bram@vim.org>
parents:
27140
diff
changeset
|
2000 mod_mask = 0; |
63179e8300f8
patch 8.2.4203: entering a character with CTRL-V may include modifiers
Bram Moolenaar <Bram@vim.org>
parents:
27140
diff
changeset
|
2001 } |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2002 got_int = FALSE; // CTRL-C typed after CTRL-V is not an interrupt |
7 | 2003 return cc; |
2004 } | |
2005 | |
2006 /* | |
2007 * Insert character, taking care of special keys and mod_mask | |
2008 */ | |
2009 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2010 insert_special( |
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2011 int c, |
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2012 int allow_modmask, |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2013 int ctrlv) // c was typed after CTRL-V |
7 | 2014 { |
2015 char_u *p; | |
2016 int len; | |
2017 | |
2018 /* | |
2019 * Special function key, translate into "<Key>". Up to the last '>' is | |
2020 * inserted with ins_str(), so as not to replace characters in replace | |
2021 * mode. | |
2022 * Only use mod_mask for special keys, to avoid things like <S-Space>, | |
2023 * unless 'allow_modmask' is TRUE. | |
2024 */ | |
12716
351cf7c67bbe
patch 8.0.1236: Mac features are confusing
Christian Brabandt <cb@256bit.org>
parents:
12674
diff
changeset
|
2025 #ifdef MACOS_X |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2026 // Command-key never produces a normal key |
7 | 2027 if (mod_mask & MOD_MASK_CMD) |
2028 allow_modmask = TRUE; | |
2029 #endif | |
2030 if (IS_SPECIAL(c) || (mod_mask && allow_modmask)) | |
2031 { | |
2032 p = get_special_key_name(c, mod_mask); | |
2033 len = (int)STRLEN(p); | |
2034 c = p[len - 1]; | |
2035 if (len > 2) | |
2036 { | |
2037 if (stop_arrow() == FAIL) | |
2038 return; | |
2039 p[len - 1] = NUL; | |
2040 ins_str(p); | |
620 | 2041 AppendToRedobuffLit(p, -1); |
7 | 2042 ctrlv = FALSE; |
2043 } | |
2044 } | |
2045 if (stop_arrow() == OK) | |
2046 insertchar(c, ctrlv ? INSCHAR_CTRLV : 0, -1); | |
2047 } | |
2048 | |
2049 /* | |
2050 * Special characters in this context are those that need processing other | |
2051 * than the simple insertion that can be performed here. This includes ESC | |
2052 * which terminates the insert, and CR/NL which need special processing to | |
2053 * open up a new line. This routine tries to optimize insertions performed by | |
2054 * the "redo", "undo" or "put" commands, so it needs to know when it should | |
2055 * stop and defer processing to the "normal" mechanism. | |
2056 * '0' and '^' are special, because they can be followed by CTRL-D. | |
2057 */ | |
27490
fb4c30606b4a
patch 8.2.4273: the EBCDIC support is outdated
Bram Moolenaar <Bram@vim.org>
parents:
27426
diff
changeset
|
2058 #define ISSPECIAL(c) ((c) < ' ' || (c) >= DEL || (c) == '0' || (c) == '^') |
7 | 2059 |
3584 | 2060 /* |
2061 * "flags": INSCHAR_FORMAT - force formatting | |
2062 * INSCHAR_CTRLV - char typed just after CTRL-V | |
2063 * INSCHAR_NO_FEX - don't use 'formatexpr' | |
2064 * | |
2065 * NOTE: passes the flags value straight through to internal_format() which, | |
2066 * beside INSCHAR_FORMAT (above), is also looking for these: | |
2067 * INSCHAR_DO_COM - format comments | |
2068 * INSCHAR_COM_LIST - format comments with num list or 2nd line indent | |
2069 */ | |
7 | 2070 void |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2071 insertchar( |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2072 int c, // character to insert or NUL |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2073 int flags, // INSCHAR_FORMAT, etc. |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2074 int second_indent) // indent for second line if >= 0 |
7 | 2075 { |
2076 int textwidth; | |
2077 char_u *p; | |
2078 int fo_ins_blank; | |
6667 | 2079 int force_format = flags & INSCHAR_FORMAT; |
2080 | |
2081 textwidth = comp_textwidth(force_format); | |
7 | 2082 fo_ins_blank = has_format_option(FO_INS_BLANK); |
2083 | |
2084 /* | |
2085 * Try to break the line in two or more pieces when: | |
2086 * - Always do this if we have been called to do formatting only. | |
2087 * - Always do this when 'formatoptions' has the 'a' flag and the line | |
2088 * ends in white space. | |
2089 * - Otherwise: | |
2090 * - Don't do this if inserting a blank | |
2091 * - Don't do this if an existing character is being replaced, unless | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
2092 * we're in MODE_VREPLACE state. |
7 | 2093 * - Do this if the cursor is not on the line where insert started |
2094 * or - 'formatoptions' doesn't have 'l' or the line was not too long | |
2095 * before the insert. | |
2096 * - 'formatoptions' doesn't have 'b' or a blank was inserted at or | |
2097 * before 'textwidth' | |
2098 */ | |
667 | 2099 if (textwidth > 0 |
6667 | 2100 && (force_format |
11129
f4ea50924c6d
patch 8.0.0452: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents:
11127
diff
changeset
|
2101 || (!VIM_ISWHITE(c) |
7 | 2102 && !((State & REPLACE_FLAG) |
2103 && !(State & VREPLACE_FLAG) | |
2104 && *ml_get_cursor() != NUL) | |
2105 && (curwin->w_cursor.lnum != Insstart.lnum | |
2106 || ((!has_format_option(FO_INS_LONG) | |
2107 || Insstart_textlen <= (colnr_T)textwidth) | |
2108 && (!fo_ins_blank | |
2109 || Insstart_blank_vcol <= (colnr_T)textwidth | |
2110 )))))) | |
2111 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2112 // Format with 'formatexpr' when it's set. Use internal formatting |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2113 // when 'formatexpr' isn't set or it returns non-zero. |
667 | 2114 #if defined(FEAT_EVAL) |
6667 | 2115 int do_internal = TRUE; |
2116 colnr_T virtcol = get_nolist_virtcol() | |
2117 + char2cells(c != NUL ? c : gchar_cursor()); | |
2118 | |
2119 if (*curbuf->b_p_fex != NUL && (flags & INSCHAR_NO_FEX) == 0 | |
2120 && (force_format || virtcol > (colnr_T)textwidth)) | |
1000 | 2121 { |
2122 do_internal = (fex_format(curwin->w_cursor.lnum, 1L, c) != 0); | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2123 // It may be required to save for undo again, e.g. when setline() |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2124 // was called. |
1000 | 2125 ins_need_undo = TRUE; |
2126 } | |
2127 if (do_internal) | |
667 | 2128 #endif |
2004 | 2129 internal_format(textwidth, second_indent, flags, c == NUL, c); |
667 | 2130 } |
2131 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2132 if (c == NUL) // only formatting was wanted |
7 | 2133 return; |
2134 | |
18203
e0ec4cd7a865
patch 8.1.2096: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
18135
diff
changeset
|
2135 // Check whether this character should end a comment. |
27426
41e0dcf38521
patch 8.2.4241: some type casts are redundant
Bram Moolenaar <Bram@vim.org>
parents:
27380
diff
changeset
|
2136 if (did_ai && c == end_comment_pending) |
7 | 2137 { |
2138 char_u *line; | |
18203
e0ec4cd7a865
patch 8.1.2096: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
18135
diff
changeset
|
2139 char_u lead_end[COM_MAX_LEN]; // end-comment string |
7 | 2140 int middle_len, end_len; |
2141 int i; | |
2142 | |
2143 /* | |
2144 * Need to remove existing (middle) comment leader and insert end | |
2145 * comment leader. First, check what comment leader we can find. | |
2146 */ | |
3562 | 2147 i = get_leader_len(line = ml_get_curline(), &p, FALSE, TRUE); |
18203
e0ec4cd7a865
patch 8.1.2096: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
18135
diff
changeset
|
2148 if (i > 0 && vim_strchr(p, COM_MIDDLE) != NULL) // Just checking |
7 | 2149 { |
18203
e0ec4cd7a865
patch 8.1.2096: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
18135
diff
changeset
|
2150 // Skip middle-comment string |
e0ec4cd7a865
patch 8.1.2096: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
18135
diff
changeset
|
2151 while (*p && p[-1] != ':') // find end of middle flags |
7 | 2152 ++p; |
2153 middle_len = copy_option_part(&p, lead_end, COM_MAX_LEN, ","); | |
18203
e0ec4cd7a865
patch 8.1.2096: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
18135
diff
changeset
|
2154 // Don't count trailing white space for middle_len |
11129
f4ea50924c6d
patch 8.0.0452: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents:
11127
diff
changeset
|
2155 while (middle_len > 0 && VIM_ISWHITE(lead_end[middle_len - 1])) |
7 | 2156 --middle_len; |
2157 | |
18203
e0ec4cd7a865
patch 8.1.2096: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
18135
diff
changeset
|
2158 // Find the end-comment string |
e0ec4cd7a865
patch 8.1.2096: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
18135
diff
changeset
|
2159 while (*p && p[-1] != ':') // find end of end flags |
7 | 2160 ++p; |
2161 end_len = copy_option_part(&p, lead_end, COM_MAX_LEN, ","); | |
2162 | |
18203
e0ec4cd7a865
patch 8.1.2096: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
18135
diff
changeset
|
2163 // Skip white space before the cursor |
7 | 2164 i = curwin->w_cursor.col; |
11129
f4ea50924c6d
patch 8.0.0452: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents:
11127
diff
changeset
|
2165 while (--i >= 0 && VIM_ISWHITE(line[i])) |
7 | 2166 ; |
2167 i++; | |
2168 | |
18203
e0ec4cd7a865
patch 8.1.2096: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
18135
diff
changeset
|
2169 // Skip to before the middle leader |
7 | 2170 i -= middle_len; |
2171 | |
18203
e0ec4cd7a865
patch 8.1.2096: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
18135
diff
changeset
|
2172 // Check some expected things before we go on |
7 | 2173 if (i >= 0 && lead_end[end_len - 1] == end_comment_pending) |
2174 { | |
18203
e0ec4cd7a865
patch 8.1.2096: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
18135
diff
changeset
|
2175 // Backspace over all the stuff we want to replace |
7 | 2176 backspace_until_column(i); |
2177 | |
18203
e0ec4cd7a865
patch 8.1.2096: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
18135
diff
changeset
|
2178 // Insert the end-comment string, except for the last |
e0ec4cd7a865
patch 8.1.2096: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
18135
diff
changeset
|
2179 // character, which will get inserted as normal later. |
7 | 2180 ins_bytes_len(lead_end, end_len - 1); |
2181 } | |
2182 } | |
2183 } | |
2184 end_comment_pending = NUL; | |
2185 | |
2186 did_ai = FALSE; | |
2187 did_si = FALSE; | |
2188 can_si = FALSE; | |
2189 can_si_back = FALSE; | |
2190 | |
2191 /* | |
2192 * If there's any pending input, grab up to INPUT_BUFLEN at once. | |
2193 * This speeds up normal text input considerably. | |
2194 * Don't do this when 'cindent' or 'indentexpr' is set, because we might | |
2195 * need to re-indent at a ':', or any other character (but not what | |
2196 * 'paste' is set).. | |
3390 | 2197 * Don't do this when there an InsertCharPre autocommand is defined, |
2198 * because we need to fire the event for every character. | |
13870
08370aad873d
patch 8.0.1806: InsertCharPre causes problems for autocomplete
Christian Brabandt <cb@256bit.org>
parents:
13788
diff
changeset
|
2199 * Do the check for InsertCharPre before the call to vpeekc() because the |
08370aad873d
patch 8.0.1806: InsertCharPre causes problems for autocomplete
Christian Brabandt <cb@256bit.org>
parents:
13788
diff
changeset
|
2200 * InsertCharPre autocommand could change the input buffer. |
7 | 2201 */ |
2202 #ifdef USE_ON_FLY_SCROLL | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2203 dont_scroll = FALSE; // allow scrolling here |
7 | 2204 #endif |
2205 | |
2206 if ( !ISSPECIAL(c) | |
2207 && (!has_mbyte || (*mb_char2len)(c) == 1) | |
13870
08370aad873d
patch 8.0.1806: InsertCharPre causes problems for autocomplete
Christian Brabandt <cb@256bit.org>
parents:
13788
diff
changeset
|
2208 && !has_insertcharpre() |
7 | 2209 && vpeekc() != NUL |
2210 && !(State & REPLACE_FLAG) | |
2211 && !cindent_on() | |
2212 #ifdef FEAT_RIGHTLEFT | |
2213 && !p_ri | |
2214 #endif | |
13870
08370aad873d
patch 8.0.1806: InsertCharPre causes problems for autocomplete
Christian Brabandt <cb@256bit.org>
parents:
13788
diff
changeset
|
2215 ) |
7 | 2216 { |
2217 #define INPUT_BUFLEN 100 | |
2218 char_u buf[INPUT_BUFLEN + 1]; | |
2219 int i; | |
2220 colnr_T virtcol = 0; | |
2221 | |
2222 buf[0] = c; | |
2223 i = 1; | |
667 | 2224 if (textwidth > 0) |
7 | 2225 virtcol = get_nolist_virtcol(); |
2226 /* | |
2227 * Stop the string when: | |
2228 * - no more chars available | |
2229 * - finding a special character (command key) | |
2230 * - buffer is full | |
2231 * - running into the 'textwidth' boundary | |
2232 * - need to check for abbreviation: A non-word char after a word-char | |
2233 */ | |
2234 while ( (c = vpeekc()) != NUL | |
2235 && !ISSPECIAL(c) | |
2236 && (!has_mbyte || MB_BYTE2LEN_CHECK(c) == 1) | |
2237 && i < INPUT_BUFLEN | |
2238 && (textwidth == 0 | |
2239 || (virtcol += byte2cells(buf[i - 1])) < (colnr_T)textwidth) | |
2240 && !(!no_abbr && !vim_iswordc(c) && vim_iswordc(buf[i - 1]))) | |
2241 { | |
2242 #ifdef FEAT_RIGHTLEFT | |
2243 c = vgetc(); | |
2244 if (p_hkmap && KeyTyped) | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2245 c = hkmap(c); // Hebrew mode mapping |
7 | 2246 buf[i++] = c; |
2247 #else | |
2248 buf[i++] = vgetc(); | |
2249 #endif | |
2250 } | |
2251 | |
2252 #ifdef FEAT_DIGRAPHS | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2253 do_digraph(-1); // clear digraphs |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2254 do_digraph(buf[i-1]); // may be the start of a digraph |
7 | 2255 #endif |
2256 buf[i] = NUL; | |
2257 ins_str(buf); | |
2258 if (flags & INSCHAR_CTRLV) | |
2259 { | |
2260 redo_literal(*buf); | |
2261 i = 1; | |
2262 } | |
2263 else | |
2264 i = 0; | |
2265 if (buf[i] != NUL) | |
620 | 2266 AppendToRedobuffLit(buf + i, -1); |
7 | 2267 } |
2268 else | |
2269 { | |
667 | 2270 int cc; |
2271 | |
7 | 2272 if (has_mbyte && (cc = (*mb_char2len)(c)) > 1) |
2273 { | |
2274 char_u buf[MB_MAXBYTES + 1]; | |
2275 | |
2276 (*mb_char2bytes)(c, buf); | |
2277 buf[cc] = NUL; | |
2278 ins_char_bytes(buf, cc); | |
2279 AppendCharToRedobuff(c); | |
2280 } | |
2281 else | |
2282 { | |
2283 ins_char(c); | |
2284 if (flags & INSCHAR_CTRLV) | |
2285 redo_literal(c); | |
2286 else | |
2287 AppendCharToRedobuff(c); | |
2288 } | |
2289 } | |
2290 } | |
2291 | |
2292 /* | |
2293 * Put a character in the redo buffer, for when just after a CTRL-V. | |
2294 */ | |
2295 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2296 redo_literal(int c) |
7 | 2297 { |
2298 char_u buf[10]; | |
2299 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2300 // Only digits need special treatment. Translate them into a string of |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2301 // three digits. |
7 | 2302 if (VIM_ISDIGIT(c)) |
2303 { | |
1872 | 2304 vim_snprintf((char *)buf, sizeof(buf), "%03d", c); |
7 | 2305 AppendToRedobuff(buf); |
2306 } | |
2307 else | |
2308 AppendCharToRedobuff(c); | |
2309 } | |
2310 | |
2311 /* | |
2312 * start_arrow() is called when an arrow key is used in insert mode. | |
484 | 2313 * For undo/redo it resembles hitting the <ESC> key. |
7 | 2314 */ |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
2315 void |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2316 start_arrow( |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2317 pos_T *end_insert_pos) // can be NULL |
7074
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2318 { |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2319 start_arrow_common(end_insert_pos, TRUE); |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2320 } |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2321 |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2322 /* |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2323 * Like start_arrow() but with end_change argument. |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2324 * Will prepare for redo of CTRL-G U if "end_change" is FALSE. |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2325 */ |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2326 static void |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2327 start_arrow_with_change( |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2328 pos_T *end_insert_pos, // can be NULL |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2329 int end_change) // end undoable change |
7074
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2330 { |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2331 start_arrow_common(end_insert_pos, end_change); |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2332 if (!end_change) |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2333 { |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2334 AppendCharToRedobuff(Ctrl_G); |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2335 AppendCharToRedobuff('U'); |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2336 } |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2337 } |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2338 |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2339 static void |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2340 start_arrow_common( |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2341 pos_T *end_insert_pos, // can be NULL |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2342 int end_change) // end undoable change |
7074
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
2343 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2344 if (!arrow_used && end_change) // something has been inserted |
7 | 2345 { |
2346 AppendToRedobuff(ESC_STR); | |
5434 | 2347 stop_insert(end_insert_pos, FALSE, FALSE); |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2348 arrow_used = TRUE; // this means we stopped the current insert |
7 | 2349 } |
744 | 2350 #ifdef FEAT_SPELL |
221 | 2351 check_spell_redraw(); |
2352 #endif | |
7 | 2353 } |
2354 | |
744 | 2355 #ifdef FEAT_SPELL |
221 | 2356 /* |
2357 * If we skipped highlighting word at cursor, do it now. | |
2358 * It may be skipped again, thus reset spell_redraw_lnum first. | |
2359 */ | |
2360 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2361 check_spell_redraw(void) |
221 | 2362 { |
2363 if (spell_redraw_lnum != 0) | |
2364 { | |
2365 linenr_T lnum = spell_redraw_lnum; | |
2366 | |
2367 spell_redraw_lnum = 0; | |
15400
ac5542aadd9c
patch 8.1.0708: third argument for redrawWinline() is always FALSE
Bram Moolenaar <Bram@vim.org>
parents:
15382
diff
changeset
|
2368 redrawWinline(curwin, lnum); |
221 | 2369 } |
2370 } | |
484 | 2371 |
221 | 2372 #endif |
2373 | |
7 | 2374 /* |
2375 * stop_arrow() is called before a change is made in insert mode. | |
2376 * If an arrow key has been used, start a new insertion. | |
2377 * Returns FAIL if undo is impossible, shouldn't insert then. | |
2378 */ | |
2379 int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2380 stop_arrow(void) |
7 | 2381 { |
2382 if (arrow_used) | |
2383 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2384 Insstart = curwin->w_cursor; // new insertion starts here |
6138 | 2385 if (Insstart.col > Insstart_orig.col && !ins_need_undo) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2386 // Don't update the original insert position when moved to the |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2387 // right, except when nothing was inserted yet. |
6138 | 2388 update_Insstart_orig = FALSE; |
30833
e3d5781c7ec6
patch 9.0.0751: 'scrolloff' does not work well with 'smoothscroll'
Bram Moolenaar <Bram@vim.org>
parents:
30825
diff
changeset
|
2389 Insstart_textlen = (colnr_T)linetabsize_str(ml_get_curline()); |
6138 | 2390 |
7 | 2391 if (u_save_cursor() == OK) |
2392 { | |
2393 arrow_used = FALSE; | |
2394 ins_need_undo = FALSE; | |
2395 } | |
6138 | 2396 |
7 | 2397 ai_col = 0; |
2398 if (State & VREPLACE_FLAG) | |
2399 { | |
2400 orig_line_count = curbuf->b_ml.ml_line_count; | |
2401 vr_lines_changed = 1; | |
2402 } | |
2403 ResetRedobuff(); | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2404 AppendToRedobuff((char_u *)"1i"); // pretend we start an insertion |
613 | 2405 new_insert_skip = 2; |
7 | 2406 } |
2407 else if (ins_need_undo) | |
2408 { | |
2409 if (u_save_cursor() == OK) | |
2410 ins_need_undo = FALSE; | |
2411 } | |
2412 | |
2413 #ifdef FEAT_FOLDING | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2414 // Always open fold at the cursor line when inserting something. |
7 | 2415 foldOpenCursor(); |
2416 #endif | |
2417 | |
2418 return (arrow_used || ins_need_undo ? FAIL : OK); | |
2419 } | |
2420 | |
2421 /* | |
840 | 2422 * Do a few things to stop inserting. |
2423 * "end_insert_pos" is where insert ended. It is NULL when we already jumped | |
2424 * to another window/buffer. | |
7 | 2425 */ |
2426 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2427 stop_insert( |
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2428 pos_T *end_insert_pos, |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2429 int esc, // called by ins_esc() |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2430 int nomove) // <c-\><c-o>, don't move cursor |
7 | 2431 { |
603 | 2432 int cc; |
2433 char_u *ptr; | |
7 | 2434 |
2435 stop_redo_ins(); | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2436 replace_flush(); // abandon replace stack |
7 | 2437 |
2438 /* | |
603 | 2439 * Save the inserted text for later redo with ^@ and CTRL-A. |
2440 * Don't do it when "restart_edit" was set and nothing was inserted, | |
2441 * otherwise CTRL-O w and then <Left> will clear "last_insert". | |
7 | 2442 */ |
603 | 2443 ptr = get_inserted(); |
615 | 2444 if (did_restart_edit == 0 || (ptr != NULL |
2445 && (int)STRLEN(ptr) > new_insert_skip)) | |
603 | 2446 { |
2447 vim_free(last_insert); | |
2448 last_insert = ptr; | |
2449 last_insert_skip = new_insert_skip; | |
2450 } | |
2451 else | |
2452 vim_free(ptr); | |
7 | 2453 |
840 | 2454 if (!arrow_used && end_insert_pos != NULL) |
7 | 2455 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2456 // Auto-format now. It may seem strange to do this when stopping an |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2457 // insertion (or moving the cursor), but it's required when appending |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2458 // a line and having it end in a space. But only do it when something |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2459 // was actually inserted, otherwise undo won't work. |
10 | 2460 if (!ins_need_undo && has_format_option(FO_AUTO)) |
7 | 2461 { |
10 | 2462 pos_T tpos = curwin->w_cursor; |
2463 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2464 // When the cursor is at the end of the line after a space the |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2465 // formatting will move it to the following word. Avoid that by |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2466 // moving the cursor onto the space. |
7 | 2467 cc = 'x'; |
2468 if (curwin->w_cursor.col > 0 && gchar_cursor() == NUL) | |
2469 { | |
2470 dec_cursor(); | |
2471 cc = gchar_cursor(); | |
11129
f4ea50924c6d
patch 8.0.0452: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents:
11127
diff
changeset
|
2472 if (!VIM_ISWHITE(cc)) |
10 | 2473 curwin->w_cursor = tpos; |
7 | 2474 } |
2475 | |
2476 auto_format(TRUE, FALSE); | |
2477 | |
11129
f4ea50924c6d
patch 8.0.0452: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents:
11127
diff
changeset
|
2478 if (VIM_ISWHITE(cc)) |
10 | 2479 { |
2480 if (gchar_cursor() != NUL) | |
2481 inc_cursor(); | |
15636
6f1c7e9a6393
patch 8.1.0826: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15629
diff
changeset
|
2482 // If the cursor is still at the same character, also keep |
6f1c7e9a6393
patch 8.1.0826: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15629
diff
changeset
|
2483 // the "coladd". |
10 | 2484 if (gchar_cursor() == NUL |
2485 && curwin->w_cursor.lnum == tpos.lnum | |
2486 && curwin->w_cursor.col == tpos.col) | |
2487 curwin->w_cursor.coladd = tpos.coladd; | |
2488 } | |
7 | 2489 } |
2490 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2491 // If a space was inserted for auto-formatting, remove it now. |
7 | 2492 check_auto_format(TRUE); |
2493 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2494 // If we just did an auto-indent, remove the white space from the end |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2495 // of the line, and put the cursor back. |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2496 // Do this when ESC was used or moving the cursor up/down. |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2497 // Check for the old position still being valid, just in case the text |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2498 // got changed unexpectedly. |
5434 | 2499 if (!nomove && did_ai && (esc || (vim_strchr(p_cpo, CPO_INDENT) == NULL |
1892 | 2500 && curwin->w_cursor.lnum != end_insert_pos->lnum)) |
2501 && end_insert_pos->lnum <= curbuf->b_ml.ml_line_count) | |
7 | 2502 { |
10 | 2503 pos_T tpos = curwin->w_cursor; |
2504 | |
2505 curwin->w_cursor = *end_insert_pos; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2506 check_cursor_col(); // make sure it is not past the line |
786 | 2507 for (;;) |
2508 { | |
2509 if (gchar_cursor() == NUL && curwin->w_cursor.col > 0) | |
2510 --curwin->w_cursor.col; | |
2511 cc = gchar_cursor(); | |
11129
f4ea50924c6d
patch 8.0.0452: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents:
11127
diff
changeset
|
2512 if (!VIM_ISWHITE(cc)) |
786 | 2513 break; |
1892 | 2514 if (del_char(TRUE) == FAIL) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2515 break; // should not happen |
786 | 2516 } |
10 | 2517 if (curwin->w_cursor.lnum != tpos.lnum) |
2518 curwin->w_cursor = tpos; | |
6318 | 2519 else |
2520 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2521 // reset tpos, could have been invalidated in the loop above |
6363 | 2522 tpos = curwin->w_cursor; |
6318 | 2523 tpos.col++; |
2524 if (cc != NUL && gchar_pos(&tpos) == NUL) | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2525 ++curwin->w_cursor.col; // put cursor back on the NUL |
6318 | 2526 } |
7 | 2527 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2528 // <C-S-Right> may have started Visual mode, adjust the position for |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2529 // deleted characters. |
28893
aa44d5842d6c
patch 8.2.4969: changing text in Visual mode may cause invalid memory access
Bram Moolenaar <Bram@vim.org>
parents:
28856
diff
changeset
|
2530 if (VIsual_active) |
aa44d5842d6c
patch 8.2.4969: changing text in Visual mode may cause invalid memory access
Bram Moolenaar <Bram@vim.org>
parents:
28856
diff
changeset
|
2531 check_visual_pos(); |
7 | 2532 } |
2533 } | |
2534 did_ai = FALSE; | |
2535 did_si = FALSE; | |
2536 can_si = FALSE; | |
2537 can_si_back = FALSE; | |
2538 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2539 // Set '[ and '] to the inserted text. When end_insert_pos is NULL we are |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2540 // now in a different buffer. |
840 | 2541 if (end_insert_pos != NULL) |
2542 { | |
2543 curbuf->b_op_start = Insstart; | |
5680 | 2544 curbuf->b_op_start_orig = Insstart_orig; |
840 | 2545 curbuf->b_op_end = *end_insert_pos; |
2546 } | |
7 | 2547 } |
2548 | |
2549 /* | |
2550 * Set the last inserted text to a single character. | |
2551 * Used for the replace command. | |
2552 */ | |
2553 void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2554 set_last_insert(int c) |
7 | 2555 { |
2556 char_u *s; | |
2557 | |
2558 vim_free(last_insert); | |
2559 last_insert = alloc(MB_MAXBYTES * 3 + 5); | |
31545
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
2560 if (last_insert == NULL) |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
2561 return; |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
2562 |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
2563 s = last_insert; |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
2564 // Use the CTRL-V only when entering a special char |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
2565 if (c < ' ' || c == DEL) |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
2566 *s++ = Ctrl_V; |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
2567 s = add_char2buf(c, s); |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
2568 *s++ = ESC; |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
2569 *s++ = NUL; |
c8d4fced1f94
patch 9.0.1105: code is indented too much
Bram Moolenaar <Bram@vim.org>
parents:
31406
diff
changeset
|
2570 last_insert_skip = 0; |
7 | 2571 } |
2572 | |
359 | 2573 #if defined(EXITFREE) || defined(PROTO) |
2574 void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2575 free_last_insert(void) |
359 | 2576 { |
13244
ac42c4b11dbc
patch 8.0.1496: clearing a pointer takes two lines
Christian Brabandt <cb@256bit.org>
parents:
13240
diff
changeset
|
2577 VIM_CLEAR(last_insert); |
359 | 2578 } |
2579 #endif | |
2580 | |
7 | 2581 /* |
2582 * Add character "c" to buffer "s". Escape the special meaning of K_SPECIAL | |
2583 * and CSI. Handle multi-byte characters. | |
2584 * Returns a pointer to after the added bytes. | |
2585 */ | |
2586 char_u * | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2587 add_char2buf(int c, char_u *s) |
7 | 2588 { |
3549 | 2589 char_u temp[MB_MAXBYTES + 1]; |
7 | 2590 int i; |
2591 int len; | |
2592 | |
2593 len = (*mb_char2bytes)(c, temp); | |
2594 for (i = 0; i < len; ++i) | |
2595 { | |
2596 c = temp[i]; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2597 // Need to escape K_SPECIAL and CSI like in the typeahead buffer. |
7 | 2598 if (c == K_SPECIAL) |
2599 { | |
2600 *s++ = K_SPECIAL; | |
2601 *s++ = KS_SPECIAL; | |
2602 *s++ = KE_FILLER; | |
2603 } | |
2604 #ifdef FEAT_GUI | |
2605 else if (c == CSI) | |
2606 { | |
2607 *s++ = CSI; | |
2608 *s++ = KS_EXTRA; | |
2609 *s++ = (int)KE_CSI; | |
2610 } | |
2611 #endif | |
2612 else | |
2613 *s++ = c; | |
15595
1ec942f1b648
patch 8.1.0805: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15569
diff
changeset
|
2614 } |
7 | 2615 return s; |
2616 } | |
2617 | |
2618 /* | |
2619 * move cursor to start of line | |
2620 * if flags & BL_WHITE move to first non-white | |
2621 * if flags & BL_SOL move to first non-white if startofline is set, | |
2622 * otherwise keep "curswant" column | |
2623 * if flags & BL_FIX don't leave the cursor on a NUL. | |
2624 */ | |
2625 void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2626 beginline(int flags) |
7 | 2627 { |
2628 if ((flags & BL_SOL) && !p_sol) | |
2629 coladvance(curwin->w_curswant); | |
2630 else | |
2631 { | |
2632 curwin->w_cursor.col = 0; | |
2633 curwin->w_cursor.coladd = 0; | |
2634 | |
2635 if (flags & (BL_WHITE | BL_SOL)) | |
2636 { | |
2637 char_u *ptr; | |
2638 | |
11129
f4ea50924c6d
patch 8.0.0452: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents:
11127
diff
changeset
|
2639 for (ptr = ml_get_curline(); VIM_ISWHITE(*ptr) |
7 | 2640 && !((flags & BL_FIX) && ptr[1] == NUL); ++ptr) |
2641 ++curwin->w_cursor.col; | |
2642 } | |
2643 curwin->w_set_curswant = TRUE; | |
2644 } | |
30799
ffa5492137c3
patch 9.0.0734: cursor position invalid when scrolling with 'smoothscroll'
Bram Moolenaar <Bram@vim.org>
parents:
30659
diff
changeset
|
2645 adjust_skipcol(); |
7 | 2646 } |
2647 | |
2648 /* | |
2649 * oneright oneleft cursor_down cursor_up | |
2650 * | |
2651 * Move one char {right,left,down,up}. | |
773 | 2652 * Doesn't move onto the NUL past the end of the line, unless it is allowed. |
7 | 2653 * Return OK when successful, FAIL when we hit a line of file boundary. |
2654 */ | |
2655 | |
2656 int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2657 oneright(void) |
7 | 2658 { |
2659 char_u *ptr; | |
2660 int l; | |
2661 | |
2662 if (virtual_active()) | |
2663 { | |
2664 pos_T prevpos = curwin->w_cursor; | |
2665 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2666 // Adjust for multi-wide char (excluding TAB) |
7 | 2667 ptr = ml_get_cursor(); |
15595
1ec942f1b648
patch 8.1.0805: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15569
diff
changeset
|
2668 coladvance(getviscol() + ((*ptr != TAB |
1ec942f1b648
patch 8.1.0805: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15569
diff
changeset
|
2669 && vim_isprintc((*mb_ptr2char)(ptr))) |
7 | 2670 ? ptr2cells(ptr) : 1)); |
2671 curwin->w_set_curswant = TRUE; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2672 // Return OK if the cursor moved, FAIL otherwise (at window edge). |
7 | 2673 return (prevpos.col != curwin->w_cursor.col |
2674 || prevpos.coladd != curwin->w_cursor.coladd) ? OK : FAIL; | |
2675 } | |
2676 | |
2677 ptr = ml_get_cursor(); | |
773 | 2678 if (*ptr == NUL) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2679 return FAIL; // already at the very end |
773 | 2680 |
2681 if (has_mbyte) | |
2682 l = (*mb_ptr2len)(ptr); | |
7 | 2683 else |
773 | 2684 l = 1; |
2685 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2686 // move "l" bytes right, but don't end up on the NUL, unless 'virtualedit' |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2687 // contains "onemore". |
25380
ac88cd21ae88
patch 8.2.3227: 'virtualedit' can only be set globally
Bram Moolenaar <Bram@vim.org>
parents:
25378
diff
changeset
|
2688 if (ptr[l] == NUL && (get_ve_flags() & VE_ONEMORE) == 0) |
773 | 2689 return FAIL; |
2690 curwin->w_cursor.col += l; | |
7 | 2691 |
2692 curwin->w_set_curswant = TRUE; | |
30799
ffa5492137c3
patch 9.0.0734: cursor position invalid when scrolling with 'smoothscroll'
Bram Moolenaar <Bram@vim.org>
parents:
30659
diff
changeset
|
2693 adjust_skipcol(); |
7 | 2694 return OK; |
2695 } | |
2696 | |
2697 int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2698 oneleft(void) |
7 | 2699 { |
2700 if (virtual_active()) | |
2701 { | |
15636
6f1c7e9a6393
patch 8.1.0826: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15629
diff
changeset
|
2702 #ifdef FEAT_LINEBREAK |
7 | 2703 int width; |
15636
6f1c7e9a6393
patch 8.1.0826: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15629
diff
changeset
|
2704 #endif |
7 | 2705 int v = getviscol(); |
2706 | |
2707 if (v == 0) | |
2708 return FAIL; | |
2709 | |
15636
6f1c7e9a6393
patch 8.1.0826: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15629
diff
changeset
|
2710 #ifdef FEAT_LINEBREAK |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2711 // We might get stuck on 'showbreak', skip over it. |
7 | 2712 width = 1; |
2713 for (;;) | |
2714 { | |
2715 coladvance(v - width); | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2716 // getviscol() is slow, skip it when 'showbreak' is empty, |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2717 // 'breakindent' is not set and there are no multi-byte |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2718 // characters |
18574
8b0114ffde2b
patch 8.1.2281: 'showbreak' cannot be set for one window
Bram Moolenaar <Bram@vim.org>
parents:
18534
diff
changeset
|
2719 if ((*get_showbreak_value(curwin) == NUL && !curwin->w_p_bri |
15595
1ec942f1b648
patch 8.1.0805: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15569
diff
changeset
|
2720 && !has_mbyte) || getviscol() < v) |
7 | 2721 break; |
2722 ++width; | |
2723 } | |
15636
6f1c7e9a6393
patch 8.1.0826: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15629
diff
changeset
|
2724 #else |
7 | 2725 coladvance(v - 1); |
15636
6f1c7e9a6393
patch 8.1.0826: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15629
diff
changeset
|
2726 #endif |
7 | 2727 |
2728 if (curwin->w_cursor.coladd == 1) | |
2729 { | |
2730 char_u *ptr; | |
2731 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2732 // Adjust for multi-wide char (not a TAB) |
7 | 2733 ptr = ml_get_cursor(); |
15595
1ec942f1b648
patch 8.1.0805: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15569
diff
changeset
|
2734 if (*ptr != TAB && vim_isprintc((*mb_ptr2char)(ptr)) |
1ec942f1b648
patch 8.1.0805: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15569
diff
changeset
|
2735 && ptr2cells(ptr) > 1) |
7 | 2736 curwin->w_cursor.coladd = 0; |
2737 } | |
2738 | |
2739 curwin->w_set_curswant = TRUE; | |
2740 return OK; | |
2741 } | |
2742 | |
2743 if (curwin->w_cursor.col == 0) | |
2744 return FAIL; | |
2745 | |
2746 curwin->w_set_curswant = TRUE; | |
2747 --curwin->w_cursor.col; | |
2748 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2749 // if the character on the left of the current cursor is a multi-byte |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2750 // character, move to its first byte |
7 | 2751 if (has_mbyte) |
2752 mb_adjust_cursor(); | |
30799
ffa5492137c3
patch 9.0.0734: cursor position invalid when scrolling with 'smoothscroll'
Bram Moolenaar <Bram@vim.org>
parents:
30659
diff
changeset
|
2753 adjust_skipcol(); |
7 | 2754 return OK; |
2755 } | |
2756 | |
30535
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2757 /* |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2758 * Move the cursor up "n" lines in window "wp". |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2759 * Takes care of closed folds. |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2760 * Returns the new cursor line or zero for failure. |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2761 */ |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2762 linenr_T |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2763 cursor_up_inner(win_T *wp, long n) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2764 { |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2765 linenr_T lnum = wp->w_cursor.lnum; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2766 |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2767 // This fails if the cursor is already in the first line or the count is |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2768 // larger than the line number and '-' is in 'cpoptions' |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2769 if (lnum <= 1 || (n >= lnum && vim_strchr(p_cpo, CPO_MINUS) != NULL)) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2770 return 0; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2771 if (n >= lnum) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2772 lnum = 1; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2773 else |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2774 #ifdef FEAT_FOLDING |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2775 if (hasAnyFolding(wp)) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2776 { |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2777 /* |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2778 * Count each sequence of folded lines as one logical line. |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2779 */ |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2780 // go to the start of the current fold |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2781 (void)hasFoldingWin(wp, lnum, &lnum, NULL, TRUE, NULL); |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2782 |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2783 while (n--) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2784 { |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2785 // move up one line |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2786 --lnum; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2787 if (lnum <= 1) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2788 break; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2789 // If we entered a fold, move to the beginning, unless in |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2790 // Insert mode or when 'foldopen' contains "all": it will open |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2791 // in a moment. |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2792 if (n > 0 || !((State & MODE_INSERT) || (fdo_flags & FDO_ALL))) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2793 (void)hasFoldingWin(wp, lnum, &lnum, NULL, TRUE, NULL); |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2794 } |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2795 if (lnum < 1) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2796 lnum = 1; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2797 } |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2798 else |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2799 #endif |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2800 lnum -= n; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2801 |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2802 wp->w_cursor.lnum = lnum; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2803 return lnum; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2804 } |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2805 |
7 | 2806 int |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2807 cursor_up( |
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2808 long n, |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2809 int upd_topline) // When TRUE: update topline |
7 | 2810 { |
30535
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2811 if (n > 0 && cursor_up_inner(curwin, n) == 0) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2812 return FAIL; |
7 | 2813 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2814 // try to advance to the column we want to be at |
7 | 2815 coladvance(curwin->w_curswant); |
2816 | |
2817 if (upd_topline) | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2818 update_topline(); // make sure curwin->w_topline is valid |
7 | 2819 |
2820 return OK; | |
2821 } | |
2822 | |
2823 /* | |
30535
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2824 * Move the cursor down "n" lines in window "wp". |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2825 * Takes care of closed folds. |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2826 * Returns the new cursor line or zero for failure. |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2827 */ |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2828 linenr_T |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2829 cursor_down_inner(win_T *wp, long n) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2830 { |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2831 linenr_T lnum = wp->w_cursor.lnum; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2832 linenr_T line_count = wp->w_buffer->b_ml.ml_line_count; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2833 |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2834 #ifdef FEAT_FOLDING |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2835 // Move to last line of fold, will fail if it's the end-of-file. |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2836 (void)hasFoldingWin(wp, lnum, NULL, &lnum, TRUE, NULL); |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2837 #endif |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2838 // This fails if the cursor is already in the last line or would move |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2839 // beyond the last line and '-' is in 'cpoptions' |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2840 if (lnum >= line_count |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2841 || (lnum + n > line_count && vim_strchr(p_cpo, CPO_MINUS) != NULL)) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2842 return FAIL; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2843 if (lnum + n >= line_count) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2844 lnum = line_count; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2845 else |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2846 #ifdef FEAT_FOLDING |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2847 if (hasAnyFolding(wp)) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2848 { |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2849 linenr_T last; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2850 |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2851 // count each sequence of folded lines as one logical line |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2852 while (n--) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2853 { |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2854 if (hasFoldingWin(wp, lnum, NULL, &last, TRUE, NULL)) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2855 lnum = last + 1; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2856 else |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2857 ++lnum; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2858 if (lnum >= line_count) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2859 break; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2860 } |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2861 if (lnum > line_count) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2862 lnum = line_count; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2863 } |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2864 else |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2865 #endif |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2866 lnum += n; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2867 |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2868 wp->w_cursor.lnum = lnum; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2869 return lnum; |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2870 } |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2871 |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2872 /* |
7 | 2873 * Cursor down a number of logical lines. |
2874 */ | |
2875 int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2876 cursor_down( |
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2877 long n, |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2878 int upd_topline) // When TRUE: update topline |
7 | 2879 { |
30535
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2880 if (n > 0 && cursor_down_inner(curwin, n) == 0) |
04df44c52d65
patch 9.0.0603: with 'nosplitscroll' folds are not handled correctly
Bram Moolenaar <Bram@vim.org>
parents:
30509
diff
changeset
|
2881 return FAIL; |
7 | 2882 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2883 // try to advance to the column we want to be at |
7 | 2884 coladvance(curwin->w_curswant); |
2885 | |
2886 if (upd_topline) | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2887 update_topline(); // make sure curwin->w_topline is valid |
7 | 2888 |
2889 return OK; | |
2890 } | |
2891 | |
2892 /* | |
2893 * Stuff the last inserted text in the read buffer. | |
2894 * Last_insert actually is a copy of the redo buffer, so we | |
2895 * first have to remove the command. | |
2896 */ | |
2897 int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2898 stuff_inserted( |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2899 int c, // Command character to be inserted |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2900 long count, // Repeat this many times |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2901 int no_esc) // Don't add an ESC at the end |
7 | 2902 { |
2903 char_u *esc_ptr; | |
2904 char_u *ptr; | |
2905 char_u *last_ptr; | |
2906 char_u last = NUL; | |
2907 | |
2908 ptr = get_last_insert(); | |
2909 if (ptr == NULL) | |
2910 { | |
25306
078edc1821bf
patch 8.2.3190: error messages are spread out
Bram Moolenaar <Bram@vim.org>
parents:
25074
diff
changeset
|
2911 emsg(_(e_no_inserted_text_yet)); |
7 | 2912 return FAIL; |
2913 } | |
2914 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2915 // may want to stuff the command character, to start Insert mode |
7 | 2916 if (c != NUL) |
2917 stuffcharReadbuff(c); | |
27426
41e0dcf38521
patch 8.2.4241: some type casts are redundant
Bram Moolenaar <Bram@vim.org>
parents:
27380
diff
changeset
|
2918 if ((esc_ptr = vim_strrchr(ptr, ESC)) != NULL) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2919 *esc_ptr = NUL; // remove the ESC |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2920 |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2921 // when the last char is either "0" or "^" it will be quoted if no ESC |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2922 // comes after it OR if it will inserted more than once and "ptr" |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2923 // starts with ^D. -- Acevedo |
7 | 2924 last_ptr = (esc_ptr ? esc_ptr : ptr + STRLEN(ptr)) - 1; |
2925 if (last_ptr >= ptr && (*last_ptr == '0' || *last_ptr == '^') | |
2926 && (no_esc || (*ptr == Ctrl_D && count > 1))) | |
2927 { | |
2928 last = *last_ptr; | |
2929 *last_ptr = NUL; | |
2930 } | |
2931 | |
2932 do | |
2933 { | |
2934 stuffReadbuff(ptr); | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2935 // a trailing "0" is inserted as "<C-V>048", "^" as "<C-V>^" |
7 | 2936 if (last) |
27490
fb4c30606b4a
patch 8.2.4273: the EBCDIC support is outdated
Bram Moolenaar <Bram@vim.org>
parents:
27426
diff
changeset
|
2937 stuffReadbuff( |
fb4c30606b4a
patch 8.2.4273: the EBCDIC support is outdated
Bram Moolenaar <Bram@vim.org>
parents:
27426
diff
changeset
|
2938 (char_u *)(last == '0' ? "\026\060\064\070" : "\026^")); |
7 | 2939 } |
2940 while (--count > 0); | |
2941 | |
2942 if (last) | |
2943 *last_ptr = last; | |
2944 | |
2945 if (esc_ptr != NULL) | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2946 *esc_ptr = ESC; // put the ESC back |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2947 |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2948 // may want to stuff a trailing ESC, to get out of Insert mode |
7 | 2949 if (!no_esc) |
2950 stuffcharReadbuff(ESC); | |
2951 | |
2952 return OK; | |
2953 } | |
2954 | |
2955 char_u * | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2956 get_last_insert(void) |
7 | 2957 { |
2958 if (last_insert == NULL) | |
2959 return NULL; | |
2960 return last_insert + last_insert_skip; | |
2961 } | |
2962 | |
2963 /* | |
2964 * Get last inserted string, and remove trailing <Esc>. | |
2965 * Returns pointer to allocated memory (must be freed) or NULL. | |
2966 */ | |
2967 char_u * | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2968 get_last_insert_save(void) |
7 | 2969 { |
2970 char_u *s; | |
2971 int len; | |
2972 | |
2973 if (last_insert == NULL) | |
2974 return NULL; | |
2975 s = vim_strsave(last_insert + last_insert_skip); | |
31667
b89cfd86e18e
patch 9.0.1166: code is indented more than necessary
Bram Moolenaar <Bram@vim.org>
parents:
31588
diff
changeset
|
2976 if (s == NULL) |
b89cfd86e18e
patch 9.0.1166: code is indented more than necessary
Bram Moolenaar <Bram@vim.org>
parents:
31588
diff
changeset
|
2977 return NULL; |
b89cfd86e18e
patch 9.0.1166: code is indented more than necessary
Bram Moolenaar <Bram@vim.org>
parents:
31588
diff
changeset
|
2978 |
b89cfd86e18e
patch 9.0.1166: code is indented more than necessary
Bram Moolenaar <Bram@vim.org>
parents:
31588
diff
changeset
|
2979 len = (int)STRLEN(s); |
b89cfd86e18e
patch 9.0.1166: code is indented more than necessary
Bram Moolenaar <Bram@vim.org>
parents:
31588
diff
changeset
|
2980 if (len > 0 && s[len - 1] == ESC) // remove trailing ESC |
b89cfd86e18e
patch 9.0.1166: code is indented more than necessary
Bram Moolenaar <Bram@vim.org>
parents:
31588
diff
changeset
|
2981 s[len - 1] = NUL; |
7 | 2982 return s; |
2983 } | |
2984 | |
2985 /* | |
2986 * Check the word in front of the cursor for an abbreviation. | |
2987 * Called when the non-id character "c" has been entered. | |
2988 * When an abbreviation is recognized it is removed from the text and | |
2989 * the replacement string is inserted in typebuf.tb_buf[], followed by "c". | |
2990 */ | |
2991 static int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
2992 echeck_abbr(int c) |
7 | 2993 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2994 // Don't check for abbreviation in paste mode, when disabled and just |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
2995 // after moving around with cursor keys. |
7 | 2996 if (p_paste || no_abbr || arrow_used) |
2997 return FALSE; | |
2998 | |
2999 return check_abbr(c, ml_get_curline(), curwin->w_cursor.col, | |
3000 curwin->w_cursor.lnum == Insstart.lnum ? Insstart.col : 0); | |
3001 } | |
3002 | |
3003 /* | |
3004 * replace-stack functions | |
3005 * | |
3006 * When replacing characters, the replaced characters are remembered for each | |
3007 * new character. This is used to re-insert the old text when backspacing. | |
3008 * | |
3009 * There is a NUL headed list of characters for each character that is | |
3010 * currently in the file after the insertion point. When BS is used, one NUL | |
3011 * headed list is put back for the deleted character. | |
3012 * | |
3013 * For a newline, there are two NUL headed lists. One contains the characters | |
3014 * that the NL replaced. The extra one stores the characters after the cursor | |
3015 * that were deleted (always white space). | |
3016 * | |
3017 * Replace_offset is normally 0, in which case replace_push will add a new | |
3018 * character at the end of the stack. If replace_offset is not 0, that many | |
3019 * characters will be left on the stack above the newly inserted character. | |
3020 */ | |
3021 | |
298 | 3022 static char_u *replace_stack = NULL; |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3023 static long replace_stack_nr = 0; // next entry in replace stack |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3024 static long replace_stack_len = 0; // max. number of entries |
7 | 3025 |
3026 void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3027 replace_push( |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3028 int c) // character that is replaced (NUL is none) |
7 | 3029 { |
3030 char_u *p; | |
3031 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3032 if (replace_stack_nr < replace_offset) // nothing to do |
7 | 3033 return; |
3034 if (replace_stack_len <= replace_stack_nr) | |
3035 { | |
3036 replace_stack_len += 50; | |
16904
9138e2c60bf1
patch 8.1.1453: popup window "moved" property not implemented yet
Bram Moolenaar <Bram@vim.org>
parents:
16768
diff
changeset
|
3037 p = ALLOC_MULT(char_u, replace_stack_len); |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3038 if (p == NULL) // out of memory |
7 | 3039 { |
3040 replace_stack_len -= 50; | |
3041 return; | |
3042 } | |
3043 if (replace_stack != NULL) | |
3044 { | |
3045 mch_memmove(p, replace_stack, | |
3046 (size_t)(replace_stack_nr * sizeof(char_u))); | |
3047 vim_free(replace_stack); | |
3048 } | |
3049 replace_stack = p; | |
3050 } | |
3051 p = replace_stack + replace_stack_nr - replace_offset; | |
3052 if (replace_offset) | |
3053 mch_memmove(p + 1, p, (size_t)(replace_offset * sizeof(char_u))); | |
3054 *p = c; | |
3055 ++replace_stack_nr; | |
3056 } | |
3057 | |
1470 | 3058 /* |
3059 * Push a character onto the replace stack. Handles a multi-byte character in | |
3060 * reverse byte order, so that the first byte is popped off first. | |
3061 * Return the number of bytes done (includes composing characters). | |
3062 */ | |
3063 int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3064 replace_push_mb(char_u *p) |
1470 | 3065 { |
3066 int l = (*mb_ptr2len)(p); | |
3067 int j; | |
3068 | |
3069 for (j = l - 1; j >= 0; --j) | |
3070 replace_push(p[j]); | |
3071 return l; | |
3072 } | |
3073 | |
7 | 3074 /* |
3075 * Pop one item from the replace stack. | |
3076 * return -1 if stack empty | |
3077 * return replaced character or NUL otherwise | |
3078 */ | |
3079 static int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3080 replace_pop(void) |
7 | 3081 { |
3082 if (replace_stack_nr == 0) | |
3083 return -1; | |
3084 return (int)replace_stack[--replace_stack_nr]; | |
3085 } | |
3086 | |
3087 /* | |
3088 * Join the top two items on the replace stack. This removes to "off"'th NUL | |
3089 * encountered. | |
3090 */ | |
18265
fe5afdc03bd2
patch 8.1.2127: the indent.c file is a bit big
Bram Moolenaar <Bram@vim.org>
parents:
18203
diff
changeset
|
3091 void |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3092 replace_join( |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3093 int off) // offset for which NUL to remove |
7 | 3094 { |
3095 int i; | |
3096 | |
3097 for (i = replace_stack_nr; --i >= 0; ) | |
3098 if (replace_stack[i] == NUL && off-- <= 0) | |
3099 { | |
3100 --replace_stack_nr; | |
3101 mch_memmove(replace_stack + i, replace_stack + i + 1, | |
3102 (size_t)(replace_stack_nr - i)); | |
3103 return; | |
3104 } | |
3105 } | |
3106 | |
3107 /* | |
3108 * Pop bytes from the replace stack until a NUL is found, and insert them | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
3109 * before the cursor. Can only be used in MODE_REPLACE or MODE_VREPLACE state. |
7 | 3110 */ |
3111 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3112 replace_pop_ins(void) |
7 | 3113 { |
3114 int cc; | |
3115 int oldState = State; | |
3116 | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
3117 State = MODE_NORMAL; // don't want MODE_REPLACE here |
7 | 3118 while ((cc = replace_pop()) > 0) |
3119 { | |
3120 mb_replace_pop_ins(cc); | |
3121 dec_cursor(); | |
3122 } | |
3123 State = oldState; | |
3124 } | |
3125 | |
3126 /* | |
3127 * Insert bytes popped from the replace stack. "cc" is the first byte. If it | |
3128 * indicates a multi-byte char, pop the other bytes too. | |
3129 */ | |
3130 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3131 mb_replace_pop_ins(int cc) |
7 | 3132 { |
3133 int n; | |
3549 | 3134 char_u buf[MB_MAXBYTES + 1]; |
7 | 3135 int i; |
3136 int c; | |
3137 | |
3138 if (has_mbyte && (n = MB_BYTE2LEN(cc)) > 1) | |
3139 { | |
3140 buf[0] = cc; | |
3141 for (i = 1; i < n; ++i) | |
3142 buf[i] = replace_pop(); | |
3143 ins_bytes_len(buf, n); | |
3144 } | |
3145 else | |
3146 ins_char(cc); | |
3147 | |
3148 if (enc_utf8) | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3149 // Handle composing chars. |
7 | 3150 for (;;) |
3151 { | |
3152 c = replace_pop(); | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3153 if (c == -1) // stack empty |
7 | 3154 break; |
3155 if ((n = MB_BYTE2LEN(c)) == 1) | |
3156 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3157 // Not a multi-byte char, put it back. |
7 | 3158 replace_push(c); |
3159 break; | |
3160 } | |
28363
a9a56b567709
patch 8.2.4707: redrawing could be a bit more efficient
Bram Moolenaar <Bram@vim.org>
parents:
28269
diff
changeset
|
3161 |
a9a56b567709
patch 8.2.4707: redrawing could be a bit more efficient
Bram Moolenaar <Bram@vim.org>
parents:
28269
diff
changeset
|
3162 buf[0] = c; |
a9a56b567709
patch 8.2.4707: redrawing could be a bit more efficient
Bram Moolenaar <Bram@vim.org>
parents:
28269
diff
changeset
|
3163 for (i = 1; i < n; ++i) |
a9a56b567709
patch 8.2.4707: redrawing could be a bit more efficient
Bram Moolenaar <Bram@vim.org>
parents:
28269
diff
changeset
|
3164 buf[i] = replace_pop(); |
a9a56b567709
patch 8.2.4707: redrawing could be a bit more efficient
Bram Moolenaar <Bram@vim.org>
parents:
28269
diff
changeset
|
3165 if (utf_iscomposing(utf_ptr2char(buf))) |
a9a56b567709
patch 8.2.4707: redrawing could be a bit more efficient
Bram Moolenaar <Bram@vim.org>
parents:
28269
diff
changeset
|
3166 ins_bytes_len(buf, n); |
7 | 3167 else |
3168 { | |
28363
a9a56b567709
patch 8.2.4707: redrawing could be a bit more efficient
Bram Moolenaar <Bram@vim.org>
parents:
28269
diff
changeset
|
3169 // Not a composing char, put it back. |
a9a56b567709
patch 8.2.4707: redrawing could be a bit more efficient
Bram Moolenaar <Bram@vim.org>
parents:
28269
diff
changeset
|
3170 for (i = n - 1; i >= 0; --i) |
a9a56b567709
patch 8.2.4707: redrawing could be a bit more efficient
Bram Moolenaar <Bram@vim.org>
parents:
28269
diff
changeset
|
3171 replace_push(buf[i]); |
a9a56b567709
patch 8.2.4707: redrawing could be a bit more efficient
Bram Moolenaar <Bram@vim.org>
parents:
28269
diff
changeset
|
3172 break; |
7 | 3173 } |
28363
a9a56b567709
patch 8.2.4707: redrawing could be a bit more efficient
Bram Moolenaar <Bram@vim.org>
parents:
28269
diff
changeset
|
3174 |
7 | 3175 } |
3176 } | |
3177 | |
3178 /* | |
3179 * make the replace stack empty | |
3180 * (called when exiting replace mode) | |
3181 */ | |
3182 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3183 replace_flush(void) |
7 | 3184 { |
13244
ac42c4b11dbc
patch 8.0.1496: clearing a pointer takes two lines
Christian Brabandt <cb@256bit.org>
parents:
13240
diff
changeset
|
3185 VIM_CLEAR(replace_stack); |
7 | 3186 replace_stack_len = 0; |
3187 replace_stack_nr = 0; | |
3188 } | |
3189 | |
3190 /* | |
3191 * Handle doing a BS for one character. | |
3192 * cc < 0: replace stack empty, just move cursor | |
3193 * cc == 0: character was inserted, delete it | |
3194 * cc > 0: character was replaced, put cc (first byte of original char) back | |
3195 * and check for more characters to be put back | |
1782 | 3196 * When "limit_col" is >= 0, don't delete before this column. Matters when |
3197 * using composing characters, use del_char_after_col() instead of del_char(). | |
7 | 3198 */ |
3199 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3200 replace_do_bs(int limit_col) |
7 | 3201 { |
3202 int cc; | |
3203 int orig_len = 0; | |
3204 int ins_len; | |
3205 int orig_vcols = 0; | |
3206 colnr_T start_vcol; | |
3207 char_u *p; | |
3208 int i; | |
3209 int vcol; | |
3210 | |
3211 cc = replace_pop(); | |
3212 if (cc > 0) | |
3213 { | |
18763
49b78d6465e5
patch 8.1.2371: FEAT_TEXT_PROP is a confusing name
Bram Moolenaar <Bram@vim.org>
parents:
18717
diff
changeset
|
3214 #ifdef FEAT_PROP_POPUP |
15382
87a0e3c3734c
patch 8.1.0699: compiler warning for uninitialized variable
Bram Moolenaar <Bram@vim.org>
parents:
15377
diff
changeset
|
3215 size_t len_before = 0; // init to shut up GCC |
15349
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3216 |
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3217 if (curbuf->b_has_textprop) |
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3218 { |
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3219 // Do not adjust text properties for individual delete and insert |
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3220 // operations, do it afterwards on the resulting text. |
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3221 len_before = STRLEN(ml_get_curline()); |
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3222 ++text_prop_frozen; |
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3223 } |
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3224 #endif |
7 | 3225 if (State & VREPLACE_FLAG) |
3226 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3227 // Get the number of screen cells used by the character we are |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3228 // going to delete. |
7 | 3229 getvcol(curwin, &curwin->w_cursor, NULL, &start_vcol, NULL); |
3230 orig_vcols = chartabsize(ml_get_cursor(), start_vcol); | |
3231 } | |
3232 if (has_mbyte) | |
3233 { | |
1782 | 3234 (void)del_char_after_col(limit_col); |
7 | 3235 if (State & VREPLACE_FLAG) |
835 | 3236 orig_len = (int)STRLEN(ml_get_cursor()); |
7 | 3237 replace_push(cc); |
3238 } | |
3239 else | |
3240 { | |
3241 pchar_cursor(cc); | |
3242 if (State & VREPLACE_FLAG) | |
835 | 3243 orig_len = (int)STRLEN(ml_get_cursor()) - 1; |
7 | 3244 } |
3245 replace_pop_ins(); | |
3246 | |
3247 if (State & VREPLACE_FLAG) | |
3248 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3249 // Get the number of screen cells used by the inserted characters |
7 | 3250 p = ml_get_cursor(); |
835 | 3251 ins_len = (int)STRLEN(p) - orig_len; |
7 | 3252 vcol = start_vcol; |
3253 for (i = 0; i < ins_len; ++i) | |
3254 { | |
3255 vcol += chartabsize(p + i, vcol); | |
474 | 3256 i += (*mb_ptr2len)(p) - 1; |
7 | 3257 } |
3258 vcol -= start_vcol; | |
3259 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3260 // Delete spaces that were inserted after the cursor to keep the |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3261 // text aligned. |
7 | 3262 curwin->w_cursor.col += ins_len; |
3263 while (vcol > orig_vcols && gchar_cursor() == ' ') | |
3264 { | |
3265 del_char(FALSE); | |
3266 ++orig_vcols; | |
3267 } | |
3268 curwin->w_cursor.col -= ins_len; | |
3269 } | |
3270 | |
15349
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3271 // mark the buffer as changed and prepare for displaying |
7 | 3272 changed_bytes(curwin->w_cursor.lnum, curwin->w_cursor.col); |
15349
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3273 |
18763
49b78d6465e5
patch 8.1.2371: FEAT_TEXT_PROP is a confusing name
Bram Moolenaar <Bram@vim.org>
parents:
18717
diff
changeset
|
3274 #ifdef FEAT_PROP_POPUP |
15349
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3275 if (curbuf->b_has_textprop) |
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3276 { |
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3277 size_t len_now = STRLEN(ml_get_curline()); |
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3278 |
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3279 --text_prop_frozen; |
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3280 adjust_prop_columns(curwin->w_cursor.lnum, curwin->w_cursor.col, |
16714
ba592f30c082
patch 8.1.1359: text property wrong after :substitute with backslash
Bram Moolenaar <Bram@vim.org>
parents:
16698
diff
changeset
|
3281 (int)(len_now - len_before), 0); |
15349
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3282 } |
6abee072b93c
patch 8.1.0682: text properties not adjusted when backspacing replaced text
Bram Moolenaar <Bram@vim.org>
parents:
15347
diff
changeset
|
3283 #endif |
7 | 3284 } |
3285 else if (cc == 0) | |
1782 | 3286 (void)del_char_after_col(limit_col); |
7 | 3287 } |
3288 | |
3289 #if defined(FEAT_RIGHTLEFT) || defined(PROTO) | |
3290 /* | |
3291 * Map Hebrew keyboard when in hkmap mode. | |
3292 */ | |
3293 int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3294 hkmap(int c) |
7 | 3295 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3296 if (p_hkmapp) // phonetic mapping, by Ilya Dogolazky |
7 | 3297 { |
3298 enum {hALEF=0, BET, GIMEL, DALET, HEI, VAV, ZAIN, HET, TET, IUD, | |
3299 KAFsofit, hKAF, LAMED, MEMsofit, MEM, NUNsofit, NUN, SAMEH, AIN, | |
3300 PEIsofit, PEI, ZADIsofit, ZADI, KOF, RESH, hSHIN, TAV}; | |
3301 static char_u map[26] = | |
3302 {(char_u)hALEF/*a*/, (char_u)BET /*b*/, (char_u)hKAF /*c*/, | |
3303 (char_u)DALET/*d*/, (char_u)-1 /*e*/, (char_u)PEIsofit/*f*/, | |
3304 (char_u)GIMEL/*g*/, (char_u)HEI /*h*/, (char_u)IUD /*i*/, | |
3305 (char_u)HET /*j*/, (char_u)KOF /*k*/, (char_u)LAMED /*l*/, | |
3306 (char_u)MEM /*m*/, (char_u)NUN /*n*/, (char_u)SAMEH /*o*/, | |
3307 (char_u)PEI /*p*/, (char_u)-1 /*q*/, (char_u)RESH /*r*/, | |
3308 (char_u)ZAIN /*s*/, (char_u)TAV /*t*/, (char_u)TET /*u*/, | |
3309 (char_u)VAV /*v*/, (char_u)hSHIN/*w*/, (char_u)-1 /*x*/, | |
3310 (char_u)AIN /*y*/, (char_u)ZADI /*z*/}; | |
3311 | |
3312 if (c == 'N' || c == 'M' || c == 'P' || c == 'C' || c == 'Z') | |
3313 return (int)(map[CharOrd(c)] - 1 + p_aleph); | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3314 // '-1'='sofit' |
7 | 3315 else if (c == 'x') |
3316 return 'X'; | |
3317 else if (c == 'q') | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3318 return '\''; // {geresh}={'} |
7 | 3319 else if (c == 246) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3320 return ' '; // \"o --> ' ' for a german keyboard |
7 | 3321 else if (c == 228) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3322 return ' '; // \"a --> ' ' -- / -- |
7 | 3323 else if (c == 252) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3324 return ' '; // \"u --> ' ' -- / -- |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3325 // NOTE: islower() does not do the right thing for us on Linux so we |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3326 // do this the same was as 5.7 and previous, so it works correctly on |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3327 // all systems. Specifically, the e.g. Delete and Arrow keys are |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3328 // munged and won't work if e.g. searching for Hebrew text. |
7 | 3329 else if (c >= 'a' && c <= 'z') |
3330 return (int)(map[CharOrdLow(c)] + p_aleph); | |
3331 else | |
3332 return c; | |
3333 } | |
3334 else | |
3335 { | |
3336 switch (c) | |
3337 { | |
3338 case '`': return ';'; | |
3339 case '/': return '.'; | |
3340 case '\'': return ','; | |
3341 case 'q': return '/'; | |
3342 case 'w': return '\''; | |
3343 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3344 // Hebrew letters - set offset from 'a' |
7 | 3345 case ',': c = '{'; break; |
3346 case '.': c = 'v'; break; | |
3347 case ';': c = 't'; break; | |
3348 default: { | |
3349 static char str[] = "zqbcxlsjphmkwonu ydafe rig"; | |
3350 | |
3351 if (c < 'a' || c > 'z') | |
3352 return c; | |
3353 c = str[CharOrdLow(c)]; | |
3354 break; | |
3355 } | |
3356 } | |
3357 | |
3358 return (int)(CharOrdLow(c) + p_aleph); | |
3359 } | |
3360 } | |
3361 #endif | |
3362 | |
3363 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3364 ins_reg(void) |
7 | 3365 { |
3366 int need_redraw = FALSE; | |
3367 int regname; | |
3368 int literally = 0; | |
844 | 3369 int vis_active = VIsual_active; |
7 | 3370 |
3371 /* | |
3372 * If we are going to wait for a character, show a '"'. | |
3373 */ | |
3374 pc_status = PC_STATUS_UNSET; | |
3375 if (redrawing() && !char_avail()) | |
3376 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3377 // may need to redraw when no more chars available now |
661 | 3378 ins_redraw(FALSE); |
7 | 3379 |
3380 edit_putchar('"', TRUE); | |
3381 add_to_showcmd_c(Ctrl_R); | |
3382 } | |
3383 | |
3384 #ifdef USE_ON_FLY_SCROLL | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3385 dont_scroll = TRUE; // disallow scrolling here |
7 | 3386 #endif |
3387 | |
3388 /* | |
3389 * Don't map the register name. This also prevents the mode message to be | |
3390 * deleted when ESC is hit. | |
3391 */ | |
3392 ++no_mapping; | |
18709
ac08c7ad9d37
patch 8.1.2346: CTRL-R CTRL-R doesn't work with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18671
diff
changeset
|
3393 ++allow_keys; |
1389 | 3394 regname = plain_vgetc(); |
7 | 3395 LANGMAP_ADJUST(regname, TRUE); |
3396 if (regname == Ctrl_R || regname == Ctrl_O || regname == Ctrl_P) | |
3397 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3398 // Get a third key for literal register insertion |
7 | 3399 literally = regname; |
3400 add_to_showcmd_c(literally); | |
1389 | 3401 regname = plain_vgetc(); |
7 | 3402 LANGMAP_ADJUST(regname, TRUE); |
3403 } | |
3404 --no_mapping; | |
18709
ac08c7ad9d37
patch 8.1.2346: CTRL-R CTRL-R doesn't work with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18671
diff
changeset
|
3405 --allow_keys; |
7 | 3406 |
3407 #ifdef FEAT_EVAL | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3408 // Don't call u_sync() while typing the expression or giving an error |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3409 // message for it. Only call it explicitly. |
7 | 3410 ++no_u_sync; |
3411 if (regname == '=') | |
3412 { | |
15569
43fa814a7977
patch 8.1.0792: bad display if opening cmdline window from Insert completion
Bram Moolenaar <Bram@vim.org>
parents:
15543
diff
changeset
|
3413 pos_T curpos = curwin->w_cursor; |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
3414 # ifdef HAVE_INPUT_METHOD |
7 | 3415 int im_on = im_get_status(); |
133 | 3416 # endif |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3417 // Sync undo when evaluating the expression calls setline() or |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3418 // append(), so that it can be undone separately. |
5120
6e611380b4cf
updated for version 7.3.1303
Bram Moolenaar <bram@vim.org>
parents:
5094
diff
changeset
|
3419 u_sync_once = 2; |
5018
d6a7dea44a86
updated for version 7.3.1253
Bram Moolenaar <bram@vim.org>
parents:
4909
diff
changeset
|
3420 |
7 | 3421 regname = get_expr_register(); |
15569
43fa814a7977
patch 8.1.0792: bad display if opening cmdline window from Insert completion
Bram Moolenaar <Bram@vim.org>
parents:
15543
diff
changeset
|
3422 |
43fa814a7977
patch 8.1.0792: bad display if opening cmdline window from Insert completion
Bram Moolenaar <Bram@vim.org>
parents:
15543
diff
changeset
|
3423 // Cursor may be moved back a column. |
43fa814a7977
patch 8.1.0792: bad display if opening cmdline window from Insert completion
Bram Moolenaar <Bram@vim.org>
parents:
15543
diff
changeset
|
3424 curwin->w_cursor = curpos; |
43fa814a7977
patch 8.1.0792: bad display if opening cmdline window from Insert completion
Bram Moolenaar <Bram@vim.org>
parents:
15543
diff
changeset
|
3425 check_cursor(); |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
3426 # ifdef HAVE_INPUT_METHOD |
15569
43fa814a7977
patch 8.1.0792: bad display if opening cmdline window from Insert completion
Bram Moolenaar <Bram@vim.org>
parents:
15543
diff
changeset
|
3427 // Restore the Input Method. |
7 | 3428 if (im_on) |
3429 im_set_active(TRUE); | |
133 | 3430 # endif |
7 | 3431 } |
140 | 3432 if (regname == NUL || !valid_yank_reg(regname, FALSE)) |
3433 { | |
6949 | 3434 vim_beep(BO_REG); |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3435 need_redraw = TRUE; // remove the '"' |
140 | 3436 } |
7 | 3437 else |
3438 { | |
3439 #endif | |
3440 if (literally == Ctrl_O || literally == Ctrl_P) | |
3441 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3442 // Append the command to the redo buffer. |
7 | 3443 AppendCharToRedobuff(Ctrl_R); |
3444 AppendCharToRedobuff(literally); | |
3445 AppendCharToRedobuff(regname); | |
3446 | |
22176
6941d3205be9
patch 8.2.1637: Vim9: :put ={expr} does not work inside :def function
Bram Moolenaar <Bram@vim.org>
parents:
22095
diff
changeset
|
3447 do_put(regname, NULL, BACKWARD, 1L, |
7 | 3448 (literally == Ctrl_P ? PUT_FIXINDENT : 0) | PUT_CURSEND); |
3449 } | |
3450 else if (insert_reg(regname, literally) == FAIL) | |
3451 { | |
6949 | 3452 vim_beep(BO_REG); |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3453 need_redraw = TRUE; // remove the '"' |
7 | 3454 } |
133 | 3455 else if (stop_insert_mode) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3456 // When the '=' register was used and a function was invoked that |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3457 // did ":stopinsert" then stuff_empty() returns FALSE but we won't |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3458 // insert anything, need to remove the '"' |
133 | 3459 need_redraw = TRUE; |
3460 | |
7 | 3461 #ifdef FEAT_EVAL |
3462 } | |
3463 --no_u_sync; | |
5120
6e611380b4cf
updated for version 7.3.1303
Bram Moolenaar <bram@vim.org>
parents:
5094
diff
changeset
|
3464 if (u_sync_once == 1) |
6e611380b4cf
updated for version 7.3.1303
Bram Moolenaar <bram@vim.org>
parents:
5094
diff
changeset
|
3465 ins_need_undo = TRUE; |
6e611380b4cf
updated for version 7.3.1303
Bram Moolenaar <bram@vim.org>
parents:
5094
diff
changeset
|
3466 u_sync_once = 0; |
7 | 3467 #endif |
3468 clear_showcmd(); | |
3469 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3470 // If the inserted register is empty, we need to remove the '"' |
7 | 3471 if (need_redraw || stuff_empty()) |
3472 edit_unputchar(); | |
844 | 3473 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3474 // Disallow starting Visual mode here, would get a weird mode. |
844 | 3475 if (!vis_active && VIsual_active) |
3476 end_visual_mode(); | |
7 | 3477 } |
3478 | |
3479 /* | |
3480 * CTRL-G commands in Insert mode. | |
3481 */ | |
3482 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3483 ins_ctrl_g(void) |
7 | 3484 { |
3485 int c; | |
3486 | |
17809
59f8948b7590
patch 8.1.1901: the +insert_expand feature is not always available
Bram Moolenaar <Bram@vim.org>
parents:
17775
diff
changeset
|
3487 // Right after CTRL-X the cursor will be after the ruler. |
7 | 3488 setcursor(); |
3489 | |
3490 /* | |
3491 * Don't map the second key. This also prevents the mode message to be | |
3492 * deleted when ESC is hit. | |
3493 */ | |
3494 ++no_mapping; | |
18709
ac08c7ad9d37
patch 8.1.2346: CTRL-R CTRL-R doesn't work with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18671
diff
changeset
|
3495 ++allow_keys; |
1389 | 3496 c = plain_vgetc(); |
7 | 3497 --no_mapping; |
18709
ac08c7ad9d37
patch 8.1.2346: CTRL-R CTRL-R doesn't work with modifyOtherKeys
Bram Moolenaar <Bram@vim.org>
parents:
18671
diff
changeset
|
3498 --allow_keys; |
7 | 3499 switch (c) |
3500 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3501 // CTRL-G k and CTRL-G <Up>: cursor up to Insstart.col |
7 | 3502 case K_UP: |
3503 case Ctrl_K: | |
3504 case 'k': ins_up(TRUE); | |
3505 break; | |
3506 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3507 // CTRL-G j and CTRL-G <Down>: cursor down to Insstart.col |
7 | 3508 case K_DOWN: |
3509 case Ctrl_J: | |
3510 case 'j': ins_down(TRUE); | |
3511 break; | |
3512 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3513 // CTRL-G u: start new undoable edit |
825 | 3514 case 'u': u_sync(TRUE); |
7 | 3515 ins_need_undo = TRUE; |
626 | 3516 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3517 // Need to reset Insstart, esp. because a BS that joins |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3518 // a line to the previous one must save for undo. |
5680 | 3519 update_Insstart_orig = FALSE; |
626 | 3520 Insstart = curwin->w_cursor; |
7 | 3521 break; |
3522 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3523 // CTRL-G U: do not break undo with the next char |
7074
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
3524 case 'U': |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3525 // Allow one left/right cursor movement with the next char, |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3526 // without breaking undo. |
7074
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
3527 dont_sync_undo = MAYBE; |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
3528 break; |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
3529 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3530 // Unknown CTRL-G command, reserved for future expansion. |
6949 | 3531 default: vim_beep(BO_CTRLG); |
7 | 3532 } |
3533 } | |
3534 | |
3535 /* | |
449 | 3536 * CTRL-^ in Insert mode. |
3537 */ | |
3538 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3539 ins_ctrl_hat(void) |
449 | 3540 { |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
3541 if (map_to_exists_mode((char_u *)"", MODE_LANGMAP, FALSE)) |
449 | 3542 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3543 // ":lmap" mappings exists, Toggle use of ":lmap" mappings. |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
3544 if (State & MODE_LANGMAP) |
449 | 3545 { |
3546 curbuf->b_p_iminsert = B_IMODE_NONE; | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
3547 State &= ~MODE_LANGMAP; |
449 | 3548 } |
3549 else | |
3550 { | |
3551 curbuf->b_p_iminsert = B_IMODE_LMAP; | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
3552 State |= MODE_LANGMAP; |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
3553 #ifdef HAVE_INPUT_METHOD |
449 | 3554 im_set_active(FALSE); |
3555 #endif | |
3556 } | |
3557 } | |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
3558 #ifdef HAVE_INPUT_METHOD |
449 | 3559 else |
3560 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3561 // There are no ":lmap" mappings, toggle IM |
449 | 3562 if (im_get_status()) |
3563 { | |
3564 curbuf->b_p_iminsert = B_IMODE_NONE; | |
3565 im_set_active(FALSE); | |
3566 } | |
3567 else | |
3568 { | |
3569 curbuf->b_p_iminsert = B_IMODE_IM; | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
3570 State &= ~MODE_LANGMAP; |
449 | 3571 im_set_active(TRUE); |
3572 } | |
3573 } | |
3574 #endif | |
3575 set_iminsert_global(); | |
3576 showmode(); | |
3577 #ifdef FEAT_GUI | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3578 // may show different cursor shape or color |
449 | 3579 if (gui.in_use) |
3580 gui_update_cursor(TRUE, FALSE); | |
3581 #endif | |
12477
68d7bc045dbe
patch 8.0.1118: FEAT_WINDOWS adds a lot of #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
12323
diff
changeset
|
3582 #if defined(FEAT_KEYMAP) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3583 // Show/unshow value of 'keymap' in status lines. |
449 | 3584 status_redraw_curbuf(); |
3585 #endif | |
3586 } | |
3587 | |
3588 /* | |
7 | 3589 * Handle ESC in insert mode. |
3590 * Returns TRUE when leaving insert mode, FALSE when going to repeat the | |
3591 * insert. | |
3592 */ | |
3593 static int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3594 ins_esc( |
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3595 long *count, |
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3596 int cmdchar, |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3597 int nomove) // don't move cursor |
7 | 3598 { |
3599 int temp; | |
3600 static int disabled_redraw = FALSE; | |
25818
37bc83bbda91
patch 8.2.3444: concealed text not revealed when leaving insert mode
Bram Moolenaar <Bram@vim.org>
parents:
25790
diff
changeset
|
3601 #ifdef FEAT_CONCEAL |
37bc83bbda91
patch 8.2.3444: concealed text not revealed when leaving insert mode
Bram Moolenaar <Bram@vim.org>
parents:
25790
diff
changeset
|
3602 // Remember if the cursor line was concealed before changing State. |
37bc83bbda91
patch 8.2.3444: concealed text not revealed when leaving insert mode
Bram Moolenaar <Bram@vim.org>
parents:
25790
diff
changeset
|
3603 int cursor_line_was_concealed = curwin->w_p_cole > 0 |
37bc83bbda91
patch 8.2.3444: concealed text not revealed when leaving insert mode
Bram Moolenaar <Bram@vim.org>
parents:
25790
diff
changeset
|
3604 && conceal_cursor_line(curwin); |
37bc83bbda91
patch 8.2.3444: concealed text not revealed when leaving insert mode
Bram Moolenaar <Bram@vim.org>
parents:
25790
diff
changeset
|
3605 #endif |
7 | 3606 |
744 | 3607 #ifdef FEAT_SPELL |
449 | 3608 check_spell_redraw(); |
3609 #endif | |
7 | 3610 |
3611 temp = curwin->w_cursor.col; | |
3612 if (disabled_redraw) | |
3613 { | |
3614 --RedrawingDisabled; | |
3615 disabled_redraw = FALSE; | |
3616 } | |
3617 if (!arrow_used) | |
3618 { | |
3619 /* | |
3620 * Don't append the ESC for "r<CR>" and "grx". | |
75 | 3621 * When 'insertmode' is set only CTRL-L stops Insert mode. Needed for |
3622 * when "count" is non-zero. | |
7 | 3623 */ |
3624 if (cmdchar != 'r' && cmdchar != 'v') | |
75 | 3625 AppendToRedobuff(p_im ? (char_u *)"\014" : ESC_STR); |
7 | 3626 |
3627 /* | |
3628 * Repeating insert may take a long time. Check for | |
3629 * interrupt now and then. | |
3630 */ | |
3631 if (*count > 0) | |
3632 { | |
3633 line_breakcheck(); | |
3634 if (got_int) | |
3635 *count = 0; | |
3636 } | |
3637 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3638 if (--*count > 0) // repeat what was typed |
7 | 3639 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3640 // Vi repeats the insert without replacing characters. |
164 | 3641 if (vim_strchr(p_cpo, CPO_REPLCNT) != NULL) |
3642 State &= ~REPLACE_FLAG; | |
3643 | |
7 | 3644 (void)start_redo_ins(); |
3645 if (cmdchar == 'r' || cmdchar == 'v') | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3646 stuffRedoReadbuff(ESC_STR); // no ESC in redo buffer |
7 | 3647 ++RedrawingDisabled; |
3648 disabled_redraw = TRUE; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3649 return FALSE; // repeat the insert |
7 | 3650 } |
5434 | 3651 stop_insert(&curwin->w_cursor, TRUE, nomove); |
7 | 3652 undisplay_dollar(); |
3653 } | |
3654 | |
22651
fba5ccf33794
patch 8.2.1874: can't do something just before leaving Insert mode
Bram Moolenaar <Bram@vim.org>
parents:
22427
diff
changeset
|
3655 if (cmdchar != 'r' && cmdchar != 'v') |
fba5ccf33794
patch 8.2.1874: can't do something just before leaving Insert mode
Bram Moolenaar <Bram@vim.org>
parents:
22427
diff
changeset
|
3656 ins_apply_autocmds(EVENT_INSERTLEAVEPRE); |
fba5ccf33794
patch 8.2.1874: can't do something just before leaving Insert mode
Bram Moolenaar <Bram@vim.org>
parents:
22427
diff
changeset
|
3657 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3658 // When an autoindent was removed, curswant stays after the |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3659 // indent |
7 | 3660 if (restart_edit == NUL && (colnr_T)temp == curwin->w_cursor.col) |
3661 curwin->w_set_curswant = TRUE; | |
3662 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3663 // Remember the last Insert position in the '^ mark. |
22699
e82579016863
patch 8.2.1898: command modifier parsing always uses global cmdmod
Bram Moolenaar <Bram@vim.org>
parents:
22651
diff
changeset
|
3664 if ((cmdmod.cmod_flags & CMOD_KEEPJUMPS) == 0) |
7 | 3665 curbuf->b_last_insert = curwin->w_cursor; |
3666 | |
3667 /* | |
3668 * The cursor should end up on the last inserted character. | |
477 | 3669 * Don't do it for CTRL-O, unless past the end of the line. |
7 | 3670 */ |
477 | 3671 if (!nomove |
3672 && (curwin->w_cursor.col != 0 | |
15636
6f1c7e9a6393
patch 8.1.0826: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15629
diff
changeset
|
3673 || curwin->w_cursor.coladd > 0) |
477 | 3674 && (restart_edit == NUL |
5735 | 3675 || (gchar_cursor() == NUL && !VIsual_active)) |
7 | 3676 #ifdef FEAT_RIGHTLEFT |
3677 && !revins_on | |
3678 #endif | |
3679 ) | |
3680 { | |
25380
ac88cd21ae88
patch 8.2.3227: 'virtualedit' can only be set globally
Bram Moolenaar <Bram@vim.org>
parents:
25378
diff
changeset
|
3681 if (curwin->w_cursor.coladd > 0 || get_ve_flags() == VE_ALL) |
7 | 3682 { |
3683 oneleft(); | |
3684 if (restart_edit != NUL) | |
3685 ++curwin->w_cursor.coladd; | |
3686 } | |
3687 else | |
3688 { | |
3689 --curwin->w_cursor.col; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3690 // Correct cursor for multi-byte character. |
7 | 3691 if (has_mbyte) |
3692 mb_adjust_cursor(); | |
3693 } | |
3694 } | |
3695 | |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
3696 #ifdef HAVE_INPUT_METHOD |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3697 // Disable IM to allow typing English directly for Normal mode commands. |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3698 // When ":lmap" is enabled don't change 'iminsert' (IM can be enabled as |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3699 // well). |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
3700 if (!(State & MODE_LANGMAP)) |
7 | 3701 im_save_status(&curbuf->b_p_iminsert); |
3702 im_set_active(FALSE); | |
3703 #endif | |
3704 | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
3705 State = MODE_NORMAL; |
28397
d1702731786c
patch 8.2.4723: the ModeChanged autocmd event is inefficient
Bram Moolenaar <Bram@vim.org>
parents:
28375
diff
changeset
|
3706 may_trigger_modechanged(); |
28363
a9a56b567709
patch 8.2.4707: redrawing could be a bit more efficient
Bram Moolenaar <Bram@vim.org>
parents:
28269
diff
changeset
|
3707 // need to position cursor again when on a TAB |
a9a56b567709
patch 8.2.4707: redrawing could be a bit more efficient
Bram Moolenaar <Bram@vim.org>
parents:
28269
diff
changeset
|
3708 if (gchar_cursor() == TAB) |
a9a56b567709
patch 8.2.4707: redrawing could be a bit more efficient
Bram Moolenaar <Bram@vim.org>
parents:
28269
diff
changeset
|
3709 curwin->w_valid &= ~(VALID_WROW|VALID_WCOL|VALID_VIRTCOL); |
7 | 3710 |
3711 setmouse(); | |
3712 #ifdef CURSOR_SHAPE | |
18534
7dd83b5325e9
patch 8.1.2261: with modifyOtherKeys set 'noesckeys' doesn't work
Bram Moolenaar <Bram@vim.org>
parents:
18354
diff
changeset
|
3713 ui_cursor_shape(); // may show different cursor shape |
7 | 3714 #endif |
10684
83a36d655a74
patch 8.0.0232: paste does not work when 'esckeys' is off
Christian Brabandt <cb@256bit.org>
parents:
10682
diff
changeset
|
3715 if (!p_ek) |
18534
7dd83b5325e9
patch 8.1.2261: with modifyOtherKeys set 'noesckeys' doesn't work
Bram Moolenaar <Bram@vim.org>
parents:
18354
diff
changeset
|
3716 { |
29069
be6c32395444
patch 8.2.5056: the channel log only contains some of the raw terminal output
Bram Moolenaar <Bram@vim.org>
parents:
29014
diff
changeset
|
3717 MAY_WANT_TO_LOG_THIS; |
be6c32395444
patch 8.2.5056: the channel log only contains some of the raw terminal output
Bram Moolenaar <Bram@vim.org>
parents:
29014
diff
changeset
|
3718 |
18534
7dd83b5325e9
patch 8.1.2261: with modifyOtherKeys set 'noesckeys' doesn't work
Bram Moolenaar <Bram@vim.org>
parents:
18354
diff
changeset
|
3719 // Re-enable bracketed paste mode. |
31588
e94571ac4134
patch 9.0.1126: bracketed paste can be enabled when it is not recognized
Bram Moolenaar <Bram@vim.org>
parents:
31545
diff
changeset
|
3720 out_str_t_BE(); |
7 | 3721 |
18534
7dd83b5325e9
patch 8.1.2261: with modifyOtherKeys set 'noesckeys' doesn't work
Bram Moolenaar <Bram@vim.org>
parents:
18354
diff
changeset
|
3722 // Re-enable modifyOtherKeys. |
31293
ff4473b3fc58
patch 9.0.0980: the keyboard state response may end up in a shell command
Bram Moolenaar <Bram@vim.org>
parents:
31192
diff
changeset
|
3723 out_str_t_TI(); |
18534
7dd83b5325e9
patch 8.1.2261: with modifyOtherKeys set 'noesckeys' doesn't work
Bram Moolenaar <Bram@vim.org>
parents:
18354
diff
changeset
|
3724 } |
25818
37bc83bbda91
patch 8.2.3444: concealed text not revealed when leaving insert mode
Bram Moolenaar <Bram@vim.org>
parents:
25790
diff
changeset
|
3725 #ifdef FEAT_CONCEAL |
37bc83bbda91
patch 8.2.3444: concealed text not revealed when leaving insert mode
Bram Moolenaar <Bram@vim.org>
parents:
25790
diff
changeset
|
3726 // Check if the cursor line needs redrawing after changing State. If |
37bc83bbda91
patch 8.2.3444: concealed text not revealed when leaving insert mode
Bram Moolenaar <Bram@vim.org>
parents:
25790
diff
changeset
|
3727 // 'concealcursor' is "i" it needs to be redrawn without concealing. |
37bc83bbda91
patch 8.2.3444: concealed text not revealed when leaving insert mode
Bram Moolenaar <Bram@vim.org>
parents:
25790
diff
changeset
|
3728 conceal_check_cursor_line(cursor_line_was_concealed); |
37bc83bbda91
patch 8.2.3444: concealed text not revealed when leaving insert mode
Bram Moolenaar <Bram@vim.org>
parents:
25790
diff
changeset
|
3729 #endif |
18534
7dd83b5325e9
patch 8.1.2261: with modifyOtherKeys set 'noesckeys' doesn't work
Bram Moolenaar <Bram@vim.org>
parents:
18354
diff
changeset
|
3730 |
16378
3d6b282e2d6e
patch 8.1.1194: typos and small problems in source files
Bram Moolenaar <Bram@vim.org>
parents:
16368
diff
changeset
|
3731 // When recording or for CTRL-O, need to display the new mode. |
3d6b282e2d6e
patch 8.1.1194: typos and small problems in source files
Bram Moolenaar <Bram@vim.org>
parents:
16368
diff
changeset
|
3732 // Otherwise remove the mode message. |
14004
e124262d435e
patch 8.1.0020: cannot tell whether a register is executing or recording
Christian Brabandt <cb@256bit.org>
parents:
13876
diff
changeset
|
3733 if (reg_recording != 0 || restart_edit != NUL) |
7 | 3734 showmode(); |
16368
a3b5cbd2effe
patch 8.1.1189: mode is not cleared when leaving Insert mode
Bram Moolenaar <Bram@vim.org>
parents:
16162
diff
changeset
|
3735 else if (p_smd && (got_int || !skip_showmode())) |
15543
dd725a8ab112
patch 8.1.0779: argument for message functions is inconsistent
Bram Moolenaar <Bram@vim.org>
parents:
15521
diff
changeset
|
3736 msg(""); |
7 | 3737 |
18534
7dd83b5325e9
patch 8.1.2261: with modifyOtherKeys set 'noesckeys' doesn't work
Bram Moolenaar <Bram@vim.org>
parents:
18354
diff
changeset
|
3738 return TRUE; // exit Insert mode |
7 | 3739 } |
3740 | |
3741 #ifdef FEAT_RIGHTLEFT | |
3742 /* | |
3743 * Toggle language: hkmap and revins_on. | |
3744 * Move to end of reverse inserted text. | |
3745 */ | |
3746 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3747 ins_ctrl_(void) |
7 | 3748 { |
3749 if (revins_on && revins_chars && revins_scol >= 0) | |
3750 { | |
3751 while (gchar_cursor() != NUL && revins_chars--) | |
3752 ++curwin->w_cursor.col; | |
3753 } | |
3754 p_ri = !p_ri; | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
3755 revins_on = (State == MODE_INSERT && p_ri); |
7 | 3756 if (revins_on) |
3757 { | |
3758 revins_scol = curwin->w_cursor.col; | |
3759 revins_legal++; | |
3760 revins_chars = 0; | |
3761 undisplay_dollar(); | |
3762 } | |
3763 else | |
3764 revins_scol = -1; | |
15850
a6ca8cf07a98
patch 8.1.0932: Farsi support is outdated and unused
Bram Moolenaar <Bram@vim.org>
parents:
15738
diff
changeset
|
3765 p_hkmap = curwin->w_p_rl ^ p_ri; // be consistent! |
7 | 3766 showmode(); |
3767 } | |
3768 #endif | |
3769 | |
3770 /* | |
3771 * If 'keymodel' contains "startsel", may start selection. | |
3772 * Returns TRUE when a CTRL-O and other keys stuffed. | |
3773 */ | |
3774 static int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3775 ins_start_select(int c) |
7 | 3776 { |
29566
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3777 if (!km_startsel) |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3778 return FALSE; |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3779 switch (c) |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3780 { |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3781 case K_KHOME: |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3782 case K_KEND: |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3783 case K_PAGEUP: |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3784 case K_KPAGEUP: |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3785 case K_PAGEDOWN: |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3786 case K_KPAGEDOWN: |
12716
351cf7c67bbe
patch 8.0.1236: Mac features are confusing
Christian Brabandt <cb@256bit.org>
parents:
12674
diff
changeset
|
3787 # ifdef MACOS_X |
29566
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3788 case K_LEFT: |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3789 case K_RIGHT: |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3790 case K_UP: |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3791 case K_DOWN: |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3792 case K_END: |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3793 case K_HOME: |
7 | 3794 # endif |
29566
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3795 if (!(mod_mask & MOD_MASK_SHIFT)) |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3796 break; |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3797 // FALLTHROUGH |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3798 case K_S_LEFT: |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3799 case K_S_RIGHT: |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3800 case K_S_UP: |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3801 case K_S_DOWN: |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3802 case K_S_END: |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3803 case K_S_HOME: |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3804 // Start selection right away, the cursor can move with CTRL-O when |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3805 // beyond the end of the line. |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3806 start_selection(); |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3807 |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3808 // Execute the key in (insert) Select mode. |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3809 stuffcharReadbuff(Ctrl_O); |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3810 if (mod_mask) |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3811 { |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3812 char_u buf[4]; |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3813 |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3814 buf[0] = K_SPECIAL; |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3815 buf[1] = KS_MODIFIER; |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3816 buf[2] = mod_mask; |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3817 buf[3] = NUL; |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3818 stuffReadbuff(buf); |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3819 } |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3820 stuffcharReadbuff(c); |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3821 return TRUE; |
99e3763cbd34
patch 9.0.0124: code has more indent than needed
Bram Moolenaar <Bram@vim.org>
parents:
29451
diff
changeset
|
3822 } |
7 | 3823 return FALSE; |
3824 } | |
3825 | |
3826 /* | |
4352 | 3827 * <Insert> key in Insert mode: toggle insert/replace mode. |
449 | 3828 */ |
3829 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3830 ins_insert(int replaceState) |
449 | 3831 { |
15850
a6ca8cf07a98
patch 8.1.0932: Farsi support is outdated and unused
Bram Moolenaar <Bram@vim.org>
parents:
15738
diff
changeset
|
3832 #ifdef FEAT_EVAL |
449 | 3833 set_vim_var_string(VV_INSERTMODE, |
14424
0a69e6e708f9
patch 8.1.0226: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
14419
diff
changeset
|
3834 (char_u *)((State & REPLACE_FLAG) ? "i" |
28809
d0241e74bfdb
patch 8.2.4928: various white space and cosmetic mistakes
Bram Moolenaar <Bram@vim.org>
parents:
28773
diff
changeset
|
3835 : replaceState == MODE_VREPLACE ? "v" : "r"), 1); |
15850
a6ca8cf07a98
patch 8.1.0932: Farsi support is outdated and unused
Bram Moolenaar <Bram@vim.org>
parents:
15738
diff
changeset
|
3836 #endif |
14485
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
3837 ins_apply_autocmds(EVENT_INSERTCHANGE); |
449 | 3838 if (State & REPLACE_FLAG) |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
3839 State = MODE_INSERT | (State & MODE_LANGMAP); |
449 | 3840 else |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
3841 State = replaceState | (State & MODE_LANGMAP); |
28397
d1702731786c
patch 8.2.4723: the ModeChanged autocmd event is inefficient
Bram Moolenaar <Bram@vim.org>
parents:
28375
diff
changeset
|
3842 may_trigger_modechanged(); |
449 | 3843 AppendCharToRedobuff(K_INS); |
3844 showmode(); | |
3845 #ifdef CURSOR_SHAPE | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3846 ui_cursor_shape(); // may show different cursor shape |
449 | 3847 #endif |
3848 } | |
3849 | |
3850 /* | |
3851 * Pressed CTRL-O in Insert mode. | |
3852 */ | |
3853 static void | |
32031
e9b8deedab60
patch 9.0.1347: "gr CTRL-O" stays in Insert mode
Bram Moolenaar <Bram@vim.org>
parents:
32009
diff
changeset
|
3854 ins_ctrl_o(int cmdchar) |
449 | 3855 { |
32031
e9b8deedab60
patch 9.0.1347: "gr CTRL-O" stays in Insert mode
Bram Moolenaar <Bram@vim.org>
parents:
32009
diff
changeset
|
3856 if (cmdchar == 'v') |
e9b8deedab60
patch 9.0.1347: "gr CTRL-O" stays in Insert mode
Bram Moolenaar <Bram@vim.org>
parents:
32009
diff
changeset
|
3857 return; // abort replacing one char for gr CTRL-O |
449 | 3858 if (State & VREPLACE_FLAG) |
3859 restart_edit = 'V'; | |
23076
5fbac68bda23
patch 8.2.2084: CTRL-V U doesn't work to enter a Unicode character
Bram Moolenaar <Bram@vim.org>
parents:
22882
diff
changeset
|
3860 else if (State & REPLACE_FLAG) |
449 | 3861 restart_edit = 'R'; |
3862 else | |
3863 restart_edit = 'I'; | |
3864 if (virtual_active()) | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3865 ins_at_eol = FALSE; // cursor always keeps its column |
449 | 3866 else |
3867 ins_at_eol = (gchar_cursor() == NUL); | |
3868 } | |
3869 | |
3870 /* | |
7 | 3871 * If the cursor is on an indent, ^T/^D insert/delete one |
3872 * shiftwidth. Otherwise ^T/^D behave like a "<<" or ">>". | |
1796 | 3873 * Always round the indent to 'shiftwidth', this is compatible |
7 | 3874 * with vi. But vi only supports ^T and ^D after an |
3875 * autoindent, we support it everywhere. | |
3876 */ | |
3877 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3878 ins_shift(int c, int lastc) |
7 | 3879 { |
3880 if (stop_arrow() == FAIL) | |
3881 return; | |
3882 AppendCharToRedobuff(c); | |
3883 | |
3884 /* | |
3885 * 0^D and ^^D: remove all indent. | |
3886 */ | |
1330 | 3887 if (c == Ctrl_D && (lastc == '0' || lastc == '^') |
3888 && curwin->w_cursor.col > 0) | |
7 | 3889 { |
3890 --curwin->w_cursor.col; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3891 (void)del_char(FALSE); // delete the '^' or '0' |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3892 // In Replace mode, restore the characters that '^' or '0' replaced. |
7 | 3893 if (State & REPLACE_FLAG) |
3894 replace_pop_ins(); | |
3895 if (lastc == '^') | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3896 old_indent = get_indent(); // remember curr. indent |
1516 | 3897 change_indent(INDENT_SET, 0, TRUE, 0, TRUE); |
7 | 3898 } |
3899 else | |
1516 | 3900 change_indent(c == Ctrl_D ? INDENT_DEC : INDENT_INC, 0, TRUE, 0, TRUE); |
7 | 3901 |
3902 if (did_ai && *skipwhite(ml_get_curline()) != NUL) | |
3903 did_ai = FALSE; | |
3904 did_si = FALSE; | |
3905 can_si = FALSE; | |
3906 can_si_back = FALSE; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3907 can_cindent = FALSE; // no cindenting after ^D or ^T |
7 | 3908 } |
3909 | |
3910 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3911 ins_del(void) |
7 | 3912 { |
3913 int temp; | |
3914 | |
3915 if (stop_arrow() == FAIL) | |
3916 return; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3917 if (gchar_cursor() == NUL) // delete newline |
7 | 3918 { |
3919 temp = curwin->w_cursor.col; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3920 if (!can_bs(BS_EOL) // only if "eol" included |
5848 | 3921 || do_join(2, FALSE, TRUE, FALSE, FALSE) == FAIL) |
6949 | 3922 vim_beep(BO_BS); |
7 | 3923 else |
13402
338b15c63e2c
patch 8.0.1575: crash when using virtual replace
Christian Brabandt <cb@256bit.org>
parents:
13384
diff
changeset
|
3924 { |
7 | 3925 curwin->w_cursor.col = temp; |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3926 // Adjust orig_line_count in case more lines have been deleted than |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3927 // have been added. That makes sure, that open_line() later |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3928 // can access all buffer lines correctly |
13402
338b15c63e2c
patch 8.0.1575: crash when using virtual replace
Christian Brabandt <cb@256bit.org>
parents:
13384
diff
changeset
|
3929 if (State & VREPLACE_FLAG && |
338b15c63e2c
patch 8.0.1575: crash when using virtual replace
Christian Brabandt <cb@256bit.org>
parents:
13384
diff
changeset
|
3930 orig_line_count > curbuf->b_ml.ml_line_count) |
338b15c63e2c
patch 8.0.1575: crash when using virtual replace
Christian Brabandt <cb@256bit.org>
parents:
13384
diff
changeset
|
3931 orig_line_count = curbuf->b_ml.ml_line_count; |
338b15c63e2c
patch 8.0.1575: crash when using virtual replace
Christian Brabandt <cb@256bit.org>
parents:
13384
diff
changeset
|
3932 } |
7 | 3933 } |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3934 else if (del_char(FALSE) == FAIL) // delete char under cursor |
6949 | 3935 vim_beep(BO_BS); |
7 | 3936 did_ai = FALSE; |
3937 did_si = FALSE; | |
3938 can_si = FALSE; | |
3939 can_si_back = FALSE; | |
3940 AppendCharToRedobuff(K_DEL); | |
3941 } | |
3942 | |
1460 | 3943 /* |
3944 * Delete one character for ins_bs(). | |
3945 */ | |
3946 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3947 ins_bs_one(colnr_T *vcolp) |
1460 | 3948 { |
3949 dec_cursor(); | |
3950 getvcol(curwin, &curwin->w_cursor, vcolp, NULL, NULL); | |
3951 if (State & REPLACE_FLAG) | |
3952 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3953 // Don't delete characters before the insert point when in |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3954 // Replace mode |
1460 | 3955 if (curwin->w_cursor.lnum != Insstart.lnum |
3956 || curwin->w_cursor.col >= Insstart.col) | |
1782 | 3957 replace_do_bs(-1); |
1460 | 3958 } |
3959 else | |
3960 (void)del_char(FALSE); | |
3961 } | |
3962 | |
7 | 3963 /* |
3964 * Handle Backspace, delete-word and delete-line in Insert mode. | |
3965 * Return TRUE when backspace was actually used. | |
3966 */ | |
3967 static int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3968 ins_bs( |
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3969 int c, |
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3970 int mode, |
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
3971 int *inserted_space_p) |
7 | 3972 { |
3973 linenr_T lnum; | |
3974 int cc; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3975 int temp = 0; // init for GCC |
1872 | 3976 colnr_T save_col; |
7 | 3977 colnr_T mincol; |
3978 int did_backspace = FALSE; | |
3979 int in_indent; | |
3980 int oldState; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
3981 int cpc[MAX_MCO]; // composing characters |
26813
efa773bec478
patch 8.2.3935: CTRL-U in Insert mode does not fix the indent
Bram Moolenaar <Bram@vim.org>
parents:
26771
diff
changeset
|
3982 int call_fix_indent = FALSE; |
7 | 3983 |
3984 /* | |
3985 * can't delete anything in an empty file | |
3986 * can't backup past first character in buffer | |
3987 * can't backup past starting point unless 'backspace' > 1 | |
3988 * can backup to a previous line if 'backspace' == 0 | |
3989 */ | |
11121
778c10516955
patch 8.0.0448: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents:
11105
diff
changeset
|
3990 if ( BUFEMPTY() |
7 | 3991 || ( |
3992 #ifdef FEAT_RIGHTLEFT | |
3993 !revins_on && | |
3994 #endif | |
3995 ((curwin->w_cursor.lnum == 1 && curwin->w_cursor.col == 0) | |
3996 || (!can_bs(BS_START) | |
22858
52b5aa2e8c8f
patch 8.2.1976: cannot backspace in prompt buffer after using cursor-left
Bram Moolenaar <Bram@vim.org>
parents:
22699
diff
changeset
|
3997 && ((arrow_used |
52b5aa2e8c8f
patch 8.2.1976: cannot backspace in prompt buffer after using cursor-left
Bram Moolenaar <Bram@vim.org>
parents:
22699
diff
changeset
|
3998 #ifdef FEAT_JOB_CHANNEL |
52b5aa2e8c8f
patch 8.2.1976: cannot backspace in prompt buffer after using cursor-left
Bram Moolenaar <Bram@vim.org>
parents:
22699
diff
changeset
|
3999 && !bt_prompt(curbuf) |
52b5aa2e8c8f
patch 8.2.1976: cannot backspace in prompt buffer after using cursor-left
Bram Moolenaar <Bram@vim.org>
parents:
22699
diff
changeset
|
4000 #endif |
52b5aa2e8c8f
patch 8.2.1976: cannot backspace in prompt buffer after using cursor-left
Bram Moolenaar <Bram@vim.org>
parents:
22699
diff
changeset
|
4001 ) || (curwin->w_cursor.lnum == Insstart_orig.lnum |
5852 | 4002 && curwin->w_cursor.col <= Insstart_orig.col))) |
7 | 4003 || (!can_bs(BS_INDENT) && !arrow_used && ai_col > 0 |
4004 && curwin->w_cursor.col <= ai_col) | |
4005 || (!can_bs(BS_EOL) && curwin->w_cursor.col == 0)))) | |
4006 { | |
6949 | 4007 vim_beep(BO_BS); |
7 | 4008 return FALSE; |
4009 } | |
4010 | |
4011 if (stop_arrow() == FAIL) | |
4012 return FALSE; | |
4013 in_indent = inindent(0); | |
4014 if (in_indent) | |
4015 can_cindent = FALSE; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4016 end_comment_pending = NUL; // After BS, don't auto-end comment |
7 | 4017 #ifdef FEAT_RIGHTLEFT |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4018 if (revins_on) // put cursor after last inserted char |
7 | 4019 inc_cursor(); |
4020 #endif | |
4021 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4022 // Virtualedit: |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4023 // BACKSPACE_CHAR eats a virtual space |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4024 // BACKSPACE_WORD eats all coladd |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4025 // BACKSPACE_LINE eats all coladd and keeps going |
7 | 4026 if (curwin->w_cursor.coladd > 0) |
4027 { | |
4028 if (mode == BACKSPACE_CHAR) | |
4029 { | |
4030 --curwin->w_cursor.coladd; | |
4031 return TRUE; | |
4032 } | |
4033 if (mode == BACKSPACE_WORD) | |
4034 { | |
4035 curwin->w_cursor.coladd = 0; | |
4036 return TRUE; | |
4037 } | |
4038 curwin->w_cursor.coladd = 0; | |
4039 } | |
4040 | |
4041 /* | |
11295
d772bf077b3f
patch 8.0.0533: abbreviation doesn't work after backspacing newline
Christian Brabandt <cb@256bit.org>
parents:
11289
diff
changeset
|
4042 * Delete newline! |
7 | 4043 */ |
4044 if (curwin->w_cursor.col == 0) | |
4045 { | |
6629 | 4046 lnum = Insstart.lnum; |
5852 | 4047 if (curwin->w_cursor.lnum == lnum |
7 | 4048 #ifdef FEAT_RIGHTLEFT |
4049 || revins_on | |
4050 #endif | |
4051 ) | |
4052 { | |
4053 if (u_save((linenr_T)(curwin->w_cursor.lnum - 2), | |
4054 (linenr_T)(curwin->w_cursor.lnum + 1)) == FAIL) | |
4055 return FALSE; | |
6629 | 4056 --Insstart.lnum; |
11311
be499043ca70
patch 8.0.0541: compiler warning on MS-Windows
Christian Brabandt <cb@256bit.org>
parents:
11295
diff
changeset
|
4057 Insstart.col = (colnr_T)STRLEN(ml_get(Insstart.lnum)); |
7 | 4058 } |
4059 /* | |
4060 * In replace mode: | |
4061 * cc < 0: NL was inserted, delete it | |
4062 * cc >= 0: NL was replaced, put original characters back | |
4063 */ | |
4064 cc = -1; | |
4065 if (State & REPLACE_FLAG) | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4066 cc = replace_pop(); // returns -1 if NL was inserted |
7 | 4067 /* |
4068 * In replace mode, in the line we started replacing, we only move the | |
4069 * cursor. | |
4070 */ | |
4071 if ((State & REPLACE_FLAG) && curwin->w_cursor.lnum <= lnum) | |
4072 { | |
4073 dec_cursor(); | |
4074 } | |
4075 else | |
4076 { | |
4077 if (!(State & VREPLACE_FLAG) | |
4078 || curwin->w_cursor.lnum > orig_line_count) | |
4079 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4080 temp = gchar_cursor(); // remember current char |
7 | 4081 --curwin->w_cursor.lnum; |
278 | 4082 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4083 // When "aw" is in 'formatoptions' we must delete the space at |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4084 // the end of the line, otherwise the line will be broken |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4085 // again when auto-formatting. |
278 | 4086 if (has_format_option(FO_AUTO) |
4087 && has_format_option(FO_WHITE_PAR)) | |
4088 { | |
4089 char_u *ptr = ml_get_buf(curbuf, curwin->w_cursor.lnum, | |
4090 TRUE); | |
4091 int len; | |
4092 | |
835 | 4093 len = (int)STRLEN(ptr); |
278 | 4094 if (len > 0 && ptr[len - 1] == ' ') |
4095 ptr[len - 1] = NUL; | |
4096 } | |
4097 | |
5848 | 4098 (void)do_join(2, FALSE, FALSE, FALSE, FALSE); |
7 | 4099 if (temp == NUL && gchar_cursor() != NUL) |
4100 inc_cursor(); | |
4101 } | |
4102 else | |
4103 dec_cursor(); | |
4104 | |
4105 /* | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
4106 * In MODE_REPLACE mode we have to put back the text that was |
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
4107 * replaced by the NL. On the replace stack is first a |
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
4108 * NUL-terminated sequence of characters that were deleted and then |
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
4109 * the characters that NL replaced. |
7 | 4110 */ |
4111 if (State & REPLACE_FLAG) | |
4112 { | |
4113 /* | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
4114 * Do the next ins_char() in MODE_NORMAL state, to |
7 | 4115 * prevent ins_char() from replacing characters and |
4116 * avoiding showmatch(). | |
4117 */ | |
4118 oldState = State; | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
4119 State = MODE_NORMAL; |
7 | 4120 /* |
4121 * restore characters (blanks) deleted after cursor | |
4122 */ | |
4123 while (cc > 0) | |
4124 { | |
1872 | 4125 save_col = curwin->w_cursor.col; |
7 | 4126 mb_replace_pop_ins(cc); |
1872 | 4127 curwin->w_cursor.col = save_col; |
7 | 4128 cc = replace_pop(); |
4129 } | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4130 // restore the characters that NL replaced |
7 | 4131 replace_pop_ins(); |
4132 State = oldState; | |
4133 } | |
4134 } | |
4135 did_ai = FALSE; | |
4136 } | |
4137 else | |
4138 { | |
4139 /* | |
4140 * Delete character(s) before the cursor. | |
4141 */ | |
4142 #ifdef FEAT_RIGHTLEFT | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4143 if (revins_on) // put cursor on last inserted char |
7 | 4144 dec_cursor(); |
4145 #endif | |
4146 mincol = 0; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4147 // keep indent |
1085 | 4148 if (mode == BACKSPACE_LINE |
28942
6cdf55afaae9
patch 8.2.4993: smart/C/lisp indenting is optional
Bram Moolenaar <Bram@vim.org>
parents:
28893
diff
changeset
|
4149 && (curbuf->b_p_ai || cindent_on()) |
7 | 4150 #ifdef FEAT_RIGHTLEFT |
4151 && !revins_on | |
4152 #endif | |
4153 ) | |
4154 { | |
1872 | 4155 save_col = curwin->w_cursor.col; |
7 | 4156 beginline(BL_WHITE); |
1988 | 4157 if (curwin->w_cursor.col < save_col) |
26813
efa773bec478
patch 8.2.3935: CTRL-U in Insert mode does not fix the indent
Bram Moolenaar <Bram@vim.org>
parents:
26771
diff
changeset
|
4158 { |
7 | 4159 mincol = curwin->w_cursor.col; |
26813
efa773bec478
patch 8.2.3935: CTRL-U in Insert mode does not fix the indent
Bram Moolenaar <Bram@vim.org>
parents:
26771
diff
changeset
|
4160 // should now fix the indent to match with the previous line |
efa773bec478
patch 8.2.3935: CTRL-U in Insert mode does not fix the indent
Bram Moolenaar <Bram@vim.org>
parents:
26771
diff
changeset
|
4161 call_fix_indent = TRUE; |
efa773bec478
patch 8.2.3935: CTRL-U in Insert mode does not fix the indent
Bram Moolenaar <Bram@vim.org>
parents:
26771
diff
changeset
|
4162 } |
1872 | 4163 curwin->w_cursor.col = save_col; |
7 | 4164 } |
4165 | |
4166 /* | |
4167 * Handle deleting one 'shiftwidth' or 'softtabstop'. | |
4168 */ | |
4169 if ( mode == BACKSPACE_CHAR | |
4170 && ((p_sta && in_indent) | |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4171 || ((get_sts_value() != 0 |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4172 #ifdef FEAT_VARTABS |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4173 || tabstop_count(curbuf->b_p_vsts_array) |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4174 #endif |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4175 ) |
1497 | 4176 && curwin->w_cursor.col > 0 |
7 | 4177 && (*(ml_get_cursor() - 1) == TAB |
4178 || (*(ml_get_cursor() - 1) == ' ' | |
4179 && (!*inserted_space_p | |
4180 || arrow_used)))))) | |
4181 { | |
4182 int ts; | |
4183 colnr_T vcol; | |
4184 colnr_T want_vcol; | |
1460 | 4185 colnr_T start_vcol; |
7 | 4186 |
4187 *inserted_space_p = FALSE; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4188 // Compute the virtual column where we want to be. Since |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4189 // 'showbreak' may get in the way, need to get the last column of |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4190 // the previous character. |
7 | 4191 getvcol(curwin, &curwin->w_cursor, &vcol, NULL, NULL); |
1460 | 4192 start_vcol = vcol; |
7 | 4193 dec_cursor(); |
4194 getvcol(curwin, &curwin->w_cursor, NULL, NULL, &want_vcol); | |
4195 inc_cursor(); | |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4196 #ifdef FEAT_VARTABS |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4197 if (p_sta && in_indent) |
14276
752ef53d3731
patch 8.1.0154: crash with "set smarttab shiftwidth=0 softtabstop=-1"
Christian Brabandt <cb@256bit.org>
parents:
14243
diff
changeset
|
4198 { |
752ef53d3731
patch 8.1.0154: crash with "set smarttab shiftwidth=0 softtabstop=-1"
Christian Brabandt <cb@256bit.org>
parents:
14243
diff
changeset
|
4199 ts = (int)get_sw_value(curbuf); |
752ef53d3731
patch 8.1.0154: crash with "set smarttab shiftwidth=0 softtabstop=-1"
Christian Brabandt <cb@256bit.org>
parents:
14243
diff
changeset
|
4200 want_vcol = (want_vcol / ts) * ts; |
752ef53d3731
patch 8.1.0154: crash with "set smarttab shiftwidth=0 softtabstop=-1"
Christian Brabandt <cb@256bit.org>
parents:
14243
diff
changeset
|
4201 } |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4202 else |
14243
fbf0681606fa
patch 8.1.0138: negative value of 'softtabstop' not used correctly
Christian Brabandt <cb@256bit.org>
parents:
14175
diff
changeset
|
4203 want_vcol = tabstop_start(want_vcol, get_sts_value(), |
27490
fb4c30606b4a
patch 8.2.4273: the EBCDIC support is outdated
Bram Moolenaar <Bram@vim.org>
parents:
27426
diff
changeset
|
4204 curbuf->b_p_vsts_array); |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4205 #else |
14276
752ef53d3731
patch 8.1.0154: crash with "set smarttab shiftwidth=0 softtabstop=-1"
Christian Brabandt <cb@256bit.org>
parents:
14243
diff
changeset
|
4206 if (p_sta && in_indent) |
752ef53d3731
patch 8.1.0154: crash with "set smarttab shiftwidth=0 softtabstop=-1"
Christian Brabandt <cb@256bit.org>
parents:
14243
diff
changeset
|
4207 ts = (int)get_sw_value(curbuf); |
752ef53d3731
patch 8.1.0154: crash with "set smarttab shiftwidth=0 softtabstop=-1"
Christian Brabandt <cb@256bit.org>
parents:
14243
diff
changeset
|
4208 else |
752ef53d3731
patch 8.1.0154: crash with "set smarttab shiftwidth=0 softtabstop=-1"
Christian Brabandt <cb@256bit.org>
parents:
14243
diff
changeset
|
4209 ts = (int)get_sts_value(); |
7 | 4210 want_vcol = (want_vcol / ts) * ts; |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4211 #endif |
7 | 4212 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4213 // delete characters until we are at or before want_vcol |
29291
3e5166df3004
patch 8.2.5162: reading before the start of the line with BS in Replace mode
Bram Moolenaar <Bram@vim.org>
parents:
29069
diff
changeset
|
4214 while (vcol > want_vcol && curwin->w_cursor.col > 0 |
11129
f4ea50924c6d
patch 8.0.0452: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents:
11127
diff
changeset
|
4215 && (cc = *(ml_get_cursor() - 1), VIM_ISWHITE(cc))) |
1460 | 4216 ins_bs_one(&vcol); |
7 | 4217 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4218 // insert extra spaces until we are at want_vcol |
7 | 4219 while (vcol < want_vcol) |
4220 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4221 // Remember the first char we inserted |
5852 | 4222 if (curwin->w_cursor.lnum == Insstart_orig.lnum |
4223 && curwin->w_cursor.col < Insstart_orig.col) | |
4224 Insstart_orig.col = curwin->w_cursor.col; | |
7 | 4225 |
4226 if (State & VREPLACE_FLAG) | |
4227 ins_char(' '); | |
4228 else | |
4229 { | |
4230 ins_str((char_u *)" "); | |
1460 | 4231 if ((State & REPLACE_FLAG)) |
4232 replace_push(NUL); | |
7 | 4233 } |
4234 getvcol(curwin, &curwin->w_cursor, &vcol, NULL, NULL); | |
4235 } | |
1460 | 4236 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4237 // If we are now back where we started delete one character. Can |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4238 // happen when using 'sts' and 'linebreak'. |
1460 | 4239 if (vcol >= start_vcol) |
4240 ins_bs_one(&vcol); | |
7 | 4241 } |
4242 | |
4243 /* | |
18763
49b78d6465e5
patch 8.1.2371: FEAT_TEXT_PROP is a confusing name
Bram Moolenaar <Bram@vim.org>
parents:
18717
diff
changeset
|
4244 * Delete up to starting point, start of line or previous word. |
7 | 4245 */ |
6712 | 4246 else |
4247 { | |
4248 int cclass = 0, prev_cclass = 0; | |
4249 | |
4250 if (has_mbyte) | |
4251 cclass = mb_get_class(ml_get_cursor()); | |
4252 do | |
7 | 4253 { |
4254 #ifdef FEAT_RIGHTLEFT | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4255 if (!revins_on) // put cursor on char to be deleted |
6712 | 4256 #endif |
7 | 4257 dec_cursor(); |
6712 | 4258 |
4259 cc = gchar_cursor(); | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4260 // look multi-byte character class |
6712 | 4261 if (has_mbyte) |
4262 { | |
4263 prev_cclass = cclass; | |
4264 cclass = mb_get_class(ml_get_cursor()); | |
4265 } | |
4266 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4267 // start of word? |
6712 | 4268 if (mode == BACKSPACE_WORD && !vim_isspace(cc)) |
4269 { | |
4270 mode = BACKSPACE_WORD_NOT_SPACE; | |
4271 temp = vim_iswordc(cc); | |
4272 } | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4273 // end of word? |
6712 | 4274 else if (mode == BACKSPACE_WORD_NOT_SPACE |
4275 && ((vim_isspace(cc) || vim_iswordc(cc) != temp) | |
15595
1ec942f1b648
patch 8.1.0805: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15569
diff
changeset
|
4276 || prev_cclass != cclass)) |
6712 | 4277 { |
4278 #ifdef FEAT_RIGHTLEFT | |
4279 if (!revins_on) | |
4280 #endif | |
4281 inc_cursor(); | |
4282 #ifdef FEAT_RIGHTLEFT | |
4283 else if (State & REPLACE_FLAG) | |
4284 dec_cursor(); | |
4285 #endif | |
4286 break; | |
4287 } | |
4288 if (State & REPLACE_FLAG) | |
4289 replace_do_bs(-1); | |
4290 else | |
4291 { | |
4292 if (enc_utf8 && p_deco) | |
4293 (void)utfc_ptr2char(ml_get_cursor(), cpc); | |
4294 (void)del_char(FALSE); | |
4295 /* | |
4296 * If there are combining characters and 'delcombine' is set | |
4297 * move the cursor back. Don't back up before the base | |
4298 * character. | |
4299 */ | |
4300 if (enc_utf8 && p_deco && cpc[0] != NUL) | |
4301 inc_cursor(); | |
7 | 4302 #ifdef FEAT_RIGHTLEFT |
6712 | 4303 if (revins_chars) |
4304 { | |
4305 revins_chars--; | |
4306 revins_legal++; | |
4307 } | |
4308 if (revins_on && gchar_cursor() == NUL) | |
4309 break; | |
4310 #endif | |
7 | 4311 } |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4312 // Just a single backspace?: |
6712 | 4313 if (mode == BACKSPACE_CHAR) |
7 | 4314 break; |
6712 | 4315 } while ( |
7 | 4316 #ifdef FEAT_RIGHTLEFT |
6712 | 4317 revins_on || |
4318 #endif | |
4319 (curwin->w_cursor.col > mincol | |
20069
9a67d41708d2
patch 8.2.0590: no 'backspace' value allows ignoring the insertion point
Bram Moolenaar <Bram@vim.org>
parents:
19627
diff
changeset
|
4320 && (can_bs(BS_NOSTOP) |
9a67d41708d2
patch 8.2.0590: no 'backspace' value allows ignoring the insertion point
Bram Moolenaar <Bram@vim.org>
parents:
19627
diff
changeset
|
4321 || (curwin->w_cursor.lnum != Insstart_orig.lnum |
9a67d41708d2
patch 8.2.0590: no 'backspace' value allows ignoring the insertion point
Bram Moolenaar <Bram@vim.org>
parents:
19627
diff
changeset
|
4322 || curwin->w_cursor.col != Insstart_orig.col) |
9a67d41708d2
patch 8.2.0590: no 'backspace' value allows ignoring the insertion point
Bram Moolenaar <Bram@vim.org>
parents:
19627
diff
changeset
|
4323 ))); |
6712 | 4324 } |
7 | 4325 did_backspace = TRUE; |
4326 } | |
4327 did_si = FALSE; | |
4328 can_si = FALSE; | |
4329 can_si_back = FALSE; | |
4330 if (curwin->w_cursor.col <= 1) | |
4331 did_ai = FALSE; | |
26813
efa773bec478
patch 8.2.3935: CTRL-U in Insert mode does not fix the indent
Bram Moolenaar <Bram@vim.org>
parents:
26771
diff
changeset
|
4332 |
efa773bec478
patch 8.2.3935: CTRL-U in Insert mode does not fix the indent
Bram Moolenaar <Bram@vim.org>
parents:
26771
diff
changeset
|
4333 if (call_fix_indent) |
efa773bec478
patch 8.2.3935: CTRL-U in Insert mode does not fix the indent
Bram Moolenaar <Bram@vim.org>
parents:
26771
diff
changeset
|
4334 fix_indent(); |
efa773bec478
patch 8.2.3935: CTRL-U in Insert mode does not fix the indent
Bram Moolenaar <Bram@vim.org>
parents:
26771
diff
changeset
|
4335 |
7 | 4336 /* |
4337 * It's a little strange to put backspaces into the redo | |
4338 * buffer, but it makes auto-indent a lot easier to deal | |
4339 * with. | |
4340 */ | |
4341 AppendCharToRedobuff(c); | |
4342 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4343 // If deleted before the insertion point, adjust it |
5852 | 4344 if (curwin->w_cursor.lnum == Insstart_orig.lnum |
14037
afce2005fdc8
patch 8.1.0036: not restoring Insert mode if leaving prompt buffer with mouse
Christian Brabandt <cb@256bit.org>
parents:
14035
diff
changeset
|
4345 && curwin->w_cursor.col < Insstart_orig.col) |
5852 | 4346 Insstart_orig.col = curwin->w_cursor.col; |
7 | 4347 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4348 // vi behaviour: the cursor moves backward but the character that |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4349 // was there remains visible |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4350 // Vim behaviour: the cursor moves backward and the character that |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4351 // was there is erased from the screen. |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4352 // We can emulate the vi behaviour by pretending there is a dollar |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4353 // displayed even when there isn't. |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4354 // --pkv Sun Jan 19 01:56:40 EST 2003 |
3318 | 4355 if (vim_strchr(p_cpo, CPO_BACKSPACE) != NULL && dollar_vcol == -1) |
7 | 4356 dollar_vcol = curwin->w_virtcol; |
4357 | |
1514 | 4358 #ifdef FEAT_FOLDING |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4359 // When deleting a char the cursor line must never be in a closed fold. |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4360 // E.g., when 'foldmethod' is indent and deleting the first non-white |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4361 // char before a Tab. |
1514 | 4362 if (did_backspace) |
4363 foldOpenCursor(); | |
4364 #endif | |
4365 | |
7 | 4366 return did_backspace; |
4367 } | |
4368 | |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4369 /* |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4370 * Handle receiving P_PS: start paste mode. Inserts the following text up to |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4371 * P_PE literally. |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4372 * When "drop" is TRUE then consume the text and drop it. |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4373 */ |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4374 int |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4375 bracketed_paste(paste_mode_T mode, int drop, garray_T *gap) |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4376 { |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4377 int c; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4378 char_u buf[NUMBUFLEN + MB_MAXBYTES]; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4379 int idx = 0; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4380 char_u *end = find_termcode((char_u *)"PE"); |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4381 int ret_char = -1; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4382 int save_allow_keys = allow_keys; |
10696
689e88afdd11
patch 8.0.0238: bracketed paste does not disable autoindent
Christian Brabandt <cb@256bit.org>
parents:
10684
diff
changeset
|
4383 int save_paste = p_paste; |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4384 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4385 // If the end code is too long we can't detect it, read everything. |
19151
f12eda320c78
patch 8.2.0135: bracketed paste can still cause invalid memory access
Bram Moolenaar <Bram@vim.org>
parents:
19147
diff
changeset
|
4386 if (end != NULL && STRLEN(end) >= NUMBUFLEN) |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4387 end = NULL; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4388 ++no_mapping; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4389 allow_keys = 0; |
14419
cdc4eacdd81d
patch 8.1.0224: hang in bracketed paste mode when t_PE not encountered
Christian Brabandt <cb@256bit.org>
parents:
14301
diff
changeset
|
4390 if (!p_paste) |
cdc4eacdd81d
patch 8.1.0224: hang in bracketed paste mode when t_PE not encountered
Christian Brabandt <cb@256bit.org>
parents:
14301
diff
changeset
|
4391 // Also have the side effects of setting 'paste' to make it work much |
cdc4eacdd81d
patch 8.1.0224: hang in bracketed paste mode when t_PE not encountered
Christian Brabandt <cb@256bit.org>
parents:
14301
diff
changeset
|
4392 // faster. |
28457
4dcccb2673fe
patch 8.2.4753: error from setting an option is silently ignored
Bram Moolenaar <Bram@vim.org>
parents:
28429
diff
changeset
|
4393 set_option_value_give_err((char_u *)"paste", TRUE, NULL, 0); |
10696
689e88afdd11
patch 8.0.0238: bracketed paste does not disable autoindent
Christian Brabandt <cb@256bit.org>
parents:
10684
diff
changeset
|
4394 |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4395 for (;;) |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4396 { |
14419
cdc4eacdd81d
patch 8.1.0224: hang in bracketed paste mode when t_PE not encountered
Christian Brabandt <cb@256bit.org>
parents:
14301
diff
changeset
|
4397 // When the end is not defined read everything there is. |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4398 if (end == NULL && vpeekc() == NUL) |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4399 break; |
14419
cdc4eacdd81d
patch 8.1.0224: hang in bracketed paste mode when t_PE not encountered
Christian Brabandt <cb@256bit.org>
parents:
14301
diff
changeset
|
4400 do |
cdc4eacdd81d
patch 8.1.0224: hang in bracketed paste mode when t_PE not encountered
Christian Brabandt <cb@256bit.org>
parents:
14301
diff
changeset
|
4401 c = vgetc(); |
16162
cd5c83115ec6
patch 8.1.1086: too many curly braces
Bram Moolenaar <Bram@vim.org>
parents:
16142
diff
changeset
|
4402 while (c == K_IGNORE || c == K_VER_SCROLLBAR || c == K_HOR_SCROLLBAR); |
31293
ff4473b3fc58
patch 9.0.0980: the keyboard state response may end up in a shell command
Bram Moolenaar <Bram@vim.org>
parents:
31192
diff
changeset
|
4403 |
19147
06ef1e438ac8
patch 8.2.0133: invalid memory access with search command
Bram Moolenaar <Bram@vim.org>
parents:
19097
diff
changeset
|
4404 if (c == NUL || got_int || (ex_normal_busy > 0 && c == Ctrl_C)) |
14419
cdc4eacdd81d
patch 8.1.0224: hang in bracketed paste mode when t_PE not encountered
Christian Brabandt <cb@256bit.org>
parents:
14301
diff
changeset
|
4405 // When CTRL-C was encountered the typeahead will be flushed and we |
19147
06ef1e438ac8
patch 8.2.0133: invalid memory access with search command
Bram Moolenaar <Bram@vim.org>
parents:
19097
diff
changeset
|
4406 // won't get the end sequence. Except when using ":normal". |
14419
cdc4eacdd81d
patch 8.1.0224: hang in bracketed paste mode when t_PE not encountered
Christian Brabandt <cb@256bit.org>
parents:
14301
diff
changeset
|
4407 break; |
cdc4eacdd81d
patch 8.1.0224: hang in bracketed paste mode when t_PE not encountered
Christian Brabandt <cb@256bit.org>
parents:
14301
diff
changeset
|
4408 |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4409 if (has_mbyte) |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4410 idx += (*mb_char2bytes)(c, buf + idx); |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4411 else |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4412 buf[idx++] = c; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4413 buf[idx] = NUL; |
11317
e45c6e4d78af
patch 8.0.0544: cppcheck warnings
Christian Brabandt <cb@256bit.org>
parents:
11311
diff
changeset
|
4414 if (end != NULL && STRNCMP(buf, end, idx) == 0) |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4415 { |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4416 if (end[idx] == NUL) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4417 break; // Found the end of paste code. |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4418 continue; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4419 } |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4420 if (!drop) |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4421 { |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4422 switch (mode) |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4423 { |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4424 case PASTE_CMDLINE: |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4425 put_on_cmdline(buf, idx, TRUE); |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4426 break; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4427 |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4428 case PASTE_EX: |
27380
7c07681f8a05
patch 8.2.4218: illegal memory access with bracketed paste in Ex mode
Bram Moolenaar <Bram@vim.org>
parents:
27350
diff
changeset
|
4429 // add one for the NUL that is going to be appended |
7c07681f8a05
patch 8.2.4218: illegal memory access with bracketed paste in Ex mode
Bram Moolenaar <Bram@vim.org>
parents:
27350
diff
changeset
|
4430 if (gap != NULL && ga_grow(gap, idx + 1) == OK) |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4431 { |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4432 mch_memmove((char *)gap->ga_data + gap->ga_len, |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4433 buf, (size_t)idx); |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4434 gap->ga_len += idx; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4435 } |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4436 break; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4437 |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4438 case PASTE_INSERT: |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4439 if (stop_arrow() == OK) |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4440 { |
10680
75c324ab1270
patch 8.0.0230: bracketed paste does not support line breaks
Christian Brabandt <cb@256bit.org>
parents:
10640
diff
changeset
|
4441 c = buf[0]; |
75c324ab1270
patch 8.0.0230: bracketed paste does not support line breaks
Christian Brabandt <cb@256bit.org>
parents:
10640
diff
changeset
|
4442 if (idx == 1 && (c == CAR || c == K_KENTER || c == NL)) |
75c324ab1270
patch 8.0.0230: bracketed paste does not support line breaks
Christian Brabandt <cb@256bit.org>
parents:
10640
diff
changeset
|
4443 ins_eol(c); |
75c324ab1270
patch 8.0.0230: bracketed paste does not support line breaks
Christian Brabandt <cb@256bit.org>
parents:
10640
diff
changeset
|
4444 else |
10682
d564e73ff9ee
patch 8.0.0231: bracketed paste mode is not tested
Christian Brabandt <cb@256bit.org>
parents:
10680
diff
changeset
|
4445 { |
10680
75c324ab1270
patch 8.0.0230: bracketed paste does not support line breaks
Christian Brabandt <cb@256bit.org>
parents:
10640
diff
changeset
|
4446 ins_char_bytes(buf, idx); |
10682
d564e73ff9ee
patch 8.0.0231: bracketed paste mode is not tested
Christian Brabandt <cb@256bit.org>
parents:
10680
diff
changeset
|
4447 AppendToRedobuffLit(buf, idx); |
d564e73ff9ee
patch 8.0.0231: bracketed paste mode is not tested
Christian Brabandt <cb@256bit.org>
parents:
10680
diff
changeset
|
4448 } |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4449 } |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4450 break; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4451 |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4452 case PASTE_ONE_CHAR: |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4453 if (ret_char == -1) |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4454 { |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4455 if (has_mbyte) |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4456 ret_char = (*mb_ptr2char)(buf); |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4457 else |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4458 ret_char = buf[0]; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4459 } |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4460 break; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4461 } |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4462 } |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4463 idx = 0; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4464 } |
10696
689e88afdd11
patch 8.0.0238: bracketed paste does not disable autoindent
Christian Brabandt <cb@256bit.org>
parents:
10684
diff
changeset
|
4465 |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4466 --no_mapping; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4467 allow_keys = save_allow_keys; |
14419
cdc4eacdd81d
patch 8.1.0224: hang in bracketed paste mode when t_PE not encountered
Christian Brabandt <cb@256bit.org>
parents:
14301
diff
changeset
|
4468 if (!save_paste) |
28457
4dcccb2673fe
patch 8.2.4753: error from setting an option is silently ignored
Bram Moolenaar <Bram@vim.org>
parents:
28429
diff
changeset
|
4469 set_option_value_give_err((char_u *)"paste", FALSE, NULL, 0); |
10640
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4470 |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4471 return ret_char; |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4472 } |
27be410d6d29
patch 8.0.0210: no support for bracketed paste
Christian Brabandt <cb@256bit.org>
parents:
10636
diff
changeset
|
4473 |
692 | 4474 #if defined(FEAT_GUI_TABLINE) || defined(PROTO) |
724 | 4475 static void |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
4476 ins_tabline(int c) |
692 | 4477 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4478 // We will be leaving the current window, unless closing another tab. |
692 | 4479 if (c != K_TABMENU || current_tabmenu != TABLINE_MENU_CLOSE |
4480 || (current_tab != 0 && current_tab != tabpage_index(curtab))) | |
4481 { | |
4482 undisplay_dollar(); | |
4483 start_arrow(&curwin->w_cursor); | |
4484 can_cindent = TRUE; | |
4485 } | |
4486 | |
4487 if (c == K_TABLINE) | |
4488 goto_tabpage(current_tab); | |
4489 else | |
846 | 4490 { |
692 | 4491 handle_tabmenu(); |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4492 redraw_statuslines(); // will redraw the tabline when needed |
846 | 4493 } |
692 | 4494 } |
4495 #endif | |
4496 | |
4497 #if defined(FEAT_GUI) || defined(PROTO) | |
7 | 4498 void |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
4499 ins_scroll(void) |
7 | 4500 { |
4501 pos_T tpos; | |
4502 | |
4503 undisplay_dollar(); | |
4504 tpos = curwin->w_cursor; | |
4505 if (gui_do_scroll()) | |
4506 { | |
4507 start_arrow(&tpos); | |
4508 can_cindent = TRUE; | |
4509 } | |
4510 } | |
4511 | |
4512 void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
4513 ins_horscroll(void) |
7 | 4514 { |
4515 pos_T tpos; | |
4516 | |
4517 undisplay_dollar(); | |
4518 tpos = curwin->w_cursor; | |
31103
33ca088dbd3e
patch 9.0.0886: horizontal mouse scroll only works in the GUI
Bram Moolenaar <Bram@vim.org>
parents:
30833
diff
changeset
|
4519 if (do_mousescroll_horiz(scrollbar_value)) |
7 | 4520 { |
4521 start_arrow(&tpos); | |
4522 can_cindent = TRUE; | |
4523 } | |
4524 } | |
4525 #endif | |
4526 | |
4527 static void | |
16101
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4528 ins_left(void) |
7 | 4529 { |
4530 pos_T tpos; | |
16101
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4531 int end_change = dont_sync_undo == FALSE; // end undoable change |
7 | 4532 |
4533 #ifdef FEAT_FOLDING | |
4534 if ((fdo_flags & FDO_HOR) && KeyTyped) | |
4535 foldOpenCursor(); | |
4536 #endif | |
4537 undisplay_dollar(); | |
4538 tpos = curwin->w_cursor; | |
4539 if (oneleft() == OK) | |
4540 { | |
941 | 4541 #if defined(FEAT_XIM) && defined(FEAT_GUI_GTK) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4542 // Only call start_arrow() when not busy with preediting, it will |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4543 // break undo. K_LEFT is inserted in im_correct_cursor(). |
12293
1ff5e5dfa9b0
patch 8.0.1026: GTK on-the-spot input has problems
Christian Brabandt <cb@256bit.org>
parents:
12136
diff
changeset
|
4544 if (p_imst == IM_OVER_THE_SPOT || !im_is_preediting()) |
941 | 4545 #endif |
7074
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
4546 { |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
4547 start_arrow_with_change(&tpos, end_change); |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
4548 if (!end_change) |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
4549 AppendCharToRedobuff(K_LEFT); |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
4550 } |
7 | 4551 #ifdef FEAT_RIGHTLEFT |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4552 // If exit reversed string, position is fixed |
7 | 4553 if (revins_scol != -1 && (int)curwin->w_cursor.col >= revins_scol) |
4554 revins_legal++; | |
4555 revins_chars++; | |
4556 #endif | |
4557 } | |
4558 | |
4559 /* | |
4560 * if 'whichwrap' set for cursor in insert mode may go to | |
4561 * previous line | |
4562 */ | |
4563 else if (vim_strchr(p_ww, '[') != NULL && curwin->w_cursor.lnum > 1) | |
4564 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4565 // always break undo when moving upwards/downwards, else undo may break |
7 | 4566 start_arrow(&tpos); |
4567 --(curwin->w_cursor.lnum); | |
4568 coladvance((colnr_T)MAXCOL); | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4569 curwin->w_set_curswant = TRUE; // so we stay at the end |
7 | 4570 } |
4571 else | |
6949 | 4572 vim_beep(BO_CRSR); |
7074
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
4573 dont_sync_undo = FALSE; |
7 | 4574 } |
4575 | |
4576 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
4577 ins_home(int c) |
7 | 4578 { |
4579 pos_T tpos; | |
4580 | |
4581 #ifdef FEAT_FOLDING | |
4582 if ((fdo_flags & FDO_HOR) && KeyTyped) | |
4583 foldOpenCursor(); | |
4584 #endif | |
4585 undisplay_dollar(); | |
4586 tpos = curwin->w_cursor; | |
4587 if (c == K_C_HOME) | |
4588 curwin->w_cursor.lnum = 1; | |
4589 curwin->w_cursor.col = 0; | |
4590 curwin->w_cursor.coladd = 0; | |
4591 curwin->w_curswant = 0; | |
4592 start_arrow(&tpos); | |
4593 } | |
4594 | |
4595 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
4596 ins_end(int c) |
7 | 4597 { |
4598 pos_T tpos; | |
4599 | |
4600 #ifdef FEAT_FOLDING | |
4601 if ((fdo_flags & FDO_HOR) && KeyTyped) | |
4602 foldOpenCursor(); | |
4603 #endif | |
4604 undisplay_dollar(); | |
4605 tpos = curwin->w_cursor; | |
4606 if (c == K_C_END) | |
4607 curwin->w_cursor.lnum = curbuf->b_ml.ml_line_count; | |
4608 coladvance((colnr_T)MAXCOL); | |
4609 curwin->w_curswant = MAXCOL; | |
4610 | |
4611 start_arrow(&tpos); | |
4612 } | |
4613 | |
4614 static void | |
32009
4545f58c8490
patch 9.0.1336: functions without arguments are not always declared properly
Bram Moolenaar <Bram@vim.org>
parents:
31667
diff
changeset
|
4615 ins_s_left(void) |
16101
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4616 { |
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4617 int end_change = dont_sync_undo == FALSE; // end undoable change |
7 | 4618 #ifdef FEAT_FOLDING |
4619 if ((fdo_flags & FDO_HOR) && KeyTyped) | |
4620 foldOpenCursor(); | |
4621 #endif | |
4622 undisplay_dollar(); | |
4623 if (curwin->w_cursor.lnum > 1 || curwin->w_cursor.col > 0) | |
4624 { | |
16101
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4625 start_arrow_with_change(&curwin->w_cursor, end_change); |
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4626 if (!end_change) |
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4627 AppendCharToRedobuff(K_S_LEFT); |
7 | 4628 (void)bck_word(1L, FALSE, FALSE); |
4629 curwin->w_set_curswant = TRUE; | |
4630 } | |
4631 else | |
6949 | 4632 vim_beep(BO_CRSR); |
16101
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4633 dont_sync_undo = FALSE; |
7 | 4634 } |
4635 | |
4636 static void | |
16101
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4637 ins_right(void) |
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4638 { |
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4639 int end_change = dont_sync_undo == FALSE; // end undoable change |
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4640 |
7 | 4641 #ifdef FEAT_FOLDING |
4642 if ((fdo_flags & FDO_HOR) && KeyTyped) | |
4643 foldOpenCursor(); | |
4644 #endif | |
4645 undisplay_dollar(); | |
15636
6f1c7e9a6393
patch 8.1.0826: too many #ifdefs
Bram Moolenaar <Bram@vim.org>
parents:
15629
diff
changeset
|
4646 if (gchar_cursor() != NUL || virtual_active()) |
7 | 4647 { |
7074
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
4648 start_arrow_with_change(&curwin->w_cursor, end_change); |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
4649 if (!end_change) |
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
4650 AppendCharToRedobuff(K_RIGHT); |
7 | 4651 curwin->w_set_curswant = TRUE; |
4652 if (virtual_active()) | |
4653 oneright(); | |
4654 else | |
4655 { | |
4656 if (has_mbyte) | |
474 | 4657 curwin->w_cursor.col += (*mb_ptr2len)(ml_get_cursor()); |
7 | 4658 else |
4659 ++curwin->w_cursor.col; | |
4660 } | |
4661 | |
4662 #ifdef FEAT_RIGHTLEFT | |
4663 revins_legal++; | |
4664 if (revins_chars) | |
4665 revins_chars--; | |
4666 #endif | |
4667 } | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4668 // if 'whichwrap' set for cursor in insert mode, may move the |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4669 // cursor to the next line |
7 | 4670 else if (vim_strchr(p_ww, ']') != NULL |
4671 && curwin->w_cursor.lnum < curbuf->b_ml.ml_line_count) | |
4672 { | |
4673 start_arrow(&curwin->w_cursor); | |
4674 curwin->w_set_curswant = TRUE; | |
4675 ++curwin->w_cursor.lnum; | |
4676 curwin->w_cursor.col = 0; | |
4677 } | |
4678 else | |
6949 | 4679 vim_beep(BO_CRSR); |
7074
c8efa41dd451
commit https://github.com/vim/vim/commit/8b5f65a527c353b9942e362e719687c3a7592309
Christian Brabandt <cb@256bit.org>
parents:
6971
diff
changeset
|
4680 dont_sync_undo = FALSE; |
7 | 4681 } |
4682 | |
4683 static void | |
32009
4545f58c8490
patch 9.0.1336: functions without arguments are not always declared properly
Bram Moolenaar <Bram@vim.org>
parents:
31667
diff
changeset
|
4684 ins_s_right(void) |
16101
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4685 { |
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4686 int end_change = dont_sync_undo == FALSE; // end undoable change |
7 | 4687 #ifdef FEAT_FOLDING |
4688 if ((fdo_flags & FDO_HOR) && KeyTyped) | |
4689 foldOpenCursor(); | |
4690 #endif | |
4691 undisplay_dollar(); | |
4692 if (curwin->w_cursor.lnum < curbuf->b_ml.ml_line_count | |
4693 || gchar_cursor() != NUL) | |
4694 { | |
16101
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4695 start_arrow_with_change(&curwin->w_cursor, end_change); |
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4696 if (!end_change) |
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4697 AppendCharToRedobuff(K_S_RIGHT); |
7 | 4698 (void)fwd_word(1L, FALSE, 0); |
4699 curwin->w_set_curswant = TRUE; | |
4700 } | |
4701 else | |
6949 | 4702 vim_beep(BO_CRSR); |
16101
5c5d211bd5a8
patch 8.1.1055: CTRL-G U in Insert mode doesn't work for shift-Left
Bram Moolenaar <Bram@vim.org>
parents:
16054
diff
changeset
|
4703 dont_sync_undo = FALSE; |
7 | 4704 } |
4705 | |
4706 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
4707 ins_up( |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4708 int startcol) // when TRUE move to Insstart.col |
7 | 4709 { |
4710 pos_T tpos; | |
4711 linenr_T old_topline = curwin->w_topline; | |
4712 #ifdef FEAT_DIFF | |
4713 int old_topfill = curwin->w_topfill; | |
4714 #endif | |
4715 | |
4716 undisplay_dollar(); | |
4717 tpos = curwin->w_cursor; | |
4718 if (cursor_up(1L, TRUE) == OK) | |
4719 { | |
4720 if (startcol) | |
4721 coladvance(getvcol_nolist(&Insstart)); | |
4722 if (old_topline != curwin->w_topline | |
4723 #ifdef FEAT_DIFF | |
4724 || old_topfill != curwin->w_topfill | |
4725 #endif | |
4726 ) | |
29732
89e1d67814a9
patch 9.0.0206: redraw flags are not named specifically
Bram Moolenaar <Bram@vim.org>
parents:
29579
diff
changeset
|
4727 redraw_later(UPD_VALID); |
7 | 4728 start_arrow(&tpos); |
4729 can_cindent = TRUE; | |
4730 } | |
4731 else | |
6949 | 4732 vim_beep(BO_CRSR); |
7 | 4733 } |
4734 | |
4735 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
4736 ins_pageup(void) |
7 | 4737 { |
4738 pos_T tpos; | |
4739 | |
4740 undisplay_dollar(); | |
828 | 4741 |
4742 if (mod_mask & MOD_MASK_CTRL) | |
4743 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4744 // <C-PageUp>: tab page back |
1013 | 4745 if (first_tabpage->tp_next != NULL) |
4746 { | |
4747 start_arrow(&curwin->w_cursor); | |
4748 goto_tabpage(-1); | |
4749 } | |
828 | 4750 return; |
4751 } | |
4752 | |
7 | 4753 tpos = curwin->w_cursor; |
4754 if (onepage(BACKWARD, 1L) == OK) | |
4755 { | |
4756 start_arrow(&tpos); | |
4757 can_cindent = TRUE; | |
4758 } | |
4759 else | |
6949 | 4760 vim_beep(BO_CRSR); |
7 | 4761 } |
4762 | |
4763 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
4764 ins_down( |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4765 int startcol) // when TRUE move to Insstart.col |
7 | 4766 { |
4767 pos_T tpos; | |
4768 linenr_T old_topline = curwin->w_topline; | |
4769 #ifdef FEAT_DIFF | |
4770 int old_topfill = curwin->w_topfill; | |
4771 #endif | |
4772 | |
4773 undisplay_dollar(); | |
4774 tpos = curwin->w_cursor; | |
4775 if (cursor_down(1L, TRUE) == OK) | |
4776 { | |
4777 if (startcol) | |
4778 coladvance(getvcol_nolist(&Insstart)); | |
4779 if (old_topline != curwin->w_topline | |
4780 #ifdef FEAT_DIFF | |
4781 || old_topfill != curwin->w_topfill | |
4782 #endif | |
4783 ) | |
29732
89e1d67814a9
patch 9.0.0206: redraw flags are not named specifically
Bram Moolenaar <Bram@vim.org>
parents:
29579
diff
changeset
|
4784 redraw_later(UPD_VALID); |
7 | 4785 start_arrow(&tpos); |
4786 can_cindent = TRUE; | |
4787 } | |
4788 else | |
6949 | 4789 vim_beep(BO_CRSR); |
7 | 4790 } |
4791 | |
4792 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
4793 ins_pagedown(void) |
7 | 4794 { |
4795 pos_T tpos; | |
4796 | |
4797 undisplay_dollar(); | |
828 | 4798 |
4799 if (mod_mask & MOD_MASK_CTRL) | |
4800 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4801 // <C-PageDown>: tab page forward |
1013 | 4802 if (first_tabpage->tp_next != NULL) |
4803 { | |
4804 start_arrow(&curwin->w_cursor); | |
4805 goto_tabpage(0); | |
4806 } | |
828 | 4807 return; |
4808 } | |
4809 | |
7 | 4810 tpos = curwin->w_cursor; |
4811 if (onepage(FORWARD, 1L) == OK) | |
4812 { | |
4813 start_arrow(&tpos); | |
4814 can_cindent = TRUE; | |
4815 } | |
4816 else | |
6949 | 4817 vim_beep(BO_CRSR); |
7 | 4818 } |
4819 | |
4820 #ifdef FEAT_DND | |
4821 static void | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
4822 ins_drop(void) |
7 | 4823 { |
22176
6941d3205be9
patch 8.2.1637: Vim9: :put ={expr} does not work inside :def function
Bram Moolenaar <Bram@vim.org>
parents:
22095
diff
changeset
|
4824 do_put('~', NULL, BACKWARD, 1L, PUT_CURSEND); |
7 | 4825 } |
4826 #endif | |
4827 | |
4828 /* | |
4829 * Handle TAB in Insert or Replace mode. | |
4830 * Return TRUE when the TAB needs to be inserted like a normal character. | |
4831 */ | |
4832 static int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
4833 ins_tab(void) |
7 | 4834 { |
4835 int ind; | |
4836 int i; | |
4837 int temp; | |
4838 | |
4839 if (Insstart_blank_vcol == MAXCOL && curwin->w_cursor.lnum == Insstart.lnum) | |
4840 Insstart_blank_vcol = get_nolist_virtcol(); | |
4841 if (echeck_abbr(TAB + ABBR_OFF)) | |
4842 return FALSE; | |
4843 | |
4844 ind = inindent(0); | |
4845 if (ind) | |
4846 can_cindent = FALSE; | |
4847 | |
4848 /* | |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4849 * When nothing special, insert TAB like a normal character. |
7 | 4850 */ |
4851 if (!curbuf->b_p_et | |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4852 #ifdef FEAT_VARTABS |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4853 && !(p_sta && ind |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4854 // These five lines mean 'tabstop' != 'shiftwidth' |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4855 && ((tabstop_count(curbuf->b_p_vts_array) > 1) |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4856 || (tabstop_count(curbuf->b_p_vts_array) == 1 |
28809
d0241e74bfdb
patch 8.2.4928: various white space and cosmetic mistakes
Bram Moolenaar <Bram@vim.org>
parents:
28773
diff
changeset
|
4857 && tabstop_first(curbuf->b_p_vts_array) |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4858 != get_sw_value(curbuf)) |
28809
d0241e74bfdb
patch 8.2.4928: various white space and cosmetic mistakes
Bram Moolenaar <Bram@vim.org>
parents:
28773
diff
changeset
|
4859 || (tabstop_count(curbuf->b_p_vts_array) == 0 |
d0241e74bfdb
patch 8.2.4928: various white space and cosmetic mistakes
Bram Moolenaar <Bram@vim.org>
parents:
28773
diff
changeset
|
4860 && curbuf->b_p_ts != get_sw_value(curbuf)))) |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4861 && tabstop_count(curbuf->b_p_vsts_array) == 0 |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4862 #else |
5438 | 4863 && !(p_sta && ind && curbuf->b_p_ts != get_sw_value(curbuf)) |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4864 #endif |
3873 | 4865 && get_sts_value() == 0) |
7 | 4866 return TRUE; |
4867 | |
4868 if (stop_arrow() == FAIL) | |
4869 return TRUE; | |
4870 | |
4871 did_ai = FALSE; | |
4872 did_si = FALSE; | |
4873 can_si = FALSE; | |
4874 can_si_back = FALSE; | |
4875 AppendToRedobuff((char_u *)"\t"); | |
4876 | |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4877 #ifdef FEAT_VARTABS |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4878 if (p_sta && ind) // insert tab in indent, use 'shiftwidth' |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4879 { |
14276
752ef53d3731
patch 8.1.0154: crash with "set smarttab shiftwidth=0 softtabstop=-1"
Christian Brabandt <cb@256bit.org>
parents:
14243
diff
changeset
|
4880 temp = (int)get_sw_value(curbuf); |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4881 temp -= get_nolist_virtcol() % temp; |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4882 } |
14243
fbf0681606fa
patch 8.1.0138: negative value of 'softtabstop' not used correctly
Christian Brabandt <cb@256bit.org>
parents:
14175
diff
changeset
|
4883 else if (tabstop_count(curbuf->b_p_vsts_array) > 0 || curbuf->b_p_sts != 0) |
28809
d0241e74bfdb
patch 8.2.4928: various white space and cosmetic mistakes
Bram Moolenaar <Bram@vim.org>
parents:
28773
diff
changeset
|
4884 // use 'softtabstop' when set |
14243
fbf0681606fa
patch 8.1.0138: negative value of 'softtabstop' not used correctly
Christian Brabandt <cb@256bit.org>
parents:
14175
diff
changeset
|
4885 temp = tabstop_padding(get_nolist_virtcol(), get_sts_value(), |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4886 curbuf->b_p_vsts_array); |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4887 else // otherwise use 'tabstop' |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4888 temp = tabstop_padding(get_nolist_virtcol(), curbuf->b_p_ts, |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4889 curbuf->b_p_vts_array); |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4890 #else |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4891 if (p_sta && ind) // insert tab in indent, use 'shiftwidth' |
5438 | 4892 temp = (int)get_sw_value(curbuf); |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4893 else if (curbuf->b_p_sts != 0) // use 'softtabstop' when set |
3873 | 4894 temp = (int)get_sts_value(); |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4895 else // otherwise use 'tabstop' |
7 | 4896 temp = (int)curbuf->b_p_ts; |
4897 temp -= get_nolist_virtcol() % temp; | |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4898 #endif |
7 | 4899 |
4900 /* | |
4901 * Insert the first space with ins_char(). It will delete one char in | |
4902 * replace mode. Insert the rest with ins_str(); it will not delete any | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
4903 * chars. For MODE_VREPLACE state, we use ins_char() for all characters. |
7 | 4904 */ |
4905 ins_char(' '); | |
4906 while (--temp > 0) | |
4907 { | |
4908 if (State & VREPLACE_FLAG) | |
4909 ins_char(' '); | |
4910 else | |
4911 { | |
4912 ins_str((char_u *)" "); | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4913 if (State & REPLACE_FLAG) // no char replaced |
7 | 4914 replace_push(NUL); |
4915 } | |
4916 } | |
4917 | |
4918 /* | |
4919 * When 'expandtab' not set: Replace spaces by TABs where possible. | |
4920 */ | |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4921 #ifdef FEAT_VARTABS |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4922 if (!curbuf->b_p_et && (tabstop_count(curbuf->b_p_vsts_array) > 0 |
28809
d0241e74bfdb
patch 8.2.4928: various white space and cosmetic mistakes
Bram Moolenaar <Bram@vim.org>
parents:
28773
diff
changeset
|
4923 || get_sts_value() > 0 |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4924 || (p_sta && ind))) |
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4925 #else |
3873 | 4926 if (!curbuf->b_p_et && (get_sts_value() || (p_sta && ind))) |
14175
2ad722003b36
patch 8.1.0105: all tab stops are the same
Christian Brabandt <cb@256bit.org>
parents:
14103
diff
changeset
|
4927 #endif |
7 | 4928 { |
4929 char_u *ptr; | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4930 char_u *saved_line = NULL; // init for GCC |
7 | 4931 pos_T pos; |
4932 pos_T fpos; | |
4933 pos_T *cursor; | |
4934 colnr_T want_vcol, vcol; | |
4935 int change_col = -1; | |
4936 int save_list = curwin->w_p_list; | |
29451
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
4937 char_u *tab = (char_u *)"\t"; |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
4938 chartabsize_T cts; |
7 | 4939 |
4940 /* | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
4941 * Get the current line. For MODE_VREPLACE state, don't make real |
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
4942 * changes yet, just work on a copy of the line. |
7 | 4943 */ |
4944 if (State & VREPLACE_FLAG) | |
4945 { | |
4946 pos = curwin->w_cursor; | |
4947 cursor = &pos; | |
4948 saved_line = vim_strsave(ml_get_curline()); | |
4949 if (saved_line == NULL) | |
4950 return FALSE; | |
4951 ptr = saved_line + pos.col; | |
4952 } | |
4953 else | |
4954 { | |
4955 ptr = ml_get_cursor(); | |
4956 cursor = &curwin->w_cursor; | |
4957 } | |
4958 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4959 // When 'L' is not in 'cpoptions' a tab always takes up 'ts' spaces. |
7 | 4960 if (vim_strchr(p_cpo, CPO_LISTWM) == NULL) |
4961 curwin->w_p_list = FALSE; | |
4962 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4963 // Find first white before the cursor |
7 | 4964 fpos = curwin->w_cursor; |
11129
f4ea50924c6d
patch 8.0.0452: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents:
11127
diff
changeset
|
4965 while (fpos.col > 0 && VIM_ISWHITE(ptr[-1])) |
7 | 4966 { |
4967 --fpos.col; | |
4968 --ptr; | |
4969 } | |
4970 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4971 // In Replace mode, don't change characters before the insert point. |
7 | 4972 if ((State & REPLACE_FLAG) |
4973 && fpos.lnum == Insstart.lnum | |
4974 && fpos.col < Insstart.col) | |
4975 { | |
4976 ptr += Insstart.col - fpos.col; | |
4977 fpos.col = Insstart.col; | |
4978 } | |
4979 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4980 // compute virtual column numbers of first white and cursor |
7 | 4981 getvcol(curwin, &fpos, &vcol, NULL, NULL); |
4982 getvcol(curwin, cursor, &want_vcol, NULL, NULL); | |
4983 | |
29451
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
4984 init_chartabsize_arg(&cts, curwin, 0, vcol, tab, tab); |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
4985 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4986 // Use as many TABs as possible. Beware of 'breakindent', 'showbreak' |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4987 // and 'linebreak' adding extra virtual columns. |
11129
f4ea50924c6d
patch 8.0.0452: some macros are in lower case
Christian Brabandt <cb@256bit.org>
parents:
11127
diff
changeset
|
4988 while (VIM_ISWHITE(*ptr)) |
7 | 4989 { |
29451
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
4990 i = lbr_chartabsize(&cts); |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
4991 if (cts.cts_vcol + i > want_vcol) |
7 | 4992 break; |
4993 if (*ptr != TAB) | |
4994 { | |
4995 *ptr = TAB; | |
4996 if (change_col < 0) | |
4997 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4998 change_col = fpos.col; // Column of first change |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
4999 // May have to adjust Insstart |
7 | 5000 if (fpos.lnum == Insstart.lnum && fpos.col < Insstart.col) |
5001 Insstart.col = fpos.col; | |
5002 } | |
5003 } | |
5004 ++fpos.col; | |
5005 ++ptr; | |
29451
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5006 cts.cts_vcol += i; |
7 | 5007 } |
29451
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5008 vcol = cts.cts_vcol; |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5009 clear_chartabsize_arg(&cts); |
7 | 5010 |
5011 if (change_col >= 0) | |
5012 { | |
29451
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5013 int repl_off = 0; |
7 | 5014 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5015 // Skip over the spaces we need. |
29451
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5016 init_chartabsize_arg(&cts, curwin, 0, vcol, ptr, ptr); |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5017 while (cts.cts_vcol < want_vcol && *cts.cts_ptr == ' ') |
7 | 5018 { |
29451
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5019 cts.cts_vcol += lbr_chartabsize(&cts); |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5020 ++cts.cts_ptr; |
7 | 5021 ++repl_off; |
5022 } | |
29451
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5023 ptr = cts.cts_ptr; |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5024 vcol = cts.cts_vcol; |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5025 clear_chartabsize_arg(&cts); |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5026 |
7 | 5027 if (vcol > want_vcol) |
5028 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5029 // Must have a char with 'showbreak' just before it. |
7 | 5030 --ptr; |
5031 --repl_off; | |
5032 } | |
5033 fpos.col += repl_off; | |
5034 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5035 // Delete following spaces. |
7 | 5036 i = cursor->col - fpos.col; |
5037 if (i > 0) | |
5038 { | |
19045
143d44d8f477
patch 8.2.0083: text properties wrong when tabs and spaces are exchanged
Bram Moolenaar <Bram@vim.org>
parents:
18777
diff
changeset
|
5039 #ifdef FEAT_PROP_POPUP |
143d44d8f477
patch 8.2.0083: text properties wrong when tabs and spaces are exchanged
Bram Moolenaar <Bram@vim.org>
parents:
18777
diff
changeset
|
5040 if (!(State & VREPLACE_FLAG)) |
143d44d8f477
patch 8.2.0083: text properties wrong when tabs and spaces are exchanged
Bram Moolenaar <Bram@vim.org>
parents:
18777
diff
changeset
|
5041 { |
19097
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5042 char_u *newp; |
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5043 int col; |
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5044 |
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5045 newp = alloc(curbuf->b_ml.ml_line_len - i); |
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5046 if (newp == NULL) |
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5047 return FALSE; |
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5048 |
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5049 col = ptr - curbuf->b_ml.ml_line_ptr; |
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5050 if (col > 0) |
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5051 mch_memmove(newp, ptr - col, col); |
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5052 mch_memmove(newp + col, ptr + i, |
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5053 curbuf->b_ml.ml_line_len - col - i); |
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5054 |
29340
fba9e366ced4
patch 9.0.0013: reproducing memory access errors can be difficult
Bram Moolenaar <Bram@vim.org>
parents:
29291
diff
changeset
|
5055 if (curbuf->b_ml.ml_flags & (ML_LINE_DIRTY | ML_ALLOCATED)) |
19097
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5056 vim_free(curbuf->b_ml.ml_line_ptr); |
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5057 curbuf->b_ml.ml_line_ptr = newp; |
19045
143d44d8f477
patch 8.2.0083: text properties wrong when tabs and spaces are exchanged
Bram Moolenaar <Bram@vim.org>
parents:
18777
diff
changeset
|
5058 curbuf->b_ml.ml_line_len -= i; |
19097
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5059 curbuf->b_ml.ml_flags = |
bcbc9fe665b5
patch 8.2.0109: corrupted text properties when expanding spaces
Bram Moolenaar <Bram@vim.org>
parents:
19045
diff
changeset
|
5060 (curbuf->b_ml.ml_flags | ML_LINE_DIRTY) & ~ML_EMPTY; |
19045
143d44d8f477
patch 8.2.0083: text properties wrong when tabs and spaces are exchanged
Bram Moolenaar <Bram@vim.org>
parents:
18777
diff
changeset
|
5061 } |
143d44d8f477
patch 8.2.0083: text properties wrong when tabs and spaces are exchanged
Bram Moolenaar <Bram@vim.org>
parents:
18777
diff
changeset
|
5062 else |
143d44d8f477
patch 8.2.0083: text properties wrong when tabs and spaces are exchanged
Bram Moolenaar <Bram@vim.org>
parents:
18777
diff
changeset
|
5063 #endif |
143d44d8f477
patch 8.2.0083: text properties wrong when tabs and spaces are exchanged
Bram Moolenaar <Bram@vim.org>
parents:
18777
diff
changeset
|
5064 STRMOVE(ptr, ptr + i); |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5065 // correct replace stack. |
14424
0a69e6e708f9
patch 8.1.0226: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
14419
diff
changeset
|
5066 if ((State & REPLACE_FLAG) && !(State & VREPLACE_FLAG)) |
7 | 5067 for (temp = i; --temp >= 0; ) |
5068 replace_join(repl_off); | |
5069 } | |
33 | 5070 #ifdef FEAT_NETBEANS_INTG |
2210 | 5071 if (netbeans_active()) |
33 | 5072 { |
2209
d0ddf7ba1630
Included the patch to support netbeans in a terminal.
Bram Moolenaar <bram@vim.org>
parents:
2178
diff
changeset
|
5073 netbeans_removed(curbuf, fpos.lnum, cursor->col, (long)(i + 1)); |
33 | 5074 netbeans_inserted(curbuf, fpos.lnum, cursor->col, |
5075 (char_u *)"\t", 1); | |
5076 } | |
5077 #endif | |
7 | 5078 cursor->col -= i; |
5079 | |
5080 /* | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
5081 * In MODE_VREPLACE state, we haven't changed anything yet. Do it |
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
5082 * now by backspacing over the changed spacing and then inserting |
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
5083 * the new spacing. |
7 | 5084 */ |
5085 if (State & VREPLACE_FLAG) | |
5086 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5087 // Backspace from real cursor to change_col |
7 | 5088 backspace_until_column(change_col); |
5089 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5090 // Insert each char in saved_line from changed_col to |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5091 // ptr-cursor |
7 | 5092 ins_bytes_len(saved_line + change_col, |
5093 cursor->col - change_col); | |
5094 } | |
14424
0a69e6e708f9
patch 8.1.0226: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
14419
diff
changeset
|
5095 } |
0a69e6e708f9
patch 8.1.0226: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
14419
diff
changeset
|
5096 |
7 | 5097 if (State & VREPLACE_FLAG) |
5098 vim_free(saved_line); | |
5099 curwin->w_p_list = save_list; | |
5100 } | |
5101 | |
5102 return FALSE; | |
5103 } | |
5104 | |
5105 /* | |
5106 * Handle CR or NL in insert mode. | |
13772
cc21507ee4b1
patch 8.0.1758: open_line() returns TRUE/FALSE for success/failure
Christian Brabandt <cb@256bit.org>
parents:
13718
diff
changeset
|
5107 * Return FAIL when out of memory or can't undo. |
7 | 5108 */ |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
5109 int |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
5110 ins_eol(int c) |
7 | 5111 { |
5112 int i; | |
5113 | |
5114 if (echeck_abbr(c + ABBR_OFF)) | |
13788
a27d380b257f
patch 8.0.1766: expanding abbreviation doesn't work
Christian Brabandt <cb@256bit.org>
parents:
13772
diff
changeset
|
5115 return OK; |
7 | 5116 if (stop_arrow() == FAIL) |
13788
a27d380b257f
patch 8.0.1766: expanding abbreviation doesn't work
Christian Brabandt <cb@256bit.org>
parents:
13772
diff
changeset
|
5117 return FAIL; |
7 | 5118 undisplay_dollar(); |
5119 | |
5120 /* | |
5121 * Strange Vi behaviour: In Replace mode, typing a NL will not delete the | |
5122 * character under the cursor. Only push a NUL on the replace stack, | |
5123 * nothing to put back when the NL is deleted. | |
5124 */ | |
14424
0a69e6e708f9
patch 8.1.0226: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
14419
diff
changeset
|
5125 if ((State & REPLACE_FLAG) && !(State & VREPLACE_FLAG)) |
7 | 5126 replace_push(NUL); |
5127 | |
5128 /* | |
28773
d770568e6c98
patch 8.2.4911: the mode #defines are not clearly named
Bram Moolenaar <Bram@vim.org>
parents:
28704
diff
changeset
|
5129 * In MODE_VREPLACE state, a NL replaces the rest of the line, and starts |
7 | 5130 * replacing the next line, so we push all of the characters left on the |
5131 * line onto the replace stack. This is not done here though, it is done | |
5132 * in open_line(). | |
5133 */ | |
5134 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5135 // Put cursor on NUL if on the last char and coladd is 1 (happens after |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5136 // CTRL-O). |
844 | 5137 if (virtual_active() && curwin->w_cursor.coladd > 0) |
5138 coladvance(getviscol()); | |
5139 | |
7 | 5140 #ifdef FEAT_RIGHTLEFT |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5141 // NL in reverse insert will always start in the end of |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5142 // current line. |
7 | 5143 if (revins_on) |
5144 curwin->w_cursor.col += (colnr_T)STRLEN(ml_get_cursor()); | |
5145 #endif | |
5146 | |
5147 AppendToRedobuff(NL_STR); | |
5148 i = open_line(FORWARD, | |
26516
9596c652420b
patch 8.2.3787: no proper formatting of a C line comment after a statement
Bram Moolenaar <Bram@vim.org>
parents:
26468
diff
changeset
|
5149 has_format_option(FO_RET_COMS) ? OPENLINE_DO_COM : 0, old_indent, |
9596c652420b
patch 8.2.3787: no proper formatting of a C line comment after a statement
Bram Moolenaar <Bram@vim.org>
parents:
26468
diff
changeset
|
5150 NULL); |
7 | 5151 old_indent = 0; |
5152 can_cindent = TRUE; | |
1032 | 5153 #ifdef FEAT_FOLDING |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5154 // When inserting a line the cursor line must never be in a closed fold. |
1032 | 5155 foldOpenCursor(); |
5156 #endif | |
7 | 5157 |
13772
cc21507ee4b1
patch 8.0.1758: open_line() returns TRUE/FALSE for success/failure
Christian Brabandt <cb@256bit.org>
parents:
13718
diff
changeset
|
5158 return i; |
7 | 5159 } |
5160 | |
5161 #ifdef FEAT_DIGRAPHS | |
5162 /* | |
5163 * Handle digraph in insert mode. | |
5164 * Returns character still to be inserted, or NUL when nothing remaining to be | |
5165 * done. | |
5166 */ | |
5167 static int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
5168 ins_digraph(void) |
7 | 5169 { |
5170 int c; | |
5171 int cc; | |
2811 | 5172 int did_putchar = FALSE; |
7 | 5173 |
5174 pc_status = PC_STATUS_UNSET; | |
5175 if (redrawing() && !char_avail()) | |
5176 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5177 // may need to redraw when no more chars available now |
661 | 5178 ins_redraw(FALSE); |
7 | 5179 |
5180 edit_putchar('?', TRUE); | |
2811 | 5181 did_putchar = TRUE; |
7 | 5182 add_to_showcmd_c(Ctrl_K); |
5183 } | |
5184 | |
5185 #ifdef USE_ON_FLY_SCROLL | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5186 dont_scroll = TRUE; // disallow scrolling here |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5187 #endif |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5188 |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5189 // don't map the digraph chars. This also prevents the |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5190 // mode message to be deleted when ESC is hit |
7 | 5191 ++no_mapping; |
5192 ++allow_keys; | |
1389 | 5193 c = plain_vgetc(); |
7 | 5194 --no_mapping; |
5195 --allow_keys; | |
2811 | 5196 if (did_putchar) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5197 // when the line fits in 'columns' the '?' is at the start of the next |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5198 // line and will not be removed by the redraw |
2811 | 5199 edit_unputchar(); |
2319
c79ccf947487
Fix: When entering a digraph or special character after a line that fits the
Bram Moolenaar <bram@vim.org>
parents:
2297
diff
changeset
|
5200 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5201 if (IS_SPECIAL(c) || mod_mask) // special key |
7 | 5202 { |
5203 clear_showcmd(); | |
5204 insert_special(c, TRUE, FALSE); | |
5205 return NUL; | |
5206 } | |
5207 if (c != ESC) | |
5208 { | |
2811 | 5209 did_putchar = FALSE; |
7 | 5210 if (redrawing() && !char_avail()) |
5211 { | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5212 // may need to redraw when no more chars available now |
661 | 5213 ins_redraw(FALSE); |
7 | 5214 |
5215 if (char2cells(c) == 1) | |
5216 { | |
661 | 5217 ins_redraw(FALSE); |
7 | 5218 edit_putchar(c, TRUE); |
2811 | 5219 did_putchar = TRUE; |
7 | 5220 } |
5221 add_to_showcmd_c(c); | |
5222 } | |
5223 ++no_mapping; | |
5224 ++allow_keys; | |
1389 | 5225 cc = plain_vgetc(); |
7 | 5226 --no_mapping; |
5227 --allow_keys; | |
2811 | 5228 if (did_putchar) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5229 // when the line fits in 'columns' the '?' is at the start of the |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5230 // next line and will not be removed by a redraw |
2811 | 5231 edit_unputchar(); |
7 | 5232 if (cc != ESC) |
5233 { | |
5234 AppendToRedobuff((char_u *)CTRL_V_STR); | |
25378
890fd8211202
patch 8.2.3226: new digraph functions use old naming scheme
Bram Moolenaar <Bram@vim.org>
parents:
25320
diff
changeset
|
5235 c = digraph_get(c, cc, TRUE); |
7 | 5236 clear_showcmd(); |
5237 return c; | |
5238 } | |
5239 } | |
5240 clear_showcmd(); | |
5241 return NUL; | |
5242 } | |
5243 #endif | |
5244 | |
5245 /* | |
5246 * Handle CTRL-E and CTRL-Y in Insert mode: copy char from other line. | |
5247 * Returns the char to be inserted, or NUL if none found. | |
5248 */ | |
3501 | 5249 int |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
5250 ins_copychar(linenr_T lnum) |
7 | 5251 { |
29451
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5252 int c; |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5253 char_u *ptr, *prev_ptr; |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5254 char_u *line; |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5255 chartabsize_T cts; |
7 | 5256 |
5257 if (lnum < 1 || lnum > curbuf->b_ml.ml_line_count) | |
5258 { | |
6949 | 5259 vim_beep(BO_COPY); |
7 | 5260 return NUL; |
5261 } | |
5262 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5263 // try to advance to the cursor column |
29340
fba9e366ced4
patch 9.0.0013: reproducing memory access errors can be difficult
Bram Moolenaar <Bram@vim.org>
parents:
29291
diff
changeset
|
5264 validate_virtcol(); |
29451
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5265 line = ml_get(lnum); |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5266 prev_ptr = line; |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5267 init_chartabsize_arg(&cts, curwin, lnum, 0, line, line); |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5268 while (cts.cts_vcol < curwin->w_virtcol && *cts.cts_ptr != NUL) |
7 | 5269 { |
29451
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5270 prev_ptr = cts.cts_ptr; |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5271 cts.cts_vcol += lbr_chartabsize_adv(&cts); |
7 | 5272 } |
29451
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5273 if (cts.cts_vcol > curwin->w_virtcol) |
7 | 5274 ptr = prev_ptr; |
29451
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5275 else |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5276 ptr = cts.cts_ptr; |
057c26b5c33a
patch 9.0.0067: cannot show virtual text
Bram Moolenaar <Bram@vim.org>
parents:
29340
diff
changeset
|
5277 clear_chartabsize_arg(&cts); |
7 | 5278 |
5279 c = (*mb_ptr2char)(ptr); | |
5280 if (c == NUL) | |
6949 | 5281 vim_beep(BO_COPY); |
7 | 5282 return c; |
5283 } | |
5284 | |
449 | 5285 /* |
5286 * CTRL-Y or CTRL-E typed in Insert mode. | |
5287 */ | |
5288 static int | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
5289 ins_ctrl_ey(int tc) |
449 | 5290 { |
5291 int c = tc; | |
5292 | |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
5293 if (ctrl_x_mode_scroll()) |
449 | 5294 { |
5295 if (c == Ctrl_Y) | |
5296 scrolldown_clamp(); | |
5297 else | |
5298 scrollup_clamp(); | |
29732
89e1d67814a9
patch 9.0.0206: redraw flags are not named specifically
Bram Moolenaar <Bram@vim.org>
parents:
29579
diff
changeset
|
5299 redraw_later(UPD_VALID); |
449 | 5300 } |
5301 else | |
5302 { | |
5303 c = ins_copychar(curwin->w_cursor.lnum + (c == Ctrl_Y ? -1 : 1)); | |
5304 if (c != NUL) | |
5305 { | |
5306 long tw_save; | |
5307 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5308 // The character must be taken literally, insert like it |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5309 // was typed after a CTRL-V, and pretend 'textwidth' |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5310 // wasn't set. Digits, 'o' and 'x' are special after a |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5311 // CTRL-V, don't use it for these. |
449 | 5312 if (c < 256 && !isalnum(c)) |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5313 AppendToRedobuff((char_u *)CTRL_V_STR); // CTRL-V |
449 | 5314 tw_save = curbuf->b_p_tw; |
5315 curbuf->b_p_tw = -1; | |
5316 insert_special(c, TRUE, FALSE); | |
5317 curbuf->b_p_tw = tw_save; | |
5318 #ifdef FEAT_RIGHTLEFT | |
5319 revins_chars++; | |
5320 revins_legal++; | |
5321 #endif | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5322 c = Ctrl_V; // pretend CTRL-V is last character |
449 | 5323 auto_format(FALSE, TRUE); |
5324 } | |
5325 } | |
5326 return c; | |
5327 } | |
5328 | |
7 | 5329 /* |
5330 * Get the value that w_virtcol would have when 'list' is off. | |
5331 * Unless 'cpo' contains the 'L' flag. | |
5332 */ | |
15062
3a94f7918980
patch 8.1.0542: shiftwidth() does not take 'vartabstop' into account
Bram Moolenaar <Bram@vim.org>
parents:
14985
diff
changeset
|
5333 colnr_T |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
5334 get_nolist_virtcol(void) |
7 | 5335 { |
15062
3a94f7918980
patch 8.1.0542: shiftwidth() does not take 'vartabstop' into account
Bram Moolenaar <Bram@vim.org>
parents:
14985
diff
changeset
|
5336 // check validity of cursor in current buffer |
3a94f7918980
patch 8.1.0542: shiftwidth() does not take 'vartabstop' into account
Bram Moolenaar <Bram@vim.org>
parents:
14985
diff
changeset
|
5337 if (curwin->w_buffer == NULL |
3a94f7918980
patch 8.1.0542: shiftwidth() does not take 'vartabstop' into account
Bram Moolenaar <Bram@vim.org>
parents:
14985
diff
changeset
|
5338 || curwin->w_buffer->b_ml.ml_mfp == NULL |
3a94f7918980
patch 8.1.0542: shiftwidth() does not take 'vartabstop' into account
Bram Moolenaar <Bram@vim.org>
parents:
14985
diff
changeset
|
5339 || curwin->w_cursor.lnum > curwin->w_buffer->b_ml.ml_line_count) |
3a94f7918980
patch 8.1.0542: shiftwidth() does not take 'vartabstop' into account
Bram Moolenaar <Bram@vim.org>
parents:
14985
diff
changeset
|
5340 return 0; |
7 | 5341 if (curwin->w_p_list && vim_strchr(p_cpo, CPO_LISTWM) == NULL) |
5342 return getvcol_nolist(&curwin->w_cursor); | |
5343 validate_virtcol(); | |
5344 return curwin->w_virtcol; | |
5345 } | |
3390 | 5346 |
13380
69517d67421f
patch 8.0.1564: too many #ifdefs
Christian Brabandt <cb@256bit.org>
parents:
13244
diff
changeset
|
5347 #if defined(FEAT_EVAL) |
3390 | 5348 /* |
5349 * Handle the InsertCharPre autocommand. | |
5350 * "c" is the character that was typed. | |
5351 * Return a pointer to allocated memory with the replacement string. | |
5352 * Return NULL to continue inserting "c". | |
5353 */ | |
5354 static char_u * | |
7817
83861277e6a3
commit https://github.com/vim/vim/commit/7454a06e2642d2b37afad1c5e71cec68081ca4ff
Christian Brabandt <cb@256bit.org>
parents:
7799
diff
changeset
|
5355 do_insert_char_pre(int c) |
3390 | 5356 { |
3547 | 5357 char_u *res; |
5358 char_u buf[MB_MAXBYTES + 1]; | |
15377
88b0a490816e
patch 8.1.0696: when test_edit fails 'insertmode' may not be reset
Bram Moolenaar <Bram@vim.org>
parents:
15349
diff
changeset
|
5359 int save_State = State; |
3390 | 5360 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5361 // Return quickly when there is nothing to do. |
3390 | 5362 if (!has_insertcharpre()) |
5363 return NULL; | |
5364 | |
3547 | 5365 if (has_mbyte) |
5366 buf[(*mb_char2bytes)(c, buf)] = NUL; | |
5367 else | |
5368 { | |
5369 buf[0] = c; | |
5370 buf[1] = NUL; | |
5371 } | |
5372 | |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5373 // Lock the text to avoid weird things from happening. |
29014
45c182c4f7e9
patch 8.2.5029: "textlock" is always zero
Bram Moolenaar <Bram@vim.org>
parents:
28942
diff
changeset
|
5374 ++textlock; |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5375 set_vim_var_string(VV_CHAR, buf, -1); // set v:char |
3547 | 5376 |
5377 res = NULL; | |
14485
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5378 if (ins_apply_autocmds(EVENT_INSERTCHARPRE)) |
3547 | 5379 { |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5380 // Get the value of v:char. It may be empty or more than one |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5381 // character. Only use it when changed, otherwise continue with the |
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5382 // original character to avoid breaking autoindent. |
3547 | 5383 if (STRCMP(buf, get_vim_var_str(VV_CHAR)) != 0) |
5384 res = vim_strsave(get_vim_var_str(VV_CHAR)); | |
5385 } | |
3390 | 5386 |
18777
3a68dc2a1bc1
patch 8.1.2378: using old C style comments
Bram Moolenaar <Bram@vim.org>
parents:
18763
diff
changeset
|
5387 set_vim_var_string(VV_CHAR, NULL, -1); // clear v:char |
29014
45c182c4f7e9
patch 8.2.5029: "textlock" is always zero
Bram Moolenaar <Bram@vim.org>
parents:
28942
diff
changeset
|
5388 --textlock; |
3390 | 5389 |
15377
88b0a490816e
patch 8.1.0696: when test_edit fails 'insertmode' may not be reset
Bram Moolenaar <Bram@vim.org>
parents:
15349
diff
changeset
|
5390 // Restore the State, it may have been changed. |
88b0a490816e
patch 8.1.0696: when test_edit fails 'insertmode' may not be reset
Bram Moolenaar <Bram@vim.org>
parents:
15349
diff
changeset
|
5391 State = save_State; |
88b0a490816e
patch 8.1.0696: when test_edit fails 'insertmode' may not be reset
Bram Moolenaar <Bram@vim.org>
parents:
15349
diff
changeset
|
5392 |
3390 | 5393 return res; |
5394 } | |
5395 #endif | |
14485
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5396 |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
5397 int |
18135
1868ec23360e
patch 8.1.2062: the mouse code is spread out
Bram Moolenaar <Bram@vim.org>
parents:
18098
diff
changeset
|
5398 get_can_cindent(void) |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
5399 { |
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
5400 return can_cindent; |
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
5401 } |
18135
1868ec23360e
patch 8.1.2062: the mouse code is spread out
Bram Moolenaar <Bram@vim.org>
parents:
18098
diff
changeset
|
5402 |
1868ec23360e
patch 8.1.2062: the mouse code is spread out
Bram Moolenaar <Bram@vim.org>
parents:
18098
diff
changeset
|
5403 void |
1868ec23360e
patch 8.1.2062: the mouse code is spread out
Bram Moolenaar <Bram@vim.org>
parents:
18098
diff
changeset
|
5404 set_can_cindent(int val) |
1868ec23360e
patch 8.1.2062: the mouse code is spread out
Bram Moolenaar <Bram@vim.org>
parents:
18098
diff
changeset
|
5405 { |
1868ec23360e
patch 8.1.2062: the mouse code is spread out
Bram Moolenaar <Bram@vim.org>
parents:
18098
diff
changeset
|
5406 can_cindent = val; |
1868ec23360e
patch 8.1.2062: the mouse code is spread out
Bram Moolenaar <Bram@vim.org>
parents:
18098
diff
changeset
|
5407 } |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
5408 |
14485
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5409 /* |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5410 * Trigger "event" and take care of fixing undo. |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5411 */ |
16142
570a296aa0b4
patch 8.1.1076: file for Insert mode is much too big
Bram Moolenaar <Bram@vim.org>
parents:
16127
diff
changeset
|
5412 int |
14485
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5413 ins_apply_autocmds(event_T event) |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5414 { |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5415 varnumber_T tick = CHANGEDTICK(curbuf); |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5416 int r; |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5417 |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5418 r = apply_autocmds(event, NULL, NULL, FALSE, curbuf); |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5419 |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5420 // If u_savesub() was called then we are not prepared to start |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5421 // a new line. Call u_save() with no contents to fix that. |
20187
79cc97206476
patch 8.2.0649: undo problem whn an InsertLeave autocommand resets undo
Bram Moolenaar <Bram@vim.org>
parents:
20118
diff
changeset
|
5422 // Except when leaving Insert mode. |
79cc97206476
patch 8.2.0649: undo problem whn an InsertLeave autocommand resets undo
Bram Moolenaar <Bram@vim.org>
parents:
20118
diff
changeset
|
5423 if (event != EVENT_INSERTLEAVE && tick != CHANGEDTICK(curbuf)) |
14485
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5424 u_save(curwin->w_cursor.lnum, (linenr_T)(curwin->w_cursor.lnum + 1)); |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5425 |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5426 return r; |
c71d65c3672f
patch 8.1.0256: using setline() in TextChangedI splits undo
Christian Brabandt <cb@256bit.org>
parents:
14465
diff
changeset
|
5427 } |