/ Hex Artifact Content
Login

Artifact a9bc647738c0dcaebf205d6d194b3ce4a6ef3925801cd2d919f0a4ea33a15aeb:


0000: 0a 23 69 6e 63 6c 75 64 65 20 22 6c 73 6d 74 65  .#include "lsmte
0010: 73 74 2e 68 22 0a 23 69 6e 63 6c 75 64 65 20 3c  st.h".#include <
0020: 73 71 6c 69 74 65 33 2e 68 3e 0a 0a 76 6f 69 64  sqlite3.h>..void
0030: 20 74 65 73 74 5f 66 61 69 6c 65 64 28 29 7b 20   test_failed(){ 
0040: 0a 20 20 61 73 73 65 72 74 28 20 30 20 29 3b 0a  .  assert( 0 );.
0050: 20 20 72 65 74 75 72 6e 3b 20 0a 7d 0a 0a 23 64    return; .}..#d
0060: 65 66 69 6e 65 20 74 65 73 74 53 65 74 45 72 72  efine testSetErr
0070: 6f 72 28 72 63 29 20 74 65 73 74 53 65 74 45 72  or(rc) testSetEr
0080: 72 6f 72 46 75 6e 63 28 72 63 2c 20 70 52 63 2c  rorFunc(rc, pRc,
0090: 20 5f 5f 46 49 4c 45 5f 5f 2c 20 5f 5f 4c 49 4e   __FILE__, __LIN
00a0: 45 5f 5f 29 0a 73 74 61 74 69 63 20 76 6f 69 64  E__).static void
00b0: 20 74 65 73 74 53 65 74 45 72 72 6f 72 46 75 6e   testSetErrorFun
00c0: 63 28 69 6e 74 20 72 63 2c 20 69 6e 74 20 2a 70  c(int rc, int *p
00d0: 52 63 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  Rc, const char *
00e0: 7a 46 69 6c 65 2c 20 69 6e 74 20 69 4c 69 6e 65  zFile, int iLine
00f0: 29 7b 0a 20 20 69 66 28 20 72 63 20 29 7b 0a 20  ){.  if( rc ){. 
0100: 20 20 20 2a 70 52 63 20 3d 20 72 63 3b 0a 20 20     *pRc = rc;.  
0110: 20 20 66 70 72 69 6e 74 66 28 73 74 64 65 72 72    fprintf(stderr
0120: 2c 20 22 46 41 49 4c 45 44 20 28 25 73 3a 25 64  , "FAILED (%s:%d
0130: 29 20 72 63 3d 25 64 20 22 2c 20 7a 46 69 6c 65  ) rc=%d ", zFile
0140: 2c 20 69 4c 69 6e 65 2c 20 72 63 29 3b 0a 20 20  , iLine, rc);.  
0150: 20 20 74 65 73 74 5f 66 61 69 6c 65 64 28 29 3b    test_failed();
0160: 0a 20 20 7d 0a 7d 0a 0a 73 74 61 74 69 63 20 69  .  }.}..static i
0170: 6e 74 20 6c 73 6d 5f 6d 65 6d 63 6d 70 28 75 38  nt lsm_memcmp(u8
0180: 20 2a 61 2c 20 75 38 20 2a 62 2c 20 69 6e 74 20   *a, u8 *b, int 
0190: 63 29 7b 0a 20 20 69 6e 74 20 69 3b 0a 20 20 66  c){.  int i;.  f
01a0: 6f 72 28 69 3d 30 3b 20 69 3c 63 3b 20 69 2b 2b  or(i=0; i<c; i++
01b0: 29 7b 0a 20 20 20 20 69 66 28 20 61 5b 69 5d 21  ){.    if( a[i]!
01c0: 3d 62 5b 69 5d 20 29 20 72 65 74 75 72 6e 20 61  =b[i] ) return a
01d0: 5b 69 5d 20 2d 20 62 5b 69 5d 3b 0a 20 20 7d 0a  [i] - b[i];.  }.
01e0: 20 20 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 2f    return 0;.}../
01f0: 2a 0a 2a 2a 20 41 20 74 65 73 74 20 75 74 69 6c  *.** A test util
0200: 69 74 79 20 66 75 6e 63 74 69 6f 6e 2e 0a 2a 2f  ity function..*/
0210: 0a 76 6f 69 64 20 74 65 73 74 46 65 74 63 68 28  .void testFetch(
0220: 0a 20 20 54 65 73 74 44 62 20 2a 70 44 62 2c 20  .  TestDb *pDb, 
0230: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0240: 20 20 20 2f 2a 20 44 61 74 61 62 61 73 65 20 68     /* Database h
0250: 61 6e 64 6c 65 20 2a 2f 0a 20 20 76 6f 69 64 20  andle */.  void 
0260: 2a 70 4b 65 79 2c 20 69 6e 74 20 6e 4b 65 79 2c  *pKey, int nKey,
0270: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4b 65             /* Ke
0280: 79 20 74 6f 20 71 75 65 72 79 20 64 61 74 61 62  y to query datab
0290: 61 73 65 20 66 6f 72 20 2a 2f 0a 20 20 76 6f 69  ase for */.  voi
02a0: 64 20 2a 70 56 61 6c 2c 20 69 6e 74 20 6e 56 61  d *pVal, int nVa
02b0: 6c 2c 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20  l,           /* 
02c0: 45 78 70 65 63 74 65 64 20 76 61 6c 75 65 20 2a  Expected value *
02d0: 2f 0a 20 20 69 6e 74 20 2a 70 52 63 20 20 20 20  /.  int *pRc    
02e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
02f0: 20 20 20 20 2f 2a 20 49 4e 2f 4f 55 54 3a 20 45      /* IN/OUT: E
0300: 72 72 6f 72 20 63 6f 64 65 20 2a 2f 0a 29 7b 0a  rror code */.){.
0310: 20 20 69 66 28 20 2a 70 52 63 3d 3d 30 20 29 7b    if( *pRc==0 ){
0320: 0a 20 20 20 20 76 6f 69 64 20 2a 70 44 62 56 61  .    void *pDbVa
0330: 6c 3b 0a 20 20 20 20 69 6e 74 20 6e 44 62 56 61  l;.    int nDbVa
0340: 6c 3b 0a 20 20 20 20 69 6e 74 20 72 63 3b 0a 0a  l;.    int rc;..
0350: 20 20 20 20 73 74 61 74 69 63 20 69 6e 74 20 6e      static int n
0360: 43 61 6c 6c 20 3d 20 30 3b 20 6e 43 61 6c 6c 2b  Call = 0; nCall+
0370: 2b 3b 0a 0a 20 20 20 20 72 63 20 3d 20 74 64 62  +;..    rc = tdb
0380: 5f 66 65 74 63 68 28 70 44 62 2c 20 70 4b 65 79  _fetch(pDb, pKey
0390: 2c 20 6e 4b 65 79 2c 20 26 70 44 62 56 61 6c 2c  , nKey, &pDbVal,
03a0: 20 26 6e 44 62 56 61 6c 29 3b 0a 20 20 20 20 74   &nDbVal);.    t
03b0: 65 73 74 53 65 74 45 72 72 6f 72 28 72 63 29 3b  estSetError(rc);
03c0: 0a 20 20 20 20 69 66 28 20 72 63 3d 3d 30 20 26  .    if( rc==0 &
03d0: 26 20 28 6e 56 61 6c 21 3d 6e 44 62 56 61 6c 20  & (nVal!=nDbVal 
03e0: 7c 7c 20 28 6e 56 61 6c 3e 30 20 26 26 20 6c 73  || (nVal>0 && ls
03f0: 6d 5f 6d 65 6d 63 6d 70 28 70 56 61 6c 2c 20 70  m_memcmp(pVal, p
0400: 44 62 56 61 6c 2c 20 6e 56 61 6c 29 29 29 20 29  DbVal, nVal))) )
0410: 7b 0a 20 20 20 20 20 20 74 65 73 74 53 65 74 45  {.      testSetE
0420: 72 72 6f 72 28 31 29 3b 0a 20 20 20 20 7d 0a 20  rror(1);.    }. 
0430: 20 7d 0a 7d 0a 0a 76 6f 69 64 20 74 65 73 74 57   }.}..void testW
0440: 72 69 74 65 28 0a 20 20 54 65 73 74 44 62 20 2a  rite(.  TestDb *
0450: 70 44 62 2c 20 20 20 20 20 20 20 20 20 20 20 20  pDb,            
0460: 20 20 20 20 20 20 20 20 2f 2a 20 44 61 74 61 62          /* Datab
0470: 61 73 65 20 68 61 6e 64 6c 65 20 2a 2f 0a 20 20  ase handle */.  
0480: 76 6f 69 64 20 2a 70 4b 65 79 2c 20 69 6e 74 20  void *pKey, int 
0490: 6e 4b 65 79 2c 20 20 20 20 20 20 20 20 20 20 20  nKey,           
04a0: 2f 2a 20 4b 65 79 20 74 6f 20 71 75 65 72 79 20  /* Key to query 
04b0: 64 61 74 61 62 61 73 65 20 66 6f 72 20 2a 2f 0a  database for */.
04c0: 20 20 76 6f 69 64 20 2a 70 56 61 6c 2c 20 69 6e    void *pVal, in
04d0: 74 20 6e 56 61 6c 2c 20 20 20 20 20 20 20 20 20  t nVal,         
04e0: 20 20 2f 2a 20 56 61 6c 75 65 20 74 6f 20 77 72    /* Value to wr
04f0: 69 74 65 20 2a 2f 0a 20 20 69 6e 74 20 2a 70 52  ite */.  int *pR
0500: 63 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  c               
0510: 20 20 20 20 20 20 20 20 20 2f 2a 20 49 4e 2f 4f           /* IN/O
0520: 55 54 3a 20 45 72 72 6f 72 20 63 6f 64 65 20 2a  UT: Error code *
0530: 2f 0a 29 7b 0a 20 20 69 66 28 20 2a 70 52 63 3d  /.){.  if( *pRc=
0540: 3d 30 20 29 7b 0a 20 20 20 20 69 6e 74 20 72 63  =0 ){.    int rc
0550: 3b 0a 73 74 61 74 69 63 20 69 6e 74 20 6e 43 61  ;.static int nCa
0560: 6c 6c 20 3d 20 30 3b 0a 6e 43 61 6c 6c 2b 2b 3b  ll = 0;.nCall++;
0570: 0a 20 20 20 20 72 63 20 3d 20 74 64 62 5f 77 72  .    rc = tdb_wr
0580: 69 74 65 28 70 44 62 2c 20 70 4b 65 79 2c 20 6e  ite(pDb, pKey, n
0590: 4b 65 79 2c 20 70 56 61 6c 2c 20 6e 56 61 6c 29  Key, pVal, nVal)
05a0: 3b 0a 20 20 20 20 74 65 73 74 53 65 74 45 72 72  ;.    testSetErr
05b0: 6f 72 28 72 63 29 3b 0a 20 20 7d 0a 7d 0a 76 6f  or(rc);.  }.}.vo
05c0: 69 64 20 74 65 73 74 44 65 6c 65 74 65 28 0a 20  id testDelete(. 
05d0: 20 54 65 73 74 44 62 20 2a 70 44 62 2c 20 20 20   TestDb *pDb,   
05e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
05f0: 20 2f 2a 20 44 61 74 61 62 61 73 65 20 68 61 6e   /* Database han
0600: 64 6c 65 20 2a 2f 0a 20 20 76 6f 69 64 20 2a 70  dle */.  void *p
0610: 4b 65 79 2c 20 69 6e 74 20 6e 4b 65 79 2c 20 20  Key, int nKey,  
0620: 20 20 20 20 20 20 20 20 20 2f 2a 20 4b 65 79 20           /* Key 
0630: 74 6f 20 71 75 65 72 79 20 64 61 74 61 62 61 73  to query databas
0640: 65 20 66 6f 72 20 2a 2f 0a 20 20 69 6e 74 20 2a  e for */.  int *
0650: 70 52 63 20 20 20 20 20 20 20 20 20 20 20 20 20  pRc             
0660: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 49 4e             /* IN
0670: 2f 4f 55 54 3a 20 45 72 72 6f 72 20 63 6f 64 65  /OUT: Error code
0680: 20 2a 2f 0a 29 7b 0a 20 20 69 66 28 20 2a 70 52   */.){.  if( *pR
0690: 63 3d 3d 30 20 29 7b 0a 20 20 20 20 69 6e 74 20  c==0 ){.    int 
06a0: 72 63 3b 0a 20 20 20 20 2a 70 52 63 20 3d 20 72  rc;.    *pRc = r
06b0: 63 20 3d 20 74 64 62 5f 64 65 6c 65 74 65 28 70  c = tdb_delete(p
06c0: 44 62 2c 20 70 4b 65 79 2c 20 6e 4b 65 79 29 3b  Db, pKey, nKey);
06d0: 0a 20 20 20 20 74 65 73 74 53 65 74 45 72 72 6f  .    testSetErro
06e0: 72 28 72 63 29 3b 0a 20 20 7d 0a 7d 0a 76 6f 69  r(rc);.  }.}.voi
06f0: 64 20 74 65 73 74 44 65 6c 65 74 65 52 61 6e 67  d testDeleteRang
0700: 65 28 0a 20 20 54 65 73 74 44 62 20 2a 70 44 62  e(.  TestDb *pDb
0710: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,               
0720: 20 20 20 20 20 2f 2a 20 44 61 74 61 62 61 73 65       /* Database
0730: 20 68 61 6e 64 6c 65 20 2a 2f 0a 20 20 76 6f 69   handle */.  voi
0740: 64 20 2a 70 4b 65 79 31 2c 20 69 6e 74 20 6e 4b  d *pKey1, int nK
0750: 65 79 31 2c 0a 20 20 76 6f 69 64 20 2a 70 4b 65  ey1,.  void *pKe
0760: 79 32 2c 20 69 6e 74 20 6e 4b 65 79 32 2c 0a 20  y2, int nKey2,. 
0770: 20 69 6e 74 20 2a 70 52 63 20 20 20 20 20 20 20   int *pRc       
0780: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0790: 20 2f 2a 20 49 4e 2f 4f 55 54 3a 20 45 72 72 6f   /* IN/OUT: Erro
07a0: 72 20 63 6f 64 65 20 2a 2f 0a 29 7b 0a 20 20 69  r code */.){.  i
07b0: 66 28 20 2a 70 52 63 3d 3d 30 20 29 7b 0a 20 20  f( *pRc==0 ){.  
07c0: 20 20 69 6e 74 20 72 63 3b 0a 20 20 20 20 2a 70    int rc;.    *p
07d0: 52 63 20 3d 20 72 63 20 3d 20 74 64 62 5f 64 65  Rc = rc = tdb_de
07e0: 6c 65 74 65 5f 72 61 6e 67 65 28 70 44 62 2c 20  lete_range(pDb, 
07f0: 70 4b 65 79 31 2c 20 6e 4b 65 79 31 2c 20 70 4b  pKey1, nKey1, pK
0800: 65 79 32 2c 20 6e 4b 65 79 32 29 3b 0a 20 20 20  ey2, nKey2);.   
0810: 20 74 65 73 74 53 65 74 45 72 72 6f 72 28 72 63   testSetError(rc
0820: 29 3b 0a 20 20 7d 0a 7d 0a 0a 76 6f 69 64 20 74  );.  }.}..void t
0830: 65 73 74 42 65 67 69 6e 28 54 65 73 74 44 62 20  estBegin(TestDb 
0840: 2a 70 44 62 2c 20 69 6e 74 20 69 54 72 61 6e 73  *pDb, int iTrans
0850: 2c 20 69 6e 74 20 2a 70 52 63 29 7b 0a 20 20 69  , int *pRc){.  i
0860: 66 28 20 2a 70 52 63 3d 3d 30 20 29 7b 0a 20 20  f( *pRc==0 ){.  
0870: 20 20 69 6e 74 20 72 63 3b 0a 20 20 20 20 72 63    int rc;.    rc
0880: 20 3d 20 74 64 62 5f 62 65 67 69 6e 28 70 44 62   = tdb_begin(pDb
0890: 2c 20 69 54 72 61 6e 73 29 3b 0a 20 20 20 20 74  , iTrans);.    t
08a0: 65 73 74 53 65 74 45 72 72 6f 72 28 72 63 29 3b  estSetError(rc);
08b0: 0a 20 20 7d 0a 7d 0a 76 6f 69 64 20 74 65 73 74  .  }.}.void test
08c0: 43 6f 6d 6d 69 74 28 54 65 73 74 44 62 20 2a 70  Commit(TestDb *p
08d0: 44 62 2c 20 69 6e 74 20 69 54 72 61 6e 73 2c 20  Db, int iTrans, 
08e0: 69 6e 74 20 2a 70 52 63 29 7b 0a 20 20 69 66 28  int *pRc){.  if(
08f0: 20 2a 70 52 63 3d 3d 30 20 29 7b 0a 20 20 20 20   *pRc==0 ){.    
0900: 69 6e 74 20 72 63 3b 0a 20 20 20 20 72 63 20 3d  int rc;.    rc =
0910: 20 74 64 62 5f 63 6f 6d 6d 69 74 28 70 44 62 2c   tdb_commit(pDb,
0920: 20 69 54 72 61 6e 73 29 3b 0a 20 20 20 20 74 65   iTrans);.    te
0930: 73 74 53 65 74 45 72 72 6f 72 28 72 63 29 3b 0a  stSetError(rc);.
0940: 20 20 7d 0a 7d 0a 23 69 66 20 30 20 2f 2a 20 75    }.}.#if 0 /* u
0950: 6e 75 73 65 64 20 2a 2f 0a 73 74 61 74 69 63 20  nused */.static 
0960: 76 6f 69 64 20 74 65 73 74 52 6f 6c 6c 62 61 63  void testRollbac
0970: 6b 28 54 65 73 74 44 62 20 2a 70 44 62 2c 20 69  k(TestDb *pDb, i
0980: 6e 74 20 69 54 72 61 6e 73 2c 20 69 6e 74 20 2a  nt iTrans, int *
0990: 70 52 63 29 7b 0a 20 20 69 66 28 20 2a 70 52 63  pRc){.  if( *pRc
09a0: 3d 3d 30 20 29 7b 0a 20 20 20 20 69 6e 74 20 72  ==0 ){.    int r
09b0: 63 3b 0a 20 20 20 20 72 63 20 3d 20 74 64 62 5f  c;.    rc = tdb_
09c0: 72 6f 6c 6c 62 61 63 6b 28 70 44 62 2c 20 69 54  rollback(pDb, iT
09d0: 72 61 6e 73 29 3b 0a 20 20 20 20 74 65 73 74 53  rans);.    testS
09e0: 65 74 45 72 72 6f 72 28 72 63 29 3b 0a 20 20 7d  etError(rc);.  }
09f0: 0a 7d 0a 23 65 6e 64 69 66 0a 0a 76 6f 69 64 20  .}.#endif..void 
0a00: 74 65 73 74 57 72 69 74 65 53 74 72 28 0a 20 20  testWriteStr(.  
0a10: 54 65 73 74 44 62 20 2a 70 44 62 2c 20 20 20 20  TestDb *pDb,    
0a20: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0a30: 2f 2a 20 44 61 74 61 62 61 73 65 20 68 61 6e 64  /* Database hand
0a40: 6c 65 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68  le */.  const ch
0a50: 61 72 20 2a 7a 4b 65 79 2c 20 20 20 20 20 20 20  ar *zKey,       
0a60: 20 20 20 20 20 20 20 20 2f 2a 20 4b 65 79 20 74          /* Key t
0a70: 6f 20 71 75 65 72 79 20 64 61 74 61 62 61 73 65  o query database
0a80: 20 66 6f 72 20 2a 2f 0a 20 20 63 6f 6e 73 74 20   for */.  const 
0a90: 63 68 61 72 20 2a 7a 56 61 6c 2c 20 20 20 20 20  char *zVal,     
0aa0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 56 61 6c            /* Val
0ab0: 75 65 20 74 6f 20 77 72 69 74 65 20 2a 2f 0a 20  ue to write */. 
0ac0: 20 69 6e 74 20 2a 70 52 63 20 20 20 20 20 20 20   int *pRc       
0ad0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0ae0: 20 2f 2a 20 49 4e 2f 4f 55 54 3a 20 45 72 72 6f   /* IN/OUT: Erro
0af0: 72 20 63 6f 64 65 20 2a 2f 0a 29 7b 0a 20 20 69  r code */.){.  i
0b00: 6e 74 20 6e 56 61 6c 20 3d 20 28 7a 56 61 6c 20  nt nVal = (zVal 
0b10: 3f 20 73 74 72 6c 65 6e 28 7a 56 61 6c 29 20 3a  ? strlen(zVal) :
0b20: 20 30 29 3b 0a 20 20 74 65 73 74 57 72 69 74 65   0);.  testWrite
0b30: 28 70 44 62 2c 20 28 76 6f 69 64 20 2a 29 7a 4b  (pDb, (void *)zK
0b40: 65 79 2c 20 73 74 72 6c 65 6e 28 7a 4b 65 79 29  ey, strlen(zKey)
0b50: 2c 20 28 76 6f 69 64 20 2a 29 7a 56 61 6c 2c 20  , (void *)zVal, 
0b60: 6e 56 61 6c 2c 20 70 52 63 29 3b 0a 7d 0a 0a 23  nVal, pRc);.}..#
0b70: 69 66 20 30 20 2f 2a 20 75 6e 75 73 65 64 20 2a  if 0 /* unused *
0b80: 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20 74 65  /.static void te
0b90: 73 74 44 65 6c 65 74 65 53 74 72 28 54 65 73 74  stDeleteStr(Test
0ba0: 44 62 20 2a 70 44 62 2c 20 63 6f 6e 73 74 20 63  Db *pDb, const c
0bb0: 68 61 72 20 2a 7a 4b 65 79 2c 20 69 6e 74 20 2a  har *zKey, int *
0bc0: 70 52 63 29 7b 0a 20 20 74 65 73 74 44 65 6c 65  pRc){.  testDele
0bd0: 74 65 28 70 44 62 2c 20 28 76 6f 69 64 20 2a 29  te(pDb, (void *)
0be0: 7a 4b 65 79 2c 20 73 74 72 6c 65 6e 28 7a 4b 65  zKey, strlen(zKe
0bf0: 79 29 2c 20 70 52 63 29 3b 0a 7d 0a 23 65 6e 64  y), pRc);.}.#end
0c00: 69 66 0a 76 6f 69 64 20 74 65 73 74 46 65 74 63  if.void testFetc
0c10: 68 53 74 72 28 0a 20 20 54 65 73 74 44 62 20 2a  hStr(.  TestDb *
0c20: 70 44 62 2c 20 20 20 20 20 20 20 20 20 20 20 20  pDb,            
0c30: 20 20 20 20 20 20 20 20 2f 2a 20 44 61 74 61 62          /* Datab
0c40: 61 73 65 20 68 61 6e 64 6c 65 20 2a 2f 0a 20 20  ase handle */.  
0c50: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 4b 65 79  const char *zKey
0c60: 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,               
0c70: 2f 2a 20 4b 65 79 20 74 6f 20 71 75 65 72 79 20  /* Key to query 
0c80: 64 61 74 61 62 61 73 65 20 66 6f 72 20 2a 2f 0a  database for */.
0c90: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 56    const char *zV
0ca0: 61 6c 2c 20 20 20 20 20 20 20 20 20 20 20 20 20  al,             
0cb0: 20 20 2f 2a 20 56 61 6c 75 65 20 74 6f 20 77 72    /* Value to wr
0cc0: 69 74 65 20 2a 2f 0a 20 20 69 6e 74 20 2a 70 52  ite */.  int *pR
0cd0: 63 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  c               
0ce0: 20 20 20 20 20 20 20 20 20 2f 2a 20 49 4e 2f 4f           /* IN/O
0cf0: 55 54 3a 20 45 72 72 6f 72 20 63 6f 64 65 20 2a  UT: Error code *
0d00: 2f 0a 29 7b 0a 20 20 69 6e 74 20 6e 56 61 6c 20  /.){.  int nVal 
0d10: 3d 20 28 7a 56 61 6c 20 3f 20 73 74 72 6c 65 6e  = (zVal ? strlen
0d20: 28 7a 56 61 6c 29 20 3a 20 30 29 3b 0a 20 20 74  (zVal) : 0);.  t
0d30: 65 73 74 46 65 74 63 68 28 70 44 62 2c 20 28 76  estFetch(pDb, (v
0d40: 6f 69 64 20 2a 29 7a 4b 65 79 2c 20 73 74 72 6c  oid *)zKey, strl
0d50: 65 6e 28 7a 4b 65 79 29 2c 20 28 76 6f 69 64 20  en(zKey), (void 
0d60: 2a 29 7a 56 61 6c 2c 20 6e 56 61 6c 2c 20 70 52  *)zVal, nVal, pR
0d70: 63 29 3b 0a 7d 0a 0a 76 6f 69 64 20 74 65 73 74  c);.}..void test
0d80: 46 65 74 63 68 43 6f 6d 70 61 72 65 28 0a 20 20  FetchCompare(.  
0d90: 54 65 73 74 44 62 20 2a 70 43 6f 6e 74 72 6f 6c  TestDb *pControl
0da0: 2c 20 0a 20 20 54 65 73 74 44 62 20 2a 70 44 62  , .  TestDb *pDb
0db0: 2c 20 0a 20 20 76 6f 69 64 20 2a 70 4b 65 79 2c  , .  void *pKey,
0dc0: 20 69 6e 74 20 6e 4b 65 79 2c 20 0a 20 20 69 6e   int nKey, .  in
0dd0: 74 20 2a 70 52 63 0a 29 7b 0a 20 20 69 6e 74 20  t *pRc.){.  int 
0de0: 72 63 3b 0a 20 20 76 6f 69 64 20 2a 70 44 62 56  rc;.  void *pDbV
0df0: 61 6c 31 3b 0a 20 20 76 6f 69 64 20 2a 70 44 62  al1;.  void *pDb
0e00: 56 61 6c 32 3b 0a 20 20 69 6e 74 20 6e 44 62 56  Val2;.  int nDbV
0e10: 61 6c 31 3b 0a 20 20 69 6e 74 20 6e 44 62 56 61  al1;.  int nDbVa
0e20: 6c 32 3b 0a 0a 20 20 73 74 61 74 69 63 20 69 6e  l2;..  static in
0e30: 74 20 6e 43 61 6c 6c 20 3d 20 30 3b 0a 20 20 6e  t nCall = 0;.  n
0e40: 43 61 6c 6c 2b 2b 3b 0a 0a 20 20 72 63 20 3d 20  Call++;..  rc = 
0e50: 74 64 62 5f 66 65 74 63 68 28 70 43 6f 6e 74 72  tdb_fetch(pContr
0e60: 6f 6c 2c 20 70 4b 65 79 2c 20 6e 4b 65 79 2c 20  ol, pKey, nKey, 
0e70: 26 70 44 62 56 61 6c 31 2c 20 26 6e 44 62 56 61  &pDbVal1, &nDbVa
0e80: 6c 31 29 3b 0a 20 20 74 65 73 74 53 65 74 45 72  l1);.  testSetEr
0e90: 72 6f 72 28 72 63 29 3b 0a 0a 20 20 72 63 20 3d  ror(rc);..  rc =
0ea0: 20 74 64 62 5f 66 65 74 63 68 28 70 44 62 2c 20   tdb_fetch(pDb, 
0eb0: 70 4b 65 79 2c 20 6e 4b 65 79 2c 20 26 70 44 62  pKey, nKey, &pDb
0ec0: 56 61 6c 32 2c 20 26 6e 44 62 56 61 6c 32 29 3b  Val2, &nDbVal2);
0ed0: 0a 20 20 74 65 73 74 53 65 74 45 72 72 6f 72 28  .  testSetError(
0ee0: 72 63 29 3b 0a 0a 20 20 69 66 28 20 2a 70 52 63  rc);..  if( *pRc
0ef0: 3d 3d 30 20 0a 20 20 20 26 26 20 28 6e 44 62 56  ==0 .   && (nDbV
0f00: 61 6c 31 21 3d 6e 44 62 56 61 6c 32 20 7c 7c 20  al1!=nDbVal2 || 
0f10: 28 6e 44 62 56 61 6c 31 3e 30 20 26 26 20 6d 65  (nDbVal1>0 && me
0f20: 6d 63 6d 70 28 70 44 62 56 61 6c 31 2c 20 70 44  mcmp(pDbVal1, pD
0f30: 62 56 61 6c 32 2c 20 6e 44 62 56 61 6c 31 29 29  bVal2, nDbVal1))
0f40: 29 0a 20 20 29 7b 0a 20 20 20 20 74 65 73 74 53  ).  ){.    testS
0f50: 65 74 45 72 72 6f 72 28 31 29 3b 0a 20 20 7d 0a  etError(1);.  }.
0f60: 7d 0a 0a 74 79 70 65 64 65 66 20 73 74 72 75 63  }..typedef struc
0f70: 74 20 53 63 61 6e 52 65 73 75 6c 74 20 53 63 61  t ScanResult Sca
0f80: 6e 52 65 73 75 6c 74 3b 0a 73 74 72 75 63 74 20  nResult;.struct 
0f90: 53 63 61 6e 52 65 73 75 6c 74 20 7b 0a 20 20 54  ScanResult {.  T
0fa0: 65 73 74 44 62 20 2a 70 44 62 3b 0a 0a 20 20 69  estDb *pDb;..  i
0fb0: 6e 74 20 6e 52 6f 77 3b 0a 20 20 75 33 32 20 63  nt nRow;.  u32 c
0fc0: 6b 73 75 6d 31 3b 0a 20 20 75 33 32 20 63 6b 73  ksum1;.  u32 cks
0fd0: 75 6d 32 3b 0a 20 20 76 6f 69 64 20 2a 70 4b 65  um2;.  void *pKe
0fe0: 79 31 3b 20 69 6e 74 20 6e 4b 65 79 31 3b 0a 20  y1; int nKey1;. 
0ff0: 20 76 6f 69 64 20 2a 70 4b 65 79 32 3b 20 69 6e   void *pKey2; in
1000: 74 20 6e 4b 65 79 32 3b 0a 0a 20 20 69 6e 74 20  t nKey2;..  int 
1010: 62 52 65 76 65 72 73 65 3b 0a 20 20 69 6e 74 20  bReverse;.  int 
1020: 6e 50 72 65 76 4b 65 79 3b 0a 20 20 75 38 20 61  nPrevKey;.  u8 a
1030: 50 72 65 76 4b 65 79 5b 32 35 36 5d 3b 0a 7d 3b  PrevKey[256];.};
1040: 0a 0a 73 74 61 74 69 63 20 69 6e 74 20 6b 65 79  ..static int key
1050: 43 6f 6d 70 61 72 65 28 76 6f 69 64 20 2a 70 4b  Compare(void *pK
1060: 65 79 31 2c 20 69 6e 74 20 6e 4b 65 79 31 2c 20  ey1, int nKey1, 
1070: 76 6f 69 64 20 2a 70 4b 65 79 32 2c 20 69 6e 74  void *pKey2, int
1080: 20 6e 4b 65 79 32 29 7b 0a 20 20 69 6e 74 20 72   nKey2){.  int r
1090: 65 73 3b 0a 20 20 72 65 73 20 3d 20 6d 65 6d 63  es;.  res = memc
10a0: 6d 70 28 70 4b 65 79 31 2c 20 70 4b 65 79 32 2c  mp(pKey1, pKey2,
10b0: 20 4d 49 4e 28 6e 4b 65 79 31 2c 20 6e 4b 65 79   MIN(nKey1, nKey
10c0: 32 29 29 3b 0a 20 20 69 66 28 20 72 65 73 3d 3d  2));.  if( res==
10d0: 30 20 29 7b 0a 20 20 20 20 72 65 73 20 3d 20 6e  0 ){.    res = n
10e0: 4b 65 79 31 20 2d 20 6e 4b 65 79 32 3b 0a 20 20  Key1 - nKey2;.  
10f0: 7d 0a 20 20 72 65 74 75 72 6e 20 72 65 73 3b 0a  }.  return res;.
1100: 7d 0a 0a 69 6e 74 20 74 65 73 74 5f 73 63 61 6e  }..int test_scan
1110: 5f 64 65 62 75 67 20 3d 20 30 3b 0a 0a 73 74 61  _debug = 0;..sta
1120: 74 69 63 20 76 6f 69 64 20 73 63 61 6e 43 6f 6d  tic void scanCom
1130: 70 61 72 65 43 62 28 0a 20 20 76 6f 69 64 20 2a  pareCb(.  void *
1140: 70 43 74 78 2c 20 0a 20 20 76 6f 69 64 20 2a 70  pCtx, .  void *p
1150: 4b 65 79 2c 20 69 6e 74 20 6e 4b 65 79 2c 0a 20  Key, int nKey,. 
1160: 20 76 6f 69 64 20 2a 70 56 61 6c 2c 20 69 6e 74   void *pVal, int
1170: 20 6e 56 61 6c 0a 29 7b 0a 20 20 53 63 61 6e 52   nVal.){.  ScanR
1180: 65 73 75 6c 74 20 2a 70 20 3d 20 28 53 63 61 6e  esult *p = (Scan
1190: 52 65 73 75 6c 74 20 2a 29 70 43 74 78 3b 0a 20  Result *)pCtx;. 
11a0: 20 75 38 20 2a 61 4b 65 79 20 3d 20 28 75 38 20   u8 *aKey = (u8 
11b0: 2a 29 70 4b 65 79 3b 0a 20 20 75 38 20 2a 61 56  *)pKey;.  u8 *aV
11c0: 61 6c 20 3d 20 28 75 38 20 2a 29 70 56 61 6c 3b  al = (u8 *)pVal;
11d0: 0a 20 20 69 6e 74 20 69 3b 0a 0a 20 20 69 66 28  .  int i;..  if(
11e0: 20 74 65 73 74 5f 73 63 61 6e 5f 64 65 62 75 67   test_scan_debug
11f0: 20 29 7b 0a 20 20 20 20 70 72 69 6e 74 66 28 22   ){.    printf("
1200: 25 64 3a 20 25 2e 2a 73 5c 6e 22 2c 20 70 2d 3e  %d: %.*s\n", p->
1210: 6e 52 6f 77 2c 20 6e 4b 65 79 2c 20 28 63 68 61  nRow, nKey, (cha
1220: 72 20 2a 29 70 4b 65 79 29 3b 0a 20 20 20 20 66  r *)pKey);.    f
1230: 66 6c 75 73 68 28 73 74 64 6f 75 74 29 3b 0a 20  flush(stdout);. 
1240: 20 7d 0a 23 69 66 20 30 0a 20 20 69 66 28 20 74   }.#if 0.  if( t
1250: 65 73 74 5f 73 63 61 6e 5f 64 65 62 75 67 20 29  est_scan_debug )
1260: 20 70 72 69 6e 74 66 28 22 25 2e 32 30 73 5c 6e   printf("%.20s\n
1270: 22 2c 20 28 63 68 61 72 20 2a 29 70 56 61 6c 29  ", (char *)pVal)
1280: 3b 0a 23 65 6e 64 69 66 0a 0a 23 69 66 20 30 0a  ;.#endif..#if 0.
1290: 20 20 2f 2a 20 43 68 65 63 6b 20 74 64 62 5f 66    /* Check tdb_f
12a0: 65 74 63 68 28 29 20 6d 61 74 63 68 65 73 20 2a  etch() matches *
12b0: 2f 0a 20 20 69 6e 74 20 72 63 20 3d 20 30 3b 0a  /.  int rc = 0;.
12c0: 20 20 74 65 73 74 46 65 74 63 68 28 70 2d 3e 70    testFetch(p->p
12d0: 44 62 2c 20 70 4b 65 79 2c 20 6e 4b 65 79 2c 20  Db, pKey, nKey, 
12e0: 70 56 61 6c 2c 20 6e 56 61 6c 2c 20 26 72 63 29  pVal, nVal, &rc)
12f0: 3b 0a 20 20 61 73 73 65 72 74 28 20 72 63 3d 3d  ;.  assert( rc==
1300: 30 20 29 3b 0a 23 65 6e 64 69 66 0a 0a 20 20 2f  0 );.#endif..  /
1310: 2a 20 55 70 64 61 74 65 20 74 68 65 20 63 68 65  * Update the che
1320: 63 6b 73 75 6d 20 64 61 74 61 20 2a 2f 0a 20 20  cksum data */.  
1330: 70 2d 3e 6e 52 6f 77 2b 2b 3b 0a 20 20 66 6f 72  p->nRow++;.  for
1340: 28 69 3d 30 3b 20 69 3c 6e 4b 65 79 3b 20 69 2b  (i=0; i<nKey; i+
1350: 2b 29 7b 0a 20 20 20 20 70 2d 3e 63 6b 73 75 6d  +){.    p->cksum
1360: 31 20 2b 3d 20 28 28 69 6e 74 29 61 4b 65 79 5b  1 += ((int)aKey[
1370: 69 5d 20 3c 3c 20 28 69 26 30 78 30 46 29 29 3b  i] << (i&0x0F));
1380: 0a 20 20 20 20 70 2d 3e 63 6b 73 75 6d 32 20 2b  .    p->cksum2 +
1390: 3d 20 70 2d 3e 63 6b 73 75 6d 31 3b 0a 20 20 7d  = p->cksum1;.  }
13a0: 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 6e 56  .  for(i=0; i<nV
13b0: 61 6c 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 70 2d  al; i++){.    p-
13c0: 3e 63 6b 73 75 6d 31 20 2b 3d 20 28 28 69 6e 74  >cksum1 += ((int
13d0: 29 61 56 61 6c 5b 69 5d 20 3c 3c 20 28 69 26 30  )aVal[i] << (i&0
13e0: 78 30 46 29 29 3b 0a 20 20 20 20 70 2d 3e 63 6b  x0F));.    p->ck
13f0: 73 75 6d 32 20 2b 3d 20 70 2d 3e 63 6b 73 75 6d  sum2 += p->cksum
1400: 31 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 43 68 65  1;.  }..  /* Che
1410: 63 6b 20 74 68 61 74 20 74 68 65 20 64 65 6c 69  ck that the deli
1420: 76 65 72 65 64 20 72 6f 77 20 69 73 20 6e 6f 74  vered row is not
1430: 20 6f 75 74 20 6f 66 20 6f 72 64 65 72 2e 20 2a   out of order. *
1440: 2f 0a 20 20 69 66 28 20 6e 4b 65 79 3c 28 69 6e  /.  if( nKey<(in
1450: 74 29 73 69 7a 65 6f 66 28 70 2d 3e 61 50 72 65  t)sizeof(p->aPre
1460: 76 4b 65 79 29 20 29 7b 0a 20 20 20 20 69 66 28  vKey) ){.    if(
1470: 20 70 2d 3e 6e 50 72 65 76 4b 65 79 20 29 7b 0a   p->nPrevKey ){.
1480: 20 20 20 20 20 20 69 6e 74 20 72 65 73 20 3d 20        int res = 
1490: 6b 65 79 43 6f 6d 70 61 72 65 28 70 2d 3e 61 50  keyCompare(p->aP
14a0: 72 65 76 4b 65 79 2c 20 70 2d 3e 6e 50 72 65 76  revKey, p->nPrev
14b0: 4b 65 79 2c 20 70 4b 65 79 2c 20 6e 4b 65 79 29  Key, pKey, nKey)
14c0: 3b 0a 20 20 20 20 20 20 69 66 28 20 28 72 65 73  ;.      if( (res
14d0: 3c 30 20 26 26 20 70 2d 3e 62 52 65 76 65 72 73  <0 && p->bRevers
14e0: 65 29 20 7c 7c 20 28 72 65 73 3e 30 20 26 26 20  e) || (res>0 && 
14f0: 70 2d 3e 62 52 65 76 65 72 73 65 3d 3d 30 29 20  p->bReverse==0) 
1500: 29 7b 0a 20 20 20 20 20 20 20 20 74 65 73 74 50  ){.        testP
1510: 72 69 6e 74 45 72 72 6f 72 28 22 52 65 74 75 72  rintError("Retur
1520: 6e 65 64 20 6b 65 79 20 6f 75 74 20 6f 66 20 6f  ned key out of o
1530: 72 64 65 72 20 61 74 20 25 73 3a 25 64 5c 6e 22  rder at %s:%d\n"
1540: 2c 20 0a 20 20 20 20 20 20 20 20 20 20 20 20 5f  , .            _
1550: 5f 46 49 4c 45 5f 5f 2c 20 5f 5f 4c 49 4e 45 5f  _FILE__, __LINE_
1560: 5f 0a 20 20 20 20 20 20 20 20 29 3b 0a 20 20 20  _.        );.   
1570: 20 20 20 7d 0a 20 20 20 20 7d 0a 0a 20 20 20 20     }.    }..    
1580: 70 2d 3e 6e 50 72 65 76 4b 65 79 20 3d 20 6e 4b  p->nPrevKey = nK
1590: 65 79 3b 0a 20 20 20 20 6d 65 6d 63 70 79 28 70  ey;.    memcpy(p
15a0: 2d 3e 61 50 72 65 76 4b 65 79 2c 20 70 4b 65 79  ->aPrevKey, pKey
15b0: 2c 20 4d 49 4e 28 70 2d 3e 6e 50 72 65 76 4b 65  , MIN(p->nPrevKe
15c0: 79 2c 20 6e 4b 65 79 29 29 3b 0a 20 20 7d 0a 0a  y, nKey));.  }..
15d0: 20 20 2f 2a 20 43 68 65 63 6b 20 74 68 61 74 20    /* Check that 
15e0: 74 68 65 20 64 65 6c 69 76 65 72 65 64 20 72 6f  the delivered ro
15f0: 77 20 69 73 20 77 69 74 68 69 6e 20 72 61 6e 67  w is within rang
1600: 65 2e 20 2a 2f 0a 20 20 69 66 28 20 70 2d 3e 70  e. */.  if( p->p
1610: 4b 65 79 31 20 26 26 20 28 0a 20 20 20 20 20 20  Key1 && (.      
1620: 28 6d 65 6d 63 6d 70 28 70 2d 3e 70 4b 65 79 31  (memcmp(p->pKey1
1630: 2c 20 70 4b 65 79 2c 20 4d 49 4e 28 70 2d 3e 6e  , pKey, MIN(p->n
1640: 4b 65 79 31 2c 20 6e 4b 65 79 29 29 3e 30 29 0a  Key1, nKey))>0).
1650: 20 20 20 7c 7c 20 28 6d 65 6d 63 6d 70 28 70 2d     || (memcmp(p-
1660: 3e 70 4b 65 79 31 2c 20 70 4b 65 79 2c 20 4d 49  >pKey1, pKey, MI
1670: 4e 28 70 2d 3e 6e 4b 65 79 31 2c 20 6e 4b 65 79  N(p->nKey1, nKey
1680: 29 29 3d 3d 30 20 26 26 20 70 2d 3e 6e 4b 65 79  ))==0 && p->nKey
1690: 31 3e 6e 4b 65 79 29 0a 20 20 29 29 7b 0a 20 20  1>nKey).  )){.  
16a0: 20 20 74 65 73 74 50 72 69 6e 74 45 72 72 6f 72    testPrintError
16b0: 28 22 52 65 74 75 72 6e 65 64 20 6b 65 79 20 74  ("Returned key t
16c0: 6f 6f 20 73 6d 61 6c 6c 20 61 74 20 25 73 3a 25  oo small at %s:%
16d0: 64 5c 6e 22 2c 20 5f 5f 46 49 4c 45 5f 5f 2c 20  d\n", __FILE__, 
16e0: 5f 5f 4c 49 4e 45 5f 5f 29 3b 0a 20 20 7d 0a 20  __LINE__);.  }. 
16f0: 20 69 66 28 20 70 2d 3e 70 4b 65 79 32 20 26 26   if( p->pKey2 &&
1700: 20 28 0a 20 20 20 20 20 20 28 6d 65 6d 63 6d 70   (.      (memcmp
1710: 28 70 2d 3e 70 4b 65 79 32 2c 20 70 4b 65 79 2c  (p->pKey2, pKey,
1720: 20 4d 49 4e 28 70 2d 3e 6e 4b 65 79 32 2c 20 6e   MIN(p->nKey2, n
1730: 4b 65 79 29 29 3c 30 29 0a 20 20 20 7c 7c 20 28  Key))<0).   || (
1740: 6d 65 6d 63 6d 70 28 70 2d 3e 70 4b 65 79 32 2c  memcmp(p->pKey2,
1750: 20 70 4b 65 79 2c 20 4d 49 4e 28 70 2d 3e 6e 4b   pKey, MIN(p->nK
1760: 65 79 32 2c 20 6e 4b 65 79 29 29 3d 3d 30 20 26  ey2, nKey))==0 &
1770: 26 20 70 2d 3e 6e 4b 65 79 32 3c 6e 4b 65 79 29  & p->nKey2<nKey)
1780: 0a 20 20 29 29 7b 0a 20 20 20 20 74 65 73 74 50  .  )){.    testP
1790: 72 69 6e 74 45 72 72 6f 72 28 22 52 65 74 75 72  rintError("Retur
17a0: 6e 65 64 20 6b 65 79 20 74 6f 6f 20 6c 61 72 67  ned key too larg
17b0: 65 20 61 74 20 25 73 3a 25 64 5c 6e 22 2c 20 5f  e at %s:%d\n", _
17c0: 5f 46 49 4c 45 5f 5f 2c 20 5f 5f 4c 49 4e 45 5f  _FILE__, __LINE_
17d0: 5f 29 3b 0a 20 20 7d 0a 0a 7d 0a 0a 2f 2a 0a 2a  _);.  }..}../*.*
17e0: 2a 20 53 63 61 6e 20 74 68 65 20 63 6f 6e 74 65  * Scan the conte
17f0: 6e 74 73 20 6f 66 20 74 68 65 20 74 77 6f 20 64  nts of the two d
1800: 61 74 61 62 61 73 65 73 2e 20 43 68 65 63 6b 20  atabases. Check 
1810: 74 68 61 74 20 74 68 65 79 20 6d 61 74 63 68 2e  that they match.
1820: 0a 2a 2f 0a 76 6f 69 64 20 74 65 73 74 53 63 61  .*/.void testSca
1830: 6e 43 6f 6d 70 61 72 65 28 0a 20 20 54 65 73 74  nCompare(.  Test
1840: 44 62 20 2a 70 44 62 31 2c 20 20 20 20 20 20 20  Db *pDb1,       
1850: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 43              /* C
1860: 6f 6e 74 72 6f 6c 20 28 74 72 75 73 74 65 64 29  ontrol (trusted)
1870: 20 64 61 74 61 62 61 73 65 20 2a 2f 0a 20 20 54   database */.  T
1880: 65 73 74 44 62 20 2a 70 44 62 32 2c 20 20 20 20  estDb *pDb2,    
1890: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
18a0: 2a 20 44 61 74 61 62 61 73 65 20 62 65 69 6e 67  * Database being
18b0: 20 74 65 73 74 65 64 20 2a 2f 0a 20 20 69 6e 74   tested */.  int
18c0: 20 62 52 65 76 65 72 73 65 2c 0a 20 20 76 6f 69   bReverse,.  voi
18d0: 64 20 2a 70 4b 65 79 31 2c 20 69 6e 74 20 6e 4b  d *pKey1, int nK
18e0: 65 79 31 2c 20 0a 20 20 76 6f 69 64 20 2a 70 4b  ey1, .  void *pK
18f0: 65 79 32 2c 20 69 6e 74 20 6e 4b 65 79 32 2c 20  ey2, int nKey2, 
1900: 0a 20 20 69 6e 74 20 2a 70 52 63 0a 29 7b 0a 20  .  int *pRc.){. 
1910: 20 73 74 61 74 69 63 20 69 6e 74 20 6e 43 61 6c   static int nCal
1920: 6c 20 3d 20 30 3b 20 6e 43 61 6c 6c 2b 2b 3b 0a  l = 0; nCall++;.
1930: 20 20 69 66 28 20 2a 70 52 63 3d 3d 30 20 29 7b    if( *pRc==0 ){
1940: 0a 20 20 20 20 53 63 61 6e 52 65 73 75 6c 74 20  .    ScanResult 
1950: 72 65 73 31 3b 0a 20 20 20 20 53 63 61 6e 52 65  res1;.    ScanRe
1960: 73 75 6c 74 20 72 65 73 32 3b 0a 20 20 20 20 76  sult res2;.    v
1970: 6f 69 64 20 2a 70 52 65 73 31 20 3d 20 28 76 6f  oid *pRes1 = (vo
1980: 69 64 20 2a 29 26 72 65 73 31 3b 0a 20 20 20 20  id *)&res1;.    
1990: 76 6f 69 64 20 2a 70 52 65 73 32 20 3d 20 28 76  void *pRes2 = (v
19a0: 6f 69 64 20 2a 29 26 72 65 73 32 3b 0a 0a 20 20  oid *)&res2;..  
19b0: 20 20 6d 65 6d 73 65 74 28 26 72 65 73 31 2c 20    memset(&res1, 
19c0: 30 2c 20 73 69 7a 65 6f 66 28 53 63 61 6e 52 65  0, sizeof(ScanRe
19d0: 73 75 6c 74 29 29 3b 0a 20 20 20 20 6d 65 6d 73  sult));.    mems
19e0: 65 74 28 26 72 65 73 32 2c 20 30 2c 20 73 69 7a  et(&res2, 0, siz
19f0: 65 6f 66 28 53 63 61 6e 52 65 73 75 6c 74 29 29  eof(ScanResult))
1a00: 3b 0a 0a 20 20 20 20 72 65 73 31 2e 70 44 62 20  ;..    res1.pDb 
1a10: 3d 20 70 44 62 31 3b 0a 20 20 20 20 72 65 73 31  = pDb1;.    res1
1a20: 2e 6e 4b 65 79 31 20 3d 20 6e 4b 65 79 31 3b 20  .nKey1 = nKey1; 
1a30: 72 65 73 31 2e 70 4b 65 79 31 20 3d 20 70 4b 65  res1.pKey1 = pKe
1a40: 79 31 3b 0a 20 20 20 20 72 65 73 31 2e 6e 4b 65  y1;.    res1.nKe
1a50: 79 32 20 3d 20 6e 4b 65 79 32 3b 20 72 65 73 31  y2 = nKey2; res1
1a60: 2e 70 4b 65 79 32 20 3d 20 70 4b 65 79 32 3b 0a  .pKey2 = pKey2;.
1a70: 20 20 20 20 72 65 73 31 2e 62 52 65 76 65 72 73      res1.bRevers
1a80: 65 20 3d 20 62 52 65 76 65 72 73 65 3b 0a 20 20  e = bReverse;.  
1a90: 20 20 72 65 73 32 2e 70 44 62 20 3d 20 70 44 62    res2.pDb = pDb
1aa0: 32 3b 0a 20 20 20 20 72 65 73 32 2e 6e 4b 65 79  2;.    res2.nKey
1ab0: 31 20 3d 20 6e 4b 65 79 31 3b 20 72 65 73 32 2e  1 = nKey1; res2.
1ac0: 70 4b 65 79 31 20 3d 20 70 4b 65 79 31 3b 0a 20  pKey1 = pKey1;. 
1ad0: 20 20 20 72 65 73 32 2e 6e 4b 65 79 32 20 3d 20     res2.nKey2 = 
1ae0: 6e 4b 65 79 32 3b 20 72 65 73 32 2e 70 4b 65 79  nKey2; res2.pKey
1af0: 32 20 3d 20 70 4b 65 79 32 3b 0a 20 20 20 20 72  2 = pKey2;.    r
1b00: 65 73 32 2e 62 52 65 76 65 72 73 65 20 3d 20 62  es2.bReverse = b
1b10: 52 65 76 65 72 73 65 3b 0a 0a 20 20 20 20 74 64  Reverse;..    td
1b20: 62 5f 73 63 61 6e 28 70 44 62 31 2c 20 70 52 65  b_scan(pDb1, pRe
1b30: 73 31 2c 20 62 52 65 76 65 72 73 65 2c 20 70 4b  s1, bReverse, pK
1b40: 65 79 31 2c 20 6e 4b 65 79 31 2c 20 70 4b 65 79  ey1, nKey1, pKey
1b50: 32 2c 20 6e 4b 65 79 32 2c 20 73 63 61 6e 43 6f  2, nKey2, scanCo
1b60: 6d 70 61 72 65 43 62 29 3b 0a 69 66 28 20 74 65  mpareCb);.if( te
1b70: 73 74 5f 73 63 61 6e 5f 64 65 62 75 67 20 29 20  st_scan_debug ) 
1b80: 70 72 69 6e 74 66 28 22 5c 6e 5c 6e 5c 6e 22 29  printf("\n\n\n")
1b90: 3b 0a 20 20 20 20 74 64 62 5f 73 63 61 6e 28 70  ;.    tdb_scan(p
1ba0: 44 62 32 2c 20 70 52 65 73 32 2c 20 62 52 65 76  Db2, pRes2, bRev
1bb0: 65 72 73 65 2c 20 70 4b 65 79 31 2c 20 6e 4b 65  erse, pKey1, nKe
1bc0: 79 31 2c 20 70 4b 65 79 32 2c 20 6e 4b 65 79 32  y1, pKey2, nKey2
1bd0: 2c 20 73 63 61 6e 43 6f 6d 70 61 72 65 43 62 29  , scanCompareCb)
1be0: 3b 0a 69 66 28 20 74 65 73 74 5f 73 63 61 6e 5f  ;.if( test_scan_
1bf0: 64 65 62 75 67 20 29 20 70 72 69 6e 74 66 28 22  debug ) printf("
1c00: 5c 6e 5c 6e 5c 6e 22 29 3b 0a 0a 20 20 20 20 69  \n\n\n");..    i
1c10: 66 28 20 72 65 73 31 2e 6e 52 6f 77 21 3d 72 65  f( res1.nRow!=re
1c20: 73 32 2e 6e 52 6f 77 20 0a 20 20 20 20 20 7c 7c  s2.nRow .     ||
1c30: 20 72 65 73 31 2e 63 6b 73 75 6d 31 21 3d 72 65   res1.cksum1!=re
1c40: 73 32 2e 63 6b 73 75 6d 31 20 0a 20 20 20 20 20  s2.cksum1 .     
1c50: 7c 7c 20 72 65 73 31 2e 63 6b 73 75 6d 32 21 3d  || res1.cksum2!=
1c60: 72 65 73 32 2e 63 6b 73 75 6d 32 0a 20 20 20 20  res2.cksum2.    
1c70: 29 7b 0a 20 20 20 20 20 20 70 72 69 6e 74 66 28  ){.      printf(
1c80: 22 65 78 70 65 63 74 65 64 3a 20 25 64 20 25 58  "expected: %d %X
1c90: 20 25 58 5c 6e 22 2c 20 72 65 73 31 2e 6e 52 6f   %X\n", res1.nRo
1ca0: 77 2c 20 72 65 73 31 2e 63 6b 73 75 6d 31 2c 20  w, res1.cksum1, 
1cb0: 72 65 73 31 2e 63 6b 73 75 6d 32 29 3b 0a 20 20  res1.cksum2);.  
1cc0: 20 20 20 20 70 72 69 6e 74 66 28 22 67 6f 74 3a      printf("got:
1cd0: 20 20 20 20 20 20 25 64 20 25 58 20 25 58 5c 6e        %d %X %X\n
1ce0: 22 2c 20 72 65 73 32 2e 6e 52 6f 77 2c 20 72 65  ", res2.nRow, re
1cf0: 73 32 2e 63 6b 73 75 6d 31 2c 20 72 65 73 32 2e  s2.cksum1, res2.
1d00: 63 6b 73 75 6d 32 29 3b 0a 20 20 20 20 20 20 74  cksum2);.      t
1d10: 65 73 74 53 65 74 45 72 72 6f 72 28 31 29 3b 0a  estSetError(1);.
1d20: 20 20 20 20 20 20 2a 70 52 63 20 3d 20 31 3b 0a        *pRc = 1;.
1d30: 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a 0a 76 6f 69      }.  }.}..voi
1d40: 64 20 74 65 73 74 43 6c 6f 73 65 28 54 65 73 74  d testClose(Test
1d50: 44 62 20 2a 2a 70 70 44 62 29 7b 0a 20 20 74 64  Db **ppDb){.  td
1d60: 62 5f 63 6c 6f 73 65 28 2a 70 70 44 62 29 3b 0a  b_close(*ppDb);.
1d70: 20 20 2a 70 70 44 62 20 3d 20 30 3b 0a 7d 0a 0a    *ppDb = 0;.}..
1d80: 54 65 73 74 44 62 20 2a 74 65 73 74 4f 70 65 6e  TestDb *testOpen
1d90: 28 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 53 79  (const char *zSy
1da0: 73 74 65 6d 2c 20 69 6e 74 20 62 43 6c 65 61 72  stem, int bClear
1db0: 2c 20 69 6e 74 20 2a 70 52 63 29 7b 0a 20 20 54  , int *pRc){.  T
1dc0: 65 73 74 44 62 20 2a 70 44 62 20 3d 20 30 3b 0a  estDb *pDb = 0;.
1dd0: 20 20 69 66 28 20 2a 70 52 63 3d 3d 30 20 29 7b    if( *pRc==0 ){
1de0: 0a 20 20 20 20 69 6e 74 20 72 63 3b 0a 20 20 20  .    int rc;.   
1df0: 20 72 63 20 3d 20 74 64 62 5f 6f 70 65 6e 28 7a   rc = tdb_open(z
1e00: 53 79 73 74 65 6d 2c 20 30 2c 20 62 43 6c 65 61  System, 0, bClea
1e10: 72 2c 20 26 70 44 62 29 3b 0a 20 20 20 20 69 66  r, &pDb);.    if
1e20: 28 20 72 63 21 3d 30 20 29 7b 0a 20 20 20 20 20  ( rc!=0 ){.     
1e30: 20 74 65 73 74 53 65 74 45 72 72 6f 72 28 72 63   testSetError(rc
1e40: 29 3b 0a 20 20 20 20 20 20 2a 70 52 63 20 3d 20  );.      *pRc = 
1e50: 72 63 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20  rc;.    }.  }.  
1e60: 72 65 74 75 72 6e 20 70 44 62 3b 0a 7d 0a 0a 76  return pDb;.}..v
1e70: 6f 69 64 20 74 65 73 74 52 65 6f 70 65 6e 28 54  oid testReopen(T
1e80: 65 73 74 44 62 20 2a 2a 70 70 44 62 2c 20 69 6e  estDb **ppDb, in
1e90: 74 20 2a 70 52 63 29 7b 0a 20 20 69 66 28 20 2a  t *pRc){.  if( *
1ea0: 70 52 63 3d 3d 30 20 29 7b 0a 20 20 20 20 63 6f  pRc==0 ){.    co
1eb0: 6e 73 74 20 63 68 61 72 20 2a 7a 4c 69 62 3b 0a  nst char *zLib;.
1ec0: 20 20 20 20 7a 4c 69 62 20 3d 20 74 64 62 5f 6c      zLib = tdb_l
1ed0: 69 62 72 61 72 79 5f 6e 61 6d 65 28 2a 70 70 44  ibrary_name(*ppD
1ee0: 62 29 3b 0a 20 20 20 20 74 65 73 74 43 6c 6f 73  b);.    testClos
1ef0: 65 28 70 70 44 62 29 3b 0a 20 20 20 20 2a 70 52  e(ppDb);.    *pR
1f00: 63 20 3d 20 74 64 62 5f 6f 70 65 6e 28 7a 4c 69  c = tdb_open(zLi
1f10: 62 2c 20 30 2c 20 30 2c 20 70 70 44 62 29 3b 0a  b, 0, 0, ppDb);.
1f20: 20 20 7d 0a 7d 0a 0a 0a 23 69 66 20 30 20 2f 2a    }.}...#if 0 /*
1f30: 20 75 6e 75 73 65 64 20 2a 2f 0a 73 74 61 74 69   unused */.stati
1f40: 63 20 76 6f 69 64 20 74 65 73 74 53 79 73 74 65  c void testSyste
1f50: 6d 53 65 6c 65 63 74 28 63 6f 6e 73 74 20 63 68  mSelect(const ch
1f60: 61 72 20 2a 7a 53 79 73 2c 20 69 6e 74 20 2a 70  ar *zSys, int *p
1f70: 69 53 65 6c 2c 20 69 6e 74 20 2a 70 52 63 29 7b  iSel, int *pRc){
1f80: 0a 20 20 69 66 28 20 2a 70 52 63 3d 3d 30 20 29  .  if( *pRc==0 )
1f90: 7b 0a 20 20 20 20 73 74 72 75 63 74 20 53 79 73  {.    struct Sys
1fa0: 4e 61 6d 65 20 7b 20 63 6f 6e 73 74 20 63 68 61  Name { const cha
1fb0: 72 20 2a 7a 4e 61 6d 65 3b 20 7d 20 2a 61 4e 61  r *zName; } *aNa
1fc0: 6d 65 3b 0a 20 20 20 20 69 6e 74 20 6e 53 79 73  me;.    int nSys
1fd0: 3b 0a 20 20 20 20 69 6e 74 20 69 3b 0a 0a 20 20  ;.    int i;..  
1fe0: 20 20 66 6f 72 28 6e 53 79 73 3d 30 3b 20 74 64    for(nSys=0; td
1ff0: 62 5f 73 79 73 74 65 6d 5f 6e 61 6d 65 28 6e 53  b_system_name(nS
2000: 79 73 29 3b 20 6e 53 79 73 2b 2b 29 3b 0a 20 20  ys); nSys++);.  
2010: 20 20 61 4e 61 6d 65 20 3d 20 6d 61 6c 6c 6f 63    aName = malloc
2020: 28 73 69 7a 65 6f 66 28 73 74 72 75 63 74 20 53  (sizeof(struct S
2030: 79 73 4e 61 6d 65 29 20 2a 20 28 6e 53 79 73 2b  ysName) * (nSys+
2040: 31 29 29 3b 0a 20 20 20 20 66 6f 72 28 69 3d 30  1));.    for(i=0
2050: 3b 20 69 3c 3d 6e 53 79 73 3b 20 69 2b 2b 29 7b  ; i<=nSys; i++){
2060: 0a 20 20 20 20 20 20 61 4e 61 6d 65 5b 69 5d 2e  .      aName[i].
2070: 7a 4e 61 6d 65 20 3d 20 74 64 62 5f 73 79 73 74  zName = tdb_syst
2080: 65 6d 5f 6e 61 6d 65 28 69 29 3b 0a 20 20 20 20  em_name(i);.    
2090: 7d 0a 0a 20 20 20 20 2a 70 52 63 20 3d 20 74 65  }..    *pRc = te
20a0: 73 74 41 72 67 53 65 6c 65 63 74 28 61 4e 61 6d  stArgSelect(aNam
20b0: 65 2c 20 22 64 62 22 2c 20 7a 53 79 73 2c 20 70  e, "db", zSys, p
20c0: 69 53 65 6c 29 3b 0a 20 20 20 20 66 72 65 65 28  iSel);.    free(
20d0: 61 4e 61 6d 65 29 3b 0a 20 20 7d 0a 7d 0a 23 65  aName);.  }.}.#e
20e0: 6e 64 69 66 0a 0a 63 68 61 72 20 2a 74 65 73 74  ndif..char *test
20f0: 4d 61 6c 6c 6f 63 56 50 72 69 6e 74 66 28 63 6f  MallocVPrintf(co
2100: 6e 73 74 20 63 68 61 72 20 2a 7a 46 6f 72 6d 61  nst char *zForma
2110: 74 2c 20 76 61 5f 6c 69 73 74 20 61 70 29 7b 0a  t, va_list ap){.
2120: 20 20 69 6e 74 20 6e 42 79 74 65 3b 0a 20 20 76    int nByte;.  v
2130: 61 5f 6c 69 73 74 20 63 6f 70 79 3b 0a 20 20 63  a_list copy;.  c
2140: 68 61 72 20 2a 7a 52 65 74 3b 0a 0a 20 20 5f 5f  har *zRet;..  __
2150: 76 61 5f 63 6f 70 79 28 63 6f 70 79 2c 20 61 70  va_copy(copy, ap
2160: 29 3b 0a 20 20 6e 42 79 74 65 20 3d 20 76 73 6e  );.  nByte = vsn
2170: 70 72 69 6e 74 66 28 30 2c 20 30 2c 20 7a 46 6f  printf(0, 0, zFo
2180: 72 6d 61 74 2c 20 63 6f 70 79 29 3b 0a 20 20 76  rmat, copy);.  v
2190: 61 5f 65 6e 64 28 63 6f 70 79 29 3b 0a 0a 20 20  a_end(copy);..  
21a0: 61 73 73 65 72 74 28 20 6e 42 79 74 65 3e 3d 30  assert( nByte>=0
21b0: 20 29 3b 0a 20 20 7a 52 65 74 20 3d 20 28 63 68   );.  zRet = (ch
21c0: 61 72 20 2a 29 74 65 73 74 4d 61 6c 6c 6f 63 28  ar *)testMalloc(
21d0: 6e 42 79 74 65 2b 31 29 3b 0a 20 20 76 73 6e 70  nByte+1);.  vsnp
21e0: 72 69 6e 74 66 28 7a 52 65 74 2c 20 6e 42 79 74  rintf(zRet, nByt
21f0: 65 2b 31 2c 20 7a 46 6f 72 6d 61 74 2c 20 61 70  e+1, zFormat, ap
2200: 29 3b 0a 20 20 72 65 74 75 72 6e 20 7a 52 65 74  );.  return zRet
2210: 3b 0a 7d 0a 0a 63 68 61 72 20 2a 74 65 73 74 4d  ;.}..char *testM
2220: 61 6c 6c 6f 63 50 72 69 6e 74 66 28 63 6f 6e 73  allocPrintf(cons
2230: 74 20 63 68 61 72 20 2a 7a 46 6f 72 6d 61 74 2c  t char *zFormat,
2240: 20 2e 2e 2e 29 7b 0a 20 20 76 61 5f 6c 69 73 74   ...){.  va_list
2250: 20 61 70 3b 0a 20 20 63 68 61 72 20 2a 7a 52 65   ap;.  char *zRe
2260: 74 3b 0a 0a 20 20 76 61 5f 73 74 61 72 74 28 61  t;..  va_start(a
2270: 70 2c 20 7a 46 6f 72 6d 61 74 29 3b 0a 20 20 7a  p, zFormat);.  z
2280: 52 65 74 20 3d 20 74 65 73 74 4d 61 6c 6c 6f 63  Ret = testMalloc
2290: 56 50 72 69 6e 74 66 28 7a 46 6f 72 6d 61 74 2c  VPrintf(zFormat,
22a0: 20 61 70 29 3b 0a 20 20 76 61 5f 65 6e 64 28 61   ap);.  va_end(a
22b0: 70 29 3b 0a 0a 20 20 72 65 74 75 72 6e 20 7a 52  p);..  return zR
22c0: 65 74 3b 0a 7d 0a 0a 0a 2f 2a 0a 2a 2a 20 41 20  et;.}.../*.** A 
22d0: 77 72 61 70 70 65 72 20 61 72 6f 75 6e 64 20 6d  wrapper around m
22e0: 61 6c 6c 6f 63 28 33 29 2e 0a 2a 2a 0a 2a 2a 20  alloc(3)..**.** 
22f0: 54 68 69 73 20 66 75 6e 63 74 69 6f 6e 20 73 68  This function sh
2300: 6f 75 6c 64 20 62 65 20 75 73 65 64 20 66 6f 72  ould be used for
2310: 20 61 6c 6c 20 61 6c 6c 6f 63 61 74 69 6f 6e 73   all allocations
2320: 20 6d 61 64 65 20 62 79 20 74 65 73 74 20 70 72   made by test pr
2330: 6f 63 65 64 75 72 65 73 2e 0a 2a 2a 20 49 74 20  ocedures..** It 
2340: 68 61 73 20 74 68 65 20 66 6f 6c 6c 6f 77 69 6e  has the followin
2350: 67 20 70 72 6f 70 65 72 74 69 65 73 3a 0a 2a 2a  g properties:.**
2360: 0a 2a 2a 20 20 20 2a 20 54 65 73 74 20 63 6f 64  .**   * Test cod
2370: 65 20 6d 61 79 20 61 73 73 75 6d 65 20 74 68 61  e may assume tha
2380: 74 20 61 6c 6c 6f 63 61 74 69 6f 6e 73 20 6d 61  t allocations ma
2390: 79 20 6e 6f 74 20 66 61 69 6c 2e 0a 2a 2a 20 20  y not fail..**  
23a0: 20 2a 20 52 65 74 75 72 6e 65 64 20 6d 65 6d 6f   * Returned memo
23b0: 72 79 20 69 73 20 61 6c 77 61 79 73 20 7a 65 72  ry is always zer
23c0: 6f 65 64 2e 0a 2a 2a 0a 2a 2a 20 41 6c 6c 6f 63  oed..**.** Alloc
23d0: 61 74 69 6f 6e 73 20 6d 61 64 65 20 75 73 69 6e  ations made usin
23e0: 67 20 74 65 73 74 4d 61 6c 6c 6f 63 28 29 20 73  g testMalloc() s
23f0: 68 6f 75 6c 64 20 62 65 20 66 72 65 65 64 20 75  hould be freed u
2400: 73 69 6e 67 20 74 65 73 74 46 72 65 65 28 29 2e  sing testFree().
2410: 0a 2a 2f 0a 76 6f 69 64 20 2a 74 65 73 74 4d 61  .*/.void *testMa
2420: 6c 6c 6f 63 28 69 6e 74 20 6e 29 7b 0a 20 20 75  lloc(int n){.  u
2430: 38 20 2a 70 20 3d 20 28 75 38 2a 29 6d 61 6c 6c  8 *p = (u8*)mall
2440: 6f 63 28 6e 20 2b 20 38 29 3b 0a 20 20 6d 65 6d  oc(n + 8);.  mem
2450: 73 65 74 28 70 2c 20 30 2c 20 6e 2b 38 29 3b 0a  set(p, 0, n+8);.
2460: 20 20 2a 28 69 6e 74 2a 29 70 20 3d 20 6e 3b 0a    *(int*)p = n;.
2470: 20 20 72 65 74 75 72 6e 20 28 76 6f 69 64 2a 29    return (void*)
2480: 26 70 5b 38 5d 3b 0a 7d 0a 0a 76 6f 69 64 20 2a  &p[8];.}..void *
2490: 74 65 73 74 4d 61 6c 6c 6f 63 43 6f 70 79 28 76  testMallocCopy(v
24a0: 6f 69 64 20 2a 70 43 6f 70 79 2c 20 69 6e 74 20  oid *pCopy, int 
24b0: 6e 42 79 74 65 29 7b 0a 20 20 76 6f 69 64 20 2a  nByte){.  void *
24c0: 70 52 65 74 20 3d 20 74 65 73 74 4d 61 6c 6c 6f  pRet = testMallo
24d0: 63 28 6e 42 79 74 65 29 3b 0a 20 20 6d 65 6d 63  c(nByte);.  memc
24e0: 70 79 28 70 52 65 74 2c 20 70 43 6f 70 79 2c 20  py(pRet, pCopy, 
24f0: 6e 42 79 74 65 29 3b 0a 20 20 72 65 74 75 72 6e  nByte);.  return
2500: 20 70 52 65 74 3b 0a 7d 0a 0a 76 6f 69 64 20 2a   pRet;.}..void *
2510: 74 65 73 74 52 65 61 6c 6c 6f 63 28 76 6f 69 64  testRealloc(void
2520: 20 2a 70 74 72 2c 20 69 6e 74 20 6e 29 7b 0a 20   *ptr, int n){. 
2530: 20 69 66 28 20 70 74 72 20 29 7b 0a 20 20 20 20   if( ptr ){.    
2540: 75 38 20 2a 70 20 3d 20 28 75 38 2a 29 70 74 72  u8 *p = (u8*)ptr
2550: 20 2d 20 38 3b 0a 20 20 20 20 69 6e 74 20 6e 4f   - 8;.    int nO
2560: 72 69 67 20 3d 20 20 2a 28 69 6e 74 2a 29 70 3b  rig =  *(int*)p;
2570: 0a 20 20 20 20 70 20 3d 20 28 75 38 2a 29 72 65  .    p = (u8*)re
2580: 61 6c 6c 6f 63 28 70 2c 20 6e 2b 38 29 3b 0a 20  alloc(p, n+8);. 
2590: 20 20 20 69 66 28 20 6e 4f 72 69 67 3c 6e 20 29     if( nOrig<n )
25a0: 7b 0a 20 20 20 20 20 20 6d 65 6d 73 65 74 28 26  {.      memset(&
25b0: 70 5b 38 2b 6e 4f 72 69 67 5d 2c 20 30 2c 20 6e  p[8+nOrig], 0, n
25c0: 2d 6e 4f 72 69 67 29 3b 0a 20 20 20 20 7d 0a 20  -nOrig);.    }. 
25d0: 20 20 20 2a 28 69 6e 74 2a 29 70 20 3d 20 6e 3b     *(int*)p = n;
25e0: 0a 20 20 20 20 72 65 74 75 72 6e 20 28 76 6f 69  .    return (voi
25f0: 64 2a 29 26 70 5b 38 5d 3b 0a 20 20 7d 0a 20 20  d*)&p[8];.  }.  
2600: 72 65 74 75 72 6e 20 74 65 73 74 4d 61 6c 6c 6f  return testMallo
2610: 63 28 6e 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 46  c(n);.}../*.** F
2620: 72 65 65 20 61 6e 20 61 6c 6c 6f 63 61 74 69 6f  ree an allocatio
2630: 6e 20 6d 61 64 65 20 62 79 20 61 6e 20 65 61 72  n made by an ear
2640: 6c 69 65 72 20 63 61 6c 6c 20 74 6f 20 74 65 73  lier call to tes
2650: 74 4d 61 6c 6c 6f 63 28 29 2e 0a 2a 2f 0a 76 6f  tMalloc()..*/.vo
2660: 69 64 20 74 65 73 74 46 72 65 65 28 76 6f 69 64  id testFree(void
2670: 20 2a 70 74 72 29 7b 0a 20 20 69 66 28 20 70 74   *ptr){.  if( pt
2680: 72 20 29 7b 0a 20 20 20 20 75 38 20 2a 70 20 3d  r ){.    u8 *p =
2690: 20 28 75 38 2a 29 70 74 72 20 2d 20 38 3b 0a 20   (u8*)ptr - 8;. 
26a0: 20 20 20 6d 65 6d 73 65 74 28 70 2c 20 30 78 35     memset(p, 0x5
26b0: 35 2c 20 2a 28 69 6e 74 2a 29 70 20 2b 20 38 29  5, *(int*)p + 8)
26c0: 3b 0a 20 20 20 20 66 72 65 65 28 70 29 3b 0a 20  ;.    free(p);. 
26d0: 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 53 74 72 69   }.}../*.** Stri
26e0: 6e 67 20 7a 50 61 74 74 65 72 6e 20 63 6f 6e 74  ng zPattern cont
26f0: 61 69 6e 73 20 61 20 67 6c 6f 62 20 70 61 74 74  ains a glob patt
2700: 65 72 6e 2e 20 52 65 74 75 72 6e 20 74 72 75 65  ern. Return true
2710: 20 69 66 20 7a 53 74 72 20 6d 61 74 63 68 65 73   if zStr matches
2720: 20 0a 2a 2a 20 74 68 65 20 70 61 74 74 65 72 6e   .** the pattern
2730: 2c 20 6f 72 20 66 61 6c 73 65 20 69 66 20 69 74  , or false if it
2740: 20 64 6f 65 73 20 6e 6f 74 2e 0a 2a 2f 0a 69 6e   does not..*/.in
2750: 74 20 74 65 73 74 47 6c 6f 62 4d 61 74 63 68 28  t testGlobMatch(
2760: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 50 61 74  const char *zPat
2770: 74 65 72 6e 2c 20 63 6f 6e 73 74 20 63 68 61 72  tern, const char
2780: 20 2a 7a 53 74 72 29 7b 0a 20 20 69 6e 74 20 69   *zStr){.  int i
2790: 20 3d 20 30 3b 0a 20 20 69 6e 74 20 6a 20 3d 20   = 0;.  int j = 
27a0: 30 3b 0a 0a 20 20 77 68 69 6c 65 28 20 7a 50 61  0;..  while( zPa
27b0: 74 74 65 72 6e 5b 69 5d 20 29 7b 0a 20 20 20 20  ttern[i] ){.    
27c0: 63 68 61 72 20 70 20 3d 20 7a 50 61 74 74 65 72  char p = zPatter
27d0: 6e 5b 69 5d 3b 0a 0a 20 20 20 20 69 66 28 20 70  n[i];..    if( p
27e0: 3d 3d 27 2a 27 20 7c 7c 20 70 3d 3d 27 25 27 20  =='*' || p=='%' 
27f0: 29 7b 0a 20 20 20 20 20 20 64 6f 20 7b 0a 20 20  ){.      do {.  
2800: 20 20 20 20 20 20 69 66 28 20 74 65 73 74 47 6c        if( testGl
2810: 6f 62 4d 61 74 63 68 28 26 7a 50 61 74 74 65 72  obMatch(&zPatter
2820: 6e 5b 69 2b 31 5d 2c 20 26 7a 53 74 72 5b 6a 5d  n[i+1], &zStr[j]
2830: 29 20 29 20 72 65 74 75 72 6e 20 31 3b 0a 20 20  ) ) return 1;.  
2840: 20 20 20 20 7d 77 68 69 6c 65 28 20 7a 53 74 72      }while( zStr
2850: 5b 6a 2b 2b 5d 20 29 3b 0a 20 20 20 20 20 20 72  [j++] );.      r
2860: 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 7d 0a 0a  eturn 0;.    }..
2870: 20 20 20 20 69 66 28 20 7a 53 74 72 5b 6a 5d 3d      if( zStr[j]=
2880: 3d 30 20 7c 7c 20 28 70 21 3d 27 3f 27 20 26 26  =0 || (p!='?' &&
2890: 20 70 21 3d 7a 53 74 72 5b 6a 5d 29 20 29 7b 0a   p!=zStr[j]) ){.
28a0: 20 20 20 20 20 20 2f 2a 20 4d 61 74 63 68 20 66        /* Match f
28b0: 61 69 6c 65 64 2e 20 2a 2f 0a 20 20 20 20 20 20  ailed. */.      
28c0: 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 7d 0a  return 0;.    }.
28d0: 0a 20 20 20 20 6a 2b 2b 3b 0a 20 20 20 20 69 2b  .    j++;.    i+
28e0: 2b 3b 0a 20 20 7d 0a 0a 20 20 72 65 74 75 72 6e  +;.  }..  return
28f0: 20 28 7a 50 61 74 74 65 72 6e 5b 69 5d 3d 3d 30   (zPattern[i]==0
2900: 20 26 26 20 7a 53 74 72 5b 6a 5d 3d 3d 30 29 3b   && zStr[j]==0);
2910: 0a 7d 0a 0a 2f 2a 20 0a 2a 2a 20 45 6e 64 20 6f  .}../* .** End o
2920: 66 20 74 65 73 74 20 75 74 69 6c 69 74 69 65 73  f test utilities
2930: 20 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a   .**************
2940: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
2950: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
2960: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
2970: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2f 0a 0a 69  ************/..i
2980: 6e 74 20 64 6f 5f 74 65 73 74 28 69 6e 74 20 6e  nt do_test(int n
2990: 41 72 67 2c 20 63 68 61 72 20 2a 2a 61 7a 41 72  Arg, char **azAr
29a0: 67 29 7b 0a 20 20 69 6e 74 20 6a 3b 0a 20 20 69  g){.  int j;.  i
29b0: 6e 74 20 72 63 3b 0a 20 20 69 6e 74 20 6e 46 61  nt rc;.  int nFa
29c0: 69 6c 20 3d 20 30 3b 0a 20 20 63 6f 6e 73 74 20  il = 0;.  const 
29d0: 63 68 61 72 20 2a 7a 50 61 74 74 65 72 6e 20 3d  char *zPattern =
29e0: 20 30 3b 0a 0a 20 20 69 66 28 20 6e 41 72 67 3e   0;..  if( nArg>
29f0: 31 20 29 7b 0a 20 20 20 20 74 65 73 74 50 72 69  1 ){.    testPri
2a00: 6e 74 45 72 72 6f 72 28 22 55 73 61 67 65 3a 20  ntError("Usage: 
2a10: 74 65 73 74 20 3f 50 41 54 54 45 52 4e 3f 5c 6e  test ?PATTERN?\n
2a20: 22 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20 31  ");.    return 1
2a30: 3b 0a 20 20 7d 0a 20 20 69 66 28 20 6e 41 72 67  ;.  }.  if( nArg
2a40: 3d 3d 31 20 29 7b 0a 20 20 20 20 7a 50 61 74 74  ==1 ){.    zPatt
2a50: 65 72 6e 20 3d 20 61 7a 41 72 67 5b 30 5d 3b 0a  ern = azArg[0];.
2a60: 20 20 7d 0a 0a 20 20 66 6f 72 28 6a 3d 30 3b 20    }..  for(j=0; 
2a70: 74 64 62 5f 73 79 73 74 65 6d 5f 6e 61 6d 65 28  tdb_system_name(
2a80: 6a 29 3b 20 6a 2b 2b 29 7b 0a 20 20 20 20 72 63  j); j++){.    rc
2a90: 20 3d 20 30 3b 0a 0a 20 20 20 20 74 65 73 74 5f   = 0;..    test_
2aa0: 64 61 74 61 5f 31 28 74 64 62 5f 73 79 73 74 65  data_1(tdb_syste
2ab0: 6d 5f 6e 61 6d 65 28 6a 29 2c 20 7a 50 61 74 74  m_name(j), zPatt
2ac0: 65 72 6e 2c 20 26 72 63 29 3b 0a 20 20 20 20 74  ern, &rc);.    t
2ad0: 65 73 74 5f 64 61 74 61 5f 32 28 74 64 62 5f 73  est_data_2(tdb_s
2ae0: 79 73 74 65 6d 5f 6e 61 6d 65 28 6a 29 2c 20 7a  ystem_name(j), z
2af0: 50 61 74 74 65 72 6e 2c 20 26 72 63 29 3b 0a 20  Pattern, &rc);. 
2b00: 20 20 20 74 65 73 74 5f 64 61 74 61 5f 33 28 74     test_data_3(t
2b10: 64 62 5f 73 79 73 74 65 6d 5f 6e 61 6d 65 28 6a  db_system_name(j
2b20: 29 2c 20 7a 50 61 74 74 65 72 6e 2c 20 26 72 63  ), zPattern, &rc
2b30: 29 3b 0a 20 20 20 20 74 65 73 74 5f 64 61 74 61  );.    test_data
2b40: 5f 34 28 74 64 62 5f 73 79 73 74 65 6d 5f 6e 61  _4(tdb_system_na
2b50: 6d 65 28 6a 29 2c 20 7a 50 61 74 74 65 72 6e 2c  me(j), zPattern,
2b60: 20 26 72 63 29 3b 0a 20 20 20 20 74 65 73 74 5f   &rc);.    test_
2b70: 72 6f 6c 6c 62 61 63 6b 28 74 64 62 5f 73 79 73  rollback(tdb_sys
2b80: 74 65 6d 5f 6e 61 6d 65 28 6a 29 2c 20 7a 50 61  tem_name(j), zPa
2b90: 74 74 65 72 6e 2c 20 26 72 63 29 3b 0a 20 20 20  ttern, &rc);.   
2ba0: 20 74 65 73 74 5f 6d 63 28 74 64 62 5f 73 79 73   test_mc(tdb_sys
2bb0: 74 65 6d 5f 6e 61 6d 65 28 6a 29 2c 20 7a 50 61  tem_name(j), zPa
2bc0: 74 74 65 72 6e 2c 20 26 72 63 29 3b 0a 20 20 20  ttern, &rc);.   
2bd0: 20 74 65 73 74 5f 6d 74 28 74 64 62 5f 73 79 73   test_mt(tdb_sys
2be0: 74 65 6d 5f 6e 61 6d 65 28 6a 29 2c 20 7a 50 61  tem_name(j), zPa
2bf0: 74 74 65 72 6e 2c 20 26 72 63 29 3b 0a 0a 20 20  ttern, &rc);..  
2c00: 20 20 69 66 28 20 72 63 20 29 20 6e 46 61 69 6c    if( rc ) nFail
2c10: 2b 2b 3b 0a 20 20 7d 0a 0a 20 20 72 63 20 3d 20  ++;.  }..  rc = 
2c20: 30 3b 0a 20 20 74 65 73 74 5f 6f 6f 6d 28 7a 50  0;.  test_oom(zP
2c30: 61 74 74 65 72 6e 2c 20 26 72 63 29 3b 0a 20 20  attern, &rc);.  
2c40: 69 66 28 20 72 63 20 29 20 6e 46 61 69 6c 2b 2b  if( rc ) nFail++
2c50: 3b 0a 0a 20 20 72 63 20 3d 20 30 3b 0a 20 20 74  ;..  rc = 0;.  t
2c60: 65 73 74 5f 61 70 69 28 7a 50 61 74 74 65 72 6e  est_api(zPattern
2c70: 2c 20 26 72 63 29 3b 0a 20 20 69 66 28 20 72 63  , &rc);.  if( rc
2c80: 20 29 20 6e 46 61 69 6c 2b 2b 3b 0a 0a 20 20 72   ) nFail++;..  r
2c90: 63 20 3d 20 30 3b 0a 20 20 64 6f 5f 63 72 61 73  c = 0;.  do_cras
2ca0: 68 5f 74 65 73 74 28 7a 50 61 74 74 65 72 6e 2c  h_test(zPattern,
2cb0: 20 26 72 63 29 3b 0a 20 20 69 66 28 20 72 63 20   &rc);.  if( rc 
2cc0: 29 20 6e 46 61 69 6c 2b 2b 3b 0a 0a 20 20 72 63  ) nFail++;..  rc
2cd0: 20 3d 20 30 3b 0a 20 20 64 6f 5f 77 72 69 74 65   = 0;.  do_write
2ce0: 72 5f 63 72 61 73 68 5f 74 65 73 74 28 7a 50 61  r_crash_test(zPa
2cf0: 74 74 65 72 6e 2c 20 26 72 63 29 3b 0a 20 20 69  ttern, &rc);.  i
2d00: 66 28 20 72 63 20 29 20 6e 46 61 69 6c 2b 2b 3b  f( rc ) nFail++;
2d10: 0a 0a 20 20 72 65 74 75 72 6e 20 28 6e 46 61 69  ..  return (nFai
2d20: 6c 21 3d 30 29 3b 0a 7d 0a 0a 73 74 61 74 69 63  l!=0);.}..static
2d30: 20 6c 73 6d 5f 64 62 20 2a 63 6f 6e 66 69 67 75   lsm_db *configu
2d40: 72 65 5f 6c 73 6d 5f 64 62 28 54 65 73 74 44 62  re_lsm_db(TestDb
2d50: 20 2a 70 44 62 29 7b 0a 20 20 6c 73 6d 5f 64 62   *pDb){.  lsm_db
2d60: 20 2a 70 4c 73 6d 3b 0a 20 20 70 4c 73 6d 20 3d   *pLsm;.  pLsm =
2d70: 20 74 64 62 5f 6c 73 6d 28 70 44 62 29 3b 0a 20   tdb_lsm(pDb);. 
2d80: 20 69 66 28 20 70 4c 73 6d 20 29 7b 0a 20 20 20   if( pLsm ){.   
2d90: 20 74 64 62 5f 6c 73 6d 5f 63 6f 6e 66 69 67 5f   tdb_lsm_config_
2da0: 73 74 72 28 70 44 62 2c 20 22 6d 6d 61 70 3d 31  str(pDb, "mmap=1
2db0: 20 61 75 74 6f 77 6f 72 6b 3d 31 20 61 75 74 6f   autowork=1 auto
2dc0: 6d 65 72 67 65 3d 34 20 77 6f 72 6b 65 72 5f 61  merge=4 worker_a
2dd0: 75 74 6f 6d 65 72 67 65 3d 34 22 29 3b 0a 20 20  utomerge=4");.  
2de0: 7d 0a 20 20 72 65 74 75 72 6e 20 70 4c 73 6d 3b  }.  return pLsm;
2df0: 0a 7d 0a 0a 74 79 70 65 64 65 66 20 73 74 72 75  .}..typedef stru
2e00: 63 74 20 57 72 69 74 65 48 6f 6f 6b 45 76 65 6e  ct WriteHookEven
2e10: 74 20 57 72 69 74 65 48 6f 6f 6b 45 76 65 6e 74  t WriteHookEvent
2e20: 3b 0a 73 74 72 75 63 74 20 57 72 69 74 65 48 6f  ;.struct WriteHo
2e30: 6f 6b 45 76 65 6e 74 20 7b 0a 20 20 69 36 34 20  okEvent {.  i64 
2e40: 69 4f 66 66 3b 0a 20 20 69 6e 74 20 6e 44 61 74  iOff;.  int nDat
2e50: 61 3b 0a 20 20 69 6e 74 20 6e 55 73 3b 0a 7d 3b  a;.  int nUs;.};
2e60: 0a 57 72 69 74 65 48 6f 6f 6b 45 76 65 6e 74 20  .WriteHookEvent 
2e70: 70 72 65 76 20 3d 20 7b 30 2c 20 30 2c 20 30 7d  prev = {0, 0, 0}
2e80: 3b 0a 0a 73 74 61 74 69 63 20 76 6f 69 64 20 66  ;..static void f
2e90: 6c 75 73 68 50 72 65 76 28 46 49 4c 45 20 2a 70  lushPrev(FILE *p
2ea0: 4f 75 74 29 7b 0a 20 20 69 66 28 20 70 72 65 76  Out){.  if( prev
2eb0: 2e 6e 44 61 74 61 20 29 7b 0a 20 20 20 20 66 70  .nData ){.    fp
2ec0: 72 69 6e 74 66 28 70 4f 75 74 2c 20 22 77 20 25  rintf(pOut, "w %
2ed0: 73 20 25 6c 6c 64 20 25 64 20 25 64 5c 6e 22 2c  s %lld %d %d\n",
2ee0: 20 22 64 22 2c 20 70 72 65 76 2e 69 4f 66 66 2c   "d", prev.iOff,
2ef0: 20 70 72 65 76 2e 6e 44 61 74 61 2c 20 70 72 65   prev.nData, pre
2f00: 76 2e 6e 55 73 29 3b 0a 20 20 20 20 70 72 65 76  v.nUs);.    prev
2f10: 2e 6e 44 61 74 61 20 3d 20 30 3b 0a 20 20 7d 0a  .nData = 0;.  }.
2f20: 7d 0a 0a 23 69 66 20 30 20 2f 2a 20 75 6e 75 73  }..#if 0 /* unus
2f30: 65 64 20 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69  ed */.static voi
2f40: 64 20 64 6f 5f 73 70 65 65 64 5f 77 72 69 74 65  d do_speed_write
2f50: 5f 68 6f 6f 6b 32 28 0a 20 20 76 6f 69 64 20 2a  _hook2(.  void *
2f60: 70 43 74 78 2c 0a 20 20 69 6e 74 20 62 4c 6f 67  pCtx,.  int bLog
2f70: 2c 0a 20 20 69 36 34 20 69 4f 66 66 2c 0a 20 20  ,.  i64 iOff,.  
2f80: 69 6e 74 20 6e 44 61 74 61 2c 0a 20 20 69 6e 74  int nData,.  int
2f90: 20 6e 55 73 0a 29 7b 0a 20 20 46 49 4c 45 20 2a   nUs.){.  FILE *
2fa0: 70 4f 75 74 20 3d 20 28 46 49 4c 45 20 2a 29 70  pOut = (FILE *)p
2fb0: 43 74 78 3b 0a 20 20 69 66 28 20 62 4c 6f 67 20  Ctx;.  if( bLog 
2fc0: 29 20 72 65 74 75 72 6e 3b 0a 0a 20 20 69 66 28  ) return;..  if(
2fd0: 20 70 72 65 76 2e 6e 44 61 74 61 20 26 26 20 6e   prev.nData && n
2fe0: 44 61 74 61 20 26 26 20 69 4f 66 66 3d 3d 70 72  Data && iOff==pr
2ff0: 65 76 2e 69 4f 66 66 2b 70 72 65 76 2e 6e 44 61  ev.iOff+prev.nDa
3000: 74 61 20 29 7b 0a 20 20 20 20 70 72 65 76 2e 6e  ta ){.    prev.n
3010: 44 61 74 61 20 2b 3d 20 6e 44 61 74 61 3b 0a 20  Data += nData;. 
3020: 20 20 20 70 72 65 76 2e 6e 55 73 20 2b 3d 20 6e     prev.nUs += n
3030: 55 73 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20  Us;.  }else{.   
3040: 20 66 6c 75 73 68 50 72 65 76 28 70 4f 75 74 29   flushPrev(pOut)
3050: 3b 0a 20 20 20 20 69 66 28 20 6e 44 61 74 61 3d  ;.    if( nData=
3060: 3d 30 20 29 7b 0a 20 20 20 20 20 20 66 70 72 69  =0 ){.      fpri
3070: 6e 74 66 28 70 4f 75 74 2c 20 22 73 20 25 73 20  ntf(pOut, "s %s 
3080: 30 20 30 20 25 64 5c 6e 22 2c 20 28 62 4c 6f 67  0 0 %d\n", (bLog
3090: 20 3f 20 22 6c 22 20 3a 20 22 64 22 29 2c 20 6e   ? "l" : "d"), n
30a0: 55 73 29 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a  Us);.    }else{.
30b0: 20 20 20 20 20 20 70 72 65 76 2e 69 4f 66 66 20        prev.iOff 
30c0: 3d 20 69 4f 66 66 3b 0a 20 20 20 20 20 20 70 72  = iOff;.      pr
30d0: 65 76 2e 6e 44 61 74 61 20 3d 20 6e 44 61 74 61  ev.nData = nData
30e0: 3b 0a 20 20 20 20 20 20 70 72 65 76 2e 6e 55 73  ;.      prev.nUs
30f0: 20 3d 20 6e 55 73 3b 0a 20 20 20 20 7d 0a 20 20   = nUs;.    }.  
3100: 7d 0a 7d 0a 23 65 6e 64 69 66 0a 0a 23 64 65 66  }.}.#endif..#def
3110: 69 6e 65 20 53 54 5f 52 45 50 45 41 54 20 20 30  ine ST_REPEAT  0
3120: 0a 23 64 65 66 69 6e 65 20 53 54 5f 57 52 49 54  .#define ST_WRIT
3130: 45 20 20 20 31 0a 23 64 65 66 69 6e 65 20 53 54  E   1.#define ST
3140: 5f 50 41 55 53 45 20 20 20 32 0a 23 64 65 66 69  _PAUSE   2.#defi
3150: 6e 65 20 53 54 5f 46 45 54 43 48 20 20 20 33 0a  ne ST_FETCH   3.
3160: 23 64 65 66 69 6e 65 20 53 54 5f 53 43 41 4e 20  #define ST_SCAN 
3170: 20 20 20 34 0a 23 64 65 66 69 6e 65 20 53 54 5f     4.#define ST_
3180: 4e 53 43 41 4e 20 20 20 35 0a 23 64 65 66 69 6e  NSCAN   5.#defin
3190: 65 20 53 54 5f 4b 45 59 53 49 5a 45 20 36 0a 23  e ST_KEYSIZE 6.#
31a0: 64 65 66 69 6e 65 20 53 54 5f 56 41 4c 53 49 5a  define ST_VALSIZ
31b0: 45 20 37 0a 23 64 65 66 69 6e 65 20 53 54 5f 54  E 7.#define ST_T
31c0: 52 41 4e 53 20 20 20 38 0a 0a 0a 73 74 61 74 69  RANS   8...stati
31d0: 63 20 76 6f 69 64 20 70 72 69 6e 74 5f 73 70 65  c void print_spe
31e0: 65 64 5f 74 65 73 74 5f 68 65 6c 70 28 29 7b 0a  ed_test_help(){.
31f0: 20 20 70 72 69 6e 74 66 28 0a 22 5c 6e 22 0a 22    printf(."\n"."
3200: 52 65 70 65 61 74 20 74 68 65 20 66 6f 6c 6c 6f  Repeat the follo
3210: 77 69 6e 67 20 24 72 65 70 65 61 74 20 74 69 6d  wing $repeat tim
3220: 65 73 3a 5c 6e 22 0a 22 20 20 31 2e 20 49 6e 73  es:\n"."  1. Ins
3230: 65 72 74 20 24 77 72 69 74 65 20 6b 65 79 2d 76  ert $write key-v
3240: 61 6c 75 65 20 70 61 69 72 73 2e 20 4f 6e 65 20  alue pairs. One 
3250: 74 72 61 6e 73 61 63 74 69 6f 6e 20 66 6f 72 20  transaction for 
3260: 65 61 63 68 20 77 72 69 74 65 20 6f 70 2e 5c 6e  each write op.\n
3270: 22 0a 22 20 20 32 2e 20 50 61 75 73 65 20 66 6f  "."  2. Pause fo
3280: 72 20 24 70 61 75 73 65 20 6d 73 2e 5c 6e 22 0a  r $pause ms.\n".
3290: 22 20 20 33 2e 20 50 65 72 66 6f 72 6d 20 24 66  "  3. Perform $f
32a0: 65 74 63 68 20 71 75 65 72 69 65 73 20 6f 6e 20  etch queries on 
32b0: 74 68 65 20 64 61 74 61 62 61 73 65 2e 5c 6e 22  the database.\n"
32c0: 0a 22 5c 6e 22 0a 22 20 20 4b 65 79 73 20 61 72  ."\n"."  Keys ar
32d0: 65 20 24 6b 65 79 73 69 7a 65 20 62 79 74 65 73  e $keysize bytes
32e0: 20 69 6e 20 73 69 7a 65 2e 20 56 61 6c 75 65 73   in size. Values
32f0: 20 61 72 65 20 24 76 61 6c 73 69 7a 65 20 62 79   are $valsize by
3300: 74 65 73 20 69 6e 20 73 69 7a 65 5c 6e 22 0a 22  tes in size\n"."
3310: 20 20 42 6f 74 68 20 6b 65 79 73 20 61 6e 64 20    Both keys and 
3320: 76 61 6c 75 65 73 20 61 72 65 20 70 73 65 75 64  values are pseud
3330: 6f 2d 72 61 6e 64 6f 6d 6c 79 20 67 65 6e 65 72  o-randomly gener
3340: 61 74 65 64 5c 6e 22 0a 22 5c 6e 22 0a 22 4f 70  ated\n"."\n"."Op
3350: 74 69 6f 6e 73 20 61 72 65 3a 5c 6e 22 0a 22 20  tions are:\n"." 
3360: 20 2d 72 65 70 65 61 74 20 20 24 72 65 70 65 61   -repeat  $repea
3370: 74 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  t               
3380: 20 20 28 64 65 66 61 75 6c 74 20 76 61 6c 75 65    (default value
3390: 20 31 30 29 5c 6e 22 0a 22 20 20 2d 77 72 69 74   10)\n"."  -writ
33a0: 65 20 20 20 24 77 72 69 74 65 20 20 20 20 20 20  e   $write      
33b0: 20 20 20 20 20 20 20 20 20 20 20 20 28 64 65 66              (def
33c0: 61 75 6c 74 20 76 61 6c 75 65 20 31 30 30 30 30  ault value 10000
33d0: 29 5c 6e 22 0a 22 20 20 2d 70 61 75 73 65 20 20  )\n"."  -pause  
33e0: 20 24 70 61 75 73 65 20 20 20 20 20 20 20 20 20   $pause         
33f0: 20 20 20 20 20 20 20 20 20 28 64 65 66 61 75 6c           (defaul
3400: 74 20 76 61 6c 75 65 20 30 29 5c 6e 22 0a 22 20  t value 0)\n"." 
3410: 20 2d 66 65 74 63 68 20 20 20 24 66 65 74 63 68   -fetch   $fetch
3420: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3430: 20 20 28 64 65 66 61 75 6c 74 20 76 61 6c 75 65    (default value
3440: 20 30 29 5c 6e 22 0a 22 20 20 2d 6b 65 79 73 69   0)\n"."  -keysi
3450: 7a 65 20 24 6b 65 79 73 69 7a 65 20 20 20 20 20  ze $keysize     
3460: 20 20 20 20 20 20 20 20 20 20 20 28 64 65 66 61             (defa
3470: 75 6c 74 20 76 61 6c 75 65 20 31 32 29 5c 6e 22  ult value 12)\n"
3480: 0a 22 20 20 2d 76 61 6c 73 69 7a 65 20 24 76 61  ."  -valsize $va
3490: 6c 73 69 7a 65 20 20 20 20 20 20 20 20 20 20 20  lsize           
34a0: 20 20 20 20 20 28 64 65 66 61 75 6c 74 20 76 61       (default va
34b0: 6c 75 65 20 31 30 30 29 5c 6e 22 0a 22 20 20 2d  lue 100)\n"."  -
34c0: 73 79 73 74 65 6d 20 20 24 73 79 73 74 65 6d 20  system  $system 
34d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
34e0: 28 64 65 66 61 75 6c 74 20 76 61 6c 75 65 20 5c  (default value \
34f0: 22 6c 73 6d 5c 22 29 5c 6e 22 0a 22 20 20 2d 74  "lsm\")\n"."  -t
3500: 72 61 6e 73 20 20 20 24 74 72 61 6e 73 20 20 20  rans   $trans   
3510: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 28                 (
3520: 64 65 66 61 75 6c 74 20 76 61 6c 75 65 20 30 29  default value 0)
3530: 5c 6e 22 0a 22 5c 6e 22 0a 29 3b 0a 7d 0a 0a 69  \n"."\n".);.}..i
3540: 6e 74 20 64 6f 5f 73 70 65 65 64 5f 74 65 73 74  nt do_speed_test
3550: 32 28 69 6e 74 20 6e 41 72 67 2c 20 63 68 61 72  2(int nArg, char
3560: 20 2a 2a 61 7a 41 72 67 29 7b 0a 20 20 73 74 72   **azArg){.  str
3570: 75 63 74 20 4f 70 74 69 6f 6e 20 7b 0a 20 20 20  uct Option {.   
3580: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 4f 70   const char *zOp
3590: 74 3b 0a 20 20 20 20 69 6e 74 20 65 56 61 6c 3b  t;.    int eVal;
35a0: 0a 20 20 20 20 69 6e 74 20 69 44 65 66 61 75 6c  .    int iDefaul
35b0: 74 3b 0a 20 20 7d 20 61 4f 70 74 5b 5d 20 3d 20  t;.  } aOpt[] = 
35c0: 7b 0a 20 20 20 20 7b 20 22 2d 72 65 70 65 61 74  {.    { "-repeat
35d0: 22 2c 20 20 53 54 5f 52 45 50 45 41 54 2c 20 20  ",  ST_REPEAT,  
35e0: 20 20 31 30 7d 2c 0a 20 20 20 20 7b 20 22 2d 77    10},.    { "-w
35f0: 72 69 74 65 22 2c 20 20 20 53 54 5f 57 52 49 54  rite",   ST_WRIT
3600: 45 2c 20 20 31 30 30 30 30 7d 2c 0a 20 20 20 20  E,  10000},.    
3610: 7b 20 22 2d 70 61 75 73 65 22 2c 20 20 20 53 54  { "-pause",   ST
3620: 5f 50 41 55 53 45 2c 20 20 20 20 20 20 30 7d 2c  _PAUSE,      0},
3630: 0a 20 20 20 20 7b 20 22 2d 66 65 74 63 68 22 2c  .    { "-fetch",
3640: 20 20 20 53 54 5f 46 45 54 43 48 2c 20 20 20 20     ST_FETCH,    
3650: 20 20 30 7d 2c 0a 20 20 20 20 7b 20 22 2d 73 63    0},.    { "-sc
3660: 61 6e 22 2c 20 20 20 20 53 54 5f 53 43 41 4e 2c  an",    ST_SCAN,
3670: 20 20 20 20 20 20 20 30 7d 2c 0a 20 20 20 20 7b         0},.    {
3680: 20 22 2d 6e 73 63 61 6e 22 2c 20 20 20 53 54 5f   "-nscan",   ST_
3690: 4e 53 43 41 4e 2c 20 20 20 20 20 20 30 7d 2c 0a  NSCAN,      0},.
36a0: 20 20 20 20 7b 20 22 2d 6b 65 79 73 69 7a 65 22      { "-keysize"
36b0: 2c 20 53 54 5f 4b 45 59 53 49 5a 45 2c 20 20 20  , ST_KEYSIZE,   
36c0: 31 32 7d 2c 0a 20 20 20 20 7b 20 22 2d 76 61 6c  12},.    { "-val
36d0: 73 69 7a 65 22 2c 20 53 54 5f 56 41 4c 53 49 5a  size", ST_VALSIZ
36e0: 45 2c 20 20 31 30 30 7d 2c 0a 20 20 20 20 7b 20  E,  100},.    { 
36f0: 22 2d 74 72 61 6e 73 22 2c 20 20 20 53 54 5f 54  "-trans",   ST_T
3700: 52 41 4e 53 2c 20 20 20 20 20 20 30 7d 2c 0a 20  RANS,      0},. 
3710: 20 20 20 7b 20 22 2d 73 79 73 74 65 6d 22 2c 20     { "-system", 
3720: 20 2d 31 2c 20 20 20 20 20 20 20 20 20 20 20 20   -1,            
3730: 30 7d 2c 0a 20 20 20 20 7b 20 22 68 65 6c 70 22  0},.    { "help"
3740: 2c 20 20 20 20 20 2d 32 2c 20 20 20 20 20 20 20  ,     -2,       
3750: 20 20 20 20 20 30 7d 2c 0a 20 20 20 20 7b 30 2c       0},.    {0,
3760: 20 30 2c 20 30 7d 0a 20 20 7d 3b 0a 20 20 69 6e   0, 0}.  };.  in
3770: 74 20 69 3b 0a 20 20 69 6e 74 20 61 50 61 72 61  t i;.  int aPara
3780: 6d 5b 39 5d 3b 0a 20 20 69 6e 74 20 72 63 20 3d  m[9];.  int rc =
3790: 20 30 3b 0a 20 20 69 6e 74 20 62 52 65 61 64 6f   0;.  int bReado
37a0: 6e 6c 79 20 3d 20 30 3b 0a 20 20 69 6e 74 20 6e  nly = 0;.  int n
37b0: 43 6f 6e 74 65 6e 74 20 3d 20 30 3b 0a 0a 20 20  Content = 0;..  
37c0: 54 65 73 74 44 62 20 2a 70 44 62 3b 0a 20 20 44  TestDb *pDb;.  D
37d0: 61 74 61 73 6f 75 72 63 65 20 2a 70 44 61 74 61  atasource *pData
37e0: 3b 0a 20 20 44 61 74 61 73 6f 75 72 63 65 44 65  ;.  DatasourceDe
37f0: 66 6e 20 64 65 66 6e 20 3d 20 7b 20 54 45 53 54  fn defn = { TEST
3800: 5f 44 41 54 41 53 4f 55 52 43 45 5f 52 41 4e 44  _DATASOURCE_RAND
3810: 4f 4d 2c 20 30 2c 20 30 2c 20 30 2c 20 30 20 7d  OM, 0, 0, 0, 0 }
3820: 3b 0a 20 20 63 68 61 72 20 2a 7a 53 79 73 74 65  ;.  char *zSyste
3830: 6d 20 3d 20 22 22 3b 0a 20 20 69 6e 74 20 62 4c  m = "";.  int bL
3840: 73 6d 20 3d 20 31 3b 0a 20 20 46 49 4c 45 20 2a  sm = 1;.  FILE *
3850: 70 4c 6f 67 20 3d 20 30 3b 0a 0a 23 69 66 64 65  pLog = 0;..#ifde
3860: 66 20 4e 44 45 42 55 47 0a 20 20 2f 2a 20 49 66  f NDEBUG.  /* If
3870: 20 4e 44 45 42 55 47 20 69 73 20 64 65 66 69 6e   NDEBUG is defin
3880: 65 64 2c 20 64 69 73 61 62 6c 65 20 74 68 65 20  ed, disable the 
3890: 64 79 6e 61 6d 69 63 20 6d 65 6d 6f 72 79 20 72  dynamic memory r
38a0: 65 6c 61 74 65 64 20 63 68 65 63 6b 73 20 69 6e  elated checks in
38b0: 0a 20 20 2a 2a 20 6c 73 6d 74 65 73 74 5f 6d 65  .  ** lsmtest_me
38c0: 6d 2e 63 2e 20 54 68 65 79 20 73 6c 6f 77 20 74  m.c. They slow t
38d0: 68 69 6e 67 73 20 64 6f 77 6e 2e 20 20 2a 2f 0a  hings down.  */.
38e0: 20 20 74 65 73 74 4d 61 6c 6c 6f 63 55 6e 69 6e    testMallocUnin
38f0: 73 74 61 6c 6c 28 74 64 62 5f 6c 73 6d 5f 65 6e  stall(tdb_lsm_en
3900: 76 28 29 29 3b 0a 23 65 6e 64 69 66 0a 0a 20 20  v());.#endif..  
3910: 2f 2a 20 49 6e 69 74 69 61 6c 69 7a 65 20 61 50  /* Initialize aP
3920: 61 72 61 6d 5b 5d 20 77 69 74 68 20 64 65 66 61  aram[] with defa
3930: 75 6c 74 20 76 61 6c 75 65 73 2e 20 2a 2f 0a 20  ult values. */. 
3940: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 41 72 72 61   for(i=0; i<Arra
3950: 79 53 69 7a 65 28 61 4f 70 74 29 3b 20 69 2b 2b  ySize(aOpt); i++
3960: 29 7b 0a 20 20 20 20 69 66 28 20 61 4f 70 74 5b  ){.    if( aOpt[
3970: 69 5d 2e 7a 4f 70 74 20 29 20 61 50 61 72 61 6d  i].zOpt ) aParam
3980: 5b 61 4f 70 74 5b 69 5d 2e 65 56 61 6c 5d 20 3d  [aOpt[i].eVal] =
3990: 20 61 4f 70 74 5b 69 5d 2e 69 44 65 66 61 75 6c   aOpt[i].iDefaul
39a0: 74 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 50 72 6f  t;.  }..  /* Pro
39b0: 63 65 73 73 20 74 68 65 20 63 6f 6d 6d 61 6e 64  cess the command
39c0: 20 6c 69 6e 65 20 73 77 69 74 63 68 65 73 2e 20   line switches. 
39d0: 2a 2f 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c  */.  for(i=0; i<
39e0: 6e 41 72 67 3b 20 69 2b 3d 32 29 7b 0a 20 20 20  nArg; i+=2){.   
39f0: 20 69 6e 74 20 69 53 65 6c 3b 0a 20 20 20 20 72   int iSel;.    r
3a00: 63 20 3d 20 74 65 73 74 41 72 67 53 65 6c 65 63  c = testArgSelec
3a10: 74 28 61 4f 70 74 2c 20 22 73 77 69 74 63 68 22  t(aOpt, "switch"
3a20: 2c 20 61 7a 41 72 67 5b 69 5d 2c 20 26 69 53 65  , azArg[i], &iSe
3a30: 6c 29 3b 0a 20 20 20 20 69 66 28 20 72 63 20 29  l);.    if( rc )
3a40: 7b 0a 20 20 20 20 20 20 72 65 74 75 72 6e 20 72  {.      return r
3a50: 63 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 66 28  c;.    }.    if(
3a60: 20 61 4f 70 74 5b 69 53 65 6c 5d 2e 65 56 61 6c   aOpt[iSel].eVal
3a70: 3d 3d 2d 32 20 29 7b 0a 20 20 20 20 20 20 70 72  ==-2 ){.      pr
3a80: 69 6e 74 5f 73 70 65 65 64 5f 74 65 73 74 5f 68  int_speed_test_h
3a90: 65 6c 70 28 29 3b 0a 20 20 20 20 20 20 72 65 74  elp();.      ret
3aa0: 75 72 6e 20 30 3b 0a 20 20 20 20 7d 0a 20 20 20  urn 0;.    }.   
3ab0: 20 69 66 28 20 69 2b 31 3d 3d 6e 41 72 67 20 29   if( i+1==nArg )
3ac0: 7b 0a 20 20 20 20 20 20 74 65 73 74 50 72 69 6e  {.      testPrin
3ad0: 74 45 72 72 6f 72 28 22 6f 70 74 69 6f 6e 20 25  tError("option %
3ae0: 73 20 72 65 71 75 69 72 65 73 20 61 6e 20 61 72  s requires an ar
3af0: 67 75 6d 65 6e 74 5c 6e 22 2c 20 61 4f 70 74 5b  gument\n", aOpt[
3b00: 69 53 65 6c 5d 2e 7a 4f 70 74 29 3b 0a 20 20 20  iSel].zOpt);.   
3b10: 20 20 20 72 65 74 75 72 6e 20 31 3b 0a 20 20 20     return 1;.   
3b20: 20 7d 0a 20 20 20 20 69 66 28 20 61 4f 70 74 5b   }.    if( aOpt[
3b30: 69 53 65 6c 5d 2e 65 56 61 6c 3e 3d 30 20 29 7b  iSel].eVal>=0 ){
3b40: 0a 20 20 20 20 20 20 61 50 61 72 61 6d 5b 61 4f  .      aParam[aO
3b50: 70 74 5b 69 53 65 6c 5d 2e 65 56 61 6c 5d 20 3d  pt[iSel].eVal] =
3b60: 20 61 74 6f 69 28 61 7a 41 72 67 5b 69 2b 31 5d   atoi(azArg[i+1]
3b70: 29 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20  );.    }else{.  
3b80: 20 20 20 20 7a 53 79 73 74 65 6d 20 3d 20 61 7a      zSystem = az
3b90: 41 72 67 5b 69 2b 31 5d 3b 0a 20 20 20 20 20 20  Arg[i+1];.      
3ba0: 62 4c 73 6d 20 3d 20 30 3b 0a 23 69 66 20 30 0a  bLsm = 0;.#if 0.
3bb0: 20 20 20 20 20 20 66 6f 72 28 6a 3d 30 3b 20 7a        for(j=0; z
3bc0: 53 79 73 74 65 6d 5b 6a 5d 3b 20 6a 2b 2b 29 7b  System[j]; j++){
3bd0: 0a 20 20 20 20 20 20 20 20 69 66 28 20 7a 53 79  .        if( zSy
3be0: 73 74 65 6d 5b 6a 5d 3d 3d 27 3d 27 20 29 20 62  stem[j]=='=' ) b
3bf0: 4c 73 6d 20 3d 20 31 3b 0a 20 20 20 20 20 20 7d  Lsm = 1;.      }
3c00: 0a 23 65 6e 64 69 66 0a 20 20 20 20 7d 0a 20 20  .#endif.    }.  
3c10: 7d 0a 20 20 0a 20 20 70 72 69 6e 74 66 28 22 23  }.  .  printf("#
3c20: 22 29 3b 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69  ");.  for(i=0; i
3c30: 3c 41 72 72 61 79 53 69 7a 65 28 61 4f 70 74 29  <ArraySize(aOpt)
3c40: 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20  ; i++){.    if( 
3c50: 61 4f 70 74 5b 69 5d 2e 7a 4f 70 74 20 29 7b 0a  aOpt[i].zOpt ){.
3c60: 20 20 20 20 20 20 69 66 28 20 61 4f 70 74 5b 69        if( aOpt[i
3c70: 5d 2e 65 56 61 6c 3e 3d 30 20 29 7b 0a 20 20 20  ].eVal>=0 ){.   
3c80: 20 20 20 20 20 70 72 69 6e 74 66 28 22 20 25 73       printf(" %s
3c90: 3d 25 64 22 2c 20 26 61 4f 70 74 5b 69 5d 2e 7a  =%d", &aOpt[i].z
3ca0: 4f 70 74 5b 31 5d 2c 20 61 50 61 72 61 6d 5b 61  Opt[1], aParam[a
3cb0: 4f 70 74 5b 69 5d 2e 65 56 61 6c 5d 29 3b 0a 20  Opt[i].eVal]);. 
3cc0: 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 61       }else if( a
3cd0: 4f 70 74 5b 69 5d 2e 65 56 61 6c 3d 3d 2d 31 20  Opt[i].eVal==-1 
3ce0: 29 7b 0a 20 20 20 20 20 20 20 20 70 72 69 6e 74  ){.        print
3cf0: 66 28 22 20 25 73 3d 5c 22 25 73 5c 22 22 2c 20  f(" %s=\"%s\"", 
3d00: 26 61 4f 70 74 5b 69 5d 2e 7a 4f 70 74 5b 31 5d  &aOpt[i].zOpt[1]
3d10: 2c 20 7a 53 79 73 74 65 6d 29 3b 0a 20 20 20 20  , zSystem);.    
3d20: 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20    }.    }.  }.  
3d30: 70 72 69 6e 74 66 28 22 5c 6e 22 29 3b 0a 0a 20  printf("\n");.. 
3d40: 20 64 65 66 6e 2e 6e 4d 69 6e 4b 65 79 20 3d 20   defn.nMinKey = 
3d50: 64 65 66 6e 2e 6e 4d 61 78 4b 65 79 20 3d 20 61  defn.nMaxKey = a
3d60: 50 61 72 61 6d 5b 53 54 5f 4b 45 59 53 49 5a 45  Param[ST_KEYSIZE
3d70: 5d 3b 0a 20 20 64 65 66 6e 2e 6e 4d 69 6e 56 61  ];.  defn.nMinVa
3d80: 6c 20 3d 20 64 65 66 6e 2e 6e 4d 61 78 56 61 6c  l = defn.nMaxVal
3d90: 20 3d 20 61 50 61 72 61 6d 5b 53 54 5f 56 41 4c   = aParam[ST_VAL
3da0: 53 49 5a 45 5d 3b 0a 20 20 70 44 61 74 61 20 3d  SIZE];.  pData =
3db0: 20 74 65 73 74 44 61 74 61 73 6f 75 72 63 65 4e   testDatasourceN
3dc0: 65 77 28 26 64 65 66 6e 29 3b 0a 0a 20 20 69 66  ew(&defn);..  if
3dd0: 28 20 61 50 61 72 61 6d 5b 53 54 5f 57 52 49 54  ( aParam[ST_WRIT
3de0: 45 5d 3d 3d 30 20 29 7b 0a 20 20 20 20 62 52 65  E]==0 ){.    bRe
3df0: 61 64 6f 6e 6c 79 20 3d 20 31 3b 0a 20 20 7d 0a  adonly = 1;.  }.
3e00: 0a 20 20 69 66 28 20 62 4c 73 6d 20 29 7b 0a 20  .  if( bLsm ){. 
3e10: 20 20 20 72 63 20 3d 20 74 64 62 5f 6c 73 6d 5f     rc = tdb_lsm_
3e20: 6f 70 65 6e 28 7a 53 79 73 74 65 6d 2c 20 22 74  open(zSystem, "t
3e30: 65 73 74 64 62 2e 6c 73 6d 22 2c 20 21 62 52 65  estdb.lsm", !bRe
3e40: 61 64 6f 6e 6c 79 2c 20 26 70 44 62 29 3b 0a 20  adonly, &pDb);. 
3e50: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 70 44 62 20   }else{.    pDb 
3e60: 3d 20 74 65 73 74 4f 70 65 6e 28 7a 53 79 73 74  = testOpen(zSyst
3e70: 65 6d 2c 20 21 62 52 65 61 64 6f 6e 6c 79 2c 20  em, !bReadonly, 
3e80: 26 72 63 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20  &rc);.  }.  if( 
3e90: 72 63 21 3d 30 20 29 20 72 65 74 75 72 6e 20 72  rc!=0 ) return r
3ea0: 63 3b 0a 20 20 69 66 28 20 62 52 65 61 64 6f 6e  c;.  if( bReadon
3eb0: 6c 79 20 29 7b 0a 20 20 20 20 6e 43 6f 6e 74 65  ly ){.    nConte
3ec0: 6e 74 20 3d 20 74 65 73 74 43 6f 75 6e 74 44 61  nt = testCountDa
3ed0: 74 61 62 61 73 65 28 70 44 62 29 3b 0a 20 20 7d  tabase(pDb);.  }
3ee0: 0a 0a 23 69 66 20 30 0a 20 20 70 4c 6f 67 20 3d  ..#if 0.  pLog =
3ef0: 20 66 6f 70 65 6e 28 22 2f 74 6d 70 2f 73 70 65   fopen("/tmp/spe
3f00: 65 64 2e 6c 6f 67 22 2c 20 22 77 22 29 3b 0a 20  ed.log", "w");. 
3f10: 20 74 64 62 5f 6c 73 6d 5f 77 72 69 74 65 5f 68   tdb_lsm_write_h
3f20: 6f 6f 6b 28 70 44 62 2c 20 64 6f 5f 73 70 65 65  ook(pDb, do_spee
3f30: 64 5f 77 72 69 74 65 5f 68 6f 6f 6b 32 2c 20 28  d_write_hook2, (
3f40: 76 6f 69 64 20 2a 29 70 4c 6f 67 29 3b 0a 23 65  void *)pLog);.#e
3f50: 6e 64 69 66 0a 0a 20 20 66 6f 72 28 69 3d 30 3b  ndif..  for(i=0;
3f60: 20 69 3c 61 50 61 72 61 6d 5b 53 54 5f 52 45 50   i<aParam[ST_REP
3f70: 45 41 54 5d 20 26 26 20 72 63 3d 3d 30 3b 20 69  EAT] && rc==0; i
3f80: 2b 2b 29 7b 0a 20 20 20 20 69 6e 74 20 6d 73 57  ++){.    int msW
3f90: 72 69 74 65 2c 20 6d 73 46 65 74 63 68 3b 0a 20  rite, msFetch;. 
3fa0: 20 20 20 69 6e 74 20 69 46 65 74 63 68 3b 0a 20     int iFetch;. 
3fb0: 20 20 20 69 6e 74 20 6e 57 72 69 74 65 20 3d 20     int nWrite = 
3fc0: 61 50 61 72 61 6d 5b 53 54 5f 57 52 49 54 45 5d  aParam[ST_WRITE]
3fd0: 3b 0a 0a 20 20 20 20 69 66 28 20 62 52 65 61 64  ;..    if( bRead
3fe0: 6f 6e 6c 79 20 29 7b 0a 20 20 20 20 20 20 6d 73  only ){.      ms
3ff0: 57 72 69 74 65 20 3d 20 30 3b 0a 20 20 20 20 7d  Write = 0;.    }
4000: 65 6c 73 65 7b 0a 20 20 20 20 20 20 74 65 73 74  else{.      test
4010: 54 69 6d 65 49 6e 69 74 28 29 3b 0a 0a 20 20 20  TimeInit();..   
4020: 20 20 20 69 66 28 20 61 50 61 72 61 6d 5b 53 54     if( aParam[ST
4030: 5f 54 52 41 4e 53 5d 20 29 20 74 65 73 74 42 65  _TRANS] ) testBe
4040: 67 69 6e 28 70 44 62 2c 20 32 2c 20 26 72 63 29  gin(pDb, 2, &rc)
4050: 3b 0a 20 20 20 20 20 20 74 65 73 74 57 72 69 74  ;.      testWrit
4060: 65 44 61 74 61 73 6f 75 72 63 65 52 61 6e 67 65  eDatasourceRange
4070: 28 70 44 62 2c 20 70 44 61 74 61 2c 20 69 2a 6e  (pDb, pData, i*n
4080: 57 72 69 74 65 2c 20 6e 57 72 69 74 65 2c 20 26  Write, nWrite, &
4090: 72 63 29 3b 0a 20 20 20 20 20 20 69 66 28 20 61  rc);.      if( a
40a0: 50 61 72 61 6d 5b 53 54 5f 54 52 41 4e 53 5d 20  Param[ST_TRANS] 
40b0: 29 20 74 65 73 74 43 6f 6d 6d 69 74 28 70 44 62  ) testCommit(pDb
40c0: 2c 20 30 2c 20 26 72 63 29 3b 0a 0a 20 20 20 20  , 0, &rc);..    
40d0: 20 20 6d 73 57 72 69 74 65 20 3d 20 74 65 73 74    msWrite = test
40e0: 54 69 6d 65 47 65 74 28 29 3b 0a 20 20 20 20 20  TimeGet();.     
40f0: 20 6e 43 6f 6e 74 65 6e 74 20 2b 3d 20 6e 57 72   nContent += nWr
4100: 69 74 65 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  ite;.    }..    
4110: 69 66 28 20 61 50 61 72 61 6d 5b 53 54 5f 50 41  if( aParam[ST_PA
4120: 55 53 45 5d 20 29 7b 0a 20 20 20 20 20 20 69 66  USE] ){.      if
4130: 28 20 61 50 61 72 61 6d 5b 53 54 5f 50 41 55 53  ( aParam[ST_PAUS
4140: 45 5d 2f 31 30 30 30 20 29 20 73 6c 65 65 70 28  E]/1000 ) sleep(
4150: 61 50 61 72 61 6d 5b 53 54 5f 50 41 55 53 45 5d  aParam[ST_PAUSE]
4160: 2f 31 30 30 30 29 3b 0a 20 20 20 20 20 20 69 66  /1000);.      if
4170: 28 20 61 50 61 72 61 6d 5b 53 54 5f 50 41 55 53  ( aParam[ST_PAUS
4180: 45 5d 25 31 30 30 30 20 29 20 75 73 6c 65 65 70  E]%1000 ) usleep
4190: 28 31 30 30 30 20 2a 20 28 61 50 61 72 61 6d 5b  (1000 * (aParam[
41a0: 53 54 5f 50 41 55 53 45 5d 25 31 30 30 30 29 29  ST_PAUSE]%1000))
41b0: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 69 66 28  ;.    }..    if(
41c0: 20 61 50 61 72 61 6d 5b 53 54 5f 46 45 54 43 48   aParam[ST_FETCH
41d0: 5d 20 29 7b 0a 20 20 20 20 20 20 74 65 73 74 54  ] ){.      testT
41e0: 69 6d 65 49 6e 69 74 28 29 3b 0a 20 20 20 20 20  imeInit();.     
41f0: 20 69 66 28 20 61 50 61 72 61 6d 5b 53 54 5f 54   if( aParam[ST_T
4200: 52 41 4e 53 5d 20 29 20 74 65 73 74 42 65 67 69  RANS] ) testBegi
4210: 6e 28 70 44 62 2c 20 31 2c 20 26 72 63 29 3b 0a  n(pDb, 1, &rc);.
4220: 20 20 20 20 20 20 66 6f 72 28 69 46 65 74 63 68        for(iFetch
4230: 3d 30 3b 20 69 46 65 74 63 68 3c 61 50 61 72 61  =0; iFetch<aPara
4240: 6d 5b 53 54 5f 46 45 54 43 48 5d 3b 20 69 46 65  m[ST_FETCH]; iFe
4250: 74 63 68 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20  tch++){.        
4260: 69 6e 74 20 69 4b 65 79 20 3d 20 74 65 73 74 50  int iKey = testP
4270: 72 6e 67 56 61 6c 75 65 28 69 2a 6e 57 72 69 74  rngValue(i*nWrit
4280: 65 2b 69 46 65 74 63 68 29 20 25 20 6e 43 6f 6e  e+iFetch) % nCon
4290: 74 65 6e 74 3b 0a 23 69 66 6e 64 65 66 20 4e 44  tent;.#ifndef ND
42a0: 45 42 55 47 0a 20 20 20 20 20 20 20 20 74 65 73  EBUG.        tes
42b0: 74 44 61 74 61 73 6f 75 72 63 65 46 65 74 63 68  tDatasourceFetch
42c0: 28 70 44 62 2c 20 70 44 61 74 61 2c 20 69 4b 65  (pDb, pData, iKe
42d0: 79 2c 20 26 72 63 29 3b 0a 23 65 6c 73 65 0a 20  y, &rc);.#else. 
42e0: 20 20 20 20 20 20 20 76 6f 69 64 20 2a 70 4b 65         void *pKe
42f0: 79 3b 20 69 6e 74 20 6e 4b 65 79 3b 20 20 20 20  y; int nKey;    
4300: 20 20 20 20 20 20 20 2f 2a 20 44 61 74 61 62 61         /* Databa
4310: 73 65 20 6b 65 79 20 74 6f 20 71 75 65 72 79 20  se key to query 
4320: 66 6f 72 20 2a 2f 0a 20 20 20 20 20 20 20 20 76  for */.        v
4330: 6f 69 64 20 2a 70 56 61 6c 3b 20 69 6e 74 20 6e  oid *pVal; int n
4340: 56 61 6c 3b 20 20 20 20 20 20 20 20 20 20 20 2f  Val;           /
4350: 2a 20 52 65 73 75 6c 74 20 6f 66 20 71 75 65 72  * Result of quer
4360: 79 20 2a 2f 0a 0a 20 20 20 20 20 20 20 20 74 65  y */..        te
4370: 73 74 44 61 74 61 73 6f 75 72 63 65 45 6e 74 72  stDatasourceEntr
4380: 79 28 70 44 61 74 61 2c 20 69 4b 65 79 2c 20 26  y(pData, iKey, &
4390: 70 4b 65 79 2c 20 26 6e 4b 65 79 2c 20 30 2c 20  pKey, &nKey, 0, 
43a0: 30 29 3b 0a 20 20 20 20 20 20 20 20 72 63 20 3d  0);.        rc =
43b0: 20 74 64 62 5f 66 65 74 63 68 28 70 44 62 2c 20   tdb_fetch(pDb, 
43c0: 70 4b 65 79 2c 20 6e 4b 65 79 2c 20 26 70 56 61  pKey, nKey, &pVa
43d0: 6c 2c 20 26 6e 56 61 6c 29 3b 0a 20 20 20 20 20  l, &nVal);.     
43e0: 20 20 20 69 66 28 20 72 63 3d 3d 30 20 26 26 20     if( rc==0 && 
43f0: 6e 56 61 6c 3c 30 20 29 20 72 63 20 3d 20 31 3b  nVal<0 ) rc = 1;
4400: 0a 20 20 20 20 20 20 20 20 69 66 28 20 72 63 20  .        if( rc 
4410: 29 20 62 72 65 61 6b 3b 0a 23 65 6e 64 69 66 0a  ) break;.#endif.
4420: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66        }.      if
4430: 28 20 61 50 61 72 61 6d 5b 53 54 5f 54 52 41 4e  ( aParam[ST_TRAN
4440: 53 5d 20 29 20 74 65 73 74 43 6f 6d 6d 69 74 28  S] ) testCommit(
4450: 70 44 62 2c 20 30 2c 20 26 72 63 29 3b 0a 20 20  pDb, 0, &rc);.  
4460: 20 20 20 20 6d 73 46 65 74 63 68 20 3d 20 74 65      msFetch = te
4470: 73 74 54 69 6d 65 47 65 74 28 29 3b 0a 20 20 20  stTimeGet();.   
4480: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 6d 73   }else{.      ms
4490: 46 65 74 63 68 20 3d 20 30 3b 0a 20 20 20 20 7d  Fetch = 0;.    }
44a0: 0a 0a 20 20 20 20 69 66 28 20 69 3d 3d 28 61 50  ..    if( i==(aP
44b0: 61 72 61 6d 5b 53 54 5f 52 45 50 45 41 54 5d 2d  aram[ST_REPEAT]-
44c0: 31 29 20 29 7b 0a 20 20 20 20 20 20 74 65 73 74  1) ){.      test
44d0: 54 69 6d 65 49 6e 69 74 28 29 3b 0a 20 20 20 20  TimeInit();.    
44e0: 20 20 74 65 73 74 43 6c 6f 73 65 28 26 70 44 62    testClose(&pDb
44f0: 29 3b 0a 20 20 20 20 20 20 6d 73 57 72 69 74 65  );.      msWrite
4500: 20 2b 3d 20 74 65 73 74 54 69 6d 65 47 65 74 28   += testTimeGet(
4510: 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 70 72  );.    }..    pr
4520: 69 6e 74 66 28 22 25 64 20 25 64 20 25 64 5c 6e  intf("%d %d %d\n
4530: 22 2c 20 69 2c 20 6d 73 57 72 69 74 65 2c 20 6d  ", i, msWrite, m
4540: 73 46 65 74 63 68 29 3b 0a 20 20 20 20 66 66 6c  sFetch);.    ffl
4550: 75 73 68 28 73 74 64 6f 75 74 29 3b 0a 20 20 7d  ush(stdout);.  }
4560: 0a 0a 20 20 74 65 73 74 43 6c 6f 73 65 28 26 70  ..  testClose(&p
4570: 44 62 29 3b 0a 20 20 74 65 73 74 44 61 74 61 73  Db);.  testDatas
4580: 6f 75 72 63 65 46 72 65 65 28 70 44 61 74 61 29  ourceFree(pData)
4590: 3b 0a 0a 20 20 69 66 28 20 70 4c 6f 67 20 29 7b  ;..  if( pLog ){
45a0: 0a 20 20 20 20 66 6c 75 73 68 50 72 65 76 28 70  .    flushPrev(p
45b0: 4c 6f 67 29 3b 0a 20 20 20 20 66 63 6c 6f 73 65  Log);.    fclose
45c0: 28 70 4c 6f 67 29 3b 0a 20 20 7d 0a 20 20 72 65  (pLog);.  }.  re
45d0: 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 69 6e 74 20  turn rc;.}..int 
45e0: 64 6f 5f 73 70 65 65 64 5f 74 65 73 74 73 28 69  do_speed_tests(i
45f0: 6e 74 20 6e 41 72 67 2c 20 63 68 61 72 20 2a 2a  nt nArg, char **
4600: 61 7a 41 72 67 29 7b 0a 0a 20 20 73 74 72 75 63  azArg){..  struc
4610: 74 20 44 62 53 79 73 74 65 6d 20 7b 0a 20 20 20  t DbSystem {.   
4620: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 4c 69   const char *zLi
4630: 62 72 61 72 79 3b 0a 20 20 20 20 63 6f 6e 73 74  brary;.    const
4640: 20 63 68 61 72 20 2a 7a 43 6f 6c 6f 72 3b 0a 20   char *zColor;. 
4650: 20 7d 20 61 53 79 73 5b 5d 20 3d 20 7b 0a 20 20   } aSys[] = {.  
4660: 20 20 7b 20 22 73 71 6c 69 74 65 33 22 2c 20 20    { "sqlite3",  
4670: 20 20 20 20 22 62 6c 61 63 6b 22 20 7d 2c 0a 20      "black" },. 
4680: 20 20 20 7b 20 22 6c 65 76 65 6c 64 62 22 2c 20     { "leveldb", 
4690: 20 20 20 20 20 22 62 6c 75 65 22 20 7d 2c 0a 20       "blue" },. 
46a0: 20 20 20 7b 20 22 6c 73 6d 22 2c 20 20 20 20 20     { "lsm",     
46b0: 20 20 20 20 20 22 72 65 64 22 20 7d 2c 0a 20 20       "red" },.  
46c0: 20 20 7b 20 22 6c 73 6d 5f 6d 74 32 22 2c 20 20    { "lsm_mt2",  
46d0: 20 20 20 20 22 6f 72 61 6e 67 65 22 20 7d 2c 0a      "orange" },.
46e0: 20 20 20 20 7b 20 22 6c 73 6d 5f 6d 74 33 22 2c      { "lsm_mt3",
46f0: 20 20 20 20 20 20 22 70 75 72 70 6c 65 22 20 7d        "purple" }
4700: 2c 0a 20 20 20 20 7b 20 22 6b 79 6f 74 6f 63 61  ,.    { "kyotoca
4710: 62 69 6e 65 74 22 2c 20 22 67 72 65 65 6e 22 20  binet", "green" 
4720: 7d 2c 0a 20 20 20 20 7b 30 2c 20 30 7d 0a 20 20  },.    {0, 0}.  
4730: 7d 3b 0a 0a 20 20 69 6e 74 20 69 3b 0a 20 20 69  };..  int i;.  i
4740: 6e 74 20 6a 3b 0a 20 20 69 6e 74 20 72 63 3b 0a  nt j;.  int rc;.
4750: 20 20 69 6e 74 20 6e 53 6c 65 65 70 20 3d 20 30    int nSleep = 0
4760: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
4770: 20 20 2f 2a 20 6d 73 20 6f 66 20 72 65 73 74 20    /* ms of rest 
4780: 61 6c 6c 6f 77 65 64 20 62 65 74 77 65 65 6e 20  allowed between 
4790: 49 4e 53 45 52 54 20 74 65 73 74 73 20 2a 2f 0a  INSERT tests */.
47a0: 20 20 69 6e 74 20 6e 52 6f 77 20 3d 20 30 3b 20    int nRow = 0; 
47b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
47c0: 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20 72    /* Number of r
47d0: 6f 77 73 20 74 6f 20 69 6e 73 65 72 74 20 69 6e  ows to insert in
47e0: 74 6f 20 64 61 74 61 62 61 73 65 20 2a 2f 0a 20  to database */. 
47f0: 20 69 6e 74 20 6e 53 74 65 70 3b 20 20 20 20 20   int nStep;     
4800: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4810: 20 2f 2a 20 4d 65 61 73 75 72 65 20 49 4e 53 45   /* Measure INSE
4820: 52 54 20 74 69 6d 65 20 61 66 74 65 72 20 74 68  RT time after th
4830: 69 73 20 6d 61 6e 79 20 72 6f 77 73 20 2a 2f 0a  is many rows */.
4840: 20 20 69 6e 74 20 6e 53 65 6c 53 74 65 70 3b 20    int nSelStep; 
4850: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4860: 20 20 2f 2a 20 4d 65 61 73 75 72 65 20 53 45 4c    /* Measure SEL
4870: 45 43 54 20 74 69 6d 65 20 61 66 74 65 72 20 74  ECT time after t
4880: 68 69 73 20 6d 61 6e 79 20 72 6f 77 73 20 2a 2f  his many rows */
4890: 0a 20 20 69 6e 74 20 6e 53 65 6c 54 65 73 74 3b  .  int nSelTest;
48a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
48b0: 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f 66 20     /* Number of 
48c0: 53 45 4c 45 43 54 73 20 74 6f 20 72 75 6e 20 66  SELECTs to run f
48d0: 6f 72 20 74 69 6d 69 6e 67 20 2a 2f 0a 20 20 69  or timing */.  i
48e0: 6e 74 20 64 6f 52 65 61 64 54 65 73 74 20 3d 20  nt doReadTest = 
48f0: 31 3b 0a 20 20 69 6e 74 20 64 6f 57 72 69 74 65  1;.  int doWrite
4900: 54 65 73 74 20 3d 20 31 3b 0a 0a 20 20 69 6e 74  Test = 1;..  int
4910: 20 2a 61 54 69 6d 65 3b 20 20 20 20 20 20 20 20   *aTime;        
4920: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
4930: 49 4e 53 45 52 54 20 74 69 6d 69 6e 67 20 64 61  INSERT timing da
4940: 74 61 20 2a 2f 0a 20 20 69 6e 74 20 2a 61 57 72  ta */.  int *aWr
4950: 69 74 65 3b 20 20 20 20 20 20 20 20 20 20 20 20  ite;            
4960: 20 20 20 20 20 20 20 20 2f 2a 20 57 72 69 74 65          /* Write
4970: 73 20 70 65 72 20 6e 53 74 65 70 20 69 6e 73 65  s per nStep inse
4980: 72 74 73 20 2a 2f 0a 20 20 69 6e 74 20 2a 61 53  rts */.  int *aS
4990: 65 6c 54 69 6d 65 3b 20 20 20 20 20 20 20 20 20  elTime;         
49a0: 20 20 20 20 20 20 20 20 20 2f 2a 20 53 45 4c 45           /* SELE
49b0: 43 54 20 74 69 6d 69 6e 67 20 64 61 74 61 20 2a  CT timing data *
49c0: 2f 0a 20 20 69 6e 74 20 69 73 46 69 72 73 74 20  /.  int isFirst 
49d0: 3d 20 31 3b 0a 20 20 69 6e 74 20 62 53 6c 65 65  = 1;.  int bSlee
49e0: 70 20 3d 20 30 3b 0a 0a 20 20 2f 2a 20 46 69 6c  p = 0;..  /* Fil
49f0: 65 20 74 6f 20 77 72 69 74 65 20 67 6e 75 70 6c  e to write gnupl
4a00: 6f 74 20 73 63 72 69 70 74 20 74 6f 2e 20 2a 2f  ot script to. */
4a10: 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  .  const char *z
4a20: 4f 75 74 20 3d 20 22 6c 73 6d 74 65 73 74 5f 73  Out = "lsmtest_s
4a30: 70 65 65 64 2e 67 6e 75 70 6c 6f 74 22 3b 0a 0a  peed.gnuplot";..
4a40: 20 20 75 33 32 20 73 79 73 5f 6d 61 73 6b 20 3d    u32 sys_mask =
4a50: 20 30 3b 0a 0a 20 20 74 65 73 74 4d 61 6c 6c 6f   0;..  testMallo
4a60: 63 55 6e 69 6e 73 74 61 6c 6c 28 74 64 62 5f 6c  cUninstall(tdb_l
4a70: 73 6d 5f 65 6e 76 28 29 29 3b 0a 0a 20 20 66 6f  sm_env());..  fo
4a80: 72 28 69 3d 30 3b 20 69 3c 6e 41 72 67 3b 20 69  r(i=0; i<nArg; i
4a90: 2b 2b 29 7b 0a 20 20 20 20 73 74 72 75 63 74 20  ++){.    struct 
4aa0: 4f 70 74 20 7b 20 0a 20 20 20 20 20 20 63 6f 6e  Opt { .      con
4ab0: 73 74 20 63 68 61 72 20 2a 7a 4f 70 74 3b 20 0a  st char *zOpt; .
4ac0: 20 20 20 20 20 20 69 6e 74 20 69 73 53 77 69 74        int isSwit
4ad0: 63 68 3b 0a 20 20 20 20 7d 20 61 4f 70 74 5b 5d  ch;.    } aOpt[]
4ae0: 20 3d 20 7b 0a 20 20 20 20 20 20 7b 20 22 73 71   = {.      { "sq
4af0: 6c 69 74 65 33 22 20 2c 20 30 7d 2c 0a 20 20 20  lite3" , 0},.   
4b00: 20 20 20 7b 20 22 6c 65 76 65 6c 64 62 22 20 2c     { "leveldb" ,
4b10: 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20 22 6c 73   0},.      { "ls
4b20: 6d 22 20 2c 20 30 7d 2c 0a 20 20 20 20 20 20 7b  m" , 0},.      {
4b30: 20 22 6c 73 6d 5f 6d 74 32 22 20 2c 20 30 7d 2c   "lsm_mt2" , 0},
4b40: 0a 20 20 20 20 20 20 7b 20 22 6c 73 6d 5f 6d 74  .      { "lsm_mt
4b50: 33 22 20 2c 20 30 7d 2c 0a 20 20 20 20 20 20 7b  3" , 0},.      {
4b60: 20 22 6b 79 6f 74 6f 63 61 62 69 6e 65 74 22 20   "kyotocabinet" 
4b70: 2c 20 30 7d 2c 0a 20 20 20 20 20 20 7b 20 22 2d  , 0},.      { "-
4b80: 72 6f 77 73 22 20 20 20 20 20 2c 20 31 7d 2c 0a  rows"     , 1},.
4b90: 20 20 20 20 20 20 7b 20 22 2d 73 6c 65 65 70 22        { "-sleep"
4ba0: 20 20 20 20 2c 20 32 7d 2c 0a 20 20 20 20 20 20      , 2},.      
4bb0: 7b 20 22 2d 74 65 73 74 6d 6f 64 65 22 20 2c 20  { "-testmode" , 
4bc0: 33 7d 2c 0a 20 20 20 20 20 20 7b 20 22 2d 6f 75  3},.      { "-ou
4bd0: 74 22 20 20 20 20 20 20 2c 20 34 7d 2c 0a 20 20  t"      , 4},.  
4be0: 20 20 20 20 7b 20 30 2c 20 30 7d 0a 20 20 20 20      { 0, 0}.    
4bf0: 7d 3b 0a 20 20 20 20 69 6e 74 20 69 53 65 6c 3b  };.    int iSel;
4c00: 0a 0a 20 20 20 20 72 63 20 3d 20 74 65 73 74 41  ..    rc = testA
4c10: 72 67 53 65 6c 65 63 74 28 61 4f 70 74 2c 20 22  rgSelect(aOpt, "
4c20: 61 72 67 75 6d 65 6e 74 22 2c 20 61 7a 41 72 67  argument", azArg
4c30: 5b 69 5d 2c 20 26 69 53 65 6c 29 3b 0a 20 20 20  [i], &iSel);.   
4c40: 20 69 66 28 20 72 63 20 29 20 72 65 74 75 72 6e   if( rc ) return
4c50: 20 72 63 3b 0a 0a 20 20 20 20 69 66 28 20 61 4f   rc;..    if( aO
4c60: 70 74 5b 69 53 65 6c 5d 2e 69 73 53 77 69 74 63  pt[iSel].isSwitc
4c70: 68 20 29 7b 0a 20 20 20 20 20 20 69 2b 2b 3b 0a  h ){.      i++;.
4c80: 0a 20 20 20 20 20 20 69 66 28 20 69 3e 3d 6e 41  .      if( i>=nA
4c90: 72 67 20 29 7b 0a 20 20 20 20 20 20 20 20 74 65  rg ){.        te
4ca0: 73 74 50 72 69 6e 74 45 72 72 6f 72 28 22 6f 70  stPrintError("op
4cb0: 74 69 6f 6e 20 25 73 20 72 65 71 75 69 72 65 73  tion %s requires
4cc0: 20 61 6e 20 61 72 67 75 6d 65 6e 74 5c 6e 22 2c   an argument\n",
4cd0: 20 61 4f 70 74 5b 69 53 65 6c 5d 2e 7a 4f 70 74   aOpt[iSel].zOpt
4ce0: 29 3b 0a 20 20 20 20 20 20 20 20 72 65 74 75 72  );.        retur
4cf0: 6e 20 31 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  n 1;.      }.   
4d00: 20 20 20 69 66 28 20 61 4f 70 74 5b 69 53 65 6c     if( aOpt[iSel
4d10: 5d 2e 69 73 53 77 69 74 63 68 3d 3d 31 20 29 7b  ].isSwitch==1 ){
4d20: 0a 20 20 20 20 20 20 20 20 6e 52 6f 77 20 3d 20  .        nRow = 
4d30: 61 74 6f 69 28 61 7a 41 72 67 5b 69 5d 29 3b 0a  atoi(azArg[i]);.
4d40: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66        }.      if
4d50: 28 20 61 4f 70 74 5b 69 53 65 6c 5d 2e 69 73 53  ( aOpt[iSel].isS
4d60: 77 69 74 63 68 3d 3d 32 20 29 7b 0a 20 20 20 20  witch==2 ){.    
4d70: 20 20 20 20 6e 53 6c 65 65 70 20 3d 20 61 74 6f      nSleep = ato
4d80: 69 28 61 7a 41 72 67 5b 69 5d 29 3b 0a 20 20 20  i(azArg[i]);.   
4d90: 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28 20 61     }.      if( a
4da0: 4f 70 74 5b 69 53 65 6c 5d 2e 69 73 53 77 69 74  Opt[iSel].isSwit
4db0: 63 68 3d 3d 33 20 29 7b 0a 20 20 20 20 20 20 20  ch==3 ){.       
4dc0: 20 73 74 72 75 63 74 20 4d 6f 64 65 20 7b 0a 20   struct Mode {. 
4dd0: 20 20 20 20 20 20 20 20 20 63 6f 6e 73 74 20 63           const c
4de0: 68 61 72 20 2a 7a 4d 6f 64 65 3b 0a 20 20 20 20  har *zMode;.    
4df0: 20 20 20 20 20 20 69 6e 74 20 64 6f 52 65 61 64        int doRead
4e00: 54 65 73 74 3b 0a 20 20 20 20 20 20 20 20 20 20  Test;.          
4e10: 69 6e 74 20 64 6f 57 72 69 74 65 54 65 73 74 3b  int doWriteTest;
4e20: 0a 20 20 20 20 20 20 20 20 7d 20 61 4d 6f 64 65  .        } aMode
4e30: 5b 5d 20 3d 20 7b 7b 22 72 6f 22 2c 20 31 2c 20  [] = {{"ro", 1, 
4e40: 30 7d 20 2c 20 7b 22 72 77 22 2c 20 31 2c 20 31  0} , {"rw", 1, 1
4e50: 7d 2c 20 7b 22 77 6f 22 2c 20 30 2c 20 31 7d 2c  }, {"wo", 0, 1},
4e60: 20 7b 30 2c 20 30 2c 20 30 7d 7d 3b 0a 20 20 20   {0, 0, 0}};.   
4e70: 20 20 20 20 20 69 6e 74 20 69 4d 6f 64 65 3b 0a       int iMode;.
4e80: 20 20 20 20 20 20 20 20 72 63 20 3d 20 74 65 73          rc = tes
4e90: 74 41 72 67 53 65 6c 65 63 74 28 61 4d 6f 64 65  tArgSelect(aMode
4ea0: 2c 20 22 6f 70 74 69 6f 6e 22 2c 20 61 7a 41 72  , "option", azAr
4eb0: 67 5b 69 5d 2c 20 26 69 4d 6f 64 65 29 3b 0a 20  g[i], &iMode);. 
4ec0: 20 20 20 20 20 20 20 69 66 28 20 72 63 20 29 20         if( rc ) 
4ed0: 72 65 74 75 72 6e 20 72 63 3b 0a 20 20 20 20 20  return rc;.     
4ee0: 20 20 20 64 6f 52 65 61 64 54 65 73 74 20 3d 20     doReadTest = 
4ef0: 61 4d 6f 64 65 5b 69 4d 6f 64 65 5d 2e 64 6f 52  aMode[iMode].doR
4f00: 65 61 64 54 65 73 74 3b 0a 20 20 20 20 20 20 20  eadTest;.       
4f10: 20 64 6f 57 72 69 74 65 54 65 73 74 20 3d 20 61   doWriteTest = a
4f20: 4d 6f 64 65 5b 69 4d 6f 64 65 5d 2e 64 6f 57 72  Mode[iMode].doWr
4f30: 69 74 65 54 65 73 74 3b 0a 20 20 20 20 20 20 7d  iteTest;.      }
4f40: 0a 20 20 20 20 20 20 69 66 28 20 61 4f 70 74 5b  .      if( aOpt[
4f50: 69 53 65 6c 5d 2e 69 73 53 77 69 74 63 68 3d 3d  iSel].isSwitch==
4f60: 34 20 29 7b 0a 20 20 20 20 20 20 20 20 2f 2a 20  4 ){.        /* 
4f70: 54 68 65 20 22 2d 6f 75 74 20 46 49 4c 45 22 20  The "-out FILE" 
4f80: 73 77 69 74 63 68 2e 20 54 68 69 73 20 6f 70 74  switch. This opt
4f90: 69 6f 6e 20 69 73 20 75 73 65 64 20 74 6f 20 73  ion is used to s
4fa0: 70 65 63 69 66 79 20 61 20 66 69 6c 65 20 74 6f  pecify a file to
4fb0: 0a 20 20 20 20 20 20 20 20 2a 2a 20 77 72 69 74  .        ** writ
4fc0: 65 20 74 68 65 20 67 6e 75 70 6c 6f 74 20 73 63  e the gnuplot sc
4fd0: 72 69 70 74 20 74 6f 2e 20 2a 2f 0a 20 20 20 20  ript to. */.    
4fe0: 20 20 20 20 7a 4f 75 74 20 3d 20 61 7a 41 72 67      zOut = azArg
4ff0: 5b 69 5d 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  [i];.      }.   
5000: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 2f 2a   }else{.      /*
5010: 20 41 20 64 62 20 6e 61 6d 65 20 2a 2f 0a 20 20   A db name */.  
5020: 20 20 20 20 72 63 20 3d 20 74 65 73 74 41 72 67      rc = testArg
5030: 53 65 6c 65 63 74 28 61 4f 70 74 2c 20 22 73 79  Select(aOpt, "sy
5040: 73 74 65 6d 22 2c 20 61 7a 41 72 67 5b 69 5d 2c  stem", azArg[i],
5050: 20 26 69 53 65 6c 29 3b 0a 20 20 20 20 20 20 69   &iSel);.      i
5060: 66 28 20 72 63 20 29 20 72 65 74 75 72 6e 20 72  f( rc ) return r
5070: 63 3b 0a 20 20 20 20 20 20 73 79 73 5f 6d 61 73  c;.      sys_mas
5080: 6b 20 7c 3d 20 28 31 3c 3c 69 53 65 6c 29 3b 0a  k |= (1<<iSel);.
5090: 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 69 66 28      }.  }..  if(
50a0: 20 73 79 73 5f 6d 61 73 6b 3d 3d 30 20 29 20 73   sys_mask==0 ) s
50b0: 79 73 5f 6d 61 73 6b 20 3d 20 28 31 20 3c 3c 20  ys_mask = (1 << 
50c0: 30 29 20 7c 20 28 31 20 3c 3c 20 31 29 20 7c 20  0) | (1 << 1) | 
50d0: 28 31 20 3c 3c 20 32 29 20 7c 20 28 31 20 3c 3c  (1 << 2) | (1 <<
50e0: 20 33 29 3b 0a 20 20 6e 52 6f 77 20 3d 20 4d 41   3);.  nRow = MA
50f0: 58 28 6e 52 6f 77 2c 20 31 30 30 30 30 30 29 3b  X(nRow, 100000);
5100: 0a 20 20 6e 53 74 65 70 20 3d 20 6e 52 6f 77 2f  .  nStep = nRow/
5110: 31 30 30 3b 0a 20 20 6e 53 65 6c 53 74 65 70 20  100;.  nSelStep 
5120: 3d 20 6e 52 6f 77 2f 31 30 3b 0a 20 20 6e 53 65  = nRow/10;.  nSe
5130: 6c 54 65 73 74 20 3d 20 28 6e 53 65 6c 53 74 65  lTest = (nSelSte
5140: 70 20 3e 20 31 30 30 30 30 30 29 20 3f 20 31 30  p > 100000) ? 10
5150: 30 30 30 30 20 3a 20 6e 53 65 6c 53 74 65 70 3b  0000 : nSelStep;
5160: 0a 0a 20 20 61 54 69 6d 65 20 3d 20 6d 61 6c 6c  ..  aTime = mall
5170: 6f 63 28 73 69 7a 65 6f 66 28 69 6e 74 29 20 2a  oc(sizeof(int) *
5180: 20 41 72 72 61 79 53 69 7a 65 28 61 53 79 73 29   ArraySize(aSys)
5190: 20 2a 20 6e 52 6f 77 2f 6e 53 74 65 70 29 3b 0a   * nRow/nStep);.
51a0: 20 20 61 57 72 69 74 65 20 3d 20 6d 61 6c 6c 6f    aWrite = mallo
51b0: 63 28 73 69 7a 65 6f 66 28 69 6e 74 29 20 2a 20  c(sizeof(int) * 
51c0: 6e 52 6f 77 2f 6e 53 74 65 70 29 3b 0a 20 20 61  nRow/nStep);.  a
51d0: 53 65 6c 54 69 6d 65 20 3d 20 6d 61 6c 6c 6f 63  SelTime = malloc
51e0: 28 73 69 7a 65 6f 66 28 69 6e 74 29 20 2a 20 41  (sizeof(int) * A
51f0: 72 72 61 79 53 69 7a 65 28 61 53 79 73 29 20 2a  rraySize(aSys) *
5200: 20 6e 52 6f 77 2f 6e 53 65 6c 53 74 65 70 29 3b   nRow/nSelStep);
5210: 0a 0a 20 20 2f 2a 20 54 68 69 73 20 6c 6f 6f 70  ..  /* This loop
5220: 20 63 6f 6c 6c 65 63 74 73 20 74 68 65 20 49 4e   collects the IN
5230: 53 45 52 54 20 73 70 65 65 64 20 64 61 74 61 2e  SERT speed data.
5240: 20 2a 2f 0a 20 20 69 66 28 20 64 6f 57 72 69 74   */.  if( doWrit
5250: 65 54 65 73 74 20 29 7b 0a 20 20 20 20 70 72 69  eTest ){.    pri
5260: 6e 74 66 28 22 57 72 69 74 69 6e 67 20 6f 75 74  ntf("Writing out
5270: 70 75 74 20 74 6f 20 66 69 6c 65 20 5c 22 25 73  put to file \"%s
5280: 5c 22 2e 5c 6e 22 2c 20 20 7a 4f 75 74 29 3b 0a  \".\n",  zOut);.
5290: 0a 20 20 20 20 66 6f 72 28 6a 3d 30 3b 20 61 53  .    for(j=0; aS
52a0: 79 73 5b 6a 5d 2e 7a 4c 69 62 72 61 72 79 3b 20  ys[j].zLibrary; 
52b0: 6a 2b 2b 29 7b 0a 20 20 20 20 20 20 46 49 4c 45  j++){.      FILE
52c0: 20 2a 70 4c 6f 67 20 3d 20 30 3b 0a 20 20 20 20   *pLog = 0;.    
52d0: 20 20 54 65 73 74 44 62 20 2a 70 44 62 3b 20 20    TestDb *pDb;  
52e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
52f0: 2f 2a 20 44 61 74 61 62 61 73 65 20 62 65 69 6e  /* Database bein
5300: 67 20 74 65 73 74 65 64 20 2a 2f 0a 20 20 20 20  g tested */.    
5310: 20 20 6c 73 6d 5f 64 62 20 2a 70 4c 73 6d 3b 0a    lsm_db *pLsm;.
5320: 20 20 20 20 20 20 69 6e 74 20 69 44 6f 74 20 3d        int iDot =
5330: 20 30 3b 0a 20 20 0a 20 20 20 20 20 20 69 66 28   0;.  .      if(
5340: 20 28 28 31 3c 3c 6a 29 26 73 79 73 5f 6d 61 73   ((1<<j)&sys_mas
5350: 6b 29 3d 3d 30 20 29 20 63 6f 6e 74 69 6e 75 65  k)==0 ) continue
5360: 3b 0a 20 20 20 20 20 20 69 66 28 20 62 53 6c 65  ;.      if( bSle
5370: 65 70 20 26 26 20 6e 53 6c 65 65 70 20 29 20 73  ep && nSleep ) s
5380: 71 6c 69 74 65 33 5f 73 6c 65 65 70 28 6e 53 6c  qlite3_sleep(nSl
5390: 65 65 70 29 3b 0a 20 20 20 20 20 20 62 53 6c 65  eep);.      bSle
53a0: 65 70 20 3d 20 31 3b 0a 0a 20 20 20 20 20 20 74  ep = 1;..      t
53b0: 65 73 74 43 61 73 65 42 65 67 69 6e 28 26 72 63  estCaseBegin(&rc
53c0: 2c 20 30 2c 20 22 73 70 65 65 64 2e 69 6e 73 65  , 0, "speed.inse
53d0: 72 74 2e 25 73 22 2c 20 61 53 79 73 5b 6a 5d 2e  rt.%s", aSys[j].
53e0: 7a 4c 69 62 72 61 72 79 29 3b 0a 0a 20 20 20 20  zLibrary);..    
53f0: 20 20 72 63 20 3d 20 74 64 62 5f 6f 70 65 6e 28    rc = tdb_open(
5400: 61 53 79 73 5b 6a 5d 2e 7a 4c 69 62 72 61 72 79  aSys[j].zLibrary
5410: 2c 20 30 2c 20 31 2c 20 26 70 44 62 29 3b 0a 20  , 0, 1, &pDb);. 
5420: 20 20 20 20 20 69 66 28 20 72 63 20 29 20 72 65       if( rc ) re
5430: 74 75 72 6e 20 72 63 3b 0a 0a 20 20 20 20 20 20  turn rc;..      
5440: 70 4c 73 6d 20 3d 20 63 6f 6e 66 69 67 75 72 65  pLsm = configure
5450: 5f 6c 73 6d 5f 64 62 28 70 44 62 29 3b 0a 23 69  _lsm_db(pDb);.#i
5460: 66 20 30 0a 20 20 20 20 20 20 70 4c 6f 67 20 3d  f 0.      pLog =
5470: 20 66 6f 70 65 6e 28 22 2f 74 6d 70 2f 73 70 65   fopen("/tmp/spe
5480: 65 64 2e 6c 6f 67 22 2c 20 22 77 22 29 3b 0a 20  ed.log", "w");. 
5490: 20 20 20 20 20 74 64 62 5f 6c 73 6d 5f 77 72 69       tdb_lsm_wri
54a0: 74 65 5f 68 6f 6f 6b 28 70 44 62 2c 20 64 6f 5f  te_hook(pDb, do_
54b0: 73 70 65 65 64 5f 77 72 69 74 65 5f 68 6f 6f 6b  speed_write_hook
54c0: 32 2c 20 28 76 6f 69 64 20 2a 29 70 4c 6f 67 29  2, (void *)pLog)
54d0: 3b 0a 23 65 6e 64 69 66 0a 20 20 0a 20 20 20 20  ;.#endif.  .    
54e0: 20 20 74 65 73 74 54 69 6d 65 49 6e 69 74 28 29    testTimeInit()
54f0: 3b 0a 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b  ;.      for(i=0;
5500: 20 69 3c 6e 52 6f 77 3b 20 69 2b 3d 6e 53 74 65   i<nRow; i+=nSte
5510: 70 29 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20  p){.        int 
5520: 69 53 74 65 70 3b 0a 20 20 20 20 20 20 20 20 69  iStep;.        i
5530: 6e 74 20 6e 57 72 69 74 65 31 20 3d 20 30 2c 20  nt nWrite1 = 0, 
5540: 6e 57 72 69 74 65 32 20 3d 20 30 3b 0a 20 20 20  nWrite2 = 0;.   
5550: 20 20 20 20 20 74 65 73 74 43 61 73 65 50 72 6f       testCasePro
5560: 67 72 65 73 73 28 69 2c 20 6e 52 6f 77 2c 20 74  gress(i, nRow, t
5570: 65 73 74 43 61 73 65 4e 44 6f 74 28 29 2c 20 26  estCaseNDot(), &
5580: 69 44 6f 74 29 3b 0a 20 20 20 20 20 20 20 20 69  iDot);.        i
5590: 66 28 20 70 4c 73 6d 20 29 20 6c 73 6d 5f 69 6e  f( pLsm ) lsm_in
55a0: 66 6f 28 70 4c 73 6d 2c 20 4c 53 4d 5f 49 4e 46  fo(pLsm, LSM_INF
55b0: 4f 5f 4e 57 52 49 54 45 2c 20 26 6e 57 72 69 74  O_NWRITE, &nWrit
55c0: 65 31 29 3b 0a 20 20 20 20 20 20 20 20 66 6f 72  e1);.        for
55d0: 28 69 53 74 65 70 3d 30 3b 20 69 53 74 65 70 3c  (iStep=0; iStep<
55e0: 6e 53 74 65 70 3b 20 69 53 74 65 70 2b 2b 29 7b  nStep; iStep++){
55f0: 0a 20 20 20 20 20 20 20 20 20 20 75 33 32 20 61  .          u32 a
5600: 4b 65 79 5b 34 5d 3b 20 20 20 20 20 20 20 20 20  Key[4];         
5610: 20 20 20 20 20 20 20 20 20 2f 2a 20 31 36 2d 62           /* 16-b
5620: 79 74 65 20 6b 65 79 20 2a 2f 0a 20 20 20 20 20  yte key */.     
5630: 20 20 20 20 20 75 33 32 20 61 56 61 6c 5b 32 35       u32 aVal[25
5640: 5d 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ];              
5650: 20 20 20 2f 2a 20 31 30 30 20 62 79 74 65 20 76     /* 100 byte v
5660: 61 6c 75 65 20 2a 2f 0a 20 20 20 20 20 20 20 20  alue */.        
5670: 20 20 74 65 73 74 50 72 6e 67 41 72 72 61 79 28    testPrngArray(
5680: 69 2b 69 53 74 65 70 2c 20 61 4b 65 79 2c 20 41  i+iStep, aKey, A
5690: 72 72 61 79 53 69 7a 65 28 61 4b 65 79 29 29 3b  rraySize(aKey));
56a0: 0a 20 20 20 20 20 20 20 20 20 20 74 65 73 74 50  .          testP
56b0: 72 6e 67 41 72 72 61 79 28 69 2b 69 53 74 65 70  rngArray(i+iStep
56c0: 2c 20 61 56 61 6c 2c 20 41 72 72 61 79 53 69 7a  , aVal, ArraySiz
56d0: 65 28 61 56 61 6c 29 29 3b 0a 20 20 20 20 20 20  e(aVal));.      
56e0: 20 20 20 20 72 63 20 3d 20 74 64 62 5f 77 72 69      rc = tdb_wri
56f0: 74 65 28 70 44 62 2c 20 61 4b 65 79 2c 20 73 69  te(pDb, aKey, si
5700: 7a 65 6f 66 28 61 4b 65 79 29 2c 20 61 56 61 6c  zeof(aKey), aVal
5710: 2c 20 73 69 7a 65 6f 66 28 61 56 61 6c 29 29 3b  , sizeof(aVal));
5720: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
5730: 20 20 20 61 54 69 6d 65 5b 28 6a 2a 6e 52 6f 77     aTime[(j*nRow
5740: 2b 69 29 2f 6e 53 74 65 70 5d 20 3d 20 74 65 73  +i)/nStep] = tes
5750: 74 54 69 6d 65 47 65 74 28 29 3b 0a 20 20 20 20  tTimeGet();.    
5760: 20 20 20 20 69 66 28 20 70 4c 73 6d 20 29 20 6c      if( pLsm ) l
5770: 73 6d 5f 69 6e 66 6f 28 70 4c 73 6d 2c 20 4c 53  sm_info(pLsm, LS
5780: 4d 5f 49 4e 46 4f 5f 4e 57 52 49 54 45 2c 20 26  M_INFO_NWRITE, &
5790: 6e 57 72 69 74 65 32 29 3b 0a 20 20 20 20 20 20  nWrite2);.      
57a0: 20 20 61 57 72 69 74 65 5b 69 2f 6e 53 74 65 70    aWrite[i/nStep
57b0: 5d 20 3d 20 6e 57 72 69 74 65 32 20 2d 20 6e 57  ] = nWrite2 - nW
57c0: 72 69 74 65 31 3b 0a 20 20 20 20 20 20 7d 0a 0a  rite1;.      }..
57d0: 20 20 20 20 20 20 74 64 62 5f 63 6c 6f 73 65 28        tdb_close(
57e0: 70 44 62 29 3b 0a 20 20 20 20 20 20 69 66 28 20  pDb);.      if( 
57f0: 70 4c 6f 67 20 29 20 66 63 6c 6f 73 65 28 70 4c  pLog ) fclose(pL
5800: 6f 67 29 3b 0a 20 20 20 20 20 20 74 65 73 74 43  og);.      testC
5810: 61 73 65 46 69 6e 69 73 68 28 72 63 29 3b 0a 20  aseFinish(rc);. 
5820: 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 2f 2a 20 54     }.  }..  /* T
5830: 68 69 73 20 6c 6f 6f 70 20 63 6f 6c 6c 65 63 74  his loop collect
5840: 73 20 74 68 65 20 53 45 4c 45 43 54 20 73 70 65  s the SELECT spe
5850: 65 64 20 64 61 74 61 2e 20 2a 2f 0a 20 20 69 66  ed data. */.  if
5860: 28 20 64 6f 52 65 61 64 54 65 73 74 20 29 7b 0a  ( doReadTest ){.
5870: 20 20 20 20 66 6f 72 28 6a 3d 30 3b 20 61 53 79      for(j=0; aSy
5880: 73 5b 6a 5d 2e 7a 4c 69 62 72 61 72 79 3b 20 6a  s[j].zLibrary; j
5890: 2b 2b 29 7b 0a 20 20 20 20 20 20 69 6e 74 20 69  ++){.      int i
58a0: 44 6f 74 20 3d 20 30 3b 0a 20 20 20 20 20 20 54  Dot = 0;.      T
58b0: 65 73 74 44 62 20 2a 70 44 62 3b 20 20 20 20 20  estDb *pDb;     
58c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
58d0: 44 61 74 61 62 61 73 65 20 62 65 69 6e 67 20 74  Database being t
58e0: 65 73 74 65 64 20 2a 2f 0a 0a 20 20 20 20 20 20  ested */..      
58f0: 69 66 28 20 28 28 31 3c 3c 6a 29 26 73 79 73 5f  if( ((1<<j)&sys_
5900: 6d 61 73 6b 29 3d 3d 30 20 29 20 63 6f 6e 74 69  mask)==0 ) conti
5910: 6e 75 65 3b 0a 20 20 20 20 20 20 69 66 28 20 62  nue;.      if( b
5920: 53 6c 65 65 70 20 26 26 20 6e 53 6c 65 65 70 20  Sleep && nSleep 
5930: 29 20 73 71 6c 69 74 65 33 5f 73 6c 65 65 70 28  ) sqlite3_sleep(
5940: 6e 53 6c 65 65 70 29 3b 0a 20 20 20 20 20 20 62  nSleep);.      b
5950: 53 6c 65 65 70 20 3d 20 31 3b 0a 0a 20 20 20 20  Sleep = 1;..    
5960: 20 20 74 65 73 74 43 61 73 65 42 65 67 69 6e 28    testCaseBegin(
5970: 26 72 63 2c 20 30 2c 20 22 73 70 65 65 64 2e 73  &rc, 0, "speed.s
5980: 65 6c 65 63 74 2e 25 73 22 2c 20 61 53 79 73 5b  elect.%s", aSys[
5990: 6a 5d 2e 7a 4c 69 62 72 61 72 79 29 3b 0a 0a 20  j].zLibrary);.. 
59a0: 20 20 20 20 20 69 66 28 20 64 6f 57 72 69 74 65       if( doWrite
59b0: 54 65 73 74 20 29 7b 0a 20 20 20 20 20 20 20 20  Test ){.        
59c0: 72 63 20 3d 20 74 64 62 5f 6f 70 65 6e 28 61 53  rc = tdb_open(aS
59d0: 79 73 5b 6a 5d 2e 7a 4c 69 62 72 61 72 79 2c 20  ys[j].zLibrary, 
59e0: 30 2c 20 31 2c 20 26 70 44 62 29 3b 0a 20 20 20  0, 1, &pDb);.   
59f0: 20 20 20 20 20 69 66 28 20 72 63 20 29 20 72 65       if( rc ) re
5a00: 74 75 72 6e 20 72 63 3b 0a 20 20 20 20 20 20 20  turn rc;.       
5a10: 20 63 6f 6e 66 69 67 75 72 65 5f 6c 73 6d 5f 64   configure_lsm_d
5a20: 62 28 70 44 62 29 3b 0a 0a 20 20 20 20 20 20 20  b(pDb);..       
5a30: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 6e 52 6f 77   for(i=0; i<nRow
5a40: 3b 20 69 2b 3d 6e 53 65 6c 53 74 65 70 29 7b 0a  ; i+=nSelStep){.
5a50: 20 20 20 20 20 20 20 20 20 20 69 6e 74 20 69 53            int iS
5a60: 74 65 70 3b 0a 20 20 20 20 20 20 20 20 20 20 69  tep;.          i
5a70: 6e 74 20 69 53 65 6c 3b 0a 20 20 20 20 20 20 20  nt iSel;.       
5a80: 20 20 20 74 65 73 74 43 61 73 65 50 72 6f 67 72     testCaseProgr
5a90: 65 73 73 28 69 2c 20 6e 52 6f 77 2c 20 74 65 73  ess(i, nRow, tes
5aa0: 74 43 61 73 65 4e 44 6f 74 28 29 2c 20 26 69 44  tCaseNDot(), &iD
5ab0: 6f 74 29 3b 0a 20 20 20 20 20 20 20 20 20 20 66  ot);.          f
5ac0: 6f 72 28 69 53 74 65 70 3d 30 3b 20 69 53 74 65  or(iStep=0; iSte
5ad0: 70 3c 6e 53 65 6c 53 74 65 70 3b 20 69 53 74 65  p<nSelStep; iSte
5ae0: 70 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 20 20  p++){.          
5af0: 20 20 75 33 32 20 61 4b 65 79 5b 34 5d 3b 20 20    u32 aKey[4];  
5b00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5b10: 2f 2a 20 31 36 2d 62 79 74 65 20 6b 65 79 20 2a  /* 16-byte key *
5b20: 2f 0a 20 20 20 20 20 20 20 20 20 20 20 20 75 33  /.            u3
5b30: 32 20 61 56 61 6c 5b 32 35 5d 3b 20 20 20 20 20  2 aVal[25];     
5b40: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 31              /* 1
5b50: 30 30 20 62 79 74 65 20 76 61 6c 75 65 20 2a 2f  00 byte value */
5b60: 0a 20 20 20 20 20 20 20 20 20 20 20 20 74 65 73  .            tes
5b70: 74 50 72 6e 67 41 72 72 61 79 28 69 2b 69 53 74  tPrngArray(i+iSt
5b80: 65 70 2c 20 61 4b 65 79 2c 20 41 72 72 61 79 53  ep, aKey, ArrayS
5b90: 69 7a 65 28 61 4b 65 79 29 29 3b 0a 20 20 20 20  ize(aKey));.    
5ba0: 20 20 20 20 20 20 20 20 74 65 73 74 50 72 6e 67          testPrng
5bb0: 41 72 72 61 79 28 69 2b 69 53 74 65 70 2c 20 61  Array(i+iStep, a
5bc0: 56 61 6c 2c 20 41 72 72 61 79 53 69 7a 65 28 61  Val, ArraySize(a
5bd0: 56 61 6c 29 29 3b 0a 20 20 20 20 20 20 20 20 20  Val));.         
5be0: 20 20 20 72 63 20 3d 20 74 64 62 5f 77 72 69 74     rc = tdb_writ
5bf0: 65 28 70 44 62 2c 20 61 4b 65 79 2c 20 73 69 7a  e(pDb, aKey, siz
5c00: 65 6f 66 28 61 4b 65 79 29 2c 20 61 56 61 6c 2c  eof(aKey), aVal,
5c10: 20 73 69 7a 65 6f 66 28 61 56 61 6c 29 29 3b 0a   sizeof(aVal));.
5c20: 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20            }.    
5c30: 0a 20 20 20 20 20 20 20 20 20 20 74 65 73 74 54  .          testT
5c40: 69 6d 65 49 6e 69 74 28 29 3b 0a 20 20 20 20 20  imeInit();.     
5c50: 20 20 20 20 20 66 6f 72 28 69 53 65 6c 3d 30 3b       for(iSel=0;
5c60: 20 69 53 65 6c 3c 6e 53 65 6c 54 65 73 74 3b 20   iSel<nSelTest; 
5c70: 69 53 65 6c 2b 2b 29 7b 0a 20 20 20 20 20 20 20  iSel++){.       
5c80: 20 20 20 20 20 76 6f 69 64 20 2a 70 44 75 6d 6d       void *pDumm
5c90: 79 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 69  y;.            i
5ca0: 6e 74 20 6e 44 75 6d 6d 79 3b 0a 20 20 20 20 20  nt nDummy;.     
5cb0: 20 20 20 20 20 20 20 75 33 32 20 69 4b 65 79 3b         u32 iKey;
5cc0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 75 33 32  .            u32
5cd0: 20 61 4b 65 79 5b 34 5d 3b 20 20 20 20 20 20 20   aKey[4];       
5ce0: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 31 36             /* 16
5cf0: 2d 62 79 74 65 20 6b 65 79 20 2a 2f 0a 20 20 20  -byte key */.   
5d00: 20 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 4b   .            iK
5d10: 65 79 20 3d 20 74 65 73 74 50 72 6e 67 56 61 6c  ey = testPrngVal
5d20: 75 65 28 69 53 65 6c 29 20 25 20 28 69 2b 6e 53  ue(iSel) % (i+nS
5d30: 65 6c 53 74 65 70 29 3b 0a 20 20 20 20 20 20 20  elStep);.       
5d40: 20 20 20 20 20 74 65 73 74 50 72 6e 67 41 72 72       testPrngArr
5d50: 61 79 28 69 4b 65 79 2c 20 61 4b 65 79 2c 20 41  ay(iKey, aKey, A
5d60: 72 72 61 79 53 69 7a 65 28 61 4b 65 79 29 29 3b  rraySize(aKey));
5d70: 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 63 20  .            rc 
5d80: 3d 20 74 64 62 5f 66 65 74 63 68 28 70 44 62 2c  = tdb_fetch(pDb,
5d90: 20 61 4b 65 79 2c 20 73 69 7a 65 6f 66 28 61 4b   aKey, sizeof(aK
5da0: 65 79 29 2c 20 26 70 44 75 6d 6d 79 2c 20 26 6e  ey), &pDummy, &n
5db0: 44 75 6d 6d 79 29 3b 0a 20 20 20 20 20 20 20 20  Dummy);.        
5dc0: 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 61 53    }.          aS
5dd0: 65 6c 54 69 6d 65 5b 28 6a 2a 6e 52 6f 77 2b 69  elTime[(j*nRow+i
5de0: 29 2f 6e 53 65 6c 53 74 65 70 5d 20 3d 20 74 65  )/nSelStep] = te
5df0: 73 74 54 69 6d 65 47 65 74 28 29 3b 0a 20 20 20  stTimeGet();.   
5e00: 20 20 20 20 20 20 20 74 64 62 5f 66 65 74 63 68         tdb_fetch
5e10: 28 70 44 62 2c 20 30 2c 20 30 2c 20 30 2c 20 30  (pDb, 0, 0, 0, 0
5e20: 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20  );.        }.   
5e30: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
5e40: 20 20 69 6e 74 20 74 3b 0a 20 20 20 20 20 20 20    int t;.       
5e50: 20 69 6e 74 20 69 53 65 6c 3b 0a 0a 20 20 20 20   int iSel;..    
5e60: 20 20 20 20 72 63 20 3d 20 74 64 62 5f 6f 70 65      rc = tdb_ope
5e70: 6e 28 61 53 79 73 5b 6a 5d 2e 7a 4c 69 62 72 61  n(aSys[j].zLibra
5e80: 72 79 2c 20 30 2c 20 30 2c 20 26 70 44 62 29 3b  ry, 0, 0, &pDb);
5e90: 0a 20 20 20 20 20 20 20 20 63 6f 6e 66 69 67 75  .        configu
5ea0: 72 65 5f 6c 73 6d 5f 64 62 28 70 44 62 29 3b 0a  re_lsm_db(pDb);.
5eb0: 0a 20 20 20 20 20 20 20 20 74 65 73 74 54 69 6d  .        testTim
5ec0: 65 49 6e 69 74 28 29 3b 0a 20 20 20 20 20 20 20  eInit();.       
5ed0: 20 66 6f 72 28 69 53 65 6c 3d 30 3b 20 72 63 3d   for(iSel=0; rc=
5ee0: 3d 4c 53 4d 5f 4f 4b 20 26 26 20 69 53 65 6c 3c  =LSM_OK && iSel<
5ef0: 6e 53 65 6c 54 65 73 74 3b 20 69 53 65 6c 2b 2b  nSelTest; iSel++
5f00: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 76 6f 69  ){.          voi
5f10: 64 20 2a 70 44 75 6d 6d 79 3b 0a 20 20 20 20 20  d *pDummy;.     
5f20: 20 20 20 20 20 69 6e 74 20 6e 44 75 6d 6d 79 3b       int nDummy;
5f30: 0a 20 20 20 20 20 20 20 20 20 20 75 33 32 20 69  .          u32 i
5f40: 4b 65 79 3b 0a 20 20 20 20 20 20 20 20 20 20 75  Key;.          u
5f50: 33 32 20 61 4b 65 79 5b 34 5d 3b 20 20 20 20 20  32 aKey[4];     
5f60: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
5f70: 31 36 2d 62 79 74 65 20 6b 65 79 20 2a 2f 0a 23  16-byte key */.#
5f80: 69 66 6e 64 65 66 20 4e 44 45 42 55 47 0a 20 20  ifndef NDEBUG.  
5f90: 20 20 20 20 20 20 20 20 75 33 32 20 61 56 61 6c          u32 aVal
5fa0: 5b 32 35 5d 3b 20 20 20 20 20 20 20 20 20 20 20  [25];           
5fb0: 20 20 20 20 20 20 2f 2a 20 31 30 30 20 62 79 74        /* 100 byt
5fc0: 65 20 76 61 6c 75 65 20 2a 2f 0a 23 65 6e 64 69  e value */.#endi
5fd0: 66 0a 0a 20 20 20 20 20 20 20 20 20 20 74 65 73  f..          tes
5fe0: 74 43 61 73 65 50 72 6f 67 72 65 73 73 28 69 53  tCaseProgress(iS
5ff0: 65 6c 2c 20 6e 53 65 6c 54 65 73 74 2c 20 74 65  el, nSelTest, te
6000: 73 74 43 61 73 65 4e 44 6f 74 28 29 2c 20 26 69  stCaseNDot(), &i
6010: 44 6f 74 29 3b 0a 20 20 20 20 0a 20 20 20 20 20  Dot);.    .     
6020: 20 20 20 20 20 69 4b 65 79 20 3d 20 74 65 73 74       iKey = test
6030: 50 72 6e 67 56 61 6c 75 65 28 69 53 65 6c 29 20  PrngValue(iSel) 
6040: 25 20 6e 52 6f 77 3b 0a 20 20 20 20 20 20 20 20  % nRow;.        
6050: 20 20 74 65 73 74 50 72 6e 67 41 72 72 61 79 28    testPrngArray(
6060: 69 4b 65 79 2c 20 61 4b 65 79 2c 20 41 72 72 61  iKey, aKey, Arra
6070: 79 53 69 7a 65 28 61 4b 65 79 29 29 3b 0a 20 20  ySize(aKey));.  
6080: 20 20 20 20 20 20 20 20 72 63 20 3d 20 74 64 62          rc = tdb
6090: 5f 66 65 74 63 68 28 70 44 62 2c 20 61 4b 65 79  _fetch(pDb, aKey
60a0: 2c 20 73 69 7a 65 6f 66 28 61 4b 65 79 29 2c 20  , sizeof(aKey), 
60b0: 26 70 44 75 6d 6d 79 2c 20 26 6e 44 75 6d 6d 79  &pDummy, &nDummy
60c0: 29 3b 0a 0a 23 69 66 6e 64 65 66 20 4e 44 45 42  );..#ifndef NDEB
60d0: 55 47 0a 20 20 20 20 20 20 20 20 20 20 74 65 73  UG.          tes
60e0: 74 50 72 6e 67 41 72 72 61 79 28 69 4b 65 79 2c  tPrngArray(iKey,
60f0: 20 61 56 61 6c 2c 20 41 72 72 61 79 53 69 7a 65   aVal, ArraySize
6100: 28 61 56 61 6c 29 29 3b 0a 20 20 20 20 20 20 20  (aVal));.       
6110: 20 20 20 61 73 73 65 72 74 28 20 6e 44 75 6d 6d     assert( nDumm
6120: 79 3d 3d 31 30 30 20 26 26 20 6d 65 6d 63 6d 70  y==100 && memcmp
6130: 28 61 56 61 6c 2c 20 70 44 75 6d 6d 79 2c 20 31  (aVal, pDummy, 1
6140: 30 30 29 3d 3d 30 20 29 3b 0a 23 65 6e 64 69 66  00)==0 );.#endif
6150: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
6160: 20 20 20 69 66 28 20 72 63 21 3d 4c 53 4d 5f 4f     if( rc!=LSM_O
6170: 4b 20 29 20 72 65 74 75 72 6e 20 72 63 3b 0a 0a  K ) return rc;..
6180: 20 20 20 20 20 20 20 20 74 20 3d 20 74 65 73 74          t = test
6190: 54 69 6d 65 47 65 74 28 29 3b 0a 20 20 20 20 20  TimeGet();.     
61a0: 20 20 20 74 64 62 5f 66 65 74 63 68 28 70 44 62     tdb_fetch(pDb
61b0: 2c 20 30 2c 20 30 2c 20 30 2c 20 30 29 3b 0a 0a  , 0, 0, 0, 0);..
61c0: 20 20 20 20 20 20 20 20 70 72 69 6e 74 66 28 22          printf("
61d0: 25 73 3a 20 25 64 20 73 65 6c 65 63 74 73 2f 73  %s: %d selects/s
61e0: 65 63 6f 6e 64 5c 6e 22 2c 20 0a 20 20 20 20 20  econd\n", .     
61f0: 20 20 20 20 20 20 20 61 53 79 73 5b 6a 5d 2e 7a         aSys[j].z
6200: 4c 69 62 72 61 72 79 2c 20 28 69 6e 74 29 28 28  Library, (int)((
6210: 64 6f 75 62 6c 65 29 6e 53 65 6c 54 65 73 74 2a  double)nSelTest*
6220: 31 30 30 30 2e 30 2f 74 29 0a 20 20 20 20 20 20  1000.0/t).      
6230: 20 20 29 3b 0a 20 20 20 20 20 20 7d 0a 0a 20 20    );.      }..  
6240: 20 20 20 20 74 64 62 5f 63 6c 6f 73 65 28 70 44      tdb_close(pD
6250: 62 29 3b 0a 20 20 20 20 20 20 74 65 73 74 43 61  b);.      testCa
6260: 73 65 46 69 6e 69 73 68 28 72 63 29 3b 0a 20 20  seFinish(rc);.  
6270: 20 20 7d 0a 20 20 7d 0a 0a 0a 20 20 69 66 28 20    }.  }...  if( 
6280: 64 6f 57 72 69 74 65 54 65 73 74 20 29 7b 0a 20  doWriteTest ){. 
6290: 20 20 20 46 49 4c 45 20 2a 70 4f 75 74 20 3d 20     FILE *pOut = 
62a0: 66 6f 70 65 6e 28 7a 4f 75 74 2c 20 22 77 22 29  fopen(zOut, "w")
62b0: 3b 0a 20 20 20 20 69 66 28 20 21 70 4f 75 74 20  ;.    if( !pOut 
62c0: 29 7b 0a 20 20 20 20 20 20 70 72 69 6e 74 66 28  ){.      printf(
62d0: 22 66 6f 70 65 6e 28 5c 22 25 73 5c 22 2c 20 5c  "fopen(\"%s\", \
62e0: 22 77 5c 22 29 3a 20 25 73 5c 6e 22 2c 20 7a 4f  "w\"): %s\n", zO
62f0: 75 74 2c 20 73 74 72 65 72 72 6f 72 28 65 72 72  ut, strerror(err
6300: 6e 6f 29 29 3b 0a 20 20 20 20 20 20 72 65 74 75  no));.      retu
6310: 72 6e 20 31 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  rn 1;.    }..   
6320: 20 66 70 72 69 6e 74 66 28 70 4f 75 74 2c 20 22   fprintf(pOut, "
6330: 73 65 74 20 78 6c 61 62 65 6c 20 5c 22 52 6f 77  set xlabel \"Row
6340: 73 20 49 6e 73 65 72 74 65 64 5c 22 5c 6e 22 29  s Inserted\"\n")
6350: 3b 0a 20 20 20 20 66 70 72 69 6e 74 66 28 70 4f  ;.    fprintf(pO
6360: 75 74 2c 20 22 73 65 74 20 79 6c 61 62 65 6c 20  ut, "set ylabel 
6370: 5c 22 49 6e 73 65 72 74 73 20 70 65 72 20 73 65  \"Inserts per se
6380: 63 6f 6e 64 5c 22 5c 6e 22 29 3b 0a 20 20 20 20  cond\"\n");.    
6390: 69 66 28 20 64 6f 52 65 61 64 54 65 73 74 20 29  if( doReadTest )
63a0: 7b 0a 20 20 20 20 20 20 66 70 72 69 6e 74 66 28  {.      fprintf(
63b0: 70 4f 75 74 2c 20 22 73 65 74 20 79 32 6c 61 62  pOut, "set y2lab
63c0: 65 6c 20 5c 22 53 65 6c 65 63 74 73 20 70 65 72  el \"Selects per
63d0: 20 73 65 63 6f 6e 64 5c 22 5c 6e 22 29 3b 0a 20   second\"\n");. 
63e0: 20 20 20 7d 65 6c 73 65 20 69 66 28 20 73 79 73     }else if( sys
63f0: 5f 6d 61 73 6b 3d 3d 28 31 3c 3c 32 29 20 29 7b  _mask==(1<<2) ){
6400: 0a 20 20 20 20 20 20 66 70 72 69 6e 74 66 28 70  .      fprintf(p
6410: 4f 75 74 2c 20 22 73 65 74 20 79 32 6c 61 62 65  Out, "set y2labe
6420: 6c 20 5c 22 50 61 67 65 20 77 72 69 74 65 73 20  l \"Page writes 
6430: 70 65 72 20 69 6e 73 65 72 74 5c 22 5c 6e 22 29  per insert\"\n")
6440: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 66 70 72 69  ;.    }.    fpri
6450: 6e 74 66 28 70 4f 75 74 2c 20 22 73 65 74 20 79  ntf(pOut, "set y
6460: 72 61 6e 67 65 20 5b 30 3a 2a 5d 5c 6e 22 29 3b  range [0:*]\n");
6470: 0a 20 20 20 20 66 70 72 69 6e 74 66 28 70 4f 75  .    fprintf(pOu
6480: 74 2c 20 22 73 65 74 20 79 32 72 61 6e 67 65 20  t, "set y2range 
6490: 5b 30 3a 2a 5d 5c 6e 22 29 3b 0a 20 20 20 20 66  [0:*]\n");.    f
64a0: 70 72 69 6e 74 66 28 70 4f 75 74 2c 20 22 73 65  printf(pOut, "se
64b0: 74 20 78 72 61 6e 67 65 20 5b 25 64 3a 2a 5d 5c  t xrange [%d:*]\
64c0: 6e 22 2c 20 4d 41 58 28 6e 53 74 65 70 2c 20 6e  n", MAX(nStep, n
64d0: 52 6f 77 2f 32 30 29 20 29 3b 0a 20 20 20 20 66  Row/20) );.    f
64e0: 70 72 69 6e 74 66 28 70 4f 75 74 2c 20 22 73 65  printf(pOut, "se
64f0: 74 20 79 74 69 63 73 20 6e 6f 6d 69 72 72 6f 72  t ytics nomirror
6500: 5c 6e 22 29 3b 0a 20 20 20 20 66 70 72 69 6e 74  \n");.    fprint
6510: 66 28 70 4f 75 74 2c 20 22 73 65 74 20 79 32 74  f(pOut, "set y2t
6520: 69 63 73 20 6e 6f 6d 69 72 72 6f 72 5c 6e 22 29  ics nomirror\n")
6530: 3b 0a 20 20 20 20 66 70 72 69 6e 74 66 28 70 4f  ;.    fprintf(pO
6540: 75 74 2c 20 22 73 65 74 20 6b 65 79 20 62 6f 78  ut, "set key box
6550: 20 6c 77 20 30 2e 30 31 5c 6e 22 29 3b 0a 20 20   lw 0.01\n");.  
6560: 20 20 66 70 72 69 6e 74 66 28 70 4f 75 74 2c 20    fprintf(pOut, 
6570: 22 70 6c 6f 74 20 22 29 3b 0a 20 20 0a 20 20 20  "plot ");.  .   
6580: 20 66 6f 72 28 6a 3d 30 3b 20 61 53 79 73 5b 6a   for(j=0; aSys[j
6590: 5d 2e 7a 4c 69 62 72 61 72 79 3b 20 6a 2b 2b 29  ].zLibrary; j++)
65a0: 7b 0a 20 20 20 20 20 20 69 66 28 20 28 31 3c 3c  {.      if( (1<<
65b0: 6a 29 26 73 79 73 5f 6d 61 73 6b 20 29 7b 0a 20  j)&sys_mask ){. 
65c0: 20 20 20 20 20 20 20 63 6f 6e 73 74 20 63 68 61         const cha
65d0: 72 20 2a 7a 4c 69 62 20 3d 20 61 53 79 73 5b 6a  r *zLib = aSys[j
65e0: 5d 2e 7a 4c 69 62 72 61 72 79 3b 0a 20 20 20 20  ].zLibrary;.    
65f0: 20 20 20 20 66 70 72 69 6e 74 66 28 70 4f 75 74      fprintf(pOut
6600: 2c 20 22 25 73 5c 22 2d 5c 22 20 74 69 20 5c 22  , "%s\"-\" ti \"
6610: 25 73 20 49 4e 53 45 52 54 5c 22 20 77 69 74 68  %s INSERT\" with
6620: 20 6c 69 6e 65 73 20 6c 63 20 72 67 62 20 5c 22   lines lc rgb \"
6630: 25 73 5c 22 20 22 2c 20 0a 20 20 20 20 20 20 20  %s\" ", .       
6640: 20 20 20 20 20 28 69 73 46 69 72 73 74 3f 22 22       (isFirst?""
6650: 3a 22 2c 20 22 29 2c 20 7a 4c 69 62 2c 20 61 53  :", "), zLib, aS
6660: 79 73 5b 6a 5d 2e 7a 43 6f 6c 6f 72 0a 20 20 20  ys[j].zColor.   
6670: 20 20 20 20 20 29 3b 0a 20 20 20 20 20 20 20 20       );.        
6680: 69 66 28 20 64 6f 52 65 61 64 54 65 73 74 20 29  if( doReadTest )
6690: 7b 0a 20 20 20 20 20 20 20 20 20 20 66 70 72 69  {.          fpri
66a0: 6e 74 66 28 70 4f 75 74 2c 20 22 2c 20 5c 22 2d  ntf(pOut, ", \"-
66b0: 5c 22 20 74 69 20 5c 22 25 73 20 53 45 4c 45 43  \" ti \"%s SELEC
66c0: 54 5c 22 20 22 0a 20 20 20 20 20 20 20 20 20 20  T\" ".          
66d0: 20 20 20 20 20 20 20 22 61 78 69 73 20 78 31 79         "axis x1y
66e0: 32 20 77 69 74 68 20 70 6f 69 6e 74 73 20 6c 77  2 with points lw
66f0: 20 33 20 6c 63 20 72 67 62 20 5c 22 25 73 5c 22   3 lc rgb \"%s\"
6700: 22 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ".              
6710: 2c 20 7a 4c 69 62 2c 20 61 53 79 73 5b 6a 5d 2e  , zLib, aSys[j].
6720: 7a 43 6f 6c 6f 72 0a 20 20 20 20 20 20 20 20 20  zColor.         
6730: 20 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20   );.        }.  
6740: 20 20 20 20 20 20 69 73 46 69 72 73 74 20 3d 20        isFirst = 
6750: 30 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d  0;.      }.    }
6760: 0a 0a 20 20 20 20 61 73 73 65 72 74 28 20 73 74  ..    assert( st
6770: 72 63 6d 70 28 61 53 79 73 5b 32 5d 2e 7a 4c 69  rcmp(aSys[2].zLi
6780: 62 72 61 72 79 2c 20 22 6c 73 6d 22 29 3d 3d 30  brary, "lsm")==0
6790: 20 29 3b 0a 20 20 20 20 69 66 28 20 73 79 73 5f   );.    if( sys_
67a0: 6d 61 73 6b 3d 3d 28 31 3c 3c 32 29 20 26 26 20  mask==(1<<2) && 
67b0: 21 64 6f 52 65 61 64 54 65 73 74 20 29 7b 0a 20  !doReadTest ){. 
67c0: 20 20 20 20 20 66 70 72 69 6e 74 66 28 70 4f 75       fprintf(pOu
67d0: 74 2c 20 22 2c 20 5c 22 2d 5c 22 20 74 69 20 5c  t, ", \"-\" ti \
67e0: 22 6c 73 6d 20 70 61 67 65 73 20 77 72 69 74 74  "lsm pages writt
67f0: 65 6e 5c 22 20 22 0a 20 20 20 20 20 20 20 20 22  en\" ".        "
6800: 61 78 69 73 20 78 31 79 32 20 77 69 74 68 20 62  axis x1y2 with b
6810: 6f 78 65 73 20 6c 77 20 31 20 6c 63 20 72 67 62  oxes lw 1 lc rgb
6820: 20 5c 22 67 72 65 79 5c 22 22 0a 20 20 20 20 20   \"grey\"".     
6830: 20 29 3b 0a 20 20 20 20 7d 0a 20 20 0a 20 20 20   );.    }.  .   
6840: 20 66 70 72 69 6e 74 66 28 70 4f 75 74 2c 20 22   fprintf(pOut, "
6850: 5c 6e 22 29 3b 0a 20 20 0a 20 20 20 20 66 6f 72  \n");.  .    for
6860: 28 6a 3d 30 3b 20 61 53 79 73 5b 6a 5d 2e 7a 4c  (j=0; aSys[j].zL
6870: 69 62 72 61 72 79 3b 20 6a 2b 2b 29 7b 0a 20 20  ibrary; j++){.  
6880: 20 20 20 20 69 66 28 20 28 28 31 3c 3c 6a 29 26      if( ((1<<j)&
6890: 73 79 73 5f 6d 61 73 6b 29 3d 3d 30 20 29 20 63  sys_mask)==0 ) c
68a0: 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 20 20 66  ontinue;.      f
68b0: 70 72 69 6e 74 66 28 70 4f 75 74 2c 20 22 23 20  printf(pOut, "# 
68c0: 52 6f 77 73 20 20 20 20 49 6e 73 65 72 74 73 20  Rows    Inserts 
68d0: 70 65 72 20 73 65 63 6f 6e 64 5c 6e 22 29 3b 0a  per second\n");.
68e0: 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b 20 69        for(i=0; i
68f0: 3c 6e 52 6f 77 3b 20 69 2b 3d 6e 53 74 65 70 29  <nRow; i+=nStep)
6900: 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20 69 54  {.        int iT
6910: 69 6d 65 20 3d 20 61 54 69 6d 65 5b 28 6a 2a 6e  ime = aTime[(j*n
6920: 52 6f 77 2b 69 29 2f 6e 53 74 65 70 5d 3b 0a 20  Row+i)/nStep];. 
6930: 20 20 20 20 20 20 20 69 6e 74 20 69 70 73 20 3d         int ips =
6940: 20 28 69 6e 74 29 28 28 69 2b 6e 53 74 65 70 29   (int)((i+nStep)
6950: 2a 31 30 30 30 2e 30 20 2f 20 28 64 6f 75 62 6c  *1000.0 / (doubl
6960: 65 29 69 54 69 6d 65 29 3b 0a 20 20 20 20 20 20  e)iTime);.      
6970: 20 20 66 70 72 69 6e 74 66 28 70 4f 75 74 2c 20    fprintf(pOut, 
6980: 22 25 64 20 25 64 5c 6e 22 2c 20 69 2b 6e 53 74  "%d %d\n", i+nSt
6990: 65 70 2c 20 69 70 73 29 3b 0a 20 20 20 20 20 20  ep, ips);.      
69a0: 7d 0a 20 20 20 20 20 20 66 70 72 69 6e 74 66 28  }.      fprintf(
69b0: 70 4f 75 74 2c 20 22 65 6e 64 5c 6e 22 29 3b 0a  pOut, "end\n");.
69c0: 20 20 0a 20 20 20 20 20 20 69 66 28 20 64 6f 52    .      if( doR
69d0: 65 61 64 54 65 73 74 20 29 7b 0a 20 20 20 20 20  eadTest ){.     
69e0: 20 20 20 66 70 72 69 6e 74 66 28 70 4f 75 74 2c     fprintf(pOut,
69f0: 20 22 23 20 52 6f 77 73 20 20 20 20 53 65 6c 65   "# Rows    Sele
6a00: 63 74 73 20 70 65 72 20 73 65 63 6f 6e 64 5c 6e  cts per second\n
6a10: 22 29 3b 0a 20 20 20 20 20 20 20 20 66 6f 72 28  ");.        for(
6a20: 69 3d 30 3b 20 69 3c 6e 52 6f 77 3b 20 69 2b 3d  i=0; i<nRow; i+=
6a30: 6e 53 65 6c 53 74 65 70 29 7b 0a 20 20 20 20 20  nSelStep){.     
6a40: 20 20 20 20 20 69 6e 74 20 73 70 73 20 3d 20 28       int sps = (
6a50: 69 6e 74 29 28 6e 53 65 6c 54 65 73 74 2a 31 30  int)(nSelTest*10
6a60: 30 30 2e 30 2f 28 64 6f 75 62 6c 65 29 61 53 65  00.0/(double)aSe
6a70: 6c 54 69 6d 65 5b 28 6a 2a 6e 52 6f 77 2b 69 29  lTime[(j*nRow+i)
6a80: 2f 6e 53 65 6c 53 74 65 70 5d 29 3b 0a 20 20 20  /nSelStep]);.   
6a90: 20 20 20 20 20 20 20 66 70 72 69 6e 74 66 28 70         fprintf(p
6aa0: 4f 75 74 2c 20 22 25 64 20 25 64 5c 6e 22 2c 20  Out, "%d %d\n", 
6ab0: 69 2b 6e 53 65 6c 53 74 65 70 2c 20 73 70 73 29  i+nSelStep, sps)
6ac0: 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  ;.        }.    
6ad0: 20 20 20 20 66 70 72 69 6e 74 66 28 70 4f 75 74      fprintf(pOut
6ae0: 2c 20 22 65 6e 64 5c 6e 22 29 3b 0a 20 20 20 20  , "end\n");.    
6af0: 20 20 7d 65 6c 73 65 20 69 66 28 20 73 79 73 5f    }else if( sys_
6b00: 6d 61 73 6b 3d 3d 28 31 3c 3c 32 29 20 29 7b 0a  mask==(1<<2) ){.
6b10: 20 20 20 20 20 20 20 20 66 6f 72 28 69 3d 30 3b          for(i=0;
6b20: 20 69 3c 28 6e 52 6f 77 2f 6e 53 74 65 70 29 3b   i<(nRow/nStep);
6b30: 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 20   i++){.         
6b40: 20 66 70 72 69 6e 74 66 28 70 4f 75 74 2c 20 22   fprintf(pOut, "
6b50: 25 64 20 25 66 5c 6e 22 2c 20 69 2a 6e 53 74 65  %d %f\n", i*nSte
6b60: 70 2c 20 28 64 6f 75 62 6c 65 29 61 57 72 69 74  p, (double)aWrit
6b70: 65 5b 69 5d 20 2f 20 28 64 6f 75 62 6c 65 29 6e  e[i] / (double)n
6b80: 53 74 65 70 29 3b 0a 20 20 20 20 20 20 20 20 7d  Step);.        }
6b90: 0a 20 20 20 20 20 20 20 20 66 70 72 69 6e 74 66  .        fprintf
6ba0: 28 70 4f 75 74 2c 20 22 65 6e 64 5c 6e 22 29 3b  (pOut, "end\n");
6bb0: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20  .      }.    }. 
6bc0: 20 0a 20 20 20 20 66 70 72 69 6e 74 66 28 70 4f   .    fprintf(pO
6bd0: 75 74 2c 20 22 70 61 75 73 65 20 2d 31 5c 6e 22  ut, "pause -1\n"
6be0: 29 3b 0a 20 20 20 20 66 63 6c 6f 73 65 28 70 4f  );.    fclose(pO
6bf0: 75 74 29 3b 0a 20 20 7d 0a 0a 20 20 66 72 65 65  ut);.  }..  free
6c00: 28 61 54 69 6d 65 29 3b 0a 20 20 66 72 65 65 28  (aTime);.  free(
6c10: 61 53 65 6c 54 69 6d 65 29 3b 0a 20 20 66 72 65  aSelTime);.  fre
6c20: 65 28 61 57 72 69 74 65 29 3b 0a 20 20 74 65 73  e(aWrite);.  tes
6c30: 74 4d 61 6c 6c 6f 63 49 6e 73 74 61 6c 6c 28 74  tMallocInstall(t
6c40: 64 62 5f 6c 73 6d 5f 65 6e 76 28 29 29 3b 0a 20  db_lsm_env());. 
6c50: 20 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 2f 2a   return 0;.}../*
6c60: 0a 2a 2a 20 55 73 61 67 65 3a 20 6c 73 6d 74 65  .** Usage: lsmte
6c70: 73 74 20 72 61 6e 64 6f 6d 20 3f 4e 3f 0a 2a 2a  st random ?N?.**
6c80: 0a 2a 2a 20 54 68 69 73 20 63 6f 6d 6d 61 6e 64  .** This command
6c90: 20 70 72 69 6e 74 73 20 61 20 73 65 71 75 65 6e   prints a sequen
6ca0: 63 65 20 6f 66 20 7a 65 72 6f 20 6f 72 20 6d 6f  ce of zero or mo
6cb0: 72 65 20 6e 75 6d 62 65 72 73 20 66 72 6f 6d 20  re numbers from 
6cc0: 74 68 65 20 50 52 4e 47 0a 2a 2a 20 73 79 73 74  the PRNG.** syst
6cd0: 65 6d 20 74 6f 20 73 74 64 6f 75 74 2e 20 49 66  em to stdout. If
6ce0: 20 74 68 65 20 22 4e 22 20 61 72 67 75 6d 65 6e   the "N" argumen
6cf0: 74 20 69 73 20 6d 69 73 73 69 6e 67 2c 20 76 61  t is missing, va
6d00: 6c 75 65 73 20 74 68 65 20 66 69 72 73 74 20 31  lues the first 1
6d10: 30 0a 2a 2a 20 76 61 6c 75 65 73 20 28 69 3d 30  0.** values (i=0
6d20: 2c 20 69 3d 31 2c 20 2e 2e 2e 20 69 3d 39 29 20  , i=1, ... i=9) 
6d30: 61 72 65 20 70 72 69 6e 74 65 64 2e 20 4f 74 68  are printed. Oth
6d40: 65 72 77 69 73 65 2c 20 74 68 65 20 66 69 72 73  erwise, the firs
6d50: 74 20 4e 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20  t N..**.** This 
6d60: 77 61 73 20 61 64 64 65 64 20 74 6f 20 76 65 72  was added to ver
6d70: 69 66 79 20 74 68 61 74 20 74 68 65 20 50 52 4e  ify that the PRN
6d80: 47 20 76 61 6c 75 65 73 20 64 6f 20 6e 6f 74 20  G values do not 
6d90: 63 68 61 6e 67 65 20 62 65 74 77 65 65 6e 0a 2a  change between.*
6da0: 2a 20 72 75 6e 73 20 6f 66 20 74 68 65 20 6c 73  * runs of the ls
6db0: 6d 74 65 73 74 20 70 72 6f 67 72 61 6d 2e 0a 2a  mtest program..*
6dc0: 2f 0a 69 6e 74 20 64 6f 5f 72 61 6e 64 6f 6d 5f  /.int do_random_
6dd0: 74 65 73 74 73 28 69 6e 74 20 6e 41 72 67 2c 20  tests(int nArg, 
6de0: 63 68 61 72 20 2a 2a 61 7a 41 72 67 29 7b 0a 20  char **azArg){. 
6df0: 20 69 6e 74 20 69 3b 0a 20 20 69 6e 74 20 6e 52   int i;.  int nR
6e00: 61 6e 64 3b 0a 20 20 69 66 28 20 6e 41 72 67 3d  and;.  if( nArg=
6e10: 3d 30 20 29 7b 0a 20 20 20 20 6e 52 61 6e 64 20  =0 ){.    nRand 
6e20: 3d 20 31 30 3b 0a 20 20 7d 65 6c 73 65 20 69 66  = 10;.  }else if
6e30: 28 20 6e 41 72 67 3d 3d 31 20 29 7b 0a 20 20 20  ( nArg==1 ){.   
6e40: 20 6e 52 61 6e 64 20 3d 20 61 74 6f 69 28 61 7a   nRand = atoi(az
6e50: 41 72 67 5b 30 5d 29 3b 0a 20 20 7d 65 6c 73 65  Arg[0]);.  }else
6e60: 7b 0a 20 20 20 20 74 65 73 74 50 72 69 6e 74 45  {.    testPrintE
6e70: 72 72 6f 72 28 22 55 73 61 67 65 3a 20 72 61 6e  rror("Usage: ran
6e80: 64 6f 6d 20 3f 4e 3f 5c 6e 22 29 3b 0a 20 20 20  dom ?N?\n");.   
6e90: 20 72 65 74 75 72 6e 20 2d 31 3b 0a 20 20 7d 0a   return -1;.  }.
6ea0: 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c 6e 52 61    for(i=0; i<nRa
6eb0: 6e 64 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 70 72  nd; i++){.    pr
6ec0: 69 6e 74 66 28 22 30 78 25 78 5c 6e 22 2c 20 74  intf("0x%x\n", t
6ed0: 65 73 74 50 72 6e 67 56 61 6c 75 65 28 69 29 29  estPrngValue(i))
6ee0: 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 30  ;.  }.  return 0
6ef0: 3b 0a 7d 0a 0a 73 74 61 74 69 63 20 69 6e 74 20  ;.}..static int 
6f00: 74 65 73 74 46 6f 72 6d 61 74 53 69 7a 65 28 63  testFormatSize(c
6f10: 68 61 72 20 2a 61 42 75 66 2c 20 69 6e 74 20 6e  har *aBuf, int n
6f20: 42 75 66 2c 20 69 36 34 20 6e 42 79 74 65 29 7b  Buf, i64 nByte){
6f30: 0a 20 20 69 6e 74 20 72 65 73 3b 0a 20 20 69 66  .  int res;.  if
6f40: 28 20 6e 42 79 74 65 3c 28 31 3c 3c 31 30 29 20  ( nByte<(1<<10) 
6f50: 29 7b 0a 20 20 20 20 72 65 73 20 3d 20 73 6e 70  ){.    res = snp
6f60: 72 69 6e 74 66 28 61 42 75 66 2c 20 6e 42 75 66  rintf(aBuf, nBuf
6f70: 2c 20 22 25 64 20 62 79 74 65 22 2c 20 28 69 6e  , "%d byte", (in
6f80: 74 29 6e 42 79 74 65 29 3b 0a 20 20 7d 65 6c 73  t)nByte);.  }els
6f90: 65 20 69 66 28 20 6e 42 79 74 65 3c 28 31 3c 3c  e if( nByte<(1<<
6fa0: 32 30 29 20 29 7b 0a 20 20 20 20 72 65 73 20 3d  20) ){.    res =
6fb0: 20 73 6e 70 72 69 6e 74 66 28 61 42 75 66 2c 20   snprintf(aBuf, 
6fc0: 6e 42 75 66 2c 20 22 25 64 4b 22 2c 20 28 69 6e  nBuf, "%dK", (in
6fd0: 74 29 28 6e 42 79 74 65 2f 28 31 3c 3c 31 30 29  t)(nByte/(1<<10)
6fe0: 29 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20  ));.  }else{.   
6ff0: 20 72 65 73 20 3d 20 73 6e 70 72 69 6e 74 66 28   res = snprintf(
7000: 61 42 75 66 2c 20 6e 42 75 66 2c 20 22 25 64 4d  aBuf, nBuf, "%dM
7010: 22 2c 20 28 69 6e 74 29 28 6e 42 79 74 65 2f 28  ", (int)(nByte/(
7020: 31 3c 3c 32 30 29 29 29 3b 0a 20 20 7d 0a 20 20  1<<20)));.  }.  
7030: 72 65 74 75 72 6e 20 72 65 73 3b 0a 7d 0a 0a 73  return res;.}..s
7040: 74 61 74 69 63 20 69 36 34 20 74 65 73 74 52 65  tatic i64 testRe
7050: 61 64 53 69 7a 65 28 63 68 61 72 20 2a 7a 29 7b  adSize(char *z){
7060: 0a 20 20 69 6e 74 20 6e 20 3d 20 73 74 72 6c 65  .  int n = strle
7070: 6e 28 7a 29 3b 0a 20 20 63 68 61 72 20 63 20 3d  n(z);.  char c =
7080: 20 7a 5b 6e 2d 31 5d 3b 0a 20 20 69 36 34 20 6e   z[n-1];.  i64 n
7090: 4d 75 6c 20 3d 20 31 3b 0a 0a 20 20 73 77 69 74  Mul = 1;..  swit
70a0: 63 68 28 20 63 20 29 7b 0a 20 20 20 20 63 61 73  ch( c ){.    cas
70b0: 65 20 27 67 27 3a 20 63 61 73 65 20 27 47 27 3a  e 'g': case 'G':
70c0: 0a 20 20 20 20 20 20 6e 4d 75 6c 20 3d 20 28 31  .      nMul = (1
70d0: 3c 3c 33 30 29 3b 0a 20 20 20 20 20 20 62 72 65  <<30);.      bre
70e0: 61 6b 3b 0a 0a 20 20 20 20 63 61 73 65 20 27 6d  ak;..    case 'm
70f0: 27 3a 20 63 61 73 65 20 27 4d 27 3a 0a 20 20 20  ': case 'M':.   
7100: 20 20 20 6e 4d 75 6c 20 3d 20 28 31 3c 3c 32 30     nMul = (1<<20
7110: 29 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  );.      break;.
7120: 0a 20 20 20 20 63 61 73 65 20 27 6b 27 3a 20 63  .    case 'k': c
7130: 61 73 65 20 27 4b 27 3a 0a 20 20 20 20 20 20 6e  ase 'K':.      n
7140: 4d 75 6c 20 3d 20 28 31 3c 3c 31 30 29 3b 0a 20  Mul = (1<<10);. 
7150: 20 20 20 20 20 62 72 65 61 6b 3b 0a 0a 20 20 20       break;..   
7160: 20 64 65 66 61 75 6c 74 3a 0a 20 20 20 20 20 20   default:.      
7170: 6e 4d 75 6c 20 3d 20 31 3b 0a 20 20 7d 0a 0a 20  nMul = 1;.  }.. 
7180: 20 72 65 74 75 72 6e 20 6e 4d 75 6c 20 2a 20 28   return nMul * (
7190: 69 36 34 29 61 74 6f 69 28 7a 29 3b 0a 7d 20 0a  i64)atoi(z);.} .
71a0: 0a 2f 2a 0a 2a 2a 20 55 73 61 67 65 3a 20 6c 73  ./*.** Usage: ls
71b0: 6d 74 65 73 74 20 77 72 69 74 65 73 70 65 65 64  mtest writespeed
71c0: 20 46 49 4c 45 53 49 5a 45 20 42 4c 4f 43 4b 53   FILESIZE BLOCKS
71d0: 49 5a 45 20 53 59 4e 43 53 49 5a 45 0a 2a 2f 0a  IZE SYNCSIZE.*/.
71e0: 73 74 61 74 69 63 20 69 6e 74 20 64 6f 5f 77 72  static int do_wr
71f0: 69 74 65 72 5f 74 65 73 74 28 69 6e 74 20 6e 41  iter_test(int nA
7200: 72 67 2c 20 63 68 61 72 20 2a 2a 61 7a 41 72 67  rg, char **azArg
7210: 29 7b 0a 20 20 69 6e 74 20 6e 42 6c 6f 63 6b 3b  ){.  int nBlock;
7220: 0a 20 20 69 6e 74 20 6e 53 69 7a 65 3b 0a 20 20  .  int nSize;.  
7230: 69 6e 74 20 69 3b 0a 20 20 69 6e 74 20 66 64 3b  int i;.  int fd;
7240: 0a 20 20 69 6e 74 20 6d 73 3b 0a 20 20 63 68 61  .  int ms;.  cha
7250: 72 20 61 46 69 6c 65 73 69 7a 65 5b 33 32 5d 3b  r aFilesize[32];
7260: 0a 20 20 63 68 61 72 20 61 42 6c 6f 63 6b 53 69  .  char aBlockSi
7270: 7a 65 5b 33 32 5d 3b 0a 0a 20 20 63 68 61 72 20  ze[32];..  char 
7280: 2a 61 50 61 67 65 3b 0a 20 20 69 6e 74 20 2a 61  *aPage;.  int *a
7290: 4f 72 64 65 72 3b 0a 20 20 69 6e 74 20 6e 53 79  Order;.  int nSy
72a0: 6e 63 3b 0a 0a 20 20 69 36 34 20 66 69 6c 65 73  nc;..  i64 files
72b0: 69 7a 65 3b 0a 20 20 69 36 34 20 62 6c 6f 63 6b  ize;.  i64 block
72c0: 73 69 7a 65 3b 0a 20 20 69 36 34 20 73 79 6e 63  size;.  i64 sync
72d0: 73 69 7a 65 3b 0a 20 20 69 6e 74 20 6e 50 61 67  size;.  int nPag
72e0: 65 20 3d 20 34 30 39 36 3b 0a 0a 20 20 2f 2a 20  e = 4096;..  /* 
72f0: 48 6f 77 20 6c 6f 6e 67 20 74 6f 20 73 6c 65 65  How long to slee
7300: 70 20 62 65 66 6f 72 65 20 72 75 6e 6e 69 6e 67  p before running
7310: 20 61 20 74 72 69 61 6c 20 28 69 6e 20 6d 73 29   a trial (in ms)
7320: 2e 20 2a 2f 0a 23 69 66 20 30 0a 20 20 63 6f 6e  . */.#if 0.  con
7330: 73 74 20 69 6e 74 20 6e 53 6c 65 65 70 20 3d 20  st int nSleep = 
7340: 31 30 30 30 30 3b 0a 23 65 6e 64 69 66 0a 20 20  10000;.#endif.  
7350: 63 6f 6e 73 74 20 69 6e 74 20 6e 53 6c 65 65 70  const int nSleep
7360: 20 3d 20 30 3b 0a 0a 20 20 69 66 28 20 6e 41 72   = 0;..  if( nAr
7370: 67 21 3d 33 20 29 7b 0a 20 20 20 20 74 65 73 74  g!=3 ){.    test
7380: 50 72 69 6e 74 55 73 61 67 65 28 22 46 49 4c 45  PrintUsage("FILE
7390: 53 49 5a 45 20 42 4c 4f 43 4b 53 49 5a 45 20 53  SIZE BLOCKSIZE S
73a0: 59 4e 43 53 49 5a 45 22 29 3b 0a 20 20 20 20 72  YNCSIZE");.    r
73b0: 65 74 75 72 6e 20 2d 31 3b 0a 20 20 7d 0a 0a 20  eturn -1;.  }.. 
73c0: 20 66 69 6c 65 73 69 7a 65 20 3d 20 74 65 73 74   filesize = test
73d0: 52 65 61 64 53 69 7a 65 28 61 7a 41 72 67 5b 30  ReadSize(azArg[0
73e0: 5d 29 3b 0a 20 20 62 6c 6f 63 6b 73 69 7a 65 20  ]);.  blocksize 
73f0: 3d 20 74 65 73 74 52 65 61 64 53 69 7a 65 28 61  = testReadSize(a
7400: 7a 41 72 67 5b 31 5d 29 3b 0a 20 20 73 79 6e 63  zArg[1]);.  sync
7410: 73 69 7a 65 20 3d 20 74 65 73 74 52 65 61 64 53  size = testReadS
7420: 69 7a 65 28 61 7a 41 72 67 5b 32 5d 29 3b 0a 0a  ize(azArg[2]);..
7430: 20 20 6e 42 6c 6f 63 6b 20 3d 20 28 69 6e 74 29    nBlock = (int)
7440: 28 66 69 6c 65 73 69 7a 65 20 2f 20 62 6c 6f 63  (filesize / bloc
7450: 6b 73 69 7a 65 29 3b 0a 20 20 6e 53 69 7a 65 20  ksize);.  nSize 
7460: 3d 20 28 69 6e 74 29 62 6c 6f 63 6b 73 69 7a 65  = (int)blocksize
7470: 3b 0a 20 20 6e 53 79 6e 63 20 3d 20 28 69 6e 74  ;.  nSync = (int
7480: 29 28 73 79 6e 63 73 69 7a 65 20 2f 20 62 6c 6f  )(syncsize / blo
7490: 63 6b 73 69 7a 65 29 3b 0a 0a 20 20 61 50 61 67  cksize);..  aPag
74a0: 65 20 3d 20 28 63 68 61 72 20 2a 29 6d 61 6c 6c  e = (char *)mall
74b0: 6f 63 28 34 30 39 36 29 3b 0a 20 20 61 4f 72 64  oc(4096);.  aOrd
74c0: 65 72 20 3d 20 28 69 6e 74 20 2a 29 6d 61 6c 6c  er = (int *)mall
74d0: 6f 63 28 6e 42 6c 6f 63 6b 20 2a 20 73 69 7a 65  oc(nBlock * size
74e0: 6f 66 28 69 6e 74 29 29 3b 0a 20 20 66 6f 72 28  of(int));.  for(
74f0: 69 3d 30 3b 20 69 3c 6e 42 6c 6f 63 6b 3b 20 69  i=0; i<nBlock; i
7500: 2b 2b 29 20 61 4f 72 64 65 72 5b 69 5d 20 3d 20  ++) aOrder[i] = 
7510: 69 3b 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c  i;.  for(i=0; i<
7520: 28 6e 42 6c 6f 63 6b 2a 32 35 29 3b 20 69 2b 2b  (nBlock*25); i++
7530: 29 7b 0a 20 20 20 20 69 6e 74 20 74 6d 70 3b 0a  ){.    int tmp;.
7540: 20 20 20 20 75 33 32 20 61 20 3d 20 74 65 73 74      u32 a = test
7550: 50 72 6e 67 56 61 6c 75 65 28 69 29 3b 0a 20 20  PrngValue(i);.  
7560: 20 20 75 33 32 20 62 20 3d 20 74 65 73 74 50 72    u32 b = testPr
7570: 6e 67 56 61 6c 75 65 28 61 29 3b 0a 20 20 20 20  ngValue(a);.    
7580: 61 20 3d 20 61 20 25 20 6e 42 6c 6f 63 6b 3b 0a  a = a % nBlock;.
7590: 20 20 20 20 62 20 3d 20 62 20 25 20 6e 42 6c 6f      b = b % nBlo
75a0: 63 6b 3b 0a 20 20 20 20 74 6d 70 20 3d 20 61 4f  ck;.    tmp = aO
75b0: 72 64 65 72 5b 61 5d 3b 0a 20 20 20 20 61 4f 72  rder[a];.    aOr
75c0: 64 65 72 5b 61 5d 20 3d 20 61 4f 72 64 65 72 5b  der[a] = aOrder[
75d0: 62 5d 3b 0a 20 20 20 20 61 4f 72 64 65 72 5b 62  b];.    aOrder[b
75e0: 5d 20 3d 20 74 6d 70 3b 0a 20 20 7d 0a 0a 20 20  ] = tmp;.  }..  
75f0: 74 65 73 74 46 6f 72 6d 61 74 53 69 7a 65 28 61  testFormatSize(a
7600: 46 69 6c 65 73 69 7a 65 2c 20 73 69 7a 65 6f 66  Filesize, sizeof
7610: 28 61 46 69 6c 65 73 69 7a 65 29 2c 20 28 69 36  (aFilesize), (i6
7620: 34 29 6e 42 6c 6f 63 6b 20 2a 20 28 69 36 34 29  4)nBlock * (i64)
7630: 6e 53 69 7a 65 29 3b 0a 20 20 74 65 73 74 46 6f  nSize);.  testFo
7640: 72 6d 61 74 53 69 7a 65 28 61 42 6c 6f 63 6b 53  rmatSize(aBlockS
7650: 69 7a 65 2c 20 73 69 7a 65 6f 66 28 61 46 69 6c  ize, sizeof(aFil
7660: 65 73 69 7a 65 29 2c 20 6e 53 69 7a 65 29 3b 0a  esize), nSize);.
7670: 0a 20 20 70 72 69 6e 74 66 28 22 54 65 73 74 69  .  printf("Testi
7680: 6e 67 20 77 72 69 74 69 6e 67 20 61 20 25 73 20  ng writing a %s 
7690: 66 69 6c 65 20 75 73 69 6e 67 20 25 73 20 62 6c  file using %s bl
76a0: 6f 63 6b 73 2e 20 22 2c 20 61 46 69 6c 65 73 69  ocks. ", aFilesi
76b0: 7a 65 2c 20 61 42 6c 6f 63 6b 53 69 7a 65 29 3b  ze, aBlockSize);
76c0: 0a 20 20 69 66 28 20 6e 53 79 6e 63 3d 3d 31 20  .  if( nSync==1 
76d0: 29 7b 0a 20 20 20 20 70 72 69 6e 74 66 28 22 53  ){.    printf("S
76e0: 79 6e 63 20 61 66 74 65 72 20 65 61 63 68 20 62  ync after each b
76f0: 6c 6f 63 6b 2e 5c 6e 22 29 3b 0a 20 20 7d 65 6c  lock.\n");.  }el
7700: 73 65 7b 0a 20 20 20 20 70 72 69 6e 74 66 28 22  se{.    printf("
7710: 53 79 6e 63 20 61 66 74 65 72 20 65 61 63 68 20  Sync after each 
7720: 25 64 20 62 6c 6f 63 6b 73 2e 5c 6e 22 2c 20 6e  %d blocks.\n", n
7730: 53 79 6e 63 29 3b 0a 20 20 7d 0a 0a 20 20 70 72  Sync);.  }..  pr
7740: 69 6e 74 66 28 22 50 72 65 70 61 72 69 6e 67 20  intf("Preparing 
7750: 66 69 6c 65 2e 2e 2e 20 22 29 3b 0a 20 20 66 66  file... ");.  ff
7760: 6c 75 73 68 28 73 74 64 6f 75 74 29 3b 0a 20 20  lush(stdout);.  
7770: 75 6e 6c 69 6e 6b 28 22 77 72 69 74 65 72 2e 6f  unlink("writer.o
7780: 75 74 22 29 3b 0a 20 20 66 64 20 3d 20 6f 70 65  ut");.  fd = ope
7790: 6e 28 22 77 72 69 74 65 72 2e 6f 75 74 22 2c 20  n("writer.out", 
77a0: 4f 5f 52 44 57 52 7c 4f 5f 43 52 45 41 54 7c 5f  O_RDWR|O_CREAT|_
77b0: 4f 5f 42 49 4e 41 52 59 2c 20 30 36 36 34 29 3b  O_BINARY, 0664);
77c0: 0a 20 20 69 66 28 20 66 64 3c 30 20 29 7b 0a 20  .  if( fd<0 ){. 
77d0: 20 20 20 74 65 73 74 50 72 69 6e 74 45 72 72 6f     testPrintErro
77e0: 72 28 22 6f 70 65 6e 28 29 3a 20 25 64 20 2d 20  r("open(): %d - 
77f0: 25 73 5c 6e 22 2c 20 65 72 72 6e 6f 2c 20 73 74  %s\n", errno, st
7800: 72 65 72 72 6f 72 28 65 72 72 6e 6f 29 29 3b 0a  rerror(errno));.
7810: 20 20 20 20 72 65 74 75 72 6e 20 2d 31 3b 0a 20      return -1;. 
7820: 20 7d 0a 20 20 74 65 73 74 54 69 6d 65 49 6e 69   }.  testTimeIni
7830: 74 28 29 3b 0a 20 20 66 6f 72 28 69 3d 30 3b 20  t();.  for(i=0; 
7840: 69 3c 6e 42 6c 6f 63 6b 3b 20 69 2b 2b 29 7b 0a  i<nBlock; i++){.
7850: 20 20 20 20 69 6e 74 20 69 50 67 3b 0a 20 20 20      int iPg;.   
7860: 20 6d 65 6d 73 65 74 28 61 50 61 67 65 2c 20 69   memset(aPage, i
7870: 26 30 78 46 46 2c 20 6e 50 61 67 65 29 3b 0a 20  &0xFF, nPage);. 
7880: 20 20 20 66 6f 72 28 69 50 67 3d 30 3b 20 69 50     for(iPg=0; iP
7890: 67 3c 28 6e 53 69 7a 65 2f 6e 50 61 67 65 29 3b  g<(nSize/nPage);
78a0: 20 69 50 67 2b 2b 29 7b 0a 20 20 20 20 20 20 77   iPg++){.      w
78b0: 72 69 74 65 28 66 64 2c 20 61 50 61 67 65 2c 20  rite(fd, aPage, 
78c0: 6e 50 61 67 65 29 3b 0a 20 20 20 20 7d 0a 20 20  nPage);.    }.  
78d0: 7d 0a 20 20 66 73 79 6e 63 28 66 64 29 3b 0a 20  }.  fsync(fd);. 
78e0: 20 70 72 69 6e 74 66 28 22 6f 6b 20 28 25 64 20   printf("ok (%d 
78f0: 6d 73 29 5c 6e 22 2c 20 74 65 73 74 54 69 6d 65  ms)\n", testTime
7900: 47 65 74 28 29 29 3b 0a 0a 20 20 66 6f 72 28 69  Get());..  for(i
7910: 3d 30 3b 20 69 3c 35 3b 20 69 2b 2b 29 7b 0a 20  =0; i<5; i++){. 
7920: 20 20 20 69 6e 74 20 6a 3b 0a 0a 20 20 20 20 73     int j;..    s
7930: 71 6c 69 74 65 33 5f 73 6c 65 65 70 28 6e 53 6c  qlite3_sleep(nSl
7940: 65 65 70 29 3b 0a 20 20 20 20 70 72 69 6e 74 66  eep);.    printf
7950: 28 22 4e 6f 77 20 77 72 69 74 69 6e 67 20 73 65  ("Now writing se
7960: 71 75 65 6e 74 69 61 6c 6c 79 2e 2e 2e 20 20 22  quentially...  "
7970: 29 3b 0a 20 20 20 20 66 66 6c 75 73 68 28 73 74  );.    fflush(st
7980: 64 6f 75 74 29 3b 0a 0a 20 20 20 20 6c 73 65 65  dout);..    lsee
7990: 6b 28 66 64 2c 20 30 2c 20 53 45 45 4b 5f 53 45  k(fd, 0, SEEK_SE
79a0: 54 29 3b 0a 20 20 20 20 74 65 73 74 54 69 6d 65  T);.    testTime
79b0: 49 6e 69 74 28 29 3b 0a 20 20 20 20 66 6f 72 28  Init();.    for(
79c0: 6a 3d 30 3b 20 6a 3c 6e 42 6c 6f 63 6b 3b 20 6a  j=0; j<nBlock; j
79d0: 2b 2b 29 7b 0a 20 20 20 20 20 20 69 6e 74 20 69  ++){.      int i
79e0: 50 67 3b 0a 20 20 20 20 20 20 69 66 28 20 28 28  Pg;.      if( ((
79f0: 6a 2b 31 29 25 6e 53 79 6e 63 29 3d 3d 30 20 29  j+1)%nSync)==0 )
7a00: 20 66 64 61 74 61 73 79 6e 63 28 66 64 29 3b 0a   fdatasync(fd);.
7a10: 20 20 20 20 20 20 6d 65 6d 73 65 74 28 61 50 61        memset(aPa
7a20: 67 65 2c 20 6a 26 30 78 46 46 2c 20 6e 50 61 67  ge, j&0xFF, nPag
7a30: 65 29 3b 0a 20 20 20 20 20 20 66 6f 72 28 69 50  e);.      for(iP
7a40: 67 3d 30 3b 20 69 50 67 3c 28 6e 53 69 7a 65 2f  g=0; iPg<(nSize/
7a50: 6e 50 61 67 65 29 3b 20 69 50 67 2b 2b 29 7b 0a  nPage); iPg++){.
7a60: 20 20 20 20 20 20 20 20 77 72 69 74 65 28 66 64          write(fd
7a70: 2c 20 61 50 61 67 65 2c 20 6e 50 61 67 65 29 3b  , aPage, nPage);
7a80: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20  .      }.    }. 
7a90: 20 20 20 66 64 61 74 61 73 79 6e 63 28 66 64 29     fdatasync(fd)
7aa0: 3b 0a 20 20 20 20 6d 73 20 3d 20 74 65 73 74 54  ;.    ms = testT
7ab0: 69 6d 65 47 65 74 28 29 3b 0a 20 20 20 20 70 72  imeGet();.    pr
7ac0: 69 6e 74 66 28 22 25 64 20 6d 73 5c 6e 22 2c 20  intf("%d ms\n", 
7ad0: 6d 73 29 3b 0a 20 20 20 20 73 71 6c 69 74 65 33  ms);.    sqlite3
7ae0: 5f 73 6c 65 65 70 28 6e 53 6c 65 65 70 29 3b 0a  _sleep(nSleep);.
7af0: 20 20 20 20 70 72 69 6e 74 66 28 22 4e 6f 77 20      printf("Now 
7b00: 69 6e 20 61 6e 20 61 72 62 69 74 72 61 72 79 20  in an arbitrary 
7b10: 6f 72 64 65 72 2e 2e 2e 20 22 29 3b 0a 0a 20 20  order... ");..  
7b20: 20 20 66 66 6c 75 73 68 28 73 74 64 6f 75 74 29    fflush(stdout)
7b30: 3b 0a 20 20 20 20 74 65 73 74 54 69 6d 65 49 6e  ;.    testTimeIn
7b40: 69 74 28 29 3b 0a 20 20 20 20 66 6f 72 28 6a 3d  it();.    for(j=
7b50: 30 3b 20 6a 3c 6e 42 6c 6f 63 6b 3b 20 6a 2b 2b  0; j<nBlock; j++
7b60: 29 7b 0a 20 20 20 20 20 20 69 6e 74 20 69 50 67  ){.      int iPg
7b70: 3b 0a 20 20 20 20 20 20 69 66 28 20 28 28 6a 2b  ;.      if( ((j+
7b80: 31 29 25 6e 53 79 6e 63 29 3d 3d 30 20 29 20 66  1)%nSync)==0 ) f
7b90: 64 61 74 61 73 79 6e 63 28 66 64 29 3b 0a 20 20  datasync(fd);.  
7ba0: 20 20 20 20 6c 73 65 65 6b 28 66 64 2c 20 61 4f      lseek(fd, aO
7bb0: 72 64 65 72 5b 6a 5d 2a 6e 53 69 7a 65 2c 20 53  rder[j]*nSize, S
7bc0: 45 45 4b 5f 53 45 54 29 3b 0a 20 20 20 20 20 20  EEK_SET);.      
7bd0: 6d 65 6d 73 65 74 28 61 50 61 67 65 2c 20 6a 26  memset(aPage, j&
7be0: 30 78 46 46 2c 20 6e 50 61 67 65 29 3b 0a 20 20  0xFF, nPage);.  
7bf0: 20 20 20 20 66 6f 72 28 69 50 67 3d 30 3b 20 69      for(iPg=0; i
7c00: 50 67 3c 28 6e 53 69 7a 65 2f 6e 50 61 67 65 29  Pg<(nSize/nPage)
7c10: 3b 20 69 50 67 2b 2b 29 7b 0a 20 20 20 20 20 20  ; iPg++){.      
7c20: 20 20 77 72 69 74 65 28 66 64 2c 20 61 50 61 67    write(fd, aPag
7c30: 65 2c 20 6e 50 61 67 65 29 3b 0a 20 20 20 20 20  e, nPage);.     
7c40: 20 7d 0a 20 20 20 20 7d 0a 20 20 20 20 66 64 61   }.    }.    fda
7c50: 74 61 73 79 6e 63 28 66 64 29 3b 0a 20 20 20 20  tasync(fd);.    
7c60: 6d 73 20 3d 20 74 65 73 74 54 69 6d 65 47 65 74  ms = testTimeGet
7c70: 28 29 3b 0a 20 20 20 20 70 72 69 6e 74 66 28 22  ();.    printf("
7c80: 25 64 20 6d 73 5c 6e 22 2c 20 6d 73 29 3b 0a 20  %d ms\n", ms);. 
7c90: 20 7d 0a 0a 20 20 63 6c 6f 73 65 28 66 64 29 3b   }..  close(fd);
7ca0: 0a 20 20 66 72 65 65 28 61 50 61 67 65 29 3b 0a  .  free(aPage);.
7cb0: 20 20 66 72 65 65 28 61 4f 72 64 65 72 29 3b 0a    free(aOrder);.
7cc0: 0a 20 20 72 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a  .  return 0;.}..
7cd0: 73 74 61 74 69 63 20 76 6f 69 64 20 64 6f 5f 69  static void do_i
7ce0: 6e 73 65 72 74 5f 77 6f 72 6b 5f 68 6f 6f 6b 28  nsert_work_hook(
7cf0: 6c 73 6d 5f 64 62 20 2a 64 62 2c 20 76 6f 69 64  lsm_db *db, void
7d00: 20 2a 70 29 7b 0a 20 20 63 68 61 72 20 2a 7a 20   *p){.  char *z 
7d10: 3d 20 30 3b 0a 20 20 6c 73 6d 5f 69 6e 66 6f 28  = 0;.  lsm_info(
7d20: 64 62 2c 20 4c 53 4d 5f 49 4e 46 4f 5f 44 42 5f  db, LSM_INFO_DB_
7d30: 53 54 52 55 43 54 55 52 45 2c 20 26 7a 29 3b 0a  STRUCTURE, &z);.
7d40: 20 20 69 66 28 20 7a 20 29 7b 0a 20 20 20 20 70    if( z ){.    p
7d50: 72 69 6e 74 66 28 22 25 73 5c 6e 22 2c 20 7a 29  rintf("%s\n", z)
7d60: 3b 0a 20 20 20 20 66 66 6c 75 73 68 28 73 74 64  ;.    fflush(std
7d70: 6f 75 74 29 3b 0a 20 20 20 20 6c 73 6d 5f 66 72  out);.    lsm_fr
7d80: 65 65 28 6c 73 6d 5f 67 65 74 5f 65 6e 76 28 64  ee(lsm_get_env(d
7d90: 62 29 2c 20 7a 29 3b 0a 20 20 7d 0a 0a 20 20 75  b), z);.  }..  u
7da0: 6e 75 73 65 64 5f 70 61 72 61 6d 65 74 65 72 28  nused_parameter(
7db0: 70 29 3b 0a 7d 0a 0a 74 79 70 65 64 65 66 20 73  p);.}..typedef s
7dc0: 74 72 75 63 74 20 49 6e 73 65 72 74 57 72 69 74  truct InsertWrit
7dd0: 65 48 6f 6f 6b 20 49 6e 73 65 72 74 57 72 69 74  eHook InsertWrit
7de0: 65 48 6f 6f 6b 3b 0a 73 74 72 75 63 74 20 49 6e  eHook;.struct In
7df0: 73 65 72 74 57 72 69 74 65 48 6f 6f 6b 20 7b 0a  sertWriteHook {.
7e00: 20 20 46 49 4c 45 20 2a 70 4f 75 74 3b 0a 20 20    FILE *pOut;.  
7e10: 69 6e 74 20 62 4c 6f 67 3b 0a 20 20 69 36 34 20  int bLog;.  i64 
7e20: 69 4f 66 66 3b 0a 20 20 69 6e 74 20 6e 44 61 74  iOff;.  int nDat
7e30: 61 3b 0a 7d 3b 0a 0a 73 74 61 74 69 63 20 76 6f  a;.};..static vo
7e40: 69 64 20 66 6c 75 73 68 48 6f 6f 6b 28 49 6e 73  id flushHook(Ins
7e50: 65 72 74 57 72 69 74 65 48 6f 6f 6b 20 2a 70 48  ertWriteHook *pH
7e60: 6f 6f 6b 29 7b 0a 20 20 69 66 28 20 70 48 6f 6f  ook){.  if( pHoo
7e70: 6b 2d 3e 6e 44 61 74 61 20 29 7b 0a 20 20 20 20  k->nData ){.    
7e80: 66 70 72 69 6e 74 66 28 70 48 6f 6f 6b 2d 3e 70  fprintf(pHook->p
7e90: 4f 75 74 2c 20 22 77 72 69 74 65 20 25 73 20 25  Out, "write %s %
7ea0: 64 20 25 64 5c 6e 22 2c 20 0a 20 20 20 20 20 20  d %d\n", .      
7eb0: 20 20 28 70 48 6f 6f 6b 2d 3e 62 4c 6f 67 20 3f    (pHook->bLog ?
7ec0: 20 22 6c 6f 67 22 20 3a 20 22 64 62 22 29 2c 20   "log" : "db"), 
7ed0: 28 69 6e 74 29 70 48 6f 6f 6b 2d 3e 69 4f 66 66  (int)pHook->iOff
7ee0: 2c 20 70 48 6f 6f 6b 2d 3e 6e 44 61 74 61 0a 20  , pHook->nData. 
7ef0: 20 20 20 29 3b 0a 20 20 20 20 70 48 6f 6f 6b 2d     );.    pHook-
7f00: 3e 6e 44 61 74 61 20 3d 20 30 3b 0a 20 20 20 20  >nData = 0;.    
7f10: 66 66 6c 75 73 68 28 70 48 6f 6f 6b 2d 3e 70 4f  fflush(pHook->pO
7f20: 75 74 29 3b 0a 20 20 7d 0a 7d 0a 0a 73 74 61 74  ut);.  }.}..stat
7f30: 69 63 20 76 6f 69 64 20 64 6f 5f 69 6e 73 65 72  ic void do_inser
7f40: 74 5f 77 72 69 74 65 5f 68 6f 6f 6b 28 0a 20 20  t_write_hook(.  
7f50: 76 6f 69 64 20 2a 70 43 74 78 2c 0a 20 20 69 6e  void *pCtx,.  in
7f60: 74 20 62 4c 6f 67 2c 0a 20 20 69 36 34 20 69 4f  t bLog,.  i64 iO
7f70: 66 66 2c 0a 20 20 69 6e 74 20 6e 44 61 74 61 2c  ff,.  int nData,
7f80: 0a 20 20 69 6e 74 20 6e 55 73 0a 29 7b 0a 20 20  .  int nUs.){.  
7f90: 49 6e 73 65 72 74 57 72 69 74 65 48 6f 6f 6b 20  InsertWriteHook 
7fa0: 2a 70 48 6f 6f 6b 20 3d 20 28 49 6e 73 65 72 74  *pHook = (Insert
7fb0: 57 72 69 74 65 48 6f 6f 6b 20 2a 29 70 43 74 78  WriteHook *)pCtx
7fc0: 3b 0a 20 20 69 66 28 20 62 4c 6f 67 20 29 20 72  ;.  if( bLog ) r
7fd0: 65 74 75 72 6e 3b 0a 0a 20 20 69 66 28 20 6e 44  eturn;..  if( nD
7fe0: 61 74 61 3d 3d 30 20 29 7b 0a 20 20 20 20 66 6c  ata==0 ){.    fl
7ff0: 75 73 68 48 6f 6f 6b 28 70 48 6f 6f 6b 29 3b 0a  ushHook(pHook);.
8000: 20 20 20 20 66 70 72 69 6e 74 66 28 70 48 6f 6f      fprintf(pHoo
8010: 6b 2d 3e 70 4f 75 74 2c 20 22 73 79 6e 63 20 25  k->pOut, "sync %
8020: 73 5c 6e 22 2c 20 28 62 4c 6f 67 20 3f 20 22 6c  s\n", (bLog ? "l
8030: 6f 67 22 20 3a 20 22 64 62 22 29 29 3b 0a 20 20  og" : "db"));.  
8040: 7d 65 6c 73 65 20 69 66 28 20 70 48 6f 6f 6b 2d  }else if( pHook-
8050: 3e 6e 44 61 74 61 20 0a 20 20 20 20 20 20 20 20  >nData .        
8060: 20 26 26 20 62 4c 6f 67 3d 3d 70 48 6f 6f 6b 2d   && bLog==pHook-
8070: 3e 62 4c 6f 67 20 0a 20 20 20 20 20 20 20 20 20  >bLog .         
8080: 26 26 20 69 4f 66 66 3d 3d 28 70 48 6f 6f 6b 2d  && iOff==(pHook-
8090: 3e 69 4f 66 66 2b 70 48 6f 6f 6b 2d 3e 6e 44 61  >iOff+pHook->nDa
80a0: 74 61 29 20 0a 20 20 29 7b 0a 20 20 20 20 70 48  ta) .  ){.    pH
80b0: 6f 6f 6b 2d 3e 6e 44 61 74 61 20 2b 3d 20 6e 44  ook->nData += nD
80c0: 61 74 61 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20  ata;.  }else{.  
80d0: 20 20 66 6c 75 73 68 48 6f 6f 6b 28 70 48 6f 6f    flushHook(pHoo
80e0: 6b 29 3b 0a 20 20 20 20 70 48 6f 6f 6b 2d 3e 62  k);.    pHook->b
80f0: 4c 6f 67 20 3d 20 62 4c 6f 67 3b 0a 20 20 20 20  Log = bLog;.    
8100: 70 48 6f 6f 6b 2d 3e 69 4f 66 66 20 3d 20 69 4f  pHook->iOff = iO
8110: 66 66 3b 0a 20 20 20 20 70 48 6f 6f 6b 2d 3e 6e  ff;.    pHook->n
8120: 44 61 74 61 20 3d 20 6e 44 61 74 61 3b 0a 20 20  Data = nData;.  
8130: 7d 0a 7d 0a 0a 73 74 61 74 69 63 20 69 6e 74 20  }.}..static int 
8140: 64 6f 5f 72 65 70 6c 61 79 28 69 6e 74 20 6e 41  do_replay(int nA
8150: 72 67 2c 20 63 68 61 72 20 2a 2a 61 7a 41 72 67  rg, char **azArg
8160: 29 7b 0a 20 20 63 68 61 72 20 61 42 75 66 5b 34  ){.  char aBuf[4
8170: 30 39 36 5d 3b 0a 20 20 46 49 4c 45 20 2a 70 49  096];.  FILE *pI
8180: 6e 70 75 74 3b 0a 20 20 46 49 4c 45 20 2a 70 43  nput;.  FILE *pC
8190: 6c 6f 73 65 20 3d 20 30 3b 0a 20 20 63 6f 6e 73  lose = 0;.  cons
81a0: 74 20 63 68 61 72 20 2a 7a 44 62 3b 0a 0a 20 20  t char *zDb;..  
81b0: 6c 73 6d 5f 65 6e 76 20 2a 70 45 6e 76 3b 0a 20  lsm_env *pEnv;. 
81c0: 20 6c 73 6d 5f 66 69 6c 65 20 2a 70 4f 75 74 3b   lsm_file *pOut;
81d0: 0a 20 20 69 6e 74 20 72 63 3b 0a 0a 20 20 69 66  .  int rc;..  if
81e0: 28 20 6e 41 72 67 21 3d 32 20 29 7b 0a 20 20 20  ( nArg!=2 ){.   
81f0: 20 74 65 73 74 50 72 69 6e 74 45 72 72 6f 72 28   testPrintError(
8200: 22 55 73 61 67 65 3a 20 72 65 70 6c 61 79 20 57  "Usage: replay W
8210: 52 49 54 45 4c 4f 47 20 46 49 4c 45 5c 6e 22 29  RITELOG FILE\n")
8220: 3b 0a 20 20 20 20 72 65 74 75 72 6e 20 31 3b 0a  ;.    return 1;.
8230: 20 20 7d 0a 0a 20 20 69 66 28 20 73 74 72 63 6d    }..  if( strcm
8240: 70 28 61 7a 41 72 67 5b 30 5d 2c 20 22 2d 22 29  p(azArg[0], "-")
8250: 3d 3d 30 20 29 7b 0a 20 20 20 20 70 49 6e 70 75  ==0 ){.    pInpu
8260: 74 20 3d 20 73 74 64 69 6e 3b 0a 20 20 7d 65 6c  t = stdin;.  }el
8270: 73 65 7b 0a 20 20 20 20 70 43 6c 6f 73 65 20 3d  se{.    pClose =
8280: 20 70 49 6e 70 75 74 20 3d 20 66 6f 70 65 6e 28   pInput = fopen(
8290: 61 7a 41 72 67 5b 30 5d 2c 20 22 72 22 29 3b 0a  azArg[0], "r");.
82a0: 20 20 7d 0a 20 20 7a 44 62 20 3d 20 61 7a 41 72    }.  zDb = azAr
82b0: 67 5b 31 5d 3b 0a 20 20 70 45 6e 76 20 3d 20 74  g[1];.  pEnv = t
82c0: 64 62 5f 6c 73 6d 5f 65 6e 76 28 29 3b 0a 20 20  db_lsm_env();.  
82d0: 72 63 20 3d 20 70 45 6e 76 2d 3e 78 4f 70 65 6e  rc = pEnv->xOpen
82e0: 28 70 45 6e 76 2c 20 7a 44 62 2c 20 30 2c 20 26  (pEnv, zDb, 0, &
82f0: 70 4f 75 74 29 3b 0a 20 20 69 66 28 20 72 63 21  pOut);.  if( rc!
8300: 3d 4c 53 4d 5f 4f 4b 20 29 20 72 65 74 75 72 6e  =LSM_OK ) return
8310: 20 72 63 3b 0a 0a 20 20 77 68 69 6c 65 28 20 66   rc;..  while( f
8320: 65 6f 66 28 70 49 6e 70 75 74 29 3d 3d 30 20 29  eof(pInput)==0 )
8330: 7b 0a 20 20 20 20 63 68 61 72 20 7a 4c 69 6e 65  {.    char zLine
8340: 5b 38 30 5d 3b 0a 20 20 20 20 66 67 65 74 73 28  [80];.    fgets(
8350: 7a 4c 69 6e 65 2c 20 73 69 7a 65 6f 66 28 7a 4c  zLine, sizeof(zL
8360: 69 6e 65 29 2d 31 2c 20 70 49 6e 70 75 74 29 3b  ine)-1, pInput);
8370: 0a 20 20 20 20 7a 4c 69 6e 65 5b 73 69 7a 65 6f  .    zLine[sizeo
8380: 66 28 7a 4c 69 6e 65 29 2d 31 5d 20 3d 20 27 5c  f(zLine)-1] = '\
8390: 30 27 3b 0a 0a 20 20 20 20 69 66 28 20 30 3d 3d  0';..    if( 0==
83a0: 6d 65 6d 63 6d 70 28 22 73 79 6e 63 20 64 62 22  memcmp("sync db"
83b0: 2c 20 7a 4c 69 6e 65 2c 20 37 29 20 29 7b 0a 20  , zLine, 7) ){. 
83c0: 20 20 20 20 20 72 63 20 3d 20 70 45 6e 76 2d 3e       rc = pEnv->
83d0: 78 53 79 6e 63 28 70 4f 75 74 29 3b 0a 20 20 20  xSync(pOut);.   
83e0: 20 20 20 69 66 28 20 72 63 21 3d 30 20 29 20 62     if( rc!=0 ) b
83f0: 72 65 61 6b 3b 0a 20 20 20 20 7d 65 6c 73 65 7b  reak;.    }else{
8400: 0a 20 20 20 20 20 20 69 6e 74 20 69 4f 66 66 3b  .      int iOff;
8410: 0a 20 20 20 20 20 20 69 6e 74 20 6e 44 61 74 61  .      int nData
8420: 3b 0a 20 20 20 20 20 20 69 6e 74 20 6e 4d 61 74  ;.      int nMat
8430: 63 68 3b 0a 20 20 20 20 20 20 6e 4d 61 74 63 68  ch;.      nMatch
8440: 20 3d 20 73 73 63 61 6e 66 28 7a 4c 69 6e 65 2c   = sscanf(zLine,
8450: 20 22 77 72 69 74 65 20 64 62 20 25 64 20 25 64   "write db %d %d
8460: 22 2c 20 26 69 4f 66 66 2c 20 26 6e 44 61 74 61  ", &iOff, &nData
8470: 29 3b 0a 20 20 20 20 20 20 69 66 28 20 6e 4d 61  );.      if( nMa
8480: 74 63 68 3d 3d 32 20 29 7b 0a 20 20 20 20 20 20  tch==2 ){.      
8490: 20 20 69 6e 74 20 69 3b 0a 20 20 20 20 20 20 20    int i;.       
84a0: 20 66 6f 72 28 69 3d 30 3b 20 69 3c 6e 44 61 74   for(i=0; i<nDat
84b0: 61 3b 20 69 2b 3d 73 69 7a 65 6f 66 28 61 42 75  a; i+=sizeof(aBu
84c0: 66 29 29 7b 0a 20 20 20 20 20 20 20 20 20 20 6d  f)){.          m
84d0: 65 6d 73 65 74 28 61 42 75 66 2c 20 69 26 30 78  emset(aBuf, i&0x
84e0: 46 46 2c 20 73 69 7a 65 6f 66 28 61 42 75 66 29  FF, sizeof(aBuf)
84f0: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 72 63 20  );.          rc 
8500: 3d 20 70 45 6e 76 2d 3e 78 57 72 69 74 65 28 70  = pEnv->xWrite(p
8510: 4f 75 74 2c 20 69 4f 66 66 2b 69 2c 20 61 42 75  Out, iOff+i, aBu
8520: 66 2c 20 73 69 7a 65 6f 66 28 61 42 75 66 29 29  f, sizeof(aBuf))
8530: 3b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20  ;.          if( 
8540: 72 63 21 3d 30 20 29 20 62 72 65 61 6b 3b 0a 20  rc!=0 ) break;. 
8550: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d         }.      }
8560: 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 69 66 28  .    }.  }.  if(
8570: 20 70 43 6c 6f 73 65 20 29 20 66 63 6c 6f 73 65   pClose ) fclose
8580: 28 70 43 6c 6f 73 65 29 3b 0a 20 20 70 45 6e 76  (pClose);.  pEnv
8590: 2d 3e 78 43 6c 6f 73 65 28 70 4f 75 74 29 3b 0a  ->xClose(pOut);.
85a0: 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a  .  return rc;.}.
85b0: 0a 73 74 61 74 69 63 20 69 6e 74 20 64 6f 5f 69  .static int do_i
85c0: 6e 73 65 72 74 28 69 6e 74 20 6e 41 72 67 2c 20  nsert(int nArg, 
85d0: 63 68 61 72 20 2a 2a 61 7a 41 72 67 29 7b 0a 20  char **azArg){. 
85e0: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 44 62   const char *zDb
85f0: 20 3d 20 22 6c 73 6d 22 3b 0a 20 20 54 65 73 74   = "lsm";.  Test
8600: 44 62 20 2a 70 44 62 20 3d 20 30 3b 0a 20 20 69  Db *pDb = 0;.  i
8610: 6e 74 20 69 3b 0a 20 20 69 6e 74 20 72 63 3b 0a  nt i;.  int rc;.
8620: 20 20 63 6f 6e 73 74 20 69 6e 74 20 6e 52 6f 77    const int nRow
8630: 20 3d 20 31 20 2a 20 31 30 30 30 20 2a 20 31 30   = 1 * 1000 * 10
8640: 30 30 3b 0a 0a 20 20 44 61 74 61 73 6f 75 72 63  00;..  Datasourc
8650: 65 44 65 66 6e 20 64 65 66 6e 20 3d 20 7b 20 54  eDefn defn = { T
8660: 45 53 54 5f 44 41 54 41 53 4f 55 52 43 45 5f 52  EST_DATASOURCE_R
8670: 41 4e 44 4f 4d 2c 20 38 2c 20 31 35 2c 20 38 30  ANDOM, 8, 15, 80
8680: 2c 20 31 35 30 20 7d 3b 0a 20 20 44 61 74 61 73  , 150 };.  Datas
8690: 6f 75 72 63 65 20 2a 70 44 61 74 61 20 3d 20 30  ource *pData = 0
86a0: 3b 0a 0a 20 20 69 66 28 20 6e 41 72 67 3e 31 20  ;..  if( nArg>1 
86b0: 29 7b 0a 20 20 20 20 74 65 73 74 50 72 69 6e 74  ){.    testPrint
86c0: 45 72 72 6f 72 28 22 55 73 61 67 65 3a 20 69 6e  Error("Usage: in
86d0: 73 65 72 74 20 3f 44 41 54 41 42 41 53 45 3f 5c  sert ?DATABASE?\
86e0: 6e 22 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20  n");.    return 
86f0: 31 3b 0a 20 20 7d 0a 20 20 69 66 28 20 6e 41 72  1;.  }.  if( nAr
8700: 67 3d 3d 31 20 29 7b 20 7a 44 62 20 3d 20 61 7a  g==1 ){ zDb = az
8710: 41 72 67 5b 30 5d 3b 20 7d 0a 0a 20 20 74 65 73  Arg[0]; }..  tes
8720: 74 4d 61 6c 6c 6f 63 55 6e 69 6e 73 74 61 6c 6c  tMallocUninstall
8730: 28 74 64 62 5f 6c 73 6d 5f 65 6e 76 28 29 29 3b  (tdb_lsm_env());
8740: 0a 20 20 66 6f 72 28 69 3d 30 3b 20 7a 44 62 5b  .  for(i=0; zDb[
8750: 69 5d 20 26 26 20 7a 44 62 5b 69 5d 21 3d 27 3d  i] && zDb[i]!='=
8760: 27 3b 20 69 2b 2b 29 3b 0a 20 20 69 66 28 20 7a  '; i++);.  if( z
8770: 44 62 5b 69 5d 20 29 7b 0a 20 20 20 20 72 63 20  Db[i] ){.    rc 
8780: 3d 20 74 64 62 5f 6c 73 6d 5f 6f 70 65 6e 28 7a  = tdb_lsm_open(z
8790: 44 62 2c 20 22 74 65 73 74 64 62 2e 6c 73 6d 22  Db, "testdb.lsm"
87a0: 2c 20 31 2c 20 26 70 44 62 29 3b 0a 20 20 7d 65  , 1, &pDb);.  }e
87b0: 6c 73 65 7b 0a 20 20 20 20 72 63 20 3d 20 74 64  lse{.    rc = td
87c0: 62 5f 6f 70 65 6e 28 7a 44 62 2c 20 30 2c 20 31  b_open(zDb, 0, 1
87d0: 2c 20 26 70 44 62 29 3b 0a 20 20 7d 0a 0a 20 20  , &pDb);.  }..  
87e0: 69 66 28 20 72 63 21 3d 30 20 29 7b 0a 20 20 20  if( rc!=0 ){.   
87f0: 20 74 65 73 74 50 72 69 6e 74 45 72 72 6f 72 28   testPrintError(
8800: 22 45 72 72 6f 72 20 6f 70 65 6e 69 6e 67 20 64  "Error opening d
8810: 62 20 5c 22 25 73 5c 22 3a 20 25 64 5c 6e 22 2c  b \"%s\": %d\n",
8820: 20 7a 44 62 2c 20 72 63 29 3b 0a 20 20 7d 65 6c   zDb, rc);.  }el
8830: 73 65 7b 0a 20 20 20 20 49 6e 73 65 72 74 57 72  se{.    InsertWr
8840: 69 74 65 48 6f 6f 6b 20 68 6f 6f 6b 3b 0a 20 20  iteHook hook;.  
8850: 20 20 6d 65 6d 73 65 74 28 26 68 6f 6f 6b 2c 20    memset(&hook, 
8860: 30 2c 20 73 69 7a 65 6f 66 28 68 6f 6f 6b 29 29  0, sizeof(hook))
8870: 3b 0a 20 20 20 20 68 6f 6f 6b 2e 70 4f 75 74 20  ;.    hook.pOut 
8880: 3d 20 66 6f 70 65 6e 28 22 77 72 69 74 65 6c 6f  = fopen("writelo
8890: 67 2e 74 78 74 22 2c 20 22 77 22 29 3b 0a 0a 20  g.txt", "w");.. 
88a0: 20 20 20 70 44 61 74 61 20 3d 20 74 65 73 74 44     pData = testD
88b0: 61 74 61 73 6f 75 72 63 65 4e 65 77 28 26 64 65  atasourceNew(&de
88c0: 66 6e 29 3b 0a 20 20 20 20 74 64 62 5f 6c 73 6d  fn);.    tdb_lsm
88d0: 5f 63 6f 6e 66 69 67 5f 77 6f 72 6b 5f 68 6f 6f  _config_work_hoo
88e0: 6b 28 70 44 62 2c 20 64 6f 5f 69 6e 73 65 72 74  k(pDb, do_insert
88f0: 5f 77 6f 72 6b 5f 68 6f 6f 6b 2c 20 30 29 3b 0a  _work_hook, 0);.
8900: 20 20 20 20 74 64 62 5f 6c 73 6d 5f 77 72 69 74      tdb_lsm_writ
8910: 65 5f 68 6f 6f 6b 28 70 44 62 2c 20 64 6f 5f 69  e_hook(pDb, do_i
8920: 6e 73 65 72 74 5f 77 72 69 74 65 5f 68 6f 6f 6b  nsert_write_hook
8930: 2c 20 28 76 6f 69 64 20 2a 29 26 68 6f 6f 6b 29  , (void *)&hook)
8940: 3b 0a 0a 20 20 20 20 69 66 28 20 72 63 3d 3d 30  ;..    if( rc==0
8950: 20 29 7b 0a 20 20 20 20 20 20 66 6f 72 28 69 3d   ){.      for(i=
8960: 30 3b 20 69 3c 6e 52 6f 77 3b 20 69 2b 2b 29 7b  0; i<nRow; i++){
8970: 0a 20 20 20 20 20 20 20 20 76 6f 69 64 20 2a 70  .        void *p
8980: 4b 65 79 3b 20 69 6e 74 20 6e 4b 65 79 3b 20 20  Key; int nKey;  
8990: 20 20 20 2f 2a 20 44 61 74 61 62 61 73 65 20 6b     /* Database k
89a0: 65 79 20 74 6f 20 69 6e 73 65 72 74 20 2a 2f 0a  ey to insert */.
89b0: 20 20 20 20 20 20 20 20 76 6f 69 64 20 2a 70 56          void *pV
89c0: 61 6c 3b 20 69 6e 74 20 6e 56 61 6c 3b 20 20 20  al; int nVal;   
89d0: 20 20 2f 2a 20 44 61 74 61 62 61 73 65 20 76 61    /* Database va
89e0: 6c 75 65 20 74 6f 20 69 6e 73 65 72 74 20 2a 2f  lue to insert */
89f0: 0a 20 20 20 20 20 20 20 20 74 65 73 74 44 61 74  .        testDat
8a00: 61 73 6f 75 72 63 65 45 6e 74 72 79 28 70 44 61  asourceEntry(pDa
8a10: 74 61 2c 20 69 2c 20 26 70 4b 65 79 2c 20 26 6e  ta, i, &pKey, &n
8a20: 4b 65 79 2c 20 26 70 56 61 6c 2c 20 26 6e 56 61  Key, &pVal, &nVa
8a30: 6c 29 3b 0a 20 20 20 20 20 20 20 20 74 64 62 5f  l);.        tdb_
8a40: 77 72 69 74 65 28 70 44 62 2c 20 70 4b 65 79 2c  write(pDb, pKey,
8a50: 20 6e 4b 65 79 2c 20 70 56 61 6c 2c 20 6e 56 61   nKey, pVal, nVa
8a60: 6c 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  l);.      }.    
8a70: 7d 0a 0a 20 20 20 20 74 65 73 74 44 61 74 61 73  }..    testDatas
8a80: 6f 75 72 63 65 46 72 65 65 28 70 44 61 74 61 29  ourceFree(pData)
8a90: 3b 0a 20 20 20 20 74 64 62 5f 63 6c 6f 73 65 28  ;.    tdb_close(
8aa0: 70 44 62 29 3b 0a 20 20 20 20 66 6c 75 73 68 48  pDb);.    flushH
8ab0: 6f 6f 6b 28 26 68 6f 6f 6b 29 3b 0a 20 20 20 20  ook(&hook);.    
8ac0: 66 63 6c 6f 73 65 28 68 6f 6f 6b 2e 70 4f 75 74  fclose(hook.pOut
8ad0: 29 3b 0a 20 20 7d 0a 20 20 74 65 73 74 4d 61 6c  );.  }.  testMal
8ae0: 6c 6f 63 49 6e 73 74 61 6c 6c 28 74 64 62 5f 6c  locInstall(tdb_l
8af0: 73 6d 5f 65 6e 76 28 29 29 3b 0a 0a 20 20 72 65  sm_env());..  re
8b00: 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 73 74 61 74  turn rc;.}..stat
8b10: 69 63 20 69 6e 74 20 73 74 5f 64 6f 5f 73 68 6f  ic int st_do_sho
8b20: 77 28 69 6e 74 20 61 2c 20 63 68 61 72 20 2a 2a  w(int a, char **
8b30: 62 29 20 20 20 20 20 20 7b 20 72 65 74 75 72 6e  b)      { return
8b40: 20 64 6f 5f 73 68 6f 77 28 61 2c 20 62 29 3b 20   do_show(a, b); 
8b50: 7d 0a 73 74 61 74 69 63 20 69 6e 74 20 73 74 5f  }.static int st_
8b60: 64 6f 5f 77 6f 72 6b 28 69 6e 74 20 61 2c 20 63  do_work(int a, c
8b70: 68 61 72 20 2a 2a 62 29 20 20 20 20 20 20 7b 20  har **b)      { 
8b80: 72 65 74 75 72 6e 20 64 6f 5f 77 6f 72 6b 28 61  return do_work(a
8b90: 2c 20 62 29 3b 20 7d 0a 73 74 61 74 69 63 20 69  , b); }.static i
8ba0: 6e 74 20 73 74 5f 64 6f 5f 69 6f 28 69 6e 74 20  nt st_do_io(int 
8bb0: 61 2c 20 63 68 61 72 20 2a 2a 62 29 20 20 20 20  a, char **b)    
8bc0: 20 20 20 20 7b 20 72 65 74 75 72 6e 20 64 6f 5f      { return do_
8bd0: 69 6f 28 61 2c 20 62 29 3b 20 7d 0a 0a 23 69 66  io(a, b); }..#if
8be0: 64 65 66 20 5f 5f 6c 69 6e 75 78 5f 5f 0a 23 69  def __linux__.#i
8bf0: 6e 63 6c 75 64 65 20 3c 73 79 73 2f 74 69 6d 65  nclude <sys/time
8c00: 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 73 79  .h>.#include <sy
8c10: 73 2f 72 65 73 6f 75 72 63 65 2e 68 3e 0a 0a 73  s/resource.h>..s
8c20: 74 61 74 69 63 20 76 6f 69 64 20 6c 73 6d 74 65  tatic void lsmte
8c30: 73 74 5f 72 75 73 61 67 65 5f 72 65 70 6f 72 74  st_rusage_report
8c40: 28 76 6f 69 64 29 7b 0a 20 20 73 74 72 75 63 74  (void){.  struct
8c50: 20 72 75 73 61 67 65 20 72 3b 0a 20 20 6d 65 6d   rusage r;.  mem
8c60: 73 65 74 28 26 72 2c 20 30 2c 20 73 69 7a 65 6f  set(&r, 0, sizeo
8c70: 66 28 72 29 29 3b 0a 0a 20 20 67 65 74 72 75 73  f(r));..  getrus
8c80: 61 67 65 28 52 55 53 41 47 45 5f 53 45 4c 46 2c  age(RUSAGE_SELF,
8c90: 20 26 72 29 3b 0a 20 20 70 72 69 6e 74 66 28 22   &r);.  printf("
8ca0: 23 20 67 65 74 72 75 73 61 67 65 3a 20 7b 20 72  # getrusage: { r
8cb0: 75 5f 6d 61 78 72 73 73 20 25 64 20 72 75 5f 6f  u_maxrss %d ru_o
8cc0: 75 62 6c 6f 63 6b 20 25 64 20 72 75 5f 69 6e 62  ublock %d ru_inb
8cd0: 6c 6f 63 6b 20 25 64 20 7d 5c 6e 22 2c 20 0a 20  lock %d }\n", . 
8ce0: 20 20 20 20 20 28 69 6e 74 29 72 2e 72 75 5f 6d       (int)r.ru_m
8cf0: 61 78 72 73 73 2c 20 28 69 6e 74 29 72 2e 72 75  axrss, (int)r.ru
8d00: 5f 6f 75 62 6c 6f 63 6b 2c 20 28 69 6e 74 29 72  _oublock, (int)r
8d10: 2e 72 75 5f 69 6e 62 6c 6f 63 6b 0a 20 20 29 3b  .ru_inblock.  );
8d20: 0a 7d 0a 23 65 6c 73 65 0a 73 74 61 74 69 63 20  .}.#else.static 
8d30: 76 6f 69 64 20 6c 73 6d 74 65 73 74 5f 72 75 73  void lsmtest_rus
8d40: 61 67 65 5f 72 65 70 6f 72 74 28 76 6f 69 64 29  age_report(void)
8d50: 7b 0a 20 20 2f 2a 20 6e 6f 2d 6f 70 20 2a 2f 0a  {.  /* no-op */.
8d60: 7d 0a 23 65 6e 64 69 66 0a 0a 69 6e 74 20 6d 61  }.#endif..int ma
8d70: 69 6e 28 69 6e 74 20 61 72 67 63 2c 20 63 68 61  in(int argc, cha
8d80: 72 20 2a 2a 61 72 67 76 29 7b 0a 20 20 73 74 72  r **argv){.  str
8d90: 75 63 74 20 54 65 73 74 46 75 6e 63 20 7b 0a 20  uct TestFunc {. 
8da0: 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a     const char *z
8db0: 4e 61 6d 65 3b 0a 20 20 20 20 69 6e 74 20 62 52  Name;.    int bR
8dc0: 75 73 61 67 65 52 65 70 6f 72 74 3b 0a 20 20 20  usageReport;.   
8dd0: 20 69 6e 74 20 28 2a 78 46 75 6e 63 29 28 69 6e   int (*xFunc)(in
8de0: 74 2c 20 63 68 61 72 20 2a 2a 29 3b 0a 20 20 7d  t, char **);.  }
8df0: 20 61 54 65 73 74 5b 5d 20 3d 20 7b 0a 20 20 20   aTest[] = {.   
8e00: 20 7b 22 72 61 6e 64 6f 6d 22 2c 20 20 20 20 20   {"random",     
8e10: 20 31 2c 20 64 6f 5f 72 61 6e 64 6f 6d 5f 74 65   1, do_random_te
8e20: 73 74 73 7d 2c 0a 20 20 20 20 7b 22 77 72 69 74  sts},.    {"writ
8e30: 65 73 70 65 65 64 22 2c 20 20 31 2c 20 64 6f 5f  espeed",  1, do_
8e40: 77 72 69 74 65 72 5f 74 65 73 74 7d 2c 0a 20 20  writer_test},.  
8e50: 20 20 7b 22 69 6f 22 2c 20 20 20 20 20 20 20 20    {"io",        
8e60: 20 20 31 2c 20 73 74 5f 64 6f 5f 69 6f 7d 2c 0a    1, st_do_io},.
8e70: 0a 20 20 20 20 7b 22 69 6e 73 65 72 74 22 2c 20  .    {"insert", 
8e80: 20 20 20 20 20 31 2c 20 64 6f 5f 69 6e 73 65 72       1, do_inser
8e90: 74 7d 2c 0a 20 20 20 20 7b 22 72 65 70 6c 61 79  t},.    {"replay
8ea0: 22 2c 20 20 20 20 20 20 31 2c 20 64 6f 5f 72 65  ",      1, do_re
8eb0: 70 6c 61 79 7d 2c 0a 0a 20 20 20 20 7b 22 73 70  play},..    {"sp
8ec0: 65 65 64 22 2c 20 20 20 20 20 20 20 31 2c 20 64  eed",       1, d
8ed0: 6f 5f 73 70 65 65 64 5f 74 65 73 74 73 7d 2c 0a  o_speed_tests},.
8ee0: 20 20 20 20 7b 22 73 70 65 65 64 32 22 2c 20 20      {"speed2",  
8ef0: 20 20 20 20 31 2c 20 64 6f 5f 73 70 65 65 64 5f      1, do_speed_
8f00: 74 65 73 74 32 7d 2c 0a 20 20 20 20 7b 22 73 68  test2},.    {"sh
8f10: 6f 77 22 2c 20 20 20 20 20 20 20 20 30 2c 20 73  ow",        0, s
8f20: 74 5f 64 6f 5f 73 68 6f 77 7d 2c 0a 20 20 20 20  t_do_show},.    
8f30: 7b 22 77 6f 72 6b 22 2c 20 20 20 20 20 20 20 20  {"work",        
8f40: 31 2c 20 73 74 5f 64 6f 5f 77 6f 72 6b 7d 2c 0a  1, st_do_work},.
8f50: 20 20 20 20 7b 22 74 65 73 74 22 2c 20 20 20 20      {"test",    
8f60: 20 20 20 20 31 2c 20 64 6f 5f 74 65 73 74 7d 2c      1, do_test},
8f70: 0a 0a 20 20 20 20 7b 30 2c 20 30 7d 0a 20 20 7d  ..    {0, 0}.  }
8f80: 3b 0a 20 20 69 6e 74 20 72 63 3b 20 20 20 20 20  ;.  int rc;     
8f90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8fa0: 20 20 20 20 2f 2a 20 52 65 74 75 72 6e 20 43 6f      /* Return Co
8fb0: 64 65 20 2a 2f 0a 20 20 69 6e 74 20 69 46 75 6e  de */.  int iFun
8fc0: 63 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  c;              
8fd0: 20 20 20 20 20 20 20 20 2f 2a 20 49 6e 64 65 78          /* Index
8fe0: 20 69 6e 74 6f 20 61 54 65 73 74 5b 5d 20 2a 2f   into aTest[] */
8ff0: 0a 0a 20 20 69 6e 74 20 6e 4c 65 61 6b 41 6c 6c  ..  int nLeakAll
9000: 6f 63 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20  oc = 0;         
9010: 20 20 20 20 2f 2a 20 41 6c 6c 6f 63 61 74 69 6f      /* Allocatio
9020: 6e 73 20 6c 65 61 6b 65 64 20 62 79 20 6c 73 6d  ns leaked by lsm
9030: 20 2a 2f 0a 20 20 69 6e 74 20 6e 4c 65 61 6b 42   */.  int nLeakB
9040: 79 74 65 20 3d 20 30 3b 20 20 20 20 20 20 20 20  yte = 0;        
9050: 20 20 20 20 20 20 2f 2a 20 42 79 74 65 73 20 6c        /* Bytes l
9060: 65 61 6b 65 64 20 62 79 20 6c 73 6d 20 2a 2f 0a  eaked by lsm */.
9070: 0a 23 69 66 64 65 66 20 4c 53 4d 5f 44 45 42 55  .#ifdef LSM_DEBU
9080: 47 5f 4d 45 4d 0a 20 20 46 49 4c 45 20 2a 70 52  G_MEM.  FILE *pR
9090: 65 70 6f 72 74 20 3d 20 30 3b 20 20 20 20 20 20  eport = 0;      
90a0: 20 20 20 20 20 20 20 20 2f 2a 20 6c 73 6d 20 6d          /* lsm m
90b0: 61 6c 6c 6f 63 28 29 20 72 65 70 6f 72 74 20 66  alloc() report f
90c0: 69 6c 65 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 63  ile */.  const c
90d0: 68 61 72 20 2a 7a 52 65 70 6f 72 74 20 3d 20 22  har *zReport = "
90e0: 6d 61 6c 6c 6f 63 2e 74 78 74 20 67 65 6e 65 72  malloc.txt gener
90f0: 61 74 65 64 22 3b 0a 23 65 6c 73 65 0a 20 20 63  ated";.#else.  c
9100: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 52 65 70 6f  onst char *zRepo
9110: 72 74 20 3d 20 22 6d 61 6c 6c 6f 63 2e 74 78 74  rt = "malloc.txt
9120: 20 4e 4f 54 20 67 65 6e 65 72 61 74 65 64 22 3b   NOT generated";
9130: 0a 23 65 6e 64 69 66 0a 0a 20 20 74 65 73 74 4d  .#endif..  testM
9140: 61 6c 6c 6f 63 49 6e 73 74 61 6c 6c 28 74 64 62  allocInstall(tdb
9150: 5f 6c 73 6d 5f 65 6e 76 28 29 29 3b 0a 0a 20 20  _lsm_env());..  
9160: 69 66 28 20 61 72 67 63 3c 32 20 29 7b 0a 20 20  if( argc<2 ){.  
9170: 20 20 74 65 73 74 50 72 69 6e 74 45 72 72 6f 72    testPrintError
9180: 28 22 55 73 61 67 65 3a 20 25 73 20 73 75 62 2d  ("Usage: %s sub-
9190: 63 6f 6d 6d 61 6e 64 20 3f 61 72 67 73 2e 2e 2e  command ?args...
91a0: 3f 5c 6e 22 2c 20 61 72 67 76 5b 30 5d 29 3b 0a  ?\n", argv[0]);.
91b0: 20 20 20 20 72 65 74 75 72 6e 20 2d 31 3b 0a 20      return -1;. 
91c0: 20 7d 0a 0a 20 20 2f 2a 20 49 6e 69 74 69 61 6c   }..  /* Initial
91d0: 69 7a 65 20 65 72 72 6f 72 20 72 65 70 6f 72 74  ize error report
91e0: 69 6e 67 20 2a 2f 0a 20 20 74 65 73 74 45 72 72  ing */.  testErr
91f0: 6f 72 49 6e 69 74 28 61 72 67 63 2c 20 61 72 67  orInit(argc, arg
9200: 76 29 3b 0a 0a 20 20 2f 2a 20 49 6e 69 74 69 61  v);..  /* Initia
9210: 6c 69 7a 65 20 50 52 4e 47 20 73 79 73 74 65 6d  lize PRNG system
9220: 20 2a 2f 0a 20 20 74 65 73 74 50 72 6e 67 49 6e   */.  testPrngIn
9230: 69 74 28 29 3b 0a 0a 20 20 72 63 20 3d 20 74 65  it();..  rc = te
9240: 73 74 41 72 67 53 65 6c 65 63 74 28 61 54 65 73  stArgSelect(aTes
9250: 74 2c 20 22 73 75 62 2d 63 6f 6d 6d 61 6e 64 22  t, "sub-command"
9260: 2c 20 61 72 67 76 5b 31 5d 2c 20 26 69 46 75 6e  , argv[1], &iFun
9270: 63 29 3b 0a 20 20 69 66 28 20 72 63 3d 3d 30 20  c);.  if( rc==0 
9280: 29 7b 0a 20 20 20 20 72 63 20 3d 20 61 54 65 73  ){.    rc = aTes
9290: 74 5b 69 46 75 6e 63 5d 2e 78 46 75 6e 63 28 61  t[iFunc].xFunc(a
92a0: 72 67 63 2d 32 2c 20 26 61 72 67 76 5b 32 5d 29  rgc-2, &argv[2])
92b0: 3b 0a 20 20 7d 0a 0a 23 69 66 64 65 66 20 4c 53  ;.  }..#ifdef LS
92c0: 4d 5f 44 45 42 55 47 5f 4d 45 4d 0a 20 20 70 52  M_DEBUG_MEM.  pR
92d0: 65 70 6f 72 74 20 3d 20 66 6f 70 65 6e 28 22 6d  eport = fopen("m
92e0: 61 6c 6c 6f 63 2e 74 78 74 22 2c 20 22 77 22 29  alloc.txt", "w")
92f0: 3b 0a 20 20 74 65 73 74 4d 61 6c 6c 6f 63 43 68  ;.  testMallocCh
9300: 65 63 6b 28 74 64 62 5f 6c 73 6d 5f 65 6e 76 28  eck(tdb_lsm_env(
9310: 29 2c 20 26 6e 4c 65 61 6b 41 6c 6c 6f 63 2c 20  ), &nLeakAlloc, 
9320: 26 6e 4c 65 61 6b 42 79 74 65 2c 20 70 52 65 70  &nLeakByte, pRep
9330: 6f 72 74 29 3b 0a 20 20 66 63 6c 6f 73 65 28 70  ort);.  fclose(p
9340: 52 65 70 6f 72 74 29 3b 0a 23 65 6c 73 65 0a 20  Report);.#else. 
9350: 20 74 65 73 74 4d 61 6c 6c 6f 63 43 68 65 63 6b   testMallocCheck
9360: 28 74 64 62 5f 6c 73 6d 5f 65 6e 76 28 29 2c 20  (tdb_lsm_env(), 
9370: 26 6e 4c 65 61 6b 41 6c 6c 6f 63 2c 20 26 6e 4c  &nLeakAlloc, &nL
9380: 65 61 6b 42 79 74 65 2c 20 30 29 3b 0a 23 65 6e  eakByte, 0);.#en
9390: 64 69 66 0a 0a 20 20 69 66 28 20 6e 4c 65 61 6b  dif..  if( nLeak
93a0: 41 6c 6c 6f 63 20 29 7b 0a 20 20 20 20 74 65 73  Alloc ){.    tes
93b0: 74 50 72 69 6e 74 45 72 72 6f 72 28 22 4c 65 61  tPrintError("Lea
93c0: 6b 65 64 20 25 64 20 62 79 74 65 73 20 69 6e 20  ked %d bytes in 
93d0: 25 64 20 61 6c 6c 6f 63 61 74 69 6f 6e 73 20 28  %d allocations (
93e0: 25 73 29 5c 6e 22 2c 20 0a 20 20 20 20 20 20 20  %s)\n", .       
93f0: 20 6e 4c 65 61 6b 42 79 74 65 2c 20 6e 4c 65 61   nLeakByte, nLea
9400: 6b 41 6c 6c 6f 63 2c 20 7a 52 65 70 6f 72 74 0a  kAlloc, zReport.
9410: 20 20 20 20 29 3b 0a 20 20 20 20 69 66 28 20 72      );.    if( r
9420: 63 3d 3d 30 20 29 20 72 63 20 3d 20 2d 31 3b 0a  c==0 ) rc = -1;.
9430: 20 20 7d 0a 20 20 74 65 73 74 4d 61 6c 6c 6f 63    }.  testMalloc
9440: 55 6e 69 6e 73 74 61 6c 6c 28 74 64 62 5f 6c 73  Uninstall(tdb_ls
9450: 6d 5f 65 6e 76 28 29 29 3b 0a 0a 20 20 69 66 28  m_env());..  if(
9460: 20 61 54 65 73 74 5b 69 46 75 6e 63 5d 2e 62 52   aTest[iFunc].bR
9470: 75 73 61 67 65 52 65 70 6f 72 74 20 29 7b 0a 20  usageReport ){. 
9480: 20 20 20 6c 73 6d 74 65 73 74 5f 72 75 73 61 67     lsmtest_rusag
9490: 65 5f 72 65 70 6f 72 74 28 29 3b 0a 20 20 7d 0a  e_report();.  }.
94a0: 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a       return rc;.}.