/ Hex Artifact Content
Login

Artifact eb1fe4f44d7c8ff53fc0c6a4388ab79fbd34cd64:


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 33 20 32 30 30 38 2f 30 38 2f  ,v 1.53 2008/08/
01f0: 30 32 20 30 33 3a 35 30 3a 33 39 20 64 72 68 20  02 03:50:39 drh 
0200: 45 78 70 20 24 0a 2a 2f 0a 0a 23 69 66 6e 64 65  Exp $.*/..#ifnde
0210: 66 20 53 51 4c 49 54 45 5f 43 4f 52 45 0a 20 20  f SQLITE_CORE.  
0220: 23 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 43  #define SQLITE_C
0230: 4f 52 45 20 31 20 20 2f 2a 20 44 69 73 61 62 6c  ORE 1  /* Disabl
0240: 65 20 74 68 65 20 41 50 49 20 72 65 64 65 66 69  e the API redefi
0250: 6e 69 74 69 6f 6e 20 69 6e 20 73 71 6c 69 74 65  nition in sqlite
0260: 33 65 78 74 2e 68 20 2a 2f 0a 23 65 6e 64 69 66  3ext.h */.#endif
0270: 0a 23 69 6e 63 6c 75 64 65 20 22 73 71 6c 69 74  .#include "sqlit
0280: 65 33 65 78 74 2e 68 22 0a 23 69 6e 63 6c 75 64  e3ext.h".#includ
0290: 65 20 22 73 71 6c 69 74 65 49 6e 74 2e 68 22 0a  e "sqliteInt.h".
02a0: 23 69 6e 63 6c 75 64 65 20 3c 73 74 72 69 6e 67  #include <string
02b0: 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 63 74  .h>.#include <ct
02c0: 79 70 65 2e 68 3e 0a 0a 23 69 66 6e 64 65 66 20  ype.h>..#ifndef 
02d0: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 4c 4f 41 44  SQLITE_OMIT_LOAD
02e0: 5f 45 58 54 45 4e 53 49 4f 4e 0a 0a 2f 2a 0a 2a  _EXTENSION../*.*
02f0: 2a 20 53 6f 6d 65 20 41 50 49 20 72 6f 75 74 69  * Some API routi
0300: 6e 65 73 20 61 72 65 20 6f 6d 69 74 74 65 64 20  nes are omitted 
0310: 77 68 65 6e 20 76 61 72 69 6f 75 73 20 66 65 61  when various fea
0320: 74 75 72 65 73 20 61 72 65 0a 2a 2a 20 65 78 63  tures are.** exc
0330: 6c 75 64 65 64 20 66 72 6f 6d 20 61 20 62 75 69  luded from a bui
0340: 6c 64 20 6f 66 20 53 51 4c 69 74 65 2e 20 20 53  ld of SQLite.  S
0350: 75 62 73 74 69 74 75 74 65 20 61 20 4e 55 4c 4c  ubstitute a NULL
0360: 20 70 6f 69 6e 74 65 72 0a 2a 2a 20 66 6f 72 20   pointer.** for 
0370: 61 6e 79 20 6d 69 73 73 69 6e 67 20 41 50 49 73  any missing APIs
0380: 2e 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c  ..*/.#ifndef SQL
0390: 49 54 45 5f 45 4e 41 42 4c 45 5f 43 4f 4c 55 4d  ITE_ENABLE_COLUM
03a0: 4e 5f 4d 45 54 41 44 41 54 41 0a 23 20 64 65 66  N_METADATA.# def
03b0: 69 6e 65 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75  ine sqlite3_colu
03c0: 6d 6e 5f 64 61 74 61 62 61 73 65 5f 6e 61 6d 65  mn_database_name
03d0: 20 20 20 30 0a 23 20 64 65 66 69 6e 65 20 73 71     0.# define sq
03e0: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 61 74  lite3_column_dat
03f0: 61 62 61 73 65 5f 6e 61 6d 65 31 36 20 30 0a 23  abase_name16 0.#
0400: 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f   define sqlite3_
0410: 63 6f 6c 75 6d 6e 5f 74 61 62 6c 65 5f 6e 61 6d  column_table_nam
0420: 65 20 20 20 20 20 20 30 0a 23 20 64 65 66 69 6e  e      0.# defin
0430: 65 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  e sqlite3_column
0440: 5f 74 61 62 6c 65 5f 6e 61 6d 65 31 36 20 20 20  _table_name16   
0450: 20 30 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69   0.# define sqli
0460: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6f 72 69 67 69  te3_column_origi
0470: 6e 5f 6e 61 6d 65 20 20 20 20 20 30 0a 23 20 64  n_name     0.# d
0480: 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 63 6f  efine sqlite3_co
0490: 6c 75 6d 6e 5f 6f 72 69 67 69 6e 5f 6e 61 6d 65  lumn_origin_name
04a0: 31 36 20 20 20 30 0a 23 20 64 65 66 69 6e 65 20  16   0.# define 
04b0: 73 71 6c 69 74 65 33 5f 74 61 62 6c 65 5f 63 6f  sqlite3_table_co
04c0: 6c 75 6d 6e 5f 6d 65 74 61 64 61 74 61 20 20 30  lumn_metadata  0
04d0: 0a 23 65 6e 64 69 66 0a 0a 23 69 66 64 65 66 20  .#endif..#ifdef 
04e0: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 41 55 54 48  SQLITE_OMIT_AUTH
04f0: 4f 52 49 5a 41 54 49 4f 4e 0a 23 20 64 65 66 69  ORIZATION.# defi
0500: 6e 65 20 73 71 6c 69 74 65 33 5f 73 65 74 5f 61  ne sqlite3_set_a
0510: 75 74 68 6f 72 69 7a 65 72 20 20 20 20 20 20 20  uthorizer       
0520: 20 20 30 0a 23 65 6e 64 69 66 0a 0a 23 69 66 64    0.#endif..#ifd
0530: 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 55  ef SQLITE_OMIT_U
0540: 54 46 31 36 0a 23 20 64 65 66 69 6e 65 20 73 71  TF16.# define sq
0550: 6c 69 74 65 33 5f 62 69 6e 64 5f 74 65 78 74 31  lite3_bind_text1
0560: 36 20 20 20 20 20 20 20 20 20 20 20 20 30 0a 23  6            0.#
0570: 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f   define sqlite3_
0580: 63 6f 6c 6c 61 74 69 6f 6e 5f 6e 65 65 64 65 64  collation_needed
0590: 31 36 20 20 20 20 20 30 0a 23 20 64 65 66 69 6e  16     0.# defin
05a0: 65 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  e sqlite3_column
05b0: 5f 64 65 63 6c 74 79 70 65 31 36 20 20 20 20 20  _decltype16     
05c0: 20 30 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69   0.# define sqli
05d0: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d 65 31  te3_column_name1
05e0: 36 20 20 20 20 20 20 20 20 20 20 30 0a 23 20 64  6          0.# d
05f0: 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 63 6f  efine sqlite3_co
0600: 6c 75 6d 6e 5f 74 65 78 74 31 36 20 20 20 20 20  lumn_text16     
0610: 20 20 20 20 20 30 0a 23 20 64 65 66 69 6e 65 20       0.# define 
0620: 73 71 6c 69 74 65 33 5f 63 6f 6d 70 6c 65 74 65  sqlite3_complete
0630: 31 36 20 20 20 20 20 20 20 20 20 20 20 20 20 30  16             0
0640: 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65  .# define sqlite
0650: 33 5f 63 72 65 61 74 65 5f 63 6f 6c 6c 61 74 69  3_create_collati
0660: 6f 6e 31 36 20 20 20 20 20 30 0a 23 20 64 65 66  on16     0.# def
0670: 69 6e 65 20 73 71 6c 69 74 65 33 5f 63 72 65 61  ine sqlite3_crea
0680: 74 65 5f 66 75 6e 63 74 69 6f 6e 31 36 20 20 20  te_function16   
0690: 20 20 20 30 0a 23 20 64 65 66 69 6e 65 20 73 71     0.# define sq
06a0: 6c 69 74 65 33 5f 65 72 72 6d 73 67 31 36 20 20  lite3_errmsg16  
06b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 30 0a 23               0.#
06c0: 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f   define sqlite3_
06d0: 6f 70 65 6e 31 36 20 20 20 20 20 20 20 20 20 20  open16          
06e0: 20 20 20 20 20 20 20 30 0a 23 20 64 65 66 69 6e         0.# defin
06f0: 65 20 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72  e sqlite3_prepar
0700: 65 31 36 20 20 20 20 20 20 20 20 20 20 20 20 20  e16             
0710: 20 30 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69   0.# define sqli
0720: 74 65 33 5f 70 72 65 70 61 72 65 31 36 5f 76 32  te3_prepare16_v2
0730: 20 20 20 20 20 20 20 20 20 20 20 30 0a 23 20 64             0.# d
0740: 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 72 65  efine sqlite3_re
0750: 73 75 6c 74 5f 65 72 72 6f 72 31 36 20 20 20 20  sult_error16    
0760: 20 20 20 20 20 30 0a 23 20 64 65 66 69 6e 65 20       0.# define 
0770: 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 74  sqlite3_result_t
0780: 65 78 74 31 36 20 20 20 20 20 20 20 20 20 20 30  ext16          0
0790: 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65  .# define sqlite
07a0: 33 5f 72 65 73 75 6c 74 5f 74 65 78 74 31 36 62  3_result_text16b
07b0: 65 20 20 20 20 20 20 20 20 30 0a 23 20 64 65 66  e        0.# def
07c0: 69 6e 65 20 73 71 6c 69 74 65 33 5f 72 65 73 75  ine sqlite3_resu
07d0: 6c 74 5f 74 65 78 74 31 36 6c 65 20 20 20 20 20  lt_text16le     
07e0: 20 20 20 30 0a 23 20 64 65 66 69 6e 65 20 73 71     0.# define sq
07f0: 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74  lite3_value_text
0800: 31 36 20 20 20 20 20 20 20 20 20 20 20 30 0a 23  16           0.#
0810: 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f   define sqlite3_
0820: 76 61 6c 75 65 5f 74 65 78 74 31 36 62 65 20 20  value_text16be  
0830: 20 20 20 20 20 20 20 30 0a 23 20 64 65 66 69 6e         0.# defin
0840: 65 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f  e sqlite3_value_
0850: 74 65 78 74 31 36 6c 65 20 20 20 20 20 20 20 20  text16le        
0860: 20 30 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69   0.# define sqli
0870: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 61 74 61 62  te3_column_datab
0880: 61 73 65 5f 6e 61 6d 65 31 36 20 30 0a 23 20 64  ase_name16 0.# d
0890: 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 63 6f  efine sqlite3_co
08a0: 6c 75 6d 6e 5f 74 61 62 6c 65 5f 6e 61 6d 65 31  lumn_table_name1
08b0: 36 20 20 20 20 30 0a 23 20 64 65 66 69 6e 65 20  6    0.# define 
08c0: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 6f  sqlite3_column_o
08d0: 72 69 67 69 6e 5f 6e 61 6d 65 31 36 20 20 20 30  rigin_name16   0
08e0: 0a 23 65 6e 64 69 66 0a 0a 23 69 66 64 65 66 20  .#endif..#ifdef 
08f0: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 43 4f 4d 50  SQLITE_OMIT_COMP
0900: 4c 45 54 45 0a 23 20 64 65 66 69 6e 65 20 73 71  LETE.# define sq
0910: 6c 69 74 65 33 5f 63 6f 6d 70 6c 65 74 65 20 30  lite3_complete 0
0920: 0a 23 20 64 65 66 69 6e 65 20 73 71 6c 69 74 65  .# define sqlite
0930: 33 5f 63 6f 6d 70 6c 65 74 65 31 36 20 30 0a 23  3_complete16 0.#
0940: 65 6e 64 69 66 0a 0a 23 69 66 64 65 66 20 53 51  endif..#ifdef SQ
0950: 4c 49 54 45 5f 4f 4d 49 54 5f 50 52 4f 47 52 45  LITE_OMIT_PROGRE
0960: 53 53 5f 43 41 4c 4c 42 41 43 4b 0a 23 20 64 65  SS_CALLBACK.# de
0970: 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 70 72 6f  fine sqlite3_pro
0980: 67 72 65 73 73 5f 68 61 6e 64 6c 65 72 20 30 0a  gress_handler 0.
0990: 23 65 6e 64 69 66 0a 0a 23 69 66 64 65 66 20 53  #endif..#ifdef S
09a0: 51 4c 49 54 45 5f 4f 4d 49 54 5f 56 49 52 54 55  QLITE_OMIT_VIRTU
09b0: 41 4c 54 41 42 4c 45 0a 23 20 64 65 66 69 6e 65  ALTABLE.# define
09c0: 20 73 71 6c 69 74 65 33 5f 63 72 65 61 74 65 5f   sqlite3_create_
09d0: 6d 6f 64 75 6c 65 20 30 0a 23 20 64 65 66 69 6e  module 0.# defin
09e0: 65 20 73 71 6c 69 74 65 33 5f 63 72 65 61 74 65  e sqlite3_create
09f0: 5f 6d 6f 64 75 6c 65 5f 76 32 20 30 0a 23 20 64  _module_v2 0.# d
0a00: 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 64 65  efine sqlite3_de
0a10: 63 6c 61 72 65 5f 76 74 61 62 20 30 0a 23 65 6e  clare_vtab 0.#en
0a20: 64 69 66 0a 0a 23 69 66 64 65 66 20 53 51 4c 49  dif..#ifdef SQLI
0a30: 54 45 5f 4f 4d 49 54 5f 53 48 41 52 45 44 5f 43  TE_OMIT_SHARED_C
0a40: 41 43 48 45 0a 23 20 64 65 66 69 6e 65 20 73 71  ACHE.# define sq
0a50: 6c 69 74 65 33 5f 65 6e 61 62 6c 65 5f 73 68 61  lite3_enable_sha
0a60: 72 65 64 5f 63 61 63 68 65 20 30 0a 23 65 6e 64  red_cache 0.#end
0a70: 69 66 0a 0a 23 69 66 64 65 66 20 53 51 4c 49 54  if..#ifdef SQLIT
0a80: 45 5f 4f 4d 49 54 5f 54 52 41 43 45 0a 23 20 64  E_OMIT_TRACE.# d
0a90: 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 70 72  efine sqlite3_pr
0aa0: 6f 66 69 6c 65 20 20 20 20 20 20 20 30 0a 23 20  ofile       0.# 
0ab0: 64 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 74  define sqlite3_t
0ac0: 72 61 63 65 20 20 20 20 20 20 20 20 20 30 0a 23  race         0.#
0ad0: 65 6e 64 69 66 0a 0a 23 69 66 64 65 66 20 53 51  endif..#ifdef SQ
0ae0: 4c 49 54 45 5f 4f 4d 49 54 5f 47 45 54 5f 54 41  LITE_OMIT_GET_TA
0af0: 42 4c 45 0a 23 20 64 65 66 69 6e 65 20 73 71 6c  BLE.# define sql
0b00: 69 74 65 33 5f 66 72 65 65 5f 74 61 62 6c 65 20  ite3_free_table 
0b10: 20 20 20 30 0a 23 20 64 65 66 69 6e 65 20 73 71     0.# define sq
0b20: 6c 69 74 65 33 5f 67 65 74 5f 74 61 62 6c 65 20  lite3_get_table 
0b30: 20 20 20 20 30 0a 23 65 6e 64 69 66 0a 0a 23 69      0.#endif..#i
0b40: 66 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54  fdef SQLITE_OMIT
0b50: 5f 49 4e 43 52 42 4c 4f 42 0a 23 64 65 66 69 6e  _INCRBLOB.#defin
0b60: 65 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 7a  e sqlite3_bind_z
0b70: 65 72 6f 62 6c 6f 62 20 20 30 0a 23 64 65 66 69  eroblob  0.#defi
0b80: 6e 65 20 73 71 6c 69 74 65 33 5f 62 6c 6f 62 5f  ne sqlite3_blob_
0b90: 62 79 74 65 73 20 20 20 20 20 30 0a 23 64 65 66  bytes     0.#def
0ba0: 69 6e 65 20 73 71 6c 69 74 65 33 5f 62 6c 6f 62  ine sqlite3_blob
0bb0: 5f 63 6c 6f 73 65 20 20 20 20 20 30 0a 23 64 65  _close     0.#de
0bc0: 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 62 6c 6f  fine sqlite3_blo
0bd0: 62 5f 6f 70 65 6e 20 20 20 20 20 20 30 0a 23 64  b_open      0.#d
0be0: 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 62 6c  efine sqlite3_bl
0bf0: 6f 62 5f 72 65 61 64 20 20 20 20 20 20 30 0a 23  ob_read      0.#
0c00: 64 65 66 69 6e 65 20 73 71 6c 69 74 65 33 5f 62  define sqlite3_b
0c10: 6c 6f 62 5f 77 72 69 74 65 20 20 20 20 20 30 0a  lob_write     0.
0c20: 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 54 68  #endif../*.** Th
0c30: 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 73 74 72 75  e following stru
0c40: 63 74 75 72 65 20 63 6f 6e 74 61 69 6e 73 20 70  cture contains p
0c50: 6f 69 6e 74 65 72 73 20 74 6f 20 61 6c 6c 20 53  ointers to all S
0c60: 51 4c 69 74 65 20 41 50 49 20 72 6f 75 74 69 6e  QLite API routin
0c70: 65 73 2e 0a 2a 2a 20 41 20 70 6f 69 6e 74 65 72  es..** A pointer
0c80: 20 74 6f 20 74 68 69 73 20 73 74 72 75 63 74 75   to this structu
0c90: 72 65 20 69 73 20 70 61 73 73 65 64 20 69 6e 74  re is passed int
0ca0: 6f 20 65 78 74 65 6e 73 69 6f 6e 73 20 77 68 65  o extensions whe
0cb0: 6e 20 74 68 65 79 20 61 72 65 0a 2a 2a 20 6c 6f  n they are.** lo
0cc0: 61 64 65 64 20 73 6f 20 74 68 61 74 20 74 68 65  aded so that the
0cd0: 20 65 78 74 65 6e 73 69 6f 6e 20 63 61 6e 20 6d   extension can m
0ce0: 61 6b 65 20 63 61 6c 6c 73 20 62 61 63 6b 20 69  ake calls back i
0cf0: 6e 74 6f 20 74 68 65 20 53 51 4c 69 74 65 0a 2a  nto the SQLite.*
0d00: 2a 20 6c 69 62 72 61 72 79 2e 0a 2a 2a 0a 2a 2a  * library..**.**
0d10: 20 57 68 65 6e 20 61 64 64 69 6e 67 20 6e 65 77   When adding new
0d20: 20 41 50 49 73 2c 20 61 64 64 20 74 68 65 6d 20   APIs, add them 
0d30: 74 6f 20 74 68 65 20 62 6f 74 74 6f 6d 20 6f 66  to the bottom of
0d40: 20 74 68 69 73 20 73 74 72 75 63 74 75 72 65 0a   this structure.
0d50: 2a 2a 20 69 6e 20 6f 72 64 65 72 20 74 6f 20 70  ** in order to p
0d60: 72 65 73 65 72 76 65 20 62 61 63 6b 77 61 72 64  reserve backward
0d70: 73 20 63 6f 6d 70 61 74 69 62 69 6c 69 74 79 2e  s compatibility.
0d80: 0a 2a 2a 0a 2a 2a 20 45 78 74 65 6e 73 69 6f 6e  .**.** Extension
0d90: 73 20 74 68 61 74 20 75 73 65 20 6e 65 77 65 72  s that use newer
0da0: 20 41 50 49 73 20 73 68 6f 75 6c 64 20 66 69 72   APIs should fir
0db0: 73 74 20 63 61 6c 6c 20 74 68 65 0a 2a 2a 20 73  st call the.** s
0dc0: 71 6c 69 74 65 33 5f 6c 69 62 76 65 72 73 69 6f  qlite3_libversio
0dd0: 6e 5f 6e 75 6d 62 65 72 28 29 20 74 6f 20 6d 61  n_number() to ma
0de0: 6b 65 20 73 75 72 65 20 74 68 61 74 20 74 68 65  ke sure that the
0df0: 20 41 50 49 20 74 68 65 79 0a 2a 2a 20 69 6e 74   API they.** int
0e00: 65 6e 64 20 74 6f 20 75 73 65 20 69 73 20 73 75  end to use is su
0e10: 70 70 6f 72 74 65 64 20 62 79 20 74 68 65 20 6c  pported by the l
0e20: 69 62 72 61 72 79 2e 20 20 45 78 74 65 6e 73 69  ibrary.  Extensi
0e30: 6f 6e 73 20 73 68 6f 75 6c 64 0a 2a 2a 20 61 6c  ons should.** al
0e40: 73 6f 20 63 68 65 63 6b 20 74 6f 20 6d 61 6b 65  so check to make
0e50: 20 73 75 72 65 20 74 68 61 74 20 74 68 65 20 70   sure that the p
0e60: 6f 69 6e 74 65 72 20 74 6f 20 74 68 65 20 66 75  ointer to the fu
0e70: 6e 63 74 69 6f 6e 20 69 73 0a 2a 2a 20 6e 6f 74  nction is.** not
0e80: 20 4e 55 4c 4c 20 62 65 66 6f 72 65 20 63 61 6c   NULL before cal
0e90: 6c 69 6e 67 20 69 74 2e 0a 2a 2f 0a 73 74 61 74  ling it..*/.stat
0ea0: 69 63 20 63 6f 6e 73 74 20 73 71 6c 69 74 65 33  ic const sqlite3
0eb0: 5f 61 70 69 5f 72 6f 75 74 69 6e 65 73 20 73 71  _api_routines sq
0ec0: 6c 69 74 65 33 41 70 69 73 20 3d 20 7b 0a 20 20  lite3Apis = {.  
0ed0: 73 71 6c 69 74 65 33 5f 61 67 67 72 65 67 61 74  sqlite3_aggregat
0ee0: 65 5f 63 6f 6e 74 65 78 74 2c 0a 20 20 73 71 6c  e_context,.  sql
0ef0: 69 74 65 33 5f 61 67 67 72 65 67 61 74 65 5f 63  ite3_aggregate_c
0f00: 6f 75 6e 74 2c 0a 20 20 73 71 6c 69 74 65 33 5f  ount,.  sqlite3_
0f10: 62 69 6e 64 5f 62 6c 6f 62 2c 0a 20 20 73 71 6c  bind_blob,.  sql
0f20: 69 74 65 33 5f 62 69 6e 64 5f 64 6f 75 62 6c 65  ite3_bind_double
0f30: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 62 69 6e 64  ,.  sqlite3_bind
0f40: 5f 69 6e 74 2c 0a 20 20 73 71 6c 69 74 65 33 5f  _int,.  sqlite3_
0f50: 62 69 6e 64 5f 69 6e 74 36 34 2c 0a 20 20 73 71  bind_int64,.  sq
0f60: 6c 69 74 65 33 5f 62 69 6e 64 5f 6e 75 6c 6c 2c  lite3_bind_null,
0f70: 0a 20 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f  .  sqlite3_bind_
0f80: 70 61 72 61 6d 65 74 65 72 5f 63 6f 75 6e 74 2c  parameter_count,
0f90: 0a 20 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f  .  sqlite3_bind_
0fa0: 70 61 72 61 6d 65 74 65 72 5f 69 6e 64 65 78 2c  parameter_index,
0fb0: 0a 20 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f  .  sqlite3_bind_
0fc0: 70 61 72 61 6d 65 74 65 72 5f 6e 61 6d 65 2c 0a  parameter_name,.
0fd0: 20 20 73 71 6c 69 74 65 33 5f 62 69 6e 64 5f 74    sqlite3_bind_t
0fe0: 65 78 74 2c 0a 20 20 73 71 6c 69 74 65 33 5f 62  ext,.  sqlite3_b
0ff0: 69 6e 64 5f 74 65 78 74 31 36 2c 0a 20 20 73 71  ind_text16,.  sq
1000: 6c 69 74 65 33 5f 62 69 6e 64 5f 76 61 6c 75 65  lite3_bind_value
1010: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 62 75 73 79  ,.  sqlite3_busy
1020: 5f 68 61 6e 64 6c 65 72 2c 0a 20 20 73 71 6c 69  _handler,.  sqli
1030: 74 65 33 5f 62 75 73 79 5f 74 69 6d 65 6f 75 74  te3_busy_timeout
1040: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63 68 61 6e  ,.  sqlite3_chan
1050: 67 65 73 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63  ges,.  sqlite3_c
1060: 6c 6f 73 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f  lose,.  sqlite3_
1070: 63 6f 6c 6c 61 74 69 6f 6e 5f 6e 65 65 64 65 64  collation_needed
1080: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c 6c  ,.  sqlite3_coll
1090: 61 74 69 6f 6e 5f 6e 65 65 64 65 64 31 36 2c 0a  ation_needed16,.
10a0: 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e    sqlite3_column
10b0: 5f 62 6c 6f 62 2c 0a 20 20 73 71 6c 69 74 65 33  _blob,.  sqlite3
10c0: 5f 63 6f 6c 75 6d 6e 5f 62 79 74 65 73 2c 0a 20  _column_bytes,. 
10d0: 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f   sqlite3_column_
10e0: 62 79 74 65 73 31 36 2c 0a 20 20 73 71 6c 69 74  bytes16,.  sqlit
10f0: 65 33 5f 63 6f 6c 75 6d 6e 5f 63 6f 75 6e 74 2c  e3_column_count,
1100: 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  .  sqlite3_colum
1110: 6e 5f 64 61 74 61 62 61 73 65 5f 6e 61 6d 65 2c  n_database_name,
1120: 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d  .  sqlite3_colum
1130: 6e 5f 64 61 74 61 62 61 73 65 5f 6e 61 6d 65 31  n_database_name1
1140: 36 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c  6,.  sqlite3_col
1150: 75 6d 6e 5f 64 65 63 6c 74 79 70 65 2c 0a 20 20  umn_decltype,.  
1160: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64  sqlite3_column_d
1170: 65 63 6c 74 79 70 65 31 36 2c 0a 20 20 73 71 6c  ecltype16,.  sql
1180: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 64 6f 75 62  ite3_column_doub
1190: 6c 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f  le,.  sqlite3_co
11a0: 6c 75 6d 6e 5f 69 6e 74 2c 0a 20 20 73 71 6c 69  lumn_int,.  sqli
11b0: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 36 34  te3_column_int64
11c0: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75  ,.  sqlite3_colu
11d0: 6d 6e 5f 6e 61 6d 65 2c 0a 20 20 73 71 6c 69 74  mn_name,.  sqlit
11e0: 65 33 5f 63 6f 6c 75 6d 6e 5f 6e 61 6d 65 31 36  e3_column_name16
11f0: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75  ,.  sqlite3_colu
1200: 6d 6e 5f 6f 72 69 67 69 6e 5f 6e 61 6d 65 2c 0a  mn_origin_name,.
1210: 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e    sqlite3_column
1220: 5f 6f 72 69 67 69 6e 5f 6e 61 6d 65 31 36 2c 0a  _origin_name16,.
1230: 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e    sqlite3_column
1240: 5f 74 61 62 6c 65 5f 6e 61 6d 65 2c 0a 20 20 73  _table_name,.  s
1250: 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 61  qlite3_column_ta
1260: 62 6c 65 5f 6e 61 6d 65 31 36 2c 0a 20 20 73 71  ble_name16,.  sq
1270: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78  lite3_column_tex
1280: 74 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c  t,.  sqlite3_col
1290: 75 6d 6e 5f 74 65 78 74 31 36 2c 0a 20 20 73 71  umn_text16,.  sq
12a0: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 79 70  lite3_column_typ
12b0: 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c  e,.  sqlite3_col
12c0: 75 6d 6e 5f 76 61 6c 75 65 2c 0a 20 20 73 71 6c  umn_value,.  sql
12d0: 69 74 65 33 5f 63 6f 6d 6d 69 74 5f 68 6f 6f 6b  ite3_commit_hook
12e0: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6d 70  ,.  sqlite3_comp
12f0: 6c 65 74 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f  lete,.  sqlite3_
1300: 63 6f 6d 70 6c 65 74 65 31 36 2c 0a 20 20 73 71  complete16,.  sq
1310: 6c 69 74 65 33 5f 63 72 65 61 74 65 5f 63 6f 6c  lite3_create_col
1320: 6c 61 74 69 6f 6e 2c 0a 20 20 73 71 6c 69 74 65  lation,.  sqlite
1330: 33 5f 63 72 65 61 74 65 5f 63 6f 6c 6c 61 74 69  3_create_collati
1340: 6f 6e 31 36 2c 0a 20 20 73 71 6c 69 74 65 33 5f  on16,.  sqlite3_
1350: 63 72 65 61 74 65 5f 66 75 6e 63 74 69 6f 6e 2c  create_function,
1360: 0a 20 20 73 71 6c 69 74 65 33 5f 63 72 65 61 74  .  sqlite3_creat
1370: 65 5f 66 75 6e 63 74 69 6f 6e 31 36 2c 0a 20 20  e_function16,.  
1380: 73 71 6c 69 74 65 33 5f 63 72 65 61 74 65 5f 6d  sqlite3_create_m
1390: 6f 64 75 6c 65 2c 0a 20 20 73 71 6c 69 74 65 33  odule,.  sqlite3
13a0: 5f 64 61 74 61 5f 63 6f 75 6e 74 2c 0a 20 20 73  _data_count,.  s
13b0: 71 6c 69 74 65 33 5f 64 62 5f 68 61 6e 64 6c 65  qlite3_db_handle
13c0: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 64 65 63 6c  ,.  sqlite3_decl
13d0: 61 72 65 5f 76 74 61 62 2c 0a 20 20 73 71 6c 69  are_vtab,.  sqli
13e0: 74 65 33 5f 65 6e 61 62 6c 65 5f 73 68 61 72 65  te3_enable_share
13f0: 64 5f 63 61 63 68 65 2c 0a 20 20 73 71 6c 69 74  d_cache,.  sqlit
1400: 65 33 5f 65 72 72 63 6f 64 65 2c 0a 20 20 73 71  e3_errcode,.  sq
1410: 6c 69 74 65 33 5f 65 72 72 6d 73 67 2c 0a 20 20  lite3_errmsg,.  
1420: 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 31 36  sqlite3_errmsg16
1430: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 65 78 65 63  ,.  sqlite3_exec
1440: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 65 78 70 69  ,.  sqlite3_expi
1450: 72 65 64 2c 0a 20 20 73 71 6c 69 74 65 33 5f 66  red,.  sqlite3_f
1460: 69 6e 61 6c 69 7a 65 2c 0a 20 20 73 71 6c 69 74  inalize,.  sqlit
1470: 65 33 5f 66 72 65 65 2c 0a 20 20 73 71 6c 69 74  e3_free,.  sqlit
1480: 65 33 5f 66 72 65 65 5f 74 61 62 6c 65 2c 0a 20  e3_free_table,. 
1490: 20 73 71 6c 69 74 65 33 5f 67 65 74 5f 61 75 74   sqlite3_get_aut
14a0: 6f 63 6f 6d 6d 69 74 2c 0a 20 20 73 71 6c 69 74  ocommit,.  sqlit
14b0: 65 33 5f 67 65 74 5f 61 75 78 64 61 74 61 2c 0a  e3_get_auxdata,.
14c0: 20 20 73 71 6c 69 74 65 33 5f 67 65 74 5f 74 61    sqlite3_get_ta
14d0: 62 6c 65 2c 0a 20 20 30 2c 20 20 20 20 20 2f 2a  ble,.  0,     /*
14e0: 20 57 61 73 20 73 71 6c 69 74 65 33 5f 67 6c 6f   Was sqlite3_glo
14f0: 62 61 6c 5f 72 65 63 6f 76 65 72 28 29 2c 20 62  bal_recover(), b
1500: 75 74 20 74 68 61 74 20 66 75 6e 63 74 69 6f 6e  ut that function
1510: 20 69 73 20 64 65 70 72 65 63 61 74 65 64 20 2a   is deprecated *
1520: 2f 0a 20 20 73 71 6c 69 74 65 33 5f 69 6e 74 65  /.  sqlite3_inte
1530: 72 72 75 70 74 2c 0a 20 20 73 71 6c 69 74 65 33  rrupt,.  sqlite3
1540: 5f 6c 61 73 74 5f 69 6e 73 65 72 74 5f 72 6f 77  _last_insert_row
1550: 69 64 2c 0a 20 20 73 71 6c 69 74 65 33 5f 6c 69  id,.  sqlite3_li
1560: 62 76 65 72 73 69 6f 6e 2c 0a 20 20 73 71 6c 69  bversion,.  sqli
1570: 74 65 33 5f 6c 69 62 76 65 72 73 69 6f 6e 5f 6e  te3_libversion_n
1580: 75 6d 62 65 72 2c 0a 20 20 73 71 6c 69 74 65 33  umber,.  sqlite3
1590: 5f 6d 61 6c 6c 6f 63 2c 0a 20 20 73 71 6c 69 74  _malloc,.  sqlit
15a0: 65 33 5f 6d 70 72 69 6e 74 66 2c 0a 20 20 73 71  e3_mprintf,.  sq
15b0: 6c 69 74 65 33 5f 6f 70 65 6e 2c 0a 20 20 73 71  lite3_open,.  sq
15c0: 6c 69 74 65 33 5f 6f 70 65 6e 31 36 2c 0a 20 20  lite3_open16,.  
15d0: 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 2c  sqlite3_prepare,
15e0: 0a 20 20 73 71 6c 69 74 65 33 5f 70 72 65 70 61  .  sqlite3_prepa
15f0: 72 65 31 36 2c 0a 20 20 73 71 6c 69 74 65 33 5f  re16,.  sqlite3_
1600: 70 72 6f 66 69 6c 65 2c 0a 20 20 73 71 6c 69 74  profile,.  sqlit
1610: 65 33 5f 70 72 6f 67 72 65 73 73 5f 68 61 6e 64  e3_progress_hand
1620: 6c 65 72 2c 0a 20 20 73 71 6c 69 74 65 33 5f 72  ler,.  sqlite3_r
1630: 65 61 6c 6c 6f 63 2c 0a 20 20 73 71 6c 69 74 65  ealloc,.  sqlite
1640: 33 5f 72 65 73 65 74 2c 0a 20 20 73 71 6c 69 74  3_reset,.  sqlit
1650: 65 33 5f 72 65 73 75 6c 74 5f 62 6c 6f 62 2c 0a  e3_result_blob,.
1660: 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74    sqlite3_result
1670: 5f 64 6f 75 62 6c 65 2c 0a 20 20 73 71 6c 69 74  _double,.  sqlit
1680: 65 33 5f 72 65 73 75 6c 74 5f 65 72 72 6f 72 2c  e3_result_error,
1690: 0a 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c  .  sqlite3_resul
16a0: 74 5f 65 72 72 6f 72 31 36 2c 0a 20 20 73 71 6c  t_error16,.  sql
16b0: 69 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74 2c  ite3_result_int,
16c0: 0a 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c  .  sqlite3_resul
16d0: 74 5f 69 6e 74 36 34 2c 0a 20 20 73 71 6c 69 74  t_int64,.  sqlit
16e0: 65 33 5f 72 65 73 75 6c 74 5f 6e 75 6c 6c 2c 0a  e3_result_null,.
16f0: 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74    sqlite3_result
1700: 5f 74 65 78 74 2c 0a 20 20 73 71 6c 69 74 65 33  _text,.  sqlite3
1710: 5f 72 65 73 75 6c 74 5f 74 65 78 74 31 36 2c 0a  _result_text16,.
1720: 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74    sqlite3_result
1730: 5f 74 65 78 74 31 36 62 65 2c 0a 20 20 73 71 6c  _text16be,.  sql
1740: 69 74 65 33 5f 72 65 73 75 6c 74 5f 74 65 78 74  ite3_result_text
1750: 31 36 6c 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f  16le,.  sqlite3_
1760: 72 65 73 75 6c 74 5f 76 61 6c 75 65 2c 0a 20 20  result_value,.  
1770: 73 71 6c 69 74 65 33 5f 72 6f 6c 6c 62 61 63 6b  sqlite3_rollback
1780: 5f 68 6f 6f 6b 2c 0a 20 20 73 71 6c 69 74 65 33  _hook,.  sqlite3
1790: 5f 73 65 74 5f 61 75 74 68 6f 72 69 7a 65 72 2c  _set_authorizer,
17a0: 0a 20 20 73 71 6c 69 74 65 33 5f 73 65 74 5f 61  .  sqlite3_set_a
17b0: 75 78 64 61 74 61 2c 0a 20 20 73 71 6c 69 74 65  uxdata,.  sqlite
17c0: 33 5f 73 6e 70 72 69 6e 74 66 2c 0a 20 20 73 71  3_snprintf,.  sq
17d0: 6c 69 74 65 33 5f 73 74 65 70 2c 0a 20 20 73 71  lite3_step,.  sq
17e0: 6c 69 74 65 33 5f 74 61 62 6c 65 5f 63 6f 6c 75  lite3_table_colu
17f0: 6d 6e 5f 6d 65 74 61 64 61 74 61 2c 0a 20 20 73  mn_metadata,.  s
1800: 71 6c 69 74 65 33 5f 74 68 72 65 61 64 5f 63 6c  qlite3_thread_cl
1810: 65 61 6e 75 70 2c 0a 20 20 73 71 6c 69 74 65 33  eanup,.  sqlite3
1820: 5f 74 6f 74 61 6c 5f 63 68 61 6e 67 65 73 2c 0a  _total_changes,.
1830: 20 20 73 71 6c 69 74 65 33 5f 74 72 61 63 65 2c    sqlite3_trace,
1840: 0a 20 20 73 71 6c 69 74 65 33 5f 74 72 61 6e 73  .  sqlite3_trans
1850: 66 65 72 5f 62 69 6e 64 69 6e 67 73 2c 0a 20 20  fer_bindings,.  
1860: 73 71 6c 69 74 65 33 5f 75 70 64 61 74 65 5f 68  sqlite3_update_h
1870: 6f 6f 6b 2c 0a 20 20 73 71 6c 69 74 65 33 5f 75  ook,.  sqlite3_u
1880: 73 65 72 5f 64 61 74 61 2c 0a 20 20 73 71 6c 69  ser_data,.  sqli
1890: 74 65 33 5f 76 61 6c 75 65 5f 62 6c 6f 62 2c 0a  te3_value_blob,.
18a0: 20 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f    sqlite3_value_
18b0: 62 79 74 65 73 2c 0a 20 20 73 71 6c 69 74 65 33  bytes,.  sqlite3
18c0: 5f 76 61 6c 75 65 5f 62 79 74 65 73 31 36 2c 0a  _value_bytes16,.
18d0: 20 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f    sqlite3_value_
18e0: 64 6f 75 62 6c 65 2c 0a 20 20 73 71 6c 69 74 65  double,.  sqlite
18f0: 33 5f 76 61 6c 75 65 5f 69 6e 74 2c 0a 20 20 73  3_value_int,.  s
1900: 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 69 6e 74  qlite3_value_int
1910: 36 34 2c 0a 20 20 73 71 6c 69 74 65 33 5f 76 61  64,.  sqlite3_va
1920: 6c 75 65 5f 6e 75 6d 65 72 69 63 5f 74 79 70 65  lue_numeric_type
1930: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 76 61 6c 75  ,.  sqlite3_valu
1940: 65 5f 74 65 78 74 2c 0a 20 20 73 71 6c 69 74 65  e_text,.  sqlite
1950: 33 5f 76 61 6c 75 65 5f 74 65 78 74 31 36 2c 0a  3_value_text16,.
1960: 20 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f    sqlite3_value_
1970: 74 65 78 74 31 36 62 65 2c 0a 20 20 73 71 6c 69  text16be,.  sqli
1980: 74 65 33 5f 76 61 6c 75 65 5f 74 65 78 74 31 36  te3_value_text16
1990: 6c 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f 76 61  le,.  sqlite3_va
19a0: 6c 75 65 5f 74 79 70 65 2c 0a 20 20 73 71 6c 69  lue_type,.  sqli
19b0: 74 65 33 5f 76 6d 70 72 69 6e 74 66 2c 0a 20 20  te3_vmprintf,.  
19c0: 2f 2a 0a 20 20 2a 2a 20 54 68 65 20 6f 72 69 67  /*.  ** The orig
19d0: 69 6e 61 6c 20 41 50 49 20 73 65 74 20 65 6e 64  inal API set end
19e0: 73 20 68 65 72 65 2e 20 20 41 6c 6c 20 65 78 74  s here.  All ext
19f0: 65 6e 73 69 6f 6e 73 20 63 61 6e 20 63 61 6c 6c  ensions can call
1a00: 20 61 6e 79 0a 20 20 2a 2a 20 6f 66 20 74 68 65   any.  ** of the
1a10: 20 41 50 49 73 20 61 62 6f 76 65 20 70 72 6f 76   APIs above prov
1a20: 69 64 65 64 20 74 68 61 74 20 74 68 65 20 70 6f  ided that the po
1a30: 69 6e 74 65 72 20 69 73 20 6e 6f 74 20 4e 55 4c  inter is not NUL
1a40: 4c 2e 20 20 42 75 74 0a 20 20 2a 2a 20 62 65 66  L.  But.  ** bef
1a50: 6f 72 65 20 63 61 6c 6c 69 6e 67 20 41 50 49 73  ore calling APIs
1a60: 20 74 68 61 74 20 66 6f 6c 6c 6f 77 2c 20 65 78   that follow, ex
1a70: 74 65 6e 73 69 6f 6e 20 73 68 6f 75 6c 64 20 63  tension should c
1a80: 68 65 63 6b 20 74 68 65 0a 20 20 2a 2a 20 73 71  heck the.  ** sq
1a90: 6c 69 74 65 33 5f 6c 69 62 76 65 72 73 69 6f 6e  lite3_libversion
1aa0: 5f 6e 75 6d 62 65 72 28 29 20 74 6f 20 6d 61 6b  _number() to mak
1ab0: 65 20 73 75 72 65 20 74 68 65 79 20 61 72 65 20  e sure they are 
1ac0: 64 65 61 6c 69 6e 67 20 77 69 74 68 0a 20 20 2a  dealing with.  *
1ad0: 2a 20 61 20 6c 69 62 72 61 72 79 20 74 68 61 74  * a library that
1ae0: 20 69 73 20 6e 65 77 20 65 6e 6f 75 67 68 20 74   is new enough t
1af0: 6f 20 73 75 70 70 6f 72 74 20 74 68 61 74 20 41  o support that A
1b00: 50 49 2e 0a 20 20 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  PI..  **********
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 0a  ***************.
1b50: 20 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f 6f    */.  sqlite3_o
1b60: 76 65 72 6c 6f 61 64 5f 66 75 6e 63 74 69 6f 6e  verload_function
1b70: 2c 0a 0a 20 20 2f 2a 0a 20 20 2a 2a 20 41 64 64  ,..  /*.  ** Add
1b80: 65 64 20 61 66 74 65 72 20 33 2e 33 2e 31 33 0a  ed after 3.3.13.
1b90: 20 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f 70    */.  sqlite3_p
1ba0: 72 65 70 61 72 65 5f 76 32 2c 0a 20 20 73 71 6c  repare_v2,.  sql
1bb0: 69 74 65 33 5f 70 72 65 70 61 72 65 31 36 5f 76  ite3_prepare16_v
1bc0: 32 2c 0a 20 20 73 71 6c 69 74 65 33 5f 63 6c 65  2,.  sqlite3_cle
1bd0: 61 72 5f 62 69 6e 64 69 6e 67 73 2c 0a 0a 20 20  ar_bindings,..  
1be0: 2f 2a 0a 20 20 2a 2a 20 41 64 64 65 64 20 66 6f  /*.  ** Added fo
1bf0: 72 20 33 2e 34 2e 31 0a 20 20 2a 2f 0a 20 20 73  r 3.4.1.  */.  s
1c00: 71 6c 69 74 65 33 5f 63 72 65 61 74 65 5f 6d 6f  qlite3_create_mo
1c10: 64 75 6c 65 5f 76 32 2c 0a 0a 20 20 2f 2a 0a 20  dule_v2,..  /*. 
1c20: 20 2a 2a 20 41 64 64 65 64 20 66 6f 72 20 33 2e   ** Added for 3.
1c30: 35 2e 30 0a 20 20 2a 2f 0a 20 20 73 71 6c 69 74  5.0.  */.  sqlit
1c40: 65 33 5f 62 69 6e 64 5f 7a 65 72 6f 62 6c 6f 62  e3_bind_zeroblob
1c50: 2c 0a 20 20 73 71 6c 69 74 65 33 5f 62 6c 6f 62  ,.  sqlite3_blob
1c60: 5f 62 79 74 65 73 2c 0a 20 20 73 71 6c 69 74 65  _bytes,.  sqlite
1c70: 33 5f 62 6c 6f 62 5f 63 6c 6f 73 65 2c 0a 20 20  3_blob_close,.  
1c80: 73 71 6c 69 74 65 33 5f 62 6c 6f 62 5f 6f 70 65  sqlite3_blob_ope
1c90: 6e 2c 0a 20 20 73 71 6c 69 74 65 33 5f 62 6c 6f  n,.  sqlite3_blo
1ca0: 62 5f 72 65 61 64 2c 0a 20 20 73 71 6c 69 74 65  b_read,.  sqlite
1cb0: 33 5f 62 6c 6f 62 5f 77 72 69 74 65 2c 0a 20 20  3_blob_write,.  
1cc0: 73 71 6c 69 74 65 33 5f 63 72 65 61 74 65 5f 63  sqlite3_create_c
1cd0: 6f 6c 6c 61 74 69 6f 6e 5f 76 32 2c 0a 20 20 73  ollation_v2,.  s
1ce0: 71 6c 69 74 65 33 5f 66 69 6c 65 5f 63 6f 6e 74  qlite3_file_cont
1cf0: 72 6f 6c 2c 0a 20 20 73 71 6c 69 74 65 33 5f 6d  rol,.  sqlite3_m
1d00: 65 6d 6f 72 79 5f 68 69 67 68 77 61 74 65 72 2c  emory_highwater,
1d10: 0a 20 20 73 71 6c 69 74 65 33 5f 6d 65 6d 6f 72  .  sqlite3_memor
1d20: 79 5f 75 73 65 64 2c 0a 23 69 66 64 65 66 20 53  y_used,.#ifdef S
1d30: 51 4c 49 54 45 5f 4d 55 54 45 58 5f 4e 4f 4f 50  QLITE_MUTEX_NOOP
1d40: 0a 20 20 30 2c 20 0a 20 20 30 2c 20 0a 20 20 30  .  0, .  0, .  0
1d50: 2c 0a 20 20 30 2c 0a 20 20 30 2c 0a 23 65 6c 73  ,.  0,.  0,.#els
1d60: 65 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65  e.  sqlite3_mute
1d70: 78 5f 61 6c 6c 6f 63 2c 0a 20 20 73 71 6c 69 74  x_alloc,.  sqlit
1d80: 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 2c 0a  e3_mutex_enter,.
1d90: 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f    sqlite3_mutex_
1da0: 66 72 65 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f  free,.  sqlite3_
1db0: 6d 75 74 65 78 5f 6c 65 61 76 65 2c 0a 20 20 73  mutex_leave,.  s
1dc0: 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 74 72 79  qlite3_mutex_try
1dd0: 2c 0a 23 65 6e 64 69 66 0a 20 20 73 71 6c 69 74  ,.#endif.  sqlit
1de0: 65 33 5f 6f 70 65 6e 5f 76 32 2c 0a 20 20 73 71  e3_open_v2,.  sq
1df0: 6c 69 74 65 33 5f 72 65 6c 65 61 73 65 5f 6d 65  lite3_release_me
1e00: 6d 6f 72 79 2c 0a 20 20 73 71 6c 69 74 65 33 5f  mory,.  sqlite3_
1e10: 72 65 73 75 6c 74 5f 65 72 72 6f 72 5f 6e 6f 6d  result_error_nom
1e20: 65 6d 2c 0a 20 20 73 71 6c 69 74 65 33 5f 72 65  em,.  sqlite3_re
1e30: 73 75 6c 74 5f 65 72 72 6f 72 5f 74 6f 6f 62 69  sult_error_toobi
1e40: 67 2c 0a 20 20 73 71 6c 69 74 65 33 5f 73 6c 65  g,.  sqlite3_sle
1e50: 65 70 2c 0a 20 20 73 71 6c 69 74 65 33 5f 73 6f  ep,.  sqlite3_so
1e60: 66 74 5f 68 65 61 70 5f 6c 69 6d 69 74 2c 0a 20  ft_heap_limit,. 
1e70: 20 73 71 6c 69 74 65 33 5f 76 66 73 5f 66 69 6e   sqlite3_vfs_fin
1e80: 64 2c 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73  d,.  sqlite3_vfs
1e90: 5f 72 65 67 69 73 74 65 72 2c 0a 20 20 73 71 6c  _register,.  sql
1ea0: 69 74 65 33 5f 76 66 73 5f 75 6e 72 65 67 69 73  ite3_vfs_unregis
1eb0: 74 65 72 2c 0a 0a 20 20 2f 2a 0a 20 20 2a 2a 20  ter,..  /*.  ** 
1ec0: 41 64 64 65 64 20 66 6f 72 20 33 2e 35 2e 38 0a  Added for 3.5.8.
1ed0: 20 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f 74    */.  sqlite3_t
1ee0: 68 72 65 61 64 73 61 66 65 2c 0a 20 20 73 71 6c  hreadsafe,.  sql
1ef0: 69 74 65 33 5f 72 65 73 75 6c 74 5f 7a 65 72 6f  ite3_result_zero
1f00: 62 6c 6f 62 2c 0a 20 20 73 71 6c 69 74 65 33 5f  blob,.  sqlite3_
1f10: 72 65 73 75 6c 74 5f 65 72 72 6f 72 5f 63 6f 64  result_error_cod
1f20: 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f 74 65 73  e,.  sqlite3_tes
1f30: 74 5f 63 6f 6e 74 72 6f 6c 2c 0a 20 20 73 71 6c  t_control,.  sql
1f40: 69 74 65 33 5f 72 61 6e 64 6f 6d 6e 65 73 73 2c  ite3_randomness,
1f50: 0a 20 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65  .  sqlite3_conte
1f60: 78 74 5f 64 62 5f 68 61 6e 64 6c 65 2c 0a 0a 20  xt_db_handle,.. 
1f70: 20 2f 2a 0a 20 20 2a 2a 20 41 64 64 65 64 20 66   /*.  ** Added f
1f80: 6f 72 20 33 2e 36 2e 30 0a 20 20 2a 2f 0a 20 20  or 3.6.0.  */.  
1f90: 73 71 6c 69 74 65 33 5f 65 78 74 65 6e 64 65 64  sqlite3_extended
1fa0: 5f 72 65 73 75 6c 74 5f 63 6f 64 65 73 2c 0a 20  _result_codes,. 
1fb0: 20 73 71 6c 69 74 65 33 5f 6c 69 6d 69 74 2c 0a   sqlite3_limit,.
1fc0: 20 20 73 71 6c 69 74 65 33 5f 6e 65 78 74 5f 73    sqlite3_next_s
1fd0: 74 6d 74 2c 0a 20 20 73 71 6c 69 74 65 33 5f 73  tmt,.  sqlite3_s
1fe0: 71 6c 2c 0a 20 20 73 71 6c 69 74 65 33 5f 73 74  ql,.  sqlite3_st
1ff0: 61 74 75 73 2c 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20  atus,.};../*.** 
2000: 41 74 74 65 6d 70 74 20 74 6f 20 6c 6f 61 64 20  Attempt to load 
2010: 61 6e 20 53 51 4c 69 74 65 20 65 78 74 65 6e 73  an SQLite extens
2020: 69 6f 6e 20 6c 69 62 72 61 72 79 20 63 6f 6e 74  ion library cont
2030: 61 69 6e 65 64 20 69 6e 20 74 68 65 20 66 69 6c  ained in the fil
2040: 65 0a 2a 2a 20 7a 46 69 6c 65 2e 20 20 54 68 65  e.** zFile.  The
2050: 20 65 6e 74 72 79 20 70 6f 69 6e 74 20 69 73 20   entry point is 
2060: 7a 50 72 6f 63 2e 20 20 7a 50 72 6f 63 20 6d 61  zProc.  zProc ma
2070: 79 20 62 65 20 30 20 69 6e 20 77 68 69 63 68 20  y be 0 in which 
2080: 63 61 73 65 20 61 0a 2a 2a 20 64 65 66 61 75 6c  case a.** defaul
2090: 74 20 65 6e 74 72 79 20 70 6f 69 6e 74 20 6e 61  t entry point na
20a0: 6d 65 20 28 73 71 6c 69 74 65 33 5f 65 78 74 65  me (sqlite3_exte
20b0: 6e 73 69 6f 6e 5f 69 6e 69 74 29 20 69 73 20 75  nsion_init) is u
20c0: 73 65 64 2e 20 20 55 73 65 0a 2a 2a 20 6f 66 20  sed.  Use.** of 
20d0: 74 68 65 20 64 65 66 61 75 6c 74 20 6e 61 6d 65  the default name
20e0: 20 69 73 20 72 65 63 6f 6d 6d 65 6e 64 65 64 2e   is recommended.
20f0: 0a 2a 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 53 51  .**.** Return SQ
2100: 4c 49 54 45 5f 4f 4b 20 6f 6e 20 73 75 63 63 65  LITE_OK on succe
2110: 73 73 20 61 6e 64 20 53 51 4c 49 54 45 5f 45 52  ss and SQLITE_ER
2120: 52 4f 52 20 69 66 20 73 6f 6d 65 74 68 69 6e 67  ROR if something
2130: 20 67 6f 65 73 20 77 72 6f 6e 67 2e 0a 2a 2a 0a   goes wrong..**.
2140: 2a 2a 20 49 66 20 61 6e 20 65 72 72 6f 72 20 6f  ** If an error o
2150: 63 63 75 72 73 20 61 6e 64 20 70 7a 45 72 72 4d  ccurs and pzErrM
2160: 73 67 20 69 73 20 6e 6f 74 20 30 2c 20 74 68 65  sg is not 0, the
2170: 6e 20 66 69 6c 6c 20 2a 70 7a 45 72 72 4d 73 67  n fill *pzErrMsg
2180: 20 77 69 74 68 20 0a 2a 2a 20 65 72 72 6f 72 20   with .** error 
2190: 6d 65 73 73 61 67 65 20 74 65 78 74 2e 20 20 54  message text.  T
21a0: 68 65 20 63 61 6c 6c 69 6e 67 20 66 75 6e 63 74  he calling funct
21b0: 69 6f 6e 20 73 68 6f 75 6c 64 20 66 72 65 65 20  ion should free 
21c0: 74 68 69 73 20 6d 65 6d 6f 72 79 0a 2a 2a 20 62  this memory.** b
21d0: 79 20 63 61 6c 6c 69 6e 67 20 73 71 6c 69 74 65  y calling sqlite
21e0: 33 44 62 46 72 65 65 28 64 62 2c 20 29 2e 0a 2a  3DbFree(db, )..*
21f0: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 73 71 6c  /.static int sql
2200: 69 74 65 33 4c 6f 61 64 45 78 74 65 6e 73 69 6f  ite3LoadExtensio
2210: 6e 28 0a 20 20 73 71 6c 69 74 65 33 20 2a 64 62  n(.  sqlite3 *db
2220: 2c 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4c 6f  ,          /* Lo
2230: 61 64 20 74 68 65 20 65 78 74 65 6e 73 69 6f 6e  ad the extension
2240: 20 69 6e 74 6f 20 74 68 69 73 20 64 61 74 61 62   into this datab
2250: 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 2a  ase connection *
2260: 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  /.  const char *
2270: 7a 46 69 6c 65 2c 20 20 20 20 2f 2a 20 4e 61 6d  zFile,    /* Nam
2280: 65 20 6f 66 20 74 68 65 20 73 68 61 72 65 64 20  e of the shared 
2290: 6c 69 62 72 61 72 79 20 63 6f 6e 74 61 69 6e 69  library containi
22a0: 6e 67 20 65 78 74 65 6e 73 69 6f 6e 20 2a 2f 0a  ng extension */.
22b0: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 50    const char *zP
22c0: 72 6f 63 2c 20 20 20 20 2f 2a 20 45 6e 74 72 79  roc,    /* Entry
22d0: 20 70 6f 69 6e 74 2e 20 20 55 73 65 20 22 73 71   point.  Use "sq
22e0: 6c 69 74 65 33 5f 65 78 74 65 6e 73 69 6f 6e 5f  lite3_extension_
22f0: 69 6e 69 74 22 20 69 66 20 30 20 2a 2f 0a 20 20  init" if 0 */.  
2300: 63 68 61 72 20 2a 2a 70 7a 45 72 72 4d 73 67 20  char **pzErrMsg 
2310: 20 20 20 20 20 20 2f 2a 20 50 75 74 20 65 72 72        /* Put err
2320: 6f 72 20 6d 65 73 73 61 67 65 20 68 65 72 65 20  or message here 
2330: 69 66 20 6e 6f 74 20 30 20 2a 2f 0a 29 7b 0a 20  if not 0 */.){. 
2340: 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56   sqlite3_vfs *pV
2350: 66 73 20 3d 20 64 62 2d 3e 70 56 66 73 3b 0a 20  fs = db->pVfs;. 
2360: 20 76 6f 69 64 20 2a 68 61 6e 64 6c 65 3b 0a 20   void *handle;. 
2370: 20 69 6e 74 20 28 2a 78 49 6e 69 74 29 28 73 71   int (*xInit)(sq
2380: 6c 69 74 65 33 2a 2c 63 68 61 72 2a 2a 2c 63 6f  lite3*,char**,co
2390: 6e 73 74 20 73 71 6c 69 74 65 33 5f 61 70 69 5f  nst sqlite3_api_
23a0: 72 6f 75 74 69 6e 65 73 2a 29 3b 0a 20 20 63 68  routines*);.  ch
23b0: 61 72 20 2a 7a 45 72 72 6d 73 67 20 3d 20 30 3b  ar *zErrmsg = 0;
23c0: 0a 20 20 76 6f 69 64 20 2a 2a 61 48 61 6e 64 6c  .  void **aHandl
23d0: 65 3b 0a 0a 20 20 2f 2a 20 54 69 63 6b 65 74 20  e;..  /* Ticket 
23e0: 23 31 38 36 33 2e 20 20 54 6f 20 61 76 6f 69 64  #1863.  To avoid
23f0: 20 61 20 63 72 65 61 74 69 6e 67 20 73 65 63 75   a creating secu
2400: 72 69 74 79 20 70 72 6f 62 6c 65 6d 73 20 66 6f  rity problems fo
2410: 72 20 6f 6c 64 65 72 0a 20 20 2a 2a 20 61 70 70  r older.  ** app
2420: 6c 69 63 61 74 69 6f 6e 73 20 74 68 61 74 20 72  lications that r
2430: 65 6c 69 6e 6b 20 61 67 61 69 6e 73 74 20 6e 65  elink against ne
2440: 77 65 72 20 76 65 72 73 69 6f 6e 73 20 6f 66 20  wer versions of 
2450: 53 51 4c 69 74 65 2c 20 74 68 65 0a 20 20 2a 2a  SQLite, the.  **
2460: 20 61 62 69 6c 69 74 79 20 74 6f 20 72 75 6e 20   ability to run 
2470: 6c 6f 61 64 5f 65 78 74 65 6e 73 69 6f 6e 20 69  load_extension i
2480: 73 20 74 75 72 6e 65 64 20 6f 66 66 20 62 79 20  s turned off by 
2490: 64 65 66 61 75 6c 74 2e 20 20 4f 6e 65 0a 20 20  default.  One.  
24a0: 2a 2a 20 6d 75 73 74 20 63 61 6c 6c 20 73 71 6c  ** must call sql
24b0: 69 74 65 33 5f 65 6e 61 62 6c 65 5f 6c 6f 61 64  ite3_enable_load
24c0: 5f 65 78 74 65 6e 73 69 6f 6e 28 29 20 74 6f 20  _extension() to 
24d0: 74 75 72 6e 20 6f 6e 20 65 78 74 65 6e 73 69 6f  turn on extensio
24e0: 6e 0a 20 20 2a 2a 20 6c 6f 61 64 69 6e 67 2e 20  n.  ** loading. 
24f0: 20 4f 74 68 65 72 77 69 73 65 20 79 6f 75 20 67   Otherwise you g
2500: 65 74 20 74 68 65 20 66 6f 6c 6c 6f 77 69 6e 67  et the following
2510: 20 65 72 72 6f 72 2e 0a 20 20 2a 2f 0a 20 20 69   error..  */.  i
2520: 66 28 20 28 64 62 2d 3e 66 6c 61 67 73 20 26 20  f( (db->flags & 
2530: 53 51 4c 49 54 45 5f 4c 6f 61 64 45 78 74 65 6e  SQLITE_LoadExten
2540: 73 69 6f 6e 29 3d 3d 30 20 29 7b 0a 20 20 20 20  sion)==0 ){.    
2550: 69 66 28 20 70 7a 45 72 72 4d 73 67 20 29 7b 0a  if( pzErrMsg ){.
2560: 20 20 20 20 20 20 2a 70 7a 45 72 72 4d 73 67 20        *pzErrMsg 
2570: 3d 20 73 71 6c 69 74 65 33 5f 6d 70 72 69 6e 74  = sqlite3_mprint
2580: 66 28 22 6e 6f 74 20 61 75 74 68 6f 72 69 7a 65  f("not authorize
2590: 64 22 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 72  d");.    }.    r
25a0: 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 45 52 52  eturn SQLITE_ERR
25b0: 4f 52 3b 0a 20 20 7d 0a 0a 20 20 69 66 28 20 7a  OR;.  }..  if( z
25c0: 50 72 6f 63 3d 3d 30 20 29 7b 0a 20 20 20 20 7a  Proc==0 ){.    z
25d0: 50 72 6f 63 20 3d 20 22 73 71 6c 69 74 65 33 5f  Proc = "sqlite3_
25e0: 65 78 74 65 6e 73 69 6f 6e 5f 69 6e 69 74 22 3b  extension_init";
25f0: 0a 20 20 7d 0a 0a 20 20 68 61 6e 64 6c 65 20 3d  .  }..  handle =
2600: 20 73 71 6c 69 74 65 33 4f 73 44 6c 4f 70 65 6e   sqlite3OsDlOpen
2610: 28 70 56 66 73 2c 20 7a 46 69 6c 65 29 3b 0a 20  (pVfs, zFile);. 
2620: 20 69 66 28 20 68 61 6e 64 6c 65 3d 3d 30 20 29   if( handle==0 )
2630: 7b 0a 20 20 20 20 69 66 28 20 70 7a 45 72 72 4d  {.    if( pzErrM
2640: 73 67 20 29 7b 0a 20 20 20 20 20 20 63 68 61 72  sg ){.      char
2650: 20 7a 45 72 72 5b 32 35 36 5d 3b 0a 20 20 20 20   zErr[256];.    
2660: 20 20 7a 45 72 72 5b 73 69 7a 65 6f 66 28 7a 45    zErr[sizeof(zE
2670: 72 72 29 2d 31 5d 20 3d 20 27 5c 30 27 3b 0a 20  rr)-1] = '\0';. 
2680: 20 20 20 20 20 73 71 6c 69 74 65 33 5f 73 6e 70       sqlite3_snp
2690: 72 69 6e 74 66 28 73 69 7a 65 6f 66 28 7a 45 72  rintf(sizeof(zEr
26a0: 72 29 2d 31 2c 20 7a 45 72 72 2c 20 0a 20 20 20  r)-1, zErr, .   
26b0: 20 20 20 20 20 20 20 22 75 6e 61 62 6c 65 20 74         "unable t
26c0: 6f 20 6f 70 65 6e 20 73 68 61 72 65 64 20 6c 69  o open shared li
26d0: 62 72 61 72 79 20 5b 25 73 5d 22 2c 20 7a 46 69  brary [%s]", zFi
26e0: 6c 65 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74  le);.      sqlit
26f0: 65 33 4f 73 44 6c 45 72 72 6f 72 28 70 56 66 73  e3OsDlError(pVfs
2700: 2c 20 73 69 7a 65 6f 66 28 7a 45 72 72 29 2d 31  , sizeof(zErr)-1
2710: 2c 20 7a 45 72 72 29 3b 0a 20 20 20 20 20 20 2a  , zErr);.      *
2720: 70 7a 45 72 72 4d 73 67 20 3d 20 73 71 6c 69 74  pzErrMsg = sqlit
2730: 65 33 44 62 53 74 72 44 75 70 28 30 2c 20 7a 45  e3DbStrDup(0, zE
2740: 72 72 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 72  rr);.    }.    r
2750: 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 45 52 52  eturn SQLITE_ERR
2760: 4f 52 3b 0a 20 20 7d 0a 20 20 78 49 6e 69 74 20  OR;.  }.  xInit 
2770: 3d 20 28 69 6e 74 28 2a 29 28 73 71 6c 69 74 65  = (int(*)(sqlite
2780: 33 2a 2c 63 68 61 72 2a 2a 2c 63 6f 6e 73 74 20  3*,char**,const 
2790: 73 71 6c 69 74 65 33 5f 61 70 69 5f 72 6f 75 74  sqlite3_api_rout
27a0: 69 6e 65 73 2a 29 29 0a 20 20 20 20 20 20 20 20  ines*)).        
27b0: 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74             sqlit
27c0: 65 33 4f 73 44 6c 53 79 6d 28 70 56 66 73 2c 20  e3OsDlSym(pVfs, 
27d0: 68 61 6e 64 6c 65 2c 20 7a 50 72 6f 63 29 3b 0a  handle, zProc);.
27e0: 20 20 69 66 28 20 78 49 6e 69 74 3d 3d 30 20 29    if( xInit==0 )
27f0: 7b 0a 20 20 20 20 69 66 28 20 70 7a 45 72 72 4d  {.    if( pzErrM
2800: 73 67 20 29 7b 0a 20 20 20 20 20 20 63 68 61 72  sg ){.      char
2810: 20 7a 45 72 72 5b 32 35 36 5d 3b 0a 20 20 20 20   zErr[256];.    
2820: 20 20 7a 45 72 72 5b 73 69 7a 65 6f 66 28 7a 45    zErr[sizeof(zE
2830: 72 72 29 2d 31 5d 20 3d 20 27 5c 30 27 3b 0a 20  rr)-1] = '\0';. 
2840: 20 20 20 20 20 73 71 6c 69 74 65 33 5f 73 6e 70       sqlite3_snp
2850: 72 69 6e 74 66 28 73 69 7a 65 6f 66 28 7a 45 72  rintf(sizeof(zEr
2860: 72 29 2d 31 2c 20 7a 45 72 72 2c 0a 20 20 20 20  r)-1, zErr,.    
2870: 20 20 20 20 20 20 22 6e 6f 20 65 6e 74 72 79 20        "no entry 
2880: 70 6f 69 6e 74 20 5b 25 73 5d 20 69 6e 20 73 68  point [%s] in sh
2890: 61 72 65 64 20 6c 69 62 72 61 72 79 20 5b 25 73  ared library [%s
28a0: 5d 22 2c 20 7a 50 72 6f 63 2c 7a 46 69 6c 65 29  ]", zProc,zFile)
28b0: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 4f  ;.      sqlite3O
28c0: 73 44 6c 45 72 72 6f 72 28 70 56 66 73 2c 20 73  sDlError(pVfs, s
28d0: 69 7a 65 6f 66 28 7a 45 72 72 29 2d 31 2c 20 7a  izeof(zErr)-1, z
28e0: 45 72 72 29 3b 0a 20 20 20 20 20 20 2a 70 7a 45  Err);.      *pzE
28f0: 72 72 4d 73 67 20 3d 20 73 71 6c 69 74 65 33 44  rrMsg = sqlite3D
2900: 62 53 74 72 44 75 70 28 30 2c 20 7a 45 72 72 29  bStrDup(0, zErr)
2910: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 4f  ;.      sqlite3O
2920: 73 44 6c 43 6c 6f 73 65 28 70 56 66 73 2c 20 68  sDlClose(pVfs, h
2930: 61 6e 64 6c 65 29 3b 0a 20 20 20 20 7d 0a 20 20  andle);.    }.  
2940: 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f    return SQLITE_
2950: 45 52 52 4f 52 3b 0a 20 20 7d 65 6c 73 65 20 69  ERROR;.  }else i
2960: 66 28 20 78 49 6e 69 74 28 64 62 2c 20 26 7a 45  f( xInit(db, &zE
2970: 72 72 6d 73 67 2c 20 26 73 71 6c 69 74 65 33 41  rrmsg, &sqlite3A
2980: 70 69 73 29 20 29 7b 0a 20 20 20 20 69 66 28 20  pis) ){.    if( 
2990: 70 7a 45 72 72 4d 73 67 20 29 7b 0a 20 20 20 20  pzErrMsg ){.    
29a0: 20 20 2a 70 7a 45 72 72 4d 73 67 20 3d 20 73 71    *pzErrMsg = sq
29b0: 6c 69 74 65 33 5f 6d 70 72 69 6e 74 66 28 22 65  lite3_mprintf("e
29c0: 72 72 6f 72 20 64 75 72 69 6e 67 20 69 6e 69 74  rror during init
29d0: 69 61 6c 69 7a 61 74 69 6f 6e 3a 20 25 73 22 2c  ialization: %s",
29e0: 20 7a 45 72 72 6d 73 67 29 3b 0a 20 20 20 20 7d   zErrmsg);.    }
29f0: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66 72 65  .    sqlite3_fre
2a00: 65 28 7a 45 72 72 6d 73 67 29 3b 0a 20 20 20 20  e(zErrmsg);.    
2a10: 73 71 6c 69 74 65 33 4f 73 44 6c 43 6c 6f 73 65  sqlite3OsDlClose
2a20: 28 70 56 66 73 2c 20 68 61 6e 64 6c 65 29 3b 0a  (pVfs, handle);.
2a30: 20 20 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54      return SQLIT
2a40: 45 5f 45 52 52 4f 52 3b 0a 20 20 7d 0a 0a 20 20  E_ERROR;.  }..  
2a50: 2f 2a 20 41 70 70 65 6e 64 20 74 68 65 20 6e 65  /* Append the ne
2a60: 77 20 73 68 61 72 65 64 20 6c 69 62 72 61 72 79  w shared library
2a70: 20 68 61 6e 64 6c 65 20 74 6f 20 74 68 65 20 64   handle to the d
2a80: 62 2d 3e 61 45 78 74 65 6e 73 69 6f 6e 20 61 72  b->aExtension ar
2a90: 72 61 79 2e 20 2a 2f 0a 20 20 61 48 61 6e 64 6c  ray. */.  aHandl
2aa0: 65 20 3d 20 73 71 6c 69 74 65 33 44 62 4d 61 6c  e = sqlite3DbMal
2ab0: 6c 6f 63 5a 65 72 6f 28 64 62 2c 20 73 69 7a 65  locZero(db, size
2ac0: 6f 66 28 68 61 6e 64 6c 65 29 2a 28 64 62 2d 3e  of(handle)*(db->
2ad0: 6e 45 78 74 65 6e 73 69 6f 6e 2b 31 29 29 3b 0a  nExtension+1));.
2ae0: 20 20 69 66 28 20 61 48 61 6e 64 6c 65 3d 3d 30    if( aHandle==0
2af0: 20 29 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 53   ){.    return S
2b00: 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 7d  QLITE_NOMEM;.  }
2b10: 0a 20 20 69 66 28 20 64 62 2d 3e 6e 45 78 74 65  .  if( db->nExte
2b20: 6e 73 69 6f 6e 3e 30 20 29 7b 0a 20 20 20 20 6d  nsion>0 ){.    m
2b30: 65 6d 63 70 79 28 61 48 61 6e 64 6c 65 2c 20 64  emcpy(aHandle, d
2b40: 62 2d 3e 61 45 78 74 65 6e 73 69 6f 6e 2c 20 73  b->aExtension, s
2b50: 69 7a 65 6f 66 28 68 61 6e 64 6c 65 29 2a 64 62  izeof(handle)*db
2b60: 2d 3e 6e 45 78 74 65 6e 73 69 6f 6e 29 3b 0a 20  ->nExtension);. 
2b70: 20 7d 0a 20 20 73 71 6c 69 74 65 33 44 62 46 72   }.  sqlite3DbFr
2b80: 65 65 28 64 62 2c 20 64 62 2d 3e 61 45 78 74 65  ee(db, db->aExte
2b90: 6e 73 69 6f 6e 29 3b 0a 20 20 64 62 2d 3e 61 45  nsion);.  db->aE
2ba0: 78 74 65 6e 73 69 6f 6e 20 3d 20 61 48 61 6e 64  xtension = aHand
2bb0: 6c 65 3b 0a 0a 20 20 64 62 2d 3e 61 45 78 74 65  le;..  db->aExte
2bc0: 6e 73 69 6f 6e 5b 64 62 2d 3e 6e 45 78 74 65 6e  nsion[db->nExten
2bd0: 73 69 6f 6e 2b 2b 5d 20 3d 20 68 61 6e 64 6c 65  sion++] = handle
2be0: 3b 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54  ;.  return SQLIT
2bf0: 45 5f 4f 4b 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69  E_OK;.}.int sqli
2c00: 74 65 33 5f 6c 6f 61 64 5f 65 78 74 65 6e 73 69  te3_load_extensi
2c10: 6f 6e 28 0a 20 20 73 71 6c 69 74 65 33 20 2a 64  on(.  sqlite3 *d
2c20: 62 2c 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4c  b,          /* L
2c30: 6f 61 64 20 74 68 65 20 65 78 74 65 6e 73 69 6f  oad the extensio
2c40: 6e 20 69 6e 74 6f 20 74 68 69 73 20 64 61 74 61  n into this data
2c50: 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20  base connection 
2c60: 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20  */.  const char 
2c70: 2a 7a 46 69 6c 65 2c 20 20 20 20 2f 2a 20 4e 61  *zFile,    /* Na
2c80: 6d 65 20 6f 66 20 74 68 65 20 73 68 61 72 65 64  me of the shared
2c90: 20 6c 69 62 72 61 72 79 20 63 6f 6e 74 61 69 6e   library contain
2ca0: 69 6e 67 20 65 78 74 65 6e 73 69 6f 6e 20 2a 2f  ing extension */
2cb0: 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  .  const char *z
2cc0: 50 72 6f 63 2c 20 20 20 20 2f 2a 20 45 6e 74 72  Proc,    /* Entr
2cd0: 79 20 70 6f 69 6e 74 2e 20 20 55 73 65 20 22 73  y point.  Use "s
2ce0: 71 6c 69 74 65 33 5f 65 78 74 65 6e 73 69 6f 6e  qlite3_extension
2cf0: 5f 69 6e 69 74 22 20 69 66 20 30 20 2a 2f 0a 20  _init" if 0 */. 
2d00: 20 63 68 61 72 20 2a 2a 70 7a 45 72 72 4d 73 67   char **pzErrMsg
2d10: 20 20 20 20 20 20 20 2f 2a 20 50 75 74 20 65 72         /* Put er
2d20: 72 6f 72 20 6d 65 73 73 61 67 65 20 68 65 72 65  ror message here
2d30: 20 69 66 20 6e 6f 74 20 30 20 2a 2f 0a 29 7b 0a   if not 0 */.){.
2d40: 20 20 69 6e 74 20 72 63 3b 0a 20 20 73 71 6c 69    int rc;.  sqli
2d50: 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28  te3_mutex_enter(
2d60: 64 62 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 72 63  db->mutex);.  rc
2d70: 20 3d 20 73 71 6c 69 74 65 33 4c 6f 61 64 45 78   = sqlite3LoadEx
2d80: 74 65 6e 73 69 6f 6e 28 64 62 2c 20 7a 46 69 6c  tension(db, zFil
2d90: 65 2c 20 7a 50 72 6f 63 2c 20 70 7a 45 72 72 4d  e, zProc, pzErrM
2da0: 73 67 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 6d  sg);.  sqlite3_m
2db0: 75 74 65 78 5f 6c 65 61 76 65 28 64 62 2d 3e 6d  utex_leave(db->m
2dc0: 75 74 65 78 29 3b 0a 20 20 72 65 74 75 72 6e 20  utex);.  return 
2dd0: 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 61 6c  rc;.}../*.** Cal
2de0: 6c 20 74 68 69 73 20 72 6f 75 74 69 6e 65 20 77  l this routine w
2df0: 68 65 6e 20 74 68 65 20 64 61 74 61 62 61 73 65  hen the database
2e00: 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 69 73 20 63   connection is c
2e10: 6c 6f 73 69 6e 67 20 69 6e 20 6f 72 64 65 72 0a  losing in order.
2e20: 2a 2a 20 74 6f 20 63 6c 65 61 6e 20 75 70 20 6c  ** to clean up l
2e30: 6f 61 64 65 64 20 65 78 74 65 6e 73 69 6f 6e 73  oaded extensions
2e40: 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c 69 74 65 33  .*/.void sqlite3
2e50: 43 6c 6f 73 65 45 78 74 65 6e 73 69 6f 6e 73 28  CloseExtensions(
2e60: 73 71 6c 69 74 65 33 20 2a 64 62 29 7b 0a 20 20  sqlite3 *db){.  
2e70: 69 6e 74 20 69 3b 0a 20 20 61 73 73 65 72 74 28  int i;.  assert(
2e80: 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 68   sqlite3_mutex_h
2e90: 65 6c 64 28 64 62 2d 3e 6d 75 74 65 78 29 20 29  eld(db->mutex) )
2ea0: 3b 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 64  ;.  for(i=0; i<d
2eb0: 62 2d 3e 6e 45 78 74 65 6e 73 69 6f 6e 3b 20 69  b->nExtension; i
2ec0: 2b 2b 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33  ++){.    sqlite3
2ed0: 4f 73 44 6c 43 6c 6f 73 65 28 64 62 2d 3e 70 56  OsDlClose(db->pV
2ee0: 66 73 2c 20 64 62 2d 3e 61 45 78 74 65 6e 73 69  fs, db->aExtensi
2ef0: 6f 6e 5b 69 5d 29 3b 0a 20 20 7d 0a 20 20 73 71  on[i]);.  }.  sq
2f00: 6c 69 74 65 33 44 62 46 72 65 65 28 64 62 2c 20  lite3DbFree(db, 
2f10: 64 62 2d 3e 61 45 78 74 65 6e 73 69 6f 6e 29 3b  db->aExtension);
2f20: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 45 6e 61 62 6c 65  .}../*.** Enable
2f30: 20 6f 72 20 64 69 73 61 62 6c 65 20 65 78 74 65   or disable exte
2f40: 6e 73 69 6f 6e 20 6c 6f 61 64 69 6e 67 2e 20 20  nsion loading.  
2f50: 45 78 74 65 6e 73 69 6f 6e 20 6c 6f 61 64 69 6e  Extension loadin
2f60: 67 20 69 73 20 64 69 73 61 62 6c 65 64 20 62 79  g is disabled by
2f70: 0a 2a 2a 20 64 65 66 61 75 6c 74 20 73 6f 20 61  .** default so a
2f80: 73 20 6e 6f 74 20 74 6f 20 6f 70 65 6e 20 73 65  s not to open se
2f90: 63 75 72 69 74 79 20 68 6f 6c 65 73 20 69 6e 20  curity holes in 
2fa0: 6f 6c 64 65 72 20 61 70 70 6c 69 63 61 74 69 6f  older applicatio
2fb0: 6e 73 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74  ns..*/.int sqlit
2fc0: 65 33 5f 65 6e 61 62 6c 65 5f 6c 6f 61 64 5f 65  e3_enable_load_e
2fd0: 78 74 65 6e 73 69 6f 6e 28 73 71 6c 69 74 65 33  xtension(sqlite3
2fe0: 20 2a 64 62 2c 20 69 6e 74 20 6f 6e 6f 66 66 29   *db, int onoff)
2ff0: 7b 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65  {.  sqlite3_mute
3000: 78 5f 65 6e 74 65 72 28 64 62 2d 3e 6d 75 74 65  x_enter(db->mute
3010: 78 29 3b 0a 20 20 69 66 28 20 6f 6e 6f 66 66 20  x);.  if( onoff 
3020: 29 7b 0a 20 20 20 20 64 62 2d 3e 66 6c 61 67 73  ){.    db->flags
3030: 20 7c 3d 20 53 51 4c 49 54 45 5f 4c 6f 61 64 45   |= SQLITE_LoadE
3040: 78 74 65 6e 73 69 6f 6e 3b 0a 20 20 7d 65 6c 73  xtension;.  }els
3050: 65 7b 0a 20 20 20 20 64 62 2d 3e 66 6c 61 67 73  e{.    db->flags
3060: 20 26 3d 20 7e 53 51 4c 49 54 45 5f 4c 6f 61 64   &= ~SQLITE_Load
3070: 45 78 74 65 6e 73 69 6f 6e 3b 0a 20 20 7d 0a 20  Extension;.  }. 
3080: 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c   sqlite3_mutex_l
3090: 65 61 76 65 28 64 62 2d 3e 6d 75 74 65 78 29 3b  eave(db->mutex);
30a0: 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45  .  return SQLITE
30b0: 5f 4f 4b 3b 0a 7d 0a 0a 23 65 6e 64 69 66 20 2f  _OK;.}..#endif /
30c0: 2a 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 4c 4f  * SQLITE_OMIT_LO
30d0: 41 44 5f 45 58 54 45 4e 53 49 4f 4e 20 2a 2f 0a  AD_EXTENSION */.
30e0: 0a 2f 2a 0a 2a 2a 20 54 68 65 20 61 75 74 6f 2d  ./*.** The auto-
30f0: 65 78 74 65 6e 73 69 6f 6e 20 63 6f 64 65 20 61  extension code a
3100: 64 64 65 64 20 72 65 67 61 72 64 6c 65 73 73 20  dded regardless 
3110: 6f 66 20 77 68 65 74 68 65 72 20 6f 72 20 6e 6f  of whether or no
3120: 74 20 65 78 74 65 6e 73 69 6f 6e 0a 2a 2a 20 6c  t extension.** l
3130: 6f 61 64 69 6e 67 20 69 73 20 73 75 70 70 6f 72  oading is suppor
3140: 74 65 64 2e 20 20 57 65 20 6e 65 65 64 20 61 20  ted.  We need a 
3150: 64 75 6d 6d 79 20 73 71 6c 69 74 65 33 41 70 69  dummy sqlite3Api
3160: 73 20 70 6f 69 6e 74 65 72 20 66 6f 72 20 74 68  s pointer for th
3170: 61 74 0a 2a 2a 20 63 6f 64 65 20 69 66 20 72 65  at.** code if re
3180: 67 75 6c 61 72 20 65 78 74 65 6e 73 69 6f 6e 20  gular extension 
3190: 6c 6f 61 64 69 6e 67 20 69 73 20 6e 6f 74 20 61  loading is not a
31a0: 76 61 69 6c 61 62 6c 65 2e 20 20 54 68 69 73 20  vailable.  This 
31b0: 69 73 20 74 68 61 74 0a 2a 2a 20 64 75 6d 6d 79  is that.** dummy
31c0: 20 70 6f 69 6e 74 65 72 2e 0a 2a 2f 0a 23 69 66   pointer..*/.#if
31d0: 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  def SQLITE_OMIT_
31e0: 4c 4f 41 44 5f 45 58 54 45 4e 53 49 4f 4e 0a 73  LOAD_EXTENSION.s
31f0: 74 61 74 69 63 20 63 6f 6e 73 74 20 73 71 6c 69  tatic const sqli
3200: 74 65 33 5f 61 70 69 5f 72 6f 75 74 69 6e 65 73  te3_api_routines
3210: 20 73 71 6c 69 74 65 33 41 70 69 73 20 3d 20 7b   sqlite3Apis = {
3220: 20 30 20 7d 3b 0a 23 65 6e 64 69 66 0a 0a 0a 2f   0 };.#endif.../
3230: 2a 0a 2a 2a 20 54 68 65 20 66 6f 6c 6c 6f 77 69  *.** The followi
3240: 6e 67 20 6f 62 6a 65 63 74 20 68 6f 6c 64 73 20  ng object holds 
3250: 74 68 65 20 6c 69 73 74 20 6f 66 20 61 75 74 6f  the list of auto
3260: 6d 61 74 69 63 61 6c 6c 79 20 6c 6f 61 64 65 64  matically loaded
3270: 0a 2a 2a 20 65 78 74 65 6e 73 69 6f 6e 73 2e 0a  .** extensions..
3280: 2a 2a 0a 2a 2a 20 54 68 69 73 20 6c 69 73 74 20  **.** This list 
3290: 69 73 20 73 68 61 72 65 64 20 61 63 72 6f 73 73  is shared across
32a0: 20 74 68 72 65 61 64 73 2e 20 20 54 68 65 20 53   threads.  The S
32b0: 51 4c 49 54 45 5f 4d 55 54 45 58 5f 53 54 41 54  QLITE_MUTEX_STAT
32c0: 49 43 5f 4d 41 53 54 45 52 0a 2a 2a 20 6d 75 74  IC_MASTER.** mut
32d0: 65 78 20 6d 75 73 74 20 62 65 20 68 65 6c 64 20  ex must be held 
32e0: 77 68 69 6c 65 20 61 63 63 65 73 73 69 6e 67 20  while accessing 
32f0: 74 68 69 73 20 6c 69 73 74 2e 0a 2a 2f 0a 73 74  this list..*/.st
3300: 61 74 69 63 20 73 74 72 75 63 74 20 7b 0a 20 20  atic struct {.  
3310: 69 6e 74 20 6e 45 78 74 3b 20 20 20 20 20 20 20  int nExt;       
3320: 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 65 6e   /* Number of en
3330: 74 72 69 65 73 20 69 6e 20 61 45 78 74 5b 5d 20  tries in aExt[] 
3340: 2a 2f 20 20 20 20 20 20 20 20 20 20 0a 20 20 76  */          .  v
3350: 6f 69 64 20 2a 2a 61 45 78 74 3b 20 20 20 20 20  oid **aExt;     
3360: 2f 2a 20 50 6f 69 6e 74 65 72 73 20 74 6f 20 74  /* Pointers to t
3370: 68 65 20 65 78 74 65 6e 73 69 6f 6e 20 69 6e 69  he extension ini
3380: 74 20 66 75 6e 63 74 69 6f 6e 73 20 2a 2f 0a 7d  t functions */.}
3390: 20 61 75 74 6f 65 78 74 20 3d 20 7b 20 30 2c 20   autoext = { 0, 
33a0: 30 20 7d 3b 0a 0a 0a 2f 2a 0a 2a 2a 20 52 65 67  0 };.../*.** Reg
33b0: 69 73 74 65 72 20 61 20 73 74 61 74 69 63 61 6c  ister a statical
33c0: 6c 79 20 6c 69 6e 6b 65 64 20 65 78 74 65 6e 73  ly linked extens
33d0: 69 6f 6e 20 74 68 61 74 20 69 73 20 61 75 74 6f  ion that is auto
33e0: 6d 61 74 69 63 61 6c 6c 79 0a 2a 2a 20 6c 6f 61  matically.** loa
33f0: 64 65 64 20 62 79 20 65 76 65 72 79 20 6e 65 77  ded by every new
3400: 20 64 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63   database connec
3410: 74 69 6f 6e 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c  tion..*/.int sql
3420: 69 74 65 33 5f 61 75 74 6f 5f 65 78 74 65 6e 73  ite3_auto_extens
3430: 69 6f 6e 28 76 6f 69 64 20 2a 78 49 6e 69 74 29  ion(void *xInit)
3440: 7b 0a 20 20 69 6e 74 20 72 63 20 3d 20 53 51 4c  {.  int rc = SQL
3450: 49 54 45 5f 4f 4b 3b 0a 23 69 66 6e 64 65 66 20  ITE_OK;.#ifndef 
3460: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 41 55 54 4f  SQLITE_OMIT_AUTO
3470: 49 4e 49 54 0a 20 20 72 63 20 3d 20 73 71 6c 69  INIT.  rc = sqli
3480: 74 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65 28 29  te3_initialize()
3490: 3b 0a 20 20 69 66 28 20 72 63 20 29 7b 0a 20 20  ;.  if( rc ){.  
34a0: 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 20 20 7d    return rc;.  }
34b0: 65 6c 73 65 0a 23 65 6e 64 69 66 0a 20 20 7b 0a  else.#endif.  {.
34c0: 20 20 20 20 69 6e 74 20 69 3b 0a 23 69 66 6e 64      int i;.#ifnd
34d0: 65 66 20 53 51 4c 49 54 45 5f 4d 55 54 45 58 5f  ef SQLITE_MUTEX_
34e0: 4e 4f 4f 50 0a 20 20 20 20 73 71 6c 69 74 65 33  NOOP.    sqlite3
34f0: 5f 6d 75 74 65 78 20 2a 6d 75 74 65 78 20 3d 20  _mutex *mutex = 
3500: 73 71 6c 69 74 65 33 4d 75 74 65 78 41 6c 6c 6f  sqlite3MutexAllo
3510: 63 28 53 51 4c 49 54 45 5f 4d 55 54 45 58 5f 53  c(SQLITE_MUTEX_S
3520: 54 41 54 49 43 5f 4d 41 53 54 45 52 29 3b 0a 23  TATIC_MASTER);.#
3530: 65 6e 64 69 66 0a 20 20 20 20 73 71 6c 69 74 65  endif.    sqlite
3540: 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28 6d 75  3_mutex_enter(mu
3550: 74 65 78 29 3b 0a 20 20 20 20 66 6f 72 28 69 3d  tex);.    for(i=
3560: 30 3b 20 69 3c 61 75 74 6f 65 78 74 2e 6e 45 78  0; i<autoext.nEx
3570: 74 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 69  t; i++){.      i
3580: 66 28 20 61 75 74 6f 65 78 74 2e 61 45 78 74 5b  f( autoext.aExt[
3590: 69 5d 3d 3d 78 49 6e 69 74 20 29 20 62 72 65 61  i]==xInit ) brea
35a0: 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 66 28  k;.    }.    if(
35b0: 20 69 3d 3d 61 75 74 6f 65 78 74 2e 6e 45 78 74   i==autoext.nExt
35c0: 20 29 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e 42   ){.      int nB
35d0: 79 74 65 20 3d 20 28 61 75 74 6f 65 78 74 2e 6e  yte = (autoext.n
35e0: 45 78 74 2b 31 29 2a 73 69 7a 65 6f 66 28 61 75  Ext+1)*sizeof(au
35f0: 74 6f 65 78 74 2e 61 45 78 74 5b 30 5d 29 3b 0a  toext.aExt[0]);.
3600: 20 20 20 20 20 20 76 6f 69 64 20 2a 2a 61 4e 65        void **aNe
3610: 77 3b 0a 20 20 20 20 20 20 61 4e 65 77 20 3d 20  w;.      aNew = 
3620: 73 71 6c 69 74 65 33 5f 72 65 61 6c 6c 6f 63 28  sqlite3_realloc(
3630: 61 75 74 6f 65 78 74 2e 61 45 78 74 2c 20 6e 42  autoext.aExt, nB
3640: 79 74 65 29 3b 0a 20 20 20 20 20 20 69 66 28 20  yte);.      if( 
3650: 61 4e 65 77 3d 3d 30 20 29 7b 0a 20 20 20 20 20  aNew==0 ){.     
3660: 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 4e     rc = SQLITE_N
3670: 4f 4d 45 4d 3b 0a 20 20 20 20 20 20 7d 65 6c 73  OMEM;.      }els
3680: 65 7b 0a 20 20 20 20 20 20 20 20 61 75 74 6f 65  e{.        autoe
3690: 78 74 2e 61 45 78 74 20 3d 20 61 4e 65 77 3b 0a  xt.aExt = aNew;.
36a0: 20 20 20 20 20 20 20 20 61 75 74 6f 65 78 74 2e          autoext.
36b0: 61 45 78 74 5b 61 75 74 6f 65 78 74 2e 6e 45 78  aExt[autoext.nEx
36c0: 74 5d 20 3d 20 78 49 6e 69 74 3b 0a 20 20 20 20  t] = xInit;.    
36d0: 20 20 20 20 61 75 74 6f 65 78 74 2e 6e 45 78 74      autoext.nExt
36e0: 2b 2b 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  ++;.      }.    
36f0: 7d 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 6d 75  }.    sqlite3_mu
3700: 74 65 78 5f 6c 65 61 76 65 28 6d 75 74 65 78 29  tex_leave(mutex)
3710: 3b 0a 20 20 20 20 61 73 73 65 72 74 28 20 28 72  ;.    assert( (r
3720: 63 26 30 78 66 66 29 3d 3d 72 63 20 29 3b 0a 20  c&0xff)==rc );. 
3730: 20 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 20 20     return rc;.  
3740: 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 73 65 74  }.}../*.** Reset
3750: 20 74 68 65 20 61 75 74 6f 6d 61 74 69 63 20 65   the automatic e
3760: 78 74 65 6e 73 69 6f 6e 20 6c 6f 61 64 69 6e 67  xtension loading
3770: 20 6d 65 63 68 61 6e 69 73 6d 2e 0a 2a 2f 0a 76   mechanism..*/.v
3780: 6f 69 64 20 73 71 6c 69 74 65 33 5f 72 65 73 65  oid sqlite3_rese
3790: 74 5f 61 75 74 6f 5f 65 78 74 65 6e 73 69 6f 6e  t_auto_extension
37a0: 28 76 6f 69 64 29 7b 0a 23 69 66 6e 64 65 66 20  (void){.#ifndef 
37b0: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 41 55 54 4f  SQLITE_OMIT_AUTO
37c0: 49 4e 49 54 0a 20 20 69 66 28 20 73 71 6c 69 74  INIT.  if( sqlit
37d0: 65 33 5f 69 6e 69 74 69 61 6c 69 7a 65 28 29 3d  e3_initialize()=
37e0: 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 0a 23 65 6e  =SQLITE_OK ).#en
37f0: 64 69 66 0a 20 20 7b 0a 23 69 66 6e 64 65 66 20  dif.  {.#ifndef 
3800: 53 51 4c 49 54 45 5f 4d 55 54 45 58 5f 4e 4f 4f  SQLITE_MUTEX_NOO
3810: 50 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 6d 75  P.    sqlite3_mu
3820: 74 65 78 20 2a 6d 75 74 65 78 20 3d 20 73 71 6c  tex *mutex = sql
3830: 69 74 65 33 4d 75 74 65 78 41 6c 6c 6f 63 28 53  ite3MutexAlloc(S
3840: 51 4c 49 54 45 5f 4d 55 54 45 58 5f 53 54 41 54  QLITE_MUTEX_STAT
3850: 49 43 5f 4d 41 53 54 45 52 29 3b 0a 23 65 6e 64  IC_MASTER);.#end
3860: 69 66 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 6d  if.    sqlite3_m
3870: 75 74 65 78 5f 65 6e 74 65 72 28 6d 75 74 65 78  utex_enter(mutex
3880: 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66  );.    sqlite3_f
3890: 72 65 65 28 61 75 74 6f 65 78 74 2e 61 45 78 74  ree(autoext.aExt
38a0: 29 3b 0a 20 20 20 20 61 75 74 6f 65 78 74 2e 61  );.    autoext.a
38b0: 45 78 74 20 3d 20 30 3b 0a 20 20 20 20 61 75 74  Ext = 0;.    aut
38c0: 6f 65 78 74 2e 6e 45 78 74 20 3d 20 30 3b 0a 20  oext.nExt = 0;. 
38d0: 20 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78     sqlite3_mutex
38e0: 5f 6c 65 61 76 65 28 6d 75 74 65 78 29 3b 0a 20  _leave(mutex);. 
38f0: 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 4c 6f 61 64   }.}../*.** Load
3900: 20 61 6c 6c 20 61 75 74 6f 6d 61 74 69 63 20 65   all automatic e
3910: 78 74 65 6e 73 69 6f 6e 73 2e 0a 2a 2f 0a 69 6e  xtensions..*/.in
3920: 74 20 73 71 6c 69 74 65 33 41 75 74 6f 4c 6f 61  t sqlite3AutoLoa
3930: 64 45 78 74 65 6e 73 69 6f 6e 73 28 73 71 6c 69  dExtensions(sqli
3940: 74 65 33 20 2a 64 62 29 7b 0a 20 20 69 6e 74 20  te3 *db){.  int 
3950: 69 3b 0a 20 20 69 6e 74 20 67 6f 20 3d 20 31 3b  i;.  int go = 1;
3960: 0a 20 20 69 6e 74 20 72 63 20 3d 20 53 51 4c 49  .  int rc = SQLI
3970: 54 45 5f 4f 4b 3b 0a 20 20 69 6e 74 20 28 2a 78  TE_OK;.  int (*x
3980: 49 6e 69 74 29 28 73 71 6c 69 74 65 33 2a 2c 63  Init)(sqlite3*,c
3990: 68 61 72 2a 2a 2c 63 6f 6e 73 74 20 73 71 6c 69  har**,const sqli
39a0: 74 65 33 5f 61 70 69 5f 72 6f 75 74 69 6e 65 73  te3_api_routines
39b0: 2a 29 3b 0a 0a 20 20 69 66 28 20 61 75 74 6f 65  *);..  if( autoe
39c0: 78 74 2e 6e 45 78 74 3d 3d 30 20 29 7b 0a 20 20  xt.nExt==0 ){.  
39d0: 20 20 2f 2a 20 43 6f 6d 6d 6f 6e 20 63 61 73 65    /* Common case
39e0: 3a 20 65 61 72 6c 79 20 6f 75 74 20 77 69 74 68  : early out with
39f0: 6f 75 74 20 65 76 65 72 79 20 68 61 76 69 6e 67  out every having
3a00: 20 74 6f 20 61 63 71 75 69 72 65 20 61 20 6d 75   to acquire a mu
3a10: 74 65 78 20 2a 2f 0a 20 20 20 20 72 65 74 75 72  tex */.    retur
3a20: 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 7d  n SQLITE_OK;.  }
3a30: 0a 20 20 66 6f 72 28 69 3d 30 3b 20 67 6f 3b 20  .  for(i=0; go; 
3a40: 69 2b 2b 29 7b 0a 20 20 20 20 63 68 61 72 20 2a  i++){.    char *
3a50: 7a 45 72 72 6d 73 67 20 3d 20 30 3b 0a 23 69 66  zErrmsg = 0;.#if
3a60: 6e 64 65 66 20 53 51 4c 49 54 45 5f 4d 55 54 45  ndef SQLITE_MUTE
3a70: 58 5f 4e 4f 4f 50 0a 20 20 20 20 73 71 6c 69 74  X_NOOP.    sqlit
3a80: 65 33 5f 6d 75 74 65 78 20 2a 6d 75 74 65 78 20  e3_mutex *mutex 
3a90: 3d 20 73 71 6c 69 74 65 33 4d 75 74 65 78 41 6c  = sqlite3MutexAl
3aa0: 6c 6f 63 28 53 51 4c 49 54 45 5f 4d 55 54 45 58  loc(SQLITE_MUTEX
3ab0: 5f 53 54 41 54 49 43 5f 4d 41 53 54 45 52 29 3b  _STATIC_MASTER);
3ac0: 0a 23 65 6e 64 69 66 0a 20 20 20 20 73 71 6c 69  .#endif.    sqli
3ad0: 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28  te3_mutex_enter(
3ae0: 6d 75 74 65 78 29 3b 0a 20 20 20 20 69 66 28 20  mutex);.    if( 
3af0: 69 3e 3d 61 75 74 6f 65 78 74 2e 6e 45 78 74 20  i>=autoext.nExt 
3b00: 29 7b 0a 20 20 20 20 20 20 78 49 6e 69 74 20 3d  ){.      xInit =
3b10: 20 30 3b 0a 20 20 20 20 20 20 67 6f 20 3d 20 30   0;.      go = 0
3b20: 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20  ;.    }else{.   
3b30: 20 20 20 78 49 6e 69 74 20 3d 20 28 69 6e 74 28     xInit = (int(
3b40: 2a 29 28 73 71 6c 69 74 65 33 2a 2c 63 68 61 72  *)(sqlite3*,char
3b50: 2a 2a 2c 63 6f 6e 73 74 20 73 71 6c 69 74 65 33  **,const sqlite3
3b60: 5f 61 70 69 5f 72 6f 75 74 69 6e 65 73 2a 29 29  _api_routines*))
3b70: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 61  .              a
3b80: 75 74 6f 65 78 74 2e 61 45 78 74 5b 69 5d 3b 0a  utoext.aExt[i];.
3b90: 20 20 20 20 7d 0a 20 20 20 20 73 71 6c 69 74 65      }.    sqlite
3ba0: 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 6d 75  3_mutex_leave(mu
3bb0: 74 65 78 29 3b 0a 20 20 20 20 69 66 28 20 78 49  tex);.    if( xI
3bc0: 6e 69 74 20 26 26 20 78 49 6e 69 74 28 64 62 2c  nit && xInit(db,
3bd0: 20 26 7a 45 72 72 6d 73 67 2c 20 26 73 71 6c 69   &zErrmsg, &sqli
3be0: 74 65 33 41 70 69 73 29 20 29 7b 0a 20 20 20 20  te3Apis) ){.    
3bf0: 20 20 73 71 6c 69 74 65 33 45 72 72 6f 72 28 64    sqlite3Error(d
3c00: 62 2c 20 53 51 4c 49 54 45 5f 45 52 52 4f 52 2c  b, SQLITE_ERROR,
3c10: 0a 20 20 20 20 20 20 20 20 20 20 20 20 22 61 75  .            "au
3c20: 74 6f 6d 61 74 69 63 20 65 78 74 65 6e 73 69 6f  tomatic extensio
3c30: 6e 20 6c 6f 61 64 69 6e 67 20 66 61 69 6c 65 64  n loading failed
3c40: 3a 20 25 73 22 2c 20 7a 45 72 72 6d 73 67 29 3b  : %s", zErrmsg);
3c50: 0a 20 20 20 20 20 20 67 6f 20 3d 20 30 3b 0a 20  .      go = 0;. 
3c60: 20 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45       rc = SQLITE
3c70: 5f 45 52 52 4f 52 3b 0a 20 20 20 20 20 20 73 71  _ERROR;.      sq
3c80: 6c 69 74 65 33 5f 66 72 65 65 28 7a 45 72 72 6d  lite3_free(zErrm
3c90: 73 67 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20  sg);.    }.  }. 
3ca0: 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a         return rc;.}.