… | |
… | |
284 | if (parent[0]) |
284 | if (parent[0]) |
285 | XDestroyWindow (disp, parent[0]); |
285 | XDestroyWindow (disp, parent[0]); |
286 | } |
286 | } |
287 | |
287 | |
288 | // TODO: free pixcolours, colours should become part of rxvt_display |
288 | // TODO: free pixcolours, colours should become part of rxvt_display |
289 | |
|
|
290 | delete pix_colors_focused; |
289 | delete pix_colors_focused; |
291 | #if OFF_FOCUS_FADING |
290 | #if OFF_FOCUS_FADING |
292 | delete pix_colors_unfocused; |
291 | delete pix_colors_unfocused; |
293 | #endif |
292 | #endif |
294 | |
293 | |
… | |
… | |
479 | /*----------------------------------------------------------------------*/ |
478 | /*----------------------------------------------------------------------*/ |
480 | bool |
479 | bool |
481 | rxvt_term::init (int argc, const char *const *argv) |
480 | rxvt_term::init (int argc, const char *const *argv) |
482 | { |
481 | { |
483 | SET_R (this); |
482 | SET_R (this); |
|
|
483 | |
|
|
484 | const char **cmd_argv; |
|
|
485 | |
|
|
486 | { |
484 | TEMP_ENV; // few things in X do not call setlocale :( |
487 | TEMP_ENV; // few things in X do not call setlocale :( |
485 | |
488 | |
486 | set_locale (""); |
489 | set_locale (""); |
487 | |
490 | |
488 | if (!init_vars ()) |
491 | if (!init_vars ()) |
489 | return false; |
492 | return false; |
490 | |
493 | |
491 | init_secondary (); |
494 | init_secondary (); |
492 | |
495 | |
493 | const char **cmd_argv = init_resources (argc, argv); |
496 | cmd_argv = init_resources (argc, argv); |
494 | |
497 | |
495 | #ifdef KEYSYM_RESOURCE |
498 | #ifdef KEYSYM_RESOURCE |
496 | keyboard->register_done (); |
499 | keyboard->register_done (); |
497 | #endif |
500 | #endif |
498 | |
501 | |
499 | #if MENUBAR_MAX |
502 | #if MENUBAR_MAX |
500 | menubar_read (rs[Rs_menu]); |
503 | menubar_read (rs[Rs_menu]); |
501 | #endif |
504 | #endif |
502 | #ifdef HAVE_SCROLLBARS |
505 | #ifdef HAVE_SCROLLBARS |
503 | if (OPTION (Opt_scrollBar)) |
506 | if (OPTION (Opt_scrollBar)) |
504 | scrollBar.setIdle (); /* set existence for size calculations */ |
507 | scrollBar.setIdle (); /* set existence for size calculations */ |
505 | #endif |
508 | #endif |
|
|
509 | } |
506 | |
510 | |
507 | #if ENABLE_PERL |
511 | #if ENABLE_PERL |
508 | if (!rs[Rs_perl_ext_1]) |
512 | if (!rs[Rs_perl_ext_1]) |
509 | rs[Rs_perl_ext_1] = "default"; |
513 | rs[Rs_perl_ext_1] = "default"; |
510 | |
514 | |
… | |
… | |
524 | rs[Rs_perl_eval] = 0; |
528 | rs[Rs_perl_eval] = 0; |
525 | } |
529 | } |
526 | } |
530 | } |
527 | #endif |
531 | #endif |
528 | rxvt_perl.init (); |
532 | rxvt_perl.init (); |
|
|
533 | setlocale (LC_CTYPE, curlocale); // perl destroys this info |
529 | HOOK_INVOKE ((this, HOOK_INIT, DT_END)); |
534 | HOOK_INVOKE ((this, HOOK_INIT, DT_END)); |
530 | } |
535 | } |
531 | #endif |
536 | #endif |
532 | |
537 | |
|
|
538 | { |
|
|
539 | TEMP_ENV; |
|
|
540 | |
533 | create_windows (argc, argv); |
541 | create_windows (argc, argv); |
534 | |
542 | |
535 | dDisp; |
543 | dDisp; |
536 | |
544 | |
537 | init_xlocale (); |
545 | init_xlocale (); |
538 | |
546 | |
539 | scr_reset (); // initialize screen |
547 | scr_reset (); // initialize screen |
540 | |
548 | |
541 | #if 0 |
549 | #if 0 |
542 | XSynchronize (disp, True); |
550 | XSynchronize (disp, True); |
543 | #endif |
551 | #endif |
544 | |
552 | |
545 | #ifdef HAVE_SCROLLBARS |
553 | #ifdef HAVE_SCROLLBARS |
546 | if (OPTION (Opt_scrollBar)) |
554 | if (OPTION (Opt_scrollBar)) |
547 | resize_scrollbar (); /* create and map scrollbar */ |
555 | resize_scrollbar (); /* create and map scrollbar */ |
548 | #endif |
556 | #endif |
549 | #if (MENUBAR_MAX) |
557 | #if (MENUBAR_MAX) |
550 | if (menubar_visible ()) |
558 | if (menubar_visible ()) |
551 | XMapWindow (disp, menuBar.win); |
559 | XMapWindow (disp, menuBar.win); |
552 | #endif |
560 | #endif |
553 | #ifdef TRANSPARENT |
561 | #ifdef TRANSPARENT |
554 | if (OPTION (Opt_transparent)) |
562 | if (OPTION (Opt_transparent)) |
555 | { |
563 | { |
556 | XSelectInput (disp, display->root, PropertyChangeMask); |
564 | XSelectInput (disp, display->root, PropertyChangeMask); |
557 | check_our_parents (); |
565 | check_our_parents (); |
558 | rootwin_ev.start (display, display->root); |
566 | rootwin_ev.start (display, display->root); |
559 | } |
567 | } |
560 | #endif |
568 | #endif |
561 | |
569 | |
562 | XMapWindow (disp, vt); |
570 | XMapWindow (disp, vt); |
563 | XMapWindow (disp, parent[0]); |
571 | XMapWindow (disp, parent[0]); |
564 | |
572 | |
565 | set_colorfgbg (); |
573 | set_colorfgbg (); |
566 | |
574 | |
567 | init_command (cmd_argv); |
575 | init_command (cmd_argv); |
568 | |
576 | |
569 | free (cmd_argv); |
577 | free (cmd_argv); |
570 | |
578 | |
571 | if (pty.pty >= 0) |
579 | if (pty.pty >= 0) |
572 | pty_ev.start (pty.pty, EVENT_READ); |
580 | pty_ev.start (pty.pty, EVENT_READ); |
573 | |
581 | |
574 | check_ev.start (); |
582 | check_ev.start (); |
575 | |
583 | |
576 | HOOK_INVOKE ((this, HOOK_START, DT_END)); |
584 | HOOK_INVOKE ((this, HOOK_START, DT_END)); |
|
|
585 | } |
577 | |
586 | |
578 | return true; |
587 | return true; |
579 | } |
588 | } |
580 | |
589 | |
581 | static struct sig_handlers |
590 | static struct sig_handlers |
… | |
… | |
704 | case IGNORE: |
713 | case IGNORE: |
705 | /* |
714 | /* |
706 | * change effective uid/gid - not real uid/gid - so we can switch |
715 | * change effective uid/gid - not real uid/gid - so we can switch |
707 | * back to root later, as required |
716 | * back to root later, as required |
708 | */ |
717 | */ |
|
|
718 | setegid (getgid ()); |
709 | seteuid (getuid ()); |
719 | seteuid (getuid ()); |
710 | setegid (getgid ()); |
|
|
711 | break; |
720 | break; |
712 | case SAVE: |
721 | case SAVE: |
|
|
722 | saved_egid = getegid (); |
713 | saved_euid = geteuid (); |
723 | saved_euid = geteuid (); |
714 | saved_egid = getegid (); |
|
|
715 | break; |
724 | break; |
716 | case RESTORE: |
725 | case RESTORE: |
|
|
726 | setegid (saved_egid); |
717 | seteuid (saved_euid); |
727 | seteuid (saved_euid); |
718 | setegid (saved_egid); |
|
|
719 | break; |
728 | break; |
720 | } |
729 | } |
721 | # else |
730 | # else |
722 | switch (action) |
731 | switch (action) |
723 | { |
732 | { |
724 | case IGNORE: |
733 | case IGNORE: |
|
|
734 | setgid (getgid ()); |
725 | setuid (getuid ()); |
735 | setuid (getuid ()); |
726 | setgid (getgid ()); |
|
|
727 | /* FALLTHROUGH */ |
736 | /* FALLTHROUGH */ |
728 | case SAVE: |
737 | case SAVE: |
729 | /* FALLTHROUGH */ |
738 | /* FALLTHROUGH */ |
730 | case RESTORE: |
739 | case RESTORE: |
731 | break; |
740 | break; |