*** pgsql/src/backend/utils/adt/cash.c 2008/04/21 00:26:45 1.79 --- pgsql/src/backend/utils/adt/cash.c 2008/06/09 19:58:39 1.80 *************** *** 13,19 **** * this version handles 64 bit numbers and so can hold values up to * $92,233,720,368,547,758.07. * ! * $PostgreSQL: pgsql/src/backend/utils/adt/cash.c,v 1.78 2008/03/25 22:42:43 tgl Exp $ */ #include "postgres.h" --- 13,19 ---- * this version handles 64 bit numbers and so can hold values up to * $92,233,720,368,547,758.07. * ! * $PostgreSQL: pgsql/src/backend/utils/adt/cash.c,v 1.79 2008/04/21 00:26:45 tgl Exp $ */ #include "postgres.h" *************** cash_words(PG_FUNCTION_ARGS) *** 794,806 **** /* Now treat as unsigned, to avoid trouble at INT_MIN */ val = (uint64) value; ! m0 = val % 100ll; /* cents */ ! m1 = (val / 100ll) % 1000; /* hundreds */ ! m2 = (val / 100000ll) % 1000; /* thousands */ ! m3 = val / 100000000ll % 1000; /* millions */ ! m4 = val / 100000000000ll % 1000; /* billions */ ! m5 = val / 100000000000000ll % 1000; /* trillions */ ! m6 = val / 100000000000000000ll % 1000; /* quadrillions */ if (m6) { --- 794,806 ---- /* Now treat as unsigned, to avoid trouble at INT_MIN */ val = (uint64) value; ! m0 = val % INT64CONST(100); /* cents */ ! m1 = (val / INT64CONST(100)) % 1000; /* hundreds */ ! m2 = (val / INT64CONST(100000)) % 1000; /* thousands */ ! m3 = (val / INT64CONST(100000000)) % 1000; /* millions */ ! m4 = (val / INT64CONST(100000000000)) % 1000; /* billions */ ! m5 = (val / INT64CONST(100000000000000)) % 1000; /* trillions */ ! m6 = (val / INT64CONST(100000000000000000)) % 1000; /* quadrillions */ if (m6) {