1
0
mirror of https://github.com/postgres/postgres.git synced 2025-07-18 17:42:25 +03:00

Use pg_assume() to avoid compiler warning below exec_set_found()

The warning, visible when building with -O3 and a recent-ish gcc, is due to
gcc not realizing that found is a byvalue type and therefore will never be
interpreted as a varlena type.

Discussion: https://postgr.es/m/3prdb6hkep3duglhsujrn52bkvnlkvhc54fzvph2emrsm4vodl@77yy6j4hkemb
Discussion: https://postgr.es/m/20230316172818.x6375uvheom3ibt2%40awork3.anarazel.de
Discussion: https://postgr.es/m/20240207203138.sknifhlppdtgtxnk%40awork3.anarazel.de
This commit is contained in:
Andres Freund
2025-07-09 18:38:05 -04:00
parent d65eb5b1b8
commit 48a23f6eae

View File

@ -8610,6 +8610,15 @@ exec_set_found(PLpgSQL_execstate *estate, bool state)
PLpgSQL_var *var;
var = (PLpgSQL_var *) (estate->datums[estate->found_varno]);
/*
* Use pg_assume() to avoid a spurious warning with some compilers, by
* telling the compiler that the VARATT_IS_EXTERNAL_NON_EXPANDED() branch
* in assign_simple_var() will never be reached when called from here, due
* to "found" being a boolean (i.e. a byvalue type), not a varlena.
*/
pg_assume(var->datatype->typlen != -1);
assign_simple_var(estate, var, BoolGetDatum(state), false, false);
}