/ Hex Artifact Content
Login

Artifact 29b84656502eee5f444c3147f331ee686956ab0e:


0000: 23 21 2f 75 73 72 2f 62 69 6e 2f 61 77 6b 20 2d  #!/usr/bin/awk -
0010: 66 0a 23 0a 23 20 47 65 6e 65 72 61 74 65 20 74  f.#.# Generate t
0020: 68 65 20 66 69 6c 65 20 6f 70 63 6f 64 65 73 2e  he file opcodes.
0030: 68 2e 0a 23 0a 23 20 54 68 69 73 20 41 57 4b 20  h..#.# This AWK 
0040: 73 63 72 69 70 74 20 73 63 61 6e 73 20 61 20 63  script scans a c
0050: 6f 6e 63 61 74 65 6e 61 74 69 6f 6e 20 6f 66 20  oncatenation of 
0060: 74 68 65 20 70 61 72 73 65 2e 68 20 6f 75 74 70  the parse.h outp
0070: 75 74 20 66 69 6c 65 20 66 72 6f 6d 20 74 68 65  ut file from the
0080: 0a 23 20 70 61 72 73 65 72 20 61 6e 64 20 74 68  .# parser and th
0090: 65 20 76 64 62 65 2e 63 20 73 6f 75 72 63 65 20  e vdbe.c source 
00a0: 66 69 6c 65 20 69 6e 20 6f 72 64 65 72 20 74 6f  file in order to
00b0: 20 67 65 6e 65 72 61 74 65 20 74 68 65 20 6f 70   generate the op
00c0: 63 6f 64 65 73 20 6e 75 6d 62 65 72 73 0a 23 20  codes numbers.# 
00d0: 66 6f 72 20 61 6c 6c 20 6f 70 63 6f 64 65 73 2e  for all opcodes.
00e0: 20 20 0a 23 0a 23 20 54 68 65 20 6c 69 6e 65 73    .#.# The lines
00f0: 20 6f 66 20 74 68 65 20 76 64 62 65 2e 63 20 74   of the vdbe.c t
0100: 68 61 74 20 77 65 20 61 72 65 20 69 6e 74 65 72  hat we are inter
0110: 65 73 74 65 64 20 69 6e 20 61 72 65 20 6f 66 20  ested in are of 
0120: 74 68 65 20 66 6f 72 6d 3a 0a 23 0a 23 20 20 20  the form:.#.#   
0130: 20 20 20 20 63 61 73 65 20 4f 50 5f 61 61 61 61      case OP_aaaa
0140: 3a 20 20 20 20 20 20 2f 2a 20 73 61 6d 65 20 61  :      /* same a
0150: 73 20 54 4b 5f 62 62 62 62 62 20 2a 2f 0a 23 0a  s TK_bbbbb */.#.
0160: 23 20 54 68 65 20 54 4b 5f 20 63 6f 6d 6d 65 6e  # The TK_ commen
0170: 74 20 69 73 20 6f 70 74 69 6f 6e 61 6c 2e 20 20  t is optional.  
0180: 49 66 20 69 74 20 69 73 20 70 72 65 73 65 6e 74  If it is present
0190: 2c 20 74 68 65 6e 20 74 68 65 20 76 61 6c 75 65  , then the value
01a0: 20 61 73 73 69 67 6e 65 64 20 74 6f 0a 23 20 74   assigned to.# t
01b0: 68 65 20 4f 50 5f 20 69 73 20 74 68 65 20 73 61  he OP_ is the sa
01c0: 6d 65 20 61 73 20 74 68 65 20 54 4b 5f 20 76 61  me as the TK_ va
01d0: 6c 75 65 2e 20 20 49 66 20 6d 69 73 73 69 6e 67  lue.  If missing
01e0: 2c 20 74 68 65 20 4f 50 5f 20 76 61 6c 75 65 20  , the OP_ value 
01f0: 69 73 20 61 73 73 69 67 6e 65 64 0a 23 20 61 20  is assigned.# a 
0200: 73 6d 61 6c 6c 20 69 6e 74 65 67 65 72 20 74 68  small integer th
0210: 61 74 20 69 73 20 64 69 66 66 65 72 65 6e 74 20  at is different 
0220: 66 72 6f 6d 20 65 76 65 72 79 20 6f 74 68 65 72  from every other
0230: 20 4f 50 5f 20 76 61 6c 75 65 2e 0a 23 0a 23 20   OP_ value..#.# 
0240: 57 65 20 67 6f 20 74 6f 20 74 68 65 20 74 72 6f  We go to the tro
0250: 75 62 6c 65 20 6f 66 20 6d 61 6b 69 6e 67 20 73  uble of making s
0260: 6f 6d 65 20 4f 50 5f 20 76 61 6c 75 65 73 20 74  ome OP_ values t
0270: 68 65 20 73 61 6d 65 20 61 73 20 54 4b 5f 20 76  he same as TK_ v
0280: 61 6c 75 65 73 0a 23 20 61 73 20 61 6e 20 6f 70  alues.# as an op
0290: 74 69 6d 69 7a 61 74 69 6f 6e 2e 20 20 44 75 72  timization.  Dur
02a0: 69 6e 67 20 70 61 72 73 69 6e 67 2c 20 74 68 69  ing parsing, thi
02b0: 6e 67 73 20 6c 69 6b 65 20 65 78 70 72 65 73 73  ngs like express
02c0: 69 6f 6e 20 6f 70 65 72 61 74 6f 72 73 0a 23 20  ion operators.# 
02d0: 61 72 65 20 63 6f 64 65 64 20 77 69 74 68 20 54  are coded with T
02e0: 4b 5f 20 76 61 6c 75 65 73 20 73 75 63 68 20 61  K_ values such a
02f0: 73 20 54 4b 5f 41 44 44 2c 20 54 4b 5f 44 49 56  s TK_ADD, TK_DIV
0300: 49 44 45 2c 20 61 6e 64 20 73 6f 20 66 6f 72 74  IDE, and so fort
0310: 68 2e 20 20 4c 61 74 65 72 0a 23 20 64 75 72 69  h.  Later.# duri
0320: 6e 67 20 63 6f 64 65 20 67 65 6e 65 72 61 74 69  ng code generati
0330: 6f 6e 2c 20 77 65 20 6e 65 65 64 20 74 6f 20 67  on, we need to g
0340: 65 6e 65 72 61 74 65 20 63 6f 72 72 65 73 70 6f  enerate correspo
0350: 6e 64 69 6e 67 20 6f 70 63 6f 64 65 73 20 6c 69  nding opcodes li
0360: 6b 65 0a 23 20 4f 50 5f 41 64 64 20 61 6e 64 20  ke.# OP_Add and 
0370: 4f 50 5f 44 69 76 69 64 65 2e 20 20 42 79 20 6d  OP_Divide.  By m
0380: 61 6b 69 6e 67 20 54 4b 5f 41 44 44 3d 3d 4f 50  aking TK_ADD==OP
0390: 5f 41 64 64 20 61 6e 64 20 54 4b 5f 44 49 56 49  _Add and TK_DIVI
03a0: 44 45 3d 3d 4f 50 5f 44 69 76 69 64 65 2c 0a 23  DE==OP_Divide,.#
03b0: 20 63 6f 64 65 20 74 6f 20 74 72 61 6e 73 6c 61   code to transla
03c0: 74 65 20 66 72 6f 6d 20 6f 6e 65 20 74 6f 20 74  te from one to t
03d0: 68 65 20 6f 74 68 65 72 20 69 73 20 61 76 6f 69  he other is avoi
03e0: 64 65 64 2e 20 20 54 68 69 73 20 6d 61 6b 65 73  ded.  This makes
03f0: 20 74 68 65 0a 23 20 63 6f 64 65 20 67 65 6e 65   the.# code gene
0400: 72 61 74 6f 72 20 72 75 6e 20 28 69 6e 66 69 6e  rator run (infin
0410: 69 74 65 73 69 6d 61 6c 6c 79 29 20 66 61 73 74  itesimally) fast
0420: 65 72 20 61 6e 64 20 6d 6f 72 65 20 69 6d 70 6f  er and more impo
0430: 72 74 61 6e 74 6c 79 20 69 74 20 6d 61 6b 65 73  rtantly it makes
0440: 0a 23 20 74 68 65 20 6c 69 62 72 61 72 79 20 66  .# the library f
0450: 6f 6f 74 70 72 69 6e 74 20 73 6d 61 6c 6c 65 72  ootprint smaller
0460: 2e 0a 23 0a 23 20 54 68 69 73 20 73 63 72 69 70  ..#.# This scrip
0470: 74 20 61 6c 73 6f 20 73 63 61 6e 73 20 66 6f 72  t also scans for
0480: 20 6c 69 6e 65 73 20 6f 66 20 74 68 65 20 66 6f   lines of the fo
0490: 72 6d 3a 0a 23 0a 23 20 20 20 20 20 20 20 63 61  rm:.#.#       ca
04a0: 73 65 20 4f 50 5f 61 61 61 61 3a 20 20 20 20 20  se OP_aaaa:     
04b0: 20 20 2f 2a 20 6a 75 6d 70 2c 20 69 6e 31 2c 20    /* jump, in1, 
04c0: 69 6e 32 2c 20 69 6e 33 2c 20 6f 75 74 32 2d 70  in2, in3, out2-p
04d0: 72 65 72 65 6c 65 61 73 65 2c 20 6f 75 74 33 20  rerelease, out3 
04e0: 2a 2f 0a 23 0a 23 20 57 68 65 6e 20 73 75 63 68  */.#.# When such
04f0: 20 63 6f 6d 6d 65 6e 74 73 20 61 72 65 20 66 6f   comments are fo
0500: 75 6e 64 20 6f 6e 20 61 6e 20 6f 70 63 6f 64 65  und on an opcode
0510: 2c 20 69 74 20 6d 65 61 6e 73 20 74 68 61 74 20  , it means that 
0520: 63 65 72 74 61 69 6e 0a 23 20 70 72 6f 70 65 72  certain.# proper
0530: 74 69 65 73 20 61 70 70 6c 79 20 74 6f 20 74 68  ties apply to th
0540: 61 74 20 6f 70 63 6f 64 65 2e 20 20 53 65 74 20  at opcode.  Set 
0550: 63 6f 72 72 65 73 70 6f 6e 64 69 6e 67 20 66 6c  corresponding fl
0560: 61 67 73 20 75 73 69 6e 67 20 74 68 65 0a 23 20  ags using the.# 
0570: 4f 50 46 4c 47 5f 49 4e 49 54 49 41 4c 49 5a 45  OPFLG_INITIALIZE
0580: 52 20 6d 61 63 72 6f 2e 0a 23 0a 0a 0a 23 20 52  R macro..#...# R
0590: 65 6d 65 6d 62 65 72 20 74 68 65 20 54 4b 5f 20  emember the TK_ 
05a0: 76 61 6c 75 65 73 20 66 72 6f 6d 20 74 68 65 20  values from the 
05b0: 70 61 72 73 65 2e 68 20 66 69 6c 65 0a 2f 5e 23  parse.h file./^#
05c0: 64 65 66 69 6e 65 20 54 4b 5f 2f 20 7b 0a 20 20  define TK_/ {.  
05d0: 74 6b 5b 24 32 5d 20 3d 20 30 2b 24 33 0a 7d 0a  tk[$2] = 0+$3.}.
05e0: 0a 23 20 53 63 61 6e 20 66 6f 72 20 22 63 61 73  .# Scan for "cas
05f0: 65 20 4f 50 5f 61 61 61 61 3a 22 20 6c 69 6e 65  e OP_aaaa:" line
0600: 73 20 69 6e 20 74 68 65 20 76 64 62 65 2e 63 20  s in the vdbe.c 
0610: 66 69 6c 65 0a 2f 5e 63 61 73 65 20 4f 50 5f 2f  file./^case OP_/
0620: 20 7b 0a 20 20 6e 61 6d 65 20 3d 20 24 32 0a 20   {.  name = $2. 
0630: 20 73 75 62 28 2f 3a 2f 2c 22 22 2c 6e 61 6d 65   sub(/:/,"",name
0640: 29 0a 20 20 73 75 62 28 22 5c 72 22 2c 22 22 2c  ).  sub("\r","",
0650: 6e 61 6d 65 29 0a 20 20 6f 70 5b 6e 61 6d 65 5d  name).  op[name]
0660: 20 3d 20 2d 31 0a 20 20 6a 75 6d 70 5b 6e 61 6d   = -1.  jump[nam
0670: 65 5d 20 3d 20 30 0a 20 20 6f 75 74 32 5f 70 72  e] = 0.  out2_pr
0680: 65 72 65 6c 65 61 73 65 5b 6e 61 6d 65 5d 20 3d  erelease[name] =
0690: 20 30 0a 20 20 69 6e 31 5b 6e 61 6d 65 5d 20 3d   0.  in1[name] =
06a0: 20 30 0a 20 20 69 6e 32 5b 6e 61 6d 65 5d 20 3d   0.  in2[name] =
06b0: 20 30 0a 20 20 69 6e 33 5b 6e 61 6d 65 5d 20 3d   0.  in3[name] =
06c0: 20 30 0a 20 20 6f 75 74 32 5b 6e 61 6d 65 5d 20   0.  out2[name] 
06d0: 3d 20 30 0a 20 20 6f 75 74 33 5b 6e 61 6d 65 5d  = 0.  out3[name]
06e0: 20 3d 20 30 0a 20 20 66 6f 72 28 69 3d 33 3b 20   = 0.  for(i=3; 
06f0: 69 3c 4e 46 3b 20 69 2b 2b 29 7b 0a 20 20 20 20  i<NF; i++){.    
0700: 69 66 28 24 69 3d 3d 22 73 61 6d 65 22 20 26 26  if($i=="same" &&
0710: 20 24 28 69 2b 31 29 3d 3d 22 61 73 22 29 7b 0a   $(i+1)=="as"){.
0720: 20 20 20 20 20 20 73 79 6d 20 3d 20 24 28 69 2b        sym = $(i+
0730: 32 29 0a 20 20 20 20 20 20 73 75 62 28 2f 2c 2f  2).      sub(/,/
0740: 2c 22 22 2c 73 79 6d 29 0a 20 20 20 20 20 20 6f  ,"",sym).      o
0750: 70 5b 6e 61 6d 65 5d 20 3d 20 74 6b 5b 73 79 6d  p[name] = tk[sym
0760: 5d 0a 20 20 20 20 20 20 75 73 65 64 5b 6f 70 5b  ].      used[op[
0770: 6e 61 6d 65 5d 5d 20 3d 20 31 0a 20 20 20 20 20  name]] = 1.     
0780: 20 73 61 6d 65 61 73 5b 6f 70 5b 6e 61 6d 65 5d   sameas[op[name]
0790: 5d 20 3d 20 73 79 6d 0a 20 20 20 20 7d 0a 20 20  ] = sym.    }.  
07a0: 20 20 78 20 3d 20 24 69 0a 20 20 20 20 73 75 62    x = $i.    sub
07b0: 28 22 2c 22 2c 22 22 2c 78 29 0a 20 20 20 20 69  (",","",x).    i
07c0: 66 28 78 3d 3d 22 6a 75 6d 70 22 29 7b 0a 20 20  f(x=="jump"){.  
07d0: 20 20 20 20 6a 75 6d 70 5b 6e 61 6d 65 5d 20 3d      jump[name] =
07e0: 20 31 0a 20 20 20 20 7d 65 6c 73 65 20 69 66 28   1.    }else if(
07f0: 78 3d 3d 22 6f 75 74 32 2d 70 72 65 72 65 6c 65  x=="out2-prerele
0800: 61 73 65 22 29 7b 0a 20 20 20 20 20 20 6f 75 74  ase"){.      out
0810: 32 5f 70 72 65 72 65 6c 65 61 73 65 5b 6e 61 6d  2_prerelease[nam
0820: 65 5d 20 3d 20 31 0a 20 20 20 20 7d 65 6c 73 65  e] = 1.    }else
0830: 20 69 66 28 78 3d 3d 22 69 6e 31 22 29 7b 0a 20   if(x=="in1"){. 
0840: 20 20 20 20 20 69 6e 31 5b 6e 61 6d 65 5d 20 3d       in1[name] =
0850: 20 31 0a 20 20 20 20 7d 65 6c 73 65 20 69 66 28   1.    }else if(
0860: 78 3d 3d 22 69 6e 32 22 29 7b 0a 20 20 20 20 20  x=="in2"){.     
0870: 20 69 6e 32 5b 6e 61 6d 65 5d 20 3d 20 31 0a 20   in2[name] = 1. 
0880: 20 20 20 7d 65 6c 73 65 20 69 66 28 78 3d 3d 22     }else if(x=="
0890: 69 6e 33 22 29 7b 0a 20 20 20 20 20 20 69 6e 33  in3"){.      in3
08a0: 5b 6e 61 6d 65 5d 20 3d 20 31 0a 20 20 20 20 7d  [name] = 1.    }
08b0: 65 6c 73 65 20 69 66 28 78 3d 3d 22 6f 75 74 32  else if(x=="out2
08c0: 22 29 7b 0a 20 20 20 20 20 20 6f 75 74 32 5b 6e  "){.      out2[n
08d0: 61 6d 65 5d 20 3d 20 31 0a 20 20 20 20 7d 65 6c  ame] = 1.    }el
08e0: 73 65 20 69 66 28 78 3d 3d 22 6f 75 74 33 22 29  se if(x=="out3")
08f0: 7b 0a 20 20 20 20 20 20 6f 75 74 33 5b 6e 61 6d  {.      out3[nam
0900: 65 5d 20 3d 20 31 0a 20 20 20 20 7d 0a 20 20 7d  e] = 1.    }.  }
0910: 0a 20 20 6f 72 64 65 72 5b 6e 5f 6f 70 2b 2b 5d  .  order[n_op++]
0920: 20 3d 20 6e 61 6d 65 3b 0a 7d 0a 0a 23 20 41 73   = name;.}..# As
0930: 73 69 67 6e 20 6e 75 6d 62 65 72 73 20 74 6f 20  sign numbers to 
0940: 61 6c 6c 20 6f 70 63 6f 64 65 73 20 61 6e 64 20  all opcodes and 
0950: 6f 75 74 70 75 74 20 74 68 65 20 72 65 73 75 6c  output the resul
0960: 74 2e 0a 45 4e 44 20 7b 0a 20 20 63 6e 74 20 3d  t..END {.  cnt =
0970: 20 30 0a 20 20 6d 61 78 20 3d 20 30 0a 20 20 70   0.  max = 0.  p
0980: 72 69 6e 74 20 22 2f 2a 20 41 75 74 6f 6d 61 74  rint "/* Automat
0990: 69 63 61 6c 6c 79 20 67 65 6e 65 72 61 74 65 64  ically generated
09a0: 2e 20 20 44 6f 20 6e 6f 74 20 65 64 69 74 20 2a  .  Do not edit *
09b0: 2f 22 0a 20 20 70 72 69 6e 74 20 22 2f 2a 20 53  /".  print "/* S
09c0: 65 65 20 74 68 65 20 6d 6b 6f 70 63 6f 64 65 68  ee the mkopcodeh
09d0: 2e 61 77 6b 20 73 63 72 69 70 74 20 66 6f 72 20  .awk script for 
09e0: 64 65 74 61 69 6c 73 20 2a 2f 22 0a 20 20 6f 70  details */".  op
09f0: 5b 22 4f 50 5f 4e 6f 6f 70 22 5d 20 3d 20 2d 31  ["OP_Noop"] = -1
0a00: 3b 0a 20 20 6f 72 64 65 72 5b 6e 5f 6f 70 2b 2b  ;.  order[n_op++
0a10: 5d 20 3d 20 22 4f 50 5f 4e 6f 6f 70 22 3b 0a 20  ] = "OP_Noop";. 
0a20: 20 6f 70 5b 22 4f 50 5f 45 78 70 6c 61 69 6e 22   op["OP_Explain"
0a30: 5d 20 3d 20 2d 31 3b 0a 20 20 6f 72 64 65 72 5b  ] = -1;.  order[
0a40: 6e 5f 6f 70 2b 2b 5d 20 3d 20 22 4f 50 5f 45 78  n_op++] = "OP_Ex
0a50: 70 6c 61 69 6e 22 3b 0a 20 20 66 6f 72 28 69 3d  plain";.  for(i=
0a60: 30 3b 20 69 3c 6e 5f 6f 70 3b 20 69 2b 2b 29 7b  0; i<n_op; i++){
0a70: 0a 20 20 20 20 6e 61 6d 65 20 3d 20 6f 72 64 65  .    name = orde
0a80: 72 5b 69 5d 3b 0a 20 20 20 20 69 66 28 20 6f 70  r[i];.    if( op
0a90: 5b 6e 61 6d 65 5d 3c 30 20 29 7b 0a 20 20 20 20  [name]<0 ){.    
0aa0: 20 20 63 6e 74 2b 2b 0a 20 20 20 20 20 20 77 68    cnt++.      wh
0ab0: 69 6c 65 28 20 75 73 65 64 5b 63 6e 74 5d 20 29  ile( used[cnt] )
0ac0: 20 63 6e 74 2b 2b 0a 20 20 20 20 20 20 6f 70 5b   cnt++.      op[
0ad0: 6e 61 6d 65 5d 20 3d 20 63 6e 74 0a 20 20 20 20  name] = cnt.    
0ae0: 7d 0a 20 20 20 20 75 73 65 64 5b 6f 70 5b 6e 61  }.    used[op[na
0af0: 6d 65 5d 5d 20 3d 20 31 3b 0a 20 20 20 20 69 66  me]] = 1;.    if
0b00: 28 20 6f 70 5b 6e 61 6d 65 5d 3e 6d 61 78 20 29  ( op[name]>max )
0b10: 20 6d 61 78 20 3d 20 6f 70 5b 6e 61 6d 65 5d 0a   max = op[name].
0b20: 20 20 20 20 70 72 69 6e 74 66 20 22 23 64 65 66      printf "#def
0b30: 69 6e 65 20 25 2d 32 35 73 20 25 31 35 64 22 2c  ine %-25s %15d",
0b40: 20 6e 61 6d 65 2c 20 6f 70 5b 6e 61 6d 65 5d 0a   name, op[name].
0b50: 20 20 20 20 69 66 28 20 73 61 6d 65 61 73 5b 6f      if( sameas[o
0b60: 70 5b 6e 61 6d 65 5d 5d 20 29 20 7b 0a 20 20 20  p[name]] ) {.   
0b70: 20 20 20 70 72 69 6e 74 66 20 22 20 20 20 2f 2a     printf "   /*
0b80: 20 73 61 6d 65 20 61 73 20 25 2d 31 32 73 2a 2f   same as %-12s*/
0b90: 22 2c 20 73 61 6d 65 61 73 5b 6f 70 5b 6e 61 6d  ", sameas[op[nam
0ba0: 65 5d 5d 0a 20 20 20 20 7d 20 0a 20 20 20 20 70  e]].    } .    p
0bb0: 72 69 6e 74 66 20 22 5c 6e 22 0a 0a 20 20 7d 0a  rintf "\n"..  }.
0bc0: 20 20 73 65 65 6e 55 6e 75 73 65 64 20 3d 20 30    seenUnused = 0
0bd0: 3b 0a 20 20 66 6f 72 28 69 3d 31 3b 20 69 3c 6d  ;.  for(i=1; i<m
0be0: 61 78 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 69 66  ax; i++){.    if
0bf0: 28 20 21 75 73 65 64 5b 69 5d 20 29 7b 0a 20 20  ( !used[i] ){.  
0c00: 20 20 20 20 69 66 28 20 21 73 65 65 6e 55 6e 75      if( !seenUnu
0c10: 73 65 64 20 29 7b 0a 20 20 20 20 20 20 20 20 70  sed ){.        p
0c20: 72 69 6e 74 66 20 22 5c 6e 2f 2a 20 54 68 65 20  rintf "\n/* The 
0c30: 66 6f 6c 6c 6f 77 69 6e 67 20 6f 70 63 6f 64 65  following opcode
0c40: 20 76 61 6c 75 65 73 20 61 72 65 20 6e 65 76 65   values are neve
0c50: 72 20 75 73 65 64 20 2a 2f 5c 6e 22 0a 20 20 20  r used */\n".   
0c60: 20 20 20 20 20 73 65 65 6e 55 6e 75 73 65 64 20       seenUnused 
0c70: 3d 20 31 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  = 1.      }.    
0c80: 20 20 70 72 69 6e 74 66 20 22 23 64 65 66 69 6e    printf "#defin
0c90: 65 20 25 2d 32 35 73 20 25 31 35 64 5c 6e 22 2c  e %-25s %15d\n",
0ca0: 20 73 70 72 69 6e 74 66 28 20 22 4f 50 5f 4e 6f   sprintf( "OP_No
0cb0: 74 55 73 65 64 5f 25 2d 33 64 22 2c 20 69 20 29  tUsed_%-3d", i )
0cc0: 2c 20 69 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20  , i.    }.  }.. 
0cd0: 20 23 20 47 65 6e 65 72 61 74 65 20 74 68 65 20   # Generate the 
0ce0: 62 69 74 76 65 63 74 6f 72 73 3a 0a 20 20 23 0a  bitvectors:.  #.
0cf0: 20 20 23 20 20 62 69 74 20 30 3a 20 20 20 20 20    #  bit 0:     
0d00: 6a 75 6d 70 0a 20 20 23 20 20 62 69 74 20 31 3a  jump.  #  bit 1:
0d10: 20 20 20 20 20 70 75 73 68 65 73 20 61 20 72 65       pushes a re
0d20: 73 75 6c 74 20 6f 6e 74 6f 20 73 74 61 63 6b 0a  sult onto stack.
0d30: 20 20 23 20 20 62 69 74 20 32 3a 20 20 20 20 20    #  bit 2:     
0d40: 6f 75 74 70 75 74 20 74 6f 20 70 31 2e 20 20 72  output to p1.  r
0d50: 65 6c 65 61 73 65 20 70 31 20 62 65 66 6f 72 65  elease p1 before
0d60: 20 6f 70 63 6f 64 65 20 72 75 6e 73 0a 20 20 23   opcode runs.  #
0d70: 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 3d 6d  .  for(i=0; i<=m
0d80: 61 78 3b 20 69 2b 2b 29 20 62 76 5b 69 5d 20 3d  ax; i++) bv[i] =
0d90: 20 30 3b 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69   0;.  for(i=0; i
0da0: 3c 6e 5f 6f 70 3b 20 69 2b 2b 29 7b 0a 20 20 20  <n_op; i++){.   
0db0: 20 6e 61 6d 65 20 3d 20 6f 72 64 65 72 5b 69 5d   name = order[i]
0dc0: 3b 0a 20 20 20 20 78 20 3d 20 6f 70 5b 6e 61 6d  ;.    x = op[nam
0dd0: 65 5d 0a 20 20 20 20 61 30 20 3d 20 61 31 20 3d  e].    a0 = a1 =
0de0: 20 61 32 20 3d 20 61 33 20 3d 20 61 34 20 3d 20   a2 = a3 = a4 = 
0df0: 61 35 20 3d 20 61 36 20 3d 20 61 37 20 3d 20 30  a5 = a6 = a7 = 0
0e00: 0a 20 20 20 20 23 20 61 37 20 3d 20 61 39 20 3d  .    # a7 = a9 =
0e10: 20 61 31 30 20 3d 20 61 31 31 20 3d 20 61 31 32   a10 = a11 = a12
0e20: 20 3d 20 61 31 33 20 3d 20 61 31 34 20 3d 20 61   = a13 = a14 = a
0e30: 31 35 20 3d 20 30 0a 20 20 20 20 69 66 28 20 6a  15 = 0.    if( j
0e40: 75 6d 70 5b 6e 61 6d 65 5d 20 29 20 61 30 20 3d  ump[name] ) a0 =
0e50: 20 31 3b 0a 20 20 20 20 69 66 28 20 6f 75 74 32   1;.    if( out2
0e60: 5f 70 72 65 72 65 6c 65 61 73 65 5b 6e 61 6d 65  _prerelease[name
0e70: 5d 20 29 20 61 31 20 3d 20 32 3b 0a 20 20 20 20  ] ) a1 = 2;.    
0e80: 69 66 28 20 69 6e 31 5b 6e 61 6d 65 5d 20 29 20  if( in1[name] ) 
0e90: 61 32 20 3d 20 34 3b 0a 20 20 20 20 69 66 28 20  a2 = 4;.    if( 
0ea0: 69 6e 32 5b 6e 61 6d 65 5d 20 29 20 61 33 20 3d  in2[name] ) a3 =
0eb0: 20 38 3b 0a 20 20 20 20 69 66 28 20 69 6e 33 5b   8;.    if( in3[
0ec0: 6e 61 6d 65 5d 20 29 20 61 34 20 3d 20 31 36 3b  name] ) a4 = 16;
0ed0: 0a 20 20 20 20 69 66 28 20 6f 75 74 32 5b 6e 61  .    if( out2[na
0ee0: 6d 65 5d 20 29 20 61 35 20 3d 20 33 32 3b 0a 20  me] ) a5 = 32;. 
0ef0: 20 20 20 69 66 28 20 6f 75 74 33 5b 6e 61 6d 65     if( out3[name
0f00: 5d 20 29 20 61 36 20 3d 20 36 34 3b 0a 20 20 20  ] ) a6 = 64;.   
0f10: 20 23 20 62 76 5b 78 5d 20 3d 20 61 30 2b 61 31   # bv[x] = a0+a1
0f20: 2b 61 32 2b 61 33 2b 61 34 2b 61 35 2b 61 36 2b  +a2+a3+a4+a5+a6+
0f30: 61 37 2b 61 38 2b 61 39 2b 61 31 30 2b 61 31 31  a7+a8+a9+a10+a11
0f40: 2b 61 31 32 2b 61 31 33 2b 61 31 34 2b 61 31 35  +a12+a13+a14+a15
0f50: 3b 0a 20 20 20 20 62 76 5b 78 5d 20 3d 20 61 30  ;.    bv[x] = a0
0f60: 2b 61 31 2b 61 32 2b 61 33 2b 61 34 2b 61 35 2b  +a1+a2+a3+a4+a5+
0f70: 61 36 2b 61 37 3b 0a 20 20 7d 0a 20 20 70 72 69  a6+a7;.  }.  pri
0f80: 6e 74 20 22 5c 6e 22 0a 20 20 70 72 69 6e 74 20  nt "\n".  print 
0f90: 22 2f 2a 20 50 72 6f 70 65 72 74 69 65 73 20 73  "/* Properties s
0fa0: 75 63 68 20 61 73 20 5c 22 6f 75 74 32 5c 22 20  uch as \"out2\" 
0fb0: 6f 72 20 5c 22 6a 75 6d 70 5c 22 20 74 68 61 74  or \"jump\" that
0fc0: 20 61 72 65 20 73 70 65 63 69 66 69 65 64 20 69   are specified i
0fd0: 6e 22 0a 20 20 70 72 69 6e 74 20 22 2a 2a 20 63  n".  print "** c
0fe0: 6f 6d 6d 65 6e 74 73 20 66 6f 6c 6c 6f 77 69 6e  omments followin
0ff0: 67 20 74 68 65 20 5c 22 63 61 73 65 5c 22 20 66  g the \"case\" f
1000: 6f 72 20 65 61 63 68 20 6f 70 63 6f 64 65 20 69  or each opcode i
1010: 6e 20 74 68 65 20 76 64 62 65 2e 63 22 0a 20 20  n the vdbe.c".  
1020: 70 72 69 6e 74 20 22 2a 2a 20 61 72 65 20 65 6e  print "** are en
1030: 63 6f 64 65 64 20 69 6e 74 6f 20 62 69 74 76 65  coded into bitve
1040: 63 74 6f 72 73 20 61 73 20 66 6f 6c 6c 6f 77 73  ctors as follows
1050: 3a 22 0a 20 20 70 72 69 6e 74 20 22 2a 2f 22 0a  :".  print "*/".
1060: 20 20 70 72 69 6e 74 20 22 23 64 65 66 69 6e 65    print "#define
1070: 20 4f 50 46 4c 47 5f 4a 55 4d 50 20 20 20 20 20   OPFLG_JUMP     
1080: 20 20 20 20 20 20 20 30 78 30 30 30 31 20 20 2f         0x0001  /
1090: 2a 20 6a 75 6d 70 3a 20 20 50 32 20 68 6f 6c 64  * jump:  P2 hold
10a0: 73 20 6a 6d 70 20 74 61 72 67 65 74 20 2a 2f 22  s jmp target */"
10b0: 0a 20 20 70 72 69 6e 74 20 22 23 64 65 66 69 6e  .  print "#defin
10c0: 65 20 4f 50 46 4c 47 5f 4f 55 54 32 5f 50 52 45  e OPFLG_OUT2_PRE
10d0: 52 45 4c 45 41 53 45 20 30 78 30 30 30 32 20 20  RELEASE 0x0002  
10e0: 2f 2a 20 6f 75 74 32 2d 70 72 65 72 65 6c 65 61  /* out2-prerelea
10f0: 73 65 3a 20 2a 2f 22 0a 20 20 70 72 69 6e 74 20  se: */".  print 
1100: 22 23 64 65 66 69 6e 65 20 4f 50 46 4c 47 5f 49  "#define OPFLG_I
1110: 4e 31 20 20 20 20 20 20 20 20 20 20 20 20 20 30  N1             0
1120: 78 30 30 30 34 20 20 2f 2a 20 69 6e 31 3a 20 20  x0004  /* in1:  
1130: 20 50 31 20 69 73 20 61 6e 20 69 6e 70 75 74 20   P1 is an input 
1140: 2a 2f 22 0a 20 20 70 72 69 6e 74 20 22 23 64 65  */".  print "#de
1150: 66 69 6e 65 20 4f 50 46 4c 47 5f 49 4e 32 20 20  fine OPFLG_IN2  
1160: 20 20 20 20 20 20 20 20 20 20 20 30 78 30 30 30             0x000
1170: 38 20 20 2f 2a 20 69 6e 32 3a 20 20 20 50 32 20  8  /* in2:   P2 
1180: 69 73 20 61 6e 20 69 6e 70 75 74 20 2a 2f 22 0a  is an input */".
1190: 20 20 70 72 69 6e 74 20 22 23 64 65 66 69 6e 65    print "#define
11a0: 20 4f 50 46 4c 47 5f 49 4e 33 20 20 20 20 20 20   OPFLG_IN3      
11b0: 20 20 20 20 20 20 20 30 78 30 30 31 30 20 20 2f         0x0010  /
11c0: 2a 20 69 6e 33 3a 20 20 20 50 33 20 69 73 20 61  * in3:   P3 is a
11d0: 6e 20 69 6e 70 75 74 20 2a 2f 22 0a 20 20 70 72  n input */".  pr
11e0: 69 6e 74 20 22 23 64 65 66 69 6e 65 20 4f 50 46  int "#define OPF
11f0: 4c 47 5f 4f 55 54 32 20 20 20 20 20 20 20 20 20  LG_OUT2         
1200: 20 20 20 30 78 30 30 32 30 20 20 2f 2a 20 6f 75     0x0020  /* ou
1210: 74 32 3a 20 20 50 32 20 69 73 20 61 6e 20 6f 75  t2:  P2 is an ou
1220: 74 70 75 74 20 2a 2f 22 0a 20 20 70 72 69 6e 74  tput */".  print
1230: 20 22 23 64 65 66 69 6e 65 20 4f 50 46 4c 47 5f   "#define OPFLG_
1240: 4f 55 54 33 20 20 20 20 20 20 20 20 20 20 20 20  OUT3            
1250: 30 78 30 30 34 30 20 20 2f 2a 20 6f 75 74 33 3a  0x0040  /* out3:
1260: 20 20 50 33 20 69 73 20 61 6e 20 6f 75 74 70 75    P3 is an outpu
1270: 74 20 2a 2f 22 0a 20 20 70 72 69 6e 74 20 22 23  t */".  print "#
1280: 64 65 66 69 6e 65 20 4f 50 46 4c 47 5f 49 4e 49  define OPFLG_INI
1290: 54 49 41 4c 49 5a 45 52 20 7b 5c 5c 22 0a 20 20  TIALIZER {\\".  
12a0: 66 6f 72 28 69 3d 30 3b 20 69 3c 3d 6d 61 78 3b  for(i=0; i<=max;
12b0: 20 69 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20 69   i++){.    if( i
12c0: 25 38 3d 3d 30 20 29 20 70 72 69 6e 74 66 28 22  %8==0 ) printf("
12d0: 2f 2a 20 25 33 64 20 2a 2f 22 2c 69 29 0a 20 20  /* %3d */",i).  
12e0: 20 20 70 72 69 6e 74 66 20 22 20 30 78 25 30 32    printf " 0x%02
12f0: 78 2c 22 2c 20 62 76 5b 69 5d 0a 20 20 20 20 69  x,", bv[i].    i
1300: 66 28 20 69 25 38 3d 3d 37 20 29 20 70 72 69 6e  f( i%8==7 ) prin
1310: 74 66 28 22 5c 5c 5c 6e 22 29 3b 0a 20 20 7d 0a  tf("\\\n");.  }.
1320: 20 20 70 72 69 6e 74 20 22 7d 22 0a 7d 0a          print "}".}.