pg_query 2.0.0 → 2.0.1

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 (375) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +6 -0
  3. data/ext/pg_query/include/access/amapi.h +246 -0
  4. data/ext/pg_query/include/access/attmap.h +52 -0
  5. data/ext/pg_query/include/access/attnum.h +64 -0
  6. data/ext/pg_query/include/access/clog.h +61 -0
  7. data/ext/pg_query/include/access/commit_ts.h +77 -0
  8. data/ext/pg_query/include/access/detoast.h +92 -0
  9. data/ext/pg_query/include/access/genam.h +228 -0
  10. data/ext/pg_query/include/access/gin.h +78 -0
  11. data/ext/pg_query/include/access/htup.h +89 -0
  12. data/ext/pg_query/include/access/htup_details.h +819 -0
  13. data/ext/pg_query/include/access/itup.h +161 -0
  14. data/ext/pg_query/include/access/parallel.h +82 -0
  15. data/ext/pg_query/include/access/printtup.h +35 -0
  16. data/ext/pg_query/include/access/relation.h +28 -0
  17. data/ext/pg_query/include/access/relscan.h +176 -0
  18. data/ext/pg_query/include/access/rmgr.h +35 -0
  19. data/ext/pg_query/include/access/rmgrlist.h +49 -0
  20. data/ext/pg_query/include/access/sdir.h +58 -0
  21. data/ext/pg_query/include/access/skey.h +151 -0
  22. data/ext/pg_query/include/access/stratnum.h +83 -0
  23. data/ext/pg_query/include/access/sysattr.h +29 -0
  24. data/ext/pg_query/include/access/table.h +27 -0
  25. data/ext/pg_query/include/access/tableam.h +1825 -0
  26. data/ext/pg_query/include/access/transam.h +265 -0
  27. data/ext/pg_query/include/access/tupconvert.h +51 -0
  28. data/ext/pg_query/include/access/tupdesc.h +154 -0
  29. data/ext/pg_query/include/access/tupmacs.h +247 -0
  30. data/ext/pg_query/include/access/twophase.h +61 -0
  31. data/ext/pg_query/include/access/xact.h +463 -0
  32. data/ext/pg_query/include/access/xlog.h +398 -0
  33. data/ext/pg_query/include/access/xlog_internal.h +330 -0
  34. data/ext/pg_query/include/access/xlogdefs.h +109 -0
  35. data/ext/pg_query/include/access/xloginsert.h +64 -0
  36. data/ext/pg_query/include/access/xlogreader.h +327 -0
  37. data/ext/pg_query/include/access/xlogrecord.h +227 -0
  38. data/ext/pg_query/include/bootstrap/bootstrap.h +62 -0
  39. data/ext/pg_query/include/c.h +1322 -0
  40. data/ext/pg_query/include/catalog/catalog.h +42 -0
  41. data/ext/pg_query/include/catalog/catversion.h +58 -0
  42. data/ext/pg_query/include/catalog/dependency.h +275 -0
  43. data/ext/pg_query/include/catalog/genbki.h +64 -0
  44. data/ext/pg_query/include/catalog/index.h +199 -0
  45. data/ext/pg_query/include/catalog/indexing.h +366 -0
  46. data/ext/pg_query/include/catalog/namespace.h +188 -0
  47. data/ext/pg_query/include/catalog/objectaccess.h +197 -0
  48. data/ext/pg_query/include/catalog/objectaddress.h +84 -0
  49. data/ext/pg_query/include/catalog/pg_aggregate.h +176 -0
  50. data/ext/pg_query/include/catalog/pg_aggregate_d.h +77 -0
  51. data/ext/pg_query/include/catalog/pg_am.h +60 -0
  52. data/ext/pg_query/include/catalog/pg_am_d.h +45 -0
  53. data/ext/pg_query/include/catalog/pg_attribute.h +204 -0
  54. data/ext/pg_query/include/catalog/pg_attribute_d.h +59 -0
  55. data/ext/pg_query/include/catalog/pg_authid.h +58 -0
  56. data/ext/pg_query/include/catalog/pg_authid_d.h +49 -0
  57. data/ext/pg_query/include/catalog/pg_class.h +200 -0
  58. data/ext/pg_query/include/catalog/pg_class_d.h +103 -0
  59. data/ext/pg_query/include/catalog/pg_collation.h +73 -0
  60. data/ext/pg_query/include/catalog/pg_collation_d.h +45 -0
  61. data/ext/pg_query/include/catalog/pg_constraint.h +247 -0
  62. data/ext/pg_query/include/catalog/pg_constraint_d.h +67 -0
  63. data/ext/pg_query/include/catalog/pg_control.h +250 -0
  64. data/ext/pg_query/include/catalog/pg_conversion.h +72 -0
  65. data/ext/pg_query/include/catalog/pg_conversion_d.h +35 -0
  66. data/ext/pg_query/include/catalog/pg_depend.h +73 -0
  67. data/ext/pg_query/include/catalog/pg_depend_d.h +34 -0
  68. data/ext/pg_query/include/catalog/pg_event_trigger.h +51 -0
  69. data/ext/pg_query/include/catalog/pg_event_trigger_d.h +34 -0
  70. data/ext/pg_query/include/catalog/pg_index.h +80 -0
  71. data/ext/pg_query/include/catalog/pg_index_d.h +56 -0
  72. data/ext/pg_query/include/catalog/pg_language.h +67 -0
  73. data/ext/pg_query/include/catalog/pg_language_d.h +39 -0
  74. data/ext/pg_query/include/catalog/pg_namespace.h +59 -0
  75. data/ext/pg_query/include/catalog/pg_namespace_d.h +34 -0
  76. data/ext/pg_query/include/catalog/pg_opclass.h +85 -0
  77. data/ext/pg_query/include/catalog/pg_opclass_d.h +49 -0
  78. data/ext/pg_query/include/catalog/pg_operator.h +102 -0
  79. data/ext/pg_query/include/catalog/pg_operator_d.h +106 -0
  80. data/ext/pg_query/include/catalog/pg_opfamily.h +60 -0
  81. data/ext/pg_query/include/catalog/pg_opfamily_d.h +47 -0
  82. data/ext/pg_query/include/catalog/pg_partitioned_table.h +63 -0
  83. data/ext/pg_query/include/catalog/pg_partitioned_table_d.h +35 -0
  84. data/ext/pg_query/include/catalog/pg_proc.h +211 -0
  85. data/ext/pg_query/include/catalog/pg_proc_d.h +99 -0
  86. data/ext/pg_query/include/catalog/pg_publication.h +115 -0
  87. data/ext/pg_query/include/catalog/pg_publication_d.h +36 -0
  88. data/ext/pg_query/include/catalog/pg_replication_origin.h +57 -0
  89. data/ext/pg_query/include/catalog/pg_replication_origin_d.h +29 -0
  90. data/ext/pg_query/include/catalog/pg_statistic.h +275 -0
  91. data/ext/pg_query/include/catalog/pg_statistic_d.h +194 -0
  92. data/ext/pg_query/include/catalog/pg_statistic_ext.h +74 -0
  93. data/ext/pg_query/include/catalog/pg_statistic_ext_d.h +40 -0
  94. data/ext/pg_query/include/catalog/pg_transform.h +45 -0
  95. data/ext/pg_query/include/catalog/pg_transform_d.h +32 -0
  96. data/ext/pg_query/include/catalog/pg_trigger.h +137 -0
  97. data/ext/pg_query/include/catalog/pg_trigger_d.h +106 -0
  98. data/ext/pg_query/include/catalog/pg_ts_config.h +50 -0
  99. data/ext/pg_query/include/catalog/pg_ts_config_d.h +32 -0
  100. data/ext/pg_query/include/catalog/pg_ts_dict.h +54 -0
  101. data/ext/pg_query/include/catalog/pg_ts_dict_d.h +33 -0
  102. data/ext/pg_query/include/catalog/pg_ts_parser.h +57 -0
  103. data/ext/pg_query/include/catalog/pg_ts_parser_d.h +35 -0
  104. data/ext/pg_query/include/catalog/pg_ts_template.h +48 -0
  105. data/ext/pg_query/include/catalog/pg_ts_template_d.h +32 -0
  106. data/ext/pg_query/include/catalog/pg_type.h +372 -0
  107. data/ext/pg_query/include/catalog/pg_type_d.h +285 -0
  108. data/ext/pg_query/include/catalog/storage.h +48 -0
  109. data/ext/pg_query/include/commands/async.h +54 -0
  110. data/ext/pg_query/include/commands/dbcommands.h +35 -0
  111. data/ext/pg_query/include/commands/defrem.h +173 -0
  112. data/ext/pg_query/include/commands/event_trigger.h +88 -0
  113. data/ext/pg_query/include/commands/explain.h +127 -0
  114. data/ext/pg_query/include/commands/prepare.h +61 -0
  115. data/ext/pg_query/include/commands/tablespace.h +67 -0
  116. data/ext/pg_query/include/commands/trigger.h +277 -0
  117. data/ext/pg_query/include/commands/user.h +37 -0
  118. data/ext/pg_query/include/commands/vacuum.h +293 -0
  119. data/ext/pg_query/include/commands/variable.h +38 -0
  120. data/ext/pg_query/include/common/file_perm.h +56 -0
  121. data/ext/pg_query/include/common/hashfn.h +104 -0
  122. data/ext/pg_query/include/common/ip.h +37 -0
  123. data/ext/pg_query/include/common/keywords.h +33 -0
  124. data/ext/pg_query/include/common/kwlookup.h +44 -0
  125. data/ext/pg_query/include/common/relpath.h +90 -0
  126. data/ext/pg_query/include/common/string.h +19 -0
  127. data/ext/pg_query/include/common/unicode_combining_table.h +196 -0
  128. data/ext/pg_query/include/datatype/timestamp.h +197 -0
  129. data/ext/pg_query/include/executor/execdesc.h +70 -0
  130. data/ext/pg_query/include/executor/executor.h +614 -0
  131. data/ext/pg_query/include/executor/functions.h +41 -0
  132. data/ext/pg_query/include/executor/instrument.h +101 -0
  133. data/ext/pg_query/include/executor/spi.h +175 -0
  134. data/ext/pg_query/include/executor/tablefunc.h +67 -0
  135. data/ext/pg_query/include/executor/tuptable.h +487 -0
  136. data/ext/pg_query/include/fmgr.h +775 -0
  137. data/ext/pg_query/include/funcapi.h +348 -0
  138. data/ext/pg_query/include/getaddrinfo.h +162 -0
  139. data/ext/pg_query/include/jit/jit.h +105 -0
  140. data/ext/pg_query/include/kwlist_d.h +1072 -0
  141. data/ext/pg_query/include/lib/ilist.h +727 -0
  142. data/ext/pg_query/include/lib/pairingheap.h +102 -0
  143. data/ext/pg_query/include/lib/simplehash.h +1059 -0
  144. data/ext/pg_query/include/lib/stringinfo.h +161 -0
  145. data/ext/pg_query/include/libpq/auth.h +29 -0
  146. data/ext/pg_query/include/libpq/crypt.h +46 -0
  147. data/ext/pg_query/include/libpq/hba.h +140 -0
  148. data/ext/pg_query/include/libpq/libpq-be.h +326 -0
  149. data/ext/pg_query/include/libpq/libpq.h +133 -0
  150. data/ext/pg_query/include/libpq/pqcomm.h +208 -0
  151. data/ext/pg_query/include/libpq/pqformat.h +210 -0
  152. data/ext/pg_query/include/libpq/pqsignal.h +42 -0
  153. data/ext/pg_query/include/mb/pg_wchar.h +672 -0
  154. data/ext/pg_query/include/mb/stringinfo_mb.h +24 -0
  155. data/ext/pg_query/include/miscadmin.h +476 -0
  156. data/ext/pg_query/include/nodes/bitmapset.h +122 -0
  157. data/ext/pg_query/include/nodes/execnodes.h +2520 -0
  158. data/ext/pg_query/include/nodes/extensible.h +160 -0
  159. data/ext/pg_query/include/nodes/lockoptions.h +61 -0
  160. data/ext/pg_query/include/nodes/makefuncs.h +108 -0
  161. data/ext/pg_query/include/nodes/memnodes.h +108 -0
  162. data/ext/pg_query/include/nodes/nodeFuncs.h +162 -0
  163. data/ext/pg_query/include/nodes/nodes.h +842 -0
  164. data/ext/pg_query/include/nodes/params.h +170 -0
  165. data/ext/pg_query/include/nodes/parsenodes.h +3579 -0
  166. data/ext/pg_query/include/nodes/pathnodes.h +2556 -0
  167. data/ext/pg_query/include/nodes/pg_list.h +605 -0
  168. data/ext/pg_query/include/nodes/plannodes.h +1251 -0
  169. data/ext/pg_query/include/nodes/primnodes.h +1541 -0
  170. data/ext/pg_query/include/nodes/print.h +34 -0
  171. data/ext/pg_query/include/nodes/tidbitmap.h +75 -0
  172. data/ext/pg_query/include/nodes/value.h +61 -0
  173. data/ext/pg_query/include/optimizer/cost.h +206 -0
  174. data/ext/pg_query/include/optimizer/geqo.h +88 -0
  175. data/ext/pg_query/include/optimizer/geqo_gene.h +45 -0
  176. data/ext/pg_query/include/optimizer/optimizer.h +199 -0
  177. data/ext/pg_query/include/optimizer/paths.h +249 -0
  178. data/ext/pg_query/include/optimizer/planmain.h +119 -0
  179. data/ext/pg_query/include/parser/analyze.h +49 -0
  180. data/ext/pg_query/include/parser/gram.h +1067 -0
  181. data/ext/pg_query/include/parser/gramparse.h +75 -0
  182. data/ext/pg_query/include/parser/kwlist.h +477 -0
  183. data/ext/pg_query/include/parser/parse_agg.h +68 -0
  184. data/ext/pg_query/include/parser/parse_clause.h +54 -0
  185. data/ext/pg_query/include/parser/parse_coerce.h +97 -0
  186. data/ext/pg_query/include/parser/parse_collate.h +27 -0
  187. data/ext/pg_query/include/parser/parse_expr.h +26 -0
  188. data/ext/pg_query/include/parser/parse_func.h +73 -0
  189. data/ext/pg_query/include/parser/parse_node.h +327 -0
  190. data/ext/pg_query/include/parser/parse_oper.h +67 -0
  191. data/ext/pg_query/include/parser/parse_relation.h +123 -0
  192. data/ext/pg_query/include/parser/parse_target.h +46 -0
  193. data/ext/pg_query/include/parser/parse_type.h +60 -0
  194. data/ext/pg_query/include/parser/parser.h +41 -0
  195. data/ext/pg_query/include/parser/parsetree.h +61 -0
  196. data/ext/pg_query/include/parser/scanner.h +152 -0
  197. data/ext/pg_query/include/parser/scansup.h +30 -0
  198. data/ext/pg_query/include/partitioning/partdefs.h +26 -0
  199. data/ext/pg_query/include/pg_config.h +988 -0
  200. data/ext/pg_query/include/pg_config_ext.h +8 -0
  201. data/ext/pg_query/include/pg_config_manual.h +350 -0
  202. data/ext/pg_query/include/pg_config_os.h +8 -0
  203. data/ext/pg_query/include/pg_getopt.h +56 -0
  204. data/ext/pg_query/include/pg_query.h +121 -0
  205. data/ext/pg_query/include/pg_query_enum_defs.c +2454 -0
  206. data/ext/pg_query/include/pg_query_fingerprint_conds.c +875 -0
  207. data/ext/pg_query/include/pg_query_fingerprint_defs.c +12413 -0
  208. data/ext/pg_query/include/pg_query_json_helper.c +61 -0
  209. data/ext/pg_query/include/pg_query_outfuncs_conds.c +686 -0
  210. data/ext/pg_query/include/pg_query_outfuncs_defs.c +2437 -0
  211. data/ext/pg_query/include/pg_query_readfuncs_conds.c +222 -0
  212. data/ext/pg_query/include/pg_query_readfuncs_defs.c +2878 -0
  213. data/ext/pg_query/include/pg_trace.h +17 -0
  214. data/ext/pg_query/include/pgstat.h +1487 -0
  215. data/ext/pg_query/include/pgtime.h +84 -0
  216. data/ext/pg_query/include/pl_gram.h +385 -0
  217. data/ext/pg_query/include/pl_reserved_kwlist.h +52 -0
  218. data/ext/pg_query/include/pl_reserved_kwlist_d.h +114 -0
  219. data/ext/pg_query/include/pl_unreserved_kwlist.h +112 -0
  220. data/ext/pg_query/include/pl_unreserved_kwlist_d.h +246 -0
  221. data/ext/pg_query/include/plerrcodes.h +990 -0
  222. data/ext/pg_query/include/plpgsql.h +1347 -0
  223. data/ext/pg_query/include/port.h +524 -0
  224. data/ext/pg_query/include/port/atomics.h +524 -0
  225. data/ext/pg_query/include/port/atomics/arch-arm.h +26 -0
  226. data/ext/pg_query/include/port/atomics/arch-ppc.h +254 -0
  227. data/ext/pg_query/include/port/atomics/arch-x86.h +252 -0
  228. data/ext/pg_query/include/port/atomics/fallback.h +170 -0
  229. data/ext/pg_query/include/port/atomics/generic-gcc.h +286 -0
  230. data/ext/pg_query/include/port/atomics/generic.h +401 -0
  231. data/ext/pg_query/include/port/pg_bitutils.h +226 -0
  232. data/ext/pg_query/include/port/pg_bswap.h +161 -0
  233. data/ext/pg_query/include/port/pg_crc32c.h +101 -0
  234. data/ext/pg_query/include/portability/instr_time.h +256 -0
  235. data/ext/pg_query/include/postgres.h +764 -0
  236. data/ext/pg_query/include/postgres_ext.h +74 -0
  237. data/ext/pg_query/include/postmaster/autovacuum.h +83 -0
  238. data/ext/pg_query/include/postmaster/bgworker.h +161 -0
  239. data/ext/pg_query/include/postmaster/bgworker_internals.h +64 -0
  240. data/ext/pg_query/include/postmaster/bgwriter.h +45 -0
  241. data/ext/pg_query/include/postmaster/fork_process.h +17 -0
  242. data/ext/pg_query/include/postmaster/interrupt.h +32 -0
  243. data/ext/pg_query/include/postmaster/pgarch.h +39 -0
  244. data/ext/pg_query/include/postmaster/postmaster.h +77 -0
  245. data/ext/pg_query/include/postmaster/syslogger.h +98 -0
  246. data/ext/pg_query/include/postmaster/walwriter.h +21 -0
  247. data/ext/pg_query/include/protobuf-c.h +1106 -0
  248. data/ext/pg_query/include/protobuf-c/protobuf-c.h +1106 -0
  249. data/ext/pg_query/include/protobuf/pg_query.pb-c.h +10846 -0
  250. data/ext/pg_query/include/protobuf/pg_query.pb.h +124718 -0
  251. data/ext/pg_query/include/regex/regex.h +184 -0
  252. data/ext/pg_query/include/replication/logicallauncher.h +31 -0
  253. data/ext/pg_query/include/replication/logicalproto.h +110 -0
  254. data/ext/pg_query/include/replication/logicalworker.h +19 -0
  255. data/ext/pg_query/include/replication/origin.h +73 -0
  256. data/ext/pg_query/include/replication/reorderbuffer.h +467 -0
  257. data/ext/pg_query/include/replication/slot.h +219 -0
  258. data/ext/pg_query/include/replication/syncrep.h +115 -0
  259. data/ext/pg_query/include/replication/walreceiver.h +340 -0
  260. data/ext/pg_query/include/replication/walsender.h +74 -0
  261. data/ext/pg_query/include/rewrite/prs2lock.h +46 -0
  262. data/ext/pg_query/include/rewrite/rewriteHandler.h +40 -0
  263. data/ext/pg_query/include/rewrite/rewriteManip.h +87 -0
  264. data/ext/pg_query/include/rewrite/rewriteSupport.h +26 -0
  265. data/ext/pg_query/include/storage/backendid.h +37 -0
  266. data/ext/pg_query/include/storage/block.h +121 -0
  267. data/ext/pg_query/include/storage/buf.h +46 -0
  268. data/ext/pg_query/include/storage/bufmgr.h +292 -0
  269. data/ext/pg_query/include/storage/bufpage.h +459 -0
  270. data/ext/pg_query/include/storage/condition_variable.h +62 -0
  271. data/ext/pg_query/include/storage/dsm.h +61 -0
  272. data/ext/pg_query/include/storage/dsm_impl.h +75 -0
  273. data/ext/pg_query/include/storage/fd.h +168 -0
  274. data/ext/pg_query/include/storage/ipc.h +81 -0
  275. data/ext/pg_query/include/storage/item.h +19 -0
  276. data/ext/pg_query/include/storage/itemid.h +184 -0
  277. data/ext/pg_query/include/storage/itemptr.h +206 -0
  278. data/ext/pg_query/include/storage/large_object.h +100 -0
  279. data/ext/pg_query/include/storage/latch.h +190 -0
  280. data/ext/pg_query/include/storage/lmgr.h +114 -0
  281. data/ext/pg_query/include/storage/lock.h +612 -0
  282. data/ext/pg_query/include/storage/lockdefs.h +59 -0
  283. data/ext/pg_query/include/storage/lwlock.h +232 -0
  284. data/ext/pg_query/include/storage/lwlocknames.h +51 -0
  285. data/ext/pg_query/include/storage/off.h +57 -0
  286. data/ext/pg_query/include/storage/pg_sema.h +61 -0
  287. data/ext/pg_query/include/storage/pg_shmem.h +90 -0
  288. data/ext/pg_query/include/storage/pmsignal.h +94 -0
  289. data/ext/pg_query/include/storage/predicate.h +87 -0
  290. data/ext/pg_query/include/storage/proc.h +333 -0
  291. data/ext/pg_query/include/storage/proclist_types.h +51 -0
  292. data/ext/pg_query/include/storage/procsignal.h +75 -0
  293. data/ext/pg_query/include/storage/relfilenode.h +99 -0
  294. data/ext/pg_query/include/storage/s_lock.h +1047 -0
  295. data/ext/pg_query/include/storage/sharedfileset.h +45 -0
  296. data/ext/pg_query/include/storage/shm_mq.h +85 -0
  297. data/ext/pg_query/include/storage/shm_toc.h +58 -0
  298. data/ext/pg_query/include/storage/shmem.h +81 -0
  299. data/ext/pg_query/include/storage/sinval.h +153 -0
  300. data/ext/pg_query/include/storage/sinvaladt.h +43 -0
  301. data/ext/pg_query/include/storage/smgr.h +109 -0
  302. data/ext/pg_query/include/storage/spin.h +77 -0
  303. data/ext/pg_query/include/storage/standby.h +91 -0
  304. data/ext/pg_query/include/storage/standbydefs.h +74 -0
  305. data/ext/pg_query/include/storage/sync.h +62 -0
  306. data/ext/pg_query/include/tcop/cmdtag.h +58 -0
  307. data/ext/pg_query/include/tcop/cmdtaglist.h +217 -0
  308. data/ext/pg_query/include/tcop/deparse_utility.h +108 -0
  309. data/ext/pg_query/include/tcop/dest.h +149 -0
  310. data/ext/pg_query/include/tcop/fastpath.h +21 -0
  311. data/ext/pg_query/include/tcop/pquery.h +45 -0
  312. data/ext/pg_query/include/tcop/tcopprot.h +89 -0
  313. data/ext/pg_query/include/tcop/utility.h +108 -0
  314. data/ext/pg_query/include/tsearch/ts_cache.h +98 -0
  315. data/ext/pg_query/include/utils/acl.h +312 -0
  316. data/ext/pg_query/include/utils/aclchk_internal.h +45 -0
  317. data/ext/pg_query/include/utils/array.h +458 -0
  318. data/ext/pg_query/include/utils/builtins.h +127 -0
  319. data/ext/pg_query/include/utils/bytea.h +27 -0
  320. data/ext/pg_query/include/utils/catcache.h +231 -0
  321. data/ext/pg_query/include/utils/date.h +90 -0
  322. data/ext/pg_query/include/utils/datetime.h +343 -0
  323. data/ext/pg_query/include/utils/datum.h +68 -0
  324. data/ext/pg_query/include/utils/dsa.h +123 -0
  325. data/ext/pg_query/include/utils/dynahash.h +19 -0
  326. data/ext/pg_query/include/utils/elog.h +439 -0
  327. data/ext/pg_query/include/utils/errcodes.h +352 -0
  328. data/ext/pg_query/include/utils/expandeddatum.h +159 -0
  329. data/ext/pg_query/include/utils/expandedrecord.h +231 -0
  330. data/ext/pg_query/include/utils/float.h +356 -0
  331. data/ext/pg_query/include/utils/fmgroids.h +2657 -0
  332. data/ext/pg_query/include/utils/fmgrprotos.h +2646 -0
  333. data/ext/pg_query/include/utils/fmgrtab.h +48 -0
  334. data/ext/pg_query/include/utils/guc.h +443 -0
  335. data/ext/pg_query/include/utils/guc_tables.h +272 -0
  336. data/ext/pg_query/include/utils/hsearch.h +149 -0
  337. data/ext/pg_query/include/utils/inval.h +64 -0
  338. data/ext/pg_query/include/utils/lsyscache.h +197 -0
  339. data/ext/pg_query/include/utils/memdebug.h +82 -0
  340. data/ext/pg_query/include/utils/memutils.h +225 -0
  341. data/ext/pg_query/include/utils/numeric.h +76 -0
  342. data/ext/pg_query/include/utils/palloc.h +136 -0
  343. data/ext/pg_query/include/utils/partcache.h +102 -0
  344. data/ext/pg_query/include/utils/pg_locale.h +119 -0
  345. data/ext/pg_query/include/utils/pg_lsn.h +29 -0
  346. data/ext/pg_query/include/utils/pidfile.h +56 -0
  347. data/ext/pg_query/include/utils/plancache.h +235 -0
  348. data/ext/pg_query/include/utils/portal.h +241 -0
  349. data/ext/pg_query/include/utils/probes.h +114 -0
  350. data/ext/pg_query/include/utils/ps_status.h +25 -0
  351. data/ext/pg_query/include/utils/queryenvironment.h +74 -0
  352. data/ext/pg_query/include/utils/regproc.h +28 -0
  353. data/ext/pg_query/include/utils/rel.h +644 -0
  354. data/ext/pg_query/include/utils/relcache.h +151 -0
  355. data/ext/pg_query/include/utils/reltrigger.h +81 -0
  356. data/ext/pg_query/include/utils/resowner.h +86 -0
  357. data/ext/pg_query/include/utils/rls.h +50 -0
  358. data/ext/pg_query/include/utils/ruleutils.h +44 -0
  359. data/ext/pg_query/include/utils/sharedtuplestore.h +61 -0
  360. data/ext/pg_query/include/utils/snapmgr.h +158 -0
  361. data/ext/pg_query/include/utils/snapshot.h +206 -0
  362. data/ext/pg_query/include/utils/sortsupport.h +276 -0
  363. data/ext/pg_query/include/utils/syscache.h +219 -0
  364. data/ext/pg_query/include/utils/timeout.h +88 -0
  365. data/ext/pg_query/include/utils/timestamp.h +116 -0
  366. data/ext/pg_query/include/utils/tuplesort.h +277 -0
  367. data/ext/pg_query/include/utils/tuplestore.h +91 -0
  368. data/ext/pg_query/include/utils/typcache.h +202 -0
  369. data/ext/pg_query/include/utils/tzparser.h +39 -0
  370. data/ext/pg_query/include/utils/varlena.h +39 -0
  371. data/ext/pg_query/include/utils/xml.h +84 -0
  372. data/ext/pg_query/include/xxhash.h +5445 -0
  373. data/ext/pg_query/include/xxhash/xxhash.h +5445 -0
  374. data/lib/pg_query/version.rb +1 -1
  375. metadata +372 -1
@@ -0,0 +1,77 @@
1
+ /*
2
+ * commit_ts.h
3
+ *
4
+ * PostgreSQL commit timestamp manager
5
+ *
6
+ * Portions Copyright (c) 1996-2020, PostgreSQL Global Development Group
7
+ * Portions Copyright (c) 1994, Regents of the University of California
8
+ *
9
+ * src/include/access/commit_ts.h
10
+ */
11
+ #ifndef COMMIT_TS_H
12
+ #define COMMIT_TS_H
13
+
14
+ #include "access/xlog.h"
15
+ #include "datatype/timestamp.h"
16
+ #include "replication/origin.h"
17
+ #include "utils/guc.h"
18
+
19
+
20
+ extern PGDLLIMPORT bool track_commit_timestamp;
21
+
22
+ extern bool check_track_commit_timestamp(bool *newval, void **extra,
23
+ GucSource source);
24
+
25
+ extern void TransactionTreeSetCommitTsData(TransactionId xid, int nsubxids,
26
+ TransactionId *subxids, TimestampTz timestamp,
27
+ RepOriginId nodeid, bool write_xlog);
28
+ extern bool TransactionIdGetCommitTsData(TransactionId xid,
29
+ TimestampTz *ts, RepOriginId *nodeid);
30
+ extern TransactionId GetLatestCommitTsData(TimestampTz *ts,
31
+ RepOriginId *nodeid);
32
+
33
+ extern Size CommitTsShmemBuffers(void);
34
+ extern Size CommitTsShmemSize(void);
35
+ extern void CommitTsShmemInit(void);
36
+ extern void BootStrapCommitTs(void);
37
+ extern void StartupCommitTs(void);
38
+ extern void CommitTsParameterChange(bool newvalue, bool oldvalue);
39
+ extern void CompleteCommitTsInitialization(void);
40
+ extern void ShutdownCommitTs(void);
41
+ extern void CheckPointCommitTs(void);
42
+ extern void ExtendCommitTs(TransactionId newestXact);
43
+ extern void TruncateCommitTs(TransactionId oldestXact);
44
+ extern void SetCommitTsLimit(TransactionId oldestXact,
45
+ TransactionId newestXact);
46
+ extern void AdvanceOldestCommitTsXid(TransactionId oldestXact);
47
+
48
+ /* XLOG stuff */
49
+ #define COMMIT_TS_ZEROPAGE 0x00
50
+ #define COMMIT_TS_TRUNCATE 0x10
51
+ #define COMMIT_TS_SETTS 0x20
52
+
53
+ typedef struct xl_commit_ts_set
54
+ {
55
+ TimestampTz timestamp;
56
+ RepOriginId nodeid;
57
+ TransactionId mainxid;
58
+ /* subxact Xids follow */
59
+ } xl_commit_ts_set;
60
+
61
+ #define SizeOfCommitTsSet (offsetof(xl_commit_ts_set, mainxid) + \
62
+ sizeof(TransactionId))
63
+
64
+ typedef struct xl_commit_ts_truncate
65
+ {
66
+ int pageno;
67
+ TransactionId oldestXid;
68
+ } xl_commit_ts_truncate;
69
+
70
+ #define SizeOfCommitTsTruncate (offsetof(xl_commit_ts_truncate, oldestXid) + \
71
+ sizeof(TransactionId))
72
+
73
+ extern void commit_ts_redo(XLogReaderState *record);
74
+ extern void commit_ts_desc(StringInfo buf, XLogReaderState *record);
75
+ extern const char *commit_ts_identify(uint8 info);
76
+
77
+ #endif /* COMMIT_TS_H */
@@ -0,0 +1,92 @@
1
+ /*-------------------------------------------------------------------------
2
+ *
3
+ * detoast.h
4
+ * Access to compressed and external varlena values.
5
+ *
6
+ * Copyright (c) 2000-2020, PostgreSQL Global Development Group
7
+ *
8
+ * src/include/access/detoast.h
9
+ *
10
+ *-------------------------------------------------------------------------
11
+ */
12
+ #ifndef DETOAST_H
13
+ #define DETOAST_H
14
+
15
+ /*
16
+ * Testing whether an externally-stored value is compressed now requires
17
+ * comparing extsize (the actual length of the external data) to rawsize
18
+ * (the original uncompressed datum's size). The latter includes VARHDRSZ
19
+ * overhead, the former doesn't. We never use compression unless it actually
20
+ * saves space, so we expect either equality or less-than.
21
+ */
22
+ #define VARATT_EXTERNAL_IS_COMPRESSED(toast_pointer) \
23
+ ((toast_pointer).va_extsize < (toast_pointer).va_rawsize - VARHDRSZ)
24
+
25
+ /*
26
+ * Macro to fetch the possibly-unaligned contents of an EXTERNAL datum
27
+ * into a local "struct varatt_external" toast pointer. This should be
28
+ * just a memcpy, but some versions of gcc seem to produce broken code
29
+ * that assumes the datum contents are aligned. Introducing an explicit
30
+ * intermediate "varattrib_1b_e *" variable seems to fix it.
31
+ */
32
+ #define VARATT_EXTERNAL_GET_POINTER(toast_pointer, attr) \
33
+ do { \
34
+ varattrib_1b_e *attre = (varattrib_1b_e *) (attr); \
35
+ Assert(VARATT_IS_EXTERNAL(attre)); \
36
+ Assert(VARSIZE_EXTERNAL(attre) == sizeof(toast_pointer) + VARHDRSZ_EXTERNAL); \
37
+ memcpy(&(toast_pointer), VARDATA_EXTERNAL(attre), sizeof(toast_pointer)); \
38
+ } while (0)
39
+
40
+ /* Size of an EXTERNAL datum that contains a standard TOAST pointer */
41
+ #define TOAST_POINTER_SIZE (VARHDRSZ_EXTERNAL + sizeof(varatt_external))
42
+
43
+ /* Size of an EXTERNAL datum that contains an indirection pointer */
44
+ #define INDIRECT_POINTER_SIZE (VARHDRSZ_EXTERNAL + sizeof(varatt_indirect))
45
+
46
+ /* ----------
47
+ * detoast_external_attr() -
48
+ *
49
+ * Fetches an external stored attribute from the toast
50
+ * relation. Does NOT decompress it, if stored external
51
+ * in compressed format.
52
+ * ----------
53
+ */
54
+ extern struct varlena *detoast_external_attr(struct varlena *attr);
55
+
56
+ /* ----------
57
+ * detoast_attr() -
58
+ *
59
+ * Fully detoasts one attribute, fetching and/or decompressing
60
+ * it as needed.
61
+ * ----------
62
+ */
63
+ extern struct varlena *detoast_attr(struct varlena *attr);
64
+
65
+ /* ----------
66
+ * detoast_attr_slice() -
67
+ *
68
+ * Fetches only the specified portion of an attribute.
69
+ * (Handles all cases for attribute storage)
70
+ * ----------
71
+ */
72
+ extern struct varlena *detoast_attr_slice(struct varlena *attr,
73
+ int32 sliceoffset,
74
+ int32 slicelength);
75
+
76
+ /* ----------
77
+ * toast_raw_datum_size -
78
+ *
79
+ * Return the raw (detoasted) size of a varlena datum
80
+ * ----------
81
+ */
82
+ extern Size toast_raw_datum_size(Datum value);
83
+
84
+ /* ----------
85
+ * toast_datum_size -
86
+ *
87
+ * Return the storage size of a varlena datum
88
+ * ----------
89
+ */
90
+ extern Size toast_datum_size(Datum value);
91
+
92
+ #endif /* DETOAST_H */
@@ -0,0 +1,228 @@
1
+ /*-------------------------------------------------------------------------
2
+ *
3
+ * genam.h
4
+ * POSTGRES generalized index access method definitions.
5
+ *
6
+ *
7
+ * Portions Copyright (c) 1996-2020, PostgreSQL Global Development Group
8
+ * Portions Copyright (c) 1994, Regents of the University of California
9
+ *
10
+ * src/include/access/genam.h
11
+ *
12
+ *-------------------------------------------------------------------------
13
+ */
14
+ #ifndef GENAM_H
15
+ #define GENAM_H
16
+
17
+ #include "access/sdir.h"
18
+ #include "access/skey.h"
19
+ #include "nodes/tidbitmap.h"
20
+ #include "storage/lockdefs.h"
21
+ #include "utils/relcache.h"
22
+ #include "utils/snapshot.h"
23
+
24
+ /* We don't want this file to depend on execnodes.h. */
25
+ struct IndexInfo;
26
+
27
+ /*
28
+ * Struct for statistics returned by ambuild
29
+ */
30
+ typedef struct IndexBuildResult
31
+ {
32
+ double heap_tuples; /* # of tuples seen in parent table */
33
+ double index_tuples; /* # of tuples inserted into index */
34
+ } IndexBuildResult;
35
+
36
+ /*
37
+ * Struct for input arguments passed to ambulkdelete and amvacuumcleanup
38
+ *
39
+ * num_heap_tuples is accurate only when estimated_count is false;
40
+ * otherwise it's just an estimate (currently, the estimate is the
41
+ * prior value of the relation's pg_class.reltuples field). It will
42
+ * always just be an estimate during ambulkdelete.
43
+ */
44
+ typedef struct IndexVacuumInfo
45
+ {
46
+ Relation index; /* the index being vacuumed */
47
+ bool analyze_only; /* ANALYZE (without any actual vacuum) */
48
+ bool report_progress; /* emit progress.h status reports */
49
+ bool estimated_count; /* num_heap_tuples is an estimate */
50
+ int message_level; /* ereport level for progress messages */
51
+ double num_heap_tuples; /* tuples remaining in heap */
52
+ BufferAccessStrategy strategy; /* access strategy for reads */
53
+ } IndexVacuumInfo;
54
+
55
+ /*
56
+ * Struct for statistics returned by ambulkdelete and amvacuumcleanup
57
+ *
58
+ * This struct is normally allocated by the first ambulkdelete call and then
59
+ * passed along through subsequent ones until amvacuumcleanup; however,
60
+ * amvacuumcleanup must be prepared to allocate it in the case where no
61
+ * ambulkdelete calls were made (because no tuples needed deletion).
62
+ * Note that an index AM could choose to return a larger struct
63
+ * of which this is just the first field; this provides a way for ambulkdelete
64
+ * to communicate additional private data to amvacuumcleanup.
65
+ *
66
+ * Note: pages_removed is the amount by which the index physically shrank,
67
+ * if any (ie the change in its total size on disk). pages_deleted and
68
+ * pages_free refer to free space within the index file. Some index AMs
69
+ * may compute num_index_tuples by reference to num_heap_tuples, in which
70
+ * case they should copy the estimated_count field from IndexVacuumInfo.
71
+ */
72
+ typedef struct IndexBulkDeleteResult
73
+ {
74
+ BlockNumber num_pages; /* pages remaining in index */
75
+ BlockNumber pages_removed; /* # removed during vacuum operation */
76
+ bool estimated_count; /* num_index_tuples is an estimate */
77
+ double num_index_tuples; /* tuples remaining */
78
+ double tuples_removed; /* # removed during vacuum operation */
79
+ BlockNumber pages_deleted; /* # unused pages in index */
80
+ BlockNumber pages_free; /* # pages available for reuse */
81
+ } IndexBulkDeleteResult;
82
+
83
+ /* Typedef for callback function to determine if a tuple is bulk-deletable */
84
+ typedef bool (*IndexBulkDeleteCallback) (ItemPointer itemptr, void *state);
85
+
86
+ /* struct definitions appear in relscan.h */
87
+ typedef struct IndexScanDescData *IndexScanDesc;
88
+ typedef struct SysScanDescData *SysScanDesc;
89
+
90
+ typedef struct ParallelIndexScanDescData *ParallelIndexScanDesc;
91
+
92
+ /*
93
+ * Enumeration specifying the type of uniqueness check to perform in
94
+ * index_insert().
95
+ *
96
+ * UNIQUE_CHECK_YES is the traditional Postgres immediate check, possibly
97
+ * blocking to see if a conflicting transaction commits.
98
+ *
99
+ * For deferrable unique constraints, UNIQUE_CHECK_PARTIAL is specified at
100
+ * insertion time. The index AM should test if the tuple is unique, but
101
+ * should not throw error, block, or prevent the insertion if the tuple
102
+ * appears not to be unique. We'll recheck later when it is time for the
103
+ * constraint to be enforced. The AM must return true if the tuple is
104
+ * known unique, false if it is possibly non-unique. In the "true" case
105
+ * it is safe to omit the later recheck.
106
+ *
107
+ * When it is time to recheck the deferred constraint, a pseudo-insertion
108
+ * call is made with UNIQUE_CHECK_EXISTING. The tuple is already in the
109
+ * index in this case, so it should not be inserted again. Rather, just
110
+ * check for conflicting live tuples (possibly blocking).
111
+ */
112
+ typedef enum IndexUniqueCheck
113
+ {
114
+ UNIQUE_CHECK_NO, /* Don't do any uniqueness checking */
115
+ UNIQUE_CHECK_YES, /* Enforce uniqueness at insertion time */
116
+ UNIQUE_CHECK_PARTIAL, /* Test uniqueness, but no error */
117
+ UNIQUE_CHECK_EXISTING /* Check if existing tuple is unique */
118
+ } IndexUniqueCheck;
119
+
120
+
121
+ /* Nullable "ORDER BY col op const" distance */
122
+ typedef struct IndexOrderByDistance
123
+ {
124
+ double value;
125
+ bool isnull;
126
+ } IndexOrderByDistance;
127
+
128
+ /*
129
+ * generalized index_ interface routines (in indexam.c)
130
+ */
131
+
132
+ /*
133
+ * IndexScanIsValid
134
+ * True iff the index scan is valid.
135
+ */
136
+ #define IndexScanIsValid(scan) PointerIsValid(scan)
137
+
138
+ extern Relation index_open(Oid relationId, LOCKMODE lockmode);
139
+ extern void index_close(Relation relation, LOCKMODE lockmode);
140
+
141
+ extern bool index_insert(Relation indexRelation,
142
+ Datum *values, bool *isnull,
143
+ ItemPointer heap_t_ctid,
144
+ Relation heapRelation,
145
+ IndexUniqueCheck checkUnique,
146
+ struct IndexInfo *indexInfo);
147
+
148
+ extern IndexScanDesc index_beginscan(Relation heapRelation,
149
+ Relation indexRelation,
150
+ Snapshot snapshot,
151
+ int nkeys, int norderbys);
152
+ extern IndexScanDesc index_beginscan_bitmap(Relation indexRelation,
153
+ Snapshot snapshot,
154
+ int nkeys);
155
+ extern void index_rescan(IndexScanDesc scan,
156
+ ScanKey keys, int nkeys,
157
+ ScanKey orderbys, int norderbys);
158
+ extern void index_endscan(IndexScanDesc scan);
159
+ extern void index_markpos(IndexScanDesc scan);
160
+ extern void index_restrpos(IndexScanDesc scan);
161
+ extern Size index_parallelscan_estimate(Relation indexrel, Snapshot snapshot);
162
+ extern void index_parallelscan_initialize(Relation heaprel, Relation indexrel,
163
+ Snapshot snapshot, ParallelIndexScanDesc target);
164
+ extern void index_parallelrescan(IndexScanDesc scan);
165
+ extern IndexScanDesc index_beginscan_parallel(Relation heaprel,
166
+ Relation indexrel, int nkeys, int norderbys,
167
+ ParallelIndexScanDesc pscan);
168
+ extern ItemPointer index_getnext_tid(IndexScanDesc scan,
169
+ ScanDirection direction);
170
+ struct TupleTableSlot;
171
+ extern bool index_fetch_heap(IndexScanDesc scan, struct TupleTableSlot *slot);
172
+ extern bool index_getnext_slot(IndexScanDesc scan, ScanDirection direction,
173
+ struct TupleTableSlot *slot);
174
+ extern int64 index_getbitmap(IndexScanDesc scan, TIDBitmap *bitmap);
175
+
176
+ extern IndexBulkDeleteResult *index_bulk_delete(IndexVacuumInfo *info,
177
+ IndexBulkDeleteResult *stats,
178
+ IndexBulkDeleteCallback callback,
179
+ void *callback_state);
180
+ extern IndexBulkDeleteResult *index_vacuum_cleanup(IndexVacuumInfo *info,
181
+ IndexBulkDeleteResult *stats);
182
+ extern bool index_can_return(Relation indexRelation, int attno);
183
+ extern RegProcedure index_getprocid(Relation irel, AttrNumber attnum,
184
+ uint16 procnum);
185
+ extern FmgrInfo *index_getprocinfo(Relation irel, AttrNumber attnum,
186
+ uint16 procnum);
187
+ extern void index_store_float8_orderby_distances(IndexScanDesc scan,
188
+ Oid *orderByTypes,
189
+ IndexOrderByDistance *distances,
190
+ bool recheckOrderBy);
191
+ extern bytea *index_opclass_options(Relation relation, AttrNumber attnum,
192
+ Datum attoptions, bool validate);
193
+
194
+
195
+ /*
196
+ * index access method support routines (in genam.c)
197
+ */
198
+ extern IndexScanDesc RelationGetIndexScan(Relation indexRelation,
199
+ int nkeys, int norderbys);
200
+ extern void IndexScanEnd(IndexScanDesc scan);
201
+ extern char *BuildIndexValueDescription(Relation indexRelation,
202
+ Datum *values, bool *isnull);
203
+ extern TransactionId index_compute_xid_horizon_for_tuples(Relation irel,
204
+ Relation hrel,
205
+ Buffer ibuf,
206
+ OffsetNumber *itemnos,
207
+ int nitems);
208
+
209
+ /*
210
+ * heap-or-index access to system catalogs (in genam.c)
211
+ */
212
+ extern SysScanDesc systable_beginscan(Relation heapRelation,
213
+ Oid indexId,
214
+ bool indexOK,
215
+ Snapshot snapshot,
216
+ int nkeys, ScanKey key);
217
+ extern HeapTuple systable_getnext(SysScanDesc sysscan);
218
+ extern bool systable_recheck_tuple(SysScanDesc sysscan, HeapTuple tup);
219
+ extern void systable_endscan(SysScanDesc sysscan);
220
+ extern SysScanDesc systable_beginscan_ordered(Relation heapRelation,
221
+ Relation indexRelation,
222
+ Snapshot snapshot,
223
+ int nkeys, ScanKey key);
224
+ extern HeapTuple systable_getnext_ordered(SysScanDesc sysscan,
225
+ ScanDirection direction);
226
+ extern void systable_endscan_ordered(SysScanDesc sysscan);
227
+
228
+ #endif /* GENAM_H */
@@ -0,0 +1,78 @@
1
+ /*--------------------------------------------------------------------------
2
+ * gin.h
3
+ * Public header file for Generalized Inverted Index access method.
4
+ *
5
+ * Copyright (c) 2006-2020, PostgreSQL Global Development Group
6
+ *
7
+ * src/include/access/gin.h
8
+ *--------------------------------------------------------------------------
9
+ */
10
+ #ifndef GIN_H
11
+ #define GIN_H
12
+
13
+ #include "access/xlogreader.h"
14
+ #include "lib/stringinfo.h"
15
+ #include "storage/block.h"
16
+ #include "utils/relcache.h"
17
+
18
+
19
+ /*
20
+ * amproc indexes for inverted indexes.
21
+ */
22
+ #define GIN_COMPARE_PROC 1
23
+ #define GIN_EXTRACTVALUE_PROC 2
24
+ #define GIN_EXTRACTQUERY_PROC 3
25
+ #define GIN_CONSISTENT_PROC 4
26
+ #define GIN_COMPARE_PARTIAL_PROC 5
27
+ #define GIN_TRICONSISTENT_PROC 6
28
+ #define GIN_OPTIONS_PROC 7
29
+ #define GINNProcs 7
30
+
31
+ /*
32
+ * searchMode settings for extractQueryFn.
33
+ */
34
+ #define GIN_SEARCH_MODE_DEFAULT 0
35
+ #define GIN_SEARCH_MODE_INCLUDE_EMPTY 1
36
+ #define GIN_SEARCH_MODE_ALL 2
37
+ #define GIN_SEARCH_MODE_EVERYTHING 3 /* for internal use only */
38
+
39
+ /*
40
+ * GinStatsData represents stats data for planner use
41
+ */
42
+ typedef struct GinStatsData
43
+ {
44
+ BlockNumber nPendingPages;
45
+ BlockNumber nTotalPages;
46
+ BlockNumber nEntryPages;
47
+ BlockNumber nDataPages;
48
+ int64 nEntries;
49
+ int32 ginVersion;
50
+ } GinStatsData;
51
+
52
+ /*
53
+ * A ternary value used by tri-consistent functions.
54
+ *
55
+ * This must be of the same size as a bool because some code will cast a
56
+ * pointer to a bool to a pointer to a GinTernaryValue.
57
+ */
58
+ typedef char GinTernaryValue;
59
+
60
+ #define GIN_FALSE 0 /* item is not present / does not match */
61
+ #define GIN_TRUE 1 /* item is present / matches */
62
+ #define GIN_MAYBE 2 /* don't know if item is present / don't know
63
+ * if matches */
64
+
65
+ #define DatumGetGinTernaryValue(X) ((GinTernaryValue)(X))
66
+ #define GinTernaryValueGetDatum(X) ((Datum)(X))
67
+ #define PG_RETURN_GIN_TERNARY_VALUE(x) return GinTernaryValueGetDatum(x)
68
+
69
+ /* GUC parameters */
70
+ extern PGDLLIMPORT int GinFuzzySearchLimit;
71
+ extern int gin_pending_list_limit;
72
+
73
+ /* ginutil.c */
74
+ extern void ginGetStats(Relation index, GinStatsData *stats);
75
+ extern void ginUpdateStats(Relation index, const GinStatsData *stats,
76
+ bool is_build);
77
+
78
+ #endif /* GIN_H */