diff options
-rw-r--r-- | lib/libtermlib/Makefile | 5 | ||||
-rw-r--r-- | lib/libtermlib/_mvcur.c | 127 | ||||
-rw-r--r-- | lib/libtermlib/mvcur.c | 101 |
3 files changed, 142 insertions, 91 deletions
diff --git a/lib/libtermlib/Makefile b/lib/libtermlib/Makefile index 173f56fabef..77f7c7e5fd5 100644 --- a/lib/libtermlib/Makefile +++ b/lib/libtermlib/Makefile @@ -1,4 +1,4 @@ -# $OpenBSD: Makefile,v 1.3 1996/09/21 19:22:25 tholo Exp $ +# $OpenBSD: Makefile,v 1.4 1996/10/12 03:08:24 tholo Exp $ # # Copyright (c) 1996 SigmaSoft, Th. Lockert <tholo@sigmasoft.com> # All rights reserved. @@ -31,7 +31,8 @@ LIB= termlib SRCS= captoinfo.c def_prog_mode.c def_shell_mode.c del_curterm.c \ - fillcap.c findcap.c findinfo.c getterm.c globals.c mvcur.c \ + fillcap.c findcap.c findinfo.c getterm.c globals.c \ + mvcur.c _mvcur.c \ outc.c putp.c reset_prog_mode.c reset_shell_mode.c \ restartterm.c setterm.c setupterm.c set_curterm.c tgetent.c \ tgetflag.c tgetnum.c tgetstr.c tgoto.c tigetflag.c tigetnum.c \ diff --git a/lib/libtermlib/_mvcur.c b/lib/libtermlib/_mvcur.c new file mode 100644 index 00000000000..848337a20ff --- /dev/null +++ b/lib/libtermlib/_mvcur.c @@ -0,0 +1,127 @@ +/* $OpenBSD: _mvcur.c,v 1.1 1996/10/12 03:08:25 tholo Exp $ */ + +/* + * Copyright (c) 1996 SigmaSoft, Th. Lockert <tholo@sigmasoft.com> + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * 3. All advertising materials mentioning features or use of this software + * must display the following acknowledgement: + * This product includes software developed by SigmaSoft, Th. Lockert. + * 4. The name of the author may not be used to endorse or promote products + * derived from this software without specific prior written permission. + * + * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, + * INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY + * AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL + * THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, + * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, + * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; + * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, + * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR + * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF + * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#ifndef lint +static char rcsid[] = "$OpenBSD: _mvcur.c,v 1.1 1996/10/12 03:08:25 tholo Exp $"; +#endif + +#include <string.h> +#include <unistd.h> +#include <termios.h> +#include "term.h" + +static int +rawmode() +{ + struct termios ti; + + if (tcgetattr(STDIN_FILENO, &ti) < 0) + return 1; + if (ti.c_oflag & OPOST) + if (ti.c_oflag & ONLCR) + return 0; + return 1; +} + +/* + * Optimized cursor movement, assume cursor is currently + * located at (oldx,oldy), output what is needed for the + * cursor to be relocated to (newx,newy) + */ +int +_mvcur(oldy, oldx, newy, newx) + int oldy; + int oldx; + int newy; + int newx; +{ + int l, c, raw; + char *p; + + if (newx >= columns) { + newy += newx / columns; + newx %= columns; + } + if (oldx >= columns) { + l = (oldx + 1) / columns; + oldy += l; + oldx %= columns; + if (!auto_right_margin) { + raw = rawmode(); + while (l > 0) { + if (raw) + if (carriage_return != NULL) + tputs(carriage_return, 0, _ti_outc); + else + _ti_outc('\r'); + if (linefeed_if_not_lf != NULL) + tputs(linefeed_if_not_lf, 0, _ti_outc); + else + _ti_outc('\n'); + l--; + } + oldx = 0; + } + if (oldy >= lines - 1) { + newy -= oldy - (lines - 1); + oldy = lines - 1; + } + } + if (newy >= lines) { + l = newy; + newy = lines - 1; + if (oldy < lines - 1) { + c = newx; + if (cursor_address == NULL) + newx = 0; + mvcur(oldy, oldx, newy, newx); + newx = c; + } + while (l >= lines) { + if (linefeed_if_not_lf != NULL) + tputs(linefeed_if_not_lf, 0, _ti_outc); + else + _ti_outc('\n'); + l--; + oldx = 0; + } + } + if (newy < oldy && !(cursor_address != NULL || cursor_up != NULL)) + newy = oldy; + if (cursor_address != NULL) { + p = tparm(cursor_address, newx, newy); + tputs(p, 0, _ti_outc); + } + else + return ERR; + return OK; +} diff --git a/lib/libtermlib/mvcur.c b/lib/libtermlib/mvcur.c index d78dc965edd..4d5e6b480ba 100644 --- a/lib/libtermlib/mvcur.c +++ b/lib/libtermlib/mvcur.c @@ -1,4 +1,4 @@ -/* $OpenBSD: mvcur.c,v 1.2 1996/07/13 18:20:17 tholo Exp $ */ +/* $OpenBSD: mvcur.c,v 1.3 1996/10/12 03:08:25 tholo Exp $ */ /* * Copyright (c) 1996 SigmaSoft, Th. Lockert <tholo@sigmasoft.com> @@ -31,97 +31,20 @@ */ #ifndef lint -static char rcsid[] = "$OpenBSD: mvcur.c,v 1.2 1996/07/13 18:20:17 tholo Exp $"; +static char rcsid[] = "$OpenBSD: mvcur.c,v 1.3 1996/10/12 03:08:25 tholo Exp $"; #endif -#include <string.h> -#include <unistd.h> -#include <termios.h> -#include "term.h" +#include <sys/cdefs.h> -static int -rawmode() -{ - struct termios ti; +#ifdef __indr_reference +__indr_reference(_mvcur, mvcur); +#else - if (tcgetattr(STDIN_FILENO, &ti) < 0) - return 1; - if (ti.c_oflag & OPOST) - if (ti.c_oflag & ONLCR) - return 0; - return 1; -} +#include <stdlib.h> +#include "term.h" -/* - * Optimized cursor movement, assume cursor is currently - * located at (oldx,oldy), output what is needed for the - * cursor to be relocated to (newx,newy) - */ -int -mvcur(oldy, oldx, newy, newx) - int oldy; - int oldx; - int newy; - int newx; -{ - int l, c, raw; - char *p; +#define _mvcur mvcur +#define rcsid _rcsid +#include "_mvcur.c" - if (newx >= columns) { - newy += newx / columns; - newx %= columns; - } - if (oldx >= columns) { - l = (oldx + 1) / columns; - oldy += l; - oldx %= columns; - if (!auto_right_margin) { - raw = rawmode(); - while (l > 0) { - if (raw) - if (carriage_return != NULL) - tputs(carriage_return, 0, _ti_outc); - else - _ti_outc('\r'); - if (linefeed_if_not_lf != NULL) - tputs(linefeed_if_not_lf, 0, _ti_outc); - else - _ti_outc('\n'); - l--; - } - oldx = 0; - } - if (oldy >= lines - 1) { - newy -= oldy - (lines - 1); - oldy = lines - 1; - } - } - if (newy >= lines) { - l = newy; - newy = lines - 1; - if (oldy < lines - 1) { - c = newx; - if (cursor_address == NULL) - newx = 0; - mvcur(oldy, oldx, newy, newx); - newx = c; - } - while (l >= lines) { - if (linefeed_if_not_lf != NULL) - tputs(linefeed_if_not_lf, 0, _ti_outc); - else - _ti_outc('\n'); - l--; - oldx = 0; - } - } - if (newy < oldy && !(cursor_address != NULL || cursor_up != NULL)) - newy = oldy; - if (cursor_address != NULL) { - p = tparm(cursor_address, newx, newy); - tputs(p, 0, _ti_outc); - } - else - return ERR; - return OK; -} +#endif |