… | |
… | |
38 | #include <limits> |
38 | #include <limits> |
39 | |
39 | |
40 | #include <csignal> |
40 | #include <csignal> |
41 | #include <cstring> |
41 | #include <cstring> |
42 | |
42 | |
43 | #ifdef HAVE_TERMIOS_H |
|
|
44 | # include <termios.h> |
43 | # include <termios.h> |
45 | #endif |
|
|
46 | |
44 | |
47 | #ifdef HAVE_XSETLOCALE |
45 | #ifdef HAVE_XSETLOCALE |
48 | # define X_LOCALE |
46 | # define X_LOCALE |
49 | # include <X11/Xlocale.h> |
47 | # include <X11/Xlocale.h> |
50 | #else |
48 | #else |
… | |
… | |
329 | } |
327 | } |
330 | |
328 | |
331 | void |
329 | void |
332 | rxvt_term::destroy () |
330 | rxvt_term::destroy () |
333 | { |
331 | { |
334 | if (destroy_ev.active) |
332 | if (ev_is_active (&destroy_ev)) |
335 | return; |
333 | return; |
336 | |
334 | |
337 | HOOK_INVOKE ((this, HOOK_DESTROY, DT_END)); |
335 | HOOK_INVOKE ((this, HOOK_DESTROY, DT_END)); |
338 | |
336 | |
339 | #if ENABLE_OVERLAY |
337 | #if ENABLE_OVERLAY |
… | |
… | |
600 | ev::sig sw_term, sw_int; |
598 | ev::sig sw_term, sw_int; |
601 | |
599 | |
602 | /* |
600 | /* |
603 | * Catch a fatal signal and tidy up before quitting |
601 | * Catch a fatal signal and tidy up before quitting |
604 | */ |
602 | */ |
605 | void |
|
|
606 | sig_term (ev::sig &w, int revents) |
603 | void sig_term (ev::sig &w, int revents); |
607 | { |
|
|
608 | rxvt_emergency_cleanup (); |
|
|
609 | w.stop (); |
|
|
610 | kill (getpid (), w.signum); |
|
|
611 | } |
|
|
612 | |
604 | |
613 | sig_handlers () |
605 | sig_handlers () |
614 | { |
606 | { |
615 | sw_term.set<sig_handlers, &sig_handlers::sig_term> (this); |
607 | sw_term.set<sig_handlers, &sig_handlers::sig_term> (this); |
616 | sw_int .set<sig_handlers, &sig_handlers::sig_term> (this); |
608 | sw_int .set<sig_handlers, &sig_handlers::sig_term> (this); |
617 | } |
609 | } |
618 | } sig_handlers; |
610 | } sig_handlers; |
|
|
611 | |
|
|
612 | void |
|
|
613 | sig_handlers::sig_term (ev::sig &w, int revents) |
|
|
614 | { |
|
|
615 | rxvt_emergency_cleanup (); |
|
|
616 | w.stop (); |
|
|
617 | kill (getpid (), w.signum); |
|
|
618 | } |
619 | |
619 | |
620 | char **rxvt_environ; // startup environment |
620 | char **rxvt_environ; // startup environment |
621 | |
621 | |
622 | void |
622 | void |
623 | rxvt_init () |
623 | rxvt_init () |