mirror of
https://github.com/postgres/postgres.git
synced 2025-07-26 01:22:12 +03:00
Use unaligned output in another regression test query to reduce diff noise.
Use the unaligned/no rowcount output mode in a regression tests that shows all built-in leakproof functions. Currently a new leakproof function will often change the alignment of all existing functions, making it hard to see the actual difference and creating unnecessary patch conflicts. Noticed while looking over a patch introducing new leakproof functions.
This commit is contained in:
@ -149,242 +149,244 @@ CREATE FUNCTION functext_E_3(int) RETURNS bool LANGUAGE 'sql'
|
|||||||
LEAKPROOF AS 'SELECT $1 < 200'; -- failed
|
LEAKPROOF AS 'SELECT $1 < 200'; -- failed
|
||||||
ERROR: only superuser can define a leakproof function
|
ERROR: only superuser can define a leakproof function
|
||||||
RESET SESSION AUTHORIZATION;
|
RESET SESSION AUTHORIZATION;
|
||||||
|
---
|
||||||
-- list of built-in leakproof functions
|
-- list of built-in leakproof functions
|
||||||
|
---
|
||||||
|
-- temporarily disable fancy output, so catalog changes create less diff noise
|
||||||
|
\a\t
|
||||||
SELECT proname, prorettype::regtype, proargtypes::regtype[]
|
SELECT proname, prorettype::regtype, proargtypes::regtype[]
|
||||||
FROM pg_proc JOIN pg_namespace ON pronamespace = pg_namespace.oid
|
FROM pg_proc JOIN pg_namespace ON pronamespace = pg_namespace.oid
|
||||||
WHERE nspname = 'pg_catalog' AND proleakproof ORDER BY proname;
|
WHERE nspname = 'pg_catalog' AND proleakproof ORDER BY proname;
|
||||||
proname | prorettype | proargtypes
|
abstimeeq|boolean|[0:1]={abstime,abstime}
|
||||||
----------------+------------+---------------------------------------------------------------------
|
abstimege|boolean|[0:1]={abstime,abstime}
|
||||||
abstimeeq | boolean | [0:1]={abstime,abstime}
|
abstimegt|boolean|[0:1]={abstime,abstime}
|
||||||
abstimege | boolean | [0:1]={abstime,abstime}
|
abstimele|boolean|[0:1]={abstime,abstime}
|
||||||
abstimegt | boolean | [0:1]={abstime,abstime}
|
abstimelt|boolean|[0:1]={abstime,abstime}
|
||||||
abstimele | boolean | [0:1]={abstime,abstime}
|
abstimene|boolean|[0:1]={abstime,abstime}
|
||||||
abstimelt | boolean | [0:1]={abstime,abstime}
|
biteq|boolean|[0:1]={bit,bit}
|
||||||
abstimene | boolean | [0:1]={abstime,abstime}
|
bitge|boolean|[0:1]={bit,bit}
|
||||||
biteq | boolean | [0:1]={bit,bit}
|
bitgt|boolean|[0:1]={bit,bit}
|
||||||
bitge | boolean | [0:1]={bit,bit}
|
bitle|boolean|[0:1]={bit,bit}
|
||||||
bitgt | boolean | [0:1]={bit,bit}
|
bitlt|boolean|[0:1]={bit,bit}
|
||||||
bitle | boolean | [0:1]={bit,bit}
|
bitne|boolean|[0:1]={bit,bit}
|
||||||
bitlt | boolean | [0:1]={bit,bit}
|
booleq|boolean|[0:1]={boolean,boolean}
|
||||||
bitne | boolean | [0:1]={bit,bit}
|
boolge|boolean|[0:1]={boolean,boolean}
|
||||||
booleq | boolean | [0:1]={boolean,boolean}
|
boolgt|boolean|[0:1]={boolean,boolean}
|
||||||
boolge | boolean | [0:1]={boolean,boolean}
|
boolle|boolean|[0:1]={boolean,boolean}
|
||||||
boolgt | boolean | [0:1]={boolean,boolean}
|
boollt|boolean|[0:1]={boolean,boolean}
|
||||||
boolle | boolean | [0:1]={boolean,boolean}
|
boolne|boolean|[0:1]={boolean,boolean}
|
||||||
boollt | boolean | [0:1]={boolean,boolean}
|
bpchareq|boolean|[0:1]={character,character}
|
||||||
boolne | boolean | [0:1]={boolean,boolean}
|
bpcharne|boolean|[0:1]={character,character}
|
||||||
bpchareq | boolean | [0:1]={character,character}
|
byteaeq|boolean|[0:1]={bytea,bytea}
|
||||||
bpcharne | boolean | [0:1]={character,character}
|
byteage|boolean|[0:1]={bytea,bytea}
|
||||||
byteaeq | boolean | [0:1]={bytea,bytea}
|
byteagt|boolean|[0:1]={bytea,bytea}
|
||||||
byteage | boolean | [0:1]={bytea,bytea}
|
byteale|boolean|[0:1]={bytea,bytea}
|
||||||
byteagt | boolean | [0:1]={bytea,bytea}
|
bytealt|boolean|[0:1]={bytea,bytea}
|
||||||
byteale | boolean | [0:1]={bytea,bytea}
|
byteane|boolean|[0:1]={bytea,bytea}
|
||||||
bytealt | boolean | [0:1]={bytea,bytea}
|
cash_eq|boolean|[0:1]={money,money}
|
||||||
byteane | boolean | [0:1]={bytea,bytea}
|
cash_ge|boolean|[0:1]={money,money}
|
||||||
cash_eq | boolean | [0:1]={money,money}
|
cash_gt|boolean|[0:1]={money,money}
|
||||||
cash_ge | boolean | [0:1]={money,money}
|
cash_le|boolean|[0:1]={money,money}
|
||||||
cash_gt | boolean | [0:1]={money,money}
|
cash_lt|boolean|[0:1]={money,money}
|
||||||
cash_le | boolean | [0:1]={money,money}
|
cash_ne|boolean|[0:1]={money,money}
|
||||||
cash_lt | boolean | [0:1]={money,money}
|
chareq|boolean|[0:1]={"\"char\"","\"char\""}
|
||||||
cash_ne | boolean | [0:1]={money,money}
|
charge|boolean|[0:1]={"\"char\"","\"char\""}
|
||||||
chareq | boolean | [0:1]={"\"char\"","\"char\""}
|
chargt|boolean|[0:1]={"\"char\"","\"char\""}
|
||||||
charge | boolean | [0:1]={"\"char\"","\"char\""}
|
charle|boolean|[0:1]={"\"char\"","\"char\""}
|
||||||
chargt | boolean | [0:1]={"\"char\"","\"char\""}
|
charlt|boolean|[0:1]={"\"char\"","\"char\""}
|
||||||
charle | boolean | [0:1]={"\"char\"","\"char\""}
|
charne|boolean|[0:1]={"\"char\"","\"char\""}
|
||||||
charlt | boolean | [0:1]={"\"char\"","\"char\""}
|
cideq|boolean|[0:1]={cid,cid}
|
||||||
charne | boolean | [0:1]={"\"char\"","\"char\""}
|
circle_eq|boolean|[0:1]={circle,circle}
|
||||||
cideq | boolean | [0:1]={cid,cid}
|
circle_ge|boolean|[0:1]={circle,circle}
|
||||||
circle_eq | boolean | [0:1]={circle,circle}
|
circle_gt|boolean|[0:1]={circle,circle}
|
||||||
circle_ge | boolean | [0:1]={circle,circle}
|
circle_le|boolean|[0:1]={circle,circle}
|
||||||
circle_gt | boolean | [0:1]={circle,circle}
|
circle_lt|boolean|[0:1]={circle,circle}
|
||||||
circle_le | boolean | [0:1]={circle,circle}
|
circle_ne|boolean|[0:1]={circle,circle}
|
||||||
circle_lt | boolean | [0:1]={circle,circle}
|
date_eq|boolean|[0:1]={date,date}
|
||||||
circle_ne | boolean | [0:1]={circle,circle}
|
date_ge|boolean|[0:1]={date,date}
|
||||||
date_eq | boolean | [0:1]={date,date}
|
date_gt|boolean|[0:1]={date,date}
|
||||||
date_ge | boolean | [0:1]={date,date}
|
date_le|boolean|[0:1]={date,date}
|
||||||
date_gt | boolean | [0:1]={date,date}
|
date_lt|boolean|[0:1]={date,date}
|
||||||
date_le | boolean | [0:1]={date,date}
|
date_ne|boolean|[0:1]={date,date}
|
||||||
date_lt | boolean | [0:1]={date,date}
|
float48eq|boolean|[0:1]={real,"double precision"}
|
||||||
date_ne | boolean | [0:1]={date,date}
|
float48ge|boolean|[0:1]={real,"double precision"}
|
||||||
float48eq | boolean | [0:1]={real,"double precision"}
|
float48gt|boolean|[0:1]={real,"double precision"}
|
||||||
float48ge | boolean | [0:1]={real,"double precision"}
|
float48le|boolean|[0:1]={real,"double precision"}
|
||||||
float48gt | boolean | [0:1]={real,"double precision"}
|
float48lt|boolean|[0:1]={real,"double precision"}
|
||||||
float48le | boolean | [0:1]={real,"double precision"}
|
float48ne|boolean|[0:1]={real,"double precision"}
|
||||||
float48lt | boolean | [0:1]={real,"double precision"}
|
float4eq|boolean|[0:1]={real,real}
|
||||||
float48ne | boolean | [0:1]={real,"double precision"}
|
float4ge|boolean|[0:1]={real,real}
|
||||||
float4eq | boolean | [0:1]={real,real}
|
float4gt|boolean|[0:1]={real,real}
|
||||||
float4ge | boolean | [0:1]={real,real}
|
float4le|boolean|[0:1]={real,real}
|
||||||
float4gt | boolean | [0:1]={real,real}
|
float4lt|boolean|[0:1]={real,real}
|
||||||
float4le | boolean | [0:1]={real,real}
|
float4ne|boolean|[0:1]={real,real}
|
||||||
float4lt | boolean | [0:1]={real,real}
|
float84eq|boolean|[0:1]={"double precision",real}
|
||||||
float4ne | boolean | [0:1]={real,real}
|
float84ge|boolean|[0:1]={"double precision",real}
|
||||||
float84eq | boolean | [0:1]={"double precision",real}
|
float84gt|boolean|[0:1]={"double precision",real}
|
||||||
float84ge | boolean | [0:1]={"double precision",real}
|
float84le|boolean|[0:1]={"double precision",real}
|
||||||
float84gt | boolean | [0:1]={"double precision",real}
|
float84lt|boolean|[0:1]={"double precision",real}
|
||||||
float84le | boolean | [0:1]={"double precision",real}
|
float84ne|boolean|[0:1]={"double precision",real}
|
||||||
float84lt | boolean | [0:1]={"double precision",real}
|
float8eq|boolean|[0:1]={"double precision","double precision"}
|
||||||
float84ne | boolean | [0:1]={"double precision",real}
|
float8ge|boolean|[0:1]={"double precision","double precision"}
|
||||||
float8eq | boolean | [0:1]={"double precision","double precision"}
|
float8gt|boolean|[0:1]={"double precision","double precision"}
|
||||||
float8ge | boolean | [0:1]={"double precision","double precision"}
|
float8le|boolean|[0:1]={"double precision","double precision"}
|
||||||
float8gt | boolean | [0:1]={"double precision","double precision"}
|
float8lt|boolean|[0:1]={"double precision","double precision"}
|
||||||
float8le | boolean | [0:1]={"double precision","double precision"}
|
float8ne|boolean|[0:1]={"double precision","double precision"}
|
||||||
float8lt | boolean | [0:1]={"double precision","double precision"}
|
int24eq|boolean|[0:1]={smallint,integer}
|
||||||
float8ne | boolean | [0:1]={"double precision","double precision"}
|
int24ge|boolean|[0:1]={smallint,integer}
|
||||||
int24eq | boolean | [0:1]={smallint,integer}
|
int24gt|boolean|[0:1]={smallint,integer}
|
||||||
int24ge | boolean | [0:1]={smallint,integer}
|
int24le|boolean|[0:1]={smallint,integer}
|
||||||
int24gt | boolean | [0:1]={smallint,integer}
|
int24lt|boolean|[0:1]={smallint,integer}
|
||||||
int24le | boolean | [0:1]={smallint,integer}
|
int24ne|boolean|[0:1]={smallint,integer}
|
||||||
int24lt | boolean | [0:1]={smallint,integer}
|
int28eq|boolean|[0:1]={smallint,bigint}
|
||||||
int24ne | boolean | [0:1]={smallint,integer}
|
int28ge|boolean|[0:1]={smallint,bigint}
|
||||||
int28eq | boolean | [0:1]={smallint,bigint}
|
int28gt|boolean|[0:1]={smallint,bigint}
|
||||||
int28ge | boolean | [0:1]={smallint,bigint}
|
int28le|boolean|[0:1]={smallint,bigint}
|
||||||
int28gt | boolean | [0:1]={smallint,bigint}
|
int28lt|boolean|[0:1]={smallint,bigint}
|
||||||
int28le | boolean | [0:1]={smallint,bigint}
|
int28ne|boolean|[0:1]={smallint,bigint}
|
||||||
int28lt | boolean | [0:1]={smallint,bigint}
|
int2eq|boolean|[0:1]={smallint,smallint}
|
||||||
int28ne | boolean | [0:1]={smallint,bigint}
|
int2ge|boolean|[0:1]={smallint,smallint}
|
||||||
int2eq | boolean | [0:1]={smallint,smallint}
|
int2gt|boolean|[0:1]={smallint,smallint}
|
||||||
int2ge | boolean | [0:1]={smallint,smallint}
|
int2le|boolean|[0:1]={smallint,smallint}
|
||||||
int2gt | boolean | [0:1]={smallint,smallint}
|
int2lt|boolean|[0:1]={smallint,smallint}
|
||||||
int2le | boolean | [0:1]={smallint,smallint}
|
int2ne|boolean|[0:1]={smallint,smallint}
|
||||||
int2lt | boolean | [0:1]={smallint,smallint}
|
int42eq|boolean|[0:1]={integer,smallint}
|
||||||
int2ne | boolean | [0:1]={smallint,smallint}
|
int42ge|boolean|[0:1]={integer,smallint}
|
||||||
int42eq | boolean | [0:1]={integer,smallint}
|
int42gt|boolean|[0:1]={integer,smallint}
|
||||||
int42ge | boolean | [0:1]={integer,smallint}
|
int42le|boolean|[0:1]={integer,smallint}
|
||||||
int42gt | boolean | [0:1]={integer,smallint}
|
int42lt|boolean|[0:1]={integer,smallint}
|
||||||
int42le | boolean | [0:1]={integer,smallint}
|
int42ne|boolean|[0:1]={integer,smallint}
|
||||||
int42lt | boolean | [0:1]={integer,smallint}
|
int48eq|boolean|[0:1]={integer,bigint}
|
||||||
int42ne | boolean | [0:1]={integer,smallint}
|
int48ge|boolean|[0:1]={integer,bigint}
|
||||||
int48eq | boolean | [0:1]={integer,bigint}
|
int48gt|boolean|[0:1]={integer,bigint}
|
||||||
int48ge | boolean | [0:1]={integer,bigint}
|
int48le|boolean|[0:1]={integer,bigint}
|
||||||
int48gt | boolean | [0:1]={integer,bigint}
|
int48lt|boolean|[0:1]={integer,bigint}
|
||||||
int48le | boolean | [0:1]={integer,bigint}
|
int48ne|boolean|[0:1]={integer,bigint}
|
||||||
int48lt | boolean | [0:1]={integer,bigint}
|
int4eq|boolean|[0:1]={integer,integer}
|
||||||
int48ne | boolean | [0:1]={integer,bigint}
|
int4ge|boolean|[0:1]={integer,integer}
|
||||||
int4eq | boolean | [0:1]={integer,integer}
|
int4gt|boolean|[0:1]={integer,integer}
|
||||||
int4ge | boolean | [0:1]={integer,integer}
|
int4le|boolean|[0:1]={integer,integer}
|
||||||
int4gt | boolean | [0:1]={integer,integer}
|
int4lt|boolean|[0:1]={integer,integer}
|
||||||
int4le | boolean | [0:1]={integer,integer}
|
int4ne|boolean|[0:1]={integer,integer}
|
||||||
int4lt | boolean | [0:1]={integer,integer}
|
int82eq|boolean|[0:1]={bigint,smallint}
|
||||||
int4ne | boolean | [0:1]={integer,integer}
|
int82ge|boolean|[0:1]={bigint,smallint}
|
||||||
int82eq | boolean | [0:1]={bigint,smallint}
|
int82gt|boolean|[0:1]={bigint,smallint}
|
||||||
int82ge | boolean | [0:1]={bigint,smallint}
|
int82le|boolean|[0:1]={bigint,smallint}
|
||||||
int82gt | boolean | [0:1]={bigint,smallint}
|
int82lt|boolean|[0:1]={bigint,smallint}
|
||||||
int82le | boolean | [0:1]={bigint,smallint}
|
int82ne|boolean|[0:1]={bigint,smallint}
|
||||||
int82lt | boolean | [0:1]={bigint,smallint}
|
int84eq|boolean|[0:1]={bigint,integer}
|
||||||
int82ne | boolean | [0:1]={bigint,smallint}
|
int84ge|boolean|[0:1]={bigint,integer}
|
||||||
int84eq | boolean | [0:1]={bigint,integer}
|
int84gt|boolean|[0:1]={bigint,integer}
|
||||||
int84ge | boolean | [0:1]={bigint,integer}
|
int84le|boolean|[0:1]={bigint,integer}
|
||||||
int84gt | boolean | [0:1]={bigint,integer}
|
int84lt|boolean|[0:1]={bigint,integer}
|
||||||
int84le | boolean | [0:1]={bigint,integer}
|
int84ne|boolean|[0:1]={bigint,integer}
|
||||||
int84lt | boolean | [0:1]={bigint,integer}
|
int8eq|boolean|[0:1]={bigint,bigint}
|
||||||
int84ne | boolean | [0:1]={bigint,integer}
|
int8ge|boolean|[0:1]={bigint,bigint}
|
||||||
int8eq | boolean | [0:1]={bigint,bigint}
|
int8gt|boolean|[0:1]={bigint,bigint}
|
||||||
int8ge | boolean | [0:1]={bigint,bigint}
|
int8le|boolean|[0:1]={bigint,bigint}
|
||||||
int8gt | boolean | [0:1]={bigint,bigint}
|
int8lt|boolean|[0:1]={bigint,bigint}
|
||||||
int8le | boolean | [0:1]={bigint,bigint}
|
int8ne|boolean|[0:1]={bigint,bigint}
|
||||||
int8lt | boolean | [0:1]={bigint,bigint}
|
interval_eq|boolean|[0:1]={interval,interval}
|
||||||
int8ne | boolean | [0:1]={bigint,bigint}
|
interval_ge|boolean|[0:1]={interval,interval}
|
||||||
interval_eq | boolean | [0:1]={interval,interval}
|
interval_gt|boolean|[0:1]={interval,interval}
|
||||||
interval_ge | boolean | [0:1]={interval,interval}
|
interval_le|boolean|[0:1]={interval,interval}
|
||||||
interval_gt | boolean | [0:1]={interval,interval}
|
interval_lt|boolean|[0:1]={interval,interval}
|
||||||
interval_le | boolean | [0:1]={interval,interval}
|
interval_ne|boolean|[0:1]={interval,interval}
|
||||||
interval_lt | boolean | [0:1]={interval,interval}
|
lseg_eq|boolean|[0:1]={lseg,lseg}
|
||||||
interval_ne | boolean | [0:1]={interval,interval}
|
lseg_ge|boolean|[0:1]={lseg,lseg}
|
||||||
lseg_eq | boolean | [0:1]={lseg,lseg}
|
lseg_gt|boolean|[0:1]={lseg,lseg}
|
||||||
lseg_ge | boolean | [0:1]={lseg,lseg}
|
lseg_le|boolean|[0:1]={lseg,lseg}
|
||||||
lseg_gt | boolean | [0:1]={lseg,lseg}
|
lseg_lt|boolean|[0:1]={lseg,lseg}
|
||||||
lseg_le | boolean | [0:1]={lseg,lseg}
|
lseg_ne|boolean|[0:1]={lseg,lseg}
|
||||||
lseg_lt | boolean | [0:1]={lseg,lseg}
|
macaddr_eq|boolean|[0:1]={macaddr,macaddr}
|
||||||
lseg_ne | boolean | [0:1]={lseg,lseg}
|
macaddr_ge|boolean|[0:1]={macaddr,macaddr}
|
||||||
macaddr_eq | boolean | [0:1]={macaddr,macaddr}
|
macaddr_gt|boolean|[0:1]={macaddr,macaddr}
|
||||||
macaddr_ge | boolean | [0:1]={macaddr,macaddr}
|
macaddr_le|boolean|[0:1]={macaddr,macaddr}
|
||||||
macaddr_gt | boolean | [0:1]={macaddr,macaddr}
|
macaddr_lt|boolean|[0:1]={macaddr,macaddr}
|
||||||
macaddr_le | boolean | [0:1]={macaddr,macaddr}
|
macaddr_ne|boolean|[0:1]={macaddr,macaddr}
|
||||||
macaddr_lt | boolean | [0:1]={macaddr,macaddr}
|
nameeq|boolean|[0:1]={name,name}
|
||||||
macaddr_ne | boolean | [0:1]={macaddr,macaddr}
|
namege|boolean|[0:1]={name,name}
|
||||||
nameeq | boolean | [0:1]={name,name}
|
namegt|boolean|[0:1]={name,name}
|
||||||
namege | boolean | [0:1]={name,name}
|
namele|boolean|[0:1]={name,name}
|
||||||
namegt | boolean | [0:1]={name,name}
|
namelt|boolean|[0:1]={name,name}
|
||||||
namele | boolean | [0:1]={name,name}
|
namene|boolean|[0:1]={name,name}
|
||||||
namelt | boolean | [0:1]={name,name}
|
network_eq|boolean|[0:1]={inet,inet}
|
||||||
namene | boolean | [0:1]={name,name}
|
network_ge|boolean|[0:1]={inet,inet}
|
||||||
network_eq | boolean | [0:1]={inet,inet}
|
network_gt|boolean|[0:1]={inet,inet}
|
||||||
network_ge | boolean | [0:1]={inet,inet}
|
network_le|boolean|[0:1]={inet,inet}
|
||||||
network_gt | boolean | [0:1]={inet,inet}
|
network_lt|boolean|[0:1]={inet,inet}
|
||||||
network_le | boolean | [0:1]={inet,inet}
|
network_ne|boolean|[0:1]={inet,inet}
|
||||||
network_lt | boolean | [0:1]={inet,inet}
|
oideq|boolean|[0:1]={oid,oid}
|
||||||
network_ne | boolean | [0:1]={inet,inet}
|
oidge|boolean|[0:1]={oid,oid}
|
||||||
oideq | boolean | [0:1]={oid,oid}
|
oidgt|boolean|[0:1]={oid,oid}
|
||||||
oidge | boolean | [0:1]={oid,oid}
|
oidle|boolean|[0:1]={oid,oid}
|
||||||
oidgt | boolean | [0:1]={oid,oid}
|
oidlt|boolean|[0:1]={oid,oid}
|
||||||
oidle | boolean | [0:1]={oid,oid}
|
oidne|boolean|[0:1]={oid,oid}
|
||||||
oidlt | boolean | [0:1]={oid,oid}
|
reltimeeq|boolean|[0:1]={reltime,reltime}
|
||||||
oidne | boolean | [0:1]={oid,oid}
|
reltimege|boolean|[0:1]={reltime,reltime}
|
||||||
reltimeeq | boolean | [0:1]={reltime,reltime}
|
reltimegt|boolean|[0:1]={reltime,reltime}
|
||||||
reltimege | boolean | [0:1]={reltime,reltime}
|
reltimele|boolean|[0:1]={reltime,reltime}
|
||||||
reltimegt | boolean | [0:1]={reltime,reltime}
|
reltimelt|boolean|[0:1]={reltime,reltime}
|
||||||
reltimele | boolean | [0:1]={reltime,reltime}
|
reltimene|boolean|[0:1]={reltime,reltime}
|
||||||
reltimelt | boolean | [0:1]={reltime,reltime}
|
texteq|boolean|[0:1]={text,text}
|
||||||
reltimene | boolean | [0:1]={reltime,reltime}
|
textne|boolean|[0:1]={text,text}
|
||||||
texteq | boolean | [0:1]={text,text}
|
tideq|boolean|[0:1]={tid,tid}
|
||||||
textne | boolean | [0:1]={text,text}
|
tidge|boolean|[0:1]={tid,tid}
|
||||||
tideq | boolean | [0:1]={tid,tid}
|
tidgt|boolean|[0:1]={tid,tid}
|
||||||
tidge | boolean | [0:1]={tid,tid}
|
tidle|boolean|[0:1]={tid,tid}
|
||||||
tidgt | boolean | [0:1]={tid,tid}
|
tidlt|boolean|[0:1]={tid,tid}
|
||||||
tidle | boolean | [0:1]={tid,tid}
|
tidne|boolean|[0:1]={tid,tid}
|
||||||
tidlt | boolean | [0:1]={tid,tid}
|
time_eq|boolean|[0:1]={"time without time zone","time without time zone"}
|
||||||
tidne | boolean | [0:1]={tid,tid}
|
time_ge|boolean|[0:1]={"time without time zone","time without time zone"}
|
||||||
time_eq | boolean | [0:1]={"time without time zone","time without time zone"}
|
time_gt|boolean|[0:1]={"time without time zone","time without time zone"}
|
||||||
time_ge | boolean | [0:1]={"time without time zone","time without time zone"}
|
time_le|boolean|[0:1]={"time without time zone","time without time zone"}
|
||||||
time_gt | boolean | [0:1]={"time without time zone","time without time zone"}
|
time_lt|boolean|[0:1]={"time without time zone","time without time zone"}
|
||||||
time_le | boolean | [0:1]={"time without time zone","time without time zone"}
|
time_ne|boolean|[0:1]={"time without time zone","time without time zone"}
|
||||||
time_lt | boolean | [0:1]={"time without time zone","time without time zone"}
|
timestamp_eq|boolean|[0:1]={"timestamp without time zone","timestamp without time zone"}
|
||||||
time_ne | boolean | [0:1]={"time without time zone","time without time zone"}
|
timestamp_ge|boolean|[0:1]={"timestamp without time zone","timestamp without time zone"}
|
||||||
timestamp_eq | boolean | [0:1]={"timestamp without time zone","timestamp without time zone"}
|
timestamp_gt|boolean|[0:1]={"timestamp without time zone","timestamp without time zone"}
|
||||||
timestamp_ge | boolean | [0:1]={"timestamp without time zone","timestamp without time zone"}
|
timestamp_le|boolean|[0:1]={"timestamp without time zone","timestamp without time zone"}
|
||||||
timestamp_gt | boolean | [0:1]={"timestamp without time zone","timestamp without time zone"}
|
timestamp_lt|boolean|[0:1]={"timestamp without time zone","timestamp without time zone"}
|
||||||
timestamp_le | boolean | [0:1]={"timestamp without time zone","timestamp without time zone"}
|
timestamp_ne|boolean|[0:1]={"timestamp without time zone","timestamp without time zone"}
|
||||||
timestamp_lt | boolean | [0:1]={"timestamp without time zone","timestamp without time zone"}
|
timestamptz_eq|boolean|[0:1]={"timestamp with time zone","timestamp with time zone"}
|
||||||
timestamp_ne | boolean | [0:1]={"timestamp without time zone","timestamp without time zone"}
|
timestamptz_ge|boolean|[0:1]={"timestamp with time zone","timestamp with time zone"}
|
||||||
timestamptz_eq | boolean | [0:1]={"timestamp with time zone","timestamp with time zone"}
|
timestamptz_gt|boolean|[0:1]={"timestamp with time zone","timestamp with time zone"}
|
||||||
timestamptz_ge | boolean | [0:1]={"timestamp with time zone","timestamp with time zone"}
|
timestamptz_le|boolean|[0:1]={"timestamp with time zone","timestamp with time zone"}
|
||||||
timestamptz_gt | boolean | [0:1]={"timestamp with time zone","timestamp with time zone"}
|
timestamptz_lt|boolean|[0:1]={"timestamp with time zone","timestamp with time zone"}
|
||||||
timestamptz_le | boolean | [0:1]={"timestamp with time zone","timestamp with time zone"}
|
timestamptz_ne|boolean|[0:1]={"timestamp with time zone","timestamp with time zone"}
|
||||||
timestamptz_lt | boolean | [0:1]={"timestamp with time zone","timestamp with time zone"}
|
timetz_eq|boolean|[0:1]={"time with time zone","time with time zone"}
|
||||||
timestamptz_ne | boolean | [0:1]={"timestamp with time zone","timestamp with time zone"}
|
timetz_ge|boolean|[0:1]={"time with time zone","time with time zone"}
|
||||||
timetz_eq | boolean | [0:1]={"time with time zone","time with time zone"}
|
timetz_gt|boolean|[0:1]={"time with time zone","time with time zone"}
|
||||||
timetz_ge | boolean | [0:1]={"time with time zone","time with time zone"}
|
timetz_le|boolean|[0:1]={"time with time zone","time with time zone"}
|
||||||
timetz_gt | boolean | [0:1]={"time with time zone","time with time zone"}
|
timetz_lt|boolean|[0:1]={"time with time zone","time with time zone"}
|
||||||
timetz_le | boolean | [0:1]={"time with time zone","time with time zone"}
|
timetz_ne|boolean|[0:1]={"time with time zone","time with time zone"}
|
||||||
timetz_lt | boolean | [0:1]={"time with time zone","time with time zone"}
|
tintervaleq|boolean|[0:1]={tinterval,tinterval}
|
||||||
timetz_ne | boolean | [0:1]={"time with time zone","time with time zone"}
|
tintervalge|boolean|[0:1]={tinterval,tinterval}
|
||||||
tintervaleq | boolean | [0:1]={tinterval,tinterval}
|
tintervalgt|boolean|[0:1]={tinterval,tinterval}
|
||||||
tintervalge | boolean | [0:1]={tinterval,tinterval}
|
tintervalle|boolean|[0:1]={tinterval,tinterval}
|
||||||
tintervalgt | boolean | [0:1]={tinterval,tinterval}
|
tintervalleneq|boolean|[0:1]={tinterval,reltime}
|
||||||
tintervalle | boolean | [0:1]={tinterval,tinterval}
|
tintervallenge|boolean|[0:1]={tinterval,reltime}
|
||||||
tintervalleneq | boolean | [0:1]={tinterval,reltime}
|
tintervallengt|boolean|[0:1]={tinterval,reltime}
|
||||||
tintervallenge | boolean | [0:1]={tinterval,reltime}
|
tintervallenle|boolean|[0:1]={tinterval,reltime}
|
||||||
tintervallengt | boolean | [0:1]={tinterval,reltime}
|
tintervallenlt|boolean|[0:1]={tinterval,reltime}
|
||||||
tintervallenle | boolean | [0:1]={tinterval,reltime}
|
tintervallenne|boolean|[0:1]={tinterval,reltime}
|
||||||
tintervallenlt | boolean | [0:1]={tinterval,reltime}
|
tintervallt|boolean|[0:1]={tinterval,tinterval}
|
||||||
tintervallenne | boolean | [0:1]={tinterval,reltime}
|
tintervalne|boolean|[0:1]={tinterval,tinterval}
|
||||||
tintervallt | boolean | [0:1]={tinterval,tinterval}
|
uuid_eq|boolean|[0:1]={uuid,uuid}
|
||||||
tintervalne | boolean | [0:1]={tinterval,tinterval}
|
uuid_ge|boolean|[0:1]={uuid,uuid}
|
||||||
uuid_eq | boolean | [0:1]={uuid,uuid}
|
uuid_gt|boolean|[0:1]={uuid,uuid}
|
||||||
uuid_ge | boolean | [0:1]={uuid,uuid}
|
uuid_le|boolean|[0:1]={uuid,uuid}
|
||||||
uuid_gt | boolean | [0:1]={uuid,uuid}
|
uuid_lt|boolean|[0:1]={uuid,uuid}
|
||||||
uuid_le | boolean | [0:1]={uuid,uuid}
|
uuid_ne|boolean|[0:1]={uuid,uuid}
|
||||||
uuid_lt | boolean | [0:1]={uuid,uuid}
|
varbiteq|boolean|[0:1]={"bit varying","bit varying"}
|
||||||
uuid_ne | boolean | [0:1]={uuid,uuid}
|
varbitge|boolean|[0:1]={"bit varying","bit varying"}
|
||||||
varbiteq | boolean | [0:1]={"bit varying","bit varying"}
|
varbitgt|boolean|[0:1]={"bit varying","bit varying"}
|
||||||
varbitge | boolean | [0:1]={"bit varying","bit varying"}
|
varbitle|boolean|[0:1]={"bit varying","bit varying"}
|
||||||
varbitgt | boolean | [0:1]={"bit varying","bit varying"}
|
varbitlt|boolean|[0:1]={"bit varying","bit varying"}
|
||||||
varbitle | boolean | [0:1]={"bit varying","bit varying"}
|
varbitne|boolean|[0:1]={"bit varying","bit varying"}
|
||||||
varbitlt | boolean | [0:1]={"bit varying","bit varying"}
|
xideq|boolean|[0:1]={xid,xid}
|
||||||
varbitne | boolean | [0:1]={"bit varying","bit varying"}
|
-- restore normal output mode
|
||||||
xideq | boolean | [0:1]={xid,xid}
|
\a\t
|
||||||
(228 rows)
|
|
||||||
|
|
||||||
--
|
--
|
||||||
-- CALLED ON NULL INPUT | RETURNS NULL ON NULL INPUT | STRICT
|
-- CALLED ON NULL INPUT | RETURNS NULL ON NULL INPUT | STRICT
|
||||||
--
|
--
|
||||||
|
@ -107,11 +107,20 @@ CREATE FUNCTION functext_E_3(int) RETURNS bool LANGUAGE 'sql'
|
|||||||
|
|
||||||
RESET SESSION AUTHORIZATION;
|
RESET SESSION AUTHORIZATION;
|
||||||
|
|
||||||
|
---
|
||||||
-- list of built-in leakproof functions
|
-- list of built-in leakproof functions
|
||||||
|
---
|
||||||
|
|
||||||
|
-- temporarily disable fancy output, so catalog changes create less diff noise
|
||||||
|
\a\t
|
||||||
|
|
||||||
SELECT proname, prorettype::regtype, proargtypes::regtype[]
|
SELECT proname, prorettype::regtype, proargtypes::regtype[]
|
||||||
FROM pg_proc JOIN pg_namespace ON pronamespace = pg_namespace.oid
|
FROM pg_proc JOIN pg_namespace ON pronamespace = pg_namespace.oid
|
||||||
WHERE nspname = 'pg_catalog' AND proleakproof ORDER BY proname;
|
WHERE nspname = 'pg_catalog' AND proleakproof ORDER BY proname;
|
||||||
|
|
||||||
|
-- restore normal output mode
|
||||||
|
\a\t
|
||||||
|
|
||||||
--
|
--
|
||||||
-- CALLED ON NULL INPUT | RETURNS NULL ON NULL INPUT | STRICT
|
-- CALLED ON NULL INPUT | RETURNS NULL ON NULL INPUT | STRICT
|
||||||
--
|
--
|
||||||
|
Reference in New Issue
Block a user