Commit 5eebb8d9 authored by Andres Freund's avatar Andres Freund

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.
parent 19c9da1d
...@@ -149,242 +149,244 @@ CREATE FUNCTION functext_E_3(int) RETURNS bool LANGUAGE 'sql' ...@@ -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' ...@@ -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
-- --
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment