mirror of
https://github.com/postgres/postgres.git
synced 2025-07-30 11:03:19 +03:00
Add more use of psprintf()
This commit is contained in:
@ -1563,10 +1563,7 @@ dblink_get_pkey(PG_FUNCTION_ARGS)
|
||||
Datum result;
|
||||
|
||||
values = (char **) palloc(2 * sizeof(char *));
|
||||
values[0] = (char *) palloc(12); /* sign, 10 digits, '\0' */
|
||||
|
||||
sprintf(values[0], "%d", call_cntr + 1);
|
||||
|
||||
values[0] = psprintf("%d", call_cntr + 1);
|
||||
values[1] = results[call_cntr];
|
||||
|
||||
/* build the tuple */
|
||||
|
@ -1114,11 +1114,7 @@ hstore_out(PG_FUNCTION_ARGS)
|
||||
HEntry *entries = ARRPTR(in);
|
||||
|
||||
if (count == 0)
|
||||
{
|
||||
out = palloc(1);
|
||||
*out = '\0';
|
||||
PG_RETURN_CSTRING(out);
|
||||
}
|
||||
PG_RETURN_CSTRING(pstrdup(""));
|
||||
|
||||
buflen = 0;
|
||||
|
||||
|
@ -220,31 +220,17 @@ bt_page_stats(PG_FUNCTION_ARGS)
|
||||
elog(ERROR, "return type must be a row type");
|
||||
|
||||
j = 0;
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", stat.blkno);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%c", stat.type);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", stat.live_items);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", stat.dead_items);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", stat.avg_item_size);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", stat.page_size);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", stat.free_size);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", stat.btpo_prev);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", stat.btpo_next);
|
||||
values[j] = palloc(32);
|
||||
if (stat.type == 'd')
|
||||
snprintf(values[j++], 32, "%d", stat.btpo.xact);
|
||||
else
|
||||
snprintf(values[j++], 32, "%d", stat.btpo.level);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", stat.btpo_flags);
|
||||
values[j++] = psprintf("%d", stat.blkno);
|
||||
values[j++] = psprintf("%c", stat.type);
|
||||
values[j++] = psprintf("%d", stat.live_items);
|
||||
values[j++] = psprintf("%d", stat.dead_items);
|
||||
values[j++] = psprintf("%d", stat.avg_item_size);
|
||||
values[j++] = psprintf("%d", stat.page_size);
|
||||
values[j++] = psprintf("%d", stat.free_size);
|
||||
values[j++] = psprintf("%d", stat.btpo_prev);
|
||||
values[j++] = psprintf("%d", stat.btpo_next);
|
||||
values[j++] = psprintf("%d", (stat.type == 'd') ? stat.btpo.xact : stat.btpo.level);
|
||||
values[j++] = psprintf("%d", stat.btpo_flags);
|
||||
|
||||
tuple = BuildTupleFromCStrings(TupleDescGetAttInMetadata(tupleDesc),
|
||||
values);
|
||||
@ -380,18 +366,13 @@ bt_page_items(PG_FUNCTION_ARGS)
|
||||
itup = (IndexTuple) PageGetItem(uargs->page, id);
|
||||
|
||||
j = 0;
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", uargs->offset);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "(%u,%u)",
|
||||
BlockIdGetBlockNumber(&(itup->t_tid.ip_blkid)),
|
||||
itup->t_tid.ip_posid);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", (int) IndexTupleSize(itup));
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%c", IndexTupleHasNulls(itup) ? 't' : 'f');
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%c", IndexTupleHasVarwidths(itup) ? 't' : 'f');
|
||||
values[j++] = psprintf("%d", uargs->offset);
|
||||
values[j++] = psprintf("(%u,%u)",
|
||||
BlockIdGetBlockNumber(&(itup->t_tid.ip_blkid)),
|
||||
itup->t_tid.ip_posid);
|
||||
values[j++] = psprintf("%d", (int) IndexTupleSize(itup));
|
||||
values[j++] = psprintf("%c", IndexTupleHasNulls(itup) ? 't' : 'f');
|
||||
values[j++] = psprintf("%c", IndexTupleHasVarwidths(itup) ? 't' : 'f');
|
||||
|
||||
ptr = (char *) itup + IndexInfoFindDataOffset(itup->t_info);
|
||||
dlen = IndexTupleSize(itup) - IndexInfoFindDataOffset(itup->t_info);
|
||||
@ -477,18 +458,12 @@ bt_metap(PG_FUNCTION_ARGS)
|
||||
elog(ERROR, "return type must be a row type");
|
||||
|
||||
j = 0;
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", metad->btm_magic);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", metad->btm_version);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", metad->btm_root);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", metad->btm_level);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", metad->btm_fastroot);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", metad->btm_fastlevel);
|
||||
values[j++] = psprintf("%d", metad->btm_magic);
|
||||
values[j++] = psprintf("%d", metad->btm_version);
|
||||
values[j++] = psprintf("%d", metad->btm_root);
|
||||
values[j++] = psprintf("%d", metad->btm_level);
|
||||
values[j++] = psprintf("%d", metad->btm_fastroot);
|
||||
values[j++] = psprintf("%d", metad->btm_fastlevel);
|
||||
|
||||
tuple = BuildTupleFromCStrings(TupleDescGetAttInMetadata(tupleDesc),
|
||||
values);
|
||||
|
@ -271,39 +271,29 @@ pgstatindex_impl(Relation rel, FunctionCallInfo fcinfo)
|
||||
elog(ERROR, "return type must be a row type");
|
||||
|
||||
j = 0;
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", indexStat.version);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%d", indexStat.level);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, INT64_FORMAT,
|
||||
values[j++] = psprintf("%d", indexStat.version);
|
||||
values[j++] = psprintf("%d", indexStat.level);
|
||||
values[j++] = psprintf(INT64_FORMAT,
|
||||
(indexStat.root_pages +
|
||||
indexStat.leaf_pages +
|
||||
indexStat.internal_pages +
|
||||
indexStat.deleted_pages +
|
||||
indexStat.empty_pages) * BLCKSZ);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, "%u", indexStat.root_blkno);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, INT64_FORMAT, indexStat.internal_pages);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, INT64_FORMAT, indexStat.leaf_pages);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, INT64_FORMAT, indexStat.empty_pages);
|
||||
values[j] = palloc(32);
|
||||
snprintf(values[j++], 32, INT64_FORMAT, indexStat.deleted_pages);
|
||||
values[j] = palloc(32);
|
||||
values[j++] = psprintf("%u", indexStat.root_blkno);
|
||||
values[j++] = psprintf(INT64_FORMAT, indexStat.internal_pages);
|
||||
values[j++] = psprintf(INT64_FORMAT, indexStat.leaf_pages);
|
||||
values[j++] = psprintf(INT64_FORMAT, indexStat.empty_pages);
|
||||
values[j++] = psprintf(INT64_FORMAT, indexStat.deleted_pages);
|
||||
if (indexStat.max_avail > 0)
|
||||
snprintf(values[j++], 32, "%.2f",
|
||||
values[j++] = psprintf("%.2f",
|
||||
100.0 - (double) indexStat.free_space / (double) indexStat.max_avail * 100.0);
|
||||
else
|
||||
snprintf(values[j++], 32, "NaN");
|
||||
values[j] = palloc(32);
|
||||
values[j++] = pstrdup("NaN");
|
||||
if (indexStat.leaf_pages > 0)
|
||||
snprintf(values[j++], 32, "%.2f",
|
||||
values[j++] = psprintf("%.2f",
|
||||
(double) indexStat.fragments / (double) indexStat.leaf_pages * 100.0);
|
||||
else
|
||||
snprintf(values[j++], 32, "NaN");
|
||||
values[j++] = pstrdup("NaN");
|
||||
|
||||
tuple = BuildTupleFromCStrings(TupleDescGetAttInMetadata(tupleDesc),
|
||||
values);
|
||||
|
Reference in New Issue
Block a user