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.
Files changed (480) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +217 -99
  3. data/README.md +92 -69
  4. data/Rakefile +85 -5
  5. data/ext/pg_query/extconf.rb +3 -40
  6. data/ext/pg_query/guc-file.c +0 -0
  7. data/ext/pg_query/include/access/amapi.h +246 -0
  8. data/ext/pg_query/include/access/attmap.h +52 -0
  9. data/ext/pg_query/include/access/attnum.h +64 -0
  10. data/ext/pg_query/include/access/clog.h +61 -0
  11. data/ext/pg_query/include/access/commit_ts.h +77 -0
  12. data/ext/pg_query/include/access/detoast.h +92 -0
  13. data/ext/pg_query/include/access/genam.h +228 -0
  14. data/ext/pg_query/include/access/gin.h +78 -0
  15. data/ext/pg_query/include/access/htup.h +89 -0
  16. data/ext/pg_query/include/access/htup_details.h +819 -0
  17. data/ext/pg_query/include/access/itup.h +161 -0
  18. data/ext/pg_query/include/access/parallel.h +82 -0
  19. data/ext/pg_query/include/access/printtup.h +35 -0
  20. data/ext/pg_query/include/access/relation.h +28 -0
  21. data/ext/pg_query/include/access/relscan.h +176 -0
  22. data/ext/pg_query/include/access/rmgr.h +35 -0
  23. data/ext/pg_query/include/access/rmgrlist.h +49 -0
  24. data/ext/pg_query/include/access/sdir.h +58 -0
  25. data/ext/pg_query/include/access/skey.h +151 -0
  26. data/ext/pg_query/include/access/stratnum.h +83 -0
  27. data/ext/pg_query/include/access/sysattr.h +29 -0
  28. data/ext/pg_query/include/access/table.h +27 -0
  29. data/ext/pg_query/include/access/tableam.h +1825 -0
  30. data/ext/pg_query/include/access/transam.h +265 -0
  31. data/ext/pg_query/include/access/tupconvert.h +51 -0
  32. data/ext/pg_query/include/access/tupdesc.h +154 -0
  33. data/ext/pg_query/include/access/tupmacs.h +247 -0
  34. data/ext/pg_query/include/access/twophase.h +61 -0
  35. data/ext/pg_query/include/access/xact.h +463 -0
  36. data/ext/pg_query/include/access/xlog.h +398 -0
  37. data/ext/pg_query/include/access/xlog_internal.h +330 -0
  38. data/ext/pg_query/include/access/xlogdefs.h +109 -0
  39. data/ext/pg_query/include/access/xloginsert.h +64 -0
  40. data/ext/pg_query/include/access/xlogreader.h +327 -0
  41. data/ext/pg_query/include/access/xlogrecord.h +227 -0
  42. data/ext/pg_query/include/bootstrap/bootstrap.h +62 -0
  43. data/ext/pg_query/include/c.h +1322 -0
  44. data/ext/pg_query/include/catalog/catalog.h +42 -0
  45. data/ext/pg_query/include/catalog/catversion.h +58 -0
  46. data/ext/pg_query/include/catalog/dependency.h +275 -0
  47. data/ext/pg_query/include/catalog/genbki.h +64 -0
  48. data/ext/pg_query/include/catalog/index.h +199 -0
  49. data/ext/pg_query/include/catalog/indexing.h +366 -0
  50. data/ext/pg_query/include/catalog/namespace.h +188 -0
  51. data/ext/pg_query/include/catalog/objectaccess.h +197 -0
  52. data/ext/pg_query/include/catalog/objectaddress.h +84 -0
  53. data/ext/pg_query/include/catalog/pg_aggregate.h +176 -0
  54. data/ext/pg_query/include/catalog/pg_aggregate_d.h +77 -0
  55. data/ext/pg_query/include/catalog/pg_am.h +60 -0
  56. data/ext/pg_query/include/catalog/pg_am_d.h +45 -0
  57. data/ext/pg_query/include/catalog/pg_attribute.h +204 -0
  58. data/ext/pg_query/include/catalog/pg_attribute_d.h +59 -0
  59. data/ext/pg_query/include/catalog/pg_authid.h +58 -0
  60. data/ext/pg_query/include/catalog/pg_authid_d.h +49 -0
  61. data/ext/pg_query/include/catalog/pg_class.h +200 -0
  62. data/ext/pg_query/include/catalog/pg_class_d.h +103 -0
  63. data/ext/pg_query/include/catalog/pg_collation.h +73 -0
  64. data/ext/pg_query/include/catalog/pg_collation_d.h +45 -0
  65. data/ext/pg_query/include/catalog/pg_constraint.h +247 -0
  66. data/ext/pg_query/include/catalog/pg_constraint_d.h +67 -0
  67. data/ext/pg_query/include/catalog/pg_control.h +250 -0
  68. data/ext/pg_query/include/catalog/pg_conversion.h +72 -0
  69. data/ext/pg_query/include/catalog/pg_conversion_d.h +35 -0
  70. data/ext/pg_query/include/catalog/pg_depend.h +73 -0
  71. data/ext/pg_query/include/catalog/pg_depend_d.h +34 -0
  72. data/ext/pg_query/include/catalog/pg_event_trigger.h +51 -0
  73. data/ext/pg_query/include/catalog/pg_event_trigger_d.h +34 -0
  74. data/ext/pg_query/include/catalog/pg_index.h +80 -0
  75. data/ext/pg_query/include/catalog/pg_index_d.h +56 -0
  76. data/ext/pg_query/include/catalog/pg_language.h +67 -0
  77. data/ext/pg_query/include/catalog/pg_language_d.h +39 -0
  78. data/ext/pg_query/include/catalog/pg_namespace.h +59 -0
  79. data/ext/pg_query/include/catalog/pg_namespace_d.h +34 -0
  80. data/ext/pg_query/include/catalog/pg_opclass.h +85 -0
  81. data/ext/pg_query/include/catalog/pg_opclass_d.h +49 -0
  82. data/ext/pg_query/include/catalog/pg_operator.h +102 -0
  83. data/ext/pg_query/include/catalog/pg_operator_d.h +106 -0
  84. data/ext/pg_query/include/catalog/pg_opfamily.h +60 -0
  85. data/ext/pg_query/include/catalog/pg_opfamily_d.h +47 -0
  86. data/ext/pg_query/include/catalog/pg_partitioned_table.h +63 -0
  87. data/ext/pg_query/include/catalog/pg_partitioned_table_d.h +35 -0
  88. data/ext/pg_query/include/catalog/pg_proc.h +211 -0
  89. data/ext/pg_query/include/catalog/pg_proc_d.h +99 -0
  90. data/ext/pg_query/include/catalog/pg_publication.h +115 -0
  91. data/ext/pg_query/include/catalog/pg_publication_d.h +36 -0
  92. data/ext/pg_query/include/catalog/pg_replication_origin.h +57 -0
  93. data/ext/pg_query/include/catalog/pg_replication_origin_d.h +29 -0
  94. data/ext/pg_query/include/catalog/pg_statistic.h +275 -0
  95. data/ext/pg_query/include/catalog/pg_statistic_d.h +194 -0
  96. data/ext/pg_query/include/catalog/pg_statistic_ext.h +74 -0
  97. data/ext/pg_query/include/catalog/pg_statistic_ext_d.h +40 -0
  98. data/ext/pg_query/include/catalog/pg_transform.h +45 -0
  99. data/ext/pg_query/include/catalog/pg_transform_d.h +32 -0
  100. data/ext/pg_query/include/catalog/pg_trigger.h +137 -0
  101. data/ext/pg_query/include/catalog/pg_trigger_d.h +106 -0
  102. data/ext/pg_query/include/catalog/pg_ts_config.h +50 -0
  103. data/ext/pg_query/include/catalog/pg_ts_config_d.h +32 -0
  104. data/ext/pg_query/include/catalog/pg_ts_dict.h +54 -0
  105. data/ext/pg_query/include/catalog/pg_ts_dict_d.h +33 -0
  106. data/ext/pg_query/include/catalog/pg_ts_parser.h +57 -0
  107. data/ext/pg_query/include/catalog/pg_ts_parser_d.h +35 -0
  108. data/ext/pg_query/include/catalog/pg_ts_template.h +48 -0
  109. data/ext/pg_query/include/catalog/pg_ts_template_d.h +32 -0
  110. data/ext/pg_query/include/catalog/pg_type.h +372 -0
  111. data/ext/pg_query/include/catalog/pg_type_d.h +285 -0
  112. data/ext/pg_query/include/catalog/storage.h +48 -0
  113. data/ext/pg_query/include/commands/async.h +54 -0
  114. data/ext/pg_query/include/commands/dbcommands.h +35 -0
  115. data/ext/pg_query/include/commands/defrem.h +173 -0
  116. data/ext/pg_query/include/commands/event_trigger.h +88 -0
  117. data/ext/pg_query/include/commands/explain.h +127 -0
  118. data/ext/pg_query/include/commands/prepare.h +61 -0
  119. data/ext/pg_query/include/commands/tablespace.h +67 -0
  120. data/ext/pg_query/include/commands/trigger.h +277 -0
  121. data/ext/pg_query/include/commands/user.h +37 -0
  122. data/ext/pg_query/include/commands/vacuum.h +293 -0
  123. data/ext/pg_query/include/commands/variable.h +38 -0
  124. data/ext/pg_query/include/common/file_perm.h +56 -0
  125. data/ext/pg_query/include/common/hashfn.h +104 -0
  126. data/ext/pg_query/include/common/ip.h +37 -0
  127. data/ext/pg_query/include/common/keywords.h +33 -0
  128. data/ext/pg_query/include/common/kwlookup.h +44 -0
  129. data/ext/pg_query/include/common/relpath.h +90 -0
  130. data/ext/pg_query/include/common/string.h +19 -0
  131. data/ext/pg_query/include/common/unicode_combining_table.h +196 -0
  132. data/ext/pg_query/include/datatype/timestamp.h +197 -0
  133. data/ext/pg_query/include/executor/execdesc.h +70 -0
  134. data/ext/pg_query/include/executor/executor.h +614 -0
  135. data/ext/pg_query/include/executor/functions.h +41 -0
  136. data/ext/pg_query/include/executor/instrument.h +101 -0
  137. data/ext/pg_query/include/executor/spi.h +175 -0
  138. data/ext/pg_query/include/executor/tablefunc.h +67 -0
  139. data/ext/pg_query/include/executor/tuptable.h +487 -0
  140. data/ext/pg_query/include/fmgr.h +775 -0
  141. data/ext/pg_query/include/funcapi.h +348 -0
  142. data/ext/pg_query/include/getaddrinfo.h +162 -0
  143. data/ext/pg_query/include/jit/jit.h +105 -0
  144. data/ext/pg_query/include/kwlist_d.h +1072 -0
  145. data/ext/pg_query/include/lib/ilist.h +727 -0
  146. data/ext/pg_query/include/lib/pairingheap.h +102 -0
  147. data/ext/pg_query/include/lib/simplehash.h +1059 -0
  148. data/ext/pg_query/include/lib/stringinfo.h +161 -0
  149. data/ext/pg_query/include/libpq/auth.h +29 -0
  150. data/ext/pg_query/include/libpq/crypt.h +46 -0
  151. data/ext/pg_query/include/libpq/hba.h +140 -0
  152. data/ext/pg_query/include/libpq/libpq-be.h +326 -0
  153. data/ext/pg_query/include/libpq/libpq.h +133 -0
  154. data/ext/pg_query/include/libpq/pqcomm.h +208 -0
  155. data/ext/pg_query/include/libpq/pqformat.h +210 -0
  156. data/ext/pg_query/include/libpq/pqsignal.h +42 -0
  157. data/ext/pg_query/include/mb/pg_wchar.h +672 -0
  158. data/ext/pg_query/include/mb/stringinfo_mb.h +24 -0
  159. data/ext/pg_query/include/miscadmin.h +476 -0
  160. data/ext/pg_query/include/nodes/bitmapset.h +122 -0
  161. data/ext/pg_query/include/nodes/execnodes.h +2520 -0
  162. data/ext/pg_query/include/nodes/extensible.h +160 -0
  163. data/ext/pg_query/include/nodes/lockoptions.h +61 -0
  164. data/ext/pg_query/include/nodes/makefuncs.h +108 -0
  165. data/ext/pg_query/include/nodes/memnodes.h +108 -0
  166. data/ext/pg_query/include/nodes/nodeFuncs.h +162 -0
  167. data/ext/pg_query/include/nodes/nodes.h +842 -0
  168. data/ext/pg_query/include/nodes/params.h +170 -0
  169. data/ext/pg_query/include/nodes/parsenodes.h +3579 -0
  170. data/ext/pg_query/include/nodes/pathnodes.h +2556 -0
  171. data/ext/pg_query/include/nodes/pg_list.h +605 -0
  172. data/ext/pg_query/include/nodes/plannodes.h +1251 -0
  173. data/ext/pg_query/include/nodes/primnodes.h +1541 -0
  174. data/ext/pg_query/include/nodes/print.h +34 -0
  175. data/ext/pg_query/include/nodes/tidbitmap.h +75 -0
  176. data/ext/pg_query/include/nodes/value.h +61 -0
  177. data/ext/pg_query/include/optimizer/cost.h +206 -0
  178. data/ext/pg_query/include/optimizer/geqo.h +88 -0
  179. data/ext/pg_query/include/optimizer/geqo_gene.h +45 -0
  180. data/ext/pg_query/include/optimizer/optimizer.h +199 -0
  181. data/ext/pg_query/include/optimizer/paths.h +249 -0
  182. data/ext/pg_query/include/optimizer/planmain.h +119 -0
  183. data/ext/pg_query/include/parser/analyze.h +49 -0
  184. data/ext/pg_query/include/parser/gram.h +1067 -0
  185. data/ext/pg_query/include/parser/gramparse.h +75 -0
  186. data/ext/pg_query/include/parser/kwlist.h +477 -0
  187. data/ext/pg_query/include/parser/parse_agg.h +68 -0
  188. data/ext/pg_query/include/parser/parse_clause.h +54 -0
  189. data/ext/pg_query/include/parser/parse_coerce.h +97 -0
  190. data/ext/pg_query/include/parser/parse_collate.h +27 -0
  191. data/ext/pg_query/include/parser/parse_expr.h +26 -0
  192. data/ext/pg_query/include/parser/parse_func.h +73 -0
  193. data/ext/pg_query/include/parser/parse_node.h +327 -0
  194. data/ext/pg_query/include/parser/parse_oper.h +67 -0
  195. data/ext/pg_query/include/parser/parse_relation.h +123 -0
  196. data/ext/pg_query/include/parser/parse_target.h +46 -0
  197. data/ext/pg_query/include/parser/parse_type.h +60 -0
  198. data/ext/pg_query/include/parser/parser.h +41 -0
  199. data/ext/pg_query/include/parser/parsetree.h +61 -0
  200. data/ext/pg_query/include/parser/scanner.h +152 -0
  201. data/ext/pg_query/include/parser/scansup.h +30 -0
  202. data/ext/pg_query/include/partitioning/partdefs.h +26 -0
  203. data/ext/pg_query/include/pg_config.h +989 -0
  204. data/ext/pg_query/include/pg_config_ext.h +8 -0
  205. data/ext/pg_query/include/pg_config_manual.h +350 -0
  206. data/ext/pg_query/include/pg_config_os.h +8 -0
  207. data/ext/pg_query/include/pg_getopt.h +56 -0
  208. data/ext/pg_query/include/pg_query.h +121 -0
  209. data/ext/pg_query/include/pg_query_enum_defs.c +2454 -0
  210. data/ext/pg_query/include/pg_query_fingerprint_conds.c +875 -0
  211. data/ext/pg_query/include/pg_query_fingerprint_defs.c +12413 -0
  212. data/ext/pg_query/include/pg_query_json_helper.c +61 -0
  213. data/ext/pg_query/include/pg_query_outfuncs_conds.c +686 -0
  214. data/ext/pg_query/include/pg_query_outfuncs_defs.c +2437 -0
  215. data/ext/pg_query/include/pg_query_readfuncs_conds.c +222 -0
  216. data/ext/pg_query/include/pg_query_readfuncs_defs.c +2878 -0
  217. data/ext/pg_query/include/pg_trace.h +17 -0
  218. data/ext/pg_query/include/pgstat.h +1487 -0
  219. data/ext/pg_query/include/pgtime.h +84 -0
  220. data/ext/pg_query/include/pl_gram.h +385 -0
  221. data/ext/pg_query/include/pl_reserved_kwlist.h +52 -0
  222. data/ext/pg_query/include/pl_reserved_kwlist_d.h +114 -0
  223. data/ext/pg_query/include/pl_unreserved_kwlist.h +112 -0
  224. data/ext/pg_query/include/pl_unreserved_kwlist_d.h +246 -0
  225. data/ext/pg_query/include/plerrcodes.h +990 -0
  226. data/ext/pg_query/include/plpgsql.h +1347 -0
  227. data/ext/pg_query/include/port.h +524 -0
  228. data/ext/pg_query/include/port/atomics.h +524 -0
  229. data/ext/pg_query/include/port/atomics/arch-arm.h +26 -0
  230. data/ext/pg_query/include/port/atomics/arch-ppc.h +254 -0
  231. data/ext/pg_query/include/port/atomics/arch-x86.h +252 -0
  232. data/ext/pg_query/include/port/atomics/fallback.h +170 -0
  233. data/ext/pg_query/include/port/atomics/generic-gcc.h +286 -0
  234. data/ext/pg_query/include/port/atomics/generic.h +401 -0
  235. data/ext/pg_query/include/port/pg_bitutils.h +226 -0
  236. data/ext/pg_query/include/port/pg_bswap.h +161 -0
  237. data/ext/pg_query/include/port/pg_crc32c.h +101 -0
  238. data/ext/pg_query/include/portability/instr_time.h +256 -0
  239. data/ext/pg_query/include/postgres.h +764 -0
  240. data/ext/pg_query/include/postgres_ext.h +74 -0
  241. data/ext/pg_query/include/postmaster/autovacuum.h +83 -0
  242. data/ext/pg_query/include/postmaster/bgworker.h +161 -0
  243. data/ext/pg_query/include/postmaster/bgworker_internals.h +64 -0
  244. data/ext/pg_query/include/postmaster/bgwriter.h +45 -0
  245. data/ext/pg_query/include/postmaster/fork_process.h +17 -0
  246. data/ext/pg_query/include/postmaster/interrupt.h +32 -0
  247. data/ext/pg_query/include/postmaster/pgarch.h +39 -0
  248. data/ext/pg_query/include/postmaster/postmaster.h +77 -0
  249. data/ext/pg_query/include/postmaster/syslogger.h +98 -0
  250. data/ext/pg_query/include/postmaster/walwriter.h +21 -0
  251. data/ext/pg_query/include/protobuf-c.h +1106 -0
  252. data/ext/pg_query/include/protobuf-c/protobuf-c.h +1106 -0
  253. data/ext/pg_query/include/protobuf/pg_query.pb-c.h +10846 -0
  254. data/ext/pg_query/include/protobuf/pg_query.pb.h +124718 -0
  255. data/ext/pg_query/include/regex/regex.h +184 -0
  256. data/ext/pg_query/include/replication/logicallauncher.h +31 -0
  257. data/ext/pg_query/include/replication/logicalproto.h +110 -0
  258. data/ext/pg_query/include/replication/logicalworker.h +19 -0
  259. data/ext/pg_query/include/replication/origin.h +73 -0
  260. data/ext/pg_query/include/replication/reorderbuffer.h +467 -0
  261. data/ext/pg_query/include/replication/slot.h +219 -0
  262. data/ext/pg_query/include/replication/syncrep.h +115 -0
  263. data/ext/pg_query/include/replication/walreceiver.h +340 -0
  264. data/ext/pg_query/include/replication/walsender.h +74 -0
  265. data/ext/pg_query/include/rewrite/prs2lock.h +46 -0
  266. data/ext/pg_query/include/rewrite/rewriteHandler.h +40 -0
  267. data/ext/pg_query/include/rewrite/rewriteManip.h +87 -0
  268. data/ext/pg_query/include/rewrite/rewriteSupport.h +26 -0
  269. data/ext/pg_query/include/storage/backendid.h +37 -0
  270. data/ext/pg_query/include/storage/block.h +121 -0
  271. data/ext/pg_query/include/storage/buf.h +46 -0
  272. data/ext/pg_query/include/storage/bufmgr.h +292 -0
  273. data/ext/pg_query/include/storage/bufpage.h +459 -0
  274. data/ext/pg_query/include/storage/condition_variable.h +62 -0
  275. data/ext/pg_query/include/storage/dsm.h +61 -0
  276. data/ext/pg_query/include/storage/dsm_impl.h +75 -0
  277. data/ext/pg_query/include/storage/fd.h +168 -0
  278. data/ext/pg_query/include/storage/ipc.h +81 -0
  279. data/ext/pg_query/include/storage/item.h +19 -0
  280. data/ext/pg_query/include/storage/itemid.h +184 -0
  281. data/ext/pg_query/include/storage/itemptr.h +206 -0
  282. data/ext/pg_query/include/storage/large_object.h +100 -0
  283. data/ext/pg_query/include/storage/latch.h +190 -0
  284. data/ext/pg_query/include/storage/lmgr.h +114 -0
  285. data/ext/pg_query/include/storage/lock.h +612 -0
  286. data/ext/pg_query/include/storage/lockdefs.h +59 -0
  287. data/ext/pg_query/include/storage/lwlock.h +232 -0
  288. data/ext/pg_query/include/storage/lwlocknames.h +51 -0
  289. data/ext/pg_query/include/storage/off.h +57 -0
  290. data/ext/pg_query/include/storage/pg_sema.h +61 -0
  291. data/ext/pg_query/include/storage/pg_shmem.h +90 -0
  292. data/ext/pg_query/include/storage/pmsignal.h +94 -0
  293. data/ext/pg_query/include/storage/predicate.h +87 -0
  294. data/ext/pg_query/include/storage/proc.h +333 -0
  295. data/ext/pg_query/include/storage/proclist_types.h +51 -0
  296. data/ext/pg_query/include/storage/procsignal.h +75 -0
  297. data/ext/pg_query/include/storage/relfilenode.h +99 -0
  298. data/ext/pg_query/include/storage/s_lock.h +1047 -0
  299. data/ext/pg_query/include/storage/sharedfileset.h +45 -0
  300. data/ext/pg_query/include/storage/shm_mq.h +85 -0
  301. data/ext/pg_query/include/storage/shm_toc.h +58 -0
  302. data/ext/pg_query/include/storage/shmem.h +81 -0
  303. data/ext/pg_query/include/storage/sinval.h +153 -0
  304. data/ext/pg_query/include/storage/sinvaladt.h +43 -0
  305. data/ext/pg_query/include/storage/smgr.h +109 -0
  306. data/ext/pg_query/include/storage/spin.h +77 -0
  307. data/ext/pg_query/include/storage/standby.h +91 -0
  308. data/ext/pg_query/include/storage/standbydefs.h +74 -0
  309. data/ext/pg_query/include/storage/sync.h +62 -0
  310. data/ext/pg_query/include/tcop/cmdtag.h +58 -0
  311. data/ext/pg_query/include/tcop/cmdtaglist.h +217 -0
  312. data/ext/pg_query/include/tcop/deparse_utility.h +108 -0
  313. data/ext/pg_query/include/tcop/dest.h +149 -0
  314. data/ext/pg_query/include/tcop/fastpath.h +21 -0
  315. data/ext/pg_query/include/tcop/pquery.h +45 -0
  316. data/ext/pg_query/include/tcop/tcopprot.h +89 -0
  317. data/ext/pg_query/include/tcop/utility.h +108 -0
  318. data/ext/pg_query/include/tsearch/ts_cache.h +98 -0
  319. data/ext/pg_query/include/utils/acl.h +312 -0
  320. data/ext/pg_query/include/utils/aclchk_internal.h +45 -0
  321. data/ext/pg_query/include/utils/array.h +458 -0
  322. data/ext/pg_query/include/utils/builtins.h +127 -0
  323. data/ext/pg_query/include/utils/bytea.h +27 -0
  324. data/ext/pg_query/include/utils/catcache.h +231 -0
  325. data/ext/pg_query/include/utils/date.h +90 -0
  326. data/ext/pg_query/include/utils/datetime.h +343 -0
  327. data/ext/pg_query/include/utils/datum.h +68 -0
  328. data/ext/pg_query/include/utils/dsa.h +123 -0
  329. data/ext/pg_query/include/utils/dynahash.h +19 -0
  330. data/ext/pg_query/include/utils/elog.h +439 -0
  331. data/ext/pg_query/include/utils/errcodes.h +352 -0
  332. data/ext/pg_query/include/utils/expandeddatum.h +159 -0
  333. data/ext/pg_query/include/utils/expandedrecord.h +231 -0
  334. data/ext/pg_query/include/utils/float.h +356 -0
  335. data/ext/pg_query/include/utils/fmgroids.h +2657 -0
  336. data/ext/pg_query/include/utils/fmgrprotos.h +2646 -0
  337. data/ext/pg_query/include/utils/fmgrtab.h +48 -0
  338. data/ext/pg_query/include/utils/guc.h +443 -0
  339. data/ext/pg_query/include/utils/guc_tables.h +272 -0
  340. data/ext/pg_query/include/utils/hsearch.h +149 -0
  341. data/ext/pg_query/include/utils/inval.h +64 -0
  342. data/ext/pg_query/include/utils/lsyscache.h +197 -0
  343. data/ext/pg_query/include/utils/memdebug.h +82 -0
  344. data/ext/pg_query/include/utils/memutils.h +225 -0
  345. data/ext/pg_query/include/utils/numeric.h +76 -0
  346. data/ext/pg_query/include/utils/palloc.h +136 -0
  347. data/ext/pg_query/include/utils/partcache.h +102 -0
  348. data/ext/pg_query/include/utils/pg_locale.h +119 -0
  349. data/ext/pg_query/include/utils/pg_lsn.h +29 -0
  350. data/ext/pg_query/include/utils/pidfile.h +56 -0
  351. data/ext/pg_query/include/utils/plancache.h +235 -0
  352. data/ext/pg_query/include/utils/portal.h +241 -0
  353. data/ext/pg_query/include/utils/probes.h +114 -0
  354. data/ext/pg_query/include/utils/ps_status.h +25 -0
  355. data/ext/pg_query/include/utils/queryenvironment.h +74 -0
  356. data/ext/pg_query/include/utils/regproc.h +28 -0
  357. data/ext/pg_query/include/utils/rel.h +644 -0
  358. data/ext/pg_query/include/utils/relcache.h +151 -0
  359. data/ext/pg_query/include/utils/reltrigger.h +81 -0
  360. data/ext/pg_query/include/utils/resowner.h +86 -0
  361. data/ext/pg_query/include/utils/rls.h +50 -0
  362. data/ext/pg_query/include/utils/ruleutils.h +44 -0
  363. data/ext/pg_query/include/utils/sharedtuplestore.h +61 -0
  364. data/ext/pg_query/include/utils/snapmgr.h +158 -0
  365. data/ext/pg_query/include/utils/snapshot.h +206 -0
  366. data/ext/pg_query/include/utils/sortsupport.h +276 -0
  367. data/ext/pg_query/include/utils/syscache.h +219 -0
  368. data/ext/pg_query/include/utils/timeout.h +88 -0
  369. data/ext/pg_query/include/utils/timestamp.h +116 -0
  370. data/ext/pg_query/include/utils/tuplesort.h +277 -0
  371. data/ext/pg_query/include/utils/tuplestore.h +91 -0
  372. data/ext/pg_query/include/utils/typcache.h +202 -0
  373. data/ext/pg_query/include/utils/tzparser.h +39 -0
  374. data/ext/pg_query/include/utils/varlena.h +39 -0
  375. data/ext/pg_query/include/utils/xml.h +84 -0
  376. data/ext/pg_query/include/xxhash.h +5445 -0
  377. data/ext/pg_query/include/xxhash/xxhash.h +5445 -0
  378. data/ext/pg_query/pg_query.c +104 -0
  379. data/ext/pg_query/pg_query.pb-c.c +37628 -0
  380. data/ext/pg_query/pg_query_deparse.c +9959 -0
  381. data/ext/pg_query/pg_query_fingerprint.c +295 -0
  382. data/ext/pg_query/pg_query_fingerprint.h +8 -0
  383. data/ext/pg_query/pg_query_internal.h +24 -0
  384. data/ext/pg_query/pg_query_json_plpgsql.c +738 -0
  385. data/ext/pg_query/pg_query_json_plpgsql.h +9 -0
  386. data/ext/pg_query/pg_query_normalize.c +439 -0
  387. data/ext/pg_query/pg_query_outfuncs.h +10 -0
  388. data/ext/pg_query/pg_query_outfuncs_json.c +297 -0
  389. data/ext/pg_query/pg_query_outfuncs_protobuf.c +237 -0
  390. data/ext/pg_query/pg_query_parse.c +148 -0
  391. data/ext/pg_query/pg_query_parse_plpgsql.c +460 -0
  392. data/ext/pg_query/pg_query_readfuncs.h +11 -0
  393. data/ext/pg_query/pg_query_readfuncs_protobuf.c +142 -0
  394. data/ext/pg_query/pg_query_ruby.c +108 -12
  395. data/ext/pg_query/pg_query_scan.c +173 -0
  396. data/ext/pg_query/pg_query_split.c +221 -0
  397. data/ext/pg_query/protobuf-c.c +3660 -0
  398. data/ext/pg_query/src_backend_catalog_namespace.c +1051 -0
  399. data/ext/pg_query/src_backend_catalog_pg_proc.c +142 -0
  400. data/ext/pg_query/src_backend_commands_define.c +117 -0
  401. data/ext/pg_query/src_backend_libpq_pqcomm.c +651 -0
  402. data/ext/pg_query/src_backend_nodes_bitmapset.c +513 -0
  403. data/ext/pg_query/src_backend_nodes_copyfuncs.c +6013 -0
  404. data/ext/pg_query/src_backend_nodes_equalfuncs.c +4003 -0
  405. data/ext/pg_query/src_backend_nodes_extensible.c +99 -0
  406. data/ext/pg_query/src_backend_nodes_list.c +922 -0
  407. data/ext/pg_query/src_backend_nodes_makefuncs.c +417 -0
  408. data/ext/pg_query/src_backend_nodes_nodeFuncs.c +1363 -0
  409. data/ext/pg_query/src_backend_nodes_value.c +84 -0
  410. data/ext/pg_query/src_backend_parser_gram.c +47456 -0
  411. data/ext/pg_query/src_backend_parser_parse_expr.c +313 -0
  412. data/ext/pg_query/src_backend_parser_parser.c +497 -0
  413. data/ext/pg_query/src_backend_parser_scan.c +7091 -0
  414. data/ext/pg_query/src_backend_parser_scansup.c +160 -0
  415. data/ext/pg_query/src_backend_postmaster_postmaster.c +2230 -0
  416. data/ext/pg_query/src_backend_storage_ipc_ipc.c +192 -0
  417. data/ext/pg_query/src_backend_storage_lmgr_s_lock.c +370 -0
  418. data/ext/pg_query/src_backend_tcop_postgres.c +776 -0
  419. data/ext/pg_query/src_backend_utils_adt_datum.c +326 -0
  420. data/ext/pg_query/src_backend_utils_adt_expandeddatum.c +98 -0
  421. data/ext/pg_query/src_backend_utils_adt_format_type.c +136 -0
  422. data/ext/pg_query/src_backend_utils_adt_ruleutils.c +1683 -0
  423. data/ext/pg_query/src_backend_utils_error_assert.c +74 -0
  424. data/ext/pg_query/src_backend_utils_error_elog.c +1748 -0
  425. data/ext/pg_query/src_backend_utils_fmgr_fmgr.c +570 -0
  426. data/ext/pg_query/src_backend_utils_hash_dynahash.c +1086 -0
  427. data/ext/pg_query/src_backend_utils_init_globals.c +168 -0
  428. data/ext/pg_query/src_backend_utils_mb_mbutils.c +839 -0
  429. data/ext/pg_query/src_backend_utils_misc_guc.c +1831 -0
  430. data/ext/pg_query/src_backend_utils_mmgr_aset.c +1560 -0
  431. data/ext/pg_query/src_backend_utils_mmgr_mcxt.c +1006 -0
  432. data/ext/pg_query/src_common_encnames.c +158 -0
  433. data/ext/pg_query/src_common_keywords.c +39 -0
  434. data/ext/pg_query/src_common_kwlist_d.h +1081 -0
  435. data/ext/pg_query/src_common_kwlookup.c +91 -0
  436. data/ext/pg_query/src_common_psprintf.c +158 -0
  437. data/ext/pg_query/src_common_string.c +86 -0
  438. data/ext/pg_query/src_common_stringinfo.c +336 -0
  439. data/ext/pg_query/src_common_wchar.c +1651 -0
  440. data/ext/pg_query/src_pl_plpgsql_src_pl_comp.c +1133 -0
  441. data/ext/pg_query/src_pl_plpgsql_src_pl_funcs.c +877 -0
  442. data/ext/pg_query/src_pl_plpgsql_src_pl_gram.c +6533 -0
  443. data/ext/pg_query/src_pl_plpgsql_src_pl_handler.c +107 -0
  444. data/ext/pg_query/src_pl_plpgsql_src_pl_reserved_kwlist_d.h +123 -0
  445. data/ext/pg_query/src_pl_plpgsql_src_pl_scanner.c +671 -0
  446. data/ext/pg_query/src_pl_plpgsql_src_pl_unreserved_kwlist_d.h +255 -0
  447. data/ext/pg_query/src_port_erand48.c +127 -0
  448. data/ext/pg_query/src_port_pg_bitutils.c +246 -0
  449. data/ext/pg_query/src_port_pgsleep.c +69 -0
  450. data/ext/pg_query/src_port_pgstrcasecmp.c +83 -0
  451. data/ext/pg_query/src_port_qsort.c +240 -0
  452. data/ext/pg_query/src_port_random.c +31 -0
  453. data/ext/pg_query/src_port_snprintf.c +1449 -0
  454. data/ext/pg_query/src_port_strerror.c +324 -0
  455. data/ext/pg_query/src_port_strnlen.c +39 -0
  456. data/ext/pg_query/xxhash.c +43 -0
  457. data/lib/pg_query.rb +7 -4
  458. data/lib/pg_query/constants.rb +21 -0
  459. data/lib/pg_query/deparse.rb +15 -1581
  460. data/lib/pg_query/filter_columns.rb +88 -85
  461. data/lib/pg_query/fingerprint.rb +122 -87
  462. data/lib/pg_query/json_field_names.rb +1402 -0
  463. data/lib/pg_query/node.rb +31 -0
  464. data/lib/pg_query/param_refs.rb +42 -37
  465. data/lib/pg_query/parse.rb +220 -203
  466. data/lib/pg_query/parse_error.rb +1 -1
  467. data/lib/pg_query/pg_query_pb.rb +3211 -0
  468. data/lib/pg_query/scan.rb +23 -0
  469. data/lib/pg_query/treewalker.rb +24 -40
  470. data/lib/pg_query/truncate.rb +71 -42
  471. data/lib/pg_query/version.rb +2 -2
  472. metadata +472 -11
  473. data/ext/pg_query/pg_query_ruby.h +0 -10
  474. data/lib/pg_query/deep_dup.rb +0 -16
  475. data/lib/pg_query/deparse/alter_table.rb +0 -42
  476. data/lib/pg_query/deparse/interval.rb +0 -105
  477. data/lib/pg_query/deparse/keywords.rb +0 -159
  478. data/lib/pg_query/deparse/rename.rb +0 -41
  479. data/lib/pg_query/legacy_parsetree.rb +0 -109
  480. data/lib/pg_query/node_types.rb +0 -296
@@ -0,0 +1,398 @@
1
+ /*
2
+ * xlog.h
3
+ *
4
+ * PostgreSQL write-ahead 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/xlog.h
10
+ */
11
+ #ifndef XLOG_H
12
+ #define XLOG_H
13
+
14
+ #include "access/rmgr.h"
15
+ #include "access/xlogdefs.h"
16
+ #include "access/xloginsert.h"
17
+ #include "access/xlogreader.h"
18
+ #include "datatype/timestamp.h"
19
+ #include "lib/stringinfo.h"
20
+ #include "nodes/pg_list.h"
21
+ #include "storage/fd.h"
22
+
23
+
24
+ /* Sync methods */
25
+ #define SYNC_METHOD_FSYNC 0
26
+ #define SYNC_METHOD_FDATASYNC 1
27
+ #define SYNC_METHOD_OPEN 2 /* for O_SYNC */
28
+ #define SYNC_METHOD_FSYNC_WRITETHROUGH 3
29
+ #define SYNC_METHOD_OPEN_DSYNC 4 /* for O_DSYNC */
30
+ extern int sync_method;
31
+
32
+ extern PGDLLIMPORT TimeLineID ThisTimeLineID; /* current TLI */
33
+
34
+ /*
35
+ * Prior to 8.4, all activity during recovery was carried out by the startup
36
+ * process. This local variable continues to be used in many parts of the
37
+ * code to indicate actions taken by RecoveryManagers. Other processes that
38
+ * potentially perform work during recovery should check RecoveryInProgress().
39
+ * See XLogCtl notes in xlog.c.
40
+ */
41
+ extern bool InRecovery;
42
+
43
+ /*
44
+ * Like InRecovery, standbyState is only valid in the startup process.
45
+ * In all other processes it will have the value STANDBY_DISABLED (so
46
+ * InHotStandby will read as false).
47
+ *
48
+ * In DISABLED state, we're performing crash recovery or hot standby was
49
+ * disabled in postgresql.conf.
50
+ *
51
+ * In INITIALIZED state, we've run InitRecoveryTransactionEnvironment, but
52
+ * we haven't yet processed a RUNNING_XACTS or shutdown-checkpoint WAL record
53
+ * to initialize our master-transaction tracking system.
54
+ *
55
+ * When the transaction tracking is initialized, we enter the SNAPSHOT_PENDING
56
+ * state. The tracked information might still be incomplete, so we can't allow
57
+ * connections yet, but redo functions must update the in-memory state when
58
+ * appropriate.
59
+ *
60
+ * In SNAPSHOT_READY mode, we have full knowledge of transactions that are
61
+ * (or were) running in the master at the current WAL location. Snapshots
62
+ * can be taken, and read-only queries can be run.
63
+ */
64
+ typedef enum
65
+ {
66
+ STANDBY_DISABLED,
67
+ STANDBY_INITIALIZED,
68
+ STANDBY_SNAPSHOT_PENDING,
69
+ STANDBY_SNAPSHOT_READY
70
+ } HotStandbyState;
71
+
72
+ extern HotStandbyState standbyState;
73
+
74
+ #define InHotStandby (standbyState >= STANDBY_SNAPSHOT_PENDING)
75
+
76
+ /*
77
+ * Recovery target type.
78
+ * Only set during a Point in Time recovery, not when in standby mode.
79
+ */
80
+ typedef enum
81
+ {
82
+ RECOVERY_TARGET_UNSET,
83
+ RECOVERY_TARGET_XID,
84
+ RECOVERY_TARGET_TIME,
85
+ RECOVERY_TARGET_NAME,
86
+ RECOVERY_TARGET_LSN,
87
+ RECOVERY_TARGET_IMMEDIATE
88
+ } RecoveryTargetType;
89
+
90
+ /*
91
+ * Recovery target TimeLine goal
92
+ */
93
+ typedef enum
94
+ {
95
+ RECOVERY_TARGET_TIMELINE_CONTROLFILE,
96
+ RECOVERY_TARGET_TIMELINE_LATEST,
97
+ RECOVERY_TARGET_TIMELINE_NUMERIC
98
+ } RecoveryTargetTimeLineGoal;
99
+
100
+ extern XLogRecPtr ProcLastRecPtr;
101
+ extern XLogRecPtr XactLastRecEnd;
102
+ extern PGDLLIMPORT XLogRecPtr XactLastCommitEnd;
103
+
104
+ extern bool reachedConsistency;
105
+
106
+ /* these variables are GUC parameters related to XLOG */
107
+ extern int wal_segment_size;
108
+ extern int min_wal_size_mb;
109
+ extern int max_wal_size_mb;
110
+ extern int wal_keep_size_mb;
111
+ extern int max_slot_wal_keep_size_mb;
112
+ extern int XLOGbuffers;
113
+ extern int XLogArchiveTimeout;
114
+ extern int wal_retrieve_retry_interval;
115
+ extern char *XLogArchiveCommand;
116
+ extern bool EnableHotStandby;
117
+ extern bool fullPageWrites;
118
+ extern bool wal_log_hints;
119
+ extern bool wal_compression;
120
+ extern bool wal_init_zero;
121
+ extern bool wal_recycle;
122
+ extern bool *wal_consistency_checking;
123
+ extern char *wal_consistency_checking_string;
124
+ extern bool log_checkpoints;
125
+ extern char *recoveryRestoreCommand;
126
+ extern char *recoveryEndCommand;
127
+ extern char *archiveCleanupCommand;
128
+ extern bool recoveryTargetInclusive;
129
+ extern int recoveryTargetAction;
130
+ extern int recovery_min_apply_delay;
131
+ extern char *PrimaryConnInfo;
132
+ extern char *PrimarySlotName;
133
+ extern bool wal_receiver_create_temp_slot;
134
+
135
+ /* indirectly set via GUC system */
136
+ extern TransactionId recoveryTargetXid;
137
+ extern char *recovery_target_time_string;
138
+ extern const char *recoveryTargetName;
139
+ extern XLogRecPtr recoveryTargetLSN;
140
+ extern RecoveryTargetType recoveryTarget;
141
+ extern char *PromoteTriggerFile;
142
+ extern RecoveryTargetTimeLineGoal recoveryTargetTimeLineGoal;
143
+ extern TimeLineID recoveryTargetTLIRequested;
144
+ extern TimeLineID recoveryTargetTLI;
145
+
146
+ extern int CheckPointSegments;
147
+
148
+ /* option set locally in startup process only when signal files exist */
149
+ extern bool StandbyModeRequested;
150
+ extern bool StandbyMode;
151
+
152
+ /* Archive modes */
153
+ typedef enum ArchiveMode
154
+ {
155
+ ARCHIVE_MODE_OFF = 0, /* disabled */
156
+ ARCHIVE_MODE_ON, /* enabled while server is running normally */
157
+ ARCHIVE_MODE_ALWAYS /* enabled always (even during recovery) */
158
+ } ArchiveMode;
159
+ extern int XLogArchiveMode;
160
+
161
+ /* WAL levels */
162
+ typedef enum WalLevel
163
+ {
164
+ WAL_LEVEL_MINIMAL = 0,
165
+ WAL_LEVEL_REPLICA,
166
+ WAL_LEVEL_LOGICAL
167
+ } WalLevel;
168
+
169
+ /* Recovery states */
170
+ typedef enum RecoveryState
171
+ {
172
+ RECOVERY_STATE_CRASH = 0, /* crash recovery */
173
+ RECOVERY_STATE_ARCHIVE, /* archive recovery */
174
+ RECOVERY_STATE_DONE /* currently in production */
175
+ } RecoveryState;
176
+
177
+ extern PGDLLIMPORT int wal_level;
178
+
179
+ /* Is WAL archiving enabled (always or only while server is running normally)? */
180
+ #define XLogArchivingActive() \
181
+ (AssertMacro(XLogArchiveMode == ARCHIVE_MODE_OFF || wal_level >= WAL_LEVEL_REPLICA), XLogArchiveMode > ARCHIVE_MODE_OFF)
182
+ /* Is WAL archiving enabled always (even during recovery)? */
183
+ #define XLogArchivingAlways() \
184
+ (AssertMacro(XLogArchiveMode == ARCHIVE_MODE_OFF || wal_level >= WAL_LEVEL_REPLICA), XLogArchiveMode == ARCHIVE_MODE_ALWAYS)
185
+ #define XLogArchiveCommandSet() (XLogArchiveCommand[0] != '\0')
186
+
187
+ /*
188
+ * Is WAL-logging necessary for archival or log-shipping, or can we skip
189
+ * WAL-logging if we fsync() the data before committing instead?
190
+ */
191
+ #define XLogIsNeeded() (wal_level >= WAL_LEVEL_REPLICA)
192
+
193
+ /*
194
+ * Is a full-page image needed for hint bit updates?
195
+ *
196
+ * Normally, we don't WAL-log hint bit updates, but if checksums are enabled,
197
+ * we have to protect them against torn page writes. When you only set
198
+ * individual bits on a page, it's still consistent no matter what combination
199
+ * of the bits make it to disk, but the checksum wouldn't match. Also WAL-log
200
+ * them if forced by wal_log_hints=on.
201
+ */
202
+ #define XLogHintBitIsNeeded() (DataChecksumsEnabled() || wal_log_hints)
203
+
204
+ /* Do we need to WAL-log information required only for Hot Standby and logical replication? */
205
+ #define XLogStandbyInfoActive() (wal_level >= WAL_LEVEL_REPLICA)
206
+
207
+ /* Do we need to WAL-log information required only for logical replication? */
208
+ #define XLogLogicalInfoActive() (wal_level >= WAL_LEVEL_LOGICAL)
209
+
210
+ #ifdef WAL_DEBUG
211
+ extern bool XLOG_DEBUG;
212
+ #endif
213
+
214
+ /*
215
+ * OR-able request flag bits for checkpoints. The "cause" bits are used only
216
+ * for logging purposes. Note: the flags must be defined so that it's
217
+ * sensible to OR together request flags arising from different requestors.
218
+ */
219
+
220
+ /* These directly affect the behavior of CreateCheckPoint and subsidiaries */
221
+ #define CHECKPOINT_IS_SHUTDOWN 0x0001 /* Checkpoint is for shutdown */
222
+ #define CHECKPOINT_END_OF_RECOVERY 0x0002 /* Like shutdown checkpoint, but
223
+ * issued at end of WAL recovery */
224
+ #define CHECKPOINT_IMMEDIATE 0x0004 /* Do it without delays */
225
+ #define CHECKPOINT_FORCE 0x0008 /* Force even if no activity */
226
+ #define CHECKPOINT_FLUSH_ALL 0x0010 /* Flush all pages, including those
227
+ * belonging to unlogged tables */
228
+ /* These are important to RequestCheckpoint */
229
+ #define CHECKPOINT_WAIT 0x0020 /* Wait for completion */
230
+ #define CHECKPOINT_REQUESTED 0x0040 /* Checkpoint request has been made */
231
+ /* These indicate the cause of a checkpoint request */
232
+ #define CHECKPOINT_CAUSE_XLOG 0x0080 /* XLOG consumption */
233
+ #define CHECKPOINT_CAUSE_TIME 0x0100 /* Elapsed time */
234
+
235
+ /*
236
+ * Flag bits for the record being inserted, set using XLogSetRecordFlags().
237
+ */
238
+ #define XLOG_INCLUDE_ORIGIN 0x01 /* include the replication origin */
239
+ #define XLOG_MARK_UNIMPORTANT 0x02 /* record not important for durability */
240
+
241
+
242
+ /* Checkpoint statistics */
243
+ typedef struct CheckpointStatsData
244
+ {
245
+ TimestampTz ckpt_start_t; /* start of checkpoint */
246
+ TimestampTz ckpt_write_t; /* start of flushing buffers */
247
+ TimestampTz ckpt_sync_t; /* start of fsyncs */
248
+ TimestampTz ckpt_sync_end_t; /* end of fsyncs */
249
+ TimestampTz ckpt_end_t; /* end of checkpoint */
250
+
251
+ int ckpt_bufs_written; /* # of buffers written */
252
+
253
+ int ckpt_segs_added; /* # of new xlog segments created */
254
+ int ckpt_segs_removed; /* # of xlog segments deleted */
255
+ int ckpt_segs_recycled; /* # of xlog segments recycled */
256
+
257
+ int ckpt_sync_rels; /* # of relations synced */
258
+ uint64 ckpt_longest_sync; /* Longest sync for one relation */
259
+ uint64 ckpt_agg_sync_time; /* The sum of all the individual sync
260
+ * times, which is not necessarily the
261
+ * same as the total elapsed time for the
262
+ * entire sync phase. */
263
+ } CheckpointStatsData;
264
+
265
+ extern CheckpointStatsData CheckpointStats;
266
+
267
+ /*
268
+ * GetWALAvailability return codes
269
+ */
270
+ typedef enum WALAvailability
271
+ {
272
+ WALAVAIL_INVALID_LSN, /* parameter error */
273
+ WALAVAIL_RESERVED, /* WAL segment is within max_wal_size */
274
+ WALAVAIL_EXTENDED, /* WAL segment is reserved by a slot or
275
+ * wal_keep_size */
276
+ WALAVAIL_UNRESERVED, /* no longer reserved, but not removed yet */
277
+ WALAVAIL_REMOVED /* WAL segment has been removed */
278
+ } WALAvailability;
279
+
280
+ struct XLogRecData;
281
+
282
+ extern XLogRecPtr XLogInsertRecord(struct XLogRecData *rdata,
283
+ XLogRecPtr fpw_lsn,
284
+ uint8 flags,
285
+ int num_fpi);
286
+ extern void XLogFlush(XLogRecPtr RecPtr);
287
+ extern bool XLogBackgroundFlush(void);
288
+ extern bool XLogNeedsFlush(XLogRecPtr RecPtr);
289
+ extern int XLogFileInit(XLogSegNo segno, bool *use_existent, bool use_lock);
290
+ extern int XLogFileOpen(XLogSegNo segno);
291
+
292
+ extern void CheckXLogRemoved(XLogSegNo segno, TimeLineID tli);
293
+ extern XLogSegNo XLogGetLastRemovedSegno(void);
294
+ extern void XLogSetAsyncXactLSN(XLogRecPtr record);
295
+ extern void XLogSetReplicationSlotMinimumLSN(XLogRecPtr lsn);
296
+
297
+ extern void xlog_redo(XLogReaderState *record);
298
+ extern void xlog_desc(StringInfo buf, XLogReaderState *record);
299
+ extern const char *xlog_identify(uint8 info);
300
+
301
+ extern void issue_xlog_fsync(int fd, XLogSegNo segno);
302
+
303
+ extern bool RecoveryInProgress(void);
304
+ extern RecoveryState GetRecoveryState(void);
305
+ extern bool HotStandbyActive(void);
306
+ extern bool HotStandbyActiveInReplay(void);
307
+ extern bool XLogInsertAllowed(void);
308
+ extern void GetXLogReceiptTime(TimestampTz *rtime, bool *fromStream);
309
+ extern XLogRecPtr GetXLogReplayRecPtr(TimeLineID *replayTLI);
310
+ extern XLogRecPtr GetXLogInsertRecPtr(void);
311
+ extern XLogRecPtr GetXLogWriteRecPtr(void);
312
+ extern bool RecoveryIsPaused(void);
313
+ extern void SetRecoveryPause(bool recoveryPause);
314
+ extern TimestampTz GetLatestXTime(void);
315
+ extern TimestampTz GetCurrentChunkReplayStartTime(void);
316
+
317
+ extern void UpdateControlFile(void);
318
+ extern uint64 GetSystemIdentifier(void);
319
+ extern char *GetMockAuthenticationNonce(void);
320
+ extern bool DataChecksumsEnabled(void);
321
+ extern XLogRecPtr GetFakeLSNForUnloggedRel(void);
322
+ extern Size XLOGShmemSize(void);
323
+ extern void XLOGShmemInit(void);
324
+ extern void BootStrapXLOG(void);
325
+ extern void LocalProcessControlFile(bool reset);
326
+ extern void StartupXLOG(void);
327
+ extern void ShutdownXLOG(int code, Datum arg);
328
+ extern void InitXLOGAccess(void);
329
+ extern void CreateCheckPoint(int flags);
330
+ extern bool CreateRestartPoint(int flags);
331
+ extern WALAvailability GetWALAvailability(XLogRecPtr targetLSN);
332
+ extern XLogRecPtr CalculateMaxmumSafeLSN(void);
333
+ extern void XLogPutNextOid(Oid nextOid);
334
+ extern XLogRecPtr XLogRestorePoint(const char *rpName);
335
+ extern void UpdateFullPageWrites(void);
336
+ extern void GetFullPageWriteInfo(XLogRecPtr *RedoRecPtr_p, bool *doPageWrites_p);
337
+ extern XLogRecPtr GetRedoRecPtr(void);
338
+ extern XLogRecPtr GetInsertRecPtr(void);
339
+ extern XLogRecPtr GetFlushRecPtr(void);
340
+ extern XLogRecPtr GetLastImportantRecPtr(void);
341
+ extern void RemovePromoteSignalFiles(void);
342
+
343
+ extern bool PromoteIsTriggered(void);
344
+ extern bool CheckPromoteSignal(void);
345
+ extern void WakeupRecovery(void);
346
+ extern void SetWalWriterSleeping(bool sleeping);
347
+
348
+ extern void StartupRequestWalReceiverRestart(void);
349
+ extern void XLogRequestWalReceiverReply(void);
350
+
351
+ extern void assign_max_wal_size(int newval, void *extra);
352
+ extern void assign_checkpoint_completion_target(double newval, void *extra);
353
+
354
+ /*
355
+ * Routines to start, stop, and get status of a base backup.
356
+ */
357
+
358
+ /*
359
+ * Session-level status of base backups
360
+ *
361
+ * This is used in parallel with the shared memory status to control parallel
362
+ * execution of base backup functions for a given session, be it a backend
363
+ * dedicated to replication or a normal backend connected to a database. The
364
+ * update of the session-level status happens at the same time as the shared
365
+ * memory counters to keep a consistent global and local state of the backups
366
+ * running.
367
+ */
368
+ typedef enum SessionBackupState
369
+ {
370
+ SESSION_BACKUP_NONE,
371
+ SESSION_BACKUP_EXCLUSIVE,
372
+ SESSION_BACKUP_NON_EXCLUSIVE
373
+ } SessionBackupState;
374
+
375
+ extern XLogRecPtr do_pg_start_backup(const char *backupidstr, bool fast,
376
+ TimeLineID *starttli_p, StringInfo labelfile,
377
+ List **tablespaces, StringInfo tblspcmapfile, bool infotbssize,
378
+ bool needtblspcmapfile);
379
+ extern XLogRecPtr do_pg_stop_backup(char *labelfile, bool waitforarchive,
380
+ TimeLineID *stoptli_p);
381
+ extern void do_pg_abort_backup(int code, Datum arg);
382
+ extern void register_persistent_abort_backup_handler(void);
383
+ extern SessionBackupState get_backup_status(void);
384
+
385
+ /* File path names (all relative to $PGDATA) */
386
+ #define RECOVERY_SIGNAL_FILE "recovery.signal"
387
+ #define STANDBY_SIGNAL_FILE "standby.signal"
388
+ #define BACKUP_LABEL_FILE "backup_label"
389
+ #define BACKUP_LABEL_OLD "backup_label.old"
390
+
391
+ #define TABLESPACE_MAP "tablespace_map"
392
+ #define TABLESPACE_MAP_OLD "tablespace_map.old"
393
+
394
+ /* files to signal promotion to primary */
395
+ #define PROMOTE_SIGNAL_FILE "promote"
396
+ #define FALLBACK_PROMOTE_SIGNAL_FILE "fallback_promote"
397
+
398
+ #endif /* XLOG_H */
@@ -0,0 +1,330 @@
1
+ /*
2
+ * xlog_internal.h
3
+ *
4
+ * PostgreSQL write-ahead log internal declarations
5
+ *
6
+ * NOTE: this file is intended to contain declarations useful for
7
+ * manipulating the XLOG files directly, but it is not supposed to be
8
+ * needed by rmgr routines (redo support for individual record types).
9
+ * So the XLogRecord typedef and associated stuff appear in xlogrecord.h.
10
+ *
11
+ * Note: This file must be includable in both frontend and backend contexts,
12
+ * to allow stand-alone tools like pg_receivewal to deal with WAL files.
13
+ *
14
+ * Portions Copyright (c) 1996-2020, PostgreSQL Global Development Group
15
+ * Portions Copyright (c) 1994, Regents of the University of California
16
+ *
17
+ * src/include/access/xlog_internal.h
18
+ */
19
+ #ifndef XLOG_INTERNAL_H
20
+ #define XLOG_INTERNAL_H
21
+
22
+ #include "access/xlogdefs.h"
23
+ #include "access/xlogreader.h"
24
+ #include "datatype/timestamp.h"
25
+ #include "lib/stringinfo.h"
26
+ #include "pgtime.h"
27
+ #include "storage/block.h"
28
+ #include "storage/relfilenode.h"
29
+
30
+
31
+ /*
32
+ * Each page of XLOG file has a header like this:
33
+ */
34
+ #define XLOG_PAGE_MAGIC 0xD106 /* can be used as WAL version indicator */
35
+
36
+ typedef struct XLogPageHeaderData
37
+ {
38
+ uint16 xlp_magic; /* magic value for correctness checks */
39
+ uint16 xlp_info; /* flag bits, see below */
40
+ TimeLineID xlp_tli; /* TimeLineID of first record on page */
41
+ XLogRecPtr xlp_pageaddr; /* XLOG address of this page */
42
+
43
+ /*
44
+ * When there is not enough space on current page for whole record, we
45
+ * continue on the next page. xlp_rem_len is the number of bytes
46
+ * remaining from a previous page.
47
+ *
48
+ * Note that xlp_rem_len includes backup-block data; that is, it tracks
49
+ * xl_tot_len not xl_len in the initial header. Also note that the
50
+ * continuation data isn't necessarily aligned.
51
+ */
52
+ uint32 xlp_rem_len; /* total len of remaining data for record */
53
+ } XLogPageHeaderData;
54
+
55
+ #define SizeOfXLogShortPHD MAXALIGN(sizeof(XLogPageHeaderData))
56
+
57
+ typedef XLogPageHeaderData *XLogPageHeader;
58
+
59
+ /*
60
+ * When the XLP_LONG_HEADER flag is set, we store additional fields in the
61
+ * page header. (This is ordinarily done just in the first page of an
62
+ * XLOG file.) The additional fields serve to identify the file accurately.
63
+ */
64
+ typedef struct XLogLongPageHeaderData
65
+ {
66
+ XLogPageHeaderData std; /* standard header fields */
67
+ uint64 xlp_sysid; /* system identifier from pg_control */
68
+ uint32 xlp_seg_size; /* just as a cross-check */
69
+ uint32 xlp_xlog_blcksz; /* just as a cross-check */
70
+ } XLogLongPageHeaderData;
71
+
72
+ #define SizeOfXLogLongPHD MAXALIGN(sizeof(XLogLongPageHeaderData))
73
+
74
+ typedef XLogLongPageHeaderData *XLogLongPageHeader;
75
+
76
+ /* When record crosses page boundary, set this flag in new page's header */
77
+ #define XLP_FIRST_IS_CONTRECORD 0x0001
78
+ /* This flag indicates a "long" page header */
79
+ #define XLP_LONG_HEADER 0x0002
80
+ /* This flag indicates backup blocks starting in this page are optional */
81
+ #define XLP_BKP_REMOVABLE 0x0004
82
+ /* All defined flag bits in xlp_info (used for validity checking of header) */
83
+ #define XLP_ALL_FLAGS 0x0007
84
+
85
+ #define XLogPageHeaderSize(hdr) \
86
+ (((hdr)->xlp_info & XLP_LONG_HEADER) ? SizeOfXLogLongPHD : SizeOfXLogShortPHD)
87
+
88
+ /* wal_segment_size can range from 1MB to 1GB */
89
+ #define WalSegMinSize 1024 * 1024
90
+ #define WalSegMaxSize 1024 * 1024 * 1024
91
+ /* default number of min and max wal segments */
92
+ #define DEFAULT_MIN_WAL_SEGS 5
93
+ #define DEFAULT_MAX_WAL_SEGS 64
94
+
95
+ /* check that the given size is a valid wal_segment_size */
96
+ #define IsPowerOf2(x) (x > 0 && ((x) & ((x)-1)) == 0)
97
+ #define IsValidWalSegSize(size) \
98
+ (IsPowerOf2(size) && \
99
+ ((size) >= WalSegMinSize && (size) <= WalSegMaxSize))
100
+
101
+ #define XLogSegmentsPerXLogId(wal_segsz_bytes) \
102
+ (UINT64CONST(0x100000000) / (wal_segsz_bytes))
103
+
104
+ #define XLogSegNoOffsetToRecPtr(segno, offset, wal_segsz_bytes, dest) \
105
+ (dest) = (segno) * (wal_segsz_bytes) + (offset)
106
+
107
+ #define XLogSegmentOffset(xlogptr, wal_segsz_bytes) \
108
+ ((xlogptr) & ((wal_segsz_bytes) - 1))
109
+
110
+ /*
111
+ * Compute a segment number from an XLogRecPtr.
112
+ *
113
+ * For XLByteToSeg, do the computation at face value. For XLByteToPrevSeg,
114
+ * a boundary byte is taken to be in the previous segment. This is suitable
115
+ * for deciding which segment to write given a pointer to a record end,
116
+ * for example.
117
+ */
118
+ #define XLByteToSeg(xlrp, logSegNo, wal_segsz_bytes) \
119
+ logSegNo = (xlrp) / (wal_segsz_bytes)
120
+
121
+ #define XLByteToPrevSeg(xlrp, logSegNo, wal_segsz_bytes) \
122
+ logSegNo = ((xlrp) - 1) / (wal_segsz_bytes)
123
+
124
+ /*
125
+ * Convert values of GUCs measured in megabytes to equiv. segment count.
126
+ * Rounds down.
127
+ */
128
+ #define XLogMBVarToSegs(mbvar, wal_segsz_bytes) \
129
+ ((mbvar) / ((wal_segsz_bytes) / (1024 * 1024)))
130
+
131
+ /*
132
+ * Is an XLogRecPtr within a particular XLOG segment?
133
+ *
134
+ * For XLByteInSeg, do the computation at face value. For XLByteInPrevSeg,
135
+ * a boundary byte is taken to be in the previous segment.
136
+ */
137
+ #define XLByteInSeg(xlrp, logSegNo, wal_segsz_bytes) \
138
+ (((xlrp) / (wal_segsz_bytes)) == (logSegNo))
139
+
140
+ #define XLByteInPrevSeg(xlrp, logSegNo, wal_segsz_bytes) \
141
+ ((((xlrp) - 1) / (wal_segsz_bytes)) == (logSegNo))
142
+
143
+ /* Check if an XLogRecPtr value is in a plausible range */
144
+ #define XRecOffIsValid(xlrp) \
145
+ ((xlrp) % XLOG_BLCKSZ >= SizeOfXLogShortPHD)
146
+
147
+ /*
148
+ * The XLog directory and control file (relative to $PGDATA)
149
+ */
150
+ #define XLOGDIR "pg_wal"
151
+ #define XLOG_CONTROL_FILE "global/pg_control"
152
+
153
+ /*
154
+ * These macros encapsulate knowledge about the exact layout of XLog file
155
+ * names, timeline history file names, and archive-status file names.
156
+ */
157
+ #define MAXFNAMELEN 64
158
+
159
+ /* Length of XLog file name */
160
+ #define XLOG_FNAME_LEN 24
161
+
162
+ /*
163
+ * Generate a WAL segment file name. Do not use this macro in a helper
164
+ * function allocating the result generated.
165
+ */
166
+ #define XLogFileName(fname, tli, logSegNo, wal_segsz_bytes) \
167
+ snprintf(fname, MAXFNAMELEN, "%08X%08X%08X", tli, \
168
+ (uint32) ((logSegNo) / XLogSegmentsPerXLogId(wal_segsz_bytes)), \
169
+ (uint32) ((logSegNo) % XLogSegmentsPerXLogId(wal_segsz_bytes)))
170
+
171
+ #define XLogFileNameById(fname, tli, log, seg) \
172
+ snprintf(fname, MAXFNAMELEN, "%08X%08X%08X", tli, log, seg)
173
+
174
+ #define IsXLogFileName(fname) \
175
+ (strlen(fname) == XLOG_FNAME_LEN && \
176
+ strspn(fname, "0123456789ABCDEF") == XLOG_FNAME_LEN)
177
+
178
+ /*
179
+ * XLOG segment with .partial suffix. Used by pg_receivewal and at end of
180
+ * archive recovery, when we want to archive a WAL segment but it might not
181
+ * be complete yet.
182
+ */
183
+ #define IsPartialXLogFileName(fname) \
184
+ (strlen(fname) == XLOG_FNAME_LEN + strlen(".partial") && \
185
+ strspn(fname, "0123456789ABCDEF") == XLOG_FNAME_LEN && \
186
+ strcmp((fname) + XLOG_FNAME_LEN, ".partial") == 0)
187
+
188
+ #define XLogFromFileName(fname, tli, logSegNo, wal_segsz_bytes) \
189
+ do { \
190
+ uint32 log; \
191
+ uint32 seg; \
192
+ sscanf(fname, "%08X%08X%08X", tli, &log, &seg); \
193
+ *logSegNo = (uint64) log * XLogSegmentsPerXLogId(wal_segsz_bytes) + seg; \
194
+ } while (0)
195
+
196
+ #define XLogFilePath(path, tli, logSegNo, wal_segsz_bytes) \
197
+ snprintf(path, MAXPGPATH, XLOGDIR "/%08X%08X%08X", tli, \
198
+ (uint32) ((logSegNo) / XLogSegmentsPerXLogId(wal_segsz_bytes)), \
199
+ (uint32) ((logSegNo) % XLogSegmentsPerXLogId(wal_segsz_bytes)))
200
+
201
+ #define TLHistoryFileName(fname, tli) \
202
+ snprintf(fname, MAXFNAMELEN, "%08X.history", tli)
203
+
204
+ #define IsTLHistoryFileName(fname) \
205
+ (strlen(fname) == 8 + strlen(".history") && \
206
+ strspn(fname, "0123456789ABCDEF") == 8 && \
207
+ strcmp((fname) + 8, ".history") == 0)
208
+
209
+ #define TLHistoryFilePath(path, tli) \
210
+ snprintf(path, MAXPGPATH, XLOGDIR "/%08X.history", tli)
211
+
212
+ #define StatusFilePath(path, xlog, suffix) \
213
+ snprintf(path, MAXPGPATH, XLOGDIR "/archive_status/%s%s", xlog, suffix)
214
+
215
+ #define BackupHistoryFileName(fname, tli, logSegNo, startpoint, wal_segsz_bytes) \
216
+ snprintf(fname, MAXFNAMELEN, "%08X%08X%08X.%08X.backup", tli, \
217
+ (uint32) ((logSegNo) / XLogSegmentsPerXLogId(wal_segsz_bytes)), \
218
+ (uint32) ((logSegNo) % XLogSegmentsPerXLogId(wal_segsz_bytes)), \
219
+ (uint32) (XLogSegmentOffset(startpoint, wal_segsz_bytes)))
220
+
221
+ #define IsBackupHistoryFileName(fname) \
222
+ (strlen(fname) > XLOG_FNAME_LEN && \
223
+ strspn(fname, "0123456789ABCDEF") == XLOG_FNAME_LEN && \
224
+ strcmp((fname) + strlen(fname) - strlen(".backup"), ".backup") == 0)
225
+
226
+ #define BackupHistoryFilePath(path, tli, logSegNo, startpoint, wal_segsz_bytes) \
227
+ snprintf(path, MAXPGPATH, XLOGDIR "/%08X%08X%08X.%08X.backup", tli, \
228
+ (uint32) ((logSegNo) / XLogSegmentsPerXLogId(wal_segsz_bytes)), \
229
+ (uint32) ((logSegNo) % XLogSegmentsPerXLogId(wal_segsz_bytes)), \
230
+ (uint32) (XLogSegmentOffset((startpoint), wal_segsz_bytes)))
231
+
232
+ /*
233
+ * Information logged when we detect a change in one of the parameters
234
+ * important for Hot Standby.
235
+ */
236
+ typedef struct xl_parameter_change
237
+ {
238
+ int MaxConnections;
239
+ int max_worker_processes;
240
+ int max_wal_senders;
241
+ int max_prepared_xacts;
242
+ int max_locks_per_xact;
243
+ int wal_level;
244
+ bool wal_log_hints;
245
+ bool track_commit_timestamp;
246
+ } xl_parameter_change;
247
+
248
+ /* logs restore point */
249
+ typedef struct xl_restore_point
250
+ {
251
+ TimestampTz rp_time;
252
+ char rp_name[MAXFNAMELEN];
253
+ } xl_restore_point;
254
+
255
+ /* End of recovery mark, when we don't do an END_OF_RECOVERY checkpoint */
256
+ typedef struct xl_end_of_recovery
257
+ {
258
+ TimestampTz end_time;
259
+ TimeLineID ThisTimeLineID; /* new TLI */
260
+ TimeLineID PrevTimeLineID; /* previous TLI we forked off from */
261
+ } xl_end_of_recovery;
262
+
263
+ /*
264
+ * The functions in xloginsert.c construct a chain of XLogRecData structs
265
+ * to represent the final WAL record.
266
+ */
267
+ typedef struct XLogRecData
268
+ {
269
+ struct XLogRecData *next; /* next struct in chain, or NULL */
270
+ char *data; /* start of rmgr data to include */
271
+ uint32 len; /* length of rmgr data to include */
272
+ } XLogRecData;
273
+
274
+ /*
275
+ * Recovery target action.
276
+ */
277
+ typedef enum
278
+ {
279
+ RECOVERY_TARGET_ACTION_PAUSE,
280
+ RECOVERY_TARGET_ACTION_PROMOTE,
281
+ RECOVERY_TARGET_ACTION_SHUTDOWN
282
+ } RecoveryTargetAction;
283
+
284
+ /*
285
+ * Method table for resource managers.
286
+ *
287
+ * This struct must be kept in sync with the PG_RMGR definition in
288
+ * rmgr.c.
289
+ *
290
+ * rm_identify must return a name for the record based on xl_info (without
291
+ * reference to the rmid). For example, XLOG_BTREE_VACUUM would be named
292
+ * "VACUUM". rm_desc can then be called to obtain additional detail for the
293
+ * record, if available (e.g. the last block).
294
+ *
295
+ * rm_mask takes as input a page modified by the resource manager and masks
296
+ * out bits that shouldn't be flagged by wal_consistency_checking.
297
+ *
298
+ * RmgrTable[] is indexed by RmgrId values (see rmgrlist.h).
299
+ */
300
+ typedef struct RmgrData
301
+ {
302
+ const char *rm_name;
303
+ void (*rm_redo) (XLogReaderState *record);
304
+ void (*rm_desc) (StringInfo buf, XLogReaderState *record);
305
+ const char *(*rm_identify) (uint8 info);
306
+ void (*rm_startup) (void);
307
+ void (*rm_cleanup) (void);
308
+ void (*rm_mask) (char *pagedata, BlockNumber blkno);
309
+ } RmgrData;
310
+
311
+ extern const RmgrData RmgrTable[];
312
+
313
+ /*
314
+ * Exported to support xlog switching from checkpointer
315
+ */
316
+ extern pg_time_t GetLastSegSwitchData(XLogRecPtr *lastSwitchLSN);
317
+ extern XLogRecPtr RequestXLogSwitch(bool mark_unimportant);
318
+
319
+ extern void GetOldestRestartPoint(XLogRecPtr *oldrecptr, TimeLineID *oldtli);
320
+
321
+ /*
322
+ * Exported for the functions in timeline.c and xlogarchive.c. Only valid
323
+ * in the startup process.
324
+ */
325
+ extern bool ArchiveRecoveryRequested;
326
+ extern bool InArchiveRecovery;
327
+ extern bool StandbyMode;
328
+ extern char *recoveryRestoreCommand;
329
+
330
+ #endif /* XLOG_INTERNAL_H */