/ Hex Artifact Content
Login
SQLite training in Houston TX on 2019-11-05 (details)
Part of the 2019 Tcl Conference

Artifact 031a87445e5e0afc85312d1c380e123ad6c7aeaf:


0000: 2f 2a 0a 2a 2a 20 32 30 30 31 20 53 65 70 74 65  /*.** 2001 Septe
0010: 6d 62 65 72 20 31 35 0a 2a 2a 0a 2a 2a 20 54 68  mber 15.**.** Th
0020: 65 20 61 75 74 68 6f 72 20 64 69 73 63 6c 61 69  e author disclai
0030: 6d 73 20 63 6f 70 79 72 69 67 68 74 20 74 6f 20  ms copyright to 
0040: 74 68 69 73 20 73 6f 75 72 63 65 20 63 6f 64 65  this source code
0050: 2e 20 20 49 6e 20 70 6c 61 63 65 20 6f 66 0a 2a  .  In place of.*
0060: 2a 20 61 20 6c 65 67 61 6c 20 6e 6f 74 69 63 65  * a legal notice
0070: 2c 20 68 65 72 65 20 69 73 20 61 20 62 6c 65 73  , here is a bles
0080: 73 69 6e 67 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 4d  sing:.**.**    M
0090: 61 79 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20 61  ay you do good a
00a0: 6e 64 20 6e 6f 74 20 65 76 69 6c 2e 0a 2a 2a 20  nd not evil..** 
00b0: 20 20 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20     May you find 
00c0: 66 6f 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20  forgiveness for 
00d0: 79 6f 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72  yourself and for
00e0: 67 69 76 65 20 6f 74 68 65 72 73 2e 0a 2a 2a 20  give others..** 
00f0: 20 20 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65     May you share
0100: 20 66 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74   freely, never t
0110: 61 6b 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20  aking more than 
0120: 79 6f 75 20 67 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a  you 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 0a 2a 2a 20 54 68 69 73 20 68  ******.** This h
0180: 65 61 64 65 72 20 66 69 6c 65 20 64 65 66 69 6e  eader file defin
0190: 65 73 20 74 68 65 20 69 6e 74 65 72 66 61 63 65  es the interface
01a0: 20 74 68 61 74 20 74 68 65 20 73 71 6c 69 74 65   that the sqlite
01b0: 20 70 61 67 65 20 63 61 63 68 65 0a 2a 2a 20 73   page cache.** s
01c0: 75 62 73 79 73 74 65 6d 2e 20 20 54 68 65 20 70  ubsystem.  The p
01d0: 61 67 65 20 63 61 63 68 65 20 73 75 62 73 79 73  age cache subsys
01e0: 74 65 6d 20 72 65 61 64 73 20 61 6e 64 20 77 72  tem reads and wr
01f0: 69 74 65 73 20 61 20 66 69 6c 65 20 61 20 70 61  ites a file a pa
0200: 67 65 0a 2a 2a 20 61 74 20 61 20 74 69 6d 65 20  ge.** at a time 
0210: 61 6e 64 20 70 72 6f 76 69 64 65 73 20 61 20 6a  and provides a j
0220: 6f 75 72 6e 61 6c 20 66 6f 72 20 72 6f 6c 6c 62  ournal for rollb
0230: 61 63 6b 2e 0a 2a 2f 0a 0a 23 69 66 6e 64 65 66  ack..*/..#ifndef
0240: 20 53 51 4c 49 54 45 5f 50 41 47 45 52 5f 48 0a   SQLITE_PAGER_H.
0250: 23 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 50  #define SQLITE_P
0260: 41 47 45 52 5f 48 0a 0a 2f 2a 0a 2a 2a 20 44 65  AGER_H../*.** De
0270: 66 61 75 6c 74 20 6d 61 78 69 6d 75 6d 20 73 69  fault maximum si
0280: 7a 65 20 66 6f 72 20 70 65 72 73 69 73 74 65 6e  ze for persisten
0290: 74 20 6a 6f 75 72 6e 61 6c 20 66 69 6c 65 73 2e  t journal files.
02a0: 20 41 20 6e 65 67 61 74 69 76 65 20 0a 2a 2a 20   A negative .** 
02b0: 76 61 6c 75 65 20 6d 65 61 6e 73 20 6e 6f 20 6c  value means no l
02c0: 69 6d 69 74 2e 20 54 68 69 73 20 76 61 6c 75 65  imit. This value
02d0: 20 6d 61 79 20 62 65 20 6f 76 65 72 72 69 64 64   may be overridd
02e0: 65 6e 20 75 73 69 6e 67 20 74 68 65 20 0a 2a 2a  en using the .**
02f0: 20 73 71 6c 69 74 65 33 50 61 67 65 72 4a 6f 75   sqlite3PagerJou
0300: 72 6e 61 6c 53 69 7a 65 4c 69 6d 69 74 28 29 20  rnalSizeLimit() 
0310: 41 50 49 2e 20 53 65 65 20 61 6c 73 6f 20 22 50  API. See also "P
0320: 52 41 47 4d 41 20 6a 6f 75 72 6e 61 6c 5f 73 69  RAGMA journal_si
0330: 7a 65 5f 6c 69 6d 69 74 22 2e 0a 2a 2f 0a 23 69  ze_limit"..*/.#i
0340: 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 44 45 46  fndef SQLITE_DEF
0350: 41 55 4c 54 5f 4a 4f 55 52 4e 41 4c 5f 53 49 5a  AULT_JOURNAL_SIZ
0360: 45 5f 4c 49 4d 49 54 0a 20 20 23 64 65 66 69 6e  E_LIMIT.  #defin
0370: 65 20 53 51 4c 49 54 45 5f 44 45 46 41 55 4c 54  e SQLITE_DEFAULT
0380: 5f 4a 4f 55 52 4e 41 4c 5f 53 49 5a 45 5f 4c 49  _JOURNAL_SIZE_LI
0390: 4d 49 54 20 2d 31 0a 23 65 6e 64 69 66 0a 0a 2f  MIT -1.#endif../
03a0: 2a 0a 2a 2a 20 54 68 65 20 74 79 70 65 20 75 73  *.** The type us
03b0: 65 64 20 74 6f 20 72 65 70 72 65 73 65 6e 74 20  ed to represent 
03c0: 61 20 70 61 67 65 20 6e 75 6d 62 65 72 2e 20 20  a page number.  
03d0: 54 68 65 20 66 69 72 73 74 20 70 61 67 65 20 69  The first page i
03e0: 6e 20 61 20 66 69 6c 65 0a 2a 2a 20 69 73 20 63  n a file.** is c
03f0: 61 6c 6c 65 64 20 70 61 67 65 20 31 2e 20 20 30  alled page 1.  0
0400: 20 69 73 20 75 73 65 64 20 74 6f 20 72 65 70 72   is used to repr
0410: 65 73 65 6e 74 20 22 6e 6f 74 20 61 20 70 61 67  esent "not a pag
0420: 65 22 2e 0a 2a 2f 0a 74 79 70 65 64 65 66 20 75  e"..*/.typedef u
0430: 33 32 20 50 67 6e 6f 3b 0a 0a 2f 2a 0a 2a 2a 20  32 Pgno;../*.** 
0440: 45 61 63 68 20 6f 70 65 6e 20 66 69 6c 65 20 69  Each open file i
0450: 73 20 6d 61 6e 61 67 65 64 20 62 79 20 61 20 73  s managed by a s
0460: 65 70 61 72 61 74 65 20 69 6e 73 74 61 6e 63 65  eparate instance
0470: 20 6f 66 20 74 68 65 20 22 50 61 67 65 72 22 20   of the "Pager" 
0480: 73 74 72 75 63 74 75 72 65 2e 0a 2a 2f 0a 74 79  structure..*/.ty
0490: 70 65 64 65 66 20 73 74 72 75 63 74 20 50 61 67  pedef struct Pag
04a0: 65 72 20 50 61 67 65 72 3b 0a 0a 2f 2a 0a 2a 2a  er Pager;../*.**
04b0: 20 48 61 6e 64 6c 65 20 74 79 70 65 20 66 6f 72   Handle type for
04c0: 20 70 61 67 65 73 2e 0a 2a 2f 0a 74 79 70 65 64   pages..*/.typed
04d0: 65 66 20 73 74 72 75 63 74 20 50 67 48 64 72 20  ef struct PgHdr 
04e0: 44 62 50 61 67 65 3b 0a 0a 2f 2a 0a 2a 2a 20 50  DbPage;../*.** P
04f0: 61 67 65 20 6e 75 6d 62 65 72 20 50 41 47 45 52  age number PAGER
0500: 5f 4d 4a 5f 50 47 4e 4f 20 69 73 20 6e 65 76 65  _MJ_PGNO is neve
0510: 72 20 75 73 65 64 20 69 6e 20 61 6e 20 53 51 4c  r used in an SQL
0520: 69 74 65 20 64 61 74 61 62 61 73 65 20 28 69 74  ite database (it
0530: 20 69 73 0a 2a 2a 20 72 65 73 65 72 76 65 64 20   is.** reserved 
0540: 66 6f 72 20 77 6f 72 6b 69 6e 67 20 61 72 6f 75  for working arou
0550: 6e 64 20 61 20 77 69 6e 64 6f 77 73 2f 70 6f 73  nd a windows/pos
0560: 69 78 20 69 6e 63 6f 6d 70 61 74 69 62 69 6c 69  ix incompatibili
0570: 74 79 29 2e 20 49 74 20 69 73 0a 2a 2a 20 75 73  ty). It is.** us
0580: 65 64 20 69 6e 20 74 68 65 20 6a 6f 75 72 6e 61  ed in the journa
0590: 6c 20 74 6f 20 73 69 67 6e 69 66 79 20 74 68 61  l to signify tha
05a0: 74 20 74 68 65 20 72 65 6d 61 69 6e 64 65 72 20  t the remainder 
05b0: 6f 66 20 74 68 65 20 6a 6f 75 72 6e 61 6c 20 66  of the journal f
05c0: 69 6c 65 20 0a 2a 2a 20 69 73 20 64 65 76 6f 74  ile .** is devot
05d0: 65 64 20 74 6f 20 73 74 6f 72 69 6e 67 20 61 20  ed to storing a 
05e0: 6d 61 73 74 65 72 20 6a 6f 75 72 6e 61 6c 20 6e  master journal n
05f0: 61 6d 65 20 2d 20 74 68 65 72 65 20 61 72 65 20  ame - there are 
0600: 6e 6f 20 6d 6f 72 65 20 70 61 67 65 73 20 74 6f  no more pages to
0610: 0a 2a 2a 20 72 6f 6c 6c 20 62 61 63 6b 2e 20 53  .** roll back. S
0620: 65 65 20 63 6f 6d 6d 65 6e 74 73 20 66 6f 72 20  ee comments for 
0630: 66 75 6e 63 74 69 6f 6e 20 77 72 69 74 65 4d 61  function writeMa
0640: 73 74 65 72 4a 6f 75 72 6e 61 6c 28 29 20 69 6e  sterJournal() in
0650: 20 70 61 67 65 72 2e 63 20 0a 2a 2a 20 66 6f 72   pager.c .** for
0660: 20 64 65 74 61 69 6c 73 2e 0a 2a 2f 0a 23 64 65   details..*/.#de
0670: 66 69 6e 65 20 50 41 47 45 52 5f 4d 4a 5f 50 47  fine PAGER_MJ_PG
0680: 4e 4f 28 78 29 20 28 28 50 67 6e 6f 29 28 28 50  NO(x) ((Pgno)((P
0690: 45 4e 44 49 4e 47 5f 42 59 54 45 2f 28 28 78 29  ENDING_BYTE/((x)
06a0: 2d 3e 70 61 67 65 53 69 7a 65 29 29 2b 31 29 29  ->pageSize))+1))
06b0: 0a 0a 2f 2a 0a 2a 2a 20 41 6c 6c 6f 77 65 64 20  ../*.** Allowed 
06c0: 76 61 6c 75 65 73 20 66 6f 72 20 74 68 65 20 66  values for the f
06d0: 6c 61 67 73 20 70 61 72 61 6d 65 74 65 72 20 74  lags parameter t
06e0: 6f 20 73 71 6c 69 74 65 33 50 61 67 65 72 4f 70  o sqlite3PagerOp
06f0: 65 6e 28 29 2e 0a 2a 2a 0a 2a 2a 20 4e 4f 54 45  en()..**.** NOTE
0700: 3a 20 54 68 65 73 65 20 76 61 6c 75 65 73 20 6d  : These values m
0710: 75 73 74 20 6d 61 74 63 68 20 74 68 65 20 63 6f  ust match the co
0720: 72 72 65 73 70 6f 6e 64 69 6e 67 20 42 54 52 45  rresponding BTRE
0730: 45 5f 20 76 61 6c 75 65 73 20 69 6e 20 62 74 72  E_ values in btr
0740: 65 65 2e 68 2e 0a 2a 2f 0a 23 64 65 66 69 6e 65  ee.h..*/.#define
0750: 20 50 41 47 45 52 5f 4f 4d 49 54 5f 4a 4f 55 52   PAGER_OMIT_JOUR
0760: 4e 41 4c 20 20 30 78 30 30 30 31 20 20 20 20 2f  NAL  0x0001    /
0770: 2a 20 44 6f 20 6e 6f 74 20 75 73 65 20 61 20 72  * Do not use a r
0780: 6f 6c 6c 62 61 63 6b 20 6a 6f 75 72 6e 61 6c 20  ollback journal 
0790: 2a 2f 0a 23 64 65 66 69 6e 65 20 50 41 47 45 52  */.#define PAGER
07a0: 5f 4d 45 4d 4f 52 59 20 20 20 20 20 20 20 20 30  _MEMORY        0
07b0: 78 30 30 30 32 20 20 20 20 2f 2a 20 49 6e 2d 6d  x0002    /* In-m
07c0: 65 6d 6f 72 79 20 64 61 74 61 62 61 73 65 20 2a  emory database *
07d0: 2f 0a 0a 2f 2a 0a 2a 2a 20 56 61 6c 69 64 20 76  /../*.** Valid v
07e0: 61 6c 75 65 73 20 66 6f 72 20 74 68 65 20 73 65  alues for the se
07f0: 63 6f 6e 64 20 61 72 67 75 6d 65 6e 74 20 74 6f  cond argument to
0800: 20 73 71 6c 69 74 65 33 50 61 67 65 72 4c 6f 63   sqlite3PagerLoc
0810: 6b 69 6e 67 4d 6f 64 65 28 29 2e 0a 2a 2f 0a 23  kingMode()..*/.#
0820: 64 65 66 69 6e 65 20 50 41 47 45 52 5f 4c 4f 43  define PAGER_LOC
0830: 4b 49 4e 47 4d 4f 44 45 5f 51 55 45 52 59 20 20  KINGMODE_QUERY  
0840: 20 20 20 20 2d 31 0a 23 64 65 66 69 6e 65 20 50      -1.#define P
0850: 41 47 45 52 5f 4c 4f 43 4b 49 4e 47 4d 4f 44 45  AGER_LOCKINGMODE
0860: 5f 4e 4f 52 4d 41 4c 20 20 20 20 20 20 30 0a 23  _NORMAL      0.#
0870: 64 65 66 69 6e 65 20 50 41 47 45 52 5f 4c 4f 43  define PAGER_LOC
0880: 4b 49 4e 47 4d 4f 44 45 5f 45 58 43 4c 55 53 49  KINGMODE_EXCLUSI
0890: 56 45 20 20 20 31 0a 0a 2f 2a 0a 2a 2a 20 4e 75  VE   1../*.** Nu
08a0: 6d 65 72 69 63 20 63 6f 6e 73 74 61 6e 74 73 20  meric constants 
08b0: 74 68 61 74 20 65 6e 63 6f 64 65 20 74 68 65 20  that encode the 
08c0: 6a 6f 75 72 6e 61 6c 6d 6f 64 65 2e 0a 2a 2a 0a  journalmode..**.
08d0: 2a 2a 20 54 68 65 20 6e 75 6d 65 72 69 63 20 76  ** The numeric v
08e0: 61 6c 75 65 73 20 65 6e 63 6f 64 65 64 20 68 65  alues encoded he
08f0: 72 65 20 28 6f 74 68 65 72 20 74 68 61 6e 20 50  re (other than P
0900: 41 47 45 52 5f 4a 4f 55 52 4e 41 4c 4d 4f 44 45  AGER_JOURNALMODE
0910: 5f 51 55 45 52 59 29 0a 2a 2a 20 61 72 65 20 65  _QUERY).** are e
0920: 78 70 6f 73 65 64 20 69 6e 20 74 68 65 20 41 50  xposed in the AP
0930: 49 20 76 69 61 20 74 68 65 20 22 50 52 41 47 4d  I via the "PRAGM
0940: 41 20 6a 6f 75 72 6e 61 6c 5f 6d 6f 64 65 22 20  A journal_mode" 
0950: 63 6f 6d 6d 61 6e 64 20 61 6e 64 0a 2a 2a 20 74  command and.** t
0960: 68 65 72 65 66 6f 72 65 20 63 61 6e 6e 6f 74 20  herefore cannot 
0970: 62 65 20 63 68 61 6e 67 65 64 20 77 69 74 68 6f  be changed witho
0980: 75 74 20 61 20 63 6f 6d 70 61 74 69 62 69 6c 69  ut a compatibili
0990: 74 79 20 62 72 65 61 6b 2e 0a 2a 2f 0a 23 64 65  ty break..*/.#de
09a0: 66 69 6e 65 20 50 41 47 45 52 5f 4a 4f 55 52 4e  fine PAGER_JOURN
09b0: 41 4c 4d 4f 44 45 5f 51 55 45 52 59 20 20 20 20  ALMODE_QUERY    
09c0: 20 28 2d 31 29 20 20 2f 2a 20 51 75 65 72 79 20   (-1)  /* Query 
09d0: 74 68 65 20 76 61 6c 75 65 20 6f 66 20 6a 6f 75  the value of jou
09e0: 72 6e 61 6c 6d 6f 64 65 20 2a 2f 0a 23 64 65 66  rnalmode */.#def
09f0: 69 6e 65 20 50 41 47 45 52 5f 4a 4f 55 52 4e 41  ine PAGER_JOURNA
0a00: 4c 4d 4f 44 45 5f 44 45 4c 45 54 45 20 20 20 20  LMODE_DELETE    
0a10: 20 20 30 20 20 20 2f 2a 20 43 6f 6d 6d 69 74 20    0   /* Commit 
0a20: 62 79 20 64 65 6c 65 74 69 6e 67 20 6a 6f 75 72  by deleting jour
0a30: 6e 61 6c 20 66 69 6c 65 20 2a 2f 0a 23 64 65 66  nal file */.#def
0a40: 69 6e 65 20 50 41 47 45 52 5f 4a 4f 55 52 4e 41  ine PAGER_JOURNA
0a50: 4c 4d 4f 44 45 5f 50 45 52 53 49 53 54 20 20 20  LMODE_PERSIST   
0a60: 20 20 31 20 20 20 2f 2a 20 43 6f 6d 6d 69 74 20    1   /* Commit 
0a70: 62 79 20 7a 65 72 6f 69 6e 67 20 6a 6f 75 72 6e  by zeroing journ
0a80: 61 6c 20 68 65 61 64 65 72 20 2a 2f 0a 23 64 65  al header */.#de
0a90: 66 69 6e 65 20 50 41 47 45 52 5f 4a 4f 55 52 4e  fine PAGER_JOURN
0aa0: 41 4c 4d 4f 44 45 5f 4f 46 46 20 20 20 20 20 20  ALMODE_OFF      
0ab0: 20 20 20 32 20 20 20 2f 2a 20 4a 6f 75 72 6e 61     2   /* Journa
0ac0: 6c 20 6f 6d 69 74 74 65 64 2e 20 20 2a 2f 0a 23  l omitted.  */.#
0ad0: 64 65 66 69 6e 65 20 50 41 47 45 52 5f 4a 4f 55  define PAGER_JOU
0ae0: 52 4e 41 4c 4d 4f 44 45 5f 54 52 55 4e 43 41 54  RNALMODE_TRUNCAT
0af0: 45 20 20 20 20 33 20 20 20 2f 2a 20 43 6f 6d 6d  E    3   /* Comm
0b00: 69 74 20 62 79 20 74 72 75 6e 63 61 74 69 6e 67  it by truncating
0b10: 20 6a 6f 75 72 6e 61 6c 20 2a 2f 0a 23 64 65 66   journal */.#def
0b20: 69 6e 65 20 50 41 47 45 52 5f 4a 4f 55 52 4e 41  ine PAGER_JOURNA
0b30: 4c 4d 4f 44 45 5f 4d 45 4d 4f 52 59 20 20 20 20  LMODE_MEMORY    
0b40: 20 20 34 20 20 20 2f 2a 20 49 6e 2d 6d 65 6d 6f    4   /* In-memo
0b50: 72 79 20 6a 6f 75 72 6e 61 6c 20 66 69 6c 65 20  ry journal file 
0b60: 2a 2f 0a 23 64 65 66 69 6e 65 20 50 41 47 45 52  */.#define PAGER
0b70: 5f 4a 4f 55 52 4e 41 4c 4d 4f 44 45 5f 57 41 4c  _JOURNALMODE_WAL
0b80: 20 20 20 20 20 20 20 20 20 35 20 20 20 2f 2a 20           5   /* 
0b90: 55 73 65 20 77 72 69 74 65 2d 61 68 65 61 64 20  Use write-ahead 
0ba0: 6c 6f 67 67 69 6e 67 20 2a 2f 0a 0a 2f 2a 0a 2a  logging */../*.*
0bb0: 2a 20 46 6c 61 67 73 20 74 68 61 74 20 6d 61 6b  * Flags that mak
0bc0: 65 20 75 70 20 74 68 65 20 6d 61 73 6b 20 70 61  e up the mask pa
0bd0: 73 73 65 64 20 74 6f 20 73 71 6c 69 74 65 33 50  ssed to sqlite3P
0be0: 61 67 65 72 47 65 74 28 29 2e 0a 2a 2f 0a 23 64  agerGet()..*/.#d
0bf0: 65 66 69 6e 65 20 50 41 47 45 52 5f 47 45 54 5f  efine PAGER_GET_
0c00: 4e 4f 43 4f 4e 54 45 4e 54 20 20 20 20 20 30 78  NOCONTENT     0x
0c10: 30 31 20 20 2f 2a 20 44 6f 20 6e 6f 74 20 6c 6f  01  /* Do not lo
0c20: 61 64 20 64 61 74 61 20 66 72 6f 6d 20 64 69 73  ad data from dis
0c30: 6b 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50 41 47  k */.#define PAG
0c40: 45 52 5f 47 45 54 5f 52 45 41 44 4f 4e 4c 59 20  ER_GET_READONLY 
0c50: 20 20 20 20 20 30 78 30 32 20 20 2f 2a 20 52 65       0x02  /* Re
0c60: 61 64 2d 6f 6e 6c 79 20 70 61 67 65 20 69 73 20  ad-only page is 
0c70: 61 63 63 65 70 74 61 62 6c 65 20 2a 2f 0a 0a 2f  acceptable */../
0c80: 2a 0a 2a 2a 20 46 6c 61 67 73 20 66 6f 72 20 73  *.** Flags for s
0c90: 71 6c 69 74 65 33 50 61 67 65 72 53 65 74 46 6c  qlite3PagerSetFl
0ca0: 61 67 73 28 29 0a 2a 2a 0a 2a 2a 20 56 61 6c 75  ags().**.** Valu
0cb0: 65 20 63 6f 6e 73 74 72 61 69 6e 74 73 20 28 65  e constraints (e
0cc0: 6e 66 6f 72 63 65 64 20 76 69 61 20 61 73 73 65  nforced via asse
0cd0: 72 74 28 29 29 3a 0a 2a 2a 20 20 20 20 50 41 47  rt()):.**    PAG
0ce0: 45 52 5f 46 55 4c 4c 46 53 59 4e 43 20 20 20 20  ER_FULLFSYNC    
0cf0: 20 20 3d 3d 20 53 51 4c 49 54 45 5f 46 75 6c 6c    == SQLITE_Full
0d00: 46 53 79 6e 63 0a 2a 2a 20 20 20 20 50 41 47 45  FSync.**    PAGE
0d10: 52 5f 43 4b 50 54 5f 46 55 4c 4c 46 53 59 4e 43  R_CKPT_FULLFSYNC
0d20: 20 3d 3d 20 53 51 4c 49 54 45 5f 43 6b 70 74 46   == SQLITE_CkptF
0d30: 75 6c 6c 46 53 79 6e 63 0a 2a 2a 20 20 20 20 50  ullFSync.**    P
0d40: 41 47 45 52 5f 43 41 43 48 45 5f 53 50 49 4c 4c  AGER_CACHE_SPILL
0d50: 20 20 20 20 3d 3d 20 53 51 4c 49 54 45 5f 43 61      == SQLITE_Ca
0d60: 63 68 65 53 70 69 6c 6c 0a 2a 2f 0a 23 64 65 66  cheSpill.*/.#def
0d70: 69 6e 65 20 50 41 47 45 52 5f 53 59 4e 43 48 52  ine PAGER_SYNCHR
0d80: 4f 4e 4f 55 53 5f 4f 46 46 20 20 20 20 20 20 20  ONOUS_OFF       
0d90: 30 78 30 31 20 20 2f 2a 20 50 52 41 47 4d 41 20  0x01  /* PRAGMA 
0da0: 73 79 6e 63 68 72 6f 6e 6f 75 73 3d 4f 46 46 20  synchronous=OFF 
0db0: 2a 2f 0a 23 64 65 66 69 6e 65 20 50 41 47 45 52  */.#define PAGER
0dc0: 5f 53 59 4e 43 48 52 4f 4e 4f 55 53 5f 4e 4f 52  _SYNCHRONOUS_NOR
0dd0: 4d 41 4c 20 20 20 20 30 78 30 32 20 20 2f 2a 20  MAL    0x02  /* 
0de0: 50 52 41 47 4d 41 20 73 79 6e 63 68 72 6f 6e 6f  PRAGMA synchrono
0df0: 75 73 3d 4e 4f 52 4d 41 4c 20 2a 2f 0a 23 64 65  us=NORMAL */.#de
0e00: 66 69 6e 65 20 50 41 47 45 52 5f 53 59 4e 43 48  fine PAGER_SYNCH
0e10: 52 4f 4e 4f 55 53 5f 46 55 4c 4c 20 20 20 20 20  RONOUS_FULL     
0e20: 20 30 78 30 33 20 20 2f 2a 20 50 52 41 47 4d 41   0x03  /* PRAGMA
0e30: 20 73 79 6e 63 68 72 6f 6e 6f 75 73 3d 46 55 4c   synchronous=FUL
0e40: 4c 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50 41 47  L */.#define PAG
0e50: 45 52 5f 53 59 4e 43 48 52 4f 4e 4f 55 53 5f 45  ER_SYNCHRONOUS_E
0e60: 58 54 52 41 20 20 20 20 20 30 78 30 34 20 20 2f  XTRA     0x04  /
0e70: 2a 20 50 52 41 47 4d 41 20 73 79 6e 63 68 72 6f  * PRAGMA synchro
0e80: 6e 6f 75 73 3d 45 58 54 52 41 20 2a 2f 0a 23 64  nous=EXTRA */.#d
0e90: 65 66 69 6e 65 20 50 41 47 45 52 5f 53 59 4e 43  efine PAGER_SYNC
0ea0: 48 52 4f 4e 4f 55 53 5f 4d 41 53 4b 20 20 20 20  HRONOUS_MASK    
0eb0: 20 20 30 78 30 37 20 20 2f 2a 20 4d 61 73 6b 20    0x07  /* Mask 
0ec0: 66 6f 72 20 66 6f 75 72 20 76 61 6c 75 65 73 20  for four values 
0ed0: 61 62 6f 76 65 20 2a 2f 0a 23 64 65 66 69 6e 65  above */.#define
0ee0: 20 50 41 47 45 52 5f 46 55 4c 4c 46 53 59 4e 43   PAGER_FULLFSYNC
0ef0: 20 20 20 20 20 20 20 20 20 20 20 20 20 30 78 30               0x0
0f00: 38 20 20 2f 2a 20 50 52 41 47 4d 41 20 66 75 6c  8  /* PRAGMA ful
0f10: 6c 66 73 79 6e 63 3d 4f 4e 20 2a 2f 0a 23 64 65  lfsync=ON */.#de
0f20: 66 69 6e 65 20 50 41 47 45 52 5f 43 4b 50 54 5f  fine PAGER_CKPT_
0f30: 46 55 4c 4c 46 53 59 4e 43 20 20 20 20 20 20 20  FULLFSYNC       
0f40: 20 30 78 31 30 20 20 2f 2a 20 50 52 41 47 4d 41   0x10  /* PRAGMA
0f50: 20 63 68 65 63 6b 70 6f 69 6e 74 5f 66 75 6c 6c   checkpoint_full
0f60: 66 73 79 6e 63 3d 4f 4e 20 2a 2f 0a 23 64 65 66  fsync=ON */.#def
0f70: 69 6e 65 20 50 41 47 45 52 5f 43 41 43 48 45 53  ine PAGER_CACHES
0f80: 50 49 4c 4c 20 20 20 20 20 20 20 20 20 20 20 20  PILL            
0f90: 30 78 32 30 20 20 2f 2a 20 50 52 41 47 4d 41 20  0x20  /* PRAGMA 
0fa0: 63 61 63 68 65 5f 73 70 69 6c 6c 3d 4f 4e 20 2a  cache_spill=ON *
0fb0: 2f 0a 23 64 65 66 69 6e 65 20 50 41 47 45 52 5f  /.#define PAGER_
0fc0: 46 4c 41 47 53 5f 4d 41 53 4b 20 20 20 20 20 20  FLAGS_MASK      
0fd0: 20 20 20 20 20 20 30 78 33 38 20 20 2f 2a 20 41        0x38  /* A
0fe0: 6c 6c 20 61 62 6f 76 65 20 65 78 63 65 70 74 20  ll above except 
0ff0: 53 59 4e 43 48 52 4f 4e 4f 55 53 20 2a 2f 0a 0a  SYNCHRONOUS */..
1000: 2f 2a 0a 2a 2a 20 54 68 65 20 72 65 6d 61 69 6e  /*.** The remain
1010: 64 65 72 20 6f 66 20 74 68 69 73 20 66 69 6c 65  der of this file
1020: 20 63 6f 6e 74 61 69 6e 73 20 74 68 65 20 64 65   contains the de
1030: 63 6c 61 72 61 74 69 6f 6e 73 20 6f 66 20 74 68  clarations of th
1040: 65 20 66 75 6e 63 74 69 6f 6e 73 0a 2a 2a 20 74  e functions.** t
1050: 68 61 74 20 6d 61 6b 65 20 75 70 20 74 68 65 20  hat make up the 
1060: 50 61 67 65 72 20 73 75 62 2d 73 79 73 74 65 6d  Pager sub-system
1070: 20 41 50 49 2e 20 53 65 65 20 73 6f 75 72 63 65   API. See source
1080: 20 63 6f 64 65 20 63 6f 6d 6d 65 6e 74 73 20 66   code comments f
1090: 6f 72 20 0a 2a 2a 20 61 20 64 65 74 61 69 6c 65  or .** a detaile
10a0: 64 20 64 65 73 63 72 69 70 74 69 6f 6e 20 6f 66  d description of
10b0: 20 65 61 63 68 20 72 6f 75 74 69 6e 65 2e 0a 2a   each routine..*
10c0: 2f 0a 0a 2f 2a 20 4f 70 65 6e 20 61 6e 64 20 63  /../* Open and c
10d0: 6c 6f 73 65 20 61 20 50 61 67 65 72 20 63 6f 6e  lose a Pager con
10e0: 6e 65 63 74 69 6f 6e 2e 20 2a 2f 20 0a 69 6e 74  nection. */ .int
10f0: 20 73 71 6c 69 74 65 33 50 61 67 65 72 4f 70 65   sqlite3PagerOpe
1100: 6e 28 0a 20 20 73 71 6c 69 74 65 33 5f 76 66 73  n(.  sqlite3_vfs
1110: 2a 2c 0a 20 20 50 61 67 65 72 20 2a 2a 70 70 50  *,.  Pager **ppP
1120: 61 67 65 72 2c 0a 20 20 63 6f 6e 73 74 20 63 68  ager,.  const ch
1130: 61 72 2a 2c 0a 20 20 69 6e 74 2c 0a 20 20 69 6e  ar*,.  int,.  in
1140: 74 2c 0a 20 20 69 6e 74 2c 0a 20 20 76 6f 69 64  t,.  int,.  void
1150: 28 2a 29 28 44 62 50 61 67 65 2a 29 0a 29 3b 0a  (*)(DbPage*).);.
1160: 69 6e 74 20 73 71 6c 69 74 65 33 50 61 67 65 72  int sqlite3Pager
1170: 43 6c 6f 73 65 28 50 61 67 65 72 20 2a 70 50 61  Close(Pager *pPa
1180: 67 65 72 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65  ger);.int sqlite
1190: 33 50 61 67 65 72 52 65 61 64 46 69 6c 65 68 65  3PagerReadFilehe
11a0: 61 64 65 72 28 50 61 67 65 72 2a 2c 20 69 6e 74  ader(Pager*, int
11b0: 2c 20 75 6e 73 69 67 6e 65 64 20 63 68 61 72 2a  , unsigned char*
11c0: 29 3b 0a 0a 2f 2a 20 46 75 6e 63 74 69 6f 6e 73  );../* Functions
11d0: 20 75 73 65 64 20 74 6f 20 63 6f 6e 66 69 67 75   used to configu
11e0: 72 65 20 61 20 50 61 67 65 72 20 6f 62 6a 65 63  re a Pager objec
11f0: 74 2e 20 2a 2f 0a 76 6f 69 64 20 73 71 6c 69 74  t. */.void sqlit
1200: 65 33 50 61 67 65 72 53 65 74 42 75 73 79 68 61  e3PagerSetBusyha
1210: 6e 64 6c 65 72 28 50 61 67 65 72 2a 2c 20 69 6e  ndler(Pager*, in
1220: 74 28 2a 29 28 76 6f 69 64 20 2a 29 2c 20 76 6f  t(*)(void *), vo
1230: 69 64 20 2a 29 3b 0a 69 6e 74 20 73 71 6c 69 74  id *);.int sqlit
1240: 65 33 50 61 67 65 72 53 65 74 50 61 67 65 73 69  e3PagerSetPagesi
1250: 7a 65 28 50 61 67 65 72 2a 2c 20 75 33 32 2a 2c  ze(Pager*, u32*,
1260: 20 69 6e 74 29 3b 0a 23 69 66 64 65 66 20 53 51   int);.#ifdef SQ
1270: 4c 49 54 45 5f 48 41 53 5f 43 4f 44 45 43 0a 76  LITE_HAS_CODEC.v
1280: 6f 69 64 20 73 71 6c 69 74 65 33 50 61 67 65 72  oid sqlite3Pager
1290: 41 6c 69 67 6e 52 65 73 65 72 76 65 28 50 61 67  AlignReserve(Pag
12a0: 65 72 2a 2c 50 61 67 65 72 2a 29 3b 0a 23 65 6e  er*,Pager*);.#en
12b0: 64 69 66 0a 69 6e 74 20 73 71 6c 69 74 65 33 50  dif.int sqlite3P
12c0: 61 67 65 72 4d 61 78 50 61 67 65 43 6f 75 6e 74  agerMaxPageCount
12d0: 28 50 61 67 65 72 2a 2c 20 69 6e 74 29 3b 0a 76  (Pager*, int);.v
12e0: 6f 69 64 20 73 71 6c 69 74 65 33 50 61 67 65 72  oid sqlite3Pager
12f0: 53 65 74 43 61 63 68 65 73 69 7a 65 28 50 61 67  SetCachesize(Pag
1300: 65 72 2a 2c 20 69 6e 74 29 3b 0a 69 6e 74 20 73  er*, int);.int s
1310: 71 6c 69 74 65 33 50 61 67 65 72 53 65 74 53 70  qlite3PagerSetSp
1320: 69 6c 6c 73 69 7a 65 28 50 61 67 65 72 2a 2c 20  illsize(Pager*, 
1330: 69 6e 74 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74  int);.void sqlit
1340: 65 33 50 61 67 65 72 53 65 74 4d 6d 61 70 4c 69  e3PagerSetMmapLi
1350: 6d 69 74 28 50 61 67 65 72 20 2a 2c 20 73 71 6c  mit(Pager *, sql
1360: 69 74 65 33 5f 69 6e 74 36 34 29 3b 0a 76 6f 69  ite3_int64);.voi
1370: 64 20 73 71 6c 69 74 65 33 50 61 67 65 72 53 68  d sqlite3PagerSh
1380: 72 69 6e 6b 28 50 61 67 65 72 2a 29 3b 0a 76 6f  rink(Pager*);.vo
1390: 69 64 20 73 71 6c 69 74 65 33 50 61 67 65 72 53  id sqlite3PagerS
13a0: 65 74 46 6c 61 67 73 28 50 61 67 65 72 2a 2c 75  etFlags(Pager*,u
13b0: 6e 73 69 67 6e 65 64 29 3b 0a 69 6e 74 20 73 71  nsigned);.int sq
13c0: 6c 69 74 65 33 50 61 67 65 72 4c 6f 63 6b 69 6e  lite3PagerLockin
13d0: 67 4d 6f 64 65 28 50 61 67 65 72 20 2a 2c 20 69  gMode(Pager *, i
13e0: 6e 74 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33  nt);.int sqlite3
13f0: 50 61 67 65 72 53 65 74 4a 6f 75 72 6e 61 6c 4d  PagerSetJournalM
1400: 6f 64 65 28 50 61 67 65 72 20 2a 2c 20 69 6e 74  ode(Pager *, int
1410: 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 50 61  );.int sqlite3Pa
1420: 67 65 72 47 65 74 4a 6f 75 72 6e 61 6c 4d 6f 64  gerGetJournalMod
1430: 65 28 50 61 67 65 72 2a 29 3b 0a 69 6e 74 20 73  e(Pager*);.int s
1440: 71 6c 69 74 65 33 50 61 67 65 72 4f 6b 54 6f 43  qlite3PagerOkToC
1450: 68 61 6e 67 65 4a 6f 75 72 6e 61 6c 4d 6f 64 65  hangeJournalMode
1460: 28 50 61 67 65 72 2a 29 3b 0a 69 36 34 20 73 71  (Pager*);.i64 sq
1470: 6c 69 74 65 33 50 61 67 65 72 4a 6f 75 72 6e 61  lite3PagerJourna
1480: 6c 53 69 7a 65 4c 69 6d 69 74 28 50 61 67 65 72  lSizeLimit(Pager
1490: 20 2a 2c 20 69 36 34 29 3b 0a 73 71 6c 69 74 65   *, i64);.sqlite
14a0: 33 5f 62 61 63 6b 75 70 20 2a 2a 73 71 6c 69 74  3_backup **sqlit
14b0: 65 33 50 61 67 65 72 42 61 63 6b 75 70 50 74 72  e3PagerBackupPtr
14c0: 28 50 61 67 65 72 2a 29 3b 0a 69 6e 74 20 73 71  (Pager*);.int sq
14d0: 6c 69 74 65 33 50 61 67 65 72 46 6c 75 73 68 28  lite3PagerFlush(
14e0: 50 61 67 65 72 2a 29 3b 0a 0a 2f 2a 20 46 75 6e  Pager*);../* Fun
14f0: 63 74 69 6f 6e 73 20 75 73 65 64 20 74 6f 20 6f  ctions used to o
1500: 62 74 61 69 6e 20 61 6e 64 20 72 65 6c 65 61 73  btain and releas
1510: 65 20 70 61 67 65 20 72 65 66 65 72 65 6e 63 65  e page reference
1520: 73 2e 20 2a 2f 20 0a 69 6e 74 20 73 71 6c 69 74  s. */ .int sqlit
1530: 65 33 50 61 67 65 72 47 65 74 28 50 61 67 65 72  e3PagerGet(Pager
1540: 20 2a 70 50 61 67 65 72 2c 20 50 67 6e 6f 20 70   *pPager, Pgno p
1550: 67 6e 6f 2c 20 44 62 50 61 67 65 20 2a 2a 70 70  gno, DbPage **pp
1560: 50 61 67 65 2c 20 69 6e 74 20 63 6c 72 46 6c 61  Page, int clrFla
1570: 67 29 3b 0a 44 62 50 61 67 65 20 2a 73 71 6c 69  g);.DbPage *sqli
1580: 74 65 33 50 61 67 65 72 4c 6f 6f 6b 75 70 28 50  te3PagerLookup(P
1590: 61 67 65 72 20 2a 70 50 61 67 65 72 2c 20 50 67  ager *pPager, Pg
15a0: 6e 6f 20 70 67 6e 6f 29 3b 0a 76 6f 69 64 20 73  no pgno);.void s
15b0: 71 6c 69 74 65 33 50 61 67 65 72 52 65 66 28 44  qlite3PagerRef(D
15c0: 62 50 61 67 65 2a 29 3b 0a 76 6f 69 64 20 73 71  bPage*);.void sq
15d0: 6c 69 74 65 33 50 61 67 65 72 55 6e 72 65 66 28  lite3PagerUnref(
15e0: 44 62 50 61 67 65 2a 29 3b 0a 76 6f 69 64 20 73  DbPage*);.void s
15f0: 71 6c 69 74 65 33 50 61 67 65 72 55 6e 72 65 66  qlite3PagerUnref
1600: 4e 6f 74 4e 75 6c 6c 28 44 62 50 61 67 65 2a 29  NotNull(DbPage*)
1610: 3b 0a 0a 2f 2a 20 4f 70 65 72 61 74 69 6f 6e 73  ;../* Operations
1620: 20 6f 6e 20 70 61 67 65 20 72 65 66 65 72 65 6e   on page referen
1630: 63 65 73 2e 20 2a 2f 0a 69 6e 74 20 73 71 6c 69  ces. */.int sqli
1640: 74 65 33 50 61 67 65 72 57 72 69 74 65 28 44 62  te3PagerWrite(Db
1650: 50 61 67 65 2a 29 3b 0a 76 6f 69 64 20 73 71 6c  Page*);.void sql
1660: 69 74 65 33 50 61 67 65 72 44 6f 6e 74 57 72 69  ite3PagerDontWri
1670: 74 65 28 44 62 50 61 67 65 2a 29 3b 0a 69 6e 74  te(DbPage*);.int
1680: 20 73 71 6c 69 74 65 33 50 61 67 65 72 4d 6f 76   sqlite3PagerMov
1690: 65 70 61 67 65 28 50 61 67 65 72 2a 2c 44 62 50  epage(Pager*,DbP
16a0: 61 67 65 2a 2c 50 67 6e 6f 2c 69 6e 74 29 3b 0a  age*,Pgno,int);.
16b0: 69 6e 74 20 73 71 6c 69 74 65 33 50 61 67 65 72  int sqlite3Pager
16c0: 50 61 67 65 52 65 66 63 6f 75 6e 74 28 44 62 50  PageRefcount(DbP
16d0: 61 67 65 2a 29 3b 0a 76 6f 69 64 20 2a 73 71 6c  age*);.void *sql
16e0: 69 74 65 33 50 61 67 65 72 47 65 74 44 61 74 61  ite3PagerGetData
16f0: 28 44 62 50 61 67 65 20 2a 29 3b 20 0a 76 6f 69  (DbPage *); .voi
1700: 64 20 2a 73 71 6c 69 74 65 33 50 61 67 65 72 47  d *sqlite3PagerG
1710: 65 74 45 78 74 72 61 28 44 62 50 61 67 65 20 2a  etExtra(DbPage *
1720: 29 3b 20 0a 0a 2f 2a 20 46 75 6e 63 74 69 6f 6e  ); ../* Function
1730: 73 20 75 73 65 64 20 74 6f 20 6d 61 6e 61 67 65  s used to manage
1740: 20 70 61 67 65 72 20 74 72 61 6e 73 61 63 74 69   pager transacti
1750: 6f 6e 73 20 61 6e 64 20 73 61 76 65 70 6f 69 6e  ons and savepoin
1760: 74 73 2e 20 2a 2f 0a 76 6f 69 64 20 73 71 6c 69  ts. */.void sqli
1770: 74 65 33 50 61 67 65 72 50 61 67 65 63 6f 75 6e  te3PagerPagecoun
1780: 74 28 50 61 67 65 72 2a 2c 20 69 6e 74 2a 29 3b  t(Pager*, int*);
1790: 0a 69 6e 74 20 73 71 6c 69 74 65 33 50 61 67 65  .int sqlite3Page
17a0: 72 42 65 67 69 6e 28 50 61 67 65 72 2a 2c 20 69  rBegin(Pager*, i
17b0: 6e 74 20 65 78 46 6c 61 67 2c 20 69 6e 74 29 3b  nt exFlag, int);
17c0: 0a 69 6e 74 20 73 71 6c 69 74 65 33 50 61 67 65  .int sqlite3Page
17d0: 72 43 6f 6d 6d 69 74 50 68 61 73 65 4f 6e 65 28  rCommitPhaseOne(
17e0: 50 61 67 65 72 2a 2c 63 6f 6e 73 74 20 63 68 61  Pager*,const cha
17f0: 72 20 2a 7a 4d 61 73 74 65 72 2c 20 69 6e 74 29  r *zMaster, int)
1800: 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 50 61 67  ;.int sqlite3Pag
1810: 65 72 45 78 63 6c 75 73 69 76 65 4c 6f 63 6b 28  erExclusiveLock(
1820: 50 61 67 65 72 2a 29 3b 0a 69 6e 74 20 73 71 6c  Pager*);.int sql
1830: 69 74 65 33 50 61 67 65 72 53 79 6e 63 28 50 61  ite3PagerSync(Pa
1840: 67 65 72 20 2a 70 50 61 67 65 72 2c 20 63 6f 6e  ger *pPager, con
1850: 73 74 20 63 68 61 72 20 2a 7a 4d 61 73 74 65 72  st char *zMaster
1860: 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 50 61  );.int sqlite3Pa
1870: 67 65 72 43 6f 6d 6d 69 74 50 68 61 73 65 54 77  gerCommitPhaseTw
1880: 6f 28 50 61 67 65 72 2a 29 3b 0a 69 6e 74 20 73  o(Pager*);.int s
1890: 71 6c 69 74 65 33 50 61 67 65 72 52 6f 6c 6c 62  qlite3PagerRollb
18a0: 61 63 6b 28 50 61 67 65 72 2a 29 3b 0a 69 6e 74  ack(Pager*);.int
18b0: 20 73 71 6c 69 74 65 33 50 61 67 65 72 4f 70 65   sqlite3PagerOpe
18c0: 6e 53 61 76 65 70 6f 69 6e 74 28 50 61 67 65 72  nSavepoint(Pager
18d0: 20 2a 70 50 61 67 65 72 2c 20 69 6e 74 20 6e 29   *pPager, int n)
18e0: 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 50 61 67  ;.int sqlite3Pag
18f0: 65 72 53 61 76 65 70 6f 69 6e 74 28 50 61 67 65  erSavepoint(Page
1900: 72 20 2a 70 50 61 67 65 72 2c 20 69 6e 74 20 6f  r *pPager, int o
1910: 70 2c 20 69 6e 74 20 69 53 61 76 65 70 6f 69 6e  p, int iSavepoin
1920: 74 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 50  t);.int sqlite3P
1930: 61 67 65 72 53 68 61 72 65 64 4c 6f 63 6b 28 50  agerSharedLock(P
1940: 61 67 65 72 20 2a 70 50 61 67 65 72 29 3b 0a 0a  ager *pPager);..
1950: 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f  #ifndef SQLITE_O
1960: 4d 49 54 5f 57 41 4c 0a 20 20 69 6e 74 20 73 71  MIT_WAL.  int sq
1970: 6c 69 74 65 33 50 61 67 65 72 43 68 65 63 6b 70  lite3PagerCheckp
1980: 6f 69 6e 74 28 50 61 67 65 72 20 2a 70 50 61 67  oint(Pager *pPag
1990: 65 72 2c 20 69 6e 74 2c 20 69 6e 74 2a 2c 20 69  er, int, int*, i
19a0: 6e 74 2a 29 3b 0a 20 20 69 6e 74 20 73 71 6c 69  nt*);.  int sqli
19b0: 74 65 33 50 61 67 65 72 57 61 6c 53 75 70 70 6f  te3PagerWalSuppo
19c0: 72 74 65 64 28 50 61 67 65 72 20 2a 70 50 61 67  rted(Pager *pPag
19d0: 65 72 29 3b 0a 20 20 69 6e 74 20 73 71 6c 69 74  er);.  int sqlit
19e0: 65 33 50 61 67 65 72 57 61 6c 43 61 6c 6c 62 61  e3PagerWalCallba
19f0: 63 6b 28 50 61 67 65 72 20 2a 70 50 61 67 65 72  ck(Pager *pPager
1a00: 29 3b 0a 20 20 69 6e 74 20 73 71 6c 69 74 65 33  );.  int sqlite3
1a10: 50 61 67 65 72 4f 70 65 6e 57 61 6c 28 50 61 67  PagerOpenWal(Pag
1a20: 65 72 20 2a 70 50 61 67 65 72 2c 20 69 6e 74 20  er *pPager, int 
1a30: 2a 70 69 73 4f 70 65 6e 29 3b 0a 20 20 69 6e 74  *pisOpen);.  int
1a40: 20 73 71 6c 69 74 65 33 50 61 67 65 72 43 6c 6f   sqlite3PagerClo
1a50: 73 65 57 61 6c 28 50 61 67 65 72 20 2a 70 50 61  seWal(Pager *pPa
1a60: 67 65 72 29 3b 0a 23 20 69 66 64 65 66 20 53 51  ger);.# ifdef SQ
1a70: 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 53 4e 41 50  LITE_ENABLE_SNAP
1a80: 53 48 4f 54 0a 20 20 69 6e 74 20 73 71 6c 69 74  SHOT.  int sqlit
1a90: 65 33 50 61 67 65 72 53 6e 61 70 73 68 6f 74 47  e3PagerSnapshotG
1aa0: 65 74 28 50 61 67 65 72 20 2a 70 50 61 67 65 72  et(Pager *pPager
1ab0: 2c 20 73 71 6c 69 74 65 33 5f 73 6e 61 70 73 68  , sqlite3_snapsh
1ac0: 6f 74 20 2a 2a 70 70 53 6e 61 70 73 68 6f 74 29  ot **ppSnapshot)
1ad0: 3b 0a 20 20 69 6e 74 20 73 71 6c 69 74 65 33 50  ;.  int sqlite3P
1ae0: 61 67 65 72 53 6e 61 70 73 68 6f 74 4f 70 65 6e  agerSnapshotOpen
1af0: 28 50 61 67 65 72 20 2a 70 50 61 67 65 72 2c 20  (Pager *pPager, 
1b00: 73 71 6c 69 74 65 33 5f 73 6e 61 70 73 68 6f 74  sqlite3_snapshot
1b10: 20 2a 70 53 6e 61 70 73 68 6f 74 29 3b 0a 23 20   *pSnapshot);.# 
1b20: 65 6e 64 69 66 0a 23 65 6e 64 69 66 0a 0a 23 69  endif.#endif..#i
1b30: 66 64 65 66 20 53 51 4c 49 54 45 5f 45 4e 41 42  fdef SQLITE_ENAB
1b40: 4c 45 5f 5a 49 50 56 46 53 0a 20 20 69 6e 74 20  LE_ZIPVFS.  int 
1b50: 73 71 6c 69 74 65 33 50 61 67 65 72 57 61 6c 46  sqlite3PagerWalF
1b60: 72 61 6d 65 73 69 7a 65 28 50 61 67 65 72 20 2a  ramesize(Pager *
1b70: 70 50 61 67 65 72 29 3b 0a 23 65 6e 64 69 66 0a  pPager);.#endif.
1b80: 0a 2f 2a 20 46 75 6e 63 74 69 6f 6e 73 20 75 73  ./* Functions us
1b90: 65 64 20 74 6f 20 71 75 65 72 79 20 70 61 67 65  ed to query page
1ba0: 72 20 73 74 61 74 65 20 61 6e 64 20 63 6f 6e 66  r state and conf
1bb0: 69 67 75 72 61 74 69 6f 6e 2e 20 2a 2f 0a 75 38  iguration. */.u8
1bc0: 20 73 71 6c 69 74 65 33 50 61 67 65 72 49 73 72   sqlite3PagerIsr
1bd0: 65 61 64 6f 6e 6c 79 28 50 61 67 65 72 2a 29 3b  eadonly(Pager*);
1be0: 0a 75 33 32 20 73 71 6c 69 74 65 33 50 61 67 65  .u32 sqlite3Page
1bf0: 72 44 61 74 61 56 65 72 73 69 6f 6e 28 50 61 67  rDataVersion(Pag
1c00: 65 72 2a 29 3b 0a 23 69 66 64 65 66 20 53 51 4c  er*);.#ifdef SQL
1c10: 49 54 45 5f 44 45 42 55 47 0a 20 20 69 6e 74 20  ITE_DEBUG.  int 
1c20: 73 71 6c 69 74 65 33 50 61 67 65 72 52 65 66 63  sqlite3PagerRefc
1c30: 6f 75 6e 74 28 50 61 67 65 72 2a 29 3b 0a 23 65  ount(Pager*);.#e
1c40: 6e 64 69 66 0a 69 6e 74 20 73 71 6c 69 74 65 33  ndif.int sqlite3
1c50: 50 61 67 65 72 4d 65 6d 55 73 65 64 28 50 61 67  PagerMemUsed(Pag
1c60: 65 72 2a 29 3b 0a 63 6f 6e 73 74 20 63 68 61 72  er*);.const char
1c70: 20 2a 73 71 6c 69 74 65 33 50 61 67 65 72 46 69   *sqlite3PagerFi
1c80: 6c 65 6e 61 6d 65 28 50 61 67 65 72 2a 2c 20 69  lename(Pager*, i
1c90: 6e 74 29 3b 0a 73 71 6c 69 74 65 33 5f 76 66 73  nt);.sqlite3_vfs
1ca0: 20 2a 73 71 6c 69 74 65 33 50 61 67 65 72 56 66   *sqlite3PagerVf
1cb0: 73 28 50 61 67 65 72 2a 29 3b 0a 73 71 6c 69 74  s(Pager*);.sqlit
1cc0: 65 33 5f 66 69 6c 65 20 2a 73 71 6c 69 74 65 33  e3_file *sqlite3
1cd0: 50 61 67 65 72 46 69 6c 65 28 50 61 67 65 72 2a  PagerFile(Pager*
1ce0: 29 3b 0a 73 71 6c 69 74 65 33 5f 66 69 6c 65 20  );.sqlite3_file 
1cf0: 2a 73 71 6c 69 74 65 33 50 61 67 65 72 4a 72 6e  *sqlite3PagerJrn
1d00: 6c 46 69 6c 65 28 50 61 67 65 72 2a 29 3b 0a 63  lFile(Pager*);.c
1d10: 6f 6e 73 74 20 63 68 61 72 20 2a 73 71 6c 69 74  onst char *sqlit
1d20: 65 33 50 61 67 65 72 4a 6f 75 72 6e 61 6c 6e 61  e3PagerJournalna
1d30: 6d 65 28 50 61 67 65 72 2a 29 3b 0a 76 6f 69 64  me(Pager*);.void
1d40: 20 2a 73 71 6c 69 74 65 33 50 61 67 65 72 54 65   *sqlite3PagerTe
1d50: 6d 70 53 70 61 63 65 28 50 61 67 65 72 2a 29 3b  mpSpace(Pager*);
1d60: 0a 69 6e 74 20 73 71 6c 69 74 65 33 50 61 67 65  .int sqlite3Page
1d70: 72 49 73 4d 65 6d 64 62 28 50 61 67 65 72 2a 29  rIsMemdb(Pager*)
1d80: 3b 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 50 61  ;.void sqlite3Pa
1d90: 67 65 72 43 61 63 68 65 53 74 61 74 28 50 61 67  gerCacheStat(Pag
1da0: 65 72 20 2a 2c 20 69 6e 74 2c 20 69 6e 74 2c 20  er *, int, int, 
1db0: 69 6e 74 20 2a 29 3b 0a 69 6e 74 20 73 71 6c 69  int *);.int sqli
1dc0: 74 65 33 53 65 63 74 6f 72 53 69 7a 65 28 73 71  te3SectorSize(sq
1dd0: 6c 69 74 65 33 5f 66 69 6c 65 20 2a 29 3b 0a 0a  lite3_file *);..
1de0: 2f 2a 20 46 75 6e 63 74 69 6f 6e 73 20 75 73 65  /* Functions use
1df0: 64 20 74 6f 20 74 72 75 6e 63 61 74 65 20 74 68  d to truncate th
1e00: 65 20 64 61 74 61 62 61 73 65 20 66 69 6c 65 2e  e database file.
1e10: 20 2a 2f 0a 76 6f 69 64 20 73 71 6c 69 74 65 33   */.void sqlite3
1e20: 50 61 67 65 72 54 72 75 6e 63 61 74 65 49 6d 61  PagerTruncateIma
1e30: 67 65 28 50 61 67 65 72 2a 2c 50 67 6e 6f 29 3b  ge(Pager*,Pgno);
1e40: 0a 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 50 61  ..void sqlite3Pa
1e50: 67 65 72 52 65 6b 65 79 28 44 62 50 61 67 65 2a  gerRekey(DbPage*
1e60: 2c 20 50 67 6e 6f 2c 20 75 31 36 29 3b 0a 0a 23  , Pgno, u16);..#
1e70: 69 66 20 64 65 66 69 6e 65 64 28 53 51 4c 49 54  if defined(SQLIT
1e80: 45 5f 48 41 53 5f 43 4f 44 45 43 29 20 26 26 20  E_HAS_CODEC) && 
1e90: 21 64 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f  !defined(SQLITE_
1ea0: 4f 4d 49 54 5f 57 41 4c 29 0a 76 6f 69 64 20 2a  OMIT_WAL).void *
1eb0: 73 71 6c 69 74 65 33 50 61 67 65 72 43 6f 64 65  sqlite3PagerCode
1ec0: 63 28 44 62 50 61 67 65 20 2a 29 3b 0a 23 65 6e  c(DbPage *);.#en
1ed0: 64 69 66 0a 0a 2f 2a 20 46 75 6e 63 74 69 6f 6e  dif../* Function
1ee0: 73 20 74 6f 20 73 75 70 70 6f 72 74 20 74 65 73  s to support tes
1ef0: 74 69 6e 67 20 61 6e 64 20 64 65 62 75 67 67 69  ting and debuggi
1f00: 6e 67 2e 20 2a 2f 0a 23 69 66 20 21 64 65 66 69  ng. */.#if !defi
1f10: 6e 65 64 28 4e 44 45 42 55 47 29 20 7c 7c 20 64  ned(NDEBUG) || d
1f20: 65 66 69 6e 65 64 28 53 51 4c 49 54 45 5f 54 45  efined(SQLITE_TE
1f30: 53 54 29 0a 20 20 50 67 6e 6f 20 73 71 6c 69 74  ST).  Pgno sqlit
1f40: 65 33 50 61 67 65 72 50 61 67 65 6e 75 6d 62 65  e3PagerPagenumbe
1f50: 72 28 44 62 50 61 67 65 2a 29 3b 0a 20 20 69 6e  r(DbPage*);.  in
1f60: 74 20 73 71 6c 69 74 65 33 50 61 67 65 72 49 73  t sqlite3PagerIs
1f70: 77 72 69 74 65 61 62 6c 65 28 44 62 50 61 67 65  writeable(DbPage
1f80: 2a 29 3b 0a 23 65 6e 64 69 66 0a 23 69 66 64 65  *);.#endif.#ifde
1f90: 66 20 53 51 4c 49 54 45 5f 54 45 53 54 0a 20 20  f SQLITE_TEST.  
1fa0: 69 6e 74 20 2a 73 71 6c 69 74 65 33 50 61 67 65  int *sqlite3Page
1fb0: 72 53 74 61 74 73 28 50 61 67 65 72 2a 29 3b 0a  rStats(Pager*);.
1fc0: 20 20 76 6f 69 64 20 73 71 6c 69 74 65 33 50 61    void sqlite3Pa
1fd0: 67 65 72 52 65 66 64 75 6d 70 28 50 61 67 65 72  gerRefdump(Pager
1fe0: 2a 29 3b 0a 20 20 76 6f 69 64 20 64 69 73 61 62  *);.  void disab
1ff0: 6c 65 5f 73 69 6d 75 6c 61 74 65 64 5f 69 6f 5f  le_simulated_io_
2000: 65 72 72 6f 72 73 28 76 6f 69 64 29 3b 0a 20 20  errors(void);.  
2010: 76 6f 69 64 20 65 6e 61 62 6c 65 5f 73 69 6d 75  void enable_simu
2020: 6c 61 74 65 64 5f 69 6f 5f 65 72 72 6f 72 73 28  lated_io_errors(
2030: 76 6f 69 64 29 3b 0a 23 65 6c 73 65 0a 23 20 64  void);.#else.# d
2040: 65 66 69 6e 65 20 64 69 73 61 62 6c 65 5f 73 69  efine disable_si
2050: 6d 75 6c 61 74 65 64 5f 69 6f 5f 65 72 72 6f 72  mulated_io_error
2060: 73 28 29 0a 23 20 64 65 66 69 6e 65 20 65 6e 61  s().# define ena
2070: 62 6c 65 5f 73 69 6d 75 6c 61 74 65 64 5f 69 6f  ble_simulated_io
2080: 5f 65 72 72 6f 72 73 28 29 0a 23 65 6e 64 69 66  _errors().#endif
2090: 0a 0a 23 65 6e 64 69 66 20 2f 2a 20 53 51 4c 49  ..#endif /* SQLI
20a0: 54 45 5f 50 41 47 45 52 5f 48 20 2a 2f 0a        TE_PAGER_H */.