System.Data.SQLite
Hex Artifact Content
Not logged in

Artifact 66f068a97a586a485555027aa8aa5f30a1fcafca:


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 23 69 6e 63 6c 75  lexport)..#inclu
0030: 64 65 20 22 2e 2e 2f 63 6f 72 65 2f 73 71 6c 69  de "../core/sqli
0040: 74 65 33 2e 63 22 0d 0a 0d 0a 23 69 66 20 64 65  te3.c"....#if de
0050: 66 69 6e 65 64 28 49 4e 54 45 52 4f 50 5f 45 58  fined(INTEROP_EX
0060: 54 45 4e 53 49 4f 4e 5f 46 55 4e 43 54 49 4f 4e  TENSION_FUNCTION
0070: 53 29 0d 0a 23 69 6e 63 6c 75 64 65 20 22 2e 2e  S)..#include "..
0080: 2f 63 6f 6e 74 72 69 62 2f 65 78 74 65 6e 73 69  /contrib/extensi
0090: 6f 6e 2d 66 75 6e 63 74 69 6f 6e 73 2e 63 22 0d  on-functions.c".
00a0: 0a 65 78 74 65 72 6e 20 69 6e 74 20 52 65 67 69  .extern int Regi
00b0: 73 74 65 72 45 78 74 65 6e 73 69 6f 6e 46 75 6e  sterExtensionFun
00c0: 63 74 69 6f 6e 73 28 73 71 6c 69 74 65 33 20 2a  ctions(sqlite3 *
00d0: 64 62 29 3b 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a  db);..#endif....
00e0: 23 69 66 20 64 65 66 69 6e 65 64 28 49 4e 54 45  #if defined(INTE
00f0: 52 4f 50 5f 43 4f 44 45 43 29 0d 0a 23 69 6e 63  ROP_CODEC)..#inc
0100: 6c 75 64 65 20 22 63 72 79 70 74 2e 63 22 0d 0a  lude "crypt.c"..
0110: 23 65 6e 64 69 66 0d 0a 0d 0a 23 69 66 64 65 66  #endif....#ifdef
0120: 20 53 51 4c 49 54 45 5f 4f 53 5f 57 49 4e 0d 0a   SQLITE_OS_WIN..
0130: 0d 0a 2f 2f 20 41 64 64 69 74 69 6f 6e 61 6c 20  ..// Additional 
0140: 6f 70 65 6e 20 66 6c 61 67 73 2c 20 77 65 20 75  open flags, we u
0150: 73 65 20 74 68 69 73 20 6f 6e 65 20 70 72 69 76  se this one priv
0160: 61 74 65 6c 79 0d 0a 2f 2f 23 64 65 66 69 6e 65  ately..//#define
0170: 20 53 51 4c 49 54 45 5f 4f 50 45 4e 5f 53 48 41   SQLITE_OPEN_SHA
0180: 52 45 44 43 41 43 48 45 20 20 20 20 20 20 30 78  REDCACHE      0x
0190: 30 31 30 30 30 30 30 30 0d 0a 0d 0a 74 79 70 65  01000000....type
01a0: 64 65 66 20 76 6f 69 64 20 28 2a 53 51 4c 49 54  def void (*SQLIT
01b0: 45 55 53 45 52 46 55 4e 43 29 28 73 71 6c 69 74  EUSERFUNC)(sqlit
01c0: 65 33 5f 63 6f 6e 74 65 78 74 20 2a 2c 20 69 6e  e3_context *, in
01d0: 74 2c 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65  t, sqlite3_value
01e0: 20 2a 2a 29 3b 0d 0a 74 79 70 65 64 65 66 20 76   **);..typedef v
01f0: 6f 69 64 20 28 2a 53 51 4c 49 54 45 46 55 4e 43  oid (*SQLITEFUNC
0200: 46 49 4e 41 4c 29 28 73 71 6c 69 74 65 33 5f 63  FINAL)(sqlite3_c
0210: 6f 6e 74 65 78 74 20 2a 29 3b 0d 0a 0d 0a 53 51  ontext *);....SQ
0220: 4c 49 54 45 5f 50 52 49 56 41 54 45 20 76 6f 69  LITE_PRIVATE voi
0230: 64 20 2a 20 73 71 6c 69 74 65 33 44 62 4d 61 6c  d * sqlite3DbMal
0240: 6c 6f 63 5a 65 72 6f 5f 69 6e 74 65 72 6f 70 28  locZero_interop(
0250: 73 71 6c 69 74 65 33 20 2a 64 62 2c 20 69 6e 74  sqlite3 *db, int
0260: 20 6e 29 0d 0a 7b 0d 0a 20 20 76 6f 69 64 20 2a   n)..{..  void *
0270: 70 3b 0d 0a 20 20 69 66 20 28 64 62 29 20 7b 0d  p;..  if (db) {.
0280: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 6d 75 74  .    sqlite3_mut
0290: 65 78 5f 65 6e 74 65 72 28 64 62 2d 3e 6d 75 74  ex_enter(db->mut
02a0: 65 78 29 3b 0d 0a 20 20 7d 0d 0a 20 20 70 20 3d  ex);..  }..  p =
02b0: 20 73 71 6c 69 74 65 33 44 62 4d 61 6c 6c 6f 63   sqlite3DbMalloc
02c0: 5a 65 72 6f 28 64 62 2c 6e 29 3b 0d 0a 20 20 69  Zero(db,n);..  i
02d0: 66 20 28 64 62 29 20 7b 0d 0a 20 20 20 20 73 71  f (db) {..    sq
02e0: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76  lite3_mutex_leav
02f0: 65 28 64 62 2d 3e 6d 75 74 65 78 29 3b 0d 0a 20  e(db->mutex);.. 
0300: 20 7d 0d 0a 20 20 72 65 74 75 72 6e 20 70 3b 0d   }..  return p;.
0310: 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 50 52 49  .}....SQLITE_PRI
0320: 56 41 54 45 20 76 6f 69 64 20 73 71 6c 69 74 65  VATE void sqlite
0330: 33 44 62 46 72 65 65 5f 69 6e 74 65 72 6f 70 28  3DbFree_interop(
0340: 73 71 6c 69 74 65 33 20 2a 64 62 2c 20 76 6f 69  sqlite3 *db, voi
0350: 64 20 2a 70 29 0d 0a 7b 0d 0a 20 20 69 66 20 28  d *p)..{..  if (
0360: 64 62 29 20 7b 0d 0a 20 20 20 20 73 71 6c 69 74  db) {..    sqlit
0370: 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28 64  e3_mutex_enter(d
0380: 62 2d 3e 6d 75 74 65 78 29 3b 0d 0a 20 20 7d 0d  b->mutex);..  }.
0390: 0a 20 20 69 66 20 28 70 29 20 7b 0d 0a 20 20 20  .  if (p) {..   
03a0: 20 73 71 6c 69 74 65 33 4d 65 6d 64 65 62 75 67   sqlite3Memdebug
03b0: 53 65 74 54 79 70 65 28 70 2c 20 4d 45 4d 54 59  SetType(p, MEMTY
03c0: 50 45 5f 44 42 7c 4d 45 4d 54 59 50 45 5f 48 45  PE_DB|MEMTYPE_HE
03d0: 41 50 29 3b 0d 0a 20 20 7d 0d 0a 20 20 73 71 6c  AP);..  }..  sql
03e0: 69 74 65 33 44 62 46 72 65 65 28 64 62 2c 70 29  ite3DbFree(db,p)
03f0: 3b 0d 0a 20 20 69 66 20 28 64 62 29 20 7b 0d 0a  ;..  if (db) {..
0400: 20 20 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65      sqlite3_mute
0410: 78 5f 6c 65 61 76 65 28 64 62 2d 3e 6d 75 74 65  x_leave(db->mute
0420: 78 29 3b 0d 0a 20 20 7d 0d 0a 7d 0d 0a 0d 0a 2f  x);..  }..}..../
0430: 2a 0d 0a 20 20 20 20 54 68 65 20 67 6f 61 6c 20  *..    The goal 
0440: 6f 66 20 74 68 69 73 20 76 65 72 73 69 6f 6e 20  of this version 
0450: 6f 66 20 63 6c 6f 73 65 20 69 73 20 64 69 66 66  of close is diff
0460: 65 72 65 6e 74 20 74 68 61 6e 20 74 68 61 74 20  erent than that 
0470: 6f 66 20 73 71 6c 69 74 65 33 5f 63 6c 6f 73 65  of sqlite3_close
0480: 28 29 2c 20 61 6e 64 20 69 73 20 64 65 73 69 67  (), and is desig
0490: 6e 65 64 20 74 6f 20 6c 65 6e 64 20 69 74 73 65  ned to lend itse
04a0: 6c 66 20 62 65 74 74 65 72 20 74 6f 20 2e 4e 45  lf better to .NE
04b0: 54 27 73 20 6e 6f 6e 2d 64 65 74 65 72 6d 69 6e  T's non-determin
04c0: 69 73 74 69 63 20 66 69 6e 61 6c 69 7a 65 72 73  istic finalizers
04d0: 20 61 6e 64 0d 0a 20 20 20 20 74 68 65 20 47 43   and..    the GC
04e0: 20 74 68 72 65 61 64 2e 20 20 53 51 4c 69 74 65   thread.  SQLite
04f0: 20 77 69 6c 6c 20 6e 6f 74 20 63 6c 6f 73 65 20   will not close 
0500: 61 20 64 61 74 61 62 61 73 65 20 69 66 20 73 74  a database if st
0510: 61 74 65 6d 65 6e 74 73 20 61 72 65 20 6f 70 65  atements are ope
0520: 6e 20 6f 6e 20 69 74 20 2d 2d 20 62 75 74 20 66  n on it -- but f
0530: 6f 72 20 6f 75 72 20 70 75 72 70 6f 73 65 73 2c  or our purposes,
0540: 20 77 65 27 64 20 72 61 74 68 65 72 20 66 69 6e   we'd rather fin
0550: 61 6c 69 7a 65 20 61 6c 6c 20 61 63 74 69 76 65  alize all active
0560: 20 73 74 61 74 65 6d 65 6e 74 73 0d 0a 20 20 20   statements..   
0570: 20 61 6e 64 20 66 6f 72 63 69 62 6c 79 20 63 6c   and forcibly cl
0580: 6f 73 65 20 74 68 65 20 64 61 74 61 62 61 73 65  ose the database
0590: 2e 20 20 54 68 65 20 72 65 61 73 6f 6e 20 69 73  .  The reason is
05a0: 20 73 69 6d 70 6c 65 20 2d 2d 20 61 20 6c 6f 74   simple -- a lot
05b0: 20 6f 66 20 70 65 6f 70 6c 65 20 64 6f 6e 27 74   of people don't
05c0: 20 44 69 73 70 6f 73 65 28 29 20 6f 66 20 74 68   Dispose() of th
05d0: 65 69 72 20 6f 62 6a 65 63 74 73 20 63 6f 72 72  eir objects corr
05e0: 65 63 74 6c 79 20 61 6e 64 20 6c 65 74 20 74 68  ectly and let th
05f0: 65 20 67 61 72 62 61 67 65 20 63 6f 6c 6c 65 63  e garbage collec
0600: 74 6f 72 0d 0a 20 20 20 20 64 6f 20 69 74 2e 20  tor..    do it. 
0610: 20 54 68 69 73 20 6c 65 61 64 73 20 74 6f 20 75   This leads to u
0620: 6e 65 78 70 65 63 74 65 64 20 62 65 68 61 76 69  nexpected behavi
0630: 6f 72 20 77 68 65 6e 20 61 20 75 73 65 72 20 74  or when a user t
0640: 68 69 6e 6b 73 20 74 68 65 79 27 76 65 20 63 6c  hinks they've cl
0650: 6f 73 65 64 20 61 20 64 61 74 61 62 61 73 65 2c  osed a database,
0660: 20 62 75 74 20 69 74 27 73 20 73 74 69 6c 6c 20   but it's still 
0670: 6f 70 65 6e 20 62 65 63 61 75 73 65 20 6e 6f 74  open because not
0680: 20 61 6c 6c 20 74 68 65 20 73 74 61 74 65 6d 65   all the stateme
0690: 6e 74 73 20 68 61 76 65 0d 0a 20 20 20 20 68 69  nts have..    hi
06a0: 74 20 74 68 65 20 47 43 20 79 65 74 2e 0d 0a 0d  t the GC yet....
06b0: 0a 20 20 20 20 53 6f 2c 20 68 65 72 65 20 77 65  .    So, here we
06c0: 20 68 61 76 65 20 61 20 70 72 6f 62 6c 65 6d 20   have a problem 
06d0: 2e 2e 2e 20 2e 4e 45 54 20 68 61 73 20 61 20 70  ... .NET has a p
06e0: 6f 69 6e 74 65 72 20 74 6f 20 61 6e 79 20 6e 75  ointer to any nu
06f0: 6d 62 65 72 20 6f 66 20 73 71 6c 69 74 65 33 5f  mber of sqlite3_
0700: 73 74 6d 74 20 6f 62 6a 65 63 74 73 2e 20 20 57  stmt objects.  W
0710: 65 20 63 61 6e 27 74 20 63 61 6c 6c 20 73 71 6c  e can't call sql
0720: 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 29 20  ite3_finalize() 
0730: 6f 6e 20 74 68 65 73 65 20 62 65 63 61 75 73 65  on these because
0740: 0d 0a 20 20 20 20 74 68 65 69 72 20 6d 65 6d 6f  ..    their memo
0750: 72 79 20 69 73 20 66 72 65 65 64 20 61 6e 64 20  ry is freed and 
0760: 63 61 6e 20 62 65 20 75 73 65 64 20 66 6f 72 20  can be used for 
0770: 73 6f 6d 65 74 68 69 6e 67 20 65 6c 73 65 2e 20  something else. 
0780: 20 54 68 65 20 47 43 20 74 68 72 65 61 64 20 63   The GC thread c
0790: 6f 75 6c 64 20 70 6f 74 65 6e 74 69 61 6c 6c 79  ould potentially
07a0: 20 74 72 79 20 61 6e 64 20 63 61 6c 6c 20 66 69   try and call fi
07b0: 6e 61 6c 69 7a 65 20 61 67 61 69 6e 20 6f 6e 20  nalize again on 
07c0: 74 68 65 20 73 74 61 74 65 6d 65 6e 74 20 61 66  the statement af
07d0: 74 65 72 0d 0a 20 20 20 20 74 68 61 74 20 6d 65  ter..    that me
07e0: 6d 6f 72 79 20 77 61 73 20 64 65 61 6c 6c 6f 63  mory was dealloc
07f0: 61 74 65 64 2e 20 20 42 41 44 2e 20 20 53 6f 2c  ated.  BAD.  So,
0800: 20 77 68 61 74 20 77 65 20 6e 65 65 64 20 74 6f   what we need to
0810: 20 64 6f 20 69 73 20 6d 61 6b 65 20 61 20 63 6f   do is make a co
0820: 70 79 20 6f 66 20 65 61 63 68 20 73 74 61 74 65  py of each state
0830: 6d 65 6e 74 2c 20 61 6e 64 20 63 61 6c 6c 20 66  ment, and call f
0840: 69 6e 61 6c 69 7a 65 28 29 20 6f 6e 20 74 68 65  inalize() on the
0850: 20 63 6f 70 79 20 2d 2d 20 73 6f 20 74 68 61 74   copy -- so that
0860: 20 74 68 65 20 6f 72 69 67 69 6e 61 6c 0d 0a 20   the original.. 
0870: 20 20 20 73 74 61 74 65 6d 65 6e 74 27 73 20 6d     statement's m
0880: 65 6d 6f 72 79 20 69 73 20 70 72 65 73 65 72 76  emory is preserv
0890: 65 64 2c 20 61 6e 64 20 6d 61 72 6b 65 64 20 61  ed, and marked a
08a0: 73 20 42 41 44 2c 20 62 75 74 20 77 65 20 63 61  s BAD, but we ca
08b0: 6e 20 73 74 69 6c 6c 20 6d 61 6e 61 67 65 20 74  n still manage t
08c0: 6f 20 66 69 6e 61 6c 69 7a 65 20 65 76 65 72 79  o finalize every
08d0: 74 68 69 6e 67 20 61 6e 64 20 66 6f 72 63 69 62  thing and forcib
08e0: 6c 79 20 63 6c 6f 73 65 20 74 68 65 20 64 61 74  ly close the dat
08f0: 61 62 61 73 65 2e 20 20 4c 61 74 65 72 20 77 68  abase.  Later wh
0900: 65 6e 20 74 68 65 20 0d 0a 20 20 20 20 47 43 20  en the ..    GC 
0910: 67 65 74 73 20 61 72 6f 75 6e 64 20 74 6f 20 63  gets around to c
0920: 61 6c 6c 69 6e 67 20 66 69 6e 61 6c 69 7a 65 5f  alling finalize_
0930: 69 6e 74 65 72 6f 70 28 29 20 6f 6e 20 74 68 65  interop() on the
0940: 20 22 62 61 64 22 20 73 74 61 74 65 6d 65 6e 74   "bad" statement
0950: 2c 20 77 65 20 64 65 74 65 63 74 20 74 68 61 74  , we detect that
0960: 20 61 6e 64 20 66 69 6e 69 73 68 20 64 65 61 6c   and finish deal
0970: 6c 6f 63 61 74 69 6e 67 20 74 68 65 20 70 6f 69  locating the poi
0980: 6e 74 65 72 2e 0d 0a 2a 2f 0d 0a 53 51 4c 49 54  nter...*/..SQLIT
0990: 45 5f 41 50 49 20 69 6e 74 20 57 49 4e 41 50 49  E_API int WINAPI
09a0: 20 73 71 6c 69 74 65 33 5f 63 6c 6f 73 65 5f 69   sqlite3_close_i
09b0: 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33 20 2a  nterop(sqlite3 *
09c0: 64 62 29 0d 0a 7b 0d 0a 20 20 69 6e 74 20 72 65  db)..{..  int re
09d0: 74 3b 0d 0a 20 20 0d 0a 23 69 66 20 53 51 4c 49  t;..  ..#if SQLI
09e0: 54 45 5f 56 45 52 53 49 4f 4e 5f 4e 55 4d 42 45  TE_VERSION_NUMBE
09f0: 52 20 3e 3d 20 33 30 30 37 30 31 34 0d 0a 20 20  R >= 3007014..  
0a00: 72 65 74 20 3d 20 73 71 6c 69 74 65 33 5f 63 6c  ret = sqlite3_cl
0a10: 6f 73 65 5f 76 32 28 64 62 29 3b 0d 0a 23 65 6c  ose_v2(db);..#el
0a20: 73 65 0d 0a 20 20 72 65 74 20 3d 20 73 71 6c 69  se..  ret = sqli
0a30: 74 65 33 5f 63 6c 6f 73 65 28 64 62 29 3b 0d 0a  te3_close(db);..
0a40: 0d 0a 20 20 69 66 20 28 72 65 74 20 3d 3d 20 53  ..  if (ret == S
0a50: 51 4c 49 54 45 5f 42 55 53 59 29 0d 0a 20 20 7b  QLITE_BUSY)..  {
0a60: 0d 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 6d 75  ..    sqlite3_mu
0a70: 74 65 78 5f 65 6e 74 65 72 28 64 62 2d 3e 6d 75  tex_enter(db->mu
0a80: 74 65 78 29 3b 0d 0a 0d 0a 20 20 20 20 69 66 20  tex);....    if 
0a90: 28 21 64 62 2d 3e 70 56 64 62 65 29 0d 0a 20 20  (!db->pVdbe)..  
0aa0: 20 20 7b 0d 0a 20 20 20 20 20 20 73 71 6c 69 74    {..      sqlit
0ab0: 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 64  e3_mutex_leave(d
0ac0: 62 2d 3e 6d 75 74 65 78 29 3b 0d 0a 20 20 20 20  b->mutex);..    
0ad0: 20 20 72 65 74 75 72 6e 20 72 65 74 3b 0d 0a 20    return ret;.. 
0ae0: 20 20 20 7d 0d 0a 0d 0a 20 20 20 20 77 68 69 6c     }....    whil
0af0: 65 20 28 64 62 2d 3e 70 56 64 62 65 29 0d 0a 20  e (db->pVdbe).. 
0b00: 20 20 20 7b 0d 0a 20 20 20 20 20 20 2f 2f 20 4d     {..      // M
0b10: 61 6b 65 20 61 20 63 6f 70 79 20 6f 66 20 74 68  ake a copy of th
0b20: 65 20 66 69 72 73 74 20 70 72 65 70 61 72 65 64  e first prepared
0b30: 20 73 74 61 74 65 6d 65 6e 74 0d 0a 20 20 20 20   statement..    
0b40: 20 20 56 64 62 65 20 2a 70 20 3d 20 28 56 64 62    Vdbe *p = (Vdb
0b50: 65 20 2a 29 73 71 6c 69 74 65 33 44 62 4d 61 6c  e *)sqlite3DbMal
0b60: 6c 6f 63 5a 65 72 6f 5f 69 6e 74 65 72 6f 70 28  locZero_interop(
0b70: 64 62 2c 20 73 69 7a 65 6f 66 28 56 64 62 65 29  db, sizeof(Vdbe)
0b80: 29 3b 0d 0a 20 20 20 20 20 20 56 64 62 65 20 2a  );..      Vdbe *
0b90: 70 6f 20 3d 20 64 62 2d 3e 70 56 64 62 65 3b 0d  po = db->pVdbe;.
0ba0: 0a 0d 0a 20 20 20 20 20 20 69 66 20 28 21 70 29  ...      if (!p)
0bb0: 20 0d 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20   ..      {..    
0bc0: 20 20 20 20 72 65 74 20 3d 20 53 51 4c 49 54 45      ret = SQLITE
0bd0: 5f 4e 4f 4d 45 4d 3b 0d 0a 20 20 20 20 20 20 20  _NOMEM;..       
0be0: 20 62 72 65 61 6b 3b 0d 0a 20 20 20 20 20 20 7d   break;..      }
0bf0: 0d 0a 0d 0a 20 20 20 20 20 20 43 6f 70 79 4d 65  ....      CopyMe
0c00: 6d 6f 72 79 28 70 2c 20 70 6f 2c 20 73 69 7a 65  mory(p, po, size
0c10: 6f 66 28 56 64 62 65 29 29 3b 0d 0a 0d 0a 20 20  of(Vdbe));....  
0c20: 20 20 20 20 2f 2f 20 50 75 74 20 69 74 20 6f 6e      // Put it on
0c30: 20 74 68 65 20 63 68 61 69 6e 20 73 6f 20 77 65   the chain so we
0c40: 20 63 61 6e 20 66 72 65 65 20 69 74 0d 0a 20 20   can free it..  
0c50: 20 20 20 20 64 62 2d 3e 70 56 64 62 65 20 3d 20      db->pVdbe = 
0c60: 70 3b 0d 0a 20 20 20 20 20 20 72 65 74 20 3d 20  p;..      ret = 
0c70: 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65  sqlite3_finalize
0c80: 28 28 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a  ((sqlite3_stmt *
0c90: 29 70 29 3b 20 2f 2f 20 54 68 69 73 20 77 69 6c  )p); // This wil
0ca0: 6c 20 61 6c 73 6f 20 66 72 65 65 20 74 68 65 20  l also free the 
0cb0: 63 6f 70 79 27 73 20 6d 65 6d 6f 72 79 0d 0a 20  copy's memory.. 
0cc0: 20 20 20 20 20 69 66 20 28 72 65 74 29 0d 0a 20       if (ret).. 
0cd0: 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 20 20       {..        
0ce0: 2f 2f 20 66 69 6e 61 6c 69 7a 65 20 66 61 69 6c  // finalize fail
0cf0: 65 64 20 2d 2d 20 73 6f 20 77 65 20 6d 75 73 74  ed -- so we must
0d00: 20 70 75 74 20 62 61 63 6b 20 61 6e 79 74 68 69   put back anythi
0d10: 6e 67 20 77 65 20 6d 75 6e 67 65 64 0d 0a 20 20  ng we munged..  
0d20: 20 20 20 20 20 20 43 6f 70 79 4d 65 6d 6f 72 79        CopyMemory
0d30: 28 70 6f 2c 20 70 2c 20 73 69 7a 65 6f 66 28 56  (po, p, sizeof(V
0d40: 64 62 65 29 29 3b 0d 0a 20 20 20 20 20 20 20 20  dbe));..        
0d50: 64 62 2d 3e 70 56 64 62 65 20 3d 20 70 6f 3b 0d  db->pVdbe = po;.
0d60: 0a 0d 0a 20 20 20 20 20 20 20 20 2f 2f 0d 0a 20  ...        //.. 
0d70: 20 20 20 20 20 20 20 2f 2f 20 4e 4f 54 45 3a 20         // NOTE: 
0d80: 4f 6b 2c 20 77 65 20 6d 75 73 74 20 66 72 65 65  Ok, we must free
0d90: 20 74 68 69 73 20 62 6c 6f 63 6b 20 74 68 61 74   this block that
0da0: 20 2a 77 65 2a 20 61 6c 6c 6f 63 61 74 65 64 20   *we* allocated 
0db0: 28 61 62 6f 76 65 29 20 73 69 6e 63 65 0d 0a 20  (above) since.. 
0dc0: 20 20 20 20 20 20 20 2f 2f 20 20 20 20 20 20 20         //       
0dd0: 66 69 6e 61 6c 69 7a 65 20 64 69 64 20 6e 6f 74  finalize did not
0de0: 20 64 6f 20 73 6f 2e 0d 0a 20 20 20 20 20 20 20   do so...       
0df0: 20 2f 2f 0d 0a 20 20 20 20 20 20 20 20 73 71 6c   //..        sql
0e00: 69 74 65 33 44 62 46 72 65 65 5f 69 6e 74 65 72  ite3DbFree_inter
0e10: 6f 70 28 64 62 2c 20 70 29 3b 0d 0a 20 20 20 20  op(db, p);..    
0e20: 20 20 20 20 62 72 65 61 6b 3b 0d 0a 20 20 20 20      break;..    
0e30: 20 20 7d 0d 0a 20 20 20 20 20 20 65 6c 73 65 0d    }..      else.
0e40: 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  .      {..      
0e50: 20 20 5a 65 72 6f 4d 65 6d 6f 72 79 28 70 6f 2c    ZeroMemory(po,
0e60: 20 73 69 7a 65 6f 66 28 56 64 62 65 29 29 3b 0d   sizeof(Vdbe));.
0e70: 0a 20 20 20 20 20 20 20 20 70 6f 2d 3e 6d 61 67  .        po->mag
0e80: 69 63 20 3d 20 56 44 42 45 5f 4d 41 47 49 43 5f  ic = VDBE_MAGIC_
0e90: 44 45 41 44 3b 0d 0a 20 20 20 20 20 20 7d 0d 0a  DEAD;..      }..
0ea0: 20 20 20 20 7d 0d 0a 20 20 20 20 73 71 6c 69 74      }..    sqlit
0eb0: 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 64  e3_mutex_leave(d
0ec0: 62 2d 3e 6d 75 74 65 78 29 3b 0d 0a 20 20 20 20  b->mutex);..    
0ed0: 72 65 74 20 3d 20 73 71 6c 69 74 65 33 5f 63 6c  ret = sqlite3_cl
0ee0: 6f 73 65 28 64 62 29 3b 0d 0a 20 20 7d 0d 0a 23  ose(db);..  }..#
0ef0: 65 6e 64 69 66 0d 0a 0d 0a 20 20 72 65 74 75 72  endif....  retur
0f00: 6e 20 72 65 74 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c  n ret;..}....SQL
0f10: 49 54 45 5f 41 50 49 20 69 6e 74 20 57 49 4e 41  ITE_API int WINA
0f20: 50 49 20 73 71 6c 69 74 65 33 5f 6f 70 65 6e 5f  PI sqlite3_open_
0f30: 69 6e 74 65 72 6f 70 28 63 6f 6e 73 74 20 63 68  interop(const ch
0f40: 61 72 2a 66 69 6c 65 6e 61 6d 65 2c 20 69 6e 74  ar*filename, int
0f50: 20 66 6c 61 67 73 2c 20 73 71 6c 69 74 65 33 20   flags, sqlite3 
0f60: 2a 2a 70 70 64 62 29 0d 0a 7b 0d 0a 20 20 69 6e  **ppdb)..{..  in
0f70: 74 20 72 65 74 3b 0d 0a 20 20 2f 2f 69 6e 74 20  t ret;..  //int 
0f80: 73 68 61 72 65 64 63 61 63 68 65 20 3d 20 28 28  sharedcache = ((
0f90: 66 6c 61 67 73 20 26 20 53 51 4c 49 54 45 5f 4f  flags & SQLITE_O
0fa0: 50 45 4e 5f 53 48 41 52 45 44 43 41 43 48 45 29  PEN_SHAREDCACHE)
0fb0: 20 21 3d 20 30 29 3b 0d 0a 20 20 2f 2f 66 6c 61   != 0);..  //fla
0fc0: 67 73 20 26 3d 20 7e 53 51 4c 49 54 45 5f 4f 50  gs &= ~SQLITE_OP
0fd0: 45 4e 5f 53 48 41 52 45 44 43 41 43 48 45 3b 0d  EN_SHAREDCACHE;.
0fe0: 0a 0d 0a 20 20 2f 2f 73 71 6c 69 74 65 33 5f 65  ...  //sqlite3_e
0ff0: 6e 61 62 6c 65 5f 73 68 61 72 65 64 5f 63 61 63  nable_shared_cac
1000: 68 65 28 73 68 61 72 65 64 63 61 63 68 65 29 3b  he(sharedcache);
1010: 0d 0a 20 20 72 65 74 20 3d 20 73 71 6c 69 74 65  ..  ret = sqlite
1020: 33 5f 6f 70 65 6e 5f 76 32 28 66 69 6c 65 6e 61  3_open_v2(filena
1030: 6d 65 2c 20 70 70 64 62 2c 20 66 6c 61 67 73 2c  me, ppdb, flags,
1040: 20 4e 55 4c 4c 29 3b 0d 0a 20 20 2f 2f 73 71 6c   NULL);..  //sql
1050: 69 74 65 33 5f 65 6e 61 62 6c 65 5f 73 68 61 72  ite3_enable_shar
1060: 65 64 5f 63 61 63 68 65 28 30 29 3b 0d 0a 0d 0a  ed_cache(0);....
1070: 23 69 66 20 64 65 66 69 6e 65 64 28 49 4e 54 45  #if defined(INTE
1080: 52 4f 50 5f 45 58 54 45 4e 53 49 4f 4e 5f 46 55  ROP_EXTENSION_FU
1090: 4e 43 54 49 4f 4e 53 29 0d 0a 20 20 69 66 20 28  NCTIONS)..  if (
10a0: 72 65 74 20 3d 3d 20 30 29 0d 0a 20 20 20 20 52  ret == 0)..    R
10b0: 65 67 69 73 74 65 72 45 78 74 65 6e 73 69 6f 6e  egisterExtension
10c0: 46 75 6e 63 74 69 6f 6e 73 28 2a 70 70 64 62 29  Functions(*ppdb)
10d0: 3b 0d 0a 23 65 6e 64 69 66 0d 0a 0d 0a 20 20 72  ;..#endif....  r
10e0: 65 74 75 72 6e 20 72 65 74 3b 0d 0a 7d 0d 0a 0d  eturn ret;..}...
10f0: 0a 53 51 4c 49 54 45 5f 41 50 49 20 69 6e 74 20  .SQLITE_API int 
1100: 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 6f  WINAPI sqlite3_o
1110: 70 65 6e 31 36 5f 69 6e 74 65 72 6f 70 28 63 6f  pen16_interop(co
1120: 6e 73 74 20 63 68 61 72 20 2a 66 69 6c 65 6e 61  nst char *filena
1130: 6d 65 2c 20 69 6e 74 20 66 6c 61 67 73 2c 20 73  me, int flags, s
1140: 71 6c 69 74 65 33 20 2a 2a 70 70 64 62 29 0d 0a  qlite3 **ppdb)..
1150: 7b 0d 0a 20 20 69 6e 74 20 72 65 74 20 3d 20 73  {..  int ret = s
1160: 71 6c 69 74 65 33 5f 6f 70 65 6e 5f 69 6e 74 65  qlite3_open_inte
1170: 72 6f 70 28 66 69 6c 65 6e 61 6d 65 2c 20 66 6c  rop(filename, fl
1180: 61 67 73 2c 20 70 70 64 62 29 3b 0d 0a 20 20 69  ags, ppdb);..  i
1190: 66 20 28 21 72 65 74 29 0d 0a 20 20 7b 0d 0a 20  f (!ret)..  {.. 
11a0: 20 20 20 69 66 28 21 44 62 48 61 73 50 72 6f 70     if(!DbHasProp
11b0: 65 72 74 79 28 2a 70 70 64 62 2c 20 30 2c 20 44  erty(*ppdb, 0, D
11c0: 42 5f 53 63 68 65 6d 61 4c 6f 61 64 65 64 29 29  B_SchemaLoaded))
11d0: 0d 0a 20 20 20 20 20 20 45 4e 43 28 2a 70 70 64  ..      ENC(*ppd
11e0: 62 29 20 3d 20 53 51 4c 49 54 45 5f 55 54 46 31  b) = SQLITE_UTF1
11f0: 36 4e 41 54 49 56 45 3b 0d 0a 20 20 7d 0d 0a 20  6NATIVE;..  }.. 
1200: 20 72 65 74 75 72 6e 20 72 65 74 3b 0d 0a 7d 0d   return ret;..}.
1210: 0a 0d 0a 53 51 4c 49 54 45 5f 41 50 49 20 63 6f  ...SQLITE_API co
1220: 6e 73 74 20 63 68 61 72 20 2a 20 57 49 4e 41 50  nst char * WINAP
1230: 49 20 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67  I sqlite3_errmsg
1240: 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33  _interop(sqlite3
1250: 20 2a 64 62 2c 20 69 6e 74 20 2a 70 6c 65 6e 29   *db, int *plen)
1260: 0d 0a 7b 0d 0a 20 20 63 6f 6e 73 74 20 63 68 61  ..{..  const cha
1270: 72 20 2a 70 76 61 6c 20 3d 20 73 71 6c 69 74 65  r *pval = sqlite
1280: 33 5f 65 72 72 6d 73 67 28 64 62 29 3b 0d 0a 20  3_errmsg(db);.. 
1290: 20 2a 70 6c 65 6e 20 3d 20 28 70 76 61 6c 20 21   *plen = (pval !
12a0: 3d 20 30 29 20 3f 20 73 74 72 6c 65 6e 28 70 76  = 0) ? strlen(pv
12b0: 61 6c 29 20 3a 20 30 3b 0d 0a 20 20 72 65 74 75  al) : 0;..  retu
12c0: 72 6e 20 70 76 61 6c 3b 0d 0a 7d 0d 0a 0d 0a 53  rn pval;..}....S
12d0: 51 4c 49 54 45 5f 41 50 49 20 69 6e 74 20 57 49  QLITE_API int WI
12e0: 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 70 72 65  NAPI sqlite3_pre
12f0: 70 61 72 65 5f 69 6e 74 65 72 6f 70 28 73 71 6c  pare_interop(sql
1300: 69 74 65 33 20 2a 64 62 2c 20 63 6f 6e 73 74 20  ite3 *db, const 
1310: 63 68 61 72 20 2a 73 71 6c 2c 20 69 6e 74 20 6e  char *sql, int n
1320: 62 79 74 65 73 2c 20 73 71 6c 69 74 65 33 5f 73  bytes, sqlite3_s
1330: 74 6d 74 20 2a 2a 70 70 73 74 6d 74 2c 20 63 6f  tmt **ppstmt, co
1340: 6e 73 74 20 63 68 61 72 20 2a 2a 70 7a 74 61 69  nst char **pztai
1350: 6c 2c 20 69 6e 74 20 2a 70 6c 65 6e 29 0d 0a 7b  l, int *plen)..{
1360: 0d 0a 20 20 69 6e 74 20 6e 3b 0d 0a 0d 0a 20 20  ..  int n;....  
1370: 6e 20 3d 20 73 71 6c 69 74 65 33 5f 70 72 65 70  n = sqlite3_prep
1380: 61 72 65 28 64 62 2c 20 73 71 6c 2c 20 6e 62 79  are(db, sql, nby
1390: 74 65 73 2c 20 70 70 73 74 6d 74 2c 20 70 7a 74  tes, ppstmt, pzt
13a0: 61 69 6c 29 3b 0d 0a 20 20 2a 70 6c 65 6e 20 3d  ail);..  *plen =
13b0: 20 28 2a 70 7a 74 61 69 6c 20 21 3d 20 30 29 20   (*pztail != 0) 
13c0: 3f 20 73 74 72 6c 65 6e 28 2a 70 7a 74 61 69 6c  ? strlen(*pztail
13d0: 29 20 3a 20 30 3b 0d 0a 0d 0a 20 20 72 65 74 75  ) : 0;....  retu
13e0: 72 6e 20 6e 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49  rn n;..}....SQLI
13f0: 54 45 5f 41 50 49 20 69 6e 74 20 57 49 4e 41 50  TE_API int WINAP
1400: 49 20 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72  I sqlite3_prepar
1410: 65 31 36 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69  e16_interop(sqli
1420: 74 65 33 20 2a 64 62 2c 20 63 6f 6e 73 74 20 76  te3 *db, const v
1430: 6f 69 64 20 2a 73 71 6c 2c 20 69 6e 74 20 6e 63  oid *sql, int nc
1440: 68 61 72 73 2c 20 73 71 6c 69 74 65 33 5f 73 74  hars, sqlite3_st
1450: 6d 74 20 2a 2a 70 70 73 74 6d 74 2c 20 63 6f 6e  mt **ppstmt, con
1460: 73 74 20 76 6f 69 64 20 2a 2a 70 7a 74 61 69 6c  st void **pztail
1470: 2c 20 69 6e 74 20 2a 70 6c 65 6e 29 0d 0a 7b 0d  , int *plen)..{.
1480: 0a 20 20 69 6e 74 20 6e 3b 0d 0a 0d 0a 20 20 6e  .  int n;....  n
1490: 20 3d 20 73 71 6c 69 74 65 33 5f 70 72 65 70 61   = sqlite3_prepa
14a0: 72 65 31 36 28 64 62 2c 20 73 71 6c 2c 20 6e 63  re16(db, sql, nc
14b0: 68 61 72 73 20 2a 20 73 69 7a 65 6f 66 28 77 63  hars * sizeof(wc
14c0: 68 61 72 5f 74 29 2c 20 70 70 73 74 6d 74 2c 20  har_t), ppstmt, 
14d0: 70 7a 74 61 69 6c 29 3b 0d 0a 20 20 2a 70 6c 65  pztail);..  *ple
14e0: 6e 20 3d 20 28 2a 70 7a 74 61 69 6c 20 21 3d 20  n = (*pztail != 
14f0: 30 29 20 3f 20 77 63 73 6c 65 6e 28 28 77 63 68  0) ? wcslen((wch
1500: 61 72 5f 74 20 2a 29 2a 70 7a 74 61 69 6c 29 20  ar_t *)*pztail) 
1510: 2a 20 73 69 7a 65 6f 66 28 77 63 68 61 72 5f 74  * sizeof(wchar_t
1520: 29 20 3a 20 30 3b 0d 0a 0d 0a 20 20 72 65 74 75  ) : 0;....  retu
1530: 72 6e 20 6e 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49  rn n;..}....SQLI
1540: 54 45 5f 41 50 49 20 69 6e 74 20 57 49 4e 41 50  TE_API int WINAP
1550: 49 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 64  I sqlite3_bind_d
1560: 6f 75 62 6c 65 5f 69 6e 74 65 72 6f 70 28 73 71  ouble_interop(sq
1570: 6c 69 74 65 33 5f 73 74 6d 74 20 2a 73 74 6d 74  lite3_stmt *stmt
1580: 2c 20 69 6e 74 20 69 43 6f 6c 2c 20 64 6f 75 62  , int iCol, doub
1590: 6c 65 20 2a 76 61 6c 29 0d 0a 7b 0d 0a 09 72 65  le *val)..{...re
15a0: 74 75 72 6e 20 73 71 6c 69 74 65 33 5f 62 69 6e  turn sqlite3_bin
15b0: 64 5f 64 6f 75 62 6c 65 28 73 74 6d 74 2c 69 43  d_double(stmt,iC
15c0: 6f 6c 2c 2a 76 61 6c 29 3b 0d 0a 7d 0d 0a 0d 0a  ol,*val);..}....
15d0: 53 51 4c 49 54 45 5f 41 50 49 20 69 6e 74 20 57  SQLITE_API int W
15e0: 49 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 62 69  INAPI sqlite3_bi
15f0: 6e 64 5f 69 6e 74 36 34 5f 69 6e 74 65 72 6f 70  nd_int64_interop
1600: 28 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 73  (sqlite3_stmt *s
1610: 74 6d 74 2c 20 69 6e 74 20 69 43 6f 6c 2c 20 73  tmt, int iCol, s
1620: 71 6c 69 74 65 5f 69 6e 74 36 34 20 2a 76 61 6c  qlite_int64 *val
1630: 29 0d 0a 7b 0d 0a 09 72 65 74 75 72 6e 20 73 71  )..{...return sq
1640: 6c 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74 36 34  lite3_bind_int64
1650: 28 73 74 6d 74 2c 69 43 6f 6c 2c 2a 76 61 6c 29  (stmt,iCol,*val)
1660: 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41  ;..}....SQLITE_A
1670: 50 49 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 20  PI const char * 
1680: 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 62  WINAPI sqlite3_b
1690: 69 6e 64 5f 70 61 72 61 6d 65 74 65 72 5f 6e 61  ind_parameter_na
16a0: 6d 65 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69 74  me_interop(sqlit
16b0: 65 33 5f 73 74 6d 74 20 2a 73 74 6d 74 2c 20 69  e3_stmt *stmt, i
16c0: 6e 74 20 69 43 6f 6c 2c 20 69 6e 74 20 2a 70 6c  nt iCol, int *pl
16d0: 65 6e 29 0d 0a 7b 0d 0a 20 20 63 6f 6e 73 74 20  en)..{..  const 
16e0: 63 68 61 72 20 2a 70 76 61 6c 20 3d 20 73 71 6c  char *pval = sql
16f0: 69 74 65 33 5f 62 69 6e 64 5f 70 61 72 61 6d 65  ite3_bind_parame
1700: 74 65 72 5f 6e 61 6d 65 28 73 74 6d 74 2c 20 69  ter_name(stmt, i
1710: 43 6f 6c 29 3b 0d 0a 20 20 2a 70 6c 65 6e 20 3d  Col);..  *plen =
1720: 20 28 70 76 61 6c 20 21 3d 20 30 29 20 3f 20 73   (pval != 0) ? s
1730: 74 72 6c 65 6e 28 70 76 61 6c 29 20 3a 20 30 3b  trlen(pval) : 0;
1740: 0d 0a 20 20 72 65 74 75 72 6e 20 70 76 61 6c 3b  ..  return pval;
1750: 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50  ..}....SQLITE_AP
1760: 49 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 20 57  I const char * W
1770: 49 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 63 6f  INAPI sqlite3_co
1780: 6c 75 6d 6e 5f 6e 61 6d 65 5f 69 6e 74 65 72 6f  lumn_name_intero
1790: 70 28 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a  p(sqlite3_stmt *
17a0: 73 74 6d 74 2c 20 69 6e 74 20 69 43 6f 6c 2c 20  stmt, int iCol, 
17b0: 69 6e 74 20 2a 70 6c 65 6e 29 0d 0a 7b 0d 0a 20  int *plen)..{.. 
17c0: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 70 76 61   const char *pva
17d0: 6c 20 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75  l = sqlite3_colu
17e0: 6d 6e 5f 6e 61 6d 65 28 73 74 6d 74 2c 20 69 43  mn_name(stmt, iC
17f0: 6f 6c 29 3b 0d 0a 20 20 2a 70 6c 65 6e 20 3d 20  ol);..  *plen = 
1800: 28 70 76 61 6c 20 21 3d 20 30 29 20 3f 20 73 74  (pval != 0) ? st
1810: 72 6c 65 6e 28 70 76 61 6c 29 20 3a 20 30 3b 0d  rlen(pval) : 0;.
1820: 0a 20 20 72 65 74 75 72 6e 20 70 76 61 6c 3b 0d  .  return pval;.
1830: 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50 49  .}....SQLITE_API
1840: 20 63 6f 6e 73 74 20 76 6f 69 64 20 2a 20 57 49   const void * WI
1850: 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 63 6f 6c  NAPI sqlite3_col
1860: 75 6d 6e 5f 6e 61 6d 65 31 36 5f 69 6e 74 65 72  umn_name16_inter
1870: 6f 70 28 73 71 6c 69 74 65 33 5f 73 74 6d 74 20  op(sqlite3_stmt 
1880: 2a 73 74 6d 74 2c 20 69 6e 74 20 69 43 6f 6c 2c  *stmt, int iCol,
1890: 20 69 6e 74 20 2a 70 6c 65 6e 29 0d 0a 7b 0d 0a   int *plen)..{..
18a0: 20 20 63 6f 6e 73 74 20 76 6f 69 64 20 2a 70 76    const void *pv
18b0: 61 6c 20 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6c  al = sqlite3_col
18c0: 75 6d 6e 5f 6e 61 6d 65 31 36 28 73 74 6d 74 2c  umn_name16(stmt,
18d0: 20 69 43 6f 6c 29 3b 0d 0a 20 20 2a 70 6c 65 6e   iCol);..  *plen
18e0: 20 3d 20 28 70 76 61 6c 20 21 3d 20 30 29 20 3f   = (pval != 0) ?
18f0: 20 77 63 73 6c 65 6e 28 28 77 63 68 61 72 5f 74   wcslen((wchar_t
1900: 20 2a 29 70 76 61 6c 29 20 2a 20 73 69 7a 65 6f   *)pval) * sizeo
1910: 66 28 77 63 68 61 72 5f 74 29 20 3a 20 30 3b 0d  f(wchar_t) : 0;.
1920: 0a 20 20 72 65 74 75 72 6e 20 70 76 61 6c 3b 0d  .  return pval;.
1930: 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50 49  .}....SQLITE_API
1940: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 20 57 49   const char * WI
1950: 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 63 6f 6c  NAPI sqlite3_col
1960: 75 6d 6e 5f 64 65 63 6c 74 79 70 65 5f 69 6e 74  umn_decltype_int
1970: 65 72 6f 70 28 73 71 6c 69 74 65 33 5f 73 74 6d  erop(sqlite3_stm
1980: 74 20 2a 73 74 6d 74 2c 20 69 6e 74 20 69 43 6f  t *stmt, int iCo
1990: 6c 2c 20 69 6e 74 20 2a 70 6c 65 6e 29 0d 0a 7b  l, int *plen)..{
19a0: 0d 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  ..  const char *
19b0: 70 76 61 6c 20 3d 20 73 71 6c 69 74 65 33 5f 63  pval = sqlite3_c
19c0: 6f 6c 75 6d 6e 5f 64 65 63 6c 74 79 70 65 28 73  olumn_decltype(s
19d0: 74 6d 74 2c 20 69 43 6f 6c 29 3b 0d 0a 20 20 2a  tmt, iCol);..  *
19e0: 70 6c 65 6e 20 3d 20 28 70 76 61 6c 20 21 3d 20  plen = (pval != 
19f0: 30 29 20 3f 20 73 74 72 6c 65 6e 28 70 76 61 6c  0) ? strlen(pval
1a00: 29 20 3a 20 30 3b 0d 0a 20 20 72 65 74 75 72 6e  ) : 0;..  return
1a10: 20 70 76 61 6c 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c   pval;..}....SQL
1a20: 49 54 45 5f 41 50 49 20 63 6f 6e 73 74 20 76 6f  ITE_API const vo
1a30: 69 64 20 2a 20 57 49 4e 41 50 49 20 73 71 6c 69  id * WINAPI sqli
1a40: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 65 63 6c 74  te3_column_declt
1a50: 79 70 65 31 36 5f 69 6e 74 65 72 6f 70 28 73 71  ype16_interop(sq
1a60: 6c 69 74 65 33 5f 73 74 6d 74 20 2a 73 74 6d 74  lite3_stmt *stmt
1a70: 2c 20 69 6e 74 20 69 43 6f 6c 2c 20 69 6e 74 20  , int iCol, int 
1a80: 2a 70 6c 65 6e 29 0d 0a 7b 0d 0a 20 20 63 6f 6e  *plen)..{..  con
1a90: 73 74 20 76 6f 69 64 20 2a 70 76 61 6c 20 3d 20  st void *pval = 
1aa0: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64  sqlite3_column_d
1ab0: 65 63 6c 74 79 70 65 31 36 28 73 74 6d 74 2c 20  ecltype16(stmt, 
1ac0: 69 43 6f 6c 29 3b 0d 0a 20 20 2a 70 6c 65 6e 20  iCol);..  *plen 
1ad0: 3d 20 28 70 76 61 6c 20 21 3d 20 30 29 20 3f 20  = (pval != 0) ? 
1ae0: 77 63 73 6c 65 6e 28 28 77 63 68 61 72 5f 74 20  wcslen((wchar_t 
1af0: 2a 29 70 76 61 6c 29 20 2a 20 73 69 7a 65 6f 66  *)pval) * sizeof
1b00: 28 77 63 68 61 72 5f 74 29 20 3a 20 30 3b 0d 0a  (wchar_t) : 0;..
1b10: 20 20 72 65 74 75 72 6e 20 70 76 61 6c 3b 0d 0a    return pval;..
1b20: 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50 49 20  }....SQLITE_API 
1b30: 76 6f 69 64 20 57 49 4e 41 50 49 20 73 71 6c 69  void WINAPI sqli
1b40: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 6f 75 62 6c  te3_column_doubl
1b50: 65 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69 74 65  e_interop(sqlite
1b60: 33 5f 73 74 6d 74 20 2a 73 74 6d 74 2c 20 69 6e  3_stmt *stmt, in
1b70: 74 20 69 43 6f 6c 2c 20 64 6f 75 62 6c 65 20 2a  t iCol, double *
1b80: 76 61 6c 29 0d 0a 7b 0d 0a 09 2a 76 61 6c 20 3d  val)..{...*val =
1b90: 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f   sqlite3_column_
1ba0: 64 6f 75 62 6c 65 28 73 74 6d 74 2c 69 43 6f 6c  double(stmt,iCol
1bb0: 29 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f  );..}....SQLITE_
1bc0: 41 50 49 20 76 6f 69 64 20 57 49 4e 41 50 49 20  API void WINAPI 
1bd0: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69  sqlite3_column_i
1be0: 6e 74 36 34 5f 69 6e 74 65 72 6f 70 28 73 71 6c  nt64_interop(sql
1bf0: 69 74 65 33 5f 73 74 6d 74 20 2a 73 74 6d 74 2c  ite3_stmt *stmt,
1c00: 20 69 6e 74 20 69 43 6f 6c 2c 20 73 71 6c 69 74   int iCol, sqlit
1c10: 65 5f 69 6e 74 36 34 20 2a 76 61 6c 29 0d 0a 7b  e_int64 *val)..{
1c20: 0d 0a 09 2a 76 61 6c 20 3d 20 73 71 6c 69 74 65  ...*val = sqlite
1c30: 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 36 34 28 73  3_column_int64(s
1c40: 74 6d 74 2c 69 43 6f 6c 29 3b 0d 0a 7d 0d 0a 0d  tmt,iCol);..}...
1c50: 0a 53 51 4c 49 54 45 5f 41 50 49 20 63 6f 6e 73  .SQLITE_API cons
1c60: 74 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20  t unsigned char 
1c70: 2a 20 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33  * WINAPI sqlite3
1c80: 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 5f 69 6e 74  _column_text_int
1c90: 65 72 6f 70 28 73 71 6c 69 74 65 33 5f 73 74 6d  erop(sqlite3_stm
1ca0: 74 20 2a 73 74 6d 74 2c 20 69 6e 74 20 69 43 6f  t *stmt, int iCo
1cb0: 6c 2c 20 69 6e 74 20 2a 70 6c 65 6e 29 0d 0a 7b  l, int *plen)..{
1cc0: 0d 0a 20 20 63 6f 6e 73 74 20 75 6e 73 69 67 6e  ..  const unsign
1cd0: 65 64 20 63 68 61 72 20 2a 70 76 61 6c 20 3d 20  ed char *pval = 
1ce0: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74  sqlite3_column_t
1cf0: 65 78 74 28 73 74 6d 74 2c 20 69 43 6f 6c 29 3b  ext(stmt, iCol);
1d00: 0d 0a 20 20 2a 70 6c 65 6e 20 3d 20 28 70 76 61  ..  *plen = (pva
1d10: 6c 20 21 3d 20 30 29 20 3f 20 73 74 72 6c 65 6e  l != 0) ? strlen
1d20: 28 28 63 68 61 72 20 2a 29 70 76 61 6c 29 20 3a  ((char *)pval) :
1d30: 20 30 3b 0d 0a 20 20 72 65 74 75 72 6e 20 70 76   0;..  return pv
1d40: 61 6c 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45  al;..}....SQLITE
1d50: 5f 41 50 49 20 63 6f 6e 73 74 20 76 6f 69 64 20  _API const void 
1d60: 2a 20 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33  * WINAPI sqlite3
1d70: 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 31 36 5f 69  _column_text16_i
1d80: 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33 5f 73  nterop(sqlite3_s
1d90: 74 6d 74 20 2a 73 74 6d 74 2c 20 69 6e 74 20 69  tmt *stmt, int i
1da0: 43 6f 6c 2c 20 69 6e 74 20 2a 70 6c 65 6e 29 0d  Col, int *plen).
1db0: 0a 7b 0d 0a 20 20 63 6f 6e 73 74 20 76 6f 69 64  .{..  const void
1dc0: 20 2a 70 76 61 6c 20 3d 20 73 71 6c 69 74 65 33   *pval = sqlite3
1dd0: 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 31 36 28 73  _column_text16(s
1de0: 74 6d 74 2c 20 69 43 6f 6c 29 3b 0d 0a 20 20 2a  tmt, iCol);..  *
1df0: 70 6c 65 6e 20 3d 20 28 70 76 61 6c 20 21 3d 20  plen = (pval != 
1e00: 30 29 20 3f 20 77 63 73 6c 65 6e 28 28 77 63 68  0) ? wcslen((wch
1e10: 61 72 5f 74 20 2a 29 70 76 61 6c 29 20 2a 20 73  ar_t *)pval) * s
1e20: 69 7a 65 6f 66 28 77 63 68 61 72 5f 74 29 3a 20  izeof(wchar_t): 
1e30: 30 3b 0d 0a 20 20 72 65 74 75 72 6e 20 70 76 61  0;..  return pva
1e40: 6c 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f  l;..}....SQLITE_
1e50: 41 50 49 20 69 6e 74 20 57 49 4e 41 50 49 20 73  API int WINAPI s
1e60: 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 5f  qlite3_finalize_
1e70: 69 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33 5f  interop(sqlite3_
1e80: 73 74 6d 74 20 2a 73 74 6d 74 29 0d 0a 7b 0d 0a  stmt *stmt)..{..
1e90: 23 69 66 20 53 51 4c 49 54 45 5f 56 45 52 53 49  #if SQLITE_VERSI
1ea0: 4f 4e 5f 4e 55 4d 42 45 52 20 3e 3d 20 33 30 30  ON_NUMBER >= 300
1eb0: 37 30 31 34 0d 0a 20 20 72 65 74 75 72 6e 20 73  7014..  return s
1ec0: 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28  qlite3_finalize(
1ed0: 73 74 6d 74 29 3b 0d 0a 23 65 6c 73 65 0d 0a 20  stmt);..#else.. 
1ee0: 20 56 64 62 65 20 2a 70 3b 0d 0a 20 20 69 6e 74   Vdbe *p;..  int
1ef0: 20 72 65 74 20 3d 20 53 51 4c 49 54 45 5f 4f 4b   ret = SQLITE_OK
1f00: 3b 0d 0a 0d 0a 20 20 70 20 3d 20 28 56 64 62 65  ;....  p = (Vdbe
1f10: 20 2a 29 73 74 6d 74 3b 0d 0a 20 20 69 66 20 28   *)stmt;..  if (
1f20: 70 29 0d 0a 20 20 7b 0d 0a 20 20 20 20 73 71 6c  p)..  {..    sql
1f30: 69 74 65 33 20 2a 64 62 20 3d 20 70 2d 3e 64 62  ite3 *db = p->db
1f40: 3b 0d 0a 0d 0a 20 20 20 20 69 66 20 28 64 62 20  ;....    if (db 
1f50: 21 3d 20 4e 55 4c 4c 29 0d 0a 20 20 20 20 20 20  != NULL)..      
1f60: 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65 6e  sqlite3_mutex_en
1f70: 74 65 72 28 64 62 2d 3e 6d 75 74 65 78 29 3b 0d  ter(db->mutex);.
1f80: 0a 0d 0a 20 20 20 20 69 66 20 28 28 70 2d 3e 6d  ...    if ((p->m
1f90: 61 67 69 63 20 3d 3d 20 56 44 42 45 5f 4d 41 47  agic == VDBE_MAG
1fa0: 49 43 5f 44 45 41 44 29 20 26 26 20 28 64 62 20  IC_DEAD) && (db 
1fb0: 3d 3d 20 4e 55 4c 4c 29 29 0d 0a 20 20 20 20 7b  == NULL))..    {
1fc0: 0d 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 44  ..      sqlite3D
1fd0: 62 46 72 65 65 5f 69 6e 74 65 72 6f 70 28 64 62  bFree_interop(db
1fe0: 2c 20 70 29 3b 0d 0a 20 20 20 20 7d 0d 0a 20 20  , p);..    }..  
1ff0: 20 20 65 6c 73 65 0d 0a 20 20 20 20 7b 0d 0a 20    else..    {.. 
2000: 20 20 20 20 20 72 65 74 20 3d 20 73 71 6c 69 74       ret = sqlit
2010: 65 33 5f 66 69 6e 61 6c 69 7a 65 28 73 74 6d 74  e3_finalize(stmt
2020: 29 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20 20  );..    }....   
2030: 20 69 66 20 28 64 62 20 21 3d 20 4e 55 4c 4c 29   if (db != NULL)
2040: 0d 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f  ..      sqlite3_
2050: 6d 75 74 65 78 5f 6c 65 61 76 65 28 64 62 2d 3e  mutex_leave(db->
2060: 6d 75 74 65 78 29 3b 0d 0a 20 20 7d 0d 0a 0d 0a  mutex);..  }....
2070: 20 20 72 65 74 75 72 6e 20 72 65 74 3b 0d 0a 23    return ret;..#
2080: 65 6e 64 69 66 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49  endif..}....SQLI
2090: 54 45 5f 41 50 49 20 69 6e 74 20 57 49 4e 41 50  TE_API int WINAP
20a0: 49 20 73 71 6c 69 74 65 33 5f 72 65 73 65 74 5f  I sqlite3_reset_
20b0: 69 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33 5f  interop(sqlite3_
20c0: 73 74 6d 74 20 2a 73 74 6d 74 29 0d 0a 7b 0d 0a  stmt *stmt)..{..
20d0: 20 20 69 6e 74 20 72 65 74 3b 0d 0a 0d 0a 20 20    int ret;....  
20e0: 69 66 20 28 28 28 56 64 62 65 20 2a 29 73 74 6d  if (((Vdbe *)stm
20f0: 74 29 2d 3e 6d 61 67 69 63 20 3d 3d 20 56 44 42  t)->magic == VDB
2100: 45 5f 4d 41 47 49 43 5f 44 45 41 44 29 20 72 65  E_MAGIC_DEAD) re
2110: 74 75 72 6e 20 53 51 4c 49 54 45 5f 53 43 48 45  turn SQLITE_SCHE
2120: 4d 41 3b 0d 0a 20 20 72 65 74 20 3d 20 73 71 6c  MA;..  ret = sql
2130: 69 74 65 33 5f 72 65 73 65 74 28 73 74 6d 74 29  ite3_reset(stmt)
2140: 3b 0d 0a 20 20 72 65 74 75 72 6e 20 72 65 74 3b  ;..  return ret;
2150: 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50  ..}....SQLITE_AP
2160: 49 20 69 6e 74 20 57 49 4e 41 50 49 20 73 71 6c  I int WINAPI sql
2170: 69 74 65 33 5f 63 72 65 61 74 65 5f 66 75 6e 63  ite3_create_func
2180: 74 69 6f 6e 5f 69 6e 74 65 72 6f 70 28 73 71 6c  tion_interop(sql
2190: 69 74 65 33 20 2a 70 73 71 6c 2c 20 63 6f 6e 73  ite3 *psql, cons
21a0: 74 20 63 68 61 72 20 2a 7a 46 75 6e 63 74 69 6f  t char *zFunctio
21b0: 6e 4e 61 6d 65 2c 20 69 6e 74 20 6e 41 72 67 2c  nName, int nArg,
21c0: 20 69 6e 74 20 65 54 65 78 74 52 65 70 2c 20 76   int eTextRep, v
21d0: 6f 69 64 20 2a 70 76 55 73 65 72 2c 20 53 51 4c  oid *pvUser, SQL
21e0: 49 54 45 55 53 45 52 46 55 4e 43 20 66 75 6e 63  ITEUSERFUNC func
21f0: 2c 20 53 51 4c 49 54 45 55 53 45 52 46 55 4e 43  , SQLITEUSERFUNC
2200: 20 66 75 6e 63 73 74 65 70 2c 20 53 51 4c 49 54   funcstep, SQLIT
2210: 45 46 55 4e 43 46 49 4e 41 4c 20 66 75 6e 63 66  EFUNCFINAL funcf
2220: 69 6e 61 6c 2c 20 69 6e 74 20 6e 65 65 64 43 6f  inal, int needCo
2230: 6c 6c 53 65 71 29 0d 0a 7b 0d 0a 20 20 69 6e 74  llSeq)..{..  int
2240: 20 6e 3b 0d 0a 0d 0a 20 20 69 66 20 28 65 54 65   n;....  if (eTe
2250: 78 74 52 65 70 20 3d 3d 20 53 51 4c 49 54 45 5f  xtRep == SQLITE_
2260: 55 54 46 31 36 29 0d 0a 20 20 20 20 65 54 65 78  UTF16)..    eTex
2270: 74 52 65 70 20 3d 20 53 51 4c 49 54 45 5f 55 54  tRep = SQLITE_UT
2280: 46 31 36 4e 41 54 49 56 45 3b 0d 0a 0d 0a 20 20  F16NATIVE;....  
2290: 6e 20 3d 20 73 71 6c 69 74 65 33 5f 63 72 65 61  n = sqlite3_crea
22a0: 74 65 5f 66 75 6e 63 74 69 6f 6e 28 70 73 71 6c  te_function(psql
22b0: 2c 20 7a 46 75 6e 63 74 69 6f 6e 4e 61 6d 65 2c  , zFunctionName,
22c0: 20 6e 41 72 67 2c 20 65 54 65 78 74 52 65 70 2c   nArg, eTextRep,
22d0: 20 30 2c 20 66 75 6e 63 2c 20 66 75 6e 63 73 74   0, func, funcst
22e0: 65 70 2c 20 66 75 6e 63 66 69 6e 61 6c 29 3b 0d  ep, funcfinal);.
22f0: 0a 20 20 69 66 20 28 6e 20 3d 3d 20 30 29 0d 0a  .  if (n == 0)..
2300: 20 20 7b 0d 0a 20 20 20 20 69 66 20 28 6e 65 65    {..    if (nee
2310: 64 43 6f 6c 6c 53 65 71 29 0d 0a 20 20 20 20 7b  dCollSeq)..    {
2320: 0d 0a 20 20 20 20 20 20 46 75 6e 63 44 65 66 20  ..      FuncDef 
2330: 2a 70 46 75 6e 63 20 3d 20 73 71 6c 69 74 65 33  *pFunc = sqlite3
2340: 46 69 6e 64 46 75 6e 63 74 69 6f 6e 28 70 73 71  FindFunction(psq
2350: 6c 2c 20 7a 46 75 6e 63 74 69 6f 6e 4e 61 6d 65  l, zFunctionName
2360: 2c 20 73 74 72 6c 65 6e 28 7a 46 75 6e 63 74 69  , strlen(zFuncti
2370: 6f 6e 4e 61 6d 65 29 2c 20 6e 41 72 67 2c 20 65  onName), nArg, e
2380: 54 65 78 74 52 65 70 2c 20 30 29 3b 0d 0a 20 20  TextRep, 0);..  
2390: 20 20 20 20 69 66 28 20 70 46 75 6e 63 20 29 0d      if( pFunc ).
23a0: 0a 20 20 20 20 20 20 7b 0d 0a 20 20 20 20 20 20  .      {..      
23b0: 20 20 70 46 75 6e 63 2d 3e 66 6c 61 67 73 20 7c    pFunc->flags |
23c0: 3d 20 53 51 4c 49 54 45 5f 46 55 4e 43 5f 4e 45  = SQLITE_FUNC_NE
23d0: 45 44 43 4f 4c 4c 3b 0d 0a 20 20 20 20 20 20 7d  EDCOLL;..      }
23e0: 0d 0a 20 20 20 20 7d 0d 0a 20 20 7d 0d 0a 0d 0a  ..    }..  }....
23f0: 20 20 72 65 74 75 72 6e 20 6e 3b 0d 0a 7d 0d 0a    return n;..}..
2400: 0d 0a 53 51 4c 49 54 45 5f 41 50 49 20 76 6f 69  ..SQLITE_API voi
2410: 64 20 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33  d WINAPI sqlite3
2420: 5f 76 61 6c 75 65 5f 64 6f 75 62 6c 65 5f 69 6e  _value_double_in
2430: 74 65 72 6f 70 28 73 71 6c 69 74 65 33 5f 76 61  terop(sqlite3_va
2440: 6c 75 65 20 2a 70 76 61 6c 2c 20 64 6f 75 62 6c  lue *pval, doubl
2450: 65 20 2a 76 61 6c 29 0d 0a 7b 0d 0a 20 20 2a 76  e *val)..{..  *v
2460: 61 6c 20 3d 20 73 71 6c 69 74 65 33 5f 76 61 6c  al = sqlite3_val
2470: 75 65 5f 64 6f 75 62 6c 65 28 70 76 61 6c 29 3b  ue_double(pval);
2480: 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50  ..}....SQLITE_AP
2490: 49 20 76 6f 69 64 20 57 49 4e 41 50 49 20 73 71  I void WINAPI sq
24a0: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74 36  lite3_value_int6
24b0: 34 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69 74 65  4_interop(sqlite
24c0: 33 5f 76 61 6c 75 65 20 2a 70 76 61 6c 2c 20 73  3_value *pval, s
24d0: 71 6c 69 74 65 5f 69 6e 74 36 34 20 2a 76 61 6c  qlite_int64 *val
24e0: 29 0d 0a 7b 0d 0a 20 20 2a 76 61 6c 20 3d 20 73  )..{..  *val = s
24f0: 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74  qlite3_value_int
2500: 36 34 28 70 76 61 6c 29 3b 0d 0a 7d 0d 0a 0d 0a  64(pval);..}....
2510: 53 51 4c 49 54 45 5f 41 50 49 20 63 6f 6e 73 74  SQLITE_API const
2520: 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72 20 2a   unsigned char *
2530: 20 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33 5f   WINAPI sqlite3_
2540: 76 61 6c 75 65 5f 74 65 78 74 5f 69 6e 74 65 72  value_text_inter
2550: 6f 70 28 73 71 6c 69 74 65 33 5f 76 61 6c 75 65  op(sqlite3_value
2560: 20 2a 76 61 6c 2c 20 69 6e 74 20 2a 70 6c 65 6e   *val, int *plen
2570: 29 0d 0a 7b 0d 0a 20 20 63 6f 6e 73 74 20 75 6e  )..{..  const un
2580: 73 69 67 6e 65 64 20 63 68 61 72 20 2a 70 76 61  signed char *pva
2590: 6c 20 3d 20 73 71 6c 69 74 65 33 5f 76 61 6c 75  l = sqlite3_valu
25a0: 65 5f 74 65 78 74 28 76 61 6c 29 3b 0d 0a 20 20  e_text(val);..  
25b0: 2a 70 6c 65 6e 20 3d 20 28 70 76 61 6c 20 21 3d  *plen = (pval !=
25c0: 20 30 29 20 3f 20 73 74 72 6c 65 6e 28 28 63 68   0) ? strlen((ch
25d0: 61 72 20 2a 29 70 76 61 6c 29 20 3a 20 30 3b 0d  ar *)pval) : 0;.
25e0: 0a 20 20 72 65 74 75 72 6e 20 70 76 61 6c 3b 0d  .  return pval;.
25f0: 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50 49  .}....SQLITE_API
2600: 20 63 6f 6e 73 74 20 76 6f 69 64 20 2a 20 57 49   const void * WI
2610: 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 76 61 6c  NAPI sqlite3_val
2620: 75 65 5f 74 65 78 74 31 36 5f 69 6e 74 65 72 6f  ue_text16_intero
2630: 70 28 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 20  p(sqlite3_value 
2640: 2a 76 61 6c 2c 20 69 6e 74 20 2a 70 6c 65 6e 29  *val, int *plen)
2650: 0d 0a 7b 0d 0a 20 20 63 6f 6e 73 74 20 76 6f 69  ..{..  const voi
2660: 64 20 2a 70 76 61 6c 20 3d 20 73 71 6c 69 74 65  d *pval = sqlite
2670: 33 5f 76 61 6c 75 65 5f 74 65 78 74 31 36 28 76  3_value_text16(v
2680: 61 6c 29 3b 0d 0a 20 20 2a 70 6c 65 6e 20 3d 20  al);..  *plen = 
2690: 28 70 76 61 6c 20 21 3d 20 30 29 20 3f 20 77 63  (pval != 0) ? wc
26a0: 73 6c 65 6e 28 28 77 63 68 61 72 5f 74 20 2a 29  slen((wchar_t *)
26b0: 70 76 61 6c 29 20 2a 20 73 69 7a 65 6f 66 28 77  pval) * sizeof(w
26c0: 63 68 61 72 5f 74 29 20 3a 20 30 3b 0d 0a 20 20  char_t) : 0;..  
26d0: 72 65 74 75 72 6e 20 70 76 61 6c 3b 0d 0a 7d 0d  return pval;..}.
26e0: 0a 0d 0a 53 51 4c 49 54 45 5f 41 50 49 20 76 6f  ...SQLITE_API vo
26f0: 69 64 20 57 49 4e 41 50 49 20 73 71 6c 69 74 65  id WINAPI sqlite
2700: 33 5f 72 65 73 75 6c 74 5f 64 6f 75 62 6c 65 5f  3_result_double_
2710: 69 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33 5f  interop(sqlite3_
2720: 63 6f 6e 74 65 78 74 20 2a 70 63 74 78 2c 20 64  context *pctx, d
2730: 6f 75 62 6c 65 20 2a 76 61 6c 29 0d 0a 7b 0d 0a  ouble *val)..{..
2740: 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74    sqlite3_result
2750: 5f 64 6f 75 62 6c 65 28 70 63 74 78 2c 20 2a 76  _double(pctx, *v
2760: 61 6c 29 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54  al);..}....SQLIT
2770: 45 5f 41 50 49 20 76 6f 69 64 20 57 49 4e 41 50  E_API void WINAP
2780: 49 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74  I sqlite3_result
2790: 5f 69 6e 74 36 34 5f 69 6e 74 65 72 6f 70 28 73  _int64_interop(s
27a0: 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a  qlite3_context *
27b0: 70 63 74 78 2c 20 73 71 6c 69 74 65 5f 69 6e 74  pctx, sqlite_int
27c0: 36 34 20 2a 76 61 6c 29 0d 0a 7b 0d 0a 20 20 73  64 *val)..{..  s
27d0: 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e  qlite3_result_in
27e0: 74 36 34 28 70 63 74 78 2c 20 2a 76 61 6c 29 3b  t64(pctx, *val);
27f0: 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50  ..}....SQLITE_AP
2800: 49 20 69 6e 74 20 57 49 4e 41 50 49 20 73 71 6c  I int WINAPI sql
2810: 69 74 65 33 5f 63 6f 6e 74 65 78 74 5f 63 6f 6c  ite3_context_col
2820: 6c 63 6f 6d 70 61 72 65 28 73 71 6c 69 74 65 33  lcompare(sqlite3
2830: 5f 63 6f 6e 74 65 78 74 20 2a 63 74 78 2c 20 63  _context *ctx, c
2840: 6f 6e 73 74 20 76 6f 69 64 20 2a 70 31 2c 20 69  onst void *p1, i
2850: 6e 74 20 70 31 6c 65 6e 2c 20 63 6f 6e 73 74 20  nt p1len, const 
2860: 76 6f 69 64 20 2a 70 32 2c 20 69 6e 74 20 70 32  void *p2, int p2
2870: 6c 65 6e 29 0d 0a 7b 0d 0a 20 20 69 66 20 28 28  len)..{..  if ((
2880: 63 74 78 2d 3e 70 46 75 6e 63 2d 3e 66 6c 61 67  ctx->pFunc->flag
2890: 73 20 26 20 53 51 4c 49 54 45 5f 46 55 4e 43 5f  s & SQLITE_FUNC_
28a0: 4e 45 45 44 43 4f 4c 4c 29 20 3d 3d 20 30 29 20  NEEDCOLL) == 0) 
28b0: 72 65 74 75 72 6e 20 32 3b 0d 0a 20 20 72 65 74  return 2;..  ret
28c0: 75 72 6e 20 63 74 78 2d 3e 70 43 6f 6c 6c 2d 3e  urn ctx->pColl->
28d0: 78 43 6d 70 28 63 74 78 2d 3e 70 43 6f 6c 6c 2d  xCmp(ctx->pColl-
28e0: 3e 70 55 73 65 72 2c 20 70 31 6c 65 6e 2c 20 70  >pUser, p1len, p
28f0: 31 2c 20 70 32 6c 65 6e 2c 20 70 32 29 3b 0d 0a  1, p2len, p2);..
2900: 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50 49 20  }....SQLITE_API 
2910: 63 6f 6e 73 74 20 63 68 61 72 20 2a 20 57 49 4e  const char * WIN
2920: 41 50 49 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74  API sqlite3_cont
2930: 65 78 74 5f 63 6f 6c 6c 73 65 71 28 73 71 6c 69  ext_collseq(sqli
2940: 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 63 74 78  te3_context *ctx
2950: 2c 20 69 6e 74 20 2a 70 74 79 70 65 2c 20 69 6e  , int *ptype, in
2960: 74 20 2a 65 6e 63 2c 20 69 6e 74 20 2a 70 6c 65  t *enc, int *ple
2970: 6e 29 0d 0a 7b 0d 0a 20 20 43 6f 6c 6c 53 65 71  n)..{..  CollSeq
2980: 20 2a 70 43 6f 6c 6c 20 3d 20 63 74 78 2d 3e 70   *pColl = ctx->p
2990: 43 6f 6c 6c 3b 0d 0a 20 20 2a 70 74 79 70 65 20  Coll;..  *ptype 
29a0: 3d 20 30 3b 0d 0a 20 20 2a 70 6c 65 6e 20 3d 20  = 0;..  *plen = 
29b0: 30 3b 0d 0a 20 20 2a 65 6e 63 20 3d 20 30 3b 0d  0;..  *enc = 0;.
29c0: 0a 0d 0a 20 20 69 66 20 28 28 63 74 78 2d 3e 70  ...  if ((ctx->p
29d0: 46 75 6e 63 2d 3e 66 6c 61 67 73 20 26 20 53 51  Func->flags & SQ
29e0: 4c 49 54 45 5f 46 55 4e 43 5f 4e 45 45 44 43 4f  LITE_FUNC_NEEDCO
29f0: 4c 4c 29 20 3d 3d 20 30 29 20 72 65 74 75 72 6e  LL) == 0) return
2a00: 20 4e 55 4c 4c 3b 0d 0a 0d 0a 20 20 69 66 20 28   NULL;....  if (
2a10: 70 43 6f 6c 6c 29 0d 0a 20 20 7b 0d 0a 20 20 20  pColl)..  {..   
2a20: 20 2a 65 6e 63 20 3d 20 70 43 6f 6c 6c 2d 3e 65   *enc = pColl->e
2a30: 6e 63 3b 0d 0a 23 69 66 20 53 51 4c 49 54 45 5f  nc;..#if SQLITE_
2a40: 56 45 52 53 49 4f 4e 5f 4e 55 4d 42 45 52 20 3c  VERSION_NUMBER <
2a50: 20 33 30 30 37 30 31 30 0d 0a 20 20 20 20 2a 70   3007010..    *p
2a60: 74 79 70 65 20 3d 20 70 43 6f 6c 6c 2d 3e 74 79  type = pColl->ty
2a70: 70 65 3b 0d 0a 23 65 6e 64 69 66 0d 0a 20 20 20  pe;..#endif..   
2a80: 20 2a 70 6c 65 6e 20 3d 20 28 70 43 6f 6c 6c 2d   *plen = (pColl-
2a90: 3e 7a 4e 61 6d 65 20 21 3d 20 30 29 20 3f 20 73  >zName != 0) ? s
2aa0: 74 72 6c 65 6e 28 70 43 6f 6c 6c 2d 3e 7a 4e 61  trlen(pColl->zNa
2ab0: 6d 65 29 20 3a 20 30 3b 0d 0a 0d 0a 20 20 20 20  me) : 0;....    
2ac0: 72 65 74 75 72 6e 20 70 43 6f 6c 6c 2d 3e 7a 4e  return pColl->zN
2ad0: 61 6d 65 3b 0d 0a 20 20 7d 0d 0a 20 20 72 65 74  ame;..  }..  ret
2ae0: 75 72 6e 20 4e 55 4c 4c 3b 0d 0a 7d 0d 0a 0d 0a  urn NULL;..}....
2af0: 53 51 4c 49 54 45 5f 41 50 49 20 63 6f 6e 73 74  SQLITE_API const
2b00: 20 63 68 61 72 20 2a 20 57 49 4e 41 50 49 20 73   char * WINAPI s
2b10: 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 61  qlite3_column_da
2b20: 74 61 62 61 73 65 5f 6e 61 6d 65 5f 69 6e 74 65  tabase_name_inte
2b30: 72 6f 70 28 73 71 6c 69 74 65 33 5f 73 74 6d 74  rop(sqlite3_stmt
2b40: 20 2a 73 74 6d 74 2c 20 69 6e 74 20 69 43 6f 6c   *stmt, int iCol
2b50: 2c 20 69 6e 74 20 2a 70 6c 65 6e 29 0d 0a 7b 0d  , int *plen)..{.
2b60: 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 70  .  const char *p
2b70: 76 61 6c 20 3d 20 73 71 6c 69 74 65 33 5f 63 6f  val = sqlite3_co
2b80: 6c 75 6d 6e 5f 64 61 74 61 62 61 73 65 5f 6e 61  lumn_database_na
2b90: 6d 65 28 73 74 6d 74 2c 20 69 43 6f 6c 29 3b 0d  me(stmt, iCol);.
2ba0: 0a 20 20 2a 70 6c 65 6e 20 3d 20 28 70 76 61 6c  .  *plen = (pval
2bb0: 20 21 3d 20 30 29 20 3f 20 73 74 72 6c 65 6e 28   != 0) ? strlen(
2bc0: 70 76 61 6c 29 20 3a 20 30 3b 0d 0a 20 20 72 65  pval) : 0;..  re
2bd0: 74 75 72 6e 20 70 76 61 6c 3b 0d 0a 7d 0d 0a 0d  turn pval;..}...
2be0: 0a 53 51 4c 49 54 45 5f 41 50 49 20 63 6f 6e 73  .SQLITE_API cons
2bf0: 74 20 76 6f 69 64 20 2a 20 57 49 4e 41 50 49 20  t void * WINAPI 
2c00: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64  sqlite3_column_d
2c10: 61 74 61 62 61 73 65 5f 6e 61 6d 65 31 36 5f 69  atabase_name16_i
2c20: 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33 5f 73  nterop(sqlite3_s
2c30: 74 6d 74 20 2a 73 74 6d 74 2c 20 69 6e 74 20 69  tmt *stmt, int i
2c40: 43 6f 6c 2c 20 69 6e 74 20 2a 70 6c 65 6e 29 0d  Col, int *plen).
2c50: 0a 7b 0d 0a 20 20 63 6f 6e 73 74 20 76 6f 69 64  .{..  const void
2c60: 20 2a 70 76 61 6c 20 3d 20 73 71 6c 69 74 65 33   *pval = sqlite3
2c70: 5f 63 6f 6c 75 6d 6e 5f 64 61 74 61 62 61 73 65  _column_database
2c80: 5f 6e 61 6d 65 31 36 28 73 74 6d 74 2c 20 69 43  _name16(stmt, iC
2c90: 6f 6c 29 3b 0d 0a 20 20 2a 70 6c 65 6e 20 3d 20  ol);..  *plen = 
2ca0: 28 70 76 61 6c 20 21 3d 20 30 29 20 3f 20 77 63  (pval != 0) ? wc
2cb0: 73 6c 65 6e 28 28 77 63 68 61 72 5f 74 20 2a 29  slen((wchar_t *)
2cc0: 70 76 61 6c 29 20 2a 20 73 69 7a 65 6f 66 28 77  pval) * sizeof(w
2cd0: 63 68 61 72 5f 74 29 20 3a 20 30 3b 0d 0a 20 20  char_t) : 0;..  
2ce0: 72 65 74 75 72 6e 20 70 76 61 6c 3b 0d 0a 7d 0d  return pval;..}.
2cf0: 0a 0d 0a 53 51 4c 49 54 45 5f 41 50 49 20 63 6f  ...SQLITE_API co
2d00: 6e 73 74 20 63 68 61 72 20 2a 20 57 49 4e 41 50  nst char * WINAP
2d10: 49 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  I sqlite3_column
2d20: 5f 74 61 62 6c 65 5f 6e 61 6d 65 5f 69 6e 74 65  _table_name_inte
2d30: 72 6f 70 28 73 71 6c 69 74 65 33 5f 73 74 6d 74  rop(sqlite3_stmt
2d40: 20 2a 73 74 6d 74 2c 20 69 6e 74 20 69 43 6f 6c   *stmt, int iCol
2d50: 2c 20 69 6e 74 20 2a 70 6c 65 6e 29 0d 0a 7b 0d  , int *plen)..{.
2d60: 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 70  .  const char *p
2d70: 76 61 6c 20 3d 20 73 71 6c 69 74 65 33 5f 63 6f  val = sqlite3_co
2d80: 6c 75 6d 6e 5f 74 61 62 6c 65 5f 6e 61 6d 65 28  lumn_table_name(
2d90: 73 74 6d 74 2c 20 69 43 6f 6c 29 3b 0d 0a 20 20  stmt, iCol);..  
2da0: 2a 70 6c 65 6e 20 3d 20 28 70 76 61 6c 20 21 3d  *plen = (pval !=
2db0: 20 30 29 20 3f 20 73 74 72 6c 65 6e 28 70 76 61   0) ? strlen(pva
2dc0: 6c 29 20 3a 20 30 3b 0d 0a 20 20 72 65 74 75 72  l) : 0;..  retur
2dd0: 6e 20 70 76 61 6c 3b 0d 0a 7d 0d 0a 0d 0a 53 51  n pval;..}....SQ
2de0: 4c 49 54 45 5f 41 50 49 20 63 6f 6e 73 74 20 76  LITE_API const v
2df0: 6f 69 64 20 2a 20 57 49 4e 41 50 49 20 73 71 6c  oid * WINAPI sql
2e00: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 61 62 6c  ite3_column_tabl
2e10: 65 5f 6e 61 6d 65 31 36 5f 69 6e 74 65 72 6f 70  e_name16_interop
2e20: 28 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 73  (sqlite3_stmt *s
2e30: 74 6d 74 2c 20 69 6e 74 20 69 43 6f 6c 2c 20 69  tmt, int iCol, i
2e40: 6e 74 20 2a 70 6c 65 6e 29 0d 0a 7b 0d 0a 20 20  nt *plen)..{..  
2e50: 63 6f 6e 73 74 20 76 6f 69 64 20 2a 70 76 61 6c  const void *pval
2e60: 20 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d   = sqlite3_colum
2e70: 6e 5f 74 61 62 6c 65 5f 6e 61 6d 65 31 36 28 73  n_table_name16(s
2e80: 74 6d 74 2c 20 69 43 6f 6c 29 3b 0d 0a 20 20 2a  tmt, iCol);..  *
2e90: 70 6c 65 6e 20 3d 20 28 70 76 61 6c 20 21 3d 20  plen = (pval != 
2ea0: 30 29 20 3f 20 77 63 73 6c 65 6e 28 28 77 63 68  0) ? wcslen((wch
2eb0: 61 72 5f 74 20 2a 29 70 76 61 6c 29 20 2a 20 73  ar_t *)pval) * s
2ec0: 69 7a 65 6f 66 28 77 63 68 61 72 5f 74 29 20 3a  izeof(wchar_t) :
2ed0: 20 30 3b 0d 0a 20 20 72 65 74 75 72 6e 20 70 76   0;..  return pv
2ee0: 61 6c 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45  al;..}....SQLITE
2ef0: 5f 41 50 49 20 63 6f 6e 73 74 20 63 68 61 72 20  _API const char 
2f00: 2a 20 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33  * WINAPI sqlite3
2f10: 5f 63 6f 6c 75 6d 6e 5f 6f 72 69 67 69 6e 5f 6e  _column_origin_n
2f20: 61 6d 65 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69  ame_interop(sqli
2f30: 74 65 33 5f 73 74 6d 74 20 2a 73 74 6d 74 2c 20  te3_stmt *stmt, 
2f40: 69 6e 74 20 69 43 6f 6c 2c 20 69 6e 74 20 2a 70  int iCol, int *p
2f50: 6c 65 6e 29 0d 0a 7b 0d 0a 20 20 63 6f 6e 73 74  len)..{..  const
2f60: 20 63 68 61 72 20 2a 70 76 61 6c 20 3d 20 73 71   char *pval = sq
2f70: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6f 72 69  lite3_column_ori
2f80: 67 69 6e 5f 6e 61 6d 65 28 73 74 6d 74 2c 20 69  gin_name(stmt, i
2f90: 43 6f 6c 29 3b 0d 0a 20 20 2a 70 6c 65 6e 20 3d  Col);..  *plen =
2fa0: 20 28 70 76 61 6c 20 21 3d 20 30 29 20 3f 20 73   (pval != 0) ? s
2fb0: 74 72 6c 65 6e 28 70 76 61 6c 29 20 3a 20 30 3b  trlen(pval) : 0;
2fc0: 0d 0a 20 20 72 65 74 75 72 6e 20 70 76 61 6c 3b  ..  return pval;
2fd0: 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50  ..}....SQLITE_AP
2fe0: 49 20 63 6f 6e 73 74 20 76 6f 69 64 20 2a 20 57  I const void * W
2ff0: 49 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 63 6f  INAPI sqlite3_co
3000: 6c 75 6d 6e 5f 6f 72 69 67 69 6e 5f 6e 61 6d 65  lumn_origin_name
3010: 31 36 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69 74  16_interop(sqlit
3020: 65 33 5f 73 74 6d 74 20 2a 73 74 6d 74 2c 20 69  e3_stmt *stmt, i
3030: 6e 74 20 69 43 6f 6c 2c 20 69 6e 74 20 2a 70 6c  nt iCol, int *pl
3040: 65 6e 29 0d 0a 7b 0d 0a 20 20 63 6f 6e 73 74 20  en)..{..  const 
3050: 76 6f 69 64 20 2a 70 76 61 6c 20 3d 20 73 71 6c  void *pval = sql
3060: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6f 72 69 67  ite3_column_orig
3070: 69 6e 5f 6e 61 6d 65 31 36 28 73 74 6d 74 2c 20  in_name16(stmt, 
3080: 69 43 6f 6c 29 3b 0d 0a 20 20 2a 70 6c 65 6e 20  iCol);..  *plen 
3090: 3d 20 28 70 76 61 6c 20 21 3d 20 30 29 20 3f 20  = (pval != 0) ? 
30a0: 77 63 73 6c 65 6e 28 28 77 63 68 61 72 5f 74 20  wcslen((wchar_t 
30b0: 2a 29 70 76 61 6c 29 20 2a 20 73 69 7a 65 6f 66  *)pval) * sizeof
30c0: 28 77 63 68 61 72 5f 74 29 20 3a 20 30 3b 0d 0a  (wchar_t) : 0;..
30d0: 20 20 72 65 74 75 72 6e 20 70 76 61 6c 3b 0d 0a    return pval;..
30e0: 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50 49 20  }....SQLITE_API 
30f0: 69 6e 74 20 57 49 4e 41 50 49 20 73 71 6c 69 74  int WINAPI sqlit
3100: 65 33 5f 74 61 62 6c 65 5f 63 6f 6c 75 6d 6e 5f  e3_table_column_
3110: 6d 65 74 61 64 61 74 61 5f 69 6e 74 65 72 6f 70  metadata_interop
3120: 28 73 71 6c 69 74 65 33 20 2a 64 62 2c 20 63 6f  (sqlite3 *db, co
3130: 6e 73 74 20 63 68 61 72 20 2a 7a 44 62 4e 61 6d  nst char *zDbNam
3140: 65 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  e, const char *z
3150: 54 61 62 6c 65 4e 61 6d 65 2c 20 63 6f 6e 73 74  TableName, const
3160: 20 63 68 61 72 20 2a 7a 43 6f 6c 75 6d 6e 4e 61   char *zColumnNa
3170: 6d 65 2c 20 63 68 61 72 20 2a 2a 70 7a 44 61 74  me, char **pzDat
3180: 61 54 79 70 65 2c 20 63 68 61 72 20 2a 2a 70 7a  aType, char **pz
3190: 43 6f 6c 6c 53 65 71 2c 20 69 6e 74 20 2a 70 4e  CollSeq, int *pN
31a0: 6f 74 4e 75 6c 6c 2c 20 69 6e 74 20 2a 70 50 72  otNull, int *pPr
31b0: 69 6d 61 72 79 4b 65 79 2c 20 69 6e 74 20 2a 70  imaryKey, int *p
31c0: 41 75 74 6f 69 6e 63 2c 20 69 6e 74 20 2a 70 64  Autoinc, int *pd
31d0: 74 4c 65 6e 2c 20 69 6e 74 20 2a 70 63 73 4c 65  tLen, int *pcsLe
31e0: 6e 29 0d 0a 7b 0d 0a 20 20 69 6e 74 20 6e 3b 0d  n)..{..  int n;.
31f0: 0a 20 20 0d 0a 20 20 6e 20 3d 20 73 71 6c 69 74  .  ..  n = sqlit
3200: 65 33 5f 74 61 62 6c 65 5f 63 6f 6c 75 6d 6e 5f  e3_table_column_
3210: 6d 65 74 61 64 61 74 61 28 64 62 2c 20 7a 44 62  metadata(db, zDb
3220: 4e 61 6d 65 2c 20 7a 54 61 62 6c 65 4e 61 6d 65  Name, zTableName
3230: 2c 20 7a 43 6f 6c 75 6d 6e 4e 61 6d 65 2c 20 70  , zColumnName, p
3240: 7a 44 61 74 61 54 79 70 65 2c 20 70 7a 43 6f 6c  zDataType, pzCol
3250: 6c 53 65 71 2c 20 70 4e 6f 74 4e 75 6c 6c 2c 20  lSeq, pNotNull, 
3260: 70 50 72 69 6d 61 72 79 4b 65 79 2c 20 70 41 75  pPrimaryKey, pAu
3270: 74 6f 69 6e 63 29 3b 0d 0a 20 20 2a 70 64 74 4c  toinc);..  *pdtL
3280: 65 6e 20 3d 20 28 2a 70 7a 44 61 74 61 54 79 70  en = (*pzDataTyp
3290: 65 20 21 3d 20 30 29 20 3f 20 73 74 72 6c 65 6e  e != 0) ? strlen
32a0: 28 2a 70 7a 44 61 74 61 54 79 70 65 29 20 3a 20  (*pzDataType) : 
32b0: 30 3b 0d 0a 20 20 2a 70 63 73 4c 65 6e 20 3d 20  0;..  *pcsLen = 
32c0: 28 2a 70 7a 43 6f 6c 6c 53 65 71 20 21 3d 20 30  (*pzCollSeq != 0
32d0: 29 20 3f 20 73 74 72 6c 65 6e 28 2a 70 7a 43 6f  ) ? strlen(*pzCo
32e0: 6c 6c 53 65 71 29 20 3a 20 30 3b 0d 0a 0d 0a 20  llSeq) : 0;.... 
32f0: 20 72 65 74 75 72 6e 20 6e 3b 0d 0a 7d 0d 0a 0d   return n;..}...
3300: 0a 53 51 4c 49 54 45 5f 41 50 49 20 69 6e 74 20  .SQLITE_API int 
3310: 57 49 4e 41 50 49 20 73 71 6c 69 74 65 33 5f 69  WINAPI sqlite3_i
3320: 6e 64 65 78 5f 63 6f 6c 75 6d 6e 5f 69 6e 66 6f  ndex_column_info
3330: 5f 69 6e 74 65 72 6f 70 28 73 71 6c 69 74 65 33  _interop(sqlite3
3340: 20 2a 64 62 2c 20 63 6f 6e 73 74 20 63 68 61 72   *db, const char
3350: 20 2a 7a 44 62 2c 20 63 6f 6e 73 74 20 63 68 61   *zDb, const cha
3360: 72 20 2a 7a 49 6e 64 65 78 4e 61 6d 65 2c 20 63  r *zIndexName, c
3370: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 43 6f 6c 75  onst char *zColu
3380: 6d 6e 4e 61 6d 65 2c 20 69 6e 74 20 2a 73 6f 72  mnName, int *sor
3390: 74 4f 72 64 65 72 2c 20 69 6e 74 20 2a 6f 6e 45  tOrder, int *onE
33a0: 72 72 6f 72 2c 20 63 68 61 72 20 2a 2a 70 7a 43  rror, char **pzC
33b0: 6f 6c 6c 2c 20 69 6e 74 20 2a 70 6c 65 6e 29 0d  oll, int *plen).
33c0: 0a 7b 0d 0a 20 20 49 6e 64 65 78 20 2a 70 49 64  .{..  Index *pId
33d0: 78 3b 0d 0a 20 20 54 61 62 6c 65 20 2a 70 54 61  x;..  Table *pTa
33e0: 62 3b 0d 0a 20 20 69 6e 74 20 6e 3b 0d 0a 0d 0a  b;..  int n;....
33f0: 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f    sqlite3_mutex_
3400: 65 6e 74 65 72 28 64 62 2d 3e 6d 75 74 65 78 29  enter(db->mutex)
3410: 3b 0a 20 20 73 71 6c 69 74 65 33 42 74 72 65 65  ;.  sqlite3Btree
3420: 45 6e 74 65 72 41 6c 6c 28 64 62 29 3b 0a 0d 0a  EnterAll(db);...
3430: 20 20 70 49 64 78 20 3d 20 73 71 6c 69 74 65 33    pIdx = sqlite3
3440: 46 69 6e 64 49 6e 64 65 78 28 64 62 2c 20 7a 49  FindIndex(db, zI
3450: 6e 64 65 78 4e 61 6d 65 2c 20 7a 44 62 29 3b 0d  ndexName, zDb);.
3460: 0a 0d 0a 20 20 73 71 6c 69 74 65 33 42 74 72 65  ...  sqlite3Btre
3470: 65 4c 65 61 76 65 41 6c 6c 28 64 62 29 3b 0a 20  eLeaveAll(db);. 
3480: 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c   sqlite3_mutex_l
3490: 65 61 76 65 28 64 62 2d 3e 6d 75 74 65 78 29 3b  eave(db->mutex);
34a0: 0a 0d 0a 20 20 69 66 20 28 21 70 49 64 78 29 20  ...  if (!pIdx) 
34b0: 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 45 52  return SQLITE_ER
34c0: 52 4f 52 3b 0d 0a 0d 0a 20 20 70 54 61 62 20 3d  ROR;....  pTab =
34d0: 20 70 49 64 78 2d 3e 70 54 61 62 6c 65 3b 0d 0a   pIdx->pTable;..
34e0: 20 20 66 6f 72 20 28 6e 20 3d 20 30 3b 20 6e 20    for (n = 0; n 
34f0: 3c 20 70 49 64 78 2d 3e 6e 43 6f 6c 75 6d 6e 3b  < pIdx->nColumn;
3500: 20 6e 2b 2b 29 0d 0a 20 20 7b 0d 0a 20 20 20 20   n++)..  {..    
3510: 69 6e 74 20 63 6e 75 6d 20 3d 20 70 49 64 78 2d  int cnum = pIdx-
3520: 3e 61 69 43 6f 6c 75 6d 6e 5b 6e 5d 3b 0d 0a 20  >aiColumn[n];.. 
3530: 20 20 20 69 66 20 28 73 71 6c 69 74 65 33 53 74     if (sqlite3St
3540: 72 49 43 6d 70 28 70 54 61 62 2d 3e 61 43 6f 6c  rICmp(pTab->aCol
3550: 5b 63 6e 75 6d 5d 2e 7a 4e 61 6d 65 2c 20 7a 43  [cnum].zName, zC
3560: 6f 6c 75 6d 6e 4e 61 6d 65 29 20 3d 3d 20 30 29  olumnName) == 0)
3570: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 2a  ..    {..      *
3580: 73 6f 72 74 4f 72 64 65 72 20 3d 20 70 49 64 78  sortOrder = pIdx
3590: 2d 3e 61 53 6f 72 74 4f 72 64 65 72 5b 6e 5d 3b  ->aSortOrder[n];
35a0: 0d 0a 20 20 20 20 20 20 2a 70 7a 43 6f 6c 6c 20  ..      *pzColl 
35b0: 3d 20 70 49 64 78 2d 3e 61 7a 43 6f 6c 6c 5b 6e  = pIdx->azColl[n
35c0: 5d 3b 0d 0a 20 20 20 20 20 20 2a 70 6c 65 6e 20  ];..      *plen 
35d0: 3d 20 73 74 72 6c 65 6e 28 2a 70 7a 43 6f 6c 6c  = strlen(*pzColl
35e0: 29 3b 0d 0a 20 20 20 20 20 20 2a 6f 6e 45 72 72  );..      *onErr
35f0: 6f 72 20 3d 20 70 49 64 78 2d 3e 6f 6e 45 72 72  or = pIdx->onErr
3600: 6f 72 3b 0d 0a 0d 0a 20 20 20 20 20 20 72 65 74  or;....      ret
3610: 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0d 0a  urn SQLITE_OK;..
3620: 20 20 20 20 7d 0d 0a 20 20 7d 0d 0a 20 20 72 65      }..  }..  re
3630: 74 75 72 6e 20 53 51 4c 49 54 45 5f 45 52 52 4f  turn SQLITE_ERRO
3640: 52 3b 0d 0a 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f  R;..}....SQLITE_
3650: 41 50 49 20 69 6e 74 20 57 49 4e 41 50 49 20 73  API int WINAPI s
3660: 71 6c 69 74 65 33 5f 74 61 62 6c 65 5f 63 75 72  qlite3_table_cur
3670: 73 6f 72 28 73 71 6c 69 74 65 33 5f 73 74 6d 74  sor(sqlite3_stmt
3680: 20 2a 70 73 74 6d 74 2c 20 69 6e 74 20 69 44 62   *pstmt, int iDb
3690: 2c 20 50 67 6e 6f 20 74 61 62 6c 65 52 6f 6f 74  , Pgno tableRoot
36a0: 50 61 67 65 29 0d 0a 7b 0d 0a 20 20 56 64 62 65  Page)..{..  Vdbe
36b0: 20 2a 70 20 3d 20 28 56 64 62 65 20 2a 29 70 73   *p = (Vdbe *)ps
36c0: 74 6d 74 3b 0d 0a 20 20 73 71 6c 69 74 65 33 20  tmt;..  sqlite3 
36d0: 2a 64 62 20 3d 20 28 70 20 3d 3d 20 4e 55 4c 4c  *db = (p == NULL
36e0: 29 20 3f 20 4e 55 4c 4c 20 3a 20 70 2d 3e 64 62  ) ? NULL : p->db
36f0: 3b 0d 0a 20 20 69 6e 74 20 6e 3b 0d 0a 20 20 69  ;..  int n;..  i
3700: 6e 74 20 72 65 74 20 3d 20 2d 31 3b 0d 0a 0d 0a  nt ret = -1;....
3710: 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f    sqlite3_mutex_
3720: 65 6e 74 65 72 28 64 62 2d 3e 6d 75 74 65 78 29  enter(db->mutex)
3730: 3b 0d 0a 20 20 66 6f 72 20 28 6e 20 3d 20 30 3b  ;..  for (n = 0;
3740: 20 6e 20 3c 20 70 2d 3e 6e 43 75 72 73 6f 72 20   n < p->nCursor 
3750: 26 26 20 70 2d 3e 61 70 43 73 72 5b 6e 5d 20 21  && p->apCsr[n] !
3760: 3d 20 4e 55 4c 4c 3b 20 6e 2b 2b 29 0d 0a 20 20  = NULL; n++)..  
3770: 7b 0d 0a 20 20 20 20 69 66 20 28 70 2d 3e 61 70  {..    if (p->ap
3780: 43 73 72 5b 6e 5d 2d 3e 69 73 54 61 62 6c 65 20  Csr[n]->isTable 
3790: 3d 3d 20 46 41 4c 53 45 29 20 63 6f 6e 74 69 6e  == FALSE) contin
37a0: 75 65 3b 0d 0a 20 20 20 20 69 66 20 28 70 2d 3e  ue;..    if (p->
37b0: 61 70 43 73 72 5b 6e 5d 2d 3e 69 44 62 20 21 3d  apCsr[n]->iDb !=
37c0: 20 69 44 62 29 20 63 6f 6e 74 69 6e 75 65 3b 0d   iDb) continue;.
37d0: 0a 20 20 20 20 69 66 20 28 70 2d 3e 61 70 43 73  .    if (p->apCs
37e0: 72 5b 6e 5d 2d 3e 70 43 75 72 73 6f 72 2d 3e 70  r[n]->pCursor->p
37f0: 67 6e 6f 52 6f 6f 74 20 3d 3d 20 74 61 62 6c 65  gnoRoot == table
3800: 52 6f 6f 74 50 61 67 65 29 0d 0a 20 20 20 20 7b  RootPage)..    {
3810: 0d 0a 20 20 20 20 20 20 72 65 74 20 3d 20 6e 3b  ..      ret = n;
3820: 0d 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0d 0a  ..      break;..
3830: 20 20 20 20 7d 0d 0a 20 20 7d 0d 0a 20 20 73 71      }..  }..  sq
3840: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76  lite3_mutex_leav
3850: 65 28 64 62 2d 3e 6d 75 74 65 78 29 3b 0d 0a 0d  e(db->mutex);...
3860: 0a 20 20 72 65 74 75 72 6e 20 72 65 74 3b 0d 0a  .  return ret;..
3870: 7d 0d 0a 0d 0a 53 51 4c 49 54 45 5f 41 50 49 20  }....SQLITE_API 
3880: 69 6e 74 20 57 49 4e 41 50 49 20 73 71 6c 69 74  int WINAPI sqlit
3890: 65 33 5f 63 75 72 73 6f 72 5f 72 6f 77 69 64 28  e3_cursor_rowid(
38a0: 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70 73  sqlite3_stmt *ps
38b0: 74 6d 74 2c 20 69 6e 74 20 63 75 72 73 6f 72 2c  tmt, int cursor,
38c0: 20 73 71 6c 69 74 65 5f 69 6e 74 36 34 20 2a 70   sqlite_int64 *p
38d0: 72 6f 77 69 64 29 0d 0a 7b 0d 0a 20 20 56 64 62  rowid)..{..  Vdb
38e0: 65 20 2a 70 20 3d 20 28 56 64 62 65 20 2a 29 70  e *p = (Vdbe *)p
38f0: 73 74 6d 74 3b 0d 0a 20 20 73 71 6c 69 74 65 33  stmt;..  sqlite3
3900: 20 2a 64 62 20 3d 20 28 70 20 3d 3d 20 4e 55 4c   *db = (p == NUL
3910: 4c 29 20 3f 20 4e 55 4c 4c 20 3a 20 70 2d 3e 64  L) ? NULL : p->d
3920: 62 3b 0d 0a 20 20 56 64 62 65 43 75 72 73 6f 72  b;..  VdbeCursor
3930: 20 2a 70 43 3b 0d 0a 20 20 69 6e 74 20 72 65 74   *pC;..  int ret
3940: 20 3d 20 30 3b 0d 0a 0d 0a 20 20 73 71 6c 69 74   = 0;....  sqlit
3950: 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28 64  e3_mutex_enter(d
3960: 62 2d 3e 6d 75 74 65 78 29 3b 0d 0a 20 20 77 68  b->mutex);..  wh
3970: 69 6c 65 20 28 31 29 0d 0a 20 20 7b 0d 0a 20 20  ile (1)..  {..  
3980: 20 20 69 66 20 28 63 75 72 73 6f 72 20 3c 20 30    if (cursor < 0
3990: 20 7c 7c 20 63 75 72 73 6f 72 20 3e 3d 20 70 2d   || cursor >= p-
39a0: 3e 6e 43 75 72 73 6f 72 29 0d 0a 20 20 20 20 7b  >nCursor)..    {
39b0: 0d 0a 20 20 20 20 20 20 72 65 74 20 3d 20 53 51  ..      ret = SQ
39c0: 4c 49 54 45 5f 45 52 52 4f 52 3b 0d 0a 20 20 20  LITE_ERROR;..   
39d0: 20 20 20 62 72 65 61 6b 3b 0d 0a 20 20 20 20 7d     break;..    }
39e0: 0d 0a 20 20 20 20 69 66 20 28 70 2d 3e 61 70 43  ..    if (p->apC
39f0: 73 72 5b 63 75 72 73 6f 72 5d 20 3d 3d 20 4e 55  sr[cursor] == NU
3a00: 4c 4c 29 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20  LL)..    {..    
3a10: 20 20 72 65 74 20 3d 20 53 51 4c 49 54 45 5f 45    ret = SQLITE_E
3a20: 52 52 4f 52 3b 0d 0a 20 20 20 20 20 20 62 72 65  RROR;..      bre
3a30: 61 6b 3b 0d 0a 20 20 20 20 7d 0d 0a 0d 0a 20 20  ak;..    }....  
3a40: 20 20 70 43 20 3d 20 70 2d 3e 61 70 43 73 72 5b    pC = p->apCsr[
3a50: 63 75 72 73 6f 72 5d 3b 0d 0a 0d 0a 20 20 20 20  cursor];....    
3a60: 72 65 74 20 3d 20 73 71 6c 69 74 65 33 56 64 62  ret = sqlite3Vdb
3a70: 65 43 75 72 73 6f 72 4d 6f 76 65 74 6f 28 70 43  eCursorMoveto(pC
3a80: 29 3b 0d 0a 20 20 20 20 69 66 28 72 65 74 29 0d  );..    if(ret).
3a90: 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0d 0a 0d  .      break;...
3aa0: 0a 20 20 20 20 69 66 28 70 43 2d 3e 72 6f 77 69  .    if(pC->rowi
3ab0: 64 49 73 56 61 6c 69 64 29 0d 0a 20 20 20 20 7b  dIsValid)..    {
3ac0: 0d 0a 20 20 20 20 20 20 2a 70 72 6f 77 69 64 20  ..      *prowid 
3ad0: 3d 20 70 43 2d 3e 6c 61 73 74 52 6f 77 69 64 3b  = pC->lastRowid;
3ae0: 0d 0a 20 20 20 20 7d 0d 0a 20 20 20 20 65 6c 73  ..    }..    els
3af0: 65 20 69 66 28 70 43 2d 3e 70 73 65 75 64 6f 54  e if(pC->pseudoT
3b00: 61 62 6c 65 52 65 67 20 3e 20 30 29 0d 0a 20 20  ableReg > 0)..  
3b10: 20 20 7b 0d 0a 20 20 20 20 20 20 72 65 74 20 3d    {..      ret =
3b20: 20 53 51 4c 49 54 45 5f 45 52 52 4f 52 3b 0d 0a   SQLITE_ERROR;..
3b30: 20 20 20 20 20 20 62 72 65 61 6b 3b 0d 0a 20 20        break;..  
3b40: 20 20 7d 0d 0a 20 20 20 20 65 6c 73 65 20 69 66    }..    else if
3b50: 28 70 43 2d 3e 6e 75 6c 6c 52 6f 77 20 7c 7c 20  (pC->nullRow || 
3b60: 70 43 2d 3e 70 43 75 72 73 6f 72 3d 3d 30 29 0d  pC->pCursor==0).
3b70: 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 72 65  .    {..      re
3b80: 74 20 3d 20 53 51 4c 49 54 45 5f 45 52 52 4f 52  t = SQLITE_ERROR
3b90: 3b 0d 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0d  ;..      break;.
3ba0: 0a 20 20 20 20 7d 0d 0a 20 20 20 20 65 6c 73 65  .    }..    else
3bb0: 0d 0a 20 20 20 20 7b 0d 0a 20 20 20 20 20 20 69  ..    {..      i
3bc0: 66 20 28 70 43 2d 3e 70 43 75 72 73 6f 72 20 3d  f (pC->pCursor =
3bd0: 3d 20 4e 55 4c 4c 29 0d 0a 20 20 20 20 20 20 7b  = NULL)..      {
3be0: 0d 0a 20 20 20 20 20 20 20 20 72 65 74 20 3d 20  ..        ret = 
3bf0: 53 51 4c 49 54 45 5f 45 52 52 4f 52 3b 0d 0a 20  SQLITE_ERROR;.. 
3c00: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0d 0a 20         break;.. 
3c10: 20 20 20 20 20 7d 0d 0a 20 20 20 20 20 20 73 71       }..      sq
3c20: 6c 69 74 65 33 42 74 72 65 65 4b 65 79 53 69 7a  lite3BtreeKeySiz
3c30: 65 28 70 43 2d 3e 70 43 75 72 73 6f 72 2c 20 70  e(pC->pCursor, p
3c40: 72 6f 77 69 64 29 3b 0d 0a 20 20 20 20 20 20 2a  rowid);..      *
3c50: 70 72 6f 77 69 64 20 3d 20 2a 70 72 6f 77 69 64  prowid = *prowid
3c60: 3b 0d 0a 20 20 20 20 7d 0d 0a 20 20 20 20 62 72  ;..    }..    br
3c70: 65 61 6b 3b 0d 0a 20 20 7d 0d 0a 20 20 73 71 6c  eak;..  }..  sql
3c80: 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65  ite3_mutex_leave
3c90: 28 64 62 2d 3e 6d 75 74 65 78 29 3b 0d 0a 0d 0a  (db->mutex);....
3ca0: 20 20 72 65 74 75 72 6e 20 72 65 74 3b 0d 0a 7d    return ret;..}
3cb0: 0d 0a 0d 0a 23 65 6e 64 69 66 20 2f 2f 20 53 51  ....#endif // SQ
3cc0: 4c 49 54 45 5f 4f 53 5f 57 49 4e 0d 0a           LITE_OS_WIN..