pg_query 1.3.0 → 2.0.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (109) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +86 -52
  3. data/README.md +72 -65
  4. data/Rakefile +82 -1
  5. data/ext/pg_query/extconf.rb +2 -39
  6. data/ext/pg_query/guc-file.c +0 -0
  7. data/ext/pg_query/pg_query.c +104 -0
  8. data/ext/pg_query/pg_query.pb-c.c +37628 -0
  9. data/ext/pg_query/pg_query_deparse.c +9953 -0
  10. data/ext/pg_query/pg_query_fingerprint.c +292 -0
  11. data/ext/pg_query/pg_query_fingerprint.h +8 -0
  12. data/ext/pg_query/pg_query_internal.h +24 -0
  13. data/ext/pg_query/pg_query_json_plpgsql.c +738 -0
  14. data/ext/pg_query/pg_query_json_plpgsql.h +9 -0
  15. data/ext/pg_query/pg_query_normalize.c +437 -0
  16. data/ext/pg_query/pg_query_outfuncs.h +10 -0
  17. data/ext/pg_query/pg_query_outfuncs_json.c +297 -0
  18. data/ext/pg_query/pg_query_outfuncs_protobuf.c +237 -0
  19. data/ext/pg_query/pg_query_parse.c +148 -0
  20. data/ext/pg_query/pg_query_parse_plpgsql.c +460 -0
  21. data/ext/pg_query/pg_query_readfuncs.h +11 -0
  22. data/ext/pg_query/pg_query_readfuncs_protobuf.c +142 -0
  23. data/ext/pg_query/pg_query_ruby.c +108 -12
  24. data/ext/pg_query/pg_query_scan.c +173 -0
  25. data/ext/pg_query/pg_query_split.c +221 -0
  26. data/ext/pg_query/protobuf-c.c +3660 -0
  27. data/ext/pg_query/src_backend_catalog_namespace.c +1051 -0
  28. data/ext/pg_query/src_backend_catalog_pg_proc.c +142 -0
  29. data/ext/pg_query/src_backend_commands_define.c +117 -0
  30. data/ext/pg_query/src_backend_libpq_pqcomm.c +651 -0
  31. data/ext/pg_query/src_backend_nodes_bitmapset.c +513 -0
  32. data/ext/pg_query/src_backend_nodes_copyfuncs.c +6013 -0
  33. data/ext/pg_query/src_backend_nodes_equalfuncs.c +4003 -0
  34. data/ext/pg_query/src_backend_nodes_extensible.c +99 -0
  35. data/ext/pg_query/src_backend_nodes_list.c +922 -0
  36. data/ext/pg_query/src_backend_nodes_makefuncs.c +417 -0
  37. data/ext/pg_query/src_backend_nodes_nodeFuncs.c +1363 -0
  38. data/ext/pg_query/src_backend_nodes_value.c +84 -0
  39. data/ext/pg_query/src_backend_parser_gram.c +47456 -0
  40. data/ext/pg_query/src_backend_parser_parse_expr.c +313 -0
  41. data/ext/pg_query/src_backend_parser_parser.c +497 -0
  42. data/ext/pg_query/src_backend_parser_scan.c +7091 -0
  43. data/ext/pg_query/src_backend_parser_scansup.c +160 -0
  44. data/ext/pg_query/src_backend_postmaster_postmaster.c +2230 -0
  45. data/ext/pg_query/src_backend_storage_ipc_ipc.c +192 -0
  46. data/ext/pg_query/src_backend_storage_lmgr_s_lock.c +370 -0
  47. data/ext/pg_query/src_backend_tcop_postgres.c +776 -0
  48. data/ext/pg_query/src_backend_utils_adt_datum.c +326 -0
  49. data/ext/pg_query/src_backend_utils_adt_expandeddatum.c +98 -0
  50. data/ext/pg_query/src_backend_utils_adt_format_type.c +136 -0
  51. data/ext/pg_query/src_backend_utils_adt_ruleutils.c +1683 -0
  52. data/ext/pg_query/src_backend_utils_error_assert.c +74 -0
  53. data/ext/pg_query/src_backend_utils_error_elog.c +1748 -0
  54. data/ext/pg_query/src_backend_utils_fmgr_fmgr.c +570 -0
  55. data/ext/pg_query/src_backend_utils_hash_dynahash.c +1086 -0
  56. data/ext/pg_query/src_backend_utils_init_globals.c +168 -0
  57. data/ext/pg_query/src_backend_utils_mb_mbutils.c +839 -0
  58. data/ext/pg_query/src_backend_utils_misc_guc.c +1831 -0
  59. data/ext/pg_query/src_backend_utils_mmgr_aset.c +1560 -0
  60. data/ext/pg_query/src_backend_utils_mmgr_mcxt.c +1006 -0
  61. data/ext/pg_query/src_common_encnames.c +158 -0
  62. data/ext/pg_query/src_common_keywords.c +39 -0
  63. data/ext/pg_query/src_common_kwlist_d.h +1081 -0
  64. data/ext/pg_query/src_common_kwlookup.c +91 -0
  65. data/ext/pg_query/src_common_psprintf.c +158 -0
  66. data/ext/pg_query/src_common_string.c +86 -0
  67. data/ext/pg_query/src_common_stringinfo.c +336 -0
  68. data/ext/pg_query/src_common_wchar.c +1651 -0
  69. data/ext/pg_query/src_pl_plpgsql_src_pl_comp.c +1133 -0
  70. data/ext/pg_query/src_pl_plpgsql_src_pl_funcs.c +877 -0
  71. data/ext/pg_query/src_pl_plpgsql_src_pl_gram.c +6533 -0
  72. data/ext/pg_query/src_pl_plpgsql_src_pl_handler.c +107 -0
  73. data/ext/pg_query/src_pl_plpgsql_src_pl_reserved_kwlist_d.h +123 -0
  74. data/ext/pg_query/src_pl_plpgsql_src_pl_scanner.c +671 -0
  75. data/ext/pg_query/src_pl_plpgsql_src_pl_unreserved_kwlist_d.h +255 -0
  76. data/ext/pg_query/src_port_erand48.c +127 -0
  77. data/ext/pg_query/src_port_pg_bitutils.c +246 -0
  78. data/ext/pg_query/src_port_pgsleep.c +69 -0
  79. data/ext/pg_query/src_port_pgstrcasecmp.c +83 -0
  80. data/ext/pg_query/src_port_qsort.c +240 -0
  81. data/ext/pg_query/src_port_random.c +31 -0
  82. data/ext/pg_query/src_port_snprintf.c +1449 -0
  83. data/ext/pg_query/src_port_strerror.c +324 -0
  84. data/ext/pg_query/src_port_strnlen.c +39 -0
  85. data/ext/pg_query/xxhash.c +43 -0
  86. data/lib/pg_query.rb +7 -4
  87. data/lib/pg_query/constants.rb +21 -0
  88. data/lib/pg_query/deparse.rb +15 -1673
  89. data/lib/pg_query/filter_columns.rb +86 -85
  90. data/lib/pg_query/fingerprint.rb +122 -87
  91. data/lib/pg_query/json_field_names.rb +1402 -0
  92. data/lib/pg_query/node.rb +31 -0
  93. data/lib/pg_query/param_refs.rb +42 -37
  94. data/lib/pg_query/parse.rb +220 -203
  95. data/lib/pg_query/parse_error.rb +1 -1
  96. data/lib/pg_query/pg_query_pb.rb +3211 -0
  97. data/lib/pg_query/scan.rb +23 -0
  98. data/lib/pg_query/treewalker.rb +24 -40
  99. data/lib/pg_query/truncate.rb +64 -43
  100. data/lib/pg_query/version.rb +2 -2
  101. metadata +101 -11
  102. data/ext/pg_query/pg_query_ruby.h +0 -10
  103. data/lib/pg_query/deep_dup.rb +0 -16
  104. data/lib/pg_query/deparse/alter_table.rb +0 -42
  105. data/lib/pg_query/deparse/interval.rb +0 -105
  106. data/lib/pg_query/deparse/keywords.rb +0 -159
  107. data/lib/pg_query/deparse/rename.rb +0 -41
  108. data/lib/pg_query/legacy_parsetree.rb +0 -109
  109. data/lib/pg_query/node_types.rb +0 -297
@@ -0,0 +1,324 @@
1
+ /*--------------------------------------------------------------------
2
+ * Symbols referenced in this file:
3
+ * - pg_strerror_r
4
+ * - gnuish_strerror_r
5
+ * - get_errno_symbol
6
+ *--------------------------------------------------------------------
7
+ */
8
+
9
+ /*-------------------------------------------------------------------------
10
+ *
11
+ * strerror.c
12
+ * Replacements for standard strerror() and strerror_r() functions
13
+ *
14
+ * Portions Copyright (c) 1996-2020, PostgreSQL Global Development Group
15
+ * Portions Copyright (c) 1994, Regents of the University of California
16
+ *
17
+ *
18
+ * IDENTIFICATION
19
+ * src/port/strerror.c
20
+ *
21
+ *-------------------------------------------------------------------------
22
+ */
23
+ #include "c.h"
24
+
25
+ /*
26
+ * Within this file, "strerror" means the platform's function not pg_strerror,
27
+ * and likewise for "strerror_r"
28
+ */
29
+ #undef strerror
30
+ #undef strerror_r
31
+
32
+ static char *gnuish_strerror_r(int errnum, char *buf, size_t buflen);
33
+ static char *get_errno_symbol(int errnum);
34
+ #ifdef WIN32
35
+ static char *win32_socket_strerror(int errnum, char *buf, size_t buflen);
36
+ #endif
37
+
38
+
39
+ /*
40
+ * A slightly cleaned-up version of strerror()
41
+ */
42
+
43
+
44
+ /*
45
+ * A slightly cleaned-up version of strerror_r()
46
+ */
47
+ char *
48
+ pg_strerror_r(int errnum, char *buf, size_t buflen)
49
+ {
50
+ char *str;
51
+
52
+ /* If it's a Windows Winsock error, that needs special handling */
53
+ #ifdef WIN32
54
+ /* Winsock error code range, per WinError.h */
55
+ if (errnum >= 10000 && errnum <= 11999)
56
+ return win32_socket_strerror(errnum, buf, buflen);
57
+ #endif
58
+
59
+ /* Try the platform's strerror_r(), or maybe just strerror() */
60
+ str = gnuish_strerror_r(errnum, buf, buflen);
61
+
62
+ /*
63
+ * Some strerror()s return an empty string for out-of-range errno. This
64
+ * is ANSI C spec compliant, but not exactly useful. Also, we may get
65
+ * back strings of question marks if libc cannot transcode the message to
66
+ * the codeset specified by LC_CTYPE. If we get nothing useful, first try
67
+ * get_errno_symbol(), and if that fails, print the numeric errno.
68
+ */
69
+ if (str == NULL || *str == '\0' || *str == '?')
70
+ str = get_errno_symbol(errnum);
71
+
72
+ if (str == NULL)
73
+ {
74
+ snprintf(buf, buflen, _("operating system error %d"), errnum);
75
+ str = buf;
76
+ }
77
+
78
+ return str;
79
+ }
80
+
81
+ /*
82
+ * Simple wrapper to emulate GNU strerror_r if what the platform provides is
83
+ * POSIX. Also, if platform lacks strerror_r altogether, fall back to plain
84
+ * strerror; it might not be very thread-safe, but tough luck.
85
+ */
86
+ static char *
87
+ gnuish_strerror_r(int errnum, char *buf, size_t buflen)
88
+ {
89
+ #ifdef HAVE_STRERROR_R
90
+ #ifdef STRERROR_R_INT
91
+ /* POSIX API */
92
+ if (strerror_r(errnum, buf, buflen) == 0)
93
+ return buf;
94
+ return NULL; /* let caller deal with failure */
95
+ #else
96
+ /* GNU API */
97
+ return strerror_r(errnum, buf, buflen);
98
+ #endif
99
+ #else /* !HAVE_STRERROR_R */
100
+ char *sbuf = strerror(errnum);
101
+
102
+ if (sbuf == NULL) /* can this still happen anywhere? */
103
+ return NULL;
104
+ /* To minimize thread-unsafety hazard, copy into caller's buffer */
105
+ strlcpy(buf, sbuf, buflen);
106
+ return buf;
107
+ #endif
108
+ }
109
+
110
+ /*
111
+ * Returns a symbol (e.g. "ENOENT") for an errno code.
112
+ * Returns NULL if the code is unrecognized.
113
+ */
114
+ static char *
115
+ get_errno_symbol(int errnum)
116
+ {
117
+ switch (errnum)
118
+ {
119
+ case E2BIG:
120
+ return "E2BIG";
121
+ case EACCES:
122
+ return "EACCES";
123
+ #ifdef EADDRINUSE
124
+ case EADDRINUSE:
125
+ return "EADDRINUSE";
126
+ #endif
127
+ #ifdef EADDRNOTAVAIL
128
+ case EADDRNOTAVAIL:
129
+ return "EADDRNOTAVAIL";
130
+ #endif
131
+ case EAFNOSUPPORT:
132
+ return "EAFNOSUPPORT";
133
+ #ifdef EAGAIN
134
+ case EAGAIN:
135
+ return "EAGAIN";
136
+ #endif
137
+ #ifdef EALREADY
138
+ case EALREADY:
139
+ return "EALREADY";
140
+ #endif
141
+ case EBADF:
142
+ return "EBADF";
143
+ #ifdef EBADMSG
144
+ case EBADMSG:
145
+ return "EBADMSG";
146
+ #endif
147
+ case EBUSY:
148
+ return "EBUSY";
149
+ case ECHILD:
150
+ return "ECHILD";
151
+ #ifdef ECONNABORTED
152
+ case ECONNABORTED:
153
+ return "ECONNABORTED";
154
+ #endif
155
+ case ECONNREFUSED:
156
+ return "ECONNREFUSED";
157
+ #ifdef ECONNRESET
158
+ case ECONNRESET:
159
+ return "ECONNRESET";
160
+ #endif
161
+ case EDEADLK:
162
+ return "EDEADLK";
163
+ case EDOM:
164
+ return "EDOM";
165
+ case EEXIST:
166
+ return "EEXIST";
167
+ case EFAULT:
168
+ return "EFAULT";
169
+ case EFBIG:
170
+ return "EFBIG";
171
+ #ifdef EHOSTUNREACH
172
+ case EHOSTUNREACH:
173
+ return "EHOSTUNREACH";
174
+ #endif
175
+ case EIDRM:
176
+ return "EIDRM";
177
+ case EINPROGRESS:
178
+ return "EINPROGRESS";
179
+ case EINTR:
180
+ return "EINTR";
181
+ case EINVAL:
182
+ return "EINVAL";
183
+ case EIO:
184
+ return "EIO";
185
+ #ifdef EISCONN
186
+ case EISCONN:
187
+ return "EISCONN";
188
+ #endif
189
+ case EISDIR:
190
+ return "EISDIR";
191
+ #ifdef ELOOP
192
+ case ELOOP:
193
+ return "ELOOP";
194
+ #endif
195
+ case EMFILE:
196
+ return "EMFILE";
197
+ case EMLINK:
198
+ return "EMLINK";
199
+ case EMSGSIZE:
200
+ return "EMSGSIZE";
201
+ case ENAMETOOLONG:
202
+ return "ENAMETOOLONG";
203
+ case ENFILE:
204
+ return "ENFILE";
205
+ case ENOBUFS:
206
+ return "ENOBUFS";
207
+ case ENODEV:
208
+ return "ENODEV";
209
+ case ENOENT:
210
+ return "ENOENT";
211
+ case ENOEXEC:
212
+ return "ENOEXEC";
213
+ case ENOMEM:
214
+ return "ENOMEM";
215
+ case ENOSPC:
216
+ return "ENOSPC";
217
+ case ENOSYS:
218
+ return "ENOSYS";
219
+ #ifdef ENOTCONN
220
+ case ENOTCONN:
221
+ return "ENOTCONN";
222
+ #endif
223
+ case ENOTDIR:
224
+ return "ENOTDIR";
225
+ #if defined(ENOTEMPTY) && (ENOTEMPTY != EEXIST) /* same code on AIX */
226
+ case ENOTEMPTY:
227
+ return "ENOTEMPTY";
228
+ #endif
229
+ #ifdef ENOTSOCK
230
+ case ENOTSOCK:
231
+ return "ENOTSOCK";
232
+ #endif
233
+ #ifdef ENOTSUP
234
+ case ENOTSUP:
235
+ return "ENOTSUP";
236
+ #endif
237
+ case ENOTTY:
238
+ return "ENOTTY";
239
+ case ENXIO:
240
+ return "ENXIO";
241
+ #if defined(EOPNOTSUPP) && (!defined(ENOTSUP) || (EOPNOTSUPP != ENOTSUP))
242
+ case EOPNOTSUPP:
243
+ return "EOPNOTSUPP";
244
+ #endif
245
+ #ifdef EOVERFLOW
246
+ case EOVERFLOW:
247
+ return "EOVERFLOW";
248
+ #endif
249
+ case EPERM:
250
+ return "EPERM";
251
+ case EPIPE:
252
+ return "EPIPE";
253
+ case EPROTONOSUPPORT:
254
+ return "EPROTONOSUPPORT";
255
+ case ERANGE:
256
+ return "ERANGE";
257
+ #ifdef EROFS
258
+ case EROFS:
259
+ return "EROFS";
260
+ #endif
261
+ case ESRCH:
262
+ return "ESRCH";
263
+ #ifdef ETIMEDOUT
264
+ case ETIMEDOUT:
265
+ return "ETIMEDOUT";
266
+ #endif
267
+ #ifdef ETXTBSY
268
+ case ETXTBSY:
269
+ return "ETXTBSY";
270
+ #endif
271
+ #if defined(EWOULDBLOCK) && (!defined(EAGAIN) || (EWOULDBLOCK != EAGAIN))
272
+ case EWOULDBLOCK:
273
+ return "EWOULDBLOCK";
274
+ #endif
275
+ case EXDEV:
276
+ return "EXDEV";
277
+ }
278
+
279
+ return NULL;
280
+ }
281
+
282
+
283
+ #ifdef WIN32
284
+
285
+ /*
286
+ * Windows' strerror() doesn't know the Winsock codes, so handle them this way
287
+ */
288
+ static char *
289
+ win32_socket_strerror(int errnum, char *buf, size_t buflen)
290
+ {
291
+ static HANDLE handleDLL = INVALID_HANDLE_VALUE;
292
+
293
+ if (handleDLL == INVALID_HANDLE_VALUE)
294
+ {
295
+ handleDLL = LoadLibraryEx("netmsg.dll", NULL,
296
+ DONT_RESOLVE_DLL_REFERENCES | LOAD_LIBRARY_AS_DATAFILE);
297
+ if (handleDLL == NULL)
298
+ {
299
+ snprintf(buf, buflen,
300
+ "winsock error %d (could not load netmsg.dll to translate: error code %lu)",
301
+ errnum, GetLastError());
302
+ return buf;
303
+ }
304
+ }
305
+
306
+ ZeroMemory(buf, buflen);
307
+ if (FormatMessage(FORMAT_MESSAGE_IGNORE_INSERTS |
308
+ FORMAT_MESSAGE_FROM_SYSTEM |
309
+ FORMAT_MESSAGE_FROM_HMODULE,
310
+ handleDLL,
311
+ errnum,
312
+ MAKELANGID(LANG_ENGLISH, SUBLANG_DEFAULT),
313
+ buf,
314
+ buflen - 1,
315
+ NULL) == 0)
316
+ {
317
+ /* Failed to get id */
318
+ snprintf(buf, buflen, "unrecognized winsock error %d", errnum);
319
+ }
320
+
321
+ return buf;
322
+ }
323
+
324
+ #endif /* WIN32 */
@@ -0,0 +1,39 @@
1
+ /*--------------------------------------------------------------------
2
+ * Symbols referenced in this file:
3
+ * - strnlen
4
+ *--------------------------------------------------------------------
5
+ */
6
+
7
+ /*-------------------------------------------------------------------------
8
+ *
9
+ * strnlen.c
10
+ * Fallback implementation of strnlen().
11
+ *
12
+ *
13
+ * Portions Copyright (c) 1996-2020, PostgreSQL Global Development Group
14
+ * Portions Copyright (c) 1994, Regents of the University of California
15
+ *
16
+ * IDENTIFICATION
17
+ * src/port/strnlen.c
18
+ *
19
+ *-------------------------------------------------------------------------
20
+ */
21
+
22
+ #include "c.h"
23
+
24
+ /*
25
+ * Implementation of posix' strnlen for systems where it's not available.
26
+ *
27
+ * Returns the number of characters before a null-byte in the string pointed
28
+ * to by str, unless there's no null-byte before maxlen. In the latter case
29
+ * maxlen is returned.
30
+ */
31
+ size_t
32
+ strnlen(const char *str, size_t maxlen)
33
+ {
34
+ const char *p = str;
35
+
36
+ while (maxlen-- > 0 && *p)
37
+ p++;
38
+ return p - str;
39
+ }
@@ -0,0 +1,43 @@
1
+ /*
2
+ * xxHash - Extremely Fast Hash algorithm
3
+ * Copyright (C) 2012-2020 Yann Collet
4
+ *
5
+ * BSD 2-Clause License (https://www.opensource.org/licenses/bsd-license.php)
6
+ *
7
+ * Redistribution and use in source and binary forms, with or without
8
+ * modification, are permitted provided that the following conditions are
9
+ * met:
10
+ *
11
+ * * Redistributions of source code must retain the above copyright
12
+ * notice, this list of conditions and the following disclaimer.
13
+ * * Redistributions in binary form must reproduce the above
14
+ * copyright notice, this list of conditions and the following disclaimer
15
+ * in the documentation and/or other materials provided with the
16
+ * distribution.
17
+ *
18
+ * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19
+ * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20
+ * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
21
+ * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
22
+ * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23
+ * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24
+ * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25
+ * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26
+ * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27
+ * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28
+ * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29
+ *
30
+ * You can contact the author at:
31
+ * - xxHash homepage: https://www.xxhash.com
32
+ * - xxHash source repository: https://github.com/Cyan4973/xxHash
33
+ */
34
+
35
+
36
+ /*
37
+ * xxhash.c instantiates functions defined in xxhash.h
38
+ */
39
+
40
+ #define XXH_STATIC_LINKING_ONLY /* access advanced declarations */
41
+ #define XXH_IMPLEMENTATION /* access definitions */
42
+
43
+ #include "xxhash.h"
data/lib/pg_query.rb CHANGED
@@ -1,16 +1,19 @@
1
1
  require 'pg_query/version'
2
2
  require 'pg_query/parse_error'
3
3
 
4
+ require 'pg_query/pg_query_pb'
5
+ require 'pg_query/node'
6
+
4
7
  require 'pg_query/pg_query'
8
+ require 'pg_query/constants'
5
9
  require 'pg_query/parse'
6
10
  require 'pg_query/treewalker'
7
- require 'pg_query/node_types'
8
- require 'pg_query/deep_dup'
9
-
10
- require 'pg_query/legacy_parsetree'
11
11
 
12
12
  require 'pg_query/filter_columns'
13
+ require 'pg_query/json_field_names'
13
14
  require 'pg_query/fingerprint'
14
15
  require 'pg_query/param_refs'
15
16
  require 'pg_query/deparse'
16
17
  require 'pg_query/truncate'
18
+
19
+ require 'pg_query/scan'
@@ -0,0 +1,21 @@
1
+ module PgQuery
2
+ # From Postgres source: src/include/storage/lockdefs.h
3
+ LOCK_MODE_NO_LOCK = 0 # NoLock is not a lock mode, but a flag value meaning "don't get a lock"
4
+ LOCK_MODE_ACCESS_SHARE_LOCK = 1 # SELECT
5
+ LOCK_MODE_ROW_SHARE_LOCK = 2 # SELECT FOR UPDATE/FOR SHARE
6
+ LOCK_MODE_ROW_EXCLUSIVE_LOCK = 3 # INSERT, UPDATE, DELETE
7
+ LOCK_MODE_SHARE_UPDATE_EXCLUSIVE_LOCK = 4 # VACUUM (non-FULL),ANALYZE, CREATE INDEX CONCURRENTLY
8
+ LOCK_MODE_SHARE_LOCK = 5 # CREATE INDEX (WITHOUT CONCURRENTLY)
9
+ LOCK_MODE_SHARE_ROW_EXCLUSIVE_LOCK = 6 # like EXCLUSIVE MODE, but allows ROW SHARE
10
+ LOCK_MODE_EXCLUSIVE_LOCK = 7 # blocks ROW SHARE/SELECT...FOR UPDATE
11
+ LOCK_MODE_ACCESS_EXCLUSIVE_LOCK = 8 # ALTER TABLE, DROP TABLE, VACUUM FULL, and unqualified LOCK TABLE
12
+
13
+ # From Postgres source: src/include/catalog/pg_trigger.h
14
+ TRIGGER_TYPE_ROW = (1 << 0)
15
+ TRIGGER_TYPE_BEFORE = (1 << 1)
16
+ TRIGGER_TYPE_INSERT = (1 << 2)
17
+ TRIGGER_TYPE_DELETE = (1 << 3)
18
+ TRIGGER_TYPE_UPDATE = (1 << 4)
19
+ TRIGGER_TYPE_TRUNCATE = (1 << 5)
20
+ TRIGGER_TYPE_INSTEAD = (1 << 6)
21
+ end