Home | History | Annotate | Line # | Download | only in libcurses
instr.c revision 1.4
      1  1.4   blymn /*	$NetBSD: instr.c,v 1.4 2011/08/07 10:54:53 blymn Exp $	*/
      2  1.1  simonb 
      3  1.1  simonb /*
      4  1.1  simonb  * Copyright 2001 Wasabi Systems, Inc.
      5  1.1  simonb  * All rights reserved.
      6  1.1  simonb  *
      7  1.1  simonb  * Written by Simon Burge for Wasabi Systems, Inc.
      8  1.1  simonb  *
      9  1.1  simonb  * Redistribution and use in source and binary forms, with or without
     10  1.1  simonb  * modification, are permitted provided that the following conditions
     11  1.1  simonb  * are met:
     12  1.1  simonb  * 1. Redistributions of source code must retain the above copyright
     13  1.1  simonb  *    notice, this list of conditions and the following disclaimer.
     14  1.1  simonb  * 2. Redistributions in binary form must reproduce the above copyright
     15  1.1  simonb  *    notice, this list of conditions and the following disclaimer in the
     16  1.1  simonb  *    documentation and/or other materials provided with the distribution.
     17  1.1  simonb  * 3. All advertising materials mentioning features or use of this software
     18  1.1  simonb  *    must display the following acknowledgement:
     19  1.1  simonb  *      This product includes software developed for the NetBSD Project by
     20  1.1  simonb  *      Wasabi Systems, Inc.
     21  1.1  simonb  * 4. The name of Wasabi Systems, Inc. may not be used to endorse
     22  1.1  simonb  *    or promote products derived from this software without specific prior
     23  1.1  simonb  *    written permission.
     24  1.1  simonb  *
     25  1.1  simonb  * THIS SOFTWARE IS PROVIDED BY WASABI SYSTEMS, INC. ``AS IS'' AND ANY
     26  1.1  simonb  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     27  1.1  simonb  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     28  1.1  simonb  * ARE DISCLAIMED. IN NO EVENT SHALL WASABI SYSTEMS, INC. BE
     29  1.1  simonb  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     30  1.1  simonb  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     31  1.1  simonb  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     32  1.1  simonb  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     33  1.1  simonb  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     34  1.1  simonb  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
     35  1.1  simonb  * THE POSSIBILITY OF SUCH DAMAGE.
     36  1.1  simonb  */
     37  1.1  simonb 
     38  1.1  simonb #include <sys/cdefs.h>
     39  1.1  simonb #ifndef lint
     40  1.4   blymn __RCSID("$NetBSD: instr.c,v 1.4 2011/08/07 10:54:53 blymn Exp $");
     41  1.1  simonb #endif				/* not lint */
     42  1.1  simonb 
     43  1.1  simonb #include "curses.h"
     44  1.1  simonb #include "curses_private.h"
     45  1.1  simonb 
     46  1.1  simonb #ifndef _CURSES_USE_MACROS
     47  1.1  simonb 
     48  1.1  simonb /*
     49  1.1  simonb  * instr, innstr --
     50  1.1  simonb  *	Return a string of characters at cursor position from stdscr.
     51  1.1  simonb  */
     52  1.1  simonb __warn_references(instr,
     53  1.1  simonb     "warning: this program uses instr(), which is unsafe.")
     54  1.1  simonb int
     55  1.1  simonb instr(char *str)
     56  1.1  simonb {
     57  1.1  simonb 	return winstr(stdscr, str);
     58  1.1  simonb }
     59  1.1  simonb 
     60  1.1  simonb int
     61  1.1  simonb innstr(char *str, int n)
     62  1.1  simonb {
     63  1.1  simonb 	return winnstr(stdscr, str, n);
     64  1.1  simonb }
     65  1.1  simonb 
     66  1.1  simonb /*
     67  1.1  simonb  * mvinstr, mvinnstr --
     68  1.1  simonb  *      Return a string of characters at position (y, x) from stdscr.
     69  1.1  simonb  *	XXX: should be multi-byte characters for SUSv2.
     70  1.1  simonb  */
     71  1.1  simonb __warn_references(mvinstr,
     72  1.1  simonb     "warning: this program uses mvinstr(), which is unsafe.")
     73  1.1  simonb int
     74  1.1  simonb mvinstr(int y, int x, char *str)
     75  1.1  simonb {
     76  1.1  simonb 	return mvwinstr(stdscr, y, x, str);
     77  1.1  simonb }
     78  1.1  simonb 
     79  1.1  simonb int
     80  1.1  simonb mvinnstr(int y, int x, char *str, int n)
     81  1.1  simonb {
     82  1.1  simonb 	return mvwinnstr(stdscr, y, x, str, n);
     83  1.1  simonb }
     84  1.1  simonb 
     85  1.1  simonb /*
     86  1.1  simonb  * mvwinstr, mvwinnstr --
     87  1.1  simonb  *      Return an array characters at position (y, x) from the given window.
     88  1.1  simonb  *	XXX: should be multi-byte characters for SUSv2.
     89  1.1  simonb  */
     90  1.1  simonb __warn_references(mvwinstr,
     91  1.1  simonb     "warning: this program uses mvwinstr(), which is unsafe.")
     92  1.1  simonb int
     93  1.1  simonb mvwinstr(WINDOW *win, int y, int x, char *str)
     94  1.1  simonb {
     95  1.1  simonb 	if (wmove(win, y, x) == ERR)
     96  1.1  simonb 		return ERR;
     97  1.2   blymn 
     98  1.1  simonb 	return winstr(win, str);
     99  1.1  simonb }
    100  1.1  simonb 
    101  1.1  simonb int
    102  1.1  simonb mvwinnstr(WINDOW *win, int y, int x, char *str, int n)
    103  1.1  simonb {
    104  1.1  simonb 	if (wmove(win, y, x) == ERR)
    105  1.1  simonb 		return ERR;
    106  1.2   blymn 
    107  1.1  simonb 	return winnstr(win, str, n);
    108  1.1  simonb }
    109  1.1  simonb 
    110  1.1  simonb #endif	/* _CURSES_USE_MACROS */
    111  1.1  simonb 
    112  1.1  simonb /*
    113  1.1  simonb  * winstr, winnstr --
    114  1.1  simonb  *	Return a string of characters at cursor position.
    115  1.1  simonb  *	XXX: should be multi-byte characters for SUSv2.
    116  1.1  simonb  */
    117  1.1  simonb __warn_references(winstr,
    118  1.1  simonb     "warning: this program uses winstr(), which is unsafe.")
    119  1.1  simonb int
    120  1.1  simonb winstr(WINDOW *win, char *str)
    121  1.1  simonb {
    122  1.1  simonb 
    123  1.1  simonb 	return winnstr(win, str, -1);
    124  1.1  simonb }
    125  1.1  simonb 
    126  1.1  simonb /*
    127  1.1  simonb  * XXX: This should go in a manpage!
    128  1.1  simonb  * - winnstr() returns the number of characters copied only of if it is
    129  1.1  simonb  *   called with n >= 0 (ie, as inchnstr(), mvinchnstr(), mvwinchnstr()
    130  1.1  simonb  *   or winchnstr()).  If N < 0, it returns `OK'.
    131  1.1  simonb  * - SUSv2/xcurses doesn't document whether the trailing NUL is included
    132  1.1  simonb  *   in the length count or not.  For safety's sake it _is_ included.
    133  1.1  simonb  * - This implementation does not (yet) support multi-byte characters
    134  1.1  simonb  *   strings.
    135  1.1  simonb  */
    136  1.1  simonb int
    137  1.1  simonb winnstr(WINDOW *win, char *str, int n)
    138  1.1  simonb {
    139  1.1  simonb 	__LDATA	*end, *start;
    140  1.4   blymn 	int epos, sn;
    141  1.1  simonb 
    142  1.1  simonb 	if (str == NULL)
    143  1.1  simonb 		return ERR;
    144  1.1  simonb 
    145  1.4   blymn 	sn = n;
    146  1.3     roy 	start = &win->alines[win->cury]->line[win->curx];
    147  1.1  simonb 	/* (n - 1) to leave room for the trailing NUL */
    148  1.1  simonb 	if (n < 0 || (n - 1) > win->maxx - win->curx - 1) {
    149  1.1  simonb 		epos = win->maxx - 1;
    150  1.1  simonb 		n = win->maxx - win->curx;
    151  1.1  simonb 	} else {
    152  1.1  simonb 		/* extra -1 for trailing NUL */
    153  1.1  simonb 		epos = win->curx + n - 1 - 1;
    154  1.1  simonb 		n--;
    155  1.1  simonb 	}
    156  1.3     roy 	end = &win->alines[win->cury]->line[epos];
    157  1.1  simonb 
    158  1.1  simonb 	while (start <= end) {
    159  1.1  simonb 		*str = start->ch & __CHARTEXT;
    160  1.1  simonb 		str++;
    161  1.1  simonb 		start++;
    162  1.1  simonb 	}
    163  1.1  simonb 	*str = '\0';
    164  1.1  simonb 
    165  1.4   blymn 	if (sn < 0)
    166  1.1  simonb 		return OK;
    167  1.1  simonb 	else
    168  1.1  simonb 		return n;
    169  1.1  simonb }
    170