ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/command.C
(Generate patch)

Comparing rxvt-unicode/src/command.C (file contents):
Revision 1.211 by root, Tue Dec 20 22:27:49 2005 UTC vs.
Revision 1.216 by root, Tue Dec 27 01:25:42 2005 UTC

141 || !IN_RANGE_EXC (y, 0, nrow)) 141 || !IN_RANGE_EXC (y, 0, nrow))
142 return; 142 return;
143 143
144 for (;;) 144 for (;;)
145 { 145 {
146 const line_t &l = ROW(-view_start); 146 const line_t &l = ROW(y - view_start);
147 147
148 text_t t = l.t[x]; 148 text_t t = l.t[x];
149 149
150 if (t != NOCHAR || !x) 150 if (t != NOCHAR || !x)
151 { 151 {
185 alloc = 0; 185 alloc = 0;
186 chr = &ch2; 186 chr = &ch2;
187 len = 1; 187 len = 1;
188 } 188 }
189 189
190 char attr[80]; // plenty
191
192 sprintf (attr, "%08x = fg %d bg %d%s%s%s%s%s%s",
193 (int)r,
194 GET_FGCOLOR (r), GET_BGCOLOR (r),
195 r & RS_Bold ? " bold" : "",
196 r & RS_Italic ? " italic" : "",
197 r & RS_Blink ? " blink" : "",
198 r & RS_RVid ? " rvid" : "",
199 r & RS_Uline ? " uline" : "",
200 r & RS_Careful ? " careful" : "");
201
190 int width = wcswidth (fname, wcslen (fname)); 202 int width = wcswidth (fname, wcslen (fname));
191 203
204 max_it (width, 8+5); // for char + hey
205 max_it (width, strlen (attr));
206
192 scr_overlay_new (0, -1, width < 8+5 ? 8+5 : width, len + 1); 207 scr_overlay_new (0, -1, width, len + 2);
193 208
194 r = SET_STYLE (OVERLAY_RSTYLE, GET_STYLE (r)); 209 r = SET_STYLE (OVERLAY_RSTYLE, GET_STYLE (r));
195 210
196 for (int y = 0; y < len; y++) 211 for (int y = 0; y < len; y++)
197 { 212 {
208#endif 223#endif
209 scr_overlay_set (11, y, ch, r); 224 scr_overlay_set (11, y, ch, r);
210 scr_overlay_set (12, y, NOCHAR, r); 225 scr_overlay_set (12, y, NOCHAR, r);
211 } 226 }
212 227
228 scr_overlay_set (0, len , attr);
213 scr_overlay_set (0, len, fname); 229 scr_overlay_set (0, len + 1, fname);
214 230
215 free (fname); 231 free (fname);
216 232
217#if ENABLE_COMBINING 233#if ENABLE_COMBINING
218 if (alloc) 234 if (alloc)
1067 if (n > 0) 1083 if (n > 0)
1068 { 1084 {
1069 cmdbuf_endp += n; 1085 cmdbuf_endp += n;
1070 return true; 1086 return true;
1071 } 1087 }
1072 else if (n < 0 && errno != EAGAIN) 1088 else if ((n < 0 && errno != EAGAIN && errno != EINTR) || n == 0)
1089 {
1090 pty_ev.stop ();
1091
1092 if (!(options & Opt_hold))
1073 destroy (); 1093 destroy ();
1094 }
1074 1095
1075 return false; 1096 return false;
1076} 1097}
1077 1098
1078void 1099void
1600 } 1621 }
1601 1622
1602 scroll_selection_lines = Pixel2Height (dist) 1623 scroll_selection_lines = Pixel2Height (dist)
1603 / SELECTION_SCROLL_LINE_SPEEDUP 1624 / SELECTION_SCROLL_LINE_SPEEDUP
1604 + 1; 1625 + 1;
1605 MIN_IT (scroll_selection_lines, 1626 min_it (scroll_selection_lines,
1606 SELECTION_SCROLL_MAX_LINES); 1627 SELECTION_SCROLL_MAX_LINES);
1607 } 1628 }
1608 else 1629 else
1609 { 1630 {
1610 /* we are within the text window, so we 1631 /* we are within the text window, so we
2451 nh += sy; 2472 nh += sy;
2452 ny = -sy; 2473 ny = -sy;
2453 sy = 0; 2474 sy = 0;
2454 } 2475 }
2455 2476
2456 MIN_IT (nw, (unsigned int) (wrootattr.width - sx)); 2477 min_it (nw, (unsigned int) (wrootattr.width - sx));
2457 MIN_IT (nh, (unsigned int) (wrootattr.height - sy)); 2478 min_it (nh, (unsigned int) (wrootattr.height - sy));
2458 2479
2459 XSync (disp, False); 2480 XSync (disp, False);
2460 allowedxerror = -1; 2481 allowedxerror = -1;
2461 image = XGetImage (disp, rootpixmap, sx, sy, nw, nh, AllPlanes, ZPixmap); 2482 image = XGetImage (disp, rootpixmap, sx, sy, nw, nh, AllPlanes, ZPixmap);
2462 2483
4372 } 4393 }
4373 4394
4374 memmove (v_buffer, v_buffer + written, v_buflen); 4395 memmove (v_buffer, v_buffer + written, v_buflen);
4375 } 4396 }
4376 else if (written != -1 || (errno != EAGAIN && errno != EINTR)) 4397 else if (written != -1 || (errno != EAGAIN && errno != EINTR))
4377 // original code just ignores this... 4398 pty_ev.set (EVENT_READ);
4378 destroy ();
4379} 4399}
4380 4400
4381/*----------------------- end-of-file (C source) -----------------------*/ 4401/*----------------------- end-of-file (C source) -----------------------*/
4382 4402

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines