/ Hex Artifact Content
Login

Artifact f60f0aa55d25d853ffde53d0b0370a7bb7ee41ce:


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 0a 2a 2a 20 53 74 72  nt.h"../*.** Str
0220: 75 63 74 75 72 65 20 61 6c 6c 6f 63 61 74 65 64  ucture allocated
0230: 20 66 6f 72 20 65 61 63 68 20 62 61 63 6b 75 70   for each backup
0240: 20 6f 70 65 72 61 74 69 6f 6e 2e 0a 2a 2f 0a 73   operation..*/.s
0250: 74 72 75 63 74 20 73 71 6c 69 74 65 33 5f 62 61  truct sqlite3_ba
0260: 63 6b 75 70 20 7b 0a 20 20 73 71 6c 69 74 65 33  ckup {.  sqlite3
0270: 2a 20 70 44 65 73 74 44 62 3b 20 20 20 20 20 20  * pDestDb;      
0280: 20 20 2f 2a 20 44 65 73 74 69 6e 61 74 69 6f 6e    /* Destination
0290: 20 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c 65   database handle
02a0: 20 2a 2f 0a 20 20 42 74 72 65 65 20 2a 70 44 65   */.  Btree *pDe
02b0: 73 74 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f  st;            /
02c0: 2a 20 44 65 73 74 69 6e 61 74 69 6f 6e 20 62 2d  * Destination b-
02d0: 74 72 65 65 20 66 69 6c 65 20 2a 2f 0a 20 20 75  tree file */.  u
02e0: 33 32 20 69 44 65 73 74 53 63 68 65 6d 61 3b 20  32 iDestSchema; 
02f0: 20 20 20 20 20 20 20 20 2f 2a 20 4f 72 69 67 69          /* Origi
0300: 6e 61 6c 20 73 63 68 65 6d 61 20 63 6f 6f 6b 69  nal schema cooki
0310: 65 20 69 6e 20 64 65 73 74 69 6e 61 74 69 6f 6e  e in destination
0320: 20 2a 2f 0a 20 20 69 6e 74 20 62 44 65 73 74 4c   */.  int bDestL
0330: 6f 63 6b 65 64 3b 20 20 20 20 20 20 20 20 20 2f  ocked;         /
0340: 2a 20 54 72 75 65 20 6f 6e 63 65 20 61 20 77 72  * True once a wr
0350: 69 74 65 2d 74 72 61 6e 73 61 63 74 69 6f 6e 20  ite-transaction 
0360: 69 73 20 6f 70 65 6e 20 6f 6e 20 70 44 65 73 74  is open on pDest
0370: 20 2a 2f 0a 0a 20 20 50 67 6e 6f 20 69 4e 65 78   */..  Pgno iNex
0380: 74 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  t;              
0390: 2f 2a 20 50 61 67 65 20 6e 75 6d 62 65 72 20 6f  /* Page number o
03a0: 66 20 74 68 65 20 6e 65 78 74 20 73 6f 75 72 63  f the next sourc
03b0: 65 20 70 61 67 65 20 74 6f 20 63 6f 70 79 20 2a  e page to copy *
03c0: 2f 0a 20 20 73 71 6c 69 74 65 33 2a 20 70 53 72  /.  sqlite3* pSr
03d0: 63 44 62 3b 20 20 20 20 20 20 20 20 20 2f 2a 20  cDb;         /* 
03e0: 53 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 20  Source database 
03f0: 68 61 6e 64 6c 65 20 2a 2f 0a 20 20 42 74 72 65  handle */.  Btre
0400: 65 20 2a 70 53 72 63 3b 20 20 20 20 20 20 20 20  e *pSrc;        
0410: 20 20 20 20 20 2f 2a 20 53 6f 75 72 63 65 20 62       /* Source b
0420: 2d 74 72 65 65 20 66 69 6c 65 20 2a 2f 0a 0a 20  -tree file */.. 
0430: 20 69 6e 74 20 72 63 3b 20 20 20 20 20 20 20 20   int rc;        
0440: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 42 61 63            /* Bac
0450: 6b 75 70 20 70 72 6f 63 65 73 73 20 65 72 72 6f  kup process erro
0460: 72 20 63 6f 64 65 20 2a 2f 0a 0a 20 20 2f 2a 20  r code */..  /* 
0470: 54 68 65 73 65 20 74 77 6f 20 76 61 72 69 61 62  These two variab
0480: 6c 65 73 20 61 72 65 20 73 65 74 20 62 79 20 65  les are set by e
0490: 76 65 72 79 20 63 61 6c 6c 20 74 6f 20 62 61 63  very call to bac
04a0: 6b 75 70 5f 73 74 65 70 28 29 2e 20 54 68 65 79  kup_step(). They
04b0: 20 61 72 65 0a 20 20 2a 2a 20 72 65 61 64 20 62   are.  ** read b
04c0: 79 20 63 61 6c 6c 73 20 74 6f 20 62 61 63 6b 75  y calls to backu
04d0: 70 5f 72 65 6d 61 69 6e 69 6e 67 28 29 20 61 6e  p_remaining() an
04e0: 64 20 62 61 63 6b 75 70 5f 70 61 67 65 63 6f 75  d backup_pagecou
04f0: 6e 74 28 29 2e 0a 20 20 2a 2f 0a 20 20 50 67 6e  nt()..  */.  Pgn
0500: 6f 20 6e 52 65 6d 61 69 6e 69 6e 67 3b 20 20 20  o nRemaining;   
0510: 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20        /* Number 
0520: 6f 66 20 70 61 67 65 73 20 6c 65 66 74 20 74 6f  of pages left to
0530: 20 63 6f 70 79 20 2a 2f 0a 20 20 50 67 6e 6f 20   copy */.  Pgno 
0540: 6e 50 61 67 65 63 6f 75 6e 74 3b 20 20 20 20 20  nPagecount;     
0550: 20 20 20 20 2f 2a 20 54 6f 74 61 6c 20 6e 75 6d      /* Total num
0560: 62 65 72 20 6f 66 20 70 61 67 65 73 20 74 6f 20  ber of pages to 
0570: 63 6f 70 79 20 2a 2f 0a 0a 20 20 69 6e 74 20 69  copy */..  int i
0580: 73 41 74 74 61 63 68 65 64 3b 20 20 20 20 20 20  sAttached;      
0590: 20 20 20 20 2f 2a 20 54 72 75 65 20 6f 6e 63 65      /* True once
05a0: 20 62 61 63 6b 75 70 20 68 61 73 20 62 65 65 6e   backup has been
05b0: 20 72 65 67 69 73 74 65 72 65 64 20 77 69 74 68   registered with
05c0: 20 70 61 67 65 72 20 2a 2f 0a 20 20 73 71 6c 69   pager */.  sqli
05d0: 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 4e 65 78  te3_backup *pNex
05e0: 74 3b 20 20 20 2f 2a 20 4e 65 78 74 20 62 61 63  t;   /* Next bac
05f0: 6b 75 70 20 61 73 73 6f 63 69 61 74 65 64 20 77  kup associated w
0600: 69 74 68 20 73 6f 75 72 63 65 20 70 61 67 65 72  ith source pager
0610: 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20 54 48   */.};../*.** TH
0620: 52 45 41 44 20 53 41 46 45 54 59 20 4e 4f 54 45  READ SAFETY NOTE
0630: 53 3a 0a 2a 2a 0a 2a 2a 20 20 20 4f 6e 63 65 20  S:.**.**   Once 
0640: 69 74 20 68 61 73 20 62 65 65 6e 20 63 72 65 61  it has been crea
0650: 74 65 64 20 75 73 69 6e 67 20 62 61 63 6b 75 70  ted using backup
0660: 5f 69 6e 69 74 28 29 2c 20 61 20 73 69 6e 67 6c  _init(), a singl
0670: 65 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70  e sqlite3_backup
0680: 0a 2a 2a 20 20 20 73 74 72 75 63 74 75 72 65 20  .**   structure 
0690: 6d 61 79 20 62 65 20 61 63 63 65 73 73 65 64 20  may be accessed 
06a0: 76 69 61 20 74 77 6f 20 67 72 6f 75 70 73 20 6f  via two groups o
06b0: 66 20 74 68 72 65 61 64 2d 73 61 66 65 20 65 6e  f thread-safe en
06c0: 74 72 79 20 70 6f 69 6e 74 73 3a 0a 2a 2a 0a 2a  try points:.**.*
06d0: 2a 20 20 20 20 20 2a 20 56 69 61 20 74 68 65 20  *     * Via the 
06e0: 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 58  sqlite3_backup_X
06f0: 58 58 28 29 20 41 50 49 20 66 75 6e 63 74 69 6f  XX() API functio
0700: 6e 20 62 61 63 6b 75 70 5f 73 74 65 70 28 29 20  n backup_step() 
0710: 61 6e 64 20 0a 2a 2a 20 20 20 20 20 20 20 62 61  and .**       ba
0720: 63 6b 75 70 5f 66 69 6e 69 73 68 28 29 2e 20 42  ckup_finish(). B
0730: 6f 74 68 20 74 68 65 73 65 20 66 75 6e 63 74 69  oth these functi
0740: 6f 6e 73 20 6f 62 74 61 69 6e 20 74 68 65 20 73  ons obtain the s
0750: 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 0a 2a  ource database.*
0760: 2a 20 20 20 20 20 20 20 68 61 6e 64 6c 65 20 6d  *       handle m
0770: 75 74 65 78 20 61 6e 64 20 74 68 65 20 6d 75 74  utex and the mut
0780: 65 78 20 61 73 73 6f 63 69 61 74 65 64 20 77 69  ex associated wi
0790: 74 68 20 74 68 65 20 73 6f 75 72 63 65 20 42 74  th the source Bt
07a0: 53 68 61 72 65 64 20 0a 2a 2a 20 20 20 20 20 20  Shared .**      
07b0: 20 73 74 72 75 63 74 75 72 65 2c 20 69 6e 20 74   structure, in t
07c0: 68 61 74 20 6f 72 64 65 72 2e 0a 2a 2a 0a 2a 2a  hat order..**.**
07d0: 20 20 20 20 20 2a 20 56 69 61 20 74 68 65 20 42       * Via the B
07e0: 61 63 6b 75 70 55 70 64 61 74 65 28 29 20 61 6e  ackupUpdate() an
07f0: 64 20 42 61 63 6b 75 70 52 65 73 74 61 72 74 28  d BackupRestart(
0800: 29 20 66 75 6e 63 74 69 6f 6e 73 2c 20 77 68 69  ) functions, whi
0810: 63 68 20 61 72 65 0a 2a 2a 20 20 20 20 20 20 20  ch are.**       
0820: 69 6e 76 6f 6b 65 64 20 62 79 20 74 68 65 20 70  invoked by the p
0830: 61 67 65 72 20 6c 61 79 65 72 20 74 6f 20 72 65  ager layer to re
0840: 70 6f 72 74 20 76 61 72 69 6f 75 73 20 73 74 61  port various sta
0850: 74 65 20 63 68 61 6e 67 65 73 20 69 6e 0a 2a 2a  te changes in.**
0860: 20 20 20 20 20 20 20 74 68 65 20 70 61 67 65 20         the page 
0870: 63 61 63 68 65 20 61 73 73 6f 63 69 61 74 65 64  cache associated
0880: 20 77 69 74 68 20 74 68 65 20 73 6f 75 72 63 65   with the source
0890: 20 64 61 74 61 62 61 73 65 2e 20 54 68 65 20 6d   database. The m
08a0: 75 74 65 78 0a 2a 2a 20 20 20 20 20 20 20 61 73  utex.**       as
08b0: 73 6f 63 69 61 74 65 64 20 77 69 74 68 20 74 68  sociated with th
08c0: 65 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73  e source databas
08d0: 65 20 42 74 53 68 61 72 65 64 20 73 74 72 75 63  e BtShared struc
08e0: 74 75 72 65 20 77 69 6c 6c 20 61 6c 77 61 79 73  ture will always
08f0: 20 0a 2a 2a 20 20 20 20 20 20 20 62 65 20 68 65   .**       be he
0900: 6c 64 20 77 68 65 6e 20 65 69 74 68 65 72 20 6f  ld when either o
0910: 66 20 74 68 65 73 65 20 66 75 6e 63 74 69 6f 6e  f these function
0920: 73 20 61 72 65 20 69 6e 76 6f 6b 65 64 2e 0a 2a  s are invoked..*
0930: 2a 0a 2a 2a 20 20 20 54 68 65 20 6f 74 68 65 72  *.**   The other
0940: 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f   sqlite3_backup_
0950: 58 58 58 28 29 20 41 50 49 20 66 75 6e 63 74 69  XXX() API functi
0960: 6f 6e 73 2c 20 62 61 63 6b 75 70 5f 72 65 6d 61  ons, backup_rema
0970: 69 6e 69 6e 67 28 29 20 61 6e 64 0a 2a 2a 20 20  ining() and.**  
0980: 20 62 61 63 6b 75 70 5f 70 61 67 65 63 6f 75 6e   backup_pagecoun
0990: 74 28 29 20 61 72 65 20 6e 6f 74 20 74 68 72 65  t() are not thre
09a0: 61 64 2d 73 61 66 65 20 66 75 6e 63 74 69 6f 6e  ad-safe function
09b0: 73 2e 20 49 66 20 74 68 65 79 20 61 72 65 20 63  s. If they are c
09c0: 61 6c 6c 65 64 0a 2a 2a 20 20 20 77 68 69 6c 65  alled.**   while
09d0: 20 73 6f 6d 65 20 6f 74 68 65 72 20 74 68 72 65   some other thre
09e0: 61 64 20 69 73 20 63 61 6c 6c 69 6e 67 20 62 61  ad is calling ba
09f0: 63 6b 75 70 5f 73 74 65 70 28 29 20 6f 72 20 62  ckup_step() or b
0a00: 61 63 6b 75 70 5f 66 69 6e 69 73 68 28 29 2c 0a  ackup_finish(),.
0a10: 2a 2a 20 20 20 74 68 65 20 76 61 6c 75 65 73 20  **   the values 
0a20: 72 65 74 75 72 6e 65 64 20 6d 61 79 20 62 65 20  returned may be 
0a30: 69 6e 76 61 6c 69 64 2e 20 54 68 65 72 65 20 69  invalid. There i
0a40: 73 20 6e 6f 20 77 61 79 20 66 6f 72 20 61 20 63  s no way for a c
0a50: 61 6c 6c 20 74 6f 0a 2a 2a 20 20 20 42 61 63 6b  all to.**   Back
0a60: 75 70 55 70 64 61 74 65 28 29 20 6f 72 20 42 61  upUpdate() or Ba
0a70: 63 6b 75 70 52 65 73 74 61 72 74 28 29 20 74 6f  ckupRestart() to
0a80: 20 69 6e 74 65 72 66 65 72 65 20 77 69 74 68 20   interfere with 
0a90: 62 61 63 6b 75 70 5f 72 65 6d 61 69 6e 69 6e 67  backup_remaining
0aa0: 28 29 0a 2a 2a 20 20 20 6f 72 20 62 61 63 6b 75  ().**   or backu
0ab0: 70 5f 70 61 67 65 63 6f 75 6e 74 28 29 2e 0a 2a  p_pagecount()..*
0ac0: 2a 0a 2a 2a 20 20 20 44 65 70 65 6e 64 69 6e 67  *.**   Depending
0ad0: 20 6f 6e 20 74 68 65 20 53 51 4c 69 74 65 20 63   on the SQLite c
0ae0: 6f 6e 66 69 67 75 72 61 74 69 6f 6e 2c 20 74 68  onfiguration, th
0af0: 65 20 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c  e database handl
0b00: 65 73 20 61 6e 64 2f 6f 72 0a 2a 2a 20 20 20 74  es and/or.**   t
0b10: 68 65 20 42 74 72 65 65 20 6f 62 6a 65 63 74 73  he Btree objects
0b20: 20 6d 61 79 20 68 61 76 65 20 74 68 65 69 72 20   may have their 
0b30: 6f 77 6e 20 6d 75 74 65 78 65 73 20 74 68 61 74  own mutexes that
0b40: 20 72 65 71 75 69 72 65 20 6c 6f 63 6b 69 6e 67   require locking
0b50: 2e 0a 2a 2a 20 20 20 4e 6f 6e 2d 73 68 61 72 61  ..**   Non-shara
0b60: 62 6c 65 20 42 74 72 65 65 73 20 28 69 6e 2d 6d  ble Btrees (in-m
0b70: 65 6d 6f 72 79 20 64 61 74 61 62 61 73 65 73 20  emory databases 
0b80: 66 6f 72 20 65 78 61 6d 70 6c 65 29 2c 20 64 6f  for example), do
0b90: 20 6e 6f 74 20 68 61 76 65 0a 2a 2a 20 20 20 61   not have.**   a
0ba0: 73 73 6f 63 69 61 74 65 64 20 6d 75 74 65 78 65  ssociated mutexe
0bb0: 73 2e 0a 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 52 65 74  s..*/../*.** Ret
0bc0: 75 72 6e 20 61 20 70 6f 69 6e 74 65 72 20 63 6f  urn a pointer co
0bd0: 72 72 65 73 70 6f 6e 64 69 6e 67 20 74 6f 20 64  rresponding to d
0be0: 61 74 61 62 61 73 65 20 7a 44 62 20 28 69 2e 65  atabase zDb (i.e
0bf0: 2e 20 22 6d 61 69 6e 22 2c 20 22 74 65 6d 70 22  . "main", "temp"
0c00: 29 0a 2a 2a 20 69 6e 20 63 6f 6e 6e 65 63 74 69  ).** in connecti
0c10: 6f 6e 20 68 61 6e 64 6c 65 20 70 44 62 2e 20 49  on handle pDb. I
0c20: 66 20 73 75 63 68 20 61 20 64 61 74 61 62 61 73  f such a databas
0c30: 65 20 63 61 6e 6e 6f 74 20 62 65 20 66 6f 75 6e  e cannot be foun
0c40: 64 2c 20 72 65 74 75 72 6e 0a 2a 2a 20 61 20 4e  d, return.** a N
0c50: 55 4c 4c 20 70 6f 69 6e 74 65 72 20 61 6e 64 20  ULL pointer and 
0c60: 77 72 69 74 65 20 61 6e 20 65 72 72 6f 72 20 6d  write an error m
0c70: 65 73 73 61 67 65 20 74 6f 20 70 45 72 72 6f 72  essage to pError
0c80: 44 62 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 74 68 65  Db..**.** If the
0c90: 20 22 74 65 6d 70 22 20 64 61 74 61 62 61 73 65   "temp" database
0ca0: 20 69 73 20 72 65 71 75 65 73 74 65 64 2c 20 69   is requested, i
0cb0: 74 20 6d 61 79 20 6e 65 65 64 20 74 6f 20 62 65  t may need to be
0cc0: 20 6f 70 65 6e 65 64 20 62 79 20 74 68 69 73 20   opened by this 
0cd0: 0a 2a 2a 20 66 75 6e 63 74 69 6f 6e 2e 20 49 66  .** function. If
0ce0: 20 61 6e 20 65 72 72 6f 72 20 6f 63 63 75 72 73   an error occurs
0cf0: 20 77 68 69 6c 65 20 64 6f 69 6e 67 20 73 6f 2c   while doing so,
0d00: 20 72 65 74 75 72 6e 20 30 20 61 6e 64 20 77 72   return 0 and wr
0d10: 69 74 65 20 61 6e 20 0a 2a 2a 20 65 72 72 6f 72  ite an .** error
0d20: 20 6d 65 73 73 61 67 65 20 74 6f 20 70 45 72 72   message to pErr
0d30: 6f 72 44 62 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  orDb..*/.static 
0d40: 42 74 72 65 65 20 2a 66 69 6e 64 42 74 72 65 65  Btree *findBtree
0d50: 28 73 71 6c 69 74 65 33 20 2a 70 45 72 72 6f 72  (sqlite3 *pError
0d60: 44 62 2c 20 73 71 6c 69 74 65 33 20 2a 70 44 62  Db, sqlite3 *pDb
0d70: 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 44  , const char *zD
0d80: 62 29 7b 0a 20 20 69 6e 74 20 69 20 3d 20 73 71  b){.  int i = sq
0d90: 6c 69 74 65 33 46 69 6e 64 44 62 4e 61 6d 65 28  lite3FindDbName(
0da0: 70 44 62 2c 20 7a 44 62 29 3b 0a 0a 20 20 69 66  pDb, zDb);..  if
0db0: 28 20 69 3d 3d 31 20 29 7b 0a 20 20 20 20 50 61  ( i==1 ){.    Pa
0dc0: 72 73 65 20 2a 70 50 61 72 73 65 3b 0a 20 20 20  rse *pParse;.   
0dd0: 20 69 6e 74 20 72 63 20 3d 20 30 3b 0a 20 20 20   int rc = 0;.   
0de0: 20 70 50 61 72 73 65 20 3d 20 73 71 6c 69 74 65   pParse = sqlite
0df0: 33 53 74 61 63 6b 41 6c 6c 6f 63 5a 65 72 6f 28  3StackAllocZero(
0e00: 70 45 72 72 6f 72 44 62 2c 20 73 69 7a 65 6f 66  pErrorDb, sizeof
0e10: 28 2a 70 50 61 72 73 65 29 29 3b 0a 20 20 20 20  (*pParse));.    
0e20: 69 66 28 20 70 50 61 72 73 65 3d 3d 30 20 29 7b  if( pParse==0 ){
0e30: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 45 72  .      sqlite3Er
0e40: 72 6f 72 57 69 74 68 4d 73 67 28 70 45 72 72 6f  rorWithMsg(pErro
0e50: 72 44 62 2c 20 53 51 4c 49 54 45 5f 4e 4f 4d 45  rDb, SQLITE_NOME
0e60: 4d 2c 20 22 6f 75 74 20 6f 66 20 6d 65 6d 6f 72  M, "out of memor
0e70: 79 22 29 3b 0a 20 20 20 20 20 20 72 63 20 3d 20  y");.      rc = 
0e80: 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 5f 42 4b 50  SQLITE_NOMEM_BKP
0e90: 54 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20  T;.    }else{.  
0ea0: 20 20 20 20 70 50 61 72 73 65 2d 3e 64 62 20 3d      pParse->db =
0eb0: 20 70 44 62 3b 0a 20 20 20 20 20 20 69 66 28 20   pDb;.      if( 
0ec0: 73 71 6c 69 74 65 33 4f 70 65 6e 54 65 6d 70 44  sqlite3OpenTempD
0ed0: 61 74 61 62 61 73 65 28 70 50 61 72 73 65 29 20  atabase(pParse) 
0ee0: 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  ){.        sqlit
0ef0: 65 33 45 72 72 6f 72 57 69 74 68 4d 73 67 28 70  e3ErrorWithMsg(p
0f00: 45 72 72 6f 72 44 62 2c 20 70 50 61 72 73 65 2d  ErrorDb, pParse-
0f10: 3e 72 63 2c 20 22 25 73 22 2c 20 70 50 61 72 73  >rc, "%s", pPars
0f20: 65 2d 3e 7a 45 72 72 4d 73 67 29 3b 0a 20 20 20  e->zErrMsg);.   
0f30: 20 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45       rc = SQLITE
0f40: 5f 45 52 52 4f 52 3b 0a 20 20 20 20 20 20 7d 0a  _ERROR;.      }.
0f50: 20 20 20 20 20 20 73 71 6c 69 74 65 33 44 62 46        sqlite3DbF
0f60: 72 65 65 28 70 45 72 72 6f 72 44 62 2c 20 70 50  ree(pErrorDb, pP
0f70: 61 72 73 65 2d 3e 7a 45 72 72 4d 73 67 29 3b 0a  arse->zErrMsg);.
0f80: 20 20 20 20 20 20 73 71 6c 69 74 65 33 50 61 72        sqlite3Par
0f90: 73 65 72 52 65 73 65 74 28 70 50 61 72 73 65 29  serReset(pParse)
0fa0: 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 53  ;.      sqlite3S
0fb0: 74 61 63 6b 46 72 65 65 28 70 45 72 72 6f 72 44  tackFree(pErrorD
0fc0: 62 2c 20 70 50 61 72 73 65 29 3b 0a 20 20 20 20  b, pParse);.    
0fd0: 7d 0a 20 20 20 20 69 66 28 20 72 63 20 29 7b 0a  }.    if( rc ){.
0fe0: 20 20 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0a        return 0;.
0ff0: 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 69 66 28      }.  }..  if(
1000: 20 69 3c 30 20 29 7b 0a 20 20 20 20 73 71 6c 69   i<0 ){.    sqli
1010: 74 65 33 45 72 72 6f 72 57 69 74 68 4d 73 67 28  te3ErrorWithMsg(
1020: 70 45 72 72 6f 72 44 62 2c 20 53 51 4c 49 54 45  pErrorDb, SQLITE
1030: 5f 45 52 52 4f 52 2c 20 22 75 6e 6b 6e 6f 77 6e  _ERROR, "unknown
1040: 20 64 61 74 61 62 61 73 65 20 25 73 22 2c 20 7a   database %s", z
1050: 44 62 29 3b 0a 20 20 20 20 72 65 74 75 72 6e 20  Db);.    return 
1060: 30 3b 0a 20 20 7d 0a 0a 20 20 72 65 74 75 72 6e  0;.  }..  return
1070: 20 70 44 62 2d 3e 61 44 62 5b 69 5d 2e 70 42 74   pDb->aDb[i].pBt
1080: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 41 74 74 65 6d  ;.}../*.** Attem
1090: 70 74 20 74 6f 20 73 65 74 20 74 68 65 20 70 61  pt to set the pa
10a0: 67 65 20 73 69 7a 65 20 6f 66 20 74 68 65 20 64  ge size of the d
10b0: 65 73 74 69 6e 61 74 69 6f 6e 20 74 6f 20 6d 61  estination to ma
10c0: 74 63 68 20 74 68 65 20 70 61 67 65 20 73 69 7a  tch the page siz
10d0: 65 0a 2a 2a 20 6f 66 20 74 68 65 20 73 6f 75 72  e.** of the sour
10e0: 63 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e  ce..*/.static in
10f0: 74 20 73 65 74 44 65 73 74 50 67 73 7a 28 73 71  t setDestPgsz(sq
1100: 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 29  lite3_backup *p)
1110: 7b 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20 72 63  {.  int rc;.  rc
1120: 20 3d 20 73 71 6c 69 74 65 33 42 74 72 65 65 53   = sqlite3BtreeS
1130: 65 74 50 61 67 65 53 69 7a 65 28 70 2d 3e 70 44  etPageSize(p->pD
1140: 65 73 74 2c 73 71 6c 69 74 65 33 42 74 72 65 65  est,sqlite3Btree
1150: 47 65 74 50 61 67 65 53 69 7a 65 28 70 2d 3e 70  GetPageSize(p->p
1160: 53 72 63 29 2c 2d 31 2c 30 29 3b 0a 20 20 72 65  Src),-1,0);.  re
1170: 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a  turn rc;.}../*.*
1180: 2a 20 43 68 65 63 6b 20 74 68 61 74 20 74 68 65  * Check that the
1190: 72 65 20 69 73 20 6e 6f 20 6f 70 65 6e 20 72 65  re is no open re
11a0: 61 64 2d 74 72 61 6e 73 61 63 74 69 6f 6e 20 6f  ad-transaction o
11b0: 6e 20 74 68 65 20 62 2d 74 72 65 65 20 70 61 73  n the b-tree pas
11c0: 73 65 64 20 61 73 20 74 68 65 0a 2a 2a 20 73 65  sed as the.** se
11d0: 63 6f 6e 64 20 61 72 67 75 6d 65 6e 74 2e 20 49  cond argument. I
11e0: 66 20 74 68 65 72 65 20 69 73 20 6e 6f 74 2c 20  f there is not, 
11f0: 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b  return SQLITE_OK
1200: 2e 20 4f 74 68 65 72 77 69 73 65 2c 20 69 66 20  . Otherwise, if 
1210: 74 68 65 72 65 0a 2a 2a 20 69 73 20 61 6e 20 6f  there.** is an o
1220: 70 65 6e 20 72 65 61 64 2d 74 72 61 6e 73 61 63  pen read-transac
1230: 74 69 6f 6e 2c 20 72 65 74 75 72 6e 20 53 51 4c  tion, return SQL
1240: 49 54 45 5f 45 52 52 4f 52 20 61 6e 64 20 6c 65  ITE_ERROR and le
1250: 61 76 65 20 61 6e 20 65 72 72 6f 72 20 0a 2a 2a  ave an error .**
1260: 20 6d 65 73 73 61 67 65 20 69 6e 20 64 61 74 61   message in data
1270: 62 61 73 65 20 68 61 6e 64 6c 65 20 64 62 2e 0a  base handle db..
1280: 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 63 68  */.static int ch
1290: 65 63 6b 52 65 61 64 54 72 61 6e 73 61 63 74 69  eckReadTransacti
12a0: 6f 6e 28 73 71 6c 69 74 65 33 20 2a 64 62 2c 20  on(sqlite3 *db, 
12b0: 42 74 72 65 65 20 2a 70 29 7b 0a 20 20 69 66 28  Btree *p){.  if(
12c0: 20 73 71 6c 69 74 65 33 42 74 72 65 65 49 73 49   sqlite3BtreeIsI
12d0: 6e 52 65 61 64 54 72 61 6e 73 28 70 29 20 29 7b  nReadTrans(p) ){
12e0: 0a 20 20 20 20 73 71 6c 69 74 65 33 45 72 72 6f  .    sqlite3Erro
12f0: 72 57 69 74 68 4d 73 67 28 64 62 2c 20 53 51 4c  rWithMsg(db, SQL
1300: 49 54 45 5f 45 52 52 4f 52 2c 20 22 64 65 73 74  ITE_ERROR, "dest
1310: 69 6e 61 74 69 6f 6e 20 64 61 74 61 62 61 73 65  ination database
1320: 20 69 73 20 69 6e 20 75 73 65 22 29 3b 0a 20 20   is in use");.  
1330: 20 20 72 65 74 75 72 6e 20 53 51 4c 49 54 45 5f    return SQLITE_
1340: 45 52 52 4f 52 3b 0a 20 20 7d 0a 20 20 72 65 74  ERROR;.  }.  ret
1350: 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 7d  urn SQLITE_OK;.}
1360: 0a 0a 2f 2a 0a 2a 2a 20 43 72 65 61 74 65 20 61  ../*.** Create a
1370: 6e 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70  n sqlite3_backup
1380: 20 70 72 6f 63 65 73 73 20 74 6f 20 63 6f 70 79   process to copy
1390: 20 74 68 65 20 63 6f 6e 74 65 6e 74 73 20 6f 66   the contents of
13a0: 20 7a 53 72 63 44 62 20 66 72 6f 6d 0a 2a 2a 20   zSrcDb from.** 
13b0: 63 6f 6e 6e 65 63 74 69 6f 6e 20 68 61 6e 64 6c  connection handl
13c0: 65 20 70 53 72 63 44 62 20 74 6f 20 7a 44 65 73  e pSrcDb to zDes
13d0: 74 44 62 20 69 6e 20 70 44 65 73 74 44 62 2e 20  tDb in pDestDb. 
13e0: 49 66 20 73 75 63 63 65 73 73 66 75 6c 2c 20 72  If successful, r
13f0: 65 74 75 72 6e 0a 2a 2a 20 61 20 70 6f 69 6e 74  eturn.** a point
1400: 65 72 20 74 6f 20 74 68 65 20 6e 65 77 20 73 71  er to the new sq
1410: 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 6f 62 6a  lite3_backup obj
1420: 65 63 74 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 61 6e  ect..**.** If an
1430: 20 65 72 72 6f 72 20 6f 63 63 75 72 73 2c 20 4e   error occurs, N
1440: 55 4c 4c 20 69 73 20 72 65 74 75 72 6e 65 64 20  ULL is returned 
1450: 61 6e 64 20 61 6e 20 65 72 72 6f 72 20 63 6f 64  and an error cod
1460: 65 20 61 6e 64 20 65 72 72 6f 72 20 6d 65 73 73  e and error mess
1470: 61 67 65 0a 2a 2a 20 73 74 6f 72 65 64 20 69 6e  age.** stored in
1480: 20 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c 65   database handle
1490: 20 70 44 65 73 74 44 62 2e 0a 2a 2f 0a 73 71 6c   pDestDb..*/.sql
14a0: 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 73 71 6c  ite3_backup *sql
14b0: 69 74 65 33 5f 62 61 63 6b 75 70 5f 69 6e 69 74  ite3_backup_init
14c0: 28 0a 20 20 73 71 6c 69 74 65 33 2a 20 70 44 65  (.  sqlite3* pDe
14d0: 73 74 44 62 2c 20 20 20 20 20 20 20 20 20 20 20  stDb,           
14e0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 44 61 74            /* Dat
14f0: 61 62 61 73 65 20 74 6f 20 77 72 69 74 65 20 74  abase to write t
1500: 6f 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61  o */.  const cha
1510: 72 20 2a 7a 44 65 73 74 44 62 2c 20 20 20 20 20  r *zDestDb,     
1520: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
1530: 4e 61 6d 65 20 6f 66 20 64 61 74 61 62 61 73 65  Name of database
1540: 20 77 69 74 68 69 6e 20 70 44 65 73 74 44 62 20   within pDestDb 
1550: 2a 2f 0a 20 20 73 71 6c 69 74 65 33 2a 20 70 53  */.  sqlite3* pS
1560: 72 63 44 62 2c 20 20 20 20 20 20 20 20 20 20 20  rcDb,           
1570: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 44 61             /* Da
1580: 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f  tabase connectio
1590: 6e 20 74 6f 20 72 65 61 64 20 66 72 6f 6d 20 2a  n to read from *
15a0: 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  /.  const char *
15b0: 7a 53 72 63 44 62 20 20 20 20 20 20 20 20 20 20  zSrcDb          
15c0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 61 6d            /* Nam
15d0: 65 20 6f 66 20 64 61 74 61 62 61 73 65 20 77 69  e of database wi
15e0: 74 68 69 6e 20 70 53 72 63 44 62 20 2a 2f 0a 29  thin pSrcDb */.)
15f0: 7b 0a 20 20 73 71 6c 69 74 65 33 5f 62 61 63 6b  {.  sqlite3_back
1600: 75 70 20 2a 70 3b 20 20 20 20 20 20 20 20 20 20  up *p;          
1610: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 56 61 6c            /* Val
1620: 75 65 20 74 6f 20 72 65 74 75 72 6e 20 2a 2f 0a  ue to return */.
1630: 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 45  .#ifdef SQLITE_E
1640: 4e 41 42 4c 45 5f 41 50 49 5f 41 52 4d 4f 52 0a  NABLE_API_ARMOR.
1650: 20 20 69 66 28 20 21 73 71 6c 69 74 65 33 53 61    if( !sqlite3Sa
1660: 66 65 74 79 43 68 65 63 6b 4f 6b 28 70 53 72 63  fetyCheckOk(pSrc
1670: 44 62 29 7c 7c 21 73 71 6c 69 74 65 33 53 61 66  Db)||!sqlite3Saf
1680: 65 74 79 43 68 65 63 6b 4f 6b 28 70 44 65 73 74  etyCheckOk(pDest
1690: 44 62 29 20 29 7b 0a 20 20 20 20 28 76 6f 69 64  Db) ){.    (void
16a0: 29 53 51 4c 49 54 45 5f 4d 49 53 55 53 45 5f 42  )SQLITE_MISUSE_B
16b0: 4b 50 54 3b 0a 20 20 20 20 72 65 74 75 72 6e 20  KPT;.    return 
16c0: 30 3b 0a 20 20 7d 0a 23 65 6e 64 69 66 0a 0a 20  0;.  }.#endif.. 
16d0: 20 2f 2a 20 4c 6f 63 6b 20 74 68 65 20 73 6f 75   /* Lock the sou
16e0: 72 63 65 20 64 61 74 61 62 61 73 65 20 68 61 6e  rce database han
16f0: 64 6c 65 2e 20 54 68 65 20 64 65 73 74 69 6e 61  dle. The destina
1700: 74 69 6f 6e 20 64 61 74 61 62 61 73 65 0a 20 20  tion database.  
1710: 2a 2a 20 68 61 6e 64 6c 65 20 69 73 20 6e 6f 74  ** handle is not
1720: 20 6c 6f 63 6b 65 64 20 69 6e 20 74 68 69 73 20   locked in this 
1730: 72 6f 75 74 69 6e 65 2c 20 62 75 74 20 69 74 20  routine, but it 
1740: 69 73 20 6c 6f 63 6b 65 64 20 69 6e 0a 20 20 2a  is locked in.  *
1750: 2a 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70  * sqlite3_backup
1760: 5f 73 74 65 70 28 29 2e 20 54 68 65 20 75 73 65  _step(). The use
1770: 72 20 69 73 20 72 65 71 75 69 72 65 64 20 74 6f  r is required to
1780: 20 65 6e 73 75 72 65 20 74 68 61 74 20 6e 6f 0a   ensure that no.
1790: 20 20 2a 2a 20 6f 74 68 65 72 20 74 68 72 65 61    ** other threa
17a0: 64 20 61 63 63 65 73 73 65 73 20 74 68 65 20 64  d accesses the d
17b0: 65 73 74 69 6e 61 74 69 6f 6e 20 68 61 6e 64 6c  estination handl
17c0: 65 20 66 6f 72 20 74 68 65 20 64 75 72 61 74 69  e for the durati
17d0: 6f 6e 0a 20 20 2a 2a 20 6f 66 20 74 68 65 20 62  on.  ** of the b
17e0: 61 63 6b 75 70 20 6f 70 65 72 61 74 69 6f 6e 2e  ackup operation.
17f0: 20 20 41 6e 79 20 61 74 74 65 6d 70 74 20 74 6f    Any attempt to
1800: 20 75 73 65 20 74 68 65 20 64 65 73 74 69 6e 61   use the destina
1810: 74 69 6f 6e 0a 20 20 2a 2a 20 64 61 74 61 62 61  tion.  ** databa
1820: 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 77 68  se connection wh
1830: 69 6c 65 20 61 20 62 61 63 6b 75 70 20 69 73 20  ile a backup is 
1840: 69 6e 20 70 72 6f 67 72 65 73 73 20 6d 61 79 20  in progress may 
1850: 63 61 75 73 65 0a 20 20 2a 2a 20 61 20 6d 61 6c  cause.  ** a mal
1860: 66 75 6e 63 74 69 6f 6e 20 6f 72 20 61 20 64 65  function or a de
1870: 61 64 6c 6f 63 6b 2e 0a 20 20 2a 2f 0a 20 20 73  adlock..  */.  s
1880: 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74  qlite3_mutex_ent
1890: 65 72 28 70 53 72 63 44 62 2d 3e 6d 75 74 65 78  er(pSrcDb->mutex
18a0: 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74  );.  sqlite3_mut
18b0: 65 78 5f 65 6e 74 65 72 28 70 44 65 73 74 44 62  ex_enter(pDestDb
18c0: 2d 3e 6d 75 74 65 78 29 3b 0a 0a 20 20 69 66 28  ->mutex);..  if(
18d0: 20 70 53 72 63 44 62 3d 3d 70 44 65 73 74 44 62   pSrcDb==pDestDb
18e0: 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 45   ){.    sqlite3E
18f0: 72 72 6f 72 57 69 74 68 4d 73 67 28 0a 20 20 20  rrorWithMsg(.   
1900: 20 20 20 20 20 70 44 65 73 74 44 62 2c 20 53 51       pDestDb, SQ
1910: 4c 49 54 45 5f 45 52 52 4f 52 2c 20 22 73 6f 75  LITE_ERROR, "sou
1920: 72 63 65 20 61 6e 64 20 64 65 73 74 69 6e 61 74  rce and destinat
1930: 69 6f 6e 20 6d 75 73 74 20 62 65 20 64 69 73 74  ion must be dist
1940: 69 6e 63 74 22 0a 20 20 20 20 29 3b 0a 20 20 20  inct".    );.   
1950: 20 70 20 3d 20 30 3b 0a 20 20 7d 65 6c 73 65 20   p = 0;.  }else 
1960: 7b 0a 20 20 20 20 2f 2a 20 41 6c 6c 6f 63 61 74  {.    /* Allocat
1970: 65 20 73 70 61 63 65 20 66 6f 72 20 61 20 6e 65  e space for a ne
1980: 77 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70  w sqlite3_backup
1990: 20 6f 62 6a 65 63 74 2e 2e 2e 0a 20 20 20 20 2a   object....    *
19a0: 2a 20 45 56 49 44 45 4e 43 45 2d 4f 46 3a 20 52  * EVIDENCE-OF: R
19b0: 2d 36 34 38 35 32 2d 32 31 35 39 31 20 54 68 65  -64852-21591 The
19c0: 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20   sqlite3_backup 
19d0: 6f 62 6a 65 63 74 20 69 73 20 63 72 65 61 74 65  object is create
19e0: 64 20 62 79 20 61 0a 20 20 20 20 2a 2a 20 63 61  d by a.    ** ca
19f0: 6c 6c 20 74 6f 20 73 71 6c 69 74 65 33 5f 62 61  ll to sqlite3_ba
1a00: 63 6b 75 70 5f 69 6e 69 74 28 29 20 61 6e 64 20  ckup_init() and 
1a10: 69 73 20 64 65 73 74 72 6f 79 65 64 20 62 79 20  is destroyed by 
1a20: 61 20 63 61 6c 6c 20 74 6f 0a 20 20 20 20 2a 2a  a call to.    **
1a30: 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f   sqlite3_backup_
1a40: 66 69 6e 69 73 68 28 29 2e 20 2a 2f 0a 20 20 20  finish(). */.   
1a50: 20 70 20 3d 20 28 73 71 6c 69 74 65 33 5f 62 61   p = (sqlite3_ba
1a60: 63 6b 75 70 20 2a 29 73 71 6c 69 74 65 33 4d 61  ckup *)sqlite3Ma
1a70: 6c 6c 6f 63 5a 65 72 6f 28 73 69 7a 65 6f 66 28  llocZero(sizeof(
1a80: 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 29 29  sqlite3_backup))
1a90: 3b 0a 20 20 20 20 69 66 28 20 21 70 20 29 7b 0a  ;.    if( !p ){.
1aa0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 45 72 72        sqlite3Err
1ab0: 6f 72 28 70 44 65 73 74 44 62 2c 20 53 51 4c 49  or(pDestDb, SQLI
1ac0: 54 45 5f 4e 4f 4d 45 4d 5f 42 4b 50 54 29 3b 0a  TE_NOMEM_BKPT);.
1ad0: 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 2f 2a 20      }.  }..  /* 
1ae0: 49 66 20 74 68 65 20 61 6c 6c 6f 63 61 74 69 6f  If the allocatio
1af0: 6e 20 73 75 63 63 65 65 64 65 64 2c 20 70 6f 70  n succeeded, pop
1b00: 75 6c 61 74 65 20 74 68 65 20 6e 65 77 20 6f 62  ulate the new ob
1b10: 6a 65 63 74 2e 20 2a 2f 0a 20 20 69 66 28 20 70  ject. */.  if( p
1b20: 20 29 7b 0a 20 20 20 20 70 2d 3e 70 53 72 63 20   ){.    p->pSrc 
1b30: 3d 20 66 69 6e 64 42 74 72 65 65 28 70 44 65 73  = findBtree(pDes
1b40: 74 44 62 2c 20 70 53 72 63 44 62 2c 20 7a 53 72  tDb, pSrcDb, zSr
1b50: 63 44 62 29 3b 0a 20 20 20 20 70 2d 3e 70 44 65  cDb);.    p->pDe
1b60: 73 74 20 3d 20 66 69 6e 64 42 74 72 65 65 28 70  st = findBtree(p
1b70: 44 65 73 74 44 62 2c 20 70 44 65 73 74 44 62 2c  DestDb, pDestDb,
1b80: 20 7a 44 65 73 74 44 62 29 3b 0a 20 20 20 20 70   zDestDb);.    p
1b90: 2d 3e 70 44 65 73 74 44 62 20 3d 20 70 44 65 73  ->pDestDb = pDes
1ba0: 74 44 62 3b 0a 20 20 20 20 70 2d 3e 70 53 72 63  tDb;.    p->pSrc
1bb0: 44 62 20 3d 20 70 53 72 63 44 62 3b 0a 20 20 20  Db = pSrcDb;.   
1bc0: 20 70 2d 3e 69 4e 65 78 74 20 3d 20 31 3b 0a 20   p->iNext = 1;. 
1bd0: 20 20 20 70 2d 3e 69 73 41 74 74 61 63 68 65 64     p->isAttached
1be0: 20 3d 20 30 3b 0a 0a 20 20 20 20 69 66 28 20 30   = 0;..    if( 0
1bf0: 3d 3d 70 2d 3e 70 53 72 63 20 7c 7c 20 30 3d 3d  ==p->pSrc || 0==
1c00: 70 2d 3e 70 44 65 73 74 20 0a 20 20 20 20 20 7c  p->pDest .     |
1c10: 7c 20 73 65 74 44 65 73 74 50 67 73 7a 28 70 29  | setDestPgsz(p)
1c20: 3d 3d 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 20 0a  ==SQLITE_NOMEM .
1c30: 20 20 20 20 20 7c 7c 20 63 68 65 63 6b 52 65 61       || checkRea
1c40: 64 54 72 61 6e 73 61 63 74 69 6f 6e 28 70 44 65  dTransaction(pDe
1c50: 73 74 44 62 2c 20 70 2d 3e 70 44 65 73 74 29 21  stDb, p->pDest)!
1c60: 3d 53 51 4c 49 54 45 5f 4f 4b 20 0a 20 20 20 20  =SQLITE_OK .    
1c70: 20 29 7b 0a 20 20 20 20 20 20 2f 2a 20 4f 6e 65   ){.      /* One
1c80: 20 28 6f 72 20 62 6f 74 68 29 20 6f 66 20 74 68   (or both) of th
1c90: 65 20 6e 61 6d 65 64 20 64 61 74 61 62 61 73 65  e named database
1ca0: 73 20 64 69 64 20 6e 6f 74 20 65 78 69 73 74 20  s did not exist 
1cb0: 6f 72 20 61 6e 20 4f 4f 4d 0a 20 20 20 20 20 20  or an OOM.      
1cc0: 2a 2a 20 65 72 72 6f 72 20 77 61 73 20 68 69 74  ** error was hit
1cd0: 2e 20 4f 72 20 74 68 65 72 65 20 69 73 20 61 20  . Or there is a 
1ce0: 74 72 61 6e 73 61 63 74 69 6f 6e 20 6f 70 65 6e  transaction open
1cf0: 20 6f 6e 20 74 68 65 20 64 65 73 74 69 6e 61 74   on the destinat
1d00: 69 6f 6e 0a 20 20 20 20 20 20 2a 2a 20 64 61 74  ion.      ** dat
1d10: 61 62 61 73 65 2e 20 54 68 65 20 65 72 72 6f 72  abase. The error
1d20: 20 68 61 73 20 61 6c 72 65 61 64 79 20 62 65 65   has already bee
1d30: 6e 20 77 72 69 74 74 65 6e 20 69 6e 74 6f 20 74  n written into t
1d40: 68 65 20 70 44 65 73 74 44 62 20 0a 20 20 20 20  he pDestDb .    
1d50: 20 20 2a 2a 20 68 61 6e 64 6c 65 2e 20 41 6c 6c    ** handle. All
1d60: 20 74 68 61 74 20 69 73 20 6c 65 66 74 20 74 6f   that is left to
1d70: 20 64 6f 20 68 65 72 65 20 69 73 20 66 72 65 65   do here is free
1d80: 20 74 68 65 20 73 71 6c 69 74 65 33 5f 62 61 63   the sqlite3_bac
1d90: 6b 75 70 20 0a 20 20 20 20 20 20 2a 2a 20 73 74  kup .      ** st
1da0: 72 75 63 74 75 72 65 2e 20 20 2a 2f 0a 20 20 20  ructure.  */.   
1db0: 20 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28     sqlite3_free(
1dc0: 70 29 3b 0a 20 20 20 20 20 20 70 20 3d 20 30 3b  p);.      p = 0;
1dd0: 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 69 66 28  .    }.  }.  if(
1de0: 20 70 20 29 7b 0a 20 20 20 20 70 2d 3e 70 53 72   p ){.    p->pSr
1df0: 63 2d 3e 6e 42 61 63 6b 75 70 2b 2b 3b 0a 20 20  c->nBackup++;.  
1e00: 7d 0a 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74  }..  sqlite3_mut
1e10: 65 78 5f 6c 65 61 76 65 28 70 44 65 73 74 44 62  ex_leave(pDestDb
1e20: 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 73 71 6c 69  ->mutex);.  sqli
1e30: 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28  te3_mutex_leave(
1e40: 70 53 72 63 44 62 2d 3e 6d 75 74 65 78 29 3b 0a  pSrcDb->mutex);.
1e50: 20 20 72 65 74 75 72 6e 20 70 3b 0a 7d 0a 0a 2f    return p;.}../
1e60: 2a 0a 2a 2a 20 41 72 67 75 6d 65 6e 74 20 72 63  *.** Argument rc
1e70: 20 69 73 20 61 6e 20 53 51 4c 69 74 65 20 65 72   is an SQLite er
1e80: 72 6f 72 20 63 6f 64 65 2e 20 52 65 74 75 72 6e  ror code. Return
1e90: 20 74 72 75 65 20 69 66 20 74 68 69 73 20 65 72   true if this er
1ea0: 72 6f 72 20 69 73 20 0a 2a 2a 20 63 6f 6e 73 69  ror is .** consi
1eb0: 64 65 72 65 64 20 66 61 74 61 6c 20 69 66 20 65  dered fatal if e
1ec0: 6e 63 6f 75 6e 74 65 72 65 64 20 64 75 72 69 6e  ncountered durin
1ed0: 67 20 61 20 62 61 63 6b 75 70 20 6f 70 65 72 61  g a backup opera
1ee0: 74 69 6f 6e 2e 20 41 6c 6c 20 65 72 72 6f 72 73  tion. All errors
1ef0: 0a 2a 2a 20 61 72 65 20 63 6f 6e 73 69 64 65 72  .** are consider
1f00: 65 64 20 66 61 74 61 6c 20 65 78 63 65 70 74 20  ed fatal except 
1f10: 66 6f 72 20 53 51 4c 49 54 45 5f 42 55 53 59 20  for SQLITE_BUSY 
1f20: 61 6e 64 20 53 51 4c 49 54 45 5f 4c 4f 43 4b 45  and SQLITE_LOCKE
1f30: 44 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74  D..*/.static int
1f40: 20 69 73 46 61 74 61 6c 45 72 72 6f 72 28 69 6e   isFatalError(in
1f50: 74 20 72 63 29 7b 0a 20 20 72 65 74 75 72 6e 20  t rc){.  return 
1f60: 28 72 63 21 3d 53 51 4c 49 54 45 5f 4f 4b 20 26  (rc!=SQLITE_OK &
1f70: 26 20 72 63 21 3d 53 51 4c 49 54 45 5f 42 55 53  & rc!=SQLITE_BUS
1f80: 59 20 26 26 20 41 4c 57 41 59 53 28 72 63 21 3d  Y && ALWAYS(rc!=
1f90: 53 51 4c 49 54 45 5f 4c 4f 43 4b 45 44 29 29 3b  SQLITE_LOCKED));
1fa0: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 50 61 72 61 6d 65  .}../*.** Parame
1fb0: 74 65 72 20 7a 53 72 63 44 61 74 61 20 70 6f 69  ter zSrcData poi
1fc0: 6e 74 73 20 74 6f 20 61 20 62 75 66 66 65 72 20  nts to a buffer 
1fd0: 63 6f 6e 74 61 69 6e 69 6e 67 20 74 68 65 20 64  containing the d
1fe0: 61 74 61 20 66 6f 72 20 0a 2a 2a 20 70 61 67 65  ata for .** page
1ff0: 20 69 53 72 63 50 67 20 66 72 6f 6d 20 74 68 65   iSrcPg from the
2000: 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73 65   source database
2010: 2e 20 43 6f 70 79 20 74 68 69 73 20 64 61 74 61  . Copy this data
2020: 20 69 6e 74 6f 20 74 68 65 20 0a 2a 2a 20 64 65   into the .** de
2030: 73 74 69 6e 61 74 69 6f 6e 20 64 61 74 61 62 61  stination databa
2040: 73 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e  se..*/.static in
2050: 74 20 62 61 63 6b 75 70 4f 6e 65 50 61 67 65 28  t backupOnePage(
2060: 0a 20 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75  .  sqlite3_backu
2070: 70 20 2a 70 2c 20 20 20 20 20 20 20 20 20 20 20  p *p,           
2080: 20 20 20 2f 2a 20 42 61 63 6b 75 70 20 68 61 6e     /* Backup han
2090: 64 6c 65 20 2a 2f 0a 20 20 50 67 6e 6f 20 69 53  dle */.  Pgno iS
20a0: 72 63 50 67 2c 20 20 20 20 20 20 20 20 20 20 20  rcPg,           
20b0: 20 20 20 20 20 20 20 20 20 2f 2a 20 53 6f 75 72           /* Sour
20c0: 63 65 20 64 61 74 61 62 61 73 65 20 70 61 67 65  ce database page
20d0: 20 74 6f 20 62 61 63 6b 75 70 20 2a 2f 0a 20 20   to backup */.  
20e0: 63 6f 6e 73 74 20 75 38 20 2a 7a 53 72 63 44 61  const u8 *zSrcDa
20f0: 74 61 2c 20 20 20 20 20 20 20 20 20 20 20 20 20  ta,             
2100: 2f 2a 20 53 6f 75 72 63 65 20 64 61 74 61 62 61  /* Source databa
2110: 73 65 20 70 61 67 65 20 64 61 74 61 20 2a 2f 0a  se page data */.
2120: 20 20 69 6e 74 20 62 55 70 64 61 74 65 20 20 20    int bUpdate   
2130: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2140: 20 20 2f 2a 20 54 72 75 65 20 66 6f 72 20 61 6e    /* True for an
2150: 20 75 70 64 61 74 65 2c 20 66 61 6c 73 65 20 6f   update, false o
2160: 74 68 65 72 77 69 73 65 20 2a 2f 0a 29 7b 0a 20  therwise */.){. 
2170: 20 50 61 67 65 72 20 2a 20 63 6f 6e 73 74 20 70   Pager * const p
2180: 44 65 73 74 50 61 67 65 72 20 3d 20 73 71 6c 69  DestPager = sqli
2190: 74 65 33 42 74 72 65 65 50 61 67 65 72 28 70 2d  te3BtreePager(p-
21a0: 3e 70 44 65 73 74 29 3b 0a 20 20 63 6f 6e 73 74  >pDest);.  const
21b0: 20 69 6e 74 20 6e 53 72 63 50 67 73 7a 20 3d 20   int nSrcPgsz = 
21c0: 73 71 6c 69 74 65 33 42 74 72 65 65 47 65 74 50  sqlite3BtreeGetP
21d0: 61 67 65 53 69 7a 65 28 70 2d 3e 70 53 72 63 29  ageSize(p->pSrc)
21e0: 3b 0a 20 20 69 6e 74 20 6e 44 65 73 74 50 67 73  ;.  int nDestPgs
21f0: 7a 20 3d 20 73 71 6c 69 74 65 33 42 74 72 65 65  z = sqlite3Btree
2200: 47 65 74 50 61 67 65 53 69 7a 65 28 70 2d 3e 70  GetPageSize(p->p
2210: 44 65 73 74 29 3b 0a 20 20 63 6f 6e 73 74 20 69  Dest);.  const i
2220: 6e 74 20 6e 43 6f 70 79 20 3d 20 4d 49 4e 28 6e  nt nCopy = MIN(n
2230: 53 72 63 50 67 73 7a 2c 20 6e 44 65 73 74 50 67  SrcPgsz, nDestPg
2240: 73 7a 29 3b 0a 20 20 63 6f 6e 73 74 20 69 36 34  sz);.  const i64
2250: 20 69 45 6e 64 20 3d 20 28 69 36 34 29 69 53 72   iEnd = (i64)iSr
2260: 63 50 67 2a 28 69 36 34 29 6e 53 72 63 50 67 73  cPg*(i64)nSrcPgs
2270: 7a 3b 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45  z;.#ifdef SQLITE
2280: 5f 48 41 53 5f 43 4f 44 45 43 0a 20 20 2f 2a 20  _HAS_CODEC.  /* 
2290: 55 73 65 20 42 74 72 65 65 47 65 74 52 65 73 65  Use BtreeGetRese
22a0: 72 76 65 4e 6f 4d 75 74 65 78 28 29 20 66 6f 72  rveNoMutex() for
22b0: 20 74 68 65 20 73 6f 75 72 63 65 20 62 2d 74 72   the source b-tr
22c0: 65 65 2c 20 61 73 20 61 6c 74 68 6f 75 67 68 20  ee, as although 
22d0: 69 74 20 69 73 0a 20 20 2a 2a 20 67 75 61 72 61  it is.  ** guara
22e0: 6e 74 65 65 64 20 74 68 61 74 20 74 68 65 20 73  nteed that the s
22f0: 68 61 72 65 64 2d 6d 75 74 65 78 20 69 73 20 68  hared-mutex is h
2300: 65 6c 64 20 62 79 20 74 68 69 73 20 74 68 72 65  eld by this thre
2310: 61 64 2c 20 68 61 6e 64 6c 65 0a 20 20 2a 2a 20  ad, handle.  ** 
2320: 70 2d 3e 70 53 72 63 20 6d 61 79 20 6e 6f 74 20  p->pSrc may not 
2330: 61 63 74 75 61 6c 6c 79 20 62 65 20 74 68 65 20  actually be the 
2340: 6f 77 6e 65 72 2e 20 20 2a 2f 0a 20 20 69 6e 74  owner.  */.  int
2350: 20 6e 53 72 63 52 65 73 65 72 76 65 20 3d 20 73   nSrcReserve = s
2360: 71 6c 69 74 65 33 42 74 72 65 65 47 65 74 52 65  qlite3BtreeGetRe
2370: 73 65 72 76 65 4e 6f 4d 75 74 65 78 28 70 2d 3e  serveNoMutex(p->
2380: 70 53 72 63 29 3b 0a 20 20 69 6e 74 20 6e 44 65  pSrc);.  int nDe
2390: 73 74 52 65 73 65 72 76 65 20 3d 20 73 71 6c 69  stReserve = sqli
23a0: 74 65 33 42 74 72 65 65 47 65 74 4f 70 74 69 6d  te3BtreeGetOptim
23b0: 61 6c 52 65 73 65 72 76 65 28 70 2d 3e 70 44 65  alReserve(p->pDe
23c0: 73 74 29 3b 0a 23 65 6e 64 69 66 0a 20 20 69 6e  st);.#endif.  in
23d0: 74 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 4f 4b  t rc = SQLITE_OK
23e0: 3b 0a 20 20 69 36 34 20 69 4f 66 66 3b 0a 0a 20  ;.  i64 iOff;.. 
23f0: 20 61 73 73 65 72 74 28 20 73 71 6c 69 74 65 33   assert( sqlite3
2400: 42 74 72 65 65 47 65 74 52 65 73 65 72 76 65 4e  BtreeGetReserveN
2410: 6f 4d 75 74 65 78 28 70 2d 3e 70 53 72 63 29 3e  oMutex(p->pSrc)>
2420: 3d 30 20 29 3b 0a 20 20 61 73 73 65 72 74 28 20  =0 );.  assert( 
2430: 70 2d 3e 62 44 65 73 74 4c 6f 63 6b 65 64 20 29  p->bDestLocked )
2440: 3b 0a 20 20 61 73 73 65 72 74 28 20 21 69 73 46  ;.  assert( !isF
2450: 61 74 61 6c 45 72 72 6f 72 28 70 2d 3e 72 63 29  atalError(p->rc)
2460: 20 29 3b 0a 20 20 61 73 73 65 72 74 28 20 69 53   );.  assert( iS
2470: 72 63 50 67 21 3d 50 45 4e 44 49 4e 47 5f 42 59  rcPg!=PENDING_BY
2480: 54 45 5f 50 41 47 45 28 70 2d 3e 70 53 72 63 2d  TE_PAGE(p->pSrc-
2490: 3e 70 42 74 29 20 29 3b 0a 20 20 61 73 73 65 72  >pBt) );.  asser
24a0: 74 28 20 7a 53 72 63 44 61 74 61 20 29 3b 0a 0a  t( zSrcData );..
24b0: 20 20 2f 2a 20 43 61 74 63 68 20 74 68 65 20 63    /* Catch the c
24c0: 61 73 65 20 77 68 65 72 65 20 74 68 65 20 64 65  ase where the de
24d0: 73 74 69 6e 61 74 69 6f 6e 20 69 73 20 61 6e 20  stination is an 
24e0: 69 6e 2d 6d 65 6d 6f 72 79 20 64 61 74 61 62 61  in-memory databa
24f0: 73 65 20 61 6e 64 20 74 68 65 0a 20 20 2a 2a 20  se and the.  ** 
2500: 70 61 67 65 20 73 69 7a 65 73 20 6f 66 20 74 68  page sizes of th
2510: 65 20 73 6f 75 72 63 65 20 61 6e 64 20 64 65 73  e source and des
2520: 74 69 6e 61 74 69 6f 6e 20 64 69 66 66 65 72 2e  tination differ.
2530: 20 0a 20 20 2a 2f 0a 20 20 69 66 28 20 6e 53 72   .  */.  if( nSr
2540: 63 50 67 73 7a 21 3d 6e 44 65 73 74 50 67 73 7a  cPgsz!=nDestPgsz
2550: 20 26 26 20 73 71 6c 69 74 65 33 50 61 67 65 72   && sqlite3Pager
2560: 49 73 4d 65 6d 64 62 28 70 44 65 73 74 50 61 67  IsMemdb(pDestPag
2570: 65 72 29 20 29 7b 0a 20 20 20 20 72 63 20 3d 20  er) ){.    rc = 
2580: 53 51 4c 49 54 45 5f 52 45 41 44 4f 4e 4c 59 3b  SQLITE_READONLY;
2590: 0a 20 20 7d 0a 0a 23 69 66 64 65 66 20 53 51 4c  .  }..#ifdef SQL
25a0: 49 54 45 5f 48 41 53 5f 43 4f 44 45 43 0a 20 20  ITE_HAS_CODEC.  
25b0: 2f 2a 20 42 61 63 6b 75 70 20 69 73 20 6e 6f 74  /* Backup is not
25c0: 20 70 6f 73 73 69 62 6c 65 20 69 66 20 74 68 65   possible if the
25d0: 20 70 61 67 65 20 73 69 7a 65 20 6f 66 20 74 68   page size of th
25e0: 65 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 69 73  e destination is
25f0: 20 63 68 61 6e 67 69 6e 67 0a 20 20 2a 2a 20 61   changing.  ** a
2600: 6e 64 20 61 20 63 6f 64 65 63 20 69 73 20 69 6e  nd a codec is in
2610: 20 75 73 65 2e 0a 20 20 2a 2f 0a 20 20 69 66 28   use..  */.  if(
2620: 20 6e 53 72 63 50 67 73 7a 21 3d 6e 44 65 73 74   nSrcPgsz!=nDest
2630: 50 67 73 7a 20 26 26 20 73 71 6c 69 74 65 33 50  Pgsz && sqlite3P
2640: 61 67 65 72 47 65 74 43 6f 64 65 63 28 70 44 65  agerGetCodec(pDe
2650: 73 74 50 61 67 65 72 29 21 3d 30 20 29 7b 0a 20  stPager)!=0 ){. 
2660: 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 52     rc = SQLITE_R
2670: 45 41 44 4f 4e 4c 59 3b 0a 20 20 7d 0a 0a 20 20  EADONLY;.  }..  
2680: 2f 2a 20 42 61 63 6b 75 70 20 69 73 20 6e 6f 74  /* Backup is not
2690: 20 70 6f 73 73 69 62 6c 65 20 69 66 20 74 68 65   possible if the
26a0: 20 6e 75 6d 62 65 72 20 6f 66 20 62 79 74 65 73   number of bytes
26b0: 20 6f 66 20 72 65 73 65 72 76 65 20 73 70 61 63   of reserve spac
26c0: 65 20 64 69 66 66 65 72 0a 20 20 2a 2a 20 62 65  e differ.  ** be
26d0: 74 77 65 65 6e 20 73 6f 75 72 63 65 20 61 6e 64  tween source and
26e0: 20 64 65 73 74 69 6e 61 74 69 6f 6e 2e 20 20 49   destination.  I
26f0: 66 20 74 68 65 72 65 20 69 73 20 61 20 64 69 66  f there is a dif
2700: 66 65 72 65 6e 63 65 2c 20 74 72 79 20 74 6f 0a  ference, try to.
2710: 20 20 2a 2a 20 66 69 78 20 74 68 65 20 64 65 73    ** fix the des
2720: 74 69 6e 61 74 69 6f 6e 20 74 6f 20 61 67 72 65  tination to agre
2730: 65 20 77 69 74 68 20 74 68 65 20 73 6f 75 72 63  e with the sourc
2740: 65 2e 20 20 49 66 20 74 68 61 74 20 69 73 20 6e  e.  If that is n
2750: 6f 74 20 70 6f 73 73 69 62 6c 65 2c 0a 20 20 2a  ot possible,.  *
2760: 2a 20 74 68 65 6e 20 74 68 65 20 62 61 63 6b 75  * then the backu
2770: 70 20 63 61 6e 6e 6f 74 20 70 72 6f 63 65 65 64  p cannot proceed
2780: 2e 0a 20 20 2a 2f 0a 20 20 69 66 28 20 6e 53 72  ..  */.  if( nSr
2790: 63 52 65 73 65 72 76 65 21 3d 6e 44 65 73 74 52  cReserve!=nDestR
27a0: 65 73 65 72 76 65 20 29 7b 0a 20 20 20 20 75 33  eserve ){.    u3
27b0: 32 20 6e 65 77 50 67 73 7a 20 3d 20 6e 53 72 63  2 newPgsz = nSrc
27c0: 50 67 73 7a 3b 0a 20 20 20 20 72 63 20 3d 20 73  Pgsz;.    rc = s
27d0: 71 6c 69 74 65 33 50 61 67 65 72 53 65 74 50 61  qlite3PagerSetPa
27e0: 67 65 73 69 7a 65 28 70 44 65 73 74 50 61 67 65  gesize(pDestPage
27f0: 72 2c 20 26 6e 65 77 50 67 73 7a 2c 20 6e 53 72  r, &newPgsz, nSr
2800: 63 52 65 73 65 72 76 65 29 3b 0a 20 20 20 20 69  cReserve);.    i
2810: 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b  f( rc==SQLITE_OK
2820: 20 26 26 20 6e 65 77 50 67 73 7a 21 3d 6e 53 72   && newPgsz!=nSr
2830: 63 50 67 73 7a 20 29 20 72 63 20 3d 20 53 51 4c  cPgsz ) rc = SQL
2840: 49 54 45 5f 52 45 41 44 4f 4e 4c 59 3b 0a 20 20  ITE_READONLY;.  
2850: 7d 0a 23 65 6e 64 69 66 0a 0a 20 20 2f 2a 20 54  }.#endif..  /* T
2860: 68 69 73 20 6c 6f 6f 70 20 72 75 6e 73 20 6f 6e  his loop runs on
2870: 63 65 20 66 6f 72 20 65 61 63 68 20 64 65 73 74  ce for each dest
2880: 69 6e 61 74 69 6f 6e 20 70 61 67 65 20 73 70 61  ination page spa
2890: 6e 6e 65 64 20 62 79 20 74 68 65 20 73 6f 75 72  nned by the sour
28a0: 63 65 20 0a 20 20 2a 2a 20 70 61 67 65 2e 20 46  ce .  ** page. F
28b0: 6f 72 20 65 61 63 68 20 69 74 65 72 61 74 69 6f  or each iteratio
28c0: 6e 2c 20 76 61 72 69 61 62 6c 65 20 69 4f 66 66  n, variable iOff
28d0: 20 69 73 20 73 65 74 20 74 6f 20 74 68 65 20 62   is set to the b
28e0: 79 74 65 20 6f 66 66 73 65 74 0a 20 20 2a 2a 20  yte offset.  ** 
28f0: 6f 66 20 74 68 65 20 64 65 73 74 69 6e 61 74 69  of the destinati
2900: 6f 6e 20 70 61 67 65 2e 0a 20 20 2a 2f 0a 20 20  on page..  */.  
2910: 66 6f 72 28 69 4f 66 66 3d 69 45 6e 64 2d 28 69  for(iOff=iEnd-(i
2920: 36 34 29 6e 53 72 63 50 67 73 7a 3b 20 72 63 3d  64)nSrcPgsz; rc=
2930: 3d 53 51 4c 49 54 45 5f 4f 4b 20 26 26 20 69 4f  =SQLITE_OK && iO
2940: 66 66 3c 69 45 6e 64 3b 20 69 4f 66 66 2b 3d 6e  ff<iEnd; iOff+=n
2950: 44 65 73 74 50 67 73 7a 29 7b 0a 20 20 20 20 44  DestPgsz){.    D
2960: 62 50 61 67 65 20 2a 70 44 65 73 74 50 67 20 3d  bPage *pDestPg =
2970: 20 30 3b 0a 20 20 20 20 50 67 6e 6f 20 69 44 65   0;.    Pgno iDe
2980: 73 74 20 3d 20 28 50 67 6e 6f 29 28 69 4f 66 66  st = (Pgno)(iOff
2990: 2f 6e 44 65 73 74 50 67 73 7a 29 2b 31 3b 0a 20  /nDestPgsz)+1;. 
29a0: 20 20 20 69 66 28 20 69 44 65 73 74 3d 3d 50 45     if( iDest==PE
29b0: 4e 44 49 4e 47 5f 42 59 54 45 5f 50 41 47 45 28  NDING_BYTE_PAGE(
29c0: 70 2d 3e 70 44 65 73 74 2d 3e 70 42 74 29 20 29  p->pDest->pBt) )
29d0: 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 69   continue;.    i
29e0: 66 28 20 53 51 4c 49 54 45 5f 4f 4b 3d 3d 28 72  f( SQLITE_OK==(r
29f0: 63 20 3d 20 73 71 6c 69 74 65 33 50 61 67 65 72  c = sqlite3Pager
2a00: 47 65 74 28 70 44 65 73 74 50 61 67 65 72 2c 20  Get(pDestPager, 
2a10: 69 44 65 73 74 2c 20 26 70 44 65 73 74 50 67 2c  iDest, &pDestPg,
2a20: 20 30 29 29 0a 20 20 20 20 20 26 26 20 53 51 4c   0)).     && SQL
2a30: 49 54 45 5f 4f 4b 3d 3d 28 72 63 20 3d 20 73 71  ITE_OK==(rc = sq
2a40: 6c 69 74 65 33 50 61 67 65 72 57 72 69 74 65 28  lite3PagerWrite(
2a50: 70 44 65 73 74 50 67 29 29 0a 20 20 20 20 29 7b  pDestPg)).    ){
2a60: 0a 20 20 20 20 20 20 63 6f 6e 73 74 20 75 38 20  .      const u8 
2a70: 2a 7a 49 6e 20 3d 20 26 7a 53 72 63 44 61 74 61  *zIn = &zSrcData
2a80: 5b 69 4f 66 66 25 6e 53 72 63 50 67 73 7a 5d 3b  [iOff%nSrcPgsz];
2a90: 0a 20 20 20 20 20 20 75 38 20 2a 7a 44 65 73 74  .      u8 *zDest
2aa0: 44 61 74 61 20 3d 20 73 71 6c 69 74 65 33 50 61  Data = sqlite3Pa
2ab0: 67 65 72 47 65 74 44 61 74 61 28 70 44 65 73 74  gerGetData(pDest
2ac0: 50 67 29 3b 0a 20 20 20 20 20 20 75 38 20 2a 7a  Pg);.      u8 *z
2ad0: 4f 75 74 20 3d 20 26 7a 44 65 73 74 44 61 74 61  Out = &zDestData
2ae0: 5b 69 4f 66 66 25 6e 44 65 73 74 50 67 73 7a 5d  [iOff%nDestPgsz]
2af0: 3b 0a 0a 20 20 20 20 20 20 2f 2a 20 43 6f 70 79  ;..      /* Copy
2b00: 20 74 68 65 20 64 61 74 61 20 66 72 6f 6d 20 74   the data from t
2b10: 68 65 20 73 6f 75 72 63 65 20 70 61 67 65 20 69  he source page i
2b20: 6e 74 6f 20 74 68 65 20 64 65 73 74 69 6e 61 74  nto the destinat
2b30: 69 6f 6e 20 70 61 67 65 2e 0a 20 20 20 20 20 20  ion page..      
2b40: 2a 2a 20 54 68 65 6e 20 63 6c 65 61 72 20 74 68  ** Then clear th
2b50: 65 20 42 74 72 65 65 20 6c 61 79 65 72 20 4d 65  e Btree layer Me
2b60: 6d 50 61 67 65 2e 69 73 49 6e 69 74 20 66 6c 61  mPage.isInit fla
2b70: 67 2e 20 42 6f 74 68 20 74 68 69 73 20 6d 6f 64  g. Both this mod
2b80: 75 6c 65 0a 20 20 20 20 20 20 2a 2a 20 61 6e 64  ule.      ** and
2b90: 20 74 68 65 20 70 61 67 65 72 20 63 6f 64 65 20   the pager code 
2ba0: 75 73 65 20 74 68 69 73 20 74 72 69 63 6b 20 28  use this trick (
2bb0: 63 6c 65 61 72 69 6e 67 20 74 68 65 20 66 69 72  clearing the fir
2bc0: 73 74 20 62 79 74 65 0a 20 20 20 20 20 20 2a 2a  st byte.      **
2bd0: 20 6f 66 20 74 68 65 20 70 61 67 65 20 27 65 78   of the page 'ex
2be0: 74 72 61 27 20 73 70 61 63 65 20 74 6f 20 69 6e  tra' space to in
2bf0: 76 61 6c 69 64 61 74 65 20 74 68 65 20 42 74 72  validate the Btr
2c00: 65 65 20 6c 61 79 65 72 73 0a 20 20 20 20 20 20  ee layers.      
2c10: 2a 2a 20 63 61 63 68 65 64 20 70 61 72 73 65 20  ** cached parse 
2c20: 6f 66 20 74 68 65 20 70 61 67 65 29 2e 20 4d 65  of the page). Me
2c30: 6d 50 61 67 65 2e 69 73 49 6e 69 74 20 69 73 20  mPage.isInit is 
2c40: 6d 61 72 6b 65 64 20 0a 20 20 20 20 20 20 2a 2a  marked .      **
2c50: 20 22 4d 55 53 54 20 42 45 20 46 49 52 53 54 22   "MUST BE FIRST"
2c60: 20 66 6f 72 20 74 68 69 73 20 70 75 72 70 6f 73   for this purpos
2c70: 65 2e 0a 20 20 20 20 20 20 2a 2f 0a 20 20 20 20  e..      */.    
2c80: 20 20 6d 65 6d 63 70 79 28 7a 4f 75 74 2c 20 7a    memcpy(zOut, z
2c90: 49 6e 2c 20 6e 43 6f 70 79 29 3b 0a 20 20 20 20  In, nCopy);.    
2ca0: 20 20 28 28 75 38 20 2a 29 73 71 6c 69 74 65 33    ((u8 *)sqlite3
2cb0: 50 61 67 65 72 47 65 74 45 78 74 72 61 28 70 44  PagerGetExtra(pD
2cc0: 65 73 74 50 67 29 29 5b 30 5d 20 3d 20 30 3b 0a  estPg))[0] = 0;.
2cd0: 20 20 20 20 20 20 69 66 28 20 69 4f 66 66 3d 3d        if( iOff==
2ce0: 30 20 26 26 20 62 55 70 64 61 74 65 3d 3d 30 20  0 && bUpdate==0 
2cf0: 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74  ){.        sqlit
2d00: 65 33 50 75 74 34 62 79 74 65 28 26 7a 4f 75 74  e3Put4byte(&zOut
2d10: 5b 32 38 5d 2c 20 73 71 6c 69 74 65 33 42 74 72  [28], sqlite3Btr
2d20: 65 65 4c 61 73 74 50 61 67 65 28 70 2d 3e 70 53  eeLastPage(p->pS
2d30: 72 63 29 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20  rc));.      }.  
2d40: 20 20 7d 0a 20 20 20 20 73 71 6c 69 74 65 33 50    }.    sqlite3P
2d50: 61 67 65 72 55 6e 72 65 66 28 70 44 65 73 74 50  agerUnref(pDestP
2d60: 67 29 3b 0a 20 20 7d 0a 0a 20 20 72 65 74 75 72  g);.  }..  retur
2d70: 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 49  n rc;.}../*.** I
2d80: 66 20 70 46 69 6c 65 20 69 73 20 63 75 72 72 65  f pFile is curre
2d90: 6e 74 6c 79 20 6c 61 72 67 65 72 20 74 68 61 6e  ntly larger than
2da0: 20 69 53 69 7a 65 20 62 79 74 65 73 2c 20 74 68   iSize bytes, th
2db0: 65 6e 20 74 72 75 6e 63 61 74 65 20 69 74 20 74  en truncate it t
2dc0: 6f 0a 2a 2a 20 65 78 61 63 74 6c 79 20 69 53 69  o.** exactly iSi
2dd0: 7a 65 20 62 79 74 65 73 2e 20 49 66 20 70 46 69  ze bytes. If pFi
2de0: 6c 65 20 69 73 20 6e 6f 74 20 6c 61 72 67 65 72  le is not larger
2df0: 20 74 68 61 6e 20 69 53 69 7a 65 20 62 79 74 65   than iSize byte
2e00: 73 2c 20 74 68 65 6e 0a 2a 2a 20 74 68 69 73 20  s, then.** this 
2e10: 66 75 6e 63 74 69 6f 6e 20 69 73 20 61 20 6e 6f  function is a no
2e20: 2d 6f 70 2e 0a 2a 2a 0a 2a 2a 20 52 65 74 75 72  -op..**.** Retur
2e30: 6e 20 53 51 4c 49 54 45 5f 4f 4b 20 69 66 20 65  n SQLITE_OK if e
2e40: 76 65 72 79 74 68 69 6e 67 20 69 73 20 73 75 63  verything is suc
2e50: 63 65 73 73 66 75 6c 2c 20 6f 72 20 61 6e 20 53  cessful, or an S
2e60: 51 4c 69 74 65 20 65 72 72 6f 72 20 0a 2a 2a 20  QLite error .** 
2e70: 63 6f 64 65 20 69 66 20 61 6e 20 65 72 72 6f 72  code if an error
2e80: 20 6f 63 63 75 72 73 2e 0a 2a 2f 0a 73 74 61 74   occurs..*/.stat
2e90: 69 63 20 69 6e 74 20 62 61 63 6b 75 70 54 72 75  ic int backupTru
2ea0: 6e 63 61 74 65 46 69 6c 65 28 73 71 6c 69 74 65  ncateFile(sqlite
2eb0: 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c 20 69  3_file *pFile, i
2ec0: 36 34 20 69 53 69 7a 65 29 7b 0a 20 20 69 36 34  64 iSize){.  i64
2ed0: 20 69 43 75 72 72 65 6e 74 3b 0a 20 20 69 6e 74   iCurrent;.  int
2ee0: 20 72 63 20 3d 20 73 71 6c 69 74 65 33 4f 73 46   rc = sqlite3OsF
2ef0: 69 6c 65 53 69 7a 65 28 70 46 69 6c 65 2c 20 26  ileSize(pFile, &
2f00: 69 43 75 72 72 65 6e 74 29 3b 0a 20 20 69 66 28  iCurrent);.  if(
2f10: 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 26   rc==SQLITE_OK &
2f20: 26 20 69 43 75 72 72 65 6e 74 3e 69 53 69 7a 65  & iCurrent>iSize
2f30: 20 29 7b 0a 20 20 20 20 72 63 20 3d 20 73 71 6c   ){.    rc = sql
2f40: 69 74 65 33 4f 73 54 72 75 6e 63 61 74 65 28 70  ite3OsTruncate(p
2f50: 46 69 6c 65 2c 20 69 53 69 7a 65 29 3b 0a 20 20  File, iSize);.  
2f60: 7d 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d  }.  return rc;.}
2f70: 0a 0a 2f 2a 0a 2a 2a 20 52 65 67 69 73 74 65 72  ../*.** Register
2f80: 20 74 68 69 73 20 62 61 63 6b 75 70 20 6f 62 6a   this backup obj
2f90: 65 63 74 20 77 69 74 68 20 74 68 65 20 61 73 73  ect with the ass
2fa0: 6f 63 69 61 74 65 64 20 73 6f 75 72 63 65 20 70  ociated source p
2fb0: 61 67 65 72 20 66 6f 72 0a 2a 2a 20 63 61 6c 6c  ager for.** call
2fc0: 62 61 63 6b 73 20 77 68 65 6e 20 70 61 67 65 73  backs when pages
2fd0: 20 61 72 65 20 63 68 61 6e 67 65 64 20 6f 72 20   are changed or 
2fe0: 74 68 65 20 63 61 63 68 65 20 69 6e 76 61 6c 69  the cache invali
2ff0: 64 61 74 65 64 2e 0a 2a 2f 0a 73 74 61 74 69 63  dated..*/.static
3000: 20 76 6f 69 64 20 61 74 74 61 63 68 42 61 63 6b   void attachBack
3010: 75 70 4f 62 6a 65 63 74 28 73 71 6c 69 74 65 33  upObject(sqlite3
3020: 5f 62 61 63 6b 75 70 20 2a 70 29 7b 0a 20 20 73  _backup *p){.  s
3030: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 2a  qlite3_backup **
3040: 70 70 3b 0a 20 20 61 73 73 65 72 74 28 20 73 71  pp;.  assert( sq
3050: 6c 69 74 65 33 42 74 72 65 65 48 6f 6c 64 73 4d  lite3BtreeHoldsM
3060: 75 74 65 78 28 70 2d 3e 70 53 72 63 29 20 29 3b  utex(p->pSrc) );
3070: 0a 20 20 70 70 20 3d 20 73 71 6c 69 74 65 33 50  .  pp = sqlite3P
3080: 61 67 65 72 42 61 63 6b 75 70 50 74 72 28 73 71  agerBackupPtr(sq
3090: 6c 69 74 65 33 42 74 72 65 65 50 61 67 65 72 28  lite3BtreePager(
30a0: 70 2d 3e 70 53 72 63 29 29 3b 0a 20 20 70 2d 3e  p->pSrc));.  p->
30b0: 70 4e 65 78 74 20 3d 20 2a 70 70 3b 0a 20 20 2a  pNext = *pp;.  *
30c0: 70 70 20 3d 20 70 3b 0a 20 20 70 2d 3e 69 73 41  pp = p;.  p->isA
30d0: 74 74 61 63 68 65 64 20 3d 20 31 3b 0a 7d 0a 0a  ttached = 1;.}..
30e0: 2f 2a 0a 2a 2a 20 43 6f 70 79 20 6e 50 61 67 65  /*.** Copy nPage
30f0: 20 70 61 67 65 73 20 66 72 6f 6d 20 74 68 65 20   pages from the 
3100: 73 6f 75 72 63 65 20 62 2d 74 72 65 65 20 74 6f  source b-tree to
3110: 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e   the destination
3120: 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33  ..*/.int sqlite3
3130: 5f 62 61 63 6b 75 70 5f 73 74 65 70 28 73 71 6c  _backup_step(sql
3140: 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 2c 20  ite3_backup *p, 
3150: 69 6e 74 20 6e 50 61 67 65 29 7b 0a 20 20 69 6e  int nPage){.  in
3160: 74 20 72 63 3b 0a 20 20 69 6e 74 20 64 65 73 74  t rc;.  int dest
3170: 4d 6f 64 65 3b 20 20 20 20 20 20 20 2f 2a 20 44  Mode;       /* D
3180: 65 73 74 69 6e 61 74 69 6f 6e 20 6a 6f 75 72 6e  estination journ
3190: 61 6c 20 6d 6f 64 65 20 2a 2f 0a 20 20 69 6e 74  al mode */.  int
31a0: 20 70 67 73 7a 53 72 63 20 3d 20 30 3b 20 20 20   pgszSrc = 0;   
31b0: 20 2f 2a 20 53 6f 75 72 63 65 20 70 61 67 65 20   /* Source page 
31c0: 73 69 7a 65 20 2a 2f 0a 20 20 69 6e 74 20 70 67  size */.  int pg
31d0: 73 7a 44 65 73 74 20 3d 20 30 3b 20 20 20 2f 2a  szDest = 0;   /*
31e0: 20 44 65 73 74 69 6e 61 74 69 6f 6e 20 70 61 67   Destination pag
31f0: 65 20 73 69 7a 65 20 2a 2f 0a 0a 23 69 66 64 65  e size */..#ifde
3200: 66 20 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f  f SQLITE_ENABLE_
3210: 41 50 49 5f 41 52 4d 4f 52 0a 20 20 69 66 28 20  API_ARMOR.  if( 
3220: 70 3d 3d 30 20 29 20 72 65 74 75 72 6e 20 53 51  p==0 ) return SQ
3230: 4c 49 54 45 5f 4d 49 53 55 53 45 5f 42 4b 50 54  LITE_MISUSE_BKPT
3240: 3b 0a 23 65 6e 64 69 66 0a 20 20 73 71 6c 69 74  ;.#endif.  sqlit
3250: 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28 70  e3_mutex_enter(p
3260: 2d 3e 70 53 72 63 44 62 2d 3e 6d 75 74 65 78 29  ->pSrcDb->mutex)
3270: 3b 0a 20 20 73 71 6c 69 74 65 33 42 74 72 65 65  ;.  sqlite3Btree
3280: 45 6e 74 65 72 28 70 2d 3e 70 53 72 63 29 3b 0a  Enter(p->pSrc);.
3290: 20 20 69 66 28 20 70 2d 3e 70 44 65 73 74 44 62    if( p->pDestDb
32a0: 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f   ){.    sqlite3_
32b0: 6d 75 74 65 78 5f 65 6e 74 65 72 28 70 2d 3e 70  mutex_enter(p->p
32c0: 44 65 73 74 44 62 2d 3e 6d 75 74 65 78 29 3b 0a  DestDb->mutex);.
32d0: 20 20 7d 0a 0a 20 20 72 63 20 3d 20 70 2d 3e 72    }..  rc = p->r
32e0: 63 3b 0a 20 20 69 66 28 20 21 69 73 46 61 74 61  c;.  if( !isFata
32f0: 6c 45 72 72 6f 72 28 72 63 29 20 29 7b 0a 20 20  lError(rc) ){.  
3300: 20 20 50 61 67 65 72 20 2a 20 63 6f 6e 73 74 20    Pager * const 
3310: 70 53 72 63 50 61 67 65 72 20 3d 20 73 71 6c 69  pSrcPager = sqli
3320: 74 65 33 42 74 72 65 65 50 61 67 65 72 28 70 2d  te3BtreePager(p-
3330: 3e 70 53 72 63 29 3b 20 20 20 20 20 2f 2a 20 53  >pSrc);     /* S
3340: 6f 75 72 63 65 20 70 61 67 65 72 20 2a 2f 0a 20  ource pager */. 
3350: 20 20 20 50 61 67 65 72 20 2a 20 63 6f 6e 73 74     Pager * const
3360: 20 70 44 65 73 74 50 61 67 65 72 20 3d 20 73 71   pDestPager = sq
3370: 6c 69 74 65 33 42 74 72 65 65 50 61 67 65 72 28  lite3BtreePager(
3380: 70 2d 3e 70 44 65 73 74 29 3b 20 20 20 2f 2a 20  p->pDest);   /* 
3390: 44 65 73 74 20 70 61 67 65 72 20 2a 2f 0a 20 20  Dest pager */.  
33a0: 20 20 69 6e 74 20 69 69 3b 20 20 20 20 20 20 20    int ii;       
33b0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
33c0: 20 20 20 20 20 2f 2a 20 49 74 65 72 61 74 6f 72       /* Iterator
33d0: 20 76 61 72 69 61 62 6c 65 20 2a 2f 0a 20 20 20   variable */.   
33e0: 20 69 6e 74 20 6e 53 72 63 50 61 67 65 20 3d 20   int nSrcPage = 
33f0: 2d 31 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  -1;             
3400: 20 20 20 20 2f 2a 20 53 69 7a 65 20 6f 66 20 73      /* Size of s
3410: 6f 75 72 63 65 20 64 62 20 69 6e 20 70 61 67 65  ource db in page
3420: 73 20 2a 2f 0a 20 20 20 20 69 6e 74 20 62 43 6c  s */.    int bCl
3430: 6f 73 65 54 72 61 6e 73 20 3d 20 30 3b 20 20 20  oseTrans = 0;   
3440: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54              /* T
3450: 72 75 65 20 69 66 20 73 72 63 20 64 62 20 72 65  rue if src db re
3460: 71 75 69 72 65 73 20 75 6e 6c 6f 63 6b 69 6e 67  quires unlocking
3470: 20 2a 2f 0a 0a 20 20 20 20 2f 2a 20 49 66 20 74   */..    /* If t
3480: 68 65 20 73 6f 75 72 63 65 20 70 61 67 65 72 20  he source pager 
3490: 69 73 20 63 75 72 72 65 6e 74 6c 79 20 69 6e 20  is currently in 
34a0: 61 20 77 72 69 74 65 2d 74 72 61 6e 73 61 63 74  a write-transact
34b0: 69 6f 6e 2c 20 72 65 74 75 72 6e 0a 20 20 20 20  ion, return.    
34c0: 2a 2a 20 53 51 4c 49 54 45 5f 42 55 53 59 20 69  ** SQLITE_BUSY i
34d0: 6d 6d 65 64 69 61 74 65 6c 79 2e 0a 20 20 20 20  mmediately..    
34e0: 2a 2f 0a 20 20 20 20 69 66 28 20 70 2d 3e 70 44  */.    if( p->pD
34f0: 65 73 74 44 62 20 26 26 20 70 2d 3e 70 53 72 63  estDb && p->pSrc
3500: 2d 3e 70 42 74 2d 3e 69 6e 54 72 61 6e 73 61 63  ->pBt->inTransac
3510: 74 69 6f 6e 3d 3d 54 52 41 4e 53 5f 57 52 49 54  tion==TRANS_WRIT
3520: 45 20 29 7b 0a 20 20 20 20 20 20 72 63 20 3d 20  E ){.      rc = 
3530: 53 51 4c 49 54 45 5f 42 55 53 59 3b 0a 20 20 20  SQLITE_BUSY;.   
3540: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 72 63   }else{.      rc
3550: 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20   = SQLITE_OK;.  
3560: 20 20 7d 0a 0a 20 20 20 20 2f 2a 20 4c 6f 63 6b    }..    /* Lock
3570: 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e   the destination
3580: 20 64 61 74 61 62 61 73 65 2c 20 69 66 20 69 74   database, if it
3590: 20 69 73 20 6e 6f 74 20 6c 6f 63 6b 65 64 20 61   is not locked a
35a0: 6c 72 65 61 64 79 2e 20 2a 2f 0a 20 20 20 20 69  lready. */.    i
35b0: 66 28 20 53 51 4c 49 54 45 5f 4f 4b 3d 3d 72 63  f( SQLITE_OK==rc
35c0: 20 26 26 20 70 2d 3e 62 44 65 73 74 4c 6f 63 6b   && p->bDestLock
35d0: 65 64 3d 3d 30 0a 20 20 20 20 20 26 26 20 53 51  ed==0.     && SQ
35e0: 4c 49 54 45 5f 4f 4b 3d 3d 28 72 63 20 3d 20 73  LITE_OK==(rc = s
35f0: 71 6c 69 74 65 33 42 74 72 65 65 42 65 67 69 6e  qlite3BtreeBegin
3600: 54 72 61 6e 73 28 70 2d 3e 70 44 65 73 74 2c 20  Trans(p->pDest, 
3610: 32 29 29 20 0a 20 20 20 20 29 7b 0a 20 20 20 20  2)) .    ){.    
3620: 20 20 70 2d 3e 62 44 65 73 74 4c 6f 63 6b 65 64    p->bDestLocked
3630: 20 3d 20 31 3b 0a 20 20 20 20 20 20 73 71 6c 69   = 1;.      sqli
3640: 74 65 33 42 74 72 65 65 47 65 74 4d 65 74 61 28  te3BtreeGetMeta(
3650: 70 2d 3e 70 44 65 73 74 2c 20 42 54 52 45 45 5f  p->pDest, BTREE_
3660: 53 43 48 45 4d 41 5f 56 45 52 53 49 4f 4e 2c 20  SCHEMA_VERSION, 
3670: 26 70 2d 3e 69 44 65 73 74 53 63 68 65 6d 61 29  &p->iDestSchema)
3680: 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 20  ;.    }..    /* 
3690: 49 66 20 74 68 65 72 65 20 69 73 20 6e 6f 20 6f  If there is no o
36a0: 70 65 6e 20 72 65 61 64 2d 74 72 61 6e 73 61 63  pen read-transac
36b0: 74 69 6f 6e 20 6f 6e 20 74 68 65 20 73 6f 75 72  tion on the sour
36c0: 63 65 20 64 61 74 61 62 61 73 65 2c 20 6f 70 65  ce database, ope
36d0: 6e 0a 20 20 20 20 2a 2a 20 6f 6e 65 20 6e 6f 77  n.    ** one now
36e0: 2e 20 49 66 20 61 20 74 72 61 6e 73 61 63 74 69  . If a transacti
36f0: 6f 6e 20 69 73 20 6f 70 65 6e 65 64 20 68 65 72  on is opened her
3700: 65 2c 20 74 68 65 6e 20 69 74 20 77 69 6c 6c 20  e, then it will 
3710: 62 65 20 63 6c 6f 73 65 64 0a 20 20 20 20 2a 2a  be closed.    **
3720: 20 62 65 66 6f 72 65 20 74 68 69 73 20 66 75 6e   before this fun
3730: 63 74 69 6f 6e 20 65 78 69 74 73 2e 0a 20 20 20  ction exits..   
3740: 20 2a 2f 0a 20 20 20 20 69 66 28 20 72 63 3d 3d   */.    if( rc==
3750: 53 51 4c 49 54 45 5f 4f 4b 20 26 26 20 30 3d 3d  SQLITE_OK && 0==
3760: 73 71 6c 69 74 65 33 42 74 72 65 65 49 73 49 6e  sqlite3BtreeIsIn
3770: 52 65 61 64 54 72 61 6e 73 28 70 2d 3e 70 53 72  ReadTrans(p->pSr
3780: 63 29 20 29 7b 0a 20 20 20 20 20 20 72 63 20 3d  c) ){.      rc =
3790: 20 73 71 6c 69 74 65 33 42 74 72 65 65 42 65 67   sqlite3BtreeBeg
37a0: 69 6e 54 72 61 6e 73 28 70 2d 3e 70 53 72 63 2c  inTrans(p->pSrc,
37b0: 20 30 29 3b 0a 20 20 20 20 20 20 62 43 6c 6f 73   0);.      bClos
37c0: 65 54 72 61 6e 73 20 3d 20 31 3b 0a 20 20 20 20  eTrans = 1;.    
37d0: 7d 0a 0a 20 20 20 20 2f 2a 20 44 6f 20 6e 6f 74  }..    /* Do not
37e0: 20 61 6c 6c 6f 77 20 62 61 63 6b 75 70 20 69 66   allow backup if
37f0: 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e   the destination
3800: 20 64 61 74 61 62 61 73 65 20 69 73 20 69 6e 20   database is in 
3810: 57 41 4c 20 6d 6f 64 65 0a 20 20 20 20 2a 2a 20  WAL mode.    ** 
3820: 61 6e 64 20 74 68 65 20 70 61 67 65 20 73 69 7a  and the page siz
3830: 65 73 20 61 72 65 20 64 69 66 66 65 72 65 6e 74  es are different
3840: 20 62 65 74 77 65 65 6e 20 73 6f 75 72 63 65 20   between source 
3850: 61 6e 64 20 64 65 73 74 69 6e 61 74 69 6f 6e 20  and destination 
3860: 2a 2f 0a 20 20 20 20 70 67 73 7a 53 72 63 20 3d  */.    pgszSrc =
3870: 20 73 71 6c 69 74 65 33 42 74 72 65 65 47 65 74   sqlite3BtreeGet
3880: 50 61 67 65 53 69 7a 65 28 70 2d 3e 70 53 72 63  PageSize(p->pSrc
3890: 29 3b 0a 20 20 20 20 70 67 73 7a 44 65 73 74 20  );.    pgszDest 
38a0: 3d 20 73 71 6c 69 74 65 33 42 74 72 65 65 47 65  = sqlite3BtreeGe
38b0: 74 50 61 67 65 53 69 7a 65 28 70 2d 3e 70 44 65  tPageSize(p->pDe
38c0: 73 74 29 3b 0a 20 20 20 20 64 65 73 74 4d 6f 64  st);.    destMod
38d0: 65 20 3d 20 73 71 6c 69 74 65 33 50 61 67 65 72  e = sqlite3Pager
38e0: 47 65 74 4a 6f 75 72 6e 61 6c 4d 6f 64 65 28 73  GetJournalMode(s
38f0: 71 6c 69 74 65 33 42 74 72 65 65 50 61 67 65 72  qlite3BtreePager
3900: 28 70 2d 3e 70 44 65 73 74 29 29 3b 0a 20 20 20  (p->pDest));.   
3910: 20 69 66 28 20 53 51 4c 49 54 45 5f 4f 4b 3d 3d   if( SQLITE_OK==
3920: 72 63 20 26 26 20 64 65 73 74 4d 6f 64 65 3d 3d  rc && destMode==
3930: 50 41 47 45 52 5f 4a 4f 55 52 4e 41 4c 4d 4f 44  PAGER_JOURNALMOD
3940: 45 5f 57 41 4c 20 26 26 20 70 67 73 7a 53 72 63  E_WAL && pgszSrc
3950: 21 3d 70 67 73 7a 44 65 73 74 20 29 7b 0a 20 20  !=pgszDest ){.  
3960: 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f      rc = SQLITE_
3970: 52 45 41 44 4f 4e 4c 59 3b 0a 20 20 20 20 7d 0a  READONLY;.    }.
3980: 20 20 0a 20 20 20 20 2f 2a 20 4e 6f 77 20 74 68    .    /* Now th
3990: 61 74 20 74 68 65 72 65 20 69 73 20 61 20 72 65  at there is a re
39a0: 61 64 2d 6c 6f 63 6b 20 6f 6e 20 74 68 65 20 73  ad-lock on the s
39b0: 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 2c 20  ource database, 
39c0: 71 75 65 72 79 20 74 68 65 0a 20 20 20 20 2a 2a  query the.    **
39d0: 20 73 6f 75 72 63 65 20 70 61 67 65 72 20 66 6f   source pager fo
39e0: 72 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20  r the number of 
39f0: 70 61 67 65 73 20 69 6e 20 74 68 65 20 64 61 74  pages in the dat
3a00: 61 62 61 73 65 2e 0a 20 20 20 20 2a 2f 0a 20 20  abase..    */.  
3a10: 20 20 6e 53 72 63 50 61 67 65 20 3d 20 28 69 6e    nSrcPage = (in
3a20: 74 29 73 71 6c 69 74 65 33 42 74 72 65 65 4c 61  t)sqlite3BtreeLa
3a30: 73 74 50 61 67 65 28 70 2d 3e 70 53 72 63 29 3b  stPage(p->pSrc);
3a40: 0a 20 20 20 20 61 73 73 65 72 74 28 20 6e 53 72  .    assert( nSr
3a50: 63 50 61 67 65 3e 3d 30 20 29 3b 0a 20 20 20 20  cPage>=0 );.    
3a60: 66 6f 72 28 69 69 3d 30 3b 20 28 6e 50 61 67 65  for(ii=0; (nPage
3a70: 3c 30 20 7c 7c 20 69 69 3c 6e 50 61 67 65 29 20  <0 || ii<nPage) 
3a80: 26 26 20 70 2d 3e 69 4e 65 78 74 3c 3d 28 50 67  && p->iNext<=(Pg
3a90: 6e 6f 29 6e 53 72 63 50 61 67 65 20 26 26 20 21  no)nSrcPage && !
3aa0: 72 63 3b 20 69 69 2b 2b 29 7b 0a 20 20 20 20 20  rc; ii++){.     
3ab0: 20 63 6f 6e 73 74 20 50 67 6e 6f 20 69 53 72 63   const Pgno iSrc
3ac0: 50 67 20 3d 20 70 2d 3e 69 4e 65 78 74 3b 20 20  Pg = p->iNext;  
3ad0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
3ae0: 2a 20 53 6f 75 72 63 65 20 70 61 67 65 20 6e 75  * Source page nu
3af0: 6d 62 65 72 20 2a 2f 0a 20 20 20 20 20 20 69 66  mber */.      if
3b00: 28 20 69 53 72 63 50 67 21 3d 50 45 4e 44 49 4e  ( iSrcPg!=PENDIN
3b10: 47 5f 42 59 54 45 5f 50 41 47 45 28 70 2d 3e 70  G_BYTE_PAGE(p->p
3b20: 53 72 63 2d 3e 70 42 74 29 20 29 7b 0a 20 20 20  Src->pBt) ){.   
3b30: 20 20 20 20 20 44 62 50 61 67 65 20 2a 70 53 72       DbPage *pSr
3b40: 63 50 67 3b 20 20 20 20 20 20 20 20 20 20 20 20  cPg;            
3b50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3b60: 20 2f 2a 20 53 6f 75 72 63 65 20 70 61 67 65 20   /* Source page 
3b70: 6f 62 6a 65 63 74 20 2a 2f 0a 20 20 20 20 20 20  object */.      
3b80: 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 50 61    rc = sqlite3Pa
3b90: 67 65 72 47 65 74 28 70 53 72 63 50 61 67 65 72  gerGet(pSrcPager
3ba0: 2c 20 69 53 72 63 50 67 2c 20 26 70 53 72 63 50  , iSrcPg, &pSrcP
3bb0: 67 2c 50 41 47 45 52 5f 47 45 54 5f 52 45 41 44  g,PAGER_GET_READ
3bc0: 4f 4e 4c 59 29 3b 0a 20 20 20 20 20 20 20 20 69  ONLY);.        i
3bd0: 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b  f( rc==SQLITE_OK
3be0: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 72 63   ){.          rc
3bf0: 20 3d 20 62 61 63 6b 75 70 4f 6e 65 50 61 67 65   = backupOnePage
3c00: 28 70 2c 20 69 53 72 63 50 67 2c 20 73 71 6c 69  (p, iSrcPg, sqli
3c10: 74 65 33 50 61 67 65 72 47 65 74 44 61 74 61 28  te3PagerGetData(
3c20: 70 53 72 63 50 67 29 2c 20 30 29 3b 0a 20 20 20  pSrcPg), 0);.   
3c30: 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 50 61         sqlite3Pa
3c40: 67 65 72 55 6e 72 65 66 28 70 53 72 63 50 67 29  gerUnref(pSrcPg)
3c50: 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  ;.        }.    
3c60: 20 20 7d 0a 20 20 20 20 20 20 70 2d 3e 69 4e 65    }.      p->iNe
3c70: 78 74 2b 2b 3b 0a 20 20 20 20 7d 0a 20 20 20 20  xt++;.    }.    
3c80: 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f  if( rc==SQLITE_O
3c90: 4b 20 29 7b 0a 20 20 20 20 20 20 70 2d 3e 6e 50  K ){.      p->nP
3ca0: 61 67 65 63 6f 75 6e 74 20 3d 20 6e 53 72 63 50  agecount = nSrcP
3cb0: 61 67 65 3b 0a 20 20 20 20 20 20 70 2d 3e 6e 52  age;.      p->nR
3cc0: 65 6d 61 69 6e 69 6e 67 20 3d 20 6e 53 72 63 50  emaining = nSrcP
3cd0: 61 67 65 2b 31 2d 70 2d 3e 69 4e 65 78 74 3b 0a  age+1-p->iNext;.
3ce0: 20 20 20 20 20 20 69 66 28 20 70 2d 3e 69 4e 65        if( p->iNe
3cf0: 78 74 3e 28 50 67 6e 6f 29 6e 53 72 63 50 61 67  xt>(Pgno)nSrcPag
3d00: 65 20 29 7b 0a 20 20 20 20 20 20 20 20 72 63 20  e ){.        rc 
3d10: 3d 20 53 51 4c 49 54 45 5f 44 4f 4e 45 3b 0a 20  = SQLITE_DONE;. 
3d20: 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 21       }else if( !
3d30: 70 2d 3e 69 73 41 74 74 61 63 68 65 64 20 29 7b  p->isAttached ){
3d40: 0a 20 20 20 20 20 20 20 20 61 74 74 61 63 68 42  .        attachB
3d50: 61 63 6b 75 70 4f 62 6a 65 63 74 28 70 29 3b 0a  ackupObject(p);.
3d60: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20        }.    }.  
3d70: 0a 20 20 20 20 2f 2a 20 55 70 64 61 74 65 20 74  .    /* Update t
3d80: 68 65 20 73 63 68 65 6d 61 20 76 65 72 73 69 6f  he schema versio
3d90: 6e 20 66 69 65 6c 64 20 69 6e 20 74 68 65 20 64  n field in the d
3da0: 65 73 74 69 6e 61 74 69 6f 6e 20 64 61 74 61 62  estination datab
3db0: 61 73 65 2e 20 54 68 69 73 0a 20 20 20 20 2a 2a  ase. This.    **
3dc0: 20 69 73 20 74 6f 20 6d 61 6b 65 20 73 75 72 65   is to make sure
3dd0: 20 74 68 61 74 20 74 68 65 20 73 63 68 65 6d 61   that the schema
3de0: 2d 76 65 72 73 69 6f 6e 20 72 65 61 6c 6c 79 20  -version really 
3df0: 64 6f 65 73 20 63 68 61 6e 67 65 20 69 6e 0a 20  does change in. 
3e00: 20 20 20 2a 2a 20 74 68 65 20 63 61 73 65 20 77     ** the case w
3e10: 68 65 72 65 20 74 68 65 20 73 6f 75 72 63 65 20  here the source 
3e20: 61 6e 64 20 64 65 73 74 69 6e 61 74 69 6f 6e 20  and destination 
3e30: 64 61 74 61 62 61 73 65 73 20 68 61 76 65 20 74  databases have t
3e40: 68 65 0a 20 20 20 20 2a 2a 20 73 61 6d 65 20 73  he.    ** same s
3e50: 63 68 65 6d 61 20 76 65 72 73 69 6f 6e 2e 0a 20  chema version.. 
3e60: 20 20 20 2a 2f 0a 20 20 20 20 69 66 28 20 72 63     */.    if( rc
3e70: 3d 3d 53 51 4c 49 54 45 5f 44 4f 4e 45 20 29 7b  ==SQLITE_DONE ){
3e80: 0a 20 20 20 20 20 20 69 66 28 20 6e 53 72 63 50  .      if( nSrcP
3e90: 61 67 65 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20  age==0 ){.      
3ea0: 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 42 74    rc = sqlite3Bt
3eb0: 72 65 65 4e 65 77 44 62 28 70 2d 3e 70 44 65 73  reeNewDb(p->pDes
3ec0: 74 29 3b 0a 20 20 20 20 20 20 20 20 6e 53 72 63  t);.        nSrc
3ed0: 50 61 67 65 20 3d 20 31 3b 0a 20 20 20 20 20 20  Page = 1;.      
3ee0: 7d 0a 20 20 20 20 20 20 69 66 28 20 72 63 3d 3d  }.      if( rc==
3ef0: 53 51 4c 49 54 45 5f 4f 4b 20 7c 7c 20 72 63 3d  SQLITE_OK || rc=
3f00: 3d 53 51 4c 49 54 45 5f 44 4f 4e 45 20 29 7b 0a  =SQLITE_DONE ){.
3f10: 20 20 20 20 20 20 20 20 72 63 20 3d 20 73 71 6c          rc = sql
3f20: 69 74 65 33 42 74 72 65 65 55 70 64 61 74 65 4d  ite3BtreeUpdateM
3f30: 65 74 61 28 70 2d 3e 70 44 65 73 74 2c 31 2c 70  eta(p->pDest,1,p
3f40: 2d 3e 69 44 65 73 74 53 63 68 65 6d 61 2b 31 29  ->iDestSchema+1)
3f50: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20  ;.      }.      
3f60: 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f  if( rc==SQLITE_O
3f70: 4b 20 29 7b 0a 20 20 20 20 20 20 20 20 69 66 28  K ){.        if(
3f80: 20 70 2d 3e 70 44 65 73 74 44 62 20 29 7b 0a 20   p->pDestDb ){. 
3f90: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
3fa0: 52 65 73 65 74 41 6c 6c 53 63 68 65 6d 61 73 4f  ResetAllSchemasO
3fb0: 66 43 6f 6e 6e 65 63 74 69 6f 6e 28 70 2d 3e 70  fConnection(p->p
3fc0: 44 65 73 74 44 62 29 3b 0a 20 20 20 20 20 20 20  DestDb);.       
3fd0: 20 7d 0a 20 20 20 20 20 20 20 20 69 66 28 20 64   }.        if( d
3fe0: 65 73 74 4d 6f 64 65 3d 3d 50 41 47 45 52 5f 4a  estMode==PAGER_J
3ff0: 4f 55 52 4e 41 4c 4d 4f 44 45 5f 57 41 4c 20 29  OURNALMODE_WAL )
4000: 7b 0a 20 20 20 20 20 20 20 20 20 20 72 63 20 3d  {.          rc =
4010: 20 73 71 6c 69 74 65 33 42 74 72 65 65 53 65 74   sqlite3BtreeSet
4020: 56 65 72 73 69 6f 6e 28 70 2d 3e 70 44 65 73 74  Version(p->pDest
4030: 2c 20 32 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a  , 2);.        }.
4040: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66        }.      if
4050: 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20  ( rc==SQLITE_OK 
4060: 29 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6e  ){.        int n
4070: 44 65 73 74 54 72 75 6e 63 61 74 65 3b 0a 20 20  DestTruncate;.  
4080: 20 20 20 20 20 20 2f 2a 20 53 65 74 20 6e 44 65        /* Set nDe
4090: 73 74 54 72 75 6e 63 61 74 65 20 74 6f 20 74 68  stTruncate to th
40a0: 65 20 66 69 6e 61 6c 20 6e 75 6d 62 65 72 20 6f  e final number o
40b0: 66 20 70 61 67 65 73 20 69 6e 20 74 68 65 20 64  f pages in the d
40c0: 65 73 74 69 6e 61 74 69 6f 6e 0a 20 20 20 20 20  estination.     
40d0: 20 20 20 2a 2a 20 64 61 74 61 62 61 73 65 2e 20     ** database. 
40e0: 54 68 65 20 63 6f 6d 70 6c 69 63 61 74 69 6f 6e  The complication
40f0: 20 68 65 72 65 20 69 73 20 74 68 61 74 20 74 68   here is that th
4100: 65 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 70 61  e destination pa
4110: 67 65 0a 20 20 20 20 20 20 20 20 2a 2a 20 73 69  ge.        ** si
4120: 7a 65 20 6d 61 79 20 62 65 20 64 69 66 66 65 72  ze may be differ
4130: 65 6e 74 20 74 6f 20 74 68 65 20 73 6f 75 72 63  ent to the sourc
4140: 65 20 70 61 67 65 20 73 69 7a 65 2e 20 0a 20 20  e page size. .  
4150: 20 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 20        **.       
4160: 20 2a 2a 20 49 66 20 74 68 65 20 73 6f 75 72 63   ** If the sourc
4170: 65 20 70 61 67 65 20 73 69 7a 65 20 69 73 20 73  e page size is s
4180: 6d 61 6c 6c 65 72 20 74 68 61 6e 20 74 68 65 20  maller than the 
4190: 64 65 73 74 69 6e 61 74 69 6f 6e 20 70 61 67 65  destination page
41a0: 20 73 69 7a 65 2c 20 0a 20 20 20 20 20 20 20 20   size, .        
41b0: 2a 2a 20 72 6f 75 6e 64 20 75 70 2e 20 49 6e 20  ** round up. In 
41c0: 74 68 69 73 20 63 61 73 65 20 74 68 65 20 63 61  this case the ca
41d0: 6c 6c 20 74 6f 20 73 71 6c 69 74 65 33 4f 73 54  ll to sqlite3OsT
41e0: 72 75 6e 63 61 74 65 28 29 20 62 65 6c 6f 77 20  runcate() below 
41f0: 77 69 6c 6c 0a 20 20 20 20 20 20 20 20 2a 2a 20  will.        ** 
4200: 66 69 78 20 74 68 65 20 73 69 7a 65 20 6f 66 20  fix the size of 
4210: 74 68 65 20 66 69 6c 65 2e 20 48 6f 77 65 76 65  the file. Howeve
4220: 72 20 69 74 20 69 73 20 69 6d 70 6f 72 74 61 6e  r it is importan
4230: 74 20 74 6f 20 63 61 6c 6c 0a 20 20 20 20 20 20  t to call.      
4240: 20 20 2a 2a 20 73 71 6c 69 74 65 33 50 61 67 65    ** sqlite3Page
4250: 72 54 72 75 6e 63 61 74 65 49 6d 61 67 65 28 29  rTruncateImage()
4260: 20 68 65 72 65 20 73 6f 20 74 68 61 74 20 61 6e   here so that an
4270: 79 20 70 61 67 65 73 20 69 6e 20 74 68 65 20 0a  y pages in the .
4280: 20 20 20 20 20 20 20 20 2a 2a 20 64 65 73 74 69          ** desti
4290: 6e 61 74 69 6f 6e 20 66 69 6c 65 20 74 68 61 74  nation file that
42a0: 20 6c 69 65 20 62 65 79 6f 6e 64 20 74 68 65 20   lie beyond the 
42b0: 6e 44 65 73 74 54 72 75 6e 63 61 74 65 20 70 61  nDestTruncate pa
42c0: 67 65 20 6d 61 72 6b 20 61 72 65 0a 20 20 20 20  ge mark are.    
42d0: 20 20 20 20 2a 2a 20 6a 6f 75 72 6e 61 6c 6c 65      ** journalle
42e0: 64 20 62 79 20 50 61 67 65 72 43 6f 6d 6d 69 74  d by PagerCommit
42f0: 50 68 61 73 65 4f 6e 65 28 29 20 62 65 66 6f 72  PhaseOne() befor
4300: 65 20 74 68 65 79 20 61 72 65 20 64 65 73 74 72  e they are destr
4310: 6f 79 65 64 0a 20 20 20 20 20 20 20 20 2a 2a 20  oyed.        ** 
4320: 62 79 20 74 68 65 20 66 69 6c 65 20 74 72 75 6e  by the file trun
4330: 63 61 74 69 6f 6e 2e 0a 20 20 20 20 20 20 20 20  cation..        
4340: 2a 2f 0a 20 20 20 20 20 20 20 20 61 73 73 65 72  */.        asser
4350: 74 28 20 70 67 73 7a 53 72 63 3d 3d 73 71 6c 69  t( pgszSrc==sqli
4360: 74 65 33 42 74 72 65 65 47 65 74 50 61 67 65 53  te3BtreeGetPageS
4370: 69 7a 65 28 70 2d 3e 70 53 72 63 29 20 29 3b 0a  ize(p->pSrc) );.
4380: 20 20 20 20 20 20 20 20 61 73 73 65 72 74 28 20          assert( 
4390: 70 67 73 7a 44 65 73 74 3d 3d 73 71 6c 69 74 65  pgszDest==sqlite
43a0: 33 42 74 72 65 65 47 65 74 50 61 67 65 53 69 7a  3BtreeGetPageSiz
43b0: 65 28 70 2d 3e 70 44 65 73 74 29 20 29 3b 0a 20  e(p->pDest) );. 
43c0: 20 20 20 20 20 20 20 69 66 28 20 70 67 73 7a 53         if( pgszS
43d0: 72 63 3c 70 67 73 7a 44 65 73 74 20 29 7b 0a 20  rc<pgszDest ){. 
43e0: 20 20 20 20 20 20 20 20 20 69 6e 74 20 72 61 74           int rat
43f0: 69 6f 20 3d 20 70 67 73 7a 44 65 73 74 2f 70 67  io = pgszDest/pg
4400: 73 7a 53 72 63 3b 0a 20 20 20 20 20 20 20 20 20  szSrc;.         
4410: 20 6e 44 65 73 74 54 72 75 6e 63 61 74 65 20 3d   nDestTruncate =
4420: 20 28 6e 53 72 63 50 61 67 65 2b 72 61 74 69 6f   (nSrcPage+ratio
4430: 2d 31 29 2f 72 61 74 69 6f 3b 0a 20 20 20 20 20  -1)/ratio;.     
4440: 20 20 20 20 20 69 66 28 20 6e 44 65 73 74 54 72       if( nDestTr
4450: 75 6e 63 61 74 65 3d 3d 28 69 6e 74 29 50 45 4e  uncate==(int)PEN
4460: 44 49 4e 47 5f 42 59 54 45 5f 50 41 47 45 28 70  DING_BYTE_PAGE(p
4470: 2d 3e 70 44 65 73 74 2d 3e 70 42 74 29 20 29 7b  ->pDest->pBt) ){
4480: 0a 20 20 20 20 20 20 20 20 20 20 20 20 6e 44 65  .            nDe
4490: 73 74 54 72 75 6e 63 61 74 65 2d 2d 3b 0a 20 20  stTruncate--;.  
44a0: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
44b0: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20    }else{.       
44c0: 20 20 20 6e 44 65 73 74 54 72 75 6e 63 61 74 65     nDestTruncate
44d0: 20 3d 20 6e 53 72 63 50 61 67 65 20 2a 20 28 70   = nSrcPage * (p
44e0: 67 73 7a 53 72 63 2f 70 67 73 7a 44 65 73 74 29  gszSrc/pgszDest)
44f0: 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20  ;.        }.    
4500: 20 20 20 20 61 73 73 65 72 74 28 20 6e 44 65 73      assert( nDes
4510: 74 54 72 75 6e 63 61 74 65 3e 30 20 29 3b 0a 0a  tTruncate>0 );..
4520: 20 20 20 20 20 20 20 20 69 66 28 20 70 67 73 7a          if( pgsz
4530: 53 72 63 3c 70 67 73 7a 44 65 73 74 20 29 7b 0a  Src<pgszDest ){.
4540: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 49 66 20            /* If 
4550: 74 68 65 20 73 6f 75 72 63 65 20 70 61 67 65 2d  the source page-
4560: 73 69 7a 65 20 69 73 20 73 6d 61 6c 6c 65 72 20  size is smaller 
4570: 74 68 61 6e 20 74 68 65 20 64 65 73 74 69 6e 61  than the destina
4580: 74 69 6f 6e 20 70 61 67 65 2d 73 69 7a 65 2c 0a  tion page-size,.
4590: 20 20 20 20 20 20 20 20 20 20 2a 2a 20 74 77 6f            ** two
45a0: 20 65 78 74 72 61 20 74 68 69 6e 67 73 20 6d 61   extra things ma
45b0: 79 20 6e 65 65 64 20 74 6f 20 68 61 70 70 65 6e  y need to happen
45c0: 3a 0a 20 20 20 20 20 20 20 20 20 20 2a 2a 0a 20  :.          **. 
45d0: 20 20 20 20 20 20 20 20 20 2a 2a 20 20 20 2a 20           **   * 
45e0: 54 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e 20  The destination 
45f0: 6d 61 79 20 6e 65 65 64 20 74 6f 20 62 65 20 74  may need to be t
4600: 72 75 6e 63 61 74 65 64 2c 20 61 6e 64 0a 20 20  runcated, and.  
4610: 20 20 20 20 20 20 20 20 2a 2a 0a 20 20 20 20 20          **.     
4620: 20 20 20 20 20 2a 2a 20 20 20 2a 20 44 61 74 61       **   * Data
4630: 20 73 74 6f 72 65 64 20 6f 6e 20 74 68 65 20 70   stored on the p
4640: 61 67 65 73 20 69 6d 6d 65 64 69 61 74 65 6c 79  ages immediately
4650: 20 66 6f 6c 6c 6f 77 69 6e 67 20 74 68 65 20 0a   following the .
4660: 20 20 20 20 20 20 20 20 20 20 2a 2a 20 20 20 20            **    
4670: 20 70 65 6e 64 69 6e 67 2d 62 79 74 65 20 70 61   pending-byte pa
4680: 67 65 20 69 6e 20 74 68 65 20 73 6f 75 72 63 65  ge in the source
4690: 20 64 61 74 61 62 61 73 65 20 6d 61 79 20 6e 65   database may ne
46a0: 65 64 20 74 6f 20 62 65 0a 20 20 20 20 20 20 20  ed to be.       
46b0: 20 20 20 2a 2a 20 20 20 20 20 63 6f 70 69 65 64     **     copied
46c0: 20 69 6e 74 6f 20 74 68 65 20 64 65 73 74 69 6e   into the destin
46d0: 61 74 69 6f 6e 20 64 61 74 61 62 61 73 65 2e 0a  ation database..
46e0: 20 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 20            */.   
46f0: 20 20 20 20 20 20 20 63 6f 6e 73 74 20 69 36 34         const i64
4700: 20 69 53 69 7a 65 20 3d 20 28 69 36 34 29 70 67   iSize = (i64)pg
4710: 73 7a 53 72 63 20 2a 20 28 69 36 34 29 6e 53 72  szSrc * (i64)nSr
4720: 63 50 61 67 65 3b 0a 20 20 20 20 20 20 20 20 20  cPage;.         
4730: 20 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 20   sqlite3_file * 
4740: 63 6f 6e 73 74 20 70 46 69 6c 65 20 3d 20 73 71  const pFile = sq
4750: 6c 69 74 65 33 50 61 67 65 72 46 69 6c 65 28 70  lite3PagerFile(p
4760: 44 65 73 74 50 61 67 65 72 29 3b 0a 20 20 20 20  DestPager);.    
4770: 20 20 20 20 20 20 50 67 6e 6f 20 69 50 67 3b 0a        Pgno iPg;.
4780: 20 20 20 20 20 20 20 20 20 20 69 6e 74 20 6e 44            int nD
4790: 73 74 50 61 67 65 3b 0a 20 20 20 20 20 20 20 20  stPage;.        
47a0: 20 20 69 36 34 20 69 4f 66 66 3b 0a 20 20 20 20    i64 iOff;.    
47b0: 20 20 20 20 20 20 69 36 34 20 69 45 6e 64 3b 0a        i64 iEnd;.
47c0: 0a 20 20 20 20 20 20 20 20 20 20 61 73 73 65 72  .          asser
47d0: 74 28 20 70 46 69 6c 65 20 29 3b 0a 20 20 20 20  t( pFile );.    
47e0: 20 20 20 20 20 20 61 73 73 65 72 74 28 20 6e 44        assert( nD
47f0: 65 73 74 54 72 75 6e 63 61 74 65 3d 3d 30 20 0a  estTruncate==0 .
4800: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7c 7c                ||
4810: 20 28 69 36 34 29 6e 44 65 73 74 54 72 75 6e 63   (i64)nDestTrunc
4820: 61 74 65 2a 28 69 36 34 29 70 67 73 7a 44 65 73  ate*(i64)pgszDes
4830: 74 20 3e 3d 20 69 53 69 7a 65 20 7c 7c 20 28 0a  t >= iSize || (.
4840: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4850: 6e 44 65 73 74 54 72 75 6e 63 61 74 65 3d 3d 28  nDestTruncate==(
4860: 69 6e 74 29 28 50 45 4e 44 49 4e 47 5f 42 59 54  int)(PENDING_BYT
4870: 45 5f 50 41 47 45 28 70 2d 3e 70 44 65 73 74 2d  E_PAGE(p->pDest-
4880: 3e 70 42 74 29 2d 31 29 0a 20 20 20 20 20 20 20  >pBt)-1).       
4890: 20 20 20 20 20 20 26 26 20 69 53 69 7a 65 3e 3d        && iSize>=
48a0: 50 45 4e 44 49 4e 47 5f 42 59 54 45 20 26 26 20  PENDING_BYTE && 
48b0: 69 53 69 7a 65 3c 3d 50 45 4e 44 49 4e 47 5f 42  iSize<=PENDING_B
48c0: 59 54 45 2b 70 67 73 7a 44 65 73 74 0a 20 20 20  YTE+pgszDest.   
48d0: 20 20 20 20 20 20 20 29 29 3b 0a 0a 20 20 20 20         ));..    
48e0: 20 20 20 20 20 20 2f 2a 20 54 68 69 73 20 62 6c        /* This bl
48f0: 6f 63 6b 20 65 6e 73 75 72 65 73 20 74 68 61 74  ock ensures that
4900: 20 61 6c 6c 20 64 61 74 61 20 72 65 71 75 69 72   all data requir
4910: 65 64 20 74 6f 20 72 65 63 72 65 61 74 65 20 74  ed to recreate t
4920: 68 65 20 6f 72 69 67 69 6e 61 6c 0a 20 20 20 20  he original.    
4930: 20 20 20 20 20 20 2a 2a 20 64 61 74 61 62 61 73        ** databas
4940: 65 20 68 61 73 20 62 65 65 6e 20 73 74 6f 72 65  e has been store
4950: 64 20 69 6e 20 74 68 65 20 6a 6f 75 72 6e 61 6c  d in the journal
4960: 20 66 6f 72 20 70 44 65 73 74 50 61 67 65 72 20   for pDestPager 
4970: 61 6e 64 20 74 68 65 0a 20 20 20 20 20 20 20 20  and the.        
4980: 20 20 2a 2a 20 6a 6f 75 72 6e 61 6c 20 73 79 6e    ** journal syn
4990: 63 65 64 20 74 6f 20 64 69 73 6b 2e 20 53 6f 20  ced to disk. So 
49a0: 61 74 20 74 68 69 73 20 70 6f 69 6e 74 20 77 65  at this point we
49b0: 20 6d 61 79 20 73 61 66 65 6c 79 20 6d 6f 64 69   may safely modi
49c0: 66 79 0a 20 20 20 20 20 20 20 20 20 20 2a 2a 20  fy.          ** 
49d0: 74 68 65 20 64 61 74 61 62 61 73 65 20 66 69 6c  the database fil
49e0: 65 20 69 6e 20 61 6e 79 20 77 61 79 2c 20 6b 6e  e in any way, kn
49f0: 6f 77 69 6e 67 20 74 68 61 74 20 69 66 20 61 20  owing that if a 
4a00: 70 6f 77 65 72 20 66 61 69 6c 75 72 65 0a 20 20  power failure.  
4a10: 20 20 20 20 20 20 20 20 2a 2a 20 6f 63 63 75 72          ** occur
4a20: 73 2c 20 74 68 65 20 6f 72 69 67 69 6e 61 6c 20  s, the original 
4a30: 64 61 74 61 62 61 73 65 20 77 69 6c 6c 20 62 65  database will be
4a40: 20 72 65 63 6f 6e 73 74 72 75 63 74 65 64 20 66   reconstructed f
4a50: 72 6f 6d 20 74 68 65 20 0a 20 20 20 20 20 20 20  rom the .       
4a60: 20 20 20 2a 2a 20 6a 6f 75 72 6e 61 6c 20 66 69     ** journal fi
4a70: 6c 65 2e 20 20 2a 2f 0a 20 20 20 20 20 20 20 20  le.  */.        
4a80: 20 20 73 71 6c 69 74 65 33 50 61 67 65 72 50 61    sqlite3PagerPa
4a90: 67 65 63 6f 75 6e 74 28 70 44 65 73 74 50 61 67  gecount(pDestPag
4aa0: 65 72 2c 20 26 6e 44 73 74 50 61 67 65 29 3b 0a  er, &nDstPage);.
4ab0: 20 20 20 20 20 20 20 20 20 20 66 6f 72 28 69 50            for(iP
4ac0: 67 3d 6e 44 65 73 74 54 72 75 6e 63 61 74 65 3b  g=nDestTruncate;
4ad0: 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 26   rc==SQLITE_OK &
4ae0: 26 20 69 50 67 3c 3d 28 50 67 6e 6f 29 6e 44 73  & iPg<=(Pgno)nDs
4af0: 74 50 61 67 65 3b 20 69 50 67 2b 2b 29 7b 0a 20  tPage; iPg++){. 
4b00: 20 20 20 20 20 20 20 20 20 20 20 69 66 28 20 69             if( i
4b10: 50 67 21 3d 50 45 4e 44 49 4e 47 5f 42 59 54 45  Pg!=PENDING_BYTE
4b20: 5f 50 41 47 45 28 70 2d 3e 70 44 65 73 74 2d 3e  _PAGE(p->pDest->
4b30: 70 42 74 29 20 29 7b 0a 20 20 20 20 20 20 20 20  pBt) ){.        
4b40: 20 20 20 20 20 20 44 62 50 61 67 65 20 2a 70 50        DbPage *pP
4b50: 67 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20  g;.             
4b60: 20 72 63 20 3d 20 73 71 6c 69 74 65 33 50 61 67   rc = sqlite3Pag
4b70: 65 72 47 65 74 28 70 44 65 73 74 50 61 67 65 72  erGet(pDestPager
4b80: 2c 20 69 50 67 2c 20 26 70 50 67 2c 20 30 29 3b  , iPg, &pPg, 0);
4b90: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 69  .              i
4ba0: 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b  f( rc==SQLITE_OK
4bb0: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20   ){.            
4bc0: 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33      rc = sqlite3
4bd0: 50 61 67 65 72 57 72 69 74 65 28 70 50 67 29 3b  PagerWrite(pPg);
4be0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  .               
4bf0: 20 73 71 6c 69 74 65 33 50 61 67 65 72 55 6e 72   sqlite3PagerUnr
4c00: 65 66 28 70 50 67 29 3b 0a 20 20 20 20 20 20 20  ef(pPg);.       
4c10: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
4c20: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
4c30: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 69 66 28   }.          if(
4c40: 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29   rc==SQLITE_OK )
4c50: 7b 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 63  {.            rc
4c60: 20 3d 20 73 71 6c 69 74 65 33 50 61 67 65 72 43   = sqlite3PagerC
4c70: 6f 6d 6d 69 74 50 68 61 73 65 4f 6e 65 28 70 44  ommitPhaseOne(pD
4c80: 65 73 74 50 61 67 65 72 2c 20 30 2c 20 31 29 3b  estPager, 0, 1);
4c90: 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 0a 20 20  .          }..  
4ca0: 20 20 20 20 20 20 20 20 2f 2a 20 57 72 69 74 65          /* Write
4cb0: 20 74 68 65 20 65 78 74 72 61 20 70 61 67 65 73   the extra pages
4cc0: 20 61 6e 64 20 74 72 75 6e 63 61 74 65 20 74 68   and truncate th
4cd0: 65 20 64 61 74 61 62 61 73 65 20 66 69 6c 65 20  e database file 
4ce0: 61 73 20 72 65 71 75 69 72 65 64 20 2a 2f 0a 20  as required */. 
4cf0: 20 20 20 20 20 20 20 20 20 69 45 6e 64 20 3d 20           iEnd = 
4d00: 4d 49 4e 28 50 45 4e 44 49 4e 47 5f 42 59 54 45  MIN(PENDING_BYTE
4d10: 20 2b 20 70 67 73 7a 44 65 73 74 2c 20 69 53 69   + pgszDest, iSi
4d20: 7a 65 29 3b 0a 20 20 20 20 20 20 20 20 20 20 66  ze);.          f
4d30: 6f 72 28 0a 20 20 20 20 20 20 20 20 20 20 20 20  or(.            
4d40: 69 4f 66 66 3d 50 45 4e 44 49 4e 47 5f 42 59 54  iOff=PENDING_BYT
4d50: 45 2b 70 67 73 7a 53 72 63 3b 20 0a 20 20 20 20  E+pgszSrc; .    
4d60: 20 20 20 20 20 20 20 20 72 63 3d 3d 53 51 4c 49          rc==SQLI
4d70: 54 45 5f 4f 4b 20 26 26 20 69 4f 66 66 3c 69 45  TE_OK && iOff<iE
4d80: 6e 64 3b 20 0a 20 20 20 20 20 20 20 20 20 20 20  nd; .           
4d90: 20 69 4f 66 66 2b 3d 70 67 73 7a 53 72 63 0a 20   iOff+=pgszSrc. 
4da0: 20 20 20 20 20 20 20 20 20 29 7b 0a 20 20 20 20           ){.    
4db0: 20 20 20 20 20 20 20 20 50 67 48 64 72 20 2a 70          PgHdr *p
4dc0: 53 72 63 50 67 20 3d 20 30 3b 0a 20 20 20 20 20  SrcPg = 0;.     
4dd0: 20 20 20 20 20 20 20 63 6f 6e 73 74 20 50 67 6e         const Pgn
4de0: 6f 20 69 53 72 63 50 67 20 3d 20 28 50 67 6e 6f  o iSrcPg = (Pgno
4df0: 29 28 28 69 4f 66 66 2f 70 67 73 7a 53 72 63 29  )((iOff/pgszSrc)
4e00: 2b 31 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  +1);.           
4e10: 20 72 63 20 3d 20 73 71 6c 69 74 65 33 50 61 67   rc = sqlite3Pag
4e20: 65 72 47 65 74 28 70 53 72 63 50 61 67 65 72 2c  erGet(pSrcPager,
4e30: 20 69 53 72 63 50 67 2c 20 26 70 53 72 63 50 67   iSrcPg, &pSrcPg
4e40: 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20  , 0);.          
4e50: 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45    if( rc==SQLITE
4e60: 5f 4f 4b 20 29 7b 0a 20 20 20 20 20 20 20 20 20  _OK ){.         
4e70: 20 20 20 20 20 75 38 20 2a 7a 44 61 74 61 20 3d       u8 *zData =
4e80: 20 73 71 6c 69 74 65 33 50 61 67 65 72 47 65 74   sqlite3PagerGet
4e90: 44 61 74 61 28 70 53 72 63 50 67 29 3b 0a 20 20  Data(pSrcPg);.  
4ea0: 20 20 20 20 20 20 20 20 20 20 20 20 72 63 20 3d              rc =
4eb0: 20 73 71 6c 69 74 65 33 4f 73 57 72 69 74 65 28   sqlite3OsWrite(
4ec0: 70 46 69 6c 65 2c 20 7a 44 61 74 61 2c 20 70 67  pFile, zData, pg
4ed0: 73 7a 53 72 63 2c 20 69 4f 66 66 29 3b 0a 20 20  szSrc, iOff);.  
4ee0: 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20            }.    
4ef0: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 50          sqlite3P
4f00: 61 67 65 72 55 6e 72 65 66 28 70 53 72 63 50 67  agerUnref(pSrcPg
4f10: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20  );.          }. 
4f20: 20 20 20 20 20 20 20 20 20 69 66 28 20 72 63 3d           if( rc=
4f30: 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20  =SQLITE_OK ){.  
4f40: 20 20 20 20 20 20 20 20 20 20 72 63 20 3d 20 62            rc = b
4f50: 61 63 6b 75 70 54 72 75 6e 63 61 74 65 46 69 6c  ackupTruncateFil
4f60: 65 28 70 46 69 6c 65 2c 20 69 53 69 7a 65 29 3b  e(pFile, iSize);
4f70: 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 0a 20 20  .          }..  
4f80: 20 20 20 20 20 20 20 20 2f 2a 20 53 79 6e 63 20          /* Sync 
4f90: 74 68 65 20 64 61 74 61 62 61 73 65 20 66 69 6c  the database fil
4fa0: 65 20 74 6f 20 64 69 73 6b 2e 20 2a 2f 0a 20 20  e to disk. */.  
4fb0: 20 20 20 20 20 20 20 20 69 66 28 20 72 63 3d 3d          if( rc==
4fc0: 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20  SQLITE_OK ){.   
4fd0: 20 20 20 20 20 20 20 20 20 72 63 20 3d 20 73 71           rc = sq
4fe0: 6c 69 74 65 33 50 61 67 65 72 53 79 6e 63 28 70  lite3PagerSync(p
4ff0: 44 65 73 74 50 61 67 65 72 2c 20 30 29 3b 0a 20  DestPager, 0);. 
5000: 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20           }.     
5010: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20     }else{.      
5020: 20 20 20 20 73 71 6c 69 74 65 33 50 61 67 65 72      sqlite3Pager
5030: 54 72 75 6e 63 61 74 65 49 6d 61 67 65 28 70 44  TruncateImage(pD
5040: 65 73 74 50 61 67 65 72 2c 20 6e 44 65 73 74 54  estPager, nDestT
5050: 72 75 6e 63 61 74 65 29 3b 0a 20 20 20 20 20 20  runcate);.      
5060: 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33      rc = sqlite3
5070: 50 61 67 65 72 43 6f 6d 6d 69 74 50 68 61 73 65  PagerCommitPhase
5080: 4f 6e 65 28 70 44 65 73 74 50 61 67 65 72 2c 20  One(pDestPager, 
5090: 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 20 7d  0, 0);.        }
50a0: 0a 20 20 20 20 0a 20 20 20 20 20 20 20 20 2f 2a  .    .        /*
50b0: 20 46 69 6e 69 73 68 20 63 6f 6d 6d 69 74 74 69   Finish committi
50c0: 6e 67 20 74 68 65 20 74 72 61 6e 73 61 63 74 69  ng the transacti
50d0: 6f 6e 20 74 6f 20 74 68 65 20 64 65 73 74 69 6e  on to the destin
50e0: 61 74 69 6f 6e 20 64 61 74 61 62 61 73 65 2e 20  ation database. 
50f0: 2a 2f 0a 20 20 20 20 20 20 20 20 69 66 28 20 53  */.        if( S
5100: 51 4c 49 54 45 5f 4f 4b 3d 3d 72 63 0a 20 20 20  QLITE_OK==rc.   
5110: 20 20 20 20 20 20 26 26 20 53 51 4c 49 54 45 5f        && SQLITE_
5120: 4f 4b 3d 3d 28 72 63 20 3d 20 73 71 6c 69 74 65  OK==(rc = sqlite
5130: 33 42 74 72 65 65 43 6f 6d 6d 69 74 50 68 61 73  3BtreeCommitPhas
5140: 65 54 77 6f 28 70 2d 3e 70 44 65 73 74 2c 20 30  eTwo(p->pDest, 0
5150: 29 29 0a 20 20 20 20 20 20 20 20 29 7b 0a 20 20  )).        ){.  
5160: 20 20 20 20 20 20 20 20 72 63 20 3d 20 53 51 4c          rc = SQL
5170: 49 54 45 5f 44 4f 4e 45 3b 0a 20 20 20 20 20 20  ITE_DONE;.      
5180: 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20    }.      }.    
5190: 7d 0a 20 20 0a 20 20 20 20 2f 2a 20 49 66 20 62  }.  .    /* If b
51a0: 43 6c 6f 73 65 54 72 61 6e 73 20 69 73 20 74 72  CloseTrans is tr
51b0: 75 65 2c 20 74 68 65 6e 20 74 68 69 73 20 66 75  ue, then this fu
51c0: 6e 63 74 69 6f 6e 20 6f 70 65 6e 65 64 20 61 20  nction opened a 
51d0: 72 65 61 64 20 74 72 61 6e 73 61 63 74 69 6f 6e  read transaction
51e0: 0a 20 20 20 20 2a 2a 20 6f 6e 20 74 68 65 20 73  .    ** on the s
51f0: 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 2e 20  ource database. 
5200: 43 6c 6f 73 65 20 74 68 65 20 72 65 61 64 20 74  Close the read t
5210: 72 61 6e 73 61 63 74 69 6f 6e 20 68 65 72 65 2e  ransaction here.
5220: 20 54 68 65 72 65 20 69 73 0a 20 20 20 20 2a 2a   There is.    **
5230: 20 6e 6f 20 6e 65 65 64 20 74 6f 20 63 68 65 63   no need to chec
5240: 6b 20 74 68 65 20 72 65 74 75 72 6e 20 76 61 6c  k the return val
5250: 75 65 73 20 6f 66 20 74 68 65 20 62 74 72 65 65  ues of the btree
5260: 20 6d 65 74 68 6f 64 73 20 68 65 72 65 2c 20 61   methods here, a
5270: 73 0a 20 20 20 20 2a 2a 20 22 63 6f 6d 6d 69 74  s.    ** "commit
5280: 74 69 6e 67 22 20 61 20 72 65 61 64 2d 6f 6e 6c  ting" a read-onl
5290: 79 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 63 61  y transaction ca
52a0: 6e 6e 6f 74 20 66 61 69 6c 2e 0a 20 20 20 20 2a  nnot fail..    *
52b0: 2f 0a 20 20 20 20 69 66 28 20 62 43 6c 6f 73 65  /.    if( bClose
52c0: 54 72 61 6e 73 20 29 7b 0a 20 20 20 20 20 20 54  Trans ){.      T
52d0: 45 53 54 4f 4e 4c 59 28 20 69 6e 74 20 72 63 32  ESTONLY( int rc2
52e0: 20 29 3b 0a 20 20 20 20 20 20 54 45 53 54 4f 4e   );.      TESTON
52f0: 4c 59 28 20 72 63 32 20 20 3d 20 29 20 73 71 6c  LY( rc2  = ) sql
5300: 69 74 65 33 42 74 72 65 65 43 6f 6d 6d 69 74 50  ite3BtreeCommitP
5310: 68 61 73 65 4f 6e 65 28 70 2d 3e 70 53 72 63 2c  haseOne(p->pSrc,
5320: 20 30 29 3b 0a 20 20 20 20 20 20 54 45 53 54 4f   0);.      TESTO
5330: 4e 4c 59 28 20 72 63 32 20 7c 3d 20 29 20 73 71  NLY( rc2 |= ) sq
5340: 6c 69 74 65 33 42 74 72 65 65 43 6f 6d 6d 69 74  lite3BtreeCommit
5350: 50 68 61 73 65 54 77 6f 28 70 2d 3e 70 53 72 63  PhaseTwo(p->pSrc
5360: 2c 20 30 29 3b 0a 20 20 20 20 20 20 61 73 73 65  , 0);.      asse
5370: 72 74 28 20 72 63 32 3d 3d 53 51 4c 49 54 45 5f  rt( rc2==SQLITE_
5380: 4f 4b 20 29 3b 0a 20 20 20 20 7d 0a 20 20 0a 20  OK );.    }.  . 
5390: 20 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54     if( rc==SQLIT
53a0: 45 5f 49 4f 45 52 52 5f 4e 4f 4d 45 4d 20 29 7b  E_IOERR_NOMEM ){
53b0: 0a 20 20 20 20 20 20 72 63 20 3d 20 53 51 4c 49  .      rc = SQLI
53c0: 54 45 5f 4e 4f 4d 45 4d 5f 42 4b 50 54 3b 0a 20  TE_NOMEM_BKPT;. 
53d0: 20 20 20 7d 0a 20 20 20 20 70 2d 3e 72 63 20 3d     }.    p->rc =
53e0: 20 72 63 3b 0a 20 20 7d 0a 20 20 69 66 28 20 70   rc;.  }.  if( p
53f0: 2d 3e 70 44 65 73 74 44 62 20 29 7b 0a 20 20 20  ->pDestDb ){.   
5400: 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c   sqlite3_mutex_l
5410: 65 61 76 65 28 70 2d 3e 70 44 65 73 74 44 62 2d  eave(p->pDestDb-
5420: 3e 6d 75 74 65 78 29 3b 0a 20 20 7d 0a 20 20 73  >mutex);.  }.  s
5430: 71 6c 69 74 65 33 42 74 72 65 65 4c 65 61 76 65  qlite3BtreeLeave
5440: 28 70 2d 3e 70 53 72 63 29 3b 0a 20 20 73 71 6c  (p->pSrc);.  sql
5450: 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65  ite3_mutex_leave
5460: 28 70 2d 3e 70 53 72 63 44 62 2d 3e 6d 75 74 65  (p->pSrcDb->mute
5470: 78 29 3b 0a 20 20 72 65 74 75 72 6e 20 72 63 3b  x);.  return rc;
5480: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 6c 65 61 73  .}../*.** Releas
5490: 65 20 61 6c 6c 20 72 65 73 6f 75 72 63 65 73 20  e all resources 
54a0: 61 73 73 6f 63 69 61 74 65 64 20 77 69 74 68 20  associated with 
54b0: 61 6e 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75  an sqlite3_backu
54c0: 70 2a 20 68 61 6e 64 6c 65 2e 0a 2a 2f 0a 69 6e  p* handle..*/.in
54d0: 74 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70  t sqlite3_backup
54e0: 5f 66 69 6e 69 73 68 28 73 71 6c 69 74 65 33 5f  _finish(sqlite3_
54f0: 62 61 63 6b 75 70 20 2a 70 29 7b 0a 20 20 73 71  backup *p){.  sq
5500: 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 2a 70  lite3_backup **p
5510: 70 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  p;              
5520: 20 20 20 2f 2a 20 50 74 72 20 74 6f 20 68 65 61     /* Ptr to hea
5530: 64 20 6f 66 20 70 61 67 65 72 73 20 62 61 63 6b  d of pagers back
5540: 75 70 20 6c 69 73 74 20 2a 2f 0a 20 20 73 71 6c  up list */.  sql
5550: 69 74 65 33 20 2a 70 53 72 63 44 62 3b 20 20 20  ite3 *pSrcDb;   
5560: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5570: 20 20 2f 2a 20 53 6f 75 72 63 65 20 64 61 74 61    /* Source data
5580: 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20  base connection 
5590: 2a 2f 0a 20 20 69 6e 74 20 72 63 3b 20 20 20 20  */.  int rc;    
55a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
55b0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 56 61 6c            /* Val
55c0: 75 65 20 74 6f 20 72 65 74 75 72 6e 20 2a 2f 0a  ue to return */.
55d0: 0a 20 20 2f 2a 20 45 6e 74 65 72 20 74 68 65 20  .  /* Enter the 
55e0: 6d 75 74 65 78 65 73 20 2a 2f 0a 20 20 69 66 28  mutexes */.  if(
55f0: 20 70 3d 3d 30 20 29 20 72 65 74 75 72 6e 20 53   p==0 ) return S
5600: 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 70 53 72 63  QLITE_OK;.  pSrc
5610: 44 62 20 3d 20 70 2d 3e 70 53 72 63 44 62 3b 0a  Db = p->pSrcDb;.
5620: 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f    sqlite3_mutex_
5630: 65 6e 74 65 72 28 70 53 72 63 44 62 2d 3e 6d 75  enter(pSrcDb->mu
5640: 74 65 78 29 3b 0a 20 20 73 71 6c 69 74 65 33 42  tex);.  sqlite3B
5650: 74 72 65 65 45 6e 74 65 72 28 70 2d 3e 70 53 72  treeEnter(p->pSr
5660: 63 29 3b 0a 20 20 69 66 28 20 70 2d 3e 70 44 65  c);.  if( p->pDe
5670: 73 74 44 62 20 29 7b 0a 20 20 20 20 73 71 6c 69  stDb ){.    sqli
5680: 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28  te3_mutex_enter(
5690: 70 2d 3e 70 44 65 73 74 44 62 2d 3e 6d 75 74 65  p->pDestDb->mute
56a0: 78 29 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 44 65  x);.  }..  /* De
56b0: 74 61 63 68 20 74 68 69 73 20 62 61 63 6b 75 70  tach this backup
56c0: 20 66 72 6f 6d 20 74 68 65 20 73 6f 75 72 63 65   from the source
56d0: 20 70 61 67 65 72 2e 20 2a 2f 0a 20 20 69 66 28   pager. */.  if(
56e0: 20 70 2d 3e 70 44 65 73 74 44 62 20 29 7b 0a 20   p->pDestDb ){. 
56f0: 20 20 20 70 2d 3e 70 53 72 63 2d 3e 6e 42 61 63     p->pSrc->nBac
5700: 6b 75 70 2d 2d 3b 0a 20 20 7d 0a 20 20 69 66 28  kup--;.  }.  if(
5710: 20 70 2d 3e 69 73 41 74 74 61 63 68 65 64 20 29   p->isAttached )
5720: 7b 0a 20 20 20 20 70 70 20 3d 20 73 71 6c 69 74  {.    pp = sqlit
5730: 65 33 50 61 67 65 72 42 61 63 6b 75 70 50 74 72  e3PagerBackupPtr
5740: 28 73 71 6c 69 74 65 33 42 74 72 65 65 50 61 67  (sqlite3BtreePag
5750: 65 72 28 70 2d 3e 70 53 72 63 29 29 3b 0a 20 20  er(p->pSrc));.  
5760: 20 20 77 68 69 6c 65 28 20 2a 70 70 21 3d 70 20    while( *pp!=p 
5770: 29 7b 0a 20 20 20 20 20 20 70 70 20 3d 20 26 28  ){.      pp = &(
5780: 2a 70 70 29 2d 3e 70 4e 65 78 74 3b 0a 20 20 20  *pp)->pNext;.   
5790: 20 7d 0a 20 20 20 20 2a 70 70 20 3d 20 70 2d 3e   }.    *pp = p->
57a0: 70 4e 65 78 74 3b 0a 20 20 7d 0a 0a 20 20 2f 2a  pNext;.  }..  /*
57b0: 20 49 66 20 61 20 74 72 61 6e 73 61 63 74 69 6f   If a transactio
57c0: 6e 20 69 73 20 73 74 69 6c 6c 20 6f 70 65 6e 20  n is still open 
57d0: 6f 6e 20 74 68 65 20 42 74 72 65 65 2c 20 72 6f  on the Btree, ro
57e0: 6c 6c 20 69 74 20 62 61 63 6b 2e 20 2a 2f 0a 20  ll it back. */. 
57f0: 20 73 71 6c 69 74 65 33 42 74 72 65 65 52 6f 6c   sqlite3BtreeRol
5800: 6c 62 61 63 6b 28 70 2d 3e 70 44 65 73 74 2c 20  lback(p->pDest, 
5810: 53 51 4c 49 54 45 5f 4f 4b 2c 20 30 29 3b 0a 0a  SQLITE_OK, 0);..
5820: 20 20 2f 2a 20 53 65 74 20 74 68 65 20 65 72 72    /* Set the err
5830: 6f 72 20 63 6f 64 65 20 6f 66 20 74 68 65 20 64  or code of the d
5840: 65 73 74 69 6e 61 74 69 6f 6e 20 64 61 74 61 62  estination datab
5850: 61 73 65 20 68 61 6e 64 6c 65 2e 20 2a 2f 0a 20  ase handle. */. 
5860: 20 72 63 20 3d 20 28 70 2d 3e 72 63 3d 3d 53 51   rc = (p->rc==SQ
5870: 4c 49 54 45 5f 44 4f 4e 45 29 20 3f 20 53 51 4c  LITE_DONE) ? SQL
5880: 49 54 45 5f 4f 4b 20 3a 20 70 2d 3e 72 63 3b 0a  ITE_OK : p->rc;.
5890: 20 20 69 66 28 20 70 2d 3e 70 44 65 73 74 44 62    if( p->pDestDb
58a0: 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 45   ){.    sqlite3E
58b0: 72 72 6f 72 28 70 2d 3e 70 44 65 73 74 44 62 2c  rror(p->pDestDb,
58c0: 20 72 63 29 3b 0a 0a 20 20 20 20 2f 2a 20 45 78   rc);..    /* Ex
58d0: 69 74 20 74 68 65 20 6d 75 74 65 78 65 73 20 61  it the mutexes a
58e0: 6e 64 20 66 72 65 65 20 74 68 65 20 62 61 63 6b  nd free the back
58f0: 75 70 20 63 6f 6e 74 65 78 74 20 73 74 72 75 63  up context struc
5900: 74 75 72 65 2e 20 2a 2f 0a 20 20 20 20 73 71 6c  ture. */.    sql
5910: 69 74 65 33 4c 65 61 76 65 4d 75 74 65 78 41 6e  ite3LeaveMutexAn
5920: 64 43 6c 6f 73 65 5a 6f 6d 62 69 65 28 70 2d 3e  dCloseZombie(p->
5930: 70 44 65 73 74 44 62 29 3b 0a 20 20 7d 0a 20 20  pDestDb);.  }.  
5940: 73 71 6c 69 74 65 33 42 74 72 65 65 4c 65 61 76  sqlite3BtreeLeav
5950: 65 28 70 2d 3e 70 53 72 63 29 3b 0a 20 20 69 66  e(p->pSrc);.  if
5960: 28 20 70 2d 3e 70 44 65 73 74 44 62 20 29 7b 0a  ( p->pDestDb ){.
5970: 20 20 20 20 2f 2a 20 45 56 49 44 45 4e 43 45 2d      /* EVIDENCE-
5980: 4f 46 3a 20 52 2d 36 34 38 35 32 2d 32 31 35 39  OF: R-64852-2159
5990: 31 20 54 68 65 20 73 71 6c 69 74 65 33 5f 62 61  1 The sqlite3_ba
59a0: 63 6b 75 70 20 6f 62 6a 65 63 74 20 69 73 20 63  ckup object is c
59b0: 72 65 61 74 65 64 20 62 79 20 61 0a 20 20 20 20  reated by a.    
59c0: 2a 2a 20 63 61 6c 6c 20 74 6f 20 73 71 6c 69 74  ** call to sqlit
59d0: 65 33 5f 62 61 63 6b 75 70 5f 69 6e 69 74 28 29  e3_backup_init()
59e0: 20 61 6e 64 20 69 73 20 64 65 73 74 72 6f 79 65   and is destroye
59f0: 64 20 62 79 20 61 20 63 61 6c 6c 20 74 6f 0a 20  d by a call to. 
5a00: 20 20 20 2a 2a 20 73 71 6c 69 74 65 33 5f 62 61     ** sqlite3_ba
5a10: 63 6b 75 70 5f 66 69 6e 69 73 68 28 29 2e 20 2a  ckup_finish(). *
5a20: 2f 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 66 72  /.    sqlite3_fr
5a30: 65 65 28 70 29 3b 0a 20 20 7d 0a 20 20 73 71 6c  ee(p);.  }.  sql
5a40: 69 74 65 33 4c 65 61 76 65 4d 75 74 65 78 41 6e  ite3LeaveMutexAn
5a50: 64 43 6c 6f 73 65 5a 6f 6d 62 69 65 28 70 53 72  dCloseZombie(pSr
5a60: 63 44 62 29 3b 0a 20 20 72 65 74 75 72 6e 20 72  cDb);.  return r
5a70: 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75  c;.}../*.** Retu
5a80: 72 6e 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66  rn the number of
5a90: 20 70 61 67 65 73 20 73 74 69 6c 6c 20 74 6f 20   pages still to 
5aa0: 62 65 20 62 61 63 6b 65 64 20 75 70 20 61 73 20  be backed up as 
5ab0: 6f 66 20 74 68 65 20 6d 6f 73 74 20 72 65 63 65  of the most rece
5ac0: 6e 74 0a 2a 2a 20 63 61 6c 6c 20 74 6f 20 73 71  nt.** call to sq
5ad0: 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 73 74 65  lite3_backup_ste
5ae0: 70 28 29 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69  p()..*/.int sqli
5af0: 74 65 33 5f 62 61 63 6b 75 70 5f 72 65 6d 61 69  te3_backup_remai
5b00: 6e 69 6e 67 28 73 71 6c 69 74 65 33 5f 62 61 63  ning(sqlite3_bac
5b10: 6b 75 70 20 2a 70 29 7b 0a 23 69 66 64 65 66 20  kup *p){.#ifdef 
5b20: 53 51 4c 49 54 45 5f 45 4e 41 42 4c 45 5f 41 50  SQLITE_ENABLE_AP
5b30: 49 5f 41 52 4d 4f 52 0a 20 20 69 66 28 20 70 3d  I_ARMOR.  if( p=
5b40: 3d 30 20 29 7b 0a 20 20 20 20 28 76 6f 69 64 29  =0 ){.    (void)
5b50: 53 51 4c 49 54 45 5f 4d 49 53 55 53 45 5f 42 4b  SQLITE_MISUSE_BK
5b60: 50 54 3b 0a 20 20 20 20 72 65 74 75 72 6e 20 30  PT;.    return 0
5b70: 3b 0a 20 20 7d 0a 23 65 6e 64 69 66 0a 20 20 72  ;.  }.#endif.  r
5b80: 65 74 75 72 6e 20 70 2d 3e 6e 52 65 6d 61 69 6e  eturn p->nRemain
5b90: 69 6e 67 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65  ing;.}../*.** Re
5ba0: 74 75 72 6e 20 74 68 65 20 74 6f 74 61 6c 20 6e  turn the total n
5bb0: 75 6d 62 65 72 20 6f 66 20 70 61 67 65 73 20 69  umber of pages i
5bc0: 6e 20 74 68 65 20 73 6f 75 72 63 65 20 64 61 74  n the source dat
5bd0: 61 62 61 73 65 20 61 73 20 6f 66 20 74 68 65 20  abase as of the 
5be0: 6d 6f 73 74 20 0a 2a 2a 20 72 65 63 65 6e 74 20  most .** recent 
5bf0: 63 61 6c 6c 20 74 6f 20 73 71 6c 69 74 65 33 5f  call to sqlite3_
5c00: 62 61 63 6b 75 70 5f 73 74 65 70 28 29 2e 0a 2a  backup_step()..*
5c10: 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f 62 61  /.int sqlite3_ba
5c20: 63 6b 75 70 5f 70 61 67 65 63 6f 75 6e 74 28 73  ckup_pagecount(s
5c30: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 70  qlite3_backup *p
5c40: 29 7b 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45  ){.#ifdef SQLITE
5c50: 5f 45 4e 41 42 4c 45 5f 41 50 49 5f 41 52 4d 4f  _ENABLE_API_ARMO
5c60: 52 0a 20 20 69 66 28 20 70 3d 3d 30 20 29 7b 0a  R.  if( p==0 ){.
5c70: 20 20 20 20 28 76 6f 69 64 29 53 51 4c 49 54 45      (void)SQLITE
5c80: 5f 4d 49 53 55 53 45 5f 42 4b 50 54 3b 0a 20 20  _MISUSE_BKPT;.  
5c90: 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a    return 0;.  }.
5ca0: 23 65 6e 64 69 66 0a 20 20 72 65 74 75 72 6e 20  #endif.  return 
5cb0: 70 2d 3e 6e 50 61 67 65 63 6f 75 6e 74 3b 0a 7d  p->nPagecount;.}
5cc0: 0a 0a 2f 2a 0a 2a 2a 20 54 68 69 73 20 66 75 6e  ../*.** This fun
5cd0: 63 74 69 6f 6e 20 69 73 20 63 61 6c 6c 65 64 20  ction is called 
5ce0: 61 66 74 65 72 20 74 68 65 20 63 6f 6e 74 65 6e  after the conten
5cf0: 74 73 20 6f 66 20 70 61 67 65 20 69 50 61 67 65  ts of page iPage
5d00: 20 6f 66 20 74 68 65 0a 2a 2a 20 73 6f 75 72 63   of the.** sourc
5d10: 65 20 64 61 74 61 62 61 73 65 20 68 61 76 65 20  e database have 
5d20: 62 65 65 6e 20 6d 6f 64 69 66 69 65 64 2e 20 49  been modified. I
5d30: 66 20 70 61 67 65 20 69 50 61 67 65 20 68 61 73  f page iPage has
5d40: 20 61 6c 72 65 61 64 79 20 62 65 65 6e 20 0a 2a   already been .*
5d50: 2a 20 63 6f 70 69 65 64 20 69 6e 74 6f 20 74 68  * copied into th
5d60: 65 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 64 61  e destination da
5d70: 74 61 62 61 73 65 2c 20 74 68 65 6e 20 74 68 65  tabase, then the
5d80: 20 64 61 74 61 20 77 72 69 74 74 65 6e 20 74 6f   data written to
5d90: 20 74 68 65 0a 2a 2a 20 64 65 73 74 69 6e 61 74   the.** destinat
5da0: 69 6f 6e 20 69 73 20 6e 6f 77 20 69 6e 76 61 6c  ion is now inval
5db0: 69 64 61 74 65 64 2e 20 54 68 65 20 64 65 73 74  idated. The dest
5dc0: 69 6e 61 74 69 6f 6e 20 63 6f 70 79 20 6f 66 20  ination copy of 
5dd0: 69 50 61 67 65 20 6e 65 65 64 73 0a 2a 2a 20 74  iPage needs.** t
5de0: 6f 20 62 65 20 75 70 64 61 74 65 64 20 77 69 74  o be updated wit
5df0: 68 20 74 68 65 20 6e 65 77 20 64 61 74 61 20 62  h the new data b
5e00: 65 66 6f 72 65 20 74 68 65 20 62 61 63 6b 75 70  efore the backup
5e10: 20 6f 70 65 72 61 74 69 6f 6e 20 69 73 0a 2a 2a   operation is.**
5e20: 20 63 6f 6d 70 6c 65 74 65 2e 0a 2a 2a 0a 2a 2a   complete..**.**
5e30: 20 49 74 20 69 73 20 61 73 73 75 6d 65 64 20 74   It is assumed t
5e40: 68 61 74 20 74 68 65 20 6d 75 74 65 78 20 61 73  hat the mutex as
5e50: 73 6f 63 69 61 74 65 64 20 77 69 74 68 20 74 68  sociated with th
5e60: 65 20 42 74 53 68 61 72 65 64 20 6f 62 6a 65 63  e BtShared objec
5e70: 74 0a 2a 2a 20 63 6f 72 72 65 73 70 6f 6e 64 69  t.** correspondi
5e80: 6e 67 20 74 6f 20 74 68 65 20 73 6f 75 72 63 65  ng to the source
5e90: 20 64 61 74 61 62 61 73 65 20 69 73 20 68 65 6c   database is hel
5ea0: 64 20 77 68 65 6e 20 74 68 69 73 20 66 75 6e 63  d when this func
5eb0: 74 69 6f 6e 20 69 73 0a 2a 2a 20 63 61 6c 6c 65  tion is.** calle
5ec0: 64 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 53 51 4c  d..*/.static SQL
5ed0: 49 54 45 5f 4e 4f 49 4e 4c 49 4e 45 20 76 6f 69  ITE_NOINLINE voi
5ee0: 64 20 62 61 63 6b 75 70 55 70 64 61 74 65 28 0a  d backupUpdate(.
5ef0: 20 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70    sqlite3_backup
5f00: 20 2a 70 2c 0a 20 20 50 67 6e 6f 20 69 50 61 67   *p,.  Pgno iPag
5f10: 65 2c 0a 20 20 63 6f 6e 73 74 20 75 38 20 2a 61  e,.  const u8 *a
5f20: 44 61 74 61 0a 29 7b 0a 20 20 61 73 73 65 72 74  Data.){.  assert
5f30: 28 20 70 21 3d 30 20 29 3b 0a 20 20 64 6f 7b 0a  ( p!=0 );.  do{.
5f40: 20 20 20 20 61 73 73 65 72 74 28 20 73 71 6c 69      assert( sqli
5f50: 74 65 33 5f 6d 75 74 65 78 5f 68 65 6c 64 28 70  te3_mutex_held(p
5f60: 2d 3e 70 53 72 63 2d 3e 70 42 74 2d 3e 6d 75 74  ->pSrc->pBt->mut
5f70: 65 78 29 20 29 3b 0a 20 20 20 20 69 66 28 20 21  ex) );.    if( !
5f80: 69 73 46 61 74 61 6c 45 72 72 6f 72 28 70 2d 3e  isFatalError(p->
5f90: 72 63 29 20 26 26 20 69 50 61 67 65 3c 70 2d 3e  rc) && iPage<p->
5fa0: 69 4e 65 78 74 20 29 7b 0a 20 20 20 20 20 20 2f  iNext ){.      /
5fb0: 2a 20 54 68 65 20 62 61 63 6b 75 70 20 70 72 6f  * The backup pro
5fc0: 63 65 73 73 20 70 20 68 61 73 20 61 6c 72 65 61  cess p has alrea
5fd0: 64 79 20 63 6f 70 69 65 64 20 70 61 67 65 20 69  dy copied page i
5fe0: 50 61 67 65 2e 20 42 75 74 20 6e 6f 77 20 69 74  Page. But now it
5ff0: 0a 20 20 20 20 20 20 2a 2a 20 68 61 73 20 62 65  .      ** has be
6000: 65 6e 20 6d 6f 64 69 66 69 65 64 20 62 79 20 61  en modified by a
6010: 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 6f 6e 20   transaction on 
6020: 74 68 65 20 73 6f 75 72 63 65 20 70 61 67 65 72  the source pager
6030: 2e 20 43 6f 70 79 0a 20 20 20 20 20 20 2a 2a 20  . Copy.      ** 
6040: 74 68 65 20 6e 65 77 20 64 61 74 61 20 69 6e 74  the new data int
6050: 6f 20 74 68 65 20 62 61 63 6b 75 70 2e 0a 20 20  o the backup..  
6060: 20 20 20 20 2a 2f 0a 20 20 20 20 20 20 69 6e 74      */.      int
6070: 20 72 63 3b 0a 20 20 20 20 20 20 61 73 73 65 72   rc;.      asser
6080: 74 28 20 70 2d 3e 70 44 65 73 74 44 62 20 29 3b  t( p->pDestDb );
6090: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 5f 6d  .      sqlite3_m
60a0: 75 74 65 78 5f 65 6e 74 65 72 28 70 2d 3e 70 44  utex_enter(p->pD
60b0: 65 73 74 44 62 2d 3e 6d 75 74 65 78 29 3b 0a 20  estDb->mutex);. 
60c0: 20 20 20 20 20 72 63 20 3d 20 62 61 63 6b 75 70       rc = backup
60d0: 4f 6e 65 50 61 67 65 28 70 2c 20 69 50 61 67 65  OnePage(p, iPage
60e0: 2c 20 61 44 61 74 61 2c 20 31 29 3b 0a 20 20 20  , aData, 1);.   
60f0: 20 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78     sqlite3_mutex
6100: 5f 6c 65 61 76 65 28 70 2d 3e 70 44 65 73 74 44  _leave(p->pDestD
6110: 62 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 20 20 20  b->mutex);.     
6120: 20 61 73 73 65 72 74 28 20 72 63 21 3d 53 51 4c   assert( rc!=SQL
6130: 49 54 45 5f 42 55 53 59 20 26 26 20 72 63 21 3d  ITE_BUSY && rc!=
6140: 53 51 4c 49 54 45 5f 4c 4f 43 4b 45 44 20 29 3b  SQLITE_LOCKED );
6150: 0a 20 20 20 20 20 20 69 66 28 20 72 63 21 3d 53  .      if( rc!=S
6160: 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20  QLITE_OK ){.    
6170: 20 20 20 20 70 2d 3e 72 63 20 3d 20 72 63 3b 0a      p->rc = rc;.
6180: 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20        }.    }.  
6190: 7d 77 68 69 6c 65 28 20 28 70 20 3d 20 70 2d 3e  }while( (p = p->
61a0: 70 4e 65 78 74 29 21 3d 30 20 29 3b 0a 7d 0a 76  pNext)!=0 );.}.v
61b0: 6f 69 64 20 73 71 6c 69 74 65 33 42 61 63 6b 75  oid sqlite3Backu
61c0: 70 55 70 64 61 74 65 28 73 71 6c 69 74 65 33 5f  pUpdate(sqlite3_
61d0: 62 61 63 6b 75 70 20 2a 70 42 61 63 6b 75 70 2c  backup *pBackup,
61e0: 20 50 67 6e 6f 20 69 50 61 67 65 2c 20 63 6f 6e   Pgno iPage, con
61f0: 73 74 20 75 38 20 2a 61 44 61 74 61 29 7b 0a 20  st u8 *aData){. 
6200: 20 69 66 28 20 70 42 61 63 6b 75 70 20 29 20 62   if( pBackup ) b
6210: 61 63 6b 75 70 55 70 64 61 74 65 28 70 42 61 63  ackupUpdate(pBac
6220: 6b 75 70 2c 20 69 50 61 67 65 2c 20 61 44 61 74  kup, iPage, aDat
6230: 61 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 73  a);.}../*.** Res
6240: 74 61 72 74 20 74 68 65 20 62 61 63 6b 75 70 20  tart the backup 
6250: 70 72 6f 63 65 73 73 2e 20 54 68 69 73 20 69 73  process. This is
6260: 20 63 61 6c 6c 65 64 20 77 68 65 6e 20 74 68 65   called when the
6270: 20 70 61 67 65 72 20 6c 61 79 65 72 0a 2a 2a 20   pager layer.** 
6280: 64 65 74 65 63 74 73 20 74 68 61 74 20 74 68 65  detects that the
6290: 20 64 61 74 61 62 61 73 65 20 68 61 73 20 62 65   database has be
62a0: 65 6e 20 6d 6f 64 69 66 69 65 64 20 62 79 20 61  en modified by a
62b0: 6e 20 65 78 74 65 72 6e 61 6c 20 64 61 74 61 62  n external datab
62c0: 61 73 65 0a 2a 2a 20 63 6f 6e 6e 65 63 74 69 6f  ase.** connectio
62d0: 6e 2e 20 49 6e 20 74 68 69 73 20 63 61 73 65 20  n. In this case 
62e0: 74 68 65 72 65 20 69 73 20 6e 6f 20 77 61 79 20  there is no way 
62f0: 6f 66 20 6b 6e 6f 77 69 6e 67 20 77 68 69 63 68  of knowing which
6300: 20 6f 66 20 74 68 65 0a 2a 2a 20 70 61 67 65 73   of the.** pages
6310: 20 74 68 61 74 20 68 61 76 65 20 62 65 65 6e 20   that have been 
6320: 63 6f 70 69 65 64 20 69 6e 74 6f 20 74 68 65 20  copied into the 
6330: 64 65 73 74 69 6e 61 74 69 6f 6e 20 64 61 74 61  destination data
6340: 62 61 73 65 20 61 72 65 20 73 74 69 6c 6c 20 0a  base are still .
6350: 2a 2a 20 76 61 6c 69 64 20 61 6e 64 20 77 68 69  ** valid and whi
6360: 63 68 20 61 72 65 20 6e 6f 74 2c 20 73 6f 20 74  ch are not, so t
6370: 68 65 20 65 6e 74 69 72 65 20 70 72 6f 63 65 73  he entire proces
6380: 73 20 6e 65 65 64 73 20 74 6f 20 62 65 20 72 65  s needs to be re
6390: 73 74 61 72 74 65 64 2e 0a 2a 2a 0a 2a 2a 20 49  started..**.** I
63a0: 74 20 69 73 20 61 73 73 75 6d 65 64 20 74 68 61  t is assumed tha
63b0: 74 20 74 68 65 20 6d 75 74 65 78 20 61 73 73 6f  t the mutex asso
63c0: 63 69 61 74 65 64 20 77 69 74 68 20 74 68 65 20  ciated with the 
63d0: 42 74 53 68 61 72 65 64 20 6f 62 6a 65 63 74 0a  BtShared object.
63e0: 2a 2a 20 63 6f 72 72 65 73 70 6f 6e 64 69 6e 67  ** corresponding
63f0: 20 74 6f 20 74 68 65 20 73 6f 75 72 63 65 20 64   to the source d
6400: 61 74 61 62 61 73 65 20 69 73 20 68 65 6c 64 20  atabase is held 
6410: 77 68 65 6e 20 74 68 69 73 20 66 75 6e 63 74 69  when this functi
6420: 6f 6e 20 69 73 0a 2a 2a 20 63 61 6c 6c 65 64 2e  on is.** called.
6430: 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c 69 74 65 33  .*/.void sqlite3
6440: 42 61 63 6b 75 70 52 65 73 74 61 72 74 28 73 71  BackupRestart(sq
6450: 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 42  lite3_backup *pB
6460: 61 63 6b 75 70 29 7b 0a 20 20 73 71 6c 69 74 65  ackup){.  sqlite
6470: 33 5f 62 61 63 6b 75 70 20 2a 70 3b 20 20 20 20  3_backup *p;    
6480: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f                 /
6490: 2a 20 49 74 65 72 61 74 6f 72 20 76 61 72 69 61  * Iterator varia
64a0: 62 6c 65 20 2a 2f 0a 20 20 66 6f 72 28 70 3d 70  ble */.  for(p=p
64b0: 42 61 63 6b 75 70 3b 20 70 3b 20 70 3d 70 2d 3e  Backup; p; p=p->
64c0: 70 4e 65 78 74 29 7b 0a 20 20 20 20 61 73 73 65  pNext){.    asse
64d0: 72 74 28 20 73 71 6c 69 74 65 33 5f 6d 75 74 65  rt( sqlite3_mute
64e0: 78 5f 68 65 6c 64 28 70 2d 3e 70 53 72 63 2d 3e  x_held(p->pSrc->
64f0: 70 42 74 2d 3e 6d 75 74 65 78 29 20 29 3b 0a 20  pBt->mutex) );. 
6500: 20 20 20 70 2d 3e 69 4e 65 78 74 20 3d 20 31 3b     p->iNext = 1;
6510: 0a 20 20 7d 0a 7d 0a 0a 23 69 66 6e 64 65 66 20  .  }.}..#ifndef 
6520: 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 56 41 43 55  SQLITE_OMIT_VACU
6530: 55 4d 0a 2f 2a 0a 2a 2a 20 43 6f 70 79 20 74 68  UM./*.** Copy th
6540: 65 20 63 6f 6d 70 6c 65 74 65 20 63 6f 6e 74 65  e complete conte
6550: 6e 74 20 6f 66 20 70 42 74 46 72 6f 6d 20 69 6e  nt of pBtFrom in
6560: 74 6f 20 70 42 74 54 6f 2e 20 20 41 20 74 72 61  to pBtTo.  A tra
6570: 6e 73 61 63 74 69 6f 6e 0a 2a 2a 20 6d 75 73 74  nsaction.** must
6580: 20 62 65 20 61 63 74 69 76 65 20 66 6f 72 20 62   be active for b
6590: 6f 74 68 20 66 69 6c 65 73 2e 0a 2a 2a 0a 2a 2a  oth files..**.**
65a0: 20 54 68 65 20 73 69 7a 65 20 6f 66 20 66 69 6c   The size of fil
65b0: 65 20 70 54 6f 20 6d 61 79 20 62 65 20 72 65 64  e pTo may be red
65c0: 75 63 65 64 20 62 79 20 74 68 69 73 20 6f 70 65  uced by this ope
65d0: 72 61 74 69 6f 6e 2e 20 49 66 20 61 6e 79 74 68  ration. If anyth
65e0: 69 6e 67 20 0a 2a 2a 20 67 6f 65 73 20 77 72 6f  ing .** goes wro
65f0: 6e 67 2c 20 74 68 65 20 74 72 61 6e 73 61 63 74  ng, the transact
6600: 69 6f 6e 20 6f 6e 20 70 54 6f 20 69 73 20 72 6f  ion on pTo is ro
6610: 6c 6c 65 64 20 62 61 63 6b 2e 20 49 66 20 73 75  lled back. If su
6620: 63 63 65 73 73 66 75 6c 2c 20 74 68 65 20 0a 2a  ccessful, the .*
6630: 2a 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 69 73  * transaction is
6640: 20 63 6f 6d 6d 69 74 74 65 64 20 62 65 66 6f 72   committed befor
6650: 65 20 72 65 74 75 72 6e 69 6e 67 2e 0a 2a 2f 0a  e returning..*/.
6660: 69 6e 74 20 73 71 6c 69 74 65 33 42 74 72 65 65  int sqlite3Btree
6670: 43 6f 70 79 46 69 6c 65 28 42 74 72 65 65 20 2a  CopyFile(Btree *
6680: 70 54 6f 2c 20 42 74 72 65 65 20 2a 70 46 72 6f  pTo, Btree *pFro
6690: 6d 29 7b 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20  m){.  int rc;.  
66a0: 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70 46  sqlite3_file *pF
66b0: 64 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  d;              
66c0: 2f 2a 20 46 69 6c 65 20 64 65 73 63 72 69 70 74  /* File descript
66d0: 6f 72 20 66 6f 72 20 64 61 74 61 62 61 73 65 20  or for database 
66e0: 70 54 6f 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33  pTo */.  sqlite3
66f0: 5f 62 61 63 6b 75 70 20 62 3b 0a 20 20 73 71 6c  _backup b;.  sql
6700: 69 74 65 33 42 74 72 65 65 45 6e 74 65 72 28 70  ite3BtreeEnter(p
6710: 54 6f 29 3b 0a 20 20 73 71 6c 69 74 65 33 42 74  To);.  sqlite3Bt
6720: 72 65 65 45 6e 74 65 72 28 70 46 72 6f 6d 29 3b  reeEnter(pFrom);
6730: 0a 0a 20 20 61 73 73 65 72 74 28 20 73 71 6c 69  ..  assert( sqli
6740: 74 65 33 42 74 72 65 65 49 73 49 6e 54 72 61 6e  te3BtreeIsInTran
6750: 73 28 70 54 6f 29 20 29 3b 0a 20 20 70 46 64 20  s(pTo) );.  pFd 
6760: 3d 20 73 71 6c 69 74 65 33 50 61 67 65 72 46 69  = sqlite3PagerFi
6770: 6c 65 28 73 71 6c 69 74 65 33 42 74 72 65 65 50  le(sqlite3BtreeP
6780: 61 67 65 72 28 70 54 6f 29 29 3b 0a 20 20 69 66  ager(pTo));.  if
6790: 28 20 70 46 64 2d 3e 70 4d 65 74 68 6f 64 73 20  ( pFd->pMethods 
67a0: 29 7b 0a 20 20 20 20 69 36 34 20 6e 42 79 74 65  ){.    i64 nByte
67b0: 20 3d 20 73 71 6c 69 74 65 33 42 74 72 65 65 47   = sqlite3BtreeG
67c0: 65 74 50 61 67 65 53 69 7a 65 28 70 46 72 6f 6d  etPageSize(pFrom
67d0: 29 2a 28 69 36 34 29 73 71 6c 69 74 65 33 42 74  )*(i64)sqlite3Bt
67e0: 72 65 65 4c 61 73 74 50 61 67 65 28 70 46 72 6f  reeLastPage(pFro
67f0: 6d 29 3b 0a 20 20 20 20 72 63 20 3d 20 73 71 6c  m);.    rc = sql
6800: 69 74 65 33 4f 73 46 69 6c 65 43 6f 6e 74 72 6f  ite3OsFileContro
6810: 6c 28 70 46 64 2c 20 53 51 4c 49 54 45 5f 46 43  l(pFd, SQLITE_FC
6820: 4e 54 4c 5f 4f 56 45 52 57 52 49 54 45 2c 20 26  NTL_OVERWRITE, &
6830: 6e 42 79 74 65 29 3b 0a 20 20 20 20 69 66 28 20  nByte);.    if( 
6840: 72 63 3d 3d 53 51 4c 49 54 45 5f 4e 4f 54 46 4f  rc==SQLITE_NOTFO
6850: 55 4e 44 20 29 20 72 63 20 3d 20 53 51 4c 49 54  UND ) rc = SQLIT
6860: 45 5f 4f 4b 3b 0a 20 20 20 20 69 66 28 20 72 63  E_OK;.    if( rc
6870: 20 29 20 67 6f 74 6f 20 63 6f 70 79 5f 66 69 6e   ) goto copy_fin
6880: 69 73 68 65 64 3b 0a 20 20 7d 0a 0a 20 20 2f 2a  ished;.  }..  /*
6890: 20 53 65 74 20 75 70 20 61 6e 20 73 71 6c 69 74   Set up an sqlit
68a0: 65 33 5f 62 61 63 6b 75 70 20 6f 62 6a 65 63 74  e3_backup object
68b0: 2e 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70  . sqlite3_backup
68c0: 2e 70 44 65 73 74 44 62 20 6d 75 73 74 20 62 65  .pDestDb must be
68d0: 20 73 65 74 0a 20 20 2a 2a 20 74 6f 20 30 2e 20   set.  ** to 0. 
68e0: 54 68 69 73 20 69 73 20 75 73 65 64 20 62 79 20  This is used by 
68f0: 74 68 65 20 69 6d 70 6c 65 6d 65 6e 74 61 74 69  the implementati
6900: 6f 6e 73 20 6f 66 20 73 71 6c 69 74 65 33 5f 62  ons of sqlite3_b
6910: 61 63 6b 75 70 5f 73 74 65 70 28 29 0a 20 20 2a  ackup_step().  *
6920: 2a 20 61 6e 64 20 73 71 6c 69 74 65 33 5f 62 61  * and sqlite3_ba
6930: 63 6b 75 70 5f 66 69 6e 69 73 68 28 29 20 74 6f  ckup_finish() to
6940: 20 64 65 74 65 63 74 20 74 68 61 74 20 74 68 65   detect that the
6950: 79 20 61 72 65 20 62 65 69 6e 67 20 63 61 6c 6c  y are being call
6960: 65 64 0a 20 20 2a 2a 20 66 72 6f 6d 20 74 68 69  ed.  ** from thi
6970: 73 20 66 75 6e 63 74 69 6f 6e 2c 20 6e 6f 74 20  s function, not 
6980: 64 69 72 65 63 74 6c 79 20 62 79 20 74 68 65 20  directly by the 
6990: 75 73 65 72 2e 0a 20 20 2a 2f 0a 20 20 6d 65 6d  user..  */.  mem
69a0: 73 65 74 28 26 62 2c 20 30 2c 20 73 69 7a 65 6f  set(&b, 0, sizeo
69b0: 66 28 62 29 29 3b 0a 20 20 62 2e 70 53 72 63 44  f(b));.  b.pSrcD
69c0: 62 20 3d 20 70 46 72 6f 6d 2d 3e 64 62 3b 0a 20  b = pFrom->db;. 
69d0: 20 62 2e 70 53 72 63 20 3d 20 70 46 72 6f 6d 3b   b.pSrc = pFrom;
69e0: 0a 20 20 62 2e 70 44 65 73 74 20 3d 20 70 54 6f  .  b.pDest = pTo
69f0: 3b 0a 20 20 62 2e 69 4e 65 78 74 20 3d 20 31 3b  ;.  b.iNext = 1;
6a00: 0a 0a 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f  ..#ifdef SQLITE_
6a10: 48 41 53 5f 43 4f 44 45 43 0a 20 20 73 71 6c 69  HAS_CODEC.  sqli
6a20: 74 65 33 50 61 67 65 72 41 6c 69 67 6e 52 65 73  te3PagerAlignRes
6a30: 65 72 76 65 28 73 71 6c 69 74 65 33 42 74 72 65  erve(sqlite3Btre
6a40: 65 50 61 67 65 72 28 70 54 6f 29 2c 20 73 71 6c  ePager(pTo), sql
6a50: 69 74 65 33 42 74 72 65 65 50 61 67 65 72 28 70  ite3BtreePager(p
6a60: 46 72 6f 6d 29 29 3b 0a 23 65 6e 64 69 66 0a 0a  From));.#endif..
6a70: 20 20 2f 2a 20 30 78 37 46 46 46 46 46 46 46 20    /* 0x7FFFFFFF 
6a80: 69 73 20 74 68 65 20 68 61 72 64 20 6c 69 6d 69  is the hard limi
6a90: 74 20 66 6f 72 20 74 68 65 20 6e 75 6d 62 65 72  t for the number
6aa0: 20 6f 66 20 70 61 67 65 73 20 69 6e 20 61 20 64   of pages in a d
6ab0: 61 74 61 62 61 73 65 0a 20 20 2a 2a 20 66 69 6c  atabase.  ** fil
6ac0: 65 2e 20 42 79 20 70 61 73 73 69 6e 67 20 74 68  e. By passing th
6ad0: 69 73 20 61 73 20 74 68 65 20 6e 75 6d 62 65 72  is as the number
6ae0: 20 6f 66 20 70 61 67 65 73 20 74 6f 20 63 6f 70   of pages to cop
6af0: 79 20 74 6f 0a 20 20 2a 2a 20 73 71 6c 69 74 65  y to.  ** sqlite
6b00: 33 5f 62 61 63 6b 75 70 5f 73 74 65 70 28 29 2c  3_backup_step(),
6b10: 20 77 65 20 63 61 6e 20 67 75 61 72 61 6e 74 65   we can guarante
6b20: 65 20 74 68 61 74 20 74 68 65 20 63 6f 70 79 20  e that the copy 
6b30: 66 69 6e 69 73 68 65 73 20 0a 20 20 2a 2a 20 77  finishes .  ** w
6b40: 69 74 68 69 6e 20 61 20 73 69 6e 67 6c 65 20 63  ithin a single c
6b50: 61 6c 6c 20 28 75 6e 6c 65 73 73 20 61 6e 20 65  all (unless an e
6b60: 72 72 6f 72 20 6f 63 63 75 72 73 29 2e 20 54 68  rror occurs). Th
6b70: 65 20 61 73 73 65 72 74 28 29 20 73 74 61 74 65  e assert() state
6b80: 6d 65 6e 74 0a 20 20 2a 2a 20 63 68 65 63 6b 73  ment.  ** checks
6b90: 20 74 68 69 73 20 61 73 73 75 6d 70 74 69 6f 6e   this assumption
6ba0: 20 2d 20 28 70 2d 3e 72 63 29 20 73 68 6f 75 6c   - (p->rc) shoul
6bb0: 64 20 62 65 20 73 65 74 20 74 6f 20 65 69 74 68  d be set to eith
6bc0: 65 72 20 53 51 4c 49 54 45 5f 44 4f 4e 45 20 0a  er SQLITE_DONE .
6bd0: 20 20 2a 2a 20 6f 72 20 61 6e 20 65 72 72 6f 72    ** or an error
6be0: 20 63 6f 64 65 2e 0a 20 20 2a 2f 0a 20 20 73 71   code..  */.  sq
6bf0: 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 73 74 65  lite3_backup_ste
6c00: 70 28 26 62 2c 20 30 78 37 46 46 46 46 46 46 46  p(&b, 0x7FFFFFFF
6c10: 29 3b 0a 20 20 61 73 73 65 72 74 28 20 62 2e 72  );.  assert( b.r
6c20: 63 21 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 3b 0a  c!=SQLITE_OK );.
6c30: 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 5f 62    rc = sqlite3_b
6c40: 61 63 6b 75 70 5f 66 69 6e 69 73 68 28 26 62 29  ackup_finish(&b)
6c50: 3b 0a 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49  ;.  if( rc==SQLI
6c60: 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 70 54 6f  TE_OK ){.    pTo
6c70: 2d 3e 70 42 74 2d 3e 62 74 73 46 6c 61 67 73 20  ->pBt->btsFlags 
6c80: 26 3d 20 7e 42 54 53 5f 50 41 47 45 53 49 5a 45  &= ~BTS_PAGESIZE
6c90: 5f 46 49 58 45 44 3b 0a 20 20 7d 65 6c 73 65 7b  _FIXED;.  }else{
6ca0: 0a 20 20 20 20 73 71 6c 69 74 65 33 50 61 67 65  .    sqlite3Page
6cb0: 72 43 6c 65 61 72 43 61 63 68 65 28 73 71 6c 69  rClearCache(sqli
6cc0: 74 65 33 42 74 72 65 65 50 61 67 65 72 28 62 2e  te3BtreePager(b.
6cd0: 70 44 65 73 74 29 29 3b 0a 20 20 7d 0a 0a 20 20  pDest));.  }..  
6ce0: 61 73 73 65 72 74 28 20 73 71 6c 69 74 65 33 42  assert( sqlite3B
6cf0: 74 72 65 65 49 73 49 6e 54 72 61 6e 73 28 70 54  treeIsInTrans(pT
6d00: 6f 29 3d 3d 30 20 29 3b 0a 63 6f 70 79 5f 66 69  o)==0 );.copy_fi
6d10: 6e 69 73 68 65 64 3a 0a 20 20 73 71 6c 69 74 65  nished:.  sqlite
6d20: 33 42 74 72 65 65 4c 65 61 76 65 28 70 46 72 6f  3BtreeLeave(pFro
6d30: 6d 29 3b 0a 20 20 73 71 6c 69 74 65 33 42 74 72  m);.  sqlite3Btr
6d40: 65 65 4c 65 61 76 65 28 70 54 6f 29 3b 0a 20 20  eeLeave(pTo);.  
6d50: 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 23 65 6e  return rc;.}.#en
6d60: 64 69 66 20 2f 2a 20 53 51 4c 49 54 45 5f 4f 4d  dif /* SQLITE_OM
6d70: 49 54 5f 56 41 43 55 55 4d 20 2a 2f 0a           IT_VACUUM */.