*** a/doc/src/sgml/func.sgml --- b/doc/src/sgml/func.sgml *************** *** 14978,14983 **** postgres=# SELECT * FROM pg_xlogfile_name_offset(pg_stop_backup()); --- 14978,14993 ---- + pg_size_pretty(int) + + text + + Converts a size in bytes expressed as a 32-bit integer into a + human-readable format with size units + + + + pg_size_pretty(bigint) text *** a/src/backend/utils/adt/dbsize.c --- b/src/backend/utils/adt/dbsize.c *************** *** 551,556 **** pg_size_pretty(PG_FUNCTION_ARGS) --- 551,597 ---- PG_RETURN_TEXT_P(cstring_to_text(buf)); } + Datum + pg_size_pretty_int4(PG_FUNCTION_ARGS) + { + int32 size = PG_GETARG_INT32(0); + char buf[64]; + int32 limit = 10 * 1024; + int32 limit2 = limit * 2 - 1; + + if (size < limit) + snprintf(buf, sizeof(buf), "%d bytes", size); + else + { + size >>= 9; /* keep one extra bit for rounding */ + if (size < limit2) + snprintf(buf, sizeof(buf), "%d kB", + (size + 1) / 2); + else + { + size >>= 10; + if (size < limit2) + snprintf(buf, sizeof(buf), "%d MB", + (size + 1) / 2); + else + { + size >>= 10; + if (size < limit2) + snprintf(buf, sizeof(buf), "%d GB", + (size + 1) / 2); + else + { + size >>= 10; + snprintf(buf, sizeof(buf), "%d TB", + (size + 1) / 2); + } + } + } + } + + PG_RETURN_TEXT_P(cstring_to_text(buf)); + } + static char * numeric_to_cstring(Numeric n) { *** a/src/include/catalog/pg_proc.h --- b/src/include/catalog/pg_proc.h *************** *** 3410,3415 **** DATA(insert OID = 2286 ( pg_total_relation_size PGNSP PGUID 12 1 0 0 0 f f f f t --- 3410,3417 ---- DESCR("total disk space usage for the specified table and associated indexes"); DATA(insert OID = 2288 ( pg_size_pretty PGNSP PGUID 12 1 0 0 0 f f f f t f v 1 0 25 "20" _null_ _null_ _null_ _null_ pg_size_pretty _null_ _null_ _null_ )); DESCR("convert a long int to a human readable text using size units"); + DATA(insert OID = 3167 ( pg_size_pretty PGNSP PGUID 12 1 0 0 0 f f f f t f v 1 0 25 "23" _null_ _null_ _null_ _null_ pg_size_pretty_int4 _null_ _null_ _null_ )); + DESCR("convert an int to a human readable text using size units"); DATA(insert OID = 3166 ( pg_size_pretty PGNSP PGUID 12 1 0 0 0 f f f f t f v 1 0 25 "1700" _null_ _null_ _null_ _null_ pg_size_pretty_numeric _null_ _null_ _null_ )); DESCR("convert a numeric to a human readable text using size units"); DATA(insert OID = 2997 ( pg_table_size PGNSP PGUID 12 1 0 0 0 f f f f t f v 1 0 20 "2205" _null_ _null_ _null_ _null_ pg_table_size _null_ _null_ _null_ )); *** a/src/include/utils/builtins.h --- b/src/include/utils/builtins.h *************** *** 453,458 **** extern Datum pg_database_size_name(PG_FUNCTION_ARGS); --- 453,459 ---- extern Datum pg_relation_size(PG_FUNCTION_ARGS); extern Datum pg_total_relation_size(PG_FUNCTION_ARGS); extern Datum pg_size_pretty(PG_FUNCTION_ARGS); + extern Datum pg_size_pretty_int4(PG_FUNCTION_ARGS); extern Datum pg_size_pretty_numeric(PG_FUNCTION_ARGS); extern Datum pg_table_size(PG_FUNCTION_ARGS); extern Datum pg_indexes_size(PG_FUNCTION_ARGS);