PostgreSQL Source Code git master
All Data Structures Namespaces Files Functions Variables Typedefs Enumerations Enumerator Macros Pages
reloptions.h File Reference
#include "access/amapi.h"
#include "access/htup.h"
#include "access/tupdesc.h"
#include "nodes/pg_list.h"
#include "storage/lock.h"
Include dependency graph for reloptions.h:
This graph shows which files directly or indirectly include this file:

Go to the source code of this file.

Data Structures

struct  relopt_gen
 
struct  relopt_value
 
struct  relopt_bool
 
struct  relopt_int
 
struct  relopt_real
 
struct  relopt_enum_elt_def
 
struct  relopt_enum
 
struct  relopt_string
 
struct  relopt_parse_elt
 
struct  local_relopt
 
struct  local_relopts
 

Macros

#define HEAP_RELOPT_NAMESPACES   { "toast", NULL }
 
#define GET_STRING_RELOPTION(optstruct, member)
 

Typedefs

typedef enum relopt_type relopt_type
 
typedef enum relopt_kind relopt_kind
 
typedef struct relopt_gen relopt_gen
 
typedef struct relopt_value relopt_value
 
typedef struct relopt_bool relopt_bool
 
typedef struct relopt_int relopt_int
 
typedef struct relopt_real relopt_real
 
typedef struct relopt_enum_elt_def relopt_enum_elt_def
 
typedef struct relopt_enum relopt_enum
 
typedef void(* validate_string_relopt) (const char *value)
 
typedef Size(* fill_string_relopt) (const char *value, void *ptr)
 
typedef void(* relopts_validator) (void *parsed_options, relopt_value *vals, int nvals)
 
typedef struct relopt_string relopt_string
 
typedef struct local_relopt local_relopt
 
typedef struct local_relopts local_relopts
 

Enumerations

enum  relopt_type {
  RELOPT_TYPE_BOOL , RELOPT_TYPE_INT , RELOPT_TYPE_REAL , RELOPT_TYPE_ENUM ,
  RELOPT_TYPE_STRING
}
 
enum  relopt_kind {
  RELOPT_KIND_LOCAL = 0 , RELOPT_KIND_HEAP = (1 << 0) , RELOPT_KIND_TOAST = (1 << 1) , RELOPT_KIND_BTREE = (1 << 2) ,
  RELOPT_KIND_HASH = (1 << 3) , RELOPT_KIND_GIN = (1 << 4) , RELOPT_KIND_GIST = (1 << 5) , RELOPT_KIND_ATTRIBUTE = (1 << 6) ,
  RELOPT_KIND_TABLESPACE = (1 << 7) , RELOPT_KIND_SPGIST = (1 << 8) , RELOPT_KIND_VIEW = (1 << 9) , RELOPT_KIND_BRIN = (1 << 10) ,
  RELOPT_KIND_PARTITIONED = (1 << 11) , RELOPT_KIND_LAST_DEFAULT = RELOPT_KIND_PARTITIONED , RELOPT_KIND_MAX = (1 << 30)
}
 

Functions

relopt_kind add_reloption_kind (void)
 
void add_bool_reloption (bits32 kinds, const char *name, const char *desc, bool default_val, LOCKMODE lockmode)
 
void add_int_reloption (bits32 kinds, const char *name, const char *desc, int default_val, int min_val, int max_val, LOCKMODE lockmode)
 
void add_real_reloption (bits32 kinds, const char *name, const char *desc, double default_val, double min_val, double max_val, LOCKMODE lockmode)
 
void add_enum_reloption (bits32 kinds, const char *name, const char *desc, relopt_enum_elt_def *members, int default_val, const char *detailmsg, LOCKMODE lockmode)
 
void add_string_reloption (bits32 kinds, const char *name, const char *desc, const char *default_val, validate_string_relopt validator, LOCKMODE lockmode)
 
void init_local_reloptions (local_relopts *relopts, Size relopt_struct_size)
 
void register_reloptions_validator (local_relopts *relopts, relopts_validator validator)
 
void add_local_bool_reloption (local_relopts *relopts, const char *name, const char *desc, bool default_val, int offset)
 
void add_local_int_reloption (local_relopts *relopts, const char *name, const char *desc, int default_val, int min_val, int max_val, int offset)
 
void add_local_real_reloption (local_relopts *relopts, const char *name, const char *desc, double default_val, double min_val, double max_val, int offset)
 
void add_local_enum_reloption (local_relopts *relopts, const char *name, const char *desc, relopt_enum_elt_def *members, int default_val, const char *detailmsg, int offset)
 
void add_local_string_reloption (local_relopts *relopts, const char *name, const char *desc, const char *default_val, validate_string_relopt validator, fill_string_relopt filler, int offset)
 
Datum transformRelOptions (Datum oldOptions, List *defList, const char *namspace, const char *const validnsps[], bool acceptOidsOff, bool isReset)
 
ListuntransformRelOptions (Datum options)
 
byteaextractRelOptions (HeapTuple tuple, TupleDesc tupdesc, amoptions_function amoptions)
 
void * build_reloptions (Datum reloptions, bool validate, relopt_kind kind, Size relopt_struct_size, const relopt_parse_elt *relopt_elems, int num_relopt_elems)
 
void * build_local_reloptions (local_relopts *relopts, Datum options, bool validate)
 
byteadefault_reloptions (Datum reloptions, bool validate, relopt_kind kind)
 
byteaheap_reloptions (char relkind, Datum reloptions, bool validate)
 
byteaview_reloptions (Datum reloptions, bool validate)
 
byteapartitioned_table_reloptions (Datum reloptions, bool validate)
 
byteaindex_reloptions (amoptions_function amoptions, Datum reloptions, bool validate)
 
byteaattribute_reloptions (Datum reloptions, bool validate)
 
byteatablespace_reloptions (Datum reloptions, bool validate)
 
LOCKMODE AlterTableGetRelOptionsLockLevel (List *defList)
 

Macro Definition Documentation

◆ GET_STRING_RELOPTION

#define GET_STRING_RELOPTION (   optstruct,
  member 
)
Value:
((optstruct)->member == 0 ? NULL : \
(char *)(optstruct) + (optstruct)->member)

Definition at line 191 of file reloptions.h.

◆ HEAP_RELOPT_NAMESPACES

#define HEAP_RELOPT_NAMESPACES   { "toast", NULL }

Definition at line 61 of file reloptions.h.

Typedef Documentation

◆ fill_string_relopt

typedef Size(* fill_string_relopt) (const char *value, void *ptr)

Definition at line 134 of file reloptions.h.

◆ local_relopt

typedef struct local_relopt local_relopt

◆ local_relopts

typedef struct local_relopts local_relopts

◆ relopt_bool

typedef struct relopt_bool relopt_bool

◆ relopt_enum

typedef struct relopt_enum relopt_enum

◆ relopt_enum_elt_def

◆ relopt_gen

typedef struct relopt_gen relopt_gen

◆ relopt_int

typedef struct relopt_int relopt_int

◆ relopt_kind

typedef enum relopt_kind relopt_kind

◆ relopt_real

typedef struct relopt_real relopt_real

◆ relopt_string

typedef struct relopt_string relopt_string

◆ relopt_type

typedef enum relopt_type relopt_type

◆ relopt_value

typedef struct relopt_value relopt_value

◆ relopts_validator

typedef void(* relopts_validator) (void *parsed_options, relopt_value *vals, int nvals)

Definition at line 137 of file reloptions.h.

◆ validate_string_relopt

typedef void(* validate_string_relopt) (const char *value)

Definition at line 133 of file reloptions.h.

Enumeration Type Documentation

◆ relopt_kind

Enumerator
RELOPT_KIND_LOCAL 
RELOPT_KIND_HEAP 
RELOPT_KIND_TOAST 
RELOPT_KIND_BTREE 
RELOPT_KIND_HASH 
RELOPT_KIND_GIN 
RELOPT_KIND_GIST 
RELOPT_KIND_ATTRIBUTE 
RELOPT_KIND_TABLESPACE 
RELOPT_KIND_SPGIST 
RELOPT_KIND_VIEW 
RELOPT_KIND_BRIN 
RELOPT_KIND_PARTITIONED 
RELOPT_KIND_LAST_DEFAULT 
RELOPT_KIND_MAX 

Definition at line 39 of file reloptions.h.

40{
42 RELOPT_KIND_HEAP = (1 << 0),
43 RELOPT_KIND_TOAST = (1 << 1),
44 RELOPT_KIND_BTREE = (1 << 2),
45 RELOPT_KIND_HASH = (1 << 3),
46 RELOPT_KIND_GIN = (1 << 4),
47 RELOPT_KIND_GIST = (1 << 5),
48 RELOPT_KIND_ATTRIBUTE = (1 << 6),
49 RELOPT_KIND_TABLESPACE = (1 << 7),
50 RELOPT_KIND_SPGIST = (1 << 8),
51 RELOPT_KIND_VIEW = (1 << 9),
52 RELOPT_KIND_BRIN = (1 << 10),
53 RELOPT_KIND_PARTITIONED = (1 << 11),
54 /* if you add a new kind, make sure you update "last_default" too */
56 /* some compilers treat enums as signed ints, so we can't use 1 << 31 */
57 RELOPT_KIND_MAX = (1 << 30)
relopt_kind
Definition: reloptions.h:40
@ RELOPT_KIND_LAST_DEFAULT
Definition: reloptions.h:55
@ RELOPT_KIND_ATTRIBUTE
Definition: reloptions.h:48
@ RELOPT_KIND_TOAST
Definition: reloptions.h:43
@ RELOPT_KIND_LOCAL
Definition: reloptions.h:41
@ RELOPT_KIND_SPGIST
Definition: reloptions.h:50
@ RELOPT_KIND_MAX
Definition: reloptions.h:57
@ RELOPT_KIND_GIST
Definition: reloptions.h:47
@ RELOPT_KIND_VIEW
Definition: reloptions.h:51
@ RELOPT_KIND_HEAP
Definition: reloptions.h:42
@ RELOPT_KIND_TABLESPACE
Definition: reloptions.h:49
@ RELOPT_KIND_GIN
Definition: reloptions.h:46
@ RELOPT_KIND_HASH
Definition: reloptions.h:45
@ RELOPT_KIND_PARTITIONED
Definition: reloptions.h:53
@ RELOPT_KIND_BRIN
Definition: reloptions.h:52
@ RELOPT_KIND_BTREE
Definition: reloptions.h:44

◆ relopt_type

Enumerator
RELOPT_TYPE_BOOL 
RELOPT_TYPE_INT 
RELOPT_TYPE_REAL 
RELOPT_TYPE_ENUM 
RELOPT_TYPE_STRING 

Definition at line 29 of file reloptions.h.

30{
relopt_type
Definition: reloptions.h:30
@ RELOPT_TYPE_ENUM
Definition: reloptions.h:34
@ RELOPT_TYPE_INT
Definition: reloptions.h:32
@ RELOPT_TYPE_BOOL
Definition: reloptions.h:31
@ RELOPT_TYPE_REAL
Definition: reloptions.h:33
@ RELOPT_TYPE_STRING
Definition: reloptions.h:35

Function Documentation

◆ add_bool_reloption()

void add_bool_reloption ( bits32  kinds,
const char *  name,
const char *  desc,
bool  default_val,
LOCKMODE  lockmode 
)

Definition at line 860 of file reloptions.c.

862{
863 relopt_bool *newoption = init_bool_reloption(kinds, name, desc,
864 default_val, lockmode);
865
866 add_reloption((relopt_gen *) newoption);
867}
static void add_reloption(relopt_gen *newoption)
Definition: reloptions.c:711
static relopt_bool * init_bool_reloption(bits32 kinds, const char *name, const char *desc, bool default_val, LOCKMODE lockmode)
Definition: reloptions.c:843
const char * name

References add_reloption(), init_bool_reloption(), and name.

Referenced by create_reloptions_table().

◆ add_enum_reloption()

void add_enum_reloption ( bits32  kinds,
const char *  name,
const char *  desc,
relopt_enum_elt_def members,
int  default_val,
const char *  detailmsg,
LOCKMODE  lockmode 
)

Definition at line 1029 of file reloptions.c.

1032{
1033 relopt_enum *newoption = init_enum_reloption(kinds, name, desc,
1034 members, default_val,
1035 detailmsg, lockmode);
1036
1037 add_reloption((relopt_gen *) newoption);
1038}
static relopt_enum * init_enum_reloption(bits32 kinds, const char *name, const char *desc, relopt_enum_elt_def *members, int default_val, const char *detailmsg, LOCKMODE lockmode)
Definition: reloptions.c:1000

References add_reloption(), init_enum_reloption(), and name.

Referenced by create_reloptions_table().

◆ add_int_reloption()

void add_int_reloption ( bits32  kinds,
const char *  name,
const char *  desc,
int  default_val,
int  min_val,
int  max_val,
LOCKMODE  lockmode 
)

Definition at line 912 of file reloptions.c.

914{
915 relopt_int *newoption = init_int_reloption(kinds, name, desc,
916 default_val, min_val,
917 max_val, lockmode);
918
919 add_reloption((relopt_gen *) newoption);
920}
tree ctl max_val
Definition: radixtree.h:1859
static relopt_int * init_int_reloption(bits32 kinds, const char *name, const char *desc, int default_val, int min_val, int max_val, LOCKMODE lockmode)
Definition: reloptions.c:892

References add_reloption(), init_int_reloption(), max_val, and name.

Referenced by _PG_init(), and create_reloptions_table().

◆ add_local_bool_reloption()

void add_local_bool_reloption ( local_relopts relopts,
const char *  name,
const char *  desc,
bool  default_val,
int  offset 
)

Definition at line 876 of file reloptions.c.

878{
880 name, desc,
881 default_val, 0);
882
883 add_local_reloption(relopts, (relopt_gen *) newoption, offset);
884}
static void add_local_reloption(local_relopts *relopts, relopt_gen *newoption, int offset)
Definition: reloptions.c:768

References add_local_reloption(), init_bool_reloption(), name, and RELOPT_KIND_LOCAL.

◆ add_local_enum_reloption()

void add_local_enum_reloption ( local_relopts relopts,
const char *  name,
const char *  desc,
relopt_enum_elt_def members,
int  default_val,
const char *  detailmsg,
int  offset 
)

Definition at line 1047 of file reloptions.c.

1050{
1052 name, desc,
1053 members, default_val,
1054 detailmsg, 0);
1055
1056 add_local_reloption(relopts, (relopt_gen *) newoption, offset);
1057}

References add_local_reloption(), init_enum_reloption(), name, and RELOPT_KIND_LOCAL.

◆ add_local_int_reloption()

void add_local_int_reloption ( local_relopts relopts,
const char *  name,
const char *  desc,
int  default_val,
int  min_val,
int  max_val,
int  offset 
)

◆ add_local_real_reloption()

void add_local_real_reloption ( local_relopts relopts,
const char *  name,
const char *  desc,
double  default_val,
double  min_val,
double  max_val,
int  offset 
)

Definition at line 983 of file reloptions.c.

986{
988 name, desc,
989 default_val, min_val,
990 max_val, 0);
991
992 add_local_reloption(relopts, (relopt_gen *) newoption, offset);
993}
static relopt_real * init_real_reloption(bits32 kinds, const char *name, const char *desc, double default_val, double min_val, double max_val, LOCKMODE lockmode)
Definition: reloptions.c:945

References add_local_reloption(), init_real_reloption(), max_val, name, and RELOPT_KIND_LOCAL.

Referenced by brin_bloom_options().

◆ add_local_string_reloption()

void add_local_string_reloption ( local_relopts relopts,
const char *  name,
const char *  desc,
const char *  default_val,
validate_string_relopt  validator,
fill_string_relopt  filler,
int  offset 
)

Definition at line 1129 of file reloptions.c.

1133{
1135 name, desc,
1136 default_val,
1137 validator, filler,
1138 0);
1139
1140 add_local_reloption(relopts, (relopt_gen *) newoption, offset);
1141}
static relopt_string * init_string_reloption(bits32 kinds, const char *name, const char *desc, const char *default_val, validate_string_relopt validator, fill_string_relopt filler, LOCKMODE lockmode)
Definition: reloptions.c:1064

References add_local_reloption(), init_string_reloption(), name, and RELOPT_KIND_LOCAL.

◆ add_real_reloption()

void add_real_reloption ( bits32  kinds,
const char *  name,
const char *  desc,
double  default_val,
double  min_val,
double  max_val,
LOCKMODE  lockmode 
)

Definition at line 965 of file reloptions.c.

968{
969 relopt_real *newoption = init_real_reloption(kinds, name, desc,
970 default_val, min_val,
971 max_val, lockmode);
972
973 add_reloption((relopt_gen *) newoption);
974}

References add_reloption(), init_real_reloption(), max_val, and name.

Referenced by create_reloptions_table().

◆ add_reloption_kind()

relopt_kind add_reloption_kind ( void  )

Definition at line 694 of file reloptions.c.

695{
696 /* don't hand out the last bit so that the enum's behavior is portable */
699 (errcode(ERRCODE_PROGRAM_LIMIT_EXCEEDED),
700 errmsg("user-defined relation parameter types limit exceeded")));
701 last_assigned_kind <<= 1;
703}
int errcode(int sqlerrcode)
Definition: elog.c:854
int errmsg(const char *fmt,...)
Definition: elog.c:1071
#define ERROR
Definition: elog.h:39
#define ereport(elevel,...)
Definition: elog.h:149
static bits32 last_assigned_kind
Definition: reloptions.c:565

References ereport, errcode(), errmsg(), ERROR, last_assigned_kind, and RELOPT_KIND_MAX.

Referenced by _PG_init(), and create_reloptions_table().

◆ add_string_reloption()

void add_string_reloption ( bits32  kinds,
const char *  name,
const char *  desc,
const char *  default_val,
validate_string_relopt  validator,
LOCKMODE  lockmode 
)

Definition at line 1109 of file reloptions.c.

1112{
1113 relopt_string *newoption = init_string_reloption(kinds, name, desc,
1114 default_val,
1115 validator, NULL,
1116 lockmode);
1117
1118 add_reloption((relopt_gen *) newoption);
1119}

References add_reloption(), init_string_reloption(), and name.

Referenced by create_reloptions_table().

◆ AlterTableGetRelOptionsLockLevel()

LOCKMODE AlterTableGetRelOptionsLockLevel ( List defList)

Definition at line 2135 of file reloptions.c.

2136{
2137 LOCKMODE lockmode = NoLock;
2138 ListCell *cell;
2139
2140 if (defList == NIL)
2141 return AccessExclusiveLock;
2142
2145
2146 foreach(cell, defList)
2147 {
2148 DefElem *def = (DefElem *) lfirst(cell);
2149 int i;
2150
2151 for (i = 0; relOpts[i]; i++)
2152 {
2153 if (strncmp(relOpts[i]->name,
2154 def->defname,
2155 relOpts[i]->namelen + 1) == 0)
2156 {
2157 if (lockmode < relOpts[i]->lockmode)
2158 lockmode = relOpts[i]->lockmode;
2159 }
2160 }
2161 }
2162
2163 return lockmode;
2164}
int i
Definition: isn.c:77
int LOCKMODE
Definition: lockdefs.h:26
#define NoLock
Definition: lockdefs.h:34
#define AccessExclusiveLock
Definition: lockdefs.h:43
#define lfirst(lc)
Definition: pg_list.h:172
#define NIL
Definition: pg_list.h:68
static void initialize_reloptions(void)
Definition: reloptions.c:591
static bool need_initialization
Definition: reloptions.c:569
static relopt_gen ** relOpts
Definition: reloptions.c:564
char * defname
Definition: parsenodes.h:826
LOCKMODE lockmode
Definition: reloptions.h:70
int namelen
Definition: reloptions.h:71

References AccessExclusiveLock, DefElem::defname, i, initialize_reloptions(), lfirst, relopt_gen::lockmode, name, relopt_gen::namelen, need_initialization, NIL, NoLock, and relOpts.

Referenced by AlterTableGetLockLevel().

◆ attribute_reloptions()

bytea * attribute_reloptions ( Datum  reloptions,
bool  validate 
)

Definition at line 2096 of file reloptions.c.

2097{
2098 static const relopt_parse_elt tab[] = {
2099 {"n_distinct", RELOPT_TYPE_REAL, offsetof(AttributeOpts, n_distinct)},
2100 {"n_distinct_inherited", RELOPT_TYPE_REAL, offsetof(AttributeOpts, n_distinct_inherited)}
2101 };
2102
2103 return (bytea *) build_reloptions(reloptions, validate,
2105 sizeof(AttributeOpts),
2106 tab, lengthof(tab));
2107}
static bool validate(Port *port, const char *auth)
Definition: auth-oauth.c:638
#define lengthof(array)
Definition: c.h:759
void * build_reloptions(Datum reloptions, bool validate, relopt_kind kind, Size relopt_struct_size, const relopt_parse_elt *relopt_elems, int num_relopt_elems)
Definition: reloptions.c:1934
Definition: c.h:658

References build_reloptions(), lengthof, RELOPT_KIND_ATTRIBUTE, RELOPT_TYPE_REAL, and validate().

Referenced by ATExecSetOptions(), and get_attribute_options().

◆ build_local_reloptions()

void * build_local_reloptions ( local_relopts relopts,
Datum  options,
bool  validate 
)

Definition at line 1971 of file reloptions.c.

1972{
1973 int noptions = list_length(relopts->options);
1974 relopt_parse_elt *elems = palloc(sizeof(*elems) * noptions);
1975 relopt_value *vals;
1976 void *opts;
1977 int i = 0;
1978 ListCell *lc;
1979
1980 foreach(lc, relopts->options)
1981 {
1982 local_relopt *opt = lfirst(lc);
1983
1984 elems[i].optname = opt->option->name;
1985 elems[i].opttype = opt->option->type;
1986 elems[i].offset = opt->offset;
1987 elems[i].isset_offset = 0; /* not supported for local relopts yet */
1988
1989 i++;
1990 }
1991
1992 vals = parseLocalRelOptions(relopts, options, validate);
1995 elems, noptions);
1996
1997 if (validate)
1998 foreach(lc, relopts->validators)
1999 ((relopts_validator) lfirst(lc)) (opts, vals, noptions);
2000
2001 if (elems)
2002 pfree(elems);
2003
2004 return opts;
2005}
void pfree(void *pointer)
Definition: mcxt.c:2147
void * palloc(Size size)
Definition: mcxt.c:1940
static AmcheckOptions opts
Definition: pg_amcheck.c:112
static int list_length(const List *l)
Definition: pg_list.h:152
static size_t noptions
static relopt_value * parseLocalRelOptions(local_relopts *relopts, Datum options, bool validate)
Definition: reloptions.c:1552
static void fillRelOptions(void *rdopts, Size basesize, relopt_value *options, int numoptions, bool validate, const relopt_parse_elt *elems, int numelems)
Definition: reloptions.c:1753
static void * allocateReloptStruct(Size base, relopt_value *options, int numoptions)
Definition: reloptions.c:1713
void(* relopts_validator)(void *parsed_options, relopt_value *vals, int nvals)
Definition: reloptions.h:137
relopt_gen * option
Definition: reloptions.h:173
List * validators
Definition: reloptions.h:181
List * options
Definition: reloptions.h:180
Size relopt_struct_size
Definition: reloptions.h:182
const char * name
Definition: reloptions.h:66
relopt_type type
Definition: reloptions.h:72
const char * optname
Definition: reloptions.h:152
relopt_type opttype
Definition: reloptions.h:153

References allocateReloptStruct(), fillRelOptions(), i, relopt_parse_elt::isset_offset, lfirst, list_length(), relopt_gen::name, noptions, relopt_parse_elt::offset, local_relopt::offset, local_relopt::option, local_relopts::options, relopt_parse_elt::optname, opts, relopt_parse_elt::opttype, palloc(), parseLocalRelOptions(), pfree(), local_relopts::relopt_struct_size, relopt_gen::type, validate(), and local_relopts::validators.

Referenced by index_opclass_options().

◆ build_reloptions()

void * build_reloptions ( Datum  reloptions,
bool  validate,
relopt_kind  kind,
Size  relopt_struct_size,
const relopt_parse_elt relopt_elems,
int  num_relopt_elems 
)

Definition at line 1934 of file reloptions.c.

1939{
1940 int numoptions;
1942 void *rdopts;
1943
1944 /* parse options specific to given relation option kind */
1945 options = parseRelOptions(reloptions, validate, kind, &numoptions);
1946 Assert(numoptions <= num_relopt_elems);
1947
1948 /* if none set, we're done */
1949 if (numoptions == 0)
1950 {
1951 Assert(options == NULL);
1952 return NULL;
1953 }
1954
1955 /* allocate and fill the structure */
1956 rdopts = allocateReloptStruct(relopt_struct_size, options, numoptions);
1957 fillRelOptions(rdopts, relopt_struct_size, options, numoptions,
1958 validate, relopt_elems, num_relopt_elems);
1959
1960 pfree(options);
1961
1962 return rdopts;
1963}
Assert(PointerIsAligned(start, uint64))
static char ** options
static relopt_value * parseRelOptions(Datum options, bool validate, relopt_kind kind, int *numrelopts)
Definition: reloptions.c:1510

References allocateReloptStruct(), Assert(), fillRelOptions(), options, parseRelOptions(), pfree(), and validate().

Referenced by attribute_reloptions(), bloptions(), brinoptions(), btoptions(), default_reloptions(), dioptions(), ginoptions(), gistoptions(), hashoptions(), spgoptions(), tablespace_reloptions(), and view_reloptions().

◆ default_reloptions()

bytea * default_reloptions ( Datum  reloptions,
bool  validate,
relopt_kind  kind 
)

Definition at line 1860 of file reloptions.c.

1861{
1862 static const relopt_parse_elt tab[] = {
1863 {"fillfactor", RELOPT_TYPE_INT, offsetof(StdRdOptions, fillfactor)},
1864 {"autovacuum_enabled", RELOPT_TYPE_BOOL,
1865 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, enabled)},
1866 {"autovacuum_vacuum_threshold", RELOPT_TYPE_INT,
1867 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, vacuum_threshold)},
1868 {"autovacuum_vacuum_max_threshold", RELOPT_TYPE_INT,
1869 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, vacuum_max_threshold)},
1870 {"autovacuum_vacuum_insert_threshold", RELOPT_TYPE_INT,
1871 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, vacuum_ins_threshold)},
1872 {"autovacuum_analyze_threshold", RELOPT_TYPE_INT,
1873 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, analyze_threshold)},
1874 {"autovacuum_vacuum_cost_limit", RELOPT_TYPE_INT,
1875 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, vacuum_cost_limit)},
1876 {"autovacuum_freeze_min_age", RELOPT_TYPE_INT,
1877 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, freeze_min_age)},
1878 {"autovacuum_freeze_max_age", RELOPT_TYPE_INT,
1879 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, freeze_max_age)},
1880 {"autovacuum_freeze_table_age", RELOPT_TYPE_INT,
1881 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, freeze_table_age)},
1882 {"autovacuum_multixact_freeze_min_age", RELOPT_TYPE_INT,
1883 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, multixact_freeze_min_age)},
1884 {"autovacuum_multixact_freeze_max_age", RELOPT_TYPE_INT,
1885 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, multixact_freeze_max_age)},
1886 {"autovacuum_multixact_freeze_table_age", RELOPT_TYPE_INT,
1887 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, multixact_freeze_table_age)},
1888 {"log_autovacuum_min_duration", RELOPT_TYPE_INT,
1889 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, log_min_duration)},
1890 {"toast_tuple_target", RELOPT_TYPE_INT,
1891 offsetof(StdRdOptions, toast_tuple_target)},
1892 {"autovacuum_vacuum_cost_delay", RELOPT_TYPE_REAL,
1893 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, vacuum_cost_delay)},
1894 {"autovacuum_vacuum_scale_factor", RELOPT_TYPE_REAL,
1895 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, vacuum_scale_factor)},
1896 {"autovacuum_vacuum_insert_scale_factor", RELOPT_TYPE_REAL,
1897 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, vacuum_ins_scale_factor)},
1898 {"autovacuum_analyze_scale_factor", RELOPT_TYPE_REAL,
1899 offsetof(StdRdOptions, autovacuum) + offsetof(AutoVacOpts, analyze_scale_factor)},
1900 {"user_catalog_table", RELOPT_TYPE_BOOL,
1901 offsetof(StdRdOptions, user_catalog_table)},
1902 {"parallel_workers", RELOPT_TYPE_INT,
1903 offsetof(StdRdOptions, parallel_workers)},
1904 {"vacuum_index_cleanup", RELOPT_TYPE_ENUM,
1905 offsetof(StdRdOptions, vacuum_index_cleanup)},
1906 {"vacuum_truncate", RELOPT_TYPE_BOOL,
1907 offsetof(StdRdOptions, vacuum_truncate), offsetof(StdRdOptions, vacuum_truncate_set)},
1908 {"vacuum_max_eager_freeze_failure_rate", RELOPT_TYPE_REAL,
1910 };
1911
1912 return (bytea *) build_reloptions(reloptions, validate, kind,
1913 sizeof(StdRdOptions),
1914 tab, lengthof(tab));
1915}
static int fillfactor
Definition: pgbench.c:188
double vacuum_max_eager_freeze_failure_rate
Definition: vacuum.c:79
double vacuum_cost_delay
Definition: vacuum.c:89
int vacuum_cost_limit
Definition: vacuum.c:90
bool vacuum_truncate
Definition: vacuum.c:81

References build_reloptions(), fillfactor, lengthof, RELOPT_TYPE_BOOL, RELOPT_TYPE_ENUM, RELOPT_TYPE_INT, RELOPT_TYPE_REAL, vacuum_cost_delay, vacuum_cost_limit, vacuum_max_eager_freeze_failure_rate, vacuum_truncate, and validate().

Referenced by heap_reloptions().

◆ extractRelOptions()

bytea * extractRelOptions ( HeapTuple  tuple,
TupleDesc  tupdesc,
amoptions_function  amoptions 
)

Definition at line 1390 of file reloptions.c.

1392{
1393 bytea *options;
1394 bool isnull;
1395 Datum datum;
1396 Form_pg_class classForm;
1397
1398 datum = fastgetattr(tuple,
1399 Anum_pg_class_reloptions,
1400 tupdesc,
1401 &isnull);
1402 if (isnull)
1403 return NULL;
1404
1405 classForm = (Form_pg_class) GETSTRUCT(tuple);
1406
1407 /* Parse into appropriate format; don't error out here */
1408 switch (classForm->relkind)
1409 {
1410 case RELKIND_RELATION:
1411 case RELKIND_TOASTVALUE:
1412 case RELKIND_MATVIEW:
1413 options = heap_reloptions(classForm->relkind, datum, false);
1414 break;
1415 case RELKIND_PARTITIONED_TABLE:
1416 options = partitioned_table_reloptions(datum, false);
1417 break;
1418 case RELKIND_VIEW:
1419 options = view_reloptions(datum, false);
1420 break;
1421 case RELKIND_INDEX:
1422 case RELKIND_PARTITIONED_INDEX:
1423 options = index_reloptions(amoptions, datum, false);
1424 break;
1425 case RELKIND_FOREIGN_TABLE:
1426 options = NULL;
1427 break;
1428 default:
1429 Assert(false); /* can't get here */
1430 options = NULL; /* keep compiler quiet */
1431 break;
1432 }
1433
1434 return options;
1435}
static void * GETSTRUCT(const HeapTupleData *tuple)
Definition: htup_details.h:728
static Datum fastgetattr(HeapTuple tup, int attnum, TupleDesc tupleDesc, bool *isnull)
Definition: htup_details.h:861
FormData_pg_class * Form_pg_class
Definition: pg_class.h:156
uintptr_t Datum
Definition: postgres.h:69
bytea * view_reloptions(Datum reloptions, bool validate)
Definition: reloptions.c:2025
bytea * index_reloptions(amoptions_function amoptions, Datum reloptions, bool validate)
Definition: reloptions.c:2081
bytea * partitioned_table_reloptions(Datum reloptions, bool validate)
Definition: reloptions.c:2011
bytea * heap_reloptions(char relkind, Datum reloptions, bool validate)
Definition: reloptions.c:2046

References Assert(), fastgetattr(), GETSTRUCT(), heap_reloptions(), index_reloptions(), options, partitioned_table_reloptions(), and view_reloptions().

Referenced by extract_autovac_opts(), and RelationParseRelOptions().

◆ heap_reloptions()

bytea * heap_reloptions ( char  relkind,
Datum  reloptions,
bool  validate 
)

Definition at line 2046 of file reloptions.c.

2047{
2048 StdRdOptions *rdopts;
2049
2050 switch (relkind)
2051 {
2052 case RELKIND_TOASTVALUE:
2053 rdopts = (StdRdOptions *)
2055 if (rdopts != NULL)
2056 {
2057 /* adjust default-only parameters for TOAST relations */
2058 rdopts->fillfactor = 100;
2059 rdopts->autovacuum.analyze_threshold = -1;
2060 rdopts->autovacuum.analyze_scale_factor = -1;
2061 }
2062 return (bytea *) rdopts;
2063 case RELKIND_RELATION:
2064 case RELKIND_MATVIEW:
2065 return default_reloptions(reloptions, validate, RELOPT_KIND_HEAP);
2066 default:
2067 /* other relkinds are not supported */
2068 return NULL;
2069 }
2070}
bytea * default_reloptions(Datum reloptions, bool validate, relopt_kind kind)
Definition: reloptions.c:1860
int analyze_threshold
Definition: rel.h:317
float8 analyze_scale_factor
Definition: rel.h:329
int fillfactor
Definition: rel.h:343
AutoVacOpts autovacuum
Definition: rel.h:345

References AutoVacOpts::analyze_scale_factor, AutoVacOpts::analyze_threshold, StdRdOptions::autovacuum, default_reloptions(), StdRdOptions::fillfactor, RELOPT_KIND_HEAP, RELOPT_KIND_TOAST, and validate().

Referenced by ATExecSetRelOptions(), create_ctas_internal(), DefineRelation(), extractRelOptions(), and ProcessUtilitySlow().

◆ index_reloptions()

bytea * index_reloptions ( amoptions_function  amoptions,
Datum  reloptions,
bool  validate 
)

Definition at line 2081 of file reloptions.c.

2082{
2083 Assert(amoptions != NULL);
2084
2085 /* Assume function is strict */
2086 if (!PointerIsValid(DatumGetPointer(reloptions)))
2087 return NULL;
2088
2089 return amoptions(reloptions, validate);
2090}
#define PointerIsValid(pointer)
Definition: c.h:734
static Pointer DatumGetPointer(Datum X)
Definition: postgres.h:317

References Assert(), DatumGetPointer(), PointerIsValid, and validate().

Referenced by ATExecSetRelOptions(), DefineIndex(), and extractRelOptions().

◆ init_local_reloptions()

void init_local_reloptions ( local_relopts relopts,
Size  relopt_struct_size 
)

◆ partitioned_table_reloptions()

bytea * partitioned_table_reloptions ( Datum  reloptions,
bool  validate 
)

Definition at line 2011 of file reloptions.c.

2012{
2013 if (validate && reloptions)
2014 ereport(ERROR,
2015 errcode(ERRCODE_WRONG_OBJECT_TYPE),
2016 errmsg("cannot specify storage parameters for a partitioned table"),
2017 errhint("Specify storage parameters for its leaf partitions instead."));
2018 return NULL;
2019}
int errhint(const char *fmt,...)
Definition: elog.c:1318

References ereport, errcode(), errhint(), errmsg(), ERROR, and validate().

Referenced by ATExecSetRelOptions(), DefineRelation(), and extractRelOptions().

◆ register_reloptions_validator()

void register_reloptions_validator ( local_relopts relopts,
relopts_validator  validator 
)

Definition at line 758 of file reloptions.c.

759{
760 relopts->validators = lappend(relopts->validators, validator);
761}
List * lappend(List *list, void *datum)
Definition: list.c:339

References lappend(), and local_relopts::validators.

Referenced by ltree_gist_options().

◆ tablespace_reloptions()

bytea * tablespace_reloptions ( Datum  reloptions,
bool  validate 
)

Definition at line 2113 of file reloptions.c.

2114{
2115 static const relopt_parse_elt tab[] = {
2116 {"random_page_cost", RELOPT_TYPE_REAL, offsetof(TableSpaceOpts, random_page_cost)},
2117 {"seq_page_cost", RELOPT_TYPE_REAL, offsetof(TableSpaceOpts, seq_page_cost)},
2118 {"effective_io_concurrency", RELOPT_TYPE_INT, offsetof(TableSpaceOpts, effective_io_concurrency)},
2119 {"maintenance_io_concurrency", RELOPT_TYPE_INT, offsetof(TableSpaceOpts, maintenance_io_concurrency)}
2120 };
2121
2122 return (bytea *) build_reloptions(reloptions, validate,
2124 sizeof(TableSpaceOpts),
2125 tab, lengthof(tab));
2126}
int maintenance_io_concurrency
Definition: bufmgr.c:159
int effective_io_concurrency
Definition: bufmgr.c:152
double random_page_cost
Definition: costsize.c:131
double seq_page_cost
Definition: costsize.c:130

References build_reloptions(), effective_io_concurrency, lengthof, maintenance_io_concurrency, random_page_cost, RELOPT_KIND_TABLESPACE, RELOPT_TYPE_INT, RELOPT_TYPE_REAL, seq_page_cost, and validate().

Referenced by AlterTableSpaceOptions(), CreateTableSpace(), and get_tablespace().

◆ transformRelOptions()

Datum transformRelOptions ( Datum  oldOptions,
List defList,
const char *  namspace,
const char *const  validnsps[],
bool  acceptOidsOff,
bool  isReset 
)

Definition at line 1167 of file reloptions.c.

1169{
1170 Datum result;
1171 ArrayBuildState *astate;
1172 ListCell *cell;
1173
1174 /* no change if empty list */
1175 if (defList == NIL)
1176 return oldOptions;
1177
1178 /* We build new array using accumArrayResult */
1179 astate = NULL;
1180
1181 /* Copy any oldOptions that aren't to be replaced */
1182 if (PointerIsValid(DatumGetPointer(oldOptions)))
1183 {
1184 ArrayType *array = DatumGetArrayTypeP(oldOptions);
1185 Datum *oldoptions;
1186 int noldoptions;
1187 int i;
1188
1189 deconstruct_array_builtin(array, TEXTOID, &oldoptions, NULL, &noldoptions);
1190
1191 for (i = 0; i < noldoptions; i++)
1192 {
1193 char *text_str = VARDATA(oldoptions[i]);
1194 int text_len = VARSIZE(oldoptions[i]) - VARHDRSZ;
1195
1196 /* Search for a match in defList */
1197 foreach(cell, defList)
1198 {
1199 DefElem *def = (DefElem *) lfirst(cell);
1200 int kw_len;
1201
1202 /* ignore if not in the same namespace */
1203 if (namspace == NULL)
1204 {
1205 if (def->defnamespace != NULL)
1206 continue;
1207 }
1208 else if (def->defnamespace == NULL)
1209 continue;
1210 else if (strcmp(def->defnamespace, namspace) != 0)
1211 continue;
1212
1213 kw_len = strlen(def->defname);
1214 if (text_len > kw_len && text_str[kw_len] == '=' &&
1215 strncmp(text_str, def->defname, kw_len) == 0)
1216 break;
1217 }
1218 if (!cell)
1219 {
1220 /* No match, so keep old option */
1221 astate = accumArrayResult(astate, oldoptions[i],
1222 false, TEXTOID,
1224 }
1225 }
1226 }
1227
1228 /*
1229 * If CREATE/SET, add new options to array; if RESET, just check that the
1230 * user didn't say RESET (option=val). (Must do this because the grammar
1231 * doesn't enforce it.)
1232 */
1233 foreach(cell, defList)
1234 {
1235 DefElem *def = (DefElem *) lfirst(cell);
1236
1237 if (isReset)
1238 {
1239 if (def->arg != NULL)
1240 ereport(ERROR,
1241 (errcode(ERRCODE_SYNTAX_ERROR),
1242 errmsg("RESET must not include values for parameters")));
1243 }
1244 else
1245 {
1246 text *t;
1247 const char *value;
1248 Size len;
1249
1250 /*
1251 * Error out if the namespace is not valid. A NULL namespace is
1252 * always valid.
1253 */
1254 if (def->defnamespace != NULL)
1255 {
1256 bool valid = false;
1257 int i;
1258
1259 if (validnsps)
1260 {
1261 for (i = 0; validnsps[i]; i++)
1262 {
1263 if (strcmp(def->defnamespace, validnsps[i]) == 0)
1264 {
1265 valid = true;
1266 break;
1267 }
1268 }
1269 }
1270
1271 if (!valid)
1272 ereport(ERROR,
1273 (errcode(ERRCODE_INVALID_PARAMETER_VALUE),
1274 errmsg("unrecognized parameter namespace \"%s\"",
1275 def->defnamespace)));
1276 }
1277
1278 /* ignore if not in the same namespace */
1279 if (namspace == NULL)
1280 {
1281 if (def->defnamespace != NULL)
1282 continue;
1283 }
1284 else if (def->defnamespace == NULL)
1285 continue;
1286 else if (strcmp(def->defnamespace, namspace) != 0)
1287 continue;
1288
1289 /*
1290 * Flatten the DefElem into a text string like "name=arg". If we
1291 * have just "name", assume "name=true" is meant. Note: the
1292 * namespace is not output.
1293 */
1294 if (def->arg != NULL)
1295 value = defGetString(def);
1296 else
1297 value = "true";
1298
1299 /*
1300 * This is not a great place for this test, but there's no other
1301 * convenient place to filter the option out. As WITH (oids =
1302 * false) will be removed someday, this seems like an acceptable
1303 * amount of ugly.
1304 */
1305 if (acceptOidsOff && def->defnamespace == NULL &&
1306 strcmp(def->defname, "oids") == 0)
1307 {
1308 if (defGetBoolean(def))
1309 ereport(ERROR,
1310 (errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
1311 errmsg("tables declared WITH OIDS are not supported")));
1312 /* skip over option, reloptions machinery doesn't know it */
1313 continue;
1314 }
1315
1316 len = VARHDRSZ + strlen(def->defname) + 1 + strlen(value);
1317 /* +1 leaves room for sprintf's trailing null */
1318 t = (text *) palloc(len + 1);
1319 SET_VARSIZE(t, len);
1320 sprintf(VARDATA(t), "%s=%s", def->defname, value);
1321
1322 astate = accumArrayResult(astate, PointerGetDatum(t),
1323 false, TEXTOID,
1325 }
1326 }
1327
1328 if (astate)
1329 result = makeArrayResult(astate, CurrentMemoryContext);
1330 else
1331 result = (Datum) 0;
1332
1333 return result;
1334}
#define DatumGetArrayTypeP(X)
Definition: array.h:261
ArrayBuildState * accumArrayResult(ArrayBuildState *astate, Datum dvalue, bool disnull, Oid element_type, MemoryContext rcontext)
Definition: arrayfuncs.c:5350
void deconstruct_array_builtin(ArrayType *array, Oid elmtype, Datum **elemsp, bool **nullsp, int *nelemsp)
Definition: arrayfuncs.c:3697
Datum makeArrayResult(ArrayBuildState *astate, MemoryContext rcontext)
Definition: arrayfuncs.c:5420
#define VARHDRSZ
Definition: c.h:663
size_t Size
Definition: c.h:576
char * defGetString(DefElem *def)
Definition: define.c:35
bool defGetBoolean(DefElem *def)
Definition: define.c:94
static struct @165 value
MemoryContext CurrentMemoryContext
Definition: mcxt.c:159
const void size_t len
#define sprintf
Definition: port.h:241
static Datum PointerGetDatum(const void *X)
Definition: postgres.h:327
char * defnamespace
Definition: parsenodes.h:825
Node * arg
Definition: parsenodes.h:827
#define VARDATA(PTR)
Definition: varatt.h:278
#define SET_VARSIZE(PTR, len)
Definition: varatt.h:305
#define VARSIZE(PTR)
Definition: varatt.h:279

References accumArrayResult(), DefElem::arg, CurrentMemoryContext, DatumGetArrayTypeP, DatumGetPointer(), deconstruct_array_builtin(), defGetBoolean(), defGetString(), DefElem::defname, DefElem::defnamespace, ereport, errcode(), errmsg(), ERROR, i, len, lfirst, makeArrayResult(), NIL, palloc(), PointerGetDatum(), PointerIsValid, SET_VARSIZE, sprintf, value, VARDATA, VARHDRSZ, and VARSIZE.

Referenced by AlterTableSpaceOptions(), ATExecSetOptions(), ATExecSetRelOptions(), ComputeIndexAttrs(), create_ctas_internal(), CreateTableSpace(), DefineIndex(), DefineRelation(), and ProcessUtilitySlow().

◆ untransformRelOptions()

List * untransformRelOptions ( Datum  options)

Definition at line 1342 of file reloptions.c.

1343{
1344 List *result = NIL;
1345 ArrayType *array;
1346 Datum *optiondatums;
1347 int noptions;
1348 int i;
1349
1350 /* Nothing to do if no options */
1352 return result;
1353
1354 array = DatumGetArrayTypeP(options);
1355
1356 deconstruct_array_builtin(array, TEXTOID, &optiondatums, NULL, &noptions);
1357
1358 for (i = 0; i < noptions; i++)
1359 {
1360 char *s;
1361 char *p;
1362 Node *val = NULL;
1363
1364 s = TextDatumGetCString(optiondatums[i]);
1365 p = strchr(s, '=');
1366 if (p)
1367 {
1368 *p++ = '\0';
1369 val = (Node *) makeString(p);
1370 }
1371 result = lappend(result, makeDefElem(s, val, -1));
1372 }
1373
1374 return result;
1375}
#define TextDatumGetCString(d)
Definition: builtins.h:98
long val
Definition: informix.c:689
DefElem * makeDefElem(char *name, Node *arg, int location)
Definition: makefuncs.c:637
Definition: pg_list.h:54
Definition: nodes.h:135
String * makeString(char *str)
Definition: value.c:63

References DatumGetArrayTypeP, DatumGetPointer(), deconstruct_array_builtin(), i, lappend(), makeDefElem(), makeString(), NIL, noptions, PointerIsValid, TextDatumGetCString, and val.

Referenced by ATExecSetRelOptions(), dblink_fdw_validator(), file_fdw_validator(), generateClonedIndexStmt(), GetForeignColumnOptions(), GetForeignDataWrapperExtended(), GetForeignServerExtended(), GetForeignTable(), GetUserMapping(), pg_options_to_table(), postgres_fdw_validator(), postgresql_fdw_validator(), and transformGenericOptions().

◆ view_reloptions()

bytea * view_reloptions ( Datum  reloptions,
bool  validate 
)

Definition at line 2025 of file reloptions.c.

2026{
2027 static const relopt_parse_elt tab[] = {
2028 {"security_barrier", RELOPT_TYPE_BOOL,
2029 offsetof(ViewOptions, security_barrier)},
2030 {"security_invoker", RELOPT_TYPE_BOOL,
2031 offsetof(ViewOptions, security_invoker)},
2032 {"check_option", RELOPT_TYPE_ENUM,
2033 offsetof(ViewOptions, check_option)}
2034 };
2035
2036 return (bytea *) build_reloptions(reloptions, validate,
2038 sizeof(ViewOptions),
2039 tab, lengthof(tab));
2040}

References build_reloptions(), lengthof, RELOPT_KIND_VIEW, RELOPT_TYPE_BOOL, RELOPT_TYPE_ENUM, and validate().

Referenced by ATExecSetRelOptions(), DefineRelation(), and extractRelOptions().