… | |
… | |
56 | STRNCPY (curlocale, locale, 128); |
56 | STRNCPY (curlocale, locale, 128); |
57 | setlocale (LC_CTYPE, curlocale); |
57 | setlocale (LC_CTYPE, curlocale); |
58 | } |
58 | } |
59 | } |
59 | } |
60 | |
60 | |
|
|
61 | class rxvt_composite_vec rxvt_composite; |
|
|
62 | |
|
|
63 | text_t rxvt_composite_vec::compose (uint32_t c1, uint32_t c2) |
|
|
64 | { |
|
|
65 | compose_char *cc; |
|
|
66 | |
|
|
67 | // break compose chains, as stupid readline really likes to duplicate |
|
|
68 | // composing characters for some reason near the end of a line. |
|
|
69 | cc = (*this)[c1]; |
|
|
70 | while (cc) |
|
|
71 | { |
|
|
72 | if (cc->c2 == c2) return c1; |
|
|
73 | cc = (*this)[cc->c1]; |
|
|
74 | } |
|
|
75 | |
|
|
76 | // check to see wether this combination already exists otherwise |
|
|
77 | for (cc = v.end (); cc-- > v.begin (); ) |
|
|
78 | { |
|
|
79 | if (cc->c1 == c1 && cc->c2 == c2) |
|
|
80 | return COMPOSE_LO + (cc - v.begin ()); |
|
|
81 | } |
|
|
82 | |
|
|
83 | // allocate a new combination |
|
|
84 | if (v.size () == COMPOSE_HI - COMPOSE_LO + 1) |
|
|
85 | { |
|
|
86 | static int seen; |
|
|
87 | |
|
|
88 | if (!seen++) |
|
|
89 | fprintf (stderr, "too many unrepresentable composite characters, try --enable-unicode3\n"); |
|
|
90 | |
|
|
91 | return REPLACEMENT_CHAR; |
|
|
92 | } |
|
|
93 | |
|
|
94 | v.push_back (compose_char (c1, c2)); |
|
|
95 | |
|
|
96 | return v.size () - 1 + COMPOSE_LO; |
|
|
97 | } |
|
|
98 | |
|
|
99 | int rxvt_composite_vec::expand (uint32_t c, wchar_t *r) |
|
|
100 | { |
|
|
101 | compose_char *cc = (*this)[c]; |
|
|
102 | |
|
|
103 | if (!cc) |
|
|
104 | { |
|
|
105 | if (r) *r = c; |
|
|
106 | return 1; |
|
|
107 | } |
|
|
108 | |
|
|
109 | int len = expand (cc->c1, r); |
|
|
110 | |
|
|
111 | if (r) r += len; |
|
|
112 | |
|
|
113 | if (cc->c2 != NOCHAR) |
|
|
114 | { |
|
|
115 | len++; |
|
|
116 | if (r) *r++ = cc->c2; |
|
|
117 | } |
|
|
118 | |
|
|
119 | return len; |
|
|
120 | |
|
|
121 | } |
|
|
122 | |
|
|
123 | extern struct rxvt_composite_vec rxvt_composite; |
61 | void * |
124 | void * |
62 | rxvt_term::operator new (size_t s) |
125 | rxvt_term::operator new (size_t s) |
63 | { |
126 | { |
64 | void *p = malloc (s); |
127 | void *p = malloc (s); |
65 | |
128 | |
… | |
… | |
117 | #endif |
180 | #endif |
118 | |
181 | |
119 | delete TermWin.fontset; |
182 | delete TermWin.fontset; |
120 | |
183 | |
121 | if (display) |
184 | if (display) |
|
|
185 | { |
|
|
186 | #if defined(MENUBAR) && (MENUBAR_MAX > 1) |
|
|
187 | delete menuBar.drawable; |
|
|
188 | //if (menuBar.win) |
|
|
189 | // XDestroyWindow (display->display, menuBar.win); |
|
|
190 | #endif |
|
|
191 | delete TermWin.drawable; |
|
|
192 | // destroy all windows |
122 | if (TermWin.parent[0]) |
193 | if (TermWin.parent[0]) |
123 | XDestroyWindow (display->display, TermWin.parent[0]); |
194 | XDestroyWindow (display->display, TermWin.parent[0]); |
|
|
195 | } |
124 | |
196 | |
125 | // TODO: free pixcolours, colours should become part of rxvt_display |
197 | // TODO: free pixcolours, colours should become part of rxvt_display |
126 | |
198 | |
127 | delete PixColors; |
199 | delete PixColors; |
128 | |
200 | |
… | |
… | |
249 | |
321 | |
250 | const char **cmd_argv = init_resources (argc, argv); |
322 | const char **cmd_argv = init_resources (argc, argv); |
251 | |
323 | |
252 | set_locale (""); |
324 | set_locale (""); |
253 | |
325 | |
254 | #if (MENUBAR_MAX) |
326 | #if MENUBAR_MAX |
255 | menubar_read (rs[Rs_menu]); |
327 | menubar_read (rs[Rs_menu]); |
256 | #endif |
328 | #endif |
257 | #ifdef HAVE_SCROLLBARS |
329 | #ifdef HAVE_SCROLLBARS |
258 | if (Options & Opt_scrollBar) |
330 | if (Options & Opt_scrollBar) |
259 | scrollBar.setIdle (); /* set existence for size calculations */ |
331 | scrollBar.setIdle (); /* set existence for size calculations */ |
… | |
… | |
376 | |
448 | |
377 | p = malloc (size); |
449 | p = malloc (size); |
378 | if (p) |
450 | if (p) |
379 | return p; |
451 | return p; |
380 | |
452 | |
381 | fprintf (stderr, APL_NAME ": memory allocation failure. Aborting"); |
453 | fprintf (stderr, RESNAME ": memory allocation failure. Aborting"); |
382 | rxvt_clean_exit (); |
454 | rxvt_clean_exit (); |
383 | exit (EXIT_FAILURE); |
455 | exit (EXIT_FAILURE); |
384 | /* NOTREACHED */ |
456 | /* NOTREACHED */ |
385 | } |
457 | } |
386 | |
458 | |
… | |
… | |
392 | |
464 | |
393 | p = calloc (number, size); |
465 | p = calloc (number, size); |
394 | if (p) |
466 | if (p) |
395 | return p; |
467 | return p; |
396 | |
468 | |
397 | fprintf (stderr, APL_NAME ": memory allocation failure. Aborting"); |
469 | fprintf (stderr, RESNAME ": memory allocation failure. Aborting"); |
398 | rxvt_clean_exit (); |
470 | rxvt_clean_exit (); |
399 | exit (EXIT_FAILURE); |
471 | exit (EXIT_FAILURE); |
400 | /* NOTREACHED */ |
472 | /* NOTREACHED */ |
401 | } |
473 | } |
402 | |
474 | |
… | |
… | |
411 | else |
483 | else |
412 | p = malloc (size); |
484 | p = malloc (size); |
413 | if (p) |
485 | if (p) |
414 | return p; |
486 | return p; |
415 | |
487 | |
416 | fprintf (stderr, APL_NAME ": memory allocation failure. Aborting"); |
488 | fprintf (stderr, RESNAME ": memory allocation failure. Aborting"); |
417 | rxvt_clean_exit (); |
489 | rxvt_clean_exit (); |
418 | exit (EXIT_FAILURE); |
490 | exit (EXIT_FAILURE); |
419 | /* NOTREACHED */ |
491 | /* NOTREACHED */ |
420 | } |
492 | } |
421 | |
493 | |
… | |
… | |
730 | } |
802 | } |
731 | else |
803 | else |
732 | { |
804 | { |
733 | rxvt_fontset *fs = new rxvt_fontset (this); |
805 | rxvt_fontset *fs = new rxvt_fontset (this); |
734 | |
806 | |
735 | if (fs && fs->populate (fontname)) |
807 | if (fs && fs->populate (fontname ? fontname : "fixed")) |
736 | { |
808 | { |
737 | delete TermWin.fontset; |
809 | delete TermWin.fontset; |
738 | TermWin.fontset = fs; |
810 | TermWin.fontset = fs; |
739 | TermWin.fwidth = fs->base_font ()->width; |
811 | TermWin.fwidth = fs->base_font ()->width; |
740 | TermWin.fheight = fs->base_font ()->height; |
812 | TermWin.fheight = fs->base_font ()->height; |
741 | TermWin.fbase = fs->base_font ()->ascent; |
813 | TermWin.fbase = fs->base_font ()->ascent; |
742 | |
814 | |
743 | // TODO: screen needs to be told about new fonts |
|
|
744 | |
|
|
745 | if (TermWin.parent[0]) |
815 | if (TermWin.parent[0]) |
746 | { |
816 | { |
747 | resize_all_windows (0, 0, 0); |
817 | resize_all_windows (0, 0, 0); |
748 | scr_remap_chars (); |
818 | scr_remap_chars (); |
749 | scr_touch (true); |
819 | scr_touch (true); |
… | |
… | |
769 | rxvt_term::set_title (const char *str) |
839 | rxvt_term::set_title (const char *str) |
770 | { |
840 | { |
771 | #ifndef SMART_WINDOW_TITLE |
841 | #ifndef SMART_WINDOW_TITLE |
772 | XStoreName (display->display, TermWin.parent[0], str); |
842 | XStoreName (display->display, TermWin.parent[0], str); |
773 | #else |
843 | #else |
774 | char *name; |
844 | char *name; |
775 | |
845 | |
776 | if (XFetchName (display->display, TermWin.parent[0], &name) == 0) |
846 | if (XFetchName (display->display, TermWin.parent[0], &name) == 0) |
777 | name = NULL; |
847 | name = NULL; |
778 | if (name == NULL || STRCMP (name, str)) |
848 | if (name == NULL || STRCMP (name, str)) |
779 | XStoreName (display->display, TermWin.parent[0], str); |
849 | XStoreName (display->display, TermWin.parent[0], str); |
… | |
… | |
786 | rxvt_term::set_iconName (const char *str) |
856 | rxvt_term::set_iconName (const char *str) |
787 | { |
857 | { |
788 | #ifndef SMART_WINDOW_TITLE |
858 | #ifndef SMART_WINDOW_TITLE |
789 | XSetIconName (display->display, TermWin.parent[0], str); |
859 | XSetIconName (display->display, TermWin.parent[0], str); |
790 | #else |
860 | #else |
791 | char *name; |
861 | char *name; |
792 | |
862 | |
793 | if (XGetIconName (display->display, TermWin.parent[0], &name)) |
863 | if (XGetIconName (display->display, TermWin.parent[0], &name)) |
794 | name = NULL; |
864 | name = NULL; |
795 | if (name == NULL || STRCMP (name, str)) |
865 | if (name == NULL || STRCMP (name, str)) |
796 | XSetIconName (display->display, TermWin.parent[0], str); |
866 | XSetIconName (display->display, TermWin.parent[0], str); |
… | |
… | |
801 | |
871 | |
802 | #ifdef XTERM_COLOR_CHANGE |
872 | #ifdef XTERM_COLOR_CHANGE |
803 | void |
873 | void |
804 | rxvt_term::set_window_color (int idx, const char *color) |
874 | rxvt_term::set_window_color (int idx, const char *color) |
805 | { |
875 | { |
806 | rxvt_color xcol; |
876 | rxvt_color xcol; |
807 | int i; |
877 | int i; |
808 | |
878 | |
809 | if (color == NULL || *color == '\0') |
879 | if (color == NULL || *color == '\0') |
810 | return; |
880 | return; |
811 | |
881 | |
812 | /* handle color aliases */ |
882 | /* handle color aliases */ |
… | |
… | |
1029 | 0, TermWin_TotalWidth (), menuBar_TotalHeight ()); |
1099 | 0, TermWin_TotalWidth (), menuBar_TotalHeight ()); |
1030 | |
1100 | |
1031 | XMoveResizeWindow (display->display, TermWin.vt, window_vt_x, |
1101 | XMoveResizeWindow (display->display, TermWin.vt, window_vt_x, |
1032 | window_vt_y, TermWin_TotalWidth (), |
1102 | window_vt_y, TermWin_TotalWidth (), |
1033 | TermWin_TotalHeight ()); |
1103 | TermWin_TotalHeight ()); |
1034 | scr_clear (); |
1104 | scr_clear (height != old_height); |
1035 | #ifdef XPM_BACKGROUND |
1105 | #ifdef XPM_BACKGROUND |
1036 | resize_pixmap (); |
1106 | resize_pixmap (); |
1037 | #endif |
1107 | #endif |
1038 | |
1108 | |
1039 | } |
1109 | } |