Home | History | Annotate | Line # | Download | only in libcurses
addbytes.c revision 1.14.6.2
      1  1.14.6.2      jdc /*	$NetBSD: addbytes.c,v 1.14.6.2 2000/03/05 23:25:17 jdc Exp $	*/
      2      1.11    mikel 
      3       1.1      cgd /*
      4      1.10      cgd  * Copyright (c) 1987, 1993, 1994
      5       1.7      cgd  *	The Regents of the University of California.  All rights reserved.
      6       1.1      cgd  *
      7       1.1      cgd  * Redistribution and use in source and binary forms, with or without
      8       1.1      cgd  * modification, are permitted provided that the following conditions
      9       1.1      cgd  * are met:
     10       1.1      cgd  * 1. Redistributions of source code must retain the above copyright
     11       1.1      cgd  *    notice, this list of conditions and the following disclaimer.
     12       1.1      cgd  * 2. Redistributions in binary form must reproduce the above copyright
     13       1.1      cgd  *    notice, this list of conditions and the following disclaimer in the
     14       1.1      cgd  *    documentation and/or other materials provided with the distribution.
     15       1.1      cgd  * 3. All advertising materials mentioning features or use of this software
     16       1.1      cgd  *    must display the following acknowledgement:
     17       1.1      cgd  *	This product includes software developed by the University of
     18       1.1      cgd  *	California, Berkeley and its contributors.
     19       1.1      cgd  * 4. Neither the name of the University nor the names of its contributors
     20       1.1      cgd  *    may be used to endorse or promote products derived from this software
     21       1.1      cgd  *    without specific prior written permission.
     22       1.1      cgd  *
     23       1.1      cgd  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     24       1.1      cgd  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     25       1.1      cgd  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     26       1.1      cgd  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     27       1.1      cgd  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     28       1.1      cgd  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     29       1.1      cgd  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     30       1.1      cgd  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     31       1.1      cgd  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     32       1.1      cgd  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     33       1.1      cgd  * SUCH DAMAGE.
     34       1.1      cgd  */
     35       1.1      cgd 
     36      1.11    mikel #include <sys/cdefs.h>
     37       1.1      cgd #ifndef lint
     38      1.11    mikel #if 0
     39      1.10      cgd static char sccsid[] = "@(#)addbytes.c	8.4 (Berkeley) 5/4/94";
     40      1.11    mikel #else
     41  1.14.6.2      jdc __RCSID("$NetBSD: addbytes.c,v 1.14.6.2 2000/03/05 23:25:17 jdc Exp $");
     42      1.11    mikel #endif
     43      1.13      mrg #endif				/* not lint */
     44       1.1      cgd 
     45      1.10      cgd #include "curses.h"
     46       1.1      cgd 
     47       1.7      cgd #define	SYNCH_IN	{y = win->cury; x = win->curx;}
     48       1.7      cgd #define	SYNCH_OUT	{win->cury = y; win->curx = x;}
     49       1.3      alm 
     50       1.1      cgd /*
     51       1.5  mycroft  * waddbytes --
     52       1.5  mycroft  *	Add the character to the current position in the given window.
     53       1.1      cgd  */
     54       1.5  mycroft int
     55      1.13      mrg __waddbytes(win, bytes, count, attr)
     56  1.14.6.1      jdc 	WINDOW		*win;
     57      1.13      mrg 	const char	*bytes;
     58  1.14.6.1      jdc 	int		 count;
     59  1.14.6.1      jdc 	attr_t		 attr;
     60       1.1      cgd {
     61  1.14.6.1      jdc 	static char	 blanks[] = "        ";
     62  1.14.6.1      jdc 	int		 c, newx, x, y;
     63  1.14.6.1      jdc 	attr_t		 attributes;
     64  1.14.6.1      jdc 	__LINE		*lp;
     65       1.5  mycroft 
     66       1.5  mycroft 	SYNCH_IN;
     67       1.1      cgd 
     68      1.11    mikel 	while (count--) {
     69      1.11    mikel 		c = *bytes++;
     70       1.5  mycroft #ifdef DEBUG
     71      1.13      mrg 		__CTRACE("ADDBYTES('%c') at (%d, %d)\n", c, y, x);
     72       1.5  mycroft #endif
     73       1.5  mycroft 		switch (c) {
     74       1.5  mycroft 		case '\t':
     75       1.5  mycroft 			SYNCH_OUT;
     76       1.5  mycroft 			if (waddbytes(win, blanks, 8 - (x % 8)) == ERR)
     77       1.5  mycroft 				return (ERR);
     78       1.5  mycroft 			SYNCH_IN;
     79       1.5  mycroft 			break;
     80       1.5  mycroft 
     81       1.5  mycroft 		default:
     82       1.5  mycroft #ifdef DEBUG
     83      1.13      mrg 			__CTRACE("ADDBYTES(%0.2o, %d, %d)\n", win, y, x);
     84       1.5  mycroft #endif
     85      1.14   simonb 
     86       1.7      cgd 			lp = win->lines[y];
     87       1.7      cgd 			if (lp->flags & __ISPASTEOL) {
     88       1.7      cgd 				lp->flags &= ~__ISPASTEOL;
     89      1.13      mrg 		newline:	if (y == win->maxy - 1) {
     90       1.7      cgd 					if (win->flags & __SCROLLOK) {
     91       1.7      cgd 						SYNCH_OUT;
     92       1.7      cgd 						scroll(win);
     93       1.7      cgd 						SYNCH_IN;
     94       1.7      cgd 						lp = win->lines[y];
     95      1.13      mrg 						x = 0;
     96      1.10      cgd 					} else
     97      1.10      cgd 						return (ERR);
     98       1.7      cgd 				} else {
     99       1.7      cgd 					y++;
    100       1.7      cgd 					lp = win->lines[y];
    101       1.7      cgd 					x = 0;
    102       1.7      cgd 				}
    103       1.7      cgd 				if (c == '\n')
    104       1.7      cgd 					break;
    105       1.7      cgd 			}
    106      1.14   simonb 
    107      1.13      mrg 			attributes = '\0';
    108  1.14.6.1      jdc 			if (win->wattr & __STANDOUT || attr & __STANDOUT)
    109      1.13      mrg 				attributes |= __STANDOUT;
    110  1.14.6.1      jdc 			if (win->wattr & __UNDERSCORE || attr & __UNDERSCORE)
    111      1.13      mrg 				attributes |= __UNDERSCORE;
    112  1.14.6.1      jdc 			if (win->wattr & __REVERSE || attr & __REVERSE)
    113      1.13      mrg 				attributes |= __REVERSE;
    114  1.14.6.1      jdc 			if (win->wattr & __BLINK || attr & __BLINK)
    115      1.13      mrg 				attributes |= __BLINK;
    116  1.14.6.1      jdc 			if (win->wattr & __DIM || attr & __DIM)
    117      1.13      mrg 				attributes |= __DIM;
    118  1.14.6.1      jdc 			if (win->wattr & __BOLD || attr & __BOLD)
    119      1.13      mrg 				attributes |= __BOLD;
    120  1.14.6.1      jdc 			if (win->wattr & __BLANK || attr & __BLANK)
    121      1.13      mrg 				attributes |= __BLANK;
    122  1.14.6.1      jdc 			if (win->wattr & __PROTECT || attr & __PROTECT)
    123      1.13      mrg 				attributes |= __PROTECT;
    124  1.14.6.2      jdc 			if (win->wattr & __ALTCHARSET || attr & __ALTCHARSET)
    125  1.14.6.2      jdc 				attributes |= __ALTCHARSET;
    126       1.5  mycroft #ifdef DEBUG
    127      1.13      mrg 			__CTRACE("ADDBYTES: 1: y = %d, x = %d, firstch = %d, lastch = %d\n",
    128      1.13      mrg 			    y, x, *win->lines[y]->firstchp,
    129      1.13      mrg 			    *win->lines[y]->lastchp);
    130       1.5  mycroft #endif
    131      1.13      mrg 			if (lp->line[x].ch != c ||
    132      1.13      mrg 			    !(lp->line[x].attr & attributes)) {
    133       1.7      cgd 				newx = x + win->ch_off;
    134       1.7      cgd 				if (!(lp->flags & __ISDIRTY)) {
    135       1.7      cgd 					lp->flags |= __ISDIRTY;
    136       1.7      cgd 					*lp->firstchp = *lp->lastchp = newx;
    137      1.13      mrg 				} else
    138      1.13      mrg 					if (newx < *lp->firstchp)
    139      1.13      mrg 						*lp->firstchp = newx;
    140      1.13      mrg 					else
    141      1.13      mrg 						if (newx > *lp->lastchp)
    142      1.13      mrg 							*lp->lastchp = newx;
    143       1.5  mycroft #ifdef DEBUG
    144      1.13      mrg 				__CTRACE("ADDBYTES: change gives f/l: %d/%d [%d/%d]\n",
    145      1.13      mrg 				    *lp->firstchp, *lp->lastchp,
    146      1.13      mrg 				    *lp->firstchp - win->ch_off,
    147      1.13      mrg 				    *lp->lastchp - win->ch_off);
    148       1.5  mycroft #endif
    149       1.5  mycroft 			}
    150       1.7      cgd 			lp->line[x].ch = c;
    151      1.13      mrg 			if (attributes & __STANDOUT)
    152       1.7      cgd 				lp->line[x].attr |= __STANDOUT;
    153       1.7      cgd 			else
    154       1.7      cgd 				lp->line[x].attr &= ~__STANDOUT;
    155      1.13      mrg 			if (attributes & __UNDERSCORE)
    156      1.13      mrg 				lp->line[x].attr |= __UNDERSCORE;
    157      1.13      mrg 			else
    158      1.13      mrg 				lp->line[x].attr &= ~__UNDERSCORE;
    159      1.13      mrg 			if (attributes & __REVERSE)
    160      1.13      mrg 				lp->line[x].attr |= __REVERSE;
    161      1.13      mrg 			else
    162      1.13      mrg 				lp->line[x].attr &= ~__REVERSE;
    163      1.13      mrg 			if (attributes & __BLINK)
    164      1.13      mrg 				lp->line[x].attr |= __BLINK;
    165      1.13      mrg 			else
    166      1.13      mrg 				lp->line[x].attr &= ~__BLINK;
    167      1.13      mrg 			if (attributes & __DIM)
    168      1.13      mrg 				lp->line[x].attr |= __DIM;
    169      1.13      mrg 			else
    170      1.13      mrg 				lp->line[x].attr &= ~__DIM;
    171      1.13      mrg 			if (attributes & __BOLD)
    172      1.13      mrg 				lp->line[x].attr |= __BOLD;
    173      1.13      mrg 			else
    174      1.13      mrg 				lp->line[x].attr &= ~__BOLD;
    175      1.13      mrg 			if (attributes & __BLANK)
    176      1.13      mrg 				lp->line[x].attr |= __BLANK;
    177      1.13      mrg 			else
    178      1.13      mrg 				lp->line[x].attr &= ~__BLANK;
    179      1.13      mrg 			if (attributes & __PROTECT)
    180      1.13      mrg 				lp->line[x].attr |= __PROTECT;
    181      1.13      mrg 			else
    182      1.13      mrg 				lp->line[x].attr &= ~__PROTECT;
    183  1.14.6.2      jdc 			if (attributes & __ALTCHARSET)
    184  1.14.6.2      jdc 				lp->line[x].attr |= __ALTCHARSET;
    185  1.14.6.2      jdc 			else
    186  1.14.6.2      jdc 				lp->line[x].attr &= ~__ALTCHARSET;
    187       1.7      cgd 			if (x == win->maxx - 1)
    188       1.7      cgd 				lp->flags |= __ISPASTEOL;
    189       1.7      cgd 			else
    190       1.7      cgd 				x++;
    191       1.5  mycroft #ifdef DEBUG
    192      1.13      mrg 			__CTRACE("ADDBYTES: 2: y = %d, x = %d, firstch = %d, lastch = %d\n",
    193      1.13      mrg 			    y, x, *win->lines[y]->firstchp,
    194      1.13      mrg 			    *win->lines[y]->lastchp);
    195       1.5  mycroft #endif
    196       1.5  mycroft 			break;
    197       1.5  mycroft 		case '\n':
    198       1.5  mycroft 			SYNCH_OUT;
    199       1.5  mycroft 			wclrtoeol(win);
    200       1.5  mycroft 			SYNCH_IN;
    201       1.7      cgd 			if (!NONL)
    202       1.5  mycroft 				x = 0;
    203       1.5  mycroft 			goto newline;
    204       1.5  mycroft 		case '\r':
    205       1.5  mycroft 			x = 0;
    206       1.5  mycroft 			break;
    207       1.5  mycroft 		case '\b':
    208       1.5  mycroft 			if (--x < 0)
    209       1.5  mycroft 				x = 0;
    210       1.5  mycroft 			break;
    211       1.5  mycroft 		}
    212       1.5  mycroft 	}
    213       1.5  mycroft 	SYNCH_OUT;
    214       1.5  mycroft 	return (OK);
    215       1.1      cgd }
    216