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

Comparing rxvt-unicode/src/main.C (file contents):
Revision 1.290 by ayin, Tue Dec 18 12:52:30 2007 UTC vs.
Revision 1.291 by root, Mon Dec 24 06:51:37 2007 UTC

170#endif 170#endif
171#if defined(MOUSE_WHEEL) && defined(MOUSE_SLIP_WHEELING) 171#if defined(MOUSE_WHEEL) && defined(MOUSE_SLIP_WHEELING)
172 slip_wheel_ev.set <rxvt_term, &rxvt_term::slip_wheel_cb> (this); 172 slip_wheel_ev.set <rxvt_term, &rxvt_term::slip_wheel_cb> (this);
173#endif 173#endif
174#if ENABLE_TRANSPARENCY || ENABLE_PERL 174#if ENABLE_TRANSPARENCY || ENABLE_PERL
175 rootwin_ev.set <rxvt_term, &rxvt_term::x_cb> (this), 175 rootwin_ev.set <rxvt_term, &rxvt_term::rootwin_cb> (this),
176#endif 176#endif
177#ifdef HAVE_SCROLLBARS 177#ifdef HAVE_SCROLLBARS
178 scrollbar_ev.set <rxvt_term, &rxvt_term::x_cb> (this), 178 scrollbar_ev.set <rxvt_term, &rxvt_term::x_cb> (this),
179#endif 179#endif
180#ifdef USE_XIM 180#ifdef USE_XIM
521 521
522#ifdef ENABLE_TRANSPARENCY 522#ifdef ENABLE_TRANSPARENCY
523 if (option (Opt_transparent)) 523 if (option (Opt_transparent))
524 { 524 {
525 bgPixmap.set_transparent (); 525 bgPixmap.set_transparent ();
526
526#ifdef HAVE_AFTERIMAGE 527#ifdef HAVE_AFTERIMAGE
527 if (rs [Rs_blurradius]) 528 if (rs [Rs_blurradius])
528 bgPixmap.set_blur_radius (rs [Rs_blurradius]); 529 bgPixmap.set_blur_radius (rs [Rs_blurradius]);
529#endif 530#endif
530 if (ISSET_PIXCOLOR (Color_tint)) 531 if (ISSET_PIXCOLOR (Color_tint))
531 bgPixmap.set_tint (pix_colors_focused [Color_tint]); 532 bgPixmap.set_tint (pix_colors_focused [Color_tint]);
533
532 if (rs [Rs_shade]) 534 if (rs [Rs_shade])
533 bgPixmap.set_shade (rs [Rs_shade]); 535 bgPixmap.set_shade (rs [Rs_shade]);
534 536
535 bgPixmap.set_root_pixmap (); 537 bgPixmap.set_root_pixmap ();
536 XSelectInput (dpy, display->root, PropertyChangeMask); 538 XSelectInput (dpy, display->root, PropertyChangeMask);
537 rootwin_ev.start (display, display->root); 539 rootwin_ev.start (display, display->root);
538 } 540 }
539#endif 541#endif
540 542
541#ifdef BG_IMAGE_FROM_FILE 543#ifdef BG_IMAGE_FROM_FILE
542 if (rs[Rs_backgroundPixmap] != NULL) 544 if (rs[Rs_backgroundPixmap])
543 { 545 {
544 const char *p = rs[Rs_backgroundPixmap]; 546 const char *p = rs[Rs_backgroundPixmap];
545 547
546 if ((p = strchr (p, ';')) != NULL) 548 if ((p = strchr (p, ';')) != 0)
547 { 549 {
548 p++; 550 p++;
549 bgPixmap.set_geometry (p); 551 bgPixmap.set_geometry (p);
550 } 552 }
551 else 553 else
1704} 1706}
1705 1707
1706#ifdef HAVE_BG_PIXMAP 1708#ifdef HAVE_BG_PIXMAP
1707# if TRACE_PIXMAPS 1709# if TRACE_PIXMAPS
1708# undef update_background 1710# undef update_background
1711void
1709int rxvt_term::trace_update_background (const char *file, int line) 1712rxvt_term::trace_update_background (const char *file, int line)
1710{ 1713{
1711 fprintf (stderr, "%s:%d:update_background()\n", file, line); 1714 fprintf (stderr, "%s:%d:update_background()\n", file, line);
1712 update_background (); 1715 update_background ();
1713} 1716}
1714# endif 1717# endif
1715 1718
1716int 1719void
1717rxvt_term::update_background () 1720rxvt_term::update_background ()
1718{ 1721{
1719 bgPixmap.invalidate (); 1722 bgPixmap.invalidate ();
1720 1723
1721 /* no chance of real time refresh if we are blurring! */ 1724 /* no chance of real time refresh if we are blurring! */
1722 if (bgPixmap.invalid_since + 0.5 < ev::now () && !(bgPixmap.flags & bgPixmap_t::blurNeeded)) 1725 if (bgPixmap.invalid_since + 0.50 < ev::now ()
1726 && !(bgPixmap.flags & bgPixmap_t::blurNeeded))
1727 {
1728 update_background_ev.stop ();
1723 bgPixmap.render (); 1729 bgPixmap.render ();
1730 }
1724 else 1731 else
1725 { 1732 {
1726 ev_tstamp refresh; 1733 ev_tstamp refresh;
1727 update_background_ev.stop ();
1728 1734
1729 if (!bgPixmap.need_client_side_rendering ()) 1735 if (!bgPixmap.need_client_side_rendering ())
1730 refresh = .05; 1736 refresh = .05;
1731 else if (bgPixmap.flags & bgPixmap_t::blurNeeded) 1737 else if (bgPixmap.flags & bgPixmap_t::blurNeeded)
1732 refresh = .20; /* very slow !!! */ 1738 refresh = .20; /* very slow !!! */
1733 else 1739 else
1734 refresh = .07; 1740 refresh = .07;
1741
1735 update_background_ev.start (refresh); 1742 update_background_ev.start (refresh);
1736 } 1743 }
1737
1738 return 0;
1739} 1744}
1740 1745
1741void 1746void
1742rxvt_term::update_background_cb (ev::timer &w, int revents) 1747rxvt_term::update_background_cb (ev::timer &w, int revents)
1743{ 1748{

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines