addbytes.c revision 1.6 1 1.1 cgd /*
2 1.1 cgd * Copyright (c) 1987 Regents of the University of California.
3 1.1 cgd * All rights reserved.
4 1.1 cgd *
5 1.1 cgd * Redistribution and use in source and binary forms, with or without
6 1.1 cgd * modification, are permitted provided that the following conditions
7 1.1 cgd * are met:
8 1.1 cgd * 1. Redistributions of source code must retain the above copyright
9 1.1 cgd * notice, this list of conditions and the following disclaimer.
10 1.1 cgd * 2. Redistributions in binary form must reproduce the above copyright
11 1.1 cgd * notice, this list of conditions and the following disclaimer in the
12 1.1 cgd * documentation and/or other materials provided with the distribution.
13 1.1 cgd * 3. All advertising materials mentioning features or use of this software
14 1.1 cgd * must display the following acknowledgement:
15 1.1 cgd * This product includes software developed by the University of
16 1.1 cgd * California, Berkeley and its contributors.
17 1.1 cgd * 4. Neither the name of the University nor the names of its contributors
18 1.1 cgd * may be used to endorse or promote products derived from this software
19 1.1 cgd * without specific prior written permission.
20 1.1 cgd *
21 1.1 cgd * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
22 1.1 cgd * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 1.1 cgd * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 1.1 cgd * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
25 1.1 cgd * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
26 1.1 cgd * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
27 1.1 cgd * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
28 1.1 cgd * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
29 1.1 cgd * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
30 1.1 cgd * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
31 1.1 cgd * SUCH DAMAGE.
32 1.1 cgd */
33 1.1 cgd
34 1.1 cgd #ifndef lint
35 1.5 mycroft /*static char sccsid[] = "from: @(#)addbytes.c 5.8 (Berkeley) 8/28/92";*/
36 1.6 mycroft static char rcsid[] = "$Id: addbytes.c,v 1.6 1993/08/15 16:23:57 mycroft Exp $";
37 1.5 mycroft #endif /* not lint */
38 1.1 cgd
39 1.5 mycroft #include <curses.h>
40 1.5 mycroft #include <termios.h>
41 1.1 cgd
42 1.5 mycroft #define SYNCH_IN {y = win->_cury; x = win->_curx;}
43 1.5 mycroft #define SYNCH_OUT {win->_cury = y; win->_curx = x;}
44 1.3 alm
45 1.1 cgd /*
46 1.5 mycroft * waddbytes --
47 1.5 mycroft * Add the character to the current position in the given window.
48 1.1 cgd */
49 1.5 mycroft int
50 1.5 mycroft waddbytes(win, bytes, count)
51 1.5 mycroft register WINDOW *win;
52 1.6 mycroft register const char *bytes;
53 1.5 mycroft register int count;
54 1.1 cgd {
55 1.5 mycroft static char blanks[] = " ";
56 1.5 mycroft register int c, newx, x, y;
57 1.5 mycroft
58 1.5 mycroft SYNCH_IN;
59 1.1 cgd
60 1.5 mycroft #ifdef DEBUG
61 1.5 mycroft __TRACE("ADDBYTES('%c') at (%d, %d)\n", c, y, x);
62 1.5 mycroft #endif
63 1.1 cgd while (count--) {
64 1.5 mycroft c = *bytes++;
65 1.5 mycroft switch (c) {
66 1.5 mycroft case '\t':
67 1.5 mycroft SYNCH_OUT;
68 1.5 mycroft if (waddbytes(win, blanks, 8 - (x % 8)) == ERR)
69 1.5 mycroft return (ERR);
70 1.5 mycroft SYNCH_IN;
71 1.5 mycroft break;
72 1.5 mycroft
73 1.5 mycroft default:
74 1.5 mycroft #ifdef DEBUG
75 1.5 mycroft __TRACE("ADDBYTES: 1: y = %d, x = %d, firstch = %d, lastch = %d\n",
76 1.5 mycroft y, x, win->_firstch[y], win->_lastch[y]);
77 1.5 mycroft #endif
78 1.5 mycroft if (win->_flags & _STANDOUT)
79 1.5 mycroft c |= _STANDOUT;
80 1.5 mycroft #ifdef DEBUG
81 1.5 mycroft __TRACE("ADDBYTES(%0.2o, %d, %d)\n", win, y, x);
82 1.5 mycroft #endif
83 1.5 mycroft if (win->_y[y][x] != c) {
84 1.5 mycroft newx = x + win->_ch_off;
85 1.5 mycroft if (win->_firstch[y] == _NOCHANGE)
86 1.5 mycroft win->_firstch[y] =
87 1.1 cgd win->_lastch[y] = newx;
88 1.5 mycroft else if (newx < win->_firstch[y])
89 1.5 mycroft win->_firstch[y] = newx;
90 1.5 mycroft else if (newx > win->_lastch[y])
91 1.5 mycroft win->_lastch[y] = newx;
92 1.5 mycroft #ifdef DEBUG
93 1.5 mycroft __TRACE("ADDBYTES: change gives f/l: %d/%d [%d/%d]\n",
94 1.5 mycroft win->_firstch[y], win->_lastch[y],
95 1.5 mycroft win->_firstch[y] - win->_ch_off,
96 1.5 mycroft win->_lastch[y] - win->_ch_off);
97 1.5 mycroft #endif
98 1.5 mycroft }
99 1.5 mycroft win->_y[y][x] = c;
100 1.5 mycroft if (++x >= win->_maxx) {
101 1.5 mycroft x = 0;
102 1.5 mycroft newline: if (++y >= win->_maxy)
103 1.5 mycroft if (win->_scroll) {
104 1.5 mycroft SYNCH_OUT;
105 1.5 mycroft scroll(win);
106 1.5 mycroft SYNCH_IN;
107 1.5 mycroft --y;
108 1.5 mycroft } else
109 1.5 mycroft return (ERR);
110 1.5 mycroft }
111 1.5 mycroft #ifdef DEBUG
112 1.5 mycroft __TRACE("ADDBYTES: 2: y = %d, x = %d, firstch = %d, lastch = %d\n",
113 1.5 mycroft y, x, win->_firstch[y], win->_lastch[y]);
114 1.5 mycroft #endif
115 1.5 mycroft break;
116 1.5 mycroft case '\n':
117 1.5 mycroft SYNCH_OUT;
118 1.5 mycroft wclrtoeol(win);
119 1.5 mycroft SYNCH_IN;
120 1.5 mycroft if (origtermio.c_oflag & ONLCR)
121 1.5 mycroft x = 0;
122 1.5 mycroft goto newline;
123 1.5 mycroft case '\r':
124 1.5 mycroft x = 0;
125 1.5 mycroft break;
126 1.5 mycroft case '\b':
127 1.5 mycroft if (--x < 0)
128 1.5 mycroft x = 0;
129 1.5 mycroft break;
130 1.5 mycroft }
131 1.5 mycroft }
132 1.5 mycroft SYNCH_OUT;
133 1.5 mycroft return (OK);
134 1.1 cgd }
135