/ Hex Artifact Content
Login

Artifact 2265c9895f350c8d3c39b079998fbe7481505cc1:


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 2f 0a 23 69 6e 63 6c 75 64 65  ce"..*/.#include
0200: 20 3c 73 74 64 6c 69 62 2e 68 3e 0a 23 69 6e 63   <stdlib.h>.#inc
0210: 6c 75 64 65 20 3c 73 74 72 69 6e 67 2e 68 3e 0a  lude <string.h>.
0220: 23 69 6e 63 6c 75 64 65 20 22 73 71 6c 69 74 65  #include "sqlite
0230: 33 2e 68 22 0a 0a 2f 2a 0a 2a 2a 20 41 6e 20 69  3.h"../*.** An i
0240: 6e 73 74 61 6e 63 65 20 6f 66 20 74 68 69 73 20  nstance of this 
0250: 73 74 72 75 63 74 75 72 65 20 69 73 20 61 74 74  structure is att
0260: 61 63 68 65 64 20 74 6f 20 74 68 65 20 65 61 63  ached to the eac
0270: 68 20 74 72 61 63 65 20 56 46 53 20 74 6f 0a 2a  h trace VFS to.*
0280: 2a 20 70 72 6f 76 69 64 65 20 61 75 78 69 6c 69  * provide auxili
0290: 61 72 79 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 2e  ary information.
02a0: 0a 2a 2f 0a 74 79 70 65 64 65 66 20 73 74 72 75  .*/.typedef stru
02b0: 63 74 20 76 66 73 74 72 61 63 65 5f 69 6e 66 6f  ct vfstrace_info
02c0: 20 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 3b 0a   vfstrace_info;.
02d0: 73 74 72 75 63 74 20 76 66 73 74 72 61 63 65 5f  struct vfstrace_
02e0: 69 6e 66 6f 20 7b 0a 20 20 73 71 6c 69 74 65 33  info {.  sqlite3
02f0: 5f 76 66 73 20 2a 70 52 6f 6f 74 56 66 73 3b 20  _vfs *pRootVfs; 
0300: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
0310: 54 68 65 20 75 6e 64 65 72 6c 79 69 6e 67 20 72  The underlying r
0320: 65 61 6c 20 56 46 53 20 2a 2f 0a 20 20 69 6e 74  eal VFS */.  int
0330: 20 28 2a 78 4f 75 74 29 28 63 6f 6e 73 74 20 63   (*xOut)(const c
0340: 68 61 72 2a 2c 20 76 6f 69 64 2a 29 3b 20 20 20  har*, void*);   
0350: 20 2f 2a 20 53 65 6e 64 20 6f 75 74 70 75 74 20   /* Send output 
0360: 68 65 72 65 20 2a 2f 0a 20 20 76 6f 69 64 20 2a  here */.  void *
0370: 70 4f 75 74 41 72 67 3b 20 20 20 20 20 20 20 20  pOutArg;        
0380: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
0390: 20 46 69 72 73 74 20 61 72 67 75 6d 65 6e 74 20   First argument 
03a0: 74 6f 20 78 4f 75 74 20 2a 2f 0a 20 20 63 6f 6e  to xOut */.  con
03b0: 73 74 20 63 68 61 72 20 2a 7a 56 66 73 4e 61 6d  st char *zVfsNam
03c0: 65 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  e;              
03d0: 20 2f 2a 20 4e 61 6d 65 20 6f 66 20 74 68 69 73   /* Name of this
03e0: 20 74 72 61 63 65 2d 56 46 53 20 2a 2f 0a 20 20   trace-VFS */.  
03f0: 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 54 72  sqlite3_vfs *pTr
0400: 61 63 65 56 66 73 3b 20 20 20 20 20 20 20 20 20  aceVfs;         
0410: 20 20 20 20 2f 2a 20 50 6f 69 6e 74 65 72 20 62      /* Pointer b
0420: 61 63 6b 20 74 6f 20 74 68 65 20 74 72 61 63 65  ack to the trace
0430: 20 56 46 53 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 0a 2a   VFS */.};../*.*
0440: 2a 20 54 68 65 20 73 71 6c 69 74 65 33 5f 66 69  * The sqlite3_fi
0450: 6c 65 20 6f 62 6a 65 63 74 20 66 6f 72 20 74 68  le object for th
0460: 65 20 74 72 61 63 65 20 56 46 53 0a 2a 2f 0a 74  e trace VFS.*/.t
0470: 79 70 65 64 65 66 20 73 74 72 75 63 74 20 76 66  ypedef struct vf
0480: 73 74 72 61 63 65 5f 66 69 6c 65 20 76 66 73 74  strace_file vfst
0490: 72 61 63 65 5f 66 69 6c 65 3b 0a 73 74 72 75 63  race_file;.struc
04a0: 74 20 76 66 73 74 72 61 63 65 5f 66 69 6c 65 20  t vfstrace_file 
04b0: 7b 0a 20 20 73 71 6c 69 74 65 33 5f 66 69 6c 65  {.  sqlite3_file
04c0: 20 62 61 73 65 3b 20 20 20 20 20 20 20 20 2f 2a   base;        /*
04d0: 20 42 61 73 65 20 63 6c 61 73 73 2e 20 20 4d 75   Base class.  Mu
04e0: 73 74 20 62 65 20 66 69 72 73 74 20 2a 2f 0a 20  st be first */. 
04f0: 20 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a   vfstrace_info *
0500: 70 49 6e 66 6f 3b 20 20 20 20 20 2f 2a 20 54 68  pInfo;     /* Th
0510: 65 20 74 72 61 63 65 2d 56 46 53 20 74 6f 20 77  e trace-VFS to w
0520: 68 69 63 68 20 74 68 69 73 20 66 69 6c 65 20 62  hich this file b
0530: 65 6c 6f 6e 67 73 20 2a 2f 0a 20 20 63 6f 6e 73  elongs */.  cons
0540: 74 20 63 68 61 72 20 2a 7a 46 4e 61 6d 65 3b 20  t char *zFName; 
0550: 20 20 20 20 20 20 2f 2a 20 42 61 73 65 20 6e 61        /* Base na
0560: 6d 65 20 6f 66 20 74 68 65 20 66 69 6c 65 20 2a  me of the file *
0570: 2f 0a 20 20 73 71 6c 69 74 65 33 5f 66 69 6c 65  /.  sqlite3_file
0580: 20 2a 70 52 65 61 6c 3b 20 20 20 20 20 20 2f 2a   *pReal;      /*
0590: 20 54 68 65 20 72 65 61 6c 20 75 6e 64 65 72 6c   The real underl
05a0: 79 69 6e 67 20 66 69 6c 65 20 2a 2f 0a 7d 3b 0a  ying file */.};.
05b0: 0a 2f 2a 0a 2a 2a 20 4d 65 74 68 6f 64 20 64 65  ./*.** Method de
05c0: 63 6c 61 72 61 74 69 6f 6e 73 20 66 6f 72 20 76  clarations for v
05d0: 66 73 74 72 61 63 65 5f 66 69 6c 65 2e 0a 2a 2f  fstrace_file..*/
05e0: 0a 73 74 61 74 69 63 20 69 6e 74 20 76 66 73 74  .static int vfst
05f0: 72 61 63 65 43 6c 6f 73 65 28 73 71 6c 69 74 65  raceClose(sqlite
0600: 33 5f 66 69 6c 65 2a 29 3b 0a 73 74 61 74 69 63  3_file*);.static
0610: 20 69 6e 74 20 76 66 73 74 72 61 63 65 52 65 61   int vfstraceRea
0620: 64 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 2a 2c  d(sqlite3_file*,
0630: 20 76 6f 69 64 2a 2c 20 69 6e 74 20 69 41 6d 74   void*, int iAmt
0640: 2c 20 73 71 6c 69 74 65 33 5f 69 6e 74 36 34 20  , sqlite3_int64 
0650: 69 4f 66 73 74 29 3b 0a 73 74 61 74 69 63 20 69  iOfst);.static i
0660: 6e 74 20 76 66 73 74 72 61 63 65 57 72 69 74 65  nt vfstraceWrite
0670: 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 2a 2c 63  (sqlite3_file*,c
0680: 6f 6e 73 74 20 76 6f 69 64 2a 2c 69 6e 74 20 69  onst void*,int i
0690: 41 6d 74 2c 20 73 71 6c 69 74 65 33 5f 69 6e 74  Amt, sqlite3_int
06a0: 36 34 29 3b 0a 73 74 61 74 69 63 20 69 6e 74 20  64);.static int 
06b0: 76 66 73 74 72 61 63 65 54 72 75 6e 63 61 74 65  vfstraceTruncate
06c0: 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 2a 2c 20  (sqlite3_file*, 
06d0: 73 71 6c 69 74 65 33 5f 69 6e 74 36 34 20 73 69  sqlite3_int64 si
06e0: 7a 65 29 3b 0a 73 74 61 74 69 63 20 69 6e 74 20  ze);.static int 
06f0: 76 66 73 74 72 61 63 65 53 79 6e 63 28 73 71 6c  vfstraceSync(sql
0700: 69 74 65 33 5f 66 69 6c 65 2a 2c 20 69 6e 74 20  ite3_file*, int 
0710: 66 6c 61 67 73 29 3b 0a 73 74 61 74 69 63 20 69  flags);.static i
0720: 6e 74 20 76 66 73 74 72 61 63 65 46 69 6c 65 53  nt vfstraceFileS
0730: 69 7a 65 28 73 71 6c 69 74 65 33 5f 66 69 6c 65  ize(sqlite3_file
0740: 2a 2c 20 73 71 6c 69 74 65 33 5f 69 6e 74 36 34  *, sqlite3_int64
0750: 20 2a 70 53 69 7a 65 29 3b 0a 73 74 61 74 69 63   *pSize);.static
0760: 20 69 6e 74 20 76 66 73 74 72 61 63 65 4c 6f 63   int vfstraceLoc
0770: 6b 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 2a 2c  k(sqlite3_file*,
0780: 20 69 6e 74 29 3b 0a 73 74 61 74 69 63 20 69 6e   int);.static in
0790: 74 20 76 66 73 74 72 61 63 65 55 6e 6c 6f 63 6b  t vfstraceUnlock
07a0: 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 2a 2c 20  (sqlite3_file*, 
07b0: 69 6e 74 29 3b 0a 73 74 61 74 69 63 20 69 6e 74  int);.static int
07c0: 20 76 66 73 74 72 61 63 65 43 68 65 63 6b 52 65   vfstraceCheckRe
07d0: 73 65 72 76 65 64 4c 6f 63 6b 28 73 71 6c 69 74  servedLock(sqlit
07e0: 65 33 5f 66 69 6c 65 2a 2c 20 69 6e 74 20 2a 29  e3_file*, int *)
07f0: 3b 0a 73 74 61 74 69 63 20 69 6e 74 20 76 66 73  ;.static int vfs
0800: 74 72 61 63 65 46 69 6c 65 43 6f 6e 74 72 6f 6c  traceFileControl
0810: 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 2a 2c 20  (sqlite3_file*, 
0820: 69 6e 74 20 6f 70 2c 20 76 6f 69 64 20 2a 70 41  int op, void *pA
0830: 72 67 29 3b 0a 73 74 61 74 69 63 20 69 6e 74 20  rg);.static int 
0840: 76 66 73 74 72 61 63 65 53 65 63 74 6f 72 53 69  vfstraceSectorSi
0850: 7a 65 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 2a  ze(sqlite3_file*
0860: 29 3b 0a 73 74 61 74 69 63 20 69 6e 74 20 76 66  );.static int vf
0870: 73 74 72 61 63 65 44 65 76 69 63 65 43 68 61 72  straceDeviceChar
0880: 61 63 74 65 72 69 73 74 69 63 73 28 73 71 6c 69  acteristics(sqli
0890: 74 65 33 5f 66 69 6c 65 2a 29 3b 0a 73 74 61 74  te3_file*);.stat
08a0: 69 63 20 69 6e 74 20 76 66 73 74 72 61 63 65 53  ic int vfstraceS
08b0: 68 6d 4c 6f 63 6b 28 73 71 6c 69 74 65 33 5f 66  hmLock(sqlite3_f
08c0: 69 6c 65 2a 2c 69 6e 74 2c 69 6e 74 2c 69 6e 74  ile*,int,int,int
08d0: 29 3b 0a 73 74 61 74 69 63 20 69 6e 74 20 76 66  );.static int vf
08e0: 73 74 72 61 63 65 53 68 6d 4d 61 70 28 73 71 6c  straceShmMap(sql
08f0: 69 74 65 33 5f 66 69 6c 65 2a 2c 69 6e 74 2c 69  ite3_file*,int,i
0900: 6e 74 2c 69 6e 74 2c 20 76 6f 69 64 20 76 6f 6c  nt,int, void vol
0910: 61 74 69 6c 65 20 2a 2a 29 3b 0a 73 74 61 74 69  atile **);.stati
0920: 63 20 76 6f 69 64 20 76 66 73 74 72 61 63 65 53  c void vfstraceS
0930: 68 6d 42 61 72 72 69 65 72 28 73 71 6c 69 74 65  hmBarrier(sqlite
0940: 33 5f 66 69 6c 65 2a 29 3b 0a 73 74 61 74 69 63  3_file*);.static
0950: 20 69 6e 74 20 76 66 73 74 72 61 63 65 53 68 6d   int vfstraceShm
0960: 55 6e 6d 61 70 28 73 71 6c 69 74 65 33 5f 66 69  Unmap(sqlite3_fi
0970: 6c 65 2a 2c 69 6e 74 29 3b 0a 0a 2f 2a 0a 2a 2a  le*,int);../*.**
0980: 20 4d 65 74 68 6f 64 20 64 65 63 6c 61 72 61 74   Method declarat
0990: 69 6f 6e 73 20 66 6f 72 20 76 66 73 74 72 61 63  ions for vfstrac
09a0: 65 5f 76 66 73 2e 0a 2a 2f 0a 73 74 61 74 69 63  e_vfs..*/.static
09b0: 20 69 6e 74 20 76 66 73 74 72 61 63 65 4f 70 65   int vfstraceOpe
09c0: 6e 28 73 71 6c 69 74 65 33 5f 76 66 73 2a 2c 20  n(sqlite3_vfs*, 
09d0: 63 6f 6e 73 74 20 63 68 61 72 20 2a 2c 20 73 71  const char *, sq
09e0: 6c 69 74 65 33 5f 66 69 6c 65 2a 2c 20 69 6e 74  lite3_file*, int
09f0: 20 2c 20 69 6e 74 20 2a 29 3b 0a 73 74 61 74 69   , int *);.stati
0a00: 63 20 69 6e 74 20 76 66 73 74 72 61 63 65 44 65  c int vfstraceDe
0a10: 6c 65 74 65 28 73 71 6c 69 74 65 33 5f 76 66 73  lete(sqlite3_vfs
0a20: 2a 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  *, const char *z
0a30: 4e 61 6d 65 2c 20 69 6e 74 20 73 79 6e 63 44 69  Name, int syncDi
0a40: 72 29 3b 0a 73 74 61 74 69 63 20 69 6e 74 20 76  r);.static int v
0a50: 66 73 74 72 61 63 65 41 63 63 65 73 73 28 73 71  fstraceAccess(sq
0a60: 6c 69 74 65 33 5f 76 66 73 2a 2c 20 63 6f 6e 73  lite3_vfs*, cons
0a70: 74 20 63 68 61 72 20 2a 7a 4e 61 6d 65 2c 20 69  t char *zName, i
0a80: 6e 74 20 66 6c 61 67 73 2c 20 69 6e 74 20 2a 29  nt flags, int *)
0a90: 3b 0a 73 74 61 74 69 63 20 69 6e 74 20 76 66 73  ;.static int vfs
0aa0: 74 72 61 63 65 46 75 6c 6c 50 61 74 68 6e 61 6d  traceFullPathnam
0ab0: 65 28 73 71 6c 69 74 65 33 5f 76 66 73 2a 2c 20  e(sqlite3_vfs*, 
0ac0: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 4e 61 6d  const char *zNam
0ad0: 65 2c 20 69 6e 74 2c 20 63 68 61 72 20 2a 29 3b  e, int, char *);
0ae0: 0a 73 74 61 74 69 63 20 76 6f 69 64 20 2a 76 66  .static void *vf
0af0: 73 74 72 61 63 65 44 6c 4f 70 65 6e 28 73 71 6c  straceDlOpen(sql
0b00: 69 74 65 33 5f 76 66 73 2a 2c 20 63 6f 6e 73 74  ite3_vfs*, const
0b10: 20 63 68 61 72 20 2a 7a 46 69 6c 65 6e 61 6d 65   char *zFilename
0b20: 29 3b 0a 73 74 61 74 69 63 20 76 6f 69 64 20 76  );.static void v
0b30: 66 73 74 72 61 63 65 44 6c 45 72 72 6f 72 28 73  fstraceDlError(s
0b40: 71 6c 69 74 65 33 5f 76 66 73 2a 2c 20 69 6e 74  qlite3_vfs*, int
0b50: 20 6e 42 79 74 65 2c 20 63 68 61 72 20 2a 7a 45   nByte, char *zE
0b60: 72 72 4d 73 67 29 3b 0a 73 74 61 74 69 63 20 76  rrMsg);.static v
0b70: 6f 69 64 20 28 2a 76 66 73 74 72 61 63 65 44 6c  oid (*vfstraceDl
0b80: 53 79 6d 28 73 71 6c 69 74 65 33 5f 76 66 73 2a  Sym(sqlite3_vfs*
0b90: 2c 76 6f 69 64 2a 2c 20 63 6f 6e 73 74 20 63 68  ,void*, const ch
0ba0: 61 72 20 2a 7a 53 79 6d 62 6f 6c 29 29 28 76 6f  ar *zSymbol))(vo
0bb0: 69 64 29 3b 0a 73 74 61 74 69 63 20 76 6f 69 64  id);.static void
0bc0: 20 76 66 73 74 72 61 63 65 44 6c 43 6c 6f 73 65   vfstraceDlClose
0bd0: 28 73 71 6c 69 74 65 33 5f 76 66 73 2a 2c 20 76  (sqlite3_vfs*, v
0be0: 6f 69 64 2a 29 3b 0a 73 74 61 74 69 63 20 69 6e  oid*);.static in
0bf0: 74 20 76 66 73 74 72 61 63 65 52 61 6e 64 6f 6d  t vfstraceRandom
0c00: 6e 65 73 73 28 73 71 6c 69 74 65 33 5f 76 66 73  ness(sqlite3_vfs
0c10: 2a 2c 20 69 6e 74 20 6e 42 79 74 65 2c 20 63 68  *, int nByte, ch
0c20: 61 72 20 2a 7a 4f 75 74 29 3b 0a 73 74 61 74 69  ar *zOut);.stati
0c30: 63 20 69 6e 74 20 76 66 73 74 72 61 63 65 53 6c  c int vfstraceSl
0c40: 65 65 70 28 73 71 6c 69 74 65 33 5f 76 66 73 2a  eep(sqlite3_vfs*
0c50: 2c 20 69 6e 74 20 6d 69 63 72 6f 73 65 63 6f 6e  , int microsecon
0c60: 64 73 29 3b 0a 73 74 61 74 69 63 20 69 6e 74 20  ds);.static int 
0c70: 76 66 73 74 72 61 63 65 43 75 72 72 65 6e 74 54  vfstraceCurrentT
0c80: 69 6d 65 28 73 71 6c 69 74 65 33 5f 76 66 73 2a  ime(sqlite3_vfs*
0c90: 2c 20 64 6f 75 62 6c 65 2a 29 3b 0a 73 74 61 74  , double*);.stat
0ca0: 69 63 20 69 6e 74 20 76 66 73 74 72 61 63 65 47  ic int vfstraceG
0cb0: 65 74 4c 61 73 74 45 72 72 6f 72 28 73 71 6c 69  etLastError(sqli
0cc0: 74 65 33 5f 76 66 73 2a 2c 20 69 6e 74 2c 20 63  te3_vfs*, int, c
0cd0: 68 61 72 2a 29 3b 0a 73 74 61 74 69 63 20 69 6e  har*);.static in
0ce0: 74 20 76 66 73 74 72 61 63 65 43 75 72 72 65 6e  t vfstraceCurren
0cf0: 74 54 69 6d 65 49 6e 74 36 34 28 73 71 6c 69 74  tTimeInt64(sqlit
0d00: 65 33 5f 76 66 73 2a 2c 20 73 71 6c 69 74 65 33  e3_vfs*, sqlite3
0d10: 5f 69 6e 74 36 34 2a 29 3b 0a 73 74 61 74 69 63  _int64*);.static
0d20: 20 69 6e 74 20 76 66 73 74 72 61 63 65 53 65 74   int vfstraceSet
0d30: 53 79 73 74 65 6d 43 61 6c 6c 28 73 71 6c 69 74  SystemCall(sqlit
0d40: 65 33 5f 76 66 73 2a 2c 63 6f 6e 73 74 20 63 68  e3_vfs*,const ch
0d50: 61 72 2a 2c 20 73 71 6c 69 74 65 33 5f 73 79 73  ar*, sqlite3_sys
0d60: 63 61 6c 6c 5f 70 74 72 29 3b 0a 73 74 61 74 69  call_ptr);.stati
0d70: 63 20 73 71 6c 69 74 65 33 5f 73 79 73 63 61 6c  c sqlite3_syscal
0d80: 6c 5f 70 74 72 20 76 66 73 74 72 61 63 65 47 65  l_ptr vfstraceGe
0d90: 74 53 79 73 74 65 6d 43 61 6c 6c 28 73 71 6c 69  tSystemCall(sqli
0da0: 74 65 33 5f 76 66 73 2a 2c 20 63 6f 6e 73 74 20  te3_vfs*, const 
0db0: 63 68 61 72 20 2a 29 3b 0a 73 74 61 74 69 63 20  char *);.static 
0dc0: 63 6f 6e 73 74 20 63 68 61 72 20 2a 76 66 73 74  const char *vfst
0dd0: 72 61 63 65 4e 65 78 74 53 79 73 74 65 6d 43 61  raceNextSystemCa
0de0: 6c 6c 28 73 71 6c 69 74 65 33 5f 76 66 73 2a 2c  ll(sqlite3_vfs*,
0df0: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 4e 61   const char *zNa
0e00: 6d 65 29 3b 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75  me);../*.** Retu
0e10: 72 6e 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20  rn a pointer to 
0e20: 74 68 65 20 74 61 69 6c 20 6f 66 20 74 68 65 20  the tail of the 
0e30: 70 61 74 68 6e 61 6d 65 2e 20 20 45 78 61 6d 70  pathname.  Examp
0e40: 6c 65 73 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20 2f  les:.**.**     /
0e50: 68 6f 6d 65 2f 64 72 68 2f 78 79 7a 7a 79 2e 74  home/drh/xyzzy.t
0e60: 78 74 20 2d 3e 20 78 79 7a 7a 79 2e 74 78 74 0a  xt -> xyzzy.txt.
0e70: 2a 2a 20 20 20 20 20 78 79 7a 7a 79 2e 74 78 74  **     xyzzy.txt
0e80: 20 20 20 20 20 20 20 20 20 20 20 2d 3e 20 78 79             -> xy
0e90: 7a 7a 79 2e 74 78 74 0a 2a 2f 0a 73 74 61 74 69  zzy.txt.*/.stati
0ea0: 63 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 66 69  c const char *fi
0eb0: 6c 65 54 61 69 6c 28 63 6f 6e 73 74 20 63 68 61  leTail(const cha
0ec0: 72 20 2a 7a 29 7b 0a 20 20 69 6e 74 20 69 3b 0a  r *z){.  int i;.
0ed0: 20 20 69 66 28 20 7a 3d 3d 30 20 29 20 72 65 74    if( z==0 ) ret
0ee0: 75 72 6e 20 30 3b 0a 20 20 69 20 3d 20 73 74 72  urn 0;.  i = str
0ef0: 6c 65 6e 28 7a 29 2d 31 3b 0a 20 20 77 68 69 6c  len(z)-1;.  whil
0f00: 65 28 20 69 3e 30 20 26 26 20 7a 5b 69 2d 31 5d  e( i>0 && z[i-1]
0f10: 21 3d 27 2f 27 20 29 7b 20 69 2d 2d 3b 20 7d 0a  !='/' ){ i--; }.
0f20: 20 20 72 65 74 75 72 6e 20 26 7a 5b 69 5d 3b 0a    return &z[i];.
0f30: 7d 0a 0a 2f 2a 0a 2a 2a 20 53 65 6e 64 20 74 72  }../*.** Send tr
0f40: 61 63 65 20 6f 75 74 70 75 74 20 64 65 66 69 6e  ace output defin
0f50: 65 64 20 62 79 20 7a 46 6f 72 6d 61 74 20 61 6e  ed by zFormat an
0f60: 64 20 73 75 62 73 65 71 75 65 6e 74 20 61 72 67  d subsequent arg
0f70: 75 6d 65 6e 74 73 2e 0a 2a 2f 0a 73 74 61 74 69  uments..*/.stati
0f80: 63 20 76 6f 69 64 20 76 66 73 74 72 61 63 65 5f  c void vfstrace_
0f90: 70 72 69 6e 74 66 28 0a 20 20 76 66 73 74 72 61  printf(.  vfstra
0fa0: 63 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 2c 0a  ce_info *pInfo,.
0fb0: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 46    const char *zF
0fc0: 6f 72 6d 61 74 2c 0a 20 20 2e 2e 2e 0a 29 7b 0a  ormat,.  ....){.
0fd0: 20 20 76 61 5f 6c 69 73 74 20 61 70 3b 0a 20 20    va_list ap;.  
0fe0: 63 68 61 72 20 2a 7a 4d 73 67 3b 0a 20 20 76 61  char *zMsg;.  va
0ff0: 5f 73 74 61 72 74 28 61 70 2c 20 7a 46 6f 72 6d  _start(ap, zForm
1000: 61 74 29 3b 0a 20 20 7a 4d 73 67 20 3d 20 73 71  at);.  zMsg = sq
1010: 6c 69 74 65 33 5f 76 6d 70 72 69 6e 74 66 28 7a  lite3_vmprintf(z
1020: 46 6f 72 6d 61 74 2c 20 61 70 29 3b 0a 20 20 76  Format, ap);.  v
1030: 61 5f 65 6e 64 28 61 70 29 3b 0a 20 20 70 49 6e  a_end(ap);.  pIn
1040: 66 6f 2d 3e 78 4f 75 74 28 7a 4d 73 67 2c 20 70  fo->xOut(zMsg, p
1050: 49 6e 66 6f 2d 3e 70 4f 75 74 41 72 67 29 3b 0a  Info->pOutArg);.
1060: 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28 7a    sqlite3_free(z
1070: 4d 73 67 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43  Msg);.}../*.** C
1080: 6f 6e 76 65 72 74 20 76 61 6c 75 65 20 72 63 20  onvert value rc 
1090: 69 6e 74 6f 20 61 20 73 74 72 69 6e 67 20 61 6e  into a string an
10a0: 64 20 70 72 69 6e 74 20 69 74 20 75 73 69 6e 67  d print it using
10b0: 20 7a 46 6f 72 6d 61 74 2e 20 20 7a 46 6f 72 6d   zFormat.  zForm
10c0: 61 74 0a 2a 2a 20 73 68 6f 75 6c 64 20 68 61 76  at.** should hav
10d0: 65 20 65 78 61 63 74 6c 79 20 6f 6e 65 20 25 73  e exactly one %s
10e0: 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20  .*/.static void 
10f0: 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74 5f 65  vfstrace_print_e
1100: 72 72 63 6f 64 65 28 0a 20 20 76 66 73 74 72 61  rrcode(.  vfstra
1110: 63 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 2c 0a  ce_info *pInfo,.
1120: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 46    const char *zF
1130: 6f 72 6d 61 74 2c 0a 20 20 69 6e 74 20 72 63 0a  ormat,.  int rc.
1140: 29 7b 0a 20 20 63 68 61 72 20 7a 42 75 66 5b 35  ){.  char zBuf[5
1150: 30 5d 3b 0a 20 20 63 68 61 72 20 2a 7a 56 61 6c  0];.  char *zVal
1160: 3b 0a 20 20 73 77 69 74 63 68 28 20 72 63 20 29  ;.  switch( rc )
1170: 7b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  {.    case SQLIT
1180: 45 5f 4f 4b 3a 20 20 20 20 20 20 20 20 20 7a 56  E_OK:         zV
1190: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 4f 4b 22  al = "SQLITE_OK"
11a0: 3b 20 20 20 20 20 20 20 20 20 20 62 72 65 61 6b  ;          break
11b0: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
11c0: 45 5f 45 52 52 4f 52 3a 20 20 20 20 20 20 7a 56  E_ERROR:      zV
11d0: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 45 52 52  al = "SQLITE_ERR
11e0: 4f 52 22 3b 20 20 20 20 20 20 20 62 72 65 61 6b  OR";       break
11f0: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
1200: 45 5f 50 45 52 4d 3a 20 20 20 20 20 20 20 7a 56  E_PERM:       zV
1210: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 50 45 52  al = "SQLITE_PER
1220: 4d 22 3b 20 20 20 20 20 20 20 20 62 72 65 61 6b  M";        break
1230: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
1240: 45 5f 41 42 4f 52 54 3a 20 20 20 20 20 20 7a 56  E_ABORT:      zV
1250: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 41 42 4f  al = "SQLITE_ABO
1260: 52 54 22 3b 20 20 20 20 20 20 20 62 72 65 61 6b  RT";       break
1270: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
1280: 45 5f 42 55 53 59 3a 20 20 20 20 20 20 20 7a 56  E_BUSY:       zV
1290: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 42 55 53  al = "SQLITE_BUS
12a0: 59 22 3b 20 20 20 20 20 20 20 20 62 72 65 61 6b  Y";        break
12b0: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
12c0: 45 5f 4e 4f 4d 45 4d 3a 20 20 20 20 20 20 7a 56  E_NOMEM:      zV
12d0: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 4e 4f 4d  al = "SQLITE_NOM
12e0: 45 4d 22 3b 20 20 20 20 20 20 20 62 72 65 61 6b  EM";       break
12f0: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
1300: 45 5f 52 45 41 44 4f 4e 4c 59 3a 20 20 20 7a 56  E_READONLY:   zV
1310: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 52 45 41  al = "SQLITE_REA
1320: 44 4f 4e 4c 59 22 3b 20 20 20 20 62 72 65 61 6b  DONLY";    break
1330: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
1340: 45 5f 49 4e 54 45 52 52 55 50 54 3a 20 20 7a 56  E_INTERRUPT:  zV
1350: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49 4e 54  al = "SQLITE_INT
1360: 45 52 52 55 50 54 22 3b 20 20 20 62 72 65 61 6b  ERRUPT";   break
1370: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
1380: 45 5f 49 4f 45 52 52 3a 20 20 20 20 20 20 7a 56  E_IOERR:      zV
1390: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49 4f 45  al = "SQLITE_IOE
13a0: 52 52 22 3b 20 20 20 20 20 20 20 62 72 65 61 6b  RR";       break
13b0: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
13c0: 45 5f 43 4f 52 52 55 50 54 3a 20 20 20 20 7a 56  E_CORRUPT:    zV
13d0: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 43 4f 52  al = "SQLITE_COR
13e0: 52 55 50 54 22 3b 20 20 20 20 20 62 72 65 61 6b  RUPT";     break
13f0: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
1400: 45 5f 46 55 4c 4c 3a 20 20 20 20 20 20 20 7a 56  E_FULL:       zV
1410: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 46 55 4c  al = "SQLITE_FUL
1420: 4c 22 3b 20 20 20 20 20 20 20 20 62 72 65 61 6b  L";        break
1430: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
1440: 45 5f 43 41 4e 54 4f 50 45 4e 3a 20 20 20 7a 56  E_CANTOPEN:   zV
1450: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 43 41 4e  al = "SQLITE_CAN
1460: 54 4f 50 45 4e 22 3b 20 20 20 20 62 72 65 61 6b  TOPEN";    break
1470: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
1480: 45 5f 50 52 4f 54 4f 43 4f 4c 3a 20 20 20 7a 56  E_PROTOCOL:   zV
1490: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 50 52 4f  al = "SQLITE_PRO
14a0: 54 4f 43 4f 4c 22 3b 20 20 20 20 62 72 65 61 6b  TOCOL";    break
14b0: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
14c0: 45 5f 45 4d 50 54 59 3a 20 20 20 20 20 20 7a 56  E_EMPTY:      zV
14d0: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 45 4d 50  al = "SQLITE_EMP
14e0: 54 59 22 3b 20 20 20 20 20 20 20 62 72 65 61 6b  TY";       break
14f0: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
1500: 45 5f 53 43 48 45 4d 41 3a 20 20 20 20 20 7a 56  E_SCHEMA:     zV
1510: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 53 43 48  al = "SQLITE_SCH
1520: 45 4d 41 22 3b 20 20 20 20 20 20 62 72 65 61 6b  EMA";      break
1530: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
1540: 45 5f 43 4f 4e 53 54 52 41 49 4e 54 3a 20 7a 56  E_CONSTRAINT: zV
1550: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 43 4f 4e  al = "SQLITE_CON
1560: 53 54 52 41 49 4e 54 22 3b 20 20 62 72 65 61 6b  STRAINT";  break
1570: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
1580: 45 5f 4d 49 53 4d 41 54 43 48 3a 20 20 20 7a 56  E_MISMATCH:   zV
1590: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 4d 49 53  al = "SQLITE_MIS
15a0: 4d 41 54 43 48 22 3b 20 20 20 20 62 72 65 61 6b  MATCH";    break
15b0: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
15c0: 45 5f 4d 49 53 55 53 45 3a 20 20 20 20 20 7a 56  E_MISUSE:     zV
15d0: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 4d 49 53  al = "SQLITE_MIS
15e0: 55 53 45 22 3b 20 20 20 20 20 20 62 72 65 61 6b  USE";      break
15f0: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
1600: 45 5f 4e 4f 4c 46 53 3a 20 20 20 20 20 20 7a 56  E_NOLFS:      zV
1610: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 4e 4f 4c  al = "SQLITE_NOL
1620: 46 53 22 3b 20 20 20 20 20 20 20 62 72 65 61 6b  FS";       break
1630: 3b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54  ;.    case SQLIT
1640: 45 5f 49 4f 45 52 52 5f 52 45 41 44 3a 20 20 20  E_IOERR_READ:   
1650: 20 20 20 20 20 20 7a 56 61 6c 20 3d 20 22 53 51        zVal = "SQ
1660: 4c 49 54 45 5f 49 4f 45 52 52 5f 52 45 41 44 22  LITE_IOERR_READ"
1670: 3b 20 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b  ;         break;
1680: 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54 45  .    case SQLITE
1690: 5f 49 4f 45 52 52 5f 53 48 4f 52 54 5f 52 45 41  _IOERR_SHORT_REA
16a0: 44 3a 20 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c  D:   zVal = "SQL
16b0: 49 54 45 5f 49 4f 45 52 52 5f 53 48 4f 52 54 5f  ITE_IOERR_SHORT_
16c0: 52 45 41 44 22 3b 20 20 20 62 72 65 61 6b 3b 0a  READ";   break;.
16d0: 20 20 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f      case SQLITE_
16e0: 49 4f 45 52 52 5f 57 52 49 54 45 3a 20 20 20 20  IOERR_WRITE:    
16f0: 20 20 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49      zVal = "SQLI
1700: 54 45 5f 49 4f 45 52 52 5f 57 52 49 54 45 22 3b  TE_IOERR_WRITE";
1710: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20          break;. 
1720: 20 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f 49     case SQLITE_I
1730: 4f 45 52 52 5f 46 53 59 4e 43 3a 20 20 20 20 20  OERR_FSYNC:     
1740: 20 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54     zVal = "SQLIT
1750: 45 5f 49 4f 45 52 52 5f 46 53 59 4e 43 22 3b 20  E_IOERR_FSYNC"; 
1760: 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20         break;.  
1770: 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f 49 4f    case SQLITE_IO
1780: 45 52 52 5f 44 49 52 5f 46 53 59 4e 43 3a 20 20  ERR_DIR_FSYNC:  
1790: 20 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45    zVal = "SQLITE
17a0: 5f 49 4f 45 52 52 5f 44 49 52 5f 46 53 59 4e 43  _IOERR_DIR_FSYNC
17b0: 22 3b 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20  ";    break;.   
17c0: 20 63 61 73 65 20 53 51 4c 49 54 45 5f 49 4f 45   case SQLITE_IOE
17d0: 52 52 5f 54 52 55 4e 43 41 54 45 3a 20 20 20 20  RR_TRUNCATE:    
17e0: 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f   zVal = "SQLITE_
17f0: 49 4f 45 52 52 5f 54 52 55 4e 43 41 54 45 22 3b  IOERR_TRUNCATE";
1800: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
1810: 63 61 73 65 20 53 51 4c 49 54 45 5f 49 4f 45 52  case SQLITE_IOER
1820: 52 5f 46 53 54 41 54 3a 20 20 20 20 20 20 20 20  R_FSTAT:        
1830: 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49  zVal = "SQLITE_I
1840: 4f 45 52 52 5f 46 53 54 41 54 22 3b 20 20 20 20  OERR_FSTAT";    
1850: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63      break;.    c
1860: 61 73 65 20 53 51 4c 49 54 45 5f 49 4f 45 52 52  ase SQLITE_IOERR
1870: 5f 55 4e 4c 4f 43 4b 3a 20 20 20 20 20 20 20 7a  _UNLOCK:       z
1880: 56 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49 4f  Val = "SQLITE_IO
1890: 45 52 52 5f 55 4e 4c 4f 43 4b 22 3b 20 20 20 20  ERR_UNLOCK";    
18a0: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61     break;.    ca
18b0: 73 65 20 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f  se SQLITE_IOERR_
18c0: 52 44 4c 4f 43 4b 3a 20 20 20 20 20 20 20 7a 56  RDLOCK:       zV
18d0: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49 4f 45  al = "SQLITE_IOE
18e0: 52 52 5f 52 44 4c 4f 43 4b 22 3b 20 20 20 20 20  RR_RDLOCK";     
18f0: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73    break;.    cas
1900: 65 20 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f 44  e SQLITE_IOERR_D
1910: 45 4c 45 54 45 3a 20 20 20 20 20 20 20 7a 56 61  ELETE:       zVa
1920: 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49 4f 45 52  l = "SQLITE_IOER
1930: 52 5f 44 45 4c 45 54 45 22 3b 20 20 20 20 20 20  R_DELETE";      
1940: 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65   break;.    case
1950: 20 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f 42 4c   SQLITE_IOERR_BL
1960: 4f 43 4b 45 44 3a 20 20 20 20 20 20 7a 56 61 6c  OCKED:      zVal
1970: 20 3d 20 22 53 51 4c 49 54 45 5f 49 4f 45 52 52   = "SQLITE_IOERR
1980: 5f 42 4c 4f 43 4b 45 44 22 3b 20 20 20 20 20 20  _BLOCKED";      
1990: 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20  break;.    case 
19a0: 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f 4e 4f 4d  SQLITE_IOERR_NOM
19b0: 45 4d 3a 20 20 20 20 20 20 20 20 7a 56 61 6c 20  EM:        zVal 
19c0: 3d 20 22 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f  = "SQLITE_IOERR_
19d0: 4e 4f 4d 45 4d 22 3b 20 20 20 20 20 20 20 20 62  NOMEM";        b
19e0: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
19f0: 51 4c 49 54 45 5f 49 4f 45 52 52 5f 41 43 43 45  QLITE_IOERR_ACCE
1a00: 53 53 3a 20 20 20 20 20 20 20 7a 56 61 6c 20 3d  SS:       zVal =
1a10: 20 22 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f 41   "SQLITE_IOERR_A
1a20: 43 43 45 53 53 22 3b 20 20 20 20 20 20 20 62 72  CCESS";       br
1a30: 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53 51  eak;.    case SQ
1a40: 4c 49 54 45 5f 49 4f 45 52 52 5f 43 48 45 43 4b  LITE_IOERR_CHECK
1a50: 52 45 53 45 52 56 45 44 4c 4f 43 4b 3a 0a 20 20  RESERVEDLOCK:.  
1a60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1a70: 20 20 20 20 20 20 20 20 20 20 20 20 20 7a 56 61               zVa
1a80: 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49 4f 45 52  l = "SQLITE_IOER
1a90: 52 5f 43 48 45 43 4b 52 45 53 45 52 56 45 44 4c  R_CHECKRESERVEDL
1aa0: 4f 43 4b 22 3b 20 62 72 65 61 6b 3b 0a 20 20 20  OCK"; break;.   
1ab0: 20 63 61 73 65 20 53 51 4c 49 54 45 5f 49 4f 45   case SQLITE_IOE
1ac0: 52 52 5f 4c 4f 43 4b 3a 20 20 20 20 20 20 20 20  RR_LOCK:        
1ad0: 20 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f   zVal = "SQLITE_
1ae0: 49 4f 45 52 52 5f 4c 4f 43 4b 22 3b 20 20 20 20  IOERR_LOCK";    
1af0: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
1b00: 63 61 73 65 20 53 51 4c 49 54 45 5f 49 4f 45 52  case SQLITE_IOER
1b10: 52 5f 43 4c 4f 53 45 3a 20 20 20 20 20 20 20 20  R_CLOSE:        
1b20: 7a 56 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49  zVal = "SQLITE_I
1b30: 4f 45 52 52 5f 43 4c 4f 53 45 22 3b 20 20 20 20  OERR_CLOSE";    
1b40: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63      break;.    c
1b50: 61 73 65 20 53 51 4c 49 54 45 5f 49 4f 45 52 52  ase SQLITE_IOERR
1b60: 5f 44 49 52 5f 43 4c 4f 53 45 3a 20 20 20 20 7a  _DIR_CLOSE:    z
1b70: 56 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49 4f  Val = "SQLITE_IO
1b80: 45 52 52 5f 44 49 52 5f 43 4c 4f 53 45 22 3b 20  ERR_DIR_CLOSE"; 
1b90: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61     break;.    ca
1ba0: 73 65 20 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f  se SQLITE_IOERR_
1bb0: 53 48 4d 4f 50 45 4e 3a 20 20 20 20 20 20 7a 56  SHMOPEN:      zV
1bc0: 61 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49 4f 45  al = "SQLITE_IOE
1bd0: 52 52 5f 53 48 4d 4f 50 45 4e 22 3b 20 20 20 20  RR_SHMOPEN";    
1be0: 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73    break;.    cas
1bf0: 65 20 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f 53  e SQLITE_IOERR_S
1c00: 48 4d 53 49 5a 45 3a 20 20 20 20 20 20 7a 56 61  HMSIZE:      zVa
1c10: 6c 20 3d 20 22 53 51 4c 49 54 45 5f 49 4f 45 52  l = "SQLITE_IOER
1c20: 52 5f 53 48 4d 53 49 5a 45 22 3b 20 20 20 20 20  R_SHMSIZE";     
1c30: 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65   break;.    case
1c40: 20 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f 53 48   SQLITE_IOERR_SH
1c50: 4d 4c 4f 43 4b 3a 20 20 20 20 20 20 7a 56 61 6c  MLOCK:      zVal
1c60: 20 3d 20 22 53 51 4c 49 54 45 5f 49 4f 45 52 52   = "SQLITE_IOERR
1c70: 5f 53 48 4d 4c 4f 43 4b 22 3b 20 20 20 20 20 20  _SHMLOCK";      
1c80: 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20  break;.    case 
1c90: 53 51 4c 49 54 45 5f 4c 4f 43 4b 45 44 5f 53 48  SQLITE_LOCKED_SH
1ca0: 41 52 45 44 43 41 43 48 45 3a 20 7a 56 61 6c 20  AREDCACHE: zVal 
1cb0: 3d 20 22 53 51 4c 49 54 45 5f 4c 4f 43 4b 45 44  = "SQLITE_LOCKED
1cc0: 5f 53 48 41 52 45 44 43 41 43 48 45 22 3b 20 62  _SHAREDCACHE"; b
1cd0: 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53  reak;.    case S
1ce0: 51 4c 49 54 45 5f 42 55 53 59 5f 52 45 43 4f 56  QLITE_BUSY_RECOV
1cf0: 45 52 59 3a 20 20 20 20 20 20 7a 56 61 6c 20 3d  ERY:      zVal =
1d00: 20 22 53 51 4c 49 54 45 5f 42 55 53 59 5f 52 45   "SQLITE_BUSY_RE
1d10: 43 4f 56 45 52 59 22 3b 20 20 20 20 20 20 62 72  COVERY";      br
1d20: 65 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 53 51  eak;.    case SQ
1d30: 4c 49 54 45 5f 43 41 4e 54 4f 50 45 4e 5f 4e 4f  LITE_CANTOPEN_NO
1d40: 54 45 4d 50 44 49 52 3a 20 7a 56 61 6c 20 3d 20  TEMPDIR: zVal = 
1d50: 22 53 51 4c 49 54 45 5f 43 41 4e 54 4f 50 45 4e  "SQLITE_CANTOPEN
1d60: 5f 4e 4f 54 45 4d 50 44 49 52 22 3b 20 62 72 65  _NOTEMPDIR"; bre
1d70: 61 6b 3b 0a 20 20 20 20 64 65 66 61 75 6c 74 3a  ak;.    default:
1d80: 20 7b 0a 20 20 20 20 20 20 20 73 71 6c 69 74 65   {.       sqlite
1d90: 33 5f 73 6e 70 72 69 6e 74 66 28 73 69 7a 65 6f  3_snprintf(sizeo
1da0: 66 28 7a 42 75 66 29 2c 20 7a 42 75 66 2c 20 22  f(zBuf), zBuf, "
1db0: 25 64 22 2c 20 72 63 29 3b 0a 20 20 20 20 20 20  %d", rc);.      
1dc0: 20 7a 56 61 6c 20 3d 20 7a 42 75 66 3b 0a 20 20   zVal = zBuf;.  
1dd0: 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20       break;.    
1de0: 7d 0a 20 20 7d 0a 20 20 76 66 73 74 72 61 63 65  }.  }.  vfstrace
1df0: 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20 7a  _printf(pInfo, z
1e00: 46 6f 72 6d 61 74 2c 20 7a 56 61 6c 29 3b 0a 7d  Format, zVal);.}
1e10: 0a 0a 2f 2a 0a 2a 2a 20 41 70 70 65 6e 64 20 74  ../*.** Append t
1e20: 6f 20 61 20 62 75 66 66 65 72 2e 0a 2a 2f 0a 73  o a buffer..*/.s
1e30: 74 61 74 69 63 20 76 6f 69 64 20 73 74 72 61 70  tatic void strap
1e40: 70 65 6e 64 28 63 68 61 72 20 2a 7a 2c 20 69 6e  pend(char *z, in
1e50: 74 20 2a 70 49 2c 20 63 6f 6e 73 74 20 63 68 61  t *pI, const cha
1e60: 72 20 2a 7a 41 70 70 65 6e 64 29 7b 0a 20 20 69  r *zAppend){.  i
1e70: 6e 74 20 69 20 3d 20 2a 70 49 3b 0a 20 20 77 68  nt i = *pI;.  wh
1e80: 69 6c 65 28 20 7a 41 70 70 65 6e 64 5b 30 5d 20  ile( zAppend[0] 
1e90: 29 7b 20 7a 5b 69 2b 2b 5d 20 3d 20 2a 28 7a 41  ){ z[i++] = *(zA
1ea0: 70 70 65 6e 64 2b 2b 29 3b 20 7d 0a 20 20 7a 5b  ppend++); }.  z[
1eb0: 69 5d 20 3d 20 30 3b 0a 20 20 2a 70 49 20 3d 20  i] = 0;.  *pI = 
1ec0: 69 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 6c 6f 73  i;.}../*.** Clos
1ed0: 65 20 61 6e 20 76 66 73 74 72 61 63 65 2d 66 69  e an vfstrace-fi
1ee0: 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e  le..*/.static in
1ef0: 74 20 76 66 73 74 72 61 63 65 43 6c 6f 73 65 28  t vfstraceClose(
1f00: 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46  sqlite3_file *pF
1f10: 69 6c 65 29 7b 0a 20 20 76 66 73 74 72 61 63 65  ile){.  vfstrace
1f20: 5f 66 69 6c 65 20 2a 70 20 3d 20 28 76 66 73 74  _file *p = (vfst
1f30: 72 61 63 65 5f 66 69 6c 65 20 2a 29 70 46 69 6c  race_file *)pFil
1f40: 65 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 69 6e  e;.  vfstrace_in
1f50: 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 70 2d 3e 70  fo *pInfo = p->p
1f60: 49 6e 66 6f 3b 0a 20 20 69 6e 74 20 72 63 3b 0a  Info;.  int rc;.
1f70: 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74    vfstrace_print
1f80: 66 28 70 49 6e 66 6f 2c 20 22 25 73 2e 78 43 6c  f(pInfo, "%s.xCl
1f90: 6f 73 65 28 25 73 29 22 2c 20 70 49 6e 66 6f 2d  ose(%s)", pInfo-
1fa0: 3e 7a 56 66 73 4e 61 6d 65 2c 20 70 2d 3e 7a 46  >zVfsName, p->zF
1fb0: 4e 61 6d 65 29 3b 0a 20 20 72 63 20 3d 20 70 2d  Name);.  rc = p-
1fc0: 3e 70 52 65 61 6c 2d 3e 70 4d 65 74 68 6f 64 73  >pReal->pMethods
1fd0: 2d 3e 78 43 6c 6f 73 65 28 70 2d 3e 70 52 65 61  ->xClose(p->pRea
1fe0: 6c 29 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 70  l);.  vfstrace_p
1ff0: 72 69 6e 74 5f 65 72 72 63 6f 64 65 28 70 49 6e  rint_errcode(pIn
2000: 66 6f 2c 20 22 20 2d 3e 20 25 73 5c 6e 22 2c 20  fo, " -> %s\n", 
2010: 72 63 29 3b 0a 20 20 69 66 28 20 72 63 3d 3d 53  rc);.  if( rc==S
2020: 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20  QLITE_OK ){.    
2030: 73 71 6c 69 74 65 33 5f 66 72 65 65 28 28 76 6f  sqlite3_free((vo
2040: 69 64 2a 29 70 2d 3e 62 61 73 65 2e 70 4d 65 74  id*)p->base.pMet
2050: 68 6f 64 73 29 3b 0a 20 20 20 20 70 2d 3e 62 61  hods);.    p->ba
2060: 73 65 2e 70 4d 65 74 68 6f 64 73 20 3d 20 30 3b  se.pMethods = 0;
2070: 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 72 63  .  }.  return rc
2080: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 61 64 20  ;.}../*.** Read 
2090: 64 61 74 61 20 66 72 6f 6d 20 61 6e 20 76 66 73  data from an vfs
20a0: 74 72 61 63 65 2d 66 69 6c 65 2e 0a 2a 2f 0a 73  trace-file..*/.s
20b0: 74 61 74 69 63 20 69 6e 74 20 76 66 73 74 72 61  tatic int vfstra
20c0: 63 65 52 65 61 64 28 0a 20 20 73 71 6c 69 74 65  ceRead(.  sqlite
20d0: 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c 20 0a  3_file *pFile, .
20e0: 20 20 76 6f 69 64 20 2a 7a 42 75 66 2c 20 0a 20    void *zBuf, . 
20f0: 20 69 6e 74 20 69 41 6d 74 2c 20 0a 20 20 73 71   int iAmt, .  sq
2100: 6c 69 74 65 5f 69 6e 74 36 34 20 69 4f 66 73 74  lite_int64 iOfst
2110: 0a 29 7b 0a 20 20 76 66 73 74 72 61 63 65 5f 66  .){.  vfstrace_f
2120: 69 6c 65 20 2a 70 20 3d 20 28 76 66 73 74 72 61  ile *p = (vfstra
2130: 63 65 5f 66 69 6c 65 20 2a 29 70 46 69 6c 65 3b  ce_file *)pFile;
2140: 0a 20 20 76 66 73 74 72 61 63 65 5f 69 6e 66 6f  .  vfstrace_info
2150: 20 2a 70 49 6e 66 6f 20 3d 20 70 2d 3e 70 49 6e   *pInfo = p->pIn
2160: 66 6f 3b 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20  fo;.  int rc;.  
2170: 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74 66 28  vfstrace_printf(
2180: 70 49 6e 66 6f 2c 20 22 25 73 2e 78 52 65 61 64  pInfo, "%s.xRead
2190: 28 25 73 2c 6e 3d 25 64 2c 6f 66 73 74 3d 25 6c  (%s,n=%d,ofst=%l
21a0: 6c 64 29 22 2c 0a 20 20 20 20 20 20 20 20 20 20  ld)",.          
21b0: 20 20 20 20 20 20 20 20 70 49 6e 66 6f 2d 3e 7a          pInfo->z
21c0: 56 66 73 4e 61 6d 65 2c 20 70 2d 3e 7a 46 4e 61  VfsName, p->zFNa
21d0: 6d 65 2c 20 69 41 6d 74 2c 20 69 4f 66 73 74 29  me, iAmt, iOfst)
21e0: 3b 0a 20 20 72 63 20 3d 20 70 2d 3e 70 52 65 61  ;.  rc = p->pRea
21f0: 6c 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 52 65  l->pMethods->xRe
2200: 61 64 28 70 2d 3e 70 52 65 61 6c 2c 20 7a 42 75  ad(p->pReal, zBu
2210: 66 2c 20 69 41 6d 74 2c 20 69 4f 66 73 74 29 3b  f, iAmt, iOfst);
2220: 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e  .  vfstrace_prin
2230: 74 5f 65 72 72 63 6f 64 65 28 70 49 6e 66 6f 2c  t_errcode(pInfo,
2240: 20 22 20 2d 3e 20 25 73 5c 6e 22 2c 20 72 63 29   " -> %s\n", rc)
2250: 3b 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d  ;.  return rc;.}
2260: 0a 0a 2f 2a 0a 2a 2a 20 57 72 69 74 65 20 64 61  ../*.** Write da
2270: 74 61 20 74 6f 20 61 6e 20 76 66 73 74 72 61 63  ta to an vfstrac
2280: 65 2d 66 69 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69  e-file..*/.stati
2290: 63 20 69 6e 74 20 76 66 73 74 72 61 63 65 57 72  c int vfstraceWr
22a0: 69 74 65 28 0a 20 20 73 71 6c 69 74 65 33 5f 66  ite(.  sqlite3_f
22b0: 69 6c 65 20 2a 70 46 69 6c 65 2c 20 0a 20 20 63  ile *pFile, .  c
22c0: 6f 6e 73 74 20 76 6f 69 64 20 2a 7a 42 75 66 2c  onst void *zBuf,
22d0: 20 0a 20 20 69 6e 74 20 69 41 6d 74 2c 20 0a 20   .  int iAmt, . 
22e0: 20 73 71 6c 69 74 65 5f 69 6e 74 36 34 20 69 4f   sqlite_int64 iO
22f0: 66 73 74 0a 29 7b 0a 20 20 76 66 73 74 72 61 63  fst.){.  vfstrac
2300: 65 5f 66 69 6c 65 20 2a 70 20 3d 20 28 76 66 73  e_file *p = (vfs
2310: 74 72 61 63 65 5f 66 69 6c 65 20 2a 29 70 46 69  trace_file *)pFi
2320: 6c 65 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 69  le;.  vfstrace_i
2330: 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 70 2d 3e  nfo *pInfo = p->
2340: 70 49 6e 66 6f 3b 0a 20 20 69 6e 74 20 72 63 3b  pInfo;.  int rc;
2350: 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e  .  vfstrace_prin
2360: 74 66 28 70 49 6e 66 6f 2c 20 22 25 73 2e 78 57  tf(pInfo, "%s.xW
2370: 72 69 74 65 28 25 73 2c 6e 3d 25 64 2c 6f 66 73  rite(%s,n=%d,ofs
2380: 74 3d 25 6c 6c 64 29 22 2c 0a 20 20 20 20 20 20  t=%lld)",.      
2390: 20 20 20 20 20 20 20 20 20 20 20 20 70 49 6e 66              pInf
23a0: 6f 2d 3e 7a 56 66 73 4e 61 6d 65 2c 20 70 2d 3e  o->zVfsName, p->
23b0: 7a 46 4e 61 6d 65 2c 20 69 41 6d 74 2c 20 69 4f  zFName, iAmt, iO
23c0: 66 73 74 29 3b 0a 20 20 72 63 20 3d 20 70 2d 3e  fst);.  rc = p->
23d0: 70 52 65 61 6c 2d 3e 70 4d 65 74 68 6f 64 73 2d  pReal->pMethods-
23e0: 3e 78 57 72 69 74 65 28 70 2d 3e 70 52 65 61 6c  >xWrite(p->pReal
23f0: 2c 20 7a 42 75 66 2c 20 69 41 6d 74 2c 20 69 4f  , zBuf, iAmt, iO
2400: 66 73 74 29 3b 0a 20 20 76 66 73 74 72 61 63 65  fst);.  vfstrace
2410: 5f 70 72 69 6e 74 5f 65 72 72 63 6f 64 65 28 70  _print_errcode(p
2420: 49 6e 66 6f 2c 20 22 20 2d 3e 20 25 73 5c 6e 22  Info, " -> %s\n"
2430: 2c 20 72 63 29 3b 0a 20 20 72 65 74 75 72 6e 20  , rc);.  return 
2440: 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 72 75  rc;.}../*.** Tru
2450: 6e 63 61 74 65 20 61 6e 20 76 66 73 74 72 61 63  ncate an vfstrac
2460: 65 2d 66 69 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69  e-file..*/.stati
2470: 63 20 69 6e 74 20 76 66 73 74 72 61 63 65 54 72  c int vfstraceTr
2480: 75 6e 63 61 74 65 28 73 71 6c 69 74 65 33 5f 66  uncate(sqlite3_f
2490: 69 6c 65 20 2a 70 46 69 6c 65 2c 20 73 71 6c 69  ile *pFile, sqli
24a0: 74 65 5f 69 6e 74 36 34 20 73 69 7a 65 29 7b 0a  te_int64 size){.
24b0: 20 20 76 66 73 74 72 61 63 65 5f 66 69 6c 65 20    vfstrace_file 
24c0: 2a 70 20 3d 20 28 76 66 73 74 72 61 63 65 5f 66  *p = (vfstrace_f
24d0: 69 6c 65 20 2a 29 70 46 69 6c 65 3b 0a 20 20 76  ile *)pFile;.  v
24e0: 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70 49  fstrace_info *pI
24f0: 6e 66 6f 20 3d 20 70 2d 3e 70 49 6e 66 6f 3b 0a  nfo = p->pInfo;.
2500: 20 20 69 6e 74 20 72 63 3b 0a 20 20 76 66 73 74    int rc;.  vfst
2510: 72 61 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66  race_printf(pInf
2520: 6f 2c 20 22 25 73 2e 78 54 72 75 6e 63 61 74 65  o, "%s.xTruncate
2530: 28 25 73 2c 25 6c 6c 64 29 22 2c 20 70 49 6e 66  (%s,%lld)", pInf
2540: 6f 2d 3e 7a 56 66 73 4e 61 6d 65 2c 20 70 2d 3e  o->zVfsName, p->
2550: 7a 46 4e 61 6d 65 2c 0a 20 20 20 20 20 20 20 20  zFName,.        
2560: 20 20 20 20 20 20 20 20 20 20 73 69 7a 65 29 3b            size);
2570: 0a 20 20 72 63 20 3d 20 70 2d 3e 70 52 65 61 6c  .  rc = p->pReal
2580: 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 54 72 75  ->pMethods->xTru
2590: 6e 63 61 74 65 28 70 2d 3e 70 52 65 61 6c 2c 20  ncate(p->pReal, 
25a0: 73 69 7a 65 29 3b 0a 20 20 76 66 73 74 72 61 63  size);.  vfstrac
25b0: 65 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20  e_printf(pInfo, 
25c0: 22 20 2d 3e 20 25 64 5c 6e 22 2c 20 72 63 29 3b  " -> %d\n", rc);
25d0: 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a  .  return rc;.}.
25e0: 0a 2f 2a 0a 2a 2a 20 53 79 6e 63 20 61 6e 20 76  ./*.** Sync an v
25f0: 66 73 74 72 61 63 65 2d 66 69 6c 65 2e 0a 2a 2f  fstrace-file..*/
2600: 0a 73 74 61 74 69 63 20 69 6e 74 20 76 66 73 74  .static int vfst
2610: 72 61 63 65 53 79 6e 63 28 73 71 6c 69 74 65 33  raceSync(sqlite3
2620: 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c 20 69 6e  _file *pFile, in
2630: 74 20 66 6c 61 67 73 29 7b 0a 20 20 76 66 73 74  t flags){.  vfst
2640: 72 61 63 65 5f 66 69 6c 65 20 2a 70 20 3d 20 28  race_file *p = (
2650: 76 66 73 74 72 61 63 65 5f 66 69 6c 65 20 2a 29  vfstrace_file *)
2660: 70 46 69 6c 65 3b 0a 20 20 76 66 73 74 72 61 63  pFile;.  vfstrac
2670: 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20  e_info *pInfo = 
2680: 70 2d 3e 70 49 6e 66 6f 3b 0a 20 20 69 6e 74 20  p->pInfo;.  int 
2690: 72 63 3b 0a 20 20 69 6e 74 20 69 3b 0a 20 20 63  rc;.  int i;.  c
26a0: 68 61 72 20 7a 42 75 66 5b 31 30 30 5d 3b 0a 20  har zBuf[100];. 
26b0: 20 6d 65 6d 63 70 79 28 7a 42 75 66 2c 20 22 7c   memcpy(zBuf, "|
26c0: 30 22 2c 20 33 29 3b 0a 20 20 69 20 3d 20 30 3b  0", 3);.  i = 0;
26d0: 0a 20 20 69 66 28 20 66 6c 61 67 73 20 26 20 53  .  if( flags & S
26e0: 51 4c 49 54 45 5f 53 59 4e 43 5f 46 55 4c 4c 20  QLITE_SYNC_FULL 
26f0: 29 20 20 20 20 20 20 20 20 73 74 72 61 70 70 65  )        strappe
2700: 6e 64 28 7a 42 75 66 2c 20 26 69 2c 20 22 7c 46  nd(zBuf, &i, "|F
2710: 55 4c 4c 22 29 3b 0a 20 20 65 6c 73 65 20 69 66  ULL");.  else if
2720: 28 20 66 6c 61 67 73 20 26 20 53 51 4c 49 54 45  ( flags & SQLITE
2730: 5f 53 59 4e 43 5f 4e 4f 52 4d 41 4c 20 29 20 73  _SYNC_NORMAL ) s
2740: 74 72 61 70 70 65 6e 64 28 7a 42 75 66 2c 20 26  trappend(zBuf, &
2750: 69 2c 20 22 7c 4e 4f 52 4d 41 4c 22 29 3b 0a 20  i, "|NORMAL");. 
2760: 20 69 66 28 20 66 6c 61 67 73 20 26 20 53 51 4c   if( flags & SQL
2770: 49 54 45 5f 53 59 4e 43 5f 44 41 54 41 4f 4e 4c  ITE_SYNC_DATAONL
2780: 59 20 29 20 20 20 20 73 74 72 61 70 70 65 6e 64  Y )    strappend
2790: 28 7a 42 75 66 2c 20 26 69 2c 20 22 7c 44 41 54  (zBuf, &i, "|DAT
27a0: 41 4f 4e 4c 59 22 29 3b 0a 20 20 69 66 28 20 66  AONLY");.  if( f
27b0: 6c 61 67 73 20 26 20 7e 28 53 51 4c 49 54 45 5f  lags & ~(SQLITE_
27c0: 53 59 4e 43 5f 46 55 4c 4c 7c 53 51 4c 49 54 45  SYNC_FULL|SQLITE
27d0: 5f 53 59 4e 43 5f 44 41 54 41 4f 4e 4c 59 29 20  _SYNC_DATAONLY) 
27e0: 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 73  ){.    sqlite3_s
27f0: 6e 70 72 69 6e 74 66 28 73 69 7a 65 6f 66 28 7a  nprintf(sizeof(z
2800: 42 75 66 29 2d 69 2c 20 26 7a 42 75 66 5b 69 5d  Buf)-i, &zBuf[i]
2810: 2c 20 22 7c 30 78 25 78 22 2c 20 66 6c 61 67 73  , "|0x%x", flags
2820: 29 3b 0a 20 20 7d 0a 20 20 76 66 73 74 72 61 63  );.  }.  vfstrac
2830: 65 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20  e_printf(pInfo, 
2840: 22 25 73 2e 78 53 79 6e 63 28 25 73 2c 25 73 29  "%s.xSync(%s,%s)
2850: 22 2c 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61  ", pInfo->zVfsNa
2860: 6d 65 2c 20 70 2d 3e 7a 46 4e 61 6d 65 2c 0a 20  me, p->zFName,. 
2870: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2880: 20 26 7a 42 75 66 5b 31 5d 29 3b 0a 20 20 72 63   &zBuf[1]);.  rc
2890: 20 3d 20 70 2d 3e 70 52 65 61 6c 2d 3e 70 4d 65   = p->pReal->pMe
28a0: 74 68 6f 64 73 2d 3e 78 53 79 6e 63 28 70 2d 3e  thods->xSync(p->
28b0: 70 52 65 61 6c 2c 20 66 6c 61 67 73 29 3b 0a 20  pReal, flags);. 
28c0: 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74 66   vfstrace_printf
28d0: 28 70 49 6e 66 6f 2c 20 22 20 2d 3e 20 25 64 5c  (pInfo, " -> %d\
28e0: 6e 22 2c 20 72 63 29 3b 0a 20 20 72 65 74 75 72  n", rc);.  retur
28f0: 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52  n rc;.}../*.** R
2900: 65 74 75 72 6e 20 74 68 65 20 63 75 72 72 65 6e  eturn the curren
2910: 74 20 66 69 6c 65 2d 73 69 7a 65 20 6f 66 20 61  t file-size of a
2920: 6e 20 76 66 73 74 72 61 63 65 2d 66 69 6c 65 2e  n vfstrace-file.
2930: 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 76  .*/.static int v
2940: 66 73 74 72 61 63 65 46 69 6c 65 53 69 7a 65 28  fstraceFileSize(
2950: 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46  sqlite3_file *pF
2960: 69 6c 65 2c 20 73 71 6c 69 74 65 5f 69 6e 74 36  ile, sqlite_int6
2970: 34 20 2a 70 53 69 7a 65 29 7b 0a 20 20 76 66 73  4 *pSize){.  vfs
2980: 74 72 61 63 65 5f 66 69 6c 65 20 2a 70 20 3d 20  trace_file *p = 
2990: 28 76 66 73 74 72 61 63 65 5f 66 69 6c 65 20 2a  (vfstrace_file *
29a0: 29 70 46 69 6c 65 3b 0a 20 20 76 66 73 74 72 61  )pFile;.  vfstra
29b0: 63 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d  ce_info *pInfo =
29c0: 20 70 2d 3e 70 49 6e 66 6f 3b 0a 20 20 69 6e 74   p->pInfo;.  int
29d0: 20 72 63 3b 0a 20 20 76 66 73 74 72 61 63 65 5f   rc;.  vfstrace_
29e0: 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22 25  printf(pInfo, "%
29f0: 73 2e 78 46 69 6c 65 53 69 7a 65 28 25 73 29 22  s.xFileSize(%s)"
2a00: 2c 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d  , pInfo->zVfsNam
2a10: 65 2c 20 70 2d 3e 7a 46 4e 61 6d 65 29 3b 0a 20  e, p->zFName);. 
2a20: 20 72 63 20 3d 20 70 2d 3e 70 52 65 61 6c 2d 3e   rc = p->pReal->
2a30: 70 4d 65 74 68 6f 64 73 2d 3e 78 46 69 6c 65 53  pMethods->xFileS
2a40: 69 7a 65 28 70 2d 3e 70 52 65 61 6c 2c 20 70 53  ize(p->pReal, pS
2a50: 69 7a 65 29 3b 0a 20 20 76 66 73 74 72 61 63 65  ize);.  vfstrace
2a60: 5f 70 72 69 6e 74 5f 65 72 72 63 6f 64 65 28 70  _print_errcode(p
2a70: 49 6e 66 6f 2c 20 22 20 2d 3e 20 25 73 2c 22 2c  Info, " -> %s,",
2a80: 20 72 63 29 3b 0a 20 20 76 66 73 74 72 61 63 65   rc);.  vfstrace
2a90: 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22  _printf(pInfo, "
2aa0: 20 73 69 7a 65 3d 25 6c 6c 64 5c 6e 22 2c 20 2a   size=%lld\n", *
2ab0: 70 53 69 7a 65 29 3b 0a 20 20 72 65 74 75 72 6e  pSize);.  return
2ac0: 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65   rc;.}../*.** Re
2ad0: 74 75 72 6e 20 74 68 65 20 6e 61 6d 65 20 6f 66  turn the name of
2ae0: 20 61 20 6c 6f 63 6b 2e 0a 2a 2f 0a 73 74 61 74   a lock..*/.stat
2af0: 69 63 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 6c  ic const char *l
2b00: 6f 63 6b 4e 61 6d 65 28 69 6e 74 20 65 4c 6f 63  ockName(int eLoc
2b10: 6b 29 7b 0a 20 20 63 6f 6e 73 74 20 63 68 61 72  k){.  const char
2b20: 20 2a 61 7a 4c 6f 63 6b 4e 61 6d 65 73 5b 5d 20   *azLockNames[] 
2b30: 3d 20 7b 0a 20 20 20 20 20 22 4e 4f 4e 45 22 2c  = {.     "NONE",
2b40: 20 22 53 48 41 52 45 44 22 2c 20 22 52 45 53 45   "SHARED", "RESE
2b50: 52 56 45 44 22 2c 20 22 50 45 4e 44 49 4e 47 22  RVED", "PENDING"
2b60: 2c 20 22 45 58 43 4c 55 53 49 56 45 22 0a 20 20  , "EXCLUSIVE".  
2b70: 7d 3b 0a 20 20 69 66 28 20 65 4c 6f 63 6b 3c 30  };.  if( eLock<0
2b80: 20 7c 7c 20 65 4c 6f 63 6b 3e 3d 73 69 7a 65 6f   || eLock>=sizeo
2b90: 66 28 61 7a 4c 6f 63 6b 4e 61 6d 65 73 29 2f 73  f(azLockNames)/s
2ba0: 69 7a 65 6f 66 28 61 7a 4c 6f 63 6b 4e 61 6d 65  izeof(azLockName
2bb0: 73 5b 30 5d 29 20 29 7b 0a 20 20 20 20 72 65 74  s[0]) ){.    ret
2bc0: 75 72 6e 20 22 3f 3f 3f 22 3b 0a 20 20 7d 65 6c  urn "???";.  }el
2bd0: 73 65 7b 0a 20 20 20 20 72 65 74 75 72 6e 20 61  se{.    return a
2be0: 7a 4c 6f 63 6b 4e 61 6d 65 73 5b 65 4c 6f 63 6b  zLockNames[eLock
2bf0: 5d 3b 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20  ];.  }.}../*.** 
2c00: 4c 6f 63 6b 20 61 6e 20 76 66 73 74 72 61 63 65  Lock an vfstrace
2c10: 2d 66 69 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63  -file..*/.static
2c20: 20 69 6e 74 20 76 66 73 74 72 61 63 65 4c 6f 63   int vfstraceLoc
2c30: 6b 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a  k(sqlite3_file *
2c40: 70 46 69 6c 65 2c 20 69 6e 74 20 65 4c 6f 63 6b  pFile, int eLock
2c50: 29 7b 0a 20 20 76 66 73 74 72 61 63 65 5f 66 69  ){.  vfstrace_fi
2c60: 6c 65 20 2a 70 20 3d 20 28 76 66 73 74 72 61 63  le *p = (vfstrac
2c70: 65 5f 66 69 6c 65 20 2a 29 70 46 69 6c 65 3b 0a  e_file *)pFile;.
2c80: 20 20 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 20    vfstrace_info 
2c90: 2a 70 49 6e 66 6f 20 3d 20 70 2d 3e 70 49 6e 66  *pInfo = p->pInf
2ca0: 6f 3b 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20 76  o;.  int rc;.  v
2cb0: 66 73 74 72 61 63 65 5f 70 72 69 6e 74 66 28 70  fstrace_printf(p
2cc0: 49 6e 66 6f 2c 20 22 25 73 2e 78 4c 6f 63 6b 28  Info, "%s.xLock(
2cd0: 25 73 2c 25 73 29 22 2c 20 70 49 6e 66 6f 2d 3e  %s,%s)", pInfo->
2ce0: 7a 56 66 73 4e 61 6d 65 2c 20 70 2d 3e 7a 46 4e  zVfsName, p->zFN
2cf0: 61 6d 65 2c 0a 20 20 20 20 20 20 20 20 20 20 20  ame,.           
2d00: 20 20 20 20 20 20 20 6c 6f 63 6b 4e 61 6d 65 28         lockName(
2d10: 65 4c 6f 63 6b 29 29 3b 0a 20 20 72 63 20 3d 20  eLock));.  rc = 
2d20: 70 2d 3e 70 52 65 61 6c 2d 3e 70 4d 65 74 68 6f  p->pReal->pMetho
2d30: 64 73 2d 3e 78 4c 6f 63 6b 28 70 2d 3e 70 52 65  ds->xLock(p->pRe
2d40: 61 6c 2c 20 65 4c 6f 63 6b 29 3b 0a 20 20 76 66  al, eLock);.  vf
2d50: 73 74 72 61 63 65 5f 70 72 69 6e 74 5f 65 72 72  strace_print_err
2d60: 63 6f 64 65 28 70 49 6e 66 6f 2c 20 22 20 2d 3e  code(pInfo, " ->
2d70: 20 25 73 5c 6e 22 2c 20 72 63 29 3b 0a 20 20 72   %s\n", rc);.  r
2d80: 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a  eturn rc;.}../*.
2d90: 2a 2a 20 55 6e 6c 6f 63 6b 20 61 6e 20 76 66 73  ** Unlock an vfs
2da0: 74 72 61 63 65 2d 66 69 6c 65 2e 0a 2a 2f 0a 73  trace-file..*/.s
2db0: 74 61 74 69 63 20 69 6e 74 20 76 66 73 74 72 61  tatic int vfstra
2dc0: 63 65 55 6e 6c 6f 63 6b 28 73 71 6c 69 74 65 33  ceUnlock(sqlite3
2dd0: 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c 20 69 6e  _file *pFile, in
2de0: 74 20 65 4c 6f 63 6b 29 7b 0a 20 20 76 66 73 74  t eLock){.  vfst
2df0: 72 61 63 65 5f 66 69 6c 65 20 2a 70 20 3d 20 28  race_file *p = (
2e00: 76 66 73 74 72 61 63 65 5f 66 69 6c 65 20 2a 29  vfstrace_file *)
2e10: 70 46 69 6c 65 3b 0a 20 20 76 66 73 74 72 61 63  pFile;.  vfstrac
2e20: 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20  e_info *pInfo = 
2e30: 70 2d 3e 70 49 6e 66 6f 3b 0a 20 20 69 6e 74 20  p->pInfo;.  int 
2e40: 72 63 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 70  rc;.  vfstrace_p
2e50: 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22 25 73  rintf(pInfo, "%s
2e60: 2e 78 55 6e 6c 6f 63 6b 28 25 73 2c 25 73 29 22  .xUnlock(%s,%s)"
2e70: 2c 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d  , pInfo->zVfsNam
2e80: 65 2c 20 70 2d 3e 7a 46 4e 61 6d 65 2c 0a 20 20  e, p->zFName,.  
2e90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2ea0: 6c 6f 63 6b 4e 61 6d 65 28 65 4c 6f 63 6b 29 29  lockName(eLock))
2eb0: 3b 0a 20 20 72 63 20 3d 20 70 2d 3e 70 52 65 61  ;.  rc = p->pRea
2ec0: 6c 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 55 6e  l->pMethods->xUn
2ed0: 6c 6f 63 6b 28 70 2d 3e 70 52 65 61 6c 2c 20 65  lock(p->pReal, e
2ee0: 4c 6f 63 6b 29 3b 0a 20 20 76 66 73 74 72 61 63  Lock);.  vfstrac
2ef0: 65 5f 70 72 69 6e 74 5f 65 72 72 63 6f 64 65 28  e_print_errcode(
2f00: 70 49 6e 66 6f 2c 20 22 20 2d 3e 20 25 73 5c 6e  pInfo, " -> %s\n
2f10: 22 2c 20 72 63 29 3b 0a 20 20 72 65 74 75 72 6e  ", rc);.  return
2f20: 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 68   rc;.}../*.** Ch
2f30: 65 63 6b 20 69 66 20 61 6e 6f 74 68 65 72 20 66  eck if another f
2f40: 69 6c 65 2d 68 61 6e 64 6c 65 20 68 6f 6c 64 73  ile-handle holds
2f50: 20 61 20 52 45 53 45 52 56 45 44 20 6c 6f 63 6b   a RESERVED lock
2f60: 20 6f 6e 20 61 6e 20 76 66 73 74 72 61 63 65 2d   on an vfstrace-
2f70: 66 69 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  file..*/.static 
2f80: 69 6e 74 20 76 66 73 74 72 61 63 65 43 68 65 63  int vfstraceChec
2f90: 6b 52 65 73 65 72 76 65 64 4c 6f 63 6b 28 73 71  kReservedLock(sq
2fa0: 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c  lite3_file *pFil
2fb0: 65 2c 20 69 6e 74 20 2a 70 52 65 73 4f 75 74 29  e, int *pResOut)
2fc0: 7b 0a 20 20 76 66 73 74 72 61 63 65 5f 66 69 6c  {.  vfstrace_fil
2fd0: 65 20 2a 70 20 3d 20 28 76 66 73 74 72 61 63 65  e *p = (vfstrace
2fe0: 5f 66 69 6c 65 20 2a 29 70 46 69 6c 65 3b 0a 20  _file *)pFile;. 
2ff0: 20 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a   vfstrace_info *
3000: 70 49 6e 66 6f 20 3d 20 70 2d 3e 70 49 6e 66 6f  pInfo = p->pInfo
3010: 3b 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20 76 66  ;.  int rc;.  vf
3020: 73 74 72 61 63 65 5f 70 72 69 6e 74 66 28 70 49  strace_printf(pI
3030: 6e 66 6f 2c 20 22 25 73 2e 78 43 68 65 63 6b 52  nfo, "%s.xCheckR
3040: 65 73 65 72 76 65 64 4c 6f 63 6b 28 25 73 2c 25  eservedLock(%s,%
3050: 64 29 22 2c 20 0a 20 20 20 20 20 20 20 20 20 20  d)", .          
3060: 20 20 20 20 20 20 20 20 70 49 6e 66 6f 2d 3e 7a          pInfo->z
3070: 56 66 73 4e 61 6d 65 2c 20 70 2d 3e 7a 46 4e 61  VfsName, p->zFNa
3080: 6d 65 29 3b 0a 20 20 72 63 20 3d 20 70 2d 3e 70  me);.  rc = p->p
3090: 52 65 61 6c 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e  Real->pMethods->
30a0: 78 43 68 65 63 6b 52 65 73 65 72 76 65 64 4c 6f  xCheckReservedLo
30b0: 63 6b 28 70 2d 3e 70 52 65 61 6c 2c 20 70 52 65  ck(p->pReal, pRe
30c0: 73 4f 75 74 29 3b 0a 20 20 76 66 73 74 72 61 63  sOut);.  vfstrac
30d0: 65 5f 70 72 69 6e 74 5f 65 72 72 63 6f 64 65 28  e_print_errcode(
30e0: 70 49 6e 66 6f 2c 20 22 20 2d 3e 20 25 73 22 2c  pInfo, " -> %s",
30f0: 20 72 63 29 3b 0a 20 20 76 66 73 74 72 61 63 65   rc);.  vfstrace
3100: 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22  _printf(pInfo, "
3110: 2c 20 6f 75 74 3d 25 64 5c 6e 22 2c 20 2a 70 52  , out=%d\n", *pR
3120: 65 73 4f 75 74 29 3b 0a 20 20 72 65 74 75 72 6e  esOut);.  return
3130: 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 46 69   rc;.}../*.** Fi
3140: 6c 65 20 63 6f 6e 74 72 6f 6c 20 6d 65 74 68 6f  le control metho
3150: 64 2e 20 46 6f 72 20 63 75 73 74 6f 6d 20 6f 70  d. For custom op
3160: 65 72 61 74 69 6f 6e 73 20 6f 6e 20 61 6e 20 76  erations on an v
3170: 66 73 74 72 61 63 65 2d 66 69 6c 65 2e 0a 2a 2f  fstrace-file..*/
3180: 0a 73 74 61 74 69 63 20 69 6e 74 20 76 66 73 74  .static int vfst
3190: 72 61 63 65 46 69 6c 65 43 6f 6e 74 72 6f 6c 28  raceFileControl(
31a0: 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46  sqlite3_file *pF
31b0: 69 6c 65 2c 20 69 6e 74 20 6f 70 2c 20 76 6f 69  ile, int op, voi
31c0: 64 20 2a 70 41 72 67 29 7b 0a 20 20 76 66 73 74  d *pArg){.  vfst
31d0: 72 61 63 65 5f 66 69 6c 65 20 2a 70 20 3d 20 28  race_file *p = (
31e0: 76 66 73 74 72 61 63 65 5f 66 69 6c 65 20 2a 29  vfstrace_file *)
31f0: 70 46 69 6c 65 3b 0a 20 20 76 66 73 74 72 61 63  pFile;.  vfstrac
3200: 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20  e_info *pInfo = 
3210: 70 2d 3e 70 49 6e 66 6f 3b 0a 20 20 69 6e 74 20  p->pInfo;.  int 
3220: 72 63 3b 0a 20 20 63 68 61 72 20 7a 42 75 66 5b  rc;.  char zBuf[
3230: 31 30 30 5d 3b 0a 20 20 63 68 61 72 20 2a 7a 4f  100];.  char *zO
3240: 70 3b 0a 20 20 73 77 69 74 63 68 28 20 6f 70 20  p;.  switch( op 
3250: 29 7b 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49  ){.    case SQLI
3260: 54 45 5f 46 43 4e 54 4c 5f 4c 4f 43 4b 53 54 41  TE_FCNTL_LOCKSTA
3270: 54 45 3a 20 20 20 20 7a 4f 70 20 3d 20 22 4c 4f  TE:    zOp = "LO
3280: 43 4b 53 54 41 54 45 22 3b 20 20 20 20 20 20 20  CKSTATE";       
3290: 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61     break;.    ca
32a0: 73 65 20 53 51 4c 49 54 45 5f 47 45 54 5f 4c 4f  se SQLITE_GET_LO
32b0: 43 4b 50 52 4f 58 59 46 49 4c 45 3a 20 20 7a 4f  CKPROXYFILE:  zO
32c0: 70 20 3d 20 22 47 45 54 5f 4c 4f 43 4b 50 52 4f  p = "GET_LOCKPRO
32d0: 58 59 46 49 4c 45 22 3b 20 20 62 72 65 61 6b 3b  XYFILE";  break;
32e0: 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49 54 45  .    case SQLITE
32f0: 5f 53 45 54 5f 4c 4f 43 4b 50 52 4f 58 59 46 49  _SET_LOCKPROXYFI
3300: 4c 45 3a 20 20 7a 4f 70 20 3d 20 22 53 45 54 5f  LE:  zOp = "SET_
3310: 4c 4f 43 4b 50 52 4f 58 59 46 49 4c 45 22 3b 20  LOCKPROXYFILE"; 
3320: 20 62 72 65 61 6b 3b 0a 20 20 20 20 63 61 73 65   break;.    case
3330: 20 53 51 4c 49 54 45 5f 4c 41 53 54 5f 45 52 52   SQLITE_LAST_ERR
3340: 4e 4f 3a 20 20 20 20 20 20 20 20 20 7a 4f 70 20  NO:         zOp 
3350: 3d 20 22 4c 41 53 54 5f 45 52 52 4e 4f 22 3b 20  = "LAST_ERRNO"; 
3360: 20 20 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20          break;. 
3370: 20 20 20 63 61 73 65 20 53 51 4c 49 54 45 5f 46     case SQLITE_F
3380: 43 4e 54 4c 5f 53 49 5a 45 5f 48 49 4e 54 3a 20  CNTL_SIZE_HINT: 
3390: 7b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f  {.      sqlite3_
33a0: 73 6e 70 72 69 6e 74 66 28 73 69 7a 65 6f 66 28  snprintf(sizeof(
33b0: 7a 42 75 66 29 2c 20 7a 42 75 66 2c 20 22 53 49  zBuf), zBuf, "SI
33c0: 5a 45 5f 48 49 4e 54 2c 25 6c 6c 64 22 2c 0a 20  ZE_HINT,%lld",. 
33d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
33e0: 20 20 20 20 20 20 2a 28 73 71 6c 69 74 65 33 5f        *(sqlite3_
33f0: 69 6e 74 36 34 2a 29 70 41 72 67 29 3b 0a 20 20  int64*)pArg);.  
3400: 20 20 20 20 7a 4f 70 20 3d 20 7a 42 75 66 3b 0a      zOp = zBuf;.
3410: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
3420: 20 7d 0a 20 20 20 20 63 61 73 65 20 53 51 4c 49   }.    case SQLI
3430: 54 45 5f 46 43 4e 54 4c 5f 43 48 55 4e 4b 5f 53  TE_FCNTL_CHUNK_S
3440: 49 5a 45 3a 20 7b 0a 20 20 20 20 20 20 73 71 6c  IZE: {.      sql
3450: 69 74 65 33 5f 73 6e 70 72 69 6e 74 66 28 73 69  ite3_snprintf(si
3460: 7a 65 6f 66 28 7a 42 75 66 29 2c 20 7a 42 75 66  zeof(zBuf), zBuf
3470: 2c 20 22 43 48 55 4e 4b 5f 53 49 5a 45 2c 25 64  , "CHUNK_SIZE,%d
3480: 22 2c 20 2a 28 69 6e 74 2a 29 70 41 72 67 29 3b  ", *(int*)pArg);
3490: 0a 20 20 20 20 20 20 7a 4f 70 20 3d 20 7a 42 75  .      zOp = zBu
34a0: 66 3b 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a  f;.      break;.
34b0: 20 20 20 20 7d 0a 20 20 20 20 63 61 73 65 20 53      }.    case S
34c0: 51 4c 49 54 45 5f 46 43 4e 54 4c 5f 46 49 4c 45  QLITE_FCNTL_FILE
34d0: 5f 50 4f 49 4e 54 45 52 3a 20 7a 4f 70 20 3d 20  _POINTER: zOp = 
34e0: 22 46 49 4c 45 5f 50 4f 49 4e 54 45 52 22 3b 20  "FILE_POINTER"; 
34f0: 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20        break;.   
3500: 20 63 61 73 65 20 53 51 4c 49 54 45 5f 46 43 4e   case SQLITE_FCN
3510: 54 4c 5f 53 59 4e 43 5f 4f 4d 49 54 54 45 44 3a  TL_SYNC_OMITTED:
3520: 20 7a 4f 70 20 3d 20 22 53 59 4e 43 5f 4f 4d 49   zOp = "SYNC_OMI
3530: 54 54 45 44 22 3b 20 20 20 20 20 20 20 62 72 65  TTED";       bre
3540: 61 6b 3b 0a 20 20 20 20 63 61 73 65 20 30 78 63  ak;.    case 0xc
3550: 61 30 39 33 66 61 30 3a 20 20 20 20 20 20 20 20  a093fa0:        
3560: 20 20 20 20 20 20 20 20 7a 4f 70 20 3d 20 22 44          zOp = "D
3570: 42 5f 55 4e 43 48 41 4e 47 45 44 22 3b 20 20 20  B_UNCHANGED";   
3580: 20 20 20 20 62 72 65 61 6b 3b 0a 20 20 20 20 64      break;.    d
3590: 65 66 61 75 6c 74 3a 20 7b 0a 20 20 20 20 20 20  efault: {.      
35a0: 73 71 6c 69 74 65 33 5f 73 6e 70 72 69 6e 74 66  sqlite3_snprintf
35b0: 28 73 69 7a 65 6f 66 20 7a 42 75 66 2c 20 7a 42  (sizeof zBuf, zB
35c0: 75 66 2c 20 22 25 64 22 2c 20 6f 70 29 3b 0a 20  uf, "%d", op);. 
35d0: 20 20 20 20 20 7a 4f 70 20 3d 20 7a 42 75 66 3b       zOp = zBuf;
35e0: 0a 20 20 20 20 20 20 62 72 65 61 6b 3b 0a 20 20  .      break;.  
35f0: 20 20 7d 0a 20 20 7d 0a 20 20 76 66 73 74 72 61    }.  }.  vfstra
3600: 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c  ce_printf(pInfo,
3610: 20 22 25 73 2e 78 46 69 6c 65 43 6f 6e 74 72 6f   "%s.xFileContro
3620: 6c 28 25 73 2c 25 73 29 22 2c 0a 20 20 20 20 20  l(%s,%s)",.     
3630: 20 20 20 20 20 20 20 20 20 20 20 20 20 70 49 6e               pIn
3640: 66 6f 2d 3e 7a 56 66 73 4e 61 6d 65 2c 20 70 2d  fo->zVfsName, p-
3650: 3e 7a 46 4e 61 6d 65 2c 20 7a 4f 70 29 3b 0a 20  >zFName, zOp);. 
3660: 20 72 63 20 3d 20 70 2d 3e 70 52 65 61 6c 2d 3e   rc = p->pReal->
3670: 70 4d 65 74 68 6f 64 73 2d 3e 78 46 69 6c 65 43  pMethods->xFileC
3680: 6f 6e 74 72 6f 6c 28 70 2d 3e 70 52 65 61 6c 2c  ontrol(p->pReal,
3690: 20 6f 70 2c 20 70 41 72 67 29 3b 0a 20 20 76 66   op, pArg);.  vf
36a0: 73 74 72 61 63 65 5f 70 72 69 6e 74 5f 65 72 72  strace_print_err
36b0: 63 6f 64 65 28 70 49 6e 66 6f 2c 20 22 20 2d 3e  code(pInfo, " ->
36c0: 20 25 73 5c 6e 22 2c 20 72 63 29 3b 0a 20 20 72   %s\n", rc);.  r
36d0: 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a  eturn rc;.}../*.
36e0: 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20 73 65  ** Return the se
36f0: 63 74 6f 72 2d 73 69 7a 65 20 69 6e 20 62 79 74  ctor-size in byt
3700: 65 73 20 66 6f 72 20 61 6e 20 76 66 73 74 72 61  es for an vfstra
3710: 63 65 2d 66 69 6c 65 2e 0a 2a 2f 0a 73 74 61 74  ce-file..*/.stat
3720: 69 63 20 69 6e 74 20 76 66 73 74 72 61 63 65 53  ic int vfstraceS
3730: 65 63 74 6f 72 53 69 7a 65 28 73 71 6c 69 74 65  ectorSize(sqlite
3740: 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 29 7b 0a  3_file *pFile){.
3750: 20 20 76 66 73 74 72 61 63 65 5f 66 69 6c 65 20    vfstrace_file 
3760: 2a 70 20 3d 20 28 76 66 73 74 72 61 63 65 5f 66  *p = (vfstrace_f
3770: 69 6c 65 20 2a 29 70 46 69 6c 65 3b 0a 20 20 76  ile *)pFile;.  v
3780: 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70 49  fstrace_info *pI
3790: 6e 66 6f 20 3d 20 70 2d 3e 70 49 6e 66 6f 3b 0a  nfo = p->pInfo;.
37a0: 20 20 69 6e 74 20 72 63 3b 0a 20 20 76 66 73 74    int rc;.  vfst
37b0: 72 61 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66  race_printf(pInf
37c0: 6f 2c 20 22 25 73 2e 78 53 65 63 74 6f 72 53 69  o, "%s.xSectorSi
37d0: 7a 65 28 25 73 29 22 2c 20 70 49 6e 66 6f 2d 3e  ze(%s)", pInfo->
37e0: 7a 56 66 73 4e 61 6d 65 2c 20 70 2d 3e 7a 46 4e  zVfsName, p->zFN
37f0: 61 6d 65 29 3b 0a 20 20 72 63 20 3d 20 70 2d 3e  ame);.  rc = p->
3800: 70 52 65 61 6c 2d 3e 70 4d 65 74 68 6f 64 73 2d  pReal->pMethods-
3810: 3e 78 53 65 63 74 6f 72 53 69 7a 65 28 70 2d 3e  >xSectorSize(p->
3820: 70 52 65 61 6c 29 3b 0a 20 20 76 66 73 74 72 61  pReal);.  vfstra
3830: 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c  ce_printf(pInfo,
3840: 20 22 20 2d 3e 20 25 64 5c 6e 22 2c 20 72 63 29   " -> %d\n", rc)
3850: 3b 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d  ;.  return rc;.}
3860: 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 74  ../*.** Return t
3870: 68 65 20 64 65 76 69 63 65 20 63 68 61 72 61 63  he device charac
3880: 74 65 72 69 73 74 69 63 20 66 6c 61 67 73 20 73  teristic flags s
3890: 75 70 70 6f 72 74 65 64 20 62 79 20 61 6e 20 76  upported by an v
38a0: 66 73 74 72 61 63 65 2d 66 69 6c 65 2e 0a 2a 2f  fstrace-file..*/
38b0: 0a 73 74 61 74 69 63 20 69 6e 74 20 76 66 73 74  .static int vfst
38c0: 72 61 63 65 44 65 76 69 63 65 43 68 61 72 61 63  raceDeviceCharac
38d0: 74 65 72 69 73 74 69 63 73 28 73 71 6c 69 74 65  teristics(sqlite
38e0: 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 29 7b 0a  3_file *pFile){.
38f0: 20 20 76 66 73 74 72 61 63 65 5f 66 69 6c 65 20    vfstrace_file 
3900: 2a 70 20 3d 20 28 76 66 73 74 72 61 63 65 5f 66  *p = (vfstrace_f
3910: 69 6c 65 20 2a 29 70 46 69 6c 65 3b 0a 20 20 76  ile *)pFile;.  v
3920: 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70 49  fstrace_info *pI
3930: 6e 66 6f 20 3d 20 70 2d 3e 70 49 6e 66 6f 3b 0a  nfo = p->pInfo;.
3940: 20 20 69 6e 74 20 72 63 3b 0a 20 20 76 66 73 74    int rc;.  vfst
3950: 72 61 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66  race_printf(pInf
3960: 6f 2c 20 22 25 73 2e 78 44 65 76 69 63 65 43 68  o, "%s.xDeviceCh
3970: 61 72 61 63 74 65 72 69 73 74 69 63 73 28 25 73  aracteristics(%s
3980: 29 22 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20  )",.            
3990: 20 20 20 20 20 20 70 49 6e 66 6f 2d 3e 7a 56 66        pInfo->zVf
39a0: 73 4e 61 6d 65 2c 20 70 2d 3e 7a 46 4e 61 6d 65  sName, p->zFName
39b0: 29 3b 0a 20 20 72 63 20 3d 20 70 2d 3e 70 52 65  );.  rc = p->pRe
39c0: 61 6c 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 44  al->pMethods->xD
39d0: 65 76 69 63 65 43 68 61 72 61 63 74 65 72 69 73  eviceCharacteris
39e0: 74 69 63 73 28 70 2d 3e 70 52 65 61 6c 29 3b 0a  tics(p->pReal);.
39f0: 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74    vfstrace_print
3a00: 66 28 70 49 6e 66 6f 2c 20 22 20 2d 3e 20 30 78  f(pInfo, " -> 0x
3a10: 25 30 38 78 5c 6e 22 2c 20 72 63 29 3b 0a 20 20  %08x\n", rc);.  
3a20: 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a  return rc;.}../*
3a30: 0a 2a 2a 20 53 68 61 72 65 64 2d 6d 65 6d 6f 72  .** Shared-memor
3a40: 79 20 6f 70 65 72 61 74 69 6f 6e 73 2e 0a 2a 2f  y operations..*/
3a50: 0a 73 74 61 74 69 63 20 69 6e 74 20 76 66 73 74  .static int vfst
3a60: 72 61 63 65 53 68 6d 4c 6f 63 6b 28 73 71 6c 69  raceShmLock(sqli
3a70: 74 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c  te3_file *pFile,
3a80: 20 69 6e 74 20 6f 66 73 74 2c 20 69 6e 74 20 6e   int ofst, int n
3a90: 2c 20 69 6e 74 20 66 6c 61 67 73 29 7b 0a 20 20  , int flags){.  
3aa0: 76 66 73 74 72 61 63 65 5f 66 69 6c 65 20 2a 70  vfstrace_file *p
3ab0: 20 3d 20 28 76 66 73 74 72 61 63 65 5f 66 69 6c   = (vfstrace_fil
3ac0: 65 20 2a 29 70 46 69 6c 65 3b 0a 20 20 76 66 73  e *)pFile;.  vfs
3ad0: 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70 49 6e 66  trace_info *pInf
3ae0: 6f 20 3d 20 70 2d 3e 70 49 6e 66 6f 3b 0a 20 20  o = p->pInfo;.  
3af0: 69 6e 74 20 72 63 3b 0a 20 20 63 68 61 72 20 7a  int rc;.  char z
3b00: 4c 63 6b 5b 31 30 30 5d 3b 0a 20 20 69 6e 74 20  Lck[100];.  int 
3b10: 69 20 3d 20 30 3b 0a 20 20 6d 65 6d 63 70 79 28  i = 0;.  memcpy(
3b20: 7a 4c 63 6b 2c 20 22 7c 30 22 2c 20 33 29 3b 0a  zLck, "|0", 3);.
3b30: 20 20 69 66 28 20 66 6c 61 67 73 20 26 20 53 51    if( flags & SQ
3b40: 4c 49 54 45 5f 53 48 4d 5f 55 4e 4c 4f 43 4b 20  LITE_SHM_UNLOCK 
3b50: 29 20 20 20 20 73 74 72 61 70 70 65 6e 64 28 7a  )    strappend(z
3b60: 4c 63 6b 2c 20 26 69 2c 20 22 7c 55 4e 4c 4f 43  Lck, &i, "|UNLOC
3b70: 4b 22 29 3b 0a 20 20 69 66 28 20 66 6c 61 67 73  K");.  if( flags
3b80: 20 26 20 53 51 4c 49 54 45 5f 53 48 4d 5f 4c 4f   & SQLITE_SHM_LO
3b90: 43 4b 20 29 20 20 20 20 20 20 73 74 72 61 70 70  CK )      strapp
3ba0: 65 6e 64 28 7a 4c 63 6b 2c 20 26 69 2c 20 22 7c  end(zLck, &i, "|
3bb0: 4c 4f 43 4b 22 29 3b 0a 20 20 69 66 28 20 66 6c  LOCK");.  if( fl
3bc0: 61 67 73 20 26 20 53 51 4c 49 54 45 5f 53 48 4d  ags & SQLITE_SHM
3bd0: 5f 53 48 41 52 45 44 20 29 20 20 20 20 73 74 72  _SHARED )    str
3be0: 61 70 70 65 6e 64 28 7a 4c 63 6b 2c 20 26 69 2c  append(zLck, &i,
3bf0: 20 22 7c 53 48 41 52 45 44 22 29 3b 0a 20 20 69   "|SHARED");.  i
3c00: 66 28 20 66 6c 61 67 73 20 26 20 53 51 4c 49 54  f( flags & SQLIT
3c10: 45 5f 53 48 4d 5f 45 58 43 4c 55 53 49 56 45 20  E_SHM_EXCLUSIVE 
3c20: 29 20 73 74 72 61 70 70 65 6e 64 28 7a 4c 63 6b  ) strappend(zLck
3c30: 2c 20 26 69 2c 20 22 7c 45 58 43 4c 55 53 49 56  , &i, "|EXCLUSIV
3c40: 45 22 29 3b 0a 20 20 69 66 28 20 66 6c 61 67 73  E");.  if( flags
3c50: 20 26 20 7e 28 30 78 66 29 20 29 7b 0a 20 20 20   & ~(0xf) ){.   
3c60: 20 20 73 71 6c 69 74 65 33 5f 73 6e 70 72 69 6e    sqlite3_snprin
3c70: 74 66 28 73 69 7a 65 6f 66 28 7a 4c 63 6b 29 2d  tf(sizeof(zLck)-
3c80: 69 2c 20 26 7a 4c 63 6b 5b 69 5d 2c 20 22 7c 30  i, &zLck[i], "|0
3c90: 78 25 78 22 2c 20 66 6c 61 67 73 29 3b 0a 20 20  x%x", flags);.  
3ca0: 7d 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72 69  }.  vfstrace_pri
3cb0: 6e 74 66 28 70 49 6e 66 6f 2c 20 22 25 73 2e 78  ntf(pInfo, "%s.x
3cc0: 53 68 6d 4c 6f 63 6b 28 25 73 2c 6f 66 73 74 3d  ShmLock(%s,ofst=
3cd0: 25 64 2c 6e 3d 25 64 2c 25 73 29 22 2c 0a 20 20  %d,n=%d,%s)",.  
3ce0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3cf0: 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d 65 2c  pInfo->zVfsName,
3d00: 20 70 2d 3e 7a 46 4e 61 6d 65 2c 20 6f 66 73 74   p->zFName, ofst
3d10: 2c 20 6e 2c 20 26 7a 4c 63 6b 5b 31 5d 29 3b 0a  , n, &zLck[1]);.
3d20: 20 20 72 63 20 3d 20 70 2d 3e 70 52 65 61 6c 2d    rc = p->pReal-
3d30: 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 53 68 6d 4c  >pMethods->xShmL
3d40: 6f 63 6b 28 70 2d 3e 70 52 65 61 6c 2c 20 6f 66  ock(p->pReal, of
3d50: 73 74 2c 20 6e 2c 20 66 6c 61 67 73 29 3b 0a 20  st, n, flags);. 
3d60: 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74 5f   vfstrace_print_
3d70: 65 72 72 63 6f 64 65 28 70 49 6e 66 6f 2c 20 22  errcode(pInfo, "
3d80: 20 2d 3e 20 25 73 5c 6e 22 2c 20 72 63 29 3b 0a   -> %s\n", rc);.
3d90: 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 73    return rc;.}.s
3da0: 74 61 74 69 63 20 69 6e 74 20 76 66 73 74 72 61  tatic int vfstra
3db0: 63 65 53 68 6d 4d 61 70 28 0a 20 20 73 71 6c 69  ceShmMap(.  sqli
3dc0: 74 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c  te3_file *pFile,
3dd0: 20 0a 20 20 69 6e 74 20 69 52 65 67 69 6f 6e 2c   .  int iRegion,
3de0: 20 0a 20 20 69 6e 74 20 73 7a 52 65 67 69 6f 6e   .  int szRegion
3df0: 2c 20 0a 20 20 69 6e 74 20 69 73 57 72 69 74 65  , .  int isWrite
3e00: 2c 20 0a 20 20 76 6f 69 64 20 76 6f 6c 61 74 69  , .  void volati
3e10: 6c 65 20 2a 2a 70 70 0a 29 7b 0a 20 20 76 66 73  le **pp.){.  vfs
3e20: 74 72 61 63 65 5f 66 69 6c 65 20 2a 70 20 3d 20  trace_file *p = 
3e30: 28 76 66 73 74 72 61 63 65 5f 66 69 6c 65 20 2a  (vfstrace_file *
3e40: 29 70 46 69 6c 65 3b 0a 20 20 76 66 73 74 72 61  )pFile;.  vfstra
3e50: 63 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d  ce_info *pInfo =
3e60: 20 70 2d 3e 70 49 6e 66 6f 3b 0a 20 20 69 6e 74   p->pInfo;.  int
3e70: 20 72 63 3b 0a 20 20 76 66 73 74 72 61 63 65 5f   rc;.  vfstrace_
3e80: 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22 25  printf(pInfo, "%
3e90: 73 2e 78 53 68 6d 4d 61 70 28 25 73 2c 69 52 65  s.xShmMap(%s,iRe
3ea0: 67 69 6f 6e 3d 25 64 2c 73 7a 52 65 67 69 6f 6e  gion=%d,szRegion
3eb0: 3d 25 64 2c 69 73 57 72 69 74 65 3d 25 64 2c 2a  =%d,isWrite=%d,*
3ec0: 29 22 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20  )",.            
3ed0: 20 20 20 20 20 20 70 49 6e 66 6f 2d 3e 7a 56 66        pInfo->zVf
3ee0: 73 4e 61 6d 65 2c 20 70 2d 3e 7a 46 4e 61 6d 65  sName, p->zFName
3ef0: 2c 20 69 52 65 67 69 6f 6e 2c 20 73 7a 52 65 67  , iRegion, szReg
3f00: 69 6f 6e 2c 20 69 73 57 72 69 74 65 29 3b 0a 20  ion, isWrite);. 
3f10: 20 72 63 20 3d 20 70 2d 3e 70 52 65 61 6c 2d 3e   rc = p->pReal->
3f20: 70 4d 65 74 68 6f 64 73 2d 3e 78 53 68 6d 4d 61  pMethods->xShmMa
3f30: 70 28 70 2d 3e 70 52 65 61 6c 2c 20 69 52 65 67  p(p->pReal, iReg
3f40: 69 6f 6e 2c 20 73 7a 52 65 67 69 6f 6e 2c 20 69  ion, szRegion, i
3f50: 73 57 72 69 74 65 2c 20 70 70 29 3b 0a 20 20 76  sWrite, pp);.  v
3f60: 66 73 74 72 61 63 65 5f 70 72 69 6e 74 5f 65 72  fstrace_print_er
3f70: 72 63 6f 64 65 28 70 49 6e 66 6f 2c 20 22 20 2d  rcode(pInfo, " -
3f80: 3e 20 25 73 5c 6e 22 2c 20 72 63 29 3b 0a 20 20  > %s\n", rc);.  
3f90: 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 73 74 61  return rc;.}.sta
3fa0: 74 69 63 20 76 6f 69 64 20 76 66 73 74 72 61 63  tic void vfstrac
3fb0: 65 53 68 6d 42 61 72 72 69 65 72 28 73 71 6c 69  eShmBarrier(sqli
3fc0: 74 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 29  te3_file *pFile)
3fd0: 7b 0a 20 20 76 66 73 74 72 61 63 65 5f 66 69 6c  {.  vfstrace_fil
3fe0: 65 20 2a 70 20 3d 20 28 76 66 73 74 72 61 63 65  e *p = (vfstrace
3ff0: 5f 66 69 6c 65 20 2a 29 70 46 69 6c 65 3b 0a 20  _file *)pFile;. 
4000: 20 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a   vfstrace_info *
4010: 70 49 6e 66 6f 20 3d 20 70 2d 3e 70 49 6e 66 6f  pInfo = p->pInfo
4020: 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72 69  ;.  vfstrace_pri
4030: 6e 74 66 28 70 49 6e 66 6f 2c 20 22 25 73 2e 78  ntf(pInfo, "%s.x
4040: 53 68 6d 42 61 72 72 69 65 72 28 25 73 29 5c 6e  ShmBarrier(%s)\n
4050: 22 2c 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61  ", pInfo->zVfsNa
4060: 6d 65 2c 20 70 2d 3e 7a 46 4e 61 6d 65 29 3b 0a  me, p->zFName);.
4070: 20 20 70 2d 3e 70 52 65 61 6c 2d 3e 70 4d 65 74    p->pReal->pMet
4080: 68 6f 64 73 2d 3e 78 53 68 6d 42 61 72 72 69 65  hods->xShmBarrie
4090: 72 28 70 2d 3e 70 52 65 61 6c 29 3b 0a 7d 0a 73  r(p->pReal);.}.s
40a0: 74 61 74 69 63 20 69 6e 74 20 76 66 73 74 72 61  tatic int vfstra
40b0: 63 65 53 68 6d 55 6e 6d 61 70 28 73 71 6c 69 74  ceShmUnmap(sqlit
40c0: 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c 20  e3_file *pFile, 
40d0: 69 6e 74 20 64 65 6c 46 6c 61 67 29 7b 0a 20 20  int delFlag){.  
40e0: 76 66 73 74 72 61 63 65 5f 66 69 6c 65 20 2a 70  vfstrace_file *p
40f0: 20 3d 20 28 76 66 73 74 72 61 63 65 5f 66 69 6c   = (vfstrace_fil
4100: 65 20 2a 29 70 46 69 6c 65 3b 0a 20 20 76 66 73  e *)pFile;.  vfs
4110: 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70 49 6e 66  trace_info *pInf
4120: 6f 20 3d 20 70 2d 3e 70 49 6e 66 6f 3b 0a 20 20  o = p->pInfo;.  
4130: 69 6e 74 20 72 63 3b 0a 20 20 76 66 73 74 72 61  int rc;.  vfstra
4140: 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c  ce_printf(pInfo,
4150: 20 22 25 73 2e 78 53 68 6d 55 6e 6d 61 70 28 25   "%s.xShmUnmap(%
4160: 73 2c 64 65 6c 46 6c 61 67 3d 25 64 29 22 2c 0a  s,delFlag=%d)",.
4170: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4180: 20 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d    pInfo->zVfsNam
4190: 65 2c 20 70 2d 3e 7a 46 4e 61 6d 65 2c 20 64 65  e, p->zFName, de
41a0: 6c 46 6c 61 67 29 3b 0a 20 20 72 63 20 3d 20 70  lFlag);.  rc = p
41b0: 2d 3e 70 52 65 61 6c 2d 3e 70 4d 65 74 68 6f 64  ->pReal->pMethod
41c0: 73 2d 3e 78 53 68 6d 55 6e 6d 61 70 28 70 2d 3e  s->xShmUnmap(p->
41d0: 70 52 65 61 6c 2c 20 64 65 6c 46 6c 61 67 29 3b  pReal, delFlag);
41e0: 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e  .  vfstrace_prin
41f0: 74 5f 65 72 72 63 6f 64 65 28 70 49 6e 66 6f 2c  t_errcode(pInfo,
4200: 20 22 20 2d 3e 20 25 73 5c 6e 22 2c 20 72 63 29   " -> %s\n", rc)
4210: 3b 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d  ;.  return rc;.}
4220: 0a 0a 0a 0a 2f 2a 0a 2a 2a 20 4f 70 65 6e 20 61  ..../*.** Open a
4230: 6e 20 76 66 73 74 72 61 63 65 20 66 69 6c 65 20  n vfstrace file 
4240: 68 61 6e 64 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69  handle..*/.stati
4250: 63 20 69 6e 74 20 76 66 73 74 72 61 63 65 4f 70  c int vfstraceOp
4260: 65 6e 28 0a 20 20 73 71 6c 69 74 65 33 5f 76 66  en(.  sqlite3_vf
4270: 73 20 2a 70 56 66 73 2c 0a 20 20 63 6f 6e 73 74  s *pVfs,.  const
4280: 20 63 68 61 72 20 2a 7a 4e 61 6d 65 2c 0a 20 20   char *zName,.  
4290: 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46  sqlite3_file *pF
42a0: 69 6c 65 2c 0a 20 20 69 6e 74 20 66 6c 61 67 73  ile,.  int flags
42b0: 2c 0a 20 20 69 6e 74 20 2a 70 4f 75 74 46 6c 61  ,.  int *pOutFla
42c0: 67 73 0a 29 7b 0a 20 20 69 6e 74 20 72 63 3b 0a  gs.){.  int rc;.
42d0: 20 20 76 66 73 74 72 61 63 65 5f 66 69 6c 65 20    vfstrace_file 
42e0: 2a 70 20 3d 20 28 76 66 73 74 72 61 63 65 5f 66  *p = (vfstrace_f
42f0: 69 6c 65 20 2a 29 70 46 69 6c 65 3b 0a 20 20 76  ile *)pFile;.  v
4300: 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70 49  fstrace_info *pI
4310: 6e 66 6f 20 3d 20 28 76 66 73 74 72 61 63 65 5f  nfo = (vfstrace_
4320: 69 6e 66 6f 2a 29 70 56 66 73 2d 3e 70 41 70 70  info*)pVfs->pApp
4330: 44 61 74 61 3b 0a 20 20 73 71 6c 69 74 65 33 5f  Data;.  sqlite3_
4340: 76 66 73 20 2a 70 52 6f 6f 74 20 3d 20 70 49 6e  vfs *pRoot = pIn
4350: 66 6f 2d 3e 70 52 6f 6f 74 56 66 73 3b 0a 20 20  fo->pRootVfs;.  
4360: 70 2d 3e 70 49 6e 66 6f 20 3d 20 70 49 6e 66 6f  p->pInfo = pInfo
4370: 3b 0a 20 20 70 2d 3e 7a 46 4e 61 6d 65 20 3d 20  ;.  p->zFName = 
4380: 7a 4e 61 6d 65 20 3f 20 66 69 6c 65 54 61 69 6c  zName ? fileTail
4390: 28 7a 4e 61 6d 65 29 20 3a 20 22 3c 74 65 6d 70  (zName) : "<temp
43a0: 3e 22 3b 0a 20 20 70 2d 3e 70 52 65 61 6c 20 3d  >";.  p->pReal =
43b0: 20 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a   (sqlite3_file *
43c0: 29 26 70 5b 31 5d 3b 0a 20 20 72 63 20 3d 20 70  )&p[1];.  rc = p
43d0: 52 6f 6f 74 2d 3e 78 4f 70 65 6e 28 70 52 6f 6f  Root->xOpen(pRoo
43e0: 74 2c 20 7a 4e 61 6d 65 2c 20 70 2d 3e 70 52 65  t, zName, p->pRe
43f0: 61 6c 2c 20 66 6c 61 67 73 2c 20 70 4f 75 74 46  al, flags, pOutF
4400: 6c 61 67 73 29 3b 0a 20 20 76 66 73 74 72 61 63  lags);.  vfstrac
4410: 65 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20  e_printf(pInfo, 
4420: 22 25 73 2e 78 4f 70 65 6e 28 25 73 2c 66 6c 61  "%s.xOpen(%s,fla
4430: 67 73 3d 30 78 25 78 29 22 2c 0a 20 20 20 20 20  gs=0x%x)",.     
4440: 20 20 20 20 20 20 20 20 20 20 20 20 20 70 49 6e               pIn
4450: 66 6f 2d 3e 7a 56 66 73 4e 61 6d 65 2c 20 70 2d  fo->zVfsName, p-
4460: 3e 7a 46 4e 61 6d 65 2c 20 66 6c 61 67 73 29 3b  >zFName, flags);
4470: 0a 20 20 69 66 28 20 70 2d 3e 70 52 65 61 6c 2d  .  if( p->pReal-
4480: 3e 70 4d 65 74 68 6f 64 73 20 29 7b 0a 20 20 20  >pMethods ){.   
4490: 20 73 71 6c 69 74 65 33 5f 69 6f 5f 6d 65 74 68   sqlite3_io_meth
44a0: 6f 64 73 20 2a 70 4e 65 77 20 3d 20 73 71 6c 69  ods *pNew = sqli
44b0: 74 65 33 5f 6d 61 6c 6c 6f 63 28 20 73 69 7a 65  te3_malloc( size
44c0: 6f 66 28 2a 70 4e 65 77 29 20 29 3b 0a 20 20 20  of(*pNew) );.   
44d0: 20 63 6f 6e 73 74 20 73 71 6c 69 74 65 33 5f 69   const sqlite3_i
44e0: 6f 5f 6d 65 74 68 6f 64 73 20 2a 70 53 75 62 20  o_methods *pSub 
44f0: 3d 20 70 2d 3e 70 52 65 61 6c 2d 3e 70 4d 65 74  = p->pReal->pMet
4500: 68 6f 64 73 3b 0a 20 20 20 20 6d 65 6d 73 65 74  hods;.    memset
4510: 28 70 4e 65 77 2c 20 30 2c 20 73 69 7a 65 6f 66  (pNew, 0, sizeof
4520: 28 2a 70 4e 65 77 29 29 3b 0a 20 20 20 20 70 4e  (*pNew));.    pN
4530: 65 77 2d 3e 69 56 65 72 73 69 6f 6e 20 3d 20 70  ew->iVersion = p
4540: 53 75 62 2d 3e 69 56 65 72 73 69 6f 6e 3b 0a 20  Sub->iVersion;. 
4550: 20 20 20 70 4e 65 77 2d 3e 78 43 6c 6f 73 65 20     pNew->xClose 
4560: 3d 20 76 66 73 74 72 61 63 65 43 6c 6f 73 65 3b  = vfstraceClose;
4570: 0a 20 20 20 20 70 4e 65 77 2d 3e 78 52 65 61 64  .    pNew->xRead
4580: 20 3d 20 76 66 73 74 72 61 63 65 52 65 61 64 3b   = vfstraceRead;
4590: 0a 20 20 20 20 70 4e 65 77 2d 3e 78 57 72 69 74  .    pNew->xWrit
45a0: 65 20 3d 20 76 66 73 74 72 61 63 65 57 72 69 74  e = vfstraceWrit
45b0: 65 3b 0a 20 20 20 20 70 4e 65 77 2d 3e 78 54 72  e;.    pNew->xTr
45c0: 75 6e 63 61 74 65 20 3d 20 76 66 73 74 72 61 63  uncate = vfstrac
45d0: 65 54 72 75 6e 63 61 74 65 3b 0a 20 20 20 20 70  eTruncate;.    p
45e0: 4e 65 77 2d 3e 78 53 79 6e 63 20 3d 20 76 66 73  New->xSync = vfs
45f0: 74 72 61 63 65 53 79 6e 63 3b 0a 20 20 20 20 70  traceSync;.    p
4600: 4e 65 77 2d 3e 78 46 69 6c 65 53 69 7a 65 20 3d  New->xFileSize =
4610: 20 76 66 73 74 72 61 63 65 46 69 6c 65 53 69 7a   vfstraceFileSiz
4620: 65 3b 0a 20 20 20 20 70 4e 65 77 2d 3e 78 4c 6f  e;.    pNew->xLo
4630: 63 6b 20 3d 20 76 66 73 74 72 61 63 65 4c 6f 63  ck = vfstraceLoc
4640: 6b 3b 0a 20 20 20 20 70 4e 65 77 2d 3e 78 55 6e  k;.    pNew->xUn
4650: 6c 6f 63 6b 20 3d 20 76 66 73 74 72 61 63 65 55  lock = vfstraceU
4660: 6e 6c 6f 63 6b 3b 0a 20 20 20 20 70 4e 65 77 2d  nlock;.    pNew-
4670: 3e 78 43 68 65 63 6b 52 65 73 65 72 76 65 64 4c  >xCheckReservedL
4680: 6f 63 6b 20 3d 20 76 66 73 74 72 61 63 65 43 68  ock = vfstraceCh
4690: 65 63 6b 52 65 73 65 72 76 65 64 4c 6f 63 6b 3b  eckReservedLock;
46a0: 0a 20 20 20 20 70 4e 65 77 2d 3e 78 46 69 6c 65  .    pNew->xFile
46b0: 43 6f 6e 74 72 6f 6c 20 3d 20 76 66 73 74 72 61  Control = vfstra
46c0: 63 65 46 69 6c 65 43 6f 6e 74 72 6f 6c 3b 0a 20  ceFileControl;. 
46d0: 20 20 20 70 4e 65 77 2d 3e 78 53 65 63 74 6f 72     pNew->xSector
46e0: 53 69 7a 65 20 3d 20 76 66 73 74 72 61 63 65 53  Size = vfstraceS
46f0: 65 63 74 6f 72 53 69 7a 65 3b 0a 20 20 20 20 70  ectorSize;.    p
4700: 4e 65 77 2d 3e 78 44 65 76 69 63 65 43 68 61 72  New->xDeviceChar
4710: 61 63 74 65 72 69 73 74 69 63 73 20 3d 20 76 66  acteristics = vf
4720: 73 74 72 61 63 65 44 65 76 69 63 65 43 68 61 72  straceDeviceChar
4730: 61 63 74 65 72 69 73 74 69 63 73 3b 0a 20 20 20  acteristics;.   
4740: 20 69 66 28 20 70 4e 65 77 2d 3e 69 56 65 72 73   if( pNew->iVers
4750: 69 6f 6e 3e 3d 32 20 29 7b 0a 20 20 20 20 20 20  ion>=2 ){.      
4760: 70 4e 65 77 2d 3e 78 53 68 6d 4d 61 70 20 3d 20  pNew->xShmMap = 
4770: 70 53 75 62 2d 3e 78 53 68 6d 4d 61 70 20 3f 20  pSub->xShmMap ? 
4780: 76 66 73 74 72 61 63 65 53 68 6d 4d 61 70 20 3a  vfstraceShmMap :
4790: 20 30 3b 0a 20 20 20 20 20 20 70 4e 65 77 2d 3e   0;.      pNew->
47a0: 78 53 68 6d 4c 6f 63 6b 20 3d 20 70 53 75 62 2d  xShmLock = pSub-
47b0: 3e 78 53 68 6d 4c 6f 63 6b 20 3f 20 76 66 73 74  >xShmLock ? vfst
47c0: 72 61 63 65 53 68 6d 4c 6f 63 6b 20 3a 20 30 3b  raceShmLock : 0;
47d0: 0a 20 20 20 20 20 20 70 4e 65 77 2d 3e 78 53 68  .      pNew->xSh
47e0: 6d 42 61 72 72 69 65 72 20 3d 20 70 53 75 62 2d  mBarrier = pSub-
47f0: 3e 78 53 68 6d 42 61 72 72 69 65 72 20 3f 20 76  >xShmBarrier ? v
4800: 66 73 74 72 61 63 65 53 68 6d 42 61 72 72 69 65  fstraceShmBarrie
4810: 72 20 3a 20 30 3b 0a 20 20 20 20 20 20 70 4e 65  r : 0;.      pNe
4820: 77 2d 3e 78 53 68 6d 55 6e 6d 61 70 20 3d 20 70  w->xShmUnmap = p
4830: 53 75 62 2d 3e 78 53 68 6d 55 6e 6d 61 70 20 3f  Sub->xShmUnmap ?
4840: 20 76 66 73 74 72 61 63 65 53 68 6d 55 6e 6d 61   vfstraceShmUnma
4850: 70 20 3a 20 30 3b 0a 20 20 20 20 7d 0a 20 20 20  p : 0;.    }.   
4860: 20 70 46 69 6c 65 2d 3e 70 4d 65 74 68 6f 64 73   pFile->pMethods
4870: 20 3d 20 70 4e 65 77 3b 0a 20 20 7d 0a 20 20 76   = pNew;.  }.  v
4880: 66 73 74 72 61 63 65 5f 70 72 69 6e 74 5f 65 72  fstrace_print_er
4890: 72 63 6f 64 65 28 70 49 6e 66 6f 2c 20 22 20 2d  rcode(pInfo, " -
48a0: 3e 20 25 73 22 2c 20 72 63 29 3b 0a 20 20 69 66  > %s", rc);.  if
48b0: 28 20 70 4f 75 74 46 6c 61 67 73 20 29 7b 0a 20  ( pOutFlags ){. 
48c0: 20 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e     vfstrace_prin
48d0: 74 66 28 70 49 6e 66 6f 2c 20 22 2c 20 6f 75 74  tf(pInfo, ", out
48e0: 46 6c 61 67 73 3d 30 78 25 78 5c 6e 22 2c 20 2a  Flags=0x%x\n", *
48f0: 70 4f 75 74 46 6c 61 67 73 29 3b 0a 20 20 7d 65  pOutFlags);.  }e
4900: 6c 73 65 7b 0a 20 20 20 20 76 66 73 74 72 61 63  lse{.    vfstrac
4910: 65 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20  e_printf(pInfo, 
4920: 22 5c 6e 22 29 3b 0a 20 20 7d 0a 20 20 72 65 74  "\n");.  }.  ret
4930: 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  urn rc;.}../*.**
4940: 20 44 65 6c 65 74 65 20 74 68 65 20 66 69 6c 65   Delete the file
4950: 20 6c 6f 63 61 74 65 64 20 61 74 20 7a 50 61 74   located at zPat
4960: 68 2e 20 49 66 20 74 68 65 20 64 69 72 53 79 6e  h. If the dirSyn
4970: 63 20 61 72 67 75 6d 65 6e 74 20 69 73 20 74 72  c argument is tr
4980: 75 65 2c 0a 2a 2a 20 65 6e 73 75 72 65 20 74 68  ue,.** ensure th
4990: 65 20 66 69 6c 65 2d 73 79 73 74 65 6d 20 6d 6f  e file-system mo
49a0: 64 69 66 69 63 61 74 69 6f 6e 73 20 61 72 65 20  difications are 
49b0: 73 79 6e 63 65 64 20 74 6f 20 64 69 73 6b 20 62  synced to disk b
49c0: 65 66 6f 72 65 0a 2a 2a 20 72 65 74 75 72 6e 69  efore.** returni
49d0: 6e 67 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e  ng..*/.static in
49e0: 74 20 76 66 73 74 72 61 63 65 44 65 6c 65 74 65  t vfstraceDelete
49f0: 28 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56  (sqlite3_vfs *pV
4a00: 66 73 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  fs, const char *
4a10: 7a 50 61 74 68 2c 20 69 6e 74 20 64 69 72 53 79  zPath, int dirSy
4a20: 6e 63 29 7b 0a 20 20 76 66 73 74 72 61 63 65 5f  nc){.  vfstrace_
4a30: 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 28 76  info *pInfo = (v
4a40: 66 73 74 72 61 63 65 5f 69 6e 66 6f 2a 29 70 56  fstrace_info*)pV
4a50: 66 73 2d 3e 70 41 70 70 44 61 74 61 3b 0a 20 20  fs->pAppData;.  
4a60: 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 52 6f  sqlite3_vfs *pRo
4a70: 6f 74 20 3d 20 70 49 6e 66 6f 2d 3e 70 52 6f 6f  ot = pInfo->pRoo
4a80: 74 56 66 73 3b 0a 20 20 69 6e 74 20 72 63 3b 0a  tVfs;.  int rc;.
4a90: 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74    vfstrace_print
4aa0: 66 28 70 49 6e 66 6f 2c 20 22 25 73 2e 78 44 65  f(pInfo, "%s.xDe
4ab0: 6c 65 74 65 28 5c 22 25 73 5c 22 2c 25 64 29 22  lete(\"%s\",%d)"
4ac0: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,.              
4ad0: 20 20 20 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e      pInfo->zVfsN
4ae0: 61 6d 65 2c 20 7a 50 61 74 68 2c 20 64 69 72 53  ame, zPath, dirS
4af0: 79 6e 63 29 3b 0a 20 20 72 63 20 3d 20 70 52 6f  ync);.  rc = pRo
4b00: 6f 74 2d 3e 78 44 65 6c 65 74 65 28 70 52 6f 6f  ot->xDelete(pRoo
4b10: 74 2c 20 7a 50 61 74 68 2c 20 64 69 72 53 79 6e  t, zPath, dirSyn
4b20: 63 29 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 70  c);.  vfstrace_p
4b30: 72 69 6e 74 5f 65 72 72 63 6f 64 65 28 70 49 6e  rint_errcode(pIn
4b40: 66 6f 2c 20 22 20 2d 3e 20 25 73 5c 6e 22 2c 20  fo, " -> %s\n", 
4b50: 72 63 29 3b 0a 20 20 72 65 74 75 72 6e 20 72 63  rc);.  return rc
4b60: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 65 73 74 20  ;.}../*.** Test 
4b70: 66 6f 72 20 61 63 63 65 73 73 20 70 65 72 6d 69  for access permi
4b80: 73 73 69 6f 6e 73 2e 20 52 65 74 75 72 6e 20 74  ssions. Return t
4b90: 72 75 65 20 69 66 20 74 68 65 20 72 65 71 75 65  rue if the reque
4ba0: 73 74 65 64 20 70 65 72 6d 69 73 73 69 6f 6e 0a  sted permission.
4bb0: 2a 2a 20 69 73 20 61 76 61 69 6c 61 62 6c 65 2c  ** is available,
4bc0: 20 6f 72 20 66 61 6c 73 65 20 6f 74 68 65 72 77   or false otherw
4bd0: 69 73 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69  ise..*/.static i
4be0: 6e 74 20 76 66 73 74 72 61 63 65 41 63 63 65 73  nt vfstraceAcces
4bf0: 73 28 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73  s(.  sqlite3_vfs
4c00: 20 2a 70 56 66 73 2c 20 0a 20 20 63 6f 6e 73 74   *pVfs, .  const
4c10: 20 63 68 61 72 20 2a 7a 50 61 74 68 2c 20 0a 20   char *zPath, . 
4c20: 20 69 6e 74 20 66 6c 61 67 73 2c 20 0a 20 20 69   int flags, .  i
4c30: 6e 74 20 2a 70 52 65 73 4f 75 74 0a 29 7b 0a 20  nt *pResOut.){. 
4c40: 20 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a   vfstrace_info *
4c50: 70 49 6e 66 6f 20 3d 20 28 76 66 73 74 72 61 63  pInfo = (vfstrac
4c60: 65 5f 69 6e 66 6f 2a 29 70 56 66 73 2d 3e 70 41  e_info*)pVfs->pA
4c70: 70 70 44 61 74 61 3b 0a 20 20 73 71 6c 69 74 65  ppData;.  sqlite
4c80: 33 5f 76 66 73 20 2a 70 52 6f 6f 74 20 3d 20 70  3_vfs *pRoot = p
4c90: 49 6e 66 6f 2d 3e 70 52 6f 6f 74 56 66 73 3b 0a  Info->pRootVfs;.
4ca0: 20 20 69 6e 74 20 72 63 3b 0a 20 20 76 66 73 74    int rc;.  vfst
4cb0: 72 61 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66  race_printf(pInf
4cc0: 6f 2c 20 22 25 73 2e 78 44 65 6c 65 74 65 28 5c  o, "%s.xDelete(\
4cd0: 22 25 73 5c 22 2c 25 64 29 22 2c 0a 20 20 20 20  "%s\",%d)",.    
4ce0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 70 49                pI
4cf0: 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d 65 2c 20 7a  nfo->zVfsName, z
4d00: 50 61 74 68 2c 20 66 6c 61 67 73 29 3b 0a 20 20  Path, flags);.  
4d10: 72 63 20 3d 20 70 52 6f 6f 74 2d 3e 78 41 63 63  rc = pRoot->xAcc
4d20: 65 73 73 28 70 52 6f 6f 74 2c 20 7a 50 61 74 68  ess(pRoot, zPath
4d30: 2c 20 66 6c 61 67 73 2c 20 70 52 65 73 4f 75 74  , flags, pResOut
4d40: 29 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72  );.  vfstrace_pr
4d50: 69 6e 74 5f 65 72 72 63 6f 64 65 28 70 49 6e 66  int_errcode(pInf
4d60: 6f 2c 20 22 20 2d 3e 20 25 73 22 2c 20 72 63 29  o, " -> %s", rc)
4d70: 3b 0a 20 20 76 66 73 74 72 61 63 65 5f 70 72 69  ;.  vfstrace_pri
4d80: 6e 74 66 28 70 49 6e 66 6f 2c 20 22 2c 20 6f 75  ntf(pInfo, ", ou
4d90: 74 3d 25 64 5c 6e 22 2c 20 2a 70 52 65 73 4f 75  t=%d\n", *pResOu
4da0: 74 29 3b 0a 20 20 72 65 74 75 72 6e 20 72 63 3b  t);.  return rc;
4db0: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 50 6f 70 75 6c 61  .}../*.** Popula
4dc0: 74 65 20 62 75 66 66 65 72 20 7a 4f 75 74 20 77  te buffer zOut w
4dd0: 69 74 68 20 74 68 65 20 66 75 6c 6c 20 63 61 6e  ith the full can
4de0: 6f 6e 69 63 61 6c 20 70 61 74 68 6e 61 6d 65 20  onical pathname 
4df0: 63 6f 72 72 65 73 70 6f 6e 64 69 6e 67 0a 2a 2a  corresponding.**
4e00: 20 74 6f 20 74 68 65 20 70 61 74 68 6e 61 6d 65   to the pathname
4e10: 20 69 6e 20 7a 50 61 74 68 2e 20 7a 4f 75 74 20   in zPath. zOut 
4e20: 69 73 20 67 75 61 72 61 6e 74 65 65 64 20 74 6f  is guaranteed to
4e30: 20 70 6f 69 6e 74 20 74 6f 20 61 20 62 75 66 66   point to a buff
4e40: 65 72 0a 2a 2a 20 6f 66 20 61 74 20 6c 65 61 73  er.** of at leas
4e50: 74 20 28 44 45 56 53 59 4d 5f 4d 41 58 5f 50 41  t (DEVSYM_MAX_PA
4e60: 54 48 4e 41 4d 45 2b 31 29 20 62 79 74 65 73 2e  THNAME+1) bytes.
4e70: 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 76  .*/.static int v
4e80: 66 73 74 72 61 63 65 46 75 6c 6c 50 61 74 68 6e  fstraceFullPathn
4e90: 61 6d 65 28 0a 20 20 73 71 6c 69 74 65 33 5f 76  ame(.  sqlite3_v
4ea0: 66 73 20 2a 70 56 66 73 2c 20 0a 20 20 63 6f 6e  fs *pVfs, .  con
4eb0: 73 74 20 63 68 61 72 20 2a 7a 50 61 74 68 2c 20  st char *zPath, 
4ec0: 0a 20 20 69 6e 74 20 6e 4f 75 74 2c 20 0a 20 20  .  int nOut, .  
4ed0: 63 68 61 72 20 2a 7a 4f 75 74 0a 29 7b 0a 20 20  char *zOut.){.  
4ee0: 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70  vfstrace_info *p
4ef0: 49 6e 66 6f 20 3d 20 28 76 66 73 74 72 61 63 65  Info = (vfstrace
4f00: 5f 69 6e 66 6f 2a 29 70 56 66 73 2d 3e 70 41 70  _info*)pVfs->pAp
4f10: 70 44 61 74 61 3b 0a 20 20 73 71 6c 69 74 65 33  pData;.  sqlite3
4f20: 5f 76 66 73 20 2a 70 52 6f 6f 74 20 3d 20 70 49  _vfs *pRoot = pI
4f30: 6e 66 6f 2d 3e 70 52 6f 6f 74 56 66 73 3b 0a 20  nfo->pRootVfs;. 
4f40: 20 69 6e 74 20 72 63 3b 0a 20 20 76 66 73 74 72   int rc;.  vfstr
4f50: 61 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f  ace_printf(pInfo
4f60: 2c 20 22 25 73 2e 78 46 75 6c 6c 50 61 74 68 6e  , "%s.xFullPathn
4f70: 61 6d 65 28 5c 22 25 73 5c 22 29 22 2c 0a 20 20  ame(\"%s\")",.  
4f80: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4f90: 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d 65 2c  pInfo->zVfsName,
4fa0: 20 7a 50 61 74 68 29 3b 0a 20 20 72 63 20 3d 20   zPath);.  rc = 
4fb0: 70 52 6f 6f 74 2d 3e 78 46 75 6c 6c 50 61 74 68  pRoot->xFullPath
4fc0: 6e 61 6d 65 28 70 52 6f 6f 74 2c 20 7a 50 61 74  name(pRoot, zPat
4fd0: 68 2c 20 6e 4f 75 74 2c 20 7a 4f 75 74 29 3b 0a  h, nOut, zOut);.
4fe0: 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74    vfstrace_print
4ff0: 5f 65 72 72 63 6f 64 65 28 70 49 6e 66 6f 2c 20  _errcode(pInfo, 
5000: 22 20 2d 3e 20 25 73 22 2c 20 72 63 29 3b 0a 20  " -> %s", rc);. 
5010: 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74 66   vfstrace_printf
5020: 28 70 49 6e 66 6f 2c 20 22 2c 20 6f 75 74 3d 5c  (pInfo, ", out=\
5030: 22 25 2e 2a 73 5c 22 5c 6e 22 2c 20 6e 4f 75 74  "%.*s\"\n", nOut
5040: 2c 20 7a 4f 75 74 29 3b 0a 20 20 72 65 74 75 72  , zOut);.  retur
5050: 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 4f  n rc;.}../*.** O
5060: 70 65 6e 20 74 68 65 20 64 79 6e 61 6d 69 63 20  pen the dynamic 
5070: 6c 69 62 72 61 72 79 20 6c 6f 63 61 74 65 64 20  library located 
5080: 61 74 20 7a 50 61 74 68 20 61 6e 64 20 72 65 74  at zPath and ret
5090: 75 72 6e 20 61 20 68 61 6e 64 6c 65 2e 0a 2a 2f  urn a handle..*/
50a0: 0a 73 74 61 74 69 63 20 76 6f 69 64 20 2a 76 66  .static void *vf
50b0: 73 74 72 61 63 65 44 6c 4f 70 65 6e 28 73 71 6c  straceDlOpen(sql
50c0: 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c 20  ite3_vfs *pVfs, 
50d0: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 50 61 74  const char *zPat
50e0: 68 29 7b 0a 20 20 76 66 73 74 72 61 63 65 5f 69  h){.  vfstrace_i
50f0: 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 28 76 66  nfo *pInfo = (vf
5100: 73 74 72 61 63 65 5f 69 6e 66 6f 2a 29 70 56 66  strace_info*)pVf
5110: 73 2d 3e 70 41 70 70 44 61 74 61 3b 0a 20 20 73  s->pAppData;.  s
5120: 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 52 6f 6f  qlite3_vfs *pRoo
5130: 74 20 3d 20 70 49 6e 66 6f 2d 3e 70 52 6f 6f 74  t = pInfo->pRoot
5140: 56 66 73 3b 0a 20 20 76 66 73 74 72 61 63 65 5f  Vfs;.  vfstrace_
5150: 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22 25  printf(pInfo, "%
5160: 73 2e 78 44 6c 4f 70 65 6e 28 5c 22 25 73 5c 22  s.xDlOpen(\"%s\"
5170: 29 5c 6e 22 2c 20 70 49 6e 66 6f 2d 3e 7a 56 66  )\n", pInfo->zVf
5180: 73 4e 61 6d 65 2c 20 7a 50 61 74 68 29 3b 0a 20  sName, zPath);. 
5190: 20 72 65 74 75 72 6e 20 70 52 6f 6f 74 2d 3e 78   return pRoot->x
51a0: 44 6c 4f 70 65 6e 28 70 52 6f 6f 74 2c 20 7a 50  DlOpen(pRoot, zP
51b0: 61 74 68 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 50  ath);.}../*.** P
51c0: 6f 70 75 6c 61 74 65 20 74 68 65 20 62 75 66 66  opulate the buff
51d0: 65 72 20 7a 45 72 72 4d 73 67 20 28 73 69 7a 65  er zErrMsg (size
51e0: 20 6e 42 79 74 65 20 62 79 74 65 73 29 20 77 69   nByte bytes) wi
51f0: 74 68 20 61 20 68 75 6d 61 6e 20 72 65 61 64 61  th a human reada
5200: 62 6c 65 0a 2a 2a 20 75 74 66 2d 38 20 73 74 72  ble.** utf-8 str
5210: 69 6e 67 20 64 65 73 63 72 69 62 69 6e 67 20 74  ing describing t
5220: 68 65 20 6d 6f 73 74 20 72 65 63 65 6e 74 20 65  he most recent e
5230: 72 72 6f 72 20 65 6e 63 6f 75 6e 74 65 72 65 64  rror encountered
5240: 20 61 73 73 6f 63 69 61 74 65 64 20 0a 2a 2a 20   associated .** 
5250: 77 69 74 68 20 64 79 6e 61 6d 69 63 20 6c 69 62  with dynamic lib
5260: 72 61 72 69 65 73 2e 0a 2a 2f 0a 73 74 61 74 69  raries..*/.stati
5270: 63 20 76 6f 69 64 20 76 66 73 74 72 61 63 65 44  c void vfstraceD
5280: 6c 45 72 72 6f 72 28 73 71 6c 69 74 65 33 5f 76  lError(sqlite3_v
5290: 66 73 20 2a 70 56 66 73 2c 20 69 6e 74 20 6e 42  fs *pVfs, int nB
52a0: 79 74 65 2c 20 63 68 61 72 20 2a 7a 45 72 72 4d  yte, char *zErrM
52b0: 73 67 29 7b 0a 20 20 76 66 73 74 72 61 63 65 5f  sg){.  vfstrace_
52c0: 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 28 76  info *pInfo = (v
52d0: 66 73 74 72 61 63 65 5f 69 6e 66 6f 2a 29 70 56  fstrace_info*)pV
52e0: 66 73 2d 3e 70 41 70 70 44 61 74 61 3b 0a 20 20  fs->pAppData;.  
52f0: 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 52 6f  sqlite3_vfs *pRo
5300: 6f 74 20 3d 20 70 49 6e 66 6f 2d 3e 70 52 6f 6f  ot = pInfo->pRoo
5310: 74 56 66 73 3b 0a 20 20 76 66 73 74 72 61 63 65  tVfs;.  vfstrace
5320: 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22  _printf(pInfo, "
5330: 25 73 2e 78 44 6c 45 72 72 6f 72 28 25 64 29 22  %s.xDlError(%d)"
5340: 2c 20 70 49 6e 66 6f 2d 3e 7a 56 66 73 4e 61 6d  , pInfo->zVfsNam
5350: 65 2c 20 6e 42 79 74 65 29 3b 0a 20 20 70 52 6f  e, nByte);.  pRo
5360: 6f 74 2d 3e 78 44 6c 45 72 72 6f 72 28 70 52 6f  ot->xDlError(pRo
5370: 6f 74 2c 20 6e 42 79 74 65 2c 20 7a 45 72 72 4d  ot, nByte, zErrM
5380: 73 67 29 3b 0a 20 20 76 66 73 74 72 61 63 65 5f  sg);.  vfstrace_
5390: 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c 20 22 20  printf(pInfo, " 
53a0: 2d 3e 20 5c 22 25 73 5c 22 22 2c 20 7a 45 72 72  -> \"%s\"", zErr
53b0: 4d 73 67 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52  Msg);.}../*.** R
53c0: 65 74 75 72 6e 20 61 20 70 6f 69 6e 74 65 72 20  eturn a pointer 
53d0: 74 6f 20 74 68 65 20 73 79 6d 62 6f 6c 20 7a 53  to the symbol zS
53e0: 79 6d 62 6f 6c 20 69 6e 20 74 68 65 20 64 79 6e  ymbol in the dyn
53f0: 61 6d 69 63 20 6c 69 62 72 61 72 79 20 70 48 61  amic library pHa
5400: 6e 64 6c 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  ndle..*/.static 
5410: 76 6f 69 64 20 28 2a 76 66 73 74 72 61 63 65 44  void (*vfstraceD
5420: 6c 53 79 6d 28 73 71 6c 69 74 65 33 5f 76 66 73  lSym(sqlite3_vfs
5430: 20 2a 70 56 66 73 2c 76 6f 69 64 20 2a 70 2c 63   *pVfs,void *p,c
5440: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 53 79 6d 29  onst char *zSym)
5450: 29 28 76 6f 69 64 29 7b 0a 20 20 76 66 73 74 72  )(void){.  vfstr
5460: 61 63 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20  ace_info *pInfo 
5470: 3d 20 28 76 66 73 74 72 61 63 65 5f 69 6e 66 6f  = (vfstrace_info
5480: 2a 29 70 56 66 73 2d 3e 70 41 70 70 44 61 74 61  *)pVfs->pAppData
5490: 3b 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20  ;.  sqlite3_vfs 
54a0: 2a 70 52 6f 6f 74 20 3d 20 70 49 6e 66 6f 2d 3e  *pRoot = pInfo->
54b0: 70 52 6f 6f 74 56 66 73 3b 0a 20 20 76 66 73 74  pRootVfs;.  vfst
54c0: 72 61 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66  race_printf(pInf
54d0: 6f 2c 20 22 25 73 2e 78 44 6c 53 79 6d 28 5c 22  o, "%s.xDlSym(\"
54e0: 25 73 5c 22 29 5c 6e 22 2c 20 70 49 6e 66 6f 2d  %s\")\n", pInfo-
54f0: 3e 7a 56 66 73 4e 61 6d 65 2c 20 7a 53 79 6d 29  >zVfsName, zSym)
5500: 3b 0a 20 20 72 65 74 75 72 6e 20 70 52 6f 6f 74  ;.  return pRoot
5510: 2d 3e 78 44 6c 53 79 6d 28 70 52 6f 6f 74 2c 20  ->xDlSym(pRoot, 
5520: 70 2c 20 7a 53 79 6d 29 3b 0a 7d 0a 0a 2f 2a 0a  p, zSym);.}../*.
5530: 2a 2a 20 43 6c 6f 73 65 20 74 68 65 20 64 79 6e  ** Close the dyn
5540: 61 6d 69 63 20 6c 69 62 72 61 72 79 20 68 61 6e  amic library han
5550: 64 6c 65 20 70 48 61 6e 64 6c 65 2e 0a 2a 2f 0a  dle pHandle..*/.
5560: 73 74 61 74 69 63 20 76 6f 69 64 20 76 66 73 74  static void vfst
5570: 72 61 63 65 44 6c 43 6c 6f 73 65 28 73 71 6c 69  raceDlClose(sqli
5580: 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c 20 76  te3_vfs *pVfs, v
5590: 6f 69 64 20 2a 70 48 61 6e 64 6c 65 29 7b 0a 20  oid *pHandle){. 
55a0: 20 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a   vfstrace_info *
55b0: 70 49 6e 66 6f 20 3d 20 28 76 66 73 74 72 61 63  pInfo = (vfstrac
55c0: 65 5f 69 6e 66 6f 2a 29 70 56 66 73 2d 3e 70 41  e_info*)pVfs->pA
55d0: 70 70 44 61 74 61 3b 0a 20 20 73 71 6c 69 74 65  ppData;.  sqlite
55e0: 33 5f 76 66 73 20 2a 70 52 6f 6f 74 20 3d 20 70  3_vfs *pRoot = p
55f0: 49 6e 66 6f 2d 3e 70 52 6f 6f 74 56 66 73 3b 0a  Info->pRootVfs;.
5600: 20 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74    vfstrace_print
5610: 66 28 70 49 6e 66 6f 2c 20 22 25 73 2e 78 44 6c  f(pInfo, "%s.xDl
5620: 4f 70 65 6e 28 29 5c 6e 22 2c 20 70 49 6e 66 6f  Open()\n", pInfo
5630: 2d 3e 7a 56 66 73 4e 61 6d 65 29 3b 0a 20 20 70  ->zVfsName);.  p
5640: 52 6f 6f 74 2d 3e 78 44 6c 43 6c 6f 73 65 28 70  Root->xDlClose(p
5650: 52 6f 6f 74 2c 20 70 48 61 6e 64 6c 65 29 3b 0a  Root, pHandle);.
5660: 7d 0a 0a 2f 2a 0a 2a 2a 20 50 6f 70 75 6c 61 74  }../*.** Populat
5670: 65 20 74 68 65 20 62 75 66 66 65 72 20 70 6f 69  e the buffer poi
5680: 6e 74 65 64 20 74 6f 20 62 79 20 7a 42 75 66 4f  nted to by zBufO
5690: 75 74 20 77 69 74 68 20 6e 42 79 74 65 20 62 79  ut with nByte by
56a0: 74 65 73 20 6f 66 20 0a 2a 2a 20 72 61 6e 64 6f  tes of .** rando
56b0: 6d 20 64 61 74 61 2e 0a 2a 2f 0a 73 74 61 74 69  m data..*/.stati
56c0: 63 20 69 6e 74 20 76 66 73 74 72 61 63 65 52 61  c int vfstraceRa
56d0: 6e 64 6f 6d 6e 65 73 73 28 73 71 6c 69 74 65 33  ndomness(sqlite3
56e0: 5f 76 66 73 20 2a 70 56 66 73 2c 20 69 6e 74 20  _vfs *pVfs, int 
56f0: 6e 42 79 74 65 2c 20 63 68 61 72 20 2a 7a 42 75  nByte, char *zBu
5700: 66 4f 75 74 29 7b 0a 20 20 76 66 73 74 72 61 63  fOut){.  vfstrac
5710: 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20  e_info *pInfo = 
5720: 28 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 2a 29  (vfstrace_info*)
5730: 70 56 66 73 2d 3e 70 41 70 70 44 61 74 61 3b 0a  pVfs->pAppData;.
5740: 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70    sqlite3_vfs *p
5750: 52 6f 6f 74 20 3d 20 70 49 6e 66 6f 2d 3e 70 52  Root = pInfo->pR
5760: 6f 6f 74 56 66 73 3b 0a 20 20 76 66 73 74 72 61  ootVfs;.  vfstra
5770: 63 65 5f 70 72 69 6e 74 66 28 70 49 6e 66 6f 2c  ce_printf(pInfo,
5780: 20 22 25 73 2e 78 52 61 6e 64 6f 6d 6e 65 73 73   "%s.xRandomness
5790: 28 25 64 29 5c 6e 22 2c 20 70 49 6e 66 6f 2d 3e  (%d)\n", pInfo->
57a0: 7a 56 66 73 4e 61 6d 65 2c 20 6e 42 79 74 65 29  zVfsName, nByte)
57b0: 3b 0a 20 20 72 65 74 75 72 6e 20 70 52 6f 6f 74  ;.  return pRoot
57c0: 2d 3e 78 52 61 6e 64 6f 6d 6e 65 73 73 28 70 52  ->xRandomness(pR
57d0: 6f 6f 74 2c 20 6e 42 79 74 65 2c 20 7a 42 75 66  oot, nByte, zBuf
57e0: 4f 75 74 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 53  Out);.}../*.** S
57f0: 6c 65 65 70 20 66 6f 72 20 6e 4d 69 63 72 6f 20  leep for nMicro 
5800: 6d 69 63 72 6f 73 65 63 6f 6e 64 73 2e 20 52 65  microseconds. Re
5810: 74 75 72 6e 20 74 68 65 20 6e 75 6d 62 65 72 20  turn the number 
5820: 6f 66 20 6d 69 63 72 6f 73 65 63 6f 6e 64 73 20  of microseconds 
5830: 0a 2a 2a 20 61 63 74 75 61 6c 6c 79 20 73 6c 65  .** actually sle
5840: 70 74 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e  pt..*/.static in
5850: 74 20 76 66 73 74 72 61 63 65 53 6c 65 65 70 28  t vfstraceSleep(
5860: 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66  sqlite3_vfs *pVf
5870: 73 2c 20 69 6e 74 20 6e 4d 69 63 72 6f 29 7b 0a  s, int nMicro){.
5880: 20 20 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 20    vfstrace_info 
5890: 2a 70 49 6e 66 6f 20 3d 20 28 76 66 73 74 72 61  *pInfo = (vfstra
58a0: 63 65 5f 69 6e 66 6f 2a 29 70 56 66 73 2d 3e 70  ce_info*)pVfs->p
58b0: 41 70 70 44 61 74 61 3b 0a 20 20 73 71 6c 69 74  AppData;.  sqlit
58c0: 65 33 5f 76 66 73 20 2a 70 52 6f 6f 74 20 3d 20  e3_vfs *pRoot = 
58d0: 70 49 6e 66 6f 2d 3e 70 52 6f 6f 74 56 66 73 3b  pInfo->pRootVfs;
58e0: 0a 20 20 72 65 74 75 72 6e 20 70 52 6f 6f 74 2d  .  return pRoot-
58f0: 3e 78 53 6c 65 65 70 28 70 52 6f 6f 74 2c 20 6e  >xSleep(pRoot, n
5900: 4d 69 63 72 6f 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  Micro);.}../*.**
5910: 20 52 65 74 75 72 6e 20 74 68 65 20 63 75 72 72   Return the curr
5920: 65 6e 74 20 74 69 6d 65 20 61 73 20 61 20 4a 75  ent time as a Ju
5930: 6c 69 61 6e 20 44 61 79 20 6e 75 6d 62 65 72 20  lian Day number 
5940: 69 6e 20 2a 70 54 69 6d 65 4f 75 74 2e 0a 2a 2f  in *pTimeOut..*/
5950: 0a 73 74 61 74 69 63 20 69 6e 74 20 76 66 73 74  .static int vfst
5960: 72 61 63 65 43 75 72 72 65 6e 74 54 69 6d 65 28  raceCurrentTime(
5970: 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66  sqlite3_vfs *pVf
5980: 73 2c 20 64 6f 75 62 6c 65 20 2a 70 54 69 6d 65  s, double *pTime
5990: 4f 75 74 29 7b 0a 20 20 76 66 73 74 72 61 63 65  Out){.  vfstrace
59a0: 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 28  _info *pInfo = (
59b0: 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 2a 29 70  vfstrace_info*)p
59c0: 56 66 73 2d 3e 70 41 70 70 44 61 74 61 3b 0a 20  Vfs->pAppData;. 
59d0: 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 52   sqlite3_vfs *pR
59e0: 6f 6f 74 20 3d 20 70 49 6e 66 6f 2d 3e 70 52 6f  oot = pInfo->pRo
59f0: 6f 74 56 66 73 3b 0a 20 20 72 65 74 75 72 6e 20  otVfs;.  return 
5a00: 70 52 6f 6f 74 2d 3e 78 43 75 72 72 65 6e 74 54  pRoot->xCurrentT
5a10: 69 6d 65 28 70 52 6f 6f 74 2c 20 70 54 69 6d 65  ime(pRoot, pTime
5a20: 4f 75 74 29 3b 0a 7d 0a 73 74 61 74 69 63 20 69  Out);.}.static i
5a30: 6e 74 20 76 66 73 74 72 61 63 65 43 75 72 72 65  nt vfstraceCurre
5a40: 6e 74 54 69 6d 65 49 6e 74 36 34 28 73 71 6c 69  ntTimeInt64(sqli
5a50: 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c 20 73  te3_vfs *pVfs, s
5a60: 71 6c 69 74 65 33 5f 69 6e 74 36 34 20 2a 70 54  qlite3_int64 *pT
5a70: 69 6d 65 4f 75 74 29 7b 0a 20 20 76 66 73 74 72  imeOut){.  vfstr
5a80: 61 63 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f 20  ace_info *pInfo 
5a90: 3d 20 28 76 66 73 74 72 61 63 65 5f 69 6e 66 6f  = (vfstrace_info
5aa0: 2a 29 70 56 66 73 2d 3e 70 41 70 70 44 61 74 61  *)pVfs->pAppData
5ab0: 3b 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20  ;.  sqlite3_vfs 
5ac0: 2a 70 52 6f 6f 74 20 3d 20 70 49 6e 66 6f 2d 3e  *pRoot = pInfo->
5ad0: 70 52 6f 6f 74 56 66 73 3b 0a 20 20 72 65 74 75  pRootVfs;.  retu
5ae0: 72 6e 20 70 52 6f 6f 74 2d 3e 78 43 75 72 72 65  rn pRoot->xCurre
5af0: 6e 74 54 69 6d 65 49 6e 74 36 34 28 70 52 6f 6f  ntTimeInt64(pRoo
5b00: 74 2c 20 70 54 69 6d 65 4f 75 74 29 3b 0a 7d 0a  t, pTimeOut);.}.
5b10: 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68  ./*.** Return th
5b20: 33 20 65 6d 6f 73 74 20 72 65 63 65 6e 74 20 65  3 emost recent e
5b30: 72 72 6f 72 20 63 6f 64 65 20 61 6e 64 20 6d 65  rror code and me
5b40: 73 73 61 67 65 0a 2a 2f 0a 73 74 61 74 69 63 20  ssage.*/.static 
5b50: 69 6e 74 20 76 66 73 74 72 61 63 65 47 65 74 4c  int vfstraceGetL
5b60: 61 73 74 45 72 72 6f 72 28 73 71 6c 69 74 65 33  astError(sqlite3
5b70: 5f 76 66 73 20 2a 70 56 66 73 2c 20 69 6e 74 20  _vfs *pVfs, int 
5b80: 69 45 72 72 2c 20 63 68 61 72 20 2a 7a 45 72 72  iErr, char *zErr
5b90: 29 7b 0a 20 20 76 66 73 74 72 61 63 65 5f 69 6e  ){.  vfstrace_in
5ba0: 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 28 76 66 73  fo *pInfo = (vfs
5bb0: 74 72 61 63 65 5f 69 6e 66 6f 2a 29 70 56 66 73  trace_info*)pVfs
5bc0: 2d 3e 70 41 70 70 44 61 74 61 3b 0a 20 20 73 71  ->pAppData;.  sq
5bd0: 6c 69 74 65 33 5f 76 66 73 20 2a 70 52 6f 6f 74  lite3_vfs *pRoot
5be0: 20 3d 20 70 49 6e 66 6f 2d 3e 70 52 6f 6f 74 56   = pInfo->pRootV
5bf0: 66 73 3b 0a 20 20 72 65 74 75 72 6e 20 70 52 6f  fs;.  return pRo
5c00: 6f 74 2d 3e 78 47 65 74 4c 61 73 74 45 72 72 6f  ot->xGetLastErro
5c10: 72 28 70 52 6f 6f 74 2c 20 69 45 72 72 2c 20 7a  r(pRoot, iErr, z
5c20: 45 72 72 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 4f  Err);.}../*.** O
5c30: 76 65 72 72 69 64 65 20 73 79 73 74 65 6d 20 63  verride system c
5c40: 61 6c 6c 73 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  alls..*/.static 
5c50: 69 6e 74 20 76 66 73 74 72 61 63 65 53 65 74 53  int vfstraceSetS
5c60: 79 73 74 65 6d 43 61 6c 6c 28 0a 20 20 73 71 6c  ystemCall(.  sql
5c70: 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c 0a  ite3_vfs *pVfs,.
5c80: 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 4e    const char *zN
5c90: 61 6d 65 2c 0a 20 20 73 71 6c 69 74 65 33 5f 73  ame,.  sqlite3_s
5ca0: 79 73 63 61 6c 6c 5f 70 74 72 20 70 46 75 6e 63  yscall_ptr pFunc
5cb0: 0a 29 7b 0a 20 20 76 66 73 74 72 61 63 65 5f 69  .){.  vfstrace_i
5cc0: 6e 66 6f 20 2a 70 49 6e 66 6f 20 3d 20 28 76 66  nfo *pInfo = (vf
5cd0: 73 74 72 61 63 65 5f 69 6e 66 6f 2a 29 70 56 66  strace_info*)pVf
5ce0: 73 2d 3e 70 41 70 70 44 61 74 61 3b 0a 20 20 73  s->pAppData;.  s
5cf0: 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 52 6f 6f  qlite3_vfs *pRoo
5d00: 74 20 3d 20 70 49 6e 66 6f 2d 3e 70 52 6f 6f 74  t = pInfo->pRoot
5d10: 56 66 73 3b 0a 20 20 72 65 74 75 72 6e 20 70 52  Vfs;.  return pR
5d20: 6f 6f 74 2d 3e 78 53 65 74 53 79 73 74 65 6d 43  oot->xSetSystemC
5d30: 61 6c 6c 28 70 52 6f 6f 74 2c 20 7a 4e 61 6d 65  all(pRoot, zName
5d40: 2c 20 70 46 75 6e 63 29 3b 0a 7d 0a 73 74 61 74  , pFunc);.}.stat
5d50: 69 63 20 73 71 6c 69 74 65 33 5f 73 79 73 63 61  ic sqlite3_sysca
5d60: 6c 6c 5f 70 74 72 20 76 66 73 74 72 61 63 65 47  ll_ptr vfstraceG
5d70: 65 74 53 79 73 74 65 6d 43 61 6c 6c 28 0a 20 20  etSystemCall(.  
5d80: 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66  sqlite3_vfs *pVf
5d90: 73 2c 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20  s,.  const char 
5da0: 2a 7a 4e 61 6d 65 0a 29 7b 0a 20 20 76 66 73 74  *zName.){.  vfst
5db0: 72 61 63 65 5f 69 6e 66 6f 20 2a 70 49 6e 66 6f  race_info *pInfo
5dc0: 20 3d 20 28 76 66 73 74 72 61 63 65 5f 69 6e 66   = (vfstrace_inf
5dd0: 6f 2a 29 70 56 66 73 2d 3e 70 41 70 70 44 61 74  o*)pVfs->pAppDat
5de0: 61 3b 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73  a;.  sqlite3_vfs
5df0: 20 2a 70 52 6f 6f 74 20 3d 20 70 49 6e 66 6f 2d   *pRoot = pInfo-
5e00: 3e 70 52 6f 6f 74 56 66 73 3b 0a 20 20 72 65 74  >pRootVfs;.  ret
5e10: 75 72 6e 20 70 52 6f 6f 74 2d 3e 78 47 65 74 53  urn pRoot->xGetS
5e20: 79 73 74 65 6d 43 61 6c 6c 28 70 52 6f 6f 74 2c  ystemCall(pRoot,
5e30: 20 7a 4e 61 6d 65 29 3b 0a 7d 0a 73 74 61 74 69   zName);.}.stati
5e40: 63 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 76 66  c const char *vf
5e50: 73 74 72 61 63 65 4e 65 78 74 53 79 73 74 65 6d  straceNextSystem
5e60: 43 61 6c 6c 28 73 71 6c 69 74 65 33 5f 76 66 73  Call(sqlite3_vfs
5e70: 20 2a 70 56 66 73 2c 20 63 6f 6e 73 74 20 63 68   *pVfs, const ch
5e80: 61 72 20 2a 7a 4e 61 6d 65 29 7b 0a 20 20 76 66  ar *zName){.  vf
5e90: 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a 70 49 6e  strace_info *pIn
5ea0: 66 6f 20 3d 20 28 76 66 73 74 72 61 63 65 5f 69  fo = (vfstrace_i
5eb0: 6e 66 6f 2a 29 70 56 66 73 2d 3e 70 41 70 70 44  nfo*)pVfs->pAppD
5ec0: 61 74 61 3b 0a 20 20 73 71 6c 69 74 65 33 5f 76  ata;.  sqlite3_v
5ed0: 66 73 20 2a 70 52 6f 6f 74 20 3d 20 70 49 6e 66  fs *pRoot = pInf
5ee0: 6f 2d 3e 70 52 6f 6f 74 56 66 73 3b 0a 20 20 72  o->pRootVfs;.  r
5ef0: 65 74 75 72 6e 20 70 52 6f 6f 74 2d 3e 78 4e 65  eturn pRoot->xNe
5f00: 78 74 53 79 73 74 65 6d 43 61 6c 6c 28 70 52 6f  xtSystemCall(pRo
5f10: 6f 74 2c 20 7a 4e 61 6d 65 29 3b 0a 7d 0a 0a 0a  ot, zName);.}...
5f20: 2f 2a 0a 2a 2a 20 43 6c 69 65 6e 74 73 20 69 6e  /*.** Clients in
5f30: 76 6f 6b 65 20 74 68 69 73 20 72 6f 75 74 69 6e  voke this routin
5f40: 65 20 74 6f 20 63 6f 6e 73 74 72 75 63 74 20 61  e to construct a
5f50: 20 6e 65 77 20 74 72 61 63 65 2d 76 66 73 20 73   new trace-vfs s
5f60: 68 69 6d 2e 0a 2a 2a 0a 2a 2a 20 52 65 74 75 72  him..**.** Retur
5f70: 6e 20 53 51 4c 49 54 45 5f 4f 4b 20 6f 6e 20 73  n SQLITE_OK on s
5f80: 75 63 63 65 73 73 2e 20 20 0a 2a 2a 0a 2a 2a 20  uccess.  .**.** 
5f90: 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 20 69 73 20  SQLITE_NOMEM is 
5fa0: 72 65 74 75 72 6e 65 64 20 69 6e 20 74 68 65 20  returned in the 
5fb0: 63 61 73 65 20 6f 66 20 61 20 6d 65 6d 6f 72 79  case of a memory
5fc0: 20 61 6c 6c 6f 63 61 74 69 6f 6e 20 65 72 72 6f   allocation erro
5fd0: 72 2e 0a 2a 2a 20 53 51 4c 49 54 45 5f 4e 4f 54  r..** SQLITE_NOT
5fe0: 46 4f 55 4e 44 20 69 73 20 72 65 74 75 72 6e 65  FOUND is returne
5ff0: 64 20 69 66 20 7a 4f 6c 64 56 66 73 4e 61 6d 65  d if zOldVfsName
6000: 20 64 6f 65 73 20 6e 6f 74 20 65 78 69 73 74 2e   does not exist.
6010: 0a 2a 2f 0a 69 6e 74 20 76 66 73 74 72 61 63 65  .*/.int vfstrace
6020: 5f 72 65 67 69 73 74 65 72 28 0a 20 20 20 63 6f  _register(.   co
6030: 6e 73 74 20 63 68 61 72 20 2a 7a 54 72 61 63 65  nst char *zTrace
6040: 4e 61 6d 65 2c 20 20 20 20 20 20 20 20 20 20 20  Name,           
6050: 2f 2a 20 4e 61 6d 65 20 6f 66 20 74 68 65 20 6e  /* Name of the n
6060: 65 77 6c 79 20 63 6f 6e 73 74 72 75 63 74 65 64  ewly constructed
6070: 20 56 46 53 20 2a 2f 0a 20 20 20 63 6f 6e 73 74   VFS */.   const
6080: 20 63 68 61 72 20 2a 7a 4f 6c 64 56 66 73 4e 61   char *zOldVfsNa
6090: 6d 65 2c 20 20 20 20 20 20 20 20 20 20 2f 2a 20  me,          /* 
60a0: 4e 61 6d 65 20 6f 66 20 74 68 65 20 75 6e 64 65  Name of the unde
60b0: 72 6c 79 69 6e 67 20 56 46 53 20 2a 2f 0a 20 20  rlying VFS */.  
60c0: 20 69 6e 74 20 28 2a 78 4f 75 74 29 28 63 6f 6e   int (*xOut)(con
60d0: 73 74 20 63 68 61 72 2a 2c 76 6f 69 64 2a 29 2c  st char*,void*),
60e0: 20 20 20 2f 2a 20 4f 75 74 70 75 74 20 72 6f 75     /* Output rou
60f0: 74 69 6e 65 2e 20 20 65 78 3a 20 66 70 75 74 73  tine.  ex: fputs
6100: 20 2a 2f 0a 20 20 20 76 6f 69 64 20 2a 70 4f 75   */.   void *pOu
6110: 74 41 72 67 2c 20 20 20 20 20 20 20 20 20 20 20  tArg,           
6120: 20 20 20 20 20 20 20 20 20 2f 2a 20 32 6e 64 20           /* 2nd 
6130: 61 72 67 75 6d 65 6e 74 20 74 6f 20 78 4f 75 74  argument to xOut
6140: 2e 20 20 65 78 3a 20 73 74 64 65 72 72 20 2a 2f  .  ex: stderr */
6150: 0a 20 20 20 69 6e 74 20 6d 61 6b 65 44 65 66 61  .   int makeDefa
6160: 75 6c 74 20 20 20 20 20 20 20 20 20 20 20 20 20  ult             
6170: 20 20 20 20 20 20 2f 2a 20 54 72 75 65 20 74 6f        /* True to
6180: 20 6d 61 6b 65 20 74 68 65 20 6e 65 77 20 56 46   make the new VF
6190: 53 20 74 68 65 20 64 65 66 61 75 6c 74 20 2a 2f  S the default */
61a0: 0a 29 7b 0a 20 20 73 71 6c 69 74 65 33 5f 76 66  .){.  sqlite3_vf
61b0: 73 20 2a 70 4e 65 77 3b 0a 20 20 73 71 6c 69 74  s *pNew;.  sqlit
61c0: 65 33 5f 76 66 73 20 2a 70 52 6f 6f 74 3b 0a 20  e3_vfs *pRoot;. 
61d0: 20 76 66 73 74 72 61 63 65 5f 69 6e 66 6f 20 2a   vfstrace_info *
61e0: 70 49 6e 66 6f 3b 0a 20 20 69 6e 74 20 6e 4e 61  pInfo;.  int nNa
61f0: 6d 65 3b 0a 20 20 69 6e 74 20 6e 42 79 74 65 3b  me;.  int nByte;
6200: 0a 0a 20 20 70 52 6f 6f 74 20 3d 20 73 71 6c 69  ..  pRoot = sqli
6210: 74 65 33 5f 76 66 73 5f 66 69 6e 64 28 7a 4f 6c  te3_vfs_find(zOl
6220: 64 56 66 73 4e 61 6d 65 29 3b 0a 20 20 69 66 28  dVfsName);.  if(
6230: 20 70 52 6f 6f 74 3d 3d 30 20 29 20 72 65 74 75   pRoot==0 ) retu
6240: 72 6e 20 53 51 4c 49 54 45 5f 4e 4f 54 46 4f 55  rn SQLITE_NOTFOU
6250: 4e 44 3b 0a 20 20 6e 4e 61 6d 65 20 3d 20 73 74  ND;.  nName = st
6260: 72 6c 65 6e 28 7a 54 72 61 63 65 4e 61 6d 65 29  rlen(zTraceName)
6270: 3b 0a 20 20 6e 42 79 74 65 20 3d 20 73 69 7a 65  ;.  nByte = size
6280: 6f 66 28 2a 70 4e 65 77 29 20 2b 20 73 69 7a 65  of(*pNew) + size
6290: 6f 66 28 2a 70 49 6e 66 6f 29 20 2b 20 6e 4e 61  of(*pInfo) + nNa
62a0: 6d 65 20 2b 20 31 3b 0a 20 20 70 4e 65 77 20 3d  me + 1;.  pNew =
62b0: 20 73 71 6c 69 74 65 33 5f 6d 61 6c 6c 6f 63 28   sqlite3_malloc(
62c0: 20 6e 42 79 74 65 20 29 3b 0a 20 20 69 66 28 20   nByte );.  if( 
62d0: 70 4e 65 77 3d 3d 30 20 29 20 72 65 74 75 72 6e  pNew==0 ) return
62e0: 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3b 0a 20   SQLITE_NOMEM;. 
62f0: 20 6d 65 6d 73 65 74 28 70 4e 65 77 2c 20 30 2c   memset(pNew, 0,
6300: 20 6e 42 79 74 65 29 3b 0a 20 20 70 49 6e 66 6f   nByte);.  pInfo
6310: 20 3d 20 28 76 66 73 74 72 61 63 65 5f 69 6e 66   = (vfstrace_inf
6320: 6f 2a 29 26 70 4e 65 77 5b 31 5d 3b 0a 20 20 70  o*)&pNew[1];.  p
6330: 4e 65 77 2d 3e 69 56 65 72 73 69 6f 6e 20 3d 20  New->iVersion = 
6340: 70 52 6f 6f 74 2d 3e 69 56 65 72 73 69 6f 6e 3b  pRoot->iVersion;
6350: 0a 20 20 70 4e 65 77 2d 3e 73 7a 4f 73 46 69 6c  .  pNew->szOsFil
6360: 65 20 3d 20 70 52 6f 6f 74 2d 3e 73 7a 4f 73 46  e = pRoot->szOsF
6370: 69 6c 65 20 2b 20 73 69 7a 65 6f 66 28 76 66 73  ile + sizeof(vfs
6380: 74 72 61 63 65 5f 66 69 6c 65 29 3b 0a 20 20 70  trace_file);.  p
6390: 4e 65 77 2d 3e 6d 78 50 61 74 68 6e 61 6d 65 20  New->mxPathname 
63a0: 3d 20 70 52 6f 6f 74 2d 3e 6d 78 50 61 74 68 6e  = pRoot->mxPathn
63b0: 61 6d 65 3b 0a 20 20 70 4e 65 77 2d 3e 7a 4e 61  ame;.  pNew->zNa
63c0: 6d 65 20 3d 20 28 63 68 61 72 2a 29 26 70 49 6e  me = (char*)&pIn
63d0: 66 6f 5b 31 5d 3b 0a 20 20 6d 65 6d 63 70 79 28  fo[1];.  memcpy(
63e0: 28 63 68 61 72 2a 29 26 70 49 6e 66 6f 5b 31 5d  (char*)&pInfo[1]
63f0: 2c 20 7a 54 72 61 63 65 4e 61 6d 65 2c 20 6e 4e  , zTraceName, nN
6400: 61 6d 65 2b 31 29 3b 0a 20 20 70 4e 65 77 2d 3e  ame+1);.  pNew->
6410: 70 41 70 70 44 61 74 61 20 3d 20 70 49 6e 66 6f  pAppData = pInfo
6420: 3b 0a 20 20 70 4e 65 77 2d 3e 78 4f 70 65 6e 20  ;.  pNew->xOpen 
6430: 3d 20 76 66 73 74 72 61 63 65 4f 70 65 6e 3b 0a  = vfstraceOpen;.
6440: 20 20 70 4e 65 77 2d 3e 78 44 65 6c 65 74 65 20    pNew->xDelete 
6450: 3d 20 76 66 73 74 72 61 63 65 44 65 6c 65 74 65  = vfstraceDelete
6460: 3b 0a 20 20 70 4e 65 77 2d 3e 78 41 63 63 65 73  ;.  pNew->xAcces
6470: 73 20 3d 20 76 66 73 74 72 61 63 65 41 63 63 65  s = vfstraceAcce
6480: 73 73 3b 0a 20 20 70 4e 65 77 2d 3e 78 46 75 6c  ss;.  pNew->xFul
6490: 6c 50 61 74 68 6e 61 6d 65 20 3d 20 76 66 73 74  lPathname = vfst
64a0: 72 61 63 65 46 75 6c 6c 50 61 74 68 6e 61 6d 65  raceFullPathname
64b0: 3b 0a 20 20 70 4e 65 77 2d 3e 78 44 6c 4f 70 65  ;.  pNew->xDlOpe
64c0: 6e 20 3d 20 70 52 6f 6f 74 2d 3e 78 44 6c 4f 70  n = pRoot->xDlOp
64d0: 65 6e 3d 3d 30 20 3f 20 30 20 3a 20 76 66 73 74  en==0 ? 0 : vfst
64e0: 72 61 63 65 44 6c 4f 70 65 6e 3b 0a 20 20 70 4e  raceDlOpen;.  pN
64f0: 65 77 2d 3e 78 44 6c 45 72 72 6f 72 20 3d 20 70  ew->xDlError = p
6500: 52 6f 6f 74 2d 3e 78 44 6c 45 72 72 6f 72 3d 3d  Root->xDlError==
6510: 30 20 3f 20 30 20 3a 20 76 66 73 74 72 61 63 65  0 ? 0 : vfstrace
6520: 44 6c 45 72 72 6f 72 3b 0a 20 20 70 4e 65 77 2d  DlError;.  pNew-
6530: 3e 78 44 6c 53 79 6d 20 3d 20 70 52 6f 6f 74 2d  >xDlSym = pRoot-
6540: 3e 78 44 6c 53 79 6d 3d 3d 30 20 3f 20 30 20 3a  >xDlSym==0 ? 0 :
6550: 20 76 66 73 74 72 61 63 65 44 6c 53 79 6d 3b 0a   vfstraceDlSym;.
6560: 20 20 70 4e 65 77 2d 3e 78 44 6c 43 6c 6f 73 65    pNew->xDlClose
6570: 20 3d 20 70 52 6f 6f 74 2d 3e 78 44 6c 43 6c 6f   = pRoot->xDlClo
6580: 73 65 3d 3d 30 20 3f 20 30 20 3a 20 76 66 73 74  se==0 ? 0 : vfst
6590: 72 61 63 65 44 6c 43 6c 6f 73 65 3b 0a 20 20 70  raceDlClose;.  p
65a0: 4e 65 77 2d 3e 78 52 61 6e 64 6f 6d 6e 65 73 73  New->xRandomness
65b0: 20 3d 20 76 66 73 74 72 61 63 65 52 61 6e 64 6f   = vfstraceRando
65c0: 6d 6e 65 73 73 3b 0a 20 20 70 4e 65 77 2d 3e 78  mness;.  pNew->x
65d0: 53 6c 65 65 70 20 3d 20 76 66 73 74 72 61 63 65  Sleep = vfstrace
65e0: 53 6c 65 65 70 3b 0a 20 20 70 4e 65 77 2d 3e 78  Sleep;.  pNew->x
65f0: 43 75 72 72 65 6e 74 54 69 6d 65 20 3d 20 76 66  CurrentTime = vf
6600: 73 74 72 61 63 65 43 75 72 72 65 6e 74 54 69 6d  straceCurrentTim
6610: 65 3b 0a 20 20 70 4e 65 77 2d 3e 78 47 65 74 4c  e;.  pNew->xGetL
6620: 61 73 74 45 72 72 6f 72 20 3d 20 70 52 6f 6f 74  astError = pRoot
6630: 2d 3e 78 47 65 74 4c 61 73 74 45 72 72 6f 72 3d  ->xGetLastError=
6640: 3d 30 20 3f 20 30 20 3a 20 76 66 73 74 72 61 63  =0 ? 0 : vfstrac
6650: 65 47 65 74 4c 61 73 74 45 72 72 6f 72 3b 0a 20  eGetLastError;. 
6660: 20 69 66 28 20 70 4e 65 77 2d 3e 69 56 65 72 73   if( pNew->iVers
6670: 69 6f 6e 3e 3d 32 20 29 7b 0a 20 20 20 20 70 4e  ion>=2 ){.    pN
6680: 65 77 2d 3e 78 43 75 72 72 65 6e 74 54 69 6d 65  ew->xCurrentTime
6690: 49 6e 74 36 34 20 3d 20 70 52 6f 6f 74 2d 3e 78  Int64 = pRoot->x
66a0: 43 75 72 72 65 6e 74 54 69 6d 65 49 6e 74 36 34  CurrentTimeInt64
66b0: 3d 3d 30 20 3f 20 30 20 3a 0a 20 20 20 20 20 20  ==0 ? 0 :.      
66c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
66d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 76 66 73               vfs
66e0: 74 72 61 63 65 43 75 72 72 65 6e 74 54 69 6d 65  traceCurrentTime
66f0: 49 6e 74 36 34 3b 0a 20 20 20 20 69 66 28 20 70  Int64;.    if( p
6700: 4e 65 77 2d 3e 69 56 65 72 73 69 6f 6e 3e 3d 33  New->iVersion>=3
6710: 20 29 7b 0a 20 20 20 20 20 20 70 4e 65 77 2d 3e   ){.      pNew->
6720: 78 53 65 74 53 79 73 74 65 6d 43 61 6c 6c 20 3d  xSetSystemCall =
6730: 20 70 52 6f 6f 74 2d 3e 78 53 65 74 53 79 73 74   pRoot->xSetSyst
6740: 65 6d 43 61 6c 6c 3d 3d 30 20 3f 20 30 20 3a 20  emCall==0 ? 0 : 
6750: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
6760: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6770: 20 20 20 20 76 66 73 74 72 61 63 65 53 65 74 53      vfstraceSetS
6780: 79 73 74 65 6d 43 61 6c 6c 3b 0a 20 20 20 20 20  ystemCall;.     
6790: 20 70 4e 65 77 2d 3e 78 47 65 74 53 79 73 74 65   pNew->xGetSyste
67a0: 6d 43 61 6c 6c 20 3d 20 70 52 6f 6f 74 2d 3e 78  mCall = pRoot->x
67b0: 47 65 74 53 79 73 74 65 6d 43 61 6c 6c 3d 3d 30  GetSystemCall==0
67c0: 20 3f 20 30 20 3a 20 0a 20 20 20 20 20 20 20 20   ? 0 : .        
67d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
67e0: 20 20 20 20 20 20 20 20 20 20 20 76 66 73 74 72             vfstr
67f0: 61 63 65 47 65 74 53 79 73 74 65 6d 43 61 6c 6c  aceGetSystemCall
6800: 3b 0a 20 20 20 20 20 20 70 4e 65 77 2d 3e 78 4e  ;.      pNew->xN
6810: 65 78 74 53 79 73 74 65 6d 43 61 6c 6c 20 3d 20  extSystemCall = 
6820: 70 52 6f 6f 74 2d 3e 78 4e 65 78 74 53 79 73 74  pRoot->xNextSyst
6830: 65 6d 43 61 6c 6c 3d 3d 30 20 3f 20 30 20 3a 20  emCall==0 ? 0 : 
6840: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
6850: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
6860: 20 20 20 20 76 66 73 74 72 61 63 65 4e 65 78 74      vfstraceNext
6870: 53 79 73 74 65 6d 43 61 6c 6c 3b 0a 20 20 20 20  SystemCall;.    
6880: 7d 0a 20 20 7d 0a 20 20 70 49 6e 66 6f 2d 3e 70  }.  }.  pInfo->p
6890: 52 6f 6f 74 56 66 73 20 3d 20 70 52 6f 6f 74 3b  RootVfs = pRoot;
68a0: 0a 20 20 70 49 6e 66 6f 2d 3e 78 4f 75 74 20 3d  .  pInfo->xOut =
68b0: 20 78 4f 75 74 3b 0a 20 20 70 49 6e 66 6f 2d 3e   xOut;.  pInfo->
68c0: 70 4f 75 74 41 72 67 20 3d 20 70 4f 75 74 41 72  pOutArg = pOutAr
68d0: 67 3b 0a 20 20 70 49 6e 66 6f 2d 3e 7a 56 66 73  g;.  pInfo->zVfs
68e0: 4e 61 6d 65 20 3d 20 70 4e 65 77 2d 3e 7a 4e 61  Name = pNew->zNa
68f0: 6d 65 3b 0a 20 20 70 49 6e 66 6f 2d 3e 70 54 72  me;.  pInfo->pTr
6900: 61 63 65 56 66 73 20 3d 20 70 4e 65 77 3b 0a 20  aceVfs = pNew;. 
6910: 20 76 66 73 74 72 61 63 65 5f 70 72 69 6e 74 66   vfstrace_printf
6920: 28 70 49 6e 66 6f 2c 20 22 25 73 2e 65 6e 61 62  (pInfo, "%s.enab
6930: 6c 65 64 5f 66 6f 72 28 5c 22 25 73 5c 22 29 5c  led_for(\"%s\")\
6940: 6e 22 2c 0a 20 20 20 20 20 20 20 70 49 6e 66 6f  n",.       pInfo
6950: 2d 3e 7a 56 66 73 4e 61 6d 65 2c 20 70 52 6f 6f  ->zVfsName, pRoo
6960: 74 2d 3e 7a 4e 61 6d 65 29 3b 0a 20 20 72 65 74  t->zName);.  ret
6970: 75 72 6e 20 73 71 6c 69 74 65 33 5f 76 66 73 5f  urn sqlite3_vfs_
6980: 72 65 67 69 73 74 65 72 28 70 4e 65 77 2c 20 6d  register(pNew, m
6990: 61 6b 65 44 65 66 61 75 6c 74 29 3b 0a 7d 0a     akeDefault);.}.