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.279 by ayin, Wed Dec 12 09:33:48 2007 UTC vs.
Revision 1.294 by root, Fri Jan 4 19:12:23 2008 UTC

11 * Copyright (c) 1997 mj olesen <olesen@me.QueensU.CA> 11 * Copyright (c) 1997 mj olesen <olesen@me.QueensU.CA>
12 * - extensive modifications 12 * - extensive modifications
13 * Copyright (c) 1997,1998 Oezguer Kesim <kesim@math.fu-berlin.de> 13 * Copyright (c) 1997,1998 Oezguer Kesim <kesim@math.fu-berlin.de>
14 * Copyright (c) 1998-2001 Geoff Wing <gcw@pobox.com> 14 * Copyright (c) 1998-2001 Geoff Wing <gcw@pobox.com>
15 * - extensive modifications 15 * - extensive modifications
16 * Copyright (c) 2003-2006 Marc Lehmann <pcg@goof.com> 16 * Copyright (c) 2003-2007 Marc Lehmann <pcg@goof.com>
17 * 17 *
18 * This program is free software; you can redistribute it and/or modify 18 * This program is free software; you can redistribute it and/or modify
19 * it under the terms of the GNU General Public License as published by 19 * it under the terms of the GNU General Public License as published by
20 * the Free Software Foundation; either version 2 of the License, or 20 * the Free Software Foundation; either version 2 of the License, or
21 * (at your option) any later version. 21 * (at your option) any later version.
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
185#endif 185#endif
186#ifndef NO_BELL 186#ifndef NO_BELL
187 bell_ev.set <rxvt_term, &rxvt_term::bell_cb> (this); 187 bell_ev.set <rxvt_term, &rxvt_term::bell_cb> (this);
188#endif 188#endif
189 child_ev.set <rxvt_term, &rxvt_term::child_cb> (this); 189 child_ev.set <rxvt_term, &rxvt_term::child_cb> (this);
190 prepare_ev.set <rxvt_term, &rxvt_term::prepare_cb> (this);
191 flush_ev.set <rxvt_term, &rxvt_term::flush_cb> (this); 190 flush_ev.set <rxvt_term, &rxvt_term::flush_cb> (this);
192 destroy_ev.set <rxvt_term, &rxvt_term::destroy_cb> (this); 191 destroy_ev.set <rxvt_term, &rxvt_term::destroy_cb> (this);
193 pty_ev.set <rxvt_term, &rxvt_term::pty_cb> (this); 192 pty_ev.set <rxvt_term, &rxvt_term::pty_cb> (this);
194 incr_ev.set <rxvt_term, &rxvt_term::incr_cb> (this); 193 incr_ev.set <rxvt_term, &rxvt_term::incr_cb> (this);
195 termwin_ev.set <rxvt_term, &rxvt_term::x_cb> (this); 194 termwin_ev.set <rxvt_term, &rxvt_term::x_cb> (this);
277 } 276 }
278 277
279 clear (); 278 clear ();
280 } 279 }
281 280
282 delete [] pix_colors_focused;
283#if OFF_FOCUS_FADING
284 delete [] pix_colors_unfocused;
285#endif
286
287#ifdef HAVE_BG_PIXMAP 281#ifdef HAVE_BG_PIXMAP
288 bgPixmap.destroy (); 282 bgPixmap.destroy ();
289#endif 283#endif
284 display->flush (); /* ideally .put should do this */
290 displays.put (display); 285 displays.put (display);
291 286
292 scr_release (); 287 scr_release ();
293 288
294 /* clear all resources */ 289 /* clear all resources */
327} 322}
328 323
329void 324void
330rxvt_term::destroy () 325rxvt_term::destroy ()
331{ 326{
332 if (ev_is_active (&destroy_ev)) 327 if (destroy_ev.is_active ())
333 return; 328 return;
334 329
335 HOOK_INVOKE ((this, HOOK_DESTROY, DT_END)); 330 HOOK_INVOKE ((this, HOOK_DESTROY, DT_END));
336 331
337#if ENABLE_OVERLAY 332#if ENABLE_OVERLAY
352 incr_ev.stop (); 347 incr_ev.stop ();
353 termwin_ev.stop (display); 348 termwin_ev.stop (display);
354 vt_ev.stop (display); 349 vt_ev.stop (display);
355 } 350 }
356 351
357 prepare_ev.stop (); 352 flush_ev.stop ();
358 pty_ev.stop (); 353 pty_ev.stop ();
359#ifdef CURSOR_BLINK 354#ifdef CURSOR_BLINK
360 cursor_blink_ev.stop (); 355 cursor_blink_ev.stop ();
361#endif 356#endif
362#ifdef TEXT_BLINK 357#ifdef TEXT_BLINK
473 rxvt_emergency_cleanup (); 468 rxvt_emergency_cleanup ();
474 _exit (EXIT_FAILURE); 469 _exit (EXIT_FAILURE);
475} 470}
476 471
477/*----------------------------------------------------------------------*/ 472/*----------------------------------------------------------------------*/
478bool 473void
479rxvt_term::init (int argc, const char *const *argv, stringvec *envv) 474rxvt_term::init (int argc, const char *const *argv, stringvec *envv)
480{ 475{
481 this->envv = envv; 476 this->envv = envv;
482 477
483 SET_R (this); 478 SET_R (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
570 free (cmd_argv); 567 free (cmd_argv);
571 568
572 if (pty->pty >= 0) 569 if (pty->pty >= 0)
573 pty_ev.start (pty->pty, ev::READ); 570 pty_ev.start (pty->pty, ev::READ);
574 571
575 prepare_ev.start ();
576
577 HOOK_INVOKE ((this, HOOK_START, DT_END)); 572 HOOK_INVOKE ((this, HOOK_START, DT_END));
578 573
579#if ENABLE_XEMBED 574#if ENABLE_XEMBED
580 if (rs[Rs_embed]) 575 if (rs[Rs_embed])
581 { 576 {
586 } 581 }
587#endif 582#endif
588 583
589 XMapWindow (dpy, vt); 584 XMapWindow (dpy, vt);
590 XMapWindow (dpy, parent[0]); 585 XMapWindow (dpy, parent[0]);
591
592 return true;
593} 586}
594 587
595static struct sig_handlers 588static struct sig_handlers
596{ 589{
597 ev::sig sw_term, sw_int; 590 ev::sig sw_term, sw_int;
640 old_xerror_handler = XSetErrorHandler ((XErrorHandler) rxvt_xerror_handler); 633 old_xerror_handler = XSetErrorHandler ((XErrorHandler) rxvt_xerror_handler);
641 // TODO: handle this with exceptions and tolerate the memory loss 634 // TODO: handle this with exceptions and tolerate the memory loss
642 XSetIOErrorHandler (rxvt_xioerror_handler); 635 XSetIOErrorHandler (rxvt_xioerror_handler);
643 636
644 XrmInitialize (); 637 XrmInitialize ();
645}
646
647/* ------------------------------------------------------------------------- *
648 * MEMORY ALLOCATION WRAPPERS *
649 * ------------------------------------------------------------------------- */
650void *
651rxvt_malloc (size_t size)
652{
653 void *p = malloc (size);
654
655 if (!p)
656 rxvt_fatal ("memory allocation failure. aborting.\n");
657
658 return p;
659}
660
661void *
662rxvt_calloc (size_t number, size_t size)
663{
664 void *p = calloc (number, size);
665
666 if (!p)
667 rxvt_fatal ("memory allocation failure. aborting.\n");
668
669 return p;
670}
671
672void *
673rxvt_realloc (void *ptr, size_t size)
674{
675 void *p = realloc (ptr, size);
676
677 if (!p)
678 rxvt_fatal ("memory allocation failure. aborting.\n");
679
680 return p;
681} 638}
682 639
683/*----------------------------------------------------------------------*/ 640/*----------------------------------------------------------------------*/
684/* 641/*
685 * window size/position calculations for XSizeHint and other storage. 642 * window size/position calculations for XSizeHint and other storage.
1717void 1674void
1718rxvt_term::get_window_origin (int &x, int &y) 1675rxvt_term::get_window_origin (int &x, int &y)
1719{ 1676{
1720 Window cr; 1677 Window cr;
1721 XTranslateCoordinates (dpy, parent[0], display->root, 0, 0, &x, &y, &cr); 1678 XTranslateCoordinates (dpy, parent[0], display->root, 0, 0, &x, &y, &cr);
1722/* fprintf( stderr, "origin is %+d%+d\n", x, y);*/ 1679/* fprintf (stderr, "origin is %+d%+d\n", x, y);*/
1723} 1680}
1724 1681
1725Pixmap 1682Pixmap
1726rxvt_term::get_pixmap_property (int prop_id) 1683rxvt_term::get_pixmap_property (int prop_id)
1727{ 1684{
1734 unsigned char *prop = NULL; 1691 unsigned char *prop = NULL;
1735 int result = XGetWindowProperty (dpy, display->root, xa[prop_id], 1692 int result = XGetWindowProperty (dpy, display->root, xa[prop_id],
1736 0L, 1L, False, XA_PIXMAP, &atype, &aformat, 1693 0L, 1L, False, XA_PIXMAP, &atype, &aformat,
1737 &nitems, &bytes_after, &prop); 1694 &nitems, &bytes_after, &prop);
1738 if (result == Success && prop && atype == XA_PIXMAP) 1695 if (result == Success && prop && atype == XA_PIXMAP)
1739 {
1740 return *(Pixmap *)prop; 1696 return *(Pixmap *)prop;
1741 }
1742 } 1697 }
1698
1743 return None; 1699 return None;
1744} 1700}
1745 1701
1746#ifdef HAVE_BG_PIXMAP 1702#ifdef HAVE_BG_PIXMAP
1747# if TRACE_PIXMAPS 1703# if TRACE_PIXMAPS
1748# undef update_background 1704# undef update_background
1705void
1749int rxvt_term::trace_update_background (const char *file, int line) 1706rxvt_term::trace_update_background (const char *file, int line)
1750{ 1707{
1751 fprintf (stderr, "%s:%d:update_background()\n", file, line); 1708 fprintf (stderr, "%s:%d:update_background()\n", file, line);
1752 update_background (); 1709 update_background ();
1753} 1710}
1754# endif 1711# endif
1755 1712
1756int 1713void
1757rxvt_term::update_background () 1714rxvt_term::update_background ()
1758{ 1715{
1716 if (update_background_ev.is_active ())
1717 return;
1718
1759 bgPixmap.invalidate (); 1719 bgPixmap.invalidate ();
1760 1720
1721 ev_tstamp refresh;
1722
1723 if (!bgPixmap.need_client_side_rendering ())
1724 refresh = .05;
1725 else if (bgPixmap.flags & bgPixmap_t::blurNeeded)
1761 /* no chance of real time refresh if we are blurring! */ 1726 /* no chance of real time refresh if we are blurring! */
1762 if (bgPixmap.invalid_since + 0.5 < ev::now () && !(bgPixmap.flags & bgPixmap_t::blurNeeded)) 1727 refresh = .50;
1763 bgPixmap.render ();
1764 else 1728 else
1765 { 1729 refresh = .07;
1766 update_background_ev.stop ();
1767 1730
1768 if (!bgPixmap.need_client_side_rendering())
1769 update_background_ev.start (.05); 1731 update_background_ev.start (refresh);
1770 else if (bgPixmap.flags & bgPixmap_t::blurNeeded)
1771 update_background_ev.start (.20); /* very slow !!! */
1772 else
1773 update_background_ev.start (.07);
1774 }
1775
1776 return 0;
1777} 1732}
1778 1733
1779void 1734void
1780rxvt_term::update_background_cb (ev::timer &w, int revents) 1735rxvt_term::update_background_cb (ev::timer &w, int revents)
1781{ 1736{
1737 make_current ();
1738
1739 update_background_ev.stop ();
1782 bgPixmap.render (); 1740 bgPixmap.render ();
1741 refresh_check ();
1783} 1742}
1784 1743
1785#endif /* HAVE_BG_PIXMAP */ 1744#endif /* HAVE_BG_PIXMAP */
1786 1745
1787/*----------------------- end-of-file (C source) -----------------------*/ 1746/*----------------------- end-of-file (C source) -----------------------*/

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines