<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="cs">
	<id>http://postgres.cz/index.php?action=history&amp;feed=atom&amp;title=Polymorfn%C3%AD_variadick%C3%A1_funkce_format</id>
	<title>Polymorfní variadická funkce format - Historie editací</title>
	<link rel="self" type="application/atom+xml" href="http://postgres.cz/index.php?action=history&amp;feed=atom&amp;title=Polymorfn%C3%AD_variadick%C3%A1_funkce_format"/>
	<link rel="alternate" type="text/html" href="http://postgres.cz/index.php?title=Polymorfn%C3%AD_variadick%C3%A1_funkce_format&amp;action=history"/>
	<updated>2026-05-13T02:19:44Z</updated>
	<subtitle>Historie editací této stránky</subtitle>
	<generator>MediaWiki 1.43.3</generator>
	<entry>
		<id>http://postgres.cz/index.php?title=Polymorfn%C3%AD_variadick%C3%A1_funkce_format&amp;diff=462&amp;oldid=prev</id>
		<title>imported&gt;Pavel: Nová stránka: Funkci, která zjednoduší formátování (sestavení) chybového hlášení v PostgreSQL nemáme. S podporou variadických a polymorfních parametrů si ji můžeme dopsat sami:  &lt;...</title>
		<link rel="alternate" type="text/html" href="http://postgres.cz/index.php?title=Polymorfn%C3%AD_variadick%C3%A1_funkce_format&amp;diff=462&amp;oldid=prev"/>
		<updated>2009-09-10T04:16:43Z</updated>

		<summary type="html">&lt;p&gt;Nová stránka: Funkci, která zjednoduší formátování (sestavení) chybového hlášení v PostgreSQL nemáme. S podporou variadických a polymorfních parametrů si ji můžeme dopsat sami:  &amp;lt;...&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Nová stránka&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Funkci, která zjednoduší formátování (sestavení) chybového hlášení v PostgreSQL nemáme. S podporou variadických a polymorfních parametrů si ji můžeme dopsat sami:&lt;br /&gt;
&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
#include &amp;quot;postgres.h&amp;quot;&lt;br /&gt;
#include &amp;quot;fmgr.h&amp;quot;&lt;br /&gt;
#include &amp;quot;lib/stringinfo.h&amp;quot;&lt;br /&gt;
#include &amp;quot;utils/builtins.h&amp;quot;&lt;br /&gt;
#include &amp;quot;utils/lsyscache.h&amp;quot;&lt;br /&gt;
&lt;br /&gt;
PG_MODULE_MAGIC;&lt;br /&gt;
&lt;br /&gt;
PG_FUNCTION_INFO_V1(pg_format);&lt;br /&gt;
&lt;br /&gt;
Datum		pg_format(PG_FUNCTION_ARGS);&lt;br /&gt;
&lt;br /&gt;
Datum&lt;br /&gt;
pg_format(PG_FUNCTION_ARGS)&lt;br /&gt;
{&lt;br /&gt;
	char	   *fmt = PG_GETARG_CSTRING(0);&lt;br /&gt;
	StringInfo	str;&lt;br /&gt;
	char		*cp;&lt;br /&gt;
	int			i = 1;&lt;br /&gt;
&lt;br /&gt;
	if (PG_ARGISNULL(0))&lt;br /&gt;
		PG_RETURN_NULL();&lt;br /&gt;
	&lt;br /&gt;
	str = makeStringInfo();&lt;br /&gt;
	&lt;br /&gt;
	for (cp = fmt; *cp; cp++)&lt;br /&gt;
	{&lt;br /&gt;
		if (cp[0] == &amp;#039;%&amp;#039;)&lt;br /&gt;
		{&lt;br /&gt;
			Oid	valtype;&lt;br /&gt;
			Datum	value;&lt;br /&gt;
			Oid                     typoutput;&lt;br /&gt;
			bool            typIsVarlena;&lt;br /&gt;
			        &lt;br /&gt;
		&lt;br /&gt;
			if (cp[1] == &amp;#039;%&amp;#039;)&lt;br /&gt;
			{&lt;br /&gt;
				appendStringInfoChar(str, cp[1]);&lt;br /&gt;
				cp++;&lt;br /&gt;
				continue;&lt;br /&gt;
			}&lt;br /&gt;
			&lt;br /&gt;
			if (i &amp;gt; PG_NARGS())&lt;br /&gt;
				elog(ERROR, &amp;quot;too few parameters specified by format string&amp;quot;);&lt;br /&gt;
			&lt;br /&gt;
			if (PG_ARGISNULL(i))&lt;br /&gt;
			{&lt;br /&gt;
				appendStringInfoString(str, &amp;quot;NULL&amp;quot;);&lt;br /&gt;
			}&lt;br /&gt;
			else&lt;br /&gt;
			{&lt;br /&gt;
				/* append n-th value */&lt;br /&gt;
				value = PG_GETARG_DATUM(i);&lt;br /&gt;
				valtype = get_fn_expr_argtype(fcinfo-&amp;gt;flinfo, i);&lt;br /&gt;
				&lt;br /&gt;
				getTypeOutputInfo(valtype, &amp;amp;typoutput, &amp;amp;typIsVarlena);&lt;br /&gt;
				appendStringInfoString(str, OidOutputFunctionCall(typoutput, value));&lt;br /&gt;
			}&lt;br /&gt;
			i++;&lt;br /&gt;
		}&lt;br /&gt;
		else&lt;br /&gt;
			appendStringInfoChar(str, cp[0]);&lt;br /&gt;
	}&lt;br /&gt;
	&lt;br /&gt;
	if (i != PG_NARGS())&lt;br /&gt;
		elog(ERROR, &amp;quot;too much parameters&amp;quot;);&lt;br /&gt;
	&lt;br /&gt;
	PG_RETURN_TEXT_P(CStringGetTextDatum(str-&amp;gt;data));&lt;br /&gt;
}&lt;br /&gt;
&lt;br /&gt;
/*&lt;br /&gt;
 * Varianta pouze s formátovacím řetězcem, pouze obálka.&lt;br /&gt;
 */&lt;br /&gt;
Datum&lt;br /&gt;
pg_format1(PG_FUNCTION_ARGS)&lt;br /&gt;
{&lt;br /&gt;
        return pg_format(fcinfo);&lt;br /&gt;
}&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;br /&gt;
registrační skript:&lt;br /&gt;
&amp;lt;pre&amp;gt;&lt;br /&gt;
SET search_path = public;&lt;br /&gt;
&lt;br /&gt;
CREATE OR REPLACE FUNCTION format(cstring, variadic &amp;quot;any&amp;quot;)&lt;br /&gt;
RETURNS text&lt;br /&gt;
AS &amp;#039;MODULE_PATHNAME&amp;#039;, &amp;#039;pg_format&amp;#039;&lt;br /&gt;
LANGUAGE C IMMUTABLE;&lt;br /&gt;
&lt;br /&gt;
CREATE OR REPLACE FUNCTION format(cstring)&lt;br /&gt;
RETURNS text&lt;br /&gt;
AS &amp;#039;MODULE_PATHNAME&amp;#039;, &amp;#039;pg_format1&amp;#039;&lt;br /&gt;
LANGUAGE C IMMUTABLE;&lt;br /&gt;
&amp;lt;/pre&amp;gt;&lt;/div&gt;</summary>
		<author><name>imported&gt;Pavel</name></author>
	</entry>
</feed>