/ Hex Artifact Content
Login

Artifact bab9594adc976cbe696ff3970728830b4c5ed698:


0000: 2f 2a 0a 2a 2a 20 32 30 31 31 20 4d 61 72 63 68  /*.** 2011 March
0010: 20 31 36 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75   16.**.** The au
0020: 74 68 6f 72 20 64 69 73 63 6c 61 69 6d 73 20 63  thor disclaims c
0030: 6f 70 79 72 69 67 68 74 20 74 6f 20 74 68 69 73  opyright to this
0040: 20 73 6f 75 72 63 65 20 63 6f 64 65 2e 20 20 49   source code.  I
0050: 6e 20 70 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20  n place of.** a 
0060: 6c 65 67 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65  legal notice, he
0070: 72 65 20 69 73 20 61 20 62 6c 65 73 73 69 6e 67  re is a blessing
0080: 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79  :.**.**    May y
0090: 6f 75 20 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e  ou do good and n
00a0: 6f 74 20 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d  ot evil..**    M
00b0: 61 79 20 79 6f 75 20 66 69 6e 64 20 66 6f 72 67  ay you find forg
00c0: 69 76 65 6e 65 73 73 20 66 6f 72 20 79 6f 75 72  iveness for your
00d0: 73 65 6c 66 20 61 6e 64 20 66 6f 72 67 69 76 65  self and forgive
00e0: 20 6f 74 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d   others..**    M
00f0: 61 79 20 79 6f 75 20 73 68 61 72 65 20 66 72 65  ay you share fre
0100: 65 6c 79 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e  ely, never takin
0110: 67 20 6d 6f 72 65 20 74 68 61 6e 20 79 6f 75 20  g more than you 
0120: 67 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a  give..**.*******
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0160: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0170: 2a 2a 2a 2a 2a 2a 2a 0a 2a 2a 0a 2a 2a 20 54 68  *******.**.** Th
0180: 69 73 20 66 69 6c 65 20 63 6f 6e 74 61 69 6e 73  is file contains
0190: 20 63 6f 64 65 20 69 6d 70 6c 65 6d 65 6e 74 73   code implements
01a0: 20 61 20 56 46 53 20 73 68 69 6d 20 74 68 61 74   a VFS shim that
01b0: 20 77 72 69 74 65 73 20 64 69 61 67 6e 6f 73 74   writes diagnost
01c0: 69 63 0a 2a 2a 20 6f 75 74 70 75 74 20 66 6f 72  ic.** output for
01d0: 20 65 61 63 68 20 56 46 53 20 63 61 6c 6c 2c 20   each VFS call, 
01e0: 73 69 6d 69 6c 61 72 20 74 6f 20 22 73 74 72 61  similar to "stra
01f0: 63 65 22 2e 0a 2a 2a 0a 2a 2a 20 55 53 41 47 45  ce"..**.** USAGE
0200: 3a 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20 73 6f 75  :.**.** This sou
0210: 72 63 65 20 66 69 6c 65 20 65 78 70 6f 72 74 73  rce file exports
0220: 20 61 20 73 69 6e 67 6c 65 20 73 79 6d 62 6f 6c   a single symbol
0230: 20 77 68 69 63 68 20 69 73 20 74 68 65 20 6e 61   which is the na
0240: 6d 65 20 6f 66 20 61 0a 2a 2a 20 66 75 6e 63 74  me of a.** funct
0250: 69 6f 6e 3a 0a 2a 2a 0a 2a 2a 20 20 20 69 6e 74  ion:.**.**   int
0260: 20 76 66 73 74 72 61 63 65 5f 72 65 67 69 73 74   vfstrace_regist
0270: 65 72 28 0a 2a 2a 20 20 20 20 20 63 6f 6e 73 74  er(.**     const
0280: 20 63 68 61 72 20 2a 7a 54 72 61 63 65 4e 61 6d   char *zTraceNam
0290: 65 2c 20 20 20 20 20 20 20 20 20 2f 2f 20 4e 61  e,         // Na
02a0: 6d 65 20 6f 66 20 74 68 65 20 6e 65 77 6c 79 20  me of the newly 
02b0: 63 6f 6e 73 74 72 75 63 74 65 64 20 56 46 53 0a  constructed VFS.
02c0: 2a 2a 20 20 20 20 20 63 6f 6e 73 74 20 63 68 61  **     const cha
02d0: 72 20 2a 7a 4f 6c 64 56 66 73 4e 61 6d 65 2c 20  r *zOldVfsName, 
02e0: 20 20 20 20 20 20 20 2f 2f 20 4e 61 6d 65 20 6f         // Name o
02f0: 66 20 74 68 65 20 75 6e 64 65 72 6c 79 69 6e 67  f the underlying
0300: 20 56 46 53 0a 2a 2a 20 20 20 20 20 69 6e 74 20   VFS.**     int 
0310: 28 2a 78 4f 75 74 29 28 63 6f 6e 73 74 20 63 68  (*xOut)(const ch
0320: 61 72 2a 2c 76 6f 69 64 2a 29 2c 20 2f 2f 20 4f  ar*,void*), // O
0330: 75 74 70 75 74 20 72 6f 75 74 69 6e 65 2e 20 20  utput routine.  
0340: 65 78 3a 20 66 70 75 74 73 0a 2a 2a 20 20 20 20  ex: fputs.**    
0350: 20 76 6f 69 64 20 2a 70 4f 75 74 41 72 67 2c 20   void *pOutArg, 
0360: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0370: 20 2f 2f 20 32 6e 64 20 61 72 67 75 6d 65 6e 74   // 2nd argument
0380: 20 74 6f 20 78 4f 75 74 2e 20 20 65 78 3a 20 73   to xOut.  ex: s
0390: 74 64 65 72 72 0a 2a 2a 20 20 20 20 20 69 6e 74  tderr.**     int
03a0: 20 6d 61 6b 65 44 65 66 61 75 6c 74 20 20 20 20   makeDefault    
03b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2f 20               // 
03c0: 4d 61 6b 65 20 74 68 65 20 6e 65 77 20 56 46 53  Make the new VFS
03d0: 20 74 68 65 20 64 65 66 61 75 6c 74 0a 2a 2a 20   the default.** 
03e0: 20 20 29 3b 0a 2a 2a 0a 2a 2a 20 41 70 70 6c 69    );.**.** Appli
03f0: 63 61 74 69 6f 6e 73 20 74 68 61 74 20 77 61 6e  cations that wan
0400: 74 20 74 6f 20 74 72 61 63 65 20 74 68 65 69 72  t to trace their
0410: 20 56 46 53 20 75 73 61 67 65 20 6d 75 73 74 20   VFS usage must 
0420: 70 72 6f 76 69 64 65 20 61 20 63 61 6c 6c 62 61  provide a callba
0430: 63 6b 0a 2a 2a 20 66 75 6e 63 74 69 6f 6e 20 77  ck.** function w
0440: 69 74 68 20 74 68 69 73 20 70 72 6f 74 6f 74 79  ith this prototy
0450: 70 65 3a 0a 2a 2a 0a 2a 2a 20 20 20 69 6e 74 20  pe:.**.**   int 
0460: 74 72 61 63 65 4f 75 74 70 75 74 28 63 6f 6e 73  traceOutput(cons
0470: 74 20 63 68 61 72 20 2a 7a 4d 65 73 73 61 67 65  t char *zMessage
0480: 2c 20 76 6f 69 64 20 2a 70 41 70 70 44 61 74 61  , void *pAppData
0490: 29 3b 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20 66 75  );.**.** This fu
04a0: 6e 63 74 69 6f 6e 20 77 69 6c 6c 20 22 6f 75 74  nction will "out
04b0: 70 75 74 22 20 74 68 65 20 74 72 61 63 65 20 6d  put" the trace m
04c0: 65 73 73 61 67 65 73 2c 20 77 68 65 72 65 20 22  essages, where "
04d0: 6f 75 74 70 75 74 22 20 63 61 6e 0a 2a 2a 20 6d  output" can.** m
04e0: 65 61 6e 20 64 69 66 66 65 72 65 6e 74 20 74 68  ean different th
04f0: 69 6e 67 73 20 74 6f 20 64 69 66 66 65 72 65 6e  ings to differen
0500: 74 20 61 70 70 6c 69 63 61 74 69 6f 6e 73 2e 20  t applications. 
0510: 20 54 68 65 20 74 72 61 63 65 4f 75 74 70 75 74   The traceOutput
0520: 20 66 75 6e 63 74 69 6f 6e 0a 2a 2a 20 66 6f 72   function.** for
0530: 20 74 68 65 20 63 6f 6d 6d 61 6e 64 2d 6c 69 6e   the command-lin
0540: 65 20 73 68 65 6c 6c 20 28 73 65 65 20 73 68 65  e shell (see she
0550: 6c 6c 2e 63 29 20 69 73 20 22 66 70 75 74 73 22  ll.c) is "fputs"
0560: 20 66 72 6f 6d 20 74 68 65 20 73 74 61 6e 64 61   from the standa
0570: 72 64 0a 2a 2a 20 6c 69 62 72 61 72 79 2c 20 77  rd.** library, w
0580: 68 69 63 68 20 6d 65 61 6e 73 20 74 68 61 74 20  hich means that 
0590: 61 6c 6c 20 74 72 61 63 65 20 6f 75 74 70 75 74  all trace output
05a0: 20 69 73 20 77 72 69 74 74 65 6e 20 6f 6e 20 74   is written on t
05b0: 68 65 20 73 74 72 65 61 6d 0a 2a 2a 20 73 70 65  he stream.** spe
05c0: 63 69 66 69 65 64 20 62 79 20 74 68 65 20 73 65  cified by the se
05d0: 63 6f 6e 64 20 61 72 67 75 6d 65 6e 74 2e 20 20  cond argument.  
05e0: 49 6e 20 74 68 65 20 63 61 73 65 20 6f 66 20 74  In the case of t
05f0: 68 65 20 63 6f 6d 6d 61 6e 64 2d 6c 69 6e 65 20  he command-line 
0600: 73 68 65 6c 6c 0a 2a 2a 20 74 68 65 20 73 65 63  shell.** the sec
0610: 6f 6e 64 20 61 72 67 75 6d 65 6e 74 20 69 73 20  ond argument is 
0620: 73 74 64 65 72 72 2e 20 20 4f 74 68 65 72 20 61  stderr.  Other a
0630: 70 70 6c 69 63 61 74 69 6f 6e 73 20 6d 69 67 68  pplications migh
0640: 74 20 63 68 6f 6f 73 65 20 74 6f 20 6f 75 74 70  t choose to outp
0650: 75 74 0a 2a 2a 20 74 72 61 63 65 20 69 6e 66 6f  ut.** trace info
0660: 72 6d 61 74 69 6f 6e 20 74 6f 20 61 20 66 69 6c  rmation to a fil
0670: 65 2c 20 6f 76 65 72 20 61 20 73 6f 63 6b 65 74  e, over a socket
0680: 2c 20 6f 72 20 77 72 69 74 65 20 69 74 20 69 6e  , or write it in
0690: 74 6f 20 61 20 62 75 66 66 65 72 2e 0a 2a 2a 0a  to a buffer..**.
06a0: 2a 2a 20 54 68 65 20 76 66 73 74 72 61 63 65 5f  ** The vfstrace_
06b0: 72 65 67 69 73 74 65 72 28 29 20 66 75 6e 63 74  register() funct
06c0: 69 6f 6e 20 63 72 65 61 74 65 73 20 61 20 6e 65  ion creates a ne
06d0: 77 20 22 73 68 69 6d 22 20 56 46 53 20 6e 61 6d  w "shim" VFS nam
06e0: 65 64 20 62 79 0a 2a 2a 20 74 68 65 20 7a 54 72  ed by.** the zTr
06f0: 61 63 65 4e 61 6d 65 20 70 61 72 61 6d 65 74 65  aceName paramete
0700: 72 2e 20 20 41 20 22 73 68 69 6d 22 20 56 46 53  r.  A "shim" VFS
0710: 20 69 73 20 61 6e 20 53 51 4c 69 74 65 20 62 61   is an SQLite ba
0720: 63 6b 65 6e 64 20 74 68 61 74 20 64 6f 65 73 0a  ckend that does.
0730: 2a 2a 20 6e 6f 74 20 72 65 61 6c 6c 79 20 70 65  ** not really pe
0740: 72 66 6f 72 6d 20 74 68 65 20 64 75 74 69 65 73  rform the duties
0750: 20 6f 66 20 61 20 74 72 75 65 20 62 61 63 6b 65   of a true backe
0760: 6e 64 2c 20 62 75 74 20 73 69 6d 70 6c 79 20 66  nd, but simply f
0770: 69 6c 74 65 72 73 20 6f 72 0a 2a 2a 20 69 6e 74  ilters or.** int
0780: 65 72 70 72 65 74 73 20 56 46 53 20 63 61 6c 6c  erprets VFS call
0790: 73 20 62 65 66 6f 72 65 20 70 61 73 73 69 6e 67  s before passing
07a0: 20 74 68 65 6d 20 6f 66 66 20 74 6f 20 61 6e 6f   them off to ano
07b0: 74 68 65 72 20 56 46 53 20 77 68 69 63 68 20 64  ther VFS which d
07c0: 6f 65 73 0a 2a 2a 20 74 68 65 20 61 63 74 75 61  oes.** the actua
07d0: 6c 20 77 6f 72 6b 2e 20 20 49 6e 20 74 68 69 73  l work.  In this
07e0: 20 63 61 73 65 20 74 68 65 20 6f 74 68 65 72 20   case the other 
07f0: 56 46 53 20 2d 20 74 68 65 20 6f 6e 65 20 74 68  VFS - the one th
0800: 61 74 20 64 6f 65 73 20 74 68 65 0a 2a 2a 20 72  at does the.** r
0810: 65 61 6c 20 77 6f 72 6b 20 2d 20 69 73 20 69 64  eal work - is id
0820: 65 6e 74 69 66 69 65 64 20 62 79 20 74 68 65 20  entified by the 
0830: 73 65 63 6f 6e 64 20 70 61 72 61 6d 65 74 65 72  second parameter
0840: 2c 20 7a 4f 6c 64 56 66 73 4e 61 6d 65 2e 20 20  , zOldVfsName.  
0850: 49 66 0a 2a 2a 20 74 68 65 20 32 6e 64 20 70 61  If.** the 2nd pa
0860: 72 61 6d 65 74 65 72 20 69 73 20 4e 55 4c 4c 20  rameter is NULL 
0870: 74 68 65 6e 20 74 68 65 20 64 65 66 61 75 6c 74  then the default
0880: 20 56 46 53 20 69 73 20 75 73 65 64 2e 20 20 54   VFS is used.  T
0890: 68 65 20 63 6f 6d 6d 6f 6e 0a 2a 2a 20 63 61 73  he common.** cas
08a0: 65 20 69 73 20 66 6f 72 20 74 68 65 20 32 6e 64  e is for the 2nd
08b0: 20 70 61 72 61 6d 65 74 65 72 20 74 6f 20 62 65   parameter to be
08c0: 20 4e 55 4c 4c 2e 0a 2a 2a 0a 2a 2a 20 54 68 65   NULL..**.** The
08d0: 20 74 68 69 72 64 20 61 6e 64 20 66 6f 75 72 74   third and fourt
08e0: 68 20 70 61 72 61 6d 65 74 65 72 73 20 61 72 65  h parameters are
08f0: 20 74 68 65 20 70 6f 69 6e 74 65 72 20 74 6f 20   the pointer to 
0900: 74 68 65 20 6f 75 74 70 75 74 20 66 75 6e 63 74  the output funct
0910: 69 6f 6e 0a 2a 2a 20 61 6e 64 20 74 68 65 20 73  ion.** and the s
0920: 65 63 6f 6e 64 20 61 72 67 75 6d 65 6e 74 20 74  econd argument t
0930: 6f 20 74 68 65 20 6f 75 74 70 75 74 20 66 75 6e  o the output fun
0940: 63 74 69 6f 6e 2e 20 20 46 6f 72 20 74 68 65 20  ction.  For the 
0950: 53 51 4c 69 74 65 0a 2a 2a 20 63 6f 6d 6d 61 6e  SQLite.** comman
0960: 64 2d 6c 69 6e 65 20 73 68 65 6c 6c 2c 20 77 68  d-line shell, wh
0970: 65 6e 20 74 68 65 20 2d 76 66 73 74 72 61 63 65  en the -vfstrace
0980: 20 6f 70 74 69 6f 6e 20 69 73 20 75 73 65 64 2c   option is used,
0990: 20 74 68 65 73 65 20 70 61 72 61 6d 65 74 65 72   these parameter
09a0: 73 0a 2a 2a 20 61 72 65 20 66 70 75 74 73 20 61  s.** are fputs a
09b0: 6e 64 20 73 74 64 65 72 72 2c 20 72 65 73 70 65  nd stderr, respe
09c0: 63 74 69 76 65 6c 79 2e 0a 2a 2a 0a 2a 2a 20 54  ctively..**.** T
09d0: 68 65 20 66 69 66 74 68 20 61 72 67 75 6d 65 6e  he fifth argumen
09e0: 74 20 69 73 20 74 72 75 65 20 28 6e 6f 6e 2d 7a  t is true (non-z
09f0: 65 72 6f 29 20 74 6f 20 63 61 75 73 65 20 74 68  ero) to cause th
0a00: 65 20 6e 65 77 6c 79 20 63 72 65 61 74 65 64 20  e newly created 
0a10: 56 46 53 0a 2a 2a 20 74 6f 20 62 65 63 6f 6d 65  VFS.** to become
0a20: 20 74 68 65 20 64 65 66 61 75 6c 74 20 56 46 53   the default VFS
0a30: 2e 20 20 54 68 65 20 63 6f 6d 6d 6f 6e 20 63 61  .  The common ca
0a40: 73 65 20 69 73 20 66 6f 72 20 74 68 65 20 66 69  se is for the fi
0a50: 66 74 68 20 70 61 72 61 6d 65 74 65 72 0a 2a 2a  fth parameter.**
0a60: 20 74 6f 20 62 65 20 74 72 75 65 2e 0a 2a 2a 0a   to be true..**.
0a70: 2a 2a 20 54 68 65 20 63 61 6c 6c 20 74 6f 20 76  ** The call to v
0a80: 66 73 74 72 61 63 65 5f 72 65 67 69 73 74 65 72  fstrace_register
0a90: 28 29 20 73 69 6d 70 6c 79 20 63 72 65 61 74 65  () simply create
0aa0: 73 20 74 68 65 20 73 68 69 6d 20 56 46 53 20 74  s the shim VFS t
0ab0: 68 61 74 20 64 6f 65 73 0a 2a 2a 20 74 72 61 63  hat does.** trac
0ac0: 69 6e 67 2e 20 20 54 68 65 20 61 70 70 6c 69 63  ing.  The applic
0ad0: 61 74 69 6f 6e 20 6d 75 73 74 20 61 6c 73 6f 20  ation must also 
0ae0: 61 72 72 61 6e 67 65 20 74 6f 20 75 73 65 20 74  arrange to use t
0af0: 68 65 20 6e 65 77 20 56 46 53 20 66 6f 72 0a 2a  he new VFS for.*
0b00: 2a 20 61 6c 6c 20 64 61 74 61 62 61 73 65 20 63  * all database c
0b10: 6f 6e 6e 65 63 74 69 6f 6e 73 20 74 68 61 74 20  onnections that 
0b20: 61 72 65 20 63 72 65 61 74 65 64 20 61 6e 64 20  are created and 
0b30: 66 6f 72 20 77 68 69 63 68 20 74 72 61 63 69 6e  for which tracin
0b40: 67 20 69 73 20 0a 2a 2a 20 64 65 73 69 72 65 64  g is .** desired
0b50: 2e 20 20 54 68 69 73 20 63 61 6e 20 62 65 20 64  .  This can be d
0b60: 6f 6e 65 20 62 79 20 73 70 65 63 69 66 79 69 6e  one by specifyin
0b70: 67 20 74 68 65 20 74 72 61 63 65 20 56 46 53 20  g the trace VFS 
0b80: 75 73 69 6e 67 20 55 52 49 20 66 69 6c 65 6e 61  using URI filena
0b90: 6d 65 0a 2a 2a 20 6e 6f 74 61 74 69 6f 6e 2c 20  me.** notation, 
0ba0: 6f 72 20 62 79 20 73 70 65 63 69 66 79 69 6e 67  or by specifying
0bb0: 20 74 68 65 20 74 72 61 63 65 20 56 46 53 20 61   the trace VFS a
0bc0: 73 20 74 68 65 20 34 74 68 20 70 61 72 61 6d 65  s the 4th parame
0bd0: 74 65 72 20 74 6f 0a 2a 2a 20 73 71 6c 69 74 65  ter to.** sqlite
0be0: 33 5f 6f 70 65 6e 5f 76 32 28 29 20 6f 72 20 62  3_open_v2() or b
0bf0: 79 20 6d 61 6b 69 6e 67 20 74 68 65 20 74 72 61  y making the tra
0c00: 63 65 20 56 46 53 20 62 65 20 74 68 65 20 64 65  ce VFS be the de
0c10: 66 61 75 6c 74 20 28 62 79 20 73 65 74 74 69 6e  fault (by settin
0c20: 67 0a 2a 2a 20 74 68 65 20 35 74 68 20 70 61 72  g.** the 5th par
0c30: 61 6d 65 74 65 72 20 6f 66 20 76 66 73 74 72 61  ameter of vfstra
0c40: 63 65 5f 72 65 67 69 73 74 65 72 28 29 20 74 6f  ce_register() to
0c50: 20 31 29 2e 0a 2a 2a 0a 2a 2a 0a 2a 2a 20 45 4e   1)..**.**.** EN
0c60: 41 42 4c 49 4e 47 20 56 46 53 54 52 41 43 45 20  ABLING VFSTRACE 
0c70: 49 4e 20 41 20 43 4f 4d 4d 41 4e 44 2d 4c 49 4e  IN A COMMAND-LIN
0c80: 45 20 53 48 45 4c 4c 0a 2a 2a 0a 2a 2a 20 54 68  E SHELL.**.** Th
0c90: 65 20 53 51 4c 69 74 65 20 63 6f 6d 6d 61 6e 64  e SQLite command
0ca0: 20 6c 69 6e 65 20 73 68 65 6c 6c 20 69 6d 70 6c   line shell impl
0cb0: 65 6d 65 6e 74 65 64 20 62 79 20 74 68 65 20 73  emented by the s
0cc0: 68 65 6c 6c 2e 63 20 73 6f 75 72 63 65 20 66 69  hell.c source fi
0cd0: 6c 65 0a 2a 2a 20 63 61 6e 20 62 65 20 75 73 65  le.** can be use
0ce0: 64 20 77 69 74 68 20 74 68 69 73 20 6d 6f 64 75  d with this modu
0cf0: 6c 65 2e 20 20 54 6f 20 63 6f 6d 70 69 6c 65 20  le.  To compile 
0d00: 69 6e 20 2d 76 66 73 74 72 61 63 65 20 73 75 70  in -vfstrace sup
0d10: 70 6f 72 74 2c 20 66 69 72 73 74 0a 2a 2a 20 67  port, first.** g
0d20: 61 74 68 65 72 20 74 68 69 73 20 66 69 6c 65 20  ather this file 
0d30: 28 74 65 73 74 5f 76 66 73 74 72 61 63 65 2e 63  (test_vfstrace.c
0d40: 29 2c 20 74 68 65 20 73 68 65 6c 6c 20 73 6f 75  ), the shell sou
0d50: 72 63 65 20 66 69 6c 65 20 28 73 68 65 6c 6c 2e  rce file (shell.
0d60: 63 29 2c 0a 2a 2a 20 61 6e 64 20 74 68 65 20 53  c),.** and the S
0d70: 51 4c 69 74 65 20 61 6d 61 6c 67 61 6d 61 74 69  QLite amalgamati
0d80: 6f 6e 20 73 6f 75 72 63 65 20 66 69 6c 65 73 20  on source files 
0d90: 28 73 71 6c 69 74 65 33 2e 63 2c 20 73 71 6c 69  (sqlite3.c, sqli
0da0: 74 65 33 2e 68 29 20 69 6e 74 6f 0a 2a 2a 20 74  te3.h) into.** t
0db0: 68 65 20 77 6f 72 6b 69 6e 67 20 64 69 72 65 63  he working direc
0dc0: 74 6f 72 79 2e 20 20 54 68 65 6e 20 63 6f 6d 70  tory.  Then comp
0dd0: 69 6c 65 20 75 73 69 6e 67 20 61 20 63 6f 6d 6d  ile using a comm
0de0: 61 6e 64 20 6c 69 6b 65 20 74 68 65 20 66 6f 6c  and like the fol
0df0: 6c 6f 77 69 6e 67 3a 0a 2a 2a 0a 2a 2a 20 20 20  lowing:.**.**   
0e00: 20 67 63 63 20 2d 6f 20 73 71 6c 69 74 65 33 20   gcc -o sqlite3 
0e10: 2d 4f 73 20 2d 49 2e 20 2d 44 53 51 4c 49 54 45  -Os -I. -DSQLITE
0e20: 5f 45 4e 41 42 4c 45 5f 56 46 53 54 52 41 43 45  _ENABLE_VFSTRACE
0e30: 20 5c 0a 2a 2a 20 20 20 20 20 20 20 20 2d 44 53   \.**        -DS
0e40: 51 4c 49 54 45 5f 54 48 52 45 41 44 53 41 46 45  QLITE_THREADSAFE
0e50: 3d 30 20 2d 44 53 51 4c 49 54 45 5f 45 4e 41 42  =0 -DSQLITE_ENAB
0e60: 4c 45 5f 46 54 53 33 20 2d 44 53 51 4c 49 54 45  LE_FTS3 -DSQLITE
0e70: 5f 45 4e 41 42 4c 45 5f 52 54 52 45 45 20 5c 0a  _ENABLE_RTREE \.
0e80: 2a 2a 20 20 20 20 20 20 20 20 2d 44 48 41 56 45  **        -DHAVE
0e90: 5f 52 45 41 44 4c 49 4e 45 20 2d 44 48 41 56 45  _READLINE -DHAVE
0ea0: 5f 55 53 4c 45 45 50 3d 31 20 5c 0a 2a 2a 20 20  _USLEEP=1 \.**  
0eb0: 20 20 20 20 20 20 73 68 65 6c 6c 2e 63 20 74 65        shell.c te
0ec0: 73 74 5f 76 66 73 74 72 61 63 65 2e 63 20 73 71  st_vfstrace.c sq
0ed0: 6c 69 74 65 33 2e 63 20 2d 6c 64 6c 20 2d 6c 72  lite3.c -ldl -lr
0ee0: 65 61 64 6c 69 6e 65 20 2d 6c 6e 63 75 72 73 65  eadline -lncurse
0ef0: 73 0a 2a 2a 0a 2a 2a 20 54 68 65 20 67 63 63 20  s.**.** The gcc 
0f00: 63 6f 6d 6d 61 6e 64 20 61 62 6f 76 65 20 77 6f  command above wo
0f10: 72 6b 73 20 6f 6e 20 4c 69 6e 75 78 20 61 6e 64  rks on Linux and
0f20: 20 70 72 6f 76 69 64 65 73 20 28 69 6e 20 61 64   provides (in ad
0f30: 64 69 74 69 6f 6e 20 74 6f 20 74 68 65 0a 2a 2a  dition to the.**
0f40: 20 2d 76 66 73 74 72 61 63 65 20 6f 70 74 69 6f   -vfstrace optio
0f50: 6e 29 20 73 75 70 70 6f 72 74 20 66 6f 72 20 46  n) support for F
0f60: 54 53 33 20 61 6e 64 20 46 54 53 34 2c 20 52 54  TS3 and FTS4, RT
0f70: 52 45 45 2c 20 61 6e 64 20 63 6f 6d 6d 61 6e 64  REE, and command
0f80: 2d 6c 69 6e 65 0a 2a 2a 20 65 64 69 74 69 6e 67  -line.** editing
0f90: 20 75 73 69 6e 67 20 74 68 65 20 72 65 61 64 6c   using the readl
0fa0: 69 6e 65 20 6c 69 62 72 61 72 79 2e 20 20 54 68  ine library.  Th
0fb0: 65 20 63 6f 6d 6d 61 6e 64 2d 6c 69 6e 65 20 73  e command-line s
0fc0: 68 65 6c 6c 20 64 6f 65 73 20 6e 6f 74 0a 2a 2a  hell does not.**
0fd0: 20 75 73 65 20 74 68 72 65 61 64 73 20 73 6f 20   use threads so 
0fe0: 77 65 20 61 64 64 65 64 20 2d 44 53 51 4c 49 54  we added -DSQLIT
0ff0: 45 5f 54 48 52 45 41 44 53 41 46 45 3d 30 20 6a  E_THREADSAFE=0 j
1000: 75 73 74 20 74 6f 20 6d 61 6b 65 20 74 68 65 20  ust to make the 
1010: 63 6f 64 65 0a 2a 2a 20 72 75 6e 20 61 20 6c 69  code.** run a li
1020: 74 74 6c 65 20 66 61 73 74 65 72 2e 20 20 20 46  ttle faster.   F
1030: 6f 72 20 63 6f 6d 70 69 6c 69 6e 67 20 6f 6e 20  or compiling on 
1040: 61 20 4d 61 63 2c 20 79 6f 75 27 6c 6c 20 70 72  a Mac, you'll pr
1050: 6f 62 61 62 6c 79 20 6e 65 65 64 0a 2a 2a 20 74  obably need.** t
1060: 6f 20 6f 6d 69 74 20 74 68 65 20 2d 44 48 41 56  o omit the -DHAV
1070: 45 5f 52 45 41 44 4c 49 4e 45 2c 20 74 68 65 20  E_READLINE, the 
1080: 2d 6c 72 65 61 64 6c 69 6e 65 2c 20 61 6e 64 20  -lreadline, and 
1090: 74 68 65 20 2d 6c 6e 63 75 72 73 65 73 20 6f 70  the -lncurses op
10a0: 74 69 6f 6e 73 2e 0a 2a 2a 20 54 68 65 20 63 6f  tions..** The co
10b0: 6d 70 69 6c 61 74 69 6f 6e 20 63 6f 75 6c 64 20  mpilation could 
10c0: 62 65 20 73 69 6d 70 6c 69 66 69 65 64 20 74 6f  be simplified to
10d0: 20 6a 75 73 74 20 74 68 69 73 3a 0a 2a 2a 0a 2a   just this:.**.*
10e0: 2a 20 20 20 20 67 63 63 20 2d 44 53 51 4c 49 54  *    gcc -DSQLIT
10f0: 45 5f 45 4e 41 42 4c 45 5f 56 46 53 54 52 41 43  E_ENABLE_VFSTRAC
1100: 45 20 5c 0a 2a 2a 20 20 20 20 20 20 20 20 20 73  E \.**         s
1110: 68 65 6c 6c 2e 63 20 74 65 73 74 5f 76 66 73 74  hell.c test_vfst
1120: 72 61 63 65 2e 63 20 73 71 6c 69 74 65 33 2e 63  race.c sqlite3.c
1130: 20 2d 6c 64 6c 20 2d 6c 70 74 68 72 65 61 64 0a   -ldl -lpthread.
1140: 2a 2a 0a 2a 2a 20 49 6e 20 74 68 69 73 20 73 65  **.** In this se
1150: 63 6f 6e 64 20 65 78 61 6d 70 6c 65 2c 20 61 6c  cond example, al
1160: 6c 20 75 6e 6e 65 63 65 73 73 61 72 79 20 6f 70  l unnecessary op
1170: 74 69 6f 6e 73 20 68 61 76 65 20 62 65 65 6e 20  tions have been 
1180: 72 65 6d 6f 76 65 64 0a 2a 2a 20 4e 6f 74 65 20  removed.** Note 
1190: 74 68 61 74 20 73 69 6e 63 65 20 74 68 65 20 63  that since the c
11a0: 6f 64 65 20 69 73 20 6e 6f 77 20 74 68 72 65 61  ode is now threa
11b0: 64 73 61 66 65 2c 20 77 65 20 68 61 64 20 74 6f  dsafe, we had to
11c0: 20 61 64 64 20 74 68 65 20 2d 6c 70 74 68 72 65   add the -lpthre
11d0: 61 64 0a 2a 2a 20 6f 70 74 69 6f 6e 20 74 6f 20  ad.** option to 
11e0: 70 75 6c 6c 20 69 6e 20 74 68 65 20 70 74 68 72  pull in the pthr
11f0: 65 61 64 73 20 6c 69 62 72 61 72 79 2e 0a 2a 2a  eads library..**
1200: 0a 2a 2a 20 54 6f 20 63 72 6f 73 73 2d 63 6f 6d  .** To cross-com
1210: 70 69 6c 65 20 66 6f 72 20 77 69 6e 64 6f 77 73  pile for windows
1220: 20 75 73 69 6e 67 20 4d 69 6e 47 57 2c 20 61 20   using MinGW, a 
1230: 63 6f 6d 6d 61 6e 64 20 6c 69 6b 65 20 74 68 69  command like thi
1240: 73 20 6d 69 67 68 74 0a 2a 2a 20 77 6f 72 6b 3a  s might.** work:
1250: 0a 2a 2a 0a 2a 2a 20 20 20 20 2f 6f 70 74 2f 6d  .**.**    /opt/m
1260: 69 6e 67 77 2f 62 69 6e 2f 69 33 38 36 2d 6d 69  ingw/bin/i386-mi
1270: 6e 67 77 33 32 6d 73 76 63 2d 67 63 63 20 2d 6f  ngw32msvc-gcc -o
1280: 20 73 71 6c 69 74 65 33 2e 65 78 65 20 2d 4f 73   sqlite3.exe -Os
1290: 20 2d 49 20 5c 0a 2a 2a 20 20 20 20 20 20 20 20   -I \.**        
12a0: 20 2d 44 53 51 4c 49 54 45 5f 54 48 52 45 41 44   -DSQLITE_THREAD
12b0: 53 41 46 45 3d 30 20 2d 44 53 51 4c 49 54 45 5f  SAFE=0 -DSQLITE_
12c0: 45 4e 41 42 4c 45 5f 56 46 53 54 52 41 43 45 20  ENABLE_VFSTRACE 
12d0: 5c 0a 2a 2a 20 20 20 20 20 20 20 20 20 73 68 65  \.**         she
12e0: 6c 6c 2e 63 20 74 65 73 74 5f 76 66 73 74 72 61  ll.c test_vfstra
12f0: 63 65 2e 63 20 73 71 6c 69 74 65 33 2e 63 0a 2a  ce.c sqlite3.c.*
1300: 2a 0a 2a 2a 20 53 69 6d 69 6c 61 72 20 63 6f 6d  *.** Similar com
1310: 70 69 6c 65 72 20 63 6f 6d 6d 61 6e 64 73 20 77  piler commands w
1320: 69 6c 6c 20 77 6f 72 6b 20 6f 6e 20 64 69 66 66  ill work on diff
1330: 65 72 65 6e 74 20 73 79 73 74 65 6d 73 2e 20 20  erent systems.  
1340: 54 68 65 20 6b 65 79 0a 2a 2a 20 69 6e 76 61 72  The key.** invar
1350: 69 61 6e 74 73 20 61 72 65 20 28 31 29 20 79 6f  iants are (1) yo
1360: 75 20 6d 75 73 74 20 68 61 76 65 20 2d 44 53 51  u must have -DSQ
1370: 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 56 46 53 54  LITE_ENABLE_VFST
1380: 52 41 43 45 20 73 6f 20 74 68 61 74 0a 2a 2a 20  RACE so that.** 
1390: 74 68 65 20 73 68 65 6c 6c 2e 63 20 73 6f 75 72  the shell.c sour
13a0: 63 65 20 66 69 6c 65 20 77 69 6c 6c 20 6b 6e 6f  ce file will kno
13b0: 77 20 74 6f 20 69 6e 63 6c 75 64 65 20 74 68 65  w to include the
13c0: 20 2d 76 66 73 74 72 61 63 65 20 63 6f 6d 6d 61   -vfstrace comma
13d0: 6e 64 2d 6c 69 6e 65 0a 2a 2a 20 6f 70 74 69 6f  nd-line.** optio
13e0: 6e 20 61 6e 64 20 28 32 29 20 79 6f 75 20 6d 75  n and (2) you mu
13f0: 73 74 20 63 6f 6d 70 69 6c 65 20 61 6e 64 20 6c  st compile and l
1400: 69 6e 6b 20 74 68 65 20 74 68 72 65 65 20 73 6f  ink the three so
1410: 75 72 63 65 20 66 69 6c 65 73 0a 2a 2a 20 73 68  urce files.** sh
1420: 65 6c 6c 2c 63 2c 20 74 65 73 74 5f 76 66 73 74  ell,c, test_vfst
1430: 72 61 63 65 2e 63 2c 20 61 6e 64 20 73 71 6c 69  race.c, and sqli
1440: 74 65 33 2e 63 2e 20 20 0a 2a 2f 0a 23 69 6e 63  te3.c.  .*/.#inc
1450: 6c 75 64 65 20 3c 73 74 64 6c 69 62 2e 68 3e 0a  lude <stdlib.h>.
1460: 23 69 6e 63 6c 75 64 65 20 3c 73 74 72 69 6e 67  #include <string
1470: 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 22 73 71  .h>.#include "sq
1480: 6c 69 74 65 33 2e 68 22 0a 0a 2f 2a 0a 2a 2a 20  lite3.h"../*.** 
1490: 41 6e 20 69 6e 73 74 61 6e 63 65 20 6f 66 20 74  An instance of t
14a0: 68 69 73 20 73 74 72 75 63 74 75 72 65 20 69 73  his structure is
14b0: 20 61 74 74 61 63 68 65 64 20 74 6f 20 74 68 65   attached to the
14c0: 20 65 61 63 68 20 74 72 61 63 65 20 56 46 53 20   each trace VFS 
14d0: 74 6f 0a 2a 2a 20 70 72 6f 76 69 64 65 20 61 75  to.** provide au
14e0: 78 69 6c 69 61 72 79 20 69 6e 66 6f 72 6d 61 74  xiliary informat
14f0: 69 6f 6e 2e 0a 2a 2f 0a 74 79 70 65 64 65 66 20  ion..*/.typedef 
1500: 73 74 72 75 63 74 20 76 66 73 74 72 61 63 65 5f  struct vfstrace_
1510: 69 6e 66 6f 20 76 66 73 74 72 61 63 65 5f 69 6e  info vfstrace_in
1520: 66 6f 3b 0a 73 74 72 75 63 74 20 76 66 73 74 72  fo;.struct vfstr
1530: 61 63 65 5f 69 6e 66 6f 20 7b 0a 20 20 73 71 6c  ace_info {.  sql
1540: 69 74 65 33 5f 76 66 73 20 2a 70 52 6f 6f 74 56  ite3_vfs *pRootV
1550: 66 73 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  fs;             
1560: 20 2f 2a 20 54 68 65 20 75 6e 64 65 72 6c 79 69   /* The underlyi
1570: 6e 67 20 72 65 61 6c 20 56 46 53 20 2a 2f 0a 20  ng real VFS */. 
1580: 20 69 6e 74 20 28 2a 78 4f 75 74 29 28 63 6f 6e   int (*xOut)(con
1590: 73 74 20 63 68 61 72 2a 2c 20 76 6f 69 64 2a 29  st char*, void*)
15a0: 3b 20 20 20 20 2f 2a 20 53 65 6e 64 20 6f 75 74  ;    /* Send out
15b0: 70 75 74 20 68 65 72 65 20 2a 2f 0a 20 20 76 6f  put here */.  vo
15c0: 69 64 20 2a 70 4f 75 74 41 72 67 3b 20 20 20 20  id *pOutArg;    
15d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
15e0: 20 20 2f 2a 20 46 69 72 73 74 20 61 72 67 75 6d    /* First argum
15f0: 65 6e 74 20 74 6f 20 78 4f 75 74 20 2a 2f 0a 20  ent to xOut */. 
1600: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 56 66   const char *zVf
1610: 73 4e 61 6d 65 3b 20 20 20 20 20 20 20 20 20 20  sName;          
1620: 20 20 20 20 20 2f 2a 20 4e 61 6d 65 20 6f 66 20       /* Name of 
1630: 74 68 69 73 20 74 72 61 63 65 2d 56 46 53 20 2a  this trace-VFS *
1640: 2f 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20  /.  sqlite3_vfs 
1650: 2a 70 54 72 61 63 65 56 66 73 3b 20 20 20 20 20  *pTraceVfs;     
1660: 20 20 20 20 20 20 20 20 2f 2a 20 50 6f 69 6e 74          /* Point
1670: 65 72 20 62 61 63 6b 20 74 6f 20 74 68 65 20 74  er back to the t
1680: 72 61 63 65 20 56 46 53 20 2a 2f 0a 7d 3b 0a 0a  race VFS */.};..
1690: 2f 2a 0a 2a 2a 20 54 68 65 20 73 71 6c 69 74 65  /*.** The sqlite
16a0: 33 5f 66 69 6c 65 20 6f 62 6a 65 63 74 20 66 6f  3_file object fo
16b0: 72 20 74 68 65 20 74 72 61 63 65 20 56 46 53 0a  r the trace VFS.
16c0: 2a 2f 0a 74 79 70 65 64 65 66 20 73 74 72 75 63  */.typedef struc
16d0: 74 20 76 66 73 74 72 61 63 65 5f 66 69 6c 65 20  t vfstrace_file 
16e0: 76 66 73 74 72 61 63 65 5f 66 69 6c 65 3b 0a 73  vfstrace_file;.s
16f0: 74 72 75 63 74 20 76 66 73 74 72 61 63 65 5f 66  truct vfstrace_f
1700: 69 6c 65 20 7b 0a 20 20 73 71 6c 69 74 65 33 5f  ile {.  sqlite3_
1710: 66 69 6c 65 20 62 61 73 65 3b 20 20 20 20 20 20  file base;      
1720: 20 20 2f 2a 20 42 61 73 65 20 63 6c 61 73 73 2e    /* Base class.
1730: 20 20 4d 75 73 74 20 62 65 20 66 69 72 73 74 20    Must be first 
1740: 2a 2f 0a 20 20 76 66 73 74 72 61 63 65 5f 69 6e  */.  vfstrace_in
1750: 66 6f 20 2a 70 49 6e 66 6f 3b 20 20 20 20 20 2f  fo *pInfo;     /
1760: 2a 20 54 68 65 20 74 72 61 63 65 2d 56 46 53 20  * The trace-VFS 
1770: 74 6f 20 77 68 69 63 68 20 74 68 69 73 20 66 69  to which this fi
1780: 6c 65 20 62 65 6c 6f 6e 67 73 20 2a 2f 0a 20 20  le belongs */.  
1790: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 46 4e 61  const char *zFNa
17a0: 6d 65 3b 20 20 20 20 20 20 20 2f 2a 20 42 61 73  me;       /* Bas
17b0: 65 20 6e 61 6d 65 20 6f 66 20 74 68 65 20 66 69  e name of the fi
17c0: 6c 65 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f  le */.  sqlite3_
17d0: 66 69 6c 65 20 2a 70 52 65 61 6c 3b 20 20 20 20  file *pReal;    
17e0: 20 20 2f 2a 20 54 68 65 20 72 65 61 6c 20 75 6e    /* The real un
17f0: 64 65 72 6c 79 69 6e 67 20 66 69 6c 65 20 2a 2f  derlying file */
1800: 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20 4d 65 74 68 6f  .};../*.** Metho
1810: 64 20 64 65 63 6c 61 72 61 74 69 6f 6e 73 20 66  d declarations f
1820: 6f 72 20 76 66 73 74 72 61 63 65 5f 66 69 6c 65  or vfstrace_file
1830: 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20  ..*/.static int 
1840: 76 66 73 74 72 61 63 65 43 6c 6f 73 65 28 73 71  vfstraceClose(sq
1850: 6c 69 74 65 33 5f 66 69 6c 65 2a 29 3b 0a 73 74  lite3_file*);.st
1860: 61 74 69 63 20 69 6e 74 20 76 66 73 74 72 61 63  atic int vfstrac
1870: 65 52 65 61 64 28 73 71 6c 69 74 65 33 5f 66 69  eRead(sqlite3_fi
1880: 6c 65 2a 2c 20 76 6f 69 64 2a 2c 20 69 6e 74 20  le*, void*, int 
1890: 69 41 6d 74 2c 20 73 71 6c 69 74 65 33 5f 69 6e  iAmt, sqlite3_in
18a0: 74 36 34 20 69 4f 66 73 74 29 3b 0a 73 74 61 74  t64 iOfst);.stat
18b0: 69 63 20 69 6e 74 20 76 66 73 74 72 61 63 65 57  ic int vfstraceW
18c0: 72 69 74 65 28 73 71 6c 69 74 65 33 5f 66 69 6c  rite(sqlite3_fil
18d0: 65 2a 2c 63 6f 6e 73 74 20 76 6f 69 64 2a 2c 69  e*,const void*,i
18e0: 6e 74 20 69 41 6d 74 2c 20 73 71 6c 69 74 65 33  nt iAmt, sqlite3
18f0: 5f 69 6e 74 36 34 29 3b 0a 73 74 61 74 69 63 20  _int64);.static 
1900: 69 6e 74 20 76 66 73 74 72 61 63 65 54 72 75 6e  int vfstraceTrun
1910: 63 61 74 65 28 73 71 6c 69 74 65 33 5f 66 69 6c  cate(sqlite3_fil
1920: 65 2a 2c 20 73 71 6c 69 74 65 33 5f 69 6e 74 36  e*, sqlite3_int6
1930: 34 20 73 69 7a 65 29 3b 0a 73 74 61 74 69 63 20  4 size);.static 
1940: 69 6e 74 20 76 66 73 74 72 61 63 65 53 79 6e 63  int vfstraceSync
1950: 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 2a 2c 20  (sqlite3_file*, 
1960: 69 6e 74 20 66 6c 61 67 73 29 3b 0a 73 74 61 74  int flags);.stat
1970: 69 63 20 69 6e 74 20 76 66 73 74 72 61 63 65 46  ic int vfstraceF
1980: 69 6c 65 53 69 7a 65 28 73 71 6c 69 74 65 33 5f  ileSize(sqlite3_
1990: 66 69 6c 65 2a 2c 20 73 71 6c 69 74 65 33 5f 69  file*, sqlite3_i
19a0: 6e 74 36 34 20 2a 70 53 69 7a 65 29 3b 0a 73 74  nt64 *pSize);.st
19b0: 61 74 69 63 20 69 6e 74 20 76 66 73 74 72 61 63  atic int vfstrac
19c0: 65 4c 6f 63 6b 28 73 71 6c 69 74 65 33 5f 66 69  eLock(sqlite3_fi
19d0: 6c 65 2a 2c 20 69 6e 74 29 3b 0a 73 74 61 74 69  le*, int);.stati
19e0: 63 20 69 6e 74 20 76 66 73 74 72 61 63 65 55 6e  c int vfstraceUn
19f0: 6c 6f 63 6b 28 73 71 6c 69 74 65 33 5f 66 69 6c  lock(sqlite3_fil
1a00: 65 2a 2c 20 69 6e 74 29 3b 0a 73 74 61 74 69 63  e*, int);.static
1a10: 20 69 6e 74 20 76 66 73 74 72 61 63 65 43 68 65   int vfstraceChe
1a20: 63 6b 52 65 73 65 72 76 65 64 4c 6f 63 6b 28 73  ckReservedLock(s
1a30: 71 6c 69 74 65 33 5f 66 69 6c 65 2a 2c 20 69 6e  qlite3_file*, in
1a40: 74 20 2a 29 3b 0a 73 74 61 74 69 63 20 69 6e 74  t *);.static int
1a50: 20 76 66 73 74 72 61 63 65 46 69 6c 65 43 6f 6e   vfstraceFileCon
1a60: 74 72 6f 6c 28 73 71 6c 69 74 65 33 5f 66 69 6c  trol(sqlite3_fil
1a70: 65 2a 2c 20 69 6e 74 20 6f 70 2c 20 76 6f 69 64  e*, int op, void
1a80: 20 2a 70 41 72 67 29 3b 0a 73 74 61 74 69 63 20   *pArg);.static 
1a90: 69 6e 74 20 76 66 73 74 72 61 63 65 53 65 63 74  int vfstraceSect
1aa0: 6f 72 53 69 7a 65 28 73 71 6c 69 74 65 33 5f 66  orSize(sqlite3_f
1ab0: 69 6c 65 2a 29 3b 0a 73 74 61 74 69 63 20 69 6e  ile*);.static in
1ac0: 74 20 76 66 73 74 72 61 63 65 44 65 76 69 63 65  t vfstraceDevice
1ad0: 43 68 61 72 61 63 74 65 72 69 73 74 69 63 73 28  Characteristics(
1ae0: 73 71 6c 69 74 65 33 5f 66 69 6c 65 2a 29 3b 0a  sqlite3_file*);.
1af0: 73 74 61 74 69 63 20 69 6e 74 20 76 66 73 74 72  static int vfstr
1b00: 61 63 65 53 68 6d 4c 6f 63 6b 28 73 71 6c 69 74  aceShmLock(sqlit
1b10: 65 33 5f 66 69 6c 65 2a 2c 69 6e 74 2c 69 6e 74  e3_file*,int,int
1b20: 2c 69 6e 74 29 3b 0a 73 74 61 74 69 63 20 69 6e  ,int);.static in
1b30: 74 20 76 66 73 74 72 61 63 65 53 68 6d 4d 61 70  t vfstraceShmMap
1b40: 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 2a 2c 69  (sqlite3_file*,i
1b50: 6e 74 2c 69 6e 74 2c 69 6e 74 2c 20 76 6f 69 64  nt,int,int, void
1b60: 20 76 6f 6c 61 74 69 6c 65 20 2a 2a 29 3b 0a 73   volatile **);.s
1b70: 74 61 74 69 63 20 76 6f 69 64 20 76 66 73 74 72  tatic void vfstr
1b80: 61 63 65 53 68 6d 42 61 72 72 69 65 72 28 73 71  aceShmBarrier(sq
1b90: 6c 69 74 65 33 5f 66 69 6c 65 2a 29 3b 0a 73 74  lite3_file*);.st
1ba0: 61 74 69 63 20 69 6e 74 20 76 66 73 74 72 61 63  atic int vfstrac
1bb0: 65 53 68 6d 55 6e 6d 61 70 28 73 71 6c 69 74 65  eShmUnmap(sqlite
1bc0: 33 5f 66 69 6c 65 2a 2c 69 6e 74 29 3b 0a 0a 2f  3_file*,int);../
1bd0: 2a 0a 2a 2a 20 4d 65 74 68 6f 64 20 64 65 63 6c  *.** Method decl
1be0: 61 72 61 74 69 6f 6e 73 20 66 6f 72 20 76 66 73  arations for vfs
1bf0: 74 72 61 63 65 5f 76 66 73 2e 0a 2a 2f 0a 73 74  trace_vfs..*/.st
1c00: 61 74 69 63 20 69 6e 74 20 76 66 73 74 72 61 63  atic int vfstrac
1c10: 65 4f 70 65 6e 28 73 71 6c 69 74 65 33 5f 76 66  eOpen(sqlite3_vf
1c20: 73 2a 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  s*, const char *
1c30: 2c 20 73 71 6c 69 74 65 33 5f 66 69 6c 65 2a 2c  , sqlite3_file*,
1c40: 20 69 6e 74 20 2c 20 69 6e 74 20 2a 29 3b 0a 73   int , int *);.s
1c50: 74 61 74 69 63 20 69 6e 74 20 76 66 73 74 72 61  tatic int vfstra
1c60: 63 65 44 65 6c 65 74 65 28 73 71 6c 69 74 65 33  ceDelete(sqlite3
1c70: 5f 76 66 73 2a 2c 20 63 6f 6e 73 74 20 63 68 61  _vfs*, const cha
1c80: 72 20 2a 7a 4e 61 6d 65 2c 20 69 6e 74 20 73 79  r *zName, int sy
1c90: 6e 63 44 69 72 29 3b 0a 73 74 61 74 69 63 20 69  ncDir);.static i
1ca0: 6e 74 20 76 66 73 74 72 61 63 65 41 63 63 65 73  nt vfstraceAcces
1cb0: 73 28 73 71 6c 69 74 65 33 5f 76 66 73 2a 2c 20  s(sqlite3_vfs*, 
1cc0: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 4e 61 6d  const char *zNam
1cd0: 65 2c 20 69 6e 74 20 66 6c 61 67 73 2c 20 69 6e  e, int flags, in
1ce0: 74 20 2a 29 3b 0a 73 74 61 74 69 63 20 69 6e 74  t *);.static int
1cf0: 20 76 66 73 74 72 61 63 65 46 75 6c 6c 50 61 74   vfstraceFullPat
1d00: 68 6e 61 6d 65 28 73 71 6c 69 74 65 33 5f 76 66  hname(sqlite3_vf
1d10: 73 2a 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  s*, const char *
1d20: 7a 4e 61 6d 65 2c 20 69 6e 74 2c 20 63 68 61 72  zName, int, char
1d30: 20 2a 29 3b 0a 73 74 61 74 69 63 20 76 6f 69 64   *);.static void
1d40: 20 2a 76 66 73 74 72 61 63 65 44 6c 4f 70 65 6e   *vfstraceDlOpen
1d50: 28 73 71 6c 69 74 65 33 5f 76 66 73 2a 2c 20 63  (sqlite3_vfs*, c
1d60: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 46 69 6c 65  onst char *zFile
1d70: 6e 61 6d 65 29 3b 0a 73 74 61 74 69 63 20 76 6f  name);.static vo
1d80: 69 64 20 76 66 73 74 72 61 63 65 44 6c 45 72 72  id vfstraceDlErr
1d90: 6f 72 28 73 71 6c 69 74 65 33 5f 76 66 73 2a 2c  or(sqlite3_vfs*,
1da0: 20 69 6e 74 20 6e 42 79 74 65 2c 20 63 68 61 72   int nByte, char
1db0: 20 2a 7a 45 72 72 4d 73 67 29 3b 0a 73 74 61 74   *zErrMsg);.stat
1dc0: 69 63 20 76 6f 69 64 20 28 2a 76 66 73 74 72 61  ic void (*vfstra
1dd0: 63 65 44 6c 53 79 6d 28 73 71 6c 69 74 65 33 5f  ceDlSym(sqlite3_
1de0: 76 66 73 2a 2c 76 6f 69 64 2a 2c 20 63 6f 6e 73  vfs*,void*, cons
1df0: 74 20 63 68 61 72 20 2a 7a 53 79 6d 62 6f 6c 29  t char *zSymbol)
1e00: 29 28 76 6f 69 64 29 3b 0a 73 74 61 74 69 63 20  )(void);.static 
1e10: 76 6f 69 64 20 76 66 73 74 72 61 63 65 44 6c 43  void vfstraceDlC
1e20: 6c 6f 73 65 28 73 71 6c 69 74 65 33 5f 76 66 73  lose(sqlite3_vfs
1e30: 2a 2c 20 76 6f 69 64 2a 29 3b 0a 73 74 61 74 69  *, void*);.stati
1e40: 63 20 69 6e 74 20 76 66 73 74 72 61 63 65 52 61  c int vfstraceRa
1e50: 6e 64 6f 6d 6e 65 73 73 28 73 71 6c 69 74 65 33  ndomness(sqlite3
1e60: 5f 76 66 73 2a 2c 20 69 6e 74 20 6e 42 79 74 65  _vfs*, int nByte
1e70: 2c 20 63 68 61 72 20 2a 7a 4f 75 74 29 3b 0a 73  , char *zOut);.s
1e80: 74 61 74 69 63 20 69 6e 74 20 76 66 73 74 72 61  tatic int vfstra
1e90: 63 65 53 6c 65 65 70 28 73 71 6c 69 74 65 33 5f  ceSleep(sqlite3_
1ea0: 76 66 73 2a 2c 20 69 6e 74 20 6d 69 63 72 6f 73  vfs*, int micros
1eb0: 65 63 6f 6e 64 73 29 3b 0a 73 74 61 74 69 63 20  econds);.static 
1ec0: 69 6e 74 20 76 66 73 74 72 61 63 65 43 75 72 72  int vfstraceCurr
1ed0: 65 6e 74 54 69 6d 65 28 73 71 6c 69 74 65 33 5f  entTime(sqlite3_
1ee0: 76 66 73 2a 2c 20 64 6f 75 62 6c 65 2a 29 3b 0a  vfs*, double*);.
1ef0: 73 74 61 74 69 63 20 69 6e 74 20 76 66 73 74 72  static int vfstr
1f00: 61 63 65 47 65 74 4c 61 73 74 45 72 72 6f 72 28  aceGetLastError(
1f10: 73 71 6c 69 74 65 33 5f 76 66 73 2a 2c 20 69 6e  sqlite3_vfs*, in
1f20: 74 2c 20 63 68 61 72 2a 29 3b 0a 73 74 61 74 69  t, char*);.stati
1f30: 63 20 69 6e 74 20 76 66 73 74 72 61 63 65 43 75  c int vfstraceCu
1f40: 72 72 65 6e 74 54 69 6d 65 49 6e 74 36 34 28 73  rrentTimeInt64(s
1f50: 71 6c 69 74 65 33 5f 76 66 73 2a 2c 20 73 71 6c  qlite3_vfs*, sql
1f60: 69 74 65 33 5f 69 6e 74 36 34 2a 29 3b 0a 73 74  ite3_int64*);.st
1f70: 61 74 69 63 20 69 6e 74 20 76 66 73 74 72 61 63  atic int vfstrac
1f80: 65 53 65 74 53 79 73 74 65 6d 43 61 6c 6c 28 73  eSetSystemCall(s
1f90: 71 6c 69 74 65 33 5f 76 66 73 2a 2c 63 6f 6e 73  qlite3_vfs*,cons
1fa0: 74 20 63 68 61 72 2a 2c 20 73 71 6c 69 74 65 33  t char*, sqlite3
1fb0: 5f 73 79 73 63 61 6c 6c 5f 70 74 72 29 3b 0a 73  _syscall_ptr);.s
1fc0: 74 61 74 69 63 20 73 71 6c 69 74 65 33 5f 73 79  tatic sqlite3_sy
1fd0: 73 63 61 6c 6c 5f 70 74 72 20 76 66 73 74 72 61  scall_ptr vfstra
1fe0: 63 65 47 65 74 53 79 73 74 65 6d 43 61 6c 6c 28  ceGetSystemCall(
1ff0: 73 71 6c 69 74 65 33 5f 76 66 73 2a 2c 20 63 6f  sqlite3_vfs*, co
2000: 6e 73 74 20 63 68 61 72 20 2a 29 3b 0a 73 74 61  nst char *);.sta
2010: 74 69 63 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  tic const char *
2020: 76 66 73 74 72 61 63 65 4e 65 78 74 53 79 73 74  vfstraceNextSyst
2030: 65 6d 43 61 6c 6c 28 73 71 6c 69 74 65 33 5f 76  emCall(sqlite3_v
2040: 66 73 2a 2c 20 63 6f 6e 73 74 20 63 68 61 72 20  fs*, const char 
2050: 2a 7a 4e 61 6d 65 29 3b 0a 0a 2f 2a 0a 2a 2a 20  *zName);../*.** 
2060: 52 65 74 75 72 6e 20 61 20 70 6f 69 6e 74 65 72  Return a pointer
2070: 20 74 6f 20 74 68 65 20 74 61 69 6c 20 6f 66 20   to the tail of 
2080: 74 68 65 20 70 61 74 68 6e 61 6d 65 2e 20 20 45  the pathname.  E
2090: 78 61 6d 70 6c 65 73 3a 0a 2a 2a 0a 2a 2a 20 20  xamples:.**.**  
20a0: 20 20 20 2f 68 6f 6d 65 2f 64 72 68 2f 78 79 7a     /home/drh/xyz
20b0: 7a 79 2e 74 78 74 20 2d 3e 20 78 79 7a 7a 79 2e  zy.txt -> xyzzy.
20c0: 74 78 74 0a 2a 2a 20 20 20 20 20 78 79 7a 7a 79  txt.**     xyzzy
20d0: 2e 74 78 74 20 20 20 20 20 20 20 20 20 20 20 2d  .txt           -
20e0: 3e 20 78 79 7a 7a 79 2e 74 78 74 0a 2a 2f 0a 73  > xyzzy.txt.*/.s
20f0: 74 61 74 69 63 20 63 6f 6e 73 74 20 63 68 61 72  tatic const char
2100: 20 2a 66 69 6c 65 54 61 69 6c 28 63 6f 6e 73 74   *fileTail(const
2110: 20 63 68 61 72 20 2a 7a 29 7b 0a 20 20 69 6e 74   char *z){.  int
2120: 20 69 3b 0a 20 20 69 66 28 20 7a 3d 3d 30 20 29   i;.  if( z==0 )
2130: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 69 20 3d   return 0;.  i =
2140: 20 73 74 72 6c 65 6e 28 7a 29 2d 31 3b 0a 20 20   strlen(z)-1;.  
2150: 77 68 69 6c 65 28 20 69 3e 30 20 26 26 20 7a 5b  while( i>0 && z[
2160: 69 2d 31 5d 21 3d 27 2f 27 20 29 7b 20 69 2d 2d  i-1]!='/' ){ i--
2170: 3b 20 7d 0a 20 20 72 65 74 75 72 6e 20 26 7a 5b  ; }.  return &z[
2180: 69 5d 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 53 65 6e  i];.}../*.** Sen
2190: 64 20 74 72 61 63 65 20 6f 75 74 70 75 74 20 64  d trace output d
21a0: 65 66 69 6e 65 64 20 62 79 20 7a 46 6f 72 6d 61  efined by zForma
21b0: 74 20 61 6e 64 20 73 75 62 73 65 71 75 65 6e 74  t and subsequent
21c0: 20 61 72 67 75 6d 65 6e 74 73 2e 0a 2a 2f 0a 73   arguments..*/.s
21d0: 74 61 74 69 63 20 76 6f 69 64 20 76 66 73 74 72  tatic void vfstr
21e0: 61 63 65 5f 70 72 69 6e 74 66 28 0a 20 20 76 66  ace_printf(.  vf
21f0: 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70 49 6e  strace_info *pIn
2200: 66 6f 2c 0a 20 20 63 6f 6e 73 74 20 63 68 61 72  fo,.  const char
2210: 20 2a 7a 46 6f 72 6d 61 74 2c 0a 20 20 2e 2e 2e   *zFormat,.  ...
2220: 0a 29 7b 0a 20 20 76 61 5f 6c 69 73 74 20 61 70  .){.  va_list ap
2230: 3b 0a 20 20 63 68 61 72 20 2a 7a 4d 73 67 3b 0a  ;.  char *zMsg;.
2240: 20 20 76 61 5f 73 74 61 72 74 28 61 70 2c 20 7a    va_start(ap, z
2250: 46 6f 72 6d 61 74 29 3b 0a 20 20 7a 4d 73 67 20  Format);.  zMsg 
2260: 3d 20 73 71 6c 69 74 65 33 5f 76 6d 70 72 69 6e  = sqlite3_vmprin
2270: 74 66 28 7a 46 6f 72 6d 61 74 2c 20 61 70 29 3b  tf(zFormat, ap);
2280: 0a 20 20 76 61 5f 65 6e 64 28 61 70 29 3b 0a 20  .  va_end(ap);. 
2290: 20 70 49 6e 66 6f 2d 3e 78 4f 75 74 28 7a 4d 73   pInfo->xOut(zMs
22a0: 67 2c 20 70 49 6e 66 6f 2d 3e 70 4f 75 74 41 72  g, pInfo->pOutAr
22b0: 67 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 66 72  g);.  sqlite3_fr
22c0: 65 65 28 7a 4d 73 67 29 3b 0a 7d 0a 0a 2f 2a 0a  ee(zMsg);.}../*.
22d0: 2a 2a 20 43 6f 6e 76 65 72 74 20 76 61 6c 75 65  ** Convert value
22e0: 20 72 63 20 69 6e 74 6f 20 61 20 73 74 72 69 6e   rc into a strin
22f0: 67 20 61 6e 64 20 70 72 69 6e 74 20 69 74 20 75  g and print it u
2300: 73 69 6e 67 20 7a 46 6f 72 6d 61 74 2e 20 20 7a  sing zFormat.  z
2310: 46 6f 72 6d 61 74 0a 2a 2a 20 73 68 6f 75 6c 64  Format.** should
2320: 20 68 61 76 65 20 65 78 61 63 74 6c 79 20 6f 6e   have exactly on
2330: 65 20 25 73 0a 2a 2f 0a 73 74 61 74 69 63 20 76  e %s.*/.static v
2340: 6f 69 64 20 76 66 73 74 72 61 63 65 5f 70 72 69  oid vfstrace_pri
2350: 6e 74 5f 65 72 72 63 6f 64 65 28 0a 20 20 76 66  nt_errcode(.  vf
2360: 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70 49 6e  strace_info *pIn
2370: 66 6f 2c 0a 20 20 63 6f 6e 73 74 20 63 68 61 72  fo,.  const char
2380: 20 2a 7a 46 6f 72 6d 61 74 2c 0a 20 20 69 6e 74   *zFormat,.  int
2390: 20 72 63 0a 29 7b 0a 20 20 63 68 61 72 20 7a 42   rc.){.  char zB
23a0: 75 66 5b 35 30 5d 3b 0a 20 20 63 68 61 72 20 2a  uf[50];.  char *
23b0: 7a 56 61 6c 3b 0a 20 20 73 77 69 74 63 68 28 20  zVal;.  switch( 
23c0: 72 63 20 29 7b 0a 20 20 20 20 63 61 73 65 20 53  rc ){.    case S
23d0: 51 4c 49 54 45 5f 4f 4b 3a 20 20 20 20 20 20 20  QLITE_OK:       
23e0: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
23f0: 5f 4f 4b 22 3b 20 20 20 20 20 20 20 20 20 20 62  _OK";          b
2400: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
2410: 51 4c 49 54 45 5f 45 52 52 4f 52 3a 20 20 20 20  QLITE_ERROR:    
2420: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
2430: 5f 45 52 52 4f 52 22 3b 20 20 20 20 20 20 20 62  _ERROR";       b
2440: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
2450: 51 4c 49 54 45 5f 50 45 52 4d 3a 20 20 20 20 20  QLITE_PERM:     
2460: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
2470: 5f 50 45 52 4d 22 3b 20 20 20 20 20 20 20 20 62  _PERM";        b
2480: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
2490: 51 4c 49 54 45 5f 41 42 4f 52 54 3a 20 20 20 20  QLITE_ABORT:    
24a0: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
24b0: 5f 41 42 4f 52 54 22 3b 20 20 20 20 20 20 20 62  _ABORT";       b
24c0: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
24d0: 51 4c 49 54 45 5f 42 55 53 59 3a 20 20 20 20 20  QLITE_BUSY:     
24e0: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
24f0: 5f 42 55 53 59 22 3b 20 20 20 20 20 20 20 20 62  _BUSY";        b
2500: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
2510: 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3a 20 20 20 20  QLITE_NOMEM:    
2520: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
2530: 5f 4e 4f 4d 45 4d 22 3b 20 20 20 20 20 20 20 62  _NOMEM";       b
2540: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
2550: 51 4c 49 54 45 5f 52 45 41 44 4f 4e 4c 59 3a 20  QLITE_READONLY: 
2560: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
2570: 5f 52 45 41 44 4f 4e 4c 59 22 3b 20 20 20 20 62  _READONLY";    b
2580: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
2590: 51 4c 49 54 45 5f 49 4e 54 45 52 52 55 50 54 3a  QLITE_INTERRUPT:
25a0: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
25b0: 5f 49 4e 54 45 52 52 55 50 54 22 3b 20 20 20 62  _INTERRUPT";   b
25c0: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
25d0: 51 4c 49 54 45 5f 49 4f 45 52 52 3a 20 20 20 20  QLITE_IOERR:    
25e0: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
25f0: 5f 49 4f 45 52 52 22 3b 20 20 20 20 20 20 20 62  _IOERR";       b
2600: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
2610: 51 4c 49 54 45 5f 43 4f 52 52 55 50 54 3a 20 20  QLITE_CORRUPT:  
2620: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
2630: 5f 43 4f 52 52 55 50 54 22 3b 20 20 20 20 20 62  _CORRUPT";     b
2640: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
2650: 51 4c 49 54 45 5f 46 55 4c 4c 3a 20 20 20 20 20  QLITE_FULL:     
2660: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
2670: 5f 46 55 4c 4c 22 3b 20 20 20 20 20 20 20 20 62  _FULL";        b
2680: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
2690: 51 4c 49 54 45 5f 43 41 4e 54 4f 50 45 4e 3a 20  QLITE_CANTOPEN: 
26a0: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
26b0: 5f 43 41 4e 54 4f 50 45 4e 22 3b 20 20 20 20 62  _CANTOPEN";    b
26c0: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
26d0: 51 4c 49 54 45 5f 50 52 4f 54 4f 43 4f 4c 3a 20  QLITE_PROTOCOL: 
26e0: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
26f0: 5f 50 52 4f 54 4f 43 4f 4c 22 3b 20 20 20 20 62  _PROTOCOL";    b
2700: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
2710: 51 4c 49 54 45 5f 45 4d 50 54 59 3a 20 20 20 20  QLITE_EMPTY:    
2720: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
2730: 5f 45 4d 50 54 59 22 3b 20 20 20 20 20 20 20 62  _EMPTY";       b
2740: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
2750: 51 4c 49 54 45 5f 53 43 48 45 4d 41 3a 20 20 20  QLITE_SCHEMA:   
2760: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
2770: 5f 53 43 48 45 4d 41 22 3b 20 20 20 20 20 20 62  _SCHEMA";      b
2780: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
2790: 51 4c 49 54 45 5f 43 4f 4e 53 54 52 41 49 4e 54  QLITE_CONSTRAINT
27a0: 3a 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45  : zVal = "SQLITE
27b0: 5f 43 4f 4e 53 54 52 41 49 4e 54 22 3b 20 20 62  _CONSTRAINT";  b
27c0: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
27d0: 51 4c 49 54 45 5f 4d 49 53 4d 41 54 43 48 3a 20  QLITE_MISMATCH: 
27e0: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
27f0: 5f 4d 49 53 4d 41 54 43 48 22 3b 20 20 20 20 62  _MISMATCH";    b
2800: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
2810: 51 4c 49 54 45 5f 4d 49 53 55 53 45 3a 20 20 20  QLITE_MISUSE:   
2820: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
2830: 5f 4d 49 53 55 53 45 22 3b 20 20 20 20 20 20 62  _MISUSE";      b
2840: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
2850: 51 4c 49 54 45 5f 4e 4f 4c 46 53 3a 20 20 20 20  QLITE_NOLFS:    
2860: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
2870: 5f 4e 4f 4c 46 53 22 3b 20 20 20 20 20 20 20 62  _NOLFS";       b
2880: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
2890: 51 4c 49 54 45 5f 49 4f 45 52 52 5f 52 45 41 44  QLITE_IOERR_READ
28a0: 3a 20 20 20 20 20 20 20 20 20 7a 56 61 6c 20 3d  :         zVal =
28b0: 20 22 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f 52   "SQLITE_IOERR_R
28c0: 45 41 44 22 3b 20 20 20 20 20 20 20 20 20 62 72  EAD";         br
28d0: 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53 51  eak;.    case SQ
28e0: 4c 49 54 45 5f 49 4f 45 52 52 5f 53 48 4f 52 54  LITE_IOERR_SHORT
28f0: 5f 52 45 41 44 3a 20 20 20 7a 56 61 6c 20 3d 20  _READ:   zVal = 
2900: 22 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f 53 48  "SQLITE_IOERR_SH
2910: 4f 52 54 5f 52 45 41 44 22 3b 20 20 20 62 72 65  ORT_READ";   bre
2920: 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c  ak;.    case SQL
2930: 49 54 45 5f 49 4f 45 52 52 5f 57 52 49 54 45 3a  ITE_IOERR_WRITE:
2940: 20 20 20 20 20 20 20 20 7a 56 61 6c 20 3d 20 22          zVal = "
2950: 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f 57 52 49  SQLITE_IOERR_WRI
2960: 54 45 22 3b 20 20 20 20 20 20 20 20 62 72 65 61  TE";        brea
2970: 6b 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49  k;.    case SQLI
2980: 54 45 5f 49 4f 45 52 52 5f 46 53 59 4e 43 3a 20  TE_IOERR_FSYNC: 
2990: 20 20 20 20 20 20 20 7a 56 61 6c 20 3d 20 22 53         zVal = "S
29a0: 51 4c 49 54 45 5f 49 4f 45 52 52 5f 46 53 59 4e  QLITE_IOERR_FSYN
29b0: 43 22 3b 20 20 20 20 20 20 20 20 62 72 65 61 6b  C";        break
29c0: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
29d0: 45 5f 49 4f 45 52 52 5f 44 49 52 5f 46 53 59 4e  E_IOERR_DIR_FSYN
29e0: 43 3a 20 20 20 20 7a 56 61 6c 20 3d 20 22 53 51  C:    zVal = "SQ
29f0: 4c 49 54 45 5f 49 4f 45 52 52 5f 44 49 52 5f 46  LITE_IOERR_DIR_F
2a00: 53 59 4e 43 22 3b 20 20 20 20 62 72 65 61 6b 3b  SYNC";    break;
2a10: 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54 45  .    case SQLITE
2a20: 5f 49 4f 45 52 52 5f 54 52 55 4e 43 41 54 45 3a  _IOERR_TRUNCATE:
2a30: 20 20 20 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c       zVal = "SQL
2a40: 49 54 45 5f 49 4f 45 52 52 5f 54 52 55 4e 43 41  ITE_IOERR_TRUNCA
2a50: 54 45 22 3b 20 20 20 20 20 62 72 65 61 6b 3b 0a  TE";     break;.
2a60: 20 20 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f      case SQLITE_
2a70: 49 4f 45 52 52 5f 46 53 54 41 54 3a 20 20 20 20  IOERR_FSTAT:    
2a80: 20 20 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49      zVal = "SQLI
2a90: 54 45 5f 49 4f 45 52 52 5f 46 53 54 41 54 22 3b  TE_IOERR_FSTAT";
2aa0: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20          break;. 
2ab0: 20 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f 49     case SQLITE_I
2ac0: 4f 45 52 52 5f 55 4e 4c 4f 43 4b 3a 20 20 20 20  OERR_UNLOCK:    
2ad0: 20 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54     zVal = "SQLIT
2ae0: 45 5f 49 4f 45 52 52 5f 55 4e 4c 4f 43 4b 22 3b  E_IOERR_UNLOCK";
2af0: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20         break;.  
2b00: 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f 49 4f    case SQLITE_IO
2b10: 45 52 52 5f 52 44 4c 4f 43 4b 3a 20 20 20 20 20  ERR_RDLOCK:     
2b20: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
2b30: 5f 49 4f 45 52 52 5f 52 44 4c 4f 43 4b 22 3b 20  _IOERR_RDLOCK"; 
2b40: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
2b50: 20 63 61 73 65 20 53 51 4c 49 54 45 5f 49 4f 45   case SQLITE_IOE
2b60: 52 52 5f 44 45 4c 45 54 45 3a 20 20 20 20 20 20  RR_DELETE:      
2b70: 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f   zVal = "SQLITE_
2b80: 49 4f 45 52 52 5f 44 45 4c 45 54 45 22 3b 20 20  IOERR_DELETE";  
2b90: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
2ba0: 63 61 73 65 20 53 51 4c 49 54 45 5f 49 4f 45 52  case SQLITE_IOER
2bb0: 52 5f 42 4c 4f 43 4b 45 44 3a 20 20 20 20 20 20  R_BLOCKED:      
2bc0: 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49  zVal = "SQLITE_I
2bd0: 4f 45 52 52 5f 42 4c 4f 43 4b 45 44 22 3b 20 20  OERR_BLOCKED";  
2be0: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63      break;.    c
2bf0: 61 73 65 20 53 51 4c 49 54 45 5f 49 4f 45 52 52  ase SQLITE_IOERR
2c00: 5f 4e 4f 4d 45 4d 3a 20 20 20 20 20 20 20 20 7a  _NOMEM:        z
2c10: 56 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49 4f  Val = "SQLITE_IO
2c20: 45 52 52 5f 4e 4f 4d 45 4d 22 3b 20 20 20 20 20  ERR_NOMEM";     
2c30: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61     break;.    ca
2c40: 73 65 20 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f  se SQLITE_IOERR_
2c50: 41 43 43 45 53 53 3a 20 20 20 20 20 20 20 7a 56  ACCESS:       zV
2c60: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49 4f 45  al = "SQLITE_IOE
2c70: 52 52 5f 41 43 43 45 53 53 22 3b 20 20 20 20 20  RR_ACCESS";     
2c80: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73    break;.    cas
2c90: 65 20 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f 43  e SQLITE_IOERR_C
2ca0: 48 45 43 4b 52 45 53 45 52 56 45 44 4c 4f 43 4b  HECKRESERVEDLOCK
2cb0: 3a 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  :.              
2cc0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2cd0: 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f   zVal = "SQLITE_
2ce0: 49 4f 45 52 52 5f 43 48 45 43 4b 52 45 53 45 52  IOERR_CHECKRESER
2cf0: 56 45 44 4c 4f 43 4b 22 3b 20 62 72 65 61 6b 3b  VEDLOCK"; break;
2d00: 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54 45  .    case SQLITE
2d10: 5f 49 4f 45 52 52 5f 4c 4f 43 4b 3a 20 20 20 20  _IOERR_LOCK:    
2d20: 20 20 20 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c       zVal = "SQL
2d30: 49 54 45 5f 49 4f 45 52 52 5f 4c 4f 43 4b 22 3b  ITE_IOERR_LOCK";
2d40: 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a           break;.
2d50: 20 20 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f      case SQLITE_
2d60: 49 4f 45 52 52 5f 43 4c 4f 53 45 3a 20 20 20 20  IOERR_CLOSE:    
2d70: 20 20 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49      zVal = "SQLI
2d80: 54 45 5f 49 4f 45 52 52 5f 43 4c 4f 53 45 22 3b  TE_IOERR_CLOSE";
2d90: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20          break;. 
2da0: 20 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f 49     case SQLITE_I
2db0: 4f 45 52 52 5f 44 49 52 5f 43 4c 4f 53 45 3a 20  OERR_DIR_CLOSE: 
2dc0: 20 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54     zVal = "SQLIT
2dd0: 45 5f 49 4f 45 52 52 5f 44 49 52 5f 43 4c 4f 53  E_IOERR_DIR_CLOS
2de0: 45 22 3b 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  E";    break;.  
2df0: 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f 49 4f    case SQLITE_IO
2e00: 45 52 52 5f 53 48 4d 4f 50 45 4e 3a 20 20 20 20  ERR_SHMOPEN:    
2e10: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
2e20: 5f 49 4f 45 52 52 5f 53 48 4d 4f 50 45 4e 22 3b  _IOERR_SHMOPEN";
2e30: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
2e40: 20 63 61 73 65 20 53 51 4c 49 54 45 5f 49 4f 45   case SQLITE_IOE
2e50: 52 52 5f 53 48 4d 53 49 5a 45 3a 20 20 20 20 20  RR_SHMSIZE:     
2e60: 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f   zVal = "SQLITE_
2e70: 49 4f 45 52 52 5f 53 48 4d 53 49 5a 45 22 3b 20  IOERR_SHMSIZE"; 
2e80: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
2e90: 63 61 73 65 20 53 51 4c 49 54 45 5f 49 4f 45 52  case SQLITE_IOER
2ea0: 52 5f 53 48 4d 4c 4f 43 4b 3a 20 20 20 20 20 20  R_SHMLOCK:      
2eb0: 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49  zVal = "SQLITE_I
2ec0: 4f 45 52 52 5f 53 48 4d 4c 4f 43 4b 22 3b 20 20  OERR_SHMLOCK";  
2ed0: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63      break;.    c
2ee0: 61 73 65 20 53 51 4c 49 54 45 5f 49 4f 45 52 52  ase SQLITE_IOERR
2ef0: 5f 53 48 4d 4d 41 50 3a 20 20 20 20 20 20 20 7a  _SHMMAP:       z
2f00: 56 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49 4f  Val = "SQLITE_IO
2f10: 45 52 52 5f 53 48 4d 4d 41 50 22 3b 20 20 20 20  ERR_SHMMAP";    
2f20: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61     break;.    ca
2f30: 73 65 20 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f  se SQLITE_IOERR_
2f40: 53 45 45 4b 3a 20 20 20 20 20 20 20 20 20 7a 56  SEEK:         zV
2f50: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49 4f 45  al = "SQLITE_IOE
2f60: 52 52 5f 53 45 45 4b 22 3b 20 20 20 20 20 20 20  RR_SEEK";       
2f70: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73    break;.    cas
2f80: 65 20 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f 47  e SQLITE_IOERR_G
2f90: 45 54 54 45 4d 50 50 41 54 48 3a 20 20 7a 56 61  ETTEMPPATH:  zVa
2fa0: 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49 4f 45 52  l = "SQLITE_IOER
2fb0: 52 5f 47 45 54 54 45 4d 50 50 41 54 48 22 3b 20  R_GETTEMPPATH"; 
2fc0: 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65   break;.    case
2fd0: 20 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f 43 4f   SQLITE_IOERR_CO
2fe0: 4e 56 50 41 54 48 3a 20 20 20 20 20 7a 56 61 6c  NVPATH:     zVal
2ff0: 20 3d 20 22 53 51 4c 49 54 45 5f 49 4f 45 52 52   = "SQLITE_IOERR
3000: 5f 43 4f 4e 56 50 41 54 48 22 3b 20 20 20 20 20  _CONVPATH";     
3010: 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20  break;.    case 
3020: 53 51 4c 49 54 45 5f 52 45 41 44 4f 4e 4c 59 5f  SQLITE_READONLY_
3030: 44 42 4d 4f 56 45 44 3a 20 20 20 7a 56 61 6c 20  DBMOVED:   zVal 
3040: 3d 20 22 53 51 4c 49 54 45 5f 52 45 41 44 4f 4e  = "SQLITE_READON
3050: 4c 59 5f 44 42 4d 4f 56 45 44 22 3b 20 20 20 62  LY_DBMOVED";   b
3060: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
3070: 51 4c 49 54 45 5f 4c 4f 43 4b 45 44 5f 53 48 41  QLITE_LOCKED_SHA
3080: 52 45 44 43 41 43 48 45 3a 20 7a 56 61 6c 20 3d  REDCACHE: zVal =
3090: 20 22 53 51 4c 49 54 45 5f 4c 4f 43 4b 45 44 5f   "SQLITE_LOCKED_
30a0: 53 48 41 52 45 44 43 41 43 48 45 22 3b 20 62 72  SHAREDCACHE"; br
30b0: 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53 51  eak;.    case SQ
30c0: 4c 49 54 45 5f 42 55 53 59 5f 52 45 43 4f 56 45  LITE_BUSY_RECOVE
30d0: 52 59 3a 20 20 20 20 20 20 7a 56 61 6c 20 3d 20  RY:      zVal = 
30e0: 22 53 51 4c 49 54 45 5f 42 55 53 59 5f 52 45 43  "SQLITE_BUSY_REC
30f0: 4f 56 45 52 59 22 3b 20 20 20 20 20 20 62 72 65  OVERY";      bre
3100: 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c  ak;.    case SQL
3110: 49 54 45 5f 43 41 4e 54 4f 50 45 4e 5f 4e 4f 54  ITE_CANTOPEN_NOT
3120: 45 4d 50 44 49 52 3a 20 7a 56 61 6c 20 3d 20 22  EMPDIR: zVal = "
3130: 53 51 4c 49 54 45 5f 43 41 4e 54 4f 50 45 4e 5f  SQLITE_CANTOPEN_
3140: 4e 4f 54 45 4d 50 44 49 52 22 3b 20 62 72 65 61  NOTEMPDIR"; brea
3150: 6b 3b 0a 20 20 20 20 64 65 66 61 75 6c 74 3a 20  k;.    default: 
3160: 7b 0a 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  {.       sqlite3
3170: 5f 73 6e 70 72 69 6e 74 66 28 73 69 7a 65 6f 66  _snprintf(sizeof
3180: 28 7a 42 75 66 29 2c 20 7a 42 75 66 2c 20 22 25  (zBuf), zBuf, "%
3190: 64 22 2c 20 72 63 29 3b 0a 20 20 20 20 20 20 20  d", rc);.       
31a0: 7a 56 61 6c 20 3d 20 7a 42 75 66 3b 0a 20 20 20  zVal = zBuf;.   
31b0: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d      break;.    }
31c0: 0a 20 20 7d 0a 20 20 76 66 73 74 72 61 63 65 5f  .  }.  vfstrace_
31d0: 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20 7a 46  printf(pInfo, zF
31e0: 6f 72 6d 61 74 2c 20 7a 56 61 6c 29 3b 0a 7d 0a  ormat, zVal);.}.
31f0: 0a 2f 2a 0a 2a 2a 20 41 70 70 65 6e 64 20 74 6f  ./*.** Append to
3200: 20 61 20 62 75 66 66 65 72 2e 0a 2a 2f 0a 73 74   a buffer..*/.st
3210: 61 74 69 63 20 76 6f 69 64 20 73 74 72 61 70 70  atic void strapp
3220: 65 6e 64 28 63 68 61 72 20 2a 7a 2c 20 69 6e 74  end(char *z, int
3230: 20 2a 70 49 2c 20 63 6f 6e 73 74 20 63 68 61 72   *pI, const char
3240: 20 2a 7a 41 70 70 65 6e 64 29 7b 0a 20 20 69 6e   *zAppend){.  in
3250: 74 20 69 20 3d 20 2a 70 49 3b 0a 20 20 77 68 69  t i = *pI;.  whi
3260: 6c 65 28 20 7a 41 70 70 65 6e 64 5b 30 5d 20 29  le( zAppend[0] )
3270: 7b 20 7a 5b 69 2b 2b 5d 20 3d 20 2a 28 7a 41 70  { z[i++] = *(zAp
3280: 70 65 6e 64 2b 2b 29 3b 20 7d 0a 20 20 7a 5b 69  pend++); }.  z[i
3290: 5d 20 3d 20 30 3b 0a 20 20 2a 70 49 20 3d 20 69  ] = 0;.  *pI = i
32a0: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 6c 6f 73 65  ;.}../*.** Close
32b0: 20 61 6e 20 76 66 73 74 72 61 63 65 2d 66 69 6c   an vfstrace-fil
32c0: 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74  e..*/.static int
32d0: 20 76 66 73 74 72 61 63 65 43 6c 6f 73 65 28 73   vfstraceClose(s
32e0: 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46 69  qlite3_file *pFi
32f0: 6c 65 29 7b 0a 20 20 76 66 73 74 72 61 63 65 5f  le){.  vfstrace_
3300: 66 69 6c 65 20 2a 70 20 3d 20 28 76 66 73 74 72  file *p = (vfstr
3310: 61 63 65 5f 66 69 6c 65 20 2a 29 70 46 69 6c 65  ace_file *)pFile
3320: 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 69 6e 66  ;.  vfstrace_inf
3330: 6f 20 2a 70 49 6e 66 6f 20 3d 20 70 2d 3e 70 49  o *pInfo = p->pI
3340: 6e 66 6f 3b 0a 20 20 69 6e 74 20 72 63 3b 0a 20  nfo;.  int rc;. 
3350: 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74 66   vfstrace_printf
3360: 28 70 49 6e 66 6f 2c 20 22 25 73 2e 78 43 6c 6f  (pInfo, "%s.xClo
3370: 73 65 28 25 73 29 22 2c 20 70 49 6e 66 6f 2d 3e  se(%s)", pInfo->
3380: 7a 56 66 73 4e 61 6d 65 2c 20 70 2d 3e 7a 46 4e  zVfsName, p->zFN
3390: 61 6d 65 29 3b 0a 20 20 72 63 20 3d 20 70 2d 3e  ame);.  rc = p->
33a0: 70 52 65 61 6c 2d 3e 70 4d 65 74 68 6f 64 73 2d  pReal->pMethods-
33b0: 3e 78 43 6c 6f 73 65 28 70 2d 3e 70 52 65 61 6c  >xClose(p->pReal
33c0: 29 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72  );.  vfstrace_pr
33d0: 69 6e 74 5f 65 72 72 63 6f 64 65 28 70 49 6e 66  int_errcode(pInf
33e0: 6f 2c 20 22 20 2d 3e 20 25 73 5c 6e 22 2c 20 72  o, " -> %s\n", r
33f0: 63 29 3b 0a 20 20 69 66 28 20 72 63 3d 3d 53 51  c);.  if( rc==SQ
3400: 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 73  LITE_OK ){.    s
3410: 71 6c 69 74 65 33 5f 66 72 65 65 28 28 76 6f 69  qlite3_free((voi
3420: 64 2a 29 70 2d 3e 62 61 73 65 2e 70 4d 65 74 68  d*)p->base.pMeth
3430: 6f 64 73 29 3b 0a 20 20 20 20 70 2d 3e 62 61 73  ods);.    p->bas
3440: 65 2e 70 4d 65 74 68 6f 64 73 20 3d 20 30 3b 0a  e.pMethods = 0;.
3450: 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 72 63 3b    }.  return rc;
3460: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 61 64 20 64  .}../*.** Read d
3470: 61 74 61 20 66 72 6f 6d 20 61 6e 20 76 66 73 74  ata from an vfst
3480: 72 61 63 65 2d 66 69 6c 65 2e 0a 2a 2f 0a 73 74  race-file..*/.st
3490: 61 74 69 63 20 69 6e 74 20 76 66 73 74 72 61 63  atic int vfstrac
34a0: 65 52 65 61 64 28 0a 20 20 73 71 6c 69 74 65 33  eRead(.  sqlite3
34b0: 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c 20 0a 20  _file *pFile, . 
34c0: 20 76 6f 69 64 20 2a 7a 42 75 66 2c 20 0a 20 20   void *zBuf, .  
34d0: 69 6e 74 20 69 41 6d 74 2c 20 0a 20 20 73 71 6c  int iAmt, .  sql
34e0: 69 74 65 5f 69 6e 74 36 34 20 69 4f 66 73 74 0a  ite_int64 iOfst.
34f0: 29 7b 0a 20 20 76 66 73 74 72 61 63 65 5f 66 69  ){.  vfstrace_fi
3500: 6c 65 20 2a 70 20 3d 20 28 76 66 73 74 72 61 63  le *p = (vfstrac
3510: 65 5f 66 69 6c 65 20 2a 29 70 46 69 6c 65 3b 0a  e_file *)pFile;.
3520: 20 20 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 20    vfstrace_info 
3530: 2a 70 49 6e 66 6f 20 3d 20 70 2d 3e 70 49 6e 66  *pInfo = p->pInf
3540: 6f 3b 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20 76  o;.  int rc;.  v
3550: 66 73 74 72 61 63 65 5f 70 72 69 6e 74 66 28 70  fstrace_printf(p
3560: 49 6e 66 6f 2c 20 22 25 73 2e 78 52 65 61 64 28  Info, "%s.xRead(
3570: 25 73 2c 6e 3d 25 64 2c 6f 66 73 74 3d 25 6c 6c  %s,n=%d,ofst=%ll
3580: 64 29 22 2c 0a 20 20 20 20 20 20 20 20 20 20 20  d)",.           
3590: 20 20 20 20 20 20 20 70 49 6e 66 6f 2d 3e 7a 56         pInfo->zV
35a0: 66 73 4e 61 6d 65 2c 20 70 2d 3e 7a 46 4e 61 6d  fsName, p->zFNam
35b0: 65 2c 20 69 41 6d 74 2c 20 69 4f 66 73 74 29 3b  e, iAmt, iOfst);
35c0: 0a 20 20 72 63 20 3d 20 70 2d 3e 70 52 65 61 6c  .  rc = p->pReal
35d0: 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 52 65 61  ->pMethods->xRea
35e0: 64 28 70 2d 3e 70 52 65 61 6c 2c 20 7a 42 75 66  d(p->pReal, zBuf
35f0: 2c 20 69 41 6d 74 2c 20 69 4f 66 73 74 29 3b 0a  , iAmt, iOfst);.
3600: 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74    vfstrace_print
3610: 5f 65 72 72 63 6f 64 65 28 70 49 6e 66 6f 2c 20  _errcode(pInfo, 
3620: 22 20 2d 3e 20 25 73 5c 6e 22 2c 20 72 63 29 3b  " -> %s\n", rc);
3630: 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a  .  return rc;.}.
3640: 0a 2f 2a 0a 2a 2a 20 57 72 69 74 65 20 64 61 74  ./*.** Write dat
3650: 61 20 74 6f 20 61 6e 20 76 66 73 74 72 61 63 65  a to an vfstrace
3660: 2d 66 69 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63  -file..*/.static
3670: 20 69 6e 74 20 76 66 73 74 72 61 63 65 57 72 69   int vfstraceWri
3680: 74 65 28 0a 20 20 73 71 6c 69 74 65 33 5f 66 69  te(.  sqlite3_fi
3690: 6c 65 20 2a 70 46 69 6c 65 2c 20 0a 20 20 63 6f  le *pFile, .  co
36a0: 6e 73 74 20 76 6f 69 64 20 2a 7a 42 75 66 2c 20  nst void *zBuf, 
36b0: 0a 20 20 69 6e 74 20 69 41 6d 74 2c 20 0a 20 20  .  int iAmt, .  
36c0: 73 71 6c 69 74 65 5f 69 6e 74 36 34 20 69 4f 66  sqlite_int64 iOf
36d0: 73 74 0a 29 7b 0a 20 20 76 66 73 74 72 61 63 65  st.){.  vfstrace
36e0: 5f 66 69 6c 65 20 2a 70 20 3d 20 28 76 66 73 74  _file *p = (vfst
36f0: 72 61 63 65 5f 66 69 6c 65 20 2a 29 70 46 69 6c  race_file *)pFil
3700: 65 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 69 6e  e;.  vfstrace_in
3710: 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 70 2d 3e 70  fo *pInfo = p->p
3720: 49 6e 66 6f 3b 0a 20 20 69 6e 74 20 72 63 3b 0a  Info;.  int rc;.
3730: 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74    vfstrace_print
3740: 66 28 70 49 6e 66 6f 2c 20 22 25 73 2e 78 57 72  f(pInfo, "%s.xWr
3750: 69 74 65 28 25 73 2c 6e 3d 25 64 2c 6f 66 73 74  ite(%s,n=%d,ofst
3760: 3d 25 6c 6c 64 29 22 2c 0a 20 20 20 20 20 20 20  =%lld)",.       
3770: 20 20 20 20 20 20 20 20 20 20 20 70 49 6e 66 6f             pInfo
3780: 2d 3e 7a 56 66 73 4e 61 6d 65 2c 20 70 2d 3e 7a  ->zVfsName, p->z
3790: 46 4e 61 6d 65 2c 20 69 41 6d 74 2c 20 69 4f 66  FName, iAmt, iOf
37a0: 73 74 29 3b 0a 20 20 72 63 20 3d 20 70 2d 3e 70  st);.  rc = p->p
37b0: 52 65 61 6c 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e  Real->pMethods->
37c0: 78 57 72 69 74 65 28 70 2d 3e 70 52 65 61 6c 2c  xWrite(p->pReal,
37d0: 20 7a 42 75 66 2c 20 69 41 6d 74 2c 20 69 4f 66   zBuf, iAmt, iOf
37e0: 73 74 29 3b 0a 20 20 76 66 73 74 72 61 63 65 5f  st);.  vfstrace_
37f0: 70 72 69 6e 74 5f 65 72 72 63 6f 64 65 28 70 49  print_errcode(pI
3800: 6e 66 6f 2c 20 22 20 2d 3e 20 25 73 5c 6e 22 2c  nfo, " -> %s\n",
3810: 20 72 63 29 3b 0a 20 20 72 65 74 75 72 6e 20 72   rc);.  return r
3820: 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 72 75 6e  c;.}../*.** Trun
3830: 63 61 74 65 20 61 6e 20 76 66 73 74 72 61 63 65  cate an vfstrace
3840: 2d 66 69 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63  -file..*/.static
3850: 20 69 6e 74 20 76 66 73 74 72 61 63 65 54 72 75   int vfstraceTru
3860: 6e 63 61 74 65 28 73 71 6c 69 74 65 33 5f 66 69  ncate(sqlite3_fi
3870: 6c 65 20 2a 70 46 69 6c 65 2c 20 73 71 6c 69 74  le *pFile, sqlit
3880: 65 5f 69 6e 74 36 34 20 73 69 7a 65 29 7b 0a 20  e_int64 size){. 
3890: 20 76 66 73 74 72 61 63 65 5f 66 69 6c 65 20 2a   vfstrace_file *
38a0: 70 20 3d 20 28 76 66 73 74 72 61 63 65 5f 66 69  p = (vfstrace_fi
38b0: 6c 65 20 2a 29 70 46 69 6c 65 3b 0a 20 20 76 66  le *)pFile;.  vf
38c0: 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70 49 6e  strace_info *pIn
38d0: 66 6f 20 3d 20 70 2d 3e 70 49 6e 66 6f 3b 0a 20  fo = p->pInfo;. 
38e0: 20 69 6e 74 20 72 63 3b 0a 20 20 76 66 73 74 72   int rc;.  vfstr
38f0: 61 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f  ace_printf(pInfo
3900: 2c 20 22 25 73 2e 78 54 72 75 6e 63 61 74 65 28  , "%s.xTruncate(
3910: 25 73 2c 25 6c 6c 64 29 22 2c 20 70 49 6e 66 6f  %s,%lld)", pInfo
3920: 2d 3e 7a 56 66 73 4e 61 6d 65 2c 20 70 2d 3e 7a  ->zVfsName, p->z
3930: 46 4e 61 6d 65 2c 0a 20 20 20 20 20 20 20 20 20  FName,.         
3940: 20 20 20 20 20 20 20 20 20 73 69 7a 65 29 3b 0a           size);.
3950: 20 20 72 63 20 3d 20 70 2d 3e 70 52 65 61 6c 2d    rc = p->pReal-
3960: 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 54 72 75 6e  >pMethods->xTrun
3970: 63 61 74 65 28 70 2d 3e 70 52 65 61 6c 2c 20 73  cate(p->pReal, s
3980: 69 7a 65 29 3b 0a 20 20 76 66 73 74 72 61 63 65  ize);.  vfstrace
3990: 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22  _printf(pInfo, "
39a0: 20 2d 3e 20 25 64 5c 6e 22 2c 20 72 63 29 3b 0a   -> %d\n", rc);.
39b0: 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a    return rc;.}..
39c0: 2f 2a 0a 2a 2a 20 53 79 6e 63 20 61 6e 20 76 66  /*.** Sync an vf
39d0: 73 74 72 61 63 65 2d 66 69 6c 65 2e 0a 2a 2f 0a  strace-file..*/.
39e0: 73 74 61 74 69 63 20 69 6e 74 20 76 66 73 74 72  static int vfstr
39f0: 61 63 65 53 79 6e 63 28 73 71 6c 69 74 65 33 5f  aceSync(sqlite3_
3a00: 66 69 6c 65 20 2a 70 46 69 6c 65 2c 20 69 6e 74  file *pFile, int
3a10: 20 66 6c 61 67 73 29 7b 0a 20 20 76 66 73 74 72   flags){.  vfstr
3a20: 61 63 65 5f 66 69 6c 65 20 2a 70 20 3d 20 28 76  ace_file *p = (v
3a30: 66 73 74 72 61 63 65 5f 66 69 6c 65 20 2a 29 70  fstrace_file *)p
3a40: 46 69 6c 65 3b 0a 20 20 76 66 73 74 72 61 63 65  File;.  vfstrace
3a50: 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 70  _info *pInfo = p
3a60: 2d 3e 70 49 6e 66 6f 3b 0a 20 20 69 6e 74 20 72  ->pInfo;.  int r
3a70: 63 3b 0a 20 20 69 6e 74 20 69 3b 0a 20 20 63 68  c;.  int i;.  ch
3a80: 61 72 20 7a 42 75 66 5b 31 30 30 5d 3b 0a 20 20  ar zBuf[100];.  
3a90: 6d 65 6d 63 70 79 28 7a 42 75 66 2c 20 22 7c 30  memcpy(zBuf, "|0
3aa0: 22 2c 20 33 29 3b 0a 20 20 69 20 3d 20 30 3b 0a  ", 3);.  i = 0;.
3ab0: 20 20 69 66 28 20 66 6c 61 67 73 20 26 20 53 51    if( flags & SQ
3ac0: 4c 49 54 45 5f 53 59 4e 43 5f 46 55 4c 4c 20 29  LITE_SYNC_FULL )
3ad0: 20 20 20 20 20 20 20 20 73 74 72 61 70 70 65 6e          strappen
3ae0: 64 28 7a 42 75 66 2c 20 26 69 2c 20 22 7c 46 55  d(zBuf, &i, "|FU
3af0: 4c 4c 22 29 3b 0a 20 20 65 6c 73 65 20 69 66 28  LL");.  else if(
3b00: 20 66 6c 61 67 73 20 26 20 53 51 4c 49 54 45 5f   flags & SQLITE_
3b10: 53 59 4e 43 5f 4e 4f 52 4d 41 4c 20 29 20 73 74  SYNC_NORMAL ) st
3b20: 72 61 70 70 65 6e 64 28 7a 42 75 66 2c 20 26 69  rappend(zBuf, &i
3b30: 2c 20 22 7c 4e 4f 52 4d 41 4c 22 29 3b 0a 20 20  , "|NORMAL");.  
3b40: 69 66 28 20 66 6c 61 67 73 20 26 20 53 51 4c 49  if( flags & SQLI
3b50: 54 45 5f 53 59 4e 43 5f 44 41 54 41 4f 4e 4c 59  TE_SYNC_DATAONLY
3b60: 20 29 20 20 20 20 73 74 72 61 70 70 65 6e 64 28   )    strappend(
3b70: 7a 42 75 66 2c 20 26 69 2c 20 22 7c 44 41 54 41  zBuf, &i, "|DATA
3b80: 4f 4e 4c 59 22 29 3b 0a 20 20 69 66 28 20 66 6c  ONLY");.  if( fl
3b90: 61 67 73 20 26 20 7e 28 53 51 4c 49 54 45 5f 53  ags & ~(SQLITE_S
3ba0: 59 4e 43 5f 46 55 4c 4c 7c 53 51 4c 49 54 45 5f  YNC_FULL|SQLITE_
3bb0: 53 59 4e 43 5f 44 41 54 41 4f 4e 4c 59 29 20 29  SYNC_DATAONLY) )
3bc0: 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 73 6e  {.    sqlite3_sn
3bd0: 70 72 69 6e 74 66 28 73 69 7a 65 6f 66 28 7a 42  printf(sizeof(zB
3be0: 75 66 29 2d 69 2c 20 26 7a 42 75 66 5b 69 5d 2c  uf)-i, &zBuf[i],
3bf0: 20 22 7c 30 78 25 78 22 2c 20 66 6c 61 67 73 29   "|0x%x", flags)
3c00: 3b 0a 20 20 7d 0a 20 20 76 66 73 74 72 61 63 65  ;.  }.  vfstrace
3c10: 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22  _printf(pInfo, "
3c20: 25 73 2e 78 53 79 6e 63 28 25 73 2c 25 73 29 22  %s.xSync(%s,%s)"
3c30: 2c 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d  , pInfo->zVfsNam
3c40: 65 2c 20 70 2d 3e 7a 46 4e 61 6d 65 2c 0a 20 20  e, p->zFName,.  
3c50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3c60: 26 7a 42 75 66 5b 31 5d 29 3b 0a 20 20 72 63 20  &zBuf[1]);.  rc 
3c70: 3d 20 70 2d 3e 70 52 65 61 6c 2d 3e 70 4d 65 74  = p->pReal->pMet
3c80: 68 6f 64 73 2d 3e 78 53 79 6e 63 28 70 2d 3e 70  hods->xSync(p->p
3c90: 52 65 61 6c 2c 20 66 6c 61 67 73 29 3b 0a 20 20  Real, flags);.  
3ca0: 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74 66 28  vfstrace_printf(
3cb0: 70 49 6e 66 6f 2c 20 22 20 2d 3e 20 25 64 5c 6e  pInfo, " -> %d\n
3cc0: 22 2c 20 72 63 29 3b 0a 20 20 72 65 74 75 72 6e  ", rc);.  return
3cd0: 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65   rc;.}../*.** Re
3ce0: 74 75 72 6e 20 74 68 65 20 63 75 72 72 65 6e 74  turn the current
3cf0: 20 66 69 6c 65 2d 73 69 7a 65 20 6f 66 20 61 6e   file-size of an
3d00: 20 76 66 73 74 72 61 63 65 2d 66 69 6c 65 2e 0a   vfstrace-file..
3d10: 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 76 66  */.static int vf
3d20: 73 74 72 61 63 65 46 69 6c 65 53 69 7a 65 28 73  straceFileSize(s
3d30: 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46 69  qlite3_file *pFi
3d40: 6c 65 2c 20 73 71 6c 69 74 65 5f 69 6e 74 36 34  le, sqlite_int64
3d50: 20 2a 70 53 69 7a 65 29 7b 0a 20 20 76 66 73 74   *pSize){.  vfst
3d60: 72 61 63 65 5f 66 69 6c 65 20 2a 70 20 3d 20 28  race_file *p = (
3d70: 76 66 73 74 72 61 63 65 5f 66 69 6c 65 20 2a 29  vfstrace_file *)
3d80: 70 46 69 6c 65 3b 0a 20 20 76 66 73 74 72 61 63  pFile;.  vfstrac
3d90: 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20  e_info *pInfo = 
3da0: 70 2d 3e 70 49 6e 66 6f 3b 0a 20 20 69 6e 74 20  p->pInfo;.  int 
3db0: 72 63 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 70  rc;.  vfstrace_p
3dc0: 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22 25 73  rintf(pInfo, "%s
3dd0: 2e 78 46 69 6c 65 53 69 7a 65 28 25 73 29 22 2c  .xFileSize(%s)",
3de0: 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d 65   pInfo->zVfsName
3df0: 2c 20 70 2d 3e 7a 46 4e 61 6d 65 29 3b 0a 20 20  , p->zFName);.  
3e00: 72 63 20 3d 20 70 2d 3e 70 52 65 61 6c 2d 3e 70  rc = p->pReal->p
3e10: 4d 65 74 68 6f 64 73 2d 3e 78 46 69 6c 65 53 69  Methods->xFileSi
3e20: 7a 65 28 70 2d 3e 70 52 65 61 6c 2c 20 70 53 69  ze(p->pReal, pSi
3e30: 7a 65 29 3b 0a 20 20 76 66 73 74 72 61 63 65 5f  ze);.  vfstrace_
3e40: 70 72 69 6e 74 5f 65 72 72 63 6f 64 65 28 70 49  print_errcode(pI
3e50: 6e 66 6f 2c 20 22 20 2d 3e 20 25 73 2c 22 2c 20  nfo, " -> %s,", 
3e60: 72 63 29 3b 0a 20 20 76 66 73 74 72 61 63 65 5f  rc);.  vfstrace_
3e70: 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22 20  printf(pInfo, " 
3e80: 73 69 7a 65 3d 25 6c 6c 64 5c 6e 22 2c 20 2a 70  size=%lld\n", *p
3e90: 53 69 7a 65 29 3b 0a 20 20 72 65 74 75 72 6e 20  Size);.  return 
3ea0: 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74  rc;.}../*.** Ret
3eb0: 75 72 6e 20 74 68 65 20 6e 61 6d 65 20 6f 66 20  urn the name of 
3ec0: 61 20 6c 6f 63 6b 2e 0a 2a 2f 0a 73 74 61 74 69  a lock..*/.stati
3ed0: 63 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 6c 6f  c const char *lo
3ee0: 63 6b 4e 61 6d 65 28 69 6e 74 20 65 4c 6f 63 6b  ckName(int eLock
3ef0: 29 7b 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20  ){.  const char 
3f00: 2a 61 7a 4c 6f 63 6b 4e 61 6d 65 73 5b 5d 20 3d  *azLockNames[] =
3f10: 20 7b 0a 20 20 20 20 20 22 4e 4f 4e 45 22 2c 20   {.     "NONE", 
3f20: 22 53 48 41 52 45 44 22 2c 20 22 52 45 53 45 52  "SHARED", "RESER
3f30: 56 45 44 22 2c 20 22 50 45 4e 44 49 4e 47 22 2c  VED", "PENDING",
3f40: 20 22 45 58 43 4c 55 53 49 56 45 22 0a 20 20 7d   "EXCLUSIVE".  }
3f50: 3b 0a 20 20 69 66 28 20 65 4c 6f 63 6b 3c 30 20  ;.  if( eLock<0 
3f60: 7c 7c 20 65 4c 6f 63 6b 3e 3d 73 69 7a 65 6f 66  || eLock>=sizeof
3f70: 28 61 7a 4c 6f 63 6b 4e 61 6d 65 73 29 2f 73 69  (azLockNames)/si
3f80: 7a 65 6f 66 28 61 7a 4c 6f 63 6b 4e 61 6d 65 73  zeof(azLockNames
3f90: 5b 30 5d 29 20 29 7b 0a 20 20 20 20 72 65 74 75  [0]) ){.    retu
3fa0: 72 6e 20 22 3f 3f 3f 22 3b 0a 20 20 7d 65 6c 73  rn "???";.  }els
3fb0: 65 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 61 7a  e{.    return az
3fc0: 4c 6f 63 6b 4e 61 6d 65 73 5b 65 4c 6f 63 6b 5d  LockNames[eLock]
3fd0: 3b 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 4c  ;.  }.}../*.** L
3fe0: 6f 63 6b 20 61 6e 20 76 66 73 74 72 61 63 65 2d  ock an vfstrace-
3ff0: 66 69 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  file..*/.static 
4000: 69 6e 74 20 76 66 73 74 72 61 63 65 4c 6f 63 6b  int vfstraceLock
4010: 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70  (sqlite3_file *p
4020: 46 69 6c 65 2c 20 69 6e 74 20 65 4c 6f 63 6b 29  File, int eLock)
4030: 7b 0a 20 20 76 66 73 74 72 61 63 65 5f 66 69 6c  {.  vfstrace_fil
4040: 65 20 2a 70 20 3d 20 28 76 66 73 74 72 61 63 65  e *p = (vfstrace
4050: 5f 66 69 6c 65 20 2a 29 70 46 69 6c 65 3b 0a 20  _file *)pFile;. 
4060: 20 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a   vfstrace_info *
4070: 70 49 6e 66 6f 20 3d 20 70 2d 3e 70 49 6e 66 6f  pInfo = p->pInfo
4080: 3b 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20 76 66  ;.  int rc;.  vf
4090: 73 74 72 61 63 65 5f 70 72 69 6e 74 66 28 70 49  strace_printf(pI
40a0: 6e 66 6f 2c 20 22 25 73 2e 78 4c 6f 63 6b 28 25  nfo, "%s.xLock(%
40b0: 73 2c 25 73 29 22 2c 20 70 49 6e 66 6f 2d 3e 7a  s,%s)", pInfo->z
40c0: 56 66 73 4e 61 6d 65 2c 20 70 2d 3e 7a 46 4e 61  VfsName, p->zFNa
40d0: 6d 65 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20  me,.            
40e0: 20 20 20 20 20 20 6c 6f 63 6b 4e 61 6d 65 28 65        lockName(e
40f0: 4c 6f 63 6b 29 29 3b 0a 20 20 72 63 20 3d 20 70  Lock));.  rc = p
4100: 2d 3e 70 52 65 61 6c 2d 3e 70 4d 65 74 68 6f 64  ->pReal->pMethod
4110: 73 2d 3e 78 4c 6f 63 6b 28 70 2d 3e 70 52 65 61  s->xLock(p->pRea
4120: 6c 2c 20 65 4c 6f 63 6b 29 3b 0a 20 20 76 66 73  l, eLock);.  vfs
4130: 74 72 61 63 65 5f 70 72 69 6e 74 5f 65 72 72 63  trace_print_errc
4140: 6f 64 65 28 70 49 6e 66 6f 2c 20 22 20 2d 3e 20  ode(pInfo, " -> 
4150: 25 73 5c 6e 22 2c 20 72 63 29 3b 0a 20 20 72 65  %s\n", rc);.  re
4160: 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a  turn rc;.}../*.*
4170: 2a 20 55 6e 6c 6f 63 6b 20 61 6e 20 76 66 73 74  * Unlock an vfst
4180: 72 61 63 65 2d 66 69 6c 65 2e 0a 2a 2f 0a 73 74  race-file..*/.st
4190: 61 74 69 63 20 69 6e 74 20 76 66 73 74 72 61 63  atic int vfstrac
41a0: 65 55 6e 6c 6f 63 6b 28 73 71 6c 69 74 65 33 5f  eUnlock(sqlite3_
41b0: 66 69 6c 65 20 2a 70 46 69 6c 65 2c 20 69 6e 74  file *pFile, int
41c0: 20 65 4c 6f 63 6b 29 7b 0a 20 20 76 66 73 74 72   eLock){.  vfstr
41d0: 61 63 65 5f 66 69 6c 65 20 2a 70 20 3d 20 28 76  ace_file *p = (v
41e0: 66 73 74 72 61 63 65 5f 66 69 6c 65 20 2a 29 70  fstrace_file *)p
41f0: 46 69 6c 65 3b 0a 20 20 76 66 73 74 72 61 63 65  File;.  vfstrace
4200: 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 70  _info *pInfo = p
4210: 2d 3e 70 49 6e 66 6f 3b 0a 20 20 69 6e 74 20 72  ->pInfo;.  int r
4220: 63 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72  c;.  vfstrace_pr
4230: 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22 25 73 2e  intf(pInfo, "%s.
4240: 78 55 6e 6c 6f 63 6b 28 25 73 2c 25 73 29 22 2c  xUnlock(%s,%s)",
4250: 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d 65   pInfo->zVfsName
4260: 2c 20 70 2d 3e 7a 46 4e 61 6d 65 2c 0a 20 20 20  , p->zFName,.   
4270: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6c                 l
4280: 6f 63 6b 4e 61 6d 65 28 65 4c 6f 63 6b 29 29 3b  ockName(eLock));
4290: 0a 20 20 72 63 20 3d 20 70 2d 3e 70 52 65 61 6c  .  rc = p->pReal
42a0: 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 55 6e 6c  ->pMethods->xUnl
42b0: 6f 63 6b 28 70 2d 3e 70 52 65 61 6c 2c 20 65 4c  ock(p->pReal, eL
42c0: 6f 63 6b 29 3b 0a 20 20 76 66 73 74 72 61 63 65  ock);.  vfstrace
42d0: 5f 70 72 69 6e 74 5f 65 72 72 63 6f 64 65 28 70  _print_errcode(p
42e0: 49 6e 66 6f 2c 20 22 20 2d 3e 20 25 73 5c 6e 22  Info, " -> %s\n"
42f0: 2c 20 72 63 29 3b 0a 20 20 72 65 74 75 72 6e 20  , rc);.  return 
4300: 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 68 65  rc;.}../*.** Che
4310: 63 6b 20 69 66 20 61 6e 6f 74 68 65 72 20 66 69  ck if another fi
4320: 6c 65 2d 68 61 6e 64 6c 65 20 68 6f 6c 64 73 20  le-handle holds 
4330: 61 20 52 45 53 45 52 56 45 44 20 6c 6f 63 6b 20  a RESERVED lock 
4340: 6f 6e 20 61 6e 20 76 66 73 74 72 61 63 65 2d 66  on an vfstrace-f
4350: 69 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69  ile..*/.static i
4360: 6e 74 20 76 66 73 74 72 61 63 65 43 68 65 63 6b  nt vfstraceCheck
4370: 52 65 73 65 72 76 65 64 4c 6f 63 6b 28 73 71 6c  ReservedLock(sql
4380: 69 74 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65  ite3_file *pFile
4390: 2c 20 69 6e 74 20 2a 70 52 65 73 4f 75 74 29 7b  , int *pResOut){
43a0: 0a 20 20 76 66 73 74 72 61 63 65 5f 66 69 6c 65  .  vfstrace_file
43b0: 20 2a 70 20 3d 20 28 76 66 73 74 72 61 63 65 5f   *p = (vfstrace_
43c0: 66 69 6c 65 20 2a 29 70 46 69 6c 65 3b 0a 20 20  file *)pFile;.  
43d0: 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70  vfstrace_info *p
43e0: 49 6e 66 6f 20 3d 20 70 2d 3e 70 49 6e 66 6f 3b  Info = p->pInfo;
43f0: 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20 76 66 73  .  int rc;.  vfs
4400: 74 72 61 63 65 5f 70 72 69 6e 74 66 28 70 49 6e  trace_printf(pIn
4410: 66 6f 2c 20 22 25 73 2e 78 43 68 65 63 6b 52 65  fo, "%s.xCheckRe
4420: 73 65 72 76 65 64 4c 6f 63 6b 28 25 73 2c 25 64  servedLock(%s,%d
4430: 29 22 2c 20 0a 20 20 20 20 20 20 20 20 20 20 20  )", .           
4440: 20 20 20 20 20 20 20 70 49 6e 66 6f 2d 3e 7a 56         pInfo->zV
4450: 66 73 4e 61 6d 65 2c 20 70 2d 3e 7a 46 4e 61 6d  fsName, p->zFNam
4460: 65 29 3b 0a 20 20 72 63 20 3d 20 70 2d 3e 70 52  e);.  rc = p->pR
4470: 65 61 6c 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78  eal->pMethods->x
4480: 43 68 65 63 6b 52 65 73 65 72 76 65 64 4c 6f 63  CheckReservedLoc
4490: 6b 28 70 2d 3e 70 52 65 61 6c 2c 20 70 52 65 73  k(p->pReal, pRes
44a0: 4f 75 74 29 3b 0a 20 20 76 66 73 74 72 61 63 65  Out);.  vfstrace
44b0: 5f 70 72 69 6e 74 5f 65 72 72 63 6f 64 65 28 70  _print_errcode(p
44c0: 49 6e 66 6f 2c 20 22 20 2d 3e 20 25 73 22 2c 20  Info, " -> %s", 
44d0: 72 63 29 3b 0a 20 20 76 66 73 74 72 61 63 65 5f  rc);.  vfstrace_
44e0: 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22 2c  printf(pInfo, ",
44f0: 20 6f 75 74 3d 25 64 5c 6e 22 2c 20 2a 70 52 65   out=%d\n", *pRe
4500: 73 4f 75 74 29 3b 0a 20 20 72 65 74 75 72 6e 20  sOut);.  return 
4510: 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 46 69 6c  rc;.}../*.** Fil
4520: 65 20 63 6f 6e 74 72 6f 6c 20 6d 65 74 68 6f 64  e control method
4530: 2e 20 46 6f 72 20 63 75 73 74 6f 6d 20 6f 70 65  . For custom ope
4540: 72 61 74 69 6f 6e 73 20 6f 6e 20 61 6e 20 76 66  rations on an vf
4550: 73 74 72 61 63 65 2d 66 69 6c 65 2e 0a 2a 2f 0a  strace-file..*/.
4560: 73 74 61 74 69 63 20 69 6e 74 20 76 66 73 74 72  static int vfstr
4570: 61 63 65 46 69 6c 65 43 6f 6e 74 72 6f 6c 28 73  aceFileControl(s
4580: 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46 69  qlite3_file *pFi
4590: 6c 65 2c 20 69 6e 74 20 6f 70 2c 20 76 6f 69 64  le, int op, void
45a0: 20 2a 70 41 72 67 29 7b 0a 20 20 76 66 73 74 72   *pArg){.  vfstr
45b0: 61 63 65 5f 66 69 6c 65 20 2a 70 20 3d 20 28 76  ace_file *p = (v
45c0: 66 73 74 72 61 63 65 5f 66 69 6c 65 20 2a 29 70  fstrace_file *)p
45d0: 46 69 6c 65 3b 0a 20 20 76 66 73 74 72 61 63 65  File;.  vfstrace
45e0: 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 70  _info *pInfo = p
45f0: 2d 3e 70 49 6e 66 6f 3b 0a 20 20 69 6e 74 20 72  ->pInfo;.  int r
4600: 63 3b 0a 20 20 63 68 61 72 20 7a 42 75 66 5b 31  c;.  char zBuf[1
4610: 30 30 5d 3b 0a 20 20 63 68 61 72 20 2a 7a 4f 70  00];.  char *zOp
4620: 3b 0a 20 20 73 77 69 74 63 68 28 20 6f 70 20 29  ;.  switch( op )
4630: 7b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  {.    case SQLIT
4640: 45 5f 46 43 4e 54 4c 5f 4c 4f 43 4b 53 54 41 54  E_FCNTL_LOCKSTAT
4650: 45 3a 20 20 20 20 7a 4f 70 20 3d 20 22 4c 4f 43  E:    zOp = "LOC
4660: 4b 53 54 41 54 45 22 3b 20 20 20 20 20 20 20 20  KSTATE";        
4670: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73    break;.    cas
4680: 65 20 53 51 4c 49 54 45 5f 47 45 54 5f 4c 4f 43  e SQLITE_GET_LOC
4690: 4b 50 52 4f 58 59 46 49 4c 45 3a 20 20 7a 4f 70  KPROXYFILE:  zOp
46a0: 20 3d 20 22 47 45 54 5f 4c 4f 43 4b 50 52 4f 58   = "GET_LOCKPROX
46b0: 59 46 49 4c 45 22 3b 20 20 62 72 65 61 6b 3b 0a  YFILE";  break;.
46c0: 20 20 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f      case SQLITE_
46d0: 53 45 54 5f 4c 4f 43 4b 50 52 4f 58 59 46 49 4c  SET_LOCKPROXYFIL
46e0: 45 3a 20 20 7a 4f 70 20 3d 20 22 53 45 54 5f 4c  E:  zOp = "SET_L
46f0: 4f 43 4b 50 52 4f 58 59 46 49 4c 45 22 3b 20 20  OCKPROXYFILE";  
4700: 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20  break;.    case 
4710: 53 51 4c 49 54 45 5f 4c 41 53 54 5f 45 52 52 4e  SQLITE_LAST_ERRN
4720: 4f 3a 20 20 20 20 20 20 20 20 20 7a 4f 70 20 3d  O:         zOp =
4730: 20 22 4c 41 53 54 5f 45 52 52 4e 4f 22 3b 20 20   "LAST_ERRNO";  
4740: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20         break;.  
4750: 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f 46 43    case SQLITE_FC
4760: 4e 54 4c 5f 53 49 5a 45 5f 48 49 4e 54 3a 20 7b  NTL_SIZE_HINT: {
4770: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 73  .      sqlite3_s
4780: 6e 70 72 69 6e 74 66 28 73 69 7a 65 6f 66 28 7a  nprintf(sizeof(z
4790: 42 75 66 29 2c 20 7a 42 75 66 2c 20 22 53 49 5a  Buf), zBuf, "SIZ
47a0: 45 5f 48 49 4e 54 2c 25 6c 6c 64 22 2c 0a 20 20  E_HINT,%lld",.  
47b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
47c0: 20 20 20 20 20 2a 28 73 71 6c 69 74 65 33 5f 69       *(sqlite3_i
47d0: 6e 74 36 34 2a 29 70 41 72 67 29 3b 0a 20 20 20  nt64*)pArg);.   
47e0: 20 20 20 7a 4f 70 20 3d 20 7a 42 75 66 3b 0a 20     zOp = zBuf;. 
47f0: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
4800: 7d 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  }.    case SQLIT
4810: 45 5f 46 43 4e 54 4c 5f 43 48 55 4e 4b 5f 53 49  E_FCNTL_CHUNK_SI
4820: 5a 45 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c 69  ZE: {.      sqli
4830: 74 65 33 5f 73 6e 70 72 69 6e 74 66 28 73 69 7a  te3_snprintf(siz
4840: 65 6f 66 28 7a 42 75 66 29 2c 20 7a 42 75 66 2c  eof(zBuf), zBuf,
4850: 20 22 43 48 55 4e 4b 5f 53 49 5a 45 2c 25 64 22   "CHUNK_SIZE,%d"
4860: 2c 20 2a 28 69 6e 74 2a 29 70 41 72 67 29 3b 0a  , *(int*)pArg);.
4870: 20 20 20 20 20 20 7a 4f 70 20 3d 20 7a 42 75 66        zOp = zBuf
4880: 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20  ;.      break;. 
4890: 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 53 51     }.    case SQ
48a0: 4c 49 54 45 5f 46 43 4e 54 4c 5f 46 49 4c 45 5f  LITE_FCNTL_FILE_
48b0: 50 4f 49 4e 54 45 52 3a 20 7a 4f 70 20 3d 20 22  POINTER: zOp = "
48c0: 46 49 4c 45 5f 50 4f 49 4e 54 45 52 22 3b 20 20  FILE_POINTER";  
48d0: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
48e0: 63 61 73 65 20 53 51 4c 49 54 45 5f 46 43 4e 54  case SQLITE_FCNT
48f0: 4c 5f 53 59 4e 43 5f 4f 4d 49 54 54 45 44 3a 20  L_SYNC_OMITTED: 
4900: 7a 4f 70 20 3d 20 22 53 59 4e 43 5f 4f 4d 49 54  zOp = "SYNC_OMIT
4910: 54 45 44 22 3b 20 20 20 20 20 20 20 62 72 65 61  TED";       brea
4920: 6b 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49  k;.    case SQLI
4930: 54 45 5f 46 43 4e 54 4c 5f 57 49 4e 33 32 5f 41  TE_FCNTL_WIN32_A
4940: 56 5f 52 45 54 52 59 3a 20 7a 4f 70 20 3d 20 22  V_RETRY: zOp = "
4950: 57 49 4e 33 32 5f 41 56 5f 52 45 54 52 59 22 3b  WIN32_AV_RETRY";
4960: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61     break;.    ca
4970: 73 65 20 53 51 4c 49 54 45 5f 46 43 4e 54 4c 5f  se SQLITE_FCNTL_
4980: 50 45 52 53 49 53 54 5f 57 41 4c 3a 20 20 7a 4f  PERSIST_WAL:  zO
4990: 70 20 3d 20 22 50 45 52 53 49 53 54 5f 57 41 4c  p = "PERSIST_WAL
49a0: 22 3b 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b  ";        break;
49b0: 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54 45  .    case SQLITE
49c0: 5f 46 43 4e 54 4c 5f 4f 56 45 52 57 52 49 54 45  _FCNTL_OVERWRITE
49d0: 3a 20 20 20 20 7a 4f 70 20 3d 20 22 4f 56 45 52  :    zOp = "OVER
49e0: 57 52 49 54 45 22 3b 20 20 20 20 20 20 20 20 20  WRITE";         
49f0: 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65   break;.    case
4a00: 20 53 51 4c 49 54 45 5f 46 43 4e 54 4c 5f 56 46   SQLITE_FCNTL_VF
4a10: 53 4e 41 4d 45 3a 20 20 20 20 20 20 7a 4f 70 20  SNAME:      zOp 
4a20: 3d 20 22 56 46 53 4e 41 4d 45 22 3b 20 20 20 20  = "VFSNAME";    
4a30: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20          break;. 
4a40: 20 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f 46     case SQLITE_F
4a50: 43 4e 54 4c 5f 54 45 4d 50 46 49 4c 45 4e 41 4d  CNTL_TEMPFILENAM
4a60: 45 3a 20 7a 4f 70 20 3d 20 22 54 45 4d 50 46 49  E: zOp = "TEMPFI
4a70: 4c 45 4e 41 4d 45 22 3b 20 20 20 20 20 20 20 62  LENAME";       b
4a80: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 30  reak;.    case 0
4a90: 78 63 61 30 39 33 66 61 30 3a 20 20 20 20 20 20  xca093fa0:      
4aa0: 20 20 20 20 20 20 20 20 20 20 7a 4f 70 20 3d 20            zOp = 
4ab0: 22 44 42 5f 55 4e 43 48 41 4e 47 45 44 22 3b 20  "DB_UNCHANGED"; 
4ac0: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
4ad0: 20 63 61 73 65 20 53 51 4c 49 54 45 5f 46 43 4e   case SQLITE_FCN
4ae0: 54 4c 5f 50 52 41 47 4d 41 3a 20 7b 0a 20 20 20  TL_PRAGMA: {.   
4af0: 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 63     const char *c
4b00: 6f 6e 73 74 2a 20 61 20 3d 20 28 63 6f 6e 73 74  onst* a = (const
4b10: 20 63 68 61 72 2a 63 6f 6e 73 74 2a 29 70 41 72   char*const*)pAr
4b20: 67 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  g;.      sqlite3
4b30: 5f 73 6e 70 72 69 6e 74 66 28 73 69 7a 65 6f 66  _snprintf(sizeof
4b40: 28 7a 42 75 66 29 2c 20 7a 42 75 66 2c 20 22 50  (zBuf), zBuf, "P
4b50: 52 41 47 4d 41 2c 5b 25 73 2c 25 73 5d 22 2c 61  RAGMA,[%s,%s]",a
4b60: 5b 31 5d 2c 61 5b 32 5d 29 3b 0a 20 20 20 20 20  [1],a[2]);.     
4b70: 20 7a 4f 70 20 3d 20 7a 42 75 66 3b 0a 20 20 20   zOp = zBuf;.   
4b80: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 7d 0a     break;.    }.
4b90: 20 20 20 20 64 65 66 61 75 6c 74 3a 20 7b 0a 20      default: {. 
4ba0: 20 20 20 20 20 73 71 6c 69 74 65 33 5f 73 6e 70       sqlite3_snp
4bb0: 72 69 6e 74 66 28 73 69 7a 65 6f 66 20 7a 42 75  rintf(sizeof zBu
4bc0: 66 2c 20 7a 42 75 66 2c 20 22 25 64 22 2c 20 6f  f, zBuf, "%d", o
4bd0: 70 29 3b 0a 20 20 20 20 20 20 7a 4f 70 20 3d 20  p);.      zOp = 
4be0: 7a 42 75 66 3b 0a 20 20 20 20 20 20 62 72 65 61  zBuf;.      brea
4bf0: 6b 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 76  k;.    }.  }.  v
4c00: 66 73 74 72 61 63 65 5f 70 72 69 6e 74 66 28 70  fstrace_printf(p
4c10: 49 6e 66 6f 2c 20 22 25 73 2e 78 46 69 6c 65 43  Info, "%s.xFileC
4c20: 6f 6e 74 72 6f 6c 28 25 73 2c 25 73 29 22 2c 0a  ontrol(%s,%s)",.
4c30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4c40: 20 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d    pInfo->zVfsNam
4c50: 65 2c 20 70 2d 3e 7a 46 4e 61 6d 65 2c 20 7a 4f  e, p->zFName, zO
4c60: 70 29 3b 0a 20 20 72 63 20 3d 20 70 2d 3e 70 52  p);.  rc = p->pR
4c70: 65 61 6c 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78  eal->pMethods->x
4c80: 46 69 6c 65 43 6f 6e 74 72 6f 6c 28 70 2d 3e 70  FileControl(p->p
4c90: 52 65 61 6c 2c 20 6f 70 2c 20 70 41 72 67 29 3b  Real, op, pArg);
4ca0: 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e  .  vfstrace_prin
4cb0: 74 5f 65 72 72 63 6f 64 65 28 70 49 6e 66 6f 2c  t_errcode(pInfo,
4cc0: 20 22 20 2d 3e 20 25 73 5c 6e 22 2c 20 72 63 29   " -> %s\n", rc)
4cd0: 3b 0a 20 20 69 66 28 20 6f 70 3d 3d 53 51 4c 49  ;.  if( op==SQLI
4ce0: 54 45 5f 46 43 4e 54 4c 5f 56 46 53 4e 41 4d 45  TE_FCNTL_VFSNAME
4cf0: 20 26 26 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f   && rc==SQLITE_O
4d00: 4b 20 29 7b 0a 20 20 20 20 2a 28 63 68 61 72 2a  K ){.    *(char*
4d10: 2a 29 70 41 72 67 20 3d 20 73 71 6c 69 74 65 33  *)pArg = sqlite3
4d20: 5f 6d 70 72 69 6e 74 66 28 22 76 66 73 74 72 61  _mprintf("vfstra
4d30: 63 65 2e 25 73 2f 25 7a 22 2c 0a 20 20 20 20 20  ce.%s/%z",.     
4d40: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4d50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 70                 p
4d60: 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d 65 2c 20  Info->zVfsName, 
4d70: 2a 28 63 68 61 72 2a 2a 29 70 41 72 67 29 3b 0a  *(char**)pArg);.
4d80: 20 20 7d 0a 20 20 69 66 28 20 28 6f 70 3d 3d 53    }.  if( (op==S
4d90: 51 4c 49 54 45 5f 46 43 4e 54 4c 5f 50 52 41 47  QLITE_FCNTL_PRAG
4da0: 4d 41 20 7c 7c 20 6f 70 3d 3d 53 51 4c 49 54 45  MA || op==SQLITE
4db0: 5f 46 43 4e 54 4c 5f 54 45 4d 50 46 49 4c 45 4e  _FCNTL_TEMPFILEN
4dc0: 41 4d 45 29 0a 20 20 20 26 26 20 72 63 3d 3d 53  AME).   && rc==S
4dd0: 51 4c 49 54 45 5f 4f 4b 20 26 26 20 2a 28 63 68  QLITE_OK && *(ch
4de0: 61 72 2a 2a 29 70 41 72 67 20 29 7b 0a 20 20 20  ar**)pArg ){.   
4df0: 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74 66   vfstrace_printf
4e00: 28 70 49 6e 66 6f 2c 20 22 25 73 2e 78 46 69 6c  (pInfo, "%s.xFil
4e10: 65 43 6f 6e 74 72 6f 6c 28 25 73 2c 25 73 29 20  eControl(%s,%s) 
4e20: 72 65 74 75 72 6e 73 20 25 73 22 2c 0a 20 20 20  returns %s",.   
4e30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4e40: 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d 65   pInfo->zVfsName
4e50: 2c 20 70 2d 3e 7a 46 4e 61 6d 65 2c 20 7a 4f 70  , p->zFName, zOp
4e60: 2c 20 2a 28 63 68 61 72 2a 2a 29 70 41 72 67 29  , *(char**)pArg)
4e70: 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 72  ;.  }.  return r
4e80: 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75  c;.}../*.** Retu
4e90: 72 6e 20 74 68 65 20 73 65 63 74 6f 72 2d 73 69  rn the sector-si
4ea0: 7a 65 20 69 6e 20 62 79 74 65 73 20 66 6f 72 20  ze in bytes for 
4eb0: 61 6e 20 76 66 73 74 72 61 63 65 2d 66 69 6c 65  an vfstrace-file
4ec0: 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20  ..*/.static int 
4ed0: 76 66 73 74 72 61 63 65 53 65 63 74 6f 72 53 69  vfstraceSectorSi
4ee0: 7a 65 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20  ze(sqlite3_file 
4ef0: 2a 70 46 69 6c 65 29 7b 0a 20 20 76 66 73 74 72  *pFile){.  vfstr
4f00: 61 63 65 5f 66 69 6c 65 20 2a 70 20 3d 20 28 76  ace_file *p = (v
4f10: 66 73 74 72 61 63 65 5f 66 69 6c 65 20 2a 29 70  fstrace_file *)p
4f20: 46 69 6c 65 3b 0a 20 20 76 66 73 74 72 61 63 65  File;.  vfstrace
4f30: 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 70  _info *pInfo = p
4f40: 2d 3e 70 49 6e 66 6f 3b 0a 20 20 69 6e 74 20 72  ->pInfo;.  int r
4f50: 63 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72  c;.  vfstrace_pr
4f60: 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22 25 73 2e  intf(pInfo, "%s.
4f70: 78 53 65 63 74 6f 72 53 69 7a 65 28 25 73 29 22  xSectorSize(%s)"
4f80: 2c 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d  , pInfo->zVfsNam
4f90: 65 2c 20 70 2d 3e 7a 46 4e 61 6d 65 29 3b 0a 20  e, p->zFName);. 
4fa0: 20 72 63 20 3d 20 70 2d 3e 70 52 65 61 6c 2d 3e   rc = p->pReal->
4fb0: 70 4d 65 74 68 6f 64 73 2d 3e 78 53 65 63 74 6f  pMethods->xSecto
4fc0: 72 53 69 7a 65 28 70 2d 3e 70 52 65 61 6c 29 3b  rSize(p->pReal);
4fd0: 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e  .  vfstrace_prin
4fe0: 74 66 28 70 49 6e 66 6f 2c 20 22 20 2d 3e 20 25  tf(pInfo, " -> %
4ff0: 64 5c 6e 22 2c 20 72 63 29 3b 0a 20 20 72 65 74  d\n", rc);.  ret
5000: 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  urn rc;.}../*.**
5010: 20 52 65 74 75 72 6e 20 74 68 65 20 64 65 76 69   Return the devi
5020: 63 65 20 63 68 61 72 61 63 74 65 72 69 73 74 69  ce characteristi
5030: 63 20 66 6c 61 67 73 20 73 75 70 70 6f 72 74 65  c flags supporte
5040: 64 20 62 79 20 61 6e 20 76 66 73 74 72 61 63 65  d by an vfstrace
5050: 2d 66 69 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63  -file..*/.static
5060: 20 69 6e 74 20 76 66 73 74 72 61 63 65 44 65 76   int vfstraceDev
5070: 69 63 65 43 68 61 72 61 63 74 65 72 69 73 74 69  iceCharacteristi
5080: 63 73 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20  cs(sqlite3_file 
5090: 2a 70 46 69 6c 65 29 7b 0a 20 20 76 66 73 74 72  *pFile){.  vfstr
50a0: 61 63 65 5f 66 69 6c 65 20 2a 70 20 3d 20 28 76  ace_file *p = (v
50b0: 66 73 74 72 61 63 65 5f 66 69 6c 65 20 2a 29 70  fstrace_file *)p
50c0: 46 69 6c 65 3b 0a 20 20 76 66 73 74 72 61 63 65  File;.  vfstrace
50d0: 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 70  _info *pInfo = p
50e0: 2d 3e 70 49 6e 66 6f 3b 0a 20 20 69 6e 74 20 72  ->pInfo;.  int r
50f0: 63 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72  c;.  vfstrace_pr
5100: 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22 25 73 2e  intf(pInfo, "%s.
5110: 78 44 65 76 69 63 65 43 68 61 72 61 63 74 65 72  xDeviceCharacter
5120: 69 73 74 69 63 73 28 25 73 29 22 2c 0a 20 20 20  istics(%s)",.   
5130: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 70                 p
5140: 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d 65 2c 20  Info->zVfsName, 
5150: 70 2d 3e 7a 46 4e 61 6d 65 29 3b 0a 20 20 72 63  p->zFName);.  rc
5160: 20 3d 20 70 2d 3e 70 52 65 61 6c 2d 3e 70 4d 65   = p->pReal->pMe
5170: 74 68 6f 64 73 2d 3e 78 44 65 76 69 63 65 43 68  thods->xDeviceCh
5180: 61 72 61 63 74 65 72 69 73 74 69 63 73 28 70 2d  aracteristics(p-
5190: 3e 70 52 65 61 6c 29 3b 0a 20 20 76 66 73 74 72  >pReal);.  vfstr
51a0: 61 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f  ace_printf(pInfo
51b0: 2c 20 22 20 2d 3e 20 30 78 25 30 38 78 5c 6e 22  , " -> 0x%08x\n"
51c0: 2c 20 72 63 29 3b 0a 20 20 72 65 74 75 72 6e 20  , rc);.  return 
51d0: 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 53 68 61  rc;.}../*.** Sha
51e0: 72 65 64 2d 6d 65 6d 6f 72 79 20 6f 70 65 72 61  red-memory opera
51f0: 74 69 6f 6e 73 2e 0a 2a 2f 0a 73 74 61 74 69 63  tions..*/.static
5200: 20 69 6e 74 20 76 66 73 74 72 61 63 65 53 68 6d   int vfstraceShm
5210: 4c 6f 63 6b 28 73 71 6c 69 74 65 33 5f 66 69 6c  Lock(sqlite3_fil
5220: 65 20 2a 70 46 69 6c 65 2c 20 69 6e 74 20 6f 66  e *pFile, int of
5230: 73 74 2c 20 69 6e 74 20 6e 2c 20 69 6e 74 20 66  st, int n, int f
5240: 6c 61 67 73 29 7b 0a 20 20 76 66 73 74 72 61 63  lags){.  vfstrac
5250: 65 5f 66 69 6c 65 20 2a 70 20 3d 20 28 76 66 73  e_file *p = (vfs
5260: 74 72 61 63 65 5f 66 69 6c 65 20 2a 29 70 46 69  trace_file *)pFi
5270: 6c 65 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 69  le;.  vfstrace_i
5280: 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 70 2d 3e  nfo *pInfo = p->
5290: 70 49 6e 66 6f 3b 0a 20 20 69 6e 74 20 72 63 3b  pInfo;.  int rc;
52a0: 0a 20 20 63 68 61 72 20 7a 4c 63 6b 5b 31 30 30  .  char zLck[100
52b0: 5d 3b 0a 20 20 69 6e 74 20 69 20 3d 20 30 3b 0a  ];.  int i = 0;.
52c0: 20 20 6d 65 6d 63 70 79 28 7a 4c 63 6b 2c 20 22    memcpy(zLck, "
52d0: 7c 30 22 2c 20 33 29 3b 0a 20 20 69 66 28 20 66  |0", 3);.  if( f
52e0: 6c 61 67 73 20 26 20 53 51 4c 49 54 45 5f 53 48  lags & SQLITE_SH
52f0: 4d 5f 55 4e 4c 4f 43 4b 20 29 20 20 20 20 73 74  M_UNLOCK )    st
5300: 72 61 70 70 65 6e 64 28 7a 4c 63 6b 2c 20 26 69  rappend(zLck, &i
5310: 2c 20 22 7c 55 4e 4c 4f 43 4b 22 29 3b 0a 20 20  , "|UNLOCK");.  
5320: 69 66 28 20 66 6c 61 67 73 20 26 20 53 51 4c 49  if( flags & SQLI
5330: 54 45 5f 53 48 4d 5f 4c 4f 43 4b 20 29 20 20 20  TE_SHM_LOCK )   
5340: 20 20 20 73 74 72 61 70 70 65 6e 64 28 7a 4c 63     strappend(zLc
5350: 6b 2c 20 26 69 2c 20 22 7c 4c 4f 43 4b 22 29 3b  k, &i, "|LOCK");
5360: 0a 20 20 69 66 28 20 66 6c 61 67 73 20 26 20 53  .  if( flags & S
5370: 51 4c 49 54 45 5f 53 48 4d 5f 53 48 41 52 45 44  QLITE_SHM_SHARED
5380: 20 29 20 20 20 20 73 74 72 61 70 70 65 6e 64 28   )    strappend(
5390: 7a 4c 63 6b 2c 20 26 69 2c 20 22 7c 53 48 41 52  zLck, &i, "|SHAR
53a0: 45 44 22 29 3b 0a 20 20 69 66 28 20 66 6c 61 67  ED");.  if( flag
53b0: 73 20 26 20 53 51 4c 49 54 45 5f 53 48 4d 5f 45  s & SQLITE_SHM_E
53c0: 58 43 4c 55 53 49 56 45 20 29 20 73 74 72 61 70  XCLUSIVE ) strap
53d0: 70 65 6e 64 28 7a 4c 63 6b 2c 20 26 69 2c 20 22  pend(zLck, &i, "
53e0: 7c 45 58 43 4c 55 53 49 56 45 22 29 3b 0a 20 20  |EXCLUSIVE");.  
53f0: 69 66 28 20 66 6c 61 67 73 20 26 20 7e 28 30 78  if( flags & ~(0x
5400: 66 29 20 29 7b 0a 20 20 20 20 20 73 71 6c 69 74  f) ){.     sqlit
5410: 65 33 5f 73 6e 70 72 69 6e 74 66 28 73 69 7a 65  e3_snprintf(size
5420: 6f 66 28 7a 4c 63 6b 29 2d 69 2c 20 26 7a 4c 63  of(zLck)-i, &zLc
5430: 6b 5b 69 5d 2c 20 22 7c 30 78 25 78 22 2c 20 66  k[i], "|0x%x", f
5440: 6c 61 67 73 29 3b 0a 20 20 7d 0a 20 20 76 66 73  lags);.  }.  vfs
5450: 74 72 61 63 65 5f 70 72 69 6e 74 66 28 70 49 6e  trace_printf(pIn
5460: 66 6f 2c 20 22 25 73 2e 78 53 68 6d 4c 6f 63 6b  fo, "%s.xShmLock
5470: 28 25 73 2c 6f 66 73 74 3d 25 64 2c 6e 3d 25 64  (%s,ofst=%d,n=%d
5480: 2c 25 73 29 22 2c 0a 20 20 20 20 20 20 20 20 20  ,%s)",.         
5490: 20 20 20 20 20 20 20 20 20 70 49 6e 66 6f 2d 3e           pInfo->
54a0: 7a 56 66 73 4e 61 6d 65 2c 20 70 2d 3e 7a 46 4e  zVfsName, p->zFN
54b0: 61 6d 65 2c 20 6f 66 73 74 2c 20 6e 2c 20 26 7a  ame, ofst, n, &z
54c0: 4c 63 6b 5b 31 5d 29 3b 0a 20 20 72 63 20 3d 20  Lck[1]);.  rc = 
54d0: 70 2d 3e 70 52 65 61 6c 2d 3e 70 4d 65 74 68 6f  p->pReal->pMetho
54e0: 64 73 2d 3e 78 53 68 6d 4c 6f 63 6b 28 70 2d 3e  ds->xShmLock(p->
54f0: 70 52 65 61 6c 2c 20 6f 66 73 74 2c 20 6e 2c 20  pReal, ofst, n, 
5500: 66 6c 61 67 73 29 3b 0a 20 20 76 66 73 74 72 61  flags);.  vfstra
5510: 63 65 5f 70 72 69 6e 74 5f 65 72 72 63 6f 64 65  ce_print_errcode
5520: 28 70 49 6e 66 6f 2c 20 22 20 2d 3e 20 25 73 5c  (pInfo, " -> %s\
5530: 6e 22 2c 20 72 63 29 3b 0a 20 20 72 65 74 75 72  n", rc);.  retur
5540: 6e 20 72 63 3b 0a 7d 0a 73 74 61 74 69 63 20 69  n rc;.}.static i
5550: 6e 74 20 76 66 73 74 72 61 63 65 53 68 6d 4d 61  nt vfstraceShmMa
5560: 70 28 0a 20 20 73 71 6c 69 74 65 33 5f 66 69 6c  p(.  sqlite3_fil
5570: 65 20 2a 70 46 69 6c 65 2c 20 0a 20 20 69 6e 74  e *pFile, .  int
5580: 20 69 52 65 67 69 6f 6e 2c 20 0a 20 20 69 6e 74   iRegion, .  int
5590: 20 73 7a 52 65 67 69 6f 6e 2c 20 0a 20 20 69 6e   szRegion, .  in
55a0: 74 20 69 73 57 72 69 74 65 2c 20 0a 20 20 76 6f  t isWrite, .  vo
55b0: 69 64 20 76 6f 6c 61 74 69 6c 65 20 2a 2a 70 70  id volatile **pp
55c0: 0a 29 7b 0a 20 20 76 66 73 74 72 61 63 65 5f 66  .){.  vfstrace_f
55d0: 69 6c 65 20 2a 70 20 3d 20 28 76 66 73 74 72 61  ile *p = (vfstra
55e0: 63 65 5f 66 69 6c 65 20 2a 29 70 46 69 6c 65 3b  ce_file *)pFile;
55f0: 0a 20 20 76 66 73 74 72 61 63 65 5f 69 6e 66 6f  .  vfstrace_info
5600: 20 2a 70 49 6e 66 6f 20 3d 20 70 2d 3e 70 49 6e   *pInfo = p->pIn
5610: 66 6f 3b 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20  fo;.  int rc;.  
5620: 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74 66 28  vfstrace_printf(
5630: 70 49 6e 66 6f 2c 20 22 25 73 2e 78 53 68 6d 4d  pInfo, "%s.xShmM
5640: 61 70 28 25 73 2c 69 52 65 67 69 6f 6e 3d 25 64  ap(%s,iRegion=%d
5650: 2c 73 7a 52 65 67 69 6f 6e 3d 25 64 2c 69 73 57  ,szRegion=%d,isW
5660: 72 69 74 65 3d 25 64 2c 2a 29 22 2c 0a 20 20 20  rite=%d,*)",.   
5670: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 70                 p
5680: 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d 65 2c 20  Info->zVfsName, 
5690: 70 2d 3e 7a 46 4e 61 6d 65 2c 20 69 52 65 67 69  p->zFName, iRegi
56a0: 6f 6e 2c 20 73 7a 52 65 67 69 6f 6e 2c 20 69 73  on, szRegion, is
56b0: 57 72 69 74 65 29 3b 0a 20 20 72 63 20 3d 20 70  Write);.  rc = p
56c0: 2d 3e 70 52 65 61 6c 2d 3e 70 4d 65 74 68 6f 64  ->pReal->pMethod
56d0: 73 2d 3e 78 53 68 6d 4d 61 70 28 70 2d 3e 70 52  s->xShmMap(p->pR
56e0: 65 61 6c 2c 20 69 52 65 67 69 6f 6e 2c 20 73 7a  eal, iRegion, sz
56f0: 52 65 67 69 6f 6e 2c 20 69 73 57 72 69 74 65 2c  Region, isWrite,
5700: 20 70 70 29 3b 0a 20 20 76 66 73 74 72 61 63 65   pp);.  vfstrace
5710: 5f 70 72 69 6e 74 5f 65 72 72 63 6f 64 65 28 70  _print_errcode(p
5720: 49 6e 66 6f 2c 20 22 20 2d 3e 20 25 73 5c 6e 22  Info, " -> %s\n"
5730: 2c 20 72 63 29 3b 0a 20 20 72 65 74 75 72 6e 20  , rc);.  return 
5740: 72 63 3b 0a 7d 0a 73 74 61 74 69 63 20 76 6f 69  rc;.}.static voi
5750: 64 20 76 66 73 74 72 61 63 65 53 68 6d 42 61 72  d vfstraceShmBar
5760: 72 69 65 72 28 73 71 6c 69 74 65 33 5f 66 69 6c  rier(sqlite3_fil
5770: 65 20 2a 70 46 69 6c 65 29 7b 0a 20 20 76 66 73  e *pFile){.  vfs
5780: 74 72 61 63 65 5f 66 69 6c 65 20 2a 70 20 3d 20  trace_file *p = 
5790: 28 76 66 73 74 72 61 63 65 5f 66 69 6c 65 20 2a  (vfstrace_file *
57a0: 29 70 46 69 6c 65 3b 0a 20 20 76 66 73 74 72 61  )pFile;.  vfstra
57b0: 63 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d  ce_info *pInfo =
57c0: 20 70 2d 3e 70 49 6e 66 6f 3b 0a 20 20 76 66 73   p->pInfo;.  vfs
57d0: 74 72 61 63 65 5f 70 72 69 6e 74 66 28 70 49 6e  trace_printf(pIn
57e0: 66 6f 2c 20 22 25 73 2e 78 53 68 6d 42 61 72 72  fo, "%s.xShmBarr
57f0: 69 65 72 28 25 73 29 5c 6e 22 2c 20 70 49 6e 66  ier(%s)\n", pInf
5800: 6f 2d 3e 7a 56 66 73 4e 61 6d 65 2c 20 70 2d 3e  o->zVfsName, p->
5810: 7a 46 4e 61 6d 65 29 3b 0a 20 20 70 2d 3e 70 52  zFName);.  p->pR
5820: 65 61 6c 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78  eal->pMethods->x
5830: 53 68 6d 42 61 72 72 69 65 72 28 70 2d 3e 70 52  ShmBarrier(p->pR
5840: 65 61 6c 29 3b 0a 7d 0a 73 74 61 74 69 63 20 69  eal);.}.static i
5850: 6e 74 20 76 66 73 74 72 61 63 65 53 68 6d 55 6e  nt vfstraceShmUn
5860: 6d 61 70 28 73 71 6c 69 74 65 33 5f 66 69 6c 65  map(sqlite3_file
5870: 20 2a 70 46 69 6c 65 2c 20 69 6e 74 20 64 65 6c   *pFile, int del
5880: 46 6c 61 67 29 7b 0a 20 20 76 66 73 74 72 61 63  Flag){.  vfstrac
5890: 65 5f 66 69 6c 65 20 2a 70 20 3d 20 28 76 66 73  e_file *p = (vfs
58a0: 74 72 61 63 65 5f 66 69 6c 65 20 2a 29 70 46 69  trace_file *)pFi
58b0: 6c 65 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 69  le;.  vfstrace_i
58c0: 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 70 2d 3e  nfo *pInfo = p->
58d0: 70 49 6e 66 6f 3b 0a 20 20 69 6e 74 20 72 63 3b  pInfo;.  int rc;
58e0: 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e  .  vfstrace_prin
58f0: 74 66 28 70 49 6e 66 6f 2c 20 22 25 73 2e 78 53  tf(pInfo, "%s.xS
5900: 68 6d 55 6e 6d 61 70 28 25 73 2c 64 65 6c 46 6c  hmUnmap(%s,delFl
5910: 61 67 3d 25 64 29 22 2c 0a 20 20 20 20 20 20 20  ag=%d)",.       
5920: 20 20 20 20 20 20 20 20 20 20 20 70 49 6e 66 6f             pInfo
5930: 2d 3e 7a 56 66 73 4e 61 6d 65 2c 20 70 2d 3e 7a  ->zVfsName, p->z
5940: 46 4e 61 6d 65 2c 20 64 65 6c 46 6c 61 67 29 3b  FName, delFlag);
5950: 0a 20 20 72 63 20 3d 20 70 2d 3e 70 52 65 61 6c  .  rc = p->pReal
5960: 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 53 68 6d  ->pMethods->xShm
5970: 55 6e 6d 61 70 28 70 2d 3e 70 52 65 61 6c 2c 20  Unmap(p->pReal, 
5980: 64 65 6c 46 6c 61 67 29 3b 0a 20 20 76 66 73 74  delFlag);.  vfst
5990: 72 61 63 65 5f 70 72 69 6e 74 5f 65 72 72 63 6f  race_print_errco
59a0: 64 65 28 70 49 6e 66 6f 2c 20 22 20 2d 3e 20 25  de(pInfo, " -> %
59b0: 73 5c 6e 22 2c 20 72 63 29 3b 0a 20 20 72 65 74  s\n", rc);.  ret
59c0: 75 72 6e 20 72 63 3b 0a 7d 0a 0a 0a 0a 2f 2a 0a  urn rc;.}..../*.
59d0: 2a 2a 20 4f 70 65 6e 20 61 6e 20 76 66 73 74 72  ** Open an vfstr
59e0: 61 63 65 20 66 69 6c 65 20 68 61 6e 64 6c 65 2e  ace file handle.
59f0: 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 76  .*/.static int v
5a00: 66 73 74 72 61 63 65 4f 70 65 6e 28 0a 20 20 73  fstraceOpen(.  s
5a10: 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73  qlite3_vfs *pVfs
5a20: 2c 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  ,.  const char *
5a30: 7a 4e 61 6d 65 2c 0a 20 20 73 71 6c 69 74 65 33  zName,.  sqlite3
5a40: 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c 0a 20 20  _file *pFile,.  
5a50: 69 6e 74 20 66 6c 61 67 73 2c 0a 20 20 69 6e 74  int flags,.  int
5a60: 20 2a 70 4f 75 74 46 6c 61 67 73 0a 29 7b 0a 20   *pOutFlags.){. 
5a70: 20 69 6e 74 20 72 63 3b 0a 20 20 76 66 73 74 72   int rc;.  vfstr
5a80: 61 63 65 5f 66 69 6c 65 20 2a 70 20 3d 20 28 76  ace_file *p = (v
5a90: 66 73 74 72 61 63 65 5f 66 69 6c 65 20 2a 29 70  fstrace_file *)p
5aa0: 46 69 6c 65 3b 0a 20 20 76 66 73 74 72 61 63 65  File;.  vfstrace
5ab0: 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 28  _info *pInfo = (
5ac0: 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 2a 29 70  vfstrace_info*)p
5ad0: 56 66 73 2d 3e 70 41 70 70 44 61 74 61 3b 0a 20  Vfs->pAppData;. 
5ae0: 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 52   sqlite3_vfs *pR
5af0: 6f 6f 74 20 3d 20 70 49 6e 66 6f 2d 3e 70 52 6f  oot = pInfo->pRo
5b00: 6f 74 56 66 73 3b 0a 20 20 70 2d 3e 70 49 6e 66  otVfs;.  p->pInf
5b10: 6f 20 3d 20 70 49 6e 66 6f 3b 0a 20 20 70 2d 3e  o = pInfo;.  p->
5b20: 7a 46 4e 61 6d 65 20 3d 20 7a 4e 61 6d 65 20 3f  zFName = zName ?
5b30: 20 66 69 6c 65 54 61 69 6c 28 7a 4e 61 6d 65 29   fileTail(zName)
5b40: 20 3a 20 22 3c 74 65 6d 70 3e 22 3b 0a 20 20 70   : "<temp>";.  p
5b50: 2d 3e 70 52 65 61 6c 20 3d 20 28 73 71 6c 69 74  ->pReal = (sqlit
5b60: 65 33 5f 66 69 6c 65 20 2a 29 26 70 5b 31 5d 3b  e3_file *)&p[1];
5b70: 0a 20 20 72 63 20 3d 20 70 52 6f 6f 74 2d 3e 78  .  rc = pRoot->x
5b80: 4f 70 65 6e 28 70 52 6f 6f 74 2c 20 7a 4e 61 6d  Open(pRoot, zNam
5b90: 65 2c 20 70 2d 3e 70 52 65 61 6c 2c 20 66 6c 61  e, p->pReal, fla
5ba0: 67 73 2c 20 70 4f 75 74 46 6c 61 67 73 29 3b 0a  gs, pOutFlags);.
5bb0: 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74    vfstrace_print
5bc0: 66 28 70 49 6e 66 6f 2c 20 22 25 73 2e 78 4f 70  f(pInfo, "%s.xOp
5bd0: 65 6e 28 25 73 2c 66 6c 61 67 73 3d 30 78 25 78  en(%s,flags=0x%x
5be0: 29 22 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20  )",.            
5bf0: 20 20 20 20 20 20 70 49 6e 66 6f 2d 3e 7a 56 66        pInfo->zVf
5c00: 73 4e 61 6d 65 2c 20 70 2d 3e 7a 46 4e 61 6d 65  sName, p->zFName
5c10: 2c 20 66 6c 61 67 73 29 3b 0a 20 20 69 66 28 20  , flags);.  if( 
5c20: 70 2d 3e 70 52 65 61 6c 2d 3e 70 4d 65 74 68 6f  p->pReal->pMetho
5c30: 64 73 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65  ds ){.    sqlite
5c40: 33 5f 69 6f 5f 6d 65 74 68 6f 64 73 20 2a 70 4e  3_io_methods *pN
5c50: 65 77 20 3d 20 73 71 6c 69 74 65 33 5f 6d 61 6c  ew = sqlite3_mal
5c60: 6c 6f 63 28 20 73 69 7a 65 6f 66 28 2a 70 4e 65  loc( sizeof(*pNe
5c70: 77 29 20 29 3b 0a 20 20 20 20 63 6f 6e 73 74 20  w) );.    const 
5c80: 73 71 6c 69 74 65 33 5f 69 6f 5f 6d 65 74 68 6f  sqlite3_io_metho
5c90: 64 73 20 2a 70 53 75 62 20 3d 20 70 2d 3e 70 52  ds *pSub = p->pR
5ca0: 65 61 6c 2d 3e 70 4d 65 74 68 6f 64 73 3b 0a 20  eal->pMethods;. 
5cb0: 20 20 20 6d 65 6d 73 65 74 28 70 4e 65 77 2c 20     memset(pNew, 
5cc0: 30 2c 20 73 69 7a 65 6f 66 28 2a 70 4e 65 77 29  0, sizeof(*pNew)
5cd0: 29 3b 0a 20 20 20 20 70 4e 65 77 2d 3e 69 56 65  );.    pNew->iVe
5ce0: 72 73 69 6f 6e 20 3d 20 70 53 75 62 2d 3e 69 56  rsion = pSub->iV
5cf0: 65 72 73 69 6f 6e 3b 0a 20 20 20 20 70 4e 65 77  ersion;.    pNew
5d00: 2d 3e 78 43 6c 6f 73 65 20 3d 20 76 66 73 74 72  ->xClose = vfstr
5d10: 61 63 65 43 6c 6f 73 65 3b 0a 20 20 20 20 70 4e  aceClose;.    pN
5d20: 65 77 2d 3e 78 52 65 61 64 20 3d 20 76 66 73 74  ew->xRead = vfst
5d30: 72 61 63 65 52 65 61 64 3b 0a 20 20 20 20 70 4e  raceRead;.    pN
5d40: 65 77 2d 3e 78 57 72 69 74 65 20 3d 20 76 66 73  ew->xWrite = vfs
5d50: 74 72 61 63 65 57 72 69 74 65 3b 0a 20 20 20 20  traceWrite;.    
5d60: 70 4e 65 77 2d 3e 78 54 72 75 6e 63 61 74 65 20  pNew->xTruncate 
5d70: 3d 20 76 66 73 74 72 61 63 65 54 72 75 6e 63 61  = vfstraceTrunca
5d80: 74 65 3b 0a 20 20 20 20 70 4e 65 77 2d 3e 78 53  te;.    pNew->xS
5d90: 79 6e 63 20 3d 20 76 66 73 74 72 61 63 65 53 79  ync = vfstraceSy
5da0: 6e 63 3b 0a 20 20 20 20 70 4e 65 77 2d 3e 78 46  nc;.    pNew->xF
5db0: 69 6c 65 53 69 7a 65 20 3d 20 76 66 73 74 72 61  ileSize = vfstra
5dc0: 63 65 46 69 6c 65 53 69 7a 65 3b 0a 20 20 20 20  ceFileSize;.    
5dd0: 70 4e 65 77 2d 3e 78 4c 6f 63 6b 20 3d 20 76 66  pNew->xLock = vf
5de0: 73 74 72 61 63 65 4c 6f 63 6b 3b 0a 20 20 20 20  straceLock;.    
5df0: 70 4e 65 77 2d 3e 78 55 6e 6c 6f 63 6b 20 3d 20  pNew->xUnlock = 
5e00: 76 66 73 74 72 61 63 65 55 6e 6c 6f 63 6b 3b 0a  vfstraceUnlock;.
5e10: 20 20 20 20 70 4e 65 77 2d 3e 78 43 68 65 63 6b      pNew->xCheck
5e20: 52 65 73 65 72 76 65 64 4c 6f 63 6b 20 3d 20 76  ReservedLock = v
5e30: 66 73 74 72 61 63 65 43 68 65 63 6b 52 65 73 65  fstraceCheckRese
5e40: 72 76 65 64 4c 6f 63 6b 3b 0a 20 20 20 20 70 4e  rvedLock;.    pN
5e50: 65 77 2d 3e 78 46 69 6c 65 43 6f 6e 74 72 6f 6c  ew->xFileControl
5e60: 20 3d 20 76 66 73 74 72 61 63 65 46 69 6c 65 43   = vfstraceFileC
5e70: 6f 6e 74 72 6f 6c 3b 0a 20 20 20 20 70 4e 65 77  ontrol;.    pNew
5e80: 2d 3e 78 53 65 63 74 6f 72 53 69 7a 65 20 3d 20  ->xSectorSize = 
5e90: 76 66 73 74 72 61 63 65 53 65 63 74 6f 72 53 69  vfstraceSectorSi
5ea0: 7a 65 3b 0a 20 20 20 20 70 4e 65 77 2d 3e 78 44  ze;.    pNew->xD
5eb0: 65 76 69 63 65 43 68 61 72 61 63 74 65 72 69 73  eviceCharacteris
5ec0: 74 69 63 73 20 3d 20 76 66 73 74 72 61 63 65 44  tics = vfstraceD
5ed0: 65 76 69 63 65 43 68 61 72 61 63 74 65 72 69 73  eviceCharacteris
5ee0: 74 69 63 73 3b 0a 20 20 20 20 69 66 28 20 70 4e  tics;.    if( pN
5ef0: 65 77 2d 3e 69 56 65 72 73 69 6f 6e 3e 3d 32 20  ew->iVersion>=2 
5f00: 29 7b 0a 20 20 20 20 20 20 70 4e 65 77 2d 3e 78  ){.      pNew->x
5f10: 53 68 6d 4d 61 70 20 3d 20 70 53 75 62 2d 3e 78  ShmMap = pSub->x
5f20: 53 68 6d 4d 61 70 20 3f 20 76 66 73 74 72 61 63  ShmMap ? vfstrac
5f30: 65 53 68 6d 4d 61 70 20 3a 20 30 3b 0a 20 20 20  eShmMap : 0;.   
5f40: 20 20 20 70 4e 65 77 2d 3e 78 53 68 6d 4c 6f 63     pNew->xShmLoc
5f50: 6b 20 3d 20 70 53 75 62 2d 3e 78 53 68 6d 4c 6f  k = pSub->xShmLo
5f60: 63 6b 20 3f 20 76 66 73 74 72 61 63 65 53 68 6d  ck ? vfstraceShm
5f70: 4c 6f 63 6b 20 3a 20 30 3b 0a 20 20 20 20 20 20  Lock : 0;.      
5f80: 70 4e 65 77 2d 3e 78 53 68 6d 42 61 72 72 69 65  pNew->xShmBarrie
5f90: 72 20 3d 20 70 53 75 62 2d 3e 78 53 68 6d 42 61  r = pSub->xShmBa
5fa0: 72 72 69 65 72 20 3f 20 76 66 73 74 72 61 63 65  rrier ? vfstrace
5fb0: 53 68 6d 42 61 72 72 69 65 72 20 3a 20 30 3b 0a  ShmBarrier : 0;.
5fc0: 20 20 20 20 20 20 70 4e 65 77 2d 3e 78 53 68 6d        pNew->xShm
5fd0: 55 6e 6d 61 70 20 3d 20 70 53 75 62 2d 3e 78 53  Unmap = pSub->xS
5fe0: 68 6d 55 6e 6d 61 70 20 3f 20 76 66 73 74 72 61  hmUnmap ? vfstra
5ff0: 63 65 53 68 6d 55 6e 6d 61 70 20 3a 20 30 3b 0a  ceShmUnmap : 0;.
6000: 20 20 20 20 7d 0a 20 20 20 20 70 46 69 6c 65 2d      }.    pFile-
6010: 3e 70 4d 65 74 68 6f 64 73 20 3d 20 70 4e 65 77  >pMethods = pNew
6020: 3b 0a 20 20 7d 0a 20 20 76 66 73 74 72 61 63 65  ;.  }.  vfstrace
6030: 5f 70 72 69 6e 74 5f 65 72 72 63 6f 64 65 28 70  _print_errcode(p
6040: 49 6e 66 6f 2c 20 22 20 2d 3e 20 25 73 22 2c 20  Info, " -> %s", 
6050: 72 63 29 3b 0a 20 20 69 66 28 20 70 4f 75 74 46  rc);.  if( pOutF
6060: 6c 61 67 73 20 29 7b 0a 20 20 20 20 76 66 73 74  lags ){.    vfst
6070: 72 61 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66  race_printf(pInf
6080: 6f 2c 20 22 2c 20 6f 75 74 46 6c 61 67 73 3d 30  o, ", outFlags=0
6090: 78 25 78 5c 6e 22 2c 20 2a 70 4f 75 74 46 6c 61  x%x\n", *pOutFla
60a0: 67 73 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20  gs);.  }else{.  
60b0: 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74    vfstrace_print
60c0: 66 28 70 49 6e 66 6f 2c 20 22 5c 6e 22 29 3b 0a  f(pInfo, "\n");.
60d0: 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 72 63 3b    }.  return rc;
60e0: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 44 65 6c 65 74 65  .}../*.** Delete
60f0: 20 74 68 65 20 66 69 6c 65 20 6c 6f 63 61 74 65   the file locate
6100: 64 20 61 74 20 7a 50 61 74 68 2e 20 49 66 20 74  d at zPath. If t
6110: 68 65 20 64 69 72 53 79 6e 63 20 61 72 67 75 6d  he dirSync argum
6120: 65 6e 74 20 69 73 20 74 72 75 65 2c 0a 2a 2a 20  ent is true,.** 
6130: 65 6e 73 75 72 65 20 74 68 65 20 66 69 6c 65 2d  ensure the file-
6140: 73 79 73 74 65 6d 20 6d 6f 64 69 66 69 63 61 74  system modificat
6150: 69 6f 6e 73 20 61 72 65 20 73 79 6e 63 65 64 20  ions are synced 
6160: 74 6f 20 64 69 73 6b 20 62 65 66 6f 72 65 0a 2a  to disk before.*
6170: 2a 20 72 65 74 75 72 6e 69 6e 67 2e 0a 2a 2f 0a  * returning..*/.
6180: 73 74 61 74 69 63 20 69 6e 74 20 76 66 73 74 72  static int vfstr
6190: 61 63 65 44 65 6c 65 74 65 28 73 71 6c 69 74 65  aceDelete(sqlite
61a0: 33 5f 76 66 73 20 2a 70 56 66 73 2c 20 63 6f 6e  3_vfs *pVfs, con
61b0: 73 74 20 63 68 61 72 20 2a 7a 50 61 74 68 2c 20  st char *zPath, 
61c0: 69 6e 74 20 64 69 72 53 79 6e 63 29 7b 0a 20 20  int dirSync){.  
61d0: 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70  vfstrace_info *p
61e0: 49 6e 66 6f 20 3d 20 28 76 66 73 74 72 61 63 65  Info = (vfstrace
61f0: 5f 69 6e 66 6f 2a 29 70 56 66 73 2d 3e 70 41 70  _info*)pVfs->pAp
6200: 70 44 61 74 61 3b 0a 20 20 73 71 6c 69 74 65 33  pData;.  sqlite3
6210: 5f 76 66 73 20 2a 70 52 6f 6f 74 20 3d 20 70 49  _vfs *pRoot = pI
6220: 6e 66 6f 2d 3e 70 52 6f 6f 74 56 66 73 3b 0a 20  nfo->pRootVfs;. 
6230: 20 69 6e 74 20 72 63 3b 0a 20 20 76 66 73 74 72   int rc;.  vfstr
6240: 61 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f  ace_printf(pInfo
6250: 2c 20 22 25 73 2e 78 44 65 6c 65 74 65 28 5c 22  , "%s.xDelete(\"
6260: 25 73 5c 22 2c 25 64 29 22 2c 0a 20 20 20 20 20  %s\",%d)",.     
6270: 20 20 20 20 20 20 20 20 20 20 20 20 20 70 49 6e               pIn
6280: 66 6f 2d 3e 7a 56 66 73 4e 61 6d 65 2c 20 7a 50  fo->zVfsName, zP
6290: 61 74 68 2c 20 64 69 72 53 79 6e 63 29 3b 0a 20  ath, dirSync);. 
62a0: 20 72 63 20 3d 20 70 52 6f 6f 74 2d 3e 78 44 65   rc = pRoot->xDe
62b0: 6c 65 74 65 28 70 52 6f 6f 74 2c 20 7a 50 61 74  lete(pRoot, zPat
62c0: 68 2c 20 64 69 72 53 79 6e 63 29 3b 0a 20 20 76  h, dirSync);.  v
62d0: 66 73 74 72 61 63 65 5f 70 72 69 6e 74 5f 65 72  fstrace_print_er
62e0: 72 63 6f 64 65 28 70 49 6e 66 6f 2c 20 22 20 2d  rcode(pInfo, " -
62f0: 3e 20 25 73 5c 6e 22 2c 20 72 63 29 3b 0a 20 20  > %s\n", rc);.  
6300: 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a  return rc;.}../*
6310: 0a 2a 2a 20 54 65 73 74 20 66 6f 72 20 61 63 63  .** Test for acc
6320: 65 73 73 20 70 65 72 6d 69 73 73 69 6f 6e 73 2e  ess permissions.
6330: 20 52 65 74 75 72 6e 20 74 72 75 65 20 69 66 20   Return true if 
6340: 74 68 65 20 72 65 71 75 65 73 74 65 64 20 70 65  the requested pe
6350: 72 6d 69 73 73 69 6f 6e 0a 2a 2a 20 69 73 20 61  rmission.** is a
6360: 76 61 69 6c 61 62 6c 65 2c 20 6f 72 20 66 61 6c  vailable, or fal
6370: 73 65 20 6f 74 68 65 72 77 69 73 65 2e 0a 2a 2f  se otherwise..*/
6380: 0a 73 74 61 74 69 63 20 69 6e 74 20 76 66 73 74  .static int vfst
6390: 72 61 63 65 41 63 63 65 73 73 28 0a 20 20 73 71  raceAccess(.  sq
63a0: 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c  lite3_vfs *pVfs,
63b0: 20 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a   .  const char *
63c0: 7a 50 61 74 68 2c 20 0a 20 20 69 6e 74 20 66 6c  zPath, .  int fl
63d0: 61 67 73 2c 20 0a 20 20 69 6e 74 20 2a 70 52 65  ags, .  int *pRe
63e0: 73 4f 75 74 0a 29 7b 0a 20 20 76 66 73 74 72 61  sOut.){.  vfstra
63f0: 63 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d  ce_info *pInfo =
6400: 20 28 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 2a   (vfstrace_info*
6410: 29 70 56 66 73 2d 3e 70 41 70 70 44 61 74 61 3b  )pVfs->pAppData;
6420: 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a  .  sqlite3_vfs *
6430: 70 52 6f 6f 74 20 3d 20 70 49 6e 66 6f 2d 3e 70  pRoot = pInfo->p
6440: 52 6f 6f 74 56 66 73 3b 0a 20 20 69 6e 74 20 72  RootVfs;.  int r
6450: 63 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72  c;.  vfstrace_pr
6460: 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22 25 73 2e  intf(pInfo, "%s.
6470: 78 41 63 63 65 73 73 28 5c 22 25 73 5c 22 2c 25  xAccess(\"%s\",%
6480: 64 29 22 2c 0a 20 20 20 20 20 20 20 20 20 20 20  d)",.           
6490: 20 20 20 20 20 20 20 70 49 6e 66 6f 2d 3e 7a 56         pInfo->zV
64a0: 66 73 4e 61 6d 65 2c 20 7a 50 61 74 68 2c 20 66  fsName, zPath, f
64b0: 6c 61 67 73 29 3b 0a 20 20 72 63 20 3d 20 70 52  lags);.  rc = pR
64c0: 6f 6f 74 2d 3e 78 41 63 63 65 73 73 28 70 52 6f  oot->xAccess(pRo
64d0: 6f 74 2c 20 7a 50 61 74 68 2c 20 66 6c 61 67 73  ot, zPath, flags
64e0: 2c 20 70 52 65 73 4f 75 74 29 3b 0a 20 20 76 66  , pResOut);.  vf
64f0: 73 74 72 61 63 65 5f 70 72 69 6e 74 5f 65 72 72  strace_print_err
6500: 63 6f 64 65 28 70 49 6e 66 6f 2c 20 22 20 2d 3e  code(pInfo, " ->
6510: 20 25 73 22 2c 20 72 63 29 3b 0a 20 20 76 66 73   %s", rc);.  vfs
6520: 74 72 61 63 65 5f 70 72 69 6e 74 66 28 70 49 6e  trace_printf(pIn
6530: 66 6f 2c 20 22 2c 20 6f 75 74 3d 25 64 5c 6e 22  fo, ", out=%d\n"
6540: 2c 20 2a 70 52 65 73 4f 75 74 29 3b 0a 20 20 72  , *pResOut);.  r
6550: 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a  eturn rc;.}../*.
6560: 2a 2a 20 50 6f 70 75 6c 61 74 65 20 62 75 66 66  ** Populate buff
6570: 65 72 20 7a 4f 75 74 20 77 69 74 68 20 74 68 65  er zOut with the
6580: 20 66 75 6c 6c 20 63 61 6e 6f 6e 69 63 61 6c 20   full canonical 
6590: 70 61 74 68 6e 61 6d 65 20 63 6f 72 72 65 73 70  pathname corresp
65a0: 6f 6e 64 69 6e 67 0a 2a 2a 20 74 6f 20 74 68 65  onding.** to the
65b0: 20 70 61 74 68 6e 61 6d 65 20 69 6e 20 7a 50 61   pathname in zPa
65c0: 74 68 2e 20 7a 4f 75 74 20 69 73 20 67 75 61 72  th. zOut is guar
65d0: 61 6e 74 65 65 64 20 74 6f 20 70 6f 69 6e 74 20  anteed to point 
65e0: 74 6f 20 61 20 62 75 66 66 65 72 0a 2a 2a 20 6f  to a buffer.** o
65f0: 66 20 61 74 20 6c 65 61 73 74 20 28 44 45 56 53  f at least (DEVS
6600: 59 4d 5f 4d 41 58 5f 50 41 54 48 4e 41 4d 45 2b  YM_MAX_PATHNAME+
6610: 31 29 20 62 79 74 65 73 2e 0a 2a 2f 0a 73 74 61  1) bytes..*/.sta
6620: 74 69 63 20 69 6e 74 20 76 66 73 74 72 61 63 65  tic int vfstrace
6630: 46 75 6c 6c 50 61 74 68 6e 61 6d 65 28 0a 20 20  FullPathname(.  
6640: 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66  sqlite3_vfs *pVf
6650: 73 2c 20 0a 20 20 63 6f 6e 73 74 20 63 68 61 72  s, .  const char
6660: 20 2a 7a 50 61 74 68 2c 20 0a 20 20 69 6e 74 20   *zPath, .  int 
6670: 6e 4f 75 74 2c 20 0a 20 20 63 68 61 72 20 2a 7a  nOut, .  char *z
6680: 4f 75 74 0a 29 7b 0a 20 20 76 66 73 74 72 61 63  Out.){.  vfstrac
6690: 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20  e_info *pInfo = 
66a0: 28 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 2a 29  (vfstrace_info*)
66b0: 70 56 66 73 2d 3e 70 41 70 70 44 61 74 61 3b 0a  pVfs->pAppData;.
66c0: 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70    sqlite3_vfs *p
66d0: 52 6f 6f 74 20 3d 20 70 49 6e 66 6f 2d 3e 70 52  Root = pInfo->pR
66e0: 6f 6f 74 56 66 73 3b 0a 20 20 69 6e 74 20 72 63  ootVfs;.  int rc
66f0: 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72 69  ;.  vfstrace_pri
6700: 6e 74 66 28 70 49 6e 66 6f 2c 20 22 25 73 2e 78  ntf(pInfo, "%s.x
6710: 46 75 6c 6c 50 61 74 68 6e 61 6d 65 28 5c 22 25  FullPathname(\"%
6720: 73 5c 22 29 22 2c 0a 20 20 20 20 20 20 20 20 20  s\")",.         
6730: 20 20 20 20 20 20 20 20 20 70 49 6e 66 6f 2d 3e           pInfo->
6740: 7a 56 66 73 4e 61 6d 65 2c 20 7a 50 61 74 68 29  zVfsName, zPath)
6750: 3b 0a 20 20 72 63 20 3d 20 70 52 6f 6f 74 2d 3e  ;.  rc = pRoot->
6760: 78 46 75 6c 6c 50 61 74 68 6e 61 6d 65 28 70 52  xFullPathname(pR
6770: 6f 6f 74 2c 20 7a 50 61 74 68 2c 20 6e 4f 75 74  oot, zPath, nOut
6780: 2c 20 7a 4f 75 74 29 3b 0a 20 20 76 66 73 74 72  , zOut);.  vfstr
6790: 61 63 65 5f 70 72 69 6e 74 5f 65 72 72 63 6f 64  ace_print_errcod
67a0: 65 28 70 49 6e 66 6f 2c 20 22 20 2d 3e 20 25 73  e(pInfo, " -> %s
67b0: 22 2c 20 72 63 29 3b 0a 20 20 76 66 73 74 72 61  ", rc);.  vfstra
67c0: 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c  ce_printf(pInfo,
67d0: 20 22 2c 20 6f 75 74 3d 5c 22 25 2e 2a 73 5c 22   ", out=\"%.*s\"
67e0: 5c 6e 22 2c 20 6e 4f 75 74 2c 20 7a 4f 75 74 29  \n", nOut, zOut)
67f0: 3b 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d  ;.  return rc;.}
6800: 0a 0a 2f 2a 0a 2a 2a 20 4f 70 65 6e 20 74 68 65  ../*.** Open the
6810: 20 64 79 6e 61 6d 69 63 20 6c 69 62 72 61 72 79   dynamic library
6820: 20 6c 6f 63 61 74 65 64 20 61 74 20 7a 50 61 74   located at zPat
6830: 68 20 61 6e 64 20 72 65 74 75 72 6e 20 61 20 68  h and return a h
6840: 61 6e 64 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63  andle..*/.static
6850: 20 76 6f 69 64 20 2a 76 66 73 74 72 61 63 65 44   void *vfstraceD
6860: 6c 4f 70 65 6e 28 73 71 6c 69 74 65 33 5f 76 66  lOpen(sqlite3_vf
6870: 73 20 2a 70 56 66 73 2c 20 63 6f 6e 73 74 20 63  s *pVfs, const c
6880: 68 61 72 20 2a 7a 50 61 74 68 29 7b 0a 20 20 76  har *zPath){.  v
6890: 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70 49  fstrace_info *pI
68a0: 6e 66 6f 20 3d 20 28 76 66 73 74 72 61 63 65 5f  nfo = (vfstrace_
68b0: 69 6e 66 6f 2a 29 70 56 66 73 2d 3e 70 41 70 70  info*)pVfs->pApp
68c0: 44 61 74 61 3b 0a 20 20 73 71 6c 69 74 65 33 5f  Data;.  sqlite3_
68d0: 76 66 73 20 2a 70 52 6f 6f 74 20 3d 20 70 49 6e  vfs *pRoot = pIn
68e0: 66 6f 2d 3e 70 52 6f 6f 74 56 66 73 3b 0a 20 20  fo->pRootVfs;.  
68f0: 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74 66 28  vfstrace_printf(
6900: 70 49 6e 66 6f 2c 20 22 25 73 2e 78 44 6c 4f 70  pInfo, "%s.xDlOp
6910: 65 6e 28 5c 22 25 73 5c 22 29 5c 6e 22 2c 20 70  en(\"%s\")\n", p
6920: 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d 65 2c 20  Info->zVfsName, 
6930: 7a 50 61 74 68 29 3b 0a 20 20 72 65 74 75 72 6e  zPath);.  return
6940: 20 70 52 6f 6f 74 2d 3e 78 44 6c 4f 70 65 6e 28   pRoot->xDlOpen(
6950: 70 52 6f 6f 74 2c 20 7a 50 61 74 68 29 3b 0a 7d  pRoot, zPath);.}
6960: 0a 0a 2f 2a 0a 2a 2a 20 50 6f 70 75 6c 61 74 65  ../*.** Populate
6970: 20 74 68 65 20 62 75 66 66 65 72 20 7a 45 72 72   the buffer zErr
6980: 4d 73 67 20 28 73 69 7a 65 20 6e 42 79 74 65 20  Msg (size nByte 
6990: 62 79 74 65 73 29 20 77 69 74 68 20 61 20 68 75  bytes) with a hu
69a0: 6d 61 6e 20 72 65 61 64 61 62 6c 65 0a 2a 2a 20  man readable.** 
69b0: 75 74 66 2d 38 20 73 74 72 69 6e 67 20 64 65 73  utf-8 string des
69c0: 63 72 69 62 69 6e 67 20 74 68 65 20 6d 6f 73 74  cribing the most
69d0: 20 72 65 63 65 6e 74 20 65 72 72 6f 72 20 65 6e   recent error en
69e0: 63 6f 75 6e 74 65 72 65 64 20 61 73 73 6f 63 69  countered associ
69f0: 61 74 65 64 20 0a 2a 2a 20 77 69 74 68 20 64 79  ated .** with dy
6a00: 6e 61 6d 69 63 20 6c 69 62 72 61 72 69 65 73 2e  namic libraries.
6a10: 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20  .*/.static void 
6a20: 76 66 73 74 72 61 63 65 44 6c 45 72 72 6f 72 28  vfstraceDlError(
6a30: 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66  sqlite3_vfs *pVf
6a40: 73 2c 20 69 6e 74 20 6e 42 79 74 65 2c 20 63 68  s, int nByte, ch
6a50: 61 72 20 2a 7a 45 72 72 4d 73 67 29 7b 0a 20 20  ar *zErrMsg){.  
6a60: 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70  vfstrace_info *p
6a70: 49 6e 66 6f 20 3d 20 28 76 66 73 74 72 61 63 65  Info = (vfstrace
6a80: 5f 69 6e 66 6f 2a 29 70 56 66 73 2d 3e 70 41 70  _info*)pVfs->pAp
6a90: 70 44 61 74 61 3b 0a 20 20 73 71 6c 69 74 65 33  pData;.  sqlite3
6aa0: 5f 76 66 73 20 2a 70 52 6f 6f 74 20 3d 20 70 49  _vfs *pRoot = pI
6ab0: 6e 66 6f 2d 3e 70 52 6f 6f 74 56 66 73 3b 0a 20  nfo->pRootVfs;. 
6ac0: 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74 66   vfstrace_printf
6ad0: 28 70 49 6e 66 6f 2c 20 22 25 73 2e 78 44 6c 45  (pInfo, "%s.xDlE
6ae0: 72 72 6f 72 28 25 64 29 22 2c 20 70 49 6e 66 6f  rror(%d)", pInfo
6af0: 2d 3e 7a 56 66 73 4e 61 6d 65 2c 20 6e 42 79 74  ->zVfsName, nByt
6b00: 65 29 3b 0a 20 20 70 52 6f 6f 74 2d 3e 78 44 6c  e);.  pRoot->xDl
6b10: 45 72 72 6f 72 28 70 52 6f 6f 74 2c 20 6e 42 79  Error(pRoot, nBy
6b20: 74 65 2c 20 7a 45 72 72 4d 73 67 29 3b 0a 20 20  te, zErrMsg);.  
6b30: 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74 66 28  vfstrace_printf(
6b40: 70 49 6e 66 6f 2c 20 22 20 2d 3e 20 5c 22 25 73  pInfo, " -> \"%s
6b50: 5c 22 22 2c 20 7a 45 72 72 4d 73 67 29 3b 0a 7d  \"", zErrMsg);.}
6b60: 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 61  ../*.** Return a
6b70: 20 70 6f 69 6e 74 65 72 20 74 6f 20 74 68 65 20   pointer to the 
6b80: 73 79 6d 62 6f 6c 20 7a 53 79 6d 62 6f 6c 20 69  symbol zSymbol i
6b90: 6e 20 74 68 65 20 64 79 6e 61 6d 69 63 20 6c 69  n the dynamic li
6ba0: 62 72 61 72 79 20 70 48 61 6e 64 6c 65 2e 0a 2a  brary pHandle..*
6bb0: 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20 28 2a  /.static void (*
6bc0: 76 66 73 74 72 61 63 65 44 6c 53 79 6d 28 73 71  vfstraceDlSym(sq
6bd0: 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c  lite3_vfs *pVfs,
6be0: 76 6f 69 64 20 2a 70 2c 63 6f 6e 73 74 20 63 68  void *p,const ch
6bf0: 61 72 20 2a 7a 53 79 6d 29 29 28 76 6f 69 64 29  ar *zSym))(void)
6c00: 7b 0a 20 20 76 66 73 74 72 61 63 65 5f 69 6e 66  {.  vfstrace_inf
6c10: 6f 20 2a 70 49 6e 66 6f 20 3d 20 28 76 66 73 74  o *pInfo = (vfst
6c20: 72 61 63 65 5f 69 6e 66 6f 2a 29 70 56 66 73 2d  race_info*)pVfs-
6c30: 3e 70 41 70 70 44 61 74 61 3b 0a 20 20 73 71 6c  >pAppData;.  sql
6c40: 69 74 65 33 5f 76 66 73 20 2a 70 52 6f 6f 74 20  ite3_vfs *pRoot 
6c50: 3d 20 70 49 6e 66 6f 2d 3e 70 52 6f 6f 74 56 66  = pInfo->pRootVf
6c60: 73 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72  s;.  vfstrace_pr
6c70: 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22 25 73 2e  intf(pInfo, "%s.
6c80: 78 44 6c 53 79 6d 28 5c 22 25 73 5c 22 29 5c 6e  xDlSym(\"%s\")\n
6c90: 22 2c 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61  ", pInfo->zVfsNa
6ca0: 6d 65 2c 20 7a 53 79 6d 29 3b 0a 20 20 72 65 74  me, zSym);.  ret
6cb0: 75 72 6e 20 70 52 6f 6f 74 2d 3e 78 44 6c 53 79  urn pRoot->xDlSy
6cc0: 6d 28 70 52 6f 6f 74 2c 20 70 2c 20 7a 53 79 6d  m(pRoot, p, zSym
6cd0: 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 6c 6f 73  );.}../*.** Clos
6ce0: 65 20 74 68 65 20 64 79 6e 61 6d 69 63 20 6c 69  e the dynamic li
6cf0: 62 72 61 72 79 20 68 61 6e 64 6c 65 20 70 48 61  brary handle pHa
6d00: 6e 64 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  ndle..*/.static 
6d10: 76 6f 69 64 20 76 66 73 74 72 61 63 65 44 6c 43  void vfstraceDlC
6d20: 6c 6f 73 65 28 73 71 6c 69 74 65 33 5f 76 66 73  lose(sqlite3_vfs
6d30: 20 2a 70 56 66 73 2c 20 76 6f 69 64 20 2a 70 48   *pVfs, void *pH
6d40: 61 6e 64 6c 65 29 7b 0a 20 20 76 66 73 74 72 61  andle){.  vfstra
6d50: 63 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d  ce_info *pInfo =
6d60: 20 28 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 2a   (vfstrace_info*
6d70: 29 70 56 66 73 2d 3e 70 41 70 70 44 61 74 61 3b  )pVfs->pAppData;
6d80: 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a  .  sqlite3_vfs *
6d90: 70 52 6f 6f 74 20 3d 20 70 49 6e 66 6f 2d 3e 70  pRoot = pInfo->p
6da0: 52 6f 6f 74 56 66 73 3b 0a 20 20 76 66 73 74 72  RootVfs;.  vfstr
6db0: 61 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f  ace_printf(pInfo
6dc0: 2c 20 22 25 73 2e 78 44 6c 4f 70 65 6e 28 29 5c  , "%s.xDlOpen()\
6dd0: 6e 22 2c 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e  n", pInfo->zVfsN
6de0: 61 6d 65 29 3b 0a 20 20 70 52 6f 6f 74 2d 3e 78  ame);.  pRoot->x
6df0: 44 6c 43 6c 6f 73 65 28 70 52 6f 6f 74 2c 20 70  DlClose(pRoot, p
6e00: 48 61 6e 64 6c 65 29 3b 0a 7d 0a 0a 2f 2a 0a 2a  Handle);.}../*.*
6e10: 2a 20 50 6f 70 75 6c 61 74 65 20 74 68 65 20 62  * Populate the b
6e20: 75 66 66 65 72 20 70 6f 69 6e 74 65 64 20 74 6f  uffer pointed to
6e30: 20 62 79 20 7a 42 75 66 4f 75 74 20 77 69 74 68   by zBufOut with
6e40: 20 6e 42 79 74 65 20 62 79 74 65 73 20 6f 66 20   nByte bytes of 
6e50: 0a 2a 2a 20 72 61 6e 64 6f 6d 20 64 61 74 61 2e  .** random data.
6e60: 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 76  .*/.static int v
6e70: 66 73 74 72 61 63 65 52 61 6e 64 6f 6d 6e 65 73  fstraceRandomnes
6e80: 73 28 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70  s(sqlite3_vfs *p
6e90: 56 66 73 2c 20 69 6e 74 20 6e 42 79 74 65 2c 20  Vfs, int nByte, 
6ea0: 63 68 61 72 20 2a 7a 42 75 66 4f 75 74 29 7b 0a  char *zBufOut){.
6eb0: 20 20 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 20    vfstrace_info 
6ec0: 2a 70 49 6e 66 6f 20 3d 20 28 76 66 73 74 72 61  *pInfo = (vfstra
6ed0: 63 65 5f 69 6e 66 6f 2a 29 70 56 66 73 2d 3e 70  ce_info*)pVfs->p
6ee0: 41 70 70 44 61 74 61 3b 0a 20 20 73 71 6c 69 74  AppData;.  sqlit
6ef0: 65 33 5f 76 66 73 20 2a 70 52 6f 6f 74 20 3d 20  e3_vfs *pRoot = 
6f00: 70 49 6e 66 6f 2d 3e 70 52 6f 6f 74 56 66 73 3b  pInfo->pRootVfs;
6f10: 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e  .  vfstrace_prin
6f20: 74 66 28 70 49 6e 66 6f 2c 20 22 25 73 2e 78 52  tf(pInfo, "%s.xR
6f30: 61 6e 64 6f 6d 6e 65 73 73 28 25 64 29 5c 6e 22  andomness(%d)\n"
6f40: 2c 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d  , pInfo->zVfsNam
6f50: 65 2c 20 6e 42 79 74 65 29 3b 0a 20 20 72 65 74  e, nByte);.  ret
6f60: 75 72 6e 20 70 52 6f 6f 74 2d 3e 78 52 61 6e 64  urn pRoot->xRand
6f70: 6f 6d 6e 65 73 73 28 70 52 6f 6f 74 2c 20 6e 42  omness(pRoot, nB
6f80: 79 74 65 2c 20 7a 42 75 66 4f 75 74 29 3b 0a 7d  yte, zBufOut);.}
6f90: 0a 0a 2f 2a 0a 2a 2a 20 53 6c 65 65 70 20 66 6f  ../*.** Sleep fo
6fa0: 72 20 6e 4d 69 63 72 6f 20 6d 69 63 72 6f 73 65  r nMicro microse
6fb0: 63 6f 6e 64 73 2e 20 52 65 74 75 72 6e 20 74 68  conds. Return th
6fc0: 65 20 6e 75 6d 62 65 72 20 6f 66 20 6d 69 63 72  e number of micr
6fd0: 6f 73 65 63 6f 6e 64 73 20 0a 2a 2a 20 61 63 74  oseconds .** act
6fe0: 75 61 6c 6c 79 20 73 6c 65 70 74 2e 0a 2a 2f 0a  ually slept..*/.
6ff0: 73 74 61 74 69 63 20 69 6e 74 20 76 66 73 74 72  static int vfstr
7000: 61 63 65 53 6c 65 65 70 28 73 71 6c 69 74 65 33  aceSleep(sqlite3
7010: 5f 76 66 73 20 2a 70 56 66 73 2c 20 69 6e 74 20  _vfs *pVfs, int 
7020: 6e 4d 69 63 72 6f 29 7b 0a 20 20 76 66 73 74 72  nMicro){.  vfstr
7030: 61 63 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20  ace_info *pInfo 
7040: 3d 20 28 76 66 73 74 72 61 63 65 5f 69 6e 66 6f  = (vfstrace_info
7050: 2a 29 70 56 66 73 2d 3e 70 41 70 70 44 61 74 61  *)pVfs->pAppData
7060: 3b 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20  ;.  sqlite3_vfs 
7070: 2a 70 52 6f 6f 74 20 3d 20 70 49 6e 66 6f 2d 3e  *pRoot = pInfo->
7080: 70 52 6f 6f 74 56 66 73 3b 0a 20 20 72 65 74 75  pRootVfs;.  retu
7090: 72 6e 20 70 52 6f 6f 74 2d 3e 78 53 6c 65 65 70  rn pRoot->xSleep
70a0: 28 70 52 6f 6f 74 2c 20 6e 4d 69 63 72 6f 29 3b  (pRoot, nMicro);
70b0: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e  .}../*.** Return
70c0: 20 74 68 65 20 63 75 72 72 65 6e 74 20 74 69 6d   the current tim
70d0: 65 20 61 73 20 61 20 4a 75 6c 69 61 6e 20 44 61  e as a Julian Da
70e0: 79 20 6e 75 6d 62 65 72 20 69 6e 20 2a 70 54 69  y number in *pTi
70f0: 6d 65 4f 75 74 2e 0a 2a 2f 0a 73 74 61 74 69 63  meOut..*/.static
7100: 20 69 6e 74 20 76 66 73 74 72 61 63 65 43 75 72   int vfstraceCur
7110: 72 65 6e 74 54 69 6d 65 28 73 71 6c 69 74 65 33  rentTime(sqlite3
7120: 5f 76 66 73 20 2a 70 56 66 73 2c 20 64 6f 75 62  _vfs *pVfs, doub
7130: 6c 65 20 2a 70 54 69 6d 65 4f 75 74 29 7b 0a 20  le *pTimeOut){. 
7140: 20 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a   vfstrace_info *
7150: 70 49 6e 66 6f 20 3d 20 28 76 66 73 74 72 61 63  pInfo = (vfstrac
7160: 65 5f 69 6e 66 6f 2a 29 70 56 66 73 2d 3e 70 41  e_info*)pVfs->pA
7170: 70 70 44 61 74 61 3b 0a 20 20 73 71 6c 69 74 65  ppData;.  sqlite
7180: 33 5f 76 66 73 20 2a 70 52 6f 6f 74 20 3d 20 70  3_vfs *pRoot = p
7190: 49 6e 66 6f 2d 3e 70 52 6f 6f 74 56 66 73 3b 0a  Info->pRootVfs;.
71a0: 20 20 72 65 74 75 72 6e 20 70 52 6f 6f 74 2d 3e    return pRoot->
71b0: 78 43 75 72 72 65 6e 74 54 69 6d 65 28 70 52 6f  xCurrentTime(pRo
71c0: 6f 74 2c 20 70 54 69 6d 65 4f 75 74 29 3b 0a 7d  ot, pTimeOut);.}
71d0: 0a 73 74 61 74 69 63 20 69 6e 74 20 76 66 73 74  .static int vfst
71e0: 72 61 63 65 43 75 72 72 65 6e 74 54 69 6d 65 49  raceCurrentTimeI
71f0: 6e 74 36 34 28 73 71 6c 69 74 65 33 5f 76 66 73  nt64(sqlite3_vfs
7200: 20 2a 70 56 66 73 2c 20 73 71 6c 69 74 65 33 5f   *pVfs, sqlite3_
7210: 69 6e 74 36 34 20 2a 70 54 69 6d 65 4f 75 74 29  int64 *pTimeOut)
7220: 7b 0a 20 20 76 66 73 74 72 61 63 65 5f 69 6e 66  {.  vfstrace_inf
7230: 6f 20 2a 70 49 6e 66 6f 20 3d 20 28 76 66 73 74  o *pInfo = (vfst
7240: 72 61 63 65 5f 69 6e 66 6f 2a 29 70 56 66 73 2d  race_info*)pVfs-
7250: 3e 70 41 70 70 44 61 74 61 3b 0a 20 20 73 71 6c  >pAppData;.  sql
7260: 69 74 65 33 5f 76 66 73 20 2a 70 52 6f 6f 74 20  ite3_vfs *pRoot 
7270: 3d 20 70 49 6e 66 6f 2d 3e 70 52 6f 6f 74 56 66  = pInfo->pRootVf
7280: 73 3b 0a 20 20 72 65 74 75 72 6e 20 70 52 6f 6f  s;.  return pRoo
7290: 74 2d 3e 78 43 75 72 72 65 6e 74 54 69 6d 65 49  t->xCurrentTimeI
72a0: 6e 74 36 34 28 70 52 6f 6f 74 2c 20 70 54 69 6d  nt64(pRoot, pTim
72b0: 65 4f 75 74 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20  eOut);.}../*.** 
72c0: 52 65 74 75 72 6e 20 74 68 33 20 65 6d 6f 73 74  Return th3 emost
72d0: 20 72 65 63 65 6e 74 20 65 72 72 6f 72 20 63 6f   recent error co
72e0: 64 65 20 61 6e 64 20 6d 65 73 73 61 67 65 0a 2a  de and message.*
72f0: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 76 66 73  /.static int vfs
7300: 74 72 61 63 65 47 65 74 4c 61 73 74 45 72 72 6f  traceGetLastErro
7310: 72 28 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70  r(sqlite3_vfs *p
7320: 56 66 73 2c 20 69 6e 74 20 69 45 72 72 2c 20 63  Vfs, int iErr, c
7330: 68 61 72 20 2a 7a 45 72 72 29 7b 0a 20 20 76 66  har *zErr){.  vf
7340: 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70 49 6e  strace_info *pIn
7350: 66 6f 20 3d 20 28 76 66 73 74 72 61 63 65 5f 69  fo = (vfstrace_i
7360: 6e 66 6f 2a 29 70 56 66 73 2d 3e 70 41 70 70 44  nfo*)pVfs->pAppD
7370: 61 74 61 3b 0a 20 20 73 71 6c 69 74 65 33 5f 76  ata;.  sqlite3_v
7380: 66 73 20 2a 70 52 6f 6f 74 20 3d 20 70 49 6e 66  fs *pRoot = pInf
7390: 6f 2d 3e 70 52 6f 6f 74 56 66 73 3b 0a 20 20 72  o->pRootVfs;.  r
73a0: 65 74 75 72 6e 20 70 52 6f 6f 74 2d 3e 78 47 65  eturn pRoot->xGe
73b0: 74 4c 61 73 74 45 72 72 6f 72 28 70 52 6f 6f 74  tLastError(pRoot
73c0: 2c 20 69 45 72 72 2c 20 7a 45 72 72 29 3b 0a 7d  , iErr, zErr);.}
73d0: 0a 0a 2f 2a 0a 2a 2a 20 4f 76 65 72 72 69 64 65  ../*.** Override
73e0: 20 73 79 73 74 65 6d 20 63 61 6c 6c 73 2e 0a 2a   system calls..*
73f0: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 76 66 73  /.static int vfs
7400: 74 72 61 63 65 53 65 74 53 79 73 74 65 6d 43 61  traceSetSystemCa
7410: 6c 6c 28 0a 20 20 73 71 6c 69 74 65 33 5f 76 66  ll(.  sqlite3_vf
7420: 73 20 2a 70 56 66 73 2c 0a 20 20 63 6f 6e 73 74  s *pVfs,.  const
7430: 20 63 68 61 72 20 2a 7a 4e 61 6d 65 2c 0a 20 20   char *zName,.  
7440: 73 71 6c 69 74 65 33 5f 73 79 73 63 61 6c 6c 5f  sqlite3_syscall_
7450: 70 74 72 20 70 46 75 6e 63 0a 29 7b 0a 20 20 76  ptr pFunc.){.  v
7460: 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70 49  fstrace_info *pI
7470: 6e 66 6f 20 3d 20 28 76 66 73 74 72 61 63 65 5f  nfo = (vfstrace_
7480: 69 6e 66 6f 2a 29 70 56 66 73 2d 3e 70 41 70 70  info*)pVfs->pApp
7490: 44 61 74 61 3b 0a 20 20 73 71 6c 69 74 65 33 5f  Data;.  sqlite3_
74a0: 76 66 73 20 2a 70 52 6f 6f 74 20 3d 20 70 49 6e  vfs *pRoot = pIn
74b0: 66 6f 2d 3e 70 52 6f 6f 74 56 66 73 3b 0a 20 20  fo->pRootVfs;.  
74c0: 72 65 74 75 72 6e 20 70 52 6f 6f 74 2d 3e 78 53  return pRoot->xS
74d0: 65 74 53 79 73 74 65 6d 43 61 6c 6c 28 70 52 6f  etSystemCall(pRo
74e0: 6f 74 2c 20 7a 4e 61 6d 65 2c 20 70 46 75 6e 63  ot, zName, pFunc
74f0: 29 3b 0a 7d 0a 73 74 61 74 69 63 20 73 71 6c 69  );.}.static sqli
7500: 74 65 33 5f 73 79 73 63 61 6c 6c 5f 70 74 72 20  te3_syscall_ptr 
7510: 76 66 73 74 72 61 63 65 47 65 74 53 79 73 74 65  vfstraceGetSyste
7520: 6d 43 61 6c 6c 28 0a 20 20 73 71 6c 69 74 65 33  mCall(.  sqlite3
7530: 5f 76 66 73 20 2a 70 56 66 73 2c 0a 20 20 63 6f  _vfs *pVfs,.  co
7540: 6e 73 74 20 63 68 61 72 20 2a 7a 4e 61 6d 65 0a  nst char *zName.
7550: 29 7b 0a 20 20 76 66 73 74 72 61 63 65 5f 69 6e  ){.  vfstrace_in
7560: 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 28 76 66 73  fo *pInfo = (vfs
7570: 74 72 61 63 65 5f 69 6e 66 6f 2a 29 70 56 66 73  trace_info*)pVfs
7580: 2d 3e 70 41 70 70 44 61 74 61 3b 0a 20 20 73 71  ->pAppData;.  sq
7590: 6c 69 74 65 33 5f 76 66 73 20 2a 70 52 6f 6f 74  lite3_vfs *pRoot
75a0: 20 3d 20 70 49 6e 66 6f 2d 3e 70 52 6f 6f 74 56   = pInfo->pRootV
75b0: 66 73 3b 0a 20 20 72 65 74 75 72 6e 20 70 52 6f  fs;.  return pRo
75c0: 6f 74 2d 3e 78 47 65 74 53 79 73 74 65 6d 43 61  ot->xGetSystemCa
75d0: 6c 6c 28 70 52 6f 6f 74 2c 20 7a 4e 61 6d 65 29  ll(pRoot, zName)
75e0: 3b 0a 7d 0a 73 74 61 74 69 63 20 63 6f 6e 73 74  ;.}.static const
75f0: 20 63 68 61 72 20 2a 76 66 73 74 72 61 63 65 4e   char *vfstraceN
7600: 65 78 74 53 79 73 74 65 6d 43 61 6c 6c 28 73 71  extSystemCall(sq
7610: 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c  lite3_vfs *pVfs,
7620: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 4e 61   const char *zNa
7630: 6d 65 29 7b 0a 20 20 76 66 73 74 72 61 63 65 5f  me){.  vfstrace_
7640: 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 28 76  info *pInfo = (v
7650: 66 73 74 72 61 63 65 5f 69 6e 66 6f 2a 29 70 56  fstrace_info*)pV
7660: 66 73 2d 3e 70 41 70 70 44 61 74 61 3b 0a 20 20  fs->pAppData;.  
7670: 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 52 6f  sqlite3_vfs *pRo
7680: 6f 74 20 3d 20 70 49 6e 66 6f 2d 3e 70 52 6f 6f  ot = pInfo->pRoo
7690: 74 56 66 73 3b 0a 20 20 72 65 74 75 72 6e 20 70  tVfs;.  return p
76a0: 52 6f 6f 74 2d 3e 78 4e 65 78 74 53 79 73 74 65  Root->xNextSyste
76b0: 6d 43 61 6c 6c 28 70 52 6f 6f 74 2c 20 7a 4e 61  mCall(pRoot, zNa
76c0: 6d 65 29 3b 0a 7d 0a 0a 0a 2f 2a 0a 2a 2a 20 43  me);.}.../*.** C
76d0: 6c 69 65 6e 74 73 20 69 6e 76 6f 6b 65 20 74 68  lients invoke th
76e0: 69 73 20 72 6f 75 74 69 6e 65 20 74 6f 20 63 6f  is routine to co
76f0: 6e 73 74 72 75 63 74 20 61 20 6e 65 77 20 74 72  nstruct a new tr
7700: 61 63 65 2d 76 66 73 20 73 68 69 6d 2e 0a 2a 2a  ace-vfs shim..**
7710: 0a 2a 2a 20 52 65 74 75 72 6e 20 53 51 4c 49 54  .** Return SQLIT
7720: 45 5f 4f 4b 20 6f 6e 20 73 75 63 63 65 73 73 2e  E_OK on success.
7730: 20 20 0a 2a 2a 0a 2a 2a 20 53 51 4c 49 54 45 5f    .**.** SQLITE_
7740: 4e 4f 4d 45 4d 20 69 73 20 72 65 74 75 72 6e 65  NOMEM is returne
7750: 64 20 69 6e 20 74 68 65 20 63 61 73 65 20 6f 66  d in the case of
7760: 20 61 20 6d 65 6d 6f 72 79 20 61 6c 6c 6f 63 61   a memory alloca
7770: 74 69 6f 6e 20 65 72 72 6f 72 2e 0a 2a 2a 20 53  tion error..** S
7780: 51 4c 49 54 45 5f 4e 4f 54 46 4f 55 4e 44 20 69  QLITE_NOTFOUND i
7790: 73 20 72 65 74 75 72 6e 65 64 20 69 66 20 7a 4f  s returned if zO
77a0: 6c 64 56 66 73 4e 61 6d 65 20 64 6f 65 73 20 6e  ldVfsName does n
77b0: 6f 74 20 65 78 69 73 74 2e 0a 2a 2f 0a 69 6e 74  ot exist..*/.int
77c0: 20 76 66 73 74 72 61 63 65 5f 72 65 67 69 73 74   vfstrace_regist
77d0: 65 72 28 0a 20 20 20 63 6f 6e 73 74 20 63 68 61  er(.   const cha
77e0: 72 20 2a 7a 54 72 61 63 65 4e 61 6d 65 2c 20 20  r *zTraceName,  
77f0: 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 61 6d 65           /* Name
7800: 20 6f 66 20 74 68 65 20 6e 65 77 6c 79 20 63 6f   of the newly co
7810: 6e 73 74 72 75 63 74 65 64 20 56 46 53 20 2a 2f  nstructed VFS */
7820: 0a 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  .   const char *
7830: 7a 4f 6c 64 56 66 73 4e 61 6d 65 2c 20 20 20 20  zOldVfsName,    
7840: 20 20 20 20 20 20 2f 2a 20 4e 61 6d 65 20 6f 66        /* Name of
7850: 20 74 68 65 20 75 6e 64 65 72 6c 79 69 6e 67 20   the underlying 
7860: 56 46 53 20 2a 2f 0a 20 20 20 69 6e 74 20 28 2a  VFS */.   int (*
7870: 78 4f 75 74 29 28 63 6f 6e 73 74 20 63 68 61 72  xOut)(const char
7880: 2a 2c 76 6f 69 64 2a 29 2c 20 20 20 2f 2a 20 4f  *,void*),   /* O
7890: 75 74 70 75 74 20 72 6f 75 74 69 6e 65 2e 20 20  utput routine.  
78a0: 65 78 3a 20 66 70 75 74 73 20 2a 2f 0a 20 20 20  ex: fputs */.   
78b0: 76 6f 69 64 20 2a 70 4f 75 74 41 72 67 2c 20 20  void *pOutArg,  
78c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
78d0: 20 20 2f 2a 20 32 6e 64 20 61 72 67 75 6d 65 6e    /* 2nd argumen
78e0: 74 20 74 6f 20 78 4f 75 74 2e 20 20 65 78 3a 20  t to xOut.  ex: 
78f0: 73 74 64 65 72 72 20 2a 2f 0a 20 20 20 69 6e 74  stderr */.   int
7900: 20 6d 61 6b 65 44 65 66 61 75 6c 74 20 20 20 20   makeDefault    
7910: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
7920: 2a 20 54 72 75 65 20 74 6f 20 6d 61 6b 65 20 74  * True to make t
7930: 68 65 20 6e 65 77 20 56 46 53 20 74 68 65 20 64  he new VFS the d
7940: 65 66 61 75 6c 74 20 2a 2f 0a 29 7b 0a 20 20 73  efault */.){.  s
7950: 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 4e 65 77  qlite3_vfs *pNew
7960: 3b 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20  ;.  sqlite3_vfs 
7970: 2a 70 52 6f 6f 74 3b 0a 20 20 76 66 73 74 72 61  *pRoot;.  vfstra
7980: 63 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 3b 0a  ce_info *pInfo;.
7990: 20 20 69 6e 74 20 6e 4e 61 6d 65 3b 0a 20 20 69    int nName;.  i
79a0: 6e 74 20 6e 42 79 74 65 3b 0a 0a 20 20 70 52 6f  nt nByte;..  pRo
79b0: 6f 74 20 3d 20 73 71 6c 69 74 65 33 5f 76 66 73  ot = sqlite3_vfs
79c0: 5f 66 69 6e 64 28 7a 4f 6c 64 56 66 73 4e 61 6d  _find(zOldVfsNam
79d0: 65 29 3b 0a 20 20 69 66 28 20 70 52 6f 6f 74 3d  e);.  if( pRoot=
79e0: 3d 30 20 29 20 72 65 74 75 72 6e 20 53 51 4c 49  =0 ) return SQLI
79f0: 54 45 5f 4e 4f 54 46 4f 55 4e 44 3b 0a 20 20 6e  TE_NOTFOUND;.  n
7a00: 4e 61 6d 65 20 3d 20 73 74 72 6c 65 6e 28 7a 54  Name = strlen(zT
7a10: 72 61 63 65 4e 61 6d 65 29 3b 0a 20 20 6e 42 79  raceName);.  nBy
7a20: 74 65 20 3d 20 73 69 7a 65 6f 66 28 2a 70 4e 65  te = sizeof(*pNe
7a30: 77 29 20 2b 20 73 69 7a 65 6f 66 28 2a 70 49 6e  w) + sizeof(*pIn
7a40: 66 6f 29 20 2b 20 6e 4e 61 6d 65 20 2b 20 31 3b  fo) + nName + 1;
7a50: 0a 20 20 70 4e 65 77 20 3d 20 73 71 6c 69 74 65  .  pNew = sqlite
7a60: 33 5f 6d 61 6c 6c 6f 63 28 20 6e 42 79 74 65 20  3_malloc( nByte 
7a70: 29 3b 0a 20 20 69 66 28 20 70 4e 65 77 3d 3d 30  );.  if( pNew==0
7a80: 20 29 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45   ) return SQLITE
7a90: 5f 4e 4f 4d 45 4d 3b 0a 20 20 6d 65 6d 73 65 74  _NOMEM;.  memset
7aa0: 28 70 4e 65 77 2c 20 30 2c 20 6e 42 79 74 65 29  (pNew, 0, nByte)
7ab0: 3b 0a 20 20 70 49 6e 66 6f 20 3d 20 28 76 66 73  ;.  pInfo = (vfs
7ac0: 74 72 61 63 65 5f 69 6e 66 6f 2a 29 26 70 4e 65  trace_info*)&pNe
7ad0: 77 5b 31 5d 3b 0a 20 20 70 4e 65 77 2d 3e 69 56  w[1];.  pNew->iV
7ae0: 65 72 73 69 6f 6e 20 3d 20 70 52 6f 6f 74 2d 3e  ersion = pRoot->
7af0: 69 56 65 72 73 69 6f 6e 3b 0a 20 20 70 4e 65 77  iVersion;.  pNew
7b00: 2d 3e 73 7a 4f 73 46 69 6c 65 20 3d 20 70 52 6f  ->szOsFile = pRo
7b10: 6f 74 2d 3e 73 7a 4f 73 46 69 6c 65 20 2b 20 73  ot->szOsFile + s
7b20: 69 7a 65 6f 66 28 76 66 73 74 72 61 63 65 5f 66  izeof(vfstrace_f
7b30: 69 6c 65 29 3b 0a 20 20 70 4e 65 77 2d 3e 6d 78  ile);.  pNew->mx
7b40: 50 61 74 68 6e 61 6d 65 20 3d 20 70 52 6f 6f 74  Pathname = pRoot
7b50: 2d 3e 6d 78 50 61 74 68 6e 61 6d 65 3b 0a 20 20  ->mxPathname;.  
7b60: 70 4e 65 77 2d 3e 7a 4e 61 6d 65 20 3d 20 28 63  pNew->zName = (c
7b70: 68 61 72 2a 29 26 70 49 6e 66 6f 5b 31 5d 3b 0a  har*)&pInfo[1];.
7b80: 20 20 6d 65 6d 63 70 79 28 28 63 68 61 72 2a 29    memcpy((char*)
7b90: 26 70 49 6e 66 6f 5b 31 5d 2c 20 7a 54 72 61 63  &pInfo[1], zTrac
7ba0: 65 4e 61 6d 65 2c 20 6e 4e 61 6d 65 2b 31 29 3b  eName, nName+1);
7bb0: 0a 20 20 70 4e 65 77 2d 3e 70 41 70 70 44 61 74  .  pNew->pAppDat
7bc0: 61 20 3d 20 70 49 6e 66 6f 3b 0a 20 20 70 4e 65  a = pInfo;.  pNe
7bd0: 77 2d 3e 78 4f 70 65 6e 20 3d 20 76 66 73 74 72  w->xOpen = vfstr
7be0: 61 63 65 4f 70 65 6e 3b 0a 20 20 70 4e 65 77 2d  aceOpen;.  pNew-
7bf0: 3e 78 44 65 6c 65 74 65 20 3d 20 76 66 73 74 72  >xDelete = vfstr
7c00: 61 63 65 44 65 6c 65 74 65 3b 0a 20 20 70 4e 65  aceDelete;.  pNe
7c10: 77 2d 3e 78 41 63 63 65 73 73 20 3d 20 76 66 73  w->xAccess = vfs
7c20: 74 72 61 63 65 41 63 63 65 73 73 3b 0a 20 20 70  traceAccess;.  p
7c30: 4e 65 77 2d 3e 78 46 75 6c 6c 50 61 74 68 6e 61  New->xFullPathna
7c40: 6d 65 20 3d 20 76 66 73 74 72 61 63 65 46 75 6c  me = vfstraceFul
7c50: 6c 50 61 74 68 6e 61 6d 65 3b 0a 20 20 70 4e 65  lPathname;.  pNe
7c60: 77 2d 3e 78 44 6c 4f 70 65 6e 20 3d 20 70 52 6f  w->xDlOpen = pRo
7c70: 6f 74 2d 3e 78 44 6c 4f 70 65 6e 3d 3d 30 20 3f  ot->xDlOpen==0 ?
7c80: 20 30 20 3a 20 76 66 73 74 72 61 63 65 44 6c 4f   0 : vfstraceDlO
7c90: 70 65 6e 3b 0a 20 20 70 4e 65 77 2d 3e 78 44 6c  pen;.  pNew->xDl
7ca0: 45 72 72 6f 72 20 3d 20 70 52 6f 6f 74 2d 3e 78  Error = pRoot->x
7cb0: 44 6c 45 72 72 6f 72 3d 3d 30 20 3f 20 30 20 3a  DlError==0 ? 0 :
7cc0: 20 76 66 73 74 72 61 63 65 44 6c 45 72 72 6f 72   vfstraceDlError
7cd0: 3b 0a 20 20 70 4e 65 77 2d 3e 78 44 6c 53 79 6d  ;.  pNew->xDlSym
7ce0: 20 3d 20 70 52 6f 6f 74 2d 3e 78 44 6c 53 79 6d   = pRoot->xDlSym
7cf0: 3d 3d 30 20 3f 20 30 20 3a 20 76 66 73 74 72 61  ==0 ? 0 : vfstra
7d00: 63 65 44 6c 53 79 6d 3b 0a 20 20 70 4e 65 77 2d  ceDlSym;.  pNew-
7d10: 3e 78 44 6c 43 6c 6f 73 65 20 3d 20 70 52 6f 6f  >xDlClose = pRoo
7d20: 74 2d 3e 78 44 6c 43 6c 6f 73 65 3d 3d 30 20 3f  t->xDlClose==0 ?
7d30: 20 30 20 3a 20 76 66 73 74 72 61 63 65 44 6c 43   0 : vfstraceDlC
7d40: 6c 6f 73 65 3b 0a 20 20 70 4e 65 77 2d 3e 78 52  lose;.  pNew->xR
7d50: 61 6e 64 6f 6d 6e 65 73 73 20 3d 20 76 66 73 74  andomness = vfst
7d60: 72 61 63 65 52 61 6e 64 6f 6d 6e 65 73 73 3b 0a  raceRandomness;.
7d70: 20 20 70 4e 65 77 2d 3e 78 53 6c 65 65 70 20 3d    pNew->xSleep =
7d80: 20 76 66 73 74 72 61 63 65 53 6c 65 65 70 3b 0a   vfstraceSleep;.
7d90: 20 20 70 4e 65 77 2d 3e 78 43 75 72 72 65 6e 74    pNew->xCurrent
7da0: 54 69 6d 65 20 3d 20 76 66 73 74 72 61 63 65 43  Time = vfstraceC
7db0: 75 72 72 65 6e 74 54 69 6d 65 3b 0a 20 20 70 4e  urrentTime;.  pN
7dc0: 65 77 2d 3e 78 47 65 74 4c 61 73 74 45 72 72 6f  ew->xGetLastErro
7dd0: 72 20 3d 20 70 52 6f 6f 74 2d 3e 78 47 65 74 4c  r = pRoot->xGetL
7de0: 61 73 74 45 72 72 6f 72 3d 3d 30 20 3f 20 30 20  astError==0 ? 0 
7df0: 3a 20 76 66 73 74 72 61 63 65 47 65 74 4c 61 73  : vfstraceGetLas
7e00: 74 45 72 72 6f 72 3b 0a 20 20 69 66 28 20 70 4e  tError;.  if( pN
7e10: 65 77 2d 3e 69 56 65 72 73 69 6f 6e 3e 3d 32 20  ew->iVersion>=2 
7e20: 29 7b 0a 20 20 20 20 70 4e 65 77 2d 3e 78 43 75  ){.    pNew->xCu
7e30: 72 72 65 6e 74 54 69 6d 65 49 6e 74 36 34 20 3d  rrentTimeInt64 =
7e40: 20 70 52 6f 6f 74 2d 3e 78 43 75 72 72 65 6e 74   pRoot->xCurrent
7e50: 54 69 6d 65 49 6e 74 36 34 3d 3d 30 20 3f 20 30  TimeInt64==0 ? 0
7e60: 20 3a 0a 20 20 20 20 20 20 20 20 20 20 20 20 20   :.             
7e70: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7e80: 20 20 20 20 20 20 76 66 73 74 72 61 63 65 43 75        vfstraceCu
7e90: 72 72 65 6e 74 54 69 6d 65 49 6e 74 36 34 3b 0a  rrentTimeInt64;.
7ea0: 20 20 20 20 69 66 28 20 70 4e 65 77 2d 3e 69 56      if( pNew->iV
7eb0: 65 72 73 69 6f 6e 3e 3d 33 20 29 7b 0a 20 20 20  ersion>=3 ){.   
7ec0: 20 20 20 70 4e 65 77 2d 3e 78 53 65 74 53 79 73     pNew->xSetSys
7ed0: 74 65 6d 43 61 6c 6c 20 3d 20 70 52 6f 6f 74 2d  temCall = pRoot-
7ee0: 3e 78 53 65 74 53 79 73 74 65 6d 43 61 6c 6c 3d  >xSetSystemCall=
7ef0: 3d 30 20 3f 20 30 20 3a 20 0a 20 20 20 20 20 20  =0 ? 0 : .      
7f00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7f10: 20 20 20 20 20 20 20 20 20 20 20 20 20 76 66 73               vfs
7f20: 74 72 61 63 65 53 65 74 53 79 73 74 65 6d 43 61  traceSetSystemCa
7f30: 6c 6c 3b 0a 20 20 20 20 20 20 70 4e 65 77 2d 3e  ll;.      pNew->
7f40: 78 47 65 74 53 79 73 74 65 6d 43 61 6c 6c 20 3d  xGetSystemCall =
7f50: 20 70 52 6f 6f 74 2d 3e 78 47 65 74 53 79 73 74   pRoot->xGetSyst
7f60: 65 6d 43 61 6c 6c 3d 3d 30 20 3f 20 30 20 3a 20  emCall==0 ? 0 : 
7f70: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
7f80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
7f90: 20 20 20 20 76 66 73 74 72 61 63 65 47 65 74 53      vfstraceGetS
7fa0: 79 73 74 65 6d 43 61 6c 6c 3b 0a 20 20 20 20 20  ystemCall;.     
7fb0: 20 70 4e 65 77 2d 3e 78 4e 65 78 74 53 79 73 74   pNew->xNextSyst
7fc0: 65 6d 43 61 6c 6c 20 3d 20 70 52 6f 6f 74 2d 3e  emCall = pRoot->
7fd0: 78 4e 65 78 74 53 79 73 74 65 6d 43 61 6c 6c 3d  xNextSystemCall=
7fe0: 3d 30 20 3f 20 30 20 3a 20 0a 20 20 20 20 20 20  =0 ? 0 : .      
7ff0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
8000: 20 20 20 20 20 20 20 20 20 20 20 20 20 76 66 73               vfs
8010: 74 72 61 63 65 4e 65 78 74 53 79 73 74 65 6d 43  traceNextSystemC
8020: 61 6c 6c 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20  all;.    }.  }. 
8030: 20 70 49 6e 66 6f 2d 3e 70 52 6f 6f 74 56 66 73   pInfo->pRootVfs
8040: 20 3d 20 70 52 6f 6f 74 3b 0a 20 20 70 49 6e 66   = pRoot;.  pInf
8050: 6f 2d 3e 78 4f 75 74 20 3d 20 78 4f 75 74 3b 0a  o->xOut = xOut;.
8060: 20 20 70 49 6e 66 6f 2d 3e 70 4f 75 74 41 72 67    pInfo->pOutArg
8070: 20 3d 20 70 4f 75 74 41 72 67 3b 0a 20 20 70 49   = pOutArg;.  pI
8080: 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d 65 20 3d 20  nfo->zVfsName = 
8090: 70 4e 65 77 2d 3e 7a 4e 61 6d 65 3b 0a 20 20 70  pNew->zName;.  p
80a0: 49 6e 66 6f 2d 3e 70 54 72 61 63 65 56 66 73 20  Info->pTraceVfs 
80b0: 3d 20 70 4e 65 77 3b 0a 20 20 76 66 73 74 72 61  = pNew;.  vfstra
80c0: 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c  ce_printf(pInfo,
80d0: 20 22 25 73 2e 65 6e 61 62 6c 65 64 5f 66 6f 72   "%s.enabled_for
80e0: 28 5c 22 25 73 5c 22 29 5c 6e 22 2c 0a 20 20 20  (\"%s\")\n",.   
80f0: 20 20 20 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e      pInfo->zVfsN
8100: 61 6d 65 2c 20 70 52 6f 6f 74 2d 3e 7a 4e 61 6d  ame, pRoot->zNam
8110: 65 29 3b 0a 20 20 72 65 74 75 72 6e 20 73 71 6c  e);.  return sql
8120: 69 74 65 33 5f 76 66 73 5f 72 65 67 69 73 74 65  ite3_vfs_registe
8130: 72 28 70 4e 65 77 2c 20 6d 61 6b 65 44 65 66 61  r(pNew, makeDefa
8140: 75 6c 74 29 3b 0a 7d 0a                          ult);.}.