pg_query 4.2.1 → 5.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGELOG.md +31 -0
- data/README.md +6 -8
- data/Rakefile +5 -6
- data/ext/pg_query/extconf.rb +14 -4
- data/ext/pg_query/include/pg_query.h +27 -3
- data/ext/pg_query/include/pg_query_enum_defs.c +311 -149
- data/ext/pg_query/include/pg_query_fingerprint_conds.c +545 -489
- data/ext/pg_query/include/pg_query_fingerprint_defs.c +5092 -4432
- data/ext/pg_query/include/pg_query_outfuncs_conds.c +385 -343
- data/ext/pg_query/include/pg_query_outfuncs_defs.c +1294 -1161
- data/ext/pg_query/include/pg_query_readfuncs_conds.c +137 -123
- data/ext/pg_query/include/pg_query_readfuncs_defs.c +1657 -1496
- data/ext/pg_query/include/{access → postgres/access}/amapi.h +3 -1
- data/ext/pg_query/include/{access → postgres/access}/attmap.h +5 -3
- data/ext/pg_query/include/{access → postgres/access}/attnum.h +1 -1
- data/ext/pg_query/include/{access → postgres/access}/clog.h +1 -1
- data/ext/pg_query/include/{access → postgres/access}/commit_ts.h +1 -1
- data/ext/pg_query/include/{access → postgres/access}/detoast.h +1 -1
- data/ext/pg_query/include/{access → postgres/access}/genam.h +7 -5
- data/ext/pg_query/include/{access → postgres/access}/gin.h +16 -3
- data/ext/pg_query/include/{access → postgres/access}/htup.h +1 -1
- data/ext/pg_query/include/{access → postgres/access}/htup_details.h +6 -2
- data/ext/pg_query/include/{access → postgres/access}/itup.h +61 -58
- data/ext/pg_query/include/{access → postgres/access}/parallel.h +2 -2
- data/ext/pg_query/include/{access → postgres/access}/printtup.h +1 -1
- data/ext/pg_query/include/{access → postgres/access}/relation.h +1 -1
- data/ext/pg_query/include/{access → postgres/access}/relscan.h +1 -1
- data/ext/pg_query/include/{access → postgres/access}/rmgrlist.h +2 -2
- data/ext/pg_query/include/{access → postgres/access}/sdir.h +12 -3
- data/ext/pg_query/include/{access → postgres/access}/skey.h +1 -1
- data/ext/pg_query/include/{access → postgres/access}/stratnum.h +1 -1
- data/ext/pg_query/include/{access → postgres/access}/sysattr.h +1 -1
- data/ext/pg_query/include/{access → postgres/access}/table.h +1 -1
- data/ext/pg_query/include/{access → postgres/access}/tableam.h +68 -45
- data/ext/pg_query/include/{access → postgres/access}/toast_compression.h +1 -1
- data/ext/pg_query/include/{access → postgres/access}/transam.h +1 -1
- data/ext/pg_query/include/postgres/access/tsmapi.h +82 -0
- data/ext/pg_query/include/{access → postgres/access}/tupconvert.h +5 -2
- data/ext/pg_query/include/{access → postgres/access}/tupdesc.h +2 -2
- data/ext/pg_query/include/{access → postgres/access}/tupmacs.h +58 -98
- data/ext/pg_query/include/{access → postgres/access}/twophase.h +2 -2
- data/ext/pg_query/include/{access → postgres/access}/xact.h +25 -18
- data/ext/pg_query/include/{access → postgres/access}/xlog.h +15 -16
- data/ext/pg_query/include/{access → postgres/access}/xlog_internal.h +100 -62
- data/ext/pg_query/include/postgres/access/xlogbackup.h +41 -0
- data/ext/pg_query/include/{access → postgres/access}/xlogdefs.h +6 -25
- data/ext/pg_query/include/{access → postgres/access}/xlogprefetcher.h +1 -1
- data/ext/pg_query/include/{access → postgres/access}/xlogreader.h +7 -6
- data/ext/pg_query/include/{access → postgres/access}/xlogrecord.h +17 -5
- data/ext/pg_query/include/{access → postgres/access}/xlogrecovery.h +4 -3
- data/ext/pg_query/include/postgres/archive/archive_module.h +59 -0
- data/ext/pg_query/include/{c.h → postgres/c.h} +144 -156
- data/ext/pg_query/include/{catalog → postgres/catalog}/catalog.h +4 -3
- data/ext/pg_query/include/{catalog → postgres/catalog}/catversion.h +6 -2
- data/ext/pg_query/include/{catalog → postgres/catalog}/dependency.h +5 -4
- data/ext/pg_query/include/{catalog → postgres/catalog}/genbki.h +7 -6
- data/ext/pg_query/include/{catalog → postgres/catalog}/index.h +4 -4
- data/ext/pg_query/include/{catalog → postgres/catalog}/indexing.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/namespace.h +2 -2
- data/ext/pg_query/include/{catalog → postgres/catalog}/objectaccess.h +10 -8
- data/ext/pg_query/include/{catalog → postgres/catalog}/objectaddress.h +3 -3
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_aggregate.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_aggregate_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_am.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_am_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_attribute.h +19 -17
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_attribute_d.h +19 -19
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_authid.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_authid_d.h +3 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_class.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_class_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_collation.h +3 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_collation_d.h +4 -3
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_constraint.h +2 -2
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_constraint_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_control.h +9 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_conversion.h +2 -2
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_conversion_d.h +1 -1
- data/ext/pg_query/include/postgres/catalog/pg_database.h +124 -0
- data/ext/pg_query/include/postgres/catalog/pg_database_d.h +52 -0
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_depend.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_depend_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_event_trigger.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_event_trigger_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_index.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_index_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_language.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_language_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_namespace.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_namespace_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_opclass.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_opclass_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_operator.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_operator_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_opfamily.h +3 -2
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_opfamily_d.h +4 -2
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_partitioned_table.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_partitioned_table_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_proc.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_proc_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_publication.h +2 -5
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_publication_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_replication_origin.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_replication_origin_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_statistic.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_statistic_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_statistic_ext.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_statistic_ext_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_transform.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_transform_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_trigger.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_trigger_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_ts_config.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_ts_config_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_ts_dict.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_ts_dict_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_ts_parser.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_ts_parser_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_ts_template.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_ts_template_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_type.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_type_d.h +1 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/storage.h +6 -6
- data/ext/pg_query/include/{commands → postgres/commands}/async.h +1 -1
- data/ext/pg_query/include/{commands → postgres/commands}/dbcommands.h +2 -1
- data/ext/pg_query/include/{commands → postgres/commands}/defrem.h +2 -1
- data/ext/pg_query/include/{commands → postgres/commands}/event_trigger.h +1 -1
- data/ext/pg_query/include/{commands → postgres/commands}/explain.h +3 -1
- data/ext/pg_query/include/{commands → postgres/commands}/prepare.h +1 -1
- data/ext/pg_query/include/{commands → postgres/commands}/tablespace.h +4 -4
- data/ext/pg_query/include/{commands → postgres/commands}/trigger.h +15 -14
- data/ext/pg_query/include/{commands → postgres/commands}/user.h +9 -3
- data/ext/pg_query/include/{commands → postgres/commands}/vacuum.h +60 -14
- data/ext/pg_query/include/postgres/common/cryptohash.h +39 -0
- data/ext/pg_query/include/{common → postgres/common}/file_perm.h +1 -1
- data/ext/pg_query/include/{common → postgres/common}/hashfn.h +1 -1
- data/ext/pg_query/include/postgres/common/int.h +437 -0
- data/ext/pg_query/include/{common → postgres/common}/keywords.h +1 -1
- data/ext/pg_query/include/{common → postgres/common}/kwlookup.h +2 -2
- data/ext/pg_query/include/{common → postgres/common}/pg_prng.h +3 -2
- data/ext/pg_query/include/{common → postgres/common}/relpath.h +20 -13
- data/ext/pg_query/include/postgres/common/scram-common.h +70 -0
- data/ext/pg_query/include/postgres/common/sha2.h +32 -0
- data/ext/pg_query/include/{common → postgres/common}/string.h +5 -3
- data/ext/pg_query/include/{common → postgres/common}/unicode_east_asian_fw_table.h +10 -10
- data/ext/pg_query/include/{common/unicode_combining_table.h → postgres/common/unicode_nonspacing_table.h} +31 -13
- data/ext/pg_query/include/postgres/copyfuncs.funcs.c +5013 -0
- data/ext/pg_query/include/postgres/copyfuncs.switch.c +938 -0
- data/ext/pg_query/include/{datatype → postgres/datatype}/timestamp.h +11 -4
- data/ext/pg_query/include/postgres/equalfuncs.funcs.c +3097 -0
- data/ext/pg_query/include/postgres/equalfuncs.switch.c +785 -0
- data/ext/pg_query/include/{executor → postgres/executor}/execdesc.h +1 -1
- data/ext/pg_query/include/{executor → postgres/executor}/executor.h +34 -17
- data/ext/pg_query/include/{executor → postgres/executor}/functions.h +1 -1
- data/ext/pg_query/include/{executor → postgres/executor}/instrument.h +1 -1
- data/ext/pg_query/include/{executor → postgres/executor}/spi.h +2 -2
- data/ext/pg_query/include/{executor → postgres/executor}/tablefunc.h +1 -1
- data/ext/pg_query/include/{executor → postgres/executor}/tuptable.h +18 -11
- data/ext/pg_query/include/{fmgr.h → postgres/fmgr.h} +21 -2
- data/ext/pg_query/include/postgres/foreign/fdwapi.h +294 -0
- data/ext/pg_query/include/{funcapi.h → postgres/funcapi.h} +12 -12
- data/ext/pg_query/include/postgres/gram.h +1127 -0
- data/ext/pg_query/include/{parser → postgres}/gramparse.h +4 -4
- data/ext/pg_query/include/{jit → postgres/jit}/jit.h +2 -2
- data/ext/pg_query/include/postgres/kwlist_d.h +1119 -0
- data/ext/pg_query/include/{lib → postgres/lib}/dshash.h +4 -1
- data/ext/pg_query/include/{lib → postgres/lib}/ilist.h +435 -22
- data/ext/pg_query/include/{lib → postgres/lib}/pairingheap.h +1 -1
- data/ext/pg_query/include/{lib → postgres/lib}/simplehash.h +9 -9
- data/ext/pg_query/include/{lib → postgres/lib}/sort_template.h +1 -1
- data/ext/pg_query/include/{lib → postgres/lib}/stringinfo.h +3 -3
- data/ext/pg_query/include/{libpq → postgres/libpq}/auth.h +8 -2
- data/ext/pg_query/include/{libpq → postgres/libpq}/crypt.h +1 -1
- data/ext/pg_query/include/{libpq → postgres/libpq}/hba.h +24 -17
- data/ext/pg_query/include/{libpq → postgres/libpq}/libpq-be.h +36 -25
- data/ext/pg_query/include/{libpq → postgres/libpq}/libpq.h +1 -1
- data/ext/pg_query/include/{libpq → postgres/libpq}/pqcomm.h +10 -41
- data/ext/pg_query/include/{libpq → postgres/libpq}/pqformat.h +2 -2
- data/ext/pg_query/include/{libpq → postgres/libpq}/pqsignal.h +22 -10
- data/ext/pg_query/include/postgres/libpq/sasl.h +136 -0
- data/ext/pg_query/include/postgres/libpq/scram.h +37 -0
- data/ext/pg_query/include/{mb → postgres/mb}/pg_wchar.h +35 -18
- data/ext/pg_query/include/{mb → postgres/mb}/stringinfo_mb.h +1 -1
- data/ext/pg_query/include/{miscadmin.h → postgres/miscadmin.h} +27 -15
- data/ext/pg_query/include/{nodes → postgres/nodes}/bitmapset.h +11 -7
- data/ext/pg_query/include/{nodes → postgres/nodes}/execnodes.h +83 -30
- data/ext/pg_query/include/{nodes → postgres/nodes}/extensible.h +5 -3
- data/ext/pg_query/include/{nodes → postgres/nodes}/lockoptions.h +1 -1
- data/ext/pg_query/include/{nodes → postgres/nodes}/makefuncs.h +14 -2
- data/ext/pg_query/include/{nodes → postgres/nodes}/memnodes.h +7 -4
- data/ext/pg_query/include/postgres/nodes/miscnodes.h +56 -0
- data/ext/pg_query/include/{nodes → postgres/nodes}/nodeFuncs.h +89 -29
- data/ext/pg_query/include/{nodes → postgres/nodes}/nodes.h +96 -511
- data/ext/pg_query/include/postgres/nodes/nodetags.h +471 -0
- data/ext/pg_query/include/{nodes → postgres/nodes}/params.h +3 -3
- data/ext/pg_query/include/{nodes → postgres/nodes}/parsenodes.h +377 -139
- data/ext/pg_query/include/{nodes → postgres/nodes}/pathnodes.h +1090 -440
- data/ext/pg_query/include/{nodes → postgres/nodes}/pg_list.h +30 -7
- data/ext/pg_query/include/{nodes → postgres/nodes}/plannodes.h +367 -124
- data/ext/pg_query/include/{nodes → postgres/nodes}/primnodes.h +670 -222
- data/ext/pg_query/include/{nodes → postgres/nodes}/print.h +1 -1
- data/ext/pg_query/include/{utils → postgres/nodes}/queryjumble.h +5 -7
- data/ext/pg_query/include/postgres/nodes/replnodes.h +111 -0
- data/ext/pg_query/include/postgres/nodes/supportnodes.h +346 -0
- data/ext/pg_query/include/{nodes → postgres/nodes}/tidbitmap.h +1 -1
- data/ext/pg_query/include/{nodes → postgres/nodes}/value.h +12 -2
- data/ext/pg_query/include/{optimizer → postgres/optimizer}/cost.h +6 -4
- data/ext/pg_query/include/{optimizer → postgres/optimizer}/geqo.h +1 -1
- data/ext/pg_query/include/{optimizer → postgres/optimizer}/geqo_gene.h +1 -1
- data/ext/pg_query/include/{optimizer → postgres/optimizer}/optimizer.h +8 -8
- data/ext/pg_query/include/{optimizer → postgres/optimizer}/paths.h +16 -7
- data/ext/pg_query/include/{optimizer → postgres/optimizer}/planmain.h +3 -6
- data/ext/pg_query/include/{parser → postgres/parser}/analyze.h +4 -3
- data/ext/pg_query/include/{parser → postgres/parser}/kwlist.h +12 -1
- data/ext/pg_query/include/{parser → postgres/parser}/parse_agg.h +4 -2
- data/ext/pg_query/include/{parser → postgres/parser}/parse_coerce.h +3 -1
- data/ext/pg_query/include/{parser → postgres/parser}/parse_expr.h +1 -1
- data/ext/pg_query/include/{parser → postgres/parser}/parse_func.h +1 -1
- data/ext/pg_query/include/{parser → postgres/parser}/parse_node.h +22 -4
- data/ext/pg_query/include/{parser → postgres/parser}/parse_oper.h +3 -3
- data/ext/pg_query/include/{parser → postgres/parser}/parse_relation.h +8 -3
- data/ext/pg_query/include/{parser → postgres/parser}/parse_type.h +4 -3
- data/ext/pg_query/include/{parser → postgres/parser}/parser.h +4 -4
- data/ext/pg_query/include/{parser → postgres/parser}/parsetree.h +1 -1
- data/ext/pg_query/include/{parser → postgres/parser}/scanner.h +2 -2
- data/ext/pg_query/include/{parser → postgres/parser}/scansup.h +1 -1
- data/ext/pg_query/include/{partitioning → postgres/partitioning}/partdefs.h +1 -1
- data/ext/pg_query/include/{pg_config.h → postgres/pg_config.h} +158 -218
- data/ext/pg_query/include/{pg_config_manual.h → postgres/pg_config_manual.h} +8 -46
- data/ext/pg_query/include/postgres/pg_config_os.h +8 -0
- data/ext/pg_query/include/{pg_getopt.h → postgres/pg_getopt.h} +1 -1
- data/ext/pg_query/include/{pg_trace.h → postgres/pg_trace.h} +1 -1
- data/ext/pg_query/include/{pgstat.h → postgres/pgstat.h} +173 -94
- data/ext/pg_query/include/{pgtime.h → postgres/pgtime.h} +3 -3
- data/ext/pg_query/include/{pl_gram.h → postgres/pl_gram.h} +66 -64
- data/ext/pg_query/include/{pl_reserved_kwlist.h → postgres/pl_reserved_kwlist.h} +1 -1
- data/ext/pg_query/include/{pl_reserved_kwlist_d.h → postgres/pl_reserved_kwlist_d.h} +1 -1
- data/ext/pg_query/include/{pl_unreserved_kwlist.h → postgres/pl_unreserved_kwlist.h} +2 -1
- data/ext/pg_query/include/{pl_unreserved_kwlist_d.h → postgres/pl_unreserved_kwlist_d.h} +48 -46
- data/ext/pg_query/include/{plpgsql.h → postgres/plpgsql.h} +28 -33
- data/ext/pg_query/include/{port → postgres/port}/atomics/arch-arm.h +3 -3
- data/ext/pg_query/include/postgres/port/atomics/arch-hppa.h +17 -0
- data/ext/pg_query/include/{port → postgres/port}/atomics/arch-ppc.h +21 -21
- data/ext/pg_query/include/{port → postgres/port}/atomics/arch-x86.h +2 -2
- data/ext/pg_query/include/{port → postgres/port}/atomics/fallback.h +3 -3
- data/ext/pg_query/include/{port → postgres/port}/atomics/generic-gcc.h +1 -1
- data/ext/pg_query/include/postgres/port/atomics/generic-msvc.h +101 -0
- data/ext/pg_query/include/postgres/port/atomics/generic-sunpro.h +106 -0
- data/ext/pg_query/include/{port → postgres/port}/atomics/generic.h +1 -1
- data/ext/pg_query/include/{port → postgres/port}/atomics.h +2 -7
- data/ext/pg_query/include/{port → postgres/port}/pg_bitutils.h +62 -25
- data/ext/pg_query/include/{port → postgres/port}/pg_bswap.h +1 -1
- data/ext/pg_query/include/{port → postgres/port}/pg_crc32c.h +1 -1
- data/ext/pg_query/include/postgres/port/simd.h +375 -0
- data/ext/pg_query/include/postgres/port/win32/arpa/inet.h +3 -0
- data/ext/pg_query/include/postgres/port/win32/dlfcn.h +1 -0
- data/ext/pg_query/include/postgres/port/win32/grp.h +1 -0
- data/ext/pg_query/include/postgres/port/win32/netdb.h +7 -0
- data/ext/pg_query/include/postgres/port/win32/netinet/in.h +3 -0
- data/ext/pg_query/include/postgres/port/win32/netinet/tcp.h +7 -0
- data/ext/pg_query/include/postgres/port/win32/pwd.h +3 -0
- data/ext/pg_query/include/postgres/port/win32/sys/resource.h +20 -0
- data/ext/pg_query/include/postgres/port/win32/sys/select.h +3 -0
- data/ext/pg_query/include/postgres/port/win32/sys/socket.h +26 -0
- data/ext/pg_query/include/postgres/port/win32/sys/un.h +17 -0
- data/ext/pg_query/include/postgres/port/win32/sys/wait.h +3 -0
- data/ext/pg_query/include/postgres/port/win32.h +59 -0
- data/ext/pg_query/include/postgres/port/win32_msvc/dirent.h +34 -0
- data/ext/pg_query/include/postgres/port/win32_msvc/sys/file.h +1 -0
- data/ext/pg_query/include/postgres/port/win32_msvc/sys/param.h +1 -0
- data/ext/pg_query/include/postgres/port/win32_msvc/sys/time.h +1 -0
- data/ext/pg_query/include/postgres/port/win32_msvc/unistd.h +9 -0
- data/ext/pg_query/include/postgres/port/win32_msvc/utime.h +3 -0
- data/ext/pg_query/include/postgres/port/win32_port.h +594 -0
- data/ext/pg_query/include/{port.h → postgres/port.h} +42 -75
- data/ext/pg_query/include/postgres/portability/instr_time.h +197 -0
- data/ext/pg_query/include/postgres/postgres.h +579 -0
- data/ext/pg_query/include/{postgres_ext.h → postgres/postgres_ext.h} +0 -1
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/autovacuum.h +1 -4
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/bgworker.h +2 -2
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/bgworker_internals.h +1 -1
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/bgwriter.h +2 -2
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/interrupt.h +1 -1
- data/ext/pg_query/include/postgres/postmaster/pgarch.h +36 -0
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/postmaster.h +6 -3
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/startup.h +3 -1
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/syslogger.h +2 -2
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/walwriter.h +3 -1
- data/ext/pg_query/include/{regex → postgres/regex}/regex.h +9 -6
- data/ext/pg_query/include/{replication → postgres/replication}/logicallauncher.h +6 -1
- data/ext/pg_query/include/{replication → postgres/replication}/logicalproto.h +30 -10
- data/ext/pg_query/include/postgres/replication/logicalworker.h +32 -0
- data/ext/pg_query/include/{replication → postgres/replication}/origin.h +4 -4
- data/ext/pg_query/include/{replication → postgres/replication}/reorderbuffer.h +113 -45
- data/ext/pg_query/include/{replication → postgres/replication}/slot.h +25 -6
- data/ext/pg_query/include/{replication → postgres/replication}/syncrep.h +2 -8
- data/ext/pg_query/include/{replication → postgres/replication}/walreceiver.h +15 -9
- data/ext/pg_query/include/{replication → postgres/replication}/walsender.h +13 -13
- data/ext/pg_query/include/{rewrite → postgres/rewrite}/prs2lock.h +1 -1
- data/ext/pg_query/include/{rewrite → postgres/rewrite}/rewriteHandler.h +1 -4
- data/ext/pg_query/include/{rewrite → postgres/rewrite}/rewriteManip.h +11 -2
- data/ext/pg_query/include/{rewrite → postgres/rewrite}/rewriteSupport.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/backendid.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/block.h +24 -31
- data/ext/pg_query/include/{storage → postgres/storage}/buf.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/bufmgr.h +183 -87
- data/ext/pg_query/include/{storage → postgres/storage}/bufpage.h +146 -93
- data/ext/pg_query/include/{storage → postgres/storage}/condition_variable.h +2 -2
- data/ext/pg_query/include/{storage → postgres/storage}/dsm.h +3 -6
- data/ext/pg_query/include/{storage → postgres/storage}/dsm_impl.h +4 -1
- data/ext/pg_query/include/{storage → postgres/storage}/fd.h +24 -20
- data/ext/pg_query/include/{storage → postgres/storage}/fileset.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/ipc.h +2 -2
- data/ext/pg_query/include/{storage → postgres/storage}/item.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/itemid.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/itemptr.h +94 -57
- data/ext/pg_query/include/{storage → postgres/storage}/large_object.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/latch.h +9 -1
- data/ext/pg_query/include/{storage → postgres/storage}/lmgr.h +6 -1
- data/ext/pg_query/include/{storage → postgres/storage}/lock.h +21 -13
- data/ext/pg_query/include/{storage → postgres/storage}/lockdefs.h +3 -3
- data/ext/pg_query/include/{storage → postgres/storage}/lwlock.h +16 -2
- data/ext/pg_query/include/{storage → postgres/storage}/off.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/pg_sema.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/pg_shmem.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/pmsignal.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/predicate.h +2 -2
- data/ext/pg_query/include/{storage → postgres/storage}/proc.h +22 -17
- data/ext/pg_query/include/{storage → postgres/storage}/procarray.h +3 -2
- data/ext/pg_query/include/{storage → postgres/storage}/proclist_types.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/procsignal.h +3 -1
- data/ext/pg_query/include/postgres/storage/relfilelocator.h +99 -0
- data/ext/pg_query/include/{storage → postgres/storage}/s_lock.h +66 -309
- data/ext/pg_query/include/{storage → postgres/storage}/sharedfileset.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/shm_mq.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/shm_toc.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/shmem.h +1 -23
- data/ext/pg_query/include/{storage → postgres/storage}/sinval.h +3 -3
- data/ext/pg_query/include/{storage → postgres/storage}/sinvaladt.h +4 -2
- data/ext/pg_query/include/{storage → postgres/storage}/smgr.h +12 -10
- data/ext/pg_query/include/{storage → postgres/storage}/spin.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/standby.h +9 -8
- data/ext/pg_query/include/{storage → postgres/storage}/standbydefs.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/sync.h +3 -3
- data/ext/pg_query/include/{tcop → postgres/tcop}/cmdtag.h +7 -2
- data/ext/pg_query/include/{tcop → postgres/tcop}/cmdtaglist.h +1 -1
- data/ext/pg_query/include/{tcop → postgres/tcop}/deparse_utility.h +1 -1
- data/ext/pg_query/include/{tcop → postgres/tcop}/dest.h +1 -3
- data/ext/pg_query/include/{tcop → postgres/tcop}/fastpath.h +1 -1
- data/ext/pg_query/include/{tcop → postgres/tcop}/pquery.h +1 -1
- data/ext/pg_query/include/{tcop → postgres/tcop}/tcopprot.h +3 -6
- data/ext/pg_query/include/{tcop → postgres/tcop}/utility.h +1 -1
- data/ext/pg_query/include/{tsearch → postgres/tsearch}/ts_cache.h +2 -4
- data/ext/pg_query/include/{utils → postgres/utils}/acl.h +26 -81
- data/ext/pg_query/include/{utils → postgres/utils}/aclchk_internal.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/array.h +19 -1
- data/ext/pg_query/include/{utils → postgres/utils}/backend_progress.h +2 -1
- data/ext/pg_query/include/{utils → postgres/utils}/backend_status.h +24 -3
- data/ext/pg_query/include/{utils → postgres/utils}/builtins.h +15 -6
- data/ext/pg_query/include/{utils → postgres/utils}/bytea.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/catcache.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/date.h +37 -9
- data/ext/pg_query/include/{utils → postgres/utils}/datetime.h +41 -21
- data/ext/pg_query/include/{utils → postgres/utils}/datum.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/dsa.h +5 -1
- data/ext/pg_query/include/{utils → postgres/utils}/elog.h +104 -29
- data/ext/pg_query/include/{utils → postgres/utils}/expandeddatum.h +14 -3
- data/ext/pg_query/include/{utils → postgres/utils}/expandedrecord.h +14 -4
- data/ext/pg_query/include/{utils → postgres/utils}/float.h +7 -6
- data/ext/pg_query/include/{utils → postgres/utils}/fmgroids.h +54 -1
- data/ext/pg_query/include/{utils → postgres/utils}/fmgrprotos.h +45 -3
- data/ext/pg_query/include/{utils → postgres/utils}/fmgrtab.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/guc.h +59 -86
- data/ext/pg_query/include/postgres/utils/guc_hooks.h +163 -0
- data/ext/pg_query/include/{utils → postgres/utils}/guc_tables.h +49 -3
- data/ext/pg_query/include/{utils → postgres/utils}/hsearch.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/inval.h +3 -3
- data/ext/pg_query/include/postgres/utils/logtape.h +77 -0
- data/ext/pg_query/include/{utils → postgres/utils}/lsyscache.h +5 -1
- data/ext/pg_query/include/{utils → postgres/utils}/memdebug.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/memutils.h +7 -51
- data/ext/pg_query/include/postgres/utils/memutils_internal.h +136 -0
- data/ext/pg_query/include/postgres/utils/memutils_memorychunk.h +237 -0
- data/ext/pg_query/include/{utils → postgres/utils}/numeric.h +20 -5
- data/ext/pg_query/include/{utils → postgres/utils}/palloc.h +9 -2
- data/ext/pg_query/include/{utils → postgres/utils}/partcache.h +3 -2
- data/ext/pg_query/include/{utils → postgres/utils}/pg_locale.h +22 -14
- data/ext/pg_query/include/{utils → postgres/utils}/pgstat_internal.h +37 -7
- data/ext/pg_query/include/{utils → postgres/utils}/plancache.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/portal.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/probes.h +6 -6
- data/ext/pg_query/include/postgres/utils/ps_status.h +47 -0
- data/ext/pg_query/include/{utils → postgres/utils}/queryenvironment.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/regproc.h +3 -3
- data/ext/pg_query/include/{utils → postgres/utils}/rel.h +60 -43
- data/ext/pg_query/include/{utils → postgres/utils}/relcache.h +13 -8
- data/ext/pg_query/include/{utils → postgres/utils}/reltrigger.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/resowner.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/ruleutils.h +6 -1
- data/ext/pg_query/include/{utils → postgres/utils}/sharedtuplestore.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/snapmgr.h +4 -2
- data/ext/pg_query/include/{utils → postgres/utils}/snapshot.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/sortsupport.h +2 -2
- data/ext/pg_query/include/{utils → postgres/utils}/syscache.h +4 -1
- data/ext/pg_query/include/{utils → postgres/utils}/timeout.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/timestamp.h +41 -11
- data/ext/pg_query/include/{utils → postgres/utils}/tuplesort.h +189 -35
- data/ext/pg_query/include/{utils → postgres/utils}/tuplestore.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/typcache.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/varlena.h +13 -1
- data/ext/pg_query/include/{utils → postgres/utils}/wait_event.h +9 -4
- data/ext/pg_query/include/{utils → postgres/utils}/xml.h +15 -5
- data/ext/pg_query/include/{postgres.h → postgres/varatt.h} +7 -457
- data/ext/pg_query/include/protobuf/pg_query.pb-c.h +6186 -5585
- data/ext/pg_query/include/protobuf/pg_query.pb.h +112443 -91222
- data/ext/pg_query/pg_query.c +10 -1
- data/ext/pg_query/pg_query.pb-c.c +19755 -17757
- data/ext/pg_query/pg_query_deparse.c +1 -10635
- data/ext/pg_query/pg_query_fingerprint.c +12 -8
- data/ext/pg_query/pg_query_fingerprint.h +1 -1
- data/ext/pg_query/pg_query_internal.h +1 -1
- data/ext/pg_query/pg_query_json_plpgsql.c +1 -0
- data/ext/pg_query/pg_query_normalize.c +1 -1
- data/ext/pg_query/pg_query_outfuncs_json.c +6 -0
- data/ext/pg_query/pg_query_outfuncs_protobuf.c +3 -2
- data/ext/pg_query/pg_query_parse.c +47 -5
- data/ext/pg_query/pg_query_parse_plpgsql.c +7 -5
- data/ext/pg_query/pg_query_readfuncs_protobuf.c +1 -0
- data/ext/pg_query/pg_query_ruby.c +5 -0
- data/ext/pg_query/pg_query_ruby_freebsd.sym +2 -0
- data/ext/pg_query/pg_query_scan.c +1 -1
- data/ext/pg_query/pg_query_split.c +3 -3
- data/ext/pg_query/postgres_deparse.c +11067 -0
- data/ext/pg_query/postgres_deparse.h +9 -0
- data/ext/pg_query/src_backend_catalog_namespace.c +7 -2
- data/ext/pg_query/src_backend_catalog_pg_proc.c +1 -1
- data/ext/pg_query/src_backend_commands_define.c +1 -1
- data/ext/pg_query/src_backend_nodes_bitmapset.c +11 -70
- data/ext/pg_query/src_backend_nodes_copyfuncs.c +96 -6202
- data/ext/pg_query/src_backend_nodes_equalfuncs.c +95 -4068
- data/ext/pg_query/src_backend_nodes_extensible.c +6 -29
- data/ext/pg_query/src_backend_nodes_list.c +14 -2
- data/ext/pg_query/src_backend_nodes_makefuncs.c +95 -1
- data/ext/pg_query/src_backend_nodes_nodeFuncs.c +283 -132
- data/ext/pg_query/src_backend_nodes_nodes.c +38 -0
- data/ext/pg_query/src_backend_nodes_value.c +1 -1
- data/ext/pg_query/src_backend_parser_gram.c +33208 -31806
- data/ext/pg_query/src_backend_parser_parser.c +28 -2
- data/ext/pg_query/src_backend_parser_scan.c +4318 -3329
- data/ext/pg_query/src_backend_parser_scansup.c +1 -1
- data/ext/pg_query/src_backend_storage_ipc_ipc.c +1 -1
- data/ext/pg_query/src_backend_tcop_postgres.c +66 -87
- data/ext/pg_query/src_backend_utils_activity_pgstat_database.c +1 -1
- data/ext/pg_query/src_backend_utils_adt_datum.c +5 -7
- data/ext/pg_query/src_backend_utils_adt_expandeddatum.c +1 -1
- data/ext/pg_query/src_backend_utils_adt_format_type.c +1 -1
- data/ext/pg_query/src_backend_utils_adt_numutils.c +489 -0
- data/ext/pg_query/src_backend_utils_adt_ruleutils.c +79 -5
- data/ext/pg_query/src_backend_utils_error_assert.c +4 -7
- data/ext/pg_query/src_backend_utils_error_elog.c +371 -249
- data/ext/pg_query/src_backend_utils_fmgr_fmgr.c +33 -1
- data/ext/pg_query/src_backend_utils_init_globals.c +6 -3
- data/ext/pg_query/src_backend_utils_mb_mbutils.c +21 -67
- data/ext/pg_query/src_backend_utils_misc_guc_tables.c +492 -0
- data/ext/pg_query/src_backend_utils_mmgr_alignedalloc.c +163 -0
- data/ext/pg_query/src_backend_utils_mmgr_aset.c +449 -312
- data/ext/pg_query/src_backend_utils_mmgr_generation.c +1039 -0
- data/ext/pg_query/src_backend_utils_mmgr_mcxt.c +398 -49
- data/ext/pg_query/src_backend_utils_mmgr_slab.c +1021 -0
- data/ext/pg_query/src_common_encnames.c +4 -1
- data/ext/pg_query/src_common_hashfn.c +1 -1
- data/ext/pg_query/src_common_keywords.c +1 -1
- data/ext/pg_query/src_common_kwlist_d.h +534 -510
- data/ext/pg_query/src_common_kwlookup.c +1 -1
- data/ext/pg_query/src_common_psprintf.c +1 -1
- data/ext/pg_query/src_common_stringinfo.c +4 -4
- data/ext/pg_query/src_common_wchar.c +9 -8
- data/ext/pg_query/src_pl_plpgsql_src_pl_comp.c +1 -1
- data/ext/pg_query/src_pl_plpgsql_src_pl_funcs.c +3 -1
- data/ext/pg_query/src_pl_plpgsql_src_pl_gram.c +661 -694
- data/ext/pg_query/src_pl_plpgsql_src_pl_handler.c +1 -1
- data/ext/pg_query/src_pl_plpgsql_src_pl_reserved_kwlist_d.h +1 -1
- data/ext/pg_query/src_pl_plpgsql_src_pl_scanner.c +1 -1
- data/ext/pg_query/src_pl_plpgsql_src_pl_unreserved_kwlist_d.h +48 -46
- data/ext/pg_query/src_port_pg_bitutils.c +79 -5
- data/ext/pg_query/src_port_pgstrcasecmp.c +29 -1
- data/ext/pg_query/src_port_snprintf.c +6 -10
- data/ext/pg_query/src_port_strerror.c +1 -1
- data/ext/pg_query/src_port_strlcpy.c +79 -0
- data/lib/pg_query/fingerprint.rb +2 -3
- data/lib/pg_query/node.rb +16 -11
- data/lib/pg_query/parse.rb +1 -1
- data/lib/pg_query/pg_query_pb.rb +166 -3191
- data/lib/pg_query/treewalker.rb +23 -5
- data/lib/pg_query/version.rb +1 -1
- metadata +432 -380
- data/ext/pg_query/guc-file.c +0 -0
- data/ext/pg_query/include/catalog/pg_parameter_acl.h +0 -60
- data/ext/pg_query/include/catalog/pg_parameter_acl_d.h +0 -34
- data/ext/pg_query/include/commands/variable.h +0 -38
- data/ext/pg_query/include/common/ip.h +0 -31
- data/ext/pg_query/include/getaddrinfo.h +0 -162
- data/ext/pg_query/include/kwlist_d.h +0 -1095
- data/ext/pg_query/include/parser/gram.h +0 -1101
- data/ext/pg_query/include/pg_config_os.h +0 -8
- data/ext/pg_query/include/portability/instr_time.h +0 -256
- data/ext/pg_query/include/postmaster/auxprocess.h +0 -20
- data/ext/pg_query/include/postmaster/fork_process.h +0 -17
- data/ext/pg_query/include/postmaster/pgarch.h +0 -73
- data/ext/pg_query/include/replication/logicalworker.h +0 -19
- data/ext/pg_query/include/storage/relfilenode.h +0 -99
- data/ext/pg_query/include/utils/dynahash.h +0 -20
- data/ext/pg_query/include/utils/pg_lsn.h +0 -29
- data/ext/pg_query/include/utils/pidfile.h +0 -56
- data/ext/pg_query/include/utils/ps_status.h +0 -25
- data/ext/pg_query/include/utils/rls.h +0 -50
- data/ext/pg_query/include/utils/tzparser.h +0 -39
- data/ext/pg_query/src_backend_postmaster_postmaster.c +0 -2201
- data/ext/pg_query/src_backend_storage_lmgr_s_lock.c +0 -371
- data/ext/pg_query/src_backend_utils_hash_dynahash.c +0 -1116
- data/ext/pg_query/src_backend_utils_misc_guc.c +0 -1993
- data/ext/pg_query/src_common_pg_prng.c +0 -152
- data/ext/pg_query/src_common_string.c +0 -92
- data/ext/pg_query/src_port_pgsleep.c +0 -69
- data/ext/pg_query/src_port_strnlen.c +0 -39
- /data/ext/pg_query/include/{access → postgres/access}/rmgr.h +0 -0
- /data/ext/pg_query/include/{pg_config_ext.h → postgres/pg_config_ext.h} +0 -0
- /data/ext/pg_query/include/{plerrcodes.h → postgres/plerrcodes.h} +0 -0
- /data/ext/pg_query/include/{storage → postgres/storage}/lwlocknames.h +0 -0
- /data/ext/pg_query/include/{utils → postgres/utils}/errcodes.h +0 -0
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
* definitions for nodes/print.c
|
|
5
5
|
*
|
|
6
6
|
*
|
|
7
|
-
* Portions Copyright (c) 1996-
|
|
7
|
+
* Portions Copyright (c) 1996-2023, PostgreSQL Global Development Group
|
|
8
8
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
9
9
|
*
|
|
10
10
|
* src/include/nodes/print.h
|
|
@@ -3,21 +3,19 @@
|
|
|
3
3
|
* queryjumble.h
|
|
4
4
|
* Query normalization and fingerprinting.
|
|
5
5
|
*
|
|
6
|
-
* Portions Copyright (c) 1996-
|
|
6
|
+
* Portions Copyright (c) 1996-2023, PostgreSQL Global Development Group
|
|
7
7
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
8
8
|
*
|
|
9
9
|
* IDENTIFICATION
|
|
10
|
-
* src/include/
|
|
10
|
+
* src/include/nodes/queryjumble.h
|
|
11
11
|
*
|
|
12
12
|
*-------------------------------------------------------------------------
|
|
13
13
|
*/
|
|
14
|
-
#ifndef
|
|
15
|
-
#define
|
|
14
|
+
#ifndef QUERYJUMBLE_H
|
|
15
|
+
#define QUERYJUMBLE_H
|
|
16
16
|
|
|
17
17
|
#include "nodes/parsenodes.h"
|
|
18
18
|
|
|
19
|
-
#define JUMBLE_SIZE 1024 /* query serialization buffer size */
|
|
20
|
-
|
|
21
19
|
/*
|
|
22
20
|
* Struct for tracking locations/lengths of constants during normalization
|
|
23
21
|
*/
|
|
@@ -66,7 +64,7 @@ extern PGDLLIMPORT int compute_query_id;
|
|
|
66
64
|
|
|
67
65
|
|
|
68
66
|
extern const char *CleanQuerytext(const char *query, int *location, int *len);
|
|
69
|
-
extern JumbleState *JumbleQuery(Query *query
|
|
67
|
+
extern JumbleState *JumbleQuery(Query *query);
|
|
70
68
|
extern void EnableQueryId(void);
|
|
71
69
|
|
|
72
70
|
extern PGDLLIMPORT bool query_id_enabled;
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
/*-------------------------------------------------------------------------
|
|
2
|
+
*
|
|
3
|
+
* replnodes.h
|
|
4
|
+
* definitions for replication grammar parse nodes
|
|
5
|
+
*
|
|
6
|
+
*
|
|
7
|
+
* Portions Copyright (c) 1996-2023, PostgreSQL Global Development Group
|
|
8
|
+
* Portions Copyright (c) 1994, Regents of the University of California
|
|
9
|
+
*
|
|
10
|
+
* src/include/nodes/replnodes.h
|
|
11
|
+
*
|
|
12
|
+
*-------------------------------------------------------------------------
|
|
13
|
+
*/
|
|
14
|
+
#ifndef REPLNODES_H
|
|
15
|
+
#define REPLNODES_H
|
|
16
|
+
|
|
17
|
+
#include "access/xlogdefs.h"
|
|
18
|
+
#include "nodes/pg_list.h"
|
|
19
|
+
|
|
20
|
+
typedef enum ReplicationKind
|
|
21
|
+
{
|
|
22
|
+
REPLICATION_KIND_PHYSICAL,
|
|
23
|
+
REPLICATION_KIND_LOGICAL
|
|
24
|
+
} ReplicationKind;
|
|
25
|
+
|
|
26
|
+
|
|
27
|
+
/* ----------------------
|
|
28
|
+
* IDENTIFY_SYSTEM command
|
|
29
|
+
* ----------------------
|
|
30
|
+
*/
|
|
31
|
+
typedef struct IdentifySystemCmd
|
|
32
|
+
{
|
|
33
|
+
NodeTag type;
|
|
34
|
+
} IdentifySystemCmd;
|
|
35
|
+
|
|
36
|
+
|
|
37
|
+
/* ----------------------
|
|
38
|
+
* BASE_BACKUP command
|
|
39
|
+
* ----------------------
|
|
40
|
+
*/
|
|
41
|
+
typedef struct BaseBackupCmd
|
|
42
|
+
{
|
|
43
|
+
NodeTag type;
|
|
44
|
+
List *options;
|
|
45
|
+
} BaseBackupCmd;
|
|
46
|
+
|
|
47
|
+
|
|
48
|
+
/* ----------------------
|
|
49
|
+
* CREATE_REPLICATION_SLOT command
|
|
50
|
+
* ----------------------
|
|
51
|
+
*/
|
|
52
|
+
typedef struct CreateReplicationSlotCmd
|
|
53
|
+
{
|
|
54
|
+
NodeTag type;
|
|
55
|
+
char *slotname;
|
|
56
|
+
ReplicationKind kind;
|
|
57
|
+
char *plugin;
|
|
58
|
+
bool temporary;
|
|
59
|
+
List *options;
|
|
60
|
+
} CreateReplicationSlotCmd;
|
|
61
|
+
|
|
62
|
+
|
|
63
|
+
/* ----------------------
|
|
64
|
+
* DROP_REPLICATION_SLOT command
|
|
65
|
+
* ----------------------
|
|
66
|
+
*/
|
|
67
|
+
typedef struct DropReplicationSlotCmd
|
|
68
|
+
{
|
|
69
|
+
NodeTag type;
|
|
70
|
+
char *slotname;
|
|
71
|
+
bool wait;
|
|
72
|
+
} DropReplicationSlotCmd;
|
|
73
|
+
|
|
74
|
+
|
|
75
|
+
/* ----------------------
|
|
76
|
+
* START_REPLICATION command
|
|
77
|
+
* ----------------------
|
|
78
|
+
*/
|
|
79
|
+
typedef struct StartReplicationCmd
|
|
80
|
+
{
|
|
81
|
+
NodeTag type;
|
|
82
|
+
ReplicationKind kind;
|
|
83
|
+
char *slotname;
|
|
84
|
+
TimeLineID timeline;
|
|
85
|
+
XLogRecPtr startpoint;
|
|
86
|
+
List *options;
|
|
87
|
+
} StartReplicationCmd;
|
|
88
|
+
|
|
89
|
+
|
|
90
|
+
/* ----------------------
|
|
91
|
+
* READ_REPLICATION_SLOT command
|
|
92
|
+
* ----------------------
|
|
93
|
+
*/
|
|
94
|
+
typedef struct ReadReplicationSlotCmd
|
|
95
|
+
{
|
|
96
|
+
NodeTag type;
|
|
97
|
+
char *slotname;
|
|
98
|
+
} ReadReplicationSlotCmd;
|
|
99
|
+
|
|
100
|
+
|
|
101
|
+
/* ----------------------
|
|
102
|
+
* TIMELINE_HISTORY command
|
|
103
|
+
* ----------------------
|
|
104
|
+
*/
|
|
105
|
+
typedef struct TimeLineHistoryCmd
|
|
106
|
+
{
|
|
107
|
+
NodeTag type;
|
|
108
|
+
TimeLineID timeline;
|
|
109
|
+
} TimeLineHistoryCmd;
|
|
110
|
+
|
|
111
|
+
#endif /* REPLNODES_H */
|
|
@@ -0,0 +1,346 @@
|
|
|
1
|
+
/*-------------------------------------------------------------------------
|
|
2
|
+
*
|
|
3
|
+
* supportnodes.h
|
|
4
|
+
* Definitions for planner support functions.
|
|
5
|
+
*
|
|
6
|
+
* This file defines the API for "planner support functions", which
|
|
7
|
+
* are SQL functions (normally written in C) that can be attached to
|
|
8
|
+
* another "target" function to give the system additional knowledge
|
|
9
|
+
* about the target function. All the current capabilities have to do
|
|
10
|
+
* with planning queries that use the target function, though it is
|
|
11
|
+
* possible that future extensions will add functionality to be invoked
|
|
12
|
+
* by the parser or executor.
|
|
13
|
+
*
|
|
14
|
+
* A support function must have the SQL signature
|
|
15
|
+
* supportfn(internal) returns internal
|
|
16
|
+
* The argument is a pointer to one of the Node types defined in this file.
|
|
17
|
+
* The result is usually also a Node pointer, though its type depends on
|
|
18
|
+
* which capability is being invoked. In all cases, a NULL pointer result
|
|
19
|
+
* (that's PG_RETURN_POINTER(NULL), not PG_RETURN_NULL()) indicates that
|
|
20
|
+
* the support function cannot do anything useful for the given request.
|
|
21
|
+
* Support functions must return a NULL pointer, not fail, if they do not
|
|
22
|
+
* recognize the request node type or cannot handle the given case; this
|
|
23
|
+
* allows for future extensions of the set of request cases.
|
|
24
|
+
*
|
|
25
|
+
*
|
|
26
|
+
* Portions Copyright (c) 1996-2023, PostgreSQL Global Development Group
|
|
27
|
+
* Portions Copyright (c) 1994, Regents of the University of California
|
|
28
|
+
*
|
|
29
|
+
* src/include/nodes/supportnodes.h
|
|
30
|
+
*
|
|
31
|
+
*-------------------------------------------------------------------------
|
|
32
|
+
*/
|
|
33
|
+
#ifndef SUPPORTNODES_H
|
|
34
|
+
#define SUPPORTNODES_H
|
|
35
|
+
|
|
36
|
+
#include "nodes/plannodes.h"
|
|
37
|
+
|
|
38
|
+
struct PlannerInfo; /* avoid including pathnodes.h here */
|
|
39
|
+
struct IndexOptInfo;
|
|
40
|
+
struct SpecialJoinInfo;
|
|
41
|
+
struct WindowClause;
|
|
42
|
+
|
|
43
|
+
/*
|
|
44
|
+
* The Simplify request allows the support function to perform plan-time
|
|
45
|
+
* simplification of a call to its target function. For example, a varchar
|
|
46
|
+
* length coercion that does not decrease the allowed length of its argument
|
|
47
|
+
* could be replaced by a RelabelType node, or "x + 0" could be replaced by
|
|
48
|
+
* "x". This is invoked during the planner's constant-folding pass, so the
|
|
49
|
+
* function's arguments can be presumed already simplified.
|
|
50
|
+
*
|
|
51
|
+
* The planner's PlannerInfo "root" is typically not needed, but can be
|
|
52
|
+
* consulted if it's necessary to obtain info about Vars present in
|
|
53
|
+
* the given node tree. Beware that root could be NULL in some usages.
|
|
54
|
+
*
|
|
55
|
+
* "fcall" will be a FuncExpr invoking the support function's target
|
|
56
|
+
* function. (This is true even if the original parsetree node was an
|
|
57
|
+
* operator call; a FuncExpr is synthesized for this purpose.)
|
|
58
|
+
*
|
|
59
|
+
* The result should be a semantically-equivalent transformed node tree,
|
|
60
|
+
* or NULL if no simplification could be performed. Do *not* return or
|
|
61
|
+
* modify *fcall, as it isn't really a separately allocated Node. But
|
|
62
|
+
* it's okay to use fcall->args, or parts of it, in the result tree.
|
|
63
|
+
*/
|
|
64
|
+
typedef struct SupportRequestSimplify
|
|
65
|
+
{
|
|
66
|
+
NodeTag type;
|
|
67
|
+
|
|
68
|
+
struct PlannerInfo *root; /* Planner's infrastructure */
|
|
69
|
+
FuncExpr *fcall; /* Function call to be simplified */
|
|
70
|
+
} SupportRequestSimplify;
|
|
71
|
+
|
|
72
|
+
/*
|
|
73
|
+
* The Selectivity request allows the support function to provide a
|
|
74
|
+
* selectivity estimate for a function appearing at top level of a WHERE
|
|
75
|
+
* clause (so it applies only to functions returning boolean).
|
|
76
|
+
*
|
|
77
|
+
* The input arguments are the same as are supplied to operator restriction
|
|
78
|
+
* and join estimators, except that we unify those two APIs into just one
|
|
79
|
+
* request type. See clause_selectivity() for the details.
|
|
80
|
+
*
|
|
81
|
+
* If an estimate can be made, store it into the "selectivity" field and
|
|
82
|
+
* return the address of the SupportRequestSelectivity node; the estimate
|
|
83
|
+
* must be between 0 and 1 inclusive. Return NULL if no estimate can be
|
|
84
|
+
* made (in which case the planner will fall back to a default estimate,
|
|
85
|
+
* traditionally 1/3).
|
|
86
|
+
*
|
|
87
|
+
* If the target function is being used as the implementation of an operator,
|
|
88
|
+
* the support function will not be used for this purpose; the operator's
|
|
89
|
+
* restriction or join estimator is consulted instead.
|
|
90
|
+
*/
|
|
91
|
+
typedef struct SupportRequestSelectivity
|
|
92
|
+
{
|
|
93
|
+
NodeTag type;
|
|
94
|
+
|
|
95
|
+
/* Input fields: */
|
|
96
|
+
struct PlannerInfo *root; /* Planner's infrastructure */
|
|
97
|
+
Oid funcid; /* function we are inquiring about */
|
|
98
|
+
List *args; /* pre-simplified arguments to function */
|
|
99
|
+
Oid inputcollid; /* function's input collation */
|
|
100
|
+
bool is_join; /* is this a join or restriction case? */
|
|
101
|
+
int varRelid; /* if restriction, RTI of target relation */
|
|
102
|
+
JoinType jointype; /* if join, outer join type */
|
|
103
|
+
struct SpecialJoinInfo *sjinfo; /* if outer join, info about join */
|
|
104
|
+
|
|
105
|
+
/* Output fields: */
|
|
106
|
+
Selectivity selectivity; /* returned selectivity estimate */
|
|
107
|
+
} SupportRequestSelectivity;
|
|
108
|
+
|
|
109
|
+
/*
|
|
110
|
+
* The Cost request allows the support function to provide an execution
|
|
111
|
+
* cost estimate for its target function. The cost estimate can include
|
|
112
|
+
* both a one-time (query startup) component and a per-execution component.
|
|
113
|
+
* The estimate should *not* include the costs of evaluating the target
|
|
114
|
+
* function's arguments, only the target function itself.
|
|
115
|
+
*
|
|
116
|
+
* The "node" argument is normally the parse node that is invoking the
|
|
117
|
+
* target function. This is a FuncExpr in the simplest case, but it could
|
|
118
|
+
* also be an OpExpr, DistinctExpr, NullIfExpr, or WindowFunc, or possibly
|
|
119
|
+
* other cases in future. NULL is passed if the function cannot presume
|
|
120
|
+
* its arguments to be equivalent to what the calling node presents as
|
|
121
|
+
* arguments; that happens for, e.g., aggregate support functions and
|
|
122
|
+
* per-column comparison operators used by RowExprs.
|
|
123
|
+
*
|
|
124
|
+
* If an estimate can be made, store it into the cost fields and return the
|
|
125
|
+
* address of the SupportRequestCost node. Return NULL if no estimate can be
|
|
126
|
+
* made, in which case the planner will rely on the target function's procost
|
|
127
|
+
* field. (Note: while procost is automatically scaled by cpu_operator_cost,
|
|
128
|
+
* this is not the case for the outputs of the Cost request; the support
|
|
129
|
+
* function must scale its results appropriately on its own.)
|
|
130
|
+
*/
|
|
131
|
+
typedef struct SupportRequestCost
|
|
132
|
+
{
|
|
133
|
+
NodeTag type;
|
|
134
|
+
|
|
135
|
+
/* Input fields: */
|
|
136
|
+
struct PlannerInfo *root; /* Planner's infrastructure (could be NULL) */
|
|
137
|
+
Oid funcid; /* function we are inquiring about */
|
|
138
|
+
Node *node; /* parse node invoking function, or NULL */
|
|
139
|
+
|
|
140
|
+
/* Output fields: */
|
|
141
|
+
Cost startup; /* one-time cost */
|
|
142
|
+
Cost per_tuple; /* per-evaluation cost */
|
|
143
|
+
} SupportRequestCost;
|
|
144
|
+
|
|
145
|
+
/*
|
|
146
|
+
* The Rows request allows the support function to provide an output rowcount
|
|
147
|
+
* estimate for its target function (so it applies only to set-returning
|
|
148
|
+
* functions).
|
|
149
|
+
*
|
|
150
|
+
* The "node" argument is the parse node that is invoking the target function;
|
|
151
|
+
* currently this will always be a FuncExpr or OpExpr.
|
|
152
|
+
*
|
|
153
|
+
* If an estimate can be made, store it into the rows field and return the
|
|
154
|
+
* address of the SupportRequestRows node. Return NULL if no estimate can be
|
|
155
|
+
* made, in which case the planner will rely on the target function's prorows
|
|
156
|
+
* field.
|
|
157
|
+
*/
|
|
158
|
+
typedef struct SupportRequestRows
|
|
159
|
+
{
|
|
160
|
+
NodeTag type;
|
|
161
|
+
|
|
162
|
+
/* Input fields: */
|
|
163
|
+
struct PlannerInfo *root; /* Planner's infrastructure (could be NULL) */
|
|
164
|
+
Oid funcid; /* function we are inquiring about */
|
|
165
|
+
Node *node; /* parse node invoking function */
|
|
166
|
+
|
|
167
|
+
/* Output fields: */
|
|
168
|
+
double rows; /* number of rows expected to be returned */
|
|
169
|
+
} SupportRequestRows;
|
|
170
|
+
|
|
171
|
+
/*
|
|
172
|
+
* The IndexCondition request allows the support function to generate
|
|
173
|
+
* a directly-indexable condition based on a target function call that is
|
|
174
|
+
* not itself indexable. The target function call must appear at the top
|
|
175
|
+
* level of WHERE or JOIN/ON, so this applies only to functions returning
|
|
176
|
+
* boolean.
|
|
177
|
+
*
|
|
178
|
+
* The "node" argument is the parse node that is invoking the target function;
|
|
179
|
+
* currently this will always be a FuncExpr or OpExpr. The call is made
|
|
180
|
+
* only if at least one function argument matches an index column's variable
|
|
181
|
+
* or expression. "indexarg" identifies the matching argument (it's the
|
|
182
|
+
* argument's zero-based index in the node's args list).
|
|
183
|
+
*
|
|
184
|
+
* If the transformation is possible, return a List of directly-indexable
|
|
185
|
+
* condition expressions, else return NULL. (A List is used because it's
|
|
186
|
+
* sometimes useful to generate more than one indexable condition, such as
|
|
187
|
+
* when a LIKE with constant prefix gives rise to both >= and < conditions.)
|
|
188
|
+
*
|
|
189
|
+
* "Directly indexable" means that the condition must be directly executable
|
|
190
|
+
* by the index machinery. Typically this means that it is a binary OpExpr
|
|
191
|
+
* with the index column value on the left, a pseudo-constant on the right,
|
|
192
|
+
* and an operator that is in the index column's operator family. Other
|
|
193
|
+
* possibilities include RowCompareExpr, ScalarArrayOpExpr, and NullTest,
|
|
194
|
+
* depending on the index type; but those seem less likely to be useful for
|
|
195
|
+
* derived index conditions. "Pseudo-constant" means that the right-hand
|
|
196
|
+
* expression must not contain any volatile functions, nor any Vars of the
|
|
197
|
+
* table the index is for; use is_pseudo_constant_for_index() to check this.
|
|
198
|
+
* (Note: if the passed "node" is an OpExpr, the core planner already verified
|
|
199
|
+
* that the non-indexkey operand is pseudo-constant; but when the "node"
|
|
200
|
+
* is a FuncExpr, it does not check, since it doesn't know which of the
|
|
201
|
+
* function's arguments you might need to use in an index comparison value.)
|
|
202
|
+
*
|
|
203
|
+
* In many cases, an index condition can be generated but it is weaker than
|
|
204
|
+
* the function condition itself; for example, a LIKE with a constant prefix
|
|
205
|
+
* can produce an index range check based on the prefix, but we still need
|
|
206
|
+
* to execute the LIKE operator to verify the rest of the pattern. We say
|
|
207
|
+
* that such an index condition is "lossy". When returning an index condition,
|
|
208
|
+
* you should set the "lossy" request field to true if the condition is lossy,
|
|
209
|
+
* or false if it is an exact equivalent of the function's result. The core
|
|
210
|
+
* code will initialize that field to true, which is the common case.
|
|
211
|
+
*
|
|
212
|
+
* It is important to verify that the index operator family is the correct
|
|
213
|
+
* one for the condition you want to generate. Core support functions tend
|
|
214
|
+
* to use the known OID of a built-in opfamily for this, but extensions need
|
|
215
|
+
* to work harder, since their OIDs aren't fixed. A possibly workable
|
|
216
|
+
* answer for an index on an extension datatype is to verify the index AM's
|
|
217
|
+
* OID instead, and then assume that there's only one relevant opclass for
|
|
218
|
+
* your datatype so the opfamily must be the right one. Generating OpExpr
|
|
219
|
+
* nodes may also require knowing extension datatype OIDs (often you can
|
|
220
|
+
* find these out by applying exprType() to a function argument) and
|
|
221
|
+
* operator OIDs (which you can look up using get_opfamily_member).
|
|
222
|
+
*/
|
|
223
|
+
typedef struct SupportRequestIndexCondition
|
|
224
|
+
{
|
|
225
|
+
NodeTag type;
|
|
226
|
+
|
|
227
|
+
/* Input fields: */
|
|
228
|
+
struct PlannerInfo *root; /* Planner's infrastructure */
|
|
229
|
+
Oid funcid; /* function we are inquiring about */
|
|
230
|
+
Node *node; /* parse node invoking function */
|
|
231
|
+
int indexarg; /* index of function arg matching indexcol */
|
|
232
|
+
struct IndexOptInfo *index; /* planner's info about target index */
|
|
233
|
+
int indexcol; /* index of target index column (0-based) */
|
|
234
|
+
Oid opfamily; /* index column's operator family */
|
|
235
|
+
Oid indexcollation; /* index column's collation */
|
|
236
|
+
|
|
237
|
+
/* Output fields: */
|
|
238
|
+
bool lossy; /* set to false if index condition is an exact
|
|
239
|
+
* equivalent of the function call */
|
|
240
|
+
} SupportRequestIndexCondition;
|
|
241
|
+
|
|
242
|
+
/* ----------
|
|
243
|
+
* To support more efficient query execution of any monotonically increasing
|
|
244
|
+
* and/or monotonically decreasing window functions, we support calling the
|
|
245
|
+
* window function's prosupport function passing along this struct whenever
|
|
246
|
+
* the planner sees an OpExpr qual directly reference a window function in a
|
|
247
|
+
* subquery. When the planner encounters this, we populate this struct and
|
|
248
|
+
* pass it along to the window function's prosupport function so that it can
|
|
249
|
+
* evaluate if the given WindowFunc is;
|
|
250
|
+
*
|
|
251
|
+
* a) monotonically increasing, or
|
|
252
|
+
* b) monotonically decreasing, or
|
|
253
|
+
* c) both monotonically increasing and decreasing, or
|
|
254
|
+
* d) none of the above.
|
|
255
|
+
*
|
|
256
|
+
* A function that is monotonically increasing can never return a value that
|
|
257
|
+
* is lower than a value returned in a "previous call". A monotonically
|
|
258
|
+
* decreasing function can never return a value higher than a value returned
|
|
259
|
+
* in a previous call. A function that is both must return the same value
|
|
260
|
+
* each time.
|
|
261
|
+
*
|
|
262
|
+
* We define "previous call" to mean a previous call to the same WindowFunc
|
|
263
|
+
* struct in the same window partition.
|
|
264
|
+
*
|
|
265
|
+
* row_number() is an example of a monotonically increasing function. The
|
|
266
|
+
* return value will be reset back to 1 in each new partition. An example of
|
|
267
|
+
* a monotonically increasing and decreasing function is COUNT(*) OVER ().
|
|
268
|
+
* Since there is no ORDER BY clause in this example, all rows in the
|
|
269
|
+
* partition are peers and all rows within the partition will be within the
|
|
270
|
+
* frame bound. Likewise for COUNT(*) OVER(ORDER BY a ROWS BETWEEN UNBOUNDED
|
|
271
|
+
* PRECEDING AND UNBOUNDED FOLLOWING).
|
|
272
|
+
*
|
|
273
|
+
* COUNT(*) OVER (ORDER BY a ROWS BETWEEN CURRENT ROW AND UNBOUNDED FOLLOWING)
|
|
274
|
+
* is an example of a monotonically decreasing function.
|
|
275
|
+
*
|
|
276
|
+
* Implementations must only concern themselves with the given WindowFunc
|
|
277
|
+
* being monotonic in a single partition.
|
|
278
|
+
*
|
|
279
|
+
* Inputs:
|
|
280
|
+
* 'window_func' is the pointer to the window function being called.
|
|
281
|
+
*
|
|
282
|
+
* 'window_clause' pointer to the WindowClause data. Support functions can
|
|
283
|
+
* use this to check frame bounds, etc.
|
|
284
|
+
*
|
|
285
|
+
* Outputs:
|
|
286
|
+
* 'monotonic' the resulting MonotonicFunction value for the given input
|
|
287
|
+
* window function and window clause.
|
|
288
|
+
* ----------
|
|
289
|
+
*/
|
|
290
|
+
typedef struct SupportRequestWFuncMonotonic
|
|
291
|
+
{
|
|
292
|
+
NodeTag type;
|
|
293
|
+
|
|
294
|
+
/* Input fields: */
|
|
295
|
+
WindowFunc *window_func; /* Pointer to the window function data */
|
|
296
|
+
struct WindowClause *window_clause; /* Pointer to the window clause data */
|
|
297
|
+
|
|
298
|
+
/* Output fields: */
|
|
299
|
+
MonotonicFunction monotonic;
|
|
300
|
+
} SupportRequestWFuncMonotonic;
|
|
301
|
+
|
|
302
|
+
/*
|
|
303
|
+
* Some WindowFunc behavior might not be affected by certain variations in
|
|
304
|
+
* the WindowClause's frameOptions. For example, row_number() is coded in
|
|
305
|
+
* such a way that the frame options don't change the returned row number.
|
|
306
|
+
* nodeWindowAgg.c will have less work to do if the ROWS option is used
|
|
307
|
+
* instead of the RANGE option as no check needs to be done for peer rows.
|
|
308
|
+
* Since RANGE is included in the default frame options, window functions
|
|
309
|
+
* such as row_number() might want to change that to ROW.
|
|
310
|
+
*
|
|
311
|
+
* Here we allow a WindowFunc's support function to determine which, if
|
|
312
|
+
* anything, can be changed about the WindowClause which the WindowFunc
|
|
313
|
+
* belongs to. Currently only the frameOptions can be modified. However,
|
|
314
|
+
* we may want to allow more optimizations in the future.
|
|
315
|
+
*
|
|
316
|
+
* The support function is responsible for ensuring the optimized version of
|
|
317
|
+
* the frameOptions doesn't affect the result of the window function. The
|
|
318
|
+
* planner is responsible for only changing the frame options when all
|
|
319
|
+
* WindowFuncs using this particular WindowClause agree on what the optimized
|
|
320
|
+
* version of the frameOptions are. If a particular WindowFunc being used
|
|
321
|
+
* does not have a support function then the planner will not make any changes
|
|
322
|
+
* to the WindowClause's frameOptions.
|
|
323
|
+
*
|
|
324
|
+
* 'window_func' and 'window_clause' are set by the planner before calling the
|
|
325
|
+
* support function so that the support function has these fields available.
|
|
326
|
+
* These may be required in order to determine which optimizations are
|
|
327
|
+
* possible.
|
|
328
|
+
*
|
|
329
|
+
* 'frameOptions' is set by the planner to WindowClause.frameOptions. The
|
|
330
|
+
* support function must only adjust this if optimizations are possible for
|
|
331
|
+
* the given WindowFunc.
|
|
332
|
+
*/
|
|
333
|
+
typedef struct SupportRequestOptimizeWindowClause
|
|
334
|
+
{
|
|
335
|
+
NodeTag type;
|
|
336
|
+
|
|
337
|
+
/* Input fields: */
|
|
338
|
+
WindowFunc *window_func; /* Pointer to the window function data */
|
|
339
|
+
struct WindowClause *window_clause; /* Pointer to the window clause data */
|
|
340
|
+
|
|
341
|
+
/* Input/Output fields: */
|
|
342
|
+
int frameOptions; /* New frameOptions, or left untouched if no
|
|
343
|
+
* optimizations are possible. */
|
|
344
|
+
} SupportRequestOptimizeWindowClause;
|
|
345
|
+
|
|
346
|
+
#endif /* SUPPORTNODES_H */
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
* interface for value nodes
|
|
5
5
|
*
|
|
6
6
|
*
|
|
7
|
-
* Copyright (c) 2003-
|
|
7
|
+
* Copyright (c) 2003-2023, PostgreSQL Global Development Group
|
|
8
8
|
*
|
|
9
9
|
* src/include/nodes/value.h
|
|
10
10
|
*
|
|
@@ -27,6 +27,8 @@
|
|
|
27
27
|
|
|
28
28
|
typedef struct Integer
|
|
29
29
|
{
|
|
30
|
+
pg_node_attr(special_read_write)
|
|
31
|
+
|
|
30
32
|
NodeTag type;
|
|
31
33
|
int ival;
|
|
32
34
|
} Integer;
|
|
@@ -44,24 +46,32 @@ typedef struct Integer
|
|
|
44
46
|
*/
|
|
45
47
|
typedef struct Float
|
|
46
48
|
{
|
|
49
|
+
pg_node_attr(special_read_write)
|
|
50
|
+
|
|
47
51
|
NodeTag type;
|
|
48
52
|
char *fval;
|
|
49
53
|
} Float;
|
|
50
54
|
|
|
51
55
|
typedef struct Boolean
|
|
52
56
|
{
|
|
57
|
+
pg_node_attr(special_read_write)
|
|
58
|
+
|
|
53
59
|
NodeTag type;
|
|
54
60
|
bool boolval;
|
|
55
61
|
} Boolean;
|
|
56
62
|
|
|
57
63
|
typedef struct String
|
|
58
64
|
{
|
|
65
|
+
pg_node_attr(special_read_write)
|
|
66
|
+
|
|
59
67
|
NodeTag type;
|
|
60
68
|
char *sval;
|
|
61
69
|
} String;
|
|
62
70
|
|
|
63
71
|
typedef struct BitString
|
|
64
72
|
{
|
|
73
|
+
pg_node_attr(special_read_write)
|
|
74
|
+
|
|
65
75
|
NodeTag type;
|
|
66
76
|
char *bsval;
|
|
67
77
|
} BitString;
|
|
@@ -73,7 +83,7 @@ typedef struct BitString
|
|
|
73
83
|
|
|
74
84
|
extern Integer *makeInteger(int i);
|
|
75
85
|
extern Float *makeFloat(char *numericStr);
|
|
76
|
-
extern Boolean *makeBoolean(bool
|
|
86
|
+
extern Boolean *makeBoolean(bool val);
|
|
77
87
|
extern String *makeString(char *str);
|
|
78
88
|
extern BitString *makeBitString(char *str);
|
|
79
89
|
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
* prototypes for costsize.c and clausesel.c.
|
|
5
5
|
*
|
|
6
6
|
*
|
|
7
|
-
* Portions Copyright (c) 1996-
|
|
7
|
+
* Portions Copyright (c) 1996-2023, PostgreSQL Global Development Group
|
|
8
8
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
9
9
|
*
|
|
10
10
|
* src/include/optimizer/cost.h
|
|
@@ -68,6 +68,7 @@ extern PGDLLIMPORT bool enable_partitionwise_aggregate;
|
|
|
68
68
|
extern PGDLLIMPORT bool enable_parallel_append;
|
|
69
69
|
extern PGDLLIMPORT bool enable_parallel_hash;
|
|
70
70
|
extern PGDLLIMPORT bool enable_partition_pruning;
|
|
71
|
+
extern PGDLLIMPORT bool enable_presorted_aggregate;
|
|
71
72
|
extern PGDLLIMPORT bool enable_async_append;
|
|
72
73
|
extern PGDLLIMPORT int constraint_exclusion;
|
|
73
74
|
|
|
@@ -91,7 +92,8 @@ extern void cost_tidrangescan(Path *path, PlannerInfo *root,
|
|
|
91
92
|
RelOptInfo *baserel, List *tidrangequals,
|
|
92
93
|
ParamPathInfo *param_info);
|
|
93
94
|
extern void cost_subqueryscan(SubqueryScanPath *path, PlannerInfo *root,
|
|
94
|
-
RelOptInfo *baserel, ParamPathInfo *param_info
|
|
95
|
+
RelOptInfo *baserel, ParamPathInfo *param_info,
|
|
96
|
+
bool trivial_pathtarget);
|
|
95
97
|
extern void cost_functionscan(Path *path, PlannerInfo *root,
|
|
96
98
|
RelOptInfo *baserel, ParamPathInfo *param_info);
|
|
97
99
|
extern void cost_valuesscan(Path *path, PlannerInfo *root,
|
|
@@ -114,7 +116,7 @@ extern void cost_incremental_sort(Path *path,
|
|
|
114
116
|
Cost input_startup_cost, Cost input_total_cost,
|
|
115
117
|
double input_tuples, int width, Cost comparison_cost, int sort_mem,
|
|
116
118
|
double limit_tuples);
|
|
117
|
-
extern void cost_append(AppendPath *
|
|
119
|
+
extern void cost_append(AppendPath *apath);
|
|
118
120
|
extern void cost_merge_append(Path *path, PlannerInfo *root,
|
|
119
121
|
List *pathkeys, int n_streams,
|
|
120
122
|
Cost input_startup_cost, Cost input_total_cost,
|
|
@@ -166,7 +168,7 @@ extern void final_cost_hashjoin(PlannerInfo *root, HashPath *path,
|
|
|
166
168
|
JoinCostWorkspace *workspace,
|
|
167
169
|
JoinPathExtraData *extra);
|
|
168
170
|
extern void cost_gather(GatherPath *path, PlannerInfo *root,
|
|
169
|
-
RelOptInfo *
|
|
171
|
+
RelOptInfo *rel, ParamPathInfo *param_info, double *rows);
|
|
170
172
|
extern void cost_gather_merge(GatherMergePath *path, PlannerInfo *root,
|
|
171
173
|
RelOptInfo *rel, ParamPathInfo *param_info,
|
|
172
174
|
Cost input_startup_cost, Cost input_total_cost,
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
* geqo.h
|
|
4
4
|
* prototypes for various files in optimizer/geqo
|
|
5
5
|
*
|
|
6
|
-
* Portions Copyright (c) 1996-
|
|
6
|
+
* Portions Copyright (c) 1996-2023, PostgreSQL Global Development Group
|
|
7
7
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
8
8
|
*
|
|
9
9
|
* src/include/optimizer/geqo.h
|
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
* geqo_gene.h
|
|
4
4
|
* genome representation in optimizer/geqo
|
|
5
5
|
*
|
|
6
|
-
* Portions Copyright (c) 1996-
|
|
6
|
+
* Portions Copyright (c) 1996-2023, PostgreSQL Global Development Group
|
|
7
7
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
8
8
|
*
|
|
9
9
|
* src/include/optimizer/geqo_gene.h
|
|
@@ -12,7 +12,7 @@
|
|
|
12
12
|
* example. For the most part, however, code outside the core planner
|
|
13
13
|
* should not need to include any optimizer/ header except this one.
|
|
14
14
|
*
|
|
15
|
-
* Portions Copyright (c) 1996-
|
|
15
|
+
* Portions Copyright (c) 1996-2023, PostgreSQL Global Development Group
|
|
16
16
|
* Portions Copyright (c) 1994, Regents of the University of California
|
|
17
17
|
*
|
|
18
18
|
* src/include/optimizer/optimizer.h
|
|
@@ -99,16 +99,16 @@ extern bool is_pseudo_constant_for_index(PlannerInfo *root, Node *expr,
|
|
|
99
99
|
|
|
100
100
|
/* in plan/planner.c: */
|
|
101
101
|
|
|
102
|
-
/* possible values for
|
|
102
|
+
/* possible values for debug_parallel_query */
|
|
103
103
|
typedef enum
|
|
104
104
|
{
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
}
|
|
105
|
+
DEBUG_PARALLEL_OFF,
|
|
106
|
+
DEBUG_PARALLEL_ON,
|
|
107
|
+
DEBUG_PARALLEL_REGRESS
|
|
108
|
+
} DebugParallelMode;
|
|
109
109
|
|
|
110
110
|
/* GUC parameters */
|
|
111
|
-
extern PGDLLIMPORT int
|
|
111
|
+
extern PGDLLIMPORT int debug_parallel_query;
|
|
112
112
|
extern PGDLLIMPORT bool parallel_leader_participation;
|
|
113
113
|
|
|
114
114
|
extern struct PlannedStmt *planner(Query *parse, const char *query_string,
|
|
@@ -197,6 +197,6 @@ extern bool contain_var_clause(Node *node);
|
|
|
197
197
|
extern bool contain_vars_of_level(Node *node, int levelsup);
|
|
198
198
|
extern int locate_var_of_level(Node *node, int levelsup);
|
|
199
199
|
extern List *pull_var_clause(Node *node, int flags);
|
|
200
|
-
extern Node *flatten_join_alias_vars(Query *query, Node *node);
|
|
200
|
+
extern Node *flatten_join_alias_vars(PlannerInfo *root, Query *query, Node *node);
|
|
201
201
|
|
|
202
202
|
#endif /* OPTIMIZER_H */
|