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

Comparing rxvt-unicode/src/screen.C (file contents):
Revision 1.419 by root, Fri Jun 1 08:12:09 2012 UTC vs.
Revision 1.432 by sf-exg, Sun Jan 13 22:30:47 2013 UTC

169 tsize -= tsize % sizeof (rend_t); 169 tsize -= tsize % sizeof (rend_t);
170 170
171 int all_rows = total_rows + nrow + nrow; 171 int all_rows = total_rows + nrow + nrow;
172 172
173 chunk_size = (sizeof (line_t) + rsize + tsize) * all_rows; 173 chunk_size = (sizeof (line_t) + rsize + tsize) * all_rows;
174 chunk = rxvt_malloc (chunk_size); 174 chunk = chunk_alloc (chunk_size, 0);
175 175
176 char *base = (char *)chunk + sizeof (line_t) * all_rows; 176 char *base = (char *)chunk + sizeof (line_t) * all_rows;
177 177
178 for (int row = 0; row < all_rows; ++row) 178 for (int row = 0; row < all_rows; ++row)
179 { 179 {
188 drawn_buf = (line_t *)chunk; 188 drawn_buf = (line_t *)chunk;
189 swap_buf = drawn_buf + nrow; 189 swap_buf = drawn_buf + nrow;
190 row_buf = swap_buf + nrow; 190 row_buf = swap_buf + nrow;
191} 191}
192 192
193void
194rxvt_term::copy_line (line_t &dst, line_t &src)
195{
196 scr_blank_screen_mem (dst, DEFAULT_RSTYLE);
197 dst.l = min (src.l, ncol);
198 memcpy (dst.t, src.t, sizeof (text_t) * dst.l);
199 memcpy (dst.r, src.r, sizeof (rend_t) * dst.l);
200 dst.f = src.f;
201}
202
193void ecb_cold 203void ecb_cold
194rxvt_term::scr_reset () 204rxvt_term::scr_reset ()
195{ 205{
196#if ENABLE_OVERLAY 206#if ENABLE_OVERLAY
197 scr_overlay_off (); 207 scr_overlay_off ();
225 235
226 screen.tscroll = 0; 236 screen.tscroll = 0;
227 screen.bscroll = nrow - 1; 237 screen.bscroll = nrow - 1;
228 238
229 void *prev_chunk = chunk; 239 void *prev_chunk = chunk;
240 size_t prev_chunk_size = chunk_size;
230 line_t *prev_drawn_buf = drawn_buf; 241 line_t *prev_drawn_buf = drawn_buf;
231 line_t *prev_swap_buf = swap_buf; 242 line_t *prev_swap_buf = swap_buf;
232 line_t *prev_row_buf = row_buf; 243 line_t *prev_row_buf = row_buf;
233
234 int common_col = min (prev_ncol, ncol);
235 244
236 scr_alloc (); 245 scr_alloc ();
237 246
238 if (!prev_row_buf) 247 if (!prev_row_buf)
239 { 248 {
274 * add or delete rows as appropriate 283 * add or delete rows as appropriate
275 */ 284 */
276 285
277 for (int row = min (nrow, prev_nrow); row--; ) 286 for (int row = min (nrow, prev_nrow); row--; )
278 { 287 {
279 scr_blank_screen_mem (drawn_buf [row], DEFAULT_RSTYLE); 288 copy_line (drawn_buf [row], prev_drawn_buf [row]);
280 scr_blank_screen_mem (swap_buf [row], DEFAULT_RSTYLE); 289 copy_line (swap_buf [row], prev_swap_buf [row]);
281
282 memcpy (drawn_buf [row].t, prev_drawn_buf [row].t, sizeof (text_t) * common_col);
283 memcpy (drawn_buf [row].r, prev_drawn_buf [row].r, sizeof (rend_t) * common_col);
284 memcpy (swap_buf [row].t, prev_swap_buf [row].t, sizeof (text_t) * common_col);
285 memcpy (swap_buf [row].r, prev_swap_buf [row].r, sizeof (rend_t) * common_col);
286 } 290 }
287 291
288 int p = MOD (term_start + prev_nrow, prev_total_rows); // previous row 292 int p = MOD (term_start + prev_nrow, prev_total_rows); // previous row
289 int pend = MOD (term_start + top_row , prev_total_rows); 293 int pend = MOD (term_start + top_row , prev_total_rows);
290 int q = total_rows; // rewrapped row 294 int q = total_rows; // rewrapped row
385 for (int row = min (nrow, prev_nrow); row--; ) 389 for (int row = min (nrow, prev_nrow); row--; )
386 { 390 {
387 line_t &src = prev_row_buf [MOD (term_start + row, prev_total_rows)]; 391 line_t &src = prev_row_buf [MOD (term_start + row, prev_total_rows)];
388 line_t &dst = row_buf [row]; 392 line_t &dst = row_buf [row];
389 393
390 scr_blank_screen_mem (dst, DEFAULT_RSTYLE); 394 copy_line (dst, src);
391
392 memcpy (dst.t, src.t, sizeof (text_t) * common_col);
393 memcpy (dst.r, src.r, sizeof (rend_t) * common_col);
394 } 395 }
395 396
396 for (int row = prev_nrow; row < nrow; row++) 397 for (int row = prev_nrow; row < nrow; row++)
397 scr_blank_screen_mem (row_buf [row], DEFAULT_RSTYLE); 398 scr_blank_screen_mem (row_buf [row], DEFAULT_RSTYLE);
398 399
408 if (!ROW (row).valid ()) scr_blank_screen_mem (ROW (row), DEFAULT_RSTYLE); 409 if (!ROW (row).valid ()) scr_blank_screen_mem (ROW (row), DEFAULT_RSTYLE);
409 if (!swap_buf [row].valid ()) scr_blank_screen_mem (swap_buf [row], DEFAULT_RSTYLE); 410 if (!swap_buf [row].valid ()) scr_blank_screen_mem (swap_buf [row], DEFAULT_RSTYLE);
410 if (!drawn_buf [row].valid ()) scr_blank_screen_mem (drawn_buf [row], DEFAULT_RSTYLE); 411 if (!drawn_buf [row].valid ()) scr_blank_screen_mem (drawn_buf [row], DEFAULT_RSTYLE);
411 } 412 }
412 413
413 free (prev_chunk); 414 chunk_free (prev_chunk, prev_chunk_size);
414 415
415 free (tabs); 416 free (tabs);
416 tabs = (char *)rxvt_malloc (ncol); 417 tabs = (char *)rxvt_malloc (ncol);
417 418
418 for (int col = ncol; col--; ) 419 for (int col = ncol; col--; )
429} 430}
430 431
431void ecb_cold 432void ecb_cold
432rxvt_term::scr_release () NOTHROW 433rxvt_term::scr_release () NOTHROW
433{ 434{
434 free (chunk); chunk = 0; row_buf = 0; 435 chunk_free (chunk, chunk_size);
435 free (tabs); tabs = 0; 436 chunk = 0;
437 row_buf = 0;
438
439 free (tabs);
440 tabs = 0;
436} 441}
437 442
438/* ------------------------------------------------------------------------- */ 443/* ------------------------------------------------------------------------- */
439/* 444/*
440 * Hard/Soft reset 445 * Hard/Soft reset
1701 if (rvideo_state != on) 1706 if (rvideo_state != on)
1702 { 1707 {
1703 rvideo_state = on; 1708 rvideo_state = on;
1704 1709
1705 ::swap (pix_colors[Color_fg], pix_colors[Color_bg]); 1710 ::swap (pix_colors[Color_fg], pix_colors[Color_bg]);
1706#ifdef HAVE_BG_PIXMAP 1711#ifdef HAVE_IMG
1707 if (bg_pixmap == None) 1712 if (bg_img == 0)
1708#endif 1713#endif
1709 XSetWindowBackground (dpy, vt, pix_colors[Color_bg]); 1714 XSetWindowBackground (dpy, vt, pix_colors[Color_bg]);
1710 1715
1711 XGCValues gcvalue; 1716 XGCValues gcvalue;
1712 gcvalue.foreground = pix_colors[Color_fg]; 1717 gcvalue.foreground = pix_colors[Color_fg];
2046 */ 2051 */
2047 refresh_count = 0; 2052 refresh_count = 0;
2048 2053
2049 unsigned int old_screen_flags = screen.flags; 2054 unsigned int old_screen_flags = screen.flags;
2050 bool have_bg = 0; 2055 bool have_bg = 0;
2051#ifdef HAVE_BG_PIXMAP 2056#ifdef HAVE_IMG
2052 have_bg = bg_pixmap != None; 2057 have_bg = bg_img != 0;
2053#endif 2058#endif
2054 ocrow = oldcursor.row; /* is there an old outline cursor on screen? */ 2059 ocrow = oldcursor.row; /* is there an old outline cursor on screen? */
2055 2060
2056 /* 2061 /*
2057 * B: reverse any characters which are selected 2062 * B: reverse any characters which are selected
2527void ecb_cold 2532void ecb_cold
2528rxvt_term::scr_recolour (bool refresh) NOTHROW 2533rxvt_term::scr_recolour (bool refresh) NOTHROW
2529{ 2534{
2530 bool transparent = false; 2535 bool transparent = false;
2531 2536
2532#ifdef HAVE_BG_PIXMAP 2537#ifdef HAVE_IMG
2533 if (bg_pixmap != None) 2538 if (bg_img != 0)
2534 { 2539 {
2535# ifdef ENABLE_TRANSPARENCY 2540# if ENABLE_TRANSPARENCY
2536 if (bg_flags & BG_IS_TRANSPARENT) 2541 if (bg_flags & BG_IS_TRANSPARENT)
2537 { 2542 {
2538 XSetWindowBackgroundPixmap (dpy, parent, bg_pixmap); 2543 XSetWindowBackgroundPixmap (dpy, parent, bg_img->pm);
2539 XSetWindowBackgroundPixmap (dpy, vt, ParentRelative); 2544 XSetWindowBackgroundPixmap (dpy, vt, ParentRelative);
2540 2545
2541 transparent = true; 2546 transparent = true;
2542 } 2547 }
2543 else 2548 else
2544# endif 2549# endif
2545 { 2550 {
2546 XSetWindowBackground (dpy, parent, pix_colors[Color_border]); 2551 XSetWindowBackground (dpy, parent, pix_colors[Color_border]);
2547 XSetWindowBackgroundPixmap (dpy, vt, bg_pixmap); 2552 XSetWindowBackgroundPixmap (dpy, vt, bg_img->pm);
2548 } 2553 }
2549 } 2554 }
2550 else 2555 else
2551#endif 2556#endif
2552 { 2557 {
2559 if (scrollBar.win) 2564 if (scrollBar.win)
2560 { 2565 {
2561 if (transparent) 2566 if (transparent)
2562 XSetWindowBackgroundPixmap (dpy, scrollBar.win, ParentRelative); 2567 XSetWindowBackgroundPixmap (dpy, scrollBar.win, ParentRelative);
2563 else 2568 else
2564 XSetWindowBackground (dpy, scrollBar.win, pix_colors[Color_border]); 2569 XSetWindowBackground (dpy, scrollBar.win, pix_colors[scrollBar.color ()]);
2565 scrollBar.state = SB_STATE_IDLE; 2570 scrollBar.state = SB_STATE_IDLE;
2566 scrollBar.show (0); 2571 scrollBar.show (0);
2567 } 2572 }
2568 2573
2569 if (refresh) 2574 if (refresh)
3526 3531
3527 XSendEvent (dpy, rq.requestor, False, 0L, (XEvent *)&ev); 3532 XSendEvent (dpy, rq.requestor, False, 0L, (XEvent *)&ev);
3528} 3533}
3529 3534
3530/* ------------------------------------------------------------------------- */ 3535/* ------------------------------------------------------------------------- */
3531#ifdef USE_XIM 3536#if USE_XIM
3532void ecb_cold 3537void ecb_cold
3533rxvt_term::im_set_position (XPoint &pos) NOTHROW 3538rxvt_term::im_set_position (XPoint &pos) NOTHROW
3534{ 3539{
3535 XWindowAttributes xwa; 3540 XWindowAttributes xwa;
3536 3541

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines