pg_query 5.0.0 → 6.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (898) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +27 -0
  3. data/README.md +1 -1
  4. data/Rakefile +3 -4
  5. data/ext/pg_query/extconf.rb +14 -4
  6. data/ext/pg_query/include/pg_query.h +4 -3
  7. data/ext/pg_query/include/pg_query_enum_defs.c +424 -154
  8. data/ext/pg_query/include/pg_query_fingerprint_conds.c +68 -4
  9. data/ext/pg_query/include/pg_query_fingerprint_defs.c +2901 -1794
  10. data/ext/pg_query/include/pg_query_outfuncs_conds.c +51 -3
  11. data/ext/pg_query/include/pg_query_outfuncs_defs.c +211 -24
  12. data/ext/pg_query/include/pg_query_readfuncs_conds.c +17 -1
  13. data/ext/pg_query/include/pg_query_readfuncs_defs.c +272 -53
  14. data/ext/pg_query/include/postgres/access/amapi.h +299 -0
  15. data/ext/pg_query/include/postgres/access/attmap.h +54 -0
  16. data/ext/pg_query/include/postgres/access/attnum.h +64 -0
  17. data/ext/pg_query/include/postgres/access/brin_internal.h +116 -0
  18. data/ext/pg_query/include/postgres/access/brin_tuple.h +112 -0
  19. data/ext/pg_query/include/postgres/access/clog.h +62 -0
  20. data/ext/pg_query/include/postgres/access/commit_ts.h +73 -0
  21. data/ext/pg_query/include/postgres/access/detoast.h +82 -0
  22. data/ext/pg_query/include/postgres/access/genam.h +237 -0
  23. data/ext/pg_query/include/postgres/access/gin.h +91 -0
  24. data/ext/pg_query/include/postgres/access/htup.h +89 -0
  25. data/ext/pg_query/include/postgres/access/htup_details.h +811 -0
  26. data/ext/pg_query/include/postgres/access/itup.h +170 -0
  27. data/ext/pg_query/include/postgres/access/parallel.h +81 -0
  28. data/ext/pg_query/include/postgres/access/printtup.h +35 -0
  29. data/ext/pg_query/include/postgres/access/relation.h +28 -0
  30. data/ext/pg_query/include/postgres/access/relscan.h +191 -0
  31. data/ext/pg_query/include/postgres/access/rmgrlist.h +49 -0
  32. data/ext/pg_query/include/postgres/access/sdir.h +67 -0
  33. data/ext/pg_query/include/postgres/access/skey.h +151 -0
  34. data/ext/pg_query/include/postgres/access/slru.h +221 -0
  35. data/ext/pg_query/include/postgres/access/stratnum.h +85 -0
  36. data/ext/pg_query/include/postgres/access/sysattr.h +29 -0
  37. data/ext/pg_query/include/postgres/access/table.h +28 -0
  38. data/ext/pg_query/include/postgres/access/tableam.h +2109 -0
  39. data/ext/pg_query/include/postgres/access/tidstore.h +50 -0
  40. data/ext/pg_query/include/postgres/access/toast_compression.h +73 -0
  41. data/ext/pg_query/include/postgres/access/transam.h +375 -0
  42. data/ext/pg_query/include/postgres/access/tsmapi.h +82 -0
  43. data/ext/pg_query/include/postgres/access/tupconvert.h +54 -0
  44. data/ext/pg_query/include/postgres/access/tupdesc.h +154 -0
  45. data/ext/pg_query/include/postgres/access/tupmacs.h +207 -0
  46. data/ext/pg_query/include/postgres/access/twophase.h +65 -0
  47. data/ext/pg_query/include/postgres/access/xact.h +530 -0
  48. data/ext/pg_query/include/postgres/access/xlog.h +310 -0
  49. data/ext/pg_query/include/postgres/access/xlog_internal.h +405 -0
  50. data/ext/pg_query/include/postgres/access/xlogbackup.h +43 -0
  51. data/ext/pg_query/include/postgres/access/xlogdefs.h +82 -0
  52. data/ext/pg_query/include/postgres/access/xlogprefetcher.h +55 -0
  53. data/ext/pg_query/include/postgres/access/xlogreader.h +444 -0
  54. data/ext/pg_query/include/postgres/access/xlogrecord.h +248 -0
  55. data/ext/pg_query/include/postgres/access/xlogrecovery.h +158 -0
  56. data/ext/pg_query/include/postgres/archive/archive_module.h +67 -0
  57. data/ext/pg_query/include/postgres/c.h +1374 -0
  58. data/ext/pg_query/include/postgres/catalog/catalog.h +47 -0
  59. data/ext/pg_query/include/postgres/catalog/catversion.h +62 -0
  60. data/ext/pg_query/include/postgres/catalog/dependency.h +228 -0
  61. data/ext/pg_query/include/postgres/catalog/genbki.h +149 -0
  62. data/ext/pg_query/include/postgres/catalog/index.h +218 -0
  63. data/ext/pg_query/include/postgres/catalog/indexing.h +54 -0
  64. data/ext/pg_query/include/postgres/catalog/namespace.h +189 -0
  65. data/ext/pg_query/include/postgres/catalog/objectaccess.h +267 -0
  66. data/ext/pg_query/include/postgres/catalog/objectaddress.h +89 -0
  67. data/ext/pg_query/include/postgres/catalog/pg_aggregate.h +182 -0
  68. data/ext/pg_query/include/postgres/catalog/pg_aggregate_d.h +78 -0
  69. data/ext/pg_query/include/postgres/catalog/pg_am.h +66 -0
  70. data/ext/pg_query/include/postgres/catalog/pg_am_d.h +47 -0
  71. data/ext/pg_query/include/postgres/catalog/pg_attribute.h +240 -0
  72. data/ext/pg_query/include/postgres/catalog/pg_attribute_d.h +62 -0
  73. data/ext/pg_query/include/postgres/catalog/pg_authid.h +66 -0
  74. data/ext/pg_query/include/postgres/catalog/pg_authid_d.h +60 -0
  75. data/ext/pg_query/include/postgres/catalog/pg_class.h +235 -0
  76. data/ext/pg_query/include/postgres/catalog/pg_class_d.h +134 -0
  77. data/ext/pg_query/include/postgres/catalog/pg_collation.h +106 -0
  78. data/ext/pg_query/include/postgres/catalog/pg_collation_d.h +66 -0
  79. data/ext/pg_query/include/postgres/catalog/pg_constraint.h +278 -0
  80. data/ext/pg_query/include/postgres/catalog/pg_constraint_d.h +74 -0
  81. data/ext/pg_query/include/postgres/catalog/pg_control.h +260 -0
  82. data/ext/pg_query/include/postgres/catalog/pg_conversion.h +79 -0
  83. data/ext/pg_query/include/postgres/catalog/pg_conversion_d.h +38 -0
  84. data/ext/pg_query/include/postgres/catalog/pg_database.h +129 -0
  85. data/ext/pg_query/include/postgres/catalog/pg_database_d.h +53 -0
  86. data/ext/pg_query/include/postgres/catalog/pg_depend.h +77 -0
  87. data/ext/pg_query/include/postgres/catalog/pg_depend_d.h +36 -0
  88. data/ext/pg_query/include/postgres/catalog/pg_event_trigger.h +60 -0
  89. data/ext/pg_query/include/postgres/catalog/pg_event_trigger_d.h +36 -0
  90. data/ext/pg_query/include/postgres/catalog/pg_index.h +92 -0
  91. data/ext/pg_query/include/postgres/catalog/pg_index_d.h +59 -0
  92. data/ext/pg_query/include/postgres/catalog/pg_language.h +75 -0
  93. data/ext/pg_query/include/postgres/catalog/pg_language_d.h +41 -0
  94. data/ext/pg_query/include/postgres/catalog/pg_namespace.h +67 -0
  95. data/ext/pg_query/include/postgres/catalog/pg_namespace_d.h +36 -0
  96. data/ext/pg_query/include/postgres/catalog/pg_opclass.h +91 -0
  97. data/ext/pg_query/include/postgres/catalog/pg_opclass_d.h +51 -0
  98. data/ext/pg_query/include/postgres/catalog/pg_operator.h +124 -0
  99. data/ext/pg_query/include/postgres/catalog/pg_operator_d.h +142 -0
  100. data/ext/pg_query/include/postgres/catalog/pg_opfamily.h +67 -0
  101. data/ext/pg_query/include/postgres/catalog/pg_opfamily_d.h +51 -0
  102. data/ext/pg_query/include/postgres/catalog/pg_partitioned_table.h +76 -0
  103. data/ext/pg_query/include/postgres/catalog/pg_partitioned_table_d.h +36 -0
  104. data/ext/pg_query/include/postgres/catalog/pg_proc.h +223 -0
  105. data/ext/pg_query/include/postgres/catalog/pg_proc_d.h +101 -0
  106. data/ext/pg_query/include/postgres/catalog/pg_publication.h +161 -0
  107. data/ext/pg_query/include/postgres/catalog/pg_publication_d.h +38 -0
  108. data/ext/pg_query/include/postgres/catalog/pg_replication_origin.h +65 -0
  109. data/ext/pg_query/include/postgres/catalog/pg_replication_origin_d.h +33 -0
  110. data/ext/pg_query/include/postgres/catalog/pg_statistic.h +288 -0
  111. data/ext/pg_query/include/postgres/catalog/pg_statistic_d.h +199 -0
  112. data/ext/pg_query/include/postgres/catalog/pg_statistic_ext.h +91 -0
  113. data/ext/pg_query/include/postgres/catalog/pg_statistic_ext_d.h +45 -0
  114. data/ext/pg_query/include/postgres/catalog/pg_transform.h +51 -0
  115. data/ext/pg_query/include/postgres/catalog/pg_transform_d.h +34 -0
  116. data/ext/pg_query/include/postgres/catalog/pg_trigger.h +153 -0
  117. data/ext/pg_query/include/postgres/catalog/pg_trigger_d.h +109 -0
  118. data/ext/pg_query/include/postgres/catalog/pg_ts_config.h +56 -0
  119. data/ext/pg_query/include/postgres/catalog/pg_ts_config_d.h +34 -0
  120. data/ext/pg_query/include/postgres/catalog/pg_ts_dict.h +62 -0
  121. data/ext/pg_query/include/postgres/catalog/pg_ts_dict_d.h +35 -0
  122. data/ext/pg_query/include/postgres/catalog/pg_ts_parser.h +63 -0
  123. data/ext/pg_query/include/postgres/catalog/pg_ts_parser_d.h +37 -0
  124. data/ext/pg_query/include/postgres/catalog/pg_ts_template.h +54 -0
  125. data/ext/pg_query/include/postgres/catalog/pg_ts_template_d.h +34 -0
  126. data/ext/pg_query/include/postgres/catalog/pg_type.h +407 -0
  127. data/ext/pg_query/include/postgres/catalog/pg_type_d.h +324 -0
  128. data/ext/pg_query/include/postgres/catalog/storage.h +50 -0
  129. data/ext/pg_query/include/postgres/catalog/syscache_ids.h +104 -0
  130. data/ext/pg_query/include/postgres/commands/async.h +49 -0
  131. data/ext/pg_query/include/postgres/commands/dbcommands.h +37 -0
  132. data/ext/pg_query/include/postgres/commands/defrem.h +161 -0
  133. data/ext/pg_query/include/postgres/commands/event_trigger.h +91 -0
  134. data/ext/pg_query/include/postgres/commands/explain.h +145 -0
  135. data/ext/pg_query/include/postgres/commands/prepare.h +61 -0
  136. data/ext/pg_query/include/postgres/commands/tablespace.h +69 -0
  137. data/ext/pg_query/include/postgres/commands/trigger.h +288 -0
  138. data/ext/pg_query/include/postgres/commands/vacuum.h +388 -0
  139. data/ext/pg_query/include/postgres/common/cryptohash.h +39 -0
  140. data/ext/pg_query/include/postgres/common/file_perm.h +56 -0
  141. data/ext/pg_query/include/postgres/common/file_utils.h +65 -0
  142. data/ext/pg_query/include/postgres/common/hashfn.h +119 -0
  143. data/ext/pg_query/include/postgres/common/hashfn_unstable.h +453 -0
  144. data/ext/pg_query/include/postgres/common/int.h +512 -0
  145. data/ext/pg_query/include/postgres/common/keywords.h +29 -0
  146. data/ext/pg_query/include/postgres/common/kwlookup.h +44 -0
  147. data/ext/pg_query/include/postgres/common/pg_prng.h +62 -0
  148. data/ext/pg_query/include/postgres/common/relpath.h +97 -0
  149. data/ext/pg_query/include/postgres/common/scram-common.h +70 -0
  150. data/ext/pg_query/include/postgres/common/sha2.h +32 -0
  151. data/ext/pg_query/include/postgres/common/string.h +44 -0
  152. data/ext/pg_query/include/postgres/common/unicode_east_asian_fw_table.h +124 -0
  153. data/ext/pg_query/include/postgres/copyfuncs.funcs.c +5261 -0
  154. data/ext/pg_query/include/postgres/copyfuncs.switch.c +989 -0
  155. data/ext/pg_query/include/postgres/datatype/timestamp.h +269 -0
  156. data/ext/pg_query/include/postgres/equalfuncs.funcs.c +3310 -0
  157. data/ext/pg_query/include/postgres/equalfuncs.switch.c +836 -0
  158. data/ext/pg_query/include/postgres/executor/execdesc.h +70 -0
  159. data/ext/pg_query/include/postgres/executor/executor.h +681 -0
  160. data/ext/pg_query/include/postgres/executor/functions.h +56 -0
  161. data/ext/pg_query/include/postgres/executor/instrument.h +120 -0
  162. data/ext/pg_query/include/postgres/executor/spi.h +207 -0
  163. data/ext/pg_query/include/postgres/executor/tablefunc.h +67 -0
  164. data/ext/pg_query/include/postgres/executor/tuptable.h +523 -0
  165. data/ext/pg_query/include/postgres/fmgr.h +800 -0
  166. data/ext/pg_query/include/postgres/foreign/fdwapi.h +294 -0
  167. data/ext/pg_query/include/postgres/funcapi.h +360 -0
  168. data/ext/pg_query/include/postgres/gram.h +1168 -0
  169. data/ext/pg_query/include/postgres/gramparse.h +75 -0
  170. data/ext/pg_query/include/postgres/jit/jit.h +106 -0
  171. data/ext/pg_query/include/postgres/kwlist_d.h +1164 -0
  172. data/ext/pg_query/include/postgres/lib/dshash.h +130 -0
  173. data/ext/pg_query/include/postgres/lib/ilist.h +1159 -0
  174. data/ext/pg_query/include/postgres/lib/pairingheap.h +102 -0
  175. data/ext/pg_query/include/postgres/lib/simplehash.h +1206 -0
  176. data/ext/pg_query/include/postgres/lib/sort_template.h +445 -0
  177. data/ext/pg_query/include/postgres/lib/stringinfo.h +243 -0
  178. data/ext/pg_query/include/postgres/libpq/auth.h +37 -0
  179. data/ext/pg_query/include/postgres/libpq/crypt.h +47 -0
  180. data/ext/pg_query/include/postgres/libpq/hba.h +186 -0
  181. data/ext/pg_query/include/postgres/libpq/libpq-be.h +358 -0
  182. data/ext/pg_query/include/postgres/libpq/libpq.h +143 -0
  183. data/ext/pg_query/include/postgres/libpq/pqcomm.h +169 -0
  184. data/ext/pg_query/include/postgres/libpq/pqformat.h +209 -0
  185. data/ext/pg_query/include/postgres/libpq/pqsignal.h +54 -0
  186. data/ext/pg_query/include/postgres/libpq/protocol.h +89 -0
  187. data/ext/pg_query/include/postgres/libpq/sasl.h +136 -0
  188. data/ext/pg_query/include/postgres/libpq/scram.h +37 -0
  189. data/ext/pg_query/include/postgres/mb/pg_wchar.h +792 -0
  190. data/ext/pg_query/include/postgres/mb/stringinfo_mb.h +24 -0
  191. data/ext/pg_query/include/postgres/miscadmin.h +519 -0
  192. data/ext/pg_query/include/postgres/nodes/bitmapset.h +140 -0
  193. data/ext/pg_query/include/postgres/nodes/execnodes.h +2852 -0
  194. data/ext/pg_query/include/postgres/nodes/extensible.h +164 -0
  195. data/ext/pg_query/include/postgres/nodes/lockoptions.h +61 -0
  196. data/ext/pg_query/include/postgres/nodes/makefuncs.h +127 -0
  197. data/ext/pg_query/include/postgres/nodes/memnodes.h +152 -0
  198. data/ext/pg_query/include/postgres/nodes/miscnodes.h +56 -0
  199. data/ext/pg_query/include/postgres/nodes/nodeFuncs.h +222 -0
  200. data/ext/pg_query/include/postgres/nodes/nodes.h +435 -0
  201. data/ext/pg_query/include/postgres/nodes/nodetags.h +491 -0
  202. data/ext/pg_query/include/postgres/nodes/params.h +170 -0
  203. data/ext/pg_query/include/postgres/nodes/parsenodes.h +4233 -0
  204. data/ext/pg_query/include/postgres/nodes/pathnodes.h +3435 -0
  205. data/ext/pg_query/include/postgres/nodes/pg_list.h +686 -0
  206. data/ext/pg_query/include/postgres/nodes/plannodes.h +1593 -0
  207. data/ext/pg_query/include/postgres/nodes/primnodes.h +2335 -0
  208. data/ext/pg_query/include/postgres/nodes/print.h +34 -0
  209. data/ext/pg_query/include/postgres/nodes/queryjumble.h +86 -0
  210. data/ext/pg_query/include/postgres/nodes/replnodes.h +132 -0
  211. data/ext/pg_query/include/postgres/nodes/supportnodes.h +346 -0
  212. data/ext/pg_query/include/postgres/nodes/tidbitmap.h +75 -0
  213. data/ext/pg_query/include/postgres/nodes/value.h +90 -0
  214. data/ext/pg_query/include/postgres/optimizer/cost.h +216 -0
  215. data/ext/pg_query/include/postgres/optimizer/geqo.h +90 -0
  216. data/ext/pg_query/include/postgres/optimizer/geqo_gene.h +45 -0
  217. data/ext/pg_query/include/postgres/optimizer/optimizer.h +205 -0
  218. data/ext/pg_query/include/postgres/optimizer/paths.h +271 -0
  219. data/ext/pg_query/include/postgres/optimizer/planmain.h +123 -0
  220. data/ext/pg_query/include/postgres/parser/analyze.h +66 -0
  221. data/ext/pg_query/include/postgres/parser/kwlist.h +518 -0
  222. data/ext/pg_query/include/postgres/parser/parse_agg.h +65 -0
  223. data/ext/pg_query/include/postgres/parser/parse_coerce.h +102 -0
  224. data/ext/pg_query/include/postgres/parser/parse_expr.h +25 -0
  225. data/ext/pg_query/include/postgres/parser/parse_func.h +74 -0
  226. data/ext/pg_query/include/postgres/parser/parse_node.h +358 -0
  227. data/ext/pg_query/include/postgres/parser/parse_oper.h +68 -0
  228. data/ext/pg_query/include/postgres/parser/parse_relation.h +129 -0
  229. data/ext/pg_query/include/postgres/parser/parse_type.h +61 -0
  230. data/ext/pg_query/include/postgres/parser/parser.h +68 -0
  231. data/ext/pg_query/include/postgres/parser/parsetree.h +61 -0
  232. data/ext/pg_query/include/postgres/parser/scanner.h +152 -0
  233. data/ext/pg_query/include/postgres/parser/scansup.h +27 -0
  234. data/ext/pg_query/include/postgres/partitioning/partdefs.h +26 -0
  235. data/ext/pg_query/include/postgres/pg_config.h +977 -0
  236. data/ext/pg_query/include/postgres/pg_config_manual.h +385 -0
  237. data/ext/pg_query/include/postgres/pg_config_os.h +8 -0
  238. data/ext/pg_query/include/postgres/pg_getopt.h +56 -0
  239. data/ext/pg_query/include/postgres/pg_trace.h +17 -0
  240. data/ext/pg_query/include/postgres/pgstat.h +780 -0
  241. data/ext/pg_query/include/postgres/pgtime.h +94 -0
  242. data/ext/pg_query/include/postgres/pl_gram.h +385 -0
  243. data/ext/pg_query/include/postgres/pl_reserved_kwlist.h +52 -0
  244. data/ext/pg_query/include/postgres/pl_reserved_kwlist_d.h +114 -0
  245. data/ext/pg_query/include/postgres/pl_unreserved_kwlist.h +112 -0
  246. data/ext/pg_query/include/postgres/pl_unreserved_kwlist_d.h +246 -0
  247. data/ext/pg_query/include/postgres/plerrcodes.h +998 -0
  248. data/ext/pg_query/include/postgres/plpgsql.h +1342 -0
  249. data/ext/pg_query/include/postgres/port/atomics/arch-arm.h +32 -0
  250. data/ext/pg_query/include/postgres/port/atomics/arch-hppa.h +17 -0
  251. data/ext/pg_query/include/postgres/port/atomics/arch-ppc.h +256 -0
  252. data/ext/pg_query/include/postgres/port/atomics/arch-x86.h +254 -0
  253. data/ext/pg_query/include/postgres/port/atomics/fallback.h +170 -0
  254. data/ext/pg_query/include/postgres/port/atomics/generic-gcc.h +323 -0
  255. data/ext/pg_query/include/postgres/port/atomics/generic-msvc.h +119 -0
  256. data/ext/pg_query/include/postgres/port/atomics/generic-sunpro.h +121 -0
  257. data/ext/pg_query/include/postgres/port/atomics/generic.h +437 -0
  258. data/ext/pg_query/include/postgres/port/atomics.h +606 -0
  259. data/ext/pg_query/include/postgres/port/pg_bitutils.h +421 -0
  260. data/ext/pg_query/include/postgres/port/pg_bswap.h +161 -0
  261. data/ext/pg_query/include/postgres/port/pg_crc32c.h +110 -0
  262. data/ext/pg_query/include/postgres/port/pg_iovec.h +117 -0
  263. data/ext/pg_query/include/postgres/port/simd.h +422 -0
  264. data/ext/pg_query/include/postgres/port/win32/arpa/inet.h +3 -0
  265. data/ext/pg_query/include/postgres/port/win32/dlfcn.h +1 -0
  266. data/ext/pg_query/include/postgres/port/win32/grp.h +1 -0
  267. data/ext/pg_query/include/postgres/port/win32/netdb.h +7 -0
  268. data/ext/pg_query/include/postgres/port/win32/netinet/in.h +3 -0
  269. data/ext/pg_query/include/postgres/port/win32/netinet/tcp.h +7 -0
  270. data/ext/pg_query/include/postgres/port/win32/pwd.h +3 -0
  271. data/ext/pg_query/include/postgres/port/win32/sys/resource.h +20 -0
  272. data/ext/pg_query/include/postgres/port/win32/sys/select.h +3 -0
  273. data/ext/pg_query/include/postgres/port/win32/sys/socket.h +34 -0
  274. data/ext/pg_query/include/postgres/port/win32/sys/un.h +17 -0
  275. data/ext/pg_query/include/postgres/port/win32/sys/wait.h +3 -0
  276. data/ext/pg_query/include/postgres/port/win32.h +59 -0
  277. data/ext/pg_query/include/postgres/port/win32_msvc/dirent.h +34 -0
  278. data/ext/pg_query/include/postgres/port/win32_msvc/sys/file.h +1 -0
  279. data/ext/pg_query/include/postgres/port/win32_msvc/sys/param.h +1 -0
  280. data/ext/pg_query/include/postgres/port/win32_msvc/sys/time.h +1 -0
  281. data/ext/pg_query/include/postgres/port/win32_msvc/unistd.h +9 -0
  282. data/ext/pg_query/include/postgres/port/win32_msvc/utime.h +3 -0
  283. data/ext/pg_query/include/postgres/port/win32_port.h +584 -0
  284. data/ext/pg_query/include/postgres/port.h +524 -0
  285. data/ext/pg_query/include/postgres/portability/instr_time.h +197 -0
  286. data/ext/pg_query/include/postgres/postgres.h +579 -0
  287. data/ext/pg_query/include/postgres/postmaster/autovacuum.h +69 -0
  288. data/ext/pg_query/include/postgres/postmaster/bgworker.h +164 -0
  289. data/ext/pg_query/include/postgres/postmaster/bgworker_internals.h +60 -0
  290. data/ext/pg_query/include/postgres/postmaster/bgwriter.h +45 -0
  291. data/ext/pg_query/include/postgres/postmaster/interrupt.h +32 -0
  292. data/ext/pg_query/include/postgres/postmaster/pgarch.h +36 -0
  293. data/ext/pg_query/include/postgres/postmaster/postmaster.h +101 -0
  294. data/ext/pg_query/include/postgres/postmaster/startup.h +41 -0
  295. data/ext/pg_query/include/postgres/postmaster/syslogger.h +101 -0
  296. data/ext/pg_query/include/postgres/postmaster/walsummarizer.h +35 -0
  297. data/ext/pg_query/include/postgres/postmaster/walwriter.h +23 -0
  298. data/ext/pg_query/include/postgres/regex/regex.h +272 -0
  299. data/ext/pg_query/include/postgres/replication/logicallauncher.h +34 -0
  300. data/ext/pg_query/include/postgres/replication/logicalproto.h +274 -0
  301. data/ext/pg_query/include/postgres/replication/logicalworker.h +33 -0
  302. data/ext/pg_query/include/postgres/replication/origin.h +73 -0
  303. data/ext/pg_query/include/postgres/replication/reorderbuffer.h +743 -0
  304. data/ext/pg_query/include/postgres/replication/slot.h +285 -0
  305. data/ext/pg_query/include/postgres/replication/slotsync.h +38 -0
  306. data/ext/pg_query/include/postgres/replication/syncrep.h +109 -0
  307. data/ext/pg_query/include/postgres/replication/walreceiver.h +504 -0
  308. data/ext/pg_query/include/postgres/replication/walsender.h +76 -0
  309. data/ext/pg_query/include/postgres/rewrite/prs2lock.h +46 -0
  310. data/ext/pg_query/include/postgres/rewrite/rewriteHandler.h +41 -0
  311. data/ext/pg_query/include/postgres/rewrite/rewriteManip.h +96 -0
  312. data/ext/pg_query/include/postgres/rewrite/rewriteSupport.h +26 -0
  313. data/ext/pg_query/include/postgres/storage/block.h +108 -0
  314. data/ext/pg_query/include/postgres/storage/buf.h +46 -0
  315. data/ext/pg_query/include/postgres/storage/bufmgr.h +411 -0
  316. data/ext/pg_query/include/postgres/storage/bufpage.h +510 -0
  317. data/ext/pg_query/include/postgres/storage/condition_variable.h +73 -0
  318. data/ext/pg_query/include/postgres/storage/dsm.h +61 -0
  319. data/ext/pg_query/include/postgres/storage/dsm_impl.h +79 -0
  320. data/ext/pg_query/include/postgres/storage/fd.h +219 -0
  321. data/ext/pg_query/include/postgres/storage/fileset.h +40 -0
  322. data/ext/pg_query/include/postgres/storage/ipc.h +87 -0
  323. data/ext/pg_query/include/postgres/storage/item.h +19 -0
  324. data/ext/pg_query/include/postgres/storage/itemid.h +184 -0
  325. data/ext/pg_query/include/postgres/storage/itemptr.h +245 -0
  326. data/ext/pg_query/include/postgres/storage/large_object.h +100 -0
  327. data/ext/pg_query/include/postgres/storage/latch.h +196 -0
  328. data/ext/pg_query/include/postgres/storage/lmgr.h +126 -0
  329. data/ext/pg_query/include/postgres/storage/lock.h +624 -0
  330. data/ext/pg_query/include/postgres/storage/lockdefs.h +59 -0
  331. data/ext/pg_query/include/postgres/storage/lwlock.h +228 -0
  332. data/ext/pg_query/include/postgres/storage/lwlocknames.h +47 -0
  333. data/ext/pg_query/include/postgres/storage/off.h +57 -0
  334. data/ext/pg_query/include/postgres/storage/pg_sema.h +61 -0
  335. data/ext/pg_query/include/postgres/storage/pg_shmem.h +93 -0
  336. data/ext/pg_query/include/postgres/storage/pmsignal.h +105 -0
  337. data/ext/pg_query/include/postgres/storage/predicate.h +83 -0
  338. data/ext/pg_query/include/postgres/storage/proc.h +491 -0
  339. data/ext/pg_query/include/postgres/storage/procarray.h +103 -0
  340. data/ext/pg_query/include/postgres/storage/proclist_types.h +53 -0
  341. data/ext/pg_query/include/postgres/storage/procnumber.h +43 -0
  342. data/ext/pg_query/include/postgres/storage/procsignal.h +75 -0
  343. data/ext/pg_query/include/postgres/storage/read_stream.h +65 -0
  344. data/ext/pg_query/include/postgres/storage/relfilelocator.h +100 -0
  345. data/ext/pg_query/include/postgres/storage/s_lock.h +847 -0
  346. data/ext/pg_query/include/postgres/storage/sharedfileset.h +37 -0
  347. data/ext/pg_query/include/postgres/storage/shm_mq.h +86 -0
  348. data/ext/pg_query/include/postgres/storage/shm_toc.h +58 -0
  349. data/ext/pg_query/include/postgres/storage/shmem.h +59 -0
  350. data/ext/pg_query/include/postgres/storage/sinval.h +153 -0
  351. data/ext/pg_query/include/postgres/storage/smgr.h +127 -0
  352. data/ext/pg_query/include/postgres/storage/spin.h +77 -0
  353. data/ext/pg_query/include/postgres/storage/standby.h +109 -0
  354. data/ext/pg_query/include/postgres/storage/standbydefs.h +74 -0
  355. data/ext/pg_query/include/postgres/storage/sync.h +66 -0
  356. data/ext/pg_query/include/postgres/tcop/cmdtag.h +62 -0
  357. data/ext/pg_query/include/postgres/tcop/cmdtaglist.h +219 -0
  358. data/ext/pg_query/include/postgres/tcop/deparse_utility.h +108 -0
  359. data/ext/pg_query/include/postgres/tcop/dest.h +148 -0
  360. data/ext/pg_query/include/postgres/tcop/fastpath.h +20 -0
  361. data/ext/pg_query/include/postgres/tcop/pquery.h +51 -0
  362. data/ext/pg_query/include/postgres/tcop/tcopprot.h +98 -0
  363. data/ext/pg_query/include/postgres/tcop/utility.h +112 -0
  364. data/ext/pg_query/include/postgres/tsearch/ts_cache.h +96 -0
  365. data/ext/pg_query/include/postgres/utils/acl.h +290 -0
  366. data/ext/pg_query/include/postgres/utils/aclchk_internal.h +45 -0
  367. data/ext/pg_query/include/postgres/utils/array.h +481 -0
  368. data/ext/pg_query/include/postgres/utils/ascii.h +84 -0
  369. data/ext/pg_query/include/postgres/utils/backend_progress.h +46 -0
  370. data/ext/pg_query/include/postgres/utils/backend_status.h +340 -0
  371. data/ext/pg_query/include/postgres/utils/builtins.h +139 -0
  372. data/ext/pg_query/include/postgres/utils/bytea.h +28 -0
  373. data/ext/pg_query/include/postgres/utils/catcache.h +230 -0
  374. data/ext/pg_query/include/postgres/utils/date.h +118 -0
  375. data/ext/pg_query/include/postgres/utils/datetime.h +367 -0
  376. data/ext/pg_query/include/postgres/utils/datum.h +76 -0
  377. data/ext/pg_query/include/postgres/utils/dsa.h +166 -0
  378. data/ext/pg_query/include/postgres/utils/elog.h +540 -0
  379. data/ext/pg_query/include/postgres/utils/errcodes.h +352 -0
  380. data/ext/pg_query/include/postgres/utils/expandeddatum.h +170 -0
  381. data/ext/pg_query/include/postgres/utils/expandedrecord.h +241 -0
  382. data/ext/pg_query/include/postgres/utils/float.h +357 -0
  383. data/ext/pg_query/include/postgres/utils/fmgroids.h +3347 -0
  384. data/ext/pg_query/include/postgres/utils/fmgrprotos.h +2904 -0
  385. data/ext/pg_query/include/postgres/utils/fmgrtab.h +49 -0
  386. data/ext/pg_query/include/postgres/utils/guc.h +456 -0
  387. data/ext/pg_query/include/postgres/utils/guc_hooks.h +184 -0
  388. data/ext/pg_query/include/postgres/utils/guc_tables.h +323 -0
  389. data/ext/pg_query/include/postgres/utils/hsearch.h +153 -0
  390. data/ext/pg_query/include/postgres/utils/injection_point.h +44 -0
  391. data/ext/pg_query/include/postgres/utils/inval.h +68 -0
  392. data/ext/pg_query/include/postgres/utils/logtape.h +77 -0
  393. data/ext/pg_query/include/postgres/utils/lsyscache.h +215 -0
  394. data/ext/pg_query/include/postgres/utils/memdebug.h +82 -0
  395. data/ext/pg_query/include/postgres/utils/memutils.h +193 -0
  396. data/ext/pg_query/include/postgres/utils/memutils_internal.h +176 -0
  397. data/ext/pg_query/include/postgres/utils/memutils_memorychunk.h +253 -0
  398. data/ext/pg_query/include/postgres/utils/numeric.h +110 -0
  399. data/ext/pg_query/include/postgres/utils/palloc.h +151 -0
  400. data/ext/pg_query/include/postgres/utils/partcache.h +103 -0
  401. data/ext/pg_query/include/postgres/utils/pg_locale.h +136 -0
  402. data/ext/pg_query/include/postgres/utils/pgstat_internal.h +808 -0
  403. data/ext/pg_query/include/postgres/utils/plancache.h +238 -0
  404. data/ext/pg_query/include/postgres/utils/portal.h +252 -0
  405. data/ext/pg_query/include/postgres/utils/queryenvironment.h +74 -0
  406. data/ext/pg_query/include/postgres/utils/regproc.h +39 -0
  407. data/ext/pg_query/include/postgres/utils/rel.h +711 -0
  408. data/ext/pg_query/include/postgres/utils/relcache.h +155 -0
  409. data/ext/pg_query/include/postgres/utils/reltrigger.h +81 -0
  410. data/ext/pg_query/include/postgres/utils/resowner.h +167 -0
  411. data/ext/pg_query/include/postgres/utils/ruleutils.h +52 -0
  412. data/ext/pg_query/include/postgres/utils/sharedtuplestore.h +61 -0
  413. data/ext/pg_query/include/postgres/utils/snapmgr.h +130 -0
  414. data/ext/pg_query/include/postgres/utils/snapshot.h +219 -0
  415. data/ext/pg_query/include/postgres/utils/sortsupport.h +391 -0
  416. data/ext/pg_query/include/postgres/utils/syscache.h +131 -0
  417. data/ext/pg_query/include/postgres/utils/timeout.h +96 -0
  418. data/ext/pg_query/include/postgres/utils/timestamp.h +147 -0
  419. data/ext/pg_query/include/postgres/utils/tuplesort.h +472 -0
  420. data/ext/pg_query/include/postgres/utils/tuplestore.h +88 -0
  421. data/ext/pg_query/include/postgres/utils/typcache.h +210 -0
  422. data/ext/pg_query/include/postgres/utils/varlena.h +53 -0
  423. data/ext/pg_query/include/postgres/utils/wait_event.h +108 -0
  424. data/ext/pg_query/include/postgres/utils/wait_event_types.h +218 -0
  425. data/ext/pg_query/include/postgres/utils/xml.h +94 -0
  426. data/ext/pg_query/include/postgres/varatt.h +358 -0
  427. data/ext/pg_query/include/protobuf/pg_query.pb-c.h +1546 -792
  428. data/ext/pg_query/include/protobuf/pg_query.pb.h +58365 -46595
  429. data/ext/pg_query/pg_query.c +9 -0
  430. data/ext/pg_query/pg_query.pb-c.c +6598 -3739
  431. data/ext/pg_query/pg_query_fingerprint.c +4 -5
  432. data/ext/pg_query/pg_query_normalize.c +42 -1
  433. data/ext/pg_query/pg_query_outfuncs_json.c +9 -1
  434. data/ext/pg_query/pg_query_outfuncs_protobuf.c +1 -0
  435. data/ext/pg_query/pg_query_parse.c +1 -1
  436. data/ext/pg_query/pg_query_parse_plpgsql.c +18 -17
  437. data/ext/pg_query/pg_query_readfuncs_protobuf.c +3 -2
  438. data/ext/pg_query/pg_query_ruby.c +5 -0
  439. data/ext/pg_query/pg_query_ruby_freebsd.sym +0 -1
  440. data/ext/pg_query/pg_query_scan.c +1 -1
  441. data/ext/pg_query/pg_query_split.c +1 -1
  442. data/ext/pg_query/postgres_deparse.c +409 -21
  443. data/ext/pg_query/src_backend_catalog_namespace.c +241 -66
  444. data/ext/pg_query/src_backend_catalog_pg_proc.c +1 -3
  445. data/ext/pg_query/src_backend_commands_define.c +2 -3
  446. data/ext/pg_query/src_backend_nodes_bitmapset.c +137 -94
  447. data/ext/pg_query/src_backend_nodes_copyfuncs.c +1 -1
  448. data/ext/pg_query/src_backend_nodes_equalfuncs.c +1 -1
  449. data/ext/pg_query/src_backend_nodes_extensible.c +1 -1
  450. data/ext/pg_query/src_backend_nodes_list.c +3 -7
  451. data/ext/pg_query/src_backend_nodes_makefuncs.c +59 -20
  452. data/ext/pg_query/src_backend_nodes_nodeFuncs.c +109 -2
  453. data/ext/pg_query/src_backend_nodes_value.c +1 -1
  454. data/ext/pg_query/src_backend_parser_gram.c +34490 -32135
  455. data/ext/pg_query/src_backend_parser_parser.c +8 -8
  456. data/ext/pg_query/src_backend_parser_scan.c +5637 -3028
  457. data/ext/pg_query/src_backend_parser_scansup.c +2 -1
  458. data/ext/pg_query/src_backend_storage_ipc_ipc.c +1 -1
  459. data/ext/pg_query/src_backend_tcop_postgres.c +34 -10
  460. data/ext/pg_query/src_backend_utils_activity_pgstat_database.c +2 -2
  461. data/ext/pg_query/src_backend_utils_adt_datum.c +8 -6
  462. data/ext/pg_query/src_backend_utils_adt_expandeddatum.c +1 -1
  463. data/ext/pg_query/src_backend_utils_adt_format_type.c +1 -1
  464. data/ext/pg_query/src_backend_utils_adt_numutils.c +4 -5
  465. data/ext/pg_query/src_backend_utils_adt_ruleutils.c +101 -28
  466. data/ext/pg_query/src_backend_utils_error_assert.c +1 -1
  467. data/ext/pg_query/src_backend_utils_error_elog.c +60 -190
  468. data/ext/pg_query/src_backend_utils_fmgr_fmgr.c +4 -2
  469. data/ext/pg_query/src_backend_utils_init_globals.c +16 -4
  470. data/ext/pg_query/src_backend_utils_mb_mbutils.c +19 -81
  471. data/ext/pg_query/src_backend_utils_misc_guc_tables.c +16 -8
  472. data/ext/pg_query/src_backend_utils_mmgr_alignedalloc.c +8 -5
  473. data/ext/pg_query/src_backend_utils_mmgr_aset.c +308 -238
  474. data/ext/pg_query/src_backend_utils_mmgr_bump.c +728 -0
  475. data/ext/pg_query/src_backend_utils_mmgr_generation.c +273 -197
  476. data/ext/pg_query/src_backend_utils_mmgr_mcxt.c +270 -215
  477. data/ext/pg_query/src_backend_utils_mmgr_slab.c +154 -96
  478. data/ext/pg_query/src_common_encnames.c +43 -44
  479. data/ext/pg_query/src_common_hashfn.c +1 -1
  480. data/ext/pg_query/src_common_keywords.c +1 -1
  481. data/ext/pg_query/src_common_kwlist_d.h +511 -466
  482. data/ext/pg_query/src_common_kwlookup.c +1 -1
  483. data/ext/pg_query/src_common_psprintf.c +3 -3
  484. data/ext/pg_query/src_common_stringinfo.c +18 -1
  485. data/ext/pg_query/src_common_wchar.c +45 -108
  486. data/ext/pg_query/src_pl_plpgsql_src_pl_comp.c +99 -5
  487. data/ext/pg_query/src_pl_plpgsql_src_pl_funcs.c +1 -1
  488. data/ext/pg_query/src_pl_plpgsql_src_pl_gram.c +242 -143
  489. data/ext/pg_query/src_pl_plpgsql_src_pl_handler.c +1 -1
  490. data/ext/pg_query/src_pl_plpgsql_src_pl_reserved_kwlist_d.h +1 -1
  491. data/ext/pg_query/src_pl_plpgsql_src_pl_scanner.c +19 -1
  492. data/ext/pg_query/src_pl_plpgsql_src_pl_unreserved_kwlist_d.h +1 -1
  493. data/ext/pg_query/src_port_pg_bitutils.c +251 -32
  494. data/ext/pg_query/src_port_pgstrcasecmp.c +29 -1
  495. data/ext/pg_query/src_port_snprintf.c +4 -4
  496. data/ext/pg_query/src_port_strerror.c +1 -3
  497. data/ext/pg_query/src_port_strlcpy.c +79 -0
  498. data/lib/pg_query/fingerprint.rb +2 -3
  499. data/lib/pg_query/node.rb +16 -11
  500. data/lib/pg_query/param_refs.rb +1 -1
  501. data/lib/pg_query/parse.rb +1 -1
  502. data/lib/pg_query/pg_query_pb.rb +26 -3
  503. data/lib/pg_query/treewalker.rb +52 -12
  504. data/lib/pg_query/truncate.rb +1 -1
  505. data/lib/pg_query/version.rb +1 -1
  506. metadata +444 -400
  507. data/ext/pg_query/guc-file.c +0 -0
  508. data/ext/pg_query/include/access/amapi.h +0 -292
  509. data/ext/pg_query/include/access/attmap.h +0 -54
  510. data/ext/pg_query/include/access/attnum.h +0 -64
  511. data/ext/pg_query/include/access/clog.h +0 -63
  512. data/ext/pg_query/include/access/commit_ts.h +0 -74
  513. data/ext/pg_query/include/access/detoast.h +0 -82
  514. data/ext/pg_query/include/access/genam.h +0 -233
  515. data/ext/pg_query/include/access/gin.h +0 -91
  516. data/ext/pg_query/include/access/htup.h +0 -89
  517. data/ext/pg_query/include/access/htup_details.h +0 -811
  518. data/ext/pg_query/include/access/itup.h +0 -170
  519. data/ext/pg_query/include/access/parallel.h +0 -82
  520. data/ext/pg_query/include/access/printtup.h +0 -35
  521. data/ext/pg_query/include/access/relation.h +0 -28
  522. data/ext/pg_query/include/access/relscan.h +0 -191
  523. data/ext/pg_query/include/access/rmgrlist.h +0 -49
  524. data/ext/pg_query/include/access/sdir.h +0 -67
  525. data/ext/pg_query/include/access/skey.h +0 -151
  526. data/ext/pg_query/include/access/stratnum.h +0 -85
  527. data/ext/pg_query/include/access/sysattr.h +0 -29
  528. data/ext/pg_query/include/access/table.h +0 -28
  529. data/ext/pg_query/include/access/tableam.h +0 -2100
  530. data/ext/pg_query/include/access/toast_compression.h +0 -73
  531. data/ext/pg_query/include/access/transam.h +0 -375
  532. data/ext/pg_query/include/access/tsmapi.h +0 -82
  533. data/ext/pg_query/include/access/tupconvert.h +0 -54
  534. data/ext/pg_query/include/access/tupdesc.h +0 -154
  535. data/ext/pg_query/include/access/tupmacs.h +0 -207
  536. data/ext/pg_query/include/access/twophase.h +0 -65
  537. data/ext/pg_query/include/access/xact.h +0 -530
  538. data/ext/pg_query/include/access/xlog.h +0 -302
  539. data/ext/pg_query/include/access/xlog_internal.h +0 -404
  540. data/ext/pg_query/include/access/xlogbackup.h +0 -41
  541. data/ext/pg_query/include/access/xlogdefs.h +0 -82
  542. data/ext/pg_query/include/access/xlogprefetcher.h +0 -55
  543. data/ext/pg_query/include/access/xlogreader.h +0 -444
  544. data/ext/pg_query/include/access/xlogrecord.h +0 -248
  545. data/ext/pg_query/include/access/xlogrecovery.h +0 -158
  546. data/ext/pg_query/include/archive/archive_module.h +0 -59
  547. data/ext/pg_query/include/c.h +0 -1379
  548. data/ext/pg_query/include/catalog/catalog.h +0 -45
  549. data/ext/pg_query/include/catalog/catversion.h +0 -62
  550. data/ext/pg_query/include/catalog/dependency.h +0 -270
  551. data/ext/pg_query/include/catalog/genbki.h +0 -143
  552. data/ext/pg_query/include/catalog/index.h +0 -214
  553. data/ext/pg_query/include/catalog/indexing.h +0 -54
  554. data/ext/pg_query/include/catalog/namespace.h +0 -190
  555. data/ext/pg_query/include/catalog/objectaccess.h +0 -267
  556. data/ext/pg_query/include/catalog/objectaddress.h +0 -89
  557. data/ext/pg_query/include/catalog/pg_aggregate.h +0 -180
  558. data/ext/pg_query/include/catalog/pg_aggregate_d.h +0 -78
  559. data/ext/pg_query/include/catalog/pg_am.h +0 -63
  560. data/ext/pg_query/include/catalog/pg_am_d.h +0 -47
  561. data/ext/pg_query/include/catalog/pg_attribute.h +0 -223
  562. data/ext/pg_query/include/catalog/pg_attribute_d.h +0 -62
  563. data/ext/pg_query/include/catalog/pg_authid.h +0 -63
  564. data/ext/pg_query/include/catalog/pg_authid_d.h +0 -59
  565. data/ext/pg_query/include/catalog/pg_class.h +0 -230
  566. data/ext/pg_query/include/catalog/pg_class_d.h +0 -132
  567. data/ext/pg_query/include/catalog/pg_collation.h +0 -100
  568. data/ext/pg_query/include/catalog/pg_collation_d.h +0 -63
  569. data/ext/pg_query/include/catalog/pg_constraint.h +0 -273
  570. data/ext/pg_query/include/catalog/pg_constraint_d.h +0 -73
  571. data/ext/pg_query/include/catalog/pg_control.h +0 -258
  572. data/ext/pg_query/include/catalog/pg_conversion.h +0 -75
  573. data/ext/pg_query/include/catalog/pg_conversion_d.h +0 -38
  574. data/ext/pg_query/include/catalog/pg_database.h +0 -124
  575. data/ext/pg_query/include/catalog/pg_database_d.h +0 -52
  576. data/ext/pg_query/include/catalog/pg_depend.h +0 -77
  577. data/ext/pg_query/include/catalog/pg_depend_d.h +0 -36
  578. data/ext/pg_query/include/catalog/pg_event_trigger.h +0 -57
  579. data/ext/pg_query/include/catalog/pg_event_trigger_d.h +0 -36
  580. data/ext/pg_query/include/catalog/pg_index.h +0 -90
  581. data/ext/pg_query/include/catalog/pg_index_d.h +0 -59
  582. data/ext/pg_query/include/catalog/pg_language.h +0 -72
  583. data/ext/pg_query/include/catalog/pg_language_d.h +0 -41
  584. data/ext/pg_query/include/catalog/pg_namespace.h +0 -64
  585. data/ext/pg_query/include/catalog/pg_namespace_d.h +0 -36
  586. data/ext/pg_query/include/catalog/pg_opclass.h +0 -88
  587. data/ext/pg_query/include/catalog/pg_opclass_d.h +0 -51
  588. data/ext/pg_query/include/catalog/pg_operator.h +0 -107
  589. data/ext/pg_query/include/catalog/pg_operator_d.h +0 -142
  590. data/ext/pg_query/include/catalog/pg_opfamily.h +0 -64
  591. data/ext/pg_query/include/catalog/pg_opfamily_d.h +0 -51
  592. data/ext/pg_query/include/catalog/pg_partitioned_table.h +0 -74
  593. data/ext/pg_query/include/catalog/pg_partitioned_table_d.h +0 -36
  594. data/ext/pg_query/include/catalog/pg_proc.h +0 -220
  595. data/ext/pg_query/include/catalog/pg_proc_d.h +0 -101
  596. data/ext/pg_query/include/catalog/pg_publication.h +0 -158
  597. data/ext/pg_query/include/catalog/pg_publication_d.h +0 -38
  598. data/ext/pg_query/include/catalog/pg_replication_origin.h +0 -62
  599. data/ext/pg_query/include/catalog/pg_replication_origin_d.h +0 -33
  600. data/ext/pg_query/include/catalog/pg_statistic.h +0 -282
  601. data/ext/pg_query/include/catalog/pg_statistic_d.h +0 -195
  602. data/ext/pg_query/include/catalog/pg_statistic_ext.h +0 -88
  603. data/ext/pg_query/include/catalog/pg_statistic_ext_d.h +0 -45
  604. data/ext/pg_query/include/catalog/pg_transform.h +0 -48
  605. data/ext/pg_query/include/catalog/pg_transform_d.h +0 -34
  606. data/ext/pg_query/include/catalog/pg_trigger.h +0 -153
  607. data/ext/pg_query/include/catalog/pg_trigger_d.h +0 -109
  608. data/ext/pg_query/include/catalog/pg_ts_config.h +0 -53
  609. data/ext/pg_query/include/catalog/pg_ts_config_d.h +0 -34
  610. data/ext/pg_query/include/catalog/pg_ts_dict.h +0 -59
  611. data/ext/pg_query/include/catalog/pg_ts_dict_d.h +0 -35
  612. data/ext/pg_query/include/catalog/pg_ts_parser.h +0 -60
  613. data/ext/pg_query/include/catalog/pg_ts_parser_d.h +0 -37
  614. data/ext/pg_query/include/catalog/pg_ts_template.h +0 -51
  615. data/ext/pg_query/include/catalog/pg_ts_template_d.h +0 -34
  616. data/ext/pg_query/include/catalog/pg_type.h +0 -404
  617. data/ext/pg_query/include/catalog/pg_type_d.h +0 -324
  618. data/ext/pg_query/include/catalog/storage.h +0 -50
  619. data/ext/pg_query/include/commands/async.h +0 -53
  620. data/ext/pg_query/include/commands/dbcommands.h +0 -37
  621. data/ext/pg_query/include/commands/defrem.h +0 -161
  622. data/ext/pg_query/include/commands/event_trigger.h +0 -88
  623. data/ext/pg_query/include/commands/explain.h +0 -129
  624. data/ext/pg_query/include/commands/prepare.h +0 -61
  625. data/ext/pg_query/include/commands/tablespace.h +0 -69
  626. data/ext/pg_query/include/commands/trigger.h +0 -288
  627. data/ext/pg_query/include/commands/vacuum.h +0 -386
  628. data/ext/pg_query/include/common/cryptohash.h +0 -39
  629. data/ext/pg_query/include/common/file_perm.h +0 -56
  630. data/ext/pg_query/include/common/hashfn.h +0 -104
  631. data/ext/pg_query/include/common/int.h +0 -437
  632. data/ext/pg_query/include/common/ip.h +0 -33
  633. data/ext/pg_query/include/common/keywords.h +0 -29
  634. data/ext/pg_query/include/common/kwlookup.h +0 -44
  635. data/ext/pg_query/include/common/pg_prng.h +0 -61
  636. data/ext/pg_query/include/common/relpath.h +0 -97
  637. data/ext/pg_query/include/common/scram-common.h +0 -70
  638. data/ext/pg_query/include/common/sha2.h +0 -32
  639. data/ext/pg_query/include/common/string.h +0 -44
  640. data/ext/pg_query/include/common/unicode_east_asian_fw_table.h +0 -125
  641. data/ext/pg_query/include/copyfuncs.funcs.c +0 -5013
  642. data/ext/pg_query/include/copyfuncs.switch.c +0 -938
  643. data/ext/pg_query/include/datatype/timestamp.h +0 -243
  644. data/ext/pg_query/include/equalfuncs.funcs.c +0 -3097
  645. data/ext/pg_query/include/equalfuncs.switch.c +0 -785
  646. data/ext/pg_query/include/executor/execdesc.h +0 -70
  647. data/ext/pg_query/include/executor/executor.h +0 -680
  648. data/ext/pg_query/include/executor/functions.h +0 -55
  649. data/ext/pg_query/include/executor/instrument.h +0 -118
  650. data/ext/pg_query/include/executor/spi.h +0 -213
  651. data/ext/pg_query/include/executor/tablefunc.h +0 -67
  652. data/ext/pg_query/include/executor/tuptable.h +0 -494
  653. data/ext/pg_query/include/fmgr.h +0 -800
  654. data/ext/pg_query/include/foreign/fdwapi.h +0 -294
  655. data/ext/pg_query/include/funcapi.h +0 -360
  656. data/ext/pg_query/include/gram.h +0 -1127
  657. data/ext/pg_query/include/gramparse.h +0 -75
  658. data/ext/pg_query/include/jit/jit.h +0 -105
  659. data/ext/pg_query/include/kwlist_d.h +0 -1119
  660. data/ext/pg_query/include/lib/dshash.h +0 -115
  661. data/ext/pg_query/include/lib/ilist.h +0 -1159
  662. data/ext/pg_query/include/lib/pairingheap.h +0 -102
  663. data/ext/pg_query/include/lib/simplehash.h +0 -1184
  664. data/ext/pg_query/include/lib/sort_template.h +0 -432
  665. data/ext/pg_query/include/lib/stringinfo.h +0 -161
  666. data/ext/pg_query/include/libpq/auth.h +0 -37
  667. data/ext/pg_query/include/libpq/crypt.h +0 -47
  668. data/ext/pg_query/include/libpq/hba.h +0 -186
  669. data/ext/pg_query/include/libpq/libpq-be.h +0 -354
  670. data/ext/pg_query/include/libpq/libpq.h +0 -144
  671. data/ext/pg_query/include/libpq/pqcomm.h +0 -163
  672. data/ext/pg_query/include/libpq/pqformat.h +0 -210
  673. data/ext/pg_query/include/libpq/pqsignal.h +0 -54
  674. data/ext/pg_query/include/libpq/sasl.h +0 -136
  675. data/ext/pg_query/include/libpq/scram.h +0 -37
  676. data/ext/pg_query/include/mb/pg_wchar.h +0 -772
  677. data/ext/pg_query/include/mb/stringinfo_mb.h +0 -24
  678. data/ext/pg_query/include/miscadmin.h +0 -507
  679. data/ext/pg_query/include/nodes/bitmapset.h +0 -126
  680. data/ext/pg_query/include/nodes/execnodes.h +0 -2768
  681. data/ext/pg_query/include/nodes/extensible.h +0 -164
  682. data/ext/pg_query/include/nodes/lockoptions.h +0 -61
  683. data/ext/pg_query/include/nodes/makefuncs.h +0 -121
  684. data/ext/pg_query/include/nodes/memnodes.h +0 -113
  685. data/ext/pg_query/include/nodes/miscnodes.h +0 -56
  686. data/ext/pg_query/include/nodes/nodeFuncs.h +0 -222
  687. data/ext/pg_query/include/nodes/nodes.h +0 -446
  688. data/ext/pg_query/include/nodes/nodetags.h +0 -471
  689. data/ext/pg_query/include/nodes/params.h +0 -170
  690. data/ext/pg_query/include/nodes/parsenodes.h +0 -4050
  691. data/ext/pg_query/include/nodes/pathnodes.h +0 -3384
  692. data/ext/pg_query/include/nodes/pg_list.h +0 -635
  693. data/ext/pg_query/include/nodes/plannodes.h +0 -1592
  694. data/ext/pg_query/include/nodes/primnodes.h +0 -2041
  695. data/ext/pg_query/include/nodes/print.h +0 -34
  696. data/ext/pg_query/include/nodes/queryjumble.h +0 -86
  697. data/ext/pg_query/include/nodes/replnodes.h +0 -111
  698. data/ext/pg_query/include/nodes/supportnodes.h +0 -346
  699. data/ext/pg_query/include/nodes/tidbitmap.h +0 -75
  700. data/ext/pg_query/include/nodes/value.h +0 -90
  701. data/ext/pg_query/include/optimizer/cost.h +0 -215
  702. data/ext/pg_query/include/optimizer/geqo.h +0 -90
  703. data/ext/pg_query/include/optimizer/geqo_gene.h +0 -45
  704. data/ext/pg_query/include/optimizer/optimizer.h +0 -202
  705. data/ext/pg_query/include/optimizer/paths.h +0 -266
  706. data/ext/pg_query/include/optimizer/planmain.h +0 -117
  707. data/ext/pg_query/include/parser/analyze.h +0 -64
  708. data/ext/pg_query/include/parser/kwlist.h +0 -498
  709. data/ext/pg_query/include/parser/parse_agg.h +0 -65
  710. data/ext/pg_query/include/parser/parse_coerce.h +0 -102
  711. data/ext/pg_query/include/parser/parse_expr.h +0 -25
  712. data/ext/pg_query/include/parser/parse_func.h +0 -74
  713. data/ext/pg_query/include/parser/parse_node.h +0 -357
  714. data/ext/pg_query/include/parser/parse_oper.h +0 -65
  715. data/ext/pg_query/include/parser/parse_relation.h +0 -129
  716. data/ext/pg_query/include/parser/parse_type.h +0 -61
  717. data/ext/pg_query/include/parser/parser.h +0 -68
  718. data/ext/pg_query/include/parser/parsetree.h +0 -61
  719. data/ext/pg_query/include/parser/scanner.h +0 -152
  720. data/ext/pg_query/include/parser/scansup.h +0 -27
  721. data/ext/pg_query/include/partitioning/partdefs.h +0 -26
  722. data/ext/pg_query/include/pg_config.h +0 -843
  723. data/ext/pg_query/include/pg_config_manual.h +0 -372
  724. data/ext/pg_query/include/pg_config_os.h +0 -8
  725. data/ext/pg_query/include/pg_getopt.h +0 -56
  726. data/ext/pg_query/include/pg_trace.h +0 -17
  727. data/ext/pg_query/include/pgstat.h +0 -778
  728. data/ext/pg_query/include/pgtime.h +0 -94
  729. data/ext/pg_query/include/pl_gram.h +0 -385
  730. data/ext/pg_query/include/pl_reserved_kwlist.h +0 -52
  731. data/ext/pg_query/include/pl_reserved_kwlist_d.h +0 -114
  732. data/ext/pg_query/include/pl_unreserved_kwlist.h +0 -112
  733. data/ext/pg_query/include/pl_unreserved_kwlist_d.h +0 -246
  734. data/ext/pg_query/include/plerrcodes.h +0 -998
  735. data/ext/pg_query/include/plpgsql.h +0 -1340
  736. data/ext/pg_query/include/port/atomics/arch-arm.h +0 -32
  737. data/ext/pg_query/include/port/atomics/arch-ppc.h +0 -254
  738. data/ext/pg_query/include/port/atomics/arch-x86.h +0 -252
  739. data/ext/pg_query/include/port/atomics/fallback.h +0 -170
  740. data/ext/pg_query/include/port/atomics/generic-gcc.h +0 -286
  741. data/ext/pg_query/include/port/atomics/generic.h +0 -401
  742. data/ext/pg_query/include/port/atomics.h +0 -519
  743. data/ext/pg_query/include/port/pg_bitutils.h +0 -339
  744. data/ext/pg_query/include/port/pg_bswap.h +0 -161
  745. data/ext/pg_query/include/port/pg_crc32c.h +0 -101
  746. data/ext/pg_query/include/port/simd.h +0 -375
  747. data/ext/pg_query/include/port.h +0 -520
  748. data/ext/pg_query/include/portability/instr_time.h +0 -197
  749. data/ext/pg_query/include/postgres.h +0 -579
  750. data/ext/pg_query/include/postmaster/autovacuum.h +0 -80
  751. data/ext/pg_query/include/postmaster/auxprocess.h +0 -20
  752. data/ext/pg_query/include/postmaster/bgworker.h +0 -162
  753. data/ext/pg_query/include/postmaster/bgworker_internals.h +0 -64
  754. data/ext/pg_query/include/postmaster/bgwriter.h +0 -45
  755. data/ext/pg_query/include/postmaster/fork_process.h +0 -17
  756. data/ext/pg_query/include/postmaster/interrupt.h +0 -32
  757. data/ext/pg_query/include/postmaster/pgarch.h +0 -36
  758. data/ext/pg_query/include/postmaster/postmaster.h +0 -81
  759. data/ext/pg_query/include/postmaster/startup.h +0 -41
  760. data/ext/pg_query/include/postmaster/syslogger.h +0 -103
  761. data/ext/pg_query/include/postmaster/walwriter.h +0 -23
  762. data/ext/pg_query/include/regex/regex.h +0 -189
  763. data/ext/pg_query/include/replication/logicallauncher.h +0 -34
  764. data/ext/pg_query/include/replication/logicalproto.h +0 -274
  765. data/ext/pg_query/include/replication/logicalworker.h +0 -32
  766. data/ext/pg_query/include/replication/origin.h +0 -73
  767. data/ext/pg_query/include/replication/reorderbuffer.h +0 -753
  768. data/ext/pg_query/include/replication/slot.h +0 -249
  769. data/ext/pg_query/include/replication/syncrep.h +0 -109
  770. data/ext/pg_query/include/replication/walreceiver.h +0 -478
  771. data/ext/pg_query/include/replication/walsender.h +0 -74
  772. data/ext/pg_query/include/rewrite/prs2lock.h +0 -46
  773. data/ext/pg_query/include/rewrite/rewriteHandler.h +0 -35
  774. data/ext/pg_query/include/rewrite/rewriteManip.h +0 -96
  775. data/ext/pg_query/include/rewrite/rewriteSupport.h +0 -26
  776. data/ext/pg_query/include/src_backend_nodes_copyfuncs.funcs.c +0 -5321
  777. data/ext/pg_query/include/src_backend_nodes_equalfuncs.funcs.c +0 -3354
  778. data/ext/pg_query/include/storage/backendid.h +0 -37
  779. data/ext/pg_query/include/storage/block.h +0 -108
  780. data/ext/pg_query/include/storage/buf.h +0 -46
  781. data/ext/pg_query/include/storage/bufmgr.h +0 -393
  782. data/ext/pg_query/include/storage/bufpage.h +0 -510
  783. data/ext/pg_query/include/storage/condition_variable.h +0 -73
  784. data/ext/pg_query/include/storage/dsm.h +0 -61
  785. data/ext/pg_query/include/storage/dsm_impl.h +0 -79
  786. data/ext/pg_query/include/storage/fd.h +0 -202
  787. data/ext/pg_query/include/storage/fileset.h +0 -40
  788. data/ext/pg_query/include/storage/ipc.h +0 -84
  789. data/ext/pg_query/include/storage/item.h +0 -19
  790. data/ext/pg_query/include/storage/itemid.h +0 -184
  791. data/ext/pg_query/include/storage/itemptr.h +0 -245
  792. data/ext/pg_query/include/storage/large_object.h +0 -100
  793. data/ext/pg_query/include/storage/latch.h +0 -194
  794. data/ext/pg_query/include/storage/lmgr.h +0 -120
  795. data/ext/pg_query/include/storage/lock.h +0 -624
  796. data/ext/pg_query/include/storage/lockdefs.h +0 -59
  797. data/ext/pg_query/include/storage/lwlock.h +0 -220
  798. data/ext/pg_query/include/storage/lwlocknames.h +0 -50
  799. data/ext/pg_query/include/storage/off.h +0 -57
  800. data/ext/pg_query/include/storage/pg_sema.h +0 -61
  801. data/ext/pg_query/include/storage/pg_shmem.h +0 -92
  802. data/ext/pg_query/include/storage/pmsignal.h +0 -105
  803. data/ext/pg_query/include/storage/predicate.h +0 -87
  804. data/ext/pg_query/include/storage/proc.h +0 -466
  805. data/ext/pg_query/include/storage/procarray.h +0 -99
  806. data/ext/pg_query/include/storage/proclist_types.h +0 -51
  807. data/ext/pg_query/include/storage/procsignal.h +0 -73
  808. data/ext/pg_query/include/storage/relfilelocator.h +0 -99
  809. data/ext/pg_query/include/storage/s_lock.h +0 -867
  810. data/ext/pg_query/include/storage/sharedfileset.h +0 -37
  811. data/ext/pg_query/include/storage/shm_mq.h +0 -86
  812. data/ext/pg_query/include/storage/shm_toc.h +0 -58
  813. data/ext/pg_query/include/storage/shmem.h +0 -59
  814. data/ext/pg_query/include/storage/sinval.h +0 -153
  815. data/ext/pg_query/include/storage/sinvaladt.h +0 -45
  816. data/ext/pg_query/include/storage/smgr.h +0 -113
  817. data/ext/pg_query/include/storage/spin.h +0 -77
  818. data/ext/pg_query/include/storage/standby.h +0 -99
  819. data/ext/pg_query/include/storage/standbydefs.h +0 -74
  820. data/ext/pg_query/include/storage/sync.h +0 -66
  821. data/ext/pg_query/include/tcop/cmdtag.h +0 -63
  822. data/ext/pg_query/include/tcop/cmdtaglist.h +0 -218
  823. data/ext/pg_query/include/tcop/deparse_utility.h +0 -108
  824. data/ext/pg_query/include/tcop/dest.h +0 -147
  825. data/ext/pg_query/include/tcop/fastpath.h +0 -20
  826. data/ext/pg_query/include/tcop/pquery.h +0 -51
  827. data/ext/pg_query/include/tcop/tcopprot.h +0 -94
  828. data/ext/pg_query/include/tcop/utility.h +0 -112
  829. data/ext/pg_query/include/tsearch/ts_cache.h +0 -96
  830. data/ext/pg_query/include/utils/acl.h +0 -278
  831. data/ext/pg_query/include/utils/aclchk_internal.h +0 -45
  832. data/ext/pg_query/include/utils/array.h +0 -482
  833. data/ext/pg_query/include/utils/backend_progress.h +0 -45
  834. data/ext/pg_query/include/utils/backend_status.h +0 -342
  835. data/ext/pg_query/include/utils/builtins.h +0 -136
  836. data/ext/pg_query/include/utils/bytea.h +0 -28
  837. data/ext/pg_query/include/utils/catcache.h +0 -231
  838. data/ext/pg_query/include/utils/date.h +0 -118
  839. data/ext/pg_query/include/utils/datetime.h +0 -364
  840. data/ext/pg_query/include/utils/datum.h +0 -76
  841. data/ext/pg_query/include/utils/dsa.h +0 -127
  842. data/ext/pg_query/include/utils/elog.h +0 -545
  843. data/ext/pg_query/include/utils/errcodes.h +0 -354
  844. data/ext/pg_query/include/utils/expandeddatum.h +0 -170
  845. data/ext/pg_query/include/utils/expandedrecord.h +0 -241
  846. data/ext/pg_query/include/utils/float.h +0 -357
  847. data/ext/pg_query/include/utils/fmgroids.h +0 -3314
  848. data/ext/pg_query/include/utils/fmgrprotos.h +0 -2871
  849. data/ext/pg_query/include/utils/fmgrtab.h +0 -49
  850. data/ext/pg_query/include/utils/guc.h +0 -442
  851. data/ext/pg_query/include/utils/guc_hooks.h +0 -163
  852. data/ext/pg_query/include/utils/guc_tables.h +0 -322
  853. data/ext/pg_query/include/utils/hsearch.h +0 -153
  854. data/ext/pg_query/include/utils/inval.h +0 -68
  855. data/ext/pg_query/include/utils/logtape.h +0 -77
  856. data/ext/pg_query/include/utils/lsyscache.h +0 -212
  857. data/ext/pg_query/include/utils/memdebug.h +0 -82
  858. data/ext/pg_query/include/utils/memutils.h +0 -186
  859. data/ext/pg_query/include/utils/memutils_internal.h +0 -136
  860. data/ext/pg_query/include/utils/memutils_memorychunk.h +0 -237
  861. data/ext/pg_query/include/utils/numeric.h +0 -105
  862. data/ext/pg_query/include/utils/palloc.h +0 -165
  863. data/ext/pg_query/include/utils/partcache.h +0 -103
  864. data/ext/pg_query/include/utils/pg_locale.h +0 -135
  865. data/ext/pg_query/include/utils/pgstat_internal.h +0 -814
  866. data/ext/pg_query/include/utils/pidfile.h +0 -56
  867. data/ext/pg_query/include/utils/plancache.h +0 -236
  868. data/ext/pg_query/include/utils/portal.h +0 -252
  869. data/ext/pg_query/include/utils/queryenvironment.h +0 -74
  870. data/ext/pg_query/include/utils/regproc.h +0 -39
  871. data/ext/pg_query/include/utils/rel.h +0 -712
  872. data/ext/pg_query/include/utils/relcache.h +0 -158
  873. data/ext/pg_query/include/utils/reltrigger.h +0 -81
  874. data/ext/pg_query/include/utils/resowner.h +0 -86
  875. data/ext/pg_query/include/utils/ruleutils.h +0 -52
  876. data/ext/pg_query/include/utils/sharedtuplestore.h +0 -61
  877. data/ext/pg_query/include/utils/snapmgr.h +0 -181
  878. data/ext/pg_query/include/utils/snapshot.h +0 -219
  879. data/ext/pg_query/include/utils/sortsupport.h +0 -391
  880. data/ext/pg_query/include/utils/syscache.h +0 -227
  881. data/ext/pg_query/include/utils/timeout.h +0 -95
  882. data/ext/pg_query/include/utils/timestamp.h +0 -147
  883. data/ext/pg_query/include/utils/tuplesort.h +0 -445
  884. data/ext/pg_query/include/utils/tuplestore.h +0 -91
  885. data/ext/pg_query/include/utils/typcache.h +0 -209
  886. data/ext/pg_query/include/utils/varlena.h +0 -53
  887. data/ext/pg_query/include/utils/wait_event.h +0 -294
  888. data/ext/pg_query/include/utils/xml.h +0 -94
  889. data/ext/pg_query/include/varatt.h +0 -358
  890. data/ext/pg_query/src_backend_postmaster_postmaster.c +0 -2220
  891. data/ext/pg_query/src_port_strnlen.c +0 -39
  892. /data/ext/pg_query/include/{access → postgres/access}/rmgr.h +0 -0
  893. /data/ext/pg_query/include/{commands → postgres/commands}/user.h +0 -0
  894. /data/ext/pg_query/include/{common → postgres/common}/unicode_nonspacing_table.h +0 -0
  895. /data/ext/pg_query/include/{pg_config_ext.h → postgres/pg_config_ext.h} +0 -0
  896. /data/ext/pg_query/include/{postgres_ext.h → postgres/postgres_ext.h} +0 -0
  897. /data/ext/pg_query/include/{utils → postgres/utils}/probes.h +0 -0
  898. /data/ext/pg_query/include/{utils → postgres/utils}/ps_status.h +0 -0
@@ -0,0 +1,624 @@
1
+ /*-------------------------------------------------------------------------
2
+ *
3
+ * lock.h
4
+ * POSTGRES low-level lock mechanism
5
+ *
6
+ *
7
+ * Portions Copyright (c) 1996-2024, PostgreSQL Global Development Group
8
+ * Portions Copyright (c) 1994, Regents of the University of California
9
+ *
10
+ * src/include/storage/lock.h
11
+ *
12
+ *-------------------------------------------------------------------------
13
+ */
14
+ #ifndef LOCK_H_
15
+ #define LOCK_H_
16
+
17
+ #ifdef FRONTEND
18
+ #error "lock.h may not be included from frontend code"
19
+ #endif
20
+
21
+ #include "lib/ilist.h"
22
+ #include "storage/lockdefs.h"
23
+ #include "storage/lwlock.h"
24
+ #include "storage/procnumber.h"
25
+ #include "storage/shmem.h"
26
+ #include "utils/timestamp.h"
27
+
28
+ /* struct PGPROC is declared in proc.h, but must forward-reference it */
29
+ typedef struct PGPROC PGPROC;
30
+
31
+ /* GUC variables */
32
+ extern PGDLLIMPORT int max_locks_per_xact;
33
+
34
+ #ifdef LOCK_DEBUG
35
+ extern PGDLLIMPORT int Trace_lock_oidmin;
36
+ extern PGDLLIMPORT bool Trace_locks;
37
+ extern PGDLLIMPORT bool Trace_userlocks;
38
+ extern PGDLLIMPORT int Trace_lock_table;
39
+ extern PGDLLIMPORT bool Debug_deadlocks;
40
+ #endif /* LOCK_DEBUG */
41
+
42
+
43
+ /*
44
+ * Top-level transactions are identified by VirtualTransactionIDs comprising
45
+ * PGPROC fields procNumber and lxid. For recovered prepared transactions, the
46
+ * LocalTransactionId is an ordinary XID; LOCKTAG_VIRTUALTRANSACTION never
47
+ * refers to that kind. These are guaranteed unique over the short term, but
48
+ * will be reused after a database restart or XID wraparound; hence they
49
+ * should never be stored on disk.
50
+ *
51
+ * Note that struct VirtualTransactionId can not be assumed to be atomically
52
+ * assignable as a whole. However, type LocalTransactionId is assumed to
53
+ * be atomically assignable, and the proc number doesn't change often enough
54
+ * to be a problem, so we can fetch or assign the two fields separately.
55
+ * We deliberately refrain from using the struct within PGPROC, to prevent
56
+ * coding errors from trying to use struct assignment with it; instead use
57
+ * GET_VXID_FROM_PGPROC().
58
+ */
59
+ typedef struct
60
+ {
61
+ ProcNumber procNumber; /* proc number of the PGPROC */
62
+ LocalTransactionId localTransactionId; /* lxid from PGPROC */
63
+ } VirtualTransactionId;
64
+
65
+ #define InvalidLocalTransactionId 0
66
+ #define LocalTransactionIdIsValid(lxid) ((lxid) != InvalidLocalTransactionId)
67
+ #define VirtualTransactionIdIsValid(vxid) \
68
+ (LocalTransactionIdIsValid((vxid).localTransactionId))
69
+ #define VirtualTransactionIdIsRecoveredPreparedXact(vxid) \
70
+ ((vxid).procNumber == INVALID_PROC_NUMBER)
71
+ #define VirtualTransactionIdEquals(vxid1, vxid2) \
72
+ ((vxid1).procNumber == (vxid2).procNumber && \
73
+ (vxid1).localTransactionId == (vxid2).localTransactionId)
74
+ #define SetInvalidVirtualTransactionId(vxid) \
75
+ ((vxid).procNumber = INVALID_PROC_NUMBER, \
76
+ (vxid).localTransactionId = InvalidLocalTransactionId)
77
+ #define GET_VXID_FROM_PGPROC(vxid_dst, proc) \
78
+ ((vxid_dst).procNumber = (proc).vxid.procNumber, \
79
+ (vxid_dst).localTransactionId = (proc).vxid.lxid)
80
+
81
+ /* MAX_LOCKMODES cannot be larger than the # of bits in LOCKMASK */
82
+ #define MAX_LOCKMODES 10
83
+
84
+ #define LOCKBIT_ON(lockmode) (1 << (lockmode))
85
+ #define LOCKBIT_OFF(lockmode) (~(1 << (lockmode)))
86
+
87
+
88
+ /*
89
+ * This data structure defines the locking semantics associated with a
90
+ * "lock method". The semantics specify the meaning of each lock mode
91
+ * (by defining which lock modes it conflicts with).
92
+ * All of this data is constant and is kept in const tables.
93
+ *
94
+ * numLockModes -- number of lock modes (READ,WRITE,etc) that
95
+ * are defined in this lock method. Must be less than MAX_LOCKMODES.
96
+ *
97
+ * conflictTab -- this is an array of bitmasks showing lock
98
+ * mode conflicts. conflictTab[i] is a mask with the j-th bit
99
+ * turned on if lock modes i and j conflict. Lock modes are
100
+ * numbered 1..numLockModes; conflictTab[0] is unused.
101
+ *
102
+ * lockModeNames -- ID strings for debug printouts.
103
+ *
104
+ * trace_flag -- pointer to GUC trace flag for this lock method. (The
105
+ * GUC variable is not constant, but we use "const" here to denote that
106
+ * it can't be changed through this reference.)
107
+ */
108
+ typedef struct LockMethodData
109
+ {
110
+ int numLockModes;
111
+ const LOCKMASK *conflictTab;
112
+ const char *const *lockModeNames;
113
+ const bool *trace_flag;
114
+ } LockMethodData;
115
+
116
+ typedef const LockMethodData *LockMethod;
117
+
118
+ /*
119
+ * Lock methods are identified by LOCKMETHODID. (Despite the declaration as
120
+ * uint16, we are constrained to 256 lockmethods by the layout of LOCKTAG.)
121
+ */
122
+ typedef uint16 LOCKMETHODID;
123
+
124
+ /* These identify the known lock methods */
125
+ #define DEFAULT_LOCKMETHOD 1
126
+ #define USER_LOCKMETHOD 2
127
+
128
+ /*
129
+ * LOCKTAG is the key information needed to look up a LOCK item in the
130
+ * lock hashtable. A LOCKTAG value uniquely identifies a lockable object.
131
+ *
132
+ * The LockTagType enum defines the different kinds of objects we can lock.
133
+ * We can handle up to 256 different LockTagTypes.
134
+ */
135
+ typedef enum LockTagType
136
+ {
137
+ LOCKTAG_RELATION, /* whole relation */
138
+ LOCKTAG_RELATION_EXTEND, /* the right to extend a relation */
139
+ LOCKTAG_DATABASE_FROZEN_IDS, /* pg_database.datfrozenxid */
140
+ LOCKTAG_PAGE, /* one page of a relation */
141
+ LOCKTAG_TUPLE, /* one physical tuple */
142
+ LOCKTAG_TRANSACTION, /* transaction (for waiting for xact done) */
143
+ LOCKTAG_VIRTUALTRANSACTION, /* virtual transaction (ditto) */
144
+ LOCKTAG_SPECULATIVE_TOKEN, /* speculative insertion Xid and token */
145
+ LOCKTAG_OBJECT, /* non-relation database object */
146
+ LOCKTAG_USERLOCK, /* reserved for old contrib/userlock code */
147
+ LOCKTAG_ADVISORY, /* advisory user locks */
148
+ LOCKTAG_APPLY_TRANSACTION, /* transaction being applied on a logical
149
+ * replication subscriber */
150
+ } LockTagType;
151
+
152
+ #define LOCKTAG_LAST_TYPE LOCKTAG_APPLY_TRANSACTION
153
+
154
+ extern PGDLLIMPORT const char *const LockTagTypeNames[];
155
+
156
+ /*
157
+ * The LOCKTAG struct is defined with malice aforethought to fit into 16
158
+ * bytes with no padding. Note that this would need adjustment if we were
159
+ * to widen Oid, BlockNumber, or TransactionId to more than 32 bits.
160
+ *
161
+ * We include lockmethodid in the locktag so that a single hash table in
162
+ * shared memory can store locks of different lockmethods.
163
+ */
164
+ typedef struct LOCKTAG
165
+ {
166
+ uint32 locktag_field1; /* a 32-bit ID field */
167
+ uint32 locktag_field2; /* a 32-bit ID field */
168
+ uint32 locktag_field3; /* a 32-bit ID field */
169
+ uint16 locktag_field4; /* a 16-bit ID field */
170
+ uint8 locktag_type; /* see enum LockTagType */
171
+ uint8 locktag_lockmethodid; /* lockmethod indicator */
172
+ } LOCKTAG;
173
+
174
+ /*
175
+ * These macros define how we map logical IDs of lockable objects into
176
+ * the physical fields of LOCKTAG. Use these to set up LOCKTAG values,
177
+ * rather than accessing the fields directly. Note multiple eval of target!
178
+ */
179
+
180
+ /* ID info for a relation is DB OID + REL OID; DB OID = 0 if shared */
181
+ #define SET_LOCKTAG_RELATION(locktag,dboid,reloid) \
182
+ ((locktag).locktag_field1 = (dboid), \
183
+ (locktag).locktag_field2 = (reloid), \
184
+ (locktag).locktag_field3 = 0, \
185
+ (locktag).locktag_field4 = 0, \
186
+ (locktag).locktag_type = LOCKTAG_RELATION, \
187
+ (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
188
+
189
+ /* same ID info as RELATION */
190
+ #define SET_LOCKTAG_RELATION_EXTEND(locktag,dboid,reloid) \
191
+ ((locktag).locktag_field1 = (dboid), \
192
+ (locktag).locktag_field2 = (reloid), \
193
+ (locktag).locktag_field3 = 0, \
194
+ (locktag).locktag_field4 = 0, \
195
+ (locktag).locktag_type = LOCKTAG_RELATION_EXTEND, \
196
+ (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
197
+
198
+ /* ID info for frozen IDs is DB OID */
199
+ #define SET_LOCKTAG_DATABASE_FROZEN_IDS(locktag,dboid) \
200
+ ((locktag).locktag_field1 = (dboid), \
201
+ (locktag).locktag_field2 = 0, \
202
+ (locktag).locktag_field3 = 0, \
203
+ (locktag).locktag_field4 = 0, \
204
+ (locktag).locktag_type = LOCKTAG_DATABASE_FROZEN_IDS, \
205
+ (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
206
+
207
+ /* ID info for a page is RELATION info + BlockNumber */
208
+ #define SET_LOCKTAG_PAGE(locktag,dboid,reloid,blocknum) \
209
+ ((locktag).locktag_field1 = (dboid), \
210
+ (locktag).locktag_field2 = (reloid), \
211
+ (locktag).locktag_field3 = (blocknum), \
212
+ (locktag).locktag_field4 = 0, \
213
+ (locktag).locktag_type = LOCKTAG_PAGE, \
214
+ (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
215
+
216
+ /* ID info for a tuple is PAGE info + OffsetNumber */
217
+ #define SET_LOCKTAG_TUPLE(locktag,dboid,reloid,blocknum,offnum) \
218
+ ((locktag).locktag_field1 = (dboid), \
219
+ (locktag).locktag_field2 = (reloid), \
220
+ (locktag).locktag_field3 = (blocknum), \
221
+ (locktag).locktag_field4 = (offnum), \
222
+ (locktag).locktag_type = LOCKTAG_TUPLE, \
223
+ (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
224
+
225
+ /* ID info for a transaction is its TransactionId */
226
+ #define SET_LOCKTAG_TRANSACTION(locktag,xid) \
227
+ ((locktag).locktag_field1 = (xid), \
228
+ (locktag).locktag_field2 = 0, \
229
+ (locktag).locktag_field3 = 0, \
230
+ (locktag).locktag_field4 = 0, \
231
+ (locktag).locktag_type = LOCKTAG_TRANSACTION, \
232
+ (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
233
+
234
+ /* ID info for a virtual transaction is its VirtualTransactionId */
235
+ #define SET_LOCKTAG_VIRTUALTRANSACTION(locktag,vxid) \
236
+ ((locktag).locktag_field1 = (vxid).procNumber, \
237
+ (locktag).locktag_field2 = (vxid).localTransactionId, \
238
+ (locktag).locktag_field3 = 0, \
239
+ (locktag).locktag_field4 = 0, \
240
+ (locktag).locktag_type = LOCKTAG_VIRTUALTRANSACTION, \
241
+ (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
242
+
243
+ /*
244
+ * ID info for a speculative insert is TRANSACTION info +
245
+ * its speculative insert counter.
246
+ */
247
+ #define SET_LOCKTAG_SPECULATIVE_INSERTION(locktag,xid,token) \
248
+ ((locktag).locktag_field1 = (xid), \
249
+ (locktag).locktag_field2 = (token), \
250
+ (locktag).locktag_field3 = 0, \
251
+ (locktag).locktag_field4 = 0, \
252
+ (locktag).locktag_type = LOCKTAG_SPECULATIVE_TOKEN, \
253
+ (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
254
+
255
+ /*
256
+ * ID info for an object is DB OID + CLASS OID + OBJECT OID + SUBID
257
+ *
258
+ * Note: object ID has same representation as in pg_depend and
259
+ * pg_description, but notice that we are constraining SUBID to 16 bits.
260
+ * Also, we use DB OID = 0 for shared objects such as tablespaces.
261
+ */
262
+ #define SET_LOCKTAG_OBJECT(locktag,dboid,classoid,objoid,objsubid) \
263
+ ((locktag).locktag_field1 = (dboid), \
264
+ (locktag).locktag_field2 = (classoid), \
265
+ (locktag).locktag_field3 = (objoid), \
266
+ (locktag).locktag_field4 = (objsubid), \
267
+ (locktag).locktag_type = LOCKTAG_OBJECT, \
268
+ (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
269
+
270
+ #define SET_LOCKTAG_ADVISORY(locktag,id1,id2,id3,id4) \
271
+ ((locktag).locktag_field1 = (id1), \
272
+ (locktag).locktag_field2 = (id2), \
273
+ (locktag).locktag_field3 = (id3), \
274
+ (locktag).locktag_field4 = (id4), \
275
+ (locktag).locktag_type = LOCKTAG_ADVISORY, \
276
+ (locktag).locktag_lockmethodid = USER_LOCKMETHOD)
277
+
278
+ /*
279
+ * ID info for a remote transaction on a logical replication subscriber is: DB
280
+ * OID + SUBSCRIPTION OID + TRANSACTION ID + OBJID
281
+ */
282
+ #define SET_LOCKTAG_APPLY_TRANSACTION(locktag,dboid,suboid,xid,objid) \
283
+ ((locktag).locktag_field1 = (dboid), \
284
+ (locktag).locktag_field2 = (suboid), \
285
+ (locktag).locktag_field3 = (xid), \
286
+ (locktag).locktag_field4 = (objid), \
287
+ (locktag).locktag_type = LOCKTAG_APPLY_TRANSACTION, \
288
+ (locktag).locktag_lockmethodid = DEFAULT_LOCKMETHOD)
289
+
290
+ /*
291
+ * Per-locked-object lock information:
292
+ *
293
+ * tag -- uniquely identifies the object being locked
294
+ * grantMask -- bitmask for all lock types currently granted on this object.
295
+ * waitMask -- bitmask for all lock types currently awaited on this object.
296
+ * procLocks -- list of PROCLOCK objects for this lock.
297
+ * waitProcs -- queue of processes waiting for this lock.
298
+ * requested -- count of each lock type currently requested on the lock
299
+ * (includes requests already granted!!).
300
+ * nRequested -- total requested locks of all types.
301
+ * granted -- count of each lock type currently granted on the lock.
302
+ * nGranted -- total granted locks of all types.
303
+ *
304
+ * Note: these counts count 1 for each backend. Internally to a backend,
305
+ * there may be multiple grabs on a particular lock, but this is not reflected
306
+ * into shared memory.
307
+ */
308
+ typedef struct LOCK
309
+ {
310
+ /* hash key */
311
+ LOCKTAG tag; /* unique identifier of lockable object */
312
+
313
+ /* data */
314
+ LOCKMASK grantMask; /* bitmask for lock types already granted */
315
+ LOCKMASK waitMask; /* bitmask for lock types awaited */
316
+ dlist_head procLocks; /* list of PROCLOCK objects assoc. with lock */
317
+ dclist_head waitProcs; /* list of PGPROC objects waiting on lock */
318
+ int requested[MAX_LOCKMODES]; /* counts of requested locks */
319
+ int nRequested; /* total of requested[] array */
320
+ int granted[MAX_LOCKMODES]; /* counts of granted locks */
321
+ int nGranted; /* total of granted[] array */
322
+ } LOCK;
323
+
324
+ #define LOCK_LOCKMETHOD(lock) ((LOCKMETHODID) (lock).tag.locktag_lockmethodid)
325
+ #define LOCK_LOCKTAG(lock) ((LockTagType) (lock).tag.locktag_type)
326
+
327
+
328
+ /*
329
+ * We may have several different backends holding or awaiting locks
330
+ * on the same lockable object. We need to store some per-holder/waiter
331
+ * information for each such holder (or would-be holder). This is kept in
332
+ * a PROCLOCK struct.
333
+ *
334
+ * PROCLOCKTAG is the key information needed to look up a PROCLOCK item in the
335
+ * proclock hashtable. A PROCLOCKTAG value uniquely identifies the combination
336
+ * of a lockable object and a holder/waiter for that object. (We can use
337
+ * pointers here because the PROCLOCKTAG need only be unique for the lifespan
338
+ * of the PROCLOCK, and it will never outlive the lock or the proc.)
339
+ *
340
+ * Internally to a backend, it is possible for the same lock to be held
341
+ * for different purposes: the backend tracks transaction locks separately
342
+ * from session locks. However, this is not reflected in the shared-memory
343
+ * state: we only track which backend(s) hold the lock. This is OK since a
344
+ * backend can never block itself.
345
+ *
346
+ * The holdMask field shows the already-granted locks represented by this
347
+ * proclock. Note that there will be a proclock object, possibly with
348
+ * zero holdMask, for any lock that the process is currently waiting on.
349
+ * Otherwise, proclock objects whose holdMasks are zero are recycled
350
+ * as soon as convenient.
351
+ *
352
+ * releaseMask is workspace for LockReleaseAll(): it shows the locks due
353
+ * to be released during the current call. This must only be examined or
354
+ * set by the backend owning the PROCLOCK.
355
+ *
356
+ * Each PROCLOCK object is linked into lists for both the associated LOCK
357
+ * object and the owning PGPROC object. Note that the PROCLOCK is entered
358
+ * into these lists as soon as it is created, even if no lock has yet been
359
+ * granted. A PGPROC that is waiting for a lock to be granted will also be
360
+ * linked into the lock's waitProcs queue.
361
+ */
362
+ typedef struct PROCLOCKTAG
363
+ {
364
+ /* NB: we assume this struct contains no padding! */
365
+ LOCK *myLock; /* link to per-lockable-object information */
366
+ PGPROC *myProc; /* link to PGPROC of owning backend */
367
+ } PROCLOCKTAG;
368
+
369
+ typedef struct PROCLOCK
370
+ {
371
+ /* tag */
372
+ PROCLOCKTAG tag; /* unique identifier of proclock object */
373
+
374
+ /* data */
375
+ PGPROC *groupLeader; /* proc's lock group leader, or proc itself */
376
+ LOCKMASK holdMask; /* bitmask for lock types currently held */
377
+ LOCKMASK releaseMask; /* bitmask for lock types to be released */
378
+ dlist_node lockLink; /* list link in LOCK's list of proclocks */
379
+ dlist_node procLink; /* list link in PGPROC's list of proclocks */
380
+ } PROCLOCK;
381
+
382
+ #define PROCLOCK_LOCKMETHOD(proclock) \
383
+ LOCK_LOCKMETHOD(*((proclock).tag.myLock))
384
+
385
+ /*
386
+ * Each backend also maintains a local hash table with information about each
387
+ * lock it is currently interested in. In particular the local table counts
388
+ * the number of times that lock has been acquired. This allows multiple
389
+ * requests for the same lock to be executed without additional accesses to
390
+ * shared memory. We also track the number of lock acquisitions per
391
+ * ResourceOwner, so that we can release just those locks belonging to a
392
+ * particular ResourceOwner.
393
+ *
394
+ * When holding a lock taken "normally", the lock and proclock fields always
395
+ * point to the associated objects in shared memory. However, if we acquired
396
+ * the lock via the fast-path mechanism, the lock and proclock fields are set
397
+ * to NULL, since there probably aren't any such objects in shared memory.
398
+ * (If the lock later gets promoted to normal representation, we may eventually
399
+ * update our locallock's lock/proclock fields after finding the shared
400
+ * objects.)
401
+ *
402
+ * Caution: a locallock object can be left over from a failed lock acquisition
403
+ * attempt. In this case its lock/proclock fields are untrustworthy, since
404
+ * the shared lock object is neither held nor awaited, and hence is available
405
+ * to be reclaimed. If nLocks > 0 then these pointers must either be valid or
406
+ * NULL, but when nLocks == 0 they should be considered garbage.
407
+ */
408
+ typedef struct LOCALLOCKTAG
409
+ {
410
+ LOCKTAG lock; /* identifies the lockable object */
411
+ LOCKMODE mode; /* lock mode for this table entry */
412
+ } LOCALLOCKTAG;
413
+
414
+ typedef struct LOCALLOCKOWNER
415
+ {
416
+ /*
417
+ * Note: if owner is NULL then the lock is held on behalf of the session;
418
+ * otherwise it is held on behalf of my current transaction.
419
+ *
420
+ * Must use a forward struct reference to avoid circularity.
421
+ */
422
+ struct ResourceOwnerData *owner;
423
+ int64 nLocks; /* # of times held by this owner */
424
+ } LOCALLOCKOWNER;
425
+
426
+ typedef struct LOCALLOCK
427
+ {
428
+ /* tag */
429
+ LOCALLOCKTAG tag; /* unique identifier of locallock entry */
430
+
431
+ /* data */
432
+ uint32 hashcode; /* copy of LOCKTAG's hash value */
433
+ LOCK *lock; /* associated LOCK object, if any */
434
+ PROCLOCK *proclock; /* associated PROCLOCK object, if any */
435
+ int64 nLocks; /* total number of times lock is held */
436
+ int numLockOwners; /* # of relevant ResourceOwners */
437
+ int maxLockOwners; /* allocated size of array */
438
+ LOCALLOCKOWNER *lockOwners; /* dynamically resizable array */
439
+ bool holdsStrongLockCount; /* bumped FastPathStrongRelationLocks */
440
+ bool lockCleared; /* we read all sinval msgs for lock */
441
+ } LOCALLOCK;
442
+
443
+ #define LOCALLOCK_LOCKMETHOD(llock) ((llock).tag.lock.locktag_lockmethodid)
444
+ #define LOCALLOCK_LOCKTAG(llock) ((LockTagType) (llock).tag.lock.locktag_type)
445
+
446
+
447
+ /*
448
+ * These structures hold information passed from lmgr internals to the lock
449
+ * listing user-level functions (in lockfuncs.c).
450
+ */
451
+
452
+ typedef struct LockInstanceData
453
+ {
454
+ LOCKTAG locktag; /* tag for locked object */
455
+ LOCKMASK holdMask; /* locks held by this PGPROC */
456
+ LOCKMODE waitLockMode; /* lock awaited by this PGPROC, if any */
457
+ VirtualTransactionId vxid; /* virtual transaction ID of this PGPROC */
458
+ TimestampTz waitStart; /* time at which this PGPROC started waiting
459
+ * for lock */
460
+ int pid; /* pid of this PGPROC */
461
+ int leaderPid; /* pid of group leader; = pid if no group */
462
+ bool fastpath; /* taken via fastpath? */
463
+ } LockInstanceData;
464
+
465
+ typedef struct LockData
466
+ {
467
+ int nelements; /* The length of the array */
468
+ LockInstanceData *locks; /* Array of per-PROCLOCK information */
469
+ } LockData;
470
+
471
+ typedef struct BlockedProcData
472
+ {
473
+ int pid; /* pid of a blocked PGPROC */
474
+ /* Per-PROCLOCK information about PROCLOCKs of the lock the pid awaits */
475
+ /* (these fields refer to indexes in BlockedProcsData.locks[]) */
476
+ int first_lock; /* index of first relevant LockInstanceData */
477
+ int num_locks; /* number of relevant LockInstanceDatas */
478
+ /* PIDs of PGPROCs that are ahead of "pid" in the lock's wait queue */
479
+ /* (these fields refer to indexes in BlockedProcsData.waiter_pids[]) */
480
+ int first_waiter; /* index of first preceding waiter */
481
+ int num_waiters; /* number of preceding waiters */
482
+ } BlockedProcData;
483
+
484
+ typedef struct BlockedProcsData
485
+ {
486
+ BlockedProcData *procs; /* Array of per-blocked-proc information */
487
+ LockInstanceData *locks; /* Array of per-PROCLOCK information */
488
+ int *waiter_pids; /* Array of PIDs of other blocked PGPROCs */
489
+ int nprocs; /* # of valid entries in procs[] array */
490
+ int maxprocs; /* Allocated length of procs[] array */
491
+ int nlocks; /* # of valid entries in locks[] array */
492
+ int maxlocks; /* Allocated length of locks[] array */
493
+ int npids; /* # of valid entries in waiter_pids[] array */
494
+ int maxpids; /* Allocated length of waiter_pids[] array */
495
+ } BlockedProcsData;
496
+
497
+
498
+ /* Result codes for LockAcquire() */
499
+ typedef enum
500
+ {
501
+ LOCKACQUIRE_NOT_AVAIL, /* lock not available, and dontWait=true */
502
+ LOCKACQUIRE_OK, /* lock successfully acquired */
503
+ LOCKACQUIRE_ALREADY_HELD, /* incremented count for lock already held */
504
+ LOCKACQUIRE_ALREADY_CLEAR, /* incremented count for lock already clear */
505
+ } LockAcquireResult;
506
+
507
+ /* Deadlock states identified by DeadLockCheck() */
508
+ typedef enum
509
+ {
510
+ DS_NOT_YET_CHECKED, /* no deadlock check has run yet */
511
+ DS_NO_DEADLOCK, /* no deadlock detected */
512
+ DS_SOFT_DEADLOCK, /* deadlock avoided by queue rearrangement */
513
+ DS_HARD_DEADLOCK, /* deadlock, no way out but ERROR */
514
+ DS_BLOCKED_BY_AUTOVACUUM, /* no deadlock; queue blocked by autovacuum
515
+ * worker */
516
+ } DeadLockState;
517
+
518
+ /*
519
+ * The lockmgr's shared hash tables are partitioned to reduce contention.
520
+ * To determine which partition a given locktag belongs to, compute the tag's
521
+ * hash code with LockTagHashCode(), then apply one of these macros.
522
+ * NB: NUM_LOCK_PARTITIONS must be a power of 2!
523
+ */
524
+ #define LockHashPartition(hashcode) \
525
+ ((hashcode) % NUM_LOCK_PARTITIONS)
526
+ #define LockHashPartitionLock(hashcode) \
527
+ (&MainLWLockArray[LOCK_MANAGER_LWLOCK_OFFSET + \
528
+ LockHashPartition(hashcode)].lock)
529
+ #define LockHashPartitionLockByIndex(i) \
530
+ (&MainLWLockArray[LOCK_MANAGER_LWLOCK_OFFSET + (i)].lock)
531
+
532
+ /*
533
+ * The deadlock detector needs to be able to access lockGroupLeader and
534
+ * related fields in the PGPROC, so we arrange for those fields to be protected
535
+ * by one of the lock hash partition locks. Since the deadlock detector
536
+ * acquires all such locks anyway, this makes it safe for it to access these
537
+ * fields without doing anything extra. To avoid contention as much as
538
+ * possible, we map different PGPROCs to different partition locks. The lock
539
+ * used for a given lock group is determined by the group leader's pgprocno.
540
+ */
541
+ #define LockHashPartitionLockByProc(leader_pgproc) \
542
+ LockHashPartitionLock(GetNumberFromPGProc(leader_pgproc))
543
+
544
+ /*
545
+ * function prototypes
546
+ */
547
+ extern void InitLocks(void);
548
+ extern LockMethod GetLocksMethodTable(const LOCK *lock);
549
+ extern LockMethod GetLockTagsMethodTable(const LOCKTAG *locktag);
550
+ extern uint32 LockTagHashCode(const LOCKTAG *locktag);
551
+ extern bool DoLockModesConflict(LOCKMODE mode1, LOCKMODE mode2);
552
+ extern LockAcquireResult LockAcquire(const LOCKTAG *locktag,
553
+ LOCKMODE lockmode,
554
+ bool sessionLock,
555
+ bool dontWait);
556
+ extern LockAcquireResult LockAcquireExtended(const LOCKTAG *locktag,
557
+ LOCKMODE lockmode,
558
+ bool sessionLock,
559
+ bool dontWait,
560
+ bool reportMemoryError,
561
+ LOCALLOCK **locallockp);
562
+ extern void AbortStrongLockAcquire(void);
563
+ extern void MarkLockClear(LOCALLOCK *locallock);
564
+ extern bool LockRelease(const LOCKTAG *locktag,
565
+ LOCKMODE lockmode, bool sessionLock);
566
+ extern void LockReleaseAll(LOCKMETHODID lockmethodid, bool allLocks);
567
+ extern void LockReleaseSession(LOCKMETHODID lockmethodid);
568
+ extern void LockReleaseCurrentOwner(LOCALLOCK **locallocks, int nlocks);
569
+ extern void LockReassignCurrentOwner(LOCALLOCK **locallocks, int nlocks);
570
+ extern bool LockHeldByMe(const LOCKTAG *locktag,
571
+ LOCKMODE lockmode, bool orstronger);
572
+ #ifdef USE_ASSERT_CHECKING
573
+ extern HTAB *GetLockMethodLocalHash(void);
574
+ #endif
575
+ extern bool LockHasWaiters(const LOCKTAG *locktag,
576
+ LOCKMODE lockmode, bool sessionLock);
577
+ extern VirtualTransactionId *GetLockConflicts(const LOCKTAG *locktag,
578
+ LOCKMODE lockmode, int *countp);
579
+ extern void AtPrepare_Locks(void);
580
+ extern void PostPrepare_Locks(TransactionId xid);
581
+ extern bool LockCheckConflicts(LockMethod lockMethodTable,
582
+ LOCKMODE lockmode,
583
+ LOCK *lock, PROCLOCK *proclock);
584
+ extern void GrantLock(LOCK *lock, PROCLOCK *proclock, LOCKMODE lockmode);
585
+ extern void GrantAwaitedLock(void);
586
+ extern void RemoveFromWaitQueue(PGPROC *proc, uint32 hashcode);
587
+ extern Size LockShmemSize(void);
588
+ extern LockData *GetLockStatusData(void);
589
+ extern BlockedProcsData *GetBlockerStatusData(int blocked_pid);
590
+
591
+ extern xl_standby_lock *GetRunningTransactionLocks(int *nlocks);
592
+ extern const char *GetLockmodeName(LOCKMETHODID lockmethodid, LOCKMODE mode);
593
+
594
+ extern void lock_twophase_recover(TransactionId xid, uint16 info,
595
+ void *recdata, uint32 len);
596
+ extern void lock_twophase_postcommit(TransactionId xid, uint16 info,
597
+ void *recdata, uint32 len);
598
+ extern void lock_twophase_postabort(TransactionId xid, uint16 info,
599
+ void *recdata, uint32 len);
600
+ extern void lock_twophase_standby_recover(TransactionId xid, uint16 info,
601
+ void *recdata, uint32 len);
602
+
603
+ extern DeadLockState DeadLockCheck(PGPROC *proc);
604
+ extern PGPROC *GetBlockingAutoVacuumPgproc(void);
605
+ extern void DeadLockReport(void) pg_attribute_noreturn();
606
+ extern void RememberSimpleDeadLock(PGPROC *proc1,
607
+ LOCKMODE lockmode,
608
+ LOCK *lock,
609
+ PGPROC *proc2);
610
+ extern void InitDeadLockChecking(void);
611
+
612
+ extern int LockWaiterCount(const LOCKTAG *locktag);
613
+
614
+ #ifdef LOCK_DEBUG
615
+ extern void DumpLocks(PGPROC *proc);
616
+ extern void DumpAllLocks(void);
617
+ #endif
618
+
619
+ /* Lock a VXID (used to wait for a transaction to finish) */
620
+ extern void VirtualXactLockTableInsert(VirtualTransactionId vxid);
621
+ extern void VirtualXactLockTableCleanup(void);
622
+ extern bool VirtualXactLock(VirtualTransactionId vxid, bool wait);
623
+
624
+ #endif /* LOCK_H_ */
@@ -0,0 +1,59 @@
1
+ /*-------------------------------------------------------------------------
2
+ *
3
+ * lockdefs.h
4
+ * Frontend exposed parts of postgres' low level lock mechanism
5
+ *
6
+ * The split between lockdefs.h and lock.h is not very principled. This file
7
+ * contains definition that have to (indirectly) be available when included by
8
+ * FRONTEND code.
9
+ *
10
+ * Portions Copyright (c) 1996-2024, PostgreSQL Global Development Group
11
+ * Portions Copyright (c) 1994, Regents of the University of California
12
+ *
13
+ * src/include/storage/lockdefs.h
14
+ *
15
+ *-------------------------------------------------------------------------
16
+ */
17
+ #ifndef LOCKDEFS_H_
18
+ #define LOCKDEFS_H_
19
+
20
+ /*
21
+ * LOCKMODE is an integer (1..N) indicating a lock type. LOCKMASK is a bit
22
+ * mask indicating a set of held or requested lock types (the bit 1<<mode
23
+ * corresponds to a particular lock mode).
24
+ */
25
+ typedef int LOCKMASK;
26
+ typedef int LOCKMODE;
27
+
28
+ /*
29
+ * These are the valid values of type LOCKMODE for all the standard lock
30
+ * methods (both DEFAULT and USER).
31
+ */
32
+
33
+ /* NoLock is not a lock mode, but a flag value meaning "don't get a lock" */
34
+ #define NoLock 0
35
+
36
+ #define AccessShareLock 1 /* SELECT */
37
+ #define RowShareLock 2 /* SELECT FOR UPDATE/FOR SHARE */
38
+ #define RowExclusiveLock 3 /* INSERT, UPDATE, DELETE */
39
+ #define ShareUpdateExclusiveLock 4 /* VACUUM (non-FULL), ANALYZE, CREATE
40
+ * INDEX CONCURRENTLY */
41
+ #define ShareLock 5 /* CREATE INDEX (WITHOUT CONCURRENTLY) */
42
+ #define ShareRowExclusiveLock 6 /* like EXCLUSIVE MODE, but allows ROW
43
+ * SHARE */
44
+ #define ExclusiveLock 7 /* blocks ROW SHARE/SELECT...FOR UPDATE */
45
+ #define AccessExclusiveLock 8 /* ALTER TABLE, DROP TABLE, VACUUM FULL,
46
+ * and unqualified LOCK TABLE */
47
+
48
+ #define MaxLockMode 8 /* highest standard lock mode */
49
+
50
+
51
+ /* WAL representation of an AccessExclusiveLock on a table */
52
+ typedef struct xl_standby_lock
53
+ {
54
+ TransactionId xid; /* xid of holder of AccessExclusiveLock */
55
+ Oid dbOid; /* DB containing table */
56
+ Oid relOid; /* OID of table */
57
+ } xl_standby_lock;
58
+
59
+ #endif /* LOCKDEFS_H_ */