pg_query 2.0.3 → 5.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/CHANGELOG.md +165 -0
- data/README.md +67 -29
- data/Rakefile +8 -23
- data/ext/pg_query/extconf.rb +21 -3
- data/ext/pg_query/include/pg_query.h +29 -4
- data/ext/pg_query/include/pg_query_enum_defs.c +551 -272
- data/ext/pg_query/include/pg_query_fingerprint_conds.c +563 -470
- data/ext/pg_query/include/pg_query_fingerprint_defs.c +5403 -3945
- data/ext/pg_query/include/pg_query_outfuncs_conds.c +402 -330
- data/ext/pg_query/include/pg_query_outfuncs_defs.c +1319 -1059
- data/ext/pg_query/include/pg_query_readfuncs_conds.c +141 -118
- data/ext/pg_query/include/pg_query_readfuncs_defs.c +1685 -1379
- data/ext/pg_query/include/{access → postgres/access}/amapi.h +47 -1
- data/ext/pg_query/include/{access → postgres/access}/attmap.h +5 -3
- data/ext/pg_query/include/{access → postgres/access}/attnum.h +2 -2
- data/ext/pg_query/include/{access → postgres/access}/clog.h +4 -2
- data/ext/pg_query/include/{access → postgres/access}/commit_ts.h +6 -9
- data/ext/pg_query/include/{access → postgres/access}/detoast.h +1 -11
- data/ext/pg_query/include/{access → postgres/access}/genam.h +21 -16
- data/ext/pg_query/include/{access → postgres/access}/gin.h +17 -4
- data/ext/pg_query/include/{access → postgres/access}/htup.h +1 -1
- data/ext/pg_query/include/{access → postgres/access}/htup_details.h +80 -88
- data/ext/pg_query/include/{access → postgres/access}/itup.h +61 -52
- 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 +17 -2
- data/ext/pg_query/include/postgres/access/rmgr.h +62 -0
- data/ext/pg_query/include/{access → postgres/access}/rmgrlist.h +24 -24
- 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 +4 -2
- data/ext/pg_query/include/{access → postgres/access}/sysattr.h +1 -1
- data/ext/pg_query/include/{access → postgres/access}/table.h +2 -1
- data/ext/pg_query/include/{access → postgres/access}/tableam.h +337 -62
- data/ext/pg_query/include/postgres/access/toast_compression.h +73 -0
- data/ext/pg_query/include/{access → postgres/access}/transam.h +123 -13
- 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 +60 -100
- data/ext/pg_query/include/{access → postgres/access}/twophase.h +5 -1
- data/ext/pg_query/include/{access → postgres/access}/xact.h +99 -32
- data/ext/pg_query/include/{access → postgres/access}/xlog.h +69 -165
- data/ext/pg_query/include/{access → postgres/access}/xlog_internal.h +147 -73
- data/ext/pg_query/include/postgres/access/xlogbackup.h +41 -0
- data/ext/pg_query/include/{access → postgres/access}/xlogdefs.h +13 -40
- data/ext/pg_query/include/postgres/access/xlogprefetcher.h +55 -0
- data/ext/pg_query/include/{access → postgres/access}/xlogreader.h +154 -37
- data/ext/pg_query/include/{access → postgres/access}/xlogrecord.h +34 -13
- data/ext/pg_query/include/postgres/access/xlogrecovery.h +158 -0
- data/ext/pg_query/include/postgres/archive/archive_module.h +59 -0
- data/ext/pg_query/include/{c.h → postgres/c.h} +245 -188
- data/ext/pg_query/include/{catalog → postgres/catalog}/catalog.h +6 -3
- data/ext/pg_query/include/{catalog → postgres/catalog}/catversion.h +6 -2
- data/ext/pg_query/include/{catalog → postgres/catalog}/dependency.h +14 -19
- data/ext/pg_query/include/postgres/catalog/genbki.h +143 -0
- data/ext/pg_query/include/{catalog → postgres/catalog}/index.h +20 -5
- data/ext/pg_query/include/postgres/catalog/indexing.h +54 -0
- data/ext/pg_query/include/{catalog → postgres/catalog}/namespace.h +5 -3
- data/ext/pg_query/include/{catalog → postgres/catalog}/objectaccess.h +73 -3
- data/ext/pg_query/include/{catalog → postgres/catalog}/objectaddress.h +12 -7
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_aggregate.h +14 -10
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_aggregate_d.h +2 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_am.h +4 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_am_d.h +3 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_attribute.h +45 -26
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_attribute_d.h +19 -16
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_authid.h +7 -2
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_authid_d.h +19 -9
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_class.h +45 -15
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_class_d.h +31 -2
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_collation.h +35 -8
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_collation_d.h +21 -3
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_constraint.h +39 -13
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_constraint_d.h +10 -4
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_control.h +13 -5
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_conversion.h +8 -5
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_conversion_d.h +4 -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 +11 -7
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_depend_d.h +3 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_event_trigger.h +9 -3
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_event_trigger_d.h +3 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_index.h +17 -7
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_index_d.h +20 -17
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_language.h +10 -5
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_language_d.h +3 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_namespace.h +7 -2
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_namespace_d.h +3 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_opclass.h +8 -5
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_opclass_d.h +3 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_operator.h +21 -16
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_operator_d.h +37 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_opfamily.h +8 -4
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_opfamily_d.h +6 -2
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_partitioned_table.h +20 -9
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_partitioned_table_d.h +2 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_proc.h +20 -11
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_proc_d.h +10 -8
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_publication.h +49 -6
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_publication_d.h +3 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_replication_origin.h +6 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_replication_origin_d.h +5 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_statistic.h +19 -12
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_statistic_d.h +2 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_statistic_ext.h +19 -5
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_statistic_ext_d.h +7 -2
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_transform.h +8 -5
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_transform_d.h +3 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_trigger.h +24 -8
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_trigger_d.h +4 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_ts_config.h +6 -3
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_ts_config_d.h +3 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_ts_dict.h +8 -3
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_ts_dict_d.h +3 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_ts_parser.h +6 -3
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_ts_parser_d.h +3 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_ts_template.h +6 -3
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_ts_template_d.h +3 -1
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_type.h +56 -24
- data/ext/pg_query/include/{catalog → postgres/catalog}/pg_type_d.h +70 -31
- data/ext/pg_query/include/{catalog → postgres/catalog}/storage.h +9 -7
- data/ext/pg_query/include/{commands → postgres/commands}/async.h +4 -5
- data/ext/pg_query/include/{commands → postgres/commands}/dbcommands.h +3 -1
- data/ext/pg_query/include/{commands → postgres/commands}/defrem.h +12 -24
- data/ext/pg_query/include/{commands → postgres/commands}/event_trigger.h +2 -2
- 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 +6 -4
- data/ext/pg_query/include/{commands → postgres/commands}/trigger.h +36 -25
- data/ext/pg_query/include/{commands → postgres/commands}/user.h +10 -4
- data/ext/pg_query/include/{commands → postgres/commands}/vacuum.h +140 -47
- data/ext/pg_query/include/postgres/common/cryptohash.h +39 -0
- data/ext/pg_query/include/{common → postgres/common}/file_perm.h +4 -4
- 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 +2 -6
- data/ext/pg_query/include/{common → postgres/common}/kwlookup.h +2 -2
- data/ext/pg_query/include/postgres/common/pg_prng.h +61 -0
- data/ext/pg_query/include/{common → postgres/common}/relpath.h +21 -14
- 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/postgres/common/string.h +44 -0
- data/ext/pg_query/include/postgres/common/unicode_east_asian_fw_table.h +125 -0
- data/ext/pg_query/include/{common/unicode_combining_table.h → postgres/common/unicode_nonspacing_table.h} +138 -8
- 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 +50 -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 +98 -32
- data/ext/pg_query/include/{executor → postgres/executor}/functions.h +17 -3
- data/ext/pg_query/include/{executor → postgres/executor}/instrument.h +33 -16
- data/ext/pg_query/include/{executor → postgres/executor}/spi.h +42 -4
- 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} +33 -8
- data/ext/pg_query/include/postgres/foreign/fdwapi.h +294 -0
- data/ext/pg_query/include/{funcapi.h → postgres/funcapi.h} +22 -10
- 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 +12 -12
- data/ext/pg_query/include/postgres/kwlist_d.h +1119 -0
- data/ext/pg_query/include/postgres/lib/dshash.h +115 -0
- data/ext/pg_query/include/{lib → postgres/lib}/ilist.h +454 -22
- data/ext/pg_query/include/{lib → postgres/lib}/pairingheap.h +1 -1
- data/ext/pg_query/include/{lib → postgres/lib}/simplehash.h +158 -33
- data/ext/pg_query/include/postgres/lib/sort_template.h +432 -0
- data/ext/pg_query/include/{lib → postgres/lib}/stringinfo.h +3 -3
- data/ext/pg_query/include/{libpq → postgres/libpq}/auth.h +12 -4
- data/ext/pg_query/include/{libpq → postgres/libpq}/crypt.h +5 -4
- data/ext/pg_query/include/{libpq → postgres/libpq}/hba.h +54 -8
- data/ext/pg_query/include/{libpq → postgres/libpq}/libpq-be.h +45 -17
- data/ext/pg_query/include/{libpq → postgres/libpq}/libpq.h +31 -20
- data/ext/pg_query/include/{libpq → postgres/libpq}/pqcomm.h +26 -71
- data/ext/pg_query/include/{libpq → postgres/libpq}/pqformat.h +2 -2
- data/ext/pg_query/include/{libpq → postgres/libpq}/pqsignal.h +25 -13
- 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 +125 -25
- data/ext/pg_query/include/{mb → postgres/mb}/stringinfo_mb.h +1 -1
- data/ext/pg_query/include/{miscadmin.h → postgres/miscadmin.h} +96 -65
- data/ext/pg_query/include/{nodes → postgres/nodes}/bitmapset.h +11 -7
- data/ext/pg_query/include/{nodes → postgres/nodes}/execnodes.h +351 -103
- data/ext/pg_query/include/{nodes → postgres/nodes}/extensible.h +8 -4
- data/ext/pg_query/include/{nodes → postgres/nodes}/lockoptions.h +1 -1
- data/ext/pg_query/include/{nodes → postgres/nodes}/makefuncs.h +19 -6
- data/ext/pg_query/include/{nodes → postgres/nodes}/memnodes.h +11 -6
- 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 +100 -496
- 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 +678 -207
- data/ext/pg_query/include/{nodes → postgres/nodes}/pathnodes.h +1282 -454
- data/ext/pg_query/include/{nodes → postgres/nodes}/pg_list.h +103 -73
- data/ext/pg_query/include/{nodes → postgres/nodes}/plannodes.h +474 -133
- data/ext/pg_query/include/{nodes → postgres/nodes}/primnodes.h +754 -254
- data/ext/pg_query/include/{nodes → postgres/nodes}/print.h +1 -1
- data/ext/pg_query/include/postgres/nodes/queryjumble.h +86 -0
- 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/postgres/nodes/value.h +90 -0
- data/ext/pg_query/include/{optimizer → postgres/optimizer}/cost.h +14 -5
- data/ext/pg_query/include/{optimizer → postgres/optimizer}/geqo.h +9 -7
- data/ext/pg_query/include/{optimizer → postgres/optimizer}/geqo_gene.h +1 -1
- data/ext/pg_query/include/{optimizer → postgres/optimizer}/optimizer.h +31 -28
- data/ext/pg_query/include/{optimizer → postgres/optimizer}/paths.h +29 -12
- data/ext/pg_query/include/{optimizer → postgres/optimizer}/planmain.h +15 -17
- data/ext/pg_query/include/{parser → postgres/parser}/analyze.h +20 -5
- data/ext/pg_query/include/postgres/parser/kwlist.h +498 -0
- data/ext/pg_query/include/{parser → postgres/parser}/parse_agg.h +5 -8
- data/ext/pg_query/include/{parser → postgres/parser}/parse_coerce.h +6 -1
- data/ext/pg_query/include/{parser → postgres/parser}/parse_expr.h +2 -3
- data/ext/pg_query/include/{parser → postgres/parser}/parse_func.h +2 -1
- data/ext/pg_query/include/{parser → postgres/parser}/parse_node.h +41 -11
- data/ext/pg_query/include/{parser → postgres/parser}/parse_oper.h +3 -5
- data/ext/pg_query/include/{parser → postgres/parser}/parse_relation.h +11 -5
- data/ext/pg_query/include/{parser → postgres/parser}/parse_type.h +4 -3
- data/ext/pg_query/include/postgres/parser/parser.h +68 -0
- 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 +2 -5
- data/ext/pg_query/include/{partitioning → postgres/partitioning}/partdefs.h +1 -1
- data/ext/pg_query/include/{pg_config.h → postgres/pg_config.h} +216 -228
- data/ext/pg_query/include/{pg_config_manual.h → postgres/pg_config_manual.h} +80 -58
- data/ext/pg_query/include/postgres/pg_config_os.h +8 -0
- data/ext/pg_query/include/{pg_getopt.h → postgres/pg_getopt.h} +6 -6
- data/ext/pg_query/include/{pg_trace.h → postgres/pg_trace.h} +1 -1
- data/ext/pg_query/include/postgres/pgstat.h +778 -0
- data/ext/pg_query/include/{pgtime.h → postgres/pgtime.h} +16 -6
- data/ext/pg_query/include/{pl_gram.h → postgres/pl_gram.h} +116 -116
- 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} +10 -10
- data/ext/pg_query/include/{pl_unreserved_kwlist.h → postgres/pl_unreserved_kwlist.h} +3 -3
- data/ext/pg_query/include/{pl_unreserved_kwlist_d.h → postgres/pl_unreserved_kwlist_d.h} +60 -60
- data/ext/pg_query/include/{plerrcodes.h → postgres/plerrcodes.h} +9 -1
- data/ext/pg_query/include/{plpgsql.h → postgres/plpgsql.h} +79 -86
- data/ext/pg_query/include/{port → postgres/port}/atomics/arch-arm.h +9 -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 +3 -3
- 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 +129 -16
- 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} +107 -111
- 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 +17 -20
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/bgworker.h +3 -2
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/bgworker_internals.h +2 -2
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/bgwriter.h +6 -6
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/interrupt.h +1 -1
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/pgarch.h +7 -10
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/postmaster.h +21 -17
- data/ext/pg_query/include/postgres/postmaster/startup.h +41 -0
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/syslogger.h +16 -11
- data/ext/pg_query/include/{postmaster → postgres/postmaster}/walwriter.h +5 -3
- data/ext/pg_query/include/{regex → postgres/regex}/regex.h +27 -22
- data/ext/pg_query/include/{replication → postgres/replication}/logicallauncher.h +8 -5
- data/ext/pg_query/include/postgres/replication/logicalproto.h +274 -0
- data/ext/pg_query/include/postgres/replication/logicalworker.h +32 -0
- data/ext/pg_query/include/{replication → postgres/replication}/origin.h +8 -8
- data/ext/pg_query/include/postgres/replication/reorderbuffer.h +753 -0
- data/ext/pg_query/include/{replication → postgres/replication}/slot.h +42 -12
- data/ext/pg_query/include/{replication → postgres/replication}/syncrep.h +6 -12
- data/ext/pg_query/include/{replication → postgres/replication}/walreceiver.h +158 -20
- data/ext/pg_query/include/{replication → postgres/replication}/walsender.h +20 -20
- data/ext/pg_query/include/{rewrite → postgres/rewrite}/prs2lock.h +1 -1
- data/ext/pg_query/include/{rewrite → postgres/rewrite}/rewriteHandler.h +1 -6
- 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 +3 -3
- data/ext/pg_query/include/{storage → postgres/storage}/block.h +24 -37
- data/ext/pg_query/include/{storage → postgres/storage}/buf.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/bufmgr.h +196 -95
- data/ext/pg_query/include/{storage → postgres/storage}/bufpage.h +152 -101
- data/ext/pg_query/include/{storage → postgres/storage}/condition_variable.h +14 -3
- data/ext/pg_query/include/{storage → postgres/storage}/dsm.h +6 -6
- data/ext/pg_query/include/{storage → postgres/storage}/dsm_impl.h +6 -2
- data/ext/pg_query/include/{storage → postgres/storage}/fd.h +48 -14
- data/ext/pg_query/include/postgres/storage/fileset.h +40 -0
- data/ext/pg_query/include/{storage → postgres/storage}/ipc.h +5 -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 +96 -57
- data/ext/pg_query/include/{storage → postgres/storage}/large_object.h +2 -2
- data/ext/pg_query/include/{storage → postgres/storage}/latch.h +17 -13
- data/ext/pg_query/include/{storage → postgres/storage}/lmgr.h +7 -1
- data/ext/pg_query/include/{storage → postgres/storage}/lock.h +37 -25
- data/ext/pg_query/include/{storage → postgres/storage}/lockdefs.h +4 -4
- data/ext/pg_query/include/{storage → postgres/storage}/lwlock.h +21 -33
- data/ext/pg_query/include/{storage → postgres/storage}/lwlocknames.h +0 -1
- 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 +9 -7
- data/ext/pg_query/include/{storage → postgres/storage}/pmsignal.h +15 -4
- data/ext/pg_query/include/{storage → postgres/storage}/predicate.h +5 -5
- data/ext/pg_query/include/{storage → postgres/storage}/proc.h +200 -67
- data/ext/pg_query/include/postgres/storage/procarray.h +99 -0
- data/ext/pg_query/include/{storage → postgres/storage}/proclist_types.h +1 -1
- data/ext/pg_query/include/{storage → postgres/storage}/procsignal.h +5 -7
- data/ext/pg_query/include/postgres/storage/relfilelocator.h +99 -0
- data/ext/pg_query/include/{storage → postgres/storage}/s_lock.h +118 -298
- data/ext/pg_query/include/{storage → postgres/storage}/sharedfileset.h +3 -11
- data/ext/pg_query/include/{storage → postgres/storage}/shm_mq.h +5 -4
- 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 +5 -5
- data/ext/pg_query/include/{storage → postgres/storage}/sinvaladt.h +4 -2
- data/ext/pg_query/include/{storage → postgres/storage}/smgr.h +21 -17
- data/ext/pg_query/include/{storage → postgres/storage}/spin.h +2 -2
- data/ext/pg_query/include/{storage → postgres/storage}/standby.h +17 -9
- data/ext/pg_query/include/{storage → postgres/storage}/standbydefs.h +2 -2
- data/ext/pg_query/include/{storage → postgres/storage}/sync.h +9 -5
- data/ext/pg_query/include/{tcop → postgres/tcop}/cmdtag.h +7 -2
- data/ext/pg_query/include/{tcop → postgres/tcop}/cmdtaglist.h +3 -2
- 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 -2
- data/ext/pg_query/include/{tcop → postgres/tcop}/pquery.h +7 -1
- data/ext/pg_query/include/{tcop → postgres/tcop}/tcopprot.h +19 -14
- data/ext/pg_query/include/{tcop → postgres/tcop}/utility.h +7 -3
- data/ext/pg_query/include/{tsearch → postgres/tsearch}/ts_cache.h +3 -5
- data/ext/pg_query/include/{utils → postgres/utils}/acl.h +37 -71
- data/ext/pg_query/include/{utils → postgres/utils}/aclchk_internal.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/array.h +26 -2
- data/ext/pg_query/include/postgres/utils/backend_progress.h +45 -0
- data/ext/pg_query/include/postgres/utils/backend_status.h +342 -0
- data/ext/pg_query/include/{utils → postgres/utils}/builtins.h +20 -11
- data/ext/pg_query/include/{utils → postgres/utils}/bytea.h +3 -2
- 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 +48 -27
- data/ext/pg_query/include/{utils → postgres/utils}/datum.h +9 -1
- data/ext/pg_query/include/{utils → postgres/utils}/dsa.h +5 -1
- data/ext/pg_query/include/{utils → postgres/utils}/elog.h +154 -48
- data/ext/pg_query/include/{utils → postgres/utils}/errcodes.h +2 -0
- 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 +13 -12
- data/ext/pg_query/include/{utils → postgres/utils}/fmgroids.h +1353 -696
- data/ext/pg_query/include/{utils → postgres/utils}/fmgrprotos.h +243 -18
- data/ext/pg_query/include/{utils → postgres/utils}/fmgrtab.h +6 -5
- data/ext/pg_query/include/{utils → postgres/utils}/guc.h +120 -121
- data/ext/pg_query/include/postgres/utils/guc_hooks.h +163 -0
- data/ext/pg_query/include/{utils → postgres/utils}/guc_tables.h +71 -21
- data/ext/pg_query/include/{utils → postgres/utils}/hsearch.h +15 -11
- data/ext/pg_query/include/{utils → postgres/utils}/inval.h +7 -3
- data/ext/pg_query/include/postgres/utils/logtape.h +77 -0
- data/ext/pg_query/include/{utils → postgres/utils}/lsyscache.h +16 -1
- data/ext/pg_query/include/{utils → postgres/utils}/memdebug.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/memutils.h +14 -53
- 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 +38 -9
- data/ext/pg_query/include/{utils → postgres/utils}/palloc.h +33 -4
- data/ext/pg_query/include/{utils → postgres/utils}/partcache.h +3 -2
- data/ext/pg_query/include/{utils → postgres/utils}/pg_locale.h +37 -21
- data/ext/pg_query/include/postgres/utils/pgstat_internal.h +814 -0
- data/ext/pg_query/include/{utils → postgres/utils}/plancache.h +6 -5
- data/ext/pg_query/include/{utils → postgres/utils}/portal.h +12 -1
- data/ext/pg_query/include/{utils → postgres/utils}/probes.h +59 -59
- 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/postgres/utils/regproc.h +39 -0
- data/ext/pg_query/include/{utils → postgres/utils}/rel.h +129 -61
- data/ext/pg_query/include/{utils → postgres/utils}/relcache.h +21 -14
- 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 +9 -1
- data/ext/pg_query/include/{utils → postgres/utils}/sharedtuplestore.h +1 -1
- data/ext/pg_query/include/{utils → postgres/utils}/snapmgr.h +38 -15
- data/ext/pg_query/include/{utils → postgres/utils}/snapshot.h +14 -1
- data/ext/pg_query/include/{utils → postgres/utils}/sortsupport.h +117 -2
- data/ext/pg_query/include/{utils → postgres/utils}/syscache.h +9 -1
- data/ext/pg_query/include/{utils → postgres/utils}/timeout.h +11 -4
- data/ext/pg_query/include/{utils → postgres/utils}/timestamp.h +46 -15
- data/ext/pg_query/include/{utils → postgres/utils}/tuplesort.h +209 -41
- data/ext/pg_query/include/{utils → postgres/utils}/tuplestore.h +2 -2
- data/ext/pg_query/include/{utils → postgres/utils}/typcache.h +24 -17
- data/ext/pg_query/include/{utils → postgres/utils}/varlena.h +17 -3
- data/ext/pg_query/include/postgres/utils/wait_event.h +294 -0
- data/ext/pg_query/include/{utils → postgres/utils}/xml.h +18 -8
- data/ext/pg_query/include/{postgres.h → postgres/varatt.h} +65 -471
- data/ext/pg_query/include/protobuf/pg_query.pb-c.h +7494 -6382
- data/ext/pg_query/include/protobuf/pg_query.pb.h +116922 -84792
- data/ext/pg_query/include/protobuf-c/protobuf-c.h +7 -3
- data/ext/pg_query/include/protobuf-c.h +7 -3
- data/ext/pg_query/pg_query.c +10 -1
- data/ext/pg_query/pg_query.pb-c.c +21026 -17002
- data/ext/pg_query/pg_query_deparse.c +1 -9896
- data/ext/pg_query/pg_query_fingerprint.c +162 -50
- data/ext/pg_query/pg_query_fingerprint.h +3 -1
- data/ext/pg_query/pg_query_internal.h +1 -1
- data/ext/pg_query/pg_query_json_plpgsql.c +56 -12
- data/ext/pg_query/pg_query_normalize.c +259 -64
- data/ext/pg_query/pg_query_outfuncs.h +1 -0
- data/ext/pg_query/pg_query_outfuncs_json.c +71 -16
- data/ext/pg_query/pg_query_outfuncs_protobuf.c +73 -12
- data/ext/pg_query/pg_query_parse.c +47 -5
- data/ext/pg_query/pg_query_parse_plpgsql.c +86 -21
- data/ext/pg_query/pg_query_readfuncs_protobuf.c +43 -8
- data/ext/pg_query/pg_query_ruby.c +6 -1
- data/ext/pg_query/pg_query_ruby_freebsd.sym +2 -0
- data/ext/pg_query/pg_query_scan.c +3 -2
- data/ext/pg_query/pg_query_split.c +6 -5
- data/ext/pg_query/postgres_deparse.c +11067 -0
- data/ext/pg_query/postgres_deparse.h +9 -0
- data/ext/pg_query/protobuf-c.c +34 -27
- data/ext/pg_query/src_backend_catalog_namespace.c +27 -10
- data/ext/pg_query/src_backend_catalog_pg_proc.c +4 -1
- data/ext/pg_query/src_backend_commands_define.c +11 -1
- data/ext/pg_query/src_backend_nodes_bitmapset.c +13 -70
- data/ext/pg_query/src_backend_nodes_copyfuncs.c +103 -5894
- data/ext/pg_query/src_backend_nodes_equalfuncs.c +102 -3830
- data/ext/pg_query/src_backend_nodes_extensible.c +6 -29
- data/ext/pg_query/src_backend_nodes_list.c +99 -12
- data/ext/pg_query/src_backend_nodes_makefuncs.c +99 -4
- data/ext/pg_query/src_backend_nodes_nodeFuncs.c +325 -131
- data/ext/pg_query/src_backend_nodes_nodes.c +38 -0
- data/ext/pg_query/src_backend_nodes_value.c +28 -19
- data/ext/pg_query/src_backend_parser_gram.c +36104 -32074
- data/ext/pg_query/src_backend_parser_parser.c +53 -8
- data/ext/pg_query/src_backend_parser_scan.c +4893 -3701
- data/ext/pg_query/src_backend_parser_scansup.c +4 -28
- data/ext/pg_query/src_backend_storage_ipc_ipc.c +13 -4
- data/ext/pg_query/src_backend_tcop_postgres.c +133 -105
- data/ext/pg_query/src_backend_utils_activity_pgstat_database.c +140 -0
- data/ext/pg_query/src_backend_utils_adt_datum.c +17 -7
- data/ext/pg_query/src_backend_utils_adt_expandeddatum.c +1 -1
- data/ext/pg_query/src_backend_utils_adt_format_type.c +6 -2
- data/ext/pg_query/src_backend_utils_adt_numutils.c +489 -0
- data/ext/pg_query/src_backend_utils_adt_ruleutils.c +187 -19
- data/ext/pg_query/src_backend_utils_error_assert.c +17 -18
- data/ext/pg_query/src_backend_utils_error_elog.c +513 -318
- data/ext/pg_query/src_backend_utils_fmgr_fmgr.c +44 -17
- data/ext/pg_query/src_backend_utils_init_globals.c +9 -6
- data/ext/pg_query/src_backend_utils_mb_mbutils.c +74 -131
- 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 +453 -314
- data/ext/pg_query/src_backend_utils_mmgr_generation.c +1039 -0
- data/ext/pg_query/src_backend_utils_mmgr_mcxt.c +549 -76
- 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 +420 -0
- data/ext/pg_query/src_common_keywords.c +15 -2
- data/ext/pg_query/src_common_kwlist_d.h +545 -498
- 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 +717 -113
- data/ext/pg_query/src_pl_plpgsql_src_pl_comp.c +49 -22
- data/ext/pg_query/src_pl_plpgsql_src_pl_funcs.c +3 -18
- data/ext/pg_query/src_pl_plpgsql_src_pl_gram.c +1136 -1195
- 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 +10 -10
- data/ext/pg_query/src_pl_plpgsql_src_pl_scanner.c +2 -2
- data/ext/pg_query/src_pl_plpgsql_src_pl_unreserved_kwlist_d.h +60 -60
- data/ext/pg_query/src_port_pg_bitutils.c +103 -40
- data/ext/pg_query/src_port_pgstrcasecmp.c +29 -1
- data/ext/pg_query/src_port_qsort.c +12 -224
- data/ext/pg_query/src_port_snprintf.c +51 -29
- data/ext/pg_query/src_port_strerror.c +9 -19
- data/ext/pg_query/src_port_strlcpy.c +79 -0
- data/lib/pg_query/deparse.rb +7 -1
- data/lib/pg_query/filter_columns.rb +7 -5
- data/lib/pg_query/fingerprint.rb +21 -9
- data/lib/pg_query/node.rb +18 -13
- data/lib/pg_query/param_refs.rb +1 -1
- data/lib/pg_query/parse.rb +141 -50
- data/lib/pg_query/pg_query_pb.rb +175 -3031
- data/lib/pg_query/treewalker.rb +26 -2
- data/lib/pg_query/truncate.rb +54 -8
- data/lib/pg_query/version.rb +1 -1
- data/lib/pg_query.rb +0 -1
- metadata +443 -380
- data/ext/pg_query/guc-file.c +0 -0
- data/ext/pg_query/include/access/rmgr.h +0 -35
- data/ext/pg_query/include/access/xloginsert.h +0 -64
- data/ext/pg_query/include/bootstrap/bootstrap.h +0 -62
- data/ext/pg_query/include/catalog/genbki.h +0 -64
- data/ext/pg_query/include/catalog/indexing.h +0 -366
- data/ext/pg_query/include/commands/variable.h +0 -38
- data/ext/pg_query/include/common/ip.h +0 -37
- data/ext/pg_query/include/common/string.h +0 -19
- data/ext/pg_query/include/getaddrinfo.h +0 -162
- data/ext/pg_query/include/kwlist_d.h +0 -1072
- data/ext/pg_query/include/nodes/value.h +0 -61
- data/ext/pg_query/include/parser/gram.h +0 -1067
- data/ext/pg_query/include/parser/kwlist.h +0 -477
- data/ext/pg_query/include/parser/parse_clause.h +0 -54
- data/ext/pg_query/include/parser/parse_collate.h +0 -27
- data/ext/pg_query/include/parser/parse_target.h +0 -46
- data/ext/pg_query/include/parser/parser.h +0 -41
- data/ext/pg_query/include/pg_config_os.h +0 -8
- data/ext/pg_query/include/pgstat.h +0 -1487
- data/ext/pg_query/include/portability/instr_time.h +0 -256
- data/ext/pg_query/include/postmaster/fork_process.h +0 -17
- data/ext/pg_query/include/replication/logicalproto.h +0 -110
- data/ext/pg_query/include/replication/logicalworker.h +0 -19
- data/ext/pg_query/include/replication/reorderbuffer.h +0 -467
- data/ext/pg_query/include/storage/relfilenode.h +0 -99
- data/ext/pg_query/include/utils/dynahash.h +0 -19
- 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/regproc.h +0 -28
- 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_libpq_pqcomm.c +0 -651
- data/ext/pg_query/src_backend_parser_parse_expr.c +0 -313
- data/ext/pg_query/src_backend_postmaster_postmaster.c +0 -2230
- data/ext/pg_query/src_backend_storage_lmgr_s_lock.c +0 -370
- data/ext/pg_query/src_backend_utils_hash_dynahash.c +0 -1086
- data/ext/pg_query/src_backend_utils_misc_guc.c +0 -1831
- data/ext/pg_query/src_common_string.c +0 -86
- data/ext/pg_query/src_port_erand48.c +0 -127
- data/ext/pg_query/src_port_pgsleep.c +0 -69
- data/ext/pg_query/src_port_random.c +0 -31
- data/ext/pg_query/src_port_strnlen.c +0 -39
- data/lib/pg_query/json_field_names.rb +0 -1402
- /data/ext/pg_query/include/{pg_config_ext.h → postgres/pg_config_ext.h} +0 -0
@@ -0,0 +1,753 @@
|
|
1
|
+
/*
|
2
|
+
* reorderbuffer.h
|
3
|
+
* PostgreSQL logical replay/reorder buffer management.
|
4
|
+
*
|
5
|
+
* Copyright (c) 2012-2023, PostgreSQL Global Development Group
|
6
|
+
*
|
7
|
+
* src/include/replication/reorderbuffer.h
|
8
|
+
*/
|
9
|
+
#ifndef REORDERBUFFER_H
|
10
|
+
#define REORDERBUFFER_H
|
11
|
+
|
12
|
+
#include "access/htup_details.h"
|
13
|
+
#include "lib/ilist.h"
|
14
|
+
#include "storage/sinval.h"
|
15
|
+
#include "utils/hsearch.h"
|
16
|
+
#include "utils/relcache.h"
|
17
|
+
#include "utils/snapshot.h"
|
18
|
+
#include "utils/timestamp.h"
|
19
|
+
|
20
|
+
/* GUC variables */
|
21
|
+
extern PGDLLIMPORT int logical_decoding_work_mem;
|
22
|
+
extern PGDLLIMPORT int debug_logical_replication_streaming;
|
23
|
+
|
24
|
+
/* possible values for debug_logical_replication_streaming */
|
25
|
+
typedef enum
|
26
|
+
{
|
27
|
+
DEBUG_LOGICAL_REP_STREAMING_BUFFERED,
|
28
|
+
DEBUG_LOGICAL_REP_STREAMING_IMMEDIATE
|
29
|
+
} DebugLogicalRepStreamingMode;
|
30
|
+
|
31
|
+
/* an individual tuple, stored in one chunk of memory */
|
32
|
+
typedef struct ReorderBufferTupleBuf
|
33
|
+
{
|
34
|
+
/* position in preallocated list */
|
35
|
+
slist_node node;
|
36
|
+
|
37
|
+
/* tuple header, the interesting bit for users of logical decoding */
|
38
|
+
HeapTupleData tuple;
|
39
|
+
|
40
|
+
/* pre-allocated size of tuple buffer, different from tuple size */
|
41
|
+
Size alloc_tuple_size;
|
42
|
+
|
43
|
+
/* actual tuple data follows */
|
44
|
+
} ReorderBufferTupleBuf;
|
45
|
+
|
46
|
+
/* pointer to the data stored in a TupleBuf */
|
47
|
+
#define ReorderBufferTupleBufData(p) \
|
48
|
+
((HeapTupleHeader) MAXALIGN(((char *) p) + sizeof(ReorderBufferTupleBuf)))
|
49
|
+
|
50
|
+
/*
|
51
|
+
* Types of the change passed to a 'change' callback.
|
52
|
+
*
|
53
|
+
* For efficiency and simplicity reasons we want to keep Snapshots, CommandIds
|
54
|
+
* and ComboCids in the same list with the user visible INSERT/UPDATE/DELETE
|
55
|
+
* changes. Users of the decoding facilities will never see changes with
|
56
|
+
* *_INTERNAL_* actions.
|
57
|
+
*
|
58
|
+
* The INTERNAL_SPEC_INSERT and INTERNAL_SPEC_CONFIRM, and INTERNAL_SPEC_ABORT
|
59
|
+
* changes concern "speculative insertions", their confirmation, and abort
|
60
|
+
* respectively. They're used by INSERT .. ON CONFLICT .. UPDATE. Users of
|
61
|
+
* logical decoding don't have to care about these.
|
62
|
+
*/
|
63
|
+
typedef enum ReorderBufferChangeType
|
64
|
+
{
|
65
|
+
REORDER_BUFFER_CHANGE_INSERT,
|
66
|
+
REORDER_BUFFER_CHANGE_UPDATE,
|
67
|
+
REORDER_BUFFER_CHANGE_DELETE,
|
68
|
+
REORDER_BUFFER_CHANGE_MESSAGE,
|
69
|
+
REORDER_BUFFER_CHANGE_INVALIDATION,
|
70
|
+
REORDER_BUFFER_CHANGE_INTERNAL_SNAPSHOT,
|
71
|
+
REORDER_BUFFER_CHANGE_INTERNAL_COMMAND_ID,
|
72
|
+
REORDER_BUFFER_CHANGE_INTERNAL_TUPLECID,
|
73
|
+
REORDER_BUFFER_CHANGE_INTERNAL_SPEC_INSERT,
|
74
|
+
REORDER_BUFFER_CHANGE_INTERNAL_SPEC_CONFIRM,
|
75
|
+
REORDER_BUFFER_CHANGE_INTERNAL_SPEC_ABORT,
|
76
|
+
REORDER_BUFFER_CHANGE_TRUNCATE
|
77
|
+
} ReorderBufferChangeType;
|
78
|
+
|
79
|
+
/* forward declaration */
|
80
|
+
struct ReorderBufferTXN;
|
81
|
+
|
82
|
+
/*
|
83
|
+
* a single 'change', can be an insert (with one tuple), an update (old, new),
|
84
|
+
* or a delete (old).
|
85
|
+
*
|
86
|
+
* The same struct is also used internally for other purposes but that should
|
87
|
+
* never be visible outside reorderbuffer.c.
|
88
|
+
*/
|
89
|
+
typedef struct ReorderBufferChange
|
90
|
+
{
|
91
|
+
XLogRecPtr lsn;
|
92
|
+
|
93
|
+
/* The type of change. */
|
94
|
+
ReorderBufferChangeType action;
|
95
|
+
|
96
|
+
/* Transaction this change belongs to. */
|
97
|
+
struct ReorderBufferTXN *txn;
|
98
|
+
|
99
|
+
RepOriginId origin_id;
|
100
|
+
|
101
|
+
/*
|
102
|
+
* Context data for the change. Which part of the union is valid depends
|
103
|
+
* on action.
|
104
|
+
*/
|
105
|
+
union
|
106
|
+
{
|
107
|
+
/* Old, new tuples when action == *_INSERT|UPDATE|DELETE */
|
108
|
+
struct
|
109
|
+
{
|
110
|
+
/* relation that has been changed */
|
111
|
+
RelFileLocator rlocator;
|
112
|
+
|
113
|
+
/* no previously reassembled toast chunks are necessary anymore */
|
114
|
+
bool clear_toast_afterwards;
|
115
|
+
|
116
|
+
/* valid for DELETE || UPDATE */
|
117
|
+
ReorderBufferTupleBuf *oldtuple;
|
118
|
+
/* valid for INSERT || UPDATE */
|
119
|
+
ReorderBufferTupleBuf *newtuple;
|
120
|
+
} tp;
|
121
|
+
|
122
|
+
/*
|
123
|
+
* Truncate data for REORDER_BUFFER_CHANGE_TRUNCATE representing one
|
124
|
+
* set of relations to be truncated.
|
125
|
+
*/
|
126
|
+
struct
|
127
|
+
{
|
128
|
+
Size nrelids;
|
129
|
+
bool cascade;
|
130
|
+
bool restart_seqs;
|
131
|
+
Oid *relids;
|
132
|
+
} truncate;
|
133
|
+
|
134
|
+
/* Message with arbitrary data. */
|
135
|
+
struct
|
136
|
+
{
|
137
|
+
char *prefix;
|
138
|
+
Size message_size;
|
139
|
+
char *message;
|
140
|
+
} msg;
|
141
|
+
|
142
|
+
/* New snapshot, set when action == *_INTERNAL_SNAPSHOT */
|
143
|
+
Snapshot snapshot;
|
144
|
+
|
145
|
+
/*
|
146
|
+
* New command id for existing snapshot in a catalog changing tx. Set
|
147
|
+
* when action == *_INTERNAL_COMMAND_ID.
|
148
|
+
*/
|
149
|
+
CommandId command_id;
|
150
|
+
|
151
|
+
/*
|
152
|
+
* New cid mapping for catalog changing transaction, set when action
|
153
|
+
* == *_INTERNAL_TUPLECID.
|
154
|
+
*/
|
155
|
+
struct
|
156
|
+
{
|
157
|
+
RelFileLocator locator;
|
158
|
+
ItemPointerData tid;
|
159
|
+
CommandId cmin;
|
160
|
+
CommandId cmax;
|
161
|
+
CommandId combocid;
|
162
|
+
} tuplecid;
|
163
|
+
|
164
|
+
/* Invalidation. */
|
165
|
+
struct
|
166
|
+
{
|
167
|
+
uint32 ninvalidations; /* Number of messages */
|
168
|
+
SharedInvalidationMessage *invalidations; /* invalidation message */
|
169
|
+
} inval;
|
170
|
+
} data;
|
171
|
+
|
172
|
+
/*
|
173
|
+
* While in use this is how a change is linked into a transactions,
|
174
|
+
* otherwise it's the preallocated list.
|
175
|
+
*/
|
176
|
+
dlist_node node;
|
177
|
+
} ReorderBufferChange;
|
178
|
+
|
179
|
+
/* ReorderBufferTXN txn_flags */
|
180
|
+
#define RBTXN_HAS_CATALOG_CHANGES 0x0001
|
181
|
+
#define RBTXN_IS_SUBXACT 0x0002
|
182
|
+
#define RBTXN_IS_SERIALIZED 0x0004
|
183
|
+
#define RBTXN_IS_SERIALIZED_CLEAR 0x0008
|
184
|
+
#define RBTXN_IS_STREAMED 0x0010
|
185
|
+
#define RBTXN_HAS_PARTIAL_CHANGE 0x0020
|
186
|
+
#define RBTXN_PREPARE 0x0040
|
187
|
+
#define RBTXN_SKIPPED_PREPARE 0x0080
|
188
|
+
#define RBTXN_HAS_STREAMABLE_CHANGE 0x0100
|
189
|
+
|
190
|
+
/* Does the transaction have catalog changes? */
|
191
|
+
#define rbtxn_has_catalog_changes(txn) \
|
192
|
+
( \
|
193
|
+
((txn)->txn_flags & RBTXN_HAS_CATALOG_CHANGES) != 0 \
|
194
|
+
)
|
195
|
+
|
196
|
+
/* Is the transaction known as a subxact? */
|
197
|
+
#define rbtxn_is_known_subxact(txn) \
|
198
|
+
( \
|
199
|
+
((txn)->txn_flags & RBTXN_IS_SUBXACT) != 0 \
|
200
|
+
)
|
201
|
+
|
202
|
+
/* Has this transaction been spilled to disk? */
|
203
|
+
#define rbtxn_is_serialized(txn) \
|
204
|
+
( \
|
205
|
+
((txn)->txn_flags & RBTXN_IS_SERIALIZED) != 0 \
|
206
|
+
)
|
207
|
+
|
208
|
+
/* Has this transaction ever been spilled to disk? */
|
209
|
+
#define rbtxn_is_serialized_clear(txn) \
|
210
|
+
( \
|
211
|
+
((txn)->txn_flags & RBTXN_IS_SERIALIZED_CLEAR) != 0 \
|
212
|
+
)
|
213
|
+
|
214
|
+
/* Has this transaction contains partial changes? */
|
215
|
+
#define rbtxn_has_partial_change(txn) \
|
216
|
+
( \
|
217
|
+
((txn)->txn_flags & RBTXN_HAS_PARTIAL_CHANGE) != 0 \
|
218
|
+
)
|
219
|
+
|
220
|
+
/* Does this transaction contain streamable changes? */
|
221
|
+
#define rbtxn_has_streamable_change(txn) \
|
222
|
+
( \
|
223
|
+
((txn)->txn_flags & RBTXN_HAS_STREAMABLE_CHANGE) != 0 \
|
224
|
+
)
|
225
|
+
|
226
|
+
/*
|
227
|
+
* Has this transaction been streamed to downstream?
|
228
|
+
*
|
229
|
+
* (It's not possible to deduce this from nentries and nentries_mem for
|
230
|
+
* various reasons. For example, all changes may be in subtransactions in
|
231
|
+
* which case we'd have nentries==0 for the toplevel one, which would say
|
232
|
+
* nothing about the streaming. So we maintain this flag, but only for the
|
233
|
+
* toplevel transaction.)
|
234
|
+
*/
|
235
|
+
#define rbtxn_is_streamed(txn) \
|
236
|
+
( \
|
237
|
+
((txn)->txn_flags & RBTXN_IS_STREAMED) != 0 \
|
238
|
+
)
|
239
|
+
|
240
|
+
/* Has this transaction been prepared? */
|
241
|
+
#define rbtxn_prepared(txn) \
|
242
|
+
( \
|
243
|
+
((txn)->txn_flags & RBTXN_PREPARE) != 0 \
|
244
|
+
)
|
245
|
+
|
246
|
+
/* prepare for this transaction skipped? */
|
247
|
+
#define rbtxn_skip_prepared(txn) \
|
248
|
+
( \
|
249
|
+
((txn)->txn_flags & RBTXN_SKIPPED_PREPARE) != 0 \
|
250
|
+
)
|
251
|
+
|
252
|
+
/* Is this a top-level transaction? */
|
253
|
+
#define rbtxn_is_toptxn(txn) \
|
254
|
+
( \
|
255
|
+
(txn)->toptxn == NULL \
|
256
|
+
)
|
257
|
+
|
258
|
+
/* Is this a subtransaction? */
|
259
|
+
#define rbtxn_is_subtxn(txn) \
|
260
|
+
( \
|
261
|
+
(txn)->toptxn != NULL \
|
262
|
+
)
|
263
|
+
|
264
|
+
/* Get the top-level transaction of this (sub)transaction. */
|
265
|
+
#define rbtxn_get_toptxn(txn) \
|
266
|
+
( \
|
267
|
+
rbtxn_is_subtxn(txn) ? (txn)->toptxn : (txn) \
|
268
|
+
)
|
269
|
+
|
270
|
+
typedef struct ReorderBufferTXN
|
271
|
+
{
|
272
|
+
/* See above */
|
273
|
+
bits32 txn_flags;
|
274
|
+
|
275
|
+
/* The transaction's transaction id, can be a toplevel or sub xid. */
|
276
|
+
TransactionId xid;
|
277
|
+
|
278
|
+
/* Xid of top-level transaction, if known */
|
279
|
+
TransactionId toplevel_xid;
|
280
|
+
|
281
|
+
/*
|
282
|
+
* Global transaction id required for identification of prepared
|
283
|
+
* transactions.
|
284
|
+
*/
|
285
|
+
char *gid;
|
286
|
+
|
287
|
+
/*
|
288
|
+
* LSN of the first data carrying, WAL record with knowledge about this
|
289
|
+
* xid. This is allowed to *not* be first record adorned with this xid, if
|
290
|
+
* the previous records aren't relevant for logical decoding.
|
291
|
+
*/
|
292
|
+
XLogRecPtr first_lsn;
|
293
|
+
|
294
|
+
/* ----
|
295
|
+
* LSN of the record that lead to this xact to be prepared or committed or
|
296
|
+
* aborted. This can be a
|
297
|
+
* * plain commit record
|
298
|
+
* * plain commit record, of a parent transaction
|
299
|
+
* * prepared transaction
|
300
|
+
* * prepared transaction commit
|
301
|
+
* * plain abort record
|
302
|
+
* * prepared transaction abort
|
303
|
+
*
|
304
|
+
* This can also become set to earlier values than transaction end when
|
305
|
+
* a transaction is spilled to disk; specifically it's set to the LSN of
|
306
|
+
* the latest change written to disk so far.
|
307
|
+
* ----
|
308
|
+
*/
|
309
|
+
XLogRecPtr final_lsn;
|
310
|
+
|
311
|
+
/*
|
312
|
+
* LSN pointing to the end of the commit record + 1.
|
313
|
+
*/
|
314
|
+
XLogRecPtr end_lsn;
|
315
|
+
|
316
|
+
/* Toplevel transaction for this subxact (NULL for top-level). */
|
317
|
+
struct ReorderBufferTXN *toptxn;
|
318
|
+
|
319
|
+
/*
|
320
|
+
* LSN of the last lsn at which snapshot information reside, so we can
|
321
|
+
* restart decoding from there and fully recover this transaction from
|
322
|
+
* WAL.
|
323
|
+
*/
|
324
|
+
XLogRecPtr restart_decoding_lsn;
|
325
|
+
|
326
|
+
/* origin of the change that caused this transaction */
|
327
|
+
RepOriginId origin_id;
|
328
|
+
XLogRecPtr origin_lsn;
|
329
|
+
|
330
|
+
/*
|
331
|
+
* Commit or Prepare time, only known when we read the actual commit or
|
332
|
+
* prepare record.
|
333
|
+
*/
|
334
|
+
union
|
335
|
+
{
|
336
|
+
TimestampTz commit_time;
|
337
|
+
TimestampTz prepare_time;
|
338
|
+
TimestampTz abort_time;
|
339
|
+
} xact_time;
|
340
|
+
|
341
|
+
/*
|
342
|
+
* The base snapshot is used to decode all changes until either this
|
343
|
+
* transaction modifies the catalog, or another catalog-modifying
|
344
|
+
* transaction commits.
|
345
|
+
*/
|
346
|
+
Snapshot base_snapshot;
|
347
|
+
XLogRecPtr base_snapshot_lsn;
|
348
|
+
dlist_node base_snapshot_node; /* link in txns_by_base_snapshot_lsn */
|
349
|
+
|
350
|
+
/*
|
351
|
+
* Snapshot/CID from the previous streaming run. Only valid for already
|
352
|
+
* streamed transactions (NULL/InvalidCommandId otherwise).
|
353
|
+
*/
|
354
|
+
Snapshot snapshot_now;
|
355
|
+
CommandId command_id;
|
356
|
+
|
357
|
+
/*
|
358
|
+
* How many ReorderBufferChange's do we have in this txn.
|
359
|
+
*
|
360
|
+
* Changes in subtransactions are *not* included but tracked separately.
|
361
|
+
*/
|
362
|
+
uint64 nentries;
|
363
|
+
|
364
|
+
/*
|
365
|
+
* How many of the above entries are stored in memory in contrast to being
|
366
|
+
* spilled to disk.
|
367
|
+
*/
|
368
|
+
uint64 nentries_mem;
|
369
|
+
|
370
|
+
/*
|
371
|
+
* List of ReorderBufferChange structs, including new Snapshots, new
|
372
|
+
* CommandIds and command invalidation messages.
|
373
|
+
*/
|
374
|
+
dlist_head changes;
|
375
|
+
|
376
|
+
/*
|
377
|
+
* List of (relation, ctid) => (cmin, cmax) mappings for catalog tuples.
|
378
|
+
* Those are always assigned to the toplevel transaction. (Keep track of
|
379
|
+
* #entries to create a hash of the right size)
|
380
|
+
*/
|
381
|
+
dlist_head tuplecids;
|
382
|
+
uint64 ntuplecids;
|
383
|
+
|
384
|
+
/*
|
385
|
+
* On-demand built hash for looking up the above values.
|
386
|
+
*/
|
387
|
+
HTAB *tuplecid_hash;
|
388
|
+
|
389
|
+
/*
|
390
|
+
* Hash containing (potentially partial) toast entries. NULL if no toast
|
391
|
+
* tuples have been found for the current change.
|
392
|
+
*/
|
393
|
+
HTAB *toast_hash;
|
394
|
+
|
395
|
+
/*
|
396
|
+
* non-hierarchical list of subtransactions that are *not* aborted. Only
|
397
|
+
* used in toplevel transactions.
|
398
|
+
*/
|
399
|
+
dlist_head subtxns;
|
400
|
+
uint32 nsubtxns;
|
401
|
+
|
402
|
+
/*
|
403
|
+
* Stored cache invalidations. This is not a linked list because we get
|
404
|
+
* all the invalidations at once.
|
405
|
+
*/
|
406
|
+
uint32 ninvalidations;
|
407
|
+
SharedInvalidationMessage *invalidations;
|
408
|
+
|
409
|
+
/* ---
|
410
|
+
* Position in one of three lists:
|
411
|
+
* * list of subtransactions if we are *known* to be subxact
|
412
|
+
* * list of toplevel xacts (can be an as-yet unknown subxact)
|
413
|
+
* * list of preallocated ReorderBufferTXNs (if unused)
|
414
|
+
* ---
|
415
|
+
*/
|
416
|
+
dlist_node node;
|
417
|
+
|
418
|
+
/*
|
419
|
+
* A node in the list of catalog modifying transactions
|
420
|
+
*/
|
421
|
+
dlist_node catchange_node;
|
422
|
+
|
423
|
+
/*
|
424
|
+
* Size of this transaction (changes currently in memory, in bytes).
|
425
|
+
*/
|
426
|
+
Size size;
|
427
|
+
|
428
|
+
/* Size of top-transaction including sub-transactions. */
|
429
|
+
Size total_size;
|
430
|
+
|
431
|
+
/* If we have detected concurrent abort then ignore future changes. */
|
432
|
+
bool concurrent_abort;
|
433
|
+
|
434
|
+
/*
|
435
|
+
* Private data pointer of the output plugin.
|
436
|
+
*/
|
437
|
+
void *output_plugin_private;
|
438
|
+
} ReorderBufferTXN;
|
439
|
+
|
440
|
+
/* so we can define the callbacks used inside struct ReorderBuffer itself */
|
441
|
+
typedef struct ReorderBuffer ReorderBuffer;
|
442
|
+
|
443
|
+
/* change callback signature */
|
444
|
+
typedef void (*ReorderBufferApplyChangeCB) (ReorderBuffer *rb,
|
445
|
+
ReorderBufferTXN *txn,
|
446
|
+
Relation relation,
|
447
|
+
ReorderBufferChange *change);
|
448
|
+
|
449
|
+
/* truncate callback signature */
|
450
|
+
typedef void (*ReorderBufferApplyTruncateCB) (ReorderBuffer *rb,
|
451
|
+
ReorderBufferTXN *txn,
|
452
|
+
int nrelations,
|
453
|
+
Relation relations[],
|
454
|
+
ReorderBufferChange *change);
|
455
|
+
|
456
|
+
/* begin callback signature */
|
457
|
+
typedef void (*ReorderBufferBeginCB) (ReorderBuffer *rb,
|
458
|
+
ReorderBufferTXN *txn);
|
459
|
+
|
460
|
+
/* commit callback signature */
|
461
|
+
typedef void (*ReorderBufferCommitCB) (ReorderBuffer *rb,
|
462
|
+
ReorderBufferTXN *txn,
|
463
|
+
XLogRecPtr commit_lsn);
|
464
|
+
|
465
|
+
/* message callback signature */
|
466
|
+
typedef void (*ReorderBufferMessageCB) (ReorderBuffer *rb,
|
467
|
+
ReorderBufferTXN *txn,
|
468
|
+
XLogRecPtr message_lsn,
|
469
|
+
bool transactional,
|
470
|
+
const char *prefix, Size sz,
|
471
|
+
const char *message);
|
472
|
+
|
473
|
+
/* begin prepare callback signature */
|
474
|
+
typedef void (*ReorderBufferBeginPrepareCB) (ReorderBuffer *rb,
|
475
|
+
ReorderBufferTXN *txn);
|
476
|
+
|
477
|
+
/* prepare callback signature */
|
478
|
+
typedef void (*ReorderBufferPrepareCB) (ReorderBuffer *rb,
|
479
|
+
ReorderBufferTXN *txn,
|
480
|
+
XLogRecPtr prepare_lsn);
|
481
|
+
|
482
|
+
/* commit prepared callback signature */
|
483
|
+
typedef void (*ReorderBufferCommitPreparedCB) (ReorderBuffer *rb,
|
484
|
+
ReorderBufferTXN *txn,
|
485
|
+
XLogRecPtr commit_lsn);
|
486
|
+
|
487
|
+
/* rollback prepared callback signature */
|
488
|
+
typedef void (*ReorderBufferRollbackPreparedCB) (ReorderBuffer *rb,
|
489
|
+
ReorderBufferTXN *txn,
|
490
|
+
XLogRecPtr prepare_end_lsn,
|
491
|
+
TimestampTz prepare_time);
|
492
|
+
|
493
|
+
/* start streaming transaction callback signature */
|
494
|
+
typedef void (*ReorderBufferStreamStartCB) (
|
495
|
+
ReorderBuffer *rb,
|
496
|
+
ReorderBufferTXN *txn,
|
497
|
+
XLogRecPtr first_lsn);
|
498
|
+
|
499
|
+
/* stop streaming transaction callback signature */
|
500
|
+
typedef void (*ReorderBufferStreamStopCB) (
|
501
|
+
ReorderBuffer *rb,
|
502
|
+
ReorderBufferTXN *txn,
|
503
|
+
XLogRecPtr last_lsn);
|
504
|
+
|
505
|
+
/* discard streamed transaction callback signature */
|
506
|
+
typedef void (*ReorderBufferStreamAbortCB) (
|
507
|
+
ReorderBuffer *rb,
|
508
|
+
ReorderBufferTXN *txn,
|
509
|
+
XLogRecPtr abort_lsn);
|
510
|
+
|
511
|
+
/* prepare streamed transaction callback signature */
|
512
|
+
typedef void (*ReorderBufferStreamPrepareCB) (
|
513
|
+
ReorderBuffer *rb,
|
514
|
+
ReorderBufferTXN *txn,
|
515
|
+
XLogRecPtr prepare_lsn);
|
516
|
+
|
517
|
+
/* commit streamed transaction callback signature */
|
518
|
+
typedef void (*ReorderBufferStreamCommitCB) (
|
519
|
+
ReorderBuffer *rb,
|
520
|
+
ReorderBufferTXN *txn,
|
521
|
+
XLogRecPtr commit_lsn);
|
522
|
+
|
523
|
+
/* stream change callback signature */
|
524
|
+
typedef void (*ReorderBufferStreamChangeCB) (
|
525
|
+
ReorderBuffer *rb,
|
526
|
+
ReorderBufferTXN *txn,
|
527
|
+
Relation relation,
|
528
|
+
ReorderBufferChange *change);
|
529
|
+
|
530
|
+
/* stream message callback signature */
|
531
|
+
typedef void (*ReorderBufferStreamMessageCB) (
|
532
|
+
ReorderBuffer *rb,
|
533
|
+
ReorderBufferTXN *txn,
|
534
|
+
XLogRecPtr message_lsn,
|
535
|
+
bool transactional,
|
536
|
+
const char *prefix, Size sz,
|
537
|
+
const char *message);
|
538
|
+
|
539
|
+
/* stream truncate callback signature */
|
540
|
+
typedef void (*ReorderBufferStreamTruncateCB) (
|
541
|
+
ReorderBuffer *rb,
|
542
|
+
ReorderBufferTXN *txn,
|
543
|
+
int nrelations,
|
544
|
+
Relation relations[],
|
545
|
+
ReorderBufferChange *change);
|
546
|
+
|
547
|
+
/* update progress txn callback signature */
|
548
|
+
typedef void (*ReorderBufferUpdateProgressTxnCB) (
|
549
|
+
ReorderBuffer *rb,
|
550
|
+
ReorderBufferTXN *txn,
|
551
|
+
XLogRecPtr lsn);
|
552
|
+
|
553
|
+
struct ReorderBuffer
|
554
|
+
{
|
555
|
+
/*
|
556
|
+
* xid => ReorderBufferTXN lookup table
|
557
|
+
*/
|
558
|
+
HTAB *by_txn;
|
559
|
+
|
560
|
+
/*
|
561
|
+
* Transactions that could be a toplevel xact, ordered by LSN of the first
|
562
|
+
* record bearing that xid.
|
563
|
+
*/
|
564
|
+
dlist_head toplevel_by_lsn;
|
565
|
+
|
566
|
+
/*
|
567
|
+
* Transactions and subtransactions that have a base snapshot, ordered by
|
568
|
+
* LSN of the record which caused us to first obtain the base snapshot.
|
569
|
+
* This is not the same as toplevel_by_lsn, because we only set the base
|
570
|
+
* snapshot on the first logical-decoding-relevant record (eg. heap
|
571
|
+
* writes), whereas the initial LSN could be set by other operations.
|
572
|
+
*/
|
573
|
+
dlist_head txns_by_base_snapshot_lsn;
|
574
|
+
|
575
|
+
/*
|
576
|
+
* Transactions and subtransactions that have modified system catalogs.
|
577
|
+
*/
|
578
|
+
dclist_head catchange_txns;
|
579
|
+
|
580
|
+
/*
|
581
|
+
* one-entry sized cache for by_txn. Very frequently the same txn gets
|
582
|
+
* looked up over and over again.
|
583
|
+
*/
|
584
|
+
TransactionId by_txn_last_xid;
|
585
|
+
ReorderBufferTXN *by_txn_last_txn;
|
586
|
+
|
587
|
+
/*
|
588
|
+
* Callbacks to be called when a transactions commits.
|
589
|
+
*/
|
590
|
+
ReorderBufferBeginCB begin;
|
591
|
+
ReorderBufferApplyChangeCB apply_change;
|
592
|
+
ReorderBufferApplyTruncateCB apply_truncate;
|
593
|
+
ReorderBufferCommitCB commit;
|
594
|
+
ReorderBufferMessageCB message;
|
595
|
+
|
596
|
+
/*
|
597
|
+
* Callbacks to be called when streaming a transaction at prepare time.
|
598
|
+
*/
|
599
|
+
ReorderBufferBeginCB begin_prepare;
|
600
|
+
ReorderBufferPrepareCB prepare;
|
601
|
+
ReorderBufferCommitPreparedCB commit_prepared;
|
602
|
+
ReorderBufferRollbackPreparedCB rollback_prepared;
|
603
|
+
|
604
|
+
/*
|
605
|
+
* Callbacks to be called when streaming a transaction.
|
606
|
+
*/
|
607
|
+
ReorderBufferStreamStartCB stream_start;
|
608
|
+
ReorderBufferStreamStopCB stream_stop;
|
609
|
+
ReorderBufferStreamAbortCB stream_abort;
|
610
|
+
ReorderBufferStreamPrepareCB stream_prepare;
|
611
|
+
ReorderBufferStreamCommitCB stream_commit;
|
612
|
+
ReorderBufferStreamChangeCB stream_change;
|
613
|
+
ReorderBufferStreamMessageCB stream_message;
|
614
|
+
ReorderBufferStreamTruncateCB stream_truncate;
|
615
|
+
|
616
|
+
/*
|
617
|
+
* Callback to be called when updating progress during sending data of a
|
618
|
+
* transaction (and its subtransactions) to the output plugin.
|
619
|
+
*/
|
620
|
+
ReorderBufferUpdateProgressTxnCB update_progress_txn;
|
621
|
+
|
622
|
+
/*
|
623
|
+
* Pointer that will be passed untouched to the callbacks.
|
624
|
+
*/
|
625
|
+
void *private_data;
|
626
|
+
|
627
|
+
/*
|
628
|
+
* Saved output plugin option
|
629
|
+
*/
|
630
|
+
bool output_rewrites;
|
631
|
+
|
632
|
+
/*
|
633
|
+
* Private memory context.
|
634
|
+
*/
|
635
|
+
MemoryContext context;
|
636
|
+
|
637
|
+
/*
|
638
|
+
* Memory contexts for specific types objects
|
639
|
+
*/
|
640
|
+
MemoryContext change_context;
|
641
|
+
MemoryContext txn_context;
|
642
|
+
MemoryContext tup_context;
|
643
|
+
|
644
|
+
XLogRecPtr current_restart_decoding_lsn;
|
645
|
+
|
646
|
+
/* buffer for disk<->memory conversions */
|
647
|
+
char *outbuf;
|
648
|
+
Size outbufsize;
|
649
|
+
|
650
|
+
/* memory accounting */
|
651
|
+
Size size;
|
652
|
+
|
653
|
+
/*
|
654
|
+
* Statistics about transactions spilled to disk.
|
655
|
+
*
|
656
|
+
* A single transaction may be spilled repeatedly, which is why we keep
|
657
|
+
* two different counters. For spilling, the transaction counter includes
|
658
|
+
* both toplevel transactions and subtransactions.
|
659
|
+
*/
|
660
|
+
int64 spillTxns; /* number of transactions spilled to disk */
|
661
|
+
int64 spillCount; /* spill-to-disk invocation counter */
|
662
|
+
int64 spillBytes; /* amount of data spilled to disk */
|
663
|
+
|
664
|
+
/* Statistics about transactions streamed to the decoding output plugin */
|
665
|
+
int64 streamTxns; /* number of transactions streamed */
|
666
|
+
int64 streamCount; /* streaming invocation counter */
|
667
|
+
int64 streamBytes; /* amount of data decoded */
|
668
|
+
|
669
|
+
/*
|
670
|
+
* Statistics about all the transactions sent to the decoding output
|
671
|
+
* plugin
|
672
|
+
*/
|
673
|
+
int64 totalTxns; /* total number of transactions sent */
|
674
|
+
int64 totalBytes; /* total amount of data decoded */
|
675
|
+
};
|
676
|
+
|
677
|
+
|
678
|
+
extern ReorderBuffer *ReorderBufferAllocate(void);
|
679
|
+
extern void ReorderBufferFree(ReorderBuffer *rb);
|
680
|
+
|
681
|
+
extern ReorderBufferTupleBuf *ReorderBufferGetTupleBuf(ReorderBuffer *rb,
|
682
|
+
Size tuple_len);
|
683
|
+
extern void ReorderBufferReturnTupleBuf(ReorderBuffer *rb,
|
684
|
+
ReorderBufferTupleBuf *tuple);
|
685
|
+
extern ReorderBufferChange *ReorderBufferGetChange(ReorderBuffer *rb);
|
686
|
+
extern void ReorderBufferReturnChange(ReorderBuffer *rb,
|
687
|
+
ReorderBufferChange *change, bool upd_mem);
|
688
|
+
|
689
|
+
extern Oid *ReorderBufferGetRelids(ReorderBuffer *rb, int nrelids);
|
690
|
+
extern void ReorderBufferReturnRelids(ReorderBuffer *rb, Oid *relids);
|
691
|
+
|
692
|
+
extern void ReorderBufferQueueChange(ReorderBuffer *rb, TransactionId xid,
|
693
|
+
XLogRecPtr lsn, ReorderBufferChange *change,
|
694
|
+
bool toast_insert);
|
695
|
+
extern void ReorderBufferQueueMessage(ReorderBuffer *rb, TransactionId xid,
|
696
|
+
Snapshot snap, XLogRecPtr lsn,
|
697
|
+
bool transactional, const char *prefix,
|
698
|
+
Size message_size, const char *message);
|
699
|
+
extern void ReorderBufferCommit(ReorderBuffer *rb, TransactionId xid,
|
700
|
+
XLogRecPtr commit_lsn, XLogRecPtr end_lsn,
|
701
|
+
TimestampTz commit_time, RepOriginId origin_id, XLogRecPtr origin_lsn);
|
702
|
+
extern void ReorderBufferFinishPrepared(ReorderBuffer *rb, TransactionId xid,
|
703
|
+
XLogRecPtr commit_lsn, XLogRecPtr end_lsn,
|
704
|
+
XLogRecPtr two_phase_at,
|
705
|
+
TimestampTz commit_time,
|
706
|
+
RepOriginId origin_id, XLogRecPtr origin_lsn,
|
707
|
+
char *gid, bool is_commit);
|
708
|
+
extern void ReorderBufferAssignChild(ReorderBuffer *rb, TransactionId xid,
|
709
|
+
TransactionId subxid, XLogRecPtr lsn);
|
710
|
+
extern void ReorderBufferCommitChild(ReorderBuffer *rb, TransactionId xid,
|
711
|
+
TransactionId subxid, XLogRecPtr commit_lsn,
|
712
|
+
XLogRecPtr end_lsn);
|
713
|
+
extern void ReorderBufferAbort(ReorderBuffer *rb, TransactionId xid, XLogRecPtr lsn,
|
714
|
+
TimestampTz abort_time);
|
715
|
+
extern void ReorderBufferAbortOld(ReorderBuffer *rb, TransactionId oldestRunningXid);
|
716
|
+
extern void ReorderBufferForget(ReorderBuffer *rb, TransactionId xid, XLogRecPtr lsn);
|
717
|
+
extern void ReorderBufferInvalidate(ReorderBuffer *rb, TransactionId xid, XLogRecPtr lsn);
|
718
|
+
|
719
|
+
extern void ReorderBufferSetBaseSnapshot(ReorderBuffer *rb, TransactionId xid,
|
720
|
+
XLogRecPtr lsn, Snapshot snap);
|
721
|
+
extern void ReorderBufferAddSnapshot(ReorderBuffer *rb, TransactionId xid,
|
722
|
+
XLogRecPtr lsn, Snapshot snap);
|
723
|
+
extern void ReorderBufferAddNewCommandId(ReorderBuffer *rb, TransactionId xid,
|
724
|
+
XLogRecPtr lsn, CommandId cid);
|
725
|
+
extern void ReorderBufferAddNewTupleCids(ReorderBuffer *rb, TransactionId xid,
|
726
|
+
XLogRecPtr lsn, RelFileLocator locator,
|
727
|
+
ItemPointerData tid,
|
728
|
+
CommandId cmin, CommandId cmax, CommandId combocid);
|
729
|
+
extern void ReorderBufferAddInvalidations(ReorderBuffer *rb, TransactionId xid, XLogRecPtr lsn,
|
730
|
+
Size nmsgs, SharedInvalidationMessage *msgs);
|
731
|
+
extern void ReorderBufferImmediateInvalidation(ReorderBuffer *rb, uint32 ninvalidations,
|
732
|
+
SharedInvalidationMessage *invalidations);
|
733
|
+
extern void ReorderBufferProcessXid(ReorderBuffer *rb, TransactionId xid, XLogRecPtr lsn);
|
734
|
+
|
735
|
+
extern void ReorderBufferXidSetCatalogChanges(ReorderBuffer *rb, TransactionId xid, XLogRecPtr lsn);
|
736
|
+
extern bool ReorderBufferXidHasCatalogChanges(ReorderBuffer *rb, TransactionId xid);
|
737
|
+
extern bool ReorderBufferXidHasBaseSnapshot(ReorderBuffer *rb, TransactionId xid);
|
738
|
+
|
739
|
+
extern bool ReorderBufferRememberPrepareInfo(ReorderBuffer *rb, TransactionId xid,
|
740
|
+
XLogRecPtr prepare_lsn, XLogRecPtr end_lsn,
|
741
|
+
TimestampTz prepare_time,
|
742
|
+
RepOriginId origin_id, XLogRecPtr origin_lsn);
|
743
|
+
extern void ReorderBufferSkipPrepare(ReorderBuffer *rb, TransactionId xid);
|
744
|
+
extern void ReorderBufferPrepare(ReorderBuffer *rb, TransactionId xid, char *gid);
|
745
|
+
extern ReorderBufferTXN *ReorderBufferGetOldestTXN(ReorderBuffer *rb);
|
746
|
+
extern TransactionId ReorderBufferGetOldestXmin(ReorderBuffer *rb);
|
747
|
+
extern TransactionId *ReorderBufferGetCatalogChangesXacts(ReorderBuffer *rb);
|
748
|
+
|
749
|
+
extern void ReorderBufferSetRestartPoint(ReorderBuffer *rb, XLogRecPtr ptr);
|
750
|
+
|
751
|
+
extern void StartupReorderBuffer(void);
|
752
|
+
|
753
|
+
#endif
|