From: Jim Meyering Date: Mon, 23 Sep 1996 03:02:04 +0000 (+0000) Subject: (keycompare): Declare translate to be unsigned char *. X-Git-Tag: TEXTUTILS-1_19f~15 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=85cddd311953c1d1070b2be8698083daa6cd59ab;p=thirdparty%2Fcoreutils.git (keycompare): Declare translate to be unsigned char *. Otherwise, sign extension caused misordering when using e.g. -f. --- diff --git a/src/sort.c b/src/sort.c index 4614c890af..90c28567dd 100644 --- a/src/sort.c +++ b/src/sort.c @@ -987,7 +987,8 @@ getmonth (const char *s, int len) static int keycompare (const struct line *a, const struct line *b) { - register char *texta, *textb, *lima, *limb, *translate; + register char *texta, *textb, *lima, *limb; + register unsigned char *translate; register int *ignore; struct keyfield *key; int diff = 0, iter = 0, lena, lenb; @@ -995,7 +996,7 @@ keycompare (const struct line *a, const struct line *b) for (key = keyhead.next; key; key = key->next, ++iter) { ignore = key->ignore; - translate = key->translate; + translate = (unsigned char *) key->translate; /* Find the beginning and limit of each field. */ if (iter || a->keybeg == NULL || b->keybeg == NULL) @@ -1137,7 +1138,7 @@ keycompare (const struct line *a, const struct line *b) CMP_WITH_IGNORE (translate[UCHAR (*texta)], translate[UCHAR (*textb)]); else if (ignore) - CMP_WITH_IGNORE (*texta, *textb); + CMP_WITH_IGNORE (UCHAR (*texta), UCHAR (*textb)); else if (translate) while (texta < lima && textb < limb) {