/ Hex Artifact Content
Login

Artifact 2144bc8550a6471a029db262a132d2df4b9e0db61b90398bf64f5b7b3f8d92cd:


0000: 23 21 2f 75 73 72 2f 62 69 6e 2f 74 63 6c 73 68  #!/usr/bin/tclsh
0010: 0a 23 0a 23 20 52 75 6e 20 74 68 69 73 20 73 63  .#.# Run this sc
0020: 72 69 70 74 20 74 6f 20 67 65 6e 65 72 61 74 65  ript to generate
0030: 20 74 68 65 20 70 72 61 67 6d 61 20 6e 61 6d 65   the pragma name
0040: 20 6c 6f 6f 6b 75 70 20 74 61 62 6c 65 20 43 20   lookup table C 
0050: 63 6f 64 65 2e 0a 23 0a 23 20 54 6f 20 61 64 64  code..#.# To add
0060: 20 6e 65 77 20 70 72 61 67 6d 61 73 2c 20 66 69   new pragmas, fi
0070: 72 73 74 20 61 64 64 20 74 68 65 20 6e 61 6d 65  rst add the name
0080: 20 61 6e 64 20 6f 74 68 65 72 20 72 65 6c 65 76   and other relev
0090: 61 6e 74 20 61 74 74 72 69 62 75 74 65 73 0a 23  ant attributes.#
00a0: 20 6f 66 20 74 68 65 20 70 72 61 67 6d 61 20 74   of the pragma t
00b0: 6f 20 74 68 65 20 22 70 72 61 67 6d 61 5f 64 65  o the "pragma_de
00c0: 66 22 20 6f 62 6a 65 63 74 20 62 65 6c 6f 77 2e  f" object below.
00d0: 20 20 54 68 65 6e 20 72 75 6e 20 74 68 69 73 20    Then run this 
00e0: 73 63 72 69 70 74 0a 23 20 74 6f 20 67 65 6e 65  script.# to gene
00f0: 72 61 74 65 20 74 68 65 20 2e 2e 2f 73 72 63 2f  rate the ../src/
0100: 70 72 61 67 6d 61 2e 68 20 68 65 61 64 65 72 20  pragma.h header 
0110: 66 69 6c 65 20 74 68 61 74 20 63 6f 6e 74 61 69  file that contai
0120: 6e 73 20 6d 61 63 72 6f 73 20 61 6e 64 0a 23 20  ns macros and.# 
0130: 74 68 65 20 6c 6f 6f 6b 75 70 20 74 61 62 6c 65  the lookup table
0140: 20 6e 65 65 64 65 64 20 66 6f 72 20 70 72 61 67   needed for prag
0150: 6d 61 20 6e 61 6d 65 20 6c 6f 6f 6b 75 70 20 69  ma name lookup i
0160: 6e 20 74 68 65 20 70 72 61 67 6d 61 2e 63 20 6d  n the pragma.c m
0170: 6f 64 75 6c 65 2e 0a 23 20 54 68 65 6e 20 61 64  odule..# Then ad
0180: 64 20 74 68 65 20 65 78 74 72 61 20 22 63 61 73  d the extra "cas
0190: 65 20 50 72 61 67 54 79 70 5f 58 58 58 58 58 3a  e PragTyp_XXXXX:
01a0: 22 20 61 6e 64 20 73 75 62 73 65 71 75 65 6e 74  " and subsequent
01b0: 20 63 6f 64 65 20 66 6f 72 20 74 68 65 0a 23 20   code for the.# 
01c0: 6e 65 77 20 70 72 61 67 6d 61 20 69 6e 20 2e 2e  new pragma in ..
01d0: 2f 73 72 63 2f 70 72 61 67 6d 61 2e 63 2e 0a 23  /src/pragma.c..#
01e0: 0a 0a 23 20 46 6c 61 67 20 6d 65 61 6e 69 6e 67  ..# Flag meaning
01f0: 73 3a 0a 73 65 74 20 66 6c 61 67 4d 65 61 6e 69  s:.set flagMeani
0200: 6e 67 28 4e 65 65 64 53 63 68 65 6d 61 29 20 7b  ng(NeedSchema) {
0210: 46 6f 72 63 65 20 73 63 68 65 6d 61 20 6c 6f 61  Force schema loa
0220: 64 20 62 65 66 6f 72 65 20 72 75 6e 6e 69 6e 67  d before running
0230: 7d 0a 73 65 74 20 66 6c 61 67 4d 65 61 6e 69 6e  }.set flagMeanin
0240: 67 28 52 65 61 64 4f 6e 6c 79 29 20 20 20 7b 52  g(ReadOnly)   {R
0250: 65 61 64 2d 6f 6e 6c 79 20 48 45 41 44 45 52 5f  ead-only HEADER_
0260: 56 41 4c 55 45 7d 0a 73 65 74 20 66 6c 61 67 4d  VALUE}.set flagM
0270: 65 61 6e 69 6e 67 28 52 65 73 75 6c 74 30 29 20  eaning(Result0) 
0280: 20 20 20 7b 41 63 74 73 20 61 73 20 71 75 65 72     {Acts as quer
0290: 79 20 77 68 65 6e 20 6e 6f 20 61 72 67 75 6d 65  y when no argume
02a0: 6e 74 7d 0a 73 65 74 20 66 6c 61 67 4d 65 61 6e  nt}.set flagMean
02b0: 69 6e 67 28 52 65 73 75 6c 74 31 29 20 20 20 20  ing(Result1)    
02c0: 7b 41 63 74 73 20 61 73 20 71 75 65 72 79 20 77  {Acts as query w
02d0: 68 65 6e 20 68 61 73 20 6f 6e 65 20 61 72 67 75  hen has one argu
02e0: 6d 65 6e 74 7d 0a 73 65 74 20 66 6c 61 67 4d 65  ment}.set flagMe
02f0: 61 6e 69 6e 67 28 53 63 68 65 6d 61 52 65 71 29  aning(SchemaReq)
0300: 20 20 7b 53 63 68 65 6d 61 20 72 65 71 75 69 72    {Schema requir
0310: 65 64 20 2d 20 22 6d 61 69 6e 22 20 69 73 20 64  ed - "main" is d
0320: 65 66 61 75 6c 74 7d 0a 73 65 74 20 66 6c 61 67  efault}.set flag
0330: 4d 65 61 6e 69 6e 67 28 53 63 68 65 6d 61 4f 70  Meaning(SchemaOp
0340: 74 29 20 20 7b 53 63 68 65 6d 61 20 72 65 73 74  t)  {Schema rest
0350: 72 69 63 74 73 20 6e 61 6d 65 20 73 65 61 72 63  ricts name searc
0360: 68 20 69 66 20 70 72 65 73 65 6e 74 7d 0a 73 65  h if present}.se
0370: 74 20 66 6c 61 67 4d 65 61 6e 69 6e 67 28 4e 6f  t flagMeaning(No
0380: 43 6f 6c 75 6d 6e 73 29 20 20 7b 4f 50 5f 52 65  Columns)  {OP_Re
0390: 73 75 6c 74 52 6f 77 20 63 61 6c 6c 65 64 20 77  sultRow called w
03a0: 69 74 68 20 7a 65 72 6f 20 63 6f 6c 75 6d 6e 73  ith zero columns
03b0: 7d 0a 73 65 74 20 66 6c 61 67 4d 65 61 6e 69 6e  }.set flagMeanin
03c0: 67 28 4e 6f 43 6f 6c 75 6d 6e 73 31 29 20 7b 7a  g(NoColumns1) {z
03d0: 65 72 6f 20 63 6f 6c 75 6d 6e 73 20 69 66 20 52  ero columns if R
03e0: 48 53 20 61 72 67 75 6d 65 6e 74 20 69 73 20 70  HS argument is p
03f0: 72 65 73 65 6e 74 7d 0a 0a 73 65 74 20 70 72 61  resent}..set pra
0400: 67 6d 61 5f 64 65 66 20 7b 0a 20 20 4e 41 4d 45  gma_def {.  NAME
0410: 3a 20 66 75 6c 6c 5f 63 6f 6c 75 6d 6e 5f 6e 61  : full_column_na
0420: 6d 65 73 0a 20 20 54 59 50 45 3a 20 46 4c 41 47  mes.  TYPE: FLAG
0430: 0a 20 20 41 52 47 3a 20 20 53 51 4c 49 54 45 5f  .  ARG:  SQLITE_
0440: 46 75 6c 6c 43 6f 6c 4e 61 6d 65 73 0a 20 20 49  FullColNames.  I
0450: 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28 53 51  F:   !defined(SQ
0460: 4c 49 54 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f 50  LITE_OMIT_FLAG_P
0470: 52 41 47 4d 41 53 29 0a 0a 20 20 4e 41 4d 45 3a  RAGMAS)..  NAME:
0480: 20 73 68 6f 72 74 5f 63 6f 6c 75 6d 6e 5f 6e 61   short_column_na
0490: 6d 65 73 0a 20 20 54 59 50 45 3a 20 46 4c 41 47  mes.  TYPE: FLAG
04a0: 0a 20 20 41 52 47 3a 20 20 53 51 4c 49 54 45 5f  .  ARG:  SQLITE_
04b0: 53 68 6f 72 74 43 6f 6c 4e 61 6d 65 73 0a 20 20  ShortColNames.  
04c0: 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28 53  IF:   !defined(S
04d0: 51 4c 49 54 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f  QLITE_OMIT_FLAG_
04e0: 50 52 41 47 4d 41 53 29 0a 0a 20 20 4e 41 4d 45  PRAGMAS)..  NAME
04f0: 3a 20 63 6f 75 6e 74 5f 63 68 61 6e 67 65 73 0a  : count_changes.
0500: 20 20 54 59 50 45 3a 20 46 4c 41 47 0a 20 20 41    TYPE: FLAG.  A
0510: 52 47 3a 20 20 53 51 4c 49 54 45 5f 43 6f 75 6e  RG:  SQLITE_Coun
0520: 74 52 6f 77 73 0a 20 20 49 46 3a 20 20 20 21 64  tRows.  IF:   !d
0530: 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d  efined(SQLITE_OM
0540: 49 54 5f 46 4c 41 47 5f 50 52 41 47 4d 41 53 29  IT_FLAG_PRAGMAS)
0550: 0a 0a 20 20 4e 41 4d 45 3a 20 65 6d 70 74 79 5f  ..  NAME: empty_
0560: 72 65 73 75 6c 74 5f 63 61 6c 6c 62 61 63 6b 73  result_callbacks
0570: 0a 20 20 54 59 50 45 3a 20 46 4c 41 47 0a 20 20  .  TYPE: FLAG.  
0580: 41 52 47 3a 20 20 53 51 4c 49 54 45 5f 4e 75 6c  ARG:  SQLITE_Nul
0590: 6c 43 61 6c 6c 62 61 63 6b 0a 20 20 49 46 3a 20  lCallback.  IF: 
05a0: 20 20 21 64 65 66 69 6e 65 64 28 53 51 4c 49 54    !defined(SQLIT
05b0: 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f 50 52 41 47  E_OMIT_FLAG_PRAG
05c0: 4d 41 53 29 0a 0a 20 20 4e 41 4d 45 3a 20 6c 65  MAS)..  NAME: le
05d0: 67 61 63 79 5f 66 69 6c 65 5f 66 6f 72 6d 61 74  gacy_file_format
05e0: 0a 20 20 54 59 50 45 3a 20 46 4c 41 47 0a 20 20  .  TYPE: FLAG.  
05f0: 41 52 47 3a 20 20 53 51 4c 49 54 45 5f 4c 65 67  ARG:  SQLITE_Leg
0600: 61 63 79 46 69 6c 65 46 6d 74 0a 20 20 49 46 3a  acyFileFmt.  IF:
0610: 20 20 20 21 64 65 66 69 6e 65 64 28 53 51 4c 49     !defined(SQLI
0620: 54 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f 50 52 41  TE_OMIT_FLAG_PRA
0630: 47 4d 41 53 29 0a 0a 20 20 4e 41 4d 45 3a 20 66  GMAS)..  NAME: f
0640: 75 6c 6c 66 73 79 6e 63 0a 20 20 54 59 50 45 3a  ullfsync.  TYPE:
0650: 20 46 4c 41 47 0a 20 20 41 52 47 3a 20 20 53 51   FLAG.  ARG:  SQ
0660: 4c 49 54 45 5f 46 75 6c 6c 46 53 79 6e 63 0a 20  LITE_FullFSync. 
0670: 20 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28   IF:   !defined(
0680: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 46 4c 41 47  SQLITE_OMIT_FLAG
0690: 5f 50 52 41 47 4d 41 53 29 0a 0a 20 20 4e 41 4d  _PRAGMAS)..  NAM
06a0: 45 3a 20 63 68 65 63 6b 70 6f 69 6e 74 5f 66 75  E: checkpoint_fu
06b0: 6c 6c 66 73 79 6e 63 0a 20 20 54 59 50 45 3a 20  llfsync.  TYPE: 
06c0: 46 4c 41 47 0a 20 20 41 52 47 3a 20 20 53 51 4c  FLAG.  ARG:  SQL
06d0: 49 54 45 5f 43 6b 70 74 46 75 6c 6c 46 53 79 6e  ITE_CkptFullFSyn
06e0: 63 0a 20 20 49 46 3a 20 20 20 21 64 65 66 69 6e  c.  IF:   !defin
06f0: 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 46  ed(SQLITE_OMIT_F
0700: 4c 41 47 5f 50 52 41 47 4d 41 53 29 0a 0a 20 20  LAG_PRAGMAS)..  
0710: 4e 41 4d 45 3a 20 63 61 63 68 65 5f 73 70 69 6c  NAME: cache_spil
0720: 6c 0a 20 20 46 4c 41 47 3a 20 52 65 73 75 6c 74  l.  FLAG: Result
0730: 30 20 53 63 68 65 6d 61 52 65 71 20 4e 6f 43 6f  0 SchemaReq NoCo
0740: 6c 75 6d 6e 73 31 0a 20 20 49 46 3a 20 20 20 21  lumns1.  IF:   !
0750: 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f  defined(SQLITE_O
0760: 4d 49 54 5f 46 4c 41 47 5f 50 52 41 47 4d 41 53  MIT_FLAG_PRAGMAS
0770: 29 0a 0a 20 20 4e 41 4d 45 3a 20 72 65 76 65 72  )..  NAME: rever
0780: 73 65 5f 75 6e 6f 72 64 65 72 65 64 5f 73 65 6c  se_unordered_sel
0790: 65 63 74 73 0a 20 20 54 59 50 45 3a 20 46 4c 41  ects.  TYPE: FLA
07a0: 47 0a 20 20 41 52 47 3a 20 20 53 51 4c 49 54 45  G.  ARG:  SQLITE
07b0: 5f 52 65 76 65 72 73 65 4f 72 64 65 72 0a 20 20  _ReverseOrder.  
07c0: 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28 53  IF:   !defined(S
07d0: 51 4c 49 54 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f  QLITE_OMIT_FLAG_
07e0: 50 52 41 47 4d 41 53 29 0a 0a 20 20 4e 41 4d 45  PRAGMAS)..  NAME
07f0: 3a 20 71 75 65 72 79 5f 6f 6e 6c 79 0a 20 20 54  : query_only.  T
0800: 59 50 45 3a 20 46 4c 41 47 0a 20 20 41 52 47 3a  YPE: FLAG.  ARG:
0810: 20 20 53 51 4c 49 54 45 5f 51 75 65 72 79 4f 6e    SQLITE_QueryOn
0820: 6c 79 0a 20 20 49 46 3a 20 20 20 21 64 65 66 69  ly.  IF:   !defi
0830: 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  ned(SQLITE_OMIT_
0840: 46 4c 41 47 5f 50 52 41 47 4d 41 53 29 0a 0a 20  FLAG_PRAGMAS).. 
0850: 20 4e 41 4d 45 3a 20 61 75 74 6f 6d 61 74 69 63   NAME: automatic
0860: 5f 69 6e 64 65 78 0a 20 20 54 59 50 45 3a 20 46  _index.  TYPE: F
0870: 4c 41 47 0a 20 20 41 52 47 3a 20 20 53 51 4c 49  LAG.  ARG:  SQLI
0880: 54 45 5f 41 75 74 6f 49 6e 64 65 78 0a 20 20 49  TE_AutoIndex.  I
0890: 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28 53 51  F:   !defined(SQ
08a0: 4c 49 54 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f 50  LITE_OMIT_FLAG_P
08b0: 52 41 47 4d 41 53 29 0a 20 20 49 46 3a 20 20 20  RAGMAS).  IF:   
08c0: 21 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f  !defined(SQLITE_
08d0: 4f 4d 49 54 5f 41 55 54 4f 4d 41 54 49 43 5f 49  OMIT_AUTOMATIC_I
08e0: 4e 44 45 58 29 0a 0a 20 20 4e 41 4d 45 3a 20 73  NDEX)..  NAME: s
08f0: 71 6c 5f 74 72 61 63 65 0a 20 20 54 59 50 45 3a  ql_trace.  TYPE:
0900: 20 46 4c 41 47 0a 20 20 41 52 47 3a 20 20 53 51   FLAG.  ARG:  SQ
0910: 4c 49 54 45 5f 53 71 6c 54 72 61 63 65 0a 20 20  LITE_SqlTrace.  
0920: 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28 53  IF:   !defined(S
0930: 51 4c 49 54 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f  QLITE_OMIT_FLAG_
0940: 50 52 41 47 4d 41 53 29 0a 20 20 49 46 3a 20 20  PRAGMAS).  IF:  
0950: 20 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f   defined(SQLITE_
0960: 44 45 42 55 47 29 0a 0a 20 20 4e 41 4d 45 3a 20  DEBUG)..  NAME: 
0970: 76 64 62 65 5f 6c 69 73 74 69 6e 67 0a 20 20 54  vdbe_listing.  T
0980: 59 50 45 3a 20 46 4c 41 47 0a 20 20 41 52 47 3a  YPE: FLAG.  ARG:
0990: 20 20 53 51 4c 49 54 45 5f 56 64 62 65 4c 69 73    SQLITE_VdbeLis
09a0: 74 69 6e 67 0a 20 20 49 46 3a 20 20 20 21 64 65  ting.  IF:   !de
09b0: 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49  fined(SQLITE_OMI
09c0: 54 5f 46 4c 41 47 5f 50 52 41 47 4d 41 53 29 0a  T_FLAG_PRAGMAS).
09d0: 20 20 49 46 3a 20 20 20 64 65 66 69 6e 65 64 28    IF:   defined(
09e0: 53 51 4c 49 54 45 5f 44 45 42 55 47 29 0a 0a 20  SQLITE_DEBUG).. 
09f0: 20 4e 41 4d 45 3a 20 76 64 62 65 5f 74 72 61 63   NAME: vdbe_trac
0a00: 65 0a 20 20 54 59 50 45 3a 20 46 4c 41 47 0a 20  e.  TYPE: FLAG. 
0a10: 20 41 52 47 3a 20 20 53 51 4c 49 54 45 5f 56 64   ARG:  SQLITE_Vd
0a20: 62 65 54 72 61 63 65 0a 20 20 49 46 3a 20 20 20  beTrace.  IF:   
0a30: 21 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f  !defined(SQLITE_
0a40: 4f 4d 49 54 5f 46 4c 41 47 5f 50 52 41 47 4d 41  OMIT_FLAG_PRAGMA
0a50: 53 29 0a 20 20 49 46 3a 20 20 20 64 65 66 69 6e  S).  IF:   defin
0a60: 65 64 28 53 51 4c 49 54 45 5f 44 45 42 55 47 29  ed(SQLITE_DEBUG)
0a70: 0a 0a 20 20 4e 41 4d 45 3a 20 76 64 62 65 5f 61  ..  NAME: vdbe_a
0a80: 64 64 6f 70 74 72 61 63 65 0a 20 20 54 59 50 45  ddoptrace.  TYPE
0a90: 3a 20 46 4c 41 47 0a 20 20 41 52 47 3a 20 20 53  : FLAG.  ARG:  S
0aa0: 51 4c 49 54 45 5f 56 64 62 65 41 64 64 6f 70 54  QLITE_VdbeAddopT
0ab0: 72 61 63 65 0a 20 20 49 46 3a 20 20 20 21 64 65  race.  IF:   !de
0ac0: 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49  fined(SQLITE_OMI
0ad0: 54 5f 46 4c 41 47 5f 50 52 41 47 4d 41 53 29 0a  T_FLAG_PRAGMAS).
0ae0: 20 20 49 46 3a 20 20 20 64 65 66 69 6e 65 64 28    IF:   defined(
0af0: 53 51 4c 49 54 45 5f 44 45 42 55 47 29 0a 0a 20  SQLITE_DEBUG).. 
0b00: 20 4e 41 4d 45 3a 20 76 64 62 65 5f 64 65 62 75   NAME: vdbe_debu
0b10: 67 0a 20 20 54 59 50 45 3a 20 46 4c 41 47 0a 20  g.  TYPE: FLAG. 
0b20: 20 41 52 47 3a 20 20 53 51 4c 49 54 45 5f 53 71   ARG:  SQLITE_Sq
0b30: 6c 54 72 61 63 65 7c 53 51 4c 49 54 45 5f 56 64  lTrace|SQLITE_Vd
0b40: 62 65 4c 69 73 74 69 6e 67 7c 53 51 4c 49 54 45  beListing|SQLITE
0b50: 5f 56 64 62 65 54 72 61 63 65 0a 20 20 49 46 3a  _VdbeTrace.  IF:
0b60: 20 20 20 21 64 65 66 69 6e 65 64 28 53 51 4c 49     !defined(SQLI
0b70: 54 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f 50 52 41  TE_OMIT_FLAG_PRA
0b80: 47 4d 41 53 29 0a 20 20 49 46 3a 20 20 20 64 65  GMAS).  IF:   de
0b90: 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 44 45 42  fined(SQLITE_DEB
0ba0: 55 47 29 0a 0a 20 20 4e 41 4d 45 3a 20 76 64 62  UG)..  NAME: vdb
0bb0: 65 5f 65 71 70 0a 20 20 54 59 50 45 3a 20 46 4c  e_eqp.  TYPE: FL
0bc0: 41 47 0a 20 20 41 52 47 3a 20 20 53 51 4c 49 54  AG.  ARG:  SQLIT
0bd0: 45 5f 56 64 62 65 45 51 50 0a 20 20 49 46 3a 20  E_VdbeEQP.  IF: 
0be0: 20 20 21 64 65 66 69 6e 65 64 28 53 51 4c 49 54    !defined(SQLIT
0bf0: 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f 50 52 41 47  E_OMIT_FLAG_PRAG
0c00: 4d 41 53 29 0a 20 20 49 46 3a 20 20 20 64 65 66  MAS).  IF:   def
0c10: 69 6e 65 64 28 53 51 4c 49 54 45 5f 44 45 42 55  ined(SQLITE_DEBU
0c20: 47 29 0a 0a 20 20 4e 41 4d 45 3a 20 69 67 6e 6f  G)..  NAME: igno
0c30: 72 65 5f 63 68 65 63 6b 5f 63 6f 6e 73 74 72 61  re_check_constra
0c40: 69 6e 74 73 0a 20 20 54 59 50 45 3a 20 46 4c 41  ints.  TYPE: FLA
0c50: 47 0a 20 20 41 52 47 3a 20 20 53 51 4c 49 54 45  G.  ARG:  SQLITE
0c60: 5f 49 67 6e 6f 72 65 43 68 65 63 6b 73 0a 20 20  _IgnoreChecks.  
0c70: 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28 53  IF:   !defined(S
0c80: 51 4c 49 54 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f  QLITE_OMIT_FLAG_
0c90: 50 52 41 47 4d 41 53 29 0a 20 20 49 46 3a 20 20  PRAGMAS).  IF:  
0ca0: 20 21 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45   !defined(SQLITE
0cb0: 5f 4f 4d 49 54 5f 43 48 45 43 4b 29 0a 0a 20 20  _OMIT_CHECK)..  
0cc0: 4e 41 4d 45 3a 20 77 72 69 74 61 62 6c 65 5f 73  NAME: writable_s
0cd0: 63 68 65 6d 61 0a 20 20 54 59 50 45 3a 20 46 4c  chema.  TYPE: FL
0ce0: 41 47 0a 20 20 41 52 47 3a 20 20 53 51 4c 49 54  AG.  ARG:  SQLIT
0cf0: 45 5f 57 72 69 74 65 53 63 68 65 6d 61 0a 20 20  E_WriteSchema.  
0d00: 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28 53  IF:   !defined(S
0d10: 51 4c 49 54 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f  QLITE_OMIT_FLAG_
0d20: 50 52 41 47 4d 41 53 29 0a 0a 20 20 4e 41 4d 45  PRAGMAS)..  NAME
0d30: 3a 20 72 65 61 64 5f 75 6e 63 6f 6d 6d 69 74 74  : read_uncommitt
0d40: 65 64 0a 20 20 54 59 50 45 3a 20 46 4c 41 47 0a  ed.  TYPE: FLAG.
0d50: 20 20 41 52 47 3a 20 20 53 51 4c 49 54 45 5f 52    ARG:  SQLITE_R
0d60: 65 61 64 55 6e 63 6f 6d 6d 69 74 0a 20 20 49 46  eadUncommit.  IF
0d70: 3a 20 20 20 21 64 65 66 69 6e 65 64 28 53 51 4c  :   !defined(SQL
0d80: 49 54 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f 50 52  ITE_OMIT_FLAG_PR
0d90: 41 47 4d 41 53 29 0a 0a 20 20 4e 41 4d 45 3a 20  AGMAS)..  NAME: 
0da0: 72 65 63 75 72 73 69 76 65 5f 74 72 69 67 67 65  recursive_trigge
0db0: 72 73 0a 20 20 54 59 50 45 3a 20 46 4c 41 47 0a  rs.  TYPE: FLAG.
0dc0: 20 20 41 52 47 3a 20 20 53 51 4c 49 54 45 5f 52    ARG:  SQLITE_R
0dd0: 65 63 54 72 69 67 67 65 72 73 0a 20 20 49 46 3a  ecTriggers.  IF:
0de0: 20 20 20 21 64 65 66 69 6e 65 64 28 53 51 4c 49     !defined(SQLI
0df0: 54 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f 50 52 41  TE_OMIT_FLAG_PRA
0e00: 47 4d 41 53 29 0a 0a 20 20 4e 41 4d 45 3a 20 66  GMAS)..  NAME: f
0e10: 6f 72 65 69 67 6e 5f 6b 65 79 73 0a 20 20 54 59  oreign_keys.  TY
0e20: 50 45 3a 20 46 4c 41 47 0a 20 20 41 52 47 3a 20  PE: FLAG.  ARG: 
0e30: 20 53 51 4c 49 54 45 5f 46 6f 72 65 69 67 6e 4b   SQLITE_ForeignK
0e40: 65 79 73 0a 20 20 49 46 3a 20 20 20 21 64 65 66  eys.  IF:   !def
0e50: 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54  ined(SQLITE_OMIT
0e60: 5f 46 4c 41 47 5f 50 52 41 47 4d 41 53 29 0a 20  _FLAG_PRAGMAS). 
0e70: 20 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28   IF:   !defined(
0e80: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 46 4f 52 45  SQLITE_OMIT_FORE
0e90: 49 47 4e 5f 4b 45 59 29 20 26 26 20 21 64 65 66  IGN_KEY) && !def
0ea0: 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54  ined(SQLITE_OMIT
0eb0: 5f 54 52 49 47 47 45 52 29 0a 0a 20 20 4e 41 4d  _TRIGGER)..  NAM
0ec0: 45 3a 20 64 65 66 65 72 5f 66 6f 72 65 69 67 6e  E: defer_foreign
0ed0: 5f 6b 65 79 73 0a 20 20 54 59 50 45 3a 20 46 4c  _keys.  TYPE: FL
0ee0: 41 47 0a 20 20 41 52 47 3a 20 20 53 51 4c 49 54  AG.  ARG:  SQLIT
0ef0: 45 5f 44 65 66 65 72 46 4b 73 0a 20 20 49 46 3a  E_DeferFKs.  IF:
0f00: 20 20 20 21 64 65 66 69 6e 65 64 28 53 51 4c 49     !defined(SQLI
0f10: 54 45 5f 4f 4d 49 54 5f 46 4c 41 47 5f 50 52 41  TE_OMIT_FLAG_PRA
0f20: 47 4d 41 53 29 0a 20 20 49 46 3a 20 20 20 21 64  GMAS).  IF:   !d
0f30: 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d  efined(SQLITE_OM
0f40: 49 54 5f 46 4f 52 45 49 47 4e 5f 4b 45 59 29 20  IT_FOREIGN_KEY) 
0f50: 26 26 20 21 64 65 66 69 6e 65 64 28 53 51 4c 49  && !defined(SQLI
0f60: 54 45 5f 4f 4d 49 54 5f 54 52 49 47 47 45 52 29  TE_OMIT_TRIGGER)
0f70: 0a 0a 20 20 4e 41 4d 45 3a 20 63 65 6c 6c 5f 73  ..  NAME: cell_s
0f80: 69 7a 65 5f 63 68 65 63 6b 0a 20 20 54 59 50 45  ize_check.  TYPE
0f90: 3a 20 46 4c 41 47 0a 20 20 41 52 47 3a 20 20 53  : FLAG.  ARG:  S
0fa0: 51 4c 49 54 45 5f 43 65 6c 6c 53 69 7a 65 43 6b  QLITE_CellSizeCk
0fb0: 0a 0a 20 20 4e 41 4d 45 3a 20 64 65 66 61 75 6c  ..  NAME: defaul
0fc0: 74 5f 63 61 63 68 65 5f 73 69 7a 65 0a 20 20 46  t_cache_size.  F
0fd0: 4c 41 47 3a 20 4e 65 65 64 53 63 68 65 6d 61 20  LAG: NeedSchema 
0fe0: 52 65 73 75 6c 74 30 20 53 63 68 65 6d 61 52 65  Result0 SchemaRe
0ff0: 71 20 4e 6f 43 6f 6c 75 6d 6e 73 31 0a 20 20 43  q NoColumns1.  C
1000: 4f 4c 53 3a 20 63 61 63 68 65 5f 73 69 7a 65 0a  OLS: cache_size.
1010: 20 20 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64    IF:   !defined
1020: 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 50 41 47  (SQLITE_OMIT_PAG
1030: 45 52 5f 50 52 41 47 4d 41 53 29 20 26 26 20 21  ER_PRAGMAS) && !
1040: 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f  defined(SQLITE_O
1050: 4d 49 54 5f 44 45 50 52 45 43 41 54 45 44 29 0a  MIT_DEPRECATED).
1060: 0a 20 20 4e 41 4d 45 3a 20 70 61 67 65 5f 73 69  .  NAME: page_si
1070: 7a 65 0a 20 20 46 4c 41 47 3a 20 52 65 73 75 6c  ze.  FLAG: Resul
1080: 74 30 20 53 63 68 65 6d 61 52 65 71 20 4e 6f 43  t0 SchemaReq NoC
1090: 6f 6c 75 6d 6e 73 31 0a 20 20 49 46 3a 20 20 20  olumns1.  IF:   
10a0: 21 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f  !defined(SQLITE_
10b0: 4f 4d 49 54 5f 50 41 47 45 52 5f 50 52 41 47 4d  OMIT_PAGER_PRAGM
10c0: 41 53 29 0a 0a 20 20 4e 41 4d 45 3a 20 73 65 63  AS)..  NAME: sec
10d0: 75 72 65 5f 64 65 6c 65 74 65 0a 20 20 46 4c 41  ure_delete.  FLA
10e0: 47 3a 20 52 65 73 75 6c 74 30 0a 20 20 49 46 3a  G: Result0.  IF:
10f0: 20 20 20 21 64 65 66 69 6e 65 64 28 53 51 4c 49     !defined(SQLI
1100: 54 45 5f 4f 4d 49 54 5f 50 41 47 45 52 5f 50 52  TE_OMIT_PAGER_PR
1110: 41 47 4d 41 53 29 0a 0a 20 20 4e 41 4d 45 3a 20  AGMAS)..  NAME: 
1120: 70 61 67 65 5f 63 6f 75 6e 74 0a 20 20 46 4c 41  page_count.  FLA
1130: 47 3a 20 4e 65 65 64 53 63 68 65 6d 61 20 52 65  G: NeedSchema Re
1140: 73 75 6c 74 30 20 53 63 68 65 6d 61 52 65 71 0a  sult0 SchemaReq.
1150: 20 20 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64    IF:   !defined
1160: 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 50 41 47  (SQLITE_OMIT_PAG
1170: 45 52 5f 50 52 41 47 4d 41 53 29 0a 0a 20 20 4e  ER_PRAGMAS)..  N
1180: 41 4d 45 3a 20 6d 61 78 5f 70 61 67 65 5f 63 6f  AME: max_page_co
1190: 75 6e 74 0a 20 20 54 59 50 45 3a 20 50 41 47 45  unt.  TYPE: PAGE
11a0: 5f 43 4f 55 4e 54 0a 20 20 46 4c 41 47 3a 20 4e  _COUNT.  FLAG: N
11b0: 65 65 64 53 63 68 65 6d 61 20 52 65 73 75 6c 74  eedSchema Result
11c0: 30 20 53 63 68 65 6d 61 52 65 71 0a 20 20 49 46  0 SchemaReq.  IF
11d0: 3a 20 20 20 21 64 65 66 69 6e 65 64 28 53 51 4c  :   !defined(SQL
11e0: 49 54 45 5f 4f 4d 49 54 5f 50 41 47 45 52 5f 50  ITE_OMIT_PAGER_P
11f0: 52 41 47 4d 41 53 29 0a 0a 20 20 4e 41 4d 45 3a  RAGMAS)..  NAME:
1200: 20 6c 6f 63 6b 69 6e 67 5f 6d 6f 64 65 0a 20 20   locking_mode.  
1210: 46 4c 41 47 3a 20 52 65 73 75 6c 74 30 20 53 63  FLAG: Result0 Sc
1220: 68 65 6d 61 52 65 71 0a 20 20 49 46 3a 20 20 20  hemaReq.  IF:   
1230: 21 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f  !defined(SQLITE_
1240: 4f 4d 49 54 5f 50 41 47 45 52 5f 50 52 41 47 4d  OMIT_PAGER_PRAGM
1250: 41 53 29 0a 0a 20 20 4e 41 4d 45 3a 20 6a 6f 75  AS)..  NAME: jou
1260: 72 6e 61 6c 5f 6d 6f 64 65 0a 20 20 46 4c 41 47  rnal_mode.  FLAG
1270: 3a 20 4e 65 65 64 53 63 68 65 6d 61 20 52 65 73  : NeedSchema Res
1280: 75 6c 74 30 20 53 63 68 65 6d 61 52 65 71 0a 20  ult0 SchemaReq. 
1290: 20 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28   IF:   !defined(
12a0: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 50 41 47 45  SQLITE_OMIT_PAGE
12b0: 52 5f 50 52 41 47 4d 41 53 29 0a 0a 20 20 4e 41  R_PRAGMAS)..  NA
12c0: 4d 45 3a 20 6a 6f 75 72 6e 61 6c 5f 73 69 7a 65  ME: journal_size
12d0: 5f 6c 69 6d 69 74 0a 20 20 46 4c 41 47 3a 20 52  _limit.  FLAG: R
12e0: 65 73 75 6c 74 30 20 53 63 68 65 6d 61 52 65 71  esult0 SchemaReq
12f0: 0a 20 20 49 46 3a 20 20 20 21 64 65 66 69 6e 65  .  IF:   !define
1300: 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 50 41  d(SQLITE_OMIT_PA
1310: 47 45 52 5f 50 52 41 47 4d 41 53 29 0a 0a 20 20  GER_PRAGMAS)..  
1320: 4e 41 4d 45 3a 20 63 61 63 68 65 5f 73 69 7a 65  NAME: cache_size
1330: 0a 20 20 46 4c 41 47 3a 20 4e 65 65 64 53 63 68  .  FLAG: NeedSch
1340: 65 6d 61 20 52 65 73 75 6c 74 30 20 53 63 68 65  ema Result0 Sche
1350: 6d 61 52 65 71 20 4e 6f 43 6f 6c 75 6d 6e 73 31  maReq NoColumns1
1360: 0a 20 20 49 46 3a 20 20 20 21 64 65 66 69 6e 65  .  IF:   !define
1370: 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 50 41  d(SQLITE_OMIT_PA
1380: 47 45 52 5f 50 52 41 47 4d 41 53 29 0a 0a 20 20  GER_PRAGMAS)..  
1390: 4e 41 4d 45 3a 20 6d 6d 61 70 5f 73 69 7a 65 0a  NAME: mmap_size.
13a0: 20 20 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64    IF:   !defined
13b0: 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 50 41 47  (SQLITE_OMIT_PAG
13c0: 45 52 5f 50 52 41 47 4d 41 53 29 0a 0a 20 20 4e  ER_PRAGMAS)..  N
13d0: 41 4d 45 3a 20 61 75 74 6f 5f 76 61 63 75 75 6d  AME: auto_vacuum
13e0: 0a 20 20 46 4c 41 47 3a 20 4e 65 65 64 53 63 68  .  FLAG: NeedSch
13f0: 65 6d 61 20 52 65 73 75 6c 74 30 20 53 63 68 65  ema Result0 Sche
1400: 6d 61 52 65 71 20 4e 6f 43 6f 6c 75 6d 6e 73 31  maReq NoColumns1
1410: 0a 20 20 49 46 3a 20 20 20 21 64 65 66 69 6e 65  .  IF:   !define
1420: 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 41 55  d(SQLITE_OMIT_AU
1430: 54 4f 56 41 43 55 55 4d 29 0a 0a 20 20 4e 41 4d  TOVACUUM)..  NAM
1440: 45 3a 20 69 6e 63 72 65 6d 65 6e 74 61 6c 5f 76  E: incremental_v
1450: 61 63 75 75 6d 0a 20 20 46 4c 41 47 3a 20 4e 65  acuum.  FLAG: Ne
1460: 65 64 53 63 68 65 6d 61 20 4e 6f 43 6f 6c 75 6d  edSchema NoColum
1470: 6e 73 0a 20 20 49 46 3a 20 20 20 21 64 65 66 69  ns.  IF:   !defi
1480: 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  ned(SQLITE_OMIT_
1490: 41 55 54 4f 56 41 43 55 55 4d 29 0a 0a 20 20 4e  AUTOVACUUM)..  N
14a0: 41 4d 45 3a 20 74 65 6d 70 5f 73 74 6f 72 65 0a  AME: temp_store.
14b0: 20 20 46 4c 41 47 3a 20 52 65 73 75 6c 74 30 20    FLAG: Result0 
14c0: 4e 6f 43 6f 6c 75 6d 6e 73 31 0a 20 20 49 46 3a  NoColumns1.  IF:
14d0: 20 20 20 21 64 65 66 69 6e 65 64 28 53 51 4c 49     !defined(SQLI
14e0: 54 45 5f 4f 4d 49 54 5f 50 41 47 45 52 5f 50 52  TE_OMIT_PAGER_PR
14f0: 41 47 4d 41 53 29 0a 0a 20 20 4e 41 4d 45 3a 20  AGMAS)..  NAME: 
1500: 74 65 6d 70 5f 73 74 6f 72 65 5f 64 69 72 65 63  temp_store_direc
1510: 74 6f 72 79 0a 20 20 46 4c 41 47 3a 20 4e 6f 43  tory.  FLAG: NoC
1520: 6f 6c 75 6d 6e 73 31 0a 20 20 49 46 3a 20 20 20  olumns1.  IF:   
1530: 21 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f  !defined(SQLITE_
1540: 4f 4d 49 54 5f 50 41 47 45 52 5f 50 52 41 47 4d  OMIT_PAGER_PRAGM
1550: 41 53 29 0a 0a 20 20 4e 41 4d 45 3a 20 64 61 74  AS)..  NAME: dat
1560: 61 5f 73 74 6f 72 65 5f 64 69 72 65 63 74 6f 72  a_store_director
1570: 79 0a 20 20 46 4c 41 47 3a 20 4e 6f 43 6f 6c 75  y.  FLAG: NoColu
1580: 6d 6e 73 31 0a 20 20 49 46 3a 20 20 20 21 64 65  mns1.  IF:   !de
1590: 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49  fined(SQLITE_OMI
15a0: 54 5f 50 41 47 45 52 5f 50 52 41 47 4d 41 53 29  T_PAGER_PRAGMAS)
15b0: 20 26 26 20 53 51 4c 49 54 45 5f 4f 53 5f 57 49   && SQLITE_OS_WI
15c0: 4e 0a 0a 20 20 4e 41 4d 45 3a 20 6c 6f 63 6b 5f  N..  NAME: lock_
15d0: 70 72 6f 78 79 5f 66 69 6c 65 0a 20 20 46 4c 41  proxy_file.  FLA
15e0: 47 3a 20 4e 6f 43 6f 6c 75 6d 6e 73 31 0a 20 20  G: NoColumns1.  
15f0: 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28 53  IF:   !defined(S
1600: 51 4c 49 54 45 5f 4f 4d 49 54 5f 50 41 47 45 52  QLITE_OMIT_PAGER
1610: 5f 50 52 41 47 4d 41 53 29 20 26 26 20 53 51 4c  _PRAGMAS) && SQL
1620: 49 54 45 5f 45 4e 41 42 4c 45 5f 4c 4f 43 4b 49  ITE_ENABLE_LOCKI
1630: 4e 47 5f 53 54 59 4c 45 0a 0a 20 20 4e 41 4d 45  NG_STYLE..  NAME
1640: 3a 20 73 79 6e 63 68 72 6f 6e 6f 75 73 0a 20 20  : synchronous.  
1650: 46 4c 41 47 3a 20 4e 65 65 64 53 63 68 65 6d 61  FLAG: NeedSchema
1660: 20 52 65 73 75 6c 74 30 20 53 63 68 65 6d 61 52   Result0 SchemaR
1670: 65 71 20 4e 6f 43 6f 6c 75 6d 6e 73 31 0a 20 20  eq NoColumns1.  
1680: 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28 53  IF:   !defined(S
1690: 51 4c 49 54 45 5f 4f 4d 49 54 5f 50 41 47 45 52  QLITE_OMIT_PAGER
16a0: 5f 50 52 41 47 4d 41 53 29 0a 0a 20 20 4e 41 4d  _PRAGMAS)..  NAM
16b0: 45 3a 20 74 61 62 6c 65 5f 69 6e 66 6f 0a 20 20  E: table_info.  
16c0: 46 4c 41 47 3a 20 4e 65 65 64 53 63 68 65 6d 61  FLAG: NeedSchema
16d0: 20 52 65 73 75 6c 74 31 20 53 63 68 65 6d 61 4f   Result1 SchemaO
16e0: 70 74 0a 20 20 43 4f 4c 53 3a 20 63 69 64 20 6e  pt.  COLS: cid n
16f0: 61 6d 65 20 74 79 70 65 20 6e 6f 74 6e 75 6c 6c  ame type notnull
1700: 20 64 66 6c 74 5f 76 61 6c 75 65 20 70 6b 0a 20   dflt_value pk. 
1710: 20 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28   IF:   !defined(
1720: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 53 43 48 45  SQLITE_OMIT_SCHE
1730: 4d 41 5f 50 52 41 47 4d 41 53 29 0a 0a 20 20 4e  MA_PRAGMAS)..  N
1740: 41 4d 45 3a 20 73 74 61 74 73 0a 20 20 46 4c 41  AME: stats.  FLA
1750: 47 3a 20 4e 65 65 64 53 63 68 65 6d 61 20 52 65  G: NeedSchema Re
1760: 73 75 6c 74 30 20 53 63 68 65 6d 61 52 65 71 0a  sult0 SchemaReq.
1770: 20 20 43 4f 4c 53 3a 20 74 62 6c 20 69 64 78 20    COLS: tbl idx 
1780: 77 64 74 68 20 68 67 68 74 20 66 6c 67 73 0a 20  wdth hght flgs. 
1790: 20 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28   IF:   !defined(
17a0: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 53 43 48 45  SQLITE_OMIT_SCHE
17b0: 4d 41 5f 50 52 41 47 4d 41 53 29 20 26 26 20 64  MA_PRAGMAS) && d
17c0: 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 44 45  efined(SQLITE_DE
17d0: 42 55 47 29 0a 0a 20 20 4e 41 4d 45 3a 20 69 6e  BUG)..  NAME: in
17e0: 64 65 78 5f 69 6e 66 6f 0a 20 20 54 59 50 45 3a  dex_info.  TYPE:
17f0: 20 49 4e 44 45 58 5f 49 4e 46 4f 0a 20 20 41 52   INDEX_INFO.  AR
1800: 47 3a 20 20 30 0a 20 20 46 4c 41 47 3a 20 4e 65  G:  0.  FLAG: Ne
1810: 65 64 53 63 68 65 6d 61 20 52 65 73 75 6c 74 31  edSchema Result1
1820: 20 53 63 68 65 6d 61 4f 70 74 0a 20 20 43 4f 4c   SchemaOpt.  COL
1830: 53 3a 20 73 65 71 6e 6f 20 63 69 64 20 6e 61 6d  S: seqno cid nam
1840: 65 0a 20 20 49 46 3a 20 20 20 21 64 65 66 69 6e  e.  IF:   !defin
1850: 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 53  ed(SQLITE_OMIT_S
1860: 43 48 45 4d 41 5f 50 52 41 47 4d 41 53 29 0a 0a  CHEMA_PRAGMAS)..
1870: 20 20 4e 41 4d 45 3a 20 69 6e 64 65 78 5f 78 69    NAME: index_xi
1880: 6e 66 6f 0a 20 20 54 59 50 45 3a 20 49 4e 44 45  nfo.  TYPE: INDE
1890: 58 5f 49 4e 46 4f 0a 20 20 41 52 47 3a 20 20 31  X_INFO.  ARG:  1
18a0: 0a 20 20 46 4c 41 47 3a 20 4e 65 65 64 53 63 68  .  FLAG: NeedSch
18b0: 65 6d 61 20 52 65 73 75 6c 74 31 20 53 63 68 65  ema Result1 Sche
18c0: 6d 61 4f 70 74 0a 20 20 43 4f 4c 53 3a 20 73 65  maOpt.  COLS: se
18d0: 71 6e 6f 20 63 69 64 20 6e 61 6d 65 20 64 65 73  qno cid name des
18e0: 63 20 63 6f 6c 6c 20 6b 65 79 0a 20 20 49 46 3a  c coll key.  IF:
18f0: 20 20 20 21 64 65 66 69 6e 65 64 28 53 51 4c 49     !defined(SQLI
1900: 54 45 5f 4f 4d 49 54 5f 53 43 48 45 4d 41 5f 50  TE_OMIT_SCHEMA_P
1910: 52 41 47 4d 41 53 29 0a 0a 20 20 4e 41 4d 45 3a  RAGMAS)..  NAME:
1920: 20 69 6e 64 65 78 5f 6c 69 73 74 0a 20 20 46 4c   index_list.  FL
1930: 41 47 3a 20 4e 65 65 64 53 63 68 65 6d 61 20 52  AG: NeedSchema R
1940: 65 73 75 6c 74 31 20 53 63 68 65 6d 61 4f 70 74  esult1 SchemaOpt
1950: 0a 20 20 43 4f 4c 53 3a 20 73 65 71 20 6e 61 6d  .  COLS: seq nam
1960: 65 20 75 6e 69 71 75 65 20 6f 72 69 67 69 6e 20  e unique origin 
1970: 70 61 72 74 69 61 6c 0a 20 20 49 46 3a 20 20 20  partial.  IF:   
1980: 21 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f  !defined(SQLITE_
1990: 4f 4d 49 54 5f 53 43 48 45 4d 41 5f 50 52 41 47  OMIT_SCHEMA_PRAG
19a0: 4d 41 53 29 0a 0a 20 20 4e 41 4d 45 3a 20 64 61  MAS)..  NAME: da
19b0: 74 61 62 61 73 65 5f 6c 69 73 74 0a 20 20 46 4c  tabase_list.  FL
19c0: 41 47 3a 20 4e 65 65 64 53 63 68 65 6d 61 20 52  AG: NeedSchema R
19d0: 65 73 75 6c 74 30 0a 20 20 43 4f 4c 53 3a 20 73  esult0.  COLS: s
19e0: 65 71 20 6e 61 6d 65 20 66 69 6c 65 0a 20 20 49  eq name file.  I
19f0: 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28 53 51  F:   !defined(SQ
1a00: 4c 49 54 45 5f 4f 4d 49 54 5f 53 43 48 45 4d 41  LITE_OMIT_SCHEMA
1a10: 5f 50 52 41 47 4d 41 53 29 0a 0a 20 20 4e 41 4d  _PRAGMAS)..  NAM
1a20: 45 3a 20 66 75 6e 63 74 69 6f 6e 5f 6c 69 73 74  E: function_list
1a30: 0a 20 20 46 4c 41 47 3a 20 52 65 73 75 6c 74 30  .  FLAG: Result0
1a40: 0a 20 20 43 4f 4c 53 3a 20 6e 61 6d 65 20 62 75  .  COLS: name bu
1a50: 69 6c 74 69 6e 0a 20 20 49 46 3a 20 20 20 21 64  iltin.  IF:   !d
1a60: 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d  efined(SQLITE_OM
1a70: 49 54 5f 53 43 48 45 4d 41 5f 50 52 41 47 4d 41  IT_SCHEMA_PRAGMA
1a80: 53 29 0a 20 20 49 46 3a 20 20 20 64 65 66 69 6e  S).  IF:   defin
1a90: 65 64 28 53 51 4c 49 54 45 5f 49 4e 54 52 4f 53  ed(SQLITE_INTROS
1aa0: 50 45 43 54 49 4f 4e 5f 50 52 41 47 4d 41 53 29  PECTION_PRAGMAS)
1ab0: 0a 0a 20 20 4e 41 4d 45 3a 20 6d 6f 64 75 6c 65  ..  NAME: module
1ac0: 5f 6c 69 73 74 0a 20 20 46 4c 41 47 3a 20 52 65  _list.  FLAG: Re
1ad0: 73 75 6c 74 30 0a 20 20 43 4f 4c 53 3a 20 6e 61  sult0.  COLS: na
1ae0: 6d 65 0a 20 20 49 46 3a 20 20 20 21 64 65 66 69  me.  IF:   !defi
1af0: 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  ned(SQLITE_OMIT_
1b00: 53 43 48 45 4d 41 5f 50 52 41 47 4d 41 53 29 0a  SCHEMA_PRAGMAS).
1b10: 20 20 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64    IF:   !defined
1b20: 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 56 49 52  (SQLITE_OMIT_VIR
1b30: 54 55 41 4c 54 41 42 4c 45 29 0a 20 20 49 46 3a  TUALTABLE).  IF:
1b40: 20 20 20 64 65 66 69 6e 65 64 28 53 51 4c 49 54     defined(SQLIT
1b50: 45 5f 49 4e 54 52 4f 53 50 45 43 54 49 4f 4e 5f  E_INTROSPECTION_
1b60: 50 52 41 47 4d 41 53 29 0a 0a 20 20 4e 41 4d 45  PRAGMAS)..  NAME
1b70: 3a 20 70 72 61 67 6d 61 5f 6c 69 73 74 0a 20 20  : pragma_list.  
1b80: 46 4c 41 47 3a 20 52 65 73 75 6c 74 30 0a 20 20  FLAG: Result0.  
1b90: 43 4f 4c 53 3a 20 6e 61 6d 65 0a 20 20 49 46 3a  COLS: name.  IF:
1ba0: 20 20 20 64 65 66 69 6e 65 64 28 53 51 4c 49 54     defined(SQLIT
1bb0: 45 5f 49 4e 54 52 4f 53 50 45 43 54 49 4f 4e 5f  E_INTROSPECTION_
1bc0: 50 52 41 47 4d 41 53 29 0a 0a 20 20 4e 41 4d 45  PRAGMAS)..  NAME
1bd0: 3a 20 63 6f 6c 6c 61 74 69 6f 6e 5f 6c 69 73 74  : collation_list
1be0: 0a 20 20 46 4c 41 47 3a 20 52 65 73 75 6c 74 30  .  FLAG: Result0
1bf0: 0a 20 20 43 4f 4c 53 3a 20 73 65 71 20 6e 61 6d  .  COLS: seq nam
1c00: 65 0a 20 20 49 46 3a 20 20 20 21 64 65 66 69 6e  e.  IF:   !defin
1c10: 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 53  ed(SQLITE_OMIT_S
1c20: 43 48 45 4d 41 5f 50 52 41 47 4d 41 53 29 0a 0a  CHEMA_PRAGMAS)..
1c30: 20 20 4e 41 4d 45 3a 20 66 6f 72 65 69 67 6e 5f    NAME: foreign_
1c40: 6b 65 79 5f 6c 69 73 74 0a 20 20 46 4c 41 47 3a  key_list.  FLAG:
1c50: 20 4e 65 65 64 53 63 68 65 6d 61 20 52 65 73 75   NeedSchema Resu
1c60: 6c 74 31 20 53 63 68 65 6d 61 4f 70 74 0a 20 20  lt1 SchemaOpt.  
1c70: 43 4f 4c 53 3a 20 69 64 20 73 65 71 20 74 61 62  COLS: id seq tab
1c80: 6c 65 20 66 72 6f 6d 20 74 6f 20 6f 6e 5f 75 70  le from to on_up
1c90: 64 61 74 65 20 6f 6e 5f 64 65 6c 65 74 65 20 6d  date on_delete m
1ca0: 61 74 63 68 0a 20 20 49 46 3a 20 20 20 21 64 65  atch.  IF:   !de
1cb0: 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49  fined(SQLITE_OMI
1cc0: 54 5f 46 4f 52 45 49 47 4e 5f 4b 45 59 29 0a 0a  T_FOREIGN_KEY)..
1cd0: 20 20 4e 41 4d 45 3a 20 66 6f 72 65 69 67 6e 5f    NAME: foreign_
1ce0: 6b 65 79 5f 63 68 65 63 6b 0a 20 20 46 4c 41 47  key_check.  FLAG
1cf0: 3a 20 4e 65 65 64 53 63 68 65 6d 61 20 52 65 73  : NeedSchema Res
1d00: 75 6c 74 30 0a 20 20 43 4f 4c 53 3a 20 74 61 62  ult0.  COLS: tab
1d10: 6c 65 20 72 6f 77 69 64 20 70 61 72 65 6e 74 20  le rowid parent 
1d20: 66 6b 69 64 0a 20 20 49 46 3a 20 20 20 21 64 65  fkid.  IF:   !de
1d30: 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49  fined(SQLITE_OMI
1d40: 54 5f 46 4f 52 45 49 47 4e 5f 4b 45 59 29 20 26  T_FOREIGN_KEY) &
1d50: 26 20 21 64 65 66 69 6e 65 64 28 53 51 4c 49 54  & !defined(SQLIT
1d60: 45 5f 4f 4d 49 54 5f 54 52 49 47 47 45 52 29 0a  E_OMIT_TRIGGER).
1d70: 0a 20 20 4e 41 4d 45 3a 20 70 61 72 73 65 72 5f  .  NAME: parser_
1d80: 74 72 61 63 65 0a 20 20 49 46 3a 20 20 20 64 65  trace.  IF:   de
1d90: 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 44 45 42  fined(SQLITE_DEB
1da0: 55 47 29 20 26 26 20 21 64 65 66 69 6e 65 64 28  UG) && !defined(
1db0: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 50 41 52 53  SQLITE_OMIT_PARS
1dc0: 45 52 5f 54 52 41 43 45 29 0a 0a 20 20 4e 41 4d  ER_TRACE)..  NAM
1dd0: 45 3a 20 63 61 73 65 5f 73 65 6e 73 69 74 69 76  E: case_sensitiv
1de0: 65 5f 6c 69 6b 65 0a 20 20 46 4c 41 47 3a 20 4e  e_like.  FLAG: N
1df0: 6f 43 6f 6c 75 6d 6e 73 0a 0a 20 20 4e 41 4d 45  oColumns..  NAME
1e00: 3a 20 69 6e 74 65 67 72 69 74 79 5f 63 68 65 63  : integrity_chec
1e10: 6b 0a 20 20 46 4c 41 47 3a 20 4e 65 65 64 53 63  k.  FLAG: NeedSc
1e20: 68 65 6d 61 20 52 65 73 75 6c 74 30 20 52 65 73  hema Result0 Res
1e30: 75 6c 74 31 0a 20 20 49 46 3a 20 20 20 21 64 65  ult1.  IF:   !de
1e40: 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49  fined(SQLITE_OMI
1e50: 54 5f 49 4e 54 45 47 52 49 54 59 5f 43 48 45 43  T_INTEGRITY_CHEC
1e60: 4b 29 0a 0a 20 20 4e 41 4d 45 3a 20 71 75 69 63  K)..  NAME: quic
1e70: 6b 5f 63 68 65 63 6b 0a 20 20 54 59 50 45 3a 20  k_check.  TYPE: 
1e80: 49 4e 54 45 47 52 49 54 59 5f 43 48 45 43 4b 0a  INTEGRITY_CHECK.
1e90: 20 20 46 4c 41 47 3a 20 4e 65 65 64 53 63 68 65    FLAG: NeedSche
1ea0: 6d 61 20 52 65 73 75 6c 74 30 20 52 65 73 75 6c  ma Result0 Resul
1eb0: 74 31 0a 20 20 49 46 3a 20 20 20 21 64 65 66 69  t1.  IF:   !defi
1ec0: 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  ned(SQLITE_OMIT_
1ed0: 49 4e 54 45 47 52 49 54 59 5f 43 48 45 43 4b 29  INTEGRITY_CHECK)
1ee0: 0a 0a 20 20 4e 41 4d 45 3a 20 65 6e 63 6f 64 69  ..  NAME: encodi
1ef0: 6e 67 0a 20 20 46 4c 41 47 3a 20 52 65 73 75 6c  ng.  FLAG: Resul
1f00: 74 30 20 4e 6f 43 6f 6c 75 6d 6e 73 31 0a 20 20  t0 NoColumns1.  
1f10: 49 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28 53  IF:   !defined(S
1f20: 51 4c 49 54 45 5f 4f 4d 49 54 5f 55 54 46 31 36  QLITE_OMIT_UTF16
1f30: 29 0a 0a 20 20 4e 41 4d 45 3a 20 73 63 68 65 6d  )..  NAME: schem
1f40: 61 5f 76 65 72 73 69 6f 6e 0a 20 20 54 59 50 45  a_version.  TYPE
1f50: 3a 20 48 45 41 44 45 52 5f 56 41 4c 55 45 0a 20  : HEADER_VALUE. 
1f60: 20 41 52 47 3a 20 20 42 54 52 45 45 5f 53 43 48   ARG:  BTREE_SCH
1f70: 45 4d 41 5f 56 45 52 53 49 4f 4e 0a 20 20 46 4c  EMA_VERSION.  FL
1f80: 41 47 3a 20 4e 6f 43 6f 6c 75 6d 6e 73 31 20 52  AG: NoColumns1 R
1f90: 65 73 75 6c 74 30 0a 20 20 49 46 3a 20 20 20 21  esult0.  IF:   !
1fa0: 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f  defined(SQLITE_O
1fb0: 4d 49 54 5f 53 43 48 45 4d 41 5f 56 45 52 53 49  MIT_SCHEMA_VERSI
1fc0: 4f 4e 5f 50 52 41 47 4d 41 53 29 0a 0a 20 20 4e  ON_PRAGMAS)..  N
1fd0: 41 4d 45 3a 20 75 73 65 72 5f 76 65 72 73 69 6f  AME: user_versio
1fe0: 6e 0a 20 20 54 59 50 45 3a 20 48 45 41 44 45 52  n.  TYPE: HEADER
1ff0: 5f 56 41 4c 55 45 0a 20 20 41 52 47 3a 20 20 42  _VALUE.  ARG:  B
2000: 54 52 45 45 5f 55 53 45 52 5f 56 45 52 53 49 4f  TREE_USER_VERSIO
2010: 4e 0a 20 20 46 4c 41 47 3a 20 4e 6f 43 6f 6c 75  N.  FLAG: NoColu
2020: 6d 6e 73 31 20 52 65 73 75 6c 74 30 0a 20 20 49  mns1 Result0.  I
2030: 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28 53 51  F:   !defined(SQ
2040: 4c 49 54 45 5f 4f 4d 49 54 5f 53 43 48 45 4d 41  LITE_OMIT_SCHEMA
2050: 5f 56 45 52 53 49 4f 4e 5f 50 52 41 47 4d 41 53  _VERSION_PRAGMAS
2060: 29 0a 0a 20 20 4e 41 4d 45 3a 20 64 61 74 61 5f  )..  NAME: data_
2070: 76 65 72 73 69 6f 6e 0a 20 20 54 59 50 45 3a 20  version.  TYPE: 
2080: 48 45 41 44 45 52 5f 56 41 4c 55 45 0a 20 20 41  HEADER_VALUE.  A
2090: 52 47 3a 20 20 42 54 52 45 45 5f 44 41 54 41 5f  RG:  BTREE_DATA_
20a0: 56 45 52 53 49 4f 4e 0a 20 20 46 4c 41 47 3a 20  VERSION.  FLAG: 
20b0: 52 65 61 64 4f 6e 6c 79 20 52 65 73 75 6c 74 30  ReadOnly Result0
20c0: 0a 20 20 49 46 3a 20 20 20 21 64 65 66 69 6e 65  .  IF:   !define
20d0: 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 53 43  d(SQLITE_OMIT_SC
20e0: 48 45 4d 41 5f 56 45 52 53 49 4f 4e 5f 50 52 41  HEMA_VERSION_PRA
20f0: 47 4d 41 53 29 0a 0a 20 20 4e 41 4d 45 3a 20 66  GMAS)..  NAME: f
2100: 72 65 65 6c 69 73 74 5f 63 6f 75 6e 74 0a 20 20  reelist_count.  
2110: 54 59 50 45 3a 20 48 45 41 44 45 52 5f 56 41 4c  TYPE: HEADER_VAL
2120: 55 45 0a 20 20 41 52 47 3a 20 20 42 54 52 45 45  UE.  ARG:  BTREE
2130: 5f 46 52 45 45 5f 50 41 47 45 5f 43 4f 55 4e 54  _FREE_PAGE_COUNT
2140: 0a 20 20 46 4c 41 47 3a 20 52 65 61 64 4f 6e 6c  .  FLAG: ReadOnl
2150: 79 20 52 65 73 75 6c 74 30 0a 20 20 49 46 3a 20  y Result0.  IF: 
2160: 20 20 21 64 65 66 69 6e 65 64 28 53 51 4c 49 54    !defined(SQLIT
2170: 45 5f 4f 4d 49 54 5f 53 43 48 45 4d 41 5f 56 45  E_OMIT_SCHEMA_VE
2180: 52 53 49 4f 4e 5f 50 52 41 47 4d 41 53 29 0a 0a  RSION_PRAGMAS)..
2190: 20 20 4e 41 4d 45 3a 20 61 70 70 6c 69 63 61 74    NAME: applicat
21a0: 69 6f 6e 5f 69 64 0a 20 20 54 59 50 45 3a 20 48  ion_id.  TYPE: H
21b0: 45 41 44 45 52 5f 56 41 4c 55 45 0a 20 20 41 52  EADER_VALUE.  AR
21c0: 47 3a 20 20 42 54 52 45 45 5f 41 50 50 4c 49 43  G:  BTREE_APPLIC
21d0: 41 54 49 4f 4e 5f 49 44 0a 20 20 46 4c 41 47 3a  ATION_ID.  FLAG:
21e0: 20 4e 6f 43 6f 6c 75 6d 6e 73 31 20 52 65 73 75   NoColumns1 Resu
21f0: 6c 74 30 0a 20 20 49 46 3a 20 20 20 21 64 65 66  lt0.  IF:   !def
2200: 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54  ined(SQLITE_OMIT
2210: 5f 53 43 48 45 4d 41 5f 56 45 52 53 49 4f 4e 5f  _SCHEMA_VERSION_
2220: 50 52 41 47 4d 41 53 29 0a 0a 20 20 4e 41 4d 45  PRAGMAS)..  NAME
2230: 3a 20 63 6f 6d 70 69 6c 65 5f 6f 70 74 69 6f 6e  : compile_option
2240: 73 0a 20 20 46 4c 41 47 3a 20 52 65 73 75 6c 74  s.  FLAG: Result
2250: 30 0a 20 20 49 46 3a 20 20 20 21 64 65 66 69 6e  0.  IF:   !defin
2260: 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 43  ed(SQLITE_OMIT_C
2270: 4f 4d 50 49 4c 45 4f 50 54 49 4f 4e 5f 44 49 41  OMPILEOPTION_DIA
2280: 47 53 29 0a 0a 20 20 4e 41 4d 45 3a 20 77 61 6c  GS)..  NAME: wal
2290: 5f 63 68 65 63 6b 70 6f 69 6e 74 0a 20 20 46 4c  _checkpoint.  FL
22a0: 41 47 3a 20 4e 65 65 64 53 63 68 65 6d 61 0a 20  AG: NeedSchema. 
22b0: 20 43 4f 4c 53 3a 20 62 75 73 79 20 6c 6f 67 20   COLS: busy log 
22c0: 63 68 65 63 6b 70 6f 69 6e 74 65 64 0a 20 20 49  checkpointed.  I
22d0: 46 3a 20 20 20 21 64 65 66 69 6e 65 64 28 53 51  F:   !defined(SQ
22e0: 4c 49 54 45 5f 4f 4d 49 54 5f 57 41 4c 29 0a 0a  LITE_OMIT_WAL)..
22f0: 20 20 4e 41 4d 45 3a 20 77 61 6c 5f 61 75 74 6f    NAME: wal_auto
2300: 63 68 65 63 6b 70 6f 69 6e 74 0a 20 20 49 46 3a  checkpoint.  IF:
2310: 20 20 20 21 64 65 66 69 6e 65 64 28 53 51 4c 49     !defined(SQLI
2320: 54 45 5f 4f 4d 49 54 5f 57 41 4c 29 0a 0a 20 20  TE_OMIT_WAL)..  
2330: 4e 41 4d 45 3a 20 73 68 72 69 6e 6b 5f 6d 65 6d  NAME: shrink_mem
2340: 6f 72 79 0a 20 20 46 4c 41 47 3a 20 4e 6f 43 6f  ory.  FLAG: NoCo
2350: 6c 75 6d 6e 73 0a 0a 20 20 4e 41 4d 45 3a 20 62  lumns..  NAME: b
2360: 75 73 79 5f 74 69 6d 65 6f 75 74 0a 20 20 46 4c  usy_timeout.  FL
2370: 41 47 3a 20 52 65 73 75 6c 74 30 0a 20 20 43 4f  AG: Result0.  CO
2380: 4c 53 3a 20 74 69 6d 65 6f 75 74 0a 0a 20 20 4e  LS: timeout..  N
2390: 41 4d 45 3a 20 6c 6f 63 6b 5f 73 74 61 74 75 73  AME: lock_status
23a0: 0a 20 20 46 4c 41 47 3a 20 52 65 73 75 6c 74 30  .  FLAG: Result0
23b0: 0a 20 20 43 4f 4c 53 3a 20 64 61 74 61 62 61 73  .  COLS: databas
23c0: 65 20 73 74 61 74 75 73 0a 20 20 49 46 3a 20 20  e status.  IF:  
23d0: 20 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f   defined(SQLITE_
23e0: 44 45 42 55 47 29 20 7c 7c 20 64 65 66 69 6e 65  DEBUG) || define
23f0: 64 28 53 51 4c 49 54 45 5f 54 45 53 54 29 0a 0a  d(SQLITE_TEST)..
2400: 20 20 4e 41 4d 45 3a 20 6b 65 79 0a 20 20 49 46    NAME: key.  IF
2410: 3a 20 20 20 64 65 66 69 6e 65 64 28 53 51 4c 49  :   defined(SQLI
2420: 54 45 5f 48 41 53 5f 43 4f 44 45 43 29 0a 0a 20  TE_HAS_CODEC).. 
2430: 20 4e 41 4d 45 3a 20 72 65 6b 65 79 0a 20 20 49   NAME: rekey.  I
2440: 46 3a 20 20 20 64 65 66 69 6e 65 64 28 53 51 4c  F:   defined(SQL
2450: 49 54 45 5f 48 41 53 5f 43 4f 44 45 43 29 0a 0a  ITE_HAS_CODEC)..
2460: 20 20 4e 41 4d 45 3a 20 68 65 78 6b 65 79 0a 20    NAME: hexkey. 
2470: 20 49 46 3a 20 20 20 64 65 66 69 6e 65 64 28 53   IF:   defined(S
2480: 51 4c 49 54 45 5f 48 41 53 5f 43 4f 44 45 43 29  QLITE_HAS_CODEC)
2490: 0a 0a 20 20 4e 41 4d 45 3a 20 68 65 78 72 65 6b  ..  NAME: hexrek
24a0: 65 79 0a 20 20 54 59 50 45 3a 20 48 45 58 4b 45  ey.  TYPE: HEXKE
24b0: 59 0a 20 20 49 46 3a 20 20 20 64 65 66 69 6e 65  Y.  IF:   define
24c0: 64 28 53 51 4c 49 54 45 5f 48 41 53 5f 43 4f 44  d(SQLITE_HAS_COD
24d0: 45 43 29 0a 0a 20 20 4e 41 4d 45 3a 20 61 63 74  EC)..  NAME: act
24e0: 69 76 61 74 65 5f 65 78 74 65 6e 73 69 6f 6e 73  ivate_extensions
24f0: 0a 20 20 49 46 3a 20 20 20 64 65 66 69 6e 65 64  .  IF:   defined
2500: 28 53 51 4c 49 54 45 5f 48 41 53 5f 43 4f 44 45  (SQLITE_HAS_CODE
2510: 43 29 20 7c 7c 20 64 65 66 69 6e 65 64 28 53 51  C) || defined(SQ
2520: 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 43 45 52 4f  LITE_ENABLE_CERO
2530: 44 29 0a 0a 20 20 4e 41 4d 45 3a 20 73 6f 66 74  D)..  NAME: soft
2540: 5f 68 65 61 70 5f 6c 69 6d 69 74 0a 20 20 46 4c  _heap_limit.  FL
2550: 41 47 3a 20 52 65 73 75 6c 74 30 0a 0a 20 20 4e  AG: Result0..  N
2560: 41 4d 45 3a 20 74 68 72 65 61 64 73 0a 20 20 46  AME: threads.  F
2570: 4c 41 47 3a 20 52 65 73 75 6c 74 30 0a 0a 20 20  LAG: Result0..  
2580: 4e 41 4d 45 3a 20 6f 70 74 69 6d 69 7a 65 0a 20  NAME: optimize. 
2590: 20 46 4c 41 47 3a 20 52 65 73 75 6c 74 31 20 4e   FLAG: Result1 N
25a0: 65 65 64 53 63 68 65 6d 61 0a 7d 0a 0a 23 20 4f  eedSchema.}..# O
25b0: 70 65 6e 20 74 68 65 20 6f 75 74 70 75 74 20 66  pen the output f
25c0: 69 6c 65 0a 23 0a 73 65 74 20 64 65 73 74 66 69  ile.#.set destfi
25d0: 6c 65 20 22 5b 66 69 6c 65 20 64 69 72 20 5b 66  le "[file dir [f
25e0: 69 6c 65 20 64 69 72 20 5b 66 69 6c 65 20 6e 6f  ile dir [file no
25f0: 72 6d 61 6c 20 24 61 72 67 76 30 5d 5d 5d 2f 73  rmal $argv0]]]/s
2600: 72 63 2f 70 72 61 67 6d 61 2e 68 22 0a 70 75 74  rc/pragma.h".put
2610: 73 20 22 4f 76 65 72 77 72 69 74 69 6e 67 20 24  s "Overwriting $
2620: 64 65 73 74 66 69 6c 65 20 77 69 74 68 20 6e 65  destfile with ne
2630: 77 20 70 72 61 67 6d 61 20 74 61 62 6c 65 2e 2e  w pragma table..
2640: 2e 22 0a 73 65 74 20 66 64 20 5b 6f 70 65 6e 20  .".set fd [open 
2650: 24 64 65 73 74 66 69 6c 65 20 77 62 5d 0a 70 75  $destfile wb].pu
2660: 74 73 20 24 66 64 20 7b 2f 2a 20 44 4f 20 4e 4f  ts $fd {/* DO NO
2670: 54 20 45 44 49 54 21 0a 2a 2a 20 54 68 69 73 20  T EDIT!.** This 
2680: 66 69 6c 65 20 69 73 20 61 75 74 6f 6d 61 74 69  file is automati
2690: 63 61 6c 6c 79 20 67 65 6e 65 72 61 74 65 64 20  cally generated 
26a0: 62 79 20 74 68 65 20 73 63 72 69 70 74 20 61 74  by the script at
26b0: 0a 2a 2a 20 2e 2e 2f 74 6f 6f 6c 2f 6d 6b 70 72  .** ../tool/mkpr
26c0: 61 67 6d 61 74 61 62 2e 74 63 6c 2e 20 20 54 6f  agmatab.tcl.  To
26d0: 20 75 70 64 61 74 65 20 74 68 65 20 73 65 74 20   update the set 
26e0: 6f 66 20 70 72 61 67 6d 61 73 2c 20 65 64 69 74  of pragmas, edit
26f0: 0a 2a 2a 20 74 68 61 74 20 73 63 72 69 70 74 20  .** that script 
2700: 61 6e 64 20 72 65 72 75 6e 20 69 74 2e 0a 2a 2f  and rerun it..*/
2710: 7d 0a 0a 23 20 50 61 72 73 65 20 74 68 65 20 50  }..# Parse the P
2720: 52 41 47 4d 41 20 74 61 62 6c 65 20 61 62 6f 76  RAGMA table abov
2730: 65 2e 0a 23 0a 73 65 74 20 6e 61 6d 65 20 7b 7d  e..#.set name {}
2740: 0a 73 65 74 20 74 79 70 65 20 7b 7d 0a 73 65 74  .set type {}.set
2750: 20 69 66 20 7b 7d 0a 73 65 74 20 66 6c 61 67 73   if {}.set flags
2760: 20 7b 7d 0a 73 65 74 20 63 6f 6c 73 20 7b 7d 0a   {}.set cols {}.
2770: 73 65 74 20 63 6f 6c 73 5f 6c 69 73 74 20 7b 7d  set cols_list {}
2780: 0a 73 65 74 20 61 72 67 20 30 0a 70 72 6f 63 20  .set arg 0.proc 
2790: 72 65 63 6f 72 64 5f 6f 6e 65 20 7b 7d 20 7b 0a  record_one {} {.
27a0: 20 20 67 6c 6f 62 61 6c 20 6e 61 6d 65 20 74 79    global name ty
27b0: 70 65 20 69 66 20 61 72 67 20 61 6c 6c 62 79 6e  pe if arg allbyn
27c0: 61 6d 65 20 74 79 70 65 62 79 69 66 20 66 6c 61  ame typebyif fla
27d0: 67 73 20 63 6f 6c 73 20 61 6c 6c 63 6f 6c 73 0a  gs cols allcols.
27e0: 20 20 67 6c 6f 62 61 6c 20 63 6f 6c 73 5f 6c 69    global cols_li
27f0: 73 74 20 63 6f 6c 55 73 65 64 42 79 0a 20 20 69  st colUsedBy.  i
2800: 66 20 7b 24 6e 61 6d 65 3d 3d 22 22 7d 20 72 65  f {$name==""} re
2810: 74 75 72 6e 0a 20 20 69 66 20 7b 24 63 6f 6c 73  turn.  if {$cols
2820: 21 3d 22 22 7d 20 7b 0a 20 20 20 20 69 66 20 7b  !=""} {.    if {
2830: 21 5b 69 6e 66 6f 20 65 78 69 73 74 73 20 61 6c  ![info exists al
2840: 6c 63 6f 6c 73 28 24 63 6f 6c 73 29 5d 7d 20 7b  lcols($cols)]} {
2850: 0a 20 20 20 20 20 20 6c 61 70 70 65 6e 64 20 63  .      lappend c
2860: 6f 6c 73 5f 6c 69 73 74 20 24 63 6f 6c 73 0a 20  ols_list $cols. 
2870: 20 20 20 20 20 73 65 74 20 61 6c 6c 63 6f 6c 73       set allcols
2880: 28 24 63 6f 6c 73 29 20 5b 6c 6c 65 6e 67 74 68  ($cols) [llength
2890: 20 24 63 6f 6c 73 5f 6c 69 73 74 5d 0a 20 20 20   $cols_list].   
28a0: 20 7d 0a 20 20 20 20 73 65 74 20 63 78 20 24 61   }.    set cx $a
28b0: 6c 6c 63 6f 6c 73 28 24 63 6f 6c 73 29 0a 20 20  llcols($cols).  
28c0: 20 20 6c 61 70 70 65 6e 64 20 63 6f 6c 55 73 65    lappend colUse
28d0: 64 42 79 28 24 63 6f 6c 73 29 20 24 6e 61 6d 65  dBy($cols) $name
28e0: 0a 20 20 7d 20 65 6c 73 65 20 7b 0a 20 20 20 20  .  } else {.    
28f0: 73 65 74 20 63 78 20 30 0a 20 20 7d 0a 20 20 73  set cx 0.  }.  s
2900: 65 74 20 61 6c 6c 62 79 6e 61 6d 65 28 24 6e 61  et allbyname($na
2910: 6d 65 29 20 5b 6c 69 73 74 20 24 74 79 70 65 20  me) [list $type 
2920: 24 61 72 67 20 24 69 66 20 24 66 6c 61 67 73 20  $arg $if $flags 
2930: 24 63 78 5d 0a 20 20 73 65 74 20 6e 61 6d 65 20  $cx].  set name 
2940: 7b 7d 0a 20 20 73 65 74 20 74 79 70 65 20 7b 7d  {}.  set type {}
2950: 0a 20 20 73 65 74 20 69 66 20 7b 7d 0a 20 20 73  .  set if {}.  s
2960: 65 74 20 66 6c 61 67 73 20 7b 7d 0a 20 20 73 65  et flags {}.  se
2970: 74 20 63 6f 6c 73 20 7b 7d 0a 20 20 73 65 74 20  t cols {}.  set 
2980: 61 72 67 20 30 0a 7d 0a 66 6f 72 65 61 63 68 20  arg 0.}.foreach 
2990: 6c 69 6e 65 20 5b 73 70 6c 69 74 20 24 70 72 61  line [split $pra
29a0: 67 6d 61 5f 64 65 66 20 5c 6e 5d 20 7b 0a 20 20  gma_def \n] {.  
29b0: 73 65 74 20 6c 69 6e 65 20 5b 73 74 72 69 6e 67  set line [string
29c0: 20 74 72 69 6d 20 24 6c 69 6e 65 5d 0a 20 20 69   trim $line].  i
29d0: 66 20 7b 24 6c 69 6e 65 3d 3d 22 22 7d 20 63 6f  f {$line==""} co
29e0: 6e 74 69 6e 75 65 0a 20 20 66 6f 72 65 61 63 68  ntinue.  foreach
29f0: 20 7b 69 64 20 76 61 6c 7d 20 5b 73 70 6c 69 74   {id val} [split
2a00: 20 24 6c 69 6e 65 20 3a 5d 20 62 72 65 61 6b 0a   $line :] break.
2a10: 20 20 73 65 74 20 76 61 6c 20 5b 73 74 72 69 6e    set val [strin
2a20: 67 20 74 72 69 6d 20 24 76 61 6c 5d 0a 20 20 69  g trim $val].  i
2a30: 66 20 7b 24 69 64 3d 3d 22 4e 41 4d 45 22 7d 20  f {$id=="NAME"} 
2a40: 7b 0a 20 20 20 20 72 65 63 6f 72 64 5f 6f 6e 65  {.    record_one
2a50: 20 20 20 20 0a 20 20 20 20 73 65 74 20 6e 61 6d      .    set nam
2a60: 65 20 24 76 61 6c 0a 20 20 20 20 73 65 74 20 74  e $val.    set t
2a70: 79 70 65 20 5b 73 74 72 69 6e 67 20 74 6f 75 70  ype [string toup
2a80: 70 65 72 20 24 76 61 6c 5d 0a 20 20 7d 20 65 6c  per $val].  } el
2a90: 73 65 69 66 20 7b 24 69 64 3d 3d 22 54 59 50 45  seif {$id=="TYPE
2aa0: 22 7d 20 7b 0a 20 20 20 20 73 65 74 20 74 79 70  "} {.    set typ
2ab0: 65 20 24 76 61 6c 0a 20 20 20 20 69 66 20 7b 24  e $val.    if {$
2ac0: 74 79 70 65 3d 3d 22 46 4c 41 47 22 7d 20 7b 0a  type=="FLAG"} {.
2ad0: 20 20 20 20 20 20 6c 61 70 70 65 6e 64 20 66 6c        lappend fl
2ae0: 61 67 73 20 52 65 73 75 6c 74 30 20 4e 6f 43 6f  ags Result0 NoCo
2af0: 6c 75 6d 6e 73 31 0a 20 20 20 20 7d 0a 20 20 7d  lumns1.    }.  }
2b00: 20 65 6c 73 65 69 66 20 7b 24 69 64 3d 3d 22 41   elseif {$id=="A
2b10: 52 47 22 7d 20 7b 0a 20 20 20 20 73 65 74 20 61  RG"} {.    set a
2b20: 72 67 20 24 76 61 6c 0a 20 20 7d 20 65 6c 73 65  rg $val.  } else
2b30: 69 66 20 7b 24 69 64 3d 3d 22 43 4f 4c 53 22 7d  if {$id=="COLS"}
2b40: 20 7b 0a 20 20 20 20 73 65 74 20 63 6f 6c 73 20   {.    set cols 
2b50: 24 76 61 6c 0a 20 20 7d 20 65 6c 73 65 69 66 20  $val.  } elseif 
2b60: 7b 24 69 64 3d 3d 22 49 46 22 7d 20 7b 0a 20 20  {$id=="IF"} {.  
2b70: 20 20 6c 61 70 70 65 6e 64 20 69 66 20 24 76 61    lappend if $va
2b80: 6c 0a 20 20 7d 20 65 6c 73 65 69 66 20 7b 24 69  l.  } elseif {$i
2b90: 64 3d 3d 22 46 4c 41 47 22 7d 20 7b 0a 20 20 20  d=="FLAG"} {.   
2ba0: 20 66 6f 72 65 61 63 68 20 74 65 72 6d 20 5b 73   foreach term [s
2bb0: 70 6c 69 74 20 24 76 61 6c 5d 20 7b 0a 20 20 20  plit $val] {.   
2bc0: 20 20 20 6c 61 70 70 65 6e 64 20 66 6c 61 67 73     lappend flags
2bd0: 20 24 74 65 72 6d 0a 20 20 20 20 20 20 73 65 74   $term.      set
2be0: 20 61 6c 6c 66 6c 61 67 73 28 24 74 65 72 6d 29   allflags($term)
2bf0: 20 31 0a 20 20 20 20 7d 0a 20 20 7d 20 65 6c 73   1.    }.  } els
2c00: 65 20 7b 0a 20 20 20 20 65 72 72 6f 72 20 22 62  e {.    error "b
2c10: 61 64 20 70 72 61 67 6d 61 5f 64 65 66 20 6c 69  ad pragma_def li
2c20: 6e 65 3a 20 24 6c 69 6e 65 22 0a 20 20 7d 0a 7d  ne: $line".  }.}
2c30: 0a 72 65 63 6f 72 64 5f 6f 6e 65 0a 73 65 74 20  .record_one.set 
2c40: 61 6c 6c 6e 61 6d 65 73 20 5b 6c 73 6f 72 74 20  allnames [lsort 
2c50: 5b 61 72 72 61 79 20 6e 61 6d 65 73 20 61 6c 6c  [array names all
2c60: 62 79 6e 61 6d 65 5d 5d 0a 0a 23 20 47 65 6e 65  byname]]..# Gene
2c70: 72 61 74 65 20 23 64 65 66 69 6e 65 73 20 66 6f  rate #defines fo
2c80: 72 20 61 6c 6c 20 70 72 61 67 6d 61 20 74 79 70  r all pragma typ
2c90: 65 20 6e 61 6d 65 73 2e 20 20 47 72 6f 75 70 20  e names.  Group 
2ca0: 74 68 65 20 70 72 61 67 6d 61 73 20 74 68 61 74  the pragmas that
2cb0: 20 61 72 65 0a 23 20 6f 6d 69 74 20 69 6e 20 64   are.# omit in d
2cc0: 65 66 61 75 6c 74 20 62 75 69 6c 64 73 20 28 64  efault builds (d
2cd0: 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 44 45  efined(SQLITE_DE
2ce0: 42 55 47 29 20 61 6e 64 20 64 65 66 69 6e 65 64  BUG) and defined
2cf0: 28 53 51 4c 49 54 45 5f 48 41 53 5f 43 4f 44 45  (SQLITE_HAS_CODE
2d00: 43 29 29 0a 23 20 61 74 20 74 68 65 20 65 6e 64  C)).# at the end
2d10: 2e 0a 23 0a 70 75 74 73 20 24 66 64 20 22 5c 6e  ..#.puts $fd "\n
2d20: 2f 2a 20 54 68 65 20 76 61 72 69 6f 75 73 20 70  /* The various p
2d30: 72 61 67 6d 61 20 74 79 70 65 73 20 2a 2f 22 0a  ragma types */".
2d40: 73 65 74 20 70 6e 75 6d 20 30 0a 66 6f 72 65 61  set pnum 0.forea
2d50: 63 68 20 6e 61 6d 65 20 24 61 6c 6c 6e 61 6d 65  ch name $allname
2d60: 73 20 7b 0a 20 20 73 65 74 20 74 79 70 65 20 5b  s {.  set type [
2d70: 6c 69 6e 64 65 78 20 24 61 6c 6c 62 79 6e 61 6d  lindex $allbynam
2d80: 65 28 24 6e 61 6d 65 29 20 30 5d 0a 20 20 69 66  e($name) 0].  if
2d90: 20 7b 5b 69 6e 66 6f 20 65 78 69 73 74 73 20 73   {[info exists s
2da0: 65 65 6e 74 79 70 65 28 24 74 79 70 65 29 5d 7d  eentype($type)]}
2db0: 20 63 6f 6e 74 69 6e 75 65 0a 20 20 73 65 74 20   continue.  set 
2dc0: 69 66 20 5b 6c 69 6e 64 65 78 20 24 61 6c 6c 62  if [lindex $allb
2dd0: 79 6e 61 6d 65 28 24 6e 61 6d 65 29 20 32 5d 0a  yname($name) 2].
2de0: 20 20 69 66 20 7b 5b 72 65 67 65 78 70 20 53 51    if {[regexp SQ
2df0: 4c 49 54 45 5f 44 45 42 55 47 20 24 69 66 5d 20  LITE_DEBUG $if] 
2e00: 7c 7c 20 5b 72 65 67 65 78 70 20 53 51 4c 49 54  || [regexp SQLIT
2e10: 45 5f 48 41 53 5f 43 4f 44 45 43 20 24 69 66 5d  E_HAS_CODEC $if]
2e20: 7d 20 63 6f 6e 74 69 6e 75 65 0a 20 20 73 65 74  } continue.  set
2e30: 20 73 65 65 6e 74 79 70 65 28 24 74 79 70 65 29   seentype($type)
2e40: 20 31 0a 20 20 70 75 74 73 20 24 66 64 20 5b 66   1.  puts $fd [f
2e50: 6f 72 6d 61 74 20 7b 23 64 65 66 69 6e 65 20 25  ormat {#define %
2e60: 2d 33 35 73 20 25 34 64 7d 20 50 72 61 67 54 79  -35s %4d} PragTy
2e70: 70 5f 24 74 79 70 65 20 24 70 6e 75 6d 5d 0a 20  p_$type $pnum]. 
2e80: 20 69 6e 63 72 20 70 6e 75 6d 0a 7d 0a 66 6f 72   incr pnum.}.for
2e90: 65 61 63 68 20 6e 61 6d 65 20 24 61 6c 6c 6e 61  each name $allna
2ea0: 6d 65 73 20 7b 0a 20 20 73 65 74 20 74 79 70 65  mes {.  set type
2eb0: 20 5b 6c 69 6e 64 65 78 20 24 61 6c 6c 62 79 6e   [lindex $allbyn
2ec0: 61 6d 65 28 24 6e 61 6d 65 29 20 30 5d 0a 20 20  ame($name) 0].  
2ed0: 69 66 20 7b 5b 69 6e 66 6f 20 65 78 69 73 74 73  if {[info exists
2ee0: 20 73 65 65 6e 74 79 70 65 28 24 74 79 70 65 29   seentype($type)
2ef0: 5d 7d 20 63 6f 6e 74 69 6e 75 65 0a 20 20 73 65  ]} continue.  se
2f00: 74 20 69 66 20 5b 6c 69 6e 64 65 78 20 24 61 6c  t if [lindex $al
2f10: 6c 62 79 6e 61 6d 65 28 24 6e 61 6d 65 29 20 32  lbyname($name) 2
2f20: 5d 0a 20 20 69 66 20 7b 5b 72 65 67 65 78 70 20  ].  if {[regexp 
2f30: 53 51 4c 49 54 45 5f 44 45 42 55 47 20 24 69 66  SQLITE_DEBUG $if
2f40: 5d 7d 20 63 6f 6e 74 69 6e 75 65 0a 20 20 73 65  ]} continue.  se
2f50: 74 20 73 65 65 6e 74 79 70 65 28 24 74 79 70 65  t seentype($type
2f60: 29 20 31 0a 20 20 70 75 74 73 20 24 66 64 20 5b  ) 1.  puts $fd [
2f70: 66 6f 72 6d 61 74 20 7b 23 64 65 66 69 6e 65 20  format {#define 
2f80: 25 2d 33 35 73 20 25 34 64 7d 20 50 72 61 67 54  %-35s %4d} PragT
2f90: 79 70 5f 24 74 79 70 65 20 24 70 6e 75 6d 5d 0a  yp_$type $pnum].
2fa0: 20 20 69 6e 63 72 20 70 6e 75 6d 0a 7d 0a 66 6f    incr pnum.}.fo
2fb0: 72 65 61 63 68 20 6e 61 6d 65 20 24 61 6c 6c 6e  reach name $alln
2fc0: 61 6d 65 73 20 7b 0a 20 20 73 65 74 20 74 79 70  ames {.  set typ
2fd0: 65 20 5b 6c 69 6e 64 65 78 20 24 61 6c 6c 62 79  e [lindex $allby
2fe0: 6e 61 6d 65 28 24 6e 61 6d 65 29 20 30 5d 0a 20  name($name) 0]. 
2ff0: 20 69 66 20 7b 5b 69 6e 66 6f 20 65 78 69 73 74   if {[info exist
3000: 73 20 73 65 65 6e 74 79 70 65 28 24 74 79 70 65  s seentype($type
3010: 29 5d 7d 20 63 6f 6e 74 69 6e 75 65 0a 20 20 73  )]} continue.  s
3020: 65 74 20 73 65 65 6e 74 79 70 65 28 24 74 79 70  et seentype($typ
3030: 65 29 20 31 0a 20 20 70 75 74 73 20 24 66 64 20  e) 1.  puts $fd 
3040: 5b 66 6f 72 6d 61 74 20 7b 23 64 65 66 69 6e 65  [format {#define
3050: 20 25 2d 33 35 73 20 25 34 64 7d 20 50 72 61 67   %-35s %4d} Prag
3060: 54 79 70 5f 24 74 79 70 65 20 24 70 6e 75 6d 5d  Typ_$type $pnum]
3070: 0a 20 20 69 6e 63 72 20 70 6e 75 6d 0a 7d 0a 0a  .  incr pnum.}..
3080: 23 20 47 65 6e 65 72 61 74 65 20 23 64 65 66 69  # Generate #defi
3090: 6e 65 73 20 66 6f 72 20 66 6c 61 67 73 0a 23 0a  nes for flags.#.
30a0: 70 75 74 73 20 24 66 64 20 22 5c 6e 2f 2a 20 50  puts $fd "\n/* P
30b0: 72 6f 70 65 72 74 79 20 66 6c 61 67 73 20 61 73  roperty flags as
30c0: 73 6f 63 69 61 74 65 64 20 77 69 74 68 20 76 61  sociated with va
30d0: 72 69 6f 75 73 20 70 72 61 67 6d 61 2e 20 2a 2f  rious pragma. */
30e0: 22 0a 73 65 74 20 66 76 20 31 0a 66 6f 72 65 61  ".set fv 1.forea
30f0: 63 68 20 66 20 5b 6c 73 6f 72 74 20 5b 61 72 72  ch f [lsort [arr
3100: 61 79 20 6e 61 6d 65 73 20 61 6c 6c 66 6c 61 67  ay names allflag
3110: 73 5d 5d 20 7b 0a 20 20 70 75 74 73 20 24 66 64  s]] {.  puts $fd
3120: 20 5b 66 6f 72 6d 61 74 20 7b 23 64 65 66 69 6e   [format {#defin
3130: 65 20 50 72 61 67 46 6c 67 5f 25 2d 31 30 73 20  e PragFlg_%-10s 
3140: 30 78 25 30 32 78 20 2f 2a 20 25 73 20 2a 2f 7d  0x%02x /* %s */}
3150: 20 5c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20   \.             
3160: 24 66 20 24 66 76 20 24 66 6c 61 67 4d 65 61 6e  $f $fv $flagMean
3170: 69 6e 67 28 24 66 29 5d 0a 20 20 73 65 74 20 66  ing($f)].  set f
3180: 76 20 5b 65 78 70 72 20 7b 24 66 76 2a 32 7d 5d  v [expr {$fv*2}]
3190: 0a 7d 0a 0a 23 20 47 65 6e 65 72 61 74 65 20 74  .}..# Generate t
31a0: 68 65 20 61 72 72 61 79 20 6f 66 20 63 6f 6c 75  he array of colu
31b0: 6d 6e 20 6e 61 6d 65 73 20 75 73 65 64 20 62 79  mn names used by
31c0: 20 70 72 61 67 6d 61 73 20 74 68 61 74 20 61 63   pragmas that ac
31d0: 74 20 6c 69 6b 65 0a 23 20 71 75 65 72 69 65 73  t like.# queries
31e0: 2e 0a 23 0a 70 75 74 73 20 24 66 64 20 22 5c 6e  ..#.puts $fd "\n
31f0: 2f 2a 20 4e 61 6d 65 73 20 6f 66 20 63 6f 6c 75  /* Names of colu
3200: 6d 6e 73 20 66 6f 72 20 70 72 61 67 6d 61 73 20  mns for pragmas 
3210: 74 68 61 74 20 72 65 74 75 72 6e 20 6d 75 6c 74  that return mult
3220: 69 2d 63 6f 6c 75 6d 6e 20 72 65 73 75 6c 74 22  i-column result"
3230: 0a 70 75 74 73 20 24 66 64 20 22 2a 2a 20 6f 72  .puts $fd "** or
3240: 20 74 68 61 74 20 72 65 74 75 72 6e 20 73 69 6e   that return sin
3250: 67 6c 65 2d 63 6f 6c 75 6d 6e 20 72 65 73 75 6c  gle-column resul
3260: 74 73 20 77 68 65 72 65 20 74 68 65 20 6e 61 6d  ts where the nam
3270: 65 20 6f 66 20 74 68 65 22 0a 70 75 74 73 20 24  e of the".puts $
3280: 66 64 20 22 2a 2a 20 72 65 73 75 6c 74 20 63 6f  fd "** result co
3290: 6c 75 6d 6e 20 69 73 20 64 69 66 66 65 72 65 6e  lumn is differen
32a0: 74 20 66 72 6f 6d 20 74 68 65 20 6e 61 6d 65 20  t from the name 
32b0: 6f 66 20 74 68 65 20 70 72 61 67 6d 61 5c 6e 2a  of the pragma\n*
32c0: 2f 22 0a 70 75 74 73 20 24 66 64 20 22 73 74 61  /".puts $fd "sta
32d0: 74 69 63 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  tic const char *
32e0: 63 6f 6e 73 74 20 70 72 61 67 43 4e 61 6d 65 5c  const pragCName\
32f0: 5b 5c 5d 20 3d 20 7b 22 0a 73 65 74 20 6f 66 66  [\] = {".set off
3300: 73 65 74 20 30 0a 66 6f 72 65 61 63 68 20 63 6f  set 0.foreach co
3310: 6c 73 20 24 63 6f 6c 73 5f 6c 69 73 74 20 7b 0a  ls $cols_list {.
3320: 20 20 73 65 74 20 63 6f 6c 73 5f 6f 66 66 73 65    set cols_offse
3330: 74 28 24 61 6c 6c 63 6f 6c 73 28 24 63 6f 6c 73  t($allcols($cols
3340: 29 29 20 24 6f 66 66 73 65 74 0a 20 20 73 65 74  )) $offset.  set
3350: 20 75 62 20 22 20 2f 2a 20 55 73 65 64 20 62 79   ub " /* Used by
3360: 3a 20 24 63 6f 6c 55 73 65 64 42 79 28 24 63 6f  : $colUsedBy($co
3370: 6c 73 29 20 2a 2f 22 0a 20 20 66 6f 72 65 61 63  ls) */".  foreac
3380: 68 20 63 20 24 63 6f 6c 73 20 7b 0a 20 20 20 20  h c $cols {.    
3390: 70 75 74 73 20 24 66 64 20 5b 66 6f 72 6d 61 74  puts $fd [format
33a0: 20 22 20 20 2f 2a 20 25 33 64 20 2a 2f 20 25 2d   "  /* %3d */ %-
33b0: 31 34 73 25 73 22 20 24 6f 66 66 73 65 74 20 5c  14s%s" $offset \
33c0: 22 24 63 5c 22 2c 20 24 75 62 5d 0a 20 20 20 20  "$c\", $ub].    
33d0: 73 65 74 20 75 62 20 22 22 0a 20 20 20 20 69 6e  set ub "".    in
33e0: 63 72 20 6f 66 66 73 65 74 0a 20 20 7d 0a 7d 0a  cr offset.  }.}.
33f0: 70 75 74 73 20 24 66 64 20 22 5c 31 37 35 3b 22  puts $fd "\175;"
3400: 0a 0a 23 20 47 65 6e 65 72 61 74 65 20 74 68 65  ..# Generate the
3410: 20 6c 6f 6f 6b 75 70 20 74 61 62 6c 65 0a 23 0a   lookup table.#.
3420: 70 75 74 73 20 24 66 64 20 22 5c 6e 2f 2a 20 44  puts $fd "\n/* D
3430: 65 66 69 6e 69 74 69 6f 6e 73 20 6f 66 20 61 6c  efinitions of al
3440: 6c 20 62 75 69 6c 74 2d 69 6e 20 70 72 61 67 6d  l built-in pragm
3450: 61 73 20 2a 2f 22 0a 70 75 74 73 20 24 66 64 20  as */".puts $fd 
3460: 22 74 79 70 65 64 65 66 20 73 74 72 75 63 74 20  "typedef struct 
3470: 50 72 61 67 6d 61 4e 61 6d 65 20 5c 31 37 33 22  PragmaName \173"
3480: 0a 70 75 74 73 20 24 66 64 20 22 20 20 63 6f 6e  .puts $fd "  con
3490: 73 74 20 63 68 61 72 20 2a 63 6f 6e 73 74 20 7a  st char *const z
34a0: 4e 61 6d 65 3b 20 2f 2a 20 4e 61 6d 65 20 6f 66  Name; /* Name of
34b0: 20 70 72 61 67 6d 61 20 2a 2f 22 0a 70 75 74 73   pragma */".puts
34c0: 20 24 66 64 20 22 20 20 75 38 20 65 50 72 61 67   $fd "  u8 ePrag
34d0: 54 79 70 3b 20 20 20 20 20 20 20 20 20 20 20 20  Typ;            
34e0: 20 2f 2a 20 50 72 61 67 54 79 70 5f 58 58 58 20   /* PragTyp_XXX 
34f0: 76 61 6c 75 65 20 2a 2f 22 0a 70 75 74 73 20 24  value */".puts $
3500: 66 64 20 22 20 20 75 38 20 6d 50 72 61 67 46 6c  fd "  u8 mPragFl
3510: 67 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  g;             /
3520: 2a 20 5a 65 72 6f 20 6f 72 20 6d 6f 72 65 20 50  * Zero or more P
3530: 72 61 67 46 6c 67 5f 58 58 58 20 76 61 6c 75 65  ragFlg_XXX value
3540: 73 20 2a 2f 22 0a 70 75 74 73 20 24 66 64 20 7b  s */".puts $fd {
3550: 20 20 75 38 20 69 50 72 61 67 43 4e 61 6d 65 3b    u8 iPragCName;
3560: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 53 74             /* St
3570: 61 72 74 20 6f 66 20 63 6f 6c 75 6d 6e 20 6e 61  art of column na
3580: 6d 65 73 20 69 6e 20 70 72 61 67 43 4e 61 6d 65  mes in pragCName
3590: 5b 5d 20 2a 2f 7d 0a 70 75 74 73 20 24 66 64 20  [] */}.puts $fd 
35a0: 22 20 20 75 38 20 6e 50 72 61 67 43 4e 61 6d 65  "  u8 nPragCName
35b0: 3b 20 20 20 20 20 20 20 20 20 20 5c 0a 2f 2a 20  ;          \./* 
35c0: 4e 75 6d 20 6f 66 20 63 6f 6c 20 6e 61 6d 65 73  Num of col names
35d0: 2e 20 30 20 6d 65 61 6e 73 20 75 73 65 20 70 72  . 0 means use pr
35e0: 61 67 6d 61 20 6e 61 6d 65 20 2a 2f 22 0a 70 75  agma name */".pu
35f0: 74 73 20 24 66 64 20 22 20 20 75 33 32 20 69 41  ts $fd "  u32 iA
3600: 72 67 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  rg;             
3610: 20 20 20 2f 2a 20 45 78 74 72 61 20 61 72 67 75     /* Extra argu
3620: 6d 65 6e 74 20 2a 2f 22 0a 70 75 74 73 20 24 66  ment */".puts $f
3630: 64 20 22 5c 31 37 35 20 50 72 61 67 6d 61 4e 61  d "\175 PragmaNa
3640: 6d 65 3b 22 0a 70 75 74 73 20 24 66 64 20 22 73  me;".puts $fd "s
3650: 74 61 74 69 63 20 63 6f 6e 73 74 20 50 72 61 67  tatic const Prag
3660: 6d 61 4e 61 6d 65 20 61 50 72 61 67 6d 61 4e 61  maName aPragmaNa
3670: 6d 65 5c 5b 5c 5d 20 3d 20 5c 31 37 33 22 0a 0a  me\[\] = \173"..
3680: 73 65 74 20 63 75 72 72 65 6e 74 5f 69 66 20 7b  set current_if {
3690: 7d 0a 73 65 74 20 73 70 61 63 65 72 20 5b 66 6f  }.set spacer [fo
36a0: 72 6d 61 74 20 7b 20 20 20 20 25 32 36 73 20 7d  rmat {    %26s }
36b0: 20 7b 7d 5d 0a 66 6f 72 65 61 63 68 20 6e 61 6d   {}].foreach nam
36c0: 65 20 24 61 6c 6c 6e 61 6d 65 73 20 7b 0a 20 20  e $allnames {.  
36d0: 66 6f 72 65 61 63 68 20 7b 74 79 70 65 20 61 72  foreach {type ar
36e0: 67 20 69 66 20 66 6c 61 67 20 63 78 7d 20 24 61  g if flag cx} $a
36f0: 6c 6c 62 79 6e 61 6d 65 28 24 6e 61 6d 65 29 20  llbyname($name) 
3700: 62 72 65 61 6b 0a 20 20 69 66 20 7b 24 63 78 3d  break.  if {$cx=
3710: 3d 30 7d 20 7b 0a 20 20 20 20 73 65 74 20 63 79  =0} {.    set cy
3720: 20 30 0a 20 20 20 20 73 65 74 20 6e 78 20 30 0a   0.    set nx 0.
3730: 20 20 7d 20 65 6c 73 65 20 7b 0a 20 20 20 20 73    } else {.    s
3740: 65 74 20 63 79 20 24 63 6f 6c 73 5f 6f 66 66 73  et cy $cols_offs
3750: 65 74 28 24 63 78 29 0a 20 20 20 20 73 65 74 20  et($cx).    set 
3760: 6e 78 20 5b 6c 6c 65 6e 67 74 68 20 5b 6c 69 6e  nx [llength [lin
3770: 64 65 78 20 24 63 6f 6c 73 5f 6c 69 73 74 20 5b  dex $cols_list [
3780: 65 78 70 72 20 7b 24 63 78 2d 31 7d 5d 5d 5d 0a  expr {$cx-1}]]].
3790: 20 20 7d 0a 20 20 69 66 20 7b 24 69 66 21 3d 24    }.  if {$if!=$
37a0: 63 75 72 72 65 6e 74 5f 69 66 7d 20 7b 0a 20 20  current_if} {.  
37b0: 20 20 69 66 20 7b 24 63 75 72 72 65 6e 74 5f 69    if {$current_i
37c0: 66 21 3d 22 22 7d 20 7b 0a 20 20 20 20 20 20 66  f!=""} {.      f
37d0: 6f 72 65 61 63 68 20 74 68 69 73 5f 69 66 20 24  oreach this_if $
37e0: 63 75 72 72 65 6e 74 5f 69 66 20 7b 0a 20 20 20  current_if {.   
37f0: 20 20 20 20 20 70 75 74 73 20 24 66 64 20 22 23       puts $fd "#
3800: 65 6e 64 69 66 22 0a 20 20 20 20 20 20 7d 0a 20  endif".      }. 
3810: 20 20 20 7d 0a 20 20 20 20 73 65 74 20 63 75 72     }.    set cur
3820: 72 65 6e 74 5f 69 66 20 24 69 66 0a 20 20 20 20  rent_if $if.    
3830: 69 66 20 7b 24 63 75 72 72 65 6e 74 5f 69 66 21  if {$current_if!
3840: 3d 22 22 7d 20 7b 0a 20 20 20 20 20 20 66 6f 72  =""} {.      for
3850: 65 61 63 68 20 74 68 69 73 5f 69 66 20 24 63 75  each this_if $cu
3860: 72 72 65 6e 74 5f 69 66 20 7b 0a 20 20 20 20 20  rrent_if {.     
3870: 20 20 20 70 75 74 73 20 24 66 64 20 22 23 69 66     puts $fd "#if
3880: 20 24 74 68 69 73 5f 69 66 22 0a 20 20 20 20 20   $this_if".     
3890: 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 73   }.    }.  }.  s
38a0: 65 74 20 74 79 70 65 78 20 5b 66 6f 72 6d 61 74  et typex [format
38b0: 20 50 72 61 67 54 79 70 5f 25 2d 32 33 73 20 24   PragTyp_%-23s $
38c0: 74 79 70 65 2c 5d 0a 20 20 69 66 20 7b 24 66 6c  type,].  if {$fl
38d0: 61 67 3d 3d 22 22 7d 20 7b 0a 20 20 20 20 73 65  ag==""} {.    se
38e0: 74 20 66 6c 61 67 78 20 22 30 22 0a 20 20 7d 20  t flagx "0".  } 
38f0: 65 6c 73 65 20 7b 0a 20 20 20 20 73 65 74 20 66  else {.    set f
3900: 6c 61 67 78 20 50 72 61 67 46 6c 67 5f 5b 6a 6f  lagx PragFlg_[jo
3910: 69 6e 20 24 66 6c 61 67 20 7b 7c 50 72 61 67 46  in $flag {|PragF
3920: 6c 67 5f 7d 5d 0a 20 20 7d 0a 20 20 70 75 74 73  lg_}].  }.  puts
3930: 20 24 66 64 20 22 20 5c 31 37 33 2f 2a 20 7a 4e   $fd " \173/* zN
3940: 61 6d 65 3a 20 20 20 20 20 2a 2f 20 5c 22 24 6e  ame:     */ \"$n
3950: 61 6d 65 5c 22 2c 22 0a 20 20 70 75 74 73 20 24  ame\",".  puts $
3960: 66 64 20 22 20 20 2f 2a 20 65 50 72 61 67 54 79  fd "  /* ePragTy
3970: 70 3a 20 20 2a 2f 20 50 72 61 67 54 79 70 5f 24  p:  */ PragTyp_$
3980: 74 79 70 65 2c 22 0a 20 20 70 75 74 73 20 24 66  type,".  puts $f
3990: 64 20 22 20 20 2f 2a 20 65 50 72 61 67 46 6c 67  d "  /* ePragFlg
39a0: 3a 20 20 2a 2f 20 24 66 6c 61 67 78 2c 22 0a 20  :  */ $flagx,". 
39b0: 20 70 75 74 73 20 24 66 64 20 22 20 20 2f 2a 20   puts $fd "  /* 
39c0: 43 6f 6c 4e 61 6d 65 73 3a 20 20 2a 2f 20 24 63  ColNames:  */ $c
39d0: 79 2c 20 24 6e 78 2c 22 0a 20 20 70 75 74 73 20  y, $nx,".  puts 
39e0: 24 66 64 20 22 20 20 2f 2a 20 69 41 72 67 3a 20  $fd "  /* iArg: 
39f0: 20 20 20 20 20 2a 2f 20 24 61 72 67 20 5c 31 37       */ $arg \17
3a00: 35 2c 22 0a 7d 0a 69 66 20 7b 24 63 75 72 72 65  5,".}.if {$curre
3a10: 6e 74 5f 69 66 21 3d 22 22 7d 20 7b 0a 20 20 66  nt_if!=""} {.  f
3a20: 6f 72 65 61 63 68 20 74 68 69 73 5f 69 66 20 24  oreach this_if $
3a30: 63 75 72 72 65 6e 74 5f 69 66 20 7b 0a 20 20 20  current_if {.   
3a40: 20 70 75 74 73 20 24 66 64 20 22 23 65 6e 64 69   puts $fd "#endi
3a50: 66 22 0a 20 20 7d 0a 7d 0a 70 75 74 73 20 24 66  f".  }.}.puts $f
3a60: 64 20 22 5c 31 37 35 3b 22 0a 0a 23 20 63 6f 75  d "\175;"..# cou
3a70: 6e 74 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66  nt the number of
3a80: 20 70 72 61 67 6d 61 73 2c 20 66 6f 72 20 69 6e   pragmas, for in
3a90: 66 6f 72 6d 61 74 69 6f 6e 20 70 75 72 70 6f 73  formation purpos
3aa0: 65 73 0a 23 0a 73 65 74 20 61 6c 6c 63 6e 74 20  es.#.set allcnt 
3ab0: 30 0a 73 65 74 20 64 66 6c 74 63 6e 74 20 30 0a  0.set dfltcnt 0.
3ac0: 66 6f 72 65 61 63 68 20 6e 61 6d 65 20 24 61 6c  foreach name $al
3ad0: 6c 6e 61 6d 65 73 20 7b 0a 20 20 69 6e 63 72 20  lnames {.  incr 
3ae0: 61 6c 6c 63 6e 74 0a 20 20 73 65 74 20 69 66 20  allcnt.  set if 
3af0: 5b 6c 69 6e 64 65 78 20 24 61 6c 6c 62 79 6e 61  [lindex $allbyna
3b00: 6d 65 28 24 6e 61 6d 65 29 20 32 5d 0a 20 20 69  me($name) 2].  i
3b10: 66 20 7b 5b 72 65 67 65 78 70 20 7b 5e 64 65 66  f {[regexp {^def
3b20: 69 6e 65 64 7d 20 24 69 66 5d 20 7c 7c 20 5b 72  ined} $if] || [r
3b30: 65 67 65 78 70 20 7b 5b 5e 21 5d 64 65 66 69 6e  egexp {[^!]defin
3b40: 65 64 7d 20 24 69 66 5d 7d 20 63 6f 6e 74 69 6e  ed} $if]} contin
3b50: 75 65 0a 20 20 69 6e 63 72 20 64 66 6c 74 63 6e  ue.  incr dfltcn
3b60: 74 0a 7d 0a 70 75 74 73 20 24 66 64 20 22 2f 2a  t.}.puts $fd "/*
3b70: 20 4e 75 6d 62 65 72 20 6f 66 20 70 72 61 67 6d   Number of pragm
3b80: 61 73 3a 20 24 64 66 6c 74 63 6e 74 20 6f 6e 20  as: $dfltcnt on 
3b90: 62 79 20 64 65 66 61 75 6c 74 2c 20 24 61 6c 6c  by default, $all
3ba0: 63 6e 74 20 74 6f 74 61 6c 2e 20 2a 2f 22 0a     cnt total. */".