43 (
errcode(ERRCODE_INVALID_PARAMETER_VALUE),
44 errmsg(
"\"%s\" cannot be NULL",
45 arginfo[argnum].argname)));
70 (
errcode(ERRCODE_INVALID_PARAMETER_VALUE),
71 errmsg(
"\"%s\" cannot be a multidimensional array",
72 arginfo[argnum].argname)));
79 (
errcode(ERRCODE_INVALID_PARAMETER_VALUE),
80 errmsg(
"\"%s\" array cannot contain NULL values",
81 arginfo[argnum].argname)));
99 int argnum1,
int argnum2)
106 int nullarg =
PG_ARGISNULL(argnum1) ? argnum1 : argnum2;
107 int otherarg =
PG_ARGISNULL(argnum1) ? argnum2 : argnum1;
110 (
errcode(ERRCODE_INVALID_PARAMETER_VALUE),
111 errmsg(
"\"%s\" must be specified when \"%s\" is specified",
112 arginfo[nullarg].argname,
113 arginfo[otherarg].argname)));
134 Oid table_oid = reloid;
156 case RELKIND_PARTITIONED_INDEX:
168 switch (
table->rd_rel->relkind)
170 case RELKIND_RELATION:
171 case RELKIND_MATVIEW:
172 case RELKIND_FOREIGN_TABLE:
173 case RELKIND_PARTITIONED_TABLE:
177 (
errcode(ERRCODE_WRONG_OBJECT_TYPE),
178 errmsg(
"cannot modify statistics for relation \"%s\"",
196 if (
table->rd_rel->relisshared)
198 (
errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
199 errmsg(
"cannot modify statistics for shared relation")));
231 errmsg(
"relation \"%s.%s\" does not exist",
247 for (argnum = 0; arginfo[argnum].
argname != NULL; argnum++)
252 (
errmsg(
"unrecognized argument name: \"%s\"", argname)));
263 if (argtype != expectedtype)
266 (
errmsg(
"argument \"%s\" has type \"%s\", expected type \"%s\"",
296 for (
int i = 0; arginfo[
i].
argname != NULL;
i++)
307 errmsg(
"variadic arguments must be name/value pairs"),
308 errhint(
"Provide an even number of variadic arguments that can be divided into pairs."));
315 for (
int i = 0;
i < nargs;
i += 2)
322 (
errmsg(
"name at variadic position %d is NULL",
i + 1)));
326 (
errmsg(
"name at variadic position %d has type \"%s\", expected type \"%s\"",
348 arginfo[argnum].argtype))
355 positional_fcinfo->
args[argnum].
isnull =
false;
void aclcheck_error(AclResult aclerr, ObjectType objtype, const char *objectname)
bool object_ownercheck(Oid classid, Oid objectid, Oid roleid)
AclResult pg_class_aclcheck(Oid table_oid, Oid roleid, AclMode mode)
#define DatumGetArrayTypeP(X)
bool array_contains_nulls(ArrayType *array)
#define TextDatumGetCString(d)
#define OidIsValid(objectId)
int errhint(const char *fmt,...)
int errcode(int sqlerrcode)
int errmsg(const char *fmt,...)
#define ereport(elevel,...)
#define PG_GETARG_DATUM(n)
int extract_variadic_args(FunctionCallInfo fcinfo, int variadic_start, bool convert_unknown, Datum **args, Oid **types, bool **nulls)
Assert(PointerIsAligned(start, uint64))
Oid IndexGetRelation(Oid indexId, bool missing_ok)
#define ShareUpdateExclusiveLock
char get_rel_relkind(Oid relid)
Oid get_relname_relid(const char *relname, Oid relnamespace)
Oid LookupExplicitNamespace(const char *nspname, bool missing_ok)
ObjectType get_relkind_objtype(char relkind)
int errdetail_relkind_not_supported(char relkind)
static const struct lconv_member_info table[]
#define ERRCODE_UNDEFINED_TABLE
int pg_strcasecmp(const char *s1, const char *s2)
#define RelationGetRelid(relation)
#define RelationGetRelationName(relation)
void relation_close(Relation relation, LOCKMODE lockmode)
Relation relation_open(Oid relationId, LOCKMODE lockmode)
bool stats_fill_fcinfo_from_arg_pairs(FunctionCallInfo pairs_fcinfo, FunctionCallInfo positional_fcinfo, struct StatsArgInfo *arginfo)
static int get_arg_by_name(const char *argname, struct StatsArgInfo *arginfo)
static bool stats_check_arg_type(const char *argname, Oid argtype, Oid expectedtype)
bool stats_check_arg_array(FunctionCallInfo fcinfo, struct StatsArgInfo *arginfo, int argnum)
void stats_check_required_arg(FunctionCallInfo fcinfo, struct StatsArgInfo *arginfo, int argnum)
void stats_lock_check_privileges(Oid reloid)
Oid stats_lookup_relid(const char *nspname, const char *relname)
bool stats_check_arg_pair(FunctionCallInfo fcinfo, struct StatsArgInfo *arginfo, int argnum1, int argnum2)
NullableDatum args[FLEXIBLE_ARRAY_MEMBER]