/ Hex Artifact Content
Login
SQLite training in Houston TX on 2019-11-05 (details)
Part of the 2019 Tcl Conference

Artifact 17bcc2b41082f9b99718b3757cbf97145a72023a:


0000: 2f 2a 0a 2a 2a 20 32 30 30 31 20 53 65 70 74 65  /*.** 2001 Septe
0010: 6d 62 65 72 20 31 35 0a 2a 2a 0a 2a 2a 20 54 68  mber 15.**.** Th
0020: 65 20 61 75 74 68 6f 72 20 64 69 73 63 6c 61 69  e author disclai
0030: 6d 73 20 63 6f 70 79 72 69 67 68 74 20 74 6f 20  ms copyright to 
0040: 74 68 69 73 20 73 6f 75 72 63 65 20 63 6f 64 65  this source code
0050: 2e 20 20 49 6e 20 70 6c 61 63 65 20 6f 66 0a 2a  .  In place of.*
0060: 2a 20 61 20 6c 65 67 61 6c 20 6e 6f 74 69 63 65  * a legal notice
0070: 2c 20 68 65 72 65 20 69 73 20 61 20 62 6c 65 73  , here is a bles
0080: 73 69 6e 67 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 4d  sing:.**.**    M
0090: 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20 61  ay you do good a
00a0: 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 2a 2a 20  nd not evil..** 
00b0: 20 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20     May you find 
00c0: 66 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20  forgiveness for 
00d0: 79 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72  yourself and for
00e0: 67 69 76 65 20 6f 74 68 65 72 73 2e 0a 2a 2a 20  give others..** 
00f0: 20 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65     May you share
0100: 20 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74   freely, never t
0110: 61 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20  aking more than 
0120: 79 6f 75 20 67 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a  you give..**.***
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 2a  ****************
0170: 2a 2a 2a 2a 2a 2a 0a 2a 2a 20 48 65 61 64 65 72  ******.** Header
0180: 20 66 69 6c 65 20 66 6f 72 20 74 68 65 20 56 69   file for the Vi
0190: 72 74 75 61 6c 20 44 61 74 61 42 61 73 65 20 45  rtual DataBase E
01a0: 6e 67 69 6e 65 20 28 56 44 42 45 29 0a 2a 2a 0a  ngine (VDBE).**.
01b0: 2a 2a 20 54 68 69 73 20 68 65 61 64 65 72 20 64  ** This header d
01c0: 65 66 69 6e 65 73 20 74 68 65 20 69 6e 74 65 72  efines the inter
01d0: 66 61 63 65 20 74 6f 20 74 68 65 20 76 69 72 74  face to the virt
01e0: 75 61 6c 20 64 61 74 61 62 61 73 65 20 65 6e 67  ual database eng
01f0: 69 6e 65 0a 2a 2a 20 6f 72 20 56 44 42 45 2e 20  ine.** or VDBE. 
0200: 20 54 68 65 20 56 44 42 45 20 69 6d 70 6c 65 6d   The VDBE implem
0210: 65 6e 74 73 20 61 6e 20 61 62 73 74 72 61 63 74  ents an abstract
0220: 20 6d 61 63 68 69 6e 65 20 74 68 61 74 20 72 75   machine that ru
0230: 6e 73 20 61 0a 2a 2a 20 73 69 6d 70 6c 65 20 70  ns a.** simple p
0240: 72 6f 67 72 61 6d 20 74 6f 20 61 63 63 65 73 73  rogram to access
0250: 20 61 6e 64 20 6d 6f 64 69 66 79 20 74 68 65 20   and modify the 
0260: 75 6e 64 65 72 6c 79 69 6e 67 20 64 61 74 61 62  underlying datab
0270: 61 73 65 2e 0a 2a 2a 0a 2a 2a 20 24 49 64 3a 20  ase..**.** $Id: 
0280: 76 64 62 65 2e 68 2c 76 20 31 2e 31 33 37 20 32  vdbe.h,v 1.137 2
0290: 30 30 38 2f 30 38 2f 31 33 20 31 39 3a 31 31 3a  008/08/13 19:11:
02a0: 34 38 20 64 72 68 20 45 78 70 20 24 0a 2a 2f 0a  48 drh Exp $.*/.
02b0: 23 69 66 6e 64 65 66 20 5f 53 51 4c 49 54 45 5f  #ifndef _SQLITE_
02c0: 56 44 42 45 5f 48 5f 0a 23 64 65 66 69 6e 65 20  VDBE_H_.#define 
02d0: 5f 53 51 4c 49 54 45 5f 56 44 42 45 5f 48 5f 0a  _SQLITE_VDBE_H_.
02e0: 23 69 6e 63 6c 75 64 65 20 3c 73 74 64 69 6f 2e  #include <stdio.
02f0: 68 3e 0a 0a 2f 2a 0a 2a 2a 20 41 20 73 69 6e 67  h>../*.** A sing
0300: 6c 65 20 56 44 42 45 20 69 73 20 61 6e 20 6f 70  le VDBE is an op
0310: 61 71 75 65 20 73 74 72 75 63 74 75 72 65 20 6e  aque structure n
0320: 61 6d 65 64 20 22 56 64 62 65 22 2e 20 20 4f 6e  amed "Vdbe".  On
0330: 6c 79 20 72 6f 75 74 69 6e 65 73 0a 2a 2a 20 69  ly routines.** i
0340: 6e 20 74 68 65 20 73 6f 75 72 63 65 20 66 69 6c  n the source fil
0350: 65 20 73 71 6c 69 74 65 56 64 62 65 2e 63 20 61  e sqliteVdbe.c a
0360: 72 65 20 61 6c 6c 6f 77 65 64 20 74 6f 20 73 65  re allowed to se
0370: 65 20 74 68 65 20 69 6e 73 69 64 65 73 0a 2a 2a  e the insides.**
0380: 20 6f 66 20 74 68 69 73 20 73 74 72 75 63 74 75   of this structu
0390: 72 65 2e 0a 2a 2f 0a 74 79 70 65 64 65 66 20 73  re..*/.typedef s
03a0: 74 72 75 63 74 20 56 64 62 65 20 56 64 62 65 3b  truct Vdbe Vdbe;
03b0: 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 6e 61 6d 65  ../*.** The name
03c0: 73 20 6f 66 20 74 68 65 20 66 6f 6c 6c 6f 77 69  s of the followi
03d0: 6e 67 20 74 79 70 65 73 20 64 65 63 6c 61 72 65  ng types declare
03e0: 64 20 69 6e 20 76 64 62 65 49 6e 74 2e 68 20 61  d in vdbeInt.h a
03f0: 72 65 20 72 65 71 75 69 72 65 64 0a 2a 2a 20 66  re required.** f
0400: 6f 72 20 74 68 65 20 56 64 62 65 4f 70 20 64 65  or the VdbeOp de
0410: 66 69 6e 69 74 69 6f 6e 2e 0a 2a 2f 0a 74 79 70  finition..*/.typ
0420: 65 64 65 66 20 73 74 72 75 63 74 20 56 64 62 65  edef struct Vdbe
0430: 46 75 6e 63 20 56 64 62 65 46 75 6e 63 3b 0a 74  Func VdbeFunc;.t
0440: 79 70 65 64 65 66 20 73 74 72 75 63 74 20 4d 65  ypedef struct Me
0450: 6d 20 4d 65 6d 3b 0a 0a 2f 2a 0a 2a 2a 20 41 20  m Mem;../*.** A 
0460: 73 69 6e 67 6c 65 20 69 6e 73 74 72 75 63 74 69  single instructi
0470: 6f 6e 20 6f 66 20 74 68 65 20 76 69 72 74 75 61  on of the virtua
0480: 6c 20 6d 61 63 68 69 6e 65 20 68 61 73 20 61 6e  l machine has an
0490: 20 6f 70 63 6f 64 65 0a 2a 2a 20 61 6e 64 20 61   opcode.** and a
04a0: 73 20 6d 61 6e 79 20 61 73 20 74 68 72 65 65 20  s many as three 
04b0: 6f 70 65 72 61 6e 64 73 2e 20 20 54 68 65 20 69  operands.  The i
04c0: 6e 73 74 72 75 63 74 69 6f 6e 20 69 73 20 72 65  nstruction is re
04d0: 63 6f 72 64 65 64 0a 2a 2a 20 61 73 20 61 6e 20  corded.** as an 
04e0: 69 6e 73 74 61 6e 63 65 20 6f 66 20 74 68 65 20  instance of the 
04f0: 66 6f 6c 6c 6f 77 69 6e 67 20 73 74 72 75 63 74  following struct
0500: 75 72 65 3a 0a 2a 2f 0a 73 74 72 75 63 74 20 56  ure:.*/.struct V
0510: 64 62 65 4f 70 20 7b 0a 20 20 75 38 20 6f 70 63  dbeOp {.  u8 opc
0520: 6f 64 65 3b 20 20 20 20 20 20 20 20 20 20 2f 2a  ode;          /*
0530: 20 57 68 61 74 20 6f 70 65 72 61 74 69 6f 6e 20   What operation 
0540: 74 6f 20 70 65 72 66 6f 72 6d 20 2a 2f 0a 20 20  to perform */.  
0550: 73 69 67 6e 65 64 20 63 68 61 72 20 70 34 74 79  signed char p4ty
0560: 70 65 3b 20 2f 2a 20 4f 6e 65 20 6f 66 20 74 68  pe; /* One of th
0570: 65 20 50 34 5f 78 78 78 20 63 6f 6e 73 74 61 6e  e P4_xxx constan
0580: 74 73 20 66 6f 72 20 70 34 20 2a 2f 0a 20 20 75  ts for p4 */.  u
0590: 38 20 6f 70 66 6c 61 67 73 3b 20 20 20 20 20 20  8 opflags;      
05a0: 20 20 20 2f 2a 20 4e 6f 74 20 63 75 72 72 65 6e     /* Not curren
05b0: 74 6c 79 20 75 73 65 64 20 2a 2f 0a 20 20 75 38  tly used */.  u8
05c0: 20 70 35 3b 20 20 20 20 20 20 20 20 20 20 20 20   p5;            
05d0: 20 20 2f 2a 20 46 69 66 74 68 20 70 61 72 61 6d    /* Fifth param
05e0: 65 74 65 72 20 69 73 20 61 6e 20 75 6e 73 69 67  eter is an unsig
05f0: 6e 65 64 20 63 68 61 72 61 63 74 65 72 20 2a 2f  ned character */
0600: 0a 20 20 69 6e 74 20 70 31 3b 20 20 20 20 20 20  .  int p1;      
0610: 20 20 20 20 20 20 20 2f 2a 20 46 69 72 73 74 20         /* First 
0620: 6f 70 65 72 61 6e 64 20 2a 2f 0a 20 20 69 6e 74  operand */.  int
0630: 20 70 32 3b 20 20 20 20 20 20 20 20 20 20 20 20   p2;            
0640: 20 2f 2a 20 53 65 63 6f 6e 64 20 70 61 72 61 6d   /* Second param
0650: 65 74 65 72 20 28 6f 66 74 65 6e 20 74 68 65 20  eter (often the 
0660: 6a 75 6d 70 20 64 65 73 74 69 6e 61 74 69 6f 6e  jump destination
0670: 29 20 2a 2f 0a 20 20 69 6e 74 20 70 33 3b 20 20  ) */.  int p3;  
0680: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68             /* Th
0690: 65 20 74 68 69 72 64 20 70 61 72 61 6d 65 74 65  e third paramete
06a0: 72 20 2a 2f 0a 20 20 75 6e 69 6f 6e 20 7b 20 20  r */.  union {  
06b0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 66 6f             /* fo
06c0: 72 74 68 20 70 61 72 61 6d 65 74 65 72 20 2a 2f  rth parameter */
06d0: 0a 20 20 20 20 69 6e 74 20 69 3b 20 20 20 20 20  .    int i;     
06e0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 49              /* I
06f0: 6e 74 65 67 65 72 20 76 61 6c 75 65 20 69 66 20  nteger value if 
0700: 70 34 74 79 70 65 3d 3d 50 34 5f 49 4e 54 33 32  p4type==P4_INT32
0710: 20 2a 2f 0a 20 20 20 20 76 6f 69 64 20 2a 70 3b   */.    void *p;
0720: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
0730: 2a 20 47 65 6e 65 72 69 63 20 70 6f 69 6e 74 65  * Generic pointe
0740: 72 20 2a 2f 0a 20 20 20 20 63 68 61 72 20 2a 7a  r */.    char *z
0750: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
0760: 2f 2a 20 50 6f 69 6e 74 65 72 20 74 6f 20 64 61  /* Pointer to da
0770: 74 61 20 66 6f 72 20 73 74 72 69 6e 67 20 28 63  ta for string (c
0780: 68 61 72 20 61 72 72 61 79 29 20 74 79 70 65 73  har array) types
0790: 20 2a 2f 0a 20 20 20 20 69 36 34 20 2a 70 49 36   */.    i64 *pI6
07a0: 34 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  4;             /
07b0: 2a 20 55 73 65 64 20 77 68 65 6e 20 70 34 74 79  * Used when p4ty
07c0: 70 65 20 69 73 20 50 34 5f 49 4e 54 36 34 20 2a  pe is P4_INT64 *
07d0: 2f 0a 20 20 20 20 64 6f 75 62 6c 65 20 2a 70 52  /.    double *pR
07e0: 65 61 6c 3b 20 20 20 20 20 20 20 20 20 2f 2a 20  eal;         /* 
07f0: 55 73 65 64 20 77 68 65 6e 20 70 34 74 79 70 65  Used when p4type
0800: 20 69 73 20 50 34 5f 52 45 41 4c 20 2a 2f 0a 20   is P4_REAL */. 
0810: 20 20 20 46 75 6e 63 44 65 66 20 2a 70 46 75 6e     FuncDef *pFun
0820: 63 3b 20 20 20 20 20 20 20 20 2f 2a 20 55 73 65  c;        /* Use
0830: 64 20 77 68 65 6e 20 70 34 74 79 70 65 20 69 73  d when p4type is
0840: 20 50 34 5f 46 55 4e 43 44 45 46 20 2a 2f 0a 20   P4_FUNCDEF */. 
0850: 20 20 20 56 64 62 65 46 75 6e 63 20 2a 70 56 64     VdbeFunc *pVd
0860: 62 65 46 75 6e 63 3b 20 20 20 2f 2a 20 55 73 65  beFunc;   /* Use
0870: 64 20 77 68 65 6e 20 70 34 74 79 70 65 20 69 73  d when p4type is
0880: 20 50 34 5f 56 44 42 45 46 55 4e 43 20 2a 2f 0a   P4_VDBEFUNC */.
0890: 20 20 20 20 43 6f 6c 6c 53 65 71 20 2a 70 43 6f      CollSeq *pCo
08a0: 6c 6c 3b 20 20 20 20 20 20 20 20 2f 2a 20 55 73  ll;        /* Us
08b0: 65 64 20 77 68 65 6e 20 70 34 74 79 70 65 20 69  ed when p4type i
08c0: 73 20 50 34 5f 43 4f 4c 4c 53 45 51 20 2a 2f 0a  s P4_COLLSEQ */.
08d0: 20 20 20 20 4d 65 6d 20 2a 70 4d 65 6d 3b 20 20      Mem *pMem;  
08e0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 55 73             /* Us
08f0: 65 64 20 77 68 65 6e 20 70 34 74 79 70 65 20 69  ed when p4type i
0900: 73 20 50 34 5f 4d 45 4d 20 2a 2f 0a 20 20 20 20  s P4_MEM */.    
0910: 73 71 6c 69 74 65 33 5f 76 74 61 62 20 2a 70 56  sqlite3_vtab *pV
0920: 74 61 62 3b 20 20 20 2f 2a 20 55 73 65 64 20 77  tab;   /* Used w
0930: 68 65 6e 20 70 34 74 79 70 65 20 69 73 20 50 34  hen p4type is P4
0940: 5f 56 54 41 42 20 2a 2f 0a 20 20 20 20 4b 65 79  _VTAB */.    Key
0950: 49 6e 66 6f 20 2a 70 4b 65 79 49 6e 66 6f 3b 20  Info *pKeyInfo; 
0960: 20 20 20 20 2f 2a 20 55 73 65 64 20 77 68 65 6e      /* Used when
0970: 20 70 34 74 79 70 65 20 69 73 20 50 34 5f 4b 45   p4type is P4_KE
0980: 59 49 4e 46 4f 20 2a 2f 0a 20 20 20 20 69 6e 74  YINFO */.    int
0990: 20 2a 61 69 3b 20 20 20 20 20 20 20 20 20 20 20   *ai;           
09a0: 20 20 20 20 2f 2a 20 55 73 65 64 20 77 68 65 6e      /* Used when
09b0: 20 70 34 74 79 70 65 20 69 73 20 50 34 5f 49 4e   p4type is P4_IN
09c0: 54 41 52 52 41 59 20 2a 2f 0a 20 20 7d 20 70 34  TARRAY */.  } p4
09d0: 3b 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f  ;.#ifdef SQLITE_
09e0: 44 45 42 55 47 0a 20 20 63 68 61 72 20 2a 7a 43  DEBUG.  char *zC
09f0: 6f 6d 6d 65 6e 74 3b 20 20 20 20 20 20 20 20 20  omment;         
0a00: 20 2f 2a 20 43 6f 6d 6d 65 6e 74 20 74 6f 20 69   /* Comment to i
0a10: 6d 70 72 6f 76 65 20 72 65 61 64 61 62 69 6c 69  mprove readabili
0a20: 74 79 20 2a 2f 0a 23 65 6e 64 69 66 0a 23 69 66  ty */.#endif.#if
0a30: 64 65 66 20 56 44 42 45 5f 50 52 4f 46 49 4c 45  def VDBE_PROFILE
0a40: 0a 20 20 69 6e 74 20 63 6e 74 3b 20 20 20 20 20  .  int cnt;     
0a50: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e              /* N
0a60: 75 6d 62 65 72 20 6f 66 20 74 69 6d 65 73 20 74  umber of times t
0a70: 68 69 73 20 69 6e 73 74 72 75 63 74 69 6f 6e 20  his instruction 
0a80: 77 61 73 20 65 78 65 63 75 74 65 64 20 2a 2f 0a  was executed */.
0a90: 20 20 75 36 34 20 63 79 63 6c 65 73 3b 20 20 20    u64 cycles;   
0aa0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 6f             /* To
0ab0: 74 61 6c 20 74 69 6d 65 20 73 70 65 6e 74 20 65  tal time spent e
0ac0: 78 65 63 75 74 69 6e 67 20 74 68 69 73 20 69 6e  xecuting this in
0ad0: 73 74 72 75 63 74 69 6f 6e 20 2a 2f 0a 23 65 6e  struction */.#en
0ae0: 64 69 66 0a 7d 3b 0a 74 79 70 65 64 65 66 20 73  dif.};.typedef s
0af0: 74 72 75 63 74 20 56 64 62 65 4f 70 20 56 64 62  truct VdbeOp Vdb
0b00: 65 4f 70 3b 0a 0a 2f 2a 0a 2a 2a 20 41 20 73 6d  eOp;../*.** A sm
0b10: 61 6c 6c 65 72 20 76 65 72 73 69 6f 6e 20 6f 66  aller version of
0b20: 20 56 64 62 65 4f 70 20 75 73 65 64 20 66 6f 72   VdbeOp used for
0b30: 20 74 68 65 20 56 64 62 65 41 64 64 4f 70 4c 69   the VdbeAddOpLi
0b40: 73 74 28 29 20 66 75 6e 63 74 69 6f 6e 20 62 65  st() function be
0b50: 63 61 75 73 65 0a 2a 2a 20 69 74 20 74 61 6b 65  cause.** it take
0b60: 73 20 75 70 20 6c 65 73 73 20 73 70 61 63 65 2e  s up less space.
0b70: 0a 2a 2f 0a 73 74 72 75 63 74 20 56 64 62 65 4f  .*/.struct VdbeO
0b80: 70 4c 69 73 74 20 7b 0a 20 20 75 38 20 6f 70 63  pList {.  u8 opc
0b90: 6f 64 65 3b 20 20 20 20 20 20 20 20 20 20 2f 2a  ode;          /*
0ba0: 20 57 68 61 74 20 6f 70 65 72 61 74 69 6f 6e 20   What operation 
0bb0: 74 6f 20 70 65 72 66 6f 72 6d 20 2a 2f 0a 20 20  to perform */.  
0bc0: 73 69 67 6e 65 64 20 63 68 61 72 20 70 31 3b 20  signed char p1; 
0bd0: 20 20 20 20 2f 2a 20 46 69 72 73 74 20 6f 70 65      /* First ope
0be0: 72 61 6e 64 20 2a 2f 0a 20 20 73 69 67 6e 65 64  rand */.  signed
0bf0: 20 63 68 61 72 20 70 32 3b 20 20 20 20 20 2f 2a   char p2;     /*
0c00: 20 53 65 63 6f 6e 64 20 70 61 72 61 6d 65 74 65   Second paramete
0c10: 72 20 28 6f 66 74 65 6e 20 74 68 65 20 6a 75 6d  r (often the jum
0c20: 70 20 64 65 73 74 69 6e 61 74 69 6f 6e 29 20 2a  p destination) *
0c30: 2f 0a 20 20 73 69 67 6e 65 64 20 63 68 61 72 20  /.  signed char 
0c40: 70 33 3b 20 20 20 20 20 2f 2a 20 54 68 69 72 64  p3;     /* Third
0c50: 20 70 61 72 61 6d 65 74 65 72 20 2a 2f 0a 7d 3b   parameter */.};
0c60: 0a 74 79 70 65 64 65 66 20 73 74 72 75 63 74 20  .typedef struct 
0c70: 56 64 62 65 4f 70 4c 69 73 74 20 56 64 62 65 4f  VdbeOpList VdbeO
0c80: 70 4c 69 73 74 3b 0a 0a 2f 2a 0a 2a 2a 20 41 6c  pList;../*.** Al
0c90: 6c 6f 77 65 64 20 76 61 6c 75 65 73 20 6f 66 20  lowed values of 
0ca0: 56 64 62 65 4f 70 2e 70 33 74 79 70 65 0a 2a 2f  VdbeOp.p3type.*/
0cb0: 0a 23 64 65 66 69 6e 65 20 50 34 5f 4e 4f 54 55  .#define P4_NOTU
0cc0: 53 45 44 20 20 20 20 30 20 20 20 2f 2a 20 54 68  SED    0   /* Th
0cd0: 65 20 50 34 20 70 61 72 61 6d 65 74 65 72 20 69  e P4 parameter i
0ce0: 73 20 6e 6f 74 20 75 73 65 64 20 2a 2f 0a 23 64  s not used */.#d
0cf0: 65 66 69 6e 65 20 50 34 5f 44 59 4e 41 4d 49 43  efine P4_DYNAMIC
0d00: 20 20 28 2d 31 29 20 20 2f 2a 20 50 6f 69 6e 74    (-1)  /* Point
0d10: 65 72 20 74 6f 20 61 20 73 74 72 69 6e 67 20 6f  er to a string o
0d20: 62 74 61 69 6e 65 64 20 66 72 6f 6d 20 73 71 6c  btained from sql
0d30: 69 74 65 4d 61 6c 6c 6f 63 28 29 20 2a 2f 0a 23  iteMalloc() */.#
0d40: 64 65 66 69 6e 65 20 50 34 5f 53 54 41 54 49 43  define P4_STATIC
0d50: 20 20 20 28 2d 32 29 20 20 2f 2a 20 50 6f 69 6e     (-2)  /* Poin
0d60: 74 65 72 20 74 6f 20 61 20 73 74 61 74 69 63 20  ter to a static 
0d70: 73 74 72 69 6e 67 20 2a 2f 0a 23 64 65 66 69 6e  string */.#defin
0d80: 65 20 50 34 5f 43 4f 4c 4c 53 45 51 20 20 28 2d  e P4_COLLSEQ  (-
0d90: 34 29 20 20 2f 2a 20 50 34 20 69 73 20 61 20 70  4)  /* P4 is a p
0da0: 6f 69 6e 74 65 72 20 74 6f 20 61 20 43 6f 6c 6c  ointer to a Coll
0db0: 53 65 71 20 73 74 72 75 63 74 75 72 65 20 2a 2f  Seq structure */
0dc0: 0a 23 64 65 66 69 6e 65 20 50 34 5f 46 55 4e 43  .#define P4_FUNC
0dd0: 44 45 46 20 20 28 2d 35 29 20 20 2f 2a 20 50 34  DEF  (-5)  /* P4
0de0: 20 69 73 20 61 20 70 6f 69 6e 74 65 72 20 74 6f   is a pointer to
0df0: 20 61 20 46 75 6e 63 44 65 66 20 73 74 72 75 63   a FuncDef struc
0e00: 74 75 72 65 20 2a 2f 0a 23 64 65 66 69 6e 65 20  ture */.#define 
0e10: 50 34 5f 4b 45 59 49 4e 46 4f 20 20 28 2d 36 29  P4_KEYINFO  (-6)
0e20: 20 20 2f 2a 20 50 34 20 69 73 20 61 20 70 6f 69    /* P4 is a poi
0e30: 6e 74 65 72 20 74 6f 20 61 20 4b 65 79 49 6e 66  nter to a KeyInf
0e40: 6f 20 73 74 72 75 63 74 75 72 65 20 2a 2f 0a 23  o structure */.#
0e50: 64 65 66 69 6e 65 20 50 34 5f 56 44 42 45 46 55  define P4_VDBEFU
0e60: 4e 43 20 28 2d 37 29 20 20 2f 2a 20 50 34 20 69  NC (-7)  /* P4 i
0e70: 73 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 61  s a pointer to a
0e80: 20 56 64 62 65 46 75 6e 63 20 73 74 72 75 63 74   VdbeFunc struct
0e90: 75 72 65 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50  ure */.#define P
0ea0: 34 5f 4d 45 4d 20 20 20 20 20 20 28 2d 38 29 20  4_MEM      (-8) 
0eb0: 20 2f 2a 20 50 34 20 69 73 20 61 20 70 6f 69 6e   /* P4 is a poin
0ec0: 74 65 72 20 74 6f 20 61 20 4d 65 6d 2a 20 20 20  ter to a Mem*   
0ed0: 20 73 74 72 75 63 74 75 72 65 20 2a 2f 0a 23 64   structure */.#d
0ee0: 65 66 69 6e 65 20 50 34 5f 54 52 41 4e 53 49 45  efine P4_TRANSIE
0ef0: 4e 54 20 28 2d 39 29 20 2f 2a 20 50 34 20 69 73  NT (-9) /* P4 is
0f00: 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 61 20   a pointer to a 
0f10: 74 72 61 6e 73 69 65 6e 74 20 73 74 72 69 6e 67  transient string
0f20: 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50 34 5f 56   */.#define P4_V
0f30: 54 41 42 20 20 20 20 20 28 2d 31 30 29 20 2f 2a  TAB     (-10) /*
0f40: 20 50 34 20 69 73 20 61 20 70 6f 69 6e 74 65 72   P4 is a pointer
0f50: 20 74 6f 20 61 6e 20 73 71 6c 69 74 65 33 5f 76   to an sqlite3_v
0f60: 74 61 62 20 73 74 72 75 63 74 75 72 65 20 2a 2f  tab structure */
0f70: 0a 23 64 65 66 69 6e 65 20 50 34 5f 4d 50 52 49  .#define P4_MPRI
0f80: 4e 54 46 20 20 28 2d 31 31 29 20 2f 2a 20 50 34  NTF  (-11) /* P4
0f90: 20 69 73 20 61 20 73 74 72 69 6e 67 20 6f 62 74   is a string obt
0fa0: 61 69 6e 65 64 20 66 72 6f 6d 20 73 71 6c 69 74  ained from sqlit
0fb0: 65 33 5f 6d 70 72 69 6e 74 66 28 29 20 2a 2f 0a  e3_mprintf() */.
0fc0: 23 64 65 66 69 6e 65 20 50 34 5f 52 45 41 4c 20  #define P4_REAL 
0fd0: 20 20 20 20 28 2d 31 32 29 20 2f 2a 20 50 34 20      (-12) /* P4 
0fe0: 69 73 20 61 20 36 34 2d 62 69 74 20 66 6c 6f 61  is a 64-bit floa
0ff0: 74 69 6e 67 20 70 6f 69 6e 74 20 76 61 6c 75 65  ting point value
1000: 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50 34 5f 49   */.#define P4_I
1010: 4e 54 36 34 20 20 20 20 28 2d 31 33 29 20 2f 2a  NT64    (-13) /*
1020: 20 50 34 20 69 73 20 61 20 36 34 2d 62 69 74 20   P4 is a 64-bit 
1030: 73 69 67 6e 65 64 20 69 6e 74 65 67 65 72 20 2a  signed integer *
1040: 2f 0a 23 64 65 66 69 6e 65 20 50 34 5f 49 4e 54  /.#define P4_INT
1050: 33 32 20 20 20 20 28 2d 31 34 29 20 2f 2a 20 50  32    (-14) /* P
1060: 34 20 69 73 20 61 20 33 32 2d 62 69 74 20 73 69  4 is a 32-bit si
1070: 67 6e 65 64 20 69 6e 74 65 67 65 72 20 2a 2f 0a  gned integer */.
1080: 23 64 65 66 69 6e 65 20 50 34 5f 49 4e 54 41 52  #define P4_INTAR
1090: 52 41 59 20 28 2d 31 35 29 20 2f 2a 20 50 34 20  RAY (-15) /* P4 
10a0: 69 73 20 61 20 76 65 63 74 6f 72 20 6f 66 20 33  is a vector of 3
10b0: 32 2d 62 69 74 20 69 6e 74 65 67 65 72 73 20 2a  2-bit integers *
10c0: 2f 0a 0a 2f 2a 20 57 68 65 6e 20 61 64 64 69 6e  /../* When addin
10d0: 67 20 61 20 50 34 20 61 72 67 75 6d 65 6e 74 20  g a P4 argument 
10e0: 75 73 69 6e 67 20 50 34 5f 4b 45 59 49 4e 46 4f  using P4_KEYINFO
10f0: 2c 20 61 20 63 6f 70 79 20 6f 66 20 74 68 65 20  , a copy of the 
1100: 4b 65 79 49 6e 66 6f 20 73 74 72 75 63 74 75 72  KeyInfo structur
1110: 65 0a 2a 2a 20 69 73 20 6d 61 64 65 2e 20 20 54  e.** is made.  T
1120: 68 61 74 20 63 6f 70 79 20 69 73 20 66 72 65 65  hat copy is free
1130: 64 20 77 68 65 6e 20 74 68 65 20 56 64 62 65 20  d when the Vdbe 
1140: 69 73 20 66 69 6e 61 6c 69 7a 65 64 2e 20 20 42  is finalized.  B
1150: 75 74 20 69 66 20 74 68 65 0a 2a 2a 20 61 72 67  ut if the.** arg
1160: 75 6d 65 6e 74 20 69 73 20 50 34 5f 4b 45 59 49  ument is P4_KEYI
1170: 4e 46 4f 5f 48 41 4e 44 4f 46 46 2c 20 74 68 65  NFO_HANDOFF, the
1180: 20 70 61 73 73 65 64 20 69 6e 20 70 6f 69 6e 74   passed in point
1190: 65 72 20 69 73 20 75 73 65 64 2e 20 20 49 74 20  er is used.  It 
11a0: 73 74 69 6c 6c 0a 2a 2a 20 67 65 74 73 20 66 72  still.** gets fr
11b0: 65 65 64 20 77 68 65 6e 20 74 68 65 20 56 64 62  eed when the Vdb
11c0: 65 20 69 73 20 66 69 6e 61 6c 69 7a 65 64 20 73  e is finalized s
11d0: 6f 20 69 74 20 73 74 69 6c 6c 20 73 68 6f 75 6c  o it still shoul
11e0: 64 20 62 65 20 6f 62 74 61 69 6e 65 64 0a 2a 2a  d be obtained.**
11f0: 20 66 72 6f 6d 20 61 20 73 69 6e 67 6c 65 20 73   from a single s
1200: 71 6c 69 74 65 4d 61 6c 6c 6f 63 28 29 2e 20 20  qliteMalloc().  
1210: 42 75 74 20 6e 6f 20 63 6f 70 79 20 69 73 20 6d  But no copy is m
1220: 61 64 65 20 61 6e 64 20 74 68 65 20 63 61 6c 6c  ade and the call
1230: 69 6e 67 0a 2a 2a 20 66 75 6e 63 74 69 6f 6e 20  ing.** function 
1240: 73 68 6f 75 6c 64 20 2a 6e 6f 74 2a 20 74 72 79  should *not* try
1250: 20 74 6f 20 66 72 65 65 20 74 68 65 20 4b 65 79   to free the Key
1260: 49 6e 66 6f 2e 0a 2a 2f 0a 23 64 65 66 69 6e 65  Info..*/.#define
1270: 20 50 34 5f 4b 45 59 49 4e 46 4f 5f 48 41 4e 44   P4_KEYINFO_HAND
1280: 4f 46 46 20 28 2d 31 36 29 0a 23 64 65 66 69 6e  OFF (-16).#defin
1290: 65 20 50 34 5f 4b 45 59 49 4e 46 4f 5f 53 54 41  e P4_KEYINFO_STA
12a0: 54 49 43 20 20 28 2d 31 37 29 0a 0a 2f 2a 0a 2a  TIC  (-17)../*.*
12b0: 2a 20 54 68 65 20 56 64 62 65 2e 61 43 6f 6c 4e  * The Vdbe.aColN
12c0: 61 6d 65 20 61 72 72 61 79 20 63 6f 6e 74 61 69  ame array contai
12d0: 6e 73 20 35 6e 20 4d 65 6d 20 73 74 72 75 63 74  ns 5n Mem struct
12e0: 75 72 65 73 2c 20 77 68 65 72 65 20 6e 20 69 73  ures, where n is
12f0: 20 74 68 65 20 0a 2a 2a 20 6e 75 6d 62 65 72 20   the .** number 
1300: 6f 66 20 63 6f 6c 75 6d 6e 73 20 6f 66 20 64 61  of columns of da
1310: 74 61 20 72 65 74 75 72 6e 65 64 20 62 79 20 74  ta returned by t
1320: 68 65 20 73 74 61 74 65 6d 65 6e 74 2e 0a 2a 2f  he statement..*/
1330: 0a 23 64 65 66 69 6e 65 20 43 4f 4c 4e 41 4d 45  .#define COLNAME
1340: 5f 4e 41 4d 45 20 20 20 20 20 30 0a 23 64 65 66  _NAME     0.#def
1350: 69 6e 65 20 43 4f 4c 4e 41 4d 45 5f 44 45 43 4c  ine COLNAME_DECL
1360: 54 59 50 45 20 31 0a 23 64 65 66 69 6e 65 20 43  TYPE 1.#define C
1370: 4f 4c 4e 41 4d 45 5f 44 41 54 41 42 41 53 45 20  OLNAME_DATABASE 
1380: 32 0a 23 64 65 66 69 6e 65 20 43 4f 4c 4e 41 4d  2.#define COLNAM
1390: 45 5f 54 41 42 4c 45 20 20 20 20 33 0a 23 64 65  E_TABLE    3.#de
13a0: 66 69 6e 65 20 43 4f 4c 4e 41 4d 45 5f 43 4f 4c  fine COLNAME_COL
13b0: 55 4d 4e 20 20 20 34 0a 23 69 66 64 65 66 20 53  UMN   4.#ifdef S
13c0: 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 43 4f 4c  QLITE_ENABLE_COL
13d0: 55 4d 4e 5f 4d 45 54 41 44 41 54 41 0a 23 20 64  UMN_METADATA.# d
13e0: 65 66 69 6e 65 20 43 4f 4c 4e 41 4d 45 5f 4e 20  efine COLNAME_N 
13f0: 20 20 20 20 20 20 20 35 20 20 20 20 20 20 2f 2a         5      /*
1400: 20 4e 75 6d 62 65 72 20 6f 66 20 43 4f 4c 4e 41   Number of COLNA
1410: 4d 45 5f 78 78 78 20 73 79 6d 62 6f 6c 73 20 2a  ME_xxx symbols *
1420: 2f 0a 23 65 6c 73 65 0a 23 20 69 66 64 65 66 20  /.#else.# ifdef 
1430: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 44 45 43 4c  SQLITE_OMIT_DECL
1440: 54 59 50 45 0a 23 20 20 20 64 65 66 69 6e 65 20  TYPE.#   define 
1450: 43 4f 4c 4e 41 4d 45 5f 4e 20 20 20 20 20 20 31  COLNAME_N      1
1460: 20 20 20 20 20 20 2f 2a 20 53 74 6f 72 65 20 6f        /* Store o
1470: 6e 6c 79 20 74 68 65 20 6e 61 6d 65 20 2a 2f 0a  nly the name */.
1480: 23 20 65 6c 73 65 0a 23 20 20 20 64 65 66 69 6e  # else.#   defin
1490: 65 20 43 4f 4c 4e 41 4d 45 5f 4e 20 20 20 20 20  e COLNAME_N     
14a0: 20 32 20 20 20 20 20 20 2f 2a 20 53 74 6f 72 65   2      /* Store
14b0: 20 74 68 65 20 6e 61 6d 65 20 61 6e 64 20 64 65   the name and de
14c0: 63 6c 74 79 70 65 20 2a 2f 0a 23 20 65 6e 64 69  cltype */.# endi
14d0: 66 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20  f.#endif../*.** 
14e0: 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 6d 61  The following ma
14f0: 63 72 6f 20 63 6f 6e 76 65 72 74 73 20 61 20 72  cro converts a r
1500: 65 6c 61 74 69 76 65 20 61 64 64 72 65 73 73 20  elative address 
1510: 69 6e 20 74 68 65 20 70 32 20 66 69 65 6c 64 0a  in the p2 field.
1520: 2a 2a 20 6f 66 20 61 20 56 64 62 65 4f 70 20 73  ** of a VdbeOp s
1530: 74 72 75 63 74 75 72 65 20 69 6e 74 6f 20 61 20  tructure into a 
1540: 6e 65 67 61 74 69 76 65 20 6e 75 6d 62 65 72 20  negative number 
1550: 73 6f 20 74 68 61 74 20 0a 2a 2a 20 73 71 6c 69  so that .** sqli
1560: 74 65 33 56 64 62 65 41 64 64 4f 70 4c 69 73 74  te3VdbeAddOpList
1570: 28 29 20 6b 6e 6f 77 73 20 74 68 61 74 20 74 68  () knows that th
1580: 65 20 61 64 64 72 65 73 73 20 69 73 20 72 65 6c  e address is rel
1590: 61 74 69 76 65 2e 20 20 43 61 6c 6c 69 6e 67 0a  ative.  Calling.
15a0: 2a 2a 20 74 68 65 20 6d 61 63 72 6f 20 61 67 61  ** the macro aga
15b0: 69 6e 20 72 65 73 74 6f 72 65 73 20 74 68 65 20  in restores the 
15c0: 61 64 64 72 65 73 73 2e 0a 2a 2f 0a 23 64 65 66  address..*/.#def
15d0: 69 6e 65 20 41 44 44 52 28 58 29 20 20 28 2d 31  ine ADDR(X)  (-1
15e0: 2d 28 58 29 29 0a 0a 2f 2a 0a 2a 2a 20 54 68 65  -(X))../*.** The
15f0: 20 6d 61 6b 65 66 69 6c 65 20 73 63 61 6e 73 20   makefile scans 
1600: 74 68 65 20 76 64 62 65 2e 63 20 73 6f 75 72 63  the vdbe.c sourc
1610: 65 20 66 69 6c 65 20 61 6e 64 20 63 72 65 61 74  e file and creat
1620: 65 73 20 74 68 65 20 22 6f 70 63 6f 64 65 73 2e  es the "opcodes.
1630: 68 22 0a 2a 2a 20 68 65 61 64 65 72 20 66 69 6c  h".** header fil
1640: 65 20 74 68 61 74 20 64 65 66 69 6e 65 73 20 61  e that defines a
1650: 20 6e 75 6d 62 65 72 20 66 6f 72 20 65 61 63 68   number for each
1660: 20 6f 70 63 6f 64 65 20 75 73 65 64 20 62 79 20   opcode used by 
1670: 74 68 65 20 56 44 42 45 2e 0a 2a 2f 0a 23 69 6e  the VDBE..*/.#in
1680: 63 6c 75 64 65 20 22 6f 70 63 6f 64 65 73 2e 68  clude "opcodes.h
1690: 22 0a 0a 2f 2a 0a 2a 2a 20 50 72 6f 74 6f 74 79  "../*.** Prototy
16a0: 70 65 73 20 66 6f 72 20 74 68 65 20 56 44 42 45  pes for the VDBE
16b0: 20 69 6e 74 65 72 66 61 63 65 2e 20 20 53 65 65   interface.  See
16c0: 20 63 6f 6d 6d 65 6e 74 73 20 6f 6e 20 74 68 65   comments on the
16d0: 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 0a   implementation.
16e0: 2a 2a 20 66 6f 72 20 61 20 64 65 73 63 72 69 70  ** for a descrip
16f0: 74 69 6f 6e 20 6f 66 20 77 68 61 74 20 65 61 63  tion of what eac
1700: 68 20 6f 66 20 74 68 65 73 65 20 72 6f 75 74 69  h of these routi
1710: 6e 65 73 20 64 6f 65 73 2e 0a 2a 2f 0a 56 64 62  nes does..*/.Vdb
1720: 65 20 2a 73 71 6c 69 74 65 33 56 64 62 65 43 72  e *sqlite3VdbeCr
1730: 65 61 74 65 28 73 71 6c 69 74 65 33 2a 29 3b 0a  eate(sqlite3*);.
1740: 69 6e 74 20 73 71 6c 69 74 65 33 56 64 62 65 41  int sqlite3VdbeA
1750: 64 64 4f 70 30 28 56 64 62 65 2a 2c 69 6e 74 29  ddOp0(Vdbe*,int)
1760: 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 56 64 62  ;.int sqlite3Vdb
1770: 65 41 64 64 4f 70 31 28 56 64 62 65 2a 2c 69 6e  eAddOp1(Vdbe*,in
1780: 74 2c 69 6e 74 29 3b 0a 69 6e 74 20 73 71 6c 69  t,int);.int sqli
1790: 74 65 33 56 64 62 65 41 64 64 4f 70 32 28 56 64  te3VdbeAddOp2(Vd
17a0: 62 65 2a 2c 69 6e 74 2c 69 6e 74 2c 69 6e 74 29  be*,int,int,int)
17b0: 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 56 64 62  ;.int sqlite3Vdb
17c0: 65 41 64 64 4f 70 33 28 56 64 62 65 2a 2c 69 6e  eAddOp3(Vdbe*,in
17d0: 74 2c 69 6e 74 2c 69 6e 74 2c 69 6e 74 29 3b 0a  t,int,int,int);.
17e0: 69 6e 74 20 73 71 6c 69 74 65 33 56 64 62 65 41  int sqlite3VdbeA
17f0: 64 64 4f 70 34 28 56 64 62 65 2a 2c 69 6e 74 2c  ddOp4(Vdbe*,int,
1800: 69 6e 74 2c 69 6e 74 2c 69 6e 74 2c 63 6f 6e 73  int,int,int,cons
1810: 74 20 63 68 61 72 20 2a 7a 50 34 2c 69 6e 74 29  t char *zP4,int)
1820: 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 56 64 62  ;.int sqlite3Vdb
1830: 65 41 64 64 4f 70 4c 69 73 74 28 56 64 62 65 2a  eAddOpList(Vdbe*
1840: 2c 20 69 6e 74 20 6e 4f 70 2c 20 56 64 62 65 4f  , int nOp, VdbeO
1850: 70 4c 69 73 74 20 63 6f 6e 73 74 20 2a 61 4f 70  pList const *aOp
1860: 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 56  );.void sqlite3V
1870: 64 62 65 43 68 61 6e 67 65 50 31 28 56 64 62 65  dbeChangeP1(Vdbe
1880: 2a 2c 20 69 6e 74 20 61 64 64 72 2c 20 69 6e 74  *, int addr, int
1890: 20 50 31 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74   P1);.void sqlit
18a0: 65 33 56 64 62 65 43 68 61 6e 67 65 50 32 28 56  e3VdbeChangeP2(V
18b0: 64 62 65 2a 2c 20 69 6e 74 20 61 64 64 72 2c 20  dbe*, int addr, 
18c0: 69 6e 74 20 50 32 29 3b 0a 76 6f 69 64 20 73 71  int P2);.void sq
18d0: 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67 65 50  lite3VdbeChangeP
18e0: 33 28 56 64 62 65 2a 2c 20 69 6e 74 20 61 64 64  3(Vdbe*, int add
18f0: 72 2c 20 69 6e 74 20 50 33 29 3b 0a 76 6f 69 64  r, int P3);.void
1900: 20 73 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e   sqlite3VdbeChan
1910: 67 65 50 35 28 56 64 62 65 2a 2c 20 75 38 20 50  geP5(Vdbe*, u8 P
1920: 35 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74 65 33  5);.void sqlite3
1930: 56 64 62 65 4a 75 6d 70 48 65 72 65 28 56 64 62  VdbeJumpHere(Vdb
1940: 65 2a 2c 20 69 6e 74 20 61 64 64 72 29 3b 0a 76  e*, int addr);.v
1950: 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62 65 43  oid sqlite3VdbeC
1960: 68 61 6e 67 65 54 6f 4e 6f 6f 70 28 56 64 62 65  hangeToNoop(Vdbe
1970: 2a 2c 20 69 6e 74 20 61 64 64 72 2c 20 69 6e 74  *, int addr, int
1980: 20 4e 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74 65   N);.void sqlite
1990: 33 56 64 62 65 43 68 61 6e 67 65 50 34 28 56 64  3VdbeChangeP4(Vd
19a0: 62 65 2a 2c 20 69 6e 74 20 61 64 64 72 2c 20 63  be*, int addr, c
19b0: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 50 34 2c 20  onst char *zP4, 
19c0: 69 6e 74 20 4e 29 3b 0a 76 6f 69 64 20 73 71 6c  int N);.void sql
19d0: 69 74 65 33 56 64 62 65 55 73 65 73 42 74 72 65  ite3VdbeUsesBtre
19e0: 65 28 56 64 62 65 2a 2c 20 69 6e 74 29 3b 0a 56  e(Vdbe*, int);.V
19f0: 64 62 65 4f 70 20 2a 73 71 6c 69 74 65 33 56 64  dbeOp *sqlite3Vd
1a00: 62 65 47 65 74 4f 70 28 56 64 62 65 2a 2c 20 69  beGetOp(Vdbe*, i
1a10: 6e 74 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33  nt);.int sqlite3
1a20: 56 64 62 65 4d 61 6b 65 4c 61 62 65 6c 28 56 64  VdbeMakeLabel(Vd
1a30: 62 65 2a 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74  be*);.void sqlit
1a40: 65 33 56 64 62 65 44 65 6c 65 74 65 28 56 64 62  e3VdbeDelete(Vdb
1a50: 65 2a 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74 65  e*);.void sqlite
1a60: 33 56 64 62 65 4d 61 6b 65 52 65 61 64 79 28 56  3VdbeMakeReady(V
1a70: 64 62 65 2a 2c 69 6e 74 2c 69 6e 74 2c 69 6e 74  dbe*,int,int,int
1a80: 2c 69 6e 74 29 3b 0a 69 6e 74 20 73 71 6c 69 74  ,int);.int sqlit
1a90: 65 33 56 64 62 65 46 69 6e 61 6c 69 7a 65 28 56  e3VdbeFinalize(V
1aa0: 64 62 65 2a 29 3b 0a 76 6f 69 64 20 73 71 6c 69  dbe*);.void sqli
1ab0: 74 65 33 56 64 62 65 52 65 73 6f 6c 76 65 4c 61  te3VdbeResolveLa
1ac0: 62 65 6c 28 56 64 62 65 2a 2c 20 69 6e 74 29 3b  bel(Vdbe*, int);
1ad0: 0a 69 6e 74 20 73 71 6c 69 74 65 33 56 64 62 65  .int sqlite3Vdbe
1ae0: 43 75 72 72 65 6e 74 41 64 64 72 28 56 64 62 65  CurrentAddr(Vdbe
1af0: 2a 29 3b 0a 23 69 66 64 65 66 20 53 51 4c 49 54  *);.#ifdef SQLIT
1b00: 45 5f 44 45 42 55 47 0a 20 20 76 6f 69 64 20 73  E_DEBUG.  void s
1b10: 71 6c 69 74 65 33 56 64 62 65 54 72 61 63 65 28  qlite3VdbeTrace(
1b20: 56 64 62 65 2a 2c 46 49 4c 45 2a 29 3b 0a 23 65  Vdbe*,FILE*);.#e
1b30: 6e 64 69 66 0a 76 6f 69 64 20 73 71 6c 69 74 65  ndif.void sqlite
1b40: 33 56 64 62 65 52 65 73 65 74 53 74 65 70 52 65  3VdbeResetStepRe
1b50: 73 75 6c 74 28 56 64 62 65 2a 29 3b 0a 69 6e 74  sult(Vdbe*);.int
1b60: 20 73 71 6c 69 74 65 33 56 64 62 65 52 65 73 65   sqlite3VdbeRese
1b70: 74 28 56 64 62 65 2a 29 3b 0a 76 6f 69 64 20 73  t(Vdbe*);.void s
1b80: 71 6c 69 74 65 33 56 64 62 65 53 65 74 4e 75 6d  qlite3VdbeSetNum
1b90: 43 6f 6c 73 28 56 64 62 65 2a 2c 69 6e 74 29 3b  Cols(Vdbe*,int);
1ba0: 0a 69 6e 74 20 73 71 6c 69 74 65 33 56 64 62 65  .int sqlite3Vdbe
1bb0: 53 65 74 43 6f 6c 4e 61 6d 65 28 56 64 62 65 2a  SetColName(Vdbe*
1bc0: 2c 20 69 6e 74 2c 20 69 6e 74 2c 20 63 6f 6e 73  , int, int, cons
1bd0: 74 20 63 68 61 72 20 2a 2c 20 69 6e 74 29 3b 0a  t char *, int);.
1be0: 76 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62 65  void sqlite3Vdbe
1bf0: 43 6f 75 6e 74 43 68 61 6e 67 65 73 28 56 64 62  CountChanges(Vdb
1c00: 65 2a 29 3b 0a 73 71 6c 69 74 65 33 20 2a 73 71  e*);.sqlite3 *sq
1c10: 6c 69 74 65 33 56 64 62 65 44 62 28 56 64 62 65  lite3VdbeDb(Vdbe
1c20: 2a 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74 65 33  *);.void sqlite3
1c30: 56 64 62 65 53 65 74 53 71 6c 28 56 64 62 65 2a  VdbeSetSql(Vdbe*
1c40: 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 2c  , const char *z,
1c50: 20 69 6e 74 20 6e 29 3b 0a 76 6f 69 64 20 73 71   int n);.void sq
1c60: 6c 69 74 65 33 56 64 62 65 53 77 61 70 28 56 64  lite3VdbeSwap(Vd
1c70: 62 65 2a 2c 56 64 62 65 2a 29 3b 0a 0a 23 69 66  be*,Vdbe*);..#if
1c80: 64 65 66 20 53 51 4c 49 54 45 5f 45 4e 41 42 4c  def SQLITE_ENABL
1c90: 45 5f 4d 45 4d 4f 52 59 5f 4d 41 4e 41 47 45 4d  E_MEMORY_MANAGEM
1ca0: 45 4e 54 0a 69 6e 74 20 73 71 6c 69 74 65 33 56  ENT.int sqlite3V
1cb0: 64 62 65 52 65 6c 65 61 73 65 4d 65 6d 6f 72 79  dbeReleaseMemory
1cc0: 28 69 6e 74 29 3b 0a 23 65 6e 64 69 66 0a 55 6e  (int);.#endif.Un
1cd0: 70 61 63 6b 65 64 52 65 63 6f 72 64 20 2a 73 71  packedRecord *sq
1ce0: 6c 69 74 65 33 56 64 62 65 52 65 63 6f 72 64 55  lite3VdbeRecordU
1cf0: 6e 70 61 63 6b 28 4b 65 79 49 6e 66 6f 2a 2c 69  npack(KeyInfo*,i
1d00: 6e 74 2c 63 6f 6e 73 74 20 76 6f 69 64 2a 2c 76  nt,const void*,v
1d10: 6f 69 64 2a 2c 69 6e 74 29 3b 0a 76 6f 69 64 20  oid*,int);.void 
1d20: 73 71 6c 69 74 65 33 56 64 62 65 44 65 6c 65 74  sqlite3VdbeDelet
1d30: 65 55 6e 70 61 63 6b 65 64 52 65 63 6f 72 64 28  eUnpackedRecord(
1d40: 55 6e 70 61 63 6b 65 64 52 65 63 6f 72 64 2a 29  UnpackedRecord*)
1d50: 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 56 64 62  ;.int sqlite3Vdb
1d60: 65 52 65 63 6f 72 64 43 6f 6d 70 61 72 65 28 69  eRecordCompare(i
1d70: 6e 74 2c 63 6f 6e 73 74 20 76 6f 69 64 2a 2c 55  nt,const void*,U
1d80: 6e 70 61 63 6b 65 64 52 65 63 6f 72 64 2a 29 3b  npackedRecord*);
1d90: 0a 0a 0a 23 69 66 6e 64 65 66 20 4e 44 45 42 55  ...#ifndef NDEBU
1da0: 47 0a 20 20 76 6f 69 64 20 73 71 6c 69 74 65 33  G.  void sqlite3
1db0: 56 64 62 65 43 6f 6d 6d 65 6e 74 28 56 64 62 65  VdbeComment(Vdbe
1dc0: 2a 2c 20 63 6f 6e 73 74 20 63 68 61 72 2a 2c 20  *, const char*, 
1dd0: 2e 2e 2e 29 3b 0a 23 20 64 65 66 69 6e 65 20 56  ...);.# define V
1de0: 64 62 65 43 6f 6d 6d 65 6e 74 28 58 29 20 20 73  dbeComment(X)  s
1df0: 71 6c 69 74 65 33 56 64 62 65 43 6f 6d 6d 65 6e  qlite3VdbeCommen
1e00: 74 20 58 0a 20 20 76 6f 69 64 20 73 71 6c 69 74  t X.  void sqlit
1e10: 65 33 56 64 62 65 4e 6f 6f 70 43 6f 6d 6d 65 6e  e3VdbeNoopCommen
1e20: 74 28 56 64 62 65 2a 2c 20 63 6f 6e 73 74 20 63  t(Vdbe*, const c
1e30: 68 61 72 2a 2c 20 2e 2e 2e 29 3b 0a 23 20 64 65  har*, ...);.# de
1e40: 66 69 6e 65 20 56 64 62 65 4e 6f 6f 70 43 6f 6d  fine VdbeNoopCom
1e50: 6d 65 6e 74 28 58 29 20 20 73 71 6c 69 74 65 33  ment(X)  sqlite3
1e60: 56 64 62 65 4e 6f 6f 70 43 6f 6d 6d 65 6e 74 20  VdbeNoopComment 
1e70: 58 0a 23 65 6c 73 65 0a 23 20 64 65 66 69 6e 65  X.#else.# define
1e80: 20 56 64 62 65 43 6f 6d 6d 65 6e 74 28 58 29 0a   VdbeComment(X).
1e90: 23 20 64 65 66 69 6e 65 20 56 64 62 65 4e 6f 6f  # define VdbeNoo
1ea0: 70 43 6f 6d 6d 65 6e 74 28 58 29 0a 23 65 6e 64  pComment(X).#end
1eb0: 69 66 0a 0a 23 65 6e 64 69 66 0a                 if..#endif.