ps: extend utf8 multibyte support to additional fields
Form its inception (back in May of 2011), escaped_copy has always been a flawed function. It does not operate on 'escaped' strings but instead treats all input as a regular string incapable of containing utf8 sequences. As such, it should only be used for strings guaranteed to NOT embody multibyte characters (like SUPGIDS). For all other strings, which could contain utf8 stuff, the correct function should have been that escape_str guy. So this commit changes nearly every escaped_copy call. Reference(s): . May 2011, original escaped_copy (cmdline, cgroup) commit 7b0fc19e9d28380dc9790615b93bc3653d6d686e Signed-off-by: Jim Warner <james.warner@comcast.net>
This commit is contained in:
parent
e76c773561
commit
91897e7d2c
23
ps/output.c
23
ps/output.c
@ -119,7 +119,7 @@ static void get_memory_total()
|
|||||||
if ((cells) <= 0) return 0; \
|
if ((cells) <= 0) return 0; \
|
||||||
} while (0)
|
} while (0)
|
||||||
|
|
||||||
// copy an already 'escaped' string,
|
// copy a string that doesn't need to be 'escaped'
|
||||||
static int escaped_copy(char *restrict dst, const char *restrict src, int bufsize, int *maxroom){
|
static int escaped_copy(char *restrict dst, const char *restrict src, int bufsize, int *maxroom){
|
||||||
int n;
|
int n;
|
||||||
|
|
||||||
@ -402,13 +402,13 @@ setREL2(CMDLINE,ENVIRON)
|
|||||||
fh = forest_helper(outbuf);
|
fh = forest_helper(outbuf);
|
||||||
endp += fh;
|
endp += fh;
|
||||||
rightward -= fh;
|
rightward -= fh;
|
||||||
endp += escaped_copy(endp, rSv(CMDLINE, str, pp), OUTBUF_SIZE_AT(endp), &rightward);
|
endp += escape_str(endp, rSv(CMDLINE, str, pp), OUTBUF_SIZE_AT(endp), &rightward);
|
||||||
if(bsd_e_option && rightward>1) {
|
if(bsd_e_option && rightward>1) {
|
||||||
char *e = rSv(ENVIRON, str, pp);
|
char *e = rSv(ENVIRON, str, pp);
|
||||||
if(*e != '-' || *(e+1) != '\0') {
|
if(*e != '-' || *(e+1) != '\0') {
|
||||||
*endp++ = ' ';
|
*endp++ = ' ';
|
||||||
rightward--;
|
rightward--;
|
||||||
escaped_copy(endp, e, OUTBUF_SIZE_AT(endp), &rightward);
|
escape_str(endp, e, OUTBUF_SIZE_AT(endp), &rightward);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return max_rightward-rightward;
|
return max_rightward-rightward;
|
||||||
@ -428,15 +428,15 @@ setREL3(CMD,CMDLINE,ENVIRON)
|
|||||||
endp += fh;
|
endp += fh;
|
||||||
rightward -= fh;
|
rightward -= fh;
|
||||||
if(unix_f_option)
|
if(unix_f_option)
|
||||||
endp += escaped_copy(endp, rSv(CMDLINE, str, pp), OUTBUF_SIZE_AT(endp), &rightward);
|
endp += escape_str(endp, rSv(CMDLINE, str, pp), OUTBUF_SIZE_AT(endp), &rightward);
|
||||||
else
|
else
|
||||||
endp += escaped_copy(endp, rSv(CMD, str, pp), OUTBUF_SIZE_AT(endp), &rightward);
|
endp += escape_str(endp, rSv(CMD, str, pp), OUTBUF_SIZE_AT(endp), &rightward);
|
||||||
if(bsd_e_option && rightward>1) {
|
if(bsd_e_option && rightward>1) {
|
||||||
char *e = rSv(ENVIRON, str, pp);
|
char *e = rSv(ENVIRON, str, pp);
|
||||||
if(*e != '-' || *(e+1) != '\0') {
|
if(*e != '-' || *(e+1) != '\0') {
|
||||||
*endp++ = ' ';
|
*endp++ = ' ';
|
||||||
rightward--;
|
rightward--;
|
||||||
escaped_copy(endp, e, OUTBUF_SIZE_AT(endp), &rightward);
|
escape_str(endp, e, OUTBUF_SIZE_AT(endp), &rightward);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return max_rightward-rightward;
|
return max_rightward-rightward;
|
||||||
@ -446,7 +446,7 @@ static int pr_cgname(char *restrict const outbuf,const proc_t *restrict const pp
|
|||||||
int rightward;
|
int rightward;
|
||||||
setREL1(CGNAME)
|
setREL1(CGNAME)
|
||||||
rightward = max_rightward;
|
rightward = max_rightward;
|
||||||
escaped_copy(outbuf, rSv(CGNAME, str, pp), OUTBUF_SIZE, &rightward);
|
escape_str(outbuf, rSv(CGNAME, str, pp), OUTBUF_SIZE, &rightward);
|
||||||
return max_rightward-rightward;
|
return max_rightward-rightward;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -454,7 +454,7 @@ static int pr_cgroup(char *restrict const outbuf,const proc_t *restrict const pp
|
|||||||
int rightward;
|
int rightward;
|
||||||
setREL1(CGROUP)
|
setREL1(CGROUP)
|
||||||
rightward = max_rightward;
|
rightward = max_rightward;
|
||||||
escaped_copy(outbuf, rSv(CGROUP, str, pp), OUTBUF_SIZE, &rightward);
|
escape_str(outbuf, rSv(CGROUP, str, pp), OUTBUF_SIZE, &rightward);
|
||||||
return max_rightward-rightward;
|
return max_rightward-rightward;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1256,7 +1256,7 @@ static int pr_supgrp(char *restrict const outbuf, const proc_t *restrict const p
|
|||||||
int rightward;
|
int rightward;
|
||||||
setREL1(SUPGROUPS)
|
setREL1(SUPGROUPS)
|
||||||
rightward = max_rightward;
|
rightward = max_rightward;
|
||||||
escaped_copy(outbuf, rSv(SUPGROUPS, str, pp), OUTBUF_SIZE, &rightward);
|
escape_str(outbuf, rSv(SUPGROUPS, str, pp), OUTBUF_SIZE, &rightward);
|
||||||
return max_rightward-rightward;
|
return max_rightward-rightward;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1274,8 +1274,11 @@ setREL2(STATE,PROCESSOR)
|
|||||||
|
|
||||||
/* full path to executable */
|
/* full path to executable */
|
||||||
static int pr_exe(char *restrict const outbuf, const proc_t *restrict const pp){
|
static int pr_exe(char *restrict const outbuf, const proc_t *restrict const pp){
|
||||||
|
int rightward;
|
||||||
setREL1(EXE)
|
setREL1(EXE)
|
||||||
return snprintf(outbuf, COLWID, "%s", rSv(EXE, str, pp));
|
rightward = max_rightward;
|
||||||
|
escape_str(outbuf, rSv(EXE, str, pp), OUTBUF_SIZE, &rightward);
|
||||||
|
return max_rightward-rightward;
|
||||||
}
|
}
|
||||||
|
|
||||||
/************************* Systemd stuff ********************************/
|
/************************* Systemd stuff ********************************/
|
||||||
|
Loading…
x
Reference in New Issue
Block a user