System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 6f3f15804850c618e1573708c8a9b3aef8ee0d2b:


0000: 23 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 41  #define SQLITE_A
0010: 50 49 20 5f 5f 64 65 63 6c 73 70 65 63 28 64 6c  PI __declspec(dl
0020: 6c 65 78 70 6f 72 74 29 0d 0a 0d 0a 23 70 72 61  lexport)....#pra
0030: 67 6d 61 20 77 61 72 6e 69 6e 67 28 64 69 73 61  gma warning(disa
0040: 62 6c 65 3a 20 34 37 30 33 29 0d 0a 23 69 6e 63  ble: 4703)..#inc
0050: 6c 75 64 65 20 22 2e 2e 2f 63 6f 72 65 2f 73 71  lude "../core/sq
0060: 6c 69 74 65 33 2e 63 22 0d 0a 23 70 72 61 67 6d  lite3.c"..#pragm
0070: 61 20 77 61 72 6e 69 6e 67 28 64 65 66 61 75 6c  a warning(defaul
0080: 74 3a 20 34 37 30 33 29 0d 0a 0d 0a 23 69 66 20  t: 4703)....#if 
0090: 64 65 66 69 6e 65 64 28 49 4e 54 45 52 4f 50 5f  defined(INTEROP_
00a0: 45 58 54 45 4e 53 49 4f 4e 5f 46 55 4e 43 54 49  EXTENSION_FUNCTI
00b0: 4f 4e 53 29 0d 0a 23 69 6e 63 6c 75 64 65 20 22  ONS)..#include "
00c0: 2e 2e 2f 63 6f 6e 74 72 69 62 2f 65 78 74 65 6e  ../contrib/exten
00d0: 73 69 6f 6e 2d 66 75 6e 63 74 69 6f 6e 73 2e 63  sion-functions.c
00e0: 22 0d 0a 65 78 74 65 72 6e 20 69 6e 74 20 52 65  "..extern int Re
00f0: 67 69 73 74 65 72 45 78 74 65 6e 73 69 6f 6e 46  gisterExtensionF
0100: 75 6e 63 74 69 6f 6e 73 28 73 71 6c 69 74 65 33  unctions(sqlite3
0110: 20 2a 64 62 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a   *db);..#endif..
0120: 0d 0a 23 69 66 20 64 65 66 69 6e 65 64 28 49 4e  ..#if defined(IN
0130: 54 45 52 4f 50 5f 43 4f 44 45 43 29 0d 0a 23 69  TEROP_CODEC)..#i
0140: 6e 63 6c 75 64 65 20 22 63 72 79 70 74 2e 63 22  nclude "crypt.c"
0150: 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 23 69 66 64  ..#endif....#ifd
0160: 65 66 20 53 51 4c 49 54 45 5f 4f 53 5f 57 49 4e  ef SQLITE_OS_WIN
0170: 0d 0a 0d 0a 2f 2f 20 41 64 64 69 74 69 6f 6e 61  ....// Additiona
0180: 6c 20 6f 70 65 6e 20 66 6c 61 67 73 2c 20 77 65  l open flags, we
0190: 20 75 73 65 20 74 68 69 73 20 6f 6e 65 20 70 72   use this one pr
01a0: 69 76 61 74 65 6c 79 0d 0a 2f 2f 23 64 65 66 69  ivately..//#defi
01b0: 6e 65 20 53 51 4c 49 54 45 5f 4f 50 45 4e 5f 53  ne SQLITE_OPEN_S
01c0: 48 41 52 45 44 43 41 43 48 45 20 20 20 20 20 20  HAREDCACHE      
01d0: 30 78 30 31 30 30 30 30 30 30 0d 0a 0d 0a 74 79  0x01000000....ty
01e0: 70 65 64 65 66 20 76 6f 69 64 20 28 2a 53 51 4c  pedef void (*SQL
01f0: 49 54 45 55 53 45 52 46 55 4e 43 29 28 73 71 6c  ITEUSERFUNC)(sql
0200: 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 2c 20  ite3_context *, 
0210: 69 6e 74 2c 20 73 71 6c 69 74 65 33 5f 76 61 6c  int, sqlite3_val
0220: 75 65 20 2a 2a 29 3b 0d 0a 74 79 70 65 64 65 66  ue **);..typedef
0230: 20 76 6f 69 64 20 28 2a 53 51 4c 49 54 45 46 55   void (*SQLITEFU
0240: 4e 43 46 49 4e 41 4c 29 28 73 71 6c 69 74 65 33  NCFINAL)(sqlite3
0250: 5f 63 6f 6e 74 65 78 74 20 2a 29 3b 0d 0a 0d 0a  _context *);....
0260: 23 69 66 20 53 51 4c 49 54 45 5f 56 45 52 53 49  #if SQLITE_VERSI
0270: 4f 4e 5f 4e 55 4d 42 45 52 20 3c 20 33 30 30 37  ON_NUMBER < 3007
0280: 30 31 34 0d 0a 53 51 4c 49 54 45 5f 50 52 49 56  014..SQLITE_PRIV
0290: 41 54 45 20 76 6f 69 64 20 2a 20 73 71 6c 69 74  ATE void * sqlit
02a0: 65 33 44 62 4d 61 6c 6c 6f 63 5a 65 72 6f 5f 69  e3DbMallocZero_i
02b0: 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33 20 2a  nterop(sqlite3 *
02c0: 64 62 2c 20 69 6e 74 20 6e 29 0d 0a 7b 0d 0a 20  db, int n)..{.. 
02d0: 20 76 6f 69 64 20 2a 70 3b 0d 0a 20 20 69 66 20   void *p;..  if 
02e0: 28 64 62 29 20 7b 0d 0a 20 20 20 20 73 71 6c 69  (db) {..    sqli
02f0: 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28  te3_mutex_enter(
0300: 64 62 2d 3e 6d 75 74 65 78 29 3b 0d 0a 20 20 7d  db->mutex);..  }
0310: 0d 0a 20 20 70 20 3d 20 73 71 6c 69 74 65 33 44  ..  p = sqlite3D
0320: 62 4d 61 6c 6c 6f 63 5a 65 72 6f 28 64 62 2c 6e  bMallocZero(db,n
0330: 29 3b 0d 0a 20 20 69 66 20 28 64 62 29 20 7b 0d  );..  if (db) {.
0340: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 6d 75 74  .    sqlite3_mut
0350: 65 78 5f 6c 65 61 76 65 28 64 62 2d 3e 6d 75 74  ex_leave(db->mut
0360: 65 78 29 3b 0d 0a 20 20 7d 0d 0a 20 20 72 65 74  ex);..  }..  ret
0370: 75 72 6e 20 70 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c  urn p;..}....SQL
0380: 49 54 45 5f 50 52 49 56 41 54 45 20 76 6f 69 64  ITE_PRIVATE void
0390: 20 73 71 6c 69 74 65 33 44 62 46 72 65 65 5f 69   sqlite3DbFree_i
03a0: 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33 20 2a  nterop(sqlite3 *
03b0: 64 62 2c 20 76 6f 69 64 20 2a 70 29 0d 0a 7b 0d  db, void *p)..{.
03c0: 0a 20 20 69 66 20 28 64 62 29 20 7b 0d 0a 20 20  .  if (db) {..  
03d0: 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f    sqlite3_mutex_
03e0: 65 6e 74 65 72 28 64 62 2d 3e 6d 75 74 65 78 29  enter(db->mutex)
03f0: 3b 0d 0a 20 20 7d 0d 0a 20 20 69 66 20 28 70 29  ;..  }..  if (p)
0400: 20 7b 0d 0a 20 20 20 20 73 71 6c 69 74 65 33 4d   {..    sqlite3M
0410: 65 6d 64 65 62 75 67 53 65 74 54 79 70 65 28 70  emdebugSetType(p
0420: 2c 20 4d 45 4d 54 59 50 45 5f 44 42 7c 4d 45 4d  , MEMTYPE_DB|MEM
0430: 54 59 50 45 5f 48 45 41 50 29 3b 0d 0a 20 20 7d  TYPE_HEAP);..  }
0440: 0d 0a 20 20 73 71 6c 69 74 65 33 44 62 46 72 65  ..  sqlite3DbFre
0450: 65 28 64 62 2c 70 29 3b 0d 0a 20 20 69 66 20 28  e(db,p);..  if (
0460: 64 62 29 20 7b 0d 0a 20 20 20 20 73 71 6c 69 74  db) {..    sqlit
0470: 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 64  e3_mutex_leave(d
0480: 62 2d 3e 6d 75 74 65 78 29 3b 0d 0a 20 20 7d 0d  b->mutex);..  }.
0490: 0a 7d 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 2f 2a  .}..#endif..../*
04a0: 0d 0a 20 20 20 20 54 68 65 20 67 6f 61 6c 20 6f  ..    The goal o
04b0: 66 20 74 68 69 73 20 76 65 72 73 69 6f 6e 20 6f  f this version o
04c0: 66 20 63 6c 6f 73 65 20 69 73 20 64 69 66 66 65  f close is diffe
04d0: 72 65 6e 74 20 74 68 61 6e 20 74 68 61 74 20 6f  rent than that o
04e0: 66 20 73 71 6c 69 74 65 33 5f 63 6c 6f 73 65 28  f sqlite3_close(
04f0: 29 2c 20 61 6e 64 20 69 73 20 64 65 73 69 67 6e  ), and is design
0500: 65 64 20 74 6f 20 6c 65 6e 64 20 69 74 73 65 6c  ed to lend itsel
0510: 66 20 62 65 74 74 65 72 20 74 6f 20 2e 4e 45 54  f better to .NET
0520: 27 73 20 6e 6f 6e 2d 64 65 74 65 72 6d 69 6e 69  's non-determini
0530: 73 74 69 63 20 66 69 6e 61 6c 69 7a 65 72 73 20  stic finalizers 
0540: 61 6e 64 0d 0a 20 20 20 20 74 68 65 20 47 43 20  and..    the GC 
0550: 74 68 72 65 61 64 2e 20 20 53 51 4c 69 74 65 20  thread.  SQLite 
0560: 77 69 6c 6c 20 6e 6f 74 20 63 6c 6f 73 65 20 61  will not close a
0570: 20 64 61 74 61 62 61 73 65 20 69 66 20 73 74 61   database if sta
0580: 74 65 6d 65 6e 74 73 20 61 72 65 20 6f 70 65 6e  tements are open
0590: 20 6f 6e 20 69 74 20 2d 2d 20 62 75 74 20 66 6f   on it -- but fo
05a0: 72 20 6f 75 72 20 70 75 72 70 6f 73 65 73 2c 20  r our purposes, 
05b0: 77 65 27 64 20 72 61 74 68 65 72 20 66 69 6e 61  we'd rather fina
05c0: 6c 69 7a 65 20 61 6c 6c 20 61 63 74 69 76 65 20  lize all active 
05d0: 73 74 61 74 65 6d 65 6e 74 73 0d 0a 20 20 20 20  statements..    
05e0: 61 6e 64 20 66 6f 72 63 69 62 6c 79 20 63 6c 6f  and forcibly clo
05f0: 73 65 20 74 68 65 20 64 61 74 61 62 61 73 65 2e  se the database.
0600: 20 20 54 68 65 20 72 65 61 73 6f 6e 20 69 73 20    The reason is 
0610: 73 69 6d 70 6c 65 20 2d 2d 20 61 20 6c 6f 74 20  simple -- a lot 
0620: 6f 66 20 70 65 6f 70 6c 65 20 64 6f 6e 27 74 20  of people don't 
0630: 44 69 73 70 6f 73 65 28 29 20 6f 66 20 74 68 65  Dispose() of the
0640: 69 72 20 6f 62 6a 65 63 74 73 20 63 6f 72 72 65  ir objects corre
0650: 63 74 6c 79 20 61 6e 64 20 6c 65 74 20 74 68 65  ctly and let the
0660: 20 67 61 72 62 61 67 65 20 63 6f 6c 6c 65 63 74   garbage collect
0670: 6f 72 0d 0a 20 20 20 20 64 6f 20 69 74 2e 20 20  or..    do it.  
0680: 54 68 69 73 20 6c 65 61 64 73 20 74 6f 20 75 6e  This leads to un
0690: 65 78 70 65 63 74 65 64 20 62 65 68 61 76 69 6f  expected behavio
06a0: 72 20 77 68 65 6e 20 61 20 75 73 65 72 20 74 68  r when a user th
06b0: 69 6e 6b 73 20 74 68 65 79 27 76 65 20 63 6c 6f  inks they've clo
06c0: 73 65 64 20 61 20 64 61 74 61 62 61 73 65 2c 20  sed a database, 
06d0: 62 75 74 20 69 74 27 73 20 73 74 69 6c 6c 20 6f  but it's still o
06e0: 70 65 6e 20 62 65 63 61 75 73 65 20 6e 6f 74 20  pen because not 
06f0: 61 6c 6c 20 74 68 65 20 73 74 61 74 65 6d 65 6e  all the statemen
0700: 74 73 20 68 61 76 65 0d 0a 20 20 20 20 68 69 74  ts have..    hit
0710: 20 74 68 65 20 47 43 20 79 65 74 2e 0d 0a 0d 0a   the GC yet.....
0720: 20 20 20 20 53 6f 2c 20 68 65 72 65 20 77 65 20      So, here we 
0730: 68 61 76 65 20 61 20 70 72 6f 62 6c 65 6d 20 2e  have a problem .
0740: 2e 2e 20 2e 4e 45 54 20 68 61 73 20 61 20 70 6f  .. .NET has a po
0750: 69 6e 74 65 72 20 74 6f 20 61 6e 79 20 6e 75 6d  inter to any num
0760: 62 65 72 20 6f 66 20 73 71 6c 69 74 65 33 5f 73  ber of sqlite3_s
0770: 74 6d 74 20 6f 62 6a 65 63 74 73 2e 20 20 57 65  tmt objects.  We
0780: 20 63 61 6e 27 74 20 63 61 6c 6c 20 73 71 6c 69   can't call sqli
0790: 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 29 20 6f  te3_finalize() o
07a0: 6e 20 74 68 65 73 65 20 62 65 63 61 75 73 65 0d  n these because.
07b0: 0a 20 20 20 20 74 68 65 69 72 20 6d 65 6d 6f 72  .    their memor
07c0: 79 20 69 73 20 66 72 65 65 64 20 61 6e 64 20 63  y is freed and c
07d0: 61 6e 20 62 65 20 75 73 65 64 20 66 6f 72 20 73  an be used for s
07e0: 6f 6d 65 74 68 69 6e 67 20 65 6c 73 65 2e 20 20  omething else.  
07f0: 54 68 65 20 47 43 20 74 68 72 65 61 64 20 63 6f  The GC thread co
0800: 75 6c 64 20 70 6f 74 65 6e 74 69 61 6c 6c 79 20  uld potentially 
0810: 74 72 79 20 61 6e 64 20 63 61 6c 6c 20 66 69 6e  try and call fin
0820: 61 6c 69 7a 65 20 61 67 61 69 6e 20 6f 6e 20 74  alize again on t
0830: 68 65 20 73 74 61 74 65 6d 65 6e 74 20 61 66 74  he statement aft
0840: 65 72 0d 0a 20 20 20 20 74 68 61 74 20 6d 65 6d  er..    that mem
0850: 6f 72 79 20 77 61 73 20 64 65 61 6c 6c 6f 63 61  ory was dealloca
0860: 74 65 64 2e 20 20 42 41 44 2e 20 20 53 6f 2c 20  ted.  BAD.  So, 
0870: 77 68 61 74 20 77 65 20 6e 65 65 64 20 74 6f 20  what we need to 
0880: 64 6f 20 69 73 20 6d 61 6b 65 20 61 20 63 6f 70  do is make a cop
0890: 79 20 6f 66 20 65 61 63 68 20 73 74 61 74 65 6d  y of each statem
08a0: 65 6e 74 2c 20 61 6e 64 20 63 61 6c 6c 20 66 69  ent, and call fi
08b0: 6e 61 6c 69 7a 65 28 29 20 6f 6e 20 74 68 65 20  nalize() on the 
08c0: 63 6f 70 79 20 2d 2d 20 73 6f 20 74 68 61 74 20  copy -- so that 
08d0: 74 68 65 20 6f 72 69 67 69 6e 61 6c 0d 0a 20 20  the original..  
08e0: 20 20 73 74 61 74 65 6d 65 6e 74 27 73 20 6d 65    statement's me
08f0: 6d 6f 72 79 20 69 73 20 70 72 65 73 65 72 76 65  mory is preserve
0900: 64 2c 20 61 6e 64 20 6d 61 72 6b 65 64 20 61 73  d, and marked as
0910: 20 42 41 44 2c 20 62 75 74 20 77 65 20 63 61 6e   BAD, but we can
0920: 20 73 74 69 6c 6c 20 6d 61 6e 61 67 65 20 74 6f   still manage to
0930: 20 66 69 6e 61 6c 69 7a 65 20 65 76 65 72 79 74   finalize everyt
0940: 68 69 6e 67 20 61 6e 64 20 66 6f 72 63 69 62 6c  hing and forcibl
0950: 79 20 63 6c 6f 73 65 20 74 68 65 20 64 61 74 61  y close the data
0960: 62 61 73 65 2e 20 20 4c 61 74 65 72 20 77 68 65  base.  Later whe
0970: 6e 20 74 68 65 20 0d 0a 20 20 20 20 47 43 20 67  n the ..    GC g
0980: 65 74 73 20 61 72 6f 75 6e 64 20 74 6f 20 63 61  ets around to ca
0990: 6c 6c 69 6e 67 20 66 69 6e 61 6c 69 7a 65 5f 69  lling finalize_i
09a0: 6e 74 65 72 6f 70 28 29 20 6f 6e 20 74 68 65 20  nterop() on the 
09b0: 22 62 61 64 22 20 73 74 61 74 65 6d 65 6e 74 2c  "bad" statement,
09c0: 20 77 65 20 64 65 74 65 63 74 20 74 68 61 74 20   we detect that 
09d0: 61 6e 64 20 66 69 6e 69 73 68 20 64 65 61 6c 6c  and finish deall
09e0: 6f 63 61 74 69 6e 67 20 74 68 65 20 70 6f 69 6e  ocating the poin
09f0: 74 65 72 2e 0d 0a 2a 2f 0d 0a 53 51 4c 49 54 45  ter...*/..SQLITE
0a00: 5f 41 50 49 20 69 6e 74 20 57 49 4e 41 50 49 20  _API int WINAPI 
0a10: 73 71 6c 69 74 65 33 5f 63 6c 6f 73 65 5f 69 6e  sqlite3_close_in
0a20: 74 65 72 6f 70 28 73 71 6c 69 74 65 33 20 2a 64  terop(sqlite3 *d
0a30: 62 29 0d 0a 7b 0d 0a 23 69 66 20 53 51 4c 49 54  b)..{..#if SQLIT
0a40: 45 5f 56 45 52 53 49 4f 4e 5f 4e 55 4d 42 45 52  E_VERSION_NUMBER
0a50: 20 3e 3d 20 33 30 30 37 30 31 34 0d 0a 20 20 72   >= 3007014..  r
0a60: 65 74 75 72 6e 20 73 71 6c 69 74 65 33 5f 63 6c  eturn sqlite3_cl
0a70: 6f 73 65 5f 76 32 28 64 62 29 3b 0d 0a 23 65 6c  ose_v2(db);..#el
0a80: 73 65 0d 0a 20 20 69 6e 74 20 72 65 74 20 3d 20  se..  int ret = 
0a90: 73 71 6c 69 74 65 33 5f 63 6c 6f 73 65 28 64 62  sqlite3_close(db
0aa0: 29 3b 0d 0a 0d 0a 20 20 69 66 20 28 72 65 74 20  );....  if (ret 
0ab0: 3d 3d 20 53 51 4c 49 54 45 5f 42 55 53 59 29 0d  == SQLITE_BUSY).
0ac0: 0a 20 20 7b 0d 0a 20 20 20 20 73 71 6c 69 74 65  .  {..    sqlite
0ad0: 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28 64 62  3_mutex_enter(db
0ae0: 2d 3e 6d 75 74 65 78 29 3b 0d 0a 0d 0a 20 20 20  ->mutex);....   
0af0: 20 69 66 20 28 21 64 62 2d 3e 70 56 64 62 65 29   if (!db->pVdbe)
0b00: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 73  ..    {..      s
0b10: 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61  qlite3_mutex_lea
0b20: 76 65 28 64 62 2d 3e 6d 75 74 65 78 29 3b 0d 0a  ve(db->mutex);..
0b30: 20 20 20 20 20 20 72 65 74 75 72 6e 20 72 65 74        return ret
0b40: 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20 20  ;..    }....    
0b50: 77 68 69 6c 65 20 28 64 62 2d 3e 70 56 64 62 65  while (db->pVdbe
0b60: 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  )..    {..      
0b70: 2f 2f 20 4d 61 6b 65 20 61 20 63 6f 70 79 20 6f  // Make a copy o
0b80: 66 20 74 68 65 20 66 69 72 73 74 20 70 72 65 70  f the first prep
0b90: 61 72 65 64 20 73 74 61 74 65 6d 65 6e 74 0d 0a  ared statement..
0ba0: 20 20 20 20 20 20 56 64 62 65 20 2a 70 20 3d 20        Vdbe *p = 
0bb0: 28 56 64 62 65 20 2a 29 73 71 6c 69 74 65 33 44  (Vdbe *)sqlite3D
0bc0: 62 4d 61 6c 6c 6f 63 5a 65 72 6f 5f 69 6e 74 65  bMallocZero_inte
0bd0: 72 6f 70 28 64 62 2c 20 73 69 7a 65 6f 66 28 56  rop(db, sizeof(V
0be0: 64 62 65 29 29 3b 0d 0a 20 20 20 20 20 20 56 64  dbe));..      Vd
0bf0: 62 65 20 2a 70 6f 20 3d 20 64 62 2d 3e 70 56 64  be *po = db->pVd
0c00: 62 65 3b 0d 0a 0d 0a 20 20 20 20 20 20 69 66 20  be;....      if 
0c10: 28 21 70 29 20 0d 0a 20 20 20 20 20 20 7b 0d 0a  (!p) ..      {..
0c20: 20 20 20 20 20 20 20 20 72 65 74 20 3d 20 53 51          ret = SQ
0c30: 4c 49 54 45 5f 4e 4f 4d 45 4d 3b 0d 0a 20 20 20  LITE_NOMEM;..   
0c40: 20 20 20 20 20 62 72 65 61 6b 3b 0d 0a 20 20 20       break;..   
0c50: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 20 20 43 6f     }....      Co
0c60: 70 79 4d 65 6d 6f 72 79 28 70 2c 20 70 6f 2c 20  pyMemory(p, po, 
0c70: 73 69 7a 65 6f 66 28 56 64 62 65 29 29 3b 0d 0a  sizeof(Vdbe));..
0c80: 0d 0a 20 20 20 20 20 20 2f 2f 20 50 75 74 20 69  ..      // Put i
0c90: 74 20 6f 6e 20 74 68 65 20 63 68 61 69 6e 20 73  t on the chain s
0ca0: 6f 20 77 65 20 63 61 6e 20 66 72 65 65 20 69 74  o we can free it
0cb0: 0d 0a 20 20 20 20 20 20 64 62 2d 3e 70 56 64 62  ..      db->pVdb
0cc0: 65 20 3d 20 70 3b 0d 0a 20 20 20 20 20 20 72 65  e = p;..      re
0cd0: 74 20 3d 20 73 71 6c 69 74 65 33 5f 66 69 6e 61  t = sqlite3_fina
0ce0: 6c 69 7a 65 28 28 73 71 6c 69 74 65 33 5f 73 74  lize((sqlite3_st
0cf0: 6d 74 20 2a 29 70 29 3b 20 2f 2f 20 54 68 69 73  mt *)p); // This
0d00: 20 77 69 6c 6c 20 61 6c 73 6f 20 66 72 65 65 20   will also free 
0d10: 74 68 65 20 63 6f 70 79 27 73 20 6d 65 6d 6f 72  the copy's memor
0d20: 79 0d 0a 20 20 20 20 20 20 69 66 20 28 72 65 74  y..      if (ret
0d30: 29 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20  )..      {..    
0d40: 20 20 20 20 2f 2f 20 66 69 6e 61 6c 69 7a 65 20      // finalize 
0d50: 66 61 69 6c 65 64 20 2d 2d 20 73 6f 20 77 65 20  failed -- so we 
0d60: 6d 75 73 74 20 70 75 74 20 62 61 63 6b 20 61 6e  must put back an
0d70: 79 74 68 69 6e 67 20 77 65 20 6d 75 6e 67 65 64  ything we munged
0d80: 0d 0a 20 20 20 20 20 20 20 20 43 6f 70 79 4d 65  ..        CopyMe
0d90: 6d 6f 72 79 28 70 6f 2c 20 70 2c 20 73 69 7a 65  mory(po, p, size
0da0: 6f 66 28 56 64 62 65 29 29 3b 0d 0a 20 20 20 20  of(Vdbe));..    
0db0: 20 20 20 20 64 62 2d 3e 70 56 64 62 65 20 3d 20      db->pVdbe = 
0dc0: 70 6f 3b 0d 0a 0d 0a 20 20 20 20 20 20 20 20 2f  po;....        /
0dd0: 2f 0d 0a 20 20 20 20 20 20 20 20 2f 2f 20 4e 4f  /..        // NO
0de0: 54 45 3a 20 4f 6b 2c 20 77 65 20 6d 75 73 74 20  TE: Ok, we must 
0df0: 66 72 65 65 20 74 68 69 73 20 62 6c 6f 63 6b 20  free this block 
0e00: 74 68 61 74 20 2a 77 65 2a 20 61 6c 6c 6f 63 61  that *we* alloca
0e10: 74 65 64 20 28 61 62 6f 76 65 29 20 73 69 6e 63  ted (above) sinc
0e20: 65 0d 0a 20 20 20 20 20 20 20 20 2f 2f 20 20 20  e..        //   
0e30: 20 20 20 20 66 69 6e 61 6c 69 7a 65 20 64 69 64      finalize did
0e40: 20 6e 6f 74 20 64 6f 20 73 6f 2e 0d 0a 20 20 20   not do so...   
0e50: 20 20 20 20 20 2f 2f 0d 0a 20 20 20 20 20 20 20       //..       
0e60: 20 73 71 6c 69 74 65 33 44 62 46 72 65 65 5f 69   sqlite3DbFree_i
0e70: 6e 74 65 72 6f 70 28 64 62 2c 20 70 29 3b 0d 0a  nterop(db, p);..
0e80: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0d 0a          break;..
0e90: 20 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 65        }..      e
0ea0: 6c 73 65 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20  lse..      {..  
0eb0: 20 20 20 20 20 20 5a 65 72 6f 4d 65 6d 6f 72 79        ZeroMemory
0ec0: 28 70 6f 2c 20 73 69 7a 65 6f 66 28 56 64 62 65  (po, sizeof(Vdbe
0ed0: 29 29 3b 0d 0a 20 20 20 20 20 20 20 20 70 6f 2d  ));..        po-
0ee0: 3e 6d 61 67 69 63 20 3d 20 56 44 42 45 5f 4d 41  >magic = VDBE_MA
0ef0: 47 49 43 5f 44 45 41 44 3b 0d 0a 20 20 20 20 20  GIC_DEAD;..     
0f00: 20 7d 0d 0a 20 20 20 20 7d 0d 0a 20 20 20 20 73   }..    }..    s
0f10: 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61  qlite3_mutex_lea
0f20: 76 65 28 64 62 2d 3e 6d 75 74 65 78 29 3b 0d 0a  ve(db->mutex);..
0f30: 20 20 20 20 72 65 74 20 3d 20 73 71 6c 69 74 65      ret = sqlite
0f40: 33 5f 63 6c 6f 73 65 28 64 62 29 3b 0d 0a 20 20  3_close(db);..  
0f50: 7d 0d 0a 20 20 72 65 74 75 72 6e 20 72 65 74 3b  }..  return ret;
0f60: 0d 0a 23 65 6e 64 69 66 0d 0a 7d 0d 0a 0d 0a 53  ..#endif..}....S
0f70: 51 4c 49 54 45 5f 41 50 49 20 69 6e 74 20 57 49  QLITE_API int WI
0f80: 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 6f 70 65  NAPI sqlite3_ope
0f90: 6e 5f 69 6e 74 65 72 6f 70 28 63 6f 6e 73 74 20  n_interop(const 
0fa0: 63 68 61 72 2a 66 69 6c 65 6e 61 6d 65 2c 20 69  char*filename, i
0fb0: 6e 74 20 66 6c 61 67 73 2c 20 73 71 6c 69 74 65  nt flags, sqlite
0fc0: 33 20 2a 2a 70 70 64 62 29 0d 0a 7b 0d 0a 20 20  3 **ppdb)..{..  
0fd0: 69 6e 74 20 72 65 74 3b 0d 0a 20 20 2f 2f 69 6e  int ret;..  //in
0fe0: 74 20 73 68 61 72 65 64 63 61 63 68 65 20 3d 20  t sharedcache = 
0ff0: 28 28 66 6c 61 67 73 20 26 20 53 51 4c 49 54 45  ((flags & SQLITE
1000: 5f 4f 50 45 4e 5f 53 48 41 52 45 44 43 41 43 48  _OPEN_SHAREDCACH
1010: 45 29 20 21 3d 20 30 29 3b 0d 0a 20 20 2f 2f 66  E) != 0);..  //f
1020: 6c 61 67 73 20 26 3d 20 7e 53 51 4c 49 54 45 5f  lags &= ~SQLITE_
1030: 4f 50 45 4e 5f 53 48 41 52 45 44 43 41 43 48 45  OPEN_SHAREDCACHE
1040: 3b 0d 0a 0d 0a 20 20 2f 2f 73 71 6c 69 74 65 33  ;....  //sqlite3
1050: 5f 65 6e 61 62 6c 65 5f 73 68 61 72 65 64 5f 63  _enable_shared_c
1060: 61 63 68 65 28 73 68 61 72 65 64 63 61 63 68 65  ache(sharedcache
1070: 29 3b 0d 0a 20 20 72 65 74 20 3d 20 73 71 6c 69  );..  ret = sqli
1080: 74 65 33 5f 6f 70 65 6e 5f 76 32 28 66 69 6c 65  te3_open_v2(file
1090: 6e 61 6d 65 2c 20 70 70 64 62 2c 20 66 6c 61 67  name, ppdb, flag
10a0: 73 2c 20 4e 55 4c 4c 29 3b 0d 0a 20 20 2f 2f 73  s, NULL);..  //s
10b0: 71 6c 69 74 65 33 5f 65 6e 61 62 6c 65 5f 73 68  qlite3_enable_sh
10c0: 61 72 65 64 5f 63 61 63 68 65 28 30 29 3b 0d 0a  ared_cache(0);..
10d0: 0d 0a 23 69 66 20 64 65 66 69 6e 65 64 28 49 4e  ..#if defined(IN
10e0: 54 45 52 4f 50 5f 45 58 54 45 4e 53 49 4f 4e 5f  TEROP_EXTENSION_
10f0: 46 55 4e 43 54 49 4f 4e 53 29 0d 0a 20 20 69 66  FUNCTIONS)..  if
1100: 20 28 72 65 74 20 3d 3d 20 30 29 0d 0a 20 20 20   (ret == 0)..   
1110: 20 52 65 67 69 73 74 65 72 45 78 74 65 6e 73 69   RegisterExtensi
1120: 6f 6e 46 75 6e 63 74 69 6f 6e 73 28 2a 70 70 64  onFunctions(*ppd
1130: 62 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20  b);..#endif.... 
1140: 20 72 65 74 75 72 6e 20 72 65 74 3b 0d 0a 7d 0d   return ret;..}.
1150: 0a 0d 0a 53 51 4c 49 54 45 5f 41 50 49 20 69 6e  ...SQLITE_API in
1160: 74 20 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33  t WINAPI sqlite3
1170: 5f 6f 70 65 6e 31 36 5f 69 6e 74 65 72 6f 70 28  _open16_interop(
1180: 63 6f 6e 73 74 20 63 68 61 72 20 2a 66 69 6c 65  const char *file
1190: 6e 61 6d 65 2c 20 69 6e 74 20 66 6c 61 67 73 2c  name, int flags,
11a0: 20 73 71 6c 69 74 65 33 20 2a 2a 70 70 64 62 29   sqlite3 **ppdb)
11b0: 0d 0a 7b 0d 0a 20 20 69 6e 74 20 72 65 74 20 3d  ..{..  int ret =
11c0: 20 73 71 6c 69 74 65 33 5f 6f 70 65 6e 5f 69 6e   sqlite3_open_in
11d0: 74 65 72 6f 70 28 66 69 6c 65 6e 61 6d 65 2c 20  terop(filename, 
11e0: 66 6c 61 67 73 2c 20 70 70 64 62 29 3b 0d 0a 20  flags, ppdb);.. 
11f0: 20 69 66 20 28 21 72 65 74 29 0d 0a 20 20 7b 0d   if (!ret)..  {.
1200: 0a 20 20 20 20 69 66 28 21 44 62 48 61 73 50 72  .    if(!DbHasPr
1210: 6f 70 65 72 74 79 28 2a 70 70 64 62 2c 20 30 2c  operty(*ppdb, 0,
1220: 20 44 42 5f 53 63 68 65 6d 61 4c 6f 61 64 65 64   DB_SchemaLoaded
1230: 29 29 0d 0a 20 20 20 20 20 20 45 4e 43 28 2a 70  ))..      ENC(*p
1240: 70 64 62 29 20 3d 20 53 51 4c 49 54 45 5f 55 54  pdb) = SQLITE_UT
1250: 46 31 36 4e 41 54 49 56 45 3b 0d 0a 20 20 7d 0d  F16NATIVE;..  }.
1260: 0a 20 20 72 65 74 75 72 6e 20 72 65 74 3b 0d 0a  .  return ret;..
1270: 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50 49 20  }....SQLITE_API 
1280: 63 6f 6e 73 74 20 63 68 61 72 20 2a 20 57 49 4e  const char * WIN
1290: 41 50 49 20 73 71 6c 69 74 65 33 5f 65 72 72 6d  API sqlite3_errm
12a0: 73 67 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69 74  sg_interop(sqlit
12b0: 65 33 20 2a 64 62 2c 20 69 6e 74 20 2a 70 6c 65  e3 *db, int *ple
12c0: 6e 29 0d 0a 7b 0d 0a 20 20 63 6f 6e 73 74 20 63  n)..{..  const c
12d0: 68 61 72 20 2a 70 76 61 6c 20 3d 20 73 71 6c 69  har *pval = sqli
12e0: 74 65 33 5f 65 72 72 6d 73 67 28 64 62 29 3b 0d  te3_errmsg(db);.
12f0: 0a 20 20 2a 70 6c 65 6e 20 3d 20 28 70 76 61 6c  .  *plen = (pval
1300: 20 21 3d 20 30 29 20 3f 20 73 74 72 6c 65 6e 28   != 0) ? strlen(
1310: 70 76 61 6c 29 20 3a 20 30 3b 0d 0a 20 20 72 65  pval) : 0;..  re
1320: 74 75 72 6e 20 70 76 61 6c 3b 0d 0a 7d 0d 0a 0d  turn pval;..}...
1330: 0a 53 51 4c 49 54 45 5f 41 50 49 20 69 6e 74 20  .SQLITE_API int 
1340: 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 70  WINAPI sqlite3_p
1350: 72 65 70 61 72 65 5f 69 6e 74 65 72 6f 70 28 73  repare_interop(s
1360: 71 6c 69 74 65 33 20 2a 64 62 2c 20 63 6f 6e 73  qlite3 *db, cons
1370: 74 20 63 68 61 72 20 2a 73 71 6c 2c 20 69 6e 74  t char *sql, int
1380: 20 6e 62 79 74 65 73 2c 20 73 71 6c 69 74 65 33   nbytes, sqlite3
1390: 5f 73 74 6d 74 20 2a 2a 70 70 73 74 6d 74 2c 20  _stmt **ppstmt, 
13a0: 63 6f 6e 73 74 20 63 68 61 72 20 2a 2a 70 7a 74  const char **pzt
13b0: 61 69 6c 2c 20 69 6e 74 20 2a 70 6c 65 6e 29 0d  ail, int *plen).
13c0: 0a 7b 0d 0a 20 20 69 6e 74 20 6e 3b 0d 0a 0d 0a  .{..  int n;....
13d0: 20 20 6e 20 3d 20 73 71 6c 69 74 65 33 5f 70 72    n = sqlite3_pr
13e0: 65 70 61 72 65 28 64 62 2c 20 73 71 6c 2c 20 6e  epare(db, sql, n
13f0: 62 79 74 65 73 2c 20 70 70 73 74 6d 74 2c 20 70  bytes, ppstmt, p
1400: 7a 74 61 69 6c 29 3b 0d 0a 20 20 2a 70 6c 65 6e  ztail);..  *plen
1410: 20 3d 20 28 2a 70 7a 74 61 69 6c 20 21 3d 20 30   = (*pztail != 0
1420: 29 20 3f 20 73 74 72 6c 65 6e 28 2a 70 7a 74 61  ) ? strlen(*pzta
1430: 69 6c 29 20 3a 20 30 3b 0d 0a 0d 0a 20 20 72 65  il) : 0;....  re
1440: 74 75 72 6e 20 6e 3b 0d 0a 7d 0d 0a 0d 0a 53 51  turn n;..}....SQ
1450: 4c 49 54 45 5f 41 50 49 20 69 6e 74 20 57 49 4e  LITE_API int WIN
1460: 41 50 49 20 73 71 6c 69 74 65 33 5f 70 72 65 70  API sqlite3_prep
1470: 61 72 65 31 36 5f 69 6e 74 65 72 6f 70 28 73 71  are16_interop(sq
1480: 6c 69 74 65 33 20 2a 64 62 2c 20 63 6f 6e 73 74  lite3 *db, const
1490: 20 76 6f 69 64 20 2a 73 71 6c 2c 20 69 6e 74 20   void *sql, int 
14a0: 6e 63 68 61 72 73 2c 20 73 71 6c 69 74 65 33 5f  nchars, sqlite3_
14b0: 73 74 6d 74 20 2a 2a 70 70 73 74 6d 74 2c 20 63  stmt **ppstmt, c
14c0: 6f 6e 73 74 20 76 6f 69 64 20 2a 2a 70 7a 74 61  onst void **pzta
14d0: 69 6c 2c 20 69 6e 74 20 2a 70 6c 65 6e 29 0d 0a  il, int *plen)..
14e0: 7b 0d 0a 20 20 69 6e 74 20 6e 3b 0d 0a 0d 0a 20  {..  int n;.... 
14f0: 20 6e 20 3d 20 73 71 6c 69 74 65 33 5f 70 72 65   n = sqlite3_pre
1500: 70 61 72 65 31 36 28 64 62 2c 20 73 71 6c 2c 20  pare16(db, sql, 
1510: 6e 63 68 61 72 73 20 2a 20 73 69 7a 65 6f 66 28  nchars * sizeof(
1520: 77 63 68 61 72 5f 74 29 2c 20 70 70 73 74 6d 74  wchar_t), ppstmt
1530: 2c 20 70 7a 74 61 69 6c 29 3b 0d 0a 20 20 2a 70  , pztail);..  *p
1540: 6c 65 6e 20 3d 20 28 2a 70 7a 74 61 69 6c 20 21  len = (*pztail !
1550: 3d 20 30 29 20 3f 20 77 63 73 6c 65 6e 28 28 77  = 0) ? wcslen((w
1560: 63 68 61 72 5f 74 20 2a 29 2a 70 7a 74 61 69 6c  char_t *)*pztail
1570: 29 20 2a 20 73 69 7a 65 6f 66 28 77 63 68 61 72  ) * sizeof(wchar
1580: 5f 74 29 20 3a 20 30 3b 0d 0a 0d 0a 20 20 72 65  _t) : 0;....  re
1590: 74 75 72 6e 20 6e 3b 0d 0a 7d 0d 0a 0d 0a 53 51  turn n;..}....SQ
15a0: 4c 49 54 45 5f 41 50 49 20 69 6e 74 20 57 49 4e  LITE_API int WIN
15b0: 41 50 49 20 73 71 6c 69 74 65 33 5f 62 69 6e 64  API sqlite3_bind
15c0: 5f 64 6f 75 62 6c 65 5f 69 6e 74 65 72 6f 70 28  _double_interop(
15d0: 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 73 74  sqlite3_stmt *st
15e0: 6d 74 2c 20 69 6e 74 20 69 43 6f 6c 2c 20 64 6f  mt, int iCol, do
15f0: 75 62 6c 65 20 2a 76 61 6c 29 0d 0a 7b 0d 0a 09  uble *val)..{...
1600: 72 65 74 75 72 6e 20 73 71 6c 69 74 65 33 5f 62  return sqlite3_b
1610: 69 6e 64 5f 64 6f 75 62 6c 65 28 73 74 6d 74 2c  ind_double(stmt,
1620: 69 43 6f 6c 2c 2a 76 61 6c 29 3b 0d 0a 7d 0d 0a  iCol,*val);..}..
1630: 0d 0a 53 51 4c 49 54 45 5f 41 50 49 20 69 6e 74  ..SQLITE_API int
1640: 20 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33 5f   WINAPI sqlite3_
1650: 62 69 6e 64 5f 69 6e 74 36 34 5f 69 6e 74 65 72  bind_int64_inter
1660: 6f 70 28 73 71 6c 69 74 65 33 5f 73 74 6d 74 20  op(sqlite3_stmt 
1670: 2a 73 74 6d 74 2c 20 69 6e 74 20 69 43 6f 6c 2c  *stmt, int iCol,
1680: 20 73 71 6c 69 74 65 5f 69 6e 74 36 34 20 2a 76   sqlite_int64 *v
1690: 61 6c 29 0d 0a 7b 0d 0a 09 72 65 74 75 72 6e 20  al)..{...return 
16a0: 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74  sqlite3_bind_int
16b0: 36 34 28 73 74 6d 74 2c 69 43 6f 6c 2c 2a 76 61  64(stmt,iCol,*va
16c0: 6c 29 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45  l);..}....SQLITE
16d0: 5f 41 50 49 20 63 6f 6e 73 74 20 63 68 61 72 20  _API const char 
16e0: 2a 20 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33  * WINAPI sqlite3
16f0: 5f 62 69 6e 64 5f 70 61 72 61 6d 65 74 65 72 5f  _bind_parameter_
1700: 6e 61 6d 65 5f 69 6e 74 65 72 6f 70 28 73 71 6c  name_interop(sql
1710: 69 74 65 33 5f 73 74 6d 74 20 2a 73 74 6d 74 2c  ite3_stmt *stmt,
1720: 20 69 6e 74 20 69 43 6f 6c 2c 20 69 6e 74 20 2a   int iCol, int *
1730: 70 6c 65 6e 29 0d 0a 7b 0d 0a 20 20 63 6f 6e 73  plen)..{..  cons
1740: 74 20 63 68 61 72 20 2a 70 76 61 6c 20 3d 20 73  t char *pval = s
1750: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 70 61 72 61  qlite3_bind_para
1760: 6d 65 74 65 72 5f 6e 61 6d 65 28 73 74 6d 74 2c  meter_name(stmt,
1770: 20 69 43 6f 6c 29 3b 0d 0a 20 20 2a 70 6c 65 6e   iCol);..  *plen
1780: 20 3d 20 28 70 76 61 6c 20 21 3d 20 30 29 20 3f   = (pval != 0) ?
1790: 20 73 74 72 6c 65 6e 28 70 76 61 6c 29 20 3a 20   strlen(pval) : 
17a0: 30 3b 0d 0a 20 20 72 65 74 75 72 6e 20 70 76 61  0;..  return pva
17b0: 6c 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f  l;..}....SQLITE_
17c0: 41 50 49 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  API const char *
17d0: 20 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33 5f   WINAPI sqlite3_
17e0: 63 6f 6c 75 6d 6e 5f 6e 61 6d 65 5f 69 6e 74 65  column_name_inte
17f0: 72 6f 70 28 73 71 6c 69 74 65 33 5f 73 74 6d 74  rop(sqlite3_stmt
1800: 20 2a 73 74 6d 74 2c 20 69 6e 74 20 69 43 6f 6c   *stmt, int iCol
1810: 2c 20 69 6e 74 20 2a 70 6c 65 6e 29 0d 0a 7b 0d  , int *plen)..{.
1820: 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 70  .  const char *p
1830: 76 61 6c 20 3d 20 73 71 6c 69 74 65 33 5f 63 6f  val = sqlite3_co
1840: 6c 75 6d 6e 5f 6e 61 6d 65 28 73 74 6d 74 2c 20  lumn_name(stmt, 
1850: 69 43 6f 6c 29 3b 0d 0a 20 20 2a 70 6c 65 6e 20  iCol);..  *plen 
1860: 3d 20 28 70 76 61 6c 20 21 3d 20 30 29 20 3f 20  = (pval != 0) ? 
1870: 73 74 72 6c 65 6e 28 70 76 61 6c 29 20 3a 20 30  strlen(pval) : 0
1880: 3b 0d 0a 20 20 72 65 74 75 72 6e 20 70 76 61 6c  ;..  return pval
1890: 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41  ;..}....SQLITE_A
18a0: 50 49 20 63 6f 6e 73 74 20 76 6f 69 64 20 2a 20  PI const void * 
18b0: 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 63  WINAPI sqlite3_c
18c0: 6f 6c 75 6d 6e 5f 6e 61 6d 65 31 36 5f 69 6e 74  olumn_name16_int
18d0: 65 72 6f 70 28 73 71 6c 69 74 65 33 5f 73 74 6d  erop(sqlite3_stm
18e0: 74 20 2a 73 74 6d 74 2c 20 69 6e 74 20 69 43 6f  t *stmt, int iCo
18f0: 6c 2c 20 69 6e 74 20 2a 70 6c 65 6e 29 0d 0a 7b  l, int *plen)..{
1900: 0d 0a 20 20 63 6f 6e 73 74 20 76 6f 69 64 20 2a  ..  const void *
1910: 70 76 61 6c 20 3d 20 73 71 6c 69 74 65 33 5f 63  pval = sqlite3_c
1920: 6f 6c 75 6d 6e 5f 6e 61 6d 65 31 36 28 73 74 6d  olumn_name16(stm
1930: 74 2c 20 69 43 6f 6c 29 3b 0d 0a 20 20 2a 70 6c  t, iCol);..  *pl
1940: 65 6e 20 3d 20 28 70 76 61 6c 20 21 3d 20 30 29  en = (pval != 0)
1950: 20 3f 20 77 63 73 6c 65 6e 28 28 77 63 68 61 72   ? wcslen((wchar
1960: 5f 74 20 2a 29 70 76 61 6c 29 20 2a 20 73 69 7a  _t *)pval) * siz
1970: 65 6f 66 28 77 63 68 61 72 5f 74 29 20 3a 20 30  eof(wchar_t) : 0
1980: 3b 0d 0a 20 20 72 65 74 75 72 6e 20 70 76 61 6c  ;..  return pval
1990: 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41  ;..}....SQLITE_A
19a0: 50 49 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 20  PI const char * 
19b0: 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 63  WINAPI sqlite3_c
19c0: 6f 6c 75 6d 6e 5f 64 65 63 6c 74 79 70 65 5f 69  olumn_decltype_i
19d0: 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33 5f 73  nterop(sqlite3_s
19e0: 74 6d 74 20 2a 73 74 6d 74 2c 20 69 6e 74 20 69  tmt *stmt, int i
19f0: 43 6f 6c 2c 20 69 6e 74 20 2a 70 6c 65 6e 29 0d  Col, int *plen).
1a00: 0a 7b 0d 0a 20 20 63 6f 6e 73 74 20 63 68 61 72  .{..  const char
1a10: 20 2a 70 76 61 6c 20 3d 20 73 71 6c 69 74 65 33   *pval = sqlite3
1a20: 5f 63 6f 6c 75 6d 6e 5f 64 65 63 6c 74 79 70 65  _column_decltype
1a30: 28 73 74 6d 74 2c 20 69 43 6f 6c 29 3b 0d 0a 20  (stmt, iCol);.. 
1a40: 20 2a 70 6c 65 6e 20 3d 20 28 70 76 61 6c 20 21   *plen = (pval !
1a50: 3d 20 30 29 20 3f 20 73 74 72 6c 65 6e 28 70 76  = 0) ? strlen(pv
1a60: 61 6c 29 20 3a 20 30 3b 0d 0a 20 20 72 65 74 75  al) : 0;..  retu
1a70: 72 6e 20 70 76 61 6c 3b 0d 0a 7d 0d 0a 0d 0a 53  rn pval;..}....S
1a80: 51 4c 49 54 45 5f 41 50 49 20 63 6f 6e 73 74 20  QLITE_API const 
1a90: 76 6f 69 64 20 2a 20 57 49 4e 41 50 49 20 73 71  void * WINAPI sq
1aa0: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 65 63  lite3_column_dec
1ab0: 6c 74 79 70 65 31 36 5f 69 6e 74 65 72 6f 70 28  ltype16_interop(
1ac0: 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 73 74  sqlite3_stmt *st
1ad0: 6d 74 2c 20 69 6e 74 20 69 43 6f 6c 2c 20 69 6e  mt, int iCol, in
1ae0: 74 20 2a 70 6c 65 6e 29 0d 0a 7b 0d 0a 20 20 63  t *plen)..{..  c
1af0: 6f 6e 73 74 20 76 6f 69 64 20 2a 70 76 61 6c 20  onst void *pval 
1b00: 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  = sqlite3_column
1b10: 5f 64 65 63 6c 74 79 70 65 31 36 28 73 74 6d 74  _decltype16(stmt
1b20: 2c 20 69 43 6f 6c 29 3b 0d 0a 20 20 2a 70 6c 65  , iCol);..  *ple
1b30: 6e 20 3d 20 28 70 76 61 6c 20 21 3d 20 30 29 20  n = (pval != 0) 
1b40: 3f 20 77 63 73 6c 65 6e 28 28 77 63 68 61 72 5f  ? wcslen((wchar_
1b50: 74 20 2a 29 70 76 61 6c 29 20 2a 20 73 69 7a 65  t *)pval) * size
1b60: 6f 66 28 77 63 68 61 72 5f 74 29 20 3a 20 30 3b  of(wchar_t) : 0;
1b70: 0d 0a 20 20 72 65 74 75 72 6e 20 70 76 61 6c 3b  ..  return pval;
1b80: 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50  ..}....SQLITE_AP
1b90: 49 20 76 6f 69 64 20 57 49 4e 41 50 49 20 73 71  I void WINAPI sq
1ba0: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 6f 75  lite3_column_dou
1bb0: 62 6c 65 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69  ble_interop(sqli
1bc0: 74 65 33 5f 73 74 6d 74 20 2a 73 74 6d 74 2c 20  te3_stmt *stmt, 
1bd0: 69 6e 74 20 69 43 6f 6c 2c 20 64 6f 75 62 6c 65  int iCol, double
1be0: 20 2a 76 61 6c 29 0d 0a 7b 0d 0a 09 2a 76 61 6c   *val)..{...*val
1bf0: 20 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d   = sqlite3_colum
1c00: 6e 5f 64 6f 75 62 6c 65 28 73 74 6d 74 2c 69 43  n_double(stmt,iC
1c10: 6f 6c 29 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54  ol);..}....SQLIT
1c20: 45 5f 41 50 49 20 76 6f 69 64 20 57 49 4e 41 50  E_API void WINAP
1c30: 49 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  I sqlite3_column
1c40: 5f 69 6e 74 36 34 5f 69 6e 74 65 72 6f 70 28 73  _int64_interop(s
1c50: 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 73 74 6d  qlite3_stmt *stm
1c60: 74 2c 20 69 6e 74 20 69 43 6f 6c 2c 20 73 71 6c  t, int iCol, sql
1c70: 69 74 65 5f 69 6e 74 36 34 20 2a 76 61 6c 29 0d  ite_int64 *val).
1c80: 0a 7b 0d 0a 09 2a 76 61 6c 20 3d 20 73 71 6c 69  .{...*val = sqli
1c90: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 36 34  te3_column_int64
1ca0: 28 73 74 6d 74 2c 69 43 6f 6c 29 3b 0d 0a 7d 0d  (stmt,iCol);..}.
1cb0: 0a 0d 0a 53 51 4c 49 54 45 5f 41 50 49 20 63 6f  ...SQLITE_API co
1cc0: 6e 73 74 20 75 6e 73 69 67 6e 65 64 20 63 68 61  nst unsigned cha
1cd0: 72 20 2a 20 57 49 4e 41 50 49 20 73 71 6c 69 74  r * WINAPI sqlit
1ce0: 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 5f 69  e3_column_text_i
1cf0: 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33 5f 73  nterop(sqlite3_s
1d00: 74 6d 74 20 2a 73 74 6d 74 2c 20 69 6e 74 20 69  tmt *stmt, int i
1d10: 43 6f 6c 2c 20 69 6e 74 20 2a 70 6c 65 6e 29 0d  Col, int *plen).
1d20: 0a 7b 0d 0a 20 20 63 6f 6e 73 74 20 75 6e 73 69  .{..  const unsi
1d30: 67 6e 65 64 20 63 68 61 72 20 2a 70 76 61 6c 20  gned char *pval 
1d40: 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  = sqlite3_column
1d50: 5f 74 65 78 74 28 73 74 6d 74 2c 20 69 43 6f 6c  _text(stmt, iCol
1d60: 29 3b 0d 0a 20 20 2a 70 6c 65 6e 20 3d 20 28 70  );..  *plen = (p
1d70: 76 61 6c 20 21 3d 20 30 29 20 3f 20 73 74 72 6c  val != 0) ? strl
1d80: 65 6e 28 28 63 68 61 72 20 2a 29 70 76 61 6c 29  en((char *)pval)
1d90: 20 3a 20 30 3b 0d 0a 20 20 72 65 74 75 72 6e 20   : 0;..  return 
1da0: 70 76 61 6c 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49  pval;..}....SQLI
1db0: 54 45 5f 41 50 49 20 63 6f 6e 73 74 20 76 6f 69  TE_API const voi
1dc0: 64 20 2a 20 57 49 4e 41 50 49 20 73 71 6c 69 74  d * WINAPI sqlit
1dd0: 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 31 36  e3_column_text16
1de0: 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33  _interop(sqlite3
1df0: 5f 73 74 6d 74 20 2a 73 74 6d 74 2c 20 69 6e 74  _stmt *stmt, int
1e00: 20 69 43 6f 6c 2c 20 69 6e 74 20 2a 70 6c 65 6e   iCol, int *plen
1e10: 29 0d 0a 7b 0d 0a 20 20 63 6f 6e 73 74 20 76 6f  )..{..  const vo
1e20: 69 64 20 2a 70 76 61 6c 20 3d 20 73 71 6c 69 74  id *pval = sqlit
1e30: 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 31 36  e3_column_text16
1e40: 28 73 74 6d 74 2c 20 69 43 6f 6c 29 3b 0d 0a 20  (stmt, iCol);.. 
1e50: 20 2a 70 6c 65 6e 20 3d 20 28 70 76 61 6c 20 21   *plen = (pval !
1e60: 3d 20 30 29 20 3f 20 77 63 73 6c 65 6e 28 28 77  = 0) ? wcslen((w
1e70: 63 68 61 72 5f 74 20 2a 29 70 76 61 6c 29 20 2a  char_t *)pval) *
1e80: 20 73 69 7a 65 6f 66 28 77 63 68 61 72 5f 74 29   sizeof(wchar_t)
1e90: 3a 20 30 3b 0d 0a 20 20 72 65 74 75 72 6e 20 70  : 0;..  return p
1ea0: 76 61 6c 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54  val;..}....SQLIT
1eb0: 45 5f 41 50 49 20 69 6e 74 20 57 49 4e 41 50 49  E_API int WINAPI
1ec0: 20 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a   sqlite3_finaliz
1ed0: 65 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69 74 65  e_interop(sqlite
1ee0: 33 5f 73 74 6d 74 20 2a 73 74 6d 74 29 0d 0a 7b  3_stmt *stmt)..{
1ef0: 0d 0a 23 69 66 20 53 51 4c 49 54 45 5f 56 45 52  ..#if SQLITE_VER
1f00: 53 49 4f 4e 5f 4e 55 4d 42 45 52 20 3e 3d 20 33  SION_NUMBER >= 3
1f10: 30 30 37 30 31 34 0d 0a 20 20 72 65 74 75 72 6e  007014..  return
1f20: 20 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a   sqlite3_finaliz
1f30: 65 28 73 74 6d 74 29 3b 0d 0a 23 65 6c 73 65 0d  e(stmt);..#else.
1f40: 0a 20 20 56 64 62 65 20 2a 70 3b 0d 0a 20 20 69  .  Vdbe *p;..  i
1f50: 6e 74 20 72 65 74 20 3d 20 53 51 4c 49 54 45 5f  nt ret = SQLITE_
1f60: 4f 4b 3b 0d 0a 0d 0a 20 20 70 20 3d 20 28 56 64  OK;....  p = (Vd
1f70: 62 65 20 2a 29 73 74 6d 74 3b 0d 0a 20 20 69 66  be *)stmt;..  if
1f80: 20 28 70 29 0d 0a 20 20 7b 0d 0a 20 20 20 20 73   (p)..  {..    s
1f90: 71 6c 69 74 65 33 20 2a 64 62 20 3d 20 70 2d 3e  qlite3 *db = p->
1fa0: 64 62 3b 0d 0a 0d 0a 20 20 20 20 69 66 20 28 64  db;....    if (d
1fb0: 62 20 21 3d 20 4e 55 4c 4c 29 0d 0a 20 20 20 20  b != NULL)..    
1fc0: 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f    sqlite3_mutex_
1fd0: 65 6e 74 65 72 28 64 62 2d 3e 6d 75 74 65 78 29  enter(db->mutex)
1fe0: 3b 0d 0a 0d 0a 20 20 20 20 69 66 20 28 28 70 2d  ;....    if ((p-
1ff0: 3e 6d 61 67 69 63 20 3d 3d 20 56 44 42 45 5f 4d  >magic == VDBE_M
2000: 41 47 49 43 5f 44 45 41 44 29 20 26 26 20 28 64  AGIC_DEAD) && (d
2010: 62 20 3d 3d 20 4e 55 4c 4c 29 29 0d 0a 20 20 20  b == NULL))..   
2020: 20 7b 0d 0a 20 20 20 20 20 20 73 71 6c 69 74 65   {..      sqlite
2030: 33 44 62 46 72 65 65 5f 69 6e 74 65 72 6f 70 28  3DbFree_interop(
2040: 64 62 2c 20 70 29 3b 0d 0a 20 20 20 20 7d 0d 0a  db, p);..    }..
2050: 20 20 20 20 65 6c 73 65 0d 0a 20 20 20 20 7b 0d      else..    {.
2060: 0a 20 20 20 20 20 20 72 65 74 20 3d 20 73 71 6c  .      ret = sql
2070: 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 73 74  ite3_finalize(st
2080: 6d 74 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20  mt);..    }.... 
2090: 20 20 20 69 66 20 28 64 62 20 21 3d 20 4e 55 4c     if (db != NUL
20a0: 4c 29 0d 0a 20 20 20 20 20 20 73 71 6c 69 74 65  L)..      sqlite
20b0: 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 64 62  3_mutex_leave(db
20c0: 2d 3e 6d 75 74 65 78 29 3b 0d 0a 20 20 7d 0d 0a  ->mutex);..  }..
20d0: 0d 0a 20 20 72 65 74 75 72 6e 20 72 65 74 3b 0d  ..  return ret;.
20e0: 0a 23 65 6e 64 69 66 0d 0a 7d 0d 0a 0d 0a 53 51  .#endif..}....SQ
20f0: 4c 49 54 45 5f 41 50 49 20 69 6e 74 20 57 49 4e  LITE_API int WIN
2100: 41 50 49 20 73 71 6c 69 74 65 33 5f 72 65 73 65  API sqlite3_rese
2110: 74 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69 74 65  t_interop(sqlite
2120: 33 5f 73 74 6d 74 20 2a 73 74 6d 74 29 0d 0a 7b  3_stmt *stmt)..{
2130: 0d 0a 23 69 66 20 53 51 4c 49 54 45 5f 56 45 52  ..#if SQLITE_VER
2140: 53 49 4f 4e 5f 4e 55 4d 42 45 52 20 3e 3d 20 33  SION_NUMBER >= 3
2150: 30 30 37 30 31 34 0d 0a 20 20 72 65 74 75 72 6e  007014..  return
2160: 20 73 71 6c 69 74 65 33 5f 72 65 73 65 74 28 73   sqlite3_reset(s
2170: 74 6d 74 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20 20  tmt);..#else..  
2180: 69 6e 74 20 72 65 74 3b 0d 0a 0d 0a 20 20 69 66  int ret;....  if
2190: 20 28 28 28 56 64 62 65 20 2a 29 73 74 6d 74 29   (((Vdbe *)stmt)
21a0: 2d 3e 6d 61 67 69 63 20 3d 3d 20 56 44 42 45 5f  ->magic == VDBE_
21b0: 4d 41 47 49 43 5f 44 45 41 44 29 20 72 65 74 75  MAGIC_DEAD) retu
21c0: 72 6e 20 53 51 4c 49 54 45 5f 53 43 48 45 4d 41  rn SQLITE_SCHEMA
21d0: 3b 0d 0a 20 20 72 65 74 20 3d 20 73 71 6c 69 74  ;..  ret = sqlit
21e0: 65 33 5f 72 65 73 65 74 28 73 74 6d 74 29 3b 0d  e3_reset(stmt);.
21f0: 0a 20 20 72 65 74 75 72 6e 20 72 65 74 3b 0d 0a  .  return ret;..
2200: 23 65 6e 64 69 66 0d 0a 7d 0d 0a 0d 0a 53 51 4c  #endif..}....SQL
2210: 49 54 45 5f 41 50 49 20 69 6e 74 20 57 49 4e 41  ITE_API int WINA
2220: 50 49 20 73 71 6c 69 74 65 33 5f 63 72 65 61 74  PI sqlite3_creat
2230: 65 5f 66 75 6e 63 74 69 6f 6e 5f 69 6e 74 65 72  e_function_inter
2240: 6f 70 28 73 71 6c 69 74 65 33 20 2a 70 73 71 6c  op(sqlite3 *psql
2250: 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 46  , const char *zF
2260: 75 6e 63 74 69 6f 6e 4e 61 6d 65 2c 20 69 6e 74  unctionName, int
2270: 20 6e 41 72 67 2c 20 69 6e 74 20 65 54 65 78 74   nArg, int eText
2280: 52 65 70 2c 20 76 6f 69 64 20 2a 70 76 55 73 65  Rep, void *pvUse
2290: 72 2c 20 53 51 4c 49 54 45 55 53 45 52 46 55 4e  r, SQLITEUSERFUN
22a0: 43 20 66 75 6e 63 2c 20 53 51 4c 49 54 45 55 53  C func, SQLITEUS
22b0: 45 52 46 55 4e 43 20 66 75 6e 63 73 74 65 70 2c  ERFUNC funcstep,
22c0: 20 53 51 4c 49 54 45 46 55 4e 43 46 49 4e 41 4c   SQLITEFUNCFINAL
22d0: 20 66 75 6e 63 66 69 6e 61 6c 2c 20 69 6e 74 20   funcfinal, int 
22e0: 6e 65 65 64 43 6f 6c 6c 53 65 71 29 0d 0a 7b 0d  needCollSeq)..{.
22f0: 0a 20 20 69 6e 74 20 6e 3b 0d 0a 0d 0a 20 20 69  .  int n;....  i
2300: 66 20 28 65 54 65 78 74 52 65 70 20 3d 3d 20 53  f (eTextRep == S
2310: 51 4c 49 54 45 5f 55 54 46 31 36 29 0d 0a 20 20  QLITE_UTF16)..  
2320: 20 20 65 54 65 78 74 52 65 70 20 3d 20 53 51 4c    eTextRep = SQL
2330: 49 54 45 5f 55 54 46 31 36 4e 41 54 49 56 45 3b  ITE_UTF16NATIVE;
2340: 0d 0a 0d 0a 20 20 6e 20 3d 20 73 71 6c 69 74 65  ....  n = sqlite
2350: 33 5f 63 72 65 61 74 65 5f 66 75 6e 63 74 69 6f  3_create_functio
2360: 6e 28 70 73 71 6c 2c 20 7a 46 75 6e 63 74 69 6f  n(psql, zFunctio
2370: 6e 4e 61 6d 65 2c 20 6e 41 72 67 2c 20 65 54 65  nName, nArg, eTe
2380: 78 74 52 65 70 2c 20 30 2c 20 66 75 6e 63 2c 20  xtRep, 0, func, 
2390: 66 75 6e 63 73 74 65 70 2c 20 66 75 6e 63 66 69  funcstep, funcfi
23a0: 6e 61 6c 29 3b 0d 0a 20 20 69 66 20 28 6e 20 3d  nal);..  if (n =
23b0: 3d 20 30 29 0d 0a 20 20 7b 0d 0a 20 20 20 20 69  = 0)..  {..    i
23c0: 66 20 28 6e 65 65 64 43 6f 6c 6c 53 65 71 29 0d  f (needCollSeq).
23d0: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 46 75  .    {..      Fu
23e0: 6e 63 44 65 66 20 2a 70 46 75 6e 63 20 3d 20 73  ncDef *pFunc = s
23f0: 71 6c 69 74 65 33 46 69 6e 64 46 75 6e 63 74 69  qlite3FindFuncti
2400: 6f 6e 28 70 73 71 6c 2c 20 7a 46 75 6e 63 74 69  on(psql, zFuncti
2410: 6f 6e 4e 61 6d 65 2c 20 73 74 72 6c 65 6e 28 7a  onName, strlen(z
2420: 46 75 6e 63 74 69 6f 6e 4e 61 6d 65 29 2c 20 6e  FunctionName), n
2430: 41 72 67 2c 20 65 54 65 78 74 52 65 70 2c 20 30  Arg, eTextRep, 0
2440: 29 3b 0d 0a 20 20 20 20 20 20 69 66 28 20 70 46  );..      if( pF
2450: 75 6e 63 20 29 0d 0a 20 20 20 20 20 20 7b 0d 0a  unc )..      {..
2460: 20 20 20 20 20 20 20 20 70 46 75 6e 63 2d 3e 66          pFunc->f
2470: 6c 61 67 73 20 7c 3d 20 53 51 4c 49 54 45 5f 46  lags |= SQLITE_F
2480: 55 4e 43 5f 4e 45 45 44 43 4f 4c 4c 3b 0d 0a 20  UNC_NEEDCOLL;.. 
2490: 20 20 20 20 20 7d 0d 0a 20 20 20 20 7d 0d 0a 20       }..    }.. 
24a0: 20 7d 0d 0a 0d 0a 20 20 72 65 74 75 72 6e 20 6e   }....  return n
24b0: 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41  ;..}....SQLITE_A
24c0: 50 49 20 76 6f 69 64 20 57 49 4e 41 50 49 20 73  PI void WINAPI s
24d0: 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 64 6f 75  qlite3_value_dou
24e0: 62 6c 65 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69  ble_interop(sqli
24f0: 74 65 33 5f 76 61 6c 75 65 20 2a 70 76 61 6c 2c  te3_value *pval,
2500: 20 64 6f 75 62 6c 65 20 2a 76 61 6c 29 0d 0a 7b   double *val)..{
2510: 0d 0a 20 20 2a 76 61 6c 20 3d 20 73 71 6c 69 74  ..  *val = sqlit
2520: 65 33 5f 76 61 6c 75 65 5f 64 6f 75 62 6c 65 28  e3_value_double(
2530: 70 76 61 6c 29 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c  pval);..}....SQL
2540: 49 54 45 5f 41 50 49 20 76 6f 69 64 20 57 49 4e  ITE_API void WIN
2550: 41 50 49 20 73 71 6c 69 74 65 33 5f 76 61 6c 75  API sqlite3_valu
2560: 65 5f 69 6e 74 36 34 5f 69 6e 74 65 72 6f 70 28  e_int64_interop(
2570: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 20 2a 70  sqlite3_value *p
2580: 76 61 6c 2c 20 73 71 6c 69 74 65 5f 69 6e 74 36  val, sqlite_int6
2590: 34 20 2a 76 61 6c 29 0d 0a 7b 0d 0a 20 20 2a 76  4 *val)..{..  *v
25a0: 61 6c 20 3d 20 73 71 6c 69 74 65 33 5f 76 61 6c  al = sqlite3_val
25b0: 75 65 5f 69 6e 74 36 34 28 70 76 61 6c 29 3b 0d  ue_int64(pval);.
25c0: 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50 49  .}....SQLITE_API
25d0: 20 63 6f 6e 73 74 20 75 6e 73 69 67 6e 65 64 20   const unsigned 
25e0: 63 68 61 72 20 2a 20 57 49 4e 41 50 49 20 73 71  char * WINAPI sq
25f0: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74  lite3_value_text
2600: 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33  _interop(sqlite3
2610: 5f 76 61 6c 75 65 20 2a 76 61 6c 2c 20 69 6e 74  _value *val, int
2620: 20 2a 70 6c 65 6e 29 0d 0a 7b 0d 0a 20 20 63 6f   *plen)..{..  co
2630: 6e 73 74 20 75 6e 73 69 67 6e 65 64 20 63 68 61  nst unsigned cha
2640: 72 20 2a 70 76 61 6c 20 3d 20 73 71 6c 69 74 65  r *pval = sqlite
2650: 33 5f 76 61 6c 75 65 5f 74 65 78 74 28 76 61 6c  3_value_text(val
2660: 29 3b 0d 0a 20 20 2a 70 6c 65 6e 20 3d 20 28 70  );..  *plen = (p
2670: 76 61 6c 20 21 3d 20 30 29 20 3f 20 73 74 72 6c  val != 0) ? strl
2680: 65 6e 28 28 63 68 61 72 20 2a 29 70 76 61 6c 29  en((char *)pval)
2690: 20 3a 20 30 3b 0d 0a 20 20 72 65 74 75 72 6e 20   : 0;..  return 
26a0: 70 76 61 6c 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49  pval;..}....SQLI
26b0: 54 45 5f 41 50 49 20 63 6f 6e 73 74 20 76 6f 69  TE_API const voi
26c0: 64 20 2a 20 57 49 4e 41 50 49 20 73 71 6c 69 74  d * WINAPI sqlit
26d0: 65 33 5f 76 61 6c 75 65 5f 74 65 78 74 31 36 5f  e3_value_text16_
26e0: 69 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33 5f  interop(sqlite3_
26f0: 76 61 6c 75 65 20 2a 76 61 6c 2c 20 69 6e 74 20  value *val, int 
2700: 2a 70 6c 65 6e 29 0d 0a 7b 0d 0a 20 20 63 6f 6e  *plen)..{..  con
2710: 73 74 20 76 6f 69 64 20 2a 70 76 61 6c 20 3d 20  st void *pval = 
2720: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 65  sqlite3_value_te
2730: 78 74 31 36 28 76 61 6c 29 3b 0d 0a 20 20 2a 70  xt16(val);..  *p
2740: 6c 65 6e 20 3d 20 28 70 76 61 6c 20 21 3d 20 30  len = (pval != 0
2750: 29 20 3f 20 77 63 73 6c 65 6e 28 28 77 63 68 61  ) ? wcslen((wcha
2760: 72 5f 74 20 2a 29 70 76 61 6c 29 20 2a 20 73 69  r_t *)pval) * si
2770: 7a 65 6f 66 28 77 63 68 61 72 5f 74 29 20 3a 20  zeof(wchar_t) : 
2780: 30 3b 0d 0a 20 20 72 65 74 75 72 6e 20 70 76 61  0;..  return pva
2790: 6c 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f  l;..}....SQLITE_
27a0: 41 50 49 20 76 6f 69 64 20 57 49 4e 41 50 49 20  API void WINAPI 
27b0: 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 64  sqlite3_result_d
27c0: 6f 75 62 6c 65 5f 69 6e 74 65 72 6f 70 28 73 71  ouble_interop(sq
27d0: 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 70  lite3_context *p
27e0: 63 74 78 2c 20 64 6f 75 62 6c 65 20 2a 76 61 6c  ctx, double *val
27f0: 29 0d 0a 7b 0d 0a 20 20 73 71 6c 69 74 65 33 5f  )..{..  sqlite3_
2800: 72 65 73 75 6c 74 5f 64 6f 75 62 6c 65 28 70 63  result_double(pc
2810: 74 78 2c 20 2a 76 61 6c 29 3b 0d 0a 7d 0d 0a 0d  tx, *val);..}...
2820: 0a 53 51 4c 49 54 45 5f 41 50 49 20 76 6f 69 64  .SQLITE_API void
2830: 20 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33 5f   WINAPI sqlite3_
2840: 72 65 73 75 6c 74 5f 69 6e 74 36 34 5f 69 6e 74  result_int64_int
2850: 65 72 6f 70 28 73 71 6c 69 74 65 33 5f 63 6f 6e  erop(sqlite3_con
2860: 74 65 78 74 20 2a 70 63 74 78 2c 20 73 71 6c 69  text *pctx, sqli
2870: 74 65 5f 69 6e 74 36 34 20 2a 76 61 6c 29 0d 0a  te_int64 *val)..
2880: 7b 0d 0a 20 20 73 71 6c 69 74 65 33 5f 72 65 73  {..  sqlite3_res
2890: 75 6c 74 5f 69 6e 74 36 34 28 70 63 74 78 2c 20  ult_int64(pctx, 
28a0: 2a 76 61 6c 29 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c  *val);..}....SQL
28b0: 49 54 45 5f 41 50 49 20 69 6e 74 20 57 49 4e 41  ITE_API int WINA
28c0: 50 49 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65  PI sqlite3_conte
28d0: 78 74 5f 63 6f 6c 6c 63 6f 6d 70 61 72 65 28 73  xt_collcompare(s
28e0: 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a  qlite3_context *
28f0: 63 74 78 2c 20 63 6f 6e 73 74 20 76 6f 69 64 20  ctx, const void 
2900: 2a 70 31 2c 20 69 6e 74 20 70 31 6c 65 6e 2c 20  *p1, int p1len, 
2910: 63 6f 6e 73 74 20 76 6f 69 64 20 2a 70 32 2c 20  const void *p2, 
2920: 69 6e 74 20 70 32 6c 65 6e 29 0d 0a 7b 0d 0a 20  int p2len)..{.. 
2930: 20 69 66 20 28 28 63 74 78 2d 3e 70 46 75 6e 63   if ((ctx->pFunc
2940: 2d 3e 66 6c 61 67 73 20 26 20 53 51 4c 49 54 45  ->flags & SQLITE
2950: 5f 46 55 4e 43 5f 4e 45 45 44 43 4f 4c 4c 29 20  _FUNC_NEEDCOLL) 
2960: 3d 3d 20 30 29 20 72 65 74 75 72 6e 20 32 3b 0d  == 0) return 2;.
2970: 0a 20 20 72 65 74 75 72 6e 20 63 74 78 2d 3e 70  .  return ctx->p
2980: 43 6f 6c 6c 2d 3e 78 43 6d 70 28 63 74 78 2d 3e  Coll->xCmp(ctx->
2990: 70 43 6f 6c 6c 2d 3e 70 55 73 65 72 2c 20 70 31  pColl->pUser, p1
29a0: 6c 65 6e 2c 20 70 31 2c 20 70 32 6c 65 6e 2c 20  len, p1, p2len, 
29b0: 70 32 29 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54  p2);..}....SQLIT
29c0: 45 5f 41 50 49 20 63 6f 6e 73 74 20 63 68 61 72  E_API const char
29d0: 20 2a 20 57 49 4e 41 50 49 20 73 71 6c 69 74 65   * WINAPI sqlite
29e0: 33 5f 63 6f 6e 74 65 78 74 5f 63 6f 6c 6c 73 65  3_context_collse
29f0: 71 28 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78  q(sqlite3_contex
2a00: 74 20 2a 63 74 78 2c 20 69 6e 74 20 2a 70 74 79  t *ctx, int *pty
2a10: 70 65 2c 20 69 6e 74 20 2a 65 6e 63 2c 20 69 6e  pe, int *enc, in
2a20: 74 20 2a 70 6c 65 6e 29 0d 0a 7b 0d 0a 20 20 43  t *plen)..{..  C
2a30: 6f 6c 6c 53 65 71 20 2a 70 43 6f 6c 6c 20 3d 20  ollSeq *pColl = 
2a40: 63 74 78 2d 3e 70 43 6f 6c 6c 3b 0d 0a 20 20 2a  ctx->pColl;..  *
2a50: 70 74 79 70 65 20 3d 20 30 3b 0d 0a 20 20 2a 70  ptype = 0;..  *p
2a60: 6c 65 6e 20 3d 20 30 3b 0d 0a 20 20 2a 65 6e 63  len = 0;..  *enc
2a70: 20 3d 20 30 3b 0d 0a 0d 0a 20 20 69 66 20 28 28   = 0;....  if ((
2a80: 63 74 78 2d 3e 70 46 75 6e 63 2d 3e 66 6c 61 67  ctx->pFunc->flag
2a90: 73 20 26 20 53 51 4c 49 54 45 5f 46 55 4e 43 5f  s & SQLITE_FUNC_
2aa0: 4e 45 45 44 43 4f 4c 4c 29 20 3d 3d 20 30 29 20  NEEDCOLL) == 0) 
2ab0: 72 65 74 75 72 6e 20 4e 55 4c 4c 3b 0d 0a 0d 0a  return NULL;....
2ac0: 20 20 69 66 20 28 70 43 6f 6c 6c 29 0d 0a 20 20    if (pColl)..  
2ad0: 7b 0d 0a 20 20 20 20 2a 65 6e 63 20 3d 20 70 43  {..    *enc = pC
2ae0: 6f 6c 6c 2d 3e 65 6e 63 3b 0d 0a 23 69 66 20 53  oll->enc;..#if S
2af0: 51 4c 49 54 45 5f 56 45 52 53 49 4f 4e 5f 4e 55  QLITE_VERSION_NU
2b00: 4d 42 45 52 20 3c 20 33 30 30 37 30 31 30 0d 0a  MBER < 3007010..
2b10: 20 20 20 20 2a 70 74 79 70 65 20 3d 20 70 43 6f      *ptype = pCo
2b20: 6c 6c 2d 3e 74 79 70 65 3b 0d 0a 23 65 6e 64 69  ll->type;..#endi
2b30: 66 0d 0a 20 20 20 20 2a 70 6c 65 6e 20 3d 20 28  f..    *plen = (
2b40: 70 43 6f 6c 6c 2d 3e 7a 4e 61 6d 65 20 21 3d 20  pColl->zName != 
2b50: 30 29 20 3f 20 73 74 72 6c 65 6e 28 70 43 6f 6c  0) ? strlen(pCol
2b60: 6c 2d 3e 7a 4e 61 6d 65 29 20 3a 20 30 3b 0d 0a  l->zName) : 0;..
2b70: 0d 0a 20 20 20 20 72 65 74 75 72 6e 20 70 43 6f  ..    return pCo
2b80: 6c 6c 2d 3e 7a 4e 61 6d 65 3b 0d 0a 20 20 7d 0d  ll->zName;..  }.
2b90: 0a 20 20 72 65 74 75 72 6e 20 4e 55 4c 4c 3b 0d  .  return NULL;.
2ba0: 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50 49  .}....SQLITE_API
2bb0: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 20 57 49   const char * WI
2bc0: 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 63 6f 6c  NAPI sqlite3_col
2bd0: 75 6d 6e 5f 64 61 74 61 62 61 73 65 5f 6e 61 6d  umn_database_nam
2be0: 65 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69 74 65  e_interop(sqlite
2bf0: 33 5f 73 74 6d 74 20 2a 73 74 6d 74 2c 20 69 6e  3_stmt *stmt, in
2c00: 74 20 69 43 6f 6c 2c 20 69 6e 74 20 2a 70 6c 65  t iCol, int *ple
2c10: 6e 29 0d 0a 7b 0d 0a 20 20 63 6f 6e 73 74 20 63  n)..{..  const c
2c20: 68 61 72 20 2a 70 76 61 6c 20 3d 20 73 71 6c 69  har *pval = sqli
2c30: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 61 74 61 62  te3_column_datab
2c40: 61 73 65 5f 6e 61 6d 65 28 73 74 6d 74 2c 20 69  ase_name(stmt, i
2c50: 43 6f 6c 29 3b 0d 0a 20 20 2a 70 6c 65 6e 20 3d  Col);..  *plen =
2c60: 20 28 70 76 61 6c 20 21 3d 20 30 29 20 3f 20 73   (pval != 0) ? s
2c70: 74 72 6c 65 6e 28 70 76 61 6c 29 20 3a 20 30 3b  trlen(pval) : 0;
2c80: 0d 0a 20 20 72 65 74 75 72 6e 20 70 76 61 6c 3b  ..  return pval;
2c90: 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50  ..}....SQLITE_AP
2ca0: 49 20 63 6f 6e 73 74 20 76 6f 69 64 20 2a 20 57  I const void * W
2cb0: 49 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 63 6f  INAPI sqlite3_co
2cc0: 6c 75 6d 6e 5f 64 61 74 61 62 61 73 65 5f 6e 61  lumn_database_na
2cd0: 6d 65 31 36 5f 69 6e 74 65 72 6f 70 28 73 71 6c  me16_interop(sql
2ce0: 69 74 65 33 5f 73 74 6d 74 20 2a 73 74 6d 74 2c  ite3_stmt *stmt,
2cf0: 20 69 6e 74 20 69 43 6f 6c 2c 20 69 6e 74 20 2a   int iCol, int *
2d00: 70 6c 65 6e 29 0d 0a 7b 0d 0a 20 20 63 6f 6e 73  plen)..{..  cons
2d10: 74 20 76 6f 69 64 20 2a 70 76 61 6c 20 3d 20 73  t void *pval = s
2d20: 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 61  qlite3_column_da
2d30: 74 61 62 61 73 65 5f 6e 61 6d 65 31 36 28 73 74  tabase_name16(st
2d40: 6d 74 2c 20 69 43 6f 6c 29 3b 0d 0a 20 20 2a 70  mt, iCol);..  *p
2d50: 6c 65 6e 20 3d 20 28 70 76 61 6c 20 21 3d 20 30  len = (pval != 0
2d60: 29 20 3f 20 77 63 73 6c 65 6e 28 28 77 63 68 61  ) ? wcslen((wcha
2d70: 72 5f 74 20 2a 29 70 76 61 6c 29 20 2a 20 73 69  r_t *)pval) * si
2d80: 7a 65 6f 66 28 77 63 68 61 72 5f 74 29 20 3a 20  zeof(wchar_t) : 
2d90: 30 3b 0d 0a 20 20 72 65 74 75 72 6e 20 70 76 61  0;..  return pva
2da0: 6c 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f  l;..}....SQLITE_
2db0: 41 50 49 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  API const char *
2dc0: 20 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33 5f   WINAPI sqlite3_
2dd0: 63 6f 6c 75 6d 6e 5f 74 61 62 6c 65 5f 6e 61 6d  column_table_nam
2de0: 65 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69 74 65  e_interop(sqlite
2df0: 33 5f 73 74 6d 74 20 2a 73 74 6d 74 2c 20 69 6e  3_stmt *stmt, in
2e00: 74 20 69 43 6f 6c 2c 20 69 6e 74 20 2a 70 6c 65  t iCol, int *ple
2e10: 6e 29 0d 0a 7b 0d 0a 20 20 63 6f 6e 73 74 20 63  n)..{..  const c
2e20: 68 61 72 20 2a 70 76 61 6c 20 3d 20 73 71 6c 69  har *pval = sqli
2e30: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 61 62 6c 65  te3_column_table
2e40: 5f 6e 61 6d 65 28 73 74 6d 74 2c 20 69 43 6f 6c  _name(stmt, iCol
2e50: 29 3b 0d 0a 20 20 2a 70 6c 65 6e 20 3d 20 28 70  );..  *plen = (p
2e60: 76 61 6c 20 21 3d 20 30 29 20 3f 20 73 74 72 6c  val != 0) ? strl
2e70: 65 6e 28 70 76 61 6c 29 20 3a 20 30 3b 0d 0a 20  en(pval) : 0;.. 
2e80: 20 72 65 74 75 72 6e 20 70 76 61 6c 3b 0d 0a 7d   return pval;..}
2e90: 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50 49 20 63  ....SQLITE_API c
2ea0: 6f 6e 73 74 20 76 6f 69 64 20 2a 20 57 49 4e 41  onst void * WINA
2eb0: 50 49 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  PI sqlite3_colum
2ec0: 6e 5f 74 61 62 6c 65 5f 6e 61 6d 65 31 36 5f 69  n_table_name16_i
2ed0: 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33 5f 73  nterop(sqlite3_s
2ee0: 74 6d 74 20 2a 73 74 6d 74 2c 20 69 6e 74 20 69  tmt *stmt, int i
2ef0: 43 6f 6c 2c 20 69 6e 74 20 2a 70 6c 65 6e 29 0d  Col, int *plen).
2f00: 0a 7b 0d 0a 20 20 63 6f 6e 73 74 20 76 6f 69 64  .{..  const void
2f10: 20 2a 70 76 61 6c 20 3d 20 73 71 6c 69 74 65 33   *pval = sqlite3
2f20: 5f 63 6f 6c 75 6d 6e 5f 74 61 62 6c 65 5f 6e 61  _column_table_na
2f30: 6d 65 31 36 28 73 74 6d 74 2c 20 69 43 6f 6c 29  me16(stmt, iCol)
2f40: 3b 0d 0a 20 20 2a 70 6c 65 6e 20 3d 20 28 70 76  ;..  *plen = (pv
2f50: 61 6c 20 21 3d 20 30 29 20 3f 20 77 63 73 6c 65  al != 0) ? wcsle
2f60: 6e 28 28 77 63 68 61 72 5f 74 20 2a 29 70 76 61  n((wchar_t *)pva
2f70: 6c 29 20 2a 20 73 69 7a 65 6f 66 28 77 63 68 61  l) * sizeof(wcha
2f80: 72 5f 74 29 20 3a 20 30 3b 0d 0a 20 20 72 65 74  r_t) : 0;..  ret
2f90: 75 72 6e 20 70 76 61 6c 3b 0d 0a 7d 0d 0a 0d 0a  urn pval;..}....
2fa0: 53 51 4c 49 54 45 5f 41 50 49 20 63 6f 6e 73 74  SQLITE_API const
2fb0: 20 63 68 61 72 20 2a 20 57 49 4e 41 50 49 20 73   char * WINAPI s
2fc0: 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6f 72  qlite3_column_or
2fd0: 69 67 69 6e 5f 6e 61 6d 65 5f 69 6e 74 65 72 6f  igin_name_intero
2fe0: 70 28 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a  p(sqlite3_stmt *
2ff0: 73 74 6d 74 2c 20 69 6e 74 20 69 43 6f 6c 2c 20  stmt, int iCol, 
3000: 69 6e 74 20 2a 70 6c 65 6e 29 0d 0a 7b 0d 0a 20  int *plen)..{.. 
3010: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 70 76 61   const char *pva
3020: 6c 20 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75  l = sqlite3_colu
3030: 6d 6e 5f 6f 72 69 67 69 6e 5f 6e 61 6d 65 28 73  mn_origin_name(s
3040: 74 6d 74 2c 20 69 43 6f 6c 29 3b 0d 0a 20 20 2a  tmt, iCol);..  *
3050: 70 6c 65 6e 20 3d 20 28 70 76 61 6c 20 21 3d 20  plen = (pval != 
3060: 30 29 20 3f 20 73 74 72 6c 65 6e 28 70 76 61 6c  0) ? strlen(pval
3070: 29 20 3a 20 30 3b 0d 0a 20 20 72 65 74 75 72 6e  ) : 0;..  return
3080: 20 70 76 61 6c 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c   pval;..}....SQL
3090: 49 54 45 5f 41 50 49 20 63 6f 6e 73 74 20 76 6f  ITE_API const vo
30a0: 69 64 20 2a 20 57 49 4e 41 50 49 20 73 71 6c 69  id * WINAPI sqli
30b0: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6f 72 69 67 69  te3_column_origi
30c0: 6e 5f 6e 61 6d 65 31 36 5f 69 6e 74 65 72 6f 70  n_name16_interop
30d0: 28 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 73  (sqlite3_stmt *s
30e0: 74 6d 74 2c 20 69 6e 74 20 69 43 6f 6c 2c 20 69  tmt, int iCol, i
30f0: 6e 74 20 2a 70 6c 65 6e 29 0d 0a 7b 0d 0a 20 20  nt *plen)..{..  
3100: 63 6f 6e 73 74 20 76 6f 69 64 20 2a 70 76 61 6c  const void *pval
3110: 20 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d   = sqlite3_colum
3120: 6e 5f 6f 72 69 67 69 6e 5f 6e 61 6d 65 31 36 28  n_origin_name16(
3130: 73 74 6d 74 2c 20 69 43 6f 6c 29 3b 0d 0a 20 20  stmt, iCol);..  
3140: 2a 70 6c 65 6e 20 3d 20 28 70 76 61 6c 20 21 3d  *plen = (pval !=
3150: 20 30 29 20 3f 20 77 63 73 6c 65 6e 28 28 77 63   0) ? wcslen((wc
3160: 68 61 72 5f 74 20 2a 29 70 76 61 6c 29 20 2a 20  har_t *)pval) * 
3170: 73 69 7a 65 6f 66 28 77 63 68 61 72 5f 74 29 20  sizeof(wchar_t) 
3180: 3a 20 30 3b 0d 0a 20 20 72 65 74 75 72 6e 20 70  : 0;..  return p
3190: 76 61 6c 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54  val;..}....SQLIT
31a0: 45 5f 41 50 49 20 69 6e 74 20 57 49 4e 41 50 49  E_API int WINAPI
31b0: 20 73 71 6c 69 74 65 33 5f 74 61 62 6c 65 5f 63   sqlite3_table_c
31c0: 6f 6c 75 6d 6e 5f 6d 65 74 61 64 61 74 61 5f 69  olumn_metadata_i
31d0: 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33 20 2a  nterop(sqlite3 *
31e0: 64 62 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  db, const char *
31f0: 7a 44 62 4e 61 6d 65 2c 20 63 6f 6e 73 74 20 63  zDbName, const c
3200: 68 61 72 20 2a 7a 54 61 62 6c 65 4e 61 6d 65 2c  har *zTableName,
3210: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 43 6f   const char *zCo
3220: 6c 75 6d 6e 4e 61 6d 65 2c 20 63 68 61 72 20 2a  lumnName, char *
3230: 2a 70 7a 44 61 74 61 54 79 70 65 2c 20 63 68 61  *pzDataType, cha
3240: 72 20 2a 2a 70 7a 43 6f 6c 6c 53 65 71 2c 20 69  r **pzCollSeq, i
3250: 6e 74 20 2a 70 4e 6f 74 4e 75 6c 6c 2c 20 69 6e  nt *pNotNull, in
3260: 74 20 2a 70 50 72 69 6d 61 72 79 4b 65 79 2c 20  t *pPrimaryKey, 
3270: 69 6e 74 20 2a 70 41 75 74 6f 69 6e 63 2c 20 69  int *pAutoinc, i
3280: 6e 74 20 2a 70 64 74 4c 65 6e 2c 20 69 6e 74 20  nt *pdtLen, int 
3290: 2a 70 63 73 4c 65 6e 29 0d 0a 7b 0d 0a 20 20 69  *pcsLen)..{..  i
32a0: 6e 74 20 6e 3b 0d 0a 20 20 0d 0a 20 20 6e 20 3d  nt n;..  ..  n =
32b0: 20 73 71 6c 69 74 65 33 5f 74 61 62 6c 65 5f 63   sqlite3_table_c
32c0: 6f 6c 75 6d 6e 5f 6d 65 74 61 64 61 74 61 28 64  olumn_metadata(d
32d0: 62 2c 20 7a 44 62 4e 61 6d 65 2c 20 7a 54 61 62  b, zDbName, zTab
32e0: 6c 65 4e 61 6d 65 2c 20 7a 43 6f 6c 75 6d 6e 4e  leName, zColumnN
32f0: 61 6d 65 2c 20 70 7a 44 61 74 61 54 79 70 65 2c  ame, pzDataType,
3300: 20 70 7a 43 6f 6c 6c 53 65 71 2c 20 70 4e 6f 74   pzCollSeq, pNot
3310: 4e 75 6c 6c 2c 20 70 50 72 69 6d 61 72 79 4b 65  Null, pPrimaryKe
3320: 79 2c 20 70 41 75 74 6f 69 6e 63 29 3b 0d 0a 20  y, pAutoinc);.. 
3330: 20 2a 70 64 74 4c 65 6e 20 3d 20 28 2a 70 7a 44   *pdtLen = (*pzD
3340: 61 74 61 54 79 70 65 20 21 3d 20 30 29 20 3f 20  ataType != 0) ? 
3350: 73 74 72 6c 65 6e 28 2a 70 7a 44 61 74 61 54 79  strlen(*pzDataTy
3360: 70 65 29 20 3a 20 30 3b 0d 0a 20 20 2a 70 63 73  pe) : 0;..  *pcs
3370: 4c 65 6e 20 3d 20 28 2a 70 7a 43 6f 6c 6c 53 65  Len = (*pzCollSe
3380: 71 20 21 3d 20 30 29 20 3f 20 73 74 72 6c 65 6e  q != 0) ? strlen
3390: 28 2a 70 7a 43 6f 6c 6c 53 65 71 29 20 3a 20 30  (*pzCollSeq) : 0
33a0: 3b 0d 0a 0d 0a 20 20 72 65 74 75 72 6e 20 6e 3b  ;....  return n;
33b0: 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50  ..}....SQLITE_AP
33c0: 49 20 69 6e 74 20 57 49 4e 41 50 49 20 73 71 6c  I int WINAPI sql
33d0: 69 74 65 33 5f 69 6e 64 65 78 5f 63 6f 6c 75 6d  ite3_index_colum
33e0: 6e 5f 69 6e 66 6f 5f 69 6e 74 65 72 6f 70 28 73  n_info_interop(s
33f0: 71 6c 69 74 65 33 20 2a 64 62 2c 20 63 6f 6e 73  qlite3 *db, cons
3400: 74 20 63 68 61 72 20 2a 7a 44 62 2c 20 63 6f 6e  t char *zDb, con
3410: 73 74 20 63 68 61 72 20 2a 7a 49 6e 64 65 78 4e  st char *zIndexN
3420: 61 6d 65 2c 20 63 6f 6e 73 74 20 63 68 61 72 20  ame, const char 
3430: 2a 7a 43 6f 6c 75 6d 6e 4e 61 6d 65 2c 20 69 6e  *zColumnName, in
3440: 74 20 2a 73 6f 72 74 4f 72 64 65 72 2c 20 69 6e  t *sortOrder, in
3450: 74 20 2a 6f 6e 45 72 72 6f 72 2c 20 63 68 61 72  t *onError, char
3460: 20 2a 2a 70 7a 43 6f 6c 6c 2c 20 69 6e 74 20 2a   **pzColl, int *
3470: 70 6c 65 6e 29 0d 0a 7b 0d 0a 20 20 49 6e 64 65  plen)..{..  Inde
3480: 78 20 2a 70 49 64 78 3b 0d 0a 20 20 54 61 62 6c  x *pIdx;..  Tabl
3490: 65 20 2a 70 54 61 62 3b 0d 0a 20 20 69 6e 74 20  e *pTab;..  int 
34a0: 6e 3b 0d 0a 0d 0a 20 20 73 71 6c 69 74 65 33 5f  n;....  sqlite3_
34b0: 6d 75 74 65 78 5f 65 6e 74 65 72 28 64 62 2d 3e  mutex_enter(db->
34c0: 6d 75 74 65 78 29 3b 0a 20 20 73 71 6c 69 74 65  mutex);.  sqlite
34d0: 33 42 74 72 65 65 45 6e 74 65 72 41 6c 6c 28 64  3BtreeEnterAll(d
34e0: 62 29 3b 0a 0d 0a 20 20 70 49 64 78 20 3d 20 73  b);...  pIdx = s
34f0: 71 6c 69 74 65 33 46 69 6e 64 49 6e 64 65 78 28  qlite3FindIndex(
3500: 64 62 2c 20 7a 49 6e 64 65 78 4e 61 6d 65 2c 20  db, zIndexName, 
3510: 7a 44 62 29 3b 0d 0a 0d 0a 20 20 73 71 6c 69 74  zDb);....  sqlit
3520: 65 33 42 74 72 65 65 4c 65 61 76 65 41 6c 6c 28  e3BtreeLeaveAll(
3530: 64 62 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 6d  db);.  sqlite3_m
3540: 75 74 65 78 5f 6c 65 61 76 65 28 64 62 2d 3e 6d  utex_leave(db->m
3550: 75 74 65 78 29 3b 0a 0d 0a 20 20 69 66 20 28 21  utex);...  if (!
3560: 70 49 64 78 29 20 72 65 74 75 72 6e 20 53 51 4c  pIdx) return SQL
3570: 49 54 45 5f 45 52 52 4f 52 3b 0d 0a 0d 0a 20 20  ITE_ERROR;....  
3580: 70 54 61 62 20 3d 20 70 49 64 78 2d 3e 70 54 61  pTab = pIdx->pTa
3590: 62 6c 65 3b 0d 0a 20 20 66 6f 72 20 28 6e 20 3d  ble;..  for (n =
35a0: 20 30 3b 20 6e 20 3c 20 70 49 64 78 2d 3e 6e 43   0; n < pIdx->nC
35b0: 6f 6c 75 6d 6e 3b 20 6e 2b 2b 29 0d 0a 20 20 7b  olumn; n++)..  {
35c0: 0d 0a 20 20 20 20 69 6e 74 20 63 6e 75 6d 20 3d  ..    int cnum =
35d0: 20 70 49 64 78 2d 3e 61 69 43 6f 6c 75 6d 6e 5b   pIdx->aiColumn[
35e0: 6e 5d 3b 0d 0a 20 20 20 20 69 66 20 28 73 71 6c  n];..    if (sql
35f0: 69 74 65 33 53 74 72 49 43 6d 70 28 70 54 61 62  ite3StrICmp(pTab
3600: 2d 3e 61 43 6f 6c 5b 63 6e 75 6d 5d 2e 7a 4e 61  ->aCol[cnum].zNa
3610: 6d 65 2c 20 7a 43 6f 6c 75 6d 6e 4e 61 6d 65 29  me, zColumnName)
3620: 20 3d 3d 20 30 29 0d 0a 20 20 20 20 7b 0d 0a 20   == 0)..    {.. 
3630: 20 20 20 20 20 2a 73 6f 72 74 4f 72 64 65 72 20       *sortOrder 
3640: 3d 20 70 49 64 78 2d 3e 61 53 6f 72 74 4f 72 64  = pIdx->aSortOrd
3650: 65 72 5b 6e 5d 3b 0d 0a 20 20 20 20 20 20 2a 70  er[n];..      *p
3660: 7a 43 6f 6c 6c 20 3d 20 70 49 64 78 2d 3e 61 7a  zColl = pIdx->az
3670: 43 6f 6c 6c 5b 6e 5d 3b 0d 0a 20 20 20 20 20 20  Coll[n];..      
3680: 2a 70 6c 65 6e 20 3d 20 73 74 72 6c 65 6e 28 2a  *plen = strlen(*
3690: 70 7a 43 6f 6c 6c 29 3b 0d 0a 20 20 20 20 20 20  pzColl);..      
36a0: 2a 6f 6e 45 72 72 6f 72 20 3d 20 70 49 64 78 2d  *onError = pIdx-
36b0: 3e 6f 6e 45 72 72 6f 72 3b 0d 0a 0d 0a 20 20 20  >onError;....   
36c0: 20 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45     return SQLITE
36d0: 5f 4f 4b 3b 0d 0a 20 20 20 20 7d 0d 0a 20 20 7d  _OK;..    }..  }
36e0: 0d 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54  ..  return SQLIT
36f0: 45 5f 45 52 52 4f 52 3b 0d 0a 7d 0d 0a 0d 0a 53  E_ERROR;..}....S
3700: 51 4c 49 54 45 5f 41 50 49 20 69 6e 74 20 57 49  QLITE_API int WI
3710: 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 74 61 62  NAPI sqlite3_tab
3720: 6c 65 5f 63 75 72 73 6f 72 28 73 71 6c 69 74 65  le_cursor(sqlite
3730: 33 5f 73 74 6d 74 20 2a 70 73 74 6d 74 2c 20 69  3_stmt *pstmt, i
3740: 6e 74 20 69 44 62 2c 20 50 67 6e 6f 20 74 61 62  nt iDb, Pgno tab
3750: 6c 65 52 6f 6f 74 50 61 67 65 29 0d 0a 7b 0d 0a  leRootPage)..{..
3760: 20 20 56 64 62 65 20 2a 70 20 3d 20 28 56 64 62    Vdbe *p = (Vdb
3770: 65 20 2a 29 70 73 74 6d 74 3b 0d 0a 20 20 73 71  e *)pstmt;..  sq
3780: 6c 69 74 65 33 20 2a 64 62 20 3d 20 28 70 20 3d  lite3 *db = (p =
3790: 3d 20 4e 55 4c 4c 29 20 3f 20 4e 55 4c 4c 20 3a  = NULL) ? NULL :
37a0: 20 70 2d 3e 64 62 3b 0d 0a 20 20 69 6e 74 20 6e   p->db;..  int n
37b0: 3b 0d 0a 20 20 69 6e 74 20 72 65 74 20 3d 20 2d  ;..  int ret = -
37c0: 31 3b 0d 0a 0d 0a 20 20 73 71 6c 69 74 65 33 5f  1;....  sqlite3_
37d0: 6d 75 74 65 78 5f 65 6e 74 65 72 28 64 62 2d 3e  mutex_enter(db->
37e0: 6d 75 74 65 78 29 3b 0d 0a 20 20 66 6f 72 20 28  mutex);..  for (
37f0: 6e 20 3d 20 30 3b 20 6e 20 3c 20 70 2d 3e 6e 43  n = 0; n < p->nC
3800: 75 72 73 6f 72 20 26 26 20 70 2d 3e 61 70 43 73  ursor && p->apCs
3810: 72 5b 6e 5d 20 21 3d 20 4e 55 4c 4c 3b 20 6e 2b  r[n] != NULL; n+
3820: 2b 29 0d 0a 20 20 7b 0d 0a 20 20 20 20 69 66 20  +)..  {..    if 
3830: 28 70 2d 3e 61 70 43 73 72 5b 6e 5d 2d 3e 69 73  (p->apCsr[n]->is
3840: 54 61 62 6c 65 20 3d 3d 20 46 41 4c 53 45 29 20  Table == FALSE) 
3850: 63 6f 6e 74 69 6e 75 65 3b 0d 0a 20 20 20 20 69  continue;..    i
3860: 66 20 28 70 2d 3e 61 70 43 73 72 5b 6e 5d 2d 3e  f (p->apCsr[n]->
3870: 69 44 62 20 21 3d 20 69 44 62 29 20 63 6f 6e 74  iDb != iDb) cont
3880: 69 6e 75 65 3b 0d 0a 20 20 20 20 69 66 20 28 70  inue;..    if (p
3890: 2d 3e 61 70 43 73 72 5b 6e 5d 2d 3e 70 43 75 72  ->apCsr[n]->pCur
38a0: 73 6f 72 2d 3e 70 67 6e 6f 52 6f 6f 74 20 3d 3d  sor->pgnoRoot ==
38b0: 20 74 61 62 6c 65 52 6f 6f 74 50 61 67 65 29 0d   tableRootPage).
38c0: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 72 65  .    {..      re
38d0: 74 20 3d 20 6e 3b 0d 0a 20 20 20 20 20 20 62 72  t = n;..      br
38e0: 65 61 6b 3b 0d 0a 20 20 20 20 7d 0d 0a 20 20 7d  eak;..    }..  }
38f0: 0d 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65  ..  sqlite3_mute
3900: 78 5f 6c 65 61 76 65 28 64 62 2d 3e 6d 75 74 65  x_leave(db->mute
3910: 78 29 3b 0d 0a 0d 0a 20 20 72 65 74 75 72 6e 20  x);....  return 
3920: 72 65 74 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54  ret;..}....SQLIT
3930: 45 5f 41 50 49 20 69 6e 74 20 57 49 4e 41 50 49  E_API int WINAPI
3940: 20 73 71 6c 69 74 65 33 5f 63 75 72 73 6f 72 5f   sqlite3_cursor_
3950: 72 6f 77 69 64 28 73 71 6c 69 74 65 33 5f 73 74  rowid(sqlite3_st
3960: 6d 74 20 2a 70 73 74 6d 74 2c 20 69 6e 74 20 63  mt *pstmt, int c
3970: 75 72 73 6f 72 2c 20 73 71 6c 69 74 65 5f 69 6e  ursor, sqlite_in
3980: 74 36 34 20 2a 70 72 6f 77 69 64 29 0d 0a 7b 0d  t64 *prowid)..{.
3990: 0a 20 20 56 64 62 65 20 2a 70 20 3d 20 28 56 64  .  Vdbe *p = (Vd
39a0: 62 65 20 2a 29 70 73 74 6d 74 3b 0d 0a 20 20 73  be *)pstmt;..  s
39b0: 71 6c 69 74 65 33 20 2a 64 62 20 3d 20 28 70 20  qlite3 *db = (p 
39c0: 3d 3d 20 4e 55 4c 4c 29 20 3f 20 4e 55 4c 4c 20  == NULL) ? NULL 
39d0: 3a 20 70 2d 3e 64 62 3b 0d 0a 20 20 56 64 62 65  : p->db;..  Vdbe
39e0: 43 75 72 73 6f 72 20 2a 70 43 3b 0d 0a 20 20 69  Cursor *pC;..  i
39f0: 6e 74 20 72 65 74 20 3d 20 30 3b 0d 0a 0d 0a 20  nt ret = 0;.... 
3a00: 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65   sqlite3_mutex_e
3a10: 6e 74 65 72 28 64 62 2d 3e 6d 75 74 65 78 29 3b  nter(db->mutex);
3a20: 0d 0a 20 20 77 68 69 6c 65 20 28 31 29 0d 0a 20  ..  while (1).. 
3a30: 20 7b 0d 0a 20 20 20 20 69 66 20 28 63 75 72 73   {..    if (curs
3a40: 6f 72 20 3c 20 30 20 7c 7c 20 63 75 72 73 6f 72  or < 0 || cursor
3a50: 20 3e 3d 20 70 2d 3e 6e 43 75 72 73 6f 72 29 0d   >= p->nCursor).
3a60: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 72 65  .    {..      re
3a70: 74 20 3d 20 53 51 4c 49 54 45 5f 45 52 52 4f 52  t = SQLITE_ERROR
3a80: 3b 0d 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0d  ;..      break;.
3a90: 0a 20 20 20 20 7d 0d 0a 20 20 20 20 69 66 20 28  .    }..    if (
3aa0: 70 2d 3e 61 70 43 73 72 5b 63 75 72 73 6f 72 5d  p->apCsr[cursor]
3ab0: 20 3d 3d 20 4e 55 4c 4c 29 0d 0a 20 20 20 20 7b   == NULL)..    {
3ac0: 0d 0a 20 20 20 20 20 20 72 65 74 20 3d 20 53 51  ..      ret = SQ
3ad0: 4c 49 54 45 5f 45 52 52 4f 52 3b 0d 0a 20 20 20  LITE_ERROR;..   
3ae0: 20 20 20 62 72 65 61 6b 3b 0d 0a 20 20 20 20 7d     break;..    }
3af0: 0d 0a 0d 0a 20 20 20 20 70 43 20 3d 20 70 2d 3e  ....    pC = p->
3b00: 61 70 43 73 72 5b 63 75 72 73 6f 72 5d 3b 0d 0a  apCsr[cursor];..
3b10: 0d 0a 20 20 20 20 72 65 74 20 3d 20 73 71 6c 69  ..    ret = sqli
3b20: 74 65 33 56 64 62 65 43 75 72 73 6f 72 4d 6f 76  te3VdbeCursorMov
3b30: 65 74 6f 28 70 43 29 3b 0d 0a 20 20 20 20 69 66  eto(pC);..    if
3b40: 28 72 65 74 29 0d 0a 20 20 20 20 20 20 62 72 65  (ret)..      bre
3b50: 61 6b 3b 0d 0a 0d 0a 20 20 20 20 69 66 28 70 43  ak;....    if(pC
3b60: 2d 3e 72 6f 77 69 64 49 73 56 61 6c 69 64 29 0d  ->rowidIsValid).
3b70: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 2a 70  .    {..      *p
3b80: 72 6f 77 69 64 20 3d 20 70 43 2d 3e 6c 61 73 74  rowid = pC->last
3b90: 52 6f 77 69 64 3b 0d 0a 20 20 20 20 7d 0d 0a 20  Rowid;..    }.. 
3ba0: 20 20 20 65 6c 73 65 20 69 66 28 70 43 2d 3e 70     else if(pC->p
3bb0: 73 65 75 64 6f 54 61 62 6c 65 52 65 67 20 3e 20  seudoTableReg > 
3bc0: 30 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20  0)..    {..     
3bd0: 20 72 65 74 20 3d 20 53 51 4c 49 54 45 5f 45 52   ret = SQLITE_ER
3be0: 52 4f 52 3b 0d 0a 20 20 20 20 20 20 62 72 65 61  ROR;..      brea
3bf0: 6b 3b 0d 0a 20 20 20 20 7d 0d 0a 20 20 20 20 65  k;..    }..    e
3c00: 6c 73 65 20 69 66 28 70 43 2d 3e 6e 75 6c 6c 52  lse if(pC->nullR
3c10: 6f 77 20 7c 7c 20 70 43 2d 3e 70 43 75 72 73 6f  ow || pC->pCurso
3c20: 72 3d 3d 30 29 0d 0a 20 20 20 20 7b 0d 0a 20 20  r==0)..    {..  
3c30: 20 20 20 20 72 65 74 20 3d 20 53 51 4c 49 54 45      ret = SQLITE
3c40: 5f 45 52 52 4f 52 3b 0d 0a 20 20 20 20 20 20 62  _ERROR;..      b
3c50: 72 65 61 6b 3b 0d 0a 20 20 20 20 7d 0d 0a 20 20  reak;..    }..  
3c60: 20 20 65 6c 73 65 0d 0a 20 20 20 20 7b 0d 0a 20    else..    {.. 
3c70: 20 20 20 20 20 69 66 20 28 70 43 2d 3e 70 43 75       if (pC->pCu
3c80: 72 73 6f 72 20 3d 3d 20 4e 55 4c 4c 29 0d 0a 20  rsor == NULL).. 
3c90: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
3ca0: 72 65 74 20 3d 20 53 51 4c 49 54 45 5f 45 52 52  ret = SQLITE_ERR
3cb0: 4f 52 3b 0d 0a 20 20 20 20 20 20 20 20 62 72 65  OR;..        bre
3cc0: 61 6b 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a 20 20  ak;..      }..  
3cd0: 20 20 20 20 73 71 6c 69 74 65 33 42 74 72 65 65      sqlite3Btree
3ce0: 4b 65 79 53 69 7a 65 28 70 43 2d 3e 70 43 75 72  KeySize(pC->pCur
3cf0: 73 6f 72 2c 20 70 72 6f 77 69 64 29 3b 0d 0a 20  sor, prowid);.. 
3d00: 20 20 20 20 20 2a 70 72 6f 77 69 64 20 3d 20 2a       *prowid = *
3d10: 70 72 6f 77 69 64 3b 0d 0a 20 20 20 20 7d 0d 0a  prowid;..    }..
3d20: 20 20 20 20 62 72 65 61 6b 3b 0d 0a 20 20 7d 0d      break;..  }.
3d30: 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78  .  sqlite3_mutex
3d40: 5f 6c 65 61 76 65 28 64 62 2d 3e 6d 75 74 65 78  _leave(db->mutex
3d50: 29 3b 0d 0a 0d 0a 20 20 72 65 74 75 72 6e 20 72  );....  return r
3d60: 65 74 3b 0d 0a 7d 0d 0a 0d 0a 23 65 6e 64 69 66  et;..}....#endif
3d70: 20 2f 2f 20 53 51 4c 49 54 45 5f 4f 53 5f 57 49   // SQLITE_OS_WI
3d80: 4e 0d 0a                                         N..