{
if (extra == gconf->extra)
return true;
- switch (gconf->vartype)
- {
- case PGC_BOOL:
- if (extra == ((struct config_bool *) gconf)->reset_extra)
- return true;
- break;
- case PGC_INT:
- if (extra == ((struct config_int *) gconf)->reset_extra)
- return true;
- break;
- case PGC_REAL:
- if (extra == ((struct config_real *) gconf)->reset_extra)
- return true;
- break;
- case PGC_STRING:
- if (extra == ((struct config_string *) gconf)->reset_extra)
- return true;
- break;
- case PGC_ENUM:
- if (extra == ((struct config_enum *) gconf)->reset_extra)
- return true;
- break;
- }
+ if (extra == gconf->reset_extra)
+ return true;
for (GucStack *stack = gconf->stack; stack; stack = stack->prev)
{
if (extra == stack->prior.extra ||
static void
InitializeOneGUCOption(struct config_generic *gconf)
{
+ void *extra = NULL;
+
gconf->status = 0;
gconf->source = PGC_S_DEFAULT;
gconf->reset_source = PGC_S_DEFAULT;
{
struct config_bool *conf = (struct config_bool *) gconf;
bool newval = conf->boot_val;
- void *extra = NULL;
if (!call_bool_check_hook(conf, &newval, &extra,
PGC_S_DEFAULT, LOG))
if (conf->assign_hook)
conf->assign_hook(newval, extra);
*conf->variable = conf->reset_val = newval;
- conf->gen.extra = conf->reset_extra = extra;
break;
}
case PGC_INT:
{
struct config_int *conf = (struct config_int *) gconf;
int newval = conf->boot_val;
- void *extra = NULL;
Assert(newval >= conf->min);
Assert(newval <= conf->max);
if (conf->assign_hook)
conf->assign_hook(newval, extra);
*conf->variable = conf->reset_val = newval;
- conf->gen.extra = conf->reset_extra = extra;
break;
}
case PGC_REAL:
{
struct config_real *conf = (struct config_real *) gconf;
double newval = conf->boot_val;
- void *extra = NULL;
Assert(newval >= conf->min);
Assert(newval <= conf->max);
if (conf->assign_hook)
conf->assign_hook(newval, extra);
*conf->variable = conf->reset_val = newval;
- conf->gen.extra = conf->reset_extra = extra;
break;
}
case PGC_STRING:
{
struct config_string *conf = (struct config_string *) gconf;
char *newval;
- void *extra = NULL;
/* non-NULL boot_val must always get strdup'd */
if (conf->boot_val != NULL)
if (conf->assign_hook)
conf->assign_hook(newval, extra);
*conf->variable = conf->reset_val = newval;
- conf->gen.extra = conf->reset_extra = extra;
break;
}
case PGC_ENUM:
{
struct config_enum *conf = (struct config_enum *) gconf;
int newval = conf->boot_val;
- void *extra = NULL;
if (!call_enum_check_hook(conf, &newval, &extra,
PGC_S_DEFAULT, LOG))
if (conf->assign_hook)
conf->assign_hook(newval, extra);
*conf->variable = conf->reset_val = newval;
- conf->gen.extra = conf->reset_extra = extra;
break;
}
}
+
+ gconf->extra = gconf->reset_extra = extra;
}
/*
if (conf->assign_hook)
conf->assign_hook(conf->reset_val,
- conf->reset_extra);
+ conf->gen.reset_extra);
*conf->variable = conf->reset_val;
set_extra_field(&conf->gen, &conf->gen.extra,
- conf->reset_extra);
+ conf->gen.reset_extra);
break;
}
case PGC_INT:
if (conf->assign_hook)
conf->assign_hook(conf->reset_val,
- conf->reset_extra);
+ conf->gen.reset_extra);
*conf->variable = conf->reset_val;
set_extra_field(&conf->gen, &conf->gen.extra,
- conf->reset_extra);
+ conf->gen.reset_extra);
break;
}
case PGC_REAL:
if (conf->assign_hook)
conf->assign_hook(conf->reset_val,
- conf->reset_extra);
+ conf->gen.reset_extra);
*conf->variable = conf->reset_val;
set_extra_field(&conf->gen, &conf->gen.extra,
- conf->reset_extra);
+ conf->gen.reset_extra);
break;
}
case PGC_STRING:
if (conf->assign_hook)
conf->assign_hook(conf->reset_val,
- conf->reset_extra);
+ conf->gen.reset_extra);
set_string_field(conf, conf->variable, conf->reset_val);
set_extra_field(&conf->gen, &conf->gen.extra,
- conf->reset_extra);
+ conf->gen.reset_extra);
break;
}
case PGC_ENUM:
if (conf->assign_hook)
conf->assign_hook(conf->reset_val,
- conf->reset_extra);
+ conf->gen.reset_extra);
*conf->variable = conf->reset_val;
set_extra_field(&conf->gen, &conf->gen.extra,
- conf->reset_extra);
+ conf->gen.reset_extra);
break;
}
}
else
{
newval = conf->reset_val;
- newextra = conf->reset_extra;
+ newextra = conf->gen.reset_extra;
source = conf->gen.reset_source;
context = conf->gen.reset_scontext;
srole = conf->gen.reset_srole;
if (conf->gen.reset_source <= source)
{
conf->reset_val = newval;
- set_extra_field(&conf->gen, &conf->reset_extra,
+ set_extra_field(&conf->gen, &conf->gen.reset_extra,
newextra);
conf->gen.reset_source = source;
conf->gen.reset_scontext = context;
else
{
newval = conf->reset_val;
- newextra = conf->reset_extra;
+ newextra = conf->gen.reset_extra;
source = conf->gen.reset_source;
context = conf->gen.reset_scontext;
srole = conf->gen.reset_srole;
if (conf->gen.reset_source <= source)
{
conf->reset_val = newval;
- set_extra_field(&conf->gen, &conf->reset_extra,
+ set_extra_field(&conf->gen, &conf->gen.reset_extra,
newextra);
conf->gen.reset_source = source;
conf->gen.reset_scontext = context;
else
{
newval = conf->reset_val;
- newextra = conf->reset_extra;
+ newextra = conf->gen.reset_extra;
source = conf->gen.reset_source;
context = conf->gen.reset_scontext;
srole = conf->gen.reset_srole;
if (conf->gen.reset_source <= source)
{
conf->reset_val = newval;
- set_extra_field(&conf->gen, &conf->reset_extra,
+ set_extra_field(&conf->gen, &conf->gen.reset_extra,
newextra);
conf->gen.reset_source = source;
conf->gen.reset_scontext = context;
* guc.c's control
*/
newval = conf->reset_val;
- newextra = conf->reset_extra;
+ newextra = conf->gen.reset_extra;
source = conf->gen.reset_source;
context = conf->gen.reset_scontext;
srole = conf->gen.reset_srole;
if (conf->gen.reset_source <= source)
{
set_string_field(conf, &conf->reset_val, newval);
- set_extra_field(&conf->gen, &conf->reset_extra,
+ set_extra_field(&conf->gen, &conf->gen.reset_extra,
newextra);
conf->gen.reset_source = source;
conf->gen.reset_scontext = context;
else
{
newval = conf->reset_val;
- newextra = conf->reset_extra;
+ newextra = conf->gen.reset_extra;
source = conf->gen.reset_source;
context = conf->gen.reset_scontext;
srole = conf->gen.reset_srole;
if (conf->gen.reset_source <= source)
{
conf->reset_val = newval;
- set_extra_field(&conf->gen, &conf->reset_extra,
+ set_extra_field(&conf->gen, &conf->gen.reset_extra,
newextra);
conf->gen.reset_source = source;
conf->gen.reset_scontext = context;
switch (gconf->vartype)
{
case PGC_BOOL:
- {
- struct config_bool *conf = (struct config_bool *) gconf;
-
- if (conf->reset_extra && conf->reset_extra != gconf->extra)
- guc_free(conf->reset_extra);
- break;
- }
case PGC_INT:
- {
- struct config_int *conf = (struct config_int *) gconf;
-
- if (conf->reset_extra && conf->reset_extra != gconf->extra)
- guc_free(conf->reset_extra);
- break;
- }
case PGC_REAL:
- {
- struct config_real *conf = (struct config_real *) gconf;
-
- if (conf->reset_extra && conf->reset_extra != gconf->extra)
- guc_free(conf->reset_extra);
- break;
- }
+ case PGC_ENUM:
+ /* no need to do anything */
+ break;
case PGC_STRING:
{
struct config_string *conf = (struct config_string *) gconf;
guc_free(*conf->variable);
if (conf->reset_val && conf->reset_val != *conf->variable)
guc_free(conf->reset_val);
- if (conf->reset_extra && conf->reset_extra != gconf->extra)
- guc_free(conf->reset_extra);
- break;
- }
- case PGC_ENUM:
- {
- struct config_enum *conf = (struct config_enum *) gconf;
-
- if (conf->reset_extra && conf->reset_extra != gconf->extra)
- guc_free(conf->reset_extra);
break;
}
}
+ if (gconf->reset_extra && gconf->reset_extra != gconf->extra)
+ guc_free(gconf->reset_extra);
/* Remove it from any lists it's in. */
RemoveGUCFromLists(gconf);
/* Now we can reset the struct to PGS_S_DEFAULT state. */