/ Hex Artifact Content
Login

Artifact ced72140a3a25c148975428e170ec1850d3c3a7d:


0000: 2f 2a 0a 2a 2a 20 32 30 30 36 20 4a 75 6e 65 20  /*.** 2006 June 
0010: 31 30 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74  10.**.** The aut
0020: 68 6f 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f  hor disclaims co
0030: 70 79 72 69 67 68 74 20 74 6f 20 74 68 69 73 20  pyright to this 
0040: 73 6f 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e  source code.  In
0050: 20 70 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c   place of.** a l
0060: 65 67 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72  egal notice, her
0070: 65 20 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a  e is a blessing:
0080: 0a 2a 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f  .**.**    May yo
0090: 75 20 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f  u do good and no
00a0: 74 20 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61  t evil..**    Ma
00b0: 79 20 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69  y you find forgi
00c0: 76 65 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73  veness for yours
00d0: 65 6c 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20  elf and forgive 
00e0: 6f 74 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61  others..**    Ma
00f0: 79 20 79 6f 75 20 73 68 61 72 65 20 66 72 65 65  y you share free
0100: 6c 79 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67  ly, never taking
0110: 20 6d 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67   more than you g
0120: 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a  ive..**.********
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: 2a 0a 2a 2a 20 43 6f 64 65 20 66 6f 72 20 74 65  *.** Code for te
0180: 73 74 69 6e 67 20 74 68 65 20 76 69 72 74 75 61  sting the virtua
0190: 6c 20 74 61 62 6c 65 20 69 6e 74 65 72 66 61 63  l table interfac
01a0: 65 73 2e 20 20 54 68 69 73 20 63 6f 64 65 0a 2a  es.  This code.*
01b0: 2a 20 69 73 20 6e 6f 74 20 69 6e 63 6c 75 64 65  * is not include
01c0: 64 20 69 6e 20 74 68 65 20 53 51 4c 69 74 65 20  d in the SQLite 
01d0: 6c 69 62 72 61 72 79 2e 20 20 49 74 20 69 73 20  library.  It is 
01e0: 75 73 65 64 20 66 6f 72 20 61 75 74 6f 6d 61 74  used for automat
01f0: 65 64 0a 2a 2a 20 74 65 73 74 69 6e 67 20 6f 66  ed.** testing of
0200: 20 74 68 65 20 53 51 4c 69 74 65 20 6c 69 62 72   the SQLite libr
0210: 61 72 79 2e 0a 2a 2a 0a 2a 2a 20 24 49 64 3a 20  ary..**.** $Id: 
0220: 74 65 73 74 5f 73 63 68 65 6d 61 2e 63 2c 76 20  test_schema.c,v 
0230: 31 2e 31 31 20 32 30 30 36 2f 30 39 2f 31 31 20  1.11 2006/09/11 
0240: 30 30 3a 33 34 3a 32 32 20 64 72 68 20 45 78 70  00:34:22 drh Exp
0250: 20 24 0a 2a 2f 0a 0a 2f 2a 20 54 68 65 20 63 6f   $.*/../* The co
0260: 64 65 20 69 6e 20 74 68 69 73 20 66 69 6c 65 20  de in this file 
0270: 64 65 66 69 6e 65 73 20 61 20 73 71 6c 69 74 65  defines a sqlite
0280: 33 20 76 69 72 74 75 61 6c 2d 74 61 62 6c 65 20  3 virtual-table 
0290: 6d 6f 64 75 6c 65 20 74 68 61 74 0a 2a 2a 20 70  module that.** p
02a0: 72 6f 76 69 64 65 73 20 61 20 72 65 61 64 2d 6f  rovides a read-o
02b0: 6e 6c 79 20 76 69 65 77 20 6f 66 20 74 68 65 20  nly view of the 
02c0: 63 75 72 72 65 6e 74 20 64 61 74 61 62 61 73 65  current database
02d0: 20 73 63 68 65 6d 61 2e 20 54 68 65 72 65 20 69   schema. There i
02e0: 73 20 6f 6e 65 0a 2a 2a 20 72 6f 77 20 69 6e 20  s one.** row in 
02f0: 74 68 65 20 73 63 68 65 6d 61 20 74 61 62 6c 65  the schema table
0300: 20 66 6f 72 20 65 61 63 68 20 63 6f 6c 75 6d 6e   for each column
0310: 20 69 6e 20 74 68 65 20 64 61 74 61 62 61 73 65   in the database
0320: 20 73 63 68 65 6d 61 2e 0a 2a 2f 0a 23 64 65 66   schema..*/.#def
0330: 69 6e 65 20 53 43 48 45 4d 41 20 5c 0a 22 43 52  ine SCHEMA \."CR
0340: 45 41 54 45 20 54 41 42 4c 45 20 78 28 22 20 20  EATE TABLE x("  
0350: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0360: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0370: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0380: 20 20 20 20 20 20 20 20 20 20 5c 0a 20 20 22 64            \.  "d
0390: 61 74 61 62 61 73 65 2c 22 20 20 20 20 20 20 20  atabase,"       
03a0: 20 20 20 2f 2a 20 4e 61 6d 65 20 6f 66 20 64 61     /* Name of da
03b0: 74 61 62 61 73 65 20 28 69 2e 65 2e 20 6d 61 69  tabase (i.e. mai
03c0: 6e 2c 20 74 65 6d 70 20 65 74 63 2e 29 20 2a 2f  n, temp etc.) */
03d0: 20 20 20 20 20 20 20 20 20 5c 0a 20 20 22 74 61           \.  "ta
03e0: 62 6c 65 6e 61 6d 65 2c 22 20 20 20 20 20 20 20  blename,"       
03f0: 20 20 2f 2a 20 4e 61 6d 65 20 6f 66 20 74 61 62    /* Name of tab
0400: 6c 65 20 2a 2f 20 20 20 20 20 20 20 20 20 20 20  le */           
0410: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0420: 20 20 20 20 20 20 20 20 5c 0a 20 20 22 63 69 64          \.  "cid
0430: 2c 22 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,"              
0440: 20 2f 2a 20 43 6f 6c 75 6d 6e 20 6e 75 6d 62 65   /* Column numbe
0450: 72 20 28 66 72 6f 6d 20 6c 65 66 74 2d 74 6f 2d  r (from left-to-
0460: 72 69 67 68 74 2c 20 30 20 75 70 77 61 72 64 29  right, 0 upward)
0470: 20 2a 2f 20 20 20 20 5c 0a 20 20 22 6e 61 6d 65   */    \.  "name
0480: 2c 22 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,"              
0490: 2f 2a 20 43 6f 6c 75 6d 6e 20 6e 61 6d 65 20 2a  /* Column name *
04a0: 2f 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  /               
04b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
04c0: 20 20 20 20 20 20 5c 0a 20 20 22 74 79 70 65 2c        \.  "type,
04d0: 22 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  "              /
04e0: 2a 20 53 70 65 63 69 66 69 65 64 20 74 79 70 65  * Specified type
04f0: 20 28 69 2e 65 2e 20 56 41 52 43 48 41 52 28 33   (i.e. VARCHAR(3
0500: 32 29 29 20 2a 2f 20 20 20 20 20 20 20 20 20 20  2)) */          
0510: 20 20 20 20 20 5c 0a 20 20 22 6e 6f 74 5f 6e 75       \.  "not_nu
0520: 6c 6c 2c 22 20 20 20 20 20 20 20 20 20 20 2f 2a  ll,"          /*
0530: 20 42 6f 6f 6c 65 61 6e 2e 20 54 72 75 65 20 69   Boolean. True i
0540: 66 20 4e 4f 54 20 4e 55 4c 4c 20 77 61 73 20 73  f NOT NULL was s
0550: 70 65 63 69 66 69 65 64 20 2a 2f 20 20 20 20 20  pecified */     
0560: 20 20 20 20 5c 0a 20 20 22 64 66 6c 74 5f 76 61      \.  "dflt_va
0570: 6c 75 65 2c 22 20 20 20 20 20 20 20 20 2f 2a 20  lue,"        /* 
0580: 44 65 66 61 75 6c 74 20 76 61 6c 75 65 20 66 6f  Default value fo
0590: 72 20 74 68 69 73 20 63 6f 6c 75 6d 6e 20 2a 2f  r this column */
05a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
05b0: 20 20 20 5c 0a 20 20 22 70 6b 22 20 20 20 20 20     \.  "pk"     
05c0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54              /* T
05d0: 72 75 65 20 69 66 20 74 68 69 73 20 63 6f 6c 75  rue if this colu
05e0: 6d 6e 20 69 73 20 70 61 72 74 20 6f 66 20 74 68  mn is part of th
05f0: 65 20 70 72 69 6d 61 72 79 20 6b 65 79 20 2a 2f  e primary key */
0600: 20 20 5c 0a 22 29 22 0a 0a 2f 2a 20 49 66 20 53    \.")"../* If S
0610: 51 4c 49 54 45 5f 54 45 53 54 20 69 73 20 64 65  QLITE_TEST is de
0620: 66 69 6e 65 64 20 74 68 69 73 20 63 6f 64 65 20  fined this code 
0630: 69 73 20 70 72 65 70 72 6f 63 65 73 73 65 64 20  is preprocessed 
0640: 66 6f 72 20 75 73 65 20 61 73 20 70 61 72 74 0a  for use as part.
0650: 2a 2a 20 6f 66 20 74 68 65 20 73 71 6c 69 74 65  ** of the sqlite
0660: 20 74 65 73 74 20 62 69 6e 61 72 79 20 22 74 65   test binary "te
0670: 73 74 66 69 78 74 75 72 65 22 2e 20 4f 74 68 65  stfixture". Othe
0680: 72 77 69 73 65 20 69 74 20 69 73 20 70 72 65 70  rwise it is prep
0690: 72 6f 63 65 73 73 65 64 0a 2a 2a 20 74 6f 20 62  rocessed.** to b
06a0: 65 20 63 6f 6d 70 69 6c 65 64 20 69 6e 74 6f 20  e compiled into 
06b0: 61 6e 20 73 71 6c 69 74 65 20 64 79 6e 61 6d 69  an sqlite dynami
06c0: 63 20 65 78 74 65 6e 73 69 6f 6e 2e 0a 2a 2f 0a  c extension..*/.
06d0: 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 54 45  #ifdef SQLITE_TE
06e0: 53 54 0a 20 20 23 69 6e 63 6c 75 64 65 20 22 73  ST.  #include "s
06f0: 71 6c 69 74 65 49 6e 74 2e 68 22 0a 20 20 23 69  qliteInt.h".  #i
0700: 6e 63 6c 75 64 65 20 22 74 63 6c 2e 68 22 0a 20  nclude "tcl.h". 
0710: 20 23 64 65 66 69 6e 65 20 4d 41 4c 4c 4f 43 28   #define MALLOC(
0720: 78 29 20 73 71 6c 69 74 65 4d 61 6c 6c 6f 63 52  x) sqliteMallocR
0730: 61 77 28 78 29 20 0a 20 20 23 64 65 66 69 6e 65  aw(x) .  #define
0740: 20 46 52 45 45 28 78 29 20 20 20 73 71 6c 69 74   FREE(x)   sqlit
0750: 65 46 72 65 65 28 78 29 0a 23 65 6c 73 65 0a 20  eFree(x).#else. 
0760: 20 23 69 6e 63 6c 75 64 65 20 22 73 71 6c 69 74   #include "sqlit
0770: 65 33 65 78 74 2e 68 22 0a 20 20 53 51 4c 49 54  e3ext.h".  SQLIT
0780: 45 5f 45 58 54 45 4e 53 49 4f 4e 5f 49 4e 49 54  E_EXTENSION_INIT
0790: 31 0a 20 20 23 64 65 66 69 6e 65 20 4d 41 4c 4c  1.  #define MALL
07a0: 4f 43 28 78 29 20 6d 61 6c 6c 6f 63 28 78 29 20  OC(x) malloc(x) 
07b0: 0a 20 20 23 64 65 66 69 6e 65 20 46 52 45 45 28  .  #define FREE(
07c0: 78 29 20 20 20 66 72 65 65 28 78 29 0a 23 65 6e  x)   free(x).#en
07d0: 64 69 66 0a 0a 23 69 6e 63 6c 75 64 65 20 3c 73  dif..#include <s
07e0: 74 64 6c 69 62 2e 68 3e 0a 23 69 6e 63 6c 75 64  tdlib.h>.#includ
07f0: 65 20 3c 73 74 72 69 6e 67 2e 68 3e 0a 23 69 6e  e <string.h>.#in
0800: 63 6c 75 64 65 20 3c 61 73 73 65 72 74 2e 68 3e  clude <assert.h>
0810: 0a 0a 74 79 70 65 64 65 66 20 73 74 72 75 63 74  ..typedef struct
0820: 20 73 63 68 65 6d 61 5f 76 74 61 62 20 73 63 68   schema_vtab sch
0830: 65 6d 61 5f 76 74 61 62 3b 0a 74 79 70 65 64 65  ema_vtab;.typede
0840: 66 20 73 74 72 75 63 74 20 73 63 68 65 6d 61 5f  f struct schema_
0850: 63 75 72 73 6f 72 20 73 63 68 65 6d 61 5f 63 75  cursor schema_cu
0860: 72 73 6f 72 3b 0a 0a 2f 2a 20 41 20 73 63 68 65  rsor;../* A sche
0870: 6d 61 20 74 61 62 6c 65 20 6f 62 6a 65 63 74 20  ma table object 
0880: 2a 2f 0a 73 74 72 75 63 74 20 73 63 68 65 6d 61  */.struct schema
0890: 5f 76 74 61 62 20 7b 0a 20 20 73 71 6c 69 74 65  _vtab {.  sqlite
08a0: 33 5f 76 74 61 62 20 62 61 73 65 3b 0a 20 20 73  3_vtab base;.  s
08b0: 71 6c 69 74 65 33 20 2a 64 62 3b 0a 7d 3b 0a 0a  qlite3 *db;.};..
08c0: 2f 2a 20 41 20 73 63 68 65 6d 61 20 74 61 62 6c  /* A schema tabl
08d0: 65 20 63 75 72 73 6f 72 20 6f 62 6a 65 63 74 20  e cursor object 
08e0: 2a 2f 0a 73 74 72 75 63 74 20 73 63 68 65 6d 61  */.struct schema
08f0: 5f 63 75 72 73 6f 72 20 7b 0a 20 20 73 71 6c 69  _cursor {.  sqli
0900: 74 65 33 5f 76 74 61 62 5f 63 75 72 73 6f 72 20  te3_vtab_cursor 
0910: 62 61 73 65 3b 0a 20 20 73 71 6c 69 74 65 33 5f  base;.  sqlite3_
0920: 73 74 6d 74 20 2a 70 44 62 4c 69 73 74 3b 0a 20  stmt *pDbList;. 
0930: 20 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70   sqlite3_stmt *p
0940: 54 61 62 6c 65 4c 69 73 74 3b 0a 20 20 73 71 6c  TableList;.  sql
0950: 69 74 65 33 5f 73 74 6d 74 20 2a 70 43 6f 6c 75  ite3_stmt *pColu
0960: 6d 6e 4c 69 73 74 3b 0a 20 20 69 6e 74 20 72 6f  mnList;.  int ro
0970: 77 69 64 3b 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20 54  wid;.};../*.** T
0980: 61 62 6c 65 20 64 65 73 74 72 75 63 74 6f 72 20  able destructor 
0990: 66 6f 72 20 74 68 65 20 73 63 68 65 6d 61 20 6d  for the schema m
09a0: 6f 64 75 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63  odule..*/.static
09b0: 20 69 6e 74 20 73 63 68 65 6d 61 44 65 73 74 72   int schemaDestr
09c0: 6f 79 28 73 71 6c 69 74 65 33 5f 76 74 61 62 20  oy(sqlite3_vtab 
09d0: 2a 70 56 74 61 62 29 7b 0a 20 20 46 52 45 45 28  *pVtab){.  FREE(
09e0: 70 56 74 61 62 29 3b 0a 20 20 72 65 74 75 72 6e  pVtab);.  return
09f0: 20 30 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 61 62   0;.}../*.** Tab
0a00: 6c 65 20 63 6f 6e 73 74 72 75 63 74 6f 72 20 66  le constructor f
0a10: 6f 72 20 74 68 65 20 73 63 68 65 6d 61 20 6d 6f  or the schema mo
0a20: 64 75 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  dule..*/.static 
0a30: 69 6e 74 20 73 63 68 65 6d 61 43 72 65 61 74 65  int schemaCreate
0a40: 28 0a 20 20 73 71 6c 69 74 65 33 20 2a 64 62 2c  (.  sqlite3 *db,
0a50: 0a 20 20 76 6f 69 64 20 2a 70 41 75 78 2c 0a 20  .  void *pAux,. 
0a60: 20 69 6e 74 20 61 72 67 63 2c 20 63 6f 6e 73 74   int argc, const
0a70: 20 63 68 61 72 20 2a 63 6f 6e 73 74 2a 61 72 67   char *const*arg
0a80: 76 2c 0a 20 20 73 71 6c 69 74 65 33 5f 76 74 61  v,.  sqlite3_vta
0a90: 62 20 2a 2a 70 70 56 74 61 62 2c 0a 20 20 63 68  b **ppVtab,.  ch
0aa0: 61 72 20 2a 2a 70 7a 45 72 72 0a 29 7b 0a 20 20  ar **pzErr.){.  
0ab0: 69 6e 74 20 72 63 20 3d 20 53 51 4c 49 54 45 5f  int rc = SQLITE_
0ac0: 4e 4f 4d 45 4d 3b 0a 20 20 73 63 68 65 6d 61 5f  NOMEM;.  schema_
0ad0: 76 74 61 62 20 2a 70 56 74 61 62 20 3d 20 4d 41  vtab *pVtab = MA
0ae0: 4c 4c 4f 43 28 73 69 7a 65 6f 66 28 73 63 68 65  LLOC(sizeof(sche
0af0: 6d 61 5f 76 74 61 62 29 29 3b 0a 20 20 69 66 28  ma_vtab));.  if(
0b00: 20 70 56 74 61 62 20 29 7b 0a 20 20 20 20 6d 65   pVtab ){.    me
0b10: 6d 73 65 74 28 70 56 74 61 62 2c 20 30 2c 20 73  mset(pVtab, 0, s
0b20: 69 7a 65 6f 66 28 73 63 68 65 6d 61 5f 76 74 61  izeof(schema_vta
0b30: 62 29 29 3b 0a 20 20 20 20 70 56 74 61 62 2d 3e  b));.    pVtab->
0b40: 64 62 20 3d 20 64 62 3b 0a 23 69 66 6e 64 65 66  db = db;.#ifndef
0b50: 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 56 49 52   SQLITE_OMIT_VIR
0b60: 54 55 41 4c 54 41 42 4c 45 0a 20 20 20 20 72 63  TUALTABLE.    rc
0b70: 20 3d 20 73 71 6c 69 74 65 33 5f 64 65 63 6c 61   = sqlite3_decla
0b80: 72 65 5f 76 74 61 62 28 64 62 2c 20 53 43 48 45  re_vtab(db, SCHE
0b90: 4d 41 29 3b 0a 23 65 6e 64 69 66 0a 20 20 7d 0a  MA);.#endif.  }.
0ba0: 20 20 2a 70 70 56 74 61 62 20 3d 20 28 73 71 6c    *ppVtab = (sql
0bb0: 69 74 65 33 5f 76 74 61 62 20 2a 29 70 56 74 61  ite3_vtab *)pVta
0bc0: 62 3b 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a  b;.  return rc;.
0bd0: 7d 0a 0a 2f 2a 0a 2a 2a 20 4f 70 65 6e 20 61 20  }../*.** Open a 
0be0: 6e 65 77 20 63 75 72 73 6f 72 20 6f 6e 20 74 68  new cursor on th
0bf0: 65 20 73 63 68 65 6d 61 20 74 61 62 6c 65 2e 0a  e schema table..
0c00: 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 73 63  */.static int sc
0c10: 68 65 6d 61 4f 70 65 6e 28 73 71 6c 69 74 65 33  hemaOpen(sqlite3
0c20: 5f 76 74 61 62 20 2a 70 56 54 61 62 2c 20 73 71  _vtab *pVTab, sq
0c30: 6c 69 74 65 33 5f 76 74 61 62 5f 63 75 72 73 6f  lite3_vtab_curso
0c40: 72 20 2a 2a 70 70 43 75 72 73 6f 72 29 7b 0a 20  r **ppCursor){. 
0c50: 20 69 6e 74 20 72 63 20 3d 20 53 51 4c 49 54 45   int rc = SQLITE
0c60: 5f 4e 4f 4d 45 4d 3b 0a 20 20 73 63 68 65 6d 61  _NOMEM;.  schema
0c70: 5f 63 75 72 73 6f 72 20 2a 70 43 75 72 3b 0a 20  _cursor *pCur;. 
0c80: 20 70 43 75 72 20 3d 20 4d 41 4c 4c 4f 43 28 73   pCur = MALLOC(s
0c90: 69 7a 65 6f 66 28 73 63 68 65 6d 61 5f 63 75 72  izeof(schema_cur
0ca0: 73 6f 72 29 29 3b 0a 20 20 69 66 28 20 70 43 75  sor));.  if( pCu
0cb0: 72 20 29 7b 0a 20 20 20 20 6d 65 6d 73 65 74 28  r ){.    memset(
0cc0: 70 43 75 72 2c 20 30 2c 20 73 69 7a 65 6f 66 28  pCur, 0, sizeof(
0cd0: 73 63 68 65 6d 61 5f 63 75 72 73 6f 72 29 29 3b  schema_cursor));
0ce0: 0a 20 20 20 20 2a 70 70 43 75 72 73 6f 72 20 3d  .    *ppCursor =
0cf0: 20 28 73 71 6c 69 74 65 33 5f 76 74 61 62 5f 63   (sqlite3_vtab_c
0d00: 75 72 73 6f 72 20 2a 29 70 43 75 72 3b 0a 20 20  ursor *)pCur;.  
0d10: 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 4f 4b    rc = SQLITE_OK
0d20: 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 72  ;.  }.  return r
0d30: 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 6c 6f 73  c;.}../*.** Clos
0d40: 65 20 61 20 73 63 68 65 6d 61 20 74 61 62 6c 65  e a schema table
0d50: 20 63 75 72 73 6f 72 2e 0a 2a 2f 0a 73 74 61 74   cursor..*/.stat
0d60: 69 63 20 69 6e 74 20 73 63 68 65 6d 61 43 6c 6f  ic int schemaClo
0d70: 73 65 28 73 71 6c 69 74 65 33 5f 76 74 61 62 5f  se(sqlite3_vtab_
0d80: 63 75 72 73 6f 72 20 2a 63 75 72 29 7b 0a 20 20  cursor *cur){.  
0d90: 73 63 68 65 6d 61 5f 63 75 72 73 6f 72 20 2a 70  schema_cursor *p
0da0: 43 75 72 20 3d 20 28 73 63 68 65 6d 61 5f 63 75  Cur = (schema_cu
0db0: 72 73 6f 72 20 2a 29 63 75 72 3b 0a 20 20 73 71  rsor *)cur;.  sq
0dc0: 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70  lite3_finalize(p
0dd0: 43 75 72 2d 3e 70 44 62 4c 69 73 74 29 3b 0a 20  Cur->pDbList);. 
0de0: 20 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a   sqlite3_finaliz
0df0: 65 28 70 43 75 72 2d 3e 70 54 61 62 6c 65 4c 69  e(pCur->pTableLi
0e00: 73 74 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 66  st);.  sqlite3_f
0e10: 69 6e 61 6c 69 7a 65 28 70 43 75 72 2d 3e 70 43  inalize(pCur->pC
0e20: 6f 6c 75 6d 6e 4c 69 73 74 29 3b 0a 20 20 46 52  olumnList);.  FR
0e30: 45 45 28 70 43 75 72 29 3b 0a 20 20 72 65 74 75  EE(pCur);.  retu
0e40: 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a  rn SQLITE_OK;.}.
0e50: 0a 2f 2a 0a 2a 2a 20 52 65 74 72 69 65 76 65 20  ./*.** Retrieve 
0e60: 61 20 63 6f 6c 75 6d 6e 20 6f 66 20 64 61 74 61  a column of data
0e70: 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20  ..*/.static int 
0e80: 73 63 68 65 6d 61 43 6f 6c 75 6d 6e 28 73 71 6c  schemaColumn(sql
0e90: 69 74 65 33 5f 76 74 61 62 5f 63 75 72 73 6f 72  ite3_vtab_cursor
0ea0: 20 2a 63 75 72 2c 20 73 71 6c 69 74 65 33 5f 63   *cur, sqlite3_c
0eb0: 6f 6e 74 65 78 74 20 2a 63 74 78 2c 20 69 6e 74  ontext *ctx, int
0ec0: 20 69 29 7b 0a 20 20 73 63 68 65 6d 61 5f 63 75   i){.  schema_cu
0ed0: 72 73 6f 72 20 2a 70 43 75 72 20 3d 20 28 73 63  rsor *pCur = (sc
0ee0: 68 65 6d 61 5f 63 75 72 73 6f 72 20 2a 29 63 75  hema_cursor *)cu
0ef0: 72 3b 0a 20 20 73 77 69 74 63 68 28 20 69 20 29  r;.  switch( i )
0f00: 7b 0a 20 20 20 20 63 61 73 65 20 30 3a 0a 20 20  {.    case 0:.  
0f10: 20 20 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75      sqlite3_resu
0f20: 6c 74 5f 76 61 6c 75 65 28 63 74 78 2c 20 73 71  lt_value(ctx, sq
0f30: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 76 61 6c  lite3_column_val
0f40: 75 65 28 70 43 75 72 2d 3e 70 44 62 4c 69 73 74  ue(pCur->pDbList
0f50: 2c 20 31 29 29 3b 0a 20 20 20 20 20 20 62 72 65  , 1));.      bre
0f60: 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 31 3a 0a  ak;.    case 1:.
0f70: 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 72 65        sqlite3_re
0f80: 73 75 6c 74 5f 76 61 6c 75 65 28 63 74 78 2c 20  sult_value(ctx, 
0f90: 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 76  sqlite3_column_v
0fa0: 61 6c 75 65 28 70 43 75 72 2d 3e 70 54 61 62 6c  alue(pCur->pTabl
0fb0: 65 4c 69 73 74 2c 20 30 29 29 3b 0a 20 20 20 20  eList, 0));.    
0fc0: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 64 65 66    break;.    def
0fd0: 61 75 6c 74 3a 0a 20 20 20 20 20 20 73 71 6c 69  ault:.      sqli
0fe0: 74 65 33 5f 72 65 73 75 6c 74 5f 76 61 6c 75 65  te3_result_value
0ff0: 28 63 74 78 2c 20 73 71 6c 69 74 65 33 5f 63 6f  (ctx, sqlite3_co
1000: 6c 75 6d 6e 5f 76 61 6c 75 65 28 70 43 75 72 2d  lumn_value(pCur-
1010: 3e 70 43 6f 6c 75 6d 6e 4c 69 73 74 2c 20 69 2d  >pColumnList, i-
1020: 32 29 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b  2));.      break
1030: 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 53  ;.  }.  return S
1040: 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a  QLITE_OK;.}../*.
1050: 2a 2a 20 52 65 74 72 69 65 76 65 20 74 68 65 20  ** Retrieve the 
1060: 63 75 72 72 65 6e 74 20 72 6f 77 69 64 2e 0a 2a  current rowid..*
1070: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 73 63 68  /.static int sch
1080: 65 6d 61 52 6f 77 69 64 28 73 71 6c 69 74 65 33  emaRowid(sqlite3
1090: 5f 76 74 61 62 5f 63 75 72 73 6f 72 20 2a 63 75  _vtab_cursor *cu
10a0: 72 2c 20 73 71 6c 69 74 65 5f 69 6e 74 36 34 20  r, sqlite_int64 
10b0: 2a 70 52 6f 77 69 64 29 7b 0a 20 20 73 63 68 65  *pRowid){.  sche
10c0: 6d 61 5f 63 75 72 73 6f 72 20 2a 70 43 75 72 20  ma_cursor *pCur 
10d0: 3d 20 28 73 63 68 65 6d 61 5f 63 75 72 73 6f 72  = (schema_cursor
10e0: 20 2a 29 63 75 72 3b 0a 20 20 2a 70 52 6f 77 69   *)cur;.  *pRowi
10f0: 64 20 3d 20 70 43 75 72 2d 3e 72 6f 77 69 64 3b  d = pCur->rowid;
1100: 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45  .  return SQLITE
1110: 5f 4f 4b 3b 0a 7d 0a 0a 73 74 61 74 69 63 20 69  _OK;.}..static i
1120: 6e 74 20 66 69 6e 61 6c 69 7a 65 28 73 71 6c 69  nt finalize(sqli
1130: 74 65 33 5f 73 74 6d 74 20 2a 2a 70 70 53 74 6d  te3_stmt **ppStm
1140: 74 29 7b 0a 20 20 69 6e 74 20 72 63 20 3d 20 73  t){.  int rc = s
1150: 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28  qlite3_finalize(
1160: 2a 70 70 53 74 6d 74 29 3b 0a 20 20 2a 70 70 53  *ppStmt);.  *ppS
1170: 74 6d 74 20 3d 20 30 3b 0a 20 20 72 65 74 75 72  tmt = 0;.  retur
1180: 6e 20 72 63 3b 0a 7d 0a 0a 73 74 61 74 69 63 20  n rc;.}..static 
1190: 69 6e 74 20 73 63 68 65 6d 61 45 6f 66 28 73 71  int schemaEof(sq
11a0: 6c 69 74 65 33 5f 76 74 61 62 5f 63 75 72 73 6f  lite3_vtab_curso
11b0: 72 20 2a 63 75 72 29 7b 0a 20 20 73 63 68 65 6d  r *cur){.  schem
11c0: 61 5f 63 75 72 73 6f 72 20 2a 70 43 75 72 20 3d  a_cursor *pCur =
11d0: 20 28 73 63 68 65 6d 61 5f 63 75 72 73 6f 72 20   (schema_cursor 
11e0: 2a 29 63 75 72 3b 0a 20 20 72 65 74 75 72 6e 20  *)cur;.  return 
11f0: 28 70 43 75 72 2d 3e 70 44 62 4c 69 73 74 20 3f  (pCur->pDbList ?
1200: 20 30 20 3a 20 31 29 3b 0a 7d 0a 0a 2f 2a 0a 2a   0 : 1);.}../*.*
1210: 2a 20 41 64 76 61 6e 63 65 20 74 68 65 20 63 75  * Advance the cu
1220: 72 73 6f 72 20 74 6f 20 74 68 65 20 6e 65 78 74  rsor to the next
1230: 20 72 6f 77 2e 0a 2a 2f 0a 73 74 61 74 69 63 20   row..*/.static 
1240: 69 6e 74 20 73 63 68 65 6d 61 4e 65 78 74 28 73  int schemaNext(s
1250: 71 6c 69 74 65 33 5f 76 74 61 62 5f 63 75 72 73  qlite3_vtab_curs
1260: 6f 72 20 2a 63 75 72 29 7b 0a 20 20 69 6e 74 20  or *cur){.  int 
1270: 72 63 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a  rc = SQLITE_OK;.
1280: 20 20 73 63 68 65 6d 61 5f 63 75 72 73 6f 72 20    schema_cursor 
1290: 2a 70 43 75 72 20 3d 20 28 73 63 68 65 6d 61 5f  *pCur = (schema_
12a0: 63 75 72 73 6f 72 20 2a 29 63 75 72 3b 0a 20 20  cursor *)cur;.  
12b0: 73 63 68 65 6d 61 5f 76 74 61 62 20 2a 70 56 74  schema_vtab *pVt
12c0: 61 62 20 3d 20 28 73 63 68 65 6d 61 5f 76 74 61  ab = (schema_vta
12d0: 62 20 2a 29 28 63 75 72 2d 3e 70 56 74 61 62 29  b *)(cur->pVtab)
12e0: 3b 0a 20 20 63 68 61 72 20 2a 7a 53 71 6c 20 3d  ;.  char *zSql =
12f0: 20 30 3b 0a 0a 20 20 77 68 69 6c 65 28 20 21 70   0;..  while( !p
1300: 43 75 72 2d 3e 70 43 6f 6c 75 6d 6e 4c 69 73 74  Cur->pColumnList
1310: 20 7c 7c 20 53 51 4c 49 54 45 5f 52 4f 57 21 3d   || SQLITE_ROW!=
1320: 73 71 6c 69 74 65 33 5f 73 74 65 70 28 70 43 75  sqlite3_step(pCu
1330: 72 2d 3e 70 43 6f 6c 75 6d 6e 4c 69 73 74 29 20  r->pColumnList) 
1340: 29 7b 0a 20 20 20 20 69 66 28 20 53 51 4c 49 54  ){.    if( SQLIT
1350: 45 5f 4f 4b 21 3d 28 72 63 20 3d 20 66 69 6e 61  E_OK!=(rc = fina
1360: 6c 69 7a 65 28 26 70 43 75 72 2d 3e 70 43 6f 6c  lize(&pCur->pCol
1370: 75 6d 6e 4c 69 73 74 29 29 20 29 20 67 6f 74 6f  umnList)) ) goto
1380: 20 6e 65 78 74 5f 65 78 69 74 3b 0a 0a 20 20 20   next_exit;..   
1390: 20 77 68 69 6c 65 28 20 21 70 43 75 72 2d 3e 70   while( !pCur->p
13a0: 54 61 62 6c 65 4c 69 73 74 20 7c 7c 20 53 51 4c  TableList || SQL
13b0: 49 54 45 5f 52 4f 57 21 3d 73 71 6c 69 74 65 33  ITE_ROW!=sqlite3
13c0: 5f 73 74 65 70 28 70 43 75 72 2d 3e 70 54 61 62  _step(pCur->pTab
13d0: 6c 65 4c 69 73 74 29 20 29 7b 0a 20 20 20 20 20  leList) ){.     
13e0: 20 69 66 28 20 53 51 4c 49 54 45 5f 4f 4b 21 3d   if( SQLITE_OK!=
13f0: 28 72 63 20 3d 20 66 69 6e 61 6c 69 7a 65 28 26  (rc = finalize(&
1400: 70 43 75 72 2d 3e 70 54 61 62 6c 65 4c 69 73 74  pCur->pTableList
1410: 29 29 20 29 20 67 6f 74 6f 20 6e 65 78 74 5f 65  )) ) goto next_e
1420: 78 69 74 3b 0a 0a 20 20 20 20 20 20 61 73 73 65  xit;..      asse
1430: 72 74 28 70 43 75 72 2d 3e 70 44 62 4c 69 73 74  rt(pCur->pDbList
1440: 29 3b 0a 20 20 20 20 20 20 77 68 69 6c 65 28 20  );.      while( 
1450: 53 51 4c 49 54 45 5f 52 4f 57 21 3d 73 71 6c 69  SQLITE_ROW!=sqli
1460: 74 65 33 5f 73 74 65 70 28 70 43 75 72 2d 3e 70  te3_step(pCur->p
1470: 44 62 4c 69 73 74 29 20 29 7b 0a 20 20 20 20 20  DbList) ){.     
1480: 20 20 20 72 63 20 3d 20 66 69 6e 61 6c 69 7a 65     rc = finalize
1490: 28 26 70 43 75 72 2d 3e 70 44 62 4c 69 73 74 29  (&pCur->pDbList)
14a0: 3b 0a 20 20 20 20 20 20 20 20 67 6f 74 6f 20 6e  ;.        goto n
14b0: 65 78 74 5f 65 78 69 74 3b 0a 20 20 20 20 20 20  ext_exit;.      
14c0: 7d 0a 0a 20 20 20 20 20 20 2f 2a 20 53 65 74 20  }..      /* Set 
14d0: 7a 53 71 6c 20 74 6f 20 74 68 65 20 53 51 4c 20  zSql to the SQL 
14e0: 74 6f 20 70 75 6c 6c 20 74 68 65 20 6c 69 73 74  to pull the list
14f0: 20 6f 66 20 74 61 62 6c 65 73 20 66 72 6f 6d 20   of tables from 
1500: 74 68 65 20 0a 20 20 20 20 20 20 2a 2a 20 73 71  the .      ** sq
1510: 6c 69 74 65 5f 6d 61 73 74 65 72 20 28 6f 72 20  lite_master (or 
1520: 73 71 6c 69 74 65 5f 74 65 6d 70 5f 6d 61 73 74  sqlite_temp_mast
1530: 65 72 29 20 74 61 62 6c 65 20 6f 66 20 74 68 65  er) table of the
1540: 20 64 61 74 61 62 61 73 65 0a 20 20 20 20 20 20   database.      
1550: 2a 2a 20 69 64 65 6e 74 66 69 65 64 20 62 79 20  ** identfied by 
1560: 74 68 65 20 72 6f 77 20 70 6f 69 6e 74 65 64 20  the row pointed 
1570: 74 6f 20 62 79 20 74 68 65 20 53 51 4c 20 73 74  to by the SQL st
1580: 61 74 65 6d 65 6e 74 20 70 43 75 72 2d 3e 70 44  atement pCur->pD
1590: 62 4c 69 73 74 0a 20 20 20 20 20 20 2a 2a 20 28  bList.      ** (
15a0: 69 74 65 72 61 74 69 6e 67 20 74 68 72 6f 75 67  iterating throug
15b0: 68 20 61 20 22 50 52 41 47 4d 41 20 64 61 74 61  h a "PRAGMA data
15c0: 62 61 73 65 5f 6c 69 73 74 3b 22 20 73 74 61 74  base_list;" stat
15d0: 65 6d 65 6e 74 29 2e 0a 20 20 20 20 20 20 2a 2f  ement)..      */
15e0: 0a 20 20 20 20 20 20 69 66 28 20 73 71 6c 69 74  .      if( sqlit
15f0: 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 28 70 43  e3_column_int(pC
1600: 75 72 2d 3e 70 44 62 4c 69 73 74 2c 20 30 29 3d  ur->pDbList, 0)=
1610: 3d 31 20 29 7b 0a 20 20 20 20 20 20 20 20 7a 53  =1 ){.        zS
1620: 71 6c 20 3d 20 73 71 6c 69 74 65 33 5f 6d 70 72  ql = sqlite3_mpr
1630: 69 6e 74 66 28 0a 20 20 20 20 20 20 20 20 20 20  intf(.          
1640: 20 20 22 53 45 4c 45 43 54 20 6e 61 6d 65 20 46    "SELECT name F
1650: 52 4f 4d 20 73 71 6c 69 74 65 5f 74 65 6d 70 5f  ROM sqlite_temp_
1660: 6d 61 73 74 65 72 20 57 48 45 52 45 20 74 79 70  master WHERE typ
1670: 65 3d 27 74 61 62 6c 65 27 22 0a 20 20 20 20 20  e='table'".     
1680: 20 20 20 29 3b 0a 20 20 20 20 20 20 7d 65 6c 73     );.      }els
1690: 65 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  e{.        sqlit
16a0: 65 33 5f 73 74 6d 74 20 2a 70 44 62 4c 69 73 74  e3_stmt *pDbList
16b0: 20 3d 20 70 43 75 72 2d 3e 70 44 62 4c 69 73 74   = pCur->pDbList
16c0: 3b 0a 20 20 20 20 20 20 20 20 7a 53 71 6c 20 3d  ;.        zSql =
16d0: 20 73 71 6c 69 74 65 33 5f 6d 70 72 69 6e 74 66   sqlite3_mprintf
16e0: 28 0a 20 20 20 20 20 20 20 20 20 20 20 20 22 53  (.            "S
16f0: 45 4c 45 43 54 20 6e 61 6d 65 20 46 52 4f 4d 20  ELECT name FROM 
1700: 25 51 2e 73 71 6c 69 74 65 5f 6d 61 73 74 65 72  %Q.sqlite_master
1710: 20 57 48 45 52 45 20 74 79 70 65 3d 27 74 61 62   WHERE type='tab
1720: 6c 65 27 22 2c 0a 20 20 20 20 20 20 20 20 20 20  le'",.          
1730: 20 20 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d     sqlite3_colum
1740: 6e 5f 74 65 78 74 28 70 44 62 4c 69 73 74 2c 20  n_text(pDbList, 
1750: 31 29 0a 20 20 20 20 20 20 20 20 29 3b 0a 20 20  1).        );.  
1760: 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20      }.      if( 
1770: 21 7a 53 71 6c 20 29 7b 0a 20 20 20 20 20 20 20  !zSql ){.       
1780: 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 4e 4f 4d   rc = SQLITE_NOM
1790: 45 4d 3b 0a 20 20 20 20 20 20 20 20 67 6f 74 6f  EM;.        goto
17a0: 20 6e 65 78 74 5f 65 78 69 74 3b 0a 20 20 20 20   next_exit;.    
17b0: 20 20 7d 0a 0a 20 20 20 20 20 20 72 63 20 3d 20    }..      rc = 
17c0: 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 28  sqlite3_prepare(
17d0: 70 56 74 61 62 2d 3e 64 62 2c 20 7a 53 71 6c 2c  pVtab->db, zSql,
17e0: 20 2d 31 2c 20 26 70 43 75 72 2d 3e 70 54 61 62   -1, &pCur->pTab
17f0: 6c 65 4c 69 73 74 2c 20 30 29 3b 0a 20 20 20 20  leList, 0);.    
1800: 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 7a    sqlite3_free(z
1810: 53 71 6c 29 3b 0a 20 20 20 20 20 20 69 66 28 20  Sql);.      if( 
1820: 72 63 21 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 20  rc!=SQLITE_OK ) 
1830: 67 6f 74 6f 20 6e 65 78 74 5f 65 78 69 74 3b 0a  goto next_exit;.
1840: 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 20 53 65      }..    /* Se
1850: 74 20 7a 53 71 6c 20 74 6f 20 74 68 65 20 53 51  t zSql to the SQ
1860: 4c 20 74 6f 20 74 68 65 20 74 61 62 6c 65 5f 69  L to the table_i
1870: 6e 66 6f 20 70 72 61 67 6d 61 20 66 6f 72 20 74  nfo pragma for t
1880: 68 65 20 74 61 62 6c 65 20 63 75 72 72 65 6e 74  he table current
1890: 6c 79 0a 20 20 20 20 2a 2a 20 69 64 65 6e 74 69  ly.    ** identi
18a0: 66 69 65 64 20 62 79 20 74 68 65 20 72 6f 77 73  fied by the rows
18b0: 20 70 6f 69 6e 74 65 64 20 74 6f 20 62 79 20 73   pointed to by s
18c0: 74 61 74 65 6d 65 6e 74 73 20 70 43 75 72 2d 3e  tatements pCur->
18d0: 70 44 62 4c 69 73 74 20 61 6e 64 0a 20 20 20 20  pDbList and.    
18e0: 2a 2a 20 70 43 75 72 2d 3e 70 54 61 62 6c 65 4c  ** pCur->pTableL
18f0: 69 73 74 2e 0a 20 20 20 20 2a 2f 0a 20 20 20 20  ist..    */.    
1900: 7a 53 71 6c 20 3d 20 73 71 6c 69 74 65 33 5f 6d  zSql = sqlite3_m
1910: 70 72 69 6e 74 66 28 22 50 52 41 47 4d 41 20 25  printf("PRAGMA %
1920: 51 2e 74 61 62 6c 65 5f 69 6e 66 6f 28 25 51 29  Q.table_info(%Q)
1930: 22 2c 20 0a 20 20 20 20 20 20 20 20 73 71 6c 69  ", .        sqli
1940: 74 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 28  te3_column_text(
1950: 70 43 75 72 2d 3e 70 44 62 4c 69 73 74 2c 20 31  pCur->pDbList, 1
1960: 29 2c 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  ),.        sqlit
1970: 65 33 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 28 70  e3_column_text(p
1980: 43 75 72 2d 3e 70 54 61 62 6c 65 4c 69 73 74 2c  Cur->pTableList,
1990: 20 30 29 0a 20 20 20 20 29 3b 0a 0a 20 20 20 20   0).    );..    
19a0: 69 66 28 20 21 7a 53 71 6c 20 29 7b 0a 20 20 20  if( !zSql ){.   
19b0: 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 4e     rc = SQLITE_N
19c0: 4f 4d 45 4d 3b 0a 20 20 20 20 20 20 67 6f 74 6f  OMEM;.      goto
19d0: 20 6e 65 78 74 5f 65 78 69 74 3b 0a 20 20 20 20   next_exit;.    
19e0: 7d 0a 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74  }.    rc = sqlit
19f0: 65 33 5f 70 72 65 70 61 72 65 28 70 56 74 61 62  e3_prepare(pVtab
1a00: 2d 3e 64 62 2c 20 7a 53 71 6c 2c 20 2d 31 2c 20  ->db, zSql, -1, 
1a10: 26 70 43 75 72 2d 3e 70 43 6f 6c 75 6d 6e 4c 69  &pCur->pColumnLi
1a20: 73 74 2c 20 30 29 3b 0a 20 20 20 20 73 71 6c 69  st, 0);.    sqli
1a30: 74 65 33 5f 66 72 65 65 28 7a 53 71 6c 29 3b 0a  te3_free(zSql);.
1a40: 20 20 20 20 69 66 28 20 72 63 21 3d 53 51 4c 49      if( rc!=SQLI
1a50: 54 45 5f 4f 4b 20 29 20 67 6f 74 6f 20 6e 65 78  TE_OK ) goto nex
1a60: 74 5f 65 78 69 74 3b 0a 20 20 7d 0a 20 20 70 43  t_exit;.  }.  pC
1a70: 75 72 2d 3e 72 6f 77 69 64 2b 2b 3b 0a 0a 6e 65  ur->rowid++;..ne
1a80: 78 74 5f 65 78 69 74 3a 0a 20 20 2f 2a 20 54 4f  xt_exit:.  /* TO
1a90: 44 4f 3a 20 48 61 6e 64 6c 65 20 72 63 20 2a 2f  DO: Handle rc */
1aa0: 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a  .  return rc;.}.
1ab0: 0a 2f 2a 0a 2a 2a 20 52 65 73 65 74 20 61 20 73  ./*.** Reset a s
1ac0: 63 68 65 6d 61 20 74 61 62 6c 65 20 63 75 72 73  chema table curs
1ad0: 6f 72 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e  or..*/.static in
1ae0: 74 20 73 63 68 65 6d 61 46 69 6c 74 65 72 28 0a  t schemaFilter(.
1af0: 20 20 73 71 6c 69 74 65 33 5f 76 74 61 62 5f 63    sqlite3_vtab_c
1b00: 75 72 73 6f 72 20 2a 70 56 74 61 62 43 75 72 73  ursor *pVtabCurs
1b10: 6f 72 2c 20 0a 20 20 69 6e 74 20 69 64 78 4e 75  or, .  int idxNu
1b20: 6d 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 69  m, const char *i
1b30: 64 78 53 74 72 2c 0a 20 20 69 6e 74 20 61 72 67  dxStr,.  int arg
1b40: 63 2c 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65  c, sqlite3_value
1b50: 20 2a 2a 61 72 67 76 0a 29 7b 0a 20 20 69 6e 74   **argv.){.  int
1b60: 20 72 63 3b 0a 20 20 73 63 68 65 6d 61 5f 76 74   rc;.  schema_vt
1b70: 61 62 20 2a 70 56 74 61 62 20 3d 20 28 73 63 68  ab *pVtab = (sch
1b80: 65 6d 61 5f 76 74 61 62 20 2a 29 28 70 56 74 61  ema_vtab *)(pVta
1b90: 62 43 75 72 73 6f 72 2d 3e 70 56 74 61 62 29 3b  bCursor->pVtab);
1ba0: 0a 20 20 73 63 68 65 6d 61 5f 63 75 72 73 6f 72  .  schema_cursor
1bb0: 20 2a 70 43 75 72 20 3d 20 28 73 63 68 65 6d 61   *pCur = (schema
1bc0: 5f 63 75 72 73 6f 72 20 2a 29 70 56 74 61 62 43  _cursor *)pVtabC
1bd0: 75 72 73 6f 72 3b 0a 20 20 70 43 75 72 2d 3e 72  ursor;.  pCur->r
1be0: 6f 77 69 64 20 3d 20 30 3b 0a 20 20 66 69 6e 61  owid = 0;.  fina
1bf0: 6c 69 7a 65 28 26 70 43 75 72 2d 3e 70 54 61 62  lize(&pCur->pTab
1c00: 6c 65 4c 69 73 74 29 3b 0a 20 20 66 69 6e 61 6c  leList);.  final
1c10: 69 7a 65 28 26 70 43 75 72 2d 3e 70 43 6f 6c 75  ize(&pCur->pColu
1c20: 6d 6e 4c 69 73 74 29 3b 0a 20 20 66 69 6e 61 6c  mnList);.  final
1c30: 69 7a 65 28 26 70 43 75 72 2d 3e 70 44 62 4c 69  ize(&pCur->pDbLi
1c40: 73 74 29 3b 0a 20 20 72 63 20 3d 20 73 71 6c 69  st);.  rc = sqli
1c50: 74 65 33 5f 70 72 65 70 61 72 65 28 70 56 74 61  te3_prepare(pVta
1c60: 62 2d 3e 64 62 2c 22 50 52 41 47 4d 41 20 64 61  b->db,"PRAGMA da
1c70: 74 61 62 61 73 65 5f 6c 69 73 74 22 2c 20 2d 31  tabase_list", -1
1c80: 2c 20 26 70 43 75 72 2d 3e 70 44 62 4c 69 73 74  , &pCur->pDbList
1c90: 2c 20 30 29 3b 0a 20 20 72 65 74 75 72 6e 20 28  , 0);.  return (
1ca0: 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 3f 20  rc==SQLITE_OK ? 
1cb0: 73 63 68 65 6d 61 4e 65 78 74 28 70 56 74 61 62  schemaNext(pVtab
1cc0: 43 75 72 73 6f 72 29 20 3a 20 72 63 29 3b 0a 7d  Cursor) : rc);.}
1cd0: 0a 0a 2f 2a 0a 2a 2a 20 41 6e 61 6c 79 73 65 20  ../*.** Analyse 
1ce0: 74 68 65 20 57 48 45 52 45 20 63 6f 6e 64 69 74  the WHERE condit
1cf0: 69 6f 6e 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69  ion..*/.static i
1d00: 6e 74 20 73 63 68 65 6d 61 42 65 73 74 49 6e 64  nt schemaBestInd
1d10: 65 78 28 73 71 6c 69 74 65 33 5f 76 74 61 62 20  ex(sqlite3_vtab 
1d20: 2a 74 61 62 2c 20 73 71 6c 69 74 65 33 5f 69 6e  *tab, sqlite3_in
1d30: 64 65 78 5f 69 6e 66 6f 20 2a 70 49 64 78 49 6e  dex_info *pIdxIn
1d40: 66 6f 29 7b 0a 20 20 72 65 74 75 72 6e 20 53 51  fo){.  return SQ
1d50: 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a  LITE_OK;.}../*.*
1d60: 2a 20 41 20 76 69 72 74 75 61 6c 20 74 61 62 6c  * A virtual tabl
1d70: 65 20 6d 6f 64 75 6c 65 20 74 68 61 74 20 6d 65  e module that me
1d80: 72 65 6c 79 20 65 63 68 6f 73 20 6d 65 74 68 6f  rely echos metho
1d90: 64 20 63 61 6c 6c 73 20 69 6e 74 6f 20 54 43 4c  d calls into TCL
1da0: 0a 2a 2a 20 76 61 72 69 61 62 6c 65 73 2e 0a 2a  .** variables..*
1db0: 2f 0a 73 74 61 74 69 63 20 73 71 6c 69 74 65 33  /.static sqlite3
1dc0: 5f 6d 6f 64 75 6c 65 20 73 63 68 65 6d 61 4d 6f  _module schemaMo
1dd0: 64 75 6c 65 20 3d 20 7b 0a 20 20 30 2c 20 20 20  dule = {.  0,   
1de0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1df0: 20 20 20 20 20 20 20 20 2f 2a 20 69 56 65 72 73          /* iVers
1e00: 69 6f 6e 20 2a 2f 0a 20 20 73 63 68 65 6d 61 43  ion */.  schemaC
1e10: 72 65 61 74 65 2c 0a 20 20 73 63 68 65 6d 61 43  reate,.  schemaC
1e20: 72 65 61 74 65 2c 0a 20 20 73 63 68 65 6d 61 42  reate,.  schemaB
1e30: 65 73 74 49 6e 64 65 78 2c 0a 20 20 73 63 68 65  estIndex,.  sche
1e40: 6d 61 44 65 73 74 72 6f 79 2c 0a 20 20 73 63 68  maDestroy,.  sch
1e50: 65 6d 61 44 65 73 74 72 6f 79 2c 0a 20 20 73 63  emaDestroy,.  sc
1e60: 68 65 6d 61 4f 70 65 6e 2c 20 20 20 20 20 20 20  hemaOpen,       
1e70: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 4f             /* xO
1e80: 70 65 6e 20 2d 20 6f 70 65 6e 20 61 20 63 75 72  pen - open a cur
1e90: 73 6f 72 20 2a 2f 0a 20 20 73 63 68 65 6d 61 43  sor */.  schemaC
1ea0: 6c 6f 73 65 2c 20 20 20 20 20 20 20 20 20 20 20  lose,           
1eb0: 20 20 20 20 20 20 2f 2a 20 78 43 6c 6f 73 65 20        /* xClose 
1ec0: 2d 20 63 6c 6f 73 65 20 61 20 63 75 72 73 6f 72  - close a cursor
1ed0: 20 2a 2f 0a 20 20 73 63 68 65 6d 61 46 69 6c 74   */.  schemaFilt
1ee0: 65 72 2c 20 20 20 20 20 20 20 20 20 20 20 20 20  er,             
1ef0: 20 20 20 2f 2a 20 78 46 69 6c 74 65 72 20 2d 20     /* xFilter - 
1f00: 63 6f 6e 66 69 67 75 72 65 20 73 63 61 6e 20 63  configure scan c
1f10: 6f 6e 73 74 72 61 69 6e 74 73 20 2a 2f 0a 20 20  onstraints */.  
1f20: 73 63 68 65 6d 61 4e 65 78 74 2c 20 20 20 20 20  schemaNext,     
1f30: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
1f40: 78 4e 65 78 74 20 2d 20 61 64 76 61 6e 63 65 20  xNext - advance 
1f50: 61 20 63 75 72 73 6f 72 20 2a 2f 0a 20 20 73 63  a cursor */.  sc
1f60: 68 65 6d 61 45 6f 66 2c 20 20 20 20 20 20 20 20  hemaEof,        
1f70: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 45             /* xE
1f80: 6f 66 20 2a 2f 0a 20 20 73 63 68 65 6d 61 43 6f  of */.  schemaCo
1f90: 6c 75 6d 6e 2c 20 20 20 20 20 20 20 20 20 20 20  lumn,           
1fa0: 20 20 20 20 20 2f 2a 20 78 43 6f 6c 75 6d 6e 20       /* xColumn 
1fb0: 2d 20 72 65 61 64 20 64 61 74 61 20 2a 2f 0a 20  - read data */. 
1fc0: 20 73 63 68 65 6d 61 52 6f 77 69 64 2c 20 20 20   schemaRowid,   
1fd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
1fe0: 20 78 52 6f 77 69 64 20 2d 20 72 65 61 64 20 64   xRowid - read d
1ff0: 61 74 61 20 2a 2f 0a 20 20 30 2c 20 20 20 20 20  ata */.  0,     
2000: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2010: 20 20 20 20 20 20 2f 2a 20 78 55 70 64 61 74 65        /* xUpdate
2020: 20 2a 2f 0a 20 20 30 2c 20 20 20 20 20 20 20 20   */.  0,        
2030: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2040: 20 20 20 2f 2a 20 78 42 65 67 69 6e 20 2a 2f 0a     /* xBegin */.
2050: 20 20 30 2c 20 20 20 20 20 20 20 20 20 20 20 20    0,            
2060: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
2070: 2a 20 78 53 79 6e 63 20 2a 2f 0a 20 20 30 2c 20  * xSync */.  0, 
2080: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2090: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 43 6f            /* xCo
20a0: 6d 6d 69 74 20 2a 2f 0a 20 20 30 2c 20 20 20 20  mmit */.  0,    
20b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
20c0: 20 20 20 20 20 20 20 2f 2a 20 78 52 6f 6c 6c 62         /* xRollb
20d0: 61 63 6b 20 2a 2f 0a 20 20 30 2c 20 20 20 20 20  ack */.  0,     
20e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
20f0: 20 20 20 20 20 20 2f 2a 20 78 46 69 6e 64 4d 65        /* xFindMe
2100: 74 68 6f 64 20 2a 2f 0a 7d 3b 0a 0a 0a 23 69 66  thod */.};...#if
2110: 64 65 66 20 53 51 4c 49 54 45 5f 54 45 53 54 0a  def SQLITE_TEST.
2120: 0a 2f 2a 0a 2a 2a 20 44 65 63 6f 64 65 20 61 20  ./*.** Decode a 
2130: 70 6f 69 6e 74 65 72 20 74 6f 20 61 6e 20 73 71  pointer to an sq
2140: 6c 69 74 65 33 20 6f 62 6a 65 63 74 2e 0a 2a 2f  lite3 object..*/
2150: 0a 73 74 61 74 69 63 20 69 6e 74 20 67 65 74 44  .static int getD
2160: 62 50 6f 69 6e 74 65 72 28 54 63 6c 5f 49 6e 74  bPointer(Tcl_Int
2170: 65 72 70 20 2a 69 6e 74 65 72 70 2c 20 63 6f 6e  erp *interp, con
2180: 73 74 20 63 68 61 72 20 2a 7a 41 2c 20 73 71 6c  st char *zA, sql
2190: 69 74 65 33 20 2a 2a 70 70 44 62 29 7b 0a 20 20  ite3 **ppDb){.  
21a0: 2a 70 70 44 62 20 3d 20 28 73 71 6c 69 74 65 33  *ppDb = (sqlite3
21b0: 2a 29 73 71 6c 69 74 65 33 54 65 78 74 54 6f 50  *)sqlite3TextToP
21c0: 74 72 28 7a 41 29 3b 0a 20 20 72 65 74 75 72 6e  tr(zA);.  return
21d0: 20 54 43 4c 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a   TCL_OK;.}../*.*
21e0: 2a 20 52 65 67 69 73 74 65 72 20 74 68 65 20 73  * Register the s
21f0: 63 68 65 6d 61 20 76 69 72 74 75 61 6c 20 74 61  chema virtual ta
2200: 62 6c 65 20 6d 6f 64 75 6c 65 2e 0a 2a 2f 0a 73  ble module..*/.s
2210: 74 61 74 69 63 20 69 6e 74 20 72 65 67 69 73 74  tatic int regist
2220: 65 72 5f 73 63 68 65 6d 61 5f 6d 6f 64 75 6c 65  er_schema_module
2230: 28 0a 20 20 43 6c 69 65 6e 74 44 61 74 61 20 63  (.  ClientData c
2240: 6c 69 65 6e 74 44 61 74 61 2c 20 2f 2a 20 4e 6f  lientData, /* No
2250: 74 20 75 73 65 64 20 2a 2f 0a 20 20 54 63 6c 5f  t used */.  Tcl_
2260: 49 6e 74 65 72 70 20 2a 69 6e 74 65 72 70 2c 20  Interp *interp, 
2270: 20 20 20 2f 2a 20 54 68 65 20 54 43 4c 20 69 6e     /* The TCL in
2280: 74 65 72 70 72 65 74 65 72 20 74 68 61 74 20 69  terpreter that i
2290: 6e 76 6f 6b 65 64 20 74 68 69 73 20 63 6f 6d 6d  nvoked this comm
22a0: 61 6e 64 20 2a 2f 0a 20 20 69 6e 74 20 6f 62 6a  and */.  int obj
22b0: 63 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20  c,              
22c0: 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 61 72 67  /* Number of arg
22d0: 75 6d 65 6e 74 73 20 2a 2f 0a 20 20 54 63 6c 5f  uments */.  Tcl_
22e0: 4f 62 6a 20 2a 43 4f 4e 53 54 20 6f 62 6a 76 5b  Obj *CONST objv[
22f0: 5d 20 20 2f 2a 20 43 6f 6d 6d 61 6e 64 20 61 72  ]  /* Command ar
2300: 67 75 6d 65 6e 74 73 20 2a 2f 0a 29 7b 0a 20 20  guments */.){.  
2310: 73 71 6c 69 74 65 33 20 2a 64 62 3b 0a 20 20 69  sqlite3 *db;.  i
2320: 66 28 20 6f 62 6a 63 21 3d 32 20 29 7b 0a 20 20  f( objc!=2 ){.  
2330: 20 20 54 63 6c 5f 57 72 6f 6e 67 4e 75 6d 41 72    Tcl_WrongNumAr
2340: 67 73 28 69 6e 74 65 72 70 2c 20 31 2c 20 6f 62  gs(interp, 1, ob
2350: 6a 76 2c 20 22 44 42 22 29 3b 0a 20 20 20 20 72  jv, "DB");.    r
2360: 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52 3b  eturn TCL_ERROR;
2370: 0a 20 20 7d 0a 20 20 69 66 28 20 67 65 74 44 62  .  }.  if( getDb
2380: 50 6f 69 6e 74 65 72 28 69 6e 74 65 72 70 2c 20  Pointer(interp, 
2390: 54 63 6c 5f 47 65 74 53 74 72 69 6e 67 28 6f 62  Tcl_GetString(ob
23a0: 6a 76 5b 31 5d 29 2c 20 26 64 62 29 20 29 20 72  jv[1]), &db) ) r
23b0: 65 74 75 72 6e 20 54 43 4c 5f 45 52 52 4f 52 3b  eturn TCL_ERROR;
23c0: 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f  .#ifndef SQLITE_
23d0: 4f 4d 49 54 5f 56 49 52 54 55 41 4c 54 41 42 4c  OMIT_VIRTUALTABL
23e0: 45 0a 20 20 73 71 6c 69 74 65 33 5f 63 72 65 61  E.  sqlite3_crea
23f0: 74 65 5f 6d 6f 64 75 6c 65 28 64 62 2c 20 22 73  te_module(db, "s
2400: 63 68 65 6d 61 22 2c 20 26 73 63 68 65 6d 61 4d  chema", &schemaM
2410: 6f 64 75 6c 65 2c 20 30 29 3b 0a 23 65 6e 64 69  odule, 0);.#endi
2420: 66 0a 20 20 72 65 74 75 72 6e 20 54 43 4c 5f 4f  f.  return TCL_O
2430: 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 67 69  K;.}../*.** Regi
2440: 73 74 65 72 20 63 6f 6d 6d 61 6e 64 73 20 77 69  ster commands wi
2450: 74 68 20 74 68 65 20 54 43 4c 20 69 6e 74 65 72  th the TCL inter
2460: 70 72 65 74 65 72 2e 0a 2a 2f 0a 69 6e 74 20 53  preter..*/.int S
2470: 71 6c 69 74 65 74 65 73 74 73 63 68 65 6d 61 5f  qlitetestschema_
2480: 49 6e 69 74 28 54 63 6c 5f 49 6e 74 65 72 70 20  Init(Tcl_Interp 
2490: 2a 69 6e 74 65 72 70 29 7b 0a 20 20 73 74 61 74  *interp){.  stat
24a0: 69 63 20 73 74 72 75 63 74 20 7b 0a 20 20 20 20  ic struct {.    
24b0: 20 63 68 61 72 20 2a 7a 4e 61 6d 65 3b 0a 20 20   char *zName;.  
24c0: 20 20 20 54 63 6c 5f 4f 62 6a 43 6d 64 50 72 6f     Tcl_ObjCmdPro
24d0: 63 20 2a 78 50 72 6f 63 3b 0a 20 20 20 20 20 76  c *xProc;.     v
24e0: 6f 69 64 20 2a 63 6c 69 65 6e 74 44 61 74 61 3b  oid *clientData;
24f0: 0a 20 20 7d 20 61 4f 62 6a 43 6d 64 5b 5d 20 3d  .  } aObjCmd[] =
2500: 20 7b 0a 20 20 20 20 20 7b 20 22 72 65 67 69 73   {.     { "regis
2510: 74 65 72 5f 73 63 68 65 6d 61 5f 6d 6f 64 75 6c  ter_schema_modul
2520: 65 22 2c 20 72 65 67 69 73 74 65 72 5f 73 63 68  e", register_sch
2530: 65 6d 61 5f 6d 6f 64 75 6c 65 2c 20 30 20 7d 2c  ema_module, 0 },
2540: 0a 20 20 7d 3b 0a 20 20 69 6e 74 20 69 3b 0a 20  .  };.  int i;. 
2550: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 73 69 7a 65   for(i=0; i<size
2560: 6f 66 28 61 4f 62 6a 43 6d 64 29 2f 73 69 7a 65  of(aObjCmd)/size
2570: 6f 66 28 61 4f 62 6a 43 6d 64 5b 30 5d 29 3b 20  of(aObjCmd[0]); 
2580: 69 2b 2b 29 7b 0a 20 20 20 20 54 63 6c 5f 43 72  i++){.    Tcl_Cr
2590: 65 61 74 65 4f 62 6a 43 6f 6d 6d 61 6e 64 28 69  eateObjCommand(i
25a0: 6e 74 65 72 70 2c 20 61 4f 62 6a 43 6d 64 5b 69  nterp, aObjCmd[i
25b0: 5d 2e 7a 4e 61 6d 65 2c 20 0a 20 20 20 20 20 20  ].zName, .      
25c0: 20 20 61 4f 62 6a 43 6d 64 5b 69 5d 2e 78 50 72    aObjCmd[i].xPr
25d0: 6f 63 2c 20 61 4f 62 6a 43 6d 64 5b 69 5d 2e 63  oc, aObjCmd[i].c
25e0: 6c 69 65 6e 74 44 61 74 61 2c 20 30 29 3b 0a 20  lientData, 0);. 
25f0: 20 7d 0a 20 20 72 65 74 75 72 6e 20 54 43 4c 5f   }.  return TCL_
2600: 4f 4b 3b 0a 7d 0a 0a 23 65 6c 73 65 0a 0a 2f 2a  OK;.}..#else../*
2610: 0a 2a 2a 20 45 78 74 65 6e 73 69 6f 6e 20 6c 6f  .** Extension lo
2620: 61 64 20 66 75 6e 63 74 69 6f 6e 2e 0a 2a 2f 0a  ad function..*/.
2630: 69 6e 74 20 73 71 6c 69 74 65 33 5f 65 78 74 65  int sqlite3_exte
2640: 6e 73 69 6f 6e 5f 69 6e 69 74 28 0a 20 20 73 71  nsion_init(.  sq
2650: 6c 69 74 65 33 20 2a 64 62 2c 20 0a 20 20 63 68  lite3 *db, .  ch
2660: 61 72 20 2a 2a 70 7a 45 72 72 4d 73 67 2c 20 0a  ar **pzErrMsg, .
2670: 20 20 63 6f 6e 73 74 20 73 71 6c 69 74 65 33 5f    const sqlite3_
2680: 61 70 69 5f 72 6f 75 74 69 6e 65 73 20 2a 70 41  api_routines *pA
2690: 70 69 0a 29 7b 0a 20 20 53 51 4c 49 54 45 5f 45  pi.){.  SQLITE_E
26a0: 58 54 45 4e 53 49 4f 4e 5f 49 4e 49 54 32 28 70  XTENSION_INIT2(p
26b0: 41 70 69 29 3b 0a 23 69 66 6e 64 65 66 20 53 51  Api);.#ifndef SQ
26c0: 4c 49 54 45 5f 4f 4d 49 54 5f 56 49 52 54 55 41  LITE_OMIT_VIRTUA
26d0: 4c 54 41 42 4c 45 0a 20 20 73 71 6c 69 74 65 33  LTABLE.  sqlite3
26e0: 5f 63 72 65 61 74 65 5f 6d 6f 64 75 6c 65 28 64  _create_module(d
26f0: 62 2c 20 22 73 63 68 65 6d 61 22 2c 20 26 73 63  b, "schema", &sc
2700: 68 65 6d 61 4d 6f 64 75 6c 65 2c 20 30 29 3b 0a  hemaModule, 0);.
2710: 23 65 6e 64 69 66 0a 20 20 72 65 74 75 72 6e 20  #endif.  return 
2720: 30 3b 0a 7d 0a 0a 23 65 6e 64 69 66 0a           0;.}..#endif.