Changes to support *echochar().

Should fix PR lib/24927.
This commit is contained in:
jdc 2004-03-28 08:58:37 +00:00
parent 5eb61d5ca7
commit a6a9a97d12
6 changed files with 55 additions and 18 deletions

View File

@ -1,4 +1,4 @@
# $NetBSD: Makefile,v 1.50 2004/03/23 21:56:53 jdc Exp $
# $NetBSD: Makefile,v 1.51 2004/03/28 08:58:37 jdc Exp $
# @(#)Makefile 8.2 (Berkeley) 1/2/94
.include <bsd.own.mk>
@ -18,11 +18,11 @@ LIB= curses
SRCS= acs.c addbytes.c addch.c addchnstr.c addnstr.c attributes.c \
background.c bell.c border.c box.c clear.c clearok.c clrtobot.c \
clrtoeol.c color.c copywin.c cr_put.c ctrace.c cur_hash.c curs_set.c \
curses.c delch.c deleteln.c delwin.c erase.c flushok.c fullname.c \
getch.c getstr.c getyx.c id_subwins.c idlok.c idcok.c inch.c \
inchstr.c initscr.c insch.c insdelln.c insertln.c instr.c keypad.c \
keyname.c leaveok.c line.c longname.c meta.c move.c mvwin.c newwin.c \
nodelay.c notimeout.c overlay.c overwrite.c pause.c printw.c \
curses.c delch.c deleteln.c delwin.c echochar.c erase.c flushok.c \
fullname.c getch.c getstr.c getyx.c id_subwins.c idlok.c idcok.c \
inch.c inchstr.c initscr.c insch.c insdelln.c insertln.c instr.c \
keypad.c keyname.c leaveok.c line.c longname.c meta.c move.c mvwin.c \
newwin.c nodelay.c notimeout.c overlay.c overwrite.c pause.c printw.c \
putchar.c refresh.c resize.c scanw.c screen.c scroll.c scrollok.c \
setterm.c standout.c timeout.c toucholap.c touchwin.c tscroll.c \
tstp.c tty.c unctrl.c underscore.c
@ -30,8 +30,8 @@ SRCS= acs.c addbytes.c addch.c addchnstr.c addnstr.c attributes.c \
MAN= curses.3 curses_addch.3 curses_addchstr.3 curses_addstr.3 \
curses_attributes.3 curses_background.3 curses_border.3 \
curses_clear.3 curses_color.3 curses_cursor.3 curses_default_colors.3 \
curses_delch.3 curses_deleteln.3 curses_inch.3 curses_input.3 \
curses_insertch.3 curses_insertln.3 curses_insdelln.3 \
curses_delch.3 curses_deleteln.3 curses_echochar.3 curses_inch.3 \
curses_input.3 curses_insertch.3 curses_insertln.3 curses_insdelln.3 \
curses_keyname.3 curses_line.3 curses_pad.3 curses_print.3 \
curses_refresh.3 curses_scanw.3 curses_screen.3 curses_scroll.3 \
curses_standout.3 curses_termcap.3 curses_touch.3 curses_tty.3 \
@ -63,7 +63,7 @@ MLINKS+= curses_addch.3 addch.3 curses_addchstr.3 addchnstr.3 \
curses_deleteln.3 deleteln.3 curses_screen.3 delscreen.3 \
curses_window.3 delwin.3 curses_window.3 derwin.3 \
curses_refresh.3 doupdate.3 curses_window.3 dupwin.3 \
curses_tty.3 echo.3 \
curses_tty.3 echo.3 curses_echochar.3 echochar.3 \
curses_screen.3 endwin.3 curses_clear.3 erase.3 \
curses_tty.3 erasechar.3 \
curses_tty.3 flash.3 curses_tty.3 flushinp.3 \
@ -115,7 +115,8 @@ MLINKS+= curses_addch.3 addch.3 curses_addchstr.3 addchnstr.3 \
curses_tty.3 noqiflush.3 \
curses_tty.3 noraw.3 curses_input.3 notimeout.3 \
curses_window.3 overlay.3 curses_window.3 overwrite.3 \
curses_color.3 pair_content.3 curses_pad.3 pnoutrefresh.3 \
curses_color.3 pair_content.3 curses_echochar.3 pechochar.3 \
curses_pad.3 pnoutrefresh.3 \
curses_pad.3 prefresh.3 curses_print.3 printw.3 \
curses_tty.3 qiflush.3 \
curses_tty.3 raw.3 curses_refresh.3 refresh.3 \
@ -144,6 +145,7 @@ MLINKS+= curses_addch.3 addch.3 curses_addchstr.3 addchnstr.3 \
curses_clear.3 wclear.3 curses_clear.3 wclrtobot.3 \
curses_clear.3 wclrtoeol.3 curses_attributes.3 wcolor_set.3 \
curses_delch.3 wdelch.3 curses_deleteln.3 wdeleteln.3 \
curses_echochar.3 wechochar.3 \
curses_clear.3 werase.3 curses_input.3 wgetch.3 \
curses_input.3 wgetnstr.3 curses_input.3 wgetstr.3 \
curses_line.3 whline.3 curses_inch.3 winch.3 \

View File

@ -451,6 +451,13 @@ Creates an exact copy of the window
.De
Sets the terminal to echo characters.
.Ds
.Fn echochar "const chtype ch" \(dg
.De
Add the character
.Vn ch
on the window
at the current \*y and immediately refresh the window.
.Ds
.Fn endwin ""
.De
Finish up window routines before exit.
@ -1256,6 +1263,13 @@ become blank on
Get the foreground and background colors of pair
.Vn pair .
.Ds
.Fn pechochar "const chtype ch" \(dg
.De
Add the character
.Vn ch
on the pad
at the current \*y and immediately refresh the pad.
.Ds
.Fn pnoutrefresh "WINDOW *pad" "int pbeg_y" "int pbeg_x" "int sbeg_y" "int sbeg_x" "int smax_y" "int smax_x"
.De
Add the pad contents to a virtual screen. Several pads can be added
@ -1688,6 +1702,7 @@ specification of a window, rather than the use of the default
.Fn wclrtoeol "WINDOW *win"
.Fn wdelch "WINDOW *win"
.Fn wdeleteln "WINDOW *win"
.Fn wechochar "WINDOW *win" "chtype ch"
.Fn werase "WINDOW *win"
.Fn wgetch "WINDOW *win"
.Fn wgetnstr "WINDOW *win" "char *str" "int len"

View File

@ -1,4 +1,4 @@
/* $NetBSD: curses.h,v 1.85 2004/03/23 21:35:29 jdc Exp $ */
/* $NetBSD: curses.h,v 1.86 2004/03/28 08:58:37 jdc Exp $ */
/*
* Copyright (c) 1981, 1993, 1994
@ -338,6 +338,7 @@ extern int ESCDELAY; /* Delay between keys in esc seq's. */
#define color_set(c, o) wcolor_set(stdscr, c, o)
#define delch() wdelch(stdscr)
#define deleteln() wdeleteln(stdscr)
#define echochar(c) wechochar(stdscr, c)
#define erase() werase(stdscr)
#define getch() wgetch(stdscr)
#define getnstr(s, n) wgetnstr(stdscr, s, n)
@ -442,6 +443,7 @@ int clrtoeol(void);
int color_set(short, void *);
int delch(void);
int deleteln(void);
int echochar(const chtype);
int erase(void);
int getch(void);
int getnstr(char *, int);
@ -600,6 +602,7 @@ int notimeout(WINDOW *, bool);
int overlay(const WINDOW *, WINDOW *);
int overwrite(const WINDOW *, WINDOW *);
int pair_content(short, short *, short *);
int pechochar(WINDOW *, const chtype);
int pnoutrefresh(WINDOW *, int, int, int, int, int, int);
int prefresh(WINDOW *, int, int, int, int, int, int);
int printw(const char *, ...)
@ -653,6 +656,7 @@ int wclrtoeol(WINDOW *);
int wcolor_set(WINDOW *, short, void *);
int wdelch(WINDOW *);
int wdeleteln(WINDOW *);
int wechochar(WINDOW *, const chtype);
int werase(WINDOW *);
int wgetch(WINDOW *);
int wgetnstr(WINDOW *, char *, int);

View File

@ -1,4 +1,4 @@
/* $NetBSD: curses_private.h,v 1.35 2004/03/22 18:57:38 jdc Exp $ */
/* $NetBSD: curses_private.h,v 1.36 2004/03/28 08:58:37 jdc Exp $ */
/*-
* Copyright (c) 1998-2000 Brett Lymn
@ -124,6 +124,9 @@ struct __window { /* Window structure. */
attr_t battr; /* Background attributes */
int scr_t, scr_b; /* Scrolling region top, bottom */
SCREEN *screen; /* Screen for this window */
int pbegy, pbegx,
sbegy, sbegx,
smaxy, smaxx; /* Saved prefresh() values */
};
/* Set of attributes unset by 'me' - 'mb', 'md', 'mh', 'mk', 'mp' and 'mr'. */

View File

@ -1,4 +1,4 @@
/* $NetBSD: newwin.c,v 1.41 2003/08/07 16:44:22 agc Exp $ */
/* $NetBSD: newwin.c,v 1.42 2004/03/28 08:58:37 jdc Exp $ */
/*
* Copyright (c) 1981, 1993, 1994
@ -34,7 +34,7 @@
#if 0
static char sccsid[] = "@(#)newwin.c 8.3 (Berkeley) 7/27/94";
#else
__RCSID("$NetBSD: newwin.c,v 1.41 2003/08/07 16:44:22 agc Exp $");
__RCSID("$NetBSD: newwin.c,v 1.42 2004/03/28 08:58:37 jdc Exp $");
#endif
#endif /* not lint */
@ -348,9 +348,15 @@ __makenew(SCREEN *screen, int nlines, int ncols, int by, int bx, int sub,
win->battr = 0;
win->scr_t = 0;
win->scr_b = win->maxy - 1;
if (ispad)
if (ispad) {
win->flags |= __ISPAD;
else
win->pbegy = 0;
win->pbegx = 0;
win->sbegy = 0;
win->sbegx = 0;
win->smaxy = 0;
win->smaxx = 0;
} else
__swflags(win);
#ifdef DEBUG
__CTRACE("makenew: win->wattr = %08x\n", win->wattr);

View File

@ -1,4 +1,4 @@
/* $NetBSD: refresh.c,v 1.58 2003/08/07 16:44:23 agc Exp $ */
/* $NetBSD: refresh.c,v 1.59 2004/03/28 08:58:37 jdc Exp $ */
/*
* Copyright (c) 1981, 1993, 1994
@ -34,7 +34,7 @@
#if 0
static char sccsid[] = "@(#)refresh.c 8.7 (Berkeley) 8/13/94";
#else
__RCSID("$NetBSD: refresh.c,v 1.58 2003/08/07 16:44:23 agc Exp $");
__RCSID("$NetBSD: refresh.c,v 1.59 2004/03/28 08:58:37 jdc Exp $");
#endif
#endif /* not lint */
@ -340,6 +340,13 @@ prefresh(WINDOW *pad, int pbegy, int pbegx, int sbegy, int sbegx,
#ifdef DEBUG
__CTRACE("prefresh: pad %p, flags 0x%08x\n", pad, pad->flags);
#endif
/* Retain values in case pechochar() is called. */
pad->pbegy = pbegy;
pad->pbegx = pbegx;
pad->sbegy = sbegy;
pad->sbegx = sbegx;
pad->smaxy = smaxy;
pad->smaxx = smaxx;
/* Use pnoutrefresh() to avoid duplicating code here */
retval = pnoutrefresh(pad, pbegy, pbegx, sbegy, sbegx, smaxy, smaxx);