summaryrefslogtreecommitdiff
path: root/usr.bin/vim/term.c
diff options
context:
space:
mode:
Diffstat (limited to 'usr.bin/vim/term.c')
-rw-r--r--usr.bin/vim/term.c52
1 files changed, 42 insertions, 10 deletions
diff --git a/usr.bin/vim/term.c b/usr.bin/vim/term.c
index 502c722ebae..cc7e4483580 100644
--- a/usr.bin/vim/term.c
+++ b/usr.bin/vim/term.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: term.c,v 1.1 1996/09/07 21:40:24 downsj Exp $ */
+/* $OpenBSD: term.c,v 1.2 1996/09/21 06:23:22 downsj Exp $ */
/* vi:set ts=4 sw=4:
*
* VIM - Vi IMproved by Bram Moolenaar
@@ -365,6 +365,10 @@ struct builtin_term builtin_termcaps[] =
{KS_MD, "\033|63m"},
{KS_SE, "\033|0m"},
{KS_SO, "\033|31m"},
+ {KS_CZH, "\033|225m"}, /* italic mode: blue text on yellow */
+ {KS_CZR, "\033|0m"}, /* italic mode end */
+ {KS_US, "\033|67m"}, /* underscore mode: cyan text on red */
+ {KS_UE, "\033|0m"}, /* underscore mode end */
{KS_MS, "\001"},
# ifdef TERMINFO
{KS_CM, "\033|%i%p1%d;%p2%dH"},
@@ -633,8 +637,10 @@ struct builtin_term builtin_termcaps[] =
{K_HELP, "\033[28~"},
{K_UNDO, "\033[26~"},
{K_INS, "\033[2~"},
- {K_HOME, "\033[7~"}, /* also seen: "\033[1~" */
- {K_END, "\033[8~"}, /* also seen: "\033[4~" */
+ {K_HOME, "\033[7~"},
+ {K_KHOME, "\033[1~"},
+ {K_END, "\033[8~"},
+ {K_KEND, "\033[4~"},
{K_PAGEUP, "\033[5~"},
{K_PAGEDOWN, "\033[6~"},
/* {K_DEL, "\033[3~"}, not used */
@@ -832,6 +838,10 @@ struct builtin_term builtin_termcaps[] =
{K_END, "[END]"},
{K_PAGEUP, "[PAGEUP]"},
{K_PAGEDOWN, "[PAGEDOWN]"},
+ {K_KHOME, "[KHOME]"},
+ {K_KEND, "[KEND]"},
+ {K_KPAGEUP, "[KPAGEUP]"},
+ {K_KPAGEDOWN, "[KPAGEDOWN]"},
{K_MOUSE, "[MOUSE]"},
# endif
@@ -1015,7 +1025,7 @@ set_termname(term)
"k1", "k2", "k3", "k4", "k5", "k6",
"k7", "k8", "k9", "k;", "F1", "F2",
"%1", "&8", "kb", "kI", "kD", "kh",
- "@7", "kP", "kN",
+ "@7", "kP", "kN", "K1", "K3", "K4", "K5",
NULL
};
static struct {
@@ -1051,9 +1061,9 @@ set_termname(term)
for (i = 0; string_names[i].name != NULL; ++i)
{
if (term_strings[string_names[i].dest] == NULL ||
- term_strings[string_names[i].dest] == empty_option)
+ term_strings[string_names[i].dest] == empty_option)
term_strings[string_names[i].dest] =
- TGETSTR(string_names[i].name, &tp);
+ TGETSTR(string_names[i].name, &tp);
}
if ((T_MS == NULL || T_MS == empty_option) && tgetflag("ms"))
@@ -1070,7 +1080,7 @@ set_termname(term)
{
if (find_termcode((char_u *)key_names[i]) == NULL)
add_termcode((char_u *)key_names[i],
- TGETSTR(key_names[i], &tp));
+ TGETSTR(key_names[i], &tp));
}
/* if cursor-left == backspace, ignore it (televideo 925) */
@@ -1569,8 +1579,10 @@ tgoto(cm, x, y)
termcapinit(term)
char_u *term;
{
+#ifndef WIN32
if (!term || !*term)
term = vim_getenv((char_u *)"TERM");
+#endif
if (!term || !*term)
term = DEFAULT_TERM;
set_string_option((char_u *)"term", -1, term, TRUE);
@@ -1755,7 +1767,7 @@ setcursor()
ttest(pairs)
int pairs;
{
- char *t = NULL;
+ char *t = NULL;
check_options(); /* make sure no options are NULL */
@@ -1974,6 +1986,7 @@ set_winsize(width, height, mustset)
if (!starting)
{
comp_Botline_all();
+ maketitle();
if (State == ASKMORE || State == EXTERNCMD)
{
screenalloc(FALSE); /* don't redraw, just adjust screen size */
@@ -2212,7 +2225,7 @@ clear_termcodes()
#ifdef HAVE_TGETENT
BC = (char *)empty_option;
UP = (char *)empty_option;
- PC = ' '; /* set pad character to space */
+ PC = NUL; /* set pad character to NUL */
ospeed = 0;
#endif
@@ -2368,7 +2381,7 @@ check_termcode(max_offset)
int new_slen;
int extra;
char_u string[MAX_KEY_CODE_LEN + 1];
- int i;
+ int i, j;
#ifdef USE_GUI
long_u val;
#endif
@@ -2476,6 +2489,25 @@ check_termcode(max_offset)
if (len < slen) /* got a partial sequence */
return -1; /* need to get more chars */
+ /*
+ * When found a keypad key, check if there is another key
+ * that matches and use that one. This makes <Home> to be
+ * found instead of <kHome> when they produce the same
+ * key code.
+ */
+ if (termcodes[i].name[0] == 'K' &&
+ isdigit(termcodes[i].name[1]))
+ {
+ for (j = i + 1; j < tc_len; ++j)
+ if (termcodes[j].len == slen &&
+ STRNCMP(termcodes[i].code,
+ termcodes[j].code, slen) == 0)
+ {
+ i = j;
+ break;
+ }
+ }
+
key_name[0] = termcodes[i].name[0];
key_name[1] = termcodes[i].name[1];