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.288 by ayin, Tue Dec 18 01:36:24 2007 UTC vs.
Revision 1.294 by root, Fri Jan 4 19:12:23 2008 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
275#endif 275#endif
276 } 276 }
277 277
278 clear (); 278 clear ();
279 } 279 }
280
281 delete [] pix_colors_focused;
282#if OFF_FOCUS_FADING
283 delete [] pix_colors_unfocused;
284#endif
285 280
286#ifdef HAVE_BG_PIXMAP 281#ifdef HAVE_BG_PIXMAP
287 bgPixmap.destroy (); 282 bgPixmap.destroy ();
288#endif 283#endif
289 display->flush (); /* ideally .put should do this */ 284 display->flush (); /* ideally .put should do this */
521 516
522#ifdef ENABLE_TRANSPARENCY 517#ifdef ENABLE_TRANSPARENCY
523 if (option (Opt_transparent)) 518 if (option (Opt_transparent))
524 { 519 {
525 bgPixmap.set_transparent (); 520 bgPixmap.set_transparent ();
521
526#ifdef HAVE_AFTERIMAGE 522#ifdef HAVE_AFTERIMAGE
527 if (rs [Rs_blurradius]) 523 if (rs [Rs_blurradius])
528 bgPixmap.set_blur_radius (rs [Rs_blurradius]); 524 bgPixmap.set_blur_radius (rs [Rs_blurradius]);
529#endif 525#endif
530 if (ISSET_PIXCOLOR (Color_tint)) 526 if (ISSET_PIXCOLOR (Color_tint))
531 bgPixmap.set_tint (pix_colors_focused [Color_tint]); 527 bgPixmap.set_tint (pix_colors_focused [Color_tint]);
528
532 if (rs [Rs_shade]) 529 if (rs [Rs_shade])
533 bgPixmap.set_shade (rs [Rs_shade]); 530 bgPixmap.set_shade (rs [Rs_shade]);
534 531
535 bgPixmap.set_root_pixmap (); 532 bgPixmap.set_root_pixmap ();
536 XSelectInput (dpy, display->root, PropertyChangeMask); 533 XSelectInput (dpy, display->root, PropertyChangeMask);
537 rootwin_ev.start (display, display->root); 534 rootwin_ev.start (display, display->root);
538 } 535 }
539#endif 536#endif
540 537
541#ifdef BG_IMAGE_FROM_FILE 538#ifdef BG_IMAGE_FROM_FILE
542 if (rs[Rs_backgroundPixmap] != NULL) 539 if (rs[Rs_backgroundPixmap])
543 { 540 {
544 const char *p = rs[Rs_backgroundPixmap]; 541 const char *p = rs[Rs_backgroundPixmap];
545 542
546 if ((p = strchr (p, ';')) != NULL) 543 if ((p = strchr (p, ';')) != 0)
547 { 544 {
548 p++; 545 p++;
549 bgPixmap.set_geometry (p); 546 bgPixmap.set_geometry (p);
550 } 547 }
551 else 548 else
1677void 1674void
1678rxvt_term::get_window_origin (int &x, int &y) 1675rxvt_term::get_window_origin (int &x, int &y)
1679{ 1676{
1680 Window cr; 1677 Window cr;
1681 XTranslateCoordinates (dpy, parent[0], display->root, 0, 0, &x, &y, &cr); 1678 XTranslateCoordinates (dpy, parent[0], display->root, 0, 0, &x, &y, &cr);
1682/* fprintf( stderr, "origin is %+d%+d\n", x, y);*/ 1679/* fprintf (stderr, "origin is %+d%+d\n", x, y);*/
1683} 1680}
1684 1681
1685Pixmap 1682Pixmap
1686rxvt_term::get_pixmap_property (int prop_id) 1683rxvt_term::get_pixmap_property (int prop_id)
1687{ 1684{
1694 unsigned char *prop = NULL; 1691 unsigned char *prop = NULL;
1695 int result = XGetWindowProperty (dpy, display->root, xa[prop_id], 1692 int result = XGetWindowProperty (dpy, display->root, xa[prop_id],
1696 0L, 1L, False, XA_PIXMAP, &atype, &aformat, 1693 0L, 1L, False, XA_PIXMAP, &atype, &aformat,
1697 &nitems, &bytes_after, &prop); 1694 &nitems, &bytes_after, &prop);
1698 if (result == Success && prop && atype == XA_PIXMAP) 1695 if (result == Success && prop && atype == XA_PIXMAP)
1699 {
1700 return *(Pixmap *)prop; 1696 return *(Pixmap *)prop;
1701 }
1702 } 1697 }
1698
1703 return None; 1699 return None;
1704} 1700}
1705 1701
1706#ifdef HAVE_BG_PIXMAP 1702#ifdef HAVE_BG_PIXMAP
1707# if TRACE_PIXMAPS 1703# if TRACE_PIXMAPS
1708# undef update_background 1704# undef update_background
1705void
1709int rxvt_term::trace_update_background (const char *file, int line) 1706rxvt_term::trace_update_background (const char *file, int line)
1710{ 1707{
1711 fprintf (stderr, "%s:%d:update_background()\n", file, line); 1708 fprintf (stderr, "%s:%d:update_background()\n", file, line);
1712 update_background (); 1709 update_background ();
1713} 1710}
1714# endif 1711# endif
1715 1712
1716int 1713void
1717rxvt_term::update_background () 1714rxvt_term::update_background ()
1718{ 1715{
1716 if (update_background_ev.is_active ())
1717 return;
1718
1719 bgPixmap.invalidate (); 1719 bgPixmap.invalidate ();
1720 1720
1721 ev_tstamp refresh;
1722
1723 if (!bgPixmap.need_client_side_rendering ())
1724 refresh = .05;
1725 else if (bgPixmap.flags & bgPixmap_t::blurNeeded)
1721 /* no chance of real time refresh if we are blurring! */ 1726 /* no chance of real time refresh if we are blurring! */
1722 if (bgPixmap.invalid_since + 0.5 < ev::now () && !(bgPixmap.flags & bgPixmap_t::blurNeeded)) 1727 refresh = .50;
1723 bgPixmap.render ();
1724 else 1728 else
1725 {
1726 ev_tstamp refresh;
1727 update_background_ev.stop ();
1728
1729 if (!bgPixmap.need_client_side_rendering ())
1730 refresh = .05;
1731 else if (bgPixmap.flags & bgPixmap_t::blurNeeded)
1732 refresh = .20; /* very slow !!! */
1733 else
1734 refresh = .07; 1729 refresh = .07;
1730
1735 update_background_ev.start (refresh); 1731 update_background_ev.start (refresh);
1736 }
1737
1738 return 0;
1739} 1732}
1740 1733
1741void 1734void
1742rxvt_term::update_background_cb (ev::timer &w, int revents) 1735rxvt_term::update_background_cb (ev::timer &w, int revents)
1743{ 1736{
1744 make_current (); 1737 make_current ();
1738
1739 update_background_ev.stop ();
1745 bgPixmap.render (); 1740 bgPixmap.render ();
1746 refresh_check (); 1741 refresh_check ();
1747} 1742}
1748 1743
1749#endif /* HAVE_BG_PIXMAP */ 1744#endif /* HAVE_BG_PIXMAP */

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines