X-Git-Url: https://jasonwoof.com/gitweb/?a=blobdiff_plain;f=st.c;h=efe309fb9b5d5e67deda1f2b3d122a43cf5267bb;hb=980c5956ed4eb0c1e748f1e5c550fabdaaf4ef14;hp=2d080e554a692a264590f54d9f4b6f879b66420f;hpb=055a4f6d2cc727cc58509a39e130bdd8dbfa452b;p=st.git diff --git a/st.c b/st.c index 2d080e5..efe309f 100644 --- a/st.c +++ b/st.c @@ -278,7 +278,7 @@ static void tmoveto(int, int); static void tnew(int, int); static void tnewline(int); static void tputtab(bool); -static void tputc(char*); +static void tputc(char*, int); static void treset(void); static int tresize(int, int); static void tscrollup(int, int); @@ -884,7 +884,7 @@ ttyread(void) { while(buflen >= UTF_SIZ || isfullutf8(ptr,buflen)) { charsize = utf8decode(ptr, &utf8c); utf8encode(&utf8c, s); - tputc(s); + tputc(s, charsize); ptr += charsize; buflen -= charsize; } @@ -1641,11 +1641,11 @@ tputtab(bool forward) { } void -tputc(char *c) { +tputc(char *c, int len) { char ascii = *c; if(iofd != -1) - write(iofd, c, 1); + write(iofd, c, len); if(term.esc & ESC_START) { if(term.esc & ESC_CSI) { @@ -1700,6 +1700,7 @@ tputc(char *c) { strescseq.type = ascii; term.esc |= ESC_STR; break; + case ')': case '(': term.esc |= ESC_ALTCHARSET; break;