/ Hex Artifact Content
Login

Artifact b15945976976c80e9a29c2d331a9c6fb42d3efa5:


0000: 2f 2a 0a 2a 2a 20 32 30 30 34 20 4d 61 79 20 32  /*.** 2004 May 2
0010: 32 0a 2a 2a 0a 2a 2a 20 54 68 65 20 61 75 74 68  2.**.** The auth
0020: 6f 72 20 64 69 73 63 6c 61 69 6d 73 20 63 6f 70  or disclaims cop
0030: 79 72 69 67 68 74 20 74 6f 20 74 68 69 73 20 73  yright to this s
0040: 6f 75 72 63 65 20 63 6f 64 65 2e 20 20 49 6e 20  ource code.  In 
0050: 70 6c 61 63 65 20 6f 66 0a 2a 2a 20 61 20 6c 65  place of.** a le
0060: 67 61 6c 20 6e 6f 74 69 63 65 2c 20 68 65 72 65  gal notice, here
0070: 20 69 73 20 61 20 62 6c 65 73 73 69 6e 67 3a 0a   is a blessing:.
0080: 2a 2a 0a 2a 2a 20 20 20 20 4d 61 79 20 79 6f 75  **.**    May you
0090: 20 64 6f 20 67 6f 6f 64 20 61 6e 64 20 6e 6f 74   do good and not
00a0: 20 65 76 69 6c 2e 0a 2a 2a 20 20 20 20 4d 61 79   evil..**    May
00b0: 20 79 6f 75 20 66 69 6e 64 20 66 6f 72 67 69 76   you find forgiv
00c0: 65 6e 65 73 73 20 66 6f 72 20 79 6f 75 72 73 65  eness for yourse
00d0: 6c 66 20 61 6e 64 20 66 6f 72 67 69 76 65 20 6f  lf and forgive o
00e0: 74 68 65 72 73 2e 0a 2a 2a 20 20 20 20 4d 61 79  thers..**    May
00f0: 20 79 6f 75 20 73 68 61 72 65 20 66 72 65 65 6c   you share freel
0100: 79 2c 20 6e 65 76 65 72 20 74 61 6b 69 6e 67 20  y, never taking 
0110: 6d 6f 72 65 20 74 68 61 6e 20 79 6f 75 20 67 69  more than you gi
0120: 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ve..**.*********
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 0a 2a 2a 0a 2a 2a 20 54 68 69 73  *****.**.** This
0180: 20 66 69 6c 65 20 63 6f 6e 74 61 69 6e 73 20 6d   file contains m
0190: 61 63 72 6f 73 20 61 6e 64 20 61 20 6c 69 74 74  acros and a litt
01a0: 6c 65 20 62 69 74 20 6f 66 20 63 6f 64 65 20 74  le bit of code t
01b0: 68 61 74 20 69 73 20 63 6f 6d 6d 6f 6e 20 74 6f  hat is common to
01c0: 0a 2a 2a 20 61 6c 6c 20 6f 66 20 74 68 65 20 70  .** all of the p
01d0: 6c 61 74 66 6f 72 6d 2d 73 70 65 63 69 66 69 63  latform-specific
01e0: 20 66 69 6c 65 73 20 28 6f 73 5f 2a 2e 63 29 20   files (os_*.c) 
01f0: 61 6e 64 20 69 73 20 23 69 6e 63 6c 75 64 65 64  and is #included
0200: 20 69 6e 74 6f 20 74 68 6f 73 65 0a 2a 2a 20 66   into those.** f
0210: 69 6c 65 73 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 73  iles..**.** This
0220: 20 66 69 6c 65 20 73 68 6f 75 6c 64 20 62 65 20   file should be 
0230: 23 69 6e 63 6c 75 64 65 64 20 62 79 20 74 68 65  #included by the
0240: 20 6f 73 5f 2a 2e 63 20 66 69 6c 65 73 20 6f 6e   os_*.c files on
0250: 6c 79 2e 20 20 49 74 20 69 73 20 6e 6f 74 20 61  ly.  It is not a
0260: 0a 2a 2a 20 67 65 6e 65 72 61 6c 20 70 75 72 70  .** general purp
0270: 6f 73 65 20 68 65 61 64 65 72 20 66 69 6c 65 2e  ose header file.
0280: 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 5f 4f 53 5f  .*/.#ifndef _OS_
0290: 43 4f 4d 4d 4f 4e 5f 48 5f 0a 23 64 65 66 69 6e  COMMON_H_.#defin
02a0: 65 20 5f 4f 53 5f 43 4f 4d 4d 4f 4e 5f 48 5f 0a  e _OS_COMMON_H_.
02b0: 0a 2f 2a 0a 2a 2a 20 41 74 20 6c 65 61 73 74 20  ./*.** At least 
02c0: 74 77 6f 20 62 75 67 73 20 68 61 76 65 20 73 6c  two bugs have sl
02d0: 69 70 70 65 64 20 69 6e 20 62 65 63 61 75 73 65  ipped in because
02e0: 20 77 65 20 63 68 61 6e 67 65 64 20 74 68 65 20   we changed the 
02f0: 4d 45 4d 4f 52 59 5f 44 45 42 55 47 0a 2a 2a 20  MEMORY_DEBUG.** 
0300: 6d 61 63 72 6f 20 74 6f 20 53 51 4c 49 54 45 5f  macro to SQLITE_
0310: 44 45 42 55 47 20 61 6e 64 20 73 6f 6d 65 20 6f  DEBUG and some o
0320: 6c 64 65 72 20 6d 61 6b 65 66 69 6c 65 73 20 68  lder makefiles h
0330: 61 76 65 20 6e 6f 74 20 79 65 74 20 6d 61 64 65  ave not yet made
0340: 20 74 68 65 0a 2a 2a 20 73 77 69 74 63 68 2e 20   the.** switch. 
0350: 20 54 68 65 20 66 6f 6c 6c 6f 77 69 6e 67 20 63   The following c
0360: 6f 64 65 20 73 68 6f 75 6c 64 20 63 61 74 63 68  ode should catch
0370: 20 74 68 69 73 20 70 72 6f 62 6c 65 6d 20 61 74   this problem at
0380: 20 63 6f 6d 70 69 6c 65 2d 74 69 6d 65 2e 0a 2a   compile-time..*
0390: 2f 0a 23 69 66 64 65 66 20 4d 45 4d 4f 52 59 5f  /.#ifdef MEMORY_
03a0: 44 45 42 55 47 0a 23 20 65 72 72 6f 72 20 22 54  DEBUG.# error "T
03b0: 68 65 20 4d 45 4d 4f 52 59 5f 44 45 42 55 47 20  he MEMORY_DEBUG 
03c0: 6d 61 63 72 6f 20 69 73 20 6f 62 73 6f 6c 65 74  macro is obsolet
03d0: 65 2e 20 20 55 73 65 20 53 51 4c 49 54 45 5f 44  e.  Use SQLITE_D
03e0: 45 42 55 47 20 69 6e 73 74 65 61 64 2e 22 0a 23  EBUG instead.".#
03f0: 65 6e 64 69 66 0a 0a 23 69 66 64 65 66 20 53 51  endif..#ifdef SQ
0400: 4c 49 54 45 5f 54 45 53 54 0a 23 20 69 66 6e 64  LITE_TEST.# ifnd
0410: 65 66 20 53 51 4c 49 54 45 5f 44 45 42 55 47 5f  ef SQLITE_DEBUG_
0420: 4f 53 5f 54 52 41 43 45 0a 23 20 20 20 64 65 66  OS_TRACE.#   def
0430: 69 6e 65 20 53 51 4c 49 54 45 5f 44 45 42 55 47  ine SQLITE_DEBUG
0440: 5f 4f 53 5f 54 52 41 43 45 20 30 0a 23 20 65 6e  _OS_TRACE 0.# en
0450: 64 69 66 0a 20 20 69 6e 74 20 73 71 6c 69 74 65  dif.  int sqlite
0460: 33 4f 53 54 72 61 63 65 20 3d 20 53 51 4c 49 54  3OSTrace = SQLIT
0470: 45 5f 44 45 42 55 47 5f 4f 53 5f 54 52 41 43 45  E_DEBUG_OS_TRACE
0480: 3b 0a 23 20 64 65 66 69 6e 65 20 4f 53 54 52 41  ;.# define OSTRA
0490: 43 45 28 58 29 20 20 20 20 20 20 20 20 20 20 69  CE(X)          i
04a0: 66 28 20 73 71 6c 69 74 65 33 4f 53 54 72 61 63  f( sqlite3OSTrac
04b0: 65 20 29 20 73 71 6c 69 74 65 33 44 65 62 75 67  e ) sqlite3Debug
04c0: 50 72 69 6e 74 66 20 58 0a 23 65 6c 73 65 0a 23  Printf X.#else.#
04d0: 20 64 65 66 69 6e 65 20 4f 53 54 52 41 43 45 28   define OSTRACE(
04e0: 58 29 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a  X).#endif../*.**
04f0: 20 4d 61 63 72 6f 73 20 66 6f 72 20 70 65 72 66   Macros for perf
0500: 6f 72 6d 61 6e 63 65 20 74 72 61 63 69 6e 67 2e  ormance tracing.
0510: 20 20 4e 6f 72 6d 61 6c 6c 79 20 74 75 72 6e 65    Normally turne
0520: 64 20 6f 66 66 2e 20 20 4f 6e 6c 79 20 77 6f 72  d off.  Only wor
0530: 6b 73 0a 2a 2a 20 6f 6e 20 69 34 38 36 20 68 61  ks.** on i486 ha
0540: 72 64 77 61 72 65 2e 0a 2a 2f 0a 23 69 66 64 65  rdware..*/.#ifde
0550: 66 20 53 51 4c 49 54 45 5f 50 45 52 46 4f 52 4d  f SQLITE_PERFORM
0560: 41 4e 43 45 5f 54 52 41 43 45 0a 0a 2f 2a 20 0a  ANCE_TRACE../* .
0570: 2a 2a 20 68 77 74 69 6d 65 2e 68 20 63 6f 6e 74  ** hwtime.h cont
0580: 61 69 6e 73 20 69 6e 6c 69 6e 65 20 61 73 73 65  ains inline asse
0590: 6d 62 6c 65 72 20 63 6f 64 65 20 66 6f 72 20 69  mbler code for i
05a0: 6d 70 6c 65 6d 65 6e 74 69 6e 67 20 0a 2a 2a 20  mplementing .** 
05b0: 68 69 67 68 2d 70 65 72 66 6f 72 6d 61 6e 63 65  high-performance
05c0: 20 74 69 6d 69 6e 67 20 72 6f 75 74 69 6e 65 73   timing routines
05d0: 2e 0a 2a 2f 0a 23 69 6e 63 6c 75 64 65 20 22 68  ..*/.#include "h
05e0: 77 74 69 6d 65 2e 68 22 0a 0a 73 74 61 74 69 63  wtime.h"..static
05f0: 20 73 71 6c 69 74 65 5f 75 69 6e 74 36 34 20 67   sqlite_uint64 g
0600: 5f 73 74 61 72 74 3b 0a 73 74 61 74 69 63 20 73  _start;.static s
0610: 71 6c 69 74 65 5f 75 69 6e 74 36 34 20 67 5f 65  qlite_uint64 g_e
0620: 6c 61 70 73 65 64 3b 0a 23 64 65 66 69 6e 65 20  lapsed;.#define 
0630: 54 49 4d 45 52 5f 53 54 41 52 54 20 20 20 20 20  TIMER_START     
0640: 20 20 67 5f 73 74 61 72 74 3d 73 71 6c 69 74 65    g_start=sqlite
0650: 33 48 77 74 69 6d 65 28 29 0a 23 64 65 66 69 6e  3Hwtime().#defin
0660: 65 20 54 49 4d 45 52 5f 45 4e 44 20 20 20 20 20  e TIMER_END     
0670: 20 20 20 20 67 5f 65 6c 61 70 73 65 64 3d 73 71      g_elapsed=sq
0680: 6c 69 74 65 33 48 77 74 69 6d 65 28 29 2d 67 5f  lite3Hwtime()-g_
0690: 73 74 61 72 74 0a 23 64 65 66 69 6e 65 20 54 49  start.#define TI
06a0: 4d 45 52 5f 45 4c 41 50 53 45 44 20 20 20 20 20  MER_ELAPSED     
06b0: 67 5f 65 6c 61 70 73 65 64 0a 23 65 6c 73 65 0a  g_elapsed.#else.
06c0: 23 64 65 66 69 6e 65 20 54 49 4d 45 52 5f 53 54  #define TIMER_ST
06d0: 41 52 54 0a 23 64 65 66 69 6e 65 20 54 49 4d 45  ART.#define TIME
06e0: 52 5f 45 4e 44 0a 23 64 65 66 69 6e 65 20 54 49  R_END.#define TI
06f0: 4d 45 52 5f 45 4c 41 50 53 45 44 20 20 20 20 20  MER_ELAPSED     
0700: 28 28 73 71 6c 69 74 65 5f 75 69 6e 74 36 34 29  ((sqlite_uint64)
0710: 30 29 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a  0).#endif../*.**
0720: 20 49 66 20 77 65 20 63 6f 6d 70 69 6c 65 20 77   If we compile w
0730: 69 74 68 20 74 68 65 20 53 51 4c 49 54 45 5f 54  ith the SQLITE_T
0740: 45 53 54 20 6d 61 63 72 6f 20 73 65 74 2c 20 74  EST macro set, t
0750: 68 65 6e 20 74 68 65 20 66 6f 6c 6c 6f 77 69 6e  hen the followin
0760: 67 20 62 6c 6f 63 6b 0a 2a 2a 20 6f 66 20 63 6f  g block.** of co
0770: 64 65 20 77 69 6c 6c 20 67 69 76 65 20 75 73 20  de will give us 
0780: 74 68 65 20 61 62 69 6c 69 74 79 20 74 6f 20 73  the ability to s
0790: 69 6d 75 6c 61 74 65 20 61 20 64 69 73 6b 20 49  imulate a disk I
07a0: 2f 4f 20 65 72 72 6f 72 2e 20 20 54 68 69 73 0a  /O error.  This.
07b0: 2a 2a 20 69 73 20 75 73 65 64 20 66 6f 72 20 74  ** is used for t
07c0: 65 73 74 69 6e 67 20 74 68 65 20 49 2f 4f 20 72  esting the I/O r
07d0: 65 63 6f 76 65 72 79 20 6c 6f 67 69 63 2e 0a 2a  ecovery logic..*
07e0: 2f 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f  /.#ifdef SQLITE_
07f0: 54 45 53 54 0a 69 6e 74 20 73 71 6c 69 74 65 33  TEST.int sqlite3
0800: 5f 69 6f 5f 65 72 72 6f 72 5f 68 69 74 20 3d 20  _io_error_hit = 
0810: 30 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  0;            /*
0820: 20 54 6f 74 61 6c 20 6e 75 6d 62 65 72 20 6f 66   Total number of
0830: 20 49 2f 4f 20 45 72 72 6f 72 73 20 2a 2f 0a 69   I/O Errors */.i
0840: 6e 74 20 73 71 6c 69 74 65 33 5f 69 6f 5f 65 72  nt sqlite3_io_er
0850: 72 6f 72 5f 68 61 72 64 68 69 74 20 3d 20 30 3b  ror_hardhit = 0;
0860: 20 20 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65          /* Numbe
0870: 72 20 6f 66 20 6e 6f 6e 2d 62 65 6e 69 67 6e 20  r of non-benign 
0880: 65 72 72 6f 72 73 20 2a 2f 0a 69 6e 74 20 73 71  errors */.int sq
0890: 6c 69 74 65 33 5f 69 6f 5f 65 72 72 6f 72 5f 70  lite3_io_error_p
08a0: 65 6e 64 69 6e 67 20 3d 20 30 3b 20 20 20 20 20  ending = 0;     
08b0: 20 20 20 2f 2a 20 43 6f 75 6e 74 20 64 6f 77 6e     /* Count down
08c0: 20 74 6f 20 66 69 72 73 74 20 49 2f 4f 20 65 72   to first I/O er
08d0: 72 6f 72 20 2a 2f 0a 69 6e 74 20 73 71 6c 69 74  ror */.int sqlit
08e0: 65 33 5f 69 6f 5f 65 72 72 6f 72 5f 70 65 72 73  e3_io_error_pers
08f0: 69 73 74 20 3d 20 30 3b 20 20 20 20 20 20 20 20  ist = 0;        
0900: 2f 2a 20 54 72 75 65 20 69 66 20 49 2f 4f 20 65  /* True if I/O e
0910: 72 72 6f 72 73 20 70 65 72 73 69 73 74 20 2a 2f  rrors persist */
0920: 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f 69 6f 5f  .int sqlite3_io_
0930: 65 72 72 6f 72 5f 62 65 6e 69 67 6e 20 3d 20 30  error_benign = 0
0940: 3b 20 20 20 20 20 20 20 20 20 2f 2a 20 54 72 75  ;         /* Tru
0950: 65 20 69 66 20 65 72 72 6f 72 73 20 61 72 65 20  e if errors are 
0960: 62 65 6e 69 67 6e 20 2a 2f 0a 69 6e 74 20 73 71  benign */.int sq
0970: 6c 69 74 65 33 5f 64 69 73 6b 66 75 6c 6c 5f 70  lite3_diskfull_p
0980: 65 6e 64 69 6e 67 20 3d 20 30 3b 0a 69 6e 74 20  ending = 0;.int 
0990: 73 71 6c 69 74 65 33 5f 64 69 73 6b 66 75 6c 6c  sqlite3_diskfull
09a0: 20 3d 20 30 3b 0a 23 64 65 66 69 6e 65 20 53 69   = 0;.#define Si
09b0: 6d 75 6c 61 74 65 49 4f 45 72 72 6f 72 42 65 6e  mulateIOErrorBen
09c0: 69 67 6e 28 58 29 20 73 71 6c 69 74 65 33 5f 69  ign(X) sqlite3_i
09d0: 6f 5f 65 72 72 6f 72 5f 62 65 6e 69 67 6e 3d 28  o_error_benign=(
09e0: 58 29 0a 23 64 65 66 69 6e 65 20 53 69 6d 75 6c  X).#define Simul
09f0: 61 74 65 49 4f 45 72 72 6f 72 28 43 4f 44 45 29  ateIOError(CODE)
0a00: 20 20 5c 0a 20 20 69 66 28 20 28 73 71 6c 69 74    \.  if( (sqlit
0a10: 65 33 5f 69 6f 5f 65 72 72 6f 72 5f 70 65 72 73  e3_io_error_pers
0a20: 69 73 74 20 26 26 20 73 71 6c 69 74 65 33 5f 69  ist && sqlite3_i
0a30: 6f 5f 65 72 72 6f 72 5f 68 69 74 29 20 5c 0a 20  o_error_hit) \. 
0a40: 20 20 20 20 20 20 7c 7c 20 73 71 6c 69 74 65 33        || sqlite3
0a50: 5f 69 6f 5f 65 72 72 6f 72 5f 70 65 6e 64 69 6e  _io_error_pendin
0a60: 67 2d 2d 20 3d 3d 20 31 20 29 20 20 5c 0a 20 20  g-- == 1 )  \.  
0a70: 20 20 20 20 20 20 20 20 20 20 20 20 7b 20 6c 6f              { lo
0a80: 63 61 6c 5f 69 6f 65 72 72 28 29 3b 20 43 4f 44  cal_ioerr(); COD
0a90: 45 3b 20 7d 0a 73 74 61 74 69 63 20 76 6f 69 64  E; }.static void
0aa0: 20 6c 6f 63 61 6c 5f 69 6f 65 72 72 28 29 7b 0a   local_ioerr(){.
0ab0: 20 20 49 4f 54 52 41 43 45 28 28 22 49 4f 45 52    IOTRACE(("IOER
0ac0: 52 5c 6e 22 29 29 3b 0a 20 20 73 71 6c 69 74 65  R\n"));.  sqlite
0ad0: 33 5f 69 6f 5f 65 72 72 6f 72 5f 68 69 74 2b 2b  3_io_error_hit++
0ae0: 3b 0a 20 20 69 66 28 20 21 73 71 6c 69 74 65 33  ;.  if( !sqlite3
0af0: 5f 69 6f 5f 65 72 72 6f 72 5f 62 65 6e 69 67 6e  _io_error_benign
0b00: 20 29 20 73 71 6c 69 74 65 33 5f 69 6f 5f 65 72   ) sqlite3_io_er
0b10: 72 6f 72 5f 68 61 72 64 68 69 74 2b 2b 3b 0a 7d  ror_hardhit++;.}
0b20: 0a 23 64 65 66 69 6e 65 20 53 69 6d 75 6c 61 74  .#define Simulat
0b30: 65 44 69 73 6b 66 75 6c 6c 45 72 72 6f 72 28 43  eDiskfullError(C
0b40: 4f 44 45 29 20 5c 0a 20 20 20 69 66 28 20 73 71  ODE) \.   if( sq
0b50: 6c 69 74 65 33 5f 64 69 73 6b 66 75 6c 6c 5f 70  lite3_diskfull_p
0b60: 65 6e 64 69 6e 67 20 29 7b 20 5c 0a 20 20 20 20  ending ){ \.    
0b70: 20 69 66 28 20 73 71 6c 69 74 65 33 5f 64 69 73   if( sqlite3_dis
0b80: 6b 66 75 6c 6c 5f 70 65 6e 64 69 6e 67 20 3d 3d  kfull_pending ==
0b90: 20 31 20 29 7b 20 5c 0a 20 20 20 20 20 20 20 6c   1 ){ \.       l
0ba0: 6f 63 61 6c 5f 69 6f 65 72 72 28 29 3b 20 5c 0a  ocal_ioerr(); \.
0bb0: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 64         sqlite3_d
0bc0: 69 73 6b 66 75 6c 6c 20 3d 20 31 3b 20 5c 0a 20  iskfull = 1; \. 
0bd0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 69 6f        sqlite3_io
0be0: 5f 65 72 72 6f 72 5f 68 69 74 20 3d 20 31 3b 20  _error_hit = 1; 
0bf0: 5c 0a 20 20 20 20 20 20 20 43 4f 44 45 3b 20 5c  \.       CODE; \
0c00: 0a 20 20 20 20 20 7d 65 6c 73 65 7b 20 5c 0a 20  .     }else{ \. 
0c10: 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 64 69        sqlite3_di
0c20: 73 6b 66 75 6c 6c 5f 70 65 6e 64 69 6e 67 2d 2d  skfull_pending--
0c30: 3b 20 5c 0a 20 20 20 20 20 7d 20 5c 0a 20 20 20  ; \.     } \.   
0c40: 7d 0a 23 65 6c 73 65 0a 23 64 65 66 69 6e 65 20  }.#else.#define 
0c50: 53 69 6d 75 6c 61 74 65 49 4f 45 72 72 6f 72 42  SimulateIOErrorB
0c60: 65 6e 69 67 6e 28 58 29 0a 23 64 65 66 69 6e 65  enign(X).#define
0c70: 20 53 69 6d 75 6c 61 74 65 49 4f 45 72 72 6f 72   SimulateIOError
0c80: 28 41 29 0a 23 64 65 66 69 6e 65 20 53 69 6d 75  (A).#define Simu
0c90: 6c 61 74 65 44 69 73 6b 66 75 6c 6c 45 72 72 6f  lateDiskfullErro
0ca0: 72 28 41 29 0a 23 65 6e 64 69 66 0a 0a 2f 2a 0a  r(A).#endif../*.
0cb0: 2a 2a 20 57 68 65 6e 20 74 65 73 74 69 6e 67 2c  ** When testing,
0cc0: 20 6b 65 65 70 20 61 20 63 6f 75 6e 74 20 6f 66   keep a count of
0cd0: 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 6f   the number of o
0ce0: 70 65 6e 20 66 69 6c 65 73 2e 0a 2a 2f 0a 23 69  pen files..*/.#i
0cf0: 66 64 65 66 20 53 51 4c 49 54 45 5f 54 45 53 54  fdef SQLITE_TEST
0d00: 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f 6f 70 65  .int sqlite3_ope
0d10: 6e 5f 66 69 6c 65 5f 63 6f 75 6e 74 20 3d 20 30  n_file_count = 0
0d20: 3b 0a 23 64 65 66 69 6e 65 20 4f 70 65 6e 43 6f  ;.#define OpenCo
0d30: 75 6e 74 65 72 28 58 29 20 20 73 71 6c 69 74 65  unter(X)  sqlite
0d40: 33 5f 6f 70 65 6e 5f 66 69 6c 65 5f 63 6f 75 6e  3_open_file_coun
0d50: 74 2b 3d 28 58 29 0a 23 65 6c 73 65 0a 23 64 65  t+=(X).#else.#de
0d60: 66 69 6e 65 20 4f 70 65 6e 43 6f 75 6e 74 65 72  fine OpenCounter
0d70: 28 58 29 0a 23 65 6e 64 69 66 0a 0a 23 65 6e 64  (X).#endif..#end
0d80: 69 66 20 2f 2a 20 21 64 65 66 69 6e 65 64 28 5f  if /* !defined(_
0d90: 4f 53 5f 43 4f 4d 4d 4f 4e 5f 48 5f 29 20 2a 2f  OS_COMMON_H_) */
0da0: 0a                                               .