/ Hex Artifact Content
Login

Artifact 8c39a1ebba1e9dc385519cc4d434c7b0cab6638c:


0000: 2f 2a 0a 2a 2a 20 32 30 30 39 20 4a 61 6e 75 61  /*.** 2009 Janua
0010: 72 79 20 32 38 0a 2a 2a 0a 2a 2a 20 54 68 65 20  ry 28.**.** The 
0020: 61 75 74 68 6f 72 20 64 69 73 63 6c 61 69 6d 73  author disclaims
0030: 20 63 6f 70 79 72 69 67 68 74 20 74 6f 20 74 68   copyright to th
0040: 69 73 20 73 6f 75 72 63 65 20 63 6f 64 65 2e 20  is source code. 
0050: 20 49 6e 20 70 6c 61 63 65 20 6f 66 0a 2a 2a 20   In place of.** 
0060: 61 20 6c 65 67 61 6c 20 6e 6f 74 69 63 65 2c 20  a legal notice, 
0070: 68 65 72 65 20 69 73 20 61 20 62 6c 65 73 73 69  here is a blessi
0080: 6e 67 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 4d 61 79  ng:.**.**    May
0090: 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20 61 6e 64   you do good and
00a0: 20 6e 6f 74 20 65 76 69 6c 2e 0a 2a 2a 20 20 20   not evil..**   
00b0: 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20 66 6f   May you find fo
00c0: 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20 79 6f  rgiveness for yo
00d0: 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72 67 69  urself and forgi
00e0: 76 65 20 6f 74 68 65 72 73 2e 0a 2a 2a 20 20 20  ve others..**   
00f0: 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65 20 66   May you share f
0100: 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74 61 6b  reely, never tak
0110: 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20 79 6f  ing more than yo
0120: 75 20 67 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a  u 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 0a 2a 2a 20 54 68 69 73 20 66 69 6c  ****.** This fil
0180: 65 20 63 6f 6e 74 61 69 6e 73 20 74 68 65 20 69  e contains the i
0190: 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 20 6f 66  mplementation of
01a0: 20 74 68 65 20 73 71 6c 69 74 65 33 5f 62 61 63   the sqlite3_bac
01b0: 6b 75 70 5f 58 58 58 28 29 20 0a 2a 2a 20 41 50  kup_XXX() .** AP
01c0: 49 20 66 75 6e 63 74 69 6f 6e 73 20 61 6e 64 20  I functions and 
01d0: 74 68 65 20 72 65 6c 61 74 65 64 20 66 65 61 74  the related feat
01e0: 75 72 65 73 2e 0a 2a 2f 0a 23 69 6e 63 6c 75 64  ures..*/.#includ
01f0: 65 20 22 73 71 6c 69 74 65 49 6e 74 2e 68 22 0a  e "sqliteInt.h".
0200: 23 69 6e 63 6c 75 64 65 20 22 62 74 72 65 65 49  #include "btreeI
0210: 6e 74 2e 68 22 0a 0a 2f 2a 20 4d 61 63 72 6f 20  nt.h"../* Macro 
0220: 74 6f 20 66 69 6e 64 20 74 68 65 20 6d 69 6e 69  to find the mini
0230: 6d 75 6d 20 6f 66 20 74 77 6f 20 6e 75 6d 65 72  mum of two numer
0240: 69 63 20 76 61 6c 75 65 73 2e 0a 2a 2f 0a 23 69  ic values..*/.#i
0250: 66 6e 64 65 66 20 4d 49 4e 0a 23 20 64 65 66 69  fndef MIN.# defi
0260: 6e 65 20 4d 49 4e 28 78 2c 79 29 20 28 28 78 29  ne MIN(x,y) ((x)
0270: 3c 28 79 29 3f 28 78 29 3a 28 79 29 29 0a 23 65  <(y)?(x):(y)).#e
0280: 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 53 74 72 75  ndif../*.** Stru
0290: 63 74 75 72 65 20 61 6c 6c 6f 63 61 74 65 64 20  cture allocated 
02a0: 66 6f 72 20 65 61 63 68 20 62 61 63 6b 75 70 20  for each backup 
02b0: 6f 70 65 72 61 74 69 6f 6e 2e 0a 2a 2f 0a 73 74  operation..*/.st
02c0: 72 75 63 74 20 73 71 6c 69 74 65 33 5f 62 61 63  ruct sqlite3_bac
02d0: 6b 75 70 20 7b 0a 20 20 73 71 6c 69 74 65 33 2a  kup {.  sqlite3*
02e0: 20 70 44 65 73 74 44 62 3b 20 20 20 20 20 20 20   pDestDb;       
02f0: 20 2f 2a 20 44 65 73 74 69 6e 61 74 69 6f 6e 20   /* Destination 
0300: 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c 65 20  database handle 
0310: 2a 2f 0a 20 20 42 74 72 65 65 20 2a 70 44 65 73  */.  Btree *pDes
0320: 74 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a  t;            /*
0330: 20 44 65 73 74 69 6e 61 74 69 6f 6e 20 62 2d 74   Destination b-t
0340: 72 65 65 20 66 69 6c 65 20 2a 2f 0a 20 20 75 33  ree file */.  u3
0350: 32 20 69 44 65 73 74 53 63 68 65 6d 61 3b 20 20  2 iDestSchema;  
0360: 20 20 20 20 20 20 20 2f 2a 20 4f 72 69 67 69 6e         /* Origin
0370: 61 6c 20 73 63 68 65 6d 61 20 63 6f 6f 6b 69 65  al schema cookie
0380: 20 69 6e 20 64 65 73 74 69 6e 61 74 69 6f 6e 20   in destination 
0390: 2a 2f 0a 20 20 69 6e 74 20 62 44 65 73 74 4c 6f  */.  int bDestLo
03a0: 63 6b 65 64 3b 20 20 20 20 20 20 20 20 20 2f 2a  cked;         /*
03b0: 20 54 72 75 65 20 6f 6e 63 65 20 61 20 77 72 69   True once a wri
03c0: 74 65 2d 74 72 61 6e 73 61 63 74 69 6f 6e 20 69  te-transaction i
03d0: 73 20 6f 70 65 6e 20 6f 6e 20 70 44 65 73 74 20  s open on pDest 
03e0: 2a 2f 0a 0a 20 20 50 67 6e 6f 20 69 4e 65 78 74  */..  Pgno iNext
03f0: 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f  ;              /
0400: 2a 20 50 61 67 65 20 6e 75 6d 62 65 72 20 6f 66  * Page number of
0410: 20 74 68 65 20 6e 65 78 74 20 73 6f 75 72 63 65   the next source
0420: 20 70 61 67 65 20 74 6f 20 63 6f 70 79 20 2a 2f   page to copy */
0430: 0a 20 20 73 71 6c 69 74 65 33 2a 20 70 53 72 63  .  sqlite3* pSrc
0440: 44 62 3b 20 20 20 20 20 20 20 20 20 2f 2a 20 53  Db;         /* S
0450: 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 20 68  ource database h
0460: 61 6e 64 6c 65 20 2a 2f 0a 20 20 42 74 72 65 65  andle */.  Btree
0470: 20 2a 70 53 72 63 3b 20 20 20 20 20 20 20 20 20   *pSrc;         
0480: 20 20 20 20 2f 2a 20 53 6f 75 72 63 65 20 62 2d      /* Source b-
0490: 74 72 65 65 20 66 69 6c 65 20 2a 2f 0a 0a 20 20  tree file */..  
04a0: 69 6e 74 20 72 63 3b 20 20 20 20 20 20 20 20 20  int rc;         
04b0: 20 20 20 20 20 20 20 20 20 2f 2a 20 42 61 63 6b           /* Back
04c0: 75 70 20 70 72 6f 63 65 73 73 20 65 72 72 6f 72  up process error
04d0: 20 63 6f 64 65 20 2a 2f 0a 0a 20 20 2f 2a 20 54   code */..  /* T
04e0: 68 65 73 65 20 74 77 6f 20 76 61 72 69 61 62 6c  hese two variabl
04f0: 65 73 20 61 72 65 20 73 65 74 20 62 79 20 65 76  es are set by ev
0500: 65 72 79 20 63 61 6c 6c 20 74 6f 20 62 61 63 6b  ery call to back
0510: 75 70 5f 73 74 65 70 28 29 2e 20 54 68 65 79 20  up_step(). They 
0520: 61 72 65 0a 20 20 2a 2a 20 72 65 61 64 20 62 79  are.  ** read by
0530: 20 63 61 6c 6c 73 20 74 6f 20 62 61 63 6b 75 70   calls to backup
0540: 5f 72 65 6d 61 69 6e 69 6e 67 28 29 20 61 6e 64  _remaining() and
0550: 20 62 61 63 6b 75 70 5f 70 61 67 65 63 6f 75 6e   backup_pagecoun
0560: 74 28 29 2e 0a 20 20 2a 2f 0a 20 20 50 67 6e 6f  t()..  */.  Pgno
0570: 20 6e 52 65 6d 61 69 6e 69 6e 67 3b 20 20 20 20   nRemaining;    
0580: 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20 6f       /* Number o
0590: 66 20 70 61 67 65 73 20 6c 65 66 74 20 74 6f 20  f pages left to 
05a0: 63 6f 70 79 20 2a 2f 0a 20 20 50 67 6e 6f 20 6e  copy */.  Pgno n
05b0: 50 61 67 65 63 6f 75 6e 74 3b 20 20 20 20 20 20  Pagecount;      
05c0: 20 20 20 2f 2a 20 54 6f 74 61 6c 20 6e 75 6d 62     /* Total numb
05d0: 65 72 20 6f 66 20 70 61 67 65 73 20 74 6f 20 63  er of pages to c
05e0: 6f 70 79 20 2a 2f 0a 0a 20 20 69 6e 74 20 69 73  opy */..  int is
05f0: 41 74 74 61 63 68 65 64 3b 20 20 20 20 20 20 20  Attached;       
0600: 20 20 20 2f 2a 20 54 72 75 65 20 6f 6e 63 65 20     /* True once 
0610: 62 61 63 6b 75 70 20 68 61 73 20 62 65 65 6e 20  backup has been 
0620: 72 65 67 69 73 74 65 72 65 64 20 77 69 74 68 20  registered with 
0630: 70 61 67 65 72 20 2a 2f 0a 20 20 73 71 6c 69 74  pager */.  sqlit
0640: 65 33 5f 62 61 63 6b 75 70 20 2a 70 4e 65 78 74  e3_backup *pNext
0650: 3b 20 20 20 2f 2a 20 4e 65 78 74 20 62 61 63 6b  ;   /* Next back
0660: 75 70 20 61 73 73 6f 63 69 61 74 65 64 20 77 69  up associated wi
0670: 74 68 20 73 6f 75 72 63 65 20 70 61 67 65 72 20  th source pager 
0680: 2a 2f 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20 54 48 52  */.};../*.** THR
0690: 45 41 44 20 53 41 46 45 54 59 20 4e 4f 54 45 53  EAD SAFETY NOTES
06a0: 3a 0a 2a 2a 0a 2a 2a 20 20 20 4f 6e 63 65 20 69  :.**.**   Once i
06b0: 74 20 68 61 73 20 62 65 65 6e 20 63 72 65 61 74  t has been creat
06c0: 65 64 20 75 73 69 6e 67 20 62 61 63 6b 75 70 5f  ed using backup_
06d0: 69 6e 69 74 28 29 2c 20 61 20 73 69 6e 67 6c 65  init(), a single
06e0: 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 0a   sqlite3_backup.
06f0: 2a 2a 20 20 20 73 74 72 75 63 74 75 72 65 20 6d  **   structure m
0700: 61 79 20 62 65 20 61 63 63 65 73 73 65 64 20 76  ay be accessed v
0710: 69 61 20 74 77 6f 20 67 72 6f 75 70 73 20 6f 66  ia two groups of
0720: 20 74 68 72 65 61 64 2d 73 61 66 65 20 65 6e 74   thread-safe ent
0730: 72 79 20 70 6f 69 6e 74 73 3a 0a 2a 2a 0a 2a 2a  ry points:.**.**
0740: 20 20 20 20 20 2a 20 56 69 61 20 74 68 65 20 73       * Via the s
0750: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 58 58  qlite3_backup_XX
0760: 58 28 29 20 41 50 49 20 66 75 6e 63 74 69 6f 6e  X() API function
0770: 20 62 61 63 6b 75 70 5f 73 74 65 70 28 29 20 61   backup_step() a
0780: 6e 64 20 0a 2a 2a 20 20 20 20 20 20 20 62 61 63  nd .**       bac
0790: 6b 75 70 5f 66 69 6e 69 73 68 28 29 2e 20 42 6f  kup_finish(). Bo
07a0: 74 68 20 74 68 65 73 65 20 66 75 6e 63 74 69 6f  th these functio
07b0: 6e 73 20 6f 62 74 61 69 6e 20 74 68 65 20 73 6f  ns obtain the so
07c0: 75 72 63 65 20 64 61 74 61 62 61 73 65 0a 2a 2a  urce database.**
07d0: 20 20 20 20 20 20 20 68 61 6e 64 6c 65 20 6d 75         handle mu
07e0: 74 65 78 20 61 6e 64 20 74 68 65 20 6d 75 74 65  tex and the mute
07f0: 78 20 61 73 73 6f 63 69 61 74 65 64 20 77 69 74  x associated wit
0800: 68 20 74 68 65 20 73 6f 75 72 63 65 20 42 74 53  h the source BtS
0810: 68 61 72 65 64 20 0a 2a 2a 20 20 20 20 20 20 20  hared .**       
0820: 73 74 72 75 63 74 75 72 65 2c 20 69 6e 20 74 68  structure, in th
0830: 61 74 20 6f 72 64 65 72 2e 0a 2a 2a 0a 2a 2a 20  at order..**.** 
0840: 20 20 20 20 2a 20 56 69 61 20 74 68 65 20 42 61      * Via the Ba
0850: 63 6b 75 70 55 70 64 61 74 65 28 29 20 61 6e 64  ckupUpdate() and
0860: 20 42 61 63 6b 75 70 52 65 73 74 61 72 74 28 29   BackupRestart()
0870: 20 66 75 6e 63 74 69 6f 6e 73 2c 20 77 68 69 63   functions, whic
0880: 68 20 61 72 65 0a 2a 2a 20 20 20 20 20 20 20 69  h are.**       i
0890: 6e 76 6f 6b 65 64 20 62 79 20 74 68 65 20 70 61  nvoked by the pa
08a0: 67 65 72 20 6c 61 79 65 72 20 74 6f 20 72 65 70  ger layer to rep
08b0: 6f 72 74 20 76 61 72 69 6f 75 73 20 73 74 61 74  ort various stat
08c0: 65 20 63 68 61 6e 67 65 73 20 69 6e 0a 2a 2a 20  e changes in.** 
08d0: 20 20 20 20 20 20 74 68 65 20 70 61 67 65 20 63        the page c
08e0: 61 63 68 65 20 61 73 73 6f 63 69 61 74 65 64 20  ache associated 
08f0: 77 69 74 68 20 74 68 65 20 73 6f 75 72 63 65 20  with the source 
0900: 64 61 74 61 62 61 73 65 2e 20 54 68 65 20 6d 75  database. The mu
0910: 74 65 78 0a 2a 2a 20 20 20 20 20 20 20 61 73 73  tex.**       ass
0920: 6f 63 69 61 74 65 64 20 77 69 74 68 20 74 68 65  ociated with the
0930: 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73 65   source database
0940: 20 42 74 53 68 61 72 65 64 20 73 74 72 75 63 74   BtShared struct
0950: 75 72 65 20 77 69 6c 6c 20 61 6c 77 61 79 73 20  ure will always 
0960: 0a 2a 2a 20 20 20 20 20 20 20 62 65 20 68 65 6c  .**       be hel
0970: 64 20 77 68 65 6e 20 65 69 74 68 65 72 20 6f 66  d when either of
0980: 20 74 68 65 73 65 20 66 75 6e 63 74 69 6f 6e 73   these functions
0990: 20 61 72 65 20 69 6e 76 6f 6b 65 64 2e 0a 2a 2a   are invoked..**
09a0: 0a 2a 2a 20 20 20 54 68 65 20 6f 74 68 65 72 20  .**   The other 
09b0: 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 58  sqlite3_backup_X
09c0: 58 58 28 29 20 41 50 49 20 66 75 6e 63 74 69 6f  XX() API functio
09d0: 6e 73 2c 20 62 61 63 6b 75 70 5f 72 65 6d 61 69  ns, backup_remai
09e0: 6e 69 6e 67 28 29 20 61 6e 64 0a 2a 2a 20 20 20  ning() and.**   
09f0: 62 61 63 6b 75 70 5f 70 61 67 65 63 6f 75 6e 74  backup_pagecount
0a00: 28 29 20 61 72 65 20 6e 6f 74 20 74 68 72 65 61  () are not threa
0a10: 64 2d 73 61 66 65 20 66 75 6e 63 74 69 6f 6e 73  d-safe functions
0a20: 2e 20 49 66 20 74 68 65 79 20 61 72 65 20 63 61  . If they are ca
0a30: 6c 6c 65 64 0a 2a 2a 20 20 20 77 68 69 6c 65 20  lled.**   while 
0a40: 73 6f 6d 65 20 6f 74 68 65 72 20 74 68 72 65 61  some other threa
0a50: 64 20 69 73 20 63 61 6c 6c 69 6e 67 20 62 61 63  d is calling bac
0a60: 6b 75 70 5f 73 74 65 70 28 29 20 6f 72 20 62 61  kup_step() or ba
0a70: 63 6b 75 70 5f 66 69 6e 69 73 68 28 29 2c 0a 2a  ckup_finish(),.*
0a80: 2a 20 20 20 74 68 65 20 76 61 6c 75 65 73 20 72  *   the values r
0a90: 65 74 75 72 6e 65 64 20 6d 61 79 20 62 65 20 69  eturned may be i
0aa0: 6e 76 61 6c 69 64 2e 20 54 68 65 72 65 20 69 73  nvalid. There is
0ab0: 20 6e 6f 20 77 61 79 20 66 6f 72 20 61 20 63 61   no way for a ca
0ac0: 6c 6c 20 74 6f 0a 2a 2a 20 20 20 42 61 63 6b 75  ll to.**   Backu
0ad0: 70 55 70 64 61 74 65 28 29 20 6f 72 20 42 61 63  pUpdate() or Bac
0ae0: 6b 75 70 52 65 73 74 61 72 74 28 29 20 74 6f 20  kupRestart() to 
0af0: 69 6e 74 65 72 66 65 72 65 20 77 69 74 68 20 62  interfere with b
0b00: 61 63 6b 75 70 5f 72 65 6d 61 69 6e 69 6e 67 28  ackup_remaining(
0b10: 29 0a 2a 2a 20 20 20 6f 72 20 62 61 63 6b 75 70  ).**   or backup
0b20: 5f 70 61 67 65 63 6f 75 6e 74 28 29 2e 0a 2a 2a  _pagecount()..**
0b30: 0a 2a 2a 20 20 20 44 65 70 65 6e 64 69 6e 67 20  .**   Depending 
0b40: 6f 6e 20 74 68 65 20 53 51 4c 69 74 65 20 63 6f  on the SQLite co
0b50: 6e 66 69 67 75 72 61 74 69 6f 6e 2c 20 74 68 65  nfiguration, the
0b60: 20 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c 65   database handle
0b70: 73 20 61 6e 64 2f 6f 72 0a 2a 2a 20 20 20 74 68  s and/or.**   th
0b80: 65 20 42 74 72 65 65 20 6f 62 6a 65 63 74 73 20  e Btree objects 
0b90: 6d 61 79 20 68 61 76 65 20 74 68 65 69 72 20 6f  may have their o
0ba0: 77 6e 20 6d 75 74 65 78 65 73 20 74 68 61 74 20  wn mutexes that 
0bb0: 72 65 71 75 69 72 65 20 6c 6f 63 6b 69 6e 67 2e  require locking.
0bc0: 0a 2a 2a 20 20 20 4e 6f 6e 2d 73 68 61 72 61 62  .**   Non-sharab
0bd0: 6c 65 20 42 74 72 65 65 73 20 28 69 6e 2d 6d 65  le Btrees (in-me
0be0: 6d 6f 72 79 20 64 61 74 61 62 61 73 65 73 20 66  mory databases f
0bf0: 6f 72 20 65 78 61 6d 70 6c 65 29 2c 20 64 6f 20  or example), do 
0c00: 6e 6f 74 20 68 61 76 65 0a 2a 2a 20 20 20 61 73  not have.**   as
0c10: 73 6f 63 69 61 74 65 64 20 6d 75 74 65 78 65 73  sociated mutexes
0c20: 2e 0a 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75  ..*/../*.** Retu
0c30: 72 6e 20 61 20 70 6f 69 6e 74 65 72 20 63 6f 72  rn a pointer cor
0c40: 72 65 73 70 6f 6e 64 69 6e 67 20 74 6f 20 64 61  responding to da
0c50: 74 61 62 61 73 65 20 7a 44 62 20 28 69 2e 65 2e  tabase zDb (i.e.
0c60: 20 22 6d 61 69 6e 22 2c 20 22 74 65 6d 70 22 29   "main", "temp")
0c70: 0a 2a 2a 20 69 6e 20 63 6f 6e 6e 65 63 74 69 6f  .** in connectio
0c80: 6e 20 68 61 6e 64 6c 65 20 70 44 62 2e 20 49 66  n handle pDb. If
0c90: 20 73 75 63 68 20 61 20 64 61 74 61 62 61 73 65   such a database
0ca0: 20 63 61 6e 6e 6f 74 20 62 65 20 66 6f 75 6e 64   cannot be found
0cb0: 2c 20 72 65 74 75 72 6e 0a 2a 2a 20 61 20 4e 55  , return.** a NU
0cc0: 4c 4c 20 70 6f 69 6e 74 65 72 20 61 6e 64 20 77  LL pointer and w
0cd0: 72 69 74 65 20 61 6e 20 65 72 72 6f 72 20 6d 65  rite an error me
0ce0: 73 73 61 67 65 20 74 6f 20 70 45 72 72 6f 72 44  ssage to pErrorD
0cf0: 62 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 74 68 65 20  b..**.** If the 
0d00: 22 74 65 6d 70 22 20 64 61 74 61 62 61 73 65 20  "temp" database 
0d10: 69 73 20 72 65 71 75 65 73 74 65 64 2c 20 69 74  is requested, it
0d20: 20 6d 61 79 20 6e 65 65 64 20 74 6f 20 62 65 20   may need to be 
0d30: 6f 70 65 6e 65 64 20 62 79 20 74 68 69 73 20 0a  opened by this .
0d40: 2a 2a 20 66 75 6e 63 74 69 6f 6e 2e 20 49 66 20  ** function. If 
0d50: 61 6e 20 65 72 72 6f 72 20 6f 63 63 75 72 73 20  an error occurs 
0d60: 77 68 69 6c 65 20 64 6f 69 6e 67 20 73 6f 2c 20  while doing so, 
0d70: 72 65 74 75 72 6e 20 30 20 61 6e 64 20 77 72 69  return 0 and wri
0d80: 74 65 20 61 6e 20 0a 2a 2a 20 65 72 72 6f 72 20  te an .** error 
0d90: 6d 65 73 73 61 67 65 20 74 6f 20 70 45 72 72 6f  message to pErro
0da0: 72 44 62 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 42  rDb..*/.static B
0db0: 74 72 65 65 20 2a 66 69 6e 64 42 74 72 65 65 28  tree *findBtree(
0dc0: 73 71 6c 69 74 65 33 20 2a 70 45 72 72 6f 72 44  sqlite3 *pErrorD
0dd0: 62 2c 20 73 71 6c 69 74 65 33 20 2a 70 44 62 2c  b, sqlite3 *pDb,
0de0: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 44 62   const char *zDb
0df0: 29 7b 0a 20 20 69 6e 74 20 69 20 3d 20 73 71 6c  ){.  int i = sql
0e00: 69 74 65 33 46 69 6e 64 44 62 4e 61 6d 65 28 70  ite3FindDbName(p
0e10: 44 62 2c 20 7a 44 62 29 3b 0a 0a 20 20 69 66 28  Db, zDb);..  if(
0e20: 20 69 3d 3d 31 20 29 7b 0a 20 20 20 20 50 61 72   i==1 ){.    Par
0e30: 73 65 20 2a 70 50 61 72 73 65 3b 0a 20 20 20 20  se *pParse;.    
0e40: 69 6e 74 20 72 63 20 3d 20 30 3b 0a 20 20 20 20  int rc = 0;.    
0e50: 70 50 61 72 73 65 20 3d 20 73 71 6c 69 74 65 33  pParse = sqlite3
0e60: 53 74 61 63 6b 41 6c 6c 6f 63 5a 65 72 6f 28 70  StackAllocZero(p
0e70: 45 72 72 6f 72 44 62 2c 20 73 69 7a 65 6f 66 28  ErrorDb, sizeof(
0e80: 2a 70 50 61 72 73 65 29 29 3b 0a 20 20 20 20 69  *pParse));.    i
0e90: 66 28 20 70 50 61 72 73 65 3d 3d 30 20 29 7b 0a  f( pParse==0 ){.
0ea0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 45 72 72        sqlite3Err
0eb0: 6f 72 28 70 45 72 72 6f 72 44 62 2c 20 53 51 4c  or(pErrorDb, SQL
0ec0: 49 54 45 5f 4e 4f 4d 45 4d 2c 20 22 6f 75 74 20  ITE_NOMEM, "out 
0ed0: 6f 66 20 6d 65 6d 6f 72 79 22 29 3b 0a 20 20 20  of memory");.   
0ee0: 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 4e     rc = SQLITE_N
0ef0: 4f 4d 45 4d 3b 0a 20 20 20 20 7d 65 6c 73 65 7b  OMEM;.    }else{
0f00: 0a 20 20 20 20 20 20 70 50 61 72 73 65 2d 3e 64  .      pParse->d
0f10: 62 20 3d 20 70 44 62 3b 0a 20 20 20 20 20 20 69  b = pDb;.      i
0f20: 66 28 20 73 71 6c 69 74 65 33 4f 70 65 6e 54 65  f( sqlite3OpenTe
0f30: 6d 70 44 61 74 61 62 61 73 65 28 70 50 61 72 73  mpDatabase(pPars
0f40: 65 29 20 29 7b 0a 20 20 20 20 20 20 20 20 73 71  e) ){.        sq
0f50: 6c 69 74 65 33 45 72 72 6f 72 28 70 45 72 72 6f  lite3Error(pErro
0f60: 72 44 62 2c 20 70 50 61 72 73 65 2d 3e 72 63 2c  rDb, pParse->rc,
0f70: 20 22 25 73 22 2c 20 70 50 61 72 73 65 2d 3e 7a   "%s", pParse->z
0f80: 45 72 72 4d 73 67 29 3b 0a 20 20 20 20 20 20 20  ErrMsg);.       
0f90: 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 45 52 52   rc = SQLITE_ERR
0fa0: 4f 52 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20  OR;.      }.    
0fb0: 20 20 73 71 6c 69 74 65 33 44 62 46 72 65 65 28    sqlite3DbFree(
0fc0: 70 45 72 72 6f 72 44 62 2c 20 70 50 61 72 73 65  pErrorDb, pParse
0fd0: 2d 3e 7a 45 72 72 4d 73 67 29 3b 0a 20 20 20 20  ->zErrMsg);.    
0fe0: 20 20 73 71 6c 69 74 65 33 53 74 61 63 6b 46 72    sqlite3StackFr
0ff0: 65 65 28 70 45 72 72 6f 72 44 62 2c 20 70 50 61  ee(pErrorDb, pPa
1000: 72 73 65 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20  rse);.    }.    
1010: 69 66 28 20 72 63 20 29 7b 0a 20 20 20 20 20 20  if( rc ){.      
1020: 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 7d 0a  return 0;.    }.
1030: 20 20 7d 0a 0a 20 20 69 66 28 20 69 3c 30 20 29    }..  if( i<0 )
1040: 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 45 72 72  {.    sqlite3Err
1050: 6f 72 28 70 45 72 72 6f 72 44 62 2c 20 53 51 4c  or(pErrorDb, SQL
1060: 49 54 45 5f 45 52 52 4f 52 2c 20 22 75 6e 6b 6e  ITE_ERROR, "unkn
1070: 6f 77 6e 20 64 61 74 61 62 61 73 65 20 25 73 22  own database %s"
1080: 2c 20 7a 44 62 29 3b 0a 20 20 20 20 72 65 74 75  , zDb);.    retu
1090: 72 6e 20 30 3b 0a 20 20 7d 0a 0a 20 20 72 65 74  rn 0;.  }..  ret
10a0: 75 72 6e 20 70 44 62 2d 3e 61 44 62 5b 69 5d 2e  urn pDb->aDb[i].
10b0: 70 42 74 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 41 74  pBt;.}../*.** At
10c0: 74 65 6d 70 74 20 74 6f 20 73 65 74 20 74 68 65  tempt to set the
10d0: 20 70 61 67 65 20 73 69 7a 65 20 6f 66 20 74 68   page size of th
10e0: 65 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 74 6f  e destination to
10f0: 20 6d 61 74 63 68 20 74 68 65 20 70 61 67 65 20   match the page 
1100: 73 69 7a 65 0a 2a 2a 20 6f 66 20 74 68 65 20 73  size.** of the s
1110: 6f 75 72 63 65 2e 0a 2a 2f 0a 73 74 61 74 69 63  ource..*/.static
1120: 20 69 6e 74 20 73 65 74 44 65 73 74 50 67 73 7a   int setDestPgsz
1130: 28 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20  (sqlite3_backup 
1140: 2a 70 29 7b 0a 20 20 69 6e 74 20 72 63 3b 0a 20  *p){.  int rc;. 
1150: 20 72 63 20 3d 20 73 71 6c 69 74 65 33 42 74 72   rc = sqlite3Btr
1160: 65 65 53 65 74 50 61 67 65 53 69 7a 65 28 70 2d  eeSetPageSize(p-
1170: 3e 70 44 65 73 74 2c 73 71 6c 69 74 65 33 42 74  >pDest,sqlite3Bt
1180: 72 65 65 47 65 74 50 61 67 65 53 69 7a 65 28 70  reeGetPageSize(p
1190: 2d 3e 70 53 72 63 29 2c 2d 31 2c 30 29 3b 0a 20  ->pSrc),-1,0);. 
11a0: 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f   return rc;.}../
11b0: 2a 0a 2a 2a 20 43 72 65 61 74 65 20 61 6e 20 73  *.** Create an s
11c0: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 70 72  qlite3_backup pr
11d0: 6f 63 65 73 73 20 74 6f 20 63 6f 70 79 20 74 68  ocess to copy th
11e0: 65 20 63 6f 6e 74 65 6e 74 73 20 6f 66 20 7a 53  e contents of zS
11f0: 72 63 44 62 20 66 72 6f 6d 0a 2a 2a 20 63 6f 6e  rcDb from.** con
1200: 6e 65 63 74 69 6f 6e 20 68 61 6e 64 6c 65 20 70  nection handle p
1210: 53 72 63 44 62 20 74 6f 20 7a 44 65 73 74 44 62  SrcDb to zDestDb
1220: 20 69 6e 20 70 44 65 73 74 44 62 2e 20 49 66 20   in pDestDb. If 
1230: 73 75 63 63 65 73 73 66 75 6c 2c 20 72 65 74 75  successful, retu
1240: 72 6e 0a 2a 2a 20 61 20 70 6f 69 6e 74 65 72 20  rn.** a pointer 
1250: 74 6f 20 74 68 65 20 6e 65 77 20 73 71 6c 69 74  to the new sqlit
1260: 65 33 5f 62 61 63 6b 75 70 20 6f 62 6a 65 63 74  e3_backup object
1270: 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 61 6e 20 65 72  ..**.** If an er
1280: 72 6f 72 20 6f 63 63 75 72 73 2c 20 4e 55 4c 4c  ror occurs, NULL
1290: 20 69 73 20 72 65 74 75 72 6e 65 64 20 61 6e 64   is returned and
12a0: 20 61 6e 20 65 72 72 6f 72 20 63 6f 64 65 20 61   an error code a
12b0: 6e 64 20 65 72 72 6f 72 20 6d 65 73 73 61 67 65  nd error message
12c0: 0a 2a 2a 20 73 74 6f 72 65 64 20 69 6e 20 64 61  .** stored in da
12d0: 74 61 62 61 73 65 20 68 61 6e 64 6c 65 20 70 44  tabase handle pD
12e0: 65 73 74 44 62 2e 0a 2a 2f 0a 73 71 6c 69 74 65  estDb..*/.sqlite
12f0: 33 5f 62 61 63 6b 75 70 20 2a 73 71 6c 69 74 65  3_backup *sqlite
1300: 33 5f 62 61 63 6b 75 70 5f 69 6e 69 74 28 0a 20  3_backup_init(. 
1310: 20 73 71 6c 69 74 65 33 2a 20 70 44 65 73 74 44   sqlite3* pDestD
1320: 62 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20  b,              
1330: 20 20 20 20 20 20 20 2f 2a 20 44 61 74 61 62 61         /* Databa
1340: 73 65 20 74 6f 20 77 72 69 74 65 20 74 6f 20 2a  se to write to *
1350: 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  /.  const char *
1360: 7a 44 65 73 74 44 62 2c 20 20 20 20 20 20 20 20  zDestDb,        
1370: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 61 6d            /* Nam
1380: 65 20 6f 66 20 64 61 74 61 62 61 73 65 20 77 69  e of database wi
1390: 74 68 69 6e 20 70 44 65 73 74 44 62 20 2a 2f 0a  thin pDestDb */.
13a0: 20 20 73 71 6c 69 74 65 33 2a 20 70 53 72 63 44    sqlite3* pSrcD
13b0: 62 2c 20 20 20 20 20 20 20 20 20 20 20 20 20 20  b,              
13c0: 20 20 20 20 20 20 20 20 2f 2a 20 44 61 74 61 62          /* Datab
13d0: 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 74  ase connection t
13e0: 6f 20 72 65 61 64 20 66 72 6f 6d 20 2a 2f 0a 20  o read from */. 
13f0: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 53 72   const char *zSr
1400: 63 44 62 20 20 20 20 20 20 20 20 20 20 20 20 20  cDb             
1410: 20 20 20 20 20 20 20 2f 2a 20 4e 61 6d 65 20 6f         /* Name o
1420: 66 20 64 61 74 61 62 61 73 65 20 77 69 74 68 69  f database withi
1430: 6e 20 70 53 72 63 44 62 20 2a 2f 0a 29 7b 0a 20  n pSrcDb */.){. 
1440: 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20   sqlite3_backup 
1450: 2a 70 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  *p;             
1460: 20 20 20 20 20 20 20 2f 2a 20 56 61 6c 75 65 20         /* Value 
1470: 74 6f 20 72 65 74 75 72 6e 20 2a 2f 0a 0a 20 20  to return */..  
1480: 2f 2a 20 4c 6f 63 6b 20 74 68 65 20 73 6f 75 72  /* Lock the sour
1490: 63 65 20 64 61 74 61 62 61 73 65 20 68 61 6e 64  ce database hand
14a0: 6c 65 2e 20 54 68 65 20 64 65 73 74 69 6e 61 74  le. The destinat
14b0: 69 6f 6e 20 64 61 74 61 62 61 73 65 0a 20 20 2a  ion database.  *
14c0: 2a 20 68 61 6e 64 6c 65 20 69 73 20 6e 6f 74 20  * handle is not 
14d0: 6c 6f 63 6b 65 64 20 69 6e 20 74 68 69 73 20 72  locked in this r
14e0: 6f 75 74 69 6e 65 2c 20 62 75 74 20 69 74 20 69  outine, but it i
14f0: 73 20 6c 6f 63 6b 65 64 20 69 6e 0a 20 20 2a 2a  s locked in.  **
1500: 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f   sqlite3_backup_
1510: 73 74 65 70 28 29 2e 20 54 68 65 20 75 73 65 72  step(). The user
1520: 20 69 73 20 72 65 71 75 69 72 65 64 20 74 6f 20   is required to 
1530: 65 6e 73 75 72 65 20 74 68 61 74 20 6e 6f 0a 20  ensure that no. 
1540: 20 2a 2a 20 6f 74 68 65 72 20 74 68 72 65 61 64   ** other thread
1550: 20 61 63 63 65 73 73 65 73 20 74 68 65 20 64 65   accesses the de
1560: 73 74 69 6e 61 74 69 6f 6e 20 68 61 6e 64 6c 65  stination handle
1570: 20 66 6f 72 20 74 68 65 20 64 75 72 61 74 69 6f   for the duratio
1580: 6e 0a 20 20 2a 2a 20 6f 66 20 74 68 65 20 62 61  n.  ** of the ba
1590: 63 6b 75 70 20 6f 70 65 72 61 74 69 6f 6e 2e 20  ckup operation. 
15a0: 20 41 6e 79 20 61 74 74 65 6d 70 74 20 74 6f 20   Any attempt to 
15b0: 75 73 65 20 74 68 65 20 64 65 73 74 69 6e 61 74  use the destinat
15c0: 69 6f 6e 0a 20 20 2a 2a 20 64 61 74 61 62 61 73  ion.  ** databas
15d0: 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 77 68 69  e connection whi
15e0: 6c 65 20 61 20 62 61 63 6b 75 70 20 69 73 20 69  le a backup is i
15f0: 6e 20 70 72 6f 67 72 65 73 73 20 6d 61 79 20 63  n progress may c
1600: 61 75 73 65 0a 20 20 2a 2a 20 61 20 6d 61 6c 66  ause.  ** a malf
1610: 75 6e 63 74 69 6f 6e 20 6f 72 20 61 20 64 65 61  unction or a dea
1620: 64 6c 6f 63 6b 2e 0a 20 20 2a 2f 0a 20 20 73 71  dlock..  */.  sq
1630: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65  lite3_mutex_ente
1640: 72 28 70 53 72 63 44 62 2d 3e 6d 75 74 65 78 29  r(pSrcDb->mutex)
1650: 3b 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65  ;.  sqlite3_mute
1660: 78 5f 65 6e 74 65 72 28 70 44 65 73 74 44 62 2d  x_enter(pDestDb-
1670: 3e 6d 75 74 65 78 29 3b 0a 0a 20 20 69 66 28 20  >mutex);..  if( 
1680: 70 53 72 63 44 62 3d 3d 70 44 65 73 74 44 62 20  pSrcDb==pDestDb 
1690: 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 45 72  ){.    sqlite3Er
16a0: 72 6f 72 28 0a 20 20 20 20 20 20 20 20 70 44 65  ror(.        pDe
16b0: 73 74 44 62 2c 20 53 51 4c 49 54 45 5f 45 52 52  stDb, SQLITE_ERR
16c0: 4f 52 2c 20 22 73 6f 75 72 63 65 20 61 6e 64 20  OR, "source and 
16d0: 64 65 73 74 69 6e 61 74 69 6f 6e 20 6d 75 73 74  destination must
16e0: 20 62 65 20 64 69 73 74 69 6e 63 74 22 0a 20 20   be distinct".  
16f0: 20 20 29 3b 0a 20 20 20 20 70 20 3d 20 30 3b 0a    );.    p = 0;.
1700: 20 20 7d 65 6c 73 65 20 7b 0a 20 20 20 20 2f 2a    }else {.    /*
1710: 20 41 6c 6c 6f 63 61 74 65 20 73 70 61 63 65 20   Allocate space 
1720: 66 6f 72 20 61 20 6e 65 77 20 73 71 6c 69 74 65  for a new sqlite
1730: 33 5f 62 61 63 6b 75 70 20 6f 62 6a 65 63 74 2e  3_backup object.
1740: 2e 2e 0a 20 20 20 20 2a 2a 20 45 56 49 44 45 4e  ...    ** EVIDEN
1750: 43 45 2d 4f 46 3a 20 52 2d 36 34 38 35 32 2d 32  CE-OF: R-64852-2
1760: 31 35 39 31 20 54 68 65 20 73 71 6c 69 74 65 33  1591 The sqlite3
1770: 5f 62 61 63 6b 75 70 20 6f 62 6a 65 63 74 20 69  _backup object i
1780: 73 20 63 72 65 61 74 65 64 20 62 79 20 61 0a 20  s created by a. 
1790: 20 20 20 2a 2a 20 63 61 6c 6c 20 74 6f 20 73 71     ** call to sq
17a0: 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 69 6e 69  lite3_backup_ini
17b0: 74 28 29 20 61 6e 64 20 69 73 20 64 65 73 74 72  t() and is destr
17c0: 6f 79 65 64 20 62 79 20 61 20 63 61 6c 6c 20 74  oyed by a call t
17d0: 6f 0a 20 20 20 20 2a 2a 20 73 71 6c 69 74 65 33  o.    ** sqlite3
17e0: 5f 62 61 63 6b 75 70 5f 66 69 6e 69 73 68 28 29  _backup_finish()
17f0: 2e 20 2a 2f 0a 20 20 20 20 70 20 3d 20 28 73 71  . */.    p = (sq
1800: 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 29 73  lite3_backup *)s
1810: 71 6c 69 74 65 33 5f 6d 61 6c 6c 6f 63 28 73 69  qlite3_malloc(si
1820: 7a 65 6f 66 28 73 71 6c 69 74 65 33 5f 62 61 63  zeof(sqlite3_bac
1830: 6b 75 70 29 29 3b 0a 20 20 20 20 69 66 28 20 21  kup));.    if( !
1840: 70 20 29 7b 0a 20 20 20 20 20 20 73 71 6c 69 74  p ){.      sqlit
1850: 65 33 45 72 72 6f 72 28 70 44 65 73 74 44 62 2c  e3Error(pDestDb,
1860: 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 2c 20 30   SQLITE_NOMEM, 0
1870: 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20  );.    }.  }..  
1880: 2f 2a 20 49 66 20 74 68 65 20 61 6c 6c 6f 63 61  /* If the alloca
1890: 74 69 6f 6e 20 73 75 63 63 65 65 64 65 64 2c 20  tion succeeded, 
18a0: 70 6f 70 75 6c 61 74 65 20 74 68 65 20 6e 65 77  populate the new
18b0: 20 6f 62 6a 65 63 74 2e 20 2a 2f 0a 20 20 69 66   object. */.  if
18c0: 28 20 70 20 29 7b 0a 20 20 20 20 6d 65 6d 73 65  ( p ){.    memse
18d0: 74 28 70 2c 20 30 2c 20 73 69 7a 65 6f 66 28 73  t(p, 0, sizeof(s
18e0: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 29 29 3b  qlite3_backup));
18f0: 0a 20 20 20 20 70 2d 3e 70 53 72 63 20 3d 20 66  .    p->pSrc = f
1900: 69 6e 64 42 74 72 65 65 28 70 44 65 73 74 44 62  indBtree(pDestDb
1910: 2c 20 70 53 72 63 44 62 2c 20 7a 53 72 63 44 62  , pSrcDb, zSrcDb
1920: 29 3b 0a 20 20 20 20 70 2d 3e 70 44 65 73 74 20  );.    p->pDest 
1930: 3d 20 66 69 6e 64 42 74 72 65 65 28 70 44 65 73  = findBtree(pDes
1940: 74 44 62 2c 20 70 44 65 73 74 44 62 2c 20 7a 44  tDb, pDestDb, zD
1950: 65 73 74 44 62 29 3b 0a 20 20 20 20 70 2d 3e 70  estDb);.    p->p
1960: 44 65 73 74 44 62 20 3d 20 70 44 65 73 74 44 62  DestDb = pDestDb
1970: 3b 0a 20 20 20 20 70 2d 3e 70 53 72 63 44 62 20  ;.    p->pSrcDb 
1980: 3d 20 70 53 72 63 44 62 3b 0a 20 20 20 20 70 2d  = pSrcDb;.    p-
1990: 3e 69 4e 65 78 74 20 3d 20 31 3b 0a 20 20 20 20  >iNext = 1;.    
19a0: 70 2d 3e 69 73 41 74 74 61 63 68 65 64 20 3d 20  p->isAttached = 
19b0: 30 3b 0a 0a 20 20 20 20 69 66 28 20 30 3d 3d 70  0;..    if( 0==p
19c0: 2d 3e 70 53 72 63 20 7c 7c 20 30 3d 3d 70 2d 3e  ->pSrc || 0==p->
19d0: 70 44 65 73 74 20 7c 7c 20 73 65 74 44 65 73 74  pDest || setDest
19e0: 50 67 73 7a 28 70 29 3d 3d 53 51 4c 49 54 45 5f  Pgsz(p)==SQLITE_
19f0: 4e 4f 4d 45 4d 20 29 7b 0a 20 20 20 20 20 20 2f  NOMEM ){.      /
1a00: 2a 20 4f 6e 65 20 28 6f 72 20 62 6f 74 68 29 20  * One (or both) 
1a10: 6f 66 20 74 68 65 20 6e 61 6d 65 64 20 64 61 74  of the named dat
1a20: 61 62 61 73 65 73 20 64 69 64 20 6e 6f 74 20 65  abases did not e
1a30: 78 69 73 74 20 6f 72 20 61 6e 20 4f 4f 4d 0a 20  xist or an OOM. 
1a40: 20 20 20 20 20 2a 2a 20 65 72 72 6f 72 20 77 61       ** error wa
1a50: 73 20 68 69 74 2e 20 20 54 68 65 20 65 72 72 6f  s hit.  The erro
1a60: 72 20 68 61 73 20 61 6c 72 65 61 64 79 20 62 65  r has already be
1a70: 65 6e 20 77 72 69 74 74 65 6e 20 69 6e 74 6f 20  en written into 
1a80: 74 68 65 0a 20 20 20 20 20 20 2a 2a 20 70 44 65  the.      ** pDe
1a90: 73 74 44 62 20 68 61 6e 64 6c 65 2e 20 20 41 6c  stDb handle.  Al
1aa0: 6c 20 74 68 61 74 20 69 73 20 6c 65 66 74 20 74  l that is left t
1ab0: 6f 20 64 6f 20 68 65 72 65 20 69 73 20 66 72 65  o do here is fre
1ac0: 65 20 74 68 65 0a 20 20 20 20 20 20 2a 2a 20 73  e the.      ** s
1ad0: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 73 74  qlite3_backup st
1ae0: 72 75 63 74 75 72 65 2e 0a 20 20 20 20 20 20 2a  ructure..      *
1af0: 2f 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f  /.      sqlite3_
1b00: 66 72 65 65 28 70 29 3b 0a 20 20 20 20 20 20 70  free(p);.      p
1b10: 20 3d 20 30 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a   = 0;.    }.  }.
1b20: 20 20 69 66 28 20 70 20 29 7b 0a 20 20 20 20 70    if( p ){.    p
1b30: 2d 3e 70 53 72 63 2d 3e 6e 42 61 63 6b 75 70 2b  ->pSrc->nBackup+
1b40: 2b 3b 0a 20 20 7d 0a 0a 20 20 73 71 6c 69 74 65  +;.  }..  sqlite
1b50: 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 70 44  3_mutex_leave(pD
1b60: 65 73 74 44 62 2d 3e 6d 75 74 65 78 29 3b 0a 20  estDb->mutex);. 
1b70: 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c   sqlite3_mutex_l
1b80: 65 61 76 65 28 70 53 72 63 44 62 2d 3e 6d 75 74  eave(pSrcDb->mut
1b90: 65 78 29 3b 0a 20 20 72 65 74 75 72 6e 20 70 3b  ex);.  return p;
1ba0: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 41 72 67 75 6d 65  .}../*.** Argume
1bb0: 6e 74 20 72 63 20 69 73 20 61 6e 20 53 51 4c 69  nt rc is an SQLi
1bc0: 74 65 20 65 72 72 6f 72 20 63 6f 64 65 2e 20 52  te error code. R
1bd0: 65 74 75 72 6e 20 74 72 75 65 20 69 66 20 74 68  eturn true if th
1be0: 69 73 20 65 72 72 6f 72 20 69 73 20 0a 2a 2a 20  is error is .** 
1bf0: 63 6f 6e 73 69 64 65 72 65 64 20 66 61 74 61 6c  considered fatal
1c00: 20 69 66 20 65 6e 63 6f 75 6e 74 65 72 65 64 20   if encountered 
1c10: 64 75 72 69 6e 67 20 61 20 62 61 63 6b 75 70 20  during a backup 
1c20: 6f 70 65 72 61 74 69 6f 6e 2e 20 41 6c 6c 20 65  operation. All e
1c30: 72 72 6f 72 73 0a 2a 2a 20 61 72 65 20 63 6f 6e  rrors.** are con
1c40: 73 69 64 65 72 65 64 20 66 61 74 61 6c 20 65 78  sidered fatal ex
1c50: 63 65 70 74 20 66 6f 72 20 53 51 4c 49 54 45 5f  cept for SQLITE_
1c60: 42 55 53 59 20 61 6e 64 20 53 51 4c 49 54 45 5f  BUSY and SQLITE_
1c70: 4c 4f 43 4b 45 44 2e 0a 2a 2f 0a 73 74 61 74 69  LOCKED..*/.stati
1c80: 63 20 69 6e 74 20 69 73 46 61 74 61 6c 45 72 72  c int isFatalErr
1c90: 6f 72 28 69 6e 74 20 72 63 29 7b 0a 20 20 72 65  or(int rc){.  re
1ca0: 74 75 72 6e 20 28 72 63 21 3d 53 51 4c 49 54 45  turn (rc!=SQLITE
1cb0: 5f 4f 4b 20 26 26 20 72 63 21 3d 53 51 4c 49 54  _OK && rc!=SQLIT
1cc0: 45 5f 42 55 53 59 20 26 26 20 41 4c 57 41 59 53  E_BUSY && ALWAYS
1cd0: 28 72 63 21 3d 53 51 4c 49 54 45 5f 4c 4f 43 4b  (rc!=SQLITE_LOCK
1ce0: 45 44 29 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 50  ED));.}../*.** P
1cf0: 61 72 61 6d 65 74 65 72 20 7a 53 72 63 44 61 74  arameter zSrcDat
1d00: 61 20 70 6f 69 6e 74 73 20 74 6f 20 61 20 62 75  a points to a bu
1d10: 66 66 65 72 20 63 6f 6e 74 61 69 6e 69 6e 67 20  ffer containing 
1d20: 74 68 65 20 64 61 74 61 20 66 6f 72 20 0a 2a 2a  the data for .**
1d30: 20 70 61 67 65 20 69 53 72 63 50 67 20 66 72 6f   page iSrcPg fro
1d40: 6d 20 74 68 65 20 73 6f 75 72 63 65 20 64 61 74  m the source dat
1d50: 61 62 61 73 65 2e 20 43 6f 70 79 20 74 68 69 73  abase. Copy this
1d60: 20 64 61 74 61 20 69 6e 74 6f 20 74 68 65 20 0a   data into the .
1d70: 2a 2a 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 64  ** destination d
1d80: 61 74 61 62 61 73 65 2e 0a 2a 2f 0a 73 74 61 74  atabase..*/.stat
1d90: 69 63 20 69 6e 74 20 62 61 63 6b 75 70 4f 6e 65  ic int backupOne
1da0: 50 61 67 65 28 73 71 6c 69 74 65 33 5f 62 61 63  Page(sqlite3_bac
1db0: 6b 75 70 20 2a 70 2c 20 50 67 6e 6f 20 69 53 72  kup *p, Pgno iSr
1dc0: 63 50 67 2c 20 63 6f 6e 73 74 20 75 38 20 2a 7a  cPg, const u8 *z
1dd0: 53 72 63 44 61 74 61 29 7b 0a 20 20 50 61 67 65  SrcData){.  Page
1de0: 72 20 2a 20 63 6f 6e 73 74 20 70 44 65 73 74 50  r * const pDestP
1df0: 61 67 65 72 20 3d 20 73 71 6c 69 74 65 33 42 74  ager = sqlite3Bt
1e00: 72 65 65 50 61 67 65 72 28 70 2d 3e 70 44 65 73  reePager(p->pDes
1e10: 74 29 3b 0a 20 20 63 6f 6e 73 74 20 69 6e 74 20  t);.  const int 
1e20: 6e 53 72 63 50 67 73 7a 20 3d 20 73 71 6c 69 74  nSrcPgsz = sqlit
1e30: 65 33 42 74 72 65 65 47 65 74 50 61 67 65 53 69  e3BtreeGetPageSi
1e40: 7a 65 28 70 2d 3e 70 53 72 63 29 3b 0a 20 20 69  ze(p->pSrc);.  i
1e50: 6e 74 20 6e 44 65 73 74 50 67 73 7a 20 3d 20 73  nt nDestPgsz = s
1e60: 71 6c 69 74 65 33 42 74 72 65 65 47 65 74 50 61  qlite3BtreeGetPa
1e70: 67 65 53 69 7a 65 28 70 2d 3e 70 44 65 73 74 29  geSize(p->pDest)
1e80: 3b 0a 20 20 63 6f 6e 73 74 20 69 6e 74 20 6e 43  ;.  const int nC
1e90: 6f 70 79 20 3d 20 4d 49 4e 28 6e 53 72 63 50 67  opy = MIN(nSrcPg
1ea0: 73 7a 2c 20 6e 44 65 73 74 50 67 73 7a 29 3b 0a  sz, nDestPgsz);.
1eb0: 20 20 63 6f 6e 73 74 20 69 36 34 20 69 45 6e 64    const i64 iEnd
1ec0: 20 3d 20 28 69 36 34 29 69 53 72 63 50 67 2a 28   = (i64)iSrcPg*(
1ed0: 69 36 34 29 6e 53 72 63 50 67 73 7a 3b 0a 0a 20  i64)nSrcPgsz;.. 
1ee0: 20 69 6e 74 20 72 63 20 3d 20 53 51 4c 49 54 45   int rc = SQLITE
1ef0: 5f 4f 4b 3b 0a 20 20 69 36 34 20 69 4f 66 66 3b  _OK;.  i64 iOff;
1f00: 0a 0a 20 20 61 73 73 65 72 74 28 20 70 2d 3e 62  ..  assert( p->b
1f10: 44 65 73 74 4c 6f 63 6b 65 64 20 29 3b 0a 20 20  DestLocked );.  
1f20: 61 73 73 65 72 74 28 20 21 69 73 46 61 74 61 6c  assert( !isFatal
1f30: 45 72 72 6f 72 28 70 2d 3e 72 63 29 20 29 3b 0a  Error(p->rc) );.
1f40: 20 20 61 73 73 65 72 74 28 20 69 53 72 63 50 67    assert( iSrcPg
1f50: 21 3d 50 45 4e 44 49 4e 47 5f 42 59 54 45 5f 50  !=PENDING_BYTE_P
1f60: 41 47 45 28 70 2d 3e 70 53 72 63 2d 3e 70 42 74  AGE(p->pSrc->pBt
1f70: 29 20 29 3b 0a 20 20 61 73 73 65 72 74 28 20 7a  ) );.  assert( z
1f80: 53 72 63 44 61 74 61 20 29 3b 0a 0a 20 20 2f 2a  SrcData );..  /*
1f90: 20 43 61 74 63 68 20 74 68 65 20 63 61 73 65 20   Catch the case 
1fa0: 77 68 65 72 65 20 74 68 65 20 64 65 73 74 69 6e  where the destin
1fb0: 61 74 69 6f 6e 20 69 73 20 61 6e 20 69 6e 2d 6d  ation is an in-m
1fc0: 65 6d 6f 72 79 20 64 61 74 61 62 61 73 65 20 61  emory database a
1fd0: 6e 64 20 74 68 65 0a 20 20 2a 2a 20 70 61 67 65  nd the.  ** page
1fe0: 20 73 69 7a 65 73 20 6f 66 20 74 68 65 20 73 6f   sizes of the so
1ff0: 75 72 63 65 20 61 6e 64 20 64 65 73 74 69 6e 61  urce and destina
2000: 74 69 6f 6e 20 64 69 66 66 65 72 2e 20 0a 20 20  tion differ. .  
2010: 2a 2f 0a 20 20 69 66 28 20 6e 53 72 63 50 67 73  */.  if( nSrcPgs
2020: 7a 21 3d 6e 44 65 73 74 50 67 73 7a 20 26 26 20  z!=nDestPgsz && 
2030: 73 71 6c 69 74 65 33 50 61 67 65 72 49 73 4d 65  sqlite3PagerIsMe
2040: 6d 64 62 28 70 44 65 73 74 50 61 67 65 72 29 20  mdb(pDestPager) 
2050: 29 7b 0a 20 20 20 20 72 63 20 3d 20 53 51 4c 49  ){.    rc = SQLI
2060: 54 45 5f 52 45 41 44 4f 4e 4c 59 3b 0a 20 20 7d  TE_READONLY;.  }
2070: 0a 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f  ..#ifdef SQLITE_
2080: 48 41 53 5f 43 4f 44 45 43 0a 20 20 2f 2a 20 42  HAS_CODEC.  /* B
2090: 61 63 6b 75 70 20 69 73 20 6e 6f 74 20 70 6f 73  ackup is not pos
20a0: 73 69 62 6c 65 20 69 66 20 74 68 65 20 70 61 67  sible if the pag
20b0: 65 20 73 69 7a 65 20 6f 66 20 74 68 65 20 64 65  e size of the de
20c0: 73 74 69 6e 61 74 69 6f 6e 20 69 73 20 63 68 61  stination is cha
20d0: 6e 67 69 6e 67 0a 20 20 2a 2a 20 61 20 61 20 63  nging.  ** a a c
20e0: 6f 64 65 63 20 69 73 20 69 6e 20 75 73 65 2e 0a  odec is in use..
20f0: 20 20 2a 2f 0a 20 20 69 66 28 20 6e 53 72 63 50    */.  if( nSrcP
2100: 67 73 7a 21 3d 6e 44 65 73 74 50 67 73 7a 20 26  gsz!=nDestPgsz &
2110: 26 20 73 71 6c 69 74 65 33 50 61 67 65 72 47 65  & sqlite3PagerGe
2120: 74 43 6f 64 65 63 28 70 44 65 73 74 50 61 67 65  tCodec(pDestPage
2130: 72 29 21 3d 30 20 29 7b 0a 20 20 20 20 72 63 20  r)!=0 ){.    rc 
2140: 3d 20 53 51 4c 49 54 45 5f 52 45 41 44 4f 4e 4c  = SQLITE_READONL
2150: 59 3b 0a 20 20 7d 0a 23 65 6e 64 69 66 0a 0a 20  Y;.  }.#endif.. 
2160: 20 2f 2a 20 54 68 69 73 20 6c 6f 6f 70 20 72 75   /* This loop ru
2170: 6e 73 20 6f 6e 63 65 20 66 6f 72 20 65 61 63 68  ns once for each
2180: 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 70 61 67   destination pag
2190: 65 20 73 70 61 6e 6e 65 64 20 62 79 20 74 68 65  e spanned by the
21a0: 20 73 6f 75 72 63 65 20 0a 20 20 2a 2a 20 70 61   source .  ** pa
21b0: 67 65 2e 20 46 6f 72 20 65 61 63 68 20 69 74 65  ge. For each ite
21c0: 72 61 74 69 6f 6e 2c 20 76 61 72 69 61 62 6c 65  ration, variable
21d0: 20 69 4f 66 66 20 69 73 20 73 65 74 20 74 6f 20   iOff is set to 
21e0: 74 68 65 20 62 79 74 65 20 6f 66 66 73 65 74 0a  the byte offset.
21f0: 20 20 2a 2a 20 6f 66 20 74 68 65 20 64 65 73 74    ** of the dest
2200: 69 6e 61 74 69 6f 6e 20 70 61 67 65 2e 0a 20 20  ination page..  
2210: 2a 2f 0a 20 20 66 6f 72 28 69 4f 66 66 3d 69 45  */.  for(iOff=iE
2220: 6e 64 2d 28 69 36 34 29 6e 53 72 63 50 67 73 7a  nd-(i64)nSrcPgsz
2230: 3b 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20  ; rc==SQLITE_OK 
2240: 26 26 20 69 4f 66 66 3c 69 45 6e 64 3b 20 69 4f  && iOff<iEnd; iO
2250: 66 66 2b 3d 6e 44 65 73 74 50 67 73 7a 29 7b 0a  ff+=nDestPgsz){.
2260: 20 20 20 20 44 62 50 61 67 65 20 2a 70 44 65 73      DbPage *pDes
2270: 74 50 67 20 3d 20 30 3b 0a 20 20 20 20 50 67 6e  tPg = 0;.    Pgn
2280: 6f 20 69 44 65 73 74 20 3d 20 28 50 67 6e 6f 29  o iDest = (Pgno)
2290: 28 69 4f 66 66 2f 6e 44 65 73 74 50 67 73 7a 29  (iOff/nDestPgsz)
22a0: 2b 31 3b 0a 20 20 20 20 69 66 28 20 69 44 65 73  +1;.    if( iDes
22b0: 74 3d 3d 50 45 4e 44 49 4e 47 5f 42 59 54 45 5f  t==PENDING_BYTE_
22c0: 50 41 47 45 28 70 2d 3e 70 44 65 73 74 2d 3e 70  PAGE(p->pDest->p
22d0: 42 74 29 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a  Bt) ) continue;.
22e0: 20 20 20 20 69 66 28 20 53 51 4c 49 54 45 5f 4f      if( SQLITE_O
22f0: 4b 3d 3d 28 72 63 20 3d 20 73 71 6c 69 74 65 33  K==(rc = sqlite3
2300: 50 61 67 65 72 47 65 74 28 70 44 65 73 74 50 61  PagerGet(pDestPa
2310: 67 65 72 2c 20 69 44 65 73 74 2c 20 26 70 44 65  ger, iDest, &pDe
2320: 73 74 50 67 29 29 0a 20 20 20 20 20 26 26 20 53  stPg)).     && S
2330: 51 4c 49 54 45 5f 4f 4b 3d 3d 28 72 63 20 3d 20  QLITE_OK==(rc = 
2340: 73 71 6c 69 74 65 33 50 61 67 65 72 57 72 69 74  sqlite3PagerWrit
2350: 65 28 70 44 65 73 74 50 67 29 29 0a 20 20 20 20  e(pDestPg)).    
2360: 29 7b 0a 20 20 20 20 20 20 63 6f 6e 73 74 20 75  ){.      const u
2370: 38 20 2a 7a 49 6e 20 3d 20 26 7a 53 72 63 44 61  8 *zIn = &zSrcDa
2380: 74 61 5b 69 4f 66 66 25 6e 53 72 63 50 67 73 7a  ta[iOff%nSrcPgsz
2390: 5d 3b 0a 20 20 20 20 20 20 75 38 20 2a 7a 44 65  ];.      u8 *zDe
23a0: 73 74 44 61 74 61 20 3d 20 73 71 6c 69 74 65 33  stData = sqlite3
23b0: 50 61 67 65 72 47 65 74 44 61 74 61 28 70 44 65  PagerGetData(pDe
23c0: 73 74 50 67 29 3b 0a 20 20 20 20 20 20 75 38 20  stPg);.      u8 
23d0: 2a 7a 4f 75 74 20 3d 20 26 7a 44 65 73 74 44 61  *zOut = &zDestDa
23e0: 74 61 5b 69 4f 66 66 25 6e 44 65 73 74 50 67 73  ta[iOff%nDestPgs
23f0: 7a 5d 3b 0a 0a 20 20 20 20 20 20 2f 2a 20 43 6f  z];..      /* Co
2400: 70 79 20 74 68 65 20 64 61 74 61 20 66 72 6f 6d  py the data from
2410: 20 74 68 65 20 73 6f 75 72 63 65 20 70 61 67 65   the source page
2420: 20 69 6e 74 6f 20 74 68 65 20 64 65 73 74 69 6e   into the destin
2430: 61 74 69 6f 6e 20 70 61 67 65 2e 0a 20 20 20 20  ation page..    
2440: 20 20 2a 2a 20 54 68 65 6e 20 63 6c 65 61 72 20    ** Then clear 
2450: 74 68 65 20 42 74 72 65 65 20 6c 61 79 65 72 20  the Btree layer 
2460: 4d 65 6d 50 61 67 65 2e 69 73 49 6e 69 74 20 66  MemPage.isInit f
2470: 6c 61 67 2e 20 42 6f 74 68 20 74 68 69 73 20 6d  lag. Both this m
2480: 6f 64 75 6c 65 0a 20 20 20 20 20 20 2a 2a 20 61  odule.      ** a
2490: 6e 64 20 74 68 65 20 70 61 67 65 72 20 63 6f 64  nd the pager cod
24a0: 65 20 75 73 65 20 74 68 69 73 20 74 72 69 63 6b  e use this trick
24b0: 20 28 63 6c 65 61 72 69 6e 67 20 74 68 65 20 66   (clearing the f
24c0: 69 72 73 74 20 62 79 74 65 0a 20 20 20 20 20 20  irst byte.      
24d0: 2a 2a 20 6f 66 20 74 68 65 20 70 61 67 65 20 27  ** of the page '
24e0: 65 78 74 72 61 27 20 73 70 61 63 65 20 74 6f 20  extra' space to 
24f0: 69 6e 76 61 6c 69 64 61 74 65 20 74 68 65 20 42  invalidate the B
2500: 74 72 65 65 20 6c 61 79 65 72 73 0a 20 20 20 20  tree layers.    
2510: 20 20 2a 2a 20 63 61 63 68 65 64 20 70 61 72 73    ** cached pars
2520: 65 20 6f 66 20 74 68 65 20 70 61 67 65 29 2e 20  e of the page). 
2530: 4d 65 6d 50 61 67 65 2e 69 73 49 6e 69 74 20 69  MemPage.isInit i
2540: 73 20 6d 61 72 6b 65 64 20 0a 20 20 20 20 20 20  s marked .      
2550: 2a 2a 20 22 4d 55 53 54 20 42 45 20 46 49 52 53  ** "MUST BE FIRS
2560: 54 22 20 66 6f 72 20 74 68 69 73 20 70 75 72 70  T" for this purp
2570: 6f 73 65 2e 0a 20 20 20 20 20 20 2a 2f 0a 20 20  ose..      */.  
2580: 20 20 20 20 6d 65 6d 63 70 79 28 7a 4f 75 74 2c      memcpy(zOut,
2590: 20 7a 49 6e 2c 20 6e 43 6f 70 79 29 3b 0a 20 20   zIn, nCopy);.  
25a0: 20 20 20 20 28 28 75 38 20 2a 29 73 71 6c 69 74      ((u8 *)sqlit
25b0: 65 33 50 61 67 65 72 47 65 74 45 78 74 72 61 28  e3PagerGetExtra(
25c0: 70 44 65 73 74 50 67 29 29 5b 30 5d 20 3d 20 30  pDestPg))[0] = 0
25d0: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 73 71 6c 69  ;.    }.    sqli
25e0: 74 65 33 50 61 67 65 72 55 6e 72 65 66 28 70 44  te3PagerUnref(pD
25f0: 65 73 74 50 67 29 3b 0a 20 20 7d 0a 0a 20 20 72  estPg);.  }..  r
2600: 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a  eturn rc;.}../*.
2610: 2a 2a 20 49 66 20 70 46 69 6c 65 20 69 73 20 63  ** If pFile is c
2620: 75 72 72 65 6e 74 6c 79 20 6c 61 72 67 65 72 20  urrently larger 
2630: 74 68 61 6e 20 69 53 69 7a 65 20 62 79 74 65 73  than iSize bytes
2640: 2c 20 74 68 65 6e 20 74 72 75 6e 63 61 74 65 20  , then truncate 
2650: 69 74 20 74 6f 0a 2a 2a 20 65 78 61 63 74 6c 79  it to.** exactly
2660: 20 69 53 69 7a 65 20 62 79 74 65 73 2e 20 49 66   iSize bytes. If
2670: 20 70 46 69 6c 65 20 69 73 20 6e 6f 74 20 6c 61   pFile is not la
2680: 72 67 65 72 20 74 68 61 6e 20 69 53 69 7a 65 20  rger than iSize 
2690: 62 79 74 65 73 2c 20 74 68 65 6e 0a 2a 2a 20 74  bytes, then.** t
26a0: 68 69 73 20 66 75 6e 63 74 69 6f 6e 20 69 73 20  his function is 
26b0: 61 20 6e 6f 2d 6f 70 2e 0a 2a 2a 0a 2a 2a 20 52  a no-op..**.** R
26c0: 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 20  eturn SQLITE_OK 
26d0: 69 66 20 65 76 65 72 79 74 68 69 6e 67 20 69 73  if everything is
26e0: 20 73 75 63 63 65 73 73 66 75 6c 2c 20 6f 72 20   successful, or 
26f0: 61 6e 20 53 51 4c 69 74 65 20 65 72 72 6f 72 20  an SQLite error 
2700: 0a 2a 2a 20 63 6f 64 65 20 69 66 20 61 6e 20 65  .** code if an e
2710: 72 72 6f 72 20 6f 63 63 75 72 73 2e 0a 2a 2f 0a  rror occurs..*/.
2720: 73 74 61 74 69 63 20 69 6e 74 20 62 61 63 6b 75  static int backu
2730: 70 54 72 75 6e 63 61 74 65 46 69 6c 65 28 73 71  pTruncateFile(sq
2740: 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46 69 6c  lite3_file *pFil
2750: 65 2c 20 69 36 34 20 69 53 69 7a 65 29 7b 0a 20  e, i64 iSize){. 
2760: 20 69 36 34 20 69 43 75 72 72 65 6e 74 3b 0a 20   i64 iCurrent;. 
2770: 20 69 6e 74 20 72 63 20 3d 20 73 71 6c 69 74 65   int rc = sqlite
2780: 33 4f 73 46 69 6c 65 53 69 7a 65 28 70 46 69 6c  3OsFileSize(pFil
2790: 65 2c 20 26 69 43 75 72 72 65 6e 74 29 3b 0a 20  e, &iCurrent);. 
27a0: 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f   if( rc==SQLITE_
27b0: 4f 4b 20 26 26 20 69 43 75 72 72 65 6e 74 3e 69  OK && iCurrent>i
27c0: 53 69 7a 65 20 29 7b 0a 20 20 20 20 72 63 20 3d  Size ){.    rc =
27d0: 20 73 71 6c 69 74 65 33 4f 73 54 72 75 6e 63 61   sqlite3OsTrunca
27e0: 74 65 28 70 46 69 6c 65 2c 20 69 53 69 7a 65 29  te(pFile, iSize)
27f0: 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72 6e 20 72  ;.  }.  return r
2800: 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 67 69  c;.}../*.** Regi
2810: 73 74 65 72 20 74 68 69 73 20 62 61 63 6b 75 70  ster this backup
2820: 20 6f 62 6a 65 63 74 20 77 69 74 68 20 74 68 65   object with the
2830: 20 61 73 73 6f 63 69 61 74 65 64 20 73 6f 75 72   associated sour
2840: 63 65 20 70 61 67 65 72 20 66 6f 72 0a 2a 2a 20  ce pager for.** 
2850: 63 61 6c 6c 62 61 63 6b 73 20 77 68 65 6e 20 70  callbacks when p
2860: 61 67 65 73 20 61 72 65 20 63 68 61 6e 67 65 64  ages are changed
2870: 20 6f 72 20 74 68 65 20 63 61 63 68 65 20 69 6e   or the cache in
2880: 76 61 6c 69 64 61 74 65 64 2e 0a 2a 2f 0a 73 74  validated..*/.st
2890: 61 74 69 63 20 76 6f 69 64 20 61 74 74 61 63 68  atic void attach
28a0: 42 61 63 6b 75 70 4f 62 6a 65 63 74 28 73 71 6c  BackupObject(sql
28b0: 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 29 7b  ite3_backup *p){
28c0: 0a 20 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75  .  sqlite3_backu
28d0: 70 20 2a 2a 70 70 3b 0a 20 20 61 73 73 65 72 74  p **pp;.  assert
28e0: 28 20 73 71 6c 69 74 65 33 42 74 72 65 65 48 6f  ( sqlite3BtreeHo
28f0: 6c 64 73 4d 75 74 65 78 28 70 2d 3e 70 53 72 63  ldsMutex(p->pSrc
2900: 29 20 29 3b 0a 20 20 70 70 20 3d 20 73 71 6c 69  ) );.  pp = sqli
2910: 74 65 33 50 61 67 65 72 42 61 63 6b 75 70 50 74  te3PagerBackupPt
2920: 72 28 73 71 6c 69 74 65 33 42 74 72 65 65 50 61  r(sqlite3BtreePa
2930: 67 65 72 28 70 2d 3e 70 53 72 63 29 29 3b 0a 20  ger(p->pSrc));. 
2940: 20 70 2d 3e 70 4e 65 78 74 20 3d 20 2a 70 70 3b   p->pNext = *pp;
2950: 0a 20 20 2a 70 70 20 3d 20 70 3b 0a 20 20 70 2d  .  *pp = p;.  p-
2960: 3e 69 73 41 74 74 61 63 68 65 64 20 3d 20 31 3b  >isAttached = 1;
2970: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 6f 70 79 20 6e  .}../*.** Copy n
2980: 50 61 67 65 20 70 61 67 65 73 20 66 72 6f 6d 20  Page pages from 
2990: 74 68 65 20 73 6f 75 72 63 65 20 62 2d 74 72 65  the source b-tre
29a0: 65 20 74 6f 20 74 68 65 20 64 65 73 74 69 6e 61  e to the destina
29b0: 74 69 6f 6e 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c  tion..*/.int sql
29c0: 69 74 65 33 5f 62 61 63 6b 75 70 5f 73 74 65 70  ite3_backup_step
29d0: 28 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20  (sqlite3_backup 
29e0: 2a 70 2c 20 69 6e 74 20 6e 50 61 67 65 29 7b 0a  *p, int nPage){.
29f0: 20 20 69 6e 74 20 72 63 3b 0a 20 20 69 6e 74 20    int rc;.  int 
2a00: 64 65 73 74 4d 6f 64 65 3b 20 20 20 20 20 20 20  destMode;       
2a10: 2f 2a 20 44 65 73 74 69 6e 61 74 69 6f 6e 20 6a  /* Destination j
2a20: 6f 75 72 6e 61 6c 20 6d 6f 64 65 20 2a 2f 0a 20  ournal mode */. 
2a30: 20 69 6e 74 20 70 67 73 7a 53 72 63 20 3d 20 30   int pgszSrc = 0
2a40: 3b 20 20 20 20 2f 2a 20 53 6f 75 72 63 65 20 70  ;    /* Source p
2a50: 61 67 65 20 73 69 7a 65 20 2a 2f 0a 20 20 69 6e  age size */.  in
2a60: 74 20 70 67 73 7a 44 65 73 74 20 3d 20 30 3b 20  t pgszDest = 0; 
2a70: 20 20 2f 2a 20 44 65 73 74 69 6e 61 74 69 6f 6e    /* Destination
2a80: 20 70 61 67 65 20 73 69 7a 65 20 2a 2f 0a 0a 20   page size */.. 
2a90: 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65   sqlite3_mutex_e
2aa0: 6e 74 65 72 28 70 2d 3e 70 53 72 63 44 62 2d 3e  nter(p->pSrcDb->
2ab0: 6d 75 74 65 78 29 3b 0a 20 20 73 71 6c 69 74 65  mutex);.  sqlite
2ac0: 33 42 74 72 65 65 45 6e 74 65 72 28 70 2d 3e 70  3BtreeEnter(p->p
2ad0: 53 72 63 29 3b 0a 20 20 69 66 28 20 70 2d 3e 70  Src);.  if( p->p
2ae0: 44 65 73 74 44 62 20 29 7b 0a 20 20 20 20 73 71  DestDb ){.    sq
2af0: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65  lite3_mutex_ente
2b00: 72 28 70 2d 3e 70 44 65 73 74 44 62 2d 3e 6d 75  r(p->pDestDb->mu
2b10: 74 65 78 29 3b 0a 20 20 7d 0a 0a 20 20 72 63 20  tex);.  }..  rc 
2b20: 3d 20 70 2d 3e 72 63 3b 0a 20 20 69 66 28 20 21  = p->rc;.  if( !
2b30: 69 73 46 61 74 61 6c 45 72 72 6f 72 28 72 63 29  isFatalError(rc)
2b40: 20 29 7b 0a 20 20 20 20 50 61 67 65 72 20 2a 20   ){.    Pager * 
2b50: 63 6f 6e 73 74 20 70 53 72 63 50 61 67 65 72 20  const pSrcPager 
2b60: 3d 20 73 71 6c 69 74 65 33 42 74 72 65 65 50 61  = sqlite3BtreePa
2b70: 67 65 72 28 70 2d 3e 70 53 72 63 29 3b 20 20 20  ger(p->pSrc);   
2b80: 20 20 2f 2a 20 53 6f 75 72 63 65 20 70 61 67 65    /* Source page
2b90: 72 20 2a 2f 0a 20 20 20 20 50 61 67 65 72 20 2a  r */.    Pager *
2ba0: 20 63 6f 6e 73 74 20 70 44 65 73 74 50 61 67 65   const pDestPage
2bb0: 72 20 3d 20 73 71 6c 69 74 65 33 42 74 72 65 65  r = sqlite3Btree
2bc0: 50 61 67 65 72 28 70 2d 3e 70 44 65 73 74 29 3b  Pager(p->pDest);
2bd0: 20 20 20 2f 2a 20 44 65 73 74 20 70 61 67 65 72     /* Dest pager
2be0: 20 2a 2f 0a 20 20 20 20 69 6e 74 20 69 69 3b 20   */.    int ii; 
2bf0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2c00: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 49 74             /* It
2c10: 65 72 61 74 6f 72 20 76 61 72 69 61 62 6c 65 20  erator variable 
2c20: 2a 2f 0a 20 20 20 20 69 6e 74 20 6e 53 72 63 50  */.    int nSrcP
2c30: 61 67 65 20 3d 20 2d 31 3b 20 20 20 20 20 20 20  age = -1;       
2c40: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 53 69 7a            /* Siz
2c50: 65 20 6f 66 20 73 6f 75 72 63 65 20 64 62 20 69  e of source db i
2c60: 6e 20 70 61 67 65 73 20 2a 2f 0a 20 20 20 20 69  n pages */.    i
2c70: 6e 74 20 62 43 6c 6f 73 65 54 72 61 6e 73 20 3d  nt bCloseTrans =
2c80: 20 30 3b 20 20 20 20 20 20 20 20 20 20 20 20 20   0;             
2c90: 20 20 2f 2a 20 54 72 75 65 20 69 66 20 73 72 63    /* True if src
2ca0: 20 64 62 20 72 65 71 75 69 72 65 73 20 75 6e 6c   db requires unl
2cb0: 6f 63 6b 69 6e 67 20 2a 2f 0a 0a 20 20 20 20 2f  ocking */..    /
2cc0: 2a 20 49 66 20 74 68 65 20 73 6f 75 72 63 65 20  * If the source 
2cd0: 70 61 67 65 72 20 69 73 20 63 75 72 72 65 6e 74  pager is current
2ce0: 6c 79 20 69 6e 20 61 20 77 72 69 74 65 2d 74 72  ly in a write-tr
2cf0: 61 6e 73 61 63 74 69 6f 6e 2c 20 72 65 74 75 72  ansaction, retur
2d00: 6e 0a 20 20 20 20 2a 2a 20 53 51 4c 49 54 45 5f  n.    ** SQLITE_
2d10: 42 55 53 59 20 69 6d 6d 65 64 69 61 74 65 6c 79  BUSY immediately
2d20: 2e 0a 20 20 20 20 2a 2f 0a 20 20 20 20 69 66 28  ..    */.    if(
2d30: 20 70 2d 3e 70 44 65 73 74 44 62 20 26 26 20 70   p->pDestDb && p
2d40: 2d 3e 70 53 72 63 2d 3e 70 42 74 2d 3e 69 6e 54  ->pSrc->pBt->inT
2d50: 72 61 6e 73 61 63 74 69 6f 6e 3d 3d 54 52 41 4e  ransaction==TRAN
2d60: 53 5f 57 52 49 54 45 20 29 7b 0a 20 20 20 20 20  S_WRITE ){.     
2d70: 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 42 55 53   rc = SQLITE_BUS
2d80: 59 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20  Y;.    }else{.  
2d90: 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f      rc = SQLITE_
2da0: 4f 4b 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f  OK;.    }..    /
2db0: 2a 20 4c 6f 63 6b 20 74 68 65 20 64 65 73 74 69  * Lock the desti
2dc0: 6e 61 74 69 6f 6e 20 64 61 74 61 62 61 73 65 2c  nation database,
2dd0: 20 69 66 20 69 74 20 69 73 20 6e 6f 74 20 6c 6f   if it is not lo
2de0: 63 6b 65 64 20 61 6c 72 65 61 64 79 2e 20 2a 2f  cked already. */
2df0: 0a 20 20 20 20 69 66 28 20 53 51 4c 49 54 45 5f  .    if( SQLITE_
2e00: 4f 4b 3d 3d 72 63 20 26 26 20 70 2d 3e 62 44 65  OK==rc && p->bDe
2e10: 73 74 4c 6f 63 6b 65 64 3d 3d 30 0a 20 20 20 20  stLocked==0.    
2e20: 20 26 26 20 53 51 4c 49 54 45 5f 4f 4b 3d 3d 28   && SQLITE_OK==(
2e30: 72 63 20 3d 20 73 71 6c 69 74 65 33 42 74 72 65  rc = sqlite3Btre
2e40: 65 42 65 67 69 6e 54 72 61 6e 73 28 70 2d 3e 70  eBeginTrans(p->p
2e50: 44 65 73 74 2c 20 32 29 29 20 0a 20 20 20 20 29  Dest, 2)) .    )
2e60: 7b 0a 20 20 20 20 20 20 70 2d 3e 62 44 65 73 74  {.      p->bDest
2e70: 4c 6f 63 6b 65 64 20 3d 20 31 3b 0a 20 20 20 20  Locked = 1;.    
2e80: 20 20 73 71 6c 69 74 65 33 42 74 72 65 65 47 65    sqlite3BtreeGe
2e90: 74 4d 65 74 61 28 70 2d 3e 70 44 65 73 74 2c 20  tMeta(p->pDest, 
2ea0: 42 54 52 45 45 5f 53 43 48 45 4d 41 5f 56 45 52  BTREE_SCHEMA_VER
2eb0: 53 49 4f 4e 2c 20 26 70 2d 3e 69 44 65 73 74 53  SION, &p->iDestS
2ec0: 63 68 65 6d 61 29 3b 0a 20 20 20 20 7d 0a 0a 20  chema);.    }.. 
2ed0: 20 20 20 2f 2a 20 49 66 20 74 68 65 72 65 20 69     /* If there i
2ee0: 73 20 6e 6f 20 6f 70 65 6e 20 72 65 61 64 2d 74  s no open read-t
2ef0: 72 61 6e 73 61 63 74 69 6f 6e 20 6f 6e 20 74 68  ransaction on th
2f00: 65 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73  e source databas
2f10: 65 2c 20 6f 70 65 6e 0a 20 20 20 20 2a 2a 20 6f  e, open.    ** o
2f20: 6e 65 20 6e 6f 77 2e 20 49 66 20 61 20 74 72 61  ne now. If a tra
2f30: 6e 73 61 63 74 69 6f 6e 20 69 73 20 6f 70 65 6e  nsaction is open
2f40: 65 64 20 68 65 72 65 2c 20 74 68 65 6e 20 69 74  ed here, then it
2f50: 20 77 69 6c 6c 20 62 65 20 63 6c 6f 73 65 64 0a   will be closed.
2f60: 20 20 20 20 2a 2a 20 62 65 66 6f 72 65 20 74 68      ** before th
2f70: 69 73 20 66 75 6e 63 74 69 6f 6e 20 65 78 69 74  is function exit
2f80: 73 2e 0a 20 20 20 20 2a 2f 0a 20 20 20 20 69 66  s..    */.    if
2f90: 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20  ( rc==SQLITE_OK 
2fa0: 26 26 20 30 3d 3d 73 71 6c 69 74 65 33 42 74 72  && 0==sqlite3Btr
2fb0: 65 65 49 73 49 6e 52 65 61 64 54 72 61 6e 73 28  eeIsInReadTrans(
2fc0: 70 2d 3e 70 53 72 63 29 20 29 7b 0a 20 20 20 20  p->pSrc) ){.    
2fd0: 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 42 74    rc = sqlite3Bt
2fe0: 72 65 65 42 65 67 69 6e 54 72 61 6e 73 28 70 2d  reeBeginTrans(p-
2ff0: 3e 70 53 72 63 2c 20 30 29 3b 0a 20 20 20 20 20  >pSrc, 0);.     
3000: 20 62 43 6c 6f 73 65 54 72 61 6e 73 20 3d 20 31   bCloseTrans = 1
3010: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 20  ;.    }..    /* 
3020: 44 6f 20 6e 6f 74 20 61 6c 6c 6f 77 20 62 61 63  Do not allow bac
3030: 6b 75 70 20 69 66 20 74 68 65 20 64 65 73 74 69  kup if the desti
3040: 6e 61 74 69 6f 6e 20 64 61 74 61 62 61 73 65 20  nation database 
3050: 69 73 20 69 6e 20 57 41 4c 20 6d 6f 64 65 0a 20  is in WAL mode. 
3060: 20 20 20 2a 2a 20 61 6e 64 20 74 68 65 20 70 61     ** and the pa
3070: 67 65 20 73 69 7a 65 73 20 61 72 65 20 64 69 66  ge sizes are dif
3080: 66 65 72 65 6e 74 20 62 65 74 77 65 65 6e 20 73  ferent between s
3090: 6f 75 72 63 65 20 61 6e 64 20 64 65 73 74 69 6e  ource and destin
30a0: 61 74 69 6f 6e 20 2a 2f 0a 20 20 20 20 70 67 73  ation */.    pgs
30b0: 7a 53 72 63 20 3d 20 73 71 6c 69 74 65 33 42 74  zSrc = sqlite3Bt
30c0: 72 65 65 47 65 74 50 61 67 65 53 69 7a 65 28 70  reeGetPageSize(p
30d0: 2d 3e 70 53 72 63 29 3b 0a 20 20 20 20 70 67 73  ->pSrc);.    pgs
30e0: 7a 44 65 73 74 20 3d 20 73 71 6c 69 74 65 33 42  zDest = sqlite3B
30f0: 74 72 65 65 47 65 74 50 61 67 65 53 69 7a 65 28  treeGetPageSize(
3100: 70 2d 3e 70 44 65 73 74 29 3b 0a 20 20 20 20 64  p->pDest);.    d
3110: 65 73 74 4d 6f 64 65 20 3d 20 73 71 6c 69 74 65  estMode = sqlite
3120: 33 50 61 67 65 72 47 65 74 4a 6f 75 72 6e 61 6c  3PagerGetJournal
3130: 4d 6f 64 65 28 73 71 6c 69 74 65 33 42 74 72 65  Mode(sqlite3Btre
3140: 65 50 61 67 65 72 28 70 2d 3e 70 44 65 73 74 29  ePager(p->pDest)
3150: 29 3b 0a 20 20 20 20 69 66 28 20 53 51 4c 49 54  );.    if( SQLIT
3160: 45 5f 4f 4b 3d 3d 72 63 20 26 26 20 64 65 73 74  E_OK==rc && dest
3170: 4d 6f 64 65 3d 3d 50 41 47 45 52 5f 4a 4f 55 52  Mode==PAGER_JOUR
3180: 4e 41 4c 4d 4f 44 45 5f 57 41 4c 20 26 26 20 70  NALMODE_WAL && p
3190: 67 73 7a 53 72 63 21 3d 70 67 73 7a 44 65 73 74  gszSrc!=pgszDest
31a0: 20 29 7b 0a 20 20 20 20 20 20 72 63 20 3d 20 53   ){.      rc = S
31b0: 51 4c 49 54 45 5f 52 45 41 44 4f 4e 4c 59 3b 0a  QLITE_READONLY;.
31c0: 20 20 20 20 7d 0a 20 20 0a 20 20 20 20 2f 2a 20      }.  .    /* 
31d0: 4e 6f 77 20 74 68 61 74 20 74 68 65 72 65 20 69  Now that there i
31e0: 73 20 61 20 72 65 61 64 2d 6c 6f 63 6b 20 6f 6e  s a read-lock on
31f0: 20 74 68 65 20 73 6f 75 72 63 65 20 64 61 74 61   the source data
3200: 62 61 73 65 2c 20 71 75 65 72 79 20 74 68 65 0a  base, query the.
3210: 20 20 20 20 2a 2a 20 73 6f 75 72 63 65 20 70 61      ** source pa
3220: 67 65 72 20 66 6f 72 20 74 68 65 20 6e 75 6d 62  ger for the numb
3230: 65 72 20 6f 66 20 70 61 67 65 73 20 69 6e 20 74  er of pages in t
3240: 68 65 20 64 61 74 61 62 61 73 65 2e 0a 20 20 20  he database..   
3250: 20 2a 2f 0a 20 20 20 20 6e 53 72 63 50 61 67 65   */.    nSrcPage
3260: 20 3d 20 28 69 6e 74 29 73 71 6c 69 74 65 33 42   = (int)sqlite3B
3270: 74 72 65 65 4c 61 73 74 50 61 67 65 28 70 2d 3e  treeLastPage(p->
3280: 70 53 72 63 29 3b 0a 20 20 20 20 61 73 73 65 72  pSrc);.    asser
3290: 74 28 20 6e 53 72 63 50 61 67 65 3e 3d 30 20 29  t( nSrcPage>=0 )
32a0: 3b 0a 20 20 20 20 66 6f 72 28 69 69 3d 30 3b 20  ;.    for(ii=0; 
32b0: 28 6e 50 61 67 65 3c 30 20 7c 7c 20 69 69 3c 6e  (nPage<0 || ii<n
32c0: 50 61 67 65 29 20 26 26 20 70 2d 3e 69 4e 65 78  Page) && p->iNex
32d0: 74 3c 3d 28 50 67 6e 6f 29 6e 53 72 63 50 61 67  t<=(Pgno)nSrcPag
32e0: 65 20 26 26 20 21 72 63 3b 20 69 69 2b 2b 29 7b  e && !rc; ii++){
32f0: 0a 20 20 20 20 20 20 63 6f 6e 73 74 20 50 67 6e  .      const Pgn
3300: 6f 20 69 53 72 63 50 67 20 3d 20 70 2d 3e 69 4e  o iSrcPg = p->iN
3310: 65 78 74 3b 20 20 20 20 20 20 20 20 20 20 20 20  ext;            
3320: 20 20 20 20 20 2f 2a 20 53 6f 75 72 63 65 20 70       /* Source p
3330: 61 67 65 20 6e 75 6d 62 65 72 20 2a 2f 0a 20 20  age number */.  
3340: 20 20 20 20 69 66 28 20 69 53 72 63 50 67 21 3d      if( iSrcPg!=
3350: 50 45 4e 44 49 4e 47 5f 42 59 54 45 5f 50 41 47  PENDING_BYTE_PAG
3360: 45 28 70 2d 3e 70 53 72 63 2d 3e 70 42 74 29 20  E(p->pSrc->pBt) 
3370: 29 7b 0a 20 20 20 20 20 20 20 20 44 62 50 61 67  ){.        DbPag
3380: 65 20 2a 70 53 72 63 50 67 3b 20 20 20 20 20 20  e *pSrcPg;      
3390: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
33a0: 20 20 20 20 20 20 20 2f 2a 20 53 6f 75 72 63 65         /* Source
33b0: 20 70 61 67 65 20 6f 62 6a 65 63 74 20 2a 2f 0a   page object */.
33c0: 20 20 20 20 20 20 20 20 72 63 20 3d 20 73 71 6c          rc = sql
33d0: 69 74 65 33 50 61 67 65 72 47 65 74 28 70 53 72  ite3PagerGet(pSr
33e0: 63 50 61 67 65 72 2c 20 69 53 72 63 50 67 2c 20  cPager, iSrcPg, 
33f0: 26 70 53 72 63 50 67 29 3b 0a 20 20 20 20 20 20  &pSrcPg);.      
3400: 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45    if( rc==SQLITE
3410: 5f 4f 4b 20 29 7b 0a 20 20 20 20 20 20 20 20 20  _OK ){.         
3420: 20 72 63 20 3d 20 62 61 63 6b 75 70 4f 6e 65 50   rc = backupOneP
3430: 61 67 65 28 70 2c 20 69 53 72 63 50 67 2c 20 73  age(p, iSrcPg, s
3440: 71 6c 69 74 65 33 50 61 67 65 72 47 65 74 44 61  qlite3PagerGetDa
3450: 74 61 28 70 53 72 63 50 67 29 29 3b 0a 20 20 20  ta(pSrcPg));.   
3460: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 50 61         sqlite3Pa
3470: 67 65 72 55 6e 72 65 66 28 70 53 72 63 50 67 29  gerUnref(pSrcPg)
3480: 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  ;.        }.    
3490: 20 20 7d 0a 20 20 20 20 20 20 70 2d 3e 69 4e 65    }.      p->iNe
34a0: 78 74 2b 2b 3b 0a 20 20 20 20 7d 0a 20 20 20 20  xt++;.    }.    
34b0: 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f  if( rc==SQLITE_O
34c0: 4b 20 29 7b 0a 20 20 20 20 20 20 70 2d 3e 6e 50  K ){.      p->nP
34d0: 61 67 65 63 6f 75 6e 74 20 3d 20 6e 53 72 63 50  agecount = nSrcP
34e0: 61 67 65 3b 0a 20 20 20 20 20 20 70 2d 3e 6e 52  age;.      p->nR
34f0: 65 6d 61 69 6e 69 6e 67 20 3d 20 6e 53 72 63 50  emaining = nSrcP
3500: 61 67 65 2b 31 2d 70 2d 3e 69 4e 65 78 74 3b 0a  age+1-p->iNext;.
3510: 20 20 20 20 20 20 69 66 28 20 70 2d 3e 69 4e 65        if( p->iNe
3520: 78 74 3e 28 50 67 6e 6f 29 6e 53 72 63 50 61 67  xt>(Pgno)nSrcPag
3530: 65 20 29 7b 0a 20 20 20 20 20 20 20 20 72 63 20  e ){.        rc 
3540: 3d 20 53 51 4c 49 54 45 5f 44 4f 4e 45 3b 0a 20  = SQLITE_DONE;. 
3550: 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 21       }else if( !
3560: 70 2d 3e 69 73 41 74 74 61 63 68 65 64 20 29 7b  p->isAttached ){
3570: 0a 20 20 20 20 20 20 20 20 61 74 74 61 63 68 42  .        attachB
3580: 61 63 6b 75 70 4f 62 6a 65 63 74 28 70 29 3b 0a  ackupObject(p);.
3590: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20        }.    }.  
35a0: 0a 20 20 20 20 2f 2a 20 55 70 64 61 74 65 20 74  .    /* Update t
35b0: 68 65 20 73 63 68 65 6d 61 20 76 65 72 73 69 6f  he schema versio
35c0: 6e 20 66 69 65 6c 64 20 69 6e 20 74 68 65 20 64  n field in the d
35d0: 65 73 74 69 6e 61 74 69 6f 6e 20 64 61 74 61 62  estination datab
35e0: 61 73 65 2e 20 54 68 69 73 0a 20 20 20 20 2a 2a  ase. This.    **
35f0: 20 69 73 20 74 6f 20 6d 61 6b 65 20 73 75 72 65   is to make sure
3600: 20 74 68 61 74 20 74 68 65 20 73 63 68 65 6d 61   that the schema
3610: 2d 76 65 72 73 69 6f 6e 20 72 65 61 6c 6c 79 20  -version really 
3620: 64 6f 65 73 20 63 68 61 6e 67 65 20 69 6e 0a 20  does change in. 
3630: 20 20 20 2a 2a 20 74 68 65 20 63 61 73 65 20 77     ** the case w
3640: 68 65 72 65 20 74 68 65 20 73 6f 75 72 63 65 20  here the source 
3650: 61 6e 64 20 64 65 73 74 69 6e 61 74 69 6f 6e 20  and destination 
3660: 64 61 74 61 62 61 73 65 73 20 68 61 76 65 20 74  databases have t
3670: 68 65 0a 20 20 20 20 2a 2a 20 73 61 6d 65 20 73  he.    ** same s
3680: 63 68 65 6d 61 20 76 65 72 73 69 6f 6e 2e 0a 20  chema version.. 
3690: 20 20 20 2a 2f 0a 20 20 20 20 69 66 28 20 72 63     */.    if( rc
36a0: 3d 3d 53 51 4c 49 54 45 5f 44 4f 4e 45 20 0a 20  ==SQLITE_DONE . 
36b0: 20 20 20 20 26 26 20 28 72 63 20 3d 20 73 71 6c      && (rc = sql
36c0: 69 74 65 33 42 74 72 65 65 55 70 64 61 74 65 4d  ite3BtreeUpdateM
36d0: 65 74 61 28 70 2d 3e 70 44 65 73 74 2c 31 2c 70  eta(p->pDest,1,p
36e0: 2d 3e 69 44 65 73 74 53 63 68 65 6d 61 2b 31 29  ->iDestSchema+1)
36f0: 29 3d 3d 53 51 4c 49 54 45 5f 4f 4b 0a 20 20 20  )==SQLITE_OK.   
3700: 20 29 7b 0a 20 20 20 20 20 20 69 6e 74 20 6e 44   ){.      int nD
3710: 65 73 74 54 72 75 6e 63 61 74 65 3b 0a 20 20 0a  estTruncate;.  .
3720: 20 20 20 20 20 20 69 66 28 20 70 2d 3e 70 44 65        if( p->pDe
3730: 73 74 44 62 20 29 7b 0a 20 20 20 20 20 20 20 20  stDb ){.        
3740: 73 71 6c 69 74 65 33 52 65 73 65 74 49 6e 74 65  sqlite3ResetInte
3750: 72 6e 61 6c 53 63 68 65 6d 61 28 70 2d 3e 70 44  rnalSchema(p->pD
3760: 65 73 74 44 62 2c 20 30 29 3b 0a 20 20 20 20 20  estDb, 0);.     
3770: 20 7d 0a 0a 20 20 20 20 20 20 2f 2a 20 53 65 74   }..      /* Set
3780: 20 6e 44 65 73 74 54 72 75 6e 63 61 74 65 20 74   nDestTruncate t
3790: 6f 20 74 68 65 20 66 69 6e 61 6c 20 6e 75 6d 62  o the final numb
37a0: 65 72 20 6f 66 20 70 61 67 65 73 20 69 6e 20 74  er of pages in t
37b0: 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e 0a 20  he destination. 
37c0: 20 20 20 20 20 2a 2a 20 64 61 74 61 62 61 73 65       ** database
37d0: 2e 20 54 68 65 20 63 6f 6d 70 6c 69 63 61 74 69  . The complicati
37e0: 6f 6e 20 68 65 72 65 20 69 73 20 74 68 61 74 20  on here is that 
37f0: 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e 20  the destination 
3800: 70 61 67 65 0a 20 20 20 20 20 20 2a 2a 20 73 69  page.      ** si
3810: 7a 65 20 6d 61 79 20 62 65 20 64 69 66 66 65 72  ze may be differ
3820: 65 6e 74 20 74 6f 20 74 68 65 20 73 6f 75 72 63  ent to the sourc
3830: 65 20 70 61 67 65 20 73 69 7a 65 2e 20 0a 20 20  e page size. .  
3840: 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 2a 2a 20      **.      ** 
3850: 49 66 20 74 68 65 20 73 6f 75 72 63 65 20 70 61  If the source pa
3860: 67 65 20 73 69 7a 65 20 69 73 20 73 6d 61 6c 6c  ge size is small
3870: 65 72 20 74 68 61 6e 20 74 68 65 20 64 65 73 74  er than the dest
3880: 69 6e 61 74 69 6f 6e 20 70 61 67 65 20 73 69 7a  ination page siz
3890: 65 2c 20 0a 20 20 20 20 20 20 2a 2a 20 72 6f 75  e, .      ** rou
38a0: 6e 64 20 75 70 2e 20 49 6e 20 74 68 69 73 20 63  nd up. In this c
38b0: 61 73 65 20 74 68 65 20 63 61 6c 6c 20 74 6f 20  ase the call to 
38c0: 73 71 6c 69 74 65 33 4f 73 54 72 75 6e 63 61 74  sqlite3OsTruncat
38d0: 65 28 29 20 62 65 6c 6f 77 20 77 69 6c 6c 0a 20  e() below will. 
38e0: 20 20 20 20 20 2a 2a 20 66 69 78 20 74 68 65 20       ** fix the 
38f0: 73 69 7a 65 20 6f 66 20 74 68 65 20 66 69 6c 65  size of the file
3900: 2e 20 48 6f 77 65 76 65 72 20 69 74 20 69 73 20  . However it is 
3910: 69 6d 70 6f 72 74 61 6e 74 20 74 6f 20 63 61 6c  important to cal
3920: 6c 0a 20 20 20 20 20 20 2a 2a 20 73 71 6c 69 74  l.      ** sqlit
3930: 65 33 50 61 67 65 72 54 72 75 6e 63 61 74 65 49  e3PagerTruncateI
3940: 6d 61 67 65 28 29 20 68 65 72 65 20 73 6f 20 74  mage() here so t
3950: 68 61 74 20 61 6e 79 20 70 61 67 65 73 20 69 6e  hat any pages in
3960: 20 74 68 65 20 0a 20 20 20 20 20 20 2a 2a 20 64   the .      ** d
3970: 65 73 74 69 6e 61 74 69 6f 6e 20 66 69 6c 65 20  estination file 
3980: 74 68 61 74 20 6c 69 65 20 62 65 79 6f 6e 64 20  that lie beyond 
3990: 74 68 65 20 6e 44 65 73 74 54 72 75 6e 63 61 74  the nDestTruncat
39a0: 65 20 70 61 67 65 20 6d 61 72 6b 20 61 72 65 0a  e page mark are.
39b0: 20 20 20 20 20 20 2a 2a 20 6a 6f 75 72 6e 61 6c        ** journal
39c0: 6c 65 64 20 62 79 20 50 61 67 65 72 43 6f 6d 6d  led by PagerComm
39d0: 69 74 50 68 61 73 65 4f 6e 65 28 29 20 62 65 66  itPhaseOne() bef
39e0: 6f 72 65 20 74 68 65 79 20 61 72 65 20 64 65 73  ore they are des
39f0: 74 72 6f 79 65 64 0a 20 20 20 20 20 20 2a 2a 20  troyed.      ** 
3a00: 62 79 20 74 68 65 20 66 69 6c 65 20 74 72 75 6e  by the file trun
3a10: 63 61 74 69 6f 6e 2e 0a 20 20 20 20 20 20 2a 2f  cation..      */
3a20: 0a 20 20 20 20 20 20 61 73 73 65 72 74 28 20 70  .      assert( p
3a30: 67 73 7a 53 72 63 3d 3d 73 71 6c 69 74 65 33 42  gszSrc==sqlite3B
3a40: 74 72 65 65 47 65 74 50 61 67 65 53 69 7a 65 28  treeGetPageSize(
3a50: 70 2d 3e 70 53 72 63 29 20 29 3b 0a 20 20 20 20  p->pSrc) );.    
3a60: 20 20 61 73 73 65 72 74 28 20 70 67 73 7a 44 65    assert( pgszDe
3a70: 73 74 3d 3d 73 71 6c 69 74 65 33 42 74 72 65 65  st==sqlite3Btree
3a80: 47 65 74 50 61 67 65 53 69 7a 65 28 70 2d 3e 70  GetPageSize(p->p
3a90: 44 65 73 74 29 20 29 3b 0a 20 20 20 20 20 20 69  Dest) );.      i
3aa0: 66 28 20 70 67 73 7a 53 72 63 3c 70 67 73 7a 44  f( pgszSrc<pgszD
3ab0: 65 73 74 20 29 7b 0a 20 20 20 20 20 20 20 20 69  est ){.        i
3ac0: 6e 74 20 72 61 74 69 6f 20 3d 20 70 67 73 7a 44  nt ratio = pgszD
3ad0: 65 73 74 2f 70 67 73 7a 53 72 63 3b 0a 20 20 20  est/pgszSrc;.   
3ae0: 20 20 20 20 20 6e 44 65 73 74 54 72 75 6e 63 61       nDestTrunca
3af0: 74 65 20 3d 20 28 6e 53 72 63 50 61 67 65 2b 72  te = (nSrcPage+r
3b00: 61 74 69 6f 2d 31 29 2f 72 61 74 69 6f 3b 0a 20  atio-1)/ratio;. 
3b10: 20 20 20 20 20 20 20 69 66 28 20 6e 44 65 73 74         if( nDest
3b20: 54 72 75 6e 63 61 74 65 3d 3d 28 69 6e 74 29 50  Truncate==(int)P
3b30: 45 4e 44 49 4e 47 5f 42 59 54 45 5f 50 41 47 45  ENDING_BYTE_PAGE
3b40: 28 70 2d 3e 70 44 65 73 74 2d 3e 70 42 74 29 20  (p->pDest->pBt) 
3b50: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 6e 44 65  ){.          nDe
3b60: 73 74 54 72 75 6e 63 61 74 65 2d 2d 3b 0a 20 20  stTruncate--;.  
3b70: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 65        }.      }e
3b80: 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 6e 44 65  lse{.        nDe
3b90: 73 74 54 72 75 6e 63 61 74 65 20 3d 20 6e 53 72  stTruncate = nSr
3ba0: 63 50 61 67 65 20 2a 20 28 70 67 73 7a 53 72 63  cPage * (pgszSrc
3bb0: 2f 70 67 73 7a 44 65 73 74 29 3b 0a 20 20 20 20  /pgszDest);.    
3bc0: 20 20 7d 0a 20 20 20 20 20 20 73 71 6c 69 74 65    }.      sqlite
3bd0: 33 50 61 67 65 72 54 72 75 6e 63 61 74 65 49 6d  3PagerTruncateIm
3be0: 61 67 65 28 70 44 65 73 74 50 61 67 65 72 2c 20  age(pDestPager, 
3bf0: 6e 44 65 73 74 54 72 75 6e 63 61 74 65 29 3b 0a  nDestTruncate);.
3c00: 0a 20 20 20 20 20 20 69 66 28 20 70 67 73 7a 53  .      if( pgszS
3c10: 72 63 3c 70 67 73 7a 44 65 73 74 20 29 7b 0a 20  rc<pgszDest ){. 
3c20: 20 20 20 20 20 20 20 2f 2a 20 49 66 20 74 68 65         /* If the
3c30: 20 73 6f 75 72 63 65 20 70 61 67 65 2d 73 69 7a   source page-siz
3c40: 65 20 69 73 20 73 6d 61 6c 6c 65 72 20 74 68 61  e is smaller tha
3c50: 6e 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f  n the destinatio
3c60: 6e 20 70 61 67 65 2d 73 69 7a 65 2c 0a 20 20 20  n page-size,.   
3c70: 20 20 20 20 20 2a 2a 20 74 77 6f 20 65 78 74 72       ** two extr
3c80: 61 20 74 68 69 6e 67 73 20 6d 61 79 20 6e 65 65  a things may nee
3c90: 64 20 74 6f 20 68 61 70 70 65 6e 3a 0a 20 20 20  d to happen:.   
3ca0: 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 20 20       **.        
3cb0: 2a 2a 20 20 20 2a 20 54 68 65 20 64 65 73 74 69  **   * The desti
3cc0: 6e 61 74 69 6f 6e 20 6d 61 79 20 6e 65 65 64 20  nation may need 
3cd0: 74 6f 20 62 65 20 74 72 75 6e 63 61 74 65 64 2c  to be truncated,
3ce0: 20 61 6e 64 0a 20 20 20 20 20 20 20 20 2a 2a 0a   and.        **.
3cf0: 20 20 20 20 20 20 20 20 2a 2a 20 20 20 2a 20 44          **   * D
3d00: 61 74 61 20 73 74 6f 72 65 64 20 6f 6e 20 74 68  ata stored on th
3d10: 65 20 70 61 67 65 73 20 69 6d 6d 65 64 69 61 74  e pages immediat
3d20: 65 6c 79 20 66 6f 6c 6c 6f 77 69 6e 67 20 74 68  ely following th
3d30: 65 20 0a 20 20 20 20 20 20 20 20 2a 2a 20 20 20  e .        **   
3d40: 20 20 70 65 6e 64 69 6e 67 2d 62 79 74 65 20 70    pending-byte p
3d50: 61 67 65 20 69 6e 20 74 68 65 20 73 6f 75 72 63  age in the sourc
3d60: 65 20 64 61 74 61 62 61 73 65 20 6d 61 79 20 6e  e database may n
3d70: 65 65 64 20 74 6f 20 62 65 0a 20 20 20 20 20 20  eed to be.      
3d80: 20 20 2a 2a 20 20 20 20 20 63 6f 70 69 65 64 20    **     copied 
3d90: 69 6e 74 6f 20 74 68 65 20 64 65 73 74 69 6e 61  into the destina
3da0: 74 69 6f 6e 20 64 61 74 61 62 61 73 65 2e 0a 20  tion database.. 
3db0: 20 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20 20         */.      
3dc0: 20 20 63 6f 6e 73 74 20 69 36 34 20 69 53 69 7a    const i64 iSiz
3dd0: 65 20 3d 20 28 69 36 34 29 70 67 73 7a 53 72 63  e = (i64)pgszSrc
3de0: 20 2a 20 28 69 36 34 29 6e 53 72 63 50 61 67 65   * (i64)nSrcPage
3df0: 3b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  ;.        sqlite
3e00: 33 5f 66 69 6c 65 20 2a 20 63 6f 6e 73 74 20 70  3_file * const p
3e10: 46 69 6c 65 20 3d 20 73 71 6c 69 74 65 33 50 61  File = sqlite3Pa
3e20: 67 65 72 46 69 6c 65 28 70 44 65 73 74 50 61 67  gerFile(pDestPag
3e30: 65 72 29 3b 0a 20 20 20 20 20 20 20 20 69 36 34  er);.        i64
3e40: 20 69 4f 66 66 3b 0a 20 20 20 20 20 20 20 20 69   iOff;.        i
3e50: 36 34 20 69 45 6e 64 3b 0a 0a 20 20 20 20 20 20  64 iEnd;..      
3e60: 20 20 61 73 73 65 72 74 28 20 70 46 69 6c 65 20    assert( pFile 
3e70: 29 3b 0a 20 20 20 20 20 20 20 20 61 73 73 65 72  );.        asser
3e80: 74 28 20 28 69 36 34 29 6e 44 65 73 74 54 72 75  t( (i64)nDestTru
3e90: 6e 63 61 74 65 2a 28 69 36 34 29 70 67 73 7a 44  ncate*(i64)pgszD
3ea0: 65 73 74 20 3e 3d 20 69 53 69 7a 65 20 7c 7c 20  est >= iSize || 
3eb0: 28 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  (.              
3ec0: 6e 44 65 73 74 54 72 75 6e 63 61 74 65 3d 3d 28  nDestTruncate==(
3ed0: 69 6e 74 29 28 50 45 4e 44 49 4e 47 5f 42 59 54  int)(PENDING_BYT
3ee0: 45 5f 50 41 47 45 28 70 2d 3e 70 44 65 73 74 2d  E_PAGE(p->pDest-
3ef0: 3e 70 42 74 29 2d 31 29 0a 20 20 20 20 20 20 20  >pBt)-1).       
3f00: 20 20 20 20 26 26 20 69 53 69 7a 65 3e 3d 50 45      && iSize>=PE
3f10: 4e 44 49 4e 47 5f 42 59 54 45 20 26 26 20 69 53  NDING_BYTE && iS
3f20: 69 7a 65 3c 3d 50 45 4e 44 49 4e 47 5f 42 59 54  ize<=PENDING_BYT
3f30: 45 2b 70 67 73 7a 44 65 73 74 0a 20 20 20 20 20  E+pgszDest.     
3f40: 20 20 20 29 29 3b 0a 20 20 20 20 20 20 20 20 69     ));.        i
3f50: 45 6e 64 20 3d 20 4d 49 4e 28 50 45 4e 44 49 4e  End = MIN(PENDIN
3f60: 47 5f 42 59 54 45 20 2b 20 70 67 73 7a 44 65 73  G_BYTE + pgszDes
3f70: 74 2c 20 69 53 69 7a 65 29 3b 0a 20 20 20 20 20  t, iSize);.     
3f80: 20 20 20 66 6f 72 28 0a 20 20 20 20 20 20 20 20     for(.        
3f90: 20 20 69 4f 66 66 3d 50 45 4e 44 49 4e 47 5f 42    iOff=PENDING_B
3fa0: 59 54 45 2b 70 67 73 7a 53 72 63 3b 20 0a 20 20  YTE+pgszSrc; .  
3fb0: 20 20 20 20 20 20 20 20 72 63 3d 3d 53 51 4c 49          rc==SQLI
3fc0: 54 45 5f 4f 4b 20 26 26 20 69 4f 66 66 3c 69 45  TE_OK && iOff<iE
3fd0: 6e 64 3b 20 0a 20 20 20 20 20 20 20 20 20 20 69  nd; .          i
3fe0: 4f 66 66 2b 3d 70 67 73 7a 53 72 63 0a 20 20 20  Off+=pgszSrc.   
3ff0: 20 20 20 20 20 29 7b 0a 20 20 20 20 20 20 20 20       ){.        
4000: 20 20 50 67 48 64 72 20 2a 70 53 72 63 50 67 20    PgHdr *pSrcPg 
4010: 3d 20 30 3b 0a 20 20 20 20 20 20 20 20 20 20 63  = 0;.          c
4020: 6f 6e 73 74 20 50 67 6e 6f 20 69 53 72 63 50 67  onst Pgno iSrcPg
4030: 20 3d 20 28 50 67 6e 6f 29 28 28 69 4f 66 66 2f   = (Pgno)((iOff/
4040: 70 67 73 7a 53 72 63 29 2b 31 29 3b 0a 20 20 20  pgszSrc)+1);.   
4050: 20 20 20 20 20 20 20 72 63 20 3d 20 73 71 6c 69         rc = sqli
4060: 74 65 33 50 61 67 65 72 47 65 74 28 70 53 72 63  te3PagerGet(pSrc
4070: 50 61 67 65 72 2c 20 69 53 72 63 50 67 2c 20 26  Pager, iSrcPg, &
4080: 70 53 72 63 50 67 29 3b 0a 20 20 20 20 20 20 20  pSrcPg);.       
4090: 20 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54     if( rc==SQLIT
40a0: 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 20 20 20 20  E_OK ){.        
40b0: 20 20 20 20 75 38 20 2a 7a 44 61 74 61 20 3d 20      u8 *zData = 
40c0: 73 71 6c 69 74 65 33 50 61 67 65 72 47 65 74 44  sqlite3PagerGetD
40d0: 61 74 61 28 70 53 72 63 50 67 29 3b 0a 20 20 20  ata(pSrcPg);.   
40e0: 20 20 20 20 20 20 20 20 20 72 63 20 3d 20 73 71           rc = sq
40f0: 6c 69 74 65 33 4f 73 57 72 69 74 65 28 70 46 69  lite3OsWrite(pFi
4100: 6c 65 2c 20 7a 44 61 74 61 2c 20 70 67 73 7a 53  le, zData, pgszS
4110: 72 63 2c 20 69 4f 66 66 29 3b 0a 20 20 20 20 20  rc, iOff);.     
4120: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
4130: 20 73 71 6c 69 74 65 33 50 61 67 65 72 55 6e 72   sqlite3PagerUnr
4140: 65 66 28 70 53 72 63 50 67 29 3b 0a 20 20 20 20  ef(pSrcPg);.    
4150: 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 69 66      }.        if
4160: 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20  ( rc==SQLITE_OK 
4170: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 72 63 20  ){.          rc 
4180: 3d 20 73 71 6c 69 74 65 33 50 61 67 65 72 43 6f  = sqlite3PagerCo
4190: 6d 6d 69 74 50 68 61 73 65 4f 6e 65 28 70 44 65  mmitPhaseOne(pDe
41a0: 73 74 50 61 67 65 72 2c 20 30 2c 20 31 29 3b 0a  stPager, 0, 1);.
41b0: 20 20 20 20 20 20 20 20 20 20 69 66 28 20 72 63            if( rc
41c0: 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20  ==SQLITE_OK ){. 
41d0: 20 20 20 20 20 20 20 20 20 20 20 72 63 20 3d 20             rc = 
41e0: 62 61 63 6b 75 70 54 72 75 6e 63 61 74 65 46 69  backupTruncateFi
41f0: 6c 65 28 70 46 69 6c 65 2c 20 69 53 69 7a 65 29  le(pFile, iSize)
4200: 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20  ;.          }.  
4210: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 65        }.      }e
4220: 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 72 63 20  lse{.        rc 
4230: 3d 20 73 71 6c 69 74 65 33 50 61 67 65 72 43 6f  = sqlite3PagerCo
4240: 6d 6d 69 74 50 68 61 73 65 4f 6e 65 28 70 44 65  mmitPhaseOne(pDe
4250: 73 74 50 61 67 65 72 2c 20 30 2c 20 30 29 3b 0a  stPager, 0, 0);.
4260: 20 20 20 20 20 20 7d 0a 20 20 0a 20 20 20 20 20        }.  .     
4270: 20 2f 2a 20 46 69 6e 69 73 68 20 63 6f 6d 6d 69   /* Finish commi
4280: 74 74 69 6e 67 20 74 68 65 20 74 72 61 6e 73 61  tting the transa
4290: 63 74 69 6f 6e 20 74 6f 20 74 68 65 20 64 65 73  ction to the des
42a0: 74 69 6e 61 74 69 6f 6e 20 64 61 74 61 62 61 73  tination databas
42b0: 65 2e 20 2a 2f 0a 20 20 20 20 20 20 69 66 28 20  e. */.      if( 
42c0: 53 51 4c 49 54 45 5f 4f 4b 3d 3d 72 63 0a 20 20  SQLITE_OK==rc.  
42d0: 20 20 20 20 20 26 26 20 53 51 4c 49 54 45 5f 4f       && SQLITE_O
42e0: 4b 3d 3d 28 72 63 20 3d 20 73 71 6c 69 74 65 33  K==(rc = sqlite3
42f0: 42 74 72 65 65 43 6f 6d 6d 69 74 50 68 61 73 65  BtreeCommitPhase
4300: 54 77 6f 28 70 2d 3e 70 44 65 73 74 29 29 0a 20  Two(p->pDest)). 
4310: 20 20 20 20 20 29 7b 0a 20 20 20 20 20 20 20 20       ){.        
4320: 72 63 20 3d 20 53 51 4c 49 54 45 5f 44 4f 4e 45  rc = SQLITE_DONE
4330: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a  ;.      }.    }.
4340: 20 20 0a 20 20 20 20 2f 2a 20 49 66 20 62 43 6c    .    /* If bCl
4350: 6f 73 65 54 72 61 6e 73 20 69 73 20 74 72 75 65  oseTrans is true
4360: 2c 20 74 68 65 6e 20 74 68 69 73 20 66 75 6e 63  , then this func
4370: 74 69 6f 6e 20 6f 70 65 6e 65 64 20 61 20 72 65  tion opened a re
4380: 61 64 20 74 72 61 6e 73 61 63 74 69 6f 6e 0a 20  ad transaction. 
4390: 20 20 20 2a 2a 20 6f 6e 20 74 68 65 20 73 6f 75     ** on the sou
43a0: 72 63 65 20 64 61 74 61 62 61 73 65 2e 20 43 6c  rce database. Cl
43b0: 6f 73 65 20 74 68 65 20 72 65 61 64 20 74 72 61  ose the read tra
43c0: 6e 73 61 63 74 69 6f 6e 20 68 65 72 65 2e 20 54  nsaction here. T
43d0: 68 65 72 65 20 69 73 0a 20 20 20 20 2a 2a 20 6e  here is.    ** n
43e0: 6f 20 6e 65 65 64 20 74 6f 20 63 68 65 63 6b 20  o need to check 
43f0: 74 68 65 20 72 65 74 75 72 6e 20 76 61 6c 75 65  the return value
4400: 73 20 6f 66 20 74 68 65 20 62 74 72 65 65 20 6d  s of the btree m
4410: 65 74 68 6f 64 73 20 68 65 72 65 2c 20 61 73 0a  ethods here, as.
4420: 20 20 20 20 2a 2a 20 22 63 6f 6d 6d 69 74 74 69      ** "committi
4430: 6e 67 22 20 61 20 72 65 61 64 2d 6f 6e 6c 79 20  ng" a read-only 
4440: 74 72 61 6e 73 61 63 74 69 6f 6e 20 63 61 6e 6e  transaction cann
4450: 6f 74 20 66 61 69 6c 2e 0a 20 20 20 20 2a 2f 0a  ot fail..    */.
4460: 20 20 20 20 69 66 28 20 62 43 6c 6f 73 65 54 72      if( bCloseTr
4470: 61 6e 73 20 29 7b 0a 20 20 20 20 20 20 54 45 53  ans ){.      TES
4480: 54 4f 4e 4c 59 28 20 69 6e 74 20 72 63 32 20 29  TONLY( int rc2 )
4490: 3b 0a 20 20 20 20 20 20 54 45 53 54 4f 4e 4c 59  ;.      TESTONLY
44a0: 28 20 72 63 32 20 20 3d 20 29 20 73 71 6c 69 74  ( rc2  = ) sqlit
44b0: 65 33 42 74 72 65 65 43 6f 6d 6d 69 74 50 68 61  e3BtreeCommitPha
44c0: 73 65 4f 6e 65 28 70 2d 3e 70 53 72 63 2c 20 30  seOne(p->pSrc, 0
44d0: 29 3b 0a 20 20 20 20 20 20 54 45 53 54 4f 4e 4c  );.      TESTONL
44e0: 59 28 20 72 63 32 20 7c 3d 20 29 20 73 71 6c 69  Y( rc2 |= ) sqli
44f0: 74 65 33 42 74 72 65 65 43 6f 6d 6d 69 74 50 68  te3BtreeCommitPh
4500: 61 73 65 54 77 6f 28 70 2d 3e 70 53 72 63 29 3b  aseTwo(p->pSrc);
4510: 0a 20 20 20 20 20 20 61 73 73 65 72 74 28 20 72  .      assert( r
4520: 63 32 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 3b  c2==SQLITE_OK );
4530: 0a 20 20 20 20 7d 0a 20 20 0a 20 20 20 20 69 66  .    }.  .    if
4540: 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 49 4f 45  ( rc==SQLITE_IOE
4550: 52 52 5f 4e 4f 4d 45 4d 20 29 7b 0a 20 20 20 20  RR_NOMEM ){.    
4560: 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 4e 4f    rc = SQLITE_NO
4570: 4d 45 4d 3b 0a 20 20 20 20 7d 0a 20 20 20 20 70  MEM;.    }.    p
4580: 2d 3e 72 63 20 3d 20 72 63 3b 0a 20 20 7d 0a 20  ->rc = rc;.  }. 
4590: 20 69 66 28 20 70 2d 3e 70 44 65 73 74 44 62 20   if( p->pDestDb 
45a0: 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 6d  ){.    sqlite3_m
45b0: 75 74 65 78 5f 6c 65 61 76 65 28 70 2d 3e 70 44  utex_leave(p->pD
45c0: 65 73 74 44 62 2d 3e 6d 75 74 65 78 29 3b 0a 20  estDb->mutex);. 
45d0: 20 7d 0a 20 20 73 71 6c 69 74 65 33 42 74 72 65   }.  sqlite3Btre
45e0: 65 4c 65 61 76 65 28 70 2d 3e 70 53 72 63 29 3b  eLeave(p->pSrc);
45f0: 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78  .  sqlite3_mutex
4600: 5f 6c 65 61 76 65 28 70 2d 3e 70 53 72 63 44 62  _leave(p->pSrcDb
4610: 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 72 65 74 75  ->mutex);.  retu
4620: 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20  rn rc;.}../*.** 
4630: 52 65 6c 65 61 73 65 20 61 6c 6c 20 72 65 73 6f  Release all reso
4640: 75 72 63 65 73 20 61 73 73 6f 63 69 61 74 65 64  urces associated
4650: 20 77 69 74 68 20 61 6e 20 73 71 6c 69 74 65 33   with an sqlite3
4660: 5f 62 61 63 6b 75 70 2a 20 68 61 6e 64 6c 65 2e  _backup* handle.
4670: 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f  .*/.int sqlite3_
4680: 62 61 63 6b 75 70 5f 66 69 6e 69 73 68 28 73 71  backup_finish(sq
4690: 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 29  lite3_backup *p)
46a0: 7b 0a 20 20 73 71 6c 69 74 65 33 5f 62 61 63 6b  {.  sqlite3_back
46b0: 75 70 20 2a 2a 70 70 3b 20 20 20 20 20 20 20 20  up **pp;        
46c0: 20 20 20 20 20 20 20 20 20 2f 2a 20 50 74 72 20           /* Ptr 
46d0: 74 6f 20 68 65 61 64 20 6f 66 20 70 61 67 65 72  to head of pager
46e0: 73 20 62 61 63 6b 75 70 20 6c 69 73 74 20 2a 2f  s backup list */
46f0: 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78  .  sqlite3_mutex
4700: 20 2a 6d 75 74 65 78 3b 20 20 20 20 20 20 20 20   *mutex;        
4710: 20 20 20 20 20 20 20 20 2f 2a 20 4d 75 74 65 78          /* Mutex
4720: 20 74 6f 20 70 72 6f 74 65 63 74 20 73 6f 75 72   to protect sour
4730: 63 65 20 64 61 74 61 62 61 73 65 20 2a 2f 0a 20  ce database */. 
4740: 20 69 6e 74 20 72 63 3b 20 20 20 20 20 20 20 20   int rc;        
4750: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4760: 20 20 20 20 20 20 2f 2a 20 56 61 6c 75 65 20 74        /* Value t
4770: 6f 20 72 65 74 75 72 6e 20 2a 2f 0a 0a 20 20 2f  o return */..  /
4780: 2a 20 45 6e 74 65 72 20 74 68 65 20 6d 75 74 65  * Enter the mute
4790: 78 65 73 20 2a 2f 0a 20 20 69 66 28 20 70 3d 3d  xes */.  if( p==
47a0: 30 20 29 20 72 65 74 75 72 6e 20 53 51 4c 49 54  0 ) return SQLIT
47b0: 45 5f 4f 4b 3b 0a 20 20 73 71 6c 69 74 65 33 5f  E_OK;.  sqlite3_
47c0: 6d 75 74 65 78 5f 65 6e 74 65 72 28 70 2d 3e 70  mutex_enter(p->p
47d0: 53 72 63 44 62 2d 3e 6d 75 74 65 78 29 3b 0a 20  SrcDb->mutex);. 
47e0: 20 73 71 6c 69 74 65 33 42 74 72 65 65 45 6e 74   sqlite3BtreeEnt
47f0: 65 72 28 70 2d 3e 70 53 72 63 29 3b 0a 20 20 6d  er(p->pSrc);.  m
4800: 75 74 65 78 20 3d 20 70 2d 3e 70 53 72 63 44 62  utex = p->pSrcDb
4810: 2d 3e 6d 75 74 65 78 3b 0a 20 20 69 66 28 20 70  ->mutex;.  if( p
4820: 2d 3e 70 44 65 73 74 44 62 20 29 7b 0a 20 20 20  ->pDestDb ){.   
4830: 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65   sqlite3_mutex_e
4840: 6e 74 65 72 28 70 2d 3e 70 44 65 73 74 44 62 2d  nter(p->pDestDb-
4850: 3e 6d 75 74 65 78 29 3b 0a 20 20 7d 0a 0a 20 20  >mutex);.  }..  
4860: 2f 2a 20 44 65 74 61 63 68 20 74 68 69 73 20 62  /* Detach this b
4870: 61 63 6b 75 70 20 66 72 6f 6d 20 74 68 65 20 73  ackup from the s
4880: 6f 75 72 63 65 20 70 61 67 65 72 2e 20 2a 2f 0a  ource pager. */.
4890: 20 20 69 66 28 20 70 2d 3e 70 44 65 73 74 44 62    if( p->pDestDb
48a0: 20 29 7b 0a 20 20 20 20 70 2d 3e 70 53 72 63 2d   ){.    p->pSrc-
48b0: 3e 6e 42 61 63 6b 75 70 2d 2d 3b 0a 20 20 7d 0a  >nBackup--;.  }.
48c0: 20 20 69 66 28 20 70 2d 3e 69 73 41 74 74 61 63    if( p->isAttac
48d0: 68 65 64 20 29 7b 0a 20 20 20 20 70 70 20 3d 20  hed ){.    pp = 
48e0: 73 71 6c 69 74 65 33 50 61 67 65 72 42 61 63 6b  sqlite3PagerBack
48f0: 75 70 50 74 72 28 73 71 6c 69 74 65 33 42 74 72  upPtr(sqlite3Btr
4900: 65 65 50 61 67 65 72 28 70 2d 3e 70 53 72 63 29  eePager(p->pSrc)
4910: 29 3b 0a 20 20 20 20 77 68 69 6c 65 28 20 2a 70  );.    while( *p
4920: 70 21 3d 70 20 29 7b 0a 20 20 20 20 20 20 70 70  p!=p ){.      pp
4930: 20 3d 20 26 28 2a 70 70 29 2d 3e 70 4e 65 78 74   = &(*pp)->pNext
4940: 3b 0a 20 20 20 20 7d 0a 20 20 20 20 2a 70 70 20  ;.    }.    *pp 
4950: 3d 20 70 2d 3e 70 4e 65 78 74 3b 0a 20 20 7d 0a  = p->pNext;.  }.
4960: 0a 20 20 2f 2a 20 49 66 20 61 20 74 72 61 6e 73  .  /* If a trans
4970: 61 63 74 69 6f 6e 20 69 73 20 73 74 69 6c 6c 20  action is still 
4980: 6f 70 65 6e 20 6f 6e 20 74 68 65 20 42 74 72 65  open on the Btre
4990: 65 2c 20 72 6f 6c 6c 20 69 74 20 62 61 63 6b 2e  e, roll it back.
49a0: 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 42 74 72   */.  sqlite3Btr
49b0: 65 65 52 6f 6c 6c 62 61 63 6b 28 70 2d 3e 70 44  eeRollback(p->pD
49c0: 65 73 74 29 3b 0a 0a 20 20 2f 2a 20 53 65 74 20  est);..  /* Set 
49d0: 74 68 65 20 65 72 72 6f 72 20 63 6f 64 65 20 6f  the error code o
49e0: 66 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f  f the destinatio
49f0: 6e 20 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c  n database handl
4a00: 65 2e 20 2a 2f 0a 20 20 72 63 20 3d 20 28 70 2d  e. */.  rc = (p-
4a10: 3e 72 63 3d 3d 53 51 4c 49 54 45 5f 44 4f 4e 45  >rc==SQLITE_DONE
4a20: 29 20 3f 20 53 51 4c 49 54 45 5f 4f 4b 20 3a 20  ) ? SQLITE_OK : 
4a30: 70 2d 3e 72 63 3b 0a 20 20 73 71 6c 69 74 65 33  p->rc;.  sqlite3
4a40: 45 72 72 6f 72 28 70 2d 3e 70 44 65 73 74 44 62  Error(p->pDestDb
4a50: 2c 20 72 63 2c 20 30 29 3b 0a 0a 20 20 2f 2a 20  , rc, 0);..  /* 
4a60: 45 78 69 74 20 74 68 65 20 6d 75 74 65 78 65 73  Exit the mutexes
4a70: 20 61 6e 64 20 66 72 65 65 20 74 68 65 20 62 61   and free the ba
4a80: 63 6b 75 70 20 63 6f 6e 74 65 78 74 20 73 74 72  ckup context str
4a90: 75 63 74 75 72 65 2e 20 2a 2f 0a 20 20 69 66 28  ucture. */.  if(
4aa0: 20 70 2d 3e 70 44 65 73 74 44 62 20 29 7b 0a 20   p->pDestDb ){. 
4ab0: 20 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78     sqlite3_mutex
4ac0: 5f 6c 65 61 76 65 28 70 2d 3e 70 44 65 73 74 44  _leave(p->pDestD
4ad0: 62 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 7d 0a 20  b->mutex);.  }. 
4ae0: 20 73 71 6c 69 74 65 33 42 74 72 65 65 4c 65 61   sqlite3BtreeLea
4af0: 76 65 28 70 2d 3e 70 53 72 63 29 3b 0a 20 20 69  ve(p->pSrc);.  i
4b00: 66 28 20 70 2d 3e 70 44 65 73 74 44 62 20 29 7b  f( p->pDestDb ){
4b10: 0a 20 20 20 20 2f 2a 20 45 56 49 44 45 4e 43 45  .    /* EVIDENCE
4b20: 2d 4f 46 3a 20 52 2d 36 34 38 35 32 2d 32 31 35  -OF: R-64852-215
4b30: 39 31 20 54 68 65 20 73 71 6c 69 74 65 33 5f 62  91 The sqlite3_b
4b40: 61 63 6b 75 70 20 6f 62 6a 65 63 74 20 69 73 20  ackup object is 
4b50: 63 72 65 61 74 65 64 20 62 79 20 61 0a 20 20 20  created by a.   
4b60: 20 2a 2a 20 63 61 6c 6c 20 74 6f 20 73 71 6c 69   ** call to sqli
4b70: 74 65 33 5f 62 61 63 6b 75 70 5f 69 6e 69 74 28  te3_backup_init(
4b80: 29 20 61 6e 64 20 69 73 20 64 65 73 74 72 6f 79  ) and is destroy
4b90: 65 64 20 62 79 20 61 20 63 61 6c 6c 20 74 6f 0a  ed by a call to.
4ba0: 20 20 20 20 2a 2a 20 73 71 6c 69 74 65 33 5f 62      ** sqlite3_b
4bb0: 61 63 6b 75 70 5f 66 69 6e 69 73 68 28 29 2e 20  ackup_finish(). 
4bc0: 2a 2f 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66  */.    sqlite3_f
4bd0: 72 65 65 28 70 29 3b 0a 20 20 7d 0a 20 20 73 71  ree(p);.  }.  sq
4be0: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76  lite3_mutex_leav
4bf0: 65 28 6d 75 74 65 78 29 3b 0a 20 20 72 65 74 75  e(mutex);.  retu
4c00: 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20  rn rc;.}../*.** 
4c10: 52 65 74 75 72 6e 20 74 68 65 20 6e 75 6d 62 65  Return the numbe
4c20: 72 20 6f 66 20 70 61 67 65 73 20 73 74 69 6c 6c  r of pages still
4c30: 20 74 6f 20 62 65 20 62 61 63 6b 65 64 20 75 70   to be backed up
4c40: 20 61 73 20 6f 66 20 74 68 65 20 6d 6f 73 74 20   as of the most 
4c50: 72 65 63 65 6e 74 0a 2a 2a 20 63 61 6c 6c 20 74  recent.** call t
4c60: 6f 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70  o sqlite3_backup
4c70: 5f 73 74 65 70 28 29 2e 0a 2a 2f 0a 69 6e 74 20  _step()..*/.int 
4c80: 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 72  sqlite3_backup_r
4c90: 65 6d 61 69 6e 69 6e 67 28 73 71 6c 69 74 65 33  emaining(sqlite3
4ca0: 5f 62 61 63 6b 75 70 20 2a 70 29 7b 0a 20 20 72  _backup *p){.  r
4cb0: 65 74 75 72 6e 20 70 2d 3e 6e 52 65 6d 61 69 6e  eturn p->nRemain
4cc0: 69 6e 67 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65  ing;.}../*.** Re
4cd0: 74 75 72 6e 20 74 68 65 20 74 6f 74 61 6c 20 6e  turn the total n
4ce0: 75 6d 62 65 72 20 6f 66 20 70 61 67 65 73 20 69  umber of pages i
4cf0: 6e 20 74 68 65 20 73 6f 75 72 63 65 20 64 61 74  n the source dat
4d00: 61 62 61 73 65 20 61 73 20 6f 66 20 74 68 65 20  abase as of the 
4d10: 6d 6f 73 74 20 0a 2a 2a 20 72 65 63 65 6e 74 20  most .** recent 
4d20: 63 61 6c 6c 20 74 6f 20 73 71 6c 69 74 65 33 5f  call to sqlite3_
4d30: 62 61 63 6b 75 70 5f 73 74 65 70 28 29 2e 0a 2a  backup_step()..*
4d40: 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f 62 61  /.int sqlite3_ba
4d50: 63 6b 75 70 5f 70 61 67 65 63 6f 75 6e 74 28 73  ckup_pagecount(s
4d60: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 70  qlite3_backup *p
4d70: 29 7b 0a 20 20 72 65 74 75 72 6e 20 70 2d 3e 6e  ){.  return p->n
4d80: 50 61 67 65 63 6f 75 6e 74 3b 0a 7d 0a 0a 2f 2a  Pagecount;.}../*
4d90: 0a 2a 2a 20 54 68 69 73 20 66 75 6e 63 74 69 6f  .** This functio
4da0: 6e 20 69 73 20 63 61 6c 6c 65 64 20 61 66 74 65  n is called afte
4db0: 72 20 74 68 65 20 63 6f 6e 74 65 6e 74 73 20 6f  r the contents o
4dc0: 66 20 70 61 67 65 20 69 50 61 67 65 20 6f 66 20  f page iPage of 
4dd0: 74 68 65 0a 2a 2a 20 73 6f 75 72 63 65 20 64 61  the.** source da
4de0: 74 61 62 61 73 65 20 68 61 76 65 20 62 65 65 6e  tabase have been
4df0: 20 6d 6f 64 69 66 69 65 64 2e 20 49 66 20 70 61   modified. If pa
4e00: 67 65 20 69 50 61 67 65 20 68 61 73 20 61 6c 72  ge iPage has alr
4e10: 65 61 64 79 20 62 65 65 6e 20 0a 2a 2a 20 63 6f  eady been .** co
4e20: 70 69 65 64 20 69 6e 74 6f 20 74 68 65 20 64 65  pied into the de
4e30: 73 74 69 6e 61 74 69 6f 6e 20 64 61 74 61 62 61  stination databa
4e40: 73 65 2c 20 74 68 65 6e 20 74 68 65 20 64 61 74  se, then the dat
4e50: 61 20 77 72 69 74 74 65 6e 20 74 6f 20 74 68 65  a written to the
4e60: 0a 2a 2a 20 64 65 73 74 69 6e 61 74 69 6f 6e 20  .** destination 
4e70: 69 73 20 6e 6f 77 20 69 6e 76 61 6c 69 64 61 74  is now invalidat
4e80: 65 64 2e 20 54 68 65 20 64 65 73 74 69 6e 61 74  ed. The destinat
4e90: 69 6f 6e 20 63 6f 70 79 20 6f 66 20 69 50 61 67  ion copy of iPag
4ea0: 65 20 6e 65 65 64 73 0a 2a 2a 20 74 6f 20 62 65  e needs.** to be
4eb0: 20 75 70 64 61 74 65 64 20 77 69 74 68 20 74 68   updated with th
4ec0: 65 20 6e 65 77 20 64 61 74 61 20 62 65 66 6f 72  e new data befor
4ed0: 65 20 74 68 65 20 62 61 63 6b 75 70 20 6f 70 65  e the backup ope
4ee0: 72 61 74 69 6f 6e 20 69 73 0a 2a 2a 20 63 6f 6d  ration is.** com
4ef0: 70 6c 65 74 65 2e 0a 2a 2a 0a 2a 2a 20 49 74 20  plete..**.** It 
4f00: 69 73 20 61 73 73 75 6d 65 64 20 74 68 61 74 20  is assumed that 
4f10: 74 68 65 20 6d 75 74 65 78 20 61 73 73 6f 63 69  the mutex associ
4f20: 61 74 65 64 20 77 69 74 68 20 74 68 65 20 42 74  ated with the Bt
4f30: 53 68 61 72 65 64 20 6f 62 6a 65 63 74 0a 2a 2a  Shared object.**
4f40: 20 63 6f 72 72 65 73 70 6f 6e 64 69 6e 67 20 74   corresponding t
4f50: 6f 20 74 68 65 20 73 6f 75 72 63 65 20 64 61 74  o the source dat
4f60: 61 62 61 73 65 20 69 73 20 68 65 6c 64 20 77 68  abase is held wh
4f70: 65 6e 20 74 68 69 73 20 66 75 6e 63 74 69 6f 6e  en this function
4f80: 20 69 73 0a 2a 2a 20 63 61 6c 6c 65 64 2e 0a 2a   is.** called..*
4f90: 2f 0a 76 6f 69 64 20 73 71 6c 69 74 65 33 42 61  /.void sqlite3Ba
4fa0: 63 6b 75 70 55 70 64 61 74 65 28 73 71 6c 69 74  ckupUpdate(sqlit
4fb0: 65 33 5f 62 61 63 6b 75 70 20 2a 70 42 61 63 6b  e3_backup *pBack
4fc0: 75 70 2c 20 50 67 6e 6f 20 69 50 61 67 65 2c 20  up, Pgno iPage, 
4fd0: 63 6f 6e 73 74 20 75 38 20 2a 61 44 61 74 61 29  const u8 *aData)
4fe0: 7b 0a 20 20 73 71 6c 69 74 65 33 5f 62 61 63 6b  {.  sqlite3_back
4ff0: 75 70 20 2a 70 3b 20 20 20 20 20 20 20 20 20 20  up *p;          
5000: 20 20 20 20 20 20 20 20 20 2f 2a 20 49 74 65 72           /* Iter
5010: 61 74 6f 72 20 76 61 72 69 61 62 6c 65 20 2a 2f  ator variable */
5020: 0a 20 20 66 6f 72 28 70 3d 70 42 61 63 6b 75 70  .  for(p=pBackup
5030: 3b 20 70 3b 20 70 3d 70 2d 3e 70 4e 65 78 74 29  ; p; p=p->pNext)
5040: 7b 0a 20 20 20 20 61 73 73 65 72 74 28 20 73 71  {.    assert( sq
5050: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 68 65 6c 64  lite3_mutex_held
5060: 28 70 2d 3e 70 53 72 63 2d 3e 70 42 74 2d 3e 6d  (p->pSrc->pBt->m
5070: 75 74 65 78 29 20 29 3b 0a 20 20 20 20 69 66 28  utex) );.    if(
5080: 20 21 69 73 46 61 74 61 6c 45 72 72 6f 72 28 70   !isFatalError(p
5090: 2d 3e 72 63 29 20 26 26 20 69 50 61 67 65 3c 70  ->rc) && iPage<p
50a0: 2d 3e 69 4e 65 78 74 20 29 7b 0a 20 20 20 20 20  ->iNext ){.     
50b0: 20 2f 2a 20 54 68 65 20 62 61 63 6b 75 70 20 70   /* The backup p
50c0: 72 6f 63 65 73 73 20 70 20 68 61 73 20 61 6c 72  rocess p has alr
50d0: 65 61 64 79 20 63 6f 70 69 65 64 20 70 61 67 65  eady copied page
50e0: 20 69 50 61 67 65 2e 20 42 75 74 20 6e 6f 77 20   iPage. But now 
50f0: 69 74 0a 20 20 20 20 20 20 2a 2a 20 68 61 73 20  it.      ** has 
5100: 62 65 65 6e 20 6d 6f 64 69 66 69 65 64 20 62 79  been modified by
5110: 20 61 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 6f   a transaction o
5120: 6e 20 74 68 65 20 73 6f 75 72 63 65 20 70 61 67  n the source pag
5130: 65 72 2e 20 43 6f 70 79 0a 20 20 20 20 20 20 2a  er. Copy.      *
5140: 2a 20 74 68 65 20 6e 65 77 20 64 61 74 61 20 69  * the new data i
5150: 6e 74 6f 20 74 68 65 20 62 61 63 6b 75 70 2e 0a  nto the backup..
5160: 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20 20 69        */.      i
5170: 6e 74 20 72 63 20 3d 20 62 61 63 6b 75 70 4f 6e  nt rc = backupOn
5180: 65 50 61 67 65 28 70 2c 20 69 50 61 67 65 2c 20  ePage(p, iPage, 
5190: 61 44 61 74 61 29 3b 0a 20 20 20 20 20 20 61 73  aData);.      as
51a0: 73 65 72 74 28 20 72 63 21 3d 53 51 4c 49 54 45  sert( rc!=SQLITE
51b0: 5f 42 55 53 59 20 26 26 20 72 63 21 3d 53 51 4c  _BUSY && rc!=SQL
51c0: 49 54 45 5f 4c 4f 43 4b 45 44 20 29 3b 0a 20 20  ITE_LOCKED );.  
51d0: 20 20 20 20 69 66 28 20 72 63 21 3d 53 51 4c 49      if( rc!=SQLI
51e0: 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 20 20 20  TE_OK ){.       
51f0: 20 70 2d 3e 72 63 20 3d 20 72 63 3b 0a 20 20 20   p->rc = rc;.   
5200: 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d     }.    }.  }.}
5210: 0a 0a 2f 2a 0a 2a 2a 20 52 65 73 74 61 72 74 20  ../*.** Restart 
5220: 74 68 65 20 62 61 63 6b 75 70 20 70 72 6f 63 65  the backup proce
5230: 73 73 2e 20 54 68 69 73 20 69 73 20 63 61 6c 6c  ss. This is call
5240: 65 64 20 77 68 65 6e 20 74 68 65 20 70 61 67 65  ed when the page
5250: 72 20 6c 61 79 65 72 0a 2a 2a 20 64 65 74 65 63  r layer.** detec
5260: 74 73 20 74 68 61 74 20 74 68 65 20 64 61 74 61  ts that the data
5270: 62 61 73 65 20 68 61 73 20 62 65 65 6e 20 6d 6f  base has been mo
5280: 64 69 66 69 65 64 20 62 79 20 61 6e 20 65 78 74  dified by an ext
5290: 65 72 6e 61 6c 20 64 61 74 61 62 61 73 65 0a 2a  ernal database.*
52a0: 2a 20 63 6f 6e 6e 65 63 74 69 6f 6e 2e 20 49 6e  * connection. In
52b0: 20 74 68 69 73 20 63 61 73 65 20 74 68 65 72 65   this case there
52c0: 20 69 73 20 6e 6f 20 77 61 79 20 6f 66 20 6b 6e   is no way of kn
52d0: 6f 77 69 6e 67 20 77 68 69 63 68 20 6f 66 20 74  owing which of t
52e0: 68 65 0a 2a 2a 20 70 61 67 65 73 20 74 68 61 74  he.** pages that
52f0: 20 68 61 76 65 20 62 65 65 6e 20 63 6f 70 69 65   have been copie
5300: 64 20 69 6e 74 6f 20 74 68 65 20 64 65 73 74 69  d into the desti
5310: 6e 61 74 69 6f 6e 20 64 61 74 61 62 61 73 65 20  nation database 
5320: 61 72 65 20 73 74 69 6c 6c 20 0a 2a 2a 20 76 61  are still .** va
5330: 6c 69 64 20 61 6e 64 20 77 68 69 63 68 20 61 72  lid and which ar
5340: 65 20 6e 6f 74 2c 20 73 6f 20 74 68 65 20 65 6e  e not, so the en
5350: 74 69 72 65 20 70 72 6f 63 65 73 73 20 6e 65 65  tire process nee
5360: 64 73 20 74 6f 20 62 65 20 72 65 73 74 61 72 74  ds to be restart
5370: 65 64 2e 0a 2a 2a 0a 2a 2a 20 49 74 20 69 73 20  ed..**.** It is 
5380: 61 73 73 75 6d 65 64 20 74 68 61 74 20 74 68 65  assumed that the
5390: 20 6d 75 74 65 78 20 61 73 73 6f 63 69 61 74 65   mutex associate
53a0: 64 20 77 69 74 68 20 74 68 65 20 42 74 53 68 61  d with the BtSha
53b0: 72 65 64 20 6f 62 6a 65 63 74 0a 2a 2a 20 63 6f  red object.** co
53c0: 72 72 65 73 70 6f 6e 64 69 6e 67 20 74 6f 20 74  rresponding to t
53d0: 68 65 20 73 6f 75 72 63 65 20 64 61 74 61 62 61  he source databa
53e0: 73 65 20 69 73 20 68 65 6c 64 20 77 68 65 6e 20  se is held when 
53f0: 74 68 69 73 20 66 75 6e 63 74 69 6f 6e 20 69 73  this function is
5400: 0a 2a 2a 20 63 61 6c 6c 65 64 2e 0a 2a 2f 0a 76  .** called..*/.v
5410: 6f 69 64 20 73 71 6c 69 74 65 33 42 61 63 6b 75  oid sqlite3Backu
5420: 70 52 65 73 74 61 72 74 28 73 71 6c 69 74 65 33  pRestart(sqlite3
5430: 5f 62 61 63 6b 75 70 20 2a 70 42 61 63 6b 75 70  _backup *pBackup
5440: 29 7b 0a 20 20 73 71 6c 69 74 65 33 5f 62 61 63  ){.  sqlite3_bac
5450: 6b 75 70 20 2a 70 3b 20 20 20 20 20 20 20 20 20  kup *p;         
5460: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 49 74 65            /* Ite
5470: 72 61 74 6f 72 20 76 61 72 69 61 62 6c 65 20 2a  rator variable *
5480: 2f 0a 20 20 66 6f 72 28 70 3d 70 42 61 63 6b 75  /.  for(p=pBacku
5490: 70 3b 20 70 3b 20 70 3d 70 2d 3e 70 4e 65 78 74  p; p; p=p->pNext
54a0: 29 7b 0a 20 20 20 20 61 73 73 65 72 74 28 20 73  ){.    assert( s
54b0: 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 68 65 6c  qlite3_mutex_hel
54c0: 64 28 70 2d 3e 70 53 72 63 2d 3e 70 42 74 2d 3e  d(p->pSrc->pBt->
54d0: 6d 75 74 65 78 29 20 29 3b 0a 20 20 20 20 70 2d  mutex) );.    p-
54e0: 3e 69 4e 65 78 74 20 3d 20 31 3b 0a 20 20 7d 0a  >iNext = 1;.  }.
54f0: 7d 0a 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54  }..#ifndef SQLIT
5500: 45 5f 4f 4d 49 54 5f 56 41 43 55 55 4d 0a 2f 2a  E_OMIT_VACUUM./*
5510: 0a 2a 2a 20 43 6f 70 79 20 74 68 65 20 63 6f 6d  .** Copy the com
5520: 70 6c 65 74 65 20 63 6f 6e 74 65 6e 74 20 6f 66  plete content of
5530: 20 70 42 74 46 72 6f 6d 20 69 6e 74 6f 20 70 42   pBtFrom into pB
5540: 74 54 6f 2e 20 20 41 20 74 72 61 6e 73 61 63 74  tTo.  A transact
5550: 69 6f 6e 0a 2a 2a 20 6d 75 73 74 20 62 65 20 61  ion.** must be a
5560: 63 74 69 76 65 20 66 6f 72 20 62 6f 74 68 20 66  ctive for both f
5570: 69 6c 65 73 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20  iles..**.** The 
5580: 73 69 7a 65 20 6f 66 20 66 69 6c 65 20 70 54 6f  size of file pTo
5590: 20 6d 61 79 20 62 65 20 72 65 64 75 63 65 64 20   may be reduced 
55a0: 62 79 20 74 68 69 73 20 6f 70 65 72 61 74 69 6f  by this operatio
55b0: 6e 2e 20 49 66 20 61 6e 79 74 68 69 6e 67 20 0a  n. If anything .
55c0: 2a 2a 20 67 6f 65 73 20 77 72 6f 6e 67 2c 20 74  ** goes wrong, t
55d0: 68 65 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 6f  he transaction o
55e0: 6e 20 70 54 6f 20 69 73 20 72 6f 6c 6c 65 64 20  n pTo is rolled 
55f0: 62 61 63 6b 2e 20 49 66 20 73 75 63 63 65 73 73  back. If success
5600: 66 75 6c 2c 20 74 68 65 20 0a 2a 2a 20 74 72 61  ful, the .** tra
5610: 6e 73 61 63 74 69 6f 6e 20 69 73 20 63 6f 6d 6d  nsaction is comm
5620: 69 74 74 65 64 20 62 65 66 6f 72 65 20 72 65 74  itted before ret
5630: 75 72 6e 69 6e 67 2e 0a 2a 2f 0a 69 6e 74 20 73  urning..*/.int s
5640: 71 6c 69 74 65 33 42 74 72 65 65 43 6f 70 79 46  qlite3BtreeCopyF
5650: 69 6c 65 28 42 74 72 65 65 20 2a 70 54 6f 2c 20  ile(Btree *pTo, 
5660: 42 74 72 65 65 20 2a 70 46 72 6f 6d 29 7b 0a 20  Btree *pFrom){. 
5670: 20 69 6e 74 20 72 63 3b 0a 20 20 73 71 6c 69 74   int rc;.  sqlit
5680: 65 33 5f 62 61 63 6b 75 70 20 62 3b 0a 20 20 73  e3_backup b;.  s
5690: 71 6c 69 74 65 33 42 74 72 65 65 45 6e 74 65 72  qlite3BtreeEnter
56a0: 28 70 54 6f 29 3b 0a 20 20 73 71 6c 69 74 65 33  (pTo);.  sqlite3
56b0: 42 74 72 65 65 45 6e 74 65 72 28 70 46 72 6f 6d  BtreeEnter(pFrom
56c0: 29 3b 0a 0a 20 20 2f 2a 20 53 65 74 20 75 70 20  );..  /* Set up 
56d0: 61 6e 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75  an sqlite3_backu
56e0: 70 20 6f 62 6a 65 63 74 2e 20 73 71 6c 69 74 65  p object. sqlite
56f0: 33 5f 62 61 63 6b 75 70 2e 70 44 65 73 74 44 62  3_backup.pDestDb
5700: 20 6d 75 73 74 20 62 65 20 73 65 74 0a 20 20 2a   must be set.  *
5710: 2a 20 74 6f 20 30 2e 20 54 68 69 73 20 69 73 20  * to 0. This is 
5720: 75 73 65 64 20 62 79 20 74 68 65 20 69 6d 70 6c  used by the impl
5730: 65 6d 65 6e 74 61 74 69 6f 6e 73 20 6f 66 20 73  ementations of s
5740: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 73 74  qlite3_backup_st
5750: 65 70 28 29 0a 20 20 2a 2a 20 61 6e 64 20 73 71  ep().  ** and sq
5760: 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 66 69 6e  lite3_backup_fin
5770: 69 73 68 28 29 20 74 6f 20 64 65 74 65 63 74 20  ish() to detect 
5780: 74 68 61 74 20 74 68 65 79 20 61 72 65 20 62 65  that they are be
5790: 69 6e 67 20 63 61 6c 6c 65 64 0a 20 20 2a 2a 20  ing called.  ** 
57a0: 66 72 6f 6d 20 74 68 69 73 20 66 75 6e 63 74 69  from this functi
57b0: 6f 6e 2c 20 6e 6f 74 20 64 69 72 65 63 74 6c 79  on, not directly
57c0: 20 62 79 20 74 68 65 20 75 73 65 72 2e 0a 20 20   by the user..  
57d0: 2a 2f 0a 20 20 6d 65 6d 73 65 74 28 26 62 2c 20  */.  memset(&b, 
57e0: 30 2c 20 73 69 7a 65 6f 66 28 62 29 29 3b 0a 20  0, sizeof(b));. 
57f0: 20 62 2e 70 53 72 63 44 62 20 3d 20 70 46 72 6f   b.pSrcDb = pFro
5800: 6d 2d 3e 64 62 3b 0a 20 20 62 2e 70 53 72 63 20  m->db;.  b.pSrc 
5810: 3d 20 70 46 72 6f 6d 3b 0a 20 20 62 2e 70 44 65  = pFrom;.  b.pDe
5820: 73 74 20 3d 20 70 54 6f 3b 0a 20 20 62 2e 69 4e  st = pTo;.  b.iN
5830: 65 78 74 20 3d 20 31 3b 0a 0a 20 20 2f 2a 20 30  ext = 1;..  /* 0
5840: 78 37 46 46 46 46 46 46 46 20 69 73 20 74 68 65  x7FFFFFFF is the
5850: 20 68 61 72 64 20 6c 69 6d 69 74 20 66 6f 72 20   hard limit for 
5860: 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 70 61  the number of pa
5870: 67 65 73 20 69 6e 20 61 20 64 61 74 61 62 61 73  ges in a databas
5880: 65 0a 20 20 2a 2a 20 66 69 6c 65 2e 20 42 79 20  e.  ** file. By 
5890: 70 61 73 73 69 6e 67 20 74 68 69 73 20 61 73 20  passing this as 
58a0: 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 70 61  the number of pa
58b0: 67 65 73 20 74 6f 20 63 6f 70 79 20 74 6f 0a 20  ges to copy to. 
58c0: 20 2a 2a 20 73 71 6c 69 74 65 33 5f 62 61 63 6b   ** sqlite3_back
58d0: 75 70 5f 73 74 65 70 28 29 2c 20 77 65 20 63 61  up_step(), we ca
58e0: 6e 20 67 75 61 72 61 6e 74 65 65 20 74 68 61 74  n guarantee that
58f0: 20 74 68 65 20 63 6f 70 79 20 66 69 6e 69 73 68   the copy finish
5900: 65 73 20 0a 20 20 2a 2a 20 77 69 74 68 69 6e 20  es .  ** within 
5910: 61 20 73 69 6e 67 6c 65 20 63 61 6c 6c 20 28 75  a single call (u
5920: 6e 6c 65 73 73 20 61 6e 20 65 72 72 6f 72 20 6f  nless an error o
5930: 63 63 75 72 73 29 2e 20 54 68 65 20 61 73 73 65  ccurs). The asse
5940: 72 74 28 29 20 73 74 61 74 65 6d 65 6e 74 0a 20  rt() statement. 
5950: 20 2a 2a 20 63 68 65 63 6b 73 20 74 68 69 73 20   ** checks this 
5960: 61 73 73 75 6d 70 74 69 6f 6e 20 2d 20 28 70 2d  assumption - (p-
5970: 3e 72 63 29 20 73 68 6f 75 6c 64 20 62 65 20 73  >rc) should be s
5980: 65 74 20 74 6f 20 65 69 74 68 65 72 20 53 51 4c  et to either SQL
5990: 49 54 45 5f 44 4f 4e 45 20 0a 20 20 2a 2a 20 6f  ITE_DONE .  ** o
59a0: 72 20 61 6e 20 65 72 72 6f 72 20 63 6f 64 65 2e  r an error code.
59b0: 0a 20 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f  .  */.  sqlite3_
59c0: 62 61 63 6b 75 70 5f 73 74 65 70 28 26 62 2c 20  backup_step(&b, 
59d0: 30 78 37 46 46 46 46 46 46 46 29 3b 0a 20 20 61  0x7FFFFFFF);.  a
59e0: 73 73 65 72 74 28 20 62 2e 72 63 21 3d 53 51 4c  ssert( b.rc!=SQL
59f0: 49 54 45 5f 4f 4b 20 29 3b 0a 20 20 72 63 20 3d  ITE_OK );.  rc =
5a00: 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f   sqlite3_backup_
5a10: 66 69 6e 69 73 68 28 26 62 29 3b 0a 20 20 69 66  finish(&b);.  if
5a20: 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20  ( rc==SQLITE_OK 
5a30: 29 7b 0a 20 20 20 20 70 54 6f 2d 3e 70 42 74 2d  ){.    pTo->pBt-
5a40: 3e 70 61 67 65 53 69 7a 65 46 69 78 65 64 20 3d  >pageSizeFixed =
5a50: 20 30 3b 0a 20 20 7d 0a 0a 20 20 73 71 6c 69 74   0;.  }..  sqlit
5a60: 65 33 42 74 72 65 65 4c 65 61 76 65 28 70 46 72  e3BtreeLeave(pFr
5a70: 6f 6d 29 3b 0a 20 20 73 71 6c 69 74 65 33 42 74  om);.  sqlite3Bt
5a80: 72 65 65 4c 65 61 76 65 28 70 54 6f 29 3b 0a 20  reeLeave(pTo);. 
5a90: 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 23 65   return rc;.}.#e
5aa0: 6e 64 69 66 20 2f 2a 20 53 51 4c 49 54 45 5f 4f  ndif /* SQLITE_O
5ab0: 4d 49 54 5f 56 41 43 55 55 4d 20 2a 2f 0a        MIT_VACUUM */.