Annotation of src/usr.bin/mg/def.h, Revision 1.79
1.79 ! kjell 1: /* $OpenBSD: def.h,v 1.78 2005/11/22 05:02:44 kjell Exp $ */
1.64 kjell 2:
3: /* This file is in the public domain. */
1.30 vincent 4:
5: #include <sys/queue.h>
1.6 niklas 6:
1.1 deraadt 7: /*
8: * This file is the general header file for all parts
1.4 millert 9: * of the Mg display editor. It contains all of the
1.1 deraadt 10: * general definitions and macros. It also contains some
11: * conditional compilation flags. All of the per-system and
12: * per-terminal definitions are in special header files.
13: */
1.58 henning 14:
1.4 millert 15: #include "sysdef.h" /* Order is critical. */
1.1 deraadt 16: #include "ttydef.h"
17: #include "chrdef.h"
18:
19: #ifdef NO_MACRO
20: #ifndef NO_STARTUP
1.4 millert 21: #define NO_STARTUP /* NO_MACRO implies NO_STARTUP */
1.1 deraadt 22: #endif
23: #endif
24:
1.47 vincent 25: typedef int (*PF)(int, int); /* generally useful type */
1.1 deraadt 26:
27: /*
28: * Table sizes, etc.
29: */
1.7 art 30: #define NFILEN 1024 /* Length, file name. */
31: #define NBUFN NFILEN /* Length, buffer name. */
1.4 millert 32: #define NLINE 256 /* Length, line. */
33: #define PBMODES 4 /* modes per buffer */
34: #define NKBDM 256 /* Length, keyboard macro. */
35: #define NPAT 80 /* Length, pattern. */
36: #define HUGE 1000 /* A rather large number. */
37: #define NSRCH 128 /* Undoable search commands. */
38: #define NXNAME 64 /* Length, extended command. */
1.60 db 39: #define NKNAME 20 /* Length, key names. */
1.68 kjell 40: #define NTIME 50 /* Length, timestamp string. */
1.1 deraadt 41: /*
42: * Universal.
43: */
1.4 millert 44: #define FALSE 0 /* False, no, bad, etc. */
45: #define TRUE 1 /* True, yes, good, etc. */
46: #define ABORT 2 /* Death, ^G, abort, etc. */
1.1 deraadt 47:
1.4 millert 48: #define KPROMPT 2 /* keyboard prompt */
1.1 deraadt 49:
50: /*
51: * These flag bits keep track of
52: * some aspects of the last command. The CFCPCN
53: * flag controls goal column setting. The CFKILL
54: * flag controls the clearing versus appending
55: * of data in the kill buffer.
56: */
1.4 millert 57: #define CFCPCN 0x0001 /* Last command was C-P, C-N */
58: #define CFKILL 0x0002 /* Last command was a kill */
1.60 db 59: #define CFINS 0x0004 /* Last command was self-insert */
1.1 deraadt 60:
61: /*
62: * File I/O.
63: */
1.4 millert 64: #define FIOSUC 0 /* Success. */
65: #define FIOFNF 1 /* File not found. */
66: #define FIOEOF 2 /* End of file. */
67: #define FIOERR 3 /* Error. */
68: #define FIOLONG 4 /* long line partially read */
1.77 deraadt 69: #define FIODIR 5 /* File is a directory */
1.1 deraadt 70:
71: /*
72: * Directory I/O.
73: */
1.4 millert 74: #define DIOSUC 0 /* Success. */
75: #define DIOEOF 1 /* End of file. */
76: #define DIOERR 2 /* Error. */
1.1 deraadt 77:
78: /*
79: * Display colors.
80: */
1.4 millert 81: #define CNONE 0 /* Unknown color. */
82: #define CTEXT 1 /* Text color. */
83: #define CMODE 2 /* Mode line color. */
84:
85: /*
1.22 millert 86: * Flags for keyboard invoked functions.
1.4 millert 87: */
88: #define FFUNIV 1 /* universal argument */
1.27 deraadt 89: #define FFNEGARG 2 /* negative only argument */
1.4 millert 90: #define FFOTHARG 4 /* other argument */
91: #define FFARG 7 /* any argument */
92: #define FFRAND 8 /* Called by other function */
1.1 deraadt 93:
94: /*
95: * Flags for "eread".
96: */
1.4 millert 97: #define EFFUNC 0x0001 /* Autocomplete functions. */
98: #define EFBUF 0x0002 /* Autocomplete buffers. */
99: #define EFFILE 0x0004 /* " files (maybe someday) */
1.60 db 100: #define EFAUTO 0x0007 /* Some autocompletion on */
1.4 millert 101: #define EFNEW 0x0008 /* New prompt. */
102: #define EFCR 0x0010 /* Echo CR at end; last read. */
1.20 art 103: #define EFDEF 0x0020 /* buffer contains default args */
1.63 kjell 104: #define EFNUL 0x0040 /* Null Minibuffer OK */
1.1 deraadt 105:
106: /*
1.75 kjell 107: * Direction of insert into kill ring
1.1 deraadt 108: */
109: #define KNONE 0
110: #define KFORW 1
111: #define KBACK 2
112:
1.49 vincent 113: /*
114: * This structure holds the starting position
115: * (as a line/offset pair) and the number of characters in a
116: * region of a buffer. This makes passing the specification
117: * of a region around a little bit easier.
118: */
1.74 deraadt 119: struct region {
120: struct line *r_linep; /* Origin line address. */
121: int r_offset; /* Origin line offset. */
1.60 db 122: RSIZE r_size; /* Length in characters. */
1.74 deraadt 123: };
1.49 vincent 124:
125:
1.1 deraadt 126: /*
127: * All text is kept in circularly linked
1.75 kjell 128: * lists of "line" structures. These begin at the
1.1 deraadt 129: * header line (which is the blank line beyond the
130: * end of the buffer). This line is pointed to by
1.75 kjell 131: * the "buffer" structure. Each line contains the number of
1.1 deraadt 132: * bytes in the line (the "used" size), the size
133: * of the text array, and the text. The end of line
134: * is not stored as a byte; it's implied. Future
135: * additions will include update hints, and a
136: * list of marks into the line.
137: */
1.74 deraadt 138: struct line {
139: struct line *l_fp; /* Link to the next line */
140: struct line *l_bp; /* Link to the previous line */
1.60 db 141: int l_size; /* Allocated size */
142: int l_used; /* Used size */
143: char *l_text; /* Content of the line */
1.74 deraadt 144: };
1.1 deraadt 145:
146: /*
147: * The rationale behind these macros is that you
148: * could (with some editing, like changing the type of a line
1.75 kjell 149: * link from a "struct line *" to a "REFLINE", and fixing the commands
1.1 deraadt 150: * like file reading that break the rules) change the actual
151: * storage representation of lines to use something fancy on
152: * machines with small address spaces.
153: */
154: #define lforw(lp) ((lp)->l_fp)
155: #define lback(lp) ((lp)->l_bp)
156: #define lgetc(lp, n) (CHARMASK((lp)->l_text[(n)]))
157: #define lputc(lp, n, c) ((lp)->l_text[(n)]=(c))
158: #define llength(lp) ((lp)->l_used)
159: #define ltext(lp) ((lp)->l_text)
160:
161: /*
162: * All repeated structures are kept as linked lists of structures.
163: * All of these start with a LIST structure (except lines, which
164: * have their own abstraction). This will allow for
165: * later conversion to generic list manipulation routines should
1.60 db 166: * I decide to do that. It does mean that there are four extra
1.1 deraadt 167: * bytes per window. I feel that this is an acceptable price,
168: * considering that there are usually only one or two windows.
169: */
1.74 deraadt 170: struct list {
1.1 deraadt 171: union {
1.74 deraadt 172: struct mgwin *l_wp;
1.75 kjell 173: struct buffer *x_bp; /* l_bp is used by struct line */
1.74 deraadt 174: struct list *l_nxt;
1.1 deraadt 175: } l_p;
1.36 vincent 176: const char *l_name;
1.74 deraadt 177: };
1.4 millert 178:
1.1 deraadt 179: /*
180: * Usual hack - to keep from uglifying the code with lotsa
181: * references through the union, we #define something for it.
182: */
183: #define l_next l_p.l_nxt
184:
185: /*
186: * There is a window structure allocated for
187: * every active display window. The windows are kept in a
188: * big list, in top to bottom screen order, with the listhead at
189: * "wheadp". Each window contains its own values of dot and mark.
190: * The flag field contains some bits that are set by commands
191: * to guide redisplay; although this is a bit of a compromise in
192: * terms of decoupling, the full blown redisplay is just too
193: * expensive to run for every input character.
194: */
1.74 deraadt 195: struct mgwin {
196: struct list w_list; /* List header */
197: struct buffer *w_bufp; /* Buffer displayed in window */
198: struct line *w_linep; /* Top line in the window */
199: struct line *w_dotp; /* Line containing "." */
200: struct line *w_markp; /* Line containing "mark" */
1.60 db 201: int w_doto; /* Byte offset for "." */
202: int w_marko; /* Byte offset for "mark" */
203: char w_toprow; /* Origin 0 top row of window */
204: char w_ntrows; /* # of rows of text in window */
205: char w_force; /* If NZ, forcing row. */
206: char w_flag; /* Flags. */
1.74 deraadt 207: struct line *w_wrapline;
208: };
1.1 deraadt 209: #define w_wndp w_list.l_p.l_wp
210: #define w_name w_list.l_name
211:
212: /*
213: * Window flags are set by command processors to
214: * tell the display system what has happened to the buffer
215: * mapped by the window. Setting "WFHARD" is always a safe thing
216: * to do, but it may do more work than is necessary. Always try
217: * to set the simplest action that achieves the required update.
218: * Because commands set bits in the "w_flag", update will see
219: * all change flags, and do the most general one.
220: */
1.43 vincent 221: #define WFFORCE 0x01 /* Force reframe. */
222: #define WFMOVE 0x02 /* Movement from line to line. */
223: #define WFEDIT 0x04 /* Editing within a line. */
224: #define WFHARD 0x08 /* Better to a full display. */
225: #define WFMODE 0x10 /* Update mode line. */
1.1 deraadt 226:
1.35 vincent 227: struct undo_rec;
228:
1.1 deraadt 229: /*
230: * Text is kept in buffers. A buffer header, described
231: * below, exists for every buffer in the system. The buffers are
232: * kept in a big list, so that commands that search for a buffer by
233: * name can find the buffer header. There is a safe store for the
234: * dot and mark in the header, but this is only valid if the buffer
235: * is not being displayed (that is, if "b_nwnd" is 0). The text for
236: * the buffer is kept in a circularly linked list of lines, with
237: * a pointer to the header line in "b_linep".
238: */
1.74 deraadt 239: struct buffer {
240: struct list b_list; /* buffer list pointer */
241: struct buffer *b_altb; /* Link to alternate buffer */
1.75 kjell 242: struct line *b_dotp; /* Link to "." line structure */
1.74 deraadt 243: struct line *b_markp; /* ditto for mark */
1.75 kjell 244: struct line *b_linep; /* Link to the header line */
1.74 deraadt 245: struct maps_s *b_modes[PBMODES]; /* buffer modes */
1.75 kjell 246: int b_doto; /* Offset of "." in above line */
1.60 db 247: int b_marko; /* ditto for the "mark" */
248: short b_nmodes; /* number of non-fundamental modes */
249: char b_nwnd; /* Count of windows on buffer */
250: char b_flag; /* Flags */
251: char b_fname[NFILEN]; /* File name */
252: struct fileinfo b_fi; /* File attributes */
1.67 kjell 253: LIST_HEAD(, undo_rec) b_undo; /* Undo actions list */
1.77 deraadt 254: int b_undopos; /* Where we were during last undo */
1.67 kjell 255: struct undo_rec *b_undoptr;
1.74 deraadt 256: };
1.1 deraadt 257: #define b_bufp b_list.l_p.x_bp
258: #define b_bname b_list.l_name
259:
1.43 vincent 260: #define BFCHG 0x01 /* Changed. */
261: #define BFBAK 0x02 /* Need to make a backup. */
1.1 deraadt 262: #ifdef NOTAB
1.43 vincent 263: #define BFNOTAB 0x04 /* no tab mode */
1.1 deraadt 264: #endif
1.43 vincent 265: #define BFOVERWRITE 0x08 /* overwrite mode */
1.60 db 266: #define BFREADONLY 0x10 /* read only mode */
1.1 deraadt 267:
268: /*
1.30 vincent 269: * This structure holds information about recent actions for the Undo command.
270: */
271: struct undo_rec {
1.34 deraadt 272: LIST_ENTRY(undo_rec) next;
1.30 vincent 273: enum {
274: INSERT = 1,
275: DELETE,
276: BOUNDARY
277: } type;
1.74 deraadt 278: struct region region;
1.30 vincent 279: int pos;
1.34 deraadt 280: char *content;
1.30 vincent 281: };
282:
283: /*
1.4 millert 284: * Prototypes.
285: */
286:
1.5 millert 287: /* tty.c X */
1.74 deraadt 288: void ttinit(void);
289: void ttreinit(void);
290: void tttidy(void);
291: void ttmove(int, int);
292: void tteeol(void);
293: void tteeop(void);
294: void ttbeep(void);
295: void ttinsl(int, int, int);
296: void ttdell(int, int, int);
297: void ttwindow(int, int);
298: void ttnowindow(void);
299: void ttcolor(int);
300: void ttresize(void);
1.31 deraadt 301:
302: volatile sig_atomic_t winch_flag;
1.4 millert 303:
304: /* ttyio.c */
1.74 deraadt 305: void ttopen(void);
306: int ttraw(void);
307: void ttclose(void);
308: int ttcooked(void);
309: int ttputc(int);
310: void ttflush(void);
311: int ttgetc(void);
312: int ttwait(int);
313: int typeahead(void);
1.4 millert 314:
315: /* dir.c */
1.74 deraadt 316: void dirinit(void);
317: int changedir(int, int);
318: int showcwdir(int, int);
1.4 millert 319:
320: /* dired.c */
1.74 deraadt 321: struct buffer *dired_(char *);
1.5 millert 322:
323: /* file.c X */
1.74 deraadt 324: int fileinsert(int, int);
325: int filevisit(int, int);
326: int filevisitalt(int, int);
327: int filevisitro(int, int);
328: int poptofile(int, int);
329: struct buffer *findbuffer(char *);
330: int readin(char *);
331: int insertfile(char *, char *, int);
332: int filewrite(int, int);
333: int filesave(int, int);
334: int buffsave(struct buffer *);
335: int makebkfile(int, int);
336: int writeout(struct buffer *, char *);
337: void upmodes(struct buffer *);
1.5 millert 338:
339: /* line.c X */
1.74 deraadt 340: struct line *lalloc(int);
341: int lrealloc(struct line *, int);
342: void lfree(struct line *);
343: void lchange(int);
344: int linsert_str(const char *, int);
345: int linsert(int, int);
346: int lnewline_at(struct line *, int);
347: int lnewline(void);
348: int ldelete(RSIZE, int);
349: int ldelnewline(void);
350: int lreplace(RSIZE, char *);
1.78 kjell 351:
352: /* yank.c X */
353:
1.74 deraadt 354: void kdelete(void);
355: int kinsert(int, int);
356: int kremove(int);
1.76 kjell 357: int kchunk(char *, RSIZE, int);
1.78 kjell 358: int killline(int, int);
359: int yank(int, int);
1.5 millert 360:
361: /* window.c X */
1.74 deraadt 362: struct mgwin *new_window(struct buffer *);
363: void free_window(struct mgwin *);
364: int reposition(int, int);
365: int refresh(int, int);
366: int nextwind(int, int);
367: int prevwind(int, int);
368: int onlywind(int, int);
369: int splitwind(int, int);
370: int enlargewind(int, int);
371: int shrinkwind(int, int);
372: int delwind(int, int);
373: struct mgwin *wpopup(void);
1.4 millert 374:
375: /* buffer.c */
1.74 deraadt 376: int togglereadonly(int, int);
377: struct buffer *bfind(const char *, int);
378: int poptobuffer(int, int);
379: int killbuffer(struct buffer *);
380: int killbuffer_cmd(int, int);
381: int savebuffers(int, int);
382: int listbuffers(int, int);
383: int addlinef(struct buffer *, char *, ...);
1.12 art 384: #define addline(bp, text) addlinef(bp, "%s", text)
1.74 deraadt 385: int anycb(int);
386: int bclear(struct buffer *);
387: int showbuffer(struct buffer *, struct mgwin *, int);
388: struct mgwin *popbuf(struct buffer *);
389: int bufferinsert(int, int);
390: int usebuffer(int, int);
391: int notmodified(int, int);
392: int popbuftop(struct buffer *);
1.4 millert 393:
394: /* display.c */
1.74 deraadt 395: int vtresize(int, int, int);
396: void vtinit(void);
397: void vttidy(void);
398: void update(void);
1.5 millert 399:
400: /* echo.c X */
1.74 deraadt 401: void eerase(void);
402: int eyorn(const char *);
403: int eyesno(const char *);
404: void ewprintf(const char *fmt, ...);
405: char *ereply(const char *, char *, size_t, ...);
406: char *eread(const char *, char *, size_t, int, ...);
407: int getxtra(struct list *, struct list *, int, int);
408: void free_file_list(struct list *);
1.4 millert 409:
410: /* fileio.c */
1.74 deraadt 411: int ffropen(const char *, struct buffer *);
412: int ffwopen(const char *, struct buffer *);
413: int ffclose(struct buffer *);
414: int ffputbuf(struct buffer *);
415: int ffgetline(char *, int, int *);
416: int fbackupfile(const char *);
417: char *adjustname(const char *);
418: char *startupfile(char *);
419: int copy(char *, char *);
420: struct list *make_file_list(char *);
421: int fisdir(const char *);
1.4 millert 422:
1.5 millert 423: /* kbd.c X */
1.74 deraadt 424: int do_meta(int, int);
425: int bsmap(int, int);
426: void ungetkey(int);
427: int getkey(int);
428: int doin(void);
429: int rescan(int, int);
430: int universal_argument(int, int);
431: int digit_argument(int, int);
432: int negative_argument(int, int);
433: int selfinsert(int, int);
434: int quote(int, int);
1.4 millert 435:
436: /* main.c */
1.74 deraadt 437: int ctrlg(int, int);
438: int quit(int, int);
1.4 millert 439:
440: /* ttyio.c */
1.74 deraadt 441: void panic(char *);
1.4 millert 442:
443: /* cinfo.c */
1.74 deraadt 444: char *keyname(char *, size_t, int);
1.4 millert 445:
446: /* basic.c */
1.74 deraadt 447: int gotobol(int, int);
448: int backchar(int, int);
449: int gotoeol(int, int);
450: int forwchar(int, int);
451: int gotobob(int, int);
452: int gotoeob(int, int);
453: int forwline(int, int);
454: int backline(int, int);
455: void setgoal(void);
456: int getgoal(struct line *);
457: int forwpage(int, int);
458: int backpage(int, int);
459: int forw1page(int, int);
460: int back1page(int, int);
461: int pagenext(int, int);
462: void isetmark(void);
463: int setmark(int, int);
464: int swapmark(int, int);
465: int gotoline(int, int);
1.5 millert 466:
467: /* random.c X */
1.74 deraadt 468: int showcpos(int, int);
469: int getcolpos(void);
470: int twiddle(int, int);
471: int openline(int, int);
472: int newline(int, int);
473: int deblank(int, int);
474: int justone(int, int);
475: int delwhite(int, int);
476: int indent(int, int);
477: int forwdel(int, int);
478: int backdel(int, int);
479: int space_to_tabstop(int, int);
1.5 millert 480:
481: /* extend.c X */
1.74 deraadt 482: int insert(int, int);
483: int bindtokey(int, int);
484: int localbind(int, int);
485: int define_key(int, int);
486: int unbindtokey(int, int);
487: int localunbind(int, int);
488: int extend(int, int);
489: int evalexpr(int, int);
490: int evalbuffer(int, int);
491: int evalfile(int, int);
492: int load(const char *);
493: int excline(char *);
1.5 millert 494:
495: /* help.c X */
1.74 deraadt 496: int desckey(int, int);
497: int wallchart(int, int);
498: int help_help(int, int);
499: int apropos_command(int, int);
1.5 millert 500:
501: /* paragraph.c X */
1.74 deraadt 502: int gotobop(int, int);
503: int gotoeop(int, int);
504: int fillpara(int, int);
505: int killpara(int, int);
506: int fillword(int, int);
507: int setfillcol(int, int);
1.5 millert 508:
509: /* word.c X */
1.74 deraadt 510: int backword(int, int);
511: int forwword(int, int);
512: int upperword(int, int);
513: int lowerword(int, int);
514: int capword(int, int);
515: int delfword(int, int);
516: int delbword(int, int);
517: int inword(void);
1.5 millert 518:
519: /* region.c X */
1.74 deraadt 520: int killregion(int, int);
521: int copyregion(int, int);
522: int lowerregion(int, int);
523: int upperregion(int, int);
524: int prefixregion(int, int);
525: int setprefix(int, int);
526: int region_get_data(struct region *, char *, int);
1.79 ! kjell 527: void region_put_data(const char *, int);
1.5 millert 528:
529: /* search.c X */
1.74 deraadt 530: int forwsearch(int, int);
531: int backsearch(int, int);
532: int searchagain(int, int);
533: int forwisearch(int, int);
534: int backisearch(int, int);
535: int queryrepl(int, int);
536: int forwsrch(void);
537: int backsrch(void);
538: int readpattern(char *);
1.5 millert 539:
540: /* spawn.c X */
1.74 deraadt 541: int spawncli(int, int);
1.5 millert 542:
543: /* ttykbd.c X */
1.74 deraadt 544: void ttykeymapinit(void);
545: void ttykeymaptidy(void);
1.5 millert 546:
547: /* match.c X */
1.74 deraadt 548: int showmatch(int, int);
1.5 millert 549:
550: /* version.c X */
1.74 deraadt 551: int showversion(int, int);
1.5 millert 552:
553: #ifndef NO_MACRO
554: /* macro.c X */
1.74 deraadt 555: int definemacro(int, int);
556: int finishmacro(int, int);
557: int executemacro(int, int);
1.5 millert 558: #endif /* !NO_MACRO */
559:
560: /* modes.c X */
1.74 deraadt 561: int indentmode(int, int);
562: int fillmode(int, int);
563: int blinkparen(int, int);
1.5 millert 564: #ifdef NOTAB
1.74 deraadt 565: int notabmode(int, int);
1.5 millert 566: #endif /* NOTAB */
1.74 deraadt 567: int overwrite(int, int);
568: int set_default_mode(int,int);
1.5 millert 569:
570: #ifdef REGEX
571: /* re_search.c X */
1.74 deraadt 572: int re_forwsearch(int, int);
573: int re_backsearch(int, int);
574: int re_searchagain(int, int);
575: int re_queryrepl(int, int);
576: int replstr(int, int);
577: int setcasefold(int, int);
578: int delmatchlines(int, int);
579: int delnonmatchlines(int, int);
580: int cntmatchlines(int, int);
581: int cntnonmatchlines(int, int);
1.5 millert 582: #endif /* REGEX */
1.1 deraadt 583:
1.30 vincent 584: /* undo.c X */
1.74 deraadt 585: void free_undo_record(struct undo_rec *);
586: int undo_dump(int, int);
587: int undo_enable(int);
588: int undo_add_boundary(void);
589: int undo_add_insert(struct line *, int, int);
590: int undo_add_delete(struct line *, int, int);
591: void undo_no_boundary(int);
592: int undo_add_change(struct line *, int, int);
593: int undo(int, int);
1.41 vincent 594:
595: /* autoexec.c X */
1.74 deraadt 596: int auto_execute(int, int);
597: PF *find_autoexec(const char *);
598: int add_autoexec(const char *, const char *);
1.46 vincent 599:
600: /* mail.c X */
1.74 deraadt 601: void mail_init(void);
1.66 kjell 602:
603: /* grep.c X */
1.74 deraadt 604: int next_error(int, int);
1.30 vincent 605:
1.1 deraadt 606: /*
607: * Externals.
608: */
1.74 deraadt 609: extern struct buffer *bheadp;
610: extern struct buffer *curbp;
611: extern struct mgwin *curwp;
612: extern struct mgwin *wheadp;
613: extern int thisflag;
614: extern int lastflag;
615: extern int curgoal;
616: extern int startrow;
617: extern int epresf;
618: extern int sgarbf;
619: extern int mode;
620: extern int nrow;
621: extern int ncol;
622: extern int ttrow;
623: extern int ttcol;
624: extern int tttop;
625: extern int ttbot;
626: extern int tthue;
627: extern int defb_nmodes;
628: extern int defb_flag;
629: extern const char cinfo[];
630: extern char *keystrings[];
631: extern char pat[NPAT];
1.5 millert 632: #ifndef NO_DPROMPT
1.74 deraadt 633: extern char prompt[];
1.5 millert 634: #endif /* !NO_DPROMPT */
635:
636: /*
637: * Globals.
638: */
1.74 deraadt 639: int tceeol;
640: int tcinsl;
641: int tcdell;