From: Heikki Linnakangas Date: Thu, 6 Mar 2014 19:19:00 +0000 (+0200) Subject: isdigit() needs an unsigned char argument. X-Git-Tag: REL9_4_BETA1~373 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=a0c2fa9b5cfaf9595e8809a68eec929a5052834e;p=postgresql isdigit() needs an unsigned char argument. Per the C standard, the routine should be passed an int, with a value that's representable as an unsigned char or EOF. Passing a signed char is wrong, because a negative value is not representable as an unsigned char. Unfortunately no compiler warns about that. --- diff --git a/src/backend/utils/adt/timestamp.c b/src/backend/utils/adt/timestamp.c index 8ba3209fda..ce30bb6e9f 100644 --- a/src/backend/utils/adt/timestamp.c +++ b/src/backend/utils/adt/timestamp.c @@ -511,7 +511,7 @@ parse_sane_timezone(struct pg_tm *tm, text *zone) * as invalid, it's enough to disallow having a digit in the first * position of our input string. */ - if (isdigit(*tzname)) + if (isdigit((unsigned char) *tzname)) ereport(ERROR, (errcode(ERRCODE_INVALID_PARAMETER_VALUE), errmsg("invalid input syntax for numeric time zone: \"%s\"",