/ Hex Artifact Content
Login

Artifact 7ce07da76b5e745783e703a834417d725b7d45fd:


0000: 2f 2a 0a 2a 2a 20 50 65 72 66 6f 72 6d 61 6e 63  /*.** Performanc
0010: 65 20 74 65 73 74 20 66 6f 72 20 53 51 4c 69 74  e test for SQLit
0020: 65 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20 70 72  e..**.** This pr
0030: 6f 67 72 61 6d 20 72 65 61 64 73 20 41 53 43 49  ogram reads ASCI
0040: 49 20 74 65 78 74 20 66 72 6f 6d 20 61 20 66 69  I text from a fi
0050: 6c 65 20 6e 61 6d 65 64 20 6f 6e 20 74 68 65 20  le named on the 
0060: 63 6f 6d 6d 61 6e 64 2d 6c 69 6e 65 0a 2a 2a 20  command-line.** 
0070: 61 6e 64 20 73 75 62 6d 69 74 73 20 74 68 61 74  and submits that
0080: 20 74 65 78 74 20 20 74 6f 20 53 51 4c 69 74 65   text  to SQLite
0090: 20 66 6f 72 20 65 76 61 6c 75 61 74 69 6f 6e 2e   for evaluation.
00a0: 20 20 41 20 6e 65 77 20 64 61 74 61 62 61 73 65    A new database
00b0: 0a 2a 2a 20 69 73 20 63 72 65 61 74 65 64 20 61  .** is created a
00c0: 74 20 74 68 65 20 62 65 67 69 6e 6e 69 6e 67 20  t the beginning 
00d0: 6f 66 20 74 68 65 20 70 72 6f 67 72 61 6d 2e 20  of the program. 
00e0: 20 41 6c 6c 20 73 74 61 74 65 6d 65 6e 74 73 20   All statements 
00f0: 61 72 65 0a 2a 2a 20 74 69 6d 65 64 20 75 73 69  are.** timed usi
0100: 6e 67 20 74 68 65 20 68 69 67 68 2d 72 65 73 6f  ng the high-reso
0110: 6c 75 74 69 6f 6e 20 74 69 6d 65 72 20 62 75 69  lution timer bui
0120: 6c 74 20 69 6e 74 6f 20 49 6e 74 65 6c 2d 63 6c  lt into Intel-cl
0130: 61 73 73 20 70 72 6f 63 65 73 73 6f 72 73 2e 0a  ass processors..
0140: 2a 2a 0a 2a 2a 20 54 6f 20 63 6f 6d 70 69 6c 65  **.** To compile
0150: 20 74 68 69 73 20 70 72 6f 67 72 61 6d 2c 20 66   this program, f
0160: 69 72 73 74 20 63 6f 6d 70 69 6c 65 20 74 68 65  irst compile the
0170: 20 53 51 4c 69 74 65 20 6c 69 62 72 61 72 79 20   SQLite library 
0180: 73 65 70 61 72 61 74 65 6c 79 0a 2a 2a 20 77 69  separately.** wi
0190: 6c 6c 20 66 75 6c 6c 20 6f 70 74 69 6d 69 7a 61  ll full optimiza
01a0: 74 69 6f 6e 73 2e 20 20 46 6f 72 20 65 78 61 6d  tions.  For exam
01b0: 70 6c 65 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 67  ple:.**.**     g
01c0: 63 63 20 2d 63 20 2d 4f 36 20 2d 44 53 51 4c 49  cc -c -O6 -DSQLI
01d0: 54 45 5f 54 48 52 45 41 44 53 41 46 45 3d 30 20  TE_THREADSAFE=0 
01e0: 73 71 6c 69 74 65 33 2e 63 0a 2a 2a 0a 2a 2a 20  sqlite3.c.**.** 
01f0: 54 68 65 6e 20 6c 69 6e 6b 20 61 67 61 69 6e 73  Then link agains
0200: 74 20 74 68 69 73 20 70 72 6f 67 72 61 6d 2e 20  t this program. 
0210: 20 42 75 74 20 74 6f 20 64 6f 20 6f 70 74 69 6d   But to do optim
0220: 69 7a 65 20 74 68 69 73 20 70 72 6f 67 72 61 6d  ize this program
0230: 0a 2a 2a 20 62 65 63 61 75 73 65 20 74 68 61 74  .** because that
0240: 20 64 65 66 65 61 74 73 20 74 68 65 20 68 69 2d   defeats the hi-
0250: 72 65 73 20 74 69 6d 65 72 2e 0a 2a 2a 0a 2a 2a  res timer..**.**
0260: 20 20 20 20 20 67 63 63 20 73 70 65 65 64 74 65       gcc speedte
0270: 73 74 38 2e 63 20 73 71 6c 69 74 65 33 2e 6f 20  st8.c sqlite3.o 
0280: 2d 6c 64 6c 20 2d 49 2e 2e 2f 73 72 63 0a 2a 2a  -ldl -I../src.**
0290: 0a 2a 2a 20 54 68 65 6e 20 72 75 6e 20 74 68 69  .** Then run thi
02a0: 73 20 70 72 6f 67 72 61 6d 20 77 69 74 68 20 61  s program with a
02b0: 20 73 69 6e 67 6c 65 20 61 72 67 75 6d 65 6e 74   single argument
02c0: 20 77 68 69 63 68 20 69 73 20 74 68 65 20 6e 61   which is the na
02d0: 6d 65 20 6f 66 0a 2a 2a 20 61 20 66 69 6c 65 20  me of.** a file 
02e0: 63 6f 6e 74 61 69 6e 69 6e 67 20 53 51 4c 20 73  containing SQL s
02f0: 63 72 69 70 74 20 74 68 61 74 20 79 6f 75 20 77  cript that you w
0300: 61 6e 74 20 74 6f 20 74 65 73 74 3a 0a 2a 2a 0a  ant to test:.**.
0310: 2a 2a 20 20 20 20 20 2e 2f 61 2e 6f 75 74 20 74  **     ./a.out t
0320: 65 73 74 2e 64 62 20 20 74 65 73 74 2e 73 71 6c  est.db  test.sql
0330: 0a 2a 2f 0a 23 69 6e 63 6c 75 64 65 20 3c 73 74  .*/.#include <st
0340: 64 69 6f 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20  dio.h>.#include 
0350: 3c 73 74 72 69 6e 67 2e 68 3e 0a 23 69 6e 63 6c  <string.h>.#incl
0360: 75 64 65 20 3c 73 74 64 6c 69 62 2e 68 3e 0a 23  ude <stdlib.h>.#
0370: 69 6e 63 6c 75 64 65 20 3c 63 74 79 70 65 2e 68  include <ctype.h
0380: 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 75 6e 69 73  >.#include <unis
0390: 74 64 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c  td.h>.#include <
03a0: 73 74 64 61 72 67 2e 68 3e 0a 23 69 6e 63 6c 75  stdarg.h>.#inclu
03b0: 64 65 20 22 73 71 6c 69 74 65 33 2e 68 22 0a 0a  de "sqlite3.h"..
03c0: 23 64 65 66 69 6e 65 20 49 53 53 50 41 43 45 28  #define ISSPACE(
03d0: 58 29 20 20 69 73 73 70 61 63 65 28 28 75 6e 73  X)  isspace((uns
03e0: 69 67 6e 65 64 20 63 68 61 72 29 28 58 29 29 0a  igned char)(X)).
03f0: 0a 23 69 6e 63 6c 75 64 65 20 22 74 65 73 74 5f  .#include "test_
0400: 6f 73 69 6e 73 74 2e 63 22 0a 0a 2f 2a 0a 2a 2a  osinst.c"../*.**
0410: 20 50 72 65 70 61 72 65 20 61 6e 64 20 72 75 6e   Prepare and run
0420: 20 61 20 73 69 6e 67 6c 65 20 73 74 61 74 65 6d   a single statem
0430: 65 6e 74 20 6f 66 20 53 51 4c 2e 0a 2a 2f 0a 73  ent of SQL..*/.s
0440: 74 61 74 69 63 20 76 6f 69 64 20 70 72 65 70 61  tatic void prepa
0450: 72 65 41 6e 64 52 75 6e 28 73 71 6c 69 74 65 33  reAndRun(sqlite3
0460: 5f 76 66 73 20 2a 70 49 6e 73 74 56 66 73 2c 20  _vfs *pInstVfs, 
0470: 73 71 6c 69 74 65 33 20 2a 64 62 2c 20 63 6f 6e  sqlite3 *db, con
0480: 73 74 20 63 68 61 72 20 2a 7a 53 71 6c 29 7b 0a  st char *zSql){.
0490: 20 20 73 71 6c 69 74 65 33 5f 73 74 6d 74 20 2a    sqlite3_stmt *
04a0: 70 53 74 6d 74 3b 0a 20 20 63 6f 6e 73 74 20 63  pStmt;.  const c
04b0: 68 61 72 20 2a 73 74 6d 74 54 61 69 6c 3b 0a 20  har *stmtTail;. 
04c0: 20 69 6e 74 20 72 63 3b 0a 20 20 63 68 61 72 20   int rc;.  char 
04d0: 7a 4d 65 73 73 61 67 65 5b 31 30 32 34 5d 3b 0a  zMessage[1024];.
04e0: 20 20 7a 4d 65 73 73 61 67 65 5b 31 30 32 33 5d    zMessage[1023]
04f0: 20 3d 20 27 5c 30 27 3b 0a 0a 20 20 73 71 6c 69   = '\0';..  sqli
0500: 74 65 33 5f 75 69 6e 74 36 34 20 69 54 69 6d 65  te3_uint64 iTime
0510: 3b 0a 0a 20 20 73 71 6c 69 74 65 33 5f 73 6e 70  ;..  sqlite3_snp
0520: 72 69 6e 74 66 28 31 30 32 33 2c 20 7a 4d 65 73  rintf(1023, zMes
0530: 73 61 67 65 2c 20 22 73 71 6c 69 74 65 33 5f 70  sage, "sqlite3_p
0540: 72 65 70 61 72 65 5f 76 32 3a 20 25 73 22 2c 20  repare_v2: %s", 
0550: 7a 53 71 6c 29 3b 0a 20 20 73 71 6c 69 74 65 33  zSql);.  sqlite3
0560: 5f 69 6e 73 74 76 66 73 5f 62 69 6e 61 72 79 6c  _instvfs_binaryl
0570: 6f 67 5f 6d 61 72 6b 65 72 28 70 49 6e 73 74 56  og_marker(pInstV
0580: 66 73 2c 20 7a 4d 65 73 73 61 67 65 29 3b 0a 0a  fs, zMessage);..
0590: 20 20 69 54 69 6d 65 20 3d 20 73 71 6c 69 74 65    iTime = sqlite
05a0: 33 48 77 74 69 6d 65 28 29 3b 0a 20 20 72 63 20  3Hwtime();.  rc 
05b0: 3d 20 73 71 6c 69 74 65 33 5f 70 72 65 70 61 72  = sqlite3_prepar
05c0: 65 5f 76 32 28 64 62 2c 20 7a 53 71 6c 2c 20 2d  e_v2(db, zSql, -
05d0: 31 2c 20 26 70 53 74 6d 74 2c 20 26 73 74 6d 74  1, &pStmt, &stmt
05e0: 54 61 69 6c 29 3b 0a 20 20 69 54 69 6d 65 20 3d  Tail);.  iTime =
05f0: 20 73 71 6c 69 74 65 33 48 77 74 69 6d 65 28 29   sqlite3Hwtime()
0600: 20 2d 20 69 54 69 6d 65 3b 0a 20 20 73 71 6c 69   - iTime;.  sqli
0610: 74 65 33 5f 69 6e 73 74 76 66 73 5f 62 69 6e 61  te3_instvfs_bina
0620: 72 79 6c 6f 67 5f 63 61 6c 6c 28 70 49 6e 73 74  rylog_call(pInst
0630: 56 66 73 2c 42 49 4e 41 52 59 4c 4f 47 5f 50 52  Vfs,BINARYLOG_PR
0640: 45 50 41 52 45 5f 56 32 2c 69 54 69 6d 65 2c 72  EPARE_V2,iTime,r
0650: 63 2c 7a 53 71 6c 29 3b 0a 0a 20 20 69 66 28 20  c,zSql);..  if( 
0660: 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b  rc==SQLITE_OK ){
0670: 0a 20 20 20 20 69 6e 74 20 6e 52 6f 77 20 3d 20  .    int nRow = 
0680: 30 3b 0a 0a 20 20 20 20 73 71 6c 69 74 65 33 5f  0;..    sqlite3_
0690: 73 6e 70 72 69 6e 74 66 28 31 30 32 33 2c 20 7a  snprintf(1023, z
06a0: 4d 65 73 73 61 67 65 2c 20 22 73 71 6c 69 74 65  Message, "sqlite
06b0: 33 5f 73 74 65 70 20 6c 6f 6f 70 3a 20 25 73 22  3_step loop: %s"
06c0: 2c 20 7a 53 71 6c 29 3b 0a 20 20 20 20 73 71 6c  , zSql);.    sql
06d0: 69 74 65 33 5f 69 6e 73 74 76 66 73 5f 62 69 6e  ite3_instvfs_bin
06e0: 61 72 79 6c 6f 67 5f 6d 61 72 6b 65 72 28 70 49  arylog_marker(pI
06f0: 6e 73 74 56 66 73 2c 20 7a 4d 65 73 73 61 67 65  nstVfs, zMessage
0700: 29 3b 0a 20 20 20 20 69 54 69 6d 65 20 3d 20 73  );.    iTime = s
0710: 71 6c 69 74 65 33 48 77 74 69 6d 65 28 29 3b 0a  qlite3Hwtime();.
0720: 20 20 20 20 77 68 69 6c 65 28 20 28 72 63 3d 73      while( (rc=s
0730: 71 6c 69 74 65 33 5f 73 74 65 70 28 70 53 74 6d  qlite3_step(pStm
0740: 74 29 29 3d 3d 53 51 4c 49 54 45 5f 52 4f 57 20  t))==SQLITE_ROW 
0750: 29 7b 20 6e 52 6f 77 2b 2b 3b 20 7d 0a 20 20 20  ){ nRow++; }.   
0760: 20 69 54 69 6d 65 20 3d 20 73 71 6c 69 74 65 33   iTime = sqlite3
0770: 48 77 74 69 6d 65 28 29 20 2d 20 69 54 69 6d 65  Hwtime() - iTime
0780: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 69 6e  ;.    sqlite3_in
0790: 73 74 76 66 73 5f 62 69 6e 61 72 79 6c 6f 67 5f  stvfs_binarylog_
07a0: 63 61 6c 6c 28 70 49 6e 73 74 56 66 73 2c 20 42  call(pInstVfs, B
07b0: 49 4e 41 52 59 4c 4f 47 5f 53 54 45 50 2c 20 69  INARYLOG_STEP, i
07c0: 54 69 6d 65 2c 20 72 63 2c 20 7a 53 71 6c 29 3b  Time, rc, zSql);
07d0: 0a 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 73 6e  ..    sqlite3_sn
07e0: 70 72 69 6e 74 66 28 31 30 32 33 2c 20 7a 4d 65  printf(1023, zMe
07f0: 73 73 61 67 65 2c 20 22 73 71 6c 69 74 65 33 5f  ssage, "sqlite3_
0800: 66 69 6e 61 6c 69 7a 65 3a 20 25 73 22 2c 20 7a  finalize: %s", z
0810: 53 71 6c 29 3b 0a 20 20 20 20 73 71 6c 69 74 65  Sql);.    sqlite
0820: 33 5f 69 6e 73 74 76 66 73 5f 62 69 6e 61 72 79  3_instvfs_binary
0830: 6c 6f 67 5f 6d 61 72 6b 65 72 28 70 49 6e 73 74  log_marker(pInst
0840: 56 66 73 2c 20 7a 4d 65 73 73 61 67 65 29 3b 0a  Vfs, zMessage);.
0850: 20 20 20 20 69 54 69 6d 65 20 3d 20 73 71 6c 69      iTime = sqli
0860: 74 65 33 48 77 74 69 6d 65 28 29 3b 0a 20 20 20  te3Hwtime();.   
0870: 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 66 69   rc = sqlite3_fi
0880: 6e 61 6c 69 7a 65 28 70 53 74 6d 74 29 3b 0a 20  nalize(pStmt);. 
0890: 20 20 20 69 54 69 6d 65 20 3d 20 73 71 6c 69 74     iTime = sqlit
08a0: 65 33 48 77 74 69 6d 65 28 29 20 2d 20 69 54 69  e3Hwtime() - iTi
08b0: 6d 65 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f  me;.    sqlite3_
08c0: 69 6e 73 74 76 66 73 5f 62 69 6e 61 72 79 6c 6f  instvfs_binarylo
08d0: 67 5f 63 61 6c 6c 28 70 49 6e 73 74 56 66 73 2c  g_call(pInstVfs,
08e0: 20 42 49 4e 41 52 59 4c 4f 47 5f 46 49 4e 41 4c   BINARYLOG_FINAL
08f0: 49 5a 45 2c 20 69 54 69 6d 65 2c 20 72 63 2c 20  IZE, iTime, rc, 
0900: 7a 53 71 6c 29 3b 0a 20 20 7d 0a 7d 0a 0a 73 74  zSql);.  }.}..st
0910: 61 74 69 63 20 69 6e 74 20 73 74 72 69 6e 67 63  atic int stringc
0920: 6f 6d 70 61 72 65 28 63 6f 6e 73 74 20 63 68 61  ompare(const cha
0930: 72 20 2a 7a 4c 65 66 74 2c 20 63 6f 6e 73 74 20  r *zLeft, const 
0940: 63 68 61 72 20 2a 7a 52 69 67 68 74 29 7b 0a 20  char *zRight){. 
0950: 20 69 6e 74 20 69 69 3b 0a 20 20 66 6f 72 28 69   int ii;.  for(i
0960: 69 3d 30 3b 20 7a 4c 65 66 74 5b 69 69 5d 20 26  i=0; zLeft[ii] &
0970: 26 20 7a 52 69 67 68 74 5b 69 69 5d 3b 20 69 69  & zRight[ii]; ii
0980: 2b 2b 29 7b 0a 20 20 20 20 69 66 28 20 7a 4c 65  ++){.    if( zLe
0990: 66 74 5b 69 69 5d 21 3d 7a 52 69 67 68 74 5b 69  ft[ii]!=zRight[i
09a0: 69 5d 20 29 20 72 65 74 75 72 6e 20 30 3b 0a 20  i] ) return 0;. 
09b0: 20 7d 0a 20 20 72 65 74 75 72 6e 28 20 7a 4c 65   }.  return( zLe
09c0: 66 74 5b 69 69 5d 3d 3d 7a 52 69 67 68 74 5b 69  ft[ii]==zRight[i
09d0: 69 5d 20 29 3b 0a 7d 0a 0a 73 74 61 74 69 63 20  i] );.}..static 
09e0: 63 68 61 72 20 2a 72 65 61 64 53 63 72 69 70 74  char *readScript
09f0: 46 69 6c 65 28 63 6f 6e 73 74 20 63 68 61 72 20  File(const char 
0a00: 2a 7a 46 69 6c 65 2c 20 69 6e 74 20 2a 70 6e 53  *zFile, int *pnS
0a10: 63 72 69 70 74 29 7b 0a 20 20 73 71 6c 69 74 65  cript){.  sqlite
0a20: 33 5f 76 66 73 20 2a 70 56 66 73 20 3d 20 73 71  3_vfs *pVfs = sq
0a30: 6c 69 74 65 33 5f 76 66 73 5f 66 69 6e 64 28 30  lite3_vfs_find(0
0a40: 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 66 69 6c  );.  sqlite3_fil
0a50: 65 20 2a 70 3b 0a 20 20 69 6e 74 20 72 63 3b 0a  e *p;.  int rc;.
0a60: 20 20 73 71 6c 69 74 65 33 5f 69 6e 74 36 34 20    sqlite3_int64 
0a70: 6e 42 79 74 65 3b 0a 20 20 63 68 61 72 20 2a 7a  nByte;.  char *z
0a80: 44 61 74 61 20 3d 20 30 3b 0a 20 20 69 6e 74 20  Data = 0;.  int 
0a90: 66 6c 61 67 73 20 3d 20 53 51 4c 49 54 45 5f 4f  flags = SQLITE_O
0aa0: 50 45 4e 5f 52 45 41 44 4f 4e 4c 59 7c 53 51 4c  PEN_READONLY|SQL
0ab0: 49 54 45 5f 4f 50 45 4e 5f 4d 41 49 4e 5f 44 42  ITE_OPEN_MAIN_DB
0ac0: 3b 0a 0a 20 20 70 20 3d 20 28 73 71 6c 69 74 65  ;..  p = (sqlite
0ad0: 33 5f 66 69 6c 65 20 2a 29 6d 61 6c 6c 6f 63 28  3_file *)malloc(
0ae0: 70 56 66 73 2d 3e 73 7a 4f 73 46 69 6c 65 29 3b  pVfs->szOsFile);
0af0: 0a 20 20 72 63 20 3d 20 70 56 66 73 2d 3e 78 4f  .  rc = pVfs->xO
0b00: 70 65 6e 28 70 56 66 73 2c 20 7a 46 69 6c 65 2c  pen(pVfs, zFile,
0b10: 20 70 2c 20 66 6c 61 67 73 2c 20 26 66 6c 61 67   p, flags, &flag
0b20: 73 29 3b 0a 20 20 69 66 28 20 72 63 21 3d 53 51  s);.  if( rc!=SQ
0b30: 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 67  LITE_OK ){.    g
0b40: 6f 74 6f 20 65 72 72 6f 72 5f 6f 75 74 3b 0a 20  oto error_out;. 
0b50: 20 7d 0a 0a 20 20 72 63 20 3d 20 70 2d 3e 70 4d   }..  rc = p->pM
0b60: 65 74 68 6f 64 73 2d 3e 78 46 69 6c 65 53 69 7a  ethods->xFileSiz
0b70: 65 28 70 2c 20 26 6e 42 79 74 65 29 3b 0a 20 20  e(p, &nByte);.  
0b80: 69 66 28 20 72 63 21 3d 53 51 4c 49 54 45 5f 4f  if( rc!=SQLITE_O
0b90: 4b 20 29 7b 0a 20 20 20 20 67 6f 74 6f 20 63 6c  K ){.    goto cl
0ba0: 6f 73 65 5f 6f 75 74 3b 0a 20 20 7d 0a 0a 20 20  ose_out;.  }..  
0bb0: 7a 44 61 74 61 20 3d 20 28 63 68 61 72 20 2a 29  zData = (char *)
0bc0: 6d 61 6c 6c 6f 63 28 6e 42 79 74 65 2b 31 29 3b  malloc(nByte+1);
0bd0: 0a 20 20 72 63 20 3d 20 70 2d 3e 70 4d 65 74 68  .  rc = p->pMeth
0be0: 6f 64 73 2d 3e 78 52 65 61 64 28 70 2c 20 7a 44  ods->xRead(p, zD
0bf0: 61 74 61 2c 20 6e 42 79 74 65 2c 20 30 29 3b 0a  ata, nByte, 0);.
0c00: 20 20 69 66 28 20 72 63 21 3d 53 51 4c 49 54 45    if( rc!=SQLITE
0c10: 5f 4f 4b 20 29 7b 0a 20 20 20 20 67 6f 74 6f 20  _OK ){.    goto 
0c20: 63 6c 6f 73 65 5f 6f 75 74 3b 0a 20 20 7d 0a 20  close_out;.  }. 
0c30: 20 7a 44 61 74 61 5b 6e 42 79 74 65 5d 20 3d 20   zData[nByte] = 
0c40: 27 5c 30 27 3b 0a 0a 20 20 70 2d 3e 70 4d 65 74  '\0';..  p->pMet
0c50: 68 6f 64 73 2d 3e 78 43 6c 6f 73 65 28 70 29 3b  hods->xClose(p);
0c60: 0a 20 20 66 72 65 65 28 70 29 3b 0a 20 20 2a 70  .  free(p);.  *p
0c70: 6e 53 63 72 69 70 74 20 3d 20 6e 42 79 74 65 3b  nScript = nByte;
0c80: 0a 20 20 72 65 74 75 72 6e 20 7a 44 61 74 61 3b  .  return zData;
0c90: 0a 0a 63 6c 6f 73 65 5f 6f 75 74 3a 0a 20 20 70  ..close_out:.  p
0ca0: 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 43 6c 6f  ->pMethods->xClo
0cb0: 73 65 28 70 29 3b 0a 0a 65 72 72 6f 72 5f 6f 75  se(p);..error_ou
0cc0: 74 3a 0a 20 20 66 72 65 65 28 70 29 3b 0a 20 20  t:.  free(p);.  
0cd0: 66 72 65 65 28 7a 44 61 74 61 29 3b 0a 20 20 72  free(zData);.  r
0ce0: 65 74 75 72 6e 20 30 3b 0a 7d 0a 0a 69 6e 74 20  eturn 0;.}..int 
0cf0: 6d 61 69 6e 28 69 6e 74 20 61 72 67 63 2c 20 63  main(int argc, c
0d00: 68 61 72 20 2a 2a 61 72 67 76 29 7b 0a 0a 20 20  har **argv){..  
0d10: 63 6f 6e 73 74 20 63 68 61 72 20 7a 55 73 61 67  const char zUsag
0d20: 65 4d 73 67 5b 5d 20 3d 20 0a 20 20 20 20 22 55  eMsg[] = .    "U
0d30: 73 61 67 65 3a 20 25 73 20 6f 70 74 69 6f 6e 73  sage: %s options
0d40: 2e 2e 2e 5c 6e 22 0a 20 20 20 20 22 20 20 77 68  ...\n".    "  wh
0d50: 65 72 65 20 61 76 61 69 6c 61 62 6c 65 20 6f 70  ere available op
0d60: 74 69 6f 6e 73 20 61 72 65 3a 5c 6e 22 0a 20 20  tions are:\n".  
0d70: 20 20 22 5c 6e 22 0a 20 20 20 20 22 20 20 20 20    "\n".    "    
0d80: 2d 64 62 20 20 20 20 20 20 44 41 54 41 42 41 53  -db      DATABAS
0d90: 45 2d 46 49 4c 45 20 20 28 64 61 74 61 62 61 73  E-FILE  (databas
0da0: 65 20 66 69 6c 65 20 74 6f 20 6f 70 65 72 61 74  e file to operat
0db0: 65 20 6f 6e 29 5c 6e 22 0a 20 20 20 20 22 20 20  e on)\n".    "  
0dc0: 20 20 2d 73 63 72 69 70 74 20 20 53 43 52 49 50    -script  SCRIP
0dd0: 54 2d 46 49 4c 45 20 20 20 20 28 73 63 72 69 70  T-FILE    (scrip
0de0: 74 20 66 69 6c 65 20 74 6f 20 72 65 61 64 20 73  t file to read s
0df0: 71 6c 20 66 72 6f 6d 29 5c 6e 22 0a 20 20 20 20  ql from)\n".    
0e00: 22 20 20 20 20 2d 6c 6f 67 20 20 20 20 20 4c 4f  "    -log     LO
0e10: 47 2d 46 49 4c 45 20 20 20 20 20 20 20 28 6c 6f  G-FILE       (lo
0e20: 67 20 66 69 6c 65 20 74 6f 20 63 72 65 61 74 65  g file to create
0e30: 29 5c 6e 22 0a 20 20 20 20 22 20 20 20 20 2d 6c  )\n".    "    -l
0e40: 6f 67 64 61 74 61 20 20 20 20 20 20 20 20 20 20  ogdata          
0e50: 20 20 20 20 20 20 28 6c 6f 67 20 61 6c 6c 20 64        (log all d
0e60: 61 74 61 20 74 6f 20 6c 6f 67 20 66 69 6c 65 29  ata to log file)
0e70: 5c 6e 22 0a 20 20 20 20 22 5c 6e 22 0a 20 20 20  \n".    "\n".   
0e80: 20 22 20 20 4f 70 74 69 6f 6e 73 20 2d 64 62 2c   "  Options -db,
0e90: 20 2d 73 63 72 69 70 74 20 61 6e 64 20 2d 6c 6f   -script and -lo
0ea0: 67 20 61 72 65 20 63 6f 6d 70 75 6c 73 6f 72 79  g are compulsory
0eb0: 5c 6e 22 0a 20 20 20 20 22 5c 6e 22 0a 20 20 3b  \n".    "\n".  ;
0ec0: 0a 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  ..  const char *
0ed0: 7a 44 62 20 3d 20 30 3b 0a 20 20 63 6f 6e 73 74  zDb = 0;.  const
0ee0: 20 63 68 61 72 20 2a 7a 53 63 72 69 70 74 20 3d   char *zScript =
0ef0: 20 30 3b 0a 20 20 63 6f 6e 73 74 20 63 68 61 72   0;.  const char
0f00: 20 2a 7a 4c 6f 67 20 3d 20 30 3b 0a 20 20 69 6e   *zLog = 0;.  in
0f10: 74 20 6c 6f 67 64 61 74 61 20 3d 20 30 3b 0a 0a  t logdata = 0;..
0f20: 20 20 69 6e 74 20 69 69 3b 0a 20 20 69 6e 74 20    int ii;.  int 
0f30: 69 2c 20 6a 3b 0a 20 20 69 6e 74 20 72 63 3b 0a  i, j;.  int rc;.
0f40: 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a  .  sqlite3_vfs *
0f50: 70 49 6e 73 74 56 66 73 3b 20 20 20 20 20 20 20  pInstVfs;       
0f60: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 49 6e 73            /* Ins
0f70: 74 72 75 6d 65 6e 74 61 74 69 6f 6e 20 56 46 53  trumentation VFS
0f80: 20 2a 2f 0a 0a 20 20 63 68 61 72 20 2a 7a 53 71   */..  char *zSq
0f90: 6c 20 3d 20 30 3b 0a 20 20 69 6e 74 20 6e 53 71  l = 0;.  int nSq
0fa0: 6c 3b 0a 0a 20 20 73 71 6c 69 74 65 33 20 2a 64  l;..  sqlite3 *d
0fb0: 62 3b 0a 0a 20 20 66 6f 72 28 69 69 3d 31 3b 20  b;..  for(ii=1; 
0fc0: 69 69 3c 61 72 67 63 3b 20 69 69 2b 2b 29 7b 0a  ii<argc; ii++){.
0fd0: 20 20 20 20 69 66 28 20 73 74 72 69 6e 67 63 6f      if( stringco
0fe0: 6d 70 61 72 65 28 22 2d 64 62 22 2c 20 61 72 67  mpare("-db", arg
0ff0: 76 5b 69 69 5d 29 20 26 26 20 28 69 69 2b 31 29  v[ii]) && (ii+1)
1000: 3c 61 72 67 63 20 29 7b 0a 20 20 20 20 20 20 7a  <argc ){.      z
1010: 44 62 20 3d 20 61 72 67 76 5b 2b 2b 69 69 5d 3b  Db = argv[++ii];
1020: 0a 20 20 20 20 7d 0a 0a 20 20 20 20 65 6c 73 65  .    }..    else
1030: 20 69 66 28 20 73 74 72 69 6e 67 63 6f 6d 70 61   if( stringcompa
1040: 72 65 28 22 2d 73 63 72 69 70 74 22 2c 20 61 72  re("-script", ar
1050: 67 76 5b 69 69 5d 29 20 26 26 20 28 69 69 2b 31  gv[ii]) && (ii+1
1060: 29 3c 61 72 67 63 20 29 7b 0a 20 20 20 20 20 20  )<argc ){.      
1070: 7a 53 63 72 69 70 74 20 3d 20 61 72 67 76 5b 2b  zScript = argv[+
1080: 2b 69 69 5d 3b 0a 20 20 20 20 7d 0a 0a 20 20 20  +ii];.    }..   
1090: 20 65 6c 73 65 20 69 66 28 20 73 74 72 69 6e 67   else if( string
10a0: 63 6f 6d 70 61 72 65 28 22 2d 6c 6f 67 22 2c 20  compare("-log", 
10b0: 61 72 67 76 5b 69 69 5d 29 20 26 26 20 28 69 69  argv[ii]) && (ii
10c0: 2b 31 29 3c 61 72 67 63 20 29 7b 0a 20 20 20 20  +1)<argc ){.    
10d0: 20 20 7a 4c 6f 67 20 3d 20 61 72 67 76 5b 2b 2b    zLog = argv[++
10e0: 69 69 5d 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  ii];.    }..    
10f0: 65 6c 73 65 20 69 66 28 20 73 74 72 69 6e 67 63  else if( stringc
1100: 6f 6d 70 61 72 65 28 22 2d 6c 6f 67 64 61 74 61  ompare("-logdata
1110: 22 2c 20 61 72 67 76 5b 69 69 5d 29 20 29 7b 0a  ", argv[ii]) ){.
1120: 20 20 20 20 20 20 6c 6f 67 64 61 74 61 20 3d 20        logdata = 
1130: 31 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 65 6c  1;.    }..    el
1140: 73 65 20 7b 0a 20 20 20 20 20 20 67 6f 74 6f 20  se {.      goto 
1150: 75 73 61 67 65 3b 0a 20 20 20 20 7d 0a 20 20 7d  usage;.    }.  }
1160: 0a 20 20 69 66 28 20 21 7a 44 62 20 7c 7c 20 21  .  if( !zDb || !
1170: 7a 53 63 72 69 70 74 20 7c 7c 20 21 7a 4c 6f 67  zScript || !zLog
1180: 20 29 20 67 6f 74 6f 20 75 73 61 67 65 3b 0a 0a   ) goto usage;..
1190: 20 20 7a 53 71 6c 20 3d 20 72 65 61 64 53 63 72    zSql = readScr
11a0: 69 70 74 46 69 6c 65 28 7a 53 63 72 69 70 74 2c  iptFile(zScript,
11b0: 20 26 6e 53 71 6c 29 3b 0a 20 20 69 66 28 20 21   &nSql);.  if( !
11c0: 7a 53 71 6c 20 29 7b 0a 20 20 20 20 66 70 72 69  zSql ){.    fpri
11d0: 6e 74 66 28 73 74 64 65 72 72 2c 20 22 46 61 69  ntf(stderr, "Fai
11e0: 6c 65 64 20 74 6f 20 72 65 61 64 20 73 63 72 69  led to read scri
11f0: 70 74 20 66 69 6c 65 5c 6e 22 29 3b 0a 20 20 20  pt file\n");.   
1200: 20 72 65 74 75 72 6e 20 2d 31 3b 0a 20 20 7d 0a   return -1;.  }.
1210: 0a 20 20 70 49 6e 73 74 56 66 73 20 3d 20 73 71  .  pInstVfs = sq
1220: 6c 69 74 65 33 5f 69 6e 73 74 76 66 73 5f 62 69  lite3_instvfs_bi
1230: 6e 61 72 79 6c 6f 67 28 22 6c 6f 67 67 69 6e 67  narylog("logging
1240: 22 2c 20 30 2c 20 7a 4c 6f 67 2c 20 6c 6f 67 64  ", 0, zLog, logd
1250: 61 74 61 29 3b 0a 0a 20 20 72 63 20 3d 20 73 71  ata);..  rc = sq
1260: 6c 69 74 65 33 5f 6f 70 65 6e 5f 76 32 28 0a 20  lite3_open_v2(. 
1270: 20 20 20 20 7a 44 62 2c 20 26 64 62 2c 20 53 51      zDb, &db, SQ
1280: 4c 49 54 45 5f 4f 50 45 4e 5f 52 45 41 44 57 52  LITE_OPEN_READWR
1290: 49 54 45 20 7c 20 53 51 4c 49 54 45 5f 4f 50 45  ITE | SQLITE_OPE
12a0: 4e 5f 43 52 45 41 54 45 2c 20 22 6c 6f 67 67 69  N_CREATE, "loggi
12b0: 6e 67 22 0a 20 20 29 3b 0a 20 20 69 66 28 20 72  ng".  );.  if( r
12c0: 63 21 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a  c!=SQLITE_OK ){.
12d0: 20 20 20 20 66 70 72 69 6e 74 66 28 73 74 64 65      fprintf(stde
12e0: 72 72 2c 20 22 46 61 69 6c 65 64 20 74 6f 20 6f  rr, "Failed to o
12f0: 70 65 6e 20 64 62 3a 20 25 73 5c 6e 22 2c 20 73  pen db: %s\n", s
1300: 71 6c 69 74 65 33 5f 65 72 72 6d 73 67 28 64 62  qlite3_errmsg(db
1310: 29 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20 2d  ));.    return -
1320: 32 3b 0a 20 20 7d 0a 0a 20 20 66 6f 72 28 69 3d  2;.  }..  for(i=
1330: 6a 3d 30 3b 20 6a 3c 6e 53 71 6c 3b 20 6a 2b 2b  j=0; j<nSql; j++
1340: 29 7b 0a 20 20 20 20 69 66 28 20 7a 53 71 6c 5b  ){.    if( zSql[
1350: 6a 5d 3d 3d 27 3b 27 20 29 7b 0a 20 20 20 20 20  j]==';' ){.     
1360: 20 69 6e 74 20 69 73 43 6f 6d 70 6c 65 74 65 3b   int isComplete;
1370: 0a 20 20 20 20 20 20 63 68 61 72 20 63 20 3d 20  .      char c = 
1380: 7a 53 71 6c 5b 6a 2b 31 5d 3b 0a 20 20 20 20 20  zSql[j+1];.     
1390: 20 7a 53 71 6c 5b 6a 2b 31 5d 20 3d 20 30 3b 0a   zSql[j+1] = 0;.
13a0: 20 20 20 20 20 20 69 73 43 6f 6d 70 6c 65 74 65        isComplete
13b0: 20 3d 20 73 71 6c 69 74 65 33 5f 63 6f 6d 70 6c   = sqlite3_compl
13c0: 65 74 65 28 26 7a 53 71 6c 5b 69 5d 29 3b 0a 20  ete(&zSql[i]);. 
13d0: 20 20 20 20 20 7a 53 71 6c 5b 6a 2b 31 5d 20 3d       zSql[j+1] =
13e0: 20 63 3b 0a 20 20 20 20 20 20 69 66 28 20 69 73   c;.      if( is
13f0: 43 6f 6d 70 6c 65 74 65 20 29 7b 0a 20 20 20 20  Complete ){.    
1400: 20 20 20 20 7a 53 71 6c 5b 6a 5d 20 3d 20 30 3b      zSql[j] = 0;
1410: 0a 20 20 20 20 20 20 20 20 77 68 69 6c 65 28 20  .        while( 
1420: 69 3c 6a 20 26 26 20 49 53 53 50 41 43 45 28 7a  i<j && ISSPACE(z
1430: 53 71 6c 5b 69 5d 29 20 29 7b 20 69 2b 2b 3b 20  Sql[i]) ){ i++; 
1440: 7d 0a 20 20 20 20 20 20 20 20 69 66 28 20 69 3c  }.        if( i<
1450: 6a 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 70  j ){.          p
1460: 72 65 70 61 72 65 41 6e 64 52 75 6e 28 70 49 6e  repareAndRun(pIn
1470: 73 74 56 66 73 2c 20 64 62 2c 20 26 7a 53 71 6c  stVfs, db, &zSql
1480: 5b 69 5d 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a  [i]);.        }.
1490: 20 20 20 20 20 20 20 20 7a 53 71 6c 5b 6a 5d 20          zSql[j] 
14a0: 3d 20 27 3b 27 3b 0a 20 20 20 20 20 20 20 20 69  = ';';.        i
14b0: 20 3d 20 6a 2b 31 3b 0a 20 20 20 20 20 20 7d 0a   = j+1;.      }.
14c0: 20 20 20 20 7d 0a 20 20 7d 0a 20 20 0a 20 20 73      }.  }.  .  s
14d0: 71 6c 69 74 65 33 5f 69 6e 73 74 76 66 73 5f 64  qlite3_instvfs_d
14e0: 65 73 74 72 6f 79 28 70 49 6e 73 74 56 66 73 29  estroy(pInstVfs)
14f0: 3b 0a 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20  ;.  return 0;.  
1500: 0a 75 73 61 67 65 3a 0a 20 20 66 70 72 69 6e 74  .usage:.  fprint
1510: 66 28 73 74 64 65 72 72 2c 20 7a 55 73 61 67 65  f(stderr, zUsage
1520: 4d 73 67 2c 20 61 72 67 76 5b 30 5d 29 3b 0a 20  Msg, argv[0]);. 
1530: 20 72 65 74 75 72 6e 20 2d 33 3b 0a 7d 0a         return -3;.}.