xref: /freebsd/contrib/tcsh/ed.h (revision 87569f75a91f298c52a71823c04d41cf53c88889)
1 /* $Header: /src/pub/tcsh/ed.h,v 3.44 2005/03/05 03:20:15 christos Exp $ */
2 /*
3  * ed.h: Editor declarations and globals
4  */
5 /*-
6  * Copyright (c) 1980, 1991 The Regents of the University of California.
7  * All rights reserved.
8  *
9  * Redistribution and use in source and binary forms, with or without
10  * modification, are permitted provided that the following conditions
11  * are met:
12  * 1. Redistributions of source code must retain the above copyright
13  *    notice, this list of conditions and the following disclaimer.
14  * 2. Redistributions in binary form must reproduce the above copyright
15  *    notice, this list of conditions and the following disclaimer in the
16  *    documentation and/or other materials provided with the distribution.
17  * 3. Neither the name of the University nor the names of its contributors
18  *    may be used to endorse or promote products derived from this software
19  *    without specific prior written permission.
20  *
21  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
22  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
25  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31  * SUCH DAMAGE.
32  */
33 #ifndef _h_ed
34 #define _h_ed
35 
36 #ifndef EXTERN
37 # define EXTERN extern
38 #endif
39 
40 #define TABSIZE		8	/* usually 8 spaces/tab */
41 #define MAXMACROLEVELS	10	/* max number of nested kbd macros */
42 
43 #ifndef WINNT_NATIVE
44 # define NT_NUM_KEYS	256
45 #endif /* WINNT_NATIVE */
46 
47 /****************************************************************************/
48 /* stuff for the different states returned by the character editor routines */
49 /****************************************************************************/
50 
51 #define CCRETVAL	char	/* size needed for the different char editor */
52  /* return values */
53 
54 #define KEYCMD   unsigned char	/* size needed to index into CcFuncTbl */
55  /* Must be unsigned 		       */
56 
57 typedef CCRETVAL(*PFCmd) __P((Char));	/* pointer to function returning CCRETVAL */
58 
59 struct KeyFuncs {		/* for the "bind" shell command */
60     const char *name;		/* function name for bind command */
61     int     func;		/* function numeric value */
62     const char *desc;		/* description of function */
63 };
64 
65 extern PFCmd CcFuncTbl[];	/* table of available commands */
66 extern KEYCMD CcKeyMap[];	/* keymap table, each index into above tbl */
67 extern KEYCMD CcAltMap[];	/* Alt keymap table */
68 extern KEYCMD CcEmacsMap[];	/* keymap table for Emacs default bindings */
69 extern KEYCMD CcViCmdMap[];	/* for Vi command mode defaults */
70 extern struct KeyFuncs FuncNames[];	/* string names vs. CcFuncTbl indices */
71 
72 extern KEYCMD NumFuns;		/* number of KEYCMDs in above table */
73 
74 #define	CC_ERROR		100	/* there should NOT be 100 different... */
75 #define CC_FATAL		101	/* fatal error: inconsistant, must
76 					 * reset */
77 #define	CC_NORM			0
78 #define	CC_NEWLINE		1
79 #define	CC_EOF			2
80 #define	CC_COMPLETE		3
81 #define	CC_LIST_CHOICES		4
82 #define	CC_LIST_GLOB		5
83 #define CC_EXPAND_GLOB		6
84 #define	CC_HELPME		9
85 #define CC_CORRECT		10
86 #define CC_WHICH		11
87 #define CC_ARGHACK		12
88 #define CC_CORRECT_L		13
89 #define CC_REFRESH		14
90 #define CC_EXPAND_VARS		15
91 #define CC_NORMALIZE_PATH	16
92 #define CC_LIST_ALL		17
93 #define CC_COMPLETE_ALL		18
94 #define CC_COMPLETE_FWD		19
95 #define CC_COMPLETE_BACK	20
96 #define CC_NORMALIZE_COMMAND	21
97 
98 typedef struct {
99     Char *buf;
100     int   len;
101 } CStr;
102 
103 typedef union Xmapval {		/* value passed to the Xkey routines */
104     KEYCMD cmd;
105     CStr str;
106 } XmapVal;
107 
108 #define XK_NOD	-1		/* Internal tree node */
109 #define XK_CMD	 0		/* X-key was an editor command */
110 #define XK_STR	 1		/* X-key was a string macro */
111 #define XK_EXE	 2		/* X-key was a unix command */
112 
113 /****************************/
114 /* Editor state and buffers */
115 /****************************/
116 
117 EXTERN KEYCMD *CurrentKeyMap;	/* current command key map */
118 EXTERN int inputmode;		/* insert, replace, replace1 mode */
119 EXTERN Char GettingInput;	/* true if getting an input line (mostly) */
120 EXTERN Char NeedsRedraw;	/* for editor and twenex error messages */
121 EXTERN Char InputBuf[INBUFSIZE];	/* the real input data */
122 EXTERN Char *LastChar, *Cursor;	/* point to the next open space */
123 EXTERN Char *InputLim;		/* limit of size of InputBuf */
124 EXTERN Char MetaNext;		/* flags for ^V and ^[ functions */
125 EXTERN Char AltKeyMap;		/* Using alternative command map (for vi mode) */
126 EXTERN Char VImode;		/* true if running in vi mode (PWP 6-27-88) */
127 EXTERN Char *Mark;		/* the emacs "mark" (dot is Cursor) */
128 EXTERN Char DoingArg;		/* true if we have an argument */
129 EXTERN int Argument;		/* "universal" argument value */
130 EXTERN KEYCMD LastCmd;		/* previous command executed */
131 EXTERN CStr *KillRing;		/* kill ring */
132 EXTERN int KillRingMax;		/* max length of kill ring */
133 EXTERN int KillRingLen;		/* current length of kill ring */
134 EXTERN int KillPos;		/* points to next kill */
135 EXTERN int YankPos;		/* points to next yank */
136 
137 EXTERN Char UndoBuf[INBUFSIZE];
138 EXTERN Char *UndoPtr;
139 EXTERN int  UndoSize;
140 EXTERN int  UndoAction;
141 
142 EXTERN Char HistBuf[INBUFSIZE];	/* history buffer */
143 EXTERN Char *LastHist;		/* points to end of history buffer */
144 EXTERN int Hist_num;		/* what point up the history we are at now. */
145 EXTERN Char WhichBuf[INBUFSIZE];	/* buffer for which command */
146 EXTERN Char *LastWhich;		/* points to end of which buffer */
147 EXTERN Char *CursWhich;		/* points to the cursor point in which buf */
148 EXTERN int HistWhich;		/* Hist_num is saved in this */
149 EXTERN char Expand;		/* true if we are expanding a line */
150 extern Char HistLit;		/* true if history lines are shown literal */
151 EXTERN Char CurrentHistLit;	/* Literal status of current show history line */
152 extern int Tty_raw_mode;
153 
154 /*
155  * These are truly extern
156  */
157 extern int MacroLvl;
158 extern Char *litptr;	 /* Entries start at offsets divisible by LIT_FACTOR */
159 #define LIT_FACTOR 4
160 extern int didsetty;
161 
162 EXTERN Char *KeyMacro[MAXMACROLEVELS];
163 
164 /* CHAR_DBWIDTH in Display and Vdisplay means the non-first column of a character
165    that is wider than one "regular" position. The cursor should never point
166    in the middle of a multiple-column character. */
167 EXTERN Char **Display;		/* display buffer seed vector */
168 EXTERN int CursorV,		/* real cursor vertical (line) */
169         CursorH,		/* real cursor horisontal (column) */
170         TermV,			/* number of real screen lines
171 				 * (sizeof(DisplayBuf) / width */
172         TermH;			/* screen width */
173 EXTERN Char **Vdisplay;	/* new buffer */
174 
175 /* Variables that describe terminal ability */
176 EXTERN int T_Lines, T_Cols;	/* Rows and Cols of the terminal */
177 EXTERN Char T_CanIns;		/* true if I can insert characters */
178 EXTERN Char T_CanDel;		/* dito for delete characters */
179 EXTERN Char T_Tabs;		/* true if tty interface is passing tabs */
180 EXTERN Char T_Margin;
181 #define MARGIN_AUTO  1		/* term has auto margins */
182 #define MARGIN_MAGIC 2		/* concept glitch */
183 EXTERN speed_t T_Speed;		/* Tty input Baud rate */
184 EXTERN Char T_CanCEOL;		/* true if we can clear to end of line */
185 EXTERN Char T_CanUP;		/* true if this term can do reverse linefeen */
186 EXTERN Char T_HasMeta;		/* true if we have a meta key */
187 
188 /* note the extra characters in the Strchr() call in this macro */
189 #define isword(c)	(Isalpha(c)||Isdigit(c)||Strchr(word_chars,c))
190 #define min(x,y)	(((x)<(y))?(x):(y))
191 #define max(x,y)	(((x)>(y))?(x):(y))
192 
193 #define MODE_INSERT	0
194 #define MODE_REPLACE	1
195 #define MODE_REPLACE_1	2
196 
197 #define EX_IO	0	/* while we are executing	*/
198 #define ED_IO	1	/* while we are editing		*/
199 #define TS_IO	2	/* new mode from terminal	*/
200 #define QU_IO	2	/* used only for quoted chars	*/
201 #define NN_IO	3	/* The number of entries	*/
202 
203 #if defined(POSIX) || defined(TERMIO)
204 # define M_INPUT	0
205 # define M_OUTPUT	1
206 # define M_CONTROL	2
207 # define M_LINED	3
208 # define M_CHAR		4
209 # define M_NN		5
210 #else /* GSTTY */
211 # define M_CONTROL	0
212 # define M_LOCAL	1
213 # define M_CHAR		2
214 # define M_NN		3
215 #endif /* TERMIO */
216 typedef struct {
217     const char *t_name;
218     unsigned int  t_setmask;
219     unsigned int  t_clrmask;
220 } ttyperm_t[NN_IO][M_NN];
221 
222 extern ttyperm_t ttylist;
223 #include "ed.term.h"
224 #include "ed.decls.h"
225 
226 #ifndef POSIX
227 /*
228  * We don't prototype these, cause some systems have them wrong!
229  */
230 extern int   tgetent	__P(());
231 extern char *tgetstr	__P(());
232 extern int   tgetflag	__P(());
233 extern int   tgetnum	__P(());
234 extern char *tgoto	__P(());
235 # define PUTPURE putpure
236 # define PUTRAW putraw
237 #else
238 extern int   tgetent	__P((char *, const char *));
239 extern char *tgetstr	__P((const char *, char **));
240 extern int   tgetflag	__P((const char *));
241 extern int   tgetnum	__P((const char *));
242 extern char *tgoto	__P((const char *, int, int));
243 extern void  tputs	__P((const char *, int, void (*)(int)));
244 # define PUTPURE ((void (*)__P((int))) putpure)
245 # define PUTRAW ((void (*)__P((int))) putraw)
246 #endif
247 
248 #endif /* _h_ed */
249