/ Hex Artifact Content
Login

Artifact ae0eed9fa96d74172d2a90ee63b5bc36d284295c:


0000: 2f 2a 0a 2a 2a 20 32 30 30 36 20 4a 75 6e 65 20  /*.** 2006 June 
0010: 37 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74 68  7.**.** The auth
0020: 6f 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70  or disclaims cop
0030: 79 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73  yright to this s
0040: 6f 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20  ource code.  In 
0050: 70 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c 65  place of.** a le
0060: 67 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65  gal notice, here
0070: 20 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a   is a blessing:.
0080: 2a 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f 75  **.**    May you
0090: 20 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74   do good and not
00a0: 20 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61 79   evil..**    May
00b0: 20 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69 76   you find forgiv
00c0: 65 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73 65  eness for yourse
00d0: 6c 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20 6f  lf and forgive o
00e0: 74 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61 79  thers..**    May
00f0: 20 79 6f 75 20 73 68 61 72 65 20 66 72 65 65 6c   you share freel
0100: 79 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67 20  y, never taking 
0110: 6d 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67 69  more than you gi
0120: 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ve..**.*********
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0170: 0a 2a 2a 20 54 68 69 73 20 66 69 6c 65 20 63 6f  .** This file co
0180: 6e 74 61 69 6e 73 20 63 6f 64 65 20 75 73 65 64  ntains code used
0190: 20 74 6f 20 64 79 6e 61 6d 69 63 61 6c 6c 79 20   to dynamically 
01a0: 6c 6f 61 64 20 65 78 74 65 6e 73 69 6f 6e 73 20  load extensions 
01b0: 69 6e 74 6f 0a 2a 2a 20 74 68 65 20 53 51 4c 69  into.** the SQLi
01c0: 74 65 20 6c 69 62 72 61 72 79 2e 0a 2a 2a 0a 2a  te library..**.*
01d0: 2a 20 24 49 64 3a 20 6c 6f 61 64 65 78 74 2e 63  * $Id: loadext.c
01e0: 2c 76 20 31 2e 35 31 20 32 30 30 38 2f 30 37 2f  ,v 1.51 2008/07/
01f0: 30 38 20 31 34 3a 31 37 3a 33 35 20 64 61 6e 69  08 14:17:35 dani
0200: 65 6c 6b 31 39 37 37 20 45 78 70 20 24 0a 2a 2f  elk1977 Exp $.*/
0210: 0a 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45  ..#ifndef SQLITE
0220: 5f 43 4f 52 45 0a 20 20 23 64 65 66 69 6e 65 20  _CORE.  #define 
0230: 53 51 4c 49 54 45 5f 43 4f 52 45 20 31 20 20 2f  SQLITE_CORE 1  /
0240: 2a 20 44 69 73 61 62 6c 65 20 74 68 65 20 41 50  * Disable the AP
0250: 49 20 72 65 64 65 66 69 6e 69 74 69 6f 6e 20 69  I redefinition i
0260: 6e 20 73 71 6c 69 74 65 33 65 78 74 2e 68 20 2a  n sqlite3ext.h *
0270: 2f 0a 23 65 6e 64 69 66 0a 23 69 6e 63 6c 75 64  /.#endif.#includ
0280: 65 20 22 73 71 6c 69 74 65 33 65 78 74 2e 68 22  e "sqlite3ext.h"
0290: 0a 23 69 6e 63 6c 75 64 65 20 22 73 71 6c 69 74  .#include "sqlit
02a0: 65 49 6e 74 2e 68 22 0a 23 69 6e 63 6c 75 64 65  eInt.h".#include
02b0: 20 3c 73 74 72 69 6e 67 2e 68 3e 0a 23 69 6e 63   <string.h>.#inc
02c0: 6c 75 64 65 20 3c 63 74 79 70 65 2e 68 3e 0a 0a  lude <ctype.h>..
02d0: 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f  #ifndef SQLITE_O
02e0: 4d 49 54 5f 4c 4f 41 44 5f 45 58 54 45 4e 53 49  MIT_LOAD_EXTENSI
02f0: 4f 4e 0a 0a 2f 2a 0a 2a 2a 20 53 6f 6d 65 20 41  ON../*.** Some A
0300: 50 49 20 72 6f 75 74 69 6e 65 73 20 61 72 65 20  PI routines are 
0310: 6f 6d 69 74 74 65 64 20 77 68 65 6e 20 76 61 72  omitted when var
0320: 69 6f 75 73 20 66 65 61 74 75 72 65 73 20 61 72  ious features ar
0330: 65 0a 2a 2a 20 65 78 63 6c 75 64 65 64 20 66 72  e.** excluded fr
0340: 6f 6d 20 61 20 62 75 69 6c 64 20 6f 66 20 53 51  om a build of SQ
0350: 4c 69 74 65 2e 20 20 53 75 62 73 74 69 74 75 74  Lite.  Substitut
0360: 65 20 61 20 4e 55 4c 4c 20 70 6f 69 6e 74 65 72  e a NULL pointer
0370: 0a 2a 2a 20 66 6f 72 20 61 6e 79 20 6d 69 73 73  .** for any miss
0380: 69 6e 67 20 41 50 49 73 2e 0a 2a 2f 0a 23 69 66  ing APIs..*/.#if
0390: 6e 64 65 66 20 53 51 4c 49 54 45 5f 45 4e 41 42  ndef SQLITE_ENAB
03a0: 4c 45 5f 43 4f 4c 55 4d 4e 5f 4d 45 54 41 44 41  LE_COLUMN_METADA
03b0: 54 41 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69  TA.# define sqli
03c0: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 61 74 61 62  te3_column_datab
03d0: 61 73 65 5f 6e 61 6d 65 20 20 20 30 0a 23 20 64  ase_name   0.# d
03e0: 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 63 6f  efine sqlite3_co
03f0: 6c 75 6d 6e 5f 64 61 74 61 62 61 73 65 5f 6e 61  lumn_database_na
0400: 6d 65 31 36 20 30 0a 23 20 64 65 66 69 6e 65 20  me16 0.# define 
0410: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74  sqlite3_column_t
0420: 61 62 6c 65 5f 6e 61 6d 65 20 20 20 20 20 20 30  able_name      0
0430: 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65  .# define sqlite
0440: 33 5f 63 6f 6c 75 6d 6e 5f 74 61 62 6c 65 5f 6e  3_column_table_n
0450: 61 6d 65 31 36 20 20 20 20 30 0a 23 20 64 65 66  ame16    0.# def
0460: 69 6e 65 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75  ine sqlite3_colu
0470: 6d 6e 5f 6f 72 69 67 69 6e 5f 6e 61 6d 65 20 20  mn_origin_name  
0480: 20 20 20 30 0a 23 20 64 65 66 69 6e 65 20 73 71     0.# define sq
0490: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6f 72 69  lite3_column_ori
04a0: 67 69 6e 5f 6e 61 6d 65 31 36 20 20 20 30 0a 23  gin_name16   0.#
04b0: 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f   define sqlite3_
04c0: 74 61 62 6c 65 5f 63 6f 6c 75 6d 6e 5f 6d 65 74  table_column_met
04d0: 61 64 61 74 61 20 20 30 0a 23 65 6e 64 69 66 0a  adata  0.#endif.
04e0: 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 4f  .#ifdef SQLITE_O
04f0: 4d 49 54 5f 41 55 54 48 4f 52 49 5a 41 54 49 4f  MIT_AUTHORIZATIO
0500: 4e 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69 74  N.# define sqlit
0510: 65 33 5f 73 65 74 5f 61 75 74 68 6f 72 69 7a 65  e3_set_authorize
0520: 72 20 20 20 20 20 20 20 20 20 30 0a 23 65 6e 64  r         0.#end
0530: 69 66 0a 0a 23 69 66 64 65 66 20 53 51 4c 49 54  if..#ifdef SQLIT
0540: 45 5f 4f 4d 49 54 5f 55 54 46 31 36 0a 23 20 64  E_OMIT_UTF16.# d
0550: 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 62 69  efine sqlite3_bi
0560: 6e 64 5f 74 65 78 74 31 36 20 20 20 20 20 20 20  nd_text16       
0570: 20 20 20 20 20 30 0a 23 20 64 65 66 69 6e 65 20       0.# define 
0580: 73 71 6c 69 74 65 33 5f 63 6f 6c 6c 61 74 69 6f  sqlite3_collatio
0590: 6e 5f 6e 65 65 64 65 64 31 36 20 20 20 20 20 30  n_needed16     0
05a0: 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65  .# define sqlite
05b0: 33 5f 63 6f 6c 75 6d 6e 5f 64 65 63 6c 74 79 70  3_column_decltyp
05c0: 65 31 36 20 20 20 20 20 20 30 0a 23 20 64 65 66  e16      0.# def
05d0: 69 6e 65 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75  ine sqlite3_colu
05e0: 6d 6e 5f 6e 61 6d 65 31 36 20 20 20 20 20 20 20  mn_name16       
05f0: 20 20 20 30 0a 23 20 64 65 66 69 6e 65 20 73 71     0.# define sq
0600: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78  lite3_column_tex
0610: 74 31 36 20 20 20 20 20 20 20 20 20 20 30 0a 23  t16          0.#
0620: 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f   define sqlite3_
0630: 63 6f 6d 70 6c 65 74 65 31 36 20 20 20 20 20 20  complete16      
0640: 20 20 20 20 20 20 20 30 0a 23 20 64 65 66 69 6e         0.# defin
0650: 65 20 73 71 6c 69 74 65 33 5f 63 72 65 61 74 65  e sqlite3_create
0660: 5f 63 6f 6c 6c 61 74 69 6f 6e 31 36 20 20 20 20  _collation16    
0670: 20 30 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69   0.# define sqli
0680: 74 65 33 5f 63 72 65 61 74 65 5f 66 75 6e 63 74  te3_create_funct
0690: 69 6f 6e 31 36 20 20 20 20 20 20 30 0a 23 20 64  ion16      0.# d
06a0: 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 65 72  efine sqlite3_er
06b0: 72 6d 73 67 31 36 20 20 20 20 20 20 20 20 20 20  rmsg16          
06c0: 20 20 20 20 20 30 0a 23 20 64 65 66 69 6e 65 20       0.# define 
06d0: 73 71 6c 69 74 65 33 5f 6f 70 65 6e 31 36 20 20  sqlite3_open16  
06e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 30                 0
06f0: 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65  .# define sqlite
0700: 33 5f 70 72 65 70 61 72 65 31 36 20 20 20 20 20  3_prepare16     
0710: 20 20 20 20 20 20 20 20 20 30 0a 23 20 64 65 66           0.# def
0720: 69 6e 65 20 73 71 6c 69 74 65 33 5f 70 72 65 70  ine sqlite3_prep
0730: 61 72 65 31 36 5f 76 32 20 20 20 20 20 20 20 20  are16_v2        
0740: 20 20 20 30 0a 23 20 64 65 66 69 6e 65 20 73 71     0.# define sq
0750: 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 65 72 72  lite3_result_err
0760: 6f 72 31 36 20 20 20 20 20 20 20 20 20 30 0a 23  or16         0.#
0770: 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f   define sqlite3_
0780: 72 65 73 75 6c 74 5f 74 65 78 74 31 36 20 20 20  result_text16   
0790: 20 20 20 20 20 20 20 30 0a 23 20 64 65 66 69 6e         0.# defin
07a0: 65 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74  e sqlite3_result
07b0: 5f 74 65 78 74 31 36 62 65 20 20 20 20 20 20 20  _text16be       
07c0: 20 30 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69   0.# define sqli
07d0: 74 65 33 5f 72 65 73 75 6c 74 5f 74 65 78 74 31  te3_result_text1
07e0: 36 6c 65 20 20 20 20 20 20 20 20 30 0a 23 20 64  6le        0.# d
07f0: 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 76 61  efine sqlite3_va
0800: 6c 75 65 5f 74 65 78 74 31 36 20 20 20 20 20 20  lue_text16      
0810: 20 20 20 20 20 30 0a 23 20 64 65 66 69 6e 65 20       0.# define 
0820: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 65  sqlite3_value_te
0830: 78 74 31 36 62 65 20 20 20 20 20 20 20 20 20 30  xt16be         0
0840: 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65  .# define sqlite
0850: 33 5f 76 61 6c 75 65 5f 74 65 78 74 31 36 6c 65  3_value_text16le
0860: 20 20 20 20 20 20 20 20 20 30 0a 23 20 64 65 66           0.# def
0870: 69 6e 65 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75  ine sqlite3_colu
0880: 6d 6e 5f 64 61 74 61 62 61 73 65 5f 6e 61 6d 65  mn_database_name
0890: 31 36 20 30 0a 23 20 64 65 66 69 6e 65 20 73 71  16 0.# define sq
08a0: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 61 62  lite3_column_tab
08b0: 6c 65 5f 6e 61 6d 65 31 36 20 20 20 20 30 0a 23  le_name16    0.#
08c0: 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f   define sqlite3_
08d0: 63 6f 6c 75 6d 6e 5f 6f 72 69 67 69 6e 5f 6e 61  column_origin_na
08e0: 6d 65 31 36 20 20 20 30 0a 23 65 6e 64 69 66 0a  me16   0.#endif.
08f0: 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 4f  .#ifdef SQLITE_O
0900: 4d 49 54 5f 43 4f 4d 50 4c 45 54 45 0a 23 20 64  MIT_COMPLETE.# d
0910: 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 63 6f  efine sqlite3_co
0920: 6d 70 6c 65 74 65 20 30 0a 23 20 64 65 66 69 6e  mplete 0.# defin
0930: 65 20 73 71 6c 69 74 65 33 5f 63 6f 6d 70 6c 65  e sqlite3_comple
0940: 74 65 31 36 20 30 0a 23 65 6e 64 69 66 0a 0a 23  te16 0.#endif..#
0950: 69 66 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49  ifdef SQLITE_OMI
0960: 54 5f 50 52 4f 47 52 45 53 53 5f 43 41 4c 4c 42  T_PROGRESS_CALLB
0970: 41 43 4b 0a 23 20 64 65 66 69 6e 65 20 73 71 6c  ACK.# define sql
0980: 69 74 65 33 5f 70 72 6f 67 72 65 73 73 5f 68 61  ite3_progress_ha
0990: 6e 64 6c 65 72 20 30 0a 23 65 6e 64 69 66 0a 0a  ndler 0.#endif..
09a0: 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d  #ifdef SQLITE_OM
09b0: 49 54 5f 56 49 52 54 55 41 4c 54 41 42 4c 45 0a  IT_VIRTUALTABLE.
09c0: 23 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65 33  # define sqlite3
09d0: 5f 63 72 65 61 74 65 5f 6d 6f 64 75 6c 65 20 30  _create_module 0
09e0: 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65  .# define sqlite
09f0: 33 5f 63 72 65 61 74 65 5f 6d 6f 64 75 6c 65 5f  3_create_module_
0a00: 76 32 20 30 0a 23 20 64 65 66 69 6e 65 20 73 71  v2 0.# define sq
0a10: 6c 69 74 65 33 5f 64 65 63 6c 61 72 65 5f 76 74  lite3_declare_vt
0a20: 61 62 20 30 0a 23 65 6e 64 69 66 0a 0a 23 69 66  ab 0.#endif..#if
0a30: 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  def SQLITE_OMIT_
0a40: 53 48 41 52 45 44 5f 43 41 43 48 45 0a 23 20 64  SHARED_CACHE.# d
0a50: 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 65 6e  efine sqlite3_en
0a60: 61 62 6c 65 5f 73 68 61 72 65 64 5f 63 61 63 68  able_shared_cach
0a70: 65 20 30 0a 23 65 6e 64 69 66 0a 0a 23 69 66 64  e 0.#endif..#ifd
0a80: 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 54  ef SQLITE_OMIT_T
0a90: 52 41 43 45 0a 23 20 64 65 66 69 6e 65 20 73 71  RACE.# define sq
0aa0: 6c 69 74 65 33 5f 70 72 6f 66 69 6c 65 20 20 20  lite3_profile   
0ab0: 20 20 20 20 30 0a 23 20 64 65 66 69 6e 65 20 73      0.# define s
0ac0: 71 6c 69 74 65 33 5f 74 72 61 63 65 20 20 20 20  qlite3_trace    
0ad0: 20 20 20 20 20 30 0a 23 65 6e 64 69 66 0a 0a 23       0.#endif..#
0ae0: 69 66 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49  ifdef SQLITE_OMI
0af0: 54 5f 47 45 54 5f 54 41 42 4c 45 0a 23 20 64 65  T_GET_TABLE.# de
0b00: 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 66 72 65  fine sqlite3_fre
0b10: 65 5f 74 61 62 6c 65 20 20 20 20 30 0a 23 20 64  e_table    0.# d
0b20: 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 67 65  efine sqlite3_ge
0b30: 74 5f 74 61 62 6c 65 20 20 20 20 20 30 0a 23 65  t_table     0.#e
0b40: 6e 64 69 66 0a 0a 23 69 66 64 65 66 20 53 51 4c  ndif..#ifdef SQL
0b50: 49 54 45 5f 4f 4d 49 54 5f 49 4e 43 52 42 4c 4f  ITE_OMIT_INCRBLO
0b60: 42 0a 23 64 65 66 69 6e 65 20 73 71 6c 69 74 65  B.#define sqlite
0b70: 33 5f 62 69 6e 64 5f 7a 65 72 6f 62 6c 6f 62 20  3_bind_zeroblob 
0b80: 20 30 0a 23 64 65 66 69 6e 65 20 73 71 6c 69 74   0.#define sqlit
0b90: 65 33 5f 62 6c 6f 62 5f 62 79 74 65 73 20 20 20  e3_blob_bytes   
0ba0: 20 20 30 0a 23 64 65 66 69 6e 65 20 73 71 6c 69    0.#define sqli
0bb0: 74 65 33 5f 62 6c 6f 62 5f 63 6c 6f 73 65 20 20  te3_blob_close  
0bc0: 20 20 20 30 0a 23 64 65 66 69 6e 65 20 73 71 6c     0.#define sql
0bd0: 69 74 65 33 5f 62 6c 6f 62 5f 6f 70 65 6e 20 20  ite3_blob_open  
0be0: 20 20 20 20 30 0a 23 64 65 66 69 6e 65 20 73 71      0.#define sq
0bf0: 6c 69 74 65 33 5f 62 6c 6f 62 5f 72 65 61 64 20  lite3_blob_read 
0c00: 20 20 20 20 20 30 0a 23 64 65 66 69 6e 65 20 73       0.#define s
0c10: 71 6c 69 74 65 33 5f 62 6c 6f 62 5f 77 72 69 74  qlite3_blob_writ
0c20: 65 20 20 20 20 20 30 0a 23 65 6e 64 69 66 0a 0a  e     0.#endif..
0c30: 2f 2a 0a 2a 2a 20 54 68 65 20 66 6f 6c 6c 6f 77  /*.** The follow
0c40: 69 6e 67 20 73 74 72 75 63 74 75 72 65 20 63 6f  ing structure co
0c50: 6e 74 61 69 6e 73 20 70 6f 69 6e 74 65 72 73 20  ntains pointers 
0c60: 74 6f 20 61 6c 6c 20 53 51 4c 69 74 65 20 41 50  to all SQLite AP
0c70: 49 20 72 6f 75 74 69 6e 65 73 2e 0a 2a 2a 20 41  I routines..** A
0c80: 20 70 6f 69 6e 74 65 72 20 74 6f 20 74 68 69 73   pointer to this
0c90: 20 73 74 72 75 63 74 75 72 65 20 69 73 20 70 61   structure is pa
0ca0: 73 73 65 64 20 69 6e 74 6f 20 65 78 74 65 6e 73  ssed into extens
0cb0: 69 6f 6e 73 20 77 68 65 6e 20 74 68 65 79 20 61  ions when they a
0cc0: 72 65 0a 2a 2a 20 6c 6f 61 64 65 64 20 73 6f 20  re.** loaded so 
0cd0: 74 68 61 74 20 74 68 65 20 65 78 74 65 6e 73 69  that the extensi
0ce0: 6f 6e 20 63 61 6e 20 6d 61 6b 65 20 63 61 6c 6c  on can make call
0cf0: 73 20 62 61 63 6b 20 69 6e 74 6f 20 74 68 65 20  s back into the 
0d00: 53 51 4c 69 74 65 0a 2a 2a 20 6c 69 62 72 61 72  SQLite.** librar
0d10: 79 2e 0a 2a 2a 0a 2a 2a 20 57 68 65 6e 20 61 64  y..**.** When ad
0d20: 64 69 6e 67 20 6e 65 77 20 41 50 49 73 2c 20 61  ding new APIs, a
0d30: 64 64 20 74 68 65 6d 20 74 6f 20 74 68 65 20 62  dd them to the b
0d40: 6f 74 74 6f 6d 20 6f 66 20 74 68 69 73 20 73 74  ottom of this st
0d50: 72 75 63 74 75 72 65 0a 2a 2a 20 69 6e 20 6f 72  ructure.** in or
0d60: 64 65 72 20 74 6f 20 70 72 65 73 65 72 76 65 20  der to preserve 
0d70: 62 61 63 6b 77 61 72 64 73 20 63 6f 6d 70 61 74  backwards compat
0d80: 69 62 69 6c 69 74 79 2e 0a 2a 2a 0a 2a 2a 20 45  ibility..**.** E
0d90: 78 74 65 6e 73 69 6f 6e 73 20 74 68 61 74 20 75  xtensions that u
0da0: 73 65 20 6e 65 77 65 72 20 41 50 49 73 20 73 68  se newer APIs sh
0db0: 6f 75 6c 64 20 66 69 72 73 74 20 63 61 6c 6c 20  ould first call 
0dc0: 74 68 65 0a 2a 2a 20 73 71 6c 69 74 65 33 5f 6c  the.** sqlite3_l
0dd0: 69 62 76 65 72 73 69 6f 6e 5f 6e 75 6d 62 65 72  ibversion_number
0de0: 28 29 20 74 6f 20 6d 61 6b 65 20 73 75 72 65 20  () to make sure 
0df0: 74 68 61 74 20 74 68 65 20 41 50 49 20 74 68 65  that the API the
0e00: 79 0a 2a 2a 20 69 6e 74 65 6e 64 20 74 6f 20 75  y.** intend to u
0e10: 73 65 20 69 73 20 73 75 70 70 6f 72 74 65 64 20  se is supported 
0e20: 62 79 20 74 68 65 20 6c 69 62 72 61 72 79 2e 20  by the library. 
0e30: 20 45 78 74 65 6e 73 69 6f 6e 73 20 73 68 6f 75   Extensions shou
0e40: 6c 64 0a 2a 2a 20 61 6c 73 6f 20 63 68 65 63 6b  ld.** also check
0e50: 20 74 6f 20 6d 61 6b 65 20 73 75 72 65 20 74 68   to make sure th
0e60: 61 74 20 74 68 65 20 70 6f 69 6e 74 65 72 20 74  at the pointer t
0e70: 6f 20 74 68 65 20 66 75 6e 63 74 69 6f 6e 20 69  o the function i
0e80: 73 0a 2a 2a 20 6e 6f 74 20 4e 55 4c 4c 20 62 65  s.** not NULL be
0e90: 66 6f 72 65 20 63 61 6c 6c 69 6e 67 20 69 74 2e  fore calling it.
0ea0: 0a 2a 2f 0a 73 74 61 74 69 63 20 63 6f 6e 73 74  .*/.static const
0eb0: 20 73 71 6c 69 74 65 33 5f 61 70 69 5f 72 6f 75   sqlite3_api_rou
0ec0: 74 69 6e 65 73 20 73 71 6c 69 74 65 33 41 70 69  tines sqlite3Api
0ed0: 73 20 3d 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f  s = {.  sqlite3_
0ee0: 61 67 67 72 65 67 61 74 65 5f 63 6f 6e 74 65 78  aggregate_contex
0ef0: 74 2c 0a 20 20 73 71 6c 69 74 65 33 5f 61 67 67  t,.  sqlite3_agg
0f00: 72 65 67 61 74 65 5f 63 6f 75 6e 74 2c 0a 20 20  regate_count,.  
0f10: 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 62 6c 6f  sqlite3_bind_blo
0f20: 62 2c 0a 20 20 73 71 6c 69 74 65 33 5f 62 69 6e  b,.  sqlite3_bin
0f30: 64 5f 64 6f 75 62 6c 65 2c 0a 20 20 73 71 6c 69  d_double,.  sqli
0f40: 74 65 33 5f 62 69 6e 64 5f 69 6e 74 2c 0a 20 20  te3_bind_int,.  
0f50: 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74  sqlite3_bind_int
0f60: 36 34 2c 0a 20 20 73 71 6c 69 74 65 33 5f 62 69  64,.  sqlite3_bi
0f70: 6e 64 5f 6e 75 6c 6c 2c 0a 20 20 73 71 6c 69 74  nd_null,.  sqlit
0f80: 65 33 5f 62 69 6e 64 5f 70 61 72 61 6d 65 74 65  e3_bind_paramete
0f90: 72 5f 63 6f 75 6e 74 2c 0a 20 20 73 71 6c 69 74  r_count,.  sqlit
0fa0: 65 33 5f 62 69 6e 64 5f 70 61 72 61 6d 65 74 65  e3_bind_paramete
0fb0: 72 5f 69 6e 64 65 78 2c 0a 20 20 73 71 6c 69 74  r_index,.  sqlit
0fc0: 65 33 5f 62 69 6e 64 5f 70 61 72 61 6d 65 74 65  e3_bind_paramete
0fd0: 72 5f 6e 61 6d 65 2c 0a 20 20 73 71 6c 69 74 65  r_name,.  sqlite
0fe0: 33 5f 62 69 6e 64 5f 74 65 78 74 2c 0a 20 20 73  3_bind_text,.  s
0ff0: 71 6c 69 74 65 33 5f 62 69 6e 64 5f 74 65 78 74  qlite3_bind_text
1000: 31 36 2c 0a 20 20 73 71 6c 69 74 65 33 5f 62 69  16,.  sqlite3_bi
1010: 6e 64 5f 76 61 6c 75 65 2c 0a 20 20 73 71 6c 69  nd_value,.  sqli
1020: 74 65 33 5f 62 75 73 79 5f 68 61 6e 64 6c 65 72  te3_busy_handler
1030: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 62 75 73 79  ,.  sqlite3_busy
1040: 5f 74 69 6d 65 6f 75 74 2c 0a 20 20 73 71 6c 69  _timeout,.  sqli
1050: 74 65 33 5f 63 68 61 6e 67 65 73 2c 0a 20 20 73  te3_changes,.  s
1060: 71 6c 69 74 65 33 5f 63 6c 6f 73 65 2c 0a 20 20  qlite3_close,.  
1070: 73 71 6c 69 74 65 33 5f 63 6f 6c 6c 61 74 69 6f  sqlite3_collatio
1080: 6e 5f 6e 65 65 64 65 64 2c 0a 20 20 73 71 6c 69  n_needed,.  sqli
1090: 74 65 33 5f 63 6f 6c 6c 61 74 69 6f 6e 5f 6e 65  te3_collation_ne
10a0: 65 64 65 64 31 36 2c 0a 20 20 73 71 6c 69 74 65  eded16,.  sqlite
10b0: 33 5f 63 6f 6c 75 6d 6e 5f 62 6c 6f 62 2c 0a 20  3_column_blob,. 
10c0: 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f   sqlite3_column_
10d0: 62 79 74 65 73 2c 0a 20 20 73 71 6c 69 74 65 33  bytes,.  sqlite3
10e0: 5f 63 6f 6c 75 6d 6e 5f 62 79 74 65 73 31 36 2c  _column_bytes16,
10f0: 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  .  sqlite3_colum
1100: 6e 5f 63 6f 75 6e 74 2c 0a 20 20 73 71 6c 69 74  n_count,.  sqlit
1110: 65 33 5f 63 6f 6c 75 6d 6e 5f 64 61 74 61 62 61  e3_column_databa
1120: 73 65 5f 6e 61 6d 65 2c 0a 20 20 73 71 6c 69 74  se_name,.  sqlit
1130: 65 33 5f 63 6f 6c 75 6d 6e 5f 64 61 74 61 62 61  e3_column_databa
1140: 73 65 5f 6e 61 6d 65 31 36 2c 0a 20 20 73 71 6c  se_name16,.  sql
1150: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 65 63 6c  ite3_column_decl
1160: 74 79 70 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f  type,.  sqlite3_
1170: 63 6f 6c 75 6d 6e 5f 64 65 63 6c 74 79 70 65 31  column_decltype1
1180: 36 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c  6,.  sqlite3_col
1190: 75 6d 6e 5f 64 6f 75 62 6c 65 2c 0a 20 20 73 71  umn_double,.  sq
11a0: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74  lite3_column_int
11b0: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75  ,.  sqlite3_colu
11c0: 6d 6e 5f 69 6e 74 36 34 2c 0a 20 20 73 71 6c 69  mn_int64,.  sqli
11d0: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d 65 2c  te3_column_name,
11e0: 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  .  sqlite3_colum
11f0: 6e 5f 6e 61 6d 65 31 36 2c 0a 20 20 73 71 6c 69  n_name16,.  sqli
1200: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6f 72 69 67 69  te3_column_origi
1210: 6e 5f 6e 61 6d 65 2c 0a 20 20 73 71 6c 69 74 65  n_name,.  sqlite
1220: 33 5f 63 6f 6c 75 6d 6e 5f 6f 72 69 67 69 6e 5f  3_column_origin_
1230: 6e 61 6d 65 31 36 2c 0a 20 20 73 71 6c 69 74 65  name16,.  sqlite
1240: 33 5f 63 6f 6c 75 6d 6e 5f 74 61 62 6c 65 5f 6e  3_column_table_n
1250: 61 6d 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63  ame,.  sqlite3_c
1260: 6f 6c 75 6d 6e 5f 74 61 62 6c 65 5f 6e 61 6d 65  olumn_table_name
1270: 31 36 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f  16,.  sqlite3_co
1280: 6c 75 6d 6e 5f 74 65 78 74 2c 0a 20 20 73 71 6c  lumn_text,.  sql
1290: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74  ite3_column_text
12a0: 31 36 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f  16,.  sqlite3_co
12b0: 6c 75 6d 6e 5f 74 79 70 65 2c 0a 20 20 73 71 6c  lumn_type,.  sql
12c0: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 76 61 6c 75  ite3_column_valu
12d0: 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6d  e,.  sqlite3_com
12e0: 6d 69 74 5f 68 6f 6f 6b 2c 0a 20 20 73 71 6c 69  mit_hook,.  sqli
12f0: 74 65 33 5f 63 6f 6d 70 6c 65 74 65 2c 0a 20 20  te3_complete,.  
1300: 73 71 6c 69 74 65 33 5f 63 6f 6d 70 6c 65 74 65  sqlite3_complete
1310: 31 36 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63 72  16,.  sqlite3_cr
1320: 65 61 74 65 5f 63 6f 6c 6c 61 74 69 6f 6e 2c 0a  eate_collation,.
1330: 20 20 73 71 6c 69 74 65 33 5f 63 72 65 61 74 65    sqlite3_create
1340: 5f 63 6f 6c 6c 61 74 69 6f 6e 31 36 2c 0a 20 20  _collation16,.  
1350: 73 71 6c 69 74 65 33 5f 63 72 65 61 74 65 5f 66  sqlite3_create_f
1360: 75 6e 63 74 69 6f 6e 2c 0a 20 20 73 71 6c 69 74  unction,.  sqlit
1370: 65 33 5f 63 72 65 61 74 65 5f 66 75 6e 63 74 69  e3_create_functi
1380: 6f 6e 31 36 2c 0a 20 20 73 71 6c 69 74 65 33 5f  on16,.  sqlite3_
1390: 63 72 65 61 74 65 5f 6d 6f 64 75 6c 65 2c 0a 20  create_module,. 
13a0: 20 73 71 6c 69 74 65 33 5f 64 61 74 61 5f 63 6f   sqlite3_data_co
13b0: 75 6e 74 2c 0a 20 20 73 71 6c 69 74 65 33 5f 64  unt,.  sqlite3_d
13c0: 62 5f 68 61 6e 64 6c 65 2c 0a 20 20 73 71 6c 69  b_handle,.  sqli
13d0: 74 65 33 5f 64 65 63 6c 61 72 65 5f 76 74 61 62  te3_declare_vtab
13e0: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 65 6e 61 62  ,.  sqlite3_enab
13f0: 6c 65 5f 73 68 61 72 65 64 5f 63 61 63 68 65 2c  le_shared_cache,
1400: 0a 20 20 73 71 6c 69 74 65 33 5f 65 72 72 63 6f  .  sqlite3_errco
1410: 64 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f 65 72  de,.  sqlite3_er
1420: 72 6d 73 67 2c 0a 20 20 73 71 6c 69 74 65 33 5f  rmsg,.  sqlite3_
1430: 65 72 72 6d 73 67 31 36 2c 0a 20 20 73 71 6c 69  errmsg16,.  sqli
1440: 74 65 33 5f 65 78 65 63 2c 0a 20 20 73 71 6c 69  te3_exec,.  sqli
1450: 74 65 33 5f 65 78 70 69 72 65 64 2c 0a 20 20 73  te3_expired,.  s
1460: 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 2c  qlite3_finalize,
1470: 0a 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 2c  .  sqlite3_free,
1480: 0a 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 5f  .  sqlite3_free_
1490: 74 61 62 6c 65 2c 0a 20 20 73 71 6c 69 74 65 33  table,.  sqlite3
14a0: 5f 67 65 74 5f 61 75 74 6f 63 6f 6d 6d 69 74 2c  _get_autocommit,
14b0: 0a 20 20 73 71 6c 69 74 65 33 5f 67 65 74 5f 61  .  sqlite3_get_a
14c0: 75 78 64 61 74 61 2c 0a 20 20 73 71 6c 69 74 65  uxdata,.  sqlite
14d0: 33 5f 67 65 74 5f 74 61 62 6c 65 2c 0a 20 20 30  3_get_table,.  0
14e0: 2c 20 20 20 20 20 2f 2a 20 57 61 73 20 73 71 6c  ,     /* Was sql
14f0: 69 74 65 33 5f 67 6c 6f 62 61 6c 5f 72 65 63 6f  ite3_global_reco
1500: 76 65 72 28 29 2c 20 62 75 74 20 74 68 61 74 20  ver(), but that 
1510: 66 75 6e 63 74 69 6f 6e 20 69 73 20 64 65 70 72  function is depr
1520: 65 63 61 74 65 64 20 2a 2f 0a 20 20 73 71 6c 69  ecated */.  sqli
1530: 74 65 33 5f 69 6e 74 65 72 72 75 70 74 2c 0a 20  te3_interrupt,. 
1540: 20 73 71 6c 69 74 65 33 5f 6c 61 73 74 5f 69 6e   sqlite3_last_in
1550: 73 65 72 74 5f 72 6f 77 69 64 2c 0a 20 20 73 71  sert_rowid,.  sq
1560: 6c 69 74 65 33 5f 6c 69 62 76 65 72 73 69 6f 6e  lite3_libversion
1570: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 6c 69 62 76  ,.  sqlite3_libv
1580: 65 72 73 69 6f 6e 5f 6e 75 6d 62 65 72 2c 0a 20  ersion_number,. 
1590: 20 73 71 6c 69 74 65 33 5f 6d 61 6c 6c 6f 63 2c   sqlite3_malloc,
15a0: 0a 20 20 73 71 6c 69 74 65 33 5f 6d 70 72 69 6e  .  sqlite3_mprin
15b0: 74 66 2c 0a 20 20 73 71 6c 69 74 65 33 5f 6f 70  tf,.  sqlite3_op
15c0: 65 6e 2c 0a 20 20 73 71 6c 69 74 65 33 5f 6f 70  en,.  sqlite3_op
15d0: 65 6e 31 36 2c 0a 20 20 73 71 6c 69 74 65 33 5f  en16,.  sqlite3_
15e0: 70 72 65 70 61 72 65 2c 0a 20 20 73 71 6c 69 74  prepare,.  sqlit
15f0: 65 33 5f 70 72 65 70 61 72 65 31 36 2c 0a 20 20  e3_prepare16,.  
1600: 73 71 6c 69 74 65 33 5f 70 72 6f 66 69 6c 65 2c  sqlite3_profile,
1610: 0a 20 20 73 71 6c 69 74 65 33 5f 70 72 6f 67 72  .  sqlite3_progr
1620: 65 73 73 5f 68 61 6e 64 6c 65 72 2c 0a 20 20 73  ess_handler,.  s
1630: 71 6c 69 74 65 33 5f 72 65 61 6c 6c 6f 63 2c 0a  qlite3_realloc,.
1640: 20 20 73 71 6c 69 74 65 33 5f 72 65 73 65 74 2c    sqlite3_reset,
1650: 0a 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c  .  sqlite3_resul
1660: 74 5f 62 6c 6f 62 2c 0a 20 20 73 71 6c 69 74 65  t_blob,.  sqlite
1670: 33 5f 72 65 73 75 6c 74 5f 64 6f 75 62 6c 65 2c  3_result_double,
1680: 0a 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c  .  sqlite3_resul
1690: 74 5f 65 72 72 6f 72 2c 0a 20 20 73 71 6c 69 74  t_error,.  sqlit
16a0: 65 33 5f 72 65 73 75 6c 74 5f 65 72 72 6f 72 31  e3_result_error1
16b0: 36 2c 0a 20 20 73 71 6c 69 74 65 33 5f 72 65 73  6,.  sqlite3_res
16c0: 75 6c 74 5f 69 6e 74 2c 0a 20 20 73 71 6c 69 74  ult_int,.  sqlit
16d0: 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74 36 34 2c  e3_result_int64,
16e0: 0a 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c  .  sqlite3_resul
16f0: 74 5f 6e 75 6c 6c 2c 0a 20 20 73 71 6c 69 74 65  t_null,.  sqlite
1700: 33 5f 72 65 73 75 6c 74 5f 74 65 78 74 2c 0a 20  3_result_text,. 
1710: 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f   sqlite3_result_
1720: 74 65 78 74 31 36 2c 0a 20 20 73 71 6c 69 74 65  text16,.  sqlite
1730: 33 5f 72 65 73 75 6c 74 5f 74 65 78 74 31 36 62  3_result_text16b
1740: 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f 72 65 73  e,.  sqlite3_res
1750: 75 6c 74 5f 74 65 78 74 31 36 6c 65 2c 0a 20 20  ult_text16le,.  
1760: 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 76  sqlite3_result_v
1770: 61 6c 75 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f  alue,.  sqlite3_
1780: 72 6f 6c 6c 62 61 63 6b 5f 68 6f 6f 6b 2c 0a 20  rollback_hook,. 
1790: 20 73 71 6c 69 74 65 33 5f 73 65 74 5f 61 75 74   sqlite3_set_aut
17a0: 68 6f 72 69 7a 65 72 2c 0a 20 20 73 71 6c 69 74  horizer,.  sqlit
17b0: 65 33 5f 73 65 74 5f 61 75 78 64 61 74 61 2c 0a  e3_set_auxdata,.
17c0: 20 20 73 71 6c 69 74 65 33 5f 73 6e 70 72 69 6e    sqlite3_snprin
17d0: 74 66 2c 0a 20 20 73 71 6c 69 74 65 33 5f 73 74  tf,.  sqlite3_st
17e0: 65 70 2c 0a 20 20 73 71 6c 69 74 65 33 5f 74 61  ep,.  sqlite3_ta
17f0: 62 6c 65 5f 63 6f 6c 75 6d 6e 5f 6d 65 74 61 64  ble_column_metad
1800: 61 74 61 2c 0a 20 20 73 71 6c 69 74 65 33 5f 74  ata,.  sqlite3_t
1810: 68 72 65 61 64 5f 63 6c 65 61 6e 75 70 2c 0a 20  hread_cleanup,. 
1820: 20 73 71 6c 69 74 65 33 5f 74 6f 74 61 6c 5f 63   sqlite3_total_c
1830: 68 61 6e 67 65 73 2c 0a 20 20 73 71 6c 69 74 65  hanges,.  sqlite
1840: 33 5f 74 72 61 63 65 2c 0a 20 20 73 71 6c 69 74  3_trace,.  sqlit
1850: 65 33 5f 74 72 61 6e 73 66 65 72 5f 62 69 6e 64  e3_transfer_bind
1860: 69 6e 67 73 2c 0a 20 20 73 71 6c 69 74 65 33 5f  ings,.  sqlite3_
1870: 75 70 64 61 74 65 5f 68 6f 6f 6b 2c 0a 20 20 73  update_hook,.  s
1880: 71 6c 69 74 65 33 5f 75 73 65 72 5f 64 61 74 61  qlite3_user_data
1890: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 76 61 6c 75  ,.  sqlite3_valu
18a0: 65 5f 62 6c 6f 62 2c 0a 20 20 73 71 6c 69 74 65  e_blob,.  sqlite
18b0: 33 5f 76 61 6c 75 65 5f 62 79 74 65 73 2c 0a 20  3_value_bytes,. 
18c0: 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 62   sqlite3_value_b
18d0: 79 74 65 73 31 36 2c 0a 20 20 73 71 6c 69 74 65  ytes16,.  sqlite
18e0: 33 5f 76 61 6c 75 65 5f 64 6f 75 62 6c 65 2c 0a  3_value_double,.
18f0: 20 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f    sqlite3_value_
1900: 69 6e 74 2c 0a 20 20 73 71 6c 69 74 65 33 5f 76  int,.  sqlite3_v
1910: 61 6c 75 65 5f 69 6e 74 36 34 2c 0a 20 20 73 71  alue_int64,.  sq
1920: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 6e 75 6d 65  lite3_value_nume
1930: 72 69 63 5f 74 79 70 65 2c 0a 20 20 73 71 6c 69  ric_type,.  sqli
1940: 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74 2c 0a  te3_value_text,.
1950: 20 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f    sqlite3_value_
1960: 74 65 78 74 31 36 2c 0a 20 20 73 71 6c 69 74 65  text16,.  sqlite
1970: 33 5f 76 61 6c 75 65 5f 74 65 78 74 31 36 62 65  3_value_text16be
1980: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 76 61 6c 75  ,.  sqlite3_valu
1990: 65 5f 74 65 78 74 31 36 6c 65 2c 0a 20 20 73 71  e_text16le,.  sq
19a0: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 79 70 65  lite3_value_type
19b0: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 76 6d 70 72  ,.  sqlite3_vmpr
19c0: 69 6e 74 66 2c 0a 20 20 2f 2a 0a 20 20 2a 2a 20  intf,.  /*.  ** 
19d0: 54 68 65 20 6f 72 69 67 69 6e 61 6c 20 41 50 49  The original API
19e0: 20 73 65 74 20 65 6e 64 73 20 68 65 72 65 2e 20   set ends here. 
19f0: 20 41 6c 6c 20 65 78 74 65 6e 73 69 6f 6e 73 20   All extensions 
1a00: 63 61 6e 20 63 61 6c 6c 20 61 6e 79 0a 20 20 2a  can call any.  *
1a10: 2a 20 6f 66 20 74 68 65 20 41 50 49 73 20 61 62  * of the APIs ab
1a20: 6f 76 65 20 70 72 6f 76 69 64 65 64 20 74 68 61  ove provided tha
1a30: 74 20 74 68 65 20 70 6f 69 6e 74 65 72 20 69 73  t the pointer is
1a40: 20 6e 6f 74 20 4e 55 4c 4c 2e 20 20 42 75 74 0a   not NULL.  But.
1a50: 20 20 2a 2a 20 62 65 66 6f 72 65 20 63 61 6c 6c    ** before call
1a60: 69 6e 67 20 41 50 49 73 20 74 68 61 74 20 66 6f  ing APIs that fo
1a70: 6c 6c 6f 77 2c 20 65 78 74 65 6e 73 69 6f 6e 20  llow, extension 
1a80: 73 68 6f 75 6c 64 20 63 68 65 63 6b 20 74 68 65  should check the
1a90: 0a 20 20 2a 2a 20 73 71 6c 69 74 65 33 5f 6c 69  .  ** sqlite3_li
1aa0: 62 76 65 72 73 69 6f 6e 5f 6e 75 6d 62 65 72 28  bversion_number(
1ab0: 29 20 74 6f 20 6d 61 6b 65 20 73 75 72 65 20 74  ) to make sure t
1ac0: 68 65 79 20 61 72 65 20 64 65 61 6c 69 6e 67 20  hey are dealing 
1ad0: 77 69 74 68 0a 20 20 2a 2a 20 61 20 6c 69 62 72  with.  ** a libr
1ae0: 61 72 79 20 74 68 61 74 20 69 73 20 6e 65 77 20  ary that is new 
1af0: 65 6e 6f 75 67 68 20 74 6f 20 73 75 70 70 6f 72  enough to suppor
1b00: 74 20 74 68 61 74 20 41 50 49 2e 0a 20 20 2a 2a  t that API..  **
1b10: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
1b20: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
1b30: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
1b40: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
1b50: 2a 2a 2a 2a 2a 2a 2a 0a 20 20 2a 2f 0a 20 20 73  *******.  */.  s
1b60: 71 6c 69 74 65 33 5f 6f 76 65 72 6c 6f 61 64 5f  qlite3_overload_
1b70: 66 75 6e 63 74 69 6f 6e 2c 0a 0a 20 20 2f 2a 0a  function,..  /*.
1b80: 20 20 2a 2a 20 41 64 64 65 64 20 61 66 74 65 72    ** Added after
1b90: 20 33 2e 33 2e 31 33 0a 20 20 2a 2f 0a 20 20 73   3.3.13.  */.  s
1ba0: 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76  qlite3_prepare_v
1bb0: 32 2c 0a 20 20 73 71 6c 69 74 65 33 5f 70 72 65  2,.  sqlite3_pre
1bc0: 70 61 72 65 31 36 5f 76 32 2c 0a 20 20 73 71 6c  pare16_v2,.  sql
1bd0: 69 74 65 33 5f 63 6c 65 61 72 5f 62 69 6e 64 69  ite3_clear_bindi
1be0: 6e 67 73 2c 0a 0a 20 20 2f 2a 0a 20 20 2a 2a 20  ngs,..  /*.  ** 
1bf0: 41 64 64 65 64 20 66 6f 72 20 33 2e 34 2e 31 0a  Added for 3.4.1.
1c00: 20 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f 63    */.  sqlite3_c
1c10: 72 65 61 74 65 5f 6d 6f 64 75 6c 65 5f 76 32 2c  reate_module_v2,
1c20: 0a 0a 20 20 2f 2a 0a 20 20 2a 2a 20 41 64 64 65  ..  /*.  ** Adde
1c30: 64 20 66 6f 72 20 33 2e 35 2e 30 0a 20 20 2a 2f  d for 3.5.0.  */
1c40: 0a 20 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f  .  sqlite3_bind_
1c50: 7a 65 72 6f 62 6c 6f 62 2c 0a 20 20 73 71 6c 69  zeroblob,.  sqli
1c60: 74 65 33 5f 62 6c 6f 62 5f 62 79 74 65 73 2c 0a  te3_blob_bytes,.
1c70: 20 20 73 71 6c 69 74 65 33 5f 62 6c 6f 62 5f 63    sqlite3_blob_c
1c80: 6c 6f 73 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f  lose,.  sqlite3_
1c90: 62 6c 6f 62 5f 6f 70 65 6e 2c 0a 20 20 73 71 6c  blob_open,.  sql
1ca0: 69 74 65 33 5f 62 6c 6f 62 5f 72 65 61 64 2c 0a  ite3_blob_read,.
1cb0: 20 20 73 71 6c 69 74 65 33 5f 62 6c 6f 62 5f 77    sqlite3_blob_w
1cc0: 72 69 74 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f  rite,.  sqlite3_
1cd0: 63 72 65 61 74 65 5f 63 6f 6c 6c 61 74 69 6f 6e  create_collation
1ce0: 5f 76 32 2c 0a 20 20 73 71 6c 69 74 65 33 5f 66  _v2,.  sqlite3_f
1cf0: 69 6c 65 5f 63 6f 6e 74 72 6f 6c 2c 0a 20 20 73  ile_control,.  s
1d00: 71 6c 69 74 65 33 5f 6d 65 6d 6f 72 79 5f 68 69  qlite3_memory_hi
1d10: 67 68 77 61 74 65 72 2c 0a 20 20 73 71 6c 69 74  ghwater,.  sqlit
1d20: 65 33 5f 6d 65 6d 6f 72 79 5f 75 73 65 64 2c 0a  e3_memory_used,.
1d30: 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 4d 55  #ifdef SQLITE_MU
1d40: 54 45 58 5f 4e 4f 4f 50 0a 20 20 30 2c 20 0a 20  TEX_NOOP.  0, . 
1d50: 20 30 2c 20 0a 20 20 30 2c 0a 20 20 30 2c 0a 20   0, .  0,.  0,. 
1d60: 20 30 2c 0a 23 65 6c 73 65 0a 20 20 73 71 6c 69   0,.#else.  sqli
1d70: 74 65 33 5f 6d 75 74 65 78 5f 61 6c 6c 6f 63 2c  te3_mutex_alloc,
1d80: 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78  .  sqlite3_mutex
1d90: 5f 65 6e 74 65 72 2c 0a 20 20 73 71 6c 69 74 65  _enter,.  sqlite
1da0: 33 5f 6d 75 74 65 78 5f 66 72 65 65 2c 0a 20 20  3_mutex_free,.  
1db0: 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65  sqlite3_mutex_le
1dc0: 61 76 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f 6d  ave,.  sqlite3_m
1dd0: 75 74 65 78 5f 74 72 79 2c 0a 23 65 6e 64 69 66  utex_try,.#endif
1de0: 0a 20 20 73 71 6c 69 74 65 33 5f 6f 70 65 6e 5f  .  sqlite3_open_
1df0: 76 32 2c 0a 20 20 73 71 6c 69 74 65 33 5f 72 65  v2,.  sqlite3_re
1e00: 6c 65 61 73 65 5f 6d 65 6d 6f 72 79 2c 0a 20 20  lease_memory,.  
1e10: 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 65  sqlite3_result_e
1e20: 72 72 6f 72 5f 6e 6f 6d 65 6d 2c 0a 20 20 73 71  rror_nomem,.  sq
1e30: 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 65 72 72  lite3_result_err
1e40: 6f 72 5f 74 6f 6f 62 69 67 2c 0a 20 20 73 71 6c  or_toobig,.  sql
1e50: 69 74 65 33 5f 73 6c 65 65 70 2c 0a 20 20 73 71  ite3_sleep,.  sq
1e60: 6c 69 74 65 33 5f 73 6f 66 74 5f 68 65 61 70 5f  lite3_soft_heap_
1e70: 6c 69 6d 69 74 2c 0a 20 20 73 71 6c 69 74 65 33  limit,.  sqlite3
1e80: 5f 76 66 73 5f 66 69 6e 64 2c 0a 20 20 73 71 6c  _vfs_find,.  sql
1e90: 69 74 65 33 5f 76 66 73 5f 72 65 67 69 73 74 65  ite3_vfs_registe
1ea0: 72 2c 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73  r,.  sqlite3_vfs
1eb0: 5f 75 6e 72 65 67 69 73 74 65 72 2c 0a 0a 20 20  _unregister,..  
1ec0: 2f 2a 0a 20 20 2a 2a 20 41 64 64 65 64 20 66 6f  /*.  ** Added fo
1ed0: 72 20 33 2e 35 2e 38 0a 20 20 2a 2f 0a 20 20 73  r 3.5.8.  */.  s
1ee0: 71 6c 69 74 65 33 5f 74 68 72 65 61 64 73 61 66  qlite3_threadsaf
1ef0: 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f 72 65 73  e,.  sqlite3_res
1f00: 75 6c 74 5f 7a 65 72 6f 62 6c 6f 62 2c 0a 20 20  ult_zeroblob,.  
1f10: 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 65  sqlite3_result_e
1f20: 72 72 6f 72 5f 63 6f 64 65 2c 0a 20 20 73 71 6c  rror_code,.  sql
1f30: 69 74 65 33 5f 74 65 73 74 5f 63 6f 6e 74 72 6f  ite3_test_contro
1f40: 6c 2c 0a 20 20 73 71 6c 69 74 65 33 5f 72 61 6e  l,.  sqlite3_ran
1f50: 64 6f 6d 6e 65 73 73 2c 0a 20 20 73 71 6c 69 74  domness,.  sqlit
1f60: 65 33 5f 63 6f 6e 74 65 78 74 5f 64 62 5f 68 61  e3_context_db_ha
1f70: 6e 64 6c 65 2c 0a 0a 20 20 2f 2a 0a 20 20 2a 2a  ndle,..  /*.  **
1f80: 20 41 64 64 65 64 20 66 6f 72 20 33 2e 36 2e 30   Added for 3.6.0
1f90: 0a 20 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f  .  */.  sqlite3_
1fa0: 65 78 74 65 6e 64 65 64 5f 72 65 73 75 6c 74 5f  extended_result_
1fb0: 63 6f 64 65 73 2c 0a 20 20 73 71 6c 69 74 65 33  codes,.  sqlite3
1fc0: 5f 6c 69 6d 69 74 2c 0a 20 20 73 71 6c 69 74 65  _limit,.  sqlite
1fd0: 33 5f 6e 65 78 74 5f 73 74 6d 74 2c 0a 20 20 73  3_next_stmt,.  s
1fe0: 71 6c 69 74 65 33 5f 73 71 6c 2c 0a 20 20 73 71  qlite3_sql,.  sq
1ff0: 6c 69 74 65 33 5f 73 74 61 74 75 73 2c 0a 7d 3b  lite3_status,.};
2000: 0a 0a 2f 2a 0a 2a 2a 20 41 74 74 65 6d 70 74 20  ../*.** Attempt 
2010: 74 6f 20 6c 6f 61 64 20 61 6e 20 53 51 4c 69 74  to load an SQLit
2020: 65 20 65 78 74 65 6e 73 69 6f 6e 20 6c 69 62 72  e extension libr
2030: 61 72 79 20 63 6f 6e 74 61 69 6e 65 64 20 69 6e  ary contained in
2040: 20 74 68 65 20 66 69 6c 65 0a 2a 2a 20 7a 46 69   the file.** zFi
2050: 6c 65 2e 20 20 54 68 65 20 65 6e 74 72 79 20 70  le.  The entry p
2060: 6f 69 6e 74 20 69 73 20 7a 50 72 6f 63 2e 20 20  oint is zProc.  
2070: 7a 50 72 6f 63 20 6d 61 79 20 62 65 20 30 20 69  zProc may be 0 i
2080: 6e 20 77 68 69 63 68 20 63 61 73 65 20 61 0a 2a  n which case a.*
2090: 2a 20 64 65 66 61 75 6c 74 20 65 6e 74 72 79 20  * default entry 
20a0: 70 6f 69 6e 74 20 6e 61 6d 65 20 28 73 71 6c 69  point name (sqli
20b0: 74 65 33 5f 65 78 74 65 6e 73 69 6f 6e 5f 69 6e  te3_extension_in
20c0: 69 74 29 20 69 73 20 75 73 65 64 2e 20 20 55 73  it) is used.  Us
20d0: 65 0a 2a 2a 20 6f 66 20 74 68 65 20 64 65 66 61  e.** of the defa
20e0: 75 6c 74 20 6e 61 6d 65 20 69 73 20 72 65 63 6f  ult name is reco
20f0: 6d 6d 65 6e 64 65 64 2e 0a 2a 2a 0a 2a 2a 20 52  mmended..**.** R
2100: 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 20  eturn SQLITE_OK 
2110: 6f 6e 20 73 75 63 63 65 73 73 20 61 6e 64 20 53  on success and S
2120: 51 4c 49 54 45 5f 45 52 52 4f 52 20 69 66 20 73  QLITE_ERROR if s
2130: 6f 6d 65 74 68 69 6e 67 20 67 6f 65 73 20 77 72  omething goes wr
2140: 6f 6e 67 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 61 6e  ong..**.** If an
2150: 20 65 72 72 6f 72 20 6f 63 63 75 72 73 20 61 6e   error occurs an
2160: 64 20 70 7a 45 72 72 4d 73 67 20 69 73 20 6e 6f  d pzErrMsg is no
2170: 74 20 30 2c 20 74 68 65 6e 20 66 69 6c 6c 20 2a  t 0, then fill *
2180: 70 7a 45 72 72 4d 73 67 20 77 69 74 68 20 0a 2a  pzErrMsg with .*
2190: 2a 20 65 72 72 6f 72 20 6d 65 73 73 61 67 65 20  * error message 
21a0: 74 65 78 74 2e 20 20 54 68 65 20 63 61 6c 6c 69  text.  The calli
21b0: 6e 67 20 66 75 6e 63 74 69 6f 6e 20 73 68 6f 75  ng function shou
21c0: 6c 64 20 66 72 65 65 20 74 68 69 73 20 6d 65 6d  ld free this mem
21d0: 6f 72 79 0a 2a 2a 20 62 79 20 63 61 6c 6c 69 6e  ory.** by callin
21e0: 67 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 29  g sqlite3_free()
21f0: 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20  ..*/.static int 
2200: 73 71 6c 69 74 65 33 4c 6f 61 64 45 78 74 65 6e  sqlite3LoadExten
2210: 73 69 6f 6e 28 0a 20 20 73 71 6c 69 74 65 33 20  sion(.  sqlite3 
2220: 2a 64 62 2c 20 20 20 20 20 20 20 20 20 20 2f 2a  *db,          /*
2230: 20 4c 6f 61 64 20 74 68 65 20 65 78 74 65 6e 73   Load the extens
2240: 69 6f 6e 20 69 6e 74 6f 20 74 68 69 73 20 64 61  ion into this da
2250: 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f  tabase connectio
2260: 6e 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61  n */.  const cha
2270: 72 20 2a 7a 46 69 6c 65 2c 20 20 20 20 2f 2a 20  r *zFile,    /* 
2280: 4e 61 6d 65 20 6f 66 20 74 68 65 20 73 68 61 72  Name of the shar
2290: 65 64 20 6c 69 62 72 61 72 79 20 63 6f 6e 74 61  ed library conta
22a0: 69 6e 69 6e 67 20 65 78 74 65 6e 73 69 6f 6e 20  ining extension 
22b0: 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20  */.  const char 
22c0: 2a 7a 50 72 6f 63 2c 20 20 20 20 2f 2a 20 45 6e  *zProc,    /* En
22d0: 74 72 79 20 70 6f 69 6e 74 2e 20 20 55 73 65 20  try point.  Use 
22e0: 22 73 71 6c 69 74 65 33 5f 65 78 74 65 6e 73 69  "sqlite3_extensi
22f0: 6f 6e 5f 69 6e 69 74 22 20 69 66 20 30 20 2a 2f  on_init" if 0 */
2300: 0a 20 20 63 68 61 72 20 2a 2a 70 7a 45 72 72 4d  .  char **pzErrM
2310: 73 67 20 20 20 20 20 20 20 2f 2a 20 50 75 74 20  sg       /* Put 
2320: 65 72 72 6f 72 20 6d 65 73 73 61 67 65 20 68 65  error message he
2330: 72 65 20 69 66 20 6e 6f 74 20 30 20 2a 2f 0a 29  re if not 0 */.)
2340: 7b 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20  {.  sqlite3_vfs 
2350: 2a 70 56 66 73 20 3d 20 64 62 2d 3e 70 56 66 73  *pVfs = db->pVfs
2360: 3b 0a 20 20 76 6f 69 64 20 2a 68 61 6e 64 6c 65  ;.  void *handle
2370: 3b 0a 20 20 69 6e 74 20 28 2a 78 49 6e 69 74 29  ;.  int (*xInit)
2380: 28 73 71 6c 69 74 65 33 2a 2c 63 68 61 72 2a 2a  (sqlite3*,char**
2390: 2c 63 6f 6e 73 74 20 73 71 6c 69 74 65 33 5f 61  ,const sqlite3_a
23a0: 70 69 5f 72 6f 75 74 69 6e 65 73 2a 29 3b 0a 20  pi_routines*);. 
23b0: 20 63 68 61 72 20 2a 7a 45 72 72 6d 73 67 20 3d   char *zErrmsg =
23c0: 20 30 3b 0a 20 20 76 6f 69 64 20 2a 2a 61 48 61   0;.  void **aHa
23d0: 6e 64 6c 65 3b 0a 0a 20 20 2f 2a 20 54 69 63 6b  ndle;..  /* Tick
23e0: 65 74 20 23 31 38 36 33 2e 20 20 54 6f 20 61 76  et #1863.  To av
23f0: 6f 69 64 20 61 20 63 72 65 61 74 69 6e 67 20 73  oid a creating s
2400: 65 63 75 72 69 74 79 20 70 72 6f 62 6c 65 6d 73  ecurity problems
2410: 20 66 6f 72 20 6f 6c 64 65 72 0a 20 20 2a 2a 20   for older.  ** 
2420: 61 70 70 6c 69 63 61 74 69 6f 6e 73 20 74 68 61  applications tha
2430: 74 20 72 65 6c 69 6e 6b 20 61 67 61 69 6e 73 74  t relink against
2440: 20 6e 65 77 65 72 20 76 65 72 73 69 6f 6e 73 20   newer versions 
2450: 6f 66 20 53 51 4c 69 74 65 2c 20 74 68 65 0a 20  of SQLite, the. 
2460: 20 2a 2a 20 61 62 69 6c 69 74 79 20 74 6f 20 72   ** ability to r
2470: 75 6e 20 6c 6f 61 64 5f 65 78 74 65 6e 73 69 6f  un load_extensio
2480: 6e 20 69 73 20 74 75 72 6e 65 64 20 6f 66 66 20  n is turned off 
2490: 62 79 20 64 65 66 61 75 6c 74 2e 20 20 4f 6e 65  by default.  One
24a0: 0a 20 20 2a 2a 20 6d 75 73 74 20 63 61 6c 6c 20  .  ** must call 
24b0: 73 71 6c 69 74 65 33 5f 65 6e 61 62 6c 65 5f 6c  sqlite3_enable_l
24c0: 6f 61 64 5f 65 78 74 65 6e 73 69 6f 6e 28 29 20  oad_extension() 
24d0: 74 6f 20 74 75 72 6e 20 6f 6e 20 65 78 74 65 6e  to turn on exten
24e0: 73 69 6f 6e 0a 20 20 2a 2a 20 6c 6f 61 64 69 6e  sion.  ** loadin
24f0: 67 2e 20 20 4f 74 68 65 72 77 69 73 65 20 79 6f  g.  Otherwise yo
2500: 75 20 67 65 74 20 74 68 65 20 66 6f 6c 6c 6f 77  u get the follow
2510: 69 6e 67 20 65 72 72 6f 72 2e 0a 20 20 2a 2f 0a  ing error..  */.
2520: 20 20 69 66 28 20 28 64 62 2d 3e 66 6c 61 67 73    if( (db->flags
2530: 20 26 20 53 51 4c 49 54 45 5f 4c 6f 61 64 45 78   & SQLITE_LoadEx
2540: 74 65 6e 73 69 6f 6e 29 3d 3d 30 20 29 7b 0a 20  tension)==0 ){. 
2550: 20 20 20 69 66 28 20 70 7a 45 72 72 4d 73 67 20     if( pzErrMsg 
2560: 29 7b 0a 20 20 20 20 20 20 2a 70 7a 45 72 72 4d  ){.      *pzErrM
2570: 73 67 20 3d 20 73 71 6c 69 74 65 33 5f 6d 70 72  sg = sqlite3_mpr
2580: 69 6e 74 66 28 22 6e 6f 74 20 61 75 74 68 6f 72  intf("not author
2590: 69 7a 65 64 22 29 3b 0a 20 20 20 20 7d 0a 20 20  ized");.    }.  
25a0: 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f    return SQLITE_
25b0: 45 52 52 4f 52 3b 0a 20 20 7d 0a 0a 20 20 69 66  ERROR;.  }..  if
25c0: 28 20 7a 50 72 6f 63 3d 3d 30 20 29 7b 0a 20 20  ( zProc==0 ){.  
25d0: 20 20 7a 50 72 6f 63 20 3d 20 22 73 71 6c 69 74    zProc = "sqlit
25e0: 65 33 5f 65 78 74 65 6e 73 69 6f 6e 5f 69 6e 69  e3_extension_ini
25f0: 74 22 3b 0a 20 20 7d 0a 0a 20 20 68 61 6e 64 6c  t";.  }..  handl
2600: 65 20 3d 20 73 71 6c 69 74 65 33 4f 73 44 6c 4f  e = sqlite3OsDlO
2610: 70 65 6e 28 70 56 66 73 2c 20 7a 46 69 6c 65 29  pen(pVfs, zFile)
2620: 3b 0a 20 20 69 66 28 20 68 61 6e 64 6c 65 3d 3d  ;.  if( handle==
2630: 30 20 29 7b 0a 20 20 20 20 69 66 28 20 70 7a 45  0 ){.    if( pzE
2640: 72 72 4d 73 67 20 29 7b 0a 20 20 20 20 20 20 63  rrMsg ){.      c
2650: 68 61 72 20 7a 45 72 72 5b 32 35 36 5d 3b 0a 20  har zErr[256];. 
2660: 20 20 20 20 20 7a 45 72 72 5b 73 69 7a 65 6f 66       zErr[sizeof
2670: 28 7a 45 72 72 29 2d 31 5d 20 3d 20 27 5c 30 27  (zErr)-1] = '\0'
2680: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f  ;.      sqlite3_
2690: 73 6e 70 72 69 6e 74 66 28 73 69 7a 65 6f 66 28  snprintf(sizeof(
26a0: 7a 45 72 72 29 2d 31 2c 20 7a 45 72 72 2c 20 0a  zErr)-1, zErr, .
26b0: 20 20 20 20 20 20 20 20 20 20 22 75 6e 61 62 6c            "unabl
26c0: 65 20 74 6f 20 6f 70 65 6e 20 73 68 61 72 65 64  e to open shared
26d0: 20 6c 69 62 72 61 72 79 20 5b 25 73 5d 22 2c 20   library [%s]", 
26e0: 7a 46 69 6c 65 29 3b 0a 20 20 20 20 20 20 73 71  zFile);.      sq
26f0: 6c 69 74 65 33 4f 73 44 6c 45 72 72 6f 72 28 70  lite3OsDlError(p
2700: 56 66 73 2c 20 73 69 7a 65 6f 66 28 7a 45 72 72  Vfs, sizeof(zErr
2710: 29 2d 31 2c 20 7a 45 72 72 29 3b 0a 20 20 20 20  )-1, zErr);.    
2720: 20 20 2a 70 7a 45 72 72 4d 73 67 20 3d 20 73 71    *pzErrMsg = sq
2730: 6c 69 74 65 33 44 62 53 74 72 44 75 70 28 64 62  lite3DbStrDup(db
2740: 2c 20 7a 45 72 72 29 3b 0a 20 20 20 20 7d 0a 20  , zErr);.    }. 
2750: 20 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45     return SQLITE
2760: 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 20 20 78 49  _ERROR;.  }.  xI
2770: 6e 69 74 20 3d 20 28 69 6e 74 28 2a 29 28 73 71  nit = (int(*)(sq
2780: 6c 69 74 65 33 2a 2c 63 68 61 72 2a 2a 2c 63 6f  lite3*,char**,co
2790: 6e 73 74 20 73 71 6c 69 74 65 33 5f 61 70 69 5f  nst sqlite3_api_
27a0: 72 6f 75 74 69 6e 65 73 2a 29 29 0a 20 20 20 20  routines*)).    
27b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 73                 s
27c0: 71 6c 69 74 65 33 4f 73 44 6c 53 79 6d 28 70 56  qlite3OsDlSym(pV
27d0: 66 73 2c 20 68 61 6e 64 6c 65 2c 20 7a 50 72 6f  fs, handle, zPro
27e0: 63 29 3b 0a 20 20 69 66 28 20 78 49 6e 69 74 3d  c);.  if( xInit=
27f0: 3d 30 20 29 7b 0a 20 20 20 20 69 66 28 20 70 7a  =0 ){.    if( pz
2800: 45 72 72 4d 73 67 20 29 7b 0a 20 20 20 20 20 20  ErrMsg ){.      
2810: 63 68 61 72 20 7a 45 72 72 5b 32 35 36 5d 3b 0a  char zErr[256];.
2820: 20 20 20 20 20 20 7a 45 72 72 5b 73 69 7a 65 6f        zErr[sizeo
2830: 66 28 7a 45 72 72 29 2d 31 5d 20 3d 20 27 5c 30  f(zErr)-1] = '\0
2840: 27 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  ';.      sqlite3
2850: 5f 73 6e 70 72 69 6e 74 66 28 73 69 7a 65 6f 66  _snprintf(sizeof
2860: 28 7a 45 72 72 29 2d 31 2c 20 7a 45 72 72 2c 0a  (zErr)-1, zErr,.
2870: 20 20 20 20 20 20 20 20 20 20 22 6e 6f 20 65 6e            "no en
2880: 74 72 79 20 70 6f 69 6e 74 20 5b 25 73 5d 20 69  try point [%s] i
2890: 6e 20 73 68 61 72 65 64 20 6c 69 62 72 61 72 79  n shared library
28a0: 20 5b 25 73 5d 22 2c 20 7a 50 72 6f 63 2c 7a 46   [%s]", zProc,zF
28b0: 69 6c 65 29 3b 0a 20 20 20 20 20 20 73 71 6c 69  ile);.      sqli
28c0: 74 65 33 4f 73 44 6c 45 72 72 6f 72 28 70 56 66  te3OsDlError(pVf
28d0: 73 2c 20 73 69 7a 65 6f 66 28 7a 45 72 72 29 2d  s, sizeof(zErr)-
28e0: 31 2c 20 7a 45 72 72 29 3b 0a 20 20 20 20 20 20  1, zErr);.      
28f0: 2a 70 7a 45 72 72 4d 73 67 20 3d 20 73 71 6c 69  *pzErrMsg = sqli
2900: 74 65 33 44 62 53 74 72 44 75 70 28 64 62 2c 20  te3DbStrDup(db, 
2910: 7a 45 72 72 29 3b 0a 20 20 20 20 20 20 73 71 6c  zErr);.      sql
2920: 69 74 65 33 4f 73 44 6c 43 6c 6f 73 65 28 70 56  ite3OsDlClose(pV
2930: 66 73 2c 20 68 61 6e 64 6c 65 29 3b 0a 20 20 20  fs, handle);.   
2940: 20 7d 0a 20 20 20 20 72 65 74 75 72 6e 20 53 51   }.    return SQ
2950: 4c 49 54 45 5f 45 52 52 4f 52 3b 0a 20 20 7d 65  LITE_ERROR;.  }e
2960: 6c 73 65 20 69 66 28 20 78 49 6e 69 74 28 64 62  lse if( xInit(db
2970: 2c 20 26 7a 45 72 72 6d 73 67 2c 20 26 73 71 6c  , &zErrmsg, &sql
2980: 69 74 65 33 41 70 69 73 29 20 29 7b 0a 20 20 20  ite3Apis) ){.   
2990: 20 69 66 28 20 70 7a 45 72 72 4d 73 67 20 29 7b   if( pzErrMsg ){
29a0: 0a 20 20 20 20 20 20 2a 70 7a 45 72 72 4d 73 67  .      *pzErrMsg
29b0: 20 3d 20 73 71 6c 69 74 65 33 5f 6d 70 72 69 6e   = sqlite3_mprin
29c0: 74 66 28 22 65 72 72 6f 72 20 64 75 72 69 6e 67  tf("error during
29d0: 20 69 6e 69 74 69 61 6c 69 7a 61 74 69 6f 6e 3a   initialization:
29e0: 20 25 73 22 2c 20 7a 45 72 72 6d 73 67 29 3b 0a   %s", zErrmsg);.
29f0: 20 20 20 20 7d 0a 20 20 20 20 73 71 6c 69 74 65      }.    sqlite
2a00: 33 5f 66 72 65 65 28 7a 45 72 72 6d 73 67 29 3b  3_free(zErrmsg);
2a10: 0a 20 20 20 20 73 71 6c 69 74 65 33 4f 73 44 6c  .    sqlite3OsDl
2a20: 43 6c 6f 73 65 28 70 56 66 73 2c 20 68 61 6e 64  Close(pVfs, hand
2a30: 6c 65 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20  le);.    return 
2a40: 53 51 4c 49 54 45 5f 45 52 52 4f 52 3b 0a 20 20  SQLITE_ERROR;.  
2a50: 7d 0a 0a 20 20 2f 2a 20 41 70 70 65 6e 64 20 74  }..  /* Append t
2a60: 68 65 20 6e 65 77 20 73 68 61 72 65 64 20 6c 69  he new shared li
2a70: 62 72 61 72 79 20 68 61 6e 64 6c 65 20 74 6f 20  brary handle to 
2a80: 74 68 65 20 64 62 2d 3e 61 45 78 74 65 6e 73 69  the db->aExtensi
2a90: 6f 6e 20 61 72 72 61 79 2e 20 2a 2f 0a 20 20 64  on array. */.  d
2aa0: 62 2d 3e 6e 45 78 74 65 6e 73 69 6f 6e 2b 2b 3b  b->nExtension++;
2ab0: 0a 20 20 61 48 61 6e 64 6c 65 20 3d 20 73 71 6c  .  aHandle = sql
2ac0: 69 74 65 33 44 62 4d 61 6c 6c 6f 63 5a 65 72 6f  ite3DbMallocZero
2ad0: 28 64 62 2c 20 73 69 7a 65 6f 66 28 68 61 6e 64  (db, sizeof(hand
2ae0: 6c 65 29 2a 64 62 2d 3e 6e 45 78 74 65 6e 73 69  le)*db->nExtensi
2af0: 6f 6e 29 3b 0a 20 20 69 66 28 20 61 48 61 6e 64  on);.  if( aHand
2b00: 6c 65 3d 3d 30 20 29 7b 0a 20 20 20 20 72 65 74  le==0 ){.    ret
2b10: 75 72 6e 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d  urn SQLITE_NOMEM
2b20: 3b 0a 20 20 7d 0a 20 20 69 66 28 20 64 62 2d 3e  ;.  }.  if( db->
2b30: 6e 45 78 74 65 6e 73 69 6f 6e 3e 30 20 29 7b 0a  nExtension>0 ){.
2b40: 20 20 20 20 6d 65 6d 63 70 79 28 61 48 61 6e 64      memcpy(aHand
2b50: 6c 65 2c 20 64 62 2d 3e 61 45 78 74 65 6e 73 69  le, db->aExtensi
2b60: 6f 6e 2c 20 73 69 7a 65 6f 66 28 68 61 6e 64 6c  on, sizeof(handl
2b70: 65 29 2a 28 64 62 2d 3e 6e 45 78 74 65 6e 73 69  e)*(db->nExtensi
2b80: 6f 6e 2d 31 29 29 3b 0a 20 20 7d 0a 20 20 73 71  on-1));.  }.  sq
2b90: 6c 69 74 65 33 5f 66 72 65 65 28 64 62 2d 3e 61  lite3_free(db->a
2ba0: 45 78 74 65 6e 73 69 6f 6e 29 3b 0a 20 20 64 62  Extension);.  db
2bb0: 2d 3e 61 45 78 74 65 6e 73 69 6f 6e 20 3d 20 61  ->aExtension = a
2bc0: 48 61 6e 64 6c 65 3b 0a 0a 20 20 64 62 2d 3e 61  Handle;..  db->a
2bd0: 45 78 74 65 6e 73 69 6f 6e 5b 64 62 2d 3e 6e 45  Extension[db->nE
2be0: 78 74 65 6e 73 69 6f 6e 2d 31 5d 20 3d 20 68 61  xtension-1] = ha
2bf0: 6e 64 6c 65 3b 0a 20 20 72 65 74 75 72 6e 20 53  ndle;.  return S
2c00: 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 69 6e 74 20  QLITE_OK;.}.int 
2c10: 73 71 6c 69 74 65 33 5f 6c 6f 61 64 5f 65 78 74  sqlite3_load_ext
2c20: 65 6e 73 69 6f 6e 28 0a 20 20 73 71 6c 69 74 65  ension(.  sqlite
2c30: 33 20 2a 64 62 2c 20 20 20 20 20 20 20 20 20 20  3 *db,          
2c40: 2f 2a 20 4c 6f 61 64 20 74 68 65 20 65 78 74 65  /* Load the exte
2c50: 6e 73 69 6f 6e 20 69 6e 74 6f 20 74 68 69 73 20  nsion into this 
2c60: 64 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74  database connect
2c70: 69 6f 6e 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 63  ion */.  const c
2c80: 68 61 72 20 2a 7a 46 69 6c 65 2c 20 20 20 20 2f  har *zFile,    /
2c90: 2a 20 4e 61 6d 65 20 6f 66 20 74 68 65 20 73 68  * Name of the sh
2ca0: 61 72 65 64 20 6c 69 62 72 61 72 79 20 63 6f 6e  ared library con
2cb0: 74 61 69 6e 69 6e 67 20 65 78 74 65 6e 73 69 6f  taining extensio
2cc0: 6e 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61  n */.  const cha
2cd0: 72 20 2a 7a 50 72 6f 63 2c 20 20 20 20 2f 2a 20  r *zProc,    /* 
2ce0: 45 6e 74 72 79 20 70 6f 69 6e 74 2e 20 20 55 73  Entry point.  Us
2cf0: 65 20 22 73 71 6c 69 74 65 33 5f 65 78 74 65 6e  e "sqlite3_exten
2d00: 73 69 6f 6e 5f 69 6e 69 74 22 20 69 66 20 30 20  sion_init" if 0 
2d10: 2a 2f 0a 20 20 63 68 61 72 20 2a 2a 70 7a 45 72  */.  char **pzEr
2d20: 72 4d 73 67 20 20 20 20 20 20 20 2f 2a 20 50 75  rMsg       /* Pu
2d30: 74 20 65 72 72 6f 72 20 6d 65 73 73 61 67 65 20  t error message 
2d40: 68 65 72 65 20 69 66 20 6e 6f 74 20 30 20 2a 2f  here if not 0 */
2d50: 0a 29 7b 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20  .){.  int rc;.  
2d60: 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65 6e  sqlite3_mutex_en
2d70: 74 65 72 28 64 62 2d 3e 6d 75 74 65 78 29 3b 0a  ter(db->mutex);.
2d80: 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 4c 6f    rc = sqlite3Lo
2d90: 61 64 45 78 74 65 6e 73 69 6f 6e 28 64 62 2c 20  adExtension(db, 
2da0: 7a 46 69 6c 65 2c 20 7a 50 72 6f 63 2c 20 70 7a  zFile, zProc, pz
2db0: 45 72 72 4d 73 67 29 3b 0a 20 20 73 71 6c 69 74  ErrMsg);.  sqlit
2dc0: 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 64  e3_mutex_leave(d
2dd0: 62 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 72 65 74  b->mutex);.  ret
2de0: 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  urn rc;.}../*.**
2df0: 20 43 61 6c 6c 20 74 68 69 73 20 72 6f 75 74 69   Call this routi
2e00: 6e 65 20 77 68 65 6e 20 74 68 65 20 64 61 74 61  ne when the data
2e10: 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20  base connection 
2e20: 69 73 20 63 6c 6f 73 69 6e 67 20 69 6e 20 6f 72  is closing in or
2e30: 64 65 72 0a 2a 2a 20 74 6f 20 63 6c 65 61 6e 20  der.** to clean 
2e40: 75 70 20 6c 6f 61 64 65 64 20 65 78 74 65 6e 73  up loaded extens
2e50: 69 6f 6e 73 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c  ions.*/.void sql
2e60: 69 74 65 33 43 6c 6f 73 65 45 78 74 65 6e 73 69  ite3CloseExtensi
2e70: 6f 6e 73 28 73 71 6c 69 74 65 33 20 2a 64 62 29  ons(sqlite3 *db)
2e80: 7b 0a 20 20 69 6e 74 20 69 3b 0a 20 20 61 73 73  {.  int i;.  ass
2e90: 65 72 74 28 20 73 71 6c 69 74 65 33 5f 6d 75 74  ert( sqlite3_mut
2ea0: 65 78 5f 68 65 6c 64 28 64 62 2d 3e 6d 75 74 65  ex_held(db->mute
2eb0: 78 29 20 29 3b 0a 20 20 66 6f 72 28 69 3d 30 3b  x) );.  for(i=0;
2ec0: 20 69 3c 64 62 2d 3e 6e 45 78 74 65 6e 73 69 6f   i<db->nExtensio
2ed0: 6e 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 73 71 6c  n; i++){.    sql
2ee0: 69 74 65 33 4f 73 44 6c 43 6c 6f 73 65 28 64 62  ite3OsDlClose(db
2ef0: 2d 3e 70 56 66 73 2c 20 64 62 2d 3e 61 45 78 74  ->pVfs, db->aExt
2f00: 65 6e 73 69 6f 6e 5b 69 5d 29 3b 0a 20 20 7d 0a  ension[i]);.  }.
2f10: 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 64    sqlite3_free(d
2f20: 62 2d 3e 61 45 78 74 65 6e 73 69 6f 6e 29 3b 0a  b->aExtension);.
2f30: 7d 0a 0a 2f 2a 0a 2a 2a 20 45 6e 61 62 6c 65 20  }../*.** Enable 
2f40: 6f 72 20 64 69 73 61 62 6c 65 20 65 78 74 65 6e  or disable exten
2f50: 73 69 6f 6e 20 6c 6f 61 64 69 6e 67 2e 20 20 45  sion loading.  E
2f60: 78 74 65 6e 73 69 6f 6e 20 6c 6f 61 64 69 6e 67  xtension loading
2f70: 20 69 73 20 64 69 73 61 62 6c 65 64 20 62 79 0a   is disabled by.
2f80: 2a 2a 20 64 65 66 61 75 6c 74 20 73 6f 20 61 73  ** default so as
2f90: 20 6e 6f 74 20 74 6f 20 6f 70 65 6e 20 73 65 63   not to open sec
2fa0: 75 72 69 74 79 20 68 6f 6c 65 73 20 69 6e 20 6f  urity holes in o
2fb0: 6c 64 65 72 20 61 70 70 6c 69 63 61 74 69 6f 6e  lder application
2fc0: 73 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65  s..*/.int sqlite
2fd0: 33 5f 65 6e 61 62 6c 65 5f 6c 6f 61 64 5f 65 78  3_enable_load_ex
2fe0: 74 65 6e 73 69 6f 6e 28 73 71 6c 69 74 65 33 20  tension(sqlite3 
2ff0: 2a 64 62 2c 20 69 6e 74 20 6f 6e 6f 66 66 29 7b  *db, int onoff){
3000: 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78  .  sqlite3_mutex
3010: 5f 65 6e 74 65 72 28 64 62 2d 3e 6d 75 74 65 78  _enter(db->mutex
3020: 29 3b 0a 20 20 69 66 28 20 6f 6e 6f 66 66 20 29  );.  if( onoff )
3030: 7b 0a 20 20 20 20 64 62 2d 3e 66 6c 61 67 73 20  {.    db->flags 
3040: 7c 3d 20 53 51 4c 49 54 45 5f 4c 6f 61 64 45 78  |= SQLITE_LoadEx
3050: 74 65 6e 73 69 6f 6e 3b 0a 20 20 7d 65 6c 73 65  tension;.  }else
3060: 7b 0a 20 20 20 20 64 62 2d 3e 66 6c 61 67 73 20  {.    db->flags 
3070: 26 3d 20 7e 53 51 4c 49 54 45 5f 4c 6f 61 64 45  &= ~SQLITE_LoadE
3080: 78 74 65 6e 73 69 6f 6e 3b 0a 20 20 7d 0a 20 20  xtension;.  }.  
3090: 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65  sqlite3_mutex_le
30a0: 61 76 65 28 64 62 2d 3e 6d 75 74 65 78 29 3b 0a  ave(db->mutex);.
30b0: 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f    return SQLITE_
30c0: 4f 4b 3b 0a 7d 0a 0a 23 65 6e 64 69 66 20 2f 2a  OK;.}..#endif /*
30d0: 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 4c 4f 41   SQLITE_OMIT_LOA
30e0: 44 5f 45 58 54 45 4e 53 49 4f 4e 20 2a 2f 0a 0a  D_EXTENSION */..
30f0: 2f 2a 0a 2a 2a 20 54 68 65 20 61 75 74 6f 2d 65  /*.** The auto-e
3100: 78 74 65 6e 73 69 6f 6e 20 63 6f 64 65 20 61 64  xtension code ad
3110: 64 65 64 20 72 65 67 61 72 64 6c 65 73 73 20 6f  ded regardless o
3120: 66 20 77 68 65 74 68 65 72 20 6f 72 20 6e 6f 74  f whether or not
3130: 20 65 78 74 65 6e 73 69 6f 6e 0a 2a 2a 20 6c 6f   extension.** lo
3140: 61 64 69 6e 67 20 69 73 20 73 75 70 70 6f 72 74  ading is support
3150: 65 64 2e 20 20 57 65 20 6e 65 65 64 20 61 20 64  ed.  We need a d
3160: 75 6d 6d 79 20 73 71 6c 69 74 65 33 41 70 69 73  ummy sqlite3Apis
3170: 20 70 6f 69 6e 74 65 72 20 66 6f 72 20 74 68 61   pointer for tha
3180: 74 0a 2a 2a 20 63 6f 64 65 20 69 66 20 72 65 67  t.** code if reg
3190: 75 6c 61 72 20 65 78 74 65 6e 73 69 6f 6e 20 6c  ular extension l
31a0: 6f 61 64 69 6e 67 20 69 73 20 6e 6f 74 20 61 76  oading is not av
31b0: 61 69 6c 61 62 6c 65 2e 20 20 54 68 69 73 20 69  ailable.  This i
31c0: 73 20 74 68 61 74 0a 2a 2a 20 64 75 6d 6d 79 20  s that.** dummy 
31d0: 70 6f 69 6e 74 65 72 2e 0a 2a 2f 0a 23 69 66 64  pointer..*/.#ifd
31e0: 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 4c  ef SQLITE_OMIT_L
31f0: 4f 41 44 5f 45 58 54 45 4e 53 49 4f 4e 0a 73 74  OAD_EXTENSION.st
3200: 61 74 69 63 20 63 6f 6e 73 74 20 73 71 6c 69 74  atic const sqlit
3210: 65 33 5f 61 70 69 5f 72 6f 75 74 69 6e 65 73 20  e3_api_routines 
3220: 73 71 6c 69 74 65 33 41 70 69 73 20 3d 20 7b 20  sqlite3Apis = { 
3230: 30 20 7d 3b 0a 23 65 6e 64 69 66 0a 0a 0a 2f 2a  0 };.#endif.../*
3240: 0a 2a 2a 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e  .** The followin
3250: 67 20 6f 62 6a 65 63 74 20 68 6f 6c 64 73 20 74  g object holds t
3260: 68 65 20 6c 69 73 74 20 6f 66 20 61 75 74 6f 6d  he list of autom
3270: 61 74 69 63 61 6c 6c 79 20 6c 6f 61 64 65 64 0a  atically loaded.
3280: 2a 2a 20 65 78 74 65 6e 73 69 6f 6e 73 2e 0a 2a  ** extensions..*
3290: 2a 0a 2a 2a 20 54 68 69 73 20 6c 69 73 74 20 69  *.** This list i
32a0: 73 20 73 68 61 72 65 64 20 61 63 72 6f 73 73 20  s shared across 
32b0: 74 68 72 65 61 64 73 2e 20 20 54 68 65 20 53 51  threads.  The SQ
32c0: 4c 49 54 45 5f 4d 55 54 45 58 5f 53 54 41 54 49  LITE_MUTEX_STATI
32d0: 43 5f 4d 41 53 54 45 52 0a 2a 2a 20 6d 75 74 65  C_MASTER.** mute
32e0: 78 20 6d 75 73 74 20 62 65 20 68 65 6c 64 20 77  x must be held w
32f0: 68 69 6c 65 20 61 63 63 65 73 73 69 6e 67 20 74  hile accessing t
3300: 68 69 73 20 6c 69 73 74 2e 0a 2a 2f 0a 73 74 61  his list..*/.sta
3310: 74 69 63 20 73 74 72 75 63 74 20 7b 0a 20 20 69  tic struct {.  i
3320: 6e 74 20 6e 45 78 74 3b 20 20 20 20 20 20 20 20  nt nExt;        
3330: 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 65 6e 74  /* Number of ent
3340: 72 69 65 73 20 69 6e 20 61 45 78 74 5b 5d 20 2a  ries in aExt[] *
3350: 2f 20 20 20 20 20 20 20 20 20 20 0a 20 20 76 6f  /          .  vo
3360: 69 64 20 2a 2a 61 45 78 74 3b 20 20 20 20 20 2f  id **aExt;     /
3370: 2a 20 50 6f 69 6e 74 65 72 73 20 74 6f 20 74 68  * Pointers to th
3380: 65 20 65 78 74 65 6e 73 69 6f 6e 20 69 6e 69 74  e extension init
3390: 20 66 75 6e 63 74 69 6f 6e 73 20 2a 2f 0a 7d 20   functions */.} 
33a0: 61 75 74 6f 65 78 74 20 3d 20 7b 20 30 2c 20 30  autoext = { 0, 0
33b0: 20 7d 3b 0a 0a 0a 2f 2a 0a 2a 2a 20 52 65 67 69   };.../*.** Regi
33c0: 73 74 65 72 20 61 20 73 74 61 74 69 63 61 6c 6c  ster a staticall
33d0: 79 20 6c 69 6e 6b 65 64 20 65 78 74 65 6e 73 69  y linked extensi
33e0: 6f 6e 20 74 68 61 74 20 69 73 20 61 75 74 6f 6d  on that is autom
33f0: 61 74 69 63 61 6c 6c 79 0a 2a 2a 20 6c 6f 61 64  atically.** load
3400: 65 64 20 62 79 20 65 76 65 72 79 20 6e 65 77 20  ed by every new 
3410: 64 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74  database connect
3420: 69 6f 6e 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69  ion..*/.int sqli
3430: 74 65 33 5f 61 75 74 6f 5f 65 78 74 65 6e 73 69  te3_auto_extensi
3440: 6f 6e 28 76 6f 69 64 20 2a 78 49 6e 69 74 29 7b  on(void *xInit){
3450: 0a 20 20 69 6e 74 20 72 63 20 3d 20 53 51 4c 49  .  int rc = SQLI
3460: 54 45 5f 4f 4b 3b 0a 23 69 66 6e 64 65 66 20 53  TE_OK;.#ifndef S
3470: 51 4c 49 54 45 5f 4f 4d 49 54 5f 41 55 54 4f 49  QLITE_OMIT_AUTOI
3480: 4e 49 54 0a 20 20 72 63 20 3d 20 73 71 6c 69 74  NIT.  rc = sqlit
3490: 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65 28 29 3b  e3_initialize();
34a0: 0a 20 20 69 66 28 20 72 63 20 29 7b 0a 20 20 20  .  if( rc ){.   
34b0: 20 72 65 74 75 72 6e 20 72 63 3b 0a 20 20 7d 65   return rc;.  }e
34c0: 6c 73 65 0a 23 65 6e 64 69 66 0a 20 20 7b 0a 20  lse.#endif.  {. 
34d0: 20 20 20 69 6e 74 20 69 3b 0a 23 69 66 6e 64 65     int i;.#ifnde
34e0: 66 20 53 51 4c 49 54 45 5f 4d 55 54 45 58 5f 4e  f SQLITE_MUTEX_N
34f0: 4f 4f 50 0a 20 20 20 20 73 71 6c 69 74 65 33 5f  OOP.    sqlite3_
3500: 6d 75 74 65 78 20 2a 6d 75 74 65 78 20 3d 20 73  mutex *mutex = s
3510: 71 6c 69 74 65 33 4d 75 74 65 78 41 6c 6c 6f 63  qlite3MutexAlloc
3520: 28 53 51 4c 49 54 45 5f 4d 55 54 45 58 5f 53 54  (SQLITE_MUTEX_ST
3530: 41 54 49 43 5f 4d 41 53 54 45 52 29 3b 0a 23 65  ATIC_MASTER);.#e
3540: 6e 64 69 66 0a 20 20 20 20 73 71 6c 69 74 65 33  ndif.    sqlite3
3550: 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28 6d 75 74  _mutex_enter(mut
3560: 65 78 29 3b 0a 20 20 20 20 66 6f 72 28 69 3d 30  ex);.    for(i=0
3570: 3b 20 69 3c 61 75 74 6f 65 78 74 2e 6e 45 78 74  ; i<autoext.nExt
3580: 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 69 66  ; i++){.      if
3590: 28 20 61 75 74 6f 65 78 74 2e 61 45 78 74 5b 69  ( autoext.aExt[i
35a0: 5d 3d 3d 78 49 6e 69 74 20 29 20 62 72 65 61 6b  ]==xInit ) break
35b0: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 66 28 20  ;.    }.    if( 
35c0: 69 3d 3d 61 75 74 6f 65 78 74 2e 6e 45 78 74 20  i==autoext.nExt 
35d0: 29 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e 42 79  ){.      int nBy
35e0: 74 65 20 3d 20 28 61 75 74 6f 65 78 74 2e 6e 45  te = (autoext.nE
35f0: 78 74 2b 31 29 2a 73 69 7a 65 6f 66 28 61 75 74  xt+1)*sizeof(aut
3600: 6f 65 78 74 2e 61 45 78 74 5b 30 5d 29 3b 0a 20  oext.aExt[0]);. 
3610: 20 20 20 20 20 76 6f 69 64 20 2a 2a 61 4e 65 77       void **aNew
3620: 3b 0a 20 20 20 20 20 20 61 4e 65 77 20 3d 20 73  ;.      aNew = s
3630: 71 6c 69 74 65 33 5f 72 65 61 6c 6c 6f 63 28 61  qlite3_realloc(a
3640: 75 74 6f 65 78 74 2e 61 45 78 74 2c 20 6e 42 79  utoext.aExt, nBy
3650: 74 65 29 3b 0a 20 20 20 20 20 20 69 66 28 20 61  te);.      if( a
3660: 4e 65 77 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20  New==0 ){.      
3670: 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 4e 4f    rc = SQLITE_NO
3680: 4d 45 4d 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65  MEM;.      }else
3690: 7b 0a 20 20 20 20 20 20 20 20 61 75 74 6f 65 78  {.        autoex
36a0: 74 2e 61 45 78 74 20 3d 20 61 4e 65 77 3b 0a 20  t.aExt = aNew;. 
36b0: 20 20 20 20 20 20 20 61 75 74 6f 65 78 74 2e 61         autoext.a
36c0: 45 78 74 5b 61 75 74 6f 65 78 74 2e 6e 45 78 74  Ext[autoext.nExt
36d0: 5d 20 3d 20 78 49 6e 69 74 3b 0a 20 20 20 20 20  ] = xInit;.     
36e0: 20 20 20 61 75 74 6f 65 78 74 2e 6e 45 78 74 2b     autoext.nExt+
36f0: 2b 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d  +;.      }.    }
3700: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 6d 75 74  .    sqlite3_mut
3710: 65 78 5f 6c 65 61 76 65 28 6d 75 74 65 78 29 3b  ex_leave(mutex);
3720: 0a 20 20 20 20 61 73 73 65 72 74 28 20 28 72 63  .    assert( (rc
3730: 26 30 78 66 66 29 3d 3d 72 63 20 29 3b 0a 20 20  &0xff)==rc );.  
3740: 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 20 20 7d    return rc;.  }
3750: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 73 65 74 20  .}../*.** Reset 
3760: 74 68 65 20 61 75 74 6f 6d 61 74 69 63 20 65 78  the automatic ex
3770: 74 65 6e 73 69 6f 6e 20 6c 6f 61 64 69 6e 67 20  tension loading 
3780: 6d 65 63 68 61 6e 69 73 6d 2e 0a 2a 2f 0a 76 6f  mechanism..*/.vo
3790: 69 64 20 73 71 6c 69 74 65 33 5f 72 65 73 65 74  id sqlite3_reset
37a0: 5f 61 75 74 6f 5f 65 78 74 65 6e 73 69 6f 6e 28  _auto_extension(
37b0: 76 6f 69 64 29 7b 0a 23 69 66 6e 64 65 66 20 53  void){.#ifndef S
37c0: 51 4c 49 54 45 5f 4f 4d 49 54 5f 41 55 54 4f 49  QLITE_OMIT_AUTOI
37d0: 4e 49 54 0a 20 20 69 66 28 20 73 71 6c 69 74 65  NIT.  if( sqlite
37e0: 33 5f 69 6e 69 74 69 61 6c 69 7a 65 28 29 3d 3d  3_initialize()==
37f0: 53 51 4c 49 54 45 5f 4f 4b 20 29 0a 23 65 6e 64  SQLITE_OK ).#end
3800: 69 66 0a 20 20 7b 0a 23 69 66 6e 64 65 66 20 53  if.  {.#ifndef S
3810: 51 4c 49 54 45 5f 4d 55 54 45 58 5f 4e 4f 4f 50  QLITE_MUTEX_NOOP
3820: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 6d 75 74  .    sqlite3_mut
3830: 65 78 20 2a 6d 75 74 65 78 20 3d 20 73 71 6c 69  ex *mutex = sqli
3840: 74 65 33 4d 75 74 65 78 41 6c 6c 6f 63 28 53 51  te3MutexAlloc(SQ
3850: 4c 49 54 45 5f 4d 55 54 45 58 5f 53 54 41 54 49  LITE_MUTEX_STATI
3860: 43 5f 4d 41 53 54 45 52 29 3b 0a 23 65 6e 64 69  C_MASTER);.#endi
3870: 66 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 6d 75  f.    sqlite3_mu
3880: 74 65 78 5f 65 6e 74 65 72 28 6d 75 74 65 78 29  tex_enter(mutex)
3890: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66 72  ;.    sqlite3_fr
38a0: 65 65 28 61 75 74 6f 65 78 74 2e 61 45 78 74 29  ee(autoext.aExt)
38b0: 3b 0a 20 20 20 20 61 75 74 6f 65 78 74 2e 61 45  ;.    autoext.aE
38c0: 78 74 20 3d 20 30 3b 0a 20 20 20 20 61 75 74 6f  xt = 0;.    auto
38d0: 65 78 74 2e 6e 45 78 74 20 3d 20 30 3b 0a 20 20  ext.nExt = 0;.  
38e0: 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f    sqlite3_mutex_
38f0: 6c 65 61 76 65 28 6d 75 74 65 78 29 3b 0a 20 20  leave(mutex);.  
3900: 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 4c 6f 61 64 20  }.}../*.** Load 
3910: 61 6c 6c 20 61 75 74 6f 6d 61 74 69 63 20 65 78  all automatic ex
3920: 74 65 6e 73 69 6f 6e 73 2e 0a 2a 2f 0a 69 6e 74  tensions..*/.int
3930: 20 73 71 6c 69 74 65 33 41 75 74 6f 4c 6f 61 64   sqlite3AutoLoad
3940: 45 78 74 65 6e 73 69 6f 6e 73 28 73 71 6c 69 74  Extensions(sqlit
3950: 65 33 20 2a 64 62 29 7b 0a 20 20 69 6e 74 20 69  e3 *db){.  int i
3960: 3b 0a 20 20 69 6e 74 20 67 6f 20 3d 20 31 3b 0a  ;.  int go = 1;.
3970: 20 20 69 6e 74 20 72 63 20 3d 20 53 51 4c 49 54    int rc = SQLIT
3980: 45 5f 4f 4b 3b 0a 20 20 69 6e 74 20 28 2a 78 49  E_OK;.  int (*xI
3990: 6e 69 74 29 28 73 71 6c 69 74 65 33 2a 2c 63 68  nit)(sqlite3*,ch
39a0: 61 72 2a 2a 2c 63 6f 6e 73 74 20 73 71 6c 69 74  ar**,const sqlit
39b0: 65 33 5f 61 70 69 5f 72 6f 75 74 69 6e 65 73 2a  e3_api_routines*
39c0: 29 3b 0a 0a 20 20 69 66 28 20 61 75 74 6f 65 78  );..  if( autoex
39d0: 74 2e 6e 45 78 74 3d 3d 30 20 29 7b 0a 20 20 20  t.nExt==0 ){.   
39e0: 20 2f 2a 20 43 6f 6d 6d 6f 6e 20 63 61 73 65 3a   /* Common case:
39f0: 20 65 61 72 6c 79 20 6f 75 74 20 77 69 74 68 6f   early out witho
3a00: 75 74 20 65 76 65 72 79 20 68 61 76 69 6e 67 20  ut every having 
3a10: 74 6f 20 61 63 71 75 69 72 65 20 61 20 6d 75 74  to acquire a mut
3a20: 65 78 20 2a 2f 0a 20 20 20 20 72 65 74 75 72 6e  ex */.    return
3a30: 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 7d 0a   SQLITE_OK;.  }.
3a40: 20 20 66 6f 72 28 69 3d 30 3b 20 67 6f 3b 20 69    for(i=0; go; i
3a50: 2b 2b 29 7b 0a 20 20 20 20 63 68 61 72 20 2a 7a  ++){.    char *z
3a60: 45 72 72 6d 73 67 20 3d 20 30 3b 0a 23 69 66 6e  Errmsg = 0;.#ifn
3a70: 64 65 66 20 53 51 4c 49 54 45 5f 4d 55 54 45 58  def SQLITE_MUTEX
3a80: 5f 4e 4f 4f 50 0a 20 20 20 20 73 71 6c 69 74 65  _NOOP.    sqlite
3a90: 33 5f 6d 75 74 65 78 20 2a 6d 75 74 65 78 20 3d  3_mutex *mutex =
3aa0: 20 73 71 6c 69 74 65 33 4d 75 74 65 78 41 6c 6c   sqlite3MutexAll
3ab0: 6f 63 28 53 51 4c 49 54 45 5f 4d 55 54 45 58 5f  oc(SQLITE_MUTEX_
3ac0: 53 54 41 54 49 43 5f 4d 41 53 54 45 52 29 3b 0a  STATIC_MASTER);.
3ad0: 23 65 6e 64 69 66 0a 20 20 20 20 73 71 6c 69 74  #endif.    sqlit
3ae0: 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28 6d  e3_mutex_enter(m
3af0: 75 74 65 78 29 3b 0a 20 20 20 20 69 66 28 20 69  utex);.    if( i
3b00: 3e 3d 61 75 74 6f 65 78 74 2e 6e 45 78 74 20 29  >=autoext.nExt )
3b10: 7b 0a 20 20 20 20 20 20 78 49 6e 69 74 20 3d 20  {.      xInit = 
3b20: 30 3b 0a 20 20 20 20 20 20 67 6f 20 3d 20 30 3b  0;.      go = 0;
3b30: 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  .    }else{.    
3b40: 20 20 78 49 6e 69 74 20 3d 20 28 69 6e 74 28 2a    xInit = (int(*
3b50: 29 28 73 71 6c 69 74 65 33 2a 2c 63 68 61 72 2a  )(sqlite3*,char*
3b60: 2a 2c 63 6f 6e 73 74 20 73 71 6c 69 74 65 33 5f  *,const sqlite3_
3b70: 61 70 69 5f 72 6f 75 74 69 6e 65 73 2a 29 29 0a  api_routines*)).
3b80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 61 75                au
3b90: 74 6f 65 78 74 2e 61 45 78 74 5b 69 5d 3b 0a 20  toext.aExt[i];. 
3ba0: 20 20 20 7d 0a 20 20 20 20 73 71 6c 69 74 65 33     }.    sqlite3
3bb0: 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 6d 75 74  _mutex_leave(mut
3bc0: 65 78 29 3b 0a 20 20 20 20 69 66 28 20 78 49 6e  ex);.    if( xIn
3bd0: 69 74 20 26 26 20 78 49 6e 69 74 28 64 62 2c 20  it && xInit(db, 
3be0: 26 7a 45 72 72 6d 73 67 2c 20 26 73 71 6c 69 74  &zErrmsg, &sqlit
3bf0: 65 33 41 70 69 73 29 20 29 7b 0a 20 20 20 20 20  e3Apis) ){.     
3c00: 20 73 71 6c 69 74 65 33 45 72 72 6f 72 28 64 62   sqlite3Error(db
3c10: 2c 20 53 51 4c 49 54 45 5f 45 52 52 4f 52 2c 0a  , SQLITE_ERROR,.
3c20: 20 20 20 20 20 20 20 20 20 20 20 20 22 61 75 74              "aut
3c30: 6f 6d 61 74 69 63 20 65 78 74 65 6e 73 69 6f 6e  omatic extension
3c40: 20 6c 6f 61 64 69 6e 67 20 66 61 69 6c 65 64 3a   loading failed:
3c50: 20 25 73 22 2c 20 7a 45 72 72 6d 73 67 29 3b 0a   %s", zErrmsg);.
3c60: 20 20 20 20 20 20 67 6f 20 3d 20 30 3b 0a 20 20        go = 0;.  
3c70: 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f      rc = SQLITE_
3c80: 45 52 52 4f 52 3b 0a 20 20 20 20 20 20 73 71 6c  ERROR;.      sql
3c90: 69 74 65 33 5f 66 72 65 65 28 7a 45 72 72 6d 73  ite3_free(zErrms
3ca0: 67 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20  g);.    }.  }.  
3cb0: 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a           return rc;.}.