/ Hex Artifact Content
Login

Artifact 6020ce61dd7a536a3866952eb1e616c7e8b14b8f623368ed5a98f0639cedf048:


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 59 59 41 43 54  .*/.static YYACT
5060: 49 4f 4e 54 59 50 45 20 79 79 5f 66 69 6e 64 5f  IONTYPE yy_find_
5070: 72 65 64 75 63 65 5f 61 63 74 69 6f 6e 28 0a 20  reduce_action(. 
5080: 20 59 59 41 43 54 49 4f 4e 54 59 50 45 20 73 74   YYACTIONTYPE st
5090: 61 74 65 6e 6f 2c 20 20 20 20 20 2f 2a 20 43 75  ateno,     /* Cu
50a0: 72 72 65 6e 74 20 73 74 61 74 65 20 6e 75 6d 62  rrent state numb
50b0: 65 72 20 2a 2f 0a 20 20 59 59 43 4f 44 45 54 59  er */.  YYCODETY
50c0: 50 45 20 69 4c 6f 6f 6b 41 68 65 61 64 20 20 20  PE iLookAhead   
50d0: 20 20 2f 2a 20 54 68 65 20 6c 6f 6f 6b 2d 61 68    /* The look-ah
50e0: 65 61 64 20 74 6f 6b 65 6e 20 2a 2f 0a 29 7b 0a  ead token */.){.
50f0: 20 20 69 6e 74 20 69 3b 0a 23 69 66 64 65 66 20    int i;.#ifdef 
5100: 59 59 45 52 52 4f 52 53 59 4d 42 4f 4c 0a 20 20  YYERRORSYMBOL.  
5110: 69 66 28 20 73 74 61 74 65 6e 6f 3e 59 59 5f 52  if( stateno>YY_R
5120: 45 44 55 43 45 5f 43 4f 55 4e 54 20 29 7b 0a 20  EDUCE_COUNT ){. 
5130: 20 20 20 72 65 74 75 72 6e 20 79 79 5f 64 65 66     return yy_def
5140: 61 75 6c 74 5b 73 74 61 74 65 6e 6f 5d 3b 0a 20  ault[stateno];. 
5150: 20 7d 0a 23 65 6c 73 65 0a 20 20 61 73 73 65 72   }.#else.  asser
5160: 74 28 20 73 74 61 74 65 6e 6f 3c 3d 59 59 5f 52  t( stateno<=YY_R
5170: 45 44 55 43 45 5f 43 4f 55 4e 54 20 29 3b 0a 23  EDUCE_COUNT );.#
5180: 65 6e 64 69 66 0a 20 20 69 20 3d 20 79 79 5f 72  endif.  i = yy_r
5190: 65 64 75 63 65 5f 6f 66 73 74 5b 73 74 61 74 65  educe_ofst[state
51a0: 6e 6f 5d 3b 0a 20 20 61 73 73 65 72 74 28 20 69  no];.  assert( i
51b0: 4c 6f 6f 6b 41 68 65 61 64 21 3d 59 59 4e 4f 43  LookAhead!=YYNOC
51c0: 4f 44 45 20 29 3b 0a 20 20 69 20 2b 3d 20 69 4c  ODE );.  i += iL
51d0: 6f 6f 6b 41 68 65 61 64 3b 0a 23 69 66 64 65 66  ookAhead;.#ifdef
51e0: 20 59 59 45 52 52 4f 52 53 59 4d 42 4f 4c 0a 20   YYERRORSYMBOL. 
51f0: 20 69 66 28 20 69 3c 30 20 7c 7c 20 69 3e 3d 59   if( i<0 || i>=Y
5200: 59 5f 41 43 54 54 41 42 5f 43 4f 55 4e 54 20 7c  Y_ACTTAB_COUNT |
5210: 7c 20 79 79 5f 6c 6f 6f 6b 61 68 65 61 64 5b 69  | yy_lookahead[i
5220: 5d 21 3d 69 4c 6f 6f 6b 41 68 65 61 64 20 29 7b  ]!=iLookAhead ){
5230: 0a 20 20 20 20 72 65 74 75 72 6e 20 79 79 5f 64  .    return yy_d
5240: 65 66 61 75 6c 74 5b 73 74 61 74 65 6e 6f 5d 3b  efault[stateno];
5250: 0a 20 20 7d 0a 23 65 6c 73 65 0a 20 20 61 73 73  .  }.#else.  ass
5260: 65 72 74 28 20 69 3e 3d 30 20 26 26 20 69 3c 59  ert( i>=0 && i<Y
5270: 59 5f 41 43 54 54 41 42 5f 43 4f 55 4e 54 20 29  Y_ACTTAB_COUNT )
5280: 3b 0a 20 20 61 73 73 65 72 74 28 20 79 79 5f 6c  ;.  assert( yy_l
5290: 6f 6f 6b 61 68 65 61 64 5b 69 5d 3d 3d 69 4c 6f  ookahead[i]==iLo
52a0: 6f 6b 41 68 65 61 64 20 29 3b 0a 23 65 6e 64 69  okAhead );.#endi
52b0: 66 0a 20 20 72 65 74 75 72 6e 20 79 79 5f 61 63  f.  return yy_ac
52c0: 74 69 6f 6e 5b 69 5d 3b 0a 7d 0a 0a 2f 2a 0a 2a  tion[i];.}../*.*
52d0: 2a 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20  * The following 
52e0: 72 6f 75 74 69 6e 65 20 69 73 20 63 61 6c 6c 65  routine is calle
52f0: 64 20 69 66 20 74 68 65 20 73 74 61 63 6b 20 6f  d if the stack o
5300: 76 65 72 66 6c 6f 77 73 2e 0a 2a 2f 0a 73 74 61  verflows..*/.sta
5310: 74 69 63 20 76 6f 69 64 20 79 79 53 74 61 63 6b  tic void yyStack
5320: 4f 76 65 72 66 6c 6f 77 28 79 79 50 61 72 73 65  Overflow(yyParse
5330: 72 20 2a 79 79 70 50 61 72 73 65 72 29 7b 0a 20  r *yypParser){. 
5340: 20 20 50 61 72 73 65 41 52 47 5f 46 45 54 43 48    ParseARG_FETCH
5350: 0a 20 20 20 50 61 72 73 65 43 54 58 5f 46 45 54  .   ParseCTX_FET
5360: 43 48 0a 23 69 66 6e 64 65 66 20 4e 44 45 42 55  CH.#ifndef NDEBU
5370: 47 0a 20 20 20 69 66 28 20 79 79 54 72 61 63 65  G.   if( yyTrace
5380: 46 49 4c 45 20 29 7b 0a 20 20 20 20 20 66 70 72  FILE ){.     fpr
5390: 69 6e 74 66 28 79 79 54 72 61 63 65 46 49 4c 45  intf(yyTraceFILE
53a0: 2c 22 25 73 53 74 61 63 6b 20 4f 76 65 72 66 6c  ,"%sStack Overfl
53b0: 6f 77 21 5c 6e 22 2c 79 79 54 72 61 63 65 50 72  ow!\n",yyTracePr
53c0: 6f 6d 70 74 29 3b 0a 20 20 20 7d 0a 23 65 6e 64  ompt);.   }.#end
53d0: 69 66 0a 20 20 20 77 68 69 6c 65 28 20 79 79 70  if.   while( yyp
53e0: 50 61 72 73 65 72 2d 3e 79 79 74 6f 73 3e 79 79  Parser->yytos>yy
53f0: 70 50 61 72 73 65 72 2d 3e 79 79 73 74 61 63 6b  pParser->yystack
5400: 20 29 20 79 79 5f 70 6f 70 5f 70 61 72 73 65 72   ) yy_pop_parser
5410: 5f 73 74 61 63 6b 28 79 79 70 50 61 72 73 65 72  _stack(yypParser
5420: 29 3b 0a 20 20 20 2f 2a 20 48 65 72 65 20 63 6f  );.   /* Here co
5430: 64 65 20 69 73 20 69 6e 73 65 72 74 65 64 20 77  de is inserted w
5440: 68 69 63 68 20 77 69 6c 6c 20 65 78 65 63 75 74  hich will execut
5450: 65 20 69 66 20 74 68 65 20 70 61 72 73 65 72 0a  e if the parser.
5460: 20 20 20 2a 2a 20 73 74 61 63 6b 20 65 76 65 72     ** stack ever
5470: 79 20 6f 76 65 72 66 6c 6f 77 73 20 2a 2f 0a 2f  y overflows */./
5480: 2a 2a 2a 2a 2a 2a 2a 2a 20 42 65 67 69 6e 20 25  ******** Begin %
5490: 73 74 61 63 6b 5f 6f 76 65 72 66 6c 6f 77 20 63  stack_overflow c
54a0: 6f 64 65 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ode ************
54b0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
54c0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a  **************/.
54d0: 25 25 0a 2f 2a 2a 2a 2a 2a 2a 2a 2a 20 45 6e 64  %%./******** End
54e0: 20 25 73 74 61 63 6b 5f 6f 76 65 72 66 6c 6f 77   %stack_overflow
54f0: 20 63 6f 64 65 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a   code **********
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 2a 2a 2a 2a 2a 2a 2a  ****************
5520: 2a 2a 2f 0a 20 20 20 50 61 72 73 65 41 52 47 5f  **/.   ParseARG_
5530: 53 54 4f 52 45 20 2f 2a 20 53 75 70 70 72 65 73  STORE /* Suppres
5540: 73 20 77 61 72 6e 69 6e 67 20 61 62 6f 75 74 20  s warning about 
5550: 75 6e 75 73 65 64 20 25 65 78 74 72 61 5f 61 72  unused %extra_ar
5560: 67 75 6d 65 6e 74 20 76 61 72 20 2a 2f 0a 20 20  gument var */.  
5570: 20 50 61 72 73 65 43 54 58 5f 53 54 4f 52 45 0a   ParseCTX_STORE.
5580: 7d 0a 0a 2f 2a 0a 2a 2a 20 50 72 69 6e 74 20 74  }../*.** Print t
5590: 72 61 63 69 6e 67 20 69 6e 66 6f 72 6d 61 74 69  racing informati
55a0: 6f 6e 20 66 6f 72 20 61 20 53 48 49 46 54 20 61  on for a SHIFT a
55b0: 63 74 69 6f 6e 0a 2a 2f 0a 23 69 66 6e 64 65 66  ction.*/.#ifndef
55c0: 20 4e 44 45 42 55 47 0a 73 74 61 74 69 63 20 76   NDEBUG.static v
55d0: 6f 69 64 20 79 79 54 72 61 63 65 53 68 69 66 74  oid yyTraceShift
55e0: 28 79 79 50 61 72 73 65 72 20 2a 79 79 70 50 61  (yyParser *yypPa
55f0: 72 73 65 72 2c 20 69 6e 74 20 79 79 4e 65 77 53  rser, int yyNewS
5600: 74 61 74 65 2c 20 63 6f 6e 73 74 20 63 68 61 72  tate, const char
5610: 20 2a 7a 54 61 67 29 7b 0a 20 20 69 66 28 20 79   *zTag){.  if( y
5620: 79 54 72 61 63 65 46 49 4c 45 20 29 7b 0a 20 20  yTraceFILE ){.  
5630: 20 20 69 66 28 20 79 79 4e 65 77 53 74 61 74 65    if( yyNewState
5640: 3c 59 59 4e 53 54 41 54 45 20 29 7b 0a 20 20 20  <YYNSTATE ){.   
5650: 20 20 20 66 70 72 69 6e 74 66 28 79 79 54 72 61     fprintf(yyTra
5660: 63 65 46 49 4c 45 2c 22 25 73 25 73 20 27 25 73  ceFILE,"%s%s '%s
5670: 27 2c 20 67 6f 20 74 6f 20 73 74 61 74 65 20 25  ', go to state %
5680: 64 5c 6e 22 2c 0a 20 20 20 20 20 20 20 20 20 79  d\n",.         y
5690: 79 54 72 61 63 65 50 72 6f 6d 70 74 2c 20 7a 54  yTracePrompt, zT
56a0: 61 67 2c 20 79 79 54 6f 6b 65 6e 4e 61 6d 65 5b  ag, yyTokenName[
56b0: 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74 6f 73  yypParser->yytos
56c0: 2d 3e 6d 61 6a 6f 72 5d 2c 0a 20 20 20 20 20 20  ->major],.      
56d0: 20 20 20 79 79 4e 65 77 53 74 61 74 65 29 3b 0a     yyNewState);.
56e0: 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20      }else{.     
56f0: 20 66 70 72 69 6e 74 66 28 79 79 54 72 61 63 65   fprintf(yyTrace
5700: 46 49 4c 45 2c 22 25 73 25 73 20 27 25 73 27 2c  FILE,"%s%s '%s',
5710: 20 70 65 6e 64 69 6e 67 20 72 65 64 75 63 65 20   pending reduce 
5720: 25 64 5c 6e 22 2c 0a 20 20 20 20 20 20 20 20 20  %d\n",.         
5730: 79 79 54 72 61 63 65 50 72 6f 6d 70 74 2c 20 7a  yyTracePrompt, z
5740: 54 61 67 2c 20 79 79 54 6f 6b 65 6e 4e 61 6d 65  Tag, yyTokenName
5750: 5b 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74 6f  [yypParser->yyto
5760: 73 2d 3e 6d 61 6a 6f 72 5d 2c 0a 20 20 20 20 20  s->major],.     
5770: 20 20 20 20 79 79 4e 65 77 53 74 61 74 65 20 2d      yyNewState -
5780: 20 59 59 5f 4d 49 4e 5f 52 45 44 55 43 45 29 3b   YY_MIN_REDUCE);
5790: 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a 23 65 6c  .    }.  }.}.#el
57a0: 73 65 0a 23 20 64 65 66 69 6e 65 20 79 79 54 72  se.# define yyTr
57b0: 61 63 65 53 68 69 66 74 28 58 2c 59 2c 5a 29 0a  aceShift(X,Y,Z).
57c0: 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 50 65  #endif../*.** Pe
57d0: 72 66 6f 72 6d 20 61 20 73 68 69 66 74 20 61 63  rform a shift ac
57e0: 74 69 6f 6e 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  tion..*/.static 
57f0: 76 6f 69 64 20 79 79 5f 73 68 69 66 74 28 0a 20  void yy_shift(. 
5800: 20 79 79 50 61 72 73 65 72 20 2a 79 79 70 50 61   yyParser *yypPa
5810: 72 73 65 72 2c 20 20 20 20 20 20 20 20 20 20 2f  rser,          /
5820: 2a 20 54 68 65 20 70 61 72 73 65 72 20 74 6f 20  * The parser to 
5830: 62 65 20 73 68 69 66 74 65 64 20 2a 2f 0a 20 20  be shifted */.  
5840: 59 59 41 43 54 49 4f 4e 54 59 50 45 20 79 79 4e  YYACTIONTYPE yyN
5850: 65 77 53 74 61 74 65 2c 20 20 20 20 20 20 2f 2a  ewState,      /*
5860: 20 54 68 65 20 6e 65 77 20 73 74 61 74 65 20 74   The new state t
5870: 6f 20 73 68 69 66 74 20 69 6e 20 2a 2f 0a 20 20  o shift in */.  
5880: 59 59 43 4f 44 45 54 59 50 45 20 79 79 4d 61 6a  YYCODETYPE yyMaj
5890: 6f 72 2c 20 20 20 20 20 20 20 20 20 20 20 2f 2a  or,           /*
58a0: 20 54 68 65 20 6d 61 6a 6f 72 20 74 6f 6b 65 6e   The major token
58b0: 20 74 6f 20 73 68 69 66 74 20 69 6e 20 2a 2f 0a   to shift in */.
58c0: 20 20 50 61 72 73 65 54 4f 4b 45 4e 54 59 50 45    ParseTOKENTYPE
58d0: 20 79 79 4d 69 6e 6f 72 20 20 20 20 20 20 20 20   yyMinor        
58e0: 2f 2a 20 54 68 65 20 6d 69 6e 6f 72 20 74 6f 6b  /* The minor tok
58f0: 65 6e 20 74 6f 20 73 68 69 66 74 20 69 6e 20 2a  en to shift in *
5900: 2f 0a 29 7b 0a 20 20 79 79 53 74 61 63 6b 45 6e  /.){.  yyStackEn
5910: 74 72 79 20 2a 79 79 74 6f 73 3b 0a 20 20 79 79  try *yytos;.  yy
5920: 70 50 61 72 73 65 72 2d 3e 79 79 74 6f 73 2b 2b  pParser->yytos++
5930: 3b 0a 23 69 66 64 65 66 20 59 59 54 52 41 43 4b  ;.#ifdef YYTRACK
5940: 4d 41 58 53 54 41 43 4b 44 45 50 54 48 0a 20 20  MAXSTACKDEPTH.  
5950: 69 66 28 20 28 69 6e 74 29 28 79 79 70 50 61 72  if( (int)(yypPar
5960: 73 65 72 2d 3e 79 79 74 6f 73 20 2d 20 79 79 70  ser->yytos - yyp
5970: 50 61 72 73 65 72 2d 3e 79 79 73 74 61 63 6b 29  Parser->yystack)
5980: 3e 79 79 70 50 61 72 73 65 72 2d 3e 79 79 68 77  >yypParser->yyhw
5990: 6d 20 29 7b 0a 20 20 20 20 79 79 70 50 61 72 73  m ){.    yypPars
59a0: 65 72 2d 3e 79 79 68 77 6d 2b 2b 3b 0a 20 20 20  er->yyhwm++;.   
59b0: 20 61 73 73 65 72 74 28 20 79 79 70 50 61 72 73   assert( yypPars
59c0: 65 72 2d 3e 79 79 68 77 6d 20 3d 3d 20 28 69 6e  er->yyhwm == (in
59d0: 74 29 28 79 79 70 50 61 72 73 65 72 2d 3e 79 79  t)(yypParser->yy
59e0: 74 6f 73 20 2d 20 79 79 70 50 61 72 73 65 72 2d  tos - yypParser-
59f0: 3e 79 79 73 74 61 63 6b 29 20 29 3b 0a 20 20 7d  >yystack) );.  }
5a00: 0a 23 65 6e 64 69 66 0a 23 69 66 20 59 59 53 54  .#endif.#if YYST
5a10: 41 43 4b 44 45 50 54 48 3e 30 20 0a 20 20 69 66  ACKDEPTH>0 .  if
5a20: 28 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74  ( yypParser->yyt
5a30: 6f 73 3e 79 79 70 50 61 72 73 65 72 2d 3e 79 79  os>yypParser->yy
5a40: 73 74 61 63 6b 45 6e 64 20 29 7b 0a 20 20 20 20  stackEnd ){.    
5a50: 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74 6f 73  yypParser->yytos
5a60: 2d 2d 3b 0a 20 20 20 20 79 79 53 74 61 63 6b 4f  --;.    yyStackO
5a70: 76 65 72 66 6c 6f 77 28 79 79 70 50 61 72 73 65  verflow(yypParse
5a80: 72 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 3b 0a  r);.    return;.
5a90: 20 20 7d 0a 23 65 6c 73 65 0a 20 20 69 66 28 20    }.#else.  if( 
5aa0: 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74 6f 73  yypParser->yytos
5ab0: 3e 3d 26 79 79 70 50 61 72 73 65 72 2d 3e 79 79  >=&yypParser->yy
5ac0: 73 74 61 63 6b 5b 79 79 70 50 61 72 73 65 72 2d  stack[yypParser-
5ad0: 3e 79 79 73 74 6b 73 7a 5d 20 29 7b 0a 20 20 20  >yystksz] ){.   
5ae0: 20 69 66 28 20 79 79 47 72 6f 77 53 74 61 63 6b   if( yyGrowStack
5af0: 28 79 79 70 50 61 72 73 65 72 29 20 29 7b 0a 20  (yypParser) ){. 
5b00: 20 20 20 20 20 79 79 70 50 61 72 73 65 72 2d 3e       yypParser->
5b10: 79 79 74 6f 73 2d 2d 3b 0a 20 20 20 20 20 20 79  yytos--;.      y
5b20: 79 53 74 61 63 6b 4f 76 65 72 66 6c 6f 77 28 79  yStackOverflow(y
5b30: 79 70 50 61 72 73 65 72 29 3b 0a 20 20 20 20 20  ypParser);.     
5b40: 20 72 65 74 75 72 6e 3b 0a 20 20 20 20 7d 0a 20   return;.    }. 
5b50: 20 7d 0a 23 65 6e 64 69 66 0a 20 20 69 66 28 20   }.#endif.  if( 
5b60: 79 79 4e 65 77 53 74 61 74 65 20 3e 20 59 59 5f  yyNewState > YY_
5b70: 4d 41 58 5f 53 48 49 46 54 20 29 7b 0a 20 20 20  MAX_SHIFT ){.   
5b80: 20 79 79 4e 65 77 53 74 61 74 65 20 2b 3d 20 59   yyNewState += Y
5b90: 59 5f 4d 49 4e 5f 52 45 44 55 43 45 20 2d 20 59  Y_MIN_REDUCE - Y
5ba0: 59 5f 4d 49 4e 5f 53 48 49 46 54 52 45 44 55 43  Y_MIN_SHIFTREDUC
5bb0: 45 3b 0a 20 20 7d 0a 20 20 79 79 74 6f 73 20 3d  E;.  }.  yytos =
5bc0: 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74 6f   yypParser->yyto
5bd0: 73 3b 0a 20 20 79 79 74 6f 73 2d 3e 73 74 61 74  s;.  yytos->stat
5be0: 65 6e 6f 20 3d 20 79 79 4e 65 77 53 74 61 74 65  eno = yyNewState
5bf0: 3b 0a 20 20 79 79 74 6f 73 2d 3e 6d 61 6a 6f 72  ;.  yytos->major
5c00: 20 3d 20 79 79 4d 61 6a 6f 72 3b 0a 20 20 79 79   = yyMajor;.  yy
5c10: 74 6f 73 2d 3e 6d 69 6e 6f 72 2e 79 79 30 20 3d  tos->minor.yy0 =
5c20: 20 79 79 4d 69 6e 6f 72 3b 0a 20 20 79 79 54 72   yyMinor;.  yyTr
5c30: 61 63 65 53 68 69 66 74 28 79 79 70 50 61 72 73  aceShift(yypPars
5c40: 65 72 2c 20 79 79 4e 65 77 53 74 61 74 65 2c 20  er, yyNewState, 
5c50: 22 53 68 69 66 74 22 29 3b 0a 7d 0a 0a 2f 2a 20  "Shift");.}../* 
5c60: 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 74 61  The following ta
5c70: 62 6c 65 20 63 6f 6e 74 61 69 6e 73 20 69 6e 66  ble contains inf
5c80: 6f 72 6d 61 74 69 6f 6e 20 61 62 6f 75 74 20 65  ormation about e
5c90: 76 65 72 79 20 72 75 6c 65 20 74 68 61 74 0a 2a  very rule that.*
5ca0: 2a 20 69 73 20 75 73 65 64 20 64 75 72 69 6e 67  * is used during
5cb0: 20 74 68 65 20 72 65 64 75 63 65 2e 0a 2a 2f 0a   the reduce..*/.
5cc0: 73 74 61 74 69 63 20 63 6f 6e 73 74 20 73 74 72  static const str
5cd0: 75 63 74 20 7b 0a 20 20 59 59 43 4f 44 45 54 59  uct {.  YYCODETY
5ce0: 50 45 20 6c 68 73 3b 20 20 20 20 20 20 20 2f 2a  PE lhs;       /*
5cf0: 20 53 79 6d 62 6f 6c 20 6f 6e 20 74 68 65 20 6c   Symbol on the l
5d00: 65 66 74 2d 68 61 6e 64 20 73 69 64 65 20 6f 66  eft-hand side of
5d10: 20 74 68 65 20 72 75 6c 65 20 2a 2f 0a 20 20 73   the rule */.  s
5d20: 69 67 6e 65 64 20 63 68 61 72 20 6e 72 68 73 3b  igned char nrhs;
5d30: 20 20 20 20 20 2f 2a 20 4e 65 67 61 74 69 76 65       /* Negative
5d40: 20 6f 66 20 74 68 65 20 6e 75 6d 62 65 72 20 6f   of the number o
5d50: 66 20 52 48 53 20 73 79 6d 62 6f 6c 73 20 69 6e  f RHS symbols in
5d60: 20 74 68 65 20 72 75 6c 65 20 2a 2f 0a 7d 20 79   the rule */.} y
5d70: 79 52 75 6c 65 49 6e 66 6f 5b 5d 20 3d 20 7b 0a  yRuleInfo[] = {.
5d80: 25 25 0a 7d 3b 0a 0a 73 74 61 74 69 63 20 76 6f  %%.};..static vo
5d90: 69 64 20 79 79 5f 61 63 63 65 70 74 28 79 79 50  id yy_accept(yyP
5da0: 61 72 73 65 72 2a 29 3b 20 20 2f 2a 20 46 6f 72  arser*);  /* For
5db0: 77 61 72 64 20 44 65 63 6c 61 72 61 74 69 6f 6e  ward Declaration
5dc0: 20 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 50 65 72 66 6f   */../*.** Perfo
5dd0: 72 6d 20 61 20 72 65 64 75 63 65 20 61 63 74 69  rm a reduce acti
5de0: 6f 6e 20 61 6e 64 20 74 68 65 20 73 68 69 66 74  on and the shift
5df0: 20 74 68 61 74 20 6d 75 73 74 20 69 6d 6d 65 64   that must immed
5e00: 69 61 74 65 6c 79 0a 2a 2a 20 66 6f 6c 6c 6f 77  iately.** follow
5e10: 20 74 68 65 20 72 65 64 75 63 65 2e 0a 2a 2a 0a   the reduce..**.
5e20: 2a 2a 20 54 68 65 20 79 79 4c 6f 6f 6b 61 68 65  ** The yyLookahe
5e30: 61 64 20 61 6e 64 20 79 79 4c 6f 6f 6b 61 68 65  ad and yyLookahe
5e40: 61 64 54 6f 6b 65 6e 20 70 61 72 61 6d 65 74 65  adToken paramete
5e50: 72 73 20 70 72 6f 76 69 64 65 20 72 65 64 75 63  rs provide reduc
5e60: 65 20 61 63 74 69 6f 6e 73 0a 2a 2a 20 61 63 63  e actions.** acc
5e70: 65 73 73 20 74 6f 20 74 68 65 20 6c 6f 6f 6b 61  ess to the looka
5e80: 68 65 61 64 20 74 6f 6b 65 6e 20 28 69 66 20 61  head token (if a
5e90: 6e 79 29 2e 20 20 54 68 65 20 79 79 4c 6f 6f 6b  ny).  The yyLook
5ea0: 61 68 65 61 64 20 77 69 6c 6c 20 62 65 20 59 59  ahead will be YY
5eb0: 4e 4f 43 4f 44 45 0a 2a 2a 20 69 66 20 74 68 65  NOCODE.** if the
5ec0: 20 6c 6f 6f 6b 61 68 65 61 64 20 74 6f 6b 65 6e   lookahead token
5ed0: 20 68 61 73 20 61 6c 72 65 61 64 79 20 62 65 65   has already bee
5ee0: 6e 20 63 6f 6e 73 75 6d 65 64 2e 20 20 41 73 20  n consumed.  As 
5ef0: 74 68 69 73 20 70 72 6f 63 65 64 75 72 65 20 69  this procedure i
5f00: 73 0a 2a 2a 20 6f 6e 6c 79 20 63 61 6c 6c 65 64  s.** only called
5f10: 20 66 72 6f 6d 20 6f 6e 65 20 70 6c 61 63 65 2c   from one place,
5f20: 20 6f 70 74 69 6d 69 7a 69 6e 67 20 63 6f 6d 70   optimizing comp
5f30: 69 6c 65 72 73 20 77 69 6c 6c 20 69 6e 2d 6c 69  ilers will in-li
5f40: 6e 65 20 69 74 2c 20 77 68 69 63 68 0a 2a 2a 20  ne it, which.** 
5f50: 6d 65 61 6e 73 20 74 68 61 74 20 74 68 65 20 65  means that the e
5f60: 78 74 72 61 20 70 61 72 61 6d 65 74 65 72 73 20  xtra parameters 
5f70: 68 61 76 65 20 6e 6f 20 70 65 72 66 6f 72 6d 61  have no performa
5f80: 6e 63 65 20 69 6d 70 61 63 74 2e 0a 2a 2f 0a 73  nce impact..*/.s
5f90: 74 61 74 69 63 20 59 59 41 43 54 49 4f 4e 54 59  tatic YYACTIONTY
5fa0: 50 45 20 79 79 5f 72 65 64 75 63 65 28 0a 20 20  PE yy_reduce(.  
5fb0: 79 79 50 61 72 73 65 72 20 2a 79 79 70 50 61 72  yyParser *yypPar
5fc0: 73 65 72 2c 20 20 20 20 20 20 20 20 20 2f 2a 20  ser,         /* 
5fd0: 54 68 65 20 70 61 72 73 65 72 20 2a 2f 0a 20 20  The parser */.  
5fe0: 75 6e 73 69 67 6e 65 64 20 69 6e 74 20 79 79 72  unsigned int yyr
5ff0: 75 6c 65 6e 6f 2c 20 20 20 20 20 20 20 2f 2a 20  uleno,       /* 
6000: 4e 75 6d 62 65 72 20 6f 66 20 74 68 65 20 72 75  Number of the ru
6010: 6c 65 20 62 79 20 77 68 69 63 68 20 74 6f 20 72  le by which to r
6020: 65 64 75 63 65 20 2a 2f 0a 20 20 69 6e 74 20 79  educe */.  int y
6030: 79 4c 6f 6f 6b 61 68 65 61 64 2c 20 20 20 20 20  yLookahead,     
6040: 20 20 20 20 20 20 20 20 2f 2a 20 4c 6f 6f 6b 61          /* Looka
6050: 68 65 61 64 20 74 6f 6b 65 6e 2c 20 6f 72 20 59  head token, or Y
6060: 59 4e 4f 43 4f 44 45 20 69 66 20 6e 6f 6e 65 20  YNOCODE if none 
6070: 2a 2f 0a 20 20 50 61 72 73 65 54 4f 4b 45 4e 54  */.  ParseTOKENT
6080: 59 50 45 20 79 79 4c 6f 6f 6b 61 68 65 61 64 54  YPE yyLookaheadT
6090: 6f 6b 65 6e 20 20 2f 2a 20 56 61 6c 75 65 20 6f  oken  /* Value o
60a0: 66 20 74 68 65 20 6c 6f 6f 6b 61 68 65 61 64 20  f the lookahead 
60b0: 74 6f 6b 65 6e 20 2a 2f 0a 20 20 50 61 72 73 65  token */.  Parse
60c0: 43 54 58 5f 50 44 45 43 4c 20 20 20 20 20 20 20  CTX_PDECL       
60d0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 25              /* %
60e0: 65 78 74 72 61 5f 63 6f 6e 74 65 78 74 20 2a 2f  extra_context */
60f0: 0a 29 7b 0a 20 20 69 6e 74 20 79 79 67 6f 74 6f  .){.  int yygoto
6100: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
6110: 20 20 20 20 20 20 2f 2a 20 54 68 65 20 6e 65 78        /* The nex
6120: 74 20 73 74 61 74 65 20 2a 2f 0a 20 20 59 59 41  t state */.  YYA
6130: 43 54 49 4f 4e 54 59 50 45 20 79 79 61 63 74 3b  CTIONTYPE yyact;
6140: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
6150: 54 68 65 20 6e 65 78 74 20 61 63 74 69 6f 6e 20  The next action 
6160: 2a 2f 0a 20 20 79 79 53 74 61 63 6b 45 6e 74 72  */.  yyStackEntr
6170: 79 20 2a 79 79 6d 73 70 3b 20 20 20 20 20 20 20  y *yymsp;       
6180: 20 20 20 20 20 2f 2a 20 54 68 65 20 74 6f 70 20       /* The top 
6190: 6f 66 20 74 68 65 20 70 61 72 73 65 72 27 73 20  of the parser's 
61a0: 73 74 61 63 6b 20 2a 2f 0a 20 20 69 6e 74 20 79  stack */.  int y
61b0: 79 73 69 7a 65 3b 20 20 20 20 20 20 20 20 20 20  ysize;          
61c0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 41 6d             /* Am
61d0: 6f 75 6e 74 20 74 6f 20 70 6f 70 20 74 68 65 20  ount to pop the 
61e0: 73 74 61 63 6b 20 2a 2f 0a 20 20 50 61 72 73 65  stack */.  Parse
61f0: 41 52 47 5f 46 45 54 43 48 0a 20 20 28 76 6f 69  ARG_FETCH.  (voi
6200: 64 29 79 79 4c 6f 6f 6b 61 68 65 61 64 3b 0a 20  d)yyLookahead;. 
6210: 20 28 76 6f 69 64 29 79 79 4c 6f 6f 6b 61 68 65   (void)yyLookahe
6220: 61 64 54 6f 6b 65 6e 3b 0a 20 20 79 79 6d 73 70  adToken;.  yymsp
6230: 20 3d 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79   = yypParser->yy
6240: 74 6f 73 3b 0a 23 69 66 6e 64 65 66 20 4e 44 45  tos;.#ifndef NDE
6250: 42 55 47 0a 20 20 69 66 28 20 79 79 54 72 61 63  BUG.  if( yyTrac
6260: 65 46 49 4c 45 20 26 26 20 79 79 72 75 6c 65 6e  eFILE && yyrulen
6270: 6f 3c 28 69 6e 74 29 28 73 69 7a 65 6f 66 28 79  o<(int)(sizeof(y
6280: 79 52 75 6c 65 4e 61 6d 65 29 2f 73 69 7a 65 6f  yRuleName)/sizeo
6290: 66 28 79 79 52 75 6c 65 4e 61 6d 65 5b 30 5d 29  f(yyRuleName[0])
62a0: 29 20 29 7b 0a 20 20 20 20 79 79 73 69 7a 65 20  ) ){.    yysize 
62b0: 3d 20 79 79 52 75 6c 65 49 6e 66 6f 5b 79 79 72  = yyRuleInfo[yyr
62c0: 75 6c 65 6e 6f 5d 2e 6e 72 68 73 3b 0a 20 20 20  uleno].nrhs;.   
62d0: 20 69 66 28 20 79 79 73 69 7a 65 20 29 7b 0a 20   if( yysize ){. 
62e0: 20 20 20 20 20 66 70 72 69 6e 74 66 28 79 79 54       fprintf(yyT
62f0: 72 61 63 65 46 49 4c 45 2c 20 22 25 73 52 65 64  raceFILE, "%sRed
6300: 75 63 65 20 25 64 20 5b 25 73 5d 2c 20 67 6f 20  uce %d [%s], go 
6310: 74 6f 20 73 74 61 74 65 20 25 64 2e 5c 6e 22 2c  to state %d.\n",
6320: 0a 20 20 20 20 20 20 20 20 79 79 54 72 61 63 65  .        yyTrace
6330: 50 72 6f 6d 70 74 2c 0a 20 20 20 20 20 20 20 20  Prompt,.        
6340: 79 79 72 75 6c 65 6e 6f 2c 20 79 79 52 75 6c 65  yyruleno, yyRule
6350: 4e 61 6d 65 5b 79 79 72 75 6c 65 6e 6f 5d 2c 20  Name[yyruleno], 
6360: 79 79 6d 73 70 5b 79 79 73 69 7a 65 5d 2e 73 74  yymsp[yysize].st
6370: 61 74 65 6e 6f 29 3b 0a 20 20 20 20 7d 65 6c 73  ateno);.    }els
6380: 65 7b 0a 20 20 20 20 20 20 66 70 72 69 6e 74 66  e{.      fprintf
6390: 28 79 79 54 72 61 63 65 46 49 4c 45 2c 20 22 25  (yyTraceFILE, "%
63a0: 73 52 65 64 75 63 65 20 25 64 20 5b 25 73 5d 2e  sReduce %d [%s].
63b0: 5c 6e 22 2c 0a 20 20 20 20 20 20 20 20 79 79 54  \n",.        yyT
63c0: 72 61 63 65 50 72 6f 6d 70 74 2c 20 79 79 72 75  racePrompt, yyru
63d0: 6c 65 6e 6f 2c 20 79 79 52 75 6c 65 4e 61 6d 65  leno, yyRuleName
63e0: 5b 79 79 72 75 6c 65 6e 6f 5d 29 3b 0a 20 20 20  [yyruleno]);.   
63f0: 20 7d 0a 20 20 7d 0a 23 65 6e 64 69 66 20 2f 2a   }.  }.#endif /*
6400: 20 4e 44 45 42 55 47 20 2a 2f 0a 0a 20 20 2f 2a   NDEBUG */..  /*
6410: 20 43 68 65 63 6b 20 74 68 61 74 20 74 68 65 20   Check that the 
6420: 73 74 61 63 6b 20 69 73 20 6c 61 72 67 65 20 65  stack is large e
6430: 6e 6f 75 67 68 20 74 6f 20 67 72 6f 77 20 62 79  nough to grow by
6440: 20 61 20 73 69 6e 67 6c 65 20 65 6e 74 72 79 0a   a single entry.
6450: 20 20 2a 2a 20 69 66 20 74 68 65 20 52 48 53 20    ** if the RHS 
6460: 6f 66 20 74 68 65 20 72 75 6c 65 20 69 73 20 65  of the rule is e
6470: 6d 70 74 79 2e 20 20 54 68 69 73 20 65 6e 73 75  mpty.  This ensu
6480: 72 65 73 20 74 68 61 74 20 74 68 65 72 65 20 69  res that there i
6490: 73 20 72 6f 6f 6d 0a 20 20 2a 2a 20 65 6e 6f 75  s room.  ** enou
64a0: 67 68 20 6f 6e 20 74 68 65 20 73 74 61 63 6b 20  gh on the stack 
64b0: 74 6f 20 70 75 73 68 20 74 68 65 20 4c 48 53 20  to push the LHS 
64c0: 76 61 6c 75 65 20 2a 2f 0a 20 20 69 66 28 20 79  value */.  if( y
64d0: 79 52 75 6c 65 49 6e 66 6f 5b 79 79 72 75 6c 65  yRuleInfo[yyrule
64e0: 6e 6f 5d 2e 6e 72 68 73 3d 3d 30 20 29 7b 0a 23  no].nrhs==0 ){.#
64f0: 69 66 64 65 66 20 59 59 54 52 41 43 4b 4d 41 58  ifdef YYTRACKMAX
6500: 53 54 41 43 4b 44 45 50 54 48 0a 20 20 20 20 69  STACKDEPTH.    i
6510: 66 28 20 28 69 6e 74 29 28 79 79 70 50 61 72 73  f( (int)(yypPars
6520: 65 72 2d 3e 79 79 74 6f 73 20 2d 20 79 79 70 50  er->yytos - yypP
6530: 61 72 73 65 72 2d 3e 79 79 73 74 61 63 6b 29 3e  arser->yystack)>
6540: 79 79 70 50 61 72 73 65 72 2d 3e 79 79 68 77 6d  yypParser->yyhwm
6550: 20 29 7b 0a 20 20 20 20 20 20 79 79 70 50 61 72   ){.      yypPar
6560: 73 65 72 2d 3e 79 79 68 77 6d 2b 2b 3b 0a 20 20  ser->yyhwm++;.  
6570: 20 20 20 20 61 73 73 65 72 74 28 20 79 79 70 50      assert( yypP
6580: 61 72 73 65 72 2d 3e 79 79 68 77 6d 20 3d 3d 20  arser->yyhwm == 
6590: 28 69 6e 74 29 28 79 79 70 50 61 72 73 65 72 2d  (int)(yypParser-
65a0: 3e 79 79 74 6f 73 20 2d 20 79 79 70 50 61 72 73  >yytos - yypPars
65b0: 65 72 2d 3e 79 79 73 74 61 63 6b 29 29 3b 0a 20  er->yystack));. 
65c0: 20 20 20 7d 0a 23 65 6e 64 69 66 0a 23 69 66 20     }.#endif.#if 
65d0: 59 59 53 54 41 43 4b 44 45 50 54 48 3e 30 20 0a  YYSTACKDEPTH>0 .
65e0: 20 20 20 20 69 66 28 20 79 79 70 50 61 72 73 65      if( yypParse
65f0: 72 2d 3e 79 79 74 6f 73 3e 3d 79 79 70 50 61 72  r->yytos>=yypPar
6600: 73 65 72 2d 3e 79 79 73 74 61 63 6b 45 6e 64 20  ser->yystackEnd 
6610: 29 7b 0a 20 20 20 20 20 20 79 79 53 74 61 63 6b  ){.      yyStack
6620: 4f 76 65 72 66 6c 6f 77 28 79 79 70 50 61 72 73  Overflow(yypPars
6630: 65 72 29 3b 0a 20 20 20 20 20 20 2f 2a 20 54 68  er);.      /* Th
6640: 65 20 63 61 6c 6c 20 74 6f 20 79 79 53 74 61 63  e call to yyStac
6650: 6b 4f 76 65 72 66 6c 6f 77 28 29 20 61 62 6f 76  kOverflow() abov
6660: 65 20 70 6f 70 73 20 74 68 65 20 73 74 61 63 6b  e pops the stack
6670: 20 75 6e 74 69 6c 20 69 74 20 69 73 0a 20 20 20   until it is.   
6680: 20 20 20 2a 2a 20 65 6d 70 74 79 2c 20 63 61 75     ** empty, cau
6690: 73 69 6e 67 20 74 68 65 20 6d 61 69 6e 20 70 61  sing the main pa
66a0: 72 73 65 72 20 6c 6f 6f 70 20 74 6f 20 65 78 69  rser loop to exi
66b0: 74 2e 20 20 53 6f 20 74 68 65 20 72 65 74 75 72  t.  So the retur
66c0: 6e 20 76 61 6c 75 65 0a 20 20 20 20 20 20 2a 2a  n value.      **
66d0: 20 69 73 20 6e 65 76 65 72 20 75 73 65 64 20 61   is never used a
66e0: 6e 64 20 64 6f 65 73 20 6e 6f 74 20 6d 61 74 74  nd does not matt
66f0: 65 72 2e 20 2a 2f 0a 20 20 20 20 20 20 72 65 74  er. */.      ret
6700: 75 72 6e 20 30 3b 0a 20 20 20 20 7d 0a 23 65 6c  urn 0;.    }.#el
6710: 73 65 0a 20 20 20 20 69 66 28 20 79 79 70 50 61  se.    if( yypPa
6720: 72 73 65 72 2d 3e 79 79 74 6f 73 3e 3d 26 79 79  rser->yytos>=&yy
6730: 70 50 61 72 73 65 72 2d 3e 79 79 73 74 61 63 6b  pParser->yystack
6740: 5b 79 79 70 50 61 72 73 65 72 2d 3e 79 79 73 74  [yypParser->yyst
6750: 6b 73 7a 2d 31 5d 20 29 7b 0a 20 20 20 20 20 20  ksz-1] ){.      
6760: 69 66 28 20 79 79 47 72 6f 77 53 74 61 63 6b 28  if( yyGrowStack(
6770: 79 79 70 50 61 72 73 65 72 29 20 29 7b 0a 20 20  yypParser) ){.  
6780: 20 20 20 20 20 20 79 79 53 74 61 63 6b 4f 76 65        yyStackOve
6790: 72 66 6c 6f 77 28 79 79 70 50 61 72 73 65 72 29  rflow(yypParser)
67a0: 3b 0a 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65  ;.        /* The
67b0: 20 63 61 6c 6c 20 74 6f 20 79 79 53 74 61 63 6b   call to yyStack
67c0: 4f 76 65 72 66 6c 6f 77 28 29 20 61 62 6f 76 65  Overflow() above
67d0: 20 70 6f 70 73 20 74 68 65 20 73 74 61 63 6b 20   pops the stack 
67e0: 75 6e 74 69 6c 20 69 74 20 69 73 0a 20 20 20 20  until it is.    
67f0: 20 20 20 20 2a 2a 20 65 6d 70 74 79 2c 20 63 61      ** empty, ca
6800: 75 73 69 6e 67 20 74 68 65 20 6d 61 69 6e 20 70  using the main p
6810: 61 72 73 65 72 20 6c 6f 6f 70 20 74 6f 20 65 78  arser loop to ex
6820: 69 74 2e 20 20 53 6f 20 74 68 65 20 72 65 74 75  it.  So the retu
6830: 72 6e 20 76 61 6c 75 65 0a 20 20 20 20 20 20 20  rn value.       
6840: 20 2a 2a 20 69 73 20 6e 65 76 65 72 20 75 73 65   ** is never use
6850: 64 20 61 6e 64 20 64 6f 65 73 20 6e 6f 74 20 6d  d and does not m
6860: 61 74 74 65 72 2e 20 2a 2f 0a 20 20 20 20 20 20  atter. */.      
6870: 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20    return 0;.    
6880: 20 20 7d 0a 20 20 20 20 20 20 79 79 6d 73 70 20    }.      yymsp 
6890: 3d 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74  = yypParser->yyt
68a0: 6f 73 3b 0a 20 20 20 20 7d 0a 23 65 6e 64 69 66  os;.    }.#endif
68b0: 0a 20 20 7d 0a 0a 20 20 73 77 69 74 63 68 28 20  .  }..  switch( 
68c0: 79 79 72 75 6c 65 6e 6f 20 29 7b 0a 20 20 2f 2a  yyruleno ){.  /*
68d0: 20 42 65 67 69 6e 6e 69 6e 67 20 68 65 72 65 20   Beginning here 
68e0: 61 72 65 20 74 68 65 20 72 65 64 75 63 74 69 6f  are the reductio
68f0: 6e 20 63 61 73 65 73 2e 20 20 41 20 74 79 70 69  n cases.  A typi
6900: 63 61 6c 20 65 78 61 6d 70 6c 65 0a 20 20 2a 2a  cal example.  **
6910: 20 66 6f 6c 6c 6f 77 73 3a 0a 20 20 2a 2a 20 20   follows:.  **  
6920: 20 63 61 73 65 20 30 3a 0a 20 20 2a 2a 20 20 23   case 0:.  **  #
6930: 6c 69 6e 65 20 3c 6c 69 6e 65 6e 6f 3e 20 3c 67  line <lineno> <g
6940: 72 61 6d 6d 61 72 66 69 6c 65 3e 0a 20 20 2a 2a  rammarfile>.  **
6950: 20 20 20 20 20 7b 20 2e 2e 2e 20 7d 20 20 20 20       { ... }    
6960: 20 20 20 20 20 20 20 2f 2f 20 55 73 65 72 20 73         // User s
6970: 75 70 70 6c 69 65 64 20 63 6f 64 65 0a 20 20 2a  upplied code.  *
6980: 2a 20 20 23 6c 69 6e 65 20 3c 6c 69 6e 65 6e 6f  *  #line <lineno
6990: 3e 20 3c 74 68 69 73 66 69 6c 65 3e 0a 20 20 2a  > <thisfile>.  *
69a0: 2a 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 2a  *     break;.  *
69b0: 2f 0a 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 20 42 65  /./********** Be
69c0: 67 69 6e 20 72 65 64 75 63 65 20 61 63 74 69 6f  gin reduce actio
69d0: 6e 73 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ns *************
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 2a 2a 2a 2a 2a 2a 2a 2a  ****************
6a00: 2a 2f 0a 25 25 0a 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a  */.%%./*********
6a10: 2a 20 45 6e 64 20 72 65 64 75 63 65 20 61 63 74  * End reduce act
6a20: 69 6f 6e 73 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ions ***********
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 2a 2a 2a 2a  ****************
6a50: 2a 2a 2a 2a 2a 2f 0a 20 20 7d 3b 0a 20 20 61 73  *****/.  };.  as
6a60: 73 65 72 74 28 20 79 79 72 75 6c 65 6e 6f 3c 73  sert( yyruleno<s
6a70: 69 7a 65 6f 66 28 79 79 52 75 6c 65 49 6e 66 6f  izeof(yyRuleInfo
6a80: 29 2f 73 69 7a 65 6f 66 28 79 79 52 75 6c 65 49  )/sizeof(yyRuleI
6a90: 6e 66 6f 5b 30 5d 29 20 29 3b 0a 20 20 79 79 67  nfo[0]) );.  yyg
6aa0: 6f 74 6f 20 3d 20 79 79 52 75 6c 65 49 6e 66 6f  oto = yyRuleInfo
6ab0: 5b 79 79 72 75 6c 65 6e 6f 5d 2e 6c 68 73 3b 0a  [yyruleno].lhs;.
6ac0: 20 20 79 79 73 69 7a 65 20 3d 20 79 79 52 75 6c    yysize = yyRul
6ad0: 65 49 6e 66 6f 5b 79 79 72 75 6c 65 6e 6f 5d 2e  eInfo[yyruleno].
6ae0: 6e 72 68 73 3b 0a 20 20 79 79 61 63 74 20 3d 20  nrhs;.  yyact = 
6af0: 79 79 5f 66 69 6e 64 5f 72 65 64 75 63 65 5f 61  yy_find_reduce_a
6b00: 63 74 69 6f 6e 28 79 79 6d 73 70 5b 79 79 73 69  ction(yymsp[yysi
6b10: 7a 65 5d 2e 73 74 61 74 65 6e 6f 2c 28 59 59 43  ze].stateno,(YYC
6b20: 4f 44 45 54 59 50 45 29 79 79 67 6f 74 6f 29 3b  ODETYPE)yygoto);
6b30: 0a 0a 20 20 2f 2a 20 54 68 65 72 65 20 61 72 65  ..  /* There are
6b40: 20 6e 6f 20 53 48 49 46 54 52 45 44 55 43 45 20   no SHIFTREDUCE 
6b50: 61 63 74 69 6f 6e 73 20 6f 6e 20 6e 6f 6e 74 65  actions on nonte
6b60: 72 6d 69 6e 61 6c 73 20 62 65 63 61 75 73 65 20  rminals because 
6b70: 74 68 65 20 74 61 62 6c 65 0a 20 20 2a 2a 20 67  the table.  ** g
6b80: 65 6e 65 72 61 74 6f 72 20 68 61 73 20 73 69 6d  enerator has sim
6b90: 70 6c 69 66 69 65 64 20 74 68 65 6d 20 74 6f 20  plified them to 
6ba0: 70 75 72 65 20 52 45 44 55 43 45 20 61 63 74 69  pure REDUCE acti
6bb0: 6f 6e 73 2e 20 2a 2f 0a 20 20 61 73 73 65 72 74  ons. */.  assert
6bc0: 28 20 21 28 79 79 61 63 74 3e 59 59 5f 4d 41 58  ( !(yyact>YY_MAX
6bd0: 5f 53 48 49 46 54 20 26 26 20 79 79 61 63 74 3c  _SHIFT && yyact<
6be0: 3d 59 59 5f 4d 41 58 5f 53 48 49 46 54 52 45 44  =YY_MAX_SHIFTRED
6bf0: 55 43 45 29 20 29 3b 0a 0a 20 20 2f 2a 20 49 74  UCE) );..  /* It
6c00: 20 69 73 20 6e 6f 74 20 70 6f 73 73 69 62 6c 65   is not possible
6c10: 20 66 6f 72 20 61 20 52 45 44 55 43 45 20 74 6f   for a REDUCE to
6c20: 20 62 65 20 66 6f 6c 6c 6f 77 65 64 20 62 79 20   be followed by 
6c30: 61 6e 20 65 72 72 6f 72 20 2a 2f 0a 20 20 61 73  an error */.  as
6c40: 73 65 72 74 28 20 79 79 61 63 74 21 3d 59 59 5f  sert( yyact!=YY_
6c50: 45 52 52 4f 52 5f 41 43 54 49 4f 4e 20 29 3b 0a  ERROR_ACTION );.
6c60: 0a 20 20 79 79 6d 73 70 20 2b 3d 20 79 79 73 69  .  yymsp += yysi
6c70: 7a 65 2b 31 3b 0a 20 20 79 79 70 50 61 72 73 65  ze+1;.  yypParse
6c80: 72 2d 3e 79 79 74 6f 73 20 3d 20 79 79 6d 73 70  r->yytos = yymsp
6c90: 3b 0a 20 20 79 79 6d 73 70 2d 3e 73 74 61 74 65  ;.  yymsp->state
6ca0: 6e 6f 20 3d 20 28 59 59 41 43 54 49 4f 4e 54 59  no = (YYACTIONTY
6cb0: 50 45 29 79 79 61 63 74 3b 0a 20 20 79 79 6d 73  PE)yyact;.  yyms
6cc0: 70 2d 3e 6d 61 6a 6f 72 20 3d 20 28 59 59 43 4f  p->major = (YYCO
6cd0: 44 45 54 59 50 45 29 79 79 67 6f 74 6f 3b 0a 20  DETYPE)yygoto;. 
6ce0: 20 79 79 54 72 61 63 65 53 68 69 66 74 28 79 79   yyTraceShift(yy
6cf0: 70 50 61 72 73 65 72 2c 20 79 79 61 63 74 2c 20  pParser, yyact, 
6d00: 22 2e 2e 2e 20 74 68 65 6e 20 73 68 69 66 74 22  "... then shift"
6d10: 29 3b 0a 20 20 72 65 74 75 72 6e 20 79 79 61 63  );.  return yyac
6d20: 74 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20  t;.}../*.** The 
6d30: 66 6f 6c 6c 6f 77 69 6e 67 20 63 6f 64 65 20 65  following code e
6d40: 78 65 63 75 74 65 73 20 77 68 65 6e 20 74 68 65  xecutes when the
6d50: 20 70 61 72 73 65 20 66 61 69 6c 73 0a 2a 2f 0a   parse fails.*/.
6d60: 23 69 66 6e 64 65 66 20 59 59 4e 4f 45 52 52 4f  #ifndef YYNOERRO
6d70: 52 52 45 43 4f 56 45 52 59 0a 73 74 61 74 69 63  RRECOVERY.static
6d80: 20 76 6f 69 64 20 79 79 5f 70 61 72 73 65 5f 66   void yy_parse_f
6d90: 61 69 6c 65 64 28 0a 20 20 79 79 50 61 72 73 65  ailed(.  yyParse
6da0: 72 20 2a 79 79 70 50 61 72 73 65 72 20 20 20 20  r *yypParser    
6db0: 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20 70 61         /* The pa
6dc0: 72 73 65 72 20 2a 2f 0a 29 7b 0a 20 20 50 61 72  rser */.){.  Par
6dd0: 73 65 41 52 47 5f 46 45 54 43 48 0a 20 20 50 61  seARG_FETCH.  Pa
6de0: 72 73 65 43 54 58 5f 46 45 54 43 48 0a 23 69 66  rseCTX_FETCH.#if
6df0: 6e 64 65 66 20 4e 44 45 42 55 47 0a 20 20 69 66  ndef NDEBUG.  if
6e00: 28 20 79 79 54 72 61 63 65 46 49 4c 45 20 29 7b  ( yyTraceFILE ){
6e10: 0a 20 20 20 20 66 70 72 69 6e 74 66 28 79 79 54  .    fprintf(yyT
6e20: 72 61 63 65 46 49 4c 45 2c 22 25 73 46 61 69 6c  raceFILE,"%sFail
6e30: 21 5c 6e 22 2c 79 79 54 72 61 63 65 50 72 6f 6d  !\n",yyTraceProm
6e40: 70 74 29 3b 0a 20 20 7d 0a 23 65 6e 64 69 66 0a  pt);.  }.#endif.
6e50: 20 20 77 68 69 6c 65 28 20 79 79 70 50 61 72 73    while( yypPars
6e60: 65 72 2d 3e 79 79 74 6f 73 3e 79 79 70 50 61 72  er->yytos>yypPar
6e70: 73 65 72 2d 3e 79 79 73 74 61 63 6b 20 29 20 79  ser->yystack ) y
6e80: 79 5f 70 6f 70 5f 70 61 72 73 65 72 5f 73 74 61  y_pop_parser_sta
6e90: 63 6b 28 79 79 70 50 61 72 73 65 72 29 3b 0a 20  ck(yypParser);. 
6ea0: 20 2f 2a 20 48 65 72 65 20 63 6f 64 65 20 69 73   /* Here code is
6eb0: 20 69 6e 73 65 72 74 65 64 20 77 68 69 63 68 20   inserted which 
6ec0: 77 69 6c 6c 20 62 65 20 65 78 65 63 75 74 65 64  will be executed
6ed0: 20 77 68 65 6e 65 76 65 72 20 74 68 65 0a 20 20   whenever the.  
6ee0: 2a 2a 20 70 61 72 73 65 72 20 66 61 69 6c 73 20  ** parser fails 
6ef0: 2a 2f 0a 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  */./************
6f00: 20 42 65 67 69 6e 20 25 70 61 72 73 65 5f 66 61   Begin %parse_fa
6f10: 69 6c 75 72 65 20 63 6f 64 65 20 2a 2a 2a 2a 2a  ilure code *****
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 2a 2a 2a 2a 2a 2a 2a  ****************
6f40: 2a 2a 2f 0a 25 25 0a 2f 2a 2a 2a 2a 2a 2a 2a 2a  **/.%%./********
6f50: 2a 2a 2a 2a 20 45 6e 64 20 25 70 61 72 73 65 5f  **** End %parse_
6f60: 66 61 69 6c 75 72 65 20 63 6f 64 65 20 2a 2a 2a  failure code ***
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 2a 2a 2a  ****************
6f90: 2a 2a 2a 2a 2a 2a 2f 0a 20 20 50 61 72 73 65 41  ******/.  ParseA
6fa0: 52 47 5f 53 54 4f 52 45 20 2f 2a 20 53 75 70 70  RG_STORE /* Supp
6fb0: 72 65 73 73 20 77 61 72 6e 69 6e 67 20 61 62 6f  ress warning abo
6fc0: 75 74 20 75 6e 75 73 65 64 20 25 65 78 74 72 61  ut unused %extra
6fd0: 5f 61 72 67 75 6d 65 6e 74 20 76 61 72 69 61 62  _argument variab
6fe0: 6c 65 20 2a 2f 0a 20 20 50 61 72 73 65 43 54 58  le */.  ParseCTX
6ff0: 5f 53 54 4f 52 45 0a 7d 0a 23 65 6e 64 69 66 20  _STORE.}.#endif 
7000: 2f 2a 20 59 59 4e 4f 45 52 52 4f 52 52 45 43 4f  /* YYNOERRORRECO
7010: 56 45 52 59 20 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 54  VERY */../*.** T
7020: 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 63 6f 64  he following cod
7030: 65 20 65 78 65 63 75 74 65 73 20 77 68 65 6e 20  e executes when 
7040: 61 20 73 79 6e 74 61 78 20 65 72 72 6f 72 20 66  a syntax error f
7050: 69 72 73 74 20 6f 63 63 75 72 73 2e 0a 2a 2f 0a  irst occurs..*/.
7060: 73 74 61 74 69 63 20 76 6f 69 64 20 79 79 5f 73  static void yy_s
7070: 79 6e 74 61 78 5f 65 72 72 6f 72 28 0a 20 20 79  yntax_error(.  y
7080: 79 50 61 72 73 65 72 20 2a 79 79 70 50 61 72 73  yParser *yypPars
7090: 65 72 2c 20 20 20 20 20 20 20 20 20 20 20 2f 2a  er,           /*
70a0: 20 54 68 65 20 70 61 72 73 65 72 20 2a 2f 0a 20   The parser */. 
70b0: 20 69 6e 74 20 79 79 6d 61 6a 6f 72 2c 20 20 20   int yymajor,   
70c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
70d0: 2f 2a 20 54 68 65 20 6d 61 6a 6f 72 20 74 79 70  /* The major typ
70e0: 65 20 6f 66 20 74 68 65 20 65 72 72 6f 72 20 74  e of the error t
70f0: 6f 6b 65 6e 20 2a 2f 0a 20 20 50 61 72 73 65 54  oken */.  ParseT
7100: 4f 4b 45 4e 54 59 50 45 20 79 79 6d 69 6e 6f 72  OKENTYPE yyminor
7110: 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68 65 20           /* The 
7120: 6d 69 6e 6f 72 20 74 79 70 65 20 6f 66 20 74 68  minor type of th
7130: 65 20 65 72 72 6f 72 20 74 6f 6b 65 6e 20 2a 2f  e error token */
7140: 0a 29 7b 0a 20 20 50 61 72 73 65 41 52 47 5f 46  .){.  ParseARG_F
7150: 45 54 43 48 0a 20 20 50 61 72 73 65 43 54 58 5f  ETCH.  ParseCTX_
7160: 46 45 54 43 48 0a 23 64 65 66 69 6e 65 20 54 4f  FETCH.#define TO
7170: 4b 45 4e 20 79 79 6d 69 6e 6f 72 0a 2f 2a 2a 2a  KEN yyminor./***
7180: 2a 2a 2a 2a 2a 2a 2a 2a 2a 20 42 65 67 69 6e 20  ********* Begin 
7190: 25 73 79 6e 74 61 78 5f 65 72 72 6f 72 20 63 6f  %syntax_error co
71a0: 64 65 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  de *************
71b0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
71c0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a 25 25 0a  ***********/.%%.
71d0: 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 20 45 6e  /************ En
71e0: 64 20 25 73 79 6e 74 61 78 5f 65 72 72 6f 72 20  d %syntax_error 
71f0: 63 6f 64 65 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  code ***********
7200: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
7210: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f  ***************/
7220: 0a 20 20 50 61 72 73 65 41 52 47 5f 53 54 4f 52  .  ParseARG_STOR
7230: 45 20 2f 2a 20 53 75 70 70 72 65 73 73 20 77 61  E /* Suppress wa
7240: 72 6e 69 6e 67 20 61 62 6f 75 74 20 75 6e 75 73  rning about unus
7250: 65 64 20 25 65 78 74 72 61 5f 61 72 67 75 6d 65  ed %extra_argume
7260: 6e 74 20 76 61 72 69 61 62 6c 65 20 2a 2f 0a 20  nt variable */. 
7270: 20 50 61 72 73 65 43 54 58 5f 53 54 4f 52 45 0a   ParseCTX_STORE.
7280: 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 66 6f 6c  }../*.** The fol
7290: 6c 6f 77 69 6e 67 20 69 73 20 65 78 65 63 75 74  lowing is execut
72a0: 65 64 20 77 68 65 6e 20 74 68 65 20 70 61 72 73  ed when the pars
72b0: 65 72 20 61 63 63 65 70 74 73 0a 2a 2f 0a 73 74  er accepts.*/.st
72c0: 61 74 69 63 20 76 6f 69 64 20 79 79 5f 61 63 63  atic void yy_acc
72d0: 65 70 74 28 0a 20 20 79 79 50 61 72 73 65 72 20  ept(.  yyParser 
72e0: 2a 79 79 70 50 61 72 73 65 72 20 20 20 20 20 20  *yypParser      
72f0: 20 20 20 20 20 2f 2a 20 54 68 65 20 70 61 72 73       /* The pars
7300: 65 72 20 2a 2f 0a 29 7b 0a 20 20 50 61 72 73 65  er */.){.  Parse
7310: 41 52 47 5f 46 45 54 43 48 0a 20 20 50 61 72 73  ARG_FETCH.  Pars
7320: 65 43 54 58 5f 46 45 54 43 48 0a 23 69 66 6e 64  eCTX_FETCH.#ifnd
7330: 65 66 20 4e 44 45 42 55 47 0a 20 20 69 66 28 20  ef NDEBUG.  if( 
7340: 79 79 54 72 61 63 65 46 49 4c 45 20 29 7b 0a 20  yyTraceFILE ){. 
7350: 20 20 20 66 70 72 69 6e 74 66 28 79 79 54 72 61     fprintf(yyTra
7360: 63 65 46 49 4c 45 2c 22 25 73 41 63 63 65 70 74  ceFILE,"%sAccept
7370: 21 5c 6e 22 2c 79 79 54 72 61 63 65 50 72 6f 6d  !\n",yyTraceProm
7380: 70 74 29 3b 0a 20 20 7d 0a 23 65 6e 64 69 66 0a  pt);.  }.#endif.
7390: 23 69 66 6e 64 65 66 20 59 59 4e 4f 45 52 52 4f  #ifndef YYNOERRO
73a0: 52 52 45 43 4f 56 45 52 59 0a 20 20 79 79 70 50  RRECOVERY.  yypP
73b0: 61 72 73 65 72 2d 3e 79 79 65 72 72 63 6e 74 20  arser->yyerrcnt 
73c0: 3d 20 2d 31 3b 0a 23 65 6e 64 69 66 0a 20 20 61  = -1;.#endif.  a
73d0: 73 73 65 72 74 28 20 79 79 70 50 61 72 73 65 72  ssert( yypParser
73e0: 2d 3e 79 79 74 6f 73 3d 3d 79 79 70 50 61 72 73  ->yytos==yypPars
73f0: 65 72 2d 3e 79 79 73 74 61 63 6b 20 29 3b 0a 20  er->yystack );. 
7400: 20 2f 2a 20 48 65 72 65 20 63 6f 64 65 20 69 73   /* Here code is
7410: 20 69 6e 73 65 72 74 65 64 20 77 68 69 63 68 20   inserted which 
7420: 77 69 6c 6c 20 62 65 20 65 78 65 63 75 74 65 64  will be executed
7430: 20 77 68 65 6e 65 76 65 72 20 74 68 65 0a 20 20   whenever the.  
7440: 2a 2a 20 70 61 72 73 65 72 20 61 63 63 65 70 74  ** parser accept
7450: 73 20 2a 2f 0a 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  s */./**********
7460: 2a 20 42 65 67 69 6e 20 25 70 61 72 73 65 5f 61  * Begin %parse_a
7470: 63 63 65 70 74 20 63 6f 64 65 20 2a 2a 2a 2a 2a  ccept code *****
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 2a 2a 2a 2a 2a  ****************
74a0: 2a 2a 2a 2a 2f 0a 25 25 0a 2f 2a 2a 2a 2a 2a 2a  ****/.%%./******
74b0: 2a 2a 2a 2a 2a 20 45 6e 64 20 25 70 61 72 73 65  ***** End %parse
74c0: 5f 61 63 63 65 70 74 20 63 6f 64 65 20 2a 2a 2a  _accept code ***
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 2a  ****************
74f0: 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a 20 20 50 61 72 73  ********/.  Pars
7500: 65 41 52 47 5f 53 54 4f 52 45 20 2f 2a 20 53 75  eARG_STORE /* Su
7510: 70 70 72 65 73 73 20 77 61 72 6e 69 6e 67 20 61  ppress warning a
7520: 62 6f 75 74 20 75 6e 75 73 65 64 20 25 65 78 74  bout unused %ext
7530: 72 61 5f 61 72 67 75 6d 65 6e 74 20 76 61 72 69  ra_argument vari
7540: 61 62 6c 65 20 2a 2f 0a 20 20 50 61 72 73 65 43  able */.  ParseC
7550: 54 58 5f 53 54 4f 52 45 0a 7d 0a 0a 2f 2a 20 54  TX_STORE.}../* T
7560: 68 65 20 6d 61 69 6e 20 70 61 72 73 65 72 20 70  he main parser p
7570: 72 6f 67 72 61 6d 2e 0a 2a 2a 20 54 68 65 20 66  rogram..** The f
7580: 69 72 73 74 20 61 72 67 75 6d 65 6e 74 20 69 73  irst argument is
7590: 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 61 20   a pointer to a 
75a0: 73 74 72 75 63 74 75 72 65 20 6f 62 74 61 69 6e  structure obtain
75b0: 65 64 20 66 72 6f 6d 0a 2a 2a 20 22 50 61 72 73  ed from.** "Pars
75c0: 65 41 6c 6c 6f 63 22 20 77 68 69 63 68 20 64 65  eAlloc" which de
75d0: 73 63 72 69 62 65 73 20 74 68 65 20 63 75 72 72  scribes the curr
75e0: 65 6e 74 20 73 74 61 74 65 20 6f 66 20 74 68 65  ent state of the
75f0: 20 70 61 72 73 65 72 2e 0a 2a 2a 20 54 68 65 20   parser..** The 
7600: 73 65 63 6f 6e 64 20 61 72 67 75 6d 65 6e 74 20  second argument 
7610: 69 73 20 74 68 65 20 6d 61 6a 6f 72 20 74 6f 6b  is the major tok
7620: 65 6e 20 6e 75 6d 62 65 72 2e 20 20 54 68 65 20  en number.  The 
7630: 74 68 69 72 64 20 69 73 0a 2a 2a 20 74 68 65 20  third is.** the 
7640: 6d 69 6e 6f 72 20 74 6f 6b 65 6e 2e 20 20 54 68  minor token.  Th
7650: 65 20 66 6f 75 72 74 68 20 6f 70 74 69 6f 6e 61  e fourth optiona
7660: 6c 20 61 72 67 75 6d 65 6e 74 20 69 73 20 77 68  l argument is wh
7670: 61 74 65 76 65 72 20 74 68 65 0a 2a 2a 20 75 73  atever the.** us
7680: 65 72 20 77 61 6e 74 73 20 28 61 6e 64 20 73 70  er wants (and sp
7690: 65 63 69 66 69 65 64 20 69 6e 20 74 68 65 20 67  ecified in the g
76a0: 72 61 6d 6d 61 72 29 20 61 6e 64 20 69 73 20 61  rammar) and is a
76b0: 76 61 69 6c 61 62 6c 65 20 66 6f 72 0a 2a 2a 20  vailable for.** 
76c0: 75 73 65 20 62 79 20 74 68 65 20 61 63 74 69 6f  use by the actio
76d0: 6e 20 72 6f 75 74 69 6e 65 73 2e 0a 2a 2a 0a 2a  n routines..**.*
76e0: 2a 20 49 6e 70 75 74 73 3a 0a 2a 2a 20 3c 75 6c  * Inputs:.** <ul
76f0: 3e 0a 2a 2a 20 3c 6c 69 3e 20 41 20 70 6f 69 6e  >.** <li> A poin
7700: 74 65 72 20 74 6f 20 74 68 65 20 70 61 72 73 65  ter to the parse
7710: 72 20 28 61 6e 20 6f 70 61 71 75 65 20 73 74 72  r (an opaque str
7720: 75 63 74 75 72 65 2e 29 0a 2a 2a 20 3c 6c 69 3e  ucture.).** <li>
7730: 20 54 68 65 20 6d 61 6a 6f 72 20 74 6f 6b 65 6e   The major token
7740: 20 6e 75 6d 62 65 72 2e 0a 2a 2a 20 3c 6c 69 3e   number..** <li>
7750: 20 54 68 65 20 6d 69 6e 6f 72 20 74 6f 6b 65 6e   The minor token
7760: 20 6e 75 6d 62 65 72 2e 0a 2a 2a 20 3c 6c 69 3e   number..** <li>
7770: 20 41 6e 20 6f 70 74 69 6f 6e 20 61 72 67 75 6d   An option argum
7780: 65 6e 74 20 6f 66 20 61 20 67 72 61 6d 6d 61 72  ent of a grammar
7790: 2d 73 70 65 63 69 66 69 65 64 20 74 79 70 65 2e  -specified type.
77a0: 0a 2a 2a 20 3c 2f 75 6c 3e 0a 2a 2a 0a 2a 2a 20  .** </ul>.**.** 
77b0: 4f 75 74 70 75 74 73 3a 0a 2a 2a 20 4e 6f 6e 65  Outputs:.** None
77c0: 2e 0a 2a 2f 0a 76 6f 69 64 20 50 61 72 73 65 28  ..*/.void Parse(
77d0: 0a 20 20 76 6f 69 64 20 2a 79 79 70 2c 20 20 20  .  void *yyp,   
77e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
77f0: 2f 2a 20 54 68 65 20 70 61 72 73 65 72 20 2a 2f  /* The parser */
7800: 0a 20 20 69 6e 74 20 79 79 6d 61 6a 6f 72 2c 20  .  int yymajor, 
7810: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7820: 2f 2a 20 54 68 65 20 6d 61 6a 6f 72 20 74 6f 6b  /* The major tok
7830: 65 6e 20 63 6f 64 65 20 6e 75 6d 62 65 72 20 2a  en code number *
7840: 2f 0a 20 20 50 61 72 73 65 54 4f 4b 45 4e 54 59  /.  ParseTOKENTY
7850: 50 45 20 79 79 6d 69 6e 6f 72 20 20 20 20 20 20  PE yyminor      
7860: 20 2f 2a 20 54 68 65 20 76 61 6c 75 65 20 66 6f   /* The value fo
7870: 72 20 74 68 65 20 74 6f 6b 65 6e 20 2a 2f 0a 20  r the token */. 
7880: 20 50 61 72 73 65 41 52 47 5f 50 44 45 43 4c 20   ParseARG_PDECL 
7890: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
78a0: 20 4f 70 74 69 6f 6e 61 6c 20 25 65 78 74 72 61   Optional %extra
78b0: 5f 61 72 67 75 6d 65 6e 74 20 70 61 72 61 6d 65  _argument parame
78c0: 74 65 72 20 2a 2f 0a 29 7b 0a 20 20 59 59 4d 49  ter */.){.  YYMI
78d0: 4e 4f 52 54 59 50 45 20 79 79 6d 69 6e 6f 72 75  NORTYPE yyminoru
78e0: 6e 69 6f 6e 3b 0a 20 20 59 59 41 43 54 49 4f 4e  nion;.  YYACTION
78f0: 54 59 50 45 20 79 79 61 63 74 3b 20 20 20 2f 2a  TYPE yyact;   /*
7900: 20 54 68 65 20 70 61 72 73 65 72 20 61 63 74 69   The parser acti
7910: 6f 6e 2e 20 2a 2f 0a 23 69 66 20 21 64 65 66 69  on. */.#if !defi
7920: 6e 65 64 28 59 59 45 52 52 4f 52 53 59 4d 42 4f  ned(YYERRORSYMBO
7930: 4c 29 20 26 26 20 21 64 65 66 69 6e 65 64 28 59  L) && !defined(Y
7940: 59 4e 4f 45 52 52 4f 52 52 45 43 4f 56 45 52 59  YNOERRORRECOVERY
7950: 29 0a 20 20 69 6e 74 20 79 79 65 6e 64 6f 66 69  ).  int yyendofi
7960: 6e 70 75 74 3b 20 20 20 20 20 2f 2a 20 54 72 75  nput;     /* Tru
7970: 65 20 69 66 20 77 65 20 61 72 65 20 61 74 20 74  e if we are at t
7980: 68 65 20 65 6e 64 20 6f 66 20 69 6e 70 75 74 20  he end of input 
7990: 2a 2f 0a 23 65 6e 64 69 66 0a 23 69 66 64 65 66  */.#endif.#ifdef
79a0: 20 59 59 45 52 52 4f 52 53 59 4d 42 4f 4c 0a 20   YYERRORSYMBOL. 
79b0: 20 69 6e 74 20 79 79 65 72 72 6f 72 68 69 74 20   int yyerrorhit 
79c0: 3d 20 30 3b 20 20 20 2f 2a 20 54 72 75 65 20 69  = 0;   /* True i
79d0: 66 20 79 79 6d 61 6a 6f 72 20 68 61 73 20 69 6e  f yymajor has in
79e0: 76 6f 6b 65 64 20 61 6e 20 65 72 72 6f 72 20 2a  voked an error *
79f0: 2f 0a 23 65 6e 64 69 66 0a 20 20 79 79 50 61 72  /.#endif.  yyPar
7a00: 73 65 72 20 2a 79 79 70 50 61 72 73 65 72 20 3d  ser *yypParser =
7a10: 20 28 79 79 50 61 72 73 65 72 2a 29 79 79 70 3b   (yyParser*)yyp;
7a20: 20 20 2f 2a 20 54 68 65 20 70 61 72 73 65 72 20    /* The parser 
7a30: 2a 2f 0a 20 20 50 61 72 73 65 43 54 58 5f 46 45  */.  ParseCTX_FE
7a40: 54 43 48 0a 20 20 50 61 72 73 65 41 52 47 5f 53  TCH.  ParseARG_S
7a50: 54 4f 52 45 0a 0a 20 20 61 73 73 65 72 74 28 20  TORE..  assert( 
7a60: 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74 6f 73  yypParser->yytos
7a70: 21 3d 30 20 29 3b 0a 23 69 66 20 21 64 65 66 69  !=0 );.#if !defi
7a80: 6e 65 64 28 59 59 45 52 52 4f 52 53 59 4d 42 4f  ned(YYERRORSYMBO
7a90: 4c 29 20 26 26 20 21 64 65 66 69 6e 65 64 28 59  L) && !defined(Y
7aa0: 59 4e 4f 45 52 52 4f 52 52 45 43 4f 56 45 52 59  YNOERRORRECOVERY
7ab0: 29 0a 20 20 79 79 65 6e 64 6f 66 69 6e 70 75 74  ).  yyendofinput
7ac0: 20 3d 20 28 79 79 6d 61 6a 6f 72 3d 3d 30 29 3b   = (yymajor==0);
7ad0: 0a 23 65 6e 64 69 66 0a 0a 20 20 79 79 61 63 74  .#endif..  yyact
7ae0: 20 3d 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79   = yypParser->yy
7af0: 74 6f 73 2d 3e 73 74 61 74 65 6e 6f 3b 0a 23 69  tos->stateno;.#i
7b00: 66 6e 64 65 66 20 4e 44 45 42 55 47 0a 20 20 69  fndef NDEBUG.  i
7b10: 66 28 20 79 79 54 72 61 63 65 46 49 4c 45 20 29  f( yyTraceFILE )
7b20: 7b 0a 20 20 20 20 69 66 28 20 79 79 61 63 74 20  {.    if( yyact 
7b30: 3c 20 59 59 5f 4d 49 4e 5f 52 45 44 55 43 45 20  < YY_MIN_REDUCE 
7b40: 29 7b 0a 20 20 20 20 20 20 66 70 72 69 6e 74 66  ){.      fprintf
7b50: 28 79 79 54 72 61 63 65 46 49 4c 45 2c 22 25 73  (yyTraceFILE,"%s
7b60: 49 6e 70 75 74 20 27 25 73 27 20 69 6e 20 73 74  Input '%s' in st
7b70: 61 74 65 20 25 64 5c 6e 22 2c 0a 20 20 20 20 20  ate %d\n",.     
7b80: 20 20 20 20 20 20 20 20 20 79 79 54 72 61 63 65           yyTrace
7b90: 50 72 6f 6d 70 74 2c 79 79 54 6f 6b 65 6e 4e 61  Prompt,yyTokenNa
7ba0: 6d 65 5b 79 79 6d 61 6a 6f 72 5d 2c 79 79 61 63  me[yymajor],yyac
7bb0: 74 29 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20  t);.    }else{. 
7bc0: 20 20 20 20 20 66 70 72 69 6e 74 66 28 79 79 54       fprintf(yyT
7bd0: 72 61 63 65 46 49 4c 45 2c 22 25 73 49 6e 70 75  raceFILE,"%sInpu
7be0: 74 20 27 25 73 27 20 77 69 74 68 20 70 65 6e 64  t '%s' with pend
7bf0: 69 6e 67 20 72 65 64 75 63 65 20 25 64 5c 6e 22  ing reduce %d\n"
7c00: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,.              
7c10: 79 79 54 72 61 63 65 50 72 6f 6d 70 74 2c 79 79  yyTracePrompt,yy
7c20: 54 6f 6b 65 6e 4e 61 6d 65 5b 79 79 6d 61 6a 6f  TokenName[yymajo
7c30: 72 5d 2c 79 79 61 63 74 2d 59 59 5f 4d 49 4e 5f  r],yyact-YY_MIN_
7c40: 52 45 44 55 43 45 29 3b 0a 20 20 20 20 7d 0a 20  REDUCE);.    }. 
7c50: 20 7d 0a 23 65 6e 64 69 66 0a 0a 20 20 64 6f 7b   }.#endif..  do{
7c60: 0a 20 20 20 20 61 73 73 65 72 74 28 20 79 79 61  .    assert( yya
7c70: 63 74 3d 3d 79 79 70 50 61 72 73 65 72 2d 3e 79  ct==yypParser->y
7c80: 79 74 6f 73 2d 3e 73 74 61 74 65 6e 6f 20 29 3b  ytos->stateno );
7c90: 0a 20 20 20 20 79 79 61 63 74 20 3d 20 79 79 5f  .    yyact = yy_
7ca0: 66 69 6e 64 5f 73 68 69 66 74 5f 61 63 74 69 6f  find_shift_actio
7cb0: 6e 28 28 59 59 43 4f 44 45 54 59 50 45 29 79 79  n((YYCODETYPE)yy
7cc0: 6d 61 6a 6f 72 2c 79 79 61 63 74 29 3b 0a 20 20  major,yyact);.  
7cd0: 20 20 69 66 28 20 79 79 61 63 74 20 3e 3d 20 59    if( yyact >= Y
7ce0: 59 5f 4d 49 4e 5f 52 45 44 55 43 45 20 29 7b 0a  Y_MIN_REDUCE ){.
7cf0: 20 20 20 20 20 20 79 79 61 63 74 20 3d 20 79 79        yyact = yy
7d00: 5f 72 65 64 75 63 65 28 79 79 70 50 61 72 73 65  _reduce(yypParse
7d10: 72 2c 79 79 61 63 74 2d 59 59 5f 4d 49 4e 5f 52  r,yyact-YY_MIN_R
7d20: 45 44 55 43 45 2c 79 79 6d 61 6a 6f 72 2c 0a 20  EDUCE,yymajor,. 
7d30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7d40: 20 20 20 20 20 20 20 79 79 6d 69 6e 6f 72 20 50         yyminor P
7d50: 61 72 73 65 43 54 58 5f 50 41 52 41 4d 29 3b 0a  arseCTX_PARAM);.
7d60: 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 79 79      }else if( yy
7d70: 61 63 74 20 3c 3d 20 59 59 5f 4d 41 58 5f 53 48  act <= YY_MAX_SH
7d80: 49 46 54 52 45 44 55 43 45 20 29 7b 0a 20 20 20  IFTREDUCE ){.   
7d90: 20 20 20 79 79 5f 73 68 69 66 74 28 79 79 70 50     yy_shift(yypP
7da0: 61 72 73 65 72 2c 79 79 61 63 74 2c 28 59 59 43  arser,yyact,(YYC
7db0: 4f 44 45 54 59 50 45 29 79 79 6d 61 6a 6f 72 2c  ODETYPE)yymajor,
7dc0: 79 79 6d 69 6e 6f 72 29 3b 0a 23 69 66 6e 64 65  yyminor);.#ifnde
7dd0: 66 20 59 59 4e 4f 45 52 52 4f 52 52 45 43 4f 56  f YYNOERRORRECOV
7de0: 45 52 59 0a 20 20 20 20 20 20 79 79 70 50 61 72  ERY.      yypPar
7df0: 73 65 72 2d 3e 79 79 65 72 72 63 6e 74 2d 2d 3b  ser->yyerrcnt--;
7e00: 0a 23 65 6e 64 69 66 0a 20 20 20 20 20 20 62 72  .#endif.      br
7e10: 65 61 6b 3b 0a 20 20 20 20 7d 65 6c 73 65 20 69  eak;.    }else i
7e20: 66 28 20 79 79 61 63 74 3d 3d 59 59 5f 41 43 43  f( yyact==YY_ACC
7e30: 45 50 54 5f 41 43 54 49 4f 4e 20 29 7b 0a 20 20  EPT_ACTION ){.  
7e40: 20 20 20 20 79 79 70 50 61 72 73 65 72 2d 3e 79      yypParser->y
7e50: 79 74 6f 73 2d 2d 3b 0a 20 20 20 20 20 20 79 79  ytos--;.      yy
7e60: 5f 61 63 63 65 70 74 28 79 79 70 50 61 72 73 65  _accept(yypParse
7e70: 72 29 3b 0a 20 20 20 20 20 20 72 65 74 75 72 6e  r);.      return
7e80: 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20  ;.    }else{.   
7e90: 20 20 20 61 73 73 65 72 74 28 20 79 79 61 63 74     assert( yyact
7ea0: 20 3d 3d 20 59 59 5f 45 52 52 4f 52 5f 41 43 54   == YY_ERROR_ACT
7eb0: 49 4f 4e 20 29 3b 0a 20 20 20 20 20 20 79 79 6d  ION );.      yym
7ec0: 69 6e 6f 72 75 6e 69 6f 6e 2e 79 79 30 20 3d 20  inorunion.yy0 = 
7ed0: 79 79 6d 69 6e 6f 72 3b 0a 23 69 66 64 65 66 20  yyminor;.#ifdef 
7ee0: 59 59 45 52 52 4f 52 53 59 4d 42 4f 4c 0a 20 20  YYERRORSYMBOL.  
7ef0: 20 20 20 20 69 6e 74 20 79 79 6d 78 3b 0a 23 65      int yymx;.#e
7f00: 6e 64 69 66 0a 23 69 66 6e 64 65 66 20 4e 44 45  ndif.#ifndef NDE
7f10: 42 55 47 0a 20 20 20 20 20 20 69 66 28 20 79 79  BUG.      if( yy
7f20: 54 72 61 63 65 46 49 4c 45 20 29 7b 0a 20 20 20  TraceFILE ){.   
7f30: 20 20 20 20 20 66 70 72 69 6e 74 66 28 79 79 54       fprintf(yyT
7f40: 72 61 63 65 46 49 4c 45 2c 22 25 73 53 79 6e 74  raceFILE,"%sSynt
7f50: 61 78 20 45 72 72 6f 72 21 5c 6e 22 2c 79 79 54  ax Error!\n",yyT
7f60: 72 61 63 65 50 72 6f 6d 70 74 29 3b 0a 20 20 20  racePrompt);.   
7f70: 20 20 20 7d 0a 23 65 6e 64 69 66 0a 23 69 66 64     }.#endif.#ifd
7f80: 65 66 20 59 59 45 52 52 4f 52 53 59 4d 42 4f 4c  ef YYERRORSYMBOL
7f90: 0a 20 20 20 20 20 20 2f 2a 20 41 20 73 79 6e 74  .      /* A synt
7fa0: 61 78 20 65 72 72 6f 72 20 68 61 73 20 6f 63 63  ax error has occ
7fb0: 75 72 72 65 64 2e 0a 20 20 20 20 20 20 2a 2a 20  urred..      ** 
7fc0: 54 68 65 20 72 65 73 70 6f 6e 73 65 20 74 6f 20  The response to 
7fd0: 61 6e 20 65 72 72 6f 72 20 64 65 70 65 6e 64 73  an error depends
7fe0: 20 75 70 6f 6e 20 77 68 65 74 68 65 72 20 6f 72   upon whether or
7ff0: 20 6e 6f 74 20 74 68 65 0a 20 20 20 20 20 20 2a   not the.      *
8000: 2a 20 67 72 61 6d 6d 61 72 20 64 65 66 69 6e 65  * grammar define
8010: 73 20 61 6e 20 65 72 72 6f 72 20 74 6f 6b 65 6e  s an error token
8020: 20 22 45 52 52 4f 52 22 2e 20 20 0a 20 20 20 20   "ERROR".  .    
8030: 20 20 2a 2a 0a 20 20 20 20 20 20 2a 2a 20 54 68    **.      ** Th
8040: 69 73 20 69 73 20 77 68 61 74 20 77 65 20 64 6f  is is what we do
8050: 20 69 66 20 74 68 65 20 67 72 61 6d 6d 61 72 20   if the grammar 
8060: 64 6f 65 73 20 64 65 66 69 6e 65 20 45 52 52 4f  does define ERRO
8070: 52 3a 0a 20 20 20 20 20 20 2a 2a 0a 20 20 20 20  R:.      **.    
8080: 20 20 2a 2a 20 20 2a 20 43 61 6c 6c 20 74 68 65    **  * Call the
8090: 20 25 73 79 6e 74 61 78 5f 65 72 72 6f 72 20 66   %syntax_error f
80a0: 75 6e 63 74 69 6f 6e 2e 0a 20 20 20 20 20 20 2a  unction..      *
80b0: 2a 0a 20 20 20 20 20 20 2a 2a 20 20 2a 20 42 65  *.      **  * Be
80c0: 67 69 6e 20 70 6f 70 70 69 6e 67 20 74 68 65 20  gin popping the 
80d0: 73 74 61 63 6b 20 75 6e 74 69 6c 20 77 65 20 65  stack until we e
80e0: 6e 74 65 72 20 61 20 73 74 61 74 65 20 77 68 65  nter a state whe
80f0: 72 65 0a 20 20 20 20 20 20 2a 2a 20 20 20 20 69  re.      **    i
8100: 74 20 69 73 20 6c 65 67 61 6c 20 74 6f 20 73 68  t is legal to sh
8110: 69 66 74 20 74 68 65 20 65 72 72 6f 72 20 73 79  ift the error sy
8120: 6d 62 6f 6c 2c 20 74 68 65 6e 20 73 68 69 66 74  mbol, then shift
8130: 0a 20 20 20 20 20 20 2a 2a 20 20 20 20 74 68 65  .      **    the
8140: 20 65 72 72 6f 72 20 73 79 6d 62 6f 6c 2e 0a 20   error symbol.. 
8150: 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 2a 2a       **.      **
8160: 20 20 2a 20 53 65 74 20 74 68 65 20 65 72 72 6f    * Set the erro
8170: 72 20 63 6f 75 6e 74 20 74 6f 20 74 68 72 65 65  r count to three
8180: 2e 0a 20 20 20 20 20 20 2a 2a 0a 20 20 20 20 20  ..      **.     
8190: 20 2a 2a 20 20 2a 20 42 65 67 69 6e 20 61 63 63   **  * Begin acc
81a0: 65 70 74 69 6e 67 20 61 6e 64 20 73 68 69 66 74  epting and shift
81b0: 69 6e 67 20 6e 65 77 20 74 6f 6b 65 6e 73 2e 20  ing new tokens. 
81c0: 20 4e 6f 20 6e 65 77 20 65 72 72 6f 72 0a 20 20   No new error.  
81d0: 20 20 20 20 2a 2a 20 20 20 20 70 72 6f 63 65 73      **    proces
81e0: 73 69 6e 67 20 77 69 6c 6c 20 6f 63 63 75 72 20  sing will occur 
81f0: 75 6e 74 69 6c 20 74 68 72 65 65 20 74 6f 6b 65  until three toke
8200: 6e 73 20 68 61 76 65 20 62 65 65 6e 0a 20 20 20  ns have been.   
8210: 20 20 20 2a 2a 20 20 20 20 73 68 69 66 74 65 64     **    shifted
8220: 20 73 75 63 63 65 73 73 66 75 6c 6c 79 2e 0a 20   successfully.. 
8230: 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 2a 2f       **.      */
8240: 0a 20 20 20 20 20 20 69 66 28 20 79 79 70 50 61  .      if( yypPa
8250: 72 73 65 72 2d 3e 79 79 65 72 72 63 6e 74 3c 30  rser->yyerrcnt<0
8260: 20 29 7b 0a 20 20 20 20 20 20 20 20 79 79 5f 73   ){.        yy_s
8270: 79 6e 74 61 78 5f 65 72 72 6f 72 28 79 79 70 50  yntax_error(yypP
8280: 61 72 73 65 72 2c 79 79 6d 61 6a 6f 72 2c 79 79  arser,yymajor,yy
8290: 6d 69 6e 6f 72 29 3b 0a 20 20 20 20 20 20 7d 0a  minor);.      }.
82a0: 20 20 20 20 20 20 79 79 6d 78 20 3d 20 79 79 70        yymx = yyp
82b0: 50 61 72 73 65 72 2d 3e 79 79 74 6f 73 2d 3e 6d  Parser->yytos->m
82c0: 61 6a 6f 72 3b 0a 20 20 20 20 20 20 69 66 28 20  ajor;.      if( 
82d0: 79 79 6d 78 3d 3d 59 59 45 52 52 4f 52 53 59 4d  yymx==YYERRORSYM
82e0: 42 4f 4c 20 7c 7c 20 79 79 65 72 72 6f 72 68 69  BOL || yyerrorhi
82f0: 74 20 29 7b 0a 23 69 66 6e 64 65 66 20 4e 44 45  t ){.#ifndef NDE
8300: 42 55 47 0a 20 20 20 20 20 20 20 20 69 66 28 20  BUG.        if( 
8310: 79 79 54 72 61 63 65 46 49 4c 45 20 29 7b 0a 20  yyTraceFILE ){. 
8320: 20 20 20 20 20 20 20 20 20 66 70 72 69 6e 74 66           fprintf
8330: 28 79 79 54 72 61 63 65 46 49 4c 45 2c 22 25 73  (yyTraceFILE,"%s
8340: 44 69 73 63 61 72 64 20 69 6e 70 75 74 20 74 6f  Discard input to
8350: 6b 65 6e 20 25 73 5c 6e 22 2c 0a 20 20 20 20 20  ken %s\n",.     
8360: 20 20 20 20 20 20 20 20 79 79 54 72 61 63 65 50          yyTraceP
8370: 72 6f 6d 70 74 2c 79 79 54 6f 6b 65 6e 4e 61 6d  rompt,yyTokenNam
8380: 65 5b 79 79 6d 61 6a 6f 72 5d 29 3b 0a 20 20 20  e[yymajor]);.   
8390: 20 20 20 20 20 7d 0a 23 65 6e 64 69 66 0a 20 20       }.#endif.  
83a0: 20 20 20 20 20 20 79 79 5f 64 65 73 74 72 75 63        yy_destruc
83b0: 74 6f 72 28 79 79 70 50 61 72 73 65 72 2c 20 28  tor(yypParser, (
83c0: 59 59 43 4f 44 45 54 59 50 45 29 79 79 6d 61 6a  YYCODETYPE)yymaj
83d0: 6f 72 2c 20 26 79 79 6d 69 6e 6f 72 75 6e 69 6f  or, &yyminorunio
83e0: 6e 29 3b 0a 20 20 20 20 20 20 20 20 79 79 6d 61  n);.        yyma
83f0: 6a 6f 72 20 3d 20 59 59 4e 4f 43 4f 44 45 3b 0a  jor = YYNOCODE;.
8400: 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20        }else{.   
8410: 20 20 20 20 20 77 68 69 6c 65 28 20 79 79 70 50       while( yypP
8420: 61 72 73 65 72 2d 3e 79 79 74 6f 73 20 3e 3d 20  arser->yytos >= 
8430: 79 79 70 50 61 72 73 65 72 2d 3e 79 79 73 74 61  yypParser->yysta
8440: 63 6b 0a 20 20 20 20 20 20 20 20 20 20 20 20 26  ck.            &
8450: 26 20 79 79 6d 78 20 21 3d 20 59 59 45 52 52 4f  & yymx != YYERRO
8460: 52 53 59 4d 42 4f 4c 0a 20 20 20 20 20 20 20 20  RSYMBOL.        
8470: 20 20 20 20 26 26 20 28 79 79 61 63 74 20 3d 20      && (yyact = 
8480: 79 79 5f 66 69 6e 64 5f 72 65 64 75 63 65 5f 61  yy_find_reduce_a
8490: 63 74 69 6f 6e 28 0a 20 20 20 20 20 20 20 20 20  ction(.         
84a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 79                 y
84b0: 79 70 50 61 72 73 65 72 2d 3e 79 79 74 6f 73 2d  ypParser->yytos-
84c0: 3e 73 74 61 74 65 6e 6f 2c 0a 20 20 20 20 20 20  >stateno,.      
84d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
84e0: 20 20 59 59 45 52 52 4f 52 53 59 4d 42 4f 4c 29    YYERRORSYMBOL)
84f0: 29 20 3e 3d 20 59 59 5f 4d 49 4e 5f 52 45 44 55  ) >= YY_MIN_REDU
8500: 43 45 0a 20 20 20 20 20 20 20 20 29 7b 0a 20 20  CE.        ){.  
8510: 20 20 20 20 20 20 20 20 79 79 5f 70 6f 70 5f 70          yy_pop_p
8520: 61 72 73 65 72 5f 73 74 61 63 6b 28 79 79 70 50  arser_stack(yypP
8530: 61 72 73 65 72 29 3b 0a 20 20 20 20 20 20 20 20  arser);.        
8540: 7d 0a 20 20 20 20 20 20 20 20 69 66 28 20 79 79  }.        if( yy
8550: 70 50 61 72 73 65 72 2d 3e 79 79 74 6f 73 20 3c  pParser->yytos <
8560: 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79 73 74   yypParser->yyst
8570: 61 63 6b 20 7c 7c 20 79 79 6d 61 6a 6f 72 3d 3d  ack || yymajor==
8580: 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 79  0 ){.          y
8590: 79 5f 64 65 73 74 72 75 63 74 6f 72 28 79 79 70  y_destructor(yyp
85a0: 50 61 72 73 65 72 2c 28 59 59 43 4f 44 45 54 59  Parser,(YYCODETY
85b0: 50 45 29 79 79 6d 61 6a 6f 72 2c 26 79 79 6d 69  PE)yymajor,&yymi
85c0: 6e 6f 72 75 6e 69 6f 6e 29 3b 0a 20 20 20 20 20  norunion);.     
85d0: 20 20 20 20 20 79 79 5f 70 61 72 73 65 5f 66 61       yy_parse_fa
85e0: 69 6c 65 64 28 79 79 70 50 61 72 73 65 72 29 3b  iled(yypParser);
85f0: 0a 23 69 66 6e 64 65 66 20 59 59 4e 4f 45 52 52  .#ifndef YYNOERR
8600: 4f 52 52 45 43 4f 56 45 52 59 0a 20 20 20 20 20  ORRECOVERY.     
8610: 20 20 20 20 20 79 79 70 50 61 72 73 65 72 2d 3e       yypParser->
8620: 79 79 65 72 72 63 6e 74 20 3d 20 2d 31 3b 0a 23  yyerrcnt = -1;.#
8630: 65 6e 64 69 66 0a 20 20 20 20 20 20 20 20 20 20  endif.          
8640: 79 79 6d 61 6a 6f 72 20 3d 20 59 59 4e 4f 43 4f  yymajor = YYNOCO
8650: 44 45 3b 0a 20 20 20 20 20 20 20 20 7d 65 6c 73  DE;.        }els
8660: 65 20 69 66 28 20 79 79 6d 78 21 3d 59 59 45 52  e if( yymx!=YYER
8670: 52 4f 52 53 59 4d 42 4f 4c 20 29 7b 0a 20 20 20  RORSYMBOL ){.   
8680: 20 20 20 20 20 20 20 79 79 5f 73 68 69 66 74 28         yy_shift(
8690: 79 79 70 50 61 72 73 65 72 2c 79 79 61 63 74 2c  yypParser,yyact,
86a0: 59 59 45 52 52 4f 52 53 59 4d 42 4f 4c 2c 79 79  YYERRORSYMBOL,yy
86b0: 6d 69 6e 6f 72 29 3b 0a 20 20 20 20 20 20 20 20  minor);.        
86c0: 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20  }.      }.      
86d0: 79 79 70 50 61 72 73 65 72 2d 3e 79 79 65 72 72  yypParser->yyerr
86e0: 63 6e 74 20 3d 20 33 3b 0a 20 20 20 20 20 20 79  cnt = 3;.      y
86f0: 79 65 72 72 6f 72 68 69 74 20 3d 20 31 3b 0a 20  yerrorhit = 1;. 
8700: 20 20 20 20 20 69 66 28 20 79 79 6d 61 6a 6f 72       if( yymajor
8710: 3d 3d 59 59 4e 4f 43 4f 44 45 20 29 20 62 72 65  ==YYNOCODE ) bre
8720: 61 6b 3b 0a 20 20 20 20 20 20 79 79 61 63 74 20  ak;.      yyact 
8730: 3d 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74  = yypParser->yyt
8740: 6f 73 2d 3e 73 74 61 74 65 6e 6f 3b 0a 23 65 6c  os->stateno;.#el
8750: 69 66 20 64 65 66 69 6e 65 64 28 59 59 4e 4f 45  if defined(YYNOE
8760: 52 52 4f 52 52 45 43 4f 56 45 52 59 29 0a 20 20  RRORRECOVERY).  
8770: 20 20 20 20 2f 2a 20 49 66 20 74 68 65 20 59 59      /* If the YY
8780: 4e 4f 45 52 52 4f 52 52 45 43 4f 56 45 52 59 20  NOERRORRECOVERY 
8790: 6d 61 63 72 6f 20 69 73 20 64 65 66 69 6e 65 64  macro is defined
87a0: 2c 20 74 68 65 6e 20 64 6f 20 6e 6f 74 20 61 74  , then do not at
87b0: 74 65 6d 70 74 20 74 6f 0a 20 20 20 20 20 20 2a  tempt to.      *
87c0: 2a 20 64 6f 20 61 6e 79 20 6b 69 6e 64 20 6f 66  * do any kind of
87d0: 20 65 72 72 6f 72 20 72 65 63 6f 76 65 72 79 2e   error recovery.
87e0: 20 20 49 6e 73 74 65 61 64 2c 20 73 69 6d 70 6c    Instead, simpl
87f0: 79 20 69 6e 76 6f 6b 65 20 74 68 65 20 73 79 6e  y invoke the syn
8800: 74 61 78 0a 20 20 20 20 20 20 2a 2a 20 65 72 72  tax.      ** err
8810: 6f 72 20 72 6f 75 74 69 6e 65 20 61 6e 64 20 63  or routine and c
8820: 6f 6e 74 69 6e 75 65 20 67 6f 69 6e 67 20 61 73  ontinue going as
8830: 20 69 66 20 6e 6f 74 68 69 6e 67 20 68 61 64 20   if nothing had 
8840: 68 61 70 70 65 6e 65 64 2e 0a 20 20 20 20 20 20  happened..      
8850: 2a 2a 0a 20 20 20 20 20 20 2a 2a 20 41 70 70 6c  **.      ** Appl
8860: 69 63 61 74 69 6f 6e 73 20 63 61 6e 20 73 65 74  ications can set
8870: 20 74 68 69 73 20 6d 61 63 72 6f 20 28 66 6f 72   this macro (for
8880: 20 65 78 61 6d 70 6c 65 20 69 6e 73 69 64 65 20   example inside 
8890: 25 69 6e 63 6c 75 64 65 29 20 69 66 0a 20 20 20  %include) if.   
88a0: 20 20 20 2a 2a 20 74 68 65 79 20 69 6e 74 65 6e     ** they inten
88b0: 64 20 74 6f 20 61 62 61 6e 64 6f 6e 20 74 68 65  d to abandon the
88c0: 20 70 61 72 73 65 20 75 70 6f 6e 20 74 68 65 20   parse upon the 
88d0: 66 69 72 73 74 20 73 79 6e 74 61 78 20 65 72 72  first syntax err
88e0: 6f 72 20 73 65 65 6e 2e 0a 20 20 20 20 20 20 2a  or seen..      *
88f0: 2f 0a 20 20 20 20 20 20 79 79 5f 73 79 6e 74 61  /.      yy_synta
8900: 78 5f 65 72 72 6f 72 28 79 79 70 50 61 72 73 65  x_error(yypParse
8910: 72 2c 79 79 6d 61 6a 6f 72 2c 20 79 79 6d 69 6e  r,yymajor, yymin
8920: 6f 72 29 3b 0a 20 20 20 20 20 20 79 79 5f 64 65  or);.      yy_de
8930: 73 74 72 75 63 74 6f 72 28 79 79 70 50 61 72 73  structor(yypPars
8940: 65 72 2c 28 59 59 43 4f 44 45 54 59 50 45 29 79  er,(YYCODETYPE)y
8950: 79 6d 61 6a 6f 72 2c 26 79 79 6d 69 6e 6f 72 75  ymajor,&yyminoru
8960: 6e 69 6f 6e 29 3b 0a 20 20 20 20 20 20 62 72 65  nion);.      bre
8970: 61 6b 3b 0a 23 65 6c 73 65 20 20 2f 2a 20 59 59  ak;.#else  /* YY
8980: 45 52 52 4f 52 53 59 4d 42 4f 4c 20 69 73 20 6e  ERRORSYMBOL is n
8990: 6f 74 20 64 65 66 69 6e 65 64 20 2a 2f 0a 20 20  ot defined */.  
89a0: 20 20 20 20 2f 2a 20 54 68 69 73 20 69 73 20 77      /* This is w
89b0: 68 61 74 20 77 65 20 64 6f 20 69 66 20 74 68 65  hat we do if the
89c0: 20 67 72 61 6d 6d 61 72 20 64 6f 65 73 20 6e 6f   grammar does no
89d0: 74 20 64 65 66 69 6e 65 20 45 52 52 4f 52 3a 0a  t define ERROR:.
89e0: 20 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 2a        **.      *
89f0: 2a 20 20 2a 20 52 65 70 6f 72 74 20 61 6e 20 65  *  * Report an e
8a00: 72 72 6f 72 20 6d 65 73 73 61 67 65 2c 20 61 6e  rror message, an
8a10: 64 20 74 68 72 6f 77 20 61 77 61 79 20 74 68 65  d throw away the
8a20: 20 69 6e 70 75 74 20 74 6f 6b 65 6e 2e 0a 20 20   input token..  
8a30: 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 2a 2a 20      **.      ** 
8a40: 20 2a 20 49 66 20 74 68 65 20 69 6e 70 75 74 20   * If the input 
8a50: 74 6f 6b 65 6e 20 69 73 20 24 2c 20 74 68 65 6e  token is $, then
8a60: 20 66 61 69 6c 20 74 68 65 20 70 61 72 73 65 2e   fail the parse.
8a70: 0a 20 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20  .      **.      
8a80: 2a 2a 20 41 73 20 62 65 66 6f 72 65 2c 20 73 75  ** As before, su
8a90: 62 73 65 71 75 65 6e 74 20 65 72 72 6f 72 20 6d  bsequent error m
8aa0: 65 73 73 61 67 65 73 20 61 72 65 20 73 75 70 70  essages are supp
8ab0: 72 65 73 73 65 64 20 75 6e 74 69 6c 0a 20 20 20  ressed until.   
8ac0: 20 20 20 2a 2a 20 74 68 72 65 65 20 69 6e 70 75     ** three inpu
8ad0: 74 20 74 6f 6b 65 6e 73 20 68 61 76 65 20 62 65  t tokens have be
8ae0: 65 6e 20 73 75 63 63 65 73 73 66 75 6c 6c 79 20  en successfully 
8af0: 73 68 69 66 74 65 64 2e 0a 20 20 20 20 20 20 2a  shifted..      *
8b00: 2f 0a 20 20 20 20 20 20 69 66 28 20 79 79 70 50  /.      if( yypP
8b10: 61 72 73 65 72 2d 3e 79 79 65 72 72 63 6e 74 3c  arser->yyerrcnt<
8b20: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 79 79  =0 ){.        yy
8b30: 5f 73 79 6e 74 61 78 5f 65 72 72 6f 72 28 79 79  _syntax_error(yy
8b40: 70 50 61 72 73 65 72 2c 79 79 6d 61 6a 6f 72 2c  pParser,yymajor,
8b50: 20 79 79 6d 69 6e 6f 72 29 3b 0a 20 20 20 20 20   yyminor);.     
8b60: 20 7d 0a 20 20 20 20 20 20 79 79 70 50 61 72 73   }.      yypPars
8b70: 65 72 2d 3e 79 79 65 72 72 63 6e 74 20 3d 20 33  er->yyerrcnt = 3
8b80: 3b 0a 20 20 20 20 20 20 79 79 5f 64 65 73 74 72  ;.      yy_destr
8b90: 75 63 74 6f 72 28 79 79 70 50 61 72 73 65 72 2c  uctor(yypParser,
8ba0: 28 59 59 43 4f 44 45 54 59 50 45 29 79 79 6d 61  (YYCODETYPE)yyma
8bb0: 6a 6f 72 2c 26 79 79 6d 69 6e 6f 72 75 6e 69 6f  jor,&yyminorunio
8bc0: 6e 29 3b 0a 20 20 20 20 20 20 69 66 28 20 79 79  n);.      if( yy
8bd0: 65 6e 64 6f 66 69 6e 70 75 74 20 29 7b 0a 20 20  endofinput ){.  
8be0: 20 20 20 20 20 20 79 79 5f 70 61 72 73 65 5f 66        yy_parse_f
8bf0: 61 69 6c 65 64 28 79 79 70 50 61 72 73 65 72 29  ailed(yypParser)
8c00: 3b 0a 23 69 66 6e 64 65 66 20 59 59 4e 4f 45 52  ;.#ifndef YYNOER
8c10: 52 4f 52 52 45 43 4f 56 45 52 59 0a 20 20 20 20  RORRECOVERY.    
8c20: 20 20 20 20 79 79 70 50 61 72 73 65 72 2d 3e 79      yypParser->y
8c30: 79 65 72 72 63 6e 74 20 3d 20 2d 31 3b 0a 23 65  yerrcnt = -1;.#e
8c40: 6e 64 69 66 0a 20 20 20 20 20 20 7d 0a 20 20 20  ndif.      }.   
8c50: 20 20 20 62 72 65 61 6b 3b 0a 23 65 6e 64 69 66     break;.#endif
8c60: 0a 20 20 20 20 7d 0a 20 20 7d 77 68 69 6c 65 28  .    }.  }while(
8c70: 20 79 79 70 50 61 72 73 65 72 2d 3e 79 79 74 6f   yypParser->yyto
8c80: 73 3e 79 79 70 50 61 72 73 65 72 2d 3e 79 79 73  s>yypParser->yys
8c90: 74 61 63 6b 20 29 3b 0a 23 69 66 6e 64 65 66 20  tack );.#ifndef 
8ca0: 4e 44 45 42 55 47 0a 20 20 69 66 28 20 79 79 54  NDEBUG.  if( yyT
8cb0: 72 61 63 65 46 49 4c 45 20 29 7b 0a 20 20 20 20  raceFILE ){.    
8cc0: 79 79 53 74 61 63 6b 45 6e 74 72 79 20 2a 69 3b  yyStackEntry *i;
8cd0: 0a 20 20 20 20 63 68 61 72 20 63 44 69 76 20 3d  .    char cDiv =
8ce0: 20 27 5b 27 3b 0a 20 20 20 20 66 70 72 69 6e 74   '[';.    fprint
8cf0: 66 28 79 79 54 72 61 63 65 46 49 4c 45 2c 22 25  f(yyTraceFILE,"%
8d00: 73 52 65 74 75 72 6e 2e 20 53 74 61 63 6b 3d 22  sReturn. Stack="
8d10: 2c 79 79 54 72 61 63 65 50 72 6f 6d 70 74 29 3b  ,yyTracePrompt);
8d20: 0a 20 20 20 20 66 6f 72 28 69 3d 26 79 79 70 50  .    for(i=&yypP
8d30: 61 72 73 65 72 2d 3e 79 79 73 74 61 63 6b 5b 31  arser->yystack[1
8d40: 5d 3b 20 69 3c 3d 79 79 70 50 61 72 73 65 72 2d  ]; i<=yypParser-
8d50: 3e 79 79 74 6f 73 3b 20 69 2b 2b 29 7b 0a 20 20  >yytos; i++){.  
8d60: 20 20 20 20 66 70 72 69 6e 74 66 28 79 79 54 72      fprintf(yyTr
8d70: 61 63 65 46 49 4c 45 2c 22 25 63 25 73 22 2c 20  aceFILE,"%c%s", 
8d80: 63 44 69 76 2c 20 79 79 54 6f 6b 65 6e 4e 61 6d  cDiv, yyTokenNam
8d90: 65 5b 69 2d 3e 6d 61 6a 6f 72 5d 29 3b 0a 20 20  e[i->major]);.  
8da0: 20 20 20 20 63 44 69 76 20 3d 20 27 20 27 3b 0a      cDiv = ' ';.
8db0: 20 20 20 20 7d 0a 20 20 20 20 66 70 72 69 6e 74      }.    fprint
8dc0: 66 28 79 79 54 72 61 63 65 46 49 4c 45 2c 22 5d  f(yyTraceFILE,"]
8dd0: 5c 6e 22 29 3b 0a 20 20 7d 0a 23 65 6e 64 69 66  \n");.  }.#endif
8de0: 0a 20 20 72 65 74 75 72 6e 3b 0a 7d 0a 0a 2f 2a  .  return;.}../*
8df0: 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20 66  .** Return the f
8e00: 61 6c 6c 62 61 63 6b 20 74 6f 6b 65 6e 20 63 6f  allback token co
8e10: 72 72 65 73 70 6f 6e 64 69 6e 67 20 74 6f 20 63  rresponding to c
8e20: 61 6e 6f 6e 69 63 61 6c 20 74 6f 6b 65 6e 20 69  anonical token i
8e30: 54 6f 6b 65 6e 2c 20 6f 72 0a 2a 2a 20 30 20 69  Token, or.** 0 i
8e40: 66 20 69 54 6f 6b 65 6e 20 68 61 73 20 6e 6f 20  f iToken has no 
8e50: 66 61 6c 6c 62 61 63 6b 2e 0a 2a 2f 0a 69 6e 74  fallback..*/.int
8e60: 20 50 61 72 73 65 46 61 6c 6c 62 61 63 6b 28 69   ParseFallback(i
8e70: 6e 74 20 69 54 6f 6b 65 6e 29 7b 0a 23 69 66 64  nt iToken){.#ifd
8e80: 65 66 20 59 59 46 41 4c 4c 42 41 43 4b 0a 20 20  ef YYFALLBACK.  
8e90: 69 66 28 20 69 54 6f 6b 65 6e 3c 28 69 6e 74 29  if( iToken<(int)
8ea0: 28 73 69 7a 65 6f 66 28 79 79 46 61 6c 6c 62 61  (sizeof(yyFallba
8eb0: 63 6b 29 2f 73 69 7a 65 6f 66 28 79 79 46 61 6c  ck)/sizeof(yyFal
8ec0: 6c 62 61 63 6b 5b 30 5d 29 29 20 29 7b 0a 20 20  lback[0])) ){.  
8ed0: 20 20 72 65 74 75 72 6e 20 79 79 46 61 6c 6c 62    return yyFallb
8ee0: 61 63 6b 5b 69 54 6f 6b 65 6e 5d 3b 0a 20 20 7d  ack[iToken];.  }
8ef0: 0a 23 65 6c 73 65 0a 20 20 28 76 6f 69 64 29 69  .#else.  (void)i
8f00: 54 6f 6b 65 6e 3b 0a 23 65 6e 64 69 66 0a 20 20  Token;.#endif.  
8f10: 72 65 74 75 72 6e 20 30 3b 0a 7d 0a              return 0;.}.