/ Hex Artifact Content
Login

Artifact cf7e09d4215f35fc8269f0fa99f03fd2c2978658:


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 31 33 20 32 30 30 38 2f 30 36 2f 31 35  1.113 2008/06/15
01f0: 20 30 32 3a 35 31 3a 34 38 20 64 72 68 20 45 78   02:51:48 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 4f 53 5f 57 49 4e 3d 3d 30 29 0a   && (OS_WIN==0).
04a0: 20 20 23 64 65 66 69 6e 65 20 44 4f 5f 4f 53 5f    #define DO_OS_
04b0: 4d 41 4c 4c 4f 43 5f 54 45 53 54 20 69 66 20 28  MALLOC_TEST if (
04c0: 31 29 20 7b 20 20 20 20 20 20 20 20 20 20 20 20  1) {            
04d0: 5c 0a 20 20 20 20 76 6f 69 64 20 2a 70 54 73 74  \.    void *pTst
04e0: 41 6c 6c 6f 63 20 3d 20 73 71 6c 69 74 65 33 4d  Alloc = sqlite3M
04f0: 61 6c 6c 6f 63 28 31 30 29 3b 20 20 20 20 20 20  alloc(10);      
0500: 20 5c 0a 20 20 20 20 69 66 20 28 21 70 54 73 74   \.    if (!pTst
0510: 41 6c 6c 6f 63 29 20 72 65 74 75 72 6e 20 53 51  Alloc) return SQ
0520: 4c 49 54 45 5f 49 4f 45 52 52 5f 4e 4f 4d 45 4d  LITE_IOERR_NOMEM
0530: 3b 20 20 5c 0a 20 20 20 20 73 71 6c 69 74 65 33  ;  \.    sqlite3
0540: 5f 66 72 65 65 28 70 54 73 74 41 6c 6c 6f 63 29  _free(pTstAlloc)
0550: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;               
0560: 20 20 20 20 20 5c 0a 20 20 7d 0a 23 65 6c 73 65       \.  }.#else
0570: 0a 20 20 23 64 65 66 69 6e 65 20 44 4f 5f 4f 53  .  #define DO_OS
0580: 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54 0a 23 65 6e  _MALLOC_TEST.#en
0590: 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 66  dif../*.** The f
05a0: 6f 6c 6c 6f 77 69 6e 67 20 72 6f 75 74 69 6e 65  ollowing routine
05b0: 73 20 61 72 65 20 63 6f 6e 76 65 6e 69 65 6e 63  s are convenienc
05c0: 65 20 77 72 61 70 70 65 72 73 20 61 72 6f 75 6e  e wrappers aroun
05d0: 64 20 6d 65 74 68 6f 64 73 0a 2a 2a 20 6f 66 20  d methods.** of 
05e0: 74 68 65 20 73 71 6c 69 74 65 33 5f 66 69 6c 65  the sqlite3_file
05f0: 20 6f 62 6a 65 63 74 2e 20 20 54 68 69 73 20 69   object.  This i
0600: 73 20 6d 6f 73 74 6c 79 20 6a 75 73 74 20 73 79  s mostly just sy
0610: 6e 74 61 63 74 69 63 20 73 75 67 61 72 2e 20 41  ntactic sugar. A
0620: 6c 6c 0a 2a 2a 20 6f 66 20 74 68 69 73 20 77 6f  ll.** of this wo
0630: 75 6c 64 20 62 65 20 63 6f 6d 70 6c 65 74 65 6c  uld be completel
0640: 79 20 61 75 74 6f 6d 61 74 69 63 20 69 66 20 53  y automatic if S
0650: 51 4c 69 74 65 20 77 65 72 65 20 63 6f 64 65 64  QLite were coded
0660: 20 75 73 69 6e 67 0a 2a 2a 20 43 2b 2b 20 69 6e   using.** C++ in
0670: 73 74 65 61 64 20 6f 66 20 70 6c 61 69 6e 20 6f  stead of plain o
0680: 6c 64 20 43 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c  ld C..*/.int sql
0690: 69 74 65 33 4f 73 43 6c 6f 73 65 28 73 71 6c 69  ite3OsClose(sqli
06a0: 74 65 33 5f 66 69 6c 65 20 2a 70 49 64 29 7b 0a  te3_file *pId){.
06b0: 20 20 69 6e 74 20 72 63 20 3d 20 53 51 4c 49 54    int rc = SQLIT
06c0: 45 5f 4f 4b 3b 0a 20 20 69 66 28 20 70 49 64 2d  E_OK;.  if( pId-
06d0: 3e 70 4d 65 74 68 6f 64 73 20 29 7b 0a 20 20 20  >pMethods ){.   
06e0: 20 72 63 20 3d 20 70 49 64 2d 3e 70 4d 65 74 68   rc = pId->pMeth
06f0: 6f 64 73 2d 3e 78 43 6c 6f 73 65 28 70 49 64 29  ods->xClose(pId)
0700: 3b 0a 20 20 20 20 70 49 64 2d 3e 70 4d 65 74 68  ;.    pId->pMeth
0710: 6f 64 73 20 3d 20 30 3b 0a 20 20 7d 0a 20 20 72  ods = 0;.  }.  r
0720: 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 69 6e 74 20  eturn rc;.}.int 
0730: 73 71 6c 69 74 65 33 4f 73 52 65 61 64 28 73 71  sqlite3OsRead(sq
0740: 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20  lite3_file *id, 
0750: 76 6f 69 64 20 2a 70 42 75 66 2c 20 69 6e 74 20  void *pBuf, int 
0760: 61 6d 74 2c 20 69 36 34 20 6f 66 66 73 65 74 29  amt, i64 offset)
0770: 7b 0a 20 20 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43  {.  DO_OS_MALLOC
0780: 5f 54 45 53 54 3b 0a 20 20 72 65 74 75 72 6e 20  _TEST;.  return 
0790: 69 64 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e 78 52  id->pMethods->xR
07a0: 65 61 64 28 69 64 2c 20 70 42 75 66 2c 20 61 6d  ead(id, pBuf, am
07b0: 74 2c 20 6f 66 66 73 65 74 29 3b 0a 7d 0a 69 6e  t, offset);.}.in
07c0: 74 20 73 71 6c 69 74 65 33 4f 73 57 72 69 74 65  t sqlite3OsWrite
07d0: 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69  (sqlite3_file *i
07e0: 64 2c 20 63 6f 6e 73 74 20 76 6f 69 64 20 2a 70  d, const void *p
07f0: 42 75 66 2c 20 69 6e 74 20 61 6d 74 2c 20 69 36  Buf, int amt, i6
0800: 34 20 6f 66 66 73 65 74 29 7b 0a 20 20 44 4f 5f  4 offset){.  DO_
0810: 4f 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54 3b 0a  OS_MALLOC_TEST;.
0820: 20 20 72 65 74 75 72 6e 20 69 64 2d 3e 70 4d 65    return id->pMe
0830: 74 68 6f 64 73 2d 3e 78 57 72 69 74 65 28 69 64  thods->xWrite(id
0840: 2c 20 70 42 75 66 2c 20 61 6d 74 2c 20 6f 66 66  , pBuf, amt, off
0850: 73 65 74 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69  set);.}.int sqli
0860: 74 65 33 4f 73 54 72 75 6e 63 61 74 65 28 73 71  te3OsTruncate(sq
0870: 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20  lite3_file *id, 
0880: 69 36 34 20 73 69 7a 65 29 7b 0a 20 20 72 65 74  i64 size){.  ret
0890: 75 72 6e 20 69 64 2d 3e 70 4d 65 74 68 6f 64 73  urn id->pMethods
08a0: 2d 3e 78 54 72 75 6e 63 61 74 65 28 69 64 2c 20  ->xTruncate(id, 
08b0: 73 69 7a 65 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c  size);.}.int sql
08c0: 69 74 65 33 4f 73 53 79 6e 63 28 73 71 6c 69 74  ite3OsSync(sqlit
08d0: 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20 69 6e 74  e3_file *id, int
08e0: 20 66 6c 61 67 73 29 7b 0a 20 20 44 4f 5f 4f 53   flags){.  DO_OS
08f0: 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54 3b 0a 20 20  _MALLOC_TEST;.  
0900: 72 65 74 75 72 6e 20 69 64 2d 3e 70 4d 65 74 68  return id->pMeth
0910: 6f 64 73 2d 3e 78 53 79 6e 63 28 69 64 2c 20 66  ods->xSync(id, f
0920: 6c 61 67 73 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c  lags);.}.int sql
0930: 69 74 65 33 4f 73 46 69 6c 65 53 69 7a 65 28 73  ite3OsFileSize(s
0940: 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c  qlite3_file *id,
0950: 20 69 36 34 20 2a 70 53 69 7a 65 29 7b 0a 20 20   i64 *pSize){.  
0960: 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53  DO_OS_MALLOC_TES
0970: 54 3b 0a 20 20 72 65 74 75 72 6e 20 69 64 2d 3e  T;.  return id->
0980: 70 4d 65 74 68 6f 64 73 2d 3e 78 46 69 6c 65 53  pMethods->xFileS
0990: 69 7a 65 28 69 64 2c 20 70 53 69 7a 65 29 3b 0a  ize(id, pSize);.
09a0: 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f 73 4c  }.int sqlite3OsL
09b0: 6f 63 6b 28 73 71 6c 69 74 65 33 5f 66 69 6c 65  ock(sqlite3_file
09c0: 20 2a 69 64 2c 20 69 6e 74 20 6c 6f 63 6b 54 79   *id, int lockTy
09d0: 70 65 29 7b 0a 20 20 44 4f 5f 4f 53 5f 4d 41 4c  pe){.  DO_OS_MAL
09e0: 4c 4f 43 5f 54 45 53 54 3b 0a 20 20 72 65 74 75  LOC_TEST;.  retu
09f0: 72 6e 20 69 64 2d 3e 70 4d 65 74 68 6f 64 73 2d  rn id->pMethods-
0a00: 3e 78 4c 6f 63 6b 28 69 64 2c 20 6c 6f 63 6b 54  >xLock(id, lockT
0a10: 79 70 65 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69  ype);.}.int sqli
0a20: 74 65 33 4f 73 55 6e 6c 6f 63 6b 28 73 71 6c 69  te3OsUnlock(sqli
0a30: 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20 69 6e  te3_file *id, in
0a40: 74 20 6c 6f 63 6b 54 79 70 65 29 7b 0a 20 20 72  t lockType){.  r
0a50: 65 74 75 72 6e 20 69 64 2d 3e 70 4d 65 74 68 6f  eturn id->pMetho
0a60: 64 73 2d 3e 78 55 6e 6c 6f 63 6b 28 69 64 2c 20  ds->xUnlock(id, 
0a70: 6c 6f 63 6b 54 79 70 65 29 3b 0a 7d 0a 69 6e 74  lockType);.}.int
0a80: 20 73 71 6c 69 74 65 33 4f 73 43 68 65 63 6b 52   sqlite3OsCheckR
0a90: 65 73 65 72 76 65 64 4c 6f 63 6b 28 73 71 6c 69  eservedLock(sqli
0aa0: 74 65 33 5f 66 69 6c 65 20 2a 69 64 2c 20 69 6e  te3_file *id, in
0ab0: 74 20 2a 70 52 65 73 4f 75 74 29 7b 0a 20 20 44  t *pResOut){.  D
0ac0: 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43 5f 54 45 53 54  O_OS_MALLOC_TEST
0ad0: 3b 0a 20 20 72 65 74 75 72 6e 20 69 64 2d 3e 70  ;.  return id->p
0ae0: 4d 65 74 68 6f 64 73 2d 3e 78 43 68 65 63 6b 52  Methods->xCheckR
0af0: 65 73 65 72 76 65 64 4c 6f 63 6b 28 69 64 2c 20  eservedLock(id, 
0b00: 70 52 65 73 4f 75 74 29 3b 0a 7d 0a 69 6e 74 20  pResOut);.}.int 
0b10: 73 71 6c 69 74 65 33 4f 73 46 69 6c 65 43 6f 6e  sqlite3OsFileCon
0b20: 74 72 6f 6c 28 73 71 6c 69 74 65 33 5f 66 69 6c  trol(sqlite3_fil
0b30: 65 20 2a 69 64 2c 20 69 6e 74 20 6f 70 2c 20 76  e *id, int op, v
0b40: 6f 69 64 20 2a 70 41 72 67 29 7b 0a 20 20 72 65  oid *pArg){.  re
0b50: 74 75 72 6e 20 69 64 2d 3e 70 4d 65 74 68 6f 64  turn id->pMethod
0b60: 73 2d 3e 78 46 69 6c 65 43 6f 6e 74 72 6f 6c 28  s->xFileControl(
0b70: 69 64 2c 20 6f 70 2c 20 70 41 72 67 29 3b 0a 7d  id, op, pArg);.}
0b80: 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f 73 53 65  .int sqlite3OsSe
0b90: 63 74 6f 72 53 69 7a 65 28 73 71 6c 69 74 65 33  ctorSize(sqlite3
0ba0: 5f 66 69 6c 65 20 2a 69 64 29 7b 0a 20 20 69 6e  _file *id){.  in
0bb0: 74 20 28 2a 78 53 65 63 74 6f 72 53 69 7a 65 29  t (*xSectorSize)
0bc0: 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 2a 29 20  (sqlite3_file*) 
0bd0: 3d 20 69 64 2d 3e 70 4d 65 74 68 6f 64 73 2d 3e  = id->pMethods->
0be0: 78 53 65 63 74 6f 72 53 69 7a 65 3b 0a 20 20 72  xSectorSize;.  r
0bf0: 65 74 75 72 6e 20 28 78 53 65 63 74 6f 72 53 69  eturn (xSectorSi
0c00: 7a 65 20 3f 20 78 53 65 63 74 6f 72 53 69 7a 65  ze ? xSectorSize
0c10: 28 69 64 29 20 3a 20 53 51 4c 49 54 45 5f 44 45  (id) : SQLITE_DE
0c20: 46 41 55 4c 54 5f 53 45 43 54 4f 52 5f 53 49 5a  FAULT_SECTOR_SIZ
0c30: 45 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65  E);.}.int sqlite
0c40: 33 4f 73 44 65 76 69 63 65 43 68 61 72 61 63 74  3OsDeviceCharact
0c50: 65 72 69 73 74 69 63 73 28 73 71 6c 69 74 65 33  eristics(sqlite3
0c60: 5f 66 69 6c 65 20 2a 69 64 29 7b 0a 20 20 72 65  _file *id){.  re
0c70: 74 75 72 6e 20 69 64 2d 3e 70 4d 65 74 68 6f 64  turn id->pMethod
0c80: 73 2d 3e 78 44 65 76 69 63 65 43 68 61 72 61 63  s->xDeviceCharac
0c90: 74 65 72 69 73 74 69 63 73 28 69 64 29 3b 0a 7d  teristics(id);.}
0ca0: 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 6e 65 78 74  ../*.** The next
0cb0: 20 67 72 6f 75 70 20 6f 66 20 72 6f 75 74 69 6e   group of routin
0cc0: 65 73 20 61 72 65 20 63 6f 6e 76 65 6e 69 65 6e  es are convenien
0cd0: 63 65 20 77 72 61 70 70 65 72 73 20 61 72 6f 75  ce wrappers arou
0ce0: 6e 64 20 74 68 65 0a 2a 2a 20 56 46 53 20 6d 65  nd the.** VFS me
0cf0: 74 68 6f 64 73 2e 0a 2a 2f 0a 69 6e 74 20 73 71  thods..*/.int sq
0d00: 6c 69 74 65 33 4f 73 4f 70 65 6e 28 0a 20 20 73  lite3OsOpen(.  s
0d10: 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73  qlite3_vfs *pVfs
0d20: 2c 20 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20  , .  const char 
0d30: 2a 7a 50 61 74 68 2c 20 0a 20 20 73 71 6c 69 74  *zPath, .  sqlit
0d40: 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c 20  e3_file *pFile, 
0d50: 0a 20 20 69 6e 74 20 66 6c 61 67 73 2c 20 0a 20  .  int flags, . 
0d60: 20 69 6e 74 20 2a 70 46 6c 61 67 73 4f 75 74 0a   int *pFlagsOut.
0d70: 29 7b 0a 20 20 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f  ){.  DO_OS_MALLO
0d80: 43 5f 54 45 53 54 3b 0a 20 20 72 65 74 75 72 6e  C_TEST;.  return
0d90: 20 70 56 66 73 2d 3e 78 4f 70 65 6e 28 70 56 66   pVfs->xOpen(pVf
0da0: 73 2c 20 7a 50 61 74 68 2c 20 70 46 69 6c 65 2c  s, zPath, pFile,
0db0: 20 66 6c 61 67 73 2c 20 70 46 6c 61 67 73 4f 75   flags, pFlagsOu
0dc0: 74 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65  t);.}.int sqlite
0dd0: 33 4f 73 44 65 6c 65 74 65 28 73 71 6c 69 74 65  3OsDelete(sqlite
0de0: 33 5f 76 66 73 20 2a 70 56 66 73 2c 20 63 6f 6e  3_vfs *pVfs, con
0df0: 73 74 20 63 68 61 72 20 2a 7a 50 61 74 68 2c 20  st char *zPath, 
0e00: 69 6e 74 20 64 69 72 53 79 6e 63 29 7b 0a 20 20  int dirSync){.  
0e10: 72 65 74 75 72 6e 20 70 56 66 73 2d 3e 78 44 65  return pVfs->xDe
0e20: 6c 65 74 65 28 70 56 66 73 2c 20 7a 50 61 74 68  lete(pVfs, zPath
0e30: 2c 20 64 69 72 53 79 6e 63 29 3b 0a 7d 0a 69 6e  , dirSync);.}.in
0e40: 74 20 73 71 6c 69 74 65 33 4f 73 41 63 63 65 73  t sqlite3OsAcces
0e50: 73 28 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73  s(.  sqlite3_vfs
0e60: 20 2a 70 56 66 73 2c 20 0a 20 20 63 6f 6e 73 74   *pVfs, .  const
0e70: 20 63 68 61 72 20 2a 7a 50 61 74 68 2c 20 0a 20   char *zPath, . 
0e80: 20 69 6e 74 20 66 6c 61 67 73 2c 20 0a 20 20 69   int flags, .  i
0e90: 6e 74 20 2a 70 52 65 73 4f 75 74 0a 29 7b 0a 20  nt *pResOut.){. 
0ea0: 20 44 4f 5f 4f 53 5f 4d 41 4c 4c 4f 43 5f 54 45   DO_OS_MALLOC_TE
0eb0: 53 54 3b 0a 20 20 72 65 74 75 72 6e 20 70 56 66  ST;.  return pVf
0ec0: 73 2d 3e 78 41 63 63 65 73 73 28 70 56 66 73 2c  s->xAccess(pVfs,
0ed0: 20 7a 50 61 74 68 2c 20 66 6c 61 67 73 2c 20 70   zPath, flags, p
0ee0: 52 65 73 4f 75 74 29 3b 0a 7d 0a 69 6e 74 20 73  ResOut);.}.int s
0ef0: 71 6c 69 74 65 33 4f 73 46 75 6c 6c 50 61 74 68  qlite3OsFullPath
0f00: 6e 61 6d 65 28 0a 20 20 73 71 6c 69 74 65 33 5f  name(.  sqlite3_
0f10: 76 66 73 20 2a 70 56 66 73 2c 20 0a 20 20 63 6f  vfs *pVfs, .  co
0f20: 6e 73 74 20 63 68 61 72 20 2a 7a 50 61 74 68 2c  nst char *zPath,
0f30: 20 0a 20 20 69 6e 74 20 6e 50 61 74 68 4f 75 74   .  int nPathOut
0f40: 2c 20 0a 20 20 63 68 61 72 20 2a 7a 50 61 74 68  , .  char *zPath
0f50: 4f 75 74 0a 29 7b 0a 20 20 72 65 74 75 72 6e 20  Out.){.  return 
0f60: 70 56 66 73 2d 3e 78 46 75 6c 6c 50 61 74 68 6e  pVfs->xFullPathn
0f70: 61 6d 65 28 70 56 66 73 2c 20 7a 50 61 74 68 2c  ame(pVfs, zPath,
0f80: 20 6e 50 61 74 68 4f 75 74 2c 20 7a 50 61 74 68   nPathOut, zPath
0f90: 4f 75 74 29 3b 0a 7d 0a 23 69 66 6e 64 65 66 20  Out);.}.#ifndef 
0fa0: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 4c 4f 41 44  SQLITE_OMIT_LOAD
0fb0: 5f 45 58 54 45 4e 53 49 4f 4e 0a 76 6f 69 64 20  _EXTENSION.void 
0fc0: 2a 73 71 6c 69 74 65 33 4f 73 44 6c 4f 70 65 6e  *sqlite3OsDlOpen
0fd0: 28 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56  (sqlite3_vfs *pV
0fe0: 66 73 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  fs, const char *
0ff0: 7a 50 61 74 68 29 7b 0a 20 20 72 65 74 75 72 6e  zPath){.  return
1000: 20 70 56 66 73 2d 3e 78 44 6c 4f 70 65 6e 28 70   pVfs->xDlOpen(p
1010: 56 66 73 2c 20 7a 50 61 74 68 29 3b 0a 7d 0a 76  Vfs, zPath);.}.v
1020: 6f 69 64 20 73 71 6c 69 74 65 33 4f 73 44 6c 45  oid sqlite3OsDlE
1030: 72 72 6f 72 28 73 71 6c 69 74 65 33 5f 76 66 73  rror(sqlite3_vfs
1040: 20 2a 70 56 66 73 2c 20 69 6e 74 20 6e 42 79 74   *pVfs, int nByt
1050: 65 2c 20 63 68 61 72 20 2a 7a 42 75 66 4f 75 74  e, char *zBufOut
1060: 29 7b 0a 20 20 70 56 66 73 2d 3e 78 44 6c 45 72  ){.  pVfs->xDlEr
1070: 72 6f 72 28 70 56 66 73 2c 20 6e 42 79 74 65 2c  ror(pVfs, nByte,
1080: 20 7a 42 75 66 4f 75 74 29 3b 0a 7d 0a 76 6f 69   zBufOut);.}.voi
1090: 64 20 2a 73 71 6c 69 74 65 33 4f 73 44 6c 53 79  d *sqlite3OsDlSy
10a0: 6d 28 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70  m(sqlite3_vfs *p
10b0: 56 66 73 2c 20 76 6f 69 64 20 2a 70 48 61 6e 64  Vfs, void *pHand
10c0: 6c 65 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  le, const char *
10d0: 7a 53 79 6d 62 6f 6c 29 7b 0a 20 20 72 65 74 75  zSymbol){.  retu
10e0: 72 6e 20 70 56 66 73 2d 3e 78 44 6c 53 79 6d 28  rn pVfs->xDlSym(
10f0: 70 56 66 73 2c 20 70 48 61 6e 64 6c 65 2c 20 7a  pVfs, pHandle, z
1100: 53 79 6d 62 6f 6c 29 3b 0a 7d 0a 76 6f 69 64 20  Symbol);.}.void 
1110: 73 71 6c 69 74 65 33 4f 73 44 6c 43 6c 6f 73 65  sqlite3OsDlClose
1120: 28 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56  (sqlite3_vfs *pV
1130: 66 73 2c 20 76 6f 69 64 20 2a 70 48 61 6e 64 6c  fs, void *pHandl
1140: 65 29 7b 0a 20 20 70 56 66 73 2d 3e 78 44 6c 43  e){.  pVfs->xDlC
1150: 6c 6f 73 65 28 70 56 66 73 2c 20 70 48 61 6e 64  lose(pVfs, pHand
1160: 6c 65 29 3b 0a 7d 0a 23 65 6e 64 69 66 20 2f 2a  le);.}.#endif /*
1170: 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 4c 4f 41   SQLITE_OMIT_LOA
1180: 44 5f 45 58 54 45 4e 53 49 4f 4e 20 2a 2f 0a 69  D_EXTENSION */.i
1190: 6e 74 20 73 71 6c 69 74 65 33 4f 73 52 61 6e 64  nt sqlite3OsRand
11a0: 6f 6d 6e 65 73 73 28 73 71 6c 69 74 65 33 5f 76  omness(sqlite3_v
11b0: 66 73 20 2a 70 56 66 73 2c 20 69 6e 74 20 6e 42  fs *pVfs, int nB
11c0: 79 74 65 2c 20 63 68 61 72 20 2a 7a 42 75 66 4f  yte, char *zBufO
11d0: 75 74 29 7b 0a 20 20 72 65 74 75 72 6e 20 70 56  ut){.  return pV
11e0: 66 73 2d 3e 78 52 61 6e 64 6f 6d 6e 65 73 73 28  fs->xRandomness(
11f0: 70 56 66 73 2c 20 6e 42 79 74 65 2c 20 7a 42 75  pVfs, nByte, zBu
1200: 66 4f 75 74 29 3b 0a 7d 0a 69 6e 74 20 73 71 6c  fOut);.}.int sql
1210: 69 74 65 33 4f 73 53 6c 65 65 70 28 73 71 6c 69  ite3OsSleep(sqli
1220: 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c 20 69  te3_vfs *pVfs, i
1230: 6e 74 20 6e 4d 69 63 72 6f 29 7b 0a 20 20 72 65  nt nMicro){.  re
1240: 74 75 72 6e 20 70 56 66 73 2d 3e 78 53 6c 65 65  turn pVfs->xSlee
1250: 70 28 70 56 66 73 2c 20 6e 4d 69 63 72 6f 29 3b  p(pVfs, nMicro);
1260: 0a 7d 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f 73  .}.int sqlite3Os
1270: 43 75 72 72 65 6e 74 54 69 6d 65 28 73 71 6c 69  CurrentTime(sqli
1280: 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c 20 64  te3_vfs *pVfs, d
1290: 6f 75 62 6c 65 20 2a 70 54 69 6d 65 4f 75 74 29  ouble *pTimeOut)
12a0: 7b 0a 20 20 72 65 74 75 72 6e 20 70 56 66 73 2d  {.  return pVfs-
12b0: 3e 78 43 75 72 72 65 6e 74 54 69 6d 65 28 70 56  >xCurrentTime(pV
12c0: 66 73 2c 20 70 54 69 6d 65 4f 75 74 29 3b 0a 7d  fs, pTimeOut);.}
12d0: 0a 0a 69 6e 74 20 73 71 6c 69 74 65 33 4f 73 4f  ..int sqlite3OsO
12e0: 70 65 6e 4d 61 6c 6c 6f 63 28 0a 20 20 73 71 6c  penMalloc(.  sql
12f0: 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73 2c 20  ite3_vfs *pVfs, 
1300: 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a  .  const char *z
1310: 46 69 6c 65 2c 20 0a 20 20 73 71 6c 69 74 65 33  File, .  sqlite3
1320: 5f 66 69 6c 65 20 2a 2a 70 70 46 69 6c 65 2c 20  _file **ppFile, 
1330: 0a 20 20 69 6e 74 20 66 6c 61 67 73 2c 0a 20 20  .  int flags,.  
1340: 69 6e 74 20 2a 70 4f 75 74 46 6c 61 67 73 0a 29  int *pOutFlags.)
1350: 7b 0a 20 20 69 6e 74 20 72 63 20 3d 20 53 51 4c  {.  int rc = SQL
1360: 49 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 73 71 6c  ITE_NOMEM;.  sql
1370: 69 74 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65  ite3_file *pFile
1380: 3b 0a 20 20 70 46 69 6c 65 20 3d 20 28 73 71 6c  ;.  pFile = (sql
1390: 69 74 65 33 5f 66 69 6c 65 20 2a 29 73 71 6c 69  ite3_file *)sqli
13a0: 74 65 33 4d 61 6c 6c 6f 63 28 70 56 66 73 2d 3e  te3Malloc(pVfs->
13b0: 73 7a 4f 73 46 69 6c 65 29 3b 0a 20 20 69 66 28  szOsFile);.  if(
13c0: 20 70 46 69 6c 65 20 29 7b 0a 20 20 20 20 72 63   pFile ){.    rc
13d0: 20 3d 20 73 71 6c 69 74 65 33 4f 73 4f 70 65 6e   = sqlite3OsOpen
13e0: 28 70 56 66 73 2c 20 7a 46 69 6c 65 2c 20 70 46  (pVfs, zFile, pF
13f0: 69 6c 65 2c 20 66 6c 61 67 73 2c 20 70 4f 75 74  ile, flags, pOut
1400: 46 6c 61 67 73 29 3b 0a 20 20 20 20 69 66 28 20  Flags);.    if( 
1410: 72 63 21 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b  rc!=SQLITE_OK ){
1420: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 66  .      sqlite3_f
1430: 72 65 65 28 70 46 69 6c 65 29 3b 0a 20 20 20 20  ree(pFile);.    
1440: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 2a 70 70  }else{.      *pp
1450: 46 69 6c 65 20 3d 20 70 46 69 6c 65 3b 0a 20 20  File = pFile;.  
1460: 20 20 7d 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e    }.  }.  return
1470: 20 72 63 3b 0a 7d 0a 69 6e 74 20 73 71 6c 69 74   rc;.}.int sqlit
1480: 65 33 4f 73 43 6c 6f 73 65 46 72 65 65 28 73 71  e3OsCloseFree(sq
1490: 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c  lite3_file *pFil
14a0: 65 29 7b 0a 20 20 69 6e 74 20 72 63 20 3d 20 53  e){.  int rc = S
14b0: 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 61 73 73 65  QLITE_OK;.  asse
14c0: 72 74 28 20 70 46 69 6c 65 20 29 3b 0a 20 20 72  rt( pFile );.  r
14d0: 63 20 3d 20 73 71 6c 69 74 65 33 4f 73 43 6c 6f  c = sqlite3OsClo
14e0: 73 65 28 70 46 69 6c 65 29 3b 0a 20 20 73 71 6c  se(pFile);.  sql
14f0: 69 74 65 33 5f 66 72 65 65 28 70 46 69 6c 65 29  ite3_free(pFile)
1500: 3b 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d  ;.  return rc;.}
1510: 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 6c 69 73 74  ../*.** The list
1520: 20 6f 66 20 61 6c 6c 20 72 65 67 69 73 74 65 72   of all register
1530: 65 64 20 56 46 53 20 69 6d 70 6c 65 6d 65 6e 74  ed VFS implement
1540: 61 74 69 6f 6e 73 2e 20 20 54 68 69 73 20 6c 69  ations.  This li
1550: 73 74 20 69 73 0a 2a 2a 20 69 6e 69 74 69 61 6c  st is.** initial
1560: 69 7a 65 64 20 74 6f 20 74 68 65 20 73 69 6e 67  ized to the sing
1570: 6c 65 20 56 46 53 20 72 65 74 75 72 6e 65 64 20  le VFS returned 
1580: 62 79 20 73 71 6c 69 74 65 33 4f 73 44 65 66 61  by sqlite3OsDefa
1590: 75 6c 74 56 66 73 28 29 0a 2a 2a 20 75 70 6f 6e  ultVfs().** upon
15a0: 20 74 68 65 20 66 69 72 73 74 20 63 61 6c 6c 20   the first call 
15b0: 74 6f 20 73 71 6c 69 74 65 33 5f 76 66 73 5f 66  to sqlite3_vfs_f
15c0: 69 6e 64 28 29 2e 0a 2a 2f 0a 73 74 61 74 69 63  ind()..*/.static
15d0: 20 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 76 66   sqlite3_vfs *vf
15e0: 73 4c 69 73 74 20 3d 20 30 3b 0a 0a 2f 2a 0a 2a  sList = 0;../*.*
15f0: 2a 20 4c 6f 63 61 74 65 20 61 20 56 46 53 20 62  * Locate a VFS b
1600: 79 20 6e 61 6d 65 2e 20 20 49 66 20 6e 6f 20 6e  y name.  If no n
1610: 61 6d 65 20 69 73 20 67 69 76 65 6e 2c 20 73 69  ame is given, si
1620: 6d 70 6c 79 20 72 65 74 75 72 6e 20 74 68 65 0a  mply return the.
1630: 2a 2a 20 66 69 72 73 74 20 56 46 53 20 6f 6e 20  ** first VFS on 
1640: 74 68 65 20 6c 69 73 74 2e 0a 2a 2f 0a 73 71 6c  the list..*/.sql
1650: 69 74 65 33 5f 76 66 73 20 2a 73 71 6c 69 74 65  ite3_vfs *sqlite
1660: 33 5f 76 66 73 5f 66 69 6e 64 28 63 6f 6e 73 74  3_vfs_find(const
1670: 20 63 68 61 72 20 2a 7a 56 66 73 29 7b 0a 23 69   char *zVfs){.#i
1680: 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4d 55 54  fndef SQLITE_MUT
1690: 45 58 5f 4e 4f 4f 50 0a 20 20 73 71 6c 69 74 65  EX_NOOP.  sqlite
16a0: 33 5f 6d 75 74 65 78 20 2a 6d 75 74 65 78 3b 0a  3_mutex *mutex;.
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 4f 4d 49 54 5f 41 55 54 4f 49  QLITE_OMIT_AUTOI
16d0: 4e 49 54 0a 20 20 69 6e 74 20 72 63 20 3d 20 73  NIT.  int rc = s
16e0: 71 6c 69 74 65 33 5f 69 6e 69 74 69 61 6c 69 7a  qlite3_initializ
16f0: 65 28 29 3b 0a 20 20 69 66 28 20 72 63 20 29 20  e();.  if( rc ) 
1700: 72 65 74 75 72 6e 20 30 3b 0a 23 65 6e 64 69 66  return 0;.#endif
1710: 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f  .#ifndef SQLITE_
1720: 4d 55 54 45 58 5f 4e 4f 4f 50 0a 20 20 6d 75 74  MUTEX_NOOP.  mut
1730: 65 78 20 3d 20 73 71 6c 69 74 65 33 5f 6d 75 74  ex = sqlite3_mut
1740: 65 78 5f 61 6c 6c 6f 63 28 53 51 4c 49 54 45 5f  ex_alloc(SQLITE_
1750: 4d 55 54 45 58 5f 53 54 41 54 49 43 5f 4d 41 53  MUTEX_STATIC_MAS
1760: 54 45 52 29 3b 0a 23 65 6e 64 69 66 0a 20 20 73  TER);.#endif.  s
1770: 71 6c 69 74 65 33 5f 76 66 73 20 2a 70 56 66 73  qlite3_vfs *pVfs
1780: 20 3d 20 30 3b 0a 20 20 73 74 61 74 69 63 20 69   = 0;.  static i
1790: 6e 74 20 69 73 49 6e 69 74 20 3d 20 30 3b 0a 20  nt isInit = 0;. 
17a0: 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65   sqlite3_mutex_e
17b0: 6e 74 65 72 28 6d 75 74 65 78 29 3b 0a 20 20 69  nter(mutex);.  i
17c0: 66 28 20 21 69 73 49 6e 69 74 20 29 7b 0a 20 20  f( !isInit ){.  
17d0: 20 20 76 66 73 4c 69 73 74 20 3d 20 73 71 6c 69    vfsList = sqli
17e0: 74 65 33 4f 73 44 65 66 61 75 6c 74 56 66 73 28  te3OsDefaultVfs(
17f0: 29 3b 0a 20 20 20 20 69 73 49 6e 69 74 20 3d 20  );.    isInit = 
1800: 31 3b 0a 20 20 7d 0a 20 20 66 6f 72 28 70 56 66  1;.  }.  for(pVf
1810: 73 20 3d 20 76 66 73 4c 69 73 74 3b 20 70 56 66  s = vfsList; pVf
1820: 73 3b 20 70 56 66 73 3d 70 56 66 73 2d 3e 70 4e  s; pVfs=pVfs->pN
1830: 65 78 74 29 7b 0a 20 20 20 20 69 66 28 20 7a 56  ext){.    if( zV
1840: 66 73 3d 3d 30 20 29 20 62 72 65 61 6b 3b 0a 20  fs==0 ) break;. 
1850: 20 20 20 69 66 28 20 73 74 72 63 6d 70 28 7a 56     if( strcmp(zV
1860: 66 73 2c 20 70 56 66 73 2d 3e 7a 4e 61 6d 65 29  fs, pVfs->zName)
1870: 3d 3d 30 20 29 20 62 72 65 61 6b 3b 0a 20 20 7d  ==0 ) break;.  }
1880: 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78  .  sqlite3_mutex
1890: 5f 6c 65 61 76 65 28 6d 75 74 65 78 29 3b 0a 20  _leave(mutex);. 
18a0: 20 72 65 74 75 72 6e 20 70 56 66 73 3b 0a 7d 0a   return pVfs;.}.
18b0: 0a 2f 2a 0a 2a 2a 20 55 6e 6c 69 6e 6b 20 61 20  ./*.** Unlink a 
18c0: 56 46 53 20 66 72 6f 6d 20 74 68 65 20 6c 69 6e  VFS from the lin
18d0: 6b 65 64 20 6c 69 73 74 0a 2a 2f 0a 73 74 61 74  ked list.*/.stat
18e0: 69 63 20 76 6f 69 64 20 76 66 73 55 6e 6c 69 6e  ic void vfsUnlin
18f0: 6b 28 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 70  k(sqlite3_vfs *p
1900: 56 66 73 29 7b 0a 20 20 61 73 73 65 72 74 28 20  Vfs){.  assert( 
1910: 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 68 65  sqlite3_mutex_he
1920: 6c 64 28 73 71 6c 69 74 65 33 5f 6d 75 74 65 78  ld(sqlite3_mutex
1930: 5f 61 6c 6c 6f 63 28 53 51 4c 49 54 45 5f 4d 55  _alloc(SQLITE_MU
1940: 54 45 58 5f 53 54 41 54 49 43 5f 4d 41 53 54 45  TEX_STATIC_MASTE
1950: 52 29 29 20 29 3b 0a 20 20 69 66 28 20 70 56 66  R)) );.  if( pVf
1960: 73 3d 3d 30 20 29 7b 0a 20 20 20 20 2f 2a 20 4e  s==0 ){.    /* N
1970: 6f 2d 6f 70 20 2a 2f 0a 20 20 7d 65 6c 73 65 20  o-op */.  }else 
1980: 69 66 28 20 76 66 73 4c 69 73 74 3d 3d 70 56 66  if( vfsList==pVf
1990: 73 20 29 7b 0a 20 20 20 20 76 66 73 4c 69 73 74  s ){.    vfsList
19a0: 20 3d 20 70 56 66 73 2d 3e 70 4e 65 78 74 3b 0a   = pVfs->pNext;.
19b0: 20 20 7d 65 6c 73 65 20 69 66 28 20 76 66 73 4c    }else if( vfsL
19c0: 69 73 74 20 29 7b 0a 20 20 20 20 73 71 6c 69 74  ist ){.    sqlit
19d0: 65 33 5f 76 66 73 20 2a 70 20 3d 20 76 66 73 4c  e3_vfs *p = vfsL
19e0: 69 73 74 3b 0a 20 20 20 20 77 68 69 6c 65 28 20  ist;.    while( 
19f0: 70 2d 3e 70 4e 65 78 74 20 26 26 20 70 2d 3e 70  p->pNext && p->p
1a00: 4e 65 78 74 21 3d 70 56 66 73 20 29 7b 0a 20 20  Next!=pVfs ){.  
1a10: 20 20 20 20 70 20 3d 20 70 2d 3e 70 4e 65 78 74      p = p->pNext
1a20: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69 66 28 20  ;.    }.    if( 
1a30: 70 2d 3e 70 4e 65 78 74 3d 3d 70 56 66 73 20 29  p->pNext==pVfs )
1a40: 7b 0a 20 20 20 20 20 20 70 2d 3e 70 4e 65 78 74  {.      p->pNext
1a50: 20 3d 20 70 56 66 73 2d 3e 70 4e 65 78 74 3b 0a   = pVfs->pNext;.
1a60: 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a      }.  }.}../*.
1a70: 2a 2a 20 52 65 67 69 73 74 65 72 20 61 20 56 46  ** Register a VF
1a80: 53 20 77 69 74 68 20 74 68 65 20 73 79 73 74 65  S with the syste
1a90: 6d 2e 20 20 49 74 20 69 73 20 68 61 72 6d 6c 65  m.  It is harmle
1aa0: 73 73 20 74 6f 20 72 65 67 69 73 74 65 72 20 74  ss to register t
1ab0: 68 65 20 73 61 6d 65 0a 2a 2a 20 56 46 53 20 6d  he same.** VFS m
1ac0: 75 6c 74 69 70 6c 65 20 74 69 6d 65 73 2e 20 20  ultiple times.  
1ad0: 54 68 65 20 6e 65 77 20 56 46 53 20 62 65 63 6f  The new VFS beco
1ae0: 6d 65 73 20 74 68 65 20 64 65 66 61 75 6c 74 20  mes the default 
1af0: 69 66 20 6d 61 6b 65 44 66 6c 74 20 69 73 0a 2a  if makeDflt is.*
1b00: 2a 20 74 72 75 65 2e 0a 2a 2f 0a 69 6e 74 20 73  * true..*/.int s
1b10: 71 6c 69 74 65 33 5f 76 66 73 5f 72 65 67 69 73  qlite3_vfs_regis
1b20: 74 65 72 28 73 71 6c 69 74 65 33 5f 76 66 73 20  ter(sqlite3_vfs 
1b30: 2a 70 56 66 73 2c 20 69 6e 74 20 6d 61 6b 65 44  *pVfs, int makeD
1b40: 66 6c 74 29 7b 0a 23 69 66 6e 64 65 66 20 53 51  flt){.#ifndef SQ
1b50: 4c 49 54 45 5f 4d 55 54 45 58 5f 4e 4f 4f 50 0a  LITE_MUTEX_NOOP.
1b60: 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 20    sqlite3_mutex 
1b70: 2a 6d 75 74 65 78 3b 0a 23 65 6e 64 69 66 0a 23  *mutex;.#endif.#
1b80: 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d  ifndef SQLITE_OM
1b90: 49 54 5f 41 55 54 4f 49 4e 49 54 0a 20 20 69 6e  IT_AUTOINIT.  in
1ba0: 74 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 69  t rc = sqlite3_i
1bb0: 6e 69 74 69 61 6c 69 7a 65 28 29 3b 0a 20 20 69  nitialize();.  i
1bc0: 66 28 20 72 63 20 29 20 72 65 74 75 72 6e 20 72  f( rc ) return r
1bd0: 63 3b 0a 23 65 6e 64 69 66 0a 23 69 66 6e 64 65  c;.#endif.#ifnde
1be0: 66 20 53 51 4c 49 54 45 5f 4d 55 54 45 58 5f 4e  f SQLITE_MUTEX_N
1bf0: 4f 4f 50 0a 20 20 6d 75 74 65 78 20 3d 20 73 71  OOP.  mutex = sq
1c00: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 61 6c 6c 6f  lite3_mutex_allo
1c10: 63 28 53 51 4c 49 54 45 5f 4d 55 54 45 58 5f 53  c(SQLITE_MUTEX_S
1c20: 54 41 54 49 43 5f 4d 41 53 54 45 52 29 3b 0a 23  TATIC_MASTER);.#
1c30: 65 6e 64 69 66 0a 20 20 73 71 6c 69 74 65 33 5f  endif.  sqlite3_
1c40: 76 66 73 5f 66 69 6e 64 28 30 29 3b 20 20 2f 2a  vfs_find(0);  /*
1c50: 20 4d 61 6b 65 20 73 75 72 65 20 77 65 20 61 72   Make sure we ar
1c60: 65 20 69 6e 69 74 69 61 6c 69 7a 65 64 20 2a 2f  e initialized */
1c70: 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78  .  sqlite3_mutex
1c80: 5f 65 6e 74 65 72 28 6d 75 74 65 78 29 3b 0a 20  _enter(mutex);. 
1c90: 20 76 66 73 55 6e 6c 69 6e 6b 28 70 56 66 73 29   vfsUnlink(pVfs)
1ca0: 3b 0a 20 20 69 66 28 20 6d 61 6b 65 44 66 6c 74  ;.  if( makeDflt
1cb0: 20 7c 7c 20 76 66 73 4c 69 73 74 3d 3d 30 20 29   || vfsList==0 )
1cc0: 7b 0a 20 20 20 20 70 56 66 73 2d 3e 70 4e 65 78  {.    pVfs->pNex
1cd0: 74 20 3d 20 76 66 73 4c 69 73 74 3b 0a 20 20 20  t = vfsList;.   
1ce0: 20 76 66 73 4c 69 73 74 20 3d 20 70 56 66 73 3b   vfsList = pVfs;
1cf0: 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 70 56  .  }else{.    pV
1d00: 66 73 2d 3e 70 4e 65 78 74 20 3d 20 76 66 73 4c  fs->pNext = vfsL
1d10: 69 73 74 2d 3e 70 4e 65 78 74 3b 0a 20 20 20 20  ist->pNext;.    
1d20: 76 66 73 4c 69 73 74 2d 3e 70 4e 65 78 74 20 3d  vfsList->pNext =
1d30: 20 70 56 66 73 3b 0a 20 20 7d 0a 20 20 61 73 73   pVfs;.  }.  ass
1d40: 65 72 74 28 76 66 73 4c 69 73 74 29 3b 0a 20 20  ert(vfsList);.  
1d50: 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65  sqlite3_mutex_le
1d60: 61 76 65 28 6d 75 74 65 78 29 3b 0a 20 20 72 65  ave(mutex);.  re
1d70: 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a  turn SQLITE_OK;.
1d80: 7d 0a 0a 2f 2a 0a 2a 2a 20 55 6e 72 65 67 69 73  }../*.** Unregis
1d90: 74 65 72 20 61 20 56 46 53 20 73 6f 20 74 68 61  ter a VFS so tha
1da0: 74 20 69 74 20 69 73 20 6e 6f 20 6c 6f 6e 67 65  t it is no longe
1db0: 72 20 61 63 63 65 73 73 69 62 6c 65 2e 0a 2a 2f  r accessible..*/
1dc0: 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f 76 66 73  .int sqlite3_vfs
1dd0: 5f 75 6e 72 65 67 69 73 74 65 72 28 73 71 6c 69  _unregister(sqli
1de0: 74 65 33 5f 76 66 73 20 2a 70 56 66 73 29 7b 0a  te3_vfs *pVfs){.
1df0: 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4d  #ifndef SQLITE_M
1e00: 55 54 45 58 5f 4e 4f 4f 50 0a 20 20 73 71 6c 69  UTEX_NOOP.  sqli
1e10: 74 65 33 5f 6d 75 74 65 78 20 2a 6d 75 74 65 78  te3_mutex *mutex
1e20: 20 3d 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78   = sqlite3_mutex
1e30: 5f 61 6c 6c 6f 63 28 53 51 4c 49 54 45 5f 4d 55  _alloc(SQLITE_MU
1e40: 54 45 58 5f 53 54 41 54 49 43 5f 4d 41 53 54 45  TEX_STATIC_MASTE
1e50: 52 29 3b 0a 23 65 6e 64 69 66 0a 20 20 73 71 6c  R);.#endif.  sql
1e60: 69 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72  ite3_mutex_enter
1e70: 28 6d 75 74 65 78 29 3b 0a 20 20 76 66 73 55 6e  (mutex);.  vfsUn
1e80: 6c 69 6e 6b 28 70 56 66 73 29 3b 0a 20 20 73 71  link(pVfs);.  sq
1e90: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76  lite3_mutex_leav
1ea0: 65 28 6d 75 74 65 78 29 3b 0a 20 20 72 65 74 75  e(mutex);.  retu
1eb0: 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d 0a  rn SQLITE_OK;.}.
1ec0: 0a 2f 2a 0a 2a 2a 20 50 72 6f 76 69 64 65 20 61  ./*.** Provide a
1ed0: 20 64 65 66 61 75 6c 74 20 73 71 6c 69 74 65 33   default sqlite3
1ee0: 4f 73 44 65 66 61 75 6c 74 56 66 73 28 29 20 69  OsDefaultVfs() i
1ef0: 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 20 69 6e  mplementation in
1f00: 20 74 68 65 0a 2a 2a 20 63 61 73 65 73 20 77 68   the.** cases wh
1f10: 65 72 65 20 6e 6f 6e 65 20 6f 66 20 74 68 65 20  ere none of the 
1f20: 73 74 61 6e 64 61 72 64 20 62 61 63 6b 65 6e 64  standard backend
1f30: 73 20 61 72 65 20 75 73 65 64 2e 0a 2a 2f 0a 23  s are used..*/.#
1f40: 69 66 20 21 4f 53 5f 55 4e 49 58 20 26 26 20 21  if !OS_UNIX && !
1f50: 4f 53 5f 57 49 4e 20 26 26 20 21 4f 53 5f 4f 53  OS_WIN && !OS_OS
1f60: 32 0a 73 71 6c 69 74 65 33 5f 76 66 73 20 2a 73  2.sqlite3_vfs *s
1f70: 71 6c 69 74 65 33 4f 73 44 65 66 61 75 6c 74 56  qlite3OsDefaultV
1f80: 66 73 28 76 6f 69 64 29 7b 20 72 65 74 75 72 6e  fs(void){ return
1f90: 20 30 3b 20 7d 0a 23 65 6e 64 69 66 0a            0; }.#endif.