… | |
… | |
163 | void |
163 | void |
164 | rxvt_term::iso14755_51 (unicode_t ch, rend_t r) |
164 | rxvt_term::iso14755_51 (unicode_t ch, rend_t r) |
165 | { |
165 | { |
166 | rxvt_fontset *fs = FONTSET (r); |
166 | rxvt_fontset *fs = FONTSET (r); |
167 | rxvt_font *f = (*fs)[fs->find_font (ch)]; |
167 | rxvt_font *f = (*fs)[fs->find_font (ch)]; |
168 | wchar_t *chr, *alloc, ch2; |
168 | wchar_t *chr, *alloc, ch2, *fname; |
169 | int len; |
169 | int len; |
|
|
170 | |
|
|
171 | fname = rxvt_utf8towcs (f->name); |
170 | |
172 | |
171 | #if ENABLE_COMBINING |
173 | #if ENABLE_COMBINING |
172 | if (IS_COMPOSE (ch)) |
174 | if (IS_COMPOSE (ch)) |
173 | { |
175 | { |
174 | len = rxvt_composite.expand (ch, 0); |
176 | len = rxvt_composite.expand (ch, 0); |
… | |
… | |
183 | alloc = 0; |
185 | alloc = 0; |
184 | chr = &ch2; |
186 | chr = &ch2; |
185 | len = 1; |
187 | len = 1; |
186 | } |
188 | } |
187 | |
189 | |
188 | int width = strlen (f->name); |
190 | int width = wcswidth (fname, wcslen (fname)); |
189 | |
191 | |
190 | scr_overlay_new (0, -1, width < 8+5 ? 8+5 : width, len + 1); |
192 | scr_overlay_new (0, -1, width < 8+5 ? 8+5 : width, len + 1); |
191 | |
193 | |
192 | r = SET_STYLE (OVERLAY_RSTYLE, GET_STYLE (r)); |
194 | r = SET_STYLE (OVERLAY_RSTYLE, GET_STYLE (r)); |
193 | |
195 | |
… | |
… | |
206 | #endif |
208 | #endif |
207 | scr_overlay_set (11, y, ch, r); |
209 | scr_overlay_set (11, y, ch, r); |
208 | scr_overlay_set (12, y, NOCHAR, r); |
210 | scr_overlay_set (12, y, NOCHAR, r); |
209 | } |
211 | } |
210 | |
212 | |
211 | scr_overlay_set (0, len, f->name); |
213 | scr_overlay_set (0, len, fname); |
|
|
214 | |
|
|
215 | free (fname); |
212 | |
216 | |
213 | #if ENABLE_COMBINING |
217 | #if ENABLE_COMBINING |
214 | if (alloc) |
218 | if (alloc) |
215 | delete [] alloc; |
219 | delete [] alloc; |
216 | #endif |
220 | #endif |
… | |
… | |
316 | |
320 | |
317 | // the XOpenIM manpage lies about hardcoding the locale |
321 | // the XOpenIM manpage lies about hardcoding the locale |
318 | // at the point of XOpenIM, so temporarily switch locales |
322 | // at the point of XOpenIM, so temporarily switch locales |
319 | if (rs[Rs_imLocale]) |
323 | if (rs[Rs_imLocale]) |
320 | SET_LOCALE (rs[Rs_imLocale]); |
324 | SET_LOCALE (rs[Rs_imLocale]); |
|
|
325 | |
321 | // assume wchar_t == unicode or better |
326 | // assume wchar_t == unicode or better |
322 | len = XwcLookupString (Input_Context, &ev, wkbuf, |
327 | len = XwcLookupString (Input_Context, &ev, wkbuf, |
323 | KBUFSZ, &keysym, &status_return); |
328 | KBUFSZ, &keysym, &status_return); |
|
|
329 | |
324 | if (rs[Rs_imLocale]) |
330 | if (rs[Rs_imLocale]) |
325 | SET_LOCALE (locale); |
331 | SET_LOCALE (locale); |
326 | |
332 | |
327 | if (status_return == XLookupChars |
333 | if (status_return == XLookupChars |
328 | || status_return == XLookupBoth) |
334 | || status_return == XLookupBoth) |
… | |
… | |
2640 | /* Read a text string from the input buffer */ |
2646 | /* Read a text string from the input buffer */ |
2641 | unicode_t buf[UBUFSIZ]; |
2647 | unicode_t buf[UBUFSIZ]; |
2642 | bool refreshnow = false; |
2648 | bool refreshnow = false; |
2643 | int nlines = 0; |
2649 | int nlines = 0; |
2644 | unicode_t *str = buf; |
2650 | unicode_t *str = buf; |
|
|
2651 | unicode_t *eol = str + min (TermWin.ncol, UBUFSIZ); |
2645 | |
2652 | |
2646 | for (;;) |
2653 | for (;;) |
2647 | { |
2654 | { |
2648 | if (ch == NOCHAR || (IS_CONTROL (ch) && ch != C0_LF && ch != C0_CR && ch != C0_HT)) |
2655 | if (ch == NOCHAR || (IS_CONTROL (ch) && ch != C0_LF && ch != C0_CR && ch != C0_HT)) |
2649 | break; |
2656 | break; |
2650 | |
2657 | |
2651 | *str++ = ch; |
2658 | *str++ = ch; |
2652 | |
2659 | |
2653 | if (ch == C0_LF) |
2660 | if (ch == C0_LF || str >= eol) |
2654 | { |
2661 | { |
|
|
2662 | if (ch == C0_LF) |
2655 | nlines++; |
2663 | nlines++; |
|
|
2664 | |
2656 | refresh_count++; |
2665 | refresh_count++; |
2657 | |
2666 | |
2658 | if (!(options & Opt_jumpScroll) |
2667 | if (!(options & Opt_jumpScroll) |
2659 | || (refresh_count >= refresh_limit * (TermWin.nrow - 1))) |
2668 | || (refresh_count >= refresh_limit * (TermWin.nrow - 1))) |
2660 | { |
2669 | { |
… | |
… | |
2667 | if (nlines >= TermWin.nrow - 1) |
2676 | if (nlines >= TermWin.nrow - 1) |
2668 | { |
2677 | { |
2669 | scr_add_lines (buf, nlines, str - buf); |
2678 | scr_add_lines (buf, nlines, str - buf); |
2670 | nlines = 0; |
2679 | nlines = 0; |
2671 | str = buf; |
2680 | str = buf; |
|
|
2681 | eol = str + min (TermWin.ncol, UBUFSIZ); |
2672 | } |
2682 | } |
2673 | } |
|
|
2674 | |
2683 | |
2675 | if (str >= buf + UBUFSIZ) |
2684 | if (str >= eol) |
2676 | { |
2685 | { |
|
|
2686 | if (eol >= buf + UBUFSIZ) |
|
|
2687 | { |
2677 | ch = NOCHAR; |
2688 | ch = NOCHAR; |
2678 | break; |
2689 | break; |
|
|
2690 | } |
|
|
2691 | else |
|
|
2692 | eol = min (eol + TermWin.ncol, buf + UBUFSIZ); |
|
|
2693 | } |
|
|
2694 | |
2679 | } |
2695 | } |
2680 | |
2696 | |
2681 | seq_begin = cmdbuf_ptr; |
2697 | seq_begin = cmdbuf_ptr; |
2682 | ch = next_char (); |
2698 | ch = next_char (); |
2683 | } |
2699 | } |
… | |
… | |
3588 | else if (ch < 0x20) |
3604 | else if (ch < 0x20) |
3589 | return NULL; /* other control character - exit */ |
3605 | return NULL; /* other control character - exit */ |
3590 | |
3606 | |
3591 | seen_esc = false; |
3607 | seen_esc = false; |
3592 | |
3608 | |
3593 | if (n >= sizeof (string) - 1) |
3609 | if (n >= STRING_MAX - 1) |
3594 | // stop at some sane length |
3610 | // stop at some sane length |
3595 | return NULL; |
3611 | return NULL; |
3596 | |
3612 | |
3597 | if (ch == C0_SYN) |
3613 | if (ch == C0_SYN) |
3598 | string[n++] = cmd_get8 (); |
3614 | string[n++] = cmd_get8 (); |