summaryrefslogtreecommitdiff
path: root/contrib/intarray
diff options
context:
space:
mode:
authorPeter Eisentraut <peter@eisentraut.org>2025-09-12 08:13:05 +0200
committerPeter Eisentraut <peter@eisentraut.org>2025-09-12 08:15:41 +0200
commit675ddc4d704f4cde0bc72244263a9efbb0d32cb8 (patch)
treecfc28c244169e1851bba83fb8dbfadc218a365d6 /contrib/intarray
parent2aac62be8cbb870ccf8c5b3fbb8a4e4aa8a14a73 (diff)
Improve pgbench definition of yyscan_t
It was defining yyscan_t as a macro while the rest of the code uses a typedef with #ifdef guards around it. The latter is also what the flex generated code uses. So it seems best to make it look like those other places for consistency. The old way also had a potential for conflict if some code included multiple headers providing yyscan_t. exprscan.l includes #include "fe_utils/psqlscan_int.h" #include "pgbench.h" and fe_utils/psqlscan_int.h contains #ifndef YY_TYPEDEF_YY_SCANNER_T #define YY_TYPEDEF_YY_SCANNER_T typedef void *yyscan_t; #endif which was then followed by pgbench.h #define yyscan_t void * and then the generated code in exprscan.c #ifndef YY_TYPEDEF_YY_SCANNER_T #define YY_TYPEDEF_YY_SCANNER_T typedef void* yyscan_t; #endif This works, but if the #ifdef guard in psqlscan_int.h is removed, this fails. We want to move toward allowing repeat typedefs, per C11, but for that we need to make sure they are all the same. Reviewed-by: Chao Li <li.evan.chao@gmail.com> Discussion: https://www.postgresql.org/message-id/flat/10d32190-f31b-40a5-b177-11db55597355@eisentraut.org
Diffstat (limited to 'contrib/intarray')
0 files changed, 0 insertions, 0 deletions