gitlab-pg_query 1.3.1 → 2.0.4
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 +217 -99
- data/README.md +92 -69
- data/Rakefile +85 -5
- data/ext/pg_query/extconf.rb +3 -40
- data/ext/pg_query/guc-file.c +0 -0
- data/ext/pg_query/include/access/amapi.h +246 -0
- data/ext/pg_query/include/access/attmap.h +52 -0
- data/ext/pg_query/include/access/attnum.h +64 -0
- data/ext/pg_query/include/access/clog.h +61 -0
- data/ext/pg_query/include/access/commit_ts.h +77 -0
- data/ext/pg_query/include/access/detoast.h +92 -0
- data/ext/pg_query/include/access/genam.h +228 -0
- data/ext/pg_query/include/access/gin.h +78 -0
- data/ext/pg_query/include/access/htup.h +89 -0
- data/ext/pg_query/include/access/htup_details.h +819 -0
- data/ext/pg_query/include/access/itup.h +161 -0
- data/ext/pg_query/include/access/parallel.h +82 -0
- data/ext/pg_query/include/access/printtup.h +35 -0
- data/ext/pg_query/include/access/relation.h +28 -0
- data/ext/pg_query/include/access/relscan.h +176 -0
- data/ext/pg_query/include/access/rmgr.h +35 -0
- data/ext/pg_query/include/access/rmgrlist.h +49 -0
- data/ext/pg_query/include/access/sdir.h +58 -0
- data/ext/pg_query/include/access/skey.h +151 -0
- data/ext/pg_query/include/access/stratnum.h +83 -0
- data/ext/pg_query/include/access/sysattr.h +29 -0
- data/ext/pg_query/include/access/table.h +27 -0
- data/ext/pg_query/include/access/tableam.h +1825 -0
- data/ext/pg_query/include/access/transam.h +265 -0
- data/ext/pg_query/include/access/tupconvert.h +51 -0
- data/ext/pg_query/include/access/tupdesc.h +154 -0
- data/ext/pg_query/include/access/tupmacs.h +247 -0
- data/ext/pg_query/include/access/twophase.h +61 -0
- data/ext/pg_query/include/access/xact.h +463 -0
- data/ext/pg_query/include/access/xlog.h +398 -0
- data/ext/pg_query/include/access/xlog_internal.h +330 -0
- data/ext/pg_query/include/access/xlogdefs.h +109 -0
- data/ext/pg_query/include/access/xloginsert.h +64 -0
- data/ext/pg_query/include/access/xlogreader.h +327 -0
- data/ext/pg_query/include/access/xlogrecord.h +227 -0
- data/ext/pg_query/include/bootstrap/bootstrap.h +62 -0
- data/ext/pg_query/include/c.h +1322 -0
- data/ext/pg_query/include/catalog/catalog.h +42 -0
- data/ext/pg_query/include/catalog/catversion.h +58 -0
- data/ext/pg_query/include/catalog/dependency.h +275 -0
- data/ext/pg_query/include/catalog/genbki.h +64 -0
- data/ext/pg_query/include/catalog/index.h +199 -0
- data/ext/pg_query/include/catalog/indexing.h +366 -0
- data/ext/pg_query/include/catalog/namespace.h +188 -0
- data/ext/pg_query/include/catalog/objectaccess.h +197 -0
- data/ext/pg_query/include/catalog/objectaddress.h +84 -0
- data/ext/pg_query/include/catalog/pg_aggregate.h +176 -0
- data/ext/pg_query/include/catalog/pg_aggregate_d.h +77 -0
- data/ext/pg_query/include/catalog/pg_am.h +60 -0
- data/ext/pg_query/include/catalog/pg_am_d.h +45 -0
- data/ext/pg_query/include/catalog/pg_attribute.h +204 -0
- data/ext/pg_query/include/catalog/pg_attribute_d.h +59 -0
- data/ext/pg_query/include/catalog/pg_authid.h +58 -0
- data/ext/pg_query/include/catalog/pg_authid_d.h +49 -0
- data/ext/pg_query/include/catalog/pg_class.h +200 -0
- data/ext/pg_query/include/catalog/pg_class_d.h +103 -0
- data/ext/pg_query/include/catalog/pg_collation.h +73 -0
- data/ext/pg_query/include/catalog/pg_collation_d.h +45 -0
- data/ext/pg_query/include/catalog/pg_constraint.h +247 -0
- data/ext/pg_query/include/catalog/pg_constraint_d.h +67 -0
- data/ext/pg_query/include/catalog/pg_control.h +250 -0
- data/ext/pg_query/include/catalog/pg_conversion.h +72 -0
- data/ext/pg_query/include/catalog/pg_conversion_d.h +35 -0
- data/ext/pg_query/include/catalog/pg_depend.h +73 -0
- data/ext/pg_query/include/catalog/pg_depend_d.h +34 -0
- data/ext/pg_query/include/catalog/pg_event_trigger.h +51 -0
- data/ext/pg_query/include/catalog/pg_event_trigger_d.h +34 -0
- data/ext/pg_query/include/catalog/pg_index.h +80 -0
- data/ext/pg_query/include/catalog/pg_index_d.h +56 -0
- data/ext/pg_query/include/catalog/pg_language.h +67 -0
- data/ext/pg_query/include/catalog/pg_language_d.h +39 -0
- data/ext/pg_query/include/catalog/pg_namespace.h +59 -0
- data/ext/pg_query/include/catalog/pg_namespace_d.h +34 -0
- data/ext/pg_query/include/catalog/pg_opclass.h +85 -0
- data/ext/pg_query/include/catalog/pg_opclass_d.h +49 -0
- data/ext/pg_query/include/catalog/pg_operator.h +102 -0
- data/ext/pg_query/include/catalog/pg_operator_d.h +106 -0
- data/ext/pg_query/include/catalog/pg_opfamily.h +60 -0
- data/ext/pg_query/include/catalog/pg_opfamily_d.h +47 -0
- data/ext/pg_query/include/catalog/pg_partitioned_table.h +63 -0
- data/ext/pg_query/include/catalog/pg_partitioned_table_d.h +35 -0
- data/ext/pg_query/include/catalog/pg_proc.h +211 -0
- data/ext/pg_query/include/catalog/pg_proc_d.h +99 -0
- data/ext/pg_query/include/catalog/pg_publication.h +115 -0
- data/ext/pg_query/include/catalog/pg_publication_d.h +36 -0
- data/ext/pg_query/include/catalog/pg_replication_origin.h +57 -0
- data/ext/pg_query/include/catalog/pg_replication_origin_d.h +29 -0
- data/ext/pg_query/include/catalog/pg_statistic.h +275 -0
- data/ext/pg_query/include/catalog/pg_statistic_d.h +194 -0
- data/ext/pg_query/include/catalog/pg_statistic_ext.h +74 -0
- data/ext/pg_query/include/catalog/pg_statistic_ext_d.h +40 -0
- data/ext/pg_query/include/catalog/pg_transform.h +45 -0
- data/ext/pg_query/include/catalog/pg_transform_d.h +32 -0
- data/ext/pg_query/include/catalog/pg_trigger.h +137 -0
- data/ext/pg_query/include/catalog/pg_trigger_d.h +106 -0
- data/ext/pg_query/include/catalog/pg_ts_config.h +50 -0
- data/ext/pg_query/include/catalog/pg_ts_config_d.h +32 -0
- data/ext/pg_query/include/catalog/pg_ts_dict.h +54 -0
- data/ext/pg_query/include/catalog/pg_ts_dict_d.h +33 -0
- data/ext/pg_query/include/catalog/pg_ts_parser.h +57 -0
- data/ext/pg_query/include/catalog/pg_ts_parser_d.h +35 -0
- data/ext/pg_query/include/catalog/pg_ts_template.h +48 -0
- data/ext/pg_query/include/catalog/pg_ts_template_d.h +32 -0
- data/ext/pg_query/include/catalog/pg_type.h +372 -0
- data/ext/pg_query/include/catalog/pg_type_d.h +285 -0
- data/ext/pg_query/include/catalog/storage.h +48 -0
- data/ext/pg_query/include/commands/async.h +54 -0
- data/ext/pg_query/include/commands/dbcommands.h +35 -0
- data/ext/pg_query/include/commands/defrem.h +173 -0
- data/ext/pg_query/include/commands/event_trigger.h +88 -0
- data/ext/pg_query/include/commands/explain.h +127 -0
- data/ext/pg_query/include/commands/prepare.h +61 -0
- data/ext/pg_query/include/commands/tablespace.h +67 -0
- data/ext/pg_query/include/commands/trigger.h +277 -0
- data/ext/pg_query/include/commands/user.h +37 -0
- data/ext/pg_query/include/commands/vacuum.h +293 -0
- data/ext/pg_query/include/commands/variable.h +38 -0
- data/ext/pg_query/include/common/file_perm.h +56 -0
- data/ext/pg_query/include/common/hashfn.h +104 -0
- data/ext/pg_query/include/common/ip.h +37 -0
- data/ext/pg_query/include/common/keywords.h +33 -0
- data/ext/pg_query/include/common/kwlookup.h +44 -0
- data/ext/pg_query/include/common/relpath.h +90 -0
- data/ext/pg_query/include/common/string.h +19 -0
- data/ext/pg_query/include/common/unicode_combining_table.h +196 -0
- data/ext/pg_query/include/datatype/timestamp.h +197 -0
- data/ext/pg_query/include/executor/execdesc.h +70 -0
- data/ext/pg_query/include/executor/executor.h +614 -0
- data/ext/pg_query/include/executor/functions.h +41 -0
- data/ext/pg_query/include/executor/instrument.h +101 -0
- data/ext/pg_query/include/executor/spi.h +175 -0
- data/ext/pg_query/include/executor/tablefunc.h +67 -0
- data/ext/pg_query/include/executor/tuptable.h +487 -0
- data/ext/pg_query/include/fmgr.h +775 -0
- data/ext/pg_query/include/funcapi.h +348 -0
- data/ext/pg_query/include/getaddrinfo.h +162 -0
- data/ext/pg_query/include/jit/jit.h +105 -0
- data/ext/pg_query/include/kwlist_d.h +1072 -0
- data/ext/pg_query/include/lib/ilist.h +727 -0
- data/ext/pg_query/include/lib/pairingheap.h +102 -0
- data/ext/pg_query/include/lib/simplehash.h +1059 -0
- data/ext/pg_query/include/lib/stringinfo.h +161 -0
- data/ext/pg_query/include/libpq/auth.h +29 -0
- data/ext/pg_query/include/libpq/crypt.h +46 -0
- data/ext/pg_query/include/libpq/hba.h +140 -0
- data/ext/pg_query/include/libpq/libpq-be.h +326 -0
- data/ext/pg_query/include/libpq/libpq.h +133 -0
- data/ext/pg_query/include/libpq/pqcomm.h +208 -0
- data/ext/pg_query/include/libpq/pqformat.h +210 -0
- data/ext/pg_query/include/libpq/pqsignal.h +42 -0
- data/ext/pg_query/include/mb/pg_wchar.h +672 -0
- data/ext/pg_query/include/mb/stringinfo_mb.h +24 -0
- data/ext/pg_query/include/miscadmin.h +476 -0
- data/ext/pg_query/include/nodes/bitmapset.h +122 -0
- data/ext/pg_query/include/nodes/execnodes.h +2520 -0
- data/ext/pg_query/include/nodes/extensible.h +160 -0
- data/ext/pg_query/include/nodes/lockoptions.h +61 -0
- data/ext/pg_query/include/nodes/makefuncs.h +108 -0
- data/ext/pg_query/include/nodes/memnodes.h +108 -0
- data/ext/pg_query/include/nodes/nodeFuncs.h +162 -0
- data/ext/pg_query/include/nodes/nodes.h +842 -0
- data/ext/pg_query/include/nodes/params.h +170 -0
- data/ext/pg_query/include/nodes/parsenodes.h +3579 -0
- data/ext/pg_query/include/nodes/pathnodes.h +2556 -0
- data/ext/pg_query/include/nodes/pg_list.h +605 -0
- data/ext/pg_query/include/nodes/plannodes.h +1251 -0
- data/ext/pg_query/include/nodes/primnodes.h +1541 -0
- data/ext/pg_query/include/nodes/print.h +34 -0
- data/ext/pg_query/include/nodes/tidbitmap.h +75 -0
- data/ext/pg_query/include/nodes/value.h +61 -0
- data/ext/pg_query/include/optimizer/cost.h +206 -0
- data/ext/pg_query/include/optimizer/geqo.h +88 -0
- data/ext/pg_query/include/optimizer/geqo_gene.h +45 -0
- data/ext/pg_query/include/optimizer/optimizer.h +199 -0
- data/ext/pg_query/include/optimizer/paths.h +249 -0
- data/ext/pg_query/include/optimizer/planmain.h +119 -0
- data/ext/pg_query/include/parser/analyze.h +49 -0
- data/ext/pg_query/include/parser/gram.h +1067 -0
- data/ext/pg_query/include/parser/gramparse.h +75 -0
- data/ext/pg_query/include/parser/kwlist.h +477 -0
- data/ext/pg_query/include/parser/parse_agg.h +68 -0
- data/ext/pg_query/include/parser/parse_clause.h +54 -0
- data/ext/pg_query/include/parser/parse_coerce.h +97 -0
- data/ext/pg_query/include/parser/parse_collate.h +27 -0
- data/ext/pg_query/include/parser/parse_expr.h +26 -0
- data/ext/pg_query/include/parser/parse_func.h +73 -0
- data/ext/pg_query/include/parser/parse_node.h +327 -0
- data/ext/pg_query/include/parser/parse_oper.h +67 -0
- data/ext/pg_query/include/parser/parse_relation.h +123 -0
- data/ext/pg_query/include/parser/parse_target.h +46 -0
- data/ext/pg_query/include/parser/parse_type.h +60 -0
- data/ext/pg_query/include/parser/parser.h +41 -0
- data/ext/pg_query/include/parser/parsetree.h +61 -0
- data/ext/pg_query/include/parser/scanner.h +152 -0
- data/ext/pg_query/include/parser/scansup.h +30 -0
- data/ext/pg_query/include/partitioning/partdefs.h +26 -0
- data/ext/pg_query/include/pg_config.h +989 -0
- data/ext/pg_query/include/pg_config_ext.h +8 -0
- data/ext/pg_query/include/pg_config_manual.h +350 -0
- data/ext/pg_query/include/pg_config_os.h +8 -0
- data/ext/pg_query/include/pg_getopt.h +56 -0
- data/ext/pg_query/include/pg_query.h +121 -0
- data/ext/pg_query/include/pg_query_enum_defs.c +2454 -0
- data/ext/pg_query/include/pg_query_fingerprint_conds.c +875 -0
- data/ext/pg_query/include/pg_query_fingerprint_defs.c +12413 -0
- data/ext/pg_query/include/pg_query_json_helper.c +61 -0
- data/ext/pg_query/include/pg_query_outfuncs_conds.c +686 -0
- data/ext/pg_query/include/pg_query_outfuncs_defs.c +2437 -0
- data/ext/pg_query/include/pg_query_readfuncs_conds.c +222 -0
- data/ext/pg_query/include/pg_query_readfuncs_defs.c +2878 -0
- data/ext/pg_query/include/pg_trace.h +17 -0
- data/ext/pg_query/include/pgstat.h +1487 -0
- data/ext/pg_query/include/pgtime.h +84 -0
- data/ext/pg_query/include/pl_gram.h +385 -0
- data/ext/pg_query/include/pl_reserved_kwlist.h +52 -0
- data/ext/pg_query/include/pl_reserved_kwlist_d.h +114 -0
- data/ext/pg_query/include/pl_unreserved_kwlist.h +112 -0
- data/ext/pg_query/include/pl_unreserved_kwlist_d.h +246 -0
- data/ext/pg_query/include/plerrcodes.h +990 -0
- data/ext/pg_query/include/plpgsql.h +1347 -0
- data/ext/pg_query/include/port.h +524 -0
- data/ext/pg_query/include/port/atomics.h +524 -0
- data/ext/pg_query/include/port/atomics/arch-arm.h +26 -0
- data/ext/pg_query/include/port/atomics/arch-ppc.h +254 -0
- data/ext/pg_query/include/port/atomics/arch-x86.h +252 -0
- data/ext/pg_query/include/port/atomics/fallback.h +170 -0
- data/ext/pg_query/include/port/atomics/generic-gcc.h +286 -0
- data/ext/pg_query/include/port/atomics/generic.h +401 -0
- data/ext/pg_query/include/port/pg_bitutils.h +226 -0
- data/ext/pg_query/include/port/pg_bswap.h +161 -0
- data/ext/pg_query/include/port/pg_crc32c.h +101 -0
- data/ext/pg_query/include/portability/instr_time.h +256 -0
- data/ext/pg_query/include/postgres.h +764 -0
- data/ext/pg_query/include/postgres_ext.h +74 -0
- data/ext/pg_query/include/postmaster/autovacuum.h +83 -0
- data/ext/pg_query/include/postmaster/bgworker.h +161 -0
- data/ext/pg_query/include/postmaster/bgworker_internals.h +64 -0
- data/ext/pg_query/include/postmaster/bgwriter.h +45 -0
- data/ext/pg_query/include/postmaster/fork_process.h +17 -0
- data/ext/pg_query/include/postmaster/interrupt.h +32 -0
- data/ext/pg_query/include/postmaster/pgarch.h +39 -0
- data/ext/pg_query/include/postmaster/postmaster.h +77 -0
- data/ext/pg_query/include/postmaster/syslogger.h +98 -0
- data/ext/pg_query/include/postmaster/walwriter.h +21 -0
- data/ext/pg_query/include/protobuf-c.h +1106 -0
- data/ext/pg_query/include/protobuf-c/protobuf-c.h +1106 -0
- data/ext/pg_query/include/protobuf/pg_query.pb-c.h +10846 -0
- data/ext/pg_query/include/protobuf/pg_query.pb.h +124718 -0
- data/ext/pg_query/include/regex/regex.h +184 -0
- data/ext/pg_query/include/replication/logicallauncher.h +31 -0
- data/ext/pg_query/include/replication/logicalproto.h +110 -0
- data/ext/pg_query/include/replication/logicalworker.h +19 -0
- data/ext/pg_query/include/replication/origin.h +73 -0
- data/ext/pg_query/include/replication/reorderbuffer.h +467 -0
- data/ext/pg_query/include/replication/slot.h +219 -0
- data/ext/pg_query/include/replication/syncrep.h +115 -0
- data/ext/pg_query/include/replication/walreceiver.h +340 -0
- data/ext/pg_query/include/replication/walsender.h +74 -0
- data/ext/pg_query/include/rewrite/prs2lock.h +46 -0
- data/ext/pg_query/include/rewrite/rewriteHandler.h +40 -0
- data/ext/pg_query/include/rewrite/rewriteManip.h +87 -0
- data/ext/pg_query/include/rewrite/rewriteSupport.h +26 -0
- data/ext/pg_query/include/storage/backendid.h +37 -0
- data/ext/pg_query/include/storage/block.h +121 -0
- data/ext/pg_query/include/storage/buf.h +46 -0
- data/ext/pg_query/include/storage/bufmgr.h +292 -0
- data/ext/pg_query/include/storage/bufpage.h +459 -0
- data/ext/pg_query/include/storage/condition_variable.h +62 -0
- data/ext/pg_query/include/storage/dsm.h +61 -0
- data/ext/pg_query/include/storage/dsm_impl.h +75 -0
- data/ext/pg_query/include/storage/fd.h +168 -0
- data/ext/pg_query/include/storage/ipc.h +81 -0
- data/ext/pg_query/include/storage/item.h +19 -0
- data/ext/pg_query/include/storage/itemid.h +184 -0
- data/ext/pg_query/include/storage/itemptr.h +206 -0
- data/ext/pg_query/include/storage/large_object.h +100 -0
- data/ext/pg_query/include/storage/latch.h +190 -0
- data/ext/pg_query/include/storage/lmgr.h +114 -0
- data/ext/pg_query/include/storage/lock.h +612 -0
- data/ext/pg_query/include/storage/lockdefs.h +59 -0
- data/ext/pg_query/include/storage/lwlock.h +232 -0
- data/ext/pg_query/include/storage/lwlocknames.h +51 -0
- data/ext/pg_query/include/storage/off.h +57 -0
- data/ext/pg_query/include/storage/pg_sema.h +61 -0
- data/ext/pg_query/include/storage/pg_shmem.h +90 -0
- data/ext/pg_query/include/storage/pmsignal.h +94 -0
- data/ext/pg_query/include/storage/predicate.h +87 -0
- data/ext/pg_query/include/storage/proc.h +333 -0
- data/ext/pg_query/include/storage/proclist_types.h +51 -0
- data/ext/pg_query/include/storage/procsignal.h +75 -0
- data/ext/pg_query/include/storage/relfilenode.h +99 -0
- data/ext/pg_query/include/storage/s_lock.h +1047 -0
- data/ext/pg_query/include/storage/sharedfileset.h +45 -0
- data/ext/pg_query/include/storage/shm_mq.h +85 -0
- data/ext/pg_query/include/storage/shm_toc.h +58 -0
- data/ext/pg_query/include/storage/shmem.h +81 -0
- data/ext/pg_query/include/storage/sinval.h +153 -0
- data/ext/pg_query/include/storage/sinvaladt.h +43 -0
- data/ext/pg_query/include/storage/smgr.h +109 -0
- data/ext/pg_query/include/storage/spin.h +77 -0
- data/ext/pg_query/include/storage/standby.h +91 -0
- data/ext/pg_query/include/storage/standbydefs.h +74 -0
- data/ext/pg_query/include/storage/sync.h +62 -0
- data/ext/pg_query/include/tcop/cmdtag.h +58 -0
- data/ext/pg_query/include/tcop/cmdtaglist.h +217 -0
- data/ext/pg_query/include/tcop/deparse_utility.h +108 -0
- data/ext/pg_query/include/tcop/dest.h +149 -0
- data/ext/pg_query/include/tcop/fastpath.h +21 -0
- data/ext/pg_query/include/tcop/pquery.h +45 -0
- data/ext/pg_query/include/tcop/tcopprot.h +89 -0
- data/ext/pg_query/include/tcop/utility.h +108 -0
- data/ext/pg_query/include/tsearch/ts_cache.h +98 -0
- data/ext/pg_query/include/utils/acl.h +312 -0
- data/ext/pg_query/include/utils/aclchk_internal.h +45 -0
- data/ext/pg_query/include/utils/array.h +458 -0
- data/ext/pg_query/include/utils/builtins.h +127 -0
- data/ext/pg_query/include/utils/bytea.h +27 -0
- data/ext/pg_query/include/utils/catcache.h +231 -0
- data/ext/pg_query/include/utils/date.h +90 -0
- data/ext/pg_query/include/utils/datetime.h +343 -0
- data/ext/pg_query/include/utils/datum.h +68 -0
- data/ext/pg_query/include/utils/dsa.h +123 -0
- data/ext/pg_query/include/utils/dynahash.h +19 -0
- data/ext/pg_query/include/utils/elog.h +439 -0
- data/ext/pg_query/include/utils/errcodes.h +352 -0
- data/ext/pg_query/include/utils/expandeddatum.h +159 -0
- data/ext/pg_query/include/utils/expandedrecord.h +231 -0
- data/ext/pg_query/include/utils/float.h +356 -0
- data/ext/pg_query/include/utils/fmgroids.h +2657 -0
- data/ext/pg_query/include/utils/fmgrprotos.h +2646 -0
- data/ext/pg_query/include/utils/fmgrtab.h +48 -0
- data/ext/pg_query/include/utils/guc.h +443 -0
- data/ext/pg_query/include/utils/guc_tables.h +272 -0
- data/ext/pg_query/include/utils/hsearch.h +149 -0
- data/ext/pg_query/include/utils/inval.h +64 -0
- data/ext/pg_query/include/utils/lsyscache.h +197 -0
- data/ext/pg_query/include/utils/memdebug.h +82 -0
- data/ext/pg_query/include/utils/memutils.h +225 -0
- data/ext/pg_query/include/utils/numeric.h +76 -0
- data/ext/pg_query/include/utils/palloc.h +136 -0
- data/ext/pg_query/include/utils/partcache.h +102 -0
- data/ext/pg_query/include/utils/pg_locale.h +119 -0
- data/ext/pg_query/include/utils/pg_lsn.h +29 -0
- data/ext/pg_query/include/utils/pidfile.h +56 -0
- data/ext/pg_query/include/utils/plancache.h +235 -0
- data/ext/pg_query/include/utils/portal.h +241 -0
- data/ext/pg_query/include/utils/probes.h +114 -0
- data/ext/pg_query/include/utils/ps_status.h +25 -0
- data/ext/pg_query/include/utils/queryenvironment.h +74 -0
- data/ext/pg_query/include/utils/regproc.h +28 -0
- data/ext/pg_query/include/utils/rel.h +644 -0
- data/ext/pg_query/include/utils/relcache.h +151 -0
- data/ext/pg_query/include/utils/reltrigger.h +81 -0
- data/ext/pg_query/include/utils/resowner.h +86 -0
- data/ext/pg_query/include/utils/rls.h +50 -0
- data/ext/pg_query/include/utils/ruleutils.h +44 -0
- data/ext/pg_query/include/utils/sharedtuplestore.h +61 -0
- data/ext/pg_query/include/utils/snapmgr.h +158 -0
- data/ext/pg_query/include/utils/snapshot.h +206 -0
- data/ext/pg_query/include/utils/sortsupport.h +276 -0
- data/ext/pg_query/include/utils/syscache.h +219 -0
- data/ext/pg_query/include/utils/timeout.h +88 -0
- data/ext/pg_query/include/utils/timestamp.h +116 -0
- data/ext/pg_query/include/utils/tuplesort.h +277 -0
- data/ext/pg_query/include/utils/tuplestore.h +91 -0
- data/ext/pg_query/include/utils/typcache.h +202 -0
- data/ext/pg_query/include/utils/tzparser.h +39 -0
- data/ext/pg_query/include/utils/varlena.h +39 -0
- data/ext/pg_query/include/utils/xml.h +84 -0
- data/ext/pg_query/include/xxhash.h +5445 -0
- data/ext/pg_query/include/xxhash/xxhash.h +5445 -0
- data/ext/pg_query/pg_query.c +104 -0
- data/ext/pg_query/pg_query.pb-c.c +37628 -0
- data/ext/pg_query/pg_query_deparse.c +9959 -0
- data/ext/pg_query/pg_query_fingerprint.c +295 -0
- data/ext/pg_query/pg_query_fingerprint.h +8 -0
- data/ext/pg_query/pg_query_internal.h +24 -0
- data/ext/pg_query/pg_query_json_plpgsql.c +738 -0
- data/ext/pg_query/pg_query_json_plpgsql.h +9 -0
- data/ext/pg_query/pg_query_normalize.c +439 -0
- data/ext/pg_query/pg_query_outfuncs.h +10 -0
- data/ext/pg_query/pg_query_outfuncs_json.c +297 -0
- data/ext/pg_query/pg_query_outfuncs_protobuf.c +237 -0
- data/ext/pg_query/pg_query_parse.c +148 -0
- data/ext/pg_query/pg_query_parse_plpgsql.c +460 -0
- data/ext/pg_query/pg_query_readfuncs.h +11 -0
- data/ext/pg_query/pg_query_readfuncs_protobuf.c +142 -0
- data/ext/pg_query/pg_query_ruby.c +108 -12
- data/ext/pg_query/pg_query_scan.c +173 -0
- data/ext/pg_query/pg_query_split.c +221 -0
- data/ext/pg_query/protobuf-c.c +3660 -0
- data/ext/pg_query/src_backend_catalog_namespace.c +1051 -0
- data/ext/pg_query/src_backend_catalog_pg_proc.c +142 -0
- data/ext/pg_query/src_backend_commands_define.c +117 -0
- data/ext/pg_query/src_backend_libpq_pqcomm.c +651 -0
- data/ext/pg_query/src_backend_nodes_bitmapset.c +513 -0
- data/ext/pg_query/src_backend_nodes_copyfuncs.c +6013 -0
- data/ext/pg_query/src_backend_nodes_equalfuncs.c +4003 -0
- data/ext/pg_query/src_backend_nodes_extensible.c +99 -0
- data/ext/pg_query/src_backend_nodes_list.c +922 -0
- data/ext/pg_query/src_backend_nodes_makefuncs.c +417 -0
- data/ext/pg_query/src_backend_nodes_nodeFuncs.c +1363 -0
- data/ext/pg_query/src_backend_nodes_value.c +84 -0
- data/ext/pg_query/src_backend_parser_gram.c +47456 -0
- data/ext/pg_query/src_backend_parser_parse_expr.c +313 -0
- data/ext/pg_query/src_backend_parser_parser.c +497 -0
- data/ext/pg_query/src_backend_parser_scan.c +7091 -0
- data/ext/pg_query/src_backend_parser_scansup.c +160 -0
- data/ext/pg_query/src_backend_postmaster_postmaster.c +2230 -0
- data/ext/pg_query/src_backend_storage_ipc_ipc.c +192 -0
- data/ext/pg_query/src_backend_storage_lmgr_s_lock.c +370 -0
- data/ext/pg_query/src_backend_tcop_postgres.c +776 -0
- data/ext/pg_query/src_backend_utils_adt_datum.c +326 -0
- data/ext/pg_query/src_backend_utils_adt_expandeddatum.c +98 -0
- data/ext/pg_query/src_backend_utils_adt_format_type.c +136 -0
- data/ext/pg_query/src_backend_utils_adt_ruleutils.c +1683 -0
- data/ext/pg_query/src_backend_utils_error_assert.c +74 -0
- data/ext/pg_query/src_backend_utils_error_elog.c +1748 -0
- data/ext/pg_query/src_backend_utils_fmgr_fmgr.c +570 -0
- data/ext/pg_query/src_backend_utils_hash_dynahash.c +1086 -0
- data/ext/pg_query/src_backend_utils_init_globals.c +168 -0
- data/ext/pg_query/src_backend_utils_mb_mbutils.c +839 -0
- data/ext/pg_query/src_backend_utils_misc_guc.c +1831 -0
- data/ext/pg_query/src_backend_utils_mmgr_aset.c +1560 -0
- data/ext/pg_query/src_backend_utils_mmgr_mcxt.c +1006 -0
- data/ext/pg_query/src_common_encnames.c +158 -0
- data/ext/pg_query/src_common_keywords.c +39 -0
- data/ext/pg_query/src_common_kwlist_d.h +1081 -0
- data/ext/pg_query/src_common_kwlookup.c +91 -0
- data/ext/pg_query/src_common_psprintf.c +158 -0
- data/ext/pg_query/src_common_string.c +86 -0
- data/ext/pg_query/src_common_stringinfo.c +336 -0
- data/ext/pg_query/src_common_wchar.c +1651 -0
- data/ext/pg_query/src_pl_plpgsql_src_pl_comp.c +1133 -0
- data/ext/pg_query/src_pl_plpgsql_src_pl_funcs.c +877 -0
- data/ext/pg_query/src_pl_plpgsql_src_pl_gram.c +6533 -0
- data/ext/pg_query/src_pl_plpgsql_src_pl_handler.c +107 -0
- data/ext/pg_query/src_pl_plpgsql_src_pl_reserved_kwlist_d.h +123 -0
- data/ext/pg_query/src_pl_plpgsql_src_pl_scanner.c +671 -0
- data/ext/pg_query/src_pl_plpgsql_src_pl_unreserved_kwlist_d.h +255 -0
- data/ext/pg_query/src_port_erand48.c +127 -0
- data/ext/pg_query/src_port_pg_bitutils.c +246 -0
- data/ext/pg_query/src_port_pgsleep.c +69 -0
- data/ext/pg_query/src_port_pgstrcasecmp.c +83 -0
- data/ext/pg_query/src_port_qsort.c +240 -0
- data/ext/pg_query/src_port_random.c +31 -0
- data/ext/pg_query/src_port_snprintf.c +1449 -0
- data/ext/pg_query/src_port_strerror.c +324 -0
- data/ext/pg_query/src_port_strnlen.c +39 -0
- data/ext/pg_query/xxhash.c +43 -0
- data/lib/pg_query.rb +7 -4
- data/lib/pg_query/constants.rb +21 -0
- data/lib/pg_query/deparse.rb +15 -1581
- data/lib/pg_query/filter_columns.rb +88 -85
- data/lib/pg_query/fingerprint.rb +122 -87
- data/lib/pg_query/json_field_names.rb +1402 -0
- data/lib/pg_query/node.rb +31 -0
- data/lib/pg_query/param_refs.rb +42 -37
- data/lib/pg_query/parse.rb +220 -203
- data/lib/pg_query/parse_error.rb +1 -1
- data/lib/pg_query/pg_query_pb.rb +3211 -0
- data/lib/pg_query/scan.rb +23 -0
- data/lib/pg_query/treewalker.rb +24 -40
- data/lib/pg_query/truncate.rb +71 -42
- data/lib/pg_query/version.rb +2 -2
- metadata +472 -11
- data/ext/pg_query/pg_query_ruby.h +0 -10
- data/lib/pg_query/deep_dup.rb +0 -16
- data/lib/pg_query/deparse/alter_table.rb +0 -42
- data/lib/pg_query/deparse/interval.rb +0 -105
- data/lib/pg_query/deparse/keywords.rb +0 -159
- data/lib/pg_query/deparse/rename.rb +0 -41
- data/lib/pg_query/legacy_parsetree.rb +0 -109
- data/lib/pg_query/node_types.rb +0 -296
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
/*-------------------------------------------------------------------------
|
|
2
|
+
*
|
|
3
|
+
* attmap.h
|
|
4
|
+
* Definitions for PostgreSQL attribute mappings
|
|
5
|
+
*
|
|
6
|
+
*
|
|
7
|
+
* Portions Copyright (c) 1996-2020, PostgreSQL Global Development Group
|
|
8
|
+
* Portions Copyright (c) 1994, Regents of the University of California
|
|
9
|
+
*
|
|
10
|
+
* src/include/access/attmap.h
|
|
11
|
+
*
|
|
12
|
+
*-------------------------------------------------------------------------
|
|
13
|
+
*/
|
|
14
|
+
#ifndef ATTMAP_H
|
|
15
|
+
#define ATTMAP_H
|
|
16
|
+
|
|
17
|
+
#include "access/attnum.h"
|
|
18
|
+
#include "access/tupdesc.h"
|
|
19
|
+
|
|
20
|
+
/*
|
|
21
|
+
* Attribute mapping structure
|
|
22
|
+
*
|
|
23
|
+
* This maps attribute numbers between a pair of relations, designated
|
|
24
|
+
* 'input' and 'output' (most typically inheritance parent and child
|
|
25
|
+
* relations), whose common columns may have different attribute numbers.
|
|
26
|
+
* Such difference may arise due to the columns being ordered differently
|
|
27
|
+
* in the two relations or the two relations having dropped columns at
|
|
28
|
+
* different positions.
|
|
29
|
+
*
|
|
30
|
+
* 'maplen' is set to the number of attributes of the 'output' relation,
|
|
31
|
+
* taking into account any of its dropped attributes, with the corresponding
|
|
32
|
+
* elements of the 'attnums' array set to 0.
|
|
33
|
+
*/
|
|
34
|
+
typedef struct AttrMap
|
|
35
|
+
{
|
|
36
|
+
AttrNumber *attnums;
|
|
37
|
+
int maplen;
|
|
38
|
+
} AttrMap;
|
|
39
|
+
|
|
40
|
+
extern AttrMap *make_attrmap(int maplen);
|
|
41
|
+
extern void free_attrmap(AttrMap *map);
|
|
42
|
+
|
|
43
|
+
/* Conversion routines to build mappings */
|
|
44
|
+
extern AttrMap *build_attrmap_by_name(TupleDesc indesc,
|
|
45
|
+
TupleDesc outdesc);
|
|
46
|
+
extern AttrMap *build_attrmap_by_name_if_req(TupleDesc indesc,
|
|
47
|
+
TupleDesc outdesc);
|
|
48
|
+
extern AttrMap *build_attrmap_by_position(TupleDesc indesc,
|
|
49
|
+
TupleDesc outdesc,
|
|
50
|
+
const char *msg);
|
|
51
|
+
|
|
52
|
+
#endif /* ATTMAP_H */
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
/*-------------------------------------------------------------------------
|
|
2
|
+
*
|
|
3
|
+
* attnum.h
|
|
4
|
+
* POSTGRES attribute number definitions.
|
|
5
|
+
*
|
|
6
|
+
*
|
|
7
|
+
* Portions Copyright (c) 1996-2020, PostgreSQL Global Development Group
|
|
8
|
+
* Portions Copyright (c) 1994, Regents of the University of California
|
|
9
|
+
*
|
|
10
|
+
* src/include/access/attnum.h
|
|
11
|
+
*
|
|
12
|
+
*-------------------------------------------------------------------------
|
|
13
|
+
*/
|
|
14
|
+
#ifndef ATTNUM_H
|
|
15
|
+
#define ATTNUM_H
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
/*
|
|
19
|
+
* user defined attribute numbers start at 1. -ay 2/95
|
|
20
|
+
*/
|
|
21
|
+
typedef int16 AttrNumber;
|
|
22
|
+
|
|
23
|
+
#define InvalidAttrNumber 0
|
|
24
|
+
#define MaxAttrNumber 32767
|
|
25
|
+
|
|
26
|
+
/* ----------------
|
|
27
|
+
* support macros
|
|
28
|
+
* ----------------
|
|
29
|
+
*/
|
|
30
|
+
/*
|
|
31
|
+
* AttributeNumberIsValid
|
|
32
|
+
* True iff the attribute number is valid.
|
|
33
|
+
*/
|
|
34
|
+
#define AttributeNumberIsValid(attributeNumber) \
|
|
35
|
+
((bool) ((attributeNumber) != InvalidAttrNumber))
|
|
36
|
+
|
|
37
|
+
/*
|
|
38
|
+
* AttrNumberIsForUserDefinedAttr
|
|
39
|
+
* True iff the attribute number corresponds to an user defined attribute.
|
|
40
|
+
*/
|
|
41
|
+
#define AttrNumberIsForUserDefinedAttr(attributeNumber) \
|
|
42
|
+
((bool) ((attributeNumber) > 0))
|
|
43
|
+
|
|
44
|
+
/*
|
|
45
|
+
* AttrNumberGetAttrOffset
|
|
46
|
+
* Returns the attribute offset for an attribute number.
|
|
47
|
+
*
|
|
48
|
+
* Note:
|
|
49
|
+
* Assumes the attribute number is for a user defined attribute.
|
|
50
|
+
*/
|
|
51
|
+
#define AttrNumberGetAttrOffset(attNum) \
|
|
52
|
+
( \
|
|
53
|
+
AssertMacro(AttrNumberIsForUserDefinedAttr(attNum)), \
|
|
54
|
+
((attNum) - 1) \
|
|
55
|
+
)
|
|
56
|
+
|
|
57
|
+
/*
|
|
58
|
+
* AttrOffsetGetAttrNumber
|
|
59
|
+
* Returns the attribute number for an attribute offset.
|
|
60
|
+
*/
|
|
61
|
+
#define AttrOffsetGetAttrNumber(attributeOffset) \
|
|
62
|
+
((AttrNumber) (1 + (attributeOffset)))
|
|
63
|
+
|
|
64
|
+
#endif /* ATTNUM_H */
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* clog.h
|
|
3
|
+
*
|
|
4
|
+
* PostgreSQL transaction-commit-log manager
|
|
5
|
+
*
|
|
6
|
+
* Portions Copyright (c) 1996-2020, PostgreSQL Global Development Group
|
|
7
|
+
* Portions Copyright (c) 1994, Regents of the University of California
|
|
8
|
+
*
|
|
9
|
+
* src/include/access/clog.h
|
|
10
|
+
*/
|
|
11
|
+
#ifndef CLOG_H
|
|
12
|
+
#define CLOG_H
|
|
13
|
+
|
|
14
|
+
#include "access/xlogreader.h"
|
|
15
|
+
#include "lib/stringinfo.h"
|
|
16
|
+
|
|
17
|
+
/*
|
|
18
|
+
* Possible transaction statuses --- note that all-zeroes is the initial
|
|
19
|
+
* state.
|
|
20
|
+
*
|
|
21
|
+
* A "subcommitted" transaction is a committed subtransaction whose parent
|
|
22
|
+
* hasn't committed or aborted yet.
|
|
23
|
+
*/
|
|
24
|
+
typedef int XidStatus;
|
|
25
|
+
|
|
26
|
+
#define TRANSACTION_STATUS_IN_PROGRESS 0x00
|
|
27
|
+
#define TRANSACTION_STATUS_COMMITTED 0x01
|
|
28
|
+
#define TRANSACTION_STATUS_ABORTED 0x02
|
|
29
|
+
#define TRANSACTION_STATUS_SUB_COMMITTED 0x03
|
|
30
|
+
|
|
31
|
+
typedef struct xl_clog_truncate
|
|
32
|
+
{
|
|
33
|
+
int pageno;
|
|
34
|
+
TransactionId oldestXact;
|
|
35
|
+
Oid oldestXactDb;
|
|
36
|
+
} xl_clog_truncate;
|
|
37
|
+
|
|
38
|
+
extern void TransactionIdSetTreeStatus(TransactionId xid, int nsubxids,
|
|
39
|
+
TransactionId *subxids, XidStatus status, XLogRecPtr lsn);
|
|
40
|
+
extern XidStatus TransactionIdGetStatus(TransactionId xid, XLogRecPtr *lsn);
|
|
41
|
+
|
|
42
|
+
extern Size CLOGShmemBuffers(void);
|
|
43
|
+
extern Size CLOGShmemSize(void);
|
|
44
|
+
extern void CLOGShmemInit(void);
|
|
45
|
+
extern void BootStrapCLOG(void);
|
|
46
|
+
extern void StartupCLOG(void);
|
|
47
|
+
extern void TrimCLOG(void);
|
|
48
|
+
extern void ShutdownCLOG(void);
|
|
49
|
+
extern void CheckPointCLOG(void);
|
|
50
|
+
extern void ExtendCLOG(TransactionId newestXact);
|
|
51
|
+
extern void TruncateCLOG(TransactionId oldestXact, Oid oldestxid_datoid);
|
|
52
|
+
|
|
53
|
+
/* XLOG stuff */
|
|
54
|
+
#define CLOG_ZEROPAGE 0x00
|
|
55
|
+
#define CLOG_TRUNCATE 0x10
|
|
56
|
+
|
|
57
|
+
extern void clog_redo(XLogReaderState *record);
|
|
58
|
+
extern void clog_desc(StringInfo buf, XLogReaderState *record);
|
|
59
|
+
extern const char *clog_identify(uint8 info);
|
|
60
|
+
|
|
61
|
+
#endif /* CLOG_H */
|
|
@@ -0,0 +1,77 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* commit_ts.h
|
|
3
|
+
*
|
|
4
|
+
* PostgreSQL commit timestamp manager
|
|
5
|
+
*
|
|
6
|
+
* Portions Copyright (c) 1996-2020, PostgreSQL Global Development Group
|
|
7
|
+
* Portions Copyright (c) 1994, Regents of the University of California
|
|
8
|
+
*
|
|
9
|
+
* src/include/access/commit_ts.h
|
|
10
|
+
*/
|
|
11
|
+
#ifndef COMMIT_TS_H
|
|
12
|
+
#define COMMIT_TS_H
|
|
13
|
+
|
|
14
|
+
#include "access/xlog.h"
|
|
15
|
+
#include "datatype/timestamp.h"
|
|
16
|
+
#include "replication/origin.h"
|
|
17
|
+
#include "utils/guc.h"
|
|
18
|
+
|
|
19
|
+
|
|
20
|
+
extern PGDLLIMPORT bool track_commit_timestamp;
|
|
21
|
+
|
|
22
|
+
extern bool check_track_commit_timestamp(bool *newval, void **extra,
|
|
23
|
+
GucSource source);
|
|
24
|
+
|
|
25
|
+
extern void TransactionTreeSetCommitTsData(TransactionId xid, int nsubxids,
|
|
26
|
+
TransactionId *subxids, TimestampTz timestamp,
|
|
27
|
+
RepOriginId nodeid, bool write_xlog);
|
|
28
|
+
extern bool TransactionIdGetCommitTsData(TransactionId xid,
|
|
29
|
+
TimestampTz *ts, RepOriginId *nodeid);
|
|
30
|
+
extern TransactionId GetLatestCommitTsData(TimestampTz *ts,
|
|
31
|
+
RepOriginId *nodeid);
|
|
32
|
+
|
|
33
|
+
extern Size CommitTsShmemBuffers(void);
|
|
34
|
+
extern Size CommitTsShmemSize(void);
|
|
35
|
+
extern void CommitTsShmemInit(void);
|
|
36
|
+
extern void BootStrapCommitTs(void);
|
|
37
|
+
extern void StartupCommitTs(void);
|
|
38
|
+
extern void CommitTsParameterChange(bool newvalue, bool oldvalue);
|
|
39
|
+
extern void CompleteCommitTsInitialization(void);
|
|
40
|
+
extern void ShutdownCommitTs(void);
|
|
41
|
+
extern void CheckPointCommitTs(void);
|
|
42
|
+
extern void ExtendCommitTs(TransactionId newestXact);
|
|
43
|
+
extern void TruncateCommitTs(TransactionId oldestXact);
|
|
44
|
+
extern void SetCommitTsLimit(TransactionId oldestXact,
|
|
45
|
+
TransactionId newestXact);
|
|
46
|
+
extern void AdvanceOldestCommitTsXid(TransactionId oldestXact);
|
|
47
|
+
|
|
48
|
+
/* XLOG stuff */
|
|
49
|
+
#define COMMIT_TS_ZEROPAGE 0x00
|
|
50
|
+
#define COMMIT_TS_TRUNCATE 0x10
|
|
51
|
+
#define COMMIT_TS_SETTS 0x20
|
|
52
|
+
|
|
53
|
+
typedef struct xl_commit_ts_set
|
|
54
|
+
{
|
|
55
|
+
TimestampTz timestamp;
|
|
56
|
+
RepOriginId nodeid;
|
|
57
|
+
TransactionId mainxid;
|
|
58
|
+
/* subxact Xids follow */
|
|
59
|
+
} xl_commit_ts_set;
|
|
60
|
+
|
|
61
|
+
#define SizeOfCommitTsSet (offsetof(xl_commit_ts_set, mainxid) + \
|
|
62
|
+
sizeof(TransactionId))
|
|
63
|
+
|
|
64
|
+
typedef struct xl_commit_ts_truncate
|
|
65
|
+
{
|
|
66
|
+
int pageno;
|
|
67
|
+
TransactionId oldestXid;
|
|
68
|
+
} xl_commit_ts_truncate;
|
|
69
|
+
|
|
70
|
+
#define SizeOfCommitTsTruncate (offsetof(xl_commit_ts_truncate, oldestXid) + \
|
|
71
|
+
sizeof(TransactionId))
|
|
72
|
+
|
|
73
|
+
extern void commit_ts_redo(XLogReaderState *record);
|
|
74
|
+
extern void commit_ts_desc(StringInfo buf, XLogReaderState *record);
|
|
75
|
+
extern const char *commit_ts_identify(uint8 info);
|
|
76
|
+
|
|
77
|
+
#endif /* COMMIT_TS_H */
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
/*-------------------------------------------------------------------------
|
|
2
|
+
*
|
|
3
|
+
* detoast.h
|
|
4
|
+
* Access to compressed and external varlena values.
|
|
5
|
+
*
|
|
6
|
+
* Copyright (c) 2000-2020, PostgreSQL Global Development Group
|
|
7
|
+
*
|
|
8
|
+
* src/include/access/detoast.h
|
|
9
|
+
*
|
|
10
|
+
*-------------------------------------------------------------------------
|
|
11
|
+
*/
|
|
12
|
+
#ifndef DETOAST_H
|
|
13
|
+
#define DETOAST_H
|
|
14
|
+
|
|
15
|
+
/*
|
|
16
|
+
* Testing whether an externally-stored value is compressed now requires
|
|
17
|
+
* comparing extsize (the actual length of the external data) to rawsize
|
|
18
|
+
* (the original uncompressed datum's size). The latter includes VARHDRSZ
|
|
19
|
+
* overhead, the former doesn't. We never use compression unless it actually
|
|
20
|
+
* saves space, so we expect either equality or less-than.
|
|
21
|
+
*/
|
|
22
|
+
#define VARATT_EXTERNAL_IS_COMPRESSED(toast_pointer) \
|
|
23
|
+
((toast_pointer).va_extsize < (toast_pointer).va_rawsize - VARHDRSZ)
|
|
24
|
+
|
|
25
|
+
/*
|
|
26
|
+
* Macro to fetch the possibly-unaligned contents of an EXTERNAL datum
|
|
27
|
+
* into a local "struct varatt_external" toast pointer. This should be
|
|
28
|
+
* just a memcpy, but some versions of gcc seem to produce broken code
|
|
29
|
+
* that assumes the datum contents are aligned. Introducing an explicit
|
|
30
|
+
* intermediate "varattrib_1b_e *" variable seems to fix it.
|
|
31
|
+
*/
|
|
32
|
+
#define VARATT_EXTERNAL_GET_POINTER(toast_pointer, attr) \
|
|
33
|
+
do { \
|
|
34
|
+
varattrib_1b_e *attre = (varattrib_1b_e *) (attr); \
|
|
35
|
+
Assert(VARATT_IS_EXTERNAL(attre)); \
|
|
36
|
+
Assert(VARSIZE_EXTERNAL(attre) == sizeof(toast_pointer) + VARHDRSZ_EXTERNAL); \
|
|
37
|
+
memcpy(&(toast_pointer), VARDATA_EXTERNAL(attre), sizeof(toast_pointer)); \
|
|
38
|
+
} while (0)
|
|
39
|
+
|
|
40
|
+
/* Size of an EXTERNAL datum that contains a standard TOAST pointer */
|
|
41
|
+
#define TOAST_POINTER_SIZE (VARHDRSZ_EXTERNAL + sizeof(varatt_external))
|
|
42
|
+
|
|
43
|
+
/* Size of an EXTERNAL datum that contains an indirection pointer */
|
|
44
|
+
#define INDIRECT_POINTER_SIZE (VARHDRSZ_EXTERNAL + sizeof(varatt_indirect))
|
|
45
|
+
|
|
46
|
+
/* ----------
|
|
47
|
+
* detoast_external_attr() -
|
|
48
|
+
*
|
|
49
|
+
* Fetches an external stored attribute from the toast
|
|
50
|
+
* relation. Does NOT decompress it, if stored external
|
|
51
|
+
* in compressed format.
|
|
52
|
+
* ----------
|
|
53
|
+
*/
|
|
54
|
+
extern struct varlena *detoast_external_attr(struct varlena *attr);
|
|
55
|
+
|
|
56
|
+
/* ----------
|
|
57
|
+
* detoast_attr() -
|
|
58
|
+
*
|
|
59
|
+
* Fully detoasts one attribute, fetching and/or decompressing
|
|
60
|
+
* it as needed.
|
|
61
|
+
* ----------
|
|
62
|
+
*/
|
|
63
|
+
extern struct varlena *detoast_attr(struct varlena *attr);
|
|
64
|
+
|
|
65
|
+
/* ----------
|
|
66
|
+
* detoast_attr_slice() -
|
|
67
|
+
*
|
|
68
|
+
* Fetches only the specified portion of an attribute.
|
|
69
|
+
* (Handles all cases for attribute storage)
|
|
70
|
+
* ----------
|
|
71
|
+
*/
|
|
72
|
+
extern struct varlena *detoast_attr_slice(struct varlena *attr,
|
|
73
|
+
int32 sliceoffset,
|
|
74
|
+
int32 slicelength);
|
|
75
|
+
|
|
76
|
+
/* ----------
|
|
77
|
+
* toast_raw_datum_size -
|
|
78
|
+
*
|
|
79
|
+
* Return the raw (detoasted) size of a varlena datum
|
|
80
|
+
* ----------
|
|
81
|
+
*/
|
|
82
|
+
extern Size toast_raw_datum_size(Datum value);
|
|
83
|
+
|
|
84
|
+
/* ----------
|
|
85
|
+
* toast_datum_size -
|
|
86
|
+
*
|
|
87
|
+
* Return the storage size of a varlena datum
|
|
88
|
+
* ----------
|
|
89
|
+
*/
|
|
90
|
+
extern Size toast_datum_size(Datum value);
|
|
91
|
+
|
|
92
|
+
#endif /* DETOAST_H */
|
|
@@ -0,0 +1,228 @@
|
|
|
1
|
+
/*-------------------------------------------------------------------------
|
|
2
|
+
*
|
|
3
|
+
* genam.h
|
|
4
|
+
* POSTGRES generalized index access method definitions.
|
|
5
|
+
*
|
|
6
|
+
*
|
|
7
|
+
* Portions Copyright (c) 1996-2020, PostgreSQL Global Development Group
|
|
8
|
+
* Portions Copyright (c) 1994, Regents of the University of California
|
|
9
|
+
*
|
|
10
|
+
* src/include/access/genam.h
|
|
11
|
+
*
|
|
12
|
+
*-------------------------------------------------------------------------
|
|
13
|
+
*/
|
|
14
|
+
#ifndef GENAM_H
|
|
15
|
+
#define GENAM_H
|
|
16
|
+
|
|
17
|
+
#include "access/sdir.h"
|
|
18
|
+
#include "access/skey.h"
|
|
19
|
+
#include "nodes/tidbitmap.h"
|
|
20
|
+
#include "storage/lockdefs.h"
|
|
21
|
+
#include "utils/relcache.h"
|
|
22
|
+
#include "utils/snapshot.h"
|
|
23
|
+
|
|
24
|
+
/* We don't want this file to depend on execnodes.h. */
|
|
25
|
+
struct IndexInfo;
|
|
26
|
+
|
|
27
|
+
/*
|
|
28
|
+
* Struct for statistics returned by ambuild
|
|
29
|
+
*/
|
|
30
|
+
typedef struct IndexBuildResult
|
|
31
|
+
{
|
|
32
|
+
double heap_tuples; /* # of tuples seen in parent table */
|
|
33
|
+
double index_tuples; /* # of tuples inserted into index */
|
|
34
|
+
} IndexBuildResult;
|
|
35
|
+
|
|
36
|
+
/*
|
|
37
|
+
* Struct for input arguments passed to ambulkdelete and amvacuumcleanup
|
|
38
|
+
*
|
|
39
|
+
* num_heap_tuples is accurate only when estimated_count is false;
|
|
40
|
+
* otherwise it's just an estimate (currently, the estimate is the
|
|
41
|
+
* prior value of the relation's pg_class.reltuples field). It will
|
|
42
|
+
* always just be an estimate during ambulkdelete.
|
|
43
|
+
*/
|
|
44
|
+
typedef struct IndexVacuumInfo
|
|
45
|
+
{
|
|
46
|
+
Relation index; /* the index being vacuumed */
|
|
47
|
+
bool analyze_only; /* ANALYZE (without any actual vacuum) */
|
|
48
|
+
bool report_progress; /* emit progress.h status reports */
|
|
49
|
+
bool estimated_count; /* num_heap_tuples is an estimate */
|
|
50
|
+
int message_level; /* ereport level for progress messages */
|
|
51
|
+
double num_heap_tuples; /* tuples remaining in heap */
|
|
52
|
+
BufferAccessStrategy strategy; /* access strategy for reads */
|
|
53
|
+
} IndexVacuumInfo;
|
|
54
|
+
|
|
55
|
+
/*
|
|
56
|
+
* Struct for statistics returned by ambulkdelete and amvacuumcleanup
|
|
57
|
+
*
|
|
58
|
+
* This struct is normally allocated by the first ambulkdelete call and then
|
|
59
|
+
* passed along through subsequent ones until amvacuumcleanup; however,
|
|
60
|
+
* amvacuumcleanup must be prepared to allocate it in the case where no
|
|
61
|
+
* ambulkdelete calls were made (because no tuples needed deletion).
|
|
62
|
+
* Note that an index AM could choose to return a larger struct
|
|
63
|
+
* of which this is just the first field; this provides a way for ambulkdelete
|
|
64
|
+
* to communicate additional private data to amvacuumcleanup.
|
|
65
|
+
*
|
|
66
|
+
* Note: pages_removed is the amount by which the index physically shrank,
|
|
67
|
+
* if any (ie the change in its total size on disk). pages_deleted and
|
|
68
|
+
* pages_free refer to free space within the index file. Some index AMs
|
|
69
|
+
* may compute num_index_tuples by reference to num_heap_tuples, in which
|
|
70
|
+
* case they should copy the estimated_count field from IndexVacuumInfo.
|
|
71
|
+
*/
|
|
72
|
+
typedef struct IndexBulkDeleteResult
|
|
73
|
+
{
|
|
74
|
+
BlockNumber num_pages; /* pages remaining in index */
|
|
75
|
+
BlockNumber pages_removed; /* # removed during vacuum operation */
|
|
76
|
+
bool estimated_count; /* num_index_tuples is an estimate */
|
|
77
|
+
double num_index_tuples; /* tuples remaining */
|
|
78
|
+
double tuples_removed; /* # removed during vacuum operation */
|
|
79
|
+
BlockNumber pages_deleted; /* # unused pages in index */
|
|
80
|
+
BlockNumber pages_free; /* # pages available for reuse */
|
|
81
|
+
} IndexBulkDeleteResult;
|
|
82
|
+
|
|
83
|
+
/* Typedef for callback function to determine if a tuple is bulk-deletable */
|
|
84
|
+
typedef bool (*IndexBulkDeleteCallback) (ItemPointer itemptr, void *state);
|
|
85
|
+
|
|
86
|
+
/* struct definitions appear in relscan.h */
|
|
87
|
+
typedef struct IndexScanDescData *IndexScanDesc;
|
|
88
|
+
typedef struct SysScanDescData *SysScanDesc;
|
|
89
|
+
|
|
90
|
+
typedef struct ParallelIndexScanDescData *ParallelIndexScanDesc;
|
|
91
|
+
|
|
92
|
+
/*
|
|
93
|
+
* Enumeration specifying the type of uniqueness check to perform in
|
|
94
|
+
* index_insert().
|
|
95
|
+
*
|
|
96
|
+
* UNIQUE_CHECK_YES is the traditional Postgres immediate check, possibly
|
|
97
|
+
* blocking to see if a conflicting transaction commits.
|
|
98
|
+
*
|
|
99
|
+
* For deferrable unique constraints, UNIQUE_CHECK_PARTIAL is specified at
|
|
100
|
+
* insertion time. The index AM should test if the tuple is unique, but
|
|
101
|
+
* should not throw error, block, or prevent the insertion if the tuple
|
|
102
|
+
* appears not to be unique. We'll recheck later when it is time for the
|
|
103
|
+
* constraint to be enforced. The AM must return true if the tuple is
|
|
104
|
+
* known unique, false if it is possibly non-unique. In the "true" case
|
|
105
|
+
* it is safe to omit the later recheck.
|
|
106
|
+
*
|
|
107
|
+
* When it is time to recheck the deferred constraint, a pseudo-insertion
|
|
108
|
+
* call is made with UNIQUE_CHECK_EXISTING. The tuple is already in the
|
|
109
|
+
* index in this case, so it should not be inserted again. Rather, just
|
|
110
|
+
* check for conflicting live tuples (possibly blocking).
|
|
111
|
+
*/
|
|
112
|
+
typedef enum IndexUniqueCheck
|
|
113
|
+
{
|
|
114
|
+
UNIQUE_CHECK_NO, /* Don't do any uniqueness checking */
|
|
115
|
+
UNIQUE_CHECK_YES, /* Enforce uniqueness at insertion time */
|
|
116
|
+
UNIQUE_CHECK_PARTIAL, /* Test uniqueness, but no error */
|
|
117
|
+
UNIQUE_CHECK_EXISTING /* Check if existing tuple is unique */
|
|
118
|
+
} IndexUniqueCheck;
|
|
119
|
+
|
|
120
|
+
|
|
121
|
+
/* Nullable "ORDER BY col op const" distance */
|
|
122
|
+
typedef struct IndexOrderByDistance
|
|
123
|
+
{
|
|
124
|
+
double value;
|
|
125
|
+
bool isnull;
|
|
126
|
+
} IndexOrderByDistance;
|
|
127
|
+
|
|
128
|
+
/*
|
|
129
|
+
* generalized index_ interface routines (in indexam.c)
|
|
130
|
+
*/
|
|
131
|
+
|
|
132
|
+
/*
|
|
133
|
+
* IndexScanIsValid
|
|
134
|
+
* True iff the index scan is valid.
|
|
135
|
+
*/
|
|
136
|
+
#define IndexScanIsValid(scan) PointerIsValid(scan)
|
|
137
|
+
|
|
138
|
+
extern Relation index_open(Oid relationId, LOCKMODE lockmode);
|
|
139
|
+
extern void index_close(Relation relation, LOCKMODE lockmode);
|
|
140
|
+
|
|
141
|
+
extern bool index_insert(Relation indexRelation,
|
|
142
|
+
Datum *values, bool *isnull,
|
|
143
|
+
ItemPointer heap_t_ctid,
|
|
144
|
+
Relation heapRelation,
|
|
145
|
+
IndexUniqueCheck checkUnique,
|
|
146
|
+
struct IndexInfo *indexInfo);
|
|
147
|
+
|
|
148
|
+
extern IndexScanDesc index_beginscan(Relation heapRelation,
|
|
149
|
+
Relation indexRelation,
|
|
150
|
+
Snapshot snapshot,
|
|
151
|
+
int nkeys, int norderbys);
|
|
152
|
+
extern IndexScanDesc index_beginscan_bitmap(Relation indexRelation,
|
|
153
|
+
Snapshot snapshot,
|
|
154
|
+
int nkeys);
|
|
155
|
+
extern void index_rescan(IndexScanDesc scan,
|
|
156
|
+
ScanKey keys, int nkeys,
|
|
157
|
+
ScanKey orderbys, int norderbys);
|
|
158
|
+
extern void index_endscan(IndexScanDesc scan);
|
|
159
|
+
extern void index_markpos(IndexScanDesc scan);
|
|
160
|
+
extern void index_restrpos(IndexScanDesc scan);
|
|
161
|
+
extern Size index_parallelscan_estimate(Relation indexrel, Snapshot snapshot);
|
|
162
|
+
extern void index_parallelscan_initialize(Relation heaprel, Relation indexrel,
|
|
163
|
+
Snapshot snapshot, ParallelIndexScanDesc target);
|
|
164
|
+
extern void index_parallelrescan(IndexScanDesc scan);
|
|
165
|
+
extern IndexScanDesc index_beginscan_parallel(Relation heaprel,
|
|
166
|
+
Relation indexrel, int nkeys, int norderbys,
|
|
167
|
+
ParallelIndexScanDesc pscan);
|
|
168
|
+
extern ItemPointer index_getnext_tid(IndexScanDesc scan,
|
|
169
|
+
ScanDirection direction);
|
|
170
|
+
struct TupleTableSlot;
|
|
171
|
+
extern bool index_fetch_heap(IndexScanDesc scan, struct TupleTableSlot *slot);
|
|
172
|
+
extern bool index_getnext_slot(IndexScanDesc scan, ScanDirection direction,
|
|
173
|
+
struct TupleTableSlot *slot);
|
|
174
|
+
extern int64 index_getbitmap(IndexScanDesc scan, TIDBitmap *bitmap);
|
|
175
|
+
|
|
176
|
+
extern IndexBulkDeleteResult *index_bulk_delete(IndexVacuumInfo *info,
|
|
177
|
+
IndexBulkDeleteResult *stats,
|
|
178
|
+
IndexBulkDeleteCallback callback,
|
|
179
|
+
void *callback_state);
|
|
180
|
+
extern IndexBulkDeleteResult *index_vacuum_cleanup(IndexVacuumInfo *info,
|
|
181
|
+
IndexBulkDeleteResult *stats);
|
|
182
|
+
extern bool index_can_return(Relation indexRelation, int attno);
|
|
183
|
+
extern RegProcedure index_getprocid(Relation irel, AttrNumber attnum,
|
|
184
|
+
uint16 procnum);
|
|
185
|
+
extern FmgrInfo *index_getprocinfo(Relation irel, AttrNumber attnum,
|
|
186
|
+
uint16 procnum);
|
|
187
|
+
extern void index_store_float8_orderby_distances(IndexScanDesc scan,
|
|
188
|
+
Oid *orderByTypes,
|
|
189
|
+
IndexOrderByDistance *distances,
|
|
190
|
+
bool recheckOrderBy);
|
|
191
|
+
extern bytea *index_opclass_options(Relation relation, AttrNumber attnum,
|
|
192
|
+
Datum attoptions, bool validate);
|
|
193
|
+
|
|
194
|
+
|
|
195
|
+
/*
|
|
196
|
+
* index access method support routines (in genam.c)
|
|
197
|
+
*/
|
|
198
|
+
extern IndexScanDesc RelationGetIndexScan(Relation indexRelation,
|
|
199
|
+
int nkeys, int norderbys);
|
|
200
|
+
extern void IndexScanEnd(IndexScanDesc scan);
|
|
201
|
+
extern char *BuildIndexValueDescription(Relation indexRelation,
|
|
202
|
+
Datum *values, bool *isnull);
|
|
203
|
+
extern TransactionId index_compute_xid_horizon_for_tuples(Relation irel,
|
|
204
|
+
Relation hrel,
|
|
205
|
+
Buffer ibuf,
|
|
206
|
+
OffsetNumber *itemnos,
|
|
207
|
+
int nitems);
|
|
208
|
+
|
|
209
|
+
/*
|
|
210
|
+
* heap-or-index access to system catalogs (in genam.c)
|
|
211
|
+
*/
|
|
212
|
+
extern SysScanDesc systable_beginscan(Relation heapRelation,
|
|
213
|
+
Oid indexId,
|
|
214
|
+
bool indexOK,
|
|
215
|
+
Snapshot snapshot,
|
|
216
|
+
int nkeys, ScanKey key);
|
|
217
|
+
extern HeapTuple systable_getnext(SysScanDesc sysscan);
|
|
218
|
+
extern bool systable_recheck_tuple(SysScanDesc sysscan, HeapTuple tup);
|
|
219
|
+
extern void systable_endscan(SysScanDesc sysscan);
|
|
220
|
+
extern SysScanDesc systable_beginscan_ordered(Relation heapRelation,
|
|
221
|
+
Relation indexRelation,
|
|
222
|
+
Snapshot snapshot,
|
|
223
|
+
int nkeys, ScanKey key);
|
|
224
|
+
extern HeapTuple systable_getnext_ordered(SysScanDesc sysscan,
|
|
225
|
+
ScanDirection direction);
|
|
226
|
+
extern void systable_endscan_ordered(SysScanDesc sysscan);
|
|
227
|
+
|
|
228
|
+
#endif /* GENAM_H */
|