diff options
-rw-r--r-- | usr.bin/mg/Makefile | 3 | ||||
-rw-r--r-- | usr.bin/mg/basic.c | 2 | ||||
-rw-r--r-- | usr.bin/mg/buffer.c | 22 | ||||
-rw-r--r-- | usr.bin/mg/def.h | 14 | ||||
-rw-r--r-- | usr.bin/mg/dir.c | 7 | ||||
-rw-r--r-- | usr.bin/mg/dired.c | 4 | ||||
-rw-r--r-- | usr.bin/mg/display.c | 28 | ||||
-rw-r--r-- | usr.bin/mg/file.c | 8 | ||||
-rw-r--r-- | usr.bin/mg/line.c | 12 | ||||
-rw-r--r-- | usr.bin/mg/main.c | 8 | ||||
-rw-r--r-- | usr.bin/mg/sysdef.h | 2 | ||||
-rw-r--r-- | usr.bin/mg/tty.c | 388 | ||||
-rw-r--r-- | usr.bin/mg/ttyio.c | 53 | ||||
-rw-r--r-- | usr.bin/mg/ttykbd.c | 82 | ||||
-rw-r--r-- | usr.bin/mg/window.c | 28 |
15 files changed, 323 insertions, 338 deletions
diff --git a/usr.bin/mg/Makefile b/usr.bin/mg/Makefile index 7bfc53659b9..17a81285ee4 100644 --- a/usr.bin/mg/Makefile +++ b/usr.bin/mg/Makefile @@ -9,6 +9,7 @@ DPADD+= ${LIBCURSES} # # DO_METAKEY -- if bit 7 is set for a key, treat like a META key # STARTUP -- look for and handle initialization file +# FKEYS -- add support for function key sequences. # XKEYS -- use termcap function key definitions. Warning - # XKEYS and bsmap mode do _not_ get along. # BACKUP -- enable "make-backup-files" @@ -16,7 +17,7 @@ DPADD+= ${LIBCURSES} # REGEX -- create regular expression functions # CDEFS = -DDO_METAKEY -CDEFS+= -DDO_METAKEY -DPREFIXREGION -DXKEYS -DBACKUP +CDEFS+= -DDO_METAKEY -DPREFIXREGION -DXKEYS -DFKEYS -DBACKUP CFLAGS+=$(CDEFS) SRCS= cinfo.c fileio.c spawn.c ttyio.c tty.c ttykbd.c \ diff --git a/usr.bin/mg/basic.c b/usr.bin/mg/basic.c index b35e1defeef..c4095800c0d 100644 --- a/usr.bin/mg/basic.c +++ b/usr.bin/mg/basic.c @@ -338,7 +338,7 @@ int f, n; */ pagenext(f, n) { - register WINDOW *wp; + register MGWIN *wp; if (wheadp->w_wndp == NULL) { ewprintf("No other window"); diff --git a/usr.bin/mg/buffer.c b/usr.bin/mg/buffer.c index b4244086bf7..6f0f920fee2 100644 --- a/usr.bin/mg/buffer.c +++ b/usr.bin/mg/buffer.c @@ -43,10 +43,10 @@ usebuffer(f, n) poptobuffer(f, n) { register BUFFER *bp; - register WINDOW *wp; + register MGWIN *wp; register int s; char bufn[NBUFN]; - WINDOW *popbuf(); + MGWIN *popbuf(); /* Get buffer to use from user */ if ((curbp->b_altb == NULL) @@ -80,7 +80,7 @@ killbuffer(f, n) register BUFFER *bp; register BUFFER *bp1; register BUFFER *bp2; - WINDOW *wp; + MGWIN *wp; register int s; char bufn[NBUFN]; @@ -160,9 +160,9 @@ savebuffers(f, n) listbuffers(f, n) { register BUFFER *bp; - register WINDOW *wp; + register MGWIN *wp; BUFFER *makelist(); - WINDOW *popbuf(); + MGWIN *popbuf(); if ((bp=makelist()) == NULL || (wp=popbuf(bp)) == NULL) return FALSE; @@ -423,9 +423,9 @@ bclear(bp) register BUFFER *bp; { * Display the given buffer in the given window. Flags indicated * action on redisplay. */ -showbuffer(bp, wp, flags) register BUFFER *bp; register WINDOW *wp; { +showbuffer(bp, wp, flags) register BUFFER *bp; register MGWIN *wp; { register BUFFER *obp; - WINDOW *owp; + MGWIN *owp; if (wp->w_bufp == bp) { /* Easy case! */ wp->w_flag |= flags; @@ -468,9 +468,9 @@ showbuffer(bp, wp, flags) register BUFFER *bp; register WINDOW *wp; { * Pop the buffer we got passed onto the screen. * Returns a status. */ -WINDOW * +MGWIN * popbuf(bp) register BUFFER *bp; { - register WINDOW *wp; + register MGWIN *wp; if (bp->b_nwnd == 0) { /* Not on screen yet. */ if ((wp=wpopup()) == NULL) return NULL; @@ -545,7 +545,7 @@ bufferinsert(f, n) /*ARGSUSED*/ notmodified(f, n) { - register WINDOW *wp; + register MGWIN *wp; curbp->b_flag &= ~BFCHG; wp = wheadp; /* Update mode lines. */ @@ -567,7 +567,7 @@ notmodified(f, n) popbuftop(bp) register BUFFER *bp; { - register WINDOW *wp; + register MGWIN *wp; bp->b_dotp = lforw(bp->b_linep); bp->b_doto = 0; diff --git a/usr.bin/mg/def.h b/usr.bin/mg/def.h index 5fc2cbedc03..bf8acb24b8b 100644 --- a/usr.bin/mg/def.h +++ b/usr.bin/mg/def.h @@ -170,7 +170,7 @@ typedef struct LINE { */ typedef struct LIST { union { - struct WINDOW *l_wp; + struct MGWIN *l_wp; struct BUFFER *x_bp; /* l_bp is used by LINE */ struct LIST *l_nxt; } l_p; @@ -192,7 +192,7 @@ typedef struct LIST { * terms of decoupling, the full blown redisplay is just too * expensive to run for every input character. */ -typedef struct WINDOW { +typedef struct MGWIN { LIST w_list; /* List header */ struct BUFFER *w_bufp; /* Buffer displayed in window */ struct LINE *w_linep; /* Top line in the window */ @@ -204,7 +204,7 @@ typedef struct WINDOW { char w_ntrows; /* # of rows of text in window */ char w_force; /* If NZ, forcing row. */ char w_flag; /* Flags. */ -} WINDOW; +} MGWIN; #define w_wndp w_list.l_p.l_wp #define w_name w_list.l_name @@ -279,14 +279,14 @@ extern int curgoal; extern int epresf; extern int sgarbf; extern int mode; -extern WINDOW *curwp; +extern MGWIN *curwp; extern BUFFER *curbp; -extern WINDOW *wheadp; +extern MGWIN *wheadp; extern BUFFER *bheadp; extern char pat[]; extern BUFFER *bfind(); -extern WINDOW *popbuf(); -extern WINDOW *wpopup(); +extern MGWIN *popbuf(); +extern MGWIN *wpopup(); extern LINE *lalloc(); extern LINE *lallocx(); extern VOID ewprintf(); diff --git a/usr.bin/mg/dir.c b/usr.bin/mg/dir.c index b8f40f973ee..d96e6552473 100644 --- a/usr.bin/mg/dir.c +++ b/usr.bin/mg/dir.c @@ -8,9 +8,6 @@ #include "def.h" #ifndef NO_DIR -#ifndef getwd /* may be a #define */ -char *getwd(); -#endif char *wdir; static char cwd[NFILEN]; @@ -19,7 +16,7 @@ static char cwd[NFILEN]; */ dirinit() { - if (!(wdir = getwd(cwd))) + if (!(wdir = getcwd(cwd, sizeof(cwd)))) panic("Can't get current directory!"); } @@ -40,7 +37,7 @@ changedir(f, n) ewprintf("Can't change dir to %s", bufc); return(FALSE); } else { - if (!(wdir = getwd(cwd))) + if (!(wdir = getcwd(cwd, sizeof(cwd)))) panic("Can't get current directory!"); ewprintf("Current directory is now %s", wdir); return(TRUE); diff --git a/usr.bin/mg/dired.c b/usr.bin/mg/dired.c index 2d3aedbbb4e..4c7ce9d3372 100644 --- a/usr.bin/mg/dired.c +++ b/usr.bin/mg/dired.c @@ -28,7 +28,7 @@ int f, n; { char dirname[NFILEN]; BUFFER *bp; - WINDOW *wp; + MGWIN *wp; dirname[0] = '\0'; if(eread("Dired other window: ", dirname, NFILEN, EFNEW | EFCR) == ABORT) @@ -112,7 +112,7 @@ int f, n; char fname[NFILEN]; register BUFFER *bp; register int s; - register WINDOW *wp; + register MGWIN *wp; BUFFER *findbuffer(); if((s = d_makename(curwp->w_dotp, fname)) == ABORT) return FALSE; diff --git a/usr.bin/mg/display.c b/usr.bin/mg/display.c index 40fd1935a19..24341c28579 100644 --- a/usr.bin/mg/display.c +++ b/usr.bin/mg/display.c @@ -28,7 +28,7 @@ #endif #ifdef STANDOUT_GLITCH -extern int SG; /* number of standout glitches */ +#include <term.h> #endif /* @@ -262,7 +262,7 @@ vteeol() { VOID update() { register LINE *lp; - register WINDOW *wp; + register MGWIN *wp; register VIDEO *vp1; VIDEO *vp2; register int i; @@ -547,16 +547,18 @@ VOID uline(row, vvp, pvp) VIDEO *vvp; VIDEO *pvp; { if (vvp->v_color != pvp->v_color) { /* Wrong color, do a */ ttmove(row, 0); /* full redraw. */ #ifdef STANDOUT_GLITCH - if (pvp->v_color != CTEXT && SG >= 0) tteeol(); + if (pvp->v_color != CTEXT && magic_cookie_glitch >= 0) + tteeol(); #endif ttcolor(vvp->v_color); #ifdef STANDOUT_GLITCH - cp1 = &vvp->v_text[SG > 0 ? SG : 0]; - /* the odd code for SG==0 is to avoid putting the invisable + cp1 = &vvp->v_text[magic_cookie_glitch > 0 ? magic_cookie_glitch : 0]; + /* the odd code for magic_cookie_glitch==0 + * is to avoid putting the invisable * glitch character on the next line. * (Hazeltine executive 80 model 30) */ - cp2 = &vvp->v_text[ncol - (SG >= 0 ? (SG!=0 ? SG : 1) : 0)]; + cp2 = &vvp->v_text[ncol - (magic_cookie_glitch >= 0 ? (magic_cookie_glitch!=0 ? magic_cookie_glitch : 1) : 0)]; #else cp1 = &vvp->v_text[0]; cp2 = &vvp->v_text[ncol]; @@ -598,10 +600,10 @@ VOID uline(row, vvp, pvp) VIDEO *vvp; VIDEO *pvp; { /* Alcyon hack */ ttmove(row, (int)(cp1-&vvp->v_text[0])); #ifdef STANDOUT_GLITCH - if (vvp->v_color != CTEXT && SG > 0) { - if(cp1 < &vvp->v_text[SG]) cp1 = &vvp->v_text[SG]; - if(cp5 > &vvp->v_text[ncol-SG]) cp5 = &vvp->v_text[ncol-SG]; - } else if (SG < 0) + if (vvp->v_color != CTEXT && magic_cookie_glitch > 0) { + if(cp1 < &vvp->v_text[magic_cookie_glitch]) cp1 = &vvp->v_text[magic_cookie_glitch]; + if(cp5 > &vvp->v_text[ncol-magic_cookie_glitch]) cp5 = &vvp->v_text[ncol-magic_cookie_glitch]; + } else if (magic_cookie_glitch < 0) #endif ttcolor(vvp->v_color); while (cp1 != cp5) { @@ -621,11 +623,11 @@ VOID uline(row, vvp, pvp) VIDEO *vvp; VIDEO *pvp; { * change the modeline format by hacking at * this routine. Called by "update" any time * there is a dirty window. - * Note that if STANDOUT_GLITCH is defined, first and last SG characters - * may never be seen. + * Note that if STANDOUT_GLITCH is defined, first and last + * magic_cookie_glitch characters may never be seen. */ VOID -modeline(wp) register WINDOW *wp; { +modeline(wp) register MGWIN *wp; { register int n; register BUFFER *bp; int mode; diff --git a/usr.bin/mg/file.c b/usr.bin/mg/file.c index f75aa6a7e3a..508b4727d25 100644 --- a/usr.bin/mg/file.c +++ b/usr.bin/mg/file.c @@ -59,7 +59,7 @@ filevisit(f, n) poptofile(f, n) { register BUFFER *bp; - register WINDOW *wp; + register MGWIN *wp; int s; char fname[NFILEN]; char *adjf; @@ -126,7 +126,7 @@ unsigned num; */ readin(fname) char *fname; { register int status; - register WINDOW *wp; + register MGWIN *wp; if (bclear(curbp) != TRUE) /* Might be old. */ return TRUE; @@ -166,7 +166,7 @@ static int linesize = 0; insertfile(fname, newname, needinfo) char fname[], newname[]; { register LINE *lp1; register LINE *lp2; - register WINDOW *wp; + register MGWIN *wp; int nbytes; LINE *olp; /* Line we started at */ int opos; /* and offset into it */ @@ -475,7 +475,7 @@ writeout(bp, fn) register BUFFER *bp; char *fn; { */ VOID upmodes(bp) register BUFFER *bp; { - register WINDOW *wp; + register MGWIN *wp; for (wp = wheadp; wp != NULL; wp = wp->w_wndp) if (bp == NULL || curwp->w_bufp == bp) wp->w_flag |= WFMODE; diff --git a/usr.bin/mg/line.c b/usr.bin/mg/line.c index 3c892c706b1..c0cad9fbda1 100644 --- a/usr.bin/mg/line.c +++ b/usr.bin/mg/line.c @@ -96,7 +96,7 @@ int used; VOID lfree(lp) register LINE *lp; { register BUFFER *bp; - register WINDOW *wp; + register MGWIN *wp; for(wp = wheadp; wp != NULL; wp = wp->w_wndp) { if (wp->w_linep == lp) @@ -139,7 +139,7 @@ lfree(lp) register LINE *lp; { */ VOID lchange(flag) register int flag; { - register WINDOW *wp; + register MGWIN *wp; if ((curbp->b_flag&BFCHG) == 0) { /* First change, so */ flag |= WFMODE; /* update mode lines. */ @@ -175,7 +175,7 @@ int n; LINE *lp3; register int doto; register RSIZE i; - WINDOW *wp; + MGWIN *wp; lchange(WFEDIT); lp1 = curwp->w_dotp; /* Current line */ @@ -267,7 +267,7 @@ lnewline() register LINE *lp2; register int doto; register int nlen; - WINDOW *wp; + MGWIN *wp; lchange(WFHARD); lp1 = curwp->w_dotp; /* Get the address and */ @@ -320,7 +320,7 @@ ldelete(n, kflag) RSIZE n; { register LINE *dotp; register int doto; register RSIZE chunk; - WINDOW *wp; + MGWIN *wp; /* * HACK - doesn't matter, and fixes back-over-nl bug for empty @@ -396,7 +396,7 @@ ldelete(n, kflag) RSIZE n; { ldelnewline() { register LINE *lp1; register LINE *lp2; - register WINDOW *wp; + register MGWIN *wp; LINE *lp3; lp1 = curwp->w_dotp; diff --git a/usr.bin/mg/main.c b/usr.bin/mg/main.c index e14fb6095f1..73271ce9b6e 100644 --- a/usr.bin/mg/main.c +++ b/usr.bin/mg/main.c @@ -10,9 +10,9 @@ int thisflag; /* Flags, this command */ int lastflag; /* Flags, last command */ int curgoal; /* Goal column */ BUFFER *curbp; /* Current buffer */ -WINDOW *curwp; /* Current window */ +MGWIN *curwp; /* Current window */ BUFFER *bheadp; /* BUFFER listhead */ -WINDOW *wheadp = (WINDOW *)NULL; /* WINDOW listhead */ +MGWIN *wheadp = (MGWIN *)NULL; /* MGWIN listhead */ char pat[NPAT]; /* Pattern */ #ifndef NO_DPROMPT extern char prompt[], *promptp; /* delayed prompting */ @@ -85,11 +85,11 @@ char **argv; static VOID edinit() { register BUFFER *bp; - register WINDOW *wp; + register MGWIN *wp; bheadp = NULL; bp = bfind("*scratch*", TRUE); /* Text buffer. */ - wp = (WINDOW *)malloc(sizeof(WINDOW)); /* Initial window. */ + wp = (MGWIN *)malloc(sizeof(MGWIN)); /* Initial window. */ if (bp==NULL || wp==NULL) panic("edinit"); curbp = bp; /* Current ones. */ wheadp = wp; diff --git a/usr.bin/mg/sysdef.h b/usr.bin/mg/sysdef.h index 50639e63566..33d112cdd47 100644 --- a/usr.bin/mg/sysdef.h +++ b/usr.bin/mg/sysdef.h @@ -1,5 +1,5 @@ /* - * System V system header file + * POSIX system header file */ #include <stdio.h> #include <unistd.h> diff --git a/usr.bin/mg/tty.c b/usr.bin/mg/tty.c index 3ec5c434629..aca60e8a3ad 100644 --- a/usr.bin/mg/tty.c +++ b/usr.bin/mg/tty.c @@ -1,8 +1,8 @@ /* - * Termcap/terminfo display driver + * Terminfo display driver * - * Termcap is a terminal information database and routines to describe - * terminals on most UNIX systems. Many other systems have adopted + * Terminfo is a terminal information database and routines to describe + * terminals on most modern UNIX systems. Many other systems have adopted * this as a reasonable way to allow for widly varying and ever changing * varieties of terminal types. This should be used where practical. */ @@ -26,7 +26,8 @@ */ #include "def.h" -#define BEL 0x07 /* BEL character. */ +#include <curses.h> +#include <term.h> extern int ttrow; extern int ttcol; @@ -34,150 +35,81 @@ extern int tttop; extern int ttbot; extern int tthue; +extern int ttputc(); + int tceeol; /* Costs are set later */ int tcinsl; int tcdell; static int insdel; /* Do we have both insert & delete line? */ +static char * scroll_fwd; /* How to scroll forward. */ #ifdef NO_RESIZE static setttysize(); #endif -char *tgetstr(); -char *tgoto(); -int ttputc(); - -#define TCAPSLEN 1024 - -char tcapbuf[TCAPSLEN]; - -/* PC, UP, and BC are used by termlib, so must be extern and have these - * names unless you have a non-standard termlib. - */ - -int LI; /* standard # lines */ -char PC, - *CM, - *CE, - *UP, - *BC, - *IM, /* insert mode */ - *IC, /* insert a single space */ - *EI, /* end insert mode */ - *DC, - *AL, /* add line */ - *DL, /* del line */ - *pAL, /* parameterized add line */ - *pDL, /* parameterized delete line */ - *TI, /* term init -- start using cursor motion */ - *TE, /* term end --- end using cursor motion */ - *SO, - *SE, - *CD, - *CS, /* set scroll region */ - *SF, /* forw index (used with scroll region) */ - *SR; /* back index (used with scroll region) */ -#ifdef XKEYS -char *KS, *KE; /* enter keypad mode, exit keypad mode */ -#endif -int SG; /* number of glitches, 0 for invisible, -1 for none */ - /* (yes virginia, there are terminals with invisible glitches) */ - /* * Initialize the terminal when the editor * gets started up. */ -static char tcbuf[1024]; - ttinit() { char *tv_stype; - char *t, *p, *tgetstr(); + char *t, *p; #ifndef gettermtype /* (avoid declaration if #define) */ char *gettermtype(); /* system dependent function to determin terminal type */ #endif - if((tv_stype = gettermtype()) == NULL) + if ((tv_stype = gettermtype()) == NULL) panic("Could not determine terminal type"); - if((tgetent(tcbuf, tv_stype)) != 1) { - (VOID) strcpy(tcbuf, "Unknown terminal type "); - (VOID) strcat(tcbuf, tv_stype); - panic(tcbuf); + if (setupterm(tv_stype, 1, NULL) == ERR) { + (void) asprintf(&p, "Unknown terminal type: %s", tv_stype); + panic(p); } - p = tcapbuf; - t = tgetstr("pc", &p); - if(t) PC = *t; - - LI = tgetnum("li"); - CD = tgetstr("cd", &p); - CM = tgetstr("cm", &p); - CE = tgetstr("ce", &p); - UP = tgetstr("up", &p); - BC = tgetstr("bc", &p); - IM = tgetstr("im", &p); - IC = tgetstr("ic", &p); - EI = tgetstr("ei", &p); - DC = tgetstr("dc", &p); - AL = tgetstr("al", &p); - DL = tgetstr("dl", &p); - pAL= tgetstr("AL", &p); /* parameterized insert and del. line */ - pDL= tgetstr("DL", &p); - TI = tgetstr("ti", &p); - TE = tgetstr("te", &p); - SO = tgetstr("so", &p); - SE = tgetstr("se", &p); - CS = tgetstr("cs", &p); /* set scrolling region */ - SF = tgetstr("sf", &p); - if(!SF || !*SF) { /* this is what GNU Emacs does */ - SF = tgetstr("do", &p); - if(!SF || !*SF) { - SF = tgetstr("nl", &p); - if(!SF || !*SF) SF = "\n"; - } + scroll_fwd = scroll_forward; + if (!scroll_fwd || !*scroll_fwd) { + /* this is what GNU Emacs does */ + scroll_fwd = parm_down_cursor; + if (!scroll_fwd || !*scroll_fwd) + scroll_fwd = "\n"; } - SR = tgetstr("sr", &p); - SG = tgetnum("sg"); /* standout glitch */ -#ifdef XKEYS - KS = tgetstr("ks", &p); /* keypad start, keypad end */ - KE = tgetstr("ke", &p); -#endif - if(CM == NULL || UP == NULL) - panic("This terminal is to stupid to run MicroGnuEmacs\n"); + if (!cursor_address || !cursor_up) + panic("This terminal is to stupid to run mg"); ttresize(); /* set nrow & ncol */ - /* watch out for empty capabilities (sure to be wrong) */ - if (CE && !*CE) CE = NULL; - if (CS && !*CS) CS = NULL; - if (SR && !*SR) SR = NULL; - if (AL && !*AL) AL = NULL; - if (DL && !*DL) DL = NULL; - if (pAL && !*pAL) pAL = NULL; - if (pDL && !*pDL) pDL = NULL; - if (CD && !*CD) CD = NULL; - - if(!CE) tceeol = ncol; - else tceeol = charcost(CE); + if (!clr_eol) + tceeol = ncol; + else + tceeol = charcost(clr_eol); /* Estimate cost of inserting a line */ - if (CS && SR) tcinsl = charcost(CS)*2 + charcost(SR); - else if (pAL) tcinsl = charcost(pAL); - else if (AL) tcinsl = charcost(AL); - else tcinsl = NROW * NCOL; /* make this cost high enough */ + if (change_scroll_region && scroll_reverse) + tcinsl = charcost(change_scroll_region)*2 + + charcost(scroll_reverse); + else if (parm_insert_line) + tcinsl = charcost(parm_insert_line); + else if (insert_line) + tcinsl = charcost(insert_line); + else + tcinsl = NROW * NCOL; /* make this cost high enough */ /* Estimate cost of deleting a line */ - if (CS) tcdell = charcost(CS)*2 + charcost(SF); - else if (pDL) tcdell = charcost(pDL); - else if (DL) tcdell = charcost(DL); - else tcdell = NROW * NCOL; /* make this cost high enough */ + if (change_scroll_region) + tcdell = charcost(change_scroll_region)*2 + + charcost(scroll_fwd); + else if (parm_delete_line) + tcdell = charcost(parm_delete_line); + else if (delete_line) + tcdell = charcost(delete_line); + else + tcdell = NROW * NCOL; /* make this cost high enough */ /* Flag to indicate that we can both insert and delete lines */ - insdel = (AL || pAL) && (DL || pDL); + insdel = (insert_line || parm_insert_line) && (delete_line || parm_delete_line); - if (p >= &tcapbuf[TCAPSLEN]) - panic("Terminal description too big!\n"); - if (TI && *TI) putpad(TI, 1); /* init the term */ + if (enter_ca_mode) + putpad(enter_ca_mode, 1); /* init the term */ } /* @@ -189,7 +121,10 @@ ttinit() { * back to what it was. */ tttidy() { - if (TE && *TE) putpad(TE, 1); /* set the term back to normal mode */ + + /* set the term back to normal mode */ + if (exit_ca_mode) + putpad(exit_ca_mode, 1); #ifdef XKEYS ttykeymaptidy(); #endif @@ -205,10 +140,10 @@ tttidy() { ttmove(row, col) { char *tgoto(); - if (ttrow!=row || ttcol!=col) { - putpad(tgoto(CM, col, row), 1); - ttrow = row; - ttcol = col; + if (ttrow != row || ttcol !=col) { + putpad(tgoto(cursor_address, col, row), 1); + ttrow = row; + ttcol = col; } } @@ -216,38 +151,44 @@ ttmove(row, col) { * Erase to end of line. */ tteeol() { - if(CE) putpad(CE, 1); - else { - register int i=ncol-ttcol; - while(i--) ttputc(' '); - ttrow = ttcol = HUGE; - } + + if (clr_eol) + putpad(clr_eol, 1); + else { + int i = ncol - ttcol; + while (i--) + ttputc(' '); + ttrow = ttcol = HUGE; + } } /* * Erase to end of page. */ tteeop() { - if(CD) putpad(CD, nrow - ttrow); - else { - putpad(CE, 1); - if (insdel) ttdell(ttrow + 1, LI, LI - ttrow - 1); - else { /* do it by hand */ - register int line; - for (line = ttrow + 1; line <= LI; ++line) { - ttmove(line, 0); - tteeol(); - } + int line; + + if (clr_eos) + putpad(clr_eos, nrow - ttrow); + else { + putpad(clr_eol, 1); + if (insdel) + ttdell(ttrow + 1, lines, lines - ttrow - 1); + else { /* do it by hand */ + for (line = ttrow + 1; line <= lines; ++line) { + ttmove(line, 0); + tteeol(); + } + } + ttrow = ttcol = HUGE; } - ttrow = ttcol = HUGE; - } } /* * Make a noise. */ ttbeep() { - ttputc(BEL); + putpad(bell, 1); ttflush(); } @@ -260,34 +201,43 @@ ttbeep() { * of insert and delete line sequences */ ttinsl(row, bot, nchunk) { - register int i, nl; + int i, nl; - if (row == bot) { /* Case of one line insert is */ - ttmove(row, 0); /* special */ - tteeol(); - return; - } - if (CS && SR) { /* Use scroll region and back index */ - nl = bot - row; - ttwindow(row,bot); - ttmove(row, 0); - while (nchunk--) putpad(SR, nl); - ttnowindow(); - return; - } else if (insdel) { - ttmove(1+bot-nchunk, 0); - nl = nrow - ttrow; - if (pDL) putpad(tgoto(pDL, 0, nchunk), nl); - else for (i=0; i<nchunk; i++) /* For all lines in the chunk */ - putpad(DL, nl); - ttmove(row, 0); - nl = nrow - ttrow; /* ttmove() changes ttrow */ - if (pAL) putpad(tgoto(pAL, 0, nchunk), nl); - else for (i=0; i<nchunk; i++) /* For all lines in the chunk */ - putpad(AL, nl); - ttrow = HUGE; - ttcol = HUGE; - } else panic("ttinsl: Can't insert/delete line"); + if (row == bot) { /* Case of one line insert is */ + ttmove(row, 0); /* special */ + tteeol(); + return; + } + if (change_scroll_region && scroll_reverse) { + /* Use scroll region and back index */ + nl = bot - row; + ttwindow(row,bot); + ttmove(row, 0); + while (nchunk--) + putpad(scroll_reverse, nl); + ttnowindow(); + return; + } else if (insdel) { + ttmove(1+bot-nchunk, 0); + nl = nrow - ttrow; + if (parm_delete_line) + putpad(tgoto(parm_delete_line, 0, nchunk), nl); + else + /* For all lines in the chunk */ + for (i=0; i<nchunk; i++) + putpad(delete_line, nl); + ttmove(row, 0); + nl = nrow - ttrow; /* ttmove() changes ttrow */ + if (parm_insert_line) + putpad(tgoto(parm_insert_line, 0, nchunk), nl); + else + /* For all lines in the chunk */ + for (i=0; i<nchunk; i++) + putpad(insert_line, nl); + ttrow = HUGE; + ttcol = HUGE; + } else + panic("ttinsl: Can't insert/delete line"); } /* @@ -300,34 +250,42 @@ ttinsl(row, bot, nchunk) { */ ttdell(row, bot, nchunk) { - register int i, nl; + int i, nl; - if (row == bot) { /* One line special case */ - ttmove(row, 0); - tteeol(); - return; - } - if (CS) { /* scrolling region */ - nl = bot - row; - ttwindow(row, bot); - ttmove(bot, 0); - while (nchunk--) putpad(SF, nl); - ttnowindow(); - } - else if(insdel) { - ttmove(row, 0); /* Else use insert/delete line */ - nl = nrow - ttrow; - if (pDL) putpad(tgoto(pDL, 0, nchunk), nl); - else for (i=0; i<nchunk; i++) /* For all lines in the chunk */ - putpad(DL, nl); - ttmove(1+bot-nchunk,0); - nl = nrow - ttrow; /* ttmove() changes ttrow */ - if (pAL) putpad(tgoto(pAL, 0, nchunk), nl); - else for (i=0; i<nchunk; i++) /* For all lines in the chunk */ - putpad(AL, nl); - ttrow = HUGE; - ttcol = HUGE; - } else panic("ttdell: Can't insert/delete line"); + if (row == bot) { /* One line special case */ + ttmove(row, 0); + tteeol(); + return; + } + if (change_scroll_region) { /* scrolling region */ + nl = bot - row; + ttwindow(row, bot); + ttmove(bot, 0); + while (nchunk--) + putpad(scroll_fwd, nl); + ttnowindow(); + } + else if (insdel) { + ttmove(row, 0); /* Else use insert/delete line */ + nl = nrow - ttrow; + if (parm_delete_line) + putpad(tgoto(parm_delete_line, 0, nchunk), nl); + else + /* For all lines in the chunk */ + for (i=0; i<nchunk; i++) + putpad(delete_line, nl); + ttmove(1+bot-nchunk,0); + nl = nrow - ttrow; /* ttmove() changes ttrow */ + if (parm_insert_line) + putpad(tgoto(parm_insert_line, 0, nchunk), nl); + else + /* For all lines in the chunk */ + for (i=0; i<nchunk; i++) + putpad(insert_line, nl); + ttrow = HUGE; + ttcol = HUGE; + } else + panic("ttdell: Can't insert/delete line"); } /* @@ -344,8 +302,8 @@ ttdell(row, bot, nchunk) */ ttwindow(top, bot) { - if (CS && (tttop!=top || ttbot!=bot)) { - putpad(tgoto(CS, bot, top), nrow - ttrow); + if (change_scroll_region && (tttop != top || ttbot != bot)) { + putpad(tgoto(change_scroll_region, bot, top), nrow - ttrow); ttrow = HUGE; /* Unknown. */ ttcol = HUGE; tttop = top; /* Remember region. */ @@ -359,19 +317,20 @@ ttwindow(top, bot) * editor, and by "display.c" when it is getting ready * to exit. This function gets to full screen scroll * by telling the terminal to set a scrolling regin - * that is LI or nrow rows high, whichever is larger. + * that is lines or nrow rows high, whichever is larger. * This behavior seems to work right on systems * where you can set your terminal size. */ ttnowindow() { - if (CS) { - putpad(tgoto(CS, (nrow > LI ? nrow : LI) - 1, 0), nrow - ttrow); - ttrow = HUGE; /* Unknown. */ - ttcol = HUGE; - tttop = HUGE; /* No scroll region. */ - ttbot = HUGE; - } + if (change_scroll_region) { + putpad(tgoto(change_scroll_region, + (nrow > lines ? nrow : lines) - 1, 0), nrow - ttrow); + ttrow = HUGE; /* Unknown. */ + ttcol = HUGE; + tttop = HUGE; /* No scroll region. */ + ttbot = HUGE; + } } /* @@ -383,15 +342,17 @@ ttnowindow() * line by line basis, so don't bother sending * out the color shift. */ -ttcolor(color) register int color; { - if (color != tthue) { - if (color == CTEXT) { /* Normal video. */ - putpad(SE, 1); - } else if (color == CMODE) { /* Reverse video. */ - putpad(SO, 1); +ttcolor(color) + int color; +{ + + if (color != tthue) { + if (color == CTEXT) /* Normal video. */ + putpad(exit_standout_mode, 1); + else if (color == CMODE) /* Reverse video. */ + putpad(enter_standout_mode, 1); + tthue = color; /* Save the color. */ } - tthue = color; /* Save the color. */ - } } /* @@ -404,6 +365,7 @@ ttcolor(color) register int color; { * see how the caller deals with a change. */ ttresize() { + setttysize(); /* found in "ttyio.c", */ /* ask OS for tty size */ if (nrow < 1) /* Check limits. */ @@ -435,8 +397,8 @@ char c; /* calculate the cost of doing string s */ charcost (s) char *s; { - cci = 0; + cci = 0; - tputs(s, nrow, fakec); - return cci; + tputs(s, nrow, fakec); + return (cci); } diff --git a/usr.bin/mg/ttyio.c b/usr.bin/mg/ttyio.c index 58f84eb4dfa..d13caf3e69f 100644 --- a/usr.bin/mg/ttyio.c +++ b/usr.bin/mg/ttyio.c @@ -1,6 +1,6 @@ /* * Name: MicroEMACS - * System V terminal I/O. + * POSIX terminal I/O. * Version: 0 * Last edit: Tue Aug 26 23:57:57 PDT 1986 * By: gonzo!daveb @@ -11,15 +11,14 @@ * keyboard characters, and write characters to * the display in a barely buffered fashion. * - * This version goes along with tty/termcap/tty.c. - * Terminal size is determined there, rather than here, and - * this does not open the termcap file + * This version goes along with the terminfo tty.c. */ #include "def.h" #include <sys/types.h> #include <fcntl.h> #include <termios.h> +#include <term.h> #define NOBUF 512 /* Output buffer size. */ @@ -77,45 +76,12 @@ ttopen() if (tcsetattr(0, TCSAFLUSH, &nt) < 0) abort(); - /* This really belongs in tty/termcap... */ - - if ((cp=getenv("TERMCAP")) == NULL - || (nrow=getvalue(cp, "li")) <= 0 - || (ncol=getvalue(cp, "co")) <= 0) { - nrow = 24; - ncol = 80; - } - if (nrow > NROW) /* Don't crash if the */ - nrow = NROW; /* termcap entry is */ - if (ncol > NCOL) /* too big. */ - ncol = NCOL; + setttysize(); ttyactivep = TRUE; } /* - * This routine scans a string, which is - * actually the return value of a getenv call for the TERMCAP - * variable, looking for numeric parameter "name". Return the value - * if found. Return -1 if not there. Assume that "name" is 2 - * characters long. This limited use of the TERMCAP lets us find - * out the size of a window on the X display. - */ -getvalue(cp, name) -register char *cp; -register char *name; -{ - for (;;) { - while (*cp!=0 && *cp!=':') - ++cp; - if (*cp++ == 0) /* Not found. */ - return (-1); - if (cp[0]==name[0] && cp[1]==name[1] && cp[2]=='#') - return (atoi(cp+3)); /* Stops on ":". */ - } -} - -/* * This function gets called just * before we go back home to the shell. Put all of * the terminal parameters back. @@ -223,14 +189,15 @@ setttysize() ncol = winsize . ws_col; } else #endif - if ((nrow=tgetnum ("li")) <= 0 - || (ncol=tgetnum ("co")) <= 0) { + if ((nrow = lines) <= 0 || (ncol = columns) <= 0) { nrow = 24; ncol = 80; } - if (nrow > NROW) /* Don't crash if the */ - nrow = NROW; /* termcap entry is */ - if (ncol > NCOL) /* too big. */ + + /* Enforce maximum screen size. */ + if (nrow > NROW) + nrow = NROW; + if (ncol > NCOL) ncol = NCOL; } diff --git a/usr.bin/mg/ttykbd.c b/usr.bin/mg/ttykbd.c index 13c0198a080..08c87f33573 100644 --- a/usr.bin/mg/ttykbd.c +++ b/usr.bin/mg/ttykbd.c @@ -1,12 +1,16 @@ /* * Name: MG 2a - * Termcap keyboard driver using key files + * Terminfo keyboard driver using key files * Created: 22-Nov-1987 Mic Kaczmarczik (mic@emx.cc.utexas.edu) */ #include "def.h" +#include "kbd.h" #ifdef XKEYS +#include <term.h> +#ifdef FKEYS +#include "key.h" /* * Get keyboard character. Very simple if you use keymaps and keys files. * Bob was right -- the old XKEYS code is not the right solution. @@ -14,31 +18,84 @@ * extend.c. */ -#ifdef FKEYS char *keystrings[] = { NULL } ; + +int +dobindkey(str, func) + char *str; + char *func; +{ + int i; + extern int bindkey(); /* XXX */ + + for (i = 0; *str && i < MAXKEY; i++) { + /* XXX - how to convert numbers? */ + if (*str != '\\') + key.k_chars[i] = *str; + else { + switch(*++str) { + case 't': case 'T': + key.k_chars[i] = '\t'; + break; + case 'n': case 'N': + key.k_chars[i] = '\n'; + break; + case 'r': case 'R': + key.k_chars[i] = '\r'; + break; + case 'e': case 'E': + key.k_chars[i] = CCHR('['); + break; + } + } + str++; + } + key.k_count = i; + return(bindkey(&map_table[0].p_map, func, key.k_chars, key.k_count)); +} #endif /* - * Turn on function keys using KS, then load a keys file, if available. - * The keys file is located in the same manner as the startup file is, - * depending on what startupfile() does on your system. + * Turn on function keys using keypad_xmit, then load a keys file, if + * available. The keys file is located in the same manner as the startup + * file is, depending on what startupfile() does on your system. */ extern int ttputc(); ttykeymapinit() { - extern char *KS; + char *cp; +#ifdef FKEYS + /* Bind keypad function keys. */ + if (key_left) + dobindkey(key_left, "backward-char"); + if (key_left) + dobindkey(key_left, "backward-char"); + if (key_right) + dobindkey(key_right, "forward-char"); + if (key_up) + dobindkey(key_up, "previous-line"); + if (key_down) + dobindkey(key_down, "next-line"); + if (key_beg) + dobindkey(key_beg, "beginning-of-line"); + if (key_end) + dobindkey(key_end, "end-of-line"); + if (key_npage) + dobindkey(key_npage, "scroll-up"); + if (key_ppage) + dobindkey(key_ppage, "scroll-down"); +#endif #ifndef NO_STARTUP - char *cp, *startupfile(); - if (cp = gettermtype()) { + extern char *startupfile(); if (((cp = startupfile(cp)) != NULL) && (load(cp) != TRUE)) ewprintf("Error reading key initialization file"); } #endif - if (KS && *KS) /* turn on keypad */ - putpad(KS, 1); + if (keypad_xmit) /* turn on keypad */ + putpad(keypad_xmit, 1); } /* @@ -46,10 +103,9 @@ ttykeymapinit() */ ttykeymaptidy() { - extern char *KE; - if (KE && *KE) - putpad(KE, 1); /* turn off keypad */ + if (keypad_local) + putpad(keypad_local, 1); /* turn off keypad */ } #endif diff --git a/usr.bin/mg/window.c b/usr.bin/mg/window.c index 25f6009ade6..18e944fcd0c 100644 --- a/usr.bin/mg/window.c +++ b/usr.bin/mg/window.c @@ -44,7 +44,7 @@ reposition(f, n) /*ARGSUSED*/ refresh(f, n) { - register WINDOW *wp; + register MGWIN *wp; register int oldnrow; register int oldncol; @@ -79,7 +79,7 @@ refresh(f, n) /*ARGSUSED*/ nextwind(f, n) { - register WINDOW *wp; + register MGWIN *wp; if ((wp=curwp->w_wndp) == NULL) wp = wheadp; @@ -100,8 +100,8 @@ nextwind(f, n) /*ARGSUSED*/ prevwind(f, n) { - register WINDOW *wp1; - register WINDOW *wp2; + register MGWIN *wp1; + register MGWIN *wp2; wp1 = wheadp; wp2 = curwp; @@ -129,7 +129,7 @@ prevwind(f, n) /*ARGSUSED*/ onlywind(f, n) { - register WINDOW *wp; + register MGWIN *wp; register LINE *lp; register int i; @@ -178,19 +178,19 @@ onlywind(f, n) /*ARGSUSED*/ splitwind(f, n) { - register WINDOW *wp; + register MGWIN *wp; register LINE *lp; register int ntru; register int ntrd; int ntrl; - WINDOW *wp1, *wp2; + MGWIN *wp1, *wp2; if (curwp->w_ntrows < 3) { ewprintf("Cannot split a %d line window", curwp->w_ntrows); return (FALSE); } - if ((wp = (WINDOW *)malloc(sizeof(WINDOW))) == NULL) { - ewprintf("Can't get %d", sizeof(WINDOW)); + if ((wp = (MGWIN *)malloc(sizeof(MGWIN))) == NULL) { + ewprintf("Can't get %d", sizeof(MGWIN)); return (FALSE); } ++curbp->b_nwnd; /* Displayed twice. */ @@ -256,7 +256,7 @@ splitwind(f, n) /*ARGSUSED*/ enlargewind(f, n) { - register WINDOW *adjwp; + register MGWIN *adjwp; register LINE *lp; register int i; @@ -303,7 +303,7 @@ enlargewind(f, n) */ shrinkwind(f, n) { - register WINDOW *adjwp; + register MGWIN *adjwp; register LINE *lp; register int i; @@ -353,7 +353,7 @@ shrinkwind(f, n) /*ARGSUSED*/ delwind(f, n) { - register WINDOW *wp, *nwp; + register MGWIN *wp, *nwp; wp = curwp; /* Cheap... */ /* shrinkwind returning false means only one window... */ @@ -385,9 +385,9 @@ delwind(f, n) * might be better. Return a pointer, or * NULL on error. */ -WINDOW * +MGWIN * wpopup() { - register WINDOW *wp; + register MGWIN *wp; if (wheadp->w_wndp == NULL && splitwind(FFRAND, 0) == FALSE) |