ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/rxvt-unicode/src/command.C
(Generate patch)

Comparing rxvt-unicode/src/command.C (file contents):
Revision 1.201 by root, Mon Feb 21 19:26:07 2005 UTC vs.
Revision 1.206 by root, Thu Aug 11 02:05:07 2005 UTC

163void 163void
164rxvt_term::iso14755_51 (unicode_t ch, rend_t r) 164rxvt_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)
1646{ 1652{
1647 if (!TermWin.focus) 1653 if (!TermWin.focus)
1648 { 1654 {
1649 TermWin.focus = 1; 1655 TermWin.focus = 1;
1650 want_refresh = 1; 1656 want_refresh = 1;
1651#ifdef USE_XIM 1657#if USE_XIM
1652 if (Input_Context != NULL) 1658 if (Input_Context != NULL)
1653 { 1659 {
1654 IMSetStatusPosition (); 1660 IMSetStatusPosition ();
1655 XSetICFocus (Input_Context); 1661 XSetICFocus (Input_Context);
1656 } 1662 }
1657#endif 1663#endif
1658#ifdef CURSOR_BLINK 1664#if CURSOR_BLINK
1659 if (options & Opt_cursorBlink) 1665 if (options & Opt_cursorBlink)
1660 cursor_blink_ev.start (NOW + BLINK_INTERVAL); 1666 cursor_blink_ev.start (NOW + BLINK_INTERVAL);
1661#endif 1667#endif
1662#ifdef OFF_FOCUS_FADING 1668#if OFF_FOCUS_FADING
1663 if (rs[Rs_fade]) 1669 if (rs[Rs_fade])
1664 { 1670 {
1665 pix_colors = pix_colors_focused; 1671 pix_colors = pix_colors_focused;
1666 scr_recolour (); 1672 scr_recolour ();
1667 } 1673 }
1681 iso14755buf = 0; 1687 iso14755buf = 0;
1682#endif 1688#endif
1683#if ENABLE_OVERLAY 1689#if ENABLE_OVERLAY
1684 scr_overlay_off (); 1690 scr_overlay_off ();
1685#endif 1691#endif
1686#ifdef USE_XIM 1692#if USE_XIM
1687 if (Input_Context != NULL) 1693 if (Input_Context != NULL)
1688 XUnsetICFocus (Input_Context); 1694 XUnsetICFocus (Input_Context);
1689#endif 1695#endif
1690#ifdef CURSOR_BLINK 1696#if CURSOR_BLINK
1691 if (options & Opt_cursorBlink) 1697 if (options & Opt_cursorBlink)
1692 cursor_blink_ev.stop (); 1698 cursor_blink_ev.stop ();
1693 hidden_cursor = 0; 1699 hidden_cursor = 0;
1694#endif 1700#endif
1695#ifdef OFF_FOCUS_FADING 1701#if OFF_FOCUS_FADING
1696 if (rs[Rs_fade]) 1702 if (rs[Rs_fade])
1697 { 1703 {
1698 pix_colors = pix_colors_unfocused; 1704 pix_colors = pix_colors_unfocused;
1699 scr_recolour (); 1705 scr_recolour ();
1700 } 1706 }
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 ();

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines