diff options
| author | Tom Lane | 2025-03-16 17:45:48 +0000 |
|---|---|---|
| committer | Tom Lane | 2025-03-16 17:45:48 +0000 |
| commit | 44890442398cf3a65230d53167e61905d2b0d348 (patch) | |
| tree | 1cb9b611315da7ac77b46aef74addc5918cb22d7 /contrib/isn/isn.h | |
| parent | 682c5be25c28192c56e9d5e2a9ca14673a2fcf4b (diff) | |
contrib/isn: Make weak mode a GUC setting, and fix related functions.
isn's weak mode used to be a simple static variable, settable only
via the isn_weak(boolean) function. This wasn't optimal, as this
means it doesn't respect transactions nor respond to RESET ALL.
This patch makes isn.weak a GUC parameter instead, so that
it acts like any other user-settable parameter.
The isn_weak() functions are retained for backwards compatibility.
But we must fix their volatility markings: they were marked IMMUTABLE
which is surely incorrect, and PARALLEL RESTRICTED which isn't right
for GUC-related functions either. Mark isn_weak(boolean) as
VOLATILE and PARALLEL UNSAFE, matching set_config(). Mark isn_weak()
as STABLE and PARALLEL SAFE, matching current_setting().
Reported-by: Viktor Holmberg <v@viktorh.net>
Diagnosed-by: Daniel Gustafsson <daniel@yesql.se>
Author: Viktor Holmberg <v@viktorh.net>
Reviewed-by: Tom Lane <tgl@sss.pgh.pa.us>
Discussion: https://postgr.es/m/790bc1f9-74dc-4b50-94d2-8147315b1556@Spark
Diffstat (limited to 'contrib/isn/isn.h')
| -rw-r--r-- | contrib/isn/isn.h | 1 |
1 files changed, 0 insertions, 1 deletions
diff --git a/contrib/isn/isn.h b/contrib/isn/isn.h index 038eb362c39..399896ad417 100644 --- a/contrib/isn/isn.h +++ b/contrib/isn/isn.h @@ -18,7 +18,6 @@ #include "fmgr.h" #undef ISN_DEBUG -#define ISN_WEAK_MODE /* * uint64 is the internal storage format for ISNs. |
