/ Hex Artifact Content
Login

Artifact 939ae7690a01d9401685ba124b4ba45fd4a7a2ad:


0000: 2f 2a 0a 2a 2a 20 32 30 30 35 20 4e 6f 76 65 6d  /*.** 2005 Novem
0010: 62 65 72 20 32 39 0a 2a 2a 0a 2a 2a 20 54 68 65  ber 29.**.** The
0020: 20 61 75 74 68 6f 72 20 64 69 73 63 6c 61 69 6d   author disclaim
0030: 73 20 63 6f 70 79 72 69 67 68 74 20 74 6f 20 74  s copyright to t
0040: 68 69 73 20 73 6f 75 72 63 65 20 63 6f 64 65 2e  his source code.
0050: 20 20 49 6e 20 70 6c 61 63 65 20 6f 66 0a 2a 2a    In place of.**
0060: 20 61 20 6c 65 67 61 6c 20 6e 6f 74 69 63 65 2c   a legal notice,
0070: 20 68 65 72 65 20 69 73 20 61 20 62 6c 65 73 73   here is a bless
0080: 69 6e 67 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 4d 61  ing:.**.**    Ma
0090: 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20 61 6e  y you do good an
00a0: 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 2a 2a 20 20  d not evil..**  
00b0: 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20 66    May you find f
00c0: 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20 79  orgiveness for y
00d0: 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72 67  ourself and forg
00e0: 69 76 65 20 6f 74 68 65 72 73 2e 0a 2a 2a 20 20  ive others..**  
00f0: 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65 20    May you share 
0100: 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74 61  freely, never ta
0110: 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20 79  king more than y
0120: 6f 75 20 67 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a  ou 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 2a 2a 2a 0a 2a 2a 0a 2a 2a  **********.**.**
0180: 20 54 68 69 73 20 66 69 6c 65 20 63 6f 6e 74 61   This file conta
0190: 69 6e 73 20 4f 53 20 69 6e 74 65 72 66 61 63 65  ins OS interface
01a0: 20 63 6f 64 65 20 74 68 61 74 20 69 73 20 63 6f   code that is co
01b0: 6d 6d 6f 6e 20 74 6f 20 61 6c 6c 0a 2a 2a 20 61  mmon to all.** a
01c0: 72 63 68 69 74 65 63 74 75 72 65 73 2e 0a 2a 2a  rchitectures..**
01d0: 0a 2a 2a 20 24 49 64 3a 20 6f 73 2e 63 2c 76 20  .** $Id: os.c,v 
01e0: 31 2e 31 32 30 20 32 30 30 38 2f 30 37 2f 32 38  1.120 2008/07/28
01f0: 20 31 39 3a 33 34 3a 35 33 20 64 72 68 20 45 78   19:34:53 drh Ex
0200: 70 20 24 0a 2a 2f 0a 23 64 65 66 69 6e 65 20 5f  p $.*/.#define _
0210: 53 51 4c 49 54 45 5f 4f 53 5f 43 5f 20 31 0a 23  SQLITE_OS_C_ 1.#
0220: 69 6e 63 6c 75 64 65 20 22 73 71 6c 69 74 65 49  include "sqliteI
0230: 6e 74 2e 68 22 0a 23 75 6e 64 65 66 20 5f 53 51  nt.h".#undef _SQ
0240: 4c 49 54 45 5f 4f 53 5f 43 5f 0a 0a 2f 2a 0a 2a  LITE_OS_C_../*.*
0250: 2a 20 54 68 65 20 64 65 66 61 75 6c 74 20 53 51  * The default SQ
0260: 4c 69 74 65 20 73 71 6c 69 74 65 33 5f 76 66 73  Lite sqlite3_vfs
0270: 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 73   implementations
0280: 20 64 6f 20 6e 6f 74 20 61 6c 6c 6f 63 61 74 65   do not allocate
0290: 0a 2a 2a 20 6d 65 6d 6f 72 79 20 28 61 63 74 75  .** memory (actu
02a0: 61 6c 6c 79 2c 20 6f 73 5f 75 6e 69 78 2e 63 20  ally, os_unix.c 
02b0: 61 6c 6c 6f 63 61 74 65 73 20 61 20 73 6d 61 6c  allocates a smal
02c0: 6c 20 61 6d 6f 75 6e 74 20 6f 66 20 6d 65 6d 6f  l amount of memo
02d0: 72 79 0a 2a 2a 20 66 72 6f 6d 20 77 69 74 68 69  ry.** from withi
02e0: 6e 20 4f 73 4f 70 65 6e 28 29 29 2c 20 62 75 74  n OsOpen()), but
02f0: 20 73 6f 6d 65 20 74 68 69 72 64 2d 70 61 72 74   some third-part
0300: 79 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e  y implementation
0310: 73 20 6d 61 79 2e 0a 2a 2a 20 53 6f 20 77 65 20  s may..** So we 
0320: 74 65 73 74 20 74 68 65 20 65 66 66 65 63 74 73  test the effects
0330: 20 6f 66 20 61 20 6d 61 6c 6c 6f 63 28 29 20 66   of a malloc() f
0340: 61 69 6c 69 6e 67 20 61 6e 64 20 74 68 65 20 73  ailing and the s
0350: 71 6c 69 74 65 33 4f 73 58 58 58 28 29 0a 2a 2a  qlite3OsXXX().**
0360: 20 66 75 6e 63 74 69 6f 6e 20 72 65 74 75 72 6e   function return
0370: 69 6e 67 20 53 51 4c 49 54 45 5f 49 4f 45 52 52  ing SQLITE_IOERR
0380: 5f 4e 4f 4d 45 4d 20 75 73 69 6e 67 20 74 68 65  _NOMEM using the
0390: 20 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43 5f 54 45   DO_OS_MALLOC_TE
03a0: 53 54 20 6d 61 63 72 6f 2e 0a 2a 2a 0a 2a 2a 20  ST macro..**.** 
03b0: 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 66 75  The following fu
03c0: 6e 63 74 69 6f 6e 73 20 61 72 65 20 69 6e 73 74  nctions are inst
03d0: 72 75 6d 65 6e 74 65 64 20 66 6f 72 20 6d 61 6c  rumented for mal
03e0: 6c 6f 63 28 29 20 66 61 69 6c 75 72 65 20 0a 2a  loc() failure .*
03f0: 2a 20 74 65 73 74 69 6e 67 3a 0a 2a 2a 0a 2a 2a  * testing:.**.**
0400: 20 20 20 20 20 73 71 6c 69 74 65 33 4f 73 4f 70       sqlite3OsOp
0410: 65 6e 28 29 0a 2a 2a 20 20 20 20 20 73 71 6c 69  en().**     sqli
0420: 74 65 33 4f 73 52 65 61 64 28 29 0a 2a 2a 20 20  te3OsRead().**  
0430: 20 20 20 73 71 6c 69 74 65 33 4f 73 57 72 69 74     sqlite3OsWrit
0440: 65 28 29 0a 2a 2a 20 20 20 20 20 73 71 6c 69 74  e().**     sqlit
0450: 65 33 4f 73 53 79 6e 63 28 29 0a 2a 2a 20 20 20  e3OsSync().**   
0460: 20 20 73 71 6c 69 74 65 33 4f 73 4c 6f 63 6b 28    sqlite3OsLock(
0470: 29 0a 2a 2a 0a 2a 2f 0a 23 69 66 20 64 65 66 69  ).**.*/.#if defi
0480: 6e 65 64 28 53 51 4c 49 54 45 5f 54 45 53 54 29  ned(SQLITE_TEST)
0490: 20 26 26 20 28 53 51 4c 49 54 45 5f 4f 53 5f 57   && (SQLITE_OS_W
04a0: 49 4e 3d 3d 30 29 20 26 26 20 30 0a 20 20 23 64  IN==0) && 0.  #d
04b0: 65 66 69 6e 65 20 44 4f 5f 4f 53 5f 4d 41 4c 4c  efine DO_OS_MALL
04c0: 4f 43 5f 54 45 53 54 20 69 66 20 28 31 29 20 7b  OC_TEST if (1) {
04d0: 20 20 20 20 20 20 20 20 20 20 20 20 5c 0a 20 20              \.  
04e0: 20 20 76 6f 69 64 20 2a 70 54 73 74 41 6c 6c 6f    void *pTstAllo
04f0: 63 20 3d 20 73 71 6c 69 74 65 33 4d 61 6c 6c 6f  c = sqlite3Mallo
0500: 63 28 31 30 29 3b 20 20 20 20 20 20 20 5c 0a 20  c(10);       \. 
0510: 20 20 20 69 66 20 28 21 70 54 73 74 41 6c 6c 6f     if (!pTstAllo
0520: 63 29 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45  c) return SQLITE
0530: 5f 49 4f 45 52 52 5f 4e 4f 4d 45 4d 3b 20 20 5c  _IOERR_NOMEM;  \
0540: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66 72 65  .    sqlite3_fre
0550: 65 28 70 54 73 74 41 6c 6c 6f 63 29 3b 20 20 20  e(pTstAlloc);   
0560: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0570: 20 5c 0a 20 20 7d 0a 23 65 6c 73 65 0a 20 20 23   \.  }.#else.  #
0580: 64 65 66 69 6e 65 20 44 4f 5f 4f 53 5f 4d 41 4c  define DO_OS_MAL
0590: 4c 4f 43 5f 54 45 53 54 0a 23 65 6e 64 69 66 0a  LOC_TEST.#endif.
05a0: 0a 2f 2a 0a 2a 2a 20 54 68 65 20 66 6f 6c 6c 6f  ./*.** The follo
05b0: 77 69 6e 67 20 72 6f 75 74 69 6e 65 73 20 61 72  wing routines ar
05c0: 65 20 63 6f 6e 76 65 6e 69 65 6e 63 65 20 77 72  e convenience wr
05d0: 61 70 70 65 72 73 20 61 72 6f 75 6e 64 20 6d 65  appers around me
05e0: 74 68 6f 64 73 0a 2a 2a 20 6f 66 20 74 68 65 20  thods.** of the 
05f0: 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 6f 62 6a  sqlite3_file obj
0600: 65 63 74 2e 20 20 54 68 69 73 20 69 73 20 6d 6f  ect.  This is mo
0610: 73 74 6c 79 20 6a 75 73 74 20 73 79 6e 74 61 63  stly just syntac
0620: 74 69 63 20 73 75 67 61 72 2e 20 41 6c 6c 0a 2a  tic sugar. All.*
0630: 2a 20 6f 66 20 74 68 69 73 20 77 6f 75 6c 64 20  * of this would 
0640: 62 65 20 63 6f 6d 70 6c 65 74 65 6c 79 20 61 75  be completely au
0650: 74 6f 6d 61 74 69 63 20 69 66 20 53 51 4c 69 74  tomatic if SQLit
0660: 65 20 77 65 72 65 20 63 6f 64 65 64 20 75 73 69  e were coded usi
0670: 6e 67 0a 2a 2a 20 43 2b 2b 20 69 6e 73 74 65 61  ng.** C++ instea
0680: 64 20 6f 66 20 70 6c 61 69 6e 20 6f 6c 64 20 43  d of plain old C
0690: 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33  ..*/.int sqlite3
06a0: 4f 73 43 6c 6f 73 65 28 73 71 6c 69 74 65 33 5f  OsClose(sqlite3_
06b0: 66 69 6c 65 20 2a 70 49 64 29 7b 0a 20 20 69 6e  file *pId){.  in
06c0: 74 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 4f 4b  t rc = SQLITE_OK
06d0: 3b 0a 20 20 69 66 28 20 70 49 64 2d 3e 70 4d 65  ;.  if( pId->pMe
06e0: 74 68 6f 64 73 20 29 7b 0a 20 20 20 20 72 63 20  thods ){.    rc 
06f0: 3d 20 70 49 64 2d 3e 70 4d 65 74 68 6f 64 73 2d  = pId->pMethods-
0700: 3e 78 43 6c 6f 73 65 28 70 49 64 29 3b 0a 20 20  >xClose(pId);.  
0710: 20 20 70 49 64 2d 3e 70 4d 65 74 68 6f 64 73 20    pId->pMethods 
0720: 3d 20 30 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72  = 0;.  }.  retur
0730: 6e 20 72 63 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69  n rc;.}.int sqli
0740: 74 65 33 4f 73 52 65 61 64 28 73 71 6c 69 74 65  te3OsRead(sqlite
0750: 33 5f 66 69 6c 65 20 2a 69 64 2c 20 76 6f 69 64  3_file *id, void
0760: 20 2a 70 42 75 66 2c 20 69 6e 74 20 61 6d 74 2c   *pBuf, int amt,
0770: 20 69 36 34 20 6f 66 66 73 65 74 29 7b 0a 20 20   i64 offset){.  
0780: 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53  DO_OS_MALLOC_TES
0790: 54 3b 0a 20 20 72 65 74 75 72 6e 20 69 64 2d 3e  T;.  return id->
07a0: 70 4d 65 74 68 6f 64 73 2d 3e 78 52 65 61 64 28  pMethods->xRead(
07b0: 69 64 2c 20 70 42 75 66 2c 20 61 6d 74 2c 20 6f  id, pBuf, amt, o
07c0: 66 66 73 65 74 29 3b 0a 7d 0a 69 6e 74 20 73 71  ffset);.}.int sq
07d0: 6c 69 74 65 33 4f 73 57 72 69 74 65 28 73 71 6c  lite3OsWrite(sql
07e0: 69 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20 63  ite3_file *id, c
07f0: 6f 6e 73 74 20 76 6f 69 64 20 2a 70 42 75 66 2c  onst void *pBuf,
0800: 20 69 6e 74 20 61 6d 74 2c 20 69 36 34 20 6f 66   int amt, i64 of
0810: 66 73 65 74 29 7b 0a 20 20 44 4f 5f 4f 53 5f 4d  fset){.  DO_OS_M
0820: 41 4c 4c 4f 43 5f 54 45 53 54 3b 0a 20 20 72 65  ALLOC_TEST;.  re
0830: 74 75 72 6e 20 69 64 2d 3e 70 4d 65 74 68 6f 64  turn id->pMethod
0840: 73 2d 3e 78 57 72 69 74 65 28 69 64 2c 20 70 42  s->xWrite(id, pB
0850: 75 66 2c 20 61 6d 74 2c 20 6f 66 66 73 65 74 29  uf, amt, offset)
0860: 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f  ;.}.int sqlite3O
0870: 73 54 72 75 6e 63 61 74 65 28 73 71 6c 69 74 65  sTruncate(sqlite
0880: 33 5f 66 69 6c 65 20 2a 69 64 2c 20 69 36 34 20  3_file *id, i64 
0890: 73 69 7a 65 29 7b 0a 20 20 72 65 74 75 72 6e 20  size){.  return 
08a0: 69 64 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 54  id->pMethods->xT
08b0: 72 75 6e 63 61 74 65 28 69 64 2c 20 73 69 7a 65  runcate(id, size
08c0: 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33  );.}.int sqlite3
08d0: 4f 73 53 79 6e 63 28 73 71 6c 69 74 65 33 5f 66  OsSync(sqlite3_f
08e0: 69 6c 65 20 2a 69 64 2c 20 69 6e 74 20 66 6c 61  ile *id, int fla
08f0: 67 73 29 7b 0a 20 20 44 4f 5f 4f 53 5f 4d 41 4c  gs){.  DO_OS_MAL
0900: 4c 4f 43 5f 54 45 53 54 3b 0a 20 20 72 65 74 75  LOC_TEST;.  retu
0910: 72 6e 20 69 64 2d 3e 70 4d 65 74 68 6f 64 73 2d  rn id->pMethods-
0920: 3e 78 53 79 6e 63 28 69 64 2c 20 66 6c 61 67 73  >xSync(id, flags
0930: 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33  );.}.int sqlite3
0940: 4f 73 46 69 6c 65 53 69 7a 65 28 73 71 6c 69 74  OsFileSize(sqlit
0950: 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20 69 36 34  e3_file *id, i64
0960: 20 2a 70 53 69 7a 65 29 7b 0a 20 20 44 4f 5f 4f   *pSize){.  DO_O
0970: 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54 3b 0a 20  S_MALLOC_TEST;. 
0980: 20 72 65 74 75 72 6e 20 69 64 2d 3e 70 4d 65 74   return id->pMet
0990: 68 6f 64 73 2d 3e 78 46 69 6c 65 53 69 7a 65 28  hods->xFileSize(
09a0: 69 64 2c 20 70 53 69 7a 65 29 3b 0a 7d 0a 69 6e  id, pSize);.}.in
09b0: 74 20 73 71 6c 69 74 65 33 4f 73 4c 6f 63 6b 28  t sqlite3OsLock(
09c0: 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69 64  sqlite3_file *id
09d0: 2c 20 69 6e 74 20 6c 6f 63 6b 54 79 70 65 29 7b  , int lockType){
09e0: 0a 20 20 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43 5f  .  DO_OS_MALLOC_
09f0: 54 45 53 54 3b 0a 20 20 72 65 74 75 72 6e 20 69  TEST;.  return i
0a00: 64 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 4c 6f  d->pMethods->xLo
0a10: 63 6b 28 69 64 2c 20 6c 6f 63 6b 54 79 70 65 29  ck(id, lockType)
0a20: 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f  ;.}.int sqlite3O
0a30: 73 55 6e 6c 6f 63 6b 28 73 71 6c 69 74 65 33 5f  sUnlock(sqlite3_
0a40: 66 69 6c 65 20 2a 69 64 2c 20 69 6e 74 20 6c 6f  file *id, int lo
0a50: 63 6b 54 79 70 65 29 7b 0a 20 20 72 65 74 75 72  ckType){.  retur
0a60: 6e 20 69 64 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e  n id->pMethods->
0a70: 78 55 6e 6c 6f 63 6b 28 69 64 2c 20 6c 6f 63 6b  xUnlock(id, lock
0a80: 54 79 70 65 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c  Type);.}.int sql
0a90: 69 74 65 33 4f 73 43 68 65 63 6b 52 65 73 65 72  ite3OsCheckReser
0aa0: 76 65 64 4c 6f 63 6b 28 73 71 6c 69 74 65 33 5f  vedLock(sqlite3_
0ab0: 66 69 6c 65 20 2a 69 64 2c 20 69 6e 74 20 2a 70  file *id, int *p
0ac0: 52 65 73 4f 75 74 29 7b 0a 20 20 44 4f 5f 4f 53  ResOut){.  DO_OS
0ad0: 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54 3b 0a 20 20  _MALLOC_TEST;.  
0ae0: 72 65 74 75 72 6e 20 69 64 2d 3e 70 4d 65 74 68  return id->pMeth
0af0: 6f 64 73 2d 3e 78 43 68 65 63 6b 52 65 73 65 72  ods->xCheckReser
0b00: 76 65 64 4c 6f 63 6b 28 69 64 2c 20 70 52 65 73  vedLock(id, pRes
0b10: 4f 75 74 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69  Out);.}.int sqli
0b20: 74 65 33 4f 73 46 69 6c 65 43 6f 6e 74 72 6f 6c  te3OsFileControl
0b30: 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69  (sqlite3_file *i
0b40: 64 2c 20 69 6e 74 20 6f 70 2c 20 76 6f 69 64 20  d, int op, void 
0b50: 2a 70 41 72 67 29 7b 0a 20 20 72 65 74 75 72 6e  *pArg){.  return
0b60: 20 69 64 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78   id->pMethods->x
0b70: 46 69 6c 65 43 6f 6e 74 72 6f 6c 28 69 64 2c 20  FileControl(id, 
0b80: 6f 70 2c 20 70 41 72 67 29 3b 0a 7d 0a 69 6e 74  op, pArg);.}.int
0b90: 20 73 71 6c 69 74 65 33 4f 73 53 65 63 74 6f 72   sqlite3OsSector
0ba0: 53 69 7a 65 28 73 71 6c 69 74 65 33 5f 66 69 6c  Size(sqlite3_fil
0bb0: 65 20 2a 69 64 29 7b 0a 20 20 69 6e 74 20 28 2a  e *id){.  int (*
0bc0: 78 53 65 63 74 6f 72 53 69 7a 65 29 28 73 71 6c  xSectorSize)(sql
0bd0: 69 74 65 33 5f 66 69 6c 65 2a 29 20 3d 20 69 64  ite3_file*) = id
0be0: 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 53 65 63  ->pMethods->xSec
0bf0: 74 6f 72 53 69 7a 65 3b 0a 20 20 72 65 74 75 72  torSize;.  retur
0c00: 6e 20 28 78 53 65 63 74 6f 72 53 69 7a 65 20 3f  n (xSectorSize ?
0c10: 20 78 53 65 63 74 6f 72 53 69 7a 65 28 69 64 29   xSectorSize(id)
0c20: 20 3a 20 53 51 4c 49 54 45 5f 44 45 46 41 55 4c   : SQLITE_DEFAUL
0c30: 54 5f 53 45 43 54 4f 52 5f 53 49 5a 45 29 3b 0a  T_SECTOR_SIZE);.
0c40: 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f 73 44  }.int sqlite3OsD
0c50: 65 76 69 63 65 43 68 61 72 61 63 74 65 72 69 73  eviceCharacteris
0c60: 74 69 63 73 28 73 71 6c 69 74 65 33 5f 66 69 6c  tics(sqlite3_fil
0c70: 65 20 2a 69 64 29 7b 0a 20 20 72 65 74 75 72 6e  e *id){.  return
0c80: 20 69 64 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78   id->pMethods->x
0c90: 44 65 76 69 63 65 43 68 61 72 61 63 74 65 72 69  DeviceCharacteri
0ca0: 73 74 69 63 73 28 69 64 29 3b 0a 7d 0a 0a 2f 2a  stics(id);.}../*
0cb0: 0a 2a 2a 20 54 68 65 20 6e 65 78 74 20 67 72 6f  .** The next gro
0cc0: 75 70 20 6f 66 20 72 6f 75 74 69 6e 65 73 20 61  up of routines a
0cd0: 72 65 20 63 6f 6e 76 65 6e 69 65 6e 63 65 20 77  re convenience w
0ce0: 72 61 70 70 65 72 73 20 61 72 6f 75 6e 64 20 74  rappers around t
0cf0: 68 65 0a 2a 2a 20 56 46 53 20 6d 65 74 68 6f 64  he.** VFS method
0d00: 73 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65  s..*/.int sqlite
0d10: 33 4f 73 4f 70 65 6e 28 0a 20 20 73 71 6c 69 74  3OsOpen(.  sqlit
0d20: 65 33 5f 76 66 73 20 2a 70 56 66 73 2c 20 0a 20  e3_vfs *pVfs, . 
0d30: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 50 61   const char *zPa
0d40: 74 68 2c 20 0a 20 20 73 71 6c 69 74 65 33 5f 66  th, .  sqlite3_f
0d50: 69 6c 65 20 2a 70 46 69 6c 65 2c 20 0a 20 20 69  ile *pFile, .  i
0d60: 6e 74 20 66 6c 61 67 73 2c 20 0a 20 20 69 6e 74  nt flags, .  int
0d70: 20 2a 70 46 6c 61 67 73 4f 75 74 0a 29 7b 0a 20   *pFlagsOut.){. 
0d80: 20 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43 5f 54 45   DO_OS_MALLOC_TE
0d90: 53 54 3b 0a 20 20 72 65 74 75 72 6e 20 70 56 66  ST;.  return pVf
0da0: 73 2d 3e 78 4f 70 65 6e 28 70 56 66 73 2c 20 7a  s->xOpen(pVfs, z
0db0: 50 61 74 68 2c 20 70 46 69 6c 65 2c 20 66 6c 61  Path, pFile, fla
0dc0: 67 73 2c 20 70 46 6c 61 67 73 4f 75 74 29 3b 0a  gs, pFlagsOut);.
0dd0: 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f 73 44  }.int sqlite3OsD
0de0: 65 6c 65 74 65 28 73 71 6c 69 74 65 33 5f 76 66  elete(sqlite3_vf
0df0: 73 20 2a 70 56 66 73 2c 20 63 6f 6e 73 74 20 63  s *pVfs, const c
0e00: 68 61 72 20 2a 7a 50 61 74 68 2c 20 69 6e 74 20  har *zPath, int 
0e10: 64 69 72 53 79 6e 63 29 7b 0a 20 20 72 65 74 75  dirSync){.  retu
0e20: 72 6e 20 70 56 66 73 2d 3e 78 44 65 6c 65 74 65  rn pVfs->xDelete
0e30: 28 70 56 66 73 2c 20 7a 50 61 74 68 2c 20 64 69  (pVfs, zPath, di
0e40: 72 53 79 6e 63 29 3b 0a 7d 0a 69 6e 74 20 73 71  rSync);.}.int sq
0e50: 6c 69 74 65 33 4f 73 41 63 63 65 73 73 28 0a 20  lite3OsAccess(. 
0e60: 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56   sqlite3_vfs *pV
0e70: 66 73 2c 20 0a 20 20 63 6f 6e 73 74 20 63 68 61  fs, .  const cha
0e80: 72 20 2a 7a 50 61 74 68 2c 20 0a 20 20 69 6e 74  r *zPath, .  int
0e90: 20 66 6c 61 67 73 2c 20 0a 20 20 69 6e 74 20 2a   flags, .  int *
0ea0: 70 52 65 73 4f 75 74 0a 29 7b 0a 20 20 44 4f 5f  pResOut.){.  DO_
0eb0: 4f 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54 3b 0a  OS_MALLOC_TEST;.
0ec0: 20 20 72 65 74 75 72 6e 20 70 56 66 73 2d 3e 78    return pVfs->x
0ed0: 41 63 63 65 73 73 28 70 56 66 73 2c 20 7a 50 61  Access(pVfs, zPa
0ee0: 74 68 2c 20 66 6c 61 67 73 2c 20 70 52 65 73 4f  th, flags, pResO
0ef0: 75 74 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74  ut);.}.int sqlit
0f00: 65 33 4f 73 46 75 6c 6c 50 61 74 68 6e 61 6d 65  e3OsFullPathname
0f10: 28 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73 20  (.  sqlite3_vfs 
0f20: 2a 70 56 66 73 2c 20 0a 20 20 63 6f 6e 73 74 20  *pVfs, .  const 
0f30: 63 68 61 72 20 2a 7a 50 61 74 68 2c 20 0a 20 20  char *zPath, .  
0f40: 69 6e 74 20 6e 50 61 74 68 4f 75 74 2c 20 0a 20  int nPathOut, . 
0f50: 20 63 68 61 72 20 2a 7a 50 61 74 68 4f 75 74 0a   char *zPathOut.
0f60: 29 7b 0a 20 20 72 65 74 75 72 6e 20 70 56 66 73  ){.  return pVfs
0f70: 2d 3e 78 46 75 6c 6c 50 61 74 68 6e 61 6d 65 28  ->xFullPathname(
0f80: 70 56 66 73 2c 20 7a 50 61 74 68 2c 20 6e 50 61  pVfs, zPath, nPa
0f90: 74 68 4f 75 74 2c 20 7a 50 61 74 68 4f 75 74 29  thOut, zPathOut)
0fa0: 3b 0a 7d 0a 23 69 66 6e 64 65 66 20 53 51 4c 49  ;.}.#ifndef SQLI
0fb0: 54 45 5f 4f 4d 49 54 5f 4c 4f 41 44 5f 45 58 54  TE_OMIT_LOAD_EXT
0fc0: 45 4e 53 49 4f 4e 0a 76 6f 69 64 20 2a 73 71 6c  ENSION.void *sql
0fd0: 69 74 65 33 4f 73 44 6c 4f 70 65 6e 28 73 71 6c  ite3OsDlOpen(sql
0fe0: 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c 20  ite3_vfs *pVfs, 
0ff0: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 50 61 74  const char *zPat
1000: 68 29 7b 0a 20 20 72 65 74 75 72 6e 20 70 56 66  h){.  return pVf
1010: 73 2d 3e 78 44 6c 4f 70 65 6e 28 70 56 66 73 2c  s->xDlOpen(pVfs,
1020: 20 7a 50 61 74 68 29 3b 0a 7d 0a 76 6f 69 64 20   zPath);.}.void 
1030: 73 71 6c 69 74 65 33 4f 73 44 6c 45 72 72 6f 72  sqlite3OsDlError
1040: 28 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56  (sqlite3_vfs *pV
1050: 66 73 2c 20 69 6e 74 20 6e 42 79 74 65 2c 20 63  fs, int nByte, c
1060: 68 61 72 20 2a 7a 42 75 66 4f 75 74 29 7b 0a 20  har *zBufOut){. 
1070: 20 70 56 66 73 2d 3e 78 44 6c 45 72 72 6f 72 28   pVfs->xDlError(
1080: 70 56 66 73 2c 20 6e 42 79 74 65 2c 20 7a 42 75  pVfs, nByte, zBu
1090: 66 4f 75 74 29 3b 0a 7d 0a 76 6f 69 64 20 2a 73  fOut);.}.void *s
10a0: 71 6c 69 74 65 33 4f 73 44 6c 53 79 6d 28 73 71  qlite3OsDlSym(sq
10b0: 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c  lite3_vfs *pVfs,
10c0: 20 76 6f 69 64 20 2a 70 48 61 6e 64 6c 65 2c 20   void *pHandle, 
10d0: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 53 79 6d  const char *zSym
10e0: 62 6f 6c 29 7b 0a 20 20 72 65 74 75 72 6e 20 70  bol){.  return p
10f0: 56 66 73 2d 3e 78 44 6c 53 79 6d 28 70 56 66 73  Vfs->xDlSym(pVfs
1100: 2c 20 70 48 61 6e 64 6c 65 2c 20 7a 53 79 6d 62  , pHandle, zSymb
1110: 6f 6c 29 3b 0a 7d 0a 76 6f 69 64 20 73 71 6c 69  ol);.}.void sqli
1120: 74 65 33 4f 73 44 6c 43 6c 6f 73 65 28 73 71 6c  te3OsDlClose(sql
1130: 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c 20  ite3_vfs *pVfs, 
1140: 76 6f 69 64 20 2a 70 48 61 6e 64 6c 65 29 7b 0a  void *pHandle){.
1150: 20 20 70 56 66 73 2d 3e 78 44 6c 43 6c 6f 73 65    pVfs->xDlClose
1160: 28 70 56 66 73 2c 20 70 48 61 6e 64 6c 65 29 3b  (pVfs, pHandle);
1170: 0a 7d 0a 23 65 6e 64 69 66 20 2f 2a 20 53 51 4c  .}.#endif /* SQL
1180: 49 54 45 5f 4f 4d 49 54 5f 4c 4f 41 44 5f 45 58  ITE_OMIT_LOAD_EX
1190: 54 45 4e 53 49 4f 4e 20 2a 2f 0a 69 6e 74 20 73  TENSION */.int s
11a0: 71 6c 69 74 65 33 4f 73 52 61 6e 64 6f 6d 6e 65  qlite3OsRandomne
11b0: 73 73 28 73 71 6c 69 74 65 33 5f 76 66 73 20 2a  ss(sqlite3_vfs *
11c0: 70 56 66 73 2c 20 69 6e 74 20 6e 42 79 74 65 2c  pVfs, int nByte,
11d0: 20 63 68 61 72 20 2a 7a 42 75 66 4f 75 74 29 7b   char *zBufOut){
11e0: 0a 20 20 72 65 74 75 72 6e 20 70 56 66 73 2d 3e  .  return pVfs->
11f0: 78 52 61 6e 64 6f 6d 6e 65 73 73 28 70 56 66 73  xRandomness(pVfs
1200: 2c 20 6e 42 79 74 65 2c 20 7a 42 75 66 4f 75 74  , nByte, zBufOut
1210: 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33  );.}.int sqlite3
1220: 4f 73 53 6c 65 65 70 28 73 71 6c 69 74 65 33 5f  OsSleep(sqlite3_
1230: 76 66 73 20 2a 70 56 66 73 2c 20 69 6e 74 20 6e  vfs *pVfs, int n
1240: 4d 69 63 72 6f 29 7b 0a 20 20 72 65 74 75 72 6e  Micro){.  return
1250: 20 70 56 66 73 2d 3e 78 53 6c 65 65 70 28 70 56   pVfs->xSleep(pV
1260: 66 73 2c 20 6e 4d 69 63 72 6f 29 3b 0a 7d 0a 69  fs, nMicro);.}.i
1270: 6e 74 20 73 71 6c 69 74 65 33 4f 73 43 75 72 72  nt sqlite3OsCurr
1280: 65 6e 74 54 69 6d 65 28 73 71 6c 69 74 65 33 5f  entTime(sqlite3_
1290: 76 66 73 20 2a 70 56 66 73 2c 20 64 6f 75 62 6c  vfs *pVfs, doubl
12a0: 65 20 2a 70 54 69 6d 65 4f 75 74 29 7b 0a 20 20  e *pTimeOut){.  
12b0: 72 65 74 75 72 6e 20 70 56 66 73 2d 3e 78 43 75  return pVfs->xCu
12c0: 72 72 65 6e 74 54 69 6d 65 28 70 56 66 73 2c 20  rrentTime(pVfs, 
12d0: 70 54 69 6d 65 4f 75 74 29 3b 0a 7d 0a 0a 69 6e  pTimeOut);.}..in
12e0: 74 20 73 71 6c 69 74 65 33 4f 73 4f 70 65 6e 4d  t sqlite3OsOpenM
12f0: 61 6c 6c 6f 63 28 0a 20 20 73 71 6c 69 74 65 33  alloc(.  sqlite3
1300: 5f 76 66 73 20 2a 70 56 66 73 2c 20 0a 20 20 63  _vfs *pVfs, .  c
1310: 6f 6e 73 74 20 63 68 61 72 20 2a 7a 46 69 6c 65  onst char *zFile
1320: 2c 20 0a 20 20 73 71 6c 69 74 65 33 5f 66 69 6c  , .  sqlite3_fil
1330: 65 20 2a 2a 70 70 46 69 6c 65 2c 20 0a 20 20 69  e **ppFile, .  i
1340: 6e 74 20 66 6c 61 67 73 2c 0a 20 20 69 6e 74 20  nt flags,.  int 
1350: 2a 70 4f 75 74 46 6c 61 67 73 0a 29 7b 0a 20 20  *pOutFlags.){.  
1360: 69 6e 74 20 72 63 20 3d 20 53 51 4c 49 54 45 5f  int rc = SQLITE_
1370: 4e 4f 4d 45 4d 3b 0a 20 20 73 71 6c 69 74 65 33  NOMEM;.  sqlite3
1380: 5f 66 69 6c 65 20 2a 70 46 69 6c 65 3b 0a 20 20  _file *pFile;.  
1390: 70 46 69 6c 65 20 3d 20 28 73 71 6c 69 74 65 33  pFile = (sqlite3
13a0: 5f 66 69 6c 65 20 2a 29 73 71 6c 69 74 65 33 4d  _file *)sqlite3M
13b0: 61 6c 6c 6f 63 28 70 56 66 73 2d 3e 73 7a 4f 73  alloc(pVfs->szOs
13c0: 46 69 6c 65 29 3b 0a 20 20 69 66 28 20 70 46 69  File);.  if( pFi
13d0: 6c 65 20 29 7b 0a 20 20 20 20 72 63 20 3d 20 73  le ){.    rc = s
13e0: 71 6c 69 74 65 33 4f 73 4f 70 65 6e 28 70 56 66  qlite3OsOpen(pVf
13f0: 73 2c 20 7a 46 69 6c 65 2c 20 70 46 69 6c 65 2c  s, zFile, pFile,
1400: 20 66 6c 61 67 73 2c 20 70 4f 75 74 46 6c 61 67   flags, pOutFlag
1410: 73 29 3b 0a 20 20 20 20 69 66 28 20 72 63 21 3d  s);.    if( rc!=
1420: 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20  SQLITE_OK ){.   
1430: 20 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28     sqlite3_free(
1440: 70 46 69 6c 65 29 3b 0a 20 20 20 20 7d 65 6c 73  pFile);.    }els
1450: 65 7b 0a 20 20 20 20 20 20 2a 70 70 46 69 6c 65  e{.      *ppFile
1460: 20 3d 20 70 46 69 6c 65 3b 0a 20 20 20 20 7d 0a   = pFile;.    }.
1470: 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 72 63 3b    }.  return rc;
1480: 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f 73  .}.int sqlite3Os
1490: 43 6c 6f 73 65 46 72 65 65 28 73 71 6c 69 74 65  CloseFree(sqlite
14a0: 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 29 7b 0a  3_file *pFile){.
14b0: 20 20 69 6e 74 20 72 63 20 3d 20 53 51 4c 49 54    int rc = SQLIT
14c0: 45 5f 4f 4b 3b 0a 20 20 61 73 73 65 72 74 28 20  E_OK;.  assert( 
14d0: 70 46 69 6c 65 20 29 3b 0a 20 20 72 63 20 3d 20  pFile );.  rc = 
14e0: 73 71 6c 69 74 65 33 4f 73 43 6c 6f 73 65 28 70  sqlite3OsClose(p
14f0: 46 69 6c 65 29 3b 0a 20 20 73 71 6c 69 74 65 33  File);.  sqlite3
1500: 5f 66 72 65 65 28 70 46 69 6c 65 29 3b 0a 20 20  _free(pFile);.  
1510: 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a  return rc;.}../*
1520: 0a 2a 2a 20 54 68 65 20 6c 69 73 74 20 6f 66 20  .** The list of 
1530: 61 6c 6c 20 72 65 67 69 73 74 65 72 65 64 20 56  all registered V
1540: 46 53 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69 6f  FS implementatio
1550: 6e 73 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 73 71  ns..*/.static sq
1560: 6c 69 74 65 33 5f 76 66 73 20 2a 76 66 73 4c 69  lite3_vfs *vfsLi
1570: 73 74 20 3d 20 30 3b 0a 0a 2f 2a 0a 2a 2a 20 4c  st = 0;../*.** L
1580: 6f 63 61 74 65 20 61 20 56 46 53 20 62 79 20 6e  ocate a VFS by n
1590: 61 6d 65 2e 20 20 49 66 20 6e 6f 20 6e 61 6d 65  ame.  If no name
15a0: 20 69 73 20 67 69 76 65 6e 2c 20 73 69 6d 70 6c   is given, simpl
15b0: 79 20 72 65 74 75 72 6e 20 74 68 65 0a 2a 2a 20  y return the.** 
15c0: 66 69 72 73 74 20 56 46 53 20 6f 6e 20 74 68 65  first VFS on the
15d0: 20 6c 69 73 74 2e 0a 2a 2f 0a 73 71 6c 69 74 65   list..*/.sqlite
15e0: 33 5f 76 66 73 20 2a 73 71 6c 69 74 65 33 5f 76  3_vfs *sqlite3_v
15f0: 66 73 5f 66 69 6e 64 28 63 6f 6e 73 74 20 63 68  fs_find(const ch
1600: 61 72 20 2a 7a 56 66 73 29 7b 0a 20 20 73 71 6c  ar *zVfs){.  sql
1610: 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73 20 3d  ite3_vfs *pVfs =
1620: 20 30 3b 0a 23 69 66 6e 64 65 66 20 53 51 4c 49   0;.#ifndef SQLI
1630: 54 45 5f 4d 55 54 45 58 5f 4e 4f 4f 50 0a 20 20  TE_MUTEX_NOOP.  
1640: 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 20 2a 6d  sqlite3_mutex *m
1650: 75 74 65 78 3b 0a 23 65 6e 64 69 66 0a 23 69 66  utex;.#endif.#if
1660: 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54  ndef SQLITE_OMIT
1670: 5f 41 55 54 4f 49 4e 49 54 0a 20 20 69 6e 74 20  _AUTOINIT.  int 
1680: 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 69 6e 69  rc = sqlite3_ini
1690: 74 69 61 6c 69 7a 65 28 29 3b 0a 20 20 69 66 28  tialize();.  if(
16a0: 20 72 63 20 29 20 72 65 74 75 72 6e 20 30 3b 0a   rc ) return 0;.
16b0: 23 65 6e 64 69 66 0a 23 69 66 6e 64 65 66 20 53  #endif.#ifndef S
16c0: 51 4c 49 54 45 5f 4d 55 54 45 58 5f 4e 4f 4f 50  QLITE_MUTEX_NOOP
16d0: 0a 20 20 6d 75 74 65 78 20 3d 20 73 71 6c 69 74  .  mutex = sqlit
16e0: 65 33 4d 75 74 65 78 41 6c 6c 6f 63 28 53 51 4c  e3MutexAlloc(SQL
16f0: 49 54 45 5f 4d 55 54 45 58 5f 53 54 41 54 49 43  ITE_MUTEX_STATIC
1700: 5f 4d 41 53 54 45 52 29 3b 0a 23 65 6e 64 69 66  _MASTER);.#endif
1710: 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78  .  sqlite3_mutex
1720: 5f 65 6e 74 65 72 28 6d 75 74 65 78 29 3b 0a 20  _enter(mutex);. 
1730: 20 66 6f 72 28 70 56 66 73 20 3d 20 76 66 73 4c   for(pVfs = vfsL
1740: 69 73 74 3b 20 70 56 66 73 3b 20 70 56 66 73 3d  ist; pVfs; pVfs=
1750: 70 56 66 73 2d 3e 70 4e 65 78 74 29 7b 0a 20 20  pVfs->pNext){.  
1760: 20 20 69 66 28 20 7a 56 66 73 3d 3d 30 20 29 20    if( zVfs==0 ) 
1770: 62 72 65 61 6b 3b 0a 20 20 20 20 69 66 28 20 73  break;.    if( s
1780: 74 72 63 6d 70 28 7a 56 66 73 2c 20 70 56 66 73  trcmp(zVfs, pVfs
1790: 2d 3e 7a 4e 61 6d 65 29 3d 3d 30 20 29 20 62 72  ->zName)==0 ) br
17a0: 65 61 6b 3b 0a 20 20 7d 0a 20 20 73 71 6c 69 74  eak;.  }.  sqlit
17b0: 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 6d  e3_mutex_leave(m
17c0: 75 74 65 78 29 3b 0a 20 20 72 65 74 75 72 6e 20  utex);.  return 
17d0: 70 56 66 73 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 55  pVfs;.}../*.** U
17e0: 6e 6c 69 6e 6b 20 61 20 56 46 53 20 66 72 6f 6d  nlink a VFS from
17f0: 20 74 68 65 20 6c 69 6e 6b 65 64 20 6c 69 73 74   the linked list
1800: 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20  .*/.static void 
1810: 76 66 73 55 6e 6c 69 6e 6b 28 73 71 6c 69 74 65  vfsUnlink(sqlite
1820: 33 5f 76 66 73 20 2a 70 56 66 73 29 7b 0a 20 20  3_vfs *pVfs){.  
1830: 61 73 73 65 72 74 28 20 73 71 6c 69 74 65 33 5f  assert( sqlite3_
1840: 6d 75 74 65 78 5f 68 65 6c 64 28 73 71 6c 69 74  mutex_held(sqlit
1850: 65 33 4d 75 74 65 78 41 6c 6c 6f 63 28 53 51 4c  e3MutexAlloc(SQL
1860: 49 54 45 5f 4d 55 54 45 58 5f 53 54 41 54 49 43  ITE_MUTEX_STATIC
1870: 5f 4d 41 53 54 45 52 29 29 20 29 3b 0a 20 20 69  _MASTER)) );.  i
1880: 66 28 20 70 56 66 73 3d 3d 30 20 29 7b 0a 20 20  f( pVfs==0 ){.  
1890: 20 20 2f 2a 20 4e 6f 2d 6f 70 20 2a 2f 0a 20 20    /* No-op */.  
18a0: 7d 65 6c 73 65 20 69 66 28 20 76 66 73 4c 69 73  }else if( vfsLis
18b0: 74 3d 3d 70 56 66 73 20 29 7b 0a 20 20 20 20 76  t==pVfs ){.    v
18c0: 66 73 4c 69 73 74 20 3d 20 70 56 66 73 2d 3e 70  fsList = pVfs->p
18d0: 4e 65 78 74 3b 0a 20 20 7d 65 6c 73 65 20 69 66  Next;.  }else if
18e0: 28 20 76 66 73 4c 69 73 74 20 29 7b 0a 20 20 20  ( vfsList ){.   
18f0: 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 20   sqlite3_vfs *p 
1900: 3d 20 76 66 73 4c 69 73 74 3b 0a 20 20 20 20 77  = vfsList;.    w
1910: 68 69 6c 65 28 20 70 2d 3e 70 4e 65 78 74 20 26  hile( p->pNext &
1920: 26 20 70 2d 3e 70 4e 65 78 74 21 3d 70 56 66 73  & p->pNext!=pVfs
1930: 20 29 7b 0a 20 20 20 20 20 20 70 20 3d 20 70 2d   ){.      p = p-
1940: 3e 70 4e 65 78 74 3b 0a 20 20 20 20 7d 0a 20 20  >pNext;.    }.  
1950: 20 20 69 66 28 20 70 2d 3e 70 4e 65 78 74 3d 3d    if( p->pNext==
1960: 70 56 66 73 20 29 7b 0a 20 20 20 20 20 20 70 2d  pVfs ){.      p-
1970: 3e 70 4e 65 78 74 20 3d 20 70 56 66 73 2d 3e 70  >pNext = pVfs->p
1980: 4e 65 78 74 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a  Next;.    }.  }.
1990: 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 67 69 73 74 65  }../*.** Registe
19a0: 72 20 61 20 56 46 53 20 77 69 74 68 20 74 68 65  r a VFS with the
19b0: 20 73 79 73 74 65 6d 2e 20 20 49 74 20 69 73 20   system.  It is 
19c0: 68 61 72 6d 6c 65 73 73 20 74 6f 20 72 65 67 69  harmless to regi
19d0: 73 74 65 72 20 74 68 65 20 73 61 6d 65 0a 2a 2a  ster the same.**
19e0: 20 56 46 53 20 6d 75 6c 74 69 70 6c 65 20 74 69   VFS multiple ti
19f0: 6d 65 73 2e 20 20 54 68 65 20 6e 65 77 20 56 46  mes.  The new VF
1a00: 53 20 62 65 63 6f 6d 65 73 20 74 68 65 20 64 65  S becomes the de
1a10: 66 61 75 6c 74 20 69 66 20 6d 61 6b 65 44 66 6c  fault if makeDfl
1a20: 74 20 69 73 0a 2a 2a 20 74 72 75 65 2e 0a 2a 2f  t is.** true..*/
1a30: 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f 76 66 73  .int sqlite3_vfs
1a40: 5f 72 65 67 69 73 74 65 72 28 73 71 6c 69 74 65  _register(sqlite
1a50: 33 5f 76 66 73 20 2a 70 56 66 73 2c 20 69 6e 74  3_vfs *pVfs, int
1a60: 20 6d 61 6b 65 44 66 6c 74 29 7b 0a 20 20 73 71   makeDflt){.  sq
1a70: 6c 69 74 65 33 5f 6d 75 74 65 78 20 2a 6d 75 74  lite3_mutex *mut
1a80: 65 78 20 3d 20 30 3b 0a 23 69 66 6e 64 65 66 20  ex = 0;.#ifndef 
1a90: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 41 55 54 4f  SQLITE_OMIT_AUTO
1aa0: 49 4e 49 54 0a 20 20 69 6e 74 20 72 63 20 3d 20  INIT.  int rc = 
1ab0: 73 71 6c 69 74 65 33 5f 69 6e 69 74 69 61 6c 69  sqlite3_initiali
1ac0: 7a 65 28 29 3b 0a 20 20 69 66 28 20 72 63 20 29  ze();.  if( rc )
1ad0: 20 72 65 74 75 72 6e 20 72 63 3b 0a 23 65 6e 64   return rc;.#end
1ae0: 69 66 0a 20 20 6d 75 74 65 78 20 3d 20 73 71 6c  if.  mutex = sql
1af0: 69 74 65 33 4d 75 74 65 78 41 6c 6c 6f 63 28 53  ite3MutexAlloc(S
1b00: 51 4c 49 54 45 5f 4d 55 54 45 58 5f 53 54 41 54  QLITE_MUTEX_STAT
1b10: 49 43 5f 4d 41 53 54 45 52 29 3b 0a 20 20 73 71  IC_MASTER);.  sq
1b20: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65  lite3_mutex_ente
1b30: 72 28 6d 75 74 65 78 29 3b 0a 20 20 76 66 73 55  r(mutex);.  vfsU
1b40: 6e 6c 69 6e 6b 28 70 56 66 73 29 3b 0a 20 20 69  nlink(pVfs);.  i
1b50: 66 28 20 6d 61 6b 65 44 66 6c 74 20 7c 7c 20 76  f( makeDflt || v
1b60: 66 73 4c 69 73 74 3d 3d 30 20 29 7b 0a 20 20 20  fsList==0 ){.   
1b70: 20 70 56 66 73 2d 3e 70 4e 65 78 74 20 3d 20 76   pVfs->pNext = v
1b80: 66 73 4c 69 73 74 3b 0a 20 20 20 20 76 66 73 4c  fsList;.    vfsL
1b90: 69 73 74 20 3d 20 70 56 66 73 3b 0a 20 20 7d 65  ist = pVfs;.  }e
1ba0: 6c 73 65 7b 0a 20 20 20 20 70 56 66 73 2d 3e 70  lse{.    pVfs->p
1bb0: 4e 65 78 74 20 3d 20 76 66 73 4c 69 73 74 2d 3e  Next = vfsList->
1bc0: 70 4e 65 78 74 3b 0a 20 20 20 20 76 66 73 4c 69  pNext;.    vfsLi
1bd0: 73 74 2d 3e 70 4e 65 78 74 20 3d 20 70 56 66 73  st->pNext = pVfs
1be0: 3b 0a 20 20 7d 0a 20 20 61 73 73 65 72 74 28 76  ;.  }.  assert(v
1bf0: 66 73 4c 69 73 74 29 3b 0a 20 20 73 71 6c 69 74  fsList);.  sqlit
1c00: 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 6d  e3_mutex_leave(m
1c10: 75 74 65 78 29 3b 0a 20 20 72 65 74 75 72 6e 20  utex);.  return 
1c20: 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a 0a 2f 2a  SQLITE_OK;.}../*
1c30: 0a 2a 2a 20 55 6e 72 65 67 69 73 74 65 72 20 61  .** Unregister a
1c40: 20 56 46 53 20 73 6f 20 74 68 61 74 20 69 74 20   VFS so that it 
1c50: 69 73 20 6e 6f 20 6c 6f 6e 67 65 72 20 61 63 63  is no longer acc
1c60: 65 73 73 69 62 6c 65 2e 0a 2a 2f 0a 69 6e 74 20  essible..*/.int 
1c70: 73 71 6c 69 74 65 33 5f 76 66 73 5f 75 6e 72 65  sqlite3_vfs_unre
1c80: 67 69 73 74 65 72 28 73 71 6c 69 74 65 33 5f 76  gister(sqlite3_v
1c90: 66 73 20 2a 70 56 66 73 29 7b 0a 23 69 66 6e 64  fs *pVfs){.#ifnd
1ca0: 65 66 20 53 51 4c 49 54 45 5f 4d 55 54 45 58 5f  ef SQLITE_MUTEX_
1cb0: 4e 4f 4f 50 0a 20 20 73 71 6c 69 74 65 33 5f 6d  NOOP.  sqlite3_m
1cc0: 75 74 65 78 20 2a 6d 75 74 65 78 20 3d 20 73 71  utex *mutex = sq
1cd0: 6c 69 74 65 33 4d 75 74 65 78 41 6c 6c 6f 63 28  lite3MutexAlloc(
1ce0: 53 51 4c 49 54 45 5f 4d 55 54 45 58 5f 53 54 41  SQLITE_MUTEX_STA
1cf0: 54 49 43 5f 4d 41 53 54 45 52 29 3b 0a 23 65 6e  TIC_MASTER);.#en
1d00: 64 69 66 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75  dif.  sqlite3_mu
1d10: 74 65 78 5f 65 6e 74 65 72 28 6d 75 74 65 78 29  tex_enter(mutex)
1d20: 3b 0a 20 20 76 66 73 55 6e 6c 69 6e 6b 28 70 56  ;.  vfsUnlink(pV
1d30: 66 73 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 6d  fs);.  sqlite3_m
1d40: 75 74 65 78 5f 6c 65 61 76 65 28 6d 75 74 65 78  utex_leave(mutex
1d50: 29 3b 0a 20 20 72 65 74 75 72 6e 20 53 51 4c 49  );.  return SQLI
1d60: 54 45 5f 4f 4b 3b 0a 7d 0a                       TE_OK;.}.