/ Hex Artifact Content
Login
SQLite training in Houston TX on 2019-11-05 (details)
Part of the 2019 Tcl Conference

Artifact e316fba936571584e55abd5b974a32a191727a6b746053a0c9d439bd2cf93940:


0000: 2f 2a 0a 2a 2a 20 32 30 31 39 2d 30 34 2d 31 37  /*.** 2019-04-17
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 77 6f 20 65 70 6f 6e 79 6d 6f 75 73  of two eponymous
01b0: 20 76 69 72 74 75 61 6c 20 74 61 62 6c 65 73 2c   virtual tables,
01c0: 0a 2a 2a 20 22 73 71 6c 69 74 65 5f 64 62 64 61  .** "sqlite_dbda
01d0: 74 61 22 20 61 6e 64 20 22 73 71 6c 69 74 65 5f  ta" and "sqlite_
01e0: 64 62 70 74 72 22 2e 20 42 6f 74 68 20 6d 6f 64  dbptr". Both mod
01f0: 75 6c 65 73 20 72 65 71 75 69 72 65 20 74 68 61  ules require tha
0200: 74 20 74 68 65 0a 2a 2a 20 22 73 71 6c 69 74 65  t the.** "sqlite
0210: 5f 64 62 70 61 67 65 22 20 65 70 6f 6e 79 6d 6f  _dbpage" eponymo
0220: 75 73 20 76 69 72 74 75 61 6c 20 74 61 62 6c 65  us virtual table
0230: 20 62 65 20 61 76 61 69 6c 61 62 6c 65 2e 0a 2a   be available..*
0240: 2a 0a 2a 2a 20 53 51 4c 49 54 45 5f 44 42 44 41  *.** SQLITE_DBDA
0250: 54 41 3a 0a 2a 2a 20 20 20 73 71 6c 69 74 65 5f  TA:.**   sqlite_
0260: 64 62 64 61 74 61 20 69 73 20 75 73 65 64 20 74  dbdata is used t
0270: 6f 20 65 78 74 72 61 63 74 20 64 61 74 61 20 64  o extract data d
0280: 69 72 65 63 74 6c 79 20 66 72 6f 6d 20 61 20 64  irectly from a d
0290: 61 74 61 62 61 73 65 20 62 2d 74 72 65 65 0a 2a  atabase b-tree.*
02a0: 2a 20 20 20 70 61 67 65 20 61 6e 64 20 69 74 73  *   page and its
02b0: 20 61 73 73 6f 63 69 61 74 65 64 20 6f 76 65 72   associated over
02c0: 66 6c 6f 77 20 70 61 67 65 73 2c 20 62 79 70 61  flow pages, bypa
02d0: 73 73 69 6e 67 20 74 68 65 20 62 2d 74 72 65 65  ssing the b-tree
02e0: 20 6c 61 79 65 72 2e 0a 2a 2a 20 20 20 54 68 65   layer..**   The
02f0: 20 74 61 62 6c 65 20 73 63 68 65 6d 61 20 69 73   table schema is
0300: 20 65 71 75 69 76 61 6c 65 6e 74 20 74 6f 3a 0a   equivalent to:.
0310: 2a 2a 0a 2a 2a 20 20 20 20 20 43 52 45 41 54 45  **.**     CREATE
0320: 20 54 41 42 4c 45 20 73 71 6c 69 74 65 5f 64 62   TABLE sqlite_db
0330: 64 61 74 61 28 0a 2a 2a 20 20 20 20 20 20 20 70  data(.**       p
0340: 67 6e 6f 20 49 4e 54 45 47 45 52 2c 0a 2a 2a 20  gno INTEGER,.** 
0350: 20 20 20 20 20 20 63 65 6c 6c 20 49 4e 54 45 47        cell INTEG
0360: 45 52 2c 0a 2a 2a 20 20 20 20 20 20 20 66 69 65  ER,.**       fie
0370: 6c 64 20 49 4e 54 45 47 45 52 2c 0a 2a 2a 20 20  ld INTEGER,.**  
0380: 20 20 20 20 20 76 61 6c 75 65 20 41 4e 59 2c 0a       value ANY,.
0390: 2a 2a 20 20 20 20 20 20 20 73 63 68 65 6d 61 20  **       schema 
03a0: 54 45 58 54 20 48 49 44 44 45 4e 0a 2a 2a 20 20  TEXT HIDDEN.**  
03b0: 20 20 20 29 3b 0a 2a 2a 0a 2a 2a 20 20 20 49 4d     );.**.**   IM
03c0: 50 4f 52 54 41 4e 54 3a 20 54 48 45 20 56 49 52  PORTANT: THE VIR
03d0: 54 55 41 4c 20 54 41 42 4c 45 20 53 43 48 45 4d  TUAL TABLE SCHEM
03e0: 41 20 41 42 4f 56 45 20 49 53 20 53 55 42 4a 45  A ABOVE IS SUBJE
03f0: 43 54 20 54 4f 20 43 48 41 4e 47 45 2e 20 49 4e  CT TO CHANGE. IN
0400: 20 54 48 45 0a 2a 2a 20 20 20 46 55 54 55 52 45   THE.**   FUTURE
0410: 20 4e 45 57 20 4e 4f 4e 2d 48 49 44 44 45 4e 20   NEW NON-HIDDEN 
0420: 43 4f 4c 55 4d 4e 53 20 4d 41 59 20 42 45 20 41  COLUMNS MAY BE A
0430: 44 44 45 44 20 42 45 54 57 45 45 4e 20 22 76 61  DDED BETWEEN "va
0440: 6c 75 65 22 20 41 4e 44 0a 2a 2a 20 20 20 22 73  lue" AND.**   "s
0450: 63 68 65 6d 61 22 2e 0a 2a 2a 0a 2a 2a 20 20 20  chema"..**.**   
0460: 45 61 63 68 20 70 61 67 65 20 6f 66 20 74 68 65  Each page of the
0470: 20 64 61 74 61 62 61 73 65 20 69 73 20 69 6e 73   database is ins
0480: 70 65 63 74 65 64 2e 20 49 66 20 69 74 20 63 61  pected. If it ca
0490: 6e 6e 6f 74 20 62 65 20 69 6e 74 65 72 70 72 65  nnot be interpre
04a0: 74 65 64 20 61 73 0a 2a 2a 20 20 20 61 20 62 2d  ted as.**   a b-
04b0: 74 72 65 65 20 70 61 67 65 2c 20 6f 72 20 69 66  tree page, or if
04c0: 20 69 74 20 69 73 20 61 20 62 2d 74 72 65 65 20   it is a b-tree 
04d0: 70 61 67 65 20 63 6f 6e 74 61 69 6e 69 6e 67 20  page containing 
04e0: 30 20 65 6e 74 72 69 65 73 2c 20 74 68 65 0a 2a  0 entries, the.*
04f0: 2a 20 20 20 73 71 6c 69 74 65 5f 64 62 64 61 74  *   sqlite_dbdat
0500: 61 20 74 61 62 6c 65 20 63 6f 6e 74 61 69 6e 73  a table contains
0510: 20 6e 6f 20 72 6f 77 73 20 66 6f 72 20 74 68 61   no rows for tha
0520: 74 20 70 61 67 65 2e 20 20 4f 74 68 65 72 77 69  t page.  Otherwi
0530: 73 65 2c 20 74 68 65 0a 2a 2a 20 20 20 74 61 62  se, the.**   tab
0540: 6c 65 20 63 6f 6e 74 61 69 6e 73 20 6f 6e 65 20  le contains one 
0550: 72 6f 77 20 66 6f 72 20 65 61 63 68 20 66 69 65  row for each fie
0560: 6c 64 20 69 6e 20 74 68 65 20 72 65 63 6f 72 64  ld in the record
0570: 20 61 73 73 6f 63 69 61 74 65 64 20 77 69 74 68   associated with
0580: 0a 2a 2a 20 20 20 65 61 63 68 20 63 65 6c 6c 20  .**   each cell 
0590: 6f 6e 20 74 68 65 20 70 61 67 65 2e 20 46 6f 72  on the page. For
05a0: 20 69 6e 74 6b 65 79 20 62 2d 74 72 65 65 73 2c   intkey b-trees,
05b0: 20 74 68 65 20 6b 65 79 20 76 61 6c 75 65 20 69   the key value i
05c0: 73 20 73 74 6f 72 65 64 20 69 6e 0a 2a 2a 20 20  s stored in.**  
05d0: 20 66 69 65 6c 64 20 2d 31 2e 0a 2a 2a 0a 2a 2a   field -1..**.**
05e0: 20 20 20 46 6f 72 20 65 78 61 6d 70 6c 65 2c 20     For example, 
05f0: 66 6f 72 20 74 68 65 20 64 61 74 61 62 61 73 65  for the database
0600: 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 43 52 45 41  :.**.**     CREA
0610: 54 45 20 54 41 42 4c 45 20 74 31 28 61 2c 20 62  TE TABLE t1(a, b
0620: 29 3b 20 20 20 20 20 2d 2d 20 72 6f 6f 74 20 70  );     -- root p
0630: 61 67 65 20 69 73 20 70 61 67 65 20 32 0a 2a 2a  age is page 2.**
0640: 20 20 20 20 20 49 4e 53 45 52 54 20 49 4e 54 4f       INSERT INTO
0650: 20 74 31 28 72 6f 77 69 64 2c 20 61 2c 20 62 29   t1(rowid, a, b)
0660: 20 56 41 4c 55 45 53 28 35 2c 20 27 76 27 2c 20   VALUES(5, 'v', 
0670: 27 66 69 76 65 27 29 3b 0a 2a 2a 20 20 20 20 20  'five');.**     
0680: 49 4e 53 45 52 54 20 49 4e 54 4f 20 74 31 28 72  INSERT INTO t1(r
0690: 6f 77 69 64 2c 20 61 2c 20 62 29 20 56 41 4c 55  owid, a, b) VALU
06a0: 45 53 28 31 30 2c 20 27 78 27 2c 20 27 74 65 6e  ES(10, 'x', 'ten
06b0: 27 29 3b 0a 2a 2a 0a 2a 2a 20 20 20 74 68 65 20  ');.**.**   the 
06c0: 73 71 6c 69 74 65 5f 64 62 64 61 74 61 20 74 61  sqlite_dbdata ta
06d0: 62 6c 65 20 63 6f 6e 74 61 69 6e 73 2c 20 61 73  ble contains, as
06e0: 20 77 65 6c 6c 20 61 73 20 66 72 6f 6d 20 65 6e   well as from en
06f0: 74 72 69 65 73 20 72 65 6c 61 74 65 64 20 74 6f  tries related to
0700: 20 0a 2a 2a 20 20 20 70 61 67 65 20 31 2c 20 63   .**   page 1, c
0710: 6f 6e 74 65 6e 74 20 65 71 75 69 76 61 6c 65 6e  ontent equivalen
0720: 74 20 74 6f 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20  t to:.**.**     
0730: 49 4e 53 45 52 54 20 49 4e 54 4f 20 73 71 6c 69  INSERT INTO sqli
0740: 74 65 5f 64 62 64 61 74 61 28 70 67 6e 6f 2c 20  te_dbdata(pgno, 
0750: 63 65 6c 6c 2c 20 66 69 65 6c 64 2c 20 76 61 6c  cell, field, val
0760: 75 65 29 20 56 41 4c 55 45 53 0a 2a 2a 20 20 20  ue) VALUES.**   
0770: 20 20 20 20 20 20 28 32 2c 20 30 2c 20 2d 31 2c        (2, 0, -1,
0780: 20 35 20 20 20 20 20 29 2c 0a 2a 2a 20 20 20 20   5     ),.**    
0790: 20 20 20 20 20 28 32 2c 20 30 2c 20 20 30 2c 20       (2, 0,  0, 
07a0: 27 76 27 20 20 20 29 2c 0a 2a 2a 20 20 20 20 20  'v'   ),.**     
07b0: 20 20 20 20 28 32 2c 20 30 2c 20 20 31 2c 20 27      (2, 0,  1, '
07c0: 66 69 76 65 27 29 2c 0a 2a 2a 20 20 20 20 20 20  five'),.**      
07d0: 20 20 20 28 32 2c 20 31 2c 20 2d 31 2c 20 31 30     (2, 1, -1, 10
07e0: 20 20 20 20 29 2c 0a 2a 2a 20 20 20 20 20 20 20      ),.**       
07f0: 20 20 28 32 2c 20 31 2c 20 20 30 2c 20 27 78 27    (2, 1,  0, 'x'
0800: 20 20 20 29 2c 0a 2a 2a 20 20 20 20 20 20 20 20     ),.**        
0810: 20 28 32 2c 20 31 2c 20 20 31 2c 20 27 74 65 6e   (2, 1,  1, 'ten
0820: 27 20 29 3b 0a 2a 2a 0a 2a 2a 20 20 20 49 66 20  ' );.**.**   If 
0830: 64 61 74 61 62 61 73 65 20 63 6f 72 72 75 70 74  database corrupt
0840: 69 6f 6e 20 69 73 20 65 6e 63 6f 75 6e 74 65 72  ion is encounter
0850: 65 64 2c 20 74 68 69 73 20 6d 6f 64 75 6c 65 20  ed, this module 
0860: 64 6f 65 73 20 6e 6f 74 20 72 65 70 6f 72 74 20  does not report 
0870: 61 6e 0a 2a 2a 20 20 20 65 72 72 6f 72 2e 20 49  an.**   error. I
0880: 6e 73 74 65 61 64 2c 20 69 74 20 61 74 74 65 6d  nstead, it attem
0890: 70 74 73 20 74 6f 20 65 78 74 72 61 63 74 20 61  pts to extract a
08a0: 73 20 6d 75 63 68 20 64 61 74 61 20 61 73 20 70  s much data as p
08b0: 6f 73 73 69 62 6c 65 20 61 6e 64 0a 2a 2a 20 20  ossible and.**  
08c0: 20 69 67 6e 6f 72 65 73 20 74 68 65 20 63 6f 72   ignores the cor
08d0: 72 75 70 74 69 6f 6e 2e 0a 2a 2a 0a 2a 2a 20 53  ruption..**.** S
08e0: 51 4c 49 54 45 5f 44 42 50 54 52 3a 0a 2a 2a 20  QLITE_DBPTR:.** 
08f0: 20 20 54 68 65 20 73 71 6c 69 74 65 5f 64 62 70    The sqlite_dbp
0900: 74 72 20 74 61 62 6c 65 20 68 61 73 20 74 68 65  tr table has the
0910: 20 66 6f 6c 6c 6f 77 69 6e 67 20 73 63 68 65 6d   following schem
0920: 61 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 43 52 45  a:.**.**     CRE
0930: 41 54 45 20 54 41 42 4c 45 20 73 71 6c 69 74 65  ATE TABLE sqlite
0940: 5f 64 62 70 74 72 28 0a 2a 2a 20 20 20 20 20 20  _dbptr(.**      
0950: 20 70 67 6e 6f 20 49 4e 54 45 47 45 52 2c 0a 2a   pgno INTEGER,.*
0960: 2a 20 20 20 20 20 20 20 63 68 69 6c 64 20 49 4e  *       child IN
0970: 54 45 47 45 52 2c 0a 2a 2a 20 20 20 20 20 20 20  TEGER,.**       
0980: 73 63 68 65 6d 61 20 54 45 58 54 20 48 49 44 44  schema TEXT HIDD
0990: 45 4e 0a 2a 2a 20 20 20 20 20 29 3b 0a 2a 2a 0a  EN.**     );.**.
09a0: 2a 2a 20 20 20 49 74 20 63 6f 6e 74 61 69 6e 73  **   It contains
09b0: 20 6f 6e 65 20 65 6e 74 72 79 20 66 6f 72 20 65   one entry for e
09c0: 61 63 68 20 62 2d 74 72 65 65 20 70 6f 69 6e 74  ach b-tree point
09d0: 65 72 20 62 65 74 77 65 65 6e 20 61 20 70 61 72  er between a par
09e0: 65 6e 74 20 61 6e 64 0a 2a 2a 20 20 20 63 68 69  ent and.**   chi
09f0: 6c 64 20 70 61 67 65 20 69 6e 20 74 68 65 20 64  ld page in the d
0a00: 61 74 61 62 61 73 65 2e 0a 2a 2f 0a 23 69 66 20  atabase..*/.#if 
0a10: 21 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 49  !defined(SQLITEI
0a20: 4e 54 5f 48 29 20 0a 23 69 6e 63 6c 75 64 65 20  NT_H) .#include 
0a30: 22 73 71 6c 69 74 65 33 65 78 74 2e 68 22 0a 0a  "sqlite3ext.h"..
0a40: 74 79 70 65 64 65 66 20 75 6e 73 69 67 6e 65 64  typedef unsigned
0a50: 20 63 68 61 72 20 75 38 3b 0a 0a 23 65 6e 64 69   char u8;..#endi
0a60: 66 0a 53 51 4c 49 54 45 5f 45 58 54 45 4e 53 49  f.SQLITE_EXTENSI
0a70: 4f 4e 5f 49 4e 49 54 31 0a 23 69 6e 63 6c 75 64  ON_INIT1.#includ
0a80: 65 20 3c 73 74 72 69 6e 67 2e 68 3e 0a 23 69 6e  e <string.h>.#in
0a90: 63 6c 75 64 65 20 3c 61 73 73 65 72 74 2e 68 3e  clude <assert.h>
0aa0: 0a 0a 23 64 65 66 69 6e 65 20 44 42 44 41 54 41  ..#define DBDATA
0ab0: 5f 50 41 44 44 49 4e 47 5f 42 59 54 45 53 20 31  _PADDING_BYTES 1
0ac0: 30 30 20 0a 0a 74 79 70 65 64 65 66 20 73 74 72  00 ..typedef str
0ad0: 75 63 74 20 44 62 64 61 74 61 54 61 62 6c 65 20  uct DbdataTable 
0ae0: 44 62 64 61 74 61 54 61 62 6c 65 3b 0a 74 79 70  DbdataTable;.typ
0af0: 65 64 65 66 20 73 74 72 75 63 74 20 44 62 64 61  edef struct Dbda
0b00: 74 61 43 75 72 73 6f 72 20 44 62 64 61 74 61 43  taCursor DbdataC
0b10: 75 72 73 6f 72 3b 0a 0a 2f 2a 20 43 75 72 73 6f  ursor;../* Curso
0b20: 72 20 6f 62 6a 65 63 74 20 2a 2f 0a 73 74 72 75  r object */.stru
0b30: 63 74 20 44 62 64 61 74 61 43 75 72 73 6f 72 20  ct DbdataCursor 
0b40: 7b 0a 20 20 73 71 6c 69 74 65 33 5f 76 74 61 62  {.  sqlite3_vtab
0b50: 5f 63 75 72 73 6f 72 20 62 61 73 65 3b 20 20 20  _cursor base;   
0b60: 20 20 20 20 2f 2a 20 42 61 73 65 20 63 6c 61 73      /* Base clas
0b70: 73 2e 20 20 4d 75 73 74 20 62 65 20 66 69 72 73  s.  Must be firs
0b80: 74 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f 73  t */.  sqlite3_s
0b90: 74 6d 74 20 2a 70 53 74 6d 74 3b 20 20 20 20 20  tmt *pStmt;     
0ba0: 20 20 20 20 20 20 20 2f 2a 20 46 6f 72 20 66 65         /* For fe
0bb0: 74 63 68 69 6e 67 20 64 61 74 61 62 61 73 65 20  tching database 
0bc0: 70 61 67 65 73 20 2a 2f 0a 0a 20 20 69 6e 74 20  pages */..  int 
0bd0: 69 50 67 6e 6f 3b 20 20 20 20 20 20 20 20 20 20  iPgno;          
0be0: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 43              /* C
0bf0: 75 72 72 65 6e 74 20 70 61 67 65 20 6e 75 6d 62  urrent page numb
0c00: 65 72 20 2a 2f 0a 20 20 75 38 20 2a 61 50 61 67  er */.  u8 *aPag
0c10: 65 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  e;              
0c20: 20 20 20 20 20 20 20 20 2f 2a 20 42 75 66 66 65          /* Buffe
0c30: 72 20 63 6f 6e 74 61 69 6e 69 6e 67 20 70 61 67  r containing pag
0c40: 65 20 2a 2f 0a 20 20 69 6e 74 20 6e 50 61 67 65  e */.  int nPage
0c50: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
0c60: 20 20 20 20 20 20 20 2f 2a 20 53 69 7a 65 20 6f         /* Size o
0c70: 66 20 61 50 61 67 65 5b 5d 20 69 6e 20 62 79 74  f aPage[] in byt
0c80: 65 73 20 2a 2f 0a 20 20 69 6e 74 20 6e 43 65 6c  es */.  int nCel
0c90: 6c 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  l;              
0ca0: 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65          /* Numbe
0cb0: 72 20 6f 66 20 63 65 6c 6c 73 20 6f 6e 20 61 50  r of cells on aP
0cc0: 61 67 65 5b 5d 20 2a 2f 0a 20 20 69 6e 74 20 69  age[] */.  int i
0cd0: 43 65 6c 6c 3b 20 20 20 20 20 20 20 20 20 20 20  Cell;           
0ce0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 43 75             /* Cu
0cf0: 72 72 65 6e 74 20 63 65 6c 6c 20 6e 75 6d 62 65  rrent cell numbe
0d00: 72 20 2a 2f 0a 20 20 69 6e 74 20 62 4f 6e 65 50  r */.  int bOneP
0d10: 61 67 65 3b 20 20 20 20 20 20 20 20 20 20 20 20  age;            
0d20: 20 20 20 20 20 20 20 2f 2a 20 54 72 75 65 20 74         /* True t
0d30: 6f 20 73 74 6f 70 20 61 66 74 65 72 20 6f 6e 65  o stop after one
0d40: 20 70 61 67 65 20 2a 2f 0a 20 20 69 6e 74 20 73   page */.  int s
0d50: 7a 44 62 3b 0a 20 20 73 71 6c 69 74 65 33 5f 69  zDb;.  sqlite3_i
0d60: 6e 74 36 34 20 69 52 6f 77 69 64 3b 0a 0a 20 20  nt64 iRowid;..  
0d70: 2f 2a 20 4f 6e 6c 79 20 66 6f 72 20 74 68 65 20  /* Only for the 
0d80: 73 71 6c 69 74 65 5f 64 62 64 61 74 61 20 74 61  sqlite_dbdata ta
0d90: 62 6c 65 20 2a 2f 0a 20 20 75 38 20 2a 70 52 65  ble */.  u8 *pRe
0da0: 63 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  c;              
0db0: 20 20 20 20 20 20 20 20 20 2f 2a 20 42 75 66 66           /* Buff
0dc0: 65 72 20 63 6f 6e 74 61 69 6e 69 6e 67 20 63 75  er containing cu
0dd0: 72 72 65 6e 74 20 72 65 63 6f 72 64 20 2a 2f 0a  rrent record */.
0de0: 20 20 69 6e 74 20 6e 52 65 63 3b 20 20 20 20 20    int nRec;     
0df0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0e00: 20 20 2f 2a 20 53 69 7a 65 20 6f 66 20 70 52 65    /* Size of pRe
0e10: 63 5b 5d 20 69 6e 20 62 79 74 65 73 20 2a 2f 0a  c[] in bytes */.
0e20: 20 20 69 6e 74 20 6e 48 64 72 3b 20 20 20 20 20    int nHdr;     
0e30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0e40: 20 20 2f 2a 20 53 69 7a 65 20 6f 66 20 68 65 61    /* Size of hea
0e50: 64 65 72 20 69 6e 20 62 79 74 65 73 20 2a 2f 0a  der in bytes */.
0e60: 20 20 69 6e 74 20 69 46 69 65 6c 64 3b 20 20 20    int iField;   
0e70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0e80: 20 20 2f 2a 20 43 75 72 72 65 6e 74 20 66 69 65    /* Current fie
0e90: 6c 64 20 6e 75 6d 62 65 72 20 2a 2f 0a 20 20 75  ld number */.  u
0ea0: 38 20 2a 70 48 64 72 50 74 72 3b 0a 20 20 75 38  8 *pHdrPtr;.  u8
0eb0: 20 2a 70 50 74 72 3b 0a 20 20 0a 20 20 73 71 6c   *pPtr;.  .  sql
0ec0: 69 74 65 33 5f 69 6e 74 36 34 20 69 49 6e 74 6b  ite3_int64 iIntk
0ed0: 65 79 3b 20 20 20 20 20 20 20 20 20 20 2f 2a 20  ey;          /* 
0ee0: 49 6e 74 65 67 65 72 20 6b 65 79 20 76 61 6c 75  Integer key valu
0ef0: 65 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 20 54 61 62 6c  e */.};../* Tabl
0f00: 65 20 6f 62 6a 65 63 74 20 2a 2f 0a 73 74 72 75  e object */.stru
0f10: 63 74 20 44 62 64 61 74 61 54 61 62 6c 65 20 7b  ct DbdataTable {
0f20: 0a 20 20 73 71 6c 69 74 65 33 5f 76 74 61 62 20  .  sqlite3_vtab 
0f30: 62 61 73 65 3b 20 20 20 20 20 20 20 20 20 20 20  base;           
0f40: 20 20 20 2f 2a 20 42 61 73 65 20 63 6c 61 73 73     /* Base class
0f50: 2e 20 20 4d 75 73 74 20 62 65 20 66 69 72 73 74  .  Must be first
0f60: 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 20 2a 64   */.  sqlite3 *d
0f70: 62 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  b;              
0f80: 20 20 20 20 20 20 2f 2a 20 54 68 65 20 64 61 74        /* The dat
0f90: 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e  abase connection
0fa0: 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f 73 74   */.  sqlite3_st
0fb0: 6d 74 20 2a 70 53 74 6d 74 3b 20 20 20 20 20 20  mt *pStmt;      
0fc0: 20 20 20 20 20 20 2f 2a 20 46 6f 72 20 66 65 74        /* For fet
0fd0: 63 68 69 6e 67 20 64 61 74 61 62 61 73 65 20 70  ching database p
0fe0: 61 67 65 73 20 2a 2f 0a 20 20 69 6e 74 20 62 50  ages */.  int bP
0ff0: 74 72 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  tr;             
1000: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 72 75            /* Tru
1010: 65 20 66 6f 72 20 73 71 6c 69 74 65 33 5f 64 62  e for sqlite3_db
1020: 70 74 72 20 74 61 62 6c 65 20 2a 2f 0a 7d 3b 0a  ptr table */.};.
1030: 0a 2f 2a 20 43 6f 6c 75 6d 6e 20 61 6e 64 20 73  ./* Column and s
1040: 63 68 65 6d 61 20 64 65 66 69 6e 69 74 69 6f 6e  chema definition
1050: 73 20 66 6f 72 20 73 71 6c 69 74 65 5f 64 62 64  s for sqlite_dbd
1060: 61 74 61 20 2a 2f 0a 23 64 65 66 69 6e 65 20 44  ata */.#define D
1070: 42 44 41 54 41 5f 43 4f 4c 55 4d 4e 5f 50 47 4e  BDATA_COLUMN_PGN
1080: 4f 20 20 20 20 20 20 20 20 30 0a 23 64 65 66 69  O        0.#defi
1090: 6e 65 20 44 42 44 41 54 41 5f 43 4f 4c 55 4d 4e  ne DBDATA_COLUMN
10a0: 5f 43 45 4c 4c 20 20 20 20 20 20 20 20 31 0a 23  _CELL        1.#
10b0: 64 65 66 69 6e 65 20 44 42 44 41 54 41 5f 43 4f  define DBDATA_CO
10c0: 4c 55 4d 4e 5f 46 49 45 4c 44 20 20 20 20 20 20  LUMN_FIELD      
10d0: 20 32 0a 23 64 65 66 69 6e 65 20 44 42 44 41 54   2.#define DBDAT
10e0: 41 5f 43 4f 4c 55 4d 4e 5f 56 41 4c 55 45 20 20  A_COLUMN_VALUE  
10f0: 20 20 20 20 20 33 0a 23 64 65 66 69 6e 65 20 44       3.#define D
1100: 42 44 41 54 41 5f 43 4f 4c 55 4d 4e 5f 53 43 48  BDATA_COLUMN_SCH
1110: 45 4d 41 20 20 20 20 20 20 34 0a 23 64 65 66 69  EMA      4.#defi
1120: 6e 65 20 44 42 44 41 54 41 5f 53 43 48 45 4d 41  ne DBDATA_SCHEMA
1130: 20 20 20 20 20 20 20 20 20 20 20 20 20 5c 0a 20               \. 
1140: 20 20 20 20 20 22 43 52 45 41 54 45 20 54 41 42       "CREATE TAB
1150: 4c 45 20 78 28 22 20 20 20 20 20 20 20 20 20 20  LE x("          
1160: 20 5c 0a 20 20 20 20 20 20 22 20 20 70 67 6e 6f   \.      "  pgno
1170: 20 49 4e 54 45 47 45 52 2c 22 20 20 20 20 20 20   INTEGER,"      
1180: 20 20 20 20 20 5c 0a 20 20 20 20 20 20 22 20 20       \.      "  
1190: 63 65 6c 6c 20 49 4e 54 45 47 45 52 2c 22 20 20  cell INTEGER,"  
11a0: 20 20 20 20 20 20 20 20 20 5c 0a 20 20 20 20 20           \.     
11b0: 20 22 20 20 66 69 65 6c 64 20 49 4e 54 45 47 45   "  field INTEGE
11c0: 52 2c 22 20 20 20 20 20 20 20 20 20 20 5c 0a 20  R,"          \. 
11d0: 20 20 20 20 20 22 20 20 76 61 6c 75 65 20 41 4e       "  value AN
11e0: 59 2c 22 20 20 20 20 20 20 20 20 20 20 20 20 20  Y,"             
11f0: 20 5c 0a 20 20 20 20 20 20 22 20 20 73 63 68 65   \.      "  sche
1200: 6d 61 20 54 45 58 54 20 48 49 44 44 45 4e 22 20  ma TEXT HIDDEN" 
1210: 20 20 20 20 20 5c 0a 20 20 20 20 20 20 22 29 22       \.      ")"
1220: 0a 0a 2f 2a 20 43 6f 6c 75 6d 6e 20 61 6e 64 20  ../* Column and 
1230: 73 63 68 65 6d 61 20 64 65 66 69 6e 69 74 69 6f  schema definitio
1240: 6e 73 20 66 6f 72 20 73 71 6c 69 74 65 5f 64 62  ns for sqlite_db
1250: 70 74 72 20 2a 2f 0a 23 64 65 66 69 6e 65 20 44  ptr */.#define D
1260: 42 50 54 52 5f 43 4f 4c 55 4d 4e 5f 50 47 4e 4f  BPTR_COLUMN_PGNO
1270: 20 20 20 20 20 20 20 20 20 30 0a 23 64 65 66 69           0.#defi
1280: 6e 65 20 44 42 50 54 52 5f 43 4f 4c 55 4d 4e 5f  ne DBPTR_COLUMN_
1290: 43 48 49 4c 44 20 20 20 20 20 20 20 20 31 0a 23  CHILD        1.#
12a0: 64 65 66 69 6e 65 20 44 42 50 54 52 5f 43 4f 4c  define DBPTR_COL
12b0: 55 4d 4e 5f 53 43 48 45 4d 41 20 20 20 20 20 20  UMN_SCHEMA      
12c0: 20 32 0a 23 64 65 66 69 6e 65 20 44 42 50 54 52   2.#define DBPTR
12d0: 5f 53 43 48 45 4d 41 20 20 20 20 20 20 20 20 20  _SCHEMA         
12e0: 20 20 20 20 20 5c 0a 20 20 20 20 20 20 22 43 52       \.      "CR
12f0: 45 41 54 45 20 54 41 42 4c 45 20 78 28 22 20 20  EATE TABLE x("  
1300: 20 20 20 20 20 20 20 20 20 5c 0a 20 20 20 20 20           \.     
1310: 20 22 20 20 70 67 6e 6f 20 49 4e 54 45 47 45 52   "  pgno INTEGER
1320: 2c 22 20 20 20 20 20 20 20 20 20 20 20 5c 0a 20  ,"           \. 
1330: 20 20 20 20 20 22 20 20 63 68 69 6c 64 20 49 4e       "  child IN
1340: 54 45 47 45 52 2c 22 20 20 20 20 20 20 20 20 20  TEGER,"         
1350: 20 5c 0a 20 20 20 20 20 20 22 20 20 73 63 68 65   \.      "  sche
1360: 6d 61 20 54 45 58 54 20 48 49 44 44 45 4e 22 20  ma TEXT HIDDEN" 
1370: 20 20 20 20 20 5c 0a 20 20 20 20 20 20 22 29 22       \.      ")"
1380: 0a 0a 2f 2a 0a 2a 2a 20 43 6f 6e 6e 65 63 74 20  ../*.** Connect 
1390: 74 6f 20 61 6e 20 73 71 6c 69 74 65 5f 64 62 64  to an sqlite_dbd
13a0: 61 74 61 20 28 70 41 75 78 3d 3d 30 29 20 6f 72  ata (pAux==0) or
13b0: 20 73 71 6c 69 74 65 5f 64 62 70 74 72 20 28 70   sqlite_dbptr (p
13c0: 41 75 78 21 3d 30 29 20 76 69 72 74 75 61 6c 20  Aux!=0) virtual 
13d0: 0a 2a 2a 20 74 61 62 6c 65 2e 0a 2a 2f 0a 73 74  .** table..*/.st
13e0: 61 74 69 63 20 69 6e 74 20 64 62 64 61 74 61 43  atic int dbdataC
13f0: 6f 6e 6e 65 63 74 28 0a 20 20 73 71 6c 69 74 65  onnect(.  sqlite
1400: 33 20 2a 64 62 2c 0a 20 20 76 6f 69 64 20 2a 70  3 *db,.  void *p
1410: 41 75 78 2c 0a 20 20 69 6e 74 20 61 72 67 63 2c  Aux,.  int argc,
1420: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 63 6f 6e   const char *con
1430: 73 74 2a 61 72 67 76 2c 0a 20 20 73 71 6c 69 74  st*argv,.  sqlit
1440: 65 33 5f 76 74 61 62 20 2a 2a 70 70 56 74 61 62  e3_vtab **ppVtab
1450: 2c 0a 20 20 63 68 61 72 20 2a 2a 70 7a 45 72 72  ,.  char **pzErr
1460: 0a 29 7b 0a 20 20 44 62 64 61 74 61 54 61 62 6c  .){.  DbdataTabl
1470: 65 20 2a 70 54 61 62 20 3d 20 30 3b 0a 20 20 69  e *pTab = 0;.  i
1480: 6e 74 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f  nt rc = sqlite3_
1490: 64 65 63 6c 61 72 65 5f 76 74 61 62 28 64 62 2c  declare_vtab(db,
14a0: 20 70 41 75 78 20 3f 20 44 42 50 54 52 5f 53 43   pAux ? DBPTR_SC
14b0: 48 45 4d 41 20 3a 20 44 42 44 41 54 41 5f 53 43  HEMA : DBDATA_SC
14c0: 48 45 4d 41 29 3b 0a 0a 20 20 69 66 28 20 72 63  HEMA);..  if( rc
14d0: 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20  ==SQLITE_OK ){. 
14e0: 20 20 20 70 54 61 62 20 3d 20 28 44 62 64 61 74     pTab = (Dbdat
14f0: 61 54 61 62 6c 65 2a 29 73 71 6c 69 74 65 33 5f  aTable*)sqlite3_
1500: 6d 61 6c 6c 6f 63 36 34 28 73 69 7a 65 6f 66 28  malloc64(sizeof(
1510: 44 62 64 61 74 61 54 61 62 6c 65 29 29 3b 0a 20  DbdataTable));. 
1520: 20 20 20 69 66 28 20 70 54 61 62 3d 3d 30 20 29     if( pTab==0 )
1530: 7b 0a 20 20 20 20 20 20 72 63 20 3d 20 53 51 4c  {.      rc = SQL
1540: 49 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 20 20 7d  ITE_NOMEM;.    }
1550: 65 6c 73 65 7b 0a 20 20 20 20 20 20 6d 65 6d 73  else{.      mems
1560: 65 74 28 70 54 61 62 2c 20 30 2c 20 73 69 7a 65  et(pTab, 0, size
1570: 6f 66 28 44 62 64 61 74 61 54 61 62 6c 65 29 29  of(DbdataTable))
1580: 3b 0a 20 20 20 20 20 20 70 54 61 62 2d 3e 64 62  ;.      pTab->db
1590: 20 3d 20 64 62 3b 0a 20 20 20 20 20 20 70 54 61   = db;.      pTa
15a0: 62 2d 3e 62 50 74 72 20 3d 20 28 70 41 75 78 21  b->bPtr = (pAux!
15b0: 3d 30 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a  =0);.    }.  }..
15c0: 20 20 2a 70 70 56 74 61 62 20 3d 20 28 73 71 6c    *ppVtab = (sql
15d0: 69 74 65 33 5f 76 74 61 62 2a 29 70 54 61 62 3b  ite3_vtab*)pTab;
15e0: 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a  .  return rc;.}.
15f0: 0a 2f 2a 0a 2a 2a 20 44 69 73 63 6f 6e 6e 65 63  ./*.** Disconnec
1600: 74 20 66 72 6f 6d 20 6f 72 20 64 65 73 74 72 6f  t from or destro
1610: 79 20 61 20 73 71 6c 69 74 65 5f 64 62 64 61 74  y a sqlite_dbdat
1620: 61 20 6f 72 20 73 71 6c 69 74 65 5f 64 62 70 74  a or sqlite_dbpt
1630: 72 20 76 69 72 74 75 61 6c 20 74 61 62 6c 65 2e  r virtual table.
1640: 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 64  .*/.static int d
1650: 62 64 61 74 61 44 69 73 63 6f 6e 6e 65 63 74 28  bdataDisconnect(
1660: 73 71 6c 69 74 65 33 5f 76 74 61 62 20 2a 70 56  sqlite3_vtab *pV
1670: 74 61 62 29 7b 0a 20 20 44 62 64 61 74 61 54 61  tab){.  DbdataTa
1680: 62 6c 65 20 2a 70 54 61 62 20 3d 20 28 44 62 64  ble *pTab = (Dbd
1690: 61 74 61 54 61 62 6c 65 2a 29 70 56 74 61 62 3b  ataTable*)pVtab;
16a0: 0a 20 20 69 66 28 20 70 54 61 62 20 29 7b 0a 20  .  if( pTab ){. 
16b0: 20 20 20 73 71 6c 69 74 65 33 5f 66 69 6e 61 6c     sqlite3_final
16c0: 69 7a 65 28 70 54 61 62 2d 3e 70 53 74 6d 74 29  ize(pTab->pStmt)
16d0: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66 72  ;.    sqlite3_fr
16e0: 65 65 28 70 56 74 61 62 29 3b 0a 20 20 7d 0a 20  ee(pVtab);.  }. 
16f0: 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f   return SQLITE_O
1700: 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 69 73  K;.}../*.** This
1710: 20 66 75 6e 63 74 69 6f 6e 20 69 6e 74 65 72 70   function interp
1720: 72 65 74 73 20 74 77 6f 20 74 79 70 65 73 20 6f  rets two types o
1730: 66 20 63 6f 6e 73 74 72 61 69 6e 74 73 3a 0a 2a  f constraints:.*
1740: 2a 0a 2a 2a 20 20 20 20 20 20 20 73 63 68 65 6d  *.**       schem
1750: 61 3d 3f 0a 2a 2a 20 20 20 20 20 20 20 70 67 6e  a=?.**       pgn
1760: 6f 3d 3f 0a 2a 2a 0a 2a 2a 20 49 66 20 6e 65 69  o=?.**.** If nei
1770: 74 68 65 72 20 61 72 65 20 70 72 65 73 65 6e 74  ther are present
1780: 2c 20 69 64 78 4e 75 6d 20 69 73 20 73 65 74 20  , idxNum is set 
1790: 74 6f 20 30 2e 20 49 66 20 73 63 68 65 6d 61 3d  to 0. If schema=
17a0: 3f 20 69 73 20 70 72 65 73 65 6e 74 2c 0a 2a 2a  ? is present,.**
17b0: 20 74 68 65 20 30 78 30 31 20 62 69 74 20 69 6e   the 0x01 bit in
17c0: 20 69 64 78 4e 75 6d 20 69 73 20 73 65 74 2e 20   idxNum is set. 
17d0: 49 66 20 70 67 6e 6f 3d 3f 20 69 73 20 70 72 65  If pgno=? is pre
17e0: 73 65 6e 74 2c 20 74 68 65 20 30 78 30 32 20 62  sent, the 0x02 b
17f0: 69 74 0a 2a 2a 20 69 6e 20 69 64 78 4e 75 6d 20  it.** in idxNum 
1800: 69 73 20 73 65 74 2e 0a 2a 2a 0a 2a 2a 20 49 66  is set..**.** If
1810: 20 62 6f 74 68 20 70 61 72 61 6d 65 74 65 72 73   both parameters
1820: 20 61 72 65 20 70 72 65 73 65 6e 74 2c 20 73 63   are present, sc
1830: 68 65 6d 61 20 69 73 20 69 6e 20 70 6f 73 69 74  hema is in posit
1840: 69 6f 6e 20 30 20 61 6e 64 20 70 67 6e 6f 20 69  ion 0 and pgno i
1850: 6e 0a 2a 2a 20 70 6f 73 69 74 69 6f 6e 20 31 2e  n.** position 1.
1860: 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 64  .*/.static int d
1870: 62 64 61 74 61 42 65 73 74 49 6e 64 65 78 28 73  bdataBestIndex(s
1880: 71 6c 69 74 65 33 5f 76 74 61 62 20 2a 74 61 62  qlite3_vtab *tab
1890: 2c 20 73 71 6c 69 74 65 33 5f 69 6e 64 65 78 5f  , sqlite3_index_
18a0: 69 6e 66 6f 20 2a 70 49 64 78 29 7b 0a 20 20 44  info *pIdx){.  D
18b0: 62 64 61 74 61 54 61 62 6c 65 20 2a 70 54 61 62  bdataTable *pTab
18c0: 20 3d 20 28 44 62 64 61 74 61 54 61 62 6c 65 2a   = (DbdataTable*
18d0: 29 74 61 62 3b 0a 20 20 69 6e 74 20 69 3b 0a 20  )tab;.  int i;. 
18e0: 20 69 6e 74 20 69 53 63 68 65 6d 61 20 3d 20 2d   int iSchema = -
18f0: 31 3b 0a 20 20 69 6e 74 20 69 50 67 6e 6f 20 3d  1;.  int iPgno =
1900: 20 2d 31 3b 0a 20 20 69 6e 74 20 63 6f 6c 53 63   -1;.  int colSc
1910: 68 65 6d 61 20 3d 20 28 70 54 61 62 2d 3e 62 50  hema = (pTab->bP
1920: 74 72 20 3f 20 44 42 50 54 52 5f 43 4f 4c 55 4d  tr ? DBPTR_COLUM
1930: 4e 5f 53 43 48 45 4d 41 20 3a 20 44 42 44 41 54  N_SCHEMA : DBDAT
1940: 41 5f 43 4f 4c 55 4d 4e 5f 53 43 48 45 4d 41 29  A_COLUMN_SCHEMA)
1950: 3b 0a 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c  ;..  for(i=0; i<
1960: 70 49 64 78 2d 3e 6e 43 6f 6e 73 74 72 61 69 6e  pIdx->nConstrain
1970: 74 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 73 74 72  t; i++){.    str
1980: 75 63 74 20 73 71 6c 69 74 65 33 5f 69 6e 64 65  uct sqlite3_inde
1990: 78 5f 63 6f 6e 73 74 72 61 69 6e 74 20 2a 70 20  x_constraint *p 
19a0: 3d 20 26 70 49 64 78 2d 3e 61 43 6f 6e 73 74 72  = &pIdx->aConstr
19b0: 61 69 6e 74 5b 69 5d 3b 0a 20 20 20 20 69 66 28  aint[i];.    if(
19c0: 20 70 2d 3e 6f 70 3d 3d 53 51 4c 49 54 45 5f 49   p->op==SQLITE_I
19d0: 4e 44 45 58 5f 43 4f 4e 53 54 52 41 49 4e 54 5f  NDEX_CONSTRAINT_
19e0: 45 51 20 29 7b 0a 20 20 20 20 20 20 69 66 28 20  EQ ){.      if( 
19f0: 70 2d 3e 69 43 6f 6c 75 6d 6e 3d 3d 63 6f 6c 53  p->iColumn==colS
1a00: 63 68 65 6d 61 20 29 7b 0a 20 20 20 20 20 20 20  chema ){.       
1a10: 20 69 66 28 20 70 2d 3e 75 73 61 62 6c 65 3d 3d   if( p->usable==
1a20: 30 20 29 20 72 65 74 75 72 6e 20 53 51 4c 49 54  0 ) return SQLIT
1a30: 45 5f 43 4f 4e 53 54 52 41 49 4e 54 3b 0a 20 20  E_CONSTRAINT;.  
1a40: 20 20 20 20 20 20 69 53 63 68 65 6d 61 20 3d 20        iSchema = 
1a50: 69 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20  i;.      }.     
1a60: 20 69 66 28 20 70 2d 3e 69 43 6f 6c 75 6d 6e 3d   if( p->iColumn=
1a70: 3d 44 42 44 41 54 41 5f 43 4f 4c 55 4d 4e 5f 50  =DBDATA_COLUMN_P
1a80: 47 4e 4f 20 26 26 20 70 2d 3e 75 73 61 62 6c 65  GNO && p->usable
1a90: 20 29 7b 0a 20 20 20 20 20 20 20 20 69 50 67 6e   ){.        iPgn
1aa0: 6f 20 3d 20 69 3b 0a 20 20 20 20 20 20 7d 0a 20  o = i;.      }. 
1ab0: 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 69 66 28 20     }.  }..  if( 
1ac0: 69 53 63 68 65 6d 61 3e 3d 30 20 29 7b 0a 20 20  iSchema>=0 ){.  
1ad0: 20 20 70 49 64 78 2d 3e 61 43 6f 6e 73 74 72 61    pIdx->aConstra
1ae0: 69 6e 74 55 73 61 67 65 5b 69 53 63 68 65 6d 61  intUsage[iSchema
1af0: 5d 2e 61 72 67 76 49 6e 64 65 78 20 3d 20 31 3b  ].argvIndex = 1;
1b00: 0a 20 20 20 20 70 49 64 78 2d 3e 61 43 6f 6e 73  .    pIdx->aCons
1b10: 74 72 61 69 6e 74 55 73 61 67 65 5b 69 53 63 68  traintUsage[iSch
1b20: 65 6d 61 5d 2e 6f 6d 69 74 20 3d 20 31 3b 0a 20  ema].omit = 1;. 
1b30: 20 7d 0a 20 20 69 66 28 20 69 50 67 6e 6f 3e 3d   }.  if( iPgno>=
1b40: 30 20 29 7b 0a 20 20 20 20 70 49 64 78 2d 3e 61  0 ){.    pIdx->a
1b50: 43 6f 6e 73 74 72 61 69 6e 74 55 73 61 67 65 5b  ConstraintUsage[
1b60: 69 50 67 6e 6f 5d 2e 61 72 67 76 49 6e 64 65 78  iPgno].argvIndex
1b70: 20 3d 20 31 20 2b 20 28 69 53 63 68 65 6d 61 3e   = 1 + (iSchema>
1b80: 3d 30 29 3b 0a 20 20 20 20 70 49 64 78 2d 3e 61  =0);.    pIdx->a
1b90: 43 6f 6e 73 74 72 61 69 6e 74 55 73 61 67 65 5b  ConstraintUsage[
1ba0: 69 50 67 6e 6f 5d 2e 6f 6d 69 74 20 3d 20 31 3b  iPgno].omit = 1;
1bb0: 0a 20 20 20 20 70 49 64 78 2d 3e 65 73 74 69 6d  .    pIdx->estim
1bc0: 61 74 65 64 43 6f 73 74 20 3d 20 31 30 30 3b 0a  atedCost = 100;.
1bd0: 20 20 20 20 70 49 64 78 2d 3e 65 73 74 69 6d 61      pIdx->estima
1be0: 74 65 64 52 6f 77 73 20 3d 20 20 35 30 3b 0a 0a  tedRows =  50;..
1bf0: 20 20 20 20 69 66 28 20 70 54 61 62 2d 3e 62 50      if( pTab->bP
1c00: 74 72 3d 3d 30 20 26 26 20 70 49 64 78 2d 3e 6e  tr==0 && pIdx->n
1c10: 4f 72 64 65 72 42 79 20 26 26 20 70 49 64 78 2d  OrderBy && pIdx-
1c20: 3e 61 4f 72 64 65 72 42 79 5b 30 5d 2e 64 65 73  >aOrderBy[0].des
1c30: 63 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 69 6e  c==0 ){.      in
1c40: 74 20 69 43 6f 6c 20 3d 20 70 49 64 78 2d 3e 61  t iCol = pIdx->a
1c50: 4f 72 64 65 72 42 79 5b 30 5d 2e 69 43 6f 6c 75  OrderBy[0].iColu
1c60: 6d 6e 3b 0a 20 20 20 20 20 20 69 66 28 20 70 49  mn;.      if( pI
1c70: 64 78 2d 3e 6e 4f 72 64 65 72 42 79 3d 3d 31 20  dx->nOrderBy==1 
1c80: 29 7b 0a 20 20 20 20 20 20 20 20 70 49 64 78 2d  ){.        pIdx-
1c90: 3e 6f 72 64 65 72 42 79 43 6f 6e 73 75 6d 65 64  >orderByConsumed
1ca0: 20 3d 20 28 69 43 6f 6c 3d 3d 30 20 7c 7c 20 69   = (iCol==0 || i
1cb0: 43 6f 6c 3d 3d 31 29 3b 0a 20 20 20 20 20 20 7d  Col==1);.      }
1cc0: 65 6c 73 65 20 69 66 28 20 70 49 64 78 2d 3e 6e  else if( pIdx->n
1cd0: 4f 72 64 65 72 42 79 3d 3d 32 20 26 26 20 70 49  OrderBy==2 && pI
1ce0: 64 78 2d 3e 61 4f 72 64 65 72 42 79 5b 31 5d 2e  dx->aOrderBy[1].
1cf0: 64 65 73 63 3d 3d 30 20 26 26 20 69 43 6f 6c 3d  desc==0 && iCol=
1d00: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 70 49  =0 ){.        pI
1d10: 64 78 2d 3e 6f 72 64 65 72 42 79 43 6f 6e 73 75  dx->orderByConsu
1d20: 6d 65 64 20 3d 20 28 70 49 64 78 2d 3e 61 4f 72  med = (pIdx->aOr
1d30: 64 65 72 42 79 5b 31 5d 2e 69 43 6f 6c 75 6d 6e  derBy[1].iColumn
1d40: 3d 3d 31 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20  ==1);.      }.  
1d50: 20 20 7d 0a 0a 20 20 7d 65 6c 73 65 7b 0a 20 20    }..  }else{.  
1d60: 20 20 70 49 64 78 2d 3e 65 73 74 69 6d 61 74 65    pIdx->estimate
1d70: 64 43 6f 73 74 20 3d 20 31 30 30 30 30 30 30 30  dCost = 10000000
1d80: 30 3b 0a 20 20 20 20 70 49 64 78 2d 3e 65 73 74  0;.    pIdx->est
1d90: 69 6d 61 74 65 64 52 6f 77 73 20 3d 20 31 30 30  imatedRows = 100
1da0: 30 30 30 30 30 30 30 3b 0a 20 20 7d 0a 20 20 70  0000000;.  }.  p
1db0: 49 64 78 2d 3e 69 64 78 4e 75 6d 20 3d 20 28 69  Idx->idxNum = (i
1dc0: 53 63 68 65 6d 61 3e 3d 30 20 3f 20 30 78 30 31  Schema>=0 ? 0x01
1dd0: 20 3a 20 30 78 30 30 29 20 7c 20 28 69 50 67 6e   : 0x00) | (iPgn
1de0: 6f 3e 3d 30 20 3f 20 30 78 30 32 20 3a 20 30 78  o>=0 ? 0x02 : 0x
1df0: 30 30 29 3b 0a 20 20 72 65 74 75 72 6e 20 53 51  00);.  return SQ
1e00: 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a  LITE_OK;.}../*.*
1e10: 2a 20 4f 70 65 6e 20 61 20 6e 65 77 20 73 71 6c  * Open a new sql
1e20: 69 74 65 5f 64 62 64 61 74 61 20 6f 72 20 73 71  ite_dbdata or sq
1e30: 6c 69 74 65 5f 64 62 70 74 72 20 63 75 72 73 6f  lite_dbptr curso
1e40: 72 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74  r..*/.static int
1e50: 20 64 62 64 61 74 61 4f 70 65 6e 28 73 71 6c 69   dbdataOpen(sqli
1e60: 74 65 33 5f 76 74 61 62 20 2a 70 56 54 61 62 2c  te3_vtab *pVTab,
1e70: 20 73 71 6c 69 74 65 33 5f 76 74 61 62 5f 63 75   sqlite3_vtab_cu
1e80: 72 73 6f 72 20 2a 2a 70 70 43 75 72 73 6f 72 29  rsor **ppCursor)
1e90: 7b 0a 20 20 44 62 64 61 74 61 43 75 72 73 6f 72  {.  DbdataCursor
1ea0: 20 2a 70 43 73 72 3b 0a 0a 20 20 70 43 73 72 20   *pCsr;..  pCsr 
1eb0: 3d 20 28 44 62 64 61 74 61 43 75 72 73 6f 72 2a  = (DbdataCursor*
1ec0: 29 73 71 6c 69 74 65 33 5f 6d 61 6c 6c 6f 63 36  )sqlite3_malloc6
1ed0: 34 28 73 69 7a 65 6f 66 28 44 62 64 61 74 61 43  4(sizeof(DbdataC
1ee0: 75 72 73 6f 72 29 29 3b 0a 20 20 69 66 28 20 70  ursor));.  if( p
1ef0: 43 73 72 3d 3d 30 20 29 7b 0a 20 20 20 20 72 65  Csr==0 ){.    re
1f00: 74 75 72 6e 20 53 51 4c 49 54 45 5f 4e 4f 4d 45  turn SQLITE_NOME
1f10: 4d 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  M;.  }else{.    
1f20: 6d 65 6d 73 65 74 28 70 43 73 72 2c 20 30 2c 20  memset(pCsr, 0, 
1f30: 73 69 7a 65 6f 66 28 44 62 64 61 74 61 43 75 72  sizeof(DbdataCur
1f40: 73 6f 72 29 29 3b 0a 20 20 20 20 70 43 73 72 2d  sor));.    pCsr-
1f50: 3e 62 61 73 65 2e 70 56 74 61 62 20 3d 20 70 56  >base.pVtab = pV
1f60: 54 61 62 3b 0a 20 20 7d 0a 0a 20 20 2a 70 70 43  Tab;.  }..  *ppC
1f70: 75 72 73 6f 72 20 3d 20 28 73 71 6c 69 74 65 33  ursor = (sqlite3
1f80: 5f 76 74 61 62 5f 63 75 72 73 6f 72 20 2a 29 70  _vtab_cursor *)p
1f90: 43 73 72 3b 0a 20 20 72 65 74 75 72 6e 20 53 51  Csr;.  return SQ
1fa0: 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 0a 2a  LITE_OK;.}../*.*
1fb0: 2a 20 52 65 73 74 6f 72 65 20 61 20 63 75 72 73  * Restore a curs
1fc0: 6f 72 20 6f 62 6a 65 63 74 20 74 6f 20 74 68 65  or object to the
1fd0: 20 73 74 61 74 65 20 69 74 20 77 61 73 20 69 6e   state it was in
1fe0: 20 77 68 65 6e 20 66 69 72 73 74 20 61 6c 6c 6f   when first allo
1ff0: 63 61 74 65 64 20 0a 2a 2a 20 62 79 20 64 62 64  cated .** by dbd
2000: 61 74 61 4f 70 65 6e 28 29 2e 0a 2a 2f 0a 73 74  ataOpen()..*/.st
2010: 61 74 69 63 20 76 6f 69 64 20 64 62 64 61 74 61  atic void dbdata
2020: 52 65 73 65 74 43 75 72 73 6f 72 28 44 62 64 61  ResetCursor(Dbda
2030: 74 61 43 75 72 73 6f 72 20 2a 70 43 73 72 29 7b  taCursor *pCsr){
2040: 0a 20 20 44 62 64 61 74 61 54 61 62 6c 65 20 2a  .  DbdataTable *
2050: 70 54 61 62 20 3d 20 28 44 62 64 61 74 61 54 61  pTab = (DbdataTa
2060: 62 6c 65 2a 29 28 70 43 73 72 2d 3e 62 61 73 65  ble*)(pCsr->base
2070: 2e 70 56 74 61 62 29 3b 0a 20 20 69 66 28 20 70  .pVtab);.  if( p
2080: 54 61 62 2d 3e 70 53 74 6d 74 3d 3d 30 20 29 7b  Tab->pStmt==0 ){
2090: 0a 20 20 20 20 70 54 61 62 2d 3e 70 53 74 6d 74  .    pTab->pStmt
20a0: 20 3d 20 70 43 73 72 2d 3e 70 53 74 6d 74 3b 0a   = pCsr->pStmt;.
20b0: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 73 71 6c    }else{.    sql
20c0: 69 74 65 33 5f 66 69 6e 61 6c 69 7a 65 28 70 43  ite3_finalize(pC
20d0: 73 72 2d 3e 70 53 74 6d 74 29 3b 0a 20 20 7d 0a  sr->pStmt);.  }.
20e0: 20 20 70 43 73 72 2d 3e 70 53 74 6d 74 20 3d 20    pCsr->pStmt = 
20f0: 30 3b 0a 20 20 70 43 73 72 2d 3e 69 50 67 6e 6f  0;.  pCsr->iPgno
2100: 20 3d 20 31 3b 0a 20 20 70 43 73 72 2d 3e 69 43   = 1;.  pCsr->iC
2110: 65 6c 6c 20 3d 20 30 3b 0a 20 20 70 43 73 72 2d  ell = 0;.  pCsr-
2120: 3e 69 46 69 65 6c 64 20 3d 20 30 3b 0a 20 20 70  >iField = 0;.  p
2130: 43 73 72 2d 3e 62 4f 6e 65 50 61 67 65 20 3d 20  Csr->bOnePage = 
2140: 30 3b 0a 20 20 73 71 6c 69 74 65 33 5f 66 72 65  0;.  sqlite3_fre
2150: 65 28 70 43 73 72 2d 3e 61 50 61 67 65 29 3b 0a  e(pCsr->aPage);.
2160: 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 70    sqlite3_free(p
2170: 43 73 72 2d 3e 70 52 65 63 29 3b 0a 20 20 70 43  Csr->pRec);.  pC
2180: 73 72 2d 3e 70 52 65 63 20 3d 20 30 3b 0a 20 20  sr->pRec = 0;.  
2190: 70 43 73 72 2d 3e 61 50 61 67 65 20 3d 20 30 3b  pCsr->aPage = 0;
21a0: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 6c 6f 73 65 20  .}../*.** Close 
21b0: 61 6e 20 73 71 6c 69 74 65 5f 64 62 64 61 74 61  an sqlite_dbdata
21c0: 20 6f 72 20 73 71 6c 69 74 65 5f 64 62 70 74 72   or sqlite_dbptr
21d0: 20 63 75 72 73 6f 72 2e 0a 2a 2f 0a 73 74 61 74   cursor..*/.stat
21e0: 69 63 20 69 6e 74 20 64 62 64 61 74 61 43 6c 6f  ic int dbdataClo
21f0: 73 65 28 73 71 6c 69 74 65 33 5f 76 74 61 62 5f  se(sqlite3_vtab_
2200: 63 75 72 73 6f 72 20 2a 70 43 75 72 73 6f 72 29  cursor *pCursor)
2210: 7b 0a 20 20 44 62 64 61 74 61 43 75 72 73 6f 72  {.  DbdataCursor
2220: 20 2a 70 43 73 72 20 3d 20 28 44 62 64 61 74 61   *pCsr = (Dbdata
2230: 43 75 72 73 6f 72 2a 29 70 43 75 72 73 6f 72 3b  Cursor*)pCursor;
2240: 0a 20 20 64 62 64 61 74 61 52 65 73 65 74 43 75  .  dbdataResetCu
2250: 72 73 6f 72 28 70 43 73 72 29 3b 0a 20 20 73 71  rsor(pCsr);.  sq
2260: 6c 69 74 65 33 5f 66 72 65 65 28 70 43 73 72 29  lite3_free(pCsr)
2270: 3b 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54  ;.  return SQLIT
2280: 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 20 0a 2a 2a 20  E_OK;.}../* .** 
2290: 55 74 69 6c 69 74 79 20 6d 65 74 68 6f 64 73 20  Utility methods 
22a0: 74 6f 20 64 65 63 6f 64 65 20 31 36 20 61 6e 64  to decode 16 and
22b0: 20 33 32 2d 62 69 74 20 62 69 67 2d 65 6e 64 69   32-bit big-endi
22c0: 61 6e 20 75 6e 73 69 67 6e 65 64 20 69 6e 74 65  an unsigned inte
22d0: 67 65 72 73 2e 20 0a 2a 2f 0a 73 74 61 74 69 63  gers. .*/.static
22e0: 20 75 6e 73 69 67 6e 65 64 20 69 6e 74 20 67 65   unsigned int ge
22f0: 74 5f 75 69 6e 74 31 36 28 75 6e 73 69 67 6e 65  t_uint16(unsigne
2300: 64 20 63 68 61 72 20 2a 61 29 7b 0a 20 20 72 65  d char *a){.  re
2310: 74 75 72 6e 20 28 61 5b 30 5d 3c 3c 38 29 7c 61  turn (a[0]<<8)|a
2320: 5b 31 5d 3b 0a 7d 0a 73 74 61 74 69 63 20 75 6e  [1];.}.static un
2330: 73 69 67 6e 65 64 20 69 6e 74 20 67 65 74 5f 75  signed int get_u
2340: 69 6e 74 33 32 28 75 6e 73 69 67 6e 65 64 20 63  int32(unsigned c
2350: 68 61 72 20 2a 61 29 7b 0a 20 20 72 65 74 75 72  har *a){.  retur
2360: 6e 20 28 28 75 6e 73 69 67 6e 65 64 20 69 6e 74  n ((unsigned int
2370: 29 61 5b 30 5d 3c 3c 32 34 29 0a 20 20 20 20 20  )a[0]<<24).     
2380: 20 20 7c 20 28 28 75 6e 73 69 67 6e 65 64 20 69    | ((unsigned i
2390: 6e 74 29 61 5b 31 5d 3c 3c 31 36 29 0a 20 20 20  nt)a[1]<<16).   
23a0: 20 20 20 20 7c 20 28 28 75 6e 73 69 67 6e 65 64      | ((unsigned
23b0: 20 69 6e 74 29 61 5b 32 5d 3c 3c 38 29 0a 20 20   int)a[2]<<8).  
23c0: 20 20 20 20 20 7c 20 28 28 75 6e 73 69 67 6e 65       | ((unsigne
23d0: 64 20 69 6e 74 29 61 5b 33 5d 29 3b 0a 7d 0a 0a  d int)a[3]);.}..
23e0: 2f 2a 0a 2a 2a 20 4c 6f 61 64 20 70 61 67 65 20  /*.** Load page 
23f0: 70 67 6e 6f 20 66 72 6f 6d 20 74 68 65 20 64 61  pgno from the da
2400: 74 61 62 61 73 65 20 76 69 61 20 74 68 65 20 73  tabase via the s
2410: 71 6c 69 74 65 5f 64 62 70 61 67 65 20 76 69 72  qlite_dbpage vir
2420: 74 75 61 6c 20 74 61 62 6c 65 2e 0a 2a 2a 20 49  tual table..** I
2430: 66 20 73 75 63 63 65 73 73 66 75 6c 2c 20 73 65  f successful, se
2440: 74 20 28 2a 70 70 50 61 67 65 29 20 74 6f 20 70  t (*ppPage) to p
2450: 6f 69 6e 74 20 74 6f 20 61 20 62 75 66 66 65 72  oint to a buffer
2460: 20 63 6f 6e 74 61 69 6e 69 6e 67 20 74 68 65 20   containing the 
2470: 70 61 67 65 0a 2a 2a 20 64 61 74 61 2c 20 28 2a  page.** data, (*
2480: 70 6e 50 61 67 65 29 20 74 6f 20 74 68 65 20 73  pnPage) to the s
2490: 69 7a 65 20 6f 66 20 74 68 61 74 20 62 75 66 66  ize of that buff
24a0: 65 72 20 69 6e 20 62 79 74 65 73 20 61 6e 64 20  er in bytes and 
24b0: 72 65 74 75 72 6e 0a 2a 2a 20 53 51 4c 49 54 45  return.** SQLITE
24c0: 5f 4f 4b 2e 20 49 6e 20 74 68 69 73 20 63 61 73  _OK. In this cas
24d0: 65 20 69 74 20 69 73 20 74 68 65 20 72 65 73 70  e it is the resp
24e0: 6f 6e 73 69 62 69 6c 69 74 79 20 6f 66 20 74 68  onsibility of th
24f0: 65 20 63 61 6c 6c 65 72 20 74 6f 0a 2a 2a 20 65  e caller to.** e
2500: 76 65 6e 74 75 61 6c 6c 79 20 66 72 65 65 20 74  ventually free t
2510: 68 65 20 62 75 66 66 65 72 20 75 73 69 6e 67 20  he buffer using 
2520: 73 71 6c 69 74 65 33 5f 66 72 65 65 28 29 2e 0a  sqlite3_free()..
2530: 2a 2a 0a 2a 2a 20 4f 72 2c 20 69 66 20 61 6e 20  **.** Or, if an 
2540: 65 72 72 6f 72 20 6f 63 63 75 72 73 2c 20 73 65  error occurs, se
2550: 74 20 62 6f 74 68 20 28 2a 70 70 50 61 67 65 29  t both (*ppPage)
2560: 20 61 6e 64 20 28 2a 70 6e 50 61 67 65 29 20 74   and (*pnPage) t
2570: 6f 20 30 20 61 6e 64 0a 2a 2a 20 72 65 74 75 72  o 0 and.** retur
2580: 6e 20 61 6e 20 53 51 4c 69 74 65 20 65 72 72 6f  n an SQLite erro
2590: 72 20 63 6f 64 65 2e 0a 2a 2f 0a 73 74 61 74 69  r code..*/.stati
25a0: 63 20 69 6e 74 20 64 62 64 61 74 61 4c 6f 61 64  c int dbdataLoad
25b0: 50 61 67 65 28 0a 20 20 44 62 64 61 74 61 43 75  Page(.  DbdataCu
25c0: 72 73 6f 72 20 2a 70 43 73 72 2c 20 20 20 20 20  rsor *pCsr,     
25d0: 20 20 20 20 20 20 20 20 2f 2a 20 43 75 72 73 6f          /* Curso
25e0: 72 20 6f 62 6a 65 63 74 20 2a 2f 0a 20 20 75 6e  r object */.  un
25f0: 73 69 67 6e 65 64 20 69 6e 74 20 70 67 6e 6f 2c  signed int pgno,
2600: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
2610: 20 50 61 67 65 20 6e 75 6d 62 65 72 20 6f 66 20   Page number of 
2620: 70 61 67 65 20 74 6f 20 6c 6f 61 64 20 2a 2f 0a  page to load */.
2630: 20 20 75 38 20 2a 2a 70 70 50 61 67 65 2c 20 20    u8 **ppPage,  
2640: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2650: 20 20 2f 2a 20 4f 55 54 3a 20 70 6f 69 6e 74 65    /* OUT: pointe
2660: 72 20 74 6f 20 70 61 67 65 20 62 75 66 66 65 72  r to page buffer
2670: 20 2a 2f 0a 20 20 69 6e 74 20 2a 70 6e 50 61 67   */.  int *pnPag
2680: 65 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  e               
2690: 20 20 20 20 20 20 2f 2a 20 4f 55 54 3a 20 53 69        /* OUT: Si
26a0: 7a 65 20 6f 66 20 28 2a 70 70 50 61 67 65 29 20  ze of (*ppPage) 
26b0: 69 6e 20 62 79 74 65 73 20 2a 2f 0a 29 7b 0a 20  in bytes */.){. 
26c0: 20 69 6e 74 20 72 63 32 3b 0a 20 20 69 6e 74 20   int rc2;.  int 
26d0: 72 63 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a  rc = SQLITE_OK;.
26e0: 20 20 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a    sqlite3_stmt *
26f0: 70 53 74 6d 74 20 3d 20 70 43 73 72 2d 3e 70 53  pStmt = pCsr->pS
2700: 74 6d 74 3b 0a 0a 20 20 2a 70 70 50 61 67 65 20  tmt;..  *ppPage 
2710: 3d 20 30 3b 0a 20 20 2a 70 6e 50 61 67 65 20 3d  = 0;.  *pnPage =
2720: 20 30 3b 0a 20 20 73 71 6c 69 74 65 33 5f 62 69   0;.  sqlite3_bi
2730: 6e 64 5f 69 6e 74 36 34 28 70 53 74 6d 74 2c 20  nd_int64(pStmt, 
2740: 32 2c 20 70 67 6e 6f 29 3b 0a 20 20 69 66 28 20  2, pgno);.  if( 
2750: 53 51 4c 49 54 45 5f 52 4f 57 3d 3d 73 71 6c 69  SQLITE_ROW==sqli
2760: 74 65 33 5f 73 74 65 70 28 70 53 74 6d 74 29 20  te3_step(pStmt) 
2770: 29 7b 0a 20 20 20 20 69 6e 74 20 6e 43 6f 70 79  ){.    int nCopy
2780: 20 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d   = sqlite3_colum
2790: 6e 5f 62 79 74 65 73 28 70 53 74 6d 74 2c 20 30  n_bytes(pStmt, 0
27a0: 29 3b 0a 20 20 20 20 69 66 28 20 6e 43 6f 70 79  );.    if( nCopy
27b0: 3e 30 20 29 7b 0a 20 20 20 20 20 20 75 38 20 2a  >0 ){.      u8 *
27c0: 70 50 61 67 65 3b 0a 20 20 20 20 20 20 70 50 61  pPage;.      pPa
27d0: 67 65 20 3d 20 28 75 38 2a 29 73 71 6c 69 74 65  ge = (u8*)sqlite
27e0: 33 5f 6d 61 6c 6c 6f 63 36 34 28 6e 43 6f 70 79  3_malloc64(nCopy
27f0: 20 2b 20 44 42 44 41 54 41 5f 50 41 44 44 49 4e   + DBDATA_PADDIN
2800: 47 5f 42 59 54 45 53 29 3b 0a 20 20 20 20 20 20  G_BYTES);.      
2810: 69 66 28 20 70 50 61 67 65 3d 3d 30 20 29 7b 0a  if( pPage==0 ){.
2820: 20 20 20 20 20 20 20 20 72 63 20 3d 20 53 51 4c          rc = SQL
2830: 49 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 20 20 20  ITE_NOMEM;.     
2840: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20   }else{.        
2850: 63 6f 6e 73 74 20 75 38 20 2a 70 43 6f 70 79 20  const u8 *pCopy 
2860: 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e  = sqlite3_column
2870: 5f 62 6c 6f 62 28 70 53 74 6d 74 2c 20 30 29 3b  _blob(pStmt, 0);
2880: 0a 20 20 20 20 20 20 20 20 6d 65 6d 63 70 79 28  .        memcpy(
2890: 70 50 61 67 65 2c 20 70 43 6f 70 79 2c 20 6e 43  pPage, pCopy, nC
28a0: 6f 70 79 29 3b 0a 20 20 20 20 20 20 20 20 6d 65  opy);.        me
28b0: 6d 73 65 74 28 26 70 50 61 67 65 5b 6e 43 6f 70  mset(&pPage[nCop
28c0: 79 5d 2c 20 30 2c 20 44 42 44 41 54 41 5f 50 41  y], 0, DBDATA_PA
28d0: 44 44 49 4e 47 5f 42 59 54 45 53 29 3b 0a 20 20  DDING_BYTES);.  
28e0: 20 20 20 20 7d 0a 20 20 20 20 20 20 2a 70 70 50      }.      *ppP
28f0: 61 67 65 20 3d 20 70 50 61 67 65 3b 0a 20 20 20  age = pPage;.   
2900: 20 20 20 2a 70 6e 50 61 67 65 20 3d 20 6e 43 6f     *pnPage = nCo
2910: 70 79 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20  py;.    }.  }.  
2920: 72 63 32 20 3d 20 73 71 6c 69 74 65 33 5f 72 65  rc2 = sqlite3_re
2930: 73 65 74 28 70 53 74 6d 74 29 3b 0a 20 20 69 66  set(pStmt);.  if
2940: 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20  ( rc==SQLITE_OK 
2950: 29 20 72 63 20 3d 20 72 63 32 3b 0a 0a 20 20 72  ) rc = rc2;..  r
2960: 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a  eturn rc;.}../*.
2970: 2a 2a 20 52 65 61 64 20 61 20 76 61 72 69 6e 74  ** Read a varint
2980: 2e 20 20 50 75 74 20 74 68 65 20 76 61 6c 75 65  .  Put the value
2990: 20 69 6e 20 2a 70 56 61 6c 20 61 6e 64 20 72 65   in *pVal and re
29a0: 74 75 72 6e 20 74 68 65 20 6e 75 6d 62 65 72 20  turn the number 
29b0: 6f 66 20 62 79 74 65 73 2e 0a 2a 2f 0a 73 74 61  of bytes..*/.sta
29c0: 74 69 63 20 69 6e 74 20 64 62 64 61 74 61 47 65  tic int dbdataGe
29d0: 74 56 61 72 69 6e 74 28 63 6f 6e 73 74 20 75 38  tVarint(const u8
29e0: 20 2a 7a 2c 20 73 71 6c 69 74 65 33 5f 69 6e 74   *z, sqlite3_int
29f0: 36 34 20 2a 70 56 61 6c 29 7b 0a 20 20 73 71 6c  64 *pVal){.  sql
2a00: 69 74 65 33 5f 69 6e 74 36 34 20 76 20 3d 20 30  ite3_int64 v = 0
2a10: 3b 0a 20 20 69 6e 74 20 69 3b 0a 20 20 66 6f 72  ;.  int i;.  for
2a20: 28 69 3d 30 3b 20 69 3c 38 3b 20 69 2b 2b 29 7b  (i=0; i<8; i++){
2a30: 0a 20 20 20 20 76 20 3d 20 28 76 3c 3c 37 29 20  .    v = (v<<7) 
2a40: 2b 20 28 7a 5b 69 5d 26 30 78 37 66 29 3b 0a 20  + (z[i]&0x7f);. 
2a50: 20 20 20 69 66 28 20 28 7a 5b 69 5d 26 30 78 38     if( (z[i]&0x8
2a60: 30 29 3d 3d 30 20 29 7b 20 2a 70 56 61 6c 20 3d  0)==0 ){ *pVal =
2a70: 20 76 3b 20 72 65 74 75 72 6e 20 69 2b 31 3b 20   v; return i+1; 
2a80: 7d 0a 20 20 7d 0a 20 20 76 20 3d 20 28 76 3c 3c  }.  }.  v = (v<<
2a90: 38 29 20 2b 20 28 7a 5b 69 5d 26 30 78 66 66 29  8) + (z[i]&0xff)
2aa0: 3b 0a 20 20 2a 70 56 61 6c 20 3d 20 76 3b 0a 20  ;.  *pVal = v;. 
2ab0: 20 72 65 74 75 72 6e 20 39 3b 0a 7d 0a 0a 2f 2a   return 9;.}../*
2ac0: 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20 6e  .** Return the n
2ad0: 75 6d 62 65 72 20 6f 66 20 62 79 74 65 73 20 6f  umber of bytes o
2ae0: 66 20 73 70 61 63 65 20 75 73 65 64 20 62 79 20  f space used by 
2af0: 61 6e 20 53 51 4c 69 74 65 20 76 61 6c 75 65 20  an SQLite value 
2b00: 6f 66 20 74 79 70 65 0a 2a 2a 20 65 54 79 70 65  of type.** eType
2b10: 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20  ..*/.static int 
2b20: 64 62 64 61 74 61 56 61 6c 75 65 42 79 74 65 73  dbdataValueBytes
2b30: 28 69 6e 74 20 65 54 79 70 65 29 7b 0a 20 20 73  (int eType){.  s
2b40: 77 69 74 63 68 28 20 65 54 79 70 65 20 29 7b 0a  witch( eType ){.
2b50: 20 20 20 20 63 61 73 65 20 30 3a 20 63 61 73 65      case 0: case
2b60: 20 38 3a 20 63 61 73 65 20 39 3a 0a 20 20 20 20   8: case 9:.    
2b70: 63 61 73 65 20 31 30 3a 20 63 61 73 65 20 31 31  case 10: case 11
2b80: 3a 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 30  :.      return 0
2b90: 3b 0a 20 20 20 20 63 61 73 65 20 31 3a 0a 20 20  ;.    case 1:.  
2ba0: 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20      return 1;.  
2bb0: 20 20 63 61 73 65 20 32 3a 0a 20 20 20 20 20 20    case 2:.      
2bc0: 72 65 74 75 72 6e 20 32 3b 0a 20 20 20 20 63 61  return 2;.    ca
2bd0: 73 65 20 33 3a 0a 20 20 20 20 20 20 72 65 74 75  se 3:.      retu
2be0: 72 6e 20 33 3b 0a 20 20 20 20 63 61 73 65 20 34  rn 3;.    case 4
2bf0: 3a 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 34  :.      return 4
2c00: 3b 0a 20 20 20 20 63 61 73 65 20 35 3a 0a 20 20  ;.    case 5:.  
2c10: 20 20 20 20 72 65 74 75 72 6e 20 36 3b 0a 20 20      return 6;.  
2c20: 20 20 63 61 73 65 20 36 3a 0a 20 20 20 20 63 61    case 6:.    ca
2c30: 73 65 20 37 3a 0a 20 20 20 20 20 20 72 65 74 75  se 7:.      retu
2c40: 72 6e 20 38 3b 0a 20 20 20 20 64 65 66 61 75 6c  rn 8;.    defaul
2c50: 74 3a 0a 20 20 20 20 20 20 69 66 28 20 65 54 79  t:.      if( eTy
2c60: 70 65 3e 30 20 29 7b 0a 20 20 20 20 20 20 20 20  pe>0 ){.        
2c70: 72 65 74 75 72 6e 20 28 28 65 54 79 70 65 2d 31  return ((eType-1
2c80: 32 29 20 2f 20 32 29 3b 0a 20 20 20 20 20 20 7d  2) / 2);.      }
2c90: 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 30 3b  .      return 0;
2ca0: 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 4c 6f  .  }.}../*.** Lo
2cb0: 61 64 20 61 20 76 61 6c 75 65 20 6f 66 20 74 79  ad a value of ty
2cc0: 70 65 20 65 54 79 70 65 20 66 72 6f 6d 20 62 75  pe eType from bu
2cd0: 66 66 65 72 20 70 44 61 74 61 20 61 6e 64 20 75  ffer pData and u
2ce0: 73 65 20 69 74 20 74 6f 20 73 65 74 20 74 68 65  se it to set the
2cf0: 0a 2a 2a 20 72 65 73 75 6c 74 20 6f 66 20 63 6f  .** result of co
2d00: 6e 74 65 78 74 20 6f 62 6a 65 63 74 20 70 43 74  ntext object pCt
2d10: 78 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69  x..*/.static voi
2d20: 64 20 64 62 64 61 74 61 56 61 6c 75 65 28 0a 20  d dbdataValue(. 
2d30: 20 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74   sqlite3_context
2d40: 20 2a 70 43 74 78 2c 20 0a 20 20 69 6e 74 20 65   *pCtx, .  int e
2d50: 54 79 70 65 2c 20 0a 20 20 75 38 20 2a 70 44 61  Type, .  u8 *pDa
2d60: 74 61 2c 0a 20 20 69 6e 74 20 6e 44 61 74 61 0a  ta,.  int nData.
2d70: 29 7b 0a 20 20 69 66 28 20 65 54 79 70 65 3e 3d  ){.  if( eType>=
2d80: 30 20 26 26 20 64 62 64 61 74 61 56 61 6c 75 65  0 && dbdataValue
2d90: 42 79 74 65 73 28 65 54 79 70 65 29 3c 3d 6e 44  Bytes(eType)<=nD
2da0: 61 74 61 20 29 7b 0a 20 20 20 20 73 77 69 74 63  ata ){.    switc
2db0: 68 28 20 65 54 79 70 65 20 29 7b 0a 20 20 20 20  h( eType ){.    
2dc0: 20 20 63 61 73 65 20 30 3a 20 0a 20 20 20 20 20    case 0: .     
2dd0: 20 63 61 73 65 20 31 30 3a 20 0a 20 20 20 20 20   case 10: .     
2de0: 20 63 61 73 65 20 31 31 3a 20 0a 20 20 20 20 20   case 11: .     
2df0: 20 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c     sqlite3_resul
2e00: 74 5f 6e 75 6c 6c 28 70 43 74 78 29 3b 0a 20 20  t_null(pCtx);.  
2e10: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
2e20: 20 20 20 0a 20 20 20 20 20 20 63 61 73 65 20 38     .      case 8
2e30: 3a 20 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  : .        sqlit
2e40: 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74 28 70 43  e3_result_int(pC
2e50: 74 78 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20  tx, 0);.        
2e60: 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 63 61 73  break;.      cas
2e70: 65 20 39 3a 0a 20 20 20 20 20 20 20 20 73 71 6c  e 9:.        sql
2e80: 69 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74 28  ite3_result_int(
2e90: 70 43 74 78 2c 20 31 29 3b 0a 20 20 20 20 20 20  pCtx, 1);.      
2ea0: 20 20 62 72 65 61 6b 3b 0a 20 20 0a 20 20 20 20    break;.  .    
2eb0: 20 20 63 61 73 65 20 31 3a 20 63 61 73 65 20 32    case 1: case 2
2ec0: 3a 20 63 61 73 65 20 33 3a 20 63 61 73 65 20 34  : case 3: case 4
2ed0: 3a 20 63 61 73 65 20 35 3a 20 63 61 73 65 20 36  : case 5: case 6
2ee0: 3a 20 63 61 73 65 20 37 3a 20 7b 0a 20 20 20 20  : case 7: {.    
2ef0: 20 20 20 20 73 71 6c 69 74 65 33 5f 75 69 6e 74      sqlite3_uint
2f00: 36 34 20 76 20 3d 20 28 73 69 67 6e 65 64 20 63  64 v = (signed c
2f10: 68 61 72 29 70 44 61 74 61 5b 30 5d 3b 0a 20 20  har)pData[0];.  
2f20: 20 20 20 20 20 20 70 44 61 74 61 2b 2b 3b 0a 20        pData++;. 
2f30: 20 20 20 20 20 20 20 73 77 69 74 63 68 28 20 65         switch( e
2f40: 54 79 70 65 20 29 7b 0a 20 20 20 20 20 20 20 20  Type ){.        
2f50: 20 20 63 61 73 65 20 37 3a 0a 20 20 20 20 20 20    case 7:.      
2f60: 20 20 20 20 63 61 73 65 20 36 3a 20 20 76 20 3d      case 6:  v =
2f70: 20 28 76 3c 3c 31 36 29 20 2b 20 28 70 44 61 74   (v<<16) + (pDat
2f80: 61 5b 30 5d 3c 3c 38 29 20 2b 20 70 44 61 74 61  a[0]<<8) + pData
2f90: 5b 31 5d 3b 20 20 70 44 61 74 61 20 2b 3d 20 32  [1];  pData += 2
2fa0: 3b 0a 20 20 20 20 20 20 20 20 20 20 63 61 73 65  ;.          case
2fb0: 20 35 3a 20 20 76 20 3d 20 28 76 3c 3c 31 36 29   5:  v = (v<<16)
2fc0: 20 2b 20 28 70 44 61 74 61 5b 30 5d 3c 3c 38 29   + (pData[0]<<8)
2fd0: 20 2b 20 70 44 61 74 61 5b 31 5d 3b 20 20 70 44   + pData[1];  pD
2fe0: 61 74 61 20 2b 3d 20 32 3b 0a 20 20 20 20 20 20  ata += 2;.      
2ff0: 20 20 20 20 63 61 73 65 20 34 3a 20 20 76 20 3d      case 4:  v =
3000: 20 28 76 3c 3c 38 29 20 2b 20 70 44 61 74 61 5b   (v<<8) + pData[
3010: 30 5d 3b 20 20 70 44 61 74 61 2b 2b 3b 0a 20 20  0];  pData++;.  
3020: 20 20 20 20 20 20 20 20 63 61 73 65 20 33 3a 20          case 3: 
3030: 20 76 20 3d 20 28 76 3c 3c 38 29 20 2b 20 70 44   v = (v<<8) + pD
3040: 61 74 61 5b 30 5d 3b 20 20 70 44 61 74 61 2b 2b  ata[0];  pData++
3050: 3b 0a 20 20 20 20 20 20 20 20 20 20 63 61 73 65  ;.          case
3060: 20 32 3a 20 20 76 20 3d 20 28 76 3c 3c 38 29 20   2:  v = (v<<8) 
3070: 2b 20 70 44 61 74 61 5b 30 5d 3b 20 20 70 44 61  + pData[0];  pDa
3080: 74 61 2b 2b 3b 0a 20 20 20 20 20 20 20 20 7d 0a  ta++;.        }.
3090: 20 20 0a 20 20 20 20 20 20 20 20 69 66 28 20 65    .        if( e
30a0: 54 79 70 65 3d 3d 37 20 29 7b 0a 20 20 20 20 20  Type==7 ){.     
30b0: 20 20 20 20 20 64 6f 75 62 6c 65 20 72 3b 0a 20       double r;. 
30c0: 20 20 20 20 20 20 20 20 20 6d 65 6d 63 70 79 28           memcpy(
30d0: 26 72 2c 20 26 76 2c 20 73 69 7a 65 6f 66 28 72  &r, &v, sizeof(r
30e0: 29 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73 71  ));.          sq
30f0: 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 64 6f 75  lite3_result_dou
3100: 62 6c 65 28 70 43 74 78 2c 20 72 29 3b 0a 20 20  ble(pCtx, r);.  
3110: 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20        }else{.   
3120: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 72         sqlite3_r
3130: 65 73 75 6c 74 5f 69 6e 74 36 34 28 70 43 74 78  esult_int64(pCtx
3140: 2c 20 28 73 71 6c 69 74 65 33 5f 69 6e 74 36 34  , (sqlite3_int64
3150: 29 76 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20  )v);.        }. 
3160: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20         break;.  
3170: 20 20 20 20 7d 0a 20 20 0a 20 20 20 20 20 20 64      }.  .      d
3180: 65 66 61 75 6c 74 3a 20 7b 0a 20 20 20 20 20 20  efault: {.      
3190: 20 20 69 6e 74 20 6e 20 3d 20 28 28 65 54 79 70    int n = ((eTyp
31a0: 65 2d 31 32 29 20 2f 20 32 29 3b 0a 20 20 20 20  e-12) / 2);.    
31b0: 20 20 20 20 69 66 28 20 65 54 79 70 65 20 25 20      if( eType % 
31c0: 32 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 73  2 ){.          s
31d0: 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 74 65  qlite3_result_te
31e0: 78 74 28 70 43 74 78 2c 20 28 63 6f 6e 73 74 20  xt(pCtx, (const 
31f0: 63 68 61 72 2a 29 70 44 61 74 61 2c 20 6e 2c 20  char*)pData, n, 
3200: 53 51 4c 49 54 45 5f 54 52 41 4e 53 49 45 4e 54  SQLITE_TRANSIENT
3210: 29 3b 0a 20 20 20 20 20 20 20 20 7d 65 6c 73 65  );.        }else
3220: 7b 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69  {.          sqli
3230: 74 65 33 5f 72 65 73 75 6c 74 5f 62 6c 6f 62 28  te3_result_blob(
3240: 70 43 74 78 2c 20 70 44 61 74 61 2c 20 6e 2c 20  pCtx, pData, n, 
3250: 53 51 4c 49 54 45 5f 54 52 41 4e 53 49 45 4e 54  SQLITE_TRANSIENT
3260: 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  );.        }.   
3270: 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d     }.    }.  }.}
3280: 0a 0a 2f 2a 0a 2a 2a 20 4d 6f 76 65 20 61 6e 20  ../*.** Move an 
3290: 73 71 6c 69 74 65 5f 64 62 64 61 74 61 20 6f 72  sqlite_dbdata or
32a0: 20 73 71 6c 69 74 65 5f 64 62 70 74 72 20 63 75   sqlite_dbptr cu
32b0: 72 73 6f 72 20 74 6f 20 74 68 65 20 6e 65 78 74  rsor to the next
32c0: 20 65 6e 74 72 79 2e 0a 2a 2f 0a 73 74 61 74 69   entry..*/.stati
32d0: 63 20 69 6e 74 20 64 62 64 61 74 61 4e 65 78 74  c int dbdataNext
32e0: 28 73 71 6c 69 74 65 33 5f 76 74 61 62 5f 63 75  (sqlite3_vtab_cu
32f0: 72 73 6f 72 20 2a 70 43 75 72 73 6f 72 29 7b 0a  rsor *pCursor){.
3300: 20 20 44 62 64 61 74 61 43 75 72 73 6f 72 20 2a    DbdataCursor *
3310: 70 43 73 72 20 3d 20 28 44 62 64 61 74 61 43 75  pCsr = (DbdataCu
3320: 72 73 6f 72 2a 29 70 43 75 72 73 6f 72 3b 0a 20  rsor*)pCursor;. 
3330: 20 44 62 64 61 74 61 54 61 62 6c 65 20 2a 70 54   DbdataTable *pT
3340: 61 62 20 3d 20 28 44 62 64 61 74 61 54 61 62 6c  ab = (DbdataTabl
3350: 65 2a 29 70 43 75 72 73 6f 72 2d 3e 70 56 74 61  e*)pCursor->pVta
3360: 62 3b 0a 0a 20 20 70 43 73 72 2d 3e 69 52 6f 77  b;..  pCsr->iRow
3370: 69 64 2b 2b 3b 0a 20 20 77 68 69 6c 65 28 20 31  id++;.  while( 1
3380: 20 29 7b 0a 20 20 20 20 69 6e 74 20 72 63 3b 0a   ){.    int rc;.
3390: 20 20 20 20 69 6e 74 20 69 4f 66 66 20 3d 20 28      int iOff = (
33a0: 70 43 73 72 2d 3e 69 50 67 6e 6f 3d 3d 31 20 3f  pCsr->iPgno==1 ?
33b0: 20 31 30 30 20 3a 20 30 29 3b 0a 20 20 20 20 69   100 : 0);.    i
33c0: 6e 74 20 62 4e 65 78 74 50 61 67 65 20 3d 20 30  nt bNextPage = 0
33d0: 3b 0a 0a 20 20 20 20 69 66 28 20 70 43 73 72 2d  ;..    if( pCsr-
33e0: 3e 61 50 61 67 65 3d 3d 30 20 29 7b 0a 20 20 20  >aPage==0 ){.   
33f0: 20 20 20 77 68 69 6c 65 28 20 31 20 29 7b 0a 20     while( 1 ){. 
3400: 20 20 20 20 20 20 20 69 66 28 20 70 43 73 72 2d         if( pCsr-
3410: 3e 62 4f 6e 65 50 61 67 65 3d 3d 30 20 26 26 20  >bOnePage==0 && 
3420: 70 43 73 72 2d 3e 69 50 67 6e 6f 3e 70 43 73 72  pCsr->iPgno>pCsr
3430: 2d 3e 73 7a 44 62 20 29 20 72 65 74 75 72 6e 20  ->szDb ) return 
3440: 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 20 20 20  SQLITE_OK;.     
3450: 20 20 20 72 63 20 3d 20 64 62 64 61 74 61 4c 6f     rc = dbdataLo
3460: 61 64 50 61 67 65 28 70 43 73 72 2c 20 70 43 73  adPage(pCsr, pCs
3470: 72 2d 3e 69 50 67 6e 6f 2c 20 26 70 43 73 72 2d  r->iPgno, &pCsr-
3480: 3e 61 50 61 67 65 2c 20 26 70 43 73 72 2d 3e 6e  >aPage, &pCsr->n
3490: 50 61 67 65 29 3b 0a 20 20 20 20 20 20 20 20 69  Page);.        i
34a0: 66 28 20 72 63 21 3d 53 51 4c 49 54 45 5f 4f 4b  f( rc!=SQLITE_OK
34b0: 20 29 20 72 65 74 75 72 6e 20 72 63 3b 0a 20 20   ) return rc;.  
34c0: 20 20 20 20 20 20 69 66 28 20 70 43 73 72 2d 3e        if( pCsr->
34d0: 61 50 61 67 65 20 29 20 62 72 65 61 6b 3b 0a 20  aPage ) break;. 
34e0: 20 20 20 20 20 20 20 70 43 73 72 2d 3e 69 50 67         pCsr->iPg
34f0: 6e 6f 2b 2b 3b 0a 20 20 20 20 20 20 7d 0a 20 20  no++;.      }.  
3500: 20 20 20 20 70 43 73 72 2d 3e 69 43 65 6c 6c 20      pCsr->iCell 
3510: 3d 20 70 54 61 62 2d 3e 62 50 74 72 20 3f 20 2d  = pTab->bPtr ? -
3520: 32 20 3a 20 30 3b 0a 20 20 20 20 20 20 70 43 73  2 : 0;.      pCs
3530: 72 2d 3e 6e 43 65 6c 6c 20 3d 20 67 65 74 5f 75  r->nCell = get_u
3540: 69 6e 74 31 36 28 26 70 43 73 72 2d 3e 61 50 61  int16(&pCsr->aPa
3550: 67 65 5b 69 4f 66 66 2b 33 5d 29 3b 0a 20 20 20  ge[iOff+3]);.   
3560: 20 7d 0a 0a 20 20 20 20 69 66 28 20 70 54 61 62   }..    if( pTab
3570: 2d 3e 62 50 74 72 20 29 7b 0a 20 20 20 20 20 20  ->bPtr ){.      
3580: 69 66 28 20 70 43 73 72 2d 3e 61 50 61 67 65 5b  if( pCsr->aPage[
3590: 69 4f 66 66 5d 21 3d 30 78 30 32 20 26 26 20 70  iOff]!=0x02 && p
35a0: 43 73 72 2d 3e 61 50 61 67 65 5b 69 4f 66 66 5d  Csr->aPage[iOff]
35b0: 21 3d 30 78 30 35 20 29 7b 0a 20 20 20 20 20 20  !=0x05 ){.      
35c0: 20 20 70 43 73 72 2d 3e 69 43 65 6c 6c 20 3d 20    pCsr->iCell = 
35d0: 70 43 73 72 2d 3e 6e 43 65 6c 6c 3b 0a 20 20 20  pCsr->nCell;.   
35e0: 20 20 20 7d 0a 20 20 20 20 20 20 70 43 73 72 2d     }.      pCsr-
35f0: 3e 69 43 65 6c 6c 2b 2b 3b 0a 20 20 20 20 20 20  >iCell++;.      
3600: 69 66 28 20 70 43 73 72 2d 3e 69 43 65 6c 6c 3e  if( pCsr->iCell>
3610: 3d 70 43 73 72 2d 3e 6e 43 65 6c 6c 20 29 7b 0a  =pCsr->nCell ){.
3620: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f          sqlite3_
3630: 66 72 65 65 28 70 43 73 72 2d 3e 61 50 61 67 65  free(pCsr->aPage
3640: 29 3b 0a 20 20 20 20 20 20 20 20 70 43 73 72 2d  );.        pCsr-
3650: 3e 61 50 61 67 65 20 3d 20 30 3b 0a 20 20 20 20  >aPage = 0;.    
3660: 20 20 20 20 69 66 28 20 70 43 73 72 2d 3e 62 4f      if( pCsr->bO
3670: 6e 65 50 61 67 65 20 29 20 72 65 74 75 72 6e 20  nePage ) return 
3680: 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 20 20 20  SQLITE_OK;.     
3690: 20 20 20 70 43 73 72 2d 3e 69 50 67 6e 6f 2b 2b     pCsr->iPgno++
36a0: 3b 0a 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20  ;.      }else{. 
36b0: 20 20 20 20 20 20 20 72 65 74 75 72 6e 20 53 51         return SQ
36c0: 4c 49 54 45 5f 4f 4b 3b 0a 20 20 20 20 20 20 7d  LITE_OK;.      }
36d0: 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  .    }else{.    
36e0: 20 20 2f 2a 20 49 66 20 74 68 65 72 65 20 69 73    /* If there is
36f0: 20 6e 6f 20 72 65 63 6f 72 64 20 6c 6f 61 64 65   no record loade
3700: 64 2c 20 6c 6f 61 64 20 69 74 20 6e 6f 77 2e 20  d, load it now. 
3710: 2a 2f 0a 20 20 20 20 20 20 69 66 28 20 70 43 73  */.      if( pCs
3720: 72 2d 3e 70 52 65 63 3d 3d 30 20 29 7b 0a 20 20  r->pRec==0 ){.  
3730: 20 20 20 20 20 20 69 6e 74 20 62 48 61 73 52 6f        int bHasRo
3740: 77 69 64 20 3d 20 30 3b 0a 20 20 20 20 20 20 20  wid = 0;.       
3750: 20 69 6e 74 20 6e 50 6f 69 6e 74 65 72 20 3d 20   int nPointer = 
3760: 30 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  0;.        sqlit
3770: 65 33 5f 69 6e 74 36 34 20 6e 50 61 79 6c 6f 61  e3_int64 nPayloa
3780: 64 20 3d 20 30 3b 0a 20 20 20 20 20 20 20 20 73  d = 0;.        s
3790: 71 6c 69 74 65 33 5f 69 6e 74 36 34 20 6e 48 64  qlite3_int64 nHd
37a0: 72 20 3d 20 30 3b 0a 20 20 20 20 20 20 20 20 69  r = 0;.        i
37b0: 6e 74 20 69 48 64 72 3b 0a 20 20 20 20 20 20 20  nt iHdr;.       
37c0: 20 69 6e 74 20 55 2c 20 58 3b 0a 20 20 20 20 20   int U, X;.     
37d0: 20 20 20 69 6e 74 20 6e 4c 6f 63 61 6c 3b 0a 20     int nLocal;. 
37e0: 20 0a 20 20 20 20 20 20 20 20 73 77 69 74 63 68   .        switch
37f0: 28 20 70 43 73 72 2d 3e 61 50 61 67 65 5b 69 4f  ( pCsr->aPage[iO
3800: 66 66 5d 20 29 7b 0a 20 20 20 20 20 20 20 20 20  ff] ){.         
3810: 20 63 61 73 65 20 30 78 30 32 3a 0a 20 20 20 20   case 0x02:.    
3820: 20 20 20 20 20 20 20 20 6e 50 6f 69 6e 74 65 72          nPointer
3830: 20 3d 20 34 3b 0a 20 20 20 20 20 20 20 20 20 20   = 4;.          
3840: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 20    break;.       
3850: 20 20 20 63 61 73 65 20 30 78 30 61 3a 0a 20 20     case 0x0a:.  
3860: 20 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b            break;
3870: 0a 20 20 20 20 20 20 20 20 20 20 63 61 73 65 20  .          case 
3880: 30 78 30 64 3a 0a 20 20 20 20 20 20 20 20 20 20  0x0d:.          
3890: 20 20 62 48 61 73 52 6f 77 69 64 20 3d 20 31 3b    bHasRowid = 1;
38a0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 62 72 65  .            bre
38b0: 61 6b 3b 0a 20 20 20 20 20 20 20 20 20 20 64 65  ak;.          de
38c0: 66 61 75 6c 74 3a 0a 20 20 20 20 20 20 20 20 20  fault:.         
38d0: 20 20 20 2f 2a 20 54 68 69 73 20 69 73 20 6e 6f     /* This is no
38e0: 74 20 61 20 62 2d 74 72 65 65 20 70 61 67 65 20  t a b-tree page 
38f0: 77 69 74 68 20 72 65 63 6f 72 64 73 20 6f 6e 20  with records on 
3900: 69 74 2e 20 43 6f 6e 74 69 6e 75 65 2e 20 2a 2f  it. Continue. */
3910: 0a 20 20 20 20 20 20 20 20 20 20 20 20 70 43 73  .            pCs
3920: 72 2d 3e 69 43 65 6c 6c 20 3d 20 70 43 73 72 2d  r->iCell = pCsr-
3930: 3e 6e 43 65 6c 6c 3b 0a 20 20 20 20 20 20 20 20  >nCell;.        
3940: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20      break;.     
3950: 20 20 20 7d 0a 0a 20 20 20 20 20 20 20 20 69 66     }..        if
3960: 28 20 70 43 73 72 2d 3e 69 43 65 6c 6c 3e 3d 70  ( pCsr->iCell>=p
3970: 43 73 72 2d 3e 6e 43 65 6c 6c 20 29 7b 0a 20 20  Csr->nCell ){.  
3980: 20 20 20 20 20 20 20 20 62 4e 65 78 74 50 61 67          bNextPag
3990: 65 20 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 7d  e = 1;.        }
39a0: 65 6c 73 65 7b 0a 20 20 0a 20 20 20 20 20 20 20  else{.  .       
39b0: 20 20 20 69 4f 66 66 20 2b 3d 20 38 20 2b 20 6e     iOff += 8 + n
39c0: 50 6f 69 6e 74 65 72 20 2b 20 70 43 73 72 2d 3e  Pointer + pCsr->
39d0: 69 43 65 6c 6c 2a 32 3b 0a 20 20 20 20 20 20 20  iCell*2;.       
39e0: 20 20 20 69 66 28 20 69 4f 66 66 3e 70 43 73 72     if( iOff>pCsr
39f0: 2d 3e 6e 50 61 67 65 20 29 7b 0a 20 20 20 20 20  ->nPage ){.     
3a00: 20 20 20 20 20 20 20 62 4e 65 78 74 50 61 67 65         bNextPage
3a10: 20 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 20 20   = 1;.          
3a20: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 20  }else{.         
3a30: 20 20 20 69 4f 66 66 20 3d 20 67 65 74 5f 75 69     iOff = get_ui
3a40: 6e 74 31 36 28 26 70 43 73 72 2d 3e 61 50 61 67  nt16(&pCsr->aPag
3a50: 65 5b 69 4f 66 66 5d 29 3b 0a 20 20 20 20 20 20  e[iOff]);.      
3a60: 20 20 20 20 7d 0a 20 20 20 20 0a 20 20 20 20 20      }.    .     
3a70: 20 20 20 20 20 2f 2a 20 46 6f 72 20 61 6e 20 69       /* For an i
3a80: 6e 74 65 72 69 6f 72 20 6e 6f 64 65 20 63 65 6c  nterior node cel
3a90: 6c 2c 20 73 6b 69 70 20 70 61 73 74 20 74 68 65  l, skip past the
3aa0: 20 63 68 69 6c 64 2d 70 61 67 65 20 6e 75 6d 62   child-page numb
3ab0: 65 72 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20  er */.          
3ac0: 69 4f 66 66 20 2b 3d 20 6e 50 6f 69 6e 74 65 72  iOff += nPointer
3ad0: 3b 0a 20 20 20 20 0a 20 20 20 20 20 20 20 20 20  ;.    .         
3ae0: 20 2f 2a 20 4c 6f 61 64 20 74 68 65 20 22 62 79   /* Load the "by
3af0: 74 65 20 6f 66 20 70 61 79 6c 6f 61 64 20 69 6e  te of payload in
3b00: 63 6c 75 64 69 6e 67 20 6f 76 65 72 66 6c 6f 77  cluding overflow
3b10: 22 20 66 69 65 6c 64 20 2a 2f 0a 20 20 20 20 20  " field */.     
3b20: 20 20 20 20 20 69 66 28 20 62 4e 65 78 74 50 61       if( bNextPa
3b30: 67 65 20 7c 7c 20 69 4f 66 66 3e 70 43 73 72 2d  ge || iOff>pCsr-
3b40: 3e 6e 50 61 67 65 20 29 7b 0a 20 20 20 20 20 20  >nPage ){.      
3b50: 20 20 20 20 20 20 62 4e 65 78 74 50 61 67 65 20        bNextPage 
3b60: 3d 20 31 3b 0a 20 20 20 20 20 20 20 20 20 20 7d  = 1;.          }
3b70: 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 20 20  else{.          
3b80: 20 20 69 4f 66 66 20 2b 3d 20 64 62 64 61 74 61    iOff += dbdata
3b90: 47 65 74 56 61 72 69 6e 74 28 26 70 43 73 72 2d  GetVarint(&pCsr-
3ba0: 3e 61 50 61 67 65 5b 69 4f 66 66 5d 2c 20 26 6e  >aPage[iOff], &n
3bb0: 50 61 79 6c 6f 61 64 29 3b 0a 20 20 20 20 20 20  Payload);.      
3bc0: 20 20 20 20 7d 0a 20 20 20 20 0a 20 20 20 20 20      }.    .     
3bd0: 20 20 20 20 20 2f 2a 20 49 66 20 74 68 69 73 20       /* If this 
3be0: 69 73 20 61 20 6c 65 61 66 20 69 6e 74 6b 65 79  is a leaf intkey
3bf0: 20 63 65 6c 6c 2c 20 6c 6f 61 64 20 74 68 65 20   cell, load the 
3c00: 72 6f 77 69 64 20 2a 2f 0a 20 20 20 20 20 20 20  rowid */.       
3c10: 20 20 20 69 66 28 20 62 48 61 73 52 6f 77 69 64     if( bHasRowid
3c20: 20 26 26 20 21 62 4e 65 78 74 50 61 67 65 20 26   && !bNextPage &
3c30: 26 20 69 4f 66 66 3c 70 43 73 72 2d 3e 6e 50 61  & iOff<pCsr->nPa
3c40: 67 65 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  ge ){.          
3c50: 20 20 69 4f 66 66 20 2b 3d 20 64 62 64 61 74 61    iOff += dbdata
3c60: 47 65 74 56 61 72 69 6e 74 28 26 70 43 73 72 2d  GetVarint(&pCsr-
3c70: 3e 61 50 61 67 65 5b 69 4f 66 66 5d 2c 20 26 70  >aPage[iOff], &p
3c80: 43 73 72 2d 3e 69 49 6e 74 6b 65 79 29 3b 0a 20  Csr->iIntkey);. 
3c90: 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 0a           }.    .
3ca0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 46 69 67            /* Fig
3cb0: 75 72 65 20 6f 75 74 20 68 6f 77 20 6d 75 63 68  ure out how much
3cc0: 20 64 61 74 61 20 74 6f 20 72 65 61 64 20 66 72   data to read fr
3cd0: 6f 6d 20 74 68 65 20 6c 6f 63 61 6c 20 70 61 67  om the local pag
3ce0: 65 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 55  e */.          U
3cf0: 20 3d 20 70 43 73 72 2d 3e 6e 50 61 67 65 3b 0a   = pCsr->nPage;.
3d00: 20 20 20 20 20 20 20 20 20 20 69 66 28 20 62 48            if( bH
3d10: 61 73 52 6f 77 69 64 20 29 7b 0a 20 20 20 20 20  asRowid ){.     
3d20: 20 20 20 20 20 20 20 58 20 3d 20 55 2d 33 35 3b         X = U-35;
3d30: 0a 20 20 20 20 20 20 20 20 20 20 7d 65 6c 73 65  .          }else
3d40: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 58 20  {.            X 
3d50: 3d 20 28 28 55 2d 31 32 29 2a 36 34 2f 32 35 35  = ((U-12)*64/255
3d60: 29 2d 32 33 3b 0a 20 20 20 20 20 20 20 20 20 20  )-23;.          
3d70: 7d 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20  }.          if( 
3d80: 6e 50 61 79 6c 6f 61 64 3c 3d 58 20 29 7b 0a 20  nPayload<=X ){. 
3d90: 20 20 20 20 20 20 20 20 20 20 20 6e 4c 6f 63 61             nLoca
3da0: 6c 20 3d 20 6e 50 61 79 6c 6f 61 64 3b 0a 20 20  l = nPayload;.  
3db0: 20 20 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20          }else{. 
3dc0: 20 20 20 20 20 20 20 20 20 20 20 69 6e 74 20 4d             int M
3dd0: 2c 20 4b 3b 0a 20 20 20 20 20 20 20 20 20 20 20  , K;.           
3de0: 20 4d 20 3d 20 28 28 55 2d 31 32 29 2a 33 32 2f   M = ((U-12)*32/
3df0: 32 35 35 29 2d 32 33 3b 0a 20 20 20 20 20 20 20  255)-23;.       
3e00: 20 20 20 20 20 4b 20 3d 20 4d 2b 28 28 6e 50 61       K = M+((nPa
3e10: 79 6c 6f 61 64 2d 4d 29 25 28 55 2d 34 29 29 3b  yload-M)%(U-4));
3e20: 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 66 28  .            if(
3e30: 20 4b 3c 3d 58 20 29 7b 0a 20 20 20 20 20 20 20   K<=X ){.       
3e40: 20 20 20 20 20 20 20 6e 4c 6f 63 61 6c 20 3d 20         nLocal = 
3e50: 4b 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 7d  K;.            }
3e60: 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 20 20  else{.          
3e70: 20 20 20 20 6e 4c 6f 63 61 6c 20 3d 20 4d 3b 0a      nLocal = M;.
3e80: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20              }.  
3e90: 20 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20          }..     
3ea0: 20 20 20 20 20 69 66 28 20 62 4e 65 78 74 50 61       if( bNextPa
3eb0: 67 65 20 7c 7c 20 6e 4c 6f 63 61 6c 2b 69 4f 66  ge || nLocal+iOf
3ec0: 66 3e 70 43 73 72 2d 3e 6e 50 61 67 65 20 29 7b  f>pCsr->nPage ){
3ed0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 62 4e 65  .            bNe
3ee0: 78 74 50 61 67 65 20 3d 20 31 3b 0a 20 20 20 20  xtPage = 1;.    
3ef0: 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a 0a 20 20        }else{..  
3f00: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 41 6c 6c            /* All
3f10: 6f 63 61 74 65 20 73 70 61 63 65 20 66 6f 72 20  ocate space for 
3f20: 70 61 79 6c 6f 61 64 2e 20 41 6e 64 20 61 20 62  payload. And a b
3f30: 69 74 20 6d 6f 72 65 20 74 6f 20 63 61 74 63 68  it more to catch
3f40: 20 73 6d 61 6c 6c 20 62 75 66 66 65 72 0a 20 20   small buffer.  
3f50: 20 20 20 20 20 20 20 20 20 20 2a 2a 20 6f 76 65            ** ove
3f60: 72 72 75 6e 73 20 63 61 75 73 65 64 20 62 79 20  rruns caused by 
3f70: 61 74 74 65 6d 70 74 69 6e 67 20 74 6f 20 72 65  attempting to re
3f80: 61 64 20 61 20 76 61 72 69 6e 74 20 6f 72 20 73  ad a varint or s
3f90: 69 6d 69 6c 61 72 20 66 72 6f 6d 20 0a 20 20 20  imilar from .   
3fa0: 20 20 20 20 20 20 20 20 20 2a 2a 20 6e 65 61 72           ** near
3fb0: 20 74 68 65 20 65 6e 64 20 6f 66 20 61 20 63 6f   the end of a co
3fc0: 72 72 75 70 74 20 72 65 63 6f 72 64 2e 20 20 2a  rrupt record.  *
3fd0: 2f 0a 20 20 20 20 20 20 20 20 20 20 20 20 70 43  /.            pC
3fe0: 73 72 2d 3e 70 52 65 63 20 3d 20 28 75 38 2a 29  sr->pRec = (u8*)
3ff0: 73 71 6c 69 74 65 33 5f 6d 61 6c 6c 6f 63 36 34  sqlite3_malloc64
4000: 28 6e 50 61 79 6c 6f 61 64 2b 44 42 44 41 54 41  (nPayload+DBDATA
4010: 5f 50 41 44 44 49 4e 47 5f 42 59 54 45 53 29 3b  _PADDING_BYTES);
4020: 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 66 28  .            if(
4030: 20 70 43 73 72 2d 3e 70 52 65 63 3d 3d 30 20 29   pCsr->pRec==0 )
4040: 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4e   return SQLITE_N
4050: 4f 4d 45 4d 3b 0a 20 20 20 20 20 20 20 20 20 20  OMEM;.          
4060: 20 20 6d 65 6d 73 65 74 28 70 43 73 72 2d 3e 70    memset(pCsr->p
4070: 52 65 63 2c 20 30 2c 20 6e 50 61 79 6c 6f 61 64  Rec, 0, nPayload
4080: 2b 44 42 44 41 54 41 5f 50 41 44 44 49 4e 47 5f  +DBDATA_PADDING_
4090: 42 59 54 45 53 29 3b 0a 20 20 20 20 20 20 20 20  BYTES);.        
40a0: 20 20 20 20 70 43 73 72 2d 3e 6e 52 65 63 20 3d      pCsr->nRec =
40b0: 20 6e 50 61 79 6c 6f 61 64 3b 0a 0a 20 20 20 20   nPayload;..    
40c0: 20 20 20 20 20 20 20 20 2f 2a 20 4c 6f 61 64 20          /* Load 
40d0: 74 68 65 20 6e 4c 6f 63 61 6c 20 62 79 74 65 73  the nLocal bytes
40e0: 20 6f 66 20 70 61 79 6c 6f 61 64 20 2a 2f 0a 20   of payload */. 
40f0: 20 20 20 20 20 20 20 20 20 20 20 6d 65 6d 63 70             memcp
4100: 79 28 70 43 73 72 2d 3e 70 52 65 63 2c 20 26 70  y(pCsr->pRec, &p
4110: 43 73 72 2d 3e 61 50 61 67 65 5b 69 4f 66 66 5d  Csr->aPage[iOff]
4120: 2c 20 6e 4c 6f 63 61 6c 29 3b 0a 20 20 20 20 20  , nLocal);.     
4130: 20 20 20 20 20 20 20 69 4f 66 66 20 2b 3d 20 6e         iOff += n
4140: 4c 6f 63 61 6c 3b 0a 0a 20 20 20 20 20 20 20 20  Local;..        
4150: 20 20 20 20 2f 2a 20 4c 6f 61 64 20 63 6f 6e 74      /* Load cont
4160: 65 6e 74 20 66 72 6f 6d 20 6f 76 65 72 66 6c 6f  ent from overflo
4170: 77 20 70 61 67 65 73 20 2a 2f 0a 20 20 20 20 20  w pages */.     
4180: 20 20 20 20 20 20 20 69 66 28 20 6e 50 61 79 6c         if( nPayl
4190: 6f 61 64 3e 6e 4c 6f 63 61 6c 20 29 7b 0a 20 20  oad>nLocal ){.  
41a0: 20 20 20 20 20 20 20 20 20 20 20 20 73 71 6c 69              sqli
41b0: 74 65 33 5f 69 6e 74 36 34 20 6e 52 65 6d 20 3d  te3_int64 nRem =
41c0: 20 6e 50 61 79 6c 6f 61 64 20 2d 20 6e 4c 6f 63   nPayload - nLoc
41d0: 61 6c 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  al;.            
41e0: 20 20 75 6e 73 69 67 6e 65 64 20 69 6e 74 20 70    unsigned int p
41f0: 67 6e 6f 4f 76 66 6c 20 3d 20 67 65 74 5f 75 69  gnoOvfl = get_ui
4200: 6e 74 33 32 28 26 70 43 73 72 2d 3e 61 50 61 67  nt32(&pCsr->aPag
4210: 65 5b 69 4f 66 66 5d 29 3b 0a 20 20 20 20 20 20  e[iOff]);.      
4220: 20 20 20 20 20 20 20 20 77 68 69 6c 65 28 20 6e          while( n
4230: 52 65 6d 3e 30 20 29 7b 0a 20 20 20 20 20 20 20  Rem>0 ){.       
4240: 20 20 20 20 20 20 20 20 20 75 38 20 2a 61 4f 76           u8 *aOv
4250: 66 6c 20 3d 20 30 3b 0a 20 20 20 20 20 20 20 20  fl = 0;.        
4260: 20 20 20 20 20 20 20 20 69 6e 74 20 6e 4f 76 66          int nOvf
4270: 6c 20 3d 20 30 3b 0a 20 20 20 20 20 20 20 20 20  l = 0;.         
4280: 20 20 20 20 20 20 20 69 6e 74 20 6e 43 6f 70 79         int nCopy
4290: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
42a0: 20 20 72 63 20 3d 20 64 62 64 61 74 61 4c 6f 61    rc = dbdataLoa
42b0: 64 50 61 67 65 28 70 43 73 72 2c 20 70 67 6e 6f  dPage(pCsr, pgno
42c0: 4f 76 66 6c 2c 20 26 61 4f 76 66 6c 2c 20 26 6e  Ovfl, &aOvfl, &n
42d0: 4f 76 66 6c 29 3b 0a 20 20 20 20 20 20 20 20 20  Ovfl);.         
42e0: 20 20 20 20 20 20 20 61 73 73 65 72 74 28 20 72         assert( r
42f0: 63 21 3d 53 51 4c 49 54 45 5f 4f 4b 20 7c 7c 20  c!=SQLITE_OK || 
4300: 61 4f 76 66 6c 3d 3d 30 20 7c 7c 20 6e 4f 76 66  aOvfl==0 || nOvf
4310: 6c 3d 3d 70 43 73 72 2d 3e 6e 50 61 67 65 20 29  l==pCsr->nPage )
4320: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
4330: 20 20 69 66 28 20 72 63 21 3d 53 51 4c 49 54 45    if( rc!=SQLITE
4340: 5f 4f 4b 20 29 20 72 65 74 75 72 6e 20 72 63 3b  _OK ) return rc;
4350: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
4360: 20 69 66 28 20 61 4f 76 66 6c 3d 3d 30 20 29 20   if( aOvfl==0 ) 
4370: 62 72 65 61 6b 3b 0a 0a 20 20 20 20 20 20 20 20  break;..        
4380: 20 20 20 20 20 20 20 20 6e 43 6f 70 79 20 3d 20          nCopy = 
4390: 55 2d 34 3b 0a 20 20 20 20 20 20 20 20 20 20 20  U-4;.           
43a0: 20 20 20 20 20 69 66 28 20 6e 43 6f 70 79 3e 6e       if( nCopy>n
43b0: 52 65 6d 20 29 20 6e 43 6f 70 79 20 3d 20 6e 52  Rem ) nCopy = nR
43c0: 65 6d 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  em;.            
43d0: 20 20 20 20 6d 65 6d 63 70 79 28 26 70 43 73 72      memcpy(&pCsr
43e0: 2d 3e 70 52 65 63 5b 6e 50 61 79 6c 6f 61 64 2d  ->pRec[nPayload-
43f0: 6e 52 65 6d 5d 2c 20 26 61 4f 76 66 6c 5b 34 5d  nRem], &aOvfl[4]
4400: 2c 20 6e 43 6f 70 79 29 3b 0a 20 20 20 20 20 20  , nCopy);.      
4410: 20 20 20 20 20 20 20 20 20 20 6e 52 65 6d 20 2d            nRem -
4420: 3d 20 6e 43 6f 70 79 3b 0a 0a 20 20 20 20 20 20  = nCopy;..      
4430: 20 20 20 20 20 20 20 20 20 20 70 67 6e 6f 4f 76            pgnoOv
4440: 66 6c 20 3d 20 67 65 74 5f 75 69 6e 74 33 32 28  fl = get_uint32(
4450: 61 4f 76 66 6c 29 3b 0a 20 20 20 20 20 20 20 20  aOvfl);.        
4460: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f          sqlite3_
4470: 66 72 65 65 28 61 4f 76 66 6c 29 3b 0a 20 20 20  free(aOvfl);.   
4480: 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20             }.   
4490: 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 0a           }.    .
44a0: 20 20 20 20 20 20 20 20 20 20 20 20 69 48 64 72              iHdr
44b0: 20 3d 20 64 62 64 61 74 61 47 65 74 56 61 72 69   = dbdataGetVari
44c0: 6e 74 28 70 43 73 72 2d 3e 70 52 65 63 2c 20 26  nt(pCsr->pRec, &
44d0: 6e 48 64 72 29 3b 0a 20 20 20 20 20 20 20 20 20  nHdr);.         
44e0: 20 20 20 70 43 73 72 2d 3e 6e 48 64 72 20 3d 20     pCsr->nHdr = 
44f0: 6e 48 64 72 3b 0a 20 20 20 20 20 20 20 20 20 20  nHdr;.          
4500: 20 20 70 43 73 72 2d 3e 70 48 64 72 50 74 72 20    pCsr->pHdrPtr 
4510: 3d 20 26 70 43 73 72 2d 3e 70 52 65 63 5b 69 48  = &pCsr->pRec[iH
4520: 64 72 5d 3b 0a 20 20 20 20 20 20 20 20 20 20 20  dr];.           
4530: 20 70 43 73 72 2d 3e 70 50 74 72 20 3d 20 26 70   pCsr->pPtr = &p
4540: 43 73 72 2d 3e 70 52 65 63 5b 70 43 73 72 2d 3e  Csr->pRec[pCsr->
4550: 6e 48 64 72 5d 3b 0a 20 20 20 20 20 20 20 20 20  nHdr];.         
4560: 20 20 20 70 43 73 72 2d 3e 69 46 69 65 6c 64 20     pCsr->iField 
4570: 3d 20 28 62 48 61 73 52 6f 77 69 64 20 3f 20 2d  = (bHasRowid ? -
4580: 31 20 3a 20 30 29 3b 0a 20 20 20 20 20 20 20 20  1 : 0);.        
4590: 20 20 7d 0a 20 20 20 20 20 20 20 20 7d 0a 20 20    }.        }.  
45a0: 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20      }else{.     
45b0: 20 20 20 70 43 73 72 2d 3e 69 46 69 65 6c 64 2b     pCsr->iField+
45c0: 2b 3b 0a 20 20 20 20 20 20 20 20 69 66 28 20 70  +;.        if( p
45d0: 43 73 72 2d 3e 69 46 69 65 6c 64 3e 30 20 29 7b  Csr->iField>0 ){
45e0: 0a 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74  .          sqlit
45f0: 65 33 5f 69 6e 74 36 34 20 69 54 79 70 65 3b 0a  e3_int64 iType;.
4600: 20 20 20 20 20 20 20 20 20 20 69 66 28 20 70 43            if( pC
4610: 73 72 2d 3e 70 48 64 72 50 74 72 3e 26 70 43 73  sr->pHdrPtr>&pCs
4620: 72 2d 3e 70 52 65 63 5b 70 43 73 72 2d 3e 6e 52  r->pRec[pCsr->nR
4630: 65 63 5d 20 29 7b 0a 20 20 20 20 20 20 20 20 20  ec] ){.         
4640: 20 20 20 62 4e 65 78 74 50 61 67 65 20 3d 20 31     bNextPage = 1
4650: 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 65 6c 73  ;.          }els
4660: 65 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 70  e{.            p
4670: 43 73 72 2d 3e 70 48 64 72 50 74 72 20 2b 3d 20  Csr->pHdrPtr += 
4680: 64 62 64 61 74 61 47 65 74 56 61 72 69 6e 74 28  dbdataGetVarint(
4690: 70 43 73 72 2d 3e 70 48 64 72 50 74 72 2c 20 26  pCsr->pHdrPtr, &
46a0: 69 54 79 70 65 29 3b 0a 20 20 20 20 20 20 20 20  iType);.        
46b0: 20 20 20 20 70 43 73 72 2d 3e 70 50 74 72 20 2b      pCsr->pPtr +
46c0: 3d 20 64 62 64 61 74 61 56 61 6c 75 65 42 79 74  = dbdataValueByt
46d0: 65 73 28 69 54 79 70 65 29 3b 0a 20 20 20 20 20  es(iType);.     
46e0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 7d       }.        }
46f0: 0a 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20  .      }..      
4700: 69 66 28 20 62 4e 65 78 74 50 61 67 65 20 29 7b  if( bNextPage ){
4710: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
4720: 5f 66 72 65 65 28 70 43 73 72 2d 3e 61 50 61 67  _free(pCsr->aPag
4730: 65 29 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69  e);.        sqli
4740: 74 65 33 5f 66 72 65 65 28 70 43 73 72 2d 3e 70  te3_free(pCsr->p
4750: 52 65 63 29 3b 0a 20 20 20 20 20 20 20 20 70 43  Rec);.        pC
4760: 73 72 2d 3e 61 50 61 67 65 20 3d 20 30 3b 0a 20  sr->aPage = 0;. 
4770: 20 20 20 20 20 20 20 70 43 73 72 2d 3e 70 52 65         pCsr->pRe
4780: 63 20 3d 20 30 3b 0a 20 20 20 20 20 20 20 20 69  c = 0;.        i
4790: 66 28 20 70 43 73 72 2d 3e 62 4f 6e 65 50 61 67  f( pCsr->bOnePag
47a0: 65 20 29 20 72 65 74 75 72 6e 20 53 51 4c 49 54  e ) return SQLIT
47b0: 45 5f 4f 4b 3b 0a 20 20 20 20 20 20 20 20 70 43  E_OK;.        pC
47c0: 73 72 2d 3e 69 50 67 6e 6f 2b 2b 3b 0a 20 20 20  sr->iPgno++;.   
47d0: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
47e0: 20 20 69 66 28 20 70 43 73 72 2d 3e 69 46 69 65    if( pCsr->iFie
47f0: 6c 64 3c 30 20 7c 7c 20 70 43 73 72 2d 3e 70 48  ld<0 || pCsr->pH
4800: 64 72 50 74 72 3c 26 70 43 73 72 2d 3e 70 52 65  drPtr<&pCsr->pRe
4810: 63 5b 70 43 73 72 2d 3e 6e 48 64 72 5d 20 29 7b  c[pCsr->nHdr] ){
4820: 0a 20 20 20 20 20 20 20 20 20 20 72 65 74 75 72  .          retur
4830: 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 20  n SQLITE_OK;.   
4840: 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 20 20       }..        
4850: 2f 2a 20 41 64 76 61 6e 63 65 20 74 6f 20 74 68  /* Advance to th
4860: 65 20 6e 65 78 74 20 63 65 6c 6c 2e 20 54 68 65  e next cell. The
4870: 20 6e 65 78 74 20 69 74 65 72 61 74 69 6f 6e 20   next iteration 
4880: 6f 66 20 74 68 65 20 6c 6f 6f 70 20 77 69 6c 6c  of the loop will
4890: 20 6c 6f 61 64 0a 20 20 20 20 20 20 20 20 2a 2a   load.        **
48a0: 20 74 68 65 20 72 65 63 6f 72 64 20 61 6e 64 20   the record and 
48b0: 73 6f 20 6f 6e 2e 20 2a 2f 0a 20 20 20 20 20 20  so on. */.      
48c0: 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 70    sqlite3_free(p
48d0: 43 73 72 2d 3e 70 52 65 63 29 3b 0a 20 20 20 20  Csr->pRec);.    
48e0: 20 20 20 20 70 43 73 72 2d 3e 70 52 65 63 20 3d      pCsr->pRec =
48f0: 20 30 3b 0a 20 20 20 20 20 20 20 20 70 43 73 72   0;.        pCsr
4900: 2d 3e 69 43 65 6c 6c 2b 2b 3b 0a 20 20 20 20 20  ->iCell++;.     
4910: 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20   }.    }.  }..  
4920: 61 73 73 65 72 74 28 20 21 22 63 61 6e 27 74 20  assert( !"can't 
4930: 67 65 74 20 68 65 72 65 22 20 29 3b 0a 20 20 72  get here" );.  r
4940: 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b  eturn SQLITE_OK;
4950: 0a 7d 0a 0a 2f 2a 20 0a 2a 2a 20 52 65 74 75 72  .}../* .** Retur
4960: 6e 20 74 72 75 65 20 69 66 20 74 68 65 20 63 75  n true if the cu
4970: 72 73 6f 72 20 69 73 20 61 74 20 45 4f 46 2e 0a  rsor is at EOF..
4980: 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 64 62  */.static int db
4990: 64 61 74 61 45 6f 66 28 73 71 6c 69 74 65 33 5f  dataEof(sqlite3_
49a0: 76 74 61 62 5f 63 75 72 73 6f 72 20 2a 70 43 75  vtab_cursor *pCu
49b0: 72 73 6f 72 29 7b 0a 20 20 44 62 64 61 74 61 43  rsor){.  DbdataC
49c0: 75 72 73 6f 72 20 2a 70 43 73 72 20 3d 20 28 44  ursor *pCsr = (D
49d0: 62 64 61 74 61 43 75 72 73 6f 72 2a 29 70 43 75  bdataCursor*)pCu
49e0: 72 73 6f 72 3b 0a 20 20 72 65 74 75 72 6e 20 70  rsor;.  return p
49f0: 43 73 72 2d 3e 61 50 61 67 65 3d 3d 30 3b 0a 7d  Csr->aPage==0;.}
4a00: 0a 0a 2f 2a 20 0a 2a 2a 20 44 65 74 65 72 6d 69  ../* .** Determi
4a10: 6e 65 20 74 68 65 20 73 69 7a 65 20 69 6e 20 70  ne the size in p
4a20: 61 67 65 73 20 6f 66 20 64 61 74 61 62 61 73 65  ages of database
4a30: 20 7a 53 63 68 65 6d 61 20 28 77 68 65 72 65 20   zSchema (where 
4a40: 7a 53 63 68 65 6d 61 20 69 73 0a 2a 2a 20 22 6d  zSchema is.** "m
4a50: 61 69 6e 22 2c 20 22 74 65 6d 70 22 20 6f 72 20  ain", "temp" or 
4a60: 74 68 65 20 6e 61 6d 65 20 6f 66 20 61 6e 20 61  the name of an a
4a70: 74 74 61 63 68 65 64 20 64 61 74 61 62 61 73 65  ttached database
4a80: 29 20 61 6e 64 20 73 65 74 20 0a 2a 2a 20 70 43  ) and set .** pC
4a90: 73 72 2d 3e 73 7a 44 62 20 61 63 63 6f 72 64 69  sr->szDb accordi
4aa0: 6e 67 6c 79 2e 20 49 66 20 73 75 63 63 65 73 73  ngly. If success
4ab0: 66 75 6c 2c 20 72 65 74 75 72 6e 20 53 51 4c 49  ful, return SQLI
4ac0: 54 45 5f 4f 4b 2e 20 4f 74 68 65 72 77 69 73 65  TE_OK. Otherwise
4ad0: 2c 0a 2a 2a 20 61 6e 20 53 51 4c 69 74 65 20 65  ,.** an SQLite e
4ae0: 72 72 6f 72 20 63 6f 64 65 2e 0a 2a 2f 0a 73 74  rror code..*/.st
4af0: 61 74 69 63 20 69 6e 74 20 64 62 64 61 74 61 44  atic int dbdataD
4b00: 62 73 69 7a 65 28 44 62 64 61 74 61 43 75 72 73  bsize(DbdataCurs
4b10: 6f 72 20 2a 70 43 73 72 2c 20 63 6f 6e 73 74 20  or *pCsr, const 
4b20: 63 68 61 72 20 2a 7a 53 63 68 65 6d 61 29 7b 0a  char *zSchema){.
4b30: 20 20 44 62 64 61 74 61 54 61 62 6c 65 20 2a 70    DbdataTable *p
4b40: 54 61 62 20 3d 20 28 44 62 64 61 74 61 54 61 62  Tab = (DbdataTab
4b50: 6c 65 2a 29 70 43 73 72 2d 3e 62 61 73 65 2e 70  le*)pCsr->base.p
4b60: 56 74 61 62 3b 0a 20 20 63 68 61 72 20 2a 7a 53  Vtab;.  char *zS
4b70: 71 6c 20 3d 20 30 3b 0a 20 20 69 6e 74 20 72 63  ql = 0;.  int rc
4b80: 2c 20 72 63 32 3b 0a 20 20 73 71 6c 69 74 65 33  , rc2;.  sqlite3
4b90: 5f 73 74 6d 74 20 2a 70 53 74 6d 74 20 3d 20 30  _stmt *pStmt = 0
4ba0: 3b 0a 0a 20 20 7a 53 71 6c 20 3d 20 73 71 6c 69  ;..  zSql = sqli
4bb0: 74 65 33 5f 6d 70 72 69 6e 74 66 28 22 50 52 41  te3_mprintf("PRA
4bc0: 47 4d 41 20 25 51 2e 70 61 67 65 5f 63 6f 75 6e  GMA %Q.page_coun
4bd0: 74 22 2c 20 7a 53 63 68 65 6d 61 29 3b 0a 20 20  t", zSchema);.  
4be0: 69 66 28 20 7a 53 71 6c 3d 3d 30 20 29 20 72 65  if( zSql==0 ) re
4bf0: 74 75 72 6e 20 53 51 4c 49 54 45 5f 4e 4f 4d 45  turn SQLITE_NOME
4c00: 4d 3b 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65  M;.  rc = sqlite
4c10: 33 5f 70 72 65 70 61 72 65 5f 76 32 28 70 54 61  3_prepare_v2(pTa
4c20: 62 2d 3e 64 62 2c 20 7a 53 71 6c 2c 20 2d 31 2c  b->db, zSql, -1,
4c30: 20 26 70 53 74 6d 74 2c 20 30 29 3b 0a 20 20 73   &pStmt, 0);.  s
4c40: 71 6c 69 74 65 33 5f 66 72 65 65 28 7a 53 71 6c  qlite3_free(zSql
4c50: 29 3b 0a 20 20 69 66 28 20 72 63 3d 3d 53 51 4c  );.  if( rc==SQL
4c60: 49 54 45 5f 4f 4b 20 26 26 20 73 71 6c 69 74 65  ITE_OK && sqlite
4c70: 33 5f 73 74 65 70 28 70 53 74 6d 74 29 3d 3d 53  3_step(pStmt)==S
4c80: 51 4c 49 54 45 5f 52 4f 57 20 29 7b 0a 20 20 20  QLITE_ROW ){.   
4c90: 20 70 43 73 72 2d 3e 73 7a 44 62 20 3d 20 73 71   pCsr->szDb = sq
4ca0: 6c 69 74 65 33 5f 63 6f 6c 75 6d 6e 5f 69 6e 74  lite3_column_int
4cb0: 28 70 53 74 6d 74 2c 20 30 29 3b 0a 20 20 7d 0a  (pStmt, 0);.  }.
4cc0: 20 20 72 63 32 20 3d 20 73 71 6c 69 74 65 33 5f    rc2 = sqlite3_
4cd0: 66 69 6e 61 6c 69 7a 65 28 70 53 74 6d 74 29 3b  finalize(pStmt);
4ce0: 0a 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54  .  if( rc==SQLIT
4cf0: 45 5f 4f 4b 20 29 20 72 63 20 3d 20 72 63 32 3b  E_OK ) rc = rc2;
4d00: 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a  .  return rc;.}.
4d10: 0a 2f 2a 20 0a 2a 2a 20 78 46 69 6c 74 65 72 20  ./* .** xFilter 
4d20: 6d 65 74 68 6f 64 20 66 6f 72 20 73 71 6c 69 74  method for sqlit
4d30: 65 5f 64 62 64 61 74 61 20 61 6e 64 20 73 71 6c  e_dbdata and sql
4d40: 69 74 65 5f 64 62 70 74 72 2e 0a 2a 2f 0a 73 74  ite_dbptr..*/.st
4d50: 61 74 69 63 20 69 6e 74 20 64 62 64 61 74 61 46  atic int dbdataF
4d60: 69 6c 74 65 72 28 0a 20 20 73 71 6c 69 74 65 33  ilter(.  sqlite3
4d70: 5f 76 74 61 62 5f 63 75 72 73 6f 72 20 2a 70 43  _vtab_cursor *pC
4d80: 75 72 73 6f 72 2c 20 0a 20 20 69 6e 74 20 69 64  ursor, .  int id
4d90: 78 4e 75 6d 2c 20 63 6f 6e 73 74 20 63 68 61 72  xNum, const char
4da0: 20 2a 69 64 78 53 74 72 2c 0a 20 20 69 6e 74 20   *idxStr,.  int 
4db0: 61 72 67 63 2c 20 73 71 6c 69 74 65 33 5f 76 61  argc, sqlite3_va
4dc0: 6c 75 65 20 2a 2a 61 72 67 76 0a 29 7b 0a 20 20  lue **argv.){.  
4dd0: 44 62 64 61 74 61 43 75 72 73 6f 72 20 2a 70 43  DbdataCursor *pC
4de0: 73 72 20 3d 20 28 44 62 64 61 74 61 43 75 72 73  sr = (DbdataCurs
4df0: 6f 72 2a 29 70 43 75 72 73 6f 72 3b 0a 20 20 44  or*)pCursor;.  D
4e00: 62 64 61 74 61 54 61 62 6c 65 20 2a 70 54 61 62  bdataTable *pTab
4e10: 20 3d 20 28 44 62 64 61 74 61 54 61 62 6c 65 2a   = (DbdataTable*
4e20: 29 70 43 75 72 73 6f 72 2d 3e 70 56 74 61 62 3b  )pCursor->pVtab;
4e30: 0a 20 20 69 6e 74 20 72 63 20 3d 20 53 51 4c 49  .  int rc = SQLI
4e40: 54 45 5f 4f 4b 3b 0a 20 20 63 6f 6e 73 74 20 63  TE_OK;.  const c
4e50: 68 61 72 20 2a 7a 53 63 68 65 6d 61 20 3d 20 22  har *zSchema = "
4e60: 6d 61 69 6e 22 3b 0a 0a 20 20 64 62 64 61 74 61  main";..  dbdata
4e70: 52 65 73 65 74 43 75 72 73 6f 72 28 70 43 73 72  ResetCursor(pCsr
4e80: 29 3b 0a 20 20 61 73 73 65 72 74 28 20 70 43 73  );.  assert( pCs
4e90: 72 2d 3e 69 50 67 6e 6f 3d 3d 31 20 29 3b 0a 20  r->iPgno==1 );. 
4ea0: 20 69 66 28 20 69 64 78 4e 75 6d 20 26 20 30 78   if( idxNum & 0x
4eb0: 30 31 20 29 7b 0a 20 20 20 20 7a 53 63 68 65 6d  01 ){.    zSchem
4ec0: 61 20 3d 20 28 63 6f 6e 73 74 20 63 68 61 72 2a  a = (const char*
4ed0: 29 73 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 74  )sqlite3_value_t
4ee0: 65 78 74 28 61 72 67 76 5b 30 5d 29 3b 0a 20 20  ext(argv[0]);.  
4ef0: 7d 0a 20 20 69 66 28 20 69 64 78 4e 75 6d 20 26  }.  if( idxNum &
4f00: 20 30 78 30 32 20 29 7b 0a 20 20 20 20 70 43 73   0x02 ){.    pCs
4f10: 72 2d 3e 69 50 67 6e 6f 20 3d 20 73 71 6c 69 74  r->iPgno = sqlit
4f20: 65 33 5f 76 61 6c 75 65 5f 69 6e 74 28 61 72 67  e3_value_int(arg
4f30: 76 5b 28 69 64 78 4e 75 6d 20 26 20 30 78 30 31  v[(idxNum & 0x01
4f40: 29 5d 29 3b 0a 20 20 20 20 70 43 73 72 2d 3e 62  )]);.    pCsr->b
4f50: 4f 6e 65 50 61 67 65 20 3d 20 31 3b 0a 20 20 7d  OnePage = 1;.  }
4f60: 65 6c 73 65 7b 0a 20 20 20 20 70 43 73 72 2d 3e  else{.    pCsr->
4f70: 6e 50 61 67 65 20 3d 20 64 62 64 61 74 61 44 62  nPage = dbdataDb
4f80: 73 69 7a 65 28 70 43 73 72 2c 20 7a 53 63 68 65  size(pCsr, zSche
4f90: 6d 61 29 3b 0a 20 20 20 20 72 63 20 3d 20 64 62  ma);.    rc = db
4fa0: 64 61 74 61 44 62 73 69 7a 65 28 70 43 73 72 2c  dataDbsize(pCsr,
4fb0: 20 7a 53 63 68 65 6d 61 29 3b 0a 20 20 7d 0a 0a   zSchema);.  }..
4fc0: 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45    if( rc==SQLITE
4fd0: 5f 4f 4b 20 29 7b 0a 20 20 20 20 69 66 28 20 70  _OK ){.    if( p
4fe0: 54 61 62 2d 3e 70 53 74 6d 74 20 29 7b 0a 20 20  Tab->pStmt ){.  
4ff0: 20 20 20 20 70 43 73 72 2d 3e 70 53 74 6d 74 20      pCsr->pStmt 
5000: 3d 20 70 54 61 62 2d 3e 70 53 74 6d 74 3b 0a 20  = pTab->pStmt;. 
5010: 20 20 20 20 20 70 54 61 62 2d 3e 70 53 74 6d 74       pTab->pStmt
5020: 20 3d 20 30 3b 0a 20 20 20 20 7d 65 6c 73 65 7b   = 0;.    }else{
5030: 0a 20 20 20 20 20 20 72 63 20 3d 20 73 71 6c 69  .      rc = sqli
5040: 74 65 33 5f 70 72 65 70 61 72 65 5f 76 32 28 70  te3_prepare_v2(p
5050: 54 61 62 2d 3e 64 62 2c 20 0a 20 20 20 20 20 20  Tab->db, .      
5060: 20 20 20 20 22 53 45 4c 45 43 54 20 64 61 74 61      "SELECT data
5070: 20 46 52 4f 4d 20 73 71 6c 69 74 65 5f 64 62 70   FROM sqlite_dbp
5080: 61 67 65 28 3f 29 20 57 48 45 52 45 20 70 67 6e  age(?) WHERE pgn
5090: 6f 3d 3f 22 2c 20 2d 31 2c 0a 20 20 20 20 20 20  o=?", -1,.      
50a0: 20 20 20 20 26 70 43 73 72 2d 3e 70 53 74 6d 74      &pCsr->pStmt
50b0: 2c 20 30 0a 20 20 20 20 20 20 29 3b 0a 20 20 20  , 0.      );.   
50c0: 20 7d 0a 20 20 7d 0a 20 20 69 66 28 20 72 63 3d   }.  }.  if( rc=
50d0: 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20  =SQLITE_OK ){.  
50e0: 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 62    rc = sqlite3_b
50f0: 69 6e 64 5f 74 65 78 74 28 70 43 73 72 2d 3e 70  ind_text(pCsr->p
5100: 53 74 6d 74 2c 20 31 2c 20 7a 53 63 68 65 6d 61  Stmt, 1, zSchema
5110: 2c 20 2d 31 2c 20 53 51 4c 49 54 45 5f 54 52 41  , -1, SQLITE_TRA
5120: 4e 53 49 45 4e 54 29 3b 0a 20 20 7d 65 6c 73 65  NSIENT);.  }else
5130: 7b 0a 20 20 20 20 70 54 61 62 2d 3e 62 61 73 65  {.    pTab->base
5140: 2e 7a 45 72 72 4d 73 67 20 3d 20 73 71 6c 69 74  .zErrMsg = sqlit
5150: 65 33 5f 6d 70 72 69 6e 74 66 28 22 25 73 22 2c  e3_mprintf("%s",
5160: 20 73 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 28   sqlite3_errmsg(
5170: 70 54 61 62 2d 3e 64 62 29 29 3b 0a 20 20 7d 0a  pTab->db));.  }.
5180: 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45    if( rc==SQLITE
5190: 5f 4f 4b 20 29 7b 0a 20 20 20 20 72 63 20 3d 20  _OK ){.    rc = 
51a0: 64 62 64 61 74 61 4e 65 78 74 28 70 43 75 72 73  dbdataNext(pCurs
51b0: 6f 72 29 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72  or);.  }.  retur
51c0: 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 20 0a 2a 2a 20  n rc;.}../* .** 
51d0: 52 65 74 75 72 6e 20 61 20 63 6f 6c 75 6d 6e 20  Return a column 
51e0: 66 6f 72 20 74 68 65 20 73 71 6c 69 74 65 5f 64  for the sqlite_d
51f0: 62 64 61 74 61 20 6f 72 20 73 71 6c 69 74 65 5f  bdata or sqlite_
5200: 64 62 70 74 72 20 74 61 62 6c 65 2e 0a 2a 2f 0a  dbptr table..*/.
5210: 73 74 61 74 69 63 20 69 6e 74 20 64 62 64 61 74  static int dbdat
5220: 61 43 6f 6c 75 6d 6e 28 0a 20 20 73 71 6c 69 74  aColumn(.  sqlit
5230: 65 33 5f 76 74 61 62 5f 63 75 72 73 6f 72 20 2a  e3_vtab_cursor *
5240: 70 43 75 72 73 6f 72 2c 20 0a 20 20 73 71 6c 69  pCursor, .  sqli
5250: 74 65 33 5f 63 6f 6e 74 65 78 74 20 2a 63 74 78  te3_context *ctx
5260: 2c 20 0a 20 20 69 6e 74 20 69 0a 29 7b 0a 20 20  , .  int i.){.  
5270: 44 62 64 61 74 61 43 75 72 73 6f 72 20 2a 70 43  DbdataCursor *pC
5280: 73 72 20 3d 20 28 44 62 64 61 74 61 43 75 72 73  sr = (DbdataCurs
5290: 6f 72 2a 29 70 43 75 72 73 6f 72 3b 0a 20 20 44  or*)pCursor;.  D
52a0: 62 64 61 74 61 54 61 62 6c 65 20 2a 70 54 61 62  bdataTable *pTab
52b0: 20 3d 20 28 44 62 64 61 74 61 54 61 62 6c 65 2a   = (DbdataTable*
52c0: 29 70 43 75 72 73 6f 72 2d 3e 70 56 74 61 62 3b  )pCursor->pVtab;
52d0: 0a 20 20 69 66 28 20 70 54 61 62 2d 3e 62 50 74  .  if( pTab->bPt
52e0: 72 20 29 7b 0a 20 20 20 20 73 77 69 74 63 68 28  r ){.    switch(
52f0: 20 69 20 29 7b 0a 20 20 20 20 20 20 63 61 73 65   i ){.      case
5300: 20 44 42 50 54 52 5f 43 4f 4c 55 4d 4e 5f 50 47   DBPTR_COLUMN_PG
5310: 4e 4f 3a 0a 20 20 20 20 20 20 20 20 73 71 6c 69  NO:.        sqli
5320: 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e 74 36 34  te3_result_int64
5330: 28 63 74 78 2c 20 70 43 73 72 2d 3e 69 50 67 6e  (ctx, pCsr->iPgn
5340: 6f 29 3b 0a 20 20 20 20 20 20 20 20 62 72 65 61  o);.        brea
5350: 6b 3b 0a 20 20 20 20 20 20 63 61 73 65 20 44 42  k;.      case DB
5360: 50 54 52 5f 43 4f 4c 55 4d 4e 5f 43 48 49 4c 44  PTR_COLUMN_CHILD
5370: 3a 20 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20  : {.        int 
5380: 69 4f 66 66 20 3d 20 70 43 73 72 2d 3e 69 50 67  iOff = pCsr->iPg
5390: 6e 6f 3d 3d 31 20 3f 20 31 30 30 20 3a 20 30 3b  no==1 ? 100 : 0;
53a0: 0a 20 20 20 20 20 20 20 20 69 66 28 20 70 43 73  .        if( pCs
53b0: 72 2d 3e 69 43 65 6c 6c 3c 30 20 29 7b 0a 20 20  r->iCell<0 ){.  
53c0: 20 20 20 20 20 20 20 20 69 4f 66 66 20 2b 3d 20          iOff += 
53d0: 38 3b 0a 20 20 20 20 20 20 20 20 7d 65 6c 73 65  8;.        }else
53e0: 7b 0a 20 20 20 20 20 20 20 20 20 20 69 4f 66 66  {.          iOff
53f0: 20 2b 3d 20 31 32 20 2b 20 70 43 73 72 2d 3e 69   += 12 + pCsr->i
5400: 43 65 6c 6c 2a 32 3b 0a 20 20 20 20 20 20 20 20  Cell*2;.        
5410: 20 20 69 66 28 20 69 4f 66 66 3e 70 43 73 72 2d    if( iOff>pCsr-
5420: 3e 6e 50 61 67 65 20 29 20 72 65 74 75 72 6e 20  >nPage ) return 
5430: 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 20 20 20  SQLITE_OK;.     
5440: 20 20 20 20 20 69 4f 66 66 20 3d 20 67 65 74 5f       iOff = get_
5450: 75 69 6e 74 31 36 28 26 70 43 73 72 2d 3e 61 50  uint16(&pCsr->aP
5460: 61 67 65 5b 69 4f 66 66 5d 29 3b 0a 20 20 20 20  age[iOff]);.    
5470: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 69 66      }.        if
5480: 28 20 69 4f 66 66 3c 3d 70 43 73 72 2d 3e 6e 50  ( iOff<=pCsr->nP
5490: 61 67 65 20 29 7b 0a 20 20 20 20 20 20 20 20 20  age ){.         
54a0: 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f   sqlite3_result_
54b0: 69 6e 74 36 34 28 63 74 78 2c 20 67 65 74 5f 75  int64(ctx, get_u
54c0: 69 6e 74 33 32 28 26 70 43 73 72 2d 3e 61 50 61  int32(&pCsr->aPa
54d0: 67 65 5b 69 4f 66 66 5d 29 29 3b 0a 20 20 20 20  ge[iOff]));.    
54e0: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 62 72      }.        br
54f0: 65 61 6b 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  eak;.      }.   
5500: 20 7d 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20   }.  }else{.    
5510: 73 77 69 74 63 68 28 20 69 20 29 7b 0a 20 20 20  switch( i ){.   
5520: 20 20 20 63 61 73 65 20 44 42 44 41 54 41 5f 43     case DBDATA_C
5530: 4f 4c 55 4d 4e 5f 50 47 4e 4f 3a 0a 20 20 20 20  OLUMN_PGNO:.    
5540: 20 20 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75      sqlite3_resu
5550: 6c 74 5f 69 6e 74 36 34 28 63 74 78 2c 20 70 43  lt_int64(ctx, pC
5560: 73 72 2d 3e 69 50 67 6e 6f 29 3b 0a 20 20 20 20  sr->iPgno);.    
5570: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 20      break;.     
5580: 20 63 61 73 65 20 44 42 44 41 54 41 5f 43 4f 4c   case DBDATA_COL
5590: 55 4d 4e 5f 43 45 4c 4c 3a 0a 20 20 20 20 20 20  UMN_CELL:.      
55a0: 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c 74    sqlite3_result
55b0: 5f 69 6e 74 28 63 74 78 2c 20 70 43 73 72 2d 3e  _int(ctx, pCsr->
55c0: 69 43 65 6c 6c 29 3b 0a 20 20 20 20 20 20 20 20  iCell);.        
55d0: 62 72 65 61 6b 3b 0a 20 20 20 20 20 20 63 61 73  break;.      cas
55e0: 65 20 44 42 44 41 54 41 5f 43 4f 4c 55 4d 4e 5f  e DBDATA_COLUMN_
55f0: 46 49 45 4c 44 3a 0a 20 20 20 20 20 20 20 20 73  FIELD:.        s
5600: 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e  qlite3_result_in
5610: 74 28 63 74 78 2c 20 70 43 73 72 2d 3e 69 46 69  t(ctx, pCsr->iFi
5620: 65 6c 64 29 3b 0a 20 20 20 20 20 20 20 20 62 72  eld);.        br
5630: 65 61 6b 3b 0a 20 20 20 20 20 20 63 61 73 65 20  eak;.      case 
5640: 44 42 44 41 54 41 5f 43 4f 4c 55 4d 4e 5f 56 41  DBDATA_COLUMN_VA
5650: 4c 55 45 3a 20 7b 0a 20 20 20 20 20 20 20 20 69  LUE: {.        i
5660: 66 28 20 70 43 73 72 2d 3e 69 46 69 65 6c 64 3c  f( pCsr->iField<
5670: 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 73  0 ){.          s
5680: 71 6c 69 74 65 33 5f 72 65 73 75 6c 74 5f 69 6e  qlite3_result_in
5690: 74 36 34 28 63 74 78 2c 20 70 43 73 72 2d 3e 69  t64(ctx, pCsr->i
56a0: 49 6e 74 6b 65 79 29 3b 0a 20 20 20 20 20 20 20  Intkey);.       
56b0: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20   }else{.        
56c0: 20 20 73 71 6c 69 74 65 33 5f 69 6e 74 36 34 20    sqlite3_int64 
56d0: 69 54 79 70 65 3b 0a 20 20 20 20 20 20 20 20 20  iType;.         
56e0: 20 64 62 64 61 74 61 47 65 74 56 61 72 69 6e 74   dbdataGetVarint
56f0: 28 70 43 73 72 2d 3e 70 48 64 72 50 74 72 2c 20  (pCsr->pHdrPtr, 
5700: 26 69 54 79 70 65 29 3b 0a 20 20 20 20 20 20 20  &iType);.       
5710: 20 20 20 64 62 64 61 74 61 56 61 6c 75 65 28 0a     dbdataValue(.
5720: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 63 74                ct
5730: 78 2c 20 69 54 79 70 65 2c 20 70 43 73 72 2d 3e  x, iType, pCsr->
5740: 70 50 74 72 2c 20 26 70 43 73 72 2d 3e 70 52 65  pPtr, &pCsr->pRe
5750: 63 5b 70 43 73 72 2d 3e 6e 52 65 63 5d 20 2d 20  c[pCsr->nRec] - 
5760: 70 43 73 72 2d 3e 70 50 74 72 0a 20 20 20 20 20  pCsr->pPtr.     
5770: 20 20 20 20 20 29 3b 0a 20 20 20 20 20 20 20 20       );.        
5780: 7d 0a 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b  }.        break;
5790: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20  .      }.    }. 
57a0: 20 7d 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49   }.  return SQLI
57b0: 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a 20 0a 2a 2a  TE_OK;.}../* .**
57c0: 20 52 65 74 75 72 6e 20 74 68 65 20 72 6f 77 69   Return the rowi
57d0: 64 20 66 6f 72 20 61 6e 20 73 71 6c 69 74 65 5f  d for an sqlite_
57e0: 64 62 64 61 74 61 20 6f 72 20 73 71 6c 69 74 65  dbdata or sqlite
57f0: 5f 64 70 74 72 20 74 61 62 6c 65 2e 0a 2a 2f 0a  _dptr table..*/.
5800: 73 74 61 74 69 63 20 69 6e 74 20 64 62 64 61 74  static int dbdat
5810: 61 52 6f 77 69 64 28 73 71 6c 69 74 65 33 5f 76  aRowid(sqlite3_v
5820: 74 61 62 5f 63 75 72 73 6f 72 20 2a 70 43 75 72  tab_cursor *pCur
5830: 73 6f 72 2c 20 73 71 6c 69 74 65 5f 69 6e 74 36  sor, sqlite_int6
5840: 34 20 2a 70 52 6f 77 69 64 29 7b 0a 20 20 44 62  4 *pRowid){.  Db
5850: 64 61 74 61 43 75 72 73 6f 72 20 2a 70 43 73 72  dataCursor *pCsr
5860: 20 3d 20 28 44 62 64 61 74 61 43 75 72 73 6f 72   = (DbdataCursor
5870: 2a 29 70 43 75 72 73 6f 72 3b 0a 20 20 2a 70 52  *)pCursor;.  *pR
5880: 6f 77 69 64 20 3d 20 70 43 73 72 2d 3e 69 52 6f  owid = pCsr->iRo
5890: 77 69 64 3b 0a 20 20 72 65 74 75 72 6e 20 53 51  wid;.  return SQ
58a0: 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 0a 2f 2a 0a  LITE_OK;.}.../*.
58b0: 2a 2a 20 49 6e 76 6f 6b 65 20 74 68 69 73 20 72  ** Invoke this r
58c0: 6f 75 74 69 6e 65 20 74 6f 20 72 65 67 69 73 74  outine to regist
58d0: 65 72 20 74 68 65 20 22 73 71 6c 69 74 65 5f 64  er the "sqlite_d
58e0: 62 64 61 74 61 22 20 76 69 72 74 75 61 6c 20 74  bdata" virtual t
58f0: 61 62 6c 65 20 6d 6f 64 75 6c 65 0a 2a 2f 0a 73  able module.*/.s
5900: 74 61 74 69 63 20 69 6e 74 20 73 71 6c 69 74 65  tatic int sqlite
5910: 33 44 62 64 61 74 61 52 65 67 69 73 74 65 72 28  3DbdataRegister(
5920: 73 71 6c 69 74 65 33 20 2a 64 62 29 7b 0a 20 20  sqlite3 *db){.  
5930: 73 74 61 74 69 63 20 73 71 6c 69 74 65 33 5f 6d  static sqlite3_m
5940: 6f 64 75 6c 65 20 64 62 64 61 74 61 5f 6d 6f 64  odule dbdata_mod
5950: 75 6c 65 20 3d 20 7b 0a 20 20 20 20 30 2c 20 20  ule = {.    0,  
5960: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5970: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 69 56 65            /* iVe
5980: 72 73 69 6f 6e 20 2a 2f 0a 20 20 20 20 30 2c 20  rsion */.    0, 
5990: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
59a0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 43             /* xC
59b0: 72 65 61 74 65 20 2a 2f 0a 20 20 20 20 64 62 64  reate */.    dbd
59c0: 61 74 61 43 6f 6e 6e 65 63 74 2c 20 20 20 20 20  ataConnect,     
59d0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 43             /* xC
59e0: 6f 6e 6e 65 63 74 20 2a 2f 0a 20 20 20 20 64 62  onnect */.    db
59f0: 64 61 74 61 42 65 73 74 49 6e 64 65 78 2c 20 20  dataBestIndex,  
5a00: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78              /* x
5a10: 42 65 73 74 49 6e 64 65 78 20 2a 2f 0a 20 20 20  BestIndex */.   
5a20: 20 64 62 64 61 74 61 44 69 73 63 6f 6e 6e 65 63   dbdataDisconnec
5a30: 74 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  t,             /
5a40: 2a 20 78 44 69 73 63 6f 6e 6e 65 63 74 20 2a 2f  * xDisconnect */
5a50: 0a 20 20 20 20 30 2c 20 20 20 20 20 20 20 20 20  .    0,         
5a60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5a70: 20 20 20 2f 2a 20 78 44 65 73 74 72 6f 79 20 2a     /* xDestroy *
5a80: 2f 0a 20 20 20 20 64 62 64 61 74 61 4f 70 65 6e  /.    dbdataOpen
5a90: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,               
5aa0: 20 20 20 20 2f 2a 20 78 4f 70 65 6e 20 2d 20 6f      /* xOpen - o
5ab0: 70 65 6e 20 61 20 63 75 72 73 6f 72 20 2a 2f 0a  pen a cursor */.
5ac0: 20 20 20 20 64 62 64 61 74 61 43 6c 6f 73 65 2c      dbdataClose,
5ad0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5ae0: 20 20 2f 2a 20 78 43 6c 6f 73 65 20 2d 20 63 6c    /* xClose - cl
5af0: 6f 73 65 20 61 20 63 75 72 73 6f 72 20 2a 2f 0a  ose a cursor */.
5b00: 20 20 20 20 64 62 64 61 74 61 46 69 6c 74 65 72      dbdataFilter
5b10: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,               
5b20: 20 20 2f 2a 20 78 46 69 6c 74 65 72 20 2d 20 63    /* xFilter - c
5b30: 6f 6e 66 69 67 75 72 65 20 73 63 61 6e 20 63 6f  onfigure scan co
5b40: 6e 73 74 72 61 69 6e 74 73 20 2a 2f 0a 20 20 20  nstraints */.   
5b50: 20 64 62 64 61 74 61 4e 65 78 74 2c 20 20 20 20   dbdataNext,    
5b60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
5b70: 2a 20 78 4e 65 78 74 20 2d 20 61 64 76 61 6e 63  * xNext - advanc
5b80: 65 20 61 20 63 75 72 73 6f 72 20 2a 2f 0a 20 20  e a cursor */.  
5b90: 20 20 64 62 64 61 74 61 45 6f 66 2c 20 20 20 20    dbdataEof,    
5ba0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5bb0: 2f 2a 20 78 45 6f 66 20 2d 20 63 68 65 63 6b 20  /* xEof - check 
5bc0: 66 6f 72 20 65 6e 64 20 6f 66 20 73 63 61 6e 20  for end of scan 
5bd0: 2a 2f 0a 20 20 20 20 64 62 64 61 74 61 43 6f 6c  */.    dbdataCol
5be0: 75 6d 6e 2c 20 20 20 20 20 20 20 20 20 20 20 20  umn,            
5bf0: 20 20 20 20 20 2f 2a 20 78 43 6f 6c 75 6d 6e 20       /* xColumn 
5c00: 2d 20 72 65 61 64 20 64 61 74 61 20 2a 2f 0a 20  - read data */. 
5c10: 20 20 20 64 62 64 61 74 61 52 6f 77 69 64 2c 20     dbdataRowid, 
5c20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5c30: 20 2f 2a 20 78 52 6f 77 69 64 20 2d 20 72 65 61   /* xRowid - rea
5c40: 64 20 64 61 74 61 20 2a 2f 0a 20 20 20 20 30 2c  d data */.    0,
5c50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5c60: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78              /* x
5c70: 55 70 64 61 74 65 20 2a 2f 0a 20 20 20 20 30 2c  Update */.    0,
5c80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5c90: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78              /* x
5ca0: 42 65 67 69 6e 20 2a 2f 0a 20 20 20 20 30 2c 20  Begin */.    0, 
5cb0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5cc0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 53             /* xS
5cd0: 79 6e 63 20 2a 2f 0a 20 20 20 20 30 2c 20 20 20  ync */.    0,   
5ce0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5cf0: 20 20 20 20 20 20 20 20 20 2f 2a 20 78 43 6f 6d           /* xCom
5d00: 6d 69 74 20 2a 2f 0a 20 20 20 20 30 2c 20 20 20  mit */.    0,   
5d10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5d20: 20 20 20 20 20 20 20 20 20 2f 2a 20 78 52 6f 6c           /* xRol
5d30: 6c 62 61 63 6b 20 2a 2f 0a 20 20 20 20 30 2c 20  lback */.    0, 
5d40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5d50: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 78 46             /* xF
5d60: 69 6e 64 4d 65 74 68 6f 64 20 2a 2f 0a 20 20 20  indMethod */.   
5d70: 20 30 2c 20 20 20 20 20 20 20 20 20 20 20 20 20   0,             
5d80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
5d90: 2a 20 78 52 65 6e 61 6d 65 20 2a 2f 0a 20 20 20  * xRename */.   
5da0: 20 30 2c 20 20 20 20 20 20 20 20 20 20 20 20 20   0,             
5db0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
5dc0: 2a 20 78 53 61 76 65 70 6f 69 6e 74 20 2a 2f 0a  * xSavepoint */.
5dd0: 20 20 20 20 30 2c 20 20 20 20 20 20 20 20 20 20      0,          
5de0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5df0: 20 20 2f 2a 20 78 52 65 6c 65 61 73 65 20 2a 2f    /* xRelease */
5e00: 0a 20 20 20 20 30 2c 20 20 20 20 20 20 20 20 20  .    0,         
5e10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5e20: 20 20 20 2f 2a 20 78 52 6f 6c 6c 62 61 63 6b 54     /* xRollbackT
5e30: 6f 20 2a 2f 0a 20 20 20 20 30 20 20 20 20 20 20  o */.    0      
5e40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5e50: 20 20 20 20 20 20 20 2f 2a 20 78 53 68 61 64 6f         /* xShado
5e60: 77 4e 61 6d 65 20 2a 2f 0a 20 20 7d 3b 0a 0a 20  wName */.  };.. 
5e70: 20 69 6e 74 20 72 63 20 3d 20 73 71 6c 69 74 65   int rc = sqlite
5e80: 33 5f 63 72 65 61 74 65 5f 6d 6f 64 75 6c 65 28  3_create_module(
5e90: 64 62 2c 20 22 73 71 6c 69 74 65 5f 64 62 64 61  db, "sqlite_dbda
5ea0: 74 61 22 2c 20 26 64 62 64 61 74 61 5f 6d 6f 64  ta", &dbdata_mod
5eb0: 75 6c 65 2c 20 30 29 3b 0a 20 20 69 66 28 20 72  ule, 0);.  if( r
5ec0: 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a  c==SQLITE_OK ){.
5ed0: 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33      rc = sqlite3
5ee0: 5f 63 72 65 61 74 65 5f 6d 6f 64 75 6c 65 28 64  _create_module(d
5ef0: 62 2c 20 22 73 71 6c 69 74 65 5f 64 62 70 74 72  b, "sqlite_dbptr
5f00: 22 2c 20 26 64 62 64 61 74 61 5f 6d 6f 64 75 6c  ", &dbdata_modul
5f10: 65 2c 20 28 76 6f 69 64 2a 29 31 29 3b 0a 20 20  e, (void*)1);.  
5f20: 7d 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d  }.  return rc;.}
5f30: 0a 0a 23 69 66 64 65 66 20 5f 57 49 4e 33 32 0a  ..#ifdef _WIN32.
5f40: 5f 5f 64 65 63 6c 73 70 65 63 28 64 6c 6c 65 78  __declspec(dllex
5f50: 70 6f 72 74 29 0a 23 65 6e 64 69 66 0a 69 6e 74  port).#endif.int
5f60: 20 73 71 6c 69 74 65 33 5f 64 62 64 61 74 61 5f   sqlite3_dbdata_
5f70: 69 6e 69 74 28 0a 20 20 73 71 6c 69 74 65 33 20  init(.  sqlite3 
5f80: 2a 64 62 2c 20 0a 20 20 63 68 61 72 20 2a 2a 70  *db, .  char **p
5f90: 7a 45 72 72 4d 73 67 2c 20 0a 20 20 63 6f 6e 73  zErrMsg, .  cons
5fa0: 74 20 73 71 6c 69 74 65 33 5f 61 70 69 5f 72 6f  t sqlite3_api_ro
5fb0: 75 74 69 6e 65 73 20 2a 70 41 70 69 0a 29 7b 0a  utines *pApi.){.
5fc0: 20 20 53 51 4c 49 54 45 5f 45 58 54 45 4e 53 49    SQLITE_EXTENSI
5fd0: 4f 4e 5f 49 4e 49 54 32 28 70 41 70 69 29 3b 0a  ON_INIT2(pApi);.
5fe0: 20 20 72 65 74 75 72 6e 20 73 71 6c 69 74 65 33    return sqlite3
5ff0: 44 62 64 61 74 61 52 65 67 69 73 74 65 72 28 64  DbdataRegister(d
6000: 62 29 3b 0a 7d 0a                                b);.}.