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

Artifact 79e09ff13b85457abe437d9814454534ebbc1fe3:


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 31 35 20 32  vdbe.h,v 1.115 2
0290: 30 30 37 2f 31 31 2f 31 34 20 30 36 3a 34 38 3a  007/11/14 06:48:
02a0: 34 38 20 64 61 6e 69 65 6c 6b 31 39 37 37 20 45  48 danielk1977 E
02b0: 78 70 20 24 0a 2a 2f 0a 23 69 66 6e 64 65 66 20  xp $.*/.#ifndef 
02c0: 5f 53 51 4c 49 54 45 5f 56 44 42 45 5f 48 5f 0a  _SQLITE_VDBE_H_.
02d0: 23 64 65 66 69 6e 65 20 5f 53 51 4c 49 54 45 5f  #define _SQLITE_
02e0: 56 44 42 45 5f 48 5f 0a 23 69 6e 63 6c 75 64 65  VDBE_H_.#include
02f0: 20 3c 73 74 64 69 6f 2e 68 3e 0a 0a 2f 2a 0a 2a   <stdio.h>../*.*
0300: 2a 20 41 20 73 69 6e 67 6c 65 20 56 44 42 45 20  * A single VDBE 
0310: 69 73 20 61 6e 20 6f 70 61 71 75 65 20 73 74 72  is an opaque str
0320: 75 63 74 75 72 65 20 6e 61 6d 65 64 20 22 56 64  ucture named "Vd
0330: 62 65 22 2e 20 20 4f 6e 6c 79 20 72 6f 75 74 69  be".  Only routi
0340: 6e 65 73 0a 2a 2a 20 69 6e 20 74 68 65 20 73 6f  nes.** in the so
0350: 75 72 63 65 20 66 69 6c 65 20 73 71 6c 69 74 65  urce file sqlite
0360: 56 64 62 65 2e 63 20 61 72 65 20 61 6c 6c 6f 77  Vdbe.c are allow
0370: 65 64 20 74 6f 20 73 65 65 20 74 68 65 20 69 6e  ed to see the in
0380: 73 69 64 65 73 0a 2a 2a 20 6f 66 20 74 68 69 73  sides.** of this
0390: 20 73 74 72 75 63 74 75 72 65 2e 0a 2a 2f 0a 74   structure..*/.t
03a0: 79 70 65 64 65 66 20 73 74 72 75 63 74 20 56 64  ypedef struct Vd
03b0: 62 65 20 56 64 62 65 3b 0a 0a 2f 2a 0a 2a 2a 20  be Vdbe;../*.** 
03c0: 41 20 73 69 6e 67 6c 65 20 69 6e 73 74 72 75 63  A single instruc
03d0: 74 69 6f 6e 20 6f 66 20 74 68 65 20 76 69 72 74  tion of the virt
03e0: 75 61 6c 20 6d 61 63 68 69 6e 65 20 68 61 73 20  ual machine has 
03f0: 61 6e 20 6f 70 63 6f 64 65 0a 2a 2a 20 61 6e 64  an opcode.** and
0400: 20 61 73 20 6d 61 6e 79 20 61 73 20 74 68 72 65   as many as thre
0410: 65 20 6f 70 65 72 61 6e 64 73 2e 20 20 54 68 65  e operands.  The
0420: 20 69 6e 73 74 72 75 63 74 69 6f 6e 20 69 73 20   instruction is 
0430: 72 65 63 6f 72 64 65 64 0a 2a 2a 20 61 73 20 61  recorded.** as a
0440: 6e 20 69 6e 73 74 61 6e 63 65 20 6f 66 20 74 68  n instance of th
0450: 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 73 74 72 75  e following stru
0460: 63 74 75 72 65 3a 0a 2a 2f 0a 73 74 72 75 63 74  cture:.*/.struct
0470: 20 56 64 62 65 4f 70 20 7b 0a 20 20 75 38 20 6f   VdbeOp {.  u8 o
0480: 70 63 6f 64 65 3b 20 20 20 20 20 20 20 20 20 20  pcode;          
0490: 2f 2a 20 57 68 61 74 20 6f 70 65 72 61 74 69 6f  /* What operatio
04a0: 6e 20 74 6f 20 70 65 72 66 6f 72 6d 20 2a 2f 0a  n to perform */.
04b0: 20 20 69 6e 74 20 70 31 3b 20 20 20 20 20 20 20    int p1;       
04c0: 20 20 20 20 20 20 2f 2a 20 46 69 72 73 74 20 6f        /* First o
04d0: 70 65 72 61 6e 64 20 2a 2f 0a 20 20 69 6e 74 20  perand */.  int 
04e0: 70 32 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  p2;             
04f0: 2f 2a 20 53 65 63 6f 6e 64 20 70 61 72 61 6d 65  /* Second parame
0500: 74 65 72 20 28 6f 66 74 65 6e 20 74 68 65 20 6a  ter (often the j
0510: 75 6d 70 20 64 65 73 74 69 6e 61 74 69 6f 6e 29  ump destination)
0520: 20 2a 2f 0a 20 20 63 68 61 72 20 2a 70 33 3b 20   */.  char *p3; 
0530: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68 69            /* Thi
0540: 72 64 20 70 61 72 61 6d 65 74 65 72 20 2a 2f 0a  rd parameter */.
0550: 20 20 69 6e 74 20 70 33 74 79 70 65 3b 20 20 20    int p3type;   
0560: 20 20 20 20 20 20 2f 2a 20 4f 6e 65 20 6f 66 20        /* One of 
0570: 74 68 65 20 50 33 5f 78 78 78 20 63 6f 6e 73 74  the P3_xxx const
0580: 61 6e 74 73 20 64 65 66 69 6e 65 64 20 62 65 6c  ants defined bel
0590: 6f 77 20 2a 2f 0a 23 69 66 64 65 66 20 56 44 42  ow */.#ifdef VDB
05a0: 45 5f 50 52 4f 46 49 4c 45 0a 20 20 69 6e 74 20  E_PROFILE.  int 
05b0: 63 6e 74 3b 20 20 20 20 20 20 20 20 20 20 20 20  cnt;            
05c0: 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 74 69 6d  /* Number of tim
05d0: 65 73 20 74 68 69 73 20 69 6e 73 74 72 75 63 74  es this instruct
05e0: 69 6f 6e 20 77 61 73 20 65 78 65 63 75 74 65 64  ion was executed
05f0: 20 2a 2f 0a 20 20 6c 6f 6e 67 20 6c 6f 6e 67 20   */.  long long 
0600: 63 79 63 6c 65 73 3b 20 20 20 2f 2a 20 54 6f 74  cycles;   /* Tot
0610: 61 6c 20 74 69 6d 65 20 73 70 65 6e 64 20 65 78  al time spend ex
0620: 65 63 75 74 69 6e 67 20 74 68 69 73 20 69 6e 73  ecuting this ins
0630: 74 72 75 63 74 69 6f 6e 20 2a 2f 0a 23 65 6e 64  truction */.#end
0640: 69 66 0a 7d 3b 0a 74 79 70 65 64 65 66 20 73 74  if.};.typedef st
0650: 72 75 63 74 20 56 64 62 65 4f 70 20 56 64 62 65  ruct VdbeOp Vdbe
0660: 4f 70 3b 0a 0a 2f 2a 0a 2a 2a 20 41 20 73 6d 61  Op;../*.** A sma
0670: 6c 6c 65 72 20 76 65 72 73 69 6f 6e 20 6f 66 20  ller version of 
0680: 56 64 62 65 4f 70 20 75 73 65 64 20 66 6f 72 20  VdbeOp used for 
0690: 74 68 65 20 56 64 62 65 41 64 64 4f 70 4c 69 73  the VdbeAddOpLis
06a0: 74 28 29 20 66 75 6e 63 74 69 6f 6e 20 62 65 63  t() function bec
06b0: 61 75 73 65 0a 2a 2a 20 69 74 20 74 61 6b 65 73  ause.** it takes
06c0: 20 75 70 20 6c 65 73 73 20 73 70 61 63 65 2e 0a   up less space..
06d0: 2a 2f 0a 73 74 72 75 63 74 20 56 64 62 65 4f 70  */.struct VdbeOp
06e0: 4c 69 73 74 20 7b 0a 20 20 75 38 20 6f 70 63 6f  List {.  u8 opco
06f0: 64 65 3b 20 20 20 20 20 20 20 20 20 20 2f 2a 20  de;          /* 
0700: 57 68 61 74 20 6f 70 65 72 61 74 69 6f 6e 20 74  What operation t
0710: 6f 20 70 65 72 66 6f 72 6d 20 2a 2f 0a 20 20 73  o perform */.  s
0720: 69 67 6e 65 64 20 63 68 61 72 20 70 31 3b 20 20  igned char p1;  
0730: 20 20 20 2f 2a 20 46 69 72 73 74 20 6f 70 65 72     /* First oper
0740: 61 6e 64 20 2a 2f 0a 20 20 73 68 6f 72 74 20 69  and */.  short i
0750: 6e 74 20 70 32 3b 20 20 20 20 20 20 20 2f 2a 20  nt p2;       /* 
0760: 53 65 63 6f 6e 64 20 70 61 72 61 6d 65 74 65 72  Second parameter
0770: 20 28 6f 66 74 65 6e 20 74 68 65 20 6a 75 6d 70   (often the jump
0780: 20 64 65 73 74 69 6e 61 74 69 6f 6e 29 20 2a 2f   destination) */
0790: 0a 20 20 63 68 61 72 20 2a 70 33 3b 20 20 20 20  .  char *p3;    
07a0: 20 20 20 20 20 20 20 2f 2a 20 54 68 69 72 64 20         /* Third 
07b0: 70 61 72 61 6d 65 74 65 72 20 2a 2f 0a 7d 3b 0a  parameter */.};.
07c0: 74 79 70 65 64 65 66 20 73 74 72 75 63 74 20 56  typedef struct V
07d0: 64 62 65 4f 70 4c 69 73 74 20 56 64 62 65 4f 70  dbeOpList VdbeOp
07e0: 4c 69 73 74 3b 0a 0a 2f 2a 0a 2a 2a 20 41 6c 6c  List;../*.** All
07f0: 6f 77 65 64 20 76 61 6c 75 65 73 20 6f 66 20 56  owed values of V
0800: 64 62 65 4f 70 2e 70 33 74 79 70 65 0a 2a 2f 0a  dbeOp.p3type.*/.
0810: 23 64 65 66 69 6e 65 20 50 33 5f 4e 4f 54 55 53  #define P3_NOTUS
0820: 45 44 20 20 20 20 30 20 20 20 2f 2a 20 54 68 65  ED    0   /* The
0830: 20 50 33 20 70 61 72 61 6d 65 74 65 72 20 69 73   P3 parameter is
0840: 20 6e 6f 74 20 75 73 65 64 20 2a 2f 0a 23 64 65   not used */.#de
0850: 66 69 6e 65 20 50 33 5f 44 59 4e 41 4d 49 43 20  fine P3_DYNAMIC 
0860: 20 28 2d 31 29 20 20 2f 2a 20 50 6f 69 6e 74 65   (-1)  /* Pointe
0870: 72 20 74 6f 20 61 20 73 74 72 69 6e 67 20 6f 62  r to a string ob
0880: 74 61 69 6e 65 64 20 66 72 6f 6d 20 73 71 6c 69  tained from sqli
0890: 74 65 4d 61 6c 6c 6f 63 28 29 20 2a 2f 0a 23 64  teMalloc() */.#d
08a0: 65 66 69 6e 65 20 50 33 5f 53 54 41 54 49 43 20  efine P3_STATIC 
08b0: 20 20 28 2d 32 29 20 20 2f 2a 20 50 6f 69 6e 74    (-2)  /* Point
08c0: 65 72 20 74 6f 20 61 20 73 74 61 74 69 63 20 73  er to a static s
08d0: 74 72 69 6e 67 20 2a 2f 0a 23 64 65 66 69 6e 65  tring */.#define
08e0: 20 50 33 5f 43 4f 4c 4c 53 45 51 20 20 28 2d 34   P3_COLLSEQ  (-4
08f0: 29 20 20 2f 2a 20 50 33 20 69 73 20 61 20 70 6f  )  /* P3 is a po
0900: 69 6e 74 65 72 20 74 6f 20 61 20 43 6f 6c 6c 53  inter to a CollS
0910: 65 71 20 73 74 72 75 63 74 75 72 65 20 2a 2f 0a  eq structure */.
0920: 23 64 65 66 69 6e 65 20 50 33 5f 46 55 4e 43 44  #define P3_FUNCD
0930: 45 46 20 20 28 2d 35 29 20 20 2f 2a 20 50 33 20  EF  (-5)  /* P3 
0940: 69 73 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20  is a pointer to 
0950: 61 20 46 75 6e 63 44 65 66 20 73 74 72 75 63 74  a FuncDef struct
0960: 75 72 65 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50  ure */.#define P
0970: 33 5f 4b 45 59 49 4e 46 4f 20 20 28 2d 36 29 20  3_KEYINFO  (-6) 
0980: 20 2f 2a 20 50 33 20 69 73 20 61 20 70 6f 69 6e   /* P3 is a poin
0990: 74 65 72 20 74 6f 20 61 20 4b 65 79 49 6e 66 6f  ter to a KeyInfo
09a0: 20 73 74 72 75 63 74 75 72 65 20 2a 2f 0a 23 64   structure */.#d
09b0: 65 66 69 6e 65 20 50 33 5f 56 44 42 45 46 55 4e  efine P3_VDBEFUN
09c0: 43 20 28 2d 37 29 20 20 2f 2a 20 50 33 20 69 73  C (-7)  /* P3 is
09d0: 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 61 20   a pointer to a 
09e0: 56 64 62 65 46 75 6e 63 20 73 74 72 75 63 74 75  VdbeFunc structu
09f0: 72 65 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50 33  re */.#define P3
0a00: 5f 4d 45 4d 20 20 20 20 20 20 28 2d 38 29 20 20  _MEM      (-8)  
0a10: 2f 2a 20 50 33 20 69 73 20 61 20 70 6f 69 6e 74  /* P3 is a point
0a20: 65 72 20 74 6f 20 61 20 4d 65 6d 2a 20 20 20 20  er to a Mem*    
0a30: 73 74 72 75 63 74 75 72 65 20 2a 2f 0a 23 64 65  structure */.#de
0a40: 66 69 6e 65 20 50 33 5f 54 52 41 4e 53 49 45 4e  fine P3_TRANSIEN
0a50: 54 20 28 2d 39 29 20 2f 2a 20 50 33 20 69 73 20  T (-9) /* P3 is 
0a60: 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 61 20 74  a pointer to a t
0a70: 72 61 6e 73 69 65 6e 74 20 73 74 72 69 6e 67 20  ransient string 
0a80: 2a 2f 0a 23 64 65 66 69 6e 65 20 50 33 5f 56 54  */.#define P3_VT
0a90: 41 42 20 20 20 20 20 28 2d 31 30 29 20 2f 2a 20  AB     (-10) /* 
0aa0: 50 33 20 69 73 20 61 20 70 6f 69 6e 74 65 72 20  P3 is a pointer 
0ab0: 74 6f 20 61 6e 20 73 71 6c 69 74 65 33 5f 76 74  to an sqlite3_vt
0ac0: 61 62 20 73 74 72 75 63 74 75 72 65 20 2a 2f 0a  ab structure */.
0ad0: 23 64 65 66 69 6e 65 20 50 33 5f 4d 50 52 49 4e  #define P3_MPRIN
0ae0: 54 46 20 20 28 2d 31 31 29 20 2f 2a 20 50 33 20  TF  (-11) /* P3 
0af0: 69 73 20 61 20 73 74 72 69 6e 67 20 6f 62 74 61  is a string obta
0b00: 69 6e 65 64 20 66 72 6f 6d 20 73 71 6c 69 74 65  ined from sqlite
0b10: 33 5f 6d 70 72 69 6e 74 66 28 29 20 2a 2f 0a 23  3_mprintf() */.#
0b20: 64 65 66 69 6e 65 20 50 33 5f 52 45 41 4c 20 20  define P3_REAL  
0b30: 20 20 20 28 2d 31 32 29 20 2f 2a 20 50 33 20 69     (-12) /* P3 i
0b40: 73 20 61 20 36 34 2d 62 69 74 20 66 6c 6f 61 74  s a 64-bit float
0b50: 69 6e 67 20 70 6f 69 6e 74 20 76 61 6c 75 65 20  ing point value 
0b60: 2a 2f 0a 23 64 65 66 69 6e 65 20 50 33 5f 49 4e  */.#define P3_IN
0b70: 54 36 34 20 20 20 20 28 2d 31 33 29 20 2f 2a 20  T64    (-13) /* 
0b80: 50 33 20 69 73 20 61 20 36 34 2d 62 69 74 20 73  P3 is a 64-bit s
0b90: 69 67 6e 65 64 20 69 6e 74 65 67 65 72 20 2a 2f  igned integer */
0ba0: 0a 0a 2f 2a 20 57 68 65 6e 20 61 64 64 69 6e 67  ../* When adding
0bb0: 20 61 20 50 33 20 61 72 67 75 6d 65 6e 74 20 75   a P3 argument u
0bc0: 73 69 6e 67 20 50 33 5f 4b 45 59 49 4e 46 4f 2c  sing P3_KEYINFO,
0bd0: 20 61 20 63 6f 70 79 20 6f 66 20 74 68 65 20 4b   a copy of the K
0be0: 65 79 49 6e 66 6f 20 73 74 72 75 63 74 75 72 65  eyInfo structure
0bf0: 0a 2a 2a 20 69 73 20 6d 61 64 65 2e 20 20 54 68  .** is made.  Th
0c00: 61 74 20 63 6f 70 79 20 69 73 20 66 72 65 65 64  at copy is freed
0c10: 20 77 68 65 6e 20 74 68 65 20 56 64 62 65 20 69   when the Vdbe i
0c20: 73 20 66 69 6e 61 6c 69 7a 65 64 2e 20 20 42 75  s finalized.  Bu
0c30: 74 20 69 66 20 74 68 65 0a 2a 2a 20 61 72 67 75  t if the.** argu
0c40: 6d 65 6e 74 20 69 73 20 50 33 5f 4b 45 59 49 4e  ment is P3_KEYIN
0c50: 46 4f 5f 48 41 4e 44 4f 46 46 2c 20 74 68 65 20  FO_HANDOFF, the 
0c60: 70 61 73 73 65 64 20 69 6e 20 70 6f 69 6e 74 65  passed in pointe
0c70: 72 20 69 73 20 75 73 65 64 2e 20 20 49 74 20 73  r is used.  It s
0c80: 74 69 6c 6c 0a 2a 2a 20 67 65 74 73 20 66 72 65  till.** gets fre
0c90: 65 64 20 77 68 65 6e 20 74 68 65 20 56 64 62 65  ed when the Vdbe
0ca0: 20 69 73 20 66 69 6e 61 6c 69 7a 65 64 20 73 6f   is finalized so
0cb0: 20 69 74 20 73 74 69 6c 6c 20 73 68 6f 75 6c 64   it still should
0cc0: 20 62 65 20 6f 62 74 61 69 6e 65 64 0a 2a 2a 20   be obtained.** 
0cd0: 66 72 6f 6d 20 61 20 73 69 6e 67 6c 65 20 73 71  from a single sq
0ce0: 6c 69 74 65 4d 61 6c 6c 6f 63 28 29 2e 20 20 42  liteMalloc().  B
0cf0: 75 74 20 6e 6f 20 63 6f 70 79 20 69 73 20 6d 61  ut no copy is ma
0d00: 64 65 20 61 6e 64 20 74 68 65 20 63 61 6c 6c 69  de and the calli
0d10: 6e 67 0a 2a 2a 20 66 75 6e 63 74 69 6f 6e 20 73  ng.** function s
0d20: 68 6f 75 6c 64 20 2a 6e 6f 74 2a 20 74 72 79 20  hould *not* try 
0d30: 74 6f 20 66 72 65 65 20 74 68 65 20 4b 65 79 49  to free the KeyI
0d40: 6e 66 6f 2e 0a 2a 2f 0a 23 64 65 66 69 6e 65 20  nfo..*/.#define 
0d50: 50 33 5f 4b 45 59 49 4e 46 4f 5f 48 41 4e 44 4f  P3_KEYINFO_HANDO
0d60: 46 46 20 28 2d 39 29 0a 0a 2f 2a 0a 2a 2a 20 54  FF (-9)../*.** T
0d70: 68 65 20 56 64 62 65 2e 61 43 6f 6c 4e 61 6d 65  he Vdbe.aColName
0d80: 20 61 72 72 61 79 20 63 6f 6e 74 61 69 6e 73 20   array contains 
0d90: 35 6e 20 4d 65 6d 20 73 74 72 75 63 74 75 72 65  5n Mem structure
0da0: 73 2c 20 77 68 65 72 65 20 6e 20 69 73 20 74 68  s, where n is th
0db0: 65 20 0a 2a 2a 20 6e 75 6d 62 65 72 20 6f 66 20  e .** number of 
0dc0: 63 6f 6c 75 6d 6e 73 20 6f 66 20 64 61 74 61 20  columns of data 
0dd0: 72 65 74 75 72 6e 65 64 20 62 79 20 74 68 65 20  returned by the 
0de0: 73 74 61 74 65 6d 65 6e 74 2e 0a 2a 2f 0a 23 64  statement..*/.#d
0df0: 65 66 69 6e 65 20 43 4f 4c 4e 41 4d 45 5f 4e 41  efine COLNAME_NA
0e00: 4d 45 20 20 20 20 20 30 0a 23 64 65 66 69 6e 65  ME     0.#define
0e10: 20 43 4f 4c 4e 41 4d 45 5f 44 45 43 4c 54 59 50   COLNAME_DECLTYP
0e20: 45 20 31 0a 23 64 65 66 69 6e 65 20 43 4f 4c 4e  E 1.#define COLN
0e30: 41 4d 45 5f 44 41 54 41 42 41 53 45 20 32 0a 23  AME_DATABASE 2.#
0e40: 64 65 66 69 6e 65 20 43 4f 4c 4e 41 4d 45 5f 54  define COLNAME_T
0e50: 41 42 4c 45 20 20 20 20 33 0a 23 64 65 66 69 6e  ABLE    3.#defin
0e60: 65 20 43 4f 4c 4e 41 4d 45 5f 43 4f 4c 55 4d 4e  e COLNAME_COLUMN
0e70: 20 20 20 34 0a 23 64 65 66 69 6e 65 20 43 4f 4c     4.#define COL
0e80: 4e 41 4d 45 5f 4e 20 20 20 20 20 20 20 20 35 20  NAME_N        5 
0e90: 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f       /* Number o
0ea0: 66 20 43 4f 4c 4e 41 4d 45 5f 78 78 78 20 73 79  f COLNAME_xxx sy
0eb0: 6d 62 6f 6c 73 20 2a 2f 0a 0a 2f 2a 0a 2a 2a 20  mbols */../*.** 
0ec0: 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 6d 61  The following ma
0ed0: 63 72 6f 20 63 6f 6e 76 65 72 74 73 20 61 20 72  cro converts a r
0ee0: 65 6c 61 74 69 76 65 20 61 64 64 72 65 73 73 20  elative address 
0ef0: 69 6e 20 74 68 65 20 70 32 20 66 69 65 6c 64 0a  in the p2 field.
0f00: 2a 2a 20 6f 66 20 61 20 56 64 62 65 4f 70 20 73  ** of a VdbeOp s
0f10: 74 72 75 63 74 75 72 65 20 69 6e 74 6f 20 61 20  tructure into a 
0f20: 6e 65 67 61 74 69 76 65 20 6e 75 6d 62 65 72 20  negative number 
0f30: 73 6f 20 74 68 61 74 20 0a 2a 2a 20 73 71 6c 69  so that .** sqli
0f40: 74 65 33 56 64 62 65 41 64 64 4f 70 4c 69 73 74  te3VdbeAddOpList
0f50: 28 29 20 6b 6e 6f 77 73 20 74 68 61 74 20 74 68  () knows that th
0f60: 65 20 61 64 64 72 65 73 73 20 69 73 20 72 65 6c  e address is rel
0f70: 61 74 69 76 65 2e 20 20 43 61 6c 6c 69 6e 67 0a  ative.  Calling.
0f80: 2a 2a 20 74 68 65 20 6d 61 63 72 6f 20 61 67 61  ** the macro aga
0f90: 69 6e 20 72 65 73 74 6f 72 65 73 20 74 68 65 20  in restores the 
0fa0: 61 64 64 72 65 73 73 2e 0a 2a 2f 0a 23 64 65 66  address..*/.#def
0fb0: 69 6e 65 20 41 44 44 52 28 58 29 20 20 28 2d 31  ine ADDR(X)  (-1
0fc0: 2d 28 58 29 29 0a 0a 2f 2a 0a 2a 2a 20 54 68 65  -(X))../*.** The
0fd0: 20 6d 61 6b 65 66 69 6c 65 20 73 63 61 6e 73 20   makefile scans 
0fe0: 74 68 65 20 76 64 62 65 2e 63 20 73 6f 75 72 63  the vdbe.c sourc
0ff0: 65 20 66 69 6c 65 20 61 6e 64 20 63 72 65 61 74  e file and creat
1000: 65 73 20 74 68 65 20 22 6f 70 63 6f 64 65 73 2e  es the "opcodes.
1010: 68 22 0a 2a 2a 20 68 65 61 64 65 72 20 66 69 6c  h".** header fil
1020: 65 20 74 68 61 74 20 64 65 66 69 6e 65 73 20 61  e that defines a
1030: 20 6e 75 6d 62 65 72 20 66 6f 72 20 65 61 63 68   number for each
1040: 20 6f 70 63 6f 64 65 20 75 73 65 64 20 62 79 20   opcode used by 
1050: 74 68 65 20 56 44 42 45 2e 0a 2a 2f 0a 23 69 6e  the VDBE..*/.#in
1060: 63 6c 75 64 65 20 22 6f 70 63 6f 64 65 73 2e 68  clude "opcodes.h
1070: 22 0a 0a 2f 2a 0a 2a 2a 20 50 72 6f 74 6f 74 79  "../*.** Prototy
1080: 70 65 73 20 66 6f 72 20 74 68 65 20 56 44 42 45  pes for the VDBE
1090: 20 69 6e 74 65 72 66 61 63 65 2e 20 20 53 65 65   interface.  See
10a0: 20 63 6f 6d 6d 65 6e 74 73 20 6f 6e 20 74 68 65   comments on the
10b0: 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 0a   implementation.
10c0: 2a 2a 20 66 6f 72 20 61 20 64 65 73 63 72 69 70  ** for a descrip
10d0: 74 69 6f 6e 20 6f 66 20 77 68 61 74 20 65 61 63  tion of what eac
10e0: 68 20 6f 66 20 74 68 65 73 65 20 72 6f 75 74 69  h of these routi
10f0: 6e 65 73 20 64 6f 65 73 2e 0a 2a 2f 0a 56 64 62  nes does..*/.Vdb
1100: 65 20 2a 73 71 6c 69 74 65 33 56 64 62 65 43 72  e *sqlite3VdbeCr
1110: 65 61 74 65 28 73 71 6c 69 74 65 33 2a 29 3b 0a  eate(sqlite3*);.
1120: 69 6e 74 20 73 71 6c 69 74 65 33 56 64 62 65 41  int sqlite3VdbeA
1130: 64 64 4f 70 28 56 64 62 65 2a 2c 69 6e 74 2c 69  ddOp(Vdbe*,int,i
1140: 6e 74 2c 69 6e 74 29 3b 0a 69 6e 74 20 73 71 6c  nt,int);.int sql
1150: 69 74 65 33 56 64 62 65 4f 70 33 28 56 64 62 65  ite3VdbeOp3(Vdbe
1160: 2a 2c 69 6e 74 2c 69 6e 74 2c 69 6e 74 2c 63 6f  *,int,int,int,co
1170: 6e 73 74 20 63 68 61 72 20 2a 7a 50 33 2c 69 6e  nst char *zP3,in
1180: 74 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 56  t);.int sqlite3V
1190: 64 62 65 41 64 64 4f 70 4c 69 73 74 28 56 64 62  dbeAddOpList(Vdb
11a0: 65 2a 2c 20 69 6e 74 20 6e 4f 70 2c 20 56 64 62  e*, int nOp, Vdb
11b0: 65 4f 70 4c 69 73 74 20 63 6f 6e 73 74 20 2a 61  eOpList const *a
11c0: 4f 70 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74 65  Op);.void sqlite
11d0: 33 56 64 62 65 43 68 61 6e 67 65 50 31 28 56 64  3VdbeChangeP1(Vd
11e0: 62 65 2a 2c 20 69 6e 74 20 61 64 64 72 2c 20 69  be*, int addr, i
11f0: 6e 74 20 50 31 29 3b 0a 76 6f 69 64 20 73 71 6c  nt P1);.void sql
1200: 69 74 65 33 56 64 62 65 43 68 61 6e 67 65 50 32  ite3VdbeChangeP2
1210: 28 56 64 62 65 2a 2c 20 69 6e 74 20 61 64 64 72  (Vdbe*, int addr
1220: 2c 20 69 6e 74 20 50 32 29 3b 0a 76 6f 69 64 20  , int P2);.void 
1230: 73 71 6c 69 74 65 33 56 64 62 65 4a 75 6d 70 48  sqlite3VdbeJumpH
1240: 65 72 65 28 56 64 62 65 2a 2c 20 69 6e 74 20 61  ere(Vdbe*, int a
1250: 64 64 72 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74  ddr);.void sqlit
1260: 65 33 56 64 62 65 43 68 61 6e 67 65 54 6f 4e 6f  e3VdbeChangeToNo
1270: 6f 70 28 56 64 62 65 2a 2c 20 69 6e 74 20 61 64  op(Vdbe*, int ad
1280: 64 72 2c 20 69 6e 74 20 4e 29 3b 0a 76 6f 69 64  dr, int N);.void
1290: 20 73 71 6c 69 74 65 33 56 64 62 65 43 68 61 6e   sqlite3VdbeChan
12a0: 67 65 50 33 28 56 64 62 65 2a 2c 20 69 6e 74 20  geP3(Vdbe*, int 
12b0: 61 64 64 72 2c 20 63 6f 6e 73 74 20 63 68 61 72  addr, const char
12c0: 20 2a 7a 50 31 2c 20 69 6e 74 20 4e 29 3b 0a 76   *zP1, int N);.v
12d0: 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62 65 55  oid sqlite3VdbeU
12e0: 73 65 73 42 74 72 65 65 28 56 64 62 65 2a 2c 20  sesBtree(Vdbe*, 
12f0: 69 6e 74 29 3b 0a 56 64 62 65 4f 70 20 2a 73 71  int);.VdbeOp *sq
1300: 6c 69 74 65 33 56 64 62 65 47 65 74 4f 70 28 56  lite3VdbeGetOp(V
1310: 64 62 65 2a 2c 20 69 6e 74 29 3b 0a 69 6e 74 20  dbe*, int);.int 
1320: 73 71 6c 69 74 65 33 56 64 62 65 4d 61 6b 65 4c  sqlite3VdbeMakeL
1330: 61 62 65 6c 28 56 64 62 65 2a 29 3b 0a 76 6f 69  abel(Vdbe*);.voi
1340: 64 20 73 71 6c 69 74 65 33 56 64 62 65 44 65 6c  d sqlite3VdbeDel
1350: 65 74 65 28 56 64 62 65 2a 29 3b 0a 76 6f 69 64  ete(Vdbe*);.void
1360: 20 73 71 6c 69 74 65 33 56 64 62 65 4d 61 6b 65   sqlite3VdbeMake
1370: 52 65 61 64 79 28 56 64 62 65 2a 2c 69 6e 74 2c  Ready(Vdbe*,int,
1380: 69 6e 74 2c 69 6e 74 2c 69 6e 74 29 3b 0a 69 6e  int,int,int);.in
1390: 74 20 73 71 6c 69 74 65 33 56 64 62 65 46 69 6e  t sqlite3VdbeFin
13a0: 61 6c 69 7a 65 28 56 64 62 65 2a 29 3b 0a 76 6f  alize(Vdbe*);.vo
13b0: 69 64 20 73 71 6c 69 74 65 33 56 64 62 65 52 65  id sqlite3VdbeRe
13c0: 73 6f 6c 76 65 4c 61 62 65 6c 28 56 64 62 65 2a  solveLabel(Vdbe*
13d0: 2c 20 69 6e 74 29 3b 0a 69 6e 74 20 73 71 6c 69  , int);.int sqli
13e0: 74 65 33 56 64 62 65 43 75 72 72 65 6e 74 41 64  te3VdbeCurrentAd
13f0: 64 72 28 56 64 62 65 2a 29 3b 0a 23 69 66 64 65  dr(Vdbe*);.#ifde
1400: 66 20 53 51 4c 49 54 45 5f 44 45 42 55 47 0a 20  f SQLITE_DEBUG. 
1410: 20 76 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62   void sqlite3Vdb
1420: 65 54 72 61 63 65 28 56 64 62 65 2a 2c 46 49 4c  eTrace(Vdbe*,FIL
1430: 45 2a 29 3b 0a 23 65 6e 64 69 66 0a 76 6f 69 64  E*);.#endif.void
1440: 20 73 71 6c 69 74 65 33 56 64 62 65 52 65 73 65   sqlite3VdbeRese
1450: 74 53 74 65 70 52 65 73 75 6c 74 28 56 64 62 65  tStepResult(Vdbe
1460: 2a 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 56  *);.int sqlite3V
1470: 64 62 65 52 65 73 65 74 28 56 64 62 65 2a 29 3b  dbeReset(Vdbe*);
1480: 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62  .void sqlite3Vdb
1490: 65 53 65 74 4e 75 6d 43 6f 6c 73 28 56 64 62 65  eSetNumCols(Vdbe
14a0: 2a 2c 69 6e 74 29 3b 0a 69 6e 74 20 73 71 6c 69  *,int);.int sqli
14b0: 74 65 33 56 64 62 65 53 65 74 43 6f 6c 4e 61 6d  te3VdbeSetColNam
14c0: 65 28 56 64 62 65 2a 2c 20 69 6e 74 2c 20 69 6e  e(Vdbe*, int, in
14d0: 74 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 2c  t, const char *,
14e0: 20 69 6e 74 29 3b 0a 76 6f 69 64 20 73 71 6c 69   int);.void sqli
14f0: 74 65 33 56 64 62 65 43 6f 75 6e 74 43 68 61 6e  te3VdbeCountChan
1500: 67 65 73 28 56 64 62 65 2a 29 3b 0a 73 71 6c 69  ges(Vdbe*);.sqli
1510: 74 65 33 20 2a 73 71 6c 69 74 65 33 56 64 62 65  te3 *sqlite3Vdbe
1520: 44 62 28 56 64 62 65 2a 29 3b 0a 76 6f 69 64 20  Db(Vdbe*);.void 
1530: 73 71 6c 69 74 65 33 56 64 62 65 53 65 74 53 71  sqlite3VdbeSetSq
1540: 6c 28 56 64 62 65 2a 2c 20 63 6f 6e 73 74 20 63  l(Vdbe*, const c
1550: 68 61 72 20 2a 7a 2c 20 69 6e 74 20 6e 29 3b 0a  har *z, int n);.
1560: 76 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62 65  void sqlite3Vdbe
1570: 53 77 61 70 28 56 64 62 65 2a 2c 56 64 62 65 2a  Swap(Vdbe*,Vdbe*
1580: 29 3b 0a 0a 23 69 66 6e 64 65 66 20 4e 44 45 42  );..#ifndef NDEB
1590: 55 47 0a 20 20 76 6f 69 64 20 73 71 6c 69 74 65  UG.  void sqlite
15a0: 33 56 64 62 65 43 6f 6d 6d 65 6e 74 28 56 64 62  3VdbeComment(Vdb
15b0: 65 2a 2c 20 63 6f 6e 73 74 20 63 68 61 72 2a 2c  e*, const char*,
15c0: 20 2e 2e 2e 29 3b 0a 23 20 64 65 66 69 6e 65 20   ...);.# define 
15d0: 56 64 62 65 43 6f 6d 6d 65 6e 74 28 58 29 20 20  VdbeComment(X)  
15e0: 73 71 6c 69 74 65 33 56 64 62 65 43 6f 6d 6d 65  sqlite3VdbeComme
15f0: 6e 74 20 58 0a 23 65 6c 73 65 0a 23 20 64 65 66  nt X.#else.# def
1600: 69 6e 65 20 56 64 62 65 43 6f 6d 6d 65 6e 74 28  ine VdbeComment(
1610: 58 29 0a 23 65 6e 64 69 66 0a 0a 23 65 6e 64 69  X).#endif..#endi
1620: 66 0a                                            f.