xref: /freebsd/contrib/tcsh/ed.chared.c (revision a15e6f9a9a49be5eae10ed6689eb2f855462ffbb)
1a15e6f9aSMark Peek /* $Header: /p/tcsh/cvsroot/tcsh/ed.chared.c,v 3.95 2009/06/25 21:15:37 christos Exp $ */
2c80476e4SDavid E. O'Brien /*
3c80476e4SDavid E. O'Brien  * ed.chared.c: Character editing functions.
4c80476e4SDavid E. O'Brien  */
5c80476e4SDavid E. O'Brien /*-
6c80476e4SDavid E. O'Brien  * Copyright (c) 1980, 1991 The Regents of the University of California.
7c80476e4SDavid E. O'Brien  * All rights reserved.
8c80476e4SDavid E. O'Brien  *
9c80476e4SDavid E. O'Brien  * Redistribution and use in source and binary forms, with or without
10c80476e4SDavid E. O'Brien  * modification, are permitted provided that the following conditions
11c80476e4SDavid E. O'Brien  * are met:
12c80476e4SDavid E. O'Brien  * 1. Redistributions of source code must retain the above copyright
13c80476e4SDavid E. O'Brien  *    notice, this list of conditions and the following disclaimer.
14c80476e4SDavid E. O'Brien  * 2. Redistributions in binary form must reproduce the above copyright
15c80476e4SDavid E. O'Brien  *    notice, this list of conditions and the following disclaimer in the
16c80476e4SDavid E. O'Brien  *    documentation and/or other materials provided with the distribution.
1729301572SMark Peek  * 3. Neither the name of the University nor the names of its contributors
18c80476e4SDavid E. O'Brien  *    may be used to endorse or promote products derived from this software
19c80476e4SDavid E. O'Brien  *    without specific prior written permission.
20c80476e4SDavid E. O'Brien  *
21c80476e4SDavid E. O'Brien  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
22c80476e4SDavid E. O'Brien  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23c80476e4SDavid E. O'Brien  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24c80476e4SDavid E. O'Brien  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
25c80476e4SDavid E. O'Brien  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26c80476e4SDavid E. O'Brien  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27c80476e4SDavid E. O'Brien  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28c80476e4SDavid E. O'Brien  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29c80476e4SDavid E. O'Brien  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30c80476e4SDavid E. O'Brien  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31c80476e4SDavid E. O'Brien  * SUCH DAMAGE.
32c80476e4SDavid E. O'Brien  */
33c80476e4SDavid E. O'Brien /*
34c80476e4SDavid E. O'Brien   Bjorn Knutsson @ Thu Jun 24 19:02:17 1999
35c80476e4SDavid E. O'Brien 
36c80476e4SDavid E. O'Brien   e_dabbrev_expand() did not do proper completion if quoted spaces were present
37c80476e4SDavid E. O'Brien   in the string being completed. Exemple:
38c80476e4SDavid E. O'Brien 
39c80476e4SDavid E. O'Brien   # echo hello\ world
40c80476e4SDavid E. O'Brien   hello world
41c80476e4SDavid E. O'Brien   # echo h<press key bound to dabbrev-expande>
42c80476e4SDavid E. O'Brien   # echo hello\<cursor>
43c80476e4SDavid E. O'Brien 
44c80476e4SDavid E. O'Brien   Correct behavior is:
45c80476e4SDavid E. O'Brien   # echo h<press key bound to dabbrev-expande>
46c80476e4SDavid E. O'Brien   # echo hello\ world<cursor>
47c80476e4SDavid E. O'Brien 
48c80476e4SDavid E. O'Brien   The same problem occured if spaces were present in a string withing quotation
49c80476e4SDavid E. O'Brien   marks. Example:
50c80476e4SDavid E. O'Brien 
51c80476e4SDavid E. O'Brien   # echo "hello world"
52c80476e4SDavid E. O'Brien   hello world
53c80476e4SDavid E. O'Brien   # echo "h<press key bound to dabbrev-expande>
54c80476e4SDavid E. O'Brien   # echo "hello<cursor>
55c80476e4SDavid E. O'Brien 
56c80476e4SDavid E. O'Brien   The former problem could be solved with minor modifications of c_preword()
57c80476e4SDavid E. O'Brien   and c_endword(). The latter, however, required a significant rewrite of
58c80476e4SDavid E. O'Brien   c_preword(), since quoted strings must be parsed from start to end to
59c80476e4SDavid E. O'Brien   determine if a given character is inside or outside the quotation marks.
60c80476e4SDavid E. O'Brien 
61c80476e4SDavid E. O'Brien   Compare the following two strings:
62c80476e4SDavid E. O'Brien 
63c80476e4SDavid E. O'Brien   # echo \"" 'foo \' bar\"
64c80476e4SDavid E. O'Brien   " 'foo \' bar\
65c80476e4SDavid E. O'Brien   # echo '\"" 'foo \' bar\"
66c80476e4SDavid E. O'Brien   \"" foo ' bar"
67c80476e4SDavid E. O'Brien 
68c80476e4SDavid E. O'Brien   The only difference between the two echo lines is in the first character
69c80476e4SDavid E. O'Brien   after the echo command. The result is either one or three arguments.
70c80476e4SDavid E. O'Brien 
71c80476e4SDavid E. O'Brien  */
72c80476e4SDavid E. O'Brien 
73c80476e4SDavid E. O'Brien #include "sh.h"
74c80476e4SDavid E. O'Brien 
75a15e6f9aSMark Peek RCSID("$tcsh: ed.chared.c,v 3.95 2009/06/25 21:15:37 christos Exp $")
76c80476e4SDavid E. O'Brien 
77c80476e4SDavid E. O'Brien #include "ed.h"
78c80476e4SDavid E. O'Brien #include "tw.h"
79c80476e4SDavid E. O'Brien #include "ed.defns.h"
80c80476e4SDavid E. O'Brien 
81c80476e4SDavid E. O'Brien /* #define SDEBUG */
82c80476e4SDavid E. O'Brien 
83c80476e4SDavid E. O'Brien #define TCSHOP_NOP    	  0x00
84c80476e4SDavid E. O'Brien #define TCSHOP_DELETE 	  0x01
85c80476e4SDavid E. O'Brien #define TCSHOP_INSERT 	  0x02
86c80476e4SDavid E. O'Brien #define TCSHOP_CHANGE 	  0x04
87c80476e4SDavid E. O'Brien 
88c80476e4SDavid E. O'Brien #define CHAR_FWD	0
89c80476e4SDavid E. O'Brien #define CHAR_BACK	1
90c80476e4SDavid E. O'Brien 
91c80476e4SDavid E. O'Brien /*
92c80476e4SDavid E. O'Brien  * vi word treatment
93c80476e4SDavid E. O'Brien  * from: Gert-Jan Vons <vons@cesar.crbca1.sinet.slb.com>
94c80476e4SDavid E. O'Brien  */
95c80476e4SDavid E. O'Brien #define C_CLASS_WHITE	1
96c80476e4SDavid E. O'Brien #define C_CLASS_ALNUM	2
97c80476e4SDavid E. O'Brien #define C_CLASS_OTHER	3
98c80476e4SDavid E. O'Brien 
99c80476e4SDavid E. O'Brien static Char *InsertPos = InputBuf; /* Where insertion starts */
100c80476e4SDavid E. O'Brien static Char *ActionPos = 0;	   /* Where action begins  */
101c80476e4SDavid E. O'Brien static int  ActionFlag = TCSHOP_NOP;	   /* What delayed action to take */
102c80476e4SDavid E. O'Brien /*
103c80476e4SDavid E. O'Brien  * Word search state
104c80476e4SDavid E. O'Brien  */
105c80476e4SDavid E. O'Brien static int  searchdir = F_UP_SEARCH_HIST; 	/* Direction of last search */
10645e5710bSMark Peek static struct Strbuf patbuf; /* = Strbuf_INIT; Search target */
107c80476e4SDavid E. O'Brien /*
108c80476e4SDavid E. O'Brien  * Char search state
109c80476e4SDavid E. O'Brien  */
110c80476e4SDavid E. O'Brien static int  srch_dir = CHAR_FWD;		/* Direction of last search */
111c80476e4SDavid E. O'Brien static Char srch_char = 0;			/* Search target */
112c80476e4SDavid E. O'Brien 
113c80476e4SDavid E. O'Brien /* all routines that start with c_ are private to this set of routines */
11445e5710bSMark Peek static	void	 c_alternativ_key_map	(int);
11545e5710bSMark Peek void	 c_insert		(int);
11645e5710bSMark Peek void	 c_delafter		(int);
11745e5710bSMark Peek void	 c_delbefore		(int);
11845e5710bSMark Peek static 	int	 c_to_class		(Char);
11945e5710bSMark Peek static	Char	*c_prev_word		(Char *, Char *, int);
12045e5710bSMark Peek static	Char	*c_next_word		(Char *, Char *, int);
12145e5710bSMark Peek static	Char	*c_number		(Char *, int *, int);
12245e5710bSMark Peek static	Char	*c_expand		(Char *);
123a15e6f9aSMark Peek static	int	 c_excl			(Char *);
124a15e6f9aSMark Peek static	int	 c_substitute		(void);
12545e5710bSMark Peek static	void	 c_delfini		(void);
12645e5710bSMark Peek static	int	 c_hmatch		(Char *);
12745e5710bSMark Peek static	void	 c_hsetpat		(void);
128c80476e4SDavid E. O'Brien #ifdef COMMENT
12945e5710bSMark Peek static	void	 c_get_word		(Char **, Char **);
130c80476e4SDavid E. O'Brien #endif
13145e5710bSMark Peek static	Char	*c_preword		(Char *, Char *, int, Char *);
13245e5710bSMark Peek static	Char	*c_nexword		(Char *, Char *, int);
13345e5710bSMark Peek static	Char	*c_endword		(Char *, Char *, int, Char *);
13445e5710bSMark Peek static	Char	*c_eword		(Char *, Char *, int);
13545e5710bSMark Peek static	void	 c_push_kill		(Char *, Char *);
13645e5710bSMark Peek static	void	 c_save_inputbuf	(void);
13745e5710bSMark Peek static  CCRETVAL c_search_line		(Char *, int);
13845e5710bSMark Peek static  CCRETVAL v_repeat_srch		(int);
13945e5710bSMark Peek static	CCRETVAL e_inc_search		(int);
14045e5710bSMark Peek #ifdef notyet
14145e5710bSMark Peek static  CCRETVAL e_insert_str		(Char *);
14245e5710bSMark Peek #endif
14345e5710bSMark Peek static	CCRETVAL v_search		(int);
14445e5710bSMark Peek static	CCRETVAL v_csearch_fwd		(Char, int, int);
14545e5710bSMark Peek static	CCRETVAL v_action		(int);
14645e5710bSMark Peek static	CCRETVAL v_csearch_back		(Char, int, int);
147c80476e4SDavid E. O'Brien 
148c80476e4SDavid E. O'Brien static void
14945e5710bSMark Peek c_alternativ_key_map(int state)
150c80476e4SDavid E. O'Brien {
151c80476e4SDavid E. O'Brien     switch (state) {
152c80476e4SDavid E. O'Brien     case 0:
153c80476e4SDavid E. O'Brien 	CurrentKeyMap = CcKeyMap;
154c80476e4SDavid E. O'Brien 	break;
155c80476e4SDavid E. O'Brien     case 1:
156c80476e4SDavid E. O'Brien 	CurrentKeyMap = CcAltMap;
157c80476e4SDavid E. O'Brien 	break;
158c80476e4SDavid E. O'Brien     default:
159c80476e4SDavid E. O'Brien 	return;
160c80476e4SDavid E. O'Brien     }
161c80476e4SDavid E. O'Brien 
162c80476e4SDavid E. O'Brien     AltKeyMap = (Char) state;
163c80476e4SDavid E. O'Brien }
164c80476e4SDavid E. O'Brien 
1656767bd61SMark Peek void
16645e5710bSMark Peek c_insert(int num)
167c80476e4SDavid E. O'Brien {
1686767bd61SMark Peek     Char *cp;
169c80476e4SDavid E. O'Brien 
170c80476e4SDavid E. O'Brien     if (LastChar + num >= InputLim)
171c80476e4SDavid E. O'Brien 	return;			/* can't go past end of buffer */
172c80476e4SDavid E. O'Brien 
173c80476e4SDavid E. O'Brien     if (Cursor < LastChar) {	/* if I must move chars */
174c80476e4SDavid E. O'Brien 	for (cp = LastChar; cp >= Cursor; cp--)
175c80476e4SDavid E. O'Brien 	    cp[num] = *cp;
17623338178SMark Peek 	if (Mark && Mark > Cursor)
17723338178SMark Peek 		Mark += num;
178c80476e4SDavid E. O'Brien     }
179c80476e4SDavid E. O'Brien     LastChar += num;
180c80476e4SDavid E. O'Brien }
181c80476e4SDavid E. O'Brien 
1823b6eaa7bSAndrey A. Chernov void
18345e5710bSMark Peek c_delafter(int num)
184c80476e4SDavid E. O'Brien {
1856767bd61SMark Peek     Char *cp, *kp = NULL;
186c80476e4SDavid E. O'Brien 
187c80476e4SDavid E. O'Brien     if (num > LastChar - Cursor)
188c80476e4SDavid E. O'Brien 	num = (int) (LastChar - Cursor);	/* bounds check */
189c80476e4SDavid E. O'Brien 
190c80476e4SDavid E. O'Brien     if (num > 0) {			/* if I can delete anything */
191c80476e4SDavid E. O'Brien 	if (VImode) {
192c80476e4SDavid E. O'Brien 	    kp = UndoBuf;		/* Set Up for VI undo command */
193c80476e4SDavid E. O'Brien 	    UndoAction = TCSHOP_INSERT;
194c80476e4SDavid E. O'Brien 	    UndoSize = num;
195c80476e4SDavid E. O'Brien 	    UndoPtr  = Cursor;
196c80476e4SDavid E. O'Brien 	    for (cp = Cursor; cp <= LastChar; cp++) {
197c80476e4SDavid E. O'Brien 		*kp++ = *cp;	/* Save deleted chars into undobuf */
198c80476e4SDavid E. O'Brien 		*cp = cp[num];
199c80476e4SDavid E. O'Brien 	    }
200c80476e4SDavid E. O'Brien 	}
201c80476e4SDavid E. O'Brien 	else
20223338178SMark Peek 	    for (cp = Cursor; cp + num <= LastChar; cp++)
203c80476e4SDavid E. O'Brien 		*cp = cp[num];
204c80476e4SDavid E. O'Brien 	LastChar -= num;
20545e5710bSMark Peek 	/* Mark was within the range of the deleted word? */
20645e5710bSMark Peek 	if (Mark && Mark > Cursor && Mark <= Cursor+num)
20745e5710bSMark Peek 		Mark = Cursor;
20845e5710bSMark Peek 	/* Mark after the deleted word? */
20945e5710bSMark Peek 	else if (Mark && Mark > Cursor)
21023338178SMark Peek 		Mark -= num;
211c80476e4SDavid E. O'Brien     }
212c80476e4SDavid E. O'Brien #ifdef notdef
213c80476e4SDavid E. O'Brien     else {
214c80476e4SDavid E. O'Brien 	/*
215c80476e4SDavid E. O'Brien 	 * XXX: We don't want to do that. In emacs mode overwrite should be
216c80476e4SDavid E. O'Brien 	 * sticky. I am not sure how that affects vi mode
217c80476e4SDavid E. O'Brien 	 */
218c80476e4SDavid E. O'Brien 	inputmode = MODE_INSERT;
219c80476e4SDavid E. O'Brien     }
220c80476e4SDavid E. O'Brien #endif /* notdef */
221c80476e4SDavid E. O'Brien }
222c80476e4SDavid E. O'Brien 
2233b6eaa7bSAndrey A. Chernov void
22445e5710bSMark Peek c_delbefore(int num)		/* delete before dot, with bounds checking */
225c80476e4SDavid E. O'Brien {
2266767bd61SMark Peek     Char *cp, *kp = NULL;
227c80476e4SDavid E. O'Brien 
228c80476e4SDavid E. O'Brien     if (num > Cursor - InputBuf)
229c80476e4SDavid E. O'Brien 	num = (int) (Cursor - InputBuf);	/* bounds check */
230c80476e4SDavid E. O'Brien 
231c80476e4SDavid E. O'Brien     if (num > 0) {			/* if I can delete anything */
232c80476e4SDavid E. O'Brien 	if (VImode) {
233c80476e4SDavid E. O'Brien 	    kp = UndoBuf;		/* Set Up for VI undo command */
234c80476e4SDavid E. O'Brien 	    UndoAction = TCSHOP_INSERT;
235c80476e4SDavid E. O'Brien 	    UndoSize = num;
236c80476e4SDavid E. O'Brien 	    UndoPtr  = Cursor - num;
237c80476e4SDavid E. O'Brien 	    for (cp = Cursor - num; cp <= LastChar; cp++) {
238c80476e4SDavid E. O'Brien 		*kp++ = *cp;
239c80476e4SDavid E. O'Brien 		*cp = cp[num];
240c80476e4SDavid E. O'Brien 	    }
241c80476e4SDavid E. O'Brien 	}
242c80476e4SDavid E. O'Brien 	else
24323338178SMark Peek 	    for (cp = Cursor - num; cp + num <= LastChar; cp++)
244c80476e4SDavid E. O'Brien 		*cp = cp[num];
245c80476e4SDavid E. O'Brien 	LastChar -= num;
24623338178SMark Peek 	Cursor -= num;
24745e5710bSMark Peek 	/* Mark was within the range of the deleted word? */
24845e5710bSMark Peek 	if (Mark && Mark > Cursor && Mark <= Cursor+num)
24945e5710bSMark Peek 		Mark = Cursor;
25045e5710bSMark Peek 	/* Mark after the deleted word? */
25145e5710bSMark Peek 	else if (Mark && Mark > Cursor)
25223338178SMark Peek 		Mark -= num;
253c80476e4SDavid E. O'Brien     }
254c80476e4SDavid E. O'Brien }
255c80476e4SDavid E. O'Brien 
256c80476e4SDavid E. O'Brien static Char *
25745e5710bSMark Peek c_preword(Char *p, Char *low, int n, Char *delim)
258c80476e4SDavid E. O'Brien {
259c80476e4SDavid E. O'Brien   while (n--) {
2606767bd61SMark Peek     Char *prev = low;
2616767bd61SMark Peek     Char *new;
262c80476e4SDavid E. O'Brien 
2636767bd61SMark Peek     while (prev < p) {		/* Skip initial non-word chars */
2646767bd61SMark Peek       if (!Strchr(delim, *prev) || *(prev-1) == (Char)'\\')
265c80476e4SDavid E. O'Brien 	break;
266c80476e4SDavid E. O'Brien       prev++;
267c80476e4SDavid E. O'Brien     }
268c80476e4SDavid E. O'Brien 
269c80476e4SDavid E. O'Brien     new = prev;
270c80476e4SDavid E. O'Brien 
271c80476e4SDavid E. O'Brien     while (new < p) {
272c80476e4SDavid E. O'Brien       prev = new;
2736767bd61SMark Peek       new = c_endword(prev-1, p, 1, delim); /* Skip to next non-word char */
274c80476e4SDavid E. O'Brien       new++;			/* Step away from end of word */
2756767bd61SMark Peek       while (new <= p) {	/* Skip trailing non-word chars */
2766767bd61SMark Peek 	if (!Strchr(delim, *new) || *(new-1) == (Char)'\\')
277c80476e4SDavid E. O'Brien 	  break;
278c80476e4SDavid E. O'Brien 	new++;
279c80476e4SDavid E. O'Brien       }
280c80476e4SDavid E. O'Brien     }
281c80476e4SDavid E. O'Brien 
282c80476e4SDavid E. O'Brien     p = prev;			/* Set to previous word start */
283c80476e4SDavid E. O'Brien 
284c80476e4SDavid E. O'Brien   }
285c80476e4SDavid E. O'Brien   if (p < low)
286c80476e4SDavid E. O'Brien     p = low;
287c80476e4SDavid E. O'Brien   return (p);
288c80476e4SDavid E. O'Brien }
289c80476e4SDavid E. O'Brien 
290c80476e4SDavid E. O'Brien /*
291c80476e4SDavid E. O'Brien  * c_to_class() returns the class of the given character.
292c80476e4SDavid E. O'Brien  *
293c80476e4SDavid E. O'Brien  * This is used to make the c_prev_word() and c_next_word() functions
294c80476e4SDavid E. O'Brien  * work like vi's, which classify characters. A word is a sequence of
295c80476e4SDavid E. O'Brien  * characters belonging to the same class, classes being defined as
296c80476e4SDavid E. O'Brien  * follows:
297c80476e4SDavid E. O'Brien  *
298c80476e4SDavid E. O'Brien  *	1/ whitespace
299c80476e4SDavid E. O'Brien  *	2/ alphanumeric chars, + underscore
300c80476e4SDavid E. O'Brien  *	3/ others
301c80476e4SDavid E. O'Brien  */
302c80476e4SDavid E. O'Brien static int
30345e5710bSMark Peek c_to_class(Char ch)
304c80476e4SDavid E. O'Brien {
305c80476e4SDavid E. O'Brien     if (Isspace(ch))
306c80476e4SDavid E. O'Brien         return C_CLASS_WHITE;
307c80476e4SDavid E. O'Brien 
308c80476e4SDavid E. O'Brien     if (Isdigit(ch) || Isalpha(ch) || ch == '_')
309c80476e4SDavid E. O'Brien         return C_CLASS_ALNUM;
310c80476e4SDavid E. O'Brien 
311c80476e4SDavid E. O'Brien     return C_CLASS_OTHER;
312c80476e4SDavid E. O'Brien }
313c80476e4SDavid E. O'Brien 
314c80476e4SDavid E. O'Brien static Char *
31545e5710bSMark Peek c_prev_word(Char *p, Char *low, int n)
316c80476e4SDavid E. O'Brien {
317c80476e4SDavid E. O'Brien     p--;
318c80476e4SDavid E. O'Brien 
319c80476e4SDavid E. O'Brien     if (!VImode) {
320c80476e4SDavid E. O'Brien 	while (n--) {
321c80476e4SDavid E. O'Brien 	    while ((p >= low) && !isword(*p))
322c80476e4SDavid E. O'Brien 		p--;
323c80476e4SDavid E. O'Brien 	    while ((p >= low) && isword(*p))
324c80476e4SDavid E. O'Brien 		p--;
325c80476e4SDavid E. O'Brien 	}
326c80476e4SDavid E. O'Brien 
327c80476e4SDavid E. O'Brien 	/* cp now points to one character before the word */
328c80476e4SDavid E. O'Brien 	p++;
329c80476e4SDavid E. O'Brien 	if (p < low)
330c80476e4SDavid E. O'Brien 	    p = low;
331c80476e4SDavid E. O'Brien 	/* cp now points where we want it */
332c80476e4SDavid E. O'Brien 	return(p);
333c80476e4SDavid E. O'Brien     }
334c80476e4SDavid E. O'Brien 
335c80476e4SDavid E. O'Brien     while (n--) {
3366767bd61SMark Peek         int  c_class;
337c80476e4SDavid E. O'Brien 
338c80476e4SDavid E. O'Brien         if (p < low)
339c80476e4SDavid E. O'Brien             break;
340c80476e4SDavid E. O'Brien 
341c80476e4SDavid E. O'Brien         /* scan until beginning of current word (may be all whitespace!) */
342c80476e4SDavid E. O'Brien         c_class = c_to_class(*p);
343c80476e4SDavid E. O'Brien         while ((p >= low) && c_class == c_to_class(*p))
344c80476e4SDavid E. O'Brien             p--;
345c80476e4SDavid E. O'Brien 
346c80476e4SDavid E. O'Brien         /* if this was a non_whitespace word, we're ready */
347c80476e4SDavid E. O'Brien         if (c_class != C_CLASS_WHITE)
348c80476e4SDavid E. O'Brien             continue;
349c80476e4SDavid E. O'Brien 
350c80476e4SDavid E. O'Brien         /* otherwise, move back to beginning of the word just found */
351c80476e4SDavid E. O'Brien         c_class = c_to_class(*p);
352c80476e4SDavid E. O'Brien         while ((p >= low) && c_class == c_to_class(*p))
353c80476e4SDavid E. O'Brien             p--;
354c80476e4SDavid E. O'Brien     }
355c80476e4SDavid E. O'Brien 
356c80476e4SDavid E. O'Brien     p++;                        /* correct overshoot */
357c80476e4SDavid E. O'Brien 
358c80476e4SDavid E. O'Brien     return (p);
359c80476e4SDavid E. O'Brien }
360c80476e4SDavid E. O'Brien 
361c80476e4SDavid E. O'Brien static Char *
36245e5710bSMark Peek c_next_word(Char *p, Char *high, int n)
363c80476e4SDavid E. O'Brien {
364c80476e4SDavid E. O'Brien     if (!VImode) {
365c80476e4SDavid E. O'Brien 	while (n--) {
366c80476e4SDavid E. O'Brien 	    while ((p < high) && !isword(*p))
367c80476e4SDavid E. O'Brien 		p++;
368c80476e4SDavid E. O'Brien 	    while ((p < high) && isword(*p))
369c80476e4SDavid E. O'Brien 		p++;
370c80476e4SDavid E. O'Brien 	}
371c80476e4SDavid E. O'Brien 	if (p > high)
372c80476e4SDavid E. O'Brien 	    p = high;
373c80476e4SDavid E. O'Brien 	/* p now points where we want it */
374c80476e4SDavid E. O'Brien 	return(p);
375c80476e4SDavid E. O'Brien     }
376c80476e4SDavid E. O'Brien 
377c80476e4SDavid E. O'Brien     while (n--) {
3786767bd61SMark Peek         int  c_class;
379c80476e4SDavid E. O'Brien 
380c80476e4SDavid E. O'Brien         if (p >= high)
381c80476e4SDavid E. O'Brien             break;
382c80476e4SDavid E. O'Brien 
383c80476e4SDavid E. O'Brien         /* scan until end of current word (may be all whitespace!) */
384c80476e4SDavid E. O'Brien         c_class = c_to_class(*p);
385c80476e4SDavid E. O'Brien         while ((p < high) && c_class == c_to_class(*p))
386c80476e4SDavid E. O'Brien             p++;
387c80476e4SDavid E. O'Brien 
388c80476e4SDavid E. O'Brien         /* if this was all whitespace, we're ready */
389c80476e4SDavid E. O'Brien         if (c_class == C_CLASS_WHITE)
390c80476e4SDavid E. O'Brien             continue;
391c80476e4SDavid E. O'Brien 
392c80476e4SDavid E. O'Brien 	/* if we've found white-space at the end of the word, skip it */
393c80476e4SDavid E. O'Brien         while ((p < high) && c_to_class(*p) == C_CLASS_WHITE)
394c80476e4SDavid E. O'Brien             p++;
395c80476e4SDavid E. O'Brien     }
396c80476e4SDavid E. O'Brien 
397c80476e4SDavid E. O'Brien     p--;                        /* correct overshoot */
398c80476e4SDavid E. O'Brien 
399c80476e4SDavid E. O'Brien     return (p);
400c80476e4SDavid E. O'Brien }
401c80476e4SDavid E. O'Brien 
402c80476e4SDavid E. O'Brien static Char *
40345e5710bSMark Peek c_nexword(Char *p, Char *high, int n)
404c80476e4SDavid E. O'Brien {
405c80476e4SDavid E. O'Brien     while (n--) {
406c80476e4SDavid E. O'Brien 	while ((p < high) && !Isspace(*p))
407c80476e4SDavid E. O'Brien 	    p++;
408c80476e4SDavid E. O'Brien 	while ((p < high) && Isspace(*p))
409c80476e4SDavid E. O'Brien 	    p++;
410c80476e4SDavid E. O'Brien     }
411c80476e4SDavid E. O'Brien 
412c80476e4SDavid E. O'Brien     if (p > high)
413c80476e4SDavid E. O'Brien 	p = high;
414c80476e4SDavid E. O'Brien     /* p now points where we want it */
415c80476e4SDavid E. O'Brien     return(p);
416c80476e4SDavid E. O'Brien }
417c80476e4SDavid E. O'Brien 
418c80476e4SDavid E. O'Brien /*
419c80476e4SDavid E. O'Brien  * Expand-History (originally "Magic-Space") code added by
420c80476e4SDavid E. O'Brien  * Ray Moody <ray@gibbs.physics.purdue.edu>
421c80476e4SDavid E. O'Brien  * this is a neat, but odd, addition.
422c80476e4SDavid E. O'Brien  */
423c80476e4SDavid E. O'Brien 
424c80476e4SDavid E. O'Brien /*
425c80476e4SDavid E. O'Brien  * c_number: Ignore character p points to, return number appearing after that.
426c80476e4SDavid E. O'Brien  * A '$' by itself means a big number; "$-" is for negative; '^' means 1.
427c80476e4SDavid E. O'Brien  * Return p pointing to last char used.
428c80476e4SDavid E. O'Brien  */
429c80476e4SDavid E. O'Brien 
430c80476e4SDavid E. O'Brien /*
431c80476e4SDavid E. O'Brien  * dval is the number to subtract from for things like $-3
432c80476e4SDavid E. O'Brien  */
433c80476e4SDavid E. O'Brien 
434c80476e4SDavid E. O'Brien static Char *
43545e5710bSMark Peek c_number(Char *p, int *num, int dval)
436c80476e4SDavid E. O'Brien {
4376767bd61SMark Peek     int i;
4386767bd61SMark Peek     int sign = 1;
439c80476e4SDavid E. O'Brien 
440c80476e4SDavid E. O'Brien     if (*++p == '^') {
441c80476e4SDavid E. O'Brien 	*num = 1;
442c80476e4SDavid E. O'Brien 	return(p);
443c80476e4SDavid E. O'Brien     }
444c80476e4SDavid E. O'Brien     if (*p == '$') {
445c80476e4SDavid E. O'Brien 	if (*++p != '-') {
44645e5710bSMark Peek 	    *num = INT_MAX;	/* Handle $ */
447c80476e4SDavid E. O'Brien 	    return(--p);
448c80476e4SDavid E. O'Brien 	}
449c80476e4SDavid E. O'Brien 	sign = -1;		/* Handle $- */
450c80476e4SDavid E. O'Brien 	++p;
451c80476e4SDavid E. O'Brien     }
452c80476e4SDavid E. O'Brien     for (i = 0; *p >= '0' && *p <= '9'; i = 10 * i + *p++ - '0')
453c80476e4SDavid E. O'Brien 	continue;
454c80476e4SDavid E. O'Brien     *num = (sign < 0 ? dval - i : i);
455c80476e4SDavid E. O'Brien     return(--p);
456c80476e4SDavid E. O'Brien }
457c80476e4SDavid E. O'Brien 
458c80476e4SDavid E. O'Brien /*
459c80476e4SDavid E. O'Brien  * excl_expand: There is an excl to be expanded to p -- do the right thing
460c80476e4SDavid E. O'Brien  * with it and return a version of p advanced over the expanded stuff.  Also,
461c80476e4SDavid E. O'Brien  * update tsh_cur and related things as appropriate...
462c80476e4SDavid E. O'Brien  */
463c80476e4SDavid E. O'Brien 
464c80476e4SDavid E. O'Brien static Char *
46545e5710bSMark Peek c_expand(Char *p)
466c80476e4SDavid E. O'Brien {
4676767bd61SMark Peek     Char *q;
4686767bd61SMark Peek     struct Hist *h = Histlist.Hnext;
4696767bd61SMark Peek     struct wordent *l;
470c80476e4SDavid E. O'Brien     int     i, from, to, dval;
47123338178SMark Peek     int    all_dig;
47223338178SMark Peek     int    been_once = 0;
473c80476e4SDavid E. O'Brien     Char   *op = p;
47445e5710bSMark Peek     Char   *buf;
47545e5710bSMark Peek     size_t buf_len;
47645e5710bSMark Peek     Char   *modbuf;
477c80476e4SDavid E. O'Brien 
47845e5710bSMark Peek     buf = NULL;
479c80476e4SDavid E. O'Brien     if (!h)
480c80476e4SDavid E. O'Brien 	goto excl_err;
481c80476e4SDavid E. O'Brien excl_sw:
482c80476e4SDavid E. O'Brien     switch (*(q = p + 1)) {
483c80476e4SDavid E. O'Brien 
484c80476e4SDavid E. O'Brien     case '^':
48545e5710bSMark Peek 	buf = expand_lex(&h->Hlex, 1, 1);
486c80476e4SDavid E. O'Brien 	break;
487c80476e4SDavid E. O'Brien 
488c80476e4SDavid E. O'Brien     case '$':
489c80476e4SDavid E. O'Brien 	if ((l = (h->Hlex).prev) != 0)
49045e5710bSMark Peek 	    buf = expand_lex(l->prev->prev, 0, 0);
491c80476e4SDavid E. O'Brien 	break;
492c80476e4SDavid E. O'Brien 
493c80476e4SDavid E. O'Brien     case '*':
49445e5710bSMark Peek 	buf = expand_lex(&h->Hlex, 1, INT_MAX);
495c80476e4SDavid E. O'Brien 	break;
496c80476e4SDavid E. O'Brien 
497c80476e4SDavid E. O'Brien     default:
498c80476e4SDavid E. O'Brien 	if (been_once) {	/* unknown argument */
499c80476e4SDavid E. O'Brien 	    /* assume it's a modifier, e.g. !foo:h, and get whole cmd */
50045e5710bSMark Peek 	    buf = expand_lex(&h->Hlex, 0, INT_MAX);
501c80476e4SDavid E. O'Brien 	    q -= 2;
502c80476e4SDavid E. O'Brien 	    break;
503c80476e4SDavid E. O'Brien 	}
504c80476e4SDavid E. O'Brien 	been_once = 1;
505c80476e4SDavid E. O'Brien 
506c80476e4SDavid E. O'Brien 	if (*q == ':')		/* short form: !:arg */
507c80476e4SDavid E. O'Brien 	    --q;
508c80476e4SDavid E. O'Brien 
509c80476e4SDavid E. O'Brien 	if (*q != HIST) {
510c80476e4SDavid E. O'Brien 	    /*
511c80476e4SDavid E. O'Brien 	     * Search for a space, tab, or colon.  See if we have a number (as
512c80476e4SDavid E. O'Brien 	     * in !1234:xyz).  Remember the number.
513c80476e4SDavid E. O'Brien 	     */
514c80476e4SDavid E. O'Brien 	    for (i = 0, all_dig = 1;
515c80476e4SDavid E. O'Brien 		 *q != ' ' && *q != '\t' && *q != ':' && q < Cursor; q++) {
516c80476e4SDavid E. O'Brien 		/*
517c80476e4SDavid E. O'Brien 		 * PWP: !-4 is a valid history argument too, therefore the test
518c80476e4SDavid E. O'Brien 		 * is if not a digit, or not a - as the first character.
519c80476e4SDavid E. O'Brien 		 */
520c80476e4SDavid E. O'Brien 		if ((*q < '0' || *q > '9') && (*q != '-' || q != p + 1))
521c80476e4SDavid E. O'Brien 		    all_dig = 0;
522c80476e4SDavid E. O'Brien 		else if (*q == '-')
523c80476e4SDavid E. O'Brien 		    all_dig = 2;/* we are sneeky about this */
524c80476e4SDavid E. O'Brien 		else
525c80476e4SDavid E. O'Brien 		    i = 10 * i + *q - '0';
526c80476e4SDavid E. O'Brien 	    }
527c80476e4SDavid E. O'Brien 	    --q;
528c80476e4SDavid E. O'Brien 
529c80476e4SDavid E. O'Brien 	    /*
530c80476e4SDavid E. O'Brien 	     * If we have a number, search for event i.  Otherwise, search for
531c80476e4SDavid E. O'Brien 	     * a named event (as in !foo).  (In this case, I is the length of
532c80476e4SDavid E. O'Brien 	     * the named event).
533c80476e4SDavid E. O'Brien 	     */
534c80476e4SDavid E. O'Brien 	    if (all_dig) {
535c80476e4SDavid E. O'Brien 		if (all_dig == 2)
536c80476e4SDavid E. O'Brien 		    i = -i;	/* make it negitive */
537c80476e4SDavid E. O'Brien 		if (i < 0)	/* if !-4 (for example) */
538c80476e4SDavid E. O'Brien 		    i = eventno + 1 + i;	/* remember: i is < 0 */
539c80476e4SDavid E. O'Brien 		for (; h; h = h->Hnext) {
540c80476e4SDavid E. O'Brien 		    if (h->Hnum == i)
541c80476e4SDavid E. O'Brien 			break;
542c80476e4SDavid E. O'Brien 		}
543c80476e4SDavid E. O'Brien 	    }
544c80476e4SDavid E. O'Brien 	    else {
545c80476e4SDavid E. O'Brien 		for (i = (int) (q - p); h; h = h->Hnext) {
546c80476e4SDavid E. O'Brien 		    if ((l = &h->Hlex) != 0) {
547c80476e4SDavid E. O'Brien 			if (!Strncmp(p + 1, l->next->word, (size_t) i))
548c80476e4SDavid E. O'Brien 			    break;
549c80476e4SDavid E. O'Brien 		    }
550c80476e4SDavid E. O'Brien 		}
551c80476e4SDavid E. O'Brien 	    }
552c80476e4SDavid E. O'Brien 	}
553c80476e4SDavid E. O'Brien 	if (!h)
554c80476e4SDavid E. O'Brien 	    goto excl_err;
555c80476e4SDavid E. O'Brien 	if (q[1] == ':' || q[1] == '-' || q[1] == '*' ||
556c80476e4SDavid E. O'Brien 	    q[1] == '$' || q[1] == '^') {	/* get some args */
557c80476e4SDavid E. O'Brien 	    p = q[1] == ':' ? ++q : q;
558c80476e4SDavid E. O'Brien 	    /*
559c80476e4SDavid E. O'Brien 	     * Go handle !foo:*
560c80476e4SDavid E. O'Brien 	     */
561c80476e4SDavid E. O'Brien 	    if ((q[1] < '0' || q[1] > '9') &&
562c80476e4SDavid E. O'Brien 		q[1] != '-' && q[1] != '$' && q[1] != '^')
563c80476e4SDavid E. O'Brien 		goto excl_sw;
564c80476e4SDavid E. O'Brien 	    /*
565c80476e4SDavid E. O'Brien 	     * Go handle !foo:$
566c80476e4SDavid E. O'Brien 	     */
567c80476e4SDavid E. O'Brien 	    if (q[1] == '$' && (q[2] != '-' || q[3] < '0' || q[3] > '9'))
568c80476e4SDavid E. O'Brien 		goto excl_sw;
569c80476e4SDavid E. O'Brien 	    /*
570c80476e4SDavid E. O'Brien 	     * Count up the number of words in this event.  Store it in dval.
571c80476e4SDavid E. O'Brien 	     * Dval will be fed to number.
572c80476e4SDavid E. O'Brien 	     */
573c80476e4SDavid E. O'Brien 	    dval = 0;
574c80476e4SDavid E. O'Brien 	    if ((l = h->Hlex.prev) != 0) {
575c80476e4SDavid E. O'Brien 		for (l = l->prev; l != h->Hlex.next; l = l->prev, dval++)
576c80476e4SDavid E. O'Brien 		    continue;
577c80476e4SDavid E. O'Brien 	    }
578c80476e4SDavid E. O'Brien 	    if (!dval)
579c80476e4SDavid E. O'Brien 		goto excl_err;
580c80476e4SDavid E. O'Brien 	    if (q[1] == '-')
581c80476e4SDavid E. O'Brien 		from = 0;
582c80476e4SDavid E. O'Brien 	    else
583c80476e4SDavid E. O'Brien 		q = c_number(q, &from, dval);
584c80476e4SDavid E. O'Brien 	    if (q[1] == '-') {
585c80476e4SDavid E. O'Brien 		++q;
586c80476e4SDavid E. O'Brien 		if ((q[1] < '0' || q[1] > '9') && q[1] != '$')
587c80476e4SDavid E. O'Brien 		    to = dval - 1;
588c80476e4SDavid E. O'Brien 		else
589c80476e4SDavid E. O'Brien 		    q = c_number(q, &to, dval);
590c80476e4SDavid E. O'Brien 	    }
591c80476e4SDavid E. O'Brien 	    else if (q[1] == '*') {
592c80476e4SDavid E. O'Brien 		++q;
59345e5710bSMark Peek 		to = INT_MAX;
594c80476e4SDavid E. O'Brien 	    }
595c80476e4SDavid E. O'Brien 	    else {
596c80476e4SDavid E. O'Brien 		to = from;
597c80476e4SDavid E. O'Brien 	    }
598c80476e4SDavid E. O'Brien 	    if (from < 0 || to < from)
599c80476e4SDavid E. O'Brien 		goto excl_err;
60045e5710bSMark Peek 	    buf = expand_lex(&h->Hlex, from, to);
601c80476e4SDavid E. O'Brien 	}
60245e5710bSMark Peek 	else			/* get whole cmd */
60345e5710bSMark Peek 	    buf = expand_lex(&h->Hlex, 0, INT_MAX);
604c80476e4SDavid E. O'Brien 	break;
605c80476e4SDavid E. O'Brien     }
60645e5710bSMark Peek     if (buf == NULL)
60745e5710bSMark Peek 	buf = SAVE("");
608c80476e4SDavid E. O'Brien 
609c80476e4SDavid E. O'Brien     /*
610c80476e4SDavid E. O'Brien      * Apply modifiers, if any.
611c80476e4SDavid E. O'Brien      */
612c80476e4SDavid E. O'Brien     if (q[1] == ':') {
61345e5710bSMark Peek 	modbuf = buf;
614c80476e4SDavid E. O'Brien 	while (q[1] == ':' && modbuf != NULL) {
615c80476e4SDavid E. O'Brien 	    switch (q[2]) {
616c80476e4SDavid E. O'Brien 	    case 'r':
617c80476e4SDavid E. O'Brien 	    case 'e':
618c80476e4SDavid E. O'Brien 	    case 'h':
619c80476e4SDavid E. O'Brien 	    case 't':
620c80476e4SDavid E. O'Brien 	    case 'q':
621c80476e4SDavid E. O'Brien 	    case 'x':
622c80476e4SDavid E. O'Brien 	    case 'u':
623c80476e4SDavid E. O'Brien 	    case 'l':
62445e5710bSMark Peek 		if ((modbuf = domod(buf, (int) q[2])) != NULL) {
62545e5710bSMark Peek 		    xfree(buf);
62645e5710bSMark Peek 		    buf = modbuf;
627c80476e4SDavid E. O'Brien 		}
628c80476e4SDavid E. O'Brien 		++q;
629c80476e4SDavid E. O'Brien 		break;
630c80476e4SDavid E. O'Brien 
631c80476e4SDavid E. O'Brien 	    case 'a':
632c80476e4SDavid E. O'Brien 	    case 'g':
633c80476e4SDavid E. O'Brien 		/* Not implemented; this needs to be done before expanding
634c80476e4SDavid E. O'Brien 		 * lex. We don't have the words available to us anymore.
635c80476e4SDavid E. O'Brien 		 */
636c80476e4SDavid E. O'Brien 		++q;
637c80476e4SDavid E. O'Brien 		break;
638c80476e4SDavid E. O'Brien 
639c80476e4SDavid E. O'Brien 	    case 'p':
640c80476e4SDavid E. O'Brien 		/* Ok */
641c80476e4SDavid E. O'Brien 		++q;
642c80476e4SDavid E. O'Brien 		break;
643c80476e4SDavid E. O'Brien 
644c80476e4SDavid E. O'Brien 	    case '\0':
645c80476e4SDavid E. O'Brien 		break;
646c80476e4SDavid E. O'Brien 
647c80476e4SDavid E. O'Brien 	    default:
648c80476e4SDavid E. O'Brien 		++q;
649c80476e4SDavid E. O'Brien 		break;
650c80476e4SDavid E. O'Brien 	    }
651c80476e4SDavid E. O'Brien 	    if (q[1])
652c80476e4SDavid E. O'Brien 		++q;
653c80476e4SDavid E. O'Brien 	}
654c80476e4SDavid E. O'Brien     }
655c80476e4SDavid E. O'Brien 
65645e5710bSMark Peek     buf_len = Strlen(buf);
657c80476e4SDavid E. O'Brien     /*
65845e5710bSMark Peek      * Now replace the text from op to q inclusive with the text from buf.
659c80476e4SDavid E. O'Brien      */
660c80476e4SDavid E. O'Brien     q++;
661c80476e4SDavid E. O'Brien 
662c80476e4SDavid E. O'Brien     /*
663c80476e4SDavid E. O'Brien      * Now replace text non-inclusively like a real CS major!
664c80476e4SDavid E. O'Brien      */
66545e5710bSMark Peek     if (LastChar + buf_len - (q - op) >= InputLim)
666c80476e4SDavid E. O'Brien 	goto excl_err;
66745e5710bSMark Peek     (void) memmove(op + buf_len, q, (LastChar - q) * sizeof(Char));
66845e5710bSMark Peek     LastChar += buf_len - (q - op);
66945e5710bSMark Peek     Cursor += buf_len - (q - op);
67045e5710bSMark Peek     (void) memcpy(op, buf, buf_len * sizeof(Char));
671c80476e4SDavid E. O'Brien     *LastChar = '\0';
67245e5710bSMark Peek     xfree(buf);
67345e5710bSMark Peek     return op + buf_len;
674c80476e4SDavid E. O'Brien excl_err:
67545e5710bSMark Peek     xfree(buf);
676c80476e4SDavid E. O'Brien     SoundBeep();
677c80476e4SDavid E. O'Brien     return(op + 1);
678c80476e4SDavid E. O'Brien }
679c80476e4SDavid E. O'Brien 
680c80476e4SDavid E. O'Brien /*
681c80476e4SDavid E. O'Brien  * c_excl: An excl has been found at point p -- back up and find some white
682c80476e4SDavid E. O'Brien  * space (or the beginning of the buffer) and properly expand all the excl's
683c80476e4SDavid E. O'Brien  * from there up to the current cursor position. We also avoid (trying to)
684c80476e4SDavid E. O'Brien  * expanding '>!'
685a15e6f9aSMark Peek  * Returns number of expansions attempted (doesn't matter whether they succeeded
686a15e6f9aSMark Peek  * or not).
687c80476e4SDavid E. O'Brien  */
688c80476e4SDavid E. O'Brien 
689a15e6f9aSMark Peek static int
69045e5710bSMark Peek c_excl(Char *p)
691c80476e4SDavid E. O'Brien {
6926767bd61SMark Peek     int i;
6936767bd61SMark Peek     Char *q;
694a15e6f9aSMark Peek     int nr_exp;
695c80476e4SDavid E. O'Brien 
696c80476e4SDavid E. O'Brien     /*
697c80476e4SDavid E. O'Brien      * if />[SPC TAB]*![SPC TAB]/, back up p to just after the >. otherwise,
698c80476e4SDavid E. O'Brien      * back p up to just before the current word.
699c80476e4SDavid E. O'Brien      */
700c80476e4SDavid E. O'Brien     if ((p[1] == ' ' || p[1] == '\t') &&
701c80476e4SDavid E. O'Brien 	(p[-1] == ' ' || p[-1] == '\t' || p[-1] == '>')) {
702c80476e4SDavid E. O'Brien 	for (q = p - 1; q > InputBuf && (*q == ' ' || *q == '\t'); --q)
703c80476e4SDavid E. O'Brien 	    continue;
704c80476e4SDavid E. O'Brien 	if (*q == '>')
705c80476e4SDavid E. O'Brien 	    ++p;
706c80476e4SDavid E. O'Brien     }
707c80476e4SDavid E. O'Brien     else {
708c80476e4SDavid E. O'Brien 	while (*p != ' ' && *p != '\t' && p > InputBuf)
709c80476e4SDavid E. O'Brien 	    --p;
710c80476e4SDavid E. O'Brien     }
711c80476e4SDavid E. O'Brien 
712c80476e4SDavid E. O'Brien     /*
713c80476e4SDavid E. O'Brien      * Forever: Look for history char.  (Stop looking when we find the cursor.)
714a15e6f9aSMark Peek      * Count backslashes.  If odd, skip history char.  Expand if even number of
715a15e6f9aSMark Peek      * backslashes.
716c80476e4SDavid E. O'Brien      */
717a15e6f9aSMark Peek     nr_exp = 0;
718c80476e4SDavid E. O'Brien     for (;;) {
719c80476e4SDavid E. O'Brien 	while (*p != HIST && p < Cursor)
720c80476e4SDavid E. O'Brien 	    ++p;
721c80476e4SDavid E. O'Brien 	for (i = 1; (p - i) >= InputBuf && p[-i] == '\\'; i++)
722c80476e4SDavid E. O'Brien 	    continue;
723c80476e4SDavid E. O'Brien 	if (i % 2 == 0)
724c80476e4SDavid E. O'Brien 	    ++p;
725a15e6f9aSMark Peek 	if (p >= Cursor)   /* all done */
726a15e6f9aSMark Peek 	    return nr_exp;
727a15e6f9aSMark Peek 	if (i % 2 == 1) {
728c80476e4SDavid E. O'Brien 	    p = c_expand(p);
729a15e6f9aSMark Peek 	    ++nr_exp;
730c80476e4SDavid E. O'Brien 	}
731c80476e4SDavid E. O'Brien     }
732c80476e4SDavid E. O'Brien 
733a15e6f9aSMark Peek     return nr_exp;
734a15e6f9aSMark Peek }
735c80476e4SDavid E. O'Brien 
736a15e6f9aSMark Peek 
737a15e6f9aSMark Peek static int
73845e5710bSMark Peek c_substitute(void)
739c80476e4SDavid E. O'Brien {
7406767bd61SMark Peek     Char *p;
741a15e6f9aSMark Peek     int  nr_exp;
742c80476e4SDavid E. O'Brien 
743c80476e4SDavid E. O'Brien     /*
744c80476e4SDavid E. O'Brien      * Start p out one character before the cursor.  Move it backwards looking
745c80476e4SDavid E. O'Brien      * for white space, the beginning of the line, or a history character.
746c80476e4SDavid E. O'Brien      */
747c80476e4SDavid E. O'Brien     for (p = Cursor - 1;
748c80476e4SDavid E. O'Brien 	 p > InputBuf && *p != ' ' && *p != '\t' && *p != HIST; --p)
749c80476e4SDavid E. O'Brien 	continue;
750c80476e4SDavid E. O'Brien 
751c80476e4SDavid E. O'Brien     /*
752c80476e4SDavid E. O'Brien      * If we found a history character, go expand it.
753c80476e4SDavid E. O'Brien      */
754c80476e4SDavid E. O'Brien     if (*p == HIST)
755a15e6f9aSMark Peek 	nr_exp = c_excl(p);
756a15e6f9aSMark Peek     else
757a15e6f9aSMark Peek         nr_exp = 0;
758c80476e4SDavid E. O'Brien     Refresh();
759a15e6f9aSMark Peek 
760a15e6f9aSMark Peek     return nr_exp;
761c80476e4SDavid E. O'Brien }
762c80476e4SDavid E. O'Brien 
763c80476e4SDavid E. O'Brien static void
76445e5710bSMark Peek c_delfini(void)		/* Finish up delete action */
765c80476e4SDavid E. O'Brien {
7666767bd61SMark Peek     int Size;
767c80476e4SDavid E. O'Brien 
768c80476e4SDavid E. O'Brien     if (ActionFlag & TCSHOP_INSERT)
769c80476e4SDavid E. O'Brien 	c_alternativ_key_map(0);
770c80476e4SDavid E. O'Brien 
771c80476e4SDavid E. O'Brien     ActionFlag = TCSHOP_NOP;
772c80476e4SDavid E. O'Brien 
773c80476e4SDavid E. O'Brien     if (ActionPos == 0)
774c80476e4SDavid E. O'Brien 	return;
775c80476e4SDavid E. O'Brien 
776c80476e4SDavid E. O'Brien     UndoAction = TCSHOP_INSERT;
777c80476e4SDavid E. O'Brien 
778c80476e4SDavid E. O'Brien     if (Cursor > ActionPos) {
779c80476e4SDavid E. O'Brien 	Size = (int) (Cursor-ActionPos);
780c80476e4SDavid E. O'Brien 	c_delbefore(Size);
781c80476e4SDavid E. O'Brien 	RefCursor();
782c80476e4SDavid E. O'Brien     }
783c80476e4SDavid E. O'Brien     else if (Cursor < ActionPos) {
784c80476e4SDavid E. O'Brien 	Size = (int)(ActionPos-Cursor);
785c80476e4SDavid E. O'Brien 	c_delafter(Size);
786c80476e4SDavid E. O'Brien     }
787c80476e4SDavid E. O'Brien     else  {
788c80476e4SDavid E. O'Brien 	Size = 1;
789c80476e4SDavid E. O'Brien 	c_delafter(Size);
790c80476e4SDavid E. O'Brien     }
791c80476e4SDavid E. O'Brien     UndoPtr = Cursor;
792c80476e4SDavid E. O'Brien     UndoSize = Size;
793c80476e4SDavid E. O'Brien }
794c80476e4SDavid E. O'Brien 
795c80476e4SDavid E. O'Brien static Char *
79645e5710bSMark Peek c_endword(Char *p, Char *high, int n, Char *delim)
797c80476e4SDavid E. O'Brien {
79823338178SMark Peek     Char inquote = 0;
799c80476e4SDavid E. O'Brien     p++;
800c80476e4SDavid E. O'Brien 
801c80476e4SDavid E. O'Brien     while (n--) {
8026767bd61SMark Peek         while (p < high) {	/* Skip non-word chars */
8036767bd61SMark Peek 	  if (!Strchr(delim, *p) || *(p-1) == (Char)'\\')
804c80476e4SDavid E. O'Brien 	    break;
805c80476e4SDavid E. O'Brien 	  p++;
806c80476e4SDavid E. O'Brien         }
807c80476e4SDavid E. O'Brien 	while (p < high) {	/* Skip string */
808c80476e4SDavid E. O'Brien 	  if ((*p == (Char)'\'' || *p == (Char)'"')) { /* Quotation marks? */
8096767bd61SMark Peek 	    if (inquote || *(p-1) != (Char)'\\') { /* Should it be honored? */
810c80476e4SDavid E. O'Brien 	      if (inquote == 0) inquote = *p;
811c80476e4SDavid E. O'Brien 	      else if (inquote == *p) inquote = 0;
812c80476e4SDavid E. O'Brien 	    }
813c80476e4SDavid E. O'Brien 	  }
8146767bd61SMark Peek 	  /* Break if unquoted non-word char */
8156767bd61SMark Peek 	  if (!inquote && Strchr(delim, *p) && *(p-1) != (Char)'\\')
816c80476e4SDavid E. O'Brien 	    break;
817c80476e4SDavid E. O'Brien 	  p++;
818c80476e4SDavid E. O'Brien 	}
819c80476e4SDavid E. O'Brien     }
820c80476e4SDavid E. O'Brien 
821c80476e4SDavid E. O'Brien     p--;
822c80476e4SDavid E. O'Brien     return(p);
823c80476e4SDavid E. O'Brien }
824c80476e4SDavid E. O'Brien 
825c80476e4SDavid E. O'Brien 
826c80476e4SDavid E. O'Brien static Char *
82745e5710bSMark Peek c_eword(Char *p, Char *high, int n)
828c80476e4SDavid E. O'Brien {
829c80476e4SDavid E. O'Brien     p++;
830c80476e4SDavid E. O'Brien 
831c80476e4SDavid E. O'Brien     while (n--) {
832c80476e4SDavid E. O'Brien 	while ((p < high) && Isspace(*p))
833c80476e4SDavid E. O'Brien 	    p++;
834c80476e4SDavid E. O'Brien 
835c80476e4SDavid E. O'Brien 	if (Isalnum(*p))
836c80476e4SDavid E. O'Brien 	    while ((p < high) && Isalnum(*p))
837c80476e4SDavid E. O'Brien 		p++;
838c80476e4SDavid E. O'Brien 	else
839c80476e4SDavid E. O'Brien 	    while ((p < high) && !(Isspace(*p) || Isalnum(*p)))
840c80476e4SDavid E. O'Brien 		p++;
841c80476e4SDavid E. O'Brien     }
842c80476e4SDavid E. O'Brien 
843c80476e4SDavid E. O'Brien     p--;
844c80476e4SDavid E. O'Brien     return(p);
845c80476e4SDavid E. O'Brien }
846c80476e4SDavid E. O'Brien 
8476767bd61SMark Peek /* Set the max length of the kill ring */
8486767bd61SMark Peek void
84945e5710bSMark Peek SetKillRing(int max)
8506767bd61SMark Peek {
8516767bd61SMark Peek     CStr *new;
8526767bd61SMark Peek     int count, i, j;
8536767bd61SMark Peek 
8546767bd61SMark Peek     if (max < 1)
8556767bd61SMark Peek 	max = 1;		/* no ring, but always one buffer */
8566767bd61SMark Peek     if (max == KillRingMax)
8576767bd61SMark Peek 	return;
85845e5710bSMark Peek     new = xcalloc(max, sizeof(CStr));
8596767bd61SMark Peek     if (KillRing != NULL) {
8606767bd61SMark Peek 	if (KillRingLen != 0) {
8616767bd61SMark Peek 	    if (max >= KillRingLen) {
8626767bd61SMark Peek 		count = KillRingLen;
8636767bd61SMark Peek 		j = KillPos;
8646767bd61SMark Peek 	    } else {
8656767bd61SMark Peek 		count = max;
8666767bd61SMark Peek 		j = (KillPos - count + KillRingLen) % KillRingLen;
8676767bd61SMark Peek 	    }
8686767bd61SMark Peek 	    for (i = 0; i < KillRingLen; i++) {
8696767bd61SMark Peek 		if (i < count)	/* copy latest */
8706767bd61SMark Peek 		    new[i] = KillRing[j];
8716767bd61SMark Peek 		else		/* free the others */
8726767bd61SMark Peek 		    xfree(KillRing[j].buf);
8736767bd61SMark Peek 		j = (j + 1) % KillRingLen;
8746767bd61SMark Peek 	    }
8756767bd61SMark Peek 	    KillRingLen = count;
8766767bd61SMark Peek 	    KillPos = count % max;
8776767bd61SMark Peek 	    YankPos = count - 1;
8786767bd61SMark Peek 	}
8796767bd61SMark Peek 	xfree(KillRing);
8806767bd61SMark Peek     }
8816767bd61SMark Peek     KillRing = new;
8826767bd61SMark Peek     KillRingMax = max;
8836767bd61SMark Peek }
8846767bd61SMark Peek 
8856767bd61SMark Peek /* Push string from start upto (but not including) end onto kill ring */
8866767bd61SMark Peek static void
88745e5710bSMark Peek c_push_kill(Char *start, Char *end)
8886767bd61SMark Peek {
8896767bd61SMark Peek     CStr save, *pos;
8906767bd61SMark Peek     Char *dp, *cp, *kp;
8916767bd61SMark Peek     int len = end - start, i, j, k;
8926767bd61SMark Peek 
8936767bd61SMark Peek     /* Check for duplicates? */
8946767bd61SMark Peek     if (KillRingLen > 0 && (dp = varval(STRkilldup)) != STRNULL) {
8956767bd61SMark Peek 	YankPos = (KillPos - 1 + KillRingLen) % KillRingLen;
8966767bd61SMark Peek 	if (eq(dp, STRerase)) {	/* erase earlier one (actually move up) */
8976767bd61SMark Peek 	    j = YankPos;
8986767bd61SMark Peek 	    for (i = 0; i < KillRingLen; i++) {
8996767bd61SMark Peek 		if (Strncmp(KillRing[j].buf, start, (size_t) len) == 0 &&
9006767bd61SMark Peek 		    KillRing[j].buf[len] == '\0') {
9016767bd61SMark Peek 		    save = KillRing[j];
9026767bd61SMark Peek 		    for ( ; i > 0; i--) {
9036767bd61SMark Peek 			k = j;
9046767bd61SMark Peek 			j = (j + 1) % KillRingLen;
9056767bd61SMark Peek 			KillRing[k] = KillRing[j];
9066767bd61SMark Peek 		    }
9076767bd61SMark Peek 		    KillRing[j] = save;
9086767bd61SMark Peek 		    return;
9096767bd61SMark Peek 		}
9106767bd61SMark Peek 		j = (j - 1 + KillRingLen) % KillRingLen;
9116767bd61SMark Peek 	    }
9126767bd61SMark Peek 	} else if (eq(dp, STRall)) { /* skip if any earlier */
9136767bd61SMark Peek 	    for (i = 0; i < KillRingLen; i++)
9146767bd61SMark Peek 		if (Strncmp(KillRing[i].buf, start, (size_t) len) == 0 &&
9156767bd61SMark Peek 		    KillRing[i].buf[len] == '\0')
9166767bd61SMark Peek 		    return;
9176767bd61SMark Peek 	} else if (eq(dp, STRprev)) { /* skip if immediately previous */
9186767bd61SMark Peek 	    j = YankPos;
9196767bd61SMark Peek 	    if (Strncmp(KillRing[j].buf, start, (size_t) len) == 0 &&
9206767bd61SMark Peek 		KillRing[j].buf[len] == '\0')
9216767bd61SMark Peek 		return;
9226767bd61SMark Peek 	}
9236767bd61SMark Peek     }
9246767bd61SMark Peek 
9256767bd61SMark Peek     /* No duplicate, go ahead and push */
9266767bd61SMark Peek     len++;			/* need space for '\0' */
9276767bd61SMark Peek     YankPos = KillPos;
9286767bd61SMark Peek     if (KillRingLen < KillRingMax)
9296767bd61SMark Peek 	KillRingLen++;
9306767bd61SMark Peek     pos = &KillRing[KillPos];
9316767bd61SMark Peek     KillPos = (KillPos + 1) % KillRingMax;
9326767bd61SMark Peek     if (pos->len < len) {
93345e5710bSMark Peek 	pos->buf = xrealloc(pos->buf, len * sizeof(Char));
9346767bd61SMark Peek 	pos->len = len;
9356767bd61SMark Peek     }
9366767bd61SMark Peek     cp = start;
9376767bd61SMark Peek     kp = pos->buf;
9386767bd61SMark Peek     while (cp < end)
9396767bd61SMark Peek 	*kp++ = *cp++;
9406767bd61SMark Peek     *kp = '\0';
9416767bd61SMark Peek }
9426767bd61SMark Peek 
94345e5710bSMark Peek /* Save InputBuf etc in SavedBuf etc for restore after cmd exec */
94445e5710bSMark Peek static void
94545e5710bSMark Peek c_save_inputbuf()
94645e5710bSMark Peek {
94745e5710bSMark Peek     SavedBuf.len = 0;
94845e5710bSMark Peek     Strbuf_append(&SavedBuf, InputBuf);
94945e5710bSMark Peek     Strbuf_terminate(&SavedBuf);
95045e5710bSMark Peek     LastSaved = LastChar - InputBuf;
95145e5710bSMark Peek     CursSaved = Cursor - InputBuf;
95245e5710bSMark Peek     HistSaved = Hist_num;
95345e5710bSMark Peek     RestoreSaved = 1;
95445e5710bSMark Peek }
95545e5710bSMark Peek 
95645e5710bSMark Peek CCRETVAL
95745e5710bSMark Peek GetHistLine()
958c80476e4SDavid E. O'Brien {
959c80476e4SDavid E. O'Brien     struct Hist *hp;
960c80476e4SDavid E. O'Brien     int     h;
961c80476e4SDavid E. O'Brien 
962c80476e4SDavid E. O'Brien     if (Hist_num == 0) {	/* if really the current line */
96345e5710bSMark Peek 	if (HistBuf.s != NULL)
96445e5710bSMark Peek 	    copyn(InputBuf, HistBuf.s, INBUFSIZE);/*FIXBUF*/
96545e5710bSMark Peek 	else
96645e5710bSMark Peek 	    *InputBuf = '\0';
96745e5710bSMark Peek 	LastChar = InputBuf + HistBuf.len;
968c80476e4SDavid E. O'Brien 
969c80476e4SDavid E. O'Brien #ifdef KSHVI
970c80476e4SDavid E. O'Brien     if (VImode)
971c80476e4SDavid E. O'Brien 	Cursor = InputBuf;
972c80476e4SDavid E. O'Brien     else
973c80476e4SDavid E. O'Brien #endif /* KSHVI */
974c80476e4SDavid E. O'Brien 	Cursor = LastChar;
975c80476e4SDavid E. O'Brien 
976c80476e4SDavid E. O'Brien 	return(CC_REFRESH);
977c80476e4SDavid E. O'Brien     }
978c80476e4SDavid E. O'Brien 
979c80476e4SDavid E. O'Brien     hp = Histlist.Hnext;
980c80476e4SDavid E. O'Brien     if (hp == NULL)
981c80476e4SDavid E. O'Brien 	return(CC_ERROR);
982c80476e4SDavid E. O'Brien 
983c80476e4SDavid E. O'Brien     for (h = 1; h < Hist_num; h++) {
984c80476e4SDavid E. O'Brien 	if ((hp->Hnext) == NULL) {
985c80476e4SDavid E. O'Brien 	    Hist_num = h;
986c80476e4SDavid E. O'Brien 	    return(CC_ERROR);
987c80476e4SDavid E. O'Brien 	}
988c80476e4SDavid E. O'Brien 	hp = hp->Hnext;
989c80476e4SDavid E. O'Brien     }
990c80476e4SDavid E. O'Brien 
991c80476e4SDavid E. O'Brien     if (HistLit && hp->histline) {
99245e5710bSMark Peek 	copyn(InputBuf, hp->histline, INBUFSIZE);/*FIXBUF*/
993c80476e4SDavid E. O'Brien 	CurrentHistLit = 1;
994c80476e4SDavid E. O'Brien     }
995c80476e4SDavid E. O'Brien     else {
99645e5710bSMark Peek 	Char *p;
99745e5710bSMark Peek 
99845e5710bSMark Peek 	p = sprlex(&hp->Hlex);
99945e5710bSMark Peek 	copyn(InputBuf, p, sizeof(InputBuf) / sizeof(Char));/*FIXBUF*/
100045e5710bSMark Peek 	xfree(p);
1001c80476e4SDavid E. O'Brien 	CurrentHistLit = 0;
1002c80476e4SDavid E. O'Brien     }
100345e5710bSMark Peek     LastChar = Strend(InputBuf);
1004c80476e4SDavid E. O'Brien 
1005c80476e4SDavid E. O'Brien     if (LastChar > InputBuf) {
1006c80476e4SDavid E. O'Brien 	if (LastChar[-1] == '\n')
1007c80476e4SDavid E. O'Brien 	    LastChar--;
1008c80476e4SDavid E. O'Brien #if 0
1009c80476e4SDavid E. O'Brien 	if (LastChar[-1] == ' ')
1010c80476e4SDavid E. O'Brien 	    LastChar--;
1011c80476e4SDavid E. O'Brien #endif
1012c80476e4SDavid E. O'Brien 	if (LastChar < InputBuf)
1013c80476e4SDavid E. O'Brien 	    LastChar = InputBuf;
1014c80476e4SDavid E. O'Brien     }
1015c80476e4SDavid E. O'Brien 
1016c80476e4SDavid E. O'Brien #ifdef KSHVI
1017c80476e4SDavid E. O'Brien     if (VImode)
1018c80476e4SDavid E. O'Brien 	Cursor = InputBuf;
1019c80476e4SDavid E. O'Brien     else
1020c80476e4SDavid E. O'Brien #endif /* KSHVI */
1021c80476e4SDavid E. O'Brien 	Cursor = LastChar;
1022c80476e4SDavid E. O'Brien 
1023c80476e4SDavid E. O'Brien     return(CC_REFRESH);
1024c80476e4SDavid E. O'Brien }
1025c80476e4SDavid E. O'Brien 
1026c80476e4SDavid E. O'Brien static CCRETVAL
102745e5710bSMark Peek c_search_line(Char *pattern, int dir)
1028c80476e4SDavid E. O'Brien {
1029c80476e4SDavid E. O'Brien     Char *cp;
103045e5710bSMark Peek     size_t len;
1031c80476e4SDavid E. O'Brien 
103245e5710bSMark Peek     len = Strlen(pattern);
1033c80476e4SDavid E. O'Brien 
1034c80476e4SDavid E. O'Brien     if (dir == F_UP_SEARCH_HIST) {
1035c80476e4SDavid E. O'Brien 	for (cp = Cursor; cp >= InputBuf; cp--)
103645e5710bSMark Peek 	    if (Strncmp(cp, pattern, len) == 0 ||
1037c80476e4SDavid E. O'Brien 		Gmatch(cp, pattern)) {
1038c80476e4SDavid E. O'Brien 		Cursor = cp;
1039c80476e4SDavid E. O'Brien 		return(CC_NORM);
1040c80476e4SDavid E. O'Brien 	    }
1041c80476e4SDavid E. O'Brien 	return(CC_ERROR);
1042c80476e4SDavid E. O'Brien     } else {
1043c80476e4SDavid E. O'Brien 	for (cp = Cursor; *cp != '\0' && cp < InputLim; cp++)
104445e5710bSMark Peek 	    if (Strncmp(cp, pattern, len) == 0 ||
1045c80476e4SDavid E. O'Brien 		Gmatch(cp, pattern)) {
1046c80476e4SDavid E. O'Brien 		Cursor = cp;
1047c80476e4SDavid E. O'Brien 		return(CC_NORM);
1048c80476e4SDavid E. O'Brien 	    }
1049c80476e4SDavid E. O'Brien 	return(CC_ERROR);
1050c80476e4SDavid E. O'Brien     }
1051c80476e4SDavid E. O'Brien }
1052c80476e4SDavid E. O'Brien 
1053c80476e4SDavid E. O'Brien static CCRETVAL
105445e5710bSMark Peek e_inc_search(int dir)
1055c80476e4SDavid E. O'Brien {
105645e5710bSMark Peek     static const Char STRfwd[] = { 'f', 'w', 'd', '\0' },
1057c80476e4SDavid E. O'Brien 		      STRbck[] = { 'b', 'c', 'k', '\0' };
1058c80476e4SDavid E. O'Brien     static Char pchar = ':';	/* ':' = normal, '?' = failed */
1059c80476e4SDavid E. O'Brien     static Char endcmd[2];
106045e5710bSMark Peek     const Char *cp;
106145e5710bSMark Peek     Char ch,
1062c80476e4SDavid E. O'Brien 	*oldCursor = Cursor,
1063c80476e4SDavid E. O'Brien 	oldpchar = pchar;
1064c80476e4SDavid E. O'Brien     CCRETVAL ret = CC_NORM;
1065c80476e4SDavid E. O'Brien     int oldHist_num = Hist_num,
106645e5710bSMark Peek 	oldpatlen = patbuf.len,
1067c80476e4SDavid E. O'Brien 	newdir = dir,
1068c80476e4SDavid E. O'Brien         done, redo;
1069c80476e4SDavid E. O'Brien 
107045e5710bSMark Peek     if (LastChar + sizeof(STRfwd)/sizeof(Char) + 2 + patbuf.len >= InputLim)
1071c80476e4SDavid E. O'Brien 	return(CC_ERROR);
1072c80476e4SDavid E. O'Brien 
1073c80476e4SDavid E. O'Brien     for (;;) {
1074c80476e4SDavid E. O'Brien 
107545e5710bSMark Peek 	if (patbuf.len == 0) {	/* first round */
1076c80476e4SDavid E. O'Brien 	    pchar = ':';
107745e5710bSMark Peek 	    Strbuf_append1(&patbuf, '*');
1078c80476e4SDavid E. O'Brien 	}
1079c80476e4SDavid E. O'Brien 	done = redo = 0;
1080c80476e4SDavid E. O'Brien 	*LastChar++ = '\n';
1081c80476e4SDavid E. O'Brien 	for (cp = newdir == F_UP_SEARCH_HIST ? STRbck : STRfwd;
1082c80476e4SDavid E. O'Brien 	     *cp; *LastChar++ = *cp++)
1083c80476e4SDavid E. O'Brien 	    continue;
1084c80476e4SDavid E. O'Brien 	*LastChar++ = pchar;
108545e5710bSMark Peek 	for (cp = &patbuf.s[1]; cp < &patbuf.s[patbuf.len];
108645e5710bSMark Peek 	     *LastChar++ = *cp++)
1087c80476e4SDavid E. O'Brien 	    continue;
1088c80476e4SDavid E. O'Brien 	*LastChar = '\0';
108945e5710bSMark Peek 	if (adrof(STRhighlight) && pchar == ':') {
109045e5710bSMark Peek 	    /* if the no-glob-search patch is applied, remove the - 1 below */
109145e5710bSMark Peek 	    IncMatchLen = patbuf.len - 1;
109245e5710bSMark Peek 	    ClearLines();
109345e5710bSMark Peek 	    ClearDisp();
109445e5710bSMark Peek 	}
1095c80476e4SDavid E. O'Brien 	Refresh();
1096c80476e4SDavid E. O'Brien 
1097c80476e4SDavid E. O'Brien 	if (GetNextChar(&ch) != 1)
1098c80476e4SDavid E. O'Brien 	    return(e_send_eof(0));
1099c80476e4SDavid E. O'Brien 
110023338178SMark Peek 	switch (ch > NT_NUM_KEYS
110123338178SMark Peek 		? F_INSERT : CurrentKeyMap[(unsigned char) ch]) {
1102c80476e4SDavid E. O'Brien 	case F_INSERT:
1103c80476e4SDavid E. O'Brien 	case F_DIGIT:
1104c80476e4SDavid E. O'Brien 	case F_MAGIC_SPACE:
110545e5710bSMark Peek 	    if (LastChar + 1 >= InputLim) /*FIXBUF*/
1106c80476e4SDavid E. O'Brien 		SoundBeep();
1107c80476e4SDavid E. O'Brien 	    else {
110845e5710bSMark Peek 		Strbuf_append1(&patbuf, ch);
1109c80476e4SDavid E. O'Brien 		*LastChar++ = ch;
1110c80476e4SDavid E. O'Brien 		*LastChar = '\0';
1111c80476e4SDavid E. O'Brien 		Refresh();
1112c80476e4SDavid E. O'Brien 	    }
1113c80476e4SDavid E. O'Brien 	    break;
1114c80476e4SDavid E. O'Brien 
1115c80476e4SDavid E. O'Brien 	case F_INC_FWD:
1116c80476e4SDavid E. O'Brien 	    newdir = F_DOWN_SEARCH_HIST;
1117c80476e4SDavid E. O'Brien 	    redo++;
1118c80476e4SDavid E. O'Brien 	    break;
1119c80476e4SDavid E. O'Brien 
1120c80476e4SDavid E. O'Brien 	case F_INC_BACK:
1121c80476e4SDavid E. O'Brien 	    newdir = F_UP_SEARCH_HIST;
1122c80476e4SDavid E. O'Brien 	    redo++;
1123c80476e4SDavid E. O'Brien 	    break;
1124c80476e4SDavid E. O'Brien 
1125c80476e4SDavid E. O'Brien 	case F_DELPREV:
112645e5710bSMark Peek 	    if (patbuf.len > 1)
1127c80476e4SDavid E. O'Brien 		done++;
1128c80476e4SDavid E. O'Brien 	    else
1129c80476e4SDavid E. O'Brien 		SoundBeep();
1130c80476e4SDavid E. O'Brien 	    break;
1131c80476e4SDavid E. O'Brien 
1132c80476e4SDavid E. O'Brien 	default:
113345e5710bSMark Peek 	    switch (ASC(ch)) {
1134c80476e4SDavid E. O'Brien 	    case 0007:		/* ^G: Abort */
1135c80476e4SDavid E. O'Brien 		ret = CC_ERROR;
1136c80476e4SDavid E. O'Brien 		done++;
1137c80476e4SDavid E. O'Brien 		break;
1138c80476e4SDavid E. O'Brien 
1139c80476e4SDavid E. O'Brien 	    case 0027:		/* ^W: Append word */
1140c80476e4SDavid E. O'Brien 		/* No can do if globbing characters in pattern */
114145e5710bSMark Peek 		for (cp = &patbuf.s[1]; ; cp++)
114245e5710bSMark Peek 		    if (cp >= &patbuf.s[patbuf.len]) {
114345e5710bSMark Peek 			Cursor += patbuf.len - 1;
1144c80476e4SDavid E. O'Brien 			cp = c_next_word(Cursor, LastChar, 1);
1145c80476e4SDavid E. O'Brien 			while (Cursor < cp && *Cursor != '\n') {
114645e5710bSMark Peek 			    if (LastChar + 1 >= InputLim) {/*FIXBUF*/
1147c80476e4SDavid E. O'Brien 				SoundBeep();
1148c80476e4SDavid E. O'Brien 				break;
1149c80476e4SDavid E. O'Brien 			    }
115045e5710bSMark Peek 			    Strbuf_append1(&patbuf, *Cursor);
1151c80476e4SDavid E. O'Brien 			    *LastChar++ = *Cursor++;
1152c80476e4SDavid E. O'Brien 			}
1153c80476e4SDavid E. O'Brien 			Cursor = oldCursor;
1154c80476e4SDavid E. O'Brien 			*LastChar = '\0';
1155c80476e4SDavid E. O'Brien 			Refresh();
1156c80476e4SDavid E. O'Brien 			break;
1157c80476e4SDavid E. O'Brien 		    } else if (isglob(*cp)) {
1158c80476e4SDavid E. O'Brien 			SoundBeep();
1159c80476e4SDavid E. O'Brien 			break;
1160c80476e4SDavid E. O'Brien 		    }
1161c80476e4SDavid E. O'Brien 		break;
1162c80476e4SDavid E. O'Brien 
1163c80476e4SDavid E. O'Brien 	    default:		/* Terminate and execute cmd */
1164c80476e4SDavid E. O'Brien 		endcmd[0] = ch;
1165c80476e4SDavid E. O'Brien 		PushMacro(endcmd);
1166c80476e4SDavid E. O'Brien 		/*FALLTHROUGH*/
1167c80476e4SDavid E. O'Brien 
1168c80476e4SDavid E. O'Brien 	    case 0033:		/* ESC: Terminate */
1169c80476e4SDavid E. O'Brien 		ret = CC_REFRESH;
1170c80476e4SDavid E. O'Brien 		done++;
1171c80476e4SDavid E. O'Brien 		break;
1172c80476e4SDavid E. O'Brien 	    }
1173c80476e4SDavid E. O'Brien 	    break;
1174c80476e4SDavid E. O'Brien 	}
1175c80476e4SDavid E. O'Brien 
1176c80476e4SDavid E. O'Brien 	while (LastChar > InputBuf && *LastChar != '\n')
1177c80476e4SDavid E. O'Brien 	    *LastChar-- = '\0';
1178c80476e4SDavid E. O'Brien 	*LastChar = '\0';
1179c80476e4SDavid E. O'Brien 
1180c80476e4SDavid E. O'Brien 	if (!done) {
1181c80476e4SDavid E. O'Brien 
1182c80476e4SDavid E. O'Brien 	    /* Can't search if unmatched '[' */
118345e5710bSMark Peek 	    for (cp = &patbuf.s[patbuf.len - 1], ch = ']'; cp > patbuf.s; cp--)
1184c80476e4SDavid E. O'Brien 		if (*cp == '[' || *cp == ']') {
1185c80476e4SDavid E. O'Brien 		    ch = *cp;
1186c80476e4SDavid E. O'Brien 		    break;
1187c80476e4SDavid E. O'Brien 		}
1188c80476e4SDavid E. O'Brien 
118945e5710bSMark Peek 	    if (patbuf.len > 1 && ch != '[') {
1190c80476e4SDavid E. O'Brien 		if (redo && newdir == dir) {
1191c80476e4SDavid E. O'Brien 		    if (pchar == '?') {	/* wrap around */
119245e5710bSMark Peek 			Hist_num = newdir == F_UP_SEARCH_HIST ? 0 : INT_MAX;
119345e5710bSMark Peek 			if (GetHistLine() == CC_ERROR)
1194c80476e4SDavid E. O'Brien 			    /* Hist_num was fixed by first call */
119545e5710bSMark Peek 			    (void) GetHistLine();
1196c80476e4SDavid E. O'Brien 			Cursor = newdir == F_UP_SEARCH_HIST ?
1197c80476e4SDavid E. O'Brien 			    LastChar : InputBuf;
1198c80476e4SDavid E. O'Brien 		    } else
1199c80476e4SDavid E. O'Brien 			Cursor += newdir == F_UP_SEARCH_HIST ? -1 : 1;
1200c80476e4SDavid E. O'Brien 		}
120145e5710bSMark Peek 		Strbuf_append1(&patbuf, '*');
120245e5710bSMark Peek 		Strbuf_terminate(&patbuf);
1203c80476e4SDavid E. O'Brien 		if (Cursor < InputBuf || Cursor > LastChar ||
120445e5710bSMark Peek 		    (ret = c_search_line(&patbuf.s[1], newdir)) == CC_ERROR) {
1205c80476e4SDavid E. O'Brien 		    LastCmd = (KEYCMD) newdir; /* avoid c_hsetpat */
1206c80476e4SDavid E. O'Brien 		    ret = newdir == F_UP_SEARCH_HIST ?
1207c80476e4SDavid E. O'Brien 			e_up_search_hist(0) : e_down_search_hist(0);
1208c80476e4SDavid E. O'Brien 		    if (ret != CC_ERROR) {
1209c80476e4SDavid E. O'Brien 			Cursor = newdir == F_UP_SEARCH_HIST ?
1210c80476e4SDavid E. O'Brien 			    LastChar : InputBuf;
121145e5710bSMark Peek 			(void) c_search_line(&patbuf.s[1], newdir);
1212c80476e4SDavid E. O'Brien 		    }
1213c80476e4SDavid E. O'Brien 		}
121445e5710bSMark Peek 		patbuf.s[--patbuf.len] = '\0';
1215c80476e4SDavid E. O'Brien 		if (ret == CC_ERROR) {
1216c80476e4SDavid E. O'Brien 		    SoundBeep();
1217c80476e4SDavid E. O'Brien 		    if (Hist_num != oldHist_num) {
1218c80476e4SDavid E. O'Brien 			Hist_num = oldHist_num;
121945e5710bSMark Peek 			if (GetHistLine() == CC_ERROR)
1220c80476e4SDavid E. O'Brien 			    return(CC_ERROR);
1221c80476e4SDavid E. O'Brien 		    }
1222c80476e4SDavid E. O'Brien 		    Cursor = oldCursor;
1223c80476e4SDavid E. O'Brien 		    pchar = '?';
1224c80476e4SDavid E. O'Brien 		} else {
1225c80476e4SDavid E. O'Brien 		    pchar = ':';
1226c80476e4SDavid E. O'Brien 		}
1227c80476e4SDavid E. O'Brien 	    }
1228c80476e4SDavid E. O'Brien 
1229c80476e4SDavid E. O'Brien 	    ret = e_inc_search(newdir);
1230c80476e4SDavid E. O'Brien 
1231c80476e4SDavid E. O'Brien 	    if (ret == CC_ERROR && pchar == '?' && oldpchar == ':') {
1232c80476e4SDavid E. O'Brien 		/* break abort of failed search at last non-failed */
1233c80476e4SDavid E. O'Brien 		ret = CC_NORM;
1234c80476e4SDavid E. O'Brien 	    }
1235c80476e4SDavid E. O'Brien 
1236c80476e4SDavid E. O'Brien 	}
1237c80476e4SDavid E. O'Brien 
1238c80476e4SDavid E. O'Brien 	if (ret == CC_NORM || (ret == CC_ERROR && oldpatlen == 0)) {
1239c80476e4SDavid E. O'Brien 	    /* restore on normal return or error exit */
1240c80476e4SDavid E. O'Brien 	    pchar = oldpchar;
124145e5710bSMark Peek 	    patbuf.len = oldpatlen;
1242c80476e4SDavid E. O'Brien 	    if (Hist_num != oldHist_num) {
1243c80476e4SDavid E. O'Brien 		Hist_num = oldHist_num;
124445e5710bSMark Peek 		if (GetHistLine() == CC_ERROR)
1245c80476e4SDavid E. O'Brien 		    return(CC_ERROR);
1246c80476e4SDavid E. O'Brien 	    }
1247c80476e4SDavid E. O'Brien 	    Cursor = oldCursor;
1248c80476e4SDavid E. O'Brien 	    if (ret == CC_ERROR)
1249c80476e4SDavid E. O'Brien 		Refresh();
1250c80476e4SDavid E. O'Brien 	}
1251c80476e4SDavid E. O'Brien 	if (done || ret != CC_NORM)
1252c80476e4SDavid E. O'Brien 	    return(ret);
1253c80476e4SDavid E. O'Brien 
1254c80476e4SDavid E. O'Brien     }
1255c80476e4SDavid E. O'Brien 
1256c80476e4SDavid E. O'Brien }
1257c80476e4SDavid E. O'Brien 
1258c80476e4SDavid E. O'Brien static CCRETVAL
125945e5710bSMark Peek v_search(int dir)
1260c80476e4SDavid E. O'Brien {
126145e5710bSMark Peek     struct Strbuf tmpbuf = Strbuf_INIT;
1262c80476e4SDavid E. O'Brien     Char ch;
126345e5710bSMark Peek     Char *oldbuf;
1264c80476e4SDavid E. O'Brien     Char *oldlc, *oldc;
1265c80476e4SDavid E. O'Brien 
126645e5710bSMark Peek     cleanup_push(&tmpbuf, Strbuf_cleanup);
126745e5710bSMark Peek     oldbuf = Strsave(InputBuf);
126845e5710bSMark Peek     cleanup_push(oldbuf, xfree);
1269c80476e4SDavid E. O'Brien     oldlc = LastChar;
1270c80476e4SDavid E. O'Brien     oldc = Cursor;
127145e5710bSMark Peek     Strbuf_append1(&tmpbuf, '*');
1272c80476e4SDavid E. O'Brien 
1273c80476e4SDavid E. O'Brien     InputBuf[0] = '\0';
1274c80476e4SDavid E. O'Brien     LastChar = InputBuf;
1275c80476e4SDavid E. O'Brien     Cursor = InputBuf;
1276c80476e4SDavid E. O'Brien     searchdir = dir;
1277c80476e4SDavid E. O'Brien 
1278c80476e4SDavid E. O'Brien     c_insert(2);	/* prompt + '\n' */
1279c80476e4SDavid E. O'Brien     *Cursor++ = '\n';
1280c80476e4SDavid E. O'Brien     *Cursor++ = dir == F_UP_SEARCH_HIST ? '?' : '/';
1281c80476e4SDavid E. O'Brien     Refresh();
1282c80476e4SDavid E. O'Brien     for (ch = 0;ch == 0;) {
128345e5710bSMark Peek 	if (GetNextChar(&ch) != 1) {
128445e5710bSMark Peek 	    cleanup_until(&tmpbuf);
1285c80476e4SDavid E. O'Brien 	    return(e_send_eof(0));
128645e5710bSMark Peek 	}
1287c80476e4SDavid E. O'Brien 	switch (ASC(ch)) {
1288c80476e4SDavid E. O'Brien 	case 0010:	/* Delete and backspace */
1289c80476e4SDavid E. O'Brien 	case 0177:
129045e5710bSMark Peek 	    if (tmpbuf.len > 1) {
1291c80476e4SDavid E. O'Brien 		*Cursor-- = '\0';
1292c80476e4SDavid E. O'Brien 		LastChar = Cursor;
129345e5710bSMark Peek 		tmpbuf.len--;
1294c80476e4SDavid E. O'Brien 	    }
1295c80476e4SDavid E. O'Brien 	    else {
129645e5710bSMark Peek 		copyn(InputBuf, oldbuf, INBUFSIZE);/*FIXBUF*/
1297c80476e4SDavid E. O'Brien 		LastChar = oldlc;
1298c80476e4SDavid E. O'Brien 		Cursor = oldc;
129945e5710bSMark Peek 		cleanup_until(&tmpbuf);
1300c80476e4SDavid E. O'Brien 		return(CC_REFRESH);
1301c80476e4SDavid E. O'Brien 	    }
1302c80476e4SDavid E. O'Brien 	    Refresh();
1303c80476e4SDavid E. O'Brien 	    ch = 0;
1304c80476e4SDavid E. O'Brien 	    break;
1305c80476e4SDavid E. O'Brien 
1306c80476e4SDavid E. O'Brien 	case 0033:	/* ESC */
13073b6eaa7bSAndrey A. Chernov #ifdef IS_ASCII
1308c80476e4SDavid E. O'Brien 	case '\r':	/* Newline */
1309c80476e4SDavid E. O'Brien 	case '\n':
1310c80476e4SDavid E. O'Brien #else
13113b6eaa7bSAndrey A. Chernov 	case '\012':    /* ASCII Line feed */
13123b6eaa7bSAndrey A. Chernov 	case '\015':    /* ASCII (or EBCDIC) Return */
1313c80476e4SDavid E. O'Brien #endif
1314c80476e4SDavid E. O'Brien 	    break;
1315c80476e4SDavid E. O'Brien 
1316c80476e4SDavid E. O'Brien 	default:
131745e5710bSMark Peek 	    Strbuf_append1(&tmpbuf, ch);
1318c80476e4SDavid E. O'Brien 	    *Cursor++ = ch;
1319c80476e4SDavid E. O'Brien 	    LastChar = Cursor;
1320c80476e4SDavid E. O'Brien 	    Refresh();
1321c80476e4SDavid E. O'Brien 	    ch = 0;
1322c80476e4SDavid E. O'Brien 	    break;
1323c80476e4SDavid E. O'Brien 	}
1324c80476e4SDavid E. O'Brien     }
132545e5710bSMark Peek     cleanup_until(oldbuf);
1326c80476e4SDavid E. O'Brien 
132745e5710bSMark Peek     if (tmpbuf.len == 1) {
1328c80476e4SDavid E. O'Brien 	/*
1329c80476e4SDavid E. O'Brien 	 * Use the old pattern, but wild-card it.
1330c80476e4SDavid E. O'Brien 	 */
133145e5710bSMark Peek 	if (patbuf.len == 0) {
1332c80476e4SDavid E. O'Brien 	    InputBuf[0] = '\0';
1333c80476e4SDavid E. O'Brien 	    LastChar = InputBuf;
1334c80476e4SDavid E. O'Brien 	    Cursor = InputBuf;
1335c80476e4SDavid E. O'Brien 	    Refresh();
133645e5710bSMark Peek 	    cleanup_until(&tmpbuf);
1337c80476e4SDavid E. O'Brien 	    return(CC_ERROR);
1338c80476e4SDavid E. O'Brien 	}
133945e5710bSMark Peek 	if (patbuf.s[0] != '*') {
134045e5710bSMark Peek 	    oldbuf = Strsave(patbuf.s);
134145e5710bSMark Peek 	    patbuf.len = 0;
134245e5710bSMark Peek 	    Strbuf_append1(&patbuf, '*');
134345e5710bSMark Peek 	    Strbuf_append(&patbuf, oldbuf);
134445e5710bSMark Peek 	    xfree(oldbuf);
134545e5710bSMark Peek 	    Strbuf_append1(&patbuf, '*');
134645e5710bSMark Peek 	    Strbuf_terminate(&patbuf);
1347c80476e4SDavid E. O'Brien 	}
1348c80476e4SDavid E. O'Brien     }
1349c80476e4SDavid E. O'Brien     else {
135045e5710bSMark Peek 	Strbuf_append1(&tmpbuf, '*');
135145e5710bSMark Peek 	Strbuf_terminate(&tmpbuf);
135245e5710bSMark Peek 	patbuf.len = 0;
135345e5710bSMark Peek 	Strbuf_append(&patbuf, tmpbuf.s);
135445e5710bSMark Peek 	Strbuf_terminate(&patbuf);
1355c80476e4SDavid E. O'Brien     }
135645e5710bSMark Peek     cleanup_until(&tmpbuf);
1357c80476e4SDavid E. O'Brien     LastCmd = (KEYCMD) dir; /* avoid c_hsetpat */
1358c80476e4SDavid E. O'Brien     Cursor = LastChar = InputBuf;
1359c80476e4SDavid E. O'Brien     if ((dir == F_UP_SEARCH_HIST ? e_up_search_hist(0) :
1360c80476e4SDavid E. O'Brien 				   e_down_search_hist(0)) == CC_ERROR) {
1361c80476e4SDavid E. O'Brien 	Refresh();
1362c80476e4SDavid E. O'Brien 	return(CC_ERROR);
1363c80476e4SDavid E. O'Brien     }
1364c80476e4SDavid E. O'Brien     else {
136545e5710bSMark Peek 	if (ASC(ch) == 0033) {
1366c80476e4SDavid E. O'Brien 	    Refresh();
1367c80476e4SDavid E. O'Brien 	    *LastChar++ = '\n';
1368c80476e4SDavid E. O'Brien 	    *LastChar = '\0';
1369c80476e4SDavid E. O'Brien 	    PastBottom();
1370c80476e4SDavid E. O'Brien 	    return(CC_NEWLINE);
1371c80476e4SDavid E. O'Brien 	}
1372c80476e4SDavid E. O'Brien 	else
1373c80476e4SDavid E. O'Brien 	    return(CC_REFRESH);
1374c80476e4SDavid E. O'Brien     }
1375c80476e4SDavid E. O'Brien }
1376c80476e4SDavid E. O'Brien 
1377c80476e4SDavid E. O'Brien /*
1378c80476e4SDavid E. O'Brien  * semi-PUBLIC routines.  Any routine that is of type CCRETVAL is an
1379c80476e4SDavid E. O'Brien  * entry point, called from the CcKeyMap indirected into the
1380c80476e4SDavid E. O'Brien  * CcFuncTbl array.
1381c80476e4SDavid E. O'Brien  */
1382c80476e4SDavid E. O'Brien 
1383c80476e4SDavid E. O'Brien /*ARGSUSED*/
1384c80476e4SDavid E. O'Brien CCRETVAL
138545e5710bSMark Peek v_cmd_mode(Char c)
1386c80476e4SDavid E. O'Brien {
1387c80476e4SDavid E. O'Brien     USE(c);
1388c80476e4SDavid E. O'Brien     InsertPos = 0;
1389c80476e4SDavid E. O'Brien     ActionFlag = TCSHOP_NOP;	/* [Esc] cancels pending action */
1390c80476e4SDavid E. O'Brien     ActionPos = 0;
1391c80476e4SDavid E. O'Brien     DoingArg = 0;
1392c80476e4SDavid E. O'Brien     if (UndoPtr > Cursor)
1393c80476e4SDavid E. O'Brien 	UndoSize = (int)(UndoPtr - Cursor);
1394c80476e4SDavid E. O'Brien     else
1395c80476e4SDavid E. O'Brien 	UndoSize = (int)(Cursor - UndoPtr);
1396c80476e4SDavid E. O'Brien 
1397c80476e4SDavid E. O'Brien     inputmode = MODE_INSERT;
1398c80476e4SDavid E. O'Brien     c_alternativ_key_map(1);
1399c80476e4SDavid E. O'Brien #ifdef notdef
1400c80476e4SDavid E. O'Brien     /*
1401c80476e4SDavid E. O'Brien      * We don't want to move the cursor, because all the editing
1402c80476e4SDavid E. O'Brien      * commands don't include the character under the cursor.
1403c80476e4SDavid E. O'Brien      */
1404c80476e4SDavid E. O'Brien     if (Cursor > InputBuf)
1405c80476e4SDavid E. O'Brien 	Cursor--;
1406c80476e4SDavid E. O'Brien #endif
1407c80476e4SDavid E. O'Brien     RefCursor();
1408c80476e4SDavid E. O'Brien     return(CC_NORM);
1409c80476e4SDavid E. O'Brien }
1410c80476e4SDavid E. O'Brien 
1411c80476e4SDavid E. O'Brien /*ARGSUSED*/
1412c80476e4SDavid E. O'Brien CCRETVAL
141345e5710bSMark Peek e_unassigned(Char c)
1414c80476e4SDavid E. O'Brien {				/* bound to keys that arn't really assigned */
1415c80476e4SDavid E. O'Brien     USE(c);
1416c80476e4SDavid E. O'Brien     SoundBeep();
1417c80476e4SDavid E. O'Brien     flush();
1418c80476e4SDavid E. O'Brien     return(CC_NORM);
1419c80476e4SDavid E. O'Brien }
1420c80476e4SDavid E. O'Brien 
142145e5710bSMark Peek #ifdef notyet
142223338178SMark Peek static CCRETVAL
142345e5710bSMark Peek e_insert_str(Char *c)
142423338178SMark Peek {
142523338178SMark Peek     int i, n;
142623338178SMark Peek 
142723338178SMark Peek     n = Strlen(c);
142823338178SMark Peek     if (LastChar + Argument * n >= InputLim)
142923338178SMark Peek 	return(CC_ERROR);	/* end of buffer space */
143023338178SMark Peek     if (inputmode != MODE_INSERT) {
143145e5710bSMark Peek 	c_delafter(Argument * Strlen(c));
143223338178SMark Peek     }
143323338178SMark Peek     c_insert(Argument * n);
143423338178SMark Peek     while (Argument--) {
143523338178SMark Peek 	for (i = 0; i < n; i++)
143623338178SMark Peek 	    *Cursor++ = c[i];
143723338178SMark Peek     }
143823338178SMark Peek     Refresh();
143923338178SMark Peek     return(CC_NORM);
144023338178SMark Peek }
144145e5710bSMark Peek #endif
144223338178SMark Peek 
1443c80476e4SDavid E. O'Brien CCRETVAL
144445e5710bSMark Peek e_insert(Char c)
1445c80476e4SDavid E. O'Brien {
1446c80476e4SDavid E. O'Brien #ifndef SHORT_STRINGS
1447c80476e4SDavid E. O'Brien     c &= ASCII;			/* no meta chars ever */
1448c80476e4SDavid E. O'Brien #endif
1449c80476e4SDavid E. O'Brien 
1450c80476e4SDavid E. O'Brien     if (!c)
1451c80476e4SDavid E. O'Brien 	return(CC_ERROR);	/* no NULs in the input ever!! */
1452c80476e4SDavid E. O'Brien 
1453c80476e4SDavid E. O'Brien     if (LastChar + Argument >= InputLim)
1454c80476e4SDavid E. O'Brien 	return(CC_ERROR);	/* end of buffer space */
1455c80476e4SDavid E. O'Brien 
1456c80476e4SDavid E. O'Brien     if (Argument == 1) {  	/* How was this optimized ???? */
1457c80476e4SDavid E. O'Brien 
1458c80476e4SDavid E. O'Brien 	if (inputmode != MODE_INSERT) {
1459c80476e4SDavid E. O'Brien 	    UndoBuf[UndoSize++] = *Cursor;
1460c80476e4SDavid E. O'Brien 	    UndoBuf[UndoSize] = '\0';
1461c80476e4SDavid E. O'Brien 	    c_delafter(1);   /* Do NOT use the saving ONE */
1462c80476e4SDavid E. O'Brien     	}
1463c80476e4SDavid E. O'Brien 
1464c80476e4SDavid E. O'Brien         c_insert(1);
1465c80476e4SDavid E. O'Brien 	*Cursor++ = (Char) c;
1466c80476e4SDavid E. O'Brien 	DoingArg = 0;		/* just in case */
146723338178SMark Peek 	RefPlusOne(1);		/* fast refresh for one char. */
1468c80476e4SDavid E. O'Brien     }
1469c80476e4SDavid E. O'Brien     else {
1470c80476e4SDavid E. O'Brien 	if (inputmode != MODE_INSERT) {
147123338178SMark Peek 	    int i;
1472c80476e4SDavid E. O'Brien 	    for(i = 0; i < Argument; i++)
1473c80476e4SDavid E. O'Brien 		UndoBuf[UndoSize++] = *(Cursor + i);
1474c80476e4SDavid E. O'Brien 
1475c80476e4SDavid E. O'Brien 	    UndoBuf[UndoSize] = '\0';
1476c80476e4SDavid E. O'Brien 	    c_delafter(Argument);   /* Do NOT use the saving ONE */
1477c80476e4SDavid E. O'Brien     	}
1478c80476e4SDavid E. O'Brien 
1479c80476e4SDavid E. O'Brien         c_insert(Argument);
1480c80476e4SDavid E. O'Brien 
1481c80476e4SDavid E. O'Brien 	while (Argument--)
1482c80476e4SDavid E. O'Brien 	    *Cursor++ = (Char) c;
1483c80476e4SDavid E. O'Brien 	Refresh();
1484c80476e4SDavid E. O'Brien     }
1485c80476e4SDavid E. O'Brien 
1486c80476e4SDavid E. O'Brien     if (inputmode == MODE_REPLACE_1)
1487c80476e4SDavid E. O'Brien 	(void) v_cmd_mode(0);
1488c80476e4SDavid E. O'Brien 
1489c80476e4SDavid E. O'Brien     return(CC_NORM);
1490c80476e4SDavid E. O'Brien }
1491c80476e4SDavid E. O'Brien 
1492c80476e4SDavid E. O'Brien int
149345e5710bSMark Peek InsertStr(Char *s)		/* insert ASCIZ s at cursor (for complete) */
1494c80476e4SDavid E. O'Brien {
14956767bd61SMark Peek     int len;
1496c80476e4SDavid E. O'Brien 
1497c80476e4SDavid E. O'Brien     if ((len = (int) Strlen(s)) <= 0)
1498c80476e4SDavid E. O'Brien 	return -1;
1499c80476e4SDavid E. O'Brien     if (LastChar + len >= InputLim)
1500c80476e4SDavid E. O'Brien 	return -1;		/* end of buffer space */
1501c80476e4SDavid E. O'Brien 
1502c80476e4SDavid E. O'Brien     c_insert(len);
1503c80476e4SDavid E. O'Brien     while (len--)
1504c80476e4SDavid E. O'Brien 	*Cursor++ = *s++;
1505c80476e4SDavid E. O'Brien     return 0;
1506c80476e4SDavid E. O'Brien }
1507c80476e4SDavid E. O'Brien 
1508c80476e4SDavid E. O'Brien void
150945e5710bSMark Peek DeleteBack(int n)		/* delete the n characters before . */
1510c80476e4SDavid E. O'Brien {
1511c80476e4SDavid E. O'Brien     if (n <= 0)
1512c80476e4SDavid E. O'Brien 	return;
1513c80476e4SDavid E. O'Brien     if (Cursor >= &InputBuf[n]) {
1514c80476e4SDavid E. O'Brien 	c_delbefore(n);		/* delete before dot */
1515c80476e4SDavid E. O'Brien     }
1516c80476e4SDavid E. O'Brien }
1517c80476e4SDavid E. O'Brien 
1518c80476e4SDavid E. O'Brien CCRETVAL
151945e5710bSMark Peek e_digit(Char c)			/* gray magic here */
1520c80476e4SDavid E. O'Brien {
1521c80476e4SDavid E. O'Brien     if (!Isdigit(c))
1522c80476e4SDavid E. O'Brien 	return(CC_ERROR);	/* no NULs in the input ever!! */
1523c80476e4SDavid E. O'Brien 
1524c80476e4SDavid E. O'Brien     if (DoingArg) {		/* if doing an arg, add this in... */
1525c80476e4SDavid E. O'Brien 	if (LastCmd == F_ARGFOUR)	/* if last command was ^U */
1526c80476e4SDavid E. O'Brien 	    Argument = c - '0';
1527c80476e4SDavid E. O'Brien 	else {
1528c80476e4SDavid E. O'Brien 	    if (Argument > 1000000)
1529c80476e4SDavid E. O'Brien 		return CC_ERROR;
1530c80476e4SDavid E. O'Brien 	    Argument = (Argument * 10) + (c - '0');
1531c80476e4SDavid E. O'Brien 	}
1532c80476e4SDavid E. O'Brien 	return(CC_ARGHACK);
1533c80476e4SDavid E. O'Brien     }
1534c80476e4SDavid E. O'Brien     else {
1535c80476e4SDavid E. O'Brien 	if (LastChar + 1 >= InputLim)
1536c80476e4SDavid E. O'Brien 	    return CC_ERROR;	/* end of buffer space */
1537c80476e4SDavid E. O'Brien 
1538c80476e4SDavid E. O'Brien 	if (inputmode != MODE_INSERT) {
1539c80476e4SDavid E. O'Brien 	    UndoBuf[UndoSize++] = *Cursor;
1540c80476e4SDavid E. O'Brien 	    UndoBuf[UndoSize] = '\0';
1541c80476e4SDavid E. O'Brien 	    c_delafter(1);   /* Do NOT use the saving ONE */
1542c80476e4SDavid E. O'Brien     	}
1543c80476e4SDavid E. O'Brien 	c_insert(1);
1544c80476e4SDavid E. O'Brien 	*Cursor++ = (Char) c;
1545c80476e4SDavid E. O'Brien 	DoingArg = 0;		/* just in case */
154623338178SMark Peek 	RefPlusOne(1);		/* fast refresh for one char. */
1547c80476e4SDavid E. O'Brien     }
1548c80476e4SDavid E. O'Brien     return(CC_NORM);
1549c80476e4SDavid E. O'Brien }
1550c80476e4SDavid E. O'Brien 
1551c80476e4SDavid E. O'Brien CCRETVAL
155245e5710bSMark Peek e_argdigit(Char c)		/* for ESC-n */
1553c80476e4SDavid E. O'Brien {
155445e5710bSMark Peek #ifdef IS_ASCII
1555c80476e4SDavid E. O'Brien     c &= ASCII;
155645e5710bSMark Peek #else
155745e5710bSMark Peek     c = CTL_ESC(ASC(c) & ASCII); /* stripping for EBCDIC done the ASCII way */
155845e5710bSMark Peek #endif
1559c80476e4SDavid E. O'Brien 
1560c80476e4SDavid E. O'Brien     if (!Isdigit(c))
1561c80476e4SDavid E. O'Brien 	return(CC_ERROR);	/* no NULs in the input ever!! */
1562c80476e4SDavid E. O'Brien 
1563c80476e4SDavid E. O'Brien     if (DoingArg) {		/* if doing an arg, add this in... */
1564c80476e4SDavid E. O'Brien 	if (Argument > 1000000)
1565c80476e4SDavid E. O'Brien 	    return CC_ERROR;
1566c80476e4SDavid E. O'Brien 	Argument = (Argument * 10) + (c - '0');
1567c80476e4SDavid E. O'Brien     }
1568c80476e4SDavid E. O'Brien     else {			/* else starting an argument */
1569c80476e4SDavid E. O'Brien 	Argument = c - '0';
1570c80476e4SDavid E. O'Brien 	DoingArg = 1;
1571c80476e4SDavid E. O'Brien     }
1572c80476e4SDavid E. O'Brien     return(CC_ARGHACK);
1573c80476e4SDavid E. O'Brien }
1574c80476e4SDavid E. O'Brien 
1575c80476e4SDavid E. O'Brien CCRETVAL
157645e5710bSMark Peek v_zero(Char c)			/* command mode 0 for vi */
1577c80476e4SDavid E. O'Brien {
1578c80476e4SDavid E. O'Brien     if (DoingArg) {		/* if doing an arg, add this in... */
1579c80476e4SDavid E. O'Brien 	if (Argument > 1000000)
1580c80476e4SDavid E. O'Brien 	    return CC_ERROR;
1581c80476e4SDavid E. O'Brien 	Argument = (Argument * 10) + (c - '0');
1582c80476e4SDavid E. O'Brien 	return(CC_ARGHACK);
1583c80476e4SDavid E. O'Brien     }
1584c80476e4SDavid E. O'Brien     else {			/* else starting an argument */
1585c80476e4SDavid E. O'Brien 	Cursor = InputBuf;
1586c80476e4SDavid E. O'Brien 	if (ActionFlag & TCSHOP_DELETE) {
1587c80476e4SDavid E. O'Brien 	   c_delfini();
1588c80476e4SDavid E. O'Brien 	   return(CC_REFRESH);
1589c80476e4SDavid E. O'Brien         }
1590c80476e4SDavid E. O'Brien 	RefCursor();		/* move the cursor */
1591c80476e4SDavid E. O'Brien 	return(CC_NORM);
1592c80476e4SDavid E. O'Brien     }
1593c80476e4SDavid E. O'Brien }
1594c80476e4SDavid E. O'Brien 
1595c80476e4SDavid E. O'Brien /*ARGSUSED*/
1596c80476e4SDavid E. O'Brien CCRETVAL
159745e5710bSMark Peek e_newline(Char c)
1598c80476e4SDavid E. O'Brien {				/* always ignore argument */
1599c80476e4SDavid E. O'Brien     USE(c);
160045e5710bSMark Peek     if (adrof(STRhighlight) && MarkIsSet) {
160145e5710bSMark Peek 	MarkIsSet = 0;
160245e5710bSMark Peek 	ClearLines();
160345e5710bSMark Peek 	ClearDisp();
160445e5710bSMark Peek 	Refresh();
160545e5710bSMark Peek     }
160645e5710bSMark Peek     MarkIsSet = 0;
160745e5710bSMark Peek 
1608c80476e4SDavid E. O'Brien   /*  PastBottom();  NOW done in ed.inputl.c */
1609c80476e4SDavid E. O'Brien     *LastChar++ = '\n';		/* for the benefit of CSH */
1610c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
1611c80476e4SDavid E. O'Brien     if (VImode)
1612c80476e4SDavid E. O'Brien 	InsertPos = InputBuf;	/* Reset editing position */
1613c80476e4SDavid E. O'Brien     return(CC_NEWLINE);
1614c80476e4SDavid E. O'Brien }
1615c80476e4SDavid E. O'Brien 
1616c80476e4SDavid E. O'Brien /*ARGSUSED*/
1617c80476e4SDavid E. O'Brien CCRETVAL
161845e5710bSMark Peek e_newline_hold(Char c)
161945e5710bSMark Peek {
162045e5710bSMark Peek     USE(c);
162145e5710bSMark Peek     c_save_inputbuf();
162245e5710bSMark Peek     HistSaved = 0;
162345e5710bSMark Peek     *LastChar++ = '\n';		/* for the benefit of CSH */
162445e5710bSMark Peek     *LastChar = '\0';		/* just in case */
162545e5710bSMark Peek     return(CC_NEWLINE);
162645e5710bSMark Peek }
162745e5710bSMark Peek 
162845e5710bSMark Peek /*ARGSUSED*/
162945e5710bSMark Peek CCRETVAL
163045e5710bSMark Peek e_newline_down_hist(Char c)
163145e5710bSMark Peek {
163245e5710bSMark Peek     USE(c);
163345e5710bSMark Peek     if (Hist_num > 1) {
163445e5710bSMark Peek 	HistSaved = Hist_num;
163545e5710bSMark Peek     }
163645e5710bSMark Peek     *LastChar++ = '\n';		/* for the benefit of CSH */
163745e5710bSMark Peek     *LastChar = '\0';		/* just in case */
163845e5710bSMark Peek     return(CC_NEWLINE);
163945e5710bSMark Peek }
164045e5710bSMark Peek 
164145e5710bSMark Peek /*ARGSUSED*/
164245e5710bSMark Peek CCRETVAL
164345e5710bSMark Peek e_send_eof(Char c)
1644c80476e4SDavid E. O'Brien {				/* for when ^D is ONLY send-eof */
1645c80476e4SDavid E. O'Brien     USE(c);
1646c80476e4SDavid E. O'Brien     PastBottom();
1647c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
1648c80476e4SDavid E. O'Brien     return(CC_EOF);
1649c80476e4SDavid E. O'Brien }
1650c80476e4SDavid E. O'Brien 
1651c80476e4SDavid E. O'Brien /*ARGSUSED*/
1652c80476e4SDavid E. O'Brien CCRETVAL
165345e5710bSMark Peek e_complete(Char c)
1654c80476e4SDavid E. O'Brien {
1655c80476e4SDavid E. O'Brien     USE(c);
1656c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
1657c80476e4SDavid E. O'Brien     return(CC_COMPLETE);
1658c80476e4SDavid E. O'Brien }
1659c80476e4SDavid E. O'Brien 
1660c80476e4SDavid E. O'Brien /*ARGSUSED*/
1661c80476e4SDavid E. O'Brien CCRETVAL
166245e5710bSMark Peek e_complete_back(Char c)
1663c80476e4SDavid E. O'Brien {
1664c80476e4SDavid E. O'Brien     USE(c);
1665c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
1666c80476e4SDavid E. O'Brien     return(CC_COMPLETE_BACK);
1667c80476e4SDavid E. O'Brien }
1668c80476e4SDavid E. O'Brien 
1669c80476e4SDavid E. O'Brien /*ARGSUSED*/
1670c80476e4SDavid E. O'Brien CCRETVAL
167145e5710bSMark Peek e_complete_fwd(Char c)
1672c80476e4SDavid E. O'Brien {
1673c80476e4SDavid E. O'Brien     USE(c);
1674c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
1675c80476e4SDavid E. O'Brien     return(CC_COMPLETE_FWD);
1676c80476e4SDavid E. O'Brien }
1677c80476e4SDavid E. O'Brien 
1678c80476e4SDavid E. O'Brien /*ARGSUSED*/
1679c80476e4SDavid E. O'Brien CCRETVAL
168045e5710bSMark Peek e_complete_all(Char c)
1681c80476e4SDavid E. O'Brien {
1682c80476e4SDavid E. O'Brien     USE(c);
1683c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
1684c80476e4SDavid E. O'Brien     return(CC_COMPLETE_ALL);
1685c80476e4SDavid E. O'Brien }
1686c80476e4SDavid E. O'Brien 
1687c80476e4SDavid E. O'Brien /*ARGSUSED*/
1688c80476e4SDavid E. O'Brien CCRETVAL
168945e5710bSMark Peek v_cm_complete(Char c)
1690c80476e4SDavid E. O'Brien {
1691c80476e4SDavid E. O'Brien     USE(c);
1692c80476e4SDavid E. O'Brien     if (Cursor < LastChar)
1693c80476e4SDavid E. O'Brien 	Cursor++;
1694c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
1695c80476e4SDavid E. O'Brien     return(CC_COMPLETE);
1696c80476e4SDavid E. O'Brien }
1697c80476e4SDavid E. O'Brien 
1698c80476e4SDavid E. O'Brien /*ARGSUSED*/
1699c80476e4SDavid E. O'Brien CCRETVAL
170045e5710bSMark Peek e_toggle_hist(Char c)
1701c80476e4SDavid E. O'Brien {
1702c80476e4SDavid E. O'Brien     struct Hist *hp;
1703c80476e4SDavid E. O'Brien     int     h;
1704c80476e4SDavid E. O'Brien 
1705c80476e4SDavid E. O'Brien     USE(c);
1706c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
1707c80476e4SDavid E. O'Brien 
1708c80476e4SDavid E. O'Brien     if (Hist_num <= 0) {
1709c80476e4SDavid E. O'Brien 	return CC_ERROR;
1710c80476e4SDavid E. O'Brien     }
1711c80476e4SDavid E. O'Brien 
1712c80476e4SDavid E. O'Brien     hp = Histlist.Hnext;
1713c80476e4SDavid E. O'Brien     if (hp == NULL) {	/* this is only if no history */
1714c80476e4SDavid E. O'Brien 	return(CC_ERROR);
1715c80476e4SDavid E. O'Brien     }
1716c80476e4SDavid E. O'Brien 
1717c80476e4SDavid E. O'Brien     for (h = 1; h < Hist_num; h++)
1718c80476e4SDavid E. O'Brien 	hp = hp->Hnext;
1719c80476e4SDavid E. O'Brien 
1720c80476e4SDavid E. O'Brien     if (!CurrentHistLit) {
1721c80476e4SDavid E. O'Brien 	if (hp->histline) {
172245e5710bSMark Peek 	    copyn(InputBuf, hp->histline, INBUFSIZE);/*FIXBUF*/
1723c80476e4SDavid E. O'Brien 	    CurrentHistLit = 1;
1724c80476e4SDavid E. O'Brien 	}
1725c80476e4SDavid E. O'Brien 	else {
1726c80476e4SDavid E. O'Brien 	    return CC_ERROR;
1727c80476e4SDavid E. O'Brien 	}
1728c80476e4SDavid E. O'Brien     }
1729c80476e4SDavid E. O'Brien     else {
173045e5710bSMark Peek 	Char *p;
173145e5710bSMark Peek 
173245e5710bSMark Peek 	p = sprlex(&hp->Hlex);
173345e5710bSMark Peek 	copyn(InputBuf, p, sizeof(InputBuf) / sizeof(Char));/*FIXBUF*/
173445e5710bSMark Peek 	xfree(p);
1735c80476e4SDavid E. O'Brien 	CurrentHistLit = 0;
1736c80476e4SDavid E. O'Brien     }
1737c80476e4SDavid E. O'Brien 
173845e5710bSMark Peek     LastChar = Strend(InputBuf);
1739c80476e4SDavid E. O'Brien     if (LastChar > InputBuf) {
1740c80476e4SDavid E. O'Brien 	if (LastChar[-1] == '\n')
1741c80476e4SDavid E. O'Brien 	    LastChar--;
1742c80476e4SDavid E. O'Brien 	if (LastChar[-1] == ' ')
1743c80476e4SDavid E. O'Brien 	    LastChar--;
1744c80476e4SDavid E. O'Brien 	if (LastChar < InputBuf)
1745c80476e4SDavid E. O'Brien 	    LastChar = InputBuf;
1746c80476e4SDavid E. O'Brien     }
1747c80476e4SDavid E. O'Brien 
1748c80476e4SDavid E. O'Brien #ifdef KSHVI
1749c80476e4SDavid E. O'Brien     if (VImode)
1750c80476e4SDavid E. O'Brien 	Cursor = InputBuf;
1751c80476e4SDavid E. O'Brien     else
1752c80476e4SDavid E. O'Brien #endif /* KSHVI */
1753c80476e4SDavid E. O'Brien 	Cursor = LastChar;
1754c80476e4SDavid E. O'Brien 
1755c80476e4SDavid E. O'Brien     return(CC_REFRESH);
1756c80476e4SDavid E. O'Brien }
1757c80476e4SDavid E. O'Brien 
1758c80476e4SDavid E. O'Brien /*ARGSUSED*/
1759c80476e4SDavid E. O'Brien CCRETVAL
176045e5710bSMark Peek e_up_hist(Char c)
1761c80476e4SDavid E. O'Brien {
1762c80476e4SDavid E. O'Brien     Char    beep = 0;
1763c80476e4SDavid E. O'Brien 
1764c80476e4SDavid E. O'Brien     USE(c);
1765c80476e4SDavid E. O'Brien     UndoAction = TCSHOP_NOP;
1766c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
1767c80476e4SDavid E. O'Brien 
1768c80476e4SDavid E. O'Brien     if (Hist_num == 0) {	/* save the current buffer away */
176945e5710bSMark Peek 	HistBuf.len = 0;
177045e5710bSMark Peek 	Strbuf_append(&HistBuf, InputBuf);
177145e5710bSMark Peek 	Strbuf_terminate(&HistBuf);
1772c80476e4SDavid E. O'Brien     }
1773c80476e4SDavid E. O'Brien 
1774c80476e4SDavid E. O'Brien     Hist_num += Argument;
1775c80476e4SDavid E. O'Brien 
177645e5710bSMark Peek     if (GetHistLine() == CC_ERROR) {
1777c80476e4SDavid E. O'Brien 	beep = 1;
177845e5710bSMark Peek 	(void) GetHistLine(); /* Hist_num was fixed by first call */
1779c80476e4SDavid E. O'Brien     }
1780c80476e4SDavid E. O'Brien 
1781c80476e4SDavid E. O'Brien     Refresh();
1782c80476e4SDavid E. O'Brien     if (beep)
1783c80476e4SDavid E. O'Brien 	return(CC_ERROR);
1784c80476e4SDavid E. O'Brien     else
1785c80476e4SDavid E. O'Brien 	return(CC_NORM);	/* was CC_UP_HIST */
1786c80476e4SDavid E. O'Brien }
1787c80476e4SDavid E. O'Brien 
1788c80476e4SDavid E. O'Brien /*ARGSUSED*/
1789c80476e4SDavid E. O'Brien CCRETVAL
179045e5710bSMark Peek e_down_hist(Char c)
1791c80476e4SDavid E. O'Brien {
1792c80476e4SDavid E. O'Brien     USE(c);
1793c80476e4SDavid E. O'Brien     UndoAction = TCSHOP_NOP;
1794c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
1795c80476e4SDavid E. O'Brien 
1796c80476e4SDavid E. O'Brien     Hist_num -= Argument;
1797c80476e4SDavid E. O'Brien 
1798c80476e4SDavid E. O'Brien     if (Hist_num < 0) {
1799c80476e4SDavid E. O'Brien 	Hist_num = 0;
1800c80476e4SDavid E. O'Brien 	return(CC_ERROR);	/* make it beep */
1801c80476e4SDavid E. O'Brien     }
1802c80476e4SDavid E. O'Brien 
180345e5710bSMark Peek     return(GetHistLine());
1804c80476e4SDavid E. O'Brien }
1805c80476e4SDavid E. O'Brien 
1806c80476e4SDavid E. O'Brien 
1807c80476e4SDavid E. O'Brien 
1808c80476e4SDavid E. O'Brien /*
1809c80476e4SDavid E. O'Brien  * c_hmatch() return True if the pattern matches the prefix
1810c80476e4SDavid E. O'Brien  */
1811c80476e4SDavid E. O'Brien static int
181245e5710bSMark Peek c_hmatch(Char *str)
1813c80476e4SDavid E. O'Brien {
181445e5710bSMark Peek     if (Strncmp(patbuf.s, str, patbuf.len) == 0)
1815c80476e4SDavid E. O'Brien 	return 1;
181645e5710bSMark Peek     return Gmatch(str, patbuf.s);
1817c80476e4SDavid E. O'Brien }
1818c80476e4SDavid E. O'Brien 
1819c80476e4SDavid E. O'Brien /*
1820c80476e4SDavid E. O'Brien  * c_hsetpat(): Set the history seatch pattern
1821c80476e4SDavid E. O'Brien  */
1822c80476e4SDavid E. O'Brien static void
182345e5710bSMark Peek c_hsetpat(void)
1824c80476e4SDavid E. O'Brien {
1825c80476e4SDavid E. O'Brien     if (LastCmd != F_UP_SEARCH_HIST && LastCmd != F_DOWN_SEARCH_HIST) {
182645e5710bSMark Peek 	patbuf.len = 0;
182745e5710bSMark Peek 	Strbuf_appendn(&patbuf, InputBuf, Cursor - InputBuf);
182845e5710bSMark Peek 	Strbuf_terminate(&patbuf);
1829c80476e4SDavid E. O'Brien     }
1830c80476e4SDavid E. O'Brien #ifdef SDEBUG
1831c80476e4SDavid E. O'Brien     xprintf("\nHist_num = %d\n", Hist_num);
183245e5710bSMark Peek     xprintf("patlen = %d\n", (int)patbuf.len);
183345e5710bSMark Peek     xprintf("patbuf = \"%S\"\n", patbuf.s);
1834c80476e4SDavid E. O'Brien     xprintf("Cursor %d LastChar %d\n", Cursor - InputBuf, LastChar - InputBuf);
1835c80476e4SDavid E. O'Brien #endif
1836c80476e4SDavid E. O'Brien }
1837c80476e4SDavid E. O'Brien 
1838c80476e4SDavid E. O'Brien /*ARGSUSED*/
1839c80476e4SDavid E. O'Brien CCRETVAL
184045e5710bSMark Peek e_up_search_hist(Char c)
1841c80476e4SDavid E. O'Brien {
1842c80476e4SDavid E. O'Brien     struct Hist *hp;
1843c80476e4SDavid E. O'Brien     int h;
184423338178SMark Peek     int    found = 0;
1845c80476e4SDavid E. O'Brien 
1846c80476e4SDavid E. O'Brien     USE(c);
1847c80476e4SDavid E. O'Brien     ActionFlag = TCSHOP_NOP;
1848c80476e4SDavid E. O'Brien     UndoAction = TCSHOP_NOP;
1849c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
1850c80476e4SDavid E. O'Brien     if (Hist_num < 0) {
1851c80476e4SDavid E. O'Brien #ifdef DEBUG_EDIT
1852c80476e4SDavid E. O'Brien 	xprintf("%s: e_up_search_hist(): Hist_num < 0; resetting.\n", progname);
1853c80476e4SDavid E. O'Brien #endif
1854c80476e4SDavid E. O'Brien 	Hist_num = 0;
1855c80476e4SDavid E. O'Brien 	return(CC_ERROR);
1856c80476e4SDavid E. O'Brien     }
1857c80476e4SDavid E. O'Brien 
185845e5710bSMark Peek     if (Hist_num == 0) {
185945e5710bSMark Peek 	HistBuf.len = 0;
186045e5710bSMark Peek 	Strbuf_append(&HistBuf, InputBuf);
186145e5710bSMark Peek 	Strbuf_terminate(&HistBuf);
1862c80476e4SDavid E. O'Brien     }
1863c80476e4SDavid E. O'Brien 
1864c80476e4SDavid E. O'Brien 
1865c80476e4SDavid E. O'Brien     hp = Histlist.Hnext;
1866c80476e4SDavid E. O'Brien     if (hp == NULL)
1867c80476e4SDavid E. O'Brien 	return(CC_ERROR);
1868c80476e4SDavid E. O'Brien 
1869c80476e4SDavid E. O'Brien     c_hsetpat();		/* Set search pattern !! */
1870c80476e4SDavid E. O'Brien 
1871c80476e4SDavid E. O'Brien     for (h = 1; h <= Hist_num; h++)
1872c80476e4SDavid E. O'Brien 	hp = hp->Hnext;
1873c80476e4SDavid E. O'Brien 
1874c80476e4SDavid E. O'Brien     while (hp != NULL) {
187545e5710bSMark Peek 	Char *hl;
187645e5710bSMark Peek 	int matched;
187745e5710bSMark Peek 
187845e5710bSMark Peek 	if (hp->histline == NULL)
187945e5710bSMark Peek 	    hp->histline = sprlex(&hp->Hlex);
188045e5710bSMark Peek 	if (HistLit)
188145e5710bSMark Peek 	    hl = hp->histline;
188245e5710bSMark Peek 	else {
188345e5710bSMark Peek 	    hl = sprlex(&hp->Hlex);
188445e5710bSMark Peek 	    cleanup_push(hl, xfree);
1885c80476e4SDavid E. O'Brien 	}
1886c80476e4SDavid E. O'Brien #ifdef SDEBUG
1887c80476e4SDavid E. O'Brien 	xprintf("Comparing with \"%S\"\n", hl);
1888c80476e4SDavid E. O'Brien #endif
188945e5710bSMark Peek 	matched = (Strncmp(hl, InputBuf, (size_t) (LastChar - InputBuf)) ||
189045e5710bSMark Peek 		   hl[LastChar-InputBuf]) && c_hmatch(hl);
189145e5710bSMark Peek 	if (!HistLit)
189245e5710bSMark Peek 	    cleanup_until(hl);
189345e5710bSMark Peek 	if (matched) {
1894c80476e4SDavid E. O'Brien 	    found++;
1895c80476e4SDavid E. O'Brien 	    break;
1896c80476e4SDavid E. O'Brien 	}
1897c80476e4SDavid E. O'Brien 	h++;
1898c80476e4SDavid E. O'Brien 	hp = hp->Hnext;
1899c80476e4SDavid E. O'Brien     }
1900c80476e4SDavid E. O'Brien 
1901c80476e4SDavid E. O'Brien     if (!found) {
1902c80476e4SDavid E. O'Brien #ifdef SDEBUG
1903c80476e4SDavid E. O'Brien 	xprintf("not found\n");
1904c80476e4SDavid E. O'Brien #endif
1905c80476e4SDavid E. O'Brien 	return(CC_ERROR);
1906c80476e4SDavid E. O'Brien     }
1907c80476e4SDavid E. O'Brien 
1908c80476e4SDavid E. O'Brien     Hist_num = h;
1909c80476e4SDavid E. O'Brien 
191045e5710bSMark Peek     return(GetHistLine());
1911c80476e4SDavid E. O'Brien }
1912c80476e4SDavid E. O'Brien 
1913c80476e4SDavid E. O'Brien /*ARGSUSED*/
1914c80476e4SDavid E. O'Brien CCRETVAL
191545e5710bSMark Peek e_down_search_hist(Char c)
1916c80476e4SDavid E. O'Brien {
1917c80476e4SDavid E. O'Brien     struct Hist *hp;
1918c80476e4SDavid E. O'Brien     int h;
191923338178SMark Peek     int    found = 0;
1920c80476e4SDavid E. O'Brien 
1921c80476e4SDavid E. O'Brien     USE(c);
1922c80476e4SDavid E. O'Brien     ActionFlag = TCSHOP_NOP;
1923c80476e4SDavid E. O'Brien     UndoAction = TCSHOP_NOP;
1924c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
1925c80476e4SDavid E. O'Brien 
1926c80476e4SDavid E. O'Brien     if (Hist_num == 0)
1927c80476e4SDavid E. O'Brien 	return(CC_ERROR);
1928c80476e4SDavid E. O'Brien 
1929c80476e4SDavid E. O'Brien     hp = Histlist.Hnext;
1930c80476e4SDavid E. O'Brien     if (hp == 0)
1931c80476e4SDavid E. O'Brien 	return(CC_ERROR);
1932c80476e4SDavid E. O'Brien 
1933c80476e4SDavid E. O'Brien     c_hsetpat();		/* Set search pattern !! */
1934c80476e4SDavid E. O'Brien 
1935c80476e4SDavid E. O'Brien     for (h = 1; h < Hist_num && hp; h++) {
193645e5710bSMark Peek 	Char *hl;
193745e5710bSMark Peek 	if (hp->histline == NULL)
193845e5710bSMark Peek 	    hp->histline = sprlex(&hp->Hlex);
193945e5710bSMark Peek 	if (HistLit)
194045e5710bSMark Peek 	    hl = hp->histline;
194145e5710bSMark Peek 	else {
194245e5710bSMark Peek 	    hl = sprlex(&hp->Hlex);
194345e5710bSMark Peek 	    cleanup_push(hl, xfree);
1944c80476e4SDavid E. O'Brien 	}
1945c80476e4SDavid E. O'Brien #ifdef SDEBUG
1946c80476e4SDavid E. O'Brien 	xprintf("Comparing with \"%S\"\n", hl);
1947c80476e4SDavid E. O'Brien #endif
1948c80476e4SDavid E. O'Brien 	if ((Strncmp(hl, InputBuf, (size_t) (LastChar - InputBuf)) ||
1949c80476e4SDavid E. O'Brien 	     hl[LastChar-InputBuf]) && c_hmatch(hl))
1950c80476e4SDavid E. O'Brien 	    found = h;
195145e5710bSMark Peek 	if (!HistLit)
195245e5710bSMark Peek 	    cleanup_until(hl);
1953c80476e4SDavid E. O'Brien 	hp = hp->Hnext;
1954c80476e4SDavid E. O'Brien     }
1955c80476e4SDavid E. O'Brien 
1956c80476e4SDavid E. O'Brien     if (!found) {		/* is it the current history number? */
195745e5710bSMark Peek 	if (!c_hmatch(HistBuf.s)) {
1958c80476e4SDavid E. O'Brien #ifdef SDEBUG
1959c80476e4SDavid E. O'Brien 	    xprintf("not found\n");
1960c80476e4SDavid E. O'Brien #endif
1961c80476e4SDavid E. O'Brien 	    return(CC_ERROR);
1962c80476e4SDavid E. O'Brien 	}
1963c80476e4SDavid E. O'Brien     }
1964c80476e4SDavid E. O'Brien 
1965c80476e4SDavid E. O'Brien     Hist_num = found;
1966c80476e4SDavid E. O'Brien 
196745e5710bSMark Peek     return(GetHistLine());
1968c80476e4SDavid E. O'Brien }
1969c80476e4SDavid E. O'Brien 
1970c80476e4SDavid E. O'Brien /*ARGSUSED*/
1971c80476e4SDavid E. O'Brien CCRETVAL
197245e5710bSMark Peek e_helpme(Char c)
1973c80476e4SDavid E. O'Brien {
1974c80476e4SDavid E. O'Brien     USE(c);
1975c80476e4SDavid E. O'Brien     PastBottom();
1976c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
1977c80476e4SDavid E. O'Brien     return(CC_HELPME);
1978c80476e4SDavid E. O'Brien }
1979c80476e4SDavid E. O'Brien 
1980c80476e4SDavid E. O'Brien /*ARGSUSED*/
1981c80476e4SDavid E. O'Brien CCRETVAL
198245e5710bSMark Peek e_correct(Char c)
1983c80476e4SDavid E. O'Brien {
1984c80476e4SDavid E. O'Brien     USE(c);
1985c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
1986c80476e4SDavid E. O'Brien     return(CC_CORRECT);
1987c80476e4SDavid E. O'Brien }
1988c80476e4SDavid E. O'Brien 
1989c80476e4SDavid E. O'Brien /*ARGSUSED*/
1990c80476e4SDavid E. O'Brien CCRETVAL
199145e5710bSMark Peek e_correctl(Char c)
1992c80476e4SDavid E. O'Brien {
1993c80476e4SDavid E. O'Brien     USE(c);
1994c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
1995c80476e4SDavid E. O'Brien     return(CC_CORRECT_L);
1996c80476e4SDavid E. O'Brien }
1997c80476e4SDavid E. O'Brien 
1998c80476e4SDavid E. O'Brien /*ARGSUSED*/
1999c80476e4SDavid E. O'Brien CCRETVAL
200045e5710bSMark Peek e_run_fg_editor(Char c)
2001c80476e4SDavid E. O'Brien {
20026767bd61SMark Peek     struct process *pp;
2003c80476e4SDavid E. O'Brien 
2004c80476e4SDavid E. O'Brien     USE(c);
2005c80476e4SDavid E. O'Brien     if ((pp = find_stop_ed()) != NULL) {
2006c80476e4SDavid E. O'Brien 	/* save our editor state so we can restore it */
200745e5710bSMark Peek 	c_save_inputbuf();
2008c80476e4SDavid E. O'Brien 	Hist_num = 0;		/* for the history commands */
2009c80476e4SDavid E. O'Brien 
2010c80476e4SDavid E. O'Brien 	/* put the tty in a sane mode */
2011c80476e4SDavid E. O'Brien 	PastBottom();
2012c80476e4SDavid E. O'Brien 	(void) Cookedmode();	/* make sure the tty is set up correctly */
2013c80476e4SDavid E. O'Brien 
2014c80476e4SDavid E. O'Brien 	/* do it! */
2015c80476e4SDavid E. O'Brien 	fg_proc_entry(pp);
2016c80476e4SDavid E. O'Brien 
2017c80476e4SDavid E. O'Brien 	(void) Rawmode();	/* go on */
2018c80476e4SDavid E. O'Brien 	Refresh();
201945e5710bSMark Peek 	RestoreSaved = 0;
202045e5710bSMark Peek 	HistSaved = 0;
2021c80476e4SDavid E. O'Brien     }
2022c80476e4SDavid E. O'Brien     return(CC_NORM);
2023c80476e4SDavid E. O'Brien }
2024c80476e4SDavid E. O'Brien 
2025c80476e4SDavid E. O'Brien /*ARGSUSED*/
2026c80476e4SDavid E. O'Brien CCRETVAL
202745e5710bSMark Peek e_list_choices(Char c)
2028c80476e4SDavid E. O'Brien {
2029c80476e4SDavid E. O'Brien     USE(c);
2030c80476e4SDavid E. O'Brien     PastBottom();
2031c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
2032c80476e4SDavid E. O'Brien     return(CC_LIST_CHOICES);
2033c80476e4SDavid E. O'Brien }
2034c80476e4SDavid E. O'Brien 
2035c80476e4SDavid E. O'Brien /*ARGSUSED*/
2036c80476e4SDavid E. O'Brien CCRETVAL
203745e5710bSMark Peek e_list_all(Char c)
2038c80476e4SDavid E. O'Brien {
2039c80476e4SDavid E. O'Brien     USE(c);
2040c80476e4SDavid E. O'Brien     PastBottom();
2041c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
2042c80476e4SDavid E. O'Brien     return(CC_LIST_ALL);
2043c80476e4SDavid E. O'Brien }
2044c80476e4SDavid E. O'Brien 
2045c80476e4SDavid E. O'Brien /*ARGSUSED*/
2046c80476e4SDavid E. O'Brien CCRETVAL
204745e5710bSMark Peek e_list_glob(Char c)
2048c80476e4SDavid E. O'Brien {
2049c80476e4SDavid E. O'Brien     USE(c);
2050c80476e4SDavid E. O'Brien     PastBottom();
2051c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
2052c80476e4SDavid E. O'Brien     return(CC_LIST_GLOB);
2053c80476e4SDavid E. O'Brien }
2054c80476e4SDavid E. O'Brien 
2055c80476e4SDavid E. O'Brien /*ARGSUSED*/
2056c80476e4SDavid E. O'Brien CCRETVAL
205745e5710bSMark Peek e_expand_glob(Char c)
2058c80476e4SDavid E. O'Brien {
2059c80476e4SDavid E. O'Brien     USE(c);
2060c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
2061c80476e4SDavid E. O'Brien     return(CC_EXPAND_GLOB);
2062c80476e4SDavid E. O'Brien }
2063c80476e4SDavid E. O'Brien 
2064c80476e4SDavid E. O'Brien /*ARGSUSED*/
2065c80476e4SDavid E. O'Brien CCRETVAL
206645e5710bSMark Peek e_normalize_path(Char c)
2067c80476e4SDavid E. O'Brien {
2068c80476e4SDavid E. O'Brien     USE(c);
2069c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
2070c80476e4SDavid E. O'Brien     return(CC_NORMALIZE_PATH);
2071c80476e4SDavid E. O'Brien }
2072c80476e4SDavid E. O'Brien 
2073c80476e4SDavid E. O'Brien /*ARGSUSED*/
2074c80476e4SDavid E. O'Brien CCRETVAL
207545e5710bSMark Peek e_normalize_command(Char c)
2076c80476e4SDavid E. O'Brien {
2077c80476e4SDavid E. O'Brien     USE(c);
2078c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
2079c80476e4SDavid E. O'Brien     return(CC_NORMALIZE_COMMAND);
2080c80476e4SDavid E. O'Brien }
2081c80476e4SDavid E. O'Brien 
2082c80476e4SDavid E. O'Brien /*ARGSUSED*/
2083c80476e4SDavid E. O'Brien CCRETVAL
208445e5710bSMark Peek e_expand_vars(Char c)
2085c80476e4SDavid E. O'Brien {
2086c80476e4SDavid E. O'Brien     USE(c);
2087c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
2088c80476e4SDavid E. O'Brien     return(CC_EXPAND_VARS);
2089c80476e4SDavid E. O'Brien }
2090c80476e4SDavid E. O'Brien 
2091c80476e4SDavid E. O'Brien /*ARGSUSED*/
2092c80476e4SDavid E. O'Brien CCRETVAL
209345e5710bSMark Peek e_which(Char c)
2094c80476e4SDavid E. O'Brien {				/* do a fast command line which(1) */
2095c80476e4SDavid E. O'Brien     USE(c);
209645e5710bSMark Peek     c_save_inputbuf();
209745e5710bSMark Peek     Hist_num = 0;		/* for the history commands */
2098c80476e4SDavid E. O'Brien     PastBottom();
2099c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
2100c80476e4SDavid E. O'Brien     return(CC_WHICH);
2101c80476e4SDavid E. O'Brien }
2102c80476e4SDavid E. O'Brien 
2103c80476e4SDavid E. O'Brien /*ARGSUSED*/
2104c80476e4SDavid E. O'Brien CCRETVAL
210545e5710bSMark Peek e_last_item(Char c)
2106c80476e4SDavid E. O'Brien {				/* insert the last element of the prev. cmd */
21076767bd61SMark Peek     struct Hist *hp;
21086767bd61SMark Peek     struct wordent *wp, *firstp;
21096767bd61SMark Peek     int i;
211045e5710bSMark Peek     Char *expanded;
2111c80476e4SDavid E. O'Brien 
2112c80476e4SDavid E. O'Brien     USE(c);
2113c80476e4SDavid E. O'Brien     if (Argument <= 0)
2114c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2115c80476e4SDavid E. O'Brien 
2116c80476e4SDavid E. O'Brien     hp = Histlist.Hnext;
2117c80476e4SDavid E. O'Brien     if (hp == NULL) {	/* this is only if no history */
2118c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2119c80476e4SDavid E. O'Brien     }
2120c80476e4SDavid E. O'Brien 
2121c80476e4SDavid E. O'Brien     wp = (hp->Hlex).prev;
2122c80476e4SDavid E. O'Brien 
2123c80476e4SDavid E. O'Brien     if (wp->prev == (struct wordent *) NULL)
2124c80476e4SDavid E. O'Brien 	return(CC_ERROR);	/* an empty history entry */
2125c80476e4SDavid E. O'Brien 
2126c80476e4SDavid E. O'Brien     firstp = (hp->Hlex).next;
2127c80476e4SDavid E. O'Brien 
2128c80476e4SDavid E. O'Brien     /* back up arg words in lex */
2129c80476e4SDavid E. O'Brien     for (i = 0; i < Argument && wp != firstp; i++) {
2130c80476e4SDavid E. O'Brien 	wp = wp->prev;
2131c80476e4SDavid E. O'Brien     }
2132c80476e4SDavid E. O'Brien 
213345e5710bSMark Peek     expanded = expand_lex(wp->prev, 0, i - 1);
213445e5710bSMark Peek     if (InsertStr(expanded)) {
213545e5710bSMark Peek 	xfree(expanded);
2136c80476e4SDavid E. O'Brien 	return(CC_ERROR);
213745e5710bSMark Peek     }
2138c80476e4SDavid E. O'Brien 
213945e5710bSMark Peek     xfree(expanded);
2140c80476e4SDavid E. O'Brien     return(CC_REFRESH);
2141c80476e4SDavid E. O'Brien }
2142c80476e4SDavid E. O'Brien 
2143c80476e4SDavid E. O'Brien /*ARGSUSED*/
2144c80476e4SDavid E. O'Brien CCRETVAL
214545e5710bSMark Peek e_dabbrev_expand(Char c)
2146c80476e4SDavid E. O'Brien {				/* expand to preceding word matching prefix */
21476767bd61SMark Peek     Char *cp, *ncp, *bp;
21486767bd61SMark Peek     struct Hist *hp;
214945e5710bSMark Peek     int arg = 0, i;
215045e5710bSMark Peek     size_t len = 0;
215123338178SMark Peek     int found = 0;
215245e5710bSMark Peek     Char *hbuf;
2153c80476e4SDavid E. O'Brien     static int oldevent, hist, word;
2154c80476e4SDavid E. O'Brien     static Char *start, *oldcursor;
2155c80476e4SDavid E. O'Brien 
2156c80476e4SDavid E. O'Brien     USE(c);
2157c80476e4SDavid E. O'Brien     if (Argument <= 0)
2158c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2159c80476e4SDavid E. O'Brien 
21606767bd61SMark Peek     cp = c_preword(Cursor, InputBuf, 1, STRshwordsep);
2161c80476e4SDavid E. O'Brien     if (cp == Cursor || Isspace(*cp))
2162c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2163c80476e4SDavid E. O'Brien 
216445e5710bSMark Peek     hbuf = NULL;
2165c80476e4SDavid E. O'Brien     hp = Histlist.Hnext;
2166c80476e4SDavid E. O'Brien     bp = InputBuf;
2167c80476e4SDavid E. O'Brien     if (Argument == 1 && eventno == oldevent && cp == start &&
216845e5710bSMark Peek 	Cursor == oldcursor && patbuf.len > 0
216945e5710bSMark Peek 	&& Strncmp(patbuf.s, cp, patbuf.len) == 0){
2170c80476e4SDavid E. O'Brien 	/* continue previous search - go to last match (hist/word) */
2171c80476e4SDavid E. O'Brien 	if (hist != 0) {		/* need to move up history */
2172c80476e4SDavid E. O'Brien 	    for (i = 1; i < hist && hp != NULL; i++)
2173c80476e4SDavid E. O'Brien 		hp = hp->Hnext;
2174c80476e4SDavid E. O'Brien 	    if (hp == NULL)	/* "can't happen" */
217545e5710bSMark Peek 		goto err_hbuf;
217645e5710bSMark Peek 	    hbuf = expand_lex(&hp->Hlex, 0, INT_MAX);
217745e5710bSMark Peek 	    cp = Strend(hbuf);
2178c80476e4SDavid E. O'Brien 	    bp = hbuf;
2179c80476e4SDavid E. O'Brien 	    hp = hp->Hnext;
2180c80476e4SDavid E. O'Brien 	}
21816767bd61SMark Peek 	cp = c_preword(cp, bp, word, STRshwordsep);
2182c80476e4SDavid E. O'Brien     } else {			/* starting new search */
2183c80476e4SDavid E. O'Brien 	oldevent = eventno;
2184c80476e4SDavid E. O'Brien 	start = cp;
218545e5710bSMark Peek 	patbuf.len = 0;
218645e5710bSMark Peek 	Strbuf_appendn(&patbuf, cp, Cursor - cp);
2187c80476e4SDavid E. O'Brien 	hist = 0;
2188c80476e4SDavid E. O'Brien 	word = 0;
2189c80476e4SDavid E. O'Brien     }
2190c80476e4SDavid E. O'Brien 
2191c80476e4SDavid E. O'Brien     while (!found) {
21926767bd61SMark Peek 	ncp = c_preword(cp, bp, 1, STRshwordsep);
2193c80476e4SDavid E. O'Brien 	if (ncp == cp || Isspace(*ncp)) { /* beginning of line */
2194c80476e4SDavid E. O'Brien 	    hist++;
2195c80476e4SDavid E. O'Brien 	    word = 0;
2196c80476e4SDavid E. O'Brien 	    if (hp == NULL)
219745e5710bSMark Peek 		goto err_hbuf;
219845e5710bSMark Peek 	    hbuf = expand_lex(&hp->Hlex, 0, INT_MAX);
219945e5710bSMark Peek 	    cp = Strend(hbuf);
2200c80476e4SDavid E. O'Brien 	    bp = hbuf;
2201c80476e4SDavid E. O'Brien 	    hp = hp->Hnext;
2202c80476e4SDavid E. O'Brien 	    continue;
2203c80476e4SDavid E. O'Brien 	} else {
2204c80476e4SDavid E. O'Brien 	    word++;
220545e5710bSMark Peek 	    len = c_endword(ncp-1, cp, 1, STRshwordsep) - ncp + 1;
2206c80476e4SDavid E. O'Brien 	    cp = ncp;
2207c80476e4SDavid E. O'Brien 	}
220845e5710bSMark Peek 	if (len > patbuf.len && Strncmp(cp, patbuf.s, patbuf.len) == 0) {
2209c80476e4SDavid E. O'Brien 	    /* We don't fully check distinct matches as Gnuemacs does: */
2210c80476e4SDavid E. O'Brien 	    if (Argument > 1) {	/* just count matches */
2211c80476e4SDavid E. O'Brien 		if (++arg >= Argument)
2212c80476e4SDavid E. O'Brien 		    found++;
2213c80476e4SDavid E. O'Brien 	    } else {		/* match if distinct from previous */
221445e5710bSMark Peek 		if (len != (size_t)(Cursor - start)
221545e5710bSMark Peek 		    || Strncmp(cp, start, len) != 0)
2216c80476e4SDavid E. O'Brien 		    found++;
2217c80476e4SDavid E. O'Brien 	    }
2218c80476e4SDavid E. O'Brien 	}
2219c80476e4SDavid E. O'Brien     }
2220c80476e4SDavid E. O'Brien 
2221c80476e4SDavid E. O'Brien     if (LastChar + len - (Cursor - start) >= InputLim)
222245e5710bSMark Peek 	goto err_hbuf;	/* no room */
2223c80476e4SDavid E. O'Brien     DeleteBack(Cursor - start);
2224c80476e4SDavid E. O'Brien     c_insert(len);
2225c80476e4SDavid E. O'Brien     while (len--)
2226c80476e4SDavid E. O'Brien 	*Cursor++ = *cp++;
2227c80476e4SDavid E. O'Brien     oldcursor = Cursor;
222845e5710bSMark Peek     xfree(hbuf);
2229c80476e4SDavid E. O'Brien     return(CC_REFRESH);
223045e5710bSMark Peek 
223145e5710bSMark Peek  err_hbuf:
223245e5710bSMark Peek     xfree(hbuf);
223345e5710bSMark Peek     return CC_ERROR;
2234c80476e4SDavid E. O'Brien }
2235c80476e4SDavid E. O'Brien 
2236c80476e4SDavid E. O'Brien /*ARGSUSED*/
2237c80476e4SDavid E. O'Brien CCRETVAL
223845e5710bSMark Peek e_yank_kill(Char c)
2239c80476e4SDavid E. O'Brien {				/* almost like GnuEmacs */
22406767bd61SMark Peek     int len;
22416767bd61SMark Peek     Char *kp, *cp;
2242c80476e4SDavid E. O'Brien 
2243c80476e4SDavid E. O'Brien     USE(c);
22446767bd61SMark Peek     if (KillRingLen == 0)	/* nothing killed */
2245c80476e4SDavid E. O'Brien 	return(CC_ERROR);
22466767bd61SMark Peek     len = Strlen(KillRing[YankPos].buf);
22476767bd61SMark Peek     if (LastChar + len >= InputLim)
2248c80476e4SDavid E. O'Brien 	return(CC_ERROR);	/* end of buffer space */
2249c80476e4SDavid E. O'Brien 
2250c80476e4SDavid E. O'Brien     /* else */
2251c80476e4SDavid E. O'Brien     cp = Cursor;		/* for speed */
2252c80476e4SDavid E. O'Brien 
22536767bd61SMark Peek     c_insert(len);		/* open the space, */
22546767bd61SMark Peek     for (kp = KillRing[YankPos].buf; *kp; kp++)	/* copy the chars */
2255c80476e4SDavid E. O'Brien 	*cp++ = *kp;
2256c80476e4SDavid E. O'Brien 
22576767bd61SMark Peek     if (Argument == 1) {	/* if no arg */
22586767bd61SMark Peek 	Mark = Cursor;		/* mark at beginning, cursor at end */
22596767bd61SMark Peek 	Cursor = cp;
22606767bd61SMark Peek     } else {
22616767bd61SMark Peek 	Mark = cp;		/* else cursor at beginning, mark at end */
22626767bd61SMark Peek     }
22636767bd61SMark Peek 
226445e5710bSMark Peek     if (adrof(STRhighlight) && MarkIsSet) {
226545e5710bSMark Peek 	ClearLines();
226645e5710bSMark Peek 	ClearDisp();
226745e5710bSMark Peek     }
226845e5710bSMark Peek     MarkIsSet = 0;
22696767bd61SMark Peek     return(CC_REFRESH);
22706767bd61SMark Peek }
22716767bd61SMark Peek 
22726767bd61SMark Peek /*ARGSUSED*/
22736767bd61SMark Peek CCRETVAL
227445e5710bSMark Peek e_yank_pop(Char c)
22756767bd61SMark Peek {				/* almost like GnuEmacs */
22766767bd61SMark Peek     int m_bef_c, del_len, ins_len;
22776767bd61SMark Peek     Char *kp, *cp;
22786767bd61SMark Peek 
22796767bd61SMark Peek     USE(c);
22806767bd61SMark Peek 
22816767bd61SMark Peek #if 0
22826767bd61SMark Peek     /* XXX This "should" be here, but doesn't work, since LastCmd
22836767bd61SMark Peek        gets set on CC_ERROR and CC_ARGHACK, which it shouldn't(?).
22846767bd61SMark Peek        (But what about F_ARGFOUR?) I.e. if you hit M-y twice the
22856767bd61SMark Peek        second one will "succeed" even if the first one wasn't preceded
22866767bd61SMark Peek        by a yank, and giving an argument is impossible. Now we "succeed"
22876767bd61SMark Peek        regardless of previous command, which is wrong too of course. */
22886767bd61SMark Peek     if (LastCmd != F_YANK_KILL && LastCmd != F_YANK_POP)
22896767bd61SMark Peek 	return(CC_ERROR);
22906767bd61SMark Peek #endif
22916767bd61SMark Peek 
22926767bd61SMark Peek     if (KillRingLen == 0)	/* nothing killed */
22936767bd61SMark Peek 	return(CC_ERROR);
22946767bd61SMark Peek     YankPos -= Argument;
22956767bd61SMark Peek     while (YankPos < 0)
22966767bd61SMark Peek 	YankPos += KillRingLen;
22976767bd61SMark Peek     YankPos %= KillRingLen;
22986767bd61SMark Peek 
22996767bd61SMark Peek     if (Cursor > Mark) {
23006767bd61SMark Peek 	del_len = Cursor - Mark;
23016767bd61SMark Peek 	m_bef_c = 1;
23026767bd61SMark Peek     } else {
23036767bd61SMark Peek 	del_len = Mark - Cursor;
23046767bd61SMark Peek 	m_bef_c = 0;
23056767bd61SMark Peek     }
23066767bd61SMark Peek     ins_len = Strlen(KillRing[YankPos].buf);
23076767bd61SMark Peek     if (LastChar + ins_len - del_len >= InputLim)
23086767bd61SMark Peek 	return(CC_ERROR);	/* end of buffer space */
23096767bd61SMark Peek 
23106767bd61SMark Peek     if (m_bef_c) {
23116767bd61SMark Peek 	c_delbefore(del_len);
23126767bd61SMark Peek     } else {
23136767bd61SMark Peek 	c_delafter(del_len);
23146767bd61SMark Peek     }
23156767bd61SMark Peek     cp = Cursor;		/* for speed */
23166767bd61SMark Peek 
23176767bd61SMark Peek     c_insert(ins_len);		/* open the space, */
23186767bd61SMark Peek     for (kp = KillRing[YankPos].buf; *kp; kp++)	/* copy the chars */
23196767bd61SMark Peek 	*cp++ = *kp;
23206767bd61SMark Peek 
23216767bd61SMark Peek     if (m_bef_c) {
23226767bd61SMark Peek 	Mark = Cursor;		/* mark at beginning, cursor at end */
23236767bd61SMark Peek 	Cursor = cp;
23246767bd61SMark Peek     } else {
23256767bd61SMark Peek 	Mark = cp;		/* else cursor at beginning, mark at end */
23266767bd61SMark Peek     }
2327c80476e4SDavid E. O'Brien 
232845e5710bSMark Peek     if (adrof(STRhighlight) && MarkIsSet) {
232945e5710bSMark Peek 	ClearLines();
233045e5710bSMark Peek 	ClearDisp();
233145e5710bSMark Peek     }
233245e5710bSMark Peek     MarkIsSet = 0;
2333c80476e4SDavid E. O'Brien     return(CC_REFRESH);
2334c80476e4SDavid E. O'Brien }
2335c80476e4SDavid E. O'Brien 
2336c80476e4SDavid E. O'Brien /*ARGSUSED*/
2337c80476e4SDavid E. O'Brien CCRETVAL
233845e5710bSMark Peek v_delprev(Char c) 		/* Backspace key in insert mode */
2339c80476e4SDavid E. O'Brien {
2340c80476e4SDavid E. O'Brien     int rc;
2341c80476e4SDavid E. O'Brien 
2342c80476e4SDavid E. O'Brien     USE(c);
2343c80476e4SDavid E. O'Brien     rc = CC_ERROR;
2344c80476e4SDavid E. O'Brien 
2345c80476e4SDavid E. O'Brien     if (InsertPos != 0) {
2346c80476e4SDavid E. O'Brien 	if (Argument <= Cursor - InsertPos) {
2347c80476e4SDavid E. O'Brien 	    c_delbefore(Argument);	/* delete before */
2348c80476e4SDavid E. O'Brien 	    rc = CC_REFRESH;
2349c80476e4SDavid E. O'Brien 	}
2350c80476e4SDavid E. O'Brien     }
2351c80476e4SDavid E. O'Brien     return(rc);
2352c80476e4SDavid E. O'Brien }   /* v_delprev  */
2353c80476e4SDavid E. O'Brien 
2354c80476e4SDavid E. O'Brien /*ARGSUSED*/
2355c80476e4SDavid E. O'Brien CCRETVAL
235645e5710bSMark Peek e_delprev(Char c)
2357c80476e4SDavid E. O'Brien {
2358c80476e4SDavid E. O'Brien     USE(c);
2359c80476e4SDavid E. O'Brien     if (Cursor > InputBuf) {
2360c80476e4SDavid E. O'Brien 	c_delbefore(Argument);	/* delete before dot */
2361c80476e4SDavid E. O'Brien 	return(CC_REFRESH);
2362c80476e4SDavid E. O'Brien     }
2363c80476e4SDavid E. O'Brien     else {
2364c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2365c80476e4SDavid E. O'Brien     }
2366c80476e4SDavid E. O'Brien }
2367c80476e4SDavid E. O'Brien 
2368c80476e4SDavid E. O'Brien /*ARGSUSED*/
2369c80476e4SDavid E. O'Brien CCRETVAL
237045e5710bSMark Peek e_delwordprev(Char c)
2371c80476e4SDavid E. O'Brien {
23726767bd61SMark Peek     Char *cp;
2373c80476e4SDavid E. O'Brien 
2374c80476e4SDavid E. O'Brien     USE(c);
2375c80476e4SDavid E. O'Brien     if (Cursor == InputBuf)
2376c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2377c80476e4SDavid E. O'Brien     /* else */
2378c80476e4SDavid E. O'Brien 
2379c80476e4SDavid E. O'Brien     cp = c_prev_word(Cursor, InputBuf, Argument);
2380c80476e4SDavid E. O'Brien 
23816767bd61SMark Peek     c_push_kill(cp, Cursor);	/* save the text */
2382c80476e4SDavid E. O'Brien 
2383c80476e4SDavid E. O'Brien     c_delbefore((int)(Cursor - cp));	/* delete before dot */
2384c80476e4SDavid E. O'Brien     return(CC_REFRESH);
2385c80476e4SDavid E. O'Brien }
2386c80476e4SDavid E. O'Brien 
2387c80476e4SDavid E. O'Brien /* DCS <dcs@neutron.chem.yale.edu>, 9 Oct 93
2388c80476e4SDavid E. O'Brien  *
2389c80476e4SDavid E. O'Brien  * Changed the names of some of the ^D family of editor functions to
2390c80476e4SDavid E. O'Brien  * correspond to what they actually do and created new e_delnext_list
2391c80476e4SDavid E. O'Brien  * for completeness.
2392c80476e4SDavid E. O'Brien  *
2393c80476e4SDavid E. O'Brien  *   Old names:			New names:
2394c80476e4SDavid E. O'Brien  *
2395c80476e4SDavid E. O'Brien  *   delete-char		delete-char-or-eof
2396c80476e4SDavid E. O'Brien  *     F_DELNEXT		  F_DELNEXT_EOF
2397c80476e4SDavid E. O'Brien  *     e_delnext		  e_delnext_eof
2398c80476e4SDavid E. O'Brien  *     edelnxt			  edelnxteof
2399c80476e4SDavid E. O'Brien  *   delete-char-or-eof		delete-char
2400c80476e4SDavid E. O'Brien  *     F_DELNEXT_EOF		  F_DELNEXT
2401c80476e4SDavid E. O'Brien  *     e_delnext_eof		  e_delnext
2402c80476e4SDavid E. O'Brien  *     edelnxteof		  edelnxt
2403c80476e4SDavid E. O'Brien  *   delete-char-or-list	delete-char-or-list-or-eof
2404c80476e4SDavid E. O'Brien  *     F_LIST_DELNEXT		  F_DELNEXT_LIST_EOF
2405c80476e4SDavid E. O'Brien  *     e_list_delnext		  e_delnext_list_eof
2406c80476e4SDavid E. O'Brien  *   				  edellsteof
2407c80476e4SDavid E. O'Brien  *   (no old equivalent)	delete-char-or-list
2408c80476e4SDavid E. O'Brien  *   				  F_DELNEXT_LIST
2409c80476e4SDavid E. O'Brien  *   				  e_delnext_list
2410c80476e4SDavid E. O'Brien  *   				  e_delnxtlst
2411c80476e4SDavid E. O'Brien  */
2412c80476e4SDavid E. O'Brien 
2413c80476e4SDavid E. O'Brien /* added by mtk@ari.ncl.omron.co.jp (920818) */
2414c80476e4SDavid E. O'Brien /* rename e_delnext() -> e_delnext_eof() */
2415c80476e4SDavid E. O'Brien /*ARGSUSED*/
2416c80476e4SDavid E. O'Brien CCRETVAL
241745e5710bSMark Peek e_delnext(Char c)
2418c80476e4SDavid E. O'Brien {
2419c80476e4SDavid E. O'Brien     USE(c);
2420c80476e4SDavid E. O'Brien     if (Cursor == LastChar) {/* if I'm at the end */
2421c80476e4SDavid E. O'Brien 	if (!VImode) {
2422c80476e4SDavid E. O'Brien 		return(CC_ERROR);
2423c80476e4SDavid E. O'Brien 	}
2424c80476e4SDavid E. O'Brien 	else {
2425c80476e4SDavid E. O'Brien 	    if (Cursor != InputBuf)
2426c80476e4SDavid E. O'Brien 		Cursor--;
2427c80476e4SDavid E. O'Brien 	    else
2428c80476e4SDavid E. O'Brien 		return(CC_ERROR);
2429c80476e4SDavid E. O'Brien 	}
2430c80476e4SDavid E. O'Brien     }
2431c80476e4SDavid E. O'Brien     c_delafter(Argument);	/* delete after dot */
2432c80476e4SDavid E. O'Brien     if (Cursor > LastChar)
2433c80476e4SDavid E. O'Brien 	Cursor = LastChar;	/* bounds check */
2434c80476e4SDavid E. O'Brien     return(CC_REFRESH);
2435c80476e4SDavid E. O'Brien }
2436c80476e4SDavid E. O'Brien 
2437c80476e4SDavid E. O'Brien 
2438c80476e4SDavid E. O'Brien /*ARGSUSED*/
2439c80476e4SDavid E. O'Brien CCRETVAL
244045e5710bSMark Peek e_delnext_eof(Char c)
2441c80476e4SDavid E. O'Brien {
2442c80476e4SDavid E. O'Brien     USE(c);
2443c80476e4SDavid E. O'Brien     if (Cursor == LastChar) {/* if I'm at the end */
2444c80476e4SDavid E. O'Brien 	if (!VImode) {
2445c80476e4SDavid E. O'Brien 	    if (Cursor == InputBuf) {
2446c80476e4SDavid E. O'Brien 		/* if I'm also at the beginning */
2447c80476e4SDavid E. O'Brien 		so_write(STReof, 4);/* then do a EOF */
2448c80476e4SDavid E. O'Brien 		flush();
2449c80476e4SDavid E. O'Brien 		return(CC_EOF);
2450c80476e4SDavid E. O'Brien 	    }
2451c80476e4SDavid E. O'Brien 	    else
2452c80476e4SDavid E. O'Brien 		return(CC_ERROR);
2453c80476e4SDavid E. O'Brien 	}
2454c80476e4SDavid E. O'Brien 	else {
2455c80476e4SDavid E. O'Brien 	    if (Cursor != InputBuf)
2456c80476e4SDavid E. O'Brien 		Cursor--;
2457c80476e4SDavid E. O'Brien 	    else
2458c80476e4SDavid E. O'Brien 		return(CC_ERROR);
2459c80476e4SDavid E. O'Brien 	}
2460c80476e4SDavid E. O'Brien     }
2461c80476e4SDavid E. O'Brien     c_delafter(Argument);	/* delete after dot */
2462c80476e4SDavid E. O'Brien     if (Cursor > LastChar)
2463c80476e4SDavid E. O'Brien 	Cursor = LastChar;	/* bounds check */
2464c80476e4SDavid E. O'Brien     return(CC_REFRESH);
2465c80476e4SDavid E. O'Brien }
2466c80476e4SDavid E. O'Brien 
2467c80476e4SDavid E. O'Brien /*ARGSUSED*/
2468c80476e4SDavid E. O'Brien CCRETVAL
246945e5710bSMark Peek e_delnext_list(Char c)
2470c80476e4SDavid E. O'Brien {
2471c80476e4SDavid E. O'Brien     USE(c);
2472c80476e4SDavid E. O'Brien     if (Cursor == LastChar) {	/* if I'm at the end */
2473c80476e4SDavid E. O'Brien 	PastBottom();
2474c80476e4SDavid E. O'Brien 	*LastChar = '\0';	/* just in case */
2475c80476e4SDavid E. O'Brien 	return(CC_LIST_CHOICES);
2476c80476e4SDavid E. O'Brien     }
2477c80476e4SDavid E. O'Brien     else {
2478c80476e4SDavid E. O'Brien 	c_delafter(Argument);	/* delete after dot */
2479c80476e4SDavid E. O'Brien 	if (Cursor > LastChar)
2480c80476e4SDavid E. O'Brien 	    Cursor = LastChar;	/* bounds check */
2481c80476e4SDavid E. O'Brien 	return(CC_REFRESH);
2482c80476e4SDavid E. O'Brien     }
2483c80476e4SDavid E. O'Brien }
2484c80476e4SDavid E. O'Brien 
2485c80476e4SDavid E. O'Brien /*ARGSUSED*/
2486c80476e4SDavid E. O'Brien CCRETVAL
248745e5710bSMark Peek e_delnext_list_eof(Char c)
2488c80476e4SDavid E. O'Brien {
2489c80476e4SDavid E. O'Brien     USE(c);
2490c80476e4SDavid E. O'Brien     if (Cursor == LastChar) {	/* if I'm at the end */
2491c80476e4SDavid E. O'Brien 	if (Cursor == InputBuf) {	/* if I'm also at the beginning */
2492c80476e4SDavid E. O'Brien 	    so_write(STReof, 4);/* then do a EOF */
2493c80476e4SDavid E. O'Brien 	    flush();
2494c80476e4SDavid E. O'Brien 	    return(CC_EOF);
2495c80476e4SDavid E. O'Brien 	}
2496c80476e4SDavid E. O'Brien 	else {
2497c80476e4SDavid E. O'Brien 	    PastBottom();
2498c80476e4SDavid E. O'Brien 	    *LastChar = '\0';	/* just in case */
2499c80476e4SDavid E. O'Brien 	    return(CC_LIST_CHOICES);
2500c80476e4SDavid E. O'Brien 	}
2501c80476e4SDavid E. O'Brien     }
2502c80476e4SDavid E. O'Brien     else {
2503c80476e4SDavid E. O'Brien 	c_delafter(Argument);	/* delete after dot */
2504c80476e4SDavid E. O'Brien 	if (Cursor > LastChar)
2505c80476e4SDavid E. O'Brien 	    Cursor = LastChar;	/* bounds check */
2506c80476e4SDavid E. O'Brien 	return(CC_REFRESH);
2507c80476e4SDavid E. O'Brien     }
2508c80476e4SDavid E. O'Brien }
2509c80476e4SDavid E. O'Brien 
2510c80476e4SDavid E. O'Brien /*ARGSUSED*/
2511c80476e4SDavid E. O'Brien CCRETVAL
251245e5710bSMark Peek e_list_eof(Char c)
2513c80476e4SDavid E. O'Brien {
2514c80476e4SDavid E. O'Brien     CCRETVAL rv;
2515c80476e4SDavid E. O'Brien 
2516c80476e4SDavid E. O'Brien     USE(c);
2517c80476e4SDavid E. O'Brien     if (Cursor == LastChar && Cursor == InputBuf) {
2518c80476e4SDavid E. O'Brien 	so_write(STReof, 4);	/* then do a EOF */
2519c80476e4SDavid E. O'Brien 	flush();
2520c80476e4SDavid E. O'Brien 	rv = CC_EOF;
2521c80476e4SDavid E. O'Brien     }
2522c80476e4SDavid E. O'Brien     else {
2523c80476e4SDavid E. O'Brien 	PastBottom();
2524c80476e4SDavid E. O'Brien 	*LastChar = '\0';	/* just in case */
2525c80476e4SDavid E. O'Brien 	rv = CC_LIST_CHOICES;
2526c80476e4SDavid E. O'Brien     }
2527c80476e4SDavid E. O'Brien     return rv;
2528c80476e4SDavid E. O'Brien }
2529c80476e4SDavid E. O'Brien 
2530c80476e4SDavid E. O'Brien /*ARGSUSED*/
2531c80476e4SDavid E. O'Brien CCRETVAL
253245e5710bSMark Peek e_delwordnext(Char c)
2533c80476e4SDavid E. O'Brien {
25346767bd61SMark Peek     Char *cp;
2535c80476e4SDavid E. O'Brien 
2536c80476e4SDavid E. O'Brien     USE(c);
2537c80476e4SDavid E. O'Brien     if (Cursor == LastChar)
2538c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2539c80476e4SDavid E. O'Brien     /* else */
2540c80476e4SDavid E. O'Brien 
2541c80476e4SDavid E. O'Brien     cp = c_next_word(Cursor, LastChar, Argument);
2542c80476e4SDavid E. O'Brien 
25436767bd61SMark Peek     c_push_kill(Cursor, cp);	/* save the text */
2544c80476e4SDavid E. O'Brien 
2545c80476e4SDavid E. O'Brien     c_delafter((int)(cp - Cursor));	/* delete after dot */
2546c80476e4SDavid E. O'Brien     if (Cursor > LastChar)
2547c80476e4SDavid E. O'Brien 	Cursor = LastChar;	/* bounds check */
2548c80476e4SDavid E. O'Brien     return(CC_REFRESH);
2549c80476e4SDavid E. O'Brien }
2550c80476e4SDavid E. O'Brien 
2551c80476e4SDavid E. O'Brien /*ARGSUSED*/
2552c80476e4SDavid E. O'Brien CCRETVAL
255345e5710bSMark Peek e_toend(Char c)
2554c80476e4SDavid E. O'Brien {
2555c80476e4SDavid E. O'Brien     USE(c);
2556c80476e4SDavid E. O'Brien     Cursor = LastChar;
2557c80476e4SDavid E. O'Brien     if (VImode)
2558c80476e4SDavid E. O'Brien 	if (ActionFlag & TCSHOP_DELETE) {
2559c80476e4SDavid E. O'Brien 	    c_delfini();
2560c80476e4SDavid E. O'Brien 	    return(CC_REFRESH);
2561c80476e4SDavid E. O'Brien 	}
2562c80476e4SDavid E. O'Brien     RefCursor();		/* move the cursor */
2563c80476e4SDavid E. O'Brien     return(CC_NORM);
2564c80476e4SDavid E. O'Brien }
2565c80476e4SDavid E. O'Brien 
2566c80476e4SDavid E. O'Brien /*ARGSUSED*/
2567c80476e4SDavid E. O'Brien CCRETVAL
256845e5710bSMark Peek e_tobeg(Char c)
2569c80476e4SDavid E. O'Brien {
2570c80476e4SDavid E. O'Brien     USE(c);
2571c80476e4SDavid E. O'Brien     Cursor = InputBuf;
2572c80476e4SDavid E. O'Brien 
2573c80476e4SDavid E. O'Brien     if (VImode) {
2574c80476e4SDavid E. O'Brien        while (Isspace(*Cursor)) /* We want FIRST non space character */
2575c80476e4SDavid E. O'Brien 	Cursor++;
2576c80476e4SDavid E. O'Brien 	if (ActionFlag & TCSHOP_DELETE) {
2577c80476e4SDavid E. O'Brien 	    c_delfini();
2578c80476e4SDavid E. O'Brien 	    return(CC_REFRESH);
2579c80476e4SDavid E. O'Brien 	}
2580c80476e4SDavid E. O'Brien     }
2581c80476e4SDavid E. O'Brien 
2582c80476e4SDavid E. O'Brien     RefCursor();		/* move the cursor */
2583c80476e4SDavid E. O'Brien     return(CC_NORM);
2584c80476e4SDavid E. O'Brien }
2585c80476e4SDavid E. O'Brien 
2586c80476e4SDavid E. O'Brien /*ARGSUSED*/
2587c80476e4SDavid E. O'Brien CCRETVAL
258845e5710bSMark Peek e_killend(Char c)
2589c80476e4SDavid E. O'Brien {
2590c80476e4SDavid E. O'Brien     USE(c);
25916767bd61SMark Peek     c_push_kill(Cursor, LastChar); /* copy it */
259245e5710bSMark Peek     LastChar = Cursor;		/* zap! -- delete to end */
259345e5710bSMark Peek     if (Mark > Cursor)
259445e5710bSMark Peek         Mark = Cursor;
259545e5710bSMark Peek     MarkIsSet = 0;
2596c80476e4SDavid E. O'Brien     return(CC_REFRESH);
2597c80476e4SDavid E. O'Brien }
2598c80476e4SDavid E. O'Brien 
2599c80476e4SDavid E. O'Brien 
2600c80476e4SDavid E. O'Brien /*ARGSUSED*/
2601c80476e4SDavid E. O'Brien CCRETVAL
260245e5710bSMark Peek e_killbeg(Char c)
2603c80476e4SDavid E. O'Brien {
2604c80476e4SDavid E. O'Brien     USE(c);
26056767bd61SMark Peek     c_push_kill(InputBuf, Cursor); /* copy it */
2606c80476e4SDavid E. O'Brien     c_delbefore((int)(Cursor - InputBuf));
260723338178SMark Peek     if (Mark && Mark > Cursor)
260823338178SMark Peek         Mark -= Cursor-InputBuf;
2609c80476e4SDavid E. O'Brien     return(CC_REFRESH);
2610c80476e4SDavid E. O'Brien }
2611c80476e4SDavid E. O'Brien 
2612c80476e4SDavid E. O'Brien /*ARGSUSED*/
2613c80476e4SDavid E. O'Brien CCRETVAL
261445e5710bSMark Peek e_killall(Char c)
2615c80476e4SDavid E. O'Brien {
2616c80476e4SDavid E. O'Brien     USE(c);
26176767bd61SMark Peek     c_push_kill(InputBuf, LastChar); /* copy it */
261823338178SMark Peek     Cursor = Mark = LastChar = InputBuf;	/* zap! -- delete all of it */
261945e5710bSMark Peek     MarkIsSet = 0;
2620c80476e4SDavid E. O'Brien     return(CC_REFRESH);
2621c80476e4SDavid E. O'Brien }
2622c80476e4SDavid E. O'Brien 
2623c80476e4SDavid E. O'Brien /*ARGSUSED*/
2624c80476e4SDavid E. O'Brien CCRETVAL
262545e5710bSMark Peek e_killregion(Char c)
2626c80476e4SDavid E. O'Brien {
2627c80476e4SDavid E. O'Brien     USE(c);
2628c80476e4SDavid E. O'Brien     if (!Mark)
2629c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2630c80476e4SDavid E. O'Brien 
2631c80476e4SDavid E. O'Brien     if (Mark > Cursor) {
26326767bd61SMark Peek 	c_push_kill(Cursor, Mark); /* copy it */
26336767bd61SMark Peek 	c_delafter((int)(Mark - Cursor)); /* delete it - UNUSED BY VI mode */
26346767bd61SMark Peek 	Mark = Cursor;
2635c80476e4SDavid E. O'Brien     }
2636c80476e4SDavid E. O'Brien     else {			/* mark is before cursor */
26376767bd61SMark Peek 	c_push_kill(Mark, Cursor); /* copy it */
26386767bd61SMark Peek 	c_delbefore((int)(Cursor - Mark));
2639c80476e4SDavid E. O'Brien     }
264045e5710bSMark Peek     if (adrof(STRhighlight) && MarkIsSet) {
264145e5710bSMark Peek 	ClearLines();
264245e5710bSMark Peek 	ClearDisp();
264345e5710bSMark Peek     }
264445e5710bSMark Peek     MarkIsSet = 0;
2645c80476e4SDavid E. O'Brien     return(CC_REFRESH);
2646c80476e4SDavid E. O'Brien }
2647c80476e4SDavid E. O'Brien 
2648c80476e4SDavid E. O'Brien /*ARGSUSED*/
2649c80476e4SDavid E. O'Brien CCRETVAL
265045e5710bSMark Peek e_copyregion(Char c)
2651c80476e4SDavid E. O'Brien {
2652c80476e4SDavid E. O'Brien     USE(c);
2653c80476e4SDavid E. O'Brien     if (!Mark)
2654c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2655c80476e4SDavid E. O'Brien 
2656c80476e4SDavid E. O'Brien     if (Mark > Cursor) {
26576767bd61SMark Peek 	c_push_kill(Cursor, Mark); /* copy it */
2658c80476e4SDavid E. O'Brien     }
2659c80476e4SDavid E. O'Brien     else {			/* mark is before cursor */
26606767bd61SMark Peek 	c_push_kill(Mark, Cursor); /* copy it */
2661c80476e4SDavid E. O'Brien     }
2662c80476e4SDavid E. O'Brien     return(CC_NORM);		/* don't even need to Refresh() */
2663c80476e4SDavid E. O'Brien }
2664c80476e4SDavid E. O'Brien 
2665c80476e4SDavid E. O'Brien /*ARGSUSED*/
2666c80476e4SDavid E. O'Brien CCRETVAL
266745e5710bSMark Peek e_charswitch(Char cc)
2668c80476e4SDavid E. O'Brien {
26696767bd61SMark Peek     Char c;
2670c80476e4SDavid E. O'Brien 
2671c80476e4SDavid E. O'Brien     USE(cc);
2672c80476e4SDavid E. O'Brien 
2673c80476e4SDavid E. O'Brien     /* do nothing if we are at beginning of line or have only one char */
2674c80476e4SDavid E. O'Brien     if (Cursor == &InputBuf[0] || LastChar == &InputBuf[1]) {
2675c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2676c80476e4SDavid E. O'Brien     }
2677c80476e4SDavid E. O'Brien 
2678c80476e4SDavid E. O'Brien     if (Cursor < LastChar) {
2679c80476e4SDavid E. O'Brien 	Cursor++;
2680c80476e4SDavid E. O'Brien     }
2681c80476e4SDavid E. O'Brien     c = Cursor[-2];
2682c80476e4SDavid E. O'Brien     Cursor[-2] = Cursor[-1];
2683c80476e4SDavid E. O'Brien     Cursor[-1] = c;
2684c80476e4SDavid E. O'Brien     return(CC_REFRESH);
2685c80476e4SDavid E. O'Brien }
2686c80476e4SDavid E. O'Brien 
2687c80476e4SDavid E. O'Brien /*ARGSUSED*/
2688c80476e4SDavid E. O'Brien CCRETVAL
268945e5710bSMark Peek e_gcharswitch(Char cc)
2690c80476e4SDavid E. O'Brien {				/* gosmacs style ^T */
26916767bd61SMark Peek     Char c;
2692c80476e4SDavid E. O'Brien 
2693c80476e4SDavid E. O'Brien     USE(cc);
2694c80476e4SDavid E. O'Brien     if (Cursor > &InputBuf[1]) {/* must have at least two chars entered */
2695c80476e4SDavid E. O'Brien 	c = Cursor[-2];
2696c80476e4SDavid E. O'Brien 	Cursor[-2] = Cursor[-1];
2697c80476e4SDavid E. O'Brien 	Cursor[-1] = c;
2698c80476e4SDavid E. O'Brien 	return(CC_REFRESH);
2699c80476e4SDavid E. O'Brien     }
2700c80476e4SDavid E. O'Brien     else {
2701c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2702c80476e4SDavid E. O'Brien     }
2703c80476e4SDavid E. O'Brien }
2704c80476e4SDavid E. O'Brien 
2705c80476e4SDavid E. O'Brien /*ARGSUSED*/
2706c80476e4SDavid E. O'Brien CCRETVAL
270745e5710bSMark Peek e_charback(Char c)
2708c80476e4SDavid E. O'Brien {
2709c80476e4SDavid E. O'Brien     USE(c);
2710c80476e4SDavid E. O'Brien     if (Cursor > InputBuf) {
271145e5710bSMark Peek 	if (Argument > Cursor - InputBuf)
2712c80476e4SDavid E. O'Brien 	    Cursor = InputBuf;
2713c80476e4SDavid E. O'Brien 	else
271445e5710bSMark Peek 	    Cursor -= Argument;
2715c80476e4SDavid E. O'Brien 
2716c80476e4SDavid E. O'Brien 	if (VImode)
2717c80476e4SDavid E. O'Brien 	    if (ActionFlag & TCSHOP_DELETE) {
2718c80476e4SDavid E. O'Brien 		c_delfini();
2719c80476e4SDavid E. O'Brien 		return(CC_REFRESH);
2720c80476e4SDavid E. O'Brien 	    }
2721c80476e4SDavid E. O'Brien 
2722c80476e4SDavid E. O'Brien 	RefCursor();
2723c80476e4SDavid E. O'Brien 	return(CC_NORM);
2724c80476e4SDavid E. O'Brien     }
2725c80476e4SDavid E. O'Brien     else {
2726c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2727c80476e4SDavid E. O'Brien     }
2728c80476e4SDavid E. O'Brien }
2729c80476e4SDavid E. O'Brien 
2730c80476e4SDavid E. O'Brien /*ARGSUSED*/
2731c80476e4SDavid E. O'Brien CCRETVAL
273245e5710bSMark Peek v_wordback(Char c)
2733c80476e4SDavid E. O'Brien {
2734c80476e4SDavid E. O'Brien     USE(c);
2735c80476e4SDavid E. O'Brien     if (Cursor == InputBuf)
2736c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2737c80476e4SDavid E. O'Brien     /* else */
2738c80476e4SDavid E. O'Brien 
27396767bd61SMark Peek     Cursor = c_preword(Cursor, InputBuf, Argument, STRshwspace); /* bounds check */
2740c80476e4SDavid E. O'Brien 
2741c80476e4SDavid E. O'Brien     if (ActionFlag & TCSHOP_DELETE) {
2742c80476e4SDavid E. O'Brien 	c_delfini();
2743c80476e4SDavid E. O'Brien 	return(CC_REFRESH);
2744c80476e4SDavid E. O'Brien     }
2745c80476e4SDavid E. O'Brien 
2746c80476e4SDavid E. O'Brien     RefCursor();
2747c80476e4SDavid E. O'Brien     return(CC_NORM);
2748c80476e4SDavid E. O'Brien }
2749c80476e4SDavid E. O'Brien 
2750c80476e4SDavid E. O'Brien /*ARGSUSED*/
2751c80476e4SDavid E. O'Brien CCRETVAL
275245e5710bSMark Peek e_wordback(Char c)
2753c80476e4SDavid E. O'Brien {
2754c80476e4SDavid E. O'Brien     USE(c);
2755c80476e4SDavid E. O'Brien     if (Cursor == InputBuf)
2756c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2757c80476e4SDavid E. O'Brien     /* else */
2758c80476e4SDavid E. O'Brien 
2759c80476e4SDavid E. O'Brien     Cursor = c_prev_word(Cursor, InputBuf, Argument); /* bounds check */
2760c80476e4SDavid E. O'Brien 
2761c80476e4SDavid E. O'Brien     if (VImode)
2762c80476e4SDavid E. O'Brien 	if (ActionFlag & TCSHOP_DELETE) {
2763c80476e4SDavid E. O'Brien 	    c_delfini();
2764c80476e4SDavid E. O'Brien 	    return(CC_REFRESH);
2765c80476e4SDavid E. O'Brien 	}
2766c80476e4SDavid E. O'Brien 
2767c80476e4SDavid E. O'Brien     RefCursor();
2768c80476e4SDavid E. O'Brien     return(CC_NORM);
2769c80476e4SDavid E. O'Brien }
2770c80476e4SDavid E. O'Brien 
2771c80476e4SDavid E. O'Brien /*ARGSUSED*/
2772c80476e4SDavid E. O'Brien CCRETVAL
277345e5710bSMark Peek e_charfwd(Char c)
2774c80476e4SDavid E. O'Brien {
2775c80476e4SDavid E. O'Brien     USE(c);
2776c80476e4SDavid E. O'Brien     if (Cursor < LastChar) {
277745e5710bSMark Peek 	Cursor += Argument;
2778c80476e4SDavid E. O'Brien 	if (Cursor > LastChar)
2779c80476e4SDavid E. O'Brien 	    Cursor = LastChar;
2780c80476e4SDavid E. O'Brien 
2781c80476e4SDavid E. O'Brien 	if (VImode)
2782c80476e4SDavid E. O'Brien 	    if (ActionFlag & TCSHOP_DELETE) {
2783c80476e4SDavid E. O'Brien 		c_delfini();
2784c80476e4SDavid E. O'Brien 		return(CC_REFRESH);
2785c80476e4SDavid E. O'Brien 	    }
2786c80476e4SDavid E. O'Brien 
2787c80476e4SDavid E. O'Brien 	RefCursor();
2788c80476e4SDavid E. O'Brien 	return(CC_NORM);
2789c80476e4SDavid E. O'Brien     }
2790c80476e4SDavid E. O'Brien     else {
2791c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2792c80476e4SDavid E. O'Brien     }
2793c80476e4SDavid E. O'Brien }
2794c80476e4SDavid E. O'Brien 
2795c80476e4SDavid E. O'Brien /*ARGSUSED*/
2796c80476e4SDavid E. O'Brien CCRETVAL
279745e5710bSMark Peek e_wordfwd(Char c)
2798c80476e4SDavid E. O'Brien {
2799c80476e4SDavid E. O'Brien     USE(c);
2800c80476e4SDavid E. O'Brien     if (Cursor == LastChar)
2801c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2802c80476e4SDavid E. O'Brien     /* else */
2803c80476e4SDavid E. O'Brien 
2804c80476e4SDavid E. O'Brien     Cursor = c_next_word(Cursor, LastChar, Argument);
2805c80476e4SDavid E. O'Brien 
2806c80476e4SDavid E. O'Brien     if (VImode)
2807c80476e4SDavid E. O'Brien 	if (ActionFlag & TCSHOP_DELETE) {
2808c80476e4SDavid E. O'Brien 	    c_delfini();
2809c80476e4SDavid E. O'Brien 	    return(CC_REFRESH);
2810c80476e4SDavid E. O'Brien 	}
2811c80476e4SDavid E. O'Brien 
2812c80476e4SDavid E. O'Brien     RefCursor();
2813c80476e4SDavid E. O'Brien     return(CC_NORM);
2814c80476e4SDavid E. O'Brien }
2815c80476e4SDavid E. O'Brien 
2816c80476e4SDavid E. O'Brien /*ARGSUSED*/
2817c80476e4SDavid E. O'Brien CCRETVAL
281845e5710bSMark Peek v_wordfwd(Char c)
2819c80476e4SDavid E. O'Brien {
2820c80476e4SDavid E. O'Brien     USE(c);
2821c80476e4SDavid E. O'Brien     if (Cursor == LastChar)
2822c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2823c80476e4SDavid E. O'Brien     /* else */
2824c80476e4SDavid E. O'Brien 
2825c80476e4SDavid E. O'Brien     Cursor = c_nexword(Cursor, LastChar, Argument);
2826c80476e4SDavid E. O'Brien 
2827c80476e4SDavid E. O'Brien     if (VImode)
2828c80476e4SDavid E. O'Brien 	if (ActionFlag & TCSHOP_DELETE) {
2829c80476e4SDavid E. O'Brien 	    c_delfini();
2830c80476e4SDavid E. O'Brien 	    return(CC_REFRESH);
2831c80476e4SDavid E. O'Brien 	}
2832c80476e4SDavid E. O'Brien 
2833c80476e4SDavid E. O'Brien     RefCursor();
2834c80476e4SDavid E. O'Brien     return(CC_NORM);
2835c80476e4SDavid E. O'Brien }
2836c80476e4SDavid E. O'Brien 
2837c80476e4SDavid E. O'Brien /*ARGSUSED*/
2838c80476e4SDavid E. O'Brien CCRETVAL
283945e5710bSMark Peek v_wordbegnext(Char c)
2840c80476e4SDavid E. O'Brien {
2841c80476e4SDavid E. O'Brien     USE(c);
2842c80476e4SDavid E. O'Brien     if (Cursor == LastChar)
2843c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2844c80476e4SDavid E. O'Brien     /* else */
2845c80476e4SDavid E. O'Brien 
2846c80476e4SDavid E. O'Brien     Cursor = c_next_word(Cursor, LastChar, Argument);
2847c80476e4SDavid E. O'Brien     if (Cursor < LastChar)
2848c80476e4SDavid E. O'Brien 	Cursor++;
2849c80476e4SDavid E. O'Brien 
2850c80476e4SDavid E. O'Brien     if (VImode)
2851c80476e4SDavid E. O'Brien 	if (ActionFlag & TCSHOP_DELETE) {
2852c80476e4SDavid E. O'Brien 	    c_delfini();
2853c80476e4SDavid E. O'Brien 	    return(CC_REFRESH);
2854c80476e4SDavid E. O'Brien 	}
2855c80476e4SDavid E. O'Brien 
2856c80476e4SDavid E. O'Brien     RefCursor();
2857c80476e4SDavid E. O'Brien     return(CC_NORM);
2858c80476e4SDavid E. O'Brien }
2859c80476e4SDavid E. O'Brien 
2860c80476e4SDavid E. O'Brien /*ARGSUSED*/
2861c80476e4SDavid E. O'Brien static CCRETVAL
286245e5710bSMark Peek v_repeat_srch(int c)
2863c80476e4SDavid E. O'Brien {
2864c80476e4SDavid E. O'Brien     CCRETVAL rv = CC_ERROR;
2865c80476e4SDavid E. O'Brien #ifdef SDEBUG
2866c80476e4SDavid E. O'Brien     xprintf("dir %d patlen %d patbuf %S\n",
286745e5710bSMark Peek 	    c, (int)patbuf.len, patbuf.s);
2868c80476e4SDavid E. O'Brien #endif
2869c80476e4SDavid E. O'Brien 
2870c80476e4SDavid E. O'Brien     LastCmd = (KEYCMD) c;  /* Hack to stop c_hsetpat */
2871c80476e4SDavid E. O'Brien     LastChar = InputBuf;
2872c80476e4SDavid E. O'Brien     switch (c) {
2873c80476e4SDavid E. O'Brien     case F_DOWN_SEARCH_HIST:
2874c80476e4SDavid E. O'Brien 	rv = e_down_search_hist(0);
2875c80476e4SDavid E. O'Brien 	break;
2876c80476e4SDavid E. O'Brien     case F_UP_SEARCH_HIST:
2877c80476e4SDavid E. O'Brien 	rv = e_up_search_hist(0);
2878c80476e4SDavid E. O'Brien 	break;
2879c80476e4SDavid E. O'Brien     default:
2880c80476e4SDavid E. O'Brien 	break;
2881c80476e4SDavid E. O'Brien     }
2882c80476e4SDavid E. O'Brien     return rv;
2883c80476e4SDavid E. O'Brien }
2884c80476e4SDavid E. O'Brien 
2885c80476e4SDavid E. O'Brien static CCRETVAL
288645e5710bSMark Peek v_csearch_back(Char ch, int count, int tflag)
2887c80476e4SDavid E. O'Brien {
2888c80476e4SDavid E. O'Brien     Char *cp;
2889c80476e4SDavid E. O'Brien 
2890c80476e4SDavid E. O'Brien     cp = Cursor;
2891c80476e4SDavid E. O'Brien     while (count--) {
2892c80476e4SDavid E. O'Brien 	if (*cp == ch)
2893c80476e4SDavid E. O'Brien 	    cp--;
2894c80476e4SDavid E. O'Brien 	while (cp > InputBuf && *cp != ch)
2895c80476e4SDavid E. O'Brien 	    cp--;
2896c80476e4SDavid E. O'Brien     }
2897c80476e4SDavid E. O'Brien 
2898c80476e4SDavid E. O'Brien     if (cp < InputBuf || (cp == InputBuf && *cp != ch))
2899c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2900c80476e4SDavid E. O'Brien 
2901c80476e4SDavid E. O'Brien     if (*cp == ch && tflag)
2902c80476e4SDavid E. O'Brien 	cp++;
2903c80476e4SDavid E. O'Brien 
2904c80476e4SDavid E. O'Brien     Cursor = cp;
2905c80476e4SDavid E. O'Brien 
2906c80476e4SDavid E. O'Brien     if (ActionFlag & TCSHOP_DELETE) {
2907c80476e4SDavid E. O'Brien 	Cursor++;
2908c80476e4SDavid E. O'Brien 	c_delfini();
2909c80476e4SDavid E. O'Brien 	return(CC_REFRESH);
2910c80476e4SDavid E. O'Brien     }
2911c80476e4SDavid E. O'Brien 
2912c80476e4SDavid E. O'Brien     RefCursor();
2913c80476e4SDavid E. O'Brien     return(CC_NORM);
2914c80476e4SDavid E. O'Brien }
2915c80476e4SDavid E. O'Brien 
2916c80476e4SDavid E. O'Brien static CCRETVAL
291745e5710bSMark Peek v_csearch_fwd(Char ch, int count, int tflag)
2918c80476e4SDavid E. O'Brien {
2919c80476e4SDavid E. O'Brien     Char *cp;
2920c80476e4SDavid E. O'Brien 
2921c80476e4SDavid E. O'Brien     cp = Cursor;
2922c80476e4SDavid E. O'Brien     while (count--) {
2923c80476e4SDavid E. O'Brien 	if(*cp == ch)
2924c80476e4SDavid E. O'Brien 	    cp++;
2925c80476e4SDavid E. O'Brien 	while (cp < LastChar && *cp != ch)
2926c80476e4SDavid E. O'Brien 	    cp++;
2927c80476e4SDavid E. O'Brien     }
2928c80476e4SDavid E. O'Brien 
2929c80476e4SDavid E. O'Brien     if (cp >= LastChar)
2930c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2931c80476e4SDavid E. O'Brien 
2932c80476e4SDavid E. O'Brien     if (*cp == ch && tflag)
2933c80476e4SDavid E. O'Brien 	cp--;
2934c80476e4SDavid E. O'Brien 
2935c80476e4SDavid E. O'Brien     Cursor = cp;
2936c80476e4SDavid E. O'Brien 
2937c80476e4SDavid E. O'Brien     if (ActionFlag & TCSHOP_DELETE) {
2938c80476e4SDavid E. O'Brien 	Cursor++;
2939c80476e4SDavid E. O'Brien 	c_delfini();
2940c80476e4SDavid E. O'Brien 	return(CC_REFRESH);
2941c80476e4SDavid E. O'Brien     }
2942c80476e4SDavid E. O'Brien     RefCursor();
2943c80476e4SDavid E. O'Brien     return(CC_NORM);
2944c80476e4SDavid E. O'Brien }
2945c80476e4SDavid E. O'Brien 
2946c80476e4SDavid E. O'Brien /*ARGSUSED*/
2947c80476e4SDavid E. O'Brien static CCRETVAL
294845e5710bSMark Peek v_action(int c)
2949c80476e4SDavid E. O'Brien {
29506767bd61SMark Peek     Char *cp, *kp;
2951c80476e4SDavid E. O'Brien 
2952c80476e4SDavid E. O'Brien     if (ActionFlag == TCSHOP_DELETE) {
2953c80476e4SDavid E. O'Brien 	ActionFlag = TCSHOP_NOP;
2954c80476e4SDavid E. O'Brien 	ActionPos = 0;
2955c80476e4SDavid E. O'Brien 
2956c80476e4SDavid E. O'Brien 	UndoSize = 0;
2957c80476e4SDavid E. O'Brien 	kp = UndoBuf;
2958c80476e4SDavid E. O'Brien 	for (cp = InputBuf; cp < LastChar; cp++) {
2959c80476e4SDavid E. O'Brien 	    *kp++ = *cp;
2960c80476e4SDavid E. O'Brien 	    UndoSize++;
2961c80476e4SDavid E. O'Brien 	}
2962c80476e4SDavid E. O'Brien 
2963c80476e4SDavid E. O'Brien 	UndoAction = TCSHOP_INSERT;
2964c80476e4SDavid E. O'Brien 	UndoPtr  = InputBuf;
2965c80476e4SDavid E. O'Brien 	LastChar = InputBuf;
2966c80476e4SDavid E. O'Brien 	Cursor   = InputBuf;
2967c80476e4SDavid E. O'Brien 	if (c & TCSHOP_INSERT)
2968c80476e4SDavid E. O'Brien 	    c_alternativ_key_map(0);
2969c80476e4SDavid E. O'Brien 
2970c80476e4SDavid E. O'Brien 	return(CC_REFRESH);
2971c80476e4SDavid E. O'Brien     }
2972c80476e4SDavid E. O'Brien #ifdef notdef
2973c80476e4SDavid E. O'Brien     else if (ActionFlag == TCSHOP_NOP) {
2974c80476e4SDavid E. O'Brien #endif
2975c80476e4SDavid E. O'Brien 	ActionPos = Cursor;
2976c80476e4SDavid E. O'Brien 	ActionFlag = c;
2977c80476e4SDavid E. O'Brien 	return(CC_ARGHACK);  /* Do NOT clear out argument */
2978c80476e4SDavid E. O'Brien #ifdef notdef
2979c80476e4SDavid E. O'Brien     }
2980c80476e4SDavid E. O'Brien     else {
2981c80476e4SDavid E. O'Brien 	ActionFlag = 0;
2982c80476e4SDavid E. O'Brien 	ActionPos = 0;
2983c80476e4SDavid E. O'Brien 	return(CC_ERROR);
2984c80476e4SDavid E. O'Brien     }
2985c80476e4SDavid E. O'Brien #endif
2986c80476e4SDavid E. O'Brien }
2987c80476e4SDavid E. O'Brien 
2988c80476e4SDavid E. O'Brien #ifdef COMMENT
2989c80476e4SDavid E. O'Brien /* by: Brian Allison <uiucdcs!convex!allison@RUTGERS.EDU> */
2990c80476e4SDavid E. O'Brien static void
299145e5710bSMark Peek c_get_word(Char **begin, Char **end)
2992c80476e4SDavid E. O'Brien {
2993c80476e4SDavid E. O'Brien     Char   *cp;
2994c80476e4SDavid E. O'Brien 
2995c80476e4SDavid E. O'Brien     cp = &Cursor[0];
2996c80476e4SDavid E. O'Brien     while (Argument--) {
2997c80476e4SDavid E. O'Brien 	while ((cp <= LastChar) && (isword(*cp)))
2998c80476e4SDavid E. O'Brien 	    cp++;
2999c80476e4SDavid E. O'Brien 	*end = --cp;
3000c80476e4SDavid E. O'Brien 	while ((cp >= InputBuf) && (isword(*cp)))
3001c80476e4SDavid E. O'Brien 	    cp--;
3002c80476e4SDavid E. O'Brien 	*begin = ++cp;
3003c80476e4SDavid E. O'Brien     }
3004c80476e4SDavid E. O'Brien }
3005c80476e4SDavid E. O'Brien #endif /* COMMENT */
3006c80476e4SDavid E. O'Brien 
3007c80476e4SDavid E. O'Brien /*ARGSUSED*/
3008c80476e4SDavid E. O'Brien CCRETVAL
300945e5710bSMark Peek e_uppercase(Char c)
3010c80476e4SDavid E. O'Brien {
3011c80476e4SDavid E. O'Brien     Char   *cp, *end;
3012c80476e4SDavid E. O'Brien 
3013c80476e4SDavid E. O'Brien     USE(c);
3014c80476e4SDavid E. O'Brien     end = c_next_word(Cursor, LastChar, Argument);
3015c80476e4SDavid E. O'Brien 
3016c80476e4SDavid E. O'Brien     for (cp = Cursor; cp < end; cp++)	/* PWP: was cp=begin */
3017c80476e4SDavid E. O'Brien 	if (Islower(*cp))
3018c80476e4SDavid E. O'Brien 	    *cp = Toupper(*cp);
3019c80476e4SDavid E. O'Brien 
3020c80476e4SDavid E. O'Brien     Cursor = end;
3021c80476e4SDavid E. O'Brien     if (Cursor > LastChar)
3022c80476e4SDavid E. O'Brien 	Cursor = LastChar;
3023c80476e4SDavid E. O'Brien     return(CC_REFRESH);
3024c80476e4SDavid E. O'Brien }
3025c80476e4SDavid E. O'Brien 
3026c80476e4SDavid E. O'Brien 
3027c80476e4SDavid E. O'Brien /*ARGSUSED*/
3028c80476e4SDavid E. O'Brien CCRETVAL
302945e5710bSMark Peek e_capitolcase(Char c)
3030c80476e4SDavid E. O'Brien {
3031c80476e4SDavid E. O'Brien     Char   *cp, *end;
3032c80476e4SDavid E. O'Brien 
3033c80476e4SDavid E. O'Brien     USE(c);
3034c80476e4SDavid E. O'Brien     end = c_next_word(Cursor, LastChar, Argument);
3035c80476e4SDavid E. O'Brien 
3036c80476e4SDavid E. O'Brien     cp = Cursor;
3037c80476e4SDavid E. O'Brien     for (; cp < end; cp++) {
3038c80476e4SDavid E. O'Brien 	if (Isalpha(*cp)) {
3039c80476e4SDavid E. O'Brien 	    if (Islower(*cp))
3040c80476e4SDavid E. O'Brien 		*cp = Toupper(*cp);
3041c80476e4SDavid E. O'Brien 	    cp++;
3042c80476e4SDavid E. O'Brien 	    break;
3043c80476e4SDavid E. O'Brien 	}
3044c80476e4SDavid E. O'Brien     }
3045c80476e4SDavid E. O'Brien     for (; cp < end; cp++)
3046c80476e4SDavid E. O'Brien 	if (Isupper(*cp))
3047c80476e4SDavid E. O'Brien 	    *cp = Tolower(*cp);
3048c80476e4SDavid E. O'Brien 
3049c80476e4SDavid E. O'Brien     Cursor = end;
3050c80476e4SDavid E. O'Brien     if (Cursor > LastChar)
3051c80476e4SDavid E. O'Brien 	Cursor = LastChar;
3052c80476e4SDavid E. O'Brien     return(CC_REFRESH);
3053c80476e4SDavid E. O'Brien }
3054c80476e4SDavid E. O'Brien 
3055c80476e4SDavid E. O'Brien /*ARGSUSED*/
3056c80476e4SDavid E. O'Brien CCRETVAL
305745e5710bSMark Peek e_lowercase(Char c)
3058c80476e4SDavid E. O'Brien {
3059c80476e4SDavid E. O'Brien     Char   *cp, *end;
3060c80476e4SDavid E. O'Brien 
3061c80476e4SDavid E. O'Brien     USE(c);
3062c80476e4SDavid E. O'Brien     end = c_next_word(Cursor, LastChar, Argument);
3063c80476e4SDavid E. O'Brien 
3064c80476e4SDavid E. O'Brien     for (cp = Cursor; cp < end; cp++)
3065c80476e4SDavid E. O'Brien 	if (Isupper(*cp))
3066c80476e4SDavid E. O'Brien 	    *cp = Tolower(*cp);
3067c80476e4SDavid E. O'Brien 
3068c80476e4SDavid E. O'Brien     Cursor = end;
3069c80476e4SDavid E. O'Brien     if (Cursor > LastChar)
3070c80476e4SDavid E. O'Brien 	Cursor = LastChar;
3071c80476e4SDavid E. O'Brien     return(CC_REFRESH);
3072c80476e4SDavid E. O'Brien }
3073c80476e4SDavid E. O'Brien 
3074c80476e4SDavid E. O'Brien 
3075c80476e4SDavid E. O'Brien /*ARGSUSED*/
3076c80476e4SDavid E. O'Brien CCRETVAL
307745e5710bSMark Peek e_set_mark(Char c)
3078c80476e4SDavid E. O'Brien {
3079c80476e4SDavid E. O'Brien     USE(c);
308045e5710bSMark Peek     if (adrof(STRhighlight) && MarkIsSet && Mark != Cursor) {
308145e5710bSMark Peek 	ClearLines();
308245e5710bSMark Peek 	ClearDisp();
308345e5710bSMark Peek 	Refresh();
308445e5710bSMark Peek     }
3085c80476e4SDavid E. O'Brien     Mark = Cursor;
308645e5710bSMark Peek     MarkIsSet = 1;
3087c80476e4SDavid E. O'Brien     return(CC_NORM);
3088c80476e4SDavid E. O'Brien }
3089c80476e4SDavid E. O'Brien 
3090c80476e4SDavid E. O'Brien /*ARGSUSED*/
3091c80476e4SDavid E. O'Brien CCRETVAL
309245e5710bSMark Peek e_exchange_mark(Char c)
3093c80476e4SDavid E. O'Brien {
30946767bd61SMark Peek     Char *cp;
3095c80476e4SDavid E. O'Brien 
3096c80476e4SDavid E. O'Brien     USE(c);
3097c80476e4SDavid E. O'Brien     cp = Cursor;
3098c80476e4SDavid E. O'Brien     Cursor = Mark;
3099c80476e4SDavid E. O'Brien     Mark = cp;
3100c80476e4SDavid E. O'Brien     RefCursor();
3101c80476e4SDavid E. O'Brien     return(CC_NORM);
3102c80476e4SDavid E. O'Brien }
3103c80476e4SDavid E. O'Brien 
3104c80476e4SDavid E. O'Brien /*ARGSUSED*/
3105c80476e4SDavid E. O'Brien CCRETVAL
310645e5710bSMark Peek e_argfour(Char c)
3107c80476e4SDavid E. O'Brien {				/* multiply current argument by 4 */
3108c80476e4SDavid E. O'Brien     USE(c);
3109c80476e4SDavid E. O'Brien     if (Argument > 1000000)
3110c80476e4SDavid E. O'Brien 	return CC_ERROR;
3111c80476e4SDavid E. O'Brien     DoingArg = 1;
3112c80476e4SDavid E. O'Brien     Argument *= 4;
3113c80476e4SDavid E. O'Brien     return(CC_ARGHACK);
3114c80476e4SDavid E. O'Brien }
3115c80476e4SDavid E. O'Brien 
311645e5710bSMark Peek static void
311745e5710bSMark Peek quote_mode_cleanup(void *unused)
311845e5710bSMark Peek {
311945e5710bSMark Peek     USE(unused);
312045e5710bSMark Peek     QuoteModeOff();
312145e5710bSMark Peek }
312245e5710bSMark Peek 
3123c80476e4SDavid E. O'Brien /*ARGSUSED*/
3124c80476e4SDavid E. O'Brien CCRETVAL
312545e5710bSMark Peek e_quote(Char c)
3126c80476e4SDavid E. O'Brien {
3127c80476e4SDavid E. O'Brien     Char    ch;
3128c80476e4SDavid E. O'Brien     int     num;
3129c80476e4SDavid E. O'Brien 
3130c80476e4SDavid E. O'Brien     USE(c);
3131c80476e4SDavid E. O'Brien     QuoteModeOn();
313245e5710bSMark Peek     cleanup_push(&c, quote_mode_cleanup); /* Using &c just as a mark */
3133c80476e4SDavid E. O'Brien     num = GetNextChar(&ch);
313445e5710bSMark Peek     cleanup_until(&c);
3135c80476e4SDavid E. O'Brien     if (num == 1)
3136c80476e4SDavid E. O'Brien 	return e_insert(ch);
3137c80476e4SDavid E. O'Brien     else
3138c80476e4SDavid E. O'Brien 	return e_send_eof(0);
3139c80476e4SDavid E. O'Brien }
3140c80476e4SDavid E. O'Brien 
3141c80476e4SDavid E. O'Brien /*ARGSUSED*/
3142c80476e4SDavid E. O'Brien CCRETVAL
314345e5710bSMark Peek e_metanext(Char c)
3144c80476e4SDavid E. O'Brien {
3145c80476e4SDavid E. O'Brien     USE(c);
3146c80476e4SDavid E. O'Brien     MetaNext = 1;
3147c80476e4SDavid E. O'Brien     return(CC_ARGHACK);	/* preserve argument */
3148c80476e4SDavid E. O'Brien }
3149c80476e4SDavid E. O'Brien 
3150c80476e4SDavid E. O'Brien #ifdef notdef
3151c80476e4SDavid E. O'Brien /*ARGSUSED*/
3152c80476e4SDavid E. O'Brien CCRETVAL
315345e5710bSMark Peek e_extendnext(Char c)
3154c80476e4SDavid E. O'Brien {
3155c80476e4SDavid E. O'Brien     CurrentKeyMap = CcAltMap;
3156c80476e4SDavid E. O'Brien     return(CC_ARGHACK);	/* preserve argument */
3157c80476e4SDavid E. O'Brien }
3158c80476e4SDavid E. O'Brien 
3159c80476e4SDavid E. O'Brien #endif
3160c80476e4SDavid E. O'Brien 
3161c80476e4SDavid E. O'Brien /*ARGSUSED*/
3162c80476e4SDavid E. O'Brien CCRETVAL
316345e5710bSMark Peek v_insbeg(Char c)
3164c80476e4SDavid E. O'Brien {				/* move to beginning of line and start vi
3165c80476e4SDavid E. O'Brien 				 * insert mode */
3166c80476e4SDavid E. O'Brien     USE(c);
3167c80476e4SDavid E. O'Brien     Cursor = InputBuf;
3168c80476e4SDavid E. O'Brien     InsertPos = Cursor;
3169c80476e4SDavid E. O'Brien 
3170c80476e4SDavid E. O'Brien     UndoPtr  = Cursor;
3171c80476e4SDavid E. O'Brien     UndoAction = TCSHOP_DELETE;
3172c80476e4SDavid E. O'Brien 
3173c80476e4SDavid E. O'Brien     RefCursor();		/* move the cursor */
3174c80476e4SDavid E. O'Brien     c_alternativ_key_map(0);
3175c80476e4SDavid E. O'Brien     return(CC_NORM);
3176c80476e4SDavid E. O'Brien }
3177c80476e4SDavid E. O'Brien 
3178c80476e4SDavid E. O'Brien /*ARGSUSED*/
3179c80476e4SDavid E. O'Brien CCRETVAL
318045e5710bSMark Peek v_replone(Char c)
3181c80476e4SDavid E. O'Brien {				/* vi mode overwrite one character */
3182c80476e4SDavid E. O'Brien     USE(c);
3183c80476e4SDavid E. O'Brien     c_alternativ_key_map(0);
3184c80476e4SDavid E. O'Brien     inputmode = MODE_REPLACE_1;
3185c80476e4SDavid E. O'Brien     UndoAction = TCSHOP_CHANGE;	/* Set Up for VI undo command */
3186c80476e4SDavid E. O'Brien     UndoPtr = Cursor;
3187c80476e4SDavid E. O'Brien     UndoSize = 0;
3188c80476e4SDavid E. O'Brien     return(CC_NORM);
3189c80476e4SDavid E. O'Brien }
3190c80476e4SDavid E. O'Brien 
3191c80476e4SDavid E. O'Brien /*ARGSUSED*/
3192c80476e4SDavid E. O'Brien CCRETVAL
319345e5710bSMark Peek v_replmode(Char c)
3194c80476e4SDavid E. O'Brien {				/* vi mode start overwriting */
3195c80476e4SDavid E. O'Brien     USE(c);
3196c80476e4SDavid E. O'Brien     c_alternativ_key_map(0);
3197c80476e4SDavid E. O'Brien     inputmode = MODE_REPLACE;
3198c80476e4SDavid E. O'Brien     UndoAction = TCSHOP_CHANGE;	/* Set Up for VI undo command */
3199c80476e4SDavid E. O'Brien     UndoPtr = Cursor;
3200c80476e4SDavid E. O'Brien     UndoSize = 0;
3201c80476e4SDavid E. O'Brien     return(CC_NORM);
3202c80476e4SDavid E. O'Brien }
3203c80476e4SDavid E. O'Brien 
3204c80476e4SDavid E. O'Brien /*ARGSUSED*/
3205c80476e4SDavid E. O'Brien CCRETVAL
320645e5710bSMark Peek v_substchar(Char c)
3207c80476e4SDavid E. O'Brien {				/* vi mode substitute for one char */
3208c80476e4SDavid E. O'Brien     USE(c);
3209c80476e4SDavid E. O'Brien     c_delafter(Argument);
3210c80476e4SDavid E. O'Brien     c_alternativ_key_map(0);
3211c80476e4SDavid E. O'Brien     return(CC_REFRESH);
3212c80476e4SDavid E. O'Brien }
3213c80476e4SDavid E. O'Brien 
3214c80476e4SDavid E. O'Brien /*ARGSUSED*/
3215c80476e4SDavid E. O'Brien CCRETVAL
321645e5710bSMark Peek v_substline(Char c)
3217c80476e4SDavid E. O'Brien {				/* vi mode replace whole line */
3218c80476e4SDavid E. O'Brien     USE(c);
3219c80476e4SDavid E. O'Brien     (void) e_killall(0);
3220c80476e4SDavid E. O'Brien     c_alternativ_key_map(0);
3221c80476e4SDavid E. O'Brien     return(CC_REFRESH);
3222c80476e4SDavid E. O'Brien }
3223c80476e4SDavid E. O'Brien 
3224c80476e4SDavid E. O'Brien /*ARGSUSED*/
3225c80476e4SDavid E. O'Brien CCRETVAL
322645e5710bSMark Peek v_chgtoend(Char c)
3227c80476e4SDavid E. O'Brien {				/* vi mode change to end of line */
3228c80476e4SDavid E. O'Brien     USE(c);
3229c80476e4SDavid E. O'Brien     (void) e_killend(0);
3230c80476e4SDavid E. O'Brien     c_alternativ_key_map(0);
3231c80476e4SDavid E. O'Brien     return(CC_REFRESH);
3232c80476e4SDavid E. O'Brien }
3233c80476e4SDavid E. O'Brien 
3234c80476e4SDavid E. O'Brien /*ARGSUSED*/
3235c80476e4SDavid E. O'Brien CCRETVAL
323645e5710bSMark Peek v_insert(Char c)
3237c80476e4SDavid E. O'Brien {				/* vi mode start inserting */
3238c80476e4SDavid E. O'Brien     USE(c);
3239c80476e4SDavid E. O'Brien     c_alternativ_key_map(0);
3240c80476e4SDavid E. O'Brien 
3241c80476e4SDavid E. O'Brien     InsertPos = Cursor;
3242c80476e4SDavid E. O'Brien     UndoPtr = Cursor;
3243c80476e4SDavid E. O'Brien     UndoAction = TCSHOP_DELETE;
3244c80476e4SDavid E. O'Brien 
3245c80476e4SDavid E. O'Brien     return(CC_NORM);
3246c80476e4SDavid E. O'Brien }
3247c80476e4SDavid E. O'Brien 
3248c80476e4SDavid E. O'Brien /*ARGSUSED*/
3249c80476e4SDavid E. O'Brien CCRETVAL
325045e5710bSMark Peek v_add(Char c)
3251c80476e4SDavid E. O'Brien {				/* vi mode start adding */
3252c80476e4SDavid E. O'Brien     USE(c);
3253c80476e4SDavid E. O'Brien     c_alternativ_key_map(0);
3254c80476e4SDavid E. O'Brien     if (Cursor < LastChar)
3255c80476e4SDavid E. O'Brien     {
3256c80476e4SDavid E. O'Brien 	Cursor++;
3257c80476e4SDavid E. O'Brien 	if (Cursor > LastChar)
3258c80476e4SDavid E. O'Brien 	    Cursor = LastChar;
3259c80476e4SDavid E. O'Brien 	RefCursor();
3260c80476e4SDavid E. O'Brien     }
3261c80476e4SDavid E. O'Brien 
3262c80476e4SDavid E. O'Brien     InsertPos = Cursor;
3263c80476e4SDavid E. O'Brien     UndoPtr = Cursor;
3264c80476e4SDavid E. O'Brien     UndoAction = TCSHOP_DELETE;
3265c80476e4SDavid E. O'Brien 
3266c80476e4SDavid E. O'Brien     return(CC_NORM);
3267c80476e4SDavid E. O'Brien }
3268c80476e4SDavid E. O'Brien 
3269c80476e4SDavid E. O'Brien /*ARGSUSED*/
3270c80476e4SDavid E. O'Brien CCRETVAL
327145e5710bSMark Peek v_addend(Char c)
3272c80476e4SDavid E. O'Brien {				/* vi mode to add at end of line */
3273c80476e4SDavid E. O'Brien     USE(c);
3274c80476e4SDavid E. O'Brien     c_alternativ_key_map(0);
3275c80476e4SDavid E. O'Brien     Cursor = LastChar;
3276c80476e4SDavid E. O'Brien 
3277c80476e4SDavid E. O'Brien     InsertPos = LastChar;	/* Mark where insertion begins */
3278c80476e4SDavid E. O'Brien     UndoPtr = LastChar;
3279c80476e4SDavid E. O'Brien     UndoAction = TCSHOP_DELETE;
3280c80476e4SDavid E. O'Brien 
3281c80476e4SDavid E. O'Brien     RefCursor();
3282c80476e4SDavid E. O'Brien     return(CC_NORM);
3283c80476e4SDavid E. O'Brien }
3284c80476e4SDavid E. O'Brien 
3285c80476e4SDavid E. O'Brien /*ARGSUSED*/
3286c80476e4SDavid E. O'Brien CCRETVAL
328745e5710bSMark Peek v_change_case(Char cc)
3288c80476e4SDavid E. O'Brien {
328923338178SMark Peek     Char    c;
3290c80476e4SDavid E. O'Brien 
3291c80476e4SDavid E. O'Brien     USE(cc);
3292c80476e4SDavid E. O'Brien     if (Cursor < LastChar) {
32933b6eaa7bSAndrey A. Chernov #ifndef WINNT_NATIVE
3294c80476e4SDavid E. O'Brien 	c = *Cursor;
3295c80476e4SDavid E. O'Brien #else
3296c80476e4SDavid E. O'Brien 	c = CHAR & *Cursor;
32973b6eaa7bSAndrey A. Chernov #endif /* WINNT_NATIVE */
3298c80476e4SDavid E. O'Brien 	if (Isupper(c))
3299c80476e4SDavid E. O'Brien 	    *Cursor++ = Tolower(c);
3300c80476e4SDavid E. O'Brien 	else if (Islower(c))
3301c80476e4SDavid E. O'Brien 	    *Cursor++ = Toupper(c);
3302c80476e4SDavid E. O'Brien 	else
3303c80476e4SDavid E. O'Brien 	    Cursor++;
330423338178SMark Peek 	RefPlusOne(1);		/* fast refresh for one char */
3305c80476e4SDavid E. O'Brien 	return(CC_NORM);
3306c80476e4SDavid E. O'Brien     }
3307c80476e4SDavid E. O'Brien     return(CC_ERROR);
3308c80476e4SDavid E. O'Brien }
3309c80476e4SDavid E. O'Brien 
3310c80476e4SDavid E. O'Brien /*ARGSUSED*/
3311c80476e4SDavid E. O'Brien CCRETVAL
331245e5710bSMark Peek e_expand(Char c)
3313c80476e4SDavid E. O'Brien {
33146767bd61SMark Peek     Char *p;
3315c80476e4SDavid E. O'Brien 
3316c80476e4SDavid E. O'Brien     USE(c);
3317c80476e4SDavid E. O'Brien     for (p = InputBuf; Isspace(*p); p++)
3318c80476e4SDavid E. O'Brien 	continue;
3319c80476e4SDavid E. O'Brien     if (p == LastChar)
3320c80476e4SDavid E. O'Brien 	return(CC_ERROR);
3321c80476e4SDavid E. O'Brien 
3322c80476e4SDavid E. O'Brien     justpr++;
3323c80476e4SDavid E. O'Brien     Expand++;
3324c80476e4SDavid E. O'Brien     return(e_newline(0));
3325c80476e4SDavid E. O'Brien }
3326c80476e4SDavid E. O'Brien 
3327c80476e4SDavid E. O'Brien /*ARGSUSED*/
3328c80476e4SDavid E. O'Brien CCRETVAL
332945e5710bSMark Peek e_startover(Char c)
3330c80476e4SDavid E. O'Brien {				/* erase all of current line, start again */
3331c80476e4SDavid E. O'Brien     USE(c);
3332c80476e4SDavid E. O'Brien     ResetInLine(0);		/* reset the input pointers */
3333c80476e4SDavid E. O'Brien     return(CC_REFRESH);
3334c80476e4SDavid E. O'Brien }
3335c80476e4SDavid E. O'Brien 
3336c80476e4SDavid E. O'Brien /*ARGSUSED*/
3337c80476e4SDavid E. O'Brien CCRETVAL
333845e5710bSMark Peek e_redisp(Char c)
3339c80476e4SDavid E. O'Brien {
3340c80476e4SDavid E. O'Brien     USE(c);
3341c80476e4SDavid E. O'Brien     ClearLines();
3342c80476e4SDavid E. O'Brien     ClearDisp();
3343c80476e4SDavid E. O'Brien     return(CC_REFRESH);
3344c80476e4SDavid E. O'Brien }
3345c80476e4SDavid E. O'Brien 
3346c80476e4SDavid E. O'Brien /*ARGSUSED*/
3347c80476e4SDavid E. O'Brien CCRETVAL
334845e5710bSMark Peek e_cleardisp(Char c)
3349c80476e4SDavid E. O'Brien {
3350c80476e4SDavid E. O'Brien     USE(c);
3351c80476e4SDavid E. O'Brien     ClearScreen();		/* clear the whole real screen */
3352c80476e4SDavid E. O'Brien     ClearDisp();		/* reset everything */
3353c80476e4SDavid E. O'Brien     return(CC_REFRESH);
3354c80476e4SDavid E. O'Brien }
3355c80476e4SDavid E. O'Brien 
3356c80476e4SDavid E. O'Brien /*ARGSUSED*/
3357c80476e4SDavid E. O'Brien CCRETVAL
335845e5710bSMark Peek e_tty_int(Char c)
3359c80476e4SDavid E. O'Brien {
3360c80476e4SDavid E. O'Brien     USE(c);
33613b6eaa7bSAndrey A. Chernov #if defined(_MINIX) || defined(WINNT_NATIVE)
3362c80476e4SDavid E. O'Brien     /* SAK PATCH: erase all of current line, start again */
3363c80476e4SDavid E. O'Brien     ResetInLine(0);		/* reset the input pointers */
3364c80476e4SDavid E. O'Brien     xputchar('\n');
3365c80476e4SDavid E. O'Brien     ClearDisp();
3366c80476e4SDavid E. O'Brien     return (CC_REFRESH);
33673b6eaa7bSAndrey A. Chernov #else /* !_MINIX && !WINNT_NATIVE */
3368c80476e4SDavid E. O'Brien     /* do no editing */
3369c80476e4SDavid E. O'Brien     return (CC_NORM);
33703b6eaa7bSAndrey A. Chernov #endif /* _MINIX || WINNT_NATIVE */
3371c80476e4SDavid E. O'Brien }
3372c80476e4SDavid E. O'Brien 
3373c80476e4SDavid E. O'Brien /*
3374c80476e4SDavid E. O'Brien  * From: ghazi@cesl.rutgers.edu (Kaveh R. Ghazi)
3375c80476e4SDavid E. O'Brien  * Function to send a character back to the input stream in cooked
3376c80476e4SDavid E. O'Brien  * mode. Only works if we have TIOCSTI
3377c80476e4SDavid E. O'Brien  */
3378c80476e4SDavid E. O'Brien /*ARGSUSED*/
3379c80476e4SDavid E. O'Brien CCRETVAL
338045e5710bSMark Peek e_stuff_char(Char c)
3381c80476e4SDavid E. O'Brien {
3382c80476e4SDavid E. O'Brien #ifdef TIOCSTI
3383c80476e4SDavid E. O'Brien      int was_raw = Tty_raw_mode;
338423338178SMark Peek      char buf[MB_LEN_MAX];
338523338178SMark Peek      size_t i, len;
3386c80476e4SDavid E. O'Brien 
3387c80476e4SDavid E. O'Brien      if (was_raw)
3388c80476e4SDavid E. O'Brien          (void) Cookedmode();
3389c80476e4SDavid E. O'Brien 
339045e5710bSMark Peek      (void) xwrite(SHIN, "\n", 1);
339123338178SMark Peek      len = one_wctomb(buf, c & CHAR);
339223338178SMark Peek      for (i = 0; i < len; i++)
339323338178SMark Peek 	 (void) ioctl(SHIN, TIOCSTI, (ioctl_t) &buf[i]);
3394c80476e4SDavid E. O'Brien 
3395c80476e4SDavid E. O'Brien      if (was_raw)
3396c80476e4SDavid E. O'Brien 	 (void) Rawmode();
3397c80476e4SDavid E. O'Brien      return(e_redisp(c));
3398c80476e4SDavid E. O'Brien #else /* !TIOCSTI */
3399c80476e4SDavid E. O'Brien      return(CC_ERROR);
3400c80476e4SDavid E. O'Brien #endif /* !TIOCSTI */
3401c80476e4SDavid E. O'Brien }
3402c80476e4SDavid E. O'Brien 
3403c80476e4SDavid E. O'Brien /*ARGSUSED*/
3404c80476e4SDavid E. O'Brien CCRETVAL
340545e5710bSMark Peek e_insovr(Char c)
3406c80476e4SDavid E. O'Brien {
3407c80476e4SDavid E. O'Brien     USE(c);
3408c80476e4SDavid E. O'Brien     inputmode = (inputmode == MODE_INSERT ? MODE_REPLACE : MODE_INSERT);
3409c80476e4SDavid E. O'Brien     return(CC_NORM);
3410c80476e4SDavid E. O'Brien }
3411c80476e4SDavid E. O'Brien 
3412c80476e4SDavid E. O'Brien /*ARGSUSED*/
3413c80476e4SDavid E. O'Brien CCRETVAL
341445e5710bSMark Peek e_tty_dsusp(Char c)
3415c80476e4SDavid E. O'Brien {
3416c80476e4SDavid E. O'Brien     USE(c);
3417c80476e4SDavid E. O'Brien     /* do no editing */
3418c80476e4SDavid E. O'Brien     return(CC_NORM);
3419c80476e4SDavid E. O'Brien }
3420c80476e4SDavid E. O'Brien 
3421c80476e4SDavid E. O'Brien /*ARGSUSED*/
3422c80476e4SDavid E. O'Brien CCRETVAL
342345e5710bSMark Peek e_tty_flusho(Char c)
3424c80476e4SDavid E. O'Brien {
3425c80476e4SDavid E. O'Brien     USE(c);
3426c80476e4SDavid E. O'Brien     /* do no editing */
3427c80476e4SDavid E. O'Brien     return(CC_NORM);
3428c80476e4SDavid E. O'Brien }
3429c80476e4SDavid E. O'Brien 
3430c80476e4SDavid E. O'Brien /*ARGSUSED*/
3431c80476e4SDavid E. O'Brien CCRETVAL
343245e5710bSMark Peek e_tty_quit(Char c)
3433c80476e4SDavid E. O'Brien {
3434c80476e4SDavid E. O'Brien     USE(c);
3435c80476e4SDavid E. O'Brien     /* do no editing */
3436c80476e4SDavid E. O'Brien     return(CC_NORM);
3437c80476e4SDavid E. O'Brien }
3438c80476e4SDavid E. O'Brien 
3439c80476e4SDavid E. O'Brien /*ARGSUSED*/
3440c80476e4SDavid E. O'Brien CCRETVAL
344145e5710bSMark Peek e_tty_tsusp(Char c)
3442c80476e4SDavid E. O'Brien {
3443c80476e4SDavid E. O'Brien     USE(c);
3444c80476e4SDavid E. O'Brien     /* do no editing */
3445c80476e4SDavid E. O'Brien     return(CC_NORM);
3446c80476e4SDavid E. O'Brien }
3447c80476e4SDavid E. O'Brien 
3448c80476e4SDavid E. O'Brien /*ARGSUSED*/
3449c80476e4SDavid E. O'Brien CCRETVAL
345045e5710bSMark Peek e_tty_stopo(Char c)
3451c80476e4SDavid E. O'Brien {
3452c80476e4SDavid E. O'Brien     USE(c);
3453c80476e4SDavid E. O'Brien     /* do no editing */
3454c80476e4SDavid E. O'Brien     return(CC_NORM);
3455c80476e4SDavid E. O'Brien }
3456c80476e4SDavid E. O'Brien 
3457a15e6f9aSMark Peek /* returns the number of (attempted) expansions */
3458a15e6f9aSMark Peek int
3459a15e6f9aSMark Peek ExpandHistory(void)
3460a15e6f9aSMark Peek {
3461a15e6f9aSMark Peek     *LastChar = '\0';		/* just in case */
3462a15e6f9aSMark Peek     return c_substitute();
3463a15e6f9aSMark Peek }
3464a15e6f9aSMark Peek 
3465c80476e4SDavid E. O'Brien /*ARGSUSED*/
3466c80476e4SDavid E. O'Brien CCRETVAL
346745e5710bSMark Peek e_expand_history(Char c)
3468c80476e4SDavid E. O'Brien {
3469c80476e4SDavid E. O'Brien     USE(c);
3470a15e6f9aSMark Peek     (void)ExpandHistory();
3471c80476e4SDavid E. O'Brien     return(CC_NORM);
3472c80476e4SDavid E. O'Brien }
3473c80476e4SDavid E. O'Brien 
3474c80476e4SDavid E. O'Brien /*ARGSUSED*/
3475c80476e4SDavid E. O'Brien CCRETVAL
347645e5710bSMark Peek e_magic_space(Char c)
3477c80476e4SDavid E. O'Brien {
3478c80476e4SDavid E. O'Brien     USE(c);
3479c80476e4SDavid E. O'Brien     *LastChar = '\0';		/* just in case */
3480a15e6f9aSMark Peek     (void)c_substitute();
3481c80476e4SDavid E. O'Brien     return(e_insert(' '));
3482c80476e4SDavid E. O'Brien }
3483c80476e4SDavid E. O'Brien 
3484c80476e4SDavid E. O'Brien /*ARGSUSED*/
3485c80476e4SDavid E. O'Brien CCRETVAL
348645e5710bSMark Peek e_inc_fwd(Char c)
3487c80476e4SDavid E. O'Brien {
348845e5710bSMark Peek     CCRETVAL ret;
348945e5710bSMark Peek 
3490c80476e4SDavid E. O'Brien     USE(c);
349145e5710bSMark Peek     patbuf.len = 0;
349245e5710bSMark Peek     MarkIsSet = 0;
349345e5710bSMark Peek     ret = e_inc_search(F_DOWN_SEARCH_HIST);
349445e5710bSMark Peek     if (adrof(STRhighlight) && IncMatchLen) {
349545e5710bSMark Peek 	IncMatchLen = 0;
349645e5710bSMark Peek 	ClearLines();
349745e5710bSMark Peek 	ClearDisp();
349845e5710bSMark Peek 	Refresh();
349945e5710bSMark Peek     }
350045e5710bSMark Peek     IncMatchLen = 0;
350145e5710bSMark Peek     return ret;
3502c80476e4SDavid E. O'Brien }
3503c80476e4SDavid E. O'Brien 
3504c80476e4SDavid E. O'Brien 
3505c80476e4SDavid E. O'Brien /*ARGSUSED*/
3506c80476e4SDavid E. O'Brien CCRETVAL
350745e5710bSMark Peek e_inc_back(Char c)
3508c80476e4SDavid E. O'Brien {
350945e5710bSMark Peek     CCRETVAL ret;
351045e5710bSMark Peek 
3511c80476e4SDavid E. O'Brien     USE(c);
351245e5710bSMark Peek     patbuf.len = 0;
351345e5710bSMark Peek     MarkIsSet = 0;
351445e5710bSMark Peek     ret = e_inc_search(F_UP_SEARCH_HIST);
351545e5710bSMark Peek     if (adrof(STRhighlight) && IncMatchLen) {
351645e5710bSMark Peek 	IncMatchLen = 0;
351745e5710bSMark Peek 	ClearLines();
351845e5710bSMark Peek 	ClearDisp();
351945e5710bSMark Peek 	Refresh();
352045e5710bSMark Peek     }
352145e5710bSMark Peek     IncMatchLen = 0;
352245e5710bSMark Peek     return ret;
3523c80476e4SDavid E. O'Brien }
3524c80476e4SDavid E. O'Brien 
3525c80476e4SDavid E. O'Brien /*ARGSUSED*/
3526c80476e4SDavid E. O'Brien CCRETVAL
352745e5710bSMark Peek e_copyprev(Char c)
3528c80476e4SDavid E. O'Brien {
35296767bd61SMark Peek     Char *cp, *oldc, *dp;
3530c80476e4SDavid E. O'Brien 
3531c80476e4SDavid E. O'Brien     USE(c);
3532c80476e4SDavid E. O'Brien     if (Cursor == InputBuf)
3533c80476e4SDavid E. O'Brien 	return(CC_ERROR);
3534c80476e4SDavid E. O'Brien     /* else */
3535c80476e4SDavid E. O'Brien 
3536c80476e4SDavid E. O'Brien     oldc = Cursor;
3537c80476e4SDavid E. O'Brien     /* does a bounds check */
3538c80476e4SDavid E. O'Brien     cp = c_prev_word(Cursor, InputBuf, Argument);
3539c80476e4SDavid E. O'Brien 
3540c80476e4SDavid E. O'Brien     c_insert((int)(oldc - cp));
3541c80476e4SDavid E. O'Brien     for (dp = oldc; cp < oldc && dp < LastChar; cp++)
3542c80476e4SDavid E. O'Brien 	*dp++ = *cp;
3543c80476e4SDavid E. O'Brien 
3544c80476e4SDavid E. O'Brien     Cursor = dp;		/* put cursor at end */
3545c80476e4SDavid E. O'Brien 
3546c80476e4SDavid E. O'Brien     return(CC_REFRESH);
3547c80476e4SDavid E. O'Brien }
3548c80476e4SDavid E. O'Brien 
3549c80476e4SDavid E. O'Brien /*ARGSUSED*/
3550c80476e4SDavid E. O'Brien CCRETVAL
355145e5710bSMark Peek e_tty_starto(Char c)
3552c80476e4SDavid E. O'Brien {
3553c80476e4SDavid E. O'Brien     USE(c);
3554c80476e4SDavid E. O'Brien     /* do no editing */
3555c80476e4SDavid E. O'Brien     return(CC_NORM);
3556c80476e4SDavid E. O'Brien }
3557c80476e4SDavid E. O'Brien 
3558c80476e4SDavid E. O'Brien /*ARGSUSED*/
3559c80476e4SDavid E. O'Brien CCRETVAL
356045e5710bSMark Peek e_load_average(Char c)
3561c80476e4SDavid E. O'Brien {
3562c80476e4SDavid E. O'Brien     USE(c);
3563c80476e4SDavid E. O'Brien     PastBottom();
3564c80476e4SDavid E. O'Brien #ifdef TIOCSTAT
3565c80476e4SDavid E. O'Brien     /*
3566c80476e4SDavid E. O'Brien      * Here we pass &c to the ioctl because some os's (NetBSD) expect it
3567c80476e4SDavid E. O'Brien      * there even if they don't use it. (lukem@netbsd.org)
3568c80476e4SDavid E. O'Brien      */
3569c80476e4SDavid E. O'Brien     if (ioctl(SHIN, TIOCSTAT, (ioctl_t) &c) < 0)
3570c80476e4SDavid E. O'Brien #endif
3571a15e6f9aSMark Peek 	xprintf("%s", CGETS(5, 1, "Load average unavailable\n"));
3572c80476e4SDavid E. O'Brien     return(CC_REFRESH);
3573c80476e4SDavid E. O'Brien }
3574c80476e4SDavid E. O'Brien 
3575c80476e4SDavid E. O'Brien /*ARGSUSED*/
3576c80476e4SDavid E. O'Brien CCRETVAL
357745e5710bSMark Peek v_chgmeta(Char c)
3578c80476e4SDavid E. O'Brien {
3579c80476e4SDavid E. O'Brien     USE(c);
3580c80476e4SDavid E. O'Brien     /*
3581c80476e4SDavid E. O'Brien      * Delete with insert == change: first we delete and then we leave in
3582c80476e4SDavid E. O'Brien      * insert mode.
3583c80476e4SDavid E. O'Brien      */
3584c80476e4SDavid E. O'Brien     return(v_action(TCSHOP_DELETE|TCSHOP_INSERT));
3585c80476e4SDavid E. O'Brien }
3586c80476e4SDavid E. O'Brien 
3587c80476e4SDavid E. O'Brien /*ARGSUSED*/
3588c80476e4SDavid E. O'Brien CCRETVAL
358945e5710bSMark Peek v_delmeta(Char c)
3590c80476e4SDavid E. O'Brien {
3591c80476e4SDavid E. O'Brien     USE(c);
3592c80476e4SDavid E. O'Brien     return(v_action(TCSHOP_DELETE));
3593c80476e4SDavid E. O'Brien }
3594c80476e4SDavid E. O'Brien 
3595c80476e4SDavid E. O'Brien 
3596c80476e4SDavid E. O'Brien /*ARGSUSED*/
3597c80476e4SDavid E. O'Brien CCRETVAL
359845e5710bSMark Peek v_endword(Char c)
3599c80476e4SDavid E. O'Brien {
3600c80476e4SDavid E. O'Brien     USE(c);
3601c80476e4SDavid E. O'Brien     if (Cursor == LastChar)
3602c80476e4SDavid E. O'Brien 	return(CC_ERROR);
3603c80476e4SDavid E. O'Brien     /* else */
3604c80476e4SDavid E. O'Brien 
36056767bd61SMark Peek     Cursor = c_endword(Cursor, LastChar, Argument, STRshwspace);
3606c80476e4SDavid E. O'Brien 
3607c80476e4SDavid E. O'Brien     if (ActionFlag & TCSHOP_DELETE)
3608c80476e4SDavid E. O'Brien     {
3609c80476e4SDavid E. O'Brien 	Cursor++;
3610c80476e4SDavid E. O'Brien 	c_delfini();
3611c80476e4SDavid E. O'Brien 	return(CC_REFRESH);
3612c80476e4SDavid E. O'Brien     }
3613c80476e4SDavid E. O'Brien 
3614c80476e4SDavid E. O'Brien     RefCursor();
3615c80476e4SDavid E. O'Brien     return(CC_NORM);
3616c80476e4SDavid E. O'Brien }
3617c80476e4SDavid E. O'Brien 
3618c80476e4SDavid E. O'Brien /*ARGSUSED*/
3619c80476e4SDavid E. O'Brien CCRETVAL
362045e5710bSMark Peek v_eword(Char c)
3621c80476e4SDavid E. O'Brien {
3622c80476e4SDavid E. O'Brien     USE(c);
3623c80476e4SDavid E. O'Brien     if (Cursor == LastChar)
3624c80476e4SDavid E. O'Brien 	return(CC_ERROR);
3625c80476e4SDavid E. O'Brien     /* else */
3626c80476e4SDavid E. O'Brien 
3627c80476e4SDavid E. O'Brien     Cursor = c_eword(Cursor, LastChar, Argument);
3628c80476e4SDavid E. O'Brien 
3629c80476e4SDavid E. O'Brien     if (ActionFlag & TCSHOP_DELETE) {
3630c80476e4SDavid E. O'Brien 	Cursor++;
3631c80476e4SDavid E. O'Brien 	c_delfini();
3632c80476e4SDavid E. O'Brien 	return(CC_REFRESH);
3633c80476e4SDavid E. O'Brien     }
3634c80476e4SDavid E. O'Brien 
3635c80476e4SDavid E. O'Brien     RefCursor();
3636c80476e4SDavid E. O'Brien     return(CC_NORM);
3637c80476e4SDavid E. O'Brien }
3638c80476e4SDavid E. O'Brien 
3639c80476e4SDavid E. O'Brien /*ARGSUSED*/
3640c80476e4SDavid E. O'Brien CCRETVAL
364145e5710bSMark Peek v_char_fwd(Char c)
3642c80476e4SDavid E. O'Brien {
3643c80476e4SDavid E. O'Brien     Char ch;
3644c80476e4SDavid E. O'Brien 
3645c80476e4SDavid E. O'Brien     USE(c);
3646c80476e4SDavid E. O'Brien     if (GetNextChar(&ch) != 1)
3647c80476e4SDavid E. O'Brien 	return e_send_eof(0);
3648c80476e4SDavid E. O'Brien 
3649c80476e4SDavid E. O'Brien     srch_dir = CHAR_FWD;
3650c80476e4SDavid E. O'Brien     srch_char = ch;
3651c80476e4SDavid E. O'Brien 
3652c80476e4SDavid E. O'Brien     return v_csearch_fwd(ch, Argument, 0);
3653c80476e4SDavid E. O'Brien 
3654c80476e4SDavid E. O'Brien }
3655c80476e4SDavid E. O'Brien 
3656c80476e4SDavid E. O'Brien /*ARGSUSED*/
3657c80476e4SDavid E. O'Brien CCRETVAL
365845e5710bSMark Peek v_char_back(Char c)
3659c80476e4SDavid E. O'Brien {
3660c80476e4SDavid E. O'Brien     Char ch;
3661c80476e4SDavid E. O'Brien 
3662c80476e4SDavid E. O'Brien     USE(c);
3663c80476e4SDavid E. O'Brien     if (GetNextChar(&ch) != 1)
3664c80476e4SDavid E. O'Brien 	return e_send_eof(0);
3665c80476e4SDavid E. O'Brien 
3666c80476e4SDavid E. O'Brien     srch_dir = CHAR_BACK;
3667c80476e4SDavid E. O'Brien     srch_char = ch;
3668c80476e4SDavid E. O'Brien 
3669c80476e4SDavid E. O'Brien     return v_csearch_back(ch, Argument, 0);
3670c80476e4SDavid E. O'Brien }
3671c80476e4SDavid E. O'Brien 
3672c80476e4SDavid E. O'Brien /*ARGSUSED*/
3673c80476e4SDavid E. O'Brien CCRETVAL
367445e5710bSMark Peek v_charto_fwd(Char c)
3675c80476e4SDavid E. O'Brien {
3676c80476e4SDavid E. O'Brien     Char ch;
3677c80476e4SDavid E. O'Brien 
3678c80476e4SDavid E. O'Brien     USE(c);
3679c80476e4SDavid E. O'Brien     if (GetNextChar(&ch) != 1)
3680c80476e4SDavid E. O'Brien 	return e_send_eof(0);
3681c80476e4SDavid E. O'Brien 
3682c80476e4SDavid E. O'Brien     return v_csearch_fwd(ch, Argument, 1);
3683c80476e4SDavid E. O'Brien 
3684c80476e4SDavid E. O'Brien }
3685c80476e4SDavid E. O'Brien 
3686c80476e4SDavid E. O'Brien /*ARGSUSED*/
3687c80476e4SDavid E. O'Brien CCRETVAL
368845e5710bSMark Peek v_charto_back(Char c)
3689c80476e4SDavid E. O'Brien {
3690c80476e4SDavid E. O'Brien     Char ch;
3691c80476e4SDavid E. O'Brien 
3692c80476e4SDavid E. O'Brien     USE(c);
3693c80476e4SDavid E. O'Brien     if (GetNextChar(&ch) != 1)
3694c80476e4SDavid E. O'Brien 	return e_send_eof(0);
3695c80476e4SDavid E. O'Brien 
3696c80476e4SDavid E. O'Brien     return v_csearch_back(ch, Argument, 1);
3697c80476e4SDavid E. O'Brien }
3698c80476e4SDavid E. O'Brien 
3699c80476e4SDavid E. O'Brien /*ARGSUSED*/
3700c80476e4SDavid E. O'Brien CCRETVAL
370145e5710bSMark Peek v_rchar_fwd(Char c)
3702c80476e4SDavid E. O'Brien {
3703c80476e4SDavid E. O'Brien     USE(c);
3704c80476e4SDavid E. O'Brien     if (srch_char == 0)
3705c80476e4SDavid E. O'Brien 	return CC_ERROR;
3706c80476e4SDavid E. O'Brien 
3707c80476e4SDavid E. O'Brien     return srch_dir == CHAR_FWD ? v_csearch_fwd(srch_char, Argument, 0) :
3708c80476e4SDavid E. O'Brien 			          v_csearch_back(srch_char, Argument, 0);
3709c80476e4SDavid E. O'Brien }
3710c80476e4SDavid E. O'Brien 
3711c80476e4SDavid E. O'Brien /*ARGSUSED*/
3712c80476e4SDavid E. O'Brien CCRETVAL
371345e5710bSMark Peek v_rchar_back(Char c)
3714c80476e4SDavid E. O'Brien {
3715c80476e4SDavid E. O'Brien     USE(c);
3716c80476e4SDavid E. O'Brien     if (srch_char == 0)
3717c80476e4SDavid E. O'Brien 	return CC_ERROR;
3718c80476e4SDavid E. O'Brien 
3719c80476e4SDavid E. O'Brien     return srch_dir == CHAR_BACK ? v_csearch_fwd(srch_char, Argument, 0) :
3720c80476e4SDavid E. O'Brien 			           v_csearch_back(srch_char, Argument, 0);
3721c80476e4SDavid E. O'Brien }
3722c80476e4SDavid E. O'Brien 
3723c80476e4SDavid E. O'Brien /*ARGSUSED*/
3724c80476e4SDavid E. O'Brien CCRETVAL
372545e5710bSMark Peek v_undo(Char c)
3726c80476e4SDavid E. O'Brien {
37276767bd61SMark Peek     int  loop;
37286767bd61SMark Peek     Char *kp, *cp;
3729c80476e4SDavid E. O'Brien     Char temp;
3730c80476e4SDavid E. O'Brien     int	 size;
3731c80476e4SDavid E. O'Brien 
3732c80476e4SDavid E. O'Brien     USE(c);
3733c80476e4SDavid E. O'Brien     switch (UndoAction) {
3734c80476e4SDavid E. O'Brien     case TCSHOP_DELETE|TCSHOP_INSERT:
3735c80476e4SDavid E. O'Brien     case TCSHOP_DELETE:
3736c80476e4SDavid E. O'Brien 	if (UndoSize == 0) return(CC_NORM);
3737c80476e4SDavid E. O'Brien 	cp = UndoPtr;
3738c80476e4SDavid E. O'Brien 	kp = UndoBuf;
3739c80476e4SDavid E. O'Brien 	for (loop=0; loop < UndoSize; loop++)	/* copy the chars */
3740c80476e4SDavid E. O'Brien 	    *kp++ = *cp++;			/* into UndoBuf   */
3741c80476e4SDavid E. O'Brien 
3742c80476e4SDavid E. O'Brien 	for (cp = UndoPtr; cp <= LastChar; cp++)
3743c80476e4SDavid E. O'Brien 	    *cp = cp[UndoSize];
3744c80476e4SDavid E. O'Brien 
3745c80476e4SDavid E. O'Brien 	LastChar -= UndoSize;
3746c80476e4SDavid E. O'Brien 	Cursor   =  UndoPtr;
3747c80476e4SDavid E. O'Brien 
3748c80476e4SDavid E. O'Brien 	UndoAction = TCSHOP_INSERT;
3749c80476e4SDavid E. O'Brien 	break;
3750c80476e4SDavid E. O'Brien 
3751c80476e4SDavid E. O'Brien     case TCSHOP_INSERT:
3752c80476e4SDavid E. O'Brien 	if (UndoSize == 0) return(CC_NORM);
3753c80476e4SDavid E. O'Brien 	cp = UndoPtr;
3754c80476e4SDavid E. O'Brien 	Cursor = UndoPtr;
3755c80476e4SDavid E. O'Brien 	kp = UndoBuf;
3756c80476e4SDavid E. O'Brien 	c_insert(UndoSize);		/* open the space, */
3757c80476e4SDavid E. O'Brien 	for (loop = 0; loop < UndoSize; loop++)	/* copy the chars */
3758c80476e4SDavid E. O'Brien 	    *cp++ = *kp++;
3759c80476e4SDavid E. O'Brien 
3760c80476e4SDavid E. O'Brien 	UndoAction = TCSHOP_DELETE;
3761c80476e4SDavid E. O'Brien 	break;
3762c80476e4SDavid E. O'Brien 
3763c80476e4SDavid E. O'Brien     case TCSHOP_CHANGE:
3764c80476e4SDavid E. O'Brien 	if (UndoSize == 0) return(CC_NORM);
3765c80476e4SDavid E. O'Brien 	cp = UndoPtr;
3766c80476e4SDavid E. O'Brien 	Cursor = UndoPtr;
3767c80476e4SDavid E. O'Brien 	kp = UndoBuf;
3768c80476e4SDavid E. O'Brien 	size = (int)(Cursor-LastChar); /*  NOT NSL independant */
3769c80476e4SDavid E. O'Brien 	if (size < UndoSize)
3770c80476e4SDavid E. O'Brien 	    size = UndoSize;
3771c80476e4SDavid E. O'Brien 	for(loop = 0; loop < size; loop++) {
3772c80476e4SDavid E. O'Brien 	    temp = *kp;
3773c80476e4SDavid E. O'Brien 	    *kp++ = *cp;
3774c80476e4SDavid E. O'Brien 	    *cp++ = temp;
3775c80476e4SDavid E. O'Brien 	}
3776c80476e4SDavid E. O'Brien 	break;
3777c80476e4SDavid E. O'Brien 
3778c80476e4SDavid E. O'Brien     default:
3779c80476e4SDavid E. O'Brien 	return(CC_ERROR);
3780c80476e4SDavid E. O'Brien     }
3781c80476e4SDavid E. O'Brien 
3782c80476e4SDavid E. O'Brien     return(CC_REFRESH);
3783c80476e4SDavid E. O'Brien }
3784c80476e4SDavid E. O'Brien 
3785c80476e4SDavid E. O'Brien /*ARGSUSED*/
3786c80476e4SDavid E. O'Brien CCRETVAL
378745e5710bSMark Peek v_ush_meta(Char c)
3788c80476e4SDavid E. O'Brien {
3789c80476e4SDavid E. O'Brien     USE(c);
3790c80476e4SDavid E. O'Brien     return v_search(F_UP_SEARCH_HIST);
3791c80476e4SDavid E. O'Brien }
3792c80476e4SDavid E. O'Brien 
3793c80476e4SDavid E. O'Brien /*ARGSUSED*/
3794c80476e4SDavid E. O'Brien CCRETVAL
379545e5710bSMark Peek v_dsh_meta(Char c)
3796c80476e4SDavid E. O'Brien {
3797c80476e4SDavid E. O'Brien     USE(c);
3798c80476e4SDavid E. O'Brien     return v_search(F_DOWN_SEARCH_HIST);
3799c80476e4SDavid E. O'Brien }
3800c80476e4SDavid E. O'Brien 
3801c80476e4SDavid E. O'Brien /*ARGSUSED*/
3802c80476e4SDavid E. O'Brien CCRETVAL
380345e5710bSMark Peek v_rsrch_fwd(Char c)
3804c80476e4SDavid E. O'Brien {
3805c80476e4SDavid E. O'Brien     USE(c);
380645e5710bSMark Peek     if (patbuf.len == 0) return(CC_ERROR);
3807c80476e4SDavid E. O'Brien     return(v_repeat_srch(searchdir));
3808c80476e4SDavid E. O'Brien }
3809c80476e4SDavid E. O'Brien 
3810c80476e4SDavid E. O'Brien /*ARGSUSED*/
3811c80476e4SDavid E. O'Brien CCRETVAL
381245e5710bSMark Peek v_rsrch_back(Char c)
3813c80476e4SDavid E. O'Brien {
3814c80476e4SDavid E. O'Brien     USE(c);
381545e5710bSMark Peek     if (patbuf.len == 0) return(CC_ERROR);
3816c80476e4SDavid E. O'Brien     return(v_repeat_srch(searchdir == F_UP_SEARCH_HIST ?
3817c80476e4SDavid E. O'Brien 			 F_DOWN_SEARCH_HIST : F_UP_SEARCH_HIST));
3818c80476e4SDavid E. O'Brien }
3819c80476e4SDavid E. O'Brien 
38203b6eaa7bSAndrey A. Chernov #ifndef WINNT_NATIVE
3821c80476e4SDavid E. O'Brien /* Since ed.defns.h  is generated from ed.defns.c, these empty
3822c80476e4SDavid E. O'Brien    functions will keep the F_NUM_FNS consistent
3823c80476e4SDavid E. O'Brien  */
3824c80476e4SDavid E. O'Brien CCRETVAL
382545e5710bSMark Peek e_copy_to_clipboard(Char c)
3826c80476e4SDavid E. O'Brien {
3827c80476e4SDavid E. O'Brien     USE(c);
3828c80476e4SDavid E. O'Brien     return CC_ERROR;
3829c80476e4SDavid E. O'Brien }
3830c80476e4SDavid E. O'Brien 
3831c80476e4SDavid E. O'Brien CCRETVAL
383245e5710bSMark Peek e_paste_from_clipboard(Char c)
3833c80476e4SDavid E. O'Brien {
3834c80476e4SDavid E. O'Brien     USE(c);
3835c80476e4SDavid E. O'Brien     return (CC_ERROR);
3836c80476e4SDavid E. O'Brien }
3837c80476e4SDavid E. O'Brien 
3838c80476e4SDavid E. O'Brien CCRETVAL
383945e5710bSMark Peek e_dosify_next(Char c)
3840c80476e4SDavid E. O'Brien {
3841c80476e4SDavid E. O'Brien     USE(c);
3842c80476e4SDavid E. O'Brien     return (CC_ERROR);
3843c80476e4SDavid E. O'Brien }
3844c80476e4SDavid E. O'Brien CCRETVAL
384545e5710bSMark Peek e_dosify_prev(Char c)
3846c80476e4SDavid E. O'Brien {
3847c80476e4SDavid E. O'Brien     USE(c);
3848c80476e4SDavid E. O'Brien     return (CC_ERROR);
3849c80476e4SDavid E. O'Brien }
3850c80476e4SDavid E. O'Brien CCRETVAL
385145e5710bSMark Peek e_page_up(Char c)
3852c80476e4SDavid E. O'Brien {
3853c80476e4SDavid E. O'Brien     USE(c);
3854c80476e4SDavid E. O'Brien     return (CC_ERROR);
3855c80476e4SDavid E. O'Brien }
3856c80476e4SDavid E. O'Brien CCRETVAL
385745e5710bSMark Peek e_page_down(Char c)
3858c80476e4SDavid E. O'Brien {
3859c80476e4SDavid E. O'Brien     USE(c);
3860c80476e4SDavid E. O'Brien     return (CC_ERROR);
3861c80476e4SDavid E. O'Brien }
38623b6eaa7bSAndrey A. Chernov #endif /* !WINNT_NATIVE */
3863c80476e4SDavid E. O'Brien 
3864c80476e4SDavid E. O'Brien #ifdef notdef
3865c80476e4SDavid E. O'Brien void
386645e5710bSMark Peek MoveCursor(int n)		/* move cursor + right - left char */
3867c80476e4SDavid E. O'Brien {
3868c80476e4SDavid E. O'Brien     Cursor = Cursor + n;
3869c80476e4SDavid E. O'Brien     if (Cursor < InputBuf)
3870c80476e4SDavid E. O'Brien 	Cursor = InputBuf;
3871c80476e4SDavid E. O'Brien     if (Cursor > LastChar)
3872c80476e4SDavid E. O'Brien 	Cursor = LastChar;
3873c80476e4SDavid E. O'Brien     return;
3874c80476e4SDavid E. O'Brien }
3875c80476e4SDavid E. O'Brien 
3876c80476e4SDavid E. O'Brien Char *
387745e5710bSMark Peek GetCursor(void)
3878c80476e4SDavid E. O'Brien {
3879c80476e4SDavid E. O'Brien     return(Cursor);
3880c80476e4SDavid E. O'Brien }
3881c80476e4SDavid E. O'Brien 
3882c80476e4SDavid E. O'Brien int
388345e5710bSMark Peek PutCursor(Char *p)
3884c80476e4SDavid E. O'Brien {
3885c80476e4SDavid E. O'Brien     if (p < InputBuf || p > LastChar)
3886c80476e4SDavid E. O'Brien 	return 1;		/* Error */
3887c80476e4SDavid E. O'Brien     Cursor = p;
3888c80476e4SDavid E. O'Brien     return 0;
3889c80476e4SDavid E. O'Brien }
3890c80476e4SDavid E. O'Brien #endif
3891