/ Hex Artifact Content
Login

Artifact 7738dd1d851856f2003db199d160c573b04ac383f4a3db9461a34efefe995d20:


0000: 2f 2a 0a 2a 2a 20 32 30 30 33 20 53 65 70 74 65  /*.** 2003 Septe
0010: 6d 62 65 72 20 36 0a 2a 2a 0a 2a 2a 20 54 68 65  mber 6.**.** The
0020: 20 61 75 74 68 6f 72 20 64 69 73 63 6c 61 69 6d   author disclaim
0030: 73 20 63 6f 70 79 72 69 67 68 74 20 74 6f 20 74  s copyright to t
0040: 68 69 73 20 73 6f 75 72 63 65 20 63 6f 64 65 2e  his source code.
0050: 20 20 49 6e 20 70 6c 61 63 65 20 6f 66 0a 2a 2a    In place of.**
0060: 20 61 20 6c 65 67 61 6c 20 6e 6f 74 69 63 65 2c   a legal notice,
0070: 20 68 65 72 65 20 69 73 20 61 20 62 6c 65 73 73   here is a bless
0080: 69 6e 67 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 4d 61  ing:.**.**    Ma
0090: 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20 61 6e  y you do good an
00a0: 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 2a 2a 20 20  d not evil..**  
00b0: 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20 66    May you find f
00c0: 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20 79  orgiveness for y
00d0: 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72 67  ourself and forg
00e0: 69 76 65 20 6f 74 68 65 72 73 2e 0a 2a 2a 20 20  ive others..**  
00f0: 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65 20    May you share 
0100: 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74 61  freely, never ta
0110: 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20 79  king more than y
0120: 6f 75 20 67 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a  ou 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 0a 2a 2a 20 54 68 69 73 20 69 73  *****.** This is
0180: 20 74 68 65 20 68 65 61 64 65 72 20 66 69 6c 65   the header file
0190: 20 66 6f 72 20 69 6e 66 6f 72 6d 61 74 69 6f 6e   for information
01a0: 20 74 68 61 74 20 69 73 20 70 72 69 76 61 74 65   that is private
01b0: 20 74 6f 20 74 68 65 0a 2a 2a 20 56 44 42 45 2e   to the.** VDBE.
01c0: 20 20 54 68 69 73 20 69 6e 66 6f 72 6d 61 74 69    This informati
01d0: 6f 6e 20 75 73 65 64 20 74 6f 20 61 6c 6c 20 62  on used to all b
01e0: 65 20 61 74 20 74 68 65 20 74 6f 70 20 6f 66 20  e at the top of 
01f0: 74 68 65 20 73 69 6e 67 6c 65 0a 2a 2a 20 73 6f  the single.** so
0200: 75 72 63 65 20 63 6f 64 65 20 66 69 6c 65 20 22  urce code file "
0210: 76 64 62 65 2e 63 22 2e 20 20 57 68 65 6e 20 74  vdbe.c".  When t
0220: 68 61 74 20 66 69 6c 65 20 62 65 63 61 6d 65 20  hat file became 
0230: 74 6f 6f 20 62 69 67 20 28 6f 76 65 72 0a 2a 2a  too big (over.**
0240: 20 36 30 30 30 20 6c 69 6e 65 73 20 6c 6f 6e 67   6000 lines long
0250: 29 20 69 74 20 77 61 73 20 73 70 6c 69 74 20 75  ) it was split u
0260: 70 20 69 6e 74 6f 20 73 65 76 65 72 61 6c 20 73  p into several s
0270: 6d 61 6c 6c 65 72 20 66 69 6c 65 73 20 61 6e 64  maller files and
0280: 0a 2a 2a 20 74 68 69 73 20 68 65 61 64 65 72 20  .** this header 
0290: 69 6e 66 6f 72 6d 61 74 69 6f 6e 20 77 61 73 20  information was 
02a0: 66 61 63 74 6f 72 65 64 20 6f 75 74 2e 0a 2a 2f  factored out..*/
02b0: 0a 23 69 66 6e 64 65 66 20 5f 56 44 42 45 49 4e  .#ifndef _VDBEIN
02c0: 54 5f 48 5f 0a 23 64 65 66 69 6e 65 20 5f 56 44  T_H_.#define _VD
02d0: 42 45 49 4e 54 5f 48 5f 0a 0a 2f 2a 0a 2a 2a 20  BEINT_H_../*.** 
02e0: 54 68 65 20 6d 61 78 69 6d 75 6d 20 6e 75 6d 62  The maximum numb
02f0: 65 72 20 6f 66 20 74 69 6d 65 73 20 74 68 61 74  er of times that
0300: 20 61 20 73 74 61 74 65 6d 65 6e 74 20 77 69 6c   a statement wil
0310: 6c 20 74 72 79 20 74 6f 20 72 65 70 61 72 73 65  l try to reparse
0320: 0a 2a 2a 20 69 74 73 65 6c 66 20 62 65 66 6f 72  .** itself befor
0330: 65 20 67 69 76 69 6e 67 20 75 70 20 61 6e 64 20  e giving up and 
0340: 72 65 74 75 72 6e 69 6e 67 20 53 51 4c 49 54 45  returning SQLITE
0350: 5f 53 43 48 45 4d 41 2e 0a 2a 2f 0a 23 69 66 6e  _SCHEMA..*/.#ifn
0360: 64 65 66 20 53 51 4c 49 54 45 5f 4d 41 58 5f 53  def SQLITE_MAX_S
0370: 43 48 45 4d 41 5f 52 45 54 52 59 0a 23 20 64 65  CHEMA_RETRY.# de
0380: 66 69 6e 65 20 53 51 4c 49 54 45 5f 4d 41 58 5f  fine SQLITE_MAX_
0390: 53 43 48 45 4d 41 5f 52 45 54 52 59 20 35 30 0a  SCHEMA_RETRY 50.
03a0: 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 53 51  #endif../*.** SQ
03b0: 4c 20 69 73 20 74 72 61 6e 73 6c 61 74 65 64 20  L is translated 
03c0: 69 6e 74 6f 20 61 20 73 65 71 75 65 6e 63 65 20  into a sequence 
03d0: 6f 66 20 69 6e 73 74 72 75 63 74 69 6f 6e 73 20  of instructions 
03e0: 74 6f 20 62 65 0a 2a 2a 20 65 78 65 63 75 74 65  to be.** execute
03f0: 64 20 62 79 20 61 20 76 69 72 74 75 61 6c 20 6d  d by a virtual m
0400: 61 63 68 69 6e 65 2e 20 20 45 61 63 68 20 69 6e  achine.  Each in
0410: 73 74 72 75 63 74 69 6f 6e 20 69 73 20 61 6e 20  struction is an 
0420: 69 6e 73 74 61 6e 63 65 0a 2a 2a 20 6f 66 20 74  instance.** of t
0430: 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 73 74 72  he following str
0440: 75 63 74 75 72 65 2e 0a 2a 2f 0a 74 79 70 65 64  ucture..*/.typed
0450: 65 66 20 73 74 72 75 63 74 20 56 64 62 65 4f 70  ef struct VdbeOp
0460: 20 4f 70 3b 0a 0a 2f 2a 0a 2a 2a 20 42 6f 6f 6c   Op;../*.** Bool
0470: 65 61 6e 20 76 61 6c 75 65 73 0a 2a 2f 0a 74 79  ean values.*/.ty
0480: 70 65 64 65 66 20 75 6e 73 69 67 6e 65 64 20 42  pedef unsigned B
0490: 6f 6f 6c 3b 0a 0a 2f 2a 20 4f 70 61 71 75 65 20  ool;../* Opaque 
04a0: 74 79 70 65 20 75 73 65 64 20 62 79 20 63 6f 64  type used by cod
04b0: 65 20 69 6e 20 76 64 62 65 73 6f 72 74 2e 63 20  e in vdbesort.c 
04c0: 2a 2f 0a 74 79 70 65 64 65 66 20 73 74 72 75 63  */.typedef struc
04d0: 74 20 56 64 62 65 53 6f 72 74 65 72 20 56 64 62  t VdbeSorter Vdb
04e0: 65 53 6f 72 74 65 72 3b 0a 0a 2f 2a 20 4f 70 61  eSorter;../* Opa
04f0: 71 75 65 20 74 79 70 65 20 75 73 65 64 20 62 79  que type used by
0500: 20 74 68 65 20 65 78 70 6c 61 69 6e 65 72 20 2a   the explainer *
0510: 2f 0a 74 79 70 65 64 65 66 20 73 74 72 75 63 74  /.typedef struct
0520: 20 45 78 70 6c 61 69 6e 20 45 78 70 6c 61 69 6e   Explain Explain
0530: 3b 0a 0a 2f 2a 20 45 6c 65 6d 65 6e 74 73 20 6f  ;../* Elements o
0540: 66 20 74 68 65 20 6c 69 6e 6b 65 64 20 6c 69 73  f the linked lis
0550: 74 20 61 74 20 56 64 62 65 2e 70 41 75 78 44 61  t at Vdbe.pAuxDa
0560: 74 61 20 2a 2f 0a 74 79 70 65 64 65 66 20 73 74  ta */.typedef st
0570: 72 75 63 74 20 41 75 78 44 61 74 61 20 41 75 78  ruct AuxData Aux
0580: 44 61 74 61 3b 0a 0a 2f 2a 0a 2a 2a 20 41 20 63  Data;../*.** A c
0590: 75 72 73 6f 72 20 69 73 20 61 20 70 6f 69 6e 74  ursor is a point
05a0: 65 72 20 69 6e 74 6f 20 61 20 73 69 6e 67 6c 65  er into a single
05b0: 20 42 54 72 65 65 20 77 69 74 68 69 6e 20 61 20   BTree within a 
05c0: 64 61 74 61 62 61 73 65 20 66 69 6c 65 2e 0a 2a  database file..*
05d0: 2a 20 54 68 65 20 63 75 72 73 6f 72 20 63 61 6e  * The cursor can
05e0: 20 73 65 65 6b 20 74 6f 20 61 20 42 54 72 65 65   seek to a BTree
05f0: 20 65 6e 74 72 79 20 77 69 74 68 20 61 20 70 61   entry with a pa
0600: 72 74 69 63 75 6c 61 72 20 6b 65 79 2c 20 6f 72  rticular key, or
0610: 0a 2a 2a 20 6c 6f 6f 70 20 6f 76 65 72 20 61 6c  .** loop over al
0620: 6c 20 65 6e 74 72 69 65 73 20 6f 66 20 74 68 65  l entries of the
0630: 20 42 74 72 65 65 2e 20 20 59 6f 75 20 63 61 6e   Btree.  You can
0640: 20 61 6c 73 6f 20 69 6e 73 65 72 74 20 6e 65 77   also insert new
0650: 20 42 54 72 65 65 0a 2a 2a 20 65 6e 74 72 69 65   BTree.** entrie
0660: 73 20 6f 72 20 72 65 74 72 69 65 76 65 20 74 68  s or retrieve th
0670: 65 20 6b 65 79 20 6f 72 20 64 61 74 61 20 66 72  e key or data fr
0680: 6f 6d 20 74 68 65 20 65 6e 74 72 79 20 74 68 61  om the entry tha
0690: 74 20 74 68 65 20 63 75 72 73 6f 72 0a 2a 2a 20  t the cursor.** 
06a0: 69 73 20 63 75 72 72 65 6e 74 6c 79 20 70 6f 69  is currently poi
06b0: 6e 74 69 6e 67 20 74 6f 2e 0a 2a 2a 0a 2a 2a 20  nting to..**.** 
06c0: 43 75 72 73 6f 72 73 20 63 61 6e 20 61 6c 73 6f  Cursors can also
06d0: 20 70 6f 69 6e 74 20 74 6f 20 76 69 72 74 75 61   point to virtua
06e0: 6c 20 74 61 62 6c 65 73 2c 20 73 6f 72 74 65 72  l tables, sorter
06f0: 73 2c 20 6f 72 20 22 70 73 65 75 64 6f 2d 74 61  s, or "pseudo-ta
0700: 62 6c 65 73 22 2e 0a 2a 2a 20 41 20 70 73 65 75  bles"..** A pseu
0710: 64 6f 2d 74 61 62 6c 65 20 69 73 20 61 20 73 69  do-table is a si
0720: 6e 67 6c 65 2d 72 6f 77 20 74 61 62 6c 65 20 69  ngle-row table i
0730: 6d 70 6c 65 6d 65 6e 74 65 64 20 62 79 20 72 65  mplemented by re
0740: 67 69 73 74 65 72 73 2e 0a 2a 2a 20 0a 2a 2a 20  gisters..** .** 
0750: 45 76 65 72 79 20 63 75 72 73 6f 72 20 74 68 61  Every cursor tha
0760: 74 20 74 68 65 20 76 69 72 74 75 61 6c 20 6d 61  t the virtual ma
0770: 63 68 69 6e 65 20 68 61 73 20 6f 70 65 6e 20 69  chine has open i
0780: 73 20 72 65 70 72 65 73 65 6e 74 65 64 20 62 79  s represented by
0790: 20 61 6e 0a 2a 2a 20 69 6e 73 74 61 6e 63 65 20   an.** instance 
07a0: 6f 66 20 74 68 65 20 66 6f 6c 6c 6f 77 69 6e 67  of the following
07b0: 20 73 74 72 75 63 74 75 72 65 2e 0a 2a 2f 0a 73   structure..*/.s
07c0: 74 72 75 63 74 20 56 64 62 65 43 75 72 73 6f 72  truct VdbeCursor
07d0: 20 7b 0a 20 20 42 74 43 75 72 73 6f 72 20 2a 70   {.  BtCursor *p
07e0: 43 75 72 73 6f 72 3b 20 20 20 20 2f 2a 20 54 68  Cursor;    /* Th
07f0: 65 20 63 75 72 73 6f 72 20 73 74 72 75 63 74 75  e cursor structu
0800: 72 65 20 6f 66 20 74 68 65 20 62 61 63 6b 65 6e  re of the backen
0810: 64 20 2a 2f 0a 20 20 42 74 72 65 65 20 2a 70 42  d */.  Btree *pB
0820: 74 3b 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20  t;           /* 
0830: 53 65 70 61 72 61 74 65 20 66 69 6c 65 20 68 6f  Separate file ho
0840: 6c 64 69 6e 67 20 74 65 6d 70 6f 72 61 72 79 20  lding temporary 
0850: 74 61 62 6c 65 20 2a 2f 0a 20 20 4b 65 79 49 6e  table */.  KeyIn
0860: 66 6f 20 2a 70 4b 65 79 49 6e 66 6f 3b 20 20 20  fo *pKeyInfo;   
0870: 20 2f 2a 20 49 6e 66 6f 20 61 62 6f 75 74 20 69   /* Info about i
0880: 6e 64 65 78 20 6b 65 79 73 20 6e 65 65 64 65 64  ndex keys needed
0890: 20 62 79 20 69 6e 64 65 78 20 63 75 72 73 6f 72   by index cursor
08a0: 73 20 2a 2f 0a 20 20 69 6e 74 20 73 65 65 6b 52  s */.  int seekR
08b0: 65 73 75 6c 74 3b 20 20 20 20 20 20 20 2f 2a 20  esult;       /* 
08c0: 52 65 73 75 6c 74 20 6f 66 20 70 72 65 76 69 6f  Result of previo
08d0: 75 73 20 73 71 6c 69 74 65 33 42 74 72 65 65 4d  us sqlite3BtreeM
08e0: 6f 76 65 74 6f 28 29 20 2a 2f 0a 20 20 69 6e 74  oveto() */.  int
08f0: 20 70 73 65 75 64 6f 54 61 62 6c 65 52 65 67 3b   pseudoTableReg;
0900: 20 20 20 2f 2a 20 52 65 67 69 73 74 65 72 20 68     /* Register h
0910: 6f 6c 64 69 6e 67 20 70 73 65 75 64 6f 74 61 62  olding pseudotab
0920: 6c 65 20 63 6f 6e 74 65 6e 74 2e 20 2a 2f 0a 20  le content. */. 
0930: 20 69 31 36 20 6e 46 69 65 6c 64 3b 20 20 20 20   i16 nField;    
0940: 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72         /* Number
0950: 20 6f 66 20 66 69 65 6c 64 73 20 69 6e 20 74 68   of fields in th
0960: 65 20 68 65 61 64 65 72 20 2a 2f 0a 20 20 75 31  e header */.  u1
0970: 36 20 6e 48 64 72 50 61 72 73 65 64 3b 20 20 20  6 nHdrParsed;   
0980: 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66      /* Number of
0990: 20 68 65 61 64 65 72 20 66 69 65 6c 64 73 20 70   header fields p
09a0: 61 72 73 65 64 20 73 6f 20 66 61 72 20 2a 2f 0a  arsed so far */.
09b0: 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 44 45  #ifdef SQLITE_DE
09c0: 42 55 47 0a 20 20 75 38 20 73 65 65 6b 4f 70 3b  BUG.  u8 seekOp;
09d0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4d              /* M
09e0: 6f 73 74 20 72 65 63 65 6e 74 20 73 65 65 6b 20  ost recent seek 
09f0: 6f 70 65 72 61 74 69 6f 6e 20 6f 6e 20 74 68 69  operation on thi
0a00: 73 20 63 75 72 73 6f 72 20 2a 2f 0a 23 65 6e 64  s cursor */.#end
0a10: 69 66 0a 20 20 69 38 20 69 44 62 3b 20 20 20 20  if.  i8 iDb;    
0a20: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 49 6e             /* In
0a30: 64 65 78 20 6f 66 20 63 75 72 73 6f 72 20 64 61  dex of cursor da
0a40: 74 61 62 61 73 65 20 69 6e 20 64 62 2d 3e 61 44  tabase in db->aD
0a50: 62 5b 5d 20 28 6f 72 20 2d 31 29 20 2a 2f 0a 20  b[] (or -1) */. 
0a60: 20 75 38 20 6e 75 6c 6c 52 6f 77 3b 20 20 20 20   u8 nullRow;    
0a70: 20 20 20 20 20 20 20 2f 2a 20 54 72 75 65 20 69         /* True i
0a80: 66 20 70 6f 69 6e 74 69 6e 67 20 74 6f 20 61 20  f pointing to a 
0a90: 72 6f 77 20 77 69 74 68 20 6e 6f 20 64 61 74 61  row with no data
0aa0: 20 2a 2f 0a 20 20 75 38 20 64 65 66 65 72 72 65   */.  u8 deferre
0ab0: 64 4d 6f 76 65 74 6f 3b 20 20 20 20 2f 2a 20 41  dMoveto;    /* A
0ac0: 20 63 61 6c 6c 20 74 6f 20 73 71 6c 69 74 65 33   call to sqlite3
0ad0: 42 74 72 65 65 4d 6f 76 65 74 6f 28 29 20 69 73  BtreeMoveto() is
0ae0: 20 6e 65 65 64 65 64 20 2a 2f 0a 20 20 42 6f 6f   needed */.  Boo
0af0: 6c 20 69 73 45 70 68 65 6d 65 72 61 6c 3a 31 3b  l isEphemeral:1;
0b00: 20 20 20 2f 2a 20 54 72 75 65 20 66 6f 72 20 61     /* True for a
0b10: 6e 20 65 70 68 65 6d 65 72 61 6c 20 74 61 62 6c  n ephemeral tabl
0b20: 65 20 2a 2f 0a 20 20 42 6f 6f 6c 20 75 73 65 52  e */.  Bool useR
0b30: 61 6e 64 6f 6d 52 6f 77 69 64 3a 31 3b 2f 2a 20  andomRowid:1;/* 
0b40: 47 65 6e 65 72 61 74 65 20 6e 65 77 20 72 65 63  Generate new rec
0b50: 6f 72 64 20 6e 75 6d 62 65 72 73 20 73 65 6d 69  ord numbers semi
0b60: 2d 72 61 6e 64 6f 6d 6c 79 20 2a 2f 0a 20 20 42  -randomly */.  B
0b70: 6f 6f 6c 20 69 73 54 61 62 6c 65 3a 31 3b 20 20  ool isTable:1;  
0b80: 20 20 20 20 20 2f 2a 20 54 72 75 65 20 69 66 20       /* True if 
0b90: 61 20 74 61 62 6c 65 20 72 65 71 75 69 72 69 6e  a table requirin
0ba0: 67 20 69 6e 74 65 67 65 72 20 6b 65 79 73 20 2a  g integer keys *
0bb0: 2f 0a 20 20 42 6f 6f 6c 20 69 73 4f 72 64 65 72  /.  Bool isOrder
0bc0: 65 64 3a 31 3b 20 20 20 20 20 2f 2a 20 54 72 75  ed:1;     /* Tru
0bd0: 65 20 69 66 20 74 68 65 20 75 6e 64 65 72 6c 79  e if the underly
0be0: 69 6e 67 20 74 61 62 6c 65 20 69 73 20 42 54 52  ing table is BTR
0bf0: 45 45 5f 55 4e 4f 52 44 45 52 45 44 20 2a 2f 0a  EE_UNORDERED */.
0c00: 20 20 50 67 6e 6f 20 70 67 6e 6f 52 6f 6f 74 3b    Pgno pgnoRoot;
0c10: 20 20 20 20 20 20 20 20 2f 2a 20 52 6f 6f 74 20          /* Root 
0c20: 70 61 67 65 20 6f 66 20 74 68 65 20 6f 70 65 6e  page of the open
0c30: 20 62 74 72 65 65 20 63 75 72 73 6f 72 20 2a 2f   btree cursor */
0c40: 0a 20 20 73 71 6c 69 74 65 33 5f 76 74 61 62 5f  .  sqlite3_vtab_
0c50: 63 75 72 73 6f 72 20 2a 70 56 74 61 62 43 75 72  cursor *pVtabCur
0c60: 73 6f 72 3b 20 20 2f 2a 20 54 68 65 20 63 75 72  sor;  /* The cur
0c70: 73 6f 72 20 66 6f 72 20 61 20 76 69 72 74 75 61  sor for a virtua
0c80: 6c 20 74 61 62 6c 65 20 2a 2f 0a 20 20 69 36 34  l table */.  i64
0c90: 20 73 65 71 43 6f 75 6e 74 3b 20 20 20 20 20 20   seqCount;      
0ca0: 20 20 20 2f 2a 20 53 65 71 75 65 6e 63 65 20 63     /* Sequence c
0cb0: 6f 75 6e 74 65 72 20 2a 2f 0a 20 20 69 36 34 20  ounter */.  i64 
0cc0: 6d 6f 76 65 74 6f 54 61 72 67 65 74 3b 20 20 20  movetoTarget;   
0cd0: 20 20 2f 2a 20 41 72 67 75 6d 65 6e 74 20 74 6f    /* Argument to
0ce0: 20 74 68 65 20 64 65 66 65 72 72 65 64 20 73 71   the deferred sq
0cf0: 6c 69 74 65 33 42 74 72 65 65 4d 6f 76 65 74 6f  lite3BtreeMoveto
0d00: 28 29 20 2a 2f 0a 20 20 56 64 62 65 53 6f 72 74  () */.  VdbeSort
0d10: 65 72 20 2a 70 53 6f 72 74 65 72 3b 20 20 2f 2a  er *pSorter;  /*
0d20: 20 53 6f 72 74 65 72 20 6f 62 6a 65 63 74 20 66   Sorter object f
0d30: 6f 72 20 4f 50 5f 53 6f 72 74 65 72 4f 70 65 6e  or OP_SorterOpen
0d40: 20 63 75 72 73 6f 72 73 20 2a 2f 0a 0a 20 20 2f   cursors */..  /
0d50: 2a 20 43 61 63 68 65 64 20 69 6e 66 6f 72 6d 61  * Cached informa
0d60: 74 69 6f 6e 20 61 62 6f 75 74 20 74 68 65 20 68  tion about the h
0d70: 65 61 64 65 72 20 66 6f 72 20 74 68 65 20 64 61  eader for the da
0d80: 74 61 20 72 65 63 6f 72 64 20 74 68 61 74 20 74  ta record that t
0d90: 68 65 0a 20 20 2a 2a 20 63 75 72 73 6f 72 20 69  he.  ** cursor i
0da0: 73 20 63 75 72 72 65 6e 74 6c 79 20 70 6f 69 6e  s currently poin
0db0: 74 69 6e 67 20 74 6f 2e 20 20 4f 6e 6c 79 20 76  ting to.  Only v
0dc0: 61 6c 69 64 20 69 66 20 63 61 63 68 65 53 74 61  alid if cacheSta
0dd0: 74 75 73 20 6d 61 74 63 68 65 73 0a 20 20 2a 2a  tus matches.  **
0de0: 20 56 64 62 65 2e 63 61 63 68 65 43 74 72 2e 20   Vdbe.cacheCtr. 
0df0: 20 56 64 62 65 2e 63 61 63 68 65 43 74 72 20 77   Vdbe.cacheCtr w
0e00: 69 6c 6c 20 6e 65 76 65 72 20 74 61 6b 65 20 6f  ill never take o
0e10: 6e 20 74 68 65 20 76 61 6c 75 65 20 6f 66 0a 20  n the value of. 
0e20: 20 2a 2a 20 43 41 43 48 45 5f 53 54 41 4c 45 20   ** CACHE_STALE 
0e30: 61 6e 64 20 73 6f 20 73 65 74 74 69 6e 67 20 63  and so setting c
0e40: 61 63 68 65 53 74 61 74 75 73 3d 43 41 43 48 45  acheStatus=CACHE
0e50: 5f 53 54 41 4c 45 20 67 75 61 72 61 6e 74 65 65  _STALE guarantee
0e60: 73 20 74 68 61 74 0a 20 20 2a 2a 20 74 68 65 20  s that.  ** the 
0e70: 63 61 63 68 65 20 69 73 20 6f 75 74 20 6f 66 20  cache is out of 
0e80: 64 61 74 65 2e 0a 20 20 2a 2a 0a 20 20 2a 2a 20  date..  **.  ** 
0e90: 61 52 6f 77 20 6d 69 67 68 74 20 70 6f 69 6e 74  aRow might point
0ea0: 20 74 6f 20 28 65 70 68 65 6d 65 72 61 6c 29 20   to (ephemeral) 
0eb0: 64 61 74 61 20 66 6f 72 20 74 68 65 20 63 75 72  data for the cur
0ec0: 72 65 6e 74 20 72 6f 77 2c 20 6f 72 20 69 74 20  rent row, or it 
0ed0: 6d 69 67 68 74 0a 20 20 2a 2a 20 62 65 20 4e 55  might.  ** be NU
0ee0: 4c 4c 2e 0a 20 20 2a 2f 0a 20 20 75 33 32 20 63  LL..  */.  u32 c
0ef0: 61 63 68 65 53 74 61 74 75 73 3b 20 20 20 20 20  acheStatus;     
0f00: 20 2f 2a 20 43 61 63 68 65 20 69 73 20 76 61 6c   /* Cache is val
0f10: 69 64 20 69 66 20 74 68 69 73 20 6d 61 74 63 68  id if this match
0f20: 65 73 20 56 64 62 65 2e 63 61 63 68 65 43 74 72  es Vdbe.cacheCtr
0f30: 20 2a 2f 0a 20 20 75 33 32 20 70 61 79 6c 6f 61   */.  u32 payloa
0f40: 64 53 69 7a 65 3b 20 20 20 20 20 20 2f 2a 20 54  dSize;      /* T
0f50: 6f 74 61 6c 20 6e 75 6d 62 65 72 20 6f 66 20 62  otal number of b
0f60: 79 74 65 73 20 69 6e 20 74 68 65 20 72 65 63 6f  ytes in the reco
0f70: 72 64 20 2a 2f 0a 20 20 75 33 32 20 73 7a 52 6f  rd */.  u32 szRo
0f80: 77 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  w;            /*
0f90: 20 42 79 74 65 20 61 76 61 69 6c 61 62 6c 65 20   Byte available 
0fa0: 69 6e 20 61 52 6f 77 20 2a 2f 0a 20 20 75 33 32  in aRow */.  u32
0fb0: 20 69 48 64 72 4f 66 66 73 65 74 3b 20 20 20 20   iHdrOffset;    
0fc0: 20 20 20 2f 2a 20 4f 66 66 73 65 74 20 74 6f 20     /* Offset to 
0fd0: 6e 65 78 74 20 75 6e 70 61 72 73 65 64 20 62 79  next unparsed by
0fe0: 74 65 20 6f 66 20 74 68 65 20 68 65 61 64 65 72  te of the header
0ff0: 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 75 38 20 2a   */.  const u8 *
1000: 61 52 6f 77 3b 20 20 20 20 20 20 20 2f 2a 20 44  aRow;       /* D
1010: 61 74 61 20 66 6f 72 20 74 68 65 20 63 75 72 72  ata for the curr
1020: 65 6e 74 20 72 6f 77 2c 20 69 66 20 61 6c 6c 20  ent row, if all 
1030: 6f 6e 20 6f 6e 65 20 70 61 67 65 20 2a 2f 0a 20  on one page */. 
1040: 20 75 33 32 20 2a 61 4f 66 66 73 65 74 3b 20 20   u32 *aOffset;  
1050: 20 20 20 20 20 20 20 2f 2a 20 50 6f 69 6e 74 65         /* Pointe
1060: 72 20 74 6f 20 61 54 79 70 65 5b 6e 46 69 65 6c  r to aType[nFiel
1070: 64 5d 20 2a 2f 0a 20 20 75 33 32 20 61 54 79 70  d] */.  u32 aTyp
1080: 65 5b 31 5d 3b 20 20 20 20 20 20 20 20 20 2f 2a  e[1];         /*
1090: 20 54 79 70 65 20 76 61 6c 75 65 73 20 66 6f 72   Type values for
10a0: 20 61 6c 6c 20 65 6e 74 72 69 65 73 20 69 6e 20   all entries in 
10b0: 74 68 65 20 72 65 63 6f 72 64 20 2a 2f 0a 20 20  the record */.  
10c0: 2f 2a 20 32 2a 6e 46 69 65 6c 64 20 65 78 74 72  /* 2*nField extr
10d0: 61 20 61 72 72 61 79 20 65 6c 65 6d 65 6e 74 73  a array elements
10e0: 20 61 6c 6c 6f 63 61 74 65 64 20 66 6f 72 20 61   allocated for a
10f0: 54 79 70 65 5b 5d 2c 20 62 65 79 6f 6e 64 20 74  Type[], beyond t
1100: 68 65 20 6f 6e 65 0a 20 20 2a 2a 20 73 74 61 74  he one.  ** stat
1110: 69 63 20 65 6c 65 6d 65 6e 74 20 64 65 63 6c 61  ic element decla
1120: 72 65 64 20 69 6e 20 74 68 65 20 73 74 72 75 63  red in the struc
1130: 74 75 72 65 2e 20 20 6e 46 69 65 6c 64 20 74 6f  ture.  nField to
1140: 74 61 6c 20 61 72 72 61 79 20 73 6c 6f 74 73 20  tal array slots 
1150: 66 6f 72 0a 20 20 2a 2a 20 61 54 79 70 65 5b 5d  for.  ** aType[]
1160: 20 61 6e 64 20 6e 46 69 65 6c 64 2b 31 20 61 72   and nField+1 ar
1170: 72 61 79 20 73 6c 6f 74 73 20 66 6f 72 20 61 4f  ray slots for aO
1180: 66 66 73 65 74 5b 5d 20 2a 2f 0a 7d 3b 0a 74 79  ffset[] */.};.ty
1190: 70 65 64 65 66 20 73 74 72 75 63 74 20 56 64 62  pedef struct Vdb
11a0: 65 43 75 72 73 6f 72 20 56 64 62 65 43 75 72 73  eCursor VdbeCurs
11b0: 6f 72 3b 0a 0a 2f 2a 0a 2a 2a 20 57 68 65 6e 20  or;../*.** When 
11c0: 61 20 73 75 62 2d 70 72 6f 67 72 61 6d 20 69 73  a sub-program is
11d0: 20 65 78 65 63 75 74 65 64 20 28 4f 50 5f 50 72   executed (OP_Pr
11e0: 6f 67 72 61 6d 29 2c 20 61 20 73 74 72 75 63 74  ogram), a struct
11f0: 75 72 65 20 6f 66 20 74 68 69 73 20 74 79 70 65  ure of this type
1200: 0a 2a 2a 20 69 73 20 61 6c 6c 6f 63 61 74 65 64  .** is allocated
1210: 20 74 6f 20 73 74 6f 72 65 20 74 68 65 20 63 75   to store the cu
1220: 72 72 65 6e 74 20 76 61 6c 75 65 20 6f 66 20 74  rrent value of t
1230: 68 65 20 70 72 6f 67 72 61 6d 20 63 6f 75 6e 74  he program count
1240: 65 72 2c 20 61 73 0a 2a 2a 20 77 65 6c 6c 20 61  er, as.** well a
1250: 73 20 74 68 65 20 63 75 72 72 65 6e 74 20 6d 65  s the current me
1260: 6d 6f 72 79 20 63 65 6c 6c 20 61 72 72 61 79 20  mory cell array 
1270: 61 6e 64 20 76 61 72 69 6f 75 73 20 6f 74 68 65  and various othe
1280: 72 20 66 72 61 6d 65 20 73 70 65 63 69 66 69 63  r frame specific
1290: 0a 2a 2a 20 76 61 6c 75 65 73 20 73 74 6f 72 65  .** values store
12a0: 64 20 69 6e 20 74 68 65 20 56 64 62 65 20 73 74  d in the Vdbe st
12b0: 72 75 63 74 2e 20 57 68 65 6e 20 74 68 65 20 73  ruct. When the s
12c0: 75 62 2d 70 72 6f 67 72 61 6d 20 69 73 20 66 69  ub-program is fi
12d0: 6e 69 73 68 65 64 2c 20 0a 2a 2a 20 74 68 65 73  nished, .** thes
12e0: 65 20 76 61 6c 75 65 73 20 61 72 65 20 63 6f 70  e values are cop
12f0: 69 65 64 20 62 61 63 6b 20 74 6f 20 74 68 65 20  ied back to the 
1300: 56 64 62 65 20 66 72 6f 6d 20 74 68 65 20 56 64  Vdbe from the Vd
1310: 62 65 46 72 61 6d 65 20 73 74 72 75 63 74 75 72  beFrame structur
1320: 65 2c 0a 2a 2a 20 72 65 73 74 6f 72 69 6e 67 20  e,.** restoring 
1330: 74 68 65 20 73 74 61 74 65 20 6f 66 20 74 68 65  the state of the
1340: 20 56 4d 20 74 6f 20 61 73 20 69 74 20 77 61 73   VM to as it was
1350: 20 62 65 66 6f 72 65 20 74 68 65 20 73 75 62 2d   before the sub-
1360: 70 72 6f 67 72 61 6d 0a 2a 2a 20 62 65 67 61 6e  program.** began
1370: 20 65 78 65 63 75 74 69 6e 67 2e 0a 2a 2a 0a 2a   executing..**.*
1380: 2a 20 54 68 65 20 6d 65 6d 6f 72 79 20 66 6f 72  * The memory for
1390: 20 61 20 56 64 62 65 46 72 61 6d 65 20 6f 62 6a   a VdbeFrame obj
13a0: 65 63 74 20 69 73 20 61 6c 6c 6f 63 61 74 65 64  ect is allocated
13b0: 20 61 6e 64 20 6d 61 6e 61 67 65 64 20 62 79 20   and managed by 
13c0: 61 20 6d 65 6d 6f 72 79 0a 2a 2a 20 63 65 6c 6c  a memory.** cell
13d0: 20 69 6e 20 74 68 65 20 70 61 72 65 6e 74 20 28   in the parent (
13e0: 63 61 6c 6c 69 6e 67 29 20 66 72 61 6d 65 2e 20  calling) frame. 
13f0: 57 68 65 6e 20 74 68 65 20 6d 65 6d 6f 72 79 20  When the memory 
1400: 63 65 6c 6c 20 69 73 20 64 65 6c 65 74 65 64 20  cell is deleted 
1410: 6f 72 0a 2a 2a 20 6f 76 65 72 77 72 69 74 74 65  or.** overwritte
1420: 6e 2c 20 74 68 65 20 56 64 62 65 46 72 61 6d 65  n, the VdbeFrame
1430: 20 6f 62 6a 65 63 74 20 69 73 20 6e 6f 74 20 66   object is not f
1440: 72 65 65 64 20 69 6d 6d 65 64 69 61 74 65 6c 79  reed immediately
1450: 2e 20 49 6e 73 74 65 61 64 2c 20 69 74 0a 2a 2a  . Instead, it.**
1460: 20 69 73 20 6c 69 6e 6b 65 64 20 69 6e 74 6f 20   is linked into 
1470: 74 68 65 20 56 64 62 65 2e 70 44 65 6c 46 72 61  the Vdbe.pDelFra
1480: 6d 65 20 6c 69 73 74 2e 20 54 68 65 20 63 6f 6e  me list. The con
1490: 74 65 6e 74 73 20 6f 66 20 74 68 65 20 56 64 62  tents of the Vdb
14a0: 65 2e 70 44 65 6c 46 72 61 6d 65 0a 2a 2a 20 6c  e.pDelFrame.** l
14b0: 69 73 74 20 69 73 20 64 65 6c 65 74 65 64 20 77  ist is deleted w
14c0: 68 65 6e 20 74 68 65 20 56 4d 20 69 73 20 72 65  hen the VM is re
14d0: 73 65 74 20 69 6e 20 56 64 62 65 48 61 6c 74 28  set in VdbeHalt(
14e0: 29 2e 20 54 68 65 20 72 65 61 73 6f 6e 20 66 6f  ). The reason fo
14f0: 72 20 64 6f 69 6e 67 0a 2a 2a 20 74 68 69 73 20  r doing.** this 
1500: 69 6e 73 74 65 61 64 20 6f 66 20 64 65 6c 65 74  instead of delet
1510: 69 6e 67 20 74 68 65 20 56 64 62 65 46 72 61 6d  ing the VdbeFram
1520: 65 20 69 6d 6d 65 64 69 61 74 65 6c 79 20 69 73  e immediately is
1530: 20 74 6f 20 61 76 6f 69 64 20 72 65 63 75 72 73   to avoid recurs
1540: 69 76 65 0a 2a 2a 20 63 61 6c 6c 73 20 74 6f 20  ive.** calls to 
1550: 73 71 6c 69 74 65 33 56 64 62 65 4d 65 6d 52 65  sqlite3VdbeMemRe
1560: 6c 65 61 73 65 28 29 20 77 68 65 6e 20 74 68 65  lease() when the
1570: 20 6d 65 6d 6f 72 79 20 63 65 6c 6c 73 20 62 65   memory cells be
1580: 6c 6f 6e 67 69 6e 67 20 74 6f 20 74 68 65 0a 2a  longing to the.*
1590: 2a 20 63 68 69 6c 64 20 66 72 61 6d 65 20 61 72  * child frame ar
15a0: 65 20 72 65 6c 65 61 73 65 64 2e 0a 2a 2a 0a 2a  e released..**.*
15b0: 2a 20 54 68 65 20 63 75 72 72 65 6e 74 6c 79 20  * The currently 
15c0: 65 78 65 63 75 74 69 6e 67 20 66 72 61 6d 65 20  executing frame 
15d0: 69 73 20 73 74 6f 72 65 64 20 69 6e 20 56 64 62  is stored in Vdb
15e0: 65 2e 70 46 72 61 6d 65 2e 20 56 64 62 65 2e 70  e.pFrame. Vdbe.p
15f0: 46 72 61 6d 65 20 69 73 0a 2a 2a 20 73 65 74 20  Frame is.** set 
1600: 74 6f 20 4e 55 4c 4c 20 69 66 20 74 68 65 20 63  to NULL if the c
1610: 75 72 72 65 6e 74 6c 79 20 65 78 65 63 75 74 69  urrently executi
1620: 6e 67 20 66 72 61 6d 65 20 69 73 20 74 68 65 20  ng frame is the 
1630: 6d 61 69 6e 20 70 72 6f 67 72 61 6d 2e 0a 2a 2f  main program..*/
1640: 0a 74 79 70 65 64 65 66 20 73 74 72 75 63 74 20  .typedef struct 
1650: 56 64 62 65 46 72 61 6d 65 20 56 64 62 65 46 72  VdbeFrame VdbeFr
1660: 61 6d 65 3b 0a 73 74 72 75 63 74 20 56 64 62 65  ame;.struct Vdbe
1670: 46 72 61 6d 65 20 7b 0a 20 20 56 64 62 65 20 2a  Frame {.  Vdbe *
1680: 76 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  v;              
1690: 20 20 2f 2a 20 56 4d 20 74 68 69 73 20 66 72 61    /* VM this fra
16a0: 6d 65 20 62 65 6c 6f 6e 67 73 20 74 6f 20 2a 2f  me belongs to */
16b0: 0a 20 20 56 64 62 65 46 72 61 6d 65 20 2a 70 50  .  VdbeFrame *pP
16c0: 61 72 65 6e 74 3b 20 20 20 20 20 2f 2a 20 50 61  arent;     /* Pa
16d0: 72 65 6e 74 20 6f 66 20 74 68 69 73 20 66 72 61  rent of this fra
16e0: 6d 65 2c 20 6f 72 20 4e 55 4c 4c 20 69 66 20 70  me, or NULL if p
16f0: 61 72 65 6e 74 20 69 73 20 6d 61 69 6e 20 2a 2f  arent is main */
1700: 0a 20 20 4f 70 20 2a 61 4f 70 3b 20 20 20 20 20  .  Op *aOp;     
1710: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 50 72             /* Pr
1720: 6f 67 72 61 6d 20 69 6e 73 74 72 75 63 74 69 6f  ogram instructio
1730: 6e 73 20 66 6f 72 20 70 61 72 65 6e 74 20 66 72  ns for parent fr
1740: 61 6d 65 20 2a 2f 0a 20 20 69 36 34 20 2a 61 6e  ame */.  i64 *an
1750: 45 78 65 63 3b 20 20 20 20 20 20 20 20 20 20 20  Exec;           
1760: 20 2f 2a 20 45 76 65 6e 74 20 63 6f 75 6e 74 65   /* Event counte
1770: 72 73 20 66 72 6f 6d 20 70 61 72 65 6e 74 20 66  rs from parent f
1780: 72 61 6d 65 20 2a 2f 0a 20 20 4d 65 6d 20 2a 61  rame */.  Mem *a
1790: 4d 65 6d 3b 20 20 20 20 20 20 20 20 20 20 20 20  Mem;            
17a0: 20 20 2f 2a 20 41 72 72 61 79 20 6f 66 20 6d 65    /* Array of me
17b0: 6d 6f 72 79 20 63 65 6c 6c 73 20 66 6f 72 20 70  mory cells for p
17c0: 61 72 65 6e 74 20 66 72 61 6d 65 20 2a 2f 0a 20  arent frame */. 
17d0: 20 75 38 20 2a 61 4f 6e 63 65 46 6c 61 67 3b 20   u8 *aOnceFlag; 
17e0: 20 20 20 20 20 20 20 20 20 2f 2a 20 41 72 72 61           /* Arra
17f0: 79 20 6f 66 20 4f 50 5f 4f 6e 63 65 20 66 6c 61  y of OP_Once fla
1800: 67 73 20 66 6f 72 20 70 61 72 65 6e 74 20 66 72  gs for parent fr
1810: 61 6d 65 20 2a 2f 0a 20 20 56 64 62 65 43 75 72  ame */.  VdbeCur
1820: 73 6f 72 20 2a 2a 61 70 43 73 72 3b 20 20 20 20  sor **apCsr;    
1830: 20 2f 2a 20 41 72 72 61 79 20 6f 66 20 56 64 62   /* Array of Vdb
1840: 65 20 63 75 72 73 6f 72 73 20 66 6f 72 20 70 61  e cursors for pa
1850: 72 65 6e 74 20 66 72 61 6d 65 20 2a 2f 0a 20 20  rent frame */.  
1860: 76 6f 69 64 20 2a 74 6f 6b 65 6e 3b 20 20 20 20  void *token;    
1870: 20 20 20 20 20 20 20 20 2f 2a 20 43 6f 70 79 20          /* Copy 
1880: 6f 66 20 53 75 62 50 72 6f 67 72 61 6d 2e 74 6f  of SubProgram.to
1890: 6b 65 6e 20 2a 2f 0a 20 20 69 36 34 20 6c 61 73  ken */.  i64 las
18a0: 74 52 6f 77 69 64 3b 20 20 20 20 20 20 20 20 20  tRowid;         
18b0: 20 2f 2a 20 4c 61 73 74 20 69 6e 73 65 72 74 20   /* Last insert 
18c0: 72 6f 77 69 64 20 28 73 71 6c 69 74 65 33 2e 6c  rowid (sqlite3.l
18d0: 61 73 74 52 6f 77 69 64 29 20 2a 2f 0a 20 20 69  astRowid) */.  i
18e0: 6e 74 20 6e 43 75 72 73 6f 72 3b 20 20 20 20 20  nt nCursor;     
18f0: 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72         /* Number
1900: 20 6f 66 20 65 6e 74 72 69 65 73 20 69 6e 20 61   of entries in a
1910: 70 43 73 72 20 2a 2f 0a 20 20 69 6e 74 20 70 63  pCsr */.  int pc
1920: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
1930: 20 20 2f 2a 20 50 72 6f 67 72 61 6d 20 43 6f 75    /* Program Cou
1940: 6e 74 65 72 20 69 6e 20 70 61 72 65 6e 74 20 28  nter in parent (
1950: 63 61 6c 6c 69 6e 67 29 20 66 72 61 6d 65 20 2a  calling) frame *
1960: 2f 0a 20 20 69 6e 74 20 6e 4f 70 3b 20 20 20 20  /.  int nOp;    
1970: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 53              /* S
1980: 69 7a 65 20 6f 66 20 61 4f 70 20 61 72 72 61 79  ize of aOp array
1990: 20 2a 2f 0a 20 20 69 6e 74 20 6e 4d 65 6d 3b 20   */.  int nMem; 
19a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
19b0: 20 4e 75 6d 62 65 72 20 6f 66 20 65 6e 74 72 69   Number of entri
19c0: 65 73 20 69 6e 20 61 4d 65 6d 20 2a 2f 0a 20 20  es in aMem */.  
19d0: 69 6e 74 20 6e 4f 6e 63 65 46 6c 61 67 3b 20 20  int nOnceFlag;  
19e0: 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65          /* Numbe
19f0: 72 20 6f 66 20 65 6e 74 72 69 65 73 20 69 6e 20  r of entries in 
1a00: 61 4f 6e 63 65 46 6c 61 67 20 2a 2f 0a 20 20 69  aOnceFlag */.  i
1a10: 6e 74 20 6e 43 68 69 6c 64 4d 65 6d 3b 20 20 20  nt nChildMem;   
1a20: 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72         /* Number
1a30: 20 6f 66 20 6d 65 6d 6f 72 79 20 63 65 6c 6c 73   of memory cells
1a40: 20 66 6f 72 20 63 68 69 6c 64 20 66 72 61 6d 65   for child frame
1a50: 20 2a 2f 0a 20 20 69 6e 74 20 6e 43 68 69 6c 64   */.  int nChild
1a60: 43 73 72 3b 20 20 20 20 20 20 20 20 20 20 2f 2a  Csr;          /*
1a70: 20 4e 75 6d 62 65 72 20 6f 66 20 63 75 72 73 6f   Number of curso
1a80: 72 73 20 66 6f 72 20 63 68 69 6c 64 20 66 72 61  rs for child fra
1a90: 6d 65 20 2a 2f 0a 20 20 69 6e 74 20 6e 43 68 61  me */.  int nCha
1aa0: 6e 67 65 3b 20 20 20 20 20 20 20 20 20 20 20 20  nge;            
1ab0: 2f 2a 20 53 74 61 74 65 6d 65 6e 74 20 63 68 61  /* Statement cha
1ac0: 6e 67 65 73 20 28 56 64 62 65 2e 6e 43 68 61 6e  nges (Vdbe.nChan
1ad0: 67 65 29 20 20 20 20 20 2a 2f 0a 20 20 69 6e 74  ge)     */.  int
1ae0: 20 6e 44 62 43 68 61 6e 67 65 3b 20 20 20 20 20   nDbChange;     
1af0: 20 20 20 20 20 2f 2a 20 56 61 6c 75 65 20 6f 66       /* Value of
1b00: 20 64 62 2d 3e 6e 43 68 61 6e 67 65 20 2a 2f 0a   db->nChange */.
1b10: 7d 3b 0a 0a 23 64 65 66 69 6e 65 20 56 64 62 65  };..#define Vdbe
1b20: 46 72 61 6d 65 4d 65 6d 28 70 29 20 28 28 4d 65  FrameMem(p) ((Me
1b30: 6d 20 2a 29 26 28 28 75 38 20 2a 29 70 29 5b 52  m *)&((u8 *)p)[R
1b40: 4f 55 4e 44 38 28 73 69 7a 65 6f 66 28 56 64 62  OUND8(sizeof(Vdb
1b50: 65 46 72 61 6d 65 29 29 5d 29 0a 0a 2f 2a 0a 2a  eFrame))])../*.*
1b60: 2a 20 41 20 76 61 6c 75 65 20 66 6f 72 20 56 64  * A value for Vd
1b70: 62 65 43 75 72 73 6f 72 2e 63 61 63 68 65 56 61  beCursor.cacheVa
1b80: 6c 69 64 20 74 68 61 74 20 6d 65 61 6e 73 20 74  lid that means t
1b90: 68 65 20 63 61 63 68 65 20 69 73 20 61 6c 77 61  he cache is alwa
1ba0: 79 73 20 69 6e 76 61 6c 69 64 2e 0a 2a 2f 0a 23  ys invalid..*/.#
1bb0: 64 65 66 69 6e 65 20 43 41 43 48 45 5f 53 54 41  define CACHE_STA
1bc0: 4c 45 20 30 0a 0a 2f 2a 0a 2a 2a 20 49 6e 74 65  LE 0../*.** Inte
1bd0: 72 6e 61 6c 6c 79 2c 20 74 68 65 20 76 64 62 65  rnally, the vdbe
1be0: 20 6d 61 6e 69 70 75 6c 61 74 65 73 20 6e 65 61   manipulates nea
1bf0: 72 6c 79 20 61 6c 6c 20 53 51 4c 20 76 61 6c 75  rly all SQL valu
1c00: 65 73 20 61 73 20 4d 65 6d 0a 2a 2a 20 73 74 72  es as Mem.** str
1c10: 75 63 74 75 72 65 73 2e 20 45 61 63 68 20 4d 65  uctures. Each Me
1c20: 6d 20 73 74 72 75 63 74 20 6d 61 79 20 63 61 63  m struct may cac
1c30: 68 65 20 6d 75 6c 74 69 70 6c 65 20 72 65 70 72  he multiple repr
1c40: 65 73 65 6e 74 61 74 69 6f 6e 73 20 28 73 74 72  esentations (str
1c50: 69 6e 67 2c 0a 2a 2a 20 69 6e 74 65 67 65 72 20  ing,.** integer 
1c60: 65 74 63 2e 29 20 6f 66 20 74 68 65 20 73 61 6d  etc.) of the sam
1c70: 65 20 76 61 6c 75 65 2e 0a 2a 2f 0a 73 74 72 75  e value..*/.stru
1c80: 63 74 20 4d 65 6d 20 7b 0a 20 20 75 6e 69 6f 6e  ct Mem {.  union
1c90: 20 4d 65 6d 56 61 6c 75 65 20 7b 0a 20 20 20 20   MemValue {.    
1ca0: 64 6f 75 62 6c 65 20 72 3b 20 20 20 20 20 20 20  double r;       
1cb0: 20 20 20 20 2f 2a 20 52 65 61 6c 20 76 61 6c 75      /* Real valu
1cc0: 65 20 75 73 65 64 20 77 68 65 6e 20 4d 45 4d 5f  e used when MEM_
1cd0: 52 65 61 6c 20 69 73 20 73 65 74 20 69 6e 20 66  Real is set in f
1ce0: 6c 61 67 73 20 2a 2f 0a 20 20 20 20 69 36 34 20  lags */.    i64 
1cf0: 69 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  i;              
1d00: 2f 2a 20 49 6e 74 65 67 65 72 20 76 61 6c 75 65  /* Integer value
1d10: 20 75 73 65 64 20 77 68 65 6e 20 4d 45 4d 5f 49   used when MEM_I
1d20: 6e 74 20 69 73 20 73 65 74 20 69 6e 20 66 6c 61  nt is set in fla
1d30: 67 73 20 2a 2f 0a 20 20 20 20 69 6e 74 20 6e 5a  gs */.    int nZ
1d40: 65 72 6f 3b 20 20 20 20 20 20 20 20 20 20 2f 2a  ero;          /*
1d50: 20 55 73 65 64 20 77 68 65 6e 20 62 69 74 20 4d   Used when bit M
1d60: 45 4d 5f 5a 65 72 6f 20 69 73 20 73 65 74 20 69  EM_Zero is set i
1d70: 6e 20 66 6c 61 67 73 20 2a 2f 0a 20 20 20 20 76  n flags */.    v
1d80: 6f 69 64 20 2a 70 50 74 72 3b 20 20 20 20 20 20  oid *pPtr;      
1d90: 20 20 20 2f 2a 20 50 6f 69 6e 74 65 72 20 77 68     /* Pointer wh
1da0: 65 6e 20 66 6c 61 67 73 3d 3d 4d 45 4d 5f 50 74  en flags==MEM_Pt
1db0: 72 7c 4d 45 4d 5f 4e 75 6c 6c 20 2a 2f 0a 20 20  r|MEM_Null */.  
1dc0: 20 20 46 75 6e 63 44 65 66 20 2a 70 44 65 66 3b    FuncDef *pDef;
1dd0: 20 20 20 20 20 20 2f 2a 20 55 73 65 64 20 6f 6e        /* Used on
1de0: 6c 79 20 77 68 65 6e 20 66 6c 61 67 73 3d 3d 4d  ly when flags==M
1df0: 45 4d 5f 41 67 67 20 2a 2f 0a 20 20 20 20 52 6f  EM_Agg */.    Ro
1e00: 77 53 65 74 20 2a 70 52 6f 77 53 65 74 3b 20 20  wSet *pRowSet;  
1e10: 20 20 2f 2a 20 55 73 65 64 20 6f 6e 6c 79 20 77    /* Used only w
1e20: 68 65 6e 20 66 6c 61 67 73 3d 3d 4d 45 4d 5f 52  hen flags==MEM_R
1e30: 6f 77 53 65 74 20 2a 2f 0a 20 20 20 20 56 64 62  owSet */.    Vdb
1e40: 65 46 72 61 6d 65 20 2a 70 46 72 61 6d 65 3b 20  eFrame *pFrame; 
1e50: 20 2f 2a 20 55 73 65 64 20 77 68 65 6e 20 66 6c   /* Used when fl
1e60: 61 67 73 3d 3d 4d 45 4d 5f 46 72 61 6d 65 20 2a  ags==MEM_Frame *
1e70: 2f 0a 20 20 7d 20 75 3b 0a 20 20 75 31 36 20 66  /.  } u;.  u16 f
1e80: 6c 61 67 73 3b 20 20 20 20 20 20 20 20 20 20 2f  lags;          /
1e90: 2a 20 53 6f 6d 65 20 63 6f 6d 62 69 6e 61 74 69  * Some combinati
1ea0: 6f 6e 20 6f 66 20 4d 45 4d 5f 4e 75 6c 6c 2c 20  on of MEM_Null, 
1eb0: 4d 45 4d 5f 53 74 72 2c 20 4d 45 4d 5f 44 79 6e  MEM_Str, MEM_Dyn
1ec0: 2c 20 65 74 63 2e 20 2a 2f 0a 20 20 75 38 20 20  , etc. */.  u8  
1ed0: 65 6e 63 3b 20 20 20 20 20 20 20 20 20 20 20 20  enc;            
1ee0: 2f 2a 20 53 51 4c 49 54 45 5f 55 54 46 38 2c 20  /* SQLITE_UTF8, 
1ef0: 53 51 4c 49 54 45 5f 55 54 46 31 36 42 45 2c 20  SQLITE_UTF16BE, 
1f00: 53 51 4c 49 54 45 5f 55 54 46 31 36 4c 45 20 2a  SQLITE_UTF16LE *
1f10: 2f 0a 20 20 69 6e 74 20 6e 3b 20 20 20 20 20 20  /.  int n;      
1f20: 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65          /* Numbe
1f30: 72 20 6f 66 20 63 68 61 72 61 63 74 65 72 73 20  r of characters 
1f40: 69 6e 20 73 74 72 69 6e 67 20 76 61 6c 75 65 2c  in string value,
1f50: 20 65 78 63 6c 75 64 69 6e 67 20 27 5c 30 27 20   excluding '\0' 
1f60: 2a 2f 0a 20 20 63 68 61 72 20 2a 7a 3b 20 20 20  */.  char *z;   
1f70: 20 20 20 20 20 20 20 20 20 2f 2a 20 53 74 72 69           /* Stri
1f80: 6e 67 20 6f 72 20 42 4c 4f 42 20 76 61 6c 75 65  ng or BLOB value
1f90: 20 2a 2f 0a 20 20 2f 2a 20 53 68 61 6c 6c 6f 77   */.  /* Shallow
1fa0: 43 6f 70 79 20 6f 6e 6c 79 20 6e 65 65 64 73 20  Copy only needs 
1fb0: 74 6f 20 63 6f 70 79 20 74 68 65 20 69 6e 66 6f  to copy the info
1fc0: 72 6d 61 74 69 6f 6e 20 61 62 6f 76 65 20 2a 2f  rmation above */
1fd0: 0a 20 20 63 68 61 72 20 2a 7a 4d 61 6c 6c 6f 63  .  char *zMalloc
1fe0: 3b 20 20 20 20 20 20 2f 2a 20 53 70 61 63 65 20  ;      /* Space 
1ff0: 74 6f 20 68 6f 6c 64 20 4d 45 4d 5f 53 74 72 20  to hold MEM_Str 
2000: 6f 72 20 4d 45 4d 5f 42 6c 6f 62 20 69 66 20 73  or MEM_Blob if s
2010: 7a 4d 61 6c 6c 6f 63 3e 30 20 2a 2f 0a 20 20 69  zMalloc>0 */.  i
2020: 6e 74 20 73 7a 4d 61 6c 6c 6f 63 3b 20 20 20 20  nt szMalloc;    
2030: 20 20 20 2f 2a 20 53 69 7a 65 20 6f 66 20 74 68     /* Size of th
2040: 65 20 7a 4d 61 6c 6c 6f 63 20 61 6c 6c 6f 63 61  e zMalloc alloca
2050: 74 69 6f 6e 20 2a 2f 0a 20 20 75 33 32 20 75 54  tion */.  u32 uT
2060: 65 6d 70 3b 20 20 20 20 20 20 20 20 20 20 2f 2a  emp;          /*
2070: 20 54 72 61 6e 73 69 65 6e 74 20 73 74 6f 72 61   Transient stora
2080: 67 65 20 66 6f 72 20 73 65 72 69 61 6c 5f 74 79  ge for serial_ty
2090: 70 65 20 69 6e 20 4f 50 5f 4d 61 6b 65 52 65 63  pe in OP_MakeRec
20a0: 6f 72 64 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33  ord */.  sqlite3
20b0: 20 2a 64 62 3b 20 20 20 20 20 20 20 20 2f 2a 20   *db;        /* 
20c0: 54 68 65 20 61 73 73 6f 63 69 61 74 65 64 20 64  The associated d
20d0: 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69  atabase connecti
20e0: 6f 6e 20 2a 2f 0a 20 20 76 6f 69 64 20 28 2a 78  on */.  void (*x
20f0: 44 65 6c 29 28 76 6f 69 64 2a 29 3b 2f 2a 20 44  Del)(void*);/* D
2100: 65 73 74 72 75 63 74 6f 72 20 66 6f 72 20 4d 65  estructor for Me
2110: 6d 2e 7a 20 2d 20 6f 6e 6c 79 20 76 61 6c 69 64  m.z - only valid
2120: 20 69 66 20 4d 45 4d 5f 44 79 6e 20 2a 2f 0a 23   if MEM_Dyn */.#
2130: 69 66 64 65 66 20 53 51 4c 49 54 45 5f 44 45 42  ifdef SQLITE_DEB
2140: 55 47 0a 20 20 4d 65 6d 20 2a 70 53 63 6f 70 79  UG.  Mem *pScopy
2150: 46 72 6f 6d 3b 20 20 20 20 2f 2a 20 54 68 69 73  From;    /* This
2160: 20 4d 65 6d 20 69 73 20 61 20 73 68 61 6c 6c 6f   Mem is a shallo
2170: 77 20 63 6f 70 79 20 6f 66 20 70 53 63 6f 70 79  w copy of pScopy
2180: 46 72 6f 6d 20 2a 2f 0a 20 20 76 6f 69 64 20 2a  From */.  void *
2190: 70 46 69 6c 6c 65 72 3b 20 20 20 20 20 20 2f 2a  pFiller;      /*
21a0: 20 53 6f 20 74 68 61 74 20 73 69 7a 65 6f 66 28   So that sizeof(
21b0: 4d 65 6d 29 20 69 73 20 61 20 6d 75 6c 74 69 70  Mem) is a multip
21c0: 6c 65 20 6f 66 20 38 20 2a 2f 0a 23 65 6e 64 69  le of 8 */.#endi
21d0: 66 0a 7d 3b 0a 0a 2f 2a 20 4f 6e 65 20 6f 72 20  f.};../* One or 
21e0: 6d 6f 72 65 20 6f 66 20 74 68 65 20 66 6f 6c 6c  more of the foll
21f0: 6f 77 69 6e 67 20 66 6c 61 67 73 20 61 72 65 20  owing flags are 
2200: 73 65 74 20 74 6f 20 69 6e 64 69 63 61 74 65 20  set to indicate 
2210: 74 68 65 20 76 61 6c 69 64 4f 4b 0a 2a 2a 20 72  the validOK.** r
2220: 65 70 72 65 73 65 6e 74 61 74 69 6f 6e 73 20 6f  epresentations o
2230: 66 20 74 68 65 20 76 61 6c 75 65 20 73 74 6f 72  f the value stor
2240: 65 64 20 69 6e 20 74 68 65 20 4d 65 6d 20 73 74  ed in the Mem st
2250: 72 75 63 74 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 74  ruct..**.** If t
2260: 68 65 20 4d 45 4d 5f 4e 75 6c 6c 20 66 6c 61 67  he MEM_Null flag
2270: 20 69 73 20 73 65 74 2c 20 74 68 65 6e 20 74 68   is set, then th
2280: 65 20 76 61 6c 75 65 20 69 73 20 61 6e 20 53 51  e value is an SQ
2290: 4c 20 4e 55 4c 4c 20 76 61 6c 75 65 2e 0a 2a 2a  L NULL value..**
22a0: 20 4e 6f 20 6f 74 68 65 72 20 66 6c 61 67 73 20   No other flags 
22b0: 6d 61 79 20 62 65 20 73 65 74 20 69 6e 20 74 68  may be set in th
22c0: 69 73 20 63 61 73 65 2e 0a 2a 2a 0a 2a 2a 20 49  is case..**.** I
22d0: 66 20 74 68 65 20 4d 45 4d 5f 53 74 72 20 66 6c  f the MEM_Str fl
22e0: 61 67 20 69 73 20 73 65 74 20 74 68 65 6e 20 4d  ag is set then M
22f0: 65 6d 2e 7a 20 70 6f 69 6e 74 73 20 61 74 20 61  em.z points at a
2300: 20 73 74 72 69 6e 67 20 72 65 70 72 65 73 65 6e   string represen
2310: 74 61 74 69 6f 6e 2e 0a 2a 2a 20 55 73 75 61 6c  tation..** Usual
2320: 6c 79 20 74 68 69 73 20 69 73 20 65 6e 63 6f 64  ly this is encod
2330: 65 64 20 69 6e 20 74 68 65 20 73 61 6d 65 20 75  ed in the same u
2340: 6e 69 63 6f 64 65 20 65 6e 63 6f 64 69 6e 67 20  nicode encoding 
2350: 61 73 20 74 68 65 20 6d 61 69 6e 0a 2a 2a 20 64  as the main.** d
2360: 61 74 61 62 61 73 65 20 28 73 65 65 20 62 65 6c  atabase (see bel
2370: 6f 77 20 66 6f 72 20 65 78 63 65 70 74 69 6f 6e  ow for exception
2380: 73 29 2e 20 49 66 20 74 68 65 20 4d 45 4d 5f 54  s). If the MEM_T
2390: 65 72 6d 20 66 6c 61 67 20 69 73 20 61 6c 73 6f  erm flag is also
23a0: 0a 2a 2a 20 73 65 74 2c 20 74 68 65 6e 20 74 68  .** set, then th
23b0: 65 20 73 74 72 69 6e 67 20 69 73 20 6e 75 6c 20  e string is nul 
23c0: 74 65 72 6d 69 6e 61 74 65 64 2e 20 54 68 65 20  terminated. The 
23d0: 4d 45 4d 5f 49 6e 74 20 61 6e 64 20 4d 45 4d 5f  MEM_Int and MEM_
23e0: 52 65 61 6c 20 0a 2a 2a 20 66 6c 61 67 73 20 6d  Real .** flags m
23f0: 61 79 20 63 6f 65 78 69 73 74 20 77 69 74 68 20  ay coexist with 
2400: 74 68 65 20 4d 45 4d 5f 53 74 72 20 66 6c 61 67  the MEM_Str flag
2410: 2e 0a 2a 2f 0a 23 64 65 66 69 6e 65 20 4d 45 4d  ..*/.#define MEM
2420: 5f 4e 75 6c 6c 20 20 20 20 20 20 30 78 30 30 30  _Null      0x000
2430: 31 20 20 20 2f 2a 20 56 61 6c 75 65 20 69 73 20  1   /* Value is 
2440: 4e 55 4c 4c 20 2a 2f 0a 23 64 65 66 69 6e 65 20  NULL */.#define 
2450: 4d 45 4d 5f 53 74 72 20 20 20 20 20 20 20 30 78  MEM_Str       0x
2460: 30 30 30 32 20 20 20 2f 2a 20 56 61 6c 75 65 20  0002   /* Value 
2470: 69 73 20 61 20 73 74 72 69 6e 67 20 2a 2f 0a 23  is a string */.#
2480: 64 65 66 69 6e 65 20 4d 45 4d 5f 49 6e 74 20 20  define MEM_Int  
2490: 20 20 20 20 20 30 78 30 30 30 34 20 20 20 2f 2a       0x0004   /*
24a0: 20 56 61 6c 75 65 20 69 73 20 61 6e 20 69 6e 74   Value is an int
24b0: 65 67 65 72 20 2a 2f 0a 23 64 65 66 69 6e 65 20  eger */.#define 
24c0: 4d 45 4d 5f 52 65 61 6c 20 20 20 20 20 20 30 78  MEM_Real      0x
24d0: 30 30 30 38 20 20 20 2f 2a 20 56 61 6c 75 65 20  0008   /* Value 
24e0: 69 73 20 61 20 72 65 61 6c 20 6e 75 6d 62 65 72  is a real number
24f0: 20 2a 2f 0a 23 64 65 66 69 6e 65 20 4d 45 4d 5f   */.#define MEM_
2500: 42 6c 6f 62 20 20 20 20 20 20 30 78 30 30 31 30  Blob      0x0010
2510: 20 20 20 2f 2a 20 56 61 6c 75 65 20 69 73 20 61     /* Value is a
2520: 20 42 4c 4f 42 20 2a 2f 0a 23 64 65 66 69 6e 65   BLOB */.#define
2530: 20 4d 45 4d 5f 41 66 66 4d 61 73 6b 20 20 20 30   MEM_AffMask   0
2540: 78 30 30 31 66 20 20 20 2f 2a 20 4d 61 73 6b 20  x001f   /* Mask 
2550: 6f 66 20 61 66 66 69 6e 69 74 79 20 62 69 74 73  of affinity bits
2560: 20 2a 2f 0a 23 64 65 66 69 6e 65 20 4d 45 4d 5f   */.#define MEM_
2570: 52 6f 77 53 65 74 20 20 20 20 30 78 30 30 32 30  RowSet    0x0020
2580: 20 20 20 2f 2a 20 56 61 6c 75 65 20 69 73 20 61     /* Value is a
2590: 20 52 6f 77 53 65 74 20 6f 62 6a 65 63 74 20 2a   RowSet object *
25a0: 2f 0a 23 64 65 66 69 6e 65 20 4d 45 4d 5f 46 72  /.#define MEM_Fr
25b0: 61 6d 65 20 20 20 20 20 30 78 30 30 34 30 20 20  ame     0x0040  
25c0: 20 2f 2a 20 56 61 6c 75 65 20 69 73 20 61 20 56   /* Value is a V
25d0: 64 62 65 46 72 61 6d 65 20 6f 62 6a 65 63 74 20  dbeFrame object 
25e0: 2a 2f 0a 23 64 65 66 69 6e 65 20 4d 45 4d 5f 55  */.#define MEM_U
25f0: 6e 64 65 66 69 6e 65 64 20 30 78 30 30 38 30 20  ndefined 0x0080 
2600: 20 20 2f 2a 20 56 61 6c 75 65 20 69 73 20 75 6e    /* Value is un
2610: 64 65 66 69 6e 65 64 20 2a 2f 0a 23 64 65 66 69  defined */.#defi
2620: 6e 65 20 4d 45 4d 5f 43 6c 65 61 72 65 64 20 20  ne MEM_Cleared  
2630: 20 30 78 30 31 30 30 20 20 20 2f 2a 20 4e 55 4c   0x0100   /* NUL
2640: 4c 20 73 65 74 20 62 79 20 4f 50 5f 4e 75 6c 6c  L set by OP_Null
2650: 2c 20 6e 6f 74 20 66 72 6f 6d 20 64 61 74 61 20  , not from data 
2660: 2a 2f 0a 23 64 65 66 69 6e 65 20 4d 45 4d 5f 54  */.#define MEM_T
2670: 79 70 65 4d 61 73 6b 20 20 30 78 30 31 66 66 20  ypeMask  0x01ff 
2680: 20 20 2f 2a 20 4d 61 73 6b 20 6f 66 20 74 79 70    /* Mask of typ
2690: 65 20 62 69 74 73 20 2a 2f 0a 0a 0a 2f 2a 20 57  e bits */.../* W
26a0: 68 65 6e 65 76 65 72 20 4d 65 6d 20 63 6f 6e 74  henever Mem cont
26b0: 61 69 6e 73 20 61 20 76 61 6c 69 64 20 73 74 72  ains a valid str
26c0: 69 6e 67 20 6f 72 20 62 6c 6f 62 20 72 65 70 72  ing or blob repr
26d0: 65 73 65 6e 74 61 74 69 6f 6e 2c 20 6f 6e 65 20  esentation, one 
26e0: 6f 66 0a 2a 2a 20 74 68 65 20 66 6f 6c 6c 6f 77  of.** the follow
26f0: 69 6e 67 20 66 6c 61 67 73 20 6d 75 73 74 20 62  ing flags must b
2700: 65 20 73 65 74 20 74 6f 20 64 65 74 65 72 6d 69  e set to determi
2710: 6e 65 20 74 68 65 20 6d 65 6d 6f 72 79 20 6d 61  ne the memory ma
2720: 6e 61 67 65 6d 65 6e 74 0a 2a 2a 20 70 6f 6c 69  nagement.** poli
2730: 63 79 20 66 6f 72 20 4d 65 6d 2e 7a 2e 20 20 54  cy for Mem.z.  T
2740: 68 65 20 4d 45 4d 5f 54 65 72 6d 20 66 6c 61 67  he MEM_Term flag
2750: 20 74 65 6c 6c 73 20 75 73 20 77 68 65 74 68 65   tells us whethe
2760: 72 20 6f 72 20 6e 6f 74 20 74 68 65 0a 2a 2a 20  r or not the.** 
2770: 73 74 72 69 6e 67 20 69 73 20 5c 30 30 30 20 6f  string is \000 o
2780: 72 20 5c 75 30 30 30 30 20 74 65 72 6d 69 6e 61  r \u0000 termina
2790: 74 65 64 0a 2a 2f 0a 23 64 65 66 69 6e 65 20 4d  ted.*/.#define M
27a0: 45 4d 5f 50 74 72 20 20 20 20 20 20 20 30 78 38  EM_Ptr       0x8
27b0: 30 30 30 20 20 20 2f 2a 20 75 2e 70 50 74 72 20  000   /* u.pPtr 
27c0: 69 73 20 76 61 6c 69 64 20 69 66 20 74 79 70 65  is valid if type
27d0: 3d 3d 53 51 4c 49 54 45 5f 4e 55 4c 4c 20 2a 2f  ==SQLITE_NULL */
27e0: 0a 23 64 65 66 69 6e 65 20 4d 45 4d 5f 54 65 72  .#define MEM_Ter
27f0: 6d 20 20 20 20 20 20 30 78 30 32 30 30 20 20 20  m      0x0200   
2800: 2f 2a 20 53 74 72 69 6e 67 20 72 65 70 20 69 73  /* String rep is
2810: 20 6e 75 6c 20 74 65 72 6d 69 6e 61 74 65 64 20   nul terminated 
2820: 2a 2f 0a 23 64 65 66 69 6e 65 20 4d 45 4d 5f 44  */.#define MEM_D
2830: 79 6e 20 20 20 20 20 20 20 30 78 30 34 30 30 20  yn       0x0400 
2840: 20 20 2f 2a 20 4e 65 65 64 20 74 6f 20 63 61 6c    /* Need to cal
2850: 6c 20 4d 65 6d 2e 78 44 65 6c 28 29 20 6f 6e 20  l Mem.xDel() on 
2860: 4d 65 6d 2e 7a 20 2a 2f 0a 23 64 65 66 69 6e 65  Mem.z */.#define
2870: 20 4d 45 4d 5f 53 74 61 74 69 63 20 20 20 20 30   MEM_Static    0
2880: 78 30 38 30 30 20 20 20 2f 2a 20 4d 65 6d 2e 7a  x0800   /* Mem.z
2890: 20 70 6f 69 6e 74 73 20 74 6f 20 61 20 73 74 61   points to a sta
28a0: 74 69 63 20 73 74 72 69 6e 67 20 2a 2f 0a 23 64  tic string */.#d
28b0: 65 66 69 6e 65 20 4d 45 4d 5f 45 70 68 65 6d 20  efine MEM_Ephem 
28c0: 20 20 20 20 30 78 31 30 30 30 20 20 20 2f 2a 20      0x1000   /* 
28d0: 4d 65 6d 2e 7a 20 70 6f 69 6e 74 73 20 74 6f 20  Mem.z points to 
28e0: 61 6e 20 65 70 68 65 6d 65 72 61 6c 20 73 74 72  an ephemeral str
28f0: 69 6e 67 20 2a 2f 0a 23 64 65 66 69 6e 65 20 4d  ing */.#define M
2900: 45 4d 5f 41 67 67 20 20 20 20 20 20 20 30 78 32  EM_Agg       0x2
2910: 30 30 30 20 20 20 2f 2a 20 4d 65 6d 2e 7a 20 70  000   /* Mem.z p
2920: 6f 69 6e 74 73 20 74 6f 20 61 6e 20 61 67 67 20  oints to an agg 
2930: 66 75 6e 63 74 69 6f 6e 20 63 6f 6e 74 65 78 74  function context
2940: 20 2a 2f 0a 23 64 65 66 69 6e 65 20 4d 45 4d 5f   */.#define MEM_
2950: 5a 65 72 6f 20 20 20 20 20 20 30 78 34 30 30 30  Zero      0x4000
2960: 20 20 20 2f 2a 20 4d 65 6d 2e 69 20 63 6f 6e 74     /* Mem.i cont
2970: 61 69 6e 73 20 63 6f 75 6e 74 20 6f 66 20 30 73  ains count of 0s
2980: 20 61 70 70 65 6e 64 65 64 20 74 6f 20 62 6c 6f   appended to blo
2990: 62 20 2a 2f 0a 23 69 66 64 65 66 20 53 51 4c 49  b */.#ifdef SQLI
29a0: 54 45 5f 4f 4d 49 54 5f 49 4e 43 52 42 4c 4f 42  TE_OMIT_INCRBLOB
29b0: 0a 20 20 23 75 6e 64 65 66 20 4d 45 4d 5f 5a 65  .  #undef MEM_Ze
29c0: 72 6f 0a 20 20 23 64 65 66 69 6e 65 20 4d 45 4d  ro.  #define MEM
29d0: 5f 5a 65 72 6f 20 30 78 30 30 30 30 0a 23 65 6e  _Zero 0x0000.#en
29e0: 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 43 6c 65 61 72  dif../*.** Clear
29f0: 20 61 6e 79 20 65 78 69 73 74 69 6e 67 20 74 79   any existing ty
2a00: 70 65 20 66 6c 61 67 73 20 66 72 6f 6d 20 61 20  pe flags from a 
2a10: 4d 65 6d 20 61 6e 64 20 72 65 70 6c 61 63 65 20  Mem and replace 
2a20: 74 68 65 6d 20 77 69 74 68 20 66 0a 2a 2f 0a 23  them with f.*/.#
2a30: 64 65 66 69 6e 65 20 4d 65 6d 53 65 74 54 79 70  define MemSetTyp
2a40: 65 46 6c 61 67 28 70 2c 20 66 29 20 5c 0a 20 20  eFlag(p, f) \.  
2a50: 20 28 28 70 29 2d 3e 66 6c 61 67 73 20 3d 20 28   ((p)->flags = (
2a60: 28 70 29 2d 3e 66 6c 61 67 73 26 7e 28 4d 45 4d  (p)->flags&~(MEM
2a70: 5f 54 79 70 65 4d 61 73 6b 7c 4d 45 4d 5f 5a 65  _TypeMask|MEM_Ze
2a80: 72 6f 7c 4d 45 4d 5f 50 74 72 29 29 7c 66 29 0a  ro|MEM_Ptr))|f).
2a90: 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 74 72  ./*.** Return tr
2aa0: 75 65 20 69 66 20 61 20 6d 65 6d 6f 72 79 20 63  ue if a memory c
2ab0: 65 6c 6c 20 69 73 20 6e 6f 74 20 6d 61 72 6b 65  ell is not marke
2ac0: 64 20 61 73 20 69 6e 76 61 6c 69 64 2e 20 20 54  d as invalid.  T
2ad0: 68 69 73 20 6d 61 63 72 6f 0a 2a 2a 20 69 73 20  his macro.** is 
2ae0: 66 6f 72 20 75 73 65 20 69 6e 73 69 64 65 20 61  for use inside a
2af0: 73 73 65 72 74 28 29 20 73 74 61 74 65 6d 65 6e  ssert() statemen
2b00: 74 73 20 6f 6e 6c 79 2e 0a 2a 2f 0a 23 69 66 64  ts only..*/.#ifd
2b10: 65 66 20 53 51 4c 49 54 45 5f 44 45 42 55 47 0a  ef SQLITE_DEBUG.
2b20: 23 64 65 66 69 6e 65 20 6d 65 6d 49 73 56 61 6c  #define memIsVal
2b30: 69 64 28 4d 29 20 20 28 28 4d 29 2d 3e 66 6c 61  id(M)  ((M)->fla
2b40: 67 73 20 26 20 4d 45 4d 5f 55 6e 64 65 66 69 6e  gs & MEM_Undefin
2b50: 65 64 29 3d 3d 30 0a 23 65 6e 64 69 66 0a 0a 2f  ed)==0.#endif../
2b60: 2a 0a 2a 2a 20 45 61 63 68 20 61 75 78 69 6c 69  *.** Each auxili
2b70: 61 72 79 20 64 61 74 61 20 70 6f 69 6e 74 65 72  ary data pointer
2b80: 20 73 74 6f 72 65 64 20 62 79 20 61 20 75 73 65   stored by a use
2b90: 72 20 64 65 66 69 6e 65 64 20 66 75 6e 63 74 69  r defined functi
2ba0: 6f 6e 20 0a 2a 2a 20 69 6d 70 6c 65 6d 65 6e 74  on .** implement
2bb0: 61 74 69 6f 6e 20 63 61 6c 6c 69 6e 67 20 73 71  ation calling sq
2bc0: 6c 69 74 65 33 5f 73 65 74 5f 61 75 78 64 61 74  lite3_set_auxdat
2bd0: 61 28 29 20 69 73 20 73 74 6f 72 65 64 20 69 6e  a() is stored in
2be0: 20 61 6e 20 69 6e 73 74 61 6e 63 65 0a 2a 2a 20   an instance.** 
2bf0: 6f 66 20 74 68 69 73 20 73 74 72 75 63 74 75 72  of this structur
2c00: 65 2e 20 41 6c 6c 20 73 75 63 68 20 73 74 72 75  e. All such stru
2c10: 63 74 75 72 65 73 20 61 73 73 6f 63 69 61 74 65  ctures associate
2c20: 64 20 77 69 74 68 20 61 20 73 69 6e 67 6c 65 20  d with a single 
2c30: 56 4d 0a 2a 2a 20 61 72 65 20 73 74 6f 72 65 64  VM.** are stored
2c40: 20 69 6e 20 61 20 6c 69 6e 6b 65 64 20 6c 69 73   in a linked lis
2c50: 74 20 68 65 61 64 65 64 20 61 74 20 56 64 62 65  t headed at Vdbe
2c60: 2e 70 41 75 78 44 61 74 61 2e 20 41 6c 6c 20 61  .pAuxData. All a
2c70: 72 65 20 64 65 73 74 72 6f 79 65 64 0a 2a 2a 20  re destroyed.** 
2c80: 77 68 65 6e 20 74 68 65 20 56 4d 20 69 73 20 68  when the VM is h
2c90: 61 6c 74 65 64 20 28 69 66 20 6e 6f 74 20 62 65  alted (if not be
2ca0: 66 6f 72 65 29 2e 0a 2a 2f 0a 73 74 72 75 63 74  fore)..*/.struct
2cb0: 20 41 75 78 44 61 74 61 20 7b 0a 20 20 69 6e 74   AuxData {.  int
2cc0: 20 69 4f 70 3b 20 20 20 20 20 20 20 20 20 20 20   iOp;           
2cd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
2ce0: 49 6e 73 74 72 75 63 74 69 6f 6e 20 6e 75 6d 62  Instruction numb
2cf0: 65 72 20 6f 66 20 4f 50 5f 46 75 6e 63 74 69 6f  er of OP_Functio
2d00: 6e 20 6f 70 63 6f 64 65 20 2a 2f 0a 20 20 69 6e  n opcode */.  in
2d10: 74 20 69 41 72 67 3b 20 20 20 20 20 20 20 20 20  t iArg;         
2d20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
2d30: 20 49 6e 64 65 78 20 6f 66 20 66 75 6e 63 74 69   Index of functi
2d40: 6f 6e 20 61 72 67 75 6d 65 6e 74 2e 20 2a 2f 0a  on argument. */.
2d50: 20 20 76 6f 69 64 20 2a 70 41 75 78 3b 20 20 20    void *pAux;   
2d60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2d70: 20 20 2f 2a 20 41 75 78 20 64 61 74 61 20 70 6f    /* Aux data po
2d80: 69 6e 74 65 72 20 2a 2f 0a 20 20 76 6f 69 64 20  inter */.  void 
2d90: 28 2a 78 44 65 6c 65 74 65 29 28 76 6f 69 64 20  (*xDelete)(void 
2da0: 2a 29 3b 20 20 20 20 20 20 20 20 2f 2a 20 44 65  *);        /* De
2db0: 73 74 72 75 63 74 6f 72 20 66 6f 72 20 74 68 65  structor for the
2dc0: 20 61 75 78 20 64 61 74 61 20 2a 2f 0a 20 20 41   aux data */.  A
2dd0: 75 78 44 61 74 61 20 2a 70 4e 65 78 74 3b 20 20  uxData *pNext;  
2de0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
2df0: 2a 20 4e 65 78 74 20 65 6c 65 6d 65 6e 74 20 69  * Next element i
2e00: 6e 20 6c 69 73 74 20 2a 2f 0a 7d 3b 0a 0a 2f 2a  n list */.};../*
2e10: 0a 2a 2a 20 54 68 65 20 22 63 6f 6e 74 65 78 74  .** The "context
2e20: 22 20 61 72 67 75 6d 65 6e 74 20 66 6f 72 20 61  " argument for a
2e30: 6e 20 69 6e 73 74 61 6c 6c 61 62 6c 65 20 66 75  n installable fu
2e40: 6e 63 74 69 6f 6e 2e 20 20 41 20 70 6f 69 6e 74  nction.  A point
2e50: 65 72 20 74 6f 20 61 6e 0a 2a 2a 20 69 6e 73 74  er to an.** inst
2e60: 61 6e 63 65 20 6f 66 20 74 68 69 73 20 73 74 72  ance of this str
2e70: 75 63 74 75 72 65 20 69 73 20 74 68 65 20 66 69  ucture is the fi
2e80: 72 73 74 20 61 72 67 75 6d 65 6e 74 20 74 6f 20  rst argument to 
2e90: 74 68 65 20 72 6f 75 74 69 6e 65 73 20 75 73 65  the routines use
2ea0: 64 0a 2a 2a 20 69 6d 70 6c 65 6d 65 6e 74 20 74  d.** implement t
2eb0: 68 65 20 53 51 4c 20 66 75 6e 63 74 69 6f 6e 73  he SQL functions
2ec0: 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 72 65 20 69 73  ..**.** There is
2ed0: 20 61 20 74 79 70 65 64 65 66 20 66 6f 72 20 74   a typedef for t
2ee0: 68 69 73 20 73 74 72 75 63 74 75 72 65 20 69 6e  his structure in
2ef0: 20 73 71 6c 69 74 65 2e 68 2e 20 20 53 6f 20 61   sqlite.h.  So a
2f00: 6c 6c 20 72 6f 75 74 69 6e 65 73 2c 0a 2a 2a 20  ll routines,.** 
2f10: 65 76 65 6e 20 74 68 65 20 70 75 62 6c 69 63 20  even the public 
2f20: 69 6e 74 65 72 66 61 63 65 20 74 6f 20 53 51 4c  interface to SQL
2f30: 69 74 65 2c 20 63 61 6e 20 75 73 65 20 61 20 70  ite, can use a p
2f40: 6f 69 6e 74 65 72 20 74 6f 20 74 68 69 73 20 73  ointer to this s
2f50: 74 72 75 63 74 75 72 65 2e 0a 2a 2a 20 42 75 74  tructure..** But
2f60: 20 74 68 69 73 20 66 69 6c 65 20 69 73 20 74 68   this file is th
2f70: 65 20 6f 6e 6c 79 20 70 6c 61 63 65 20 77 68 65  e only place whe
2f80: 72 65 20 74 68 65 20 69 6e 74 65 72 6e 61 6c 20  re the internal 
2f90: 64 65 74 61 69 6c 73 20 6f 66 20 74 68 69 73 0a  details of this.
2fa0: 2a 2a 20 73 74 72 75 63 74 75 72 65 20 61 72 65  ** structure are
2fb0: 20 6b 6e 6f 77 6e 2e 0a 2a 2a 0a 2a 2a 20 54 68   known..**.** Th
2fc0: 69 73 20 73 74 72 75 63 74 75 72 65 20 69 73 20  is structure is 
2fd0: 64 65 66 69 6e 65 64 20 69 6e 73 69 64 65 20 6f  defined inside o
2fe0: 66 20 76 64 62 65 49 6e 74 2e 68 20 62 65 63 61  f vdbeInt.h beca
2ff0: 75 73 65 20 69 74 20 75 73 65 73 20 73 75 62 73  use it uses subs
3000: 74 72 75 63 74 75 72 65 73 0a 2a 2a 20 28 4d 65  tructures.** (Me
3010: 6d 29 20 77 68 69 63 68 20 61 72 65 20 6f 6e 6c  m) which are onl
3020: 79 20 64 65 66 69 6e 65 64 20 74 68 65 72 65 2e  y defined there.
3030: 0a 2a 2f 0a 73 74 72 75 63 74 20 73 71 6c 69 74  .*/.struct sqlit
3040: 65 33 5f 63 6f 6e 74 65 78 74 20 7b 0a 20 20 4d  e3_context {.  M
3050: 65 6d 20 2a 70 4f 75 74 3b 20 20 20 20 20 20 20  em *pOut;       
3060: 20 20 20 20 20 2f 2a 20 54 68 65 20 72 65 74 75       /* The retu
3070: 72 6e 20 76 61 6c 75 65 20 69 73 20 73 74 6f 72  rn value is stor
3080: 65 64 20 68 65 72 65 20 2a 2f 0a 20 20 46 75 6e  ed here */.  Fun
3090: 63 44 65 66 20 2a 70 46 75 6e 63 3b 20 20 20 20  cDef *pFunc;    
30a0: 20 20 20 2f 2a 20 50 6f 69 6e 74 65 72 20 74 6f     /* Pointer to
30b0: 20 66 75 6e 63 74 69 6f 6e 20 69 6e 66 6f 72 6d   function inform
30c0: 61 74 69 6f 6e 20 2a 2f 0a 20 20 4d 65 6d 20 2a  ation */.  Mem *
30d0: 70 4d 65 6d 3b 20 20 20 20 20 20 20 20 20 20 20  pMem;           
30e0: 20 2f 2a 20 4d 65 6d 6f 72 79 20 63 65 6c 6c 20   /* Memory cell 
30f0: 75 73 65 64 20 74 6f 20 73 74 6f 72 65 20 61 67  used to store ag
3100: 67 72 65 67 61 74 65 20 63 6f 6e 74 65 78 74 20  gregate context 
3110: 2a 2f 0a 20 20 56 64 62 65 20 2a 70 56 64 62 65  */.  Vdbe *pVdbe
3120: 3b 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 68  ;          /* Th
3130: 65 20 56 4d 20 74 68 61 74 20 6f 77 6e 73 20 74  e VM that owns t
3140: 68 69 73 20 63 6f 6e 74 65 78 74 20 2a 2f 0a 20  his context */. 
3150: 20 69 6e 74 20 69 4f 70 3b 20 20 20 20 20 20 20   int iOp;       
3160: 20 20 20 20 20 20 20 2f 2a 20 49 6e 73 74 72 75         /* Instru
3170: 63 74 69 6f 6e 20 6e 75 6d 62 65 72 20 6f 66 20  ction number of 
3180: 4f 50 5f 46 75 6e 63 74 69 6f 6e 20 2a 2f 0a 20  OP_Function */. 
3190: 20 69 6e 74 20 69 73 45 72 72 6f 72 3b 20 20 20   int isError;   
31a0: 20 20 20 20 20 20 20 2f 2a 20 45 72 72 6f 72 20         /* Error 
31b0: 63 6f 64 65 20 72 65 74 75 72 6e 65 64 20 62 79  code returned by
31c0: 20 74 68 65 20 66 75 6e 63 74 69 6f 6e 2e 20 2a   the function. *
31d0: 2f 0a 20 20 75 38 20 73 6b 69 70 46 6c 61 67 3b  /.  u8 skipFlag;
31e0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 53 6b 69            /* Ski
31f0: 70 20 61 63 63 75 6d 75 6c 61 74 6f 72 20 6c 6f  p accumulator lo
3200: 61 64 69 6e 67 20 69 66 20 74 72 75 65 20 2a 2f  ading if true */
3210: 0a 20 20 75 38 20 66 45 72 72 6f 72 4f 72 41 75  .  u8 fErrorOrAu
3220: 78 3b 20 20 20 20 20 20 20 2f 2a 20 69 73 45 72  x;       /* isEr
3230: 72 6f 72 21 3d 30 20 6f 72 20 70 56 64 62 65 2d  ror!=0 or pVdbe-
3240: 3e 70 41 75 78 44 61 74 61 20 6d 6f 64 69 66 69  >pAuxData modifi
3250: 65 64 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20  ed */.};../*.** 
3260: 41 6e 20 45 78 70 6c 61 69 6e 20 6f 62 6a 65 63  An Explain objec
3270: 74 20 61 63 63 75 6d 75 6c 61 74 65 73 20 69 6e  t accumulates in
3280: 64 65 6e 74 65 64 20 6f 75 74 70 75 74 20 77 68  dented output wh
3290: 69 63 68 20 69 73 20 68 65 6c 70 66 75 6c 0a 2a  ich is helpful.*
32a0: 2a 20 69 6e 20 64 65 73 63 72 69 62 69 6e 67 20  * in describing 
32b0: 72 65 63 75 72 73 69 76 65 20 64 61 74 61 20 73  recursive data s
32c0: 74 72 75 63 74 75 72 65 73 2e 0a 2a 2f 0a 73 74  tructures..*/.st
32d0: 72 75 63 74 20 45 78 70 6c 61 69 6e 20 7b 0a 20  ruct Explain {. 
32e0: 20 56 64 62 65 20 2a 70 56 64 62 65 3b 20 20 20   Vdbe *pVdbe;   
32f0: 20 20 20 20 2f 2a 20 41 74 74 61 63 68 20 74 68      /* Attach th
3300: 65 20 65 78 70 6c 61 6e 61 74 69 6f 6e 20 74 6f  e explanation to
3310: 20 74 68 69 73 20 56 64 62 65 20 2a 2f 0a 20 20   this Vdbe */.  
3320: 53 74 72 41 63 63 75 6d 20 73 74 72 3b 20 20 20  StrAccum str;   
3330: 20 20 20 2f 2a 20 54 68 65 20 73 74 72 69 6e 67     /* The string
3340: 20 62 65 69 6e 67 20 61 63 63 75 6d 75 6c 61 74   being accumulat
3350: 65 64 20 2a 2f 0a 20 20 69 6e 74 20 6e 49 6e 64  ed */.  int nInd
3360: 65 6e 74 3b 20 20 20 20 20 20 20 2f 2a 20 4e 75  ent;       /* Nu
3370: 6d 62 65 72 20 6f 66 20 65 6c 65 6d 65 6e 74 73  mber of elements
3380: 20 69 6e 20 61 49 6e 64 65 6e 74 20 2a 2f 0a 20   in aIndent */. 
3390: 20 75 31 36 20 61 49 6e 64 65 6e 74 5b 31 30 30   u16 aIndent[100
33a0: 5d 3b 20 20 2f 2a 20 4c 65 76 65 6c 73 20 6f 66  ];  /* Levels of
33b0: 20 69 6e 64 65 6e 74 61 74 69 6f 6e 20 2a 2f 0a   indentation */.
33c0: 20 20 63 68 61 72 20 7a 42 61 73 65 5b 31 30 30    char zBase[100
33d0: 5d 3b 20 20 20 2f 2a 20 49 6e 69 74 69 61 6c 20  ];   /* Initial 
33e0: 73 70 61 63 65 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 20  space */.};../* 
33f0: 41 20 62 69 74 66 69 65 6c 64 20 74 79 70 65 20  A bitfield type 
3400: 66 6f 72 20 75 73 65 20 69 6e 73 69 64 65 20 6f  for use inside o
3410: 66 20 73 74 72 75 63 74 75 72 65 73 2e 20 20 41  f structures.  A
3420: 6c 77 61 79 73 20 66 6f 6c 6c 6f 77 20 77 69 74  lways follow wit
3430: 68 20 3a 4e 20 77 68 65 72 65 0a 2a 2a 20 4e 20  h :N where.** N 
3440: 69 73 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66  is the number of
3450: 20 62 69 74 73 2e 0a 2a 2f 0a 74 79 70 65 64 65   bits..*/.typede
3460: 66 20 75 6e 73 69 67 6e 65 64 20 62 66 74 3b 20  f unsigned bft; 
3470: 20 2f 2a 20 42 69 74 20 46 69 65 6c 64 20 54 79   /* Bit Field Ty
3480: 70 65 20 2a 2f 0a 0a 74 79 70 65 64 65 66 20 73  pe */..typedef s
3490: 74 72 75 63 74 20 53 63 61 6e 53 74 61 74 75 73  truct ScanStatus
34a0: 20 53 63 61 6e 53 74 61 74 75 73 3b 0a 73 74 72   ScanStatus;.str
34b0: 75 63 74 20 53 63 61 6e 53 74 61 74 75 73 20 7b  uct ScanStatus {
34c0: 0a 20 20 69 6e 74 20 61 64 64 72 45 78 70 6c 61  .  int addrExpla
34d0: 69 6e 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  in;             
34e0: 20 20 20 2f 2a 20 4f 50 5f 45 78 70 6c 61 69 6e     /* OP_Explain
34f0: 20 66 6f 72 20 6c 6f 6f 70 20 2a 2f 0a 20 20 69   for loop */.  i
3500: 6e 74 20 61 64 64 72 4c 6f 6f 70 3b 20 20 20 20  nt addrLoop;    
3510: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
3520: 2a 20 41 64 64 72 65 73 73 20 6f 66 20 22 6c 6f  * Address of "lo
3530: 6f 70 73 22 20 63 6f 75 6e 74 65 72 20 2a 2f 0a  ops" counter */.
3540: 20 20 69 6e 74 20 61 64 64 72 56 69 73 69 74 3b    int addrVisit;
3550: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3560: 20 20 2f 2a 20 41 64 64 72 65 73 73 20 6f 66 20    /* Address of 
3570: 22 72 6f 77 73 20 76 69 73 69 74 65 64 22 20 63  "rows visited" c
3580: 6f 75 6e 74 65 72 20 2a 2f 0a 20 20 69 6e 74 20  ounter */.  int 
3590: 69 53 65 6c 65 63 74 49 44 3b 20 20 20 20 20 20  iSelectID;      
35a0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54              /* T
35b0: 68 65 20 22 53 65 6c 65 63 74 2d 49 44 22 20 66  he "Select-ID" f
35c0: 6f 72 20 74 68 69 73 20 6c 6f 6f 70 20 2a 2f 0a  or this loop */.
35d0: 20 20 4c 6f 67 45 73 74 20 6e 45 73 74 3b 20 20    LogEst nEst;  
35e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
35f0: 20 20 2f 2a 20 45 73 74 69 6d 61 74 65 64 20 6f    /* Estimated o
3600: 75 74 70 75 74 20 72 6f 77 73 20 70 65 72 20 6c  utput rows per l
3610: 6f 6f 70 20 2a 2f 0a 20 20 63 68 61 72 20 2a 7a  oop */.  char *z
3620: 4e 61 6d 65 3b 20 20 20 20 20 20 20 20 20 20 20  Name;           
3630: 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 61 6d 65           /* Name
3640: 20 6f 66 20 74 61 62 6c 65 20 6f 72 20 69 6e 64   of table or ind
3650: 65 78 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20  ex */.};../*.** 
3660: 41 6e 20 69 6e 73 74 61 6e 63 65 20 6f 66 20 74  An instance of t
3670: 68 65 20 76 69 72 74 75 61 6c 20 6d 61 63 68 69  he virtual machi
3680: 6e 65 2e 20 20 54 68 69 73 20 73 74 72 75 63 74  ne.  This struct
3690: 75 72 65 20 63 6f 6e 74 61 69 6e 73 20 74 68 65  ure contains the
36a0: 20 63 6f 6d 70 6c 65 74 65 0a 2a 2a 20 73 74 61   complete.** sta
36b0: 74 65 20 6f 66 20 74 68 65 20 76 69 72 74 75 61  te of the virtua
36c0: 6c 20 6d 61 63 68 69 6e 65 2e 0a 2a 2a 0a 2a 2a  l machine..**.**
36d0: 20 54 68 65 20 22 73 71 6c 69 74 65 33 5f 73 74   The "sqlite3_st
36e0: 6d 74 22 20 73 74 72 75 63 74 75 72 65 20 70 6f  mt" structure po
36f0: 69 6e 74 65 72 20 74 68 61 74 20 69 73 20 72 65  inter that is re
3700: 74 75 72 6e 65 64 20 62 79 20 73 71 6c 69 74 65  turned by sqlite
3710: 33 5f 70 72 65 70 61 72 65 28 29 0a 2a 2a 20 69  3_prepare().** i
3720: 73 20 72 65 61 6c 6c 79 20 61 20 70 6f 69 6e 74  s really a point
3730: 65 72 20 74 6f 20 61 6e 20 69 6e 73 74 61 6e 63  er to an instanc
3740: 65 20 6f 66 20 74 68 69 73 20 73 74 72 75 63 74  e of this struct
3750: 75 72 65 2e 0a 2a 2f 0a 73 74 72 75 63 74 20 56  ure..*/.struct V
3760: 64 62 65 20 7b 0a 20 20 73 71 6c 69 74 65 33 20  dbe {.  sqlite3 
3770: 2a 64 62 3b 20 20 20 20 20 20 20 20 20 20 20 20  *db;            
3780: 2f 2a 20 54 68 65 20 64 61 74 61 62 61 73 65 20  /* The database 
3790: 63 6f 6e 6e 65 63 74 69 6f 6e 20 74 68 61 74 20  connection that 
37a0: 6f 77 6e 73 20 74 68 69 73 20 73 74 61 74 65 6d  owns this statem
37b0: 65 6e 74 20 2a 2f 0a 20 20 4f 70 20 2a 61 4f 70  ent */.  Op *aOp
37c0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
37d0: 20 2f 2a 20 53 70 61 63 65 20 74 6f 20 68 6f 6c   /* Space to hol
37e0: 64 20 74 68 65 20 76 69 72 74 75 61 6c 20 6d 61  d the virtual ma
37f0: 63 68 69 6e 65 27 73 20 70 72 6f 67 72 61 6d 20  chine's program 
3800: 2a 2f 0a 20 20 4d 65 6d 20 2a 61 4d 65 6d 3b 20  */.  Mem *aMem; 
3810: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
3820: 54 68 65 20 6d 65 6d 6f 72 79 20 6c 6f 63 61 74  The memory locat
3830: 69 6f 6e 73 20 2a 2f 0a 20 20 4d 65 6d 20 2a 2a  ions */.  Mem **
3840: 61 70 41 72 67 3b 20 20 20 20 20 20 20 20 20 20  apArg;          
3850: 20 20 2f 2a 20 41 72 67 75 6d 65 6e 74 73 20 74    /* Arguments t
3860: 6f 20 63 75 72 72 65 6e 74 6c 79 20 65 78 65 63  o currently exec
3870: 75 74 69 6e 67 20 75 73 65 72 20 66 75 6e 63 74  uting user funct
3880: 69 6f 6e 20 2a 2f 0a 20 20 4d 65 6d 20 2a 61 43  ion */.  Mem *aC
3890: 6f 6c 4e 61 6d 65 3b 20 20 20 20 20 20 20 20 20  olName;         
38a0: 20 2f 2a 20 43 6f 6c 75 6d 6e 20 6e 61 6d 65 73   /* Column names
38b0: 20 74 6f 20 72 65 74 75 72 6e 20 2a 2f 0a 20 20   to return */.  
38c0: 4d 65 6d 20 2a 70 52 65 73 75 6c 74 53 65 74 3b  Mem *pResultSet;
38d0: 20 20 20 20 20 20 20 20 2f 2a 20 50 6f 69 6e 74          /* Point
38e0: 65 72 20 74 6f 20 61 6e 20 61 72 72 61 79 20 6f  er to an array o
38f0: 66 20 72 65 73 75 6c 74 73 20 2a 2f 0a 20 20 50  f results */.  P
3900: 61 72 73 65 20 2a 70 50 61 72 73 65 3b 20 20 20  arse *pParse;   
3910: 20 20 20 20 20 20 20 2f 2a 20 50 61 72 73 69 6e         /* Parsin
3920: 67 20 63 6f 6e 74 65 78 74 20 75 73 65 64 20 74  g context used t
3930: 6f 20 63 72 65 61 74 65 20 74 68 69 73 20 56 64  o create this Vd
3940: 62 65 20 2a 2f 0a 20 20 69 6e 74 20 6e 4d 65 6d  be */.  int nMem
3950: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
3960: 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 6d 65 6d  /* Number of mem
3970: 6f 72 79 20 6c 6f 63 61 74 69 6f 6e 73 20 63 75  ory locations cu
3980: 72 72 65 6e 74 6c 79 20 61 6c 6c 6f 63 61 74 65  rrently allocate
3990: 64 20 2a 2f 0a 20 20 69 6e 74 20 6e 4f 70 3b 20  d */.  int nOp; 
39a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
39b0: 2a 20 4e 75 6d 62 65 72 20 6f 66 20 69 6e 73 74  * Number of inst
39c0: 72 75 63 74 69 6f 6e 73 20 69 6e 20 74 68 65 20  ructions in the 
39d0: 70 72 6f 67 72 61 6d 20 2a 2f 0a 20 20 69 6e 74  program */.  int
39e0: 20 6e 43 75 72 73 6f 72 3b 20 20 20 20 20 20 20   nCursor;       
39f0: 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f       /* Number o
3a00: 66 20 73 6c 6f 74 73 20 69 6e 20 61 70 43 73 72  f slots in apCsr
3a10: 5b 5d 20 2a 2f 0a 20 20 75 33 32 20 6d 61 67 69  [] */.  u32 magi
3a20: 63 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  c;              
3a30: 2f 2a 20 4d 61 67 69 63 20 6e 75 6d 62 65 72 20  /* Magic number 
3a40: 66 6f 72 20 73 61 6e 69 74 79 20 63 68 65 63 6b  for sanity check
3a50: 69 6e 67 20 2a 2f 0a 20 20 63 68 61 72 20 2a 7a  ing */.  char *z
3a60: 45 72 72 4d 73 67 3b 20 20 20 20 20 20 20 20 20  ErrMsg;         
3a70: 20 2f 2a 20 45 72 72 6f 72 20 6d 65 73 73 61 67   /* Error messag
3a80: 65 20 77 72 69 74 74 65 6e 20 68 65 72 65 20 2a  e written here *
3a90: 2f 0a 20 20 56 64 62 65 20 2a 70 50 72 65 76 2c  /.  Vdbe *pPrev,
3aa0: 2a 70 4e 65 78 74 3b 20 20 20 20 20 2f 2a 20 4c  *pNext;     /* L
3ab0: 69 6e 6b 65 64 20 6c 69 73 74 20 6f 66 20 56 44  inked list of VD
3ac0: 42 45 73 20 77 69 74 68 20 74 68 65 20 73 61 6d  BEs with the sam
3ad0: 65 20 56 64 62 65 2e 64 62 20 2a 2f 0a 20 20 56  e Vdbe.db */.  V
3ae0: 64 62 65 43 75 72 73 6f 72 20 2a 2a 61 70 43 73  dbeCursor **apCs
3af0: 72 3b 20 20 20 20 20 2f 2a 20 4f 6e 65 20 65 6c  r;     /* One el
3b00: 65 6d 65 6e 74 20 6f 66 20 74 68 69 73 20 61 72  ement of this ar
3b10: 72 61 79 20 66 6f 72 20 65 61 63 68 20 6f 70 65  ray for each ope
3b20: 6e 20 63 75 72 73 6f 72 20 2a 2f 0a 20 20 4d 65  n cursor */.  Me
3b30: 6d 20 2a 61 56 61 72 3b 20 20 20 20 20 20 20 20  m *aVar;        
3b40: 20 20 20 20 20 20 2f 2a 20 56 61 6c 75 65 73 20        /* Values 
3b50: 66 6f 72 20 74 68 65 20 4f 50 5f 56 61 72 69 61  for the OP_Varia
3b60: 62 6c 65 20 6f 70 63 6f 64 65 2e 20 2a 2f 0a 20  ble opcode. */. 
3b70: 20 63 68 61 72 20 2a 2a 61 7a 56 61 72 3b 20 20   char **azVar;  
3b80: 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 61 6d 65           /* Name
3b90: 20 6f 66 20 76 61 72 69 61 62 6c 65 73 20 2a 2f   of variables */
3ba0: 0a 20 20 79 6e 56 61 72 20 6e 56 61 72 3b 20 20  .  ynVar nVar;  
3bb0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 75             /* Nu
3bc0: 6d 62 65 72 20 6f 66 20 65 6e 74 72 69 65 73 20  mber of entries 
3bd0: 69 6e 20 61 56 61 72 5b 5d 20 2a 2f 0a 20 20 79  in aVar[] */.  y
3be0: 6e 56 61 72 20 6e 7a 56 61 72 3b 20 20 20 20 20  nVar nzVar;     
3bf0: 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72         /* Number
3c00: 20 6f 66 20 65 6e 74 72 69 65 73 20 69 6e 20 61   of entries in a
3c10: 7a 56 61 72 5b 5d 20 2a 2f 0a 20 20 75 33 32 20  zVar[] */.  u32 
3c20: 63 61 63 68 65 43 74 72 3b 20 20 20 20 20 20 20  cacheCtr;       
3c30: 20 20 20 20 2f 2a 20 56 64 62 65 43 75 72 73 6f      /* VdbeCurso
3c40: 72 20 72 6f 77 20 63 61 63 68 65 20 67 65 6e 65  r row cache gene
3c50: 72 61 74 69 6f 6e 20 63 6f 75 6e 74 65 72 20 2a  ration counter *
3c60: 2f 0a 20 20 69 6e 74 20 70 63 3b 20 20 20 20 20  /.  int pc;     
3c70: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54              /* T
3c80: 68 65 20 70 72 6f 67 72 61 6d 20 63 6f 75 6e 74  he program count
3c90: 65 72 20 2a 2f 0a 20 20 69 6e 74 20 72 63 3b 20  er */.  int rc; 
3ca0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3cb0: 2f 2a 20 56 61 6c 75 65 20 74 6f 20 72 65 74 75  /* Value to retu
3cc0: 72 6e 20 2a 2f 0a 23 69 66 64 65 66 20 53 51 4c  rn */.#ifdef SQL
3cd0: 49 54 45 5f 44 45 42 55 47 0a 20 20 69 6e 74 20  ITE_DEBUG.  int 
3ce0: 72 63 41 70 70 3b 20 20 20 20 20 20 20 20 20 20  rcApp;          
3cf0: 20 20 20 20 2f 2a 20 65 72 72 63 6f 64 65 20 73      /* errcode s
3d00: 65 74 20 62 79 20 73 71 6c 69 74 65 33 5f 72 65  et by sqlite3_re
3d10: 73 75 6c 74 5f 65 72 72 6f 72 5f 63 6f 64 65 28  sult_error_code(
3d20: 29 20 2a 2f 0a 23 65 6e 64 69 66 0a 20 20 75 31  ) */.#endif.  u1
3d30: 36 20 6e 52 65 73 43 6f 6c 75 6d 6e 3b 20 20 20  6 nResColumn;   
3d40: 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20        /* Number 
3d50: 6f 66 20 63 6f 6c 75 6d 6e 73 20 69 6e 20 6f 6e  of columns in on
3d60: 65 20 72 6f 77 20 6f 66 20 74 68 65 20 72 65 73  e row of the res
3d70: 75 6c 74 20 73 65 74 20 2a 2f 0a 20 20 75 38 20  ult set */.  u8 
3d80: 65 72 72 6f 72 41 63 74 69 6f 6e 3b 20 20 20 20  errorAction;    
3d90: 20 20 20 20 20 2f 2a 20 52 65 63 6f 76 65 72 79       /* Recovery
3da0: 20 61 63 74 69 6f 6e 20 74 6f 20 64 6f 20 69 6e   action to do in
3db0: 20 63 61 73 65 20 6f 66 20 61 6e 20 65 72 72 6f   case of an erro
3dc0: 72 20 2a 2f 0a 20 20 75 38 20 6d 69 6e 57 72 69  r */.  u8 minWri
3dd0: 74 65 46 69 6c 65 46 6f 72 6d 61 74 3b 20 20 2f  teFileFormat;  /
3de0: 2a 20 4d 69 6e 69 6d 75 6d 20 66 69 6c 65 20 66  * Minimum file f
3df0: 6f 72 6d 61 74 20 66 6f 72 20 77 72 69 74 61 62  ormat for writab
3e00: 6c 65 20 64 61 74 61 62 61 73 65 20 66 69 6c 65  le database file
3e10: 73 20 2a 2f 0a 20 20 62 66 74 20 65 78 70 6c 61  s */.  bft expla
3e20: 69 6e 3a 32 3b 20 20 20 20 20 20 20 20 20 20 2f  in:2;          /
3e30: 2a 20 54 72 75 65 20 69 66 20 45 58 50 4c 41 49  * True if EXPLAI
3e40: 4e 20 70 72 65 73 65 6e 74 20 6f 6e 20 53 51 4c  N present on SQL
3e50: 20 63 6f 6d 6d 61 6e 64 20 2a 2f 0a 20 20 62 66   command */.  bf
3e60: 74 20 63 68 61 6e 67 65 43 6e 74 4f 6e 3a 31 3b  t changeCntOn:1;
3e70: 20 20 20 20 20 20 2f 2a 20 54 72 75 65 20 74 6f        /* True to
3e80: 20 75 70 64 61 74 65 20 74 68 65 20 63 68 61 6e   update the chan
3e90: 67 65 2d 63 6f 75 6e 74 65 72 20 2a 2f 0a 20 20  ge-counter */.  
3ea0: 62 66 74 20 65 78 70 69 72 65 64 3a 31 3b 20 20  bft expired:1;  
3eb0: 20 20 20 20 20 20 20 20 2f 2a 20 54 72 75 65 20          /* True 
3ec0: 69 66 20 74 68 65 20 56 4d 20 6e 65 65 64 73 20  if the VM needs 
3ed0: 74 6f 20 62 65 20 72 65 63 6f 6d 70 69 6c 65 64  to be recompiled
3ee0: 20 2a 2f 0a 20 20 62 66 74 20 72 75 6e 4f 6e 6c   */.  bft runOnl
3ef0: 79 4f 6e 63 65 3a 31 3b 20 20 20 20 20 20 2f 2a  yOnce:1;      /*
3f00: 20 41 75 74 6f 6d 61 74 69 63 61 6c 6c 79 20 65   Automatically e
3f10: 78 70 69 72 65 20 6f 6e 20 72 65 73 65 74 20 2a  xpire on reset *
3f20: 2f 0a 20 20 62 66 74 20 75 73 65 73 53 74 6d 74  /.  bft usesStmt
3f30: 4a 6f 75 72 6e 61 6c 3a 31 3b 20 20 2f 2a 20 54  Journal:1;  /* T
3f40: 72 75 65 20 69 66 20 75 73 65 73 20 61 20 73 74  rue if uses a st
3f50: 61 74 65 6d 65 6e 74 20 6a 6f 75 72 6e 61 6c 20  atement journal 
3f60: 2a 2f 0a 20 20 62 66 74 20 72 65 61 64 4f 6e 6c  */.  bft readOnl
3f70: 79 3a 31 3b 20 20 20 20 20 20 20 20 20 2f 2a 20  y:1;         /* 
3f80: 54 72 75 65 20 66 6f 72 20 73 74 61 74 65 6d 65  True for stateme
3f90: 6e 74 73 20 74 68 61 74 20 64 6f 20 6e 6f 74 20  nts that do not 
3fa0: 77 72 69 74 65 20 2a 2f 0a 20 20 62 66 74 20 62  write */.  bft b
3fb0: 49 73 52 65 61 64 65 72 3a 31 3b 20 20 20 20 20  IsReader:1;     
3fc0: 20 20 20 2f 2a 20 54 72 75 65 20 66 6f 72 20 73     /* True for s
3fd0: 74 61 74 65 6d 65 6e 74 73 20 74 68 61 74 20 72  tatements that r
3fe0: 65 61 64 20 2a 2f 0a 20 20 62 66 74 20 69 73 50  ead */.  bft isP
3ff0: 72 65 70 61 72 65 56 32 3a 31 3b 20 20 20 20 20  repareV2:1;     
4000: 20 2f 2a 20 54 72 75 65 20 69 66 20 70 72 65 70   /* True if prep
4010: 61 72 65 64 20 77 69 74 68 20 70 72 65 70 61 72  ared with prepar
4020: 65 5f 76 32 28 29 20 2a 2f 0a 20 20 62 66 74 20  e_v2() */.  bft 
4030: 64 6f 69 6e 67 52 65 72 75 6e 3a 31 3b 20 20 20  doingRerun:1;   
4040: 20 20 20 20 2f 2a 20 54 72 75 65 20 69 66 20 72      /* True if r
4050: 65 72 75 6e 6e 69 6e 67 20 61 66 74 65 72 20 61  erunning after a
4060: 6e 20 61 75 74 6f 2d 72 65 70 72 65 70 61 72 65  n auto-reprepare
4070: 20 2a 2f 0a 20 20 69 6e 74 20 6e 43 68 61 6e 67   */.  int nChang
4080: 65 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  e;            /*
4090: 20 4e 75 6d 62 65 72 20 6f 66 20 64 62 20 63 68   Number of db ch
40a0: 61 6e 67 65 73 20 6d 61 64 65 20 73 69 6e 63 65  anges made since
40b0: 20 6c 61 73 74 20 72 65 73 65 74 20 2a 2f 0a 20   last reset */. 
40c0: 20 79 44 62 4d 61 73 6b 20 62 74 72 65 65 4d 61   yDbMask btreeMa
40d0: 73 6b 3b 20 20 20 20 20 20 2f 2a 20 42 69 74 6d  sk;      /* Bitm
40e0: 61 73 6b 20 6f 66 20 64 62 2d 3e 61 44 62 5b 5d  ask of db->aDb[]
40f0: 20 65 6e 74 72 69 65 73 20 72 65 66 65 72 65 6e   entries referen
4100: 63 65 64 20 2a 2f 0a 20 20 79 44 62 4d 61 73 6b  ced */.  yDbMask
4110: 20 6c 6f 63 6b 4d 61 73 6b 3b 20 20 20 20 20 20   lockMask;      
4120: 20 2f 2a 20 53 75 62 73 65 74 20 6f 66 20 62 74   /* Subset of bt
4130: 72 65 65 4d 61 73 6b 20 74 68 61 74 20 72 65 71  reeMask that req
4140: 75 69 72 65 73 20 61 20 6c 6f 63 6b 20 2a 2f 0a  uires a lock */.
4150: 20 20 69 6e 74 20 69 53 74 61 74 65 6d 65 6e 74    int iStatement
4160: 3b 20 20 20 20 20 20 20 20 20 2f 2a 20 53 74 61  ;         /* Sta
4170: 74 65 6d 65 6e 74 20 6e 75 6d 62 65 72 20 28 6f  tement number (o
4180: 72 20 30 20 69 66 20 68 61 73 20 6e 6f 74 20 6f  r 0 if has not o
4190: 70 65 6e 65 64 20 73 74 6d 74 29 20 2a 2f 0a 20  pened stmt) */. 
41a0: 20 75 33 32 20 61 43 6f 75 6e 74 65 72 5b 35 5d   u32 aCounter[5]
41b0: 3b 20 20 20 20 20 20 20 20 2f 2a 20 43 6f 75 6e  ;        /* Coun
41c0: 74 65 72 73 20 75 73 65 64 20 62 79 20 73 71 6c  ters used by sql
41d0: 69 74 65 33 5f 73 74 6d 74 5f 73 74 61 74 75 73  ite3_stmt_status
41e0: 28 29 20 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51  () */.#ifndef SQ
41f0: 4c 49 54 45 5f 4f 4d 49 54 5f 54 52 41 43 45 0a  LITE_OMIT_TRACE.
4200: 20 20 69 36 34 20 73 74 61 72 74 54 69 6d 65 3b    i64 startTime;
4210: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 69 6d            /* Tim
4220: 65 20 77 68 65 6e 20 71 75 65 72 79 20 73 74 61  e when query sta
4230: 72 74 65 64 20 2d 20 75 73 65 64 20 66 6f 72 20  rted - used for 
4240: 70 72 6f 66 69 6c 69 6e 67 20 2a 2f 0a 23 65 6e  profiling */.#en
4250: 64 69 66 0a 20 20 69 36 34 20 69 43 75 72 72 65  dif.  i64 iCurre
4260: 6e 74 54 69 6d 65 3b 20 20 20 20 20 20 20 2f 2a  ntTime;       /*
4270: 20 56 61 6c 75 65 20 6f 66 20 6a 75 6c 69 61 6e   Value of julian
4280: 64 61 79 28 27 6e 6f 77 27 29 20 66 6f 72 20 74  day('now') for t
4290: 68 69 73 20 73 74 61 74 65 6d 65 6e 74 20 2a 2f  his statement */
42a0: 0a 20 20 69 36 34 20 6e 46 6b 43 6f 6e 73 74 72  .  i64 nFkConstr
42b0: 61 69 6e 74 3b 20 20 20 20 20 20 2f 2a 20 4e 75  aint;      /* Nu
42c0: 6d 62 65 72 20 6f 66 20 69 6d 6d 2e 20 46 4b 20  mber of imm. FK 
42d0: 63 6f 6e 73 74 72 61 69 6e 74 73 20 74 68 69 73  constraints this
42e0: 20 56 4d 20 2a 2f 0a 20 20 69 36 34 20 6e 53 74   VM */.  i64 nSt
42f0: 6d 74 44 65 66 43 6f 6e 73 3b 20 20 20 20 20 20  mtDefCons;      
4300: 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 64 65   /* Number of de
4310: 66 2e 20 63 6f 6e 73 74 72 61 69 6e 74 73 20 77  f. constraints w
4320: 68 65 6e 20 73 74 6d 74 20 73 74 61 72 74 65 64  hen stmt started
4330: 20 2a 2f 0a 20 20 69 36 34 20 6e 53 74 6d 74 44   */.  i64 nStmtD
4340: 65 66 49 6d 6d 43 6f 6e 73 3b 20 20 20 20 2f 2a  efImmCons;    /*
4350: 20 4e 75 6d 62 65 72 20 6f 66 20 64 65 66 2e 20   Number of def. 
4360: 69 6d 6d 20 63 6f 6e 73 74 72 61 69 6e 74 73 20  imm constraints 
4370: 77 68 65 6e 20 73 74 6d 74 20 73 74 61 72 74 65  when stmt starte
4380: 64 20 2a 2f 0a 20 20 63 68 61 72 20 2a 7a 53 71  d */.  char *zSq
4390: 6c 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  l;             /
43a0: 2a 20 54 65 78 74 20 6f 66 20 74 68 65 20 53 51  * Text of the SQ
43b0: 4c 20 73 74 61 74 65 6d 65 6e 74 20 74 68 61 74  L statement that
43c0: 20 67 65 6e 65 72 61 74 65 64 20 74 68 69 73 20   generated this 
43d0: 2a 2f 0a 20 20 76 6f 69 64 20 2a 70 46 72 65 65  */.  void *pFree
43e0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20  ;            /* 
43f0: 46 72 65 65 20 74 68 69 73 20 77 68 65 6e 20 64  Free this when d
4400: 65 6c 65 74 69 6e 67 20 74 68 65 20 76 64 62 65  eleting the vdbe
4410: 20 2a 2f 0a 20 20 56 64 62 65 46 72 61 6d 65 20   */.  VdbeFrame 
4420: 2a 70 46 72 61 6d 65 3b 20 20 20 20 20 20 2f 2a  *pFrame;      /*
4430: 20 50 61 72 65 6e 74 20 66 72 61 6d 65 20 2a 2f   Parent frame */
4440: 0a 20 20 56 64 62 65 46 72 61 6d 65 20 2a 70 44  .  VdbeFrame *pD
4450: 65 6c 46 72 61 6d 65 3b 20 20 20 2f 2a 20 4c 69  elFrame;   /* Li
4460: 73 74 20 6f 66 20 66 72 61 6d 65 20 6f 62 6a 65  st of frame obje
4470: 63 74 73 20 74 6f 20 66 72 65 65 20 6f 6e 20 56  cts to free on V
4480: 4d 20 72 65 73 65 74 20 2a 2f 0a 20 20 69 6e 74  M reset */.  int
4490: 20 6e 46 72 61 6d 65 3b 20 20 20 20 20 20 20 20   nFrame;        
44a0: 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f       /* Number o
44b0: 66 20 66 72 61 6d 65 73 20 69 6e 20 70 46 72 61  f frames in pFra
44c0: 6d 65 20 6c 69 73 74 20 2a 2f 0a 20 20 75 33 32  me list */.  u32
44d0: 20 65 78 70 6d 61 73 6b 3b 20 20 20 20 20 20 20   expmask;       
44e0: 20 20 20 20 20 2f 2a 20 42 69 6e 64 69 6e 67 20       /* Binding 
44f0: 74 6f 20 74 68 65 73 65 20 76 61 72 73 20 69 6e  to these vars in
4500: 76 61 6c 69 64 61 74 65 73 20 56 4d 20 2a 2f 0a  validates VM */.
4510: 20 20 53 75 62 50 72 6f 67 72 61 6d 20 2a 70 50    SubProgram *pP
4520: 72 6f 67 72 61 6d 3b 20 20 20 2f 2a 20 4c 69 6e  rogram;   /* Lin
4530: 6b 65 64 20 6c 69 73 74 20 6f 66 20 61 6c 6c 20  ked list of all 
4540: 73 75 62 2d 70 72 6f 67 72 61 6d 73 20 75 73 65  sub-programs use
4550: 64 20 62 79 20 56 4d 20 2a 2f 0a 20 20 69 6e 74  d by VM */.  int
4560: 20 6e 4f 6e 63 65 46 6c 61 67 3b 20 20 20 20 20   nOnceFlag;     
4570: 20 20 20 20 20 2f 2a 20 53 69 7a 65 20 6f 66 20       /* Size of 
4580: 61 72 72 61 79 20 61 4f 6e 63 65 46 6c 61 67 5b  array aOnceFlag[
4590: 5d 20 2a 2f 0a 20 20 75 38 20 2a 61 4f 6e 63 65  ] */.  u8 *aOnce
45a0: 46 6c 61 67 3b 20 20 20 20 20 20 20 20 20 20 2f  Flag;          /
45b0: 2a 20 46 6c 61 67 73 20 66 6f 72 20 4f 50 5f 4f  * Flags for OP_O
45c0: 6e 63 65 20 2a 2f 0a 20 20 41 75 78 44 61 74 61  nce */.  AuxData
45d0: 20 2a 70 41 75 78 44 61 74 61 3b 20 20 20 20 20   *pAuxData;     
45e0: 20 2f 2a 20 4c 69 6e 6b 65 64 20 6c 69 73 74 20   /* Linked list 
45f0: 6f 66 20 61 75 78 64 61 74 61 20 61 6c 6c 6f 63  of auxdata alloc
4600: 61 74 69 6f 6e 73 20 2a 2f 0a 23 69 66 64 65 66  ations */.#ifdef
4610: 20 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 53   SQLITE_ENABLE_S
4620: 54 4d 54 5f 53 43 41 4e 53 54 41 54 55 53 0a 20  TMT_SCANSTATUS. 
4630: 20 69 36 34 20 2a 61 6e 45 78 65 63 3b 20 20 20   i64 *anExec;   
4640: 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62           /* Numb
4650: 65 72 20 6f 66 20 74 69 6d 65 73 20 65 61 63 68  er of times each
4660: 20 6f 70 20 68 61 73 20 62 65 65 6e 20 65 78 65   op has been exe
4670: 63 75 74 65 64 20 2a 2f 0a 20 20 69 6e 74 20 6e  cuted */.  int n
4680: 53 63 61 6e 3b 20 20 20 20 20 20 20 20 20 20 20  Scan;           
4690: 20 20 20 2f 2a 20 45 6e 74 72 69 65 73 20 69 6e     /* Entries in
46a0: 20 61 53 63 61 6e 5b 5d 20 2a 2f 0a 20 20 53 63   aScan[] */.  Sc
46b0: 61 6e 53 74 61 74 75 73 20 2a 61 53 63 61 6e 3b  anStatus *aScan;
46c0: 20 20 20 20 20 20 2f 2a 20 53 63 61 6e 20 64 65        /* Scan de
46d0: 66 69 6e 69 74 69 6f 6e 73 20 66 6f 72 20 73 71  finitions for sq
46e0: 6c 69 74 65 33 5f 73 74 6d 74 5f 73 63 61 6e 73  lite3_stmt_scans
46f0: 74 61 74 75 73 28 29 20 2a 2f 0a 23 65 6e 64 69  tatus() */.#endi
4700: 66 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20  f.};../*.** The 
4710: 66 6f 6c 6c 6f 77 69 6e 67 20 61 72 65 20 61 6c  following are al
4720: 6c 6f 77 65 64 20 76 61 6c 75 65 73 20 66 6f 72  lowed values for
4730: 20 56 64 62 65 2e 6d 61 67 69 63 0a 2a 2f 0a 23   Vdbe.magic.*/.#
4740: 64 65 66 69 6e 65 20 56 44 42 45 5f 4d 41 47 49  define VDBE_MAGI
4750: 43 5f 49 4e 49 54 20 20 20 20 20 30 78 32 36 62  C_INIT     0x26b
4760: 63 65 61 61 35 20 20 20 20 2f 2a 20 42 75 69 6c  ceaa5    /* Buil
4770: 64 69 6e 67 20 61 20 56 44 42 45 20 70 72 6f 67  ding a VDBE prog
4780: 72 61 6d 20 2a 2f 0a 23 64 65 66 69 6e 65 20 56  ram */.#define V
4790: 44 42 45 5f 4d 41 47 49 43 5f 52 55 4e 20 20 20  DBE_MAGIC_RUN   
47a0: 20 20 20 30 78 62 64 66 32 30 64 61 33 20 20 20     0xbdf20da3   
47b0: 20 2f 2a 20 56 44 42 45 20 69 73 20 72 65 61 64   /* VDBE is read
47c0: 79 20 74 6f 20 65 78 65 63 75 74 65 20 2a 2f 0a  y to execute */.
47d0: 23 64 65 66 69 6e 65 20 56 44 42 45 5f 4d 41 47  #define VDBE_MAG
47e0: 49 43 5f 48 41 4c 54 20 20 20 20 20 30 78 35 31  IC_HALT     0x51
47f0: 39 63 32 39 37 33 20 20 20 20 2f 2a 20 56 44 42  9c2973    /* VDB
4800: 45 20 68 61 73 20 63 6f 6d 70 6c 65 74 65 64 20  E has completed 
4810: 65 78 65 63 75 74 69 6f 6e 20 2a 2f 0a 23 64 65  execution */.#de
4820: 66 69 6e 65 20 56 44 42 45 5f 4d 41 47 49 43 5f  fine VDBE_MAGIC_
4830: 44 45 41 44 20 20 20 20 20 30 78 62 36 30 36 63  DEAD     0xb606c
4840: 33 63 38 20 20 20 20 2f 2a 20 54 68 65 20 56 44  3c8    /* The VD
4850: 42 45 20 68 61 73 20 62 65 65 6e 20 64 65 61 6c  BE has been deal
4860: 6c 6f 63 61 74 65 64 20 2a 2f 0a 0a 2f 2a 0a 2a  located */../*.*
4870: 2a 20 46 75 6e 63 74 69 6f 6e 20 70 72 6f 74 6f  * Function proto
4880: 74 79 70 65 73 0a 2a 2f 0a 76 6f 69 64 20 73 71  types.*/.void sq
4890: 6c 69 74 65 33 56 64 62 65 46 72 65 65 43 75 72  lite3VdbeFreeCur
48a0: 73 6f 72 28 56 64 62 65 20 2a 2c 20 56 64 62 65  sor(Vdbe *, Vdbe
48b0: 43 75 72 73 6f 72 2a 29 3b 0a 76 6f 69 64 20 73  Cursor*);.void s
48c0: 71 6c 69 74 65 56 64 62 65 50 6f 70 53 74 61 63  qliteVdbePopStac
48d0: 6b 28 56 64 62 65 2a 2c 69 6e 74 29 3b 0a 69 6e  k(Vdbe*,int);.in
48e0: 74 20 73 71 6c 69 74 65 33 56 64 62 65 43 75 72  t sqlite3VdbeCur
48f0: 73 6f 72 4d 6f 76 65 74 6f 28 56 64 62 65 43 75  sorMoveto(VdbeCu
4900: 72 73 6f 72 2a 29 3b 0a 69 6e 74 20 73 71 6c 69  rsor*);.int sqli
4910: 74 65 33 56 64 62 65 43 75 72 73 6f 72 52 65 73  te3VdbeCursorRes
4920: 74 6f 72 65 28 56 64 62 65 43 75 72 73 6f 72 2a  tore(VdbeCursor*
4930: 29 3b 0a 23 69 66 20 64 65 66 69 6e 65 64 28 53  );.#if defined(S
4940: 51 4c 49 54 45 5f 44 45 42 55 47 29 20 7c 7c 20  QLITE_DEBUG) || 
4950: 64 65 66 69 6e 65 64 28 56 44 42 45 5f 50 52 4f  defined(VDBE_PRO
4960: 46 49 4c 45 29 0a 76 6f 69 64 20 73 71 6c 69 74  FILE).void sqlit
4970: 65 33 56 64 62 65 50 72 69 6e 74 4f 70 28 46 49  e3VdbePrintOp(FI
4980: 4c 45 2a 2c 20 69 6e 74 2c 20 4f 70 2a 29 3b 0a  LE*, int, Op*);.
4990: 23 65 6e 64 69 66 0a 75 33 32 20 73 71 6c 69 74  #endif.u32 sqlit
49a0: 65 33 56 64 62 65 53 65 72 69 61 6c 54 79 70 65  e3VdbeSerialType
49b0: 4c 65 6e 28 75 33 32 29 3b 0a 75 33 32 20 73 71  Len(u32);.u32 sq
49c0: 6c 69 74 65 33 56 64 62 65 53 65 72 69 61 6c 54  lite3VdbeSerialT
49d0: 79 70 65 28 4d 65 6d 2a 2c 20 69 6e 74 29 3b 0a  ype(Mem*, int);.
49e0: 75 33 32 20 73 71 6c 69 74 65 33 56 64 62 65 53  u32 sqlite3VdbeS
49f0: 65 72 69 61 6c 50 75 74 28 75 6e 73 69 67 6e 65  erialPut(unsigne
4a00: 64 20 63 68 61 72 2a 2c 20 4d 65 6d 2a 2c 20 75  d char*, Mem*, u
4a10: 33 32 29 3b 0a 75 33 32 20 73 71 6c 69 74 65 33  32);.u32 sqlite3
4a20: 56 64 62 65 53 65 72 69 61 6c 47 65 74 28 63 6f  VdbeSerialGet(co
4a30: 6e 73 74 20 75 6e 73 69 67 6e 65 64 20 63 68 61  nst unsigned cha
4a40: 72 2a 2c 20 75 33 32 2c 20 4d 65 6d 2a 29 3b 0a  r*, u32, Mem*);.
4a50: 76 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62 65  void sqlite3Vdbe
4a60: 44 65 6c 65 74 65 41 75 78 44 61 74 61 28 56 64  DeleteAuxData(Vd
4a70: 62 65 2a 2c 20 69 6e 74 2c 20 69 6e 74 29 3b 0a  be*, int, int);.
4a80: 0a 69 6e 74 20 73 71 6c 69 74 65 32 42 74 72 65  .int sqlite2Btre
4a90: 65 4b 65 79 43 6f 6d 70 61 72 65 28 42 74 43 75  eKeyCompare(BtCu
4aa0: 72 73 6f 72 20 2a 2c 20 63 6f 6e 73 74 20 76 6f  rsor *, const vo
4ab0: 69 64 20 2a 2c 20 69 6e 74 2c 20 69 6e 74 2c 20  id *, int, int, 
4ac0: 69 6e 74 20 2a 29 3b 0a 69 6e 74 20 73 71 6c 69  int *);.int sqli
4ad0: 74 65 33 56 64 62 65 49 64 78 4b 65 79 43 6f 6d  te3VdbeIdxKeyCom
4ae0: 70 61 72 65 28 73 71 6c 69 74 65 33 2a 2c 56 64  pare(sqlite3*,Vd
4af0: 62 65 43 75 72 73 6f 72 2a 2c 55 6e 70 61 63 6b  beCursor*,Unpack
4b00: 65 64 52 65 63 6f 72 64 2a 2c 69 6e 74 2a 29 3b  edRecord*,int*);
4b10: 0a 69 6e 74 20 73 71 6c 69 74 65 33 56 64 62 65  .int sqlite3Vdbe
4b20: 49 64 78 52 6f 77 69 64 28 73 71 6c 69 74 65 33  IdxRowid(sqlite3
4b30: 2a 2c 20 42 74 43 75 72 73 6f 72 2a 2c 20 69 36  *, BtCursor*, i6
4b40: 34 2a 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33  4*);.int sqlite3
4b50: 56 64 62 65 45 78 65 63 28 56 64 62 65 2a 29 3b  VdbeExec(Vdbe*);
4b60: 0a 69 6e 74 20 73 71 6c 69 74 65 33 56 64 62 65  .int sqlite3Vdbe
4b70: 4c 69 73 74 28 56 64 62 65 2a 29 3b 0a 69 6e 74  List(Vdbe*);.int
4b80: 20 73 71 6c 69 74 65 33 56 64 62 65 48 61 6c 74   sqlite3VdbeHalt
4b90: 28 56 64 62 65 2a 29 3b 0a 69 6e 74 20 73 71 6c  (Vdbe*);.int sql
4ba0: 69 74 65 33 56 64 62 65 43 68 61 6e 67 65 45 6e  ite3VdbeChangeEn
4bb0: 63 6f 64 69 6e 67 28 4d 65 6d 20 2a 2c 20 69 6e  coding(Mem *, in
4bc0: 74 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 56  t);.int sqlite3V
4bd0: 64 62 65 4d 65 6d 54 6f 6f 42 69 67 28 4d 65 6d  dbeMemTooBig(Mem
4be0: 2a 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 56  *);.int sqlite3V
4bf0: 64 62 65 4d 65 6d 43 6f 70 79 28 4d 65 6d 2a 2c  dbeMemCopy(Mem*,
4c00: 20 63 6f 6e 73 74 20 4d 65 6d 2a 29 3b 0a 76 6f   const Mem*);.vo
4c10: 69 64 20 73 71 6c 69 74 65 33 56 64 62 65 4d 65  id sqlite3VdbeMe
4c20: 6d 53 68 61 6c 6c 6f 77 43 6f 70 79 28 4d 65 6d  mShallowCopy(Mem
4c30: 2a 2c 20 63 6f 6e 73 74 20 4d 65 6d 2a 2c 20 69  *, const Mem*, i
4c40: 6e 74 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74 65  nt);.void sqlite
4c50: 33 56 64 62 65 4d 65 6d 4d 6f 76 65 28 4d 65 6d  3VdbeMemMove(Mem
4c60: 2a 2c 20 4d 65 6d 2a 29 3b 0a 69 6e 74 20 73 71  *, Mem*);.int sq
4c70: 6c 69 74 65 33 56 64 62 65 4d 65 6d 4e 75 6c 54  lite3VdbeMemNulT
4c80: 65 72 6d 69 6e 61 74 65 28 4d 65 6d 2a 29 3b 0a  erminate(Mem*);.
4c90: 69 6e 74 20 73 71 6c 69 74 65 33 56 64 62 65 4d  int sqlite3VdbeM
4ca0: 65 6d 53 65 74 53 74 72 28 4d 65 6d 2a 2c 20 63  emSetStr(Mem*, c
4cb0: 6f 6e 73 74 20 63 68 61 72 2a 2c 20 69 6e 74 2c  onst char*, int,
4cc0: 20 75 38 2c 20 76 6f 69 64 28 2a 29 28 76 6f 69   u8, void(*)(voi
4cd0: 64 2a 29 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74  d*));.void sqlit
4ce0: 65 33 56 64 62 65 4d 65 6d 53 65 74 49 6e 74 36  e3VdbeMemSetInt6
4cf0: 34 28 4d 65 6d 2a 2c 20 69 36 34 29 3b 0a 23 69  4(Mem*, i64);.#i
4d00: 66 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54  fdef SQLITE_OMIT
4d10: 5f 46 4c 4f 41 54 49 4e 47 5f 50 4f 49 4e 54 0a  _FLOATING_POINT.
4d20: 23 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65 33  # define sqlite3
4d30: 56 64 62 65 4d 65 6d 53 65 74 44 6f 75 62 6c 65  VdbeMemSetDouble
4d40: 20 73 71 6c 69 74 65 33 56 64 62 65 4d 65 6d 53   sqlite3VdbeMemS
4d50: 65 74 49 6e 74 36 34 0a 23 65 6c 73 65 0a 20 20  etInt64.#else.  
4d60: 76 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62 65  void sqlite3Vdbe
4d70: 4d 65 6d 53 65 74 44 6f 75 62 6c 65 28 4d 65 6d  MemSetDouble(Mem
4d80: 2a 2c 20 64 6f 75 62 6c 65 29 3b 0a 23 65 6e 64  *, double);.#end
4d90: 69 66 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 56  if.void sqlite3V
4da0: 64 62 65 4d 65 6d 49 6e 69 74 28 4d 65 6d 2a 2c  dbeMemInit(Mem*,
4db0: 73 71 6c 69 74 65 33 2a 2c 75 31 36 29 3b 0a 76  sqlite3*,u16);.v
4dc0: 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62 65 4d  oid sqlite3VdbeM
4dd0: 65 6d 53 65 74 4e 75 6c 6c 28 4d 65 6d 2a 29 3b  emSetNull(Mem*);
4de0: 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62  .void sqlite3Vdb
4df0: 65 4d 65 6d 53 65 74 5a 65 72 6f 42 6c 6f 62 28  eMemSetZeroBlob(
4e00: 4d 65 6d 2a 2c 69 6e 74 29 3b 0a 76 6f 69 64 20  Mem*,int);.void 
4e10: 73 71 6c 69 74 65 33 56 64 62 65 4d 65 6d 53 65  sqlite3VdbeMemSe
4e20: 74 52 6f 77 53 65 74 28 4d 65 6d 2a 29 3b 0a 69  tRowSet(Mem*);.i
4e30: 6e 74 20 73 71 6c 69 74 65 33 56 64 62 65 4d 65  nt sqlite3VdbeMe
4e40: 6d 4d 61 6b 65 57 72 69 74 65 61 62 6c 65 28 4d  mMakeWriteable(M
4e50: 65 6d 2a 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65  em*);.int sqlite
4e60: 33 56 64 62 65 4d 65 6d 53 74 72 69 6e 67 69 66  3VdbeMemStringif
4e70: 79 28 4d 65 6d 2a 2c 20 75 38 2c 20 75 38 29 3b  y(Mem*, u8, u8);
4e80: 0a 69 36 34 20 73 71 6c 69 74 65 33 56 64 62 65  .i64 sqlite3Vdbe
4e90: 49 6e 74 56 61 6c 75 65 28 4d 65 6d 2a 29 3b 0a  IntValue(Mem*);.
4ea0: 69 6e 74 20 73 71 6c 69 74 65 33 56 64 62 65 4d  int sqlite3VdbeM
4eb0: 65 6d 49 6e 74 65 67 65 72 69 66 79 28 4d 65 6d  emIntegerify(Mem
4ec0: 2a 29 3b 0a 64 6f 75 62 6c 65 20 73 71 6c 69 74  *);.double sqlit
4ed0: 65 33 56 64 62 65 52 65 61 6c 56 61 6c 75 65 28  e3VdbeRealValue(
4ee0: 4d 65 6d 2a 29 3b 0a 76 6f 69 64 20 73 71 6c 69  Mem*);.void sqli
4ef0: 74 65 33 56 64 62 65 49 6e 74 65 67 65 72 41 66  te3VdbeIntegerAf
4f00: 66 69 6e 69 74 79 28 4d 65 6d 2a 29 3b 0a 69 6e  finity(Mem*);.in
4f10: 74 20 73 71 6c 69 74 65 33 56 64 62 65 4d 65 6d  t sqlite3VdbeMem
4f20: 52 65 61 6c 69 66 79 28 4d 65 6d 2a 29 3b 0a 69  Realify(Mem*);.i
4f30: 6e 74 20 73 71 6c 69 74 65 33 56 64 62 65 4d 65  nt sqlite3VdbeMe
4f40: 6d 4e 75 6d 65 72 69 66 79 28 4d 65 6d 2a 29 3b  mNumerify(Mem*);
4f50: 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62  .void sqlite3Vdb
4f60: 65 4d 65 6d 43 61 73 74 28 4d 65 6d 2a 2c 75 38  eMemCast(Mem*,u8
4f70: 2c 75 38 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65  ,u8);.int sqlite
4f80: 33 56 64 62 65 4d 65 6d 46 72 6f 6d 42 74 72 65  3VdbeMemFromBtre
4f90: 65 28 42 74 43 75 72 73 6f 72 2a 2c 75 33 32 2c  e(BtCursor*,u32,
4fa0: 75 33 32 2c 69 6e 74 2c 4d 65 6d 2a 29 3b 0a 76  u32,int,Mem*);.v
4fb0: 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62 65 4d  oid sqlite3VdbeM
4fc0: 65 6d 52 65 6c 65 61 73 65 28 4d 65 6d 20 2a 70  emRelease(Mem *p
4fd0: 29 3b 0a 23 64 65 66 69 6e 65 20 56 64 62 65 4d  );.#define VdbeM
4fe0: 65 6d 44 79 6e 61 6d 69 63 28 58 29 20 20 5c 0a  emDynamic(X)  \.
4ff0: 20 20 28 28 28 58 29 2d 3e 66 6c 61 67 73 26 28    (((X)->flags&(
5000: 4d 45 4d 5f 41 67 67 7c 4d 45 4d 5f 44 79 6e 7c  MEM_Agg|MEM_Dyn|
5010: 4d 45 4d 5f 52 6f 77 53 65 74 7c 4d 45 4d 5f 46  MEM_RowSet|MEM_F
5020: 72 61 6d 65 29 29 21 3d 30 29 0a 69 6e 74 20 73  rame))!=0).int s
5030: 71 6c 69 74 65 33 56 64 62 65 4d 65 6d 46 69 6e  qlite3VdbeMemFin
5040: 61 6c 69 7a 65 28 4d 65 6d 2a 2c 20 46 75 6e 63  alize(Mem*, Func
5050: 44 65 66 2a 29 3b 0a 63 6f 6e 73 74 20 63 68 61  Def*);.const cha
5060: 72 20 2a 73 71 6c 69 74 65 33 4f 70 63 6f 64 65  r *sqlite3Opcode
5070: 4e 61 6d 65 28 69 6e 74 29 3b 0a 69 6e 74 20 73  Name(int);.int s
5080: 71 6c 69 74 65 33 56 64 62 65 4d 65 6d 47 72 6f  qlite3VdbeMemGro
5090: 77 28 4d 65 6d 20 2a 70 4d 65 6d 2c 20 69 6e 74  w(Mem *pMem, int
50a0: 20 6e 2c 20 69 6e 74 20 70 72 65 73 65 72 76 65   n, int preserve
50b0: 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 56 64  );.int sqlite3Vd
50c0: 62 65 4d 65 6d 43 6c 65 61 72 41 6e 64 52 65 73  beMemClearAndRes
50d0: 69 7a 65 28 4d 65 6d 20 2a 70 4d 65 6d 2c 20 69  ize(Mem *pMem, i
50e0: 6e 74 20 6e 29 3b 0a 69 6e 74 20 73 71 6c 69 74  nt n);.int sqlit
50f0: 65 33 56 64 62 65 43 6c 6f 73 65 53 74 61 74 65  e3VdbeCloseState
5100: 6d 65 6e 74 28 56 64 62 65 20 2a 2c 20 69 6e 74  ment(Vdbe *, int
5110: 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 56  );.void sqlite3V
5120: 64 62 65 46 72 61 6d 65 44 65 6c 65 74 65 28 56  dbeFrameDelete(V
5130: 64 62 65 46 72 61 6d 65 2a 29 3b 0a 69 6e 74 20  dbeFrame*);.int 
5140: 73 71 6c 69 74 65 33 56 64 62 65 46 72 61 6d 65  sqlite3VdbeFrame
5150: 52 65 73 74 6f 72 65 28 56 64 62 65 46 72 61 6d  Restore(VdbeFram
5160: 65 20 2a 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65  e *);.int sqlite
5170: 33 56 64 62 65 54 72 61 6e 73 66 65 72 45 72 72  3VdbeTransferErr
5180: 6f 72 28 56 64 62 65 20 2a 70 29 3b 0a 0a 69 6e  or(Vdbe *p);..in
5190: 74 20 73 71 6c 69 74 65 33 56 64 62 65 53 6f 72  t sqlite3VdbeSor
51a0: 74 65 72 49 6e 69 74 28 73 71 6c 69 74 65 33 20  terInit(sqlite3 
51b0: 2a 2c 20 69 6e 74 2c 20 56 64 62 65 43 75 72 73  *, int, VdbeCurs
51c0: 6f 72 20 2a 29 3b 0a 76 6f 69 64 20 73 71 6c 69  or *);.void sqli
51d0: 74 65 33 56 64 62 65 53 6f 72 74 65 72 52 65 73  te3VdbeSorterRes
51e0: 65 74 28 73 71 6c 69 74 65 33 20 2a 2c 20 56 64  et(sqlite3 *, Vd
51f0: 62 65 53 6f 72 74 65 72 20 2a 29 3b 0a 76 6f 69  beSorter *);.voi
5200: 64 20 73 71 6c 69 74 65 33 56 64 62 65 53 6f 72  d sqlite3VdbeSor
5210: 74 65 72 43 6c 6f 73 65 28 73 71 6c 69 74 65 33  terClose(sqlite3
5220: 20 2a 2c 20 56 64 62 65 43 75 72 73 6f 72 20 2a   *, VdbeCursor *
5230: 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 56 64  );.int sqlite3Vd
5240: 62 65 53 6f 72 74 65 72 52 6f 77 6b 65 79 28 63  beSorterRowkey(c
5250: 6f 6e 73 74 20 56 64 62 65 43 75 72 73 6f 72 20  onst VdbeCursor 
5260: 2a 2c 20 4d 65 6d 20 2a 29 3b 0a 69 6e 74 20 73  *, Mem *);.int s
5270: 71 6c 69 74 65 33 56 64 62 65 53 6f 72 74 65 72  qlite3VdbeSorter
5280: 4e 65 78 74 28 73 71 6c 69 74 65 33 20 2a 2c 20  Next(sqlite3 *, 
5290: 63 6f 6e 73 74 20 56 64 62 65 43 75 72 73 6f 72  const VdbeCursor
52a0: 20 2a 2c 20 69 6e 74 20 2a 29 3b 0a 69 6e 74 20   *, int *);.int 
52b0: 73 71 6c 69 74 65 33 56 64 62 65 53 6f 72 74 65  sqlite3VdbeSorte
52c0: 72 52 65 77 69 6e 64 28 63 6f 6e 73 74 20 56 64  rRewind(const Vd
52d0: 62 65 43 75 72 73 6f 72 20 2a 2c 20 69 6e 74 20  beCursor *, int 
52e0: 2a 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 56  *);.int sqlite3V
52f0: 64 62 65 53 6f 72 74 65 72 57 72 69 74 65 28 63  dbeSorterWrite(c
5300: 6f 6e 73 74 20 56 64 62 65 43 75 72 73 6f 72 20  onst VdbeCursor 
5310: 2a 2c 20 4d 65 6d 20 2a 29 3b 0a 69 6e 74 20 73  *, Mem *);.int s
5320: 71 6c 69 74 65 33 56 64 62 65 53 6f 72 74 65 72  qlite3VdbeSorter
5330: 43 6f 6d 70 61 72 65 28 63 6f 6e 73 74 20 56 64  Compare(const Vd
5340: 62 65 43 75 72 73 6f 72 20 2a 2c 20 4d 65 6d 20  beCursor *, Mem 
5350: 2a 2c 20 69 6e 74 2c 20 69 6e 74 20 2a 29 3b 0a  *, int, int *);.
5360: 0a 23 69 66 20 21 64 65 66 69 6e 65 64 28 53 51  .#if !defined(SQ
5370: 4c 49 54 45 5f 4f 4d 49 54 5f 53 48 41 52 45 44  LITE_OMIT_SHARED
5380: 5f 43 41 43 48 45 29 20 26 26 20 53 51 4c 49 54  _CACHE) && SQLIT
5390: 45 5f 54 48 52 45 41 44 53 41 46 45 3e 30 0a 20  E_THREADSAFE>0. 
53a0: 20 76 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62   void sqlite3Vdb
53b0: 65 45 6e 74 65 72 28 56 64 62 65 2a 29 3b 0a 20  eEnter(Vdbe*);. 
53c0: 20 76 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62   void sqlite3Vdb
53d0: 65 4c 65 61 76 65 28 56 64 62 65 2a 29 3b 0a 23  eLeave(Vdbe*);.#
53e0: 65 6c 73 65 0a 23 20 64 65 66 69 6e 65 20 73 71  else.# define sq
53f0: 6c 69 74 65 33 56 64 62 65 45 6e 74 65 72 28 58  lite3VdbeEnter(X
5400: 29 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69 74  ).# define sqlit
5410: 65 33 56 64 62 65 4c 65 61 76 65 28 58 29 0a 23  e3VdbeLeave(X).#
5420: 65 6e 64 69 66 0a 0a 23 69 66 64 65 66 20 53 51  endif..#ifdef SQ
5430: 4c 49 54 45 5f 44 45 42 55 47 0a 76 6f 69 64 20  LITE_DEBUG.void 
5440: 73 71 6c 69 74 65 33 56 64 62 65 4d 65 6d 41 62  sqlite3VdbeMemAb
5450: 6f 75 74 54 6f 43 68 61 6e 67 65 28 56 64 62 65  outToChange(Vdbe
5460: 2a 2c 4d 65 6d 2a 29 3b 0a 69 6e 74 20 73 71 6c  *,Mem*);.int sql
5470: 69 74 65 33 56 64 62 65 43 68 65 63 6b 4d 65 6d  ite3VdbeCheckMem
5480: 49 6e 76 61 72 69 61 6e 74 73 28 4d 65 6d 2a 29  Invariants(Mem*)
5490: 3b 0a 23 65 6e 64 69 66 0a 0a 23 69 66 6e 64 65  ;.#endif..#ifnde
54a0: 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 46 4f  f SQLITE_OMIT_FO
54b0: 52 45 49 47 4e 5f 4b 45 59 0a 69 6e 74 20 73 71  REIGN_KEY.int sq
54c0: 6c 69 74 65 33 56 64 62 65 43 68 65 63 6b 46 6b  lite3VdbeCheckFk
54d0: 28 56 64 62 65 20 2a 2c 20 69 6e 74 29 3b 0a 23  (Vdbe *, int);.#
54e0: 65 6c 73 65 0a 23 20 64 65 66 69 6e 65 20 73 71  else.# define sq
54f0: 6c 69 74 65 33 56 64 62 65 43 68 65 63 6b 46 6b  lite3VdbeCheckFk
5500: 28 70 2c 69 29 20 30 0a 23 65 6e 64 69 66 0a 0a  (p,i) 0.#endif..
5510: 69 6e 74 20 73 71 6c 69 74 65 33 56 64 62 65 4d  int sqlite3VdbeM
5520: 65 6d 54 72 61 6e 73 6c 61 74 65 28 4d 65 6d 2a  emTranslate(Mem*
5530: 2c 20 75 38 29 3b 0a 23 69 66 64 65 66 20 53 51  , u8);.#ifdef SQ
5540: 4c 49 54 45 5f 44 45 42 55 47 0a 20 20 76 6f 69  LITE_DEBUG.  voi
5550: 64 20 73 71 6c 69 74 65 33 56 64 62 65 50 72 69  d sqlite3VdbePri
5560: 6e 74 53 71 6c 28 56 64 62 65 2a 29 3b 0a 20 20  ntSql(Vdbe*);.  
5570: 76 6f 69 64 20 73 71 6c 69 74 65 33 56 64 62 65  void sqlite3Vdbe
5580: 4d 65 6d 50 72 65 74 74 79 50 72 69 6e 74 28 4d  MemPrettyPrint(M
5590: 65 6d 20 2a 70 4d 65 6d 2c 20 63 68 61 72 20 2a  em *pMem, char *
55a0: 7a 42 75 66 29 3b 0a 23 65 6e 64 69 66 0a 69 6e  zBuf);.#endif.in
55b0: 74 20 73 71 6c 69 74 65 33 56 64 62 65 4d 65 6d  t sqlite3VdbeMem
55c0: 48 61 6e 64 6c 65 42 6f 6d 28 4d 65 6d 20 2a 70  HandleBom(Mem *p
55d0: 4d 65 6d 29 3b 0a 0a 23 69 66 6e 64 65 66 20 53  Mem);..#ifndef S
55e0: 51 4c 49 54 45 5f 4f 4d 49 54 5f 49 4e 43 52 42  QLITE_OMIT_INCRB
55f0: 4c 4f 42 0a 20 20 69 6e 74 20 73 71 6c 69 74 65  LOB.  int sqlite
5600: 33 56 64 62 65 4d 65 6d 45 78 70 61 6e 64 42 6c  3VdbeMemExpandBl
5610: 6f 62 28 4d 65 6d 20 2a 29 3b 0a 20 20 23 64 65  ob(Mem *);.  #de
5620: 66 69 6e 65 20 45 78 70 61 6e 64 42 6c 6f 62 28  fine ExpandBlob(
5630: 50 29 20 28 28 28 50 29 2d 3e 66 6c 61 67 73 26  P) (((P)->flags&
5640: 4d 45 4d 5f 5a 65 72 6f 29 3f 73 71 6c 69 74 65  MEM_Zero)?sqlite
5650: 33 56 64 62 65 4d 65 6d 45 78 70 61 6e 64 42 6c  3VdbeMemExpandBl
5660: 6f 62 28 50 29 3a 30 29 0a 23 65 6c 73 65 0a 20  ob(P):0).#else. 
5670: 20 23 64 65 66 69 6e 65 20 73 71 6c 69 74 65 33   #define sqlite3
5680: 56 64 62 65 4d 65 6d 45 78 70 61 6e 64 42 6c 6f  VdbeMemExpandBlo
5690: 62 28 78 29 20 53 51 4c 49 54 45 5f 4f 4b 0a 20  b(x) SQLITE_OK. 
56a0: 20 23 64 65 66 69 6e 65 20 45 78 70 61 6e 64 42   #define ExpandB
56b0: 6c 6f 62 28 50 29 20 53 51 4c 49 54 45 5f 4f 4b  lob(P) SQLITE_OK
56c0: 0a 23 65 6e 64 69 66 0a 0a 23 65 6e 64 69 66 20  .#endif..#endif 
56d0: 2f 2a 20 21 64 65 66 69 6e 65 64 28 5f 56 44 42  /* !defined(_VDB
56e0: 45 49 4e 54 5f 48 5f 29 20 2a 2f 0a              EINT_H_) */.