/ Hex Artifact Content
Login

Artifact 4f0ebf278f46e68e6306c667917766cebc5550fd35d5de17847988e22892d4d2:


0000: 2f 2a 0a 2a 2a 20 32 30 31 37 2d 31 30 2d 32 34  /*.** 2017-10-24
0010: 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74 68 6f  .**.** The autho
0020: 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70 79  r disclaims copy
0030: 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73 6f  right to this so
0040: 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20 70  urce code.  In p
0050: 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c 65 67  lace of.** a leg
0060: 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65 20  al notice, here 
0070: 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a 2a  is a blessing:.*
0080: 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f 75 20  *.**    May you 
0090: 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74 20  do good and not 
00a0: 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61 79 20  evil..**    May 
00b0: 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69 76 65  you find forgive
00c0: 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73 65 6c  ness for yoursel
00d0: 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20 6f 74  f and forgive ot
00e0: 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61 79 20  hers..**    May 
00f0: 79 6f 75 20 73 68 61 72 65 20 66 72 65 65 6c 79  you share freely
0100: 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67 20 6d  , never taking m
0110: 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67 69 76  ore than you giv
0120: 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  e..**.**********
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 2a 2a 2a 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20  ****.**.** This 
0180: 66 69 6c 65 20 63 6f 6e 74 61 69 6e 73 20 61 6e  file contains an
0190: 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 20   implementation 
01a0: 6f 66 20 74 68 65 20 22 73 71 6c 69 74 65 5f 62  of the "sqlite_b
01b0: 74 72 65 65 69 6e 66 6f 22 20 76 69 72 74 75 61  treeinfo" virtua
01c0: 6c 20 74 61 62 6c 65 2e 0a 2a 2a 0a 2a 2a 20 54  l table..**.** T
01d0: 68 65 20 73 71 6c 69 74 65 5f 62 74 72 65 65 69  he sqlite_btreei
01e0: 6e 66 6f 20 76 69 72 74 75 61 6c 20 74 61 62 6c  nfo virtual tabl
01f0: 65 20 69 73 20 61 20 72 65 61 64 2d 6f 6e 6c 79  e is a read-only
0200: 20 65 70 6f 6e 79 6d 6f 75 73 2d 6f 6e 6c 79 20   eponymous-only 
0210: 76 69 72 74 75 61 6c 0a 2a 2a 20 74 61 62 6c 65  virtual.** table
0220: 20 74 68 61 74 20 73 68 6f 77 73 20 69 6e 66 6f   that shows info
0230: 72 6d 61 74 69 6f 6e 20 61 62 6f 75 74 20 61 6c  rmation about al
0240: 6c 20 62 74 72 65 65 73 20 69 6e 20 61 6e 20 53  l btrees in an S
0250: 51 4c 69 74 65 20 64 61 74 61 62 61 73 65 20 66  QLite database f
0260: 69 6c 65 2e 0a 2a 2a 20 54 68 65 20 73 63 68 65  ile..** The sche
0270: 6d 61 20 69 73 20 6c 69 6b 65 20 74 68 69 73 3a  ma is like this:
0280: 0a 2a 2a 0a 2a 2a 20 43 52 45 41 54 45 20 54 41  .**.** CREATE TA
0290: 42 4c 45 20 73 71 6c 69 74 65 5f 62 74 72 65 65  BLE sqlite_btree
02a0: 69 6e 66 6f 28 0a 2a 2a 20 20 20 20 74 79 70 65  info(.**    type
02b0: 20 54 45 58 54 2c 20 20 20 20 20 20 20 20 20 20   TEXT,          
02c0: 20 20 20 20 20 20 20 20 20 2d 2d 20 22 74 61 62           -- "tab
02d0: 6c 65 22 20 6f 72 20 22 69 6e 64 65 78 22 0a 2a  le" or "index".*
02e0: 2a 20 20 20 20 6e 61 6d 65 20 54 45 58 54 2c 20  *    name TEXT, 
02f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0300: 20 20 2d 2d 20 4e 61 6d 65 20 6f 66 20 74 61 62    -- Name of tab
0310: 6c 65 20 6f 72 20 69 6e 64 65 78 20 66 6f 72 20  le or index for 
0320: 74 68 69 73 20 62 74 72 65 65 2e 0a 2a 2a 20 20  this btree..**  
0330: 20 20 74 62 6c 5f 6e 61 6d 65 20 54 45 58 54 2c    tbl_name TEXT,
0340: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2d                 -
0350: 2d 20 41 73 73 6f 63 69 61 74 65 64 20 74 61 62  - Associated tab
0360: 6c 65 0a 2a 2a 20 20 20 20 72 6f 6f 74 70 61 67  le.**    rootpag
0370: 65 20 49 4e 54 2c 20 20 20 20 20 20 20 20 20 20  e INT,          
0380: 20 20 20 20 20 20 2d 2d 20 54 68 65 20 72 6f 6f        -- The roo
0390: 74 20 70 61 67 65 20 6f 66 20 74 68 65 20 62 74  t page of the bt
03a0: 72 65 65 0a 2a 2a 20 20 20 20 73 71 6c 20 54 45  ree.**    sql TE
03b0: 58 54 2c 20 20 20 20 20 20 20 20 20 20 20 20 20  XT,             
03c0: 20 20 20 20 20 20 20 2d 2d 20 53 51 4c 20 66 6f         -- SQL fo
03d0: 72 20 74 68 69 73 20 62 74 72 65 65 20 2d 20 66  r this btree - f
03e0: 72 6f 6d 20 73 71 6c 69 74 65 5f 6d 61 73 74 65  rom sqlite_maste
03f0: 72 0a 2a 2a 20 20 20 20 68 61 73 52 6f 77 69 64  r.**    hasRowid
0400: 20 42 4f 4f 4c 45 41 4e 2c 20 20 20 20 20 20 20   BOOLEAN,       
0410: 20 20 20 20 20 2d 2d 20 54 72 75 65 20 69 66 20       -- True if 
0420: 74 68 65 20 62 74 72 65 65 20 68 61 73 20 61 20  the btree has a 
0430: 72 6f 77 69 64 0a 2a 2a 20 20 20 20 6e 45 6e 74  rowid.**    nEnt
0440: 72 79 20 49 4e 54 2c 20 20 20 20 20 20 20 20 20  ry INT,         
0450: 20 20 20 20 20 20 20 20 20 2d 2d 20 45 73 74 69           -- Esti
0460: 6d 61 74 65 64 20 6e 75 6d 62 65 72 20 6f 66 20  mated number of 
0470: 65 6e 74 65 72 69 65 73 0a 2a 2a 20 20 20 20 6e  enteries.**    n
0480: 50 61 67 65 20 49 4e 54 2c 20 20 20 20 20 20 20  Page INT,       
0490: 20 20 20 20 20 20 20 20 20 20 20 20 2d 2d 20 45              -- E
04a0: 73 74 69 6d 61 74 65 64 20 6e 75 6d 62 65 72 20  stimated number 
04b0: 6f 66 20 70 61 67 65 73 0a 2a 2a 20 20 20 20 64  of pages.**    d
04c0: 65 70 74 68 20 49 4e 54 2c 20 20 20 20 20 20 20  epth INT,       
04d0: 20 20 20 20 20 20 20 20 20 20 20 20 2d 2d 20 44              -- D
04e0: 65 70 74 68 20 6f 66 20 74 68 65 20 62 74 72 65  epth of the btre
04f0: 65 0a 2a 2a 20 20 20 20 73 7a 50 61 67 65 20 49  e.**    szPage I
0500: 4e 54 2c 20 20 20 20 20 20 20 20 20 20 20 20 20  NT,             
0510: 20 20 20 20 20 2d 2d 20 53 69 7a 65 20 6f 66 20       -- Size of 
0520: 65 61 63 68 20 70 61 67 65 20 69 6e 20 62 79 74  each page in byt
0530: 65 73 0a 2a 2a 20 20 20 20 7a 53 63 68 65 6d 61  es.**    zSchema
0540: 20 54 45 58 54 20 48 49 44 44 45 4e 20 20 20 20   TEXT HIDDEN    
0550: 20 20 20 20 20 20 2d 2d 20 54 68 65 20 73 63 68        -- The sch
0560: 65 6d 61 20 74 6f 20 77 68 69 63 68 20 74 68 69  ema to which thi
0570: 73 20 62 74 72 65 65 20 62 65 6c 6f 6e 67 73 0a  s btree belongs.
0580: 2a 2a 20 29 3b 0a 2a 2a 0a 2a 2a 20 54 68 65 20  ** );.**.** The 
0590: 66 69 72 73 74 20 35 20 66 69 65 6c 64 73 20 61  first 5 fields a
05a0: 72 65 20 74 61 6b 65 6e 20 64 69 72 65 63 74 6c  re taken directl
05b0: 79 20 66 72 6f 6d 20 74 68 65 20 73 71 6c 69 74  y from the sqlit
05c0: 65 5f 6d 61 73 74 65 72 20 74 61 62 6c 65 2e 0a  e_master table..
05d0: 2a 2a 20 43 6f 6e 73 69 64 65 72 69 6e 67 20 6f  ** Considering o
05e0: 6e 6c 79 20 74 68 65 20 66 69 72 73 74 20 35 20  nly the first 5 
05f0: 66 69 65 6c 64 73 2c 20 74 68 65 20 6f 6e 6c 79  fields, the only
0600: 20 64 69 66 66 65 72 65 6e 63 65 20 62 65 74 77   difference betw
0610: 65 65 6e 20 0a 2a 2a 20 74 68 69 73 20 76 69 72  een .** this vir
0620: 74 75 61 6c 20 74 61 62 6c 65 20 61 6e 64 20 74  tual table and t
0630: 68 65 20 73 71 6c 69 74 65 5f 6d 61 73 74 65 72  he sqlite_master
0640: 20 74 61 62 6c 65 20 69 73 20 74 68 61 74 20 74   table is that t
0650: 68 69 73 20 76 69 72 74 75 61 6c 0a 2a 2a 20 74  his virtual.** t
0660: 61 62 6c 65 20 6f 6d 69 74 73 20 61 6c 6c 20 65  able omits all e
0670: 6e 74 72 69 65 73 20 74 68 61 74 20 68 61 76 65  ntries that have
0680: 20 61 20 30 20 6f 72 20 4e 55 4c 4c 20 72 6f 77   a 0 or NULL row
0690: 69 64 20 2d 20 69 6e 20 6f 74 68 65 72 20 77 6f  id - in other wo
06a0: 72 64 73 0a 2a 2a 20 69 74 20 6f 6d 69 74 73 20  rds.** it omits 
06b0: 74 72 69 67 67 65 72 73 20 61 6e 64 20 76 69 65  triggers and vie
06c0: 77 73 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20 76 61  ws..**.** The va
06d0: 6c 75 65 20 61 64 64 65 64 20 62 79 20 74 68 69  lue added by thi
06e0: 73 20 74 61 62 6c 65 20 63 6f 6d 65 73 20 69 6e  s table comes in
06f0: 20 74 68 65 20 6e 65 78 74 20 35 20 66 69 65 6c   the next 5 fiel
0700: 64 73 2e 0a 2a 2a 0a 2a 2a 20 4e 6f 74 65 20 74  ds..**.** Note t
0710: 68 61 74 20 6e 45 6e 74 72 79 20 61 6e 64 20 6e  hat nEntry and n
0720: 50 61 67 65 20 61 72 65 20 2a 65 73 74 69 6d 61  Page are *estima
0730: 74 65 64 2a 2e 20 20 54 68 65 79 20 61 72 65 20  ted*.  They are 
0740: 63 6f 6d 70 75 74 65 64 20 64 6f 69 6e 67 0a 2a  computed doing.*
0750: 2a 20 61 20 73 69 6e 67 6c 65 20 73 65 61 72 63  * a single searc
0760: 68 20 66 72 6f 6d 20 74 68 65 20 72 6f 6f 74 20  h from the root 
0770: 74 6f 20 61 20 6c 65 61 66 2c 20 63 6f 75 6e 74  to a leaf, count
0780: 69 6e 67 20 74 68 65 20 6e 75 6d 62 65 72 20 6f  ing the number o
0790: 66 20 63 65 6c 6c 73 0a 2a 2a 20 61 74 20 65 61  f cells.** at ea
07a0: 63 68 20 6c 65 76 65 6c 2c 20 61 6e 64 20 61 73  ch level, and as
07b0: 73 75 6d 69 6e 67 20 74 68 61 74 20 75 6e 76 69  suming that unvi
07c0: 73 69 74 65 64 20 70 61 67 65 73 20 68 61 76 65  sited pages have
07d0: 20 61 20 73 69 6d 69 6c 61 72 20 6e 75 6d 62 65   a similar numbe
07e0: 72 0a 2a 2a 20 6f 66 20 63 65 6c 6c 73 2e 0a 2a  r.** of cells..*
07f0: 2a 0a 2a 2a 20 54 68 65 20 73 71 6c 69 74 65 5f  *.** The sqlite_
0800: 64 62 70 61 67 65 20 76 69 72 74 75 61 6c 20 74  dbpage virtual t
0810: 61 62 6c 65 20 6d 75 73 74 20 62 65 20 61 76 61  able must be ava
0820: 69 6c 61 62 6c 65 20 66 6f 72 20 74 68 69 73 20  ilable for this 
0830: 76 69 72 74 75 61 6c 20 74 61 62 6c 65 0a 2a 2a  virtual table.**
0840: 20 74 6f 20 6f 70 65 72 61 74 65 2e 0a 2a 2a 0a   to operate..**.
0850: 2a 2a 20 55 53 41 47 45 20 45 58 41 4d 50 4c 45  ** USAGE EXAMPLE
0860: 53 3a 0a 2a 2a 0a 2a 2a 20 53 68 6f 77 20 74 68  S:.**.** Show th
0870: 65 20 74 61 62 6c 65 20 62 74 72 65 65 73 20 69  e table btrees i
0880: 6e 20 61 20 73 63 68 65 6d 61 20 6f 72 64 65 72  n a schema order
0890: 20 77 69 74 68 20 74 68 65 20 74 61 62 6c 65 73   with the tables
08a0: 20 77 69 74 68 20 74 68 65 20 6d 6f 73 74 0a 2a   with the most.*
08b0: 2a 20 72 6f 77 73 20 6f 63 63 75 72 69 6e 67 20  * rows occuring 
08c0: 66 69 72 73 74 3a 0a 2a 2a 0a 2a 2a 20 20 20 20  first:.**.**    
08d0: 20 20 53 45 4c 45 43 54 20 6e 61 6d 65 2c 20 6e    SELECT name, n
08e0: 45 6e 74 72 79 0a 2a 2a 20 20 20 20 20 20 20 20  Entry.**        
08f0: 46 52 4f 4d 20 73 71 6c 69 74 65 5f 62 74 72 65  FROM sqlite_btre
0900: 65 69 6e 66 6f 0a 2a 2a 20 20 20 20 20 20 20 57  einfo.**       W
0910: 48 45 52 45 20 74 79 70 65 3d 27 74 61 62 6c 65  HERE type='table
0920: 27 0a 2a 2a 20 20 20 20 20 20 20 4f 52 44 45 52  '.**       ORDER
0930: 20 42 59 20 6e 45 6e 74 72 79 20 44 45 53 43 2c   BY nEntry DESC,
0940: 20 6e 61 6d 65 3b 0a 2a 2a 0a 2a 2a 20 53 68 6f   name;.**.** Sho
0950: 77 20 74 68 65 20 6e 61 6d 65 73 20 6f 66 20 61  w the names of a
0960: 6c 6c 20 57 49 54 48 4f 55 54 20 52 4f 57 49 44  ll WITHOUT ROWID
0970: 20 74 61 62 6c 65 73 3a 20 0a 2a 2a 0a 2a 2a 20   tables: .**.** 
0980: 20 20 20 20 20 53 45 4c 45 43 54 20 6e 61 6d 65       SELECT name
0990: 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 62 74 72   FROM sqlite_btr
09a0: 65 65 69 6e 66 6f 0a 2a 2a 20 20 20 20 20 20 20  eeinfo.**       
09b0: 57 48 45 52 45 20 74 79 70 65 3d 27 74 61 62 6c  WHERE type='tabl
09c0: 65 27 20 41 4e 44 20 4e 4f 54 20 68 61 73 52 6f  e' AND NOT hasRo
09d0: 77 69 64 3b 0a 2a 2f 0a 23 69 66 20 21 64 65 66  wid;.*/.#if !def
09e0: 69 6e 65 64 28 53 51 4c 49 54 45 49 4e 54 5f 48  ined(SQLITEINT_H
09f0: 29 0a 23 69 6e 63 6c 75 64 65 20 22 73 71 6c 69  ).#include "sqli
0a00: 74 65 33 65 78 74 2e 68 22 0a 23 65 6e 64 69 66  te3ext.h".#endif
0a10: 0a 53 51 4c 49 54 45 5f 45 58 54 45 4e 53 49 4f  .SQLITE_EXTENSIO
0a20: 4e 5f 49 4e 49 54 31 0a 23 69 6e 63 6c 75 64 65  N_INIT1.#include
0a30: 20 3c 73 74 72 69 6e 67 2e 68 3e 0a 23 69 6e 63   <string.h>.#inc
0a40: 6c 75 64 65 20 3c 61 73 73 65 72 74 2e 68 3e 0a  lude <assert.h>.
0a50: 0a 2f 2a 20 43 6f 6c 75 6d 6e 73 20 61 76 61 69  ./* Columns avai
0a60: 6c 61 62 6c 65 20 69 6e 20 74 68 69 73 20 76 69  lable in this vi
0a70: 72 74 75 61 6c 20 74 61 62 6c 65 20 2a 2f 0a 23  rtual table */.#
0a80: 64 65 66 69 6e 65 20 42 49 4e 46 4f 5f 43 4f 4c  define BINFO_COL
0a90: 55 4d 4e 5f 54 59 50 45 20 20 20 20 20 20 20 20  UMN_TYPE        
0aa0: 20 30 0a 23 64 65 66 69 6e 65 20 42 49 4e 46 4f   0.#define BINFO
0ab0: 5f 43 4f 4c 55 4d 4e 5f 4e 41 4d 45 20 20 20 20  _COLUMN_NAME    
0ac0: 20 20 20 20 20 31 0a 23 64 65 66 69 6e 65 20 42       1.#define B
0ad0: 49 4e 46 4f 5f 43 4f 4c 55 4d 4e 5f 54 42 4c 5f  INFO_COLUMN_TBL_
0ae0: 4e 41 4d 45 20 20 20 20 20 32 0a 23 64 65 66 69  NAME     2.#defi
0af0: 6e 65 20 42 49 4e 46 4f 5f 43 4f 4c 55 4d 4e 5f  ne BINFO_COLUMN_
0b00: 52 4f 4f 54 50 41 47 45 20 20 20 20 20 33 0a 23  ROOTPAGE     3.#
0b10: 64 65 66 69 6e 65 20 42 49 4e 46 4f 5f 43 4f 4c  define BINFO_COL
0b20: 55 4d 4e 5f 53 51 4c 20 20 20 20 20 20 20 20 20  UMN_SQL         
0b30: 20 34 0a 23 64 65 66 69 6e 65 20 42 49 4e 46 4f   4.#define BINFO
0b40: 5f 43 4f 4c 55 4d 4e 5f 48 41 53 52 4f 57 49 44  _COLUMN_HASROWID
0b50: 20 20 20 20 20 35 0a 23 64 65 66 69 6e 65 20 42       5.#define B
0b60: 49 4e 46 4f 5f 43 4f 4c 55 4d 4e 5f 4e 45 4e 54  INFO_COLUMN_NENT
0b70: 52 59 20 20 20 20 20 20 20 36 0a 23 64 65 66 69  RY       6.#defi
0b80: 6e 65 20 42 49 4e 46 4f 5f 43 4f 4c 55 4d 4e 5f  ne BINFO_COLUMN_
0b90: 4e 50 41 47 45 20 20 20 20 20 20 20 20 37 0a 23  NPAGE        7.#
0ba0: 64 65 66 69 6e 65 20 42 49 4e 46 4f 5f 43 4f 4c  define BINFO_COL
0bb0: 55 4d 4e 5f 44 45 50 54 48 20 20 20 20 20 20 20  UMN_DEPTH       
0bc0: 20 38 0a 23 64 65 66 69 6e 65 20 42 49 4e 46 4f   8.#define BINFO
0bd0: 5f 43 4f 4c 55 4d 4e 5f 53 5a 50 41 47 45 20 20  _COLUMN_SZPAGE  
0be0: 20 20 20 20 20 39 0a 23 64 65 66 69 6e 65 20 42       9.#define B
0bf0: 49 4e 46 4f 5f 43 4f 4c 55 4d 4e 5f 53 43 48 45  INFO_COLUMN_SCHE
0c00: 4d 41 20 20 20 20 20 20 31 30 0a 0a 2f 2a 20 46  MA      10../* F
0c10: 6f 72 77 61 72 64 20 64 65 63 6c 61 72 61 74 69  orward declarati
0c20: 6f 6e 73 20 2a 2f 0a 74 79 70 65 64 65 66 20 73  ons */.typedef s
0c30: 74 72 75 63 74 20 42 69 6e 66 6f 54 61 62 6c 65  truct BinfoTable
0c40: 20 42 69 6e 66 6f 54 61 62 6c 65 3b 0a 74 79 70   BinfoTable;.typ
0c50: 65 64 65 66 20 73 74 72 75 63 74 20 42 69 6e 66  edef struct Binf
0c60: 6f 43 75 72 73 6f 72 20 42 69 6e 66 6f 43 75 72  oCursor BinfoCur
0c70: 73 6f 72 3b 0a 0a 2f 2a 20 41 20 63 75 72 73 6f  sor;../* A curso
0c80: 72 20 66 6f 72 20 74 68 65 20 73 71 6c 69 74 65  r for the sqlite
0c90: 5f 62 74 72 65 65 69 6e 66 6f 20 74 61 62 6c 65  _btreeinfo table
0ca0: 20 2a 2f 0a 73 74 72 75 63 74 20 42 69 6e 66 6f   */.struct Binfo
0cb0: 43 75 72 73 6f 72 20 7b 0a 20 20 73 71 6c 69 74  Cursor {.  sqlit
0cc0: 65 33 5f 76 74 61 62 5f 63 75 72 73 6f 72 20 62  e3_vtab_cursor b
0cd0: 61 73 65 3b 20 20 20 20 20 20 20 2f 2a 20 42 61  ase;       /* Ba
0ce0: 73 65 20 63 6c 61 73 73 2e 20 20 4d 75 73 74 20  se class.  Must 
0cf0: 62 65 20 66 69 72 73 74 20 2a 2f 0a 20 20 73 71  be first */.  sq
0d00: 6c 69 74 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d  lite3_stmt *pStm
0d10: 74 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  t;            /*
0d20: 20 51 75 65 72 79 20 61 67 61 69 6e 73 74 20 73   Query against s
0d30: 71 6c 69 74 65 5f 6d 61 73 74 65 72 20 2a 2f 0a  qlite_master */.
0d40: 20 20 69 6e 74 20 72 63 3b 20 20 20 20 20 20 20    int rc;       
0d50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0d60: 20 20 2f 2a 20 52 65 73 75 6c 74 20 6f 66 20 70    /* Result of p
0d70: 72 65 76 69 6f 75 73 20 73 71 6c 69 74 65 5f 73  revious sqlite_s
0d80: 74 65 70 28 29 20 63 61 6c 6c 20 2a 2f 0a 20 20  tep() call */.  
0d90: 69 6e 74 20 68 61 73 52 6f 77 69 64 3b 20 20 20  int hasRowid;   
0da0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0db0: 2f 2a 20 68 61 73 52 6f 77 69 64 20 76 61 6c 75  /* hasRowid valu
0dc0: 65 2e 20 20 4e 65 67 61 74 69 76 65 20 69 66 20  e.  Negative if 
0dd0: 75 6e 6b 6e 6f 77 6e 2e 20 2a 2f 0a 20 20 73 71  unknown. */.  sq
0de0: 6c 69 74 65 33 5f 69 6e 74 36 34 20 6e 45 6e 74  lite3_int64 nEnt
0df0: 72 79 3b 20 20 20 20 20 20 20 20 20 20 20 2f 2a  ry;           /*
0e00: 20 6e 45 6e 74 72 79 20 76 61 6c 75 65 20 2a 2f   nEntry value */
0e10: 0a 20 20 69 6e 74 20 6e 50 61 67 65 3b 20 20 20  .  int nPage;   
0e20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0e30: 20 20 20 2f 2a 20 6e 50 61 67 65 20 76 61 6c 75     /* nPage valu
0e40: 65 20 2a 2f 0a 20 20 69 6e 74 20 64 65 70 74 68  e */.  int depth
0e50: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
0e60: 20 20 20 20 20 20 20 2f 2a 20 64 65 70 74 68 20         /* depth 
0e70: 76 61 6c 75 65 20 2a 2f 0a 20 20 69 6e 74 20 73  value */.  int s
0e80: 7a 50 61 67 65 3b 20 20 20 20 20 20 20 20 20 20  zPage;          
0e90: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 73 69             /* si
0ea0: 7a 65 20 6f 66 20 61 20 62 74 72 65 65 20 70 61  ze of a btree pa
0eb0: 67 65 2e 20 20 30 20 69 66 20 75 6e 6b 6e 6f 77  ge.  0 if unknow
0ec0: 6e 20 2a 2f 0a 20 20 63 68 61 72 20 2a 7a 53 63  n */.  char *zSc
0ed0: 68 65 6d 61 3b 20 20 20 20 20 20 20 20 20 20 20  hema;           
0ee0: 20 20 20 20 20 20 20 2f 2a 20 53 63 68 65 6d 61         /* Schema
0ef0: 20 62 65 69 6e 67 20 69 6e 74 65 72 72 6f 67 61   being interroga
0f00: 74 65 64 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 20 54 68  ted */.};../* Th
0f10: 65 20 73 71 6c 69 74 65 5f 62 74 72 65 65 69 6e  e sqlite_btreein
0f20: 66 6f 20 74 61 62 6c 65 20 2a 2f 0a 73 74 72 75  fo table */.stru
0f30: 63 74 20 42 69 6e 66 6f 54 61 62 6c 65 20 7b 0a  ct BinfoTable {.
0f40: 20 20 73 71 6c 69 74 65 33 5f 76 74 61 62 20 62    sqlite3_vtab b
0f50: 61 73 65 3b 20 20 20 20 20 20 20 20 20 20 20 20  ase;            
0f60: 20 20 2f 2a 20 42 61 73 65 20 63 6c 61 73 73 2e    /* Base class.
0f70: 20 20 4d 75 73 74 20 62 65 20 66 69 72 73 74 20    Must be first 
0f80: 2a 2f 0a 20 20 73 71 6c 69 74 65 33 20 2a 64 62  */.  sqlite3 *db
0f90: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
0fa0: 20 20 20 20 20 2f 2a 20 54 68 65 20 64 61 74 61       /* The data
0fb0: 62 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 2a  bse connection *
0fc0: 2f 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20 43 6f 6e 6e  /.};../*.** Conn
0fd0: 65 63 74 20 74 6f 20 74 68 65 20 73 71 6c 69 74  ect to the sqlit
0fe0: 65 5f 62 74 72 65 65 69 6e 66 6f 20 76 69 72 74  e_btreeinfo virt
0ff0: 75 61 6c 20 74 61 62 6c 65 2e 0a 2a 2f 0a 73 74  ual table..*/.st
1000: 61 74 69 63 20 69 6e 74 20 62 69 6e 66 6f 43 6f  atic int binfoCo
1010: 6e 6e 65 63 74 28 0a 20 20 73 71 6c 69 74 65 33  nnect(.  sqlite3
1020: 20 2a 64 62 2c 0a 20 20 76 6f 69 64 20 2a 70 41   *db,.  void *pA
1030: 75 78 2c 0a 20 20 69 6e 74 20 61 72 67 63 2c 20  ux,.  int argc, 
1040: 63 6f 6e 73 74 20 63 68 61 72 20 2a 63 6f 6e 73  const char *cons
1050: 74 2a 61 72 67 76 2c 0a 20 20 73 71 6c 69 74 65  t*argv,.  sqlite
1060: 33 5f 76 74 61 62 20 2a 2a 70 70 56 74 61 62 2c  3_vtab **ppVtab,
1070: 0a 20 20 63 68 61 72 20 2a 2a 70 7a 45 72 72 0a  .  char **pzErr.
1080: 29 7b 0a 20 20 42 69 6e 66 6f 54 61 62 6c 65 20  ){.  BinfoTable 
1090: 2a 70 54 61 62 20 3d 20 30 3b 0a 20 20 69 6e 74  *pTab = 0;.  int
10a0: 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b   rc = SQLITE_OK;
10b0: 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f  .  rc = sqlite3_
10c0: 64 65 63 6c 61 72 65 5f 76 74 61 62 28 64 62 2c  declare_vtab(db,
10d0: 20 0a 20 20 20 20 20 20 22 43 52 45 41 54 45 20   .      "CREATE 
10e0: 54 41 42 4c 45 20 78 28 5c 6e 22 0a 20 20 20 20  TABLE x(\n".    
10f0: 20 20 22 20 74 79 70 65 20 54 45 58 54 2c 5c 6e    " type TEXT,\n
1100: 22 0a 20 20 20 20 20 20 22 20 6e 61 6d 65 20 54  ".      " name T
1110: 45 58 54 2c 5c 6e 22 0a 20 20 20 20 20 20 22 20  EXT,\n".      " 
1120: 74 62 6c 5f 6e 61 6d 65 20 54 45 58 54 2c 5c 6e  tbl_name TEXT,\n
1130: 22 0a 20 20 20 20 20 20 22 20 72 6f 6f 74 70 61  ".      " rootpa
1140: 67 65 20 49 4e 54 2c 5c 6e 22 0a 20 20 20 20 20  ge INT,\n".     
1150: 20 22 20 73 71 6c 20 54 45 58 54 2c 5c 6e 22 0a   " sql TEXT,\n".
1160: 20 20 20 20 20 20 22 20 68 61 73 52 6f 77 69 64        " hasRowid
1170: 20 42 4f 4f 4c 45 41 4e 2c 5c 6e 22 0a 20 20 20   BOOLEAN,\n".   
1180: 20 20 20 22 20 6e 45 6e 74 72 79 20 49 4e 54 2c     " nEntry INT,
1190: 5c 6e 22 0a 20 20 20 20 20 20 22 20 6e 50 61 67  \n".      " nPag
11a0: 65 20 49 4e 54 2c 5c 6e 22 0a 20 20 20 20 20 20  e INT,\n".      
11b0: 22 20 64 65 70 74 68 20 49 4e 54 2c 5c 6e 22 0a  " depth INT,\n".
11c0: 20 20 20 20 20 20 22 20 73 7a 50 61 67 65 20 49        " szPage I
11d0: 4e 54 2c 5c 6e 22 0a 20 20 20 20 20 20 22 20 7a  NT,\n".      " z
11e0: 53 63 68 65 6d 61 20 54 45 58 54 20 48 49 44 44  Schema TEXT HIDD
11f0: 45 4e 5c 6e 22 0a 20 20 20 20 20 20 22 29 22 29  EN\n".      ")")
1200: 3b 0a 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49  ;.  if( rc==SQLI
1210: 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 70 54 61  TE_OK ){.    pTa
1220: 62 20 3d 20 28 42 69 6e 66 6f 54 61 62 6c 65 20  b = (BinfoTable 
1230: 2a 29 73 71 6c 69 74 65 33 5f 6d 61 6c 6c 6f 63  *)sqlite3_malloc
1240: 36 34 28 73 69 7a 65 6f 66 28 42 69 6e 66 6f 54  64(sizeof(BinfoT
1250: 61 62 6c 65 29 29 3b 0a 20 20 20 20 69 66 28 20  able));.    if( 
1260: 70 54 61 62 3d 3d 30 20 29 20 72 63 20 3d 20 53  pTab==0 ) rc = S
1270: 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 7d  QLITE_NOMEM;.  }
1280: 0a 20 20 61 73 73 65 72 74 28 20 72 63 3d 3d 53  .  assert( rc==S
1290: 51 4c 49 54 45 5f 4f 4b 20 7c 7c 20 70 54 61 62  QLITE_OK || pTab
12a0: 3d 3d 30 20 29 3b 0a 20 20 69 66 28 20 70 54 61  ==0 );.  if( pTa
12b0: 62 20 29 7b 0a 20 20 20 20 70 54 61 62 2d 3e 64  b ){.    pTab->d
12c0: 62 20 3d 20 64 62 3b 0a 20 20 7d 0a 20 20 2a 70  b = db;.  }.  *p
12d0: 70 56 74 61 62 20 3d 20 28 73 71 6c 69 74 65 33  pVtab = (sqlite3
12e0: 5f 76 74 61 62 2a 29 70 54 61 62 3b 0a 20 20 72  _vtab*)pTab;.  r
12f0: 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a  eturn rc;.}../*.
1300: 2a 2a 20 44 69 73 63 6f 6e 6e 65 63 74 20 66 72  ** Disconnect fr
1310: 6f 6d 20 6f 72 20 64 65 73 74 72 6f 79 20 61 20  om or destroy a 
1320: 62 74 72 65 65 69 6e 66 6f 20 76 69 72 74 75 61  btreeinfo virtua
1330: 6c 20 74 61 62 6c 65 2e 0a 2a 2f 0a 73 74 61 74  l table..*/.stat
1340: 69 63 20 69 6e 74 20 62 69 6e 66 6f 44 69 73 63  ic int binfoDisc
1350: 6f 6e 6e 65 63 74 28 73 71 6c 69 74 65 33 5f 76  onnect(sqlite3_v
1360: 74 61 62 20 2a 70 56 74 61 62 29 7b 0a 20 20 73  tab *pVtab){.  s
1370: 71 6c 69 74 65 33 5f 66 72 65 65 28 70 56 74 61  qlite3_free(pVta
1380: 62 29 3b 0a 20 20 72 65 74 75 72 6e 20 53 51 4c  b);.  return SQL
1390: 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  ITE_OK;.}../*.**
13a0: 20 69 64 78 4e 75 6d 3a 0a 2a 2a 0a 2a 2a 20 20   idxNum:.**.**  
13b0: 20 20 20 30 20 20 20 20 20 55 73 65 20 22 6d 61     0     Use "ma
13c0: 69 6e 22 20 66 6f 72 20 74 68 65 20 73 63 68 65  in" for the sche
13d0: 6d 61 0a 2a 2a 20 20 20 20 20 31 20 20 20 20 20  ma.**     1     
13e0: 53 63 68 65 6d 61 20 69 64 65 6e 74 69 66 69 65  Schema identifie
13f0: 64 20 62 79 20 70 61 72 61 6d 65 74 65 72 20 3f  d by parameter ?
1400: 31 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20  1.*/.static int 
1410: 62 69 6e 66 6f 42 65 73 74 49 6e 64 65 78 28 73  binfoBestIndex(s
1420: 71 6c 69 74 65 33 5f 76 74 61 62 20 2a 74 61 62  qlite3_vtab *tab
1430: 2c 20 73 71 6c 69 74 65 33 5f 69 6e 64 65 78 5f  , sqlite3_index_
1440: 69 6e 66 6f 20 2a 70 49 64 78 49 6e 66 6f 29 7b  info *pIdxInfo){
1450: 0a 20 20 69 6e 74 20 69 3b 0a 20 20 70 49 64 78  .  int i;.  pIdx
1460: 49 6e 66 6f 2d 3e 65 73 74 69 6d 61 74 65 64 43  Info->estimatedC
1470: 6f 73 74 20 3d 20 31 30 30 30 30 2e 30 3b 20 20  ost = 10000.0;  
1480: 2f 2a 20 43 6f 73 74 20 65 73 74 69 6d 61 74 65  /* Cost estimate
1490: 20 2a 2f 0a 20 20 70 49 64 78 49 6e 66 6f 2d 3e   */.  pIdxInfo->
14a0: 65 73 74 69 6d 61 74 65 64 52 6f 77 73 20 3d 20  estimatedRows = 
14b0: 31 30 30 3b 0a 20 20 66 6f 72 28 69 3d 30 3b 20  100;.  for(i=0; 
14c0: 69 3c 70 49 64 78 49 6e 66 6f 2d 3e 6e 43 6f 6e  i<pIdxInfo->nCon
14d0: 73 74 72 61 69 6e 74 3b 20 69 2b 2b 29 7b 0a 20  straint; i++){. 
14e0: 20 20 20 73 74 72 75 63 74 20 73 71 6c 69 74 65     struct sqlite
14f0: 33 5f 69 6e 64 65 78 5f 63 6f 6e 73 74 72 61 69  3_index_constrai
1500: 6e 74 20 2a 70 20 3d 20 26 70 49 64 78 49 6e 66  nt *p = &pIdxInf
1510: 6f 2d 3e 61 43 6f 6e 73 74 72 61 69 6e 74 5b 69  o->aConstraint[i
1520: 5d 3b 0a 20 20 20 20 69 66 28 20 70 2d 3e 75 73  ];.    if( p->us
1530: 61 62 6c 65 0a 20 20 20 20 20 26 26 20 70 2d 3e  able.     && p->
1540: 69 43 6f 6c 75 6d 6e 3d 3d 42 49 4e 46 4f 5f 43  iColumn==BINFO_C
1550: 4f 4c 55 4d 4e 5f 53 43 48 45 4d 41 0a 20 20 20  OLUMN_SCHEMA.   
1560: 20 20 26 26 20 70 2d 3e 6f 70 3d 3d 53 51 4c 49    && p->op==SQLI
1570: 54 45 5f 49 4e 44 45 58 5f 43 4f 4e 53 54 52 41  TE_INDEX_CONSTRA
1580: 49 4e 54 5f 45 51 0a 20 20 20 20 29 7b 0a 20 20  INT_EQ.    ){.  
1590: 20 20 20 20 70 49 64 78 49 6e 66 6f 2d 3e 65 73      pIdxInfo->es
15a0: 74 69 6d 61 74 65 64 43 6f 73 74 20 3d 20 31 30  timatedCost = 10
15b0: 30 30 2e 30 3b 0a 20 20 20 20 20 20 70 49 64 78  00.0;.      pIdx
15c0: 49 6e 66 6f 2d 3e 69 64 78 4e 75 6d 20 3d 20 31  Info->idxNum = 1
15d0: 3b 0a 20 20 20 20 20 20 70 49 64 78 49 6e 66 6f  ;.      pIdxInfo
15e0: 2d 3e 61 43 6f 6e 73 74 72 61 69 6e 74 55 73 61  ->aConstraintUsa
15f0: 67 65 5b 69 5d 2e 61 72 67 76 49 6e 64 65 78 20  ge[i].argvIndex 
1600: 3d 20 31 3b 0a 20 20 20 20 20 20 70 49 64 78 49  = 1;.      pIdxI
1610: 6e 66 6f 2d 3e 61 43 6f 6e 73 74 72 61 69 6e 74  nfo->aConstraint
1620: 55 73 61 67 65 5b 69 5d 2e 6f 6d 69 74 20 3d 20  Usage[i].omit = 
1630: 31 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  1;.      break;.
1640: 20 20 20 20 7d 0a 20 20 7d 0a 20 20 72 65 74 75      }.  }.  retu
1650: 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a  rn SQLITE_OK;.}.
1660: 0a 2f 2a 0a 2a 2a 20 4f 70 65 6e 20 61 20 6e 65  ./*.** Open a ne
1670: 77 20 62 74 72 65 65 69 6e 66 6f 20 63 75 72 73  w btreeinfo curs
1680: 6f 72 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e  or..*/.static in
1690: 74 20 62 69 6e 66 6f 4f 70 65 6e 28 73 71 6c 69  t binfoOpen(sqli
16a0: 74 65 33 5f 76 74 61 62 20 2a 70 56 54 61 62 2c  te3_vtab *pVTab,
16b0: 20 73 71 6c 69 74 65 33 5f 76 74 61 62 5f 63 75   sqlite3_vtab_cu
16c0: 72 73 6f 72 20 2a 2a 70 70 43 75 72 73 6f 72 29  rsor **ppCursor)
16d0: 7b 0a 20 20 42 69 6e 66 6f 43 75 72 73 6f 72 20  {.  BinfoCursor 
16e0: 2a 70 43 73 72 3b 0a 0a 20 20 70 43 73 72 20 3d  *pCsr;..  pCsr =
16f0: 20 28 42 69 6e 66 6f 43 75 72 73 6f 72 20 2a 29   (BinfoCursor *)
1700: 73 71 6c 69 74 65 33 5f 6d 61 6c 6c 6f 63 36 34  sqlite3_malloc64
1710: 28 73 69 7a 65 6f 66 28 42 69 6e 66 6f 43 75 72  (sizeof(BinfoCur
1720: 73 6f 72 29 29 3b 0a 20 20 69 66 28 20 70 43 73  sor));.  if( pCs
1730: 72 3d 3d 30 20 29 7b 0a 20 20 20 20 72 65 74 75  r==0 ){.    retu
1740: 72 6e 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3b  rn SQLITE_NOMEM;
1750: 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 6d 65  .  }else{.    me
1760: 6d 73 65 74 28 70 43 73 72 2c 20 30 2c 20 73 69  mset(pCsr, 0, si
1770: 7a 65 6f 66 28 42 69 6e 66 6f 43 75 72 73 6f 72  zeof(BinfoCursor
1780: 29 29 3b 0a 20 20 20 20 70 43 73 72 2d 3e 62 61  ));.    pCsr->ba
1790: 73 65 2e 70 56 74 61 62 20 3d 20 70 56 54 61 62  se.pVtab = pVTab
17a0: 3b 0a 20 20 7d 0a 0a 20 20 2a 70 70 43 75 72 73  ;.  }..  *ppCurs
17b0: 6f 72 20 3d 20 28 73 71 6c 69 74 65 33 5f 76 74  or = (sqlite3_vt
17c0: 61 62 5f 63 75 72 73 6f 72 20 2a 29 70 43 73 72  ab_cursor *)pCsr
17d0: 3b 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54  ;.  return SQLIT
17e0: 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43  E_OK;.}../*.** C
17f0: 6c 6f 73 65 20 61 20 62 74 72 65 65 69 6e 66 6f  lose a btreeinfo
1800: 20 63 75 72 73 6f 72 2e 0a 2a 2f 0a 73 74 61 74   cursor..*/.stat
1810: 69 63 20 69 6e 74 20 62 69 6e 66 6f 43 6c 6f 73  ic int binfoClos
1820: 65 28 73 71 6c 69 74 65 33 5f 76 74 61 62 5f 63  e(sqlite3_vtab_c
1830: 75 72 73 6f 72 20 2a 70 43 75 72 73 6f 72 29 7b  ursor *pCursor){
1840: 0a 20 20 42 69 6e 66 6f 43 75 72 73 6f 72 20 2a  .  BinfoCursor *
1850: 70 43 73 72 20 3d 20 28 42 69 6e 66 6f 43 75 72  pCsr = (BinfoCur
1860: 73 6f 72 20 2a 29 70 43 75 72 73 6f 72 3b 0a 20  sor *)pCursor;. 
1870: 20 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a   sqlite3_finaliz
1880: 65 28 70 43 73 72 2d 3e 70 53 74 6d 74 29 3b 0a  e(pCsr->pStmt);.
1890: 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 70    sqlite3_free(p
18a0: 43 73 72 2d 3e 7a 53 63 68 65 6d 61 29 3b 0a 20  Csr->zSchema);. 
18b0: 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 70 43   sqlite3_free(pC
18c0: 73 72 29 3b 0a 20 20 72 65 74 75 72 6e 20 53 51  sr);.  return SQ
18d0: 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a  LITE_OK;.}../*.*
18e0: 2a 20 4d 6f 76 65 20 61 20 62 74 72 65 65 69 6e  * Move a btreein
18f0: 66 6f 20 63 75 72 73 6f 72 20 74 6f 20 74 68 65  fo cursor to the
1900: 20 6e 65 78 74 20 65 6e 74 72 79 20 69 6e 20 74   next entry in t
1910: 68 65 20 66 69 6c 65 2e 0a 2a 2f 0a 73 74 61 74  he file..*/.stat
1920: 69 63 20 69 6e 74 20 62 69 6e 66 6f 4e 65 78 74  ic int binfoNext
1930: 28 73 71 6c 69 74 65 33 5f 76 74 61 62 5f 63 75  (sqlite3_vtab_cu
1940: 72 73 6f 72 20 2a 70 43 75 72 73 6f 72 29 7b 0a  rsor *pCursor){.
1950: 20 20 42 69 6e 66 6f 43 75 72 73 6f 72 20 2a 70    BinfoCursor *p
1960: 43 73 72 20 3d 20 28 42 69 6e 66 6f 43 75 72 73  Csr = (BinfoCurs
1970: 6f 72 20 2a 29 70 43 75 72 73 6f 72 3b 0a 20 20  or *)pCursor;.  
1980: 70 43 73 72 2d 3e 72 63 20 3d 20 73 71 6c 69 74  pCsr->rc = sqlit
1990: 65 33 5f 73 74 65 70 28 70 43 73 72 2d 3e 70 53  e3_step(pCsr->pS
19a0: 74 6d 74 29 3b 0a 20 20 70 43 73 72 2d 3e 68 61  tmt);.  pCsr->ha
19b0: 73 52 6f 77 69 64 20 3d 20 2d 31 3b 0a 20 20 72  sRowid = -1;.  r
19c0: 65 74 75 72 6e 20 70 43 73 72 2d 3e 72 63 3d 3d  eturn pCsr->rc==
19d0: 53 51 4c 49 54 45 5f 45 52 52 4f 52 20 3f 20 53  SQLITE_ERROR ? S
19e0: 51 4c 49 54 45 5f 45 52 52 4f 52 20 3a 20 53 51  QLITE_ERROR : SQ
19f0: 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 20 57  LITE_OK;.}../* W
1a00: 65 20 68 61 76 65 20 72 65 61 63 68 65 64 20 45  e have reached E
1a10: 4f 46 20 69 66 20 70 72 65 76 69 6f 75 73 20 73  OF if previous s
1a20: 71 6c 69 74 65 33 5f 73 74 65 70 28 29 20 72 65  qlite3_step() re
1a30: 74 75 72 6e 65 64 0a 2a 2a 20 61 6e 79 74 68 69  turned.** anythi
1a40: 6e 67 20 6f 74 68 65 72 20 74 68 61 6e 20 53 51  ng other than SQ
1a50: 4c 49 54 45 5f 52 4f 57 3b 0a 2a 2f 0a 73 74 61  LITE_ROW;.*/.sta
1a60: 74 69 63 20 69 6e 74 20 62 69 6e 66 6f 45 6f 66  tic int binfoEof
1a70: 28 73 71 6c 69 74 65 33 5f 76 74 61 62 5f 63 75  (sqlite3_vtab_cu
1a80: 72 73 6f 72 20 2a 70 43 75 72 73 6f 72 29 7b 0a  rsor *pCursor){.
1a90: 20 20 42 69 6e 66 6f 43 75 72 73 6f 72 20 2a 70    BinfoCursor *p
1aa0: 43 73 72 20 3d 20 28 42 69 6e 66 6f 43 75 72 73  Csr = (BinfoCurs
1ab0: 6f 72 20 2a 29 70 43 75 72 73 6f 72 3b 0a 20 20  or *)pCursor;.  
1ac0: 72 65 74 75 72 6e 20 70 43 73 72 2d 3e 72 63 21  return pCsr->rc!
1ad0: 3d 53 51 4c 49 54 45 5f 52 4f 57 3b 0a 7d 0a 0a  =SQLITE_ROW;.}..
1ae0: 2f 2a 20 50 6f 73 69 74 69 6f 6e 20 61 20 63 75  /* Position a cu
1af0: 72 73 6f 72 20 62 61 63 6b 20 74 6f 20 74 68 65  rsor back to the
1b00: 20 62 65 67 69 6e 6e 69 6e 67 2e 0a 2a 2f 0a 73   beginning..*/.s
1b10: 74 61 74 69 63 20 69 6e 74 20 62 69 6e 66 6f 46  tatic int binfoF
1b20: 69 6c 74 65 72 28 0a 20 20 73 71 6c 69 74 65 33  ilter(.  sqlite3
1b30: 5f 76 74 61 62 5f 63 75 72 73 6f 72 20 2a 70 43  _vtab_cursor *pC
1b40: 75 72 73 6f 72 2c 20 0a 20 20 69 6e 74 20 69 64  ursor, .  int id
1b50: 78 4e 75 6d 2c 20 63 6f 6e 73 74 20 63 68 61 72  xNum, const char
1b60: 20 2a 69 64 78 53 74 72 2c 0a 20 20 69 6e 74 20   *idxStr,.  int 
1b70: 61 72 67 63 2c 20 73 71 6c 69 74 65 33 5f 76 61  argc, sqlite3_va
1b80: 6c 75 65 20 2a 2a 61 72 67 76 0a 29 7b 0a 20 20  lue **argv.){.  
1b90: 42 69 6e 66 6f 43 75 72 73 6f 72 20 2a 70 43 73  BinfoCursor *pCs
1ba0: 72 20 3d 20 28 42 69 6e 66 6f 43 75 72 73 6f 72  r = (BinfoCursor
1bb0: 20 2a 29 70 43 75 72 73 6f 72 3b 0a 20 20 42 69   *)pCursor;.  Bi
1bc0: 6e 66 6f 54 61 62 6c 65 20 2a 70 54 61 62 20 3d  nfoTable *pTab =
1bd0: 20 28 42 69 6e 66 6f 54 61 62 6c 65 20 2a 29 70   (BinfoTable *)p
1be0: 43 75 72 73 6f 72 2d 3e 70 56 74 61 62 3b 0a 20  Cursor->pVtab;. 
1bf0: 20 63 68 61 72 20 2a 7a 53 71 6c 3b 0a 20 20 69   char *zSql;.  i
1c00: 6e 74 20 72 63 3b 0a 0a 20 20 73 71 6c 69 74 65  nt rc;..  sqlite
1c10: 33 5f 66 72 65 65 28 70 43 73 72 2d 3e 7a 53 63  3_free(pCsr->zSc
1c20: 68 65 6d 61 29 3b 0a 20 20 69 66 28 20 69 64 78  hema);.  if( idx
1c30: 4e 75 6d 3d 3d 31 20 26 26 20 73 71 6c 69 74 65  Num==1 && sqlite
1c40: 33 5f 76 61 6c 75 65 5f 74 79 70 65 28 61 72 67  3_value_type(arg
1c50: 76 5b 30 5d 29 21 3d 53 51 4c 49 54 45 5f 4e 55  v[0])!=SQLITE_NU
1c60: 4c 4c 20 29 7b 0a 20 20 20 20 70 43 73 72 2d 3e  LL ){.    pCsr->
1c70: 7a 53 63 68 65 6d 61 20 3d 20 73 71 6c 69 74 65  zSchema = sqlite
1c80: 33 5f 6d 70 72 69 6e 74 66 28 22 25 73 22 2c 20  3_mprintf("%s", 
1c90: 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74 65  sqlite3_value_te
1ca0: 78 74 28 61 72 67 76 5b 30 5d 29 29 3b 0a 20 20  xt(argv[0]));.  
1cb0: 7d 65 6c 73 65 7b 0a 20 20 20 20 70 43 73 72 2d  }else{.    pCsr-
1cc0: 3e 7a 53 63 68 65 6d 61 20 3d 20 73 71 6c 69 74  >zSchema = sqlit
1cd0: 65 33 5f 6d 70 72 69 6e 74 66 28 22 6d 61 69 6e  e3_mprintf("main
1ce0: 22 29 3b 0a 20 20 7d 0a 20 20 7a 53 71 6c 20 3d  ");.  }.  zSql =
1cf0: 20 73 71 6c 69 74 65 33 5f 6d 70 72 69 6e 74 66   sqlite3_mprintf
1d00: 28 0a 20 20 20 20 20 20 22 53 45 4c 45 43 54 20  (.      "SELECT 
1d10: 30 2c 20 27 74 61 62 6c 65 27 2c 27 73 71 6c 69  0, 'table','sqli
1d20: 74 65 5f 6d 61 73 74 65 72 27 2c 27 73 71 6c 69  te_master','sqli
1d30: 74 65 5f 6d 61 73 74 65 72 27 2c 31 2c 4e 55 4c  te_master',1,NUL
1d40: 4c 20 22 0a 20 20 20 20 20 20 22 55 4e 49 4f 4e  L ".      "UNION
1d50: 20 41 4c 4c 20 22 0a 20 20 20 20 20 20 22 53 45   ALL ".      "SE
1d60: 4c 45 43 54 20 72 6f 77 69 64 2c 20 74 79 70 65  LECT rowid, type
1d70: 2c 20 6e 61 6d 65 2c 20 74 62 6c 5f 6e 61 6d 65  , name, tbl_name
1d80: 2c 20 72 6f 6f 74 70 61 67 65 2c 20 73 71 6c 22  , rootpage, sql"
1d90: 0a 20 20 20 20 20 20 22 20 46 52 4f 4d 20 5c 22  .      " FROM \"
1da0: 25 77 5c 22 2e 73 71 6c 69 74 65 5f 6d 61 73 74  %w\".sqlite_mast
1db0: 65 72 20 57 48 45 52 45 20 72 6f 6f 74 70 61 67  er WHERE rootpag
1dc0: 65 3e 3d 31 22 2c 0a 20 20 20 20 20 20 20 70 43  e>=1",.       pC
1dd0: 73 72 2d 3e 7a 53 63 68 65 6d 61 29 3b 0a 20 20  sr->zSchema);.  
1de0: 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65  sqlite3_finalize
1df0: 28 70 43 73 72 2d 3e 70 53 74 6d 74 29 3b 0a 20  (pCsr->pStmt);. 
1e00: 20 70 43 73 72 2d 3e 70 53 74 6d 74 20 3d 20 30   pCsr->pStmt = 0
1e10: 3b 0a 20 20 70 43 73 72 2d 3e 68 61 73 52 6f 77  ;.  pCsr->hasRow
1e20: 69 64 20 3d 20 2d 31 3b 0a 20 20 72 63 20 3d 20  id = -1;.  rc = 
1e30: 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f  sqlite3_prepare_
1e40: 76 32 28 70 54 61 62 2d 3e 64 62 2c 20 7a 53 71  v2(pTab->db, zSq
1e50: 6c 2c 20 2d 31 2c 20 26 70 43 73 72 2d 3e 70 53  l, -1, &pCsr->pS
1e60: 74 6d 74 2c 20 30 29 3b 0a 20 20 73 71 6c 69 74  tmt, 0);.  sqlit
1e70: 65 33 5f 66 72 65 65 28 7a 53 71 6c 29 3b 0a 20  e3_free(zSql);. 
1e80: 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f   if( rc==SQLITE_
1e90: 4f 4b 20 29 7b 0a 20 20 20 20 72 63 20 3d 20 62  OK ){.    rc = b
1ea0: 69 6e 66 6f 4e 65 78 74 28 70 43 75 72 73 6f 72  infoNext(pCursor
1eb0: 29 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20  );.  }.  return 
1ec0: 72 63 3b 0a 7d 0a 0a 2f 2a 20 44 65 63 6f 64 65  rc;.}../* Decode
1ed0: 20 62 69 67 2d 65 6e 64 69 61 6e 20 69 6e 74 65   big-endian inte
1ee0: 67 65 72 73 20 2a 2f 0a 73 74 61 74 69 63 20 75  gers */.static u
1ef0: 6e 73 69 67 6e 65 64 20 69 6e 74 20 67 65 74 5f  nsigned int get_
1f00: 75 69 6e 74 31 36 28 75 6e 73 69 67 6e 65 64 20  uint16(unsigned 
1f10: 63 68 61 72 20 2a 61 29 7b 0a 20 20 72 65 74 75  char *a){.  retu
1f20: 72 6e 20 28 61 5b 30 5d 3c 3c 38 29 7c 61 5b 31  rn (a[0]<<8)|a[1
1f30: 5d 3b 0a 7d 0a 73 74 61 74 69 63 20 75 6e 73 69  ];.}.static unsi
1f40: 67 6e 65 64 20 69 6e 74 20 67 65 74 5f 75 69 6e  gned int get_uin
1f50: 74 33 32 28 75 6e 73 69 67 6e 65 64 20 63 68 61  t32(unsigned cha
1f60: 72 20 2a 61 29 7b 0a 20 20 72 65 74 75 72 6e 20  r *a){.  return 
1f70: 28 61 5b 30 5d 3c 3c 32 34 29 7c 28 61 5b 31 5d  (a[0]<<24)|(a[1]
1f80: 3c 3c 31 36 29 7c 28 61 5b 32 5d 3c 3c 38 29 7c  <<16)|(a[2]<<8)|
1f90: 61 5b 33 5d 3b 0a 7d 0a 0a 2f 2a 20 45 78 61 6d  a[3];.}../* Exam
1fa0: 69 6e 65 20 74 68 65 20 62 2d 74 72 65 65 20 72  ine the b-tree r
1fb0: 6f 6f 74 65 64 20 61 74 20 70 67 6e 6f 20 61 6e  ooted at pgno an
1fc0: 64 20 65 73 74 69 6d 61 74 65 20 69 74 73 20 73  d estimate its s
1fd0: 69 7a 65 2e 0a 2a 2a 20 52 65 74 75 72 6e 20 6e  ize..** Return n
1fe0: 6f 6e 2d 7a 65 72 6f 20 69 66 20 61 6e 79 74 68  on-zero if anyth
1ff0: 69 6e 67 20 67 6f 65 73 20 77 72 6f 6e 67 2e 0a  ing goes wrong..
2000: 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 62 69  */.static int bi
2010: 6e 66 6f 43 6f 6d 70 75 74 65 28 73 71 6c 69 74  nfoCompute(sqlit
2020: 65 33 20 2a 64 62 2c 20 69 6e 74 20 70 67 6e 6f  e3 *db, int pgno
2030: 2c 20 42 69 6e 66 6f 43 75 72 73 6f 72 20 2a 70  , BinfoCursor *p
2040: 43 73 72 29 7b 0a 20 20 73 71 6c 69 74 65 33 5f  Csr){.  sqlite3_
2050: 69 6e 74 36 34 20 6e 45 6e 74 72 79 20 3d 20 31  int64 nEntry = 1
2060: 3b 0a 20 20 69 6e 74 20 6e 50 61 67 65 20 3d 20  ;.  int nPage = 
2070: 31 3b 0a 20 20 75 6e 73 69 67 6e 65 64 20 63 68  1;.  unsigned ch
2080: 61 72 20 2a 61 44 61 74 61 3b 0a 20 20 73 71 6c  ar *aData;.  sql
2090: 69 74 65 33 5f 73 74 6d 74 20 2a 70 53 74 6d 74  ite3_stmt *pStmt
20a0: 20 3d 20 30 3b 0a 20 20 69 6e 74 20 72 63 20 3d   = 0;.  int rc =
20b0: 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 69 6e   SQLITE_OK;.  in
20c0: 74 20 70 67 73 7a 20 3d 20 30 3b 0a 20 20 69 6e  t pgsz = 0;.  in
20d0: 74 20 6e 43 65 6c 6c 3b 0a 20 20 69 6e 74 20 69  t nCell;.  int i
20e0: 43 65 6c 6c 3b 0a 0a 20 20 72 63 20 3d 20 73 71  Cell;..  rc = sq
20f0: 6c 69 74 65 33 5f 70 72 65 70 61 72 65 5f 76 32  lite3_prepare_v2
2100: 28 64 62 2c 20 0a 20 20 20 20 20 20 20 20 20 20  (db, .          
2110: 20 22 53 45 4c 45 43 54 20 64 61 74 61 20 46 52   "SELECT data FR
2120: 4f 4d 20 73 71 6c 69 74 65 5f 64 62 70 61 67 65  OM sqlite_dbpage
2130: 28 27 6d 61 69 6e 27 29 20 57 48 45 52 45 20 70  ('main') WHERE p
2140: 67 6e 6f 3d 3f 31 22 2c 20 2d 31 2c 0a 20 20 20  gno=?1", -1,.   
2150: 20 20 20 20 20 20 20 20 26 70 53 74 6d 74 2c 20          &pStmt, 
2160: 30 29 3b 0a 20 20 69 66 28 20 72 63 20 29 20 72  0);.  if( rc ) r
2170: 65 74 75 72 6e 20 72 63 3b 0a 20 20 70 43 73 72  eturn rc;.  pCsr
2180: 2d 3e 64 65 70 74 68 20 3d 20 31 3b 0a 20 20 77  ->depth = 1;.  w
2190: 68 69 6c 65 28 31 29 7b 0a 20 20 20 20 73 71 6c  hile(1){.    sql
21a0: 69 74 65 33 5f 62 69 6e 64 5f 69 6e 74 28 70 53  ite3_bind_int(pS
21b0: 74 6d 74 2c 20 31 2c 20 70 67 6e 6f 29 3b 0a 20  tmt, 1, pgno);. 
21c0: 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f     rc = sqlite3_
21d0: 73 74 65 70 28 70 53 74 6d 74 29 3b 0a 20 20 20  step(pStmt);.   
21e0: 20 69 66 28 20 72 63 21 3d 53 51 4c 49 54 45 5f   if( rc!=SQLITE_
21f0: 52 4f 57 20 29 7b 0a 20 20 20 20 20 20 72 63 20  ROW ){.      rc 
2200: 3d 20 53 51 4c 49 54 45 5f 45 52 52 4f 52 3b 0a  = SQLITE_ERROR;.
2210: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
2220: 20 7d 0a 20 20 20 20 70 43 73 72 2d 3e 73 7a 50   }.    pCsr->szP
2230: 61 67 65 20 3d 20 70 67 73 7a 20 3d 20 73 71 6c  age = pgsz = sql
2240: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 62 79 74 65  ite3_column_byte
2250: 73 28 70 53 74 6d 74 2c 20 30 29 3b 0a 20 20 20  s(pStmt, 0);.   
2260: 20 61 44 61 74 61 20 3d 20 28 75 6e 73 69 67 6e   aData = (unsign
2270: 65 64 20 63 68 61 72 2a 29 73 71 6c 69 74 65 33  ed char*)sqlite3
2280: 5f 63 6f 6c 75 6d 6e 5f 62 6c 6f 62 28 70 53 74  _column_blob(pSt
2290: 6d 74 2c 20 30 29 3b 0a 20 20 20 20 69 66 28 20  mt, 0);.    if( 
22a0: 61 44 61 74 61 3d 3d 30 20 29 7b 20 20 20 20 0a  aData==0 ){    .
22b0: 20 20 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54        rc = SQLIT
22c0: 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 20 20 20 20 62  E_NOMEM;.      b
22d0: 72 65 61 6b 3b 0a 20 20 20 20 7d 0a 20 20 20 20  reak;.    }.    
22e0: 69 66 28 20 70 67 6e 6f 3d 3d 31 20 29 7b 0a 20  if( pgno==1 ){. 
22f0: 20 20 20 20 20 61 44 61 74 61 20 2b 3d 20 31 30       aData += 10
2300: 30 3b 0a 20 20 20 20 20 20 70 67 73 7a 20 2d 3d  0;.      pgsz -=
2310: 20 31 30 30 3b 0a 20 20 20 20 7d 0a 20 20 20 20   100;.    }.    
2320: 70 43 73 72 2d 3e 68 61 73 52 6f 77 69 64 20 3d  pCsr->hasRowid =
2330: 20 61 44 61 74 61 5b 30 5d 21 3d 32 20 26 26 20   aData[0]!=2 && 
2340: 61 44 61 74 61 5b 30 5d 21 3d 31 30 3b 0a 20 20  aData[0]!=10;.  
2350: 20 20 6e 43 65 6c 6c 20 3d 20 67 65 74 5f 75 69    nCell = get_ui
2360: 6e 74 31 36 28 61 44 61 74 61 2b 33 29 3b 0a 20  nt16(aData+3);. 
2370: 20 20 20 6e 45 6e 74 72 79 20 2a 3d 20 28 6e 43     nEntry *= (nC
2380: 65 6c 6c 2b 31 29 3b 0a 20 20 20 20 69 66 28 20  ell+1);.    if( 
2390: 61 44 61 74 61 5b 30 5d 3d 3d 31 30 20 7c 7c 20  aData[0]==10 || 
23a0: 61 44 61 74 61 5b 30 5d 3d 3d 31 33 20 29 20 62  aData[0]==13 ) b
23b0: 72 65 61 6b 3b 0a 20 20 20 20 6e 50 61 67 65 20  reak;.    nPage 
23c0: 2a 3d 20 28 6e 43 65 6c 6c 2b 31 29 3b 0a 20 20  *= (nCell+1);.  
23d0: 20 20 69 66 28 20 6e 43 65 6c 6c 3c 3d 31 20 29    if( nCell<=1 )
23e0: 7b 0a 20 20 20 20 20 20 70 67 6e 6f 20 3d 20 67  {.      pgno = g
23f0: 65 74 5f 75 69 6e 74 33 32 28 61 44 61 74 61 2b  et_uint32(aData+
2400: 38 29 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20  8);.    }else{. 
2410: 20 20 20 20 20 69 43 65 6c 6c 20 3d 20 67 65 74       iCell = get
2420: 5f 75 69 6e 74 31 36 28 61 44 61 74 61 2b 31 32  _uint16(aData+12
2430: 2b 32 2a 28 6e 43 65 6c 6c 2f 32 29 29 3b 0a 20  +2*(nCell/2));. 
2440: 20 20 20 20 20 69 66 28 20 70 67 6e 6f 3d 3d 31       if( pgno==1
2450: 20 29 20 69 43 65 6c 6c 20 2d 3d 20 31 30 30 3b   ) iCell -= 100;
2460: 0a 20 20 20 20 20 20 69 66 28 20 69 43 65 6c 6c  .      if( iCell
2470: 3c 3d 31 32 20 7c 7c 20 69 43 65 6c 6c 3e 3d 70  <=12 || iCell>=p
2480: 67 73 7a 2d 34 20 29 7b 0a 20 20 20 20 20 20 20  gsz-4 ){.       
2490: 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 43 4f 52   rc = SQLITE_COR
24a0: 52 55 50 54 3b 0a 20 20 20 20 20 20 20 20 62 72  RUPT;.        br
24b0: 65 61 6b 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  eak;.      }.   
24c0: 20 20 20 70 67 6e 6f 20 3d 20 67 65 74 5f 75 69     pgno = get_ui
24d0: 6e 74 33 32 28 61 44 61 74 61 2b 69 43 65 6c 6c  nt32(aData+iCell
24e0: 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 70 43 73  );.    }.    pCs
24f0: 72 2d 3e 64 65 70 74 68 2b 2b 3b 0a 20 20 20 20  r->depth++;.    
2500: 73 71 6c 69 74 65 33 5f 72 65 73 65 74 28 70 53  sqlite3_reset(pS
2510: 74 6d 74 29 3b 0a 20 20 7d 0a 20 20 73 71 6c 69  tmt);.  }.  sqli
2520: 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70 53 74  te3_finalize(pSt
2530: 6d 74 29 3b 0a 20 20 70 43 73 72 2d 3e 6e 50 61  mt);.  pCsr->nPa
2540: 67 65 20 3d 20 6e 50 61 67 65 3b 0a 20 20 70 43  ge = nPage;.  pC
2550: 73 72 2d 3e 6e 45 6e 74 72 79 20 3d 20 6e 45 6e  sr->nEntry = nEn
2560: 74 72 79 3b 0a 20 20 69 66 28 20 72 63 3d 3d 53  try;.  if( rc==S
2570: 51 4c 49 54 45 5f 52 4f 57 20 29 20 72 63 20 3d  QLITE_ROW ) rc =
2580: 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 72 65   SQLITE_OK;.  re
2590: 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 20 52  turn rc;.}../* R
25a0: 65 74 75 72 6e 20 61 20 63 6f 6c 75 6d 6e 20 66  eturn a column f
25b0: 6f 72 20 74 68 65 20 73 71 6c 69 74 65 5f 62 74  or the sqlite_bt
25c0: 72 65 65 69 6e 66 6f 20 74 61 62 6c 65 20 2a 2f  reeinfo table */
25d0: 0a 73 74 61 74 69 63 20 69 6e 74 20 62 69 6e 66  .static int binf
25e0: 6f 43 6f 6c 75 6d 6e 28 0a 20 20 73 71 6c 69 74  oColumn(.  sqlit
25f0: 65 33 5f 76 74 61 62 5f 63 75 72 73 6f 72 20 2a  e3_vtab_cursor *
2600: 70 43 75 72 73 6f 72 2c 20 0a 20 20 73 71 6c 69  pCursor, .  sqli
2610: 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 63 74 78  te3_context *ctx
2620: 2c 20 0a 20 20 69 6e 74 20 69 0a 29 7b 0a 20 20  , .  int i.){.  
2630: 42 69 6e 66 6f 43 75 72 73 6f 72 20 2a 70 43 73  BinfoCursor *pCs
2640: 72 20 3d 20 28 42 69 6e 66 6f 43 75 72 73 6f 72  r = (BinfoCursor
2650: 20 2a 29 70 43 75 72 73 6f 72 3b 0a 20 20 69 66   *)pCursor;.  if
2660: 28 20 69 3e 3d 42 49 4e 46 4f 5f 43 4f 4c 55 4d  ( i>=BINFO_COLUM
2670: 4e 5f 48 41 53 52 4f 57 49 44 20 26 26 20 69 3c  N_HASROWID && i<
2680: 3d 42 49 4e 46 4f 5f 43 4f 4c 55 4d 4e 5f 53 5a  =BINFO_COLUMN_SZ
2690: 50 41 47 45 20 26 26 20 70 43 73 72 2d 3e 68 61  PAGE && pCsr->ha
26a0: 73 52 6f 77 69 64 3c 30 20 29 7b 0a 20 20 20 20  sRowid<0 ){.    
26b0: 69 6e 74 20 70 67 6e 6f 20 3d 20 73 71 6c 69 74  int pgno = sqlit
26c0: 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 28 70 43  e3_column_int(pC
26d0: 73 72 2d 3e 70 53 74 6d 74 2c 20 42 49 4e 46 4f  sr->pStmt, BINFO
26e0: 5f 43 4f 4c 55 4d 4e 5f 52 4f 4f 54 50 41 47 45  _COLUMN_ROOTPAGE
26f0: 2b 31 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33  +1);.    sqlite3
2700: 20 2a 64 62 20 3d 20 73 71 6c 69 74 65 33 5f 63   *db = sqlite3_c
2710: 6f 6e 74 65 78 74 5f 64 62 5f 68 61 6e 64 6c 65  ontext_db_handle
2720: 28 63 74 78 29 3b 0a 20 20 20 20 69 6e 74 20 72  (ctx);.    int r
2730: 63 20 3d 20 62 69 6e 66 6f 43 6f 6d 70 75 74 65  c = binfoCompute
2740: 28 64 62 2c 20 70 67 6e 6f 2c 20 70 43 73 72 29  (db, pgno, pCsr)
2750: 3b 0a 20 20 20 20 69 66 28 20 72 63 20 29 7b 0a  ;.    if( rc ){.
2760: 20 20 20 20 20 20 70 43 75 72 73 6f 72 2d 3e 70        pCursor->p
2770: 56 74 61 62 2d 3e 7a 45 72 72 4d 73 67 20 3d 20  Vtab->zErrMsg = 
2780: 73 71 6c 69 74 65 33 5f 6d 70 72 69 6e 74 66 28  sqlite3_mprintf(
2790: 22 25 73 22 2c 20 73 71 6c 69 74 65 33 5f 65 72  "%s", sqlite3_er
27a0: 72 6d 73 67 28 64 62 29 29 3b 0a 20 20 20 20 20  rmsg(db));.     
27b0: 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 45   return SQLITE_E
27c0: 52 52 4f 52 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a  RROR;.    }.  }.
27d0: 20 20 73 77 69 74 63 68 28 20 69 20 29 7b 0a 20    switch( i ){. 
27e0: 20 20 20 63 61 73 65 20 42 49 4e 46 4f 5f 43 4f     case BINFO_CO
27f0: 4c 55 4d 4e 5f 4e 41 4d 45 3a 0a 20 20 20 20 63  LUMN_NAME:.    c
2800: 61 73 65 20 42 49 4e 46 4f 5f 43 4f 4c 55 4d 4e  ase BINFO_COLUMN
2810: 5f 54 59 50 45 3a 0a 20 20 20 20 63 61 73 65 20  _TYPE:.    case 
2820: 42 49 4e 46 4f 5f 43 4f 4c 55 4d 4e 5f 54 42 4c  BINFO_COLUMN_TBL
2830: 5f 4e 41 4d 45 3a 0a 20 20 20 20 63 61 73 65 20  _NAME:.    case 
2840: 42 49 4e 46 4f 5f 43 4f 4c 55 4d 4e 5f 52 4f 4f  BINFO_COLUMN_ROO
2850: 54 50 41 47 45 3a 0a 20 20 20 20 63 61 73 65 20  TPAGE:.    case 
2860: 42 49 4e 46 4f 5f 43 4f 4c 55 4d 4e 5f 53 51 4c  BINFO_COLUMN_SQL
2870: 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  : {.      sqlite
2880: 33 5f 72 65 73 75 6c 74 5f 76 61 6c 75 65 28 63  3_result_value(c
2890: 74 78 2c 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75  tx, sqlite3_colu
28a0: 6d 6e 5f 76 61 6c 75 65 28 70 43 73 72 2d 3e 70  mn_value(pCsr->p
28b0: 53 74 6d 74 2c 20 69 2b 31 29 29 3b 0a 20 20 20  Stmt, i+1));.   
28c0: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a     break;.    }.
28d0: 20 20 20 20 63 61 73 65 20 42 49 4e 46 4f 5f 43      case BINFO_C
28e0: 4f 4c 55 4d 4e 5f 48 41 53 52 4f 57 49 44 3a 20  OLUMN_HASROWID: 
28f0: 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f  {.      sqlite3_
2900: 72 65 73 75 6c 74 5f 69 6e 74 28 63 74 78 2c 20  result_int(ctx, 
2910: 70 43 73 72 2d 3e 68 61 73 52 6f 77 69 64 29 3b  pCsr->hasRowid);
2920: 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  .      break;.  
2930: 20 20 7d 0a 20 20 20 20 63 61 73 65 20 42 49 4e    }.    case BIN
2940: 46 4f 5f 43 4f 4c 55 4d 4e 5f 4e 45 4e 54 52 59  FO_COLUMN_NENTRY
2950: 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65  : {.      sqlite
2960: 33 5f 72 65 73 75 6c 74 5f 69 6e 74 36 34 28 63  3_result_int64(c
2970: 74 78 2c 20 70 43 73 72 2d 3e 6e 45 6e 74 72 79  tx, pCsr->nEntry
2980: 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  );.      break;.
2990: 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 42      }.    case B
29a0: 49 4e 46 4f 5f 43 4f 4c 55 4d 4e 5f 4e 50 41 47  INFO_COLUMN_NPAG
29b0: 45 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74  E: {.      sqlit
29c0: 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74 28 63 74  e3_result_int(ct
29d0: 78 2c 20 70 43 73 72 2d 3e 6e 50 61 67 65 29 3b  x, pCsr->nPage);
29e0: 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  .      break;.  
29f0: 20 20 7d 0a 20 20 20 20 63 61 73 65 20 42 49 4e    }.    case BIN
2a00: 46 4f 5f 43 4f 4c 55 4d 4e 5f 44 45 50 54 48 3a  FO_COLUMN_DEPTH:
2a10: 20 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33   {.      sqlite3
2a20: 5f 72 65 73 75 6c 74 5f 69 6e 74 28 63 74 78 2c  _result_int(ctx,
2a30: 20 70 43 73 72 2d 3e 64 65 70 74 68 29 3b 0a 20   pCsr->depth);. 
2a40: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
2a50: 7d 0a 20 20 20 20 63 61 73 65 20 42 49 4e 46 4f  }.    case BINFO
2a60: 5f 43 4f 4c 55 4d 4e 5f 53 43 48 45 4d 41 3a 20  _COLUMN_SCHEMA: 
2a70: 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f  {.      sqlite3_
2a80: 72 65 73 75 6c 74 5f 74 65 78 74 28 63 74 78 2c  result_text(ctx,
2a90: 20 70 43 73 72 2d 3e 7a 53 63 68 65 6d 61 2c 20   pCsr->zSchema, 
2aa0: 2d 31 2c 20 53 51 4c 49 54 45 5f 53 54 41 54 49  -1, SQLITE_STATI
2ab0: 43 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b  C);.      break;
2ac0: 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 72 65 74  .    }.  }.  ret
2ad0: 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d  urn SQLITE_OK;.}
2ae0: 0a 0a 2f 2a 20 52 65 74 75 72 6e 20 74 68 65 20  ../* Return the 
2af0: 52 4f 57 49 44 20 66 6f 72 20 74 68 65 20 73 71  ROWID for the sq
2b00: 6c 69 74 65 5f 62 74 72 65 65 69 6e 66 6f 20 74  lite_btreeinfo t
2b10: 61 62 6c 65 20 2a 2f 0a 73 74 61 74 69 63 20 69  able */.static i
2b20: 6e 74 20 62 69 6e 66 6f 52 6f 77 69 64 28 73 71  nt binfoRowid(sq
2b30: 6c 69 74 65 33 5f 76 74 61 62 5f 63 75 72 73 6f  lite3_vtab_curso
2b40: 72 20 2a 70 43 75 72 73 6f 72 2c 20 73 71 6c 69  r *pCursor, sqli
2b50: 74 65 5f 69 6e 74 36 34 20 2a 70 52 6f 77 69 64  te_int64 *pRowid
2b60: 29 7b 0a 20 20 42 69 6e 66 6f 43 75 72 73 6f 72  ){.  BinfoCursor
2b70: 20 2a 70 43 73 72 20 3d 20 28 42 69 6e 66 6f 43   *pCsr = (BinfoC
2b80: 75 72 73 6f 72 20 2a 29 70 43 75 72 73 6f 72 3b  ursor *)pCursor;
2b90: 0a 20 20 2a 70 52 6f 77 69 64 20 3d 20 73 71 6c  .  *pRowid = sql
2ba0: 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 36  ite3_column_int6
2bb0: 34 28 70 43 73 72 2d 3e 70 53 74 6d 74 2c 20 30  4(pCsr->pStmt, 0
2bc0: 29 3b 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49  );.  return SQLI
2bd0: 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20  TE_OK;.}../*.** 
2be0: 49 6e 76 6f 6b 65 20 74 68 69 73 20 72 6f 75 74  Invoke this rout
2bf0: 69 6e 65 20 74 6f 20 72 65 67 69 73 74 65 72 20  ine to register 
2c00: 74 68 65 20 22 73 71 6c 69 74 65 5f 62 74 72 65  the "sqlite_btre
2c10: 65 69 6e 66 6f 22 20 76 69 72 74 75 61 6c 20 74  einfo" virtual t
2c20: 61 62 6c 65 20 6d 6f 64 75 6c 65 0a 2a 2f 0a 69  able module.*/.i
2c30: 6e 74 20 73 71 6c 69 74 65 33 42 69 6e 66 6f 52  nt sqlite3BinfoR
2c40: 65 67 69 73 74 65 72 28 73 71 6c 69 74 65 33 20  egister(sqlite3 
2c50: 2a 64 62 29 7b 0a 20 20 73 74 61 74 69 63 20 73  *db){.  static s
2c60: 71 6c 69 74 65 33 5f 6d 6f 64 75 6c 65 20 62 69  qlite3_module bi
2c70: 6e 66 6f 5f 6d 6f 64 75 6c 65 20 3d 20 7b 0a 20  nfo_module = {. 
2c80: 20 20 20 30 2c 20 20 20 20 20 20 20 20 20 20 20     0,           
2c90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2ca0: 2f 2a 20 69 56 65 72 73 69 6f 6e 20 2a 2f 0a 20  /* iVersion */. 
2cb0: 20 20 20 30 2c 20 20 20 20 20 20 20 20 20 20 20     0,           
2cc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2cd0: 2f 2a 20 78 43 72 65 61 74 65 20 2a 2f 0a 20 20  /* xCreate */.  
2ce0: 20 20 62 69 6e 66 6f 43 6f 6e 6e 65 63 74 2c 20    binfoConnect, 
2cf0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
2d00: 2a 20 78 43 6f 6e 6e 65 63 74 20 2a 2f 0a 20 20  * xConnect */.  
2d10: 20 20 62 69 6e 66 6f 42 65 73 74 49 6e 64 65 78    binfoBestIndex
2d20: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  ,              /
2d30: 2a 20 78 42 65 73 74 49 6e 64 65 78 20 2a 2f 0a  * xBestIndex */.
2d40: 20 20 20 20 62 69 6e 66 6f 44 69 73 63 6f 6e 6e      binfoDisconn
2d50: 65 63 74 2c 20 20 20 20 20 20 20 20 20 20 20 20  ect,            
2d60: 20 2f 2a 20 78 44 69 73 63 6f 6e 6e 65 63 74 20   /* xDisconnect 
2d70: 2a 2f 0a 20 20 20 20 30 2c 20 20 20 20 20 20 20  */.    0,       
2d80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2d90: 20 20 20 20 2f 2a 20 78 44 65 73 74 72 6f 79 20      /* xDestroy 
2da0: 2a 2f 0a 20 20 20 20 62 69 6e 66 6f 4f 70 65 6e  */.    binfoOpen
2db0: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,               
2dc0: 20 20 20 20 2f 2a 20 78 4f 70 65 6e 20 2d 20 6f      /* xOpen - o
2dd0: 70 65 6e 20 61 20 63 75 72 73 6f 72 20 2a 2f 0a  pen a cursor */.
2de0: 20 20 20 20 62 69 6e 66 6f 43 6c 6f 73 65 2c 20      binfoClose, 
2df0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2e00: 20 2f 2a 20 78 43 6c 6f 73 65 20 2d 20 63 6c 6f   /* xClose - clo
2e10: 73 65 20 61 20 63 75 72 73 6f 72 20 2a 2f 0a 20  se a cursor */. 
2e20: 20 20 20 62 69 6e 66 6f 46 69 6c 74 65 72 2c 20     binfoFilter, 
2e30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2e40: 2f 2a 20 78 46 69 6c 74 65 72 20 2d 20 63 6f 6e  /* xFilter - con
2e50: 66 69 67 75 72 65 20 73 63 61 6e 20 63 6f 6e 73  figure scan cons
2e60: 74 72 61 69 6e 74 73 20 2a 2f 0a 20 20 20 20 62  traints */.    b
2e70: 69 6e 66 6f 4e 65 78 74 2c 20 20 20 20 20 20 20  infoNext,       
2e80: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78              /* x
2e90: 4e 65 78 74 20 2d 20 61 64 76 61 6e 63 65 20 61  Next - advance a
2ea0: 20 63 75 72 73 6f 72 20 2a 2f 0a 20 20 20 20 62   cursor */.    b
2eb0: 69 6e 66 6f 45 6f 66 2c 20 20 20 20 20 20 20 20  infoEof,        
2ec0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78              /* x
2ed0: 45 6f 66 20 2d 20 63 68 65 63 6b 20 66 6f 72 20  Eof - check for 
2ee0: 65 6e 64 20 6f 66 20 73 63 61 6e 20 2a 2f 0a 20  end of scan */. 
2ef0: 20 20 20 62 69 6e 66 6f 43 6f 6c 75 6d 6e 2c 20     binfoColumn, 
2f00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2f10: 2f 2a 20 78 43 6f 6c 75 6d 6e 20 2d 20 72 65 61  /* xColumn - rea
2f20: 64 20 64 61 74 61 20 2a 2f 0a 20 20 20 20 62 69  d data */.    bi
2f30: 6e 66 6f 52 6f 77 69 64 2c 20 20 20 20 20 20 20  nfoRowid,       
2f40: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 52             /* xR
2f50: 6f 77 69 64 20 2d 20 72 65 61 64 20 64 61 74 61  owid - read data
2f60: 20 2a 2f 0a 20 20 20 20 30 2c 20 20 20 20 20 20   */.    0,      
2f70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2f80: 20 20 20 20 20 2f 2a 20 78 55 70 64 61 74 65 20       /* xUpdate 
2f90: 2a 2f 0a 20 20 20 20 30 2c 20 20 20 20 20 20 20  */.    0,       
2fa0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2fb0: 20 20 20 20 2f 2a 20 78 42 65 67 69 6e 20 2a 2f      /* xBegin */
2fc0: 0a 20 20 20 20 30 2c 20 20 20 20 20 20 20 20 20  .    0,         
2fd0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2fe0: 20 20 2f 2a 20 78 53 79 6e 63 20 2a 2f 0a 20 20    /* xSync */.  
2ff0: 20 20 30 2c 20 20 20 20 20 20 20 20 20 20 20 20    0,            
3000: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
3010: 2a 20 78 43 6f 6d 6d 69 74 20 2a 2f 0a 20 20 20  * xCommit */.   
3020: 20 30 2c 20 20 20 20 20 20 20 20 20 20 20 20 20   0,             
3030: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
3040: 20 78 52 6f 6c 6c 62 61 63 6b 20 2a 2f 0a 20 20   xRollback */.  
3050: 20 20 30 2c 20 20 20 20 20 20 20 20 20 20 20 20    0,            
3060: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
3070: 2a 20 78 46 69 6e 64 4d 65 74 68 6f 64 20 2a 2f  * xFindMethod */
3080: 0a 20 20 20 20 30 2c 20 20 20 20 20 20 20 20 20  .    0,         
3090: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
30a0: 20 20 2f 2a 20 78 52 65 6e 61 6d 65 20 2a 2f 0a    /* xRename */.
30b0: 20 20 20 20 30 2c 20 20 20 20 20 20 20 20 20 20      0,          
30c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
30d0: 20 2f 2a 20 78 53 61 76 65 70 6f 69 6e 74 20 2a   /* xSavepoint *
30e0: 2f 0a 20 20 20 20 30 2c 20 20 20 20 20 20 20 20  /.    0,        
30f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3100: 20 20 20 2f 2a 20 78 52 65 6c 65 61 73 65 20 2a     /* xRelease *
3110: 2f 0a 20 20 20 20 30 2c 20 20 20 20 20 20 20 20  /.    0,        
3120: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3130: 20 20 20 2f 2a 20 78 52 6f 6c 6c 62 61 63 6b 54     /* xRollbackT
3140: 6f 20 2a 2f 0a 20 20 20 20 30 20 20 20 20 20 20  o */.    0      
3150: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3160: 20 20 20 20 20 20 2f 2a 20 78 53 68 61 64 6f 77        /* xShadow
3170: 4e 61 6d 65 20 2a 2f 0a 20 20 7d 3b 0a 20 20 72  Name */.  };.  r
3180: 65 74 75 72 6e 20 73 71 6c 69 74 65 33 5f 63 72  eturn sqlite3_cr
3190: 65 61 74 65 5f 6d 6f 64 75 6c 65 28 64 62 2c 20  eate_module(db, 
31a0: 22 73 71 6c 69 74 65 5f 62 74 72 65 65 69 6e 66  "sqlite_btreeinf
31b0: 6f 22 2c 20 26 62 69 6e 66 6f 5f 6d 6f 64 75 6c  o", &binfo_modul
31c0: 65 2c 20 30 29 3b 0a 7d 0a 0a 23 69 66 64 65 66  e, 0);.}..#ifdef
31d0: 20 5f 57 49 4e 33 32 0a 5f 5f 64 65 63 6c 73 70   _WIN32.__declsp
31e0: 65 63 28 64 6c 6c 65 78 70 6f 72 74 29 0a 23 65  ec(dllexport).#e
31f0: 6e 64 69 66 0a 69 6e 74 20 73 71 6c 69 74 65 33  ndif.int sqlite3
3200: 5f 62 74 72 65 65 69 6e 66 6f 5f 69 6e 69 74 28  _btreeinfo_init(
3210: 0a 20 20 73 71 6c 69 74 65 33 20 2a 64 62 2c 20  .  sqlite3 *db, 
3220: 0a 20 20 63 68 61 72 20 2a 2a 70 7a 45 72 72 4d  .  char **pzErrM
3230: 73 67 2c 20 0a 20 20 63 6f 6e 73 74 20 73 71 6c  sg, .  const sql
3240: 69 74 65 33 5f 61 70 69 5f 72 6f 75 74 69 6e 65  ite3_api_routine
3250: 73 20 2a 70 41 70 69 0a 29 7b 0a 20 20 53 51 4c  s *pApi.){.  SQL
3260: 49 54 45 5f 45 58 54 45 4e 53 49 4f 4e 5f 49 4e  ITE_EXTENSION_IN
3270: 49 54 32 28 70 41 70 69 29 3b 0a 20 20 72 65 74  IT2(pApi);.  ret
3280: 75 72 6e 20 73 71 6c 69 74 65 33 42 69 6e 66 6f  urn sqlite3Binfo
3290: 52 65 67 69 73 74 65 72 28 64 62 29 3b 0a 7d 0a  Register(db);.}.