diff options
| author | Kazutaka YOKOTA <yokota@FreeBSD.org> | 2000-01-12 12:30:33 +0000 |
|---|---|---|
| committer | Kazutaka YOKOTA <yokota@FreeBSD.org> | 2000-01-12 12:30:33 +0000 |
| commit | e2f29c6e438443c3f3def83dbb72effb94f16d94 (patch) | |
| tree | 9505ae7d8249e6750e42e1f00eba4cfad4d669c4 /sys/dev/syscons/scmouse.c | |
| parent | d404cb51eeaa1f9c4e5fc9c16ef38bba0a0d785e (diff) | |
Notes
Diffstat (limited to 'sys/dev/syscons/scmouse.c')
| -rw-r--r-- | sys/dev/syscons/scmouse.c | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/sys/dev/syscons/scmouse.c b/sys/dev/syscons/scmouse.c index ecaa329ab994..b0663a005f02 100644 --- a/sys/dev/syscons/scmouse.c +++ b/sys/dev/syscons/scmouse.c @@ -31,6 +31,7 @@ #if NSC > 0 +#include <limits.h> #include <sys/param.h> #include <sys/systm.h> #include <sys/conf.h> @@ -954,6 +955,23 @@ sc_mouse_ioctl(struct tty *tp, u_long cmd, caddr_t data, int flag, #endif /* SC_NO_CUTPASTE */ break; + case MOUSE_MOUSECHAR: + if (mouse->u.mouse_char < 0) { + mouse->u.mouse_char = scp->sc->mouse_char; + } else { + if (mouse->u.mouse_char >= UCHAR_MAX - 4) + return EINVAL; + s = spltty(); + sc_remove_all_mouse(scp->sc); +#ifndef SC_NO_FONT_LOADING + if (ISTEXTSC(cur_scp) && (cur_scp->font_size != FONT_NONE)) + copy_font(cur_scp, LOAD, cur_scp->font_size, cur_scp->font); +#endif + scp->sc->mouse_char = mouse->u.mouse_char; + splx(s); + } + break; + default: return EINVAL; } |
