diff options
Diffstat (limited to 'sys/dev/wscons')
-rw-r--r-- | sys/dev/wscons/wsemul_dumb.c | 4 | ||||
-rw-r--r-- | sys/dev/wscons/wsemul_sun.c | 201 | ||||
-rw-r--r-- | sys/dev/wscons/wsemul_vt100.c | 338 | ||||
-rw-r--r-- | sys/dev/wscons/wsemul_vt100_chars.c | 11 | ||||
-rw-r--r-- | sys/dev/wscons/wsemul_vt100_keys.c | 7 | ||||
-rw-r--r-- | sys/dev/wscons/wsemul_vt100_subr.c | 167 | ||||
-rw-r--r-- | sys/dev/wscons/wsemul_vt100var.h | 22 | ||||
-rw-r--r-- | sys/dev/wscons/wsemulvar.h | 6 |
8 files changed, 319 insertions, 437 deletions
diff --git a/sys/dev/wscons/wsemul_dumb.c b/sys/dev/wscons/wsemul_dumb.c index 7ed932d355b..5a53b095323 100644 --- a/sys/dev/wscons/wsemul_dumb.c +++ b/sys/dev/wscons/wsemul_dumb.c @@ -1,4 +1,4 @@ -/* $OpenBSD: wsemul_dumb.c,v 1.6 2007/11/26 16:56:42 miod Exp $ */ +/* $OpenBSD: wsemul_dumb.c,v 1.7 2007/11/27 16:37:27 miod Exp $ */ /* $NetBSD: wsemul_dumb.c,v 1.7 2000/01/05 11:19:36 drochner Exp $ */ /* @@ -220,7 +220,7 @@ wsemul_dumb_output(cookie, data, count, kernel) edp->nrows - n, n, edp->defattr); edp->crow -= n - 1; break; - } + } } /* XXX */ (*edp->emulops->cursor)(edp->emulcookie, 1, edp->crow, edp->ccol); diff --git a/sys/dev/wscons/wsemul_sun.c b/sys/dev/wscons/wsemul_sun.c index 814d10eac4b..691921cf71f 100644 --- a/sys/dev/wscons/wsemul_sun.c +++ b/sys/dev/wscons/wsemul_sun.c @@ -1,4 +1,4 @@ -/* $OpenBSD: wsemul_sun.c,v 1.22 2007/11/26 16:56:42 miod Exp $ */ +/* $OpenBSD: wsemul_sun.c,v 1.23 2007/11/27 16:37:27 miod Exp $ */ /* $NetBSD: wsemul_sun.c,v 1.11 2000/01/05 11:19:36 drochner Exp $ */ /* @@ -101,17 +101,19 @@ struct wsemul_sun_emuldata { #endif }; -void wsemul_sun_init(struct wsemul_sun_emuldata *, - const struct wsscreen_descr *, void *, int, int, long); -void wsemul_sun_reset(struct wsemul_sun_emuldata *); -void wsemul_sun_output_lowchars(struct wsemul_sun_emuldata *, u_char, int); -void wsemul_sun_output_normal(struct wsemul_sun_emuldata *, u_char, int); -u_int wsemul_sun_output_haveesc(struct wsemul_sun_emuldata *, u_char); -u_int wsemul_sun_output_control(struct wsemul_sun_emuldata *, u_char); -void wsemul_sun_control(struct wsemul_sun_emuldata *, u_char); -int wsemul_sun_selectattribute(struct wsemul_sun_emuldata *, int, int, int, - long *, long *); -void wsemul_sun_scrollup(struct wsemul_sun_emuldata *, u_int); +void wsemul_sun_init(struct wsemul_sun_emuldata *, + const struct wsscreen_descr *, void *, int, int, long); +void wsemul_sun_jump_scroll(struct wsemul_sun_emuldata *, const u_char *, + u_int, int); +void wsemul_sun_reset(struct wsemul_sun_emuldata *); +void wsemul_sun_output_lowchars(struct wsemul_sun_emuldata *, u_char, int); +void wsemul_sun_output_normal(struct wsemul_sun_emuldata *, u_char, int); +u_int wsemul_sun_output_haveesc(struct wsemul_sun_emuldata *, u_char); +u_int wsemul_sun_output_control(struct wsemul_sun_emuldata *, u_char); +void wsemul_sun_control(struct wsemul_sun_emuldata *, u_char); +int wsemul_sun_selectattribute(struct wsemul_sun_emuldata *, int, int, int, + long *, long *); +void wsemul_sun_scrollup(struct wsemul_sun_emuldata *, u_int); struct wsemul_sun_emuldata wsemul_sun_console_emuldata; @@ -123,12 +125,9 @@ struct wsemul_sun_emuldata wsemul_sun_console_emuldata; #define ROWS_LEFT (edp->nrows - 1 - edp->crow) void -wsemul_sun_init(edp, type, cookie, ccol, crow, defattr) - struct wsemul_sun_emuldata *edp; - const struct wsscreen_descr *type; - void *cookie; - int ccol, crow; - long defattr; +wsemul_sun_init(struct wsemul_sun_emuldata *edp, + const struct wsscreen_descr *type, void *cookie, int ccol, int crow, + long defattr) { edp->emulops = type->textops; edp->emulcookie = cookie; @@ -141,8 +140,7 @@ wsemul_sun_init(edp, type, cookie, ccol, crow, defattr) } void -wsemul_sun_reset(edp) - struct wsemul_sun_emuldata *edp; +wsemul_sun_reset(struct wsemul_sun_emuldata *edp) { edp->state = SUN_EMUL_STATE_NORMAL; edp->bkgdattr = edp->curattr = edp->defattr; @@ -153,11 +151,8 @@ wsemul_sun_reset(edp) } void * -wsemul_sun_cnattach(type, cookie, ccol, crow, defattr) - const struct wsscreen_descr *type; - void *cookie; - int ccol, crow; - long defattr; +wsemul_sun_cnattach(const struct wsscreen_descr *type, void *cookie, int ccol, + int crow, long defattr) { struct wsemul_sun_emuldata *edp; int res; @@ -200,13 +195,8 @@ wsemul_sun_cnattach(type, cookie, ccol, crow, defattr) } void * -wsemul_sun_attach(console, type, cookie, ccol, crow, cbcookie, defattr) - int console; - const struct wsscreen_descr *type; - void *cookie; - int ccol, crow; - void *cbcookie; - long defattr; +wsemul_sun_attach(int console, const struct wsscreen_descr *type, void *cookie, + int ccol, int crow, void *cbcookie, long defattr) { struct wsemul_sun_emuldata *edp; @@ -233,10 +223,8 @@ wsemul_sun_attach(console, type, cookie, ccol, crow, cbcookie, defattr) } void -wsemul_sun_output_lowchars(edp, c, kernel) - struct wsemul_sun_emuldata *edp; - u_char c; - int kernel; +wsemul_sun_output_lowchars(struct wsemul_sun_emuldata *edp, u_char c, + int kernel) { u_int n; @@ -301,10 +289,7 @@ wsemul_sun_output_lowchars(edp, c, kernel) } void -wsemul_sun_output_normal(edp, c, kernel) - struct wsemul_sun_emuldata *edp; - u_char c; - int kernel; +wsemul_sun_output_normal(struct wsemul_sun_emuldata *edp, u_char c, int kernel) { (*edp->emulops->putchar)(edp->emulcookie, edp->crow, edp->ccol, @@ -321,9 +306,7 @@ wsemul_sun_output_normal(edp, c, kernel) } u_int -wsemul_sun_output_haveesc(edp, c) - struct wsemul_sun_emuldata *edp; - u_char c; +wsemul_sun_output_haveesc(struct wsemul_sun_emuldata *edp, u_char c) { u_int newstate; @@ -346,9 +329,7 @@ wsemul_sun_output_haveesc(edp, c) } void -wsemul_sun_control(edp, c) - struct wsemul_sun_emuldata *edp; - u_char c; +wsemul_sun_control(struct wsemul_sun_emuldata *edp, u_char c) { u_int n, src, dst; int flags, fgcol, bgcol; @@ -523,9 +504,7 @@ setattr: } u_int -wsemul_sun_output_control(edp, c) - struct wsemul_sun_emuldata *edp; - u_char c; +wsemul_sun_output_control(struct wsemul_sun_emuldata *edp, u_char c) { u_int newstate = SUN_EMUL_STATE_CONTROL; @@ -561,19 +540,10 @@ wsemul_sun_output_control(edp, c) } void -wsemul_sun_output(cookie, data, count, kernel) - void *cookie; - const u_char *data; - u_int count; - int kernel; +wsemul_sun_output(void *cookie, const u_char *data, u_int count, int kernel) { struct wsemul_sun_emuldata *edp = cookie; u_int newstate; -#ifdef JUMP_SCROLL - const u_char *eot; - u_char curchar; - u_int cnt, pos, lines; -#endif #ifdef DIAGNOSTIC if (kernel && !edp->console) @@ -591,46 +561,8 @@ wsemul_sun_output(cookie, data, count, kernel) * appears. */ if ((edp->state == SUN_EMUL_STATE_NORMAL || kernel) && - ROWS_LEFT == 0 && edp->scrolldist != 0) { - lines = 0; - pos = edp->ccol; - for (eot = data, cnt = count; cnt != 0; eot++, cnt--) { - curchar = *eot; - if (curchar == ASCII_FF || - curchar == ASCII_VT || curchar == ASCII_ESC) - break; - - switch (curchar) { - case ASCII_BS: - if (pos > 0) - pos--; - break; - case ASCII_CR: - pos = 0; - break; - case ASCII_HT: - pos = (pos + 7) & ~7; - if (pos >= edp->ncols) - pos = edp->ncols - 1; - break; - default: - if (++pos >= edp->ncols) { - pos = 0; - curchar = ASCII_LF; - } - break; - } - if (curchar == ASCII_LF) { - if (++lines >= edp->nrows - 1) - break; - } - } - - if (lines > 1) { - wsemul_sun_scrollup(edp, lines); - edp->crow--; - } - } + ROWS_LEFT == 0 && edp->scrolldist != 0) + wsemul_sun_jump_scroll(edp, data, count, kernel); #endif if (*data < ' ') { @@ -669,16 +601,62 @@ wsemul_sun_output(cookie, data, count, kernel) (*edp->emulops->cursor)(edp->emulcookie, 1, edp->crow, edp->ccol); } +#ifdef JUMP_SCROLL +void +wsemul_sun_jump_scroll(struct wsemul_sun_emuldata *edp, const u_char *data, + u_int count, int kernel) +{ + u_char curchar; + u_int pos, lines; + + lines = 0; + pos = edp->ccol; + for (; count != 0; data++, count--) { + curchar = *data; + if (curchar == ASCII_FF || + curchar == ASCII_VT || curchar == ASCII_ESC) + break; + + switch (curchar) { + case ASCII_BS: + if (pos > 0) + pos--; + break; + case ASCII_CR: + pos = 0; + break; + case ASCII_HT: + pos = (pos + 7) & ~7; + if (pos >= edp->ncols) + pos = edp->ncols - 1; + break; + default: + if (++pos >= edp->ncols) { + pos = 0; + curchar = ASCII_LF; + } + break; + } + if (curchar == ASCII_LF) { + if (++lines >= edp->nrows - 1) + break; + } + } + + if (lines > 1) { + wsemul_sun_scrollup(edp, lines); + edp->crow--; + } +} +#endif /* * Get an attribute from the graphics driver. * Try to find replacements if the desired appearance is not supported. */ int -wsemul_sun_selectattribute(edp, flags, fgcol, bgcol, attr, bkgdattr) - struct wsemul_sun_emuldata *edp; - int flags, fgcol, bgcol; - long *attr, *bkgdattr; +wsemul_sun_selectattribute(struct wsemul_sun_emuldata *edp, int flags, + int fgcol, int bgcol, long *attr, long *bkgdattr) { int error; @@ -769,10 +747,7 @@ static const char *sun_lkeys[] = { }; int -wsemul_sun_translate(cookie, in, out) - void *cookie; - keysym_t in; - const char **out; +wsemul_sun_translate(void *cookie, keysym_t in, const char **out) { static char c; @@ -845,9 +820,7 @@ wsemul_sun_translate(cookie, in, out) } void -wsemul_sun_detach(cookie, crowp, ccolp) - void *cookie; - u_int *crowp, *ccolp; +wsemul_sun_detach(void *cookie, u_int *crowp, u_int *ccolp) { struct wsemul_sun_emuldata *edp = cookie; @@ -858,9 +831,7 @@ wsemul_sun_detach(cookie, crowp, ccolp) } void -wsemul_sun_resetop(cookie, op) - void *cookie; - enum wsemul_resetops op; +wsemul_sun_resetop(void *cookie, enum wsemul_resetops op) { struct wsemul_sun_emuldata *edp = cookie; @@ -884,9 +855,7 @@ wsemul_sun_resetop(cookie, op) } void -wsemul_sun_scrollup(edp, lines) - struct wsemul_sun_emuldata *edp; - u_int lines; +wsemul_sun_scrollup(struct wsemul_sun_emuldata *edp, u_int lines) { /* * if we're in wrap-around mode, go to the first diff --git a/sys/dev/wscons/wsemul_vt100.c b/sys/dev/wscons/wsemul_vt100.c index 4ee96d99a59..08e563290b1 100644 --- a/sys/dev/wscons/wsemul_vt100.c +++ b/sys/dev/wscons/wsemul_vt100.c @@ -1,4 +1,4 @@ -/* $OpenBSD: wsemul_vt100.c,v 1.21 2007/11/25 19:11:43 miod Exp $ */ +/* $OpenBSD: wsemul_vt100.c,v 1.22 2007/11/27 16:37:27 miod Exp $ */ /* $NetBSD: wsemul_vt100.c,v 1.13 2000/04/28 21:56:16 mycroft Exp $ */ /* @@ -64,29 +64,27 @@ const struct wsemul_ops wsemul_vt100_ops = { struct wsemul_vt100_emuldata wsemul_vt100_console_emuldata; -void wsemul_vt100_init(struct wsemul_vt100_emuldata *, - const struct wsscreen_descr *, void *, int, int, - long); - -void wsemul_vt100_output_normal(struct wsemul_vt100_emuldata *, u_char, - int); -void wsemul_vt100_output_c0c1(struct wsemul_vt100_emuldata *, u_char, - int); -void wsemul_vt100_nextline(struct wsemul_vt100_emuldata *); +void wsemul_vt100_init(struct wsemul_vt100_emuldata *, + const struct wsscreen_descr *, void *, int, int, long); +void wsemul_vt100_jump_scroll(struct wsemul_vt100_emuldata *, + const u_char *, u_int, int); +void wsemul_vt100_output_normal(struct wsemul_vt100_emuldata *, u_char, int); +void wsemul_vt100_output_c0c1(struct wsemul_vt100_emuldata *, u_char, int); +void wsemul_vt100_nextline(struct wsemul_vt100_emuldata *); typedef u_int vt100_handler(struct wsemul_vt100_emuldata *, u_char); vt100_handler -wsemul_vt100_output_esc, -wsemul_vt100_output_csi, -wsemul_vt100_output_scs94, -wsemul_vt100_output_scs94_percent, -wsemul_vt100_output_scs96, -wsemul_vt100_output_scs96_percent, -wsemul_vt100_output_esc_hash, -wsemul_vt100_output_esc_spc, -wsemul_vt100_output_string, -wsemul_vt100_output_string_esc, -wsemul_vt100_output_dcs, -wsemul_vt100_output_dcs_dollar; + wsemul_vt100_output_esc, + wsemul_vt100_output_csi, + wsemul_vt100_output_scs94, + wsemul_vt100_output_scs94_percent, + wsemul_vt100_output_scs96, + wsemul_vt100_output_scs96_percent, + wsemul_vt100_output_esc_hash, + wsemul_vt100_output_esc_spc, + wsemul_vt100_output_string, + wsemul_vt100_output_string_esc, + wsemul_vt100_output_dcs, + wsemul_vt100_output_dcs_dollar; #define VT100_EMUL_STATE_NORMAL 0 /* normal processing */ #define VT100_EMUL_STATE_ESC 1 /* got ESC */ @@ -118,12 +116,9 @@ vt100_handler *vt100_output[] = { }; void -wsemul_vt100_init(edp, type, cookie, ccol, crow, defattr) - struct wsemul_vt100_emuldata *edp; - const struct wsscreen_descr *type; - void *cookie; - int ccol, crow; - long defattr; +wsemul_vt100_init(struct wsemul_vt100_emuldata *edp, + const struct wsscreen_descr *type, void *cookie, int ccol, int crow, + long defattr) { edp->emulops = type->textops; edp->emulcookie = cookie; @@ -136,11 +131,8 @@ wsemul_vt100_init(edp, type, cookie, ccol, crow, defattr) } void * -wsemul_vt100_cnattach(type, cookie, ccol, crow, defattr) - const struct wsscreen_descr *type; - void *cookie; - int ccol, crow; - long defattr; +wsemul_vt100_cnattach(const struct wsscreen_descr *type, void *cookie, int ccol, + int crow, long defattr) { struct wsemul_vt100_emuldata *edp; int res; @@ -166,13 +158,11 @@ wsemul_vt100_cnattach(type, cookie, ccol, crow, defattr) #endif if (type->capabilities & WSSCREEN_WSCOLORS) res = (*edp->emulops->alloc_attr)(cookie, - WS_KERNEL_FG, WS_KERNEL_BG, - WS_KERNEL_COLATTR | WSATTR_WSCOLORS, - &edp->kernattr); + WS_KERNEL_FG, WS_KERNEL_BG, + WS_KERNEL_COLATTR | WSATTR_WSCOLORS, &edp->kernattr); else res = (*edp->emulops->alloc_attr)(cookie, 0, 0, - WS_KERNEL_MONOATTR, - &edp->kernattr); + WS_KERNEL_MONOATTR, &edp->kernattr); if (res) edp->kernattr = defattr; @@ -187,13 +177,8 @@ wsemul_vt100_cnattach(type, cookie, ccol, crow, defattr) } void * -wsemul_vt100_attach(console, type, cookie, ccol, crow, cbcookie, defattr) - int console; - const struct wsscreen_descr *type; - void *cookie; - int ccol, crow; - void *cbcookie; - long defattr; +wsemul_vt100_attach(int console, const struct wsscreen_descr *type, + void *cookie, int ccol, int crow, void *cbcookie, long defattr) { struct wsemul_vt100_emuldata *edp; @@ -227,9 +212,7 @@ wsemul_vt100_attach(console, type, cookie, ccol, crow, cbcookie, defattr) } void -wsemul_vt100_detach(cookie, crowp, ccolp) - void *cookie; - u_int *crowp, *ccolp; +wsemul_vt100_detach(void *cookie, u_int *crowp, u_int *ccolp) { struct wsemul_vt100_emuldata *edp = cookie; @@ -249,9 +232,7 @@ wsemul_vt100_detach(cookie, crowp, ccolp) } void -wsemul_vt100_resetop(cookie, op) - void *cookie; - enum wsemul_resetops op; +wsemul_vt100_resetop(void *cookie, enum wsemul_resetops op) { struct wsemul_vt100_emuldata *edp = cookie; @@ -266,7 +247,7 @@ wsemul_vt100_resetop(cookie, op) wsemul_vt100_ed(edp, 2); edp->ccol = edp->crow = 0; (*edp->emulops->cursor)(edp->emulcookie, - edp->flags & VTFL_CURSORON, 0, 0); + edp->flags & VTFL_CURSORON, 0, 0); break; case WSEMUL_CLEARCURSOR: (*edp->emulops->cursor)(edp->emulcookie, 0, @@ -278,8 +259,7 @@ wsemul_vt100_resetop(cookie, op) } void -wsemul_vt100_reset(edp) - struct wsemul_vt100_emuldata *edp; +wsemul_vt100_reset(struct wsemul_vt100_emuldata *edp) { int i; @@ -324,17 +304,15 @@ wsemul_vt100_nextline(struct wsemul_vt100_emuldata *edp) edp->crow++; CHECK_DW; } -} +} /* * now all the state machine bits */ void -wsemul_vt100_output_normal(edp, c, kernel) - struct wsemul_vt100_emuldata *edp; - u_char c; - int kernel; +wsemul_vt100_output_normal(struct wsemul_vt100_emuldata *edp, u_char c, + int kernel) { u_int *ct, dc; @@ -361,8 +339,7 @@ wsemul_vt100_output_normal(edp, c, kernel) COPYCOLS(edp->ccol, edp->ccol + 1, COLS_LEFT); (*edp->emulops->putchar)(edp->emulcookie, edp->crow, - edp->ccol << edp->dw, dc, - kernel ? edp->kernattr : edp->curattr); + edp->ccol << edp->dw, dc, kernel ? edp->kernattr : edp->curattr); if (COLS_LEFT) edp->ccol++; @@ -371,10 +348,8 @@ wsemul_vt100_output_normal(edp, c, kernel) } void -wsemul_vt100_output_c0c1(edp, c, kernel) - struct wsemul_vt100_emuldata *edp; - u_char c; - int kernel; +wsemul_vt100_output_c0c1(struct wsemul_vt100_emuldata *edp, u_char c, + int kernel) { u_int n; @@ -457,9 +432,7 @@ wsemul_vt100_output_c0c1(edp, c, kernel) } u_int -wsemul_vt100_output_esc(edp, c) - struct wsemul_vt100_emuldata *edp; - u_char c; +wsemul_vt100_output_esc(struct wsemul_vt100_emuldata *edp, u_char c) { u_int newstate = VT100_EMUL_STATE_NORMAL; int i; @@ -577,7 +550,7 @@ wsemul_vt100_output_esc(edp, c) break; case '<': /* exit VT52 mode - ignored */ break; - default: + default: #ifdef VT100_PRINTUNKNOWN printf("ESC%c unknown\n", c); #endif @@ -588,9 +561,7 @@ wsemul_vt100_output_esc(edp, c) } u_int -wsemul_vt100_output_scs94(edp, c) - struct wsemul_vt100_emuldata *edp; - u_char c; +wsemul_vt100_output_scs94(struct wsemul_vt100_emuldata *edp, u_char c) { u_int newstate = VT100_EMUL_STATE_NORMAL; @@ -614,7 +585,7 @@ wsemul_vt100_output_scs94(edp, c) case '>': /* DEC tech */ edp->chartab_G[edp->designating] = edp->dectechtab; break; - default: + default: #ifdef VT100_PRINTUNKNOWN printf("ESC%c%c unknown\n", edp->designating + '(', c); #endif @@ -624,16 +595,14 @@ wsemul_vt100_output_scs94(edp, c) } u_int -wsemul_vt100_output_scs94_percent(edp, c) - struct wsemul_vt100_emuldata *edp; - u_char c; +wsemul_vt100_output_scs94_percent(struct wsemul_vt100_emuldata *edp, u_char c) { switch (c) { case '5': /* DEC supplemental graphic */ /* XXX there are differences */ edp->chartab_G[edp->designating] = edp->isolatin1tab; break; - default: + default: #ifdef VT100_PRINTUNKNOWN printf("ESC%c%%%c unknown\n", edp->designating + '(', c); #endif @@ -643,15 +612,13 @@ wsemul_vt100_output_scs94_percent(edp, c) } u_int -wsemul_vt100_output_scs96(edp, c) - struct wsemul_vt100_emuldata *edp; - u_char c; +wsemul_vt100_output_scs96(struct wsemul_vt100_emuldata *edp, u_char c) { u_int newstate = VT100_EMUL_STATE_NORMAL; int nrc; switch (c) { - case '%': /* probably portugese */ + case '%': /* probably portuguese */ newstate = VT100_EMUL_STATE_SCS96_PERCENT; break; case 'A': /* ISO-latin-1 supplemental */ @@ -690,7 +657,7 @@ setnrc: if (vt100_setnrc(edp, nrc) == 0) /* what table ??? */ break; /* else FALLTHROUGH */ - default: + default: #ifdef VT100_PRINTUNKNOWN printf("ESC%c%c unknown\n", edp->designating + '-' - 1, c); #endif @@ -700,16 +667,14 @@ setnrc: } u_int -wsemul_vt100_output_scs96_percent(edp, c) - struct wsemul_vt100_emuldata *edp; - u_char c; +wsemul_vt100_output_scs96_percent(struct wsemul_vt100_emuldata *edp, u_char c) { switch (c) { - case '6': /* portugese */ + case '6': /* portuguese */ if (vt100_setnrc(edp, 8) == 0) break; /* else FALLTHROUGH */ - default: + default: #ifdef VT100_PRINTUNKNOWN printf("ESC%c%%%c unknown\n", edp->designating + '-' - 1, c); #endif @@ -719,9 +684,7 @@ wsemul_vt100_output_scs96_percent(edp, c) } u_int -wsemul_vt100_output_esc_spc(edp, c) - struct wsemul_vt100_emuldata *edp; - u_char c; +wsemul_vt100_output_esc_spc(struct wsemul_vt100_emuldata *edp, u_char c) { switch (c) { case 'F': /* 7-bit controls */ @@ -730,7 +693,7 @@ wsemul_vt100_output_esc_spc(edp, c) printf("ESC<SPC>%c ignored\n", c); #endif break; - default: + default: #ifdef VT100_PRINTUNKNOWN printf("ESC<SPC>%c unknown\n", c); #endif @@ -740,9 +703,7 @@ wsemul_vt100_output_esc_spc(edp, c) } u_int -wsemul_vt100_output_string(edp, c) - struct wsemul_vt100_emuldata *edp; - u_char c; +wsemul_vt100_output_string(struct wsemul_vt100_emuldata *edp, u_char c) { if (edp->dcstype && edp->dcspos < DCS_MAXLEN) edp->dcsarg[edp->dcspos++] = c; @@ -750,9 +711,7 @@ wsemul_vt100_output_string(edp, c) } u_int -wsemul_vt100_output_string_esc(edp, c) - struct wsemul_vt100_emuldata *edp; - u_char c; +wsemul_vt100_output_string_esc(struct wsemul_vt100_emuldata *edp, u_char c) { if (c == '\\') { /* ST complete */ wsemul_vt100_handle_dcs(edp); @@ -762,9 +721,7 @@ wsemul_vt100_output_string_esc(edp, c) } u_int -wsemul_vt100_output_dcs(edp, c) - struct wsemul_vt100_emuldata *edp; - u_char c; +wsemul_vt100_output_dcs(struct wsemul_vt100_emuldata *edp, u_char c) { u_int newstate = VT100_EMUL_STATE_DCS; @@ -780,7 +737,7 @@ wsemul_vt100_output_dcs(edp, c) case ';': /* argument terminator */ edp->nargs++; break; - default: + default: edp->nargs++; if (edp->nargs > VT100_EMUL_NARGS) { #ifdef VT100_DEBUG @@ -801,7 +758,7 @@ wsemul_vt100_output_dcs(edp, c) printf("DCS%c ignored\n", c); #endif break; - default: + default: #ifdef VT100_PRINTUNKNOWN printf("DCS%c (%d, %d) unknown\n", c, ARG(0), ARG(1)); #endif @@ -813,9 +770,7 @@ wsemul_vt100_output_dcs(edp, c) } u_int -wsemul_vt100_output_dcs_dollar(edp, c) - struct wsemul_vt100_emuldata *edp; - u_char c; +wsemul_vt100_output_dcs_dollar(struct wsemul_vt100_emuldata *edp, u_char c) { switch (c) { case 'p': /* DECRSTS terminal state restore */ @@ -837,14 +792,14 @@ wsemul_vt100_output_dcs_dollar(edp, c) edp->dcspos = 0; edp->dcstype = DCSTYPE_TABRESTORE; break; - default: + default: #ifdef VT100_PRINTUNKNOWN printf("DCS%d$t unknown\n", ARG(0)); #endif break; } break; - default: + default: #ifdef VT100_PRINTUNKNOWN printf("DCS$%c (%d, %d) unknown\n", c, ARG(0), ARG(1)); #endif @@ -854,9 +809,7 @@ wsemul_vt100_output_dcs_dollar(edp, c) } u_int -wsemul_vt100_output_esc_hash(edp, c) - struct wsemul_vt100_emuldata *edp; - u_char c; +wsemul_vt100_output_esc_hash(struct wsemul_vt100_emuldata *edp, u_char c) { int i; @@ -865,11 +818,9 @@ wsemul_vt100_output_esc_hash(edp, c) if (edp->dblwid != NULL && edp->dw != 0) { for (i = 0; i < edp->ncols / 2; i++) (*edp->emulops->copycols)(edp->emulcookie, - edp->crow, - 2 * i, i, 1); + edp->crow, 2 * i, i, 1); (*edp->emulops->erasecols)(edp->emulcookie, edp->crow, - i, edp->ncols - i, - edp->bkgdattr); + i, edp->ncols - i, edp->bkgdattr); edp->dblwid[edp->crow] = 0; edp->dw = 0; } @@ -880,13 +831,10 @@ wsemul_vt100_output_esc_hash(edp, c) if (edp->dblwid != NULL && edp->dw == 0) { for (i = edp->ncols / 2 - 1; i >= 0; i--) (*edp->emulops->copycols)(edp->emulcookie, - edp->crow, - i, 2 * i, 1); + edp->crow, i, 2 * i, 1); for (i = 0; i < edp->ncols / 2; i++) (*edp->emulops->erasecols)(edp->emulcookie, - edp->crow, - 2 * i + 1, 1, - edp->bkgdattr); + edp->crow, 2 * i + 1, 1, edp->bkgdattr); edp->dblwid[edp->crow] = 1; edp->dw = 1; if (edp->ccol > (edp->ncols >> 1) - 1) @@ -898,12 +846,12 @@ wsemul_vt100_output_esc_hash(edp, c) for (i = 0; i < edp->nrows; i++) for (j = 0; j < edp->ncols; j++) (*edp->emulops->putchar)(edp->emulcookie, i, j, - 'E', edp->curattr); + 'E', edp->curattr); } edp->ccol = 0; edp->crow = 0; break; - default: + default: #ifdef VT100_PRINTUNKNOWN printf("ESC#%c unknown\n", c); #endif @@ -913,9 +861,7 @@ wsemul_vt100_output_esc_hash(edp, c) } u_int -wsemul_vt100_output_csi(edp, c) - struct wsemul_vt100_emuldata *edp; - u_char c; +wsemul_vt100_output_csi(struct wsemul_vt100_emuldata *edp, u_char c) { u_int newstate = VT100_EMUL_STATE_CSI; @@ -941,7 +887,7 @@ wsemul_vt100_output_csi(edp, c) case '&': edp->modif2 = c; break; - default: /* end of escape sequence */ + default: /* end of escape sequence */ edp->nargs++; if (edp->nargs > VT100_EMUL_NARGS) { #ifdef VT100_DEBUG @@ -957,18 +903,9 @@ wsemul_vt100_output_csi(edp, c) } void -wsemul_vt100_output(cookie, data, count, kernel) - void *cookie; - const u_char *data; - u_int count; - int kernel; +wsemul_vt100_output(void *cookie, const u_char *data, u_int count, int kernel) { struct wsemul_vt100_emuldata *edp = cookie; -#ifdef JUMP_SCROLL - const u_char *eot; - u_char curchar; - u_int cnt, pos, lines; -#endif #ifdef DIAGNOSTIC if (kernel && !edp->console) @@ -977,7 +914,7 @@ wsemul_vt100_output(cookie, data, count, kernel) if (edp->flags & VTFL_CURSORON) (*edp->emulops->cursor)(edp->emulcookie, 0, - edp->crow, edp->ccol << edp->dw); + edp->crow, edp->ccol << edp->dw); for (; count > 0; data++, count--) { #ifdef JUMP_SCROLL @@ -986,64 +923,8 @@ wsemul_vt100_output(cookie, data, count, kernel) * newlines until an escape sequence appears. */ if ((edp->state == VT100_EMUL_STATE_NORMAL || kernel) && - ROWS_BELOW == 0) { - lines = 0; - pos = edp->ccol; - for (eot = data, cnt = count; cnt != 0; eot++, cnt--) { - curchar = *eot; - /* - * Only char for which - * wsemul_vt100_output_c0c1() will switch - * to escape mode, for now. - * Revisit this when this changes... - */ - if (curchar == ASCII_ESC) - break; - - if (ISSET(edp->flags, VTFL_DECAWM)) - switch (curchar) { - case ASCII_BS: - if (pos > 0) - pos--; - break; - case ASCII_CR: - pos = 0; - break; - case ASCII_HT: - if (edp->tabs) { - pos++; - while (pos < NCOLS - 1 && - edp->tabs[pos] == 0) - pos++; - } else { - pos = (pos + 7) & ~7; - if (pos >= NCOLS) - pos = NCOLS - 1; - } - break; - default: - if ((curchar & 0x7f) < 0x20) - break; - if (pos++ >= NCOLS) { - pos = 0; - curchar = ASCII_LF; - } - break; - } - - if (curchar == ASCII_LF || - curchar == ASCII_VT || - curchar == ASCII_FF) { - if (++lines >= edp->scrreg_nrows - 1) - break; - } - } - - if (lines > 1) { - wsemul_vt100_scrollup(edp, lines); - edp->crow -= lines; - } - } + ROWS_BELOW == 0) + wsemul_vt100_jump_scroll(edp, data, count, kernel); #endif if ((*data & 0x7f) < 0x20) { @@ -1064,5 +945,72 @@ wsemul_vt100_output(cookie, data, count, kernel) if (edp->flags & VTFL_CURSORON) (*edp->emulops->cursor)(edp->emulcookie, 1, - edp->crow, edp->ccol << edp->dw); + edp->crow, edp->ccol << edp->dw); } + +#ifdef JUMP_SCROLL +void +wsemul_vt100_jump_scroll(struct wsemul_vt100_emuldata *edp, const u_char *data, + u_int count, int kernel) +{ + u_char curchar; + u_int pos, lines; + + lines = 0; + pos = edp->ccol; + for (; count != 0; data++, count--) { + curchar = *data; + /* + * Only char for which + * wsemul_vt100_output_c0c1() will switch + * to escape mode, for now. + * Revisit this when this changes... + */ + if (curchar == ASCII_ESC) + break; + + if (ISSET(edp->flags, VTFL_DECAWM)) + switch (curchar) { + case ASCII_BS: + if (pos > 0) + pos--; + break; + case ASCII_CR: + pos = 0; + break; + case ASCII_HT: + if (edp->tabs) { + pos++; + while (pos < NCOLS - 1 && + edp->tabs[pos] == 0) + pos++; + } else { + pos = (pos + 7) & ~7; + if (pos >= NCOLS) + pos = NCOLS - 1; + } + break; + default: + if ((curchar & 0x7f) < 0x20) + break; + if (pos++ >= NCOLS) { + pos = 0; + curchar = ASCII_LF; + } + break; + } + + if (curchar == ASCII_LF || + curchar == ASCII_VT || + curchar == ASCII_FF) { + if (++lines >= edp->scrreg_nrows - 1) + break; + } + } + + if (lines > 1) { + wsemul_vt100_scrollup(edp, lines); + edp->crow -= lines; + } +} +#endif diff --git a/sys/dev/wscons/wsemul_vt100_chars.c b/sys/dev/wscons/wsemul_vt100_chars.c index f62e24b49de..a45d9d9e33f 100644 --- a/sys/dev/wscons/wsemul_vt100_chars.c +++ b/sys/dev/wscons/wsemul_vt100_chars.c @@ -1,4 +1,4 @@ -/* $OpenBSD: wsemul_vt100_chars.c,v 1.5 2007/01/07 13:31:36 miod Exp $ */ +/* $OpenBSD: wsemul_vt100_chars.c,v 1.6 2007/11/27 16:37:27 miod Exp $ */ /* $NetBSD: wsemul_vt100_chars.c,v 1.4 1999/02/20 18:20:02 drochner Exp $ */ /* @@ -75,8 +75,7 @@ static const u_int16_t dectech2uni[128] = { }; void -vt100_initchartables(edp) - struct wsemul_vt100_emuldata *edp; +vt100_initchartables(struct wsemul_vt100_emuldata *edp) { int i; @@ -129,7 +128,7 @@ static const struct { /* norwegian /danish */ {{0x0023, 0x0040, 0x00c6, 0x00d8, 0x00c5, 0x005e, 0x005f, 0x0060, 0x00e6, 0x00f8, 0x00e5, 0x007e}}, - /* portugese */ + /* portuguese */ {{0x0023, 0x0040, 0x00c3, 0x00c7, 0x00d5, 0x005e, 0x005f, 0x0060, 0x00e3, 0x00e7, 0x00f5, 0x007e}}, /* spanish */ @@ -144,9 +143,7 @@ static const struct { }; int -vt100_setnrc(edp, nrc) - struct wsemul_vt100_emuldata *edp; - int nrc; +vt100_setnrc(struct wsemul_vt100_emuldata *edp, int nrc) { int i; diff --git a/sys/dev/wscons/wsemul_vt100_keys.c b/sys/dev/wscons/wsemul_vt100_keys.c index 99cb873ab39..eac920de4cf 100644 --- a/sys/dev/wscons/wsemul_vt100_keys.c +++ b/sys/dev/wscons/wsemul_vt100_keys.c @@ -1,4 +1,4 @@ -/* $OpenBSD: wsemul_vt100_keys.c,v 1.3 2007/11/26 16:56:42 miod Exp $ */ +/* $OpenBSD: wsemul_vt100_keys.c,v 1.4 2007/11/27 16:37:27 miod Exp $ */ /* $NetBSD: wsemul_vt100_keys.c,v 1.3 1999/04/22 20:06:02 mycroft Exp $ */ /* @@ -79,10 +79,7 @@ static const char *vt100_numpad[] = { }; int -wsemul_vt100_translate(cookie, in, out) - void *cookie; - keysym_t in; - const char **out; +wsemul_vt100_translate(void *cookie, keysym_t in, const char **out) { struct wsemul_vt100_emuldata *edp = cookie; static char c; diff --git a/sys/dev/wscons/wsemul_vt100_subr.c b/sys/dev/wscons/wsemul_vt100_subr.c index c67c0389592..c696630c7bb 100644 --- a/sys/dev/wscons/wsemul_vt100_subr.c +++ b/sys/dev/wscons/wsemul_vt100_subr.c @@ -1,4 +1,4 @@ -/* $OpenBSD: wsemul_vt100_subr.c,v 1.14 2007/01/07 13:31:36 miod Exp $ */ +/* $OpenBSD: wsemul_vt100_subr.c,v 1.15 2007/11/27 16:37:27 miod Exp $ */ /* $NetBSD: wsemul_vt100_subr.c,v 1.7 2000/04/28 21:56:16 mycroft Exp $ */ /* @@ -36,10 +36,10 @@ #include <dev/wscons/wsemulvar.h> #include <dev/wscons/wsemul_vt100var.h> -int vt100_selectattribute(struct wsemul_vt100_emuldata *, int, int, int, - long *, long *); -int vt100_ansimode(struct wsemul_vt100_emuldata *, int, int); -int vt100_decmode(struct wsemul_vt100_emuldata *, int, int); +int vt100_selectattribute(struct wsemul_vt100_emuldata *, int, int, int, + long *, long *); +int vt100_ansimode(struct wsemul_vt100_emuldata *, int, int); +int vt100_decmode(struct wsemul_vt100_emuldata *, int, int); #define VTMODE_SET 33 #define VTMODE_RESET 44 #define VTMODE_REPORT 55 @@ -48,9 +48,7 @@ int vt100_decmode(struct wsemul_vt100_emuldata *, int, int); * scroll up within scrolling region */ void -wsemul_vt100_scrollup(edp, n) - struct wsemul_vt100_emuldata *edp; - int n; +wsemul_vt100_scrollup(struct wsemul_vt100_emuldata *edp, int n) { int help; @@ -60,17 +58,13 @@ wsemul_vt100_scrollup(edp, n) help = edp->scrreg_nrows - n; if (help > 0) { (*edp->emulops->copyrows)(edp->emulcookie, - edp->scrreg_startrow + n, - edp->scrreg_startrow, - help); + edp->scrreg_startrow + n, edp->scrreg_startrow, help); if (edp->dblwid) /* XXX OVERLAPS */ bcopy(&edp->dblwid[edp->scrreg_startrow + n], - &edp->dblwid[edp->scrreg_startrow], - help); + &edp->dblwid[edp->scrreg_startrow], help); } (*edp->emulops->eraserows)(edp->emulcookie, - edp->scrreg_startrow + help, n, - edp->bkgdattr); + edp->scrreg_startrow + help, n, edp->bkgdattr); if (edp->dblwid) memset(&edp->dblwid[edp->scrreg_startrow + help], 0, n); CHECK_DW; @@ -80,9 +74,7 @@ wsemul_vt100_scrollup(edp, n) * scroll down within scrolling region */ void -wsemul_vt100_scrolldown(edp, n) - struct wsemul_vt100_emuldata *edp; - int n; +wsemul_vt100_scrolldown(struct wsemul_vt100_emuldata *edp, int n) { int help; @@ -92,17 +84,13 @@ wsemul_vt100_scrolldown(edp, n) help = edp->scrreg_nrows - n; if (help > 0) { (*edp->emulops->copyrows)(edp->emulcookie, - edp->scrreg_startrow, - edp->scrreg_startrow + n, - help); + edp->scrreg_startrow, edp->scrreg_startrow + n, help); if (edp->dblwid) /* XXX OVERLAPS */ bcopy(&edp->dblwid[edp->scrreg_startrow], - &edp->dblwid[edp->scrreg_startrow + n], - help); + &edp->dblwid[edp->scrreg_startrow + n], help); } - (*edp->emulops->eraserows)(edp->emulcookie, - edp->scrreg_startrow, n, - edp->bkgdattr); + (*edp->emulops->eraserows)(edp->emulcookie, edp->scrreg_startrow, n, + edp->bkgdattr); if (edp->dblwid) memset(&edp->dblwid[edp->scrreg_startrow], 0, n); CHECK_DW; @@ -112,42 +100,37 @@ wsemul_vt100_scrolldown(edp, n) * erase in display */ void -wsemul_vt100_ed(edp, arg) - struct wsemul_vt100_emuldata *edp; - int arg; +wsemul_vt100_ed(struct wsemul_vt100_emuldata *edp, int arg) { int n; switch (arg) { - case 0: /* cursor to end */ + case 0: /* cursor to end */ ERASECOLS(edp->ccol, COLS_LEFT + 1, edp->bkgdattr); n = edp->nrows - edp->crow - 1; if (n > 0) { (*edp->emulops->eraserows)(edp->emulcookie, - edp->crow + 1, n, - edp->bkgdattr); + edp->crow + 1, n, edp->bkgdattr); if (edp->dblwid) memset(&edp->dblwid[edp->crow + 1], 0, n); } break; - case 1: /* beginning to cursor */ + case 1: /* beginning to cursor */ if (edp->crow > 0) { (*edp->emulops->eraserows)(edp->emulcookie, - 0, edp->crow, - edp->bkgdattr); + 0, edp->crow, edp->bkgdattr); if (edp->dblwid) memset(&edp->dblwid[0], 0, edp->crow); } ERASECOLS(0, edp->ccol + 1, edp->bkgdattr); break; - case 2: /* complete display */ + case 2: /* complete display */ (*edp->emulops->eraserows)(edp->emulcookie, - 0, edp->nrows, - edp->bkgdattr); + 0, edp->nrows, edp->bkgdattr); if (edp->dblwid) memset(&edp->dblwid[0], 0, edp->nrows); break; - default: + default: #ifdef VT100_PRINTUNKNOWN printf("ed(%d) unknown\n", arg); #endif @@ -160,23 +143,20 @@ wsemul_vt100_ed(edp, arg) * erase in line */ void -wsemul_vt100_el(edp, arg) - struct wsemul_vt100_emuldata *edp; - int arg; +wsemul_vt100_el(struct wsemul_vt100_emuldata *edp, int arg) { switch (arg) { - case 0: /* cursor to end */ + case 0: /* cursor to end */ ERASECOLS(edp->ccol, COLS_LEFT + 1, edp->bkgdattr); break; - case 1: /* beginning to cursor */ + case 1: /* beginning to cursor */ ERASECOLS(0, edp->ccol + 1, edp->bkgdattr); break; - case 2: /* complete line */ + case 2: /* complete line */ (*edp->emulops->erasecols)(edp->emulcookie, edp->crow, - 0, edp->ncols, - edp->bkgdattr); + 0, edp->ncols, edp->bkgdattr); break; - default: + default: #ifdef VT100_PRINTUNKNOWN printf("el(%d) unknown\n", arg); #endif @@ -188,9 +168,7 @@ wsemul_vt100_el(edp, arg) * handle commands after CSI (ESC[) */ void -wsemul_vt100_handle_csi(edp, c) - struct wsemul_vt100_emuldata *edp; - u_char c; +wsemul_vt100_handle_csi(struct wsemul_vt100_emuldata *edp, u_char c) { int n, help, flags, fgcol, bgcol; long attr, bkgdattr; @@ -199,7 +177,7 @@ wsemul_vt100_handle_csi(edp, c) switch (A3(edp->modif1, edp->modif2, c)) { case A3('>', '\0', 'c'): /* DA secondary */ wsdisplay_emulinput(edp->cbcookie, WSEMUL_VT_ID2, - sizeof(WSEMUL_VT_ID2)); + sizeof(WSEMUL_VT_ID2)); break; case A3('\0', '\0', 'J'): /* ED selective erase in display */ @@ -339,17 +317,17 @@ wsemul_vt100_handle_csi(edp, c) for (i = 0; i < edp->ncols; i++) if (edp->tabs[i]) { n = snprintf(buf, sizeof buf, "%s%d", - (ps ? "/" : ""), i + 1); + (ps ? "/" : ""), i + 1); if (n == -1) n = 0; else if (n >= sizeof buf) n = sizeof buf - 1; wsdisplay_emulinput(edp->cbcookie, - buf, n); + buf, n); ps = 1; } - } wsdisplay_emulinput(edp->cbcookie, "\033\\", 2); + } break; default: #ifdef VT100_PRINTUNKNOWN @@ -430,9 +408,10 @@ wsemul_vt100_handle_csi(edp, c) break; case 'L': /* IL insert line */ case 'M': /* DL delete line */ - n = min(DEF1_ARG(0), ROWS_BELOW + 1); - { + { int savscrstartrow, savscrnrows; + + n = min(DEF1_ARG(0), ROWS_BELOW + 1); savscrstartrow = edp->scrreg_startrow; savscrnrows = edp->scrreg_nrows; edp->scrreg_nrows -= ROWS_ABOVE; @@ -443,7 +422,7 @@ wsemul_vt100_handle_csi(edp, c) wsemul_vt100_scrollup(edp, n); edp->scrreg_startrow = savscrstartrow; edp->scrreg_nrows = savscrnrows; - } + } break; case 'P': /* DCH delete character */ n = min(DEF1_ARG(0), COLS_LEFT + 1); @@ -459,7 +438,7 @@ wsemul_vt100_handle_csi(edp, c) case 'c': /* DA primary */ if (ARG(0) == 0) wsdisplay_emulinput(edp->cbcookie, WSEMUL_VT_ID1, - sizeof(WSEMUL_VT_ID1)); + sizeof(WSEMUL_VT_ID1)); break; case 'g': /* TBC */ if (edp->tabs != NULL) @@ -571,7 +550,7 @@ wsemul_vt100_handle_csi(edp, c) if (n == -1) n = 0; else if (n >= sizeof buf) - n = sizeof buf - 1; + n = sizeof buf - 1; wsdisplay_emulinput(edp->cbcookie, buf, n); } break; @@ -634,10 +613,8 @@ wsemul_vt100_handle_csi(edp, c) * is not supported */ int -vt100_selectattribute(edp, flags, fgcol, bgcol, attr, bkgdattr) - struct wsemul_vt100_emuldata *edp; - int flags, fgcol, bgcol; - long *attr, *bkgdattr; +vt100_selectattribute(struct wsemul_vt100_emuldata *edp, int flags, int fgcol, + int bgcol, long *attr, long *bkgdattr) { int error; @@ -649,7 +626,7 @@ vt100_selectattribute(edp, flags, fgcol, bgcol, attr, bkgdattr) #endif } error = (*edp->emulops->alloc_attr)(edp->emulcookie, fgcol, bgcol, - flags & WSATTR_WSCOLORS, bkgdattr); + flags & WSATTR_WSCOLORS, bkgdattr); if (error) return (error); @@ -713,8 +690,7 @@ vt100_selectattribute(edp, flags, fgcol, bgcol, attr, bkgdattr) * told so by setting edp->dcstype to a nonzero value */ void -wsemul_vt100_handle_dcs(edp) - struct wsemul_vt100_emuldata *edp; +wsemul_vt100_handle_dcs(struct wsemul_vt100_emuldata *edp) { int i, pos; @@ -756,33 +732,31 @@ wsemul_vt100_handle_dcs(edp) } int -vt100_ansimode(edp, nr, op) - struct wsemul_vt100_emuldata *edp; - int nr, op; +vt100_ansimode(struct wsemul_vt100_emuldata *edp, int nr, int op) { int res = 0; /* default: unknown */ switch (nr) { - case 2: /* KAM keyboard locked/unlocked */ + case 2: /* KAM keyboard locked/unlocked */ break; - case 3: /* CRM control representation */ + case 3: /* CRM control representation */ break; - case 4: /* IRM insert/replace characters */ + case 4: /* IRM insert/replace characters */ if (op == VTMODE_SET) edp->flags |= VTFL_INSERTMODE; else if (op == VTMODE_RESET) edp->flags &= ~VTFL_INSERTMODE; res = ((edp->flags & VTFL_INSERTMODE) ? 1 : 2); break; - case 10: /* HEM horizontal editing (permanently reset) */ + case 10: /* HEM horizontal editing (permanently reset) */ res = 4; break; - case 12: /* SRM local echo off/on */ + case 12: /* SRM local echo off/on */ res = 4; /* permanently reset ??? */ break; - case 20: /* LNM newline = newline/linefeed */ + case 20: /* LNM newline = newline/linefeed */ break; - default: + default: #ifdef VT100_PRINTUNKNOWN printf("ANSI mode %d unknown\n", nr); #endif @@ -792,74 +766,71 @@ vt100_ansimode(edp, nr, op) } int -vt100_decmode(edp, nr, op) - struct wsemul_vt100_emuldata *edp; - int nr, op; +vt100_decmode(struct wsemul_vt100_emuldata *edp, int nr, int op) { int res = 0; /* default: unknown */ int flags; flags = edp->flags; switch (nr) { - case 1: /* DECCKM application/nomal cursor keys */ + case 1: /* DECCKM application/nomal cursor keys */ if (op == VTMODE_SET) flags |= VTFL_APPLCURSOR; else if (op == VTMODE_RESET) flags &= ~VTFL_APPLCURSOR; res = ((flags & VTFL_APPLCURSOR) ? 1 : 2); break; - case 2: /* DECANM ANSI vt100/vt52 */ + case 2: /* DECANM ANSI vt100/vt52 */ res = 3; /* permanently set ??? */ break; - case 3: /* DECCOLM 132/80 cols */ - case 4: /* DECSCLM smooth/jump scroll */ - case 5: /* DECSCNM light/dark background */ + case 3: /* DECCOLM 132/80 cols */ + case 4: /* DECSCLM smooth/jump scroll */ + case 5: /* DECSCNM light/dark background */ res = 4; /* all permanently reset ??? */ break; - case 6: /* DECOM move within/outside margins */ + case 6: /* DECOM move within/outside margins */ if (op == VTMODE_SET) flags |= VTFL_DECOM; else if (op == VTMODE_RESET) flags &= ~VTFL_DECOM; res = ((flags & VTFL_DECOM) ? 1 : 2); break; - case 7: /* DECAWM autowrap */ + case 7: /* DECAWM autowrap */ if (op == VTMODE_SET) flags |= VTFL_DECAWM; else if (op == VTMODE_RESET) flags &= ~VTFL_DECAWM; res = ((flags & VTFL_DECAWM) ? 1 : 2); break; - case 8: /* DECARM keyboard autorepeat */ + case 8: /* DECARM keyboard autorepeat */ break; - case 18: /* DECPFF print form feed */ + case 18: /* DECPFF print form feed */ break; - case 19: /* DECPEX printer extent: screen/scrolling region */ + case 19: /* DECPEX printer extent: screen/scrolling region */ break; - case 25: /* DECTCEM text cursor on/off */ + case 25: /* DECTCEM text cursor on/off */ if (op == VTMODE_SET) flags |= VTFL_CURSORON; else if (op == VTMODE_RESET) flags &= ~VTFL_CURSORON; if (flags != edp->flags) (*edp->emulops->cursor)(edp->emulcookie, - flags & VTFL_CURSORON, - edp->crow, edp->ccol); + flags & VTFL_CURSORON, edp->crow, edp->ccol); res = ((flags & VTFL_CURSORON) ? 1 : 2); break; - case 42: /* DECNRCM use 7-bit NRC / - 7/8 bit from DEC multilingual or ISO-latin-1*/ + case 42: /* DECNRCM use 7-bit NRC / + 7/8 bit from DEC multilingual or ISO-latin-1*/ if (op == VTMODE_SET) flags |= VTFL_NATCHARSET; else if (op == VTMODE_RESET) flags &= ~VTFL_NATCHARSET; res = ((flags & VTFL_NATCHARSET) ? 1 : 2); break; - case 66: /* DECNKM numeric keypad */ + case 66: /* DECNKM numeric keypad */ break; - case 68: /* DECKBUM keyboard usage data processing/typewriter */ + case 68: /* DECKBUM keyboard usage data processing/typewriter */ break; - default: + default: #ifdef VT100_PRINTUNKNOWN printf("DEC mode %d unknown\n", nr); #endif diff --git a/sys/dev/wscons/wsemul_vt100var.h b/sys/dev/wscons/wsemul_vt100var.h index ae706a25c31..f72e734761d 100644 --- a/sys/dev/wscons/wsemul_vt100var.h +++ b/sys/dev/wscons/wsemul_vt100var.h @@ -1,4 +1,4 @@ -/* $OpenBSD: wsemul_vt100var.h,v 1.7 2007/11/26 16:56:42 miod Exp $ */ +/* $OpenBSD: wsemul_vt100var.h,v 1.8 2007/11/27 16:37:27 miod Exp $ */ /* $NetBSD: wsemul_vt100var.h,v 1.5 2000/04/28 21:56:17 mycroft Exp $ */ /* @@ -127,15 +127,15 @@ struct wsemul_vt100_emuldata { */ #define WSEMUL_VT_ID2 "\033[>24;20;0c" -void wsemul_vt100_reset(struct wsemul_vt100_emuldata *); -void wsemul_vt100_scrollup(struct wsemul_vt100_emuldata *, int); -void wsemul_vt100_scrolldown(struct wsemul_vt100_emuldata *, int); -void wsemul_vt100_ed(struct wsemul_vt100_emuldata *, int); -void wsemul_vt100_el(struct wsemul_vt100_emuldata *, int); -void wsemul_vt100_handle_csi(struct wsemul_vt100_emuldata *, u_char); -void wsemul_vt100_handle_dcs(struct wsemul_vt100_emuldata *); +void wsemul_vt100_reset(struct wsemul_vt100_emuldata *); +void wsemul_vt100_scrollup(struct wsemul_vt100_emuldata *, int); +void wsemul_vt100_scrolldown(struct wsemul_vt100_emuldata *, int); +void wsemul_vt100_ed(struct wsemul_vt100_emuldata *, int); +void wsemul_vt100_el(struct wsemul_vt100_emuldata *, int); +void wsemul_vt100_handle_csi(struct wsemul_vt100_emuldata *, u_char); +void wsemul_vt100_handle_dcs(struct wsemul_vt100_emuldata *); -int wsemul_vt100_translate(void *cookie, keysym_t, const char **); +int wsemul_vt100_translate(void *cookie, keysym_t, const char **); -void vt100_initchartables(struct wsemul_vt100_emuldata *); -int vt100_setnrc(struct wsemul_vt100_emuldata *, int); +void vt100_initchartables(struct wsemul_vt100_emuldata *); +int vt100_setnrc(struct wsemul_vt100_emuldata *, int); diff --git a/sys/dev/wscons/wsemulvar.h b/sys/dev/wscons/wsemulvar.h index 0084a76affa..3884f75830d 100644 --- a/sys/dev/wscons/wsemulvar.h +++ b/sys/dev/wscons/wsemulvar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: wsemulvar.h,v 1.9 2007/11/26 16:56:42 miod Exp $ */ +/* $OpenBSD: wsemulvar.h,v 1.10 2007/11/27 16:37:27 miod Exp $ */ /* $NetBSD: wsemulvar.h,v 1.6 1999/01/17 15:46:15 drochner Exp $ */ /* @@ -61,8 +61,8 @@ extern const struct wsemul_ops wsemul_vt100_ops; const struct wsemul_ops *wsemul_pick(const char *); -/* +/* * Callbacks from the emulation code to the display interface driver. - */ + */ void wsdisplay_emulbell(void *v); void wsdisplay_emulinput(void *v, const u_char *, u_int); |