/ Hex Artifact Content
Login

Artifact 9f81b08efb06db4ba8be69446e10b005c351373d:


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 5f 50 41 47 45 52 5f 48 5f 0a 23 64 65 66 69   _PAGER_H_.#defi
0250: 6e 65 20 5f 50 41 47 45 52 5f 48 5f 0a 0a 2f 2a  ne _PAGER_H_../*
0260: 0a 2a 2a 20 44 65 66 61 75 6c 74 20 6d 61 78 69  .** Default maxi
0270: 6d 75 6d 20 73 69 7a 65 20 66 6f 72 20 70 65 72  mum size for per
0280: 73 69 73 74 65 6e 74 20 6a 6f 75 72 6e 61 6c 20  sistent journal 
0290: 66 69 6c 65 73 2e 20 41 20 6e 65 67 61 74 69 76  files. A negativ
02a0: 65 20 0a 2a 2a 20 76 61 6c 75 65 20 6d 65 61 6e  e .** value mean
02b0: 73 20 6e 6f 20 6c 69 6d 69 74 2e 20 54 68 69 73  s no limit. This
02c0: 20 76 61 6c 75 65 20 6d 61 79 20 62 65 20 6f 76   value may be ov
02d0: 65 72 72 69 64 64 65 6e 20 75 73 69 6e 67 20 74  erridden using t
02e0: 68 65 20 0a 2a 2a 20 73 71 6c 69 74 65 33 50 61  he .** sqlite3Pa
02f0: 67 65 72 4a 6f 75 72 6e 61 6c 53 69 7a 65 4c 69  gerJournalSizeLi
0300: 6d 69 74 28 29 20 41 50 49 2e 20 53 65 65 20 61  mit() API. See a
0310: 6c 73 6f 20 22 50 52 41 47 4d 41 20 6a 6f 75 72  lso "PRAGMA jour
0320: 6e 61 6c 5f 73 69 7a 65 5f 6c 69 6d 69 74 22 2e  nal_size_limit".
0330: 0a 2a 2f 0a 23 69 66 6e 64 65 66 20 53 51 4c 49  .*/.#ifndef SQLI
0340: 54 45 5f 44 45 46 41 55 4c 54 5f 4a 4f 55 52 4e  TE_DEFAULT_JOURN
0350: 41 4c 5f 53 49 5a 45 5f 4c 49 4d 49 54 0a 20 20  AL_SIZE_LIMIT.  
0360: 23 64 65 66 69 6e 65 20 53 51 4c 49 54 45 5f 44  #define SQLITE_D
0370: 45 46 41 55 4c 54 5f 4a 4f 55 52 4e 41 4c 5f 53  EFAULT_JOURNAL_S
0380: 49 5a 45 5f 4c 49 4d 49 54 20 2d 31 0a 23 65 6e  IZE_LIMIT -1.#en
0390: 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 74  dif../*.** The t
03a0: 79 70 65 20 75 73 65 64 20 74 6f 20 72 65 70 72  ype used to repr
03b0: 65 73 65 6e 74 20 61 20 70 61 67 65 20 6e 75 6d  esent a page num
03c0: 62 65 72 2e 20 20 54 68 65 20 66 69 72 73 74 20  ber.  The first 
03d0: 70 61 67 65 20 69 6e 20 61 20 66 69 6c 65 0a 2a  page in a file.*
03e0: 2a 20 69 73 20 63 61 6c 6c 65 64 20 70 61 67 65  * is called page
03f0: 20 31 2e 20 20 30 20 69 73 20 75 73 65 64 20 74   1.  0 is used t
0400: 6f 20 72 65 70 72 65 73 65 6e 74 20 22 6e 6f 74  o represent "not
0410: 20 61 20 70 61 67 65 22 2e 0a 2a 2f 0a 74 79 70   a page"..*/.typ
0420: 65 64 65 66 20 75 33 32 20 50 67 6e 6f 3b 0a 0a  edef u32 Pgno;..
0430: 2f 2a 0a 2a 2a 20 45 61 63 68 20 6f 70 65 6e 20  /*.** Each open 
0440: 66 69 6c 65 20 69 73 20 6d 61 6e 61 67 65 64 20  file is managed 
0450: 62 79 20 61 20 73 65 70 61 72 61 74 65 20 69 6e  by a separate in
0460: 73 74 61 6e 63 65 20 6f 66 20 74 68 65 20 22 50  stance of the "P
0470: 61 67 65 72 22 20 73 74 72 75 63 74 75 72 65 2e  ager" structure.
0480: 0a 2a 2f 0a 74 79 70 65 64 65 66 20 73 74 72 75  .*/.typedef stru
0490: 63 74 20 50 61 67 65 72 20 50 61 67 65 72 3b 0a  ct Pager Pager;.
04a0: 0a 2f 2a 0a 2a 2a 20 48 61 6e 64 6c 65 20 74 79  ./*.** Handle ty
04b0: 70 65 20 66 6f 72 20 70 61 67 65 73 2e 0a 2a 2f  pe for pages..*/
04c0: 0a 74 79 70 65 64 65 66 20 73 74 72 75 63 74 20  .typedef struct 
04d0: 50 67 48 64 72 20 44 62 50 61 67 65 3b 0a 0a 2f  PgHdr DbPage;../
04e0: 2a 0a 2a 2a 20 50 61 67 65 20 6e 75 6d 62 65 72  *.** Page number
04f0: 20 50 41 47 45 52 5f 4d 4a 5f 50 47 4e 4f 20 69   PAGER_MJ_PGNO i
0500: 73 20 6e 65 76 65 72 20 75 73 65 64 20 69 6e 20  s never used in 
0510: 61 6e 20 53 51 4c 69 74 65 20 64 61 74 61 62 61  an SQLite databa
0520: 73 65 20 28 69 74 20 69 73 0a 2a 2a 20 72 65 73  se (it is.** res
0530: 65 72 76 65 64 20 66 6f 72 20 77 6f 72 6b 69 6e  erved for workin
0540: 67 20 61 72 6f 75 6e 64 20 61 20 77 69 6e 64 6f  g around a windo
0550: 77 73 2f 70 6f 73 69 78 20 69 6e 63 6f 6d 70 61  ws/posix incompa
0560: 74 69 62 69 6c 69 74 79 29 2e 20 49 74 20 69 73  tibility). It is
0570: 0a 2a 2a 20 75 73 65 64 20 69 6e 20 74 68 65 20  .** used in the 
0580: 6a 6f 75 72 6e 61 6c 20 74 6f 20 73 69 67 6e 69  journal to signi
0590: 66 79 20 74 68 61 74 20 74 68 65 20 72 65 6d 61  fy that the rema
05a0: 69 6e 64 65 72 20 6f 66 20 74 68 65 20 6a 6f 75  inder of the jou
05b0: 72 6e 61 6c 20 66 69 6c 65 20 0a 2a 2a 20 69 73  rnal file .** is
05c0: 20 64 65 76 6f 74 65 64 20 74 6f 20 73 74 6f 72   devoted to stor
05d0: 69 6e 67 20 61 20 6d 61 73 74 65 72 20 6a 6f 75  ing a master jou
05e0: 72 6e 61 6c 20 6e 61 6d 65 20 2d 20 74 68 65 72  rnal name - ther
05f0: 65 20 61 72 65 20 6e 6f 20 6d 6f 72 65 20 70 61  e are no more pa
0600: 67 65 73 20 74 6f 0a 2a 2a 20 72 6f 6c 6c 20 62  ges to.** roll b
0610: 61 63 6b 2e 20 53 65 65 20 63 6f 6d 6d 65 6e 74  ack. See comment
0620: 73 20 66 6f 72 20 66 75 6e 63 74 69 6f 6e 20 77  s for function w
0630: 72 69 74 65 4d 61 73 74 65 72 4a 6f 75 72 6e 61  riteMasterJourna
0640: 6c 28 29 20 69 6e 20 70 61 67 65 72 2e 63 20 0a  l() in pager.c .
0650: 2a 2a 20 66 6f 72 20 64 65 74 61 69 6c 73 2e 0a  ** for details..
0660: 2a 2f 0a 23 64 65 66 69 6e 65 20 50 41 47 45 52  */.#define PAGER
0670: 5f 4d 4a 5f 50 47 4e 4f 28 78 29 20 28 28 50 67  _MJ_PGNO(x) ((Pg
0680: 6e 6f 29 28 28 50 45 4e 44 49 4e 47 5f 42 59 54  no)((PENDING_BYT
0690: 45 2f 28 28 78 29 2d 3e 70 61 67 65 53 69 7a 65  E/((x)->pageSize
06a0: 29 29 2b 31 29 29 0a 0a 2f 2a 0a 2a 2a 20 41 6c  ))+1))../*.** Al
06b0: 6c 6f 77 65 64 20 76 61 6c 75 65 73 20 66 6f 72  lowed values for
06c0: 20 74 68 65 20 66 6c 61 67 73 20 70 61 72 61 6d   the flags param
06d0: 65 74 65 72 20 74 6f 20 73 71 6c 69 74 65 33 50  eter to sqlite3P
06e0: 61 67 65 72 4f 70 65 6e 28 29 2e 0a 2a 2a 0a 2a  agerOpen()..**.*
06f0: 2a 20 4e 4f 54 45 3a 20 54 68 65 73 65 20 76 61  * NOTE: These va
0700: 6c 75 65 73 20 6d 75 73 74 20 6d 61 74 63 68 20  lues must match 
0710: 74 68 65 20 63 6f 72 72 65 73 70 6f 6e 64 69 6e  the correspondin
0720: 67 20 42 54 52 45 45 5f 20 76 61 6c 75 65 73 20  g BTREE_ values 
0730: 69 6e 20 62 74 72 65 65 2e 68 2e 0a 2a 2f 0a 23  in btree.h..*/.#
0740: 64 65 66 69 6e 65 20 50 41 47 45 52 5f 4f 4d 49  define PAGER_OMI
0750: 54 5f 4a 4f 55 52 4e 41 4c 20 20 30 78 30 30 30  T_JOURNAL  0x000
0760: 31 20 20 20 20 2f 2a 20 44 6f 20 6e 6f 74 20 75  1    /* Do not u
0770: 73 65 20 61 20 72 6f 6c 6c 62 61 63 6b 20 6a 6f  se a rollback jo
0780: 75 72 6e 61 6c 20 2a 2f 0a 23 64 65 66 69 6e 65  urnal */.#define
0790: 20 50 41 47 45 52 5f 4e 4f 5f 52 45 41 44 4c 4f   PAGER_NO_READLO
07a0: 43 4b 20 20 20 30 78 30 30 30 32 20 20 20 20 2f  CK   0x0002    /
07b0: 2a 20 4f 6d 69 74 20 72 65 61 64 6c 6f 63 6b 73  * Omit readlocks
07c0: 20 6f 6e 20 72 65 61 64 6f 6e 6c 79 20 66 69 6c   on readonly fil
07d0: 65 73 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50 41  es */.#define PA
07e0: 47 45 52 5f 4d 45 4d 4f 52 59 20 20 20 20 20 20  GER_MEMORY      
07f0: 20 20 30 78 30 30 30 34 20 20 20 20 2f 2a 20 49    0x0004    /* I
0800: 6e 2d 6d 65 6d 6f 72 79 20 64 61 74 61 62 61 73  n-memory databas
0810: 65 20 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 56 61 6c 69  e */../*.** Vali
0820: 64 20 76 61 6c 75 65 73 20 66 6f 72 20 74 68 65  d values for the
0830: 20 73 65 63 6f 6e 64 20 61 72 67 75 6d 65 6e 74   second argument
0840: 20 74 6f 20 73 71 6c 69 74 65 33 50 61 67 65 72   to sqlite3Pager
0850: 4c 6f 63 6b 69 6e 67 4d 6f 64 65 28 29 2e 0a 2a  LockingMode()..*
0860: 2f 0a 23 64 65 66 69 6e 65 20 50 41 47 45 52 5f  /.#define PAGER_
0870: 4c 4f 43 4b 49 4e 47 4d 4f 44 45 5f 51 55 45 52  LOCKINGMODE_QUER
0880: 59 20 20 20 20 20 20 2d 31 0a 23 64 65 66 69 6e  Y      -1.#defin
0890: 65 20 50 41 47 45 52 5f 4c 4f 43 4b 49 4e 47 4d  e PAGER_LOCKINGM
08a0: 4f 44 45 5f 4e 4f 52 4d 41 4c 20 20 20 20 20 20  ODE_NORMAL      
08b0: 30 0a 23 64 65 66 69 6e 65 20 50 41 47 45 52 5f  0.#define PAGER_
08c0: 4c 4f 43 4b 49 4e 47 4d 4f 44 45 5f 45 58 43 4c  LOCKINGMODE_EXCL
08d0: 55 53 49 56 45 20 20 20 31 0a 0a 2f 2a 0a 2a 2a  USIVE   1../*.**
08e0: 20 4e 75 6d 65 72 69 63 20 63 6f 6e 73 74 61 6e   Numeric constan
08f0: 74 73 20 74 68 61 74 20 65 6e 63 6f 64 65 20 74  ts that encode t
0900: 68 65 20 6a 6f 75 72 6e 61 6c 6d 6f 64 65 2e 20  he journalmode. 
0910: 20 0a 2a 2f 0a 23 64 65 66 69 6e 65 20 50 41 47   .*/.#define PAG
0920: 45 52 5f 4a 4f 55 52 4e 41 4c 4d 4f 44 45 5f 51  ER_JOURNALMODE_Q
0930: 55 45 52 59 20 20 20 20 20 28 2d 31 29 20 20 2f  UERY     (-1)  /
0940: 2a 20 51 75 65 72 79 20 74 68 65 20 76 61 6c 75  * Query the valu
0950: 65 20 6f 66 20 6a 6f 75 72 6e 61 6c 6d 6f 64 65  e of journalmode
0960: 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50 41 47 45   */.#define PAGE
0970: 52 5f 4a 4f 55 52 4e 41 4c 4d 4f 44 45 5f 44 45  R_JOURNALMODE_DE
0980: 4c 45 54 45 20 20 20 20 20 20 30 20 20 20 2f 2a  LETE      0   /*
0990: 20 43 6f 6d 6d 69 74 20 62 79 20 64 65 6c 65 74   Commit by delet
09a0: 69 6e 67 20 6a 6f 75 72 6e 61 6c 20 66 69 6c 65  ing journal file
09b0: 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50 41 47 45   */.#define PAGE
09c0: 52 5f 4a 4f 55 52 4e 41 4c 4d 4f 44 45 5f 50 45  R_JOURNALMODE_PE
09d0: 52 53 49 53 54 20 20 20 20 20 31 20 20 20 2f 2a  RSIST     1   /*
09e0: 20 43 6f 6d 6d 69 74 20 62 79 20 7a 65 72 6f 69   Commit by zeroi
09f0: 6e 67 20 6a 6f 75 72 6e 61 6c 20 68 65 61 64 65  ng journal heade
0a00: 72 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50 41 47  r */.#define PAG
0a10: 45 52 5f 4a 4f 55 52 4e 41 4c 4d 4f 44 45 5f 4f  ER_JOURNALMODE_O
0a20: 46 46 20 20 20 20 20 20 20 20 20 32 20 20 20 2f  FF         2   /
0a30: 2a 20 4a 6f 75 72 6e 61 6c 20 6f 6d 69 74 74 65  * Journal omitte
0a40: 64 2e 20 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50  d.  */.#define P
0a50: 41 47 45 52 5f 4a 4f 55 52 4e 41 4c 4d 4f 44 45  AGER_JOURNALMODE
0a60: 5f 54 52 55 4e 43 41 54 45 20 20 20 20 33 20 20  _TRUNCATE    3  
0a70: 20 2f 2a 20 43 6f 6d 6d 69 74 20 62 79 20 74 72   /* Commit by tr
0a80: 75 6e 63 61 74 69 6e 67 20 6a 6f 75 72 6e 61 6c  uncating journal
0a90: 20 2a 2f 0a 23 64 65 66 69 6e 65 20 50 41 47 45   */.#define PAGE
0aa0: 52 5f 4a 4f 55 52 4e 41 4c 4d 4f 44 45 5f 4d 45  R_JOURNALMODE_ME
0ab0: 4d 4f 52 59 20 20 20 20 20 20 34 20 20 20 2f 2a  MORY      4   /*
0ac0: 20 49 6e 2d 6d 65 6d 6f 72 79 20 6a 6f 75 72 6e   In-memory journ
0ad0: 61 6c 20 66 69 6c 65 20 2a 2f 0a 23 64 65 66 69  al file */.#defi
0ae0: 6e 65 20 50 41 47 45 52 5f 4a 4f 55 52 4e 41 4c  ne PAGER_JOURNAL
0af0: 4d 4f 44 45 5f 57 41 4c 20 20 20 20 20 20 20 20  MODE_WAL        
0b00: 20 35 20 20 20 2f 2a 20 55 73 65 20 77 72 69 74   5   /* Use writ
0b10: 65 2d 61 68 65 61 64 20 6c 6f 67 67 69 6e 67 20  e-ahead logging 
0b20: 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 54 68 65 20 72 65  */../*.** The re
0b30: 6d 61 69 6e 64 65 72 20 6f 66 20 74 68 69 73 20  mainder of this 
0b40: 66 69 6c 65 20 63 6f 6e 74 61 69 6e 73 20 74 68  file contains th
0b50: 65 20 64 65 63 6c 61 72 61 74 69 6f 6e 73 20 6f  e declarations o
0b60: 66 20 74 68 65 20 66 75 6e 63 74 69 6f 6e 73 0a  f the functions.
0b70: 2a 2a 20 74 68 61 74 20 6d 61 6b 65 20 75 70 20  ** that make up 
0b80: 74 68 65 20 50 61 67 65 72 20 73 75 62 2d 73 79  the Pager sub-sy
0b90: 73 74 65 6d 20 41 50 49 2e 20 53 65 65 20 73 6f  stem API. See so
0ba0: 75 72 63 65 20 63 6f 64 65 20 63 6f 6d 6d 65 6e  urce code commen
0bb0: 74 73 20 66 6f 72 20 0a 2a 2a 20 61 20 64 65 74  ts for .** a det
0bc0: 61 69 6c 65 64 20 64 65 73 63 72 69 70 74 69 6f  ailed descriptio
0bd0: 6e 20 6f 66 20 65 61 63 68 20 72 6f 75 74 69 6e  n of each routin
0be0: 65 2e 0a 2a 2f 0a 0a 2f 2a 20 4f 70 65 6e 20 61  e..*/../* Open a
0bf0: 6e 64 20 63 6c 6f 73 65 20 61 20 50 61 67 65 72  nd close a Pager
0c00: 20 63 6f 6e 6e 65 63 74 69 6f 6e 2e 20 2a 2f 20   connection. */ 
0c10: 0a 69 6e 74 20 73 71 6c 69 74 65 33 50 61 67 65  .int sqlite3Page
0c20: 72 4f 70 65 6e 28 0a 20 20 73 71 6c 69 74 65 33  rOpen(.  sqlite3
0c30: 5f 76 66 73 2a 2c 0a 20 20 50 61 67 65 72 20 2a  _vfs*,.  Pager *
0c40: 2a 70 70 50 61 67 65 72 2c 0a 20 20 63 6f 6e 73  *ppPager,.  cons
0c50: 74 20 63 68 61 72 2a 2c 0a 20 20 69 6e 74 2c 0a  t char*,.  int,.
0c60: 20 20 69 6e 74 2c 0a 20 20 69 6e 74 2c 0a 20 20    int,.  int,.  
0c70: 76 6f 69 64 28 2a 29 28 44 62 50 61 67 65 2a 29  void(*)(DbPage*)
0c80: 0a 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 50  .);.int sqlite3P
0c90: 61 67 65 72 43 6c 6f 73 65 28 50 61 67 65 72 20  agerClose(Pager 
0ca0: 2a 70 50 61 67 65 72 29 3b 0a 69 6e 74 20 73 71  *pPager);.int sq
0cb0: 6c 69 74 65 33 50 61 67 65 72 52 65 61 64 46 69  lite3PagerReadFi
0cc0: 6c 65 68 65 61 64 65 72 28 50 61 67 65 72 2a 2c  leheader(Pager*,
0cd0: 20 69 6e 74 2c 20 75 6e 73 69 67 6e 65 64 20 63   int, unsigned c
0ce0: 68 61 72 2a 29 3b 0a 0a 2f 2a 20 46 75 6e 63 74  har*);../* Funct
0cf0: 69 6f 6e 73 20 75 73 65 64 20 74 6f 20 63 6f 6e  ions used to con
0d00: 66 69 67 75 72 65 20 61 20 50 61 67 65 72 20 6f  figure a Pager o
0d10: 62 6a 65 63 74 2e 20 2a 2f 0a 76 6f 69 64 20 73  bject. */.void s
0d20: 71 6c 69 74 65 33 50 61 67 65 72 53 65 74 42 75  qlite3PagerSetBu
0d30: 73 79 68 61 6e 64 6c 65 72 28 50 61 67 65 72 2a  syhandler(Pager*
0d40: 2c 20 69 6e 74 28 2a 29 28 76 6f 69 64 20 2a 29  , int(*)(void *)
0d50: 2c 20 76 6f 69 64 20 2a 29 3b 0a 69 6e 74 20 73  , void *);.int s
0d60: 71 6c 69 74 65 33 50 61 67 65 72 53 65 74 50 61  qlite3PagerSetPa
0d70: 67 65 73 69 7a 65 28 50 61 67 65 72 2a 2c 20 75  gesize(Pager*, u
0d80: 33 32 2a 2c 20 69 6e 74 29 3b 0a 69 6e 74 20 73  32*, int);.int s
0d90: 71 6c 69 74 65 33 50 61 67 65 72 4d 61 78 50 61  qlite3PagerMaxPa
0da0: 67 65 43 6f 75 6e 74 28 50 61 67 65 72 2a 2c 20  geCount(Pager*, 
0db0: 69 6e 74 29 3b 0a 76 6f 69 64 20 73 71 6c 69 74  int);.void sqlit
0dc0: 65 33 50 61 67 65 72 53 65 74 43 61 63 68 65 73  e3PagerSetCaches
0dd0: 69 7a 65 28 50 61 67 65 72 2a 2c 20 69 6e 74 29  ize(Pager*, int)
0de0: 3b 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 50 61  ;.void sqlite3Pa
0df0: 67 65 72 53 65 74 53 61 66 65 74 79 4c 65 76 65  gerSetSafetyLeve
0e00: 6c 28 50 61 67 65 72 2a 2c 69 6e 74 2c 69 6e 74  l(Pager*,int,int
0e10: 2c 69 6e 74 29 3b 0a 69 6e 74 20 73 71 6c 69 74  ,int);.int sqlit
0e20: 65 33 50 61 67 65 72 4c 6f 63 6b 69 6e 67 4d 6f  e3PagerLockingMo
0e30: 64 65 28 50 61 67 65 72 20 2a 2c 20 69 6e 74 29  de(Pager *, int)
0e40: 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 50 61 67  ;.int sqlite3Pag
0e50: 65 72 53 65 74 4a 6f 75 72 6e 61 6c 4d 6f 64 65  erSetJournalMode
0e60: 28 50 61 67 65 72 20 2a 2c 20 69 6e 74 29 3b 0a  (Pager *, int);.
0e70: 69 6e 74 20 73 71 6c 69 74 65 33 50 61 67 65 72  int sqlite3Pager
0e80: 47 65 74 4a 6f 75 72 6e 61 6c 4d 6f 64 65 28 50  GetJournalMode(P
0e90: 61 67 65 72 2a 29 3b 0a 69 6e 74 20 73 71 6c 69  ager*);.int sqli
0ea0: 74 65 33 50 61 67 65 72 4f 6b 54 6f 43 68 61 6e  te3PagerOkToChan
0eb0: 67 65 4a 6f 75 72 6e 61 6c 4d 6f 64 65 28 50 61  geJournalMode(Pa
0ec0: 67 65 72 2a 29 3b 0a 69 36 34 20 73 71 6c 69 74  ger*);.i64 sqlit
0ed0: 65 33 50 61 67 65 72 4a 6f 75 72 6e 61 6c 53 69  e3PagerJournalSi
0ee0: 7a 65 4c 69 6d 69 74 28 50 61 67 65 72 20 2a 2c  zeLimit(Pager *,
0ef0: 20 69 36 34 29 3b 0a 73 71 6c 69 74 65 33 5f 62   i64);.sqlite3_b
0f00: 61 63 6b 75 70 20 2a 2a 73 71 6c 69 74 65 33 50  ackup **sqlite3P
0f10: 61 67 65 72 42 61 63 6b 75 70 50 74 72 28 50 61  agerBackupPtr(Pa
0f20: 67 65 72 2a 29 3b 0a 0a 2f 2a 20 46 75 6e 63 74  ger*);../* Funct
0f30: 69 6f 6e 73 20 75 73 65 64 20 74 6f 20 6f 62 74  ions used to obt
0f40: 61 69 6e 20 61 6e 64 20 72 65 6c 65 61 73 65 20  ain and release 
0f50: 70 61 67 65 20 72 65 66 65 72 65 6e 63 65 73 2e  page references.
0f60: 20 2a 2f 20 0a 69 6e 74 20 73 71 6c 69 74 65 33   */ .int sqlite3
0f70: 50 61 67 65 72 41 63 71 75 69 72 65 28 50 61 67  PagerAcquire(Pag
0f80: 65 72 20 2a 70 50 61 67 65 72 2c 20 50 67 6e 6f  er *pPager, Pgno
0f90: 20 70 67 6e 6f 2c 20 44 62 50 61 67 65 20 2a 2a   pgno, DbPage **
0fa0: 70 70 50 61 67 65 2c 20 69 6e 74 20 63 6c 72 46  ppPage, int clrF
0fb0: 6c 61 67 29 3b 0a 23 64 65 66 69 6e 65 20 73 71  lag);.#define sq
0fc0: 6c 69 74 65 33 50 61 67 65 72 47 65 74 28 41 2c  lite3PagerGet(A,
0fd0: 42 2c 43 29 20 73 71 6c 69 74 65 33 50 61 67 65  B,C) sqlite3Page
0fe0: 72 41 63 71 75 69 72 65 28 41 2c 42 2c 43 2c 30  rAcquire(A,B,C,0
0ff0: 29 0a 44 62 50 61 67 65 20 2a 73 71 6c 69 74 65  ).DbPage *sqlite
1000: 33 50 61 67 65 72 4c 6f 6f 6b 75 70 28 50 61 67  3PagerLookup(Pag
1010: 65 72 20 2a 70 50 61 67 65 72 2c 20 50 67 6e 6f  er *pPager, Pgno
1020: 20 70 67 6e 6f 29 3b 0a 76 6f 69 64 20 73 71 6c   pgno);.void sql
1030: 69 74 65 33 50 61 67 65 72 52 65 66 28 44 62 50  ite3PagerRef(DbP
1040: 61 67 65 2a 29 3b 0a 76 6f 69 64 20 73 71 6c 69  age*);.void sqli
1050: 74 65 33 50 61 67 65 72 55 6e 72 65 66 28 44 62  te3PagerUnref(Db
1060: 50 61 67 65 2a 29 3b 0a 0a 2f 2a 20 4f 70 65 72  Page*);../* Oper
1070: 61 74 69 6f 6e 73 20 6f 6e 20 70 61 67 65 20 72  ations on page r
1080: 65 66 65 72 65 6e 63 65 73 2e 20 2a 2f 0a 69 6e  eferences. */.in
1090: 74 20 73 71 6c 69 74 65 33 50 61 67 65 72 57 72  t sqlite3PagerWr
10a0: 69 74 65 28 44 62 50 61 67 65 2a 29 3b 0a 76 6f  ite(DbPage*);.vo
10b0: 69 64 20 73 71 6c 69 74 65 33 50 61 67 65 72 44  id sqlite3PagerD
10c0: 6f 6e 74 57 72 69 74 65 28 44 62 50 61 67 65 2a  ontWrite(DbPage*
10d0: 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 50 61  );.int sqlite3Pa
10e0: 67 65 72 4d 6f 76 65 70 61 67 65 28 50 61 67 65  gerMovepage(Page
10f0: 72 2a 2c 44 62 50 61 67 65 2a 2c 50 67 6e 6f 2c  r*,DbPage*,Pgno,
1100: 69 6e 74 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65  int);.int sqlite
1110: 33 50 61 67 65 72 50 61 67 65 52 65 66 63 6f 75  3PagerPageRefcou
1120: 6e 74 28 44 62 50 61 67 65 2a 29 3b 0a 76 6f 69  nt(DbPage*);.voi
1130: 64 20 2a 73 71 6c 69 74 65 33 50 61 67 65 72 47  d *sqlite3PagerG
1140: 65 74 44 61 74 61 28 44 62 50 61 67 65 20 2a 29  etData(DbPage *)
1150: 3b 20 0a 76 6f 69 64 20 2a 73 71 6c 69 74 65 33  ; .void *sqlite3
1160: 50 61 67 65 72 47 65 74 45 78 74 72 61 28 44 62  PagerGetExtra(Db
1170: 50 61 67 65 20 2a 29 3b 20 0a 0a 2f 2a 20 46 75  Page *); ../* Fu
1180: 6e 63 74 69 6f 6e 73 20 75 73 65 64 20 74 6f 20  nctions used to 
1190: 6d 61 6e 61 67 65 20 70 61 67 65 72 20 74 72 61  manage pager tra
11a0: 6e 73 61 63 74 69 6f 6e 73 20 61 6e 64 20 73 61  nsactions and sa
11b0: 76 65 70 6f 69 6e 74 73 2e 20 2a 2f 0a 76 6f 69  vepoints. */.voi
11c0: 64 20 73 71 6c 69 74 65 33 50 61 67 65 72 50 61  d sqlite3PagerPa
11d0: 67 65 63 6f 75 6e 74 28 50 61 67 65 72 2a 2c 20  gecount(Pager*, 
11e0: 69 6e 74 2a 29 3b 0a 69 6e 74 20 73 71 6c 69 74  int*);.int sqlit
11f0: 65 33 50 61 67 65 72 42 65 67 69 6e 28 50 61 67  e3PagerBegin(Pag
1200: 65 72 2a 2c 20 69 6e 74 20 65 78 46 6c 61 67 2c  er*, int exFlag,
1210: 20 69 6e 74 29 3b 0a 69 6e 74 20 73 71 6c 69 74   int);.int sqlit
1220: 65 33 50 61 67 65 72 43 6f 6d 6d 69 74 50 68 61  e3PagerCommitPha
1230: 73 65 4f 6e 65 28 50 61 67 65 72 2a 2c 63 6f 6e  seOne(Pager*,con
1240: 73 74 20 63 68 61 72 20 2a 7a 4d 61 73 74 65 72  st char *zMaster
1250: 2c 20 69 6e 74 29 3b 0a 69 6e 74 20 73 71 6c 69  , int);.int sqli
1260: 74 65 33 50 61 67 65 72 45 78 63 6c 75 73 69 76  te3PagerExclusiv
1270: 65 4c 6f 63 6b 28 50 61 67 65 72 2a 29 3b 0a 69  eLock(Pager*);.i
1280: 6e 74 20 73 71 6c 69 74 65 33 50 61 67 65 72 53  nt sqlite3PagerS
1290: 79 6e 63 28 50 61 67 65 72 20 2a 70 50 61 67 65  ync(Pager *pPage
12a0: 72 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 50  r);.int sqlite3P
12b0: 61 67 65 72 43 6f 6d 6d 69 74 50 68 61 73 65 54  agerCommitPhaseT
12c0: 77 6f 28 50 61 67 65 72 2a 29 3b 0a 69 6e 74 20  wo(Pager*);.int 
12d0: 73 71 6c 69 74 65 33 50 61 67 65 72 52 6f 6c 6c  sqlite3PagerRoll
12e0: 62 61 63 6b 28 50 61 67 65 72 2a 29 3b 0a 69 6e  back(Pager*);.in
12f0: 74 20 73 71 6c 69 74 65 33 50 61 67 65 72 4f 70  t sqlite3PagerOp
1300: 65 6e 53 61 76 65 70 6f 69 6e 74 28 50 61 67 65  enSavepoint(Page
1310: 72 20 2a 70 50 61 67 65 72 2c 20 69 6e 74 20 6e  r *pPager, int n
1320: 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 50 61  );.int sqlite3Pa
1330: 67 65 72 53 61 76 65 70 6f 69 6e 74 28 50 61 67  gerSavepoint(Pag
1340: 65 72 20 2a 70 50 61 67 65 72 2c 20 69 6e 74 20  er *pPager, int 
1350: 6f 70 2c 20 69 6e 74 20 69 53 61 76 65 70 6f 69  op, int iSavepoi
1360: 6e 74 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33  nt);.int sqlite3
1370: 50 61 67 65 72 53 68 61 72 65 64 4c 6f 63 6b 28  PagerSharedLock(
1380: 50 61 67 65 72 20 2a 70 50 61 67 65 72 29 3b 0a  Pager *pPager);.
1390: 0a 69 6e 74 20 73 71 6c 69 74 65 33 50 61 67 65  .int sqlite3Page
13a0: 72 43 68 65 63 6b 70 6f 69 6e 74 28 50 61 67 65  rCheckpoint(Page
13b0: 72 20 2a 70 50 61 67 65 72 2c 20 69 6e 74 2c 20  r *pPager, int, 
13c0: 69 6e 74 2a 2c 20 69 6e 74 2a 29 3b 0a 69 6e 74  int*, int*);.int
13d0: 20 73 71 6c 69 74 65 33 50 61 67 65 72 57 61 6c   sqlite3PagerWal
13e0: 53 75 70 70 6f 72 74 65 64 28 50 61 67 65 72 20  Supported(Pager 
13f0: 2a 70 50 61 67 65 72 29 3b 0a 69 6e 74 20 73 71  *pPager);.int sq
1400: 6c 69 74 65 33 50 61 67 65 72 57 61 6c 43 61 6c  lite3PagerWalCal
1410: 6c 62 61 63 6b 28 50 61 67 65 72 20 2a 70 50 61  lback(Pager *pPa
1420: 67 65 72 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65  ger);.int sqlite
1430: 33 50 61 67 65 72 4f 70 65 6e 57 61 6c 28 50 61  3PagerOpenWal(Pa
1440: 67 65 72 20 2a 70 50 61 67 65 72 2c 20 69 6e 74  ger *pPager, int
1450: 20 2a 70 69 73 4f 70 65 6e 29 3b 0a 69 6e 74 20   *pisOpen);.int 
1460: 73 71 6c 69 74 65 33 50 61 67 65 72 43 6c 6f 73  sqlite3PagerClos
1470: 65 57 61 6c 28 50 61 67 65 72 20 2a 70 50 61 67  eWal(Pager *pPag
1480: 65 72 29 3b 0a 0a 2f 2a 20 46 75 6e 63 74 69 6f  er);../* Functio
1490: 6e 73 20 75 73 65 64 20 74 6f 20 71 75 65 72 79  ns used to query
14a0: 20 70 61 67 65 72 20 73 74 61 74 65 20 61 6e 64   pager state and
14b0: 20 63 6f 6e 66 69 67 75 72 61 74 69 6f 6e 2e 20   configuration. 
14c0: 2a 2f 0a 75 38 20 73 71 6c 69 74 65 33 50 61 67  */.u8 sqlite3Pag
14d0: 65 72 49 73 72 65 61 64 6f 6e 6c 79 28 50 61 67  erIsreadonly(Pag
14e0: 65 72 2a 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65  er*);.int sqlite
14f0: 33 50 61 67 65 72 52 65 66 63 6f 75 6e 74 28 50  3PagerRefcount(P
1500: 61 67 65 72 2a 29 3b 0a 69 6e 74 20 73 71 6c 69  ager*);.int sqli
1510: 74 65 33 50 61 67 65 72 4d 65 6d 55 73 65 64 28  te3PagerMemUsed(
1520: 50 61 67 65 72 2a 29 3b 0a 63 6f 6e 73 74 20 63  Pager*);.const c
1530: 68 61 72 20 2a 73 71 6c 69 74 65 33 50 61 67 65  har *sqlite3Page
1540: 72 46 69 6c 65 6e 61 6d 65 28 50 61 67 65 72 2a  rFilename(Pager*
1550: 29 3b 0a 63 6f 6e 73 74 20 73 71 6c 69 74 65 33  );.const sqlite3
1560: 5f 76 66 73 20 2a 73 71 6c 69 74 65 33 50 61 67  _vfs *sqlite3Pag
1570: 65 72 56 66 73 28 50 61 67 65 72 2a 29 3b 0a 73  erVfs(Pager*);.s
1580: 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 73 71 6c  qlite3_file *sql
1590: 69 74 65 33 50 61 67 65 72 46 69 6c 65 28 50 61  ite3PagerFile(Pa
15a0: 67 65 72 2a 29 3b 0a 63 6f 6e 73 74 20 63 68 61  ger*);.const cha
15b0: 72 20 2a 73 71 6c 69 74 65 33 50 61 67 65 72 4a  r *sqlite3PagerJ
15c0: 6f 75 72 6e 61 6c 6e 61 6d 65 28 50 61 67 65 72  ournalname(Pager
15d0: 2a 29 3b 0a 69 6e 74 20 73 71 6c 69 74 65 33 50  *);.int sqlite3P
15e0: 61 67 65 72 4e 6f 73 79 6e 63 28 50 61 67 65 72  agerNosync(Pager
15f0: 2a 29 3b 0a 76 6f 69 64 20 2a 73 71 6c 69 74 65  *);.void *sqlite
1600: 33 50 61 67 65 72 54 65 6d 70 53 70 61 63 65 28  3PagerTempSpace(
1610: 50 61 67 65 72 2a 29 3b 0a 69 6e 74 20 73 71 6c  Pager*);.int sql
1620: 69 74 65 33 50 61 67 65 72 49 73 4d 65 6d 64 62  ite3PagerIsMemdb
1630: 28 50 61 67 65 72 2a 29 3b 0a 76 6f 69 64 20 73  (Pager*);.void s
1640: 71 6c 69 74 65 33 50 61 67 65 72 43 61 63 68 65  qlite3PagerCache
1650: 53 74 61 74 28 50 61 67 65 72 20 2a 2c 20 69 6e  Stat(Pager *, in
1660: 74 2c 20 69 6e 74 2c 20 69 6e 74 20 2a 29 3b 0a  t, int, int *);.
1670: 76 6f 69 64 20 73 71 6c 69 74 65 33 50 61 67 65  void sqlite3Page
1680: 72 43 6c 65 61 72 43 61 63 68 65 28 50 61 67 65  rClearCache(Page
1690: 72 20 2a 29 3b 0a 0a 2f 2a 20 46 75 6e 63 74 69  r *);../* Functi
16a0: 6f 6e 73 20 75 73 65 64 20 74 6f 20 74 72 75 6e  ons used to trun
16b0: 63 61 74 65 20 74 68 65 20 64 61 74 61 62 61 73  cate the databas
16c0: 65 20 66 69 6c 65 2e 20 2a 2f 0a 76 6f 69 64 20  e file. */.void 
16d0: 73 71 6c 69 74 65 33 50 61 67 65 72 54 72 75 6e  sqlite3PagerTrun
16e0: 63 61 74 65 49 6d 61 67 65 28 50 61 67 65 72 2a  cateImage(Pager*
16f0: 2c 50 67 6e 6f 29 3b 0a 0a 23 69 66 20 64 65 66  ,Pgno);..#if def
1700: 69 6e 65 64 28 53 51 4c 49 54 45 5f 48 41 53 5f  ined(SQLITE_HAS_
1710: 43 4f 44 45 43 29 20 26 26 20 21 64 65 66 69 6e  CODEC) && !defin
1720: 65 64 28 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 57  ed(SQLITE_OMIT_W
1730: 41 4c 29 0a 76 6f 69 64 20 2a 73 71 6c 69 74 65  AL).void *sqlite
1740: 33 50 61 67 65 72 43 6f 64 65 63 28 44 62 50 61  3PagerCodec(DbPa
1750: 67 65 20 2a 29 3b 0a 23 65 6e 64 69 66 0a 0a 2f  ge *);.#endif../
1760: 2a 20 46 75 6e 63 74 69 6f 6e 73 20 74 6f 20 73  * Functions to s
1770: 75 70 70 6f 72 74 20 74 65 73 74 69 6e 67 20 61  upport testing a
1780: 6e 64 20 64 65 62 75 67 67 69 6e 67 2e 20 2a 2f  nd debugging. */
1790: 0a 23 69 66 20 21 64 65 66 69 6e 65 64 28 4e 44  .#if !defined(ND
17a0: 45 42 55 47 29 20 7c 7c 20 64 65 66 69 6e 65 64  EBUG) || defined
17b0: 28 53 51 4c 49 54 45 5f 54 45 53 54 29 0a 20 20  (SQLITE_TEST).  
17c0: 50 67 6e 6f 20 73 71 6c 69 74 65 33 50 61 67 65  Pgno sqlite3Page
17d0: 72 50 61 67 65 6e 75 6d 62 65 72 28 44 62 50 61  rPagenumber(DbPa
17e0: 67 65 2a 29 3b 0a 20 20 69 6e 74 20 73 71 6c 69  ge*);.  int sqli
17f0: 74 65 33 50 61 67 65 72 49 73 77 72 69 74 65 61  te3PagerIswritea
1800: 62 6c 65 28 44 62 50 61 67 65 2a 29 3b 0a 23 65  ble(DbPage*);.#e
1810: 6e 64 69 66 0a 23 69 66 64 65 66 20 53 51 4c 49  ndif.#ifdef SQLI
1820: 54 45 5f 54 45 53 54 0a 20 20 69 6e 74 20 2a 73  TE_TEST.  int *s
1830: 71 6c 69 74 65 33 50 61 67 65 72 53 74 61 74 73  qlite3PagerStats
1840: 28 50 61 67 65 72 2a 29 3b 0a 20 20 76 6f 69 64  (Pager*);.  void
1850: 20 73 71 6c 69 74 65 33 50 61 67 65 72 52 65 66   sqlite3PagerRef
1860: 64 75 6d 70 28 50 61 67 65 72 2a 29 3b 0a 20 20  dump(Pager*);.  
1870: 76 6f 69 64 20 64 69 73 61 62 6c 65 5f 73 69 6d  void disable_sim
1880: 75 6c 61 74 65 64 5f 69 6f 5f 65 72 72 6f 72 73  ulated_io_errors
1890: 28 76 6f 69 64 29 3b 0a 20 20 76 6f 69 64 20 65  (void);.  void e
18a0: 6e 61 62 6c 65 5f 73 69 6d 75 6c 61 74 65 64 5f  nable_simulated_
18b0: 69 6f 5f 65 72 72 6f 72 73 28 76 6f 69 64 29 3b  io_errors(void);
18c0: 0a 23 65 6c 73 65 0a 23 20 64 65 66 69 6e 65 20  .#else.# define 
18d0: 64 69 73 61 62 6c 65 5f 73 69 6d 75 6c 61 74 65  disable_simulate
18e0: 64 5f 69 6f 5f 65 72 72 6f 72 73 28 29 0a 23 20  d_io_errors().# 
18f0: 64 65 66 69 6e 65 20 65 6e 61 62 6c 65 5f 73 69  define enable_si
1900: 6d 75 6c 61 74 65 64 5f 69 6f 5f 65 72 72 6f 72  mulated_io_error
1910: 73 28 29 0a 23 65 6e 64 69 66 0a 0a 23 65 6e 64  s().#endif..#end
1920: 69 66 20 2f 2a 20 5f 50 41 47 45 52 5f 48 5f 20  if /* _PAGER_H_ 
1930: 2a 2f 0a                                         */.