From 211326e37501ac01a66994a221020b75ab5f63f0 Mon Sep 17 00:00:00 2001 From: "Todd C. Miller" Date: Wed, 3 Dec 1997 05:21:47 +0000 Subject: Merge of ncurses-4.1-971129 --- lib/libcurses/lib_insstr.c | 53 ++++++++++++++++++++++++++-------------------- 1 file changed, 30 insertions(+), 23 deletions(-) (limited to 'lib/libcurses/lib_insstr.c') diff --git a/lib/libcurses/lib_insstr.c b/lib/libcurses/lib_insstr.c index c25071f76d5..de65b7bd457 100644 --- a/lib/libcurses/lib_insstr.c +++ b/lib/libcurses/lib_insstr.c @@ -1,3 +1,5 @@ +/* $OpenBSD: lib_insstr.c,v 1.3 1997/12/03 05:21:21 millert Exp $ */ + /*************************************************************************** * COPYRIGHT NOTICE * @@ -31,33 +33,38 @@ #include #include -MODULE_ID("Id: lib_insstr.c,v 1.9 1997/02/15 16:09:53 tom Exp $") +MODULE_ID("Id: lib_insstr.c,v 1.10 1997/09/20 15:02:34 juergen Exp $") int winsnstr(WINDOW *win, const char *str, int n) { -short oy = win->_cury; -short ox = win->_curx; +int code = ERR; +short oy; +short ox ; const char *cp; - T((T_CALLED("winsstr(%p,%s,%d)"), win, _nc_visbuf(str), n)); - - for (cp = str; *cp && (n <= 0 || (cp - str) < n); cp++) { - if (*cp == '\n' || *cp == '\r' || *cp == '\t' || *cp == '\b') - _nc_waddch_nosync(win, (chtype)(*cp)); - else if (is7bits(*cp) && iscntrl(*cp)) { - winsch(win, ' ' + (chtype)(*cp)); - winsch(win, '^'); - win->_curx += 2; - } else { - winsch(win, (chtype)(*cp)); - win->_curx++; - } - if (win->_curx > win->_maxx) - win->_curx = win->_maxx; - } + T((T_CALLED("winsstr(%p,%s,%d)"), win, _nc_visbuf(str), n)); - win->_curx = ox; - win->_cury = oy; - _nc_synchook(win); - returnCode(OK); + if (win && str) { + oy = win->_cury; ox = win->_curx; + for (cp = str; *cp && (n <= 0 || (cp - str) < n); cp++) { + if (*cp == '\n' || *cp == '\r' || *cp == '\t' || *cp == '\b') + _nc_waddch_nosync(win, (chtype)(*cp)); + else if (is7bits(*cp) && iscntrl(*cp)) { + winsch(win, ' ' + (chtype)(*cp)); + winsch(win, '^'); + win->_curx += 2; + } else { + winsch(win, (chtype)(*cp)); + win->_curx++; + } + if (win->_curx > win->_maxx) + win->_curx = win->_maxx; + } + + win->_curx = ox; + win->_cury = oy; + _nc_synchook(win); + code = OK; + } + returnCode(code); } -- cgit v1.2.3