blob: c40e3f5b77d6e4fb4ef885a05e2d70810ae83c21 [file] [log] [blame]
drh9ccd8652013-09-13 16:36:46 +00001#!/usr/bin/tclsh
2#
3# Run this script to generate the pragma name lookup table C code.
4#
5# To add new pragmas, first add the name and other relevant attributes
6# of the pragma to the "pragma_def" object below. Then run this script
drh67e65e52015-02-02 21:34:54 +00007# to generate the ../src/pragma.h header file that contains macros and
8# the lookup table needed for pragma name lookup in the pragma.c module.
drh9ccd8652013-09-13 16:36:46 +00009# Then add the extra "case PragTyp_XXXXX:" and subsequent code for the
drh67e65e52015-02-02 21:34:54 +000010# new pragma in ../src/pragma.c.
drh9ccd8652013-09-13 16:36:46 +000011#
12
drhc232aca2016-12-15 16:01:17 +000013# Flag meanings:
14set flagMeaning(NeedSchema) {Force schema load before running}
15set flagMeaning(ReadOnly) {Read-only HEADER_VALUE}
16set flagMeaning(Result0) {Acts as query when no argument}
17set flagMeaning(Result1) {Acts as query when has one argument}
18set flagMeaning(SchemaReq) {Schema required - "main" is default}
19set flagMeaning(SchemaOpt) {Schema restricts name search if present}
20set flagMeaning(NoColumns) {OP_ResultRow called with zero columns}
dan9e1ab1a2017-01-05 19:32:48 +000021set flagMeaning(NoColumns1) {zero columns if RHS argument is present}
drhc232aca2016-12-15 16:01:17 +000022
drh9ccd8652013-09-13 16:36:46 +000023set pragma_def {
24 NAME: full_column_names
25 TYPE: FLAG
26 ARG: SQLITE_FullColNames
mistachkindd197832013-10-21 23:17:23 +000027 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +000028
29 NAME: short_column_names
30 TYPE: FLAG
31 ARG: SQLITE_ShortColNames
mistachkindd197832013-10-21 23:17:23 +000032 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +000033
34 NAME: count_changes
35 TYPE: FLAG
36 ARG: SQLITE_CountRows
mistachkindd197832013-10-21 23:17:23 +000037 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +000038
39 NAME: empty_result_callbacks
40 TYPE: FLAG
41 ARG: SQLITE_NullCallback
mistachkindd197832013-10-21 23:17:23 +000042 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +000043
44 NAME: legacy_file_format
45 TYPE: FLAG
46 ARG: SQLITE_LegacyFileFmt
mistachkindd197832013-10-21 23:17:23 +000047 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +000048
49 NAME: fullfsync
50 TYPE: FLAG
51 ARG: SQLITE_FullFSync
mistachkindd197832013-10-21 23:17:23 +000052 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +000053
54 NAME: checkpoint_fullfsync
55 TYPE: FLAG
56 ARG: SQLITE_CkptFullFSync
mistachkindd197832013-10-21 23:17:23 +000057 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +000058
59 NAME: cache_spill
dan9e1ab1a2017-01-05 19:32:48 +000060 FLAG: Result0 SchemaReq NoColumns1
mistachkindd197832013-10-21 23:17:23 +000061 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +000062
63 NAME: reverse_unordered_selects
64 TYPE: FLAG
65 ARG: SQLITE_ReverseOrder
mistachkindd197832013-10-21 23:17:23 +000066 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +000067
68 NAME: query_only
69 TYPE: FLAG
70 ARG: SQLITE_QueryOnly
mistachkindd197832013-10-21 23:17:23 +000071 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +000072
73 NAME: automatic_index
74 TYPE: FLAG
75 ARG: SQLITE_AutoIndex
mistachkindd197832013-10-21 23:17:23 +000076 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +000077 IF: !defined(SQLITE_OMIT_AUTOMATIC_INDEX)
78
79 NAME: sql_trace
80 TYPE: FLAG
81 ARG: SQLITE_SqlTrace
mistachkindd197832013-10-21 23:17:23 +000082 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +000083 IF: defined(SQLITE_DEBUG)
84
85 NAME: vdbe_listing
86 TYPE: FLAG
87 ARG: SQLITE_VdbeListing
mistachkindd197832013-10-21 23:17:23 +000088 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +000089 IF: defined(SQLITE_DEBUG)
90
91 NAME: vdbe_trace
92 TYPE: FLAG
93 ARG: SQLITE_VdbeTrace
mistachkindd197832013-10-21 23:17:23 +000094 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +000095 IF: defined(SQLITE_DEBUG)
96
97 NAME: vdbe_addoptrace
98 TYPE: FLAG
99 ARG: SQLITE_VdbeAddopTrace
mistachkindd197832013-10-21 23:17:23 +0000100 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +0000101 IF: defined(SQLITE_DEBUG)
102
103 NAME: vdbe_debug
104 TYPE: FLAG
105 ARG: SQLITE_SqlTrace|SQLITE_VdbeListing|SQLITE_VdbeTrace
mistachkindd197832013-10-21 23:17:23 +0000106 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +0000107 IF: defined(SQLITE_DEBUG)
108
drh84e55a82013-11-13 17:58:23 +0000109 NAME: vdbe_eqp
110 TYPE: FLAG
111 ARG: SQLITE_VdbeEQP
112 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
113 IF: defined(SQLITE_DEBUG)
114
drh9ccd8652013-09-13 16:36:46 +0000115 NAME: ignore_check_constraints
116 TYPE: FLAG
117 ARG: SQLITE_IgnoreChecks
mistachkindd197832013-10-21 23:17:23 +0000118 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +0000119 IF: !defined(SQLITE_OMIT_CHECK)
120
121 NAME: writable_schema
122 TYPE: FLAG
drh169dd922017-06-26 13:57:49 +0000123 ARG: SQLITE_WriteSchema
mistachkindd197832013-10-21 23:17:23 +0000124 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +0000125
126 NAME: read_uncommitted
127 TYPE: FLAG
drh169dd922017-06-26 13:57:49 +0000128 ARG: SQLITE_ReadUncommit
mistachkindd197832013-10-21 23:17:23 +0000129 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +0000130
131 NAME: recursive_triggers
132 TYPE: FLAG
133 ARG: SQLITE_RecTriggers
mistachkindd197832013-10-21 23:17:23 +0000134 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +0000135
136 NAME: foreign_keys
137 TYPE: FLAG
138 ARG: SQLITE_ForeignKeys
mistachkindd197832013-10-21 23:17:23 +0000139 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +0000140 IF: !defined(SQLITE_OMIT_FOREIGN_KEY) && !defined(SQLITE_OMIT_TRIGGER)
141
142 NAME: defer_foreign_keys
143 TYPE: FLAG
144 ARG: SQLITE_DeferFKs
mistachkindd197832013-10-21 23:17:23 +0000145 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +0000146 IF: !defined(SQLITE_OMIT_FOREIGN_KEY) && !defined(SQLITE_OMIT_TRIGGER)
147
drh1421d982015-05-27 03:46:18 +0000148 NAME: cell_size_check
149 TYPE: FLAG
150 ARG: SQLITE_CellSizeCk
151
drh9ccd8652013-09-13 16:36:46 +0000152 NAME: default_cache_size
dan9e1ab1a2017-01-05 19:32:48 +0000153 FLAG: NeedSchema Result0 SchemaReq NoColumns1
drhc232aca2016-12-15 16:01:17 +0000154 COLS: cache_size
drh9ccd8652013-09-13 16:36:46 +0000155 IF: !defined(SQLITE_OMIT_PAGER_PRAGMAS) && !defined(SQLITE_OMIT_DEPRECATED)
156
157 NAME: page_size
dan9e1ab1a2017-01-05 19:32:48 +0000158 FLAG: Result0 SchemaReq NoColumns1
drh9ccd8652013-09-13 16:36:46 +0000159 IF: !defined(SQLITE_OMIT_PAGER_PRAGMAS)
160
161 NAME: secure_delete
drhc232aca2016-12-15 16:01:17 +0000162 FLAG: Result0
drh9ccd8652013-09-13 16:36:46 +0000163 IF: !defined(SQLITE_OMIT_PAGER_PRAGMAS)
164
165 NAME: page_count
drhc232aca2016-12-15 16:01:17 +0000166 FLAG: NeedSchema Result0 SchemaReq
drh9ccd8652013-09-13 16:36:46 +0000167 IF: !defined(SQLITE_OMIT_PAGER_PRAGMAS)
168
169 NAME: max_page_count
170 TYPE: PAGE_COUNT
drhc232aca2016-12-15 16:01:17 +0000171 FLAG: NeedSchema Result0 SchemaReq
drh9ccd8652013-09-13 16:36:46 +0000172 IF: !defined(SQLITE_OMIT_PAGER_PRAGMAS)
173
174 NAME: locking_mode
drhc232aca2016-12-15 16:01:17 +0000175 FLAG: Result0 SchemaReq
drh9ccd8652013-09-13 16:36:46 +0000176 IF: !defined(SQLITE_OMIT_PAGER_PRAGMAS)
177
178 NAME: journal_mode
drhc232aca2016-12-15 16:01:17 +0000179 FLAG: NeedSchema Result0 SchemaReq
drh9ccd8652013-09-13 16:36:46 +0000180 IF: !defined(SQLITE_OMIT_PAGER_PRAGMAS)
181
182 NAME: journal_size_limit
drhc232aca2016-12-15 16:01:17 +0000183 FLAG: Result0 SchemaReq
drh9ccd8652013-09-13 16:36:46 +0000184 IF: !defined(SQLITE_OMIT_PAGER_PRAGMAS)
185
186 NAME: cache_size
dan9e1ab1a2017-01-05 19:32:48 +0000187 FLAG: NeedSchema Result0 SchemaReq NoColumns1
drh9ccd8652013-09-13 16:36:46 +0000188 IF: !defined(SQLITE_OMIT_PAGER_PRAGMAS)
189
190 NAME: mmap_size
191 IF: !defined(SQLITE_OMIT_PAGER_PRAGMAS)
192
193 NAME: auto_vacuum
dan9e1ab1a2017-01-05 19:32:48 +0000194 FLAG: NeedSchema Result0 SchemaReq NoColumns1
drh9ccd8652013-09-13 16:36:46 +0000195 IF: !defined(SQLITE_OMIT_AUTOVACUUM)
196
197 NAME: incremental_vacuum
drhc232aca2016-12-15 16:01:17 +0000198 FLAG: NeedSchema NoColumns
drh9ccd8652013-09-13 16:36:46 +0000199 IF: !defined(SQLITE_OMIT_AUTOVACUUM)
200
201 NAME: temp_store
dan9e1ab1a2017-01-05 19:32:48 +0000202 FLAG: Result0 NoColumns1
drh9ccd8652013-09-13 16:36:46 +0000203 IF: !defined(SQLITE_OMIT_PAGER_PRAGMAS)
204
205 NAME: temp_store_directory
dan9e1ab1a2017-01-05 19:32:48 +0000206 FLAG: NoColumns1
drh9ccd8652013-09-13 16:36:46 +0000207 IF: !defined(SQLITE_OMIT_PAGER_PRAGMAS)
208
209 NAME: data_store_directory
dan9e1ab1a2017-01-05 19:32:48 +0000210 FLAG: NoColumns1
drh9ccd8652013-09-13 16:36:46 +0000211 IF: !defined(SQLITE_OMIT_PAGER_PRAGMAS) && SQLITE_OS_WIN
212
213 NAME: lock_proxy_file
dan9e1ab1a2017-01-05 19:32:48 +0000214 FLAG: NoColumns1
drh9ccd8652013-09-13 16:36:46 +0000215 IF: !defined(SQLITE_OMIT_PAGER_PRAGMAS) && SQLITE_ENABLE_LOCKING_STYLE
216
217 NAME: synchronous
dan9e1ab1a2017-01-05 19:32:48 +0000218 FLAG: NeedSchema Result0 SchemaReq NoColumns1
drh9ccd8652013-09-13 16:36:46 +0000219 IF: !defined(SQLITE_OMIT_PAGER_PRAGMAS)
220
221 NAME: table_info
drhc232aca2016-12-15 16:01:17 +0000222 FLAG: NeedSchema Result1 SchemaOpt
drh15fc9882018-09-29 19:38:42 +0000223 ARG: 0
224 COLS: cid name type notnull dflt_value pk
225 IF: !defined(SQLITE_OMIT_SCHEMA_PRAGMAS)
226
drhbdc97442018-10-01 21:26:30 +0000227 NAME: table_xinfo
drh15fc9882018-09-29 19:38:42 +0000228 TYPE: TABLE_INFO
229 FLAG: NeedSchema Result1 SchemaOpt
230 ARG: 1
drhd7dc0a32018-10-01 18:28:42 +0000231 COLS: cid name type notnull dflt_value pk hidden
drh9ccd8652013-09-13 16:36:46 +0000232 IF: !defined(SQLITE_OMIT_SCHEMA_PRAGMAS)
233
drh3ef26152013-10-12 20:22:00 +0000234 NAME: stats
drhc232aca2016-12-15 16:01:17 +0000235 FLAG: NeedSchema Result0 SchemaReq
drha3928dd2017-02-17 15:26:36 +0000236 COLS: tbl idx wdth hght flgs
drh33bec3f2017-02-17 13:38:15 +0000237 IF: !defined(SQLITE_OMIT_SCHEMA_PRAGMAS) && defined(SQLITE_DEBUG)
drh3ef26152013-10-12 20:22:00 +0000238
drh9ccd8652013-09-13 16:36:46 +0000239 NAME: index_info
drhc228be52015-01-31 02:00:01 +0000240 TYPE: INDEX_INFO
241 ARG: 0
drhc232aca2016-12-15 16:01:17 +0000242 FLAG: NeedSchema Result1 SchemaOpt
243 COLS: seqno cid name
drhc228be52015-01-31 02:00:01 +0000244 IF: !defined(SQLITE_OMIT_SCHEMA_PRAGMAS)
245
246 NAME: index_xinfo
247 TYPE: INDEX_INFO
248 ARG: 1
drhc232aca2016-12-15 16:01:17 +0000249 FLAG: NeedSchema Result1 SchemaOpt
250 COLS: seqno cid name desc coll key
drh9ccd8652013-09-13 16:36:46 +0000251 IF: !defined(SQLITE_OMIT_SCHEMA_PRAGMAS)
252
253 NAME: index_list
drhc232aca2016-12-15 16:01:17 +0000254 FLAG: NeedSchema Result1 SchemaOpt
255 COLS: seq name unique origin partial
drh9ccd8652013-09-13 16:36:46 +0000256 IF: !defined(SQLITE_OMIT_SCHEMA_PRAGMAS)
257
258 NAME: database_list
drhc232aca2016-12-15 16:01:17 +0000259 FLAG: NeedSchema Result0
260 COLS: seq name file
drh9ccd8652013-09-13 16:36:46 +0000261 IF: !defined(SQLITE_OMIT_SCHEMA_PRAGMAS)
262
drhab53bb62017-07-07 15:43:22 +0000263 NAME: function_list
264 FLAG: Result0
265 COLS: name builtin
266 IF: !defined(SQLITE_OMIT_SCHEMA_PRAGMAS)
drh8ae11aa2017-07-07 17:33:07 +0000267 IF: defined(SQLITE_INTROSPECTION_PRAGMAS)
drhab53bb62017-07-07 15:43:22 +0000268
269 NAME: module_list
270 FLAG: Result0
271 COLS: name
272 IF: !defined(SQLITE_OMIT_SCHEMA_PRAGMAS)
273 IF: !defined(SQLITE_OMIT_VIRTUALTABLE)
drh8ae11aa2017-07-07 17:33:07 +0000274 IF: defined(SQLITE_INTROSPECTION_PRAGMAS)
275
276 NAME: pragma_list
277 FLAG: Result0
278 COLS: name
279 IF: defined(SQLITE_INTROSPECTION_PRAGMAS)
drhab53bb62017-07-07 15:43:22 +0000280
drh9ccd8652013-09-13 16:36:46 +0000281 NAME: collation_list
drhc232aca2016-12-15 16:01:17 +0000282 FLAG: Result0
283 COLS: seq name
drh9ccd8652013-09-13 16:36:46 +0000284 IF: !defined(SQLITE_OMIT_SCHEMA_PRAGMAS)
285
286 NAME: foreign_key_list
drhc232aca2016-12-15 16:01:17 +0000287 FLAG: NeedSchema Result1 SchemaOpt
288 COLS: id seq table from to on_update on_delete match
drh9ccd8652013-09-13 16:36:46 +0000289 IF: !defined(SQLITE_OMIT_FOREIGN_KEY)
290
291 NAME: foreign_key_check
drhc45fdb22017-06-21 01:36:30 +0000292 FLAG: NeedSchema Result0
drhc232aca2016-12-15 16:01:17 +0000293 COLS: table rowid parent fkid
drh9ccd8652013-09-13 16:36:46 +0000294 IF: !defined(SQLITE_OMIT_FOREIGN_KEY) && !defined(SQLITE_OMIT_TRIGGER)
295
296 NAME: parser_trace
drh35926802015-12-15 13:50:22 +0000297 IF: defined(SQLITE_DEBUG) && !defined(SQLITE_OMIT_PARSER_TRACE)
drh9ccd8652013-09-13 16:36:46 +0000298
299 NAME: case_sensitive_like
dane1ff3f52017-01-06 13:49:40 +0000300 FLAG: NoColumns
drh9ccd8652013-09-13 16:36:46 +0000301
302 NAME: integrity_check
drhc45fdb22017-06-21 01:36:30 +0000303 FLAG: NeedSchema Result0 Result1
drh9ccd8652013-09-13 16:36:46 +0000304 IF: !defined(SQLITE_OMIT_INTEGRITY_CHECK)
305
306 NAME: quick_check
307 TYPE: INTEGRITY_CHECK
drhc45fdb22017-06-21 01:36:30 +0000308 FLAG: NeedSchema Result0 Result1
drh9ccd8652013-09-13 16:36:46 +0000309 IF: !defined(SQLITE_OMIT_INTEGRITY_CHECK)
310
311 NAME: encoding
dan9e1ab1a2017-01-05 19:32:48 +0000312 FLAG: Result0 NoColumns1
drh9ccd8652013-09-13 16:36:46 +0000313 IF: !defined(SQLITE_OMIT_UTF16)
314
315 NAME: schema_version
316 TYPE: HEADER_VALUE
drh8e755e72014-12-19 18:49:55 +0000317 ARG: BTREE_SCHEMA_VERSION
dan9e1ab1a2017-01-05 19:32:48 +0000318 FLAG: NoColumns1 Result0
drh9ccd8652013-09-13 16:36:46 +0000319 IF: !defined(SQLITE_OMIT_SCHEMA_VERSION_PRAGMAS)
320
321 NAME: user_version
322 TYPE: HEADER_VALUE
drh8e755e72014-12-19 18:49:55 +0000323 ARG: BTREE_USER_VERSION
dan9e1ab1a2017-01-05 19:32:48 +0000324 FLAG: NoColumns1 Result0
drh9ccd8652013-09-13 16:36:46 +0000325 IF: !defined(SQLITE_OMIT_SCHEMA_VERSION_PRAGMAS)
326
drh91618562014-12-19 19:28:02 +0000327 NAME: data_version
328 TYPE: HEADER_VALUE
329 ARG: BTREE_DATA_VERSION
dan9e1ab1a2017-01-05 19:32:48 +0000330 FLAG: ReadOnly Result0
drh91618562014-12-19 19:28:02 +0000331 IF: !defined(SQLITE_OMIT_SCHEMA_VERSION_PRAGMAS)
332
drh9ccd8652013-09-13 16:36:46 +0000333 NAME: freelist_count
334 TYPE: HEADER_VALUE
drh8e755e72014-12-19 18:49:55 +0000335 ARG: BTREE_FREE_PAGE_COUNT
dan9e1ab1a2017-01-05 19:32:48 +0000336 FLAG: ReadOnly Result0
drh9ccd8652013-09-13 16:36:46 +0000337 IF: !defined(SQLITE_OMIT_SCHEMA_VERSION_PRAGMAS)
338
339 NAME: application_id
340 TYPE: HEADER_VALUE
drh8e755e72014-12-19 18:49:55 +0000341 ARG: BTREE_APPLICATION_ID
dan9e1ab1a2017-01-05 19:32:48 +0000342 FLAG: NoColumns1 Result0
drh9ccd8652013-09-13 16:36:46 +0000343 IF: !defined(SQLITE_OMIT_SCHEMA_VERSION_PRAGMAS)
344
345 NAME: compile_options
drhc232aca2016-12-15 16:01:17 +0000346 FLAG: Result0
drh9ccd8652013-09-13 16:36:46 +0000347 IF: !defined(SQLITE_OMIT_COMPILEOPTION_DIAGS)
348
349 NAME: wal_checkpoint
drhf63936e2013-10-03 14:08:07 +0000350 FLAG: NeedSchema
drhc232aca2016-12-15 16:01:17 +0000351 COLS: busy log checkpointed
drh9ccd8652013-09-13 16:36:46 +0000352 IF: !defined(SQLITE_OMIT_WAL)
353
354 NAME: wal_autocheckpoint
355 IF: !defined(SQLITE_OMIT_WAL)
356
357 NAME: shrink_memory
dane1ff3f52017-01-06 13:49:40 +0000358 FLAG: NoColumns
drh9ccd8652013-09-13 16:36:46 +0000359
360 NAME: busy_timeout
drhc232aca2016-12-15 16:01:17 +0000361 FLAG: Result0
362 COLS: timeout
drh9ccd8652013-09-13 16:36:46 +0000363
364 NAME: lock_status
drhc232aca2016-12-15 16:01:17 +0000365 FLAG: Result0
366 COLS: database status
drh9ccd8652013-09-13 16:36:46 +0000367 IF: defined(SQLITE_DEBUG) || defined(SQLITE_TEST)
368
369 NAME: key
370 IF: defined(SQLITE_HAS_CODEC)
371
372 NAME: rekey
373 IF: defined(SQLITE_HAS_CODEC)
374
375 NAME: hexkey
376 IF: defined(SQLITE_HAS_CODEC)
377
drh8ab88322013-10-07 00:36:01 +0000378 NAME: hexrekey
379 TYPE: HEXKEY
380 IF: defined(SQLITE_HAS_CODEC)
381
drh9ccd8652013-09-13 16:36:46 +0000382 NAME: activate_extensions
383 IF: defined(SQLITE_HAS_CODEC) || defined(SQLITE_ENABLE_CEROD)
drh55e85ca2013-09-13 21:01:56 +0000384
385 NAME: soft_heap_limit
drhc232aca2016-12-15 16:01:17 +0000386 FLAG: Result0
drh03459612014-08-25 15:13:22 +0000387
388 NAME: threads
drhc232aca2016-12-15 16:01:17 +0000389 FLAG: Result0
drh72052a72017-02-17 16:26:34 +0000390
drh2ead47c2017-02-22 20:24:10 +0000391 NAME: optimize
drh761f6912017-04-03 13:33:51 +0000392 FLAG: Result1 NeedSchema
dan674b8942018-09-20 08:28:01 +0000393
394 NAME: legacy_alter_table
395 TYPE: FLAG
396 ARG: SQLITE_LegacyAlter
397 IF: !defined(SQLITE_OMIT_FLAG_PRAGMAS)
drh9ccd8652013-09-13 16:36:46 +0000398}
drh67e65e52015-02-02 21:34:54 +0000399
400# Open the output file
401#
402set destfile "[file dir [file dir [file normal $argv0]]]/src/pragma.h"
403puts "Overwriting $destfile with new pragma table..."
404set fd [open $destfile wb]
405puts $fd {/* DO NOT EDIT!
406** This file is automatically generated by the script at
407** ../tool/mkpragmatab.tcl. To update the set of pragmas, edit
408** that script and rerun it.
409*/}
410
411# Parse the PRAGMA table above.
412#
drh9ccd8652013-09-13 16:36:46 +0000413set name {}
414set type {}
415set if {}
drhf63936e2013-10-03 14:08:07 +0000416set flags {}
drhc232aca2016-12-15 16:01:17 +0000417set cols {}
418set cols_list {}
drh9ccd8652013-09-13 16:36:46 +0000419set arg 0
420proc record_one {} {
drhbdc97442018-10-01 21:26:30 +0000421 global name type if arg allbyname typebyif flags cols all_cols
drhc232aca2016-12-15 16:01:17 +0000422 global cols_list colUsedBy
drh9ccd8652013-09-13 16:36:46 +0000423 if {$name==""} return
drhc232aca2016-12-15 16:01:17 +0000424 if {$cols!=""} {
drhbdc97442018-10-01 21:26:30 +0000425 if {![info exists all_cols($cols)]} {
426 set all_cols($cols) 1
drhc232aca2016-12-15 16:01:17 +0000427 lappend cols_list $cols
drhc232aca2016-12-15 16:01:17 +0000428 }
drhbdc97442018-10-01 21:26:30 +0000429 set cx $cols
drhc232aca2016-12-15 16:01:17 +0000430 lappend colUsedBy($cols) $name
431 } else {
432 set cx 0
433 }
drhbdc97442018-10-01 21:26:30 +0000434 set allbyname($name) [list $type $arg $if $flags $cols]
drh9ccd8652013-09-13 16:36:46 +0000435 set name {}
436 set type {}
437 set if {}
drhf63936e2013-10-03 14:08:07 +0000438 set flags {}
drhc232aca2016-12-15 16:01:17 +0000439 set cols {}
drh9ccd8652013-09-13 16:36:46 +0000440 set arg 0
441}
442foreach line [split $pragma_def \n] {
443 set line [string trim $line]
444 if {$line==""} continue
445 foreach {id val} [split $line :] break
446 set val [string trim $val]
447 if {$id=="NAME"} {
448 record_one
449 set name $val
450 set type [string toupper $val]
451 } elseif {$id=="TYPE"} {
452 set type $val
drhc232aca2016-12-15 16:01:17 +0000453 if {$type=="FLAG"} {
dan9e1ab1a2017-01-05 19:32:48 +0000454 lappend flags Result0 NoColumns1
drhc232aca2016-12-15 16:01:17 +0000455 }
drh9ccd8652013-09-13 16:36:46 +0000456 } elseif {$id=="ARG"} {
457 set arg $val
drhc232aca2016-12-15 16:01:17 +0000458 } elseif {$id=="COLS"} {
459 set cols $val
drh9ccd8652013-09-13 16:36:46 +0000460 } elseif {$id=="IF"} {
mistachkindd197832013-10-21 23:17:23 +0000461 lappend if $val
drhf63936e2013-10-03 14:08:07 +0000462 } elseif {$id=="FLAG"} {
463 foreach term [split $val] {
464 lappend flags $term
465 set allflags($term) 1
466 }
drh9ccd8652013-09-13 16:36:46 +0000467 } else {
468 error "bad pragma_def line: $line"
469 }
470}
471record_one
472set allnames [lsort [array names allbyname]]
473
474# Generate #defines for all pragma type names. Group the pragmas that are
475# omit in default builds (defined(SQLITE_DEBUG) and defined(SQLITE_HAS_CODEC))
476# at the end.
477#
drhc232aca2016-12-15 16:01:17 +0000478puts $fd "\n/* The various pragma types */"
drh9ccd8652013-09-13 16:36:46 +0000479set pnum 0
480foreach name $allnames {
481 set type [lindex $allbyname($name) 0]
482 if {[info exists seentype($type)]} continue
483 set if [lindex $allbyname($name) 2]
484 if {[regexp SQLITE_DEBUG $if] || [regexp SQLITE_HAS_CODEC $if]} continue
485 set seentype($type) 1
drh67e65e52015-02-02 21:34:54 +0000486 puts $fd [format {#define %-35s %4d} PragTyp_$type $pnum]
drh9ccd8652013-09-13 16:36:46 +0000487 incr pnum
488}
489foreach name $allnames {
490 set type [lindex $allbyname($name) 0]
491 if {[info exists seentype($type)]} continue
492 set if [lindex $allbyname($name) 2]
493 if {[regexp SQLITE_DEBUG $if]} continue
494 set seentype($type) 1
drh67e65e52015-02-02 21:34:54 +0000495 puts $fd [format {#define %-35s %4d} PragTyp_$type $pnum]
drh9ccd8652013-09-13 16:36:46 +0000496 incr pnum
497}
498foreach name $allnames {
499 set type [lindex $allbyname($name) 0]
500 if {[info exists seentype($type)]} continue
501 set seentype($type) 1
drh67e65e52015-02-02 21:34:54 +0000502 puts $fd [format {#define %-35s %4d} PragTyp_$type $pnum]
drh9ccd8652013-09-13 16:36:46 +0000503 incr pnum
504}
505
drhf63936e2013-10-03 14:08:07 +0000506# Generate #defines for flags
507#
drhc232aca2016-12-15 16:01:17 +0000508puts $fd "\n/* Property flags associated with various pragma. */"
drhf63936e2013-10-03 14:08:07 +0000509set fv 1
510foreach f [lsort [array names allflags]] {
drhc232aca2016-12-15 16:01:17 +0000511 puts $fd [format {#define PragFlg_%-10s 0x%02x /* %s */} \
512 $f $fv $flagMeaning($f)]
drhf63936e2013-10-03 14:08:07 +0000513 set fv [expr {$fv*2}]
514}
515
drhbdc97442018-10-01 21:26:30 +0000516# Sort the column lists so that longer column lists occur first
517#
518proc colscmp {a b} {
519 return [expr {[llength $b] - [llength $a]}]
520}
521set cols_list [lsort -command colscmp $cols_list]
522
drhc232aca2016-12-15 16:01:17 +0000523# Generate the array of column names used by pragmas that act like
524# queries.
525#
526puts $fd "\n/* Names of columns for pragmas that return multi-column result"
527puts $fd "** or that return single-column results where the name of the"
528puts $fd "** result column is different from the name of the pragma\n*/"
529puts $fd "static const char *const pragCName\[\] = {"
530set offset 0
drhbdc97442018-10-01 21:26:30 +0000531set allcollist {}
drhc232aca2016-12-15 16:01:17 +0000532foreach cols $cols_list {
drhbdc97442018-10-01 21:26:30 +0000533 set n [llength $cols]
534 set limit [expr {[llength $allcollist] - $n}]
535 for {set i 0} {$i<$limit} {incr i} {
536 set sublist [lrange $allcollist $i [expr {$i+$n-1}]]
537 if {$sublist==$cols} {
538 puts $fd [format "%27s/* $colUsedBy($cols) reuses $i */" ""]
539 set cols_offset($cols) $i
540 break
541 }
542 }
543 if {$i<$limit} continue
544 set cols_offset($cols) $offset
drhc232aca2016-12-15 16:01:17 +0000545 set ub " /* Used by: $colUsedBy($cols) */"
546 foreach c $cols {
drhbdc97442018-10-01 21:26:30 +0000547 lappend allcollist $c
drhc232aca2016-12-15 16:01:17 +0000548 puts $fd [format " /* %3d */ %-14s%s" $offset \"$c\", $ub]
549 set ub ""
550 incr offset
551 }
552}
553puts $fd "\175;"
554
drh9ccd8652013-09-13 16:36:46 +0000555# Generate the lookup table
556#
drhc232aca2016-12-15 16:01:17 +0000557puts $fd "\n/* Definitions of all built-in pragmas */"
drh2fcc1592016-12-15 20:59:03 +0000558puts $fd "typedef struct PragmaName \173"
drhc232aca2016-12-15 16:01:17 +0000559puts $fd " const char *const zName; /* Name of pragma */"
560puts $fd " u8 ePragTyp; /* PragTyp_XXX value */"
561puts $fd " u8 mPragFlg; /* Zero or more PragFlg_XXX values */"
562puts $fd { u8 iPragCName; /* Start of column names in pragCName[] */}
563puts $fd " u8 nPragCName; \
564/* Num of col names. 0 means use pragma name */"
565puts $fd " u32 iArg; /* Extra argument */"
drh2fcc1592016-12-15 20:59:03 +0000566puts $fd "\175 PragmaName;"
567puts $fd "static const PragmaName aPragmaName\[\] = \173"
drh9ccd8652013-09-13 16:36:46 +0000568
569set current_if {}
570set spacer [format { %26s } {}]
571foreach name $allnames {
drhc232aca2016-12-15 16:01:17 +0000572 foreach {type arg if flag cx} $allbyname($name) break
drhbdc97442018-10-01 21:26:30 +0000573 if {$cx==0 || $cx==""} {
drhc232aca2016-12-15 16:01:17 +0000574 set cy 0
575 set nx 0
576 } else {
577 set cy $cols_offset($cx)
drhbdc97442018-10-01 21:26:30 +0000578 set nx [llength $cx]
drhc232aca2016-12-15 16:01:17 +0000579 }
drh9ccd8652013-09-13 16:36:46 +0000580 if {$if!=$current_if} {
mistachkindd197832013-10-21 23:17:23 +0000581 if {$current_if!=""} {
582 foreach this_if $current_if {
drh67e65e52015-02-02 21:34:54 +0000583 puts $fd "#endif"
mistachkindd197832013-10-21 23:17:23 +0000584 }
585 }
drh9ccd8652013-09-13 16:36:46 +0000586 set current_if $if
mistachkindd197832013-10-21 23:17:23 +0000587 if {$current_if!=""} {
588 foreach this_if $current_if {
drh67e65e52015-02-02 21:34:54 +0000589 puts $fd "#if $this_if"
mistachkindd197832013-10-21 23:17:23 +0000590 }
591 }
drh9ccd8652013-09-13 16:36:46 +0000592 }
drh9ccd8652013-09-13 16:36:46 +0000593 set typex [format PragTyp_%-23s $type,]
drhf63936e2013-10-03 14:08:07 +0000594 if {$flag==""} {
595 set flagx "0"
drh9ccd8652013-09-13 16:36:46 +0000596 } else {
drhc232aca2016-12-15 16:01:17 +0000597 set flagx PragFlg_[join $flag {|PragFlg_}]
drh9ccd8652013-09-13 16:36:46 +0000598 }
drhc232aca2016-12-15 16:01:17 +0000599 puts $fd " \173/* zName: */ \"$name\","
600 puts $fd " /* ePragTyp: */ PragTyp_$type,"
601 puts $fd " /* ePragFlg: */ $flagx,"
602 puts $fd " /* ColNames: */ $cy, $nx,"
603 puts $fd " /* iArg: */ $arg \175,"
drh9ccd8652013-09-13 16:36:46 +0000604}
mistachkindd197832013-10-21 23:17:23 +0000605if {$current_if!=""} {
606 foreach this_if $current_if {
drh67e65e52015-02-02 21:34:54 +0000607 puts $fd "#endif"
mistachkindd197832013-10-21 23:17:23 +0000608 }
609}
drh67e65e52015-02-02 21:34:54 +0000610puts $fd "\175;"
drh6bb64f62013-09-13 16:56:17 +0000611
612# count the number of pragmas, for information purposes
613#
614set allcnt 0
615set dfltcnt 0
616foreach name $allnames {
617 incr allcnt
618 set if [lindex $allbyname($name) 2]
619 if {[regexp {^defined} $if] || [regexp {[^!]defined} $if]} continue
620 incr dfltcnt
621}
drh67e65e52015-02-02 21:34:54 +0000622puts $fd "/* Number of pragmas: $dfltcnt on by default, $allcnt total. */"