/ Hex Artifact Content
Login

Artifact 428a050780425be2d699e939605fcbc54a161c20884f11b476b2eea961394bbe:


0000: 2f 2a 0a 2a 2a 20 32 30 30 30 2d 30 35 2d 32 39  /*.** 2000-05-29
0010: 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74 68 6f  .**.** The autho
0020: 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70 79  r disclaims copy
0030: 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73 6f  right to this so
0040: 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20 70  urce code.  In p
0050: 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c 65 67  lace of.** a leg
0060: 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20  al notice, here 
0070: 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 2a  is a blessing:.*
0080: 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f 75 20  *.**    May you 
0090: 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20  do good and not 
00a0: 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61 79 20  evil..**    May 
00b0: 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69 76 65  you find forgive
00c0: 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73 65 6c  ness for yoursel
00d0: 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20 6f 74  f and forgive ot
00e0: 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61 79 20  hers..**    May 
00f0: 79 6f 75 20 73 68 61 72 65 20 66 72 65 65 6c 79  you share freely
0100: 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67 20 6d  , never taking m
0110: 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67 69 76  ore than you giv
0120: 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  e..**.**********
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 0a  ***************.
0170: 2a 2a 20 44 72 69 76 65 72 20 74 65 6d 70 6c 61  ** Driver templa
0180: 74 65 20 66 6f 72 20 74 68 65 20 4c 45 4d 4f 4e  te for the LEMON
0190: 20 70 61 72 73 65 72 20 67 65 6e 65 72 61 74 6f   parser generato
01a0: 72 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20 22 6c 65  r..**.** The "le
01b0: 6d 6f 6e 22 20 70 72 6f 67 72 61 6d 20 70 72 6f  mon" program pro
01c0: 63 65 73 73 65 73 20 61 6e 20 4c 41 4c 52 28 31  cesses an LALR(1
01d0: 29 20 69 6e 70 75 74 20 67 72 61 6d 6d 61 72 20  ) input grammar 
01e0: 66 69 6c 65 2c 20 74 68 65 6e 20 75 73 65 73 0a  file, then uses.
01f0: 2a 2a 20 74 68 69 73 20 74 65 6d 70 6c 61 74 65  ** this template
0200: 20 74 6f 20 63 6f 6e 73 74 72 75 63 74 20 61 20   to construct a 
0210: 70 61 72 73 65 72 2e 20 20 54 68 65 20 22 6c 65  parser.  The "le
0220: 6d 6f 6e 22 20 70 72 6f 67 72 61 6d 20 69 6e 73  mon" program ins
0230: 65 72 74 73 20 74 65 78 74 0a 2a 2a 20 61 74 20  erts text.** at 
0240: 65 61 63 68 20 22 25 25 22 20 6c 69 6e 65 2e 20  each "%%" line. 
0250: 20 41 6c 73 6f 2c 20 61 6e 79 20 22 50 2d 61 2d   Also, any "P-a-
0260: 72 2d 73 2d 65 22 20 69 64 65 6e 74 69 66 65 72  r-s-e" identifer
0270: 20 70 72 65 66 69 78 20 28 77 69 74 68 6f 75 74   prefix (without
0280: 20 74 68 65 0a 2a 2a 20 69 6e 74 65 72 73 74 69   the.** intersti
0290: 74 69 61 6c 20 22 2d 22 20 63 68 61 72 61 63 74  tial "-" charact
02a0: 65 72 73 29 20 63 6f 6e 74 61 69 6e 65 64 20 69  ers) contained i
02b0: 6e 20 74 68 69 73 20 74 65 6d 70 6c 61 74 65 20  n this template 
02c0: 69 73 20 63 68 61 6e 67 65 64 20 69 6e 74 6f 0a  is changed into.
02d0: 2a 2a 20 74 68 65 20 76 61 6c 75 65 20 6f 66 20  ** the value of 
02e0: 74 68 65 20 25 6e 61 6d 65 20 64 69 72 65 63 74  the %name direct
02f0: 69 76 65 20 66 72 6f 6d 20 74 68 65 20 67 72 61  ive from the gra
0300: 6d 6d 61 72 2e 20 20 4f 74 68 65 72 77 69 73 65  mmar.  Otherwise
0310: 2c 20 74 68 65 20 63 6f 6e 74 65 6e 74 0a 2a 2a  , the content.**
0320: 20 6f 66 20 74 68 69 73 20 74 65 6d 70 6c 61 74   of this templat
0330: 65 20 69 73 20 63 6f 70 69 65 64 20 73 74 72 61  e is copied stra
0340: 69 67 68 74 20 74 68 72 6f 75 67 68 20 69 6e 74  ight through int
0350: 6f 20 74 68 65 20 67 65 6e 65 72 61 74 65 20 70  o the generate p
0360: 61 72 73 65 72 0a 2a 2a 20 73 6f 75 72 63 65 20  arser.** source 
0370: 66 69 6c 65 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20  file..**.** The 
0380: 66 6f 6c 6c 6f 77 69 6e 67 20 69 73 20 74 68 65  following is the
0390: 20 63 6f 6e 63 61 74 65 6e 61 74 69 6f 6e 20 6f   concatenation o
03a0: 66 20 61 6c 6c 20 25 69 6e 63 6c 75 64 65 20 64  f all %include d
03b0: 69 72 65 63 74 69 76 65 73 20 66 72 6f 6d 20 74  irectives from t
03c0: 68 65 0a 2a 2a 20 69 6e 70 75 74 20 67 72 61 6d  he.** input gram
03d0: 6d 61 72 20 66 69 6c 65 3a 0a 2a 2f 0a 23 69 6e  mar file:.*/.#in
03e0: 63 6c 75 64 65 20 3c 73 74 64 69 6f 2e 68 3e 0a  clude <stdio.h>.
03f0: 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 20 42 65  /************ Be
0400: 67 69 6e 20 25 69 6e 63 6c 75 64 65 20 73 65 63  gin %include sec
0410: 74 69 6f 6e 73 20 66 72 6f 6d 20 74 68 65 20 67  tions from the g
0420: 72 61 6d 6d 61 72 20 2a 2a 2a 2a 2a 2a 2a 2a 2a  rammar *********
0430: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f  ***************/
0440: 0a 25 25 0a 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  .%%./***********
0450: 2a 2a 2a 2a 2a 20 45 6e 64 20 6f 66 20 25 69 6e  ***** End of %in
0460: 63 6c 75 64 65 20 64 69 72 65 63 74 69 76 65 73  clude directives
0470: 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a   ***************
0480: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0490: 2a 2a 2a 2f 0a 2f 2a 20 54 68 65 73 65 20 63 6f  ***/./* These co
04a0: 6e 73 74 61 6e 74 73 20 73 70 65 63 69 66 79 20  nstants specify 
04b0: 74 68 65 20 76 61 72 69 6f 75 73 20 6e 75 6d 65  the various nume
04c0: 72 69 63 20 76 61 6c 75 65 73 20 66 6f 72 20 74  ric values for t
04d0: 65 72 6d 69 6e 61 6c 20 73 79 6d 62 6f 6c 73 0a  erminal symbols.
04e0: 2a 2a 20 69 6e 20 61 20 66 6f 72 6d 61 74 20 75  ** in a format u
04f0: 6e 64 65 72 73 74 61 6e 64 61 62 6c 65 20 74 6f  nderstandable to
0500: 20 22 6d 61 6b 65 68 65 61 64 65 72 73 22 2e 20   "makeheaders". 
0510: 20 54 68 69 73 20 73 65 63 74 69 6f 6e 20 69 73   This section is
0520: 20 62 6c 61 6e 6b 20 75 6e 6c 65 73 73 0a 2a 2a   blank unless.**
0530: 20 22 6c 65 6d 6f 6e 22 20 69 73 20 72 75 6e 20   "lemon" is run 
0540: 77 69 74 68 20 74 68 65 20 22 2d 6d 22 20 63 6f  with the "-m" co
0550: 6d 6d 61 6e 64 2d 6c 69 6e 65 20 6f 70 74 69 6f  mmand-line optio
0560: 6e 2e 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  n..*************
0570: 2a 2a 2a 2a 20 42 65 67 69 6e 20 6d 61 6b 65 68  **** Begin makeh
0580: 65 61 64 65 72 73 20 74 6f 6b 65 6e 20 64 65 66  eaders token def
0590: 69 6e 69 74 69 6f 6e 73 20 2a 2a 2a 2a 2a 2a 2a  initions *******
05a0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
05b0: 2a 2a 2f 0a 25 25 0a 2f 2a 2a 2a 2a 2a 2a 2a 2a  **/.%%./********
05c0: 2a 2a 2a 2a 2a 2a 2a 2a 20 45 6e 64 20 6d 61 6b  ******** End mak
05d0: 65 68 65 61 64 65 72 73 20 74 6f 6b 65 6e 20 64  eheaders token d
05e0: 65 66 69 6e 69 74 69 6f 6e 73 20 2a 2a 2a 2a 2a  efinitions *****
05f0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0600: 2a 2a 2a 2a 2a 2a 2f 0a 0a 2f 2a 20 54 68 65 20  ******/../* The 
0610: 6e 65 78 74 20 73 65 63 74 69 6f 6e 73 20 69 73  next sections is
0620: 20 61 20 73 65 72 69 65 73 20 6f 66 20 63 6f 6e   a series of con
0630: 74 72 6f 6c 20 23 64 65 66 69 6e 65 73 2e 0a 2a  trol #defines..*
0640: 2a 20 76 61 72 69 6f 75 73 20 61 73 70 65 63 74  * various aspect
0650: 73 20 6f 66 20 74 68 65 20 67 65 6e 65 72 61 74  s of the generat
0660: 65 64 20 70 61 72 73 65 72 2e 0a 2a 2a 20 20 20  ed parser..**   
0670: 20 59 59 43 4f 44 45 54 59 50 45 20 20 20 20 20   YYCODETYPE     
0680: 20 20 20 20 69 73 20 74 68 65 20 64 61 74 61 20      is the data 
0690: 74 79 70 65 20 75 73 65 64 20 74 6f 20 73 74 6f  type used to sto
06a0: 72 65 20 74 68 65 20 69 6e 74 65 67 65 72 20 63  re the integer c
06b0: 6f 64 65 73 0a 2a 2a 20 20 20 20 20 20 20 20 20  odes.**         
06c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 74 68                th
06d0: 61 74 20 72 65 70 72 65 73 65 6e 74 20 74 65 72  at represent ter
06e0: 6d 69 6e 61 6c 20 61 6e 64 20 6e 6f 6e 2d 74 65  minal and non-te
06f0: 72 6d 69 6e 61 6c 20 73 79 6d 62 6f 6c 73 2e 0a  rminal symbols..
0700: 2a 2a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  **              
0710: 20 20 20 20 20 20 20 20 20 22 75 6e 73 69 67 6e           "unsign
0720: 65 64 20 63 68 61 72 22 20 69 73 20 75 73 65 64  ed char" is used
0730: 20 69 66 20 74 68 65 72 65 20 61 72 65 20 66 65   if there are fe
0740: 77 65 72 20 74 68 61 6e 0a 2a 2a 20 20 20 20 20  wer than.**     
0750: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0760: 20 20 32 35 36 20 73 79 6d 62 6f 6c 73 2e 20 20    256 symbols.  
0770: 4c 61 72 67 65 72 20 74 79 70 65 73 20 6f 74 68  Larger types oth
0780: 65 72 77 69 73 65 2e 0a 2a 2a 20 20 20 20 59 59  erwise..**    YY
0790: 4e 4f 43 4f 44 45 20 20 20 20 20 20 20 20 20 20  NOCODE          
07a0: 20 69 73 20 61 20 6e 75 6d 62 65 72 20 6f 66 20   is a number of 
07b0: 74 79 70 65 20 59 59 43 4f 44 45 54 59 50 45 20  type YYCODETYPE 
07c0: 74 68 61 74 20 69 73 20 6e 6f 74 20 75 73 65 64  that is not used
07d0: 20 66 6f 72 0a 2a 2a 20 20 20 20 20 20 20 20 20   for.**         
07e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 61 6e                an
07f0: 79 20 74 65 72 6d 69 6e 61 6c 20 6f 72 20 6e 6f  y terminal or no
0800: 6e 74 65 72 6d 69 6e 61 6c 20 73 79 6d 62 6f 6c  nterminal symbol
0810: 2e 0a 2a 2a 20 20 20 20 59 59 46 41 4c 4c 42 41  ..**    YYFALLBA
0820: 43 4b 20 20 20 20 20 20 20 20 20 49 66 20 64 65  CK         If de
0830: 66 69 6e 65 64 2c 20 74 68 69 73 20 69 6e 64 69  fined, this indi
0840: 63 61 74 65 73 20 74 68 61 74 20 6f 6e 65 20 6f  cates that one o
0850: 72 20 6d 6f 72 65 20 74 6f 6b 65 6e 73 0a 2a 2a  r more tokens.**
0860: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0870: 20 20 20 20 20 20 20 28 61 6c 73 6f 20 6b 6e 6f         (also kno
0880: 77 6e 20 61 73 3a 20 22 74 65 72 6d 69 6e 61 6c  wn as: "terminal
0890: 20 73 79 6d 62 6f 6c 73 22 29 20 68 61 76 65 20   symbols") have 
08a0: 66 61 6c 6c 2d 62 61 63 6b 0a 2a 2a 20 20 20 20  fall-back.**    
08b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
08c0: 20 20 20 76 61 6c 75 65 73 20 77 68 69 63 68 20     values which 
08d0: 73 68 6f 75 6c 64 20 62 65 20 75 73 65 64 20 69  should be used i
08e0: 66 20 74 68 65 20 6f 72 69 67 69 6e 61 6c 20 73  f the original s
08f0: 79 6d 62 6f 6c 0a 2a 2a 20 20 20 20 20 20 20 20  ymbol.**        
0900: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 77                 w
0910: 6f 75 6c 64 20 6e 6f 74 20 70 61 72 73 65 2e 20  ould not parse. 
0920: 20 54 68 69 73 20 70 65 72 6d 69 74 73 20 6b 65   This permits ke
0930: 79 77 6f 72 64 73 20 74 6f 20 73 6f 6d 65 74 69  ywords to someti
0940: 6d 65 73 0a 2a 2a 20 20 20 20 20 20 20 20 20 20  mes.**          
0950: 20 20 20 20 20 20 20 20 20 20 20 20 20 62 65 20               be 
0960: 75 73 65 64 20 61 73 20 69 64 65 6e 74 69 66 69  used as identifi
0970: 65 72 73 2c 20 66 6f 72 20 65 78 61 6d 70 6c 65  ers, for example
0980: 2e 0a 2a 2a 20 20 20 20 59 59 41 43 54 49 4f 4e  ..**    YYACTION
0990: 54 59 50 45 20 20 20 20 20 20 20 69 73 20 74 68  TYPE       is th
09a0: 65 20 64 61 74 61 20 74 79 70 65 20 75 73 65 64  e data type used
09b0: 20 66 6f 72 20 22 61 63 74 69 6f 6e 20 63 6f 64   for "action cod
09c0: 65 73 22 20 2d 20 6e 75 6d 62 65 72 73 0a 2a 2a  es" - numbers.**
09d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
09e0: 20 20 20 20 20 20 20 74 68 61 74 20 69 6e 64 69         that indi
09f0: 63 61 74 65 20 77 68 61 74 20 74 6f 20 64 6f 20  cate what to do 
0a00: 69 6e 20 72 65 73 70 6f 6e 73 65 20 74 6f 20 74  in response to t
0a10: 68 65 20 6e 65 78 74 0a 2a 2a 20 20 20 20 20 20  he next.**      
0a20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0a30: 20 74 6f 6b 65 6e 2e 0a 2a 2a 20 20 20 20 50 61   token..**    Pa
0a40: 72 73 65 54 4f 4b 45 4e 54 59 50 45 20 20 20 20  rseTOKENTYPE    
0a50: 20 69 73 20 74 68 65 20 64 61 74 61 20 74 79 70   is the data typ
0a60: 65 20 75 73 65 64 20 66 6f 72 20 6d 69 6e 6f 72  e used for minor
0a70: 20 74 79 70 65 20 66 6f 72 20 74 65 72 6d 69 6e   type for termin
0a80: 61 6c 0a 2a 2a 20 20 20 20 20 20 20 20 20 20 20  al.**           
0a90: 20 20 20 20 20 20 20 20 20 20 20 20 73 79 6d 62              symb
0aa0: 6f 6c 73 2e 20 20 42 61 63 6b 67 72 6f 75 6e 64  ols.  Background
0ab0: 3a 20 41 20 22 6d 69 6e 6f 72 20 74 79 70 65 22  : A "minor type"
0ac0: 20 69 73 20 61 20 73 65 6d 61 6e 74 69 63 0a 2a   is a semantic.*
0ad0: 2a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  *               
0ae0: 20 20 20 20 20 20 20 20 76 61 6c 75 65 20 61 73          value as
0af0: 73 6f 63 69 61 74 65 64 20 77 69 74 68 20 61 20  sociated with a 
0b00: 74 65 72 6d 69 6e 61 6c 20 6f 72 20 6e 6f 6e 2d  terminal or non-
0b10: 74 65 72 6d 69 6e 61 6c 0a 2a 2a 20 20 20 20 20  terminal.**     
0b20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0b30: 20 20 73 79 6d 62 6f 6c 73 2e 20 20 46 6f 72 20    symbols.  For 
0b40: 65 78 61 6d 70 6c 65 2c 20 66 6f 72 20 61 6e 20  example, for an 
0b50: 22 49 44 22 20 74 65 72 6d 69 6e 61 6c 20 73 79  "ID" terminal sy
0b60: 6d 62 6f 6c 2c 0a 2a 2a 20 20 20 20 20 20 20 20  mbol,.**        
0b70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 74                 t
0b80: 68 65 20 6d 69 6e 6f 72 20 74 79 70 65 20 6d 69  he minor type mi
0b90: 67 68 74 20 62 65 20 74 68 65 20 6e 61 6d 65 20  ght be the name 
0ba0: 6f 66 20 74 68 65 20 69 64 65 6e 74 69 66 69 65  of the identifie
0bb0: 72 2e 0a 2a 2a 20 20 20 20 20 20 20 20 20 20 20  r..**           
0bc0: 20 20 20 20 20 20 20 20 20 20 20 20 45 61 63 68              Each
0bd0: 20 6e 6f 6e 2d 74 65 72 6d 69 6e 61 6c 20 63 61   non-terminal ca
0be0: 6e 20 68 61 76 65 20 61 20 64 69 66 66 65 72 65  n have a differe
0bf0: 6e 74 20 6d 69 6e 6f 72 20 74 79 70 65 2e 0a 2a  nt minor type..*
0c00: 2a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  *               
0c10: 20 20 20 20 20 20 20 20 54 65 72 6d 69 6e 61 6c          Terminal
0c20: 20 73 79 6d 62 6f 6c 73 20 61 6c 6c 20 68 61 76   symbols all hav
0c30: 65 20 74 68 65 20 73 61 6d 65 20 6d 69 6e 6f 72  e the same minor
0c40: 20 74 79 70 65 2c 20 74 68 6f 75 67 68 2e 0a 2a   type, though..*
0c50: 2a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  *               
0c60: 20 20 20 20 20 20 20 20 54 68 69 73 20 6d 61 63          This mac
0c70: 72 6f 73 20 64 65 66 69 6e 65 73 20 74 68 65 20  ros defines the 
0c80: 6d 69 6e 6f 72 20 74 79 70 65 20 66 6f 72 20 74  minor type for t
0c90: 65 72 6d 69 6e 61 6c 20 0a 2a 2a 20 20 20 20 20  erminal .**     
0ca0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0cb0: 20 20 73 79 6d 62 6f 6c 73 2e 0a 2a 2a 20 20 20    symbols..**   
0cc0: 20 59 59 4d 49 4e 4f 52 54 59 50 45 20 20 20 20   YYMINORTYPE    
0cd0: 20 20 20 20 69 73 20 74 68 65 20 64 61 74 61 20      is the data 
0ce0: 74 79 70 65 20 75 73 65 64 20 66 6f 72 20 61 6c  type used for al
0cf0: 6c 20 6d 69 6e 6f 72 20 74 79 70 65 73 2e 0a 2a  l minor types..*
0d00: 2a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  *               
0d10: 20 20 20 20 20 20 20 20 54 68 69 73 20 69 73 20          This is 
0d20: 74 79 70 69 63 61 6c 6c 79 20 61 20 75 6e 69 6f  typically a unio
0d30: 6e 20 6f 66 20 6d 61 6e 79 20 74 79 70 65 73 2c  n of many types,
0d40: 20 6f 6e 65 20 6f 66 0a 2a 2a 20 20 20 20 20 20   one of.**      
0d50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0d60: 20 77 68 69 63 68 20 69 73 20 50 61 72 73 65 54   which is ParseT
0d70: 4f 4b 45 4e 54 59 50 45 2e 20 20 54 68 65 20 65  OKENTYPE.  The e
0d80: 6e 74 72 79 20 69 6e 20 74 68 65 20 75 6e 69 6f  ntry in the unio
0d90: 6e 0a 2a 2a 20 20 20 20 20 20 20 20 20 20 20 20  n.**            
0da0: 20 20 20 20 20 20 20 20 20 20 20 66 6f 72 20 74             for t
0db0: 65 72 6d 69 6e 61 6c 20 73 79 6d 62 6f 6c 73 20  erminal symbols 
0dc0: 69 73 20 63 61 6c 6c 65 64 20 22 79 79 30 22 2e  is called "yy0".
0dd0: 0a 2a 2a 20 20 20 20 59 59 53 54 41 43 4b 44 45  .**    YYSTACKDE
0de0: 50 54 48 20 20 20 20 20 20 20 69 73 20 74 68 65  PTH       is the
0df0: 20 6d 61 78 69 6d 75 6d 20 64 65 70 74 68 20 6f   maximum depth o
0e00: 66 20 74 68 65 20 70 61 72 73 65 72 27 73 20 73  f the parser's s
0e10: 74 61 63 6b 2e 20 20 49 66 0a 2a 2a 20 20 20 20  tack.  If.**    
0e20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0e30: 20 20 20 7a 65 72 6f 20 74 68 65 20 73 74 61 63     zero the stac
0e40: 6b 20 69 73 20 64 79 6e 61 6d 69 63 61 6c 6c 79  k is dynamically
0e50: 20 73 69 7a 65 64 20 75 73 69 6e 67 20 72 65 61   sized using rea
0e60: 6c 6c 6f 63 28 29 0a 2a 2a 20 20 20 20 50 61 72  lloc().**    Par
0e70: 73 65 41 52 47 5f 53 44 45 43 4c 20 20 20 20 20  seARG_SDECL     
0e80: 41 20 73 74 61 74 69 63 20 76 61 72 69 61 62 6c  A static variabl
0e90: 65 20 64 65 63 6c 61 72 61 74 69 6f 6e 20 66 6f  e declaration fo
0ea0: 72 20 74 68 65 20 25 65 78 74 72 61 5f 61 72 67  r the %extra_arg
0eb0: 75 6d 65 6e 74 0a 2a 2a 20 20 20 20 50 61 72 73  ument.**    Pars
0ec0: 65 41 52 47 5f 50 44 45 43 4c 20 20 20 20 20 41  eARG_PDECL     A
0ed0: 20 70 61 72 61 6d 65 74 65 72 20 64 65 63 6c 61   parameter decla
0ee0: 72 61 74 69 6f 6e 20 66 6f 72 20 74 68 65 20 25  ration for the %
0ef0: 65 78 74 72 61 5f 61 72 67 75 6d 65 6e 74 0a 2a  extra_argument.*
0f00: 2a 20 20 20 20 50 61 72 73 65 41 52 47 5f 50 41  *    ParseARG_PA
0f10: 52 41 4d 20 20 20 20 20 43 6f 64 65 20 74 6f 20  RAM     Code to 
0f20: 70 61 73 73 20 25 65 78 74 72 61 5f 61 72 67 75  pass %extra_argu
0f30: 6d 65 6e 74 20 61 73 20 61 20 73 75 62 72 6f 75  ment as a subrou
0f40: 74 69 6e 65 20 70 61 72 61 6d 65 74 65 72 0a 2a  tine parameter.*
0f50: 2a 20 20 20 20 50 61 72 73 65 41 52 47 5f 53 54  *    ParseARG_ST
0f60: 4f 52 45 20 20 20 20 20 43 6f 64 65 20 74 6f 20  ORE     Code to 
0f70: 73 74 6f 72 65 20 25 65 78 74 72 61 5f 61 72 67  store %extra_arg
0f80: 75 6d 65 6e 74 20 69 6e 74 6f 20 79 79 70 50 61  ument into yypPa
0f90: 72 73 65 72 0a 2a 2a 20 20 20 20 50 61 72 73 65  rser.**    Parse
0fa0: 41 52 47 5f 46 45 54 43 48 20 20 20 20 20 43 6f  ARG_FETCH     Co
0fb0: 64 65 20 74 6f 20 65 78 74 72 61 63 74 20 25 65  de to extract %e
0fc0: 78 74 72 61 5f 61 72 67 75 6d 65 6e 74 20 66 72  xtra_argument fr
0fd0: 6f 6d 20 79 79 70 50 61 72 73 65 72 0a 2a 2a 20  om yypParser.** 
0fe0: 20 20 20 50 61 72 73 65 43 54 58 5f 2a 20 20 20     ParseCTX_*   
0ff0: 20 20 20 20 20 20 41 73 20 50 61 72 73 65 41 52        As ParseAR
1000: 47 5f 20 65 78 63 65 70 74 20 66 6f 72 20 25 65  G_ except for %e
1010: 78 74 72 61 5f 63 6f 6e 74 65 78 74 0a 2a 2a 20  xtra_context.** 
1020: 20 20 20 59 59 45 52 52 4f 52 53 59 4d 42 4f 4c     YYERRORSYMBOL
1030: 20 20 20 20 20 20 69 73 20 74 68 65 20 63 6f 64        is the cod
1040: 65 20 6e 75 6d 62 65 72 20 6f 66 20 74 68 65 20  e number of the 
1050: 65 72 72 6f 72 20 73 79 6d 62 6f 6c 2e 20 20 49  error symbol.  I
1060: 66 20 6e 6f 74 0a 2a 2a 20 20 20 20 20 20 20 20  f not.**        
1070: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 64                 d
1080: 65 66 69 6e 65 64 2c 20 74 68 65 6e 20 64 6f 20  efined, then do 
1090: 6e 6f 20 65 72 72 6f 72 20 70 72 6f 63 65 73 73  no error process
10a0: 69 6e 67 2e 0a 2a 2a 20 20 20 20 59 59 4e 53 54  ing..**    YYNST
10b0: 41 54 45 20 20 20 20 20 20 20 20 20 20 20 74 68  ATE           th
10c0: 65 20 63 6f 6d 62 69 6e 65 64 20 6e 75 6d 62 65  e combined numbe
10d0: 72 20 6f 66 20 73 74 61 74 65 73 2e 0a 2a 2a 20  r of states..** 
10e0: 20 20 20 59 59 4e 52 55 4c 45 20 20 20 20 20 20     YYNRULE      
10f0: 20 20 20 20 20 20 74 68 65 20 6e 75 6d 62 65 72        the number
1100: 20 6f 66 20 72 75 6c 65 73 20 69 6e 20 74 68 65   of rules in the
1110: 20 67 72 61 6d 6d 61 72 0a 2a 2a 20 20 20 20 59   grammar.**    Y
1120: 59 4e 54 4f 4b 45 4e 20 20 20 20 20 20 20 20 20  YNTOKEN         
1130: 20 20 4e 75 6d 62 65 72 20 6f 66 20 74 65 72 6d    Number of term
1140: 69 6e 61 6c 20 73 79 6d 62 6f 6c 73 0a 2a 2a 20  inal symbols.** 
1150: 20 20 20 59 59 5f 4d 41 58 5f 53 48 49 46 54 20     YY_MAX_SHIFT 
1160: 20 20 20 20 20 20 4d 61 78 69 6d 75 6d 20 76 61        Maximum va
1170: 6c 75 65 20 66 6f 72 20 73 68 69 66 74 20 61 63  lue for shift ac
1180: 74 69 6f 6e 73 0a 2a 2a 20 20 20 20 59 59 5f 4d  tions.**    YY_M
1190: 49 4e 5f 53 48 49 46 54 52 45 44 55 43 45 20 4d  IN_SHIFTREDUCE M
11a0: 69 6e 69 6d 75 6d 20 76 61 6c 75 65 20 66 6f 72  inimum value for
11b0: 20 73 68 69 66 74 2d 72 65 64 75 63 65 20 61 63   shift-reduce ac
11c0: 74 69 6f 6e 73 0a 2a 2a 20 20 20 20 59 59 5f 4d  tions.**    YY_M
11d0: 41 58 5f 53 48 49 46 54 52 45 44 55 43 45 20 4d  AX_SHIFTREDUCE M
11e0: 61 78 69 6d 75 6d 20 76 61 6c 75 65 20 66 6f 72  aximum value for
11f0: 20 73 68 69 66 74 2d 72 65 64 75 63 65 20 61 63   shift-reduce ac
1200: 74 69 6f 6e 73 0a 2a 2a 20 20 20 20 59 59 5f 45  tions.**    YY_E
1210: 52 52 4f 52 5f 41 43 54 49 4f 4e 20 20 20 20 54  RROR_ACTION    T
1220: 68 65 20 79 79 5f 61 63 74 69 6f 6e 5b 5d 20 63  he yy_action[] c
1230: 6f 64 65 20 66 6f 72 20 73 79 6e 74 61 78 20 65  ode for syntax e
1240: 72 72 6f 72 0a 2a 2a 20 20 20 20 59 59 5f 41 43  rror.**    YY_AC
1250: 43 45 50 54 5f 41 43 54 49 4f 4e 20 20 20 54 68  CEPT_ACTION   Th
1260: 65 20 79 79 5f 61 63 74 69 6f 6e 5b 5d 20 63 6f  e yy_action[] co
1270: 64 65 20 66 6f 72 20 61 63 63 65 70 74 0a 2a 2a  de for accept.**
1280: 20 20 20 20 59 59 5f 4e 4f 5f 41 43 54 49 4f 4e      YY_NO_ACTION
1290: 20 20 20 20 20 20 20 54 68 65 20 79 79 5f 61 63         The yy_ac
12a0: 74 69 6f 6e 5b 5d 20 63 6f 64 65 20 66 6f 72 20  tion[] code for 
12b0: 6e 6f 2d 6f 70 0a 2a 2a 20 20 20 20 59 59 5f 4d  no-op.**    YY_M
12c0: 49 4e 5f 52 45 44 55 43 45 20 20 20 20 20 20 4d  IN_REDUCE      M
12d0: 69 6e 69 6d 75 6d 20 76 61 6c 75 65 20 66 6f 72  inimum value for
12e0: 20 72 65 64 75 63 65 20 61 63 74 69 6f 6e 73 0a   reduce actions.
12f0: 2a 2a 20 20 20 20 59 59 5f 4d 41 58 5f 52 45 44  **    YY_MAX_RED
1300: 55 43 45 20 20 20 20 20 20 4d 61 78 69 6d 75 6d  UCE      Maximum
1310: 20 76 61 6c 75 65 20 66 6f 72 20 72 65 64 75 63   value for reduc
1320: 65 20 61 63 74 69 6f 6e 73 0a 2a 2f 0a 23 69 66  e actions.*/.#if
1330: 6e 64 65 66 20 49 4e 54 45 52 46 41 43 45 0a 23  ndef INTERFACE.#
1340: 20 64 65 66 69 6e 65 20 49 4e 54 45 52 46 41 43   define INTERFAC
1350: 45 20 31 0a 23 65 6e 64 69 66 0a 2f 2a 2a 2a 2a  E 1.#endif./****
1360: 2a 2a 2a 2a 2a 2a 2a 2a 2a 20 42 65 67 69 6e 20  ********* Begin 
1370: 63 6f 6e 74 72 6f 6c 20 23 64 65 66 69 6e 65 73  control #defines
1380: 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a   ***************
1390: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
13a0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a 25 25 0a 2f  **********/.%%./
13b0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 20 45 6e  ************* En
13c0: 64 20 63 6f 6e 74 72 6f 6c 20 23 64 65 66 69 6e  d control #defin
13d0: 65 73 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  es *************
13e0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
13f0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a  **************/.
1400: 23 64 65 66 69 6e 65 20 59 59 5f 4e 4c 4f 4f 4b  #define YY_NLOOK
1410: 41 48 45 41 44 20 28 28 69 6e 74 29 28 73 69 7a  AHEAD ((int)(siz
1420: 65 6f 66 28 79 79 5f 6c 6f 6f 6b 61 68 65 61 64  eof(yy_lookahead
1430: 29 2f 73 69 7a 65 6f 66 28 79 79 5f 6c 6f 6f 6b  )/sizeof(yy_look
1440: 61 68 65 61 64 5b 30 5d 29 29 29 0a 0a 2f 2a 20  ahead[0])))../* 
1450: 44 65 66 69 6e 65 20 74 68 65 20 79 79 74 65 73  Define the yytes
1460: 74 63 61 73 65 28 29 20 6d 61 63 72 6f 20 74 6f  tcase() macro to
1470: 20 62 65 20 61 20 6e 6f 2d 6f 70 20 69 66 20 69   be a no-op if i
1480: 73 20 6e 6f 74 20 61 6c 72 65 61 64 79 20 64 65  s not already de
1490: 66 69 6e 65 64 0a 2a 2a 20 6f 74 68 65 72 77 69  fined.** otherwi
14a0: 73 65 2e 0a 2a 2a 0a 2a 2a 20 41 70 70 6c 69 63  se..**.** Applic
14b0: 61 74 69 6f 6e 73 20 63 61 6e 20 63 68 6f 6f 73  ations can choos
14c0: 65 20 74 6f 20 64 65 66 69 6e 65 20 79 79 74 65  e to define yyte
14d0: 73 74 63 61 73 65 28 29 20 69 6e 20 74 68 65 20  stcase() in the 
14e0: 25 69 6e 63 6c 75 64 65 20 73 65 63 74 69 6f 6e  %include section
14f0: 0a 2a 2a 20 74 6f 20 61 20 6d 61 63 72 6f 20 74  .** to a macro t
1500: 68 61 74 20 63 61 6e 20 61 73 73 69 73 74 20 69  hat can assist i
1510: 6e 20 76 65 72 69 66 79 69 6e 67 20 63 6f 64 65  n verifying code
1520: 20 63 6f 76 65 72 61 67 65 2e 20 20 46 6f 72 20   coverage.  For 
1530: 70 72 6f 64 75 63 74 69 6f 6e 0a 2a 2a 20 63 6f  production.** co
1540: 64 65 20 74 68 65 20 79 79 74 65 73 74 63 61 73  de the yytestcas
1550: 65 28 29 20 6d 61 63 72 6f 20 73 68 6f 75 6c 64  e() macro should
1560: 20 62 65 20 74 75 72 6e 65 64 20 6f 66 66 2e 20   be turned off. 
1570: 20 42 75 74 20 69 74 20 69 73 20 75 73 65 66 75   But it is usefu
1580: 6c 0a 2a 2a 20 66 6f 72 20 74 65 73 74 69 6e 67  l.** for testing
1590: 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 79 79 74  ..*/.#ifndef yyt
15a0: 65 73 74 63 61 73 65 0a 23 20 64 65 66 69 6e 65  estcase.# define
15b0: 20 79 79 74 65 73 74 63 61 73 65 28 58 29 0a 23   yytestcase(X).#
15c0: 65 6e 64 69 66 0a 0a 0a 2f 2a 20 4e 65 78 74 20  endif.../* Next 
15d0: 61 72 65 20 74 68 65 20 74 61 62 6c 65 73 20 75  are the tables u
15e0: 73 65 64 20 74 6f 20 64 65 74 65 72 6d 69 6e 65  sed to determine
15f0: 20 77 68 61 74 20 61 63 74 69 6f 6e 20 74 6f 20   what action to 
1600: 74 61 6b 65 20 62 61 73 65 64 20 6f 6e 20 74 68  take based on th
1610: 65 0a 2a 2a 20 63 75 72 72 65 6e 74 20 73 74 61  e.** current sta
1620: 74 65 20 61 6e 64 20 6c 6f 6f 6b 61 68 65 61 64  te and lookahead
1630: 20 74 6f 6b 65 6e 2e 20 20 54 68 65 73 65 20 74   token.  These t
1640: 61 62 6c 65 73 20 61 72 65 20 75 73 65 64 20 74  ables are used t
1650: 6f 20 69 6d 70 6c 65 6d 65 6e 74 0a 2a 2a 20 66  o implement.** f
1660: 75 6e 63 74 69 6f 6e 73 20 74 68 61 74 20 74 61  unctions that ta
1670: 6b 65 20 61 20 73 74 61 74 65 20 6e 75 6d 62 65  ke a state numbe
1680: 72 20 61 6e 64 20 6c 6f 6f 6b 61 68 65 61 64 20  r and lookahead 
1690: 76 61 6c 75 65 20 61 6e 64 20 72 65 74 75 72 6e  value and return
16a0: 20 61 6e 0a 2a 2a 20 61 63 74 69 6f 6e 20 69 6e   an.** action in
16b0: 74 65 67 65 72 2e 20 20 0a 2a 2a 0a 2a 2a 20 53  teger.  .**.** S
16c0: 75 70 70 6f 73 65 20 74 68 65 20 61 63 74 69 6f  uppose the actio
16d0: 6e 20 69 6e 74 65 67 65 72 20 69 73 20 4e 2e 20  n integer is N. 
16e0: 20 54 68 65 6e 20 74 68 65 20 61 63 74 69 6f 6e   Then the action
16f0: 20 69 73 20 64 65 74 65 72 6d 69 6e 65 64 20 61   is determined a
1700: 73 0a 2a 2a 20 66 6f 6c 6c 6f 77 73 0a 2a 2a 0a  s.** follows.**.
1710: 2a 2a 20 20 20 30 20 3c 3d 20 4e 20 3c 3d 20 59  **   0 <= N <= Y
1720: 59 5f 4d 41 58 5f 53 48 49 46 54 20 20 20 20 20  Y_MAX_SHIFT     
1730: 20 20 20 20 20 20 20 20 53 68 69 66 74 20 4e 2e          Shift N.
1740: 20 20 54 68 61 74 20 69 73 2c 20 70 75 73 68 20    That is, push 
1750: 74 68 65 20 6c 6f 6f 6b 61 68 65 61 64 0a 2a 2a  the lookahead.**
1760: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1770: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1780: 20 20 20 20 20 20 74 6f 6b 65 6e 20 6f 6e 74 6f        token onto
1790: 20 74 68 65 20 73 74 61 63 6b 20 61 6e 64 20 67   the stack and g
17a0: 6f 74 6f 20 73 74 61 74 65 20 4e 2e 0a 2a 2a 0a  oto state N..**.
17b0: 2a 2a 20 20 20 4e 20 62 65 74 77 65 65 6e 20 59  **   N between Y
17c0: 59 5f 4d 49 4e 5f 53 48 49 46 54 52 45 44 55 43  Y_MIN_SHIFTREDUC
17d0: 45 20 20 20 20 20 20 20 53 68 69 66 74 20 74 6f  E       Shift to
17e0: 20 61 6e 20 61 72 62 69 74 72 61 72 79 20 73 74   an arbitrary st
17f0: 61 74 65 20 74 68 65 6e 0a 2a 2a 20 20 20 20 20  ate then.**     
1800: 61 6e 64 20 59 59 5f 4d 41 58 5f 53 48 49 46 54  and YY_MAX_SHIFT
1810: 52 45 44 55 43 45 20 20 20 20 20 20 20 20 20 20  REDUCE          
1820: 20 72 65 64 75 63 65 20 62 79 20 72 75 6c 65 20   reduce by rule 
1830: 4e 2d 59 59 5f 4d 49 4e 5f 53 48 49 46 54 52 45  N-YY_MIN_SHIFTRE
1840: 44 55 43 45 2e 0a 2a 2a 0a 2a 2a 20 20 20 4e 20  DUCE..**.**   N 
1850: 3d 3d 20 59 59 5f 45 52 52 4f 52 5f 41 43 54 49  == YY_ERROR_ACTI
1860: 4f 4e 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ON              
1870: 20 41 20 73 79 6e 74 61 78 20 65 72 72 6f 72 20   A syntax error 
1880: 68 61 73 20 6f 63 63 75 72 72 65 64 2e 0a 2a 2a  has occurred..**
1890: 0a 2a 2a 20 20 20 4e 20 3d 3d 20 59 59 5f 41 43  .**   N == YY_AC
18a0: 43 45 50 54 5f 41 43 54 49 4f 4e 20 20 20 20 20  CEPT_ACTION     
18b0: 20 20 20 20 20 20 20 20 20 54 68 65 20 70 61 72           The par
18c0: 73 65 72 20 61 63 63 65 70 74 73 20 69 74 73 20  ser accepts its 
18d0: 69 6e 70 75 74 2e 0a 2a 2a 0a 2a 2a 20 20 20 4e  input..**.**   N
18e0: 20 3d 3d 20 59 59 5f 4e 4f 5f 41 43 54 49 4f 4e   == YY_NO_ACTION
18f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1900: 20 20 4e 6f 20 73 75 63 68 20 61 63 74 69 6f 6e    No such action
1910: 2e 20 20 44 65 6e 6f 74 65 73 20 75 6e 75 73 65  .  Denotes unuse
1920: 64 0a 2a 2a 20 20 20 20 20 20 20 20 20 20 20 20  d.**            
1930: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1940: 20 20 20 20 20 20 20 20 20 20 73 6c 6f 74 73 20            slots 
1950: 69 6e 20 74 68 65 20 79 79 5f 61 63 74 69 6f 6e  in the yy_action
1960: 5b 5d 20 74 61 62 6c 65 2e 0a 2a 2a 0a 2a 2a 20  [] table..**.** 
1970: 20 20 4e 20 62 65 74 77 65 65 6e 20 59 59 5f 4d    N between YY_M
1980: 49 4e 5f 52 45 44 55 43 45 20 20 20 20 20 20 20  IN_REDUCE       
1990: 20 20 20 20 20 52 65 64 75 63 65 20 62 79 20 72       Reduce by r
19a0: 75 6c 65 20 4e 2d 59 59 5f 4d 49 4e 5f 52 45 44  ule N-YY_MIN_RED
19b0: 55 43 45 0a 2a 2a 20 20 20 20 20 61 6e 64 20 59  UCE.**     and Y
19c0: 59 5f 4d 41 58 5f 52 45 44 55 43 45 0a 2a 2a 0a  Y_MAX_REDUCE.**.
19d0: 2a 2a 20 54 68 65 20 61 63 74 69 6f 6e 20 74 61  ** The action ta
19e0: 62 6c 65 20 69 73 20 63 6f 6e 73 74 72 75 63 74  ble is construct
19f0: 65 64 20 61 73 20 61 20 73 69 6e 67 6c 65 20 6c  ed as a single l
1a00: 61 72 67 65 20 74 61 62 6c 65 20 6e 61 6d 65 64  arge table named
1a10: 20 79 79 5f 61 63 74 69 6f 6e 5b 5d 2e 0a 2a 2a   yy_action[]..**
1a20: 20 47 69 76 65 6e 20 73 74 61 74 65 20 53 20 61   Given state S a
1a30: 6e 64 20 6c 6f 6f 6b 61 68 65 61 64 20 58 2c 20  nd lookahead X, 
1a40: 74 68 65 20 61 63 74 69 6f 6e 20 69 73 20 63 6f  the action is co
1a50: 6d 70 75 74 65 64 20 61 73 20 65 69 74 68 65 72  mputed as either
1a60: 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 28 41 29 20 20  :.**.**    (A)  
1a70: 20 4e 20 3d 20 79 79 5f 61 63 74 69 6f 6e 5b 20   N = yy_action[ 
1a80: 79 79 5f 73 68 69 66 74 5f 6f 66 73 74 5b 53 5d  yy_shift_ofst[S]
1a90: 20 2b 20 58 20 5d 0a 2a 2a 20 20 20 20 28 42 29   + X ].**    (B)
1aa0: 20 20 20 4e 20 3d 20 79 79 5f 64 65 66 61 75 6c     N = yy_defaul
1ab0: 74 5b 53 5d 0a 2a 2a 0a 2a 2a 20 54 68 65 20 28  t[S].**.** The (
1ac0: 41 29 20 66 6f 72 6d 75 6c 61 20 69 73 20 70 72  A) formula is pr
1ad0: 65 66 65 72 72 65 64 2e 20 20 54 68 65 20 42 20  eferred.  The B 
1ae0: 66 6f 72 6d 75 6c 61 20 69 73 20 75 73 65 64 20  formula is used 
1af0: 69 6e 73 74 65 61 64 20 69 66 0a 2a 2a 20 79 79  instead if.** yy
1b00: 5f 6c 6f 6f 6b 61 68 65 61 64 5b 79 79 5f 73 68  _lookahead[yy_sh
1b10: 69 66 74 5f 6f 66 73 74 5b 53 5d 2b 58 5d 20 69  ift_ofst[S]+X] i
1b20: 73 20 6e 6f 74 20 65 71 75 61 6c 20 74 6f 20 58  s not equal to X
1b30: 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20 66 6f 72 6d  ..**.** The form
1b40: 75 6c 61 73 20 61 62 6f 76 65 20 61 72 65 20 66  ulas above are f
1b50: 6f 72 20 63 6f 6d 70 75 74 69 6e 67 20 74 68 65  or computing the
1b60: 20 61 63 74 69 6f 6e 20 77 68 65 6e 20 74 68 65   action when the
1b70: 20 6c 6f 6f 6b 61 68 65 61 64 20 69 73 0a 2a 2a   lookahead is.**
1b80: 20 61 20 74 65 72 6d 69 6e 61 6c 20 73 79 6d 62   a terminal symb
1b90: 6f 6c 2e 20 20 49 66 20 74 68 65 20 6c 6f 6f 6b  ol.  If the look
1ba0: 61 68 65 61 64 20 69 73 20 61 20 6e 6f 6e 2d 74  ahead is a non-t
1bb0: 65 72 6d 69 6e 61 6c 20 28 61 73 20 6f 63 63 75  erminal (as occu
1bc0: 72 73 20 61 66 74 65 72 0a 2a 2a 20 61 20 72 65  rs after.** a re
1bd0: 64 75 63 65 20 61 63 74 69 6f 6e 29 20 74 68 65  duce action) the
1be0: 6e 20 74 68 65 20 79 79 5f 72 65 64 75 63 65 5f  n the yy_reduce_
1bf0: 6f 66 73 74 5b 5d 20 61 72 72 61 79 20 69 73 20  ofst[] array is 
1c00: 75 73 65 64 20 69 6e 20 70 6c 61 63 65 20 6f 66  used in place of
1c10: 0a 2a 2a 20 74 68 65 20 79 79 5f 73 68 69 66 74  .** the yy_shift
1c20: 5f 6f 66 73 74 5b 5d 20 61 72 72 61 79 2e 0a 2a  _ofst[] array..*
1c30: 2a 0a 2a 2a 20 54 68 65 20 66 6f 6c 6c 6f 77 69  *.** The followi
1c40: 6e 67 20 61 72 65 20 74 68 65 20 74 61 62 6c 65  ng are the table
1c50: 73 20 67 65 6e 65 72 61 74 65 64 20 69 6e 20 74  s generated in t
1c60: 68 69 73 20 73 65 63 74 69 6f 6e 3a 0a 2a 2a 0a  his section:.**.
1c70: 2a 2a 20 20 79 79 5f 61 63 74 69 6f 6e 5b 5d 20  **  yy_action[] 
1c80: 20 20 20 20 20 20 20 41 20 73 69 6e 67 6c 65 20         A single 
1c90: 74 61 62 6c 65 20 63 6f 6e 74 61 69 6e 69 6e 67  table containing
1ca0: 20 61 6c 6c 20 61 63 74 69 6f 6e 73 2e 0a 2a 2a   all actions..**
1cb0: 20 20 79 79 5f 6c 6f 6f 6b 61 68 65 61 64 5b 5d    yy_lookahead[]
1cc0: 20 20 20 20 20 41 20 74 61 62 6c 65 20 63 6f 6e       A table con
1cd0: 74 61 69 6e 69 6e 67 20 74 68 65 20 6c 6f 6f 6b  taining the look
1ce0: 61 68 65 61 64 20 66 6f 72 20 65 61 63 68 20 65  ahead for each e
1cf0: 6e 74 72 79 20 69 6e 0a 2a 2a 20 20 20 20 20 20  ntry in.**      
1d00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 79                 y
1d10: 79 5f 61 63 74 69 6f 6e 2e 20 20 55 73 65 64 20  y_action.  Used 
1d20: 74 6f 20 64 65 74 65 63 74 20 68 61 73 68 20 63  to detect hash c
1d30: 6f 6c 6c 69 73 69 6f 6e 73 2e 0a 2a 2a 20 20 79  ollisions..**  y
1d40: 79 5f 73 68 69 66 74 5f 6f 66 73 74 5b 5d 20 20  y_shift_ofst[]  
1d50: 20 20 46 6f 72 20 65 61 63 68 20 73 74 61 74 65    For each state
1d60: 2c 20 74 68 65 20 6f 66 66 73 65 74 20 69 6e 74  , the offset int
1d70: 6f 20 79 79 5f 61 63 74 69 6f 6e 20 66 6f 72 0a  o yy_action for.
1d80: 2a 2a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  **              
1d90: 20 20 20 20 20 20 20 73 68 69 66 74 69 6e 67 20         shifting 
1da0: 74 65 72 6d 69 6e 61 6c 73 2e 0a 2a 2a 20 20 79  terminals..**  y
1db0: 79 5f 72 65 64 75 63 65 5f 6f 66 73 74 5b 5d 20  y_reduce_ofst[] 
1dc0: 20 20 46 6f 72 20 65 61 63 68 20 73 74 61 74 65    For each state
1dd0: 2c 20 74 68 65 20 6f 66 66 73 65 74 20 69 6e 74  , the offset int
1de0: 6f 20 79 79 5f 61 63 74 69 6f 6e 20 66 6f 72 0a  o yy_action for.
1df0: 2a 2a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  **              
1e00: 20 20 20 20 20 20 20 73 68 69 66 74 69 6e 67 20         shifting 
1e10: 6e 6f 6e 2d 74 65 72 6d 69 6e 61 6c 73 20 61 66  non-terminals af
1e20: 74 65 72 20 61 20 72 65 64 75 63 65 2e 0a 2a 2a  ter a reduce..**
1e30: 20 20 79 79 5f 64 65 66 61 75 6c 74 5b 5d 20 20    yy_default[]  
1e40: 20 20 20 20 20 44 65 66 61 75 6c 74 20 61 63 74       Default act
1e50: 69 6f 6e 20 66 6f 72 20 65 61 63 68 20 73 74 61  ion for each sta
1e60: 74 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a  te..**.*********
1e70: 2a 2a 20 42 65 67 69 6e 20 70 61 72 73 69 6e 67  ** Begin parsing
1e80: 20 74 61 62 6c 65 73 20 2a 2a 2a 2a 2a 2a 2a 2a   tables ********
1e90: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
1ea0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
1eb0: 2a 2a 2a 2a 2a 2a 2f 0a 25 25 0a 2f 2a 2a 2a 2a  ******/.%%./****
1ec0: 2a 2a 2a 2a 2a 2a 20 45 6e 64 20 6f 66 20 6c 65  ****** End of le
1ed0: 6d 6f 6e 2d 67 65 6e 65 72 61 74 65 64 20 70 61  mon-generated pa
1ee0: 72 73 69 6e 67 20 74 61 62 6c 65 73 20 2a 2a 2a  rsing tables ***
1ef0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
1f00: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a 0a 2f 2a 20  **********/../* 
1f10: 54 68 65 20 6e 65 78 74 20 74 61 62 6c 65 20 6d  The next table m
1f20: 61 70 73 20 74 6f 6b 65 6e 73 20 28 74 65 72 6d  aps tokens (term
1f30: 69 6e 61 6c 20 73 79 6d 62 6f 6c 73 29 20 69 6e  inal symbols) in
1f40: 74 6f 20 66 61 6c 6c 62 61 63 6b 20 74 6f 6b 65  to fallback toke
1f50: 6e 73 2e 20 20 0a 2a 2a 20 49 66 20 61 20 63 6f  ns.  .** If a co
1f60: 6e 73 74 72 75 63 74 20 6c 69 6b 65 20 74 68 65  nstruct like the
1f70: 20 66 6f 6c 6c 6f 77 69 6e 67 3a 0a 2a 2a 20 0a   following:.** .
1f80: 2a 2a 20 20 20 20 20 20 25 66 61 6c 6c 62 61 63  **      %fallbac
1f90: 6b 20 49 44 20 58 20 59 20 5a 2e 0a 2a 2a 0a 2a  k ID X Y Z..**.*
1fa0: 2a 20 61 70 70 65 61 72 73 20 69 6e 20 74 68 65  * appears in the
1fb0: 20 67 72 61 6d 6d 61 72 2c 20 74 68 65 6e 20 49   grammar, then I
1fc0: 44 20 62 65 63 6f 6d 65 73 20 61 20 66 61 6c 6c  D becomes a fall
1fd0: 62 61 63 6b 20 74 6f 6b 65 6e 20 66 6f 72 20 58  back token for X
1fe0: 2c 20 59 2c 0a 2a 2a 20 61 6e 64 20 5a 2e 20 20  , Y,.** and Z.  
1ff0: 57 68 65 6e 65 76 65 72 20 6f 6e 65 20 6f 66 20  Whenever one of 
2000: 74 68 65 20 74 6f 6b 65 6e 73 20 58 2c 20 59 2c  the tokens X, Y,
2010: 20 6f 72 20 5a 20 69 73 20 69 6e 70 75 74 20 74   or Z is input t
2020: 6f 20 74 68 65 20 70 61 72 73 65 72 0a 2a 2a 20  o the parser.** 
2030: 62 75 74 20 69 74 20 64 6f 65 73 20 6e 6f 74 20  but it does not 
2040: 70 61 72 73 65 2c 20 74 68 65 20 74 79 70 65 20  parse, the type 
2050: 6f 66 20 74 68 65 20 74 6f 6b 65 6e 20 69 73 20  of the token is 
2060: 63 68 61 6e 67 65 64 20 74 6f 20 49 44 20 61 6e  changed to ID an
2070: 64 0a 2a 2a 20 74 68 65 20 70 61 72 73 65 20 69  d.** the parse i
2080: 73 20 72 65 74 72 69 65 64 20 62 65 66 6f 72 65  s retried before
2090: 20 61 6e 20 65 72 72 6f 72 20 69 73 20 74 68 72   an error is thr
20a0: 6f 77 6e 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20  own..**.** This 
20b0: 66 65 61 74 75 72 65 20 63 61 6e 20 62 65 20 75  feature can be u
20c0: 73 65 64 2c 20 66 6f 72 20 65 78 61 6d 70 6c 65  sed, for example
20d0: 2c 20 74 6f 20 63 61 75 73 65 20 73 6f 6d 65 20  , to cause some 
20e0: 6b 65 79 77 6f 72 64 73 20 69 6e 20 61 20 6c 61  keywords in a la
20f0: 6e 67 75 61 67 65 0a 2a 2a 20 74 6f 20 72 65 76  nguage.** to rev
2100: 65 72 74 20 74 6f 20 69 64 65 6e 74 69 66 69 65  ert to identifie
2110: 72 73 20 69 66 20 74 68 65 79 20 6b 65 79 77 6f  rs if they keywo
2120: 72 64 20 64 6f 65 73 20 6e 6f 74 20 61 70 70 6c  rd does not appl
2130: 79 20 69 6e 20 74 68 65 20 63 6f 6e 74 65 78 74  y in the context
2140: 20 77 68 65 72 65 0a 2a 2a 20 69 74 20 61 70 70   where.** it app
2150: 65 61 72 73 2e 0a 2a 2f 0a 23 69 66 64 65 66 20  ears..*/.#ifdef 
2160: 59 59 46 41 4c 4c 42 41 43 4b 0a 73 74 61 74 69  YYFALLBACK.stati
2170: 63 20 63 6f 6e 73 74 20 59 59 43 4f 44 45 54 59  c const YYCODETY
2180: 50 45 20 79 79 46 61 6c 6c 62 61 63 6b 5b 5d 20  PE yyFallback[] 
2190: 3d 20 7b 0a 25 25 0a 7d 3b 0a 23 65 6e 64 69 66  = {.%%.};.#endif
21a0: 20 2f 2a 20 59 59 46 41 4c 4c 42 41 43 4b 20 2a   /* YYFALLBACK *
21b0: 2f 0a 0a 2f 2a 20 54 68 65 20 66 6f 6c 6c 6f 77  /../* The follow
21c0: 69 6e 67 20 73 74 72 75 63 74 75 72 65 20 72 65  ing structure re
21d0: 70 72 65 73 65 6e 74 73 20 61 20 73 69 6e 67 6c  presents a singl
21e0: 65 20 65 6c 65 6d 65 6e 74 20 6f 66 20 74 68 65  e element of the
21f0: 0a 2a 2a 20 70 61 72 73 65 72 27 73 20 73 74 61  .** parser's sta
2200: 63 6b 2e 20 20 49 6e 66 6f 72 6d 61 74 69 6f 6e  ck.  Information
2210: 20 73 74 6f 72 65 64 20 69 6e 63 6c 75 64 65 73   stored includes
2220: 3a 0a 2a 2a 0a 2a 2a 20 20 20 2b 20 20 54 68 65  :.**.**   +  The
2230: 20 73 74 61 74 65 20 6e 75 6d 62 65 72 20 66 6f   state number fo
2240: 72 20 74 68 65 20 70 61 72 73 65 72 20 61 74 20  r the parser at 
2250: 74 68 69 73 20 6c 65 76 65 6c 20 6f 66 20 74 68  this level of th
2260: 65 20 73 74 61 63 6b 2e 0a 2a 2a 0a 2a 2a 20 20  e stack..**.**  
2270: 20 2b 20 20 54 68 65 20 76 61 6c 75 65 20 6f 66   +  The value of
2280: 20 74 68 65 20 74 6f 6b 65 6e 20 73 74 6f 72 65   the token store
2290: 64 20 61 74 20 74 68 69 73 20 6c 65 76 65 6c 20  d at this level 
22a0: 6f 66 20 74 68 65 20 73 74 61 63 6b 2e 0a 2a 2a  of the stack..**
22b0: 20 20 20 20 20 20 28 49 6e 20 6f 74 68 65 72 20        (In other 
22c0: 77 6f 72 64 73 2c 20 74 68 65 20 22 6d 61 6a 6f  words, the "majo
22d0: 72 22 20 74 6f 6b 65 6e 2e 29 0a 2a 2a 0a 2a 2a  r" token.).**.**
22e0: 20 20 20 2b 20 20 54 68 65 20 73 65 6d 61 6e 74     +  The semant
22f0: 69 63 20 76 61 6c 75 65 20 73 74 6f 72 65 64 20  ic value stored 
2300: 61 74 20 74 68 69 73 20 6c 65 76 65 6c 20 6f 66  at this level of
2310: 20 74 68 65 20 73 74 61 63 6b 2e 20 20 54 68 69   the stack.  Thi
2320: 73 20 69 73 0a 2a 2a 20 20 20 20 20 20 74 68 65  s is.**      the
2330: 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 20 75 73 65   information use
2340: 64 20 62 79 20 74 68 65 20 61 63 74 69 6f 6e 20  d by the action 
2350: 72 6f 75 74 69 6e 65 73 20 69 6e 20 74 68 65 20  routines in the 
2360: 67 72 61 6d 6d 61 72 2e 0a 2a 2a 20 20 20 20 20  grammar..**     
2370: 20 49 74 20 69 73 20 73 6f 6d 65 74 69 6d 65 73   It is sometimes
2380: 20 63 61 6c 6c 65 64 20 74 68 65 20 22 6d 69 6e   called the "min
2390: 6f 72 22 20 74 6f 6b 65 6e 2e 0a 2a 2a 0a 2a 2a  or" token..**.**
23a0: 20 41 66 74 65 72 20 74 68 65 20 22 73 68 69 66   After the "shif
23b0: 74 22 20 68 61 6c 66 20 6f 66 20 61 20 53 48 49  t" half of a SHI
23c0: 46 54 52 45 44 55 43 45 20 61 63 74 69 6f 6e 2c  FTREDUCE action,
23d0: 20 74 68 65 20 73 74 61 74 65 6e 6f 20 66 69 65   the stateno fie
23e0: 6c 64 0a 2a 2a 20 61 63 74 75 61 6c 6c 79 20 63  ld.** actually c
23f0: 6f 6e 74 61 69 6e 73 20 74 68 65 20 72 65 64 75  ontains the redu
2400: 63 65 20 61 63 74 69 6f 6e 20 66 6f 72 20 74 68  ce action for th
2410: 65 20 73 65 63 6f 6e 64 20 68 61 6c 66 20 6f 66  e second half of
2420: 20 74 68 65 0a 2a 2a 20 53 48 49 46 54 52 45 44   the.** SHIFTRED
2430: 55 43 45 2e 0a 2a 2f 0a 73 74 72 75 63 74 20 79  UCE..*/.struct y
2440: 79 53 74 61 63 6b 45 6e 74 72 79 20 7b 0a 20 20  yStackEntry {.  
2450: 59 59 41 43 54 49 4f 4e 54 59 50 45 20 73 74 61  YYACTIONTYPE sta
2460: 74 65 6e 6f 3b 20 20 2f 2a 20 54 68 65 20 73 74  teno;  /* The st
2470: 61 74 65 2d 6e 75 6d 62 65 72 2c 20 6f 72 20 72  ate-number, or r
2480: 65 64 75 63 65 20 61 63 74 69 6f 6e 20 69 6e 20  educe action in 
2490: 53 48 49 46 54 52 45 44 55 43 45 20 2a 2f 0a 20  SHIFTREDUCE */. 
24a0: 20 59 59 43 4f 44 45 54 59 50 45 20 6d 61 6a 6f   YYCODETYPE majo
24b0: 72 3b 20 20 20 20 20 20 2f 2a 20 54 68 65 20 6d  r;      /* The m
24c0: 61 6a 6f 72 20 74 6f 6b 65 6e 20 76 61 6c 75 65  ajor token value
24d0: 2e 20 20 54 68 69 73 20 69 73 20 74 68 65 20 63  .  This is the c
24e0: 6f 64 65 0a 20 20 20 20 20 20 20 20 20 20 20 20  ode.            
24f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 2a 2a 20               ** 
2500: 6e 75 6d 62 65 72 20 66 6f 72 20 74 68 65 20 74  number for the t
2510: 6f 6b 65 6e 20 61 74 20 74 68 69 73 20 73 74 61  oken at this sta
2520: 63 6b 20 6c 65 76 65 6c 20 2a 2f 0a 20 20 59 59  ck level */.  YY
2530: 4d 49 4e 4f 52 54 59 50 45 20 6d 69 6e 6f 72 3b  MINORTYPE minor;
2540: 20 20 20 20 20 2f 2a 20 54 68 65 20 75 73 65 72       /* The user
2550: 2d 73 75 70 70 6c 69 65 64 20 6d 69 6e 6f 72 20  -supplied minor 
2560: 74 6f 6b 65 6e 20 76 61 6c 75 65 2e 20 20 54 68  token value.  Th
2570: 69 73 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  is.             
2580: 20 20 20 20 20 20 20 20 20 20 20 20 2a 2a 20 69              ** i
2590: 73 20 74 68 65 20 76 61 6c 75 65 20 6f 66 20 74  s the value of t
25a0: 68 65 20 74 6f 6b 65 6e 20 20 2a 2f 0a 7d 3b 0a  he token  */.};.
25b0: 74 79 70 65 64 65 66 20 73 74 72 75 63 74 20 79  typedef struct y
25c0: 79 53 74 61 63 6b 45 6e 74 72 79 20 79 79 53 74  yStackEntry yySt
25d0: 61 63 6b 45 6e 74 72 79 3b 0a 0a 2f 2a 20 54 68  ackEntry;../* Th
25e0: 65 20 73 74 61 74 65 20 6f 66 20 74 68 65 20 70  e state of the p
25f0: 61 72 73 65 72 20 69 73 20 63 6f 6d 70 6c 65 74  arser is complet
2600: 65 6c 79 20 63 6f 6e 74 61 69 6e 65 64 20 69 6e  ely contained in
2610: 20 61 6e 20 69 6e 73 74 61 6e 63 65 20 6f 66 0a   an instance of.
2620: 2a 2a 20 74 68 65 20 66 6f 6c 6c 6f 77 69 6e 67  ** the following
2630: 20 73 74 72 75 63 74 75 72 65 20 2a 2f 0a 73 74   structure */.st
2640: 72 75 63 74 20 79 79 50 61 72 73 65 72 20 7b 0a  ruct yyParser {.
2650: 20 20 79 79 53 74 61 63 6b 45 6e 74 72 79 20 2a    yyStackEntry *
2660: 79 79 74 6f 73 3b 20 20 20 20 20 20 20 20 20 20  yytos;          
2670: 2f 2a 20 50 6f 69 6e 74 65 72 20 74 6f 20 74 6f  /* Pointer to to
2680: 70 20 65 6c 65 6d 65 6e 74 20 6f 66 20 74 68 65  p element of the
2690: 20 73 74 61 63 6b 20 2a 2f 0a 23 69 66 64 65 66   stack */.#ifdef
26a0: 20 59 59 54 52 41 43 4b 4d 41 58 53 54 41 43 4b   YYTRACKMAXSTACK
26b0: 44 45 50 54 48 0a 20 20 69 6e 74 20 79 79 68 77  DEPTH.  int yyhw
26c0: 6d 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  m;              
26d0: 20 20 20 20 20 20 2f 2a 20 48 69 67 68 2d 77 61        /* High-wa
26e0: 74 65 72 20 6d 61 72 6b 20 6f 66 20 74 68 65 20  ter mark of the 
26f0: 73 74 61 63 6b 20 2a 2f 0a 23 65 6e 64 69 66 0a  stack */.#endif.
2700: 23 69 66 6e 64 65 66 20 59 59 4e 4f 45 52 52 4f  #ifndef YYNOERRO
2710: 52 52 45 43 4f 56 45 52 59 0a 20 20 69 6e 74 20  RRECOVERY.  int 
2720: 79 79 65 72 72 63 6e 74 3b 20 20 20 20 20 20 20  yyerrcnt;       
2730: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 53 68 69            /* Shi
2740: 66 74 73 20 6c 65 66 74 20 62 65 66 6f 72 65 20  fts left before 
2750: 6f 75 74 20 6f 66 20 74 68 65 20 65 72 72 6f 72  out of the error
2760: 20 2a 2f 0a 23 65 6e 64 69 66 0a 20 20 50 61 72   */.#endif.  Par
2770: 73 65 41 52 47 5f 53 44 45 43 4c 20 20 20 20 20  seARG_SDECL     
2780: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 41 20             /* A 
2790: 70 6c 61 63 65 20 74 6f 20 68 6f 6c 64 20 25 65  place to hold %e
27a0: 78 74 72 61 5f 61 72 67 75 6d 65 6e 74 20 2a 2f  xtra_argument */
27b0: 0a 20 20 50 61 72 73 65 43 54 58 5f 53 44 45 43  .  ParseCTX_SDEC
27c0: 4c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  L               
27d0: 20 2f 2a 20 41 20 70 6c 61 63 65 20 74 6f 20 68   /* A place to h
27e0: 6f 6c 64 20 25 65 78 74 72 61 5f 63 6f 6e 74 65  old %extra_conte
27f0: 78 74 20 2a 2f 0a 23 69 66 20 59 59 53 54 41 43  xt */.#if YYSTAC
2800: 4b 44 45 50 54 48 3c 3d 30 0a 20 20 69 6e 74 20  KDEPTH<=0.  int 
2810: 79 79 73 74 6b 73 7a 3b 20 20 20 20 20 20 20 20  yystksz;        
2820: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 43 75 72            /* Cur
2830: 72 65 6e 74 20 73 69 64 65 20 6f 66 20 74 68 65  rent side of the
2840: 20 73 74 61 63 6b 20 2a 2f 0a 20 20 79 79 53 74   stack */.  yySt
2850: 61 63 6b 45 6e 74 72 79 20 2a 79 79 73 74 61 63  ackEntry *yystac
2860: 6b 3b 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65  k;        /* The
2870: 20 70 61 72 73 65 72 27 73 20 73 74 61 63 6b 20   parser's stack 
2880: 2a 2f 0a 20 20 79 79 53 74 61 63 6b 45 6e 74 72  */.  yyStackEntr
2890: 79 20 79 79 73 74 6b 30 3b 20 20 20 20 20 20 20  y yystk0;       
28a0: 20 20 20 2f 2a 20 46 69 72 73 74 20 73 74 61 63     /* First stac
28b0: 6b 20 65 6e 74 72 79 20 2a 2f 0a 23 65 6c 73 65  k entry */.#else
28c0: 0a 20 20 79 79 53 74 61 63 6b 45 6e 74 72 79 20  .  yyStackEntry 
28d0: 79 79 73 74 61 63 6b 5b 59 59 53 54 41 43 4b 44  yystack[YYSTACKD
28e0: 45 50 54 48 5d 3b 20 20 2f 2a 20 54 68 65 20 70  EPTH];  /* The p
28f0: 61 72 73 65 72 27 73 20 73 74 61 63 6b 20 2a 2f  arser's stack */
2900: 0a 20 20 79 79 53 74 61 63 6b 45 6e 74 72 79 20  .  yyStackEntry 
2910: 2a 79 79 73 74 61 63 6b 45 6e 64 3b 20 20 20 20  *yystackEnd;    
2920: 20 20 20 20 20 20 20 20 2f 2a 20 4c 61 73 74 20          /* Last 
2930: 65 6e 74 72 79 20 69 6e 20 74 68 65 20 73 74 61  entry in the sta
2940: 63 6b 20 2a 2f 0a 23 65 6e 64 69 66 0a 7d 3b 0a  ck */.#endif.};.
2950: 74 79 70 65 64 65 66 20 73 74 72 75 63 74 20 79  typedef struct y
2960: 79 50 61 72 73 65 72 20 79 79 50 61 72 73 65 72  yParser yyParser
2970: 3b 0a 0a 23 69 66 6e 64 65 66 20 4e 44 45 42 55  ;..#ifndef NDEBU
2980: 47 0a 23 69 6e 63 6c 75 64 65 20 3c 73 74 64 69  G.#include <stdi
2990: 6f 2e 68 3e 0a 73 74 61 74 69 63 20 46 49 4c 45  o.h>.static FILE
29a0: 20 2a 79 79 54 72 61 63 65 46 49 4c 45 20 3d 20   *yyTraceFILE = 
29b0: 30 3b 0a 73 74 61 74 69 63 20 63 68 61 72 20 2a  0;.static char *
29c0: 79 79 54 72 61 63 65 50 72 6f 6d 70 74 20 3d 20  yyTracePrompt = 
29d0: 30 3b 0a 23 65 6e 64 69 66 20 2f 2a 20 4e 44 45  0;.#endif /* NDE
29e0: 42 55 47 20 2a 2f 0a 0a 23 69 66 6e 64 65 66 20  BUG */..#ifndef 
29f0: 4e 44 45 42 55 47 0a 2f 2a 20 0a 2a 2a 20 54 75  NDEBUG./* .** Tu
2a00: 72 6e 20 70 61 72 73 65 72 20 74 72 61 63 69 6e  rn parser tracin
2a10: 67 20 6f 6e 20 62 79 20 67 69 76 69 6e 67 20 61  g on by giving a
2a20: 20 73 74 72 65 61 6d 20 74 6f 20 77 68 69 63 68   stream to which
2a30: 20 74 6f 20 77 72 69 74 65 20 74 68 65 20 74 72   to write the tr
2a40: 61 63 65 0a 2a 2a 20 61 6e 64 20 61 20 70 72 6f  ace.** and a pro
2a50: 6d 70 74 20 74 6f 20 70 72 65 66 61 63 65 20 65  mpt to preface e
2a60: 61 63 68 20 74 72 61 63 65 20 6d 65 73 73 61 67  ach trace messag
2a70: 65 2e 20 20 54 72 61 63 69 6e 67 20 69 73 20 74  e.  Tracing is t
2a80: 75 72 6e 65 64 20 6f 66 66 0a 2a 2a 20 62 79 20  urned off.** by 
2a90: 6d 61 6b 69 6e 67 20 65 69 74 68 65 72 20 61 72  making either ar
2aa0: 67 75 6d 65 6e 74 20 4e 55 4c 4c 20 0a 2a 2a 0a  gument NULL .**.
2ab0: 2a 2a 20 49 6e 70 75 74 73 3a 0a 2a 2a 20 3c 75  ** Inputs:.** <u
2ac0: 6c 3e 0a 2a 2a 20 3c 6c 69 3e 20 41 20 46 49 4c  l>.** <li> A FIL
2ad0: 45 2a 20 74 6f 20 77 68 69 63 68 20 74 72 61 63  E* to which trac
2ae0: 65 20 6f 75 74 70 75 74 20 73 68 6f 75 6c 64 20  e output should 
2af0: 62 65 20 77 72 69 74 74 65 6e 2e 0a 2a 2a 20 20  be written..**  
2b00: 20 20 20 20 49 66 20 4e 55 4c 4c 2c 20 74 68 65      If NULL, the
2b10: 6e 20 74 72 61 63 69 6e 67 20 69 73 20 74 75 72  n tracing is tur
2b20: 6e 65 64 20 6f 66 66 2e 0a 2a 2a 20 3c 6c 69 3e  ned off..** <li>
2b30: 20 41 20 70 72 65 66 69 78 20 73 74 72 69 6e 67   A prefix string
2b40: 20 77 72 69 74 74 65 6e 20 61 74 20 74 68 65 20   written at the 
2b50: 62 65 67 69 6e 6e 69 6e 67 20 6f 66 20 65 76 65  beginning of eve
2b60: 72 79 0a 2a 2a 20 20 20 20 20 20 6c 69 6e 65 20  ry.**      line 
2b70: 6f 66 20 74 72 61 63 65 20 6f 75 74 70 75 74 2e  of trace output.
2b80: 20 20 49 66 20 4e 55 4c 4c 2c 20 74 68 65 6e 20    If NULL, then 
2b90: 74 72 61 63 69 6e 67 20 69 73 0a 2a 2a 20 20 20  tracing is.**   
2ba0: 20 20 20 74 75 72 6e 65 64 20 6f 66 66 2e 0a 2a     turned off..*
2bb0: 2a 20 3c 2f 75 6c 3e 0a 2a 2a 0a 2a 2a 20 4f 75  * </ul>.**.** Ou
2bc0: 74 70 75 74 73 3a 0a 2a 2a 20 4e 6f 6e 65 2e 0a  tputs:.** None..
2bd0: 2a 2f 0a 76 6f 69 64 20 50 61 72 73 65 54 72 61  */.void ParseTra
2be0: 63 65 28 46 49 4c 45 20 2a 54 72 61 63 65 46 49  ce(FILE *TraceFI
2bf0: 4c 45 2c 20 63 68 61 72 20 2a 7a 54 72 61 63 65  LE, char *zTrace
2c00: 50 72 6f 6d 70 74 29 7b 0a 20 20 79 79 54 72 61  Prompt){.  yyTra
2c10: 63 65 46 49 4c 45 20 3d 20 54 72 61 63 65 46 49  ceFILE = TraceFI
2c20: 4c 45 3b 0a 20 20 79 79 54 72 61 63 65 50 72 6f  LE;.  yyTracePro
2c30: 6d 70 74 20 3d 20 7a 54 72 61 63 65 50 72 6f 6d  mpt = zTraceProm
2c40: 70 74 3b 0a 20 20 69 66 28 20 79 79 54 72 61 63  pt;.  if( yyTrac
2c50: 65 46 49 4c 45 3d 3d 30 20 29 20 79 79 54 72 61  eFILE==0 ) yyTra
2c60: 63 65 50 72 6f 6d 70 74 20 3d 20 30 3b 0a 20 20  cePrompt = 0;.  
2c70: 65 6c 73 65 20 69 66 28 20 79 79 54 72 61 63 65  else if( yyTrace
2c80: 50 72 6f 6d 70 74 3d 3d 30 20 29 20 79 79 54 72  Prompt==0 ) yyTr
2c90: 61 63 65 46 49 4c 45 20 3d 20 30 3b 0a 7d 0a 23  aceFILE = 0;.}.#
2ca0: 65 6e 64 69 66 20 2f 2a 20 4e 44 45 42 55 47 20  endif /* NDEBUG 
2cb0: 2a 2f 0a 0a 23 69 66 20 64 65 66 69 6e 65 64 28  */..#if defined(
2cc0: 59 59 43 4f 56 45 52 41 47 45 29 20 7c 7c 20 21  YYCOVERAGE) || !
2cd0: 64 65 66 69 6e 65 64 28 4e 44 45 42 55 47 29 0a  defined(NDEBUG).
2ce0: 2f 2a 20 46 6f 72 20 74 72 61 63 69 6e 67 20 73  /* For tracing s
2cf0: 68 69 66 74 73 2c 20 74 68 65 20 6e 61 6d 65 73  hifts, the names
2d00: 20 6f 66 20 61 6c 6c 20 74 65 72 6d 69 6e 61 6c   of all terminal
2d10: 73 20 61 6e 64 20 6e 6f 6e 74 65 72 6d 69 6e 61  s and nontermina
2d20: 6c 73 0a 2a 2a 20 61 72 65 20 72 65 71 75 69 72  ls.** are requir
2d30: 65 64 2e 20 20 54 68 65 20 66 6f 6c 6c 6f 77 69  ed.  The followi
2d40: 6e 67 20 74 61 62 6c 65 20 73 75 70 70 6c 69 65  ng table supplie
2d50: 73 20 74 68 65 73 65 20 6e 61 6d 65 73 20 2a 2f  s these names */
2d60: 0a 73 74 61 74 69 63 20 63 6f 6e 73 74 20 63 68  .static const ch
2d70: 61 72 20 2a 63 6f 6e 73 74 20 79 79 54 6f 6b 65  ar *const yyToke
2d80: 6e 4e 61 6d 65 5b 5d 20 3d 20 7b 20 0a 25 25 0a  nName[] = { .%%.
2d90: 7d 3b 0a 23 65 6e 64 69 66 20 2f 2a 20 64 65 66  };.#endif /* def
2da0: 69 6e 65 64 28 59 59 43 4f 56 45 52 41 47 45 29  ined(YYCOVERAGE)
2db0: 20 7c 7c 20 21 64 65 66 69 6e 65 64 28 4e 44 45   || !defined(NDE
2dc0: 42 55 47 29 20 2a 2f 0a 0a 23 69 66 6e 64 65 66  BUG) */..#ifndef
2dd0: 20 4e 44 45 42 55 47 0a 2f 2a 20 46 6f 72 20 74   NDEBUG./* For t
2de0: 72 61 63 69 6e 67 20 72 65 64 75 63 65 20 61 63  racing reduce ac
2df0: 74 69 6f 6e 73 2c 20 74 68 65 20 6e 61 6d 65 73  tions, the names
2e00: 20 6f 66 20 61 6c 6c 20 72 75 6c 65 73 20 61 72   of all rules ar
2e10: 65 20 72 65 71 75 69 72 65 64 2e 0a 2a 2f 0a 73  e required..*/.s
2e20: 74 61 74 69 63 20 63 6f 6e 73 74 20 63 68 61 72  tatic const char
2e30: 20 2a 63 6f 6e 73 74 20 79 79 52 75 6c 65 4e 61   *const yyRuleNa
2e40: 6d 65 5b 5d 20 3d 20 7b 0a 25 25 0a 7d 3b 0a 23  me[] = {.%%.};.#
2e50: 65 6e 64 69 66 20 2f 2a 20 4e 44 45 42 55 47 20  endif /* NDEBUG 
2e60: 2a 2f 0a 0a 0a 23 69 66 20 59 59 53 54 41 43 4b  */...#if YYSTACK
2e70: 44 45 50 54 48 3c 3d 30 0a 2f 2a 0a 2a 2a 20 54  DEPTH<=0./*.** T
2e80: 72 79 20 74 6f 20 69 6e 63 72 65 61 73 65 20 74  ry to increase t
2e90: 68 65 20 73 69 7a 65 20 6f 66 20 74 68 65 20 70  he size of the p
2ea0: 61 72 73 65 72 20 73 74 61 63 6b 2e 20 20 52 65  arser stack.  Re
2eb0: 74 75 72 6e 20 74 68 65 20 6e 75 6d 62 65 72 0a  turn the number.
2ec0: 2a 2a 20 6f 66 20 65 72 72 6f 72 73 2e 20 20 52  ** of errors.  R
2ed0: 65 74 75 72 6e 20 30 20 6f 6e 20 73 75 63 63 65  eturn 0 on succe
2ee0: 73 73 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e  ss..*/.static in
2ef0: 74 20 79 79 47 72 6f 77 53 74 61 63 6b 28 79 79  t yyGrowStack(yy
2f00: 50 61 72 73 65 72 20 2a 70 29 7b 0a 20 20 69 6e  Parser *p){.  in
2f10: 74 20 6e 65 77 53 69 7a 65 3b 0a 20 20 69 6e 74  t newSize;.  int
2f20: 20 69 64 78 3b 0a 20 20 79 79 53 74 61 63 6b 45   idx;.  yyStackE
2f30: 6e 74 72 79 20 2a 70 4e 65 77 3b 0a 0a 20 20 6e  ntry *pNew;..  n
2f40: 65 77 53 69 7a 65 20 3d 20 70 2d 3e 79 79 73 74  ewSize = p->yyst
2f50: 6b 73 7a 2a 32 20 2b 20 31 30 30 3b 0a 20 20 69  ksz*2 + 100;.  i
2f60: 64 78 20 3d 20 70 2d 3e 79 79 74 6f 73 20 3f 20  dx = p->yytos ? 
2f70: 28 69 6e 74 29 28 70 2d 3e 79 79 74 6f 73 20 2d  (int)(p->yytos -
2f80: 20 70 2d 3e 79 79 73 74 61 63 6b 29 20 3a 20 30   p->yystack) : 0
2f90: 3b 0a 20 20 69 66 28 20 70 2d 3e 79 79 73 74 61  ;.  if( p->yysta
2fa0: 63 6b 3d 3d 26 70 2d 3e 79 79 73 74 6b 30 20 29  ck==&p->yystk0 )
2fb0: 7b 0a 20 20 20 20 70 4e 65 77 20 3d 20 6d 61 6c  {.    pNew = mal
2fc0: 6c 6f 63 28 6e 65 77 53 69 7a 65 2a 73 69 7a 65  loc(newSize*size
2fd0: 6f 66 28 70 4e 65 77 5b 30 5d 29 29 3b 0a 20 20  of(pNew[0]));.  
2fe0: 20 20 69 66 28 20 70 4e 65 77 20 29 20 70 4e 65    if( pNew ) pNe
2ff0: 77 5b 30 5d 20 3d 20 70 2d 3e 79 79 73 74 6b 30  w[0] = p->yystk0
3000: 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 70  ;.  }else{.    p
3010: 4e 65 77 20 3d 20 72 65 61 6c 6c 6f 63 28 70 2d  New = realloc(p-
3020: 3e 79 79 73 74 61 63 6b 2c 20 6e 65 77 53 69 7a  >yystack, newSiz
3030: 65 2a 73 69 7a 65 6f 66 28 70 4e 65 77 5b 30 5d  e*sizeof(pNew[0]
3040: 29 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20 70 4e  ));.  }.  if( pN
3050: 65 77 20 29 7b 0a 20 20 20 20 70 2d 3e 79 79 73  ew ){.    p->yys
3060: 74 61 63 6b 20 3d 20 70 4e 65 77 3b 0a 20 20 20  tack = pNew;.   
3070: 20 70 2d 3e 79 79 74 6f 73 20 3d 20 26 70 2d 3e   p->yytos = &p->
3080: 79 79 73 74 61 63 6b 5b 69 64 78 5d 3b 0a 23 69  yystack[idx];.#i
3090: 66 6e 64 65 66 20 4e 44 45 42 55 47 0a 20 20 20  fndef NDEBUG.   
30a0: 20 69 66 28 20 79 79 54 72 61 63 65 46 49 4c 45   if( yyTraceFILE
30b0: 20 29 7b 0a 20 20 20 20 20 20 66 70 72 69 6e 74   ){.      fprint
30c0: 66 28 79 79 54 72 61 63 65 46 49 4c 45 2c 22 25  f(yyTraceFILE,"%
30d0: 73 53 74 61 63 6b 20 67 72 6f 77 73 20 66 72 6f  sStack grows fro
30e0: 6d 20 25 64 20 74 6f 20 25 64 20 65 6e 74 72 69  m %d to %d entri
30f0: 65 73 2e 5c 6e 22 2c 0a 20 20 20 20 20 20 20 20  es.\n",.        
3100: 20 20 20 20 20 20 79 79 54 72 61 63 65 50 72 6f        yyTracePro
3110: 6d 70 74 2c 20 70 2d 3e 79 79 73 74 6b 73 7a 2c  mpt, p->yystksz,
3120: 20 6e 65 77 53 69 7a 65 29 3b 0a 20 20 20 20 7d   newSize);.    }
3130: 0a 23 65 6e 64 69 66 0a 20 20 20 20 70 2d 3e 79  .#endif.    p->y
3140: 79 73 74 6b 73 7a 20 3d 20 6e 65 77 53 69 7a 65  ystksz = newSize
3150: 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 70  ;.  }.  return p
3160: 4e 65 77 3d 3d 30 3b 20 0a 7d 0a 23 65 6e 64 69  New==0; .}.#endi
3170: 66 0a 0a 2f 2a 20 44 61 74 61 74 79 70 65 20 6f  f../* Datatype o
3180: 66 20 74 68 65 20 61 72 67 75 6d 65 6e 74 20 74  f the argument t
3190: 6f 20 74 68 65 20 6d 65 6d 6f 72 79 20 61 6c 6c  o the memory all
31a0: 6f 63 61 74 65 64 20 70 61 73 73 65 64 20 61 73  ocated passed as
31b0: 20 74 68 65 0a 2a 2a 20 73 65 63 6f 6e 64 20 61   the.** second a
31c0: 72 67 75 6d 65 6e 74 20 74 6f 20 50 61 72 73 65  rgument to Parse
31d0: 41 6c 6c 6f 63 28 29 20 62 65 6c 6f 77 2e 20 20  Alloc() below.  
31e0: 54 68 69 73 20 63 61 6e 20 62 65 20 63 68 61 6e  This can be chan
31f0: 67 65 64 20 62 79 0a 2a 2a 20 70 75 74 74 69 6e  ged by.** puttin
3200: 67 20 61 6e 20 61 70 70 72 6f 70 72 69 61 74 65  g an appropriate
3210: 20 23 64 65 66 69 6e 65 20 69 6e 20 74 68 65 20   #define in the 
3220: 25 69 6e 63 6c 75 64 65 20 73 65 63 74 69 6f 6e  %include section
3230: 20 6f 66 20 74 68 65 20 69 6e 70 75 74 0a 2a 2a   of the input.**
3240: 20 67 72 61 6d 6d 61 72 2e 0a 2a 2f 0a 23 69 66   grammar..*/.#if
3250: 6e 64 65 66 20 59 59 4d 41 4c 4c 4f 43 41 52 47  ndef YYMALLOCARG
3260: 54 59 50 45 0a 23 20 64 65 66 69 6e 65 20 59 59  TYPE.# define YY
3270: 4d 41 4c 4c 4f 43 41 52 47 54 59 50 45 20 73 69  MALLOCARGTYPE si
3280: 7a 65 5f 74 0a 23 65 6e 64 69 66 0a 0a 2f 2a 20  ze_t.#endif../* 
3290: 49 6e 69 74 69 61 6c 69 7a 65 20 61 20 6e 65 77  Initialize a new
32a0: 20 70 61 72 73 65 72 20 74 68 61 74 20 68 61 73   parser that has
32b0: 20 61 6c 72 65 61 64 79 20 62 65 65 6e 20 61 6c   already been al
32c0: 6c 6f 63 61 74 65 64 2e 0a 2a 2f 0a 76 6f 69 64  located..*/.void
32d0: 20 50 61 72 73 65 49 6e 69 74 28 76 6f 69 64 20   ParseInit(void 
32e0: 2a 79 79 70 52 61 77 50 61 72 73 65 72 20 50 61  *yypRawParser Pa
32f0: 72 73 65 43 54 58 5f 50 44 45 43 4c 29 7b 0a 20  rseCTX_PDECL){. 
3300: 20 79 79 50 61 72 73 65 72 20 2a 79 79 70 50 61   yyParser *yypPa
3310: 72 73 65 72 20 3d 20 28 79 79 50 61 72 73 65 72  rser = (yyParser
3320: 2a 29 79 79 70 52 61 77 50 61 72 73 65 72 3b 0a  *)yypRawParser;.
3330: 20 20 50 61 72 73 65 43 54 58 5f 53 54 4f 52 45    ParseCTX_STORE
3340: 0a 23 69 66 64 65 66 20 59 59 54 52 41 43 4b 4d  .#ifdef YYTRACKM
3350: 41 58 53 54 41 43 4b 44 45 50 54 48 0a 20 20 79  AXSTACKDEPTH.  y
3360: 79 70 50 61 72 73 65 72 2d 3e 79 79 68 77 6d 20  ypParser->yyhwm 
3370: 3d 20 30 3b 0a 23 65 6e 64 69 66 0a 23 69 66 20  = 0;.#endif.#if 
3380: 59 59 53 54 41 43 4b 44 45 50 54 48 3c 3d 30 0a  YYSTACKDEPTH<=0.
3390: 20 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74    yypParser->yyt
33a0: 6f 73 20 3d 20 4e 55 4c 4c 3b 0a 20 20 79 79 70  os = NULL;.  yyp
33b0: 50 61 72 73 65 72 2d 3e 79 79 73 74 61 63 6b 20  Parser->yystack 
33c0: 3d 20 4e 55 4c 4c 3b 0a 20 20 79 79 70 50 61 72  = NULL;.  yypPar
33d0: 73 65 72 2d 3e 79 79 73 74 6b 73 7a 20 3d 20 30  ser->yystksz = 0
33e0: 3b 0a 20 20 69 66 28 20 79 79 47 72 6f 77 53 74  ;.  if( yyGrowSt
33f0: 61 63 6b 28 79 79 70 50 61 72 73 65 72 29 20 29  ack(yypParser) )
3400: 7b 0a 20 20 20 20 79 79 70 50 61 72 73 65 72 2d  {.    yypParser-
3410: 3e 79 79 73 74 61 63 6b 20 3d 20 26 79 79 70 50  >yystack = &yypP
3420: 61 72 73 65 72 2d 3e 79 79 73 74 6b 30 3b 0a 20  arser->yystk0;. 
3430: 20 20 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79     yypParser->yy
3440: 73 74 6b 73 7a 20 3d 20 31 3b 0a 20 20 7d 0a 23  stksz = 1;.  }.#
3450: 65 6e 64 69 66 0a 23 69 66 6e 64 65 66 20 59 59  endif.#ifndef YY
3460: 4e 4f 45 52 52 4f 52 52 45 43 4f 56 45 52 59 0a  NOERRORRECOVERY.
3470: 20 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79 65    yypParser->yye
3480: 72 72 63 6e 74 20 3d 20 2d 31 3b 0a 23 65 6e 64  rrcnt = -1;.#end
3490: 69 66 0a 20 20 79 79 70 50 61 72 73 65 72 2d 3e  if.  yypParser->
34a0: 79 79 74 6f 73 20 3d 20 79 79 70 50 61 72 73 65  yytos = yypParse
34b0: 72 2d 3e 79 79 73 74 61 63 6b 3b 0a 20 20 79 79  r->yystack;.  yy
34c0: 70 50 61 72 73 65 72 2d 3e 79 79 73 74 61 63 6b  pParser->yystack
34d0: 5b 30 5d 2e 73 74 61 74 65 6e 6f 20 3d 20 30 3b  [0].stateno = 0;
34e0: 0a 20 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79  .  yypParser->yy
34f0: 73 74 61 63 6b 5b 30 5d 2e 6d 61 6a 6f 72 20 3d  stack[0].major =
3500: 20 30 3b 0a 23 69 66 20 59 59 53 54 41 43 4b 44   0;.#if YYSTACKD
3510: 45 50 54 48 3e 30 0a 20 20 79 79 70 50 61 72 73  EPTH>0.  yypPars
3520: 65 72 2d 3e 79 79 73 74 61 63 6b 45 6e 64 20 3d  er->yystackEnd =
3530: 20 26 79 79 70 50 61 72 73 65 72 2d 3e 79 79 73   &yypParser->yys
3540: 74 61 63 6b 5b 59 59 53 54 41 43 4b 44 45 50 54  tack[YYSTACKDEPT
3550: 48 2d 31 5d 3b 0a 23 65 6e 64 69 66 0a 7d 0a 0a  H-1];.#endif.}..
3560: 23 69 66 6e 64 65 66 20 50 61 72 73 65 5f 45 4e  #ifndef Parse_EN
3570: 47 49 4e 45 41 4c 57 41 59 53 4f 4e 53 54 41 43  GINEALWAYSONSTAC
3580: 4b 0a 2f 2a 20 0a 2a 2a 20 54 68 69 73 20 66 75  K./* .** This fu
3590: 6e 63 74 69 6f 6e 20 61 6c 6c 6f 63 61 74 65 73  nction allocates
35a0: 20 61 20 6e 65 77 20 70 61 72 73 65 72 2e 0a 2a   a new parser..*
35b0: 2a 20 54 68 65 20 6f 6e 6c 79 20 61 72 67 75 6d  * The only argum
35c0: 65 6e 74 20 69 73 20 61 20 70 6f 69 6e 74 65 72  ent is a pointer
35d0: 20 74 6f 20 61 20 66 75 6e 63 74 69 6f 6e 20 77   to a function w
35e0: 68 69 63 68 20 77 6f 72 6b 73 20 6c 69 6b 65 0a  hich works like.
35f0: 2a 2a 20 6d 61 6c 6c 6f 63 2e 0a 2a 2a 0a 2a 2a  ** malloc..**.**
3600: 20 49 6e 70 75 74 73 3a 0a 2a 2a 20 41 20 70 6f   Inputs:.** A po
3610: 69 6e 74 65 72 20 74 6f 20 74 68 65 20 66 75 6e  inter to the fun
3620: 63 74 69 6f 6e 20 75 73 65 64 20 74 6f 20 61 6c  ction used to al
3630: 6c 6f 63 61 74 65 20 6d 65 6d 6f 72 79 2e 0a 2a  locate memory..*
3640: 2a 0a 2a 2a 20 4f 75 74 70 75 74 73 3a 0a 2a 2a  *.** Outputs:.**
3650: 20 41 20 70 6f 69 6e 74 65 72 20 74 6f 20 61 20   A pointer to a 
3660: 70 61 72 73 65 72 2e 20 20 54 68 69 73 20 70 6f  parser.  This po
3670: 69 6e 74 65 72 20 69 73 20 75 73 65 64 20 69 6e  inter is used in
3680: 20 73 75 62 73 65 71 75 65 6e 74 20 63 61 6c 6c   subsequent call
3690: 73 0a 2a 2a 20 74 6f 20 50 61 72 73 65 20 61 6e  s.** to Parse an
36a0: 64 20 50 61 72 73 65 46 72 65 65 2e 0a 2a 2f 0a  d ParseFree..*/.
36b0: 76 6f 69 64 20 2a 50 61 72 73 65 41 6c 6c 6f 63  void *ParseAlloc
36c0: 28 76 6f 69 64 20 2a 28 2a 6d 61 6c 6c 6f 63 50  (void *(*mallocP
36d0: 72 6f 63 29 28 59 59 4d 41 4c 4c 4f 43 41 52 47  roc)(YYMALLOCARG
36e0: 54 59 50 45 29 20 50 61 72 73 65 43 54 58 5f 50  TYPE) ParseCTX_P
36f0: 44 45 43 4c 29 7b 0a 20 20 79 79 50 61 72 73 65  DECL){.  yyParse
3700: 72 20 2a 79 79 70 50 61 72 73 65 72 3b 0a 20 20  r *yypParser;.  
3710: 79 79 70 50 61 72 73 65 72 20 3d 20 28 79 79 50  yypParser = (yyP
3720: 61 72 73 65 72 2a 29 28 2a 6d 61 6c 6c 6f 63 50  arser*)(*mallocP
3730: 72 6f 63 29 28 20 28 59 59 4d 41 4c 4c 4f 43 41  roc)( (YYMALLOCA
3740: 52 47 54 59 50 45 29 73 69 7a 65 6f 66 28 79 79  RGTYPE)sizeof(yy
3750: 50 61 72 73 65 72 29 20 29 3b 0a 20 20 69 66 28  Parser) );.  if(
3760: 20 79 79 70 50 61 72 73 65 72 20 29 7b 0a 20 20   yypParser ){.  
3770: 20 20 50 61 72 73 65 43 54 58 5f 53 54 4f 52 45    ParseCTX_STORE
3780: 0a 20 20 20 20 50 61 72 73 65 49 6e 69 74 28 79  .    ParseInit(y
3790: 79 70 50 61 72 73 65 72 20 50 61 72 73 65 43 54  ypParser ParseCT
37a0: 58 5f 50 41 52 41 4d 29 3b 0a 20 20 7d 0a 20 20  X_PARAM);.  }.  
37b0: 72 65 74 75 72 6e 20 28 76 6f 69 64 2a 29 79 79  return (void*)yy
37c0: 70 50 61 72 73 65 72 3b 0a 7d 0a 23 65 6e 64 69  pParser;.}.#endi
37d0: 66 20 2f 2a 20 50 61 72 73 65 5f 45 4e 47 49 4e  f /* Parse_ENGIN
37e0: 45 41 4c 57 41 59 53 4f 4e 53 54 41 43 4b 20 2a  EALWAYSONSTACK *
37f0: 2f 0a 0a 0a 2f 2a 20 54 68 65 20 66 6f 6c 6c 6f  /.../* The follo
3800: 77 69 6e 67 20 66 75 6e 63 74 69 6f 6e 20 64 65  wing function de
3810: 6c 65 74 65 73 20 74 68 65 20 22 6d 69 6e 6f 72  letes the "minor
3820: 20 74 79 70 65 22 20 6f 72 20 73 65 6d 61 6e 74   type" or semant
3830: 69 63 20 76 61 6c 75 65 0a 2a 2a 20 61 73 73 6f  ic value.** asso
3840: 63 69 61 74 65 64 20 77 69 74 68 20 61 20 73 79  ciated with a sy
3850: 6d 62 6f 6c 2e 20 20 54 68 65 20 73 79 6d 62 6f  mbol.  The symbo
3860: 6c 20 63 61 6e 20 62 65 20 65 69 74 68 65 72 20  l can be either 
3870: 61 20 74 65 72 6d 69 6e 61 6c 0a 2a 2a 20 6f 72  a terminal.** or
3880: 20 6e 6f 6e 74 65 72 6d 69 6e 61 6c 2e 20 22 79   nonterminal. "y
3890: 79 6d 61 6a 6f 72 22 20 69 73 20 74 68 65 20 73  ymajor" is the s
38a0: 79 6d 62 6f 6c 20 63 6f 64 65 2c 20 61 6e 64 20  ymbol code, and 
38b0: 22 79 79 70 6d 69 6e 6f 72 22 20 69 73 0a 2a 2a  "yypminor" is.**
38c0: 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 74 68   a pointer to th
38d0: 65 20 76 61 6c 75 65 20 74 6f 20 62 65 20 64 65  e value to be de
38e0: 6c 65 74 65 64 2e 20 20 54 68 65 20 63 6f 64 65  leted.  The code
38f0: 20 75 73 65 64 20 74 6f 20 64 6f 20 74 68 65 20   used to do the 
3900: 0a 2a 2a 20 64 65 6c 65 74 69 6f 6e 73 20 69 73  .** deletions is
3910: 20 64 65 72 69 76 65 64 20 66 72 6f 6d 20 74 68   derived from th
3920: 65 20 25 64 65 73 74 72 75 63 74 6f 72 20 61 6e  e %destructor an
3930: 64 2f 6f 72 20 25 74 6f 6b 65 6e 5f 64 65 73 74  d/or %token_dest
3940: 72 75 63 74 6f 72 0a 2a 2a 20 64 69 72 65 63 74  ructor.** direct
3950: 69 76 65 73 20 6f 66 20 74 68 65 20 69 6e 70 75  ives of the inpu
3960: 74 20 67 72 61 6d 6d 61 72 2e 0a 2a 2f 0a 73 74  t grammar..*/.st
3970: 61 74 69 63 20 76 6f 69 64 20 79 79 5f 64 65 73  atic void yy_des
3980: 74 72 75 63 74 6f 72 28 0a 20 20 79 79 50 61 72  tructor(.  yyPar
3990: 73 65 72 20 2a 79 79 70 50 61 72 73 65 72 2c 20  ser *yypParser, 
39a0: 20 20 20 2f 2a 20 54 68 65 20 70 61 72 73 65 72     /* The parser
39b0: 20 2a 2f 0a 20 20 59 59 43 4f 44 45 54 59 50 45   */.  YYCODETYPE
39c0: 20 79 79 6d 61 6a 6f 72 2c 20 20 20 20 20 2f 2a   yymajor,     /*
39d0: 20 54 79 70 65 20 63 6f 64 65 20 66 6f 72 20 6f   Type code for o
39e0: 62 6a 65 63 74 20 74 6f 20 64 65 73 74 72 6f 79  bject to destroy
39f0: 20 2a 2f 0a 20 20 59 59 4d 49 4e 4f 52 54 59 50   */.  YYMINORTYP
3a00: 45 20 2a 79 79 70 6d 69 6e 6f 72 20 20 20 2f 2a  E *yypminor   /*
3a10: 20 54 68 65 20 6f 62 6a 65 63 74 20 74 6f 20 62   The object to b
3a20: 65 20 64 65 73 74 72 6f 79 65 64 20 2a 2f 0a 29  e destroyed */.)
3a30: 7b 0a 20 20 50 61 72 73 65 41 52 47 5f 46 45 54  {.  ParseARG_FET
3a40: 43 48 0a 20 20 50 61 72 73 65 43 54 58 5f 46 45  CH.  ParseCTX_FE
3a50: 54 43 48 0a 20 20 73 77 69 74 63 68 28 20 79 79  TCH.  switch( yy
3a60: 6d 61 6a 6f 72 20 29 7b 0a 20 20 20 20 2f 2a 20  major ){.    /* 
3a70: 48 65 72 65 20 69 73 20 69 6e 73 65 72 74 65 64  Here is inserted
3a80: 20 74 68 65 20 61 63 74 69 6f 6e 73 20 77 68 69   the actions whi
3a90: 63 68 20 74 61 6b 65 20 70 6c 61 63 65 20 77 68  ch take place wh
3aa0: 65 6e 20 61 0a 20 20 20 20 2a 2a 20 74 65 72 6d  en a.    ** term
3ab0: 69 6e 61 6c 20 6f 72 20 6e 6f 6e 2d 74 65 72 6d  inal or non-term
3ac0: 69 6e 61 6c 20 69 73 20 64 65 73 74 72 6f 79 65  inal is destroye
3ad0: 64 2e 20 20 54 68 69 73 20 63 61 6e 20 68 61 70  d.  This can hap
3ae0: 70 65 6e 0a 20 20 20 20 2a 2a 20 77 68 65 6e 20  pen.    ** when 
3af0: 74 68 65 20 73 79 6d 62 6f 6c 20 69 73 20 70 6f  the symbol is po
3b00: 70 70 65 64 20 66 72 6f 6d 20 74 68 65 20 73 74  pped from the st
3b10: 61 63 6b 20 64 75 72 69 6e 67 20 61 0a 20 20 20  ack during a.   
3b20: 20 2a 2a 20 72 65 64 75 63 65 20 6f 72 20 64 75   ** reduce or du
3b30: 72 69 6e 67 20 65 72 72 6f 72 20 70 72 6f 63 65  ring error proce
3b40: 73 73 69 6e 67 20 6f 72 20 77 68 65 6e 20 61 20  ssing or when a 
3b50: 70 61 72 73 65 72 20 69 73 20 0a 20 20 20 20 2a  parser is .    *
3b60: 2a 20 62 65 69 6e 67 20 64 65 73 74 72 6f 79 65  * being destroye
3b70: 64 20 62 65 66 6f 72 65 20 69 74 20 69 73 20 66  d before it is f
3b80: 69 6e 69 73 68 65 64 20 70 61 72 73 69 6e 67 2e  inished parsing.
3b90: 0a 20 20 20 20 2a 2a 0a 20 20 20 20 2a 2a 20 4e  .    **.    ** N
3ba0: 6f 74 65 3a 20 64 75 72 69 6e 67 20 61 20 72 65  ote: during a re
3bb0: 64 75 63 65 2c 20 74 68 65 20 6f 6e 6c 79 20 73  duce, the only s
3bc0: 79 6d 62 6f 6c 73 20 64 65 73 74 72 6f 79 65 64  ymbols destroyed
3bd0: 20 61 72 65 20 74 68 6f 73 65 0a 20 20 20 20 2a   are those.    *
3be0: 2a 20 77 68 69 63 68 20 61 70 70 65 61 72 20 6f  * which appear o
3bf0: 6e 20 74 68 65 20 52 48 53 20 6f 66 20 74 68 65  n the RHS of the
3c00: 20 72 75 6c 65 2c 20 62 75 74 20 77 68 69 63 68   rule, but which
3c10: 20 61 72 65 20 2a 6e 6f 74 2a 20 75 73 65 64 0a   are *not* used.
3c20: 20 20 20 20 2a 2a 20 69 6e 73 69 64 65 20 74 68      ** inside th
3c30: 65 20 43 20 63 6f 64 65 2e 0a 20 20 20 20 2a 2f  e C code..    */
3c40: 0a 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 20 42 65 67 69  ./********* Begi
3c50: 6e 20 64 65 73 74 72 75 63 74 6f 72 20 64 65 66  n destructor def
3c60: 69 6e 69 74 69 6f 6e 73 20 2a 2a 2a 2a 2a 2a 2a  initions *******
3c70: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
3c80: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
3c90: 2f 0a 25 25 0a 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 20  /.%%./********* 
3ca0: 45 6e 64 20 64 65 73 74 72 75 63 74 6f 72 20 64  End destructor d
3cb0: 65 66 69 6e 69 74 69 6f 6e 73 20 2a 2a 2a 2a 2a  efinitions *****
3cc0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
3cd0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
3ce0: 2a 2a 2a 2a 2f 0a 20 20 20 20 64 65 66 61 75 6c  ****/.    defaul
3cf0: 74 3a 20 20 62 72 65 61 6b 3b 20 20 20 2f 2a 20  t:  break;   /* 
3d00: 49 66 20 6e 6f 20 64 65 73 74 72 75 63 74 6f 72  If no destructor
3d10: 20 61 63 74 69 6f 6e 20 73 70 65 63 69 66 69 65   action specifie
3d20: 64 3a 20 64 6f 20 6e 6f 74 68 69 6e 67 20 2a 2f  d: do nothing */
3d30: 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 50 6f  .  }.}../*.** Po
3d40: 70 20 74 68 65 20 70 61 72 73 65 72 27 73 20 73  p the parser's s
3d50: 74 61 63 6b 20 6f 6e 63 65 2e 0a 2a 2a 0a 2a 2a  tack once..**.**
3d60: 20 49 66 20 74 68 65 72 65 20 69 73 20 61 20 64   If there is a d
3d70: 65 73 74 72 75 63 74 6f 72 20 72 6f 75 74 69 6e  estructor routin
3d80: 65 20 61 73 73 6f 63 69 61 74 65 64 20 77 69 74  e associated wit
3d90: 68 20 74 68 65 20 74 6f 6b 65 6e 20 77 68 69 63  h the token whic
3da0: 68 0a 2a 2a 20 69 73 20 70 6f 70 70 65 64 20 66  h.** is popped f
3db0: 72 6f 6d 20 74 68 65 20 73 74 61 63 6b 2c 20 74  rom the stack, t
3dc0: 68 65 6e 20 63 61 6c 6c 20 69 74 2e 0a 2a 2f 0a  hen call it..*/.
3dd0: 73 74 61 74 69 63 20 76 6f 69 64 20 79 79 5f 70  static void yy_p
3de0: 6f 70 5f 70 61 72 73 65 72 5f 73 74 61 63 6b 28  op_parser_stack(
3df0: 79 79 50 61 72 73 65 72 20 2a 70 50 61 72 73 65  yyParser *pParse
3e00: 72 29 7b 0a 20 20 79 79 53 74 61 63 6b 45 6e 74  r){.  yyStackEnt
3e10: 72 79 20 2a 79 79 74 6f 73 3b 0a 20 20 61 73 73  ry *yytos;.  ass
3e20: 65 72 74 28 20 70 50 61 72 73 65 72 2d 3e 79 79  ert( pParser->yy
3e30: 74 6f 73 21 3d 30 20 29 3b 0a 20 20 61 73 73 65  tos!=0 );.  asse
3e40: 72 74 28 20 70 50 61 72 73 65 72 2d 3e 79 79 74  rt( pParser->yyt
3e50: 6f 73 20 3e 20 70 50 61 72 73 65 72 2d 3e 79 79  os > pParser->yy
3e60: 73 74 61 63 6b 20 29 3b 0a 20 20 79 79 74 6f 73  stack );.  yytos
3e70: 20 3d 20 70 50 61 72 73 65 72 2d 3e 79 79 74 6f   = pParser->yyto
3e80: 73 2d 2d 3b 0a 23 69 66 6e 64 65 66 20 4e 44 45  s--;.#ifndef NDE
3e90: 42 55 47 0a 20 20 69 66 28 20 79 79 54 72 61 63  BUG.  if( yyTrac
3ea0: 65 46 49 4c 45 20 29 7b 0a 20 20 20 20 66 70 72  eFILE ){.    fpr
3eb0: 69 6e 74 66 28 79 79 54 72 61 63 65 46 49 4c 45  intf(yyTraceFILE
3ec0: 2c 22 25 73 50 6f 70 70 69 6e 67 20 25 73 5c 6e  ,"%sPopping %s\n
3ed0: 22 2c 0a 20 20 20 20 20 20 79 79 54 72 61 63 65  ",.      yyTrace
3ee0: 50 72 6f 6d 70 74 2c 0a 20 20 20 20 20 20 79 79  Prompt,.      yy
3ef0: 54 6f 6b 65 6e 4e 61 6d 65 5b 79 79 74 6f 73 2d  TokenName[yytos-
3f00: 3e 6d 61 6a 6f 72 5d 29 3b 0a 20 20 7d 0a 23 65  >major]);.  }.#e
3f10: 6e 64 69 66 0a 20 20 79 79 5f 64 65 73 74 72 75  ndif.  yy_destru
3f20: 63 74 6f 72 28 70 50 61 72 73 65 72 2c 20 79 79  ctor(pParser, yy
3f30: 74 6f 73 2d 3e 6d 61 6a 6f 72 2c 20 26 79 79 74  tos->major, &yyt
3f40: 6f 73 2d 3e 6d 69 6e 6f 72 29 3b 0a 7d 0a 0a 2f  os->minor);.}../
3f50: 2a 0a 2a 2a 20 43 6c 65 61 72 20 61 6c 6c 20 73  *.** Clear all s
3f60: 65 63 6f 6e 64 61 72 79 20 6d 65 6d 6f 72 79 20  econdary memory 
3f70: 61 6c 6c 6f 63 61 74 69 6f 6e 73 20 66 72 6f 6d  allocations from
3f80: 20 74 68 65 20 70 61 72 73 65 72 0a 2a 2f 0a 76   the parser.*/.v
3f90: 6f 69 64 20 50 61 72 73 65 46 69 6e 61 6c 69 7a  oid ParseFinaliz
3fa0: 65 28 76 6f 69 64 20 2a 70 29 7b 0a 20 20 79 79  e(void *p){.  yy
3fb0: 50 61 72 73 65 72 20 2a 70 50 61 72 73 65 72 20  Parser *pParser 
3fc0: 3d 20 28 79 79 50 61 72 73 65 72 2a 29 70 3b 0a  = (yyParser*)p;.
3fd0: 20 20 77 68 69 6c 65 28 20 70 50 61 72 73 65 72    while( pParser
3fe0: 2d 3e 79 79 74 6f 73 3e 70 50 61 72 73 65 72 2d  ->yytos>pParser-
3ff0: 3e 79 79 73 74 61 63 6b 20 29 20 79 79 5f 70 6f  >yystack ) yy_po
4000: 70 5f 70 61 72 73 65 72 5f 73 74 61 63 6b 28 70  p_parser_stack(p
4010: 50 61 72 73 65 72 29 3b 0a 23 69 66 20 59 59 53  Parser);.#if YYS
4020: 54 41 43 4b 44 45 50 54 48 3c 3d 30 0a 20 20 69  TACKDEPTH<=0.  i
4030: 66 28 20 70 50 61 72 73 65 72 2d 3e 79 79 73 74  f( pParser->yyst
4040: 61 63 6b 21 3d 26 70 50 61 72 73 65 72 2d 3e 79  ack!=&pParser->y
4050: 79 73 74 6b 30 20 29 20 66 72 65 65 28 70 50 61  ystk0 ) free(pPa
4060: 72 73 65 72 2d 3e 79 79 73 74 61 63 6b 29 3b 0a  rser->yystack);.
4070: 23 65 6e 64 69 66 0a 7d 0a 0a 23 69 66 6e 64 65  #endif.}..#ifnde
4080: 66 20 50 61 72 73 65 5f 45 4e 47 49 4e 45 41 4c  f Parse_ENGINEAL
4090: 57 41 59 53 4f 4e 53 54 41 43 4b 0a 2f 2a 20 0a  WAYSONSTACK./* .
40a0: 2a 2a 20 44 65 61 6c 6c 6f 63 61 74 65 20 61 6e  ** Deallocate an
40b0: 64 20 64 65 73 74 72 6f 79 20 61 20 70 61 72 73  d destroy a pars
40c0: 65 72 2e 20 20 44 65 73 74 72 75 63 74 6f 72 73  er.  Destructors
40d0: 20 61 72 65 20 63 61 6c 6c 65 64 20 66 6f 72 0a   are called for.
40e0: 2a 2a 20 61 6c 6c 20 73 74 61 63 6b 20 65 6c 65  ** all stack ele
40f0: 6d 65 6e 74 73 20 62 65 66 6f 72 65 20 73 68 75  ments before shu
4100: 74 74 69 6e 67 20 74 68 65 20 70 61 72 73 65 72  tting the parser
4110: 20 64 6f 77 6e 2e 0a 2a 2a 0a 2a 2a 20 49 66 20   down..**.** If 
4120: 74 68 65 20 59 59 50 41 52 53 45 46 52 45 45 4e  the YYPARSEFREEN
4130: 45 56 45 52 4e 55 4c 4c 20 6d 61 63 72 6f 20 65  EVERNULL macro e
4140: 78 69 73 74 73 20 28 66 6f 72 20 65 78 61 6d 70  xists (for examp
4150: 6c 65 20 62 65 63 61 75 73 65 20 69 74 0a 2a 2a  le because it.**
4160: 20 69 73 20 64 65 66 69 6e 65 64 20 69 6e 20 61   is defined in a
4170: 20 25 69 6e 63 6c 75 64 65 20 73 65 63 74 69 6f   %include sectio
4180: 6e 20 6f 66 20 74 68 65 20 69 6e 70 75 74 20 67  n of the input g
4190: 72 61 6d 6d 61 72 29 20 74 68 65 6e 20 69 74 20  rammar) then it 
41a0: 69 73 0a 2a 2a 20 61 73 73 75 6d 65 64 20 74 68  is.** assumed th
41b0: 61 74 20 74 68 65 20 69 6e 70 75 74 20 70 6f 69  at the input poi
41c0: 6e 74 65 72 20 69 73 20 6e 65 76 65 72 20 4e 55  nter is never NU
41d0: 4c 4c 2e 0a 2a 2f 0a 76 6f 69 64 20 50 61 72 73  LL..*/.void Pars
41e0: 65 46 72 65 65 28 0a 20 20 76 6f 69 64 20 2a 70  eFree(.  void *p
41f0: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,               
4200: 20 20 20 20 20 2f 2a 20 54 68 65 20 70 61 72 73       /* The pars
4210: 65 72 20 74 6f 20 62 65 20 64 65 6c 65 74 65 64  er to be deleted
4220: 20 2a 2f 0a 20 20 76 6f 69 64 20 28 2a 66 72 65   */.  void (*fre
4230: 65 50 72 6f 63 29 28 76 6f 69 64 2a 29 20 20 20  eProc)(void*)   
4240: 20 20 2f 2a 20 46 75 6e 63 74 69 6f 6e 20 75 73    /* Function us
4250: 65 64 20 74 6f 20 72 65 63 6c 61 69 6d 20 6d 65  ed to reclaim me
4260: 6d 6f 72 79 20 2a 2f 0a 29 7b 0a 23 69 66 6e 64  mory */.){.#ifnd
4270: 65 66 20 59 59 50 41 52 53 45 46 52 45 45 4e 45  ef YYPARSEFREENE
4280: 56 45 52 4e 55 4c 4c 0a 20 20 69 66 28 20 70 3d  VERNULL.  if( p=
4290: 3d 30 20 29 20 72 65 74 75 72 6e 3b 0a 23 65 6e  =0 ) return;.#en
42a0: 64 69 66 0a 20 20 50 61 72 73 65 46 69 6e 61 6c  dif.  ParseFinal
42b0: 69 7a 65 28 70 29 3b 0a 20 20 28 2a 66 72 65 65  ize(p);.  (*free
42c0: 50 72 6f 63 29 28 70 29 3b 0a 7d 0a 23 65 6e 64  Proc)(p);.}.#end
42d0: 69 66 20 2f 2a 20 50 61 72 73 65 5f 45 4e 47 49  if /* Parse_ENGI
42e0: 4e 45 41 4c 57 41 59 53 4f 4e 53 54 41 43 4b 20  NEALWAYSONSTACK 
42f0: 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e  */../*.** Return
4300: 20 74 68 65 20 70 65 61 6b 20 64 65 70 74 68 20   the peak depth 
4310: 6f 66 20 74 68 65 20 73 74 61 63 6b 20 66 6f 72  of the stack for
4320: 20 61 20 70 61 72 73 65 72 2e 0a 2a 2f 0a 23 69   a parser..*/.#i
4330: 66 64 65 66 20 59 59 54 52 41 43 4b 4d 41 58 53  fdef YYTRACKMAXS
4340: 54 41 43 4b 44 45 50 54 48 0a 69 6e 74 20 50 61  TACKDEPTH.int Pa
4350: 72 73 65 53 74 61 63 6b 50 65 61 6b 28 76 6f 69  rseStackPeak(voi
4360: 64 20 2a 70 29 7b 0a 20 20 79 79 50 61 72 73 65  d *p){.  yyParse
4370: 72 20 2a 70 50 61 72 73 65 72 20 3d 20 28 79 79  r *pParser = (yy
4380: 50 61 72 73 65 72 2a 29 70 3b 0a 20 20 72 65 74  Parser*)p;.  ret
4390: 75 72 6e 20 70 50 61 72 73 65 72 2d 3e 79 79 68  urn pParser->yyh
43a0: 77 6d 3b 0a 7d 0a 23 65 6e 64 69 66 0a 0a 2f 2a  wm;.}.#endif../*
43b0: 20 54 68 69 73 20 61 72 72 61 79 20 6f 66 20 62   This array of b
43c0: 6f 6f 6c 65 61 6e 73 20 6b 65 65 70 73 20 74 72  ooleans keeps tr
43d0: 61 63 6b 20 6f 66 20 74 68 65 20 70 61 72 73 65  ack of the parse
43e0: 72 20 73 74 61 74 65 6d 65 6e 74 0a 2a 2a 20 63  r statement.** c
43f0: 6f 76 65 72 61 67 65 2e 20 20 54 68 65 20 65 6c  overage.  The el
4400: 65 6d 65 6e 74 20 79 79 63 6f 76 65 72 61 67 65  ement yycoverage
4410: 5b 58 5d 5b 59 5d 20 69 73 20 73 65 74 20 77 68  [X][Y] is set wh
4420: 65 6e 20 74 68 65 20 70 61 72 73 65 72 0a 2a 2a  en the parser.**
4430: 20 69 73 20 69 6e 20 73 74 61 74 65 20 58 20 61   is in state X a
4440: 6e 64 20 68 61 73 20 61 20 6c 6f 6f 6b 61 68 65  nd has a lookahe
4450: 61 64 20 74 6f 6b 65 6e 20 59 2e 20 20 49 6e 20  ad token Y.  In 
4460: 61 20 77 65 6c 6c 2d 74 65 73 74 65 64 0a 2a 2a  a well-tested.**
4470: 20 73 79 73 74 65 6d 73 2c 20 65 76 65 72 79 20   systems, every 
4480: 65 6c 65 6d 65 6e 74 20 6f 66 20 74 68 69 73 20  element of this 
4490: 6d 61 74 72 69 78 20 73 68 6f 75 6c 64 20 65 6e  matrix should en
44a0: 64 20 75 70 20 62 65 69 6e 67 20 73 65 74 2e 0a  d up being set..
44b0: 2a 2f 0a 23 69 66 20 64 65 66 69 6e 65 64 28 59  */.#if defined(Y
44c0: 59 43 4f 56 45 52 41 47 45 29 0a 73 74 61 74 69  YCOVERAGE).stati
44d0: 63 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20  c unsigned char 
44e0: 79 79 63 6f 76 65 72 61 67 65 5b 59 59 4e 53 54  yycoverage[YYNST
44f0: 41 54 45 5d 5b 59 59 4e 54 4f 4b 45 4e 5d 3b 0a  ATE][YYNTOKEN];.
4500: 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 57 72  #endif../*.** Wr
4510: 69 74 65 20 69 6e 74 6f 20 6f 75 74 20 61 20 64  ite into out a d
4520: 65 73 63 72 69 70 74 69 6f 6e 20 6f 66 20 65 76  escription of ev
4530: 65 72 79 20 73 74 61 74 65 2f 6c 6f 6f 6b 61 68  ery state/lookah
4540: 65 61 64 20 63 6f 6d 62 69 6e 61 74 69 6f 6e 20  ead combination 
4550: 74 68 61 74 0a 2a 2a 0a 2a 2a 20 20 20 28 31 29  that.**.**   (1)
4560: 20 20 68 61 73 20 6e 6f 74 20 62 65 65 6e 20 75    has not been u
4570: 73 65 64 20 62 79 20 74 68 65 20 70 61 72 73 65  sed by the parse
4580: 72 2c 20 61 6e 64 0a 2a 2a 20 20 20 28 32 29 20  r, and.**   (2) 
4590: 20 69 73 20 6e 6f 74 20 61 20 73 79 6e 74 61 78   is not a syntax
45a0: 20 65 72 72 6f 72 2e 0a 2a 2a 0a 2a 2a 20 52 65   error..**.** Re
45b0: 74 75 72 6e 20 74 68 65 20 6e 75 6d 62 65 72 20  turn the number 
45c0: 6f 66 20 6d 69 73 73 65 64 20 73 74 61 74 65 2f  of missed state/
45d0: 6c 6f 6f 6b 61 68 65 61 64 20 63 6f 6d 62 69 6e  lookahead combin
45e0: 61 74 69 6f 6e 73 2e 0a 2a 2f 0a 23 69 66 20 64  ations..*/.#if d
45f0: 65 66 69 6e 65 64 28 59 59 43 4f 56 45 52 41 47  efined(YYCOVERAG
4600: 45 29 0a 69 6e 74 20 50 61 72 73 65 43 6f 76 65  E).int ParseCove
4610: 72 61 67 65 28 46 49 4c 45 20 2a 6f 75 74 29 7b  rage(FILE *out){
4620: 0a 20 20 69 6e 74 20 73 74 61 74 65 6e 6f 2c 20  .  int stateno, 
4630: 69 4c 6f 6f 6b 41 68 65 61 64 2c 20 69 3b 0a 20  iLookAhead, i;. 
4640: 20 69 6e 74 20 6e 4d 69 73 73 65 64 20 3d 20 30   int nMissed = 0
4650: 3b 0a 20 20 66 6f 72 28 73 74 61 74 65 6e 6f 3d  ;.  for(stateno=
4660: 30 3b 20 73 74 61 74 65 6e 6f 3c 59 59 4e 53 54  0; stateno<YYNST
4670: 41 54 45 3b 20 73 74 61 74 65 6e 6f 2b 2b 29 7b  ATE; stateno++){
4680: 0a 20 20 20 20 69 20 3d 20 79 79 5f 73 68 69 66  .    i = yy_shif
4690: 74 5f 6f 66 73 74 5b 73 74 61 74 65 6e 6f 5d 3b  t_ofst[stateno];
46a0: 0a 20 20 20 20 66 6f 72 28 69 4c 6f 6f 6b 41 68  .    for(iLookAh
46b0: 65 61 64 3d 30 3b 20 69 4c 6f 6f 6b 41 68 65 61  ead=0; iLookAhea
46c0: 64 3c 59 59 4e 54 4f 4b 45 4e 3b 20 69 4c 6f 6f  d<YYNTOKEN; iLoo
46d0: 6b 41 68 65 61 64 2b 2b 29 7b 0a 20 20 20 20 20  kAhead++){.     
46e0: 20 69 66 28 20 79 79 5f 6c 6f 6f 6b 61 68 65 61   if( yy_lookahea
46f0: 64 5b 69 2b 69 4c 6f 6f 6b 41 68 65 61 64 5d 21  d[i+iLookAhead]!
4700: 3d 69 4c 6f 6f 6b 41 68 65 61 64 20 29 20 63 6f  =iLookAhead ) co
4710: 6e 74 69 6e 75 65 3b 0a 20 20 20 20 20 20 69 66  ntinue;.      if
4720: 28 20 79 79 63 6f 76 65 72 61 67 65 5b 73 74 61  ( yycoverage[sta
4730: 74 65 6e 6f 5d 5b 69 4c 6f 6f 6b 41 68 65 61 64  teno][iLookAhead
4740: 5d 3d 3d 30 20 29 20 6e 4d 69 73 73 65 64 2b 2b  ]==0 ) nMissed++
4750: 3b 0a 20 20 20 20 20 20 69 66 28 20 6f 75 74 20  ;.      if( out 
4760: 29 7b 0a 20 20 20 20 20 20 20 20 66 70 72 69 6e  ){.        fprin
4770: 74 66 28 6f 75 74 2c 22 53 74 61 74 65 20 25 64  tf(out,"State %d
4780: 20 6c 6f 6f 6b 61 68 65 61 64 20 25 73 20 25 73   lookahead %s %s
4790: 5c 6e 22 2c 20 73 74 61 74 65 6e 6f 2c 0a 20 20  \n", stateno,.  
47a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 79 79                yy
47b0: 54 6f 6b 65 6e 4e 61 6d 65 5b 69 4c 6f 6f 6b 41  TokenName[iLookA
47c0: 68 65 61 64 5d 2c 0a 20 20 20 20 20 20 20 20 20  head],.         
47d0: 20 20 20 20 20 20 20 79 79 63 6f 76 65 72 61 67         yycoverag
47e0: 65 5b 73 74 61 74 65 6e 6f 5d 5b 69 4c 6f 6f 6b  e[stateno][iLook
47f0: 41 68 65 61 64 5d 20 3f 20 22 6f 6b 22 20 3a 20  Ahead] ? "ok" : 
4800: 22 6d 69 73 73 65 64 22 29 3b 0a 20 20 20 20 20  "missed");.     
4810: 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 72   }.    }.  }.  r
4820: 65 74 75 72 6e 20 6e 4d 69 73 73 65 64 3b 0a 7d  eturn nMissed;.}
4830: 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 46  .#endif../*.** F
4840: 69 6e 64 20 74 68 65 20 61 70 70 72 6f 70 72 69  ind the appropri
4850: 61 74 65 20 61 63 74 69 6f 6e 20 66 6f 72 20 61  ate action for a
4860: 20 70 61 72 73 65 72 20 67 69 76 65 6e 20 74 68   parser given th
4870: 65 20 74 65 72 6d 69 6e 61 6c 0a 2a 2a 20 6c 6f  e terminal.** lo
4880: 6f 6b 2d 61 68 65 61 64 20 74 6f 6b 65 6e 20 69  ok-ahead token i
4890: 4c 6f 6f 6b 41 68 65 61 64 2e 0a 2a 2f 0a 73 74  LookAhead..*/.st
48a0: 61 74 69 63 20 59 59 41 43 54 49 4f 4e 54 59 50  atic YYACTIONTYP
48b0: 45 20 79 79 5f 66 69 6e 64 5f 73 68 69 66 74 5f  E yy_find_shift_
48c0: 61 63 74 69 6f 6e 28 0a 20 20 59 59 43 4f 44 45  action(.  YYCODE
48d0: 54 59 50 45 20 69 4c 6f 6f 6b 41 68 65 61 64 2c  TYPE iLookAhead,
48e0: 20 20 20 20 2f 2a 20 54 68 65 20 6c 6f 6f 6b 2d      /* The look-
48f0: 61 68 65 61 64 20 74 6f 6b 65 6e 20 2a 2f 0a 20  ahead token */. 
4900: 20 59 59 41 43 54 49 4f 4e 54 59 50 45 20 73 74   YYACTIONTYPE st
4910: 61 74 65 6e 6f 20 20 20 20 20 20 2f 2a 20 43 75  ateno      /* Cu
4920: 72 72 65 6e 74 20 73 74 61 74 65 20 6e 75 6d 62  rrent state numb
4930: 65 72 20 2a 2f 0a 29 7b 0a 20 20 69 6e 74 20 69  er */.){.  int i
4940: 3b 0a 0a 20 20 69 66 28 20 73 74 61 74 65 6e 6f  ;..  if( stateno
4950: 3e 59 59 5f 4d 41 58 5f 53 48 49 46 54 20 29 20  >YY_MAX_SHIFT ) 
4960: 72 65 74 75 72 6e 20 73 74 61 74 65 6e 6f 3b 0a  return stateno;.
4970: 20 20 61 73 73 65 72 74 28 20 73 74 61 74 65 6e    assert( staten
4980: 6f 20 3c 3d 20 59 59 5f 53 48 49 46 54 5f 43 4f  o <= YY_SHIFT_CO
4990: 55 4e 54 20 29 3b 0a 23 69 66 20 64 65 66 69 6e  UNT );.#if defin
49a0: 65 64 28 59 59 43 4f 56 45 52 41 47 45 29 0a 20  ed(YYCOVERAGE). 
49b0: 20 79 79 63 6f 76 65 72 61 67 65 5b 73 74 61 74   yycoverage[stat
49c0: 65 6e 6f 5d 5b 69 4c 6f 6f 6b 41 68 65 61 64 5d  eno][iLookAhead]
49d0: 20 3d 20 31 3b 0a 23 65 6e 64 69 66 0a 20 20 64   = 1;.#endif.  d
49e0: 6f 7b 0a 20 20 20 20 69 20 3d 20 79 79 5f 73 68  o{.    i = yy_sh
49f0: 69 66 74 5f 6f 66 73 74 5b 73 74 61 74 65 6e 6f  ift_ofst[stateno
4a00: 5d 3b 0a 20 20 20 20 61 73 73 65 72 74 28 20 69  ];.    assert( i
4a10: 3e 3d 30 20 29 3b 0a 20 20 20 20 2f 2a 20 61 73  >=0 );.    /* as
4a20: 73 65 72 74 28 20 69 2b 59 59 4e 54 4f 4b 45 4e  sert( i+YYNTOKEN
4a30: 3c 3d 28 69 6e 74 29 59 59 5f 4e 4c 4f 4f 4b 41  <=(int)YY_NLOOKA
4a40: 48 45 41 44 20 29 3b 20 2a 2f 0a 20 20 20 20 61  HEAD ); */.    a
4a50: 73 73 65 72 74 28 20 69 4c 6f 6f 6b 41 68 65 61  ssert( iLookAhea
4a60: 64 21 3d 59 59 4e 4f 43 4f 44 45 20 29 3b 0a 20  d!=YYNOCODE );. 
4a70: 20 20 20 61 73 73 65 72 74 28 20 69 4c 6f 6f 6b     assert( iLook
4a80: 41 68 65 61 64 20 3c 20 59 59 4e 54 4f 4b 45 4e  Ahead < YYNTOKEN
4a90: 20 29 3b 0a 20 20 20 20 69 20 2b 3d 20 69 4c 6f   );.    i += iLo
4aa0: 6f 6b 41 68 65 61 64 3b 0a 20 20 20 20 69 66 28  okAhead;.    if(
4ab0: 20 69 3e 3d 59 59 5f 4e 4c 4f 4f 4b 41 48 45 41   i>=YY_NLOOKAHEA
4ac0: 44 20 7c 7c 20 79 79 5f 6c 6f 6f 6b 61 68 65 61  D || yy_lookahea
4ad0: 64 5b 69 5d 21 3d 69 4c 6f 6f 6b 41 68 65 61 64  d[i]!=iLookAhead
4ae0: 20 29 7b 0a 23 69 66 64 65 66 20 59 59 46 41 4c   ){.#ifdef YYFAL
4af0: 4c 42 41 43 4b 0a 20 20 20 20 20 20 59 59 43 4f  LBACK.      YYCO
4b00: 44 45 54 59 50 45 20 69 46 61 6c 6c 62 61 63 6b  DETYPE iFallback
4b10: 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20  ;            /* 
4b20: 46 61 6c 6c 62 61 63 6b 20 74 6f 6b 65 6e 20 2a  Fallback token *
4b30: 2f 0a 20 20 20 20 20 20 69 66 28 20 69 4c 6f 6f  /.      if( iLoo
4b40: 6b 41 68 65 61 64 3c 73 69 7a 65 6f 66 28 79 79  kAhead<sizeof(yy
4b50: 46 61 6c 6c 62 61 63 6b 29 2f 73 69 7a 65 6f 66  Fallback)/sizeof
4b60: 28 79 79 46 61 6c 6c 62 61 63 6b 5b 30 5d 29 0a  (yyFallback[0]).
4b70: 20 20 20 20 20 20 20 20 20 20 20 20 20 26 26 20               && 
4b80: 28 69 46 61 6c 6c 62 61 63 6b 20 3d 20 79 79 46  (iFallback = yyF
4b90: 61 6c 6c 62 61 63 6b 5b 69 4c 6f 6f 6b 41 68 65  allback[iLookAhe
4ba0: 61 64 5d 29 21 3d 30 20 29 7b 0a 23 69 66 6e 64  ad])!=0 ){.#ifnd
4bb0: 65 66 20 4e 44 45 42 55 47 0a 20 20 20 20 20 20  ef NDEBUG.      
4bc0: 20 20 69 66 28 20 79 79 54 72 61 63 65 46 49 4c    if( yyTraceFIL
4bd0: 45 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 66  E ){.          f
4be0: 70 72 69 6e 74 66 28 79 79 54 72 61 63 65 46 49  printf(yyTraceFI
4bf0: 4c 45 2c 20 22 25 73 46 41 4c 4c 42 41 43 4b 20  LE, "%sFALLBACK 
4c00: 25 73 20 3d 3e 20 25 73 5c 6e 22 2c 0a 20 20 20  %s => %s\n",.   
4c10: 20 20 20 20 20 20 20 20 20 20 79 79 54 72 61 63            yyTrac
4c20: 65 50 72 6f 6d 70 74 2c 20 79 79 54 6f 6b 65 6e  ePrompt, yyToken
4c30: 4e 61 6d 65 5b 69 4c 6f 6f 6b 41 68 65 61 64 5d  Name[iLookAhead]
4c40: 2c 20 79 79 54 6f 6b 65 6e 4e 61 6d 65 5b 69 46  , yyTokenName[iF
4c50: 61 6c 6c 62 61 63 6b 5d 29 3b 0a 20 20 20 20 20  allback]);.     
4c60: 20 20 20 7d 0a 23 65 6e 64 69 66 0a 20 20 20 20     }.#endif.    
4c70: 20 20 20 20 61 73 73 65 72 74 28 20 79 79 46 61      assert( yyFa
4c80: 6c 6c 62 61 63 6b 5b 69 46 61 6c 6c 62 61 63 6b  llback[iFallback
4c90: 5d 3d 3d 30 20 29 3b 20 2f 2a 20 46 61 6c 6c 62  ]==0 ); /* Fallb
4ca0: 61 63 6b 20 6c 6f 6f 70 20 6d 75 73 74 20 74 65  ack loop must te
4cb0: 72 6d 69 6e 61 74 65 20 2a 2f 0a 20 20 20 20 20  rminate */.     
4cc0: 20 20 20 69 4c 6f 6f 6b 41 68 65 61 64 20 3d 20     iLookAhead = 
4cd0: 69 46 61 6c 6c 62 61 63 6b 3b 0a 20 20 20 20 20  iFallback;.     
4ce0: 20 20 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20     continue;.   
4cf0: 20 20 20 7d 0a 23 65 6e 64 69 66 0a 23 69 66 64     }.#endif.#ifd
4d00: 65 66 20 59 59 57 49 4c 44 43 41 52 44 0a 20 20  ef YYWILDCARD.  
4d10: 20 20 20 20 7b 0a 20 20 20 20 20 20 20 20 69 6e      {.        in
4d20: 74 20 6a 20 3d 20 69 20 2d 20 69 4c 6f 6f 6b 41  t j = i - iLookA
4d30: 68 65 61 64 20 2b 20 59 59 57 49 4c 44 43 41 52  head + YYWILDCAR
4d40: 44 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 0a  D;.        if( .
4d50: 23 69 66 20 59 59 5f 53 48 49 46 54 5f 4d 49 4e  #if YY_SHIFT_MIN
4d60: 2b 59 59 57 49 4c 44 43 41 52 44 3c 30 0a 20 20  +YYWILDCARD<0.  
4d70: 20 20 20 20 20 20 20 20 6a 3e 3d 30 20 26 26 0a          j>=0 &&.
4d80: 23 65 6e 64 69 66 0a 23 69 66 20 59 59 5f 53 48  #endif.#if YY_SH
4d90: 49 46 54 5f 4d 41 58 2b 59 59 57 49 4c 44 43 41  IFT_MAX+YYWILDCA
4da0: 52 44 3e 3d 59 59 5f 41 43 54 54 41 42 5f 43 4f  RD>=YY_ACTTAB_CO
4db0: 55 4e 54 0a 20 20 20 20 20 20 20 20 20 20 6a 3c  UNT.          j<
4dc0: 59 59 5f 41 43 54 54 41 42 5f 43 4f 55 4e 54 20  YY_ACTTAB_COUNT 
4dd0: 26 26 0a 23 65 6e 64 69 66 0a 20 20 20 20 20 20  &&.#endif.      
4de0: 20 20 20 20 6a 3c 28 69 6e 74 29 28 73 69 7a 65      j<(int)(size
4df0: 6f 66 28 79 79 5f 6c 6f 6f 6b 61 68 65 61 64 29  of(yy_lookahead)
4e00: 2f 73 69 7a 65 6f 66 28 79 79 5f 6c 6f 6f 6b 61  /sizeof(yy_looka
4e10: 68 65 61 64 5b 30 5d 29 29 20 26 26 0a 20 20 20  head[0])) &&.   
4e20: 20 20 20 20 20 20 20 79 79 5f 6c 6f 6f 6b 61 68         yy_lookah
4e30: 65 61 64 5b 6a 5d 3d 3d 59 59 57 49 4c 44 43 41  ead[j]==YYWILDCA
4e40: 52 44 20 26 26 20 69 4c 6f 6f 6b 41 68 65 61 64  RD && iLookAhead
4e50: 3e 30 0a 20 20 20 20 20 20 20 20 29 7b 0a 23 69  >0.        ){.#i
4e60: 66 6e 64 65 66 20 4e 44 45 42 55 47 0a 20 20 20  fndef NDEBUG.   
4e70: 20 20 20 20 20 20 20 69 66 28 20 79 79 54 72 61         if( yyTra
4e80: 63 65 46 49 4c 45 20 29 7b 0a 20 20 20 20 20 20  ceFILE ){.      
4e90: 20 20 20 20 20 20 66 70 72 69 6e 74 66 28 79 79        fprintf(yy
4ea0: 54 72 61 63 65 46 49 4c 45 2c 20 22 25 73 57 49  TraceFILE, "%sWI
4eb0: 4c 44 43 41 52 44 20 25 73 20 3d 3e 20 25 73 5c  LDCARD %s => %s\
4ec0: 6e 22 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20  n",.            
4ed0: 20 20 20 79 79 54 72 61 63 65 50 72 6f 6d 70 74     yyTracePrompt
4ee0: 2c 20 79 79 54 6f 6b 65 6e 4e 61 6d 65 5b 69 4c  , yyTokenName[iL
4ef0: 6f 6f 6b 41 68 65 61 64 5d 2c 0a 20 20 20 20 20  ookAhead],.     
4f00: 20 20 20 20 20 20 20 20 20 20 79 79 54 6f 6b 65            yyToke
4f10: 6e 4e 61 6d 65 5b 59 59 57 49 4c 44 43 41 52 44  nName[YYWILDCARD
4f20: 5d 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a  ]);.          }.
4f30: 23 65 6e 64 69 66 20 2f 2a 20 4e 44 45 42 55 47  #endif /* NDEBUG
4f40: 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 72 65   */.          re
4f50: 74 75 72 6e 20 79 79 5f 61 63 74 69 6f 6e 5b 6a  turn yy_action[j
4f60: 5d 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  ];.        }.   
4f70: 20 20 20 7d 0a 23 65 6e 64 69 66 20 2f 2a 20 59     }.#endif /* Y
4f80: 59 57 49 4c 44 43 41 52 44 20 2a 2f 0a 20 20 20  YWILDCARD */.   
4f90: 20 20 20 72 65 74 75 72 6e 20 79 79 5f 64 65 66     return yy_def
4fa0: 61 75 6c 74 5b 73 74 61 74 65 6e 6f 5d 3b 0a 20  ault[stateno];. 
4fb0: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
4fc0: 72 65 74 75 72 6e 20 79 79 5f 61 63 74 69 6f 6e  return yy_action
4fd0: 5b 69 5d 3b 0a 20 20 20 20 7d 0a 20 20 7d 77 68  [i];.    }.  }wh
4fe0: 69 6c 65 28 31 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  ile(1);.}../*.**
4ff0: 20 46 69 6e 64 20 74 68 65 20 61 70 70 72 6f 70   Find the approp
5000: 72 69 61 74 65 20 61 63 74 69 6f 6e 20 66 6f 72  riate action for
5010: 20 61 20 70 61 72 73 65 72 20 67 69 76 65 6e 20   a parser given 
5020: 74 68 65 20 6e 6f 6e 2d 74 65 72 6d 69 6e 61 6c  the non-terminal
5030: 0a 2a 2a 20 6c 6f 6f 6b 2d 61 68 65 61 64 20 74  .** look-ahead t
5040: 6f 6b 65 6e 20 69 4c 6f 6f 6b 41 68 65 61 64 2e  oken iLookAhead.
5050: 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 79  .*/.static int y
5060: 79 5f 66 69 6e 64 5f 72 65 64 75 63 65 5f 61 63  y_find_reduce_ac
5070: 74 69 6f 6e 28 0a 20 20 59 59 41 43 54 49 4f 4e  tion(.  YYACTION
5080: 54 59 50 45 20 73 74 61 74 65 6e 6f 2c 20 20 20  TYPE stateno,   
5090: 20 20 2f 2a 20 43 75 72 72 65 6e 74 20 73 74 61    /* Current sta
50a0: 74 65 20 6e 75 6d 62 65 72 20 2a 2f 0a 20 20 59  te number */.  Y
50b0: 59 43 4f 44 45 54 59 50 45 20 69 4c 6f 6f 6b 41  YCODETYPE iLookA
50c0: 68 65 61 64 20 20 20 20 20 2f 2a 20 54 68 65 20  head     /* The 
50d0: 6c 6f 6f 6b 2d 61 68 65 61 64 20 74 6f 6b 65 6e  look-ahead token
50e0: 20 2a 2f 0a 29 7b 0a 20 20 69 6e 74 20 69 3b 0a   */.){.  int i;.
50f0: 23 69 66 64 65 66 20 59 59 45 52 52 4f 52 53 59  #ifdef YYERRORSY
5100: 4d 42 4f 4c 0a 20 20 69 66 28 20 73 74 61 74 65  MBOL.  if( state
5110: 6e 6f 3e 59 59 5f 52 45 44 55 43 45 5f 43 4f 55  no>YY_REDUCE_COU
5120: 4e 54 20 29 7b 0a 20 20 20 20 72 65 74 75 72 6e  NT ){.    return
5130: 20 79 79 5f 64 65 66 61 75 6c 74 5b 73 74 61 74   yy_default[stat
5140: 65 6e 6f 5d 3b 0a 20 20 7d 0a 23 65 6c 73 65 0a  eno];.  }.#else.
5150: 20 20 61 73 73 65 72 74 28 20 73 74 61 74 65 6e    assert( staten
5160: 6f 3c 3d 59 59 5f 52 45 44 55 43 45 5f 43 4f 55  o<=YY_REDUCE_COU
5170: 4e 54 20 29 3b 0a 23 65 6e 64 69 66 0a 20 20 69  NT );.#endif.  i
5180: 20 3d 20 79 79 5f 72 65 64 75 63 65 5f 6f 66 73   = yy_reduce_ofs
5190: 74 5b 73 74 61 74 65 6e 6f 5d 3b 0a 20 20 61 73  t[stateno];.  as
51a0: 73 65 72 74 28 20 69 4c 6f 6f 6b 41 68 65 61 64  sert( iLookAhead
51b0: 21 3d 59 59 4e 4f 43 4f 44 45 20 29 3b 0a 20 20  !=YYNOCODE );.  
51c0: 69 20 2b 3d 20 69 4c 6f 6f 6b 41 68 65 61 64 3b  i += iLookAhead;
51d0: 0a 23 69 66 64 65 66 20 59 59 45 52 52 4f 52 53  .#ifdef YYERRORS
51e0: 59 4d 42 4f 4c 0a 20 20 69 66 28 20 69 3c 30 20  YMBOL.  if( i<0 
51f0: 7c 7c 20 69 3e 3d 59 59 5f 41 43 54 54 41 42 5f  || i>=YY_ACTTAB_
5200: 43 4f 55 4e 54 20 7c 7c 20 79 79 5f 6c 6f 6f 6b  COUNT || yy_look
5210: 61 68 65 61 64 5b 69 5d 21 3d 69 4c 6f 6f 6b 41  ahead[i]!=iLookA
5220: 68 65 61 64 20 29 7b 0a 20 20 20 20 72 65 74 75  head ){.    retu
5230: 72 6e 20 79 79 5f 64 65 66 61 75 6c 74 5b 73 74  rn yy_default[st
5240: 61 74 65 6e 6f 5d 3b 0a 20 20 7d 0a 23 65 6c 73  ateno];.  }.#els
5250: 65 0a 20 20 61 73 73 65 72 74 28 20 69 3e 3d 30  e.  assert( i>=0
5260: 20 26 26 20 69 3c 59 59 5f 41 43 54 54 41 42 5f   && i<YY_ACTTAB_
5270: 43 4f 55 4e 54 20 29 3b 0a 20 20 61 73 73 65 72  COUNT );.  asser
5280: 74 28 20 79 79 5f 6c 6f 6f 6b 61 68 65 61 64 5b  t( yy_lookahead[
5290: 69 5d 3d 3d 69 4c 6f 6f 6b 41 68 65 61 64 20 29  i]==iLookAhead )
52a0: 3b 0a 23 65 6e 64 69 66 0a 20 20 72 65 74 75 72  ;.#endif.  retur
52b0: 6e 20 79 79 5f 61 63 74 69 6f 6e 5b 69 5d 3b 0a  n yy_action[i];.
52c0: 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 66 6f 6c  }../*.** The fol
52d0: 6c 6f 77 69 6e 67 20 72 6f 75 74 69 6e 65 20 69  lowing routine i
52e0: 73 20 63 61 6c 6c 65 64 20 69 66 20 74 68 65 20  s called if the 
52f0: 73 74 61 63 6b 20 6f 76 65 72 66 6c 6f 77 73 2e  stack overflows.
5300: 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20  .*/.static void 
5310: 79 79 53 74 61 63 6b 4f 76 65 72 66 6c 6f 77 28  yyStackOverflow(
5320: 79 79 50 61 72 73 65 72 20 2a 79 79 70 50 61 72  yyParser *yypPar
5330: 73 65 72 29 7b 0a 20 20 20 50 61 72 73 65 41 52  ser){.   ParseAR
5340: 47 5f 46 45 54 43 48 0a 20 20 20 50 61 72 73 65  G_FETCH.   Parse
5350: 43 54 58 5f 46 45 54 43 48 0a 23 69 66 6e 64 65  CTX_FETCH.#ifnde
5360: 66 20 4e 44 45 42 55 47 0a 20 20 20 69 66 28 20  f NDEBUG.   if( 
5370: 79 79 54 72 61 63 65 46 49 4c 45 20 29 7b 0a 20  yyTraceFILE ){. 
5380: 20 20 20 20 66 70 72 69 6e 74 66 28 79 79 54 72      fprintf(yyTr
5390: 61 63 65 46 49 4c 45 2c 22 25 73 53 74 61 63 6b  aceFILE,"%sStack
53a0: 20 4f 76 65 72 66 6c 6f 77 21 5c 6e 22 2c 79 79   Overflow!\n",yy
53b0: 54 72 61 63 65 50 72 6f 6d 70 74 29 3b 0a 20 20  TracePrompt);.  
53c0: 20 7d 0a 23 65 6e 64 69 66 0a 20 20 20 77 68 69   }.#endif.   whi
53d0: 6c 65 28 20 79 79 70 50 61 72 73 65 72 2d 3e 79  le( yypParser->y
53e0: 79 74 6f 73 3e 79 79 70 50 61 72 73 65 72 2d 3e  ytos>yypParser->
53f0: 79 79 73 74 61 63 6b 20 29 20 79 79 5f 70 6f 70  yystack ) yy_pop
5400: 5f 70 61 72 73 65 72 5f 73 74 61 63 6b 28 79 79  _parser_stack(yy
5410: 70 50 61 72 73 65 72 29 3b 0a 20 20 20 2f 2a 20  pParser);.   /* 
5420: 48 65 72 65 20 63 6f 64 65 20 69 73 20 69 6e 73  Here code is ins
5430: 65 72 74 65 64 20 77 68 69 63 68 20 77 69 6c 6c  erted which will
5440: 20 65 78 65 63 75 74 65 20 69 66 20 74 68 65 20   execute if the 
5450: 70 61 72 73 65 72 0a 20 20 20 2a 2a 20 73 74 61  parser.   ** sta
5460: 63 6b 20 65 76 65 72 79 20 6f 76 65 72 66 6c 6f  ck every overflo
5470: 77 73 20 2a 2f 0a 2f 2a 2a 2a 2a 2a 2a 2a 2a 20  ws */./******** 
5480: 42 65 67 69 6e 20 25 73 74 61 63 6b 5f 6f 76 65  Begin %stack_ove
5490: 72 66 6c 6f 77 20 63 6f 64 65 20 2a 2a 2a 2a 2a  rflow code *****
54a0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
54b0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
54c0: 2a 2a 2a 2a 2a 2f 0a 25 25 0a 2f 2a 2a 2a 2a 2a  *****/.%%./*****
54d0: 2a 2a 2a 20 45 6e 64 20 25 73 74 61 63 6b 5f 6f  *** End %stack_o
54e0: 76 65 72 66 6c 6f 77 20 63 6f 64 65 20 2a 2a 2a  verflow code ***
54f0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
5500: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
5510: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a 20 20 20 50 61  *********/.   Pa
5520: 72 73 65 41 52 47 5f 53 54 4f 52 45 20 2f 2a 20  rseARG_STORE /* 
5530: 53 75 70 70 72 65 73 73 20 77 61 72 6e 69 6e 67  Suppress warning
5540: 20 61 62 6f 75 74 20 75 6e 75 73 65 64 20 25 65   about unused %e
5550: 78 74 72 61 5f 61 72 67 75 6d 65 6e 74 20 76 61  xtra_argument va
5560: 72 20 2a 2f 0a 20 20 20 50 61 72 73 65 43 54 58  r */.   ParseCTX
5570: 5f 53 54 4f 52 45 0a 7d 0a 0a 2f 2a 0a 2a 2a 20  _STORE.}../*.** 
5580: 50 72 69 6e 74 20 74 72 61 63 69 6e 67 20 69 6e  Print tracing in
5590: 66 6f 72 6d 61 74 69 6f 6e 20 66 6f 72 20 61 20  formation for a 
55a0: 53 48 49 46 54 20 61 63 74 69 6f 6e 0a 2a 2f 0a  SHIFT action.*/.
55b0: 23 69 66 6e 64 65 66 20 4e 44 45 42 55 47 0a 73  #ifndef NDEBUG.s
55c0: 74 61 74 69 63 20 76 6f 69 64 20 79 79 54 72 61  tatic void yyTra
55d0: 63 65 53 68 69 66 74 28 79 79 50 61 72 73 65 72  ceShift(yyParser
55e0: 20 2a 79 79 70 50 61 72 73 65 72 2c 20 69 6e 74   *yypParser, int
55f0: 20 79 79 4e 65 77 53 74 61 74 65 2c 20 63 6f 6e   yyNewState, con
5600: 73 74 20 63 68 61 72 20 2a 7a 54 61 67 29 7b 0a  st char *zTag){.
5610: 20 20 69 66 28 20 79 79 54 72 61 63 65 46 49 4c    if( yyTraceFIL
5620: 45 20 29 7b 0a 20 20 20 20 69 66 28 20 79 79 4e  E ){.    if( yyN
5630: 65 77 53 74 61 74 65 3c 59 59 4e 53 54 41 54 45  ewState<YYNSTATE
5640: 20 29 7b 0a 20 20 20 20 20 20 66 70 72 69 6e 74   ){.      fprint
5650: 66 28 79 79 54 72 61 63 65 46 49 4c 45 2c 22 25  f(yyTraceFILE,"%
5660: 73 25 73 20 27 25 73 27 2c 20 67 6f 20 74 6f 20  s%s '%s', go to 
5670: 73 74 61 74 65 20 25 64 5c 6e 22 2c 0a 20 20 20  state %d\n",.   
5680: 20 20 20 20 20 20 79 79 54 72 61 63 65 50 72 6f        yyTracePro
5690: 6d 70 74 2c 20 7a 54 61 67 2c 20 79 79 54 6f 6b  mpt, zTag, yyTok
56a0: 65 6e 4e 61 6d 65 5b 79 79 70 50 61 72 73 65 72  enName[yypParser
56b0: 2d 3e 79 79 74 6f 73 2d 3e 6d 61 6a 6f 72 5d 2c  ->yytos->major],
56c0: 0a 20 20 20 20 20 20 20 20 20 79 79 4e 65 77 53  .         yyNewS
56d0: 74 61 74 65 29 3b 0a 20 20 20 20 7d 65 6c 73 65  tate);.    }else
56e0: 7b 0a 20 20 20 20 20 20 66 70 72 69 6e 74 66 28  {.      fprintf(
56f0: 79 79 54 72 61 63 65 46 49 4c 45 2c 22 25 73 25  yyTraceFILE,"%s%
5700: 73 20 27 25 73 27 2c 20 70 65 6e 64 69 6e 67 20  s '%s', pending 
5710: 72 65 64 75 63 65 20 25 64 5c 6e 22 2c 0a 20 20  reduce %d\n",.  
5720: 20 20 20 20 20 20 20 79 79 54 72 61 63 65 50 72         yyTracePr
5730: 6f 6d 70 74 2c 20 7a 54 61 67 2c 20 79 79 54 6f  ompt, zTag, yyTo
5740: 6b 65 6e 4e 61 6d 65 5b 79 79 70 50 61 72 73 65  kenName[yypParse
5750: 72 2d 3e 79 79 74 6f 73 2d 3e 6d 61 6a 6f 72 5d  r->yytos->major]
5760: 2c 0a 20 20 20 20 20 20 20 20 20 79 79 4e 65 77  ,.         yyNew
5770: 53 74 61 74 65 20 2d 20 59 59 5f 4d 49 4e 5f 52  State - YY_MIN_R
5780: 45 44 55 43 45 29 3b 0a 20 20 20 20 7d 0a 20 20  EDUCE);.    }.  
5790: 7d 0a 7d 0a 23 65 6c 73 65 0a 23 20 64 65 66 69  }.}.#else.# defi
57a0: 6e 65 20 79 79 54 72 61 63 65 53 68 69 66 74 28  ne yyTraceShift(
57b0: 58 2c 59 2c 5a 29 0a 23 65 6e 64 69 66 0a 0a 2f  X,Y,Z).#endif../
57c0: 2a 0a 2a 2a 20 50 65 72 66 6f 72 6d 20 61 20 73  *.** Perform a s
57d0: 68 69 66 74 20 61 63 74 69 6f 6e 2e 0a 2a 2f 0a  hift action..*/.
57e0: 73 74 61 74 69 63 20 76 6f 69 64 20 79 79 5f 73  static void yy_s
57f0: 68 69 66 74 28 0a 20 20 79 79 50 61 72 73 65 72  hift(.  yyParser
5800: 20 2a 79 79 70 50 61 72 73 65 72 2c 20 20 20 20   *yypParser,    
5810: 20 20 20 20 20 20 2f 2a 20 54 68 65 20 70 61 72        /* The par
5820: 73 65 72 20 74 6f 20 62 65 20 73 68 69 66 74 65  ser to be shifte
5830: 64 20 2a 2f 0a 20 20 59 59 41 43 54 49 4f 4e 54  d */.  YYACTIONT
5840: 59 50 45 20 79 79 4e 65 77 53 74 61 74 65 2c 20  YPE yyNewState, 
5850: 20 20 20 20 20 2f 2a 20 54 68 65 20 6e 65 77 20       /* The new 
5860: 73 74 61 74 65 20 74 6f 20 73 68 69 66 74 20 69  state to shift i
5870: 6e 20 2a 2f 0a 20 20 59 59 43 4f 44 45 54 59 50  n */.  YYCODETYP
5880: 45 20 79 79 4d 61 6a 6f 72 2c 20 20 20 20 20 20  E yyMajor,      
5890: 20 20 20 20 20 2f 2a 20 54 68 65 20 6d 61 6a 6f       /* The majo
58a0: 72 20 74 6f 6b 65 6e 20 74 6f 20 73 68 69 66 74  r token to shift
58b0: 20 69 6e 20 2a 2f 0a 20 20 50 61 72 73 65 54 4f   in */.  ParseTO
58c0: 4b 45 4e 54 59 50 45 20 79 79 4d 69 6e 6f 72 20  KENTYPE yyMinor 
58d0: 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20 6d 69         /* The mi
58e0: 6e 6f 72 20 74 6f 6b 65 6e 20 74 6f 20 73 68 69  nor token to shi
58f0: 66 74 20 69 6e 20 2a 2f 0a 29 7b 0a 20 20 79 79  ft in */.){.  yy
5900: 53 74 61 63 6b 45 6e 74 72 79 20 2a 79 79 74 6f  StackEntry *yyto
5910: 73 3b 0a 20 20 79 79 70 50 61 72 73 65 72 2d 3e  s;.  yypParser->
5920: 79 79 74 6f 73 2b 2b 3b 0a 23 69 66 64 65 66 20  yytos++;.#ifdef 
5930: 59 59 54 52 41 43 4b 4d 41 58 53 54 41 43 4b 44  YYTRACKMAXSTACKD
5940: 45 50 54 48 0a 20 20 69 66 28 20 28 69 6e 74 29  EPTH.  if( (int)
5950: 28 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74 6f  (yypParser->yyto
5960: 73 20 2d 20 79 79 70 50 61 72 73 65 72 2d 3e 79  s - yypParser->y
5970: 79 73 74 61 63 6b 29 3e 79 79 70 50 61 72 73 65  ystack)>yypParse
5980: 72 2d 3e 79 79 68 77 6d 20 29 7b 0a 20 20 20 20  r->yyhwm ){.    
5990: 79 79 70 50 61 72 73 65 72 2d 3e 79 79 68 77 6d  yypParser->yyhwm
59a0: 2b 2b 3b 0a 20 20 20 20 61 73 73 65 72 74 28 20  ++;.    assert( 
59b0: 79 79 70 50 61 72 73 65 72 2d 3e 79 79 68 77 6d  yypParser->yyhwm
59c0: 20 3d 3d 20 28 69 6e 74 29 28 79 79 70 50 61 72   == (int)(yypPar
59d0: 73 65 72 2d 3e 79 79 74 6f 73 20 2d 20 79 79 70  ser->yytos - yyp
59e0: 50 61 72 73 65 72 2d 3e 79 79 73 74 61 63 6b 29  Parser->yystack)
59f0: 20 29 3b 0a 20 20 7d 0a 23 65 6e 64 69 66 0a 23   );.  }.#endif.#
5a00: 69 66 20 59 59 53 54 41 43 4b 44 45 50 54 48 3e  if YYSTACKDEPTH>
5a10: 30 20 0a 20 20 69 66 28 20 79 79 70 50 61 72 73  0 .  if( yypPars
5a20: 65 72 2d 3e 79 79 74 6f 73 3e 79 79 70 50 61 72  er->yytos>yypPar
5a30: 73 65 72 2d 3e 79 79 73 74 61 63 6b 45 6e 64 20  ser->yystackEnd 
5a40: 29 7b 0a 20 20 20 20 79 79 70 50 61 72 73 65 72  ){.    yypParser
5a50: 2d 3e 79 79 74 6f 73 2d 2d 3b 0a 20 20 20 20 79  ->yytos--;.    y
5a60: 79 53 74 61 63 6b 4f 76 65 72 66 6c 6f 77 28 79  yStackOverflow(y
5a70: 79 70 50 61 72 73 65 72 29 3b 0a 20 20 20 20 72  ypParser);.    r
5a80: 65 74 75 72 6e 3b 0a 20 20 7d 0a 23 65 6c 73 65  eturn;.  }.#else
5a90: 0a 20 20 69 66 28 20 79 79 70 50 61 72 73 65 72  .  if( yypParser
5aa0: 2d 3e 79 79 74 6f 73 3e 3d 26 79 79 70 50 61 72  ->yytos>=&yypPar
5ab0: 73 65 72 2d 3e 79 79 73 74 61 63 6b 5b 79 79 70  ser->yystack[yyp
5ac0: 50 61 72 73 65 72 2d 3e 79 79 73 74 6b 73 7a 5d  Parser->yystksz]
5ad0: 20 29 7b 0a 20 20 20 20 69 66 28 20 79 79 47 72   ){.    if( yyGr
5ae0: 6f 77 53 74 61 63 6b 28 79 79 70 50 61 72 73 65  owStack(yypParse
5af0: 72 29 20 29 7b 0a 20 20 20 20 20 20 79 79 70 50  r) ){.      yypP
5b00: 61 72 73 65 72 2d 3e 79 79 74 6f 73 2d 2d 3b 0a  arser->yytos--;.
5b10: 20 20 20 20 20 20 79 79 53 74 61 63 6b 4f 76 65        yyStackOve
5b20: 72 66 6c 6f 77 28 79 79 70 50 61 72 73 65 72 29  rflow(yypParser)
5b30: 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 3b 0a  ;.      return;.
5b40: 20 20 20 20 7d 0a 20 20 7d 0a 23 65 6e 64 69 66      }.  }.#endif
5b50: 0a 20 20 69 66 28 20 79 79 4e 65 77 53 74 61 74  .  if( yyNewStat
5b60: 65 20 3e 20 59 59 5f 4d 41 58 5f 53 48 49 46 54  e > YY_MAX_SHIFT
5b70: 20 29 7b 0a 20 20 20 20 79 79 4e 65 77 53 74 61   ){.    yyNewSta
5b80: 74 65 20 2b 3d 20 59 59 5f 4d 49 4e 5f 52 45 44  te += YY_MIN_RED
5b90: 55 43 45 20 2d 20 59 59 5f 4d 49 4e 5f 53 48 49  UCE - YY_MIN_SHI
5ba0: 46 54 52 45 44 55 43 45 3b 0a 20 20 7d 0a 20 20  FTREDUCE;.  }.  
5bb0: 79 79 74 6f 73 20 3d 20 79 79 70 50 61 72 73 65  yytos = yypParse
5bc0: 72 2d 3e 79 79 74 6f 73 3b 0a 20 20 79 79 74 6f  r->yytos;.  yyto
5bd0: 73 2d 3e 73 74 61 74 65 6e 6f 20 3d 20 79 79 4e  s->stateno = yyN
5be0: 65 77 53 74 61 74 65 3b 0a 20 20 79 79 74 6f 73  ewState;.  yytos
5bf0: 2d 3e 6d 61 6a 6f 72 20 3d 20 79 79 4d 61 6a 6f  ->major = yyMajo
5c00: 72 3b 0a 20 20 79 79 74 6f 73 2d 3e 6d 69 6e 6f  r;.  yytos->mino
5c10: 72 2e 79 79 30 20 3d 20 79 79 4d 69 6e 6f 72 3b  r.yy0 = yyMinor;
5c20: 0a 20 20 79 79 54 72 61 63 65 53 68 69 66 74 28  .  yyTraceShift(
5c30: 79 79 70 50 61 72 73 65 72 2c 20 79 79 4e 65 77  yypParser, yyNew
5c40: 53 74 61 74 65 2c 20 22 53 68 69 66 74 22 29 3b  State, "Shift");
5c50: 0a 7d 0a 0a 2f 2a 20 54 68 65 20 66 6f 6c 6c 6f  .}../* The follo
5c60: 77 69 6e 67 20 74 61 62 6c 65 20 63 6f 6e 74 61  wing table conta
5c70: 69 6e 73 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 20  ins information 
5c80: 61 62 6f 75 74 20 65 76 65 72 79 20 72 75 6c 65  about every rule
5c90: 20 74 68 61 74 0a 2a 2a 20 69 73 20 75 73 65 64   that.** is used
5ca0: 20 64 75 72 69 6e 67 20 74 68 65 20 72 65 64 75   during the redu
5cb0: 63 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 63 6f  ce..*/.static co
5cc0: 6e 73 74 20 73 74 72 75 63 74 20 7b 0a 20 20 59  nst struct {.  Y
5cd0: 59 43 4f 44 45 54 59 50 45 20 6c 68 73 3b 20 20  YCODETYPE lhs;  
5ce0: 20 20 20 20 20 2f 2a 20 53 79 6d 62 6f 6c 20 6f       /* Symbol o
5cf0: 6e 20 74 68 65 20 6c 65 66 74 2d 68 61 6e 64 20  n the left-hand 
5d00: 73 69 64 65 20 6f 66 20 74 68 65 20 72 75 6c 65  side of the rule
5d10: 20 2a 2f 0a 20 20 73 69 67 6e 65 64 20 63 68 61   */.  signed cha
5d20: 72 20 6e 72 68 73 3b 20 20 20 20 20 2f 2a 20 4e  r nrhs;     /* N
5d30: 65 67 61 74 69 76 65 20 6f 66 20 74 68 65 20 6e  egative of the n
5d40: 75 6d 62 65 72 20 6f 66 20 52 48 53 20 73 79 6d  umber of RHS sym
5d50: 62 6f 6c 73 20 69 6e 20 74 68 65 20 72 75 6c 65  bols in the rule
5d60: 20 2a 2f 0a 7d 20 79 79 52 75 6c 65 49 6e 66 6f   */.} yyRuleInfo
5d70: 5b 5d 20 3d 20 7b 0a 25 25 0a 7d 3b 0a 0a 73 74  [] = {.%%.};..st
5d80: 61 74 69 63 20 76 6f 69 64 20 79 79 5f 61 63 63  atic void yy_acc
5d90: 65 70 74 28 79 79 50 61 72 73 65 72 2a 29 3b 20  ept(yyParser*); 
5da0: 20 2f 2a 20 46 6f 72 77 61 72 64 20 44 65 63 6c   /* Forward Decl
5db0: 61 72 61 74 69 6f 6e 20 2a 2f 0a 0a 2f 2a 0a 2a  aration */../*.*
5dc0: 2a 20 50 65 72 66 6f 72 6d 20 61 20 72 65 64 75  * Perform a redu
5dd0: 63 65 20 61 63 74 69 6f 6e 20 61 6e 64 20 74 68  ce action and th
5de0: 65 20 73 68 69 66 74 20 74 68 61 74 20 6d 75 73  e shift that mus
5df0: 74 20 69 6d 6d 65 64 69 61 74 65 6c 79 0a 2a 2a  t immediately.**
5e00: 20 66 6f 6c 6c 6f 77 20 74 68 65 20 72 65 64 75   follow the redu
5e10: 63 65 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20 79 79  ce..**.** The yy
5e20: 4c 6f 6f 6b 61 68 65 61 64 20 61 6e 64 20 79 79  Lookahead and yy
5e30: 4c 6f 6f 6b 61 68 65 61 64 54 6f 6b 65 6e 20 70  LookaheadToken p
5e40: 61 72 61 6d 65 74 65 72 73 20 70 72 6f 76 69 64  arameters provid
5e50: 65 20 72 65 64 75 63 65 20 61 63 74 69 6f 6e 73  e reduce actions
5e60: 0a 2a 2a 20 61 63 63 65 73 73 20 74 6f 20 74 68  .** access to th
5e70: 65 20 6c 6f 6f 6b 61 68 65 61 64 20 74 6f 6b 65  e lookahead toke
5e80: 6e 20 28 69 66 20 61 6e 79 29 2e 20 20 54 68 65  n (if any).  The
5e90: 20 79 79 4c 6f 6f 6b 61 68 65 61 64 20 77 69 6c   yyLookahead wil
5ea0: 6c 20 62 65 20 59 59 4e 4f 43 4f 44 45 0a 2a 2a  l be YYNOCODE.**
5eb0: 20 69 66 20 74 68 65 20 6c 6f 6f 6b 61 68 65 61   if the lookahea
5ec0: 64 20 74 6f 6b 65 6e 20 68 61 73 20 61 6c 72 65  d token has alre
5ed0: 61 64 79 20 62 65 65 6e 20 63 6f 6e 73 75 6d 65  ady been consume
5ee0: 64 2e 20 20 41 73 20 74 68 69 73 20 70 72 6f 63  d.  As this proc
5ef0: 65 64 75 72 65 20 69 73 0a 2a 2a 20 6f 6e 6c 79  edure is.** only
5f00: 20 63 61 6c 6c 65 64 20 66 72 6f 6d 20 6f 6e 65   called from one
5f10: 20 70 6c 61 63 65 2c 20 6f 70 74 69 6d 69 7a 69   place, optimizi
5f20: 6e 67 20 63 6f 6d 70 69 6c 65 72 73 20 77 69 6c  ng compilers wil
5f30: 6c 20 69 6e 2d 6c 69 6e 65 20 69 74 2c 20 77 68  l in-line it, wh
5f40: 69 63 68 0a 2a 2a 20 6d 65 61 6e 73 20 74 68 61  ich.** means tha
5f50: 74 20 74 68 65 20 65 78 74 72 61 20 70 61 72 61  t the extra para
5f60: 6d 65 74 65 72 73 20 68 61 76 65 20 6e 6f 20 70  meters have no p
5f70: 65 72 66 6f 72 6d 61 6e 63 65 20 69 6d 70 61 63  erformance impac
5f80: 74 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 59 59 41  t..*/.static YYA
5f90: 43 54 49 4f 4e 54 59 50 45 20 79 79 5f 72 65 64  CTIONTYPE yy_red
5fa0: 75 63 65 28 0a 20 20 79 79 50 61 72 73 65 72 20  uce(.  yyParser 
5fb0: 2a 79 79 70 50 61 72 73 65 72 2c 20 20 20 20 20  *yypParser,     
5fc0: 20 20 20 20 2f 2a 20 54 68 65 20 70 61 72 73 65      /* The parse
5fd0: 72 20 2a 2f 0a 20 20 75 6e 73 69 67 6e 65 64 20  r */.  unsigned 
5fe0: 69 6e 74 20 79 79 72 75 6c 65 6e 6f 2c 20 20 20  int yyruleno,   
5ff0: 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66      /* Number of
6000: 20 74 68 65 20 72 75 6c 65 20 62 79 20 77 68 69   the rule by whi
6010: 63 68 20 74 6f 20 72 65 64 75 63 65 20 2a 2f 0a  ch to reduce */.
6020: 20 20 69 6e 74 20 79 79 4c 6f 6f 6b 61 68 65 61    int yyLookahea
6030: 64 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  d,             /
6040: 2a 20 4c 6f 6f 6b 61 68 65 61 64 20 74 6f 6b 65  * Lookahead toke
6050: 6e 2c 20 6f 72 20 59 59 4e 4f 43 4f 44 45 20 69  n, or YYNOCODE i
6060: 66 20 6e 6f 6e 65 20 2a 2f 0a 20 20 50 61 72 73  f none */.  Pars
6070: 65 54 4f 4b 45 4e 54 59 50 45 20 79 79 4c 6f 6f  eTOKENTYPE yyLoo
6080: 6b 61 68 65 61 64 54 6f 6b 65 6e 20 20 2f 2a 20  kaheadToken  /* 
6090: 56 61 6c 75 65 20 6f 66 20 74 68 65 20 6c 6f 6f  Value of the loo
60a0: 6b 61 68 65 61 64 20 74 6f 6b 65 6e 20 2a 2f 0a  kahead token */.
60b0: 20 20 50 61 72 73 65 43 54 58 5f 50 44 45 43 4c    ParseCTX_PDECL
60c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
60d0: 20 20 20 2f 2a 20 25 65 78 74 72 61 5f 63 6f 6e     /* %extra_con
60e0: 74 65 78 74 20 2a 2f 0a 29 7b 0a 20 20 69 6e 74  text */.){.  int
60f0: 20 79 79 67 6f 74 6f 3b 20 20 20 20 20 20 20 20   yygoto;        
6100: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
6110: 54 68 65 20 6e 65 78 74 20 73 74 61 74 65 20 2a  The next state *
6120: 2f 0a 20 20 69 6e 74 20 79 79 61 63 74 3b 20 20  /.  int yyact;  
6130: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6140: 20 20 20 20 2f 2a 20 54 68 65 20 6e 65 78 74 20      /* The next 
6150: 61 63 74 69 6f 6e 20 2a 2f 0a 20 20 79 79 53 74  action */.  yySt
6160: 61 63 6b 45 6e 74 72 79 20 2a 79 79 6d 73 70 3b  ackEntry *yymsp;
6170: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54              /* T
6180: 68 65 20 74 6f 70 20 6f 66 20 74 68 65 20 70 61  he top of the pa
6190: 72 73 65 72 27 73 20 73 74 61 63 6b 20 2a 2f 0a  rser's stack */.
61a0: 20 20 69 6e 74 20 79 79 73 69 7a 65 3b 20 20 20    int yysize;   
61b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
61c0: 20 20 2f 2a 20 41 6d 6f 75 6e 74 20 74 6f 20 70    /* Amount to p
61d0: 6f 70 20 74 68 65 20 73 74 61 63 6b 20 2a 2f 0a  op the stack */.
61e0: 20 20 50 61 72 73 65 41 52 47 5f 46 45 54 43 48    ParseARG_FETCH
61f0: 0a 20 20 28 76 6f 69 64 29 79 79 4c 6f 6f 6b 61  .  (void)yyLooka
6200: 68 65 61 64 3b 0a 20 20 28 76 6f 69 64 29 79 79  head;.  (void)yy
6210: 4c 6f 6f 6b 61 68 65 61 64 54 6f 6b 65 6e 3b 0a  LookaheadToken;.
6220: 20 20 79 79 6d 73 70 20 3d 20 79 79 70 50 61 72    yymsp = yypPar
6230: 73 65 72 2d 3e 79 79 74 6f 73 3b 0a 23 69 66 6e  ser->yytos;.#ifn
6240: 64 65 66 20 4e 44 45 42 55 47 0a 20 20 69 66 28  def NDEBUG.  if(
6250: 20 79 79 54 72 61 63 65 46 49 4c 45 20 26 26 20   yyTraceFILE && 
6260: 79 79 72 75 6c 65 6e 6f 3c 28 69 6e 74 29 28 73  yyruleno<(int)(s
6270: 69 7a 65 6f 66 28 79 79 52 75 6c 65 4e 61 6d 65  izeof(yyRuleName
6280: 29 2f 73 69 7a 65 6f 66 28 79 79 52 75 6c 65 4e  )/sizeof(yyRuleN
6290: 61 6d 65 5b 30 5d 29 29 20 29 7b 0a 20 20 20 20  ame[0])) ){.    
62a0: 79 79 73 69 7a 65 20 3d 20 79 79 52 75 6c 65 49  yysize = yyRuleI
62b0: 6e 66 6f 5b 79 79 72 75 6c 65 6e 6f 5d 2e 6e 72  nfo[yyruleno].nr
62c0: 68 73 3b 0a 20 20 20 20 69 66 28 20 79 79 73 69  hs;.    if( yysi
62d0: 7a 65 20 29 7b 0a 20 20 20 20 20 20 66 70 72 69  ze ){.      fpri
62e0: 6e 74 66 28 79 79 54 72 61 63 65 46 49 4c 45 2c  ntf(yyTraceFILE,
62f0: 20 22 25 73 52 65 64 75 63 65 20 25 64 20 5b 25   "%sReduce %d [%
6300: 73 5d 2c 20 67 6f 20 74 6f 20 73 74 61 74 65 20  s], go to state 
6310: 25 64 2e 5c 6e 22 2c 0a 20 20 20 20 20 20 20 20  %d.\n",.        
6320: 79 79 54 72 61 63 65 50 72 6f 6d 70 74 2c 0a 20  yyTracePrompt,. 
6330: 20 20 20 20 20 20 20 79 79 72 75 6c 65 6e 6f 2c         yyruleno,
6340: 20 79 79 52 75 6c 65 4e 61 6d 65 5b 79 79 72 75   yyRuleName[yyru
6350: 6c 65 6e 6f 5d 2c 20 79 79 6d 73 70 5b 79 79 73  leno], yymsp[yys
6360: 69 7a 65 5d 2e 73 74 61 74 65 6e 6f 29 3b 0a 20  ize].stateno);. 
6370: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
6380: 66 70 72 69 6e 74 66 28 79 79 54 72 61 63 65 46  fprintf(yyTraceF
6390: 49 4c 45 2c 20 22 25 73 52 65 64 75 63 65 20 25  ILE, "%sReduce %
63a0: 64 20 5b 25 73 5d 2e 5c 6e 22 2c 0a 20 20 20 20  d [%s].\n",.    
63b0: 20 20 20 20 79 79 54 72 61 63 65 50 72 6f 6d 70      yyTracePromp
63c0: 74 2c 20 79 79 72 75 6c 65 6e 6f 2c 20 79 79 52  t, yyruleno, yyR
63d0: 75 6c 65 4e 61 6d 65 5b 79 79 72 75 6c 65 6e 6f  uleName[yyruleno
63e0: 5d 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 23 65  ]);.    }.  }.#e
63f0: 6e 64 69 66 20 2f 2a 20 4e 44 45 42 55 47 20 2a  ndif /* NDEBUG *
6400: 2f 0a 0a 20 20 2f 2a 20 43 68 65 63 6b 20 74 68  /..  /* Check th
6410: 61 74 20 74 68 65 20 73 74 61 63 6b 20 69 73 20  at the stack is 
6420: 6c 61 72 67 65 20 65 6e 6f 75 67 68 20 74 6f 20  large enough to 
6430: 67 72 6f 77 20 62 79 20 61 20 73 69 6e 67 6c 65  grow by a single
6440: 20 65 6e 74 72 79 0a 20 20 2a 2a 20 69 66 20 74   entry.  ** if t
6450: 68 65 20 52 48 53 20 6f 66 20 74 68 65 20 72 75  he RHS of the ru
6460: 6c 65 20 69 73 20 65 6d 70 74 79 2e 20 20 54 68  le is empty.  Th
6470: 69 73 20 65 6e 73 75 72 65 73 20 74 68 61 74 20  is ensures that 
6480: 74 68 65 72 65 20 69 73 20 72 6f 6f 6d 0a 20 20  there is room.  
6490: 2a 2a 20 65 6e 6f 75 67 68 20 6f 6e 20 74 68 65  ** enough on the
64a0: 20 73 74 61 63 6b 20 74 6f 20 70 75 73 68 20 74   stack to push t
64b0: 68 65 20 4c 48 53 20 76 61 6c 75 65 20 2a 2f 0a  he LHS value */.
64c0: 20 20 69 66 28 20 79 79 52 75 6c 65 49 6e 66 6f    if( yyRuleInfo
64d0: 5b 79 79 72 75 6c 65 6e 6f 5d 2e 6e 72 68 73 3d  [yyruleno].nrhs=
64e0: 3d 30 20 29 7b 0a 23 69 66 64 65 66 20 59 59 54  =0 ){.#ifdef YYT
64f0: 52 41 43 4b 4d 41 58 53 54 41 43 4b 44 45 50 54  RACKMAXSTACKDEPT
6500: 48 0a 20 20 20 20 69 66 28 20 28 69 6e 74 29 28  H.    if( (int)(
6510: 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74 6f 73  yypParser->yytos
6520: 20 2d 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79   - yypParser->yy
6530: 73 74 61 63 6b 29 3e 79 79 70 50 61 72 73 65 72  stack)>yypParser
6540: 2d 3e 79 79 68 77 6d 20 29 7b 0a 20 20 20 20 20  ->yyhwm ){.     
6550: 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79 68 77   yypParser->yyhw
6560: 6d 2b 2b 3b 0a 20 20 20 20 20 20 61 73 73 65 72  m++;.      asser
6570: 74 28 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79  t( yypParser->yy
6580: 68 77 6d 20 3d 3d 20 28 69 6e 74 29 28 79 79 70  hwm == (int)(yyp
6590: 50 61 72 73 65 72 2d 3e 79 79 74 6f 73 20 2d 20  Parser->yytos - 
65a0: 79 79 70 50 61 72 73 65 72 2d 3e 79 79 73 74 61  yypParser->yysta
65b0: 63 6b 29 29 3b 0a 20 20 20 20 7d 0a 23 65 6e 64  ck));.    }.#end
65c0: 69 66 0a 23 69 66 20 59 59 53 54 41 43 4b 44 45  if.#if YYSTACKDE
65d0: 50 54 48 3e 30 20 0a 20 20 20 20 69 66 28 20 79  PTH>0 .    if( y
65e0: 79 70 50 61 72 73 65 72 2d 3e 79 79 74 6f 73 3e  ypParser->yytos>
65f0: 3d 79 79 70 50 61 72 73 65 72 2d 3e 79 79 73 74  =yypParser->yyst
6600: 61 63 6b 45 6e 64 20 29 7b 0a 20 20 20 20 20 20  ackEnd ){.      
6610: 79 79 53 74 61 63 6b 4f 76 65 72 66 6c 6f 77 28  yyStackOverflow(
6620: 79 79 70 50 61 72 73 65 72 29 3b 0a 20 20 20 20  yypParser);.    
6630: 20 20 2f 2a 20 54 68 65 20 63 61 6c 6c 20 74 6f    /* The call to
6640: 20 79 79 53 74 61 63 6b 4f 76 65 72 66 6c 6f 77   yyStackOverflow
6650: 28 29 20 61 62 6f 76 65 20 70 6f 70 73 20 74 68  () above pops th
6660: 65 20 73 74 61 63 6b 20 75 6e 74 69 6c 20 69 74  e stack until it
6670: 20 69 73 0a 20 20 20 20 20 20 2a 2a 20 65 6d 70   is.      ** emp
6680: 74 79 2c 20 63 61 75 73 69 6e 67 20 74 68 65 20  ty, causing the 
6690: 6d 61 69 6e 20 70 61 72 73 65 72 20 6c 6f 6f 70  main parser loop
66a0: 20 74 6f 20 65 78 69 74 2e 20 20 53 6f 20 74 68   to exit.  So th
66b0: 65 20 72 65 74 75 72 6e 20 76 61 6c 75 65 0a 20  e return value. 
66c0: 20 20 20 20 20 2a 2a 20 69 73 20 6e 65 76 65 72       ** is never
66d0: 20 75 73 65 64 20 61 6e 64 20 64 6f 65 73 20 6e   used and does n
66e0: 6f 74 20 6d 61 74 74 65 72 2e 20 2a 2f 0a 20 20  ot matter. */.  
66f0: 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20      return 0;.  
6700: 20 20 7d 0a 23 65 6c 73 65 0a 20 20 20 20 69 66    }.#else.    if
6710: 28 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74  ( yypParser->yyt
6720: 6f 73 3e 3d 26 79 79 70 50 61 72 73 65 72 2d 3e  os>=&yypParser->
6730: 79 79 73 74 61 63 6b 5b 79 79 70 50 61 72 73 65  yystack[yypParse
6740: 72 2d 3e 79 79 73 74 6b 73 7a 2d 31 5d 20 29 7b  r->yystksz-1] ){
6750: 0a 20 20 20 20 20 20 69 66 28 20 79 79 47 72 6f  .      if( yyGro
6760: 77 53 74 61 63 6b 28 79 79 70 50 61 72 73 65 72  wStack(yypParser
6770: 29 20 29 7b 0a 20 20 20 20 20 20 20 20 79 79 53  ) ){.        yyS
6780: 74 61 63 6b 4f 76 65 72 66 6c 6f 77 28 79 79 70  tackOverflow(yyp
6790: 50 61 72 73 65 72 29 3b 0a 20 20 20 20 20 20 20  Parser);.       
67a0: 20 2f 2a 20 54 68 65 20 63 61 6c 6c 20 74 6f 20   /* The call to 
67b0: 79 79 53 74 61 63 6b 4f 76 65 72 66 6c 6f 77 28  yyStackOverflow(
67c0: 29 20 61 62 6f 76 65 20 70 6f 70 73 20 74 68 65  ) above pops the
67d0: 20 73 74 61 63 6b 20 75 6e 74 69 6c 20 69 74 20   stack until it 
67e0: 69 73 0a 20 20 20 20 20 20 20 20 2a 2a 20 65 6d  is.        ** em
67f0: 70 74 79 2c 20 63 61 75 73 69 6e 67 20 74 68 65  pty, causing the
6800: 20 6d 61 69 6e 20 70 61 72 73 65 72 20 6c 6f 6f   main parser loo
6810: 70 20 74 6f 20 65 78 69 74 2e 20 20 53 6f 20 74  p to exit.  So t
6820: 68 65 20 72 65 74 75 72 6e 20 76 61 6c 75 65 0a  he return value.
6830: 20 20 20 20 20 20 20 20 2a 2a 20 69 73 20 6e 65          ** is ne
6840: 76 65 72 20 75 73 65 64 20 61 6e 64 20 64 6f 65  ver used and doe
6850: 73 20 6e 6f 74 20 6d 61 74 74 65 72 2e 20 2a 2f  s not matter. */
6860: 0a 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20  .        return 
6870: 30 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  0;.      }.     
6880: 20 79 79 6d 73 70 20 3d 20 79 79 70 50 61 72 73   yymsp = yypPars
6890: 65 72 2d 3e 79 79 74 6f 73 3b 0a 20 20 20 20 7d  er->yytos;.    }
68a0: 0a 23 65 6e 64 69 66 0a 20 20 7d 0a 0a 20 20 73  .#endif.  }..  s
68b0: 77 69 74 63 68 28 20 79 79 72 75 6c 65 6e 6f 20  witch( yyruleno 
68c0: 29 7b 0a 20 20 2f 2a 20 42 65 67 69 6e 6e 69 6e  ){.  /* Beginnin
68d0: 67 20 68 65 72 65 20 61 72 65 20 74 68 65 20 72  g here are the r
68e0: 65 64 75 63 74 69 6f 6e 20 63 61 73 65 73 2e 20  eduction cases. 
68f0: 20 41 20 74 79 70 69 63 61 6c 20 65 78 61 6d 70   A typical examp
6900: 6c 65 0a 20 20 2a 2a 20 66 6f 6c 6c 6f 77 73 3a  le.  ** follows:
6910: 0a 20 20 2a 2a 20 20 20 63 61 73 65 20 30 3a 0a  .  **   case 0:.
6920: 20 20 2a 2a 20 20 23 6c 69 6e 65 20 3c 6c 69 6e    **  #line <lin
6930: 65 6e 6f 3e 20 3c 67 72 61 6d 6d 61 72 66 69 6c  eno> <grammarfil
6940: 65 3e 0a 20 20 2a 2a 20 20 20 20 20 7b 20 2e 2e  e>.  **     { ..
6950: 2e 20 7d 20 20 20 20 20 20 20 20 20 20 20 2f 2f  . }           //
6960: 20 55 73 65 72 20 73 75 70 70 6c 69 65 64 20 63   User supplied c
6970: 6f 64 65 0a 20 20 2a 2a 20 20 23 6c 69 6e 65 20  ode.  **  #line 
6980: 3c 6c 69 6e 65 6e 6f 3e 20 3c 74 68 69 73 66 69  <lineno> <thisfi
6990: 6c 65 3e 0a 20 20 2a 2a 20 20 20 20 20 62 72 65  le>.  **     bre
69a0: 61 6b 3b 0a 20 20 2a 2f 0a 2f 2a 2a 2a 2a 2a 2a  ak;.  */./******
69b0: 2a 2a 2a 2a 20 42 65 67 69 6e 20 72 65 64 75 63  **** Begin reduc
69c0: 65 20 61 63 74 69 6f 6e 73 20 2a 2a 2a 2a 2a 2a  e actions ******
69d0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
69e0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
69f0: 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a 25 25 0a 2f 2a 2a  ********/.%%./**
6a00: 2a 2a 2a 2a 2a 2a 2a 2a 20 45 6e 64 20 72 65 64  ******** End red
6a10: 75 63 65 20 61 63 74 69 6f 6e 73 20 2a 2a 2a 2a  uce actions ****
6a20: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
6a30: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
6a40: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a 20 20  ************/.  
6a50: 7d 3b 0a 20 20 61 73 73 65 72 74 28 20 79 79 72  };.  assert( yyr
6a60: 75 6c 65 6e 6f 3c 73 69 7a 65 6f 66 28 79 79 52  uleno<sizeof(yyR
6a70: 75 6c 65 49 6e 66 6f 29 2f 73 69 7a 65 6f 66 28  uleInfo)/sizeof(
6a80: 79 79 52 75 6c 65 49 6e 66 6f 5b 30 5d 29 20 29  yyRuleInfo[0]) )
6a90: 3b 0a 20 20 79 79 67 6f 74 6f 20 3d 20 79 79 52  ;.  yygoto = yyR
6aa0: 75 6c 65 49 6e 66 6f 5b 79 79 72 75 6c 65 6e 6f  uleInfo[yyruleno
6ab0: 5d 2e 6c 68 73 3b 0a 20 20 79 79 73 69 7a 65 20  ].lhs;.  yysize 
6ac0: 3d 20 79 79 52 75 6c 65 49 6e 66 6f 5b 79 79 72  = yyRuleInfo[yyr
6ad0: 75 6c 65 6e 6f 5d 2e 6e 72 68 73 3b 0a 20 20 79  uleno].nrhs;.  y
6ae0: 79 61 63 74 20 3d 20 79 79 5f 66 69 6e 64 5f 72  yact = yy_find_r
6af0: 65 64 75 63 65 5f 61 63 74 69 6f 6e 28 79 79 6d  educe_action(yym
6b00: 73 70 5b 79 79 73 69 7a 65 5d 2e 73 74 61 74 65  sp[yysize].state
6b10: 6e 6f 2c 28 59 59 43 4f 44 45 54 59 50 45 29 79  no,(YYCODETYPE)y
6b20: 79 67 6f 74 6f 29 3b 0a 0a 20 20 2f 2a 20 54 68  ygoto);..  /* Th
6b30: 65 72 65 20 61 72 65 20 6e 6f 20 53 48 49 46 54  ere are no SHIFT
6b40: 52 45 44 55 43 45 20 61 63 74 69 6f 6e 73 20 6f  REDUCE actions o
6b50: 6e 20 6e 6f 6e 74 65 72 6d 69 6e 61 6c 73 20 62  n nonterminals b
6b60: 65 63 61 75 73 65 20 74 68 65 20 74 61 62 6c 65  ecause the table
6b70: 0a 20 20 2a 2a 20 67 65 6e 65 72 61 74 6f 72 20  .  ** generator 
6b80: 68 61 73 20 73 69 6d 70 6c 69 66 69 65 64 20 74  has simplified t
6b90: 68 65 6d 20 74 6f 20 70 75 72 65 20 52 45 44 55  hem to pure REDU
6ba0: 43 45 20 61 63 74 69 6f 6e 73 2e 20 2a 2f 0a 20  CE actions. */. 
6bb0: 20 61 73 73 65 72 74 28 20 21 28 79 79 61 63 74   assert( !(yyact
6bc0: 3e 59 59 5f 4d 41 58 5f 53 48 49 46 54 20 26 26  >YY_MAX_SHIFT &&
6bd0: 20 79 79 61 63 74 3c 3d 59 59 5f 4d 41 58 5f 53   yyact<=YY_MAX_S
6be0: 48 49 46 54 52 45 44 55 43 45 29 20 29 3b 0a 0a  HIFTREDUCE) );..
6bf0: 20 20 2f 2a 20 49 74 20 69 73 20 6e 6f 74 20 70    /* It is not p
6c00: 6f 73 73 69 62 6c 65 20 66 6f 72 20 61 20 52 45  ossible for a RE
6c10: 44 55 43 45 20 74 6f 20 62 65 20 66 6f 6c 6c 6f  DUCE to be follo
6c20: 77 65 64 20 62 79 20 61 6e 20 65 72 72 6f 72 20  wed by an error 
6c30: 2a 2f 0a 20 20 61 73 73 65 72 74 28 20 79 79 61  */.  assert( yya
6c40: 63 74 21 3d 59 59 5f 45 52 52 4f 52 5f 41 43 54  ct!=YY_ERROR_ACT
6c50: 49 4f 4e 20 29 3b 0a 0a 20 20 79 79 6d 73 70 20  ION );..  yymsp 
6c60: 2b 3d 20 79 79 73 69 7a 65 2b 31 3b 0a 20 20 79  += yysize+1;.  y
6c70: 79 70 50 61 72 73 65 72 2d 3e 79 79 74 6f 73 20  ypParser->yytos 
6c80: 3d 20 79 79 6d 73 70 3b 0a 20 20 79 79 6d 73 70  = yymsp;.  yymsp
6c90: 2d 3e 73 74 61 74 65 6e 6f 20 3d 20 28 59 59 41  ->stateno = (YYA
6ca0: 43 54 49 4f 4e 54 59 50 45 29 79 79 61 63 74 3b  CTIONTYPE)yyact;
6cb0: 0a 20 20 79 79 6d 73 70 2d 3e 6d 61 6a 6f 72 20  .  yymsp->major 
6cc0: 3d 20 28 59 59 43 4f 44 45 54 59 50 45 29 79 79  = (YYCODETYPE)yy
6cd0: 67 6f 74 6f 3b 0a 20 20 79 79 54 72 61 63 65 53  goto;.  yyTraceS
6ce0: 68 69 66 74 28 79 79 70 50 61 72 73 65 72 2c 20  hift(yypParser, 
6cf0: 79 79 61 63 74 2c 20 22 2e 2e 2e 20 74 68 65 6e  yyact, "... then
6d00: 20 73 68 69 66 74 22 29 3b 0a 20 20 72 65 74 75   shift");.  retu
6d10: 72 6e 20 79 79 61 63 74 3b 0a 7d 0a 0a 2f 2a 0a  rn yyact;.}../*.
6d20: 2a 2a 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67  ** The following
6d30: 20 63 6f 64 65 20 65 78 65 63 75 74 65 73 20 77   code executes w
6d40: 68 65 6e 20 74 68 65 20 70 61 72 73 65 20 66 61  hen the parse fa
6d50: 69 6c 73 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 59  ils.*/.#ifndef Y
6d60: 59 4e 4f 45 52 52 4f 52 52 45 43 4f 56 45 52 59  YNOERRORRECOVERY
6d70: 0a 73 74 61 74 69 63 20 76 6f 69 64 20 79 79 5f  .static void yy_
6d80: 70 61 72 73 65 5f 66 61 69 6c 65 64 28 0a 20 20  parse_failed(.  
6d90: 79 79 50 61 72 73 65 72 20 2a 79 79 70 50 61 72  yyParser *yypPar
6da0: 73 65 72 20 20 20 20 20 20 20 20 20 20 20 2f 2a  ser           /*
6db0: 20 54 68 65 20 70 61 72 73 65 72 20 2a 2f 0a 29   The parser */.)
6dc0: 7b 0a 20 20 50 61 72 73 65 41 52 47 5f 46 45 54  {.  ParseARG_FET
6dd0: 43 48 0a 20 20 50 61 72 73 65 43 54 58 5f 46 45  CH.  ParseCTX_FE
6de0: 54 43 48 0a 23 69 66 6e 64 65 66 20 4e 44 45 42  TCH.#ifndef NDEB
6df0: 55 47 0a 20 20 69 66 28 20 79 79 54 72 61 63 65  UG.  if( yyTrace
6e00: 46 49 4c 45 20 29 7b 0a 20 20 20 20 66 70 72 69  FILE ){.    fpri
6e10: 6e 74 66 28 79 79 54 72 61 63 65 46 49 4c 45 2c  ntf(yyTraceFILE,
6e20: 22 25 73 46 61 69 6c 21 5c 6e 22 2c 79 79 54 72  "%sFail!\n",yyTr
6e30: 61 63 65 50 72 6f 6d 70 74 29 3b 0a 20 20 7d 0a  acePrompt);.  }.
6e40: 23 65 6e 64 69 66 0a 20 20 77 68 69 6c 65 28 20  #endif.  while( 
6e50: 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74 6f 73  yypParser->yytos
6e60: 3e 79 79 70 50 61 72 73 65 72 2d 3e 79 79 73 74  >yypParser->yyst
6e70: 61 63 6b 20 29 20 79 79 5f 70 6f 70 5f 70 61 72  ack ) yy_pop_par
6e80: 73 65 72 5f 73 74 61 63 6b 28 79 79 70 50 61 72  ser_stack(yypPar
6e90: 73 65 72 29 3b 0a 20 20 2f 2a 20 48 65 72 65 20  ser);.  /* Here 
6ea0: 63 6f 64 65 20 69 73 20 69 6e 73 65 72 74 65 64  code is inserted
6eb0: 20 77 68 69 63 68 20 77 69 6c 6c 20 62 65 20 65   which will be e
6ec0: 78 65 63 75 74 65 64 20 77 68 65 6e 65 76 65 72  xecuted whenever
6ed0: 20 74 68 65 0a 20 20 2a 2a 20 70 61 72 73 65 72   the.  ** parser
6ee0: 20 66 61 69 6c 73 20 2a 2f 0a 2f 2a 2a 2a 2a 2a   fails */./*****
6ef0: 2a 2a 2a 2a 2a 2a 2a 20 42 65 67 69 6e 20 25 70  ******* Begin %p
6f00: 61 72 73 65 5f 66 61 69 6c 75 72 65 20 63 6f 64  arse_failure cod
6f10: 65 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  e **************
6f20: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
6f30: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a 25 25 0a 2f 2a  *********/.%%./*
6f40: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 20 45 6e 64 20  *********** End 
6f50: 25 70 61 72 73 65 5f 66 61 69 6c 75 72 65 20 63  %parse_failure c
6f60: 6f 64 65 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ode ************
6f70: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
6f80: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a 20  *************/. 
6f90: 20 50 61 72 73 65 41 52 47 5f 53 54 4f 52 45 20   ParseARG_STORE 
6fa0: 2f 2a 20 53 75 70 70 72 65 73 73 20 77 61 72 6e  /* Suppress warn
6fb0: 69 6e 67 20 61 62 6f 75 74 20 75 6e 75 73 65 64  ing about unused
6fc0: 20 25 65 78 74 72 61 5f 61 72 67 75 6d 65 6e 74   %extra_argument
6fd0: 20 76 61 72 69 61 62 6c 65 20 2a 2f 0a 20 20 50   variable */.  P
6fe0: 61 72 73 65 43 54 58 5f 53 54 4f 52 45 0a 7d 0a  arseCTX_STORE.}.
6ff0: 23 65 6e 64 69 66 20 2f 2a 20 59 59 4e 4f 45 52  #endif /* YYNOER
7000: 52 4f 52 52 45 43 4f 56 45 52 59 20 2a 2f 0a 0a  RORRECOVERY */..
7010: 2f 2a 0a 2a 2a 20 54 68 65 20 66 6f 6c 6c 6f 77  /*.** The follow
7020: 69 6e 67 20 63 6f 64 65 20 65 78 65 63 75 74 65  ing code execute
7030: 73 20 77 68 65 6e 20 61 20 73 79 6e 74 61 78 20  s when a syntax 
7040: 65 72 72 6f 72 20 66 69 72 73 74 20 6f 63 63 75  error first occu
7050: 72 73 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f  rs..*/.static vo
7060: 69 64 20 79 79 5f 73 79 6e 74 61 78 5f 65 72 72  id yy_syntax_err
7070: 6f 72 28 0a 20 20 79 79 50 61 72 73 65 72 20 2a  or(.  yyParser *
7080: 79 79 70 50 61 72 73 65 72 2c 20 20 20 20 20 20  yypParser,      
7090: 20 20 20 20 20 2f 2a 20 54 68 65 20 70 61 72 73       /* The pars
70a0: 65 72 20 2a 2f 0a 20 20 69 6e 74 20 79 79 6d 61  er */.  int yyma
70b0: 6a 6f 72 2c 20 20 20 20 20 20 20 20 20 20 20 20  jor,            
70c0: 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20 6d 61         /* The ma
70d0: 6a 6f 72 20 74 79 70 65 20 6f 66 20 74 68 65 20  jor type of the 
70e0: 65 72 72 6f 72 20 74 6f 6b 65 6e 20 2a 2f 0a 20  error token */. 
70f0: 20 50 61 72 73 65 54 4f 4b 45 4e 54 59 50 45 20   ParseTOKENTYPE 
7100: 79 79 6d 69 6e 6f 72 20 20 20 20 20 20 20 20 20  yyminor         
7110: 2f 2a 20 54 68 65 20 6d 69 6e 6f 72 20 74 79 70  /* The minor typ
7120: 65 20 6f 66 20 74 68 65 20 65 72 72 6f 72 20 74  e of the error t
7130: 6f 6b 65 6e 20 2a 2f 0a 29 7b 0a 20 20 50 61 72  oken */.){.  Par
7140: 73 65 41 52 47 5f 46 45 54 43 48 0a 20 20 50 61  seARG_FETCH.  Pa
7150: 72 73 65 43 54 58 5f 46 45 54 43 48 0a 23 64 65  rseCTX_FETCH.#de
7160: 66 69 6e 65 20 54 4f 4b 45 4e 20 79 79 6d 69 6e  fine TOKEN yymin
7170: 6f 72 0a 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  or./************
7180: 20 42 65 67 69 6e 20 25 73 79 6e 74 61 78 5f 65   Begin %syntax_e
7190: 72 72 6f 72 20 63 6f 64 65 20 2a 2a 2a 2a 2a 2a  rror code ******
71a0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
71b0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
71c0: 2a 2a 2f 0a 25 25 0a 2f 2a 2a 2a 2a 2a 2a 2a 2a  **/.%%./********
71d0: 2a 2a 2a 2a 20 45 6e 64 20 25 73 79 6e 74 61 78  **** End %syntax
71e0: 5f 65 72 72 6f 72 20 63 6f 64 65 20 2a 2a 2a 2a  _error code ****
71f0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
7200: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
7210: 2a 2a 2a 2a 2a 2a 2f 0a 20 20 50 61 72 73 65 41  ******/.  ParseA
7220: 52 47 5f 53 54 4f 52 45 20 2f 2a 20 53 75 70 70  RG_STORE /* Supp
7230: 72 65 73 73 20 77 61 72 6e 69 6e 67 20 61 62 6f  ress warning abo
7240: 75 74 20 75 6e 75 73 65 64 20 25 65 78 74 72 61  ut unused %extra
7250: 5f 61 72 67 75 6d 65 6e 74 20 76 61 72 69 61 62  _argument variab
7260: 6c 65 20 2a 2f 0a 20 20 50 61 72 73 65 43 54 58  le */.  ParseCTX
7270: 5f 53 54 4f 52 45 0a 7d 0a 0a 2f 2a 0a 2a 2a 20  _STORE.}../*.** 
7280: 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 69 73  The following is
7290: 20 65 78 65 63 75 74 65 64 20 77 68 65 6e 20 74   executed when t
72a0: 68 65 20 70 61 72 73 65 72 20 61 63 63 65 70 74  he parser accept
72b0: 73 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64  s.*/.static void
72c0: 20 79 79 5f 61 63 63 65 70 74 28 0a 20 20 79 79   yy_accept(.  yy
72d0: 50 61 72 73 65 72 20 2a 79 79 70 50 61 72 73 65  Parser *yypParse
72e0: 72 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54  r           /* T
72f0: 68 65 20 70 61 72 73 65 72 20 2a 2f 0a 29 7b 0a  he parser */.){.
7300: 20 20 50 61 72 73 65 41 52 47 5f 46 45 54 43 48    ParseARG_FETCH
7310: 0a 20 20 50 61 72 73 65 43 54 58 5f 46 45 54 43  .  ParseCTX_FETC
7320: 48 0a 23 69 66 6e 64 65 66 20 4e 44 45 42 55 47  H.#ifndef NDEBUG
7330: 0a 20 20 69 66 28 20 79 79 54 72 61 63 65 46 49  .  if( yyTraceFI
7340: 4c 45 20 29 7b 0a 20 20 20 20 66 70 72 69 6e 74  LE ){.    fprint
7350: 66 28 79 79 54 72 61 63 65 46 49 4c 45 2c 22 25  f(yyTraceFILE,"%
7360: 73 41 63 63 65 70 74 21 5c 6e 22 2c 79 79 54 72  sAccept!\n",yyTr
7370: 61 63 65 50 72 6f 6d 70 74 29 3b 0a 20 20 7d 0a  acePrompt);.  }.
7380: 23 65 6e 64 69 66 0a 23 69 66 6e 64 65 66 20 59  #endif.#ifndef Y
7390: 59 4e 4f 45 52 52 4f 52 52 45 43 4f 56 45 52 59  YNOERRORRECOVERY
73a0: 0a 20 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79  .  yypParser->yy
73b0: 65 72 72 63 6e 74 20 3d 20 2d 31 3b 0a 23 65 6e  errcnt = -1;.#en
73c0: 64 69 66 0a 20 20 61 73 73 65 72 74 28 20 79 79  dif.  assert( yy
73d0: 70 50 61 72 73 65 72 2d 3e 79 79 74 6f 73 3d 3d  pParser->yytos==
73e0: 79 79 70 50 61 72 73 65 72 2d 3e 79 79 73 74 61  yypParser->yysta
73f0: 63 6b 20 29 3b 0a 20 20 2f 2a 20 48 65 72 65 20  ck );.  /* Here 
7400: 63 6f 64 65 20 69 73 20 69 6e 73 65 72 74 65 64  code is inserted
7410: 20 77 68 69 63 68 20 77 69 6c 6c 20 62 65 20 65   which will be e
7420: 78 65 63 75 74 65 64 20 77 68 65 6e 65 76 65 72  xecuted whenever
7430: 20 74 68 65 0a 20 20 2a 2a 20 70 61 72 73 65 72   the.  ** parser
7440: 20 61 63 63 65 70 74 73 20 2a 2f 0a 2f 2a 2a 2a   accepts */./***
7450: 2a 2a 2a 2a 2a 2a 2a 2a 20 42 65 67 69 6e 20 25  ******** Begin %
7460: 70 61 72 73 65 5f 61 63 63 65 70 74 20 63 6f 64  parse_accept cod
7470: 65 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  e **************
7480: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
7490: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a 25 25 0a  ***********/.%%.
74a0: 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 20 45 6e 64  /*********** End
74b0: 20 25 70 61 72 73 65 5f 61 63 63 65 70 74 20 63   %parse_accept c
74c0: 6f 64 65 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ode ************
74d0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
74e0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f  ***************/
74f0: 0a 20 20 50 61 72 73 65 41 52 47 5f 53 54 4f 52  .  ParseARG_STOR
7500: 45 20 2f 2a 20 53 75 70 70 72 65 73 73 20 77 61  E /* Suppress wa
7510: 72 6e 69 6e 67 20 61 62 6f 75 74 20 75 6e 75 73  rning about unus
7520: 65 64 20 25 65 78 74 72 61 5f 61 72 67 75 6d 65  ed %extra_argume
7530: 6e 74 20 76 61 72 69 61 62 6c 65 20 2a 2f 0a 20  nt variable */. 
7540: 20 50 61 72 73 65 43 54 58 5f 53 54 4f 52 45 0a   ParseCTX_STORE.
7550: 7d 0a 0a 2f 2a 20 54 68 65 20 6d 61 69 6e 20 70  }../* The main p
7560: 61 72 73 65 72 20 70 72 6f 67 72 61 6d 2e 0a 2a  arser program..*
7570: 2a 20 54 68 65 20 66 69 72 73 74 20 61 72 67 75  * The first argu
7580: 6d 65 6e 74 20 69 73 20 61 20 70 6f 69 6e 74 65  ment is a pointe
7590: 72 20 74 6f 20 61 20 73 74 72 75 63 74 75 72 65  r to a structure
75a0: 20 6f 62 74 61 69 6e 65 64 20 66 72 6f 6d 0a 2a   obtained from.*
75b0: 2a 20 22 50 61 72 73 65 41 6c 6c 6f 63 22 20 77  * "ParseAlloc" w
75c0: 68 69 63 68 20 64 65 73 63 72 69 62 65 73 20 74  hich describes t
75d0: 68 65 20 63 75 72 72 65 6e 74 20 73 74 61 74 65  he current state
75e0: 20 6f 66 20 74 68 65 20 70 61 72 73 65 72 2e 0a   of the parser..
75f0: 2a 2a 20 54 68 65 20 73 65 63 6f 6e 64 20 61 72  ** The second ar
7600: 67 75 6d 65 6e 74 20 69 73 20 74 68 65 20 6d 61  gument is the ma
7610: 6a 6f 72 20 74 6f 6b 65 6e 20 6e 75 6d 62 65 72  jor token number
7620: 2e 20 20 54 68 65 20 74 68 69 72 64 20 69 73 0a  .  The third is.
7630: 2a 2a 20 74 68 65 20 6d 69 6e 6f 72 20 74 6f 6b  ** the minor tok
7640: 65 6e 2e 20 20 54 68 65 20 66 6f 75 72 74 68 20  en.  The fourth 
7650: 6f 70 74 69 6f 6e 61 6c 20 61 72 67 75 6d 65 6e  optional argumen
7660: 74 20 69 73 20 77 68 61 74 65 76 65 72 20 74 68  t is whatever th
7670: 65 0a 2a 2a 20 75 73 65 72 20 77 61 6e 74 73 20  e.** user wants 
7680: 28 61 6e 64 20 73 70 65 63 69 66 69 65 64 20 69  (and specified i
7690: 6e 20 74 68 65 20 67 72 61 6d 6d 61 72 29 20 61  n the grammar) a
76a0: 6e 64 20 69 73 20 61 76 61 69 6c 61 62 6c 65 20  nd is available 
76b0: 66 6f 72 0a 2a 2a 20 75 73 65 20 62 79 20 74 68  for.** use by th
76c0: 65 20 61 63 74 69 6f 6e 20 72 6f 75 74 69 6e 65  e action routine
76d0: 73 2e 0a 2a 2a 0a 2a 2a 20 49 6e 70 75 74 73 3a  s..**.** Inputs:
76e0: 0a 2a 2a 20 3c 75 6c 3e 0a 2a 2a 20 3c 6c 69 3e  .** <ul>.** <li>
76f0: 20 41 20 70 6f 69 6e 74 65 72 20 74 6f 20 74 68   A pointer to th
7700: 65 20 70 61 72 73 65 72 20 28 61 6e 20 6f 70 61  e parser (an opa
7710: 71 75 65 20 73 74 72 75 63 74 75 72 65 2e 29 0a  que structure.).
7720: 2a 2a 20 3c 6c 69 3e 20 54 68 65 20 6d 61 6a 6f  ** <li> The majo
7730: 72 20 74 6f 6b 65 6e 20 6e 75 6d 62 65 72 2e 0a  r token number..
7740: 2a 2a 20 3c 6c 69 3e 20 54 68 65 20 6d 69 6e 6f  ** <li> The mino
7750: 72 20 74 6f 6b 65 6e 20 6e 75 6d 62 65 72 2e 0a  r token number..
7760: 2a 2a 20 3c 6c 69 3e 20 41 6e 20 6f 70 74 69 6f  ** <li> An optio
7770: 6e 20 61 72 67 75 6d 65 6e 74 20 6f 66 20 61 20  n argument of a 
7780: 67 72 61 6d 6d 61 72 2d 73 70 65 63 69 66 69 65  grammar-specifie
7790: 64 20 74 79 70 65 2e 0a 2a 2a 20 3c 2f 75 6c 3e  d type..** </ul>
77a0: 0a 2a 2a 0a 2a 2a 20 4f 75 74 70 75 74 73 3a 0a  .**.** Outputs:.
77b0: 2a 2a 20 4e 6f 6e 65 2e 0a 2a 2f 0a 76 6f 69 64  ** None..*/.void
77c0: 20 50 61 72 73 65 28 0a 20 20 76 6f 69 64 20 2a   Parse(.  void *
77d0: 79 79 70 2c 20 20 20 20 20 20 20 20 20 20 20 20  yyp,            
77e0: 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20 70 61         /* The pa
77f0: 72 73 65 72 20 2a 2f 0a 20 20 69 6e 74 20 79 79  rser */.  int yy
7800: 6d 61 6a 6f 72 2c 20 20 20 20 20 20 20 20 20 20  major,          
7810: 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20 6d 61         /* The ma
7820: 6a 6f 72 20 74 6f 6b 65 6e 20 63 6f 64 65 20 6e  jor token code n
7830: 75 6d 62 65 72 20 2a 2f 0a 20 20 50 61 72 73 65  umber */.  Parse
7840: 54 4f 4b 45 4e 54 59 50 45 20 79 79 6d 69 6e 6f  TOKENTYPE yymino
7850: 72 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20 76  r       /* The v
7860: 61 6c 75 65 20 66 6f 72 20 74 68 65 20 74 6f 6b  alue for the tok
7870: 65 6e 20 2a 2f 0a 20 20 50 61 72 73 65 41 52 47  en */.  ParseARG
7880: 5f 50 44 45 43 4c 20 20 20 20 20 20 20 20 20 20  _PDECL          
7890: 20 20 20 20 20 2f 2a 20 4f 70 74 69 6f 6e 61 6c       /* Optional
78a0: 20 25 65 78 74 72 61 5f 61 72 67 75 6d 65 6e 74   %extra_argument
78b0: 20 70 61 72 61 6d 65 74 65 72 20 2a 2f 0a 29 7b   parameter */.){
78c0: 0a 20 20 59 59 4d 49 4e 4f 52 54 59 50 45 20 79  .  YYMINORTYPE y
78d0: 79 6d 69 6e 6f 72 75 6e 69 6f 6e 3b 0a 20 20 59  yminorunion;.  Y
78e0: 59 41 43 54 49 4f 4e 54 59 50 45 20 79 79 61 63  YACTIONTYPE yyac
78f0: 74 3b 20 20 20 2f 2a 20 54 68 65 20 70 61 72 73  t;   /* The pars
7900: 65 72 20 61 63 74 69 6f 6e 2e 20 2a 2f 0a 23 69  er action. */.#i
7910: 66 20 21 64 65 66 69 6e 65 64 28 59 59 45 52 52  f !defined(YYERR
7920: 4f 52 53 59 4d 42 4f 4c 29 20 26 26 20 21 64 65  ORSYMBOL) && !de
7930: 66 69 6e 65 64 28 59 59 4e 4f 45 52 52 4f 52 52  fined(YYNOERRORR
7940: 45 43 4f 56 45 52 59 29 0a 20 20 69 6e 74 20 79  ECOVERY).  int y
7950: 79 65 6e 64 6f 66 69 6e 70 75 74 3b 20 20 20 20  yendofinput;    
7960: 20 2f 2a 20 54 72 75 65 20 69 66 20 77 65 20 61   /* True if we a
7970: 72 65 20 61 74 20 74 68 65 20 65 6e 64 20 6f 66  re at the end of
7980: 20 69 6e 70 75 74 20 2a 2f 0a 23 65 6e 64 69 66   input */.#endif
7990: 0a 23 69 66 64 65 66 20 59 59 45 52 52 4f 52 53  .#ifdef YYERRORS
79a0: 59 4d 42 4f 4c 0a 20 20 69 6e 74 20 79 79 65 72  YMBOL.  int yyer
79b0: 72 6f 72 68 69 74 20 3d 20 30 3b 20 20 20 2f 2a  rorhit = 0;   /*
79c0: 20 54 72 75 65 20 69 66 20 79 79 6d 61 6a 6f 72   True if yymajor
79d0: 20 68 61 73 20 69 6e 76 6f 6b 65 64 20 61 6e 20   has invoked an 
79e0: 65 72 72 6f 72 20 2a 2f 0a 23 65 6e 64 69 66 0a  error */.#endif.
79f0: 20 20 79 79 50 61 72 73 65 72 20 2a 79 79 70 50    yyParser *yypP
7a00: 61 72 73 65 72 20 3d 20 28 79 79 50 61 72 73 65  arser = (yyParse
7a10: 72 2a 29 79 79 70 3b 20 20 2f 2a 20 54 68 65 20  r*)yyp;  /* The 
7a20: 70 61 72 73 65 72 20 2a 2f 0a 20 20 50 61 72 73  parser */.  Pars
7a30: 65 43 54 58 5f 46 45 54 43 48 0a 20 20 50 61 72  eCTX_FETCH.  Par
7a40: 73 65 41 52 47 5f 53 54 4f 52 45 0a 0a 20 20 61  seARG_STORE..  a
7a50: 73 73 65 72 74 28 20 79 79 70 50 61 72 73 65 72  ssert( yypParser
7a60: 2d 3e 79 79 74 6f 73 21 3d 30 20 29 3b 0a 23 69  ->yytos!=0 );.#i
7a70: 66 20 21 64 65 66 69 6e 65 64 28 59 59 45 52 52  f !defined(YYERR
7a80: 4f 52 53 59 4d 42 4f 4c 29 20 26 26 20 21 64 65  ORSYMBOL) && !de
7a90: 66 69 6e 65 64 28 59 59 4e 4f 45 52 52 4f 52 52  fined(YYNOERRORR
7aa0: 45 43 4f 56 45 52 59 29 0a 20 20 79 79 65 6e 64  ECOVERY).  yyend
7ab0: 6f 66 69 6e 70 75 74 20 3d 20 28 79 79 6d 61 6a  ofinput = (yymaj
7ac0: 6f 72 3d 3d 30 29 3b 0a 23 65 6e 64 69 66 0a 0a  or==0);.#endif..
7ad0: 20 20 79 79 61 63 74 20 3d 20 79 79 70 50 61 72    yyact = yypPar
7ae0: 73 65 72 2d 3e 79 79 74 6f 73 2d 3e 73 74 61 74  ser->yytos->stat
7af0: 65 6e 6f 3b 0a 23 69 66 6e 64 65 66 20 4e 44 45  eno;.#ifndef NDE
7b00: 42 55 47 0a 20 20 69 66 28 20 79 79 54 72 61 63  BUG.  if( yyTrac
7b10: 65 46 49 4c 45 20 29 7b 0a 20 20 20 20 69 66 28  eFILE ){.    if(
7b20: 20 79 79 61 63 74 20 3c 20 59 59 5f 4d 49 4e 5f   yyact < YY_MIN_
7b30: 52 45 44 55 43 45 20 29 7b 0a 20 20 20 20 20 20  REDUCE ){.      
7b40: 66 70 72 69 6e 74 66 28 79 79 54 72 61 63 65 46  fprintf(yyTraceF
7b50: 49 4c 45 2c 22 25 73 49 6e 70 75 74 20 27 25 73  ILE,"%sInput '%s
7b60: 27 20 69 6e 20 73 74 61 74 65 20 25 64 5c 6e 22  ' in state %d\n"
7b70: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,.              
7b80: 79 79 54 72 61 63 65 50 72 6f 6d 70 74 2c 79 79  yyTracePrompt,yy
7b90: 54 6f 6b 65 6e 4e 61 6d 65 5b 79 79 6d 61 6a 6f  TokenName[yymajo
7ba0: 72 5d 2c 79 79 61 63 74 29 3b 0a 20 20 20 20 7d  r],yyact);.    }
7bb0: 65 6c 73 65 7b 0a 20 20 20 20 20 20 66 70 72 69  else{.      fpri
7bc0: 6e 74 66 28 79 79 54 72 61 63 65 46 49 4c 45 2c  ntf(yyTraceFILE,
7bd0: 22 25 73 49 6e 70 75 74 20 27 25 73 27 20 77 69  "%sInput '%s' wi
7be0: 74 68 20 70 65 6e 64 69 6e 67 20 72 65 64 75 63  th pending reduc
7bf0: 65 20 25 64 5c 6e 22 2c 0a 20 20 20 20 20 20 20  e %d\n",.       
7c00: 20 20 20 20 20 20 20 79 79 54 72 61 63 65 50 72         yyTracePr
7c10: 6f 6d 70 74 2c 79 79 54 6f 6b 65 6e 4e 61 6d 65  ompt,yyTokenName
7c20: 5b 79 79 6d 61 6a 6f 72 5d 2c 79 79 61 63 74 2d  [yymajor],yyact-
7c30: 59 59 5f 4d 49 4e 5f 52 45 44 55 43 45 29 3b 0a  YY_MIN_REDUCE);.
7c40: 20 20 20 20 7d 0a 20 20 7d 0a 23 65 6e 64 69 66      }.  }.#endif
7c50: 0a 0a 20 20 64 6f 7b 0a 20 20 20 20 61 73 73 65  ..  do{.    asse
7c60: 72 74 28 20 79 79 61 63 74 3d 3d 79 79 70 50 61  rt( yyact==yypPa
7c70: 72 73 65 72 2d 3e 79 79 74 6f 73 2d 3e 73 74 61  rser->yytos->sta
7c80: 74 65 6e 6f 20 29 3b 0a 20 20 20 20 79 79 61 63  teno );.    yyac
7c90: 74 20 3d 20 79 79 5f 66 69 6e 64 5f 73 68 69 66  t = yy_find_shif
7ca0: 74 5f 61 63 74 69 6f 6e 28 79 79 6d 61 6a 6f 72  t_action(yymajor
7cb0: 2c 79 79 61 63 74 29 3b 0a 20 20 20 20 69 66 28  ,yyact);.    if(
7cc0: 20 79 79 61 63 74 20 3e 3d 20 59 59 5f 4d 49 4e   yyact >= YY_MIN
7cd0: 5f 52 45 44 55 43 45 20 29 7b 0a 20 20 20 20 20  _REDUCE ){.     
7ce0: 20 79 79 61 63 74 20 3d 20 79 79 5f 72 65 64 75   yyact = yy_redu
7cf0: 63 65 28 79 79 70 50 61 72 73 65 72 2c 79 79 61  ce(yypParser,yya
7d00: 63 74 2d 59 59 5f 4d 49 4e 5f 52 45 44 55 43 45  ct-YY_MIN_REDUCE
7d10: 2c 79 79 6d 61 6a 6f 72 2c 0a 20 20 20 20 20 20  ,yymajor,.      
7d20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7d30: 20 20 79 79 6d 69 6e 6f 72 20 50 61 72 73 65 43    yyminor ParseC
7d40: 54 58 5f 50 41 52 41 4d 29 3b 0a 20 20 20 20 7d  TX_PARAM);.    }
7d50: 65 6c 73 65 20 69 66 28 20 79 79 61 63 74 20 3c  else if( yyact <
7d60: 3d 20 59 59 5f 4d 41 58 5f 53 48 49 46 54 52 45  = YY_MAX_SHIFTRE
7d70: 44 55 43 45 20 29 7b 0a 20 20 20 20 20 20 79 79  DUCE ){.      yy
7d80: 5f 73 68 69 66 74 28 79 79 70 50 61 72 73 65 72  _shift(yypParser
7d90: 2c 79 79 61 63 74 2c 79 79 6d 61 6a 6f 72 2c 79  ,yyact,yymajor,y
7da0: 79 6d 69 6e 6f 72 29 3b 0a 23 69 66 6e 64 65 66  yminor);.#ifndef
7db0: 20 59 59 4e 4f 45 52 52 4f 52 52 45 43 4f 56 45   YYNOERRORRECOVE
7dc0: 52 59 0a 20 20 20 20 20 20 79 79 70 50 61 72 73  RY.      yypPars
7dd0: 65 72 2d 3e 79 79 65 72 72 63 6e 74 2d 2d 3b 0a  er->yyerrcnt--;.
7de0: 23 65 6e 64 69 66 0a 20 20 20 20 20 20 62 72 65  #endif.      bre
7df0: 61 6b 3b 0a 20 20 20 20 7d 65 6c 73 65 20 69 66  ak;.    }else if
7e00: 28 20 79 79 61 63 74 3d 3d 59 59 5f 41 43 43 45  ( yyact==YY_ACCE
7e10: 50 54 5f 41 43 54 49 4f 4e 20 29 7b 0a 20 20 20  PT_ACTION ){.   
7e20: 20 20 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79     yypParser->yy
7e30: 74 6f 73 2d 2d 3b 0a 20 20 20 20 20 20 79 79 5f  tos--;.      yy_
7e40: 61 63 63 65 70 74 28 79 79 70 50 61 72 73 65 72  accept(yypParser
7e50: 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 3b  );.      return;
7e60: 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  .    }else{.    
7e70: 20 20 61 73 73 65 72 74 28 20 79 79 61 63 74 20    assert( yyact 
7e80: 3d 3d 20 59 59 5f 45 52 52 4f 52 5f 41 43 54 49  == YY_ERROR_ACTI
7e90: 4f 4e 20 29 3b 0a 20 20 20 20 20 20 79 79 6d 69  ON );.      yymi
7ea0: 6e 6f 72 75 6e 69 6f 6e 2e 79 79 30 20 3d 20 79  norunion.yy0 = y
7eb0: 79 6d 69 6e 6f 72 3b 0a 23 69 66 64 65 66 20 59  yminor;.#ifdef Y
7ec0: 59 45 52 52 4f 52 53 59 4d 42 4f 4c 0a 20 20 20  YERRORSYMBOL.   
7ed0: 20 20 20 69 6e 74 20 79 79 6d 78 3b 0a 23 65 6e     int yymx;.#en
7ee0: 64 69 66 0a 23 69 66 6e 64 65 66 20 4e 44 45 42  dif.#ifndef NDEB
7ef0: 55 47 0a 20 20 20 20 20 20 69 66 28 20 79 79 54  UG.      if( yyT
7f00: 72 61 63 65 46 49 4c 45 20 29 7b 0a 20 20 20 20  raceFILE ){.    
7f10: 20 20 20 20 66 70 72 69 6e 74 66 28 79 79 54 72      fprintf(yyTr
7f20: 61 63 65 46 49 4c 45 2c 22 25 73 53 79 6e 74 61  aceFILE,"%sSynta
7f30: 78 20 45 72 72 6f 72 21 5c 6e 22 2c 79 79 54 72  x Error!\n",yyTr
7f40: 61 63 65 50 72 6f 6d 70 74 29 3b 0a 20 20 20 20  acePrompt);.    
7f50: 20 20 7d 0a 23 65 6e 64 69 66 0a 23 69 66 64 65    }.#endif.#ifde
7f60: 66 20 59 59 45 52 52 4f 52 53 59 4d 42 4f 4c 0a  f YYERRORSYMBOL.
7f70: 20 20 20 20 20 20 2f 2a 20 41 20 73 79 6e 74 61        /* A synta
7f80: 78 20 65 72 72 6f 72 20 68 61 73 20 6f 63 63 75  x error has occu
7f90: 72 72 65 64 2e 0a 20 20 20 20 20 20 2a 2a 20 54  rred..      ** T
7fa0: 68 65 20 72 65 73 70 6f 6e 73 65 20 74 6f 20 61  he response to a
7fb0: 6e 20 65 72 72 6f 72 20 64 65 70 65 6e 64 73 20  n error depends 
7fc0: 75 70 6f 6e 20 77 68 65 74 68 65 72 20 6f 72 20  upon whether or 
7fd0: 6e 6f 74 20 74 68 65 0a 20 20 20 20 20 20 2a 2a  not the.      **
7fe0: 20 67 72 61 6d 6d 61 72 20 64 65 66 69 6e 65 73   grammar defines
7ff0: 20 61 6e 20 65 72 72 6f 72 20 74 6f 6b 65 6e 20   an error token 
8000: 22 45 52 52 4f 52 22 2e 20 20 0a 20 20 20 20 20  "ERROR".  .     
8010: 20 2a 2a 0a 20 20 20 20 20 20 2a 2a 20 54 68 69   **.      ** Thi
8020: 73 20 69 73 20 77 68 61 74 20 77 65 20 64 6f 20  s is what we do 
8030: 69 66 20 74 68 65 20 67 72 61 6d 6d 61 72 20 64  if the grammar d
8040: 6f 65 73 20 64 65 66 69 6e 65 20 45 52 52 4f 52  oes define ERROR
8050: 3a 0a 20 20 20 20 20 20 2a 2a 0a 20 20 20 20 20  :.      **.     
8060: 20 2a 2a 20 20 2a 20 43 61 6c 6c 20 74 68 65 20   **  * Call the 
8070: 25 73 79 6e 74 61 78 5f 65 72 72 6f 72 20 66 75  %syntax_error fu
8080: 6e 63 74 69 6f 6e 2e 0a 20 20 20 20 20 20 2a 2a  nction..      **
8090: 0a 20 20 20 20 20 20 2a 2a 20 20 2a 20 42 65 67  .      **  * Beg
80a0: 69 6e 20 70 6f 70 70 69 6e 67 20 74 68 65 20 73  in popping the s
80b0: 74 61 63 6b 20 75 6e 74 69 6c 20 77 65 20 65 6e  tack until we en
80c0: 74 65 72 20 61 20 73 74 61 74 65 20 77 68 65 72  ter a state wher
80d0: 65 0a 20 20 20 20 20 20 2a 2a 20 20 20 20 69 74  e.      **    it
80e0: 20 69 73 20 6c 65 67 61 6c 20 74 6f 20 73 68 69   is legal to shi
80f0: 66 74 20 74 68 65 20 65 72 72 6f 72 20 73 79 6d  ft the error sym
8100: 62 6f 6c 2c 20 74 68 65 6e 20 73 68 69 66 74 0a  bol, then shift.
8110: 20 20 20 20 20 20 2a 2a 20 20 20 20 74 68 65 20        **    the 
8120: 65 72 72 6f 72 20 73 79 6d 62 6f 6c 2e 0a 20 20  error symbol..  
8130: 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 2a 2a 20      **.      ** 
8140: 20 2a 20 53 65 74 20 74 68 65 20 65 72 72 6f 72   * Set the error
8150: 20 63 6f 75 6e 74 20 74 6f 20 74 68 72 65 65 2e   count to three.
8160: 0a 20 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20  .      **.      
8170: 2a 2a 20 20 2a 20 42 65 67 69 6e 20 61 63 63 65  **  * Begin acce
8180: 70 74 69 6e 67 20 61 6e 64 20 73 68 69 66 74 69  pting and shifti
8190: 6e 67 20 6e 65 77 20 74 6f 6b 65 6e 73 2e 20 20  ng new tokens.  
81a0: 4e 6f 20 6e 65 77 20 65 72 72 6f 72 0a 20 20 20  No new error.   
81b0: 20 20 20 2a 2a 20 20 20 20 70 72 6f 63 65 73 73     **    process
81c0: 69 6e 67 20 77 69 6c 6c 20 6f 63 63 75 72 20 75  ing will occur u
81d0: 6e 74 69 6c 20 74 68 72 65 65 20 74 6f 6b 65 6e  ntil three token
81e0: 73 20 68 61 76 65 20 62 65 65 6e 0a 20 20 20 20  s have been.    
81f0: 20 20 2a 2a 20 20 20 20 73 68 69 66 74 65 64 20    **    shifted 
8200: 73 75 63 63 65 73 73 66 75 6c 6c 79 2e 0a 20 20  successfully..  
8210: 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 2a 2f 0a      **.      */.
8220: 20 20 20 20 20 20 69 66 28 20 79 79 70 50 61 72        if( yypPar
8230: 73 65 72 2d 3e 79 79 65 72 72 63 6e 74 3c 30 20  ser->yyerrcnt<0 
8240: 29 7b 0a 20 20 20 20 20 20 20 20 79 79 5f 73 79  ){.        yy_sy
8250: 6e 74 61 78 5f 65 72 72 6f 72 28 79 79 70 50 61  ntax_error(yypPa
8260: 72 73 65 72 2c 79 79 6d 61 6a 6f 72 2c 79 79 6d  rser,yymajor,yym
8270: 69 6e 6f 72 29 3b 0a 20 20 20 20 20 20 7d 0a 20  inor);.      }. 
8280: 20 20 20 20 20 79 79 6d 78 20 3d 20 79 79 70 50       yymx = yypP
8290: 61 72 73 65 72 2d 3e 79 79 74 6f 73 2d 3e 6d 61  arser->yytos->ma
82a0: 6a 6f 72 3b 0a 20 20 20 20 20 20 69 66 28 20 79  jor;.      if( y
82b0: 79 6d 78 3d 3d 59 59 45 52 52 4f 52 53 59 4d 42  ymx==YYERRORSYMB
82c0: 4f 4c 20 7c 7c 20 79 79 65 72 72 6f 72 68 69 74  OL || yyerrorhit
82d0: 20 29 7b 0a 23 69 66 6e 64 65 66 20 4e 44 45 42   ){.#ifndef NDEB
82e0: 55 47 0a 20 20 20 20 20 20 20 20 69 66 28 20 79  UG.        if( y
82f0: 79 54 72 61 63 65 46 49 4c 45 20 29 7b 0a 20 20  yTraceFILE ){.  
8300: 20 20 20 20 20 20 20 20 66 70 72 69 6e 74 66 28          fprintf(
8310: 79 79 54 72 61 63 65 46 49 4c 45 2c 22 25 73 44  yyTraceFILE,"%sD
8320: 69 73 63 61 72 64 20 69 6e 70 75 74 20 74 6f 6b  iscard input tok
8330: 65 6e 20 25 73 5c 6e 22 2c 0a 20 20 20 20 20 20  en %s\n",.      
8340: 20 20 20 20 20 20 20 79 79 54 72 61 63 65 50 72         yyTracePr
8350: 6f 6d 70 74 2c 79 79 54 6f 6b 65 6e 4e 61 6d 65  ompt,yyTokenName
8360: 5b 79 79 6d 61 6a 6f 72 5d 29 3b 0a 20 20 20 20  [yymajor]);.    
8370: 20 20 20 20 7d 0a 23 65 6e 64 69 66 0a 20 20 20      }.#endif.   
8380: 20 20 20 20 20 79 79 5f 64 65 73 74 72 75 63 74       yy_destruct
8390: 6f 72 28 79 79 70 50 61 72 73 65 72 2c 20 28 59  or(yypParser, (Y
83a0: 59 43 4f 44 45 54 59 50 45 29 79 79 6d 61 6a 6f  YCODETYPE)yymajo
83b0: 72 2c 20 26 79 79 6d 69 6e 6f 72 75 6e 69 6f 6e  r, &yyminorunion
83c0: 29 3b 0a 20 20 20 20 20 20 20 20 79 79 6d 61 6a  );.        yymaj
83d0: 6f 72 20 3d 20 59 59 4e 4f 43 4f 44 45 3b 0a 20  or = YYNOCODE;. 
83e0: 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20       }else{.    
83f0: 20 20 20 20 77 68 69 6c 65 28 20 79 79 70 50 61      while( yypPa
8400: 72 73 65 72 2d 3e 79 79 74 6f 73 20 3e 3d 20 79  rser->yytos >= y
8410: 79 70 50 61 72 73 65 72 2d 3e 79 79 73 74 61 63  ypParser->yystac
8420: 6b 0a 20 20 20 20 20 20 20 20 20 20 20 20 26 26  k.            &&
8430: 20 79 79 6d 78 20 21 3d 20 59 59 45 52 52 4f 52   yymx != YYERROR
8440: 53 59 4d 42 4f 4c 0a 20 20 20 20 20 20 20 20 20  SYMBOL.         
8450: 20 20 20 26 26 20 28 79 79 61 63 74 20 3d 20 79     && (yyact = y
8460: 79 5f 66 69 6e 64 5f 72 65 64 75 63 65 5f 61 63  y_find_reduce_ac
8470: 74 69 6f 6e 28 0a 20 20 20 20 20 20 20 20 20 20  tion(.          
8480: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 79 79                yy
8490: 70 50 61 72 73 65 72 2d 3e 79 79 74 6f 73 2d 3e  pParser->yytos->
84a0: 73 74 61 74 65 6e 6f 2c 0a 20 20 20 20 20 20 20  stateno,.       
84b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
84c0: 20 59 59 45 52 52 4f 52 53 59 4d 42 4f 4c 29 29   YYERRORSYMBOL))
84d0: 20 3e 3d 20 59 59 5f 4d 49 4e 5f 52 45 44 55 43   >= YY_MIN_REDUC
84e0: 45 0a 20 20 20 20 20 20 20 20 29 7b 0a 20 20 20  E.        ){.   
84f0: 20 20 20 20 20 20 20 79 79 5f 70 6f 70 5f 70 61         yy_pop_pa
8500: 72 73 65 72 5f 73 74 61 63 6b 28 79 79 70 50 61  rser_stack(yypPa
8510: 72 73 65 72 29 3b 0a 20 20 20 20 20 20 20 20 7d  rser);.        }
8520: 0a 20 20 20 20 20 20 20 20 69 66 28 20 79 79 70  .        if( yyp
8530: 50 61 72 73 65 72 2d 3e 79 79 74 6f 73 20 3c 20  Parser->yytos < 
8540: 79 79 70 50 61 72 73 65 72 2d 3e 79 79 73 74 61  yypParser->yysta
8550: 63 6b 20 7c 7c 20 79 79 6d 61 6a 6f 72 3d 3d 30  ck || yymajor==0
8560: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 79 79   ){.          yy
8570: 5f 64 65 73 74 72 75 63 74 6f 72 28 79 79 70 50  _destructor(yypP
8580: 61 72 73 65 72 2c 28 59 59 43 4f 44 45 54 59 50  arser,(YYCODETYP
8590: 45 29 79 79 6d 61 6a 6f 72 2c 26 79 79 6d 69 6e  E)yymajor,&yymin
85a0: 6f 72 75 6e 69 6f 6e 29 3b 0a 20 20 20 20 20 20  orunion);.      
85b0: 20 20 20 20 79 79 5f 70 61 72 73 65 5f 66 61 69      yy_parse_fai
85c0: 6c 65 64 28 79 79 70 50 61 72 73 65 72 29 3b 0a  led(yypParser);.
85d0: 23 69 66 6e 64 65 66 20 59 59 4e 4f 45 52 52 4f  #ifndef YYNOERRO
85e0: 52 52 45 43 4f 56 45 52 59 0a 20 20 20 20 20 20  RRECOVERY.      
85f0: 20 20 20 20 79 79 70 50 61 72 73 65 72 2d 3e 79      yypParser->y
8600: 79 65 72 72 63 6e 74 20 3d 20 2d 31 3b 0a 23 65  yerrcnt = -1;.#e
8610: 6e 64 69 66 0a 20 20 20 20 20 20 20 20 20 20 79  ndif.          y
8620: 79 6d 61 6a 6f 72 20 3d 20 59 59 4e 4f 43 4f 44  ymajor = YYNOCOD
8630: 45 3b 0a 20 20 20 20 20 20 20 20 7d 65 6c 73 65  E;.        }else
8640: 20 69 66 28 20 79 79 6d 78 21 3d 59 59 45 52 52   if( yymx!=YYERR
8650: 4f 52 53 59 4d 42 4f 4c 20 29 7b 0a 20 20 20 20  ORSYMBOL ){.    
8660: 20 20 20 20 20 20 79 79 5f 73 68 69 66 74 28 79        yy_shift(y
8670: 79 70 50 61 72 73 65 72 2c 79 79 61 63 74 2c 59  ypParser,yyact,Y
8680: 59 45 52 52 4f 52 53 59 4d 42 4f 4c 2c 79 79 6d  YERRORSYMBOL,yym
8690: 69 6e 6f 72 29 3b 0a 20 20 20 20 20 20 20 20 7d  inor);.        }
86a0: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 79  .      }.      y
86b0: 79 70 50 61 72 73 65 72 2d 3e 79 79 65 72 72 63  ypParser->yyerrc
86c0: 6e 74 20 3d 20 33 3b 0a 20 20 20 20 20 20 79 79  nt = 3;.      yy
86d0: 65 72 72 6f 72 68 69 74 20 3d 20 31 3b 0a 20 20  errorhit = 1;.  
86e0: 20 20 20 20 69 66 28 20 79 79 6d 61 6a 6f 72 3d      if( yymajor=
86f0: 3d 59 59 4e 4f 43 4f 44 45 20 29 20 62 72 65 61  =YYNOCODE ) brea
8700: 6b 3b 0a 20 20 20 20 20 20 79 79 61 63 74 20 3d  k;.      yyact =
8710: 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74 6f   yypParser->yyto
8720: 73 2d 3e 73 74 61 74 65 6e 6f 3b 0a 23 65 6c 69  s->stateno;.#eli
8730: 66 20 64 65 66 69 6e 65 64 28 59 59 4e 4f 45 52  f defined(YYNOER
8740: 52 4f 52 52 45 43 4f 56 45 52 59 29 0a 20 20 20  RORRECOVERY).   
8750: 20 20 20 2f 2a 20 49 66 20 74 68 65 20 59 59 4e     /* If the YYN
8760: 4f 45 52 52 4f 52 52 45 43 4f 56 45 52 59 20 6d  OERRORRECOVERY m
8770: 61 63 72 6f 20 69 73 20 64 65 66 69 6e 65 64 2c  acro is defined,
8780: 20 74 68 65 6e 20 64 6f 20 6e 6f 74 20 61 74 74   then do not att
8790: 65 6d 70 74 20 74 6f 0a 20 20 20 20 20 20 2a 2a  empt to.      **
87a0: 20 64 6f 20 61 6e 79 20 6b 69 6e 64 20 6f 66 20   do any kind of 
87b0: 65 72 72 6f 72 20 72 65 63 6f 76 65 72 79 2e 20  error recovery. 
87c0: 20 49 6e 73 74 65 61 64 2c 20 73 69 6d 70 6c 79   Instead, simply
87d0: 20 69 6e 76 6f 6b 65 20 74 68 65 20 73 79 6e 74   invoke the synt
87e0: 61 78 0a 20 20 20 20 20 20 2a 2a 20 65 72 72 6f  ax.      ** erro
87f0: 72 20 72 6f 75 74 69 6e 65 20 61 6e 64 20 63 6f  r routine and co
8800: 6e 74 69 6e 75 65 20 67 6f 69 6e 67 20 61 73 20  ntinue going as 
8810: 69 66 20 6e 6f 74 68 69 6e 67 20 68 61 64 20 68  if nothing had h
8820: 61 70 70 65 6e 65 64 2e 0a 20 20 20 20 20 20 2a  appened..      *
8830: 2a 0a 20 20 20 20 20 20 2a 2a 20 41 70 70 6c 69  *.      ** Appli
8840: 63 61 74 69 6f 6e 73 20 63 61 6e 20 73 65 74 20  cations can set 
8850: 74 68 69 73 20 6d 61 63 72 6f 20 28 66 6f 72 20  this macro (for 
8860: 65 78 61 6d 70 6c 65 20 69 6e 73 69 64 65 20 25  example inside %
8870: 69 6e 63 6c 75 64 65 29 20 69 66 0a 20 20 20 20  include) if.    
8880: 20 20 2a 2a 20 74 68 65 79 20 69 6e 74 65 6e 64    ** they intend
8890: 20 74 6f 20 61 62 61 6e 64 6f 6e 20 74 68 65 20   to abandon the 
88a0: 70 61 72 73 65 20 75 70 6f 6e 20 74 68 65 20 66  parse upon the f
88b0: 69 72 73 74 20 73 79 6e 74 61 78 20 65 72 72 6f  irst syntax erro
88c0: 72 20 73 65 65 6e 2e 0a 20 20 20 20 20 20 2a 2f  r seen..      */
88d0: 0a 20 20 20 20 20 20 79 79 5f 73 79 6e 74 61 78  .      yy_syntax
88e0: 5f 65 72 72 6f 72 28 79 79 70 50 61 72 73 65 72  _error(yypParser
88f0: 2c 79 79 6d 61 6a 6f 72 2c 20 79 79 6d 69 6e 6f  ,yymajor, yymino
8900: 72 29 3b 0a 20 20 20 20 20 20 79 79 5f 64 65 73  r);.      yy_des
8910: 74 72 75 63 74 6f 72 28 79 79 70 50 61 72 73 65  tructor(yypParse
8920: 72 2c 28 59 59 43 4f 44 45 54 59 50 45 29 79 79  r,(YYCODETYPE)yy
8930: 6d 61 6a 6f 72 2c 26 79 79 6d 69 6e 6f 72 75 6e  major,&yyminorun
8940: 69 6f 6e 29 3b 0a 20 20 20 20 20 20 62 72 65 61  ion);.      brea
8950: 6b 3b 0a 23 65 6c 73 65 20 20 2f 2a 20 59 59 45  k;.#else  /* YYE
8960: 52 52 4f 52 53 59 4d 42 4f 4c 20 69 73 20 6e 6f  RRORSYMBOL is no
8970: 74 20 64 65 66 69 6e 65 64 20 2a 2f 0a 20 20 20  t defined */.   
8980: 20 20 20 2f 2a 20 54 68 69 73 20 69 73 20 77 68     /* This is wh
8990: 61 74 20 77 65 20 64 6f 20 69 66 20 74 68 65 20  at we do if the 
89a0: 67 72 61 6d 6d 61 72 20 64 6f 65 73 20 6e 6f 74  grammar does not
89b0: 20 64 65 66 69 6e 65 20 45 52 52 4f 52 3a 0a 20   define ERROR:. 
89c0: 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 2a 2a       **.      **
89d0: 20 20 2a 20 52 65 70 6f 72 74 20 61 6e 20 65 72    * Report an er
89e0: 72 6f 72 20 6d 65 73 73 61 67 65 2c 20 61 6e 64  ror message, and
89f0: 20 74 68 72 6f 77 20 61 77 61 79 20 74 68 65 20   throw away the 
8a00: 69 6e 70 75 74 20 74 6f 6b 65 6e 2e 0a 20 20 20  input token..   
8a10: 20 20 20 2a 2a 0a 20 20 20 20 20 20 2a 2a 20 20     **.      **  
8a20: 2a 20 49 66 20 74 68 65 20 69 6e 70 75 74 20 74  * If the input t
8a30: 6f 6b 65 6e 20 69 73 20 24 2c 20 74 68 65 6e 20  oken is $, then 
8a40: 66 61 69 6c 20 74 68 65 20 70 61 72 73 65 2e 0a  fail the parse..
8a50: 20 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 2a        **.      *
8a60: 2a 20 41 73 20 62 65 66 6f 72 65 2c 20 73 75 62  * As before, sub
8a70: 73 65 71 75 65 6e 74 20 65 72 72 6f 72 20 6d 65  sequent error me
8a80: 73 73 61 67 65 73 20 61 72 65 20 73 75 70 70 72  ssages are suppr
8a90: 65 73 73 65 64 20 75 6e 74 69 6c 0a 20 20 20 20  essed until.    
8aa0: 20 20 2a 2a 20 74 68 72 65 65 20 69 6e 70 75 74    ** three input
8ab0: 20 74 6f 6b 65 6e 73 20 68 61 76 65 20 62 65 65   tokens have bee
8ac0: 6e 20 73 75 63 63 65 73 73 66 75 6c 6c 79 20 73  n successfully s
8ad0: 68 69 66 74 65 64 2e 0a 20 20 20 20 20 20 2a 2f  hifted..      */
8ae0: 0a 20 20 20 20 20 20 69 66 28 20 79 79 70 50 61  .      if( yypPa
8af0: 72 73 65 72 2d 3e 79 79 65 72 72 63 6e 74 3c 3d  rser->yyerrcnt<=
8b00: 30 20 29 7b 0a 20 20 20 20 20 20 20 20 79 79 5f  0 ){.        yy_
8b10: 73 79 6e 74 61 78 5f 65 72 72 6f 72 28 79 79 70  syntax_error(yyp
8b20: 50 61 72 73 65 72 2c 79 79 6d 61 6a 6f 72 2c 20  Parser,yymajor, 
8b30: 79 79 6d 69 6e 6f 72 29 3b 0a 20 20 20 20 20 20  yyminor);.      
8b40: 7d 0a 20 20 20 20 20 20 79 79 70 50 61 72 73 65  }.      yypParse
8b50: 72 2d 3e 79 79 65 72 72 63 6e 74 20 3d 20 33 3b  r->yyerrcnt = 3;
8b60: 0a 20 20 20 20 20 20 79 79 5f 64 65 73 74 72 75  .      yy_destru
8b70: 63 74 6f 72 28 79 79 70 50 61 72 73 65 72 2c 28  ctor(yypParser,(
8b80: 59 59 43 4f 44 45 54 59 50 45 29 79 79 6d 61 6a  YYCODETYPE)yymaj
8b90: 6f 72 2c 26 79 79 6d 69 6e 6f 72 75 6e 69 6f 6e  or,&yyminorunion
8ba0: 29 3b 0a 20 20 20 20 20 20 69 66 28 20 79 79 65  );.      if( yye
8bb0: 6e 64 6f 66 69 6e 70 75 74 20 29 7b 0a 20 20 20  ndofinput ){.   
8bc0: 20 20 20 20 20 79 79 5f 70 61 72 73 65 5f 66 61       yy_parse_fa
8bd0: 69 6c 65 64 28 79 79 70 50 61 72 73 65 72 29 3b  iled(yypParser);
8be0: 0a 23 69 66 6e 64 65 66 20 59 59 4e 4f 45 52 52  .#ifndef YYNOERR
8bf0: 4f 52 52 45 43 4f 56 45 52 59 0a 20 20 20 20 20  ORRECOVERY.     
8c00: 20 20 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79     yypParser->yy
8c10: 65 72 72 63 6e 74 20 3d 20 2d 31 3b 0a 23 65 6e  errcnt = -1;.#en
8c20: 64 69 66 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  dif.      }.    
8c30: 20 20 62 72 65 61 6b 3b 0a 23 65 6e 64 69 66 0a    break;.#endif.
8c40: 20 20 20 20 7d 0a 20 20 7d 77 68 69 6c 65 28 20      }.  }while( 
8c50: 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74 6f 73  yypParser->yytos
8c60: 3e 79 79 70 50 61 72 73 65 72 2d 3e 79 79 73 74  >yypParser->yyst
8c70: 61 63 6b 20 29 3b 0a 23 69 66 6e 64 65 66 20 4e  ack );.#ifndef N
8c80: 44 45 42 55 47 0a 20 20 69 66 28 20 79 79 54 72  DEBUG.  if( yyTr
8c90: 61 63 65 46 49 4c 45 20 29 7b 0a 20 20 20 20 79  aceFILE ){.    y
8ca0: 79 53 74 61 63 6b 45 6e 74 72 79 20 2a 69 3b 0a  yStackEntry *i;.
8cb0: 20 20 20 20 63 68 61 72 20 63 44 69 76 20 3d 20      char cDiv = 
8cc0: 27 5b 27 3b 0a 20 20 20 20 66 70 72 69 6e 74 66  '[';.    fprintf
8cd0: 28 79 79 54 72 61 63 65 46 49 4c 45 2c 22 25 73  (yyTraceFILE,"%s
8ce0: 52 65 74 75 72 6e 2e 20 53 74 61 63 6b 3d 22 2c  Return. Stack=",
8cf0: 79 79 54 72 61 63 65 50 72 6f 6d 70 74 29 3b 0a  yyTracePrompt);.
8d00: 20 20 20 20 66 6f 72 28 69 3d 26 79 79 70 50 61      for(i=&yypPa
8d10: 72 73 65 72 2d 3e 79 79 73 74 61 63 6b 5b 31 5d  rser->yystack[1]
8d20: 3b 20 69 3c 3d 79 79 70 50 61 72 73 65 72 2d 3e  ; i<=yypParser->
8d30: 79 79 74 6f 73 3b 20 69 2b 2b 29 7b 0a 20 20 20  yytos; i++){.   
8d40: 20 20 20 66 70 72 69 6e 74 66 28 79 79 54 72 61     fprintf(yyTra
8d50: 63 65 46 49 4c 45 2c 22 25 63 25 73 22 2c 20 63  ceFILE,"%c%s", c
8d60: 44 69 76 2c 20 79 79 54 6f 6b 65 6e 4e 61 6d 65  Div, yyTokenName
8d70: 5b 69 2d 3e 6d 61 6a 6f 72 5d 29 3b 0a 20 20 20  [i->major]);.   
8d80: 20 20 20 63 44 69 76 20 3d 20 27 20 27 3b 0a 20     cDiv = ' ';. 
8d90: 20 20 20 7d 0a 20 20 20 20 66 70 72 69 6e 74 66     }.    fprintf
8da0: 28 79 79 54 72 61 63 65 46 49 4c 45 2c 22 5d 5c  (yyTraceFILE,"]\
8db0: 6e 22 29 3b 0a 20 20 7d 0a 23 65 6e 64 69 66 0a  n");.  }.#endif.
8dc0: 20 20 72 65 74 75 72 6e 3b 0a 7d 0a 0a 2f 2a 0a    return;.}../*.
8dd0: 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20 66 61  ** Return the fa
8de0: 6c 6c 62 61 63 6b 20 74 6f 6b 65 6e 20 63 6f 72  llback token cor
8df0: 72 65 73 70 6f 6e 64 69 6e 67 20 74 6f 20 63 61  responding to ca
8e00: 6e 6f 6e 69 63 61 6c 20 74 6f 6b 65 6e 20 69 54  nonical token iT
8e10: 6f 6b 65 6e 2c 20 6f 72 0a 2a 2a 20 30 20 69 66  oken, or.** 0 if
8e20: 20 69 54 6f 6b 65 6e 20 68 61 73 20 6e 6f 20 66   iToken has no f
8e30: 61 6c 6c 62 61 63 6b 2e 0a 2a 2f 0a 69 6e 74 20  allback..*/.int 
8e40: 50 61 72 73 65 46 61 6c 6c 62 61 63 6b 28 69 6e  ParseFallback(in
8e50: 74 20 69 54 6f 6b 65 6e 29 7b 0a 23 69 66 64 65  t iToken){.#ifde
8e60: 66 20 59 59 46 41 4c 4c 42 41 43 4b 0a 20 20 69  f YYFALLBACK.  i
8e70: 66 28 20 69 54 6f 6b 65 6e 3c 28 69 6e 74 29 28  f( iToken<(int)(
8e80: 73 69 7a 65 6f 66 28 79 79 46 61 6c 6c 62 61 63  sizeof(yyFallbac
8e90: 6b 29 2f 73 69 7a 65 6f 66 28 79 79 46 61 6c 6c  k)/sizeof(yyFall
8ea0: 62 61 63 6b 5b 30 5d 29 29 20 29 7b 0a 20 20 20  back[0])) ){.   
8eb0: 20 72 65 74 75 72 6e 20 79 79 46 61 6c 6c 62 61   return yyFallba
8ec0: 63 6b 5b 69 54 6f 6b 65 6e 5d 3b 0a 20 20 7d 0a  ck[iToken];.  }.
8ed0: 23 65 6c 73 65 0a 20 20 28 76 6f 69 64 29 69 54  #else.  (void)iT
8ee0: 6f 6b 65 6e 3b 0a 23 65 6e 64 69 66 0a 20 20 72  oken;.#endif.  r
8ef0: 65 74 75 72 6e 20 30 3b 0a 7d 0a                 eturn 0;.}.