mirror of
https://github.com/postgres/postgres.git
synced 2026-01-29 12:02:15 +03:00
Minor GUC code refactoring.
Split out "ConfigOptionIsVisible" to perform the privilege check for GUC_SUPERUSER_ONLY GUCs (which these days can also be read by pg_read_all_settings role members), and move the should-we-show-it checks from GetConfigOptionValues to its sole caller. This commit also removes get_explain_guc_options's check of GUC_NO_SHOW_ALL, which seems to have got cargo-culted in there. While there's no obvious use-case for marking a GUC both GUC_EXPLAIN and GUC_NO_SHOW_ALL, if it were set up that way one would expect EXPLAIN to show it --- if that's not what you want, then don't set GUC_EXPLAIN. In passing, simplify the loop logic in show_all_settings. Nitin Jadhav, Bharath Rupireddy, Tom Lane Discussion: https://postgr.es/m/CAMm1aWYgfekpRK-Jz5=pM_bV+Om=ktGq1vxTZ_dr1Z6MV-qokA@mail.gmail.com
This commit is contained in:
@@ -292,6 +292,9 @@ extern struct config_generic **get_explain_guc_options(int *num);
|
||||
/* get string value of variable */
|
||||
extern char *ShowGUCOption(struct config_generic *record, bool use_units);
|
||||
|
||||
/* get whether or not the GUC variable is visible to current user */
|
||||
extern bool ConfigOptionIsVisible(struct config_generic *conf);
|
||||
|
||||
/* get the current set of variables */
|
||||
extern struct config_generic **get_guc_variables(int *num_vars);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user