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

Artifact 87b8ff40de3f55dbcdc33029416862f517c37a2f:


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 2f 0a 23 69 66 6e 64 65 66 20  ase..*/.#ifndef 
0280: 5f 53 51 4c 49 54 45 5f 56 44 42 45 5f 48 5f 0a  _SQLITE_VDBE_H_.
0290: 23 64 65 66 69 6e 65 20 5f 53 51 4c 49 54 45 5f  #define _SQLITE_
02a0: 56 44 42 45 5f 48 5f 0a 23 69 6e 63 6c 75 64 65  VDBE_H_.#include
02b0: 20 3c 73 74 64 69 6f 2e 68 3e 0a 0a 2f 2a 0a 2a   <stdio.h>../*.*
02c0: 2a 20 41 20 73 69 6e 67 6c 65 20 56 44 42 45 20  * A single VDBE 
02d0: 69 73 20 61 6e 20 6f 70 61 71 75 65 20 73 74 72  is an opaque str
02e0: 75 63 74 75 72 65 20 6e 61 6d 65 64 20 22 56 64  ucture named "Vd
02f0: 62 65 22 2e 20 20 4f 6e 6c 79 20 72 6f 75 74 69  be".  Only routi
0300: 6e 65 73 0a 2a 2a 20 69 6e 20 74 68 65 20 73 6f  nes.** in the so
0310: 75 72 63 65 20 66 69 6c 65 20 73 71 6c 69 74 65  urce file sqlite
0320: 56 64 62 65 2e 63 20 61 72 65 20 61 6c 6c 6f 77  Vdbe.c are allow
0330: 65 64 20 74 6f 20 73 65 65 20 74 68 65 20 69 6e  ed to see the in
0340: 73 69 64 65 73 0a 2a 2a 20 6f 66 20 74 68 69 73  sides.** of this
0350: 20 73 74 72 75 63 74 75 72 65 2e 0a 2a 2f 0a 74   structure..*/.t
0360: 79 70 65 64 65 66 20 73 74 72 75 63 74 20 56 64  ypedef struct Vd
0370: 62 65 20 56 64 62 65 3b 0a 0a 2f 2a 0a 2a 2a 20  be Vdbe;../*.** 
0380: 54 68 65 20 6e 61 6d 65 73 20 6f 66 20 74 68 65  The names of the
0390: 20 66 6f 6c 6c 6f 77 69 6e 67 20 74 79 70 65 73   following types
03a0: 20 64 65 63 6c 61 72 65 64 20 69 6e 20 76 64 62   declared in vdb
03b0: 65 49 6e 74 2e 68 20 61 72 65 20 72 65 71 75 69  eInt.h are requi
03c0: 72 65 64 0a 2a 2a 20 66 6f 72 20 74 68 65 20 56  red.** for the V
03d0: 64 62 65 4f 70 20 64 65 66 69 6e 69 74 69 6f 6e  dbeOp definition
03e0: 2e 0a 2a 2f 0a 74 79 70 65 64 65 66 20 73 74 72  ..*/.typedef str
03f0: 75 63 74 20 56 64 62 65 46 75 6e 63 20 56 64 62  uct VdbeFunc Vdb
0400: 65 46 75 6e 63 3b 0a 74 79 70 65 64 65 66 20 73  eFunc;.typedef s
0410: 74 72 75 63 74 20 4d 65 6d 20 4d 65 6d 3b 0a 74  truct Mem Mem;.t
0420: 79 70 65 64 65 66 20 73 74 72 75 63 74 20 53 75  ypedef struct Su
0430: 62 50 72 6f 67 72 61 6d 20 53 75 62 50 72 6f 67  bProgram SubProg
0440: 72 61 6d 3b 0a 0a 2f 2a 0a 2a 2a 20 41 20 73 69  ram;../*.** A si
0450: 6e 67 6c 65 20 69 6e 73 74 72 75 63 74 69 6f 6e  ngle instruction
0460: 20 6f 66 20 74 68 65 20 76 69 72 74 75 61 6c 20   of the virtual 
0470: 6d 61 63 68 69 6e 65 20 68 61 73 20 61 6e 20 6f  machine has an o
0480: 70 63 6f 64 65 0a 2a 2a 20 61 6e 64 20 61 73 20  pcode.** and as 
0490: 6d 61 6e 79 20 61 73 20 74 68 72 65 65 20 6f 70  many as three op
04a0: 65 72 61 6e 64 73 2e 20 20 54 68 65 20 69 6e 73  erands.  The ins
04b0: 74 72 75 63 74 69 6f 6e 20 69 73 20 72 65 63 6f  truction is reco
04c0: 72 64 65 64 0a 2a 2a 20 61 73 20 61 6e 20 69 6e  rded.** as an in
04d0: 73 74 61 6e 63 65 20 6f 66 20 74 68 65 20 66 6f  stance of the fo
04e0: 6c 6c 6f 77 69 6e 67 20 73 74 72 75 63 74 75 72  llowing structur
04f0: 65 3a 0a 2a 2f 0a 73 74 72 75 63 74 20 56 64 62  e:.*/.struct Vdb
0500: 65 4f 70 20 7b 0a 20 20 75 38 20 6f 70 63 6f 64  eOp {.  u8 opcod
0510: 65 3b 20 20 20 20 20 20 20 20 20 20 2f 2a 20 57  e;          /* W
0520: 68 61 74 20 6f 70 65 72 61 74 69 6f 6e 20 74 6f  hat operation to
0530: 20 70 65 72 66 6f 72 6d 20 2a 2f 0a 20 20 73 69   perform */.  si
0540: 67 6e 65 64 20 63 68 61 72 20 70 34 74 79 70 65  gned char p4type
0550: 3b 20 2f 2a 20 4f 6e 65 20 6f 66 20 74 68 65 20  ; /* One of the 
0560: 50 34 5f 78 78 78 20 63 6f 6e 73 74 61 6e 74 73  P4_xxx constants
0570: 20 66 6f 72 20 70 34 20 2a 2f 0a 20 20 75 38 20   for p4 */.  u8 
0580: 6f 70 66 6c 61 67 73 3b 20 20 20 20 20 20 20 20  opflags;        
0590: 20 2f 2a 20 4d 61 73 6b 20 6f 66 20 74 68 65 20   /* Mask of the 
05a0: 4f 50 46 4c 47 5f 2a 20 66 6c 61 67 73 20 69 6e  OPFLG_* flags in
05b0: 20 6f 70 63 6f 64 65 73 2e 68 20 2a 2f 0a 20 20   opcodes.h */.  
05c0: 75 38 20 70 35 3b 20 20 20 20 20 20 20 20 20 20  u8 p5;          
05d0: 20 20 20 20 2f 2a 20 46 69 66 74 68 20 70 61 72      /* Fifth par
05e0: 61 6d 65 74 65 72 20 69 73 20 61 6e 20 75 6e 73  ameter is an uns
05f0: 69 67 6e 65 64 20 63 68 61 72 61 63 74 65 72 20  igned character 
0600: 2a 2f 0a 20 20 69 6e 74 20 70 31 3b 20 20 20 20  */.  int p1;    
0610: 20 20 20 20 20 20 20 20 20 2f 2a 20 46 69 72 73           /* Firs
0620: 74 20 6f 70 65 72 61 6e 64 20 2a 2f 0a 20 20 69  t operand */.  i
0630: 6e 74 20 70 32 3b 20 20 20 20 20 20 20 20 20 20  nt p2;          
0640: 20 20 20 2f 2a 20 53 65 63 6f 6e 64 20 70 61 72     /* Second par
0650: 61 6d 65 74 65 72 20 28 6f 66 74 65 6e 20 74 68  ameter (often th
0660: 65 20 6a 75 6d 70 20 64 65 73 74 69 6e 61 74 69  e jump destinati
0670: 6f 6e 29 20 2a 2f 0a 20 20 69 6e 74 20 70 33 3b  on) */.  int p3;
0680: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
0690: 54 68 65 20 74 68 69 72 64 20 70 61 72 61 6d 65  The third parame
06a0: 74 65 72 20 2a 2f 0a 20 20 75 6e 69 6f 6e 20 7b  ter */.  union {
06b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
06c0: 66 6f 75 72 74 68 20 70 61 72 61 6d 65 74 65 72  fourth parameter
06d0: 20 2a 2f 0a 20 20 20 20 69 6e 74 20 69 3b 20 20   */.    int i;  
06e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
06f0: 2a 20 49 6e 74 65 67 65 72 20 76 61 6c 75 65 20  * Integer value 
0700: 69 66 20 70 34 74 79 70 65 3d 3d 50 34 5f 49 4e  if p4type==P4_IN
0710: 54 33 32 20 2a 2f 0a 20 20 20 20 76 6f 69 64 20  T32 */.    void 
0720: 2a 70 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  *p;             
0730: 20 20 2f 2a 20 47 65 6e 65 72 69 63 20 70 6f 69    /* Generic poi
0740: 6e 74 65 72 20 2a 2f 0a 20 20 20 20 63 68 61 72  nter */.    char
0750: 20 2a 7a 3b 20 20 20 20 20 20 20 20 20 20 20 20   *z;            
0760: 20 20 20 2f 2a 20 50 6f 69 6e 74 65 72 20 74 6f     /* Pointer to
0770: 20 64 61 74 61 20 66 6f 72 20 73 74 72 69 6e 67   data for string
0780: 20 28 63 68 61 72 20 61 72 72 61 79 29 20 74 79   (char array) ty
0790: 70 65 73 20 2a 2f 0a 20 20 20 20 69 36 34 20 2a  pes */.    i64 *
07a0: 70 49 36 34 3b 20 20 20 20 20 20 20 20 20 20 20  pI64;           
07b0: 20 20 2f 2a 20 55 73 65 64 20 77 68 65 6e 20 70    /* Used when p
07c0: 34 74 79 70 65 20 69 73 20 50 34 5f 49 4e 54 36  4type is P4_INT6
07d0: 34 20 2a 2f 0a 20 20 20 20 64 6f 75 62 6c 65 20  4 */.    double 
07e0: 2a 70 52 65 61 6c 3b 20 20 20 20 20 20 20 20 20  *pReal;         
07f0: 2f 2a 20 55 73 65 64 20 77 68 65 6e 20 70 34 74  /* Used when p4t
0800: 79 70 65 20 69 73 20 50 34 5f 52 45 41 4c 20 2a  ype is P4_REAL *
0810: 2f 0a 20 20 20 20 46 75 6e 63 44 65 66 20 2a 70  /.    FuncDef *p
0820: 46 75 6e 63 3b 20 20 20 20 20 20 20 20 2f 2a 20  Func;        /* 
0830: 55 73 65 64 20 77 68 65 6e 20 70 34 74 79 70 65  Used when p4type
0840: 20 69 73 20 50 34 5f 46 55 4e 43 44 45 46 20 2a   is P4_FUNCDEF *
0850: 2f 0a 20 20 20 20 56 64 62 65 46 75 6e 63 20 2a  /.    VdbeFunc *
0860: 70 56 64 62 65 46 75 6e 63 3b 20 20 20 2f 2a 20  pVdbeFunc;   /* 
0870: 55 73 65 64 20 77 68 65 6e 20 70 34 74 79 70 65  Used when p4type
0880: 20 69 73 20 50 34 5f 56 44 42 45 46 55 4e 43 20   is P4_VDBEFUNC 
0890: 2a 2f 0a 20 20 20 20 43 6f 6c 6c 53 65 71 20 2a  */.    CollSeq *
08a0: 70 43 6f 6c 6c 3b 20 20 20 20 20 20 20 20 2f 2a  pColl;        /*
08b0: 20 55 73 65 64 20 77 68 65 6e 20 70 34 74 79 70   Used when p4typ
08c0: 65 20 69 73 20 50 34 5f 43 4f 4c 4c 53 45 51 20  e is P4_COLLSEQ 
08d0: 2a 2f 0a 20 20 20 20 4d 65 6d 20 2a 70 4d 65 6d  */.    Mem *pMem
08e0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  ;             /*
08f0: 20 55 73 65 64 20 77 68 65 6e 20 70 34 74 79 70   Used when p4typ
0900: 65 20 69 73 20 50 34 5f 4d 45 4d 20 2a 2f 0a 20  e is P4_MEM */. 
0910: 20 20 20 56 54 61 62 6c 65 20 2a 70 56 74 61 62     VTable *pVtab
0920: 3b 20 20 20 20 20 20 20 20 20 2f 2a 20 55 73 65  ;         /* Use
0930: 64 20 77 68 65 6e 20 70 34 74 79 70 65 20 69 73  d when p4type is
0940: 20 50 34 5f 56 54 41 42 20 2a 2f 0a 20 20 20 20   P4_VTAB */.    
0950: 4b 65 79 49 6e 66 6f 20 2a 70 4b 65 79 49 6e 66  KeyInfo *pKeyInf
0960: 6f 3b 20 20 20 20 20 2f 2a 20 55 73 65 64 20 77  o;     /* Used w
0970: 68 65 6e 20 70 34 74 79 70 65 20 69 73 20 50 34  hen p4type is P4
0980: 5f 4b 45 59 49 4e 46 4f 20 2a 2f 0a 20 20 20 20  _KEYINFO */.    
0990: 69 6e 74 20 2a 61 69 3b 20 20 20 20 20 20 20 20  int *ai;        
09a0: 20 20 20 20 20 20 20 2f 2a 20 55 73 65 64 20 77         /* Used w
09b0: 68 65 6e 20 70 34 74 79 70 65 20 69 73 20 50 34  hen p4type is P4
09c0: 5f 49 4e 54 41 52 52 41 59 20 2a 2f 0a 20 20 20  _INTARRAY */.   
09d0: 20 53 75 62 50 72 6f 67 72 61 6d 20 2a 70 50 72   SubProgram *pPr
09e0: 6f 67 72 61 6d 3b 20 20 2f 2a 20 55 73 65 64 20  ogram;  /* Used 
09f0: 77 68 65 6e 20 70 34 74 79 70 65 20 69 73 20 50  when p4type is P
0a00: 34 5f 53 55 42 50 52 4f 47 52 41 4d 20 2a 2f 0a  4_SUBPROGRAM */.
0a10: 20 20 20 20 54 61 62 6c 65 20 2a 70 54 61 62 3b      Table *pTab;
0a20: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 55 73             /* Us
0a30: 65 64 20 77 68 65 6e 20 70 34 74 79 70 65 20 69  ed when p4type i
0a40: 73 20 50 34 5f 54 41 42 4c 45 20 2a 2f 0a 20 20  s P4_TABLE */.  
0a50: 20 20 69 6e 74 20 28 2a 78 41 64 76 61 6e 63 65    int (*xAdvance
0a60: 29 28 42 74 43 75 72 73 6f 72 20 2a 2c 20 69 6e  )(BtCursor *, in
0a70: 74 20 2a 29 3b 0a 20 20 7d 20 70 34 3b 0a 23 69  t *);.  } p4;.#i
0a80: 66 64 65 66 20 53 51 4c 49 54 45 5f 44 45 42 55  fdef SQLITE_DEBU
0a90: 47 0a 20 20 63 68 61 72 20 2a 7a 43 6f 6d 6d 65  G.  char *zComme
0aa0: 6e 74 3b 20 20 20 20 20 20 20 20 20 20 2f 2a 20  nt;          /* 
0ab0: 43 6f 6d 6d 65 6e 74 20 74 6f 20 69 6d 70 72 6f  Comment to impro
0ac0: 76 65 20 72 65 61 64 61 62 69 6c 69 74 79 20 2a  ve readability *
0ad0: 2f 0a 23 65 6e 64 69 66 0a 23 69 66 64 65 66 20  /.#endif.#ifdef 
0ae0: 56 44 42 45 5f 50 52 4f 46 49 4c 45 0a 20 20 69  VDBE_PROFILE.  i
0af0: 6e 74 20 63 6e 74 3b 20 20 20 20 20 20 20 20 20  nt cnt;         
0b00: 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65          /* Numbe
0b10: 72 20 6f 66 20 74 69 6d 65 73 20 74 68 69 73 20  r of times this 
0b20: 69 6e 73 74 72 75 63 74 69 6f 6e 20 77 61 73 20  instruction was 
0b30: 65 78 65 63 75 74 65 64 20 2a 2f 0a 20 20 75 36  executed */.  u6
0b40: 34 20 63 79 63 6c 65 73 3b 20 20 20 20 20 20 20  4 cycles;       
0b50: 20 20 20 20 20 20 20 2f 2a 20 54 6f 74 61 6c 20         /* Total 
0b60: 74 69 6d 65 20 73 70 65 6e 74 20 65 78 65 63 75  time spent execu
0b70: 74 69 6e 67 20 74 68 69 73 20 69 6e 73 74 72 75  ting this instru
0b80: 63 74 69 6f 6e 20 2a 2f 0a 23 65 6e 64 69 66 0a  ction */.#endif.
0b90: 7d 3b 0a 74 79 70 65 64 65 66 20 73 74 72 75 63  };.typedef struc
0ba0: 74 20 56 64 62 65 4f 70 20 56 64 62 65 4f 70 3b  t VdbeOp VdbeOp;
0bb0: 0a 0a 0a 2f 2a 0a 2a 2a 20 41 20 73 75 62 2d 72  .../*.** A sub-r
0bc0: 6f 75 74 69 6e 65 20 75 73 65 64 20 74 6f 20 69  outine used to i
0bd0: 6d 70 6c 65 6d 65 6e 74 20 61 20 74 72 69 67 67  mplement a trigg
0be0: 65 72 20 70 72 6f 67 72 61 6d 2e 0a 2a 2f 0a 73  er program..*/.s
0bf0: 74 72 75 63 74 20 53 75 62 50 72 6f 67 72 61 6d  truct SubProgram
0c00: 20 7b 0a 20 20 56 64 62 65 4f 70 20 2a 61 4f 70   {.  VdbeOp *aOp
0c10: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
0c20: 20 20 20 2f 2a 20 41 72 72 61 79 20 6f 66 20 6f     /* Array of o
0c30: 70 63 6f 64 65 73 20 66 6f 72 20 73 75 62 2d 70  pcodes for sub-p
0c40: 72 6f 67 72 61 6d 20 2a 2f 0a 20 20 69 6e 74 20  rogram */.  int 
0c50: 6e 4f 70 3b 20 20 20 20 20 20 20 20 20 20 20 20  nOp;            
0c60: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 45 6c 65            /* Ele
0c70: 6d 65 6e 74 73 20 69 6e 20 61 4f 70 5b 5d 20 2a  ments in aOp[] *
0c80: 2f 0a 20 20 69 6e 74 20 6e 4d 65 6d 3b 20 20 20  /.  int nMem;   
0c90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0ca0: 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 6d    /* Number of m
0cb0: 65 6d 6f 72 79 20 63 65 6c 6c 73 20 72 65 71 75  emory cells requ
0cc0: 69 72 65 64 20 2a 2f 0a 20 20 69 6e 74 20 6e 43  ired */.  int nC
0cd0: 73 72 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  sr;             
0ce0: 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65          /* Numbe
0cf0: 72 20 6f 66 20 63 75 72 73 6f 72 73 20 72 65 71  r of cursors req
0d00: 75 69 72 65 64 20 2a 2f 0a 20 20 69 6e 74 20 6e  uired */.  int n
0d10: 4f 6e 63 65 3b 20 20 20 20 20 20 20 20 20 20 20  Once;           
0d20: 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62           /* Numb
0d30: 65 72 20 6f 66 20 4f 50 5f 4f 6e 63 65 20 69 6e  er of OP_Once in
0d40: 73 74 72 75 63 74 69 6f 6e 73 20 2a 2f 0a 20 20  structions */.  
0d50: 76 6f 69 64 20 2a 74 6f 6b 65 6e 3b 20 20 20 20  void *token;    
0d60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
0d70: 20 69 64 20 74 68 61 74 20 6d 61 79 20 62 65 20   id that may be 
0d80: 75 73 65 64 20 74 6f 20 72 65 63 75 72 73 69 76  used to recursiv
0d90: 65 20 74 72 69 67 67 65 72 73 20 2a 2f 0a 20 20  e triggers */.  
0da0: 53 75 62 50 72 6f 67 72 61 6d 20 2a 70 4e 65 78  SubProgram *pNex
0db0: 74 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  t;            /*
0dc0: 20 4e 65 78 74 20 73 75 62 2d 70 72 6f 67 72 61   Next sub-progra
0dd0: 6d 20 61 6c 72 65 61 64 79 20 76 69 73 69 74 65  m already visite
0de0: 64 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20 41  d */.};../*.** A
0df0: 20 73 6d 61 6c 6c 65 72 20 76 65 72 73 69 6f 6e   smaller version
0e00: 20 6f 66 20 56 64 62 65 4f 70 20 75 73 65 64 20   of VdbeOp used 
0e10: 66 6f 72 20 74 68 65 20 56 64 62 65 41 64 64 4f  for the VdbeAddO
0e20: 70 4c 69 73 74 28 29 20 66 75 6e 63 74 69 6f 6e  pList() function
0e30: 20 62 65 63 61 75 73 65 0a 2a 2a 20 69 74 20 74   because.** it t
0e40: 61 6b 65 73 20 75 70 20 6c 65 73 73 20 73 70 61  akes up less spa
0e50: 63 65 2e 0a 2a 2f 0a 73 74 72 75 63 74 20 56 64  ce..*/.struct Vd
0e60: 62 65 4f 70 4c 69 73 74 20 7b 0a 20 20 75 38 20  beOpList {.  u8 
0e70: 6f 70 63 6f 64 65 3b 20 20 20 20 20 20 20 20 20  opcode;         
0e80: 20 2f 2a 20 57 68 61 74 20 6f 70 65 72 61 74 69   /* What operati
0e90: 6f 6e 20 74 6f 20 70 65 72 66 6f 72 6d 20 2a 2f  on to perform */
0ea0: 0a 20 20 73 69 67 6e 65 64 20 63 68 61 72 20 70  .  signed char p
0eb0: 31 3b 20 20 20 20 20 2f 2a 20 46 69 72 73 74 20  1;     /* First 
0ec0: 6f 70 65 72 61 6e 64 20 2a 2f 0a 20 20 73 69 67  operand */.  sig
0ed0: 6e 65 64 20 63 68 61 72 20 70 32 3b 20 20 20 20  ned char p2;    
0ee0: 20 2f 2a 20 53 65 63 6f 6e 64 20 70 61 72 61 6d   /* Second param
0ef0: 65 74 65 72 20 28 6f 66 74 65 6e 20 74 68 65 20  eter (often the 
0f00: 6a 75 6d 70 20 64 65 73 74 69 6e 61 74 69 6f 6e  jump destination
0f10: 29 20 2a 2f 0a 20 20 73 69 67 6e 65 64 20 63 68  ) */.  signed ch
0f20: 61 72 20 70 33 3b 20 20 20 20 20 2f 2a 20 54 68  ar p3;     /* Th
0f30: 69 72 64 20 70 61 72 61 6d 65 74 65 72 20 2a 2f  ird parameter */
0f40: 0a 7d 3b 0a 74 79 70 65 64 65 66 20 73 74 72 75  .};.typedef stru
0f50: 63 74 20 56 64 62 65 4f 70 4c 69 73 74 20 56 64  ct VdbeOpList Vd
0f60: 62 65 4f 70 4c 69 73 74 3b 0a 0a 2f 2a 0a 2a 2a  beOpList;../*.**
0f70: 20 41 6c 6c 6f 77 65 64 20 76 61 6c 75 65 73 20   Allowed values 
0f80: 6f 66 20 56 64 62 65 4f 70 2e 70 34 74 79 70 65  of VdbeOp.p4type
0f90: 0a 2a 2f 0a 23 64 65 66 69 6e 65 20 50 34 5f 4e  .*/.#define P4_N
0fa0: 4f 54 55 53 45 44 20 20 20 20 30 20 20 20 2f 2a  OTUSED    0   /*
0fb0: 20 54 68 65 20 50 34 20 70 61 72 61 6d 65 74 65   The P4 paramete
0fc0: 72 20 69 73 20 6e 6f 74 20 75 73 65 64 20 2a 2f  r is not used */
0fd0: 0a 23 64 65 66 69 6e 65 20 50 34 5f 44 59 4e 41  .#define P4_DYNA
0fe0: 4d 49 43 20 20 28 2d 31 29 20 20 2f 2a 20 50 6f  MIC  (-1)  /* Po
0ff0: 69 6e 74 65 72 20 74 6f 20 61 20 73 74 72 69 6e  inter to a strin
1000: 67 20 6f 62 74 61 69 6e 65 64 20 66 72 6f 6d 20  g obtained from 
1010: 73 71 6c 69 74 65 4d 61 6c 6c 6f 63 28 29 20 2a  sqliteMalloc() *
1020: 2f 0a 23 64 65 66 69 6e 65 20 50 34 5f 53 54 41  /.#define P4_STA
1030: 54 49 43 20 20 20 28 2d 32 29 20 20 2f 2a 20 50  TIC   (-2)  /* P
1040: 6f 69 6e 74 65 72 20 74 6f 20 61 20 73 74 61 74  ointer to a stat
1050: 69 63 20 73 74 72 69 6e 67 20 2a 2f 0a 23 64 65  ic string */.#de
1060: 66 69 6e 65 20 50 34 5f 43 4f 4c 4c 53 45 51 20  fine P4_COLLSEQ 
1070: 20 28 2d 34 29 20 20 2f 2a 20 50 34 20 69 73 20   (-4)  /* P4 is 
1080: 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 61 20 43  a pointer to a C
1090: 6f 6c 6c 53 65 71 20 73 74 72 75 63 74 75 72 65  ollSeq structure
10a0: 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50 34 5f 46   */.#define P4_F
10b0: 55 4e 43 44 45 46 20 20 28 2d 35 29 20 20 2f 2a  UNCDEF  (-5)  /*
10c0: 20 50 34 20 69 73 20 61 20 70 6f 69 6e 74 65 72   P4 is a pointer
10d0: 20 74 6f 20 61 20 46 75 6e 63 44 65 66 20 73 74   to a FuncDef st
10e0: 72 75 63 74 75 72 65 20 2a 2f 0a 23 64 65 66 69  ructure */.#defi
10f0: 6e 65 20 50 34 5f 4b 45 59 49 4e 46 4f 20 20 28  ne P4_KEYINFO  (
1100: 2d 36 29 20 20 2f 2a 20 50 34 20 69 73 20 61 20  -6)  /* P4 is a 
1110: 70 6f 69 6e 74 65 72 20 74 6f 20 61 20 4b 65 79  pointer to a Key
1120: 49 6e 66 6f 20 73 74 72 75 63 74 75 72 65 20 2a  Info structure *
1130: 2f 0a 23 64 65 66 69 6e 65 20 50 34 5f 56 44 42  /.#define P4_VDB
1140: 45 46 55 4e 43 20 28 2d 37 29 20 20 2f 2a 20 50  EFUNC (-7)  /* P
1150: 34 20 69 73 20 61 20 70 6f 69 6e 74 65 72 20 74  4 is a pointer t
1160: 6f 20 61 20 56 64 62 65 46 75 6e 63 20 73 74 72  o a VdbeFunc str
1170: 75 63 74 75 72 65 20 2a 2f 0a 23 64 65 66 69 6e  ucture */.#defin
1180: 65 20 50 34 5f 4d 45 4d 20 20 20 20 20 20 28 2d  e P4_MEM      (-
1190: 38 29 20 20 2f 2a 20 50 34 20 69 73 20 61 20 70  8)  /* P4 is a p
11a0: 6f 69 6e 74 65 72 20 74 6f 20 61 20 4d 65 6d 2a  ointer to a Mem*
11b0: 20 20 20 20 73 74 72 75 63 74 75 72 65 20 2a 2f      structure */
11c0: 0a 23 64 65 66 69 6e 65 20 50 34 5f 54 52 41 4e  .#define P4_TRAN
11d0: 53 49 45 4e 54 20 20 30 20 20 20 2f 2a 20 50 34  SIENT  0   /* P4
11e0: 20 69 73 20 61 20 70 6f 69 6e 74 65 72 20 74 6f   is a pointer to
11f0: 20 61 20 74 72 61 6e 73 69 65 6e 74 20 73 74 72   a transient str
1200: 69 6e 67 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50  ing */.#define P
1210: 34 5f 56 54 41 42 20 20 20 20 20 28 2d 31 30 29  4_VTAB     (-10)
1220: 20 2f 2a 20 50 34 20 69 73 20 61 20 70 6f 69 6e   /* P4 is a poin
1230: 74 65 72 20 74 6f 20 61 6e 20 73 71 6c 69 74 65  ter to an sqlite
1240: 33 5f 76 74 61 62 20 73 74 72 75 63 74 75 72 65  3_vtab structure
1250: 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50 34 5f 4d   */.#define P4_M
1260: 50 52 49 4e 54 46 20 20 28 2d 31 31 29 20 2f 2a  PRINTF  (-11) /*
1270: 20 50 34 20 69 73 20 61 20 73 74 72 69 6e 67 20   P4 is a string 
1280: 6f 62 74 61 69 6e 65 64 20 66 72 6f 6d 20 73 71  obtained from sq
1290: 6c 69 74 65 33 5f 6d 70 72 69 6e 74 66 28 29 20  lite3_mprintf() 
12a0: 2a 2f 0a 23 64 65 66 69 6e 65 20 50 34 5f 52 45  */.#define P4_RE
12b0: 41 4c 20 20 20 20 20 28 2d 31 32 29 20 2f 2a 20  AL     (-12) /* 
12c0: 50 34 20 69 73 20 61 20 36 34 2d 62 69 74 20 66  P4 is a 64-bit f
12d0: 6c 6f 61 74 69 6e 67 20 70 6f 69 6e 74 20 76 61  loating point va
12e0: 6c 75 65 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50  lue */.#define P
12f0: 34 5f 49 4e 54 36 34 20 20 20 20 28 2d 31 33 29  4_INT64    (-13)
1300: 20 2f 2a 20 50 34 20 69 73 20 61 20 36 34 2d 62   /* P4 is a 64-b
1310: 69 74 20 73 69 67 6e 65 64 20 69 6e 74 65 67 65  it signed intege
1320: 72 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50 34 5f  r */.#define P4_
1330: 49 4e 54 33 32 20 20 20 20 28 2d 31 34 29 20 2f  INT32    (-14) /
1340: 2a 20 50 34 20 69 73 20 61 20 33 32 2d 62 69 74  * P4 is a 32-bit
1350: 20 73 69 67 6e 65 64 20 69 6e 74 65 67 65 72 20   signed integer 
1360: 2a 2f 0a 23 64 65 66 69 6e 65 20 50 34 5f 49 4e  */.#define P4_IN
1370: 54 41 52 52 41 59 20 28 2d 31 35 29 20 2f 2a 20  TARRAY (-15) /* 
1380: 50 34 20 69 73 20 61 20 76 65 63 74 6f 72 20 6f  P4 is a vector o
1390: 66 20 33 32 2d 62 69 74 20 69 6e 74 65 67 65 72  f 32-bit integer
13a0: 73 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50 34 5f  s */.#define P4_
13b0: 53 55 42 50 52 4f 47 52 41 4d 20 20 28 2d 31 38  SUBPROGRAM  (-18
13c0: 29 20 2f 2a 20 50 34 20 69 73 20 61 20 70 6f 69  ) /* P4 is a poi
13d0: 6e 74 65 72 20 74 6f 20 61 20 53 75 62 50 72 6f  nter to a SubPro
13e0: 67 72 61 6d 20 73 74 72 75 63 74 75 72 65 20 2a  gram structure *
13f0: 2f 0a 23 64 65 66 69 6e 65 20 50 34 5f 41 44 56  /.#define P4_ADV
1400: 41 4e 43 45 20 20 28 2d 31 39 29 20 2f 2a 20 50  ANCE  (-19) /* P
1410: 34 20 69 73 20 61 20 70 6f 69 6e 74 65 72 20 74  4 is a pointer t
1420: 6f 20 42 74 72 65 65 4e 65 78 74 28 29 20 6f 72  o BtreeNext() or
1430: 20 42 74 72 65 65 50 72 65 76 28 29 20 2a 2f 0a   BtreePrev() */.
1440: 23 64 65 66 69 6e 65 20 50 34 5f 54 41 42 4c 45  #define P4_TABLE
1450: 20 20 20 20 28 2d 32 30 29 20 2f 2a 20 50 34 20      (-20) /* P4 
1460: 69 73 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20  is a pointer to 
1470: 61 20 54 61 62 6c 65 20 73 74 72 75 63 74 75 72  a Table structur
1480: 65 20 2a 2f 0a 0a 2f 2a 20 57 68 65 6e 20 61 64  e */../* When ad
1490: 64 69 6e 67 20 61 20 50 34 20 61 72 67 75 6d 65  ding a P4 argume
14a0: 6e 74 20 75 73 69 6e 67 20 50 34 5f 4b 45 59 49  nt using P4_KEYI
14b0: 4e 46 4f 2c 20 61 20 63 6f 70 79 20 6f 66 20 74  NFO, a copy of t
14c0: 68 65 20 4b 65 79 49 6e 66 6f 20 73 74 72 75 63  he KeyInfo struc
14d0: 74 75 72 65 0a 2a 2a 20 69 73 20 6d 61 64 65 2e  ture.** is made.
14e0: 20 20 54 68 61 74 20 63 6f 70 79 20 69 73 20 66    That copy is f
14f0: 72 65 65 64 20 77 68 65 6e 20 74 68 65 20 56 64  reed when the Vd
1500: 62 65 20 69 73 20 66 69 6e 61 6c 69 7a 65 64 2e  be is finalized.
1510: 20 20 42 75 74 20 69 66 20 74 68 65 0a 2a 2a 20    But if the.** 
1520: 61 72 67 75 6d 65 6e 74 20 69 73 20 50 34 5f 4b  argument is P4_K
1530: 45 59 49 4e 46 4f 5f 48 41 4e 44 4f 46 46 2c 20  EYINFO_HANDOFF, 
1540: 74 68 65 20 70 61 73 73 65 64 20 69 6e 20 70 6f  the passed in po
1550: 69 6e 74 65 72 20 69 73 20 75 73 65 64 2e 20 20  inter is used.  
1560: 49 74 20 73 74 69 6c 6c 0a 2a 2a 20 67 65 74 73  It still.** gets
1570: 20 66 72 65 65 64 20 77 68 65 6e 20 74 68 65 20   freed when the 
1580: 56 64 62 65 20 69 73 20 66 69 6e 61 6c 69 7a 65  Vdbe is finalize
1590: 64 20 73 6f 20 69 74 20 73 74 69 6c 6c 20 73 68  d so it still sh
15a0: 6f 75 6c 64 20 62 65 20 6f 62 74 61 69 6e 65 64  ould be obtained
15b0: 0a 2a 2a 20 66 72 6f 6d 20 61 20 73 69 6e 67 6c  .** from a singl
15c0: 65 20 73 71 6c 69 74 65 4d 61 6c 6c 6f 63 28 29  e sqliteMalloc()
15d0: 2e 20 20 42 75 74 20 6e 6f 20 63 6f 70 79 20 69  .  But no copy i
15e0: 73 20 6d 61 64 65 20 61 6e 64 20 74 68 65 20 63  s made and the c
15f0: 61 6c 6c 69 6e 67 0a 2a 2a 20 66 75 6e 63 74 69  alling.** functi
1600: 6f 6e 20 73 68 6f 75 6c 64 20 2a 6e 6f 74 2a 20  on should *not* 
1610: 74 72 79 20 74 6f 20 66 72 65 65 20 74 68 65 20  try to free the 
1620: 4b 65 79 49 6e 66 6f 2e 0a 2a 2f 0a 23 64 65 66  KeyInfo..*/.#def
1630: 69 6e 65 20 50 34 5f 4b 45 59 49 4e 46 4f 5f 48  ine P4_KEYINFO_H
1640: 41 4e 44 4f 46 46 20 28 2d 31 36 29 0a 23 64 65  ANDOFF (-16).#de
1650: 66 69 6e 65 20 50 34 5f 4b 45 59 49 4e 46 4f 5f  fine P4_KEYINFO_
1660: 53 54 41 54 49 43 20 20 28 2d 31 37 29 0a 0a 2f  STATIC  (-17)../
1670: 2a 0a 2a 2a 20 54 68 65 20 56 64 62 65 2e 61 43  *.** The Vdbe.aC
1680: 6f 6c 4e 61 6d 65 20 61 72 72 61 79 20 63 6f 6e  olName array con
1690: 74 61 69 6e 73 20 35 6e 20 4d 65 6d 20 73 74 72  tains 5n Mem str
16a0: 75 63 74 75 72 65 73 2c 20 77 68 65 72 65 20 6e  uctures, where n
16b0: 20 69 73 20 74 68 65 20 0a 2a 2a 20 6e 75 6d 62   is the .** numb
16c0: 65 72 20 6f 66 20 63 6f 6c 75 6d 6e 73 20 6f 66  er of columns of
16d0: 20 64 61 74 61 20 72 65 74 75 72 6e 65 64 20 62   data returned b
16e0: 79 20 74 68 65 20 73 74 61 74 65 6d 65 6e 74 2e  y the statement.
16f0: 0a 2a 2f 0a 23 64 65 66 69 6e 65 20 43 4f 4c 4e  .*/.#define COLN
1700: 41 4d 45 5f 4e 41 4d 45 20 20 20 20 20 30 0a 23  AME_NAME     0.#
1710: 64 65 66 69 6e 65 20 43 4f 4c 4e 41 4d 45 5f 44  define COLNAME_D
1720: 45 43 4c 54 59 50 45 20 31 0a 23 64 65 66 69 6e  ECLTYPE 1.#defin
1730: 65 20 43 4f 4c 4e 41 4d 45 5f 44 41 54 41 42 41  e COLNAME_DATABA
1740: 53 45 20 32 0a 23 64 65 66 69 6e 65 20 43 4f 4c  SE 2.#define COL
1750: 4e 41 4d 45 5f 54 41 42 4c 45 20 20 20 20 33 0a  NAME_TABLE    3.
1760: 23 64 65 66 69 6e 65 20 43 4f 4c 4e 41 4d 45 5f  #define COLNAME_
1770: 43 4f 4c 55 4d 4e 20 20 20 34 0a 23 69 66 64 65  COLUMN   4.#ifde
1780: 66 20 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f  f SQLITE_ENABLE_
1790: 43 4f 4c 55 4d 4e 5f 4d 45 54 41 44 41 54 41 0a  COLUMN_METADATA.
17a0: 23 20 64 65 66 69 6e 65 20 43 4f 4c 4e 41 4d 45  # define COLNAME
17b0: 5f 4e 20 20 20 20 20 20 20 20 35 20 20 20 20 20  _N        5     
17c0: 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 43 4f   /* Number of CO
17d0: 4c 4e 41 4d 45 5f 78 78 78 20 73 79 6d 62 6f 6c  LNAME_xxx symbol
17e0: 73 20 2a 2f 0a 23 65 6c 73 65 0a 23 20 69 66 64  s */.#else.# ifd
17f0: 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 44  ef SQLITE_OMIT_D
1800: 45 43 4c 54 59 50 45 0a 23 20 20 20 64 65 66 69  ECLTYPE.#   defi
1810: 6e 65 20 43 4f 4c 4e 41 4d 45 5f 4e 20 20 20 20  ne COLNAME_N    
1820: 20 20 31 20 20 20 20 20 20 2f 2a 20 53 74 6f 72    1      /* Stor
1830: 65 20 6f 6e 6c 79 20 74 68 65 20 6e 61 6d 65 20  e only the name 
1840: 2a 2f 0a 23 20 65 6c 73 65 0a 23 20 20 20 64 65  */.# else.#   de
1850: 66 69 6e 65 20 43 4f 4c 4e 41 4d 45 5f 4e 20 20  fine COLNAME_N  
1860: 20 20 20 20 32 20 20 20 20 20 20 2f 2a 20 53 74      2      /* St
1870: 6f 72 65 20 74 68 65 20 6e 61 6d 65 20 61 6e 64  ore the name and
1880: 20 64 65 63 6c 74 79 70 65 20 2a 2f 0a 23 20 65   decltype */.# e
1890: 6e 64 69 66 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a  ndif.#endif../*.
18a0: 2a 2a 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67  ** The following
18b0: 20 6d 61 63 72 6f 20 63 6f 6e 76 65 72 74 73 20   macro converts 
18c0: 61 20 72 65 6c 61 74 69 76 65 20 61 64 64 72 65  a relative addre
18d0: 73 73 20 69 6e 20 74 68 65 20 70 32 20 66 69 65  ss in the p2 fie
18e0: 6c 64 0a 2a 2a 20 6f 66 20 61 20 56 64 62 65 4f  ld.** of a VdbeO
18f0: 70 20 73 74 72 75 63 74 75 72 65 20 69 6e 74 6f  p structure into
1900: 20 61 20 6e 65 67 61 74 69 76 65 20 6e 75 6d 62   a negative numb
1910: 65 72 20 73 6f 20 74 68 61 74 20 0a 2a 2a 20 73  er so that .** s
1920: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 4c  qlite3VdbeAddOpL
1930: 69 73 74 28 29 20 6b 6e 6f 77 73 20 74 68 61 74  ist() knows that
1940: 20 74 68 65 20 61 64 64 72 65 73 73 20 69 73 20   the address is 
1950: 72 65 6c 61 74 69 76 65 2e 20 20 43 61 6c 6c 69  relative.  Calli
1960: 6e 67 0a 2a 2a 20 74 68 65 20 6d 61 63 72 6f 20  ng.** the macro 
1970: 61 67 61 69 6e 20 72 65 73 74 6f 72 65 73 20 74  again restores t
1980: 68 65 20 61 64 64 72 65 73 73 2e 0a 2a 2f 0a 23  he address..*/.#
1990: 64 65 66 69 6e 65 20 41 44 44 52 28 58 29 20 20  define ADDR(X)  
19a0: 28 2d 31 2d 28 58 29 29 0a 0a 2f 2a 0a 2a 2a 20  (-1-(X))../*.** 
19b0: 54 68 65 20 6d 61 6b 65 66 69 6c 65 20 73 63 61  The makefile sca
19c0: 6e 73 20 74 68 65 20 76 64 62 65 2e 63 20 73 6f  ns the vdbe.c so
19d0: 75 72 63 65 20 66 69 6c 65 20 61 6e 64 20 63 72  urce file and cr
19e0: 65 61 74 65 73 20 74 68 65 20 22 6f 70 63 6f 64  eates the "opcod
19f0: 65 73 2e 68 22 0a 2a 2a 20 68 65 61 64 65 72 20  es.h".** header 
1a00: 66 69 6c 65 20 74 68 61 74 20 64 65 66 69 6e 65  file that define
1a10: 73 20 61 20 6e 75 6d 62 65 72 20 66 6f 72 20 65  s a number for e
1a20: 61 63 68 20 6f 70 63 6f 64 65 20 75 73 65 64 20  ach opcode used 
1a30: 62 79 20 74 68 65 20 56 44 42 45 2e 0a 2a 2f 0a  by the VDBE..*/.
1a40: 23 69 6e 63 6c 75 64 65 20 22 6f 70 63 6f 64 65  #include "opcode
1a50: 73 2e 68 22 0a 0a 2f 2a 0a 2a 2a 20 50 72 6f 74  s.h"../*.** Prot
1a60: 6f 74 79 70 65 73 20 66 6f 72 20 74 68 65 20 56  otypes for the V
1a70: 44 42 45 20 69 6e 74 65 72 66 61 63 65 2e 20 20  DBE interface.  
1a80: 53 65 65 20 63 6f 6d 6d 65 6e 74 73 20 6f 6e 20  See comments on 
1a90: 74 68 65 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69  the implementati
1aa0: 6f 6e 0a 2a 2a 20 66 6f 72 20 61 20 64 65 73 63  on.** for a desc
1ab0: 72 69 70 74 69 6f 6e 20 6f 66 20 77 68 61 74 20  ription of what 
1ac0: 65 61 63 68 20 6f 66 20 74 68 65 73 65 20 72 6f  each of these ro
1ad0: 75 74 69 6e 65 73 20 64 6f 65 73 2e 0a 2a 2f 0a  utines does..*/.
1ae0: 56 64 62 65 20 2a 73 71 6c 69 74 65 33 56 64 62  Vdbe *sqlite3Vdb
1af0: 65 43 72 65 61 74 65 28 73 71 6c 69 74 65 33 2a  eCreate(sqlite3*
1b00: 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 56 64  );.int sqlite3Vd
1b10: 62 65 41 64 64 4f 70 30 28 56 64 62 65 2a 2c 69  beAddOp0(Vdbe*,i
1b20: 6e 74 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33  nt);.int sqlite3
1b30: 56 64 62 65 41 64 64 4f 70 31 28 56 64 62 65 2a  VdbeAddOp1(Vdbe*
1b40: 2c 69 6e 74 2c 69 6e 74 29 3b 0a 69 6e 74 20 73  ,int,int);.int s
1b50: 71 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 32  qlite3VdbeAddOp2
1b60: 28 56 64 62 65 2a 2c 69 6e 74 2c 69 6e 74 2c 69  (Vdbe*,int,int,i
1b70: 6e 74 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33  nt);.int sqlite3
1b80: 56 64 62 65 41 64 64 4f 70 33 28 56 64 62 65 2a  VdbeAddOp3(Vdbe*
1b90: 2c 69 6e 74 2c 69 6e 74 2c 69 6e 74 2c 69 6e 74  ,int,int,int,int
1ba0: 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 56 64  );.int sqlite3Vd
1bb0: 62 65 41 64 64 4f 70 34 28 56 64 62 65 2a 2c 69  beAddOp4(Vdbe*,i
1bc0: 6e 74 2c 69 6e 74 2c 69 6e 74 2c 69 6e 74 2c 63  nt,int,int,int,c
1bd0: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 50 34 2c 69  onst char *zP4,i
1be0: 6e 74 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33  nt);.int sqlite3
1bf0: 56 64 62 65 41 64 64 4f 70 34 49 6e 74 28 56 64  VdbeAddOp4Int(Vd
1c00: 62 65 2a 2c 69 6e 74 2c 69 6e 74 2c 69 6e 74 2c  be*,int,int,int,
1c10: 69 6e 74 2c 69 6e 74 29 3b 0a 69 6e 74 20 73 71  int,int);.int sq
1c20: 6c 69 74 65 33 56 64 62 65 41 64 64 4f 70 4c 69  lite3VdbeAddOpLi
1c30: 73 74 28 56 64 62 65 2a 2c 20 69 6e 74 20 6e 4f  st(Vdbe*, int nO
1c40: 70 2c 20 56 64 62 65 4f 70 4c 69 73 74 20 63 6f  p, VdbeOpList co
1c50: 6e 73 74 20 2a 61 4f 70 29 3b 0a 76 6f 69 64 20  nst *aOp);.void 
1c60: 73 71 6c 69 74 65 33 56 64 62 65 41 64 64 50 61  sqlite3VdbeAddPa
1c70: 72 73 65 53 63 68 65 6d 61 4f 70 28 56 64 62 65  rseSchemaOp(Vdbe
1c80: 2a 2c 69 6e 74 2c 63 68 61 72 2a 29 3b 0a 76 6f  *,int,char*);.vo
1c90: 69 64 20 73 71 6c 69 74 65 33 56 64 62 65 43 68  id sqlite3VdbeCh
1ca0: 61 6e 67 65 50 31 28 56 64 62 65 2a 2c 20 75 33  angeP1(Vdbe*, u3
1cb0: 32 20 61 64 64 72 2c 20 69 6e 74 20 50 31 29 3b  2 addr, int P1);
1cc0: 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62  .void sqlite3Vdb
1cd0: 65 43 68 61 6e 67 65 50 32 28 56 64 62 65 2a 2c  eChangeP2(Vdbe*,
1ce0: 20 75 33 32 20 61 64 64 72 2c 20 69 6e 74 20 50   u32 addr, int P
1cf0: 32 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74 65 33  2);.void sqlite3
1d00: 56 64 62 65 43 68 61 6e 67 65 50 33 28 56 64 62  VdbeChangeP3(Vdb
1d10: 65 2a 2c 20 75 33 32 20 61 64 64 72 2c 20 69 6e  e*, u32 addr, in
1d20: 74 20 50 33 29 3b 0a 76 6f 69 64 20 73 71 6c 69  t P3);.void sqli
1d30: 74 65 33 56 64 62 65 43 68 61 6e 67 65 50 35 28  te3VdbeChangeP5(
1d40: 56 64 62 65 2a 2c 20 75 38 20 50 35 29 3b 0a 76  Vdbe*, u8 P5);.v
1d50: 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62 65 4a  oid sqlite3VdbeJ
1d60: 75 6d 70 48 65 72 65 28 56 64 62 65 2a 2c 20 69  umpHere(Vdbe*, i
1d70: 6e 74 20 61 64 64 72 29 3b 0a 76 6f 69 64 20 73  nt addr);.void s
1d80: 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67 65  qlite3VdbeChange
1d90: 54 6f 4e 6f 6f 70 28 56 64 62 65 2a 2c 20 69 6e  ToNoop(Vdbe*, in
1da0: 74 20 61 64 64 72 29 3b 0a 76 6f 69 64 20 73 71  t addr);.void sq
1db0: 6c 69 74 65 33 56 64 62 65 43 68 61 6e 67 65 50  lite3VdbeChangeP
1dc0: 34 28 56 64 62 65 2a 2c 20 69 6e 74 20 61 64 64  4(Vdbe*, int add
1dd0: 72 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  r, const char *z
1de0: 50 34 2c 20 69 6e 74 20 4e 29 3b 0a 76 6f 69 64  P4, int N);.void
1df0: 20 73 71 6c 69 74 65 33 56 64 62 65 55 73 65 73   sqlite3VdbeUses
1e00: 42 74 72 65 65 28 56 64 62 65 2a 2c 20 69 6e 74  Btree(Vdbe*, int
1e10: 29 3b 0a 56 64 62 65 4f 70 20 2a 73 71 6c 69 74  );.VdbeOp *sqlit
1e20: 65 33 56 64 62 65 47 65 74 4f 70 28 56 64 62 65  e3VdbeGetOp(Vdbe
1e30: 2a 2c 20 69 6e 74 29 3b 0a 69 6e 74 20 73 71 6c  *, int);.int sql
1e40: 69 74 65 33 56 64 62 65 4d 61 6b 65 4c 61 62 65  ite3VdbeMakeLabe
1e50: 6c 28 56 64 62 65 2a 29 3b 0a 76 6f 69 64 20 73  l(Vdbe*);.void s
1e60: 71 6c 69 74 65 33 56 64 62 65 52 75 6e 4f 6e 6c  qlite3VdbeRunOnl
1e70: 79 4f 6e 63 65 28 56 64 62 65 2a 29 3b 0a 76 6f  yOnce(Vdbe*);.vo
1e80: 69 64 20 73 71 6c 69 74 65 33 56 64 62 65 44 65  id sqlite3VdbeDe
1e90: 6c 65 74 65 28 56 64 62 65 2a 29 3b 0a 76 6f 69  lete(Vdbe*);.voi
1ea0: 64 20 73 71 6c 69 74 65 33 56 64 62 65 44 65 6c  d sqlite3VdbeDel
1eb0: 65 74 65 4f 62 6a 65 63 74 28 73 71 6c 69 74 65  eteObject(sqlite
1ec0: 33 2a 2c 56 64 62 65 2a 29 3b 0a 76 6f 69 64 20  3*,Vdbe*);.void 
1ed0: 73 71 6c 69 74 65 33 56 64 62 65 4d 61 6b 65 52  sqlite3VdbeMakeR
1ee0: 65 61 64 79 28 56 64 62 65 2a 2c 50 61 72 73 65  eady(Vdbe*,Parse
1ef0: 2a 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 56  *);.int sqlite3V
1f00: 64 62 65 46 69 6e 61 6c 69 7a 65 28 56 64 62 65  dbeFinalize(Vdbe
1f10: 2a 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74 65 33  *);.void sqlite3
1f20: 56 64 62 65 52 65 73 6f 6c 76 65 4c 61 62 65 6c  VdbeResolveLabel
1f30: 28 56 64 62 65 2a 2c 20 69 6e 74 29 3b 0a 69 6e  (Vdbe*, int);.in
1f40: 74 20 73 71 6c 69 74 65 33 56 64 62 65 43 75 72  t sqlite3VdbeCur
1f50: 72 65 6e 74 41 64 64 72 28 56 64 62 65 2a 29 3b  rentAddr(Vdbe*);
1f60: 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 44  .#ifdef SQLITE_D
1f70: 45 42 55 47 0a 20 20 69 6e 74 20 73 71 6c 69 74  EBUG.  int sqlit
1f80: 65 33 56 64 62 65 41 73 73 65 72 74 4d 61 79 41  e3VdbeAssertMayA
1f90: 62 6f 72 74 28 56 64 62 65 20 2a 2c 20 69 6e 74  bort(Vdbe *, int
1fa0: 29 3b 0a 20 20 76 6f 69 64 20 73 71 6c 69 74 65  );.  void sqlite
1fb0: 33 56 64 62 65 54 72 61 63 65 28 56 64 62 65 2a  3VdbeTrace(Vdbe*
1fc0: 2c 46 49 4c 45 2a 29 3b 0a 23 65 6e 64 69 66 0a  ,FILE*);.#endif.
1fd0: 76 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62 65  void sqlite3Vdbe
1fe0: 52 65 73 65 74 53 74 65 70 52 65 73 75 6c 74 28  ResetStepResult(
1ff0: 56 64 62 65 2a 29 3b 0a 76 6f 69 64 20 73 71 6c  Vdbe*);.void sql
2000: 69 74 65 33 56 64 62 65 52 65 77 69 6e 64 28 56  ite3VdbeRewind(V
2010: 64 62 65 2a 29 3b 0a 69 6e 74 20 73 71 6c 69 74  dbe*);.int sqlit
2020: 65 33 56 64 62 65 52 65 73 65 74 28 56 64 62 65  e3VdbeReset(Vdbe
2030: 2a 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74 65 33  *);.void sqlite3
2040: 56 64 62 65 53 65 74 4e 75 6d 43 6f 6c 73 28 56  VdbeSetNumCols(V
2050: 64 62 65 2a 2c 69 6e 74 29 3b 0a 69 6e 74 20 73  dbe*,int);.int s
2060: 71 6c 69 74 65 33 56 64 62 65 53 65 74 43 6f 6c  qlite3VdbeSetCol
2070: 4e 61 6d 65 28 56 64 62 65 2a 2c 20 69 6e 74 2c  Name(Vdbe*, int,
2080: 20 69 6e 74 2c 20 63 6f 6e 73 74 20 63 68 61 72   int, const char
2090: 20 2a 2c 20 76 6f 69 64 28 2a 29 28 76 6f 69 64   *, void(*)(void
20a0: 2a 29 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74 65  *));.void sqlite
20b0: 33 56 64 62 65 43 6f 75 6e 74 43 68 61 6e 67 65  3VdbeCountChange
20c0: 73 28 56 64 62 65 2a 29 3b 0a 73 71 6c 69 74 65  s(Vdbe*);.sqlite
20d0: 33 20 2a 73 71 6c 69 74 65 33 56 64 62 65 44 62  3 *sqlite3VdbeDb
20e0: 28 56 64 62 65 2a 29 3b 0a 76 6f 69 64 20 73 71  (Vdbe*);.void sq
20f0: 6c 69 74 65 33 56 64 62 65 53 65 74 53 71 6c 28  lite3VdbeSetSql(
2100: 56 64 62 65 2a 2c 20 63 6f 6e 73 74 20 63 68 61  Vdbe*, const cha
2110: 72 20 2a 7a 2c 20 69 6e 74 20 6e 2c 20 69 6e 74  r *z, int n, int
2120: 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 56  );.void sqlite3V
2130: 64 62 65 53 77 61 70 28 56 64 62 65 2a 2c 56 64  dbeSwap(Vdbe*,Vd
2140: 62 65 2a 29 3b 0a 56 64 62 65 4f 70 20 2a 73 71  be*);.VdbeOp *sq
2150: 6c 69 74 65 33 56 64 62 65 54 61 6b 65 4f 70 41  lite3VdbeTakeOpA
2160: 72 72 61 79 28 56 64 62 65 2a 2c 20 69 6e 74 2a  rray(Vdbe*, int*
2170: 2c 20 69 6e 74 2a 29 3b 0a 73 71 6c 69 74 65 33  , int*);.sqlite3
2180: 5f 76 61 6c 75 65 20 2a 73 71 6c 69 74 65 33 56  _value *sqlite3V
2190: 64 62 65 47 65 74 56 61 6c 75 65 28 56 64 62 65  dbeGetValue(Vdbe
21a0: 2a 2c 20 69 6e 74 2c 20 75 38 29 3b 0a 76 6f 69  *, int, u8);.voi
21b0: 64 20 73 71 6c 69 74 65 33 56 64 62 65 53 65 74  d sqlite3VdbeSet
21c0: 56 61 72 6d 61 73 6b 28 56 64 62 65 2a 2c 20 69  Varmask(Vdbe*, i
21d0: 6e 74 29 3b 0a 23 69 66 6e 64 65 66 20 53 51 4c  nt);.#ifndef SQL
21e0: 49 54 45 5f 4f 4d 49 54 5f 54 52 41 43 45 0a 20  ITE_OMIT_TRACE. 
21f0: 20 63 68 61 72 20 2a 73 71 6c 69 74 65 33 56 64   char *sqlite3Vd
2200: 62 65 45 78 70 61 6e 64 53 71 6c 28 56 64 62 65  beExpandSql(Vdbe
2210: 2a 2c 20 63 6f 6e 73 74 20 63 68 61 72 2a 29 3b  *, const char*);
2220: 0a 23 65 6e 64 69 66 0a 0a 76 6f 69 64 20 73 71  .#endif..void sq
2230: 6c 69 74 65 33 56 64 62 65 52 65 63 6f 72 64 55  lite3VdbeRecordU
2240: 6e 70 61 63 6b 28 4b 65 79 49 6e 66 6f 2a 2c 69  npack(KeyInfo*,i
2250: 6e 74 2c 63 6f 6e 73 74 20 76 6f 69 64 2a 2c 55  nt,const void*,U
2260: 6e 70 61 63 6b 65 64 52 65 63 6f 72 64 2a 29 3b  npackedRecord*);
2270: 0a 69 6e 74 20 73 71 6c 69 74 65 33 56 64 62 65  .int sqlite3Vdbe
2280: 52 65 63 6f 72 64 43 6f 6d 70 61 72 65 28 69 6e  RecordCompare(in
2290: 74 2c 63 6f 6e 73 74 20 76 6f 69 64 2a 2c 55 6e  t,const void*,Un
22a0: 70 61 63 6b 65 64 52 65 63 6f 72 64 2a 29 3b 0a  packedRecord*);.
22b0: 55 6e 70 61 63 6b 65 64 52 65 63 6f 72 64 20 2a  UnpackedRecord *
22c0: 73 71 6c 69 74 65 33 56 64 62 65 41 6c 6c 6f 63  sqlite3VdbeAlloc
22d0: 55 6e 70 61 63 6b 65 64 52 65 63 6f 72 64 28 4b  UnpackedRecord(K
22e0: 65 79 49 6e 66 6f 20 2a 2c 20 63 68 61 72 20 2a  eyInfo *, char *
22f0: 2c 20 69 6e 74 2c 20 63 68 61 72 20 2a 2a 29 3b  , int, char **);
2300: 0a 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45  ..#ifndef SQLITE
2310: 5f 4f 4d 49 54 5f 54 52 49 47 47 45 52 0a 76 6f  _OMIT_TRIGGER.vo
2320: 69 64 20 73 71 6c 69 74 65 33 56 64 62 65 4c 69  id sqlite3VdbeLi
2330: 6e 6b 53 75 62 50 72 6f 67 72 61 6d 28 56 64 62  nkSubProgram(Vdb
2340: 65 20 2a 2c 20 53 75 62 50 72 6f 67 72 61 6d 20  e *, SubProgram 
2350: 2a 29 3b 0a 23 65 6e 64 69 66 0a 0a 0a 23 69 66  *);.#endif...#if
2360: 6e 64 65 66 20 4e 44 45 42 55 47 0a 20 20 76 6f  ndef NDEBUG.  vo
2370: 69 64 20 73 71 6c 69 74 65 33 56 64 62 65 43 6f  id sqlite3VdbeCo
2380: 6d 6d 65 6e 74 28 56 64 62 65 2a 2c 20 63 6f 6e  mment(Vdbe*, con
2390: 73 74 20 63 68 61 72 2a 2c 20 2e 2e 2e 29 3b 0a  st char*, ...);.
23a0: 23 20 64 65 66 69 6e 65 20 56 64 62 65 43 6f 6d  # define VdbeCom
23b0: 6d 65 6e 74 28 58 29 20 20 73 71 6c 69 74 65 33  ment(X)  sqlite3
23c0: 56 64 62 65 43 6f 6d 6d 65 6e 74 20 58 0a 20 20  VdbeComment X.  
23d0: 76 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62 65  void sqlite3Vdbe
23e0: 4e 6f 6f 70 43 6f 6d 6d 65 6e 74 28 56 64 62 65  NoopComment(Vdbe
23f0: 2a 2c 20 63 6f 6e 73 74 20 63 68 61 72 2a 2c 20  *, const char*, 
2400: 2e 2e 2e 29 3b 0a 23 20 64 65 66 69 6e 65 20 56  ...);.# define V
2410: 64 62 65 4e 6f 6f 70 43 6f 6d 6d 65 6e 74 28 58  dbeNoopComment(X
2420: 29 20 20 73 71 6c 69 74 65 33 56 64 62 65 4e 6f  )  sqlite3VdbeNo
2430: 6f 70 43 6f 6d 6d 65 6e 74 20 58 0a 23 65 6c 73  opComment X.#els
2440: 65 0a 23 20 64 65 66 69 6e 65 20 56 64 62 65 43  e.# define VdbeC
2450: 6f 6d 6d 65 6e 74 28 58 29 0a 23 20 64 65 66 69  omment(X).# defi
2460: 6e 65 20 56 64 62 65 4e 6f 6f 70 43 6f 6d 6d 65  ne VdbeNoopComme
2470: 6e 74 28 58 29 0a 23 65 6e 64 69 66 0a 0a 23 65  nt(X).#endif..#e
2480: 6e 64 69 66 0a                                   ndif.