On Wed, Jan 05, 2022 at 11:47:57AM +0900, Kyotaro Horiguchi wrote:
> At Tue, 28 Dec 2021 20:32:40 -0600, Justin Pryzby <pry...@telsasoft.com> 
> wrote in 
> > On Thu, Dec 09, 2021 at 09:53:23AM -0600, Justin Pryzby wrote:
> > > On Thu, Dec 09, 2021 at 05:17:54PM +0900, Michael Paquier wrote:
> > > One option is to expose the GUC flags in pg_settings, so this can all be 
> > > done
> > > in SQL regression tests.
> > > 
> > > Maybe the flags should be text strings, so it's a nicer user-facing 
> > > interface.
> > > But then the field would be pretty wide, even though we're only adding it 
> > > for
> > > regression tests.  The only other alternative I can think of is to make a
> > > sql-callable function like pg_get_guc_flags(text guc).
> > 
> > Rebased on cab5b9ab2c066ba904f13de2681872dcda31e207.
> > 
> > And added 0003, which changes to instead exposes the flags as a function, to
> > avoid changing pg_settings and exposing internally-defined integer flags in
> > that somewhat prominent view.
> 
> Just an idea but couldn't we use flags in a series of one-letter flag
> representations?  It is more user-friendly than integers but shorter
> than full-text representation.
> 
> +SELECT name, flags FROM pg_settings;
>           name          |  flags             
> ------------------------+--------
>  application_name       |  ARsec
>  transaction_deferrable |  Arsec
>  transaction_isolation  |  Arsec
>  transaction_read_only  |  Arsec

It's a good idea.

I suppose you intend that "A" means it's enabled and "a" means it's disabled ?

        A => show all
        R => reset all
        S => not in sample
        E => explain
        C => computed

Which is enough to support the tests that I came up with:

+       (flags&4) != 0 AS no_show_all,
+       (flags&8) != 0 AS no_reset_all,
+       (flags&32) != 0 AS not_in_sample,
+       (flags&1048576) != 0 AS guc_explain,
+       (flags&2097152) != 0 AS guc_computed

However, I think if we add a field to pg_stat_activity, it would be in a
separate patch, expected to be independently useful.

1) expose GUC flags to pg_stat_activity;
2) rewrite check_guc as a sql regression test;

In that case, *all* the flags should be exposed.  There's currently 20, which
means it may not work well after all - it's already too long, and could get
longer, and/or overflow the alphabet...

I think pg_get_guc_flags() may be best, but I'm interested to hear other
opinions.

-- 
Justin


Reply via email to