ps: provide 'namespace' protection for 32-bit compiles

This patch ensures that namespace output will look the
same whether ps is built under a 32 or a 64-bit model.

[ it would have been easier to change that library's ]
[ data type, but we'll avoid breaking that ABI again ]

Signed-off-by: Jim Warner <james.warner@comcast.net>
This commit is contained in:
Jim Warner 2016-12-03 04:05:06 -06:00 committed by Craig Small
parent da9f31ef3e
commit c41c614b0c

View File

@ -147,8 +147,8 @@ static int sr_ ## NAME (const proc_t* P, const proc_t* Q) { \
#define CMP_NS(NAME, ID) \ #define CMP_NS(NAME, ID) \
static int sr_ ## NAME (const proc_t* P, const proc_t* Q) { \ static int sr_ ## NAME (const proc_t* P, const proc_t* Q) { \
if (P->ns[ID] < Q->ns[ID]) return -1; \ if ((unsigned long)P->ns[ID] < (unsigned long)Q->ns[ID]) return -1; \
if (P->ns[ID] > Q->ns[ID]) return 1; \ if ((unsigned long)P->ns[ID] > (unsigned long)Q->ns[ID]) return 1; \
return 0; \ return 0; \
} }
@ -1236,7 +1236,7 @@ static int pr_sd_slice(char *restrict const outbuf, const proc_t *restrict const
#define _pr_ns(NAME, ID)\ #define _pr_ns(NAME, ID)\
static int pr_##NAME(char *restrict const outbuf, const proc_t *restrict const pp) {\ static int pr_##NAME(char *restrict const outbuf, const proc_t *restrict const pp) {\
if (pp->ns[ID])\ if (pp->ns[ID])\
return snprintf(outbuf, COLWID, "%li", pp->ns[ID]);\ return snprintf(outbuf, COLWID, "%lu", (unsigned long)pp->ns[ID]);\
else\ else\
return snprintf(outbuf, COLWID, "-");\ return snprintf(outbuf, COLWID, "-");\
} }