"Fossies" - the Fresh Open Source Software Archive 
Member "xterm-379/linedata.c" (18 Sep 2022, 8573 Bytes) of package /linux/misc/xterm-379.tgz:
As a special service "Fossies" has tried to format the requested source page into HTML format using (guessed) C and C++ source code syntax highlighting (style:
standard) with prefixed line numbers and
code folding option.
Alternatively you can here
view or
download the uninterpreted source code file.
For more information about "linedata.c" see the
Fossies "Dox" file reference documentation and the last
Fossies "Diffs" side-by-side code changes report:
372_vs_373.
1 /* $XTermId: linedata.c,v 1.102 2022/09/18 21:17:43 tom Exp $ */
2
3 /*
4 * Copyright 2009-2021,2022 by Thomas E. Dickey
5 *
6 * All Rights Reserved
7 *
8 * Permission is hereby granted, free of charge, to any person obtaining a
9 * copy of this software and associated documentation files (the
10 * "Software"), to deal in the Software without restriction, including
11 * without limitation the rights to use, copy, modify, merge, publish,
12 * distribute, sublicense, and/or sell copies of the Software, and to
13 * permit persons to whom the Software is furnished to do so, subject to
14 * the following conditions:
15 *
16 * The above copyright notice and this permission notice shall be included
17 * in all copies or substantial portions of the Software.
18 *
19 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
20 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
21 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
22 * IN NO EVENT SHALL THE ABOVE LISTED COPYRIGHT HOLDER(S) BE LIABLE FOR ANY
23 * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
24 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
25 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
26 *
27 * Except as contained in this notice, the name(s) of the above copyright
28 * holders shall not be used in advertising or otherwise to promote the
29 * sale, use or other dealings in this Software without prior written
30 * authorization.
31 */
32
33 #include <xterm.h>
34 #include <data.h>
35
36 #include <assert.h>
37
38 /*
39 * Given a row-number, find the corresponding data for the line in the VT100
40 * widget. Row numbers can be positive or negative.
41 *
42 * If the data comes from the scrollback, defer that to getScrollback().
43 */
44 LineData *
45 getLineData(TScreen *screen, int row)
46 {
47 LineData *result = 0;
48 ScrnBuf buffer;
49 int max_row = LastRowNumber(screen);
50
51 if (row >= 0) {
52 buffer = screen->visbuf;
53 } else {
54 buffer = 0;
55 result = getScrollback(screen, row);
56 }
57 if (row >= 0 && row <= max_row) {
58 result = (LineData *) scrnHeadAddr(screen, buffer, (unsigned) row);
59 }
60
61 return result;
62 }
63
64 /*
65 * Copy line's data, e.g., from one screen buffer to another, given the preset
66 * pointers for the destination.
67 *
68 * TODO: optionally prune unused combining character data from the result.
69 */
70 void
71 copyLineData(LineData *dst, CLineData *src)
72 {
73 if (dst == NULL || src == NULL || dst == src)
74 return;
75
76 dst->bufHead = src->bufHead;
77
78 #if OPT_WIDE_CHARS
79 dst->combSize = src->combSize;
80 #endif
81
82 /*
83 * Usually we're copying the same-sized line; a memcpy is faster than
84 * several loops.
85 */
86 if (dst->lineSize == src->lineSize) {
87 size_t size = (sizeof(dst->attribs[0])
88 #if OPT_ISO_COLORS
89 + sizeof(dst->color[0])
90 #endif
91 + sizeof(dst->charData[0])
92 #if OPT_WIDE_CHARS
93 + sizeof(dst->combData[0][0]) * dst->combSize
94 #endif
95 );
96
97 memcpy(dst->attribs, src->attribs, size * dst->lineSize);
98 } else {
99 Dimension col;
100 Dimension limit = ((dst->lineSize < src->lineSize)
101 ? dst->lineSize
102 : src->lineSize);
103 #if OPT_WIDE_CHARS
104 Char comb;
105 #endif
106
107 for (col = 0; col < limit; ++col) {
108 dst->attribs[col] = src->attribs[col];
109 #if OPT_ISO_COLORS
110 dst->color[col] = src->color[col];
111 #endif
112 dst->charData[col] = src->charData[col];
113 #if OPT_WIDE_CHARS
114 for (comb = 0; comb < dst->combSize; ++comb) {
115 dst->combData[comb][col] = src->combData[comb][col];
116 }
117 #endif
118 }
119 for (col = limit; col < dst->lineSize; ++col) {
120 dst->attribs[col] = 0;
121 #if OPT_ISO_COLORS
122 dst->color[col] = initCColor;
123 #endif
124 dst->charData[col] = 0;
125 #if OPT_WIDE_CHARS
126 for (comb = 0; comb < dst->combSize; ++comb) {
127 dst->combData[comb][col] = 0;
128 }
129 #endif
130 }
131 }
132 }
133
134 #if OPT_WIDE_CHARS
135 #define initLineExtra(screen) \
136 screen->lineExtra = ((size_t) (screen->max_combining) * sizeof(IChar *)); \
137 screen->cellExtra = ((size_t) (screen->max_combining) * sizeof(IChar))
138 #else
139 #define initLineExtra(screen) \
140 screen->lineExtra = 0; \
141 screen->cellExtra = 0
142 #endif
143
144 /*
145 * CellData size depends on the "combiningChars" resource.
146 */
147 #define CellDataSize(screen) (SizeOfCellData + screen->cellExtra)
148
149 #define CellDataAddr(screen, data, cell) \
150 ( (CellData *)(void *) ((char *)data + (cell * CellDataSize(screen))) )
151 #define ConstCellDataAddr(screen, data, cell) \
152 ( (const CellData *)(const void *) ( \
153 (const char *)data + (cell * CellDataSize(screen))) )
154
155 void
156 initLineData(XtermWidget xw)
157 {
158 TScreen *screen = TScreenOf(xw);
159
160 initLineExtra(screen);
161
162 #if OPT_WIDE_CHARS
163 TRACE(("initLineData %lu (%d combining chars)\n",
164 (unsigned long) screen->lineExtra, screen->max_combining));
165 #else
166 TRACE(("initLineData\n"));
167 #endif
168
169 /*
170 * Per-line size/offsets.
171 */
172 TRACE(("** sizeof(LineData) %lu\n", (unsigned long) sizeof(LineData)));
173 TRACE((" offset(lineSize) %lu\n", (unsigned long) offsetof(LineData, lineSize)));
174 TRACE((" offset(bufHead) %lu\n", (unsigned long) offsetof(LineData, bufHead)));
175 #if OPT_WIDE_CHARS
176 TRACE((" offset(combSize) %lu\n", (unsigned long) offsetof(LineData, combSize)));
177 #endif
178 TRACE((" offset(*attribs) %lu\n", (unsigned long) offsetof(LineData, attribs)));
179 #if OPT_ISO_COLORS
180 TRACE((" offset(*color) %lu\n", (unsigned long) offsetof(LineData, color)));
181 #endif
182 TRACE((" offset(*charData) %lu\n", (unsigned long) offsetof(LineData, charData)));
183 TRACE((" offset(*combData) %lu\n", (unsigned long) offsetof(LineData, combData)));
184
185 /*
186 * Per-cell size/offsets.
187 */
188 TRACE(("** sizeof(CellData) %lu\n", (unsigned long) CellDataSize(screen)));
189 TRACE((" offset(attribs) %lu\n", (unsigned long) offsetof(CellData, attribs)));
190 #if OPT_WIDE_CHARS
191 TRACE((" offset(combSize) %lu\n", (unsigned long) offsetof(CellData, combSize)));
192 #endif
193 #if OPT_ISO_COLORS
194 TRACE((" offset(color) %lu\n", (unsigned long) offsetof(CellData, color)));
195 #endif
196 TRACE((" offset(charData) %lu\n", (unsigned long) offsetof(CellData, charData)));
197 TRACE((" offset(combData) %lu\n", (unsigned long) offsetof(CellData, combData)));
198
199 /*
200 * Data-type sizes.
201 */
202 #if OPT_ISO_COLORS
203 TRACE(("** sizeof(CellColor) %lu\n", (unsigned long) sizeof(CellColor)));
204 #endif
205 TRACE(("** sizeof(IAttr) %lu\n", (unsigned long) sizeof(IAttr)));
206 TRACE(("** sizeof(IChar) %lu\n", (unsigned long) sizeof(IChar)));
207 TRACE(("** sizeof(RowData) %lu\n", (unsigned long) sizeof(RowData)));
208 }
209
210 CellData *
211 newCellData(XtermWidget xw, Cardinal count)
212 {
213 CellData *result;
214 TScreen *screen = TScreenOf(xw);
215
216 initLineExtra(screen);
217 result = (CellData *) calloc((size_t) count, (size_t) CellDataSize(screen));
218 return result;
219 }
220
221 void
222 saveCellData(TScreen *screen,
223 CellData *data,
224 Cardinal cell,
225 CLineData *ld,
226 XTermRect *limits,
227 int column)
228 {
229 CellData *item = CellDataAddr(screen, data, cell);
230
231 (void) limits;
232 if (column < MaxCols(screen)) {
233 item->attribs = ld->attribs[column];
234 if_OPT_ISO_COLORS(screen, {
235 item->color = ld->color[column];
236 });
237 item->charData = ld->charData[column];
238 if_OPT_WIDE_CHARS(screen, {
239 size_t off;
240 Bool blank = (((item->charData == HIDDEN_CHAR)
241 && (limits == NULL
242 || (column + 1) == limits->left))
243 || (item->charData != HIDDEN_CHAR
244 && WideCells(item->charData) > 1
245 && (limits == NULL
246 || (column + 1) >= limits->right)));
247 if (blank) {
248 item->charData = (CharData) ' ';
249 }
250 item->combSize = blank ? 0 : ld->combSize;
251 for_each_combData(off, item) {
252 item->combData[off] = ld->combData[off][column];
253 }
254 });
255 TRACE2(("SAVED::%s\n", visibleIChars(&(item->charData), 1)));
256 }
257 }
258
259 void
260 restoreCellData(TScreen *screen,
261 const CellData *data,
262 Cardinal cell,
263 LineData *ld,
264 XTermRect *limits,
265 int column)
266 {
267 const CellData *item = ConstCellDataAddr(screen, data, cell);
268
269 (void) limits;
270 if (column < MaxCols(screen)) {
271 ld->attribs[column] = item->attribs;
272 TRACE2(("BEFORE:%2d:%s\n", column + 1, visibleIChars(ld->charData, ld->lineSize)));
273 if_OPT_ISO_COLORS(screen, {
274 ld->color[column] = item->color;
275 });
276 ld->charData[column] = item->charData;
277 if_OPT_WIDE_CHARS(screen, {
278 size_t off;
279 ld->combSize = item->combSize;
280 for_each_combData(off, ld) {
281 ld->combData[off][column] = item->combData[off];
282 }
283 });
284 TRACE2(("AFTER::%2d:%s\n", column + 1, visibleIChars(ld->charData, ld->lineSize)));
285 }
286 }