xref: /vim-8.2.3635/src/misc2.c (revision 2e693a88)
1 /* vi:set ts=8 sts=4 sw=4 noet:
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  * misc2.c: Various functions.
12  */
13 #include "vim.h"
14 
15 static char_u	*username = NULL; /* cached result of mch_get_user_name() */
16 
17 static int coladvance2(pos_T *pos, int addspaces, int finetune, colnr_T wcol);
18 
19 /*
20  * Return TRUE if in the current mode we need to use virtual.
21  */
22     int
23 virtual_active(void)
24 {
25     /* While an operator is being executed we return "virtual_op", because
26      * VIsual_active has already been reset, thus we can't check for "block"
27      * being used. */
28     if (virtual_op != MAYBE)
29 	return virtual_op;
30     return (ve_flags == VE_ALL
31 	    || ((ve_flags & VE_BLOCK) && VIsual_active && VIsual_mode == Ctrl_V)
32 	    || ((ve_flags & VE_INSERT) && (State & INSERT)));
33 }
34 
35 /*
36  * Get the screen position of the cursor.
37  */
38     int
39 getviscol(void)
40 {
41     colnr_T	x;
42 
43     getvvcol(curwin, &curwin->w_cursor, &x, NULL, NULL);
44     return (int)x;
45 }
46 
47 /*
48  * Go to column "wcol", and add/insert white space as necessary to get the
49  * cursor in that column.
50  * The caller must have saved the cursor line for undo!
51  */
52     int
53 coladvance_force(colnr_T wcol)
54 {
55     int rc = coladvance2(&curwin->w_cursor, TRUE, FALSE, wcol);
56 
57     if (wcol == MAXCOL)
58 	curwin->w_valid &= ~VALID_VIRTCOL;
59     else
60     {
61 	/* Virtcol is valid */
62 	curwin->w_valid |= VALID_VIRTCOL;
63 	curwin->w_virtcol = wcol;
64     }
65     return rc;
66 }
67 
68 /*
69  * Get the screen position of character col with a coladd in the cursor line.
70  */
71     int
72 getviscol2(colnr_T col, colnr_T coladd UNUSED)
73 {
74     colnr_T	x;
75     pos_T	pos;
76 
77     pos.lnum = curwin->w_cursor.lnum;
78     pos.col = col;
79     pos.coladd = coladd;
80     getvvcol(curwin, &pos, &x, NULL, NULL);
81     return (int)x;
82 }
83 
84 /*
85  * Try to advance the Cursor to the specified screen column.
86  * If virtual editing: fine tune the cursor position.
87  * Note that all virtual positions off the end of a line should share
88  * a curwin->w_cursor.col value (n.b. this is equal to STRLEN(line)),
89  * beginning at coladd 0.
90  *
91  * return OK if desired column is reached, FAIL if not
92  */
93     int
94 coladvance(colnr_T wcol)
95 {
96     int rc = getvpos(&curwin->w_cursor, wcol);
97 
98     if (wcol == MAXCOL || rc == FAIL)
99 	curwin->w_valid &= ~VALID_VIRTCOL;
100     else if (*ml_get_cursor() != TAB)
101     {
102 	/* Virtcol is valid when not on a TAB */
103 	curwin->w_valid |= VALID_VIRTCOL;
104 	curwin->w_virtcol = wcol;
105     }
106     return rc;
107 }
108 
109 /*
110  * Return in "pos" the position of the cursor advanced to screen column "wcol".
111  * return OK if desired column is reached, FAIL if not
112  */
113     int
114 getvpos(pos_T *pos, colnr_T wcol)
115 {
116     return coladvance2(pos, FALSE, virtual_active(), wcol);
117 }
118 
119     static int
120 coladvance2(
121     pos_T	*pos,
122     int		addspaces,	// change the text to achieve our goal?
123     int		finetune,	// change char offset for the exact column
124     colnr_T	wcol_arg)	// column to move to (can be negative)
125 {
126     colnr_T	wcol = wcol_arg;
127     int		idx;
128     char_u	*ptr;
129     char_u	*line;
130     colnr_T	col = 0;
131     int		csize = 0;
132     int		one_more;
133 #ifdef FEAT_LINEBREAK
134     int		head = 0;
135 #endif
136 
137     one_more = (State & INSERT)
138 		    || restart_edit != NUL
139 		    || (VIsual_active && *p_sel != 'o')
140 		    || ((ve_flags & VE_ONEMORE) && wcol < MAXCOL);
141     line = ml_get_buf(curbuf, pos->lnum, FALSE);
142 
143     if (wcol >= MAXCOL)
144     {
145 	    idx = (int)STRLEN(line) - 1 + one_more;
146 	    col = wcol;
147 
148 	    if ((addspaces || finetune) && !VIsual_active)
149 	    {
150 		curwin->w_curswant = linetabsize(line) + one_more;
151 		if (curwin->w_curswant > 0)
152 		    --curwin->w_curswant;
153 	    }
154     }
155     else
156     {
157 	int width = curwin->w_width - win_col_off(curwin);
158 
159 	if (finetune
160 		&& curwin->w_p_wrap
161 		&& curwin->w_width != 0
162 		&& wcol >= (colnr_T)width)
163 	{
164 	    csize = linetabsize(line);
165 	    if (csize > 0)
166 		csize--;
167 
168 	    if (wcol / width > (colnr_T)csize / width
169 		    && ((State & INSERT) == 0 || (int)wcol > csize + 1))
170 	    {
171 		/* In case of line wrapping don't move the cursor beyond the
172 		 * right screen edge.  In Insert mode allow going just beyond
173 		 * the last character (like what happens when typing and
174 		 * reaching the right window edge). */
175 		wcol = (csize / width + 1) * width - 1;
176 	    }
177 	}
178 
179 	ptr = line;
180 	while (col <= wcol && *ptr != NUL)
181 	{
182 	    /* Count a tab for what it's worth (if list mode not on) */
183 #ifdef FEAT_LINEBREAK
184 	    csize = win_lbr_chartabsize(curwin, line, ptr, col, &head);
185 	    MB_PTR_ADV(ptr);
186 #else
187 	    csize = lbr_chartabsize_adv(line, &ptr, col);
188 #endif
189 	    col += csize;
190 	}
191 	idx = (int)(ptr - line);
192 	/*
193 	 * Handle all the special cases.  The virtual_active() check
194 	 * is needed to ensure that a virtual position off the end of
195 	 * a line has the correct indexing.  The one_more comparison
196 	 * replaces an explicit add of one_more later on.
197 	 */
198 	if (col > wcol || (!virtual_active() && one_more == 0))
199 	{
200 	    idx -= 1;
201 # ifdef FEAT_LINEBREAK
202 	    /* Don't count the chars from 'showbreak'. */
203 	    csize -= head;
204 # endif
205 	    col -= csize;
206 	}
207 
208 	if (virtual_active()
209 		&& addspaces
210 		&& wcol >= 0
211 		&& ((col != wcol && col != wcol + 1) || csize > 1))
212 	{
213 	    /* 'virtualedit' is set: The difference between wcol and col is
214 	     * filled with spaces. */
215 
216 	    if (line[idx] == NUL)
217 	    {
218 		/* Append spaces */
219 		int	correct = wcol - col;
220 		char_u	*newline = alloc(idx + correct + 1);
221 		int	t;
222 
223 		if (newline == NULL)
224 		    return FAIL;
225 
226 		for (t = 0; t < idx; ++t)
227 		    newline[t] = line[t];
228 
229 		for (t = 0; t < correct; ++t)
230 		    newline[t + idx] = ' ';
231 
232 		newline[idx + correct] = NUL;
233 
234 		ml_replace(pos->lnum, newline, FALSE);
235 		changed_bytes(pos->lnum, (colnr_T)idx);
236 		idx += correct;
237 		col = wcol;
238 	    }
239 	    else
240 	    {
241 		/* Break a tab */
242 		int	linelen = (int)STRLEN(line);
243 		int	correct = wcol - col - csize + 1; /* negative!! */
244 		char_u	*newline;
245 		int	t, s = 0;
246 		int	v;
247 
248 		if (-correct > csize)
249 		    return FAIL;
250 
251 		newline = alloc(linelen + csize);
252 		if (newline == NULL)
253 		    return FAIL;
254 
255 		for (t = 0; t < linelen; t++)
256 		{
257 		    if (t != idx)
258 			newline[s++] = line[t];
259 		    else
260 			for (v = 0; v < csize; v++)
261 			    newline[s++] = ' ';
262 		}
263 
264 		newline[linelen + csize - 1] = NUL;
265 
266 		ml_replace(pos->lnum, newline, FALSE);
267 		changed_bytes(pos->lnum, idx);
268 		idx += (csize - 1 + correct);
269 		col += correct;
270 	    }
271 	}
272     }
273 
274     if (idx < 0)
275 	pos->col = 0;
276     else
277 	pos->col = idx;
278 
279     pos->coladd = 0;
280 
281     if (finetune)
282     {
283 	if (wcol == MAXCOL)
284 	{
285 	    /* The width of the last character is used to set coladd. */
286 	    if (!one_more)
287 	    {
288 		colnr_T	    scol, ecol;
289 
290 		getvcol(curwin, pos, &scol, NULL, &ecol);
291 		pos->coladd = ecol - scol;
292 	    }
293 	}
294 	else
295 	{
296 	    int b = (int)wcol - (int)col;
297 
298 	    /* The difference between wcol and col is used to set coladd. */
299 	    if (b > 0 && b < (MAXCOL - 2 * curwin->w_width))
300 		pos->coladd = b;
301 
302 	    col += b;
303 	}
304     }
305 
306     /* prevent from moving onto a trail byte */
307     if (has_mbyte)
308 	mb_adjustpos(curbuf, pos);
309 
310     if (wcol < 0 || col < wcol)
311 	return FAIL;
312     return OK;
313 }
314 
315 /*
316  * Increment the cursor position.  See inc() for return values.
317  */
318     int
319 inc_cursor(void)
320 {
321     return inc(&curwin->w_cursor);
322 }
323 
324 /*
325  * Increment the line pointer "lp" crossing line boundaries as necessary.
326  * Return 1 when going to the next line.
327  * Return 2 when moving forward onto a NUL at the end of the line).
328  * Return -1 when at the end of file.
329  * Return 0 otherwise.
330  */
331     int
332 inc(pos_T *lp)
333 {
334     char_u  *p;
335 
336     /* when searching position may be set to end of a line */
337     if (lp->col != MAXCOL)
338     {
339 	p = ml_get_pos(lp);
340 	if (*p != NUL)	/* still within line, move to next char (may be NUL) */
341 	{
342 	    if (has_mbyte)
343 	    {
344 		int l = (*mb_ptr2len)(p);
345 
346 		lp->col += l;
347 		return ((p[l] != NUL) ? 0 : 2);
348 	    }
349 	    lp->col++;
350 	    lp->coladd = 0;
351 	    return ((p[1] != NUL) ? 0 : 2);
352 	}
353     }
354     if (lp->lnum != curbuf->b_ml.ml_line_count)     /* there is a next line */
355     {
356 	lp->col = 0;
357 	lp->lnum++;
358 	lp->coladd = 0;
359 	return 1;
360     }
361     return -1;
362 }
363 
364 /*
365  * incl(lp): same as inc(), but skip the NUL at the end of non-empty lines
366  */
367     int
368 incl(pos_T *lp)
369 {
370     int	    r;
371 
372     if ((r = inc(lp)) >= 1 && lp->col)
373 	r = inc(lp);
374     return r;
375 }
376 
377 /*
378  * dec(p)
379  *
380  * Decrement the line pointer 'p' crossing line boundaries as necessary.
381  * Return 1 when crossing a line, -1 when at start of file, 0 otherwise.
382  */
383     int
384 dec_cursor(void)
385 {
386     return dec(&curwin->w_cursor);
387 }
388 
389     int
390 dec(pos_T *lp)
391 {
392     char_u	*p;
393 
394     lp->coladd = 0;
395     if (lp->col == MAXCOL)
396     {
397 	/* past end of line */
398 	p = ml_get(lp->lnum);
399 	lp->col = (colnr_T)STRLEN(p);
400 	if (has_mbyte)
401 	    lp->col -= (*mb_head_off)(p, p + lp->col);
402 	return 0;
403     }
404 
405     if (lp->col > 0)
406     {
407 	/* still within line */
408 	lp->col--;
409 	if (has_mbyte)
410 	{
411 	    p = ml_get(lp->lnum);
412 	    lp->col -= (*mb_head_off)(p, p + lp->col);
413 	}
414 	return 0;
415     }
416 
417     if (lp->lnum > 1)
418     {
419 	/* there is a prior line */
420 	lp->lnum--;
421 	p = ml_get(lp->lnum);
422 	lp->col = (colnr_T)STRLEN(p);
423 	if (has_mbyte)
424 	    lp->col -= (*mb_head_off)(p, p + lp->col);
425 	return 1;
426     }
427 
428     /* at start of file */
429     return -1;
430 }
431 
432 /*
433  * decl(lp): same as dec(), but skip the NUL at the end of non-empty lines
434  */
435     int
436 decl(pos_T *lp)
437 {
438     int	    r;
439 
440     if ((r = dec(lp)) == 1 && lp->col)
441 	r = dec(lp);
442     return r;
443 }
444 
445 /*
446  * Get the line number relative to the current cursor position, i.e. the
447  * difference between line number and cursor position. Only look for lines that
448  * can be visible, folded lines don't count.
449  */
450     linenr_T
451 get_cursor_rel_lnum(
452     win_T	*wp,
453     linenr_T	lnum)		    /* line number to get the result for */
454 {
455     linenr_T	cursor = wp->w_cursor.lnum;
456     linenr_T	retval = 0;
457 
458 #ifdef FEAT_FOLDING
459     if (hasAnyFolding(wp))
460     {
461 	if (lnum > cursor)
462 	{
463 	    while (lnum > cursor)
464 	    {
465 		(void)hasFoldingWin(wp, lnum, &lnum, NULL, TRUE, NULL);
466 		/* if lnum and cursor are in the same fold,
467 		 * now lnum <= cursor */
468 		if (lnum > cursor)
469 		    retval++;
470 		lnum--;
471 	    }
472 	}
473 	else if (lnum < cursor)
474 	{
475 	    while (lnum < cursor)
476 	    {
477 		(void)hasFoldingWin(wp, lnum, NULL, &lnum, TRUE, NULL);
478 		/* if lnum and cursor are in the same fold,
479 		 * now lnum >= cursor */
480 		if (lnum < cursor)
481 		    retval--;
482 		lnum++;
483 	    }
484 	}
485 	/* else if (lnum == cursor)
486 	 *     retval = 0;
487 	 */
488     }
489     else
490 #endif
491 	retval = lnum - cursor;
492 
493     return retval;
494 }
495 
496 /*
497  * Make sure "pos.lnum" and "pos.col" are valid in "buf".
498  * This allows for the col to be on the NUL byte.
499  */
500     void
501 check_pos(buf_T *buf, pos_T *pos)
502 {
503     char_u *line;
504     colnr_T len;
505 
506     if (pos->lnum > buf->b_ml.ml_line_count)
507 	pos->lnum = buf->b_ml.ml_line_count;
508 
509     if (pos->col > 0)
510     {
511 	line = ml_get_buf(buf, pos->lnum, FALSE);
512 	len = (colnr_T)STRLEN(line);
513 	if (pos->col > len)
514 	    pos->col = len;
515     }
516 }
517 
518 /*
519  * Make sure curwin->w_cursor.lnum is valid.
520  */
521     void
522 check_cursor_lnum(void)
523 {
524     if (curwin->w_cursor.lnum > curbuf->b_ml.ml_line_count)
525     {
526 #ifdef FEAT_FOLDING
527 	/* If there is a closed fold at the end of the file, put the cursor in
528 	 * its first line.  Otherwise in the last line. */
529 	if (!hasFolding(curbuf->b_ml.ml_line_count,
530 						&curwin->w_cursor.lnum, NULL))
531 #endif
532 	    curwin->w_cursor.lnum = curbuf->b_ml.ml_line_count;
533     }
534     if (curwin->w_cursor.lnum <= 0)
535 	curwin->w_cursor.lnum = 1;
536 }
537 
538 /*
539  * Make sure curwin->w_cursor.col is valid.
540  */
541     void
542 check_cursor_col(void)
543 {
544     check_cursor_col_win(curwin);
545 }
546 
547 /*
548  * Make sure win->w_cursor.col is valid.
549  */
550     void
551 check_cursor_col_win(win_T *win)
552 {
553     colnr_T len;
554     colnr_T oldcol = win->w_cursor.col;
555     colnr_T oldcoladd = win->w_cursor.col + win->w_cursor.coladd;
556 
557     len = (colnr_T)STRLEN(ml_get_buf(win->w_buffer, win->w_cursor.lnum, FALSE));
558     if (len == 0)
559 	win->w_cursor.col = 0;
560     else if (win->w_cursor.col >= len)
561     {
562 	/* Allow cursor past end-of-line when:
563 	 * - in Insert mode or restarting Insert mode
564 	 * - in Visual mode and 'selection' isn't "old"
565 	 * - 'virtualedit' is set */
566 	if ((State & INSERT) || restart_edit
567 		|| (VIsual_active && *p_sel != 'o')
568 		|| (ve_flags & VE_ONEMORE)
569 		|| virtual_active())
570 	    win->w_cursor.col = len;
571 	else
572 	{
573 	    win->w_cursor.col = len - 1;
574 	    /* Move the cursor to the head byte. */
575 	    if (has_mbyte)
576 		mb_adjustpos(win->w_buffer, &win->w_cursor);
577 	}
578     }
579     else if (win->w_cursor.col < 0)
580 	win->w_cursor.col = 0;
581 
582     /* If virtual editing is on, we can leave the cursor on the old position,
583      * only we must set it to virtual.  But don't do it when at the end of the
584      * line. */
585     if (oldcol == MAXCOL)
586 	win->w_cursor.coladd = 0;
587     else if (ve_flags == VE_ALL)
588     {
589 	if (oldcoladd > win->w_cursor.col)
590 	{
591 	    win->w_cursor.coladd = oldcoladd - win->w_cursor.col;
592 
593 	    /* Make sure that coladd is not more than the char width.
594 	     * Not for the last character, coladd is then used when the cursor
595 	     * is actually after the last character. */
596 	    if (win->w_cursor.col + 1 < len && win->w_cursor.coladd > 0)
597 	    {
598 		int cs, ce;
599 
600 		getvcol(win, &win->w_cursor, &cs, NULL, &ce);
601 		if (win->w_cursor.coladd > ce - cs)
602 		    win->w_cursor.coladd = ce - cs;
603 	    }
604 	}
605 	else
606 	    /* avoid weird number when there is a miscalculation or overflow */
607 	    win->w_cursor.coladd = 0;
608     }
609 }
610 
611 /*
612  * make sure curwin->w_cursor in on a valid character
613  */
614     void
615 check_cursor(void)
616 {
617     check_cursor_lnum();
618     check_cursor_col();
619 }
620 
621 #if defined(FEAT_TEXTOBJ) || defined(PROTO)
622 /*
623  * Make sure curwin->w_cursor is not on the NUL at the end of the line.
624  * Allow it when in Visual mode and 'selection' is not "old".
625  */
626     void
627 adjust_cursor_col(void)
628 {
629     if (curwin->w_cursor.col > 0
630 	    && (!VIsual_active || *p_sel == 'o')
631 	    && gchar_cursor() == NUL)
632 	--curwin->w_cursor.col;
633 }
634 #endif
635 
636 /*
637  * When curwin->w_leftcol has changed, adjust the cursor position.
638  * Return TRUE if the cursor was moved.
639  */
640     int
641 leftcol_changed(void)
642 {
643     long	lastcol;
644     colnr_T	s, e;
645     int		retval = FALSE;
646     long        siso = get_sidescrolloff_value();
647 
648     changed_cline_bef_curs();
649     lastcol = curwin->w_leftcol + curwin->w_width - curwin_col_off() - 1;
650     validate_virtcol();
651 
652     /*
653      * If the cursor is right or left of the screen, move it to last or first
654      * character.
655      */
656     if (curwin->w_virtcol > (colnr_T)(lastcol - siso))
657     {
658 	retval = TRUE;
659 	coladvance((colnr_T)(lastcol - siso));
660     }
661     else if (curwin->w_virtcol < curwin->w_leftcol + siso)
662     {
663 	retval = TRUE;
664 	(void)coladvance((colnr_T)(curwin->w_leftcol + siso));
665     }
666 
667     /*
668      * If the start of the character under the cursor is not on the screen,
669      * advance the cursor one more char.  If this fails (last char of the
670      * line) adjust the scrolling.
671      */
672     getvvcol(curwin, &curwin->w_cursor, &s, NULL, &e);
673     if (e > (colnr_T)lastcol)
674     {
675 	retval = TRUE;
676 	coladvance(s - 1);
677     }
678     else if (s < curwin->w_leftcol)
679     {
680 	retval = TRUE;
681 	if (coladvance(e + 1) == FAIL)	/* there isn't another character */
682 	{
683 	    curwin->w_leftcol = s;	/* adjust w_leftcol instead */
684 	    changed_cline_bef_curs();
685 	}
686     }
687 
688     if (retval)
689 	curwin->w_set_curswant = TRUE;
690     redraw_later(NOT_VALID);
691     return retval;
692 }
693 
694 /**********************************************************************
695  * Various routines dealing with allocation and deallocation of memory.
696  */
697 
698 #if defined(MEM_PROFILE) || defined(PROTO)
699 
700 # define MEM_SIZES  8200
701 static long_u mem_allocs[MEM_SIZES];
702 static long_u mem_frees[MEM_SIZES];
703 static long_u mem_allocated;
704 static long_u mem_freed;
705 static long_u mem_peak;
706 static long_u num_alloc;
707 static long_u num_freed;
708 
709     static void
710 mem_pre_alloc_s(size_t *sizep)
711 {
712     *sizep += sizeof(size_t);
713 }
714 
715     static void
716 mem_pre_alloc_l(size_t *sizep)
717 {
718     *sizep += sizeof(size_t);
719 }
720 
721     static void
722 mem_post_alloc(
723     void **pp,
724     size_t size)
725 {
726     if (*pp == NULL)
727 	return;
728     size -= sizeof(size_t);
729     *(long_u *)*pp = size;
730     if (size <= MEM_SIZES-1)
731 	mem_allocs[size-1]++;
732     else
733 	mem_allocs[MEM_SIZES-1]++;
734     mem_allocated += size;
735     if (mem_allocated - mem_freed > mem_peak)
736 	mem_peak = mem_allocated - mem_freed;
737     num_alloc++;
738     *pp = (void *)((char *)*pp + sizeof(size_t));
739 }
740 
741     static void
742 mem_pre_free(void **pp)
743 {
744     long_u size;
745 
746     *pp = (void *)((char *)*pp - sizeof(size_t));
747     size = *(size_t *)*pp;
748     if (size <= MEM_SIZES-1)
749 	mem_frees[size-1]++;
750     else
751 	mem_frees[MEM_SIZES-1]++;
752     mem_freed += size;
753     num_freed++;
754 }
755 
756 /*
757  * called on exit via atexit()
758  */
759     void
760 vim_mem_profile_dump(void)
761 {
762     int i, j;
763 
764     printf("\r\n");
765     j = 0;
766     for (i = 0; i < MEM_SIZES - 1; i++)
767     {
768 	if (mem_allocs[i] || mem_frees[i])
769 	{
770 	    if (mem_frees[i] > mem_allocs[i])
771 		printf("\r\n%s", _("ERROR: "));
772 	    printf("[%4d / %4lu-%-4lu] ", i + 1, mem_allocs[i], mem_frees[i]);
773 	    j++;
774 	    if (j > 3)
775 	    {
776 		j = 0;
777 		printf("\r\n");
778 	    }
779 	}
780     }
781 
782     i = MEM_SIZES - 1;
783     if (mem_allocs[i])
784     {
785 	printf("\r\n");
786 	if (mem_frees[i] > mem_allocs[i])
787 	    puts(_("ERROR: "));
788 	printf("[>%d / %4lu-%-4lu]", i, mem_allocs[i], mem_frees[i]);
789     }
790 
791     printf(_("\n[bytes] total alloc-freed %lu-%lu, in use %lu, peak use %lu\n"),
792 	    mem_allocated, mem_freed, mem_allocated - mem_freed, mem_peak);
793     printf(_("[calls] total re/malloc()'s %lu, total free()'s %lu\n\n"),
794 	    num_alloc, num_freed);
795 }
796 
797 #endif /* MEM_PROFILE */
798 
799 #ifdef FEAT_EVAL
800     int
801 alloc_does_fail(size_t size)
802 {
803     if (alloc_fail_countdown == 0)
804     {
805 	if (--alloc_fail_repeat <= 0)
806 	    alloc_fail_id = 0;
807 	do_outofmem_msg(size);
808 	return TRUE;
809     }
810     --alloc_fail_countdown;
811     return FALSE;
812 }
813 #endif
814 
815 /*
816  * Some memory is reserved for error messages and for being able to
817  * call mf_release_all(), which needs some memory for mf_trans_add().
818  */
819 #define KEEP_ROOM (2 * 8192L)
820 #define KEEP_ROOM_KB (KEEP_ROOM / 1024L)
821 
822 /*
823  * The normal way to allocate memory.  This handles an out-of-memory situation
824  * as well as possible, still returns NULL when we're completely out.
825  */
826     void *
827 alloc(size_t size)
828 {
829     return lalloc(size, TRUE);
830 }
831 
832 /*
833  * alloc() with an ID for alloc_fail().
834  */
835     void *
836 alloc_id(size_t size, alloc_id_T id UNUSED)
837 {
838 #ifdef FEAT_EVAL
839     if (alloc_fail_id == id && alloc_does_fail(size))
840 	return NULL;
841 #endif
842     return lalloc(size, TRUE);
843 }
844 
845 /*
846  * Allocate memory and set all bytes to zero.
847  */
848     void *
849 alloc_clear(size_t size)
850 {
851     void *p;
852 
853     p = lalloc(size, TRUE);
854     if (p != NULL)
855 	(void)vim_memset(p, 0, size);
856     return p;
857 }
858 
859 /*
860  * Same as alloc_clear() but with allocation id for testing
861  */
862     void *
863 alloc_clear_id(size_t size, alloc_id_T id UNUSED)
864 {
865 #ifdef FEAT_EVAL
866     if (alloc_fail_id == id && alloc_does_fail(size))
867 	return NULL;
868 #endif
869     return alloc_clear(size);
870 }
871 
872 /*
873  * Allocate memory like lalloc() and set all bytes to zero.
874  */
875     void *
876 lalloc_clear(size_t size, int message)
877 {
878     void *p;
879 
880     p = lalloc(size, message);
881     if (p != NULL)
882 	(void)vim_memset(p, 0, size);
883     return p;
884 }
885 
886 /*
887  * Low level memory allocation function.
888  * This is used often, KEEP IT FAST!
889  */
890     void *
891 lalloc(size_t size, int message)
892 {
893     void	*p;		    /* pointer to new storage space */
894     static int	releasing = FALSE;  /* don't do mf_release_all() recursive */
895     int		try_again;
896 #if defined(HAVE_AVAIL_MEM)
897     static size_t allocated = 0;    /* allocated since last avail check */
898 #endif
899 
900     // Safety check for allocating zero bytes
901     if (size == 0)
902     {
903 	// Don't hide this message
904 	emsg_silent = 0;
905 	iemsg(_("E341: Internal error: lalloc(0, )"));
906 	return NULL;
907     }
908 
909 #ifdef MEM_PROFILE
910     mem_pre_alloc_l(&size);
911 #endif
912 
913     /*
914      * Loop when out of memory: Try to release some memfile blocks and
915      * if some blocks are released call malloc again.
916      */
917     for (;;)
918     {
919 	/*
920 	 * Handle three kind of systems:
921 	 * 1. No check for available memory: Just return.
922 	 * 2. Slow check for available memory: call mch_avail_mem() after
923 	 *    allocating KEEP_ROOM amount of memory.
924 	 * 3. Strict check for available memory: call mch_avail_mem()
925 	 */
926 	if ((p = malloc(size)) != NULL)
927 	{
928 #ifndef HAVE_AVAIL_MEM
929 	    /* 1. No check for available memory: Just return. */
930 	    goto theend;
931 #else
932 	    /* 2. Slow check for available memory: call mch_avail_mem() after
933 	     *    allocating (KEEP_ROOM / 2) amount of memory. */
934 	    allocated += size;
935 	    if (allocated < KEEP_ROOM / 2)
936 		goto theend;
937 	    allocated = 0;
938 
939 	    /* 3. check for available memory: call mch_avail_mem() */
940 	    if (mch_avail_mem(TRUE) < KEEP_ROOM_KB && !releasing)
941 	    {
942 		free(p);	/* System is low... no go! */
943 		p = NULL;
944 	    }
945 	    else
946 		goto theend;
947 #endif
948 	}
949 	/*
950 	 * Remember that mf_release_all() is being called to avoid an endless
951 	 * loop, because mf_release_all() may call alloc() recursively.
952 	 */
953 	if (releasing)
954 	    break;
955 	releasing = TRUE;
956 
957 	clear_sb_text(TRUE);	      /* free any scrollback text */
958 	try_again = mf_release_all(); /* release as many blocks as possible */
959 
960 	releasing = FALSE;
961 	if (!try_again)
962 	    break;
963     }
964 
965     if (message && p == NULL)
966 	do_outofmem_msg(size);
967 
968 theend:
969 #ifdef MEM_PROFILE
970     mem_post_alloc(&p, size);
971 #endif
972     return p;
973 }
974 
975 /*
976  * lalloc() with an ID for alloc_fail().
977  */
978 #if defined(FEAT_SIGNS) || defined(PROTO)
979     void *
980 lalloc_id(size_t size, int message, alloc_id_T id UNUSED)
981 {
982 #ifdef FEAT_EVAL
983     if (alloc_fail_id == id && alloc_does_fail(size))
984 	return NULL;
985 #endif
986     return (lalloc(size, message));
987 }
988 #endif
989 
990 #if defined(MEM_PROFILE) || defined(PROTO)
991 /*
992  * realloc() with memory profiling.
993  */
994     void *
995 mem_realloc(void *ptr, size_t size)
996 {
997     void *p;
998 
999     mem_pre_free(&ptr);
1000     mem_pre_alloc_s(&size);
1001 
1002     p = realloc(ptr, size);
1003 
1004     mem_post_alloc(&p, size);
1005 
1006     return p;
1007 }
1008 #endif
1009 
1010 /*
1011 * Avoid repeating the error message many times (they take 1 second each).
1012 * Did_outofmem_msg is reset when a character is read.
1013 */
1014     void
1015 do_outofmem_msg(size_t size)
1016 {
1017     if (!did_outofmem_msg)
1018     {
1019 	// Don't hide this message
1020 	emsg_silent = 0;
1021 
1022 	// Must come first to avoid coming back here when printing the error
1023 	// message fails, e.g. when setting v:errmsg.
1024 	did_outofmem_msg = TRUE;
1025 
1026 	semsg(_("E342: Out of memory!  (allocating %lu bytes)"), (long_u)size);
1027 
1028 	if (starting == NO_SCREEN)
1029 	    // Not even finished with initializations and already out of
1030 	    // memory?  Then nothing is going to work, exit.
1031 	    mch_exit(123);
1032     }
1033 }
1034 
1035 #if defined(EXITFREE) || defined(PROTO)
1036 
1037 /*
1038  * Free everything that we allocated.
1039  * Can be used to detect memory leaks, e.g., with ccmalloc.
1040  * NOTE: This is tricky!  Things are freed that functions depend on.  Don't be
1041  * surprised if Vim crashes...
1042  * Some things can't be freed, esp. things local to a library function.
1043  */
1044     void
1045 free_all_mem(void)
1046 {
1047     buf_T	*buf, *nextbuf;
1048 
1049     /* When we cause a crash here it is caught and Vim tries to exit cleanly.
1050      * Don't try freeing everything again. */
1051     if (entered_free_all_mem)
1052 	return;
1053     entered_free_all_mem = TRUE;
1054 
1055     /* Don't want to trigger autocommands from here on. */
1056     block_autocmds();
1057 
1058     /* Close all tabs and windows.  Reset 'equalalways' to avoid redraws. */
1059     p_ea = FALSE;
1060     if (first_tabpage != NULL && first_tabpage->tp_next != NULL)
1061 	do_cmdline_cmd((char_u *)"tabonly!");
1062     if (!ONE_WINDOW)
1063 	do_cmdline_cmd((char_u *)"only!");
1064 
1065 # if defined(FEAT_SPELL)
1066     /* Free all spell info. */
1067     spell_free_all();
1068 # endif
1069 
1070 # if defined(FEAT_BEVAL_TERM)
1071     ui_remove_balloon();
1072 # endif
1073 
1074     // Clear user commands (before deleting buffers).
1075     ex_comclear(NULL);
1076 
1077     // When exiting from mainerr_arg_missing curbuf has not been initialized,
1078     // and not much else.
1079     if (curbuf != NULL)
1080     {
1081 # ifdef FEAT_MENU
1082 	// Clear menus.
1083 	do_cmdline_cmd((char_u *)"aunmenu *");
1084 #  ifdef FEAT_MULTI_LANG
1085 	do_cmdline_cmd((char_u *)"menutranslate clear");
1086 #  endif
1087 # endif
1088 	// Clear mappings, abbreviations, breakpoints.
1089 	do_cmdline_cmd((char_u *)"lmapclear");
1090 	do_cmdline_cmd((char_u *)"xmapclear");
1091 	do_cmdline_cmd((char_u *)"mapclear");
1092 	do_cmdline_cmd((char_u *)"mapclear!");
1093 	do_cmdline_cmd((char_u *)"abclear");
1094 # if defined(FEAT_EVAL)
1095 	do_cmdline_cmd((char_u *)"breakdel *");
1096 # endif
1097 # if defined(FEAT_PROFILE)
1098 	do_cmdline_cmd((char_u *)"profdel *");
1099 # endif
1100 # if defined(FEAT_KEYMAP)
1101 	do_cmdline_cmd((char_u *)"set keymap=");
1102 # endif
1103     }
1104 
1105 # ifdef FEAT_TITLE
1106     free_titles();
1107 # endif
1108 # if defined(FEAT_SEARCHPATH)
1109     free_findfile();
1110 # endif
1111 
1112     /* Obviously named calls. */
1113     free_all_autocmds();
1114     clear_termcodes();
1115     free_all_marks();
1116     alist_clear(&global_alist);
1117     free_homedir();
1118     free_users();
1119     free_search_patterns();
1120     free_old_sub();
1121     free_last_insert();
1122     free_insexpand_stuff();
1123     free_prev_shellcmd();
1124     free_regexp_stuff();
1125     free_tag_stuff();
1126     free_cd_dir();
1127 # ifdef FEAT_SIGNS
1128     free_signs();
1129 # endif
1130 # ifdef FEAT_EVAL
1131     set_expr_line(NULL);
1132 # endif
1133 # ifdef FEAT_DIFF
1134     if (curtab != NULL)
1135 	diff_clear(curtab);
1136 # endif
1137     clear_sb_text(TRUE);	      /* free any scrollback text */
1138 
1139     /* Free some global vars. */
1140     vim_free(username);
1141 # ifdef FEAT_CLIPBOARD
1142     vim_regfree(clip_exclude_prog);
1143 # endif
1144     vim_free(last_cmdline);
1145     vim_free(new_last_cmdline);
1146     set_keep_msg(NULL, 0);
1147 
1148     /* Clear cmdline history. */
1149     p_hi = 0;
1150     init_history();
1151 # ifdef FEAT_TEXT_PROP
1152     clear_global_prop_types();
1153 # endif
1154 
1155 # ifdef FEAT_QUICKFIX
1156     {
1157 	win_T	    *win;
1158 	tabpage_T   *tab;
1159 
1160 	qf_free_all(NULL);
1161 	// Free all location lists
1162 	FOR_ALL_TAB_WINDOWS(tab, win)
1163 	    qf_free_all(win);
1164     }
1165 # endif
1166 
1167     // Close all script inputs.
1168     close_all_scripts();
1169 
1170     if (curwin != NULL)
1171 	// Destroy all windows.  Must come before freeing buffers.
1172 	win_free_all();
1173 
1174     /* Free all option values.  Must come after closing windows. */
1175     free_all_options();
1176 
1177     /* Free all buffers.  Reset 'autochdir' to avoid accessing things that
1178      * were freed already. */
1179 # ifdef FEAT_AUTOCHDIR
1180     p_acd = FALSE;
1181 # endif
1182     for (buf = firstbuf; buf != NULL; )
1183     {
1184 	bufref_T    bufref;
1185 
1186 	set_bufref(&bufref, buf);
1187 	nextbuf = buf->b_next;
1188 	close_buffer(NULL, buf, DOBUF_WIPE, FALSE);
1189 	if (bufref_valid(&bufref))
1190 	    buf = nextbuf;	/* didn't work, try next one */
1191 	else
1192 	    buf = firstbuf;
1193     }
1194 
1195 # ifdef FEAT_ARABIC
1196     free_arshape_buf();
1197 # endif
1198 
1199     /* Clear registers. */
1200     clear_registers();
1201     ResetRedobuff();
1202     ResetRedobuff();
1203 
1204 # if defined(FEAT_CLIENTSERVER) && defined(FEAT_X11)
1205     vim_free(serverDelayedStartName);
1206 # endif
1207 
1208     /* highlight info */
1209     free_highlight();
1210 
1211     reset_last_sourcing();
1212 
1213     if (first_tabpage != NULL)
1214     {
1215 	free_tabpage(first_tabpage);
1216 	first_tabpage = NULL;
1217     }
1218 
1219 # ifdef UNIX
1220     /* Machine-specific free. */
1221     mch_free_mem();
1222 # endif
1223 
1224     /* message history */
1225     for (;;)
1226 	if (delete_first_msg() == FAIL)
1227 	    break;
1228 
1229 # ifdef FEAT_JOB_CHANNEL
1230     channel_free_all();
1231 # endif
1232 # ifdef FEAT_TIMERS
1233     timer_free_all();
1234 # endif
1235 # ifdef FEAT_EVAL
1236     /* must be after channel_free_all() with unrefs partials */
1237     eval_clear();
1238 # endif
1239 # ifdef FEAT_JOB_CHANNEL
1240     /* must be after eval_clear() with unrefs jobs */
1241     job_free_all();
1242 # endif
1243 
1244     free_termoptions();
1245 
1246     /* screenlines (can't display anything now!) */
1247     free_screenlines();
1248 
1249 # if defined(FEAT_SOUND)
1250     sound_free();
1251 # endif
1252 # if defined(USE_XSMP)
1253     xsmp_close();
1254 # endif
1255 # ifdef FEAT_GUI_GTK
1256     gui_mch_free_all();
1257 # endif
1258     clear_hl_tables();
1259 
1260     vim_free(IObuff);
1261     vim_free(NameBuff);
1262 # ifdef FEAT_QUICKFIX
1263     check_quickfix_busy();
1264 # endif
1265 }
1266 #endif
1267 
1268 /*
1269  * Copy "string" into newly allocated memory.
1270  */
1271     char_u *
1272 vim_strsave(char_u *string)
1273 {
1274     char_u	*p;
1275     size_t	len;
1276 
1277     len = STRLEN(string) + 1;
1278     p = alloc(len);
1279     if (p != NULL)
1280 	mch_memmove(p, string, len);
1281     return p;
1282 }
1283 
1284 /*
1285  * Copy up to "len" bytes of "string" into newly allocated memory and
1286  * terminate with a NUL.
1287  * The allocated memory always has size "len + 1", also when "string" is
1288  * shorter.
1289  */
1290     char_u *
1291 vim_strnsave(char_u *string, int len)
1292 {
1293     char_u	*p;
1294 
1295     p = alloc(len + 1);
1296     if (p != NULL)
1297     {
1298 	STRNCPY(p, string, len);
1299 	p[len] = NUL;
1300     }
1301     return p;
1302 }
1303 
1304 /*
1305  * Copy "p[len]" into allocated memory, ignoring NUL characters.
1306  * Returns NULL when out of memory.
1307  */
1308     char_u *
1309 vim_memsave(char_u *p, size_t len)
1310 {
1311     char_u *ret = alloc(len);
1312 
1313     if (ret != NULL)
1314 	mch_memmove(ret, p, len);
1315     return ret;
1316 }
1317 
1318 /*
1319  * Same as vim_strsave(), but any characters found in esc_chars are preceded
1320  * by a backslash.
1321  */
1322     char_u *
1323 vim_strsave_escaped(char_u *string, char_u *esc_chars)
1324 {
1325     return vim_strsave_escaped_ext(string, esc_chars, '\\', FALSE);
1326 }
1327 
1328 /*
1329  * Same as vim_strsave_escaped(), but when "bsl" is TRUE also escape
1330  * characters where rem_backslash() would remove the backslash.
1331  * Escape the characters with "cc".
1332  */
1333     char_u *
1334 vim_strsave_escaped_ext(
1335     char_u	*string,
1336     char_u	*esc_chars,
1337     int		cc,
1338     int		bsl)
1339 {
1340     char_u	*p;
1341     char_u	*p2;
1342     char_u	*escaped_string;
1343     unsigned	length;
1344     int		l;
1345 
1346     /*
1347      * First count the number of backslashes required.
1348      * Then allocate the memory and insert them.
1349      */
1350     length = 1;				/* count the trailing NUL */
1351     for (p = string; *p; p++)
1352     {
1353 	if (has_mbyte && (l = (*mb_ptr2len)(p)) > 1)
1354 	{
1355 	    length += l;		/* count a multibyte char */
1356 	    p += l - 1;
1357 	    continue;
1358 	}
1359 	if (vim_strchr(esc_chars, *p) != NULL || (bsl && rem_backslash(p)))
1360 	    ++length;			/* count a backslash */
1361 	++length;			/* count an ordinary char */
1362     }
1363     escaped_string = alloc(length);
1364     if (escaped_string != NULL)
1365     {
1366 	p2 = escaped_string;
1367 	for (p = string; *p; p++)
1368 	{
1369 	    if (has_mbyte && (l = (*mb_ptr2len)(p)) > 1)
1370 	    {
1371 		mch_memmove(p2, p, (size_t)l);
1372 		p2 += l;
1373 		p += l - 1;		/* skip multibyte char  */
1374 		continue;
1375 	    }
1376 	    if (vim_strchr(esc_chars, *p) != NULL || (bsl && rem_backslash(p)))
1377 		*p2++ = cc;
1378 	    *p2++ = *p;
1379 	}
1380 	*p2 = NUL;
1381     }
1382     return escaped_string;
1383 }
1384 
1385 /*
1386  * Return TRUE when 'shell' has "csh" in the tail.
1387  */
1388     int
1389 csh_like_shell(void)
1390 {
1391     return (strstr((char *)gettail(p_sh), "csh") != NULL);
1392 }
1393 
1394 /*
1395  * Escape "string" for use as a shell argument with system().
1396  * This uses single quotes, except when we know we need to use double quotes
1397  * (MS-DOS and MS-Windows without 'shellslash' set).
1398  * Escape a newline, depending on the 'shell' option.
1399  * When "do_special" is TRUE also replace "!", "%", "#" and things starting
1400  * with "<" like "<cfile>".
1401  * When "do_newline" is FALSE do not escape newline unless it is csh shell.
1402  * Returns the result in allocated memory, NULL if we have run out.
1403  */
1404     char_u *
1405 vim_strsave_shellescape(char_u *string, int do_special, int do_newline)
1406 {
1407     unsigned	length;
1408     char_u	*p;
1409     char_u	*d;
1410     char_u	*escaped_string;
1411     int		l;
1412     int		csh_like;
1413 
1414     /* Only csh and similar shells expand '!' within single quotes.  For sh and
1415      * the like we must not put a backslash before it, it will be taken
1416      * literally.  If do_special is set the '!' will be escaped twice.
1417      * Csh also needs to have "\n" escaped twice when do_special is set. */
1418     csh_like = csh_like_shell();
1419 
1420     /* First count the number of extra bytes required. */
1421     length = (unsigned)STRLEN(string) + 3;  /* two quotes and a trailing NUL */
1422     for (p = string; *p != NUL; MB_PTR_ADV(p))
1423     {
1424 # ifdef MSWIN
1425 	if (!p_ssl)
1426 	{
1427 	    if (*p == '"')
1428 		++length;		/* " -> "" */
1429 	}
1430 	else
1431 # endif
1432 	if (*p == '\'')
1433 	    length += 3;		/* ' => '\'' */
1434 	if ((*p == '\n' && (csh_like || do_newline))
1435 		|| (*p == '!' && (csh_like || do_special)))
1436 	{
1437 	    ++length;			/* insert backslash */
1438 	    if (csh_like && do_special)
1439 		++length;		/* insert backslash */
1440 	}
1441 	if (do_special && find_cmdline_var(p, &l) >= 0)
1442 	{
1443 	    ++length;			/* insert backslash */
1444 	    p += l - 1;
1445 	}
1446     }
1447 
1448     /* Allocate memory for the result and fill it. */
1449     escaped_string = alloc(length);
1450     if (escaped_string != NULL)
1451     {
1452 	d = escaped_string;
1453 
1454 	/* add opening quote */
1455 # ifdef MSWIN
1456 	if (!p_ssl)
1457 	    *d++ = '"';
1458 	else
1459 # endif
1460 	    *d++ = '\'';
1461 
1462 	for (p = string; *p != NUL; )
1463 	{
1464 # ifdef MSWIN
1465 	    if (!p_ssl)
1466 	    {
1467 		if (*p == '"')
1468 		{
1469 		    *d++ = '"';
1470 		    *d++ = '"';
1471 		    ++p;
1472 		    continue;
1473 		}
1474 	    }
1475 	    else
1476 # endif
1477 	    if (*p == '\'')
1478 	    {
1479 		*d++ = '\'';
1480 		*d++ = '\\';
1481 		*d++ = '\'';
1482 		*d++ = '\'';
1483 		++p;
1484 		continue;
1485 	    }
1486 	    if ((*p == '\n' && (csh_like || do_newline))
1487 		    || (*p == '!' && (csh_like || do_special)))
1488 	    {
1489 		*d++ = '\\';
1490 		if (csh_like && do_special)
1491 		    *d++ = '\\';
1492 		*d++ = *p++;
1493 		continue;
1494 	    }
1495 	    if (do_special && find_cmdline_var(p, &l) >= 0)
1496 	    {
1497 		*d++ = '\\';		/* insert backslash */
1498 		while (--l >= 0)	/* copy the var */
1499 		    *d++ = *p++;
1500 		continue;
1501 	    }
1502 
1503 	    MB_COPY_CHAR(p, d);
1504 	}
1505 
1506 	/* add terminating quote and finish with a NUL */
1507 # ifdef MSWIN
1508 	if (!p_ssl)
1509 	    *d++ = '"';
1510 	else
1511 # endif
1512 	    *d++ = '\'';
1513 	*d = NUL;
1514     }
1515 
1516     return escaped_string;
1517 }
1518 
1519 /*
1520  * Like vim_strsave(), but make all characters uppercase.
1521  * This uses ASCII lower-to-upper case translation, language independent.
1522  */
1523     char_u *
1524 vim_strsave_up(char_u *string)
1525 {
1526     char_u *p1;
1527 
1528     p1 = vim_strsave(string);
1529     vim_strup(p1);
1530     return p1;
1531 }
1532 
1533 /*
1534  * Like vim_strnsave(), but make all characters uppercase.
1535  * This uses ASCII lower-to-upper case translation, language independent.
1536  */
1537     char_u *
1538 vim_strnsave_up(char_u *string, int len)
1539 {
1540     char_u *p1;
1541 
1542     p1 = vim_strnsave(string, len);
1543     vim_strup(p1);
1544     return p1;
1545 }
1546 
1547 /*
1548  * ASCII lower-to-upper case translation, language independent.
1549  */
1550     void
1551 vim_strup(
1552     char_u	*p)
1553 {
1554     char_u  *p2;
1555     int	    c;
1556 
1557     if (p != NULL)
1558     {
1559 	p2 = p;
1560 	while ((c = *p2) != NUL)
1561 #ifdef EBCDIC
1562 	    *p2++ = isalpha(c) ? toupper(c) : c;
1563 #else
1564 	    *p2++ = (c < 'a' || c > 'z') ? c : (c - 0x20);
1565 #endif
1566     }
1567 }
1568 
1569 #if defined(FEAT_EVAL) || defined(FEAT_SPELL) || defined(PROTO)
1570 /*
1571  * Make string "s" all upper-case and return it in allocated memory.
1572  * Handles multi-byte characters as well as possible.
1573  * Returns NULL when out of memory.
1574  */
1575     char_u *
1576 strup_save(char_u *orig)
1577 {
1578     char_u	*p;
1579     char_u	*res;
1580 
1581     res = p = vim_strsave(orig);
1582 
1583     if (res != NULL)
1584 	while (*p != NUL)
1585 	{
1586 	    int		l;
1587 
1588 	    if (enc_utf8)
1589 	    {
1590 		int	c, uc;
1591 		int	newl;
1592 		char_u	*s;
1593 
1594 		c = utf_ptr2char(p);
1595 		l = utf_ptr2len(p);
1596 		if (c == 0)
1597 		{
1598 		    /* overlong sequence, use only the first byte */
1599 		    c = *p;
1600 		    l = 1;
1601 		}
1602 		uc = utf_toupper(c);
1603 
1604 		/* Reallocate string when byte count changes.  This is rare,
1605 		 * thus it's OK to do another malloc()/free(). */
1606 		newl = utf_char2len(uc);
1607 		if (newl != l)
1608 		{
1609 		    s = alloc(STRLEN(res) + 1 + newl - l);
1610 		    if (s == NULL)
1611 		    {
1612 			vim_free(res);
1613 			return NULL;
1614 		    }
1615 		    mch_memmove(s, res, p - res);
1616 		    STRCPY(s + (p - res) + newl, p + l);
1617 		    p = s + (p - res);
1618 		    vim_free(res);
1619 		    res = s;
1620 		}
1621 
1622 		utf_char2bytes(uc, p);
1623 		p += newl;
1624 	    }
1625 	    else if (has_mbyte && (l = (*mb_ptr2len)(p)) > 1)
1626 		p += l;		/* skip multi-byte character */
1627 	    else
1628 	    {
1629 		*p = TOUPPER_LOC(*p); /* note that toupper() can be a macro */
1630 		p++;
1631 	    }
1632 	}
1633 
1634     return res;
1635 }
1636 
1637 /*
1638  * Make string "s" all lower-case and return it in allocated memory.
1639  * Handles multi-byte characters as well as possible.
1640  * Returns NULL when out of memory.
1641  */
1642     char_u *
1643 strlow_save(char_u *orig)
1644 {
1645     char_u	*p;
1646     char_u	*res;
1647 
1648     res = p = vim_strsave(orig);
1649 
1650     if (res != NULL)
1651 	while (*p != NUL)
1652 	{
1653 	    int		l;
1654 
1655 	    if (enc_utf8)
1656 	    {
1657 		int	c, lc;
1658 		int	newl;
1659 		char_u	*s;
1660 
1661 		c = utf_ptr2char(p);
1662 		l = utf_ptr2len(p);
1663 		if (c == 0)
1664 		{
1665 		    /* overlong sequence, use only the first byte */
1666 		    c = *p;
1667 		    l = 1;
1668 		}
1669 		lc = utf_tolower(c);
1670 
1671 		/* Reallocate string when byte count changes.  This is rare,
1672 		 * thus it's OK to do another malloc()/free(). */
1673 		newl = utf_char2len(lc);
1674 		if (newl != l)
1675 		{
1676 		    s = alloc(STRLEN(res) + 1 + newl - l);
1677 		    if (s == NULL)
1678 		    {
1679 			vim_free(res);
1680 			return NULL;
1681 		    }
1682 		    mch_memmove(s, res, p - res);
1683 		    STRCPY(s + (p - res) + newl, p + l);
1684 		    p = s + (p - res);
1685 		    vim_free(res);
1686 		    res = s;
1687 		}
1688 
1689 		utf_char2bytes(lc, p);
1690 		p += newl;
1691 	    }
1692 	    else if (has_mbyte && (l = (*mb_ptr2len)(p)) > 1)
1693 		p += l;		/* skip multi-byte character */
1694 	    else
1695 	    {
1696 		*p = TOLOWER_LOC(*p); /* note that tolower() can be a macro */
1697 		p++;
1698 	    }
1699 	}
1700 
1701     return res;
1702 }
1703 #endif
1704 
1705 /*
1706  * delete spaces at the end of a string
1707  */
1708     void
1709 del_trailing_spaces(char_u *ptr)
1710 {
1711     char_u	*q;
1712 
1713     q = ptr + STRLEN(ptr);
1714     while (--q > ptr && VIM_ISWHITE(q[0]) && q[-1] != '\\' && q[-1] != Ctrl_V)
1715 	*q = NUL;
1716 }
1717 
1718 /*
1719  * Like strncpy(), but always terminate the result with one NUL.
1720  * "to" must be "len + 1" long!
1721  */
1722     void
1723 vim_strncpy(char_u *to, char_u *from, size_t len)
1724 {
1725     STRNCPY(to, from, len);
1726     to[len] = NUL;
1727 }
1728 
1729 /*
1730  * Like strcat(), but make sure the result fits in "tosize" bytes and is
1731  * always NUL terminated. "from" and "to" may overlap.
1732  */
1733     void
1734 vim_strcat(char_u *to, char_u *from, size_t tosize)
1735 {
1736     size_t tolen = STRLEN(to);
1737     size_t fromlen = STRLEN(from);
1738 
1739     if (tolen + fromlen + 1 > tosize)
1740     {
1741 	mch_memmove(to + tolen, from, tosize - tolen - 1);
1742 	to[tosize - 1] = NUL;
1743     }
1744     else
1745 	mch_memmove(to + tolen, from, fromlen + 1);
1746 }
1747 
1748 /*
1749  * Isolate one part of a string option where parts are separated with
1750  * "sep_chars".
1751  * The part is copied into "buf[maxlen]".
1752  * "*option" is advanced to the next part.
1753  * The length is returned.
1754  */
1755     int
1756 copy_option_part(
1757     char_u	**option,
1758     char_u	*buf,
1759     int		maxlen,
1760     char	*sep_chars)
1761 {
1762     int	    len = 0;
1763     char_u  *p = *option;
1764 
1765     /* skip '.' at start of option part, for 'suffixes' */
1766     if (*p == '.')
1767 	buf[len++] = *p++;
1768     while (*p != NUL && vim_strchr((char_u *)sep_chars, *p) == NULL)
1769     {
1770 	/*
1771 	 * Skip backslash before a separator character and space.
1772 	 */
1773 	if (p[0] == '\\' && vim_strchr((char_u *)sep_chars, p[1]) != NULL)
1774 	    ++p;
1775 	if (len < maxlen - 1)
1776 	    buf[len++] = *p;
1777 	++p;
1778     }
1779     buf[len] = NUL;
1780 
1781     if (*p != NUL && *p != ',')	/* skip non-standard separator */
1782 	++p;
1783     p = skip_to_option_part(p);	/* p points to next file name */
1784 
1785     *option = p;
1786     return len;
1787 }
1788 
1789 /*
1790  * Replacement for free() that ignores NULL pointers.
1791  * Also skip free() when exiting for sure, this helps when we caught a deadly
1792  * signal that was caused by a crash in free().
1793  * If you want to set NULL after calling this function, you should use
1794  * VIM_CLEAR() instead.
1795  */
1796     void
1797 vim_free(void *x)
1798 {
1799     if (x != NULL && !really_exiting)
1800     {
1801 #ifdef MEM_PROFILE
1802 	mem_pre_free(&x);
1803 #endif
1804 	free(x);
1805     }
1806 }
1807 
1808 #ifndef HAVE_MEMSET
1809     void *
1810 vim_memset(void *ptr, int c, size_t size)
1811 {
1812     char *p = ptr;
1813 
1814     while (size-- > 0)
1815 	*p++ = c;
1816     return ptr;
1817 }
1818 #endif
1819 
1820 #if (!defined(HAVE_STRCASECMP) && !defined(HAVE_STRICMP)) || defined(PROTO)
1821 /*
1822  * Compare two strings, ignoring case, using current locale.
1823  * Doesn't work for multi-byte characters.
1824  * return 0 for match, < 0 for smaller, > 0 for bigger
1825  */
1826     int
1827 vim_stricmp(char *s1, char *s2)
1828 {
1829     int		i;
1830 
1831     for (;;)
1832     {
1833 	i = (int)TOLOWER_LOC(*s1) - (int)TOLOWER_LOC(*s2);
1834 	if (i != 0)
1835 	    return i;			    /* this character different */
1836 	if (*s1 == NUL)
1837 	    break;			    /* strings match until NUL */
1838 	++s1;
1839 	++s2;
1840     }
1841     return 0;				    /* strings match */
1842 }
1843 #endif
1844 
1845 #if (!defined(HAVE_STRNCASECMP) && !defined(HAVE_STRNICMP)) || defined(PROTO)
1846 /*
1847  * Compare two strings, for length "len", ignoring case, using current locale.
1848  * Doesn't work for multi-byte characters.
1849  * return 0 for match, < 0 for smaller, > 0 for bigger
1850  */
1851     int
1852 vim_strnicmp(char *s1, char *s2, size_t len)
1853 {
1854     int		i;
1855 
1856     while (len > 0)
1857     {
1858 	i = (int)TOLOWER_LOC(*s1) - (int)TOLOWER_LOC(*s2);
1859 	if (i != 0)
1860 	    return i;			    /* this character different */
1861 	if (*s1 == NUL)
1862 	    break;			    /* strings match until NUL */
1863 	++s1;
1864 	++s2;
1865 	--len;
1866     }
1867     return 0;				    /* strings match */
1868 }
1869 #endif
1870 
1871 /*
1872  * Version of strchr() and strrchr() that handle unsigned char strings
1873  * with characters from 128 to 255 correctly.  It also doesn't return a
1874  * pointer to the NUL at the end of the string.
1875  */
1876     char_u  *
1877 vim_strchr(char_u *string, int c)
1878 {
1879     char_u	*p;
1880     int		b;
1881 
1882     p = string;
1883     if (enc_utf8 && c >= 0x80)
1884     {
1885 	while (*p != NUL)
1886 	{
1887 	    int l = utfc_ptr2len(p);
1888 
1889 	    /* Avoid matching an illegal byte here. */
1890 	    if (utf_ptr2char(p) == c && l > 1)
1891 		return p;
1892 	    p += l;
1893 	}
1894 	return NULL;
1895     }
1896     if (enc_dbcs != 0 && c > 255)
1897     {
1898 	int	n2 = c & 0xff;
1899 
1900 	c = ((unsigned)c >> 8) & 0xff;
1901 	while ((b = *p) != NUL)
1902 	{
1903 	    if (b == c && p[1] == n2)
1904 		return p;
1905 	    p += (*mb_ptr2len)(p);
1906 	}
1907 	return NULL;
1908     }
1909     if (has_mbyte)
1910     {
1911 	while ((b = *p) != NUL)
1912 	{
1913 	    if (b == c)
1914 		return p;
1915 	    p += (*mb_ptr2len)(p);
1916 	}
1917 	return NULL;
1918     }
1919     while ((b = *p) != NUL)
1920     {
1921 	if (b == c)
1922 	    return p;
1923 	++p;
1924     }
1925     return NULL;
1926 }
1927 
1928 /*
1929  * Version of strchr() that only works for bytes and handles unsigned char
1930  * strings with characters above 128 correctly. It also doesn't return a
1931  * pointer to the NUL at the end of the string.
1932  */
1933     char_u  *
1934 vim_strbyte(char_u *string, int c)
1935 {
1936     char_u	*p = string;
1937 
1938     while (*p != NUL)
1939     {
1940 	if (*p == c)
1941 	    return p;
1942 	++p;
1943     }
1944     return NULL;
1945 }
1946 
1947 /*
1948  * Search for last occurrence of "c" in "string".
1949  * Return NULL if not found.
1950  * Does not handle multi-byte char for "c"!
1951  */
1952     char_u  *
1953 vim_strrchr(char_u *string, int c)
1954 {
1955     char_u	*retval = NULL;
1956     char_u	*p = string;
1957 
1958     while (*p)
1959     {
1960 	if (*p == c)
1961 	    retval = p;
1962 	MB_PTR_ADV(p);
1963     }
1964     return retval;
1965 }
1966 
1967 /*
1968  * Vim's version of strpbrk(), in case it's missing.
1969  * Don't generate a prototype for this, causes problems when it's not used.
1970  */
1971 #ifndef PROTO
1972 # ifndef HAVE_STRPBRK
1973 #  ifdef vim_strpbrk
1974 #   undef vim_strpbrk
1975 #  endif
1976     char_u *
1977 vim_strpbrk(char_u *s, char_u *charset)
1978 {
1979     while (*s)
1980     {
1981 	if (vim_strchr(charset, *s) != NULL)
1982 	    return s;
1983 	MB_PTR_ADV(s);
1984     }
1985     return NULL;
1986 }
1987 # endif
1988 #endif
1989 
1990 /*
1991  * Vim has its own isspace() function, because on some machines isspace()
1992  * can't handle characters above 128.
1993  */
1994     int
1995 vim_isspace(int x)
1996 {
1997     return ((x >= 9 && x <= 13) || x == ' ');
1998 }
1999 
2000 /************************************************************************
2001  * Functions for handling growing arrays.
2002  */
2003 
2004 /*
2005  * Clear an allocated growing array.
2006  */
2007     void
2008 ga_clear(garray_T *gap)
2009 {
2010     vim_free(gap->ga_data);
2011     ga_init(gap);
2012 }
2013 
2014 /*
2015  * Clear a growing array that contains a list of strings.
2016  */
2017     void
2018 ga_clear_strings(garray_T *gap)
2019 {
2020     int		i;
2021 
2022     for (i = 0; i < gap->ga_len; ++i)
2023 	vim_free(((char_u **)(gap->ga_data))[i]);
2024     ga_clear(gap);
2025 }
2026 
2027 /*
2028  * Initialize a growing array.	Don't forget to set ga_itemsize and
2029  * ga_growsize!  Or use ga_init2().
2030  */
2031     void
2032 ga_init(garray_T *gap)
2033 {
2034     gap->ga_data = NULL;
2035     gap->ga_maxlen = 0;
2036     gap->ga_len = 0;
2037 }
2038 
2039     void
2040 ga_init2(garray_T *gap, int itemsize, int growsize)
2041 {
2042     ga_init(gap);
2043     gap->ga_itemsize = itemsize;
2044     gap->ga_growsize = growsize;
2045 }
2046 
2047 /*
2048  * Make room in growing array "gap" for at least "n" items.
2049  * Return FAIL for failure, OK otherwise.
2050  */
2051     int
2052 ga_grow(garray_T *gap, int n)
2053 {
2054     size_t	old_len;
2055     size_t	new_len;
2056     char_u	*pp;
2057 
2058     if (gap->ga_maxlen - gap->ga_len < n)
2059     {
2060 	if (n < gap->ga_growsize)
2061 	    n = gap->ga_growsize;
2062 
2063 	// A linear growth is very inefficient when the array grows big.  This
2064 	// is a compromise between allocating memory that won't be used and too
2065 	// many copy operations. A factor of 1.5 seems reasonable.
2066 	if (n < gap->ga_len / 2)
2067 	    n = gap->ga_len / 2;
2068 
2069 	new_len = gap->ga_itemsize * (gap->ga_len + n);
2070 	pp = vim_realloc(gap->ga_data, new_len);
2071 	if (pp == NULL)
2072 	    return FAIL;
2073 	old_len = gap->ga_itemsize * gap->ga_maxlen;
2074 	vim_memset(pp + old_len, 0, new_len - old_len);
2075 	gap->ga_maxlen = gap->ga_len + n;
2076 	gap->ga_data = pp;
2077     }
2078     return OK;
2079 }
2080 
2081 #if defined(FEAT_EVAL) || defined(FEAT_SEARCHPATH) || defined(PROTO)
2082 /*
2083  * For a growing array that contains a list of strings: concatenate all the
2084  * strings with a separating "sep".
2085  * Returns NULL when out of memory.
2086  */
2087     char_u *
2088 ga_concat_strings(garray_T *gap, char *sep)
2089 {
2090     int		i;
2091     int		len = 0;
2092     int		sep_len = (int)STRLEN(sep);
2093     char_u	*s;
2094     char_u	*p;
2095 
2096     for (i = 0; i < gap->ga_len; ++i)
2097 	len += (int)STRLEN(((char_u **)(gap->ga_data))[i]) + sep_len;
2098 
2099     s = alloc(len + 1);
2100     if (s != NULL)
2101     {
2102 	*s = NUL;
2103 	p = s;
2104 	for (i = 0; i < gap->ga_len; ++i)
2105 	{
2106 	    if (p != s)
2107 	    {
2108 		STRCPY(p, sep);
2109 		p += sep_len;
2110 	    }
2111 	    STRCPY(p, ((char_u **)(gap->ga_data))[i]);
2112 	    p += STRLEN(p);
2113 	}
2114     }
2115     return s;
2116 }
2117 #endif
2118 
2119 #if defined(FEAT_VIMINFO) || defined(FEAT_EVAL) || defined(PROTO)
2120 /*
2121  * Make a copy of string "p" and add it to "gap".
2122  * When out of memory nothing changes.
2123  */
2124     void
2125 ga_add_string(garray_T *gap, char_u *p)
2126 {
2127     char_u *cp = vim_strsave(p);
2128 
2129     if (cp != NULL)
2130     {
2131 	if (ga_grow(gap, 1) == OK)
2132 	    ((char_u **)(gap->ga_data))[gap->ga_len++] = cp;
2133 	else
2134 	    vim_free(cp);
2135     }
2136 }
2137 #endif
2138 
2139 /*
2140  * Concatenate a string to a growarray which contains bytes.
2141  * When "s" is NULL does not do anything.
2142  * Note: Does NOT copy the NUL at the end!
2143  */
2144     void
2145 ga_concat(garray_T *gap, char_u *s)
2146 {
2147     int    len;
2148 
2149     if (s == NULL || *s == NUL)
2150 	return;
2151     len = (int)STRLEN(s);
2152     if (ga_grow(gap, len) == OK)
2153     {
2154 	mch_memmove((char *)gap->ga_data + gap->ga_len, s, (size_t)len);
2155 	gap->ga_len += len;
2156     }
2157 }
2158 
2159 /*
2160  * Append one byte to a growarray which contains bytes.
2161  */
2162     void
2163 ga_append(garray_T *gap, int c)
2164 {
2165     if (ga_grow(gap, 1) == OK)
2166     {
2167 	*((char *)gap->ga_data + gap->ga_len) = c;
2168 	++gap->ga_len;
2169     }
2170 }
2171 
2172 #if (defined(UNIX) && !defined(USE_SYSTEM)) || defined(MSWIN) \
2173 	|| defined(PROTO)
2174 /*
2175  * Append the text in "gap" below the cursor line and clear "gap".
2176  */
2177     void
2178 append_ga_line(garray_T *gap)
2179 {
2180     /* Remove trailing CR. */
2181     if (gap->ga_len > 0
2182 	    && !curbuf->b_p_bin
2183 	    && ((char_u *)gap->ga_data)[gap->ga_len - 1] == CAR)
2184 	--gap->ga_len;
2185     ga_append(gap, NUL);
2186     ml_append(curwin->w_cursor.lnum++, gap->ga_data, 0, FALSE);
2187     gap->ga_len = 0;
2188 }
2189 #endif
2190 
2191 /************************************************************************
2192  * functions that use lookup tables for various things, generally to do with
2193  * special key codes.
2194  */
2195 
2196 /*
2197  * Some useful tables.
2198  */
2199 
2200 static struct modmasktable
2201 {
2202     short	mod_mask;	/* Bit-mask for particular key modifier */
2203     short	mod_flag;	/* Bit(s) for particular key modifier */
2204     char_u	name;		/* Single letter name of modifier */
2205 } mod_mask_table[] =
2206 {
2207     {MOD_MASK_ALT,		MOD_MASK_ALT,		(char_u)'M'},
2208     {MOD_MASK_META,		MOD_MASK_META,		(char_u)'T'},
2209     {MOD_MASK_CTRL,		MOD_MASK_CTRL,		(char_u)'C'},
2210     {MOD_MASK_SHIFT,		MOD_MASK_SHIFT,		(char_u)'S'},
2211     {MOD_MASK_MULTI_CLICK,	MOD_MASK_2CLICK,	(char_u)'2'},
2212     {MOD_MASK_MULTI_CLICK,	MOD_MASK_3CLICK,	(char_u)'3'},
2213     {MOD_MASK_MULTI_CLICK,	MOD_MASK_4CLICK,	(char_u)'4'},
2214 #ifdef MACOS_X
2215     {MOD_MASK_CMD,		MOD_MASK_CMD,		(char_u)'D'},
2216 #endif
2217     /* 'A' must be the last one */
2218     {MOD_MASK_ALT,		MOD_MASK_ALT,		(char_u)'A'},
2219     {0, 0, NUL}
2220     /* NOTE: when adding an entry, update MAX_KEY_NAME_LEN! */
2221 };
2222 
2223 /*
2224  * Shifted key terminal codes and their unshifted equivalent.
2225  * Don't add mouse codes here, they are handled separately!
2226  */
2227 #define MOD_KEYS_ENTRY_SIZE 5
2228 
2229 static char_u modifier_keys_table[] =
2230 {
2231 /*  mod mask	    with modifier		without modifier */
2232     MOD_MASK_SHIFT, '&', '9',			'@', '1',	/* begin */
2233     MOD_MASK_SHIFT, '&', '0',			'@', '2',	/* cancel */
2234     MOD_MASK_SHIFT, '*', '1',			'@', '4',	/* command */
2235     MOD_MASK_SHIFT, '*', '2',			'@', '5',	/* copy */
2236     MOD_MASK_SHIFT, '*', '3',			'@', '6',	/* create */
2237     MOD_MASK_SHIFT, '*', '4',			'k', 'D',	/* delete char */
2238     MOD_MASK_SHIFT, '*', '5',			'k', 'L',	/* delete line */
2239     MOD_MASK_SHIFT, '*', '7',			'@', '7',	/* end */
2240     MOD_MASK_CTRL,  KS_EXTRA, (int)KE_C_END,	'@', '7',	/* end */
2241     MOD_MASK_SHIFT, '*', '9',			'@', '9',	/* exit */
2242     MOD_MASK_SHIFT, '*', '0',			'@', '0',	/* find */
2243     MOD_MASK_SHIFT, '#', '1',			'%', '1',	/* help */
2244     MOD_MASK_SHIFT, '#', '2',			'k', 'h',	/* home */
2245     MOD_MASK_CTRL,  KS_EXTRA, (int)KE_C_HOME,	'k', 'h',	/* home */
2246     MOD_MASK_SHIFT, '#', '3',			'k', 'I',	/* insert */
2247     MOD_MASK_SHIFT, '#', '4',			'k', 'l',	/* left arrow */
2248     MOD_MASK_CTRL,  KS_EXTRA, (int)KE_C_LEFT,	'k', 'l',	/* left arrow */
2249     MOD_MASK_SHIFT, '%', 'a',			'%', '3',	/* message */
2250     MOD_MASK_SHIFT, '%', 'b',			'%', '4',	/* move */
2251     MOD_MASK_SHIFT, '%', 'c',			'%', '5',	/* next */
2252     MOD_MASK_SHIFT, '%', 'd',			'%', '7',	/* options */
2253     MOD_MASK_SHIFT, '%', 'e',			'%', '8',	/* previous */
2254     MOD_MASK_SHIFT, '%', 'f',			'%', '9',	/* print */
2255     MOD_MASK_SHIFT, '%', 'g',			'%', '0',	/* redo */
2256     MOD_MASK_SHIFT, '%', 'h',			'&', '3',	/* replace */
2257     MOD_MASK_SHIFT, '%', 'i',			'k', 'r',	/* right arr. */
2258     MOD_MASK_CTRL,  KS_EXTRA, (int)KE_C_RIGHT,	'k', 'r',	/* right arr. */
2259     MOD_MASK_SHIFT, '%', 'j',			'&', '5',	/* resume */
2260     MOD_MASK_SHIFT, '!', '1',			'&', '6',	/* save */
2261     MOD_MASK_SHIFT, '!', '2',			'&', '7',	/* suspend */
2262     MOD_MASK_SHIFT, '!', '3',			'&', '8',	/* undo */
2263     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_UP,	'k', 'u',	/* up arrow */
2264     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_DOWN,	'k', 'd',	/* down arrow */
2265 
2266 								/* vt100 F1 */
2267     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_XF1,	KS_EXTRA, (int)KE_XF1,
2268     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_XF2,	KS_EXTRA, (int)KE_XF2,
2269     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_XF3,	KS_EXTRA, (int)KE_XF3,
2270     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_XF4,	KS_EXTRA, (int)KE_XF4,
2271 
2272     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F1,	'k', '1',	/* F1 */
2273     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F2,	'k', '2',
2274     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F3,	'k', '3',
2275     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F4,	'k', '4',
2276     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F5,	'k', '5',
2277     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F6,	'k', '6',
2278     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F7,	'k', '7',
2279     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F8,	'k', '8',
2280     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F9,	'k', '9',
2281     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F10,	'k', ';',	/* F10 */
2282 
2283     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F11,	'F', '1',
2284     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F12,	'F', '2',
2285     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F13,	'F', '3',
2286     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F14,	'F', '4',
2287     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F15,	'F', '5',
2288     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F16,	'F', '6',
2289     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F17,	'F', '7',
2290     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F18,	'F', '8',
2291     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F19,	'F', '9',
2292     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F20,	'F', 'A',
2293 
2294     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F21,	'F', 'B',
2295     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F22,	'F', 'C',
2296     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F23,	'F', 'D',
2297     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F24,	'F', 'E',
2298     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F25,	'F', 'F',
2299     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F26,	'F', 'G',
2300     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F27,	'F', 'H',
2301     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F28,	'F', 'I',
2302     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F29,	'F', 'J',
2303     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F30,	'F', 'K',
2304 
2305     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F31,	'F', 'L',
2306     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F32,	'F', 'M',
2307     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F33,	'F', 'N',
2308     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F34,	'F', 'O',
2309     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F35,	'F', 'P',
2310     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F36,	'F', 'Q',
2311     MOD_MASK_SHIFT, KS_EXTRA, (int)KE_S_F37,	'F', 'R',
2312 
2313 							    /* TAB pseudo code*/
2314     MOD_MASK_SHIFT, 'k', 'B',			KS_EXTRA, (int)KE_TAB,
2315 
2316     NUL
2317 };
2318 
2319 static struct key_name_entry
2320 {
2321     int	    key;	/* Special key code or ascii value */
2322     char_u  *name;	/* Name of key */
2323 } key_names_table[] =
2324 {
2325     {' ',		(char_u *)"Space"},
2326     {TAB,		(char_u *)"Tab"},
2327     {K_TAB,		(char_u *)"Tab"},
2328     {NL,		(char_u *)"NL"},
2329     {NL,		(char_u *)"NewLine"},	/* Alternative name */
2330     {NL,		(char_u *)"LineFeed"},	/* Alternative name */
2331     {NL,		(char_u *)"LF"},	/* Alternative name */
2332     {CAR,		(char_u *)"CR"},
2333     {CAR,		(char_u *)"Return"},	/* Alternative name */
2334     {CAR,		(char_u *)"Enter"},	/* Alternative name */
2335     {K_BS,		(char_u *)"BS"},
2336     {K_BS,		(char_u *)"BackSpace"},	/* Alternative name */
2337     {ESC,		(char_u *)"Esc"},
2338     {CSI,		(char_u *)"CSI"},
2339     {K_CSI,		(char_u *)"xCSI"},
2340     {'|',		(char_u *)"Bar"},
2341     {'\\',		(char_u *)"Bslash"},
2342     {K_DEL,		(char_u *)"Del"},
2343     {K_DEL,		(char_u *)"Delete"},	/* Alternative name */
2344     {K_KDEL,		(char_u *)"kDel"},
2345     {K_UP,		(char_u *)"Up"},
2346     {K_DOWN,		(char_u *)"Down"},
2347     {K_LEFT,		(char_u *)"Left"},
2348     {K_RIGHT,		(char_u *)"Right"},
2349     {K_XUP,		(char_u *)"xUp"},
2350     {K_XDOWN,		(char_u *)"xDown"},
2351     {K_XLEFT,		(char_u *)"xLeft"},
2352     {K_XRIGHT,		(char_u *)"xRight"},
2353     {K_PS,		(char_u *)"PasteStart"},
2354     {K_PE,		(char_u *)"PasteEnd"},
2355 
2356     {K_F1,		(char_u *)"F1"},
2357     {K_F2,		(char_u *)"F2"},
2358     {K_F3,		(char_u *)"F3"},
2359     {K_F4,		(char_u *)"F4"},
2360     {K_F5,		(char_u *)"F5"},
2361     {K_F6,		(char_u *)"F6"},
2362     {K_F7,		(char_u *)"F7"},
2363     {K_F8,		(char_u *)"F8"},
2364     {K_F9,		(char_u *)"F9"},
2365     {K_F10,		(char_u *)"F10"},
2366 
2367     {K_F11,		(char_u *)"F11"},
2368     {K_F12,		(char_u *)"F12"},
2369     {K_F13,		(char_u *)"F13"},
2370     {K_F14,		(char_u *)"F14"},
2371     {K_F15,		(char_u *)"F15"},
2372     {K_F16,		(char_u *)"F16"},
2373     {K_F17,		(char_u *)"F17"},
2374     {K_F18,		(char_u *)"F18"},
2375     {K_F19,		(char_u *)"F19"},
2376     {K_F20,		(char_u *)"F20"},
2377 
2378     {K_F21,		(char_u *)"F21"},
2379     {K_F22,		(char_u *)"F22"},
2380     {K_F23,		(char_u *)"F23"},
2381     {K_F24,		(char_u *)"F24"},
2382     {K_F25,		(char_u *)"F25"},
2383     {K_F26,		(char_u *)"F26"},
2384     {K_F27,		(char_u *)"F27"},
2385     {K_F28,		(char_u *)"F28"},
2386     {K_F29,		(char_u *)"F29"},
2387     {K_F30,		(char_u *)"F30"},
2388 
2389     {K_F31,		(char_u *)"F31"},
2390     {K_F32,		(char_u *)"F32"},
2391     {K_F33,		(char_u *)"F33"},
2392     {K_F34,		(char_u *)"F34"},
2393     {K_F35,		(char_u *)"F35"},
2394     {K_F36,		(char_u *)"F36"},
2395     {K_F37,		(char_u *)"F37"},
2396 
2397     {K_XF1,		(char_u *)"xF1"},
2398     {K_XF2,		(char_u *)"xF2"},
2399     {K_XF3,		(char_u *)"xF3"},
2400     {K_XF4,		(char_u *)"xF4"},
2401 
2402     {K_HELP,		(char_u *)"Help"},
2403     {K_UNDO,		(char_u *)"Undo"},
2404     {K_INS,		(char_u *)"Insert"},
2405     {K_INS,		(char_u *)"Ins"},	/* Alternative name */
2406     {K_KINS,		(char_u *)"kInsert"},
2407     {K_HOME,		(char_u *)"Home"},
2408     {K_KHOME,		(char_u *)"kHome"},
2409     {K_XHOME,		(char_u *)"xHome"},
2410     {K_ZHOME,		(char_u *)"zHome"},
2411     {K_END,		(char_u *)"End"},
2412     {K_KEND,		(char_u *)"kEnd"},
2413     {K_XEND,		(char_u *)"xEnd"},
2414     {K_ZEND,		(char_u *)"zEnd"},
2415     {K_PAGEUP,		(char_u *)"PageUp"},
2416     {K_PAGEDOWN,	(char_u *)"PageDown"},
2417     {K_KPAGEUP,		(char_u *)"kPageUp"},
2418     {K_KPAGEDOWN,	(char_u *)"kPageDown"},
2419 
2420     {K_KPLUS,		(char_u *)"kPlus"},
2421     {K_KMINUS,		(char_u *)"kMinus"},
2422     {K_KDIVIDE,		(char_u *)"kDivide"},
2423     {K_KMULTIPLY,	(char_u *)"kMultiply"},
2424     {K_KENTER,		(char_u *)"kEnter"},
2425     {K_KPOINT,		(char_u *)"kPoint"},
2426 
2427     {K_K0,		(char_u *)"k0"},
2428     {K_K1,		(char_u *)"k1"},
2429     {K_K2,		(char_u *)"k2"},
2430     {K_K3,		(char_u *)"k3"},
2431     {K_K4,		(char_u *)"k4"},
2432     {K_K5,		(char_u *)"k5"},
2433     {K_K6,		(char_u *)"k6"},
2434     {K_K7,		(char_u *)"k7"},
2435     {K_K8,		(char_u *)"k8"},
2436     {K_K9,		(char_u *)"k9"},
2437 
2438     {'<',		(char_u *)"lt"},
2439 
2440     {K_MOUSE,		(char_u *)"Mouse"},
2441 #ifdef FEAT_MOUSE_NET
2442     {K_NETTERM_MOUSE,	(char_u *)"NetMouse"},
2443 #endif
2444 #ifdef FEAT_MOUSE_DEC
2445     {K_DEC_MOUSE,	(char_u *)"DecMouse"},
2446 #endif
2447 #ifdef FEAT_MOUSE_JSB
2448     {K_JSBTERM_MOUSE,	(char_u *)"JsbMouse"},
2449 #endif
2450 #ifdef FEAT_MOUSE_PTERM
2451     {K_PTERM_MOUSE,	(char_u *)"PtermMouse"},
2452 #endif
2453 #ifdef FEAT_MOUSE_URXVT
2454     {K_URXVT_MOUSE,	(char_u *)"UrxvtMouse"},
2455 #endif
2456     {K_SGR_MOUSE,	(char_u *)"SgrMouse"},
2457     {K_SGR_MOUSERELEASE, (char_u *)"SgrMouseRelelase"},
2458     {K_LEFTMOUSE,	(char_u *)"LeftMouse"},
2459     {K_LEFTMOUSE_NM,	(char_u *)"LeftMouseNM"},
2460     {K_LEFTDRAG,	(char_u *)"LeftDrag"},
2461     {K_LEFTRELEASE,	(char_u *)"LeftRelease"},
2462     {K_LEFTRELEASE_NM,	(char_u *)"LeftReleaseNM"},
2463     {K_MOUSEMOVE,	(char_u *)"MouseMove"},
2464     {K_MIDDLEMOUSE,	(char_u *)"MiddleMouse"},
2465     {K_MIDDLEDRAG,	(char_u *)"MiddleDrag"},
2466     {K_MIDDLERELEASE,	(char_u *)"MiddleRelease"},
2467     {K_RIGHTMOUSE,	(char_u *)"RightMouse"},
2468     {K_RIGHTDRAG,	(char_u *)"RightDrag"},
2469     {K_RIGHTRELEASE,	(char_u *)"RightRelease"},
2470     {K_MOUSEDOWN,	(char_u *)"ScrollWheelUp"},
2471     {K_MOUSEUP,		(char_u *)"ScrollWheelDown"},
2472     {K_MOUSELEFT,	(char_u *)"ScrollWheelRight"},
2473     {K_MOUSERIGHT,	(char_u *)"ScrollWheelLeft"},
2474     {K_MOUSEDOWN,	(char_u *)"MouseDown"}, /* OBSOLETE: Use	  */
2475     {K_MOUSEUP,		(char_u *)"MouseUp"},	/* ScrollWheelXXX instead */
2476     {K_X1MOUSE,		(char_u *)"X1Mouse"},
2477     {K_X1DRAG,		(char_u *)"X1Drag"},
2478     {K_X1RELEASE,		(char_u *)"X1Release"},
2479     {K_X2MOUSE,		(char_u *)"X2Mouse"},
2480     {K_X2DRAG,		(char_u *)"X2Drag"},
2481     {K_X2RELEASE,		(char_u *)"X2Release"},
2482     {K_DROP,		(char_u *)"Drop"},
2483     {K_ZERO,		(char_u *)"Nul"},
2484 #ifdef FEAT_EVAL
2485     {K_SNR,		(char_u *)"SNR"},
2486 #endif
2487     {K_PLUG,		(char_u *)"Plug"},
2488     {K_CURSORHOLD,	(char_u *)"CursorHold"},
2489     {K_IGNORE,		(char_u *)"Ignore"},
2490     {0,			NULL}
2491     /* NOTE: When adding a long name update MAX_KEY_NAME_LEN. */
2492 };
2493 
2494 #define KEY_NAMES_TABLE_LEN (sizeof(key_names_table) / sizeof(struct key_name_entry))
2495 
2496 /*
2497  * Return the modifier mask bit (MOD_MASK_*) which corresponds to the given
2498  * modifier name ('S' for Shift, 'C' for Ctrl etc).
2499  */
2500     static int
2501 name_to_mod_mask(int c)
2502 {
2503     int	    i;
2504 
2505     c = TOUPPER_ASC(c);
2506     for (i = 0; mod_mask_table[i].mod_mask != 0; i++)
2507 	if (c == mod_mask_table[i].name)
2508 	    return mod_mask_table[i].mod_flag;
2509     return 0;
2510 }
2511 
2512 /*
2513  * Check if if there is a special key code for "key" that includes the
2514  * modifiers specified.
2515  */
2516     int
2517 simplify_key(int key, int *modifiers)
2518 {
2519     int	    i;
2520     int	    key0;
2521     int	    key1;
2522 
2523     if (*modifiers & (MOD_MASK_SHIFT | MOD_MASK_CTRL | MOD_MASK_ALT))
2524     {
2525 	/* TAB is a special case */
2526 	if (key == TAB && (*modifiers & MOD_MASK_SHIFT))
2527 	{
2528 	    *modifiers &= ~MOD_MASK_SHIFT;
2529 	    return K_S_TAB;
2530 	}
2531 	key0 = KEY2TERMCAP0(key);
2532 	key1 = KEY2TERMCAP1(key);
2533 	for (i = 0; modifier_keys_table[i] != NUL; i += MOD_KEYS_ENTRY_SIZE)
2534 	    if (key0 == modifier_keys_table[i + 3]
2535 		    && key1 == modifier_keys_table[i + 4]
2536 		    && (*modifiers & modifier_keys_table[i]))
2537 	    {
2538 		*modifiers &= ~modifier_keys_table[i];
2539 		return TERMCAP2KEY(modifier_keys_table[i + 1],
2540 						   modifier_keys_table[i + 2]);
2541 	    }
2542     }
2543     return key;
2544 }
2545 
2546 /*
2547  * Change <xHome> to <Home>, <xUp> to <Up>, etc.
2548  */
2549     int
2550 handle_x_keys(int key)
2551 {
2552     switch (key)
2553     {
2554 	case K_XUP:	return K_UP;
2555 	case K_XDOWN:	return K_DOWN;
2556 	case K_XLEFT:	return K_LEFT;
2557 	case K_XRIGHT:	return K_RIGHT;
2558 	case K_XHOME:	return K_HOME;
2559 	case K_ZHOME:	return K_HOME;
2560 	case K_XEND:	return K_END;
2561 	case K_ZEND:	return K_END;
2562 	case K_XF1:	return K_F1;
2563 	case K_XF2:	return K_F2;
2564 	case K_XF3:	return K_F3;
2565 	case K_XF4:	return K_F4;
2566 	case K_S_XF1:	return K_S_F1;
2567 	case K_S_XF2:	return K_S_F2;
2568 	case K_S_XF3:	return K_S_F3;
2569 	case K_S_XF4:	return K_S_F4;
2570     }
2571     return key;
2572 }
2573 
2574 /*
2575  * Return a string which contains the name of the given key when the given
2576  * modifiers are down.
2577  */
2578     char_u *
2579 get_special_key_name(int c, int modifiers)
2580 {
2581     static char_u string[MAX_KEY_NAME_LEN + 1];
2582 
2583     int	    i, idx;
2584     int	    table_idx;
2585     char_u  *s;
2586 
2587     string[0] = '<';
2588     idx = 1;
2589 
2590     /* Key that stands for a normal character. */
2591     if (IS_SPECIAL(c) && KEY2TERMCAP0(c) == KS_KEY)
2592 	c = KEY2TERMCAP1(c);
2593 
2594     /*
2595      * Translate shifted special keys into unshifted keys and set modifier.
2596      * Same for CTRL and ALT modifiers.
2597      */
2598     if (IS_SPECIAL(c))
2599     {
2600 	for (i = 0; modifier_keys_table[i] != 0; i += MOD_KEYS_ENTRY_SIZE)
2601 	    if (       KEY2TERMCAP0(c) == (int)modifier_keys_table[i + 1]
2602 		    && (int)KEY2TERMCAP1(c) == (int)modifier_keys_table[i + 2])
2603 	    {
2604 		modifiers |= modifier_keys_table[i];
2605 		c = TERMCAP2KEY(modifier_keys_table[i + 3],
2606 						   modifier_keys_table[i + 4]);
2607 		break;
2608 	    }
2609     }
2610 
2611     /* try to find the key in the special key table */
2612     table_idx = find_special_key_in_table(c);
2613 
2614     /*
2615      * When not a known special key, and not a printable character, try to
2616      * extract modifiers.
2617      */
2618     if (c > 0 && (*mb_char2len)(c) == 1)
2619     {
2620 	if (table_idx < 0
2621 		&& (!vim_isprintc(c) || (c & 0x7f) == ' ')
2622 		&& (c & 0x80))
2623 	{
2624 	    c &= 0x7f;
2625 	    modifiers |= MOD_MASK_ALT;
2626 	    /* try again, to find the un-alted key in the special key table */
2627 	    table_idx = find_special_key_in_table(c);
2628 	}
2629 	if (table_idx < 0 && !vim_isprintc(c) && c < ' ')
2630 	{
2631 #ifdef EBCDIC
2632 	    c = CtrlChar(c);
2633 #else
2634 	    c += '@';
2635 #endif
2636 	    modifiers |= MOD_MASK_CTRL;
2637 	}
2638     }
2639 
2640     /* translate the modifier into a string */
2641     for (i = 0; mod_mask_table[i].name != 'A'; i++)
2642 	if ((modifiers & mod_mask_table[i].mod_mask)
2643 						== mod_mask_table[i].mod_flag)
2644 	{
2645 	    string[idx++] = mod_mask_table[i].name;
2646 	    string[idx++] = (char_u)'-';
2647 	}
2648 
2649     if (table_idx < 0)		/* unknown special key, may output t_xx */
2650     {
2651 	if (IS_SPECIAL(c))
2652 	{
2653 	    string[idx++] = 't';
2654 	    string[idx++] = '_';
2655 	    string[idx++] = KEY2TERMCAP0(c);
2656 	    string[idx++] = KEY2TERMCAP1(c);
2657 	}
2658 	/* Not a special key, only modifiers, output directly */
2659 	else
2660 	{
2661 	    if (has_mbyte && (*mb_char2len)(c) > 1)
2662 		idx += (*mb_char2bytes)(c, string + idx);
2663 	    else if (vim_isprintc(c))
2664 		string[idx++] = c;
2665 	    else
2666 	    {
2667 		s = transchar(c);
2668 		while (*s)
2669 		    string[idx++] = *s++;
2670 	    }
2671 	}
2672     }
2673     else		/* use name of special key */
2674     {
2675 	size_t len = STRLEN(key_names_table[table_idx].name);
2676 
2677 	if (len + idx + 2 <= MAX_KEY_NAME_LEN)
2678 	{
2679 	    STRCPY(string + idx, key_names_table[table_idx].name);
2680 	    idx += (int)len;
2681 	}
2682     }
2683     string[idx++] = '>';
2684     string[idx] = NUL;
2685     return string;
2686 }
2687 
2688 /*
2689  * Try translating a <> name at (*srcp)[] to dst[].
2690  * Return the number of characters added to dst[], zero for no match.
2691  * If there is a match, srcp is advanced to after the <> name.
2692  * dst[] must be big enough to hold the result (up to six characters)!
2693  */
2694     int
2695 trans_special(
2696     char_u	**srcp,
2697     char_u	*dst,
2698     int		keycode,    // prefer key code, e.g. K_DEL instead of DEL
2699     int		in_string,  // TRUE when inside a double quoted string
2700     int		simplify,	// simplify <C-H> and <A-x>
2701     int		*did_simplify)  // found <C-H> or <A-x>
2702 {
2703     int		modifiers = 0;
2704     int		key;
2705 
2706     key = find_special_key(srcp, &modifiers, keycode, FALSE, in_string,
2707 						       simplify, did_simplify);
2708     if (key == 0)
2709 	return 0;
2710 
2711     return special_to_buf(key, modifiers, keycode, dst);
2712 }
2713 
2714 /*
2715  * Put the character sequence for "key" with "modifiers" into "dst" and return
2716  * the resulting length.
2717  * When "keycode" is TRUE prefer key code, e.g. K_DEL instead of DEL.
2718  * The sequence is not NUL terminated.
2719  * This is how characters in a string are encoded.
2720  */
2721     int
2722 special_to_buf(int key, int modifiers, int keycode, char_u *dst)
2723 {
2724     int		dlen = 0;
2725 
2726     /* Put the appropriate modifier in a string */
2727     if (modifiers != 0)
2728     {
2729 	dst[dlen++] = K_SPECIAL;
2730 	dst[dlen++] = KS_MODIFIER;
2731 	dst[dlen++] = modifiers;
2732     }
2733 
2734     if (IS_SPECIAL(key))
2735     {
2736 	dst[dlen++] = K_SPECIAL;
2737 	dst[dlen++] = KEY2TERMCAP0(key);
2738 	dst[dlen++] = KEY2TERMCAP1(key);
2739     }
2740     else if (has_mbyte && !keycode)
2741 	dlen += (*mb_char2bytes)(key, dst + dlen);
2742     else if (keycode)
2743 	dlen = (int)(add_char2buf(key, dst + dlen) - dst);
2744     else
2745 	dst[dlen++] = key;
2746 
2747     return dlen;
2748 }
2749 
2750 /*
2751  * Try translating a <> name at (*srcp)[], return the key and modifiers.
2752  * srcp is advanced to after the <> name.
2753  * returns 0 if there is no match.
2754  */
2755     int
2756 find_special_key(
2757     char_u	**srcp,
2758     int		*modp,
2759     int		keycode,	// prefer key code, e.g. K_DEL instead of DEL
2760     int		keep_x_key,	// don't translate xHome to Home key
2761     int		in_string,	// TRUE in string, double quote is escaped
2762     int		simplify,	// simplify <C-H> and <A-x>
2763     int		*did_simplify)  // found <C-H> or <A-x>
2764 {
2765     char_u	*last_dash;
2766     char_u	*end_of_name;
2767     char_u	*src;
2768     char_u	*bp;
2769     int		modifiers;
2770     int		bit;
2771     int		key;
2772     uvarnumber_T	n;
2773     int		l;
2774 
2775     src = *srcp;
2776     if (src[0] != '<')
2777 	return 0;
2778 
2779     /* Find end of modifier list */
2780     last_dash = src;
2781     for (bp = src + 1; *bp == '-' || vim_isIDc(*bp); bp++)
2782     {
2783 	if (*bp == '-')
2784 	{
2785 	    last_dash = bp;
2786 	    if (bp[1] != NUL)
2787 	    {
2788 		if (has_mbyte)
2789 		    l = mb_ptr2len(bp + 1);
2790 		else
2791 		    l = 1;
2792 		// Anything accepted, like <C-?>.
2793 		// <C-"> or <M-"> are not special in strings as " is
2794 		// the string delimiter. With a backslash it works: <M-\">
2795 		if (!(in_string && bp[1] == '"') && bp[l + 1] == '>')
2796 		    bp += l;
2797 		else if (in_string && bp[1] == '\\' && bp[2] == '"'
2798 							       && bp[3] == '>')
2799 		    bp += 2;
2800 	    }
2801 	}
2802 	if (bp[0] == 't' && bp[1] == '_' && bp[2] && bp[3])
2803 	    bp += 3;	/* skip t_xx, xx may be '-' or '>' */
2804 	else if (STRNICMP(bp, "char-", 5) == 0)
2805 	{
2806 	    vim_str2nr(bp + 5, NULL, &l, STR2NR_ALL, NULL, NULL, 0, TRUE);
2807 	    if (l == 0)
2808 	    {
2809 		emsg(_(e_invarg));
2810 		return 0;
2811 	    }
2812 	    bp += l + 5;
2813 	    break;
2814 	}
2815     }
2816 
2817     if (*bp == '>')	/* found matching '>' */
2818     {
2819 	end_of_name = bp + 1;
2820 
2821 	/* Which modifiers are given? */
2822 	modifiers = 0x0;
2823 	for (bp = src + 1; bp < last_dash; bp++)
2824 	{
2825 	    if (*bp != '-')
2826 	    {
2827 		bit = name_to_mod_mask(*bp);
2828 		if (bit == 0x0)
2829 		    break;	/* Illegal modifier name */
2830 		modifiers |= bit;
2831 	    }
2832 	}
2833 
2834 	/*
2835 	 * Legal modifier name.
2836 	 */
2837 	if (bp >= last_dash)
2838 	{
2839 	    if (STRNICMP(last_dash + 1, "char-", 5) == 0
2840 						 && VIM_ISDIGIT(last_dash[6]))
2841 	    {
2842 		/* <Char-123> or <Char-033> or <Char-0x33> */
2843 		vim_str2nr(last_dash + 6, NULL, &l, STR2NR_ALL, NULL,
2844 								  &n, 0, TRUE);
2845 		if (l == 0)
2846 		{
2847 		    emsg(_(e_invarg));
2848 		    return 0;
2849 		}
2850 		key = (int)n;
2851 	    }
2852 	    else
2853 	    {
2854 		int off = 1;
2855 
2856 		/* Modifier with single letter, or special key name.  */
2857 		if (in_string && last_dash[1] == '\\' && last_dash[2] == '"')
2858 		    off = 2;
2859 		if (has_mbyte)
2860 		    l = mb_ptr2len(last_dash + off);
2861 		else
2862 		    l = 1;
2863 		if (modifiers != 0 && last_dash[l + off] == '>')
2864 		    key = PTR2CHAR(last_dash + off);
2865 		else
2866 		{
2867 		    key = get_special_key_code(last_dash + off);
2868 		    if (!keep_x_key)
2869 			key = handle_x_keys(key);
2870 		}
2871 	    }
2872 
2873 	    /*
2874 	     * get_special_key_code() may return NUL for invalid
2875 	     * special key name.
2876 	     */
2877 	    if (key != NUL)
2878 	    {
2879 		/*
2880 		 * Only use a modifier when there is no special key code that
2881 		 * includes the modifier.
2882 		 */
2883 		key = simplify_key(key, &modifiers);
2884 
2885 		if (!keycode)
2886 		{
2887 		    /* don't want keycode, use single byte code */
2888 		    if (key == K_BS)
2889 			key = BS;
2890 		    else if (key == K_DEL || key == K_KDEL)
2891 			key = DEL;
2892 		}
2893 
2894 		// Normal Key with modifier: Try to make a single byte code.
2895 		if (!IS_SPECIAL(key))
2896 		    key = extract_modifiers(key, &modifiers,
2897 						       simplify, did_simplify);
2898 
2899 		*modp = modifiers;
2900 		*srcp = end_of_name;
2901 		return key;
2902 	    }
2903 	}
2904     }
2905     return 0;
2906 }
2907 
2908 /*
2909  * Try to include modifiers in the key.
2910  * Changes "Shift-a" to 'A', "Alt-A" to 0xc0, etc.
2911  * When "simplify" is FALSE don't do Ctrl and Alt.
2912  * When "simplify" is TRUE and Ctrl or Alt is removed from modifiers set
2913  * "did_simplify" when it's not NULL.
2914  */
2915     int
2916 extract_modifiers(int key, int *modp, int simplify, int *did_simplify)
2917 {
2918     int	modifiers = *modp;
2919 
2920 #ifdef MACOS_X
2921     // Command-key really special, no fancynest
2922     if (!(modifiers & MOD_MASK_CMD))
2923 #endif
2924     if ((modifiers & MOD_MASK_SHIFT) && ASCII_ISALPHA(key))
2925     {
2926 	key = TOUPPER_ASC(key);
2927 	// With <C-S-a> and <A-S-a> we keep the shift modifier.
2928 	// With <S-a> and <S-A> we don't keep the shift modifier.
2929 	if (simplify || modifiers == MOD_MASK_SHIFT)
2930 	    modifiers &= ~MOD_MASK_SHIFT;
2931     }
2932 
2933     // <C-H> and <C-h> mean the same thing, always use "H"
2934     if ((modifiers & MOD_MASK_CTRL) && ASCII_ISALPHA(key))
2935 	key = TOUPPER_ASC(key);
2936 
2937     if (simplify && (modifiers & MOD_MASK_CTRL)
2938 #ifdef EBCDIC
2939 	    // TODO: EBCDIC Better use:
2940 	    // && (Ctrl_chr(key) || key == '?')
2941 	    // ???
2942 	    && strchr("?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_", key)
2943 						       != NULL
2944 #else
2945 	    && ((key >= '?' && key <= '_') || ASCII_ISALPHA(key))
2946 #endif
2947 	    )
2948     {
2949 	key = Ctrl_chr(key);
2950 	modifiers &= ~MOD_MASK_CTRL;
2951 	/* <C-@> is <Nul> */
2952 	if (key == 0)
2953 	    key = K_ZERO;
2954 	if (did_simplify != NULL)
2955 	    *did_simplify = TRUE;
2956     }
2957 
2958 #ifdef MACOS_X
2959     /* Command-key really special, no fancynest */
2960     if (!(modifiers & MOD_MASK_CMD))
2961 #endif
2962     if (simplify && (modifiers & MOD_MASK_ALT) && key < 0x80
2963 	    && !enc_dbcs)		// avoid creating a lead byte
2964     {
2965 	key |= 0x80;
2966 	modifiers &= ~MOD_MASK_ALT;	/* remove the META modifier */
2967 	if (did_simplify != NULL)
2968 	    *did_simplify = TRUE;
2969     }
2970 
2971     *modp = modifiers;
2972     return key;
2973 }
2974 
2975 /*
2976  * Try to find key "c" in the special key table.
2977  * Return the index when found, -1 when not found.
2978  */
2979     int
2980 find_special_key_in_table(int c)
2981 {
2982     int	    i;
2983 
2984     for (i = 0; key_names_table[i].name != NULL; i++)
2985 	if (c == key_names_table[i].key)
2986 	    break;
2987     if (key_names_table[i].name == NULL)
2988 	i = -1;
2989     return i;
2990 }
2991 
2992 /*
2993  * Find the special key with the given name (the given string does not have to
2994  * end with NUL, the name is assumed to end before the first non-idchar).
2995  * If the name starts with "t_" the next two characters are interpreted as a
2996  * termcap name.
2997  * Return the key code, or 0 if not found.
2998  */
2999     int
3000 get_special_key_code(char_u *name)
3001 {
3002     char_u  *table_name;
3003     char_u  string[3];
3004     int	    i, j;
3005 
3006     /*
3007      * If it's <t_xx> we get the code for xx from the termcap
3008      */
3009     if (name[0] == 't' && name[1] == '_' && name[2] != NUL && name[3] != NUL)
3010     {
3011 	string[0] = name[2];
3012 	string[1] = name[3];
3013 	string[2] = NUL;
3014 	if (add_termcap_entry(string, FALSE) == OK)
3015 	    return TERMCAP2KEY(name[2], name[3]);
3016     }
3017     else
3018 	for (i = 0; key_names_table[i].name != NULL; i++)
3019 	{
3020 	    table_name = key_names_table[i].name;
3021 	    for (j = 0; vim_isIDc(name[j]) && table_name[j] != NUL; j++)
3022 		if (TOLOWER_ASC(table_name[j]) != TOLOWER_ASC(name[j]))
3023 		    break;
3024 	    if (!vim_isIDc(name[j]) && table_name[j] == NUL)
3025 		return key_names_table[i].key;
3026 	}
3027     return 0;
3028 }
3029 
3030     char_u *
3031 get_key_name(int i)
3032 {
3033     if (i >= (int)KEY_NAMES_TABLE_LEN)
3034 	return NULL;
3035     return  key_names_table[i].name;
3036 }
3037 
3038 /*
3039  * Return the current end-of-line type: EOL_DOS, EOL_UNIX or EOL_MAC.
3040  */
3041     int
3042 get_fileformat(buf_T *buf)
3043 {
3044     int		c = *buf->b_p_ff;
3045 
3046     if (buf->b_p_bin || c == 'u')
3047 	return EOL_UNIX;
3048     if (c == 'm')
3049 	return EOL_MAC;
3050     return EOL_DOS;
3051 }
3052 
3053 /*
3054  * Like get_fileformat(), but override 'fileformat' with "p" for "++opt=val"
3055  * argument.
3056  */
3057     int
3058 get_fileformat_force(
3059     buf_T	*buf,
3060     exarg_T	*eap)	    /* can be NULL! */
3061 {
3062     int		c;
3063 
3064     if (eap != NULL && eap->force_ff != 0)
3065 	c = eap->force_ff;
3066     else
3067     {
3068 	if ((eap != NULL && eap->force_bin != 0)
3069 			       ? (eap->force_bin == FORCE_BIN) : buf->b_p_bin)
3070 	    return EOL_UNIX;
3071 	c = *buf->b_p_ff;
3072     }
3073     if (c == 'u')
3074 	return EOL_UNIX;
3075     if (c == 'm')
3076 	return EOL_MAC;
3077     return EOL_DOS;
3078 }
3079 
3080 /*
3081  * Set the current end-of-line type to EOL_DOS, EOL_UNIX or EOL_MAC.
3082  * Sets both 'textmode' and 'fileformat'.
3083  * Note: Does _not_ set global value of 'textmode'!
3084  */
3085     void
3086 set_fileformat(
3087     int		t,
3088     int		opt_flags)	/* OPT_LOCAL and/or OPT_GLOBAL */
3089 {
3090     char	*p = NULL;
3091 
3092     switch (t)
3093     {
3094     case EOL_DOS:
3095 	p = FF_DOS;
3096 	curbuf->b_p_tx = TRUE;
3097 	break;
3098     case EOL_UNIX:
3099 	p = FF_UNIX;
3100 	curbuf->b_p_tx = FALSE;
3101 	break;
3102     case EOL_MAC:
3103 	p = FF_MAC;
3104 	curbuf->b_p_tx = FALSE;
3105 	break;
3106     }
3107     if (p != NULL)
3108 	set_string_option_direct((char_u *)"ff", -1, (char_u *)p,
3109 						     OPT_FREE | opt_flags, 0);
3110 
3111     /* This may cause the buffer to become (un)modified. */
3112     check_status(curbuf);
3113     redraw_tabline = TRUE;
3114 #ifdef FEAT_TITLE
3115     need_maketitle = TRUE;	    /* set window title later */
3116 #endif
3117 }
3118 
3119 /*
3120  * Return the default fileformat from 'fileformats'.
3121  */
3122     int
3123 default_fileformat(void)
3124 {
3125     switch (*p_ffs)
3126     {
3127 	case 'm':   return EOL_MAC;
3128 	case 'd':   return EOL_DOS;
3129     }
3130     return EOL_UNIX;
3131 }
3132 
3133 /*
3134  * Call shell.	Calls mch_call_shell, with 'shellxquote' added.
3135  */
3136     int
3137 call_shell(char_u *cmd, int opt)
3138 {
3139     char_u	*ncmd;
3140     int		retval;
3141 #ifdef FEAT_PROFILE
3142     proftime_T	wait_time;
3143 #endif
3144 
3145     if (p_verbose > 3)
3146     {
3147 	verbose_enter();
3148 	smsg(_("Calling shell to execute: \"%s\""),
3149 						    cmd == NULL ? p_sh : cmd);
3150 	out_char('\n');
3151 	cursor_on();
3152 	verbose_leave();
3153     }
3154 
3155 #ifdef FEAT_PROFILE
3156     if (do_profiling == PROF_YES)
3157 	prof_child_enter(&wait_time);
3158 #endif
3159 
3160     if (*p_sh == NUL)
3161     {
3162 	emsg(_(e_shellempty));
3163 	retval = -1;
3164     }
3165     else
3166     {
3167 #ifdef FEAT_GUI_MSWIN
3168 	/* Don't hide the pointer while executing a shell command. */
3169 	gui_mch_mousehide(FALSE);
3170 #endif
3171 #ifdef FEAT_GUI
3172 	++hold_gui_events;
3173 #endif
3174 	/* The external command may update a tags file, clear cached tags. */
3175 	tag_freematch();
3176 
3177 	if (cmd == NULL || *p_sxq == NUL)
3178 	    retval = mch_call_shell(cmd, opt);
3179 	else
3180 	{
3181 	    char_u *ecmd = cmd;
3182 
3183 	    if (*p_sxe != NUL && *p_sxq == '(')
3184 	    {
3185 		ecmd = vim_strsave_escaped_ext(cmd, p_sxe, '^', FALSE);
3186 		if (ecmd == NULL)
3187 		    ecmd = cmd;
3188 	    }
3189 	    ncmd = alloc(STRLEN(ecmd) + STRLEN(p_sxq) * 2 + 1);
3190 	    if (ncmd != NULL)
3191 	    {
3192 		STRCPY(ncmd, p_sxq);
3193 		STRCAT(ncmd, ecmd);
3194 		// When 'shellxquote' is ( append ).
3195 		// When 'shellxquote' is "( append )".
3196 		STRCAT(ncmd, *p_sxq == '(' ? (char_u *)")"
3197 		    : *p_sxq == '"' && *(p_sxq+1) == '(' ? (char_u *)")\""
3198 		    : p_sxq);
3199 		retval = mch_call_shell(ncmd, opt);
3200 		vim_free(ncmd);
3201 	    }
3202 	    else
3203 		retval = -1;
3204 	    if (ecmd != cmd)
3205 		vim_free(ecmd);
3206 	}
3207 #ifdef FEAT_GUI
3208 	--hold_gui_events;
3209 #endif
3210 	/*
3211 	 * Check the window size, in case it changed while executing the
3212 	 * external command.
3213 	 */
3214 	shell_resized_check();
3215     }
3216 
3217 #ifdef FEAT_EVAL
3218     set_vim_var_nr(VV_SHELL_ERROR, (long)retval);
3219 # ifdef FEAT_PROFILE
3220     if (do_profiling == PROF_YES)
3221 	prof_child_exit(&wait_time);
3222 # endif
3223 #endif
3224 
3225     return retval;
3226 }
3227 
3228 /*
3229  * VISUAL, SELECTMODE and OP_PENDING State are never set, they are equal to
3230  * NORMAL State with a condition.  This function returns the real State.
3231  */
3232     int
3233 get_real_state(void)
3234 {
3235     if (State & NORMAL)
3236     {
3237 	if (VIsual_active)
3238 	{
3239 	    if (VIsual_select)
3240 		return SELECTMODE;
3241 	    return VISUAL;
3242 	}
3243 	else if (finish_op)
3244 	    return OP_PENDING;
3245     }
3246     return State;
3247 }
3248 
3249 /*
3250  * Return TRUE if "p" points to just after a path separator.
3251  * Takes care of multi-byte characters.
3252  * "b" must point to the start of the file name
3253  */
3254     int
3255 after_pathsep(char_u *b, char_u *p)
3256 {
3257     return p > b && vim_ispathsep(p[-1])
3258 			     && (!has_mbyte || (*mb_head_off)(b, p - 1) == 0);
3259 }
3260 
3261 /*
3262  * Return TRUE if file names "f1" and "f2" are in the same directory.
3263  * "f1" may be a short name, "f2" must be a full path.
3264  */
3265     int
3266 same_directory(char_u *f1, char_u *f2)
3267 {
3268     char_u	ffname[MAXPATHL];
3269     char_u	*t1;
3270     char_u	*t2;
3271 
3272     /* safety check */
3273     if (f1 == NULL || f2 == NULL)
3274 	return FALSE;
3275 
3276     (void)vim_FullName(f1, ffname, MAXPATHL, FALSE);
3277     t1 = gettail_sep(ffname);
3278     t2 = gettail_sep(f2);
3279     return (t1 - ffname == t2 - f2
3280 	     && pathcmp((char *)ffname, (char *)f2, (int)(t1 - ffname)) == 0);
3281 }
3282 
3283 #if defined(FEAT_SESSION) || defined(FEAT_AUTOCHDIR) \
3284 	|| defined(MSWIN) || defined(FEAT_GUI_MAC) || defined(FEAT_GUI_GTK) \
3285 	|| defined(FEAT_NETBEANS_INTG) \
3286 	|| defined(PROTO)
3287 /*
3288  * Change to a file's directory.
3289  * Caller must call shorten_fnames()!
3290  * Return OK or FAIL.
3291  */
3292     int
3293 vim_chdirfile(char_u *fname, char *trigger_autocmd)
3294 {
3295     char_u	old_dir[MAXPATHL];
3296     char_u	new_dir[MAXPATHL];
3297     int		res;
3298 
3299     if (mch_dirname(old_dir, MAXPATHL) != OK)
3300 	*old_dir = NUL;
3301 
3302     vim_strncpy(new_dir, fname, MAXPATHL - 1);
3303     *gettail_sep(new_dir) = NUL;
3304 
3305     if (pathcmp((char *)old_dir, (char *)new_dir, -1) == 0)
3306 	// nothing to do
3307 	res = OK;
3308     else
3309     {
3310 	res = mch_chdir((char *)new_dir) == 0 ? OK : FAIL;
3311 
3312 	if (res == OK && trigger_autocmd != NULL)
3313 	    apply_autocmds(EVENT_DIRCHANGED, (char_u *)trigger_autocmd,
3314 						       new_dir, FALSE, curbuf);
3315     }
3316     return res;
3317 }
3318 #endif
3319 
3320 #if defined(STAT_IGNORES_SLASH) || defined(PROTO)
3321 /*
3322  * Check if "name" ends in a slash and is not a directory.
3323  * Used for systems where stat() ignores a trailing slash on a file name.
3324  * The Vim code assumes a trailing slash is only ignored for a directory.
3325  */
3326     static int
3327 illegal_slash(const char *name)
3328 {
3329     if (name[0] == NUL)
3330 	return FALSE;	    /* no file name is not illegal */
3331     if (name[strlen(name) - 1] != '/')
3332 	return FALSE;	    /* no trailing slash */
3333     if (mch_isdir((char_u *)name))
3334 	return FALSE;	    /* trailing slash for a directory */
3335     return TRUE;
3336 }
3337 
3338 /*
3339  * Special implementation of mch_stat() for Solaris.
3340  */
3341     int
3342 vim_stat(const char *name, stat_T *stp)
3343 {
3344     /* On Solaris stat() accepts "file/" as if it was "file".  Return -1 if
3345      * the name ends in "/" and it's not a directory. */
3346     return illegal_slash(name) ? -1 : stat(name, stp);
3347 }
3348 #endif
3349 
3350 #if defined(CURSOR_SHAPE) || defined(PROTO)
3351 
3352 /*
3353  * Handling of cursor and mouse pointer shapes in various modes.
3354  */
3355 
3356 cursorentry_T shape_table[SHAPE_IDX_COUNT] =
3357 {
3358     /* The values will be filled in from the 'guicursor' and 'mouseshape'
3359      * defaults when Vim starts.
3360      * Adjust the SHAPE_IDX_ defines when making changes! */
3361     {0,	0, 0, 700L, 400L, 250L, 0, 0, "n", SHAPE_CURSOR+SHAPE_MOUSE},
3362     {0,	0, 0, 700L, 400L, 250L, 0, 0, "v", SHAPE_CURSOR+SHAPE_MOUSE},
3363     {0,	0, 0, 700L, 400L, 250L, 0, 0, "i", SHAPE_CURSOR+SHAPE_MOUSE},
3364     {0,	0, 0, 700L, 400L, 250L, 0, 0, "r", SHAPE_CURSOR+SHAPE_MOUSE},
3365     {0,	0, 0, 700L, 400L, 250L, 0, 0, "c", SHAPE_CURSOR+SHAPE_MOUSE},
3366     {0,	0, 0, 700L, 400L, 250L, 0, 0, "ci", SHAPE_CURSOR+SHAPE_MOUSE},
3367     {0,	0, 0, 700L, 400L, 250L, 0, 0, "cr", SHAPE_CURSOR+SHAPE_MOUSE},
3368     {0,	0, 0, 700L, 400L, 250L, 0, 0, "o", SHAPE_CURSOR+SHAPE_MOUSE},
3369     {0,	0, 0, 700L, 400L, 250L, 0, 0, "ve", SHAPE_CURSOR+SHAPE_MOUSE},
3370     {0,	0, 0,   0L,   0L,   0L, 0, 0, "e", SHAPE_MOUSE},
3371     {0,	0, 0,   0L,   0L,   0L, 0, 0, "s", SHAPE_MOUSE},
3372     {0,	0, 0,   0L,   0L,   0L, 0, 0, "sd", SHAPE_MOUSE},
3373     {0,	0, 0,   0L,   0L,   0L, 0, 0, "vs", SHAPE_MOUSE},
3374     {0,	0, 0,   0L,   0L,   0L, 0, 0, "vd", SHAPE_MOUSE},
3375     {0,	0, 0,   0L,   0L,   0L, 0, 0, "m", SHAPE_MOUSE},
3376     {0,	0, 0,   0L,   0L,   0L, 0, 0, "ml", SHAPE_MOUSE},
3377     {0,	0, 0, 100L, 100L, 100L, 0, 0, "sm", SHAPE_CURSOR},
3378 };
3379 
3380 #ifdef FEAT_MOUSESHAPE
3381 /*
3382  * Table with names for mouse shapes.  Keep in sync with all the tables for
3383  * mch_set_mouse_shape()!.
3384  */
3385 static char * mshape_names[] =
3386 {
3387     "arrow",	/* default, must be the first one */
3388     "blank",	/* hidden */
3389     "beam",
3390     "updown",
3391     "udsizing",
3392     "leftright",
3393     "lrsizing",
3394     "busy",
3395     "no",
3396     "crosshair",
3397     "hand1",
3398     "hand2",
3399     "pencil",
3400     "question",
3401     "rightup-arrow",
3402     "up-arrow",
3403     NULL
3404 };
3405 #endif
3406 
3407 /*
3408  * Parse the 'guicursor' option ("what" is SHAPE_CURSOR) or 'mouseshape'
3409  * ("what" is SHAPE_MOUSE).
3410  * Returns error message for an illegal option, NULL otherwise.
3411  */
3412     char *
3413 parse_shape_opt(int what)
3414 {
3415     char_u	*modep;
3416     char_u	*colonp;
3417     char_u	*commap;
3418     char_u	*slashp;
3419     char_u	*p, *endp;
3420     int		idx = 0;		/* init for GCC */
3421     int		all_idx;
3422     int		len;
3423     int		i;
3424     long	n;
3425     int		found_ve = FALSE;	/* found "ve" flag */
3426     int		round;
3427 
3428     /*
3429      * First round: check for errors; second round: do it for real.
3430      */
3431     for (round = 1; round <= 2; ++round)
3432     {
3433 	/*
3434 	 * Repeat for all comma separated parts.
3435 	 */
3436 #ifdef FEAT_MOUSESHAPE
3437 	if (what == SHAPE_MOUSE)
3438 	    modep = p_mouseshape;
3439 	else
3440 #endif
3441 	    modep = p_guicursor;
3442 	while (*modep != NUL)
3443 	{
3444 	    colonp = vim_strchr(modep, ':');
3445 	    commap = vim_strchr(modep, ',');
3446 
3447 	    if (colonp == NULL || (commap != NULL && commap < colonp))
3448 		return N_("E545: Missing colon");
3449 	    if (colonp == modep)
3450 		return N_("E546: Illegal mode");
3451 
3452 	    /*
3453 	     * Repeat for all mode's before the colon.
3454 	     * For the 'a' mode, we loop to handle all the modes.
3455 	     */
3456 	    all_idx = -1;
3457 	    while (modep < colonp || all_idx >= 0)
3458 	    {
3459 		if (all_idx < 0)
3460 		{
3461 		    /* Find the mode. */
3462 		    if (modep[1] == '-' || modep[1] == ':')
3463 			len = 1;
3464 		    else
3465 			len = 2;
3466 		    if (len == 1 && TOLOWER_ASC(modep[0]) == 'a')
3467 			all_idx = SHAPE_IDX_COUNT - 1;
3468 		    else
3469 		    {
3470 			for (idx = 0; idx < SHAPE_IDX_COUNT; ++idx)
3471 			    if (STRNICMP(modep, shape_table[idx].name, len)
3472 									 == 0)
3473 				break;
3474 			if (idx == SHAPE_IDX_COUNT
3475 				   || (shape_table[idx].used_for & what) == 0)
3476 			    return N_("E546: Illegal mode");
3477 			if (len == 2 && modep[0] == 'v' && modep[1] == 'e')
3478 			    found_ve = TRUE;
3479 		    }
3480 		    modep += len + 1;
3481 		}
3482 
3483 		if (all_idx >= 0)
3484 		    idx = all_idx--;
3485 		else if (round == 2)
3486 		{
3487 #ifdef FEAT_MOUSESHAPE
3488 		    if (what == SHAPE_MOUSE)
3489 		    {
3490 			/* Set the default, for the missing parts */
3491 			shape_table[idx].mshape = 0;
3492 		    }
3493 		    else
3494 #endif
3495 		    {
3496 			/* Set the defaults, for the missing parts */
3497 			shape_table[idx].shape = SHAPE_BLOCK;
3498 			shape_table[idx].blinkwait = 700L;
3499 			shape_table[idx].blinkon = 400L;
3500 			shape_table[idx].blinkoff = 250L;
3501 		    }
3502 		}
3503 
3504 		/* Parse the part after the colon */
3505 		for (p = colonp + 1; *p && *p != ','; )
3506 		{
3507 #ifdef FEAT_MOUSESHAPE
3508 		    if (what == SHAPE_MOUSE)
3509 		    {
3510 			for (i = 0; ; ++i)
3511 			{
3512 			    if (mshape_names[i] == NULL)
3513 			    {
3514 				if (!VIM_ISDIGIT(*p))
3515 				    return N_("E547: Illegal mouseshape");
3516 				if (round == 2)
3517 				    shape_table[idx].mshape =
3518 					      getdigits(&p) + MSHAPE_NUMBERED;
3519 				else
3520 				    (void)getdigits(&p);
3521 				break;
3522 			    }
3523 			    len = (int)STRLEN(mshape_names[i]);
3524 			    if (STRNICMP(p, mshape_names[i], len) == 0)
3525 			    {
3526 				if (round == 2)
3527 				    shape_table[idx].mshape = i;
3528 				p += len;
3529 				break;
3530 			    }
3531 			}
3532 		    }
3533 		    else /* if (what == SHAPE_MOUSE) */
3534 #endif
3535 		    {
3536 			/*
3537 			 * First handle the ones with a number argument.
3538 			 */
3539 			i = *p;
3540 			len = 0;
3541 			if (STRNICMP(p, "ver", 3) == 0)
3542 			    len = 3;
3543 			else if (STRNICMP(p, "hor", 3) == 0)
3544 			    len = 3;
3545 			else if (STRNICMP(p, "blinkwait", 9) == 0)
3546 			    len = 9;
3547 			else if (STRNICMP(p, "blinkon", 7) == 0)
3548 			    len = 7;
3549 			else if (STRNICMP(p, "blinkoff", 8) == 0)
3550 			    len = 8;
3551 			if (len != 0)
3552 			{
3553 			    p += len;
3554 			    if (!VIM_ISDIGIT(*p))
3555 				return N_("E548: digit expected");
3556 			    n = getdigits(&p);
3557 			    if (len == 3)   /* "ver" or "hor" */
3558 			    {
3559 				if (n == 0)
3560 				    return N_("E549: Illegal percentage");
3561 				if (round == 2)
3562 				{
3563 				    if (TOLOWER_ASC(i) == 'v')
3564 					shape_table[idx].shape = SHAPE_VER;
3565 				    else
3566 					shape_table[idx].shape = SHAPE_HOR;
3567 				    shape_table[idx].percentage = n;
3568 				}
3569 			    }
3570 			    else if (round == 2)
3571 			    {
3572 				if (len == 9)
3573 				    shape_table[idx].blinkwait = n;
3574 				else if (len == 7)
3575 				    shape_table[idx].blinkon = n;
3576 				else
3577 				    shape_table[idx].blinkoff = n;
3578 			    }
3579 			}
3580 			else if (STRNICMP(p, "block", 5) == 0)
3581 			{
3582 			    if (round == 2)
3583 				shape_table[idx].shape = SHAPE_BLOCK;
3584 			    p += 5;
3585 			}
3586 			else	/* must be a highlight group name then */
3587 			{
3588 			    endp = vim_strchr(p, '-');
3589 			    if (commap == NULL)		    /* last part */
3590 			    {
3591 				if (endp == NULL)
3592 				    endp = p + STRLEN(p);   /* find end of part */
3593 			    }
3594 			    else if (endp > commap || endp == NULL)
3595 				endp = commap;
3596 			    slashp = vim_strchr(p, '/');
3597 			    if (slashp != NULL && slashp < endp)
3598 			    {
3599 				/* "group/langmap_group" */
3600 				i = syn_check_group(p, (int)(slashp - p));
3601 				p = slashp + 1;
3602 			    }
3603 			    if (round == 2)
3604 			    {
3605 				shape_table[idx].id = syn_check_group(p,
3606 							     (int)(endp - p));
3607 				shape_table[idx].id_lm = shape_table[idx].id;
3608 				if (slashp != NULL && slashp < endp)
3609 				    shape_table[idx].id = i;
3610 			    }
3611 			    p = endp;
3612 			}
3613 		    } /* if (what != SHAPE_MOUSE) */
3614 
3615 		    if (*p == '-')
3616 			++p;
3617 		}
3618 	    }
3619 	    modep = p;
3620 	    if (*modep == ',')
3621 		++modep;
3622 	}
3623     }
3624 
3625     /* If the 's' flag is not given, use the 'v' cursor for 's' */
3626     if (!found_ve)
3627     {
3628 #ifdef FEAT_MOUSESHAPE
3629 	if (what == SHAPE_MOUSE)
3630 	{
3631 	    shape_table[SHAPE_IDX_VE].mshape = shape_table[SHAPE_IDX_V].mshape;
3632 	}
3633 	else
3634 #endif
3635 	{
3636 	    shape_table[SHAPE_IDX_VE].shape = shape_table[SHAPE_IDX_V].shape;
3637 	    shape_table[SHAPE_IDX_VE].percentage =
3638 					 shape_table[SHAPE_IDX_V].percentage;
3639 	    shape_table[SHAPE_IDX_VE].blinkwait =
3640 					  shape_table[SHAPE_IDX_V].blinkwait;
3641 	    shape_table[SHAPE_IDX_VE].blinkon =
3642 					    shape_table[SHAPE_IDX_V].blinkon;
3643 	    shape_table[SHAPE_IDX_VE].blinkoff =
3644 					   shape_table[SHAPE_IDX_V].blinkoff;
3645 	    shape_table[SHAPE_IDX_VE].id = shape_table[SHAPE_IDX_V].id;
3646 	    shape_table[SHAPE_IDX_VE].id_lm = shape_table[SHAPE_IDX_V].id_lm;
3647 	}
3648     }
3649 
3650     return NULL;
3651 }
3652 
3653 # if defined(MCH_CURSOR_SHAPE) || defined(FEAT_GUI) \
3654 	|| defined(FEAT_MOUSESHAPE) || defined(PROTO)
3655 /*
3656  * Return the index into shape_table[] for the current mode.
3657  * When "mouse" is TRUE, consider indexes valid for the mouse pointer.
3658  */
3659     int
3660 get_shape_idx(int mouse)
3661 {
3662 #ifdef FEAT_MOUSESHAPE
3663     if (mouse && (State == HITRETURN || State == ASKMORE))
3664     {
3665 # ifdef FEAT_GUI
3666 	int x, y;
3667 	gui_mch_getmouse(&x, &y);
3668 	if (Y_2_ROW(y) == Rows - 1)
3669 	    return SHAPE_IDX_MOREL;
3670 # endif
3671 	return SHAPE_IDX_MORE;
3672     }
3673     if (mouse && drag_status_line)
3674 	return SHAPE_IDX_SDRAG;
3675     if (mouse && drag_sep_line)
3676 	return SHAPE_IDX_VDRAG;
3677 #endif
3678     if (!mouse && State == SHOWMATCH)
3679 	return SHAPE_IDX_SM;
3680     if (State & VREPLACE_FLAG)
3681 	return SHAPE_IDX_R;
3682     if (State & REPLACE_FLAG)
3683 	return SHAPE_IDX_R;
3684     if (State & INSERT)
3685 	return SHAPE_IDX_I;
3686     if (State & CMDLINE)
3687     {
3688 	if (cmdline_at_end())
3689 	    return SHAPE_IDX_C;
3690 	if (cmdline_overstrike())
3691 	    return SHAPE_IDX_CR;
3692 	return SHAPE_IDX_CI;
3693     }
3694     if (finish_op)
3695 	return SHAPE_IDX_O;
3696     if (VIsual_active)
3697     {
3698 	if (*p_sel == 'e')
3699 	    return SHAPE_IDX_VE;
3700 	else
3701 	    return SHAPE_IDX_V;
3702     }
3703     return SHAPE_IDX_N;
3704 }
3705 #endif
3706 
3707 # if defined(FEAT_MOUSESHAPE) || defined(PROTO)
3708 static int old_mouse_shape = 0;
3709 
3710 /*
3711  * Set the mouse shape:
3712  * If "shape" is -1, use shape depending on the current mode,
3713  * depending on the current state.
3714  * If "shape" is -2, only update the shape when it's CLINE or STATUS (used
3715  * when the mouse moves off the status or command line).
3716  */
3717     void
3718 update_mouseshape(int shape_idx)
3719 {
3720     int new_mouse_shape;
3721 
3722     /* Only works in GUI mode. */
3723     if (!gui.in_use || gui.starting)
3724 	return;
3725 
3726     /* Postpone the updating when more is to come.  Speeds up executing of
3727      * mappings. */
3728     if (shape_idx == -1 && char_avail())
3729     {
3730 	postponed_mouseshape = TRUE;
3731 	return;
3732     }
3733 
3734     /* When ignoring the mouse don't change shape on the statusline. */
3735     if (*p_mouse == NUL
3736 	    && (shape_idx == SHAPE_IDX_CLINE
3737 		|| shape_idx == SHAPE_IDX_STATUS
3738 		|| shape_idx == SHAPE_IDX_VSEP))
3739 	shape_idx = -2;
3740 
3741     if (shape_idx == -2
3742 	    && old_mouse_shape != shape_table[SHAPE_IDX_CLINE].mshape
3743 	    && old_mouse_shape != shape_table[SHAPE_IDX_STATUS].mshape
3744 	    && old_mouse_shape != shape_table[SHAPE_IDX_VSEP].mshape)
3745 	return;
3746     if (shape_idx < 0)
3747 	new_mouse_shape = shape_table[get_shape_idx(TRUE)].mshape;
3748     else
3749 	new_mouse_shape = shape_table[shape_idx].mshape;
3750     if (new_mouse_shape != old_mouse_shape)
3751     {
3752 	mch_set_mouse_shape(new_mouse_shape);
3753 	old_mouse_shape = new_mouse_shape;
3754     }
3755     postponed_mouseshape = FALSE;
3756 }
3757 # endif
3758 
3759 #endif /* CURSOR_SHAPE */
3760 
3761 
3762 /*
3763  * Change directory to "new_dir".  If FEAT_SEARCHPATH is defined, search
3764  * 'cdpath' for relative directory names, otherwise just mch_chdir().
3765  */
3766     int
3767 vim_chdir(char_u *new_dir)
3768 {
3769 #ifndef FEAT_SEARCHPATH
3770     return mch_chdir((char *)new_dir);
3771 #else
3772     char_u	*dir_name;
3773     int		r;
3774 
3775     dir_name = find_directory_in_path(new_dir, (int)STRLEN(new_dir),
3776 						FNAME_MESS, curbuf->b_ffname);
3777     if (dir_name == NULL)
3778 	return -1;
3779     r = mch_chdir((char *)dir_name);
3780     vim_free(dir_name);
3781     return r;
3782 #endif
3783 }
3784 
3785 /*
3786  * Get user name from machine-specific function.
3787  * Returns the user name in "buf[len]".
3788  * Some systems are quite slow in obtaining the user name (Windows NT), thus
3789  * cache the result.
3790  * Returns OK or FAIL.
3791  */
3792     int
3793 get_user_name(char_u *buf, int len)
3794 {
3795     if (username == NULL)
3796     {
3797 	if (mch_get_user_name(buf, len) == FAIL)
3798 	    return FAIL;
3799 	username = vim_strsave(buf);
3800     }
3801     else
3802 	vim_strncpy(buf, username, len - 1);
3803     return OK;
3804 }
3805 
3806 #ifndef HAVE_QSORT
3807 /*
3808  * Our own qsort(), for systems that don't have it.
3809  * It's simple and slow.  From the K&R C book.
3810  */
3811     void
3812 qsort(
3813     void	*base,
3814     size_t	elm_count,
3815     size_t	elm_size,
3816     int (*cmp)(const void *, const void *))
3817 {
3818     char_u	*buf;
3819     char_u	*p1;
3820     char_u	*p2;
3821     int		i, j;
3822     int		gap;
3823 
3824     buf = alloc(elm_size);
3825     if (buf == NULL)
3826 	return;
3827 
3828     for (gap = elm_count / 2; gap > 0; gap /= 2)
3829 	for (i = gap; i < elm_count; ++i)
3830 	    for (j = i - gap; j >= 0; j -= gap)
3831 	    {
3832 		/* Compare the elements. */
3833 		p1 = (char_u *)base + j * elm_size;
3834 		p2 = (char_u *)base + (j + gap) * elm_size;
3835 		if ((*cmp)((void *)p1, (void *)p2) <= 0)
3836 		    break;
3837 		/* Exchange the elements. */
3838 		mch_memmove(buf, p1, elm_size);
3839 		mch_memmove(p1, p2, elm_size);
3840 		mch_memmove(p2, buf, elm_size);
3841 	    }
3842 
3843     vim_free(buf);
3844 }
3845 #endif
3846 
3847 /*
3848  * Sort an array of strings.
3849  */
3850 static int sort_compare(const void *s1, const void *s2);
3851 
3852     static int
3853 sort_compare(const void *s1, const void *s2)
3854 {
3855     return STRCMP(*(char **)s1, *(char **)s2);
3856 }
3857 
3858     void
3859 sort_strings(
3860     char_u	**files,
3861     int		count)
3862 {
3863     qsort((void *)files, (size_t)count, sizeof(char_u *), sort_compare);
3864 }
3865 
3866 /*
3867  * The putenv() implementation below comes from the "screen" program.
3868  * Included with permission from Juergen Weigert.
3869  * See pty.c for the copyright notice.
3870  */
3871 
3872 /*
3873  *  putenv  --	put value into environment
3874  *
3875  *  Usage:  i = putenv (string)
3876  *    int i;
3877  *    char  *string;
3878  *
3879  *  where string is of the form <name>=<value>.
3880  *  Putenv returns 0 normally, -1 on error (not enough core for malloc).
3881  *
3882  *  Putenv may need to add a new name into the environment, or to
3883  *  associate a value longer than the current value with a particular
3884  *  name.  So, to make life simpler, putenv() copies your entire
3885  *  environment into the heap (i.e. malloc()) from the stack
3886  *  (i.e. where it resides when your process is initiated) the first
3887  *  time you call it.
3888  *
3889  *  (history removed, not very interesting.  See the "screen" sources.)
3890  */
3891 
3892 #if !defined(HAVE_SETENV) && !defined(HAVE_PUTENV)
3893 
3894 #define EXTRASIZE 5		/* increment to add to env. size */
3895 
3896 static int  envsize = -1;	/* current size of environment */
3897 extern char **environ;		/* the global which is your env. */
3898 
3899 static int  findenv(char *name); /* look for a name in the env. */
3900 static int  newenv(void);	/* copy env. from stack to heap */
3901 static int  moreenv(void);	/* incr. size of env. */
3902 
3903     int
3904 putenv(const char *string)
3905 {
3906     int	    i;
3907     char    *p;
3908 
3909     if (envsize < 0)
3910     {				/* first time putenv called */
3911 	if (newenv() < 0)	/* copy env. to heap */
3912 	    return -1;
3913     }
3914 
3915     i = findenv((char *)string); /* look for name in environment */
3916 
3917     if (i < 0)
3918     {				/* name must be added */
3919 	for (i = 0; environ[i]; i++);
3920 	if (i >= (envsize - 1))
3921 	{			/* need new slot */
3922 	    if (moreenv() < 0)
3923 		return -1;
3924 	}
3925 	p = alloc(strlen(string) + 1);
3926 	if (p == NULL)		/* not enough core */
3927 	    return -1;
3928 	environ[i + 1] = 0;	/* new end of env. */
3929     }
3930     else
3931     {				/* name already in env. */
3932 	p = vim_realloc(environ[i], strlen(string) + 1);
3933 	if (p == NULL)
3934 	    return -1;
3935     }
3936     sprintf(p, "%s", string);	/* copy into env. */
3937     environ[i] = p;
3938 
3939     return 0;
3940 }
3941 
3942     static int
3943 findenv(char *name)
3944 {
3945     char    *namechar, *envchar;
3946     int	    i, found;
3947 
3948     found = 0;
3949     for (i = 0; environ[i] && !found; i++)
3950     {
3951 	envchar = environ[i];
3952 	namechar = name;
3953 	while (*namechar && *namechar != '=' && (*namechar == *envchar))
3954 	{
3955 	    namechar++;
3956 	    envchar++;
3957 	}
3958 	found = ((*namechar == '\0' || *namechar == '=') && *envchar == '=');
3959     }
3960     return found ? i - 1 : -1;
3961 }
3962 
3963     static int
3964 newenv(void)
3965 {
3966     char    **env, *elem;
3967     int	    i, esize;
3968 
3969     for (i = 0; environ[i]; i++)
3970 	;
3971 
3972     esize = i + EXTRASIZE + 1;
3973     env = ALLOC_MULT(char *, esize);
3974     if (env == NULL)
3975 	return -1;
3976 
3977     for (i = 0; environ[i]; i++)
3978     {
3979 	elem = alloc(strlen(environ[i]) + 1);
3980 	if (elem == NULL)
3981 	    return -1;
3982 	env[i] = elem;
3983 	strcpy(elem, environ[i]);
3984     }
3985 
3986     env[i] = 0;
3987     environ = env;
3988     envsize = esize;
3989     return 0;
3990 }
3991 
3992     static int
3993 moreenv(void)
3994 {
3995     int	    esize;
3996     char    **env;
3997 
3998     esize = envsize + EXTRASIZE;
3999     env = vim_realloc((char *)environ, esize * sizeof (*env));
4000     if (env == 0)
4001 	return -1;
4002     environ = env;
4003     envsize = esize;
4004     return 0;
4005 }
4006 
4007 # ifdef USE_VIMPTY_GETENV
4008 /*
4009  * Used for mch_getenv() for Mac.
4010  */
4011     char_u *
4012 vimpty_getenv(const char_u *string)
4013 {
4014     int i;
4015     char_u *p;
4016 
4017     if (envsize < 0)
4018 	return NULL;
4019 
4020     i = findenv((char *)string);
4021 
4022     if (i < 0)
4023 	return NULL;
4024 
4025     p = vim_strchr((char_u *)environ[i], '=');
4026     return (p + 1);
4027 }
4028 # endif
4029 
4030 #endif /* !defined(HAVE_SETENV) && !defined(HAVE_PUTENV) */
4031 
4032 #if defined(FEAT_EVAL) || defined(FEAT_SPELL) || defined(PROTO)
4033 /*
4034  * Return 0 for not writable, 1 for writable file, 2 for a dir which we have
4035  * rights to write into.
4036  */
4037     int
4038 filewritable(char_u *fname)
4039 {
4040     int		retval = 0;
4041 #if defined(UNIX) || defined(VMS)
4042     int		perm = 0;
4043 #endif
4044 
4045 #if defined(UNIX) || defined(VMS)
4046     perm = mch_getperm(fname);
4047 #endif
4048     if (
4049 # ifdef MSWIN
4050 	    mch_writable(fname) &&
4051 # else
4052 # if defined(UNIX) || defined(VMS)
4053 	    (perm & 0222) &&
4054 #  endif
4055 # endif
4056 	    mch_access((char *)fname, W_OK) == 0
4057        )
4058     {
4059 	++retval;
4060 	if (mch_isdir(fname))
4061 	    ++retval;
4062     }
4063     return retval;
4064 }
4065 #endif
4066 
4067 #if defined(FEAT_SPELL) || defined(FEAT_PERSISTENT_UNDO) || defined(PROTO)
4068 /*
4069  * Read 2 bytes from "fd" and turn them into an int, MSB first.
4070  * Returns -1 when encountering EOF.
4071  */
4072     int
4073 get2c(FILE *fd)
4074 {
4075     int		c, n;
4076 
4077     n = getc(fd);
4078     if (n == EOF) return -1;
4079     c = getc(fd);
4080     if (c == EOF) return -1;
4081     return (n << 8) + c;
4082 }
4083 
4084 /*
4085  * Read 3 bytes from "fd" and turn them into an int, MSB first.
4086  * Returns -1 when encountering EOF.
4087  */
4088     int
4089 get3c(FILE *fd)
4090 {
4091     int		c, n;
4092 
4093     n = getc(fd);
4094     if (n == EOF) return -1;
4095     c = getc(fd);
4096     if (c == EOF) return -1;
4097     n = (n << 8) + c;
4098     c = getc(fd);
4099     if (c == EOF) return -1;
4100     return (n << 8) + c;
4101 }
4102 
4103 /*
4104  * Read 4 bytes from "fd" and turn them into an int, MSB first.
4105  * Returns -1 when encountering EOF.
4106  */
4107     int
4108 get4c(FILE *fd)
4109 {
4110     int		c;
4111     /* Use unsigned rather than int otherwise result is undefined
4112      * when left-shift sets the MSB. */
4113     unsigned	n;
4114 
4115     c = getc(fd);
4116     if (c == EOF) return -1;
4117     n = (unsigned)c;
4118     c = getc(fd);
4119     if (c == EOF) return -1;
4120     n = (n << 8) + (unsigned)c;
4121     c = getc(fd);
4122     if (c == EOF) return -1;
4123     n = (n << 8) + (unsigned)c;
4124     c = getc(fd);
4125     if (c == EOF) return -1;
4126     n = (n << 8) + (unsigned)c;
4127     return (int)n;
4128 }
4129 
4130 /*
4131  * Read 8 bytes from "fd" and turn them into a time_T, MSB first.
4132  * Returns -1 when encountering EOF.
4133  */
4134     time_T
4135 get8ctime(FILE *fd)
4136 {
4137     int		c;
4138     time_T	n = 0;
4139     int		i;
4140 
4141     for (i = 0; i < 8; ++i)
4142     {
4143 	c = getc(fd);
4144 	if (c == EOF) return -1;
4145 	n = (n << 8) + c;
4146     }
4147     return n;
4148 }
4149 
4150 /*
4151  * Read a string of length "cnt" from "fd" into allocated memory.
4152  * Returns NULL when out of memory or unable to read that many bytes.
4153  */
4154     char_u *
4155 read_string(FILE *fd, int cnt)
4156 {
4157     char_u	*str;
4158     int		i;
4159     int		c;
4160 
4161     /* allocate memory */
4162     str = alloc(cnt + 1);
4163     if (str != NULL)
4164     {
4165 	/* Read the string.  Quit when running into the EOF. */
4166 	for (i = 0; i < cnt; ++i)
4167 	{
4168 	    c = getc(fd);
4169 	    if (c == EOF)
4170 	    {
4171 		vim_free(str);
4172 		return NULL;
4173 	    }
4174 	    str[i] = c;
4175 	}
4176 	str[i] = NUL;
4177     }
4178     return str;
4179 }
4180 
4181 /*
4182  * Write a number to file "fd", MSB first, in "len" bytes.
4183  */
4184     int
4185 put_bytes(FILE *fd, long_u nr, int len)
4186 {
4187     int	    i;
4188 
4189     for (i = len - 1; i >= 0; --i)
4190 	if (putc((int)(nr >> (i * 8)), fd) == EOF)
4191 	    return FAIL;
4192     return OK;
4193 }
4194 
4195 #ifdef _MSC_VER
4196 # if (_MSC_VER <= 1200)
4197 /* This line is required for VC6 without the service pack.  Also see the
4198  * matching #pragma below. */
4199  #  pragma optimize("", off)
4200 # endif
4201 #endif
4202 
4203 /*
4204  * Write time_T to file "fd" in 8 bytes.
4205  * Returns FAIL when the write failed.
4206  */
4207     int
4208 put_time(FILE *fd, time_T the_time)
4209 {
4210     char_u	buf[8];
4211 
4212     time_to_bytes(the_time, buf);
4213     return fwrite(buf, (size_t)8, (size_t)1, fd) == 1 ? OK : FAIL;
4214 }
4215 
4216 /*
4217  * Write time_T to "buf[8]".
4218  */
4219     void
4220 time_to_bytes(time_T the_time, char_u *buf)
4221 {
4222     int		c;
4223     int		i;
4224     int		bi = 0;
4225     time_T	wtime = the_time;
4226 
4227     /* time_T can be up to 8 bytes in size, more than long_u, thus we
4228      * can't use put_bytes() here.
4229      * Another problem is that ">>" may do an arithmetic shift that keeps the
4230      * sign.  This happens for large values of wtime.  A cast to long_u may
4231      * truncate if time_T is 8 bytes.  So only use a cast when it is 4 bytes,
4232      * it's safe to assume that long_u is 4 bytes or more and when using 8
4233      * bytes the top bit won't be set. */
4234     for (i = 7; i >= 0; --i)
4235     {
4236 	if (i + 1 > (int)sizeof(time_T))
4237 	    /* ">>" doesn't work well when shifting more bits than avail */
4238 	    buf[bi++] = 0;
4239 	else
4240 	{
4241 #if defined(SIZEOF_TIME_T) && SIZEOF_TIME_T > 4
4242 	    c = (int)(wtime >> (i * 8));
4243 #else
4244 	    c = (int)((long_u)wtime >> (i * 8));
4245 #endif
4246 	    buf[bi++] = c;
4247 	}
4248     }
4249 }
4250 
4251 #ifdef _MSC_VER
4252 # if (_MSC_VER <= 1200)
4253  #  pragma optimize("", on)
4254 # endif
4255 #endif
4256 
4257 #endif
4258 
4259 #if defined(FEAT_QUICKFIX) || defined(FEAT_SPELL) || defined(PROTO)
4260 /*
4261  * Return TRUE if string "s" contains a non-ASCII character (128 or higher).
4262  * When "s" is NULL FALSE is returned.
4263  */
4264     int
4265 has_non_ascii(char_u *s)
4266 {
4267     char_u	*p;
4268 
4269     if (s != NULL)
4270 	for (p = s; *p != NUL; ++p)
4271 	    if (*p >= 128)
4272 		return TRUE;
4273     return FALSE;
4274 }
4275 #endif
4276 
4277 #ifndef PROTO  /* proto is defined in vim.h */
4278 # ifdef ELAPSED_TIMEVAL
4279 /*
4280  * Return time in msec since "start_tv".
4281  */
4282     long
4283 elapsed(struct timeval *start_tv)
4284 {
4285     struct timeval  now_tv;
4286 
4287     gettimeofday(&now_tv, NULL);
4288     return (now_tv.tv_sec - start_tv->tv_sec) * 1000L
4289 	 + (now_tv.tv_usec - start_tv->tv_usec) / 1000L;
4290 }
4291 # endif
4292 
4293 # ifdef ELAPSED_TICKCOUNT
4294 /*
4295  * Return time in msec since "start_tick".
4296  */
4297     long
4298 elapsed(DWORD start_tick)
4299 {
4300     DWORD	now = GetTickCount();
4301 
4302     return (long)now - (long)start_tick;
4303 }
4304 # endif
4305 #endif
4306 
4307 #if defined(FEAT_JOB_CHANNEL) \
4308 	|| (defined(UNIX) && (!defined(USE_SYSTEM) \
4309 	|| (defined(FEAT_GUI) && defined(FEAT_TERMINAL)))) \
4310 	|| defined(PROTO)
4311 /*
4312  * Parse "cmd" and put the white-separated parts in "argv".
4313  * "argv" is an allocated array with "argc" entries and room for 4 more.
4314  * Returns FAIL when out of memory.
4315  */
4316     int
4317 mch_parse_cmd(char_u *cmd, int use_shcf, char ***argv, int *argc)
4318 {
4319     int		i;
4320     char_u	*p, *d;
4321     int		inquote;
4322 
4323     /*
4324      * Do this loop twice:
4325      * 1: find number of arguments
4326      * 2: separate them and build argv[]
4327      */
4328     for (i = 0; i < 2; ++i)
4329     {
4330 	p = skipwhite(cmd);
4331 	inquote = FALSE;
4332 	*argc = 0;
4333 	for (;;)
4334 	{
4335 	    if (i == 1)
4336 		(*argv)[*argc] = (char *)p;
4337 	    ++*argc;
4338 	    d = p;
4339 	    while (*p != NUL && (inquote || (*p != ' ' && *p != TAB)))
4340 	    {
4341 		if (p[0] == '"')
4342 		    // quotes surrounding an argument and are dropped
4343 		    inquote = !inquote;
4344 		else
4345 		{
4346 		    if (rem_backslash(p))
4347 		    {
4348 			// First pass: skip over "\ " and "\"".
4349 			// Second pass: Remove the backslash.
4350 			++p;
4351 		    }
4352 		    if (i == 1)
4353 			*d++ = *p;
4354 		}
4355 		++p;
4356 	    }
4357 	    if (*p == NUL)
4358 	    {
4359 		if (i == 1)
4360 		    *d++ = NUL;
4361 		break;
4362 	    }
4363 	    if (i == 1)
4364 		*d++ = NUL;
4365 	    p = skipwhite(p + 1);
4366 	}
4367 	if (*argv == NULL)
4368 	{
4369 	    if (use_shcf)
4370 	    {
4371 		/* Account for possible multiple args in p_shcf. */
4372 		p = p_shcf;
4373 		for (;;)
4374 		{
4375 		    p = skiptowhite(p);
4376 		    if (*p == NUL)
4377 			break;
4378 		    ++*argc;
4379 		    p = skipwhite(p);
4380 		}
4381 	    }
4382 
4383 	    *argv = ALLOC_MULT(char *, *argc + 4);
4384 	    if (*argv == NULL)	    /* out of memory */
4385 		return FAIL;
4386 	}
4387     }
4388     return OK;
4389 }
4390 
4391 # if defined(FEAT_JOB_CHANNEL) || defined(PROTO)
4392 /*
4393  * Build "argv[argc]" from the string "cmd".
4394  * "argv[argc]" is set to NULL;
4395  * Return FAIL when out of memory.
4396  */
4397     int
4398 build_argv_from_string(char_u *cmd, char ***argv, int *argc)
4399 {
4400     char_u	*cmd_copy;
4401     int		i;
4402 
4403     /* Make a copy, parsing will modify "cmd". */
4404     cmd_copy = vim_strsave(cmd);
4405     if (cmd_copy == NULL
4406 	    || mch_parse_cmd(cmd_copy, FALSE, argv, argc) == FAIL)
4407     {
4408 	vim_free(cmd_copy);
4409 	return FAIL;
4410     }
4411     for (i = 0; i < *argc; i++)
4412 	(*argv)[i] = (char *)vim_strsave((char_u *)(*argv)[i]);
4413     (*argv)[*argc] = NULL;
4414     vim_free(cmd_copy);
4415     return OK;
4416 }
4417 
4418 /*
4419  * Build "argv[argc]" from the list "l".
4420  * "argv[argc]" is set to NULL;
4421  * Return FAIL when out of memory.
4422  */
4423     int
4424 build_argv_from_list(list_T *l, char ***argv, int *argc)
4425 {
4426     listitem_T  *li;
4427     char_u	*s;
4428 
4429     /* Pass argv[] to mch_call_shell(). */
4430     *argv = ALLOC_MULT(char *, l->lv_len + 1);
4431     if (*argv == NULL)
4432 	return FAIL;
4433     *argc = 0;
4434     for (li = l->lv_first; li != NULL; li = li->li_next)
4435     {
4436 	s = tv_get_string_chk(&li->li_tv);
4437 	if (s == NULL)
4438 	{
4439 	    int i;
4440 
4441 	    for (i = 0; i < *argc; ++i)
4442 		vim_free((*argv)[i]);
4443 	    return FAIL;
4444 	}
4445 	(*argv)[*argc] = (char *)vim_strsave(s);
4446 	*argc += 1;
4447     }
4448     (*argv)[*argc] = NULL;
4449     return OK;
4450 }
4451 # endif
4452 #endif
4453 
4454 /*
4455  * Change the behavior of vterm.
4456  * 0: As usual.
4457  * 1: Windows 10 version 1809
4458  *      The bug causes unstable handling of ambiguous width character.
4459  * 2: Windows 10 version 1903
4460  *      Use the wrong result because each result is different.
4461  * 3: Windows 10 insider preview (current latest logic)
4462  */
4463     int
4464 get_special_pty_type(void)
4465 {
4466 #ifdef MSWIN
4467     return get_conpty_type();
4468 #else
4469     return 0;
4470 #endif
4471 }
4472