/ Hex Artifact Content
Login

Artifact 1f7f2ac1d9f262c08b67faaca47e6a68262ff39113fa4b27d1db2843b4c33e73:


0000: 2f 2a 0a 2a 2a 20 43 6f 6d 70 69 6c 65 20 61 6e  /*.** Compile an
0010: 64 20 72 75 6e 20 74 68 69 73 20 73 74 61 6e 64  d run this stand
0020: 61 6c 6f 6e 65 20 70 72 6f 67 72 61 6d 20 69 6e  alone program in
0030: 20 6f 72 64 65 72 20 74 6f 20 67 65 6e 65 72 61   order to genera
0040: 74 65 20 63 6f 64 65 20 74 68 61 74 0a 2a 2a 20  te code that.** 
0050: 69 6d 70 6c 65 6d 65 6e 74 73 20 61 20 66 75 6e  implements a fun
0060: 63 74 69 6f 6e 20 74 68 61 74 20 77 69 6c 6c 20  ction that will 
0070: 74 72 61 6e 73 6c 61 74 65 20 61 6c 70 68 61 62  translate alphab
0080: 65 74 69 63 20 69 64 65 6e 74 69 66 69 65 72 73  etic identifiers
0090: 20 69 6e 74 6f 0a 2a 2a 20 70 61 72 73 65 72 20   into.** parser 
00a0: 74 6f 6b 65 6e 20 63 6f 64 65 73 2e 0a 2a 2f 0a  token codes..*/.
00b0: 23 69 6e 63 6c 75 64 65 20 3c 73 74 64 69 6f 2e  #include <stdio.
00c0: 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 73 74 72  h>.#include <str
00d0: 69 6e 67 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20  ing.h>.#include 
00e0: 3c 73 74 64 6c 69 62 2e 68 3e 0a 23 69 6e 63 6c  <stdlib.h>.#incl
00f0: 75 64 65 20 3c 61 73 73 65 72 74 2e 68 3e 0a 0a  ude <assert.h>..
0100: 2f 2a 0a 2a 2a 20 41 20 68 65 61 64 65 72 20 63  /*.** A header c
0110: 6f 6d 6d 65 6e 74 20 70 6c 61 63 65 64 20 61 74  omment placed at
0120: 20 74 68 65 20 62 65 67 69 6e 6e 69 6e 67 20 6f   the beginning o
0130: 66 20 67 65 6e 65 72 61 74 65 64 20 63 6f 64 65  f generated code
0140: 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 63 6f 6e 73  ..*/.static cons
0150: 74 20 63 68 61 72 20 7a 48 64 72 5b 5d 20 3d 20  t char zHdr[] = 
0160: 0a 20 20 22 2f 2a 2a 2a 2a 2a 20 54 68 69 73 20  .  "/***** This 
0170: 66 69 6c 65 20 63 6f 6e 74 61 69 6e 73 20 61 75  file contains au
0180: 74 6f 6d 61 74 69 63 61 6c 6c 79 20 67 65 6e 65  tomatically gene
0190: 72 61 74 65 64 20 63 6f 64 65 20 2a 2a 2a 2a 2a  rated code *****
01a0: 2a 5c 6e 22 0a 20 20 22 2a 2a 5c 6e 22 0a 20 20  *\n".  "**\n".  
01b0: 22 2a 2a 20 54 68 65 20 63 6f 64 65 20 69 6e 20  "** The code in 
01c0: 74 68 69 73 20 66 69 6c 65 20 68 61 73 20 62 65  this file has be
01d0: 65 6e 20 61 75 74 6f 6d 61 74 69 63 61 6c 6c 79  en automatically
01e0: 20 67 65 6e 65 72 61 74 65 64 20 62 79 5c 6e 22   generated by\n"
01f0: 0a 20 20 22 2a 2a 5c 6e 22 0a 20 20 22 2a 2a 20  .  "**\n".  "** 
0200: 20 20 73 71 6c 69 74 65 2f 74 6f 6f 6c 2f 6d 6b    sqlite/tool/mk
0210: 6b 65 79 77 6f 72 64 68 61 73 68 2e 63 5c 6e 22  keywordhash.c\n"
0220: 0a 20 20 22 2a 2a 5c 6e 22 0a 20 20 22 2a 2a 20  .  "**\n".  "** 
0230: 54 68 65 20 63 6f 64 65 20 69 6e 20 74 68 69 73  The code in this
0240: 20 66 69 6c 65 20 69 6d 70 6c 65 6d 65 6e 74 73   file implements
0250: 20 61 20 66 75 6e 63 74 69 6f 6e 20 74 68 61 74   a function that
0260: 20 64 65 74 65 72 6d 69 6e 65 73 20 77 68 65 74   determines whet
0270: 68 65 72 5c 6e 22 0a 20 20 22 2a 2a 20 6f 72 20  her\n".  "** or 
0280: 6e 6f 74 20 61 20 67 69 76 65 6e 20 69 64 65 6e  not a given iden
0290: 74 69 66 69 65 72 20 69 73 20 72 65 61 6c 6c 79  tifier is really
02a0: 20 61 6e 20 53 51 4c 20 6b 65 79 77 6f 72 64 2e   an SQL keyword.
02b0: 20 20 54 68 65 20 73 61 6d 65 20 74 68 69 6e 67    The same thing
02c0: 5c 6e 22 0a 20 20 22 2a 2a 20 6d 69 67 68 74 20  \n".  "** might 
02d0: 62 65 20 69 6d 70 6c 65 6d 65 6e 74 65 64 20 6d  be implemented m
02e0: 6f 72 65 20 64 69 72 65 63 74 6c 79 20 75 73 69  ore directly usi
02f0: 6e 67 20 61 20 68 61 6e 64 2d 77 72 69 74 74 65  ng a hand-writte
0300: 6e 20 68 61 73 68 20 74 61 62 6c 65 2e 5c 6e 22  n hash table.\n"
0310: 0a 20 20 22 2a 2a 20 42 75 74 20 62 79 20 75 73  .  "** But by us
0320: 69 6e 67 20 74 68 69 73 20 61 75 74 6f 6d 61 74  ing this automat
0330: 69 63 61 6c 6c 79 20 67 65 6e 65 72 61 74 65 64  ically generated
0340: 20 63 6f 64 65 2c 20 74 68 65 20 73 69 7a 65 20   code, the size 
0350: 6f 66 20 74 68 65 20 63 6f 64 65 5c 6e 22 0a 20  of the code\n". 
0360: 20 22 2a 2a 20 69 73 20 73 75 62 73 74 61 6e 74   "** is substant
0370: 69 61 6c 6c 79 20 72 65 64 75 63 65 64 2e 20 20  ially reduced.  
0380: 54 68 69 73 20 69 73 20 69 6d 70 6f 72 74 61 6e  This is importan
0390: 74 20 66 6f 72 20 65 6d 62 65 64 64 65 64 20 61  t for embedded a
03a0: 70 70 6c 69 63 61 74 69 6f 6e 73 5c 6e 22 0a 20  pplications\n". 
03b0: 20 22 2a 2a 20 6f 6e 20 70 6c 61 74 66 6f 72 6d   "** on platform
03c0: 73 20 77 69 74 68 20 6c 69 6d 69 74 65 64 20 6d  s with limited m
03d0: 65 6d 6f 72 79 2e 5c 6e 22 0a 20 20 22 2a 2f 5c  emory.\n".  "*/\
03e0: 6e 22 0a 3b 0a 0a 2f 2a 0a 2a 2a 20 41 6c 6c 20  n".;../*.** All 
03f0: 74 68 65 20 6b 65 79 77 6f 72 64 73 20 6f 66 20  the keywords of 
0400: 74 68 65 20 53 51 4c 20 6c 61 6e 67 75 61 67 65  the SQL language
0410: 20 61 72 65 20 73 74 6f 72 65 64 20 69 6e 20 61   are stored in a
0420: 20 68 61 73 68 0a 2a 2a 20 74 61 62 6c 65 20 63   hash.** table c
0430: 6f 6d 70 6f 73 65 64 20 6f 66 20 69 6e 73 74 61  omposed of insta
0440: 6e 63 65 73 20 6f 66 20 74 68 65 20 66 6f 6c 6c  nces of the foll
0450: 6f 77 69 6e 67 20 73 74 72 75 63 74 75 72 65 2e  owing structure.
0460: 0a 2a 2f 0a 74 79 70 65 64 65 66 20 73 74 72 75  .*/.typedef stru
0470: 63 74 20 4b 65 79 77 6f 72 64 20 4b 65 79 77 6f  ct Keyword Keywo
0480: 72 64 3b 0a 73 74 72 75 63 74 20 4b 65 79 77 6f  rd;.struct Keywo
0490: 72 64 20 7b 0a 20 20 63 68 61 72 20 2a 7a 4e 61  rd {.  char *zNa
04a0: 6d 65 3b 20 20 20 20 20 20 20 20 20 2f 2a 20 54  me;         /* T
04b0: 68 65 20 6b 65 79 77 6f 72 64 20 6e 61 6d 65 20  he keyword name 
04c0: 2a 2f 0a 20 20 63 68 61 72 20 2a 7a 54 6f 6b 65  */.  char *zToke
04d0: 6e 54 79 70 65 3b 20 20 20 20 2f 2a 20 54 6f 6b  nType;    /* Tok
04e0: 65 6e 20 76 61 6c 75 65 20 66 6f 72 20 74 68 69  en value for thi
04f0: 73 20 6b 65 79 77 6f 72 64 20 2a 2f 0a 20 20 69  s keyword */.  i
0500: 6e 74 20 6d 61 73 6b 3b 20 20 20 20 20 20 20 20  nt mask;        
0510: 20 20 20 20 2f 2a 20 43 6f 64 65 20 74 68 69 73      /* Code this
0520: 20 6b 65 79 77 6f 72 64 20 69 66 20 6e 6f 6e 2d   keyword if non-
0530: 7a 65 72 6f 20 2a 2f 0a 20 20 69 6e 74 20 69 64  zero */.  int id
0540: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  ;              /
0550: 2a 20 55 6e 69 71 75 65 20 49 44 20 66 6f 72 20  * Unique ID for 
0560: 74 68 69 73 20 72 65 63 6f 72 64 20 2a 2f 0a 20  this record */. 
0570: 20 69 6e 74 20 68 61 73 68 3b 20 20 20 20 20 20   int hash;      
0580: 20 20 20 20 20 20 2f 2a 20 48 61 73 68 20 6f 6e        /* Hash on
0590: 20 74 68 65 20 6b 65 79 77 6f 72 64 20 2a 2f 0a   the keyword */.
05a0: 20 20 69 6e 74 20 6f 66 66 73 65 74 3b 20 20 20    int offset;   
05b0: 20 20 20 20 20 20 20 2f 2a 20 4f 66 66 73 65 74         /* Offset
05c0: 20 74 6f 20 73 74 61 72 74 20 6f 66 20 6e 61 6d   to start of nam
05d0: 65 20 73 74 72 69 6e 67 20 2a 2f 0a 20 20 69 6e  e string */.  in
05e0: 74 20 6c 65 6e 3b 20 20 20 20 20 20 20 20 20 20  t len;          
05f0: 20 20 20 2f 2a 20 4c 65 6e 67 74 68 20 6f 66 20     /* Length of 
0600: 74 68 69 73 20 6b 65 79 77 6f 72 64 2c 20 6e 6f  this keyword, no
0610: 74 20 63 6f 75 6e 74 69 6e 67 20 66 69 6e 61 6c  t counting final
0620: 20 5c 30 30 30 20 2a 2f 0a 20 20 69 6e 74 20 70   \000 */.  int p
0630: 72 65 66 69 78 3b 20 20 20 20 20 20 20 20 20 20  refix;          
0640: 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 63 68 61  /* Number of cha
0650: 72 61 63 74 65 72 73 20 69 6e 20 70 72 65 66 69  racters in prefi
0660: 78 20 2a 2f 0a 20 20 69 6e 74 20 6c 6f 6e 67 65  x */.  int longe
0670: 73 74 53 75 66 66 69 78 3b 20 20 20 2f 2a 20 4c  stSuffix;   /* L
0680: 6f 6e 67 65 73 74 20 73 75 66 66 69 78 20 74 68  ongest suffix th
0690: 61 74 20 69 73 20 61 20 70 72 65 66 69 78 20 6f  at is a prefix o
06a0: 6e 20 61 6e 6f 74 68 65 72 20 77 6f 72 64 20 2a  n another word *
06b0: 2f 0a 20 20 69 6e 74 20 69 4e 65 78 74 3b 20 20  /.  int iNext;  
06c0: 20 20 20 20 20 20 20 20 20 2f 2a 20 49 6e 64 65           /* Inde
06d0: 78 20 69 6e 20 61 4b 65 79 77 6f 72 64 54 61 62  x in aKeywordTab
06e0: 6c 65 5b 5d 20 6f 66 20 6e 65 78 74 20 77 69 74  le[] of next wit
06f0: 68 20 73 61 6d 65 20 68 61 73 68 20 2a 2f 0a 20  h same hash */. 
0700: 20 69 6e 74 20 73 75 62 73 74 72 49 64 3b 20 20   int substrId;  
0710: 20 20 20 20 20 20 2f 2a 20 49 64 20 74 6f 20 61        /* Id to a
0720: 6e 6f 74 68 65 72 20 6b 65 79 77 6f 72 64 20 74  nother keyword t
0730: 68 69 73 20 6b 65 79 77 6f 72 64 20 69 73 20 65  his keyword is e
0740: 6d 62 65 64 64 65 64 20 69 6e 20 2a 2f 0a 20 20  mbedded in */.  
0750: 69 6e 74 20 73 75 62 73 74 72 4f 66 66 73 65 74  int substrOffset
0760: 3b 20 20 20 20 2f 2a 20 4f 66 66 73 65 74 20 69  ;    /* Offset i
0770: 6e 74 6f 20 73 75 62 73 74 72 49 64 20 66 6f 72  nto substrId for
0780: 20 73 74 61 72 74 20 6f 66 20 74 68 69 73 20 6b   start of this k
0790: 65 79 77 6f 72 64 20 2a 2f 0a 20 20 63 68 61 72  eyword */.  char
07a0: 20 7a 4f 72 69 67 4e 61 6d 65 5b 32 30 5d 3b 20   zOrigName[20]; 
07b0: 20 2f 2a 20 4f 72 69 67 69 6e 61 6c 20 6b 65 79   /* Original key
07c0: 77 6f 72 64 20 6e 61 6d 65 20 62 65 66 6f 72 65  word name before
07d0: 20 70 72 6f 63 65 73 73 69 6e 67 20 2a 2f 0a 7d   processing */.}
07e0: 3b 0a 0a 2f 2a 0a 2a 2a 20 44 65 66 69 6e 65 20  ;../*.** Define 
07f0: 6d 61 73 6b 73 20 75 73 65 64 20 74 6f 20 64 65  masks used to de
0800: 74 65 72 6d 69 6e 65 20 77 68 69 63 68 20 6b 65  termine which ke
0810: 79 77 6f 72 64 73 20 61 72 65 20 61 6c 6c 6f 77  ywords are allow
0820: 65 64 0a 2a 2f 0a 23 69 66 64 65 66 20 53 51 4c  ed.*/.#ifdef SQL
0830: 49 54 45 5f 4f 4d 49 54 5f 41 4c 54 45 52 54 41  ITE_OMIT_ALTERTA
0840: 42 4c 45 0a 23 20 20 64 65 66 69 6e 65 20 41 4c  BLE.#  define AL
0850: 54 45 52 20 20 20 20 20 20 30 0a 23 65 6c 73 65  TER      0.#else
0860: 0a 23 20 20 64 65 66 69 6e 65 20 41 4c 54 45 52  .#  define ALTER
0870: 20 20 20 20 20 20 30 78 30 30 30 30 30 30 30 31        0x00000001
0880: 0a 23 65 6e 64 69 66 0a 23 64 65 66 69 6e 65 20  .#endif.#define 
0890: 41 4c 57 41 59 53 20 20 20 20 20 20 20 30 78 30  ALWAYS       0x0
08a0: 30 30 30 30 30 30 32 0a 23 69 66 64 65 66 20 53  0000002.#ifdef S
08b0: 51 4c 49 54 45 5f 4f 4d 49 54 5f 41 4e 41 4c 59  QLITE_OMIT_ANALY
08c0: 5a 45 0a 23 20 20 64 65 66 69 6e 65 20 41 4e 41  ZE.#  define ANA
08d0: 4c 59 5a 45 20 20 20 20 30 0a 23 65 6c 73 65 0a  LYZE    0.#else.
08e0: 23 20 20 64 65 66 69 6e 65 20 41 4e 41 4c 59 5a  #  define ANALYZ
08f0: 45 20 20 20 20 30 78 30 30 30 30 30 30 30 34 0a  E    0x00000004.
0900: 23 65 6e 64 69 66 0a 23 69 66 64 65 66 20 53 51  #endif.#ifdef SQ
0910: 4c 49 54 45 5f 4f 4d 49 54 5f 41 54 54 41 43 48  LITE_OMIT_ATTACH
0920: 0a 23 20 20 64 65 66 69 6e 65 20 41 54 54 41 43  .#  define ATTAC
0930: 48 20 20 20 20 20 30 0a 23 65 6c 73 65 0a 23 20  H     0.#else.# 
0940: 20 64 65 66 69 6e 65 20 41 54 54 41 43 48 20 20   define ATTACH  
0950: 20 20 20 30 78 30 30 30 30 30 30 30 38 0a 23 65     0x00000008.#e
0960: 6e 64 69 66 0a 23 69 66 64 65 66 20 53 51 4c 49  ndif.#ifdef SQLI
0970: 54 45 5f 4f 4d 49 54 5f 41 55 54 4f 49 4e 43 52  TE_OMIT_AUTOINCR
0980: 45 4d 45 4e 54 0a 23 20 20 64 65 66 69 6e 65 20  EMENT.#  define 
0990: 41 55 54 4f 49 4e 43 52 20 20 20 30 0a 23 65 6c  AUTOINCR   0.#el
09a0: 73 65 0a 23 20 20 64 65 66 69 6e 65 20 41 55 54  se.#  define AUT
09b0: 4f 49 4e 43 52 20 20 20 30 78 30 30 30 30 30 30  OINCR   0x000000
09c0: 31 30 0a 23 65 6e 64 69 66 0a 23 69 66 64 65 66  10.#endif.#ifdef
09d0: 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 43 41 53   SQLITE_OMIT_CAS
09e0: 54 0a 23 20 20 64 65 66 69 6e 65 20 43 41 53 54  T.#  define CAST
09f0: 20 20 20 20 20 20 20 30 0a 23 65 6c 73 65 0a 23         0.#else.#
0a00: 20 20 64 65 66 69 6e 65 20 43 41 53 54 20 20 20    define CAST   
0a10: 20 20 20 20 30 78 30 30 30 30 30 30 32 30 0a 23      0x00000020.#
0a20: 65 6e 64 69 66 0a 23 69 66 64 65 66 20 53 51 4c  endif.#ifdef SQL
0a30: 49 54 45 5f 4f 4d 49 54 5f 43 4f 4d 50 4f 55 4e  ITE_OMIT_COMPOUN
0a40: 44 5f 53 45 4c 45 43 54 0a 23 20 20 64 65 66 69  D_SELECT.#  defi
0a50: 6e 65 20 43 4f 4d 50 4f 55 4e 44 20 20 20 30 0a  ne COMPOUND   0.
0a60: 23 65 6c 73 65 0a 23 20 20 64 65 66 69 6e 65 20  #else.#  define 
0a70: 43 4f 4d 50 4f 55 4e 44 20 20 20 30 78 30 30 30  COMPOUND   0x000
0a80: 30 30 30 34 30 0a 23 65 6e 64 69 66 0a 23 69 66  00040.#endif.#if
0a90: 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  def SQLITE_OMIT_
0aa0: 43 4f 4e 46 4c 49 43 54 5f 43 4c 41 55 53 45 0a  CONFLICT_CLAUSE.
0ab0: 23 20 20 64 65 66 69 6e 65 20 43 4f 4e 46 4c 49  #  define CONFLI
0ac0: 43 54 20 20 20 30 0a 23 65 6c 73 65 0a 23 20 20  CT   0.#else.#  
0ad0: 64 65 66 69 6e 65 20 43 4f 4e 46 4c 49 43 54 20  define CONFLICT 
0ae0: 20 20 30 78 30 30 30 30 30 30 38 30 0a 23 65 6e    0x00000080.#en
0af0: 64 69 66 0a 23 69 66 64 65 66 20 53 51 4c 49 54  dif.#ifdef SQLIT
0b00: 45 5f 4f 4d 49 54 5f 45 58 50 4c 41 49 4e 0a 23  E_OMIT_EXPLAIN.#
0b10: 20 20 64 65 66 69 6e 65 20 45 58 50 4c 41 49 4e    define EXPLAIN
0b20: 20 20 20 20 30 0a 23 65 6c 73 65 0a 23 20 20 64      0.#else.#  d
0b30: 65 66 69 6e 65 20 45 58 50 4c 41 49 4e 20 20 20  efine EXPLAIN   
0b40: 20 30 78 30 30 30 30 30 31 30 30 0a 23 65 6e 64   0x00000100.#end
0b50: 69 66 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45  if.#ifdef SQLITE
0b60: 5f 4f 4d 49 54 5f 46 4f 52 45 49 47 4e 5f 4b 45  _OMIT_FOREIGN_KE
0b70: 59 0a 23 20 20 64 65 66 69 6e 65 20 46 4b 45 59  Y.#  define FKEY
0b80: 20 20 20 20 20 20 20 30 0a 23 65 6c 73 65 0a 23         0.#else.#
0b90: 20 20 64 65 66 69 6e 65 20 46 4b 45 59 20 20 20    define FKEY   
0ba0: 20 20 20 20 30 78 30 30 30 30 30 32 30 30 0a 23      0x00000200.#
0bb0: 65 6e 64 69 66 0a 23 69 66 64 65 66 20 53 51 4c  endif.#ifdef SQL
0bc0: 49 54 45 5f 4f 4d 49 54 5f 50 52 41 47 4d 41 0a  ITE_OMIT_PRAGMA.
0bd0: 23 20 20 64 65 66 69 6e 65 20 50 52 41 47 4d 41  #  define PRAGMA
0be0: 20 20 20 20 20 30 0a 23 65 6c 73 65 0a 23 20 20       0.#else.#  
0bf0: 64 65 66 69 6e 65 20 50 52 41 47 4d 41 20 20 20  define PRAGMA   
0c00: 20 20 30 78 30 30 30 30 30 34 30 30 0a 23 65 6e    0x00000400.#en
0c10: 64 69 66 0a 23 69 66 64 65 66 20 53 51 4c 49 54  dif.#ifdef SQLIT
0c20: 45 5f 4f 4d 49 54 5f 52 45 49 4e 44 45 58 0a 23  E_OMIT_REINDEX.#
0c30: 20 20 64 65 66 69 6e 65 20 52 45 49 4e 44 45 58    define REINDEX
0c40: 20 20 20 20 30 0a 23 65 6c 73 65 0a 23 20 20 64      0.#else.#  d
0c50: 65 66 69 6e 65 20 52 45 49 4e 44 45 58 20 20 20  efine REINDEX   
0c60: 20 30 78 30 30 30 30 30 38 30 30 0a 23 65 6e 64   0x00000800.#end
0c70: 69 66 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45  if.#ifdef SQLITE
0c80: 5f 4f 4d 49 54 5f 53 55 42 51 55 45 52 59 0a 23  _OMIT_SUBQUERY.#
0c90: 20 20 64 65 66 69 6e 65 20 53 55 42 51 55 45 52    define SUBQUER
0ca0: 59 20 20 20 30 0a 23 65 6c 73 65 0a 23 20 20 64  Y   0.#else.#  d
0cb0: 65 66 69 6e 65 20 53 55 42 51 55 45 52 59 20 20  efine SUBQUERY  
0cc0: 20 30 78 30 30 30 30 31 30 30 30 0a 23 65 6e 64   0x00001000.#end
0cd0: 69 66 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45  if.#ifdef SQLITE
0ce0: 5f 4f 4d 49 54 5f 54 52 49 47 47 45 52 0a 23 20  _OMIT_TRIGGER.# 
0cf0: 20 64 65 66 69 6e 65 20 54 52 49 47 47 45 52 20   define TRIGGER 
0d00: 20 20 20 30 0a 23 65 6c 73 65 0a 23 20 20 64 65     0.#else.#  de
0d10: 66 69 6e 65 20 54 52 49 47 47 45 52 20 20 20 20  fine TRIGGER    
0d20: 30 78 30 30 30 30 32 30 30 30 0a 23 65 6e 64 69  0x00002000.#endi
0d30: 66 0a 23 69 66 20 64 65 66 69 6e 65 64 28 53 51  f.#if defined(SQ
0d40: 4c 49 54 45 5f 4f 4d 49 54 5f 41 55 54 4f 56 41  LITE_OMIT_AUTOVA
0d50: 43 55 55 4d 29 20 26 26 20 5c 0a 20 20 20 20 28  CUUM) && \.    (
0d60: 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f  defined(SQLITE_O
0d70: 4d 49 54 5f 56 41 43 55 55 4d 29 20 7c 7c 20 64  MIT_VACUUM) || d
0d80: 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 4f 4d  efined(SQLITE_OM
0d90: 49 54 5f 41 54 54 41 43 48 29 29 0a 23 20 20 64  IT_ATTACH)).#  d
0da0: 65 66 69 6e 65 20 56 41 43 55 55 4d 20 20 20 20  efine VACUUM    
0db0: 20 30 0a 23 65 6c 73 65 0a 23 20 20 64 65 66 69   0.#else.#  defi
0dc0: 6e 65 20 56 41 43 55 55 4d 20 20 20 20 20 30 78  ne VACUUM     0x
0dd0: 30 30 30 30 34 30 30 30 0a 23 65 6e 64 69 66 0a  00004000.#endif.
0de0: 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d  #ifdef SQLITE_OM
0df0: 49 54 5f 56 49 45 57 0a 23 20 20 64 65 66 69 6e  IT_VIEW.#  defin
0e00: 65 20 56 49 45 57 20 20 20 20 20 20 20 30 0a 23  e VIEW       0.#
0e10: 65 6c 73 65 0a 23 20 20 64 65 66 69 6e 65 20 56  else.#  define V
0e20: 49 45 57 20 20 20 20 20 20 20 30 78 30 30 30 30  IEW       0x0000
0e30: 38 30 30 30 0a 23 65 6e 64 69 66 0a 23 69 66 64  8000.#endif.#ifd
0e40: 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 56  ef SQLITE_OMIT_V
0e50: 49 52 54 55 41 4c 54 41 42 4c 45 0a 23 20 20 64  IRTUALTABLE.#  d
0e60: 65 66 69 6e 65 20 56 54 41 42 20 20 20 20 20 20  efine VTAB      
0e70: 20 30 0a 23 65 6c 73 65 0a 23 20 20 64 65 66 69   0.#else.#  defi
0e80: 6e 65 20 56 54 41 42 20 20 20 20 20 20 20 30 78  ne VTAB       0x
0e90: 30 30 30 31 30 30 30 30 0a 23 65 6e 64 69 66 0a  00010000.#endif.
0ea0: 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d  #ifdef SQLITE_OM
0eb0: 49 54 5f 41 55 54 4f 56 41 43 55 55 4d 0a 23 20  IT_AUTOVACUUM.# 
0ec0: 20 64 65 66 69 6e 65 20 41 55 54 4f 56 41 43 55   define AUTOVACU
0ed0: 55 4d 20 30 0a 23 65 6c 73 65 0a 23 20 20 64 65  UM 0.#else.#  de
0ee0: 66 69 6e 65 20 41 55 54 4f 56 41 43 55 55 4d 20  fine AUTOVACUUM 
0ef0: 30 78 30 30 30 32 30 30 30 30 0a 23 65 6e 64 69  0x00020000.#endi
0f00: 66 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f  f.#ifdef SQLITE_
0f10: 4f 4d 49 54 5f 43 54 45 0a 23 20 20 64 65 66 69  OMIT_CTE.#  defi
0f20: 6e 65 20 43 54 45 20 20 20 20 20 20 20 20 30 0a  ne CTE        0.
0f30: 23 65 6c 73 65 0a 23 20 20 64 65 66 69 6e 65 20  #else.#  define 
0f40: 43 54 45 20 20 20 20 20 20 20 20 30 78 30 30 30  CTE        0x000
0f50: 34 30 30 30 30 0a 23 65 6e 64 69 66 0a 23 69 66  40000.#endif.#if
0f60: 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  def SQLITE_OMIT_
0f70: 55 50 53 45 52 54 0a 23 20 20 64 65 66 69 6e 65  UPSERT.#  define
0f80: 20 55 50 53 45 52 54 20 20 20 20 20 30 0a 23 65   UPSERT     0.#e
0f90: 6c 73 65 0a 23 20 20 64 65 66 69 6e 65 20 55 50  lse.#  define UP
0fa0: 53 45 52 54 20 20 20 20 20 30 78 30 30 30 38 30  SERT     0x00080
0fb0: 30 30 30 0a 23 65 6e 64 69 66 0a 23 69 66 64 65  000.#endif.#ifde
0fc0: 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 57 49  f SQLITE_OMIT_WI
0fd0: 4e 44 4f 57 46 55 4e 43 0a 23 20 20 64 65 66 69  NDOWFUNC.#  defi
0fe0: 6e 65 20 57 49 4e 44 4f 57 46 55 4e 43 20 30 0a  ne WINDOWFUNC 0.
0ff0: 23 65 6c 73 65 0a 23 20 20 64 65 66 69 6e 65 20  #else.#  define 
1000: 57 49 4e 44 4f 57 46 55 4e 43 20 30 78 30 30 31  WINDOWFUNC 0x001
1010: 30 30 30 30 30 0a 23 65 6e 64 69 66 0a 0a 2f 2a  00000.#endif../*
1020: 0a 2a 2a 20 54 68 65 73 65 20 61 72 65 20 74 68  .** These are th
1030: 65 20 6b 65 79 77 6f 72 64 73 0a 2a 2f 0a 73 74  e keywords.*/.st
1040: 61 74 69 63 20 4b 65 79 77 6f 72 64 20 61 4b 65  atic Keyword aKe
1050: 79 77 6f 72 64 54 61 62 6c 65 5b 5d 20 3d 20 7b  ywordTable[] = {
1060: 0a 20 20 7b 20 22 41 42 4f 52 54 22 2c 20 20 20  .  { "ABORT",   
1070: 20 20 20 20 20 20 20 20 20 22 54 4b 5f 41 42 4f           "TK_ABO
1080: 52 54 22 2c 20 20 20 20 20 20 20 20 43 4f 4e 46  RT",        CONF
1090: 4c 49 43 54 7c 54 52 49 47 47 45 52 20 20 20 20  LICT|TRIGGER    
10a0: 20 20 20 7d 2c 0a 20 20 7b 20 22 41 43 54 49 4f     },.  { "ACTIO
10b0: 4e 22 2c 20 20 20 20 20 20 20 20 20 20 20 22 54  N",           "T
10c0: 4b 5f 41 43 54 49 4f 4e 22 2c 20 20 20 20 20 20  K_ACTION",      
10d0: 20 46 4b 45 59 20 20 20 20 20 20 20 20 20 20 20   FKEY           
10e0: 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22          },.  { "
10f0: 41 44 44 22 2c 20 20 20 20 20 20 20 20 20 20 20  ADD",           
1100: 20 20 20 22 54 4b 5f 41 44 44 22 2c 20 20 20 20     "TK_ADD",    
1110: 20 20 20 20 20 20 41 4c 54 45 52 20 20 20 20 20        ALTER     
1120: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a               },.
1130: 20 20 7b 20 22 41 46 54 45 52 22 2c 20 20 20 20    { "AFTER",    
1140: 20 20 20 20 20 20 20 20 22 54 4b 5f 41 46 54 45          "TK_AFTE
1150: 52 22 2c 20 20 20 20 20 20 20 20 54 52 49 47 47  R",        TRIGG
1160: 45 52 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ER              
1170: 20 20 7d 2c 0a 20 20 7b 20 22 41 4c 4c 22 2c 20    },.  { "ALL", 
1180: 20 20 20 20 20 20 20 20 20 20 20 20 20 22 54 4b               "TK
1190: 5f 41 4c 4c 22 2c 20 20 20 20 20 20 20 20 20 20  _ALL",          
11a0: 41 4c 57 41 59 53 20 20 20 20 20 20 20 20 20 20  ALWAYS          
11b0: 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 41         },.  { "A
11c0: 4c 54 45 52 22 2c 20 20 20 20 20 20 20 20 20 20  LTER",          
11d0: 20 20 22 54 4b 5f 41 4c 54 45 52 22 2c 20 20 20    "TK_ALTER",   
11e0: 20 20 20 20 20 41 4c 54 45 52 20 20 20 20 20 20       ALTER      
11f0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20              },. 
1200: 20 7b 20 22 41 4e 41 4c 59 5a 45 22 2c 20 20 20   { "ANALYZE",   
1210: 20 20 20 20 20 20 20 22 54 4b 5f 41 4e 41 4c 59         "TK_ANALY
1220: 5a 45 22 2c 20 20 20 20 20 20 41 4e 41 4c 59 5a  ZE",      ANALYZ
1230: 45 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  E               
1240: 20 7d 2c 0a 20 20 7b 20 22 41 4e 44 22 2c 20 20   },.  { "AND",  
1250: 20 20 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f              "TK_
1260: 41 4e 44 22 2c 20 20 20 20 20 20 20 20 20 20 41  AND",          A
1270: 4c 57 41 59 53 20 20 20 20 20 20 20 20 20 20 20  LWAYS           
1280: 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 41 53        },.  { "AS
1290: 22 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ",              
12a0: 20 22 54 4b 5f 41 53 22 2c 20 20 20 20 20 20 20   "TK_AS",       
12b0: 20 20 20 20 41 4c 57 41 59 53 20 20 20 20 20 20      ALWAYS      
12c0: 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20             },.  
12d0: 7b 20 22 41 53 43 22 2c 20 20 20 20 20 20 20 20  { "ASC",        
12e0: 20 20 20 20 20 20 22 54 4b 5f 41 53 43 22 2c 20        "TK_ASC", 
12f0: 20 20 20 20 20 20 20 20 20 41 4c 57 41 59 53 20           ALWAYS 
1300: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1310: 7d 2c 0a 20 20 7b 20 22 41 54 54 41 43 48 22 2c  },.  { "ATTACH",
1320: 20 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f 41             "TK_A
1330: 54 54 41 43 48 22 2c 20 20 20 20 20 20 20 41 54  TTACH",       AT
1340: 54 41 43 48 20 20 20 20 20 20 20 20 20 20 20 20  TACH            
1350: 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 41 55 54       },.  { "AUT
1360: 4f 49 4e 43 52 45 4d 45 4e 54 22 2c 20 20 20 20  OINCREMENT",    
1370: 22 54 4b 5f 41 55 54 4f 49 4e 43 52 22 2c 20 20  "TK_AUTOINCR",  
1380: 20 20 20 41 55 54 4f 49 4e 43 52 20 20 20 20 20     AUTOINCR     
1390: 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b            },.  {
13a0: 20 22 42 45 46 4f 52 45 22 2c 20 20 20 20 20 20   "BEFORE",      
13b0: 20 20 20 20 20 22 54 4b 5f 42 45 46 4f 52 45 22       "TK_BEFORE"
13c0: 2c 20 20 20 20 20 20 20 54 52 49 47 47 45 52 20  ,       TRIGGER 
13d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d                 }
13e0: 2c 0a 20 20 7b 20 22 42 45 47 49 4e 22 2c 20 20  ,.  { "BEGIN",  
13f0: 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f 42 45            "TK_BE
1400: 47 49 4e 22 2c 20 20 20 20 20 20 20 20 41 4c 57  GIN",        ALW
1410: 41 59 53 20 20 20 20 20 20 20 20 20 20 20 20 20  AYS             
1420: 20 20 20 20 7d 2c 0a 20 20 7b 20 22 42 45 54 57      },.  { "BETW
1430: 45 45 4e 22 2c 20 20 20 20 20 20 20 20 20 20 22  EEN",          "
1440: 54 4b 5f 42 45 54 57 45 45 4e 22 2c 20 20 20 20  TK_BETWEEN",    
1450: 20 20 41 4c 57 41 59 53 20 20 20 20 20 20 20 20    ALWAYS        
1460: 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20           },.  { 
1470: 22 42 59 22 2c 20 20 20 20 20 20 20 20 20 20 20  "BY",           
1480: 20 20 20 20 22 54 4b 5f 42 59 22 2c 20 20 20 20      "TK_BY",    
1490: 20 20 20 20 20 20 20 41 4c 57 41 59 53 20 20 20         ALWAYS   
14a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c                },
14b0: 0a 20 20 7b 20 22 43 41 53 43 41 44 45 22 2c 20  .  { "CASCADE", 
14c0: 20 20 20 20 20 20 20 20 20 22 54 4b 5f 43 41 53           "TK_CAS
14d0: 43 41 44 45 22 2c 20 20 20 20 20 20 46 4b 45 59  CADE",      FKEY
14e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
14f0: 20 20 20 7d 2c 0a 20 20 7b 20 22 43 41 53 45 22     },.  { "CASE"
1500: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 22 54  ,             "T
1510: 4b 5f 43 41 53 45 22 2c 20 20 20 20 20 20 20 20  K_CASE",        
1520: 20 41 4c 57 41 59 53 20 20 20 20 20 20 20 20 20   ALWAYS         
1530: 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22          },.  { "
1540: 43 41 53 54 22 2c 20 20 20 20 20 20 20 20 20 20  CAST",          
1550: 20 20 20 22 54 4b 5f 43 41 53 54 22 2c 20 20 20     "TK_CAST",   
1560: 20 20 20 20 20 20 43 41 53 54 20 20 20 20 20 20        CAST      
1570: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a               },.
1580: 20 20 7b 20 22 43 48 45 43 4b 22 2c 20 20 20 20    { "CHECK",    
1590: 20 20 20 20 20 20 20 20 22 54 4b 5f 43 48 45 43          "TK_CHEC
15a0: 4b 22 2c 20 20 20 20 20 20 20 20 41 4c 57 41 59  K",        ALWAY
15b0: 53 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  S               
15c0: 20 20 7d 2c 0a 20 20 7b 20 22 43 4f 4c 4c 41 54    },.  { "COLLAT
15d0: 45 22 2c 20 20 20 20 20 20 20 20 20 20 22 54 4b  E",          "TK
15e0: 5f 43 4f 4c 4c 41 54 45 22 2c 20 20 20 20 20 20  _COLLATE",      
15f0: 41 4c 57 41 59 53 20 20 20 20 20 20 20 20 20 20  ALWAYS          
1600: 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 43         },.  { "C
1610: 4f 4c 55 4d 4e 22 2c 20 20 20 20 20 20 20 20 20  OLUMN",         
1620: 20 20 22 54 4b 5f 43 4f 4c 55 4d 4e 4b 57 22 2c    "TK_COLUMNKW",
1630: 20 20 20 20 20 41 4c 54 45 52 20 20 20 20 20 20       ALTER      
1640: 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20              },. 
1650: 20 7b 20 22 43 4f 4d 4d 49 54 22 2c 20 20 20 20   { "COMMIT",    
1660: 20 20 20 20 20 20 20 22 54 4b 5f 43 4f 4d 4d 49         "TK_COMMI
1670: 54 22 2c 20 20 20 20 20 20 20 41 4c 57 41 59 53  T",       ALWAYS
1680: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1690: 20 7d 2c 0a 20 20 7b 20 22 43 4f 4e 46 4c 49 43   },.  { "CONFLIC
16a0: 54 22 2c 20 20 20 20 20 20 20 20 20 22 54 4b 5f  T",         "TK_
16b0: 43 4f 4e 46 4c 49 43 54 22 2c 20 20 20 20 20 43  CONFLICT",     C
16c0: 4f 4e 46 4c 49 43 54 20 20 20 20 20 20 20 20 20  ONFLICT         
16d0: 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 43 4f        },.  { "CO
16e0: 4e 53 54 52 41 49 4e 54 22 2c 20 20 20 20 20 20  NSTRAINT",      
16f0: 20 22 54 4b 5f 43 4f 4e 53 54 52 41 49 4e 54 22   "TK_CONSTRAINT"
1700: 2c 20 20 20 41 4c 57 41 59 53 20 20 20 20 20 20  ,   ALWAYS      
1710: 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20             },.  
1720: 7b 20 22 43 52 45 41 54 45 22 2c 20 20 20 20 20  { "CREATE",     
1730: 20 20 20 20 20 20 22 54 4b 5f 43 52 45 41 54 45        "TK_CREATE
1740: 22 2c 20 20 20 20 20 20 20 41 4c 57 41 59 53 20  ",       ALWAYS 
1750: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1760: 7d 2c 0a 20 20 7b 20 22 43 52 4f 53 53 22 2c 20  },.  { "CROSS", 
1770: 20 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f 4a             "TK_J
1780: 4f 49 4e 5f 4b 57 22 2c 20 20 20 20 20 20 41 4c  OIN_KW",      AL
1790: 57 41 59 53 20 20 20 20 20 20 20 20 20 20 20 20  WAYS            
17a0: 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 43 55 52       },.  { "CUR
17b0: 52 45 4e 54 22 2c 20 20 20 20 20 20 20 20 20 20  RENT",          
17c0: 22 54 4b 5f 43 55 52 52 45 4e 54 22 2c 20 20 20  "TK_CURRENT",   
17d0: 20 20 20 57 49 4e 44 4f 57 46 55 4e 43 20 20 20     WINDOWFUNC   
17e0: 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b            },.  {
17f0: 20 22 43 55 52 52 45 4e 54 5f 44 41 54 45 22 2c   "CURRENT_DATE",
1800: 20 20 20 20 20 22 54 4b 5f 43 54 49 4d 45 5f 4b       "TK_CTIME_K
1810: 57 22 2c 20 20 20 20 20 41 4c 57 41 59 53 20 20  W",     ALWAYS  
1820: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d                 }
1830: 2c 0a 20 20 7b 20 22 43 55 52 52 45 4e 54 5f 54  ,.  { "CURRENT_T
1840: 49 4d 45 22 2c 20 20 20 20 20 22 54 4b 5f 43 54  IME",     "TK_CT
1850: 49 4d 45 5f 4b 57 22 2c 20 20 20 20 20 41 4c 57  IME_KW",     ALW
1860: 41 59 53 20 20 20 20 20 20 20 20 20 20 20 20 20  AYS             
1870: 20 20 20 20 7d 2c 0a 20 20 7b 20 22 43 55 52 52      },.  { "CURR
1880: 45 4e 54 5f 54 49 4d 45 53 54 41 4d 50 22 2c 22  ENT_TIMESTAMP","
1890: 54 4b 5f 43 54 49 4d 45 5f 4b 57 22 2c 20 20 20  TK_CTIME_KW",   
18a0: 20 20 41 4c 57 41 59 53 20 20 20 20 20 20 20 20    ALWAYS        
18b0: 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20           },.  { 
18c0: 22 44 41 54 41 42 41 53 45 22 2c 20 20 20 20 20  "DATABASE",     
18d0: 20 20 20 20 22 54 4b 5f 44 41 54 41 42 41 53 45      "TK_DATABASE
18e0: 22 2c 20 20 20 20 20 41 54 54 41 43 48 20 20 20  ",     ATTACH   
18f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c                },
1900: 0a 20 20 7b 20 22 44 45 46 41 55 4c 54 22 2c 20  .  { "DEFAULT", 
1910: 20 20 20 20 20 20 20 20 20 22 54 4b 5f 44 45 46           "TK_DEF
1920: 41 55 4c 54 22 2c 20 20 20 20 20 20 41 4c 57 41  AULT",      ALWA
1930: 59 53 20 20 20 20 20 20 20 20 20 20 20 20 20 20  YS              
1940: 20 20 20 7d 2c 0a 20 20 7b 20 22 44 45 46 45 52     },.  { "DEFER
1950: 52 45 44 22 2c 20 20 20 20 20 20 20 20 20 22 54  RED",         "T
1960: 4b 5f 44 45 46 45 52 52 45 44 22 2c 20 20 20 20  K_DEFERRED",    
1970: 20 41 4c 57 41 59 53 20 20 20 20 20 20 20 20 20   ALWAYS         
1980: 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22          },.  { "
1990: 44 45 46 45 52 52 41 42 4c 45 22 2c 20 20 20 20  DEFERRABLE",    
19a0: 20 20 20 22 54 4b 5f 44 45 46 45 52 52 41 42 4c     "TK_DEFERRABL
19b0: 45 22 2c 20 20 20 46 4b 45 59 20 20 20 20 20 20  E",   FKEY      
19c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a               },.
19d0: 20 20 7b 20 22 44 45 4c 45 54 45 22 2c 20 20 20    { "DELETE",   
19e0: 20 20 20 20 20 20 20 20 22 54 4b 5f 44 45 4c 45          "TK_DELE
19f0: 54 45 22 2c 20 20 20 20 20 20 20 41 4c 57 41 59  TE",       ALWAY
1a00: 53 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  S               
1a10: 20 20 7d 2c 0a 20 20 7b 20 22 44 45 53 43 22 2c    },.  { "DESC",
1a20: 20 20 20 20 20 20 20 20 20 20 20 20 20 22 54 4b               "TK
1a30: 5f 44 45 53 43 22 2c 20 20 20 20 20 20 20 20 20  _DESC",         
1a40: 41 4c 57 41 59 53 20 20 20 20 20 20 20 20 20 20  ALWAYS          
1a50: 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 44         },.  { "D
1a60: 45 54 41 43 48 22 2c 20 20 20 20 20 20 20 20 20  ETACH",         
1a70: 20 20 22 54 4b 5f 44 45 54 41 43 48 22 2c 20 20    "TK_DETACH",  
1a80: 20 20 20 20 20 41 54 54 41 43 48 20 20 20 20 20       ATTACH     
1a90: 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20              },. 
1aa0: 20 7b 20 22 44 49 53 54 49 4e 43 54 22 2c 20 20   { "DISTINCT",  
1ab0: 20 20 20 20 20 20 20 22 54 4b 5f 44 49 53 54 49         "TK_DISTI
1ac0: 4e 43 54 22 2c 20 20 20 20 20 41 4c 57 41 59 53  NCT",     ALWAYS
1ad0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1ae0: 20 7d 2c 0a 20 20 7b 20 22 44 4f 22 2c 20 20 20   },.  { "DO",   
1af0: 20 20 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f              "TK_
1b00: 44 4f 22 2c 20 20 20 20 20 20 20 20 20 20 20 55  DO",           U
1b10: 50 53 45 52 54 20 20 20 20 20 20 20 20 20 20 20  PSERT           
1b20: 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 44 52        },.  { "DR
1b30: 4f 50 22 2c 20 20 20 20 20 20 20 20 20 20 20 20  OP",            
1b40: 20 22 54 4b 5f 44 52 4f 50 22 2c 20 20 20 20 20   "TK_DROP",     
1b50: 20 20 20 20 41 4c 57 41 59 53 20 20 20 20 20 20      ALWAYS      
1b60: 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20             },.  
1b70: 7b 20 22 45 4e 44 22 2c 20 20 20 20 20 20 20 20  { "END",        
1b80: 20 20 20 20 20 20 22 54 4b 5f 45 4e 44 22 2c 20        "TK_END", 
1b90: 20 20 20 20 20 20 20 20 20 41 4c 57 41 59 53 20           ALWAYS 
1ba0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1bb0: 7d 2c 0a 20 20 7b 20 22 45 41 43 48 22 2c 20 20  },.  { "EACH",  
1bc0: 20 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f 45             "TK_E
1bd0: 41 43 48 22 2c 20 20 20 20 20 20 20 20 20 54 52  ACH",         TR
1be0: 49 47 47 45 52 20 20 20 20 20 20 20 20 20 20 20  IGGER           
1bf0: 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 45 4c 53       },.  { "ELS
1c00: 45 22 2c 20 20 20 20 20 20 20 20 20 20 20 20 20  E",             
1c10: 22 54 4b 5f 45 4c 53 45 22 2c 20 20 20 20 20 20  "TK_ELSE",      
1c20: 20 20 20 41 4c 57 41 59 53 20 20 20 20 20 20 20     ALWAYS       
1c30: 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b            },.  {
1c40: 20 22 45 53 43 41 50 45 22 2c 20 20 20 20 20 20   "ESCAPE",      
1c50: 20 20 20 20 20 22 54 4b 5f 45 53 43 41 50 45 22       "TK_ESCAPE"
1c60: 2c 20 20 20 20 20 20 20 41 4c 57 41 59 53 20 20  ,       ALWAYS  
1c70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d                 }
1c80: 2c 0a 20 20 7b 20 22 45 58 43 45 50 54 22 2c 20  ,.  { "EXCEPT", 
1c90: 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f 45 58            "TK_EX
1ca0: 43 45 50 54 22 2c 20 20 20 20 20 20 20 43 4f 4d  CEPT",       COM
1cb0: 50 4f 55 4e 44 20 20 20 20 20 20 20 20 20 20 20  POUND           
1cc0: 20 20 20 20 7d 2c 0a 20 20 7b 20 22 45 58 43 4c      },.  { "EXCL
1cd0: 55 53 49 56 45 22 2c 20 20 20 20 20 20 20 20 22  USIVE",        "
1ce0: 54 4b 5f 45 58 43 4c 55 53 49 56 45 22 2c 20 20  TK_EXCLUSIVE",  
1cf0: 20 20 41 4c 57 41 59 53 20 20 20 20 20 20 20 20    ALWAYS        
1d00: 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20           },.  { 
1d10: 22 45 58 49 53 54 53 22 2c 20 20 20 20 20 20 20  "EXISTS",       
1d20: 20 20 20 20 22 54 4b 5f 45 58 49 53 54 53 22 2c      "TK_EXISTS",
1d30: 20 20 20 20 20 20 20 41 4c 57 41 59 53 20 20 20         ALWAYS   
1d40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c                },
1d50: 0a 20 20 7b 20 22 45 58 50 4c 41 49 4e 22 2c 20  .  { "EXPLAIN", 
1d60: 20 20 20 20 20 20 20 20 20 22 54 4b 5f 45 58 50           "TK_EXP
1d70: 4c 41 49 4e 22 2c 20 20 20 20 20 20 45 58 50 4c  LAIN",      EXPL
1d80: 41 49 4e 20 20 20 20 20 20 20 20 20 20 20 20 20  AIN             
1d90: 20 20 20 7d 2c 0a 20 20 7b 20 22 46 41 49 4c 22     },.  { "FAIL"
1da0: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 22 54  ,             "T
1db0: 4b 5f 46 41 49 4c 22 2c 20 20 20 20 20 20 20 20  K_FAIL",        
1dc0: 20 43 4f 4e 46 4c 49 43 54 7c 54 52 49 47 47 45   CONFLICT|TRIGGE
1dd0: 52 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22  R       },.  { "
1de0: 46 49 4c 54 45 52 22 2c 20 20 20 20 20 20 20 20  FILTER",        
1df0: 20 20 20 22 54 4b 5f 46 49 4c 54 45 52 22 2c 20     "TK_FILTER", 
1e00: 20 20 20 20 20 20 57 49 4e 44 4f 57 46 55 4e 43        WINDOWFUNC
1e10: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a               },.
1e20: 20 20 7b 20 22 46 4f 4c 4c 4f 57 49 4e 47 22 2c    { "FOLLOWING",
1e30: 20 20 20 20 20 20 20 20 22 54 4b 5f 46 4f 4c 4c          "TK_FOLL
1e40: 4f 57 49 4e 47 22 2c 20 20 20 20 57 49 4e 44 4f  OWING",    WINDO
1e50: 57 46 55 4e 43 20 20 20 20 20 20 20 20 20 20 20  WFUNC           
1e60: 20 20 7d 2c 0a 20 20 7b 20 22 46 4f 52 22 2c 20    },.  { "FOR", 
1e70: 20 20 20 20 20 20 20 20 20 20 20 20 20 22 54 4b               "TK
1e80: 5f 46 4f 52 22 2c 20 20 20 20 20 20 20 20 20 20  _FOR",          
1e90: 54 52 49 47 47 45 52 20 20 20 20 20 20 20 20 20  TRIGGER         
1ea0: 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 46         },.  { "F
1eb0: 4f 52 45 49 47 4e 22 2c 20 20 20 20 20 20 20 20  OREIGN",        
1ec0: 20 20 22 54 4b 5f 46 4f 52 45 49 47 4e 22 2c 20    "TK_FOREIGN", 
1ed0: 20 20 20 20 20 46 4b 45 59 20 20 20 20 20 20 20       FKEY       
1ee0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20              },. 
1ef0: 20 7b 20 22 46 52 4f 4d 22 2c 20 20 20 20 20 20   { "FROM",      
1f00: 20 20 20 20 20 20 20 22 54 4b 5f 46 52 4f 4d 22         "TK_FROM"
1f10: 2c 20 20 20 20 20 20 20 20 20 41 4c 57 41 59 53  ,         ALWAYS
1f20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1f30: 20 7d 2c 0a 20 20 7b 20 22 46 55 4c 4c 22 2c 20   },.  { "FULL", 
1f40: 20 20 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f              "TK_
1f50: 4a 4f 49 4e 5f 4b 57 22 2c 20 20 20 20 20 20 41  JOIN_KW",      A
1f60: 4c 57 41 59 53 20 20 20 20 20 20 20 20 20 20 20  LWAYS           
1f70: 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 47 4c        },.  { "GL
1f80: 4f 42 22 2c 20 20 20 20 20 20 20 20 20 20 20 20  OB",            
1f90: 20 22 54 4b 5f 4c 49 4b 45 5f 4b 57 22 2c 20 20   "TK_LIKE_KW",  
1fa0: 20 20 20 20 41 4c 57 41 59 53 20 20 20 20 20 20      ALWAYS      
1fb0: 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20             },.  
1fc0: 7b 20 22 47 52 4f 55 50 22 2c 20 20 20 20 20 20  { "GROUP",      
1fd0: 20 20 20 20 20 20 22 54 4b 5f 47 52 4f 55 50 22        "TK_GROUP"
1fe0: 2c 20 20 20 20 20 20 20 20 41 4c 57 41 59 53 20  ,        ALWAYS 
1ff0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2000: 7d 2c 0a 20 20 7b 20 22 48 41 56 49 4e 47 22 2c  },.  { "HAVING",
2010: 20 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f 48             "TK_H
2020: 41 56 49 4e 47 22 2c 20 20 20 20 20 20 20 41 4c  AVING",       AL
2030: 57 41 59 53 20 20 20 20 20 20 20 20 20 20 20 20  WAYS            
2040: 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 49 46 22       },.  { "IF"
2050: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,               
2060: 22 54 4b 5f 49 46 22 2c 20 20 20 20 20 20 20 20  "TK_IF",        
2070: 20 20 20 41 4c 57 41 59 53 20 20 20 20 20 20 20     ALWAYS       
2080: 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b            },.  {
2090: 20 22 49 47 4e 4f 52 45 22 2c 20 20 20 20 20 20   "IGNORE",      
20a0: 20 20 20 20 20 22 54 4b 5f 49 47 4e 4f 52 45 22       "TK_IGNORE"
20b0: 2c 20 20 20 20 20 20 20 43 4f 4e 46 4c 49 43 54  ,       CONFLICT
20c0: 7c 54 52 49 47 47 45 52 20 20 20 20 20 20 20 7d  |TRIGGER       }
20d0: 2c 0a 20 20 7b 20 22 49 4d 4d 45 44 49 41 54 45  ,.  { "IMMEDIATE
20e0: 22 2c 20 20 20 20 20 20 20 20 22 54 4b 5f 49 4d  ",        "TK_IM
20f0: 4d 45 44 49 41 54 45 22 2c 20 20 20 20 41 4c 57  MEDIATE",    ALW
2100: 41 59 53 20 20 20 20 20 20 20 20 20 20 20 20 20  AYS             
2110: 20 20 20 20 7d 2c 0a 20 20 7b 20 22 49 4e 22 2c      },.  { "IN",
2120: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22                 "
2130: 54 4b 5f 49 4e 22 2c 20 20 20 20 20 20 20 20 20  TK_IN",         
2140: 20 20 41 4c 57 41 59 53 20 20 20 20 20 20 20 20    ALWAYS        
2150: 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20           },.  { 
2160: 22 49 4e 44 45 58 22 2c 20 20 20 20 20 20 20 20  "INDEX",        
2170: 20 20 20 20 22 54 4b 5f 49 4e 44 45 58 22 2c 20      "TK_INDEX", 
2180: 20 20 20 20 20 20 20 41 4c 57 41 59 53 20 20 20         ALWAYS   
2190: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c                },
21a0: 0a 20 20 7b 20 22 49 4e 44 45 58 45 44 22 2c 20  .  { "INDEXED", 
21b0: 20 20 20 20 20 20 20 20 20 22 54 4b 5f 49 4e 44           "TK_IND
21c0: 45 58 45 44 22 2c 20 20 20 20 20 20 41 4c 57 41  EXED",      ALWA
21d0: 59 53 20 20 20 20 20 20 20 20 20 20 20 20 20 20  YS              
21e0: 20 20 20 7d 2c 0a 20 20 7b 20 22 49 4e 49 54 49     },.  { "INITI
21f0: 41 4c 4c 59 22 2c 20 20 20 20 20 20 20 20 22 54  ALLY",        "T
2200: 4b 5f 49 4e 49 54 49 41 4c 4c 59 22 2c 20 20 20  K_INITIALLY",   
2210: 20 46 4b 45 59 20 20 20 20 20 20 20 20 20 20 20   FKEY           
2220: 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22          },.  { "
2230: 49 4e 4e 45 52 22 2c 20 20 20 20 20 20 20 20 20  INNER",         
2240: 20 20 20 22 54 4b 5f 4a 4f 49 4e 5f 4b 57 22 2c     "TK_JOIN_KW",
2250: 20 20 20 20 20 20 41 4c 57 41 59 53 20 20 20 20        ALWAYS    
2260: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a               },.
2270: 20 20 7b 20 22 49 4e 53 45 52 54 22 2c 20 20 20    { "INSERT",   
2280: 20 20 20 20 20 20 20 20 22 54 4b 5f 49 4e 53 45          "TK_INSE
2290: 52 54 22 2c 20 20 20 20 20 20 20 41 4c 57 41 59  RT",       ALWAY
22a0: 53 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  S               
22b0: 20 20 7d 2c 0a 20 20 7b 20 22 49 4e 53 54 45 41    },.  { "INSTEA
22c0: 44 22 2c 20 20 20 20 20 20 20 20 20 20 22 54 4b  D",          "TK
22d0: 5f 49 4e 53 54 45 41 44 22 2c 20 20 20 20 20 20  _INSTEAD",      
22e0: 54 52 49 47 47 45 52 20 20 20 20 20 20 20 20 20  TRIGGER         
22f0: 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 49         },.  { "I
2300: 4e 54 45 52 53 45 43 54 22 2c 20 20 20 20 20 20  NTERSECT",      
2310: 20 20 22 54 4b 5f 49 4e 54 45 52 53 45 43 54 22    "TK_INTERSECT"
2320: 2c 20 20 20 20 43 4f 4d 50 4f 55 4e 44 20 20 20  ,    COMPOUND   
2330: 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20              },. 
2340: 20 7b 20 22 49 4e 54 4f 22 2c 20 20 20 20 20 20   { "INTO",      
2350: 20 20 20 20 20 20 20 22 54 4b 5f 49 4e 54 4f 22         "TK_INTO"
2360: 2c 20 20 20 20 20 20 20 20 20 41 4c 57 41 59 53  ,         ALWAYS
2370: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2380: 20 7d 2c 0a 20 20 7b 20 22 49 53 22 2c 20 20 20   },.  { "IS",   
2390: 20 20 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f              "TK_
23a0: 49 53 22 2c 20 20 20 20 20 20 20 20 20 20 20 41  IS",           A
23b0: 4c 57 41 59 53 20 20 20 20 20 20 20 20 20 20 20  LWAYS           
23c0: 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 49 53        },.  { "IS
23d0: 4e 55 4c 4c 22 2c 20 20 20 20 20 20 20 20 20 20  NULL",          
23e0: 20 22 54 4b 5f 49 53 4e 55 4c 4c 22 2c 20 20 20   "TK_ISNULL",   
23f0: 20 20 20 20 41 4c 57 41 59 53 20 20 20 20 20 20      ALWAYS      
2400: 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20             },.  
2410: 7b 20 22 4a 4f 49 4e 22 2c 20 20 20 20 20 20 20  { "JOIN",       
2420: 20 20 20 20 20 20 22 54 4b 5f 4a 4f 49 4e 22 2c        "TK_JOIN",
2430: 20 20 20 20 20 20 20 20 20 41 4c 57 41 59 53 20           ALWAYS 
2440: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2450: 7d 2c 0a 20 20 7b 20 22 4b 45 59 22 2c 20 20 20  },.  { "KEY",   
2460: 20 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f 4b             "TK_K
2470: 45 59 22 2c 20 20 20 20 20 20 20 20 20 20 41 4c  EY",          AL
2480: 57 41 59 53 20 20 20 20 20 20 20 20 20 20 20 20  WAYS            
2490: 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 4c 45 46       },.  { "LEF
24a0: 54 22 2c 20 20 20 20 20 20 20 20 20 20 20 20 20  T",             
24b0: 22 54 4b 5f 4a 4f 49 4e 5f 4b 57 22 2c 20 20 20  "TK_JOIN_KW",   
24c0: 20 20 20 41 4c 57 41 59 53 20 20 20 20 20 20 20     ALWAYS       
24d0: 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b            },.  {
24e0: 20 22 4c 49 4b 45 22 2c 20 20 20 20 20 20 20 20   "LIKE",        
24f0: 20 20 20 20 20 22 54 4b 5f 4c 49 4b 45 5f 4b 57       "TK_LIKE_KW
2500: 22 2c 20 20 20 20 20 20 41 4c 57 41 59 53 20 20  ",      ALWAYS  
2510: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d                 }
2520: 2c 0a 20 20 7b 20 22 4c 49 4d 49 54 22 2c 20 20  ,.  { "LIMIT",  
2530: 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f 4c 49            "TK_LI
2540: 4d 49 54 22 2c 20 20 20 20 20 20 20 20 41 4c 57  MIT",        ALW
2550: 41 59 53 20 20 20 20 20 20 20 20 20 20 20 20 20  AYS             
2560: 20 20 20 20 7d 2c 0a 20 20 7b 20 22 4d 41 54 43      },.  { "MATC
2570: 48 22 2c 20 20 20 20 20 20 20 20 20 20 20 20 22  H",            "
2580: 54 4b 5f 4d 41 54 43 48 22 2c 20 20 20 20 20 20  TK_MATCH",      
2590: 20 20 41 4c 57 41 59 53 20 20 20 20 20 20 20 20    ALWAYS        
25a0: 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20           },.  { 
25b0: 22 4e 41 54 55 52 41 4c 22 2c 20 20 20 20 20 20  "NATURAL",      
25c0: 20 20 20 20 22 54 4b 5f 4a 4f 49 4e 5f 4b 57 22      "TK_JOIN_KW"
25d0: 2c 20 20 20 20 20 20 41 4c 57 41 59 53 20 20 20  ,      ALWAYS   
25e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c                },
25f0: 0a 20 20 7b 20 22 4e 4f 22 2c 20 20 20 20 20 20  .  { "NO",      
2600: 20 20 20 20 20 20 20 20 20 22 54 4b 5f 4e 4f 22           "TK_NO"
2610: 2c 20 20 20 20 20 20 20 20 20 20 20 46 4b 45 59  ,           FKEY
2620: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2630: 20 20 20 7d 2c 0a 20 20 7b 20 22 4e 4f 54 22 2c     },.  { "NOT",
2640: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22 54                "T
2650: 4b 5f 4e 4f 54 22 2c 20 20 20 20 20 20 20 20 20  K_NOT",         
2660: 20 41 4c 57 41 59 53 20 20 20 20 20 20 20 20 20   ALWAYS         
2670: 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22          },.  { "
2680: 4e 4f 54 48 49 4e 47 22 2c 20 20 20 20 20 20 20  NOTHING",       
2690: 20 20 20 22 54 4b 5f 4e 4f 54 48 49 4e 47 22 2c     "TK_NOTHING",
26a0: 20 20 20 20 20 20 55 50 53 45 52 54 20 20 20 20        UPSERT    
26b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a               },.
26c0: 20 20 7b 20 22 4e 4f 54 4e 55 4c 4c 22 2c 20 20    { "NOTNULL",  
26d0: 20 20 20 20 20 20 20 20 22 54 4b 5f 4e 4f 54 4e          "TK_NOTN
26e0: 55 4c 4c 22 2c 20 20 20 20 20 20 41 4c 57 41 59  ULL",      ALWAY
26f0: 53 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  S               
2700: 20 20 7d 2c 0a 20 20 7b 20 22 4e 55 4c 4c 22 2c    },.  { "NULL",
2710: 20 20 20 20 20 20 20 20 20 20 20 20 20 22 54 4b               "TK
2720: 5f 4e 55 4c 4c 22 2c 20 20 20 20 20 20 20 20 20  _NULL",         
2730: 41 4c 57 41 59 53 20 20 20 20 20 20 20 20 20 20  ALWAYS          
2740: 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 4f         },.  { "O
2750: 46 22 2c 20 20 20 20 20 20 20 20 20 20 20 20 20  F",             
2760: 20 20 22 54 4b 5f 4f 46 22 2c 20 20 20 20 20 20    "TK_OF",      
2770: 20 20 20 20 20 41 4c 57 41 59 53 20 20 20 20 20       ALWAYS     
2780: 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20              },. 
2790: 20 7b 20 22 4f 46 46 53 45 54 22 2c 20 20 20 20   { "OFFSET",    
27a0: 20 20 20 20 20 20 20 22 54 4b 5f 4f 46 46 53 45         "TK_OFFSE
27b0: 54 22 2c 20 20 20 20 20 20 20 41 4c 57 41 59 53  T",       ALWAYS
27c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
27d0: 20 7d 2c 0a 20 20 7b 20 22 4f 4e 22 2c 20 20 20   },.  { "ON",   
27e0: 20 20 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f              "TK_
27f0: 4f 4e 22 2c 20 20 20 20 20 20 20 20 20 20 20 41  ON",           A
2800: 4c 57 41 59 53 20 20 20 20 20 20 20 20 20 20 20  LWAYS           
2810: 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 4f 52        },.  { "OR
2820: 22 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ",              
2830: 20 22 54 4b 5f 4f 52 22 2c 20 20 20 20 20 20 20   "TK_OR",       
2840: 20 20 20 20 41 4c 57 41 59 53 20 20 20 20 20 20      ALWAYS      
2850: 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20             },.  
2860: 7b 20 22 4f 52 44 45 52 22 2c 20 20 20 20 20 20  { "ORDER",      
2870: 20 20 20 20 20 20 22 54 4b 5f 4f 52 44 45 52 22        "TK_ORDER"
2880: 2c 20 20 20 20 20 20 20 20 41 4c 57 41 59 53 20  ,        ALWAYS 
2890: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
28a0: 7d 2c 0a 20 20 7b 20 22 4f 55 54 45 52 22 2c 20  },.  { "OUTER", 
28b0: 20 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f 4a             "TK_J
28c0: 4f 49 4e 5f 4b 57 22 2c 20 20 20 20 20 20 41 4c  OIN_KW",      AL
28d0: 57 41 59 53 20 20 20 20 20 20 20 20 20 20 20 20  WAYS            
28e0: 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 4f 56 45       },.  { "OVE
28f0: 52 22 2c 20 20 20 20 20 20 20 20 20 20 20 20 20  R",             
2900: 22 54 4b 5f 4f 56 45 52 22 2c 20 20 20 20 20 20  "TK_OVER",      
2910: 20 20 20 57 49 4e 44 4f 57 46 55 4e 43 20 20 20     WINDOWFUNC   
2920: 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b            },.  {
2930: 20 22 50 41 52 54 49 54 49 4f 4e 22 2c 20 20 20   "PARTITION",   
2940: 20 20 20 20 20 22 54 4b 5f 50 41 52 54 49 54 49       "TK_PARTITI
2950: 4f 4e 22 2c 20 20 20 20 57 49 4e 44 4f 57 46 55  ON",    WINDOWFU
2960: 4e 43 20 20 20 20 20 20 20 20 20 20 20 20 20 7d  NC             }
2970: 2c 0a 20 20 7b 20 22 50 4c 41 4e 22 2c 20 20 20  ,.  { "PLAN",   
2980: 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f 50 4c            "TK_PL
2990: 41 4e 22 2c 20 20 20 20 20 20 20 20 20 45 58 50  AN",         EXP
29a0: 4c 41 49 4e 20 20 20 20 20 20 20 20 20 20 20 20  LAIN            
29b0: 20 20 20 20 7d 2c 0a 20 20 7b 20 22 50 52 41 47      },.  { "PRAG
29c0: 4d 41 22 2c 20 20 20 20 20 20 20 20 20 20 20 22  MA",           "
29d0: 54 4b 5f 50 52 41 47 4d 41 22 2c 20 20 20 20 20  TK_PRAGMA",     
29e0: 20 20 50 52 41 47 4d 41 20 20 20 20 20 20 20 20    PRAGMA        
29f0: 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20           },.  { 
2a00: 22 50 52 45 43 45 44 49 4e 47 22 2c 20 20 20 20  "PRECEDING",    
2a10: 20 20 20 20 22 54 4b 5f 50 52 45 43 45 44 49 4e      "TK_PRECEDIN
2a20: 47 22 2c 20 20 20 20 57 49 4e 44 4f 57 46 55 4e  G",    WINDOWFUN
2a30: 43 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c  C             },
2a40: 0a 20 20 7b 20 22 50 52 49 4d 41 52 59 22 2c 20  .  { "PRIMARY", 
2a50: 20 20 20 20 20 20 20 20 20 22 54 4b 5f 50 52 49           "TK_PRI
2a60: 4d 41 52 59 22 2c 20 20 20 20 20 20 41 4c 57 41  MARY",      ALWA
2a70: 59 53 20 20 20 20 20 20 20 20 20 20 20 20 20 20  YS              
2a80: 20 20 20 7d 2c 0a 20 20 7b 20 22 51 55 45 52 59     },.  { "QUERY
2a90: 22 2c 20 20 20 20 20 20 20 20 20 20 20 20 22 54  ",            "T
2aa0: 4b 5f 51 55 45 52 59 22 2c 20 20 20 20 20 20 20  K_QUERY",       
2ab0: 20 45 58 50 4c 41 49 4e 20 20 20 20 20 20 20 20   EXPLAIN        
2ac0: 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22          },.  { "
2ad0: 52 41 49 53 45 22 2c 20 20 20 20 20 20 20 20 20  RAISE",         
2ae0: 20 20 20 22 54 4b 5f 52 41 49 53 45 22 2c 20 20     "TK_RAISE",  
2af0: 20 20 20 20 20 20 54 52 49 47 47 45 52 20 20 20        TRIGGER   
2b00: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a               },.
2b10: 20 20 7b 20 22 52 41 4e 47 45 22 2c 20 20 20 20    { "RANGE",    
2b20: 20 20 20 20 20 20 20 20 22 54 4b 5f 52 41 4e 47          "TK_RANG
2b30: 45 22 2c 20 20 20 20 20 20 20 20 57 49 4e 44 4f  E",        WINDO
2b40: 57 46 55 4e 43 20 20 20 20 20 20 20 20 20 20 20  WFUNC           
2b50: 20 20 7d 2c 0a 20 20 7b 20 22 52 45 43 55 52 53    },.  { "RECURS
2b60: 49 56 45 22 2c 20 20 20 20 20 20 20 20 22 54 4b  IVE",        "TK
2b70: 5f 52 45 43 55 52 53 49 56 45 22 2c 20 20 20 20  _RECURSIVE",    
2b80: 43 54 45 20 20 20 20 20 20 20 20 20 20 20 20 20  CTE             
2b90: 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 52         },.  { "R
2ba0: 45 46 45 52 45 4e 43 45 53 22 2c 20 20 20 20 20  EFERENCES",     
2bb0: 20 20 22 54 4b 5f 52 45 46 45 52 45 4e 43 45 53    "TK_REFERENCES
2bc0: 22 2c 20 20 20 46 4b 45 59 20 20 20 20 20 20 20  ",   FKEY       
2bd0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20              },. 
2be0: 20 7b 20 22 52 45 47 45 58 50 22 2c 20 20 20 20   { "REGEXP",    
2bf0: 20 20 20 20 20 20 20 22 54 4b 5f 4c 49 4b 45 5f         "TK_LIKE_
2c00: 4b 57 22 2c 20 20 20 20 20 20 41 4c 57 41 59 53  KW",      ALWAYS
2c10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2c20: 20 7d 2c 0a 20 20 7b 20 22 52 45 49 4e 44 45 58   },.  { "REINDEX
2c30: 22 2c 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f  ",          "TK_
2c40: 52 45 49 4e 44 45 58 22 2c 20 20 20 20 20 20 52  REINDEX",      R
2c50: 45 49 4e 44 45 58 20 20 20 20 20 20 20 20 20 20  EINDEX          
2c60: 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 52 45        },.  { "RE
2c70: 4c 45 41 53 45 22 2c 20 20 20 20 20 20 20 20 20  LEASE",         
2c80: 20 22 54 4b 5f 52 45 4c 45 41 53 45 22 2c 20 20   "TK_RELEASE",  
2c90: 20 20 20 20 41 4c 57 41 59 53 20 20 20 20 20 20      ALWAYS      
2ca0: 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20             },.  
2cb0: 7b 20 22 52 45 4e 41 4d 45 22 2c 20 20 20 20 20  { "RENAME",     
2cc0: 20 20 20 20 20 20 22 54 4b 5f 52 45 4e 41 4d 45        "TK_RENAME
2cd0: 22 2c 20 20 20 20 20 20 20 41 4c 54 45 52 20 20  ",       ALTER  
2ce0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2cf0: 7d 2c 0a 20 20 7b 20 22 52 45 50 4c 41 43 45 22  },.  { "REPLACE"
2d00: 2c 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f 52  ,          "TK_R
2d10: 45 50 4c 41 43 45 22 2c 20 20 20 20 20 20 43 4f  EPLACE",      CO
2d20: 4e 46 4c 49 43 54 20 20 20 20 20 20 20 20 20 20  NFLICT          
2d30: 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 52 45 53       },.  { "RES
2d40: 54 52 49 43 54 22 2c 20 20 20 20 20 20 20 20 20  TRICT",         
2d50: 22 54 4b 5f 52 45 53 54 52 49 43 54 22 2c 20 20  "TK_RESTRICT",  
2d60: 20 20 20 46 4b 45 59 20 20 20 20 20 20 20 20 20     FKEY         
2d70: 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b            },.  {
2d80: 20 22 52 49 47 48 54 22 2c 20 20 20 20 20 20 20   "RIGHT",       
2d90: 20 20 20 20 20 22 54 4b 5f 4a 4f 49 4e 5f 4b 57       "TK_JOIN_KW
2da0: 22 2c 20 20 20 20 20 20 41 4c 57 41 59 53 20 20  ",      ALWAYS  
2db0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d                 }
2dc0: 2c 0a 20 20 7b 20 22 52 4f 4c 4c 42 41 43 4b 22  ,.  { "ROLLBACK"
2dd0: 2c 20 20 20 20 20 20 20 20 20 22 54 4b 5f 52 4f  ,         "TK_RO
2de0: 4c 4c 42 41 43 4b 22 2c 20 20 20 20 20 41 4c 57  LLBACK",     ALW
2df0: 41 59 53 20 20 20 20 20 20 20 20 20 20 20 20 20  AYS             
2e00: 20 20 20 20 7d 2c 0a 20 20 7b 20 22 52 4f 57 22      },.  { "ROW"
2e10: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22  ,              "
2e20: 54 4b 5f 52 4f 57 22 2c 20 20 20 20 20 20 20 20  TK_ROW",        
2e30: 20 20 54 52 49 47 47 45 52 20 20 20 20 20 20 20    TRIGGER       
2e40: 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20           },.  { 
2e50: 22 52 4f 57 53 22 2c 20 20 20 20 20 20 20 20 20  "ROWS",         
2e60: 20 20 20 20 22 54 4b 5f 52 4f 57 53 22 2c 20 20      "TK_ROWS",  
2e70: 20 20 20 20 20 20 20 41 4c 57 41 59 53 20 20 20         ALWAYS   
2e80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c                },
2e90: 0a 20 20 7b 20 22 53 41 56 45 50 4f 49 4e 54 22  .  { "SAVEPOINT"
2ea0: 2c 20 20 20 20 20 20 20 20 22 54 4b 5f 53 41 56  ,        "TK_SAV
2eb0: 45 50 4f 49 4e 54 22 2c 20 20 20 20 41 4c 57 41  EPOINT",    ALWA
2ec0: 59 53 20 20 20 20 20 20 20 20 20 20 20 20 20 20  YS              
2ed0: 20 20 20 7d 2c 0a 20 20 7b 20 22 53 45 4c 45 43     },.  { "SELEC
2ee0: 54 22 2c 20 20 20 20 20 20 20 20 20 20 20 22 54  T",           "T
2ef0: 4b 5f 53 45 4c 45 43 54 22 2c 20 20 20 20 20 20  K_SELECT",      
2f00: 20 41 4c 57 41 59 53 20 20 20 20 20 20 20 20 20   ALWAYS         
2f10: 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22          },.  { "
2f20: 53 45 54 22 2c 20 20 20 20 20 20 20 20 20 20 20  SET",           
2f30: 20 20 20 22 54 4b 5f 53 45 54 22 2c 20 20 20 20     "TK_SET",    
2f40: 20 20 20 20 20 20 41 4c 57 41 59 53 20 20 20 20        ALWAYS    
2f50: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a               },.
2f60: 20 20 7b 20 22 54 41 42 4c 45 22 2c 20 20 20 20    { "TABLE",    
2f70: 20 20 20 20 20 20 20 20 22 54 4b 5f 54 41 42 4c          "TK_TABL
2f80: 45 22 2c 20 20 20 20 20 20 20 20 41 4c 57 41 59  E",        ALWAY
2f90: 53 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  S               
2fa0: 20 20 7d 2c 0a 20 20 7b 20 22 54 45 4d 50 22 2c    },.  { "TEMP",
2fb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 22 54 4b               "TK
2fc0: 5f 54 45 4d 50 22 2c 20 20 20 20 20 20 20 20 20  _TEMP",         
2fd0: 41 4c 57 41 59 53 20 20 20 20 20 20 20 20 20 20  ALWAYS          
2fe0: 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 54         },.  { "T
2ff0: 45 4d 50 4f 52 41 52 59 22 2c 20 20 20 20 20 20  EMPORARY",      
3000: 20 20 22 54 4b 5f 54 45 4d 50 22 2c 20 20 20 20    "TK_TEMP",    
3010: 20 20 20 20 20 41 4c 57 41 59 53 20 20 20 20 20       ALWAYS     
3020: 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20              },. 
3030: 20 7b 20 22 54 48 45 4e 22 2c 20 20 20 20 20 20   { "THEN",      
3040: 20 20 20 20 20 20 20 22 54 4b 5f 54 48 45 4e 22         "TK_THEN"
3050: 2c 20 20 20 20 20 20 20 20 20 41 4c 57 41 59 53  ,         ALWAYS
3060: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3070: 20 7d 2c 0a 20 20 7b 20 22 54 4f 22 2c 20 20 20   },.  { "TO",   
3080: 20 20 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f              "TK_
3090: 54 4f 22 2c 20 20 20 20 20 20 20 20 20 20 20 41  TO",           A
30a0: 4c 57 41 59 53 20 20 20 20 20 20 20 20 20 20 20  LWAYS           
30b0: 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 54 52        },.  { "TR
30c0: 41 4e 53 41 43 54 49 4f 4e 22 2c 20 20 20 20 20  ANSACTION",     
30d0: 20 22 54 4b 5f 54 52 41 4e 53 41 43 54 49 4f 4e   "TK_TRANSACTION
30e0: 22 2c 20 20 41 4c 57 41 59 53 20 20 20 20 20 20  ",  ALWAYS      
30f0: 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20             },.  
3100: 7b 20 22 54 52 49 47 47 45 52 22 2c 20 20 20 20  { "TRIGGER",    
3110: 20 20 20 20 20 20 22 54 4b 5f 54 52 49 47 47 45        "TK_TRIGGE
3120: 52 22 2c 20 20 20 20 20 20 54 52 49 47 47 45 52  R",      TRIGGER
3130: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3140: 7d 2c 0a 20 20 7b 20 22 55 4e 42 4f 55 4e 44 45  },.  { "UNBOUNDE
3150: 44 22 2c 20 20 20 20 20 20 20 20 22 54 4b 5f 55  D",        "TK_U
3160: 4e 42 4f 55 4e 44 45 44 22 2c 20 20 20 20 57 49  NBOUNDED",    WI
3170: 4e 44 4f 57 46 55 4e 43 20 20 20 20 20 20 20 20  NDOWFUNC        
3180: 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 55 4e 49       },.  { "UNI
3190: 4f 4e 22 2c 20 20 20 20 20 20 20 20 20 20 20 20  ON",            
31a0: 22 54 4b 5f 55 4e 49 4f 4e 22 2c 20 20 20 20 20  "TK_UNION",     
31b0: 20 20 20 43 4f 4d 50 4f 55 4e 44 20 20 20 20 20     COMPOUND     
31c0: 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b            },.  {
31d0: 20 22 55 4e 49 51 55 45 22 2c 20 20 20 20 20 20   "UNIQUE",      
31e0: 20 20 20 20 20 22 54 4b 5f 55 4e 49 51 55 45 22       "TK_UNIQUE"
31f0: 2c 20 20 20 20 20 20 20 41 4c 57 41 59 53 20 20  ,       ALWAYS  
3200: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d                 }
3210: 2c 0a 20 20 7b 20 22 55 50 44 41 54 45 22 2c 20  ,.  { "UPDATE", 
3220: 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f 55 50            "TK_UP
3230: 44 41 54 45 22 2c 20 20 20 20 20 20 20 41 4c 57  DATE",       ALW
3240: 41 59 53 20 20 20 20 20 20 20 20 20 20 20 20 20  AYS             
3250: 20 20 20 20 7d 2c 0a 20 20 7b 20 22 55 53 49 4e      },.  { "USIN
3260: 47 22 2c 20 20 20 20 20 20 20 20 20 20 20 20 22  G",            "
3270: 54 4b 5f 55 53 49 4e 47 22 2c 20 20 20 20 20 20  TK_USING",      
3280: 20 20 41 4c 57 41 59 53 20 20 20 20 20 20 20 20    ALWAYS        
3290: 20 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20           },.  { 
32a0: 22 56 41 43 55 55 4d 22 2c 20 20 20 20 20 20 20  "VACUUM",       
32b0: 20 20 20 20 22 54 4b 5f 56 41 43 55 55 4d 22 2c      "TK_VACUUM",
32c0: 20 20 20 20 20 20 20 56 41 43 55 55 4d 20 20 20         VACUUM   
32d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c                },
32e0: 0a 20 20 7b 20 22 56 41 4c 55 45 53 22 2c 20 20  .  { "VALUES",  
32f0: 20 20 20 20 20 20 20 20 20 22 54 4b 5f 56 41 4c           "TK_VAL
3300: 55 45 53 22 2c 20 20 20 20 20 20 20 41 4c 57 41  UES",       ALWA
3310: 59 53 20 20 20 20 20 20 20 20 20 20 20 20 20 20  YS              
3320: 20 20 20 7d 2c 0a 20 20 7b 20 22 56 49 45 57 22     },.  { "VIEW"
3330: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 22 54  ,             "T
3340: 4b 5f 56 49 45 57 22 2c 20 20 20 20 20 20 20 20  K_VIEW",        
3350: 20 56 49 45 57 20 20 20 20 20 20 20 20 20 20 20   VIEW           
3360: 20 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22          },.  { "
3370: 56 49 52 54 55 41 4c 22 2c 20 20 20 20 20 20 20  VIRTUAL",       
3380: 20 20 20 22 54 4b 5f 56 49 52 54 55 41 4c 22 2c     "TK_VIRTUAL",
3390: 20 20 20 20 20 20 56 54 41 42 20 20 20 20 20 20        VTAB      
33a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a               },.
33b0: 20 20 7b 20 22 57 49 4e 44 4f 57 22 2c 20 20 20    { "WINDOW",   
33c0: 20 20 20 20 20 20 20 20 22 54 4b 5f 57 49 4e 44          "TK_WIND
33d0: 4f 57 22 2c 20 20 20 20 20 20 20 57 49 4e 44 4f  OW",       WINDO
33e0: 57 46 55 4e 43 20 20 20 20 20 20 20 20 20 20 20  WFUNC           
33f0: 20 20 7d 2c 0a 20 20 7b 20 22 57 49 54 48 22 2c    },.  { "WITH",
3400: 20 20 20 20 20 20 20 20 20 20 20 20 20 22 54 4b               "TK
3410: 5f 57 49 54 48 22 2c 20 20 20 20 20 20 20 20 20  _WITH",         
3420: 43 54 45 20 20 20 20 20 20 20 20 20 20 20 20 20  CTE             
3430: 20 20 20 20 20 20 20 7d 2c 0a 20 20 7b 20 22 57         },.  { "W
3440: 49 54 48 4f 55 54 22 2c 20 20 20 20 20 20 20 20  ITHOUT",        
3450: 20 20 22 54 4b 5f 57 49 54 48 4f 55 54 22 2c 20    "TK_WITHOUT", 
3460: 20 20 20 20 20 41 4c 57 41 59 53 20 20 20 20 20       ALWAYS     
3470: 20 20 20 20 20 20 20 20 20 20 20 20 7d 2c 0a 20              },. 
3480: 20 7b 20 22 57 48 45 4e 22 2c 20 20 20 20 20 20   { "WHEN",      
3490: 20 20 20 20 20 20 20 22 54 4b 5f 57 48 45 4e 22         "TK_WHEN"
34a0: 2c 20 20 20 20 20 20 20 20 20 41 4c 57 41 59 53  ,         ALWAYS
34b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
34c0: 20 7d 2c 0a 20 20 7b 20 22 57 48 45 52 45 22 2c   },.  { "WHERE",
34d0: 20 20 20 20 20 20 20 20 20 20 20 20 22 54 4b 5f              "TK_
34e0: 57 48 45 52 45 22 2c 20 20 20 20 20 20 20 20 41  WHERE",        A
34f0: 4c 57 41 59 53 20 20 20 20 20 20 20 20 20 20 20  LWAYS           
3500: 20 20 20 20 20 20 7d 2c 0a 7d 3b 0a 0a 2f 2a 20        },.};../* 
3510: 4e 75 6d 62 65 72 20 6f 66 20 6b 65 79 77 6f 72  Number of keywor
3520: 64 73 20 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74  ds */.static int
3530: 20 6e 4b 65 79 77 6f 72 64 20 3d 20 28 73 69 7a   nKeyword = (siz
3540: 65 6f 66 28 61 4b 65 79 77 6f 72 64 54 61 62 6c  eof(aKeywordTabl
3550: 65 29 2f 73 69 7a 65 6f 66 28 61 4b 65 79 77 6f  e)/sizeof(aKeywo
3560: 72 64 54 61 62 6c 65 5b 30 5d 29 29 3b 0a 0a 2f  rdTable[0]));../
3570: 2a 20 4d 61 70 20 61 6c 6c 20 61 6c 70 68 61 62  * Map all alphab
3580: 65 74 69 63 20 63 68 61 72 61 63 74 65 72 73 20  etic characters 
3590: 69 6e 74 6f 20 6c 6f 77 65 72 2d 63 61 73 65 20  into lower-case 
35a0: 66 6f 72 20 68 61 73 68 69 6e 67 2e 20 20 54 68  for hashing.  Th
35b0: 69 73 20 69 73 0a 2a 2a 20 6f 6e 6c 79 20 76 61  is is.** only va
35c0: 6c 69 64 20 66 6f 72 20 61 6c 70 68 61 62 65 74  lid for alphabet
35d0: 69 63 73 2e 20 20 49 6e 20 70 61 72 74 69 63 75  ics.  In particu
35e0: 6c 61 72 20 69 74 20 64 6f 65 73 20 6e 6f 74 20  lar it does not 
35f0: 77 6f 72 6b 20 66 6f 72 20 27 5f 27 0a 2a 2a 20  work for '_'.** 
3600: 61 6e 64 20 73 6f 20 74 68 65 20 68 61 73 68 20  and so the hash 
3610: 63 61 6e 6e 6f 74 20 62 65 20 6f 6e 20 61 20 6b  cannot be on a k
3620: 65 79 77 6f 72 64 20 70 6f 73 69 74 69 6f 6e 20  eyword position 
3630: 74 68 61 74 20 6d 69 67 68 74 20 62 65 20 61 6e  that might be an
3640: 20 27 5f 27 2e 0a 2a 2f 0a 23 64 65 66 69 6e 65   '_'..*/.#define
3650: 20 63 68 61 72 4d 61 70 28 58 29 20 20 20 28 30   charMap(X)   (0
3660: 78 32 30 7c 28 58 29 29 0a 0a 2f 2a 0a 2a 2a 20  x20|(X))../*.** 
3670: 43 6f 6d 70 61 72 69 73 69 6f 6e 20 66 75 6e 63  Comparision func
3680: 74 69 6f 6e 20 66 6f 72 20 74 77 6f 20 4b 65 79  tion for two Key
3690: 77 6f 72 64 20 72 65 63 6f 72 64 73 0a 2a 2f 0a  word records.*/.
36a0: 73 74 61 74 69 63 20 69 6e 74 20 6b 65 79 77 6f  static int keywo
36b0: 72 64 43 6f 6d 70 61 72 65 31 28 63 6f 6e 73 74  rdCompare1(const
36c0: 20 76 6f 69 64 20 2a 61 2c 20 63 6f 6e 73 74 20   void *a, const 
36d0: 76 6f 69 64 20 2a 62 29 7b 0a 20 20 63 6f 6e 73  void *b){.  cons
36e0: 74 20 4b 65 79 77 6f 72 64 20 2a 70 41 20 3d 20  t Keyword *pA = 
36f0: 28 4b 65 79 77 6f 72 64 2a 29 61 3b 0a 20 20 63  (Keyword*)a;.  c
3700: 6f 6e 73 74 20 4b 65 79 77 6f 72 64 20 2a 70 42  onst Keyword *pB
3710: 20 3d 20 28 4b 65 79 77 6f 72 64 2a 29 62 3b 0a   = (Keyword*)b;.
3720: 20 20 69 6e 74 20 6e 20 3d 20 70 41 2d 3e 6c 65    int n = pA->le
3730: 6e 20 2d 20 70 42 2d 3e 6c 65 6e 3b 0a 20 20 69  n - pB->len;.  i
3740: 66 28 20 6e 3d 3d 30 20 29 7b 0a 20 20 20 20 6e  f( n==0 ){.    n
3750: 20 3d 20 73 74 72 63 6d 70 28 70 41 2d 3e 7a 4e   = strcmp(pA->zN
3760: 61 6d 65 2c 20 70 42 2d 3e 7a 4e 61 6d 65 29 3b  ame, pB->zName);
3770: 0a 20 20 7d 0a 20 20 61 73 73 65 72 74 28 20 6e  .  }.  assert( n
3780: 21 3d 30 20 29 3b 0a 20 20 72 65 74 75 72 6e 20  !=0 );.  return 
3790: 6e 3b 0a 7d 0a 73 74 61 74 69 63 20 69 6e 74 20  n;.}.static int 
37a0: 6b 65 79 77 6f 72 64 43 6f 6d 70 61 72 65 32 28  keywordCompare2(
37b0: 63 6f 6e 73 74 20 76 6f 69 64 20 2a 61 2c 20 63  const void *a, c
37c0: 6f 6e 73 74 20 76 6f 69 64 20 2a 62 29 7b 0a 20  onst void *b){. 
37d0: 20 63 6f 6e 73 74 20 4b 65 79 77 6f 72 64 20 2a   const Keyword *
37e0: 70 41 20 3d 20 28 4b 65 79 77 6f 72 64 2a 29 61  pA = (Keyword*)a
37f0: 3b 0a 20 20 63 6f 6e 73 74 20 4b 65 79 77 6f 72  ;.  const Keywor
3800: 64 20 2a 70 42 20 3d 20 28 4b 65 79 77 6f 72 64  d *pB = (Keyword
3810: 2a 29 62 3b 0a 20 20 69 6e 74 20 6e 20 3d 20 70  *)b;.  int n = p
3820: 42 2d 3e 6c 6f 6e 67 65 73 74 53 75 66 66 69 78  B->longestSuffix
3830: 20 2d 20 70 41 2d 3e 6c 6f 6e 67 65 73 74 53 75   - pA->longestSu
3840: 66 66 69 78 3b 0a 20 20 69 66 28 20 6e 3d 3d 30  ffix;.  if( n==0
3850: 20 29 7b 0a 20 20 20 20 6e 20 3d 20 73 74 72 63   ){.    n = strc
3860: 6d 70 28 70 41 2d 3e 7a 4e 61 6d 65 2c 20 70 42  mp(pA->zName, pB
3870: 2d 3e 7a 4e 61 6d 65 29 3b 0a 20 20 7d 0a 20 20  ->zName);.  }.  
3880: 61 73 73 65 72 74 28 20 6e 21 3d 30 20 29 3b 0a  assert( n!=0 );.
3890: 20 20 72 65 74 75 72 6e 20 6e 3b 0a 7d 0a 73 74    return n;.}.st
38a0: 61 74 69 63 20 69 6e 74 20 6b 65 79 77 6f 72 64  atic int keyword
38b0: 43 6f 6d 70 61 72 65 33 28 63 6f 6e 73 74 20 76  Compare3(const v
38c0: 6f 69 64 20 2a 61 2c 20 63 6f 6e 73 74 20 76 6f  oid *a, const vo
38d0: 69 64 20 2a 62 29 7b 0a 20 20 63 6f 6e 73 74 20  id *b){.  const 
38e0: 4b 65 79 77 6f 72 64 20 2a 70 41 20 3d 20 28 4b  Keyword *pA = (K
38f0: 65 79 77 6f 72 64 2a 29 61 3b 0a 20 20 63 6f 6e  eyword*)a;.  con
3900: 73 74 20 4b 65 79 77 6f 72 64 20 2a 70 42 20 3d  st Keyword *pB =
3910: 20 28 4b 65 79 77 6f 72 64 2a 29 62 3b 0a 20 20   (Keyword*)b;.  
3920: 69 6e 74 20 6e 20 3d 20 70 41 2d 3e 6f 66 66 73  int n = pA->offs
3930: 65 74 20 2d 20 70 42 2d 3e 6f 66 66 73 65 74 3b  et - pB->offset;
3940: 0a 20 20 69 66 28 20 6e 3d 3d 30 20 29 20 6e 20  .  if( n==0 ) n 
3950: 3d 20 70 42 2d 3e 69 64 20 2d 20 70 41 2d 3e 69  = pB->id - pA->i
3960: 64 3b 0a 20 20 61 73 73 65 72 74 28 20 6e 21 3d  d;.  assert( n!=
3970: 30 20 29 3b 0a 20 20 72 65 74 75 72 6e 20 6e 3b  0 );.  return n;
3980: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e  .}../*.** Return
3990: 20 61 20 4b 65 79 77 6f 72 64 54 61 62 6c 65 20   a KeywordTable 
39a0: 65 6e 74 72 79 20 77 69 74 68 20 74 68 65 20 67  entry with the g
39b0: 69 76 65 6e 20 69 64 0a 2a 2f 0a 73 74 61 74 69  iven id.*/.stati
39c0: 63 20 4b 65 79 77 6f 72 64 20 2a 66 69 6e 64 42  c Keyword *findB
39d0: 79 49 64 28 69 6e 74 20 69 64 29 7b 0a 20 20 69  yId(int id){.  i
39e0: 6e 74 20 69 3b 0a 20 20 66 6f 72 28 69 3d 30 3b  nt i;.  for(i=0;
39f0: 20 69 3c 6e 4b 65 79 77 6f 72 64 3b 20 69 2b 2b   i<nKeyword; i++
3a00: 29 7b 0a 20 20 20 20 69 66 28 20 61 4b 65 79 77  ){.    if( aKeyw
3a10: 6f 72 64 54 61 62 6c 65 5b 69 5d 2e 69 64 3d 3d  ordTable[i].id==
3a20: 69 64 20 29 20 62 72 65 61 6b 3b 0a 20 20 7d 0a  id ) break;.  }.
3a30: 20 20 72 65 74 75 72 6e 20 26 61 4b 65 79 77 6f    return &aKeywo
3a40: 72 64 54 61 62 6c 65 5b 69 5d 3b 0a 7d 0a 0a 2f  rdTable[i];.}../
3a50: 2a 0a 2a 2a 20 54 68 69 73 20 72 6f 75 74 69 6e  *.** This routin
3a60: 65 20 64 6f 65 73 20 74 68 65 20 77 6f 72 6b 2e  e does the work.
3a70: 20 20 54 68 65 20 67 65 6e 65 72 61 74 65 64 20    The generated 
3a80: 63 6f 64 65 20 69 73 20 70 72 69 6e 74 65 64 20  code is printed 
3a90: 6f 6e 20 73 74 61 6e 64 61 72 64 0a 2a 2a 20 6f  on standard.** o
3aa0: 75 74 70 75 74 2e 0a 2a 2f 0a 69 6e 74 20 6d 61  utput..*/.int ma
3ab0: 69 6e 28 69 6e 74 20 61 72 67 63 2c 20 63 68 61  in(int argc, cha
3ac0: 72 20 2a 2a 61 72 67 76 29 7b 0a 20 20 69 6e 74  r **argv){.  int
3ad0: 20 69 2c 20 6a 2c 20 6b 2c 20 68 3b 0a 20 20 69   i, j, k, h;.  i
3ae0: 6e 74 20 62 65 73 74 53 69 7a 65 2c 20 62 65 73  nt bestSize, bes
3af0: 74 43 6f 75 6e 74 3b 0a 20 20 69 6e 74 20 63 6f  tCount;.  int co
3b00: 75 6e 74 3b 0a 20 20 69 6e 74 20 6e 43 68 61 72  unt;.  int nChar
3b10: 3b 0a 20 20 69 6e 74 20 74 6f 74 61 6c 4c 65 6e  ;.  int totalLen
3b20: 20 3d 20 30 3b 0a 20 20 69 6e 74 20 61 4b 57 48   = 0;.  int aKWH
3b30: 61 73 68 5b 31 30 30 30 5d 3b 20 20 2f 2a 20 31  ash[1000];  /* 1
3b40: 30 30 30 20 69 73 20 6d 75 63 68 20 62 69 67 67  000 is much bigg
3b50: 65 72 20 74 68 61 6e 20 6e 4b 65 79 77 6f 72 64  er than nKeyword
3b60: 20 2a 2f 0a 20 20 63 68 61 72 20 7a 4b 57 54 65   */.  char zKWTe
3b70: 78 74 5b 32 30 30 30 5d 3b 0a 0a 20 20 2f 2a 20  xt[2000];..  /* 
3b80: 52 65 6d 6f 76 65 20 65 6e 74 72 69 65 73 20 66  Remove entries f
3b90: 72 6f 6d 20 74 68 65 20 6c 69 73 74 20 6f 66 20  rom the list of 
3ba0: 6b 65 79 77 6f 72 64 73 20 74 68 61 74 20 68 61  keywords that ha
3bb0: 76 65 20 6d 61 73 6b 3d 3d 30 20 2a 2f 0a 20 20  ve mask==0 */.  
3bc0: 66 6f 72 28 69 3d 6a 3d 30 3b 20 69 3c 6e 4b 65  for(i=j=0; i<nKe
3bd0: 79 77 6f 72 64 3b 20 69 2b 2b 29 7b 0a 20 20 20  yword; i++){.   
3be0: 20 69 66 28 20 61 4b 65 79 77 6f 72 64 54 61 62   if( aKeywordTab
3bf0: 6c 65 5b 69 5d 2e 6d 61 73 6b 3d 3d 30 20 29 20  le[i].mask==0 ) 
3c00: 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 69 66  continue;.    if
3c10: 28 20 6a 3c 69 20 29 7b 0a 20 20 20 20 20 20 61  ( j<i ){.      a
3c20: 4b 65 79 77 6f 72 64 54 61 62 6c 65 5b 6a 5d 20  KeywordTable[j] 
3c30: 3d 20 61 4b 65 79 77 6f 72 64 54 61 62 6c 65 5b  = aKeywordTable[
3c40: 69 5d 3b 0a 20 20 20 20 7d 0a 20 20 20 20 6a 2b  i];.    }.    j+
3c50: 2b 3b 0a 20 20 7d 0a 20 20 6e 4b 65 79 77 6f 72  +;.  }.  nKeywor
3c60: 64 20 3d 20 6a 3b 0a 0a 20 20 2f 2a 20 46 69 6c  d = j;..  /* Fil
3c70: 6c 20 69 6e 20 74 68 65 20 6c 65 6e 67 74 68 73  l in the lengths
3c80: 20 6f 66 20 73 74 72 69 6e 67 73 20 61 6e 64 20   of strings and 
3c90: 68 61 73 68 65 73 20 66 6f 72 20 61 6c 6c 20 65  hashes for all e
3ca0: 6e 74 72 69 65 73 2e 20 2a 2f 0a 20 20 66 6f 72  ntries. */.  for
3cb0: 28 69 3d 30 3b 20 69 3c 6e 4b 65 79 77 6f 72 64  (i=0; i<nKeyword
3cc0: 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 4b 65 79 77  ; i++){.    Keyw
3cd0: 6f 72 64 20 2a 70 20 3d 20 26 61 4b 65 79 77 6f  ord *p = &aKeywo
3ce0: 72 64 54 61 62 6c 65 5b 69 5d 3b 0a 20 20 20 20  rdTable[i];.    
3cf0: 70 2d 3e 6c 65 6e 20 3d 20 28 69 6e 74 29 73 74  p->len = (int)st
3d00: 72 6c 65 6e 28 70 2d 3e 7a 4e 61 6d 65 29 3b 0a  rlen(p->zName);.
3d10: 20 20 20 20 61 73 73 65 72 74 28 20 70 2d 3e 6c      assert( p->l
3d20: 65 6e 3c 73 69 7a 65 6f 66 28 70 2d 3e 7a 4f 72  en<sizeof(p->zOr
3d30: 69 67 4e 61 6d 65 29 20 29 3b 0a 20 20 20 20 6d  igName) );.    m
3d40: 65 6d 63 70 79 28 70 2d 3e 7a 4f 72 69 67 4e 61  emcpy(p->zOrigNa
3d50: 6d 65 2c 20 70 2d 3e 7a 4e 61 6d 65 2c 20 70 2d  me, p->zName, p-
3d60: 3e 6c 65 6e 2b 31 29 3b 0a 20 20 20 20 74 6f 74  >len+1);.    tot
3d70: 61 6c 4c 65 6e 20 2b 3d 20 70 2d 3e 6c 65 6e 3b  alLen += p->len;
3d80: 0a 20 20 20 20 70 2d 3e 68 61 73 68 20 3d 20 28  .    p->hash = (
3d90: 63 68 61 72 4d 61 70 28 70 2d 3e 7a 4e 61 6d 65  charMap(p->zName
3da0: 5b 30 5d 29 2a 34 29 20 5e 0a 20 20 20 20 20 20  [0])*4) ^.      
3db0: 20 20 20 20 20 20 20 20 28 63 68 61 72 4d 61 70          (charMap
3dc0: 28 70 2d 3e 7a 4e 61 6d 65 5b 70 2d 3e 6c 65 6e  (p->zName[p->len
3dd0: 2d 31 5d 29 2a 33 29 20 5e 20 28 70 2d 3e 6c 65  -1])*3) ^ (p->le
3de0: 6e 2a 31 29 3b 0a 20 20 20 20 70 2d 3e 69 64 20  n*1);.    p->id 
3df0: 3d 20 69 2b 31 3b 0a 20 20 7d 0a 0a 20 20 2f 2a  = i+1;.  }..  /*
3e00: 20 53 6f 72 74 20 74 68 65 20 74 61 62 6c 65 20   Sort the table 
3e10: 66 72 6f 6d 20 73 68 6f 72 74 65 73 74 20 74 6f  from shortest to
3e20: 20 6c 6f 6e 67 65 73 74 20 6b 65 79 77 6f 72 64   longest keyword
3e30: 20 2a 2f 0a 20 20 71 73 6f 72 74 28 61 4b 65 79   */.  qsort(aKey
3e40: 77 6f 72 64 54 61 62 6c 65 2c 20 6e 4b 65 79 77  wordTable, nKeyw
3e50: 6f 72 64 2c 20 73 69 7a 65 6f 66 28 61 4b 65 79  ord, sizeof(aKey
3e60: 77 6f 72 64 54 61 62 6c 65 5b 30 5d 29 2c 20 6b  wordTable[0]), k
3e70: 65 79 77 6f 72 64 43 6f 6d 70 61 72 65 31 29 3b  eywordCompare1);
3e80: 0a 0a 20 20 2f 2a 20 4c 6f 6f 6b 20 66 6f 72 20  ..  /* Look for 
3e90: 73 68 6f 72 74 20 6b 65 79 77 6f 72 64 73 20 65  short keywords e
3ea0: 6d 62 65 64 64 65 64 20 69 6e 20 6c 6f 6e 67 65  mbedded in longe
3eb0: 72 20 6b 65 79 77 6f 72 64 73 20 2a 2f 0a 20 20  r keywords */.  
3ec0: 66 6f 72 28 69 3d 6e 4b 65 79 77 6f 72 64 2d 32  for(i=nKeyword-2
3ed0: 3b 20 69 3e 3d 30 3b 20 69 2d 2d 29 7b 0a 20 20  ; i>=0; i--){.  
3ee0: 20 20 4b 65 79 77 6f 72 64 20 2a 70 20 3d 20 26    Keyword *p = &
3ef0: 61 4b 65 79 77 6f 72 64 54 61 62 6c 65 5b 69 5d  aKeywordTable[i]
3f00: 3b 0a 20 20 20 20 66 6f 72 28 6a 3d 6e 4b 65 79  ;.    for(j=nKey
3f10: 77 6f 72 64 2d 31 3b 20 6a 3e 69 20 26 26 20 70  word-1; j>i && p
3f20: 2d 3e 73 75 62 73 74 72 49 64 3d 3d 30 3b 20 6a  ->substrId==0; j
3f30: 2d 2d 29 7b 0a 20 20 20 20 20 20 4b 65 79 77 6f  --){.      Keywo
3f40: 72 64 20 2a 70 4f 74 68 65 72 20 3d 20 26 61 4b  rd *pOther = &aK
3f50: 65 79 77 6f 72 64 54 61 62 6c 65 5b 6a 5d 3b 0a  eywordTable[j];.
3f60: 20 20 20 20 20 20 69 66 28 20 70 4f 74 68 65 72        if( pOther
3f70: 2d 3e 73 75 62 73 74 72 49 64 20 29 20 63 6f 6e  ->substrId ) con
3f80: 74 69 6e 75 65 3b 0a 20 20 20 20 20 20 69 66 28  tinue;.      if(
3f90: 20 70 4f 74 68 65 72 2d 3e 6c 65 6e 3c 3d 70 2d   pOther->len<=p-
3fa0: 3e 6c 65 6e 20 29 20 63 6f 6e 74 69 6e 75 65 3b  >len ) continue;
3fb0: 0a 20 20 20 20 20 20 66 6f 72 28 6b 3d 30 3b 20  .      for(k=0; 
3fc0: 6b 3c 3d 70 4f 74 68 65 72 2d 3e 6c 65 6e 2d 70  k<=pOther->len-p
3fd0: 2d 3e 6c 65 6e 3b 20 6b 2b 2b 29 7b 0a 20 20 20  ->len; k++){.   
3fe0: 20 20 20 20 20 69 66 28 20 6d 65 6d 63 6d 70 28       if( memcmp(
3ff0: 70 2d 3e 7a 4e 61 6d 65 2c 20 26 70 4f 74 68 65  p->zName, &pOthe
4000: 72 2d 3e 7a 4e 61 6d 65 5b 6b 5d 2c 20 70 2d 3e  r->zName[k], p->
4010: 6c 65 6e 29 3d 3d 30 20 29 7b 0a 20 20 20 20 20  len)==0 ){.     
4020: 20 20 20 20 20 70 2d 3e 73 75 62 73 74 72 49 64       p->substrId
4030: 20 3d 20 70 4f 74 68 65 72 2d 3e 69 64 3b 0a 20   = pOther->id;. 
4040: 20 20 20 20 20 20 20 20 20 70 2d 3e 73 75 62 73           p->subs
4050: 74 72 4f 66 66 73 65 74 20 3d 20 6b 3b 0a 20 20  trOffset = k;.  
4060: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20          break;. 
4070: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d         }.      }
4080: 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 2f 2a  .    }.  }..  /*
4090: 20 43 6f 6d 70 75 74 65 20 74 68 65 20 6c 6f 6e   Compute the lon
40a0: 67 65 73 74 53 75 66 66 69 78 20 76 61 6c 75 65  gestSuffix value
40b0: 20 66 6f 72 20 65 76 65 72 79 20 77 6f 72 64 20   for every word 
40c0: 2a 2f 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c  */.  for(i=0; i<
40d0: 6e 4b 65 79 77 6f 72 64 3b 20 69 2b 2b 29 7b 0a  nKeyword; i++){.
40e0: 20 20 20 20 4b 65 79 77 6f 72 64 20 2a 70 20 3d      Keyword *p =
40f0: 20 26 61 4b 65 79 77 6f 72 64 54 61 62 6c 65 5b   &aKeywordTable[
4100: 69 5d 3b 0a 20 20 20 20 69 66 28 20 70 2d 3e 73  i];.    if( p->s
4110: 75 62 73 74 72 49 64 20 29 20 63 6f 6e 74 69 6e  ubstrId ) contin
4120: 75 65 3b 0a 20 20 20 20 66 6f 72 28 6a 3d 30 3b  ue;.    for(j=0;
4130: 20 6a 3c 6e 4b 65 79 77 6f 72 64 3b 20 6a 2b 2b   j<nKeyword; j++
4140: 29 7b 0a 20 20 20 20 20 20 4b 65 79 77 6f 72 64  ){.      Keyword
4150: 20 2a 70 4f 74 68 65 72 3b 0a 20 20 20 20 20 20   *pOther;.      
4160: 69 66 28 20 6a 3d 3d 69 20 29 20 63 6f 6e 74 69  if( j==i ) conti
4170: 6e 75 65 3b 0a 20 20 20 20 20 20 70 4f 74 68 65  nue;.      pOthe
4180: 72 20 3d 20 26 61 4b 65 79 77 6f 72 64 54 61 62  r = &aKeywordTab
4190: 6c 65 5b 6a 5d 3b 0a 20 20 20 20 20 20 69 66 28  le[j];.      if(
41a0: 20 70 4f 74 68 65 72 2d 3e 73 75 62 73 74 72 49   pOther->substrI
41b0: 64 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20  d ) continue;.  
41c0: 20 20 20 20 66 6f 72 28 6b 3d 70 2d 3e 6c 6f 6e      for(k=p->lon
41d0: 67 65 73 74 53 75 66 66 69 78 2b 31 3b 20 6b 3c  gestSuffix+1; k<
41e0: 70 2d 3e 6c 65 6e 20 26 26 20 6b 3c 70 4f 74 68  p->len && k<pOth
41f0: 65 72 2d 3e 6c 65 6e 3b 20 6b 2b 2b 29 7b 0a 20  er->len; k++){. 
4200: 20 20 20 20 20 20 20 69 66 28 20 6d 65 6d 63 6d         if( memcm
4210: 70 28 26 70 2d 3e 7a 4e 61 6d 65 5b 70 2d 3e 6c  p(&p->zName[p->l
4220: 65 6e 2d 6b 5d 2c 20 70 4f 74 68 65 72 2d 3e 7a  en-k], pOther->z
4230: 4e 61 6d 65 2c 20 6b 29 3d 3d 30 20 29 7b 0a 20  Name, k)==0 ){. 
4240: 20 20 20 20 20 20 20 20 20 70 2d 3e 6c 6f 6e 67           p->long
4250: 65 73 74 53 75 66 66 69 78 20 3d 20 6b 3b 0a 20  estSuffix = k;. 
4260: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d         }.      }
4270: 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 2f 2a  .    }.  }..  /*
4280: 20 53 6f 72 74 20 74 68 65 20 74 61 62 6c 65 20   Sort the table 
4290: 69 6e 74 6f 20 72 65 76 65 72 73 65 20 6f 72 64  into reverse ord
42a0: 65 72 20 62 79 20 6c 65 6e 67 74 68 20 2a 2f 0a  er by length */.
42b0: 20 20 71 73 6f 72 74 28 61 4b 65 79 77 6f 72 64    qsort(aKeyword
42c0: 54 61 62 6c 65 2c 20 6e 4b 65 79 77 6f 72 64 2c  Table, nKeyword,
42d0: 20 73 69 7a 65 6f 66 28 61 4b 65 79 77 6f 72 64   sizeof(aKeyword
42e0: 54 61 62 6c 65 5b 30 5d 29 2c 20 6b 65 79 77 6f  Table[0]), keywo
42f0: 72 64 43 6f 6d 70 61 72 65 32 29 3b 0a 0a 20 20  rdCompare2);..  
4300: 2f 2a 20 46 69 6c 6c 20 69 6e 20 74 68 65 20 6f  /* Fill in the o
4310: 66 66 73 65 74 20 66 6f 72 20 61 6c 6c 20 65 6e  ffset for all en
4320: 74 72 69 65 73 20 2a 2f 0a 20 20 6e 43 68 61 72  tries */.  nChar
4330: 20 3d 20 30 3b 0a 20 20 66 6f 72 28 69 3d 30 3b   = 0;.  for(i=0;
4340: 20 69 3c 6e 4b 65 79 77 6f 72 64 3b 20 69 2b 2b   i<nKeyword; i++
4350: 29 7b 0a 20 20 20 20 4b 65 79 77 6f 72 64 20 2a  ){.    Keyword *
4360: 70 20 3d 20 26 61 4b 65 79 77 6f 72 64 54 61 62  p = &aKeywordTab
4370: 6c 65 5b 69 5d 3b 0a 20 20 20 20 69 66 28 20 70  le[i];.    if( p
4380: 2d 3e 6f 66 66 73 65 74 3e 30 20 7c 7c 20 70 2d  ->offset>0 || p-
4390: 3e 73 75 62 73 74 72 49 64 20 29 20 63 6f 6e 74  >substrId ) cont
43a0: 69 6e 75 65 3b 0a 20 20 20 20 70 2d 3e 6f 66 66  inue;.    p->off
43b0: 73 65 74 20 3d 20 6e 43 68 61 72 3b 0a 20 20 20  set = nChar;.   
43c0: 20 6e 43 68 61 72 20 2b 3d 20 70 2d 3e 6c 65 6e   nChar += p->len
43d0: 3b 0a 20 20 20 20 66 6f 72 28 6b 3d 70 2d 3e 6c  ;.    for(k=p->l
43e0: 65 6e 2d 31 3b 20 6b 3e 3d 31 3b 20 6b 2d 2d 29  en-1; k>=1; k--)
43f0: 7b 0a 20 20 20 20 20 20 66 6f 72 28 6a 3d 69 2b  {.      for(j=i+
4400: 31 3b 20 6a 3c 6e 4b 65 79 77 6f 72 64 3b 20 6a  1; j<nKeyword; j
4410: 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 4b 65 79  ++){.        Key
4420: 77 6f 72 64 20 2a 70 4f 74 68 65 72 20 3d 20 26  word *pOther = &
4430: 61 4b 65 79 77 6f 72 64 54 61 62 6c 65 5b 6a 5d  aKeywordTable[j]
4440: 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 70 4f  ;.        if( pO
4450: 74 68 65 72 2d 3e 6f 66 66 73 65 74 3e 30 20 7c  ther->offset>0 |
4460: 7c 20 70 4f 74 68 65 72 2d 3e 73 75 62 73 74 72  | pOther->substr
4470: 49 64 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 20  Id ) continue;. 
4480: 20 20 20 20 20 20 20 69 66 28 20 70 4f 74 68 65         if( pOthe
4490: 72 2d 3e 6c 65 6e 3c 3d 6b 20 29 20 63 6f 6e 74  r->len<=k ) cont
44a0: 69 6e 75 65 3b 0a 20 20 20 20 20 20 20 20 69 66  inue;.        if
44b0: 28 20 6d 65 6d 63 6d 70 28 26 70 2d 3e 7a 4e 61  ( memcmp(&p->zNa
44c0: 6d 65 5b 70 2d 3e 6c 65 6e 2d 6b 5d 2c 20 70 4f  me[p->len-k], pO
44d0: 74 68 65 72 2d 3e 7a 4e 61 6d 65 2c 20 6b 29 3d  ther->zName, k)=
44e0: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  =0 ){.          
44f0: 70 20 3d 20 70 4f 74 68 65 72 3b 0a 20 20 20 20  p = pOther;.    
4500: 20 20 20 20 20 20 70 2d 3e 6f 66 66 73 65 74 20        p->offset 
4510: 3d 20 6e 43 68 61 72 20 2d 20 6b 3b 0a 20 20 20  = nChar - k;.   
4520: 20 20 20 20 20 20 20 6e 43 68 61 72 20 3d 20 70         nChar = p
4530: 2d 3e 6f 66 66 73 65 74 20 2b 20 70 2d 3e 6c 65  ->offset + p->le
4540: 6e 3b 0a 20 20 20 20 20 20 20 20 20 20 70 2d 3e  n;.          p->
4550: 7a 4e 61 6d 65 20 2b 3d 20 6b 3b 0a 20 20 20 20  zName += k;.    
4560: 20 20 20 20 20 20 70 2d 3e 6c 65 6e 20 2d 3d 20        p->len -= 
4570: 6b 3b 0a 20 20 20 20 20 20 20 20 20 20 70 2d 3e  k;.          p->
4580: 70 72 65 66 69 78 20 3d 20 6b 3b 0a 20 20 20 20  prefix = k;.    
4590: 20 20 20 20 20 20 6a 20 3d 20 69 3b 0a 20 20 20        j = i;.   
45a0: 20 20 20 20 20 20 20 6b 20 3d 20 70 2d 3e 6c 65         k = p->le
45b0: 6e 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  n;.        }.   
45c0: 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 0a 20     }.    }.  }. 
45d0: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 6e 4b 65 79   for(i=0; i<nKey
45e0: 77 6f 72 64 3b 20 69 2b 2b 29 7b 0a 20 20 20 20  word; i++){.    
45f0: 4b 65 79 77 6f 72 64 20 2a 70 20 3d 20 26 61 4b  Keyword *p = &aK
4600: 65 79 77 6f 72 64 54 61 62 6c 65 5b 69 5d 3b 0a  eywordTable[i];.
4610: 20 20 20 20 69 66 28 20 70 2d 3e 73 75 62 73 74      if( p->subst
4620: 72 49 64 20 29 7b 0a 20 20 20 20 20 20 70 2d 3e  rId ){.      p->
4630: 6f 66 66 73 65 74 20 3d 20 66 69 6e 64 42 79 49  offset = findByI
4640: 64 28 70 2d 3e 73 75 62 73 74 72 49 64 29 2d 3e  d(p->substrId)->
4650: 6f 66 66 73 65 74 20 2b 20 70 2d 3e 73 75 62 73  offset + p->subs
4660: 74 72 4f 66 66 73 65 74 3b 0a 20 20 20 20 7d 0a  trOffset;.    }.
4670: 20 20 7d 0a 0a 20 20 2f 2a 20 53 6f 72 74 20 74    }..  /* Sort t
4680: 68 65 20 74 61 62 6c 65 20 62 79 20 6f 66 66 73  he table by offs
4690: 65 74 20 2a 2f 0a 20 20 71 73 6f 72 74 28 61 4b  et */.  qsort(aK
46a0: 65 79 77 6f 72 64 54 61 62 6c 65 2c 20 6e 4b 65  eywordTable, nKe
46b0: 79 77 6f 72 64 2c 20 73 69 7a 65 6f 66 28 61 4b  yword, sizeof(aK
46c0: 65 79 77 6f 72 64 54 61 62 6c 65 5b 30 5d 29 2c  eywordTable[0]),
46d0: 20 6b 65 79 77 6f 72 64 43 6f 6d 70 61 72 65 33   keywordCompare3
46e0: 29 3b 0a 0a 20 20 2f 2a 20 46 69 67 75 72 65 20  );..  /* Figure 
46f0: 6f 75 74 20 68 6f 77 20 62 69 67 20 74 6f 20 6d  out how big to m
4700: 61 6b 65 20 74 68 65 20 68 61 73 68 20 74 61 62  ake the hash tab
4710: 6c 65 20 69 6e 20 6f 72 64 65 72 20 74 6f 20 6d  le in order to m
4720: 69 6e 69 6d 69 7a 65 20 74 68 65 0a 20 20 2a 2a  inimize the.  **
4730: 20 6e 75 6d 62 65 72 20 6f 66 20 63 6f 6c 6c 69   number of colli
4740: 73 69 6f 6e 73 20 2a 2f 0a 20 20 62 65 73 74 53  sions */.  bestS
4750: 69 7a 65 20 3d 20 6e 4b 65 79 77 6f 72 64 3b 0a  ize = nKeyword;.
4760: 20 20 62 65 73 74 43 6f 75 6e 74 20 3d 20 6e 4b    bestCount = nK
4770: 65 79 77 6f 72 64 2a 6e 4b 65 79 77 6f 72 64 3b  eyword*nKeyword;
4780: 0a 20 20 66 6f 72 28 69 3d 6e 4b 65 79 77 6f 72  .  for(i=nKeywor
4790: 64 2f 32 3b 20 69 3c 3d 32 2a 6e 4b 65 79 77 6f  d/2; i<=2*nKeywo
47a0: 72 64 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 66 6f  rd; i++){.    fo
47b0: 72 28 6a 3d 30 3b 20 6a 3c 69 3b 20 6a 2b 2b 29  r(j=0; j<i; j++)
47c0: 20 61 4b 57 48 61 73 68 5b 6a 5d 20 3d 20 30 3b   aKWHash[j] = 0;
47d0: 0a 20 20 20 20 66 6f 72 28 6a 3d 30 3b 20 6a 3c  .    for(j=0; j<
47e0: 6e 4b 65 79 77 6f 72 64 3b 20 6a 2b 2b 29 7b 0a  nKeyword; j++){.
47f0: 20 20 20 20 20 20 68 20 3d 20 61 4b 65 79 77 6f        h = aKeywo
4800: 72 64 54 61 62 6c 65 5b 6a 5d 2e 68 61 73 68 20  rdTable[j].hash 
4810: 25 20 69 3b 0a 20 20 20 20 20 20 61 4b 57 48 61  % i;.      aKWHa
4820: 73 68 5b 68 5d 20 2a 3d 20 32 3b 0a 20 20 20 20  sh[h] *= 2;.    
4830: 20 20 61 4b 57 48 61 73 68 5b 68 5d 2b 2b 3b 0a    aKWHash[h]++;.
4840: 20 20 20 20 7d 0a 20 20 20 20 66 6f 72 28 6a 3d      }.    for(j=
4850: 63 6f 75 6e 74 3d 30 3b 20 6a 3c 69 3b 20 6a 2b  count=0; j<i; j+
4860: 2b 29 20 63 6f 75 6e 74 20 2b 3d 20 61 4b 57 48  +) count += aKWH
4870: 61 73 68 5b 6a 5d 3b 0a 20 20 20 20 69 66 28 20  ash[j];.    if( 
4880: 63 6f 75 6e 74 3c 62 65 73 74 43 6f 75 6e 74 20  count<bestCount 
4890: 29 7b 0a 20 20 20 20 20 20 62 65 73 74 43 6f 75  ){.      bestCou
48a0: 6e 74 20 3d 20 63 6f 75 6e 74 3b 0a 20 20 20 20  nt = count;.    
48b0: 20 20 62 65 73 74 53 69 7a 65 20 3d 20 69 3b 0a    bestSize = i;.
48c0: 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 2f 2a 20      }.  }..  /* 
48d0: 43 6f 6d 70 75 74 65 20 74 68 65 20 68 61 73 68  Compute the hash
48e0: 20 2a 2f 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69   */.  for(i=0; i
48f0: 3c 62 65 73 74 53 69 7a 65 3b 20 69 2b 2b 29 20  <bestSize; i++) 
4900: 61 4b 57 48 61 73 68 5b 69 5d 20 3d 20 30 3b 0a  aKWHash[i] = 0;.
4910: 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 6e 4b 65    for(i=0; i<nKe
4920: 79 77 6f 72 64 3b 20 69 2b 2b 29 7b 0a 20 20 20  yword; i++){.   
4930: 20 68 20 3d 20 61 4b 65 79 77 6f 72 64 54 61 62   h = aKeywordTab
4940: 6c 65 5b 69 5d 2e 68 61 73 68 20 25 20 62 65 73  le[i].hash % bes
4950: 74 53 69 7a 65 3b 0a 20 20 20 20 61 4b 65 79 77  tSize;.    aKeyw
4960: 6f 72 64 54 61 62 6c 65 5b 69 5d 2e 69 4e 65 78  ordTable[i].iNex
4970: 74 20 3d 20 61 4b 57 48 61 73 68 5b 68 5d 3b 0a  t = aKWHash[h];.
4980: 20 20 20 20 61 4b 57 48 61 73 68 5b 68 5d 20 3d      aKWHash[h] =
4990: 20 69 2b 31 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20   i+1;.  }..  /* 
49a0: 42 65 67 69 6e 20 67 65 6e 65 72 61 74 69 6e 67  Begin generating
49b0: 20 63 6f 64 65 20 2a 2f 0a 20 20 70 72 69 6e 74   code */.  print
49c0: 66 28 22 25 73 22 2c 20 7a 48 64 72 29 3b 0a 20  f("%s", zHdr);. 
49d0: 20 70 72 69 6e 74 66 28 22 2f 2a 20 48 61 73 68   printf("/* Hash
49e0: 20 73 63 6f 72 65 3a 20 25 64 20 2a 2f 5c 6e 22   score: %d */\n"
49f0: 2c 20 62 65 73 74 43 6f 75 6e 74 29 3b 0a 20 20  , bestCount);.  
4a00: 70 72 69 6e 74 66 28 22 2f 2a 20 7a 4b 57 54 65  printf("/* zKWTe
4a10: 78 74 5b 5d 20 65 6e 63 6f 64 65 73 20 25 64 20  xt[] encodes %d 
4a20: 62 79 74 65 73 20 6f 66 20 6b 65 79 77 6f 72 64  bytes of keyword
4a30: 20 74 65 78 74 20 69 6e 20 25 64 20 62 79 74 65   text in %d byte
4a40: 73 20 2a 2f 5c 6e 22 2c 0a 20 20 20 20 20 20 20  s */\n",.       
4a50: 20 20 20 74 6f 74 61 6c 4c 65 6e 20 2b 20 6e 4b     totalLen + nK
4a60: 65 79 77 6f 72 64 2c 20 6e 43 68 61 72 2b 31 20  eyword, nChar+1 
4a70: 29 3b 0a 20 20 66 6f 72 28 69 3d 6a 3d 6b 3d 30  );.  for(i=j=k=0
4a80: 3b 20 69 3c 6e 4b 65 79 77 6f 72 64 3b 20 69 2b  ; i<nKeyword; i+
4a90: 2b 29 7b 0a 20 20 20 20 4b 65 79 77 6f 72 64 20  +){.    Keyword 
4aa0: 2a 70 20 3d 20 26 61 4b 65 79 77 6f 72 64 54 61  *p = &aKeywordTa
4ab0: 62 6c 65 5b 69 5d 3b 0a 20 20 20 20 69 66 28 20  ble[i];.    if( 
4ac0: 70 2d 3e 73 75 62 73 74 72 49 64 20 29 20 63 6f  p->substrId ) co
4ad0: 6e 74 69 6e 75 65 3b 0a 20 20 20 20 6d 65 6d 63  ntinue;.    memc
4ae0: 70 79 28 26 7a 4b 57 54 65 78 74 5b 6b 5d 2c 20  py(&zKWText[k], 
4af0: 70 2d 3e 7a 4e 61 6d 65 2c 20 70 2d 3e 6c 65 6e  p->zName, p->len
4b00: 29 3b 0a 20 20 20 20 6b 20 2b 3d 20 70 2d 3e 6c  );.    k += p->l
4b10: 65 6e 3b 0a 20 20 20 20 69 66 28 20 6a 2b 70 2d  en;.    if( j+p-
4b20: 3e 6c 65 6e 3e 37 30 20 29 7b 0a 20 20 20 20 20  >len>70 ){.     
4b30: 20 70 72 69 6e 74 66 28 22 25 2a 73 20 2a 2f 5c   printf("%*s */\
4b40: 6e 22 2c 20 37 34 2d 6a 2c 20 22 22 29 3b 0a 20  n", 74-j, "");. 
4b50: 20 20 20 20 20 6a 20 3d 20 30 3b 0a 20 20 20 20       j = 0;.    
4b60: 7d 0a 20 20 20 20 69 66 28 20 6a 3d 3d 30 20 29  }.    if( j==0 )
4b70: 7b 0a 20 20 20 20 20 20 70 72 69 6e 74 66 28 22  {.      printf("
4b80: 2f 2a 20 20 20 22 29 3b 0a 20 20 20 20 20 20 6a  /*   ");.      j
4b90: 20 3d 20 38 3b 0a 20 20 20 20 7d 0a 20 20 20 20   = 8;.    }.    
4ba0: 70 72 69 6e 74 66 28 22 25 73 22 2c 20 70 2d 3e  printf("%s", p->
4bb0: 7a 4e 61 6d 65 29 3b 0a 20 20 20 20 6a 20 2b 3d  zName);.    j +=
4bc0: 20 70 2d 3e 6c 65 6e 3b 0a 20 20 7d 0a 20 20 69   p->len;.  }.  i
4bd0: 66 28 20 6a 3e 30 20 29 7b 0a 20 20 20 20 70 72  f( j>0 ){.    pr
4be0: 69 6e 74 66 28 22 25 2a 73 20 2a 2f 5c 6e 22 2c  intf("%*s */\n",
4bf0: 20 37 34 2d 6a 2c 20 22 22 29 3b 0a 20 20 7d 0a   74-j, "");.  }.
4c00: 20 20 70 72 69 6e 74 66 28 22 73 74 61 74 69 63    printf("static
4c10: 20 63 6f 6e 73 74 20 63 68 61 72 20 7a 4b 57 54   const char zKWT
4c20: 65 78 74 5b 25 64 5d 20 3d 20 7b 5c 6e 22 2c 20  ext[%d] = {\n", 
4c30: 6e 43 68 61 72 29 3b 0a 20 20 7a 4b 57 54 65 78  nChar);.  zKWTex
4c40: 74 5b 6e 43 68 61 72 5d 20 3d 20 30 3b 0a 20 20  t[nChar] = 0;.  
4c50: 66 6f 72 28 69 3d 6a 3d 30 3b 20 69 3c 6b 3b 20  for(i=j=0; i<k; 
4c60: 69 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20 6a 3d  i++){.    if( j=
4c70: 3d 30 20 29 7b 0a 20 20 20 20 20 20 70 72 69 6e  =0 ){.      prin
4c80: 74 66 28 22 20 20 22 29 3b 0a 20 20 20 20 7d 0a  tf("  ");.    }.
4c90: 20 20 20 20 69 66 28 20 7a 4b 57 54 65 78 74 5b      if( zKWText[
4ca0: 69 5d 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 70  i]==0 ){.      p
4cb0: 72 69 6e 74 66 28 22 30 22 29 3b 0a 20 20 20 20  rintf("0");.    
4cc0: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 70 72 69  }else{.      pri
4cd0: 6e 74 66 28 22 27 25 63 27 2c 22 2c 20 7a 4b 57  ntf("'%c',", zKW
4ce0: 54 65 78 74 5b 69 5d 29 3b 0a 20 20 20 20 7d 0a  Text[i]);.    }.
4cf0: 20 20 20 20 6a 20 2b 3d 20 34 3b 0a 20 20 20 20      j += 4;.    
4d00: 69 66 28 20 6a 3e 36 38 20 29 7b 0a 20 20 20 20  if( j>68 ){.    
4d10: 20 20 70 72 69 6e 74 66 28 22 5c 6e 22 29 3b 0a    printf("\n");.
4d20: 20 20 20 20 20 20 6a 20 3d 20 30 3b 0a 20 20 20        j = 0;.   
4d30: 20 7d 0a 20 20 7d 0a 20 20 69 66 28 20 6a 3e 30   }.  }.  if( j>0
4d40: 20 29 20 70 72 69 6e 74 66 28 22 5c 6e 22 29 3b   ) printf("\n");
4d50: 0a 20 20 70 72 69 6e 74 66 28 22 7d 3b 5c 6e 22  .  printf("};\n"
4d60: 29 3b 0a 0a 20 20 70 72 69 6e 74 66 28 22 2f 2a  );..  printf("/*
4d70: 20 61 4b 57 48 61 73 68 5b 69 5d 20 69 73 20 74   aKWHash[i] is t
4d80: 68 65 20 68 61 73 68 20 76 61 6c 75 65 20 66 6f  he hash value fo
4d90: 72 20 74 68 65 20 69 2d 74 68 20 6b 65 79 77 6f  r the i-th keywo
4da0: 72 64 20 2a 2f 5c 6e 22 29 3b 0a 20 20 70 72 69  rd */\n");.  pri
4db0: 6e 74 66 28 22 73 74 61 74 69 63 20 63 6f 6e 73  ntf("static cons
4dc0: 74 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20  t unsigned char 
4dd0: 61 4b 57 48 61 73 68 5b 25 64 5d 20 3d 20 7b 5c  aKWHash[%d] = {\
4de0: 6e 22 2c 20 62 65 73 74 53 69 7a 65 29 3b 0a 20  n", bestSize);. 
4df0: 20 66 6f 72 28 69 3d 6a 3d 30 3b 20 69 3c 62 65   for(i=j=0; i<be
4e00: 73 74 53 69 7a 65 3b 20 69 2b 2b 29 7b 0a 20 20  stSize; i++){.  
4e10: 20 20 69 66 28 20 6a 3d 3d 30 20 29 20 70 72 69    if( j==0 ) pri
4e20: 6e 74 66 28 22 20 20 22 29 3b 0a 20 20 20 20 70  ntf("  ");.    p
4e30: 72 69 6e 74 66 28 22 20 25 33 64 2c 22 2c 20 61  rintf(" %3d,", a
4e40: 4b 57 48 61 73 68 5b 69 5d 29 3b 0a 20 20 20 20  KWHash[i]);.    
4e50: 6a 2b 2b 3b 0a 20 20 20 20 69 66 28 20 6a 3e 31  j++;.    if( j>1
4e60: 32 20 29 7b 0a 20 20 20 20 20 20 70 72 69 6e 74  2 ){.      print
4e70: 66 28 22 5c 6e 22 29 3b 0a 20 20 20 20 20 20 6a  f("\n");.      j
4e80: 20 3d 20 30 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a   = 0;.    }.  }.
4e90: 20 20 70 72 69 6e 74 66 28 22 25 73 7d 3b 5c 6e    printf("%s};\n
4ea0: 22 2c 20 6a 3d 3d 30 20 3f 20 22 22 20 3a 20 22  ", j==0 ? "" : "
4eb0: 5c 6e 22 29 3b 20 20 20 20 0a 0a 20 20 70 72 69  \n");    ..  pri
4ec0: 6e 74 66 28 22 2f 2a 20 61 4b 57 4e 65 78 74 5b  ntf("/* aKWNext[
4ed0: 5d 20 66 6f 72 6d 73 20 74 68 65 20 68 61 73 68  ] forms the hash
4ee0: 20 63 6f 6c 6c 69 73 69 6f 6e 20 63 68 61 69 6e   collision chain
4ef0: 2e 20 20 49 66 20 61 4b 57 48 61 73 68 5b 69 5d  .  If aKWHash[i]
4f00: 3d 3d 30 5c 6e 22 29 3b 0a 20 20 70 72 69 6e 74  ==0\n");.  print
4f10: 66 28 22 2a 2a 20 74 68 65 6e 20 74 68 65 20 69  f("** then the i
4f20: 2d 74 68 20 6b 65 79 77 6f 72 64 20 68 61 73 20  -th keyword has 
4f30: 6e 6f 20 6d 6f 72 65 20 68 61 73 68 20 63 6f 6c  no more hash col
4f40: 6c 69 73 69 6f 6e 73 2e 20 20 4f 74 68 65 72 77  lisions.  Otherw
4f50: 69 73 65 2c 5c 6e 22 29 3b 0a 20 20 70 72 69 6e  ise,\n");.  prin
4f60: 74 66 28 22 2a 2a 20 74 68 65 20 6e 65 78 74 20  tf("** the next 
4f70: 6b 65 79 77 6f 72 64 20 77 69 74 68 20 74 68 65  keyword with the
4f80: 20 73 61 6d 65 20 68 61 73 68 20 69 73 20 61 4b   same hash is aK
4f90: 57 48 61 73 68 5b 69 5d 2d 31 2e 20 2a 2f 5c 6e  WHash[i]-1. */\n
4fa0: 22 29 3b 0a 20 20 70 72 69 6e 74 66 28 22 73 74  ");.  printf("st
4fb0: 61 74 69 63 20 63 6f 6e 73 74 20 75 6e 73 69 67  atic const unsig
4fc0: 6e 65 64 20 63 68 61 72 20 61 4b 57 4e 65 78 74  ned char aKWNext
4fd0: 5b 25 64 5d 20 3d 20 7b 5c 6e 22 2c 20 6e 4b 65  [%d] = {\n", nKe
4fe0: 79 77 6f 72 64 29 3b 0a 20 20 66 6f 72 28 69 3d  yword);.  for(i=
4ff0: 6a 3d 30 3b 20 69 3c 6e 4b 65 79 77 6f 72 64 3b  j=0; i<nKeyword;
5000: 20 69 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20 6a   i++){.    if( j
5010: 3d 3d 30 20 29 20 70 72 69 6e 74 66 28 22 20 20  ==0 ) printf("  
5020: 22 29 3b 0a 20 20 20 20 70 72 69 6e 74 66 28 22  ");.    printf("
5030: 20 25 33 64 2c 22 2c 20 61 4b 65 79 77 6f 72 64   %3d,", aKeyword
5040: 54 61 62 6c 65 5b 69 5d 2e 69 4e 65 78 74 29 3b  Table[i].iNext);
5050: 0a 20 20 20 20 6a 2b 2b 3b 0a 20 20 20 20 69 66  .    j++;.    if
5060: 28 20 6a 3e 31 32 20 29 7b 0a 20 20 20 20 20 20  ( j>12 ){.      
5070: 70 72 69 6e 74 66 28 22 5c 6e 22 29 3b 0a 20 20  printf("\n");.  
5080: 20 20 20 20 6a 20 3d 20 30 3b 0a 20 20 20 20 7d      j = 0;.    }
5090: 0a 20 20 7d 0a 20 20 70 72 69 6e 74 66 28 22 25  .  }.  printf("%
50a0: 73 7d 3b 5c 6e 22 2c 20 6a 3d 3d 30 20 3f 20 22  s};\n", j==0 ? "
50b0: 22 20 3a 20 22 5c 6e 22 29 3b 20 20 20 20 0a 0a  " : "\n");    ..
50c0: 20 20 70 72 69 6e 74 66 28 22 2f 2a 20 61 4b 57    printf("/* aKW
50d0: 4c 65 6e 5b 69 5d 20 69 73 20 74 68 65 20 6c 65  Len[i] is the le
50e0: 6e 67 74 68 20 28 69 6e 20 62 79 74 65 73 29 20  ngth (in bytes) 
50f0: 6f 66 20 74 68 65 20 69 2d 74 68 20 6b 65 79 77  of the i-th keyw
5100: 6f 72 64 20 2a 2f 5c 6e 22 29 3b 0a 20 20 70 72  ord */\n");.  pr
5110: 69 6e 74 66 28 22 73 74 61 74 69 63 20 63 6f 6e  intf("static con
5120: 73 74 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72  st unsigned char
5130: 20 61 4b 57 4c 65 6e 5b 25 64 5d 20 3d 20 7b 5c   aKWLen[%d] = {\
5140: 6e 22 2c 20 6e 4b 65 79 77 6f 72 64 29 3b 0a 20  n", nKeyword);. 
5150: 20 66 6f 72 28 69 3d 6a 3d 30 3b 20 69 3c 6e 4b   for(i=j=0; i<nK
5160: 65 79 77 6f 72 64 3b 20 69 2b 2b 29 7b 0a 20 20  eyword; i++){.  
5170: 20 20 69 66 28 20 6a 3d 3d 30 20 29 20 70 72 69    if( j==0 ) pri
5180: 6e 74 66 28 22 20 20 22 29 3b 0a 20 20 20 20 70  ntf("  ");.    p
5190: 72 69 6e 74 66 28 22 20 25 33 64 2c 22 2c 20 61  rintf(" %3d,", a
51a0: 4b 65 79 77 6f 72 64 54 61 62 6c 65 5b 69 5d 2e  KeywordTable[i].
51b0: 6c 65 6e 2b 61 4b 65 79 77 6f 72 64 54 61 62 6c  len+aKeywordTabl
51c0: 65 5b 69 5d 2e 70 72 65 66 69 78 29 3b 0a 20 20  e[i].prefix);.  
51d0: 20 20 6a 2b 2b 3b 0a 20 20 20 20 69 66 28 20 6a    j++;.    if( j
51e0: 3e 31 32 20 29 7b 0a 20 20 20 20 20 20 70 72 69  >12 ){.      pri
51f0: 6e 74 66 28 22 5c 6e 22 29 3b 0a 20 20 20 20 20  ntf("\n");.     
5200: 20 6a 20 3d 20 30 3b 0a 20 20 20 20 7d 0a 20 20   j = 0;.    }.  
5210: 7d 0a 20 20 70 72 69 6e 74 66 28 22 25 73 7d 3b  }.  printf("%s};
5220: 5c 6e 22 2c 20 6a 3d 3d 30 20 3f 20 22 22 20 3a  \n", j==0 ? "" :
5230: 20 22 5c 6e 22 29 3b 20 20 20 20 0a 0a 20 20 70   "\n");    ..  p
5240: 72 69 6e 74 66 28 22 2f 2a 20 61 4b 57 4f 66 66  rintf("/* aKWOff
5250: 73 65 74 5b 69 5d 20 69 73 20 74 68 65 20 69 6e  set[i] is the in
5260: 64 65 78 20 69 6e 74 6f 20 7a 4b 57 54 65 78 74  dex into zKWText
5270: 5b 5d 20 6f 66 20 74 68 65 20 73 74 61 72 74 20  [] of the start 
5280: 6f 66 5c 6e 22 29 3b 0a 20 20 70 72 69 6e 74 66  of\n");.  printf
5290: 28 22 2a 2a 20 74 68 65 20 74 65 78 74 20 66 6f  ("** the text fo
52a0: 72 20 74 68 65 20 69 2d 74 68 20 6b 65 79 77 6f  r the i-th keywo
52b0: 72 64 2e 20 2a 2f 5c 6e 22 29 3b 0a 20 20 70 72  rd. */\n");.  pr
52c0: 69 6e 74 66 28 22 73 74 61 74 69 63 20 63 6f 6e  intf("static con
52d0: 73 74 20 75 6e 73 69 67 6e 65 64 20 73 68 6f 72  st unsigned shor
52e0: 74 20 69 6e 74 20 61 4b 57 4f 66 66 73 65 74 5b  t int aKWOffset[
52f0: 25 64 5d 20 3d 20 7b 5c 6e 22 2c 20 6e 4b 65 79  %d] = {\n", nKey
5300: 77 6f 72 64 29 3b 0a 20 20 66 6f 72 28 69 3d 6a  word);.  for(i=j
5310: 3d 30 3b 20 69 3c 6e 4b 65 79 77 6f 72 64 3b 20  =0; i<nKeyword; 
5320: 69 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20 6a 3d  i++){.    if( j=
5330: 3d 30 20 29 20 70 72 69 6e 74 66 28 22 20 20 22  =0 ) printf("  "
5340: 29 3b 0a 20 20 20 20 70 72 69 6e 74 66 28 22 20  );.    printf(" 
5350: 25 33 64 2c 22 2c 20 61 4b 65 79 77 6f 72 64 54  %3d,", aKeywordT
5360: 61 62 6c 65 5b 69 5d 2e 6f 66 66 73 65 74 29 3b  able[i].offset);
5370: 0a 20 20 20 20 6a 2b 2b 3b 0a 20 20 20 20 69 66  .    j++;.    if
5380: 28 20 6a 3e 31 32 20 29 7b 0a 20 20 20 20 20 20  ( j>12 ){.      
5390: 70 72 69 6e 74 66 28 22 5c 6e 22 29 3b 0a 20 20  printf("\n");.  
53a0: 20 20 20 20 6a 20 3d 20 30 3b 0a 20 20 20 20 7d      j = 0;.    }
53b0: 0a 20 20 7d 0a 20 20 70 72 69 6e 74 66 28 22 25  .  }.  printf("%
53c0: 73 7d 3b 5c 6e 22 2c 20 6a 3d 3d 30 20 3f 20 22  s};\n", j==0 ? "
53d0: 22 20 3a 20 22 5c 6e 22 29 3b 0a 0a 20 20 70 72  " : "\n");..  pr
53e0: 69 6e 74 66 28 22 2f 2a 20 61 4b 57 43 6f 64 65  intf("/* aKWCode
53f0: 5b 69 5d 20 69 73 20 74 68 65 20 70 61 72 73 65  [i] is the parse
5400: 72 20 73 79 6d 62 6f 6c 20 63 6f 64 65 20 66 6f  r symbol code fo
5410: 72 20 74 68 65 20 69 2d 74 68 20 6b 65 79 77 6f  r the i-th keywo
5420: 72 64 20 2a 2f 5c 6e 22 29 3b 0a 20 20 70 72 69  rd */\n");.  pri
5430: 6e 74 66 28 22 73 74 61 74 69 63 20 63 6f 6e 73  ntf("static cons
5440: 74 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20  t unsigned char 
5450: 61 4b 57 43 6f 64 65 5b 25 64 5d 20 3d 20 7b 5c  aKWCode[%d] = {\
5460: 6e 22 2c 20 6e 4b 65 79 77 6f 72 64 29 3b 0a 20  n", nKeyword);. 
5470: 20 66 6f 72 28 69 3d 6a 3d 30 3b 20 69 3c 6e 4b   for(i=j=0; i<nK
5480: 65 79 77 6f 72 64 3b 20 69 2b 2b 29 7b 0a 20 20  eyword; i++){.  
5490: 20 20 63 68 61 72 20 2a 7a 54 6f 6b 65 6e 20 3d    char *zToken =
54a0: 20 61 4b 65 79 77 6f 72 64 54 61 62 6c 65 5b 69   aKeywordTable[i
54b0: 5d 2e 7a 54 6f 6b 65 6e 54 79 70 65 3b 0a 20 20  ].zTokenType;.  
54c0: 20 20 69 66 28 20 6a 3d 3d 30 20 29 20 70 72 69    if( j==0 ) pri
54d0: 6e 74 66 28 22 20 20 22 29 3b 0a 20 20 20 20 70  ntf("  ");.    p
54e0: 72 69 6e 74 66 28 22 25 73 2c 25 2a 73 22 2c 20  rintf("%s,%*s", 
54f0: 7a 54 6f 6b 65 6e 2c 20 28 69 6e 74 29 28 31 34  zToken, (int)(14
5500: 2d 73 74 72 6c 65 6e 28 7a 54 6f 6b 65 6e 29 29  -strlen(zToken))
5510: 2c 20 22 22 29 3b 0a 20 20 20 20 6a 2b 2b 3b 0a  , "");.    j++;.
5520: 20 20 20 20 69 66 28 20 6a 3e 3d 35 20 29 7b 0a      if( j>=5 ){.
5530: 20 20 20 20 20 20 70 72 69 6e 74 66 28 22 5c 6e        printf("\n
5540: 22 29 3b 0a 20 20 20 20 20 20 6a 20 3d 20 30 3b  ");.      j = 0;
5550: 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 70 72 69  .    }.  }.  pri
5560: 6e 74 66 28 22 25 73 7d 3b 5c 6e 22 2c 20 6a 3d  ntf("%s};\n", j=
5570: 3d 30 20 3f 20 22 22 20 3a 20 22 5c 6e 22 29 3b  =0 ? "" : "\n");
5580: 0a 20 20 70 72 69 6e 74 66 28 22 2f 2a 20 43 68  .  printf("/* Ch
5590: 65 63 6b 20 74 6f 20 73 65 65 20 69 66 20 7a 5b  eck to see if z[
55a0: 30 2e 2e 6e 2d 31 5d 20 69 73 20 61 20 6b 65 79  0..n-1] is a key
55b0: 77 6f 72 64 2e 20 49 66 20 69 74 20 69 73 2c 20  word. If it is, 
55c0: 77 72 69 74 65 20 74 68 65 5c 6e 22 29 3b 0a 20  write the\n");. 
55d0: 20 70 72 69 6e 74 66 28 22 2a 2a 20 70 61 72 73   printf("** pars
55e0: 65 72 20 73 79 6d 62 6f 6c 20 63 6f 64 65 20 66  er symbol code f
55f0: 6f 72 20 74 68 61 74 20 6b 65 79 77 6f 72 64 20  or that keyword 
5600: 69 6e 74 6f 20 2a 70 54 79 70 65 2e 20 20 41 6c  into *pType.  Al
5610: 77 61 79 73 5c 6e 22 29 3b 0a 20 20 70 72 69 6e  ways\n");.  prin
5620: 74 66 28 22 2a 2a 20 72 65 74 75 72 6e 20 74 68  tf("** return th
5630: 65 20 69 6e 74 65 67 65 72 20 6e 20 28 74 68 65  e integer n (the
5640: 20 6c 65 6e 67 74 68 20 6f 66 20 74 68 65 20 74   length of the t
5650: 6f 6b 65 6e 29 2e 20 2a 2f 5c 6e 22 29 3b 0a 20  oken). */\n");. 
5660: 20 70 72 69 6e 74 66 28 22 73 74 61 74 69 63 20   printf("static 
5670: 69 6e 74 20 6b 65 79 77 6f 72 64 43 6f 64 65 28  int keywordCode(
5680: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 2c 20 69  const char *z, i
5690: 6e 74 20 6e 2c 20 69 6e 74 20 2a 70 54 79 70 65  nt n, int *pType
56a0: 29 7b 5c 6e 22 29 3b 0a 20 20 70 72 69 6e 74 66  ){\n");.  printf
56b0: 28 22 20 20 69 6e 74 20 69 2c 20 6a 3b 5c 6e 22  ("  int i, j;\n"
56c0: 29 3b 0a 20 20 70 72 69 6e 74 66 28 22 20 20 63  );.  printf("  c
56d0: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 4b 57 3b 5c  onst char *zKW;\
56e0: 6e 22 29 3b 0a 20 20 70 72 69 6e 74 66 28 22 20  n");.  printf(" 
56f0: 20 69 66 28 20 6e 3e 3d 32 20 29 7b 5c 6e 22 29   if( n>=2 ){\n")
5700: 3b 0a 20 20 70 72 69 6e 74 66 28 22 20 20 20 20  ;.  printf("    
5710: 69 20 3d 20 28 28 63 68 61 72 4d 61 70 28 7a 5b  i = ((charMap(z[
5720: 30 5d 29 2a 34 29 20 5e 20 28 63 68 61 72 4d 61  0])*4) ^ (charMa
5730: 70 28 7a 5b 6e 2d 31 5d 29 2a 33 29 20 5e 20 6e  p(z[n-1])*3) ^ n
5740: 29 20 25 25 20 25 64 3b 5c 6e 22 2c 0a 20 20 20  ) %% %d;\n",.   
5750: 20 20 20 20 20 20 20 62 65 73 74 53 69 7a 65 29         bestSize)
5760: 3b 0a 20 20 70 72 69 6e 74 66 28 22 20 20 20 20  ;.  printf("    
5770: 66 6f 72 28 69 3d 28 28 69 6e 74 29 61 4b 57 48  for(i=((int)aKWH
5780: 61 73 68 5b 69 5d 29 2d 31 3b 20 69 3e 3d 30 3b  ash[i])-1; i>=0;
5790: 20 69 3d 28 28 69 6e 74 29 61 4b 57 4e 65 78 74   i=((int)aKWNext
57a0: 5b 69 5d 29 2d 31 29 7b 5c 6e 22 29 3b 0a 20 20  [i])-1){\n");.  
57b0: 70 72 69 6e 74 66 28 22 20 20 20 20 20 20 69 66  printf("      if
57c0: 28 20 61 4b 57 4c 65 6e 5b 69 5d 21 3d 6e 20 29  ( aKWLen[i]!=n )
57d0: 20 63 6f 6e 74 69 6e 75 65 3b 5c 6e 22 29 3b 0a   continue;\n");.
57e0: 20 20 70 72 69 6e 74 66 28 22 20 20 20 20 20 20    printf("      
57f0: 6a 20 3d 20 30 3b 5c 6e 22 29 3b 0a 20 20 70 72  j = 0;\n");.  pr
5800: 69 6e 74 66 28 22 20 20 20 20 20 20 7a 4b 57 20  intf("      zKW 
5810: 3d 20 26 7a 4b 57 54 65 78 74 5b 61 4b 57 4f 66  = &zKWText[aKWOf
5820: 66 73 65 74 5b 69 5d 5d 3b 5c 6e 22 29 3b 0a 20  fset[i]];\n");. 
5830: 20 70 72 69 6e 74 66 28 22 23 69 66 64 65 66 20   printf("#ifdef 
5840: 53 51 4c 49 54 45 5f 41 53 43 49 49 5c 6e 22 29  SQLITE_ASCII\n")
5850: 3b 0a 20 20 70 72 69 6e 74 66 28 22 20 20 20 20  ;.  printf("    
5860: 20 20 77 68 69 6c 65 28 20 6a 3c 6e 20 26 26 20    while( j<n && 
5870: 28 7a 5b 6a 5d 26 7e 30 78 32 30 29 3d 3d 7a 4b  (z[j]&~0x20)==zK
5880: 57 5b 6a 5d 20 29 7b 20 6a 2b 2b 3b 20 7d 5c 6e  W[j] ){ j++; }\n
5890: 22 29 3b 0a 20 20 70 72 69 6e 74 66 28 22 23 65  ");.  printf("#e
58a0: 6e 64 69 66 5c 6e 22 29 3b 0a 20 20 70 72 69 6e  ndif\n");.  prin
58b0: 74 66 28 22 23 69 66 64 65 66 20 53 51 4c 49 54  tf("#ifdef SQLIT
58c0: 45 5f 45 42 43 44 49 43 5c 6e 22 29 3b 0a 20 20  E_EBCDIC\n");.  
58d0: 70 72 69 6e 74 66 28 22 20 20 20 20 20 20 77 68  printf("      wh
58e0: 69 6c 65 28 20 6a 3c 6e 20 26 26 20 74 6f 75 70  ile( j<n && toup
58f0: 70 65 72 28 7a 5b 6a 5d 29 3d 3d 7a 4b 57 5b 6a  per(z[j])==zKW[j
5900: 5d 20 29 7b 20 6a 2b 2b 3b 20 7d 5c 6e 22 29 3b  ] ){ j++; }\n");
5910: 0a 20 20 70 72 69 6e 74 66 28 22 23 65 6e 64 69  .  printf("#endi
5920: 66 5c 6e 22 29 3b 0a 20 20 70 72 69 6e 74 66 28  f\n");.  printf(
5930: 22 20 20 20 20 20 20 69 66 28 20 6a 3c 6e 20 29  "      if( j<n )
5940: 20 63 6f 6e 74 69 6e 75 65 3b 5c 6e 22 29 3b 0a   continue;\n");.
5950: 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 6e 4b 65    for(i=0; i<nKe
5960: 79 77 6f 72 64 3b 20 69 2b 2b 29 7b 0a 20 20 20  yword; i++){.   
5970: 20 70 72 69 6e 74 66 28 22 20 20 20 20 20 20 74   printf("      t
5980: 65 73 74 63 61 73 65 28 20 69 3d 3d 25 64 20 29  estcase( i==%d )
5990: 3b 20 2f 2a 20 25 73 20 2a 2f 5c 6e 22 2c 0a 20  ; /* %s */\n",. 
59a0: 20 20 20 20 20 20 20 20 20 20 69 2c 20 61 4b 65            i, aKe
59b0: 79 77 6f 72 64 54 61 62 6c 65 5b 69 5d 2e 7a 4f  ywordTable[i].zO
59c0: 72 69 67 4e 61 6d 65 29 3b 0a 20 20 7d 0a 20 20  rigName);.  }.  
59d0: 70 72 69 6e 74 66 28 22 20 20 20 20 20 20 2a 70  printf("      *p
59e0: 54 79 70 65 20 3d 20 61 4b 57 43 6f 64 65 5b 69  Type = aKWCode[i
59f0: 5d 3b 5c 6e 22 29 3b 0a 20 20 70 72 69 6e 74 66  ];\n");.  printf
5a00: 28 22 20 20 20 20 20 20 62 72 65 61 6b 3b 5c 6e  ("      break;\n
5a10: 22 29 3b 0a 20 20 70 72 69 6e 74 66 28 22 20 20  ");.  printf("  
5a20: 20 20 7d 5c 6e 22 29 3b 0a 20 20 70 72 69 6e 74    }\n");.  print
5a30: 66 28 22 20 20 7d 5c 6e 22 29 3b 0a 20 20 70 72  f("  }\n");.  pr
5a40: 69 6e 74 66 28 22 20 20 72 65 74 75 72 6e 20 6e  intf("  return n
5a50: 3b 5c 6e 22 29 3b 0a 20 20 70 72 69 6e 74 66 28  ;\n");.  printf(
5a60: 22 7d 5c 6e 22 29 3b 0a 20 20 70 72 69 6e 74 66  "}\n");.  printf
5a70: 28 22 69 6e 74 20 73 71 6c 69 74 65 33 4b 65 79  ("int sqlite3Key
5a80: 77 6f 72 64 43 6f 64 65 28 63 6f 6e 73 74 20 75  wordCode(const u
5a90: 6e 73 69 67 6e 65 64 20 63 68 61 72 20 2a 7a 2c  nsigned char *z,
5aa0: 20 69 6e 74 20 6e 29 7b 5c 6e 22 29 3b 0a 20 20   int n){\n");.  
5ab0: 70 72 69 6e 74 66 28 22 20 20 69 6e 74 20 69 64  printf("  int id
5ac0: 20 3d 20 54 4b 5f 49 44 3b 5c 6e 22 29 3b 0a 20   = TK_ID;\n");. 
5ad0: 20 70 72 69 6e 74 66 28 22 20 20 6b 65 79 77 6f   printf("  keywo
5ae0: 72 64 43 6f 64 65 28 28 63 68 61 72 2a 29 7a 2c  rdCode((char*)z,
5af0: 20 6e 2c 20 26 69 64 29 3b 5c 6e 22 29 3b 0a 20   n, &id);\n");. 
5b00: 20 70 72 69 6e 74 66 28 22 20 20 72 65 74 75 72   printf("  retur
5b10: 6e 20 69 64 3b 5c 6e 22 29 3b 0a 20 20 70 72 69  n id;\n");.  pri
5b20: 6e 74 66 28 22 7d 5c 6e 22 29 3b 0a 20 20 70 72  ntf("}\n");.  pr
5b30: 69 6e 74 66 28 22 23 64 65 66 69 6e 65 20 53 51  intf("#define SQ
5b40: 4c 49 54 45 5f 4e 5f 4b 45 59 57 4f 52 44 20 25  LITE_N_KEYWORD %
5b50: 64 5c 6e 22 2c 20 6e 4b 65 79 77 6f 72 64 29 3b  d\n", nKeyword);
5b60: 0a 20 20 70 72 69 6e 74 66 28 22 69 6e 74 20 73  .  printf("int s
5b70: 71 6c 69 74 65 33 5f 6b 65 79 77 6f 72 64 5f 6e  qlite3_keyword_n
5b80: 61 6d 65 28 69 6e 74 20 69 2c 63 6f 6e 73 74 20  ame(int i,const 
5b90: 63 68 61 72 20 2a 2a 70 7a 4e 61 6d 65 2c 69 6e  char **pzName,in
5ba0: 74 20 2a 70 6e 4e 61 6d 65 29 7b 5c 6e 22 29 3b  t *pnName){\n");
5bb0: 0a 20 20 70 72 69 6e 74 66 28 22 20 20 69 66 28  .  printf("  if(
5bc0: 20 69 3c 30 20 7c 7c 20 69 3e 3d 53 51 4c 49 54   i<0 || i>=SQLIT
5bd0: 45 5f 4e 5f 4b 45 59 57 4f 52 44 20 29 20 72 65  E_N_KEYWORD ) re
5be0: 74 75 72 6e 20 53 51 4c 49 54 45 5f 45 52 52 4f  turn SQLITE_ERRO
5bf0: 52 3b 5c 6e 22 29 3b 0a 20 20 70 72 69 6e 74 66  R;\n");.  printf
5c00: 28 22 20 20 2a 70 7a 4e 61 6d 65 20 3d 20 7a 4b  ("  *pzName = zK
5c10: 57 54 65 78 74 20 2b 20 61 4b 57 4f 66 66 73 65  WText + aKWOffse
5c20: 74 5b 69 5d 3b 5c 6e 22 29 3b 0a 20 20 70 72 69  t[i];\n");.  pri
5c30: 6e 74 66 28 22 20 20 2a 70 6e 4e 61 6d 65 20 3d  ntf("  *pnName =
5c40: 20 61 4b 57 4c 65 6e 5b 69 5d 3b 5c 6e 22 29 3b   aKWLen[i];\n");
5c50: 0a 20 20 70 72 69 6e 74 66 28 22 20 20 72 65 74  .  printf("  ret
5c60: 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 5c 6e  urn SQLITE_OK;\n
5c70: 22 29 3b 0a 20 20 70 72 69 6e 74 66 28 22 7d 5c  ");.  printf("}\
5c80: 6e 22 29 3b 0a 20 20 70 72 69 6e 74 66 28 22 69  n");.  printf("i
5c90: 6e 74 20 73 71 6c 69 74 65 33 5f 6b 65 79 77 6f  nt sqlite3_keywo
5ca0: 72 64 5f 63 6f 75 6e 74 28 76 6f 69 64 29 7b 20  rd_count(void){ 
5cb0: 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4e 5f  return SQLITE_N_
5cc0: 4b 45 59 57 4f 52 44 3b 20 7d 5c 6e 22 29 3b 0a  KEYWORD; }\n");.
5cd0: 20 20 70 72 69 6e 74 66 28 22 69 6e 74 20 73 71    printf("int sq
5ce0: 6c 69 74 65 33 5f 6b 65 79 77 6f 72 64 5f 63 68  lite3_keyword_ch
5cf0: 65 63 6b 28 63 6f 6e 73 74 20 63 68 61 72 20 2a  eck(const char *
5d00: 7a 4e 61 6d 65 2c 20 69 6e 74 20 6e 4e 61 6d 65  zName, int nName
5d10: 29 7b 5c 6e 22 29 3b 0a 20 20 70 72 69 6e 74 66  ){\n");.  printf
5d20: 28 22 20 20 72 65 74 75 72 6e 20 54 4b 5f 49 44  ("  return TK_ID
5d30: 21 3d 73 71 6c 69 74 65 33 4b 65 79 77 6f 72 64  !=sqlite3Keyword
5d40: 43 6f 64 65 28 28 63 6f 6e 73 74 20 75 38 2a 29  Code((const u8*)
5d50: 7a 4e 61 6d 65 2c 20 6e 4e 61 6d 65 29 3b 5c 6e  zName, nName);\n
5d60: 22 29 3b 0a 20 20 70 72 69 6e 74 66 28 22 7d 5c  ");.  printf("}\
5d70: 6e 22 29 3b 0a 0a 20 20 72 65 74 75 72 6e 20 30  n");..  return 0
5d80: 3b 0a 7d 0a                                      ;.}.