mirror of
https://github.com/neovim/neovim.git
synced 2024-12-29 14:41:06 -07:00
Merge pull request #14311 from matveyt/nomode_ce
refactor(state): Remove EXMODE_NORMAL
This commit is contained in:
commit
192adfe99f
@ -6358,8 +6358,7 @@ mode([expr]) Return a string that indicates the current mode.
|
|||||||
Rv Virtual Replace |gR|
|
Rv Virtual Replace |gR|
|
||||||
Rx Replace mode |i_CTRL-X| completion
|
Rx Replace mode |i_CTRL-X| completion
|
||||||
c Command-line editing
|
c Command-line editing
|
||||||
cv Vim Ex mode |gQ|
|
cv Vim Ex mode |Q| or |gQ|
|
||||||
ce Normal Ex mode |Q|
|
|
||||||
r Hit-enter prompt
|
r Hit-enter prompt
|
||||||
rm The -- more -- prompt
|
rm The -- more -- prompt
|
||||||
r? |:confirm| query of some sort
|
r? |:confirm| query of some sort
|
||||||
|
@ -4539,11 +4539,6 @@ A jump table for the options with a short description can be found at |Q_op|.
|
|||||||
List of items that control the format of the output of |:hardcopy|.
|
List of items that control the format of the output of |:hardcopy|.
|
||||||
See |popt-option|.
|
See |popt-option|.
|
||||||
|
|
||||||
*'prompt'* *'noprompt'*
|
|
||||||
'prompt' boolean (default on)
|
|
||||||
global
|
|
||||||
When on a ":" prompt is used in Ex mode.
|
|
||||||
|
|
||||||
*'pumblend'* *'pb'*
|
*'pumblend'* *'pb'*
|
||||||
'pumblend' 'pb' number (default 0)
|
'pumblend' 'pb' number (default 0)
|
||||||
global
|
global
|
||||||
|
@ -809,7 +809,6 @@ Short explanation of each option: *option-list*
|
|||||||
'printmbcharset' 'pmbcs' CJK character set to be used for :hardcopy
|
'printmbcharset' 'pmbcs' CJK character set to be used for :hardcopy
|
||||||
'printmbfont' 'pmbfn' font names to be used for CJK output of :hardcopy
|
'printmbfont' 'pmbfn' font names to be used for CJK output of :hardcopy
|
||||||
'printoptions' 'popt' controls the format of :hardcopy output
|
'printoptions' 'popt' controls the format of :hardcopy output
|
||||||
'prompt' 'prompt' enable prompt in Ex mode
|
|
||||||
'pumheight' 'ph' maximum height of the popup menu
|
'pumheight' 'ph' maximum height of the popup menu
|
||||||
'pumwidth' 'pw' minimum width of the popup menu
|
'pumwidth' 'pw' minimum width of the popup menu
|
||||||
'pythondll' name of the Python 2 dynamic library
|
'pythondll' name of the Python 2 dynamic library
|
||||||
|
@ -473,6 +473,7 @@ Options:
|
|||||||
'maxmem' Nvim delegates memory-management to the OS.
|
'maxmem' Nvim delegates memory-management to the OS.
|
||||||
'maxmemtot' Nvim delegates memory-management to the OS.
|
'maxmemtot' Nvim delegates memory-management to the OS.
|
||||||
'maxcombine' (6 is always used)
|
'maxcombine' (6 is always used)
|
||||||
|
*'prompt'* *'noprompt'*
|
||||||
*'restorescreen'* *'rs'* *'norestorescreen'* *'nors'*
|
*'restorescreen'* *'rs'* *'norestorescreen'* *'nors'*
|
||||||
'shelltype'
|
'shelltype'
|
||||||
*'shortname'* *'sn'* *'noshortname'* *'nosn'*
|
*'shortname'* *'sn'* *'noshortname'* *'nosn'*
|
||||||
|
@ -2887,7 +2887,6 @@ void ex_append(exarg_T *eap)
|
|||||||
} else if (lnum > 0)
|
} else if (lnum > 0)
|
||||||
indent = get_indent_lnum(lnum);
|
indent = get_indent_lnum(lnum);
|
||||||
}
|
}
|
||||||
ex_keep_indent = FALSE;
|
|
||||||
if (eap->getline == NULL) {
|
if (eap->getline == NULL) {
|
||||||
/* No getline() function, use the lines that follow. This ends
|
/* No getline() function, use the lines that follow. This ends
|
||||||
* when there is no more. */
|
* when there is no more. */
|
||||||
@ -2915,10 +2914,6 @@ void ex_append(exarg_T *eap)
|
|||||||
if (theline == NULL)
|
if (theline == NULL)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
/* Using ^ CTRL-D in getexmodeline() makes us repeat the indent. */
|
|
||||||
if (ex_keep_indent)
|
|
||||||
append_indent = indent;
|
|
||||||
|
|
||||||
/* Look for the "." after automatic indent. */
|
/* Look for the "." after automatic indent. */
|
||||||
vcol = 0;
|
vcol = 0;
|
||||||
for (p = theline; indent > vcol; ++p) {
|
for (p = theline; indent > vcol; ++p) {
|
||||||
@ -3751,6 +3746,7 @@ static buf_T *do_sub(exarg_T *eap, proftime_T timeout,
|
|||||||
*/
|
*/
|
||||||
while (subflags.do_ask) {
|
while (subflags.do_ask) {
|
||||||
if (exmode_active) {
|
if (exmode_active) {
|
||||||
|
char *prompt;
|
||||||
char_u *resp;
|
char_u *resp;
|
||||||
colnr_T sc, ec;
|
colnr_T sc, ec;
|
||||||
|
|
||||||
@ -3767,13 +3763,14 @@ static buf_T *do_sub(exarg_T *eap, proftime_T timeout,
|
|||||||
sc += numw;
|
sc += numw;
|
||||||
ec += numw;
|
ec += numw;
|
||||||
}
|
}
|
||||||
msg_start();
|
|
||||||
for (i = 0; i < (long)sc; ++i)
|
|
||||||
msg_putchar(' ');
|
|
||||||
for (; i <= (long)ec; ++i)
|
|
||||||
msg_putchar('^');
|
|
||||||
|
|
||||||
resp = getexmodeline('?', NULL, 0, true);
|
prompt = xmallocz(ec + 1);
|
||||||
|
memset(prompt, ' ', sc);
|
||||||
|
memset(prompt + sc, '^', ec - sc + 1);
|
||||||
|
resp = (char_u *)getcmdline_prompt(NUL, prompt, 0, EXPAND_NOTHING,
|
||||||
|
NULL, CALLBACK_NONE);
|
||||||
|
msg_putchar('\n');
|
||||||
|
xfree(prompt);
|
||||||
if (resp != NULL) {
|
if (resp != NULL) {
|
||||||
typed = *resp;
|
typed = *resp;
|
||||||
xfree(resp);
|
xfree(resp);
|
||||||
|
@ -186,17 +186,14 @@ static void restore_dbg_stuff(struct dbg_stuff *dsp)
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Repeatedly get commands for Ex mode, until the ":vi" command is given.
|
/// Repeatedly get commands for Ex mode, until the ":vi" command is given.
|
||||||
void do_exmode(int improved)
|
void do_exmode(void)
|
||||||
{
|
{
|
||||||
int save_msg_scroll;
|
int save_msg_scroll;
|
||||||
int prev_msg_row;
|
int prev_msg_row;
|
||||||
linenr_T prev_line;
|
linenr_T prev_line;
|
||||||
int changedtick;
|
int changedtick;
|
||||||
|
|
||||||
if (improved)
|
exmode_active = true;
|
||||||
exmode_active = EXMODE_VIM;
|
|
||||||
else
|
|
||||||
exmode_active = EXMODE_NORMAL;
|
|
||||||
State = NORMAL;
|
State = NORMAL;
|
||||||
|
|
||||||
/* When using ":global /pat/ visual" and then "Q" we return to continue
|
/* When using ":global /pat/ visual" and then "Q" we return to continue
|
||||||
@ -212,7 +209,7 @@ void do_exmode(int improved)
|
|||||||
while (exmode_active) {
|
while (exmode_active) {
|
||||||
/* Check for a ":normal" command and no more characters left. */
|
/* Check for a ":normal" command and no more characters left. */
|
||||||
if (ex_normal_busy > 0 && typebuf.tb_len == 0) {
|
if (ex_normal_busy > 0 && typebuf.tb_len == 0) {
|
||||||
exmode_active = 0;
|
exmode_active = false;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
msg_scroll = true;
|
msg_scroll = true;
|
||||||
@ -750,8 +747,7 @@ int do_cmdline(char_u *cmdline, LineGetter fgetline,
|
|||||||
* the :endtry to be missed. */
|
* the :endtry to be missed. */
|
||||||
&& (cstack.cs_trylevel == 0 || did_emsg_syntax)
|
&& (cstack.cs_trylevel == 0 || did_emsg_syntax)
|
||||||
&& used_getline
|
&& used_getline
|
||||||
&& (getline_equal(fgetline, cookie, getexmodeline)
|
&& getline_equal(fgetline, cookie, getexline))
|
||||||
|| getline_equal(fgetline, cookie, getexline)))
|
|
||||||
&& (next_cmdline != NULL
|
&& (next_cmdline != NULL
|
||||||
|| cstack.cs_idx >= 0
|
|| cstack.cs_idx >= 0
|
||||||
|| (flags & DOCMD_REPEAT)));
|
|| (flags & DOCMD_REPEAT)));
|
||||||
@ -2056,8 +2052,7 @@ int parse_command_modifiers(exarg_T *eap, char_u **errormsg, bool skip_only)
|
|||||||
|
|
||||||
// in ex mode, an empty line works like :+
|
// in ex mode, an empty line works like :+
|
||||||
if (*eap->cmd == NUL && exmode_active
|
if (*eap->cmd == NUL && exmode_active
|
||||||
&& (getline_equal(eap->getline, eap->cookie, getexmodeline)
|
&& getline_equal(eap->getline, eap->cookie, getexline)
|
||||||
|| getline_equal(eap->getline, eap->cookie, getexline))
|
|
||||||
&& curwin->w_cursor.lnum < curbuf->b_ml.ml_line_count) {
|
&& curwin->w_cursor.lnum < curbuf->b_ml.ml_line_count) {
|
||||||
eap->cmd = (char_u *)"+";
|
eap->cmd = (char_u *)"+";
|
||||||
if (!skip_only) {
|
if (!skip_only) {
|
||||||
@ -7303,7 +7298,7 @@ do_exedit(
|
|||||||
*/
|
*/
|
||||||
if (exmode_active && (eap->cmdidx == CMD_visual
|
if (exmode_active && (eap->cmdidx == CMD_visual
|
||||||
|| eap->cmdidx == CMD_view)) {
|
|| eap->cmdidx == CMD_view)) {
|
||||||
exmode_active = 0;
|
exmode_active = false;
|
||||||
ex_pressedreturn = false;
|
ex_pressedreturn = false;
|
||||||
if (*eap->arg == NUL) {
|
if (*eap->arg == NUL) {
|
||||||
/* Special case: ":global/pat/visual\NLvi-commands" */
|
/* Special case: ":global/pat/visual\NLvi-commands" */
|
||||||
|
@ -16,10 +16,6 @@
|
|||||||
#define VALID_PATH 1
|
#define VALID_PATH 1
|
||||||
#define VALID_HEAD 2
|
#define VALID_HEAD 2
|
||||||
|
|
||||||
/* Values for exmode_active (0 is no exmode) */
|
|
||||||
#define EXMODE_NORMAL 1
|
|
||||||
#define EXMODE_VIM 2
|
|
||||||
|
|
||||||
// Structure used to save the current state. Used when executing Normal mode
|
// Structure used to save the current state. Used when executing Normal mode
|
||||||
// commands while in any other mode.
|
// commands while in any other mode.
|
||||||
typedef struct {
|
typedef struct {
|
||||||
|
@ -2510,266 +2510,6 @@ getexline(
|
|||||||
return getcmdline(c, 1L, indent, do_concat);
|
return getcmdline(c, 1L, indent, do_concat);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Get an Ex command line for Ex mode.
|
|
||||||
* In Ex mode we only use the OS supplied line editing features and no
|
|
||||||
* mappings or abbreviations.
|
|
||||||
* Returns a string in allocated memory or NULL.
|
|
||||||
*/
|
|
||||||
char_u *
|
|
||||||
getexmodeline(
|
|
||||||
int promptc, // normally ':', NUL for ":append" and '?'
|
|
||||||
// for :s prompt
|
|
||||||
void *cookie,
|
|
||||||
int indent, // indent for inside conditionals
|
|
||||||
bool do_concat
|
|
||||||
)
|
|
||||||
{
|
|
||||||
garray_T line_ga;
|
|
||||||
char_u *pend;
|
|
||||||
int startcol = 0;
|
|
||||||
int c1 = 0;
|
|
||||||
int escaped = FALSE; /* CTRL-V typed */
|
|
||||||
int vcol = 0;
|
|
||||||
char_u *p;
|
|
||||||
int prev_char;
|
|
||||||
int len;
|
|
||||||
|
|
||||||
/* always start in column 0; write a newline if necessary */
|
|
||||||
compute_cmdrow();
|
|
||||||
if ((msg_col || msg_didout) && promptc != '?')
|
|
||||||
msg_putchar('\n');
|
|
||||||
if (promptc == ':') {
|
|
||||||
/* indent that is only displayed, not in the line itself */
|
|
||||||
if (p_prompt)
|
|
||||||
msg_putchar(':');
|
|
||||||
while (indent-- > 0)
|
|
||||||
msg_putchar(' ');
|
|
||||||
startcol = msg_col;
|
|
||||||
}
|
|
||||||
|
|
||||||
ga_init(&line_ga, 1, 30);
|
|
||||||
|
|
||||||
/* autoindent for :insert and :append is in the line itself */
|
|
||||||
if (promptc <= 0) {
|
|
||||||
vcol = indent;
|
|
||||||
while (indent >= 8) {
|
|
||||||
ga_append(&line_ga, TAB);
|
|
||||||
msg_puts(" ");
|
|
||||||
indent -= 8;
|
|
||||||
}
|
|
||||||
while (indent-- > 0) {
|
|
||||||
ga_append(&line_ga, ' ');
|
|
||||||
msg_putchar(' ');
|
|
||||||
}
|
|
||||||
}
|
|
||||||
no_mapping++;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Get the line, one character at a time.
|
|
||||||
*/
|
|
||||||
got_int = FALSE;
|
|
||||||
while (!got_int) {
|
|
||||||
ga_grow(&line_ga, 40);
|
|
||||||
|
|
||||||
/* Get one character at a time. Don't use inchar(), it can't handle
|
|
||||||
* special characters. */
|
|
||||||
prev_char = c1;
|
|
||||||
|
|
||||||
// Check for a ":normal" command and no more characters left.
|
|
||||||
if (ex_normal_busy > 0 && typebuf.tb_len == 0) {
|
|
||||||
c1 = '\n';
|
|
||||||
} else {
|
|
||||||
c1 = vgetc();
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Handle line editing.
|
|
||||||
* Previously this was left to the system, putting the terminal in
|
|
||||||
* cooked mode, but then CTRL-D and CTRL-T can't be used properly.
|
|
||||||
*/
|
|
||||||
if (got_int) {
|
|
||||||
msg_putchar('\n');
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!escaped) {
|
|
||||||
/* CR typed means "enter", which is NL */
|
|
||||||
if (c1 == '\r')
|
|
||||||
c1 = '\n';
|
|
||||||
|
|
||||||
if (c1 == BS || c1 == K_BS || c1 == DEL || c1 == K_DEL || c1 == K_KDEL) {
|
|
||||||
if (!GA_EMPTY(&line_ga)) {
|
|
||||||
p = (char_u *)line_ga.ga_data;
|
|
||||||
p[line_ga.ga_len] = NUL;
|
|
||||||
len = utf_head_off(p, p + line_ga.ga_len - 1) + 1;
|
|
||||||
line_ga.ga_len -= len;
|
|
||||||
goto redraw;
|
|
||||||
}
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (c1 == Ctrl_U) {
|
|
||||||
msg_col = startcol;
|
|
||||||
msg_clr_eos();
|
|
||||||
line_ga.ga_len = 0;
|
|
||||||
goto redraw;
|
|
||||||
}
|
|
||||||
|
|
||||||
int num_spaces;
|
|
||||||
if (c1 == Ctrl_T) {
|
|
||||||
int sw = get_sw_value(curbuf);
|
|
||||||
|
|
||||||
p = (char_u *)line_ga.ga_data;
|
|
||||||
p[line_ga.ga_len] = NUL;
|
|
||||||
indent = get_indent_str(p, 8, FALSE);
|
|
||||||
num_spaces = sw - indent % sw;
|
|
||||||
add_indent:
|
|
||||||
if (num_spaces > 0) {
|
|
||||||
ga_grow(&line_ga, num_spaces + 1);
|
|
||||||
p = (char_u *)line_ga.ga_data;
|
|
||||||
char_u *s = skipwhite(p);
|
|
||||||
|
|
||||||
// Insert spaces after leading whitespaces.
|
|
||||||
long move_len = line_ga.ga_len - (s - p) + 1;
|
|
||||||
assert(move_len >= 0);
|
|
||||||
memmove(s + num_spaces, s, (size_t)move_len);
|
|
||||||
memset(s, ' ', (size_t)num_spaces);
|
|
||||||
|
|
||||||
line_ga.ga_len += num_spaces;
|
|
||||||
}
|
|
||||||
redraw:
|
|
||||||
/* redraw the line */
|
|
||||||
msg_col = startcol;
|
|
||||||
vcol = 0;
|
|
||||||
p = (char_u *)line_ga.ga_data;
|
|
||||||
p[line_ga.ga_len] = NUL;
|
|
||||||
while (p < (char_u *)line_ga.ga_data + line_ga.ga_len) {
|
|
||||||
if (*p == TAB) {
|
|
||||||
do {
|
|
||||||
msg_putchar(' ');
|
|
||||||
} while (++vcol % 8);
|
|
||||||
p++;
|
|
||||||
} else {
|
|
||||||
len = utfc_ptr2len(p);
|
|
||||||
msg_outtrans_len(p, len);
|
|
||||||
vcol += ptr2cells(p);
|
|
||||||
p += len;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
msg_clr_eos();
|
|
||||||
cmd_cursor_goto(msg_row, msg_col);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (c1 == Ctrl_D) {
|
|
||||||
/* Delete one shiftwidth. */
|
|
||||||
p = (char_u *)line_ga.ga_data;
|
|
||||||
if (prev_char == '0' || prev_char == '^') {
|
|
||||||
if (prev_char == '^')
|
|
||||||
ex_keep_indent = TRUE;
|
|
||||||
indent = 0;
|
|
||||||
p[--line_ga.ga_len] = NUL;
|
|
||||||
} else {
|
|
||||||
p[line_ga.ga_len] = NUL;
|
|
||||||
indent = get_indent_str(p, 8, FALSE);
|
|
||||||
if (indent == 0) {
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
--indent;
|
|
||||||
indent -= indent % get_sw_value(curbuf);
|
|
||||||
}
|
|
||||||
|
|
||||||
// reduce the line's indentation
|
|
||||||
char_u *from = skipwhite(p);
|
|
||||||
char_u *to = from;
|
|
||||||
int old_indent;
|
|
||||||
while ((old_indent = get_indent_str(p, 8, FALSE)) > indent) {
|
|
||||||
*--to = NUL;
|
|
||||||
}
|
|
||||||
long move_len = line_ga.ga_len - (from - p) + 1;
|
|
||||||
assert(move_len > 0);
|
|
||||||
memmove(to, from, (size_t)move_len);
|
|
||||||
line_ga.ga_len -= (int)(from - to);
|
|
||||||
|
|
||||||
// Removed to much indentation, fix it before redrawing.
|
|
||||||
num_spaces = indent - old_indent;
|
|
||||||
goto add_indent;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (c1 == Ctrl_V || c1 == Ctrl_Q) {
|
|
||||||
escaped = TRUE;
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (IS_SPECIAL(c1)) {
|
|
||||||
// Ignore other special key codes
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (IS_SPECIAL(c1)) {
|
|
||||||
c1 = '?';
|
|
||||||
}
|
|
||||||
len = utf_char2bytes(c1, (char_u *)line_ga.ga_data + line_ga.ga_len);
|
|
||||||
if (c1 == '\n') {
|
|
||||||
msg_putchar('\n');
|
|
||||||
} else if (c1 == TAB) {
|
|
||||||
// Don't use chartabsize(), 'ts' can be different.
|
|
||||||
do {
|
|
||||||
msg_putchar(' ');
|
|
||||||
} while (++vcol % 8);
|
|
||||||
} else {
|
|
||||||
msg_outtrans_len(((char_u *)line_ga.ga_data) + line_ga.ga_len, len);
|
|
||||||
vcol += char2cells(c1);
|
|
||||||
}
|
|
||||||
line_ga.ga_len += len;
|
|
||||||
escaped = FALSE;
|
|
||||||
|
|
||||||
cmd_cursor_goto(msg_row, msg_col);
|
|
||||||
pend = (char_u *)(line_ga.ga_data) + line_ga.ga_len;
|
|
||||||
|
|
||||||
/* We are done when a NL is entered, but not when it comes after an
|
|
||||||
* odd number of backslashes, that results in a NUL. */
|
|
||||||
if (!GA_EMPTY(&line_ga) && pend[-1] == '\n') {
|
|
||||||
int bcount = 0;
|
|
||||||
|
|
||||||
while (line_ga.ga_len - 2 >= bcount && pend[-2 - bcount] == '\\')
|
|
||||||
++bcount;
|
|
||||||
|
|
||||||
if (bcount > 0) {
|
|
||||||
/* Halve the number of backslashes: "\NL" -> "NUL", "\\NL" ->
|
|
||||||
* "\NL", etc. */
|
|
||||||
line_ga.ga_len -= (bcount + 1) / 2;
|
|
||||||
pend -= (bcount + 1) / 2;
|
|
||||||
pend[-1] = '\n';
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((bcount & 1) == 0) {
|
|
||||||
--line_ga.ga_len;
|
|
||||||
--pend;
|
|
||||||
*pend = NUL;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
no_mapping--;
|
|
||||||
|
|
||||||
/* make following messages go to the next line */
|
|
||||||
msg_didout = FALSE;
|
|
||||||
msg_col = 0;
|
|
||||||
if (msg_row < Rows - 1) {
|
|
||||||
msg_row++;
|
|
||||||
}
|
|
||||||
emsg_on_display = false; // don't want os_delay()
|
|
||||||
|
|
||||||
if (got_int)
|
|
||||||
ga_clear(&line_ga);
|
|
||||||
|
|
||||||
return (char_u *)line_ga.ga_data;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool cmdline_overstrike(void)
|
bool cmdline_overstrike(void)
|
||||||
{
|
{
|
||||||
return ccline.overstrike;
|
return ccline.overstrike;
|
||||||
@ -6469,7 +6209,7 @@ static int open_cmdwin(void)
|
|||||||
char_u typestr[2];
|
char_u typestr[2];
|
||||||
int save_restart_edit = restart_edit;
|
int save_restart_edit = restart_edit;
|
||||||
int save_State = State;
|
int save_State = State;
|
||||||
int save_exmode = exmode_active;
|
bool save_exmode = exmode_active;
|
||||||
int save_cmdmsg_rl = cmdmsg_rl;
|
int save_cmdmsg_rl = cmdmsg_rl;
|
||||||
|
|
||||||
/* Can't do this recursively. Can't do it when typing a password. */
|
/* Can't do this recursively. Can't do it when typing a password. */
|
||||||
@ -6563,7 +6303,7 @@ static int open_cmdwin(void)
|
|||||||
save_cmdline(&save_ccline);
|
save_cmdline(&save_ccline);
|
||||||
|
|
||||||
// No Ex mode here!
|
// No Ex mode here!
|
||||||
exmode_active = 0;
|
exmode_active = false;
|
||||||
|
|
||||||
State = NORMAL;
|
State = NORMAL;
|
||||||
setmouse();
|
setmouse();
|
||||||
|
@ -2230,20 +2230,22 @@ static int vgetorpeek(bool advance)
|
|||||||
timedout = true;
|
timedout = true;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
/* When 'insertmode' is set, ESC just beeps in Insert
|
// When 'insertmode' is set, ESC just beeps in Insert
|
||||||
* mode. Use CTRL-L to make edit() return.
|
// mode. Use CTRL-L to make edit() return.
|
||||||
* For the command line only CTRL-C always breaks it.
|
// In Ex-mode \n is compatible with original Vim behaviour.
|
||||||
* For the cmdline window: Alternate between ESC and
|
// For the command line only CTRL-C always breaks it.
|
||||||
* CTRL-C: ESC for most situations and CTRL-C to close the
|
// For the cmdline window: Alternate between ESC and
|
||||||
* cmdline window. */
|
// CTRL-C: ESC for most situations and CTRL-C to close the
|
||||||
if (p_im && (State & INSERT))
|
// cmdline window.
|
||||||
|
if (p_im && (State & INSERT)) {
|
||||||
c = Ctrl_L;
|
c = Ctrl_L;
|
||||||
else if ((State & CMDLINE)
|
} else if (exmode_active) {
|
||||||
|| (cmdwin_type > 0 && tc == ESC)
|
c = '\n';
|
||||||
)
|
} else if ((State & CMDLINE) || (cmdwin_type > 0 && tc == ESC)) {
|
||||||
c = Ctrl_C;
|
c = Ctrl_C;
|
||||||
else
|
} else {
|
||||||
c = ESC;
|
c = ESC;
|
||||||
|
}
|
||||||
tc = c;
|
tc = c;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -239,7 +239,6 @@ EXTERN int did_wait_return INIT(= false); // wait_return() was used and
|
|||||||
EXTERN int need_maketitle INIT(= true); // call maketitle() soon
|
EXTERN int need_maketitle INIT(= true); // call maketitle() soon
|
||||||
|
|
||||||
EXTERN int quit_more INIT(= false); // 'q' hit at "--more--" msg
|
EXTERN int quit_more INIT(= false); // 'q' hit at "--more--" msg
|
||||||
EXTERN int ex_keep_indent INIT(= false); // getexmodeline(): keep indent
|
|
||||||
EXTERN int vgetc_busy INIT(= 0); // when inside vgetc() then > 0
|
EXTERN int vgetc_busy INIT(= 0); // when inside vgetc() then > 0
|
||||||
|
|
||||||
EXTERN int didset_vim INIT(= false); // did set $VIM ourselves
|
EXTERN int didset_vim INIT(= false); // did set $VIM ourselves
|
||||||
@ -621,7 +620,7 @@ EXTERN long opcount INIT(= 0); // count for pending operator
|
|||||||
EXTERN int motion_force INIT(=0); // motion force for pending operator
|
EXTERN int motion_force INIT(=0); // motion force for pending operator
|
||||||
|
|
||||||
// Ex Mode (Q) state
|
// Ex Mode (Q) state
|
||||||
EXTERN int exmode_active INIT(= 0); // Zero, EXMODE_NORMAL or EXMODE_VIM.
|
EXTERN bool exmode_active INIT(= false); // true if Ex mode is active
|
||||||
EXTERN int ex_no_reprint INIT(=false); // No need to print after z or p.
|
EXTERN int ex_no_reprint INIT(=false); // No need to print after z or p.
|
||||||
|
|
||||||
EXTERN int reg_recording INIT(= 0); // register for recording or zero
|
EXTERN int reg_recording INIT(= 0); // register for recording or zero
|
||||||
|
@ -318,7 +318,8 @@ int main(int argc, char **argv)
|
|||||||
debug_break_level = params.use_debug_break_level;
|
debug_break_level = params.use_debug_break_level;
|
||||||
|
|
||||||
// Read ex-commands if invoked with "-es".
|
// Read ex-commands if invoked with "-es".
|
||||||
if (!params.input_isatty && silent_mode && exmode_active == EXMODE_NORMAL) {
|
if (!params.input_isatty && !params.input_neverscript
|
||||||
|
&& silent_mode && exmode_active) {
|
||||||
input_start(STDIN_FILENO);
|
input_start(STDIN_FILENO);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -769,7 +770,7 @@ static bool edit_stdin(bool explicit, mparm_T *parmp)
|
|||||||
{
|
{
|
||||||
bool implicit = !headless_mode
|
bool implicit = !headless_mode
|
||||||
&& !embedded_mode
|
&& !embedded_mode
|
||||||
&& exmode_active != EXMODE_NORMAL // -E/-Es but not -e/-es.
|
&& (!exmode_active || parmp->input_neverscript)
|
||||||
&& !parmp->input_isatty
|
&& !parmp->input_isatty
|
||||||
&& scriptin[0] == NULL; // `-s -` was not given.
|
&& scriptin[0] == NULL; // `-s -` was not given.
|
||||||
return explicit || implicit;
|
return explicit || implicit;
|
||||||
@ -912,11 +913,12 @@ static void command_line_scan(mparm_T *parmp)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 'e': { // "-e" Ex mode
|
case 'e': { // "-e" Ex mode
|
||||||
exmode_active = EXMODE_NORMAL;
|
exmode_active = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 'E': { // "-E" Ex mode
|
case 'E': { // "-E" Ex mode
|
||||||
exmode_active = EXMODE_VIM;
|
exmode_active = true;
|
||||||
|
parmp->input_neverscript = true;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 'f': { // "-f" GUI: run in foreground.
|
case 'f': { // "-f" GUI: run in foreground.
|
||||||
|
@ -30,6 +30,7 @@ typedef struct {
|
|||||||
bool input_isatty; // stdin is a terminal
|
bool input_isatty; // stdin is a terminal
|
||||||
bool output_isatty; // stdout is a terminal
|
bool output_isatty; // stdout is a terminal
|
||||||
bool err_isatty; // stderr is a terminal
|
bool err_isatty; // stderr is a terminal
|
||||||
|
bool input_neverscript; // never treat stdin as script (-E/-Es)
|
||||||
int no_swap_file; // "-n" argument used
|
int no_swap_file; // "-n" argument used
|
||||||
int use_debug_break_level;
|
int use_debug_break_level;
|
||||||
int window_count; // number of windows to use
|
int window_count; // number of windows to use
|
||||||
|
@ -1324,8 +1324,7 @@ void msg_start(void)
|
|||||||
0;
|
0;
|
||||||
} else if (msg_didout) { // start message on next line
|
} else if (msg_didout) { // start message on next line
|
||||||
msg_putchar('\n');
|
msg_putchar('\n');
|
||||||
did_return = TRUE;
|
did_return = true;
|
||||||
if (exmode_active != EXMODE_NORMAL)
|
|
||||||
cmdline_row = msg_row;
|
cmdline_row = msg_row;
|
||||||
}
|
}
|
||||||
if (!msg_didany || lines_left < 0)
|
if (!msg_didany || lines_left < 0)
|
||||||
|
@ -1188,7 +1188,7 @@ static void normal_check_interrupt(NormalState *s)
|
|||||||
&& s->previous_got_int) {
|
&& s->previous_got_int) {
|
||||||
// Typed two CTRL-C in a row: go back to ex mode as if "Q" was
|
// Typed two CTRL-C in a row: go back to ex mode as if "Q" was
|
||||||
// used and keep "got_int" set, so that it aborts ":g".
|
// used and keep "got_int" set, so that it aborts ":g".
|
||||||
exmode_active = EXMODE_NORMAL;
|
exmode_active = true;
|
||||||
State = NORMAL;
|
State = NORMAL;
|
||||||
} else if (!global_busy || !exmode_active) {
|
} else if (!global_busy || !exmode_active) {
|
||||||
if (!quit_more) {
|
if (!quit_more) {
|
||||||
@ -1398,7 +1398,7 @@ static int normal_check(VimState *state)
|
|||||||
if (s->noexmode) {
|
if (s->noexmode) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
do_exmode(exmode_active == EXMODE_VIM);
|
do_exmode();
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -4652,7 +4652,7 @@ static void nv_exmode(cmdarg_T *cap)
|
|||||||
if (VIsual_active) {
|
if (VIsual_active) {
|
||||||
vim_beep(BO_EX);
|
vim_beep(BO_EX);
|
||||||
} else if (!checkclearop(cap->oap)) {
|
} else if (!checkclearop(cap->oap)) {
|
||||||
do_exmode(false);
|
do_exmode();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -7101,8 +7101,9 @@ static void nv_g_cmd(cmdarg_T *cap)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!checkclearopq(oap))
|
if (!checkclearopq(oap)) {
|
||||||
do_exmode(true);
|
do_exmode();
|
||||||
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
case ',':
|
case ',':
|
||||||
|
@ -459,7 +459,6 @@ EXTERN char_u *p_pmcs; // 'printmbcharset'
|
|||||||
EXTERN char_u *p_pfn; // 'printfont'
|
EXTERN char_u *p_pfn; // 'printfont'
|
||||||
EXTERN char_u *p_popt; // 'printoptions'
|
EXTERN char_u *p_popt; // 'printoptions'
|
||||||
EXTERN char_u *p_header; // 'printheader'
|
EXTERN char_u *p_header; // 'printheader'
|
||||||
EXTERN int p_prompt; // 'prompt'
|
|
||||||
EXTERN char_u *p_guicursor; // 'guicursor'
|
EXTERN char_u *p_guicursor; // 'guicursor'
|
||||||
EXTERN char_u *p_guifont; // 'guifont'
|
EXTERN char_u *p_guifont; // 'guifont'
|
||||||
EXTERN char_u *p_guifontwide; // 'guifontwide'
|
EXTERN char_u *p_guifontwide; // 'guifontwide'
|
||||||
|
@ -1800,7 +1800,7 @@ return {
|
|||||||
full_name='prompt',
|
full_name='prompt',
|
||||||
short_desc=N_("enable prompt in Ex mode"),
|
short_desc=N_("enable prompt in Ex mode"),
|
||||||
type='bool', scope={'global'},
|
type='bool', scope={'global'},
|
||||||
varname='p_prompt',
|
varname='p_force_on',
|
||||||
defaults={if_true={vi=true}}
|
defaults={if_true={vi=true}}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
@ -171,12 +171,10 @@ char *get_mode(void)
|
|||||||
buf[1] = 'x';
|
buf[1] = 'x';
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else if ((State & CMDLINE) || exmode_active) {
|
} else if (State & CMDLINE) {
|
||||||
buf[0] = 'c';
|
buf[0] = 'c';
|
||||||
if (exmode_active == EXMODE_VIM) {
|
if (exmode_active) {
|
||||||
buf[1] = 'v';
|
buf[1] = 'v';
|
||||||
} else if (exmode_active == EXMODE_NORMAL) {
|
|
||||||
buf[1] = 'e';
|
|
||||||
}
|
}
|
||||||
} else if (State & TERM_FOCUS) {
|
} else if (State & TERM_FOCUS) {
|
||||||
buf[0] = 't';
|
buf[0] = 't';
|
||||||
|
Loading…
Reference in New Issue
Block a user