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.418 by sf-exg, Mon May 28 21:13:36 2012 UTC vs.
Revision 1.430 by root, Sun Jan 13 20:16:40 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 {
225 225
226 screen.tscroll = 0; 226 screen.tscroll = 0;
227 screen.bscroll = nrow - 1; 227 screen.bscroll = nrow - 1;
228 228
229 void *prev_chunk = chunk; 229 void *prev_chunk = chunk;
230 size_t prev_chunk_size = chunk_size;
230 line_t *prev_drawn_buf = drawn_buf; 231 line_t *prev_drawn_buf = drawn_buf;
231 line_t *prev_swap_buf = swap_buf; 232 line_t *prev_swap_buf = swap_buf;
232 line_t *prev_row_buf = row_buf; 233 line_t *prev_row_buf = row_buf;
233 234
234 int common_col = min (prev_ncol, ncol); 235 int common_col = min (prev_ncol, ncol);
236 scr_alloc (); 237 scr_alloc ();
237 238
238 if (!prev_row_buf) 239 if (!prev_row_buf)
239 { 240 {
240 /* 241 /*
241 * first time called so just malloc everything: don't rely on realloc 242 * first time called (or after scr_release) so just malloc everything: don't rely on realloc
242 */ 243 */
243 top_row = 0; 244 top_row = 0;
244 term_start = 0; 245 term_start = 0;
245 246
246 memset (charsets, 'B', sizeof (charsets)); 247 memset (charsets, 'B', sizeof (charsets));
279 scr_blank_screen_mem (drawn_buf [row], DEFAULT_RSTYLE); 280 scr_blank_screen_mem (drawn_buf [row], DEFAULT_RSTYLE);
280 scr_blank_screen_mem (swap_buf [row], DEFAULT_RSTYLE); 281 scr_blank_screen_mem (swap_buf [row], DEFAULT_RSTYLE);
281 282
282 memcpy (drawn_buf [row].t, prev_drawn_buf [row].t, sizeof (text_t) * common_col); 283 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 (drawn_buf [row].r, prev_drawn_buf [row].r, sizeof (rend_t) * common_col);
285
284 memcpy (swap_buf [row].t, prev_swap_buf [row].t, sizeof (text_t) * common_col); 286 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); 287 memcpy (swap_buf [row].r, prev_swap_buf [row].r, sizeof (rend_t) * common_col);
288 swap_buf [row].l = min (prev_swap_buf [row].l, ncol);
289 swap_buf [row].f = prev_swap_buf [row].f;
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
389 393
390 scr_blank_screen_mem (dst, DEFAULT_RSTYLE); 394 scr_blank_screen_mem (dst, DEFAULT_RSTYLE);
391 395
392 memcpy (dst.t, src.t, sizeof (text_t) * common_col); 396 memcpy (dst.t, src.t, sizeof (text_t) * common_col);
393 memcpy (dst.r, src.r, sizeof (rend_t) * common_col); 397 memcpy (dst.r, src.r, sizeof (rend_t) * common_col);
398 dst.l = common_col;
394 } 399 }
395 400
396 for (int row = prev_nrow; row < nrow; row++) 401 for (int row = prev_nrow; row < nrow; row++)
397 scr_blank_screen_mem (row_buf [row], DEFAULT_RSTYLE); 402 scr_blank_screen_mem (row_buf [row], DEFAULT_RSTYLE);
398 403
408 if (!ROW (row).valid ()) scr_blank_screen_mem (ROW (row), DEFAULT_RSTYLE); 413 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); 414 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); 415 if (!drawn_buf [row].valid ()) scr_blank_screen_mem (drawn_buf [row], DEFAULT_RSTYLE);
411 } 416 }
412 417
413 free (prev_chunk); 418 chunk_free (prev_chunk, prev_chunk_size);
414 419
415 free (tabs); 420 free (tabs);
416 tabs = (char *)rxvt_malloc (ncol); 421 tabs = (char *)rxvt_malloc (ncol);
417 422
418 for (int col = ncol; col--; ) 423 for (int col = ncol; col--; )
426 tt_winch (); 431 tt_winch ();
427 432
428 HOOK_INVOKE ((this, HOOK_RESET, DT_END)); 433 HOOK_INVOKE ((this, HOOK_RESET, DT_END));
429} 434}
430 435
431/* ------------------------------------------------------------------------- */
432/*
433 * Free everything. That way malloc debugging can find leakage.
434 */
435void ecb_cold 436void ecb_cold
436rxvt_term::scr_release () NOTHROW 437rxvt_term::scr_release () NOTHROW
437{ 438{
438 free (chunk); 439 chunk_free (chunk, chunk_size);
440 chunk = 0;
441 row_buf = 0;
442
439 free (tabs); 443 free (tabs);
444 tabs = 0;
440} 445}
441 446
442/* ------------------------------------------------------------------------- */ 447/* ------------------------------------------------------------------------- */
443/* 448/*
444 * Hard/Soft reset 449 * Hard/Soft reset
446void ecb_cold 451void ecb_cold
447rxvt_term::scr_poweron () 452rxvt_term::scr_poweron ()
448{ 453{
449 scr_release (); 454 scr_release ();
450 455
451 row_buf = 0;
452 tabs = 0;
453 prev_nrow = prev_ncol = 0; 456 prev_nrow = prev_ncol = 0;
454 rvideo_mode = false; 457 rvideo_mode = false;
455 scr_soft_reset (); 458 scr_soft_reset ();
456 scr_reset (); 459 scr_reset ();
457 460
1707 if (rvideo_state != on) 1710 if (rvideo_state != on)
1708 { 1711 {
1709 rvideo_state = on; 1712 rvideo_state = on;
1710 1713
1711 ::swap (pix_colors[Color_fg], pix_colors[Color_bg]); 1714 ::swap (pix_colors[Color_fg], pix_colors[Color_bg]);
1712#ifdef HAVE_BG_PIXMAP 1715#ifdef HAVE_IMG
1713 if (bg_pixmap == None) 1716 if (bg_img == 0)
1714#endif 1717#endif
1715 XSetWindowBackground (dpy, vt, pix_colors[Color_bg]); 1718 XSetWindowBackground (dpy, vt, pix_colors[Color_bg]);
1716 1719
1717 XGCValues gcvalue; 1720 XGCValues gcvalue;
1718 gcvalue.foreground = pix_colors[Color_fg]; 1721 gcvalue.foreground = pix_colors[Color_fg];
2052 */ 2055 */
2053 refresh_count = 0; 2056 refresh_count = 0;
2054 2057
2055 unsigned int old_screen_flags = screen.flags; 2058 unsigned int old_screen_flags = screen.flags;
2056 bool have_bg = 0; 2059 bool have_bg = 0;
2057#ifdef HAVE_BG_PIXMAP 2060#ifdef HAVE_IMG
2058 have_bg = bg_pixmap != None; 2061 have_bg = bg_img != 0;
2059#endif 2062#endif
2060 ocrow = oldcursor.row; /* is there an old outline cursor on screen? */ 2063 ocrow = oldcursor.row; /* is there an old outline cursor on screen? */
2061 2064
2062 /* 2065 /*
2063 * B: reverse any characters which are selected 2066 * B: reverse any characters which are selected
2533void ecb_cold 2536void ecb_cold
2534rxvt_term::scr_recolour (bool refresh) NOTHROW 2537rxvt_term::scr_recolour (bool refresh) NOTHROW
2535{ 2538{
2536 bool transparent = false; 2539 bool transparent = false;
2537 2540
2538#ifdef HAVE_BG_PIXMAP 2541#ifdef HAVE_IMG
2539 if (bg_pixmap != None) 2542 if (bg_img != 0)
2540 { 2543 {
2541# ifdef ENABLE_TRANSPARENCY 2544# if ENABLE_TRANSPARENCY
2542 if (bg_flags & BG_IS_TRANSPARENT) 2545 if (bg_flags & BG_IS_TRANSPARENT)
2543 { 2546 {
2544 XSetWindowBackgroundPixmap (dpy, parent, bg_pixmap); 2547 XSetWindowBackgroundPixmap (dpy, parent, bg_img->pm);
2545 XSetWindowBackgroundPixmap (dpy, vt, ParentRelative); 2548 XSetWindowBackgroundPixmap (dpy, vt, ParentRelative);
2546 2549
2547 transparent = true; 2550 transparent = true;
2548 } 2551 }
2549 else 2552 else
2550# endif 2553# endif
2551 { 2554 {
2552 XSetWindowBackground (dpy, parent, pix_colors[Color_border]); 2555 XSetWindowBackground (dpy, parent, pix_colors[Color_border]);
2553 XSetWindowBackgroundPixmap (dpy, vt, bg_pixmap); 2556 XSetWindowBackgroundPixmap (dpy, vt, bg_img->pm);
2554 } 2557 }
2555 } 2558 }
2556 else 2559 else
2557#endif 2560#endif
2558 { 2561 {
2565 if (scrollBar.win) 2568 if (scrollBar.win)
2566 { 2569 {
2567 if (transparent) 2570 if (transparent)
2568 XSetWindowBackgroundPixmap (dpy, scrollBar.win, ParentRelative); 2571 XSetWindowBackgroundPixmap (dpy, scrollBar.win, ParentRelative);
2569 else 2572 else
2570 XSetWindowBackground (dpy, scrollBar.win, pix_colors[Color_border]); 2573 XSetWindowBackground (dpy, scrollBar.win, pix_colors[scrollBar.color ()]);
2571 scrollBar.state = SB_STATE_IDLE; 2574 scrollBar.state = SB_STATE_IDLE;
2572 scrollBar.show (0); 2575 scrollBar.show (0);
2573 } 2576 }
2574 2577
2575 if (refresh) 2578 if (refresh)
3532 3535
3533 XSendEvent (dpy, rq.requestor, False, 0L, (XEvent *)&ev); 3536 XSendEvent (dpy, rq.requestor, False, 0L, (XEvent *)&ev);
3534} 3537}
3535 3538
3536/* ------------------------------------------------------------------------- */ 3539/* ------------------------------------------------------------------------- */
3537#ifdef USE_XIM 3540#if USE_XIM
3538void ecb_cold 3541void ecb_cold
3539rxvt_term::im_set_position (XPoint &pos) NOTHROW 3542rxvt_term::im_set_position (XPoint &pos) NOTHROW
3540{ 3543{
3541 XWindowAttributes xwa; 3544 XWindowAttributes xwa;
3542 3545

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines