Fix bug in tputc writing to io file
If -f options is enabled then tputc() writes all the data to a file. Actual code assumes that all the strings in 'c' parameters have always 1 byte length, but this is not always true, because due to utf-8 encoding some characters can have a diferent length. So it is necessary pass string length to tputc in order it can call to write() correctly. --- st.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-)master
parent
246d704ba0
commit
eb360e5fd1
8
st.c
8
st.c
|
@ -278,7 +278,7 @@ static void tmoveto(int, int);
|
||||||
static void tnew(int, int);
|
static void tnew(int, int);
|
||||||
static void tnewline(int);
|
static void tnewline(int);
|
||||||
static void tputtab(bool);
|
static void tputtab(bool);
|
||||||
static void tputc(char*);
|
static void tputc(char*, int);
|
||||||
static void treset(void);
|
static void treset(void);
|
||||||
static int tresize(int, int);
|
static int tresize(int, int);
|
||||||
static void tscrollup(int, int);
|
static void tscrollup(int, int);
|
||||||
|
@ -884,7 +884,7 @@ ttyread(void) {
|
||||||
while(buflen >= UTF_SIZ || isfullutf8(ptr,buflen)) {
|
while(buflen >= UTF_SIZ || isfullutf8(ptr,buflen)) {
|
||||||
charsize = utf8decode(ptr, &utf8c);
|
charsize = utf8decode(ptr, &utf8c);
|
||||||
utf8encode(&utf8c, s);
|
utf8encode(&utf8c, s);
|
||||||
tputc(s);
|
tputc(s, charsize);
|
||||||
ptr += charsize;
|
ptr += charsize;
|
||||||
buflen -= charsize;
|
buflen -= charsize;
|
||||||
}
|
}
|
||||||
|
@ -1641,11 +1641,11 @@ tputtab(bool forward) {
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
tputc(char *c) {
|
tputc(char *c, int len) {
|
||||||
char ascii = *c;
|
char ascii = *c;
|
||||||
|
|
||||||
if(iofd != -1)
|
if(iofd != -1)
|
||||||
write(iofd, c, 1);
|
write(iofd, c, len);
|
||||||
|
|
||||||
if(term.esc & ESC_START) {
|
if(term.esc & ESC_START) {
|
||||||
if(term.esc & ESC_CSI) {
|
if(term.esc & ESC_CSI) {
|
||||||
|
|
Reference in New Issue