/ Hex Artifact Content
Login

Artifact d2ce598db7398acb82d65e99e7a917d5318dc702:


0000: 2f 2a 0a 2a 2a 20 32 30 30 34 20 4d 61 79 20 32  /*.** 2004 May 2
0010: 36 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74 68  6.**.** The auth
0020: 6f 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70  or disclaims cop
0030: 79 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73  yright to this s
0040: 6f 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20  ource code.  In 
0050: 70 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c 65  place of.** a le
0060: 67 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65  gal notice, here
0070: 20 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a   is a blessing:.
0080: 2a 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f 75  **.**    May you
0090: 20 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74   do good and not
00a0: 20 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61 79   evil..**    May
00b0: 20 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69 76   you find forgiv
00c0: 65 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73 65  eness for yourse
00d0: 6c 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20 6f  lf and forgive o
00e0: 74 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61 79  thers..**    May
00f0: 20 79 6f 75 20 73 68 61 72 65 20 66 72 65 65 6c   you share freel
0100: 79 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67 20  y, never taking 
0110: 6d 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67 69  more than you gi
0120: 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ve..**.*********
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: 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20 66 69 6c 65  .**.** This file
0180: 20 63 6f 6e 74 61 69 6e 73 20 63 6f 64 65 20 75   contains code u
0190: 73 65 20 74 6f 20 69 6d 70 6c 65 6d 65 6e 74 20  se to implement 
01a0: 41 50 49 73 20 74 68 61 74 20 61 72 65 20 70 61  APIs that are pa
01b0: 72 74 20 6f 66 20 74 68 65 0a 2a 2a 20 56 44 42  rt of the.** VDB
01c0: 45 2e 0a 2a 2f 0a 23 69 6e 63 6c 75 64 65 20 22  E..*/.#include "
01d0: 73 71 6c 69 74 65 49 6e 74 2e 68 22 0a 23 69 6e  sqliteInt.h".#in
01e0: 63 6c 75 64 65 20 22 76 64 62 65 49 6e 74 2e 68  clude "vdbeInt.h
01f0: 22 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f  ".#ifdef SQLITE_
0200: 45 4e 41 42 4c 45 5f 53 51 4c 52 52 0a 23 20 69  ENABLE_SQLRR.# i
0210: 6e 63 6c 75 64 65 20 22 73 71 6c 72 72 2e 68 22  nclude "sqlrr.h"
0220: 0a 23 65 6e 64 69 66 20 0a 0a 23 69 66 6e 64 65  .#endif ..#ifnde
0230: 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 44 45  f SQLITE_OMIT_DE
0240: 50 52 45 43 41 54 45 44 0a 2f 2a 0a 2a 2a 20 52  PRECATED./*.** R
0250: 65 74 75 72 6e 20 54 52 55 45 20 28 6e 6f 6e 2d  eturn TRUE (non-
0260: 7a 65 72 6f 29 20 6f 66 20 74 68 65 20 73 74 61  zero) of the sta
0270: 74 65 6d 65 6e 74 20 73 75 70 70 6c 69 65 64 20  tement supplied 
0280: 61 73 20 61 6e 20 61 72 67 75 6d 65 6e 74 20 6e  as an argument n
0290: 65 65 64 73 0a 2a 2a 20 74 6f 20 62 65 20 72 65  eeds.** to be re
02a0: 63 6f 6d 70 69 6c 65 64 2e 20 20 41 20 73 74 61  compiled.  A sta
02b0: 74 65 6d 65 6e 74 20 6e 65 65 64 73 20 74 6f 20  tement needs to 
02c0: 62 65 20 72 65 63 6f 6d 70 69 6c 65 64 20 77 68  be recompiled wh
02d0: 65 6e 65 76 65 72 20 74 68 65 0a 2a 2a 20 65 78  enever the.** ex
02e0: 65 63 75 74 69 6f 6e 20 65 6e 76 69 72 6f 6e 6d  ecution environm
02f0: 65 6e 74 20 63 68 61 6e 67 65 73 20 69 6e 20 61  ent changes in a
0300: 20 77 61 79 20 74 68 61 74 20 77 6f 75 6c 64 20   way that would 
0310: 61 6c 74 65 72 20 74 68 65 20 70 72 6f 67 72 61  alter the progra
0320: 6d 0a 2a 2a 20 74 68 61 74 20 73 71 6c 69 74 65  m.** that sqlite
0330: 33 5f 70 72 65 70 61 72 65 28 29 20 67 65 6e 65  3_prepare() gene
0340: 72 61 74 65 73 2e 20 20 46 6f 72 20 65 78 61 6d  rates.  For exam
0350: 70 6c 65 2c 20 69 66 20 6e 65 77 20 66 75 6e 63  ple, if new func
0360: 74 69 6f 6e 73 20 6f 72 0a 2a 2a 20 63 6f 6c 6c  tions or.** coll
0370: 61 74 69 6e 67 20 73 65 71 75 65 6e 63 65 73 20  ating sequences 
0380: 61 72 65 20 72 65 67 69 73 74 65 72 65 64 20 6f  are registered o
0390: 72 20 69 66 20 61 6e 20 61 75 74 68 6f 72 69 7a  r if an authoriz
03a0: 65 72 20 66 75 6e 63 74 69 6f 6e 20 69 73 0a 2a  er function is.*
03b0: 2a 20 61 64 64 65 64 20 6f 72 20 63 68 61 6e 67  * added or chang
03c0: 65 64 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74  ed..*/.int sqlit
03d0: 65 33 5f 65 78 70 69 72 65 64 28 73 71 6c 69 74  e3_expired(sqlit
03e0: 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d 74 29 7b  e3_stmt *pStmt){
03f0: 0a 20 20 56 64 62 65 20 2a 70 20 3d 20 28 56 64  .  Vdbe *p = (Vd
0400: 62 65 2a 29 70 53 74 6d 74 3b 0a 20 20 72 65 74  be*)pStmt;.  ret
0410: 75 72 6e 20 70 3d 3d 30 20 7c 7c 20 70 2d 3e 65  urn p==0 || p->e
0420: 78 70 69 72 65 64 3b 0a 7d 0a 23 65 6e 64 69 66  xpired;.}.#endif
0430: 0a 0a 2f 2a 0a 2a 2a 20 43 68 65 63 6b 20 6f 6e  ../*.** Check on
0440: 20 61 20 56 64 62 65 20 74 6f 20 6d 61 6b 65 20   a Vdbe to make 
0450: 73 75 72 65 20 69 74 20 68 61 73 20 6e 6f 74 20  sure it has not 
0460: 62 65 65 6e 20 66 69 6e 61 6c 69 7a 65 64 2e 20  been finalized. 
0470: 20 4c 6f 67 0a 2a 2a 20 61 6e 20 65 72 72 6f 72   Log.** an error
0480: 20 61 6e 64 20 72 65 74 75 72 6e 20 74 72 75 65   and return true
0490: 20 69 66 20 69 74 20 68 61 73 20 62 65 65 6e 20   if it has been 
04a0: 66 69 6e 61 6c 69 7a 65 64 20 28 6f 72 20 69 73  finalized (or is
04b0: 20 6f 74 68 65 72 77 69 73 65 0a 2a 2a 20 69 6e   otherwise.** in
04c0: 76 61 6c 69 64 29 2e 20 20 52 65 74 75 72 6e 20  valid).  Return 
04d0: 66 61 6c 73 65 20 69 66 20 69 74 20 69 73 20 6f  false if it is o
04e0: 6b 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74  k..*/.static int
04f0: 20 76 64 62 65 53 61 66 65 74 79 28 56 64 62 65   vdbeSafety(Vdbe
0500: 20 2a 70 29 7b 0a 20 20 73 71 6c 69 74 65 33 2a   *p){.  sqlite3*
0510: 20 64 62 20 3d 20 70 2d 3e 64 62 3b 0a 20 20 69   db = p->db;.  i
0520: 66 28 28 64 62 3d 3d 30 29 20 7c 7c 20 28 64 62  f((db==0) || (db
0530: 2d 3e 6d 61 67 69 63 20 21 3d 20 53 51 4c 49 54  ->magic != SQLIT
0540: 45 5f 4d 41 47 49 43 5f 4f 50 45 4e 29 20 7c 7c  E_MAGIC_OPEN) ||
0550: 20 28 28 70 2d 3e 6d 61 67 69 63 20 21 3d 20 56   ((p->magic != V
0560: 44 42 45 5f 4d 41 47 49 43 5f 52 55 4e 29 20 26  DBE_MAGIC_RUN) &
0570: 26 20 28 70 2d 3e 6d 61 67 69 63 20 21 3d 20 56  & (p->magic != V
0580: 44 42 45 5f 4d 41 47 49 43 5f 48 41 4c 54 29 29  DBE_MAGIC_HALT))
0590: 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 6c  ){.    sqlite3_l
05a0: 6f 67 28 53 51 4c 49 54 45 5f 4d 49 53 55 53 45  og(SQLITE_MISUSE
05b0: 2c 20 22 41 50 49 20 63 61 6c 6c 65 64 20 77 69  , "API called wi
05c0: 74 68 20 66 69 6e 61 6c 69 7a 65 64 20 70 72 65  th finalized pre
05d0: 70 61 72 65 64 20 73 74 61 74 65 6d 65 6e 74 22  pared statement"
05e0: 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20 31 3b  );.    return 1;
05f0: 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 72 65  .  }else{.    re
0600: 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 7d 0a 73 74  turn 0;.  }.}.st
0610: 61 74 69 63 20 69 6e 74 20 76 64 62 65 53 61 66  atic int vdbeSaf
0620: 65 74 79 4e 6f 74 4e 75 6c 6c 28 56 64 62 65 20  etyNotNull(Vdbe 
0630: 2a 70 29 7b 0a 20 20 69 66 28 20 70 3d 3d 30 20  *p){.  if( p==0 
0640: 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 6c  ){.    sqlite3_l
0650: 6f 67 28 53 51 4c 49 54 45 5f 4d 49 53 55 53 45  og(SQLITE_MISUSE
0660: 2c 20 22 41 50 49 20 63 61 6c 6c 65 64 20 77 69  , "API called wi
0670: 74 68 20 4e 55 4c 4c 20 70 72 65 70 61 72 65 64  th NULL prepared
0680: 20 73 74 61 74 65 6d 65 6e 74 22 29 3b 0a 20 20   statement");.  
0690: 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 7d 65    return 1;.  }e
06a0: 6c 73 65 7b 0a 20 20 20 20 72 65 74 75 72 6e 20  lse{.    return 
06b0: 76 64 62 65 53 61 66 65 74 79 28 70 29 3b 0a 20  vdbeSafety(p);. 
06c0: 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20   }.}../*.** The 
06d0: 66 6f 6c 6c 6f 77 69 6e 67 20 72 6f 75 74 69 6e  following routin
06e0: 65 20 64 65 73 74 72 6f 79 73 20 61 20 76 69 72  e destroys a vir
06f0: 74 75 61 6c 20 6d 61 63 68 69 6e 65 20 74 68 61  tual machine tha
0700: 74 20 69 73 20 63 72 65 61 74 65 64 20 62 79 0a  t is created by.
0710: 2a 2a 20 74 68 65 20 73 71 6c 69 74 65 33 5f 63  ** the sqlite3_c
0720: 6f 6d 70 69 6c 65 28 29 20 72 6f 75 74 69 6e 65  ompile() routine
0730: 2e 20 54 68 65 20 69 6e 74 65 67 65 72 20 72 65  . The integer re
0740: 74 75 72 6e 65 64 20 69 73 20 61 6e 20 53 51 4c  turned is an SQL
0750: 49 54 45 5f 0a 2a 2a 20 73 75 63 63 65 73 73 2f  ITE_.** success/
0760: 66 61 69 6c 75 72 65 20 63 6f 64 65 20 74 68 61  failure code tha
0770: 74 20 64 65 73 63 72 69 62 65 73 20 74 68 65 20  t describes the 
0780: 72 65 73 75 6c 74 20 6f 66 20 65 78 65 63 75 74  result of execut
0790: 69 6e 67 20 74 68 65 20 76 69 72 74 75 61 6c 0a  ing the virtual.
07a0: 2a 2a 20 6d 61 63 68 69 6e 65 2e 0a 2a 2a 0a 2a  ** machine..**.*
07b0: 2a 20 54 68 69 73 20 72 6f 75 74 69 6e 65 20 73  * This routine s
07c0: 65 74 73 20 74 68 65 20 65 72 72 6f 72 20 63 6f  ets the error co
07d0: 64 65 20 61 6e 64 20 73 74 72 69 6e 67 20 72 65  de and string re
07e0: 74 75 72 6e 65 64 20 62 79 0a 2a 2a 20 73 71 6c  turned by.** sql
07f0: 69 74 65 33 5f 65 72 72 63 6f 64 65 28 29 2c 20  ite3_errcode(), 
0800: 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 28 29  sqlite3_errmsg()
0810: 20 61 6e 64 20 73 71 6c 69 74 65 33 5f 65 72 72   and sqlite3_err
0820: 6d 73 67 31 36 28 29 2e 0a 2a 2f 0a 69 6e 74 20  msg16()..*/.int 
0830: 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65  sqlite3_finalize
0840: 28 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70  (sqlite3_stmt *p
0850: 53 74 6d 74 29 7b 0a 20 20 69 6e 74 20 72 63 3b  Stmt){.  int rc;
0860: 0a 20 20 69 66 28 20 70 53 74 6d 74 3d 3d 30 20  .  if( pStmt==0 
0870: 29 7b 0a 20 20 20 20 2f 2a 20 49 4d 50 4c 45 4d  ){.    /* IMPLEM
0880: 45 4e 54 41 54 49 4f 4e 2d 4f 46 3a 20 52 2d 35  ENTATION-OF: R-5
0890: 37 32 32 38 2d 31 32 39 30 34 20 49 6e 76 6f 6b  7228-12904 Invok
08a0: 69 6e 67 20 73 71 6c 69 74 65 33 5f 66 69 6e 61  ing sqlite3_fina
08b0: 6c 69 7a 65 28 29 20 6f 6e 20 61 20 4e 55 4c 4c  lize() on a NULL
08c0: 0a 20 20 20 20 2a 2a 20 70 6f 69 6e 74 65 72 20  .    ** pointer 
08d0: 69 73 20 61 20 68 61 72 6d 6c 65 73 73 20 6e 6f  is a harmless no
08e0: 2d 6f 70 2e 20 2a 2f 0a 20 20 20 20 72 63 20 3d  -op. */.    rc =
08f0: 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 7d 65   SQLITE_OK;.  }e
0900: 6c 73 65 7b 0a 20 20 20 20 56 64 62 65 20 2a 76  lse{.    Vdbe *v
0910: 20 3d 20 28 56 64 62 65 2a 29 70 53 74 6d 74 3b   = (Vdbe*)pStmt;
0920: 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 45  .#ifdef SQLITE_E
0930: 4e 41 42 4c 45 5f 53 51 4c 52 52 0a 20 20 20 20  NABLE_SQLRR.    
0940: 53 52 52 65 63 46 69 6e 61 6c 69 7a 65 28 70 53  SRRecFinalize(pS
0950: 74 6d 74 29 3b 0a 23 65 6e 64 69 66 0a 20 20 20  tmt);.#endif.   
0960: 20 73 71 6c 69 74 65 33 20 2a 64 62 20 3d 20 76   sqlite3 *db = v
0970: 2d 3e 64 62 3b 0a 23 69 66 20 53 51 4c 49 54 45  ->db;.#if SQLITE
0980: 5f 54 48 52 45 41 44 53 41 46 45 0a 20 20 20 20  _THREADSAFE.    
0990: 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 20 2a 6d  sqlite3_mutex *m
09a0: 75 74 65 78 3b 0a 23 65 6e 64 69 66 0a 20 20 20  utex;.#endif.   
09b0: 20 69 66 28 20 76 64 62 65 53 61 66 65 74 79 28   if( vdbeSafety(
09c0: 76 29 20 29 20 72 65 74 75 72 6e 20 53 51 4c 49  v) ) return SQLI
09d0: 54 45 5f 4d 49 53 55 53 45 5f 42 4b 50 54 3b 0a  TE_MISUSE_BKPT;.
09e0: 23 69 66 20 53 51 4c 49 54 45 5f 54 48 52 45 41  #if SQLITE_THREA
09f0: 44 53 41 46 45 0a 20 20 20 20 6d 75 74 65 78 20  DSAFE.    mutex 
0a00: 3d 20 76 2d 3e 64 62 2d 3e 6d 75 74 65 78 3b 0a  = v->db->mutex;.
0a10: 23 65 6e 64 69 66 0a 20 20 20 20 73 71 6c 69 74  #endif.    sqlit
0a20: 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28 6d  e3_mutex_enter(m
0a30: 75 74 65 78 29 3b 0a 20 20 20 20 72 63 20 3d 20  utex);.    rc = 
0a40: 73 71 6c 69 74 65 33 56 64 62 65 46 69 6e 61 6c  sqlite3VdbeFinal
0a50: 69 7a 65 28 76 29 3b 0a 20 20 20 20 72 63 20 3d  ize(v);.    rc =
0a60: 20 73 71 6c 69 74 65 33 41 70 69 45 78 69 74 28   sqlite3ApiExit(
0a70: 64 62 2c 20 72 63 29 3b 0a 20 20 20 20 73 71 6c  db, rc);.    sql
0a80: 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65  ite3_mutex_leave
0a90: 28 6d 75 74 65 78 29 3b 0a 20 20 7d 0a 20 20 72  (mutex);.  }.  r
0aa0: 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a  eturn rc;.}../*.
0ab0: 2a 2a 20 54 65 72 6d 69 6e 61 74 65 20 74 68 65  ** Terminate the
0ac0: 20 63 75 72 72 65 6e 74 20 65 78 65 63 75 74 69   current executi
0ad0: 6f 6e 20 6f 66 20 61 6e 20 53 51 4c 20 73 74 61  on of an SQL sta
0ae0: 74 65 6d 65 6e 74 20 61 6e 64 20 72 65 73 65 74  tement and reset
0af0: 20 69 74 0a 2a 2a 20 62 61 63 6b 20 74 6f 20 69   it.** back to i
0b00: 74 73 20 73 74 61 72 74 69 6e 67 20 73 74 61 74  ts starting stat
0b10: 65 20 73 6f 20 74 68 61 74 20 69 74 20 63 61 6e  e so that it can
0b20: 20 62 65 20 72 65 75 73 65 64 2e 20 41 20 73 75   be reused. A su
0b30: 63 63 65 73 73 20 63 6f 64 65 20 66 72 6f 6d 0a  ccess code from.
0b40: 2a 2a 20 74 68 65 20 70 72 69 6f 72 20 65 78 65  ** the prior exe
0b50: 63 75 74 69 6f 6e 20 69 73 20 72 65 74 75 72 6e  cution is return
0b60: 65 64 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20 72  ed..**.** This r
0b70: 6f 75 74 69 6e 65 20 73 65 74 73 20 74 68 65 20  outine sets the 
0b80: 65 72 72 6f 72 20 63 6f 64 65 20 61 6e 64 20 73  error code and s
0b90: 74 72 69 6e 67 20 72 65 74 75 72 6e 65 64 20 62  tring returned b
0ba0: 79 0a 2a 2a 20 73 71 6c 69 74 65 33 5f 65 72 72  y.** sqlite3_err
0bb0: 63 6f 64 65 28 29 2c 20 73 71 6c 69 74 65 33 5f  code(), sqlite3_
0bc0: 65 72 72 6d 73 67 28 29 20 61 6e 64 20 73 71 6c  errmsg() and sql
0bd0: 69 74 65 33 5f 65 72 72 6d 73 67 31 36 28 29 2e  ite3_errmsg16().
0be0: 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f  .*/.int sqlite3_
0bf0: 72 65 73 65 74 28 73 71 6c 69 74 65 33 5f 73 74  reset(sqlite3_st
0c00: 6d 74 20 2a 70 53 74 6d 74 29 7b 0a 20 20 69 6e  mt *pStmt){.  in
0c10: 74 20 72 63 3b 0a 20 20 69 66 28 20 70 53 74 6d  t rc;.  if( pStm
0c20: 74 3d 3d 30 20 29 7b 0a 20 20 20 20 72 63 20 3d  t==0 ){.    rc =
0c30: 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 7d 65   SQLITE_OK;.  }e
0c40: 6c 73 65 7b 0a 20 20 20 20 56 64 62 65 20 2a 76  lse{.    Vdbe *v
0c50: 20 3d 20 28 56 64 62 65 2a 29 70 53 74 6d 74 3b   = (Vdbe*)pStmt;
0c60: 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 45  .#ifdef SQLITE_E
0c70: 4e 41 42 4c 45 5f 53 51 4c 52 52 0a 20 20 20 20  NABLE_SQLRR.    
0c80: 53 52 52 65 63 52 65 73 65 74 28 70 53 74 6d 74  SRRecReset(pStmt
0c90: 29 3b 0a 23 65 6e 64 69 66 0a 20 20 20 20 73 71  );.#endif.    sq
0ca0: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65  lite3_mutex_ente
0cb0: 72 28 76 2d 3e 64 62 2d 3e 6d 75 74 65 78 29 3b  r(v->db->mutex);
0cc0: 0a 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65  .    rc = sqlite
0cd0: 33 56 64 62 65 52 65 73 65 74 28 76 29 3b 0a 20  3VdbeReset(v);. 
0ce0: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 52 65     sqlite3VdbeRe
0cf0: 77 69 6e 64 28 76 29 3b 0a 20 20 20 20 61 73 73  wind(v);.    ass
0d00: 65 72 74 28 20 28 72 63 20 26 20 28 76 2d 3e 64  ert( (rc & (v->d
0d10: 62 2d 3e 65 72 72 4d 61 73 6b 29 29 3d 3d 72 63  b->errMask))==rc
0d20: 20 29 3b 0a 20 20 20 20 72 63 20 3d 20 73 71 6c   );.    rc = sql
0d30: 69 74 65 33 41 70 69 45 78 69 74 28 76 2d 3e 64  ite3ApiExit(v->d
0d40: 62 2c 20 72 63 29 3b 0a 20 20 20 20 73 71 6c 69  b, rc);.    sqli
0d50: 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28  te3_mutex_leave(
0d60: 76 2d 3e 64 62 2d 3e 6d 75 74 65 78 29 3b 0a 20  v->db->mutex);. 
0d70: 20 7d 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a   }.  return rc;.
0d80: 7d 0a 0a 2f 2a 0a 2a 2a 20 53 65 74 20 61 6c 6c  }../*.** Set all
0d90: 20 74 68 65 20 70 61 72 61 6d 65 74 65 72 73 20   the parameters 
0da0: 69 6e 20 74 68 65 20 63 6f 6d 70 69 6c 65 64 20  in the compiled 
0db0: 53 51 4c 20 73 74 61 74 65 6d 65 6e 74 20 74 6f  SQL statement to
0dc0: 20 4e 55 4c 4c 2e 0a 2a 2f 0a 69 6e 74 20 73 71   NULL..*/.int sq
0dd0: 6c 69 74 65 33 5f 63 6c 65 61 72 5f 62 69 6e 64  lite3_clear_bind
0de0: 69 6e 67 73 28 73 71 6c 69 74 65 33 5f 73 74 6d  ings(sqlite3_stm
0df0: 74 20 2a 70 53 74 6d 74 29 7b 0a 20 20 69 6e 74  t *pStmt){.  int
0e00: 20 69 3b 0a 20 20 69 6e 74 20 72 63 20 3d 20 53   i;.  int rc = S
0e10: 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 56 64 62 65  QLITE_OK;.  Vdbe
0e20: 20 2a 70 20 3d 20 28 56 64 62 65 2a 29 70 53 74   *p = (Vdbe*)pSt
0e30: 6d 74 3b 0a 23 69 66 20 53 51 4c 49 54 45 5f 54  mt;.#if SQLITE_T
0e40: 48 52 45 41 44 53 41 46 45 0a 20 20 73 71 6c 69  HREADSAFE.  sqli
0e50: 74 65 33 5f 6d 75 74 65 78 20 2a 6d 75 74 65 78  te3_mutex *mutex
0e60: 3d 4e 55 4c 4c 3b 0a 23 65 6e 64 69 66 0a 20 20  =NULL;.#endif.  
0e70: 69 66 28 20 4e 55 4c 4c 3d 3d 70 53 74 6d 74 20  if( NULL==pStmt 
0e80: 29 7b 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45  ){ return SQLITE
0e90: 5f 4f 4b 3b 20 7d 20 2f 2a 20 3c 72 64 61 72 3a  _OK; } /* <rdar:
0ea0: 2f 2f 70 72 6f 62 6c 65 6d 2f 36 36 34 36 33 33  //problem/664633
0eb0: 31 3e 20 2a 2f 0a 23 69 66 64 65 66 20 53 51 4c  1> */.#ifdef SQL
0ec0: 49 54 45 5f 45 4e 41 42 4c 45 5f 53 51 4c 52 52  ITE_ENABLE_SQLRR
0ed0: 0a 20 20 53 52 52 65 63 43 6c 65 61 72 42 69 6e  .  SRRecClearBin
0ee0: 64 69 6e 67 73 28 70 53 74 6d 74 29 3b 20 20 0a  dings(pStmt);  .
0ef0: 23 65 6e 64 69 66 0a 23 69 66 20 53 51 4c 49 54  #endif.#if SQLIT
0f00: 45 5f 54 48 52 45 41 44 53 41 46 45 0a 20 20 6d  E_THREADSAFE.  m
0f10: 75 74 65 78 20 3d 20 28 28 56 64 62 65 2a 29 70  utex = ((Vdbe*)p
0f20: 53 74 6d 74 29 2d 3e 64 62 2d 3e 6d 75 74 65 78  Stmt)->db->mutex
0f30: 3b 0a 23 65 6e 64 69 66 0a 20 20 73 71 6c 69 74  ;.#endif.  sqlit
0f40: 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28 6d  e3_mutex_enter(m
0f50: 75 74 65 78 29 3b 0a 20 20 66 6f 72 28 69 3d 30  utex);.  for(i=0
0f60: 3b 20 69 3c 70 2d 3e 6e 56 61 72 3b 20 69 2b 2b  ; i<p->nVar; i++
0f70: 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 56 64  ){.    sqlite3Vd
0f80: 62 65 4d 65 6d 52 65 6c 65 61 73 65 28 26 70 2d  beMemRelease(&p-
0f90: 3e 61 56 61 72 5b 69 5d 29 3b 0a 20 20 20 20 70  >aVar[i]);.    p
0fa0: 2d 3e 61 56 61 72 5b 69 5d 2e 66 6c 61 67 73 20  ->aVar[i].flags 
0fb0: 3d 20 4d 45 4d 5f 4e 75 6c 6c 3b 0a 20 20 7d 0a  = MEM_Null;.  }.
0fc0: 20 20 69 66 28 20 70 2d 3e 69 73 50 72 65 70 61    if( p->isPrepa
0fd0: 72 65 56 32 20 26 26 20 70 2d 3e 65 78 70 6d 61  reV2 && p->expma
0fe0: 73 6b 20 29 7b 0a 20 20 20 20 70 2d 3e 65 78 70  sk ){.    p->exp
0ff0: 69 72 65 64 20 3d 20 31 3b 0a 20 20 7d 0a 20 20  ired = 1;.  }.  
1000: 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65  sqlite3_mutex_le
1010: 61 76 65 28 6d 75 74 65 78 29 3b 0a 20 20 72 65  ave(mutex);.  re
1020: 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 0a 2f 2a 2a  turn rc;.}.../**
1030: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
1040: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 20 73 71 6c 69 74  ********** sqlit
1050: 65 33 5f 76 61 6c 75 65 5f 20 20 2a 2a 2a 2a 2a  e3_value_  *****
1060: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
1070: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 0a 2a 2a 20 54 68  **********.** Th
1080: 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 72 6f 75 74  e following rout
1090: 69 6e 65 73 20 65 78 74 72 61 63 74 20 69 6e 66  ines extract inf
10a0: 6f 72 6d 61 74 69 6f 6e 20 66 72 6f 6d 20 61 20  ormation from a 
10b0: 4d 65 6d 20 6f 72 20 73 71 6c 69 74 65 33 5f 76  Mem or sqlite3_v
10c0: 61 6c 75 65 0a 2a 2a 20 73 74 72 75 63 74 75 72  alue.** structur
10d0: 65 2e 0a 2a 2f 0a 63 6f 6e 73 74 20 76 6f 69 64  e..*/.const void
10e0: 20 2a 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f   *sqlite3_value_
10f0: 62 6c 6f 62 28 73 71 6c 69 74 65 33 5f 76 61 6c  blob(sqlite3_val
1100: 75 65 20 2a 70 56 61 6c 29 7b 0a 20 20 4d 65 6d  ue *pVal){.  Mem
1110: 20 2a 70 20 3d 20 28 4d 65 6d 2a 29 70 56 61 6c   *p = (Mem*)pVal
1120: 3b 0a 20 20 69 66 28 20 70 2d 3e 66 6c 61 67 73  ;.  if( p->flags
1130: 20 26 20 28 4d 45 4d 5f 42 6c 6f 62 7c 4d 45 4d   & (MEM_Blob|MEM
1140: 5f 53 74 72 29 20 29 7b 0a 20 20 20 20 73 71 6c  _Str) ){.    sql
1150: 69 74 65 33 56 64 62 65 4d 65 6d 45 78 70 61 6e  ite3VdbeMemExpan
1160: 64 42 6c 6f 62 28 70 29 3b 0a 20 20 20 20 70 2d  dBlob(p);.    p-
1170: 3e 66 6c 61 67 73 20 26 3d 20 7e 4d 45 4d 5f 53  >flags &= ~MEM_S
1180: 74 72 3b 0a 20 20 20 20 70 2d 3e 66 6c 61 67 73  tr;.    p->flags
1190: 20 7c 3d 20 4d 45 4d 5f 42 6c 6f 62 3b 0a 20 20   |= MEM_Blob;.  
11a0: 20 20 72 65 74 75 72 6e 20 70 2d 3e 6e 20 3f 20    return p->n ? 
11b0: 70 2d 3e 7a 20 3a 20 30 3b 0a 20 20 7d 65 6c 73  p->z : 0;.  }els
11c0: 65 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 73 71  e{.    return sq
11d0: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74  lite3_value_text
11e0: 28 70 56 61 6c 29 3b 0a 20 20 7d 0a 7d 0a 69 6e  (pVal);.  }.}.in
11f0: 74 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f  t sqlite3_value_
1200: 62 79 74 65 73 28 73 71 6c 69 74 65 33 5f 76 61  bytes(sqlite3_va
1210: 6c 75 65 20 2a 70 56 61 6c 29 7b 0a 20 20 72 65  lue *pVal){.  re
1220: 74 75 72 6e 20 73 71 6c 69 74 65 33 56 61 6c 75  turn sqlite3Valu
1230: 65 42 79 74 65 73 28 70 56 61 6c 2c 20 53 51 4c  eBytes(pVal, SQL
1240: 49 54 45 5f 55 54 46 38 29 3b 0a 7d 0a 69 6e 74  ITE_UTF8);.}.int
1250: 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 62   sqlite3_value_b
1260: 79 74 65 73 31 36 28 73 71 6c 69 74 65 33 5f 76  ytes16(sqlite3_v
1270: 61 6c 75 65 20 2a 70 56 61 6c 29 7b 0a 20 20 72  alue *pVal){.  r
1280: 65 74 75 72 6e 20 73 71 6c 69 74 65 33 56 61 6c  eturn sqlite3Val
1290: 75 65 42 79 74 65 73 28 70 56 61 6c 2c 20 53 51  ueBytes(pVal, SQ
12a0: 4c 49 54 45 5f 55 54 46 31 36 4e 41 54 49 56 45  LITE_UTF16NATIVE
12b0: 29 3b 0a 7d 0a 64 6f 75 62 6c 65 20 73 71 6c 69  );.}.double sqli
12c0: 74 65 33 5f 76 61 6c 75 65 5f 64 6f 75 62 6c 65  te3_value_double
12d0: 28 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 20 2a  (sqlite3_value *
12e0: 70 56 61 6c 29 7b 0a 20 20 72 65 74 75 72 6e 20  pVal){.  return 
12f0: 73 71 6c 69 74 65 33 56 64 62 65 52 65 61 6c 56  sqlite3VdbeRealV
1300: 61 6c 75 65 28 28 4d 65 6d 2a 29 70 56 61 6c 29  alue((Mem*)pVal)
1310: 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f  ;.}.int sqlite3_
1320: 76 61 6c 75 65 5f 69 6e 74 28 73 71 6c 69 74 65  value_int(sqlite
1330: 33 5f 76 61 6c 75 65 20 2a 70 56 61 6c 29 7b 0a  3_value *pVal){.
1340: 20 20 72 65 74 75 72 6e 20 28 69 6e 74 29 73 71    return (int)sq
1350: 6c 69 74 65 33 56 64 62 65 49 6e 74 56 61 6c 75  lite3VdbeIntValu
1360: 65 28 28 4d 65 6d 2a 29 70 56 61 6c 29 3b 0a 7d  e((Mem*)pVal);.}
1370: 0a 73 71 6c 69 74 65 5f 69 6e 74 36 34 20 73 71  .sqlite_int64 sq
1380: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74 36  lite3_value_int6
1390: 34 28 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 20  4(sqlite3_value 
13a0: 2a 70 56 61 6c 29 7b 0a 20 20 72 65 74 75 72 6e  *pVal){.  return
13b0: 20 73 71 6c 69 74 65 33 56 64 62 65 49 6e 74 56   sqlite3VdbeIntV
13c0: 61 6c 75 65 28 28 4d 65 6d 2a 29 70 56 61 6c 29  alue((Mem*)pVal)
13d0: 3b 0a 7d 0a 63 6f 6e 73 74 20 75 6e 73 69 67 6e  ;.}.const unsign
13e0: 65 64 20 63 68 61 72 20 2a 73 71 6c 69 74 65 33  ed char *sqlite3
13f0: 5f 76 61 6c 75 65 5f 74 65 78 74 28 73 71 6c 69  _value_text(sqli
1400: 74 65 33 5f 76 61 6c 75 65 20 2a 70 56 61 6c 29  te3_value *pVal)
1410: 7b 0a 20 20 72 65 74 75 72 6e 20 28 63 6f 6e 73  {.  return (cons
1420: 74 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20  t unsigned char 
1430: 2a 29 73 71 6c 69 74 65 33 56 61 6c 75 65 54 65  *)sqlite3ValueTe
1440: 78 74 28 70 56 61 6c 2c 20 53 51 4c 49 54 45 5f  xt(pVal, SQLITE_
1450: 55 54 46 38 29 3b 0a 7d 0a 23 69 66 6e 64 65 66  UTF8);.}.#ifndef
1460: 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 55 54 46   SQLITE_OMIT_UTF
1470: 31 36 0a 63 6f 6e 73 74 20 76 6f 69 64 20 2a 73  16.const void *s
1480: 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 65 78  qlite3_value_tex
1490: 74 31 36 28 73 71 6c 69 74 65 33 5f 76 61 6c 75  t16(sqlite3_valu
14a0: 65 2a 20 70 56 61 6c 29 7b 0a 20 20 72 65 74 75  e* pVal){.  retu
14b0: 72 6e 20 73 71 6c 69 74 65 33 56 61 6c 75 65 54  rn sqlite3ValueT
14c0: 65 78 74 28 70 56 61 6c 2c 20 53 51 4c 49 54 45  ext(pVal, SQLITE
14d0: 5f 55 54 46 31 36 4e 41 54 49 56 45 29 3b 0a 7d  _UTF16NATIVE);.}
14e0: 0a 63 6f 6e 73 74 20 76 6f 69 64 20 2a 73 71 6c  .const void *sql
14f0: 69 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74 31  ite3_value_text1
1500: 36 62 65 28 73 71 6c 69 74 65 33 5f 76 61 6c 75  6be(sqlite3_valu
1510: 65 20 2a 70 56 61 6c 29 7b 0a 20 20 72 65 74 75  e *pVal){.  retu
1520: 72 6e 20 73 71 6c 69 74 65 33 56 61 6c 75 65 54  rn sqlite3ValueT
1530: 65 78 74 28 70 56 61 6c 2c 20 53 51 4c 49 54 45  ext(pVal, SQLITE
1540: 5f 55 54 46 31 36 42 45 29 3b 0a 7d 0a 63 6f 6e  _UTF16BE);.}.con
1550: 73 74 20 76 6f 69 64 20 2a 73 71 6c 69 74 65 33  st void *sqlite3
1560: 5f 76 61 6c 75 65 5f 74 65 78 74 31 36 6c 65 28  _value_text16le(
1570: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 20 2a 70  sqlite3_value *p
1580: 56 61 6c 29 7b 0a 20 20 72 65 74 75 72 6e 20 73  Val){.  return s
1590: 71 6c 69 74 65 33 56 61 6c 75 65 54 65 78 74 28  qlite3ValueText(
15a0: 70 56 61 6c 2c 20 53 51 4c 49 54 45 5f 55 54 46  pVal, SQLITE_UTF
15b0: 31 36 4c 45 29 3b 0a 7d 0a 23 65 6e 64 69 66 20  16LE);.}.#endif 
15c0: 2f 2a 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 55  /* SQLITE_OMIT_U
15d0: 54 46 31 36 20 2a 2f 0a 69 6e 74 20 73 71 6c 69  TF16 */.int sqli
15e0: 74 65 33 5f 76 61 6c 75 65 5f 74 79 70 65 28 73  te3_value_type(s
15f0: 71 6c 69 74 65 33 5f 76 61 6c 75 65 2a 20 70 56  qlite3_value* pV
1600: 61 6c 29 7b 0a 20 20 72 65 74 75 72 6e 20 70 56  al){.  return pV
1610: 61 6c 2d 3e 74 79 70 65 3b 0a 7d 0a 0a 2f 2a 2a  al->type;.}../**
1620: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
1630: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 20 73 71 6c 69 74  ********** sqlit
1640: 65 33 5f 72 65 73 75 6c 74 5f 20 20 2a 2a 2a 2a  e3_result_  ****
1650: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
1660: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 0a 2a 2a 20 54  ***********.** T
1670: 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 72 6f 75  he following rou
1680: 74 69 6e 65 73 20 61 72 65 20 75 73 65 64 20 62  tines are used b
1690: 79 20 75 73 65 72 2d 64 65 66 69 6e 65 64 20 66  y user-defined f
16a0: 75 6e 63 74 69 6f 6e 73 20 74 6f 20 73 70 65 63  unctions to spec
16b0: 69 66 79 0a 2a 2a 20 74 68 65 20 66 75 6e 63 74  ify.** the funct
16c0: 69 6f 6e 20 72 65 73 75 6c 74 2e 0a 2a 2a 0a 2a  ion result..**.*
16d0: 2a 20 54 68 65 20 73 65 74 53 74 72 4f 72 45 72  * The setStrOrEr
16e0: 72 6f 72 28 29 20 66 75 6e 74 69 6f 6e 20 63 61  ror() funtion ca
16f0: 6c 6c 73 20 73 71 6c 69 74 65 33 56 64 62 65 4d  lls sqlite3VdbeM
1700: 65 6d 53 65 74 53 74 72 28 29 20 74 6f 20 73 74  emSetStr() to st
1710: 6f 72 65 20 74 68 65 0a 2a 2a 20 72 65 73 75 6c  ore the.** resul
1720: 74 20 61 73 20 61 20 73 74 72 69 6e 67 20 6f 72  t as a string or
1730: 20 62 6c 6f 62 20 62 75 74 20 69 66 20 74 68 65   blob but if the
1740: 20 73 74 72 69 6e 67 20 6f 72 20 62 6c 6f 62 20   string or blob 
1750: 69 73 20 74 6f 6f 20 6c 61 72 67 65 2c 20 69 74  is too large, it
1760: 0a 2a 2a 20 74 68 65 6e 20 73 65 74 73 20 74 68  .** then sets th
1770: 65 20 65 72 72 6f 72 20 63 6f 64 65 20 74 6f 20  e error code to 
1780: 53 51 4c 49 54 45 5f 54 4f 4f 42 49 47 0a 2a 2f  SQLITE_TOOBIG.*/
1790: 0a 73 74 61 74 69 63 20 76 6f 69 64 20 73 65 74  .static void set
17a0: 52 65 73 75 6c 74 53 74 72 4f 72 45 72 72 6f 72  ResultStrOrError
17b0: 28 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74  (.  sqlite3_cont
17c0: 65 78 74 20 2a 70 43 74 78 2c 20 20 2f 2a 20 46  ext *pCtx,  /* F
17d0: 75 6e 63 74 69 6f 6e 20 63 6f 6e 74 65 78 74 20  unction context 
17e0: 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20  */.  const char 
17f0: 2a 7a 2c 20 20 20 20 20 20 20 20 20 20 2f 2a 20  *z,          /* 
1800: 53 74 72 69 6e 67 20 70 6f 69 6e 74 65 72 20 2a  String pointer *
1810: 2f 0a 20 20 69 6e 74 20 6e 2c 20 20 20 20 20 20  /.  int n,      
1820: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 42              /* B
1830: 79 74 65 73 20 69 6e 20 73 74 72 69 6e 67 2c 20  ytes in string, 
1840: 6f 72 20 6e 65 67 61 74 69 76 65 20 2a 2f 0a 20  or negative */. 
1850: 20 75 38 20 65 6e 63 2c 20 20 20 20 20 20 20 20   u8 enc,        
1860: 20 20 20 20 20 20 20 20 20 2f 2a 20 45 6e 63 6f           /* Enco
1870: 64 69 6e 67 20 6f 66 20 7a 2e 20 20 30 20 66 6f  ding of z.  0 fo
1880: 72 20 42 4c 4f 42 73 20 2a 2f 0a 20 20 76 6f 69  r BLOBs */.  voi
1890: 64 20 28 2a 78 44 65 6c 29 28 76 6f 69 64 2a 29  d (*xDel)(void*)
18a0: 20 20 20 20 20 2f 2a 20 44 65 73 74 72 75 63 74       /* Destruct
18b0: 6f 72 20 66 75 6e 63 74 69 6f 6e 20 2a 2f 0a 29  or function */.)
18c0: 7b 0a 20 20 69 66 28 20 73 71 6c 69 74 65 33 56  {.  if( sqlite3V
18d0: 64 62 65 4d 65 6d 53 65 74 53 74 72 28 26 70 43  dbeMemSetStr(&pC
18e0: 74 78 2d 3e 73 2c 20 7a 2c 20 6e 2c 20 65 6e 63  tx->s, z, n, enc
18f0: 2c 20 78 44 65 6c 29 3d 3d 53 51 4c 49 54 45 5f  , xDel)==SQLITE_
1900: 54 4f 4f 42 49 47 20 29 7b 0a 20 20 20 20 73 71  TOOBIG ){.    sq
1910: 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 65 72 72  lite3_result_err
1920: 6f 72 5f 74 6f 6f 62 69 67 28 70 43 74 78 29 3b  or_toobig(pCtx);
1930: 0a 20 20 7d 0a 7d 0a 76 6f 69 64 20 73 71 6c 69  .  }.}.void sqli
1940: 74 65 33 5f 72 65 73 75 6c 74 5f 62 6c 6f 62 28  te3_result_blob(
1950: 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65  .  sqlite3_conte
1960: 78 74 20 2a 70 43 74 78 2c 20 0a 20 20 63 6f 6e  xt *pCtx, .  con
1970: 73 74 20 76 6f 69 64 20 2a 7a 2c 20 0a 20 20 69  st void *z, .  i
1980: 6e 74 20 6e 2c 20 0a 20 20 76 6f 69 64 20 28 2a  nt n, .  void (*
1990: 78 44 65 6c 29 28 76 6f 69 64 20 2a 29 0a 29 7b  xDel)(void *).){
19a0: 0a 20 20 61 73 73 65 72 74 28 20 6e 3e 3d 30 20  .  assert( n>=0 
19b0: 29 3b 0a 20 20 61 73 73 65 72 74 28 20 73 71 6c  );.  assert( sql
19c0: 69 74 65 33 5f 6d 75 74 65 78 5f 68 65 6c 64 28  ite3_mutex_held(
19d0: 70 43 74 78 2d 3e 73 2e 64 62 2d 3e 6d 75 74 65  pCtx->s.db->mute
19e0: 78 29 20 29 3b 0a 20 20 73 65 74 52 65 73 75 6c  x) );.  setResul
19f0: 74 53 74 72 4f 72 45 72 72 6f 72 28 70 43 74 78  tStrOrError(pCtx
1a00: 2c 20 7a 2c 20 6e 2c 20 30 2c 20 78 44 65 6c 29  , z, n, 0, xDel)
1a10: 3b 0a 7d 0a 76 6f 69 64 20 73 71 6c 69 74 65 33  ;.}.void sqlite3
1a20: 5f 72 65 73 75 6c 74 5f 64 6f 75 62 6c 65 28 73  _result_double(s
1a30: 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a  qlite3_context *
1a40: 70 43 74 78 2c 20 64 6f 75 62 6c 65 20 72 56 61  pCtx, double rVa
1a50: 6c 29 7b 0a 20 20 61 73 73 65 72 74 28 20 73 71  l){.  assert( sq
1a60: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 68 65 6c 64  lite3_mutex_held
1a70: 28 70 43 74 78 2d 3e 73 2e 64 62 2d 3e 6d 75 74  (pCtx->s.db->mut
1a80: 65 78 29 20 29 3b 0a 20 20 73 71 6c 69 74 65 33  ex) );.  sqlite3
1a90: 56 64 62 65 4d 65 6d 53 65 74 44 6f 75 62 6c 65  VdbeMemSetDouble
1aa0: 28 26 70 43 74 78 2d 3e 73 2c 20 72 56 61 6c 29  (&pCtx->s, rVal)
1ab0: 3b 0a 7d 0a 76 6f 69 64 20 73 71 6c 69 74 65 33  ;.}.void sqlite3
1ac0: 5f 72 65 73 75 6c 74 5f 65 72 72 6f 72 28 73 71  _result_error(sq
1ad0: 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70  lite3_context *p
1ae0: 43 74 78 2c 20 63 6f 6e 73 74 20 63 68 61 72 20  Ctx, const char 
1af0: 2a 7a 2c 20 69 6e 74 20 6e 29 7b 0a 20 20 61 73  *z, int n){.  as
1b00: 73 65 72 74 28 20 73 71 6c 69 74 65 33 5f 6d 75  sert( sqlite3_mu
1b10: 74 65 78 5f 68 65 6c 64 28 70 43 74 78 2d 3e 73  tex_held(pCtx->s
1b20: 2e 64 62 2d 3e 6d 75 74 65 78 29 20 29 3b 0a 20  .db->mutex) );. 
1b30: 20 70 43 74 78 2d 3e 69 73 45 72 72 6f 72 20 3d   pCtx->isError =
1b40: 20 53 51 4c 49 54 45 5f 45 52 52 4f 52 3b 0a 20   SQLITE_ERROR;. 
1b50: 20 73 71 6c 69 74 65 33 56 64 62 65 4d 65 6d 53   sqlite3VdbeMemS
1b60: 65 74 53 74 72 28 26 70 43 74 78 2d 3e 73 2c 20  etStr(&pCtx->s, 
1b70: 7a 2c 20 6e 2c 20 53 51 4c 49 54 45 5f 55 54 46  z, n, SQLITE_UTF
1b80: 38 2c 20 53 51 4c 49 54 45 5f 54 52 41 4e 53 49  8, SQLITE_TRANSI
1b90: 45 4e 54 29 3b 0a 7d 0a 23 69 66 6e 64 65 66 20  ENT);.}.#ifndef 
1ba0: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 55 54 46 31  SQLITE_OMIT_UTF1
1bb0: 36 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 5f 72  6.void sqlite3_r
1bc0: 65 73 75 6c 74 5f 65 72 72 6f 72 31 36 28 73 71  esult_error16(sq
1bd0: 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70  lite3_context *p
1be0: 43 74 78 2c 20 63 6f 6e 73 74 20 76 6f 69 64 20  Ctx, const void 
1bf0: 2a 7a 2c 20 69 6e 74 20 6e 29 7b 0a 20 20 61 73  *z, int n){.  as
1c00: 73 65 72 74 28 20 73 71 6c 69 74 65 33 5f 6d 75  sert( sqlite3_mu
1c10: 74 65 78 5f 68 65 6c 64 28 70 43 74 78 2d 3e 73  tex_held(pCtx->s
1c20: 2e 64 62 2d 3e 6d 75 74 65 78 29 20 29 3b 0a 20  .db->mutex) );. 
1c30: 20 70 43 74 78 2d 3e 69 73 45 72 72 6f 72 20 3d   pCtx->isError =
1c40: 20 53 51 4c 49 54 45 5f 45 52 52 4f 52 3b 0a 20   SQLITE_ERROR;. 
1c50: 20 73 71 6c 69 74 65 33 56 64 62 65 4d 65 6d 53   sqlite3VdbeMemS
1c60: 65 74 53 74 72 28 26 70 43 74 78 2d 3e 73 2c 20  etStr(&pCtx->s, 
1c70: 7a 2c 20 6e 2c 20 53 51 4c 49 54 45 5f 55 54 46  z, n, SQLITE_UTF
1c80: 31 36 4e 41 54 49 56 45 2c 20 53 51 4c 49 54 45  16NATIVE, SQLITE
1c90: 5f 54 52 41 4e 53 49 45 4e 54 29 3b 0a 7d 0a 23  _TRANSIENT);.}.#
1ca0: 65 6e 64 69 66 0a 76 6f 69 64 20 73 71 6c 69 74  endif.void sqlit
1cb0: 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74 28 73 71  e3_result_int(sq
1cc0: 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70  lite3_context *p
1cd0: 43 74 78 2c 20 69 6e 74 20 69 56 61 6c 29 7b 0a  Ctx, int iVal){.
1ce0: 20 20 61 73 73 65 72 74 28 20 73 71 6c 69 74 65    assert( sqlite
1cf0: 33 5f 6d 75 74 65 78 5f 68 65 6c 64 28 70 43 74  3_mutex_held(pCt
1d00: 78 2d 3e 73 2e 64 62 2d 3e 6d 75 74 65 78 29 20  x->s.db->mutex) 
1d10: 29 3b 0a 20 20 73 71 6c 69 74 65 33 56 64 62 65  );.  sqlite3Vdbe
1d20: 4d 65 6d 53 65 74 49 6e 74 36 34 28 26 70 43 74  MemSetInt64(&pCt
1d30: 78 2d 3e 73 2c 20 28 69 36 34 29 69 56 61 6c 29  x->s, (i64)iVal)
1d40: 3b 0a 7d 0a 76 6f 69 64 20 73 71 6c 69 74 65 33  ;.}.void sqlite3
1d50: 5f 72 65 73 75 6c 74 5f 69 6e 74 36 34 28 73 71  _result_int64(sq
1d60: 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70  lite3_context *p
1d70: 43 74 78 2c 20 69 36 34 20 69 56 61 6c 29 7b 0a  Ctx, i64 iVal){.
1d80: 20 20 61 73 73 65 72 74 28 20 73 71 6c 69 74 65    assert( sqlite
1d90: 33 5f 6d 75 74 65 78 5f 68 65 6c 64 28 70 43 74  3_mutex_held(pCt
1da0: 78 2d 3e 73 2e 64 62 2d 3e 6d 75 74 65 78 29 20  x->s.db->mutex) 
1db0: 29 3b 0a 20 20 73 71 6c 69 74 65 33 56 64 62 65  );.  sqlite3Vdbe
1dc0: 4d 65 6d 53 65 74 49 6e 74 36 34 28 26 70 43 74  MemSetInt64(&pCt
1dd0: 78 2d 3e 73 2c 20 69 56 61 6c 29 3b 0a 7d 0a 76  x->s, iVal);.}.v
1de0: 6f 69 64 20 73 71 6c 69 74 65 33 5f 72 65 73 75  oid sqlite3_resu
1df0: 6c 74 5f 6e 75 6c 6c 28 73 71 6c 69 74 65 33 5f  lt_null(sqlite3_
1e00: 63 6f 6e 74 65 78 74 20 2a 70 43 74 78 29 7b 0a  context *pCtx){.
1e10: 20 20 61 73 73 65 72 74 28 20 73 71 6c 69 74 65    assert( sqlite
1e20: 33 5f 6d 75 74 65 78 5f 68 65 6c 64 28 70 43 74  3_mutex_held(pCt
1e30: 78 2d 3e 73 2e 64 62 2d 3e 6d 75 74 65 78 29 20  x->s.db->mutex) 
1e40: 29 3b 0a 20 20 73 71 6c 69 74 65 33 56 64 62 65  );.  sqlite3Vdbe
1e50: 4d 65 6d 53 65 74 4e 75 6c 6c 28 26 70 43 74 78  MemSetNull(&pCtx
1e60: 2d 3e 73 29 3b 0a 7d 0a 76 6f 69 64 20 73 71 6c  ->s);.}.void sql
1e70: 69 74 65 33 5f 72 65 73 75 6c 74 5f 74 65 78 74  ite3_result_text
1e80: 28 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74  (.  sqlite3_cont
1e90: 65 78 74 20 2a 70 43 74 78 2c 20 0a 20 20 63 6f  ext *pCtx, .  co
1ea0: 6e 73 74 20 63 68 61 72 20 2a 7a 2c 20 0a 20 20  nst char *z, .  
1eb0: 69 6e 74 20 6e 2c 0a 20 20 76 6f 69 64 20 28 2a  int n,.  void (*
1ec0: 78 44 65 6c 29 28 76 6f 69 64 20 2a 29 0a 29 7b  xDel)(void *).){
1ed0: 0a 20 20 61 73 73 65 72 74 28 20 73 71 6c 69 74  .  assert( sqlit
1ee0: 65 33 5f 6d 75 74 65 78 5f 68 65 6c 64 28 70 43  e3_mutex_held(pC
1ef0: 74 78 2d 3e 73 2e 64 62 2d 3e 6d 75 74 65 78 29  tx->s.db->mutex)
1f00: 20 29 3b 0a 20 20 73 65 74 52 65 73 75 6c 74 53   );.  setResultS
1f10: 74 72 4f 72 45 72 72 6f 72 28 70 43 74 78 2c 20  trOrError(pCtx, 
1f20: 7a 2c 20 6e 2c 20 53 51 4c 49 54 45 5f 55 54 46  z, n, SQLITE_UTF
1f30: 38 2c 20 78 44 65 6c 29 3b 0a 7d 0a 23 69 66 6e  8, xDel);.}.#ifn
1f40: 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  def SQLITE_OMIT_
1f50: 55 54 46 31 36 0a 76 6f 69 64 20 73 71 6c 69 74  UTF16.void sqlit
1f60: 65 33 5f 72 65 73 75 6c 74 5f 74 65 78 74 31 36  e3_result_text16
1f70: 28 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74  (.  sqlite3_cont
1f80: 65 78 74 20 2a 70 43 74 78 2c 20 0a 20 20 63 6f  ext *pCtx, .  co
1f90: 6e 73 74 20 76 6f 69 64 20 2a 7a 2c 20 0a 20 20  nst void *z, .  
1fa0: 69 6e 74 20 6e 2c 20 0a 20 20 76 6f 69 64 20 28  int n, .  void (
1fb0: 2a 78 44 65 6c 29 28 76 6f 69 64 20 2a 29 0a 29  *xDel)(void *).)
1fc0: 7b 0a 20 20 61 73 73 65 72 74 28 20 73 71 6c 69  {.  assert( sqli
1fd0: 74 65 33 5f 6d 75 74 65 78 5f 68 65 6c 64 28 70  te3_mutex_held(p
1fe0: 43 74 78 2d 3e 73 2e 64 62 2d 3e 6d 75 74 65 78  Ctx->s.db->mutex
1ff0: 29 20 29 3b 0a 20 20 73 65 74 52 65 73 75 6c 74  ) );.  setResult
2000: 53 74 72 4f 72 45 72 72 6f 72 28 70 43 74 78 2c  StrOrError(pCtx,
2010: 20 7a 2c 20 6e 2c 20 53 51 4c 49 54 45 5f 55 54   z, n, SQLITE_UT
2020: 46 31 36 4e 41 54 49 56 45 2c 20 78 44 65 6c 29  F16NATIVE, xDel)
2030: 3b 0a 7d 0a 76 6f 69 64 20 73 71 6c 69 74 65 33  ;.}.void sqlite3
2040: 5f 72 65 73 75 6c 74 5f 74 65 78 74 31 36 62 65  _result_text16be
2050: 28 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74  (.  sqlite3_cont
2060: 65 78 74 20 2a 70 43 74 78 2c 20 0a 20 20 63 6f  ext *pCtx, .  co
2070: 6e 73 74 20 76 6f 69 64 20 2a 7a 2c 20 0a 20 20  nst void *z, .  
2080: 69 6e 74 20 6e 2c 20 0a 20 20 76 6f 69 64 20 28  int n, .  void (
2090: 2a 78 44 65 6c 29 28 76 6f 69 64 20 2a 29 0a 29  *xDel)(void *).)
20a0: 7b 0a 20 20 61 73 73 65 72 74 28 20 73 71 6c 69  {.  assert( sqli
20b0: 74 65 33 5f 6d 75 74 65 78 5f 68 65 6c 64 28 70  te3_mutex_held(p
20c0: 43 74 78 2d 3e 73 2e 64 62 2d 3e 6d 75 74 65 78  Ctx->s.db->mutex
20d0: 29 20 29 3b 0a 20 20 73 65 74 52 65 73 75 6c 74  ) );.  setResult
20e0: 53 74 72 4f 72 45 72 72 6f 72 28 70 43 74 78 2c  StrOrError(pCtx,
20f0: 20 7a 2c 20 6e 2c 20 53 51 4c 49 54 45 5f 55 54   z, n, SQLITE_UT
2100: 46 31 36 42 45 2c 20 78 44 65 6c 29 3b 0a 7d 0a  F16BE, xDel);.}.
2110: 76 6f 69 64 20 73 71 6c 69 74 65 33 5f 72 65 73  void sqlite3_res
2120: 75 6c 74 5f 74 65 78 74 31 36 6c 65 28 0a 20 20  ult_text16le(.  
2130: 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20  sqlite3_context 
2140: 2a 70 43 74 78 2c 20 0a 20 20 63 6f 6e 73 74 20  *pCtx, .  const 
2150: 76 6f 69 64 20 2a 7a 2c 20 0a 20 20 69 6e 74 20  void *z, .  int 
2160: 6e 2c 20 0a 20 20 76 6f 69 64 20 28 2a 78 44 65  n, .  void (*xDe
2170: 6c 29 28 76 6f 69 64 20 2a 29 0a 29 7b 0a 20 20  l)(void *).){.  
2180: 61 73 73 65 72 74 28 20 73 71 6c 69 74 65 33 5f  assert( sqlite3_
2190: 6d 75 74 65 78 5f 68 65 6c 64 28 70 43 74 78 2d  mutex_held(pCtx-
21a0: 3e 73 2e 64 62 2d 3e 6d 75 74 65 78 29 20 29 3b  >s.db->mutex) );
21b0: 0a 20 20 73 65 74 52 65 73 75 6c 74 53 74 72 4f  .  setResultStrO
21c0: 72 45 72 72 6f 72 28 70 43 74 78 2c 20 7a 2c 20  rError(pCtx, z, 
21d0: 6e 2c 20 53 51 4c 49 54 45 5f 55 54 46 31 36 4c  n, SQLITE_UTF16L
21e0: 45 2c 20 78 44 65 6c 29 3b 0a 7d 0a 23 65 6e 64  E, xDel);.}.#end
21f0: 69 66 20 2f 2a 20 53 51 4c 49 54 45 5f 4f 4d 49  if /* SQLITE_OMI
2200: 54 5f 55 54 46 31 36 20 2a 2f 0a 76 6f 69 64 20  T_UTF16 */.void 
2210: 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 76  sqlite3_result_v
2220: 61 6c 75 65 28 73 71 6c 69 74 65 33 5f 63 6f 6e  alue(sqlite3_con
2230: 74 65 78 74 20 2a 70 43 74 78 2c 20 73 71 6c 69  text *pCtx, sqli
2240: 74 65 33 5f 76 61 6c 75 65 20 2a 70 56 61 6c 75  te3_value *pValu
2250: 65 29 7b 0a 20 20 61 73 73 65 72 74 28 20 73 71  e){.  assert( sq
2260: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 68 65 6c 64  lite3_mutex_held
2270: 28 70 43 74 78 2d 3e 73 2e 64 62 2d 3e 6d 75 74  (pCtx->s.db->mut
2280: 65 78 29 20 29 3b 0a 20 20 73 71 6c 69 74 65 33  ex) );.  sqlite3
2290: 56 64 62 65 4d 65 6d 43 6f 70 79 28 26 70 43 74  VdbeMemCopy(&pCt
22a0: 78 2d 3e 73 2c 20 70 56 61 6c 75 65 29 3b 0a 7d  x->s, pValue);.}
22b0: 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 5f 72 65  .void sqlite3_re
22c0: 73 75 6c 74 5f 7a 65 72 6f 62 6c 6f 62 28 73 71  sult_zeroblob(sq
22d0: 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70  lite3_context *p
22e0: 43 74 78 2c 20 69 6e 74 20 6e 29 7b 0a 20 20 61  Ctx, int n){.  a
22f0: 73 73 65 72 74 28 20 73 71 6c 69 74 65 33 5f 6d  ssert( sqlite3_m
2300: 75 74 65 78 5f 68 65 6c 64 28 70 43 74 78 2d 3e  utex_held(pCtx->
2310: 73 2e 64 62 2d 3e 6d 75 74 65 78 29 20 29 3b 0a  s.db->mutex) );.
2320: 20 20 73 71 6c 69 74 65 33 56 64 62 65 4d 65 6d    sqlite3VdbeMem
2330: 53 65 74 5a 65 72 6f 42 6c 6f 62 28 26 70 43 74  SetZeroBlob(&pCt
2340: 78 2d 3e 73 2c 20 6e 29 3b 0a 7d 0a 76 6f 69 64  x->s, n);.}.void
2350: 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f   sqlite3_result_
2360: 65 72 72 6f 72 5f 63 6f 64 65 28 73 71 6c 69 74  error_code(sqlit
2370: 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70 43 74 78  e3_context *pCtx
2380: 2c 20 69 6e 74 20 65 72 72 43 6f 64 65 29 7b 0a  , int errCode){.
2390: 20 20 70 43 74 78 2d 3e 69 73 45 72 72 6f 72 20    pCtx->isError 
23a0: 3d 20 65 72 72 43 6f 64 65 3b 0a 20 20 69 66 28  = errCode;.  if(
23b0: 20 70 43 74 78 2d 3e 73 2e 66 6c 61 67 73 20 26   pCtx->s.flags &
23c0: 20 4d 45 4d 5f 4e 75 6c 6c 20 29 7b 0a 20 20 20   MEM_Null ){.   
23d0: 20 73 71 6c 69 74 65 33 56 64 62 65 4d 65 6d 53   sqlite3VdbeMemS
23e0: 65 74 53 74 72 28 26 70 43 74 78 2d 3e 73 2c 20  etStr(&pCtx->s, 
23f0: 73 71 6c 69 74 65 33 45 72 72 53 74 72 28 65 72  sqlite3ErrStr(er
2400: 72 43 6f 64 65 29 2c 20 2d 31 2c 20 0a 20 20 20  rCode), -1, .   
2410: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2420: 20 20 20 20 20 20 53 51 4c 49 54 45 5f 55 54 46        SQLITE_UTF
2430: 38 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49 43  8, SQLITE_STATIC
2440: 29 3b 0a 20 20 7d 0a 7d 0a 0a 2f 2a 20 46 6f 72  );.  }.}../* For
2450: 63 65 20 61 6e 20 53 51 4c 49 54 45 5f 54 4f 4f  ce an SQLITE_TOO
2460: 42 49 47 20 65 72 72 6f 72 2e 20 2a 2f 0a 76 6f  BIG error. */.vo
2470: 69 64 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c  id sqlite3_resul
2480: 74 5f 65 72 72 6f 72 5f 74 6f 6f 62 69 67 28 73  t_error_toobig(s
2490: 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a  qlite3_context *
24a0: 70 43 74 78 29 7b 0a 20 20 61 73 73 65 72 74 28  pCtx){.  assert(
24b0: 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 68   sqlite3_mutex_h
24c0: 65 6c 64 28 70 43 74 78 2d 3e 73 2e 64 62 2d 3e  eld(pCtx->s.db->
24d0: 6d 75 74 65 78 29 20 29 3b 0a 20 20 70 43 74 78  mutex) );.  pCtx
24e0: 2d 3e 69 73 45 72 72 6f 72 20 3d 20 53 51 4c 49  ->isError = SQLI
24f0: 54 45 5f 54 4f 4f 42 49 47 3b 0a 20 20 73 71 6c  TE_TOOBIG;.  sql
2500: 69 74 65 33 56 64 62 65 4d 65 6d 53 65 74 53 74  ite3VdbeMemSetSt
2510: 72 28 26 70 43 74 78 2d 3e 73 2c 20 22 73 74 72  r(&pCtx->s, "str
2520: 69 6e 67 20 6f 72 20 62 6c 6f 62 20 74 6f 6f 20  ing or blob too 
2530: 62 69 67 22 2c 20 2d 31 2c 20 0a 20 20 20 20 20  big", -1, .     
2540: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2550: 20 20 53 51 4c 49 54 45 5f 55 54 46 38 2c 20 53    SQLITE_UTF8, S
2560: 51 4c 49 54 45 5f 53 54 41 54 49 43 29 3b 0a 7d  QLITE_STATIC);.}
2570: 0a 0a 2f 2a 20 41 6e 20 53 51 4c 49 54 45 5f 4e  ../* An SQLITE_N
2580: 4f 4d 45 4d 20 65 72 72 6f 72 2e 20 2a 2f 0a 76  OMEM error. */.v
2590: 6f 69 64 20 73 71 6c 69 74 65 33 5f 72 65 73 75  oid sqlite3_resu
25a0: 6c 74 5f 65 72 72 6f 72 5f 6e 6f 6d 65 6d 28 73  lt_error_nomem(s
25b0: 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a  qlite3_context *
25c0: 70 43 74 78 29 7b 0a 20 20 61 73 73 65 72 74 28  pCtx){.  assert(
25d0: 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 68   sqlite3_mutex_h
25e0: 65 6c 64 28 70 43 74 78 2d 3e 73 2e 64 62 2d 3e  eld(pCtx->s.db->
25f0: 6d 75 74 65 78 29 20 29 3b 0a 20 20 73 71 6c 69  mutex) );.  sqli
2600: 74 65 33 56 64 62 65 4d 65 6d 53 65 74 4e 75 6c  te3VdbeMemSetNul
2610: 6c 28 26 70 43 74 78 2d 3e 73 29 3b 0a 20 20 70  l(&pCtx->s);.  p
2620: 43 74 78 2d 3e 69 73 45 72 72 6f 72 20 3d 20 53  Ctx->isError = S
2630: 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 70  QLITE_NOMEM;.  p
2640: 43 74 78 2d 3e 73 2e 64 62 2d 3e 6d 61 6c 6c 6f  Ctx->s.db->mallo
2650: 63 46 61 69 6c 65 64 20 3d 20 31 3b 0a 7d 0a 0a  cFailed = 1;.}..
2660: 2f 2a 0a 2a 2a 20 54 68 69 73 20 66 75 6e 63 74  /*.** This funct
2670: 69 6f 6e 20 69 73 20 63 61 6c 6c 65 64 20 61 66  ion is called af
2680: 74 65 72 20 61 20 74 72 61 6e 73 61 63 74 69 6f  ter a transactio
2690: 6e 20 68 61 73 20 62 65 65 6e 20 63 6f 6d 6d 69  n has been commi
26a0: 74 74 65 64 2e 20 49 74 20 0a 2a 2a 20 69 6e 76  tted. It .** inv
26b0: 6f 6b 65 73 20 63 61 6c 6c 62 61 63 6b 73 20 72  okes callbacks r
26c0: 65 67 69 73 74 65 72 65 64 20 77 69 74 68 20 73  egistered with s
26d0: 71 6c 69 74 65 33 5f 77 61 6c 5f 68 6f 6f 6b 28  qlite3_wal_hook(
26e0: 29 20 61 73 20 72 65 71 75 69 72 65 64 2e 0a 2a  ) as required..*
26f0: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 64 6f 57  /.static int doW
2700: 61 6c 43 61 6c 6c 62 61 63 6b 73 28 73 71 6c 69  alCallbacks(sqli
2710: 74 65 33 20 2a 64 62 29 7b 0a 20 20 69 6e 74 20  te3 *db){.  int 
2720: 72 63 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a  rc = SQLITE_OK;.
2730: 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f  #ifndef SQLITE_O
2740: 4d 49 54 5f 57 41 4c 0a 20 20 69 6e 74 20 69 3b  MIT_WAL.  int i;
2750: 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 64 62  .  for(i=0; i<db
2760: 2d 3e 6e 44 62 3b 20 69 2b 2b 29 7b 0a 20 20 20  ->nDb; i++){.   
2770: 20 42 74 72 65 65 20 2a 70 42 74 20 3d 20 64 62   Btree *pBt = db
2780: 2d 3e 61 44 62 5b 69 5d 2e 70 42 74 3b 0a 20 20  ->aDb[i].pBt;.  
2790: 20 20 69 66 28 20 70 42 74 20 29 7b 0a 20 20 20    if( pBt ){.   
27a0: 20 20 20 69 6e 74 20 6e 45 6e 74 72 79 20 3d 20     int nEntry = 
27b0: 73 71 6c 69 74 65 33 50 61 67 65 72 57 61 6c 43  sqlite3PagerWalC
27c0: 61 6c 6c 62 61 63 6b 28 73 71 6c 69 74 65 33 42  allback(sqlite3B
27d0: 74 72 65 65 50 61 67 65 72 28 70 42 74 29 29 3b  treePager(pBt));
27e0: 0a 20 20 20 20 20 20 69 66 28 20 64 62 2d 3e 78  .      if( db->x
27f0: 57 61 6c 43 61 6c 6c 62 61 63 6b 20 26 26 20 6e  WalCallback && n
2800: 45 6e 74 72 79 3e 30 20 26 26 20 72 63 3d 3d 53  Entry>0 && rc==S
2810: 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20  QLITE_OK ){.    
2820: 20 20 20 20 72 63 20 3d 20 64 62 2d 3e 78 57 61      rc = db->xWa
2830: 6c 43 61 6c 6c 62 61 63 6b 28 64 62 2d 3e 70 57  lCallback(db->pW
2840: 61 6c 41 72 67 2c 20 64 62 2c 20 64 62 2d 3e 61  alArg, db, db->a
2850: 44 62 5b 69 5d 2e 7a 4e 61 6d 65 2c 20 6e 45 6e  Db[i].zName, nEn
2860: 74 72 79 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20  try);.      }.  
2870: 20 20 7d 0a 20 20 7d 0a 23 65 6e 64 69 66 0a 20    }.  }.#endif. 
2880: 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f   return rc;.}../
2890: 2a 0a 2a 2a 20 45 78 65 63 75 74 65 20 74 68 65  *.** Execute the
28a0: 20 73 74 61 74 65 6d 65 6e 74 20 70 53 74 6d 74   statement pStmt
28b0: 2c 20 65 69 74 68 65 72 20 75 6e 74 69 6c 20 61  , either until a
28c0: 20 72 6f 77 20 6f 66 20 64 61 74 61 20 69 73 20   row of data is 
28d0: 72 65 61 64 79 2c 20 74 68 65 0a 2a 2a 20 73 74  ready, the.** st
28e0: 61 74 65 6d 65 6e 74 20 69 73 20 63 6f 6d 70 6c  atement is compl
28f0: 65 74 65 6c 79 20 65 78 65 63 75 74 65 64 20 6f  etely executed o
2900: 72 20 61 6e 20 65 72 72 6f 72 20 6f 63 63 75 72  r an error occur
2910: 73 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20 72 6f  s..**.** This ro
2920: 75 74 69 6e 65 20 69 6d 70 6c 65 6d 65 6e 74 73  utine implements
2930: 20 74 68 65 20 62 75 6c 6b 20 6f 66 20 74 68 65   the bulk of the
2940: 20 6c 6f 67 69 63 20 62 65 68 69 6e 64 20 74 68   logic behind th
2950: 65 20 73 71 6c 69 74 65 5f 73 74 65 70 28 29 0a  e sqlite_step().
2960: 2a 2a 20 41 50 49 2e 20 20 54 68 65 20 6f 6e 6c  ** API.  The onl
2970: 79 20 74 68 69 6e 67 20 6f 6d 69 74 74 65 64 20  y thing omitted 
2980: 69 73 20 74 68 65 20 61 75 74 6f 6d 61 74 69 63  is the automatic
2990: 20 72 65 63 6f 6d 70 69 6c 65 20 69 66 20 61 20   recompile if a 
29a0: 0a 2a 2a 20 73 63 68 65 6d 61 20 63 68 61 6e 67  .** schema chang
29b0: 65 20 68 61 73 20 6f 63 63 75 72 72 65 64 2e 20  e has occurred. 
29c0: 20 54 68 61 74 20 64 65 74 61 69 6c 20 69 73 20   That detail is 
29d0: 68 61 6e 64 6c 65 64 20 62 79 20 74 68 65 0a 2a  handled by the.*
29e0: 2a 20 6f 75 74 65 72 20 73 71 6c 69 74 65 33 5f  * outer sqlite3_
29f0: 73 74 65 70 28 29 20 77 72 61 70 70 65 72 20 70  step() wrapper p
2a00: 72 6f 63 65 64 75 72 65 2e 0a 2a 2f 0a 73 74 61  rocedure..*/.sta
2a10: 74 69 63 20 69 6e 74 20 73 71 6c 69 74 65 33 53  tic int sqlite3S
2a20: 74 65 70 28 56 64 62 65 20 2a 70 29 7b 0a 20 20  tep(Vdbe *p){.  
2a30: 73 71 6c 69 74 65 33 20 2a 64 62 3b 0a 20 20 69  sqlite3 *db;.  i
2a40: 6e 74 20 72 63 3b 0a 0a 20 20 61 73 73 65 72 74  nt rc;..  assert
2a50: 28 70 29 3b 0a 20 20 69 66 28 20 70 2d 3e 6d 61  (p);.  if( p->ma
2a60: 67 69 63 21 3d 56 44 42 45 5f 4d 41 47 49 43 5f  gic!=VDBE_MAGIC_
2a70: 52 55 4e 20 29 7b 0a 20 20 20 20 2f 2a 20 57 65  RUN ){.    /* We
2a80: 20 75 73 65 64 20 74 6f 20 72 65 71 75 69 72 65   used to require
2a90: 20 74 68 61 74 20 73 71 6c 69 74 65 33 5f 72 65   that sqlite3_re
2aa0: 73 65 74 28 29 20 62 65 20 63 61 6c 6c 65 64 20  set() be called 
2ab0: 62 65 66 6f 72 65 20 72 65 74 72 79 69 6e 67 0a  before retrying.
2ac0: 20 20 20 20 2a 2a 20 73 71 6c 69 74 65 33 5f 73      ** sqlite3_s
2ad0: 74 65 70 28 29 20 61 66 74 65 72 20 61 6e 79 20  tep() after any 
2ae0: 65 72 72 6f 72 20 6f 72 20 61 66 74 65 72 20 53  error or after S
2af0: 51 4c 49 54 45 5f 44 4f 4e 45 2e 20 20 42 75 74  QLITE_DONE.  But
2b00: 20 62 65 67 69 6e 6e 69 6e 67 0a 20 20 20 20 2a   beginning.    *
2b10: 2a 20 77 69 74 68 20 76 65 72 73 69 6f 6e 20 33  * with version 3
2b20: 2e 37 2e 30 2c 20 77 65 20 63 68 61 6e 67 65 64  .7.0, we changed
2b30: 20 74 68 69 73 20 73 6f 20 74 68 61 74 20 73 71   this so that sq
2b40: 6c 69 74 65 33 5f 72 65 73 65 74 28 29 20 77 6f  lite3_reset() wo
2b50: 75 6c 64 0a 20 20 20 20 2a 2a 20 62 65 20 63 61  uld.    ** be ca
2b60: 6c 6c 65 64 20 61 75 74 6f 6d 61 74 69 63 61 6c  lled automatical
2b70: 6c 79 20 69 6e 73 74 65 61 64 20 6f 66 20 74 68  ly instead of th
2b80: 72 6f 77 69 6e 67 20 74 68 65 20 53 51 4c 49 54  rowing the SQLIT
2b90: 45 5f 4d 49 53 55 53 45 20 65 72 72 6f 72 2e 0a  E_MISUSE error..
2ba0: 20 20 20 20 2a 2a 20 54 68 69 73 20 22 61 75 74      ** This "aut
2bb0: 6f 6d 61 74 69 63 2d 72 65 73 65 74 22 20 63 68  omatic-reset" ch
2bc0: 61 6e 67 65 20 69 73 20 6e 6f 74 20 74 65 63 68  ange is not tech
2bd0: 6e 69 63 61 6c 6c 79 20 61 6e 20 69 6e 63 6f 6d  nically an incom
2be0: 70 61 74 69 62 69 6c 69 74 79 2c 20 0a 20 20 20  patibility, .   
2bf0: 20 2a 2a 20 73 69 6e 63 65 20 61 6e 79 20 61 70   ** since any ap
2c00: 70 6c 69 63 61 74 69 6f 6e 20 74 68 61 74 20 72  plication that r
2c10: 65 63 65 69 76 65 73 20 61 6e 20 53 51 4c 49 54  eceives an SQLIT
2c20: 45 5f 4d 49 53 55 53 45 20 69 73 20 62 72 6f 6b  E_MISUSE is brok
2c30: 65 6e 20 62 79 0a 20 20 20 20 2a 2a 20 64 65 66  en by.    ** def
2c40: 69 6e 69 74 69 6f 6e 2e 0a 20 20 20 20 2a 2a 0a  inition..    **.
2c50: 20 20 20 20 2a 2a 20 4e 65 76 65 72 74 68 65 6c      ** Neverthel
2c60: 65 73 73 2c 20 73 6f 6d 65 20 70 75 62 6c 69 73  ess, some publis
2c70: 68 65 64 20 61 70 70 6c 69 63 61 74 69 6f 6e 73  hed applications
2c80: 20 74 68 61 74 20 77 65 72 65 20 6f 72 69 67 69   that were origi
2c90: 6e 61 6c 6c 79 20 77 72 69 74 74 65 6e 0a 20 20  nally written.  
2ca0: 20 20 2a 2a 20 66 6f 72 20 76 65 72 73 69 6f 6e    ** for version
2cb0: 20 33 2e 36 2e 32 33 20 6f 72 20 65 61 72 6c 69   3.6.23 or earli
2cc0: 65 72 20 64 6f 20 69 6e 20 66 61 63 74 20 64 65  er do in fact de
2cd0: 70 65 6e 64 20 6f 6e 20 53 51 4c 49 54 45 5f 4d  pend on SQLITE_M
2ce0: 49 53 55 53 45 20 0a 20 20 20 20 2a 2a 20 72 65  ISUSE .    ** re
2cf0: 74 75 72 6e 73 2c 20 61 6e 64 20 74 68 65 20 73  turns, and the s
2d00: 6f 20 77 65 72 65 20 62 72 6f 6b 65 6e 20 62 79  o were broken by
2d10: 20 74 68 65 20 61 75 74 6f 6d 61 74 69 63 2d 72   the automatic-r
2d20: 65 73 65 74 20 63 68 61 6e 67 65 2e 20 20 41 73  eset change.  As
2d30: 20 61 0a 20 20 20 20 2a 2a 20 61 20 77 6f 72 6b   a.    ** a work
2d40: 2d 61 72 6f 75 6e 64 2c 20 74 68 65 20 53 51 4c  -around, the SQL
2d50: 49 54 45 5f 4f 4d 49 54 5f 41 55 54 4f 52 45 53  ITE_OMIT_AUTORES
2d60: 45 54 20 63 6f 6d 70 69 6c 65 2d 74 69 6d 65 20  ET compile-time 
2d70: 72 65 73 74 6f 72 65 73 20 74 68 65 0a 20 20 20  restores the.   
2d80: 20 2a 2a 20 6c 65 67 61 63 79 20 62 65 68 61 76   ** legacy behav
2d90: 69 6f 72 20 6f 66 20 72 65 74 75 72 6e 69 6e 67  ior of returning
2da0: 20 53 51 4c 49 54 45 5f 4d 49 53 55 53 45 20 66   SQLITE_MISUSE f
2db0: 6f 72 20 63 61 73 65 73 20 77 68 65 72 65 20 74  or cases where t
2dc0: 68 65 20 0a 20 20 20 20 2a 2a 20 70 72 65 76 69  he .    ** previ
2dd0: 6f 75 73 20 73 71 6c 69 74 65 33 5f 73 74 65 70  ous sqlite3_step
2de0: 28 29 20 72 65 74 75 72 6e 65 64 20 73 6f 6d 65  () returned some
2df0: 74 68 69 6e 67 20 6f 74 68 65 72 20 74 68 61 6e  thing other than
2e00: 20 61 20 53 51 4c 49 54 45 5f 4c 4f 43 4b 45 44   a SQLITE_LOCKED
2e10: 0a 20 20 20 20 2a 2a 20 6f 72 20 53 51 4c 49 54  .    ** or SQLIT
2e20: 45 5f 42 55 53 59 20 65 72 72 6f 72 2e 0a 20 20  E_BUSY error..  
2e30: 20 20 2a 2f 0a 23 69 66 64 65 66 20 53 51 4c 49    */.#ifdef SQLI
2e40: 54 45 5f 4f 4d 49 54 5f 41 55 54 4f 52 45 53 45  TE_OMIT_AUTORESE
2e50: 54 0a 20 20 20 20 69 66 28 20 70 2d 3e 72 63 3d  T.    if( p->rc=
2e60: 3d 53 51 4c 49 54 45 5f 42 55 53 59 20 7c 7c 20  =SQLITE_BUSY || 
2e70: 70 2d 3e 72 63 3d 3d 53 51 4c 49 54 45 5f 4c 4f  p->rc==SQLITE_LO
2e80: 43 4b 45 44 20 29 7b 0a 20 20 20 20 20 20 73 71  CKED ){.      sq
2e90: 6c 69 74 65 33 5f 72 65 73 65 74 28 28 73 71 6c  lite3_reset((sql
2ea0: 69 74 65 33 5f 73 74 6d 74 2a 29 70 29 3b 0a 20  ite3_stmt*)p);. 
2eb0: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
2ec0: 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4d 49  return SQLITE_MI
2ed0: 53 55 53 45 5f 42 4b 50 54 3b 0a 20 20 20 20 7d  SUSE_BKPT;.    }
2ee0: 0a 23 65 6c 73 65 0a 20 20 20 20 73 71 6c 69 74  .#else.    sqlit
2ef0: 65 33 5f 72 65 73 65 74 28 28 73 71 6c 69 74 65  e3_reset((sqlite
2f00: 33 5f 73 74 6d 74 2a 29 70 29 3b 0a 23 65 6e 64  3_stmt*)p);.#end
2f10: 69 66 0a 20 20 7d 0a 0a 20 20 2f 2a 20 43 68 65  if.  }..  /* Che
2f20: 63 6b 20 74 68 61 74 20 6d 61 6c 6c 6f 63 28 29  ck that malloc()
2f30: 20 68 61 73 20 6e 6f 74 20 66 61 69 6c 65 64 2e   has not failed.
2f40: 20 49 66 20 69 74 20 68 61 73 2c 20 72 65 74 75   If it has, retu
2f50: 72 6e 20 65 61 72 6c 79 2e 20 2a 2f 0a 20 20 64  rn early. */.  d
2f60: 62 20 3d 20 70 2d 3e 64 62 3b 0a 20 20 69 66 28  b = p->db;.  if(
2f70: 20 64 62 2d 3e 6d 61 6c 6c 6f 63 46 61 69 6c 65   db->mallocFaile
2f80: 64 20 29 7b 0a 20 20 20 20 70 2d 3e 72 63 20 3d  d ){.    p->rc =
2f90: 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3b 0a 20   SQLITE_NOMEM;. 
2fa0: 20 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45     return SQLITE
2fb0: 5f 4e 4f 4d 45 4d 3b 0a 20 20 7d 0a 0a 20 20 69  _NOMEM;.  }..  i
2fc0: 66 28 20 70 2d 3e 70 63 3c 3d 30 20 26 26 20 70  f( p->pc<=0 && p
2fd0: 2d 3e 65 78 70 69 72 65 64 20 29 7b 0a 20 20 20  ->expired ){.   
2fe0: 20 70 2d 3e 72 63 20 3d 20 53 51 4c 49 54 45 5f   p->rc = SQLITE_
2ff0: 53 43 48 45 4d 41 3b 0a 20 20 20 20 72 63 20 3d  SCHEMA;.    rc =
3000: 20 53 51 4c 49 54 45 5f 45 52 52 4f 52 3b 0a 20   SQLITE_ERROR;. 
3010: 20 20 20 67 6f 74 6f 20 65 6e 64 5f 6f 66 5f 73     goto end_of_s
3020: 74 65 70 3b 0a 20 20 7d 0a 20 20 69 66 28 20 70  tep;.  }.  if( p
3030: 2d 3e 70 63 3c 30 20 29 7b 0a 20 20 20 20 2f 2a  ->pc<0 ){.    /*
3040: 20 49 66 20 74 68 65 72 65 20 61 72 65 20 6e 6f   If there are no
3050: 20 6f 74 68 65 72 20 73 74 61 74 65 6d 65 6e 74   other statement
3060: 73 20 63 75 72 72 65 6e 74 6c 79 20 72 75 6e 6e  s currently runn
3070: 69 6e 67 2c 20 74 68 65 6e 0a 20 20 20 20 2a 2a  ing, then.    **
3080: 20 72 65 73 65 74 20 74 68 65 20 69 6e 74 65 72   reset the inter
3090: 72 75 70 74 20 66 6c 61 67 2e 20 20 54 68 69 73  rupt flag.  This
30a0: 20 70 72 65 76 65 6e 74 73 20 61 20 63 61 6c 6c   prevents a call
30b0: 20 74 6f 20 73 71 6c 69 74 65 33 5f 69 6e 74 65   to sqlite3_inte
30c0: 72 72 75 70 74 0a 20 20 20 20 2a 2a 20 66 72 6f  rrupt.    ** fro
30d0: 6d 20 69 6e 74 65 72 72 75 70 74 69 6e 67 20 61  m interrupting a
30e0: 20 73 74 61 74 65 6d 65 6e 74 20 74 68 61 74 20   statement that 
30f0: 68 61 73 20 6e 6f 74 20 79 65 74 20 73 74 61 72  has not yet star
3100: 74 65 64 2e 0a 20 20 20 20 2a 2f 0a 20 20 20 20  ted..    */.    
3110: 69 66 28 20 64 62 2d 3e 61 63 74 69 76 65 56 64  if( db->activeVd
3120: 62 65 43 6e 74 3d 3d 30 20 29 7b 0a 20 20 20 20  beCnt==0 ){.    
3130: 20 20 64 62 2d 3e 75 31 2e 69 73 49 6e 74 65 72    db->u1.isInter
3140: 72 75 70 74 65 64 20 3d 20 30 3b 0a 20 20 20 20  rupted = 0;.    
3150: 7d 0a 0a 20 20 20 20 61 73 73 65 72 74 28 20 64  }..    assert( d
3160: 62 2d 3e 77 72 69 74 65 56 64 62 65 43 6e 74 3e  b->writeVdbeCnt>
3170: 30 20 7c 7c 20 64 62 2d 3e 61 75 74 6f 43 6f 6d  0 || db->autoCom
3180: 6d 69 74 3d 3d 30 20 7c 7c 20 64 62 2d 3e 6e 44  mit==0 || db->nD
3190: 65 66 65 72 72 65 64 43 6f 6e 73 3d 3d 30 20 29  eferredCons==0 )
31a0: 3b 0a 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54  ;..#ifndef SQLIT
31b0: 45 5f 4f 4d 49 54 5f 54 52 41 43 45 0a 20 20 20  E_OMIT_TRACE.   
31c0: 20 69 66 28 20 64 62 2d 3e 78 50 72 6f 66 69 6c   if( db->xProfil
31d0: 65 20 26 26 20 21 64 62 2d 3e 69 6e 69 74 2e 62  e && !db->init.b
31e0: 75 73 79 20 29 7b 0a 20 20 20 20 20 20 73 71 6c  usy ){.      sql
31f0: 69 74 65 33 4f 73 43 75 72 72 65 6e 74 54 69 6d  ite3OsCurrentTim
3200: 65 49 6e 74 36 34 28 64 62 2d 3e 70 56 66 73 2c  eInt64(db->pVfs,
3210: 20 26 70 2d 3e 73 74 61 72 74 54 69 6d 65 29 3b   &p->startTime);
3220: 0a 20 20 20 20 7d 0a 23 65 6e 64 69 66 0a 0a 20  .    }.#endif.. 
3230: 20 20 20 64 62 2d 3e 61 63 74 69 76 65 56 64 62     db->activeVdb
3240: 65 43 6e 74 2b 2b 3b 0a 20 20 20 20 69 66 28 20  eCnt++;.    if( 
3250: 70 2d 3e 72 65 61 64 4f 6e 6c 79 3d 3d 30 20 29  p->readOnly==0 )
3260: 20 64 62 2d 3e 77 72 69 74 65 56 64 62 65 43 6e   db->writeVdbeCn
3270: 74 2b 2b 3b 0a 20 20 20 20 70 2d 3e 70 63 20 3d  t++;.    p->pc =
3280: 20 30 3b 0a 20 20 7d 0a 23 69 66 6e 64 65 66 20   0;.  }.#ifndef 
3290: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 45 58 50 4c  SQLITE_OMIT_EXPL
32a0: 41 49 4e 0a 20 20 69 66 28 20 70 2d 3e 65 78 70  AIN.  if( p->exp
32b0: 6c 61 69 6e 20 29 7b 0a 20 20 20 20 72 63 20 3d  lain ){.    rc =
32c0: 20 73 71 6c 69 74 65 33 56 64 62 65 4c 69 73 74   sqlite3VdbeList
32d0: 28 70 29 3b 0a 20 20 7d 65 6c 73 65 0a 23 65 6e  (p);.  }else.#en
32e0: 64 69 66 20 2f 2a 20 53 51 4c 49 54 45 5f 4f 4d  dif /* SQLITE_OM
32f0: 49 54 5f 45 58 50 4c 41 49 4e 20 2a 2f 0a 20 20  IT_EXPLAIN */.  
3300: 7b 0a 20 20 20 20 64 62 2d 3e 76 64 62 65 45 78  {.    db->vdbeEx
3310: 65 63 43 6e 74 2b 2b 3b 0a 20 20 20 20 72 63 20  ecCnt++;.    rc 
3320: 3d 20 73 71 6c 69 74 65 33 56 64 62 65 45 78 65  = sqlite3VdbeExe
3330: 63 28 70 29 3b 0a 20 20 20 20 64 62 2d 3e 76 64  c(p);.    db->vd
3340: 62 65 45 78 65 63 43 6e 74 2d 2d 3b 0a 20 20 7d  beExecCnt--;.  }
3350: 0a 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45  ..#ifndef SQLITE
3360: 5f 4f 4d 49 54 5f 54 52 41 43 45 0a 20 20 2f 2a  _OMIT_TRACE.  /*
3370: 20 49 6e 76 6f 6b 65 20 74 68 65 20 70 72 6f 66   Invoke the prof
3380: 69 6c 65 20 63 61 6c 6c 62 61 63 6b 20 69 66 20  ile callback if 
3390: 74 68 65 72 65 20 69 73 20 6f 6e 65 0a 20 20 2a  there is one.  *
33a0: 2f 0a 20 20 69 66 28 20 72 63 21 3d 53 51 4c 49  /.  if( rc!=SQLI
33b0: 54 45 5f 52 4f 57 20 26 26 20 64 62 2d 3e 78 50  TE_ROW && db->xP
33c0: 72 6f 66 69 6c 65 20 26 26 20 21 64 62 2d 3e 69  rofile && !db->i
33d0: 6e 69 74 2e 62 75 73 79 20 26 26 20 70 2d 3e 7a  nit.busy && p->z
33e0: 53 71 6c 20 29 7b 0a 20 20 20 20 73 71 6c 69 74  Sql ){.    sqlit
33f0: 65 33 5f 69 6e 74 36 34 20 69 4e 6f 77 3b 0a 20  e3_int64 iNow;. 
3400: 20 20 20 73 71 6c 69 74 65 33 4f 73 43 75 72 72     sqlite3OsCurr
3410: 65 6e 74 54 69 6d 65 49 6e 74 36 34 28 64 62 2d  entTimeInt64(db-
3420: 3e 70 56 66 73 2c 20 26 69 4e 6f 77 29 3b 0a 20  >pVfs, &iNow);. 
3430: 20 20 20 64 62 2d 3e 78 50 72 6f 66 69 6c 65 28     db->xProfile(
3440: 64 62 2d 3e 70 50 72 6f 66 69 6c 65 41 72 67 2c  db->pProfileArg,
3450: 20 70 2d 3e 7a 53 71 6c 2c 20 28 69 4e 6f 77 20   p->zSql, (iNow 
3460: 2d 20 70 2d 3e 73 74 61 72 74 54 69 6d 65 29 2a  - p->startTime)*
3470: 31 30 30 30 30 30 30 29 3b 0a 20 20 7d 0a 23 65  1000000);.  }.#e
3480: 6e 64 69 66 0a 0a 20 20 69 66 28 20 72 63 3d 3d  ndif..  if( rc==
3490: 53 51 4c 49 54 45 5f 44 4f 4e 45 20 29 7b 0a 20  SQLITE_DONE ){. 
34a0: 20 20 20 61 73 73 65 72 74 28 20 70 2d 3e 72 63     assert( p->rc
34b0: 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 3b 0a 20  ==SQLITE_OK );. 
34c0: 20 20 20 70 2d 3e 72 63 20 3d 20 64 6f 57 61 6c     p->rc = doWal
34d0: 43 61 6c 6c 62 61 63 6b 73 28 64 62 29 3b 0a 20  Callbacks(db);. 
34e0: 20 20 20 69 66 28 20 70 2d 3e 72 63 21 3d 53 51     if( p->rc!=SQ
34f0: 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 20  LITE_OK ){.     
3500: 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 45 52 52   rc = SQLITE_ERR
3510: 4f 52 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20  OR;.    }.  }.. 
3520: 20 64 62 2d 3e 65 72 72 43 6f 64 65 20 3d 20 72   db->errCode = r
3530: 63 3b 0a 20 20 69 66 28 20 53 51 4c 49 54 45 5f  c;.  if( SQLITE_
3540: 4e 4f 4d 45 4d 3d 3d 73 71 6c 69 74 65 33 41 70  NOMEM==sqlite3Ap
3550: 69 45 78 69 74 28 70 2d 3e 64 62 2c 20 70 2d 3e  iExit(p->db, p->
3560: 72 63 29 20 29 7b 0a 20 20 20 20 70 2d 3e 72 63  rc) ){.    p->rc
3570: 20 3d 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3b   = SQLITE_NOMEM;
3580: 0a 20 20 7d 0a 65 6e 64 5f 6f 66 5f 73 74 65 70  .  }.end_of_step
3590: 3a 0a 20 20 2f 2a 20 41 74 20 74 68 69 73 20 70  :.  /* At this p
35a0: 6f 69 6e 74 20 6c 6f 63 61 6c 20 76 61 72 69 61  oint local varia
35b0: 62 6c 65 20 72 63 20 68 6f 6c 64 73 20 74 68 65  ble rc holds the
35c0: 20 76 61 6c 75 65 20 74 68 61 74 20 73 68 6f 75   value that shou
35d0: 6c 64 20 62 65 20 0a 20 20 2a 2a 20 72 65 74 75  ld be .  ** retu
35e0: 72 6e 65 64 20 69 66 20 74 68 69 73 20 73 74 61  rned if this sta
35f0: 74 65 6d 65 6e 74 20 77 61 73 20 63 6f 6d 70 69  tement was compi
3600: 6c 65 64 20 75 73 69 6e 67 20 74 68 65 20 6c 65  led using the le
3610: 67 61 63 79 20 0a 20 20 2a 2a 20 73 71 6c 69 74  gacy .  ** sqlit
3620: 65 33 5f 70 72 65 70 61 72 65 28 29 20 69 6e 74  e3_prepare() int
3630: 65 72 66 61 63 65 2e 20 41 63 63 6f 72 64 69 6e  erface. Accordin
3640: 67 20 74 6f 20 74 68 65 20 64 6f 63 73 2c 20 74  g to the docs, t
3650: 68 69 73 20 63 61 6e 20 6f 6e 6c 79 0a 20 20 2a  his can only.  *
3660: 2a 20 62 65 20 6f 6e 65 20 6f 66 20 74 68 65 20  * be one of the 
3670: 76 61 6c 75 65 73 20 69 6e 20 74 68 65 20 66 69  values in the fi
3680: 72 73 74 20 61 73 73 65 72 74 28 29 20 62 65 6c  rst assert() bel
3690: 6f 77 2e 20 56 61 72 69 61 62 6c 65 20 70 2d 3e  ow. Variable p->
36a0: 72 63 20 0a 20 20 2a 2a 20 63 6f 6e 74 61 69 6e  rc .  ** contain
36b0: 73 20 74 68 65 20 76 61 6c 75 65 20 74 68 61 74  s the value that
36c0: 20 77 6f 75 6c 64 20 62 65 20 72 65 74 75 72 6e   would be return
36d0: 65 64 20 69 66 20 73 71 6c 69 74 65 33 5f 66 69  ed if sqlite3_fi
36e0: 6e 61 6c 69 7a 65 28 29 20 0a 20 20 2a 2a 20 77  nalize() .  ** w
36f0: 65 72 65 20 63 61 6c 6c 65 64 20 6f 6e 20 73 74  ere called on st
3700: 61 74 65 6d 65 6e 74 20 70 2e 0a 20 20 2a 2f 0a  atement p..  */.
3710: 20 20 61 73 73 65 72 74 28 20 72 63 3d 3d 53 51    assert( rc==SQ
3720: 4c 49 54 45 5f 52 4f 57 20 20 7c 7c 20 72 63 3d  LITE_ROW  || rc=
3730: 3d 53 51 4c 49 54 45 5f 44 4f 4e 45 20 20 20 7c  =SQLITE_DONE   |
3740: 7c 20 72 63 3d 3d 53 51 4c 49 54 45 5f 45 52 52  | rc==SQLITE_ERR
3750: 4f 52 20 0a 20 20 20 20 20 20 20 7c 7c 20 72 63  OR .       || rc
3760: 3d 3d 53 51 4c 49 54 45 5f 42 55 53 59 20 7c 7c  ==SQLITE_BUSY ||
3770: 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4d 49 53 55   rc==SQLITE_MISU
3780: 53 45 0a 20 20 29 3b 0a 20 20 61 73 73 65 72 74  SE.  );.  assert
3790: 28 20 70 2d 3e 72 63 21 3d 53 51 4c 49 54 45 5f  ( p->rc!=SQLITE_
37a0: 52 4f 57 20 26 26 20 70 2d 3e 72 63 21 3d 53 51  ROW && p->rc!=SQ
37b0: 4c 49 54 45 5f 44 4f 4e 45 20 29 3b 0a 20 20 69  LITE_DONE );.  i
37c0: 66 28 20 70 2d 3e 69 73 50 72 65 70 61 72 65 56  f( p->isPrepareV
37d0: 32 20 26 26 20 72 63 21 3d 53 51 4c 49 54 45 5f  2 && rc!=SQLITE_
37e0: 52 4f 57 20 26 26 20 72 63 21 3d 53 51 4c 49 54  ROW && rc!=SQLIT
37f0: 45 5f 44 4f 4e 45 20 29 7b 0a 20 20 20 20 2f 2a  E_DONE ){.    /*
3800: 20 49 66 20 74 68 69 73 20 73 74 61 74 65 6d 65   If this stateme
3810: 6e 74 20 77 61 73 20 70 72 65 70 61 72 65 64 20  nt was prepared 
3820: 75 73 69 6e 67 20 73 71 6c 69 74 65 33 5f 70 72  using sqlite3_pr
3830: 65 70 61 72 65 5f 76 32 28 29 2c 20 61 6e 64 20  epare_v2(), and 
3840: 61 6e 0a 20 20 20 20 2a 2a 20 65 72 72 6f 72 20  an.    ** error 
3850: 68 61 73 20 6f 63 63 75 72 65 64 2c 20 74 68 65  has occured, the
3860: 6e 20 72 65 74 75 72 6e 20 74 68 65 20 65 72 72  n return the err
3870: 6f 72 20 63 6f 64 65 20 69 6e 20 70 2d 3e 72 63  or code in p->rc
3880: 20 74 6f 20 74 68 65 0a 20 20 20 20 2a 2a 20 63   to the.    ** c
3890: 61 6c 6c 65 72 2e 20 53 65 74 20 74 68 65 20 65  aller. Set the e
38a0: 72 72 6f 72 20 63 6f 64 65 20 69 6e 20 74 68 65  rror code in the
38b0: 20 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c 65   database handle
38c0: 20 74 6f 20 74 68 65 20 73 61 6d 65 20 76 61 6c   to the same val
38d0: 75 65 2e 0a 20 20 20 20 2a 2f 20 0a 20 20 20 20  ue..    */ .    
38e0: 72 63 20 3d 20 64 62 2d 3e 65 72 72 43 6f 64 65  rc = db->errCode
38f0: 20 3d 20 70 2d 3e 72 63 3b 0a 20 20 7d 0a 20 20   = p->rc;.  }.  
3900: 72 65 74 75 72 6e 20 28 72 63 26 64 62 2d 3e 65  return (rc&db->e
3910: 72 72 4d 61 73 6b 29 3b 0a 7d 0a 0a 2f 2a 0a 2a  rrMask);.}../*.*
3920: 2a 20 54 68 69 73 20 69 73 20 74 68 65 20 74 6f  * This is the to
3930: 70 2d 6c 65 76 65 6c 20 69 6d 70 6c 65 6d 65 6e  p-level implemen
3940: 74 61 74 69 6f 6e 20 6f 66 20 73 71 6c 69 74 65  tation of sqlite
3950: 33 5f 73 74 65 70 28 29 2e 20 20 43 61 6c 6c 0a  3_step().  Call.
3960: 2a 2a 20 73 71 6c 69 74 65 33 53 74 65 70 28 29  ** sqlite3Step()
3970: 20 74 6f 20 64 6f 20 6d 6f 73 74 20 6f 66 20 74   to do most of t
3980: 68 65 20 77 6f 72 6b 2e 20 20 49 66 20 61 20 73  he work.  If a s
3990: 63 68 65 6d 61 20 65 72 72 6f 72 20 6f 63 63 75  chema error occu
39a0: 72 73 2c 0a 2a 2a 20 63 61 6c 6c 20 73 71 6c 69  rs,.** call sqli
39b0: 74 65 33 52 65 70 72 65 70 61 72 65 28 29 20 61  te3Reprepare() a
39c0: 6e 64 20 74 72 79 20 61 67 61 69 6e 2e 0a 2a 2f  nd try again..*/
39d0: 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f 73 74 65  .int sqlite3_ste
39e0: 70 28 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a  p(sqlite3_stmt *
39f0: 70 53 74 6d 74 29 7b 0a 20 20 69 6e 74 20 72 63  pStmt){.  int rc
3a00: 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b 20 20 20   = SQLITE_OK;   
3a10: 20 20 20 2f 2a 20 52 65 73 75 6c 74 20 66 72 6f     /* Result fro
3a20: 6d 20 73 71 6c 69 74 65 33 53 74 65 70 28 29 20  m sqlite3Step() 
3a30: 2a 2f 0a 20 20 69 6e 74 20 72 63 32 20 3d 20 53  */.  int rc2 = S
3a40: 51 4c 49 54 45 5f 4f 4b 3b 20 20 20 20 20 2f 2a  QLITE_OK;     /*
3a50: 20 52 65 73 75 6c 74 20 66 72 6f 6d 20 73 71 6c   Result from sql
3a60: 69 74 65 33 52 65 70 72 65 70 61 72 65 28 29 20  ite3Reprepare() 
3a70: 2a 2f 0a 20 20 56 64 62 65 20 2a 76 20 3d 20 28  */.  Vdbe *v = (
3a80: 56 64 62 65 2a 29 70 53 74 6d 74 3b 20 20 2f 2a  Vdbe*)pStmt;  /*
3a90: 20 74 68 65 20 70 72 65 70 61 72 65 64 20 73 74   the prepared st
3aa0: 61 74 65 6d 65 6e 74 20 2a 2f 0a 20 20 69 6e 74  atement */.  int
3ab0: 20 63 6e 74 20 3d 20 30 3b 20 20 20 20 20 20 20   cnt = 0;       
3ac0: 20 20 20 20 20 20 2f 2a 20 43 6f 75 6e 74 65 72        /* Counter
3ad0: 20 74 6f 20 70 72 65 76 65 6e 74 20 69 6e 66 69   to prevent infi
3ae0: 6e 69 74 65 20 6c 6f 6f 70 20 6f 66 20 72 65 70  nite loop of rep
3af0: 72 65 70 61 72 65 73 20 2a 2f 0a 20 20 73 71 6c  repares */.  sql
3b00: 69 74 65 33 20 2a 64 62 3b 20 20 20 20 20 20 20  ite3 *db;       
3b10: 20 20 20 20 20 20 2f 2a 20 54 68 65 20 64 61 74        /* The dat
3b20: 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e  abase connection
3b30: 20 2a 2f 0a 0a 20 20 69 66 28 20 76 64 62 65 53   */..  if( vdbeS
3b40: 61 66 65 74 79 4e 6f 74 4e 75 6c 6c 28 76 29 20  afetyNotNull(v) 
3b50: 29 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 53 51  ){.    return SQ
3b60: 4c 49 54 45 5f 4d 49 53 55 53 45 5f 42 4b 50 54  LITE_MISUSE_BKPT
3b70: 3b 0a 20 20 7d 0a 20 20 64 62 20 3d 20 76 2d 3e  ;.  }.  db = v->
3b80: 64 62 3b 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75  db;.  sqlite3_mu
3b90: 74 65 78 5f 65 6e 74 65 72 28 64 62 2d 3e 6d 75  tex_enter(db->mu
3ba0: 74 65 78 29 3b 0a 20 20 77 68 69 6c 65 28 20 28  tex);.  while( (
3bb0: 72 63 20 3d 20 73 71 6c 69 74 65 33 53 74 65 70  rc = sqlite3Step
3bc0: 28 76 29 29 3d 3d 53 51 4c 49 54 45 5f 53 43 48  (v))==SQLITE_SCH
3bd0: 45 4d 41 0a 20 20 20 20 20 20 20 20 20 26 26 20  EMA.         && 
3be0: 63 6e 74 2b 2b 20 3c 20 35 0a 20 20 20 20 20 20  cnt++ < 5.      
3bf0: 20 20 20 26 26 20 28 72 63 32 20 3d 20 72 63 20     && (rc2 = rc 
3c00: 3d 20 73 71 6c 69 74 65 33 52 65 70 72 65 70 61  = sqlite3Reprepa
3c10: 72 65 28 76 29 29 3d 3d 53 51 4c 49 54 45 5f 4f  re(v))==SQLITE_O
3c20: 4b 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33  K ){.    sqlite3
3c30: 5f 72 65 73 65 74 28 70 53 74 6d 74 29 3b 0a 20  _reset(pStmt);. 
3c40: 20 20 20 76 2d 3e 65 78 70 69 72 65 64 20 3d 20     v->expired = 
3c50: 30 3b 0a 20 20 7d 0a 20 20 69 66 28 20 72 63 32  0;.  }.  if( rc2
3c60: 21 3d 53 51 4c 49 54 45 5f 4f 4b 20 26 26 20 41  !=SQLITE_OK && A
3c70: 4c 57 41 59 53 28 76 2d 3e 69 73 50 72 65 70 61  LWAYS(v->isPrepa
3c80: 72 65 56 32 29 20 26 26 20 41 4c 57 41 59 53 28  reV2) && ALWAYS(
3c90: 64 62 2d 3e 70 45 72 72 29 20 29 7b 0a 20 20 20  db->pErr) ){.   
3ca0: 20 2f 2a 20 54 68 69 73 20 63 61 73 65 20 6f 63   /* This case oc
3cb0: 63 75 72 73 20 61 66 74 65 72 20 66 61 69 6c 69  curs after faili
3cc0: 6e 67 20 74 6f 20 72 65 63 6f 6d 70 69 6c 65 20  ng to recompile 
3cd0: 61 6e 20 73 71 6c 20 73 74 61 74 65 6d 65 6e 74  an sql statement
3ce0: 2e 20 0a 20 20 20 20 2a 2a 20 54 68 65 20 65 72  . .    ** The er
3cf0: 72 6f 72 20 6d 65 73 73 61 67 65 20 66 72 6f 6d  ror message from
3d00: 20 74 68 65 20 53 51 4c 20 63 6f 6d 70 69 6c 65   the SQL compile
3d10: 72 20 68 61 73 20 61 6c 72 65 61 64 79 20 62 65  r has already be
3d20: 65 6e 20 6c 6f 61 64 65 64 20 0a 20 20 20 20 2a  en loaded .    *
3d30: 2a 20 69 6e 74 6f 20 74 68 65 20 64 61 74 61 62  * into the datab
3d40: 61 73 65 20 68 61 6e 64 6c 65 2e 20 54 68 69 73  ase handle. This
3d50: 20 62 6c 6f 63 6b 20 63 6f 70 69 65 73 20 74 68   block copies th
3d60: 65 20 65 72 72 6f 72 20 6d 65 73 73 61 67 65 20  e error message 
3d70: 0a 20 20 20 20 2a 2a 20 66 72 6f 6d 20 74 68 65  .    ** from the
3d80: 20 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c 65   database handle
3d90: 20 69 6e 74 6f 20 74 68 65 20 73 74 61 74 65 6d   into the statem
3da0: 65 6e 74 20 61 6e 64 20 73 65 74 73 20 74 68 65  ent and sets the
3db0: 20 73 74 61 74 65 6d 65 6e 74 0a 20 20 20 20 2a   statement.    *
3dc0: 2a 20 70 72 6f 67 72 61 6d 20 63 6f 75 6e 74 65  * program counte
3dd0: 72 20 74 6f 20 30 20 74 6f 20 65 6e 73 75 72 65  r to 0 to ensure
3de0: 20 74 68 61 74 20 77 68 65 6e 20 74 68 65 20 73   that when the s
3df0: 74 61 74 65 6d 65 6e 74 20 69 73 20 0a 20 20 20  tatement is .   
3e00: 20 2a 2a 20 66 69 6e 61 6c 69 7a 65 64 20 6f 72   ** finalized or
3e10: 20 72 65 73 65 74 20 74 68 65 20 70 61 72 73 65   reset the parse
3e20: 72 20 65 72 72 6f 72 20 6d 65 73 73 61 67 65 20  r error message 
3e30: 69 73 20 61 76 61 69 6c 61 62 6c 65 20 76 69 61  is available via
3e40: 0a 20 20 20 20 2a 2a 20 73 71 6c 69 74 65 33 5f  .    ** sqlite3_
3e50: 65 72 72 6d 73 67 28 29 20 61 6e 64 20 73 71 6c  errmsg() and sql
3e60: 69 74 65 33 5f 65 72 72 63 6f 64 65 28 29 2e 0a  ite3_errcode()..
3e70: 20 20 20 20 2a 2f 0a 20 20 20 20 63 6f 6e 73 74      */.    const
3e80: 20 63 68 61 72 20 2a 7a 45 72 72 20 3d 20 28 63   char *zErr = (c
3e90: 6f 6e 73 74 20 63 68 61 72 20 2a 29 73 71 6c 69  onst char *)sqli
3ea0: 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74 28 64  te3_value_text(d
3eb0: 62 2d 3e 70 45 72 72 29 3b 20 0a 20 20 20 20 73  b->pErr); .    s
3ec0: 71 6c 69 74 65 33 44 62 46 72 65 65 28 64 62 2c  qlite3DbFree(db,
3ed0: 20 76 2d 3e 7a 45 72 72 4d 73 67 29 3b 0a 20 20   v->zErrMsg);.  
3ee0: 20 20 69 66 28 20 21 64 62 2d 3e 6d 61 6c 6c 6f    if( !db->mallo
3ef0: 63 46 61 69 6c 65 64 20 29 7b 0a 20 20 20 20 20  cFailed ){.     
3f00: 20 76 2d 3e 7a 45 72 72 4d 73 67 20 3d 20 73 71   v->zErrMsg = sq
3f10: 6c 69 74 65 33 44 62 53 74 72 44 75 70 28 64 62  lite3DbStrDup(db
3f20: 2c 20 7a 45 72 72 29 3b 0a 20 20 20 20 20 20 76  , zErr);.      v
3f30: 2d 3e 72 63 20 3d 20 72 63 32 3b 0a 20 20 20 20  ->rc = rc2;.    
3f40: 7d 20 65 6c 73 65 20 7b 0a 20 20 20 20 20 20 76  } else {.      v
3f50: 2d 3e 7a 45 72 72 4d 73 67 20 3d 20 30 3b 0a 20  ->zErrMsg = 0;. 
3f60: 20 20 20 20 20 76 2d 3e 72 63 20 3d 20 72 63 20       v->rc = rc 
3f70: 3d 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3b 0a  = SQLITE_NOMEM;.
3f80: 20 20 20 20 7d 0a 20 20 7d 0a 20 20 72 63 20 3d      }.  }.  rc =
3f90: 20 73 71 6c 69 74 65 33 41 70 69 45 78 69 74 28   sqlite3ApiExit(
3fa0: 64 62 2c 20 72 63 29 3b 0a 20 20 73 71 6c 69 74  db, rc);.  sqlit
3fb0: 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 64  e3_mutex_leave(d
3fc0: 62 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 72 65 74  b->mutex);.  ret
3fd0: 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  urn rc;.}../*.**
3fe0: 20 45 78 74 72 61 63 74 20 74 68 65 20 75 73 65   Extract the use
3ff0: 72 20 64 61 74 61 20 66 72 6f 6d 20 61 20 73 71  r data from a sq
4000: 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 73 74  lite3_context st
4010: 72 75 63 74 75 72 65 20 61 6e 64 20 72 65 74 75  ructure and retu
4020: 72 6e 20 61 0a 2a 2a 20 70 6f 69 6e 74 65 72 20  rn a.** pointer 
4030: 74 6f 20 69 74 2e 0a 2a 2f 0a 76 6f 69 64 20 2a  to it..*/.void *
4040: 73 71 6c 69 74 65 33 5f 75 73 65 72 5f 64 61 74  sqlite3_user_dat
4050: 61 28 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78  a(sqlite3_contex
4060: 74 20 2a 70 29 7b 0a 20 20 61 73 73 65 72 74 28  t *p){.  assert(
4070: 20 70 20 26 26 20 70 2d 3e 70 46 75 6e 63 20 29   p && p->pFunc )
4080: 3b 0a 20 20 72 65 74 75 72 6e 20 70 2d 3e 70 46  ;.  return p->pF
4090: 75 6e 63 2d 3e 70 55 73 65 72 44 61 74 61 3b 0a  unc->pUserData;.
40a0: 7d 0a 0a 2f 2a 0a 2a 2a 20 45 78 74 72 61 63 74  }../*.** Extract
40b0: 20 74 68 65 20 75 73 65 72 20 64 61 74 61 20 66   the user data f
40c0: 72 6f 6d 20 61 20 73 71 6c 69 74 65 33 5f 63 6f  rom a sqlite3_co
40d0: 6e 74 65 78 74 20 73 74 72 75 63 74 75 72 65 20  ntext structure 
40e0: 61 6e 64 20 72 65 74 75 72 6e 20 61 0a 2a 2a 20  and return a.** 
40f0: 70 6f 69 6e 74 65 72 20 74 6f 20 69 74 2e 0a 2a  pointer to it..*
4100: 2a 0a 2a 2a 20 49 4d 50 4c 45 4d 45 4e 54 41 54  *.** IMPLEMENTAT
4110: 49 4f 4e 2d 4f 46 3a 20 52 2d 34 36 37 39 38 2d  ION-OF: R-46798-
4120: 35 30 33 30 31 20 54 68 65 20 73 71 6c 69 74 65  50301 The sqlite
4130: 33 5f 63 6f 6e 74 65 78 74 5f 64 62 5f 68 61 6e  3_context_db_han
4140: 64 6c 65 28 29 20 69 6e 74 65 72 66 61 63 65 0a  dle() interface.
4150: 2a 2a 20 72 65 74 75 72 6e 73 20 61 20 63 6f 70  ** returns a cop
4160: 79 20 6f 66 20 74 68 65 20 70 6f 69 6e 74 65 72  y of the pointer
4170: 20 74 6f 20 74 68 65 20 64 61 74 61 62 61 73 65   to the database
4180: 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 28 74 68 65   connection (the
4190: 20 31 73 74 0a 2a 2a 20 70 61 72 61 6d 65 74 65   1st.** paramete
41a0: 72 29 20 6f 66 20 74 68 65 20 73 71 6c 69 74 65  r) of the sqlite
41b0: 33 5f 63 72 65 61 74 65 5f 66 75 6e 63 74 69 6f  3_create_functio
41c0: 6e 28 29 20 61 6e 64 0a 2a 2a 20 73 71 6c 69 74  n() and.** sqlit
41d0: 65 33 5f 63 72 65 61 74 65 5f 66 75 6e 63 74 69  e3_create_functi
41e0: 6f 6e 31 36 28 29 20 72 6f 75 74 69 6e 65 73 20  on16() routines 
41f0: 74 68 61 74 20 6f 72 69 67 69 6e 61 6c 6c 79 20  that originally 
4200: 72 65 67 69 73 74 65 72 65 64 20 74 68 65 0a 2a  registered the.*
4210: 2a 20 61 70 70 6c 69 63 61 74 69 6f 6e 20 64 65  * application de
4220: 66 69 6e 65 64 20 66 75 6e 63 74 69 6f 6e 2e 0a  fined function..
4230: 2a 2f 0a 73 71 6c 69 74 65 33 20 2a 73 71 6c 69  */.sqlite3 *sqli
4240: 74 65 33 5f 63 6f 6e 74 65 78 74 5f 64 62 5f 68  te3_context_db_h
4250: 61 6e 64 6c 65 28 73 71 6c 69 74 65 33 5f 63 6f  andle(sqlite3_co
4260: 6e 74 65 78 74 20 2a 70 29 7b 0a 20 20 61 73 73  ntext *p){.  ass
4270: 65 72 74 28 20 70 20 26 26 20 70 2d 3e 70 46 75  ert( p && p->pFu
4280: 6e 63 20 29 3b 0a 20 20 72 65 74 75 72 6e 20 70  nc );.  return p
4290: 2d 3e 73 2e 64 62 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  ->s.db;.}../*.**
42a0: 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 69   The following i
42b0: 73 20 74 68 65 20 69 6d 70 6c 65 6d 65 6e 74 61  s the implementa
42c0: 74 69 6f 6e 20 6f 66 20 61 6e 20 53 51 4c 20 66  tion of an SQL f
42d0: 75 6e 63 74 69 6f 6e 20 74 68 61 74 20 61 6c 77  unction that alw
42e0: 61 79 73 0a 2a 2a 20 66 61 69 6c 73 20 77 69 74  ays.** fails wit
42f0: 68 20 61 6e 20 65 72 72 6f 72 20 6d 65 73 73 61  h an error messa
4300: 67 65 20 73 74 61 74 69 6e 67 20 74 68 61 74 20  ge stating that 
4310: 74 68 65 20 66 75 6e 63 74 69 6f 6e 20 69 73 20  the function is 
4320: 75 73 65 64 20 69 6e 20 74 68 65 0a 2a 2a 20 77  used in the.** w
4330: 72 6f 6e 67 20 63 6f 6e 74 65 78 74 2e 20 20 54  rong context.  T
4340: 68 65 20 73 71 6c 69 74 65 33 5f 6f 76 65 72 6c  he sqlite3_overl
4350: 6f 61 64 5f 66 75 6e 63 74 69 6f 6e 28 29 20 41  oad_function() A
4360: 50 49 20 6d 69 67 68 74 20 63 6f 6e 73 74 72 75  PI might constru
4370: 63 74 0a 2a 2a 20 53 51 4c 20 66 75 6e 63 74 69  ct.** SQL functi
4380: 6f 6e 20 74 68 61 74 20 75 73 65 20 74 68 69 73  on that use this
4390: 20 72 6f 75 74 69 6e 65 20 73 6f 20 74 68 61 74   routine so that
43a0: 20 74 68 65 20 66 75 6e 63 74 69 6f 6e 73 20 77   the functions w
43b0: 69 6c 6c 20 65 78 69 73 74 0a 2a 2a 20 66 6f 72  ill exist.** for
43c0: 20 6e 61 6d 65 20 72 65 73 6f 6c 75 74 69 6f 6e   name resolution
43d0: 20 62 75 74 20 61 72 65 20 61 63 74 75 61 6c 6c   but are actuall
43e0: 79 20 6f 76 65 72 6c 6f 61 64 65 64 20 62 79 20  y overloaded by 
43f0: 74 68 65 20 78 46 69 6e 64 46 75 6e 63 74 69 6f  the xFindFunctio
4400: 6e 0a 2a 2a 20 6d 65 74 68 6f 64 20 6f 66 20 76  n.** method of v
4410: 69 72 74 75 61 6c 20 74 61 62 6c 65 73 2e 0a 2a  irtual tables..*
4420: 2f 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 49 6e  /.void sqlite3In
4430: 76 61 6c 69 64 46 75 6e 63 74 69 6f 6e 28 0a 20  validFunction(. 
4440: 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74   sqlite3_context
4450: 20 2a 63 6f 6e 74 65 78 74 2c 20 20 2f 2a 20 54   *context,  /* T
4460: 68 65 20 66 75 6e 63 74 69 6f 6e 20 63 61 6c 6c  he function call
4470: 69 6e 67 20 63 6f 6e 74 65 78 74 20 2a 2f 0a 20  ing context */. 
4480: 20 69 6e 74 20 4e 6f 74 55 73 65 64 2c 20 20 20   int NotUsed,   
4490: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e              /* N
44a0: 75 6d 62 65 72 20 6f 66 20 61 72 67 75 6d 65 6e  umber of argumen
44b0: 74 73 20 74 6f 20 74 68 65 20 66 75 6e 63 74 69  ts to the functi
44c0: 6f 6e 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f  on */.  sqlite3_
44d0: 76 61 6c 75 65 20 2a 2a 4e 6f 74 55 73 65 64 32  value **NotUsed2
44e0: 20 20 20 2f 2a 20 56 61 6c 75 65 20 6f 66 20 65     /* Value of e
44f0: 61 63 68 20 61 72 67 75 6d 65 6e 74 20 2a 2f 0a  ach argument */.
4500: 29 7b 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20  ){.  const char 
4510: 2a 7a 4e 61 6d 65 20 3d 20 63 6f 6e 74 65 78 74  *zName = context
4520: 2d 3e 70 46 75 6e 63 2d 3e 7a 4e 61 6d 65 3b 0a  ->pFunc->zName;.
4530: 20 20 63 68 61 72 20 2a 7a 45 72 72 3b 0a 20 20    char *zErr;.  
4540: 55 4e 55 53 45 44 5f 50 41 52 41 4d 45 54 45 52  UNUSED_PARAMETER
4550: 32 28 4e 6f 74 55 73 65 64 2c 20 4e 6f 74 55 73  2(NotUsed, NotUs
4560: 65 64 32 29 3b 0a 20 20 7a 45 72 72 20 3d 20 73  ed2);.  zErr = s
4570: 71 6c 69 74 65 33 5f 6d 70 72 69 6e 74 66 28 0a  qlite3_mprintf(.
4580: 20 20 20 20 20 20 22 75 6e 61 62 6c 65 20 74 6f        "unable to
4590: 20 75 73 65 20 66 75 6e 63 74 69 6f 6e 20 25 73   use function %s
45a0: 20 69 6e 20 74 68 65 20 72 65 71 75 65 73 74 65   in the requeste
45b0: 64 20 63 6f 6e 74 65 78 74 22 2c 20 7a 4e 61 6d  d context", zNam
45c0: 65 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 72 65  e);.  sqlite3_re
45d0: 73 75 6c 74 5f 65 72 72 6f 72 28 63 6f 6e 74 65  sult_error(conte
45e0: 78 74 2c 20 7a 45 72 72 2c 20 2d 31 29 3b 0a 20  xt, zErr, -1);. 
45f0: 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 7a 45   sqlite3_free(zE
4600: 72 72 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 41 6c  rr);.}../*.** Al
4610: 6c 6f 63 61 74 65 20 6f 72 20 72 65 74 75 72 6e  locate or return
4620: 20 74 68 65 20 61 67 67 72 65 67 61 74 65 20 63   the aggregate c
4630: 6f 6e 74 65 78 74 20 66 6f 72 20 61 20 75 73 65  ontext for a use
4640: 72 20 66 75 6e 63 74 69 6f 6e 2e 20 20 41 20 6e  r function.  A n
4650: 65 77 0a 2a 2a 20 63 6f 6e 74 65 78 74 20 69 73  ew.** context is
4660: 20 61 6c 6c 6f 63 61 74 65 64 20 6f 6e 20 74 68   allocated on th
4670: 65 20 66 69 72 73 74 20 63 61 6c 6c 2e 20 20 53  e first call.  S
4680: 75 62 73 65 71 75 65 6e 74 20 63 61 6c 6c 73 20  ubsequent calls 
4690: 72 65 74 75 72 6e 20 74 68 65 0a 2a 2a 20 73 61  return the.** sa
46a0: 6d 65 20 63 6f 6e 74 65 78 74 20 74 68 61 74 20  me context that 
46b0: 77 61 73 20 72 65 74 75 72 6e 65 64 20 6f 6e 20  was returned on 
46c0: 70 72 69 6f 72 20 63 61 6c 6c 73 2e 0a 2a 2f 0a  prior calls..*/.
46d0: 76 6f 69 64 20 2a 73 71 6c 69 74 65 33 5f 61 67  void *sqlite3_ag
46e0: 67 72 65 67 61 74 65 5f 63 6f 6e 74 65 78 74 28  gregate_context(
46f0: 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20  sqlite3_context 
4700: 2a 70 2c 20 69 6e 74 20 6e 42 79 74 65 29 7b 0a  *p, int nByte){.
4710: 20 20 4d 65 6d 20 2a 70 4d 65 6d 3b 0a 20 20 61    Mem *pMem;.  a
4720: 73 73 65 72 74 28 20 70 20 26 26 20 70 2d 3e 70  ssert( p && p->p
4730: 46 75 6e 63 20 26 26 20 70 2d 3e 70 46 75 6e 63  Func && p->pFunc
4740: 2d 3e 78 53 74 65 70 20 29 3b 0a 20 20 61 73 73  ->xStep );.  ass
4750: 65 72 74 28 20 73 71 6c 69 74 65 33 5f 6d 75 74  ert( sqlite3_mut
4760: 65 78 5f 68 65 6c 64 28 70 2d 3e 73 2e 64 62 2d  ex_held(p->s.db-
4770: 3e 6d 75 74 65 78 29 20 29 3b 0a 20 20 70 4d 65  >mutex) );.  pMe
4780: 6d 20 3d 20 70 2d 3e 70 4d 65 6d 3b 0a 20 20 74  m = p->pMem;.  t
4790: 65 73 74 63 61 73 65 28 20 6e 42 79 74 65 3c 30  estcase( nByte<0
47a0: 20 29 3b 0a 20 20 69 66 28 20 28 70 4d 65 6d 2d   );.  if( (pMem-
47b0: 3e 66 6c 61 67 73 20 26 20 4d 45 4d 5f 41 67 67  >flags & MEM_Agg
47c0: 29 3d 3d 30 20 29 7b 0a 20 20 20 20 69 66 28 20  )==0 ){.    if( 
47d0: 6e 42 79 74 65 3c 3d 30 20 29 7b 0a 20 20 20 20  nByte<=0 ){.    
47e0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 4d 65 6d    sqlite3VdbeMem
47f0: 52 65 6c 65 61 73 65 45 78 74 65 72 6e 61 6c 28  ReleaseExternal(
4800: 70 4d 65 6d 29 3b 0a 20 20 20 20 20 20 70 4d 65  pMem);.      pMe
4810: 6d 2d 3e 66 6c 61 67 73 20 3d 20 4d 45 4d 5f 4e  m->flags = MEM_N
4820: 75 6c 6c 3b 0a 20 20 20 20 20 20 70 4d 65 6d 2d  ull;.      pMem-
4830: 3e 7a 20 3d 20 30 3b 0a 20 20 20 20 7d 65 6c 73  >z = 0;.    }els
4840: 65 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  e{.      sqlite3
4850: 56 64 62 65 4d 65 6d 47 72 6f 77 28 70 4d 65 6d  VdbeMemGrow(pMem
4860: 2c 20 6e 42 79 74 65 2c 20 30 29 3b 0a 20 20 20  , nByte, 0);.   
4870: 20 20 20 70 4d 65 6d 2d 3e 66 6c 61 67 73 20 3d     pMem->flags =
4880: 20 4d 45 4d 5f 41 67 67 3b 0a 20 20 20 20 20 20   MEM_Agg;.      
4890: 70 4d 65 6d 2d 3e 75 2e 70 44 65 66 20 3d 20 70  pMem->u.pDef = p
48a0: 2d 3e 70 46 75 6e 63 3b 0a 20 20 20 20 20 20 69  ->pFunc;.      i
48b0: 66 28 20 70 4d 65 6d 2d 3e 7a 20 29 7b 0a 20 20  f( pMem->z ){.  
48c0: 20 20 20 20 20 20 6d 65 6d 73 65 74 28 70 4d 65        memset(pMe
48d0: 6d 2d 3e 7a 2c 20 30 2c 20 6e 42 79 74 65 29 3b  m->z, 0, nByte);
48e0: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20  .      }.    }. 
48f0: 20 7d 0a 20 20 72 65 74 75 72 6e 20 28 76 6f 69   }.  return (voi
4900: 64 2a 29 70 4d 65 6d 2d 3e 7a 3b 0a 7d 0a 0a 2f  d*)pMem->z;.}../
4910: 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20  *.** Return the 
4920: 61 75 78 69 6c 61 72 79 20 64 61 74 61 20 70 6f  auxilary data po
4930: 69 6e 74 65 72 2c 20 69 66 20 61 6e 79 2c 20 66  inter, if any, f
4940: 6f 72 20 74 68 65 20 69 41 72 67 27 74 68 20 61  or the iArg'th a
4950: 72 67 75 6d 65 6e 74 20 74 6f 0a 2a 2a 20 74 68  rgument to.** th
4960: 65 20 75 73 65 72 2d 66 75 6e 63 74 69 6f 6e 20  e user-function 
4970: 64 65 66 69 6e 65 64 20 62 79 20 70 43 74 78 2e  defined by pCtx.
4980: 0a 2a 2f 0a 76 6f 69 64 20 2a 73 71 6c 69 74 65  .*/.void *sqlite
4990: 33 5f 67 65 74 5f 61 75 78 64 61 74 61 28 73 71  3_get_auxdata(sq
49a0: 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70  lite3_context *p
49b0: 43 74 78 2c 20 69 6e 74 20 69 41 72 67 29 7b 0a  Ctx, int iArg){.
49c0: 20 20 56 64 62 65 46 75 6e 63 20 2a 70 56 64 62    VdbeFunc *pVdb
49d0: 65 46 75 6e 63 3b 0a 0a 20 20 61 73 73 65 72 74  eFunc;..  assert
49e0: 28 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f  ( sqlite3_mutex_
49f0: 68 65 6c 64 28 70 43 74 78 2d 3e 73 2e 64 62 2d  held(pCtx->s.db-
4a00: 3e 6d 75 74 65 78 29 20 29 3b 0a 20 20 70 56 64  >mutex) );.  pVd
4a10: 62 65 46 75 6e 63 20 3d 20 70 43 74 78 2d 3e 70  beFunc = pCtx->p
4a20: 56 64 62 65 46 75 6e 63 3b 0a 20 20 69 66 28 20  VdbeFunc;.  if( 
4a30: 21 70 56 64 62 65 46 75 6e 63 20 7c 7c 20 69 41  !pVdbeFunc || iA
4a40: 72 67 3e 3d 70 56 64 62 65 46 75 6e 63 2d 3e 6e  rg>=pVdbeFunc->n
4a50: 41 75 78 20 7c 7c 20 69 41 72 67 3c 30 20 29 7b  Aux || iArg<0 ){
4a60: 0a 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0a 20  .    return 0;. 
4a70: 20 7d 0a 20 20 72 65 74 75 72 6e 20 70 56 64 62   }.  return pVdb
4a80: 65 46 75 6e 63 2d 3e 61 70 41 75 78 5b 69 41 72  eFunc->apAux[iAr
4a90: 67 5d 2e 70 41 75 78 3b 0a 7d 0a 0a 2f 2a 0a 2a  g].pAux;.}../*.*
4aa0: 2a 20 53 65 74 20 74 68 65 20 61 75 78 69 6c 61  * Set the auxila
4ab0: 72 79 20 64 61 74 61 20 70 6f 69 6e 74 65 72 20  ry data pointer 
4ac0: 61 6e 64 20 64 65 6c 65 74 65 20 66 75 6e 63 74  and delete funct
4ad0: 69 6f 6e 2c 20 66 6f 72 20 74 68 65 20 69 41 72  ion, for the iAr
4ae0: 67 27 74 68 0a 2a 2a 20 61 72 67 75 6d 65 6e 74  g'th.** argument
4af0: 20 74 6f 20 74 68 65 20 75 73 65 72 2d 66 75 6e   to the user-fun
4b00: 63 74 69 6f 6e 20 64 65 66 69 6e 65 64 20 62 79  ction defined by
4b10: 20 70 43 74 78 2e 20 41 6e 79 20 70 72 65 76 69   pCtx. Any previ
4b20: 6f 75 73 20 76 61 6c 75 65 20 69 73 0a 2a 2a 20  ous value is.** 
4b30: 64 65 6c 65 74 65 64 20 62 79 20 63 61 6c 6c 69  deleted by calli
4b40: 6e 67 20 74 68 65 20 64 65 6c 65 74 65 20 66 75  ng the delete fu
4b50: 6e 63 74 69 6f 6e 20 73 70 65 63 69 66 69 65 64  nction specified
4b60: 20 77 68 65 6e 20 69 74 20 77 61 73 20 73 65 74   when it was set
4b70: 2e 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c 69 74 65  ..*/.void sqlite
4b80: 33 5f 73 65 74 5f 61 75 78 64 61 74 61 28 0a 20  3_set_auxdata(. 
4b90: 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74   sqlite3_context
4ba0: 20 2a 70 43 74 78 2c 20 0a 20 20 69 6e 74 20 69   *pCtx, .  int i
4bb0: 41 72 67 2c 20 0a 20 20 76 6f 69 64 20 2a 70 41  Arg, .  void *pA
4bc0: 75 78 2c 20 0a 20 20 76 6f 69 64 20 28 2a 78 44  ux, .  void (*xD
4bd0: 65 6c 65 74 65 29 28 76 6f 69 64 2a 29 0a 29 7b  elete)(void*).){
4be0: 0a 20 20 73 74 72 75 63 74 20 41 75 78 44 61 74  .  struct AuxDat
4bf0: 61 20 2a 70 41 75 78 44 61 74 61 3b 0a 20 20 56  a *pAuxData;.  V
4c00: 64 62 65 46 75 6e 63 20 2a 70 56 64 62 65 46 75  dbeFunc *pVdbeFu
4c10: 6e 63 3b 0a 20 20 69 66 28 20 69 41 72 67 3c 30  nc;.  if( iArg<0
4c20: 20 29 20 67 6f 74 6f 20 66 61 69 6c 65 64 3b 0a   ) goto failed;.
4c30: 0a 20 20 61 73 73 65 72 74 28 20 73 71 6c 69 74  .  assert( sqlit
4c40: 65 33 5f 6d 75 74 65 78 5f 68 65 6c 64 28 70 43  e3_mutex_held(pC
4c50: 74 78 2d 3e 73 2e 64 62 2d 3e 6d 75 74 65 78 29  tx->s.db->mutex)
4c60: 20 29 3b 0a 20 20 70 56 64 62 65 46 75 6e 63 20   );.  pVdbeFunc 
4c70: 3d 20 70 43 74 78 2d 3e 70 56 64 62 65 46 75 6e  = pCtx->pVdbeFun
4c80: 63 3b 0a 20 20 69 66 28 20 21 70 56 64 62 65 46  c;.  if( !pVdbeF
4c90: 75 6e 63 20 7c 7c 20 70 56 64 62 65 46 75 6e 63  unc || pVdbeFunc
4ca0: 2d 3e 6e 41 75 78 3c 3d 69 41 72 67 20 29 7b 0a  ->nAux<=iArg ){.
4cb0: 20 20 20 20 69 6e 74 20 6e 41 75 78 20 3d 20 28      int nAux = (
4cc0: 70 56 64 62 65 46 75 6e 63 20 3f 20 70 56 64 62  pVdbeFunc ? pVdb
4cd0: 65 46 75 6e 63 2d 3e 6e 41 75 78 20 3a 20 30 29  eFunc->nAux : 0)
4ce0: 3b 0a 20 20 20 20 69 6e 74 20 6e 4d 61 6c 6c 6f  ;.    int nMallo
4cf0: 63 20 3d 20 73 69 7a 65 6f 66 28 56 64 62 65 46  c = sizeof(VdbeF
4d00: 75 6e 63 29 20 2b 20 73 69 7a 65 6f 66 28 73 74  unc) + sizeof(st
4d10: 72 75 63 74 20 41 75 78 44 61 74 61 29 2a 69 41  ruct AuxData)*iA
4d20: 72 67 3b 0a 20 20 20 20 70 56 64 62 65 46 75 6e  rg;.    pVdbeFun
4d30: 63 20 3d 20 73 71 6c 69 74 65 33 44 62 52 65 61  c = sqlite3DbRea
4d40: 6c 6c 6f 63 28 70 43 74 78 2d 3e 73 2e 64 62 2c  lloc(pCtx->s.db,
4d50: 20 70 56 64 62 65 46 75 6e 63 2c 20 6e 4d 61 6c   pVdbeFunc, nMal
4d60: 6c 6f 63 29 3b 0a 20 20 20 20 69 66 28 20 21 70  loc);.    if( !p
4d70: 56 64 62 65 46 75 6e 63 20 29 7b 0a 20 20 20 20  VdbeFunc ){.    
4d80: 20 20 67 6f 74 6f 20 66 61 69 6c 65 64 3b 0a 20    goto failed;. 
4d90: 20 20 20 7d 0a 20 20 20 20 70 43 74 78 2d 3e 70     }.    pCtx->p
4da0: 56 64 62 65 46 75 6e 63 20 3d 20 70 56 64 62 65  VdbeFunc = pVdbe
4db0: 46 75 6e 63 3b 0a 20 20 20 20 6d 65 6d 73 65 74  Func;.    memset
4dc0: 28 26 70 56 64 62 65 46 75 6e 63 2d 3e 61 70 41  (&pVdbeFunc->apA
4dd0: 75 78 5b 6e 41 75 78 5d 2c 20 30 2c 20 73 69 7a  ux[nAux], 0, siz
4de0: 65 6f 66 28 73 74 72 75 63 74 20 41 75 78 44 61  eof(struct AuxDa
4df0: 74 61 29 2a 28 69 41 72 67 2b 31 2d 6e 41 75 78  ta)*(iArg+1-nAux
4e00: 29 29 3b 0a 20 20 20 20 70 56 64 62 65 46 75 6e  ));.    pVdbeFun
4e10: 63 2d 3e 6e 41 75 78 20 3d 20 69 41 72 67 2b 31  c->nAux = iArg+1
4e20: 3b 0a 20 20 20 20 70 56 64 62 65 46 75 6e 63 2d  ;.    pVdbeFunc-
4e30: 3e 70 46 75 6e 63 20 3d 20 70 43 74 78 2d 3e 70  >pFunc = pCtx->p
4e40: 46 75 6e 63 3b 0a 20 20 7d 0a 0a 20 20 70 41 75  Func;.  }..  pAu
4e50: 78 44 61 74 61 20 3d 20 26 70 56 64 62 65 46 75  xData = &pVdbeFu
4e60: 6e 63 2d 3e 61 70 41 75 78 5b 69 41 72 67 5d 3b  nc->apAux[iArg];
4e70: 0a 20 20 69 66 28 20 70 41 75 78 44 61 74 61 2d  .  if( pAuxData-
4e80: 3e 70 41 75 78 20 26 26 20 70 41 75 78 44 61 74  >pAux && pAuxDat
4e90: 61 2d 3e 78 44 65 6c 65 74 65 20 29 7b 0a 20 20  a->xDelete ){.  
4ea0: 20 20 70 41 75 78 44 61 74 61 2d 3e 78 44 65 6c    pAuxData->xDel
4eb0: 65 74 65 28 70 41 75 78 44 61 74 61 2d 3e 70 41  ete(pAuxData->pA
4ec0: 75 78 29 3b 0a 20 20 7d 0a 20 20 70 41 75 78 44  ux);.  }.  pAuxD
4ed0: 61 74 61 2d 3e 70 41 75 78 20 3d 20 70 41 75 78  ata->pAux = pAux
4ee0: 3b 0a 20 20 70 41 75 78 44 61 74 61 2d 3e 78 44  ;.  pAuxData->xD
4ef0: 65 6c 65 74 65 20 3d 20 78 44 65 6c 65 74 65 3b  elete = xDelete;
4f00: 0a 20 20 72 65 74 75 72 6e 3b 0a 0a 66 61 69 6c  .  return;..fail
4f10: 65 64 3a 0a 20 20 69 66 28 20 78 44 65 6c 65 74  ed:.  if( xDelet
4f20: 65 20 29 7b 0a 20 20 20 20 78 44 65 6c 65 74 65  e ){.    xDelete
4f30: 28 70 41 75 78 29 3b 0a 20 20 7d 0a 7d 0a 0a 23  (pAux);.  }.}..#
4f40: 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d  ifndef SQLITE_OM
4f50: 49 54 5f 44 45 50 52 45 43 41 54 45 44 0a 2f 2a  IT_DEPRECATED./*
4f60: 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20 6e  .** Return the n
4f70: 75 6d 62 65 72 20 6f 66 20 74 69 6d 65 73 20 74  umber of times t
4f80: 68 65 20 53 74 65 70 20 66 75 6e 63 74 69 6f 6e  he Step function
4f90: 20 6f 66 20 61 20 61 67 67 72 65 67 61 74 65 20   of a aggregate 
4fa0: 68 61 73 20 62 65 65 6e 20 0a 2a 2a 20 63 61 6c  has been .** cal
4fb0: 6c 65 64 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20  led..**.** This 
4fc0: 66 75 6e 63 74 69 6f 6e 20 69 73 20 64 65 70 72  function is depr
4fd0: 65 63 61 74 65 64 2e 20 20 44 6f 20 6e 6f 74 20  ecated.  Do not 
4fe0: 75 73 65 20 69 74 20 66 6f 72 20 6e 65 77 20 63  use it for new c
4ff0: 6f 64 65 2e 20 20 49 74 20 69 73 0a 2a 2a 20 70  ode.  It is.** p
5000: 72 6f 76 69 64 65 20 6f 6e 6c 79 20 74 6f 20 61  rovide only to a
5010: 76 6f 69 64 20 62 72 65 61 6b 69 6e 67 20 6c 65  void breaking le
5020: 67 61 63 79 20 63 6f 64 65 2e 20 20 4e 65 77 20  gacy code.  New 
5030: 61 67 67 72 65 67 61 74 65 20 66 75 6e 63 74 69  aggregate functi
5040: 6f 6e 0a 2a 2a 20 69 6d 70 6c 65 6d 65 6e 74 61  on.** implementa
5050: 74 69 6f 6e 73 20 73 68 6f 75 6c 64 20 6b 65 65  tions should kee
5060: 70 20 74 68 65 69 72 20 6f 77 6e 20 63 6f 75 6e  p their own coun
5070: 74 73 20 77 69 74 68 69 6e 20 74 68 65 69 72 20  ts within their 
5080: 61 67 67 72 65 67 61 74 65 0a 2a 2a 20 63 6f 6e  aggregate.** con
5090: 74 65 78 74 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c  text..*/.int sql
50a0: 69 74 65 33 5f 61 67 67 72 65 67 61 74 65 5f 63  ite3_aggregate_c
50b0: 6f 75 6e 74 28 73 71 6c 69 74 65 33 5f 63 6f 6e  ount(sqlite3_con
50c0: 74 65 78 74 20 2a 70 29 7b 0a 20 20 61 73 73 65  text *p){.  asse
50d0: 72 74 28 20 70 20 26 26 20 70 2d 3e 70 4d 65 6d  rt( p && p->pMem
50e0: 20 26 26 20 70 2d 3e 70 46 75 6e 63 20 26 26 20   && p->pFunc && 
50f0: 70 2d 3e 70 46 75 6e 63 2d 3e 78 53 74 65 70 20  p->pFunc->xStep 
5100: 29 3b 0a 20 20 72 65 74 75 72 6e 20 70 2d 3e 70  );.  return p->p
5110: 4d 65 6d 2d 3e 6e 3b 0a 7d 0a 23 65 6e 64 69 66  Mem->n;.}.#endif
5120: 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 74  ../*.** Return t
5130: 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 63 6f 6c  he number of col
5140: 75 6d 6e 73 20 69 6e 20 74 68 65 20 72 65 73 75  umns in the resu
5150: 6c 74 20 73 65 74 20 66 6f 72 20 74 68 65 20 73  lt set for the s
5160: 74 61 74 65 6d 65 6e 74 20 70 53 74 6d 74 2e 0a  tatement pStmt..
5170: 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f 63  */.int sqlite3_c
5180: 6f 6c 75 6d 6e 5f 63 6f 75 6e 74 28 73 71 6c 69  olumn_count(sqli
5190: 74 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d 74 29  te3_stmt *pStmt)
51a0: 7b 0a 20 20 56 64 62 65 20 2a 70 56 6d 20 3d 20  {.  Vdbe *pVm = 
51b0: 28 56 64 62 65 20 2a 29 70 53 74 6d 74 3b 0a 20  (Vdbe *)pStmt;. 
51c0: 20 72 65 74 75 72 6e 20 70 56 6d 20 3f 20 70 56   return pVm ? pV
51d0: 6d 2d 3e 6e 52 65 73 43 6f 6c 75 6d 6e 20 3a 20  m->nResColumn : 
51e0: 30 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75  0;.}../*.** Retu
51f0: 72 6e 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66  rn the number of
5200: 20 76 61 6c 75 65 73 20 61 76 61 69 6c 61 62 6c   values availabl
5210: 65 20 66 72 6f 6d 20 74 68 65 20 63 75 72 72 65  e from the curre
5220: 6e 74 20 72 6f 77 20 6f 66 20 74 68 65 0a 2a 2a  nt row of the.**
5230: 20 63 75 72 72 65 6e 74 6c 79 20 65 78 65 63 75   currently execu
5240: 74 69 6e 67 20 73 74 61 74 65 6d 65 6e 74 20 70  ting statement p
5250: 53 74 6d 74 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c  Stmt..*/.int sql
5260: 69 74 65 33 5f 64 61 74 61 5f 63 6f 75 6e 74 28  ite3_data_count(
5270: 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70 53  sqlite3_stmt *pS
5280: 74 6d 74 29 7b 0a 20 20 56 64 62 65 20 2a 70 56  tmt){.  Vdbe *pV
5290: 6d 20 3d 20 28 56 64 62 65 20 2a 29 70 53 74 6d  m = (Vdbe *)pStm
52a0: 74 3b 0a 20 20 69 66 28 20 70 56 6d 3d 3d 30 20  t;.  if( pVm==0 
52b0: 7c 7c 20 70 56 6d 2d 3e 70 52 65 73 75 6c 74 53  || pVm->pResultS
52c0: 65 74 3d 3d 30 20 29 20 72 65 74 75 72 6e 20 30  et==0 ) return 0
52d0: 3b 0a 20 20 72 65 74 75 72 6e 20 70 56 6d 2d 3e  ;.  return pVm->
52e0: 6e 52 65 73 43 6f 6c 75 6d 6e 3b 0a 7d 0a 0a 0a  nResColumn;.}...
52f0: 2f 2a 0a 2a 2a 20 43 68 65 63 6b 20 74 6f 20 73  /*.** Check to s
5300: 65 65 20 69 66 20 63 6f 6c 75 6d 6e 20 69 43 6f  ee if column iCo
5310: 6c 20 6f 66 20 74 68 65 20 67 69 76 65 6e 20 73  l of the given s
5320: 74 61 74 65 6d 65 6e 74 20 69 73 20 76 61 6c 69  tatement is vali
5330: 64 2e 20 20 49 66 0a 2a 2a 20 69 74 20 69 73 2c  d.  If.** it is,
5340: 20 72 65 74 75 72 6e 20 61 20 70 6f 69 6e 74 65   return a pointe
5350: 72 20 74 6f 20 74 68 65 20 4d 65 6d 20 66 6f 72  r to the Mem for
5360: 20 74 68 65 20 76 61 6c 75 65 20 6f 66 20 74 68   the value of th
5370: 61 74 20 63 6f 6c 75 6d 6e 2e 0a 2a 2a 20 49 66  at column..** If
5380: 20 69 43 6f 6c 20 69 73 20 6e 6f 74 20 76 61 6c   iCol is not val
5390: 69 64 2c 20 72 65 74 75 72 6e 20 61 20 70 6f 69  id, return a poi
53a0: 6e 74 65 72 20 74 6f 20 61 20 4d 65 6d 20 77 68  nter to a Mem wh
53b0: 69 63 68 20 68 61 73 20 61 20 76 61 6c 75 65 0a  ich has a value.
53c0: 2a 2a 20 6f 66 20 4e 55 4c 4c 2e 0a 2a 2f 0a 73  ** of NULL..*/.s
53d0: 74 61 74 69 63 20 4d 65 6d 20 2a 63 6f 6c 75 6d  tatic Mem *colum
53e0: 6e 4d 65 6d 28 73 71 6c 69 74 65 33 5f 73 74 6d  nMem(sqlite3_stm
53f0: 74 20 2a 70 53 74 6d 74 2c 20 69 6e 74 20 69 29  t *pStmt, int i)
5400: 7b 0a 20 20 56 64 62 65 20 2a 70 56 6d 3b 0a 20  {.  Vdbe *pVm;. 
5410: 20 4d 65 6d 20 2a 70 4f 75 74 3b 0a 0a 20 20 70   Mem *pOut;..  p
5420: 56 6d 20 3d 20 28 56 64 62 65 20 2a 29 70 53 74  Vm = (Vdbe *)pSt
5430: 6d 74 3b 0a 20 20 69 66 28 20 70 56 6d 20 26 26  mt;.  if( pVm &&
5440: 20 70 56 6d 2d 3e 70 52 65 73 75 6c 74 53 65 74   pVm->pResultSet
5450: 21 3d 30 20 26 26 20 69 3c 70 56 6d 2d 3e 6e 52  !=0 && i<pVm->nR
5460: 65 73 43 6f 6c 75 6d 6e 20 26 26 20 69 3e 3d 30  esColumn && i>=0
5470: 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f   ){.    sqlite3_
5480: 6d 75 74 65 78 5f 65 6e 74 65 72 28 70 56 6d 2d  mutex_enter(pVm-
5490: 3e 64 62 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 20  >db->mutex);.   
54a0: 20 70 4f 75 74 20 3d 20 26 70 56 6d 2d 3e 70 52   pOut = &pVm->pR
54b0: 65 73 75 6c 74 53 65 74 5b 69 5d 3b 0a 20 20 7d  esultSet[i];.  }
54c0: 65 6c 73 65 7b 0a 20 20 20 20 2f 2a 20 49 66 20  else{.    /* If 
54d0: 74 68 65 20 76 61 6c 75 65 20 70 61 73 73 65 64  the value passed
54e0: 20 61 73 20 74 68 65 20 73 65 63 6f 6e 64 20 61   as the second a
54f0: 72 67 75 6d 65 6e 74 20 69 73 20 6f 75 74 20 6f  rgument is out o
5500: 66 20 72 61 6e 67 65 2c 20 72 65 74 75 72 6e 0a  f range, return.
5510: 20 20 20 20 2a 2a 20 61 20 70 6f 69 6e 74 65 72      ** a pointer
5520: 20 74 6f 20 74 68 65 20 66 6f 6c 6c 6f 77 69 6e   to the followin
5530: 67 20 73 74 61 74 69 63 20 4d 65 6d 20 6f 62 6a  g static Mem obj
5540: 65 63 74 20 77 68 69 63 68 20 63 6f 6e 74 61 69  ect which contai
5550: 6e 73 20 74 68 65 0a 20 20 20 20 2a 2a 20 76 61  ns the.    ** va
5560: 6c 75 65 20 53 51 4c 20 4e 55 4c 4c 2e 20 45 76  lue SQL NULL. Ev
5570: 65 6e 20 74 68 6f 75 67 68 20 74 68 65 20 4d 65  en though the Me
5580: 6d 20 73 74 72 75 63 74 75 72 65 20 63 6f 6e 74  m structure cont
5590: 61 69 6e 73 20 61 6e 20 65 6c 65 6d 65 6e 74 0a  ains an element.
55a0: 20 20 20 20 2a 2a 20 6f 66 20 74 79 70 65 20 69      ** of type i
55b0: 36 34 2c 20 6f 6e 20 63 65 72 74 61 69 6e 20 61  64, on certain a
55c0: 72 63 68 69 74 65 63 74 75 72 65 20 28 78 38 36  rchitecture (x86
55d0: 29 20 77 69 74 68 20 63 65 72 74 61 69 6e 20 63  ) with certain c
55e0: 6f 6d 70 69 6c 65 72 0a 20 20 20 20 2a 2a 20 73  ompiler.    ** s
55f0: 77 69 74 63 68 65 73 20 28 2d 4f 73 29 2c 20 67  witches (-Os), g
5600: 63 63 20 6d 61 79 20 61 6c 69 67 6e 20 74 68 69  cc may align thi
5610: 73 20 4d 65 6d 20 6f 62 6a 65 63 74 20 6f 6e 20  s Mem object on 
5620: 61 20 34 2d 62 79 74 65 20 62 6f 75 6e 64 61 72  a 4-byte boundar
5630: 79 0a 20 20 20 20 2a 2a 20 69 6e 73 74 65 61 64  y.    ** instead
5640: 20 6f 66 20 61 6e 20 38 2d 62 79 74 65 20 6f 6e   of an 8-byte on
5650: 65 2e 20 54 68 69 73 20 61 6c 6c 20 77 6f 72 6b  e. This all work
5660: 73 20 66 69 6e 65 2c 20 65 78 63 65 70 74 20 74  s fine, except t
5670: 68 61 74 20 77 68 65 6e 0a 20 20 20 20 2a 2a 20  hat when.    ** 
5680: 72 75 6e 6e 69 6e 67 20 77 69 74 68 20 53 51 4c  running with SQL
5690: 49 54 45 5f 44 45 42 55 47 20 64 65 66 69 6e 65  ITE_DEBUG define
56a0: 64 20 74 68 65 20 53 51 4c 69 74 65 20 63 6f 64  d the SQLite cod
56b0: 65 20 73 6f 6d 65 74 69 6d 65 73 20 61 73 73 65  e sometimes asse
56c0: 72 74 28 29 73 0a 20 20 20 20 2a 2a 20 74 68 61  rt()s.    ** tha
56d0: 74 20 61 20 4d 65 6d 20 73 74 72 75 63 74 75 72  t a Mem structur
56e0: 65 20 69 73 20 6c 6f 63 61 74 65 64 20 6f 6e 20  e is located on 
56f0: 61 6e 20 38 2d 62 79 74 65 20 62 6f 75 6e 64 61  an 8-byte bounda
5700: 72 79 2e 20 54 6f 20 70 72 65 76 65 6e 74 0a 20  ry. To prevent. 
5710: 20 20 20 2a 2a 20 74 68 69 73 20 61 73 73 65 72     ** this asser
5720: 74 28 29 20 66 72 6f 6d 20 66 61 69 6c 69 6e 67  t() from failing
5730: 2c 20 77 68 65 6e 20 62 75 69 6c 64 69 6e 67 20  , when building 
5740: 77 69 74 68 20 53 51 4c 49 54 45 5f 44 45 42 55  with SQLITE_DEBU
5750: 47 20 64 65 66 69 6e 65 64 0a 20 20 20 20 2a 2a  G defined.    **
5760: 20 75 73 69 6e 67 20 67 63 63 2c 20 66 6f 72 63   using gcc, forc
5770: 65 20 6e 75 6c 6c 4d 65 6d 20 74 6f 20 62 65 20  e nullMem to be 
5780: 38 2d 62 79 74 65 20 61 6c 69 67 6e 65 64 20 75  8-byte aligned u
5790: 73 69 6e 67 20 74 68 65 20 6d 61 67 69 63 61 6c  sing the magical
57a0: 0a 20 20 20 20 2a 2a 20 5f 5f 61 74 74 72 69 62  .    ** __attrib
57b0: 75 74 65 5f 5f 28 28 61 6c 69 67 6e 65 64 28 38  ute__((aligned(8
57c0: 29 29 29 20 6d 61 63 72 6f 2e 20 20 2a 2f 0a 20  ))) macro.  */. 
57d0: 20 20 20 73 74 61 74 69 63 20 63 6f 6e 73 74 20     static const 
57e0: 4d 65 6d 20 6e 75 6c 6c 4d 65 6d 20 0a 23 69 66  Mem nullMem .#if
57f0: 20 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f   defined(SQLITE_
5800: 44 45 42 55 47 29 20 26 26 20 64 65 66 69 6e 65  DEBUG) && define
5810: 64 28 5f 5f 47 4e 55 43 5f 5f 29 0a 20 20 20 20  d(__GNUC__).    
5820: 20 20 5f 5f 61 74 74 72 69 62 75 74 65 5f 5f 28    __attribute__(
5830: 28 61 6c 69 67 6e 65 64 28 38 29 29 29 20 0a 23  (aligned(8))) .#
5840: 65 6e 64 69 66 0a 20 20 20 20 20 20 3d 20 7b 30  endif.      = {0
5850: 2c 20 22 22 2c 20 28 64 6f 75 62 6c 65 29 30 2c  , "", (double)0,
5860: 20 7b 30 7d 2c 20 30 2c 20 4d 45 4d 5f 4e 75 6c   {0}, 0, MEM_Nul
5870: 6c 2c 20 53 51 4c 49 54 45 5f 4e 55 4c 4c 2c 20  l, SQLITE_NULL, 
5880: 30 2c 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45  0,.#ifdef SQLITE
5890: 5f 44 45 42 55 47 0a 20 20 20 20 20 20 20 20 20  _DEBUG.         
58a0: 30 2c 20 30 2c 20 20 2f 2a 20 70 53 63 6f 70 79  0, 0,  /* pScopy
58b0: 46 72 6f 6d 2c 20 70 46 69 6c 6c 65 72 20 2a 2f  From, pFiller */
58c0: 0a 23 65 6e 64 69 66 0a 20 20 20 20 20 20 20 20  .#endif.        
58d0: 20 30 2c 20 30 20 7d 3b 0a 0a 20 20 20 20 69 66   0, 0 };..    if
58e0: 28 20 70 56 6d 20 26 26 20 41 4c 57 41 59 53 28  ( pVm && ALWAYS(
58f0: 70 56 6d 2d 3e 64 62 29 20 29 7b 0a 20 20 20 20  pVm->db) ){.    
5900: 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f    sqlite3_mutex_
5910: 65 6e 74 65 72 28 70 56 6d 2d 3e 64 62 2d 3e 6d  enter(pVm->db->m
5920: 75 74 65 78 29 3b 0a 20 20 20 20 20 20 73 71 6c  utex);.      sql
5930: 69 74 65 33 45 72 72 6f 72 28 70 56 6d 2d 3e 64  ite3Error(pVm->d
5940: 62 2c 20 53 51 4c 49 54 45 5f 52 41 4e 47 45 2c  b, SQLITE_RANGE,
5950: 20 30 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 70   0);.    }.    p
5960: 4f 75 74 20 3d 20 28 4d 65 6d 2a 29 26 6e 75 6c  Out = (Mem*)&nul
5970: 6c 4d 65 6d 3b 0a 20 20 7d 0a 20 20 72 65 74 75  lMem;.  }.  retu
5980: 72 6e 20 70 4f 75 74 3b 0a 7d 0a 0a 2f 2a 0a 2a  rn pOut;.}../*.*
5990: 2a 20 54 68 69 73 20 66 75 6e 63 74 69 6f 6e 20  * This function 
59a0: 69 73 20 63 61 6c 6c 65 64 20 61 66 74 65 72 20  is called after 
59b0: 69 6e 76 6f 6b 69 6e 67 20 61 6e 20 73 71 6c 69  invoking an sqli
59c0: 74 65 33 5f 76 61 6c 75 65 5f 58 58 58 20 66 75  te3_value_XXX fu
59d0: 6e 63 74 69 6f 6e 20 6f 6e 20 61 20 0a 2a 2a 20  nction on a .** 
59e0: 63 6f 6c 75 6d 6e 20 76 61 6c 75 65 20 28 69 2e  column value (i.
59f0: 65 2e 20 61 20 76 61 6c 75 65 20 72 65 74 75 72  e. a value retur
5a00: 6e 65 64 20 62 79 20 65 76 61 6c 75 61 74 69 6e  ned by evaluatin
5a10: 67 20 61 6e 20 53 51 4c 20 65 78 70 72 65 73 73  g an SQL express
5a20: 69 6f 6e 20 69 6e 20 74 68 65 0a 2a 2a 20 73 65  ion in the.** se
5a30: 6c 65 63 74 20 6c 69 73 74 20 6f 66 20 61 20 53  lect list of a S
5a40: 45 4c 45 43 54 20 73 74 61 74 65 6d 65 6e 74 29  ELECT statement)
5a50: 20 74 68 61 74 20 6d 61 79 20 63 61 75 73 65 20   that may cause 
5a60: 61 20 6d 61 6c 6c 6f 63 28 29 20 66 61 69 6c 75  a malloc() failu
5a70: 72 65 2e 20 49 66 20 0a 2a 2a 20 6d 61 6c 6c 6f  re. If .** mallo
5a80: 63 28 29 20 68 61 73 20 66 61 69 6c 65 64 2c 20  c() has failed, 
5a90: 74 68 65 20 74 68 72 65 61 64 73 20 6d 61 6c 6c  the threads mall
5aa0: 6f 63 46 61 69 6c 65 64 20 66 6c 61 67 20 69 73  ocFailed flag is
5ab0: 20 63 6c 65 61 72 65 64 20 61 6e 64 20 74 68 65   cleared and the
5ac0: 20 72 65 73 75 6c 74 0a 2a 2a 20 63 6f 64 65 20   result.** code 
5ad0: 6f 66 20 73 74 61 74 65 6d 65 6e 74 20 70 53 74  of statement pSt
5ae0: 6d 74 20 73 65 74 20 74 6f 20 53 51 4c 49 54 45  mt set to SQLITE
5af0: 5f 4e 4f 4d 45 4d 2e 0a 2a 2a 0a 2a 2a 20 53 70  _NOMEM..**.** Sp
5b00: 65 63 69 66 69 63 61 6c 6c 79 2c 20 74 68 69 73  ecifically, this
5b10: 20 69 73 20 63 61 6c 6c 65 64 20 66 72 6f 6d 20   is called from 
5b20: 77 69 74 68 69 6e 3a 0a 2a 2a 0a 2a 2a 20 20 20  within:.**.**   
5b30: 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e    sqlite3_column
5b40: 5f 69 6e 74 28 29 0a 2a 2a 20 20 20 20 20 73 71  _int().**     sq
5b50: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74  lite3_column_int
5b60: 36 34 28 29 0a 2a 2a 20 20 20 20 20 73 71 6c 69  64().**     sqli
5b70: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 28  te3_column_text(
5b80: 29 0a 2a 2a 20 20 20 20 20 73 71 6c 69 74 65 33  ).**     sqlite3
5b90: 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 31 36 28 29  _column_text16()
5ba0: 0a 2a 2a 20 20 20 20 20 73 71 6c 69 74 65 33 5f  .**     sqlite3_
5bb0: 63 6f 6c 75 6d 6e 5f 72 65 61 6c 28 29 0a 2a 2a  column_real().**
5bc0: 20 20 20 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c       sqlite3_col
5bd0: 75 6d 6e 5f 62 79 74 65 73 28 29 0a 2a 2a 20 20  umn_bytes().**  
5be0: 20 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d     sqlite3_colum
5bf0: 6e 5f 62 79 74 65 73 31 36 28 29 0a 2a 2a 20 20  n_bytes16().**  
5c00: 20 20 20 73 71 69 69 74 65 33 5f 63 6f 6c 75 6d     sqiite3_colum
5c10: 6e 5f 62 6c 6f 62 28 29 0a 2a 2f 0a 73 74 61 74  n_blob().*/.stat
5c20: 69 63 20 76 6f 69 64 20 63 6f 6c 75 6d 6e 4d 61  ic void columnMa
5c30: 6c 6c 6f 63 46 61 69 6c 75 72 65 28 73 71 6c 69  llocFailure(sqli
5c40: 74 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d 74 29  te3_stmt *pStmt)
5c50: 0a 7b 0a 20 20 2f 2a 20 49 66 20 6d 61 6c 6c 6f  .{.  /* If mallo
5c60: 63 28 29 20 66 61 69 6c 65 64 20 64 75 72 69 6e  c() failed durin
5c70: 67 20 61 6e 20 65 6e 63 6f 64 69 6e 67 20 63 6f  g an encoding co
5c80: 6e 76 65 72 73 69 6f 6e 20 77 69 74 68 69 6e 20  nversion within 
5c90: 61 6e 0a 20 20 2a 2a 20 73 71 6c 69 74 65 33 5f  an.  ** sqlite3_
5ca0: 63 6f 6c 75 6d 6e 5f 58 58 58 20 41 50 49 2c 20  column_XXX API, 
5cb0: 74 68 65 6e 20 73 65 74 20 74 68 65 20 72 65 74  then set the ret
5cc0: 75 72 6e 20 63 6f 64 65 20 6f 66 20 74 68 65 20  urn code of the 
5cd0: 73 74 61 74 65 6d 65 6e 74 20 74 6f 0a 20 20 2a  statement to.  *
5ce0: 2a 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 2e 20  * SQLITE_NOMEM. 
5cf0: 54 68 65 20 6e 65 78 74 20 63 61 6c 6c 20 74 6f  The next call to
5d00: 20 5f 73 74 65 70 28 29 20 28 69 66 20 61 6e 79   _step() (if any
5d10: 29 20 77 69 6c 6c 20 72 65 74 75 72 6e 20 53 51  ) will return SQ
5d20: 4c 49 54 45 5f 45 52 52 4f 52 0a 20 20 2a 2a 20  LITE_ERROR.  ** 
5d30: 61 6e 64 20 5f 66 69 6e 61 6c 69 7a 65 28 29 20  and _finalize() 
5d40: 77 69 6c 6c 20 72 65 74 75 72 6e 20 4e 4f 4d 45  will return NOME
5d50: 4d 2e 0a 20 20 2a 2f 0a 20 20 56 64 62 65 20 2a  M..  */.  Vdbe *
5d60: 70 20 3d 20 28 56 64 62 65 20 2a 29 70 53 74 6d  p = (Vdbe *)pStm
5d70: 74 3b 0a 20 20 69 66 28 20 70 20 29 7b 0a 20 20  t;.  if( p ){.  
5d80: 20 20 70 2d 3e 72 63 20 3d 20 73 71 6c 69 74 65    p->rc = sqlite
5d90: 33 41 70 69 45 78 69 74 28 70 2d 3e 64 62 2c 20  3ApiExit(p->db, 
5da0: 70 2d 3e 72 63 29 3b 0a 20 20 20 20 73 71 6c 69  p->rc);.    sqli
5db0: 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28  te3_mutex_leave(
5dc0: 70 2d 3e 64 62 2d 3e 6d 75 74 65 78 29 3b 0a 20  p->db->mutex);. 
5dd0: 20 7d 0a 7d 0a 0a 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a   }.}../*********
5de0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
5df0: 2a 2a 2a 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75  *** sqlite3_colu
5e00: 6d 6e 5f 20 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  mn_  ***********
5e10: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
5e20: 2a 2a 2a 2a 0a 2a 2a 20 54 68 65 20 66 6f 6c 6c  ****.** The foll
5e30: 6f 77 69 6e 67 20 72 6f 75 74 69 6e 65 73 20 61  owing routines a
5e40: 72 65 20 75 73 65 64 20 74 6f 20 61 63 63 65 73  re used to acces
5e50: 73 20 65 6c 65 6d 65 6e 74 73 20 6f 66 20 74 68  s elements of th
5e60: 65 20 63 75 72 72 65 6e 74 20 72 6f 77 0a 2a 2a  e current row.**
5e70: 20 69 6e 20 74 68 65 20 72 65 73 75 6c 74 20 73   in the result s
5e80: 65 74 2e 0a 2a 2f 0a 63 6f 6e 73 74 20 76 6f 69  et..*/.const voi
5e90: 64 20 2a 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  d *sqlite3_colum
5ea0: 6e 5f 62 6c 6f 62 28 73 71 6c 69 74 65 33 5f 73  n_blob(sqlite3_s
5eb0: 74 6d 74 20 2a 70 53 74 6d 74 2c 20 69 6e 74 20  tmt *pStmt, int 
5ec0: 69 29 7b 0a 20 20 63 6f 6e 73 74 20 76 6f 69 64  i){.  const void
5ed0: 20 2a 76 61 6c 3b 0a 20 20 76 61 6c 20 3d 20 73   *val;.  val = s
5ee0: 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 62 6c 6f  qlite3_value_blo
5ef0: 62 28 20 63 6f 6c 75 6d 6e 4d 65 6d 28 70 53 74  b( columnMem(pSt
5f00: 6d 74 2c 69 29 20 29 3b 0a 20 20 2f 2a 20 45 76  mt,i) );.  /* Ev
5f10: 65 6e 20 74 68 6f 75 67 68 20 74 68 65 72 65 20  en though there 
5f20: 69 73 20 6e 6f 20 65 6e 63 6f 64 69 6e 67 20 63  is no encoding c
5f30: 6f 6e 76 65 72 73 69 6f 6e 2c 20 76 61 6c 75 65  onversion, value
5f40: 5f 62 6c 6f 62 28 29 20 6d 69 67 68 74 0a 20 20  _blob() might.  
5f50: 2a 2a 20 6e 65 65 64 20 74 6f 20 63 61 6c 6c 20  ** need to call 
5f60: 6d 61 6c 6c 6f 63 28 29 20 74 6f 20 65 78 70 61  malloc() to expa
5f70: 6e 64 20 74 68 65 20 72 65 73 75 6c 74 20 6f 66  nd the result of
5f80: 20 61 20 7a 65 72 6f 62 6c 6f 62 28 29 20 0a 20   a zeroblob() . 
5f90: 20 2a 2a 20 65 78 70 72 65 73 73 69 6f 6e 2e 20   ** expression. 
5fa0: 0a 20 20 2a 2f 0a 20 20 63 6f 6c 75 6d 6e 4d 61  .  */.  columnMa
5fb0: 6c 6c 6f 63 46 61 69 6c 75 72 65 28 70 53 74 6d  llocFailure(pStm
5fc0: 74 29 3b 0a 20 20 72 65 74 75 72 6e 20 76 61 6c  t);.  return val
5fd0: 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f  ;.}.int sqlite3_
5fe0: 63 6f 6c 75 6d 6e 5f 62 79 74 65 73 28 73 71 6c  column_bytes(sql
5ff0: 69 74 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d 74  ite3_stmt *pStmt
6000: 2c 20 69 6e 74 20 69 29 7b 0a 20 20 69 6e 74 20  , int i){.  int 
6010: 76 61 6c 20 3d 20 73 71 6c 69 74 65 33 5f 76 61  val = sqlite3_va
6020: 6c 75 65 5f 62 79 74 65 73 28 20 63 6f 6c 75 6d  lue_bytes( colum
6030: 6e 4d 65 6d 28 70 53 74 6d 74 2c 69 29 20 29 3b  nMem(pStmt,i) );
6040: 0a 20 20 63 6f 6c 75 6d 6e 4d 61 6c 6c 6f 63 46  .  columnMallocF
6050: 61 69 6c 75 72 65 28 70 53 74 6d 74 29 3b 0a 20  ailure(pStmt);. 
6060: 20 72 65 74 75 72 6e 20 76 61 6c 3b 0a 7d 0a 69   return val;.}.i
6070: 6e 74 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  nt sqlite3_colum
6080: 6e 5f 62 79 74 65 73 31 36 28 73 71 6c 69 74 65  n_bytes16(sqlite
6090: 33 5f 73 74 6d 74 20 2a 70 53 74 6d 74 2c 20 69  3_stmt *pStmt, i
60a0: 6e 74 20 69 29 7b 0a 20 20 69 6e 74 20 76 61 6c  nt i){.  int val
60b0: 20 3d 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65   = sqlite3_value
60c0: 5f 62 79 74 65 73 31 36 28 20 63 6f 6c 75 6d 6e  _bytes16( column
60d0: 4d 65 6d 28 70 53 74 6d 74 2c 69 29 20 29 3b 0a  Mem(pStmt,i) );.
60e0: 20 20 63 6f 6c 75 6d 6e 4d 61 6c 6c 6f 63 46 61    columnMallocFa
60f0: 69 6c 75 72 65 28 70 53 74 6d 74 29 3b 0a 20 20  ilure(pStmt);.  
6100: 72 65 74 75 72 6e 20 76 61 6c 3b 0a 7d 0a 64 6f  return val;.}.do
6110: 75 62 6c 65 20 73 71 6c 69 74 65 33 5f 63 6f 6c  uble sqlite3_col
6120: 75 6d 6e 5f 64 6f 75 62 6c 65 28 73 71 6c 69 74  umn_double(sqlit
6130: 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d 74 2c 20  e3_stmt *pStmt, 
6140: 69 6e 74 20 69 29 7b 0a 20 20 64 6f 75 62 6c 65  int i){.  double
6150: 20 76 61 6c 20 3d 20 73 71 6c 69 74 65 33 5f 76   val = sqlite3_v
6160: 61 6c 75 65 5f 64 6f 75 62 6c 65 28 20 63 6f 6c  alue_double( col
6170: 75 6d 6e 4d 65 6d 28 70 53 74 6d 74 2c 69 29 20  umnMem(pStmt,i) 
6180: 29 3b 0a 20 20 63 6f 6c 75 6d 6e 4d 61 6c 6c 6f  );.  columnMallo
6190: 63 46 61 69 6c 75 72 65 28 70 53 74 6d 74 29 3b  cFailure(pStmt);
61a0: 0a 20 20 72 65 74 75 72 6e 20 76 61 6c 3b 0a 7d  .  return val;.}
61b0: 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f 63 6f 6c  .int sqlite3_col
61c0: 75 6d 6e 5f 69 6e 74 28 73 71 6c 69 74 65 33 5f  umn_int(sqlite3_
61d0: 73 74 6d 74 20 2a 70 53 74 6d 74 2c 20 69 6e 74  stmt *pStmt, int
61e0: 20 69 29 7b 0a 20 20 69 6e 74 20 76 61 6c 20 3d   i){.  int val =
61f0: 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 69   sqlite3_value_i
6200: 6e 74 28 20 63 6f 6c 75 6d 6e 4d 65 6d 28 70 53  nt( columnMem(pS
6210: 74 6d 74 2c 69 29 20 29 3b 0a 20 20 63 6f 6c 75  tmt,i) );.  colu
6220: 6d 6e 4d 61 6c 6c 6f 63 46 61 69 6c 75 72 65 28  mnMallocFailure(
6230: 70 53 74 6d 74 29 3b 0a 20 20 72 65 74 75 72 6e  pStmt);.  return
6240: 20 76 61 6c 3b 0a 7d 0a 73 71 6c 69 74 65 5f 69   val;.}.sqlite_i
6250: 6e 74 36 34 20 73 71 6c 69 74 65 33 5f 63 6f 6c  nt64 sqlite3_col
6260: 75 6d 6e 5f 69 6e 74 36 34 28 73 71 6c 69 74 65  umn_int64(sqlite
6270: 33 5f 73 74 6d 74 20 2a 70 53 74 6d 74 2c 20 69  3_stmt *pStmt, i
6280: 6e 74 20 69 29 7b 0a 20 20 73 71 6c 69 74 65 5f  nt i){.  sqlite_
6290: 69 6e 74 36 34 20 76 61 6c 20 3d 20 73 71 6c 69  int64 val = sqli
62a0: 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74 36 34 28  te3_value_int64(
62b0: 20 63 6f 6c 75 6d 6e 4d 65 6d 28 70 53 74 6d 74   columnMem(pStmt
62c0: 2c 69 29 20 29 3b 0a 20 20 63 6f 6c 75 6d 6e 4d  ,i) );.  columnM
62d0: 61 6c 6c 6f 63 46 61 69 6c 75 72 65 28 70 53 74  allocFailure(pSt
62e0: 6d 74 29 3b 0a 20 20 72 65 74 75 72 6e 20 76 61  mt);.  return va
62f0: 6c 3b 0a 7d 0a 63 6f 6e 73 74 20 75 6e 73 69 67  l;.}.const unsig
6300: 6e 65 64 20 63 68 61 72 20 2a 73 71 6c 69 74 65  ned char *sqlite
6310: 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 28 73 71  3_column_text(sq
6320: 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d  lite3_stmt *pStm
6330: 74 2c 20 69 6e 74 20 69 29 7b 0a 20 20 63 6f 6e  t, int i){.  con
6340: 73 74 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72  st unsigned char
6350: 20 2a 76 61 6c 20 3d 20 73 71 6c 69 74 65 33 5f   *val = sqlite3_
6360: 76 61 6c 75 65 5f 74 65 78 74 28 20 63 6f 6c 75  value_text( colu
6370: 6d 6e 4d 65 6d 28 70 53 74 6d 74 2c 69 29 20 29  mnMem(pStmt,i) )
6380: 3b 0a 20 20 63 6f 6c 75 6d 6e 4d 61 6c 6c 6f 63  ;.  columnMalloc
6390: 46 61 69 6c 75 72 65 28 70 53 74 6d 74 29 3b 0a  Failure(pStmt);.
63a0: 20 20 72 65 74 75 72 6e 20 76 61 6c 3b 0a 7d 0a    return val;.}.
63b0: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 20 2a 73  sqlite3_value *s
63c0: 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 76 61  qlite3_column_va
63d0: 6c 75 65 28 73 71 6c 69 74 65 33 5f 73 74 6d 74  lue(sqlite3_stmt
63e0: 20 2a 70 53 74 6d 74 2c 20 69 6e 74 20 69 29 7b   *pStmt, int i){
63f0: 0a 20 20 4d 65 6d 20 2a 70 4f 75 74 20 3d 20 63  .  Mem *pOut = c
6400: 6f 6c 75 6d 6e 4d 65 6d 28 70 53 74 6d 74 2c 20  olumnMem(pStmt, 
6410: 69 29 3b 0a 20 20 69 66 28 20 70 4f 75 74 2d 3e  i);.  if( pOut->
6420: 66 6c 61 67 73 26 4d 45 4d 5f 53 74 61 74 69 63  flags&MEM_Static
6430: 20 29 7b 0a 20 20 20 20 70 4f 75 74 2d 3e 66 6c   ){.    pOut->fl
6440: 61 67 73 20 26 3d 20 7e 4d 45 4d 5f 53 74 61 74  ags &= ~MEM_Stat
6450: 69 63 3b 0a 20 20 20 20 70 4f 75 74 2d 3e 66 6c  ic;.    pOut->fl
6460: 61 67 73 20 7c 3d 20 4d 45 4d 5f 45 70 68 65 6d  ags |= MEM_Ephem
6470: 3b 0a 20 20 7d 0a 20 20 63 6f 6c 75 6d 6e 4d 61  ;.  }.  columnMa
6480: 6c 6c 6f 63 46 61 69 6c 75 72 65 28 70 53 74 6d  llocFailure(pStm
6490: 74 29 3b 0a 20 20 72 65 74 75 72 6e 20 28 73 71  t);.  return (sq
64a0: 6c 69 74 65 33 5f 76 61 6c 75 65 20 2a 29 70 4f  lite3_value *)pO
64b0: 75 74 3b 0a 7d 0a 23 69 66 6e 64 65 66 20 53 51  ut;.}.#ifndef SQ
64c0: 4c 49 54 45 5f 4f 4d 49 54 5f 55 54 46 31 36 0a  LITE_OMIT_UTF16.
64d0: 63 6f 6e 73 74 20 76 6f 69 64 20 2a 73 71 6c 69  const void *sqli
64e0: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 31  te3_column_text1
64f0: 36 28 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a  6(sqlite3_stmt *
6500: 70 53 74 6d 74 2c 20 69 6e 74 20 69 29 7b 0a 20  pStmt, int i){. 
6510: 20 63 6f 6e 73 74 20 76 6f 69 64 20 2a 76 61 6c   const void *val
6520: 20 3d 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65   = sqlite3_value
6530: 5f 74 65 78 74 31 36 28 20 63 6f 6c 75 6d 6e 4d  _text16( columnM
6540: 65 6d 28 70 53 74 6d 74 2c 69 29 20 29 3b 0a 20  em(pStmt,i) );. 
6550: 20 63 6f 6c 75 6d 6e 4d 61 6c 6c 6f 63 46 61 69   columnMallocFai
6560: 6c 75 72 65 28 70 53 74 6d 74 29 3b 0a 20 20 72  lure(pStmt);.  r
6570: 65 74 75 72 6e 20 76 61 6c 3b 0a 7d 0a 23 65 6e  eturn val;.}.#en
6580: 64 69 66 20 2f 2a 20 53 51 4c 49 54 45 5f 4f 4d  dif /* SQLITE_OM
6590: 49 54 5f 55 54 46 31 36 20 2a 2f 0a 69 6e 74 20  IT_UTF16 */.int 
65a0: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74  sqlite3_column_t
65b0: 79 70 65 28 73 71 6c 69 74 65 33 5f 73 74 6d 74  ype(sqlite3_stmt
65c0: 20 2a 70 53 74 6d 74 2c 20 69 6e 74 20 69 29 7b   *pStmt, int i){
65d0: 0a 20 20 69 6e 74 20 69 54 79 70 65 20 3d 20 73  .  int iType = s
65e0: 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 79 70  qlite3_value_typ
65f0: 65 28 20 63 6f 6c 75 6d 6e 4d 65 6d 28 70 53 74  e( columnMem(pSt
6600: 6d 74 2c 69 29 20 29 3b 0a 20 20 63 6f 6c 75 6d  mt,i) );.  colum
6610: 6e 4d 61 6c 6c 6f 63 46 61 69 6c 75 72 65 28 70  nMallocFailure(p
6620: 53 74 6d 74 29 3b 0a 20 20 72 65 74 75 72 6e 20  Stmt);.  return 
6630: 69 54 79 70 65 3b 0a 7d 0a 0a 2f 2a 20 54 68 65  iType;.}../* The
6640: 20 66 6f 6c 6c 6f 77 69 6e 67 20 66 75 6e 63 74   following funct
6650: 69 6f 6e 20 69 73 20 65 78 70 65 72 69 6d 65 6e  ion is experimen
6660: 74 61 6c 20 61 6e 64 20 73 75 62 6a 65 63 74 20  tal and subject 
6670: 74 6f 20 63 68 61 6e 67 65 20 6f 72 0a 2a 2a 20  to change or.** 
6680: 72 65 6d 6f 76 61 6c 20 2a 2f 0a 2f 2a 69 6e 74  removal */./*int
6690: 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f   sqlite3_column_
66a0: 6e 75 6d 65 72 69 63 5f 74 79 70 65 28 73 71 6c  numeric_type(sql
66b0: 69 74 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d 74  ite3_stmt *pStmt
66c0: 2c 20 69 6e 74 20 69 29 7b 0a 2a 2a 20 20 72 65  , int i){.**  re
66d0: 74 75 72 6e 20 73 71 6c 69 74 65 33 5f 76 61 6c  turn sqlite3_val
66e0: 75 65 5f 6e 75 6d 65 72 69 63 5f 74 79 70 65 28  ue_numeric_type(
66f0: 20 63 6f 6c 75 6d 6e 4d 65 6d 28 70 53 74 6d 74   columnMem(pStmt
6700: 2c 69 29 20 29 3b 0a 2a 2a 7d 0a 2a 2f 0a 0a 2f  ,i) );.**}.*/../
6710: 2a 0a 2a 2a 20 43 6f 6e 76 65 72 74 20 74 68 65  *.** Convert the
6720: 20 4e 2d 74 68 20 65 6c 65 6d 65 6e 74 20 6f 66   N-th element of
6730: 20 70 53 74 6d 74 2d 3e 70 43 6f 6c 4e 61 6d 65   pStmt->pColName
6740: 5b 5d 20 69 6e 74 6f 20 61 20 73 74 72 69 6e 67  [] into a string
6750: 20 75 73 69 6e 67 0a 2a 2a 20 78 46 75 6e 63 28   using.** xFunc(
6760: 29 20 74 68 65 6e 20 72 65 74 75 72 6e 20 74 68  ) then return th
6770: 61 74 20 73 74 72 69 6e 67 2e 20 20 49 66 20 4e  at string.  If N
6780: 20 69 73 20 6f 75 74 20 6f 66 20 72 61 6e 67 65   is out of range
6790: 2c 20 72 65 74 75 72 6e 20 30 2e 0a 2a 2a 0a 2a  , return 0..**.*
67a0: 2a 20 54 68 65 72 65 20 61 72 65 20 75 70 20 74  * There are up t
67b0: 6f 20 35 20 6e 61 6d 65 73 20 66 6f 72 20 65 61  o 5 names for ea
67c0: 63 68 20 63 6f 6c 75 6d 6e 2e 20 20 75 73 65 54  ch column.  useT
67d0: 79 70 65 20 64 65 74 65 72 6d 69 6e 65 73 20 77  ype determines w
67e0: 68 69 63 68 0a 2a 2a 20 6e 61 6d 65 20 69 73 20  hich.** name is 
67f0: 72 65 74 75 72 6e 65 64 2e 20 20 48 65 72 65 20  returned.  Here 
6800: 61 72 65 20 74 68 65 20 6e 61 6d 65 73 3a 0a 2a  are the names:.*
6810: 2a 0a 2a 2a 20 20 20 20 30 20 20 20 20 20 20 54  *.**    0      T
6820: 68 65 20 63 6f 6c 75 6d 6e 20 6e 61 6d 65 20 61  he column name a
6830: 73 20 69 74 20 73 68 6f 75 6c 64 20 62 65 20 64  s it should be d
6840: 69 73 70 6c 61 79 65 64 20 66 6f 72 20 6f 75 74  isplayed for out
6850: 70 75 74 0a 2a 2a 20 20 20 20 31 20 20 20 20 20  put.**    1     
6860: 20 54 68 65 20 64 61 74 61 74 79 70 65 20 6e 61   The datatype na
6870: 6d 65 20 66 6f 72 20 74 68 65 20 63 6f 6c 75 6d  me for the colum
6880: 6e 0a 2a 2a 20 20 20 20 32 20 20 20 20 20 20 54  n.**    2      T
6890: 68 65 20 6e 61 6d 65 20 6f 66 20 74 68 65 20 64  he name of the d
68a0: 61 74 61 62 61 73 65 20 74 68 61 74 20 74 68 65  atabase that the
68b0: 20 63 6f 6c 75 6d 6e 20 64 65 72 69 76 65 73 20   column derives 
68c0: 66 72 6f 6d 0a 2a 2a 20 20 20 20 33 20 20 20 20  from.**    3    
68d0: 20 20 54 68 65 20 6e 61 6d 65 20 6f 66 20 74 68    The name of th
68e0: 65 20 74 61 62 6c 65 20 74 68 61 74 20 74 68 65  e table that the
68f0: 20 63 6f 6c 75 6d 6e 20 64 65 72 69 76 65 73 20   column derives 
6900: 66 72 6f 6d 0a 2a 2a 20 20 20 20 34 20 20 20 20  from.**    4    
6910: 20 20 54 68 65 20 6e 61 6d 65 20 6f 66 20 74 68    The name of th
6920: 65 20 74 61 62 6c 65 20 63 6f 6c 75 6d 6e 20 74  e table column t
6930: 68 61 74 20 74 68 65 20 72 65 73 75 6c 74 20 63  hat the result c
6940: 6f 6c 75 6d 6e 20 64 65 72 69 76 65 73 20 66 72  olumn derives fr
6950: 6f 6d 0a 2a 2a 0a 2a 2a 20 49 66 20 74 68 65 20  om.**.** If the 
6960: 72 65 73 75 6c 74 20 69 73 20 6e 6f 74 20 61 20  result is not a 
6970: 73 69 6d 70 6c 65 20 63 6f 6c 75 6d 6e 20 72 65  simple column re
6980: 66 65 72 65 6e 63 65 20 28 69 66 20 69 74 20 69  ference (if it i
6990: 73 20 61 6e 20 65 78 70 72 65 73 73 69 6f 6e 0a  s an expression.
69a0: 2a 2a 20 6f 72 20 61 20 63 6f 6e 73 74 61 6e 74  ** or a constant
69b0: 29 20 74 68 65 6e 20 75 73 65 54 79 70 65 73 20  ) then useTypes 
69c0: 32 2c 20 33 2c 20 61 6e 64 20 34 20 72 65 74 75  2, 3, and 4 retu
69d0: 72 6e 20 4e 55 4c 4c 2e 0a 2a 2f 0a 73 74 61 74  rn NULL..*/.stat
69e0: 69 63 20 63 6f 6e 73 74 20 76 6f 69 64 20 2a 63  ic const void *c
69f0: 6f 6c 75 6d 6e 4e 61 6d 65 28 0a 20 20 73 71 6c  olumnName(.  sql
6a00: 69 74 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d 74  ite3_stmt *pStmt
6a10: 2c 0a 20 20 69 6e 74 20 4e 2c 0a 20 20 63 6f 6e  ,.  int N,.  con
6a20: 73 74 20 76 6f 69 64 20 2a 28 2a 78 46 75 6e 63  st void *(*xFunc
6a30: 29 28 4d 65 6d 2a 29 2c 0a 20 20 69 6e 74 20 75  )(Mem*),.  int u
6a40: 73 65 54 79 70 65 0a 29 7b 0a 20 20 63 6f 6e 73  seType.){.  cons
6a50: 74 20 76 6f 69 64 20 2a 72 65 74 20 3d 20 30 3b  t void *ret = 0;
6a60: 0a 20 20 56 64 62 65 20 2a 70 20 3d 20 28 56 64  .  Vdbe *p = (Vd
6a70: 62 65 20 2a 29 70 53 74 6d 74 3b 0a 20 20 69 6e  be *)pStmt;.  in
6a80: 74 20 6e 3b 0a 20 20 73 71 6c 69 74 65 33 20 2a  t n;.  sqlite3 *
6a90: 64 62 20 3d 20 70 2d 3e 64 62 3b 0a 20 20 0a 20  db = p->db;.  . 
6aa0: 20 61 73 73 65 72 74 28 20 64 62 21 3d 30 20 29   assert( db!=0 )
6ab0: 3b 0a 20 20 6e 20 3d 20 73 71 6c 69 74 65 33 5f  ;.  n = sqlite3_
6ac0: 63 6f 6c 75 6d 6e 5f 63 6f 75 6e 74 28 70 53 74  column_count(pSt
6ad0: 6d 74 29 3b 0a 20 20 69 66 28 20 4e 3c 6e 20 26  mt);.  if( N<n &
6ae0: 26 20 4e 3e 3d 30 20 29 7b 0a 20 20 20 20 4e 20  & N>=0 ){.    N 
6af0: 2b 3d 20 75 73 65 54 79 70 65 2a 6e 3b 0a 20 20  += useType*n;.  
6b00: 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f    sqlite3_mutex_
6b10: 65 6e 74 65 72 28 64 62 2d 3e 6d 75 74 65 78 29  enter(db->mutex)
6b20: 3b 0a 20 20 20 20 61 73 73 65 72 74 28 20 64 62  ;.    assert( db
6b30: 2d 3e 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 3d 3d  ->mallocFailed==
6b40: 30 20 29 3b 0a 20 20 20 20 72 65 74 20 3d 20 78  0 );.    ret = x
6b50: 46 75 6e 63 28 26 70 2d 3e 61 43 6f 6c 4e 61 6d  Func(&p->aColNam
6b60: 65 5b 4e 5d 29 3b 0a 20 20 20 20 20 2f 2a 20 41  e[N]);.     /* A
6b70: 20 6d 61 6c 6c 6f 63 20 6d 61 79 20 68 61 76 65   malloc may have
6b80: 20 66 61 69 6c 65 64 20 69 6e 73 69 64 65 20 6f   failed inside o
6b90: 66 20 74 68 65 20 78 46 75 6e 63 28 29 20 63 61  f the xFunc() ca
6ba0: 6c 6c 2e 20 49 66 20 74 68 69 73 0a 20 20 20 20  ll. If this.    
6bb0: 2a 2a 20 69 73 20 74 68 65 20 63 61 73 65 2c 20  ** is the case, 
6bc0: 63 6c 65 61 72 20 74 68 65 20 6d 61 6c 6c 6f 63  clear the malloc
6bd0: 46 61 69 6c 65 64 20 66 6c 61 67 20 61 6e 64 20  Failed flag and 
6be0: 72 65 74 75 72 6e 20 4e 55 4c 4c 2e 0a 20 20 20  return NULL..   
6bf0: 20 2a 2f 0a 20 20 20 20 69 66 28 20 64 62 2d 3e   */.    if( db->
6c00: 6d 61 6c 6c 6f 63 46 61 69 6c 65 64 20 29 7b 0a  mallocFailed ){.
6c10: 20 20 20 20 20 20 64 62 2d 3e 6d 61 6c 6c 6f 63        db->malloc
6c20: 46 61 69 6c 65 64 20 3d 20 30 3b 0a 20 20 20 20  Failed = 0;.    
6c30: 20 20 72 65 74 20 3d 20 30 3b 0a 20 20 20 20 7d    ret = 0;.    }
6c40: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 6d 75 74  .    sqlite3_mut
6c50: 65 78 5f 6c 65 61 76 65 28 64 62 2d 3e 6d 75 74  ex_leave(db->mut
6c60: 65 78 29 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72  ex);.  }.  retur
6c70: 6e 20 72 65 74 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20  n ret;.}../*.** 
6c80: 52 65 74 75 72 6e 20 74 68 65 20 6e 61 6d 65 20  Return the name 
6c90: 6f 66 20 74 68 65 20 4e 74 68 20 63 6f 6c 75 6d  of the Nth colum
6ca0: 6e 20 6f 66 20 74 68 65 20 72 65 73 75 6c 74 20  n of the result 
6cb0: 73 65 74 20 72 65 74 75 72 6e 65 64 20 62 79 20  set returned by 
6cc0: 53 51 4c 0a 2a 2a 20 73 74 61 74 65 6d 65 6e 74  SQL.** statement
6cd0: 20 70 53 74 6d 74 2e 0a 2a 2f 0a 63 6f 6e 73 74   pStmt..*/.const
6ce0: 20 63 68 61 72 20 2a 73 71 6c 69 74 65 33 5f 63   char *sqlite3_c
6cf0: 6f 6c 75 6d 6e 5f 6e 61 6d 65 28 73 71 6c 69 74  olumn_name(sqlit
6d00: 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d 74 2c 20  e3_stmt *pStmt, 
6d10: 69 6e 74 20 4e 29 7b 0a 20 20 72 65 74 75 72 6e  int N){.  return
6d20: 20 63 6f 6c 75 6d 6e 4e 61 6d 65 28 0a 20 20 20   columnName(.   
6d30: 20 20 20 70 53 74 6d 74 2c 20 4e 2c 20 28 63 6f     pStmt, N, (co
6d40: 6e 73 74 20 76 6f 69 64 2a 28 2a 29 28 4d 65 6d  nst void*(*)(Mem
6d50: 2a 29 29 73 71 6c 69 74 65 33 5f 76 61 6c 75 65  *))sqlite3_value
6d60: 5f 74 65 78 74 2c 20 43 4f 4c 4e 41 4d 45 5f 4e  _text, COLNAME_N
6d70: 41 4d 45 29 3b 0a 7d 0a 23 69 66 6e 64 65 66 20  AME);.}.#ifndef 
6d80: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 55 54 46 31  SQLITE_OMIT_UTF1
6d90: 36 0a 63 6f 6e 73 74 20 76 6f 69 64 20 2a 73 71  6.const void *sq
6da0: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d  lite3_column_nam
6db0: 65 31 36 28 73 71 6c 69 74 65 33 5f 73 74 6d 74  e16(sqlite3_stmt
6dc0: 20 2a 70 53 74 6d 74 2c 20 69 6e 74 20 4e 29 7b   *pStmt, int N){
6dd0: 0a 20 20 72 65 74 75 72 6e 20 63 6f 6c 75 6d 6e  .  return column
6de0: 4e 61 6d 65 28 0a 20 20 20 20 20 20 70 53 74 6d  Name(.      pStm
6df0: 74 2c 20 4e 2c 20 28 63 6f 6e 73 74 20 76 6f 69  t, N, (const voi
6e00: 64 2a 28 2a 29 28 4d 65 6d 2a 29 29 73 71 6c 69  d*(*)(Mem*))sqli
6e10: 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74 31 36  te3_value_text16
6e20: 2c 20 43 4f 4c 4e 41 4d 45 5f 4e 41 4d 45 29 3b  , COLNAME_NAME);
6e30: 0a 7d 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a  .}.#endif../*.**
6e40: 20 43 6f 6e 73 74 72 61 69 6e 74 3a 20 20 49 66   Constraint:  If
6e50: 20 79 6f 75 20 68 61 76 65 20 45 4e 41 42 4c 45   you have ENABLE
6e60: 5f 43 4f 4c 55 4d 4e 5f 4d 45 54 41 44 41 54 41  _COLUMN_METADATA
6e70: 20 74 68 65 6e 20 79 6f 75 20 6d 75 73 74 0a 2a   then you must.*
6e80: 2a 20 6e 6f 74 20 64 65 66 69 6e 65 20 4f 4d 49  * not define OMI
6e90: 54 5f 44 45 43 4c 54 59 50 45 2e 0a 2a 2f 0a 23  T_DECLTYPE..*/.#
6ea0: 69 66 20 64 65 66 69 6e 65 64 28 53 51 4c 49 54  if defined(SQLIT
6eb0: 45 5f 4f 4d 49 54 5f 44 45 43 4c 54 59 50 45 29  E_OMIT_DECLTYPE)
6ec0: 20 26 26 20 64 65 66 69 6e 65 64 28 53 51 4c 49   && defined(SQLI
6ed0: 54 45 5f 45 4e 41 42 4c 45 5f 43 4f 4c 55 4d 4e  TE_ENABLE_COLUMN
6ee0: 5f 4d 45 54 41 44 41 54 41 29 0a 23 20 65 72 72  _METADATA).# err
6ef0: 6f 72 20 22 4d 75 73 74 20 6e 6f 74 20 64 65 66  or "Must not def
6f00: 69 6e 65 20 62 6f 74 68 20 53 51 4c 49 54 45 5f  ine both SQLITE_
6f10: 4f 4d 49 54 5f 44 45 43 4c 54 59 50 45 20 5c 0a  OMIT_DECLTYPE \.
6f20: 20 20 20 20 20 20 20 20 20 61 6e 64 20 53 51 4c           and SQL
6f30: 49 54 45 5f 45 4e 41 42 4c 45 5f 43 4f 4c 55 4d  ITE_ENABLE_COLUM
6f40: 4e 5f 4d 45 54 41 44 41 54 41 22 0a 23 65 6e 64  N_METADATA".#end
6f50: 69 66 0a 0a 23 69 66 6e 64 65 66 20 53 51 4c 49  if..#ifndef SQLI
6f60: 54 45 5f 4f 4d 49 54 5f 44 45 43 4c 54 59 50 45  TE_OMIT_DECLTYPE
6f70: 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68  ./*.** Return th
6f80: 65 20 63 6f 6c 75 6d 6e 20 64 65 63 6c 61 72 61  e column declara
6f90: 74 69 6f 6e 20 74 79 70 65 20 28 69 66 20 61 70  tion type (if ap
6fa0: 70 6c 69 63 61 62 6c 65 29 20 6f 66 20 74 68 65  plicable) of the
6fb0: 20 27 69 27 74 68 20 63 6f 6c 75 6d 6e 0a 2a 2a   'i'th column.**
6fc0: 20 6f 66 20 74 68 65 20 72 65 73 75 6c 74 20 73   of the result s
6fd0: 65 74 20 6f 66 20 53 51 4c 20 73 74 61 74 65 6d  et of SQL statem
6fe0: 65 6e 74 20 70 53 74 6d 74 2e 0a 2a 2f 0a 63 6f  ent pStmt..*/.co
6ff0: 6e 73 74 20 63 68 61 72 20 2a 73 71 6c 69 74 65  nst char *sqlite
7000: 33 5f 63 6f 6c 75 6d 6e 5f 64 65 63 6c 74 79 70  3_column_decltyp
7010: 65 28 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a  e(sqlite3_stmt *
7020: 70 53 74 6d 74 2c 20 69 6e 74 20 4e 29 7b 0a 20  pStmt, int N){. 
7030: 20 72 65 74 75 72 6e 20 63 6f 6c 75 6d 6e 4e 61   return columnNa
7040: 6d 65 28 0a 20 20 20 20 20 20 70 53 74 6d 74 2c  me(.      pStmt,
7050: 20 4e 2c 20 28 63 6f 6e 73 74 20 76 6f 69 64 2a   N, (const void*
7060: 28 2a 29 28 4d 65 6d 2a 29 29 73 71 6c 69 74 65  (*)(Mem*))sqlite
7070: 33 5f 76 61 6c 75 65 5f 74 65 78 74 2c 20 43 4f  3_value_text, CO
7080: 4c 4e 41 4d 45 5f 44 45 43 4c 54 59 50 45 29 3b  LNAME_DECLTYPE);
7090: 0a 7d 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54  .}.#ifndef SQLIT
70a0: 45 5f 4f 4d 49 54 5f 55 54 46 31 36 0a 63 6f 6e  E_OMIT_UTF16.con
70b0: 73 74 20 76 6f 69 64 20 2a 73 71 6c 69 74 65 33  st void *sqlite3
70c0: 5f 63 6f 6c 75 6d 6e 5f 64 65 63 6c 74 79 70 65  _column_decltype
70d0: 31 36 28 73 71 6c 69 74 65 33 5f 73 74 6d 74 20  16(sqlite3_stmt 
70e0: 2a 70 53 74 6d 74 2c 20 69 6e 74 20 4e 29 7b 0a  *pStmt, int N){.
70f0: 20 20 72 65 74 75 72 6e 20 63 6f 6c 75 6d 6e 4e    return columnN
7100: 61 6d 65 28 0a 20 20 20 20 20 20 70 53 74 6d 74  ame(.      pStmt
7110: 2c 20 4e 2c 20 28 63 6f 6e 73 74 20 76 6f 69 64  , N, (const void
7120: 2a 28 2a 29 28 4d 65 6d 2a 29 29 73 71 6c 69 74  *(*)(Mem*))sqlit
7130: 65 33 5f 76 61 6c 75 65 5f 74 65 78 74 31 36 2c  e3_value_text16,
7140: 20 43 4f 4c 4e 41 4d 45 5f 44 45 43 4c 54 59 50   COLNAME_DECLTYP
7150: 45 29 3b 0a 7d 0a 23 65 6e 64 69 66 20 2f 2a 20  E);.}.#endif /* 
7160: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 55 54 46 31  SQLITE_OMIT_UTF1
7170: 36 20 2a 2f 0a 23 65 6e 64 69 66 20 2f 2a 20 53  6 */.#endif /* S
7180: 51 4c 49 54 45 5f 4f 4d 49 54 5f 44 45 43 4c 54  QLITE_OMIT_DECLT
7190: 59 50 45 20 2a 2f 0a 0a 23 69 66 64 65 66 20 53  YPE */..#ifdef S
71a0: 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 43 4f 4c  QLITE_ENABLE_COL
71b0: 55 4d 4e 5f 4d 45 54 41 44 41 54 41 0a 2f 2a 0a  UMN_METADATA./*.
71c0: 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20 6e 61  ** Return the na
71d0: 6d 65 20 6f 66 20 74 68 65 20 64 61 74 61 62 61  me of the databa
71e0: 73 65 20 66 72 6f 6d 20 77 68 69 63 68 20 61 20  se from which a 
71f0: 72 65 73 75 6c 74 20 63 6f 6c 75 6d 6e 20 64 65  result column de
7200: 72 69 76 65 73 2e 0a 2a 2a 20 4e 55 4c 4c 20 69  rives..** NULL i
7210: 73 20 72 65 74 75 72 6e 65 64 20 69 66 20 74 68  s returned if th
7220: 65 20 72 65 73 75 6c 74 20 63 6f 6c 75 6d 6e 20  e result column 
7230: 69 73 20 61 6e 20 65 78 70 72 65 73 73 69 6f 6e  is an expression
7240: 20 6f 72 20 63 6f 6e 73 74 61 6e 74 20 6f 72 0a   or constant or.
7250: 2a 2a 20 61 6e 79 74 68 69 6e 67 20 65 6c 73 65  ** anything else
7260: 20 77 68 69 63 68 20 69 73 20 6e 6f 74 20 61 6e   which is not an
7270: 20 75 6e 61 62 69 67 75 6f 75 73 20 72 65 66 65   unabiguous refe
7280: 72 65 6e 63 65 20 74 6f 20 61 20 64 61 74 61 62  rence to a datab
7290: 61 73 65 20 63 6f 6c 75 6d 6e 2e 0a 2a 2f 0a 63  ase column..*/.c
72a0: 6f 6e 73 74 20 63 68 61 72 20 2a 73 71 6c 69 74  onst char *sqlit
72b0: 65 33 5f 63 6f 6c 75 6d 6e 5f 64 61 74 61 62 61  e3_column_databa
72c0: 73 65 5f 6e 61 6d 65 28 73 71 6c 69 74 65 33 5f  se_name(sqlite3_
72d0: 73 74 6d 74 20 2a 70 53 74 6d 74 2c 20 69 6e 74  stmt *pStmt, int
72e0: 20 4e 29 7b 0a 20 20 72 65 74 75 72 6e 20 63 6f   N){.  return co
72f0: 6c 75 6d 6e 4e 61 6d 65 28 0a 20 20 20 20 20 20  lumnName(.      
7300: 70 53 74 6d 74 2c 20 4e 2c 20 28 63 6f 6e 73 74  pStmt, N, (const
7310: 20 76 6f 69 64 2a 28 2a 29 28 4d 65 6d 2a 29 29   void*(*)(Mem*))
7320: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 65  sqlite3_value_te
7330: 78 74 2c 20 43 4f 4c 4e 41 4d 45 5f 44 41 54 41  xt, COLNAME_DATA
7340: 42 41 53 45 29 3b 0a 7d 0a 23 69 66 6e 64 65 66  BASE);.}.#ifndef
7350: 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 55 54 46   SQLITE_OMIT_UTF
7360: 31 36 0a 63 6f 6e 73 74 20 76 6f 69 64 20 2a 73  16.const void *s
7370: 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 61  qlite3_column_da
7380: 74 61 62 61 73 65 5f 6e 61 6d 65 31 36 28 73 71  tabase_name16(sq
7390: 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d  lite3_stmt *pStm
73a0: 74 2c 20 69 6e 74 20 4e 29 7b 0a 20 20 72 65 74  t, int N){.  ret
73b0: 75 72 6e 20 63 6f 6c 75 6d 6e 4e 61 6d 65 28 0a  urn columnName(.
73c0: 20 20 20 20 20 20 70 53 74 6d 74 2c 20 4e 2c 20        pStmt, N, 
73d0: 28 63 6f 6e 73 74 20 76 6f 69 64 2a 28 2a 29 28  (const void*(*)(
73e0: 4d 65 6d 2a 29 29 73 71 6c 69 74 65 33 5f 76 61  Mem*))sqlite3_va
73f0: 6c 75 65 5f 74 65 78 74 31 36 2c 20 43 4f 4c 4e  lue_text16, COLN
7400: 41 4d 45 5f 44 41 54 41 42 41 53 45 29 3b 0a 7d  AME_DATABASE);.}
7410: 0a 23 65 6e 64 69 66 20 2f 2a 20 53 51 4c 49 54  .#endif /* SQLIT
7420: 45 5f 4f 4d 49 54 5f 55 54 46 31 36 20 2a 2f 0a  E_OMIT_UTF16 */.
7430: 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68  ./*.** Return th
7440: 65 20 6e 61 6d 65 20 6f 66 20 74 68 65 20 74 61  e name of the ta
7450: 62 6c 65 20 66 72 6f 6d 20 77 68 69 63 68 20 61  ble from which a
7460: 20 72 65 73 75 6c 74 20 63 6f 6c 75 6d 6e 20 64   result column d
7470: 65 72 69 76 65 73 2e 0a 2a 2a 20 4e 55 4c 4c 20  erives..** NULL 
7480: 69 73 20 72 65 74 75 72 6e 65 64 20 69 66 20 74  is returned if t
7490: 68 65 20 72 65 73 75 6c 74 20 63 6f 6c 75 6d 6e  he result column
74a0: 20 69 73 20 61 6e 20 65 78 70 72 65 73 73 69 6f   is an expressio
74b0: 6e 20 6f 72 20 63 6f 6e 73 74 61 6e 74 20 6f 72  n or constant or
74c0: 0a 2a 2a 20 61 6e 79 74 68 69 6e 67 20 65 6c 73  .** anything els
74d0: 65 20 77 68 69 63 68 20 69 73 20 6e 6f 74 20 61  e which is not a
74e0: 6e 20 75 6e 61 62 69 67 75 6f 75 73 20 72 65 66  n unabiguous ref
74f0: 65 72 65 6e 63 65 20 74 6f 20 61 20 64 61 74 61  erence to a data
7500: 62 61 73 65 20 63 6f 6c 75 6d 6e 2e 0a 2a 2f 0a  base column..*/.
7510: 63 6f 6e 73 74 20 63 68 61 72 20 2a 73 71 6c 69  const char *sqli
7520: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 61 62 6c 65  te3_column_table
7530: 5f 6e 61 6d 65 28 73 71 6c 69 74 65 33 5f 73 74  _name(sqlite3_st
7540: 6d 74 20 2a 70 53 74 6d 74 2c 20 69 6e 74 20 4e  mt *pStmt, int N
7550: 29 7b 0a 20 20 72 65 74 75 72 6e 20 63 6f 6c 75  ){.  return colu
7560: 6d 6e 4e 61 6d 65 28 0a 20 20 20 20 20 20 70 53  mnName(.      pS
7570: 74 6d 74 2c 20 4e 2c 20 28 63 6f 6e 73 74 20 76  tmt, N, (const v
7580: 6f 69 64 2a 28 2a 29 28 4d 65 6d 2a 29 29 73 71  oid*(*)(Mem*))sq
7590: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74  lite3_value_text
75a0: 2c 20 43 4f 4c 4e 41 4d 45 5f 54 41 42 4c 45 29  , COLNAME_TABLE)
75b0: 3b 0a 7d 0a 23 69 66 6e 64 65 66 20 53 51 4c 49  ;.}.#ifndef SQLI
75c0: 54 45 5f 4f 4d 49 54 5f 55 54 46 31 36 0a 63 6f  TE_OMIT_UTF16.co
75d0: 6e 73 74 20 76 6f 69 64 20 2a 73 71 6c 69 74 65  nst void *sqlite
75e0: 33 5f 63 6f 6c 75 6d 6e 5f 74 61 62 6c 65 5f 6e  3_column_table_n
75f0: 61 6d 65 31 36 28 73 71 6c 69 74 65 33 5f 73 74  ame16(sqlite3_st
7600: 6d 74 20 2a 70 53 74 6d 74 2c 20 69 6e 74 20 4e  mt *pStmt, int N
7610: 29 7b 0a 20 20 72 65 74 75 72 6e 20 63 6f 6c 75  ){.  return colu
7620: 6d 6e 4e 61 6d 65 28 0a 20 20 20 20 20 20 70 53  mnName(.      pS
7630: 74 6d 74 2c 20 4e 2c 20 28 63 6f 6e 73 74 20 76  tmt, N, (const v
7640: 6f 69 64 2a 28 2a 29 28 4d 65 6d 2a 29 29 73 71  oid*(*)(Mem*))sq
7650: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74  lite3_value_text
7660: 31 36 2c 20 43 4f 4c 4e 41 4d 45 5f 54 41 42 4c  16, COLNAME_TABL
7670: 45 29 3b 0a 7d 0a 23 65 6e 64 69 66 20 2f 2a 20  E);.}.#endif /* 
7680: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 55 54 46 31  SQLITE_OMIT_UTF1
7690: 36 20 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75  6 */../*.** Retu
76a0: 72 6e 20 74 68 65 20 6e 61 6d 65 20 6f 66 20 74  rn the name of t
76b0: 68 65 20 74 61 62 6c 65 20 63 6f 6c 75 6d 6e 20  he table column 
76c0: 66 72 6f 6d 20 77 68 69 63 68 20 61 20 72 65 73  from which a res
76d0: 75 6c 74 20 63 6f 6c 75 6d 6e 20 64 65 72 69 76  ult column deriv
76e0: 65 73 2e 0a 2a 2a 20 4e 55 4c 4c 20 69 73 20 72  es..** NULL is r
76f0: 65 74 75 72 6e 65 64 20 69 66 20 74 68 65 20 72  eturned if the r
7700: 65 73 75 6c 74 20 63 6f 6c 75 6d 6e 20 69 73 20  esult column is 
7710: 61 6e 20 65 78 70 72 65 73 73 69 6f 6e 20 6f 72  an expression or
7720: 20 63 6f 6e 73 74 61 6e 74 20 6f 72 0a 2a 2a 20   constant or.** 
7730: 61 6e 79 74 68 69 6e 67 20 65 6c 73 65 20 77 68  anything else wh
7740: 69 63 68 20 69 73 20 6e 6f 74 20 61 6e 20 75 6e  ich is not an un
7750: 61 62 69 67 75 6f 75 73 20 72 65 66 65 72 65 6e  abiguous referen
7760: 63 65 20 74 6f 20 61 20 64 61 74 61 62 61 73 65  ce to a database
7770: 20 63 6f 6c 75 6d 6e 2e 0a 2a 2f 0a 63 6f 6e 73   column..*/.cons
7780: 74 20 63 68 61 72 20 2a 73 71 6c 69 74 65 33 5f  t char *sqlite3_
7790: 63 6f 6c 75 6d 6e 5f 6f 72 69 67 69 6e 5f 6e 61  column_origin_na
77a0: 6d 65 28 73 71 6c 69 74 65 33 5f 73 74 6d 74 20  me(sqlite3_stmt 
77b0: 2a 70 53 74 6d 74 2c 20 69 6e 74 20 4e 29 7b 0a  *pStmt, int N){.
77c0: 20 20 72 65 74 75 72 6e 20 63 6f 6c 75 6d 6e 4e    return columnN
77d0: 61 6d 65 28 0a 20 20 20 20 20 20 70 53 74 6d 74  ame(.      pStmt
77e0: 2c 20 4e 2c 20 28 63 6f 6e 73 74 20 76 6f 69 64  , N, (const void
77f0: 2a 28 2a 29 28 4d 65 6d 2a 29 29 73 71 6c 69 74  *(*)(Mem*))sqlit
7800: 65 33 5f 76 61 6c 75 65 5f 74 65 78 74 2c 20 43  e3_value_text, C
7810: 4f 4c 4e 41 4d 45 5f 43 4f 4c 55 4d 4e 29 3b 0a  OLNAME_COLUMN);.
7820: 7d 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45  }.#ifndef SQLITE
7830: 5f 4f 4d 49 54 5f 55 54 46 31 36 0a 63 6f 6e 73  _OMIT_UTF16.cons
7840: 74 20 76 6f 69 64 20 2a 73 71 6c 69 74 65 33 5f  t void *sqlite3_
7850: 63 6f 6c 75 6d 6e 5f 6f 72 69 67 69 6e 5f 6e 61  column_origin_na
7860: 6d 65 31 36 28 73 71 6c 69 74 65 33 5f 73 74 6d  me16(sqlite3_stm
7870: 74 20 2a 70 53 74 6d 74 2c 20 69 6e 74 20 4e 29  t *pStmt, int N)
7880: 7b 0a 20 20 72 65 74 75 72 6e 20 63 6f 6c 75 6d  {.  return colum
7890: 6e 4e 61 6d 65 28 0a 20 20 20 20 20 20 70 53 74  nName(.      pSt
78a0: 6d 74 2c 20 4e 2c 20 28 63 6f 6e 73 74 20 76 6f  mt, N, (const vo
78b0: 69 64 2a 28 2a 29 28 4d 65 6d 2a 29 29 73 71 6c  id*(*)(Mem*))sql
78c0: 69 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74 31  ite3_value_text1
78d0: 36 2c 20 43 4f 4c 4e 41 4d 45 5f 43 4f 4c 55 4d  6, COLNAME_COLUM
78e0: 4e 29 3b 0a 7d 0a 23 65 6e 64 69 66 20 2f 2a 20  N);.}.#endif /* 
78f0: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 55 54 46 31  SQLITE_OMIT_UTF1
7900: 36 20 2a 2f 0a 23 65 6e 64 69 66 20 2f 2a 20 53  6 */.#endif /* S
7910: 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 43 4f 4c  QLITE_ENABLE_COL
7920: 55 4d 4e 5f 4d 45 54 41 44 41 54 41 20 2a 2f 0a  UMN_METADATA */.
7930: 0a 0a 2f 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ../*************
7940: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
7950: 2a 2a 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f  ** sqlite3_bind_
7960: 20 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a    **************
7970: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 0a 2a 2a  *************.**
7980: 20 0a 2a 2a 20 52 6f 75 74 69 6e 65 73 20 75 73   .** Routines us
7990: 65 64 20 74 6f 20 61 74 74 61 63 68 20 76 61 6c  ed to attach val
79a0: 75 65 73 20 74 6f 20 77 69 6c 64 63 61 72 64 73  ues to wildcards
79b0: 20 69 6e 20 61 20 63 6f 6d 70 69 6c 65 64 20 53   in a compiled S
79c0: 51 4c 20 73 74 61 74 65 6d 65 6e 74 2e 0a 2a 2f  QL statement..*/
79d0: 0a 2f 2a 0a 2a 2a 20 55 6e 62 69 6e 64 20 74 68  ./*.** Unbind th
79e0: 65 20 76 61 6c 75 65 20 62 6f 75 6e 64 20 74 6f  e value bound to
79f0: 20 76 61 72 69 61 62 6c 65 20 69 20 69 6e 20 76   variable i in v
7a00: 69 72 74 75 61 6c 20 6d 61 63 68 69 6e 65 20 70  irtual machine p
7a10: 2e 20 54 68 69 73 20 69 73 20 74 68 65 20 0a 2a  . This is the .*
7a20: 2a 20 74 68 65 20 73 61 6d 65 20 61 73 20 62 69  * the same as bi
7a30: 6e 64 69 6e 67 20 61 20 4e 55 4c 4c 20 76 61 6c  nding a NULL val
7a40: 75 65 20 74 6f 20 74 68 65 20 63 6f 6c 75 6d 6e  ue to the column
7a50: 2e 20 49 66 20 74 68 65 20 22 69 22 20 70 61 72  . If the "i" par
7a60: 61 6d 65 74 65 72 20 69 73 0a 2a 2a 20 6f 75 74  ameter is.** out
7a70: 20 6f 66 20 72 61 6e 67 65 2c 20 74 68 65 6e 20   of range, then 
7a80: 53 51 4c 49 54 45 5f 52 41 4e 47 45 20 69 73 20  SQLITE_RANGE is 
7a90: 72 65 74 75 72 6e 65 64 2e 20 4f 74 68 65 77 69  returned. Othewi
7aa0: 73 65 20 53 51 4c 49 54 45 5f 4f 4b 2e 0a 2a 2a  se SQLITE_OK..**
7ab0: 0a 2a 2a 20 41 20 73 75 63 63 65 73 73 66 75 6c  .** A successful
7ac0: 20 65 76 61 6c 75 61 74 69 6f 6e 20 6f 66 20 74   evaluation of t
7ad0: 68 69 73 20 72 6f 75 74 69 6e 65 20 61 63 71 75  his routine acqu
7ae0: 69 72 65 73 20 74 68 65 20 6d 75 74 65 78 20 6f  ires the mutex o
7af0: 6e 20 70 2e 0a 2a 2a 20 74 68 65 20 6d 75 74 65  n p..** the mute
7b00: 78 20 69 73 20 72 65 6c 65 61 73 65 64 20 69 66  x is released if
7b10: 20 61 6e 79 20 6b 69 6e 64 20 6f 66 20 65 72 72   any kind of err
7b20: 6f 72 20 6f 63 63 75 72 73 2e 0a 2a 2a 0a 2a 2a  or occurs..**.**
7b30: 20 54 68 65 20 65 72 72 6f 72 20 63 6f 64 65 20   The error code 
7b40: 73 74 6f 72 65 64 20 69 6e 20 64 61 74 61 62 61  stored in databa
7b50: 73 65 20 70 2d 3e 64 62 20 69 73 20 6f 76 65 72  se p->db is over
7b60: 77 72 69 74 74 65 6e 20 77 69 74 68 20 74 68 65  written with the
7b70: 20 72 65 74 75 72 6e 0a 2a 2a 20 76 61 6c 75 65   return.** value
7b80: 20 69 6e 20 61 6e 79 20 63 61 73 65 2e 0a 2a 2f   in any case..*/
7b90: 0a 73 74 61 74 69 63 20 69 6e 74 20 76 64 62 65  .static int vdbe
7ba0: 55 6e 62 69 6e 64 28 56 64 62 65 20 2a 70 2c 20  Unbind(Vdbe *p, 
7bb0: 69 6e 74 20 69 29 7b 0a 20 20 4d 65 6d 20 2a 70  int i){.  Mem *p
7bc0: 56 61 72 3b 0a 20 20 69 66 28 20 76 64 62 65 53  Var;.  if( vdbeS
7bd0: 61 66 65 74 79 4e 6f 74 4e 75 6c 6c 28 70 29 20  afetyNotNull(p) 
7be0: 29 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 53 51  ){.    return SQ
7bf0: 4c 49 54 45 5f 4d 49 53 55 53 45 5f 42 4b 50 54  LITE_MISUSE_BKPT
7c00: 3b 0a 20 20 7d 0a 20 20 73 71 6c 69 74 65 33 5f  ;.  }.  sqlite3_
7c10: 6d 75 74 65 78 5f 65 6e 74 65 72 28 70 2d 3e 64  mutex_enter(p->d
7c20: 62 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 69 66 28  b->mutex);.  if(
7c30: 20 70 2d 3e 6d 61 67 69 63 21 3d 56 44 42 45 5f   p->magic!=VDBE_
7c40: 4d 41 47 49 43 5f 52 55 4e 20 7c 7c 20 70 2d 3e  MAGIC_RUN || p->
7c50: 70 63 3e 3d 30 20 29 7b 0a 20 20 20 20 73 71 6c  pc>=0 ){.    sql
7c60: 69 74 65 33 45 72 72 6f 72 28 70 2d 3e 64 62 2c  ite3Error(p->db,
7c70: 20 53 51 4c 49 54 45 5f 4d 49 53 55 53 45 2c 20   SQLITE_MISUSE, 
7c80: 30 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f  0);.    sqlite3_
7c90: 6d 75 74 65 78 5f 6c 65 61 76 65 28 70 2d 3e 64  mutex_leave(p->d
7ca0: 62 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 20 20 73  b->mutex);.    s
7cb0: 71 6c 69 74 65 33 5f 6c 6f 67 28 53 51 4c 49 54  qlite3_log(SQLIT
7cc0: 45 5f 4d 49 53 55 53 45 2c 20 0a 20 20 20 20 20  E_MISUSE, .     
7cd0: 20 20 20 22 62 69 6e 64 20 6f 6e 20 61 20 62 75     "bind on a bu
7ce0: 73 79 20 70 72 65 70 61 72 65 64 20 73 74 61 74  sy prepared stat
7cf0: 65 6d 65 6e 74 3a 20 5b 25 73 5d 22 2c 20 70 2d  ement: [%s]", p-
7d00: 3e 7a 53 71 6c 29 3b 0a 20 20 20 20 72 65 74 75  >zSql);.    retu
7d10: 72 6e 20 53 51 4c 49 54 45 5f 4d 49 53 55 53 45  rn SQLITE_MISUSE
7d20: 5f 42 4b 50 54 3b 0a 20 20 7d 0a 20 20 69 66 28  _BKPT;.  }.  if(
7d30: 20 69 3c 31 20 7c 7c 20 69 3e 70 2d 3e 6e 56 61   i<1 || i>p->nVa
7d40: 72 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33  r ){.    sqlite3
7d50: 45 72 72 6f 72 28 70 2d 3e 64 62 2c 20 53 51 4c  Error(p->db, SQL
7d60: 49 54 45 5f 52 41 4e 47 45 2c 20 30 29 3b 0a 20  ITE_RANGE, 0);. 
7d70: 20 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78     sqlite3_mutex
7d80: 5f 6c 65 61 76 65 28 70 2d 3e 64 62 2d 3e 6d 75  _leave(p->db->mu
7d90: 74 65 78 29 3b 0a 20 20 20 20 72 65 74 75 72 6e  tex);.    return
7da0: 20 53 51 4c 49 54 45 5f 52 41 4e 47 45 3b 0a 20   SQLITE_RANGE;. 
7db0: 20 7d 0a 20 20 69 2d 2d 3b 0a 20 20 70 56 61 72   }.  i--;.  pVar
7dc0: 20 3d 20 26 70 2d 3e 61 56 61 72 5b 69 5d 3b 0a   = &p->aVar[i];.
7dd0: 20 20 73 71 6c 69 74 65 33 56 64 62 65 4d 65 6d    sqlite3VdbeMem
7de0: 52 65 6c 65 61 73 65 28 70 56 61 72 29 3b 0a 20  Release(pVar);. 
7df0: 20 70 56 61 72 2d 3e 66 6c 61 67 73 20 3d 20 4d   pVar->flags = M
7e00: 45 4d 5f 4e 75 6c 6c 3b 0a 20 20 73 71 6c 69 74  EM_Null;.  sqlit
7e10: 65 33 45 72 72 6f 72 28 70 2d 3e 64 62 2c 20 53  e3Error(p->db, S
7e20: 51 4c 49 54 45 5f 4f 4b 2c 20 30 29 3b 0a 0a 20  QLITE_OK, 0);.. 
7e30: 20 2f 2a 20 49 66 20 74 68 65 20 62 69 74 20 63   /* If the bit c
7e40: 6f 72 72 65 73 70 6f 6e 64 69 6e 67 20 74 6f 20  orresponding to 
7e50: 74 68 69 73 20 76 61 72 69 61 62 6c 65 20 69 6e  this variable in
7e60: 20 56 64 62 65 2e 65 78 70 6d 61 73 6b 20 69 73   Vdbe.expmask is
7e70: 20 73 65 74 2c 20 74 68 65 6e 20 0a 20 20 2a 2a   set, then .  **
7e80: 20 62 69 6e 64 69 6e 67 20 61 20 6e 65 77 20 76   binding a new v
7e90: 61 6c 75 65 20 74 6f 20 74 68 69 73 20 76 61 72  alue to this var
7ea0: 69 61 62 6c 65 20 69 6e 76 61 6c 69 64 61 74 65  iable invalidate
7eb0: 73 20 74 68 65 20 63 75 72 72 65 6e 74 20 71 75  s the current qu
7ec0: 65 72 79 20 70 6c 61 6e 2e 0a 20 20 2a 2a 0a 20  ery plan..  **. 
7ed0: 20 2a 2a 20 49 4d 50 4c 45 4d 45 4e 54 41 54 49   ** IMPLEMENTATI
7ee0: 4f 4e 2d 4f 46 3a 20 52 2d 34 38 34 34 30 2d 33  ON-OF: R-48440-3
7ef0: 37 35 39 35 20 49 66 20 74 68 65 20 73 70 65 63  7595 If the spec
7f00: 69 66 69 63 20 76 61 6c 75 65 20 62 6f 75 6e 64  ific value bound
7f10: 20 74 6f 20 68 6f 73 74 0a 20 20 2a 2a 20 70 61   to host.  ** pa
7f20: 72 61 6d 65 74 65 72 20 69 6e 20 74 68 65 20 57  rameter in the W
7f30: 48 45 52 45 20 63 6c 61 75 73 65 20 6d 69 67 68  HERE clause migh
7f40: 74 20 69 6e 66 6c 75 65 6e 63 65 20 74 68 65 20  t influence the 
7f50: 63 68 6f 69 63 65 20 6f 66 20 71 75 65 72 79 20  choice of query 
7f60: 70 6c 61 6e 0a 20 20 2a 2a 20 66 6f 72 20 61 20  plan.  ** for a 
7f70: 73 74 61 74 65 6d 65 6e 74 2c 20 74 68 65 6e 20  statement, then 
7f80: 74 68 65 20 73 74 61 74 65 6d 65 6e 74 20 77 69  the statement wi
7f90: 6c 6c 20 62 65 20 61 75 74 6f 6d 61 74 69 63 61  ll be automatica
7fa0: 6c 6c 79 20 72 65 63 6f 6d 70 69 6c 65 64 2c 0a  lly recompiled,.
7fb0: 20 20 2a 2a 20 61 73 20 69 66 20 74 68 65 72 65    ** as if there
7fc0: 20 68 61 64 20 62 65 65 6e 20 61 20 73 63 68 65   had been a sche
7fd0: 6d 61 20 63 68 61 6e 67 65 2c 20 6f 6e 20 74 68  ma change, on th
7fe0: 65 20 66 69 72 73 74 20 73 71 6c 69 74 65 33 5f  e first sqlite3_
7ff0: 73 74 65 70 28 29 20 63 61 6c 6c 0a 20 20 2a 2a  step() call.  **
8000: 20 66 6f 6c 6c 6f 77 69 6e 67 20 61 6e 79 20 63   following any c
8010: 68 61 6e 67 65 20 74 6f 20 74 68 65 20 62 69 6e  hange to the bin
8020: 64 69 6e 67 73 20 6f 66 20 74 68 61 74 20 70 61  dings of that pa
8030: 72 61 6d 65 74 65 72 2e 0a 20 20 2a 2f 0a 20 20  rameter..  */.  
8040: 69 66 28 20 70 2d 3e 69 73 50 72 65 70 61 72 65  if( p->isPrepare
8050: 56 32 20 26 26 0a 20 20 20 20 20 28 28 69 3c 33  V2 &&.     ((i<3
8060: 32 20 26 26 20 70 2d 3e 65 78 70 6d 61 73 6b 20  2 && p->expmask 
8070: 26 20 28 28 75 33 32 29 31 20 3c 3c 20 69 29 29  & ((u32)1 << i))
8080: 20 7c 7c 20 70 2d 3e 65 78 70 6d 61 73 6b 3d 3d   || p->expmask==
8090: 30 78 66 66 66 66 66 66 66 66 29 0a 20 20 29 7b  0xffffffff).  ){
80a0: 0a 20 20 20 20 70 2d 3e 65 78 70 69 72 65 64 20  .    p->expired 
80b0: 3d 20 31 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72  = 1;.  }.  retur
80c0: 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a  n SQLITE_OK;.}..
80d0: 2f 2a 0a 2a 2a 20 42 69 6e 64 20 61 20 74 65 78  /*.** Bind a tex
80e0: 74 20 6f 72 20 42 4c 4f 42 20 76 61 6c 75 65 2e  t or BLOB value.
80f0: 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 62  .*/.static int b
8100: 69 6e 64 54 65 78 74 28 0a 20 20 73 71 6c 69 74  indText(.  sqlit
8110: 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d 74 2c 20  e3_stmt *pStmt, 
8120: 20 20 2f 2a 20 54 68 65 20 73 74 61 74 65 6d 65    /* The stateme
8130: 6e 74 20 74 6f 20 62 69 6e 64 20 61 67 61 69 6e  nt to bind again
8140: 73 74 20 2a 2f 0a 20 20 69 6e 74 20 69 2c 20 20  st */.  int i,  
8150: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
8160: 2a 20 49 6e 64 65 78 20 6f 66 20 74 68 65 20 70  * Index of the p
8170: 61 72 61 6d 65 74 65 72 20 74 6f 20 62 69 6e 64  arameter to bind
8180: 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 76 6f 69 64   */.  const void
8190: 20 2a 7a 44 61 74 61 2c 20 20 20 20 20 2f 2a 20   *zData,     /* 
81a0: 50 6f 69 6e 74 65 72 20 74 6f 20 74 68 65 20 64  Pointer to the d
81b0: 61 74 61 20 74 6f 20 62 65 20 62 6f 75 6e 64 20  ata to be bound 
81c0: 2a 2f 0a 20 20 69 6e 74 20 6e 44 61 74 61 2c 20  */.  int nData, 
81d0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e              /* N
81e0: 75 6d 62 65 72 20 6f 66 20 62 79 74 65 73 20 6f  umber of bytes o
81f0: 66 20 64 61 74 61 20 74 6f 20 62 65 20 62 6f 75  f data to be bou
8200: 6e 64 20 2a 2f 0a 20 20 76 6f 69 64 20 28 2a 78  nd */.  void (*x
8210: 44 65 6c 29 28 76 6f 69 64 2a 29 2c 20 20 20 2f  Del)(void*),   /
8220: 2a 20 44 65 73 74 72 75 63 74 6f 72 20 66 6f 72  * Destructor for
8230: 20 74 68 65 20 64 61 74 61 20 2a 2f 0a 20 20 75   the data */.  u
8240: 38 20 65 6e 63 6f 64 69 6e 67 20 20 20 20 20 20  8 encoding      
8250: 20 20 20 20 20 20 2f 2a 20 45 6e 63 6f 64 69 6e        /* Encodin
8260: 67 20 66 6f 72 20 74 68 65 20 64 61 74 61 20 2a  g for the data *
8270: 2f 0a 29 7b 0a 20 20 56 64 62 65 20 2a 70 20 3d  /.){.  Vdbe *p =
8280: 20 28 56 64 62 65 20 2a 29 70 53 74 6d 74 3b 0a   (Vdbe *)pStmt;.
8290: 20 20 4d 65 6d 20 2a 70 56 61 72 3b 0a 20 20 69    Mem *pVar;.  i
82a0: 6e 74 20 72 63 3b 0a 0a 20 20 72 63 20 3d 20 76  nt rc;..  rc = v
82b0: 64 62 65 55 6e 62 69 6e 64 28 70 2c 20 69 29 3b  dbeUnbind(p, i);
82c0: 0a 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54  .  if( rc==SQLIT
82d0: 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 69 66 28 20  E_OK ){.    if( 
82e0: 7a 44 61 74 61 21 3d 30 20 29 7b 0a 20 20 20 20  zData!=0 ){.    
82f0: 20 20 70 56 61 72 20 3d 20 26 70 2d 3e 61 56 61    pVar = &p->aVa
8300: 72 5b 69 2d 31 5d 3b 0a 20 20 20 20 20 20 72 63  r[i-1];.      rc
8310: 20 3d 20 73 71 6c 69 74 65 33 56 64 62 65 4d 65   = sqlite3VdbeMe
8320: 6d 53 65 74 53 74 72 28 70 56 61 72 2c 20 7a 44  mSetStr(pVar, zD
8330: 61 74 61 2c 20 6e 44 61 74 61 2c 20 65 6e 63 6f  ata, nData, enco
8340: 64 69 6e 67 2c 20 78 44 65 6c 29 3b 0a 20 20 20  ding, xDel);.   
8350: 20 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54     if( rc==SQLIT
8360: 45 5f 4f 4b 20 26 26 20 65 6e 63 6f 64 69 6e 67  E_OK && encoding
8370: 21 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 72  !=0 ){.        r
8380: 63 20 3d 20 73 71 6c 69 74 65 33 56 64 62 65 43  c = sqlite3VdbeC
8390: 68 61 6e 67 65 45 6e 63 6f 64 69 6e 67 28 70 56  hangeEncoding(pV
83a0: 61 72 2c 20 45 4e 43 28 70 2d 3e 64 62 29 29 3b  ar, ENC(p->db));
83b0: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 73  .      }.      s
83c0: 71 6c 69 74 65 33 45 72 72 6f 72 28 70 2d 3e 64  qlite3Error(p->d
83d0: 62 2c 20 72 63 2c 20 30 29 3b 0a 20 20 20 20 20  b, rc, 0);.     
83e0: 20 72 63 20 3d 20 73 71 6c 69 74 65 33 41 70 69   rc = sqlite3Api
83f0: 45 78 69 74 28 70 2d 3e 64 62 2c 20 72 63 29 3b  Exit(p->db, rc);
8400: 0a 20 20 20 20 7d 0a 20 20 20 20 73 71 6c 69 74  .    }.    sqlit
8410: 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 70  e3_mutex_leave(p
8420: 2d 3e 64 62 2d 3e 6d 75 74 65 78 29 3b 0a 20 20  ->db->mutex);.  
8430: 7d 65 6c 73 65 20 69 66 28 20 78 44 65 6c 21 3d  }else if( xDel!=
8440: 53 51 4c 49 54 45 5f 53 54 41 54 49 43 20 26 26  SQLITE_STATIC &&
8450: 20 78 44 65 6c 21 3d 53 51 4c 49 54 45 5f 54 52   xDel!=SQLITE_TR
8460: 41 4e 53 49 45 4e 54 20 29 7b 0a 20 20 20 20 78  ANSIENT ){.    x
8470: 44 65 6c 28 28 76 6f 69 64 2a 29 7a 44 61 74 61  Del((void*)zData
8480: 29 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20  );.  }.  return 
8490: 72 63 3b 0a 7d 0a 0a 0a 2f 2a 0a 2a 2a 20 42 69  rc;.}.../*.** Bi
84a0: 6e 64 20 61 20 62 6c 6f 62 20 76 61 6c 75 65 20  nd a blob value 
84b0: 74 6f 20 61 6e 20 53 51 4c 20 73 74 61 74 65 6d  to an SQL statem
84c0: 65 6e 74 20 76 61 72 69 61 62 6c 65 2e 0a 2a 2f  ent variable..*/
84d0: 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f 62 69 6e  .int sqlite3_bin
84e0: 64 5f 62 6c 6f 62 28 0a 20 20 73 71 6c 69 74 65  d_blob(.  sqlite
84f0: 33 5f 73 74 6d 74 20 2a 70 53 74 6d 74 2c 20 0a  3_stmt *pStmt, .
8500: 20 20 69 6e 74 20 69 2c 20 0a 20 20 63 6f 6e 73    int i, .  cons
8510: 74 20 76 6f 69 64 20 2a 7a 44 61 74 61 2c 20 0a  t void *zData, .
8520: 20 20 69 6e 74 20 6e 44 61 74 61 2c 20 0a 20 20    int nData, .  
8530: 76 6f 69 64 20 28 2a 78 44 65 6c 29 28 76 6f 69  void (*xDel)(voi
8540: 64 2a 29 0a 29 7b 0a 23 69 66 64 65 66 20 53 51  d*).){.#ifdef SQ
8550: 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 53 51 4c 52  LITE_ENABLE_SQLR
8560: 52 0a 20 20 53 52 52 65 63 42 69 6e 64 42 6c 6f  R.  SRRecBindBlo
8570: 62 28 70 53 74 6d 74 2c 20 69 2c 20 7a 44 61 74  b(pStmt, i, zDat
8580: 61 2c 20 6e 44 61 74 61 29 3b 0a 23 65 6e 64 69  a, nData);.#endi
8590: 66 0a 20 20 72 65 74 75 72 6e 20 62 69 6e 64 54  f.  return bindT
85a0: 65 78 74 28 70 53 74 6d 74 2c 20 69 2c 20 7a 44  ext(pStmt, i, zD
85b0: 61 74 61 2c 20 6e 44 61 74 61 2c 20 78 44 65 6c  ata, nData, xDel
85c0: 2c 20 30 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69  , 0);.}.int sqli
85d0: 74 65 33 5f 62 69 6e 64 5f 64 6f 75 62 6c 65 28  te3_bind_double(
85e0: 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70 53  sqlite3_stmt *pS
85f0: 74 6d 74 2c 20 69 6e 74 20 69 2c 20 64 6f 75 62  tmt, int i, doub
8600: 6c 65 20 72 56 61 6c 75 65 29 7b 0a 20 20 69 6e  le rValue){.  in
8610: 74 20 72 63 3b 0a 20 20 56 64 62 65 20 2a 70 20  t rc;.  Vdbe *p 
8620: 3d 20 28 56 64 62 65 20 2a 29 70 53 74 6d 74 3b  = (Vdbe *)pStmt;
8630: 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 45  .#ifdef SQLITE_E
8640: 4e 41 42 4c 45 5f 53 51 4c 52 52 0a 20 20 53 52  NABLE_SQLRR.  SR
8650: 52 65 63 42 69 6e 64 44 6f 75 62 6c 65 28 70 53  RecBindDouble(pS
8660: 74 6d 74 2c 20 69 2c 20 72 56 61 6c 75 65 29 3b  tmt, i, rValue);
8670: 0a 23 65 6e 64 69 66 0a 20 20 72 63 20 3d 20 76  .#endif.  rc = v
8680: 64 62 65 55 6e 62 69 6e 64 28 70 2c 20 69 29 3b  dbeUnbind(p, i);
8690: 0a 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54  .  if( rc==SQLIT
86a0: 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 73 71 6c 69  E_OK ){.    sqli
86b0: 74 65 33 56 64 62 65 4d 65 6d 53 65 74 44 6f 75  te3VdbeMemSetDou
86c0: 62 6c 65 28 26 70 2d 3e 61 56 61 72 5b 69 2d 31  ble(&p->aVar[i-1
86d0: 5d 2c 20 72 56 61 6c 75 65 29 3b 0a 20 20 20 20  ], rValue);.    
86e0: 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65  sqlite3_mutex_le
86f0: 61 76 65 28 70 2d 3e 64 62 2d 3e 6d 75 74 65 78  ave(p->db->mutex
8700: 29 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20  );.  }.  return 
8710: 72 63 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65  rc;.}.int sqlite
8720: 33 5f 62 69 6e 64 5f 69 6e 74 28 73 71 6c 69 74  3_bind_int(sqlit
8730: 65 33 5f 73 74 6d 74 20 2a 70 2c 20 69 6e 74 20  e3_stmt *p, int 
8740: 69 2c 20 69 6e 74 20 69 56 61 6c 75 65 29 7b 0a  i, int iValue){.
8750: 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 45 4e  #ifdef SQLITE_EN
8760: 41 42 4c 45 5f 53 51 4c 52 52 0a 20 20 53 52 52  ABLE_SQLRR.  SRR
8770: 65 63 42 69 6e 64 49 6e 74 36 34 28 70 2c 20 69  ecBindInt64(p, i
8780: 2c 20 28 69 36 34 29 69 56 61 6c 75 65 29 3b 0a  , (i64)iValue);.
8790: 23 65 6e 64 69 66 0a 20 20 72 65 74 75 72 6e 20  #endif.  return 
87a0: 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74  sqlite3_bind_int
87b0: 36 34 28 70 2c 20 69 2c 20 28 69 36 34 29 69 56  64(p, i, (i64)iV
87c0: 61 6c 75 65 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c  alue);.}.int sql
87d0: 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74 36 34 28  ite3_bind_int64(
87e0: 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70 53  sqlite3_stmt *pS
87f0: 74 6d 74 2c 20 69 6e 74 20 69 2c 20 73 71 6c 69  tmt, int i, sqli
8800: 74 65 5f 69 6e 74 36 34 20 69 56 61 6c 75 65 29  te_int64 iValue)
8810: 7b 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20 56 64  {.  int rc;.  Vd
8820: 62 65 20 2a 70 20 3d 20 28 56 64 62 65 20 2a 29  be *p = (Vdbe *)
8830: 70 53 74 6d 74 3b 0a 23 69 66 64 65 66 20 53 51  pStmt;.#ifdef SQ
8840: 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 53 51 4c 52  LITE_ENABLE_SQLR
8850: 52 0a 20 20 53 52 52 65 63 42 69 6e 64 49 6e 74  R.  SRRecBindInt
8860: 36 34 28 70 53 74 6d 74 2c 20 69 2c 20 69 56 61  64(pStmt, i, iVa
8870: 6c 75 65 29 3b 0a 23 65 6e 64 69 66 0a 20 20 72  lue);.#endif.  r
8880: 63 20 3d 20 76 64 62 65 55 6e 62 69 6e 64 28 70  c = vdbeUnbind(p
8890: 2c 20 69 29 3b 0a 20 20 69 66 28 20 72 63 3d 3d  , i);.  if( rc==
88a0: 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20  SQLITE_OK ){.   
88b0: 20 73 71 6c 69 74 65 33 56 64 62 65 4d 65 6d 53   sqlite3VdbeMemS
88c0: 65 74 49 6e 74 36 34 28 26 70 2d 3e 61 56 61 72  etInt64(&p->aVar
88d0: 5b 69 2d 31 5d 2c 20 69 56 61 6c 75 65 29 3b 0a  [i-1], iValue);.
88e0: 20 20 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65      sqlite3_mute
88f0: 78 5f 6c 65 61 76 65 28 70 2d 3e 64 62 2d 3e 6d  x_leave(p->db->m
8900: 75 74 65 78 29 3b 0a 20 20 7d 0a 20 20 72 65 74  utex);.  }.  ret
8910: 75 72 6e 20 72 63 3b 0a 7d 0a 69 6e 74 20 73 71  urn rc;.}.int sq
8920: 6c 69 74 65 33 5f 62 69 6e 64 5f 6e 75 6c 6c 28  lite3_bind_null(
8930: 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70 53  sqlite3_stmt *pS
8940: 74 6d 74 2c 20 69 6e 74 20 69 29 7b 0a 20 20 69  tmt, int i){.  i
8950: 6e 74 20 72 63 3b 0a 20 20 56 64 62 65 20 2a 70  nt rc;.  Vdbe *p
8960: 20 3d 20 28 56 64 62 65 2a 29 70 53 74 6d 74 3b   = (Vdbe*)pStmt;
8970: 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 45  .#ifdef SQLITE_E
8980: 4e 41 42 4c 45 5f 53 51 4c 52 52 0a 20 20 53 52  NABLE_SQLRR.  SR
8990: 52 65 63 42 69 6e 64 4e 75 6c 6c 28 70 53 74 6d  RecBindNull(pStm
89a0: 74 2c 20 69 29 3b 0a 23 65 6e 64 69 66 0a 20 20  t, i);.#endif.  
89b0: 72 63 20 3d 20 76 64 62 65 55 6e 62 69 6e 64 28  rc = vdbeUnbind(
89c0: 70 2c 20 69 29 3b 0a 20 20 69 66 28 20 72 63 3d  p, i);.  if( rc=
89d0: 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20  =SQLITE_OK ){.  
89e0: 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f    sqlite3_mutex_
89f0: 6c 65 61 76 65 28 70 2d 3e 64 62 2d 3e 6d 75 74  leave(p->db->mut
8a00: 65 78 29 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72  ex);.  }.  retur
8a10: 6e 20 72 63 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69  n rc;.}.int sqli
8a20: 74 65 33 5f 62 69 6e 64 5f 74 65 78 74 28 20 0a  te3_bind_text( .
8a30: 20 20 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a    sqlite3_stmt *
8a40: 70 53 74 6d 74 2c 20 0a 20 20 69 6e 74 20 69 2c  pStmt, .  int i,
8a50: 20 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a   .  const char *
8a60: 7a 44 61 74 61 2c 20 0a 20 20 69 6e 74 20 6e 44  zData, .  int nD
8a70: 61 74 61 2c 20 0a 20 20 76 6f 69 64 20 28 2a 78  ata, .  void (*x
8a80: 44 65 6c 29 28 76 6f 69 64 2a 29 0a 29 7b 0a 23  Del)(void*).){.#
8a90: 69 66 64 65 66 20 53 51 4c 49 54 45 5f 45 4e 41  ifdef SQLITE_ENA
8aa0: 42 4c 45 5f 53 51 4c 52 52 0a 20 20 53 52 52 65  BLE_SQLRR.  SRRe
8ab0: 63 42 69 6e 64 54 65 78 74 28 70 53 74 6d 74 2c  cBindText(pStmt,
8ac0: 20 69 2c 20 7a 44 61 74 61 2c 20 6e 44 61 74 61   i, zData, nData
8ad0: 29 3b 0a 23 65 6e 64 69 66 0a 20 20 72 65 74 75  );.#endif.  retu
8ae0: 72 6e 20 62 69 6e 64 54 65 78 74 28 70 53 74 6d  rn bindText(pStm
8af0: 74 2c 20 69 2c 20 7a 44 61 74 61 2c 20 6e 44 61  t, i, zData, nDa
8b00: 74 61 2c 20 78 44 65 6c 2c 20 53 51 4c 49 54 45  ta, xDel, SQLITE
8b10: 5f 55 54 46 38 29 3b 0a 7d 0a 23 69 66 6e 64 65  _UTF8);.}.#ifnde
8b20: 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 55 54  f SQLITE_OMIT_UT
8b30: 46 31 36 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f  F16.int sqlite3_
8b40: 62 69 6e 64 5f 74 65 78 74 31 36 28 0a 20 20 73  bind_text16(.  s
8b50: 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70 53 74  qlite3_stmt *pSt
8b60: 6d 74 2c 20 0a 20 20 69 6e 74 20 69 2c 20 0a 20  mt, .  int i, . 
8b70: 20 63 6f 6e 73 74 20 76 6f 69 64 20 2a 7a 44 61   const void *zDa
8b80: 74 61 2c 20 0a 20 20 69 6e 74 20 6e 44 61 74 61  ta, .  int nData
8b90: 2c 20 0a 20 20 76 6f 69 64 20 28 2a 78 44 65 6c  , .  void (*xDel
8ba0: 29 28 76 6f 69 64 2a 29 0a 29 7b 0a 23 69 66 64  )(void*).){.#ifd
8bb0: 65 66 20 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45  ef SQLITE_ENABLE
8bc0: 5f 53 51 4c 52 52 0a 20 20 53 52 52 65 63 42 69  _SQLRR.  SRRecBi
8bd0: 6e 64 54 65 78 74 28 70 53 74 6d 74 2c 20 69 2c  ndText(pStmt, i,
8be0: 20 7a 44 61 74 61 2c 20 6e 44 61 74 61 29 3b 0a   zData, nData);.
8bf0: 23 65 6e 64 69 66 0a 20 20 72 65 74 75 72 6e 20  #endif.  return 
8c00: 62 69 6e 64 54 65 78 74 28 70 53 74 6d 74 2c 20  bindText(pStmt, 
8c10: 69 2c 20 7a 44 61 74 61 2c 20 6e 44 61 74 61 2c  i, zData, nData,
8c20: 20 78 44 65 6c 2c 20 53 51 4c 49 54 45 5f 55 54   xDel, SQLITE_UT
8c30: 46 31 36 4e 41 54 49 56 45 29 3b 0a 7d 0a 23 65  F16NATIVE);.}.#e
8c40: 6e 64 69 66 20 2f 2a 20 53 51 4c 49 54 45 5f 4f  ndif /* SQLITE_O
8c50: 4d 49 54 5f 55 54 46 31 36 20 2a 2f 0a 69 6e 74  MIT_UTF16 */.int
8c60: 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 76 61   sqlite3_bind_va
8c70: 6c 75 65 28 73 71 6c 69 74 65 33 5f 73 74 6d 74  lue(sqlite3_stmt
8c80: 20 2a 70 53 74 6d 74 2c 20 69 6e 74 20 69 2c 20   *pStmt, int i, 
8c90: 63 6f 6e 73 74 20 73 71 6c 69 74 65 33 5f 76 61  const sqlite3_va
8ca0: 6c 75 65 20 2a 70 56 61 6c 75 65 29 7b 0a 20 20  lue *pValue){.  
8cb0: 69 6e 74 20 72 63 3b 0a 20 20 73 77 69 74 63 68  int rc;.  switch
8cc0: 28 20 70 56 61 6c 75 65 2d 3e 74 79 70 65 20 29  ( pValue->type )
8cd0: 7b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  {.    case SQLIT
8ce0: 45 5f 49 4e 54 45 47 45 52 3a 20 7b 0a 20 20 20  E_INTEGER: {.   
8cf0: 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f     rc = sqlite3_
8d00: 62 69 6e 64 5f 69 6e 74 36 34 28 70 53 74 6d 74  bind_int64(pStmt
8d10: 2c 20 69 2c 20 70 56 61 6c 75 65 2d 3e 75 2e 69  , i, pValue->u.i
8d20: 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  );.      break;.
8d30: 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 53      }.    case S
8d40: 51 4c 49 54 45 5f 46 4c 4f 41 54 3a 20 7b 0a 20  QLITE_FLOAT: {. 
8d50: 20 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65       rc = sqlite
8d60: 33 5f 62 69 6e 64 5f 64 6f 75 62 6c 65 28 70 53  3_bind_double(pS
8d70: 74 6d 74 2c 20 69 2c 20 70 56 61 6c 75 65 2d 3e  tmt, i, pValue->
8d80: 72 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b  r);.      break;
8d90: 0a 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20  .    }.    case 
8da0: 53 51 4c 49 54 45 5f 42 4c 4f 42 3a 20 7b 0a 20  SQLITE_BLOB: {. 
8db0: 20 20 20 20 20 69 66 28 20 70 56 61 6c 75 65 2d       if( pValue-
8dc0: 3e 66 6c 61 67 73 20 26 20 4d 45 4d 5f 5a 65 72  >flags & MEM_Zer
8dd0: 6f 20 29 7b 0a 20 20 20 20 20 20 20 20 72 63 20  o ){.        rc 
8de0: 3d 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 7a  = sqlite3_bind_z
8df0: 65 72 6f 62 6c 6f 62 28 70 53 74 6d 74 2c 20 69  eroblob(pStmt, i
8e00: 2c 20 70 56 61 6c 75 65 2d 3e 75 2e 6e 5a 65 72  , pValue->u.nZer
8e10: 6f 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 7b  o);.      }else{
8e20: 0a 20 20 20 20 20 20 20 20 72 63 20 3d 20 73 71  .        rc = sq
8e30: 6c 69 74 65 33 5f 62 69 6e 64 5f 62 6c 6f 62 28  lite3_bind_blob(
8e40: 70 53 74 6d 74 2c 20 69 2c 20 70 56 61 6c 75 65  pStmt, i, pValue
8e50: 2d 3e 7a 2c 20 70 56 61 6c 75 65 2d 3e 6e 2c 53  ->z, pValue->n,S
8e60: 51 4c 49 54 45 5f 54 52 41 4e 53 49 45 4e 54 29  QLITE_TRANSIENT)
8e70: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20  ;.      }.      
8e80: 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20  break;.    }.   
8e90: 20 63 61 73 65 20 53 51 4c 49 54 45 5f 54 45 58   case SQLITE_TEX
8ea0: 54 3a 20 7b 0a 23 69 66 64 65 66 20 53 51 4c 49  T: {.#ifdef SQLI
8eb0: 54 45 5f 45 4e 41 42 4c 45 5f 53 51 4c 52 52 0a  TE_ENABLE_SQLRR.
8ec0: 20 20 20 20 20 20 53 52 52 65 63 42 69 6e 64 54        SRRecBindT
8ed0: 65 78 74 28 70 53 74 6d 74 2c 20 69 2c 20 70 56  ext(pStmt, i, pV
8ee0: 61 6c 75 65 2d 3e 7a 2c 20 70 56 61 6c 75 65 2d  alue->z, pValue-
8ef0: 3e 6e 29 3b 0a 23 65 6e 64 69 66 0a 20 20 20 20  >n);.#endif.    
8f00: 20 20 72 63 20 3d 20 62 69 6e 64 54 65 78 74 28    rc = bindText(
8f10: 70 53 74 6d 74 2c 69 2c 20 20 70 56 61 6c 75 65  pStmt,i,  pValue
8f20: 2d 3e 7a 2c 20 70 56 61 6c 75 65 2d 3e 6e 2c 20  ->z, pValue->n, 
8f30: 53 51 4c 49 54 45 5f 54 52 41 4e 53 49 45 4e 54  SQLITE_TRANSIENT
8f40: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,.              
8f50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8f60: 70 56 61 6c 75 65 2d 3e 65 6e 63 29 3b 0a 20 20  pValue->enc);.  
8f70: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d      break;.    }
8f80: 0a 20 20 20 20 64 65 66 61 75 6c 74 3a 20 7b 0a  .    default: {.
8f90: 20 20 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74        rc = sqlit
8fa0: 65 33 5f 62 69 6e 64 5f 6e 75 6c 6c 28 70 53 74  e3_bind_null(pSt
8fb0: 6d 74 2c 20 69 29 3b 0a 20 20 20 20 20 20 62 72  mt, i);.      br
8fc0: 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20  eak;.    }.  }. 
8fd0: 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 69 6e   return rc;.}.in
8fe0: 74 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 7a  t sqlite3_bind_z
8ff0: 65 72 6f 62 6c 6f 62 28 73 71 6c 69 74 65 33 5f  eroblob(sqlite3_
9000: 73 74 6d 74 20 2a 70 53 74 6d 74 2c 20 69 6e 74  stmt *pStmt, int
9010: 20 69 2c 20 69 6e 74 20 6e 29 7b 0a 20 20 69 6e   i, int n){.  in
9020: 74 20 72 63 3b 0a 20 20 56 64 62 65 20 2a 70 20  t rc;.  Vdbe *p 
9030: 3d 20 28 56 64 62 65 20 2a 29 70 53 74 6d 74 3b  = (Vdbe *)pStmt;
9040: 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 45  .#ifdef SQLITE_E
9050: 4e 41 42 4c 45 5f 53 51 4c 52 52 0a 20 20 53 52  NABLE_SQLRR.  SR
9060: 52 65 63 42 69 6e 64 42 6c 6f 62 28 70 53 74 6d  RecBindBlob(pStm
9070: 74 2c 20 69 2c 20 4e 55 4c 4c 2c 20 6e 29 3b 0a  t, i, NULL, n);.
9080: 23 65 6e 64 69 66 0a 20 20 72 63 20 3d 20 76 64  #endif.  rc = vd
9090: 62 65 55 6e 62 69 6e 64 28 70 2c 20 69 29 3b 0a  beUnbind(p, i);.
90a0: 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45    if( rc==SQLITE
90b0: 5f 4f 4b 20 29 7b 0a 20 20 20 20 73 71 6c 69 74  _OK ){.    sqlit
90c0: 65 33 56 64 62 65 4d 65 6d 53 65 74 5a 65 72 6f  e3VdbeMemSetZero
90d0: 42 6c 6f 62 28 26 70 2d 3e 61 56 61 72 5b 69 2d  Blob(&p->aVar[i-
90e0: 31 5d 2c 20 6e 29 3b 0a 20 20 20 20 73 71 6c 69  1], n);.    sqli
90f0: 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28  te3_mutex_leave(
9100: 70 2d 3e 64 62 2d 3e 6d 75 74 65 78 29 3b 0a 20  p->db->mutex);. 
9110: 20 7d 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a   }.  return rc;.
9120: 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20  }../*.** Return 
9130: 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 77 69  the number of wi
9140: 6c 64 63 61 72 64 73 20 74 68 61 74 20 63 61 6e  ldcards that can
9150: 20 62 65 20 70 6f 74 65 6e 74 69 61 6c 6c 79 20   be potentially 
9160: 62 6f 75 6e 64 20 74 6f 2e 0a 2a 2a 20 54 68 69  bound to..** Thi
9170: 73 20 72 6f 75 74 69 6e 65 20 69 73 20 61 64 64  s routine is add
9180: 65 64 20 74 6f 20 73 75 70 70 6f 72 74 20 44 42  ed to support DB
9190: 44 3a 3a 53 51 4c 69 74 65 2e 20 20 0a 2a 2f 0a  D::SQLite.  .*/.
91a0: 69 6e 74 20 73 71 6c 69 74 65 33 5f 62 69 6e 64  int sqlite3_bind
91b0: 5f 70 61 72 61 6d 65 74 65 72 5f 63 6f 75 6e 74  _parameter_count
91c0: 28 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70  (sqlite3_stmt *p
91d0: 53 74 6d 74 29 7b 0a 20 20 56 64 62 65 20 2a 70  Stmt){.  Vdbe *p
91e0: 20 3d 20 28 56 64 62 65 2a 29 70 53 74 6d 74 3b   = (Vdbe*)pStmt;
91f0: 0a 20 20 72 65 74 75 72 6e 20 70 20 3f 20 70 2d  .  return p ? p-
9200: 3e 6e 56 61 72 20 3a 20 30 3b 0a 7d 0a 0a 2f 2a  >nVar : 0;.}../*
9210: 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20 6e  .** Return the n
9220: 61 6d 65 20 6f 66 20 61 20 77 69 6c 64 63 61 72  ame of a wildcar
9230: 64 20 70 61 72 61 6d 65 74 65 72 2e 20 20 52 65  d parameter.  Re
9240: 74 75 72 6e 20 4e 55 4c 4c 20 69 66 20 74 68 65  turn NULL if the
9250: 20 69 6e 64 65 78 0a 2a 2a 20 69 73 20 6f 75 74   index.** is out
9260: 20 6f 66 20 72 61 6e 67 65 20 6f 72 20 69 66 20   of range or if 
9270: 74 68 65 20 77 69 6c 64 63 61 72 64 20 69 73 20  the wildcard is 
9280: 75 6e 6e 61 6d 65 64 2e 0a 2a 2a 0a 2a 2a 20 54  unnamed..**.** T
9290: 68 65 20 72 65 73 75 6c 74 20 69 73 20 61 6c 77  he result is alw
92a0: 61 79 73 20 55 54 46 2d 38 2e 0a 2a 2f 0a 63 6f  ays UTF-8..*/.co
92b0: 6e 73 74 20 63 68 61 72 20 2a 73 71 6c 69 74 65  nst char *sqlite
92c0: 33 5f 62 69 6e 64 5f 70 61 72 61 6d 65 74 65 72  3_bind_parameter
92d0: 5f 6e 61 6d 65 28 73 71 6c 69 74 65 33 5f 73 74  _name(sqlite3_st
92e0: 6d 74 20 2a 70 53 74 6d 74 2c 20 69 6e 74 20 69  mt *pStmt, int i
92f0: 29 7b 0a 20 20 56 64 62 65 20 2a 70 20 3d 20 28  ){.  Vdbe *p = (
9300: 56 64 62 65 2a 29 70 53 74 6d 74 3b 0a 20 20 69  Vdbe*)pStmt;.  i
9310: 66 28 20 70 3d 3d 30 20 7c 7c 20 69 3c 31 20 7c  f( p==0 || i<1 |
9320: 7c 20 69 3e 70 2d 3e 6e 7a 56 61 72 20 29 7b 0a  | i>p->nzVar ){.
9330: 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20      return 0;.  
9340: 7d 0a 20 20 72 65 74 75 72 6e 20 70 2d 3e 61 7a  }.  return p->az
9350: 56 61 72 5b 69 2d 31 5d 3b 0a 7d 0a 0a 2f 2a 0a  Var[i-1];.}../*.
9360: 2a 2a 20 47 69 76 65 6e 20 61 20 77 69 6c 64 63  ** Given a wildc
9370: 61 72 64 20 70 61 72 61 6d 65 74 65 72 20 6e 61  ard parameter na
9380: 6d 65 2c 20 72 65 74 75 72 6e 20 74 68 65 20 69  me, return the i
9390: 6e 64 65 78 20 6f 66 20 74 68 65 20 76 61 72 69  ndex of the vari
93a0: 61 62 6c 65 0a 2a 2a 20 77 69 74 68 20 74 68 61  able.** with tha
93b0: 74 20 6e 61 6d 65 2e 20 20 49 66 20 74 68 65 72  t name.  If ther
93c0: 65 20 69 73 20 6e 6f 20 76 61 72 69 61 62 6c 65  e is no variable
93d0: 20 77 69 74 68 20 74 68 65 20 67 69 76 65 6e 20   with the given 
93e0: 6e 61 6d 65 2c 0a 2a 2a 20 72 65 74 75 72 6e 20  name,.** return 
93f0: 30 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65  0..*/.int sqlite
9400: 33 56 64 62 65 50 61 72 61 6d 65 74 65 72 49 6e  3VdbeParameterIn
9410: 64 65 78 28 56 64 62 65 20 2a 70 2c 20 63 6f 6e  dex(Vdbe *p, con
9420: 73 74 20 63 68 61 72 20 2a 7a 4e 61 6d 65 2c 20  st char *zName, 
9430: 69 6e 74 20 6e 4e 61 6d 65 29 7b 0a 20 20 69 6e  int nName){.  in
9440: 74 20 69 3b 0a 20 20 69 66 28 20 70 3d 3d 30 20  t i;.  if( p==0 
9450: 29 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 30 3b  ){.    return 0;
9460: 0a 20 20 7d 0a 20 20 69 66 28 20 7a 4e 61 6d 65  .  }.  if( zName
9470: 20 29 7b 0a 20 20 20 20 66 6f 72 28 69 3d 30 3b   ){.    for(i=0;
9480: 20 69 3c 70 2d 3e 6e 7a 56 61 72 3b 20 69 2b 2b   i<p->nzVar; i++
9490: 29 7b 0a 20 20 20 20 20 20 63 6f 6e 73 74 20 63  ){.      const c
94a0: 68 61 72 20 2a 7a 20 3d 20 70 2d 3e 61 7a 56 61  har *z = p->azVa
94b0: 72 5b 69 5d 3b 0a 20 20 20 20 20 20 69 66 28 20  r[i];.      if( 
94c0: 7a 20 26 26 20 6d 65 6d 63 6d 70 28 7a 2c 7a 4e  z && memcmp(z,zN
94d0: 61 6d 65 2c 6e 4e 61 6d 65 29 3d 3d 30 20 26 26  ame,nName)==0 &&
94e0: 20 7a 5b 6e 4e 61 6d 65 5d 3d 3d 30 20 29 7b 0a   z[nName]==0 ){.
94f0: 20 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 69          return i
9500: 2b 31 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  +1;.      }.    
9510: 7d 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 30  }.  }.  return 0
9520: 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f  ;.}.int sqlite3_
9530: 62 69 6e 64 5f 70 61 72 61 6d 65 74 65 72 5f 69  bind_parameter_i
9540: 6e 64 65 78 28 73 71 6c 69 74 65 33 5f 73 74 6d  ndex(sqlite3_stm
9550: 74 20 2a 70 53 74 6d 74 2c 20 63 6f 6e 73 74 20  t *pStmt, const 
9560: 63 68 61 72 20 2a 7a 4e 61 6d 65 29 7b 0a 20 20  char *zName){.  
9570: 72 65 74 75 72 6e 20 73 71 6c 69 74 65 33 56 64  return sqlite3Vd
9580: 62 65 50 61 72 61 6d 65 74 65 72 49 6e 64 65 78  beParameterIndex
9590: 28 28 56 64 62 65 2a 29 70 53 74 6d 74 2c 20 7a  ((Vdbe*)pStmt, z
95a0: 4e 61 6d 65 2c 20 73 71 6c 69 74 65 33 53 74 72  Name, sqlite3Str
95b0: 6c 65 6e 33 30 28 7a 4e 61 6d 65 29 29 3b 0a 7d  len30(zName));.}
95c0: 0a 0a 2f 2a 0a 2a 2a 20 54 72 61 6e 73 66 65 72  ../*.** Transfer
95d0: 20 61 6c 6c 20 62 69 6e 64 69 6e 67 73 20 66 72   all bindings fr
95e0: 6f 6d 20 74 68 65 20 66 69 72 73 74 20 73 74 61  om the first sta
95f0: 74 65 6d 65 6e 74 20 6f 76 65 72 20 74 6f 20 74  tement over to t
9600: 68 65 20 73 65 63 6f 6e 64 2e 0a 2a 2f 0a 69 6e  he second..*/.in
9610: 74 20 73 71 6c 69 74 65 33 54 72 61 6e 73 66 65  t sqlite3Transfe
9620: 72 42 69 6e 64 69 6e 67 73 28 73 71 6c 69 74 65  rBindings(sqlite
9630: 33 5f 73 74 6d 74 20 2a 70 46 72 6f 6d 53 74 6d  3_stmt *pFromStm
9640: 74 2c 20 73 71 6c 69 74 65 33 5f 73 74 6d 74 20  t, sqlite3_stmt 
9650: 2a 70 54 6f 53 74 6d 74 29 7b 0a 20 20 56 64 62  *pToStmt){.  Vdb
9660: 65 20 2a 70 46 72 6f 6d 20 3d 20 28 56 64 62 65  e *pFrom = (Vdbe
9670: 2a 29 70 46 72 6f 6d 53 74 6d 74 3b 0a 20 20 56  *)pFromStmt;.  V
9680: 64 62 65 20 2a 70 54 6f 20 3d 20 28 56 64 62 65  dbe *pTo = (Vdbe
9690: 2a 29 70 54 6f 53 74 6d 74 3b 0a 20 20 69 6e 74  *)pToStmt;.  int
96a0: 20 69 3b 0a 20 20 61 73 73 65 72 74 28 20 70 54   i;.  assert( pT
96b0: 6f 2d 3e 64 62 3d 3d 70 46 72 6f 6d 2d 3e 64 62  o->db==pFrom->db
96c0: 20 29 3b 0a 20 20 61 73 73 65 72 74 28 20 70 54   );.  assert( pT
96d0: 6f 2d 3e 6e 56 61 72 3d 3d 70 46 72 6f 6d 2d 3e  o->nVar==pFrom->
96e0: 6e 56 61 72 20 29 3b 0a 20 20 73 71 6c 69 74 65  nVar );.  sqlite
96f0: 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28 70 54  3_mutex_enter(pT
9700: 6f 2d 3e 64 62 2d 3e 6d 75 74 65 78 29 3b 0a 20  o->db->mutex);. 
9710: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 70 46 72 6f   for(i=0; i<pFro
9720: 6d 2d 3e 6e 56 61 72 3b 20 69 2b 2b 29 7b 0a 20  m->nVar; i++){. 
9730: 20 20 20 73 71 6c 69 74 65 33 56 64 62 65 4d 65     sqlite3VdbeMe
9740: 6d 4d 6f 76 65 28 26 70 54 6f 2d 3e 61 56 61 72  mMove(&pTo->aVar
9750: 5b 69 5d 2c 20 26 70 46 72 6f 6d 2d 3e 61 56 61  [i], &pFrom->aVa
9760: 72 5b 69 5d 29 3b 0a 20 20 7d 0a 20 20 73 71 6c  r[i]);.  }.  sql
9770: 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65  ite3_mutex_leave
9780: 28 70 54 6f 2d 3e 64 62 2d 3e 6d 75 74 65 78 29  (pTo->db->mutex)
9790: 3b 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54  ;.  return SQLIT
97a0: 45 5f 4f 4b 3b 0a 7d 0a 0a 23 69 66 6e 64 65 66  E_OK;.}..#ifndef
97b0: 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 44 45 50   SQLITE_OMIT_DEP
97c0: 52 45 43 41 54 45 44 0a 2f 2a 0a 2a 2a 20 44 65  RECATED./*.** De
97d0: 70 72 65 63 61 74 65 64 20 65 78 74 65 72 6e 61  precated externa
97e0: 6c 20 69 6e 74 65 72 66 61 63 65 2e 20 20 49 6e  l interface.  In
97f0: 74 65 72 6e 61 6c 2f 63 6f 72 65 20 53 51 4c 69  ternal/core SQLi
9800: 74 65 20 63 6f 64 65 0a 2a 2a 20 73 68 6f 75 6c  te code.** shoul
9810: 64 20 63 61 6c 6c 20 73 71 6c 69 74 65 33 54 72  d call sqlite3Tr
9820: 61 6e 73 66 65 72 42 69 6e 64 69 6e 67 73 2e 0a  ansferBindings..
9830: 2a 2a 0a 2a 2a 20 49 73 20 69 73 20 6d 69 73 75  **.** Is is misu
9840: 73 65 20 74 6f 20 63 61 6c 6c 20 74 68 69 73 20  se to call this 
9850: 72 6f 75 74 69 6e 65 20 77 69 74 68 20 73 74 61  routine with sta
9860: 74 65 6d 65 6e 74 73 20 66 72 6f 6d 20 64 69 66  tements from dif
9870: 66 65 72 65 6e 74 0a 2a 2a 20 64 61 74 61 62 61  ferent.** databa
9880: 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 73 2e 20  se connections. 
9890: 20 42 75 74 20 61 73 20 74 68 69 73 20 69 73 20   But as this is 
98a0: 61 20 64 65 70 72 65 63 61 74 65 64 20 69 6e 74  a deprecated int
98b0: 65 72 66 61 63 65 2c 20 77 65 0a 2a 2a 20 77 69  erface, we.** wi
98c0: 6c 6c 20 6e 6f 74 20 62 6f 74 68 65 72 20 74 6f  ll not bother to
98d0: 20 63 68 65 63 6b 20 66 6f 72 20 74 68 61 74 20   check for that 
98e0: 63 6f 6e 64 69 74 69 6f 6e 2e 0a 2a 2a 0a 2a 2a  condition..**.**
98f0: 20 49 66 20 74 68 65 20 74 77 6f 20 73 74 61 74   If the two stat
9900: 65 6d 65 6e 74 73 20 63 6f 6e 74 61 69 6e 20 61  ements contain a
9910: 20 64 69 66 66 65 72 65 6e 74 20 6e 75 6d 62 65   different numbe
9920: 72 20 6f 66 20 62 69 6e 64 69 6e 67 73 2c 20 74  r of bindings, t
9930: 68 65 6e 0a 2a 2a 20 61 6e 20 53 51 4c 49 54 45  hen.** an SQLITE
9940: 5f 45 52 52 4f 52 20 69 73 20 72 65 74 75 72 6e  _ERROR is return
9950: 65 64 2e 20 20 4e 6f 74 68 69 6e 67 20 65 6c 73  ed.  Nothing els
9960: 65 20 63 61 6e 20 67 6f 20 77 72 6f 6e 67 2c 20  e can go wrong, 
9970: 73 6f 20 6f 74 68 65 72 77 69 73 65 0a 2a 2a 20  so otherwise.** 
9980: 53 51 4c 49 54 45 5f 4f 4b 20 69 73 20 72 65 74  SQLITE_OK is ret
9990: 75 72 6e 65 64 2e 0a 2a 2f 0a 69 6e 74 20 73 71  urned..*/.int sq
99a0: 6c 69 74 65 33 5f 74 72 61 6e 73 66 65 72 5f 62  lite3_transfer_b
99b0: 69 6e 64 69 6e 67 73 28 73 71 6c 69 74 65 33 5f  indings(sqlite3_
99c0: 73 74 6d 74 20 2a 70 46 72 6f 6d 53 74 6d 74 2c  stmt *pFromStmt,
99d0: 20 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70   sqlite3_stmt *p
99e0: 54 6f 53 74 6d 74 29 7b 0a 20 20 56 64 62 65 20  ToStmt){.  Vdbe 
99f0: 2a 70 46 72 6f 6d 20 3d 20 28 56 64 62 65 2a 29  *pFrom = (Vdbe*)
9a00: 70 46 72 6f 6d 53 74 6d 74 3b 0a 20 20 56 64 62  pFromStmt;.  Vdb
9a10: 65 20 2a 70 54 6f 20 3d 20 28 56 64 62 65 2a 29  e *pTo = (Vdbe*)
9a20: 70 54 6f 53 74 6d 74 3b 0a 20 20 69 66 28 20 70  pToStmt;.  if( p
9a30: 46 72 6f 6d 2d 3e 6e 56 61 72 21 3d 70 54 6f 2d  From->nVar!=pTo-
9a40: 3e 6e 56 61 72 20 29 7b 0a 20 20 20 20 72 65 74  >nVar ){.    ret
9a50: 75 72 6e 20 53 51 4c 49 54 45 5f 45 52 52 4f 52  urn SQLITE_ERROR
9a60: 3b 0a 20 20 7d 0a 20 20 69 66 28 20 70 54 6f 2d  ;.  }.  if( pTo-
9a70: 3e 69 73 50 72 65 70 61 72 65 56 32 20 26 26 20  >isPrepareV2 && 
9a80: 70 54 6f 2d 3e 65 78 70 6d 61 73 6b 20 29 7b 0a  pTo->expmask ){.
9a90: 20 20 20 20 70 54 6f 2d 3e 65 78 70 69 72 65 64      pTo->expired
9aa0: 20 3d 20 31 3b 0a 20 20 7d 0a 20 20 69 66 28 20   = 1;.  }.  if( 
9ab0: 70 46 72 6f 6d 2d 3e 69 73 50 72 65 70 61 72 65  pFrom->isPrepare
9ac0: 56 32 20 26 26 20 70 46 72 6f 6d 2d 3e 65 78 70  V2 && pFrom->exp
9ad0: 6d 61 73 6b 20 29 7b 0a 20 20 20 20 70 46 72 6f  mask ){.    pFro
9ae0: 6d 2d 3e 65 78 70 69 72 65 64 20 3d 20 31 3b 0a  m->expired = 1;.
9af0: 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 73 71 6c    }.  return sql
9b00: 69 74 65 33 54 72 61 6e 73 66 65 72 42 69 6e 64  ite3TransferBind
9b10: 69 6e 67 73 28 70 46 72 6f 6d 53 74 6d 74 2c 20  ings(pFromStmt, 
9b20: 70 54 6f 53 74 6d 74 29 3b 0a 7d 0a 23 65 6e 64  pToStmt);.}.#end
9b30: 69 66 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e  if../*.** Return
9b40: 20 74 68 65 20 73 71 6c 69 74 65 33 2a 20 64 61   the sqlite3* da
9b50: 74 61 62 61 73 65 20 68 61 6e 64 6c 65 20 74 6f  tabase handle to
9b60: 20 77 68 69 63 68 20 74 68 65 20 70 72 65 70 61   which the prepa
9b70: 72 65 64 20 73 74 61 74 65 6d 65 6e 74 20 67 69  red statement gi
9b80: 76 65 6e 0a 2a 2a 20 69 6e 20 74 68 65 20 61 72  ven.** in the ar
9b90: 67 75 6d 65 6e 74 20 62 65 6c 6f 6e 67 73 2e 20  gument belongs. 
9ba0: 20 54 68 69 73 20 69 73 20 74 68 65 20 73 61 6d   This is the sam
9bb0: 65 20 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c  e database handl
9bc0: 65 20 74 68 61 74 20 77 61 73 0a 2a 2a 20 74 68  e that was.** th
9bd0: 65 20 66 69 72 73 74 20 61 72 67 75 6d 65 6e 74  e first argument
9be0: 20 74 6f 20 74 68 65 20 73 71 6c 69 74 65 33 5f   to the sqlite3_
9bf0: 70 72 65 70 61 72 65 28 29 20 74 68 61 74 20 77  prepare() that w
9c00: 61 73 20 75 73 65 64 20 74 6f 20 63 72 65 61 74  as used to creat
9c10: 65 0a 2a 2a 20 74 68 65 20 73 74 61 74 65 6d 65  e.** the stateme
9c20: 6e 74 20 69 6e 20 74 68 65 20 66 69 72 73 74 20  nt in the first 
9c30: 70 6c 61 63 65 2e 0a 2a 2f 0a 73 71 6c 69 74 65  place..*/.sqlite
9c40: 33 20 2a 73 71 6c 69 74 65 33 5f 64 62 5f 68 61  3 *sqlite3_db_ha
9c50: 6e 64 6c 65 28 73 71 6c 69 74 65 33 5f 73 74 6d  ndle(sqlite3_stm
9c60: 74 20 2a 70 53 74 6d 74 29 7b 0a 20 20 72 65 74  t *pStmt){.  ret
9c70: 75 72 6e 20 70 53 74 6d 74 20 3f 20 28 28 56 64  urn pStmt ? ((Vd
9c80: 62 65 2a 29 70 53 74 6d 74 29 2d 3e 64 62 20 3a  be*)pStmt)->db :
9c90: 20 30 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74   0;.}../*.** Ret
9ca0: 75 72 6e 20 74 72 75 65 20 69 66 20 74 68 65 20  urn true if the 
9cb0: 70 72 65 70 61 72 65 64 20 73 74 61 74 65 6d 65  prepared stateme
9cc0: 6e 74 20 69 73 20 67 75 61 72 61 6e 74 65 65 64  nt is guaranteed
9cd0: 20 74 6f 20 6e 6f 74 20 6d 6f 64 69 66 79 20 74   to not modify t
9ce0: 68 65 0a 2a 2a 20 64 61 74 61 62 61 73 65 2e 0a  he.** database..
9cf0: 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f 73  */.int sqlite3_s
9d00: 74 6d 74 5f 72 65 61 64 6f 6e 6c 79 28 73 71 6c  tmt_readonly(sql
9d10: 69 74 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d 74  ite3_stmt *pStmt
9d20: 29 7b 0a 20 20 72 65 74 75 72 6e 20 70 53 74 6d  ){.  return pStm
9d30: 74 20 3f 20 28 28 56 64 62 65 2a 29 70 53 74 6d  t ? ((Vdbe*)pStm
9d40: 74 29 2d 3e 72 65 61 64 4f 6e 6c 79 20 3a 20 31  t)->readOnly : 1
9d50: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72  ;.}../*.** Retur
9d60: 6e 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20 74  n a pointer to t
9d70: 68 65 20 6e 65 78 74 20 70 72 65 70 61 72 65 64  he next prepared
9d80: 20 73 74 61 74 65 6d 65 6e 74 20 61 66 74 65 72   statement after
9d90: 20 70 53 74 6d 74 20 61 73 73 6f 63 69 61 74 65   pStmt associate
9da0: 64 0a 2a 2a 20 77 69 74 68 20 64 61 74 61 62 61  d.** with databa
9db0: 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 70 44  se connection pD
9dc0: 62 2e 20 20 49 66 20 70 53 74 6d 74 20 69 73 20  b.  If pStmt is 
9dd0: 4e 55 4c 4c 2c 20 72 65 74 75 72 6e 20 74 68 65  NULL, return the
9de0: 20 66 69 72 73 74 0a 2a 2a 20 70 72 65 70 61 72   first.** prepar
9df0: 65 64 20 73 74 61 74 65 6d 65 6e 74 20 66 6f 72  ed statement for
9e00: 20 74 68 65 20 64 61 74 61 62 61 73 65 20 63 6f   the database co
9e10: 6e 6e 65 63 74 69 6f 6e 2e 20 20 52 65 74 75 72  nnection.  Retur
9e20: 6e 20 4e 55 4c 4c 20 69 66 20 74 68 65 72 65 0a  n NULL if there.
9e30: 2a 2a 20 61 72 65 20 6e 6f 20 6d 6f 72 65 2e 0a  ** are no more..
9e40: 2a 2f 0a 73 71 6c 69 74 65 33 5f 73 74 6d 74 20  */.sqlite3_stmt 
9e50: 2a 73 71 6c 69 74 65 33 5f 6e 65 78 74 5f 73 74  *sqlite3_next_st
9e60: 6d 74 28 73 71 6c 69 74 65 33 20 2a 70 44 62 2c  mt(sqlite3 *pDb,
9e70: 20 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70   sqlite3_stmt *p
9e80: 53 74 6d 74 29 7b 0a 20 20 73 71 6c 69 74 65 33  Stmt){.  sqlite3
9e90: 5f 73 74 6d 74 20 2a 70 4e 65 78 74 3b 0a 20 20  _stmt *pNext;.  
9ea0: 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65 6e  sqlite3_mutex_en
9eb0: 74 65 72 28 70 44 62 2d 3e 6d 75 74 65 78 29 3b  ter(pDb->mutex);
9ec0: 0a 20 20 69 66 28 20 70 53 74 6d 74 3d 3d 30 20  .  if( pStmt==0 
9ed0: 29 7b 0a 20 20 20 20 70 4e 65 78 74 20 3d 20 28  ){.    pNext = (
9ee0: 73 71 6c 69 74 65 33 5f 73 74 6d 74 2a 29 70 44  sqlite3_stmt*)pD
9ef0: 62 2d 3e 70 56 64 62 65 3b 0a 20 20 7d 65 6c 73  b->pVdbe;.  }els
9f00: 65 7b 0a 20 20 20 20 70 4e 65 78 74 20 3d 20 28  e{.    pNext = (
9f10: 73 71 6c 69 74 65 33 5f 73 74 6d 74 2a 29 28 28  sqlite3_stmt*)((
9f20: 56 64 62 65 2a 29 70 53 74 6d 74 29 2d 3e 70 4e  Vdbe*)pStmt)->pN
9f30: 65 78 74 3b 0a 20 20 7d 0a 20 20 73 71 6c 69 74  ext;.  }.  sqlit
9f40: 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 70  e3_mutex_leave(p
9f50: 44 62 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 72 65  Db->mutex);.  re
9f60: 74 75 72 6e 20 70 4e 65 78 74 3b 0a 7d 0a 0a 2f  turn pNext;.}../
9f70: 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20  *.** Return the 
9f80: 76 61 6c 75 65 20 6f 66 20 61 20 73 74 61 74 75  value of a statu
9f90: 73 20 63 6f 75 6e 74 65 72 20 66 6f 72 20 61 20  s counter for a 
9fa0: 70 72 65 70 61 72 65 64 20 73 74 61 74 65 6d 65  prepared stateme
9fb0: 6e 74 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65  nt.*/.int sqlite
9fc0: 33 5f 73 74 6d 74 5f 73 74 61 74 75 73 28 73 71  3_stmt_status(sq
9fd0: 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d  lite3_stmt *pStm
9fe0: 74 2c 20 69 6e 74 20 6f 70 2c 20 69 6e 74 20 72  t, int op, int r
9ff0: 65 73 65 74 46 6c 61 67 29 7b 0a 20 20 56 64 62  esetFlag){.  Vdb
a000: 65 20 2a 70 56 64 62 65 20 3d 20 28 56 64 62 65  e *pVdbe = (Vdbe
a010: 2a 29 70 53 74 6d 74 3b 0a 20 20 69 6e 74 20 76  *)pStmt;.  int v
a020: 20 3d 20 70 56 64 62 65 2d 3e 61 43 6f 75 6e 74   = pVdbe->aCount
a030: 65 72 5b 6f 70 2d 31 5d 3b 0a 20 20 69 66 28 20  er[op-1];.  if( 
a040: 72 65 73 65 74 46 6c 61 67 20 29 20 70 56 64 62  resetFlag ) pVdb
a050: 65 2d 3e 61 43 6f 75 6e 74 65 72 5b 6f 70 2d 31  e->aCounter[op-1
a060: 5d 20 3d 20 30 3b 0a 20 20 72 65 74 75 72 6e 20  ] = 0;.  return 
a070: 76 3b 0a 7d 0a                                   v;.}.