diff options
author | ache <ache@FreeBSD.org> | 1994-08-28 21:47:13 +0000 |
---|---|---|
committer | ache <ache@FreeBSD.org> | 1994-08-28 21:47:13 +0000 |
commit | b942ce9760728fb49779bf935c37cd771591179f (patch) | |
tree | 15d0f287c735370d7c344c86a8addbbf04e4b2a5 /lib/libcurses/curses.h | |
parent | a00bd57cf70abf1e00736365d5f1f652182326a1 (diff) | |
download | FreeBSD-src-b942ce9760728fb49779bf935c37cd771591179f.zip FreeBSD-src-b942ce9760728fb49779bf935c37cd771591179f.tar.gz |
newwin.c
o __FULLINE added for AL/DL/CS optimization with __noqch.
refresh.c
o Attributes does not turned off before clearing screen, cause
highlighted screen.
o Proper usage of 'affcnt' tputs parameter, affects terminals with
padding.
o make AL/DL/CS optimize not only for __FULLWIN but for __FULLLINE.
ATTENTION: original code works _only_for_ FULLWIN, i.e. if you
use two FULLLINE windows like in 'talk', you have full slow repaint with
original code, I enhance this thing. All other fixes marked
with phrase 'wrong for non-full windows' or WFNFW is continue of this fix.
I rewrite scroll code too for proper working (see below and tty.c
changes).
o DEBUG code always use 'i' index from 0 to curscr->maxy instead of
'i - win->begy', fixed
o check added into DEBUG to be shure that index inside current window.
o ->hash assigment code is WFNFW (forget win->begy).
o when CE usage required, and last spaces number counted, code don't check
attributes, so last standouted space will be incorrectly cleared.
o cep (start pointer) forget to add win->begy/win->begx, code WFNFW.
o clsp (last space) wrong in two places at once: forget to add win->begy
(WFNFW) and incorrectly use 'win->begx * __LDATASIZE' in pointer
arithmetics.
o clsp check incorrect: was 'clsp < win->maxx * __LDATASIZE', need to
be 'clsp < win->maxx
o Attributes does not turned off before clearing end of line, cause
highlighted end of line.
o When find how many lines from the top/bottom of the screen are unchanged,
code always forget '- win->begy', WFNFW.
o NO_JERKINESS code forgets to add win->begy, WFNFW.
o Curw & Curs changed in comment description
o In search for the largest block of text not changed forget to add
'- win->begy' (several places), WFNFW.
o Forget to add '- win->begy' for non-dirty lines, WFNFW.
o touchline forget to add '- win->begy', WFNFW.
o rewrite scrolln():
* remove win parameter, we deal with whole screen (curscr) now;
* use NL or '\n' instead of sf, it is faster in any case;
(imagine: cat written on curses now use '\n' for scroll
like standard cat, no ugly escapes)
* use dl (if present) instead of DL, if abs(n) == 1, the same
about al/sr, it is faster;
* change win->maxy to 'curscr->maxy - 1', we deal with whole screen
here, WFNFW.
* SF can be correctly issued only if cursor at bottom of scroll
region (whole screen region included too), fix this;
* sr/SR can be correctly issued only if cursor at top of scroll
region (whole screen region included too), fix this;
* use pre-calculaded (in setterm.c) __usecs variable to determine
usage of CS or AL/DL;
* completely rewrite scroll region stuff using __set_scroll_region
from tty.c (see below);
tty.c
o Added __set_scroll_region function which set CS region and stays
back in old position. Use SC/RC (save/restore cursor) if possible,
else use HO and __mvcur.
o __startwin: added __set_scroll_region(whole screen) at program
startup, if __usecs;
o endwin: added __set_scroll_region(whole screen) at program
exit, if __usecs;
o Fix all tc{set/get}attrs to works properly, when stdin redirected,
use /dev/tty in this case (needed for some applications).
setterm.c
o Add new variable __usecs, if (!AL/al || !Dl/dl) && CS && (SC && RC || HO)
(save/restore cursor used in __set_scroll_region in tty.c).
o Set __noqch, if !__usecs && (!AL/al || !DL/dl).
o Proper ospeed initialization for tputs, i.e. if speed == B9600,
ospeed = 13
curses.c
o Add __usecs variable that indicates usage of CS (if AL/DL absent).
curses.h
o Allow translation with applications which includes <sgtty.h>,
undef BXXX manually to avoid redefinition and include termios
to define proper ones.
o Define old-style names curx/begx/maxx/etc. for old applications.
Define _tty like __baset too.
o Typedef SGTTY type for old applications (SGTTY == struct termios).
o wstandout/wstandend should be int and not char*, some old
applications relay on this fact. See standout.c too.
o __FULLINE added indicated line width == terminal width, needed
for refresh using AL/DL/CS with __noqch, see refresh.c changes.
o Add extern __usecs variable that indicates usage of CS (if AL/DL absent).
o Add __set_scroll_region() prototype, see tty.c and refresh.c changes
for details.
o Change winch() character mask from 0177 to 0377, we don't need to
strip high bit on national characters.
o Allow translate on systems with _BSD_VA_LIST_ undefined, such as
FreeBSD 1.1.5.1
o __tty_fileno added to allows work with stdin redirected, see tty.c
o Privately declare tputs (..., void) and externally tputs(..., int),
many applications require this. Maybe not nice thing, but needed.
o Remove _putchar definition and replace it to proper _putchar
prototype, some old apps declares: 'extern int _putchar()'
and don't even include curses.h in such modules. See putchar.c
cr_put.c
o __mvcur: if destline == destcol && outline == outcol do nothing,
i.e. don't issue any escapes.
o Proper usage of 'affcnt' tputs parameter, affects terminals with
padding.
cur_hash.c
o Change char->unsigned char for proper sum 8-bit national characters.
getch.c
o check for inp == EOF added, don't add EOF to window.
getstr.c
o check for EOF added, don't add EOF to str.
insertln.c
o add cast to (int) in comparation of y and win->cury, this produce
big number (cast to (unsigned)) if y < 0
tstp.c
o Fix all tc{set/get}attrs to works properly, when stdin redirected,
use /dev/tty in this case (needed for some applications).
o add tstp() function for compatibility, some applications wants it.
standout.c
o Some old applications relay in fact that wstandout/wstandend
returns int instead of char*, change return type to OK/ERR.
putchar.c
o Add _putchar function (which calls __cputchar),
some old apps declares: 'extern int _putchar()'
and don't even include curses.h in such modules.
Diffstat (limited to 'lib/libcurses/curses.h')
-rw-r--r-- | lib/libcurses/curses.h | 69 |
1 files changed, 62 insertions, 7 deletions
diff --git a/lib/libcurses/curses.h b/lib/libcurses/curses.h index 3c585e6..9e18183 100644 --- a/lib/libcurses/curses.h +++ b/lib/libcurses/curses.h @@ -41,6 +41,10 @@ #include <stdio.h> +#ifndef _BSD_VA_LIST_ +#define _BSD_VA_LIST_ char * +#endif + /* * The following #defines and #includes are present for backward * compatibility only. They should not be used in future code. @@ -48,6 +52,34 @@ * START BACKWARD COMPATIBILITY ONLY. */ #ifndef _CURSES_PRIVATE + +/* This stuff needed for those pgms which include <sgtty.h> */ +/* Undef things manually to avoid redefinition */ + +#undef USE_OLD_TTY +#undef B0 +#undef B50 +#undef B75 +#undef B110 +#undef B134 +#undef B150 +#undef B200 +#undef B300 +#undef B600 +#undef B1200 +#undef B1800 +#undef B2400 +#undef B4800 +#undef B9600 +#undef EXTA +#undef EXTB +#undef B57600 +#undef B115200 + +#include <termios.h> +#include <sys/ioctl.h> +#include <sys/ioctl_compat.h> /* For sgttyb and related */ + #define bool char #define reg register @@ -59,7 +91,6 @@ #endif #define _puts(s) tputs(s, 0, __cputchar) -#define _putchar(c) __cputchar(c) /* Old-style terminal modes access. */ #define baudrate() (cfgetospeed(&__baset)) @@ -68,6 +99,17 @@ #define killchar() (__baset.c_cc[VKILL]) #define nocrmode() nocbreak() #define ospeed (cfgetospeed(&__baset)) + +/* WINDOW structure members name compatibility */ +#define _curx curx +#define _cury cury +#define _begx begx +#define _begy begy +#define _maxx maxx +#define _maxy maxy + +#define _tty __baset + #endif /* _CURSES_PRIVATE */ extern char GT; /* Gtty indicates tabs. */ @@ -147,6 +189,7 @@ typedef struct __window { /* Window structure. */ #define __CLEAROK 0x040 /* Clear on next refresh. */ #define __WSTANDOUT 0x080 /* Standout window */ #define __LEAVEOK 0x100 /* If curser left */ +#define __FULLLINE 0x200 /* Line width = terminal width. */ u_int flags; } WINDOW; @@ -154,9 +197,12 @@ typedef struct __window { /* Window structure. */ extern WINDOW *curscr; /* Current screen. */ extern WINDOW *stdscr; /* Standard screen. */ -extern struct termios __orig_termios; /* Terminal state before curses */ -extern struct termios __baset; /* Our base terminal state */ +typedef struct termios SGTTY; + +extern SGTTY __orig_termios; /* Terminal state before curses */ +extern SGTTY __baset; /* Our base terminal state */ extern int __tcaction; /* If terminal hardware set. */ +extern int __tty_fileno; /* Terminal file descriptor */ extern int COLS; /* Columns on the screen. */ extern int LINES; /* Lines on the screen. */ @@ -230,7 +276,7 @@ extern char *ttytype; /* Full name of current terminal. */ #define scrollok(w, bf) \ ((bf) ? ((w)->flags |= __SCROLLOK) : ((w)->flags &= ~__SCROLLOK)) #define winch(w) \ - ((w)->lines[(w)->cury]->line[(w)->curx].ch & 0177) + ((w)->lines[(w)->cury]->line[(w)->curx].ch & 0377) /* Public function prototypes. */ int box __P((WINDOW *, int, int)); @@ -289,12 +335,13 @@ int wmove __P((WINDOW *, int, int)); int wprintw __P((WINDOW *, const char *, ...)); int wrefresh __P((WINDOW *)); int wscanw __P((WINDOW *, const char *, ...)); -char *wstandend __P((WINDOW *)); -char *wstandout __P((WINDOW *)); +int wstandend __P((WINDOW *)); +int wstandout __P((WINDOW *)); int vwprintw __P((WINDOW *, const char *, _BSD_VA_LIST_)); /* Private functions that are needed for user programs prototypes. */ void __cputchar __P((int)); +int _putchar __P((int)); int __waddbytes __P((WINDOW *, const char *, int, int)); /* Private functions. */ @@ -306,6 +353,7 @@ int __mvcur __P((int, int, int, int, int)); void __restore_stophandler __P((void)); void __set_stophandler __P((void)); void __set_subwin __P((WINDOW *, WINDOW *)); +void __set_scroll_region __P((int, int, int, int)); void __startwin __P((void)); void __stop_signal_handler __P((int)); void __swflags __P((WINDOW *)); @@ -324,6 +372,14 @@ extern int __endwin; extern int __pfast; extern int __rawmode; extern int __noqch; +extern int __usecs; + +int tputs __P((char *, int, void (*)(int))); + +#else + +int tputs __P((char *, int, int (*)(int))); + #endif /* Termcap functions. */ @@ -332,6 +388,5 @@ int tgetnum __P((char *)); int tgetflag __P((char *)); char *tgetstr __P((char *, char **)); char *tgoto __P((char *, int, int)); -int tputs __P((char *, int, void (*)(int))); #endif /* !_CURSES_H_ */ |