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

Artifact 1809a7caa2504233bdddd12f5018422421789537:


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 28 70 45 72 72 6f 72 44 62 2c 20 53 51  ror(pErrorDb, SQ
0e50: 4c 49 54 45 5f 4e 4f 4d 45 4d 2c 20 22 6f 75 74  LITE_NOMEM, "out
0e60: 20 6f 66 20 6d 65 6d 6f 72 79 22 29 3b 0a 20 20   of memory");.  
0e70: 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f      rc = SQLITE_
0e80: 4e 4f 4d 45 4d 3b 0a 20 20 20 20 7d 65 6c 73 65  NOMEM;.    }else
0e90: 7b 0a 20 20 20 20 20 20 70 50 61 72 73 65 2d 3e  {.      pParse->
0ea0: 64 62 20 3d 20 70 44 62 3b 0a 20 20 20 20 20 20  db = pDb;.      
0eb0: 69 66 28 20 73 71 6c 69 74 65 33 4f 70 65 6e 54  if( sqlite3OpenT
0ec0: 65 6d 70 44 61 74 61 62 61 73 65 28 70 50 61 72  empDatabase(pPar
0ed0: 73 65 29 20 29 7b 0a 20 20 20 20 20 20 20 20 73  se) ){.        s
0ee0: 71 6c 69 74 65 33 45 72 72 6f 72 28 70 45 72 72  qlite3Error(pErr
0ef0: 6f 72 44 62 2c 20 70 50 61 72 73 65 2d 3e 72 63  orDb, pParse->rc
0f00: 2c 20 22 25 73 22 2c 20 70 50 61 72 73 65 2d 3e  , "%s", pParse->
0f10: 7a 45 72 72 4d 73 67 29 3b 0a 20 20 20 20 20 20  zErrMsg);.      
0f20: 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 45 52    rc = SQLITE_ER
0f30: 52 4f 52 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20  ROR;.      }.   
0f40: 20 20 20 73 71 6c 69 74 65 33 44 62 46 72 65 65     sqlite3DbFree
0f50: 28 70 45 72 72 6f 72 44 62 2c 20 70 50 61 72 73  (pErrorDb, pPars
0f60: 65 2d 3e 7a 45 72 72 4d 73 67 29 3b 0a 20 20 20  e->zErrMsg);.   
0f70: 20 20 20 73 71 6c 69 74 65 33 50 61 72 73 65 72     sqlite3Parser
0f80: 52 65 73 65 74 28 70 50 61 72 73 65 29 3b 0a 20  Reset(pParse);. 
0f90: 20 20 20 20 20 73 71 6c 69 74 65 33 53 74 61 63       sqlite3Stac
0fa0: 6b 46 72 65 65 28 70 45 72 72 6f 72 44 62 2c 20  kFree(pErrorDb, 
0fb0: 70 50 61 72 73 65 29 3b 0a 20 20 20 20 7d 0a 20  pParse);.    }. 
0fc0: 20 20 20 69 66 28 20 72 63 20 29 7b 0a 20 20 20     if( rc ){.   
0fd0: 20 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 20     return 0;.   
0fe0: 20 7d 0a 20 20 7d 0a 0a 20 20 69 66 28 20 69 3c   }.  }..  if( i<
0ff0: 30 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33  0 ){.    sqlite3
1000: 45 72 72 6f 72 28 70 45 72 72 6f 72 44 62 2c 20  Error(pErrorDb, 
1010: 53 51 4c 49 54 45 5f 45 52 52 4f 52 2c 20 22 75  SQLITE_ERROR, "u
1020: 6e 6b 6e 6f 77 6e 20 64 61 74 61 62 61 73 65 20  nknown database 
1030: 25 73 22 2c 20 7a 44 62 29 3b 0a 20 20 20 20 72  %s", zDb);.    r
1040: 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 0a 20 20  eturn 0;.  }..  
1050: 72 65 74 75 72 6e 20 70 44 62 2d 3e 61 44 62 5b  return pDb->aDb[
1060: 69 5d 2e 70 42 74 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  i].pBt;.}../*.**
1070: 20 41 74 74 65 6d 70 74 20 74 6f 20 73 65 74 20   Attempt to set 
1080: 74 68 65 20 70 61 67 65 20 73 69 7a 65 20 6f 66  the page size of
1090: 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e   the destination
10a0: 20 74 6f 20 6d 61 74 63 68 20 74 68 65 20 70 61   to match the pa
10b0: 67 65 20 73 69 7a 65 0a 2a 2a 20 6f 66 20 74 68  ge size.** of th
10c0: 65 20 73 6f 75 72 63 65 2e 0a 2a 2f 0a 73 74 61  e source..*/.sta
10d0: 74 69 63 20 69 6e 74 20 73 65 74 44 65 73 74 50  tic int setDestP
10e0: 67 73 7a 28 73 71 6c 69 74 65 33 5f 62 61 63 6b  gsz(sqlite3_back
10f0: 75 70 20 2a 70 29 7b 0a 20 20 69 6e 74 20 72 63  up *p){.  int rc
1100: 3b 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33  ;.  rc = sqlite3
1110: 42 74 72 65 65 53 65 74 50 61 67 65 53 69 7a 65  BtreeSetPageSize
1120: 28 70 2d 3e 70 44 65 73 74 2c 73 71 6c 69 74 65  (p->pDest,sqlite
1130: 33 42 74 72 65 65 47 65 74 50 61 67 65 53 69 7a  3BtreeGetPageSiz
1140: 65 28 70 2d 3e 70 53 72 63 29 2c 2d 31 2c 30 29  e(p->pSrc),-1,0)
1150: 3b 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d  ;.  return rc;.}
1160: 0a 0a 2f 2a 0a 2a 2a 20 43 72 65 61 74 65 20 61  ../*.** Create a
1170: 6e 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70  n sqlite3_backup
1180: 20 70 72 6f 63 65 73 73 20 74 6f 20 63 6f 70 79   process to copy
1190: 20 74 68 65 20 63 6f 6e 74 65 6e 74 73 20 6f 66   the contents of
11a0: 20 7a 53 72 63 44 62 20 66 72 6f 6d 0a 2a 2a 20   zSrcDb from.** 
11b0: 63 6f 6e 6e 65 63 74 69 6f 6e 20 68 61 6e 64 6c  connection handl
11c0: 65 20 70 53 72 63 44 62 20 74 6f 20 7a 44 65 73  e pSrcDb to zDes
11d0: 74 44 62 20 69 6e 20 70 44 65 73 74 44 62 2e 20  tDb in pDestDb. 
11e0: 49 66 20 73 75 63 63 65 73 73 66 75 6c 2c 20 72  If successful, r
11f0: 65 74 75 72 6e 0a 2a 2a 20 61 20 70 6f 69 6e 74  eturn.** a point
1200: 65 72 20 74 6f 20 74 68 65 20 6e 65 77 20 73 71  er to the new sq
1210: 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 6f 62 6a  lite3_backup obj
1220: 65 63 74 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 61 6e  ect..**.** If an
1230: 20 65 72 72 6f 72 20 6f 63 63 75 72 73 2c 20 4e   error occurs, N
1240: 55 4c 4c 20 69 73 20 72 65 74 75 72 6e 65 64 20  ULL is returned 
1250: 61 6e 64 20 61 6e 20 65 72 72 6f 72 20 63 6f 64  and an error cod
1260: 65 20 61 6e 64 20 65 72 72 6f 72 20 6d 65 73 73  e and error mess
1270: 61 67 65 0a 2a 2a 20 73 74 6f 72 65 64 20 69 6e  age.** stored in
1280: 20 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c 65   database handle
1290: 20 70 44 65 73 74 44 62 2e 0a 2a 2f 0a 73 71 6c   pDestDb..*/.sql
12a0: 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 73 71 6c  ite3_backup *sql
12b0: 69 74 65 33 5f 62 61 63 6b 75 70 5f 69 6e 69 74  ite3_backup_init
12c0: 28 0a 20 20 73 71 6c 69 74 65 33 2a 20 70 44 65  (.  sqlite3* pDe
12d0: 73 74 44 62 2c 20 20 20 20 20 20 20 20 20 20 20  stDb,           
12e0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 44 61 74            /* Dat
12f0: 61 62 61 73 65 20 74 6f 20 77 72 69 74 65 20 74  abase to write t
1300: 6f 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61  o */.  const cha
1310: 72 20 2a 7a 44 65 73 74 44 62 2c 20 20 20 20 20  r *zDestDb,     
1320: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
1330: 4e 61 6d 65 20 6f 66 20 64 61 74 61 62 61 73 65  Name of database
1340: 20 77 69 74 68 69 6e 20 70 44 65 73 74 44 62 20   within pDestDb 
1350: 2a 2f 0a 20 20 73 71 6c 69 74 65 33 2a 20 70 53  */.  sqlite3* pS
1360: 72 63 44 62 2c 20 20 20 20 20 20 20 20 20 20 20  rcDb,           
1370: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 44 61             /* Da
1380: 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f  tabase connectio
1390: 6e 20 74 6f 20 72 65 61 64 20 66 72 6f 6d 20 2a  n to read from *
13a0: 2f 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  /.  const char *
13b0: 7a 53 72 63 44 62 20 20 20 20 20 20 20 20 20 20  zSrcDb          
13c0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 4e 61 6d            /* Nam
13d0: 65 20 6f 66 20 64 61 74 61 62 61 73 65 20 77 69  e of database wi
13e0: 74 68 69 6e 20 70 53 72 63 44 62 20 2a 2f 0a 29  thin pSrcDb */.)
13f0: 7b 0a 20 20 73 71 6c 69 74 65 33 5f 62 61 63 6b  {.  sqlite3_back
1400: 75 70 20 2a 70 3b 20 20 20 20 20 20 20 20 20 20  up *p;          
1410: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 56 61 6c            /* Val
1420: 75 65 20 74 6f 20 72 65 74 75 72 6e 20 2a 2f 0a  ue to return */.
1430: 0a 20 20 2f 2a 20 4c 6f 63 6b 20 74 68 65 20 73  .  /* Lock the s
1440: 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 20 68  ource database h
1450: 61 6e 64 6c 65 2e 20 54 68 65 20 64 65 73 74 69  andle. The desti
1460: 6e 61 74 69 6f 6e 20 64 61 74 61 62 61 73 65 0a  nation database.
1470: 20 20 2a 2a 20 68 61 6e 64 6c 65 20 69 73 20 6e    ** handle is n
1480: 6f 74 20 6c 6f 63 6b 65 64 20 69 6e 20 74 68 69  ot locked in thi
1490: 73 20 72 6f 75 74 69 6e 65 2c 20 62 75 74 20 69  s routine, but i
14a0: 74 20 69 73 20 6c 6f 63 6b 65 64 20 69 6e 0a 20  t is locked in. 
14b0: 20 2a 2a 20 73 71 6c 69 74 65 33 5f 62 61 63 6b   ** sqlite3_back
14c0: 75 70 5f 73 74 65 70 28 29 2e 20 54 68 65 20 75  up_step(). The u
14d0: 73 65 72 20 69 73 20 72 65 71 75 69 72 65 64 20  ser is required 
14e0: 74 6f 20 65 6e 73 75 72 65 20 74 68 61 74 20 6e  to ensure that n
14f0: 6f 0a 20 20 2a 2a 20 6f 74 68 65 72 20 74 68 72  o.  ** other thr
1500: 65 61 64 20 61 63 63 65 73 73 65 73 20 74 68 65  ead accesses the
1510: 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 68 61 6e   destination han
1520: 64 6c 65 20 66 6f 72 20 74 68 65 20 64 75 72 61  dle for the dura
1530: 74 69 6f 6e 0a 20 20 2a 2a 20 6f 66 20 74 68 65  tion.  ** of the
1540: 20 62 61 63 6b 75 70 20 6f 70 65 72 61 74 69 6f   backup operatio
1550: 6e 2e 20 20 41 6e 79 20 61 74 74 65 6d 70 74 20  n.  Any attempt 
1560: 74 6f 20 75 73 65 20 74 68 65 20 64 65 73 74 69  to use the desti
1570: 6e 61 74 69 6f 6e 0a 20 20 2a 2a 20 64 61 74 61  nation.  ** data
1580: 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20  base connection 
1590: 77 68 69 6c 65 20 61 20 62 61 63 6b 75 70 20 69  while a backup i
15a0: 73 20 69 6e 20 70 72 6f 67 72 65 73 73 20 6d 61  s in progress ma
15b0: 79 20 63 61 75 73 65 0a 20 20 2a 2a 20 61 20 6d  y cause.  ** a m
15c0: 61 6c 66 75 6e 63 74 69 6f 6e 20 6f 72 20 61 20  alfunction or a 
15d0: 64 65 61 64 6c 6f 63 6b 2e 0a 20 20 2a 2f 0a 20  deadlock..  */. 
15e0: 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65   sqlite3_mutex_e
15f0: 6e 74 65 72 28 70 53 72 63 44 62 2d 3e 6d 75 74  nter(pSrcDb->mut
1600: 65 78 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 6d  ex);.  sqlite3_m
1610: 75 74 65 78 5f 65 6e 74 65 72 28 70 44 65 73 74  utex_enter(pDest
1620: 44 62 2d 3e 6d 75 74 65 78 29 3b 0a 0a 20 20 69  Db->mutex);..  i
1630: 66 28 20 70 53 72 63 44 62 3d 3d 70 44 65 73 74  f( pSrcDb==pDest
1640: 44 62 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65  Db ){.    sqlite
1650: 33 45 72 72 6f 72 28 0a 20 20 20 20 20 20 20 20  3Error(.        
1660: 70 44 65 73 74 44 62 2c 20 53 51 4c 49 54 45 5f  pDestDb, SQLITE_
1670: 45 52 52 4f 52 2c 20 22 73 6f 75 72 63 65 20 61  ERROR, "source a
1680: 6e 64 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 6d  nd destination m
1690: 75 73 74 20 62 65 20 64 69 73 74 69 6e 63 74 22  ust be distinct"
16a0: 0a 20 20 20 20 29 3b 0a 20 20 20 20 70 20 3d 20  .    );.    p = 
16b0: 30 3b 0a 20 20 7d 65 6c 73 65 20 7b 0a 20 20 20  0;.  }else {.   
16c0: 20 2f 2a 20 41 6c 6c 6f 63 61 74 65 20 73 70 61   /* Allocate spa
16d0: 63 65 20 66 6f 72 20 61 20 6e 65 77 20 73 71 6c  ce for a new sql
16e0: 69 74 65 33 5f 62 61 63 6b 75 70 20 6f 62 6a 65  ite3_backup obje
16f0: 63 74 2e 2e 2e 0a 20 20 20 20 2a 2a 20 45 56 49  ct....    ** EVI
1700: 44 45 4e 43 45 2d 4f 46 3a 20 52 2d 36 34 38 35  DENCE-OF: R-6485
1710: 32 2d 32 31 35 39 31 20 54 68 65 20 73 71 6c 69  2-21591 The sqli
1720: 74 65 33 5f 62 61 63 6b 75 70 20 6f 62 6a 65 63  te3_backup objec
1730: 74 20 69 73 20 63 72 65 61 74 65 64 20 62 79 20  t is created by 
1740: 61 0a 20 20 20 20 2a 2a 20 63 61 6c 6c 20 74 6f  a.    ** call to
1750: 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f   sqlite3_backup_
1760: 69 6e 69 74 28 29 20 61 6e 64 20 69 73 20 64 65  init() and is de
1770: 73 74 72 6f 79 65 64 20 62 79 20 61 20 63 61 6c  stroyed by a cal
1780: 6c 20 74 6f 0a 20 20 20 20 2a 2a 20 73 71 6c 69  l to.    ** sqli
1790: 74 65 33 5f 62 61 63 6b 75 70 5f 66 69 6e 69 73  te3_backup_finis
17a0: 68 28 29 2e 20 2a 2f 0a 20 20 20 20 70 20 3d 20  h(). */.    p = 
17b0: 28 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20  (sqlite3_backup 
17c0: 2a 29 73 71 6c 69 74 65 33 4d 61 6c 6c 6f 63 5a  *)sqlite3MallocZ
17d0: 65 72 6f 28 73 69 7a 65 6f 66 28 73 71 6c 69 74  ero(sizeof(sqlit
17e0: 65 33 5f 62 61 63 6b 75 70 29 29 3b 0a 20 20 20  e3_backup));.   
17f0: 20 69 66 28 20 21 70 20 29 7b 0a 20 20 20 20 20   if( !p ){.     
1800: 20 73 71 6c 69 74 65 33 45 72 72 6f 72 28 70 44   sqlite3Error(pD
1810: 65 73 74 44 62 2c 20 53 51 4c 49 54 45 5f 4e 4f  estDb, SQLITE_NO
1820: 4d 45 4d 2c 20 30 29 3b 0a 20 20 20 20 7d 0a 20  MEM, 0);.    }. 
1830: 20 7d 0a 0a 20 20 2f 2a 20 49 66 20 74 68 65 20   }..  /* If the 
1840: 61 6c 6c 6f 63 61 74 69 6f 6e 20 73 75 63 63 65  allocation succe
1850: 65 64 65 64 2c 20 70 6f 70 75 6c 61 74 65 20 74  eded, populate t
1860: 68 65 20 6e 65 77 20 6f 62 6a 65 63 74 2e 20 2a  he new object. *
1870: 2f 0a 20 20 69 66 28 20 70 20 29 7b 0a 20 20 20  /.  if( p ){.   
1880: 20 70 2d 3e 70 53 72 63 20 3d 20 66 69 6e 64 42   p->pSrc = findB
1890: 74 72 65 65 28 70 44 65 73 74 44 62 2c 20 70 53  tree(pDestDb, pS
18a0: 72 63 44 62 2c 20 7a 53 72 63 44 62 29 3b 0a 20  rcDb, zSrcDb);. 
18b0: 20 20 20 70 2d 3e 70 44 65 73 74 20 3d 20 66 69     p->pDest = fi
18c0: 6e 64 42 74 72 65 65 28 70 44 65 73 74 44 62 2c  ndBtree(pDestDb,
18d0: 20 70 44 65 73 74 44 62 2c 20 7a 44 65 73 74 44   pDestDb, zDestD
18e0: 62 29 3b 0a 20 20 20 20 70 2d 3e 70 44 65 73 74  b);.    p->pDest
18f0: 44 62 20 3d 20 70 44 65 73 74 44 62 3b 0a 20 20  Db = pDestDb;.  
1900: 20 20 70 2d 3e 70 53 72 63 44 62 20 3d 20 70 53    p->pSrcDb = pS
1910: 72 63 44 62 3b 0a 20 20 20 20 70 2d 3e 69 4e 65  rcDb;.    p->iNe
1920: 78 74 20 3d 20 31 3b 0a 20 20 20 20 70 2d 3e 69  xt = 1;.    p->i
1930: 73 41 74 74 61 63 68 65 64 20 3d 20 30 3b 0a 0a  sAttached = 0;..
1940: 20 20 20 20 69 66 28 20 30 3d 3d 70 2d 3e 70 53      if( 0==p->pS
1950: 72 63 20 7c 7c 20 30 3d 3d 70 2d 3e 70 44 65 73  rc || 0==p->pDes
1960: 74 20 7c 7c 20 73 65 74 44 65 73 74 50 67 73 7a  t || setDestPgsz
1970: 28 70 29 3d 3d 53 51 4c 49 54 45 5f 4e 4f 4d 45  (p)==SQLITE_NOME
1980: 4d 20 29 7b 0a 20 20 20 20 20 20 2f 2a 20 4f 6e  M ){.      /* On
1990: 65 20 28 6f 72 20 62 6f 74 68 29 20 6f 66 20 74  e (or both) of t
19a0: 68 65 20 6e 61 6d 65 64 20 64 61 74 61 62 61 73  he named databas
19b0: 65 73 20 64 69 64 20 6e 6f 74 20 65 78 69 73 74  es did not exist
19c0: 20 6f 72 20 61 6e 20 4f 4f 4d 0a 20 20 20 20 20   or an OOM.     
19d0: 20 2a 2a 20 65 72 72 6f 72 20 77 61 73 20 68 69   ** error was hi
19e0: 74 2e 20 20 54 68 65 20 65 72 72 6f 72 20 68 61  t.  The error ha
19f0: 73 20 61 6c 72 65 61 64 79 20 62 65 65 6e 20 77  s already been w
1a00: 72 69 74 74 65 6e 20 69 6e 74 6f 20 74 68 65 0a  ritten into the.
1a10: 20 20 20 20 20 20 2a 2a 20 70 44 65 73 74 44 62        ** pDestDb
1a20: 20 68 61 6e 64 6c 65 2e 20 20 41 6c 6c 20 74 68   handle.  All th
1a30: 61 74 20 69 73 20 6c 65 66 74 20 74 6f 20 64 6f  at is left to do
1a40: 20 68 65 72 65 20 69 73 20 66 72 65 65 20 74 68   here is free th
1a50: 65 0a 20 20 20 20 20 20 2a 2a 20 73 71 6c 69 74  e.      ** sqlit
1a60: 65 33 5f 62 61 63 6b 75 70 20 73 74 72 75 63 74  e3_backup struct
1a70: 75 72 65 2e 0a 20 20 20 20 20 20 2a 2f 0a 20 20  ure..      */.  
1a80: 20 20 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65      sqlite3_free
1a90: 28 70 29 3b 0a 20 20 20 20 20 20 70 20 3d 20 30  (p);.      p = 0
1aa0: 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 69 66  ;.    }.  }.  if
1ab0: 28 20 70 20 29 7b 0a 20 20 20 20 70 2d 3e 70 53  ( p ){.    p->pS
1ac0: 72 63 2d 3e 6e 42 61 63 6b 75 70 2b 2b 3b 0a 20  rc->nBackup++;. 
1ad0: 20 7d 0a 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75   }..  sqlite3_mu
1ae0: 74 65 78 5f 6c 65 61 76 65 28 70 44 65 73 74 44  tex_leave(pDestD
1af0: 62 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 73 71 6c  b->mutex);.  sql
1b00: 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65  ite3_mutex_leave
1b10: 28 70 53 72 63 44 62 2d 3e 6d 75 74 65 78 29 3b  (pSrcDb->mutex);
1b20: 0a 20 20 72 65 74 75 72 6e 20 70 3b 0a 7d 0a 0a  .  return p;.}..
1b30: 2f 2a 0a 2a 2a 20 41 72 67 75 6d 65 6e 74 20 72  /*.** Argument r
1b40: 63 20 69 73 20 61 6e 20 53 51 4c 69 74 65 20 65  c is an SQLite e
1b50: 72 72 6f 72 20 63 6f 64 65 2e 20 52 65 74 75 72  rror code. Retur
1b60: 6e 20 74 72 75 65 20 69 66 20 74 68 69 73 20 65  n true if this e
1b70: 72 72 6f 72 20 69 73 20 0a 2a 2a 20 63 6f 6e 73  rror is .** cons
1b80: 69 64 65 72 65 64 20 66 61 74 61 6c 20 69 66 20  idered fatal if 
1b90: 65 6e 63 6f 75 6e 74 65 72 65 64 20 64 75 72 69  encountered duri
1ba0: 6e 67 20 61 20 62 61 63 6b 75 70 20 6f 70 65 72  ng a backup oper
1bb0: 61 74 69 6f 6e 2e 20 41 6c 6c 20 65 72 72 6f 72  ation. All error
1bc0: 73 0a 2a 2a 20 61 72 65 20 63 6f 6e 73 69 64 65  s.** are conside
1bd0: 72 65 64 20 66 61 74 61 6c 20 65 78 63 65 70 74  red fatal except
1be0: 20 66 6f 72 20 53 51 4c 49 54 45 5f 42 55 53 59   for SQLITE_BUSY
1bf0: 20 61 6e 64 20 53 51 4c 49 54 45 5f 4c 4f 43 4b   and SQLITE_LOCK
1c00: 45 44 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69 6e  ED..*/.static in
1c10: 74 20 69 73 46 61 74 61 6c 45 72 72 6f 72 28 69  t isFatalError(i
1c20: 6e 74 20 72 63 29 7b 0a 20 20 72 65 74 75 72 6e  nt rc){.  return
1c30: 20 28 72 63 21 3d 53 51 4c 49 54 45 5f 4f 4b 20   (rc!=SQLITE_OK 
1c40: 26 26 20 72 63 21 3d 53 51 4c 49 54 45 5f 42 55  && rc!=SQLITE_BU
1c50: 53 59 20 26 26 20 41 4c 57 41 59 53 28 72 63 21  SY && ALWAYS(rc!
1c60: 3d 53 51 4c 49 54 45 5f 4c 4f 43 4b 45 44 29 29  =SQLITE_LOCKED))
1c70: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 50 61 72 61 6d  ;.}../*.** Param
1c80: 65 74 65 72 20 7a 53 72 63 44 61 74 61 20 70 6f  eter zSrcData po
1c90: 69 6e 74 73 20 74 6f 20 61 20 62 75 66 66 65 72  ints to a buffer
1ca0: 20 63 6f 6e 74 61 69 6e 69 6e 67 20 74 68 65 20   containing the 
1cb0: 64 61 74 61 20 66 6f 72 20 0a 2a 2a 20 70 61 67  data for .** pag
1cc0: 65 20 69 53 72 63 50 67 20 66 72 6f 6d 20 74 68  e iSrcPg from th
1cd0: 65 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73  e source databas
1ce0: 65 2e 20 43 6f 70 79 20 74 68 69 73 20 64 61 74  e. Copy this dat
1cf0: 61 20 69 6e 74 6f 20 74 68 65 20 0a 2a 2a 20 64  a into the .** d
1d00: 65 73 74 69 6e 61 74 69 6f 6e 20 64 61 74 61 62  estination datab
1d10: 61 73 65 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 69  ase..*/.static i
1d20: 6e 74 20 62 61 63 6b 75 70 4f 6e 65 50 61 67 65  nt backupOnePage
1d30: 28 0a 20 20 73 71 6c 69 74 65 33 5f 62 61 63 6b  (.  sqlite3_back
1d40: 75 70 20 2a 70 2c 20 20 20 20 20 20 20 20 20 20  up *p,          
1d50: 20 20 20 20 2f 2a 20 42 61 63 6b 75 70 20 68 61      /* Backup ha
1d60: 6e 64 6c 65 20 2a 2f 0a 20 20 50 67 6e 6f 20 69  ndle */.  Pgno i
1d70: 53 72 63 50 67 2c 20 20 20 20 20 20 20 20 20 20  SrcPg,          
1d80: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 53 6f 75            /* Sou
1d90: 72 63 65 20 64 61 74 61 62 61 73 65 20 70 61 67  rce database pag
1da0: 65 20 74 6f 20 62 61 63 6b 75 70 20 2a 2f 0a 20  e to backup */. 
1db0: 20 63 6f 6e 73 74 20 75 38 20 2a 7a 53 72 63 44   const u8 *zSrcD
1dc0: 61 74 61 2c 20 20 20 20 20 20 20 20 20 20 20 20  ata,            
1dd0: 20 2f 2a 20 53 6f 75 72 63 65 20 64 61 74 61 62   /* Source datab
1de0: 61 73 65 20 70 61 67 65 20 64 61 74 61 20 2a 2f  ase page data */
1df0: 0a 20 20 69 6e 74 20 62 55 70 64 61 74 65 20 20  .  int bUpdate  
1e00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1e10: 20 20 20 2f 2a 20 54 72 75 65 20 66 6f 72 20 61     /* True for a
1e20: 6e 20 75 70 64 61 74 65 2c 20 66 61 6c 73 65 20  n update, false 
1e30: 6f 74 68 65 72 77 69 73 65 20 2a 2f 0a 29 7b 0a  otherwise */.){.
1e40: 20 20 50 61 67 65 72 20 2a 20 63 6f 6e 73 74 20    Pager * const 
1e50: 70 44 65 73 74 50 61 67 65 72 20 3d 20 73 71 6c  pDestPager = sql
1e60: 69 74 65 33 42 74 72 65 65 50 61 67 65 72 28 70  ite3BtreePager(p
1e70: 2d 3e 70 44 65 73 74 29 3b 0a 20 20 63 6f 6e 73  ->pDest);.  cons
1e80: 74 20 69 6e 74 20 6e 53 72 63 50 67 73 7a 20 3d  t int nSrcPgsz =
1e90: 20 73 71 6c 69 74 65 33 42 74 72 65 65 47 65 74   sqlite3BtreeGet
1ea0: 50 61 67 65 53 69 7a 65 28 70 2d 3e 70 53 72 63  PageSize(p->pSrc
1eb0: 29 3b 0a 20 20 69 6e 74 20 6e 44 65 73 74 50 67  );.  int nDestPg
1ec0: 73 7a 20 3d 20 73 71 6c 69 74 65 33 42 74 72 65  sz = sqlite3Btre
1ed0: 65 47 65 74 50 61 67 65 53 69 7a 65 28 70 2d 3e  eGetPageSize(p->
1ee0: 70 44 65 73 74 29 3b 0a 20 20 63 6f 6e 73 74 20  pDest);.  const 
1ef0: 69 6e 74 20 6e 43 6f 70 79 20 3d 20 4d 49 4e 28  int nCopy = MIN(
1f00: 6e 53 72 63 50 67 73 7a 2c 20 6e 44 65 73 74 50  nSrcPgsz, nDestP
1f10: 67 73 7a 29 3b 0a 20 20 63 6f 6e 73 74 20 69 36  gsz);.  const i6
1f20: 34 20 69 45 6e 64 20 3d 20 28 69 36 34 29 69 53  4 iEnd = (i64)iS
1f30: 72 63 50 67 2a 28 69 36 34 29 6e 53 72 63 50 67  rcPg*(i64)nSrcPg
1f40: 73 7a 3b 0a 23 69 66 64 65 66 20 53 51 4c 49 54  sz;.#ifdef SQLIT
1f50: 45 5f 48 41 53 5f 43 4f 44 45 43 0a 20 20 2f 2a  E_HAS_CODEC.  /*
1f60: 20 55 73 65 20 42 74 72 65 65 47 65 74 52 65 73   Use BtreeGetRes
1f70: 65 72 76 65 4e 6f 4d 75 74 65 78 28 29 20 66 6f  erveNoMutex() fo
1f80: 72 20 74 68 65 20 73 6f 75 72 63 65 20 62 2d 74  r the source b-t
1f90: 72 65 65 2c 20 61 73 20 61 6c 74 68 6f 75 67 68  ree, as although
1fa0: 20 69 74 20 69 73 0a 20 20 2a 2a 20 67 75 61 72   it is.  ** guar
1fb0: 61 6e 74 65 65 64 20 74 68 61 74 20 74 68 65 20  anteed that the 
1fc0: 73 68 61 72 65 64 2d 6d 75 74 65 78 20 69 73 20  shared-mutex is 
1fd0: 68 65 6c 64 20 62 79 20 74 68 69 73 20 74 68 72  held by this thr
1fe0: 65 61 64 2c 20 68 61 6e 64 6c 65 0a 20 20 2a 2a  ead, handle.  **
1ff0: 20 70 2d 3e 70 53 72 63 20 6d 61 79 20 6e 6f 74   p->pSrc may not
2000: 20 61 63 74 75 61 6c 6c 79 20 62 65 20 74 68 65   actually be the
2010: 20 6f 77 6e 65 72 2e 20 20 2a 2f 0a 20 20 69 6e   owner.  */.  in
2020: 74 20 6e 53 72 63 52 65 73 65 72 76 65 20 3d 20  t nSrcReserve = 
2030: 73 71 6c 69 74 65 33 42 74 72 65 65 47 65 74 52  sqlite3BtreeGetR
2040: 65 73 65 72 76 65 4e 6f 4d 75 74 65 78 28 70 2d  eserveNoMutex(p-
2050: 3e 70 53 72 63 29 3b 0a 20 20 69 6e 74 20 6e 44  >pSrc);.  int nD
2060: 65 73 74 52 65 73 65 72 76 65 20 3d 20 73 71 6c  estReserve = sql
2070: 69 74 65 33 42 74 72 65 65 47 65 74 52 65 73 65  ite3BtreeGetRese
2080: 72 76 65 28 70 2d 3e 70 44 65 73 74 29 3b 0a 23  rve(p->pDest);.#
2090: 65 6e 64 69 66 0a 20 20 69 6e 74 20 72 63 20 3d  endif.  int rc =
20a0: 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 69 36   SQLITE_OK;.  i6
20b0: 34 20 69 4f 66 66 3b 0a 0a 20 20 61 73 73 65 72  4 iOff;..  asser
20c0: 74 28 20 73 71 6c 69 74 65 33 42 74 72 65 65 47  t( sqlite3BtreeG
20d0: 65 74 52 65 73 65 72 76 65 4e 6f 4d 75 74 65 78  etReserveNoMutex
20e0: 28 70 2d 3e 70 53 72 63 29 3e 3d 30 20 29 3b 0a  (p->pSrc)>=0 );.
20f0: 20 20 61 73 73 65 72 74 28 20 70 2d 3e 62 44 65    assert( p->bDe
2100: 73 74 4c 6f 63 6b 65 64 20 29 3b 0a 20 20 61 73  stLocked );.  as
2110: 73 65 72 74 28 20 21 69 73 46 61 74 61 6c 45 72  sert( !isFatalEr
2120: 72 6f 72 28 70 2d 3e 72 63 29 20 29 3b 0a 20 20  ror(p->rc) );.  
2130: 61 73 73 65 72 74 28 20 69 53 72 63 50 67 21 3d  assert( iSrcPg!=
2140: 50 45 4e 44 49 4e 47 5f 42 59 54 45 5f 50 41 47  PENDING_BYTE_PAG
2150: 45 28 70 2d 3e 70 53 72 63 2d 3e 70 42 74 29 20  E(p->pSrc->pBt) 
2160: 29 3b 0a 20 20 61 73 73 65 72 74 28 20 7a 53 72  );.  assert( zSr
2170: 63 44 61 74 61 20 29 3b 0a 0a 20 20 2f 2a 20 43  cData );..  /* C
2180: 61 74 63 68 20 74 68 65 20 63 61 73 65 20 77 68  atch the case wh
2190: 65 72 65 20 74 68 65 20 64 65 73 74 69 6e 61 74  ere the destinat
21a0: 69 6f 6e 20 69 73 20 61 6e 20 69 6e 2d 6d 65 6d  ion is an in-mem
21b0: 6f 72 79 20 64 61 74 61 62 61 73 65 20 61 6e 64  ory database and
21c0: 20 74 68 65 0a 20 20 2a 2a 20 70 61 67 65 20 73   the.  ** page s
21d0: 69 7a 65 73 20 6f 66 20 74 68 65 20 73 6f 75 72  izes of the sour
21e0: 63 65 20 61 6e 64 20 64 65 73 74 69 6e 61 74 69  ce and destinati
21f0: 6f 6e 20 64 69 66 66 65 72 2e 20 0a 20 20 2a 2f  on differ. .  */
2200: 0a 20 20 69 66 28 20 6e 53 72 63 50 67 73 7a 21  .  if( nSrcPgsz!
2210: 3d 6e 44 65 73 74 50 67 73 7a 20 26 26 20 73 71  =nDestPgsz && sq
2220: 6c 69 74 65 33 50 61 67 65 72 49 73 4d 65 6d 64  lite3PagerIsMemd
2230: 62 28 70 44 65 73 74 50 61 67 65 72 29 20 29 7b  b(pDestPager) ){
2240: 0a 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45  .    rc = SQLITE
2250: 5f 52 45 41 44 4f 4e 4c 59 3b 0a 20 20 7d 0a 0a  _READONLY;.  }..
2260: 23 69 66 64 65 66 20 53 51 4c 49 54 45 5f 48 41  #ifdef SQLITE_HA
2270: 53 5f 43 4f 44 45 43 0a 20 20 2f 2a 20 42 61 63  S_CODEC.  /* Bac
2280: 6b 75 70 20 69 73 20 6e 6f 74 20 70 6f 73 73 69  kup is not possi
2290: 62 6c 65 20 69 66 20 74 68 65 20 70 61 67 65 20  ble if the page 
22a0: 73 69 7a 65 20 6f 66 20 74 68 65 20 64 65 73 74  size of the dest
22b0: 69 6e 61 74 69 6f 6e 20 69 73 20 63 68 61 6e 67  ination is chang
22c0: 69 6e 67 0a 20 20 2a 2a 20 61 6e 64 20 61 20 63  ing.  ** and a c
22d0: 6f 64 65 63 20 69 73 20 69 6e 20 75 73 65 2e 0a  odec is in use..
22e0: 20 20 2a 2f 0a 20 20 69 66 28 20 6e 53 72 63 50    */.  if( nSrcP
22f0: 67 73 7a 21 3d 6e 44 65 73 74 50 67 73 7a 20 26  gsz!=nDestPgsz &
2300: 26 20 73 71 6c 69 74 65 33 50 61 67 65 72 47 65  & sqlite3PagerGe
2310: 74 43 6f 64 65 63 28 70 44 65 73 74 50 61 67 65  tCodec(pDestPage
2320: 72 29 21 3d 30 20 29 7b 0a 20 20 20 20 72 63 20  r)!=0 ){.    rc 
2330: 3d 20 53 51 4c 49 54 45 5f 52 45 41 44 4f 4e 4c  = SQLITE_READONL
2340: 59 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 42 61 63  Y;.  }..  /* Bac
2350: 6b 75 70 20 69 73 20 6e 6f 74 20 70 6f 73 73 69  kup is not possi
2360: 62 6c 65 20 69 66 20 74 68 65 20 6e 75 6d 62 65  ble if the numbe
2370: 72 20 6f 66 20 62 79 74 65 73 20 6f 66 20 72 65  r of bytes of re
2380: 73 65 72 76 65 20 73 70 61 63 65 20 64 69 66 66  serve space diff
2390: 65 72 0a 20 20 2a 2a 20 62 65 74 77 65 65 6e 20  er.  ** between 
23a0: 73 6f 75 72 63 65 20 61 6e 64 20 64 65 73 74 69  source and desti
23b0: 6e 61 74 69 6f 6e 2e 20 20 49 66 20 74 68 65 72  nation.  If ther
23c0: 65 20 69 73 20 61 20 64 69 66 66 65 72 65 6e 63  e is a differenc
23d0: 65 2c 20 74 72 79 20 74 6f 0a 20 20 2a 2a 20 66  e, try to.  ** f
23e0: 69 78 20 74 68 65 20 64 65 73 74 69 6e 61 74 69  ix the destinati
23f0: 6f 6e 20 74 6f 20 61 67 72 65 65 20 77 69 74 68  on to agree with
2400: 20 74 68 65 20 73 6f 75 72 63 65 2e 20 20 49 66   the source.  If
2410: 20 74 68 61 74 20 69 73 20 6e 6f 74 20 70 6f 73   that is not pos
2420: 73 69 62 6c 65 2c 0a 20 20 2a 2a 20 74 68 65 6e  sible,.  ** then
2430: 20 74 68 65 20 62 61 63 6b 75 70 20 63 61 6e 6e   the backup cann
2440: 6f 74 20 70 72 6f 63 65 65 64 2e 0a 20 20 2a 2f  ot proceed..  */
2450: 0a 20 20 69 66 28 20 6e 53 72 63 52 65 73 65 72  .  if( nSrcReser
2460: 76 65 21 3d 6e 44 65 73 74 52 65 73 65 72 76 65  ve!=nDestReserve
2470: 20 29 7b 0a 20 20 20 20 75 33 32 20 6e 65 77 50   ){.    u32 newP
2480: 67 73 7a 20 3d 20 6e 53 72 63 50 67 73 7a 3b 0a  gsz = nSrcPgsz;.
2490: 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33      rc = sqlite3
24a0: 50 61 67 65 72 53 65 74 50 61 67 65 73 69 7a 65  PagerSetPagesize
24b0: 28 70 44 65 73 74 50 61 67 65 72 2c 20 26 6e 65  (pDestPager, &ne
24c0: 77 50 67 73 7a 2c 20 6e 53 72 63 52 65 73 65 72  wPgsz, nSrcReser
24d0: 76 65 29 3b 0a 20 20 20 20 69 66 28 20 72 63 3d  ve);.    if( rc=
24e0: 3d 53 51 4c 49 54 45 5f 4f 4b 20 26 26 20 6e 65  =SQLITE_OK && ne
24f0: 77 50 67 73 7a 21 3d 6e 53 72 63 50 67 73 7a 20  wPgsz!=nSrcPgsz 
2500: 29 20 72 63 20 3d 20 53 51 4c 49 54 45 5f 52 45  ) rc = SQLITE_RE
2510: 41 44 4f 4e 4c 59 3b 0a 20 20 7d 0a 23 65 6e 64  ADONLY;.  }.#end
2520: 69 66 0a 0a 20 20 2f 2a 20 54 68 69 73 20 6c 6f  if..  /* This lo
2530: 6f 70 20 72 75 6e 73 20 6f 6e 63 65 20 66 6f 72  op runs once for
2540: 20 65 61 63 68 20 64 65 73 74 69 6e 61 74 69 6f   each destinatio
2550: 6e 20 70 61 67 65 20 73 70 61 6e 6e 65 64 20 62  n page spanned b
2560: 79 20 74 68 65 20 73 6f 75 72 63 65 20 0a 20 20  y the source .  
2570: 2a 2a 20 70 61 67 65 2e 20 46 6f 72 20 65 61 63  ** page. For eac
2580: 68 20 69 74 65 72 61 74 69 6f 6e 2c 20 76 61 72  h iteration, var
2590: 69 61 62 6c 65 20 69 4f 66 66 20 69 73 20 73 65  iable iOff is se
25a0: 74 20 74 6f 20 74 68 65 20 62 79 74 65 20 6f 66  t to the byte of
25b0: 66 73 65 74 0a 20 20 2a 2a 20 6f 66 20 74 68 65  fset.  ** of the
25c0: 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 70 61 67   destination pag
25d0: 65 2e 0a 20 20 2a 2f 0a 20 20 66 6f 72 28 69 4f  e..  */.  for(iO
25e0: 66 66 3d 69 45 6e 64 2d 28 69 36 34 29 6e 53 72  ff=iEnd-(i64)nSr
25f0: 63 50 67 73 7a 3b 20 72 63 3d 3d 53 51 4c 49 54  cPgsz; rc==SQLIT
2600: 45 5f 4f 4b 20 26 26 20 69 4f 66 66 3c 69 45 6e  E_OK && iOff<iEn
2610: 64 3b 20 69 4f 66 66 2b 3d 6e 44 65 73 74 50 67  d; iOff+=nDestPg
2620: 73 7a 29 7b 0a 20 20 20 20 44 62 50 61 67 65 20  sz){.    DbPage 
2630: 2a 70 44 65 73 74 50 67 20 3d 20 30 3b 0a 20 20  *pDestPg = 0;.  
2640: 20 20 50 67 6e 6f 20 69 44 65 73 74 20 3d 20 28    Pgno iDest = (
2650: 50 67 6e 6f 29 28 69 4f 66 66 2f 6e 44 65 73 74  Pgno)(iOff/nDest
2660: 50 67 73 7a 29 2b 31 3b 0a 20 20 20 20 69 66 28  Pgsz)+1;.    if(
2670: 20 69 44 65 73 74 3d 3d 50 45 4e 44 49 4e 47 5f   iDest==PENDING_
2680: 42 59 54 45 5f 50 41 47 45 28 70 2d 3e 70 44 65  BYTE_PAGE(p->pDe
2690: 73 74 2d 3e 70 42 74 29 20 29 20 63 6f 6e 74 69  st->pBt) ) conti
26a0: 6e 75 65 3b 0a 20 20 20 20 69 66 28 20 53 51 4c  nue;.    if( SQL
26b0: 49 54 45 5f 4f 4b 3d 3d 28 72 63 20 3d 20 73 71  ITE_OK==(rc = sq
26c0: 6c 69 74 65 33 50 61 67 65 72 47 65 74 28 70 44  lite3PagerGet(pD
26d0: 65 73 74 50 61 67 65 72 2c 20 69 44 65 73 74 2c  estPager, iDest,
26e0: 20 26 70 44 65 73 74 50 67 29 29 0a 20 20 20 20   &pDestPg)).    
26f0: 20 26 26 20 53 51 4c 49 54 45 5f 4f 4b 3d 3d 28   && SQLITE_OK==(
2700: 72 63 20 3d 20 73 71 6c 69 74 65 33 50 61 67 65  rc = sqlite3Page
2710: 72 57 72 69 74 65 28 70 44 65 73 74 50 67 29 29  rWrite(pDestPg))
2720: 0a 20 20 20 20 29 7b 0a 20 20 20 20 20 20 63 6f  .    ){.      co
2730: 6e 73 74 20 75 38 20 2a 7a 49 6e 20 3d 20 26 7a  nst u8 *zIn = &z
2740: 53 72 63 44 61 74 61 5b 69 4f 66 66 25 6e 53 72  SrcData[iOff%nSr
2750: 63 50 67 73 7a 5d 3b 0a 20 20 20 20 20 20 75 38  cPgsz];.      u8
2760: 20 2a 7a 44 65 73 74 44 61 74 61 20 3d 20 73 71   *zDestData = sq
2770: 6c 69 74 65 33 50 61 67 65 72 47 65 74 44 61 74  lite3PagerGetDat
2780: 61 28 70 44 65 73 74 50 67 29 3b 0a 20 20 20 20  a(pDestPg);.    
2790: 20 20 75 38 20 2a 7a 4f 75 74 20 3d 20 26 7a 44    u8 *zOut = &zD
27a0: 65 73 74 44 61 74 61 5b 69 4f 66 66 25 6e 44 65  estData[iOff%nDe
27b0: 73 74 50 67 73 7a 5d 3b 0a 0a 20 20 20 20 20 20  stPgsz];..      
27c0: 2f 2a 20 43 6f 70 79 20 74 68 65 20 64 61 74 61  /* Copy the data
27d0: 20 66 72 6f 6d 20 74 68 65 20 73 6f 75 72 63 65   from the source
27e0: 20 70 61 67 65 20 69 6e 74 6f 20 74 68 65 20 64   page into the d
27f0: 65 73 74 69 6e 61 74 69 6f 6e 20 70 61 67 65 2e  estination page.
2800: 0a 20 20 20 20 20 20 2a 2a 20 54 68 65 6e 20 63  .      ** Then c
2810: 6c 65 61 72 20 74 68 65 20 42 74 72 65 65 20 6c  lear the Btree l
2820: 61 79 65 72 20 4d 65 6d 50 61 67 65 2e 69 73 49  ayer MemPage.isI
2830: 6e 69 74 20 66 6c 61 67 2e 20 42 6f 74 68 20 74  nit flag. Both t
2840: 68 69 73 20 6d 6f 64 75 6c 65 0a 20 20 20 20 20  his module.     
2850: 20 2a 2a 20 61 6e 64 20 74 68 65 20 70 61 67 65   ** and the page
2860: 72 20 63 6f 64 65 20 75 73 65 20 74 68 69 73 20  r code use this 
2870: 74 72 69 63 6b 20 28 63 6c 65 61 72 69 6e 67 20  trick (clearing 
2880: 74 68 65 20 66 69 72 73 74 20 62 79 74 65 0a 20  the first byte. 
2890: 20 20 20 20 20 2a 2a 20 6f 66 20 74 68 65 20 70       ** of the p
28a0: 61 67 65 20 27 65 78 74 72 61 27 20 73 70 61 63  age 'extra' spac
28b0: 65 20 74 6f 20 69 6e 76 61 6c 69 64 61 74 65 20  e to invalidate 
28c0: 74 68 65 20 42 74 72 65 65 20 6c 61 79 65 72 73  the Btree layers
28d0: 0a 20 20 20 20 20 20 2a 2a 20 63 61 63 68 65 64  .      ** cached
28e0: 20 70 61 72 73 65 20 6f 66 20 74 68 65 20 70 61   parse of the pa
28f0: 67 65 29 2e 20 4d 65 6d 50 61 67 65 2e 69 73 49  ge). MemPage.isI
2900: 6e 69 74 20 69 73 20 6d 61 72 6b 65 64 20 0a 20  nit is marked . 
2910: 20 20 20 20 20 2a 2a 20 22 4d 55 53 54 20 42 45       ** "MUST BE
2920: 20 46 49 52 53 54 22 20 66 6f 72 20 74 68 69 73   FIRST" for this
2930: 20 70 75 72 70 6f 73 65 2e 0a 20 20 20 20 20 20   purpose..      
2940: 2a 2f 0a 20 20 20 20 20 20 6d 65 6d 63 70 79 28  */.      memcpy(
2950: 7a 4f 75 74 2c 20 7a 49 6e 2c 20 6e 43 6f 70 79  zOut, zIn, nCopy
2960: 29 3b 0a 20 20 20 20 20 20 28 28 75 38 20 2a 29  );.      ((u8 *)
2970: 73 71 6c 69 74 65 33 50 61 67 65 72 47 65 74 45  sqlite3PagerGetE
2980: 78 74 72 61 28 70 44 65 73 74 50 67 29 29 5b 30  xtra(pDestPg))[0
2990: 5d 20 3d 20 30 3b 0a 20 20 20 20 20 20 69 66 28  ] = 0;.      if(
29a0: 20 69 4f 66 66 3d 3d 30 20 26 26 20 62 55 70 64   iOff==0 && bUpd
29b0: 61 74 65 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20  ate==0 ){.      
29c0: 20 20 73 71 6c 69 74 65 33 50 75 74 34 62 79 74    sqlite3Put4byt
29d0: 65 28 26 7a 4f 75 74 5b 32 38 5d 2c 20 73 71 6c  e(&zOut[28], sql
29e0: 69 74 65 33 42 74 72 65 65 4c 61 73 74 50 61 67  ite3BtreeLastPag
29f0: 65 28 70 2d 3e 70 53 72 63 29 29 3b 0a 20 20 20  e(p->pSrc));.   
2a00: 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 20 20 73     }.    }.    s
2a10: 71 6c 69 74 65 33 50 61 67 65 72 55 6e 72 65 66  qlite3PagerUnref
2a20: 28 70 44 65 73 74 50 67 29 3b 0a 20 20 7d 0a 0a  (pDestPg);.  }..
2a30: 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a    return rc;.}..
2a40: 2f 2a 0a 2a 2a 20 49 66 20 70 46 69 6c 65 20 69  /*.** If pFile i
2a50: 73 20 63 75 72 72 65 6e 74 6c 79 20 6c 61 72 67  s currently larg
2a60: 65 72 20 74 68 61 6e 20 69 53 69 7a 65 20 62 79  er than iSize by
2a70: 74 65 73 2c 20 74 68 65 6e 20 74 72 75 6e 63 61  tes, then trunca
2a80: 74 65 20 69 74 20 74 6f 0a 2a 2a 20 65 78 61 63  te it to.** exac
2a90: 74 6c 79 20 69 53 69 7a 65 20 62 79 74 65 73 2e  tly iSize bytes.
2aa0: 20 49 66 20 70 46 69 6c 65 20 69 73 20 6e 6f 74   If pFile is not
2ab0: 20 6c 61 72 67 65 72 20 74 68 61 6e 20 69 53 69   larger than iSi
2ac0: 7a 65 20 62 79 74 65 73 2c 20 74 68 65 6e 0a 2a  ze bytes, then.*
2ad0: 2a 20 74 68 69 73 20 66 75 6e 63 74 69 6f 6e 20  * this function 
2ae0: 69 73 20 61 20 6e 6f 2d 6f 70 2e 0a 2a 2a 0a 2a  is a no-op..**.*
2af0: 2a 20 52 65 74 75 72 6e 20 53 51 4c 49 54 45 5f  * Return SQLITE_
2b00: 4f 4b 20 69 66 20 65 76 65 72 79 74 68 69 6e 67  OK if everything
2b10: 20 69 73 20 73 75 63 63 65 73 73 66 75 6c 2c 20   is successful, 
2b20: 6f 72 20 61 6e 20 53 51 4c 69 74 65 20 65 72 72  or an SQLite err
2b30: 6f 72 20 0a 2a 2a 20 63 6f 64 65 20 69 66 20 61  or .** code if a
2b40: 6e 20 65 72 72 6f 72 20 6f 63 63 75 72 73 2e 0a  n error occurs..
2b50: 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 62 61  */.static int ba
2b60: 63 6b 75 70 54 72 75 6e 63 61 74 65 46 69 6c 65  ckupTruncateFile
2b70: 28 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 70  (sqlite3_file *p
2b80: 46 69 6c 65 2c 20 69 36 34 20 69 53 69 7a 65 29  File, i64 iSize)
2b90: 7b 0a 20 20 69 36 34 20 69 43 75 72 72 65 6e 74  {.  i64 iCurrent
2ba0: 3b 0a 20 20 69 6e 74 20 72 63 20 3d 20 73 71 6c  ;.  int rc = sql
2bb0: 69 74 65 33 4f 73 46 69 6c 65 53 69 7a 65 28 70  ite3OsFileSize(p
2bc0: 46 69 6c 65 2c 20 26 69 43 75 72 72 65 6e 74 29  File, &iCurrent)
2bd0: 3b 0a 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49  ;.  if( rc==SQLI
2be0: 54 45 5f 4f 4b 20 26 26 20 69 43 75 72 72 65 6e  TE_OK && iCurren
2bf0: 74 3e 69 53 69 7a 65 20 29 7b 0a 20 20 20 20 72  t>iSize ){.    r
2c00: 63 20 3d 20 73 71 6c 69 74 65 33 4f 73 54 72 75  c = sqlite3OsTru
2c10: 6e 63 61 74 65 28 70 46 69 6c 65 2c 20 69 53 69  ncate(pFile, iSi
2c20: 7a 65 29 3b 0a 20 20 7d 0a 20 20 72 65 74 75 72  ze);.  }.  retur
2c30: 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52  n rc;.}../*.** R
2c40: 65 67 69 73 74 65 72 20 74 68 69 73 20 62 61 63  egister this bac
2c50: 6b 75 70 20 6f 62 6a 65 63 74 20 77 69 74 68 20  kup object with 
2c60: 74 68 65 20 61 73 73 6f 63 69 61 74 65 64 20 73  the associated s
2c70: 6f 75 72 63 65 20 70 61 67 65 72 20 66 6f 72 0a  ource pager for.
2c80: 2a 2a 20 63 61 6c 6c 62 61 63 6b 73 20 77 68 65  ** callbacks whe
2c90: 6e 20 70 61 67 65 73 20 61 72 65 20 63 68 61 6e  n pages are chan
2ca0: 67 65 64 20 6f 72 20 74 68 65 20 63 61 63 68 65  ged or the cache
2cb0: 20 69 6e 76 61 6c 69 64 61 74 65 64 2e 0a 2a 2f   invalidated..*/
2cc0: 0a 73 74 61 74 69 63 20 76 6f 69 64 20 61 74 74  .static void att
2cd0: 61 63 68 42 61 63 6b 75 70 4f 62 6a 65 63 74 28  achBackupObject(
2ce0: 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a  sqlite3_backup *
2cf0: 70 29 7b 0a 20 20 73 71 6c 69 74 65 33 5f 62 61  p){.  sqlite3_ba
2d00: 63 6b 75 70 20 2a 2a 70 70 3b 0a 20 20 61 73 73  ckup **pp;.  ass
2d10: 65 72 74 28 20 73 71 6c 69 74 65 33 42 74 72 65  ert( sqlite3Btre
2d20: 65 48 6f 6c 64 73 4d 75 74 65 78 28 70 2d 3e 70  eHoldsMutex(p->p
2d30: 53 72 63 29 20 29 3b 0a 20 20 70 70 20 3d 20 73  Src) );.  pp = s
2d40: 71 6c 69 74 65 33 50 61 67 65 72 42 61 63 6b 75  qlite3PagerBacku
2d50: 70 50 74 72 28 73 71 6c 69 74 65 33 42 74 72 65  pPtr(sqlite3Btre
2d60: 65 50 61 67 65 72 28 70 2d 3e 70 53 72 63 29 29  ePager(p->pSrc))
2d70: 3b 0a 20 20 70 2d 3e 70 4e 65 78 74 20 3d 20 2a  ;.  p->pNext = *
2d80: 70 70 3b 0a 20 20 2a 70 70 20 3d 20 70 3b 0a 20  pp;.  *pp = p;. 
2d90: 20 70 2d 3e 69 73 41 74 74 61 63 68 65 64 20 3d   p->isAttached =
2da0: 20 31 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 6f 70   1;.}../*.** Cop
2db0: 79 20 6e 50 61 67 65 20 70 61 67 65 73 20 66 72  y nPage pages fr
2dc0: 6f 6d 20 74 68 65 20 73 6f 75 72 63 65 20 62 2d  om the source b-
2dd0: 74 72 65 65 20 74 6f 20 74 68 65 20 64 65 73 74  tree to the dest
2de0: 69 6e 61 74 69 6f 6e 2e 0a 2a 2f 0a 69 6e 74 20  ination..*/.int 
2df0: 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 73  sqlite3_backup_s
2e00: 74 65 70 28 73 71 6c 69 74 65 33 5f 62 61 63 6b  tep(sqlite3_back
2e10: 75 70 20 2a 70 2c 20 69 6e 74 20 6e 50 61 67 65  up *p, int nPage
2e20: 29 7b 0a 20 20 69 6e 74 20 72 63 3b 0a 20 20 69  ){.  int rc;.  i
2e30: 6e 74 20 64 65 73 74 4d 6f 64 65 3b 20 20 20 20  nt destMode;    
2e40: 20 20 20 2f 2a 20 44 65 73 74 69 6e 61 74 69 6f     /* Destinatio
2e50: 6e 20 6a 6f 75 72 6e 61 6c 20 6d 6f 64 65 20 2a  n journal mode *
2e60: 2f 0a 20 20 69 6e 74 20 70 67 73 7a 53 72 63 20  /.  int pgszSrc 
2e70: 3d 20 30 3b 20 20 20 20 2f 2a 20 53 6f 75 72 63  = 0;    /* Sourc
2e80: 65 20 70 61 67 65 20 73 69 7a 65 20 2a 2f 0a 20  e page size */. 
2e90: 20 69 6e 74 20 70 67 73 7a 44 65 73 74 20 3d 20   int pgszDest = 
2ea0: 30 3b 20 20 20 2f 2a 20 44 65 73 74 69 6e 61 74  0;   /* Destinat
2eb0: 69 6f 6e 20 70 61 67 65 20 73 69 7a 65 20 2a 2f  ion page size */
2ec0: 0a 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65  ..  sqlite3_mute
2ed0: 78 5f 65 6e 74 65 72 28 70 2d 3e 70 53 72 63 44  x_enter(p->pSrcD
2ee0: 62 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 73 71 6c  b->mutex);.  sql
2ef0: 69 74 65 33 42 74 72 65 65 45 6e 74 65 72 28 70  ite3BtreeEnter(p
2f00: 2d 3e 70 53 72 63 29 3b 0a 20 20 69 66 28 20 70  ->pSrc);.  if( p
2f10: 2d 3e 70 44 65 73 74 44 62 20 29 7b 0a 20 20 20  ->pDestDb ){.   
2f20: 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65   sqlite3_mutex_e
2f30: 6e 74 65 72 28 70 2d 3e 70 44 65 73 74 44 62 2d  nter(p->pDestDb-
2f40: 3e 6d 75 74 65 78 29 3b 0a 20 20 7d 0a 0a 20 20  >mutex);.  }..  
2f50: 72 63 20 3d 20 70 2d 3e 72 63 3b 0a 20 20 69 66  rc = p->rc;.  if
2f60: 28 20 21 69 73 46 61 74 61 6c 45 72 72 6f 72 28  ( !isFatalError(
2f70: 72 63 29 20 29 7b 0a 20 20 20 20 50 61 67 65 72  rc) ){.    Pager
2f80: 20 2a 20 63 6f 6e 73 74 20 70 53 72 63 50 61 67   * const pSrcPag
2f90: 65 72 20 3d 20 73 71 6c 69 74 65 33 42 74 72 65  er = sqlite3Btre
2fa0: 65 50 61 67 65 72 28 70 2d 3e 70 53 72 63 29 3b  ePager(p->pSrc);
2fb0: 20 20 20 20 20 2f 2a 20 53 6f 75 72 63 65 20 70       /* Source p
2fc0: 61 67 65 72 20 2a 2f 0a 20 20 20 20 50 61 67 65  ager */.    Page
2fd0: 72 20 2a 20 63 6f 6e 73 74 20 70 44 65 73 74 50  r * const pDestP
2fe0: 61 67 65 72 20 3d 20 73 71 6c 69 74 65 33 42 74  ager = sqlite3Bt
2ff0: 72 65 65 50 61 67 65 72 28 70 2d 3e 70 44 65 73  reePager(p->pDes
3000: 74 29 3b 20 20 20 2f 2a 20 44 65 73 74 20 70 61  t);   /* Dest pa
3010: 67 65 72 20 2a 2f 0a 20 20 20 20 69 6e 74 20 69  ger */.    int i
3020: 69 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  i;              
3030: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a                /*
3040: 20 49 74 65 72 61 74 6f 72 20 76 61 72 69 61 62   Iterator variab
3050: 6c 65 20 2a 2f 0a 20 20 20 20 69 6e 74 20 6e 53  le */.    int nS
3060: 72 63 50 61 67 65 20 3d 20 2d 31 3b 20 20 20 20  rcPage = -1;    
3070: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20               /* 
3080: 53 69 7a 65 20 6f 66 20 73 6f 75 72 63 65 20 64  Size of source d
3090: 62 20 69 6e 20 70 61 67 65 73 20 2a 2f 0a 20 20  b in pages */.  
30a0: 20 20 69 6e 74 20 62 43 6c 6f 73 65 54 72 61 6e    int bCloseTran
30b0: 73 20 3d 20 30 3b 20 20 20 20 20 20 20 20 20 20  s = 0;          
30c0: 20 20 20 20 20 2f 2a 20 54 72 75 65 20 69 66 20       /* True if 
30d0: 73 72 63 20 64 62 20 72 65 71 75 69 72 65 73 20  src db requires 
30e0: 75 6e 6c 6f 63 6b 69 6e 67 20 2a 2f 0a 0a 20 20  unlocking */..  
30f0: 20 20 2f 2a 20 49 66 20 74 68 65 20 73 6f 75 72    /* If the sour
3100: 63 65 20 70 61 67 65 72 20 69 73 20 63 75 72 72  ce pager is curr
3110: 65 6e 74 6c 79 20 69 6e 20 61 20 77 72 69 74 65  ently in a write
3120: 2d 74 72 61 6e 73 61 63 74 69 6f 6e 2c 20 72 65  -transaction, re
3130: 74 75 72 6e 0a 20 20 20 20 2a 2a 20 53 51 4c 49  turn.    ** SQLI
3140: 54 45 5f 42 55 53 59 20 69 6d 6d 65 64 69 61 74  TE_BUSY immediat
3150: 65 6c 79 2e 0a 20 20 20 20 2a 2f 0a 20 20 20 20  ely..    */.    
3160: 69 66 28 20 70 2d 3e 70 44 65 73 74 44 62 20 26  if( p->pDestDb &
3170: 26 20 70 2d 3e 70 53 72 63 2d 3e 70 42 74 2d 3e  & p->pSrc->pBt->
3180: 69 6e 54 72 61 6e 73 61 63 74 69 6f 6e 3d 3d 54  inTransaction==T
3190: 52 41 4e 53 5f 57 52 49 54 45 20 29 7b 0a 20 20  RANS_WRITE ){.  
31a0: 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f      rc = SQLITE_
31b0: 42 55 53 59 3b 0a 20 20 20 20 7d 65 6c 73 65 7b  BUSY;.    }else{
31c0: 0a 20 20 20 20 20 20 72 63 20 3d 20 53 51 4c 49  .      rc = SQLI
31d0: 54 45 5f 4f 4b 3b 0a 20 20 20 20 7d 0a 0a 20 20  TE_OK;.    }..  
31e0: 20 20 2f 2a 20 4c 6f 63 6b 20 74 68 65 20 64 65    /* Lock the de
31f0: 73 74 69 6e 61 74 69 6f 6e 20 64 61 74 61 62 61  stination databa
3200: 73 65 2c 20 69 66 20 69 74 20 69 73 20 6e 6f 74  se, if it is not
3210: 20 6c 6f 63 6b 65 64 20 61 6c 72 65 61 64 79 2e   locked already.
3220: 20 2a 2f 0a 20 20 20 20 69 66 28 20 53 51 4c 49   */.    if( SQLI
3230: 54 45 5f 4f 4b 3d 3d 72 63 20 26 26 20 70 2d 3e  TE_OK==rc && p->
3240: 62 44 65 73 74 4c 6f 63 6b 65 64 3d 3d 30 0a 20  bDestLocked==0. 
3250: 20 20 20 20 26 26 20 53 51 4c 49 54 45 5f 4f 4b      && SQLITE_OK
3260: 3d 3d 28 72 63 20 3d 20 73 71 6c 69 74 65 33 42  ==(rc = sqlite3B
3270: 74 72 65 65 42 65 67 69 6e 54 72 61 6e 73 28 70  treeBeginTrans(p
3280: 2d 3e 70 44 65 73 74 2c 20 32 29 29 20 0a 20 20  ->pDest, 2)) .  
3290: 20 20 29 7b 0a 20 20 20 20 20 20 70 2d 3e 62 44    ){.      p->bD
32a0: 65 73 74 4c 6f 63 6b 65 64 20 3d 20 31 3b 0a 20  estLocked = 1;. 
32b0: 20 20 20 20 20 73 71 6c 69 74 65 33 42 74 72 65       sqlite3Btre
32c0: 65 47 65 74 4d 65 74 61 28 70 2d 3e 70 44 65 73  eGetMeta(p->pDes
32d0: 74 2c 20 42 54 52 45 45 5f 53 43 48 45 4d 41 5f  t, BTREE_SCHEMA_
32e0: 56 45 52 53 49 4f 4e 2c 20 26 70 2d 3e 69 44 65  VERSION, &p->iDe
32f0: 73 74 53 63 68 65 6d 61 29 3b 0a 20 20 20 20 7d  stSchema);.    }
3300: 0a 0a 20 20 20 20 2f 2a 20 49 66 20 74 68 65 72  ..    /* If ther
3310: 65 20 69 73 20 6e 6f 20 6f 70 65 6e 20 72 65 61  e is no open rea
3320: 64 2d 74 72 61 6e 73 61 63 74 69 6f 6e 20 6f 6e  d-transaction on
3330: 20 74 68 65 20 73 6f 75 72 63 65 20 64 61 74 61   the source data
3340: 62 61 73 65 2c 20 6f 70 65 6e 0a 20 20 20 20 2a  base, open.    *
3350: 2a 20 6f 6e 65 20 6e 6f 77 2e 20 49 66 20 61 20  * one now. If a 
3360: 74 72 61 6e 73 61 63 74 69 6f 6e 20 69 73 20 6f  transaction is o
3370: 70 65 6e 65 64 20 68 65 72 65 2c 20 74 68 65 6e  pened here, then
3380: 20 69 74 20 77 69 6c 6c 20 62 65 20 63 6c 6f 73   it will be clos
3390: 65 64 0a 20 20 20 20 2a 2a 20 62 65 66 6f 72 65  ed.    ** before
33a0: 20 74 68 69 73 20 66 75 6e 63 74 69 6f 6e 20 65   this function e
33b0: 78 69 74 73 2e 0a 20 20 20 20 2a 2f 0a 20 20 20  xits..    */.   
33c0: 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f   if( rc==SQLITE_
33d0: 4f 4b 20 26 26 20 30 3d 3d 73 71 6c 69 74 65 33  OK && 0==sqlite3
33e0: 42 74 72 65 65 49 73 49 6e 52 65 61 64 54 72 61  BtreeIsInReadTra
33f0: 6e 73 28 70 2d 3e 70 53 72 63 29 20 29 7b 0a 20  ns(p->pSrc) ){. 
3400: 20 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65       rc = sqlite
3410: 33 42 74 72 65 65 42 65 67 69 6e 54 72 61 6e 73  3BtreeBeginTrans
3420: 28 70 2d 3e 70 53 72 63 2c 20 30 29 3b 0a 20 20  (p->pSrc, 0);.  
3430: 20 20 20 20 62 43 6c 6f 73 65 54 72 61 6e 73 20      bCloseTrans 
3440: 3d 20 31 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20  = 1;.    }..    
3450: 2f 2a 20 44 6f 20 6e 6f 74 20 61 6c 6c 6f 77 20  /* Do not allow 
3460: 62 61 63 6b 75 70 20 69 66 20 74 68 65 20 64 65  backup if the de
3470: 73 74 69 6e 61 74 69 6f 6e 20 64 61 74 61 62 61  stination databa
3480: 73 65 20 69 73 20 69 6e 20 57 41 4c 20 6d 6f 64  se is in WAL mod
3490: 65 0a 20 20 20 20 2a 2a 20 61 6e 64 20 74 68 65  e.    ** and the
34a0: 20 70 61 67 65 20 73 69 7a 65 73 20 61 72 65 20   page sizes are 
34b0: 64 69 66 66 65 72 65 6e 74 20 62 65 74 77 65 65  different betwee
34c0: 6e 20 73 6f 75 72 63 65 20 61 6e 64 20 64 65 73  n source and des
34d0: 74 69 6e 61 74 69 6f 6e 20 2a 2f 0a 20 20 20 20  tination */.    
34e0: 70 67 73 7a 53 72 63 20 3d 20 73 71 6c 69 74 65  pgszSrc = sqlite
34f0: 33 42 74 72 65 65 47 65 74 50 61 67 65 53 69 7a  3BtreeGetPageSiz
3500: 65 28 70 2d 3e 70 53 72 63 29 3b 0a 20 20 20 20  e(p->pSrc);.    
3510: 70 67 73 7a 44 65 73 74 20 3d 20 73 71 6c 69 74  pgszDest = sqlit
3520: 65 33 42 74 72 65 65 47 65 74 50 61 67 65 53 69  e3BtreeGetPageSi
3530: 7a 65 28 70 2d 3e 70 44 65 73 74 29 3b 0a 20 20  ze(p->pDest);.  
3540: 20 20 64 65 73 74 4d 6f 64 65 20 3d 20 73 71 6c    destMode = sql
3550: 69 74 65 33 50 61 67 65 72 47 65 74 4a 6f 75 72  ite3PagerGetJour
3560: 6e 61 6c 4d 6f 64 65 28 73 71 6c 69 74 65 33 42  nalMode(sqlite3B
3570: 74 72 65 65 50 61 67 65 72 28 70 2d 3e 70 44 65  treePager(p->pDe
3580: 73 74 29 29 3b 0a 20 20 20 20 69 66 28 20 53 51  st));.    if( SQ
3590: 4c 49 54 45 5f 4f 4b 3d 3d 72 63 20 26 26 20 64  LITE_OK==rc && d
35a0: 65 73 74 4d 6f 64 65 3d 3d 50 41 47 45 52 5f 4a  estMode==PAGER_J
35b0: 4f 55 52 4e 41 4c 4d 4f 44 45 5f 57 41 4c 20 26  OURNALMODE_WAL &
35c0: 26 20 70 67 73 7a 53 72 63 21 3d 70 67 73 7a 44  & pgszSrc!=pgszD
35d0: 65 73 74 20 29 7b 0a 20 20 20 20 20 20 72 63 20  est ){.      rc 
35e0: 3d 20 53 51 4c 49 54 45 5f 52 45 41 44 4f 4e 4c  = SQLITE_READONL
35f0: 59 3b 0a 20 20 20 20 7d 0a 20 20 0a 20 20 20 20  Y;.    }.  .    
3600: 2f 2a 20 4e 6f 77 20 74 68 61 74 20 74 68 65 72  /* Now that ther
3610: 65 20 69 73 20 61 20 72 65 61 64 2d 6c 6f 63 6b  e is a read-lock
3620: 20 6f 6e 20 74 68 65 20 73 6f 75 72 63 65 20 64   on the source d
3630: 61 74 61 62 61 73 65 2c 20 71 75 65 72 79 20 74  atabase, query t
3640: 68 65 0a 20 20 20 20 2a 2a 20 73 6f 75 72 63 65  he.    ** source
3650: 20 70 61 67 65 72 20 66 6f 72 20 74 68 65 20 6e   pager for the n
3660: 75 6d 62 65 72 20 6f 66 20 70 61 67 65 73 20 69  umber of pages i
3670: 6e 20 74 68 65 20 64 61 74 61 62 61 73 65 2e 0a  n the database..
3680: 20 20 20 20 2a 2f 0a 20 20 20 20 6e 53 72 63 50      */.    nSrcP
3690: 61 67 65 20 3d 20 28 69 6e 74 29 73 71 6c 69 74  age = (int)sqlit
36a0: 65 33 42 74 72 65 65 4c 61 73 74 50 61 67 65 28  e3BtreeLastPage(
36b0: 70 2d 3e 70 53 72 63 29 3b 0a 20 20 20 20 61 73  p->pSrc);.    as
36c0: 73 65 72 74 28 20 6e 53 72 63 50 61 67 65 3e 3d  sert( nSrcPage>=
36d0: 30 20 29 3b 0a 20 20 20 20 66 6f 72 28 69 69 3d  0 );.    for(ii=
36e0: 30 3b 20 28 6e 50 61 67 65 3c 30 20 7c 7c 20 69  0; (nPage<0 || i
36f0: 69 3c 6e 50 61 67 65 29 20 26 26 20 70 2d 3e 69  i<nPage) && p->i
3700: 4e 65 78 74 3c 3d 28 50 67 6e 6f 29 6e 53 72 63  Next<=(Pgno)nSrc
3710: 50 61 67 65 20 26 26 20 21 72 63 3b 20 69 69 2b  Page && !rc; ii+
3720: 2b 29 7b 0a 20 20 20 20 20 20 63 6f 6e 73 74 20  +){.      const 
3730: 50 67 6e 6f 20 69 53 72 63 50 67 20 3d 20 70 2d  Pgno iSrcPg = p-
3740: 3e 69 4e 65 78 74 3b 20 20 20 20 20 20 20 20 20  >iNext;         
3750: 20 20 20 20 20 20 20 20 2f 2a 20 53 6f 75 72 63          /* Sourc
3760: 65 20 70 61 67 65 20 6e 75 6d 62 65 72 20 2a 2f  e page number */
3770: 0a 20 20 20 20 20 20 69 66 28 20 69 53 72 63 50  .      if( iSrcP
3780: 67 21 3d 50 45 4e 44 49 4e 47 5f 42 59 54 45 5f  g!=PENDING_BYTE_
3790: 50 41 47 45 28 70 2d 3e 70 53 72 63 2d 3e 70 42  PAGE(p->pSrc->pB
37a0: 74 29 20 29 7b 0a 20 20 20 20 20 20 20 20 44 62  t) ){.        Db
37b0: 50 61 67 65 20 2a 70 53 72 63 50 67 3b 20 20 20  Page *pSrcPg;   
37c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
37d0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 53 6f 75            /* Sou
37e0: 72 63 65 20 70 61 67 65 20 6f 62 6a 65 63 74 20  rce page object 
37f0: 2a 2f 0a 20 20 20 20 20 20 20 20 72 63 20 3d 20  */.        rc = 
3800: 73 71 6c 69 74 65 33 50 61 67 65 72 41 63 71 75  sqlite3PagerAcqu
3810: 69 72 65 28 70 53 72 63 50 61 67 65 72 2c 20 69  ire(pSrcPager, i
3820: 53 72 63 50 67 2c 20 26 70 53 72 63 50 67 2c 0a  SrcPg, &pSrcPg,.
3830: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3840: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
3850: 20 50 41 47 45 52 5f 47 45 54 5f 52 45 41 44 4f   PAGER_GET_READO
3860: 4e 4c 59 29 3b 0a 20 20 20 20 20 20 20 20 69 66  NLY);.        if
3870: 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20  ( rc==SQLITE_OK 
3880: 29 7b 0a 20 20 20 20 20 20 20 20 20 20 72 63 20  ){.          rc 
3890: 3d 20 62 61 63 6b 75 70 4f 6e 65 50 61 67 65 28  = backupOnePage(
38a0: 70 2c 20 69 53 72 63 50 67 2c 20 73 71 6c 69 74  p, iSrcPg, sqlit
38b0: 65 33 50 61 67 65 72 47 65 74 44 61 74 61 28 70  e3PagerGetData(p
38c0: 53 72 63 50 67 29 2c 20 30 29 3b 0a 20 20 20 20  SrcPg), 0);.    
38d0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 50 61 67        sqlite3Pag
38e0: 65 72 55 6e 72 65 66 28 70 53 72 63 50 67 29 3b  erUnref(pSrcPg);
38f0: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
3900: 20 7d 0a 20 20 20 20 20 20 70 2d 3e 69 4e 65 78   }.      p->iNex
3910: 74 2b 2b 3b 0a 20 20 20 20 7d 0a 20 20 20 20 69  t++;.    }.    i
3920: 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b  f( rc==SQLITE_OK
3930: 20 29 7b 0a 20 20 20 20 20 20 70 2d 3e 6e 50 61   ){.      p->nPa
3940: 67 65 63 6f 75 6e 74 20 3d 20 6e 53 72 63 50 61  gecount = nSrcPa
3950: 67 65 3b 0a 20 20 20 20 20 20 70 2d 3e 6e 52 65  ge;.      p->nRe
3960: 6d 61 69 6e 69 6e 67 20 3d 20 6e 53 72 63 50 61  maining = nSrcPa
3970: 67 65 2b 31 2d 70 2d 3e 69 4e 65 78 74 3b 0a 20  ge+1-p->iNext;. 
3980: 20 20 20 20 20 69 66 28 20 70 2d 3e 69 4e 65 78       if( p->iNex
3990: 74 3e 28 50 67 6e 6f 29 6e 53 72 63 50 61 67 65  t>(Pgno)nSrcPage
39a0: 20 29 7b 0a 20 20 20 20 20 20 20 20 72 63 20 3d   ){.        rc =
39b0: 20 53 51 4c 49 54 45 5f 44 4f 4e 45 3b 0a 20 20   SQLITE_DONE;.  
39c0: 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 21 70      }else if( !p
39d0: 2d 3e 69 73 41 74 74 61 63 68 65 64 20 29 7b 0a  ->isAttached ){.
39e0: 20 20 20 20 20 20 20 20 61 74 74 61 63 68 42 61          attachBa
39f0: 63 6b 75 70 4f 62 6a 65 63 74 28 70 29 3b 0a 20  ckupObject(p);. 
3a00: 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 0a       }.    }.  .
3a10: 20 20 20 20 2f 2a 20 55 70 64 61 74 65 20 74 68      /* Update th
3a20: 65 20 73 63 68 65 6d 61 20 76 65 72 73 69 6f 6e  e schema version
3a30: 20 66 69 65 6c 64 20 69 6e 20 74 68 65 20 64 65   field in the de
3a40: 73 74 69 6e 61 74 69 6f 6e 20 64 61 74 61 62 61  stination databa
3a50: 73 65 2e 20 54 68 69 73 0a 20 20 20 20 2a 2a 20  se. This.    ** 
3a60: 69 73 20 74 6f 20 6d 61 6b 65 20 73 75 72 65 20  is to make sure 
3a70: 74 68 61 74 20 74 68 65 20 73 63 68 65 6d 61 2d  that the schema-
3a80: 76 65 72 73 69 6f 6e 20 72 65 61 6c 6c 79 20 64  version really d
3a90: 6f 65 73 20 63 68 61 6e 67 65 20 69 6e 0a 20 20  oes change in.  
3aa0: 20 20 2a 2a 20 74 68 65 20 63 61 73 65 20 77 68    ** the case wh
3ab0: 65 72 65 20 74 68 65 20 73 6f 75 72 63 65 20 61  ere the source a
3ac0: 6e 64 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 64  nd destination d
3ad0: 61 74 61 62 61 73 65 73 20 68 61 76 65 20 74 68  atabases have th
3ae0: 65 0a 20 20 20 20 2a 2a 20 73 61 6d 65 20 73 63  e.    ** same sc
3af0: 68 65 6d 61 20 76 65 72 73 69 6f 6e 2e 0a 20 20  hema version..  
3b00: 20 20 2a 2f 0a 20 20 20 20 69 66 28 20 72 63 3d    */.    if( rc=
3b10: 3d 53 51 4c 49 54 45 5f 44 4f 4e 45 20 29 7b 0a  =SQLITE_DONE ){.
3b20: 20 20 20 20 20 20 69 66 28 20 6e 53 72 63 50 61        if( nSrcPa
3b30: 67 65 3d 3d 30 20 29 7b 0a 20 20 20 20 20 20 20  ge==0 ){.       
3b40: 20 72 63 20 3d 20 73 71 6c 69 74 65 33 42 74 72   rc = sqlite3Btr
3b50: 65 65 4e 65 77 44 62 28 70 2d 3e 70 44 65 73 74  eeNewDb(p->pDest
3b60: 29 3b 0a 20 20 20 20 20 20 20 20 6e 53 72 63 50  );.        nSrcP
3b70: 61 67 65 20 3d 20 31 3b 0a 20 20 20 20 20 20 7d  age = 1;.      }
3b80: 0a 20 20 20 20 20 20 69 66 28 20 72 63 3d 3d 53  .      if( rc==S
3b90: 51 4c 49 54 45 5f 4f 4b 20 7c 7c 20 72 63 3d 3d  QLITE_OK || rc==
3ba0: 53 51 4c 49 54 45 5f 44 4f 4e 45 20 29 7b 0a 20  SQLITE_DONE ){. 
3bb0: 20 20 20 20 20 20 20 72 63 20 3d 20 73 71 6c 69         rc = sqli
3bc0: 74 65 33 42 74 72 65 65 55 70 64 61 74 65 4d 65  te3BtreeUpdateMe
3bd0: 74 61 28 70 2d 3e 70 44 65 73 74 2c 31 2c 70 2d  ta(p->pDest,1,p-
3be0: 3e 69 44 65 73 74 53 63 68 65 6d 61 2b 31 29 3b  >iDestSchema+1);
3bf0: 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69  .      }.      i
3c00: 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b  f( rc==SQLITE_OK
3c10: 20 29 7b 0a 20 20 20 20 20 20 20 20 69 66 28 20   ){.        if( 
3c20: 70 2d 3e 70 44 65 73 74 44 62 20 29 7b 0a 20 20  p->pDestDb ){.  
3c30: 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 52          sqlite3R
3c40: 65 73 65 74 41 6c 6c 53 63 68 65 6d 61 73 4f 66  esetAllSchemasOf
3c50: 43 6f 6e 6e 65 63 74 69 6f 6e 28 70 2d 3e 70 44  Connection(p->pD
3c60: 65 73 74 44 62 29 3b 0a 20 20 20 20 20 20 20 20  estDb);.        
3c70: 7d 0a 20 20 20 20 20 20 20 20 69 66 28 20 64 65  }.        if( de
3c80: 73 74 4d 6f 64 65 3d 3d 50 41 47 45 52 5f 4a 4f  stMode==PAGER_JO
3c90: 55 52 4e 41 4c 4d 4f 44 45 5f 57 41 4c 20 29 7b  URNALMODE_WAL ){
3ca0: 0a 20 20 20 20 20 20 20 20 20 20 72 63 20 3d 20  .          rc = 
3cb0: 73 71 6c 69 74 65 33 42 74 72 65 65 53 65 74 56  sqlite3BtreeSetV
3cc0: 65 72 73 69 6f 6e 28 70 2d 3e 70 44 65 73 74 2c  ersion(p->pDest,
3cd0: 20 32 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20   2);.        }. 
3ce0: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 69 66 28       }.      if(
3cf0: 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29   rc==SQLITE_OK )
3d00: 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20 6e 44  {.        int nD
3d10: 65 73 74 54 72 75 6e 63 61 74 65 3b 0a 20 20 20  estTruncate;.   
3d20: 20 20 20 20 20 2f 2a 20 53 65 74 20 6e 44 65 73       /* Set nDes
3d30: 74 54 72 75 6e 63 61 74 65 20 74 6f 20 74 68 65  tTruncate to the
3d40: 20 66 69 6e 61 6c 20 6e 75 6d 62 65 72 20 6f 66   final number of
3d50: 20 70 61 67 65 73 20 69 6e 20 74 68 65 20 64 65   pages in the de
3d60: 73 74 69 6e 61 74 69 6f 6e 0a 20 20 20 20 20 20  stination.      
3d70: 20 20 2a 2a 20 64 61 74 61 62 61 73 65 2e 20 54    ** database. T
3d80: 68 65 20 63 6f 6d 70 6c 69 63 61 74 69 6f 6e 20  he complication 
3d90: 68 65 72 65 20 69 73 20 74 68 61 74 20 74 68 65  here is that the
3da0: 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 70 61 67   destination pag
3db0: 65 0a 20 20 20 20 20 20 20 20 2a 2a 20 73 69 7a  e.        ** siz
3dc0: 65 20 6d 61 79 20 62 65 20 64 69 66 66 65 72 65  e may be differe
3dd0: 6e 74 20 74 6f 20 74 68 65 20 73 6f 75 72 63 65  nt to the source
3de0: 20 70 61 67 65 20 73 69 7a 65 2e 20 0a 20 20 20   page size. .   
3df0: 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 20 20       **.        
3e00: 2a 2a 20 49 66 20 74 68 65 20 73 6f 75 72 63 65  ** If the source
3e10: 20 70 61 67 65 20 73 69 7a 65 20 69 73 20 73 6d   page size is sm
3e20: 61 6c 6c 65 72 20 74 68 61 6e 20 74 68 65 20 64  aller than the d
3e30: 65 73 74 69 6e 61 74 69 6f 6e 20 70 61 67 65 20  estination page 
3e40: 73 69 7a 65 2c 20 0a 20 20 20 20 20 20 20 20 2a  size, .        *
3e50: 2a 20 72 6f 75 6e 64 20 75 70 2e 20 49 6e 20 74  * round up. In t
3e60: 68 69 73 20 63 61 73 65 20 74 68 65 20 63 61 6c  his case the cal
3e70: 6c 20 74 6f 20 73 71 6c 69 74 65 33 4f 73 54 72  l to sqlite3OsTr
3e80: 75 6e 63 61 74 65 28 29 20 62 65 6c 6f 77 20 77  uncate() below w
3e90: 69 6c 6c 0a 20 20 20 20 20 20 20 20 2a 2a 20 66  ill.        ** f
3ea0: 69 78 20 74 68 65 20 73 69 7a 65 20 6f 66 20 74  ix the size of t
3eb0: 68 65 20 66 69 6c 65 2e 20 48 6f 77 65 76 65 72  he file. However
3ec0: 20 69 74 20 69 73 20 69 6d 70 6f 72 74 61 6e 74   it is important
3ed0: 20 74 6f 20 63 61 6c 6c 0a 20 20 20 20 20 20 20   to call.       
3ee0: 20 2a 2a 20 73 71 6c 69 74 65 33 50 61 67 65 72   ** sqlite3Pager
3ef0: 54 72 75 6e 63 61 74 65 49 6d 61 67 65 28 29 20  TruncateImage() 
3f00: 68 65 72 65 20 73 6f 20 74 68 61 74 20 61 6e 79  here so that any
3f10: 20 70 61 67 65 73 20 69 6e 20 74 68 65 20 0a 20   pages in the . 
3f20: 20 20 20 20 20 20 20 2a 2a 20 64 65 73 74 69 6e         ** destin
3f30: 61 74 69 6f 6e 20 66 69 6c 65 20 74 68 61 74 20  ation file that 
3f40: 6c 69 65 20 62 65 79 6f 6e 64 20 74 68 65 20 6e  lie beyond the n
3f50: 44 65 73 74 54 72 75 6e 63 61 74 65 20 70 61 67  DestTruncate pag
3f60: 65 20 6d 61 72 6b 20 61 72 65 0a 20 20 20 20 20  e mark are.     
3f70: 20 20 20 2a 2a 20 6a 6f 75 72 6e 61 6c 6c 65 64     ** journalled
3f80: 20 62 79 20 50 61 67 65 72 43 6f 6d 6d 69 74 50   by PagerCommitP
3f90: 68 61 73 65 4f 6e 65 28 29 20 62 65 66 6f 72 65  haseOne() before
3fa0: 20 74 68 65 79 20 61 72 65 20 64 65 73 74 72 6f   they are destro
3fb0: 79 65 64 0a 20 20 20 20 20 20 20 20 2a 2a 20 62  yed.        ** b
3fc0: 79 20 74 68 65 20 66 69 6c 65 20 74 72 75 6e 63  y the file trunc
3fd0: 61 74 69 6f 6e 2e 0a 20 20 20 20 20 20 20 20 2a  ation..        *
3fe0: 2f 0a 20 20 20 20 20 20 20 20 61 73 73 65 72 74  /.        assert
3ff0: 28 20 70 67 73 7a 53 72 63 3d 3d 73 71 6c 69 74  ( pgszSrc==sqlit
4000: 65 33 42 74 72 65 65 47 65 74 50 61 67 65 53 69  e3BtreeGetPageSi
4010: 7a 65 28 70 2d 3e 70 53 72 63 29 20 29 3b 0a 20  ze(p->pSrc) );. 
4020: 20 20 20 20 20 20 20 61 73 73 65 72 74 28 20 70         assert( p
4030: 67 73 7a 44 65 73 74 3d 3d 73 71 6c 69 74 65 33  gszDest==sqlite3
4040: 42 74 72 65 65 47 65 74 50 61 67 65 53 69 7a 65  BtreeGetPageSize
4050: 28 70 2d 3e 70 44 65 73 74 29 20 29 3b 0a 20 20  (p->pDest) );.  
4060: 20 20 20 20 20 20 69 66 28 20 70 67 73 7a 53 72        if( pgszSr
4070: 63 3c 70 67 73 7a 44 65 73 74 20 29 7b 0a 20 20  c<pgszDest ){.  
4080: 20 20 20 20 20 20 20 20 69 6e 74 20 72 61 74 69          int rati
4090: 6f 20 3d 20 70 67 73 7a 44 65 73 74 2f 70 67 73  o = pgszDest/pgs
40a0: 7a 53 72 63 3b 0a 20 20 20 20 20 20 20 20 20 20  zSrc;.          
40b0: 6e 44 65 73 74 54 72 75 6e 63 61 74 65 20 3d 20  nDestTruncate = 
40c0: 28 6e 53 72 63 50 61 67 65 2b 72 61 74 69 6f 2d  (nSrcPage+ratio-
40d0: 31 29 2f 72 61 74 69 6f 3b 0a 20 20 20 20 20 20  1)/ratio;.      
40e0: 20 20 20 20 69 66 28 20 6e 44 65 73 74 54 72 75      if( nDestTru
40f0: 6e 63 61 74 65 3d 3d 28 69 6e 74 29 50 45 4e 44  ncate==(int)PEND
4100: 49 4e 47 5f 42 59 54 45 5f 50 41 47 45 28 70 2d  ING_BYTE_PAGE(p-
4110: 3e 70 44 65 73 74 2d 3e 70 42 74 29 20 29 7b 0a  >pDest->pBt) ){.
4120: 20 20 20 20 20 20 20 20 20 20 20 20 6e 44 65 73              nDes
4130: 74 54 72 75 6e 63 61 74 65 2d 2d 3b 0a 20 20 20  tTruncate--;.   
4140: 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20         }.       
4150: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20   }else{.        
4160: 20 20 6e 44 65 73 74 54 72 75 6e 63 61 74 65 20    nDestTruncate 
4170: 3d 20 6e 53 72 63 50 61 67 65 20 2a 20 28 70 67  = nSrcPage * (pg
4180: 73 7a 53 72 63 2f 70 67 73 7a 44 65 73 74 29 3b  szSrc/pgszDest);
4190: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
41a0: 20 20 20 61 73 73 65 72 74 28 20 6e 44 65 73 74     assert( nDest
41b0: 54 72 75 6e 63 61 74 65 3e 30 20 29 3b 0a 0a 20  Truncate>0 );.. 
41c0: 20 20 20 20 20 20 20 69 66 28 20 70 67 73 7a 53         if( pgszS
41d0: 72 63 3c 70 67 73 7a 44 65 73 74 20 29 7b 0a 20  rc<pgszDest ){. 
41e0: 20 20 20 20 20 20 20 20 20 2f 2a 20 49 66 20 74           /* If t
41f0: 68 65 20 73 6f 75 72 63 65 20 70 61 67 65 2d 73  he source page-s
4200: 69 7a 65 20 69 73 20 73 6d 61 6c 6c 65 72 20 74  ize is smaller t
4210: 68 61 6e 20 74 68 65 20 64 65 73 74 69 6e 61 74  han the destinat
4220: 69 6f 6e 20 70 61 67 65 2d 73 69 7a 65 2c 0a 20  ion page-size,. 
4230: 20 20 20 20 20 20 20 20 20 2a 2a 20 74 77 6f 20           ** two 
4240: 65 78 74 72 61 20 74 68 69 6e 67 73 20 6d 61 79  extra things may
4250: 20 6e 65 65 64 20 74 6f 20 68 61 70 70 65 6e 3a   need to happen:
4260: 0a 20 20 20 20 20 20 20 20 20 20 2a 2a 0a 20 20  .          **.  
4270: 20 20 20 20 20 20 20 20 2a 2a 20 20 20 2a 20 54          **   * T
4280: 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 6d  he destination m
4290: 61 79 20 6e 65 65 64 20 74 6f 20 62 65 20 74 72  ay need to be tr
42a0: 75 6e 63 61 74 65 64 2c 20 61 6e 64 0a 20 20 20  uncated, and.   
42b0: 20 20 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20         **.      
42c0: 20 20 20 20 2a 2a 20 20 20 2a 20 44 61 74 61 20      **   * Data 
42d0: 73 74 6f 72 65 64 20 6f 6e 20 74 68 65 20 70 61  stored on the pa
42e0: 67 65 73 20 69 6d 6d 65 64 69 61 74 65 6c 79 20  ges immediately 
42f0: 66 6f 6c 6c 6f 77 69 6e 67 20 74 68 65 20 0a 20  following the . 
4300: 20 20 20 20 20 20 20 20 20 2a 2a 20 20 20 20 20           **     
4310: 70 65 6e 64 69 6e 67 2d 62 79 74 65 20 70 61 67  pending-byte pag
4320: 65 20 69 6e 20 74 68 65 20 73 6f 75 72 63 65 20  e in the source 
4330: 64 61 74 61 62 61 73 65 20 6d 61 79 20 6e 65 65  database may nee
4340: 64 20 74 6f 20 62 65 0a 20 20 20 20 20 20 20 20  d to be.        
4350: 20 20 2a 2a 20 20 20 20 20 63 6f 70 69 65 64 20    **     copied 
4360: 69 6e 74 6f 20 74 68 65 20 64 65 73 74 69 6e 61  into the destina
4370: 74 69 6f 6e 20 64 61 74 61 62 61 73 65 2e 0a 20  tion database.. 
4380: 20 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 20 20           */.    
4390: 20 20 20 20 20 20 63 6f 6e 73 74 20 69 36 34 20        const i64 
43a0: 69 53 69 7a 65 20 3d 20 28 69 36 34 29 70 67 73  iSize = (i64)pgs
43b0: 7a 53 72 63 20 2a 20 28 69 36 34 29 6e 53 72 63  zSrc * (i64)nSrc
43c0: 50 61 67 65 3b 0a 20 20 20 20 20 20 20 20 20 20  Page;.          
43d0: 73 71 6c 69 74 65 33 5f 66 69 6c 65 20 2a 20 63  sqlite3_file * c
43e0: 6f 6e 73 74 20 70 46 69 6c 65 20 3d 20 73 71 6c  onst pFile = sql
43f0: 69 74 65 33 50 61 67 65 72 46 69 6c 65 28 70 44  ite3PagerFile(pD
4400: 65 73 74 50 61 67 65 72 29 3b 0a 20 20 20 20 20  estPager);.     
4410: 20 20 20 20 20 50 67 6e 6f 20 69 50 67 3b 0a 20       Pgno iPg;. 
4420: 20 20 20 20 20 20 20 20 20 69 6e 74 20 6e 44 73           int nDs
4430: 74 50 61 67 65 3b 0a 20 20 20 20 20 20 20 20 20  tPage;.         
4440: 20 69 36 34 20 69 4f 66 66 3b 0a 20 20 20 20 20   i64 iOff;.     
4450: 20 20 20 20 20 69 36 34 20 69 45 6e 64 3b 0a 0a       i64 iEnd;..
4460: 20 20 20 20 20 20 20 20 20 20 61 73 73 65 72 74            assert
4470: 28 20 70 46 69 6c 65 20 29 3b 0a 20 20 20 20 20  ( pFile );.     
4480: 20 20 20 20 20 61 73 73 65 72 74 28 20 6e 44 65       assert( nDe
4490: 73 74 54 72 75 6e 63 61 74 65 3d 3d 30 20 0a 20  stTruncate==0 . 
44a0: 20 20 20 20 20 20 20 20 20 20 20 20 20 7c 7c 20               || 
44b0: 28 69 36 34 29 6e 44 65 73 74 54 72 75 6e 63 61  (i64)nDestTrunca
44c0: 74 65 2a 28 69 36 34 29 70 67 73 7a 44 65 73 74  te*(i64)pgszDest
44d0: 20 3e 3d 20 69 53 69 7a 65 20 7c 7c 20 28 0a 20   >= iSize || (. 
44e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 6e                 n
44f0: 44 65 73 74 54 72 75 6e 63 61 74 65 3d 3d 28 69  DestTruncate==(i
4500: 6e 74 29 28 50 45 4e 44 49 4e 47 5f 42 59 54 45  nt)(PENDING_BYTE
4510: 5f 50 41 47 45 28 70 2d 3e 70 44 65 73 74 2d 3e  _PAGE(p->pDest->
4520: 70 42 74 29 2d 31 29 0a 20 20 20 20 20 20 20 20  pBt)-1).        
4530: 20 20 20 20 20 26 26 20 69 53 69 7a 65 3e 3d 50       && iSize>=P
4540: 45 4e 44 49 4e 47 5f 42 59 54 45 20 26 26 20 69  ENDING_BYTE && i
4550: 53 69 7a 65 3c 3d 50 45 4e 44 49 4e 47 5f 42 59  Size<=PENDING_BY
4560: 54 45 2b 70 67 73 7a 44 65 73 74 0a 20 20 20 20  TE+pgszDest.    
4570: 20 20 20 20 20 20 29 29 3b 0a 0a 20 20 20 20 20        ));..     
4580: 20 20 20 20 20 2f 2a 20 54 68 69 73 20 62 6c 6f       /* This blo
4590: 63 6b 20 65 6e 73 75 72 65 73 20 74 68 61 74 20  ck ensures that 
45a0: 61 6c 6c 20 64 61 74 61 20 72 65 71 75 69 72 65  all data require
45b0: 64 20 74 6f 20 72 65 63 72 65 61 74 65 20 74 68  d to recreate th
45c0: 65 20 6f 72 69 67 69 6e 61 6c 0a 20 20 20 20 20  e original.     
45d0: 20 20 20 20 20 2a 2a 20 64 61 74 61 62 61 73 65       ** database
45e0: 20 68 61 73 20 62 65 65 6e 20 73 74 6f 72 65 64   has been stored
45f0: 20 69 6e 20 74 68 65 20 6a 6f 75 72 6e 61 6c 20   in the journal 
4600: 66 6f 72 20 70 44 65 73 74 50 61 67 65 72 20 61  for pDestPager a
4610: 6e 64 20 74 68 65 0a 20 20 20 20 20 20 20 20 20  nd the.         
4620: 20 2a 2a 20 6a 6f 75 72 6e 61 6c 20 73 79 6e 63   ** journal sync
4630: 65 64 20 74 6f 20 64 69 73 6b 2e 20 53 6f 20 61  ed to disk. So a
4640: 74 20 74 68 69 73 20 70 6f 69 6e 74 20 77 65 20  t this point we 
4650: 6d 61 79 20 73 61 66 65 6c 79 20 6d 6f 64 69 66  may safely modif
4660: 79 0a 20 20 20 20 20 20 20 20 20 20 2a 2a 20 74  y.          ** t
4670: 68 65 20 64 61 74 61 62 61 73 65 20 66 69 6c 65  he database file
4680: 20 69 6e 20 61 6e 79 20 77 61 79 2c 20 6b 6e 6f   in any way, kno
4690: 77 69 6e 67 20 74 68 61 74 20 69 66 20 61 20 70  wing that if a p
46a0: 6f 77 65 72 20 66 61 69 6c 75 72 65 0a 20 20 20  ower failure.   
46b0: 20 20 20 20 20 20 20 2a 2a 20 6f 63 63 75 72 73         ** occurs
46c0: 2c 20 74 68 65 20 6f 72 69 67 69 6e 61 6c 20 64  , the original d
46d0: 61 74 61 62 61 73 65 20 77 69 6c 6c 20 62 65 20  atabase will be 
46e0: 72 65 63 6f 6e 73 74 72 75 63 74 65 64 20 66 72  reconstructed fr
46f0: 6f 6d 20 74 68 65 20 0a 20 20 20 20 20 20 20 20  om the .        
4700: 20 20 2a 2a 20 6a 6f 75 72 6e 61 6c 20 66 69 6c    ** journal fil
4710: 65 2e 20 20 2a 2f 0a 20 20 20 20 20 20 20 20 20  e.  */.         
4720: 20 73 71 6c 69 74 65 33 50 61 67 65 72 50 61 67   sqlite3PagerPag
4730: 65 63 6f 75 6e 74 28 70 44 65 73 74 50 61 67 65  ecount(pDestPage
4740: 72 2c 20 26 6e 44 73 74 50 61 67 65 29 3b 0a 20  r, &nDstPage);. 
4750: 20 20 20 20 20 20 20 20 20 66 6f 72 28 69 50 67           for(iPg
4760: 3d 6e 44 65 73 74 54 72 75 6e 63 61 74 65 3b 20  =nDestTruncate; 
4770: 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 26 26  rc==SQLITE_OK &&
4780: 20 69 50 67 3c 3d 28 50 67 6e 6f 29 6e 44 73 74   iPg<=(Pgno)nDst
4790: 50 61 67 65 3b 20 69 50 67 2b 2b 29 7b 0a 20 20  Page; iPg++){.  
47a0: 20 20 20 20 20 20 20 20 20 20 69 66 28 20 69 50            if( iP
47b0: 67 21 3d 50 45 4e 44 49 4e 47 5f 42 59 54 45 5f  g!=PENDING_BYTE_
47c0: 50 41 47 45 28 70 2d 3e 70 44 65 73 74 2d 3e 70  PAGE(p->pDest->p
47d0: 42 74 29 20 29 7b 0a 20 20 20 20 20 20 20 20 20  Bt) ){.         
47e0: 20 20 20 20 20 44 62 50 61 67 65 20 2a 70 50 67       DbPage *pPg
47f0: 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ;.              
4800: 72 63 20 3d 20 73 71 6c 69 74 65 33 50 61 67 65  rc = sqlite3Page
4810: 72 47 65 74 28 70 44 65 73 74 50 61 67 65 72 2c  rGet(pDestPager,
4820: 20 69 50 67 2c 20 26 70 50 67 29 3b 0a 20 20 20   iPg, &pPg);.   
4830: 20 20 20 20 20 20 20 20 20 20 20 69 66 28 20 72             if( r
4840: 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a  c==SQLITE_OK ){.
4850: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4860: 72 63 20 3d 20 73 71 6c 69 74 65 33 50 61 67 65  rc = sqlite3Page
4870: 72 57 72 69 74 65 28 70 50 67 29 3b 0a 20 20 20  rWrite(pPg);.   
4880: 20 20 20 20 20 20 20 20 20 20 20 20 20 73 71 6c               sql
4890: 69 74 65 33 50 61 67 65 72 55 6e 72 65 66 28 70  ite3PagerUnref(p
48a0: 50 67 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20  Pg);.           
48b0: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20     }.           
48c0: 20 7d 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20   }.          }. 
48d0: 20 20 20 20 20 20 20 20 20 69 66 28 20 72 63 3d           if( rc=
48e0: 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20  =SQLITE_OK ){.  
48f0: 20 20 20 20 20 20 20 20 20 20 72 63 20 3d 20 73            rc = s
4900: 71 6c 69 74 65 33 50 61 67 65 72 43 6f 6d 6d 69  qlite3PagerCommi
4910: 74 50 68 61 73 65 4f 6e 65 28 70 44 65 73 74 50  tPhaseOne(pDestP
4920: 61 67 65 72 2c 20 30 2c 20 31 29 3b 0a 20 20 20  ager, 0, 1);.   
4930: 20 20 20 20 20 20 20 7d 0a 0a 20 20 20 20 20 20         }..      
4940: 20 20 20 20 2f 2a 20 57 72 69 74 65 20 74 68 65      /* Write the
4950: 20 65 78 74 72 61 20 70 61 67 65 73 20 61 6e 64   extra pages and
4960: 20 74 72 75 6e 63 61 74 65 20 74 68 65 20 64 61   truncate the da
4970: 74 61 62 61 73 65 20 66 69 6c 65 20 61 73 20 72  tabase file as r
4980: 65 71 75 69 72 65 64 20 2a 2f 0a 20 20 20 20 20  equired */.     
4990: 20 20 20 20 20 69 45 6e 64 20 3d 20 4d 49 4e 28       iEnd = MIN(
49a0: 50 45 4e 44 49 4e 47 5f 42 59 54 45 20 2b 20 70  PENDING_BYTE + p
49b0: 67 73 7a 44 65 73 74 2c 20 69 53 69 7a 65 29 3b  gszDest, iSize);
49c0: 0a 20 20 20 20 20 20 20 20 20 20 66 6f 72 28 0a  .          for(.
49d0: 20 20 20 20 20 20 20 20 20 20 20 20 69 4f 66 66              iOff
49e0: 3d 50 45 4e 44 49 4e 47 5f 42 59 54 45 2b 70 67  =PENDING_BYTE+pg
49f0: 73 7a 53 72 63 3b 20 0a 20 20 20 20 20 20 20 20  szSrc; .        
4a00: 20 20 20 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f      rc==SQLITE_O
4a10: 4b 20 26 26 20 69 4f 66 66 3c 69 45 6e 64 3b 20  K && iOff<iEnd; 
4a20: 0a 20 20 20 20 20 20 20 20 20 20 20 20 69 4f 66  .            iOf
4a30: 66 2b 3d 70 67 73 7a 53 72 63 0a 20 20 20 20 20  f+=pgszSrc.     
4a40: 20 20 20 20 20 29 7b 0a 20 20 20 20 20 20 20 20       ){.        
4a50: 20 20 20 20 50 67 48 64 72 20 2a 70 53 72 63 50      PgHdr *pSrcP
4a60: 67 20 3d 20 30 3b 0a 20 20 20 20 20 20 20 20 20  g = 0;.         
4a70: 20 20 20 63 6f 6e 73 74 20 50 67 6e 6f 20 69 53     const Pgno iS
4a80: 72 63 50 67 20 3d 20 28 50 67 6e 6f 29 28 28 69  rcPg = (Pgno)((i
4a90: 4f 66 66 2f 70 67 73 7a 53 72 63 29 2b 31 29 3b  Off/pgszSrc)+1);
4aa0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 63 20  .            rc 
4ab0: 3d 20 73 71 6c 69 74 65 33 50 61 67 65 72 47 65  = sqlite3PagerGe
4ac0: 74 28 70 53 72 63 50 61 67 65 72 2c 20 69 53 72  t(pSrcPager, iSr
4ad0: 63 50 67 2c 20 26 70 53 72 63 50 67 29 3b 0a 20  cPg, &pSrcPg);. 
4ae0: 20 20 20 20 20 20 20 20 20 20 20 69 66 28 20 72             if( r
4af0: 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a  c==SQLITE_OK ){.
4b00: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 75 38                u8
4b10: 20 2a 7a 44 61 74 61 20 3d 20 73 71 6c 69 74 65   *zData = sqlite
4b20: 33 50 61 67 65 72 47 65 74 44 61 74 61 28 70 53  3PagerGetData(pS
4b30: 72 63 50 67 29 3b 0a 20 20 20 20 20 20 20 20 20  rcPg);.         
4b40: 20 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65       rc = sqlite
4b50: 33 4f 73 57 72 69 74 65 28 70 46 69 6c 65 2c 20  3OsWrite(pFile, 
4b60: 7a 44 61 74 61 2c 20 70 67 73 7a 53 72 63 2c 20  zData, pgszSrc, 
4b70: 69 4f 66 66 29 3b 0a 20 20 20 20 20 20 20 20 20  iOff);.         
4b80: 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20 20 20     }.           
4b90: 20 73 71 6c 69 74 65 33 50 61 67 65 72 55 6e 72   sqlite3PagerUnr
4ba0: 65 66 28 70 53 72 63 50 67 29 3b 0a 20 20 20 20  ef(pSrcPg);.    
4bb0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20        }.        
4bc0: 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45    if( rc==SQLITE
4bd0: 5f 4f 4b 20 29 7b 0a 20 20 20 20 20 20 20 20 20  _OK ){.         
4be0: 20 20 20 72 63 20 3d 20 62 61 63 6b 75 70 54 72     rc = backupTr
4bf0: 75 6e 63 61 74 65 46 69 6c 65 28 70 46 69 6c 65  uncateFile(pFile
4c00: 2c 20 69 53 69 7a 65 29 3b 0a 20 20 20 20 20 20  , iSize);.      
4c10: 20 20 20 20 7d 0a 0a 20 20 20 20 20 20 20 20 20      }..         
4c20: 20 2f 2a 20 53 79 6e 63 20 74 68 65 20 64 61 74   /* Sync the dat
4c30: 61 62 61 73 65 20 66 69 6c 65 20 74 6f 20 64 69  abase file to di
4c40: 73 6b 2e 20 2a 2f 0a 20 20 20 20 20 20 20 20 20  sk. */.         
4c50: 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f   if( rc==SQLITE_
4c60: 4f 4b 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  OK ){.          
4c70: 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 50 61    rc = sqlite3Pa
4c80: 67 65 72 53 79 6e 63 28 70 44 65 73 74 50 61 67  gerSync(pDestPag
4c90: 65 72 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d  er);.          }
4ca0: 0a 20 20 20 20 20 20 20 20 7d 65 6c 73 65 7b 0a  .        }else{.
4cb0: 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65            sqlite
4cc0: 33 50 61 67 65 72 54 72 75 6e 63 61 74 65 49 6d  3PagerTruncateIm
4cd0: 61 67 65 28 70 44 65 73 74 50 61 67 65 72 2c 20  age(pDestPager, 
4ce0: 6e 44 65 73 74 54 72 75 6e 63 61 74 65 29 3b 0a  nDestTruncate);.
4cf0: 20 20 20 20 20 20 20 20 20 20 72 63 20 3d 20 73            rc = s
4d00: 71 6c 69 74 65 33 50 61 67 65 72 43 6f 6d 6d 69  qlite3PagerCommi
4d10: 74 50 68 61 73 65 4f 6e 65 28 70 44 65 73 74 50  tPhaseOne(pDestP
4d20: 61 67 65 72 2c 20 30 2c 20 30 29 3b 0a 20 20 20  ager, 0, 0);.   
4d30: 20 20 20 20 20 7d 0a 20 20 20 20 0a 20 20 20 20       }.    .    
4d40: 20 20 20 20 2f 2a 20 46 69 6e 69 73 68 20 63 6f      /* Finish co
4d50: 6d 6d 69 74 74 69 6e 67 20 74 68 65 20 74 72 61  mmitting the tra
4d60: 6e 73 61 63 74 69 6f 6e 20 74 6f 20 74 68 65 20  nsaction to the 
4d70: 64 65 73 74 69 6e 61 74 69 6f 6e 20 64 61 74 61  destination data
4d80: 62 61 73 65 2e 20 2a 2f 0a 20 20 20 20 20 20 20  base. */.       
4d90: 20 69 66 28 20 53 51 4c 49 54 45 5f 4f 4b 3d 3d   if( SQLITE_OK==
4da0: 72 63 0a 20 20 20 20 20 20 20 20 20 26 26 20 53  rc.         && S
4db0: 51 4c 49 54 45 5f 4f 4b 3d 3d 28 72 63 20 3d 20  QLITE_OK==(rc = 
4dc0: 73 71 6c 69 74 65 33 42 74 72 65 65 43 6f 6d 6d  sqlite3BtreeComm
4dd0: 69 74 50 68 61 73 65 54 77 6f 28 70 2d 3e 70 44  itPhaseTwo(p->pD
4de0: 65 73 74 2c 20 30 29 29 0a 20 20 20 20 20 20 20  est, 0)).       
4df0: 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20 72 63   ){.          rc
4e00: 20 3d 20 53 51 4c 49 54 45 5f 44 4f 4e 45 3b 0a   = SQLITE_DONE;.
4e10: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
4e20: 7d 0a 20 20 20 20 7d 0a 20 20 0a 20 20 20 20 2f  }.    }.  .    /
4e30: 2a 20 49 66 20 62 43 6c 6f 73 65 54 72 61 6e 73  * If bCloseTrans
4e40: 20 69 73 20 74 72 75 65 2c 20 74 68 65 6e 20 74   is true, then t
4e50: 68 69 73 20 66 75 6e 63 74 69 6f 6e 20 6f 70 65  his function ope
4e60: 6e 65 64 20 61 20 72 65 61 64 20 74 72 61 6e 73  ned a read trans
4e70: 61 63 74 69 6f 6e 0a 20 20 20 20 2a 2a 20 6f 6e  action.    ** on
4e80: 20 74 68 65 20 73 6f 75 72 63 65 20 64 61 74 61   the source data
4e90: 62 61 73 65 2e 20 43 6c 6f 73 65 20 74 68 65 20  base. Close the 
4ea0: 72 65 61 64 20 74 72 61 6e 73 61 63 74 69 6f 6e  read transaction
4eb0: 20 68 65 72 65 2e 20 54 68 65 72 65 20 69 73 0a   here. There is.
4ec0: 20 20 20 20 2a 2a 20 6e 6f 20 6e 65 65 64 20 74      ** no need t
4ed0: 6f 20 63 68 65 63 6b 20 74 68 65 20 72 65 74 75  o check the retu
4ee0: 72 6e 20 76 61 6c 75 65 73 20 6f 66 20 74 68 65  rn values of the
4ef0: 20 62 74 72 65 65 20 6d 65 74 68 6f 64 73 20 68   btree methods h
4f00: 65 72 65 2c 20 61 73 0a 20 20 20 20 2a 2a 20 22  ere, as.    ** "
4f10: 63 6f 6d 6d 69 74 74 69 6e 67 22 20 61 20 72 65  committing" a re
4f20: 61 64 2d 6f 6e 6c 79 20 74 72 61 6e 73 61 63 74  ad-only transact
4f30: 69 6f 6e 20 63 61 6e 6e 6f 74 20 66 61 69 6c 2e  ion cannot fail.
4f40: 0a 20 20 20 20 2a 2f 0a 20 20 20 20 69 66 28 20  .    */.    if( 
4f50: 62 43 6c 6f 73 65 54 72 61 6e 73 20 29 7b 0a 20  bCloseTrans ){. 
4f60: 20 20 20 20 20 54 45 53 54 4f 4e 4c 59 28 20 69       TESTONLY( i
4f70: 6e 74 20 72 63 32 20 29 3b 0a 20 20 20 20 20 20  nt rc2 );.      
4f80: 54 45 53 54 4f 4e 4c 59 28 20 72 63 32 20 20 3d  TESTONLY( rc2  =
4f90: 20 29 20 73 71 6c 69 74 65 33 42 74 72 65 65 43   ) sqlite3BtreeC
4fa0: 6f 6d 6d 69 74 50 68 61 73 65 4f 6e 65 28 70 2d  ommitPhaseOne(p-
4fb0: 3e 70 53 72 63 2c 20 30 29 3b 0a 20 20 20 20 20  >pSrc, 0);.     
4fc0: 20 54 45 53 54 4f 4e 4c 59 28 20 72 63 32 20 7c   TESTONLY( rc2 |
4fd0: 3d 20 29 20 73 71 6c 69 74 65 33 42 74 72 65 65  = ) sqlite3Btree
4fe0: 43 6f 6d 6d 69 74 50 68 61 73 65 54 77 6f 28 70  CommitPhaseTwo(p
4ff0: 2d 3e 70 53 72 63 2c 20 30 29 3b 0a 20 20 20 20  ->pSrc, 0);.    
5000: 20 20 61 73 73 65 72 74 28 20 72 63 32 3d 3d 53    assert( rc2==S
5010: 51 4c 49 54 45 5f 4f 4b 20 29 3b 0a 20 20 20 20  QLITE_OK );.    
5020: 7d 0a 20 20 0a 20 20 20 20 69 66 28 20 72 63 3d  }.  .    if( rc=
5030: 3d 53 51 4c 49 54 45 5f 49 4f 45 52 52 5f 4e 4f  =SQLITE_IOERR_NO
5040: 4d 45 4d 20 29 7b 0a 20 20 20 20 20 20 72 63 20  MEM ){.      rc 
5050: 3d 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3b 0a  = SQLITE_NOMEM;.
5060: 20 20 20 20 7d 0a 20 20 20 20 70 2d 3e 72 63 20      }.    p->rc 
5070: 3d 20 72 63 3b 0a 20 20 7d 0a 20 20 69 66 28 20  = rc;.  }.  if( 
5080: 70 2d 3e 70 44 65 73 74 44 62 20 29 7b 0a 20 20  p->pDestDb ){.  
5090: 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f    sqlite3_mutex_
50a0: 6c 65 61 76 65 28 70 2d 3e 70 44 65 73 74 44 62  leave(p->pDestDb
50b0: 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 7d 0a 20 20  ->mutex);.  }.  
50c0: 73 71 6c 69 74 65 33 42 74 72 65 65 4c 65 61 76  sqlite3BtreeLeav
50d0: 65 28 70 2d 3e 70 53 72 63 29 3b 0a 20 20 73 71  e(p->pSrc);.  sq
50e0: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76  lite3_mutex_leav
50f0: 65 28 70 2d 3e 70 53 72 63 44 62 2d 3e 6d 75 74  e(p->pSrcDb->mut
5100: 65 78 29 3b 0a 20 20 72 65 74 75 72 6e 20 72 63  ex);.  return rc
5110: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 6c 65 61  ;.}../*.** Relea
5120: 73 65 20 61 6c 6c 20 72 65 73 6f 75 72 63 65 73  se all resources
5130: 20 61 73 73 6f 63 69 61 74 65 64 20 77 69 74 68   associated with
5140: 20 61 6e 20 73 71 6c 69 74 65 33 5f 62 61 63 6b   an sqlite3_back
5150: 75 70 2a 20 68 61 6e 64 6c 65 2e 0a 2a 2f 0a 69  up* handle..*/.i
5160: 6e 74 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75  nt sqlite3_backu
5170: 70 5f 66 69 6e 69 73 68 28 73 71 6c 69 74 65 33  p_finish(sqlite3
5180: 5f 62 61 63 6b 75 70 20 2a 70 29 7b 0a 20 20 73  _backup *p){.  s
5190: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 2a  qlite3_backup **
51a0: 70 70 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  pp;             
51b0: 20 20 20 20 2f 2a 20 50 74 72 20 74 6f 20 68 65      /* Ptr to he
51c0: 61 64 20 6f 66 20 70 61 67 65 72 73 20 62 61 63  ad of pagers bac
51d0: 6b 75 70 20 6c 69 73 74 20 2a 2f 0a 20 20 73 71  kup list */.  sq
51e0: 6c 69 74 65 33 20 2a 70 53 72 63 44 62 3b 20 20  lite3 *pSrcDb;  
51f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5200: 20 20 20 2f 2a 20 53 6f 75 72 63 65 20 64 61 74     /* Source dat
5210: 61 62 61 73 65 20 63 6f 6e 6e 65 63 74 69 6f 6e  abase connection
5220: 20 2a 2f 0a 20 20 69 6e 74 20 72 63 3b 20 20 20   */.  int rc;   
5230: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5240: 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 56 61             /* Va
5250: 6c 75 65 20 74 6f 20 72 65 74 75 72 6e 20 2a 2f  lue to return */
5260: 0a 0a 20 20 2f 2a 20 45 6e 74 65 72 20 74 68 65  ..  /* Enter the
5270: 20 6d 75 74 65 78 65 73 20 2a 2f 0a 20 20 69 66   mutexes */.  if
5280: 28 20 70 3d 3d 30 20 29 20 72 65 74 75 72 6e 20  ( p==0 ) return 
5290: 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 70 53 72  SQLITE_OK;.  pSr
52a0: 63 44 62 20 3d 20 70 2d 3e 70 53 72 63 44 62 3b  cDb = p->pSrcDb;
52b0: 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78  .  sqlite3_mutex
52c0: 5f 65 6e 74 65 72 28 70 53 72 63 44 62 2d 3e 6d  _enter(pSrcDb->m
52d0: 75 74 65 78 29 3b 0a 20 20 73 71 6c 69 74 65 33  utex);.  sqlite3
52e0: 42 74 72 65 65 45 6e 74 65 72 28 70 2d 3e 70 53  BtreeEnter(p->pS
52f0: 72 63 29 3b 0a 20 20 69 66 28 20 70 2d 3e 70 44  rc);.  if( p->pD
5300: 65 73 74 44 62 20 29 7b 0a 20 20 20 20 73 71 6c  estDb ){.    sql
5310: 69 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72  ite3_mutex_enter
5320: 28 70 2d 3e 70 44 65 73 74 44 62 2d 3e 6d 75 74  (p->pDestDb->mut
5330: 65 78 29 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 44  ex);.  }..  /* D
5340: 65 74 61 63 68 20 74 68 69 73 20 62 61 63 6b 75  etach this backu
5350: 70 20 66 72 6f 6d 20 74 68 65 20 73 6f 75 72 63  p from the sourc
5360: 65 20 70 61 67 65 72 2e 20 2a 2f 0a 20 20 69 66  e pager. */.  if
5370: 28 20 70 2d 3e 70 44 65 73 74 44 62 20 29 7b 0a  ( p->pDestDb ){.
5380: 20 20 20 20 70 2d 3e 70 53 72 63 2d 3e 6e 42 61      p->pSrc->nBa
5390: 63 6b 75 70 2d 2d 3b 0a 20 20 7d 0a 20 20 69 66  ckup--;.  }.  if
53a0: 28 20 70 2d 3e 69 73 41 74 74 61 63 68 65 64 20  ( p->isAttached 
53b0: 29 7b 0a 20 20 20 20 70 70 20 3d 20 73 71 6c 69  ){.    pp = sqli
53c0: 74 65 33 50 61 67 65 72 42 61 63 6b 75 70 50 74  te3PagerBackupPt
53d0: 72 28 73 71 6c 69 74 65 33 42 74 72 65 65 50 61  r(sqlite3BtreePa
53e0: 67 65 72 28 70 2d 3e 70 53 72 63 29 29 3b 0a 20  ger(p->pSrc));. 
53f0: 20 20 20 77 68 69 6c 65 28 20 2a 70 70 21 3d 70     while( *pp!=p
5400: 20 29 7b 0a 20 20 20 20 20 20 70 70 20 3d 20 26   ){.      pp = &
5410: 28 2a 70 70 29 2d 3e 70 4e 65 78 74 3b 0a 20 20  (*pp)->pNext;.  
5420: 20 20 7d 0a 20 20 20 20 2a 70 70 20 3d 20 70 2d    }.    *pp = p-
5430: 3e 70 4e 65 78 74 3b 0a 20 20 7d 0a 0a 20 20 2f  >pNext;.  }..  /
5440: 2a 20 49 66 20 61 20 74 72 61 6e 73 61 63 74 69  * If a transacti
5450: 6f 6e 20 69 73 20 73 74 69 6c 6c 20 6f 70 65 6e  on is still open
5460: 20 6f 6e 20 74 68 65 20 42 74 72 65 65 2c 20 72   on the Btree, r
5470: 6f 6c 6c 20 69 74 20 62 61 63 6b 2e 20 2a 2f 0a  oll it back. */.
5480: 20 20 73 71 6c 69 74 65 33 42 74 72 65 65 52 6f    sqlite3BtreeRo
5490: 6c 6c 62 61 63 6b 28 70 2d 3e 70 44 65 73 74 2c  llback(p->pDest,
54a0: 20 53 51 4c 49 54 45 5f 4f 4b 29 3b 0a 0a 20 20   SQLITE_OK);..  
54b0: 2f 2a 20 53 65 74 20 74 68 65 20 65 72 72 6f 72  /* Set the error
54c0: 20 63 6f 64 65 20 6f 66 20 74 68 65 20 64 65 73   code of the des
54d0: 74 69 6e 61 74 69 6f 6e 20 64 61 74 61 62 61 73  tination databas
54e0: 65 20 68 61 6e 64 6c 65 2e 20 2a 2f 0a 20 20 72  e handle. */.  r
54f0: 63 20 3d 20 28 70 2d 3e 72 63 3d 3d 53 51 4c 49  c = (p->rc==SQLI
5500: 54 45 5f 44 4f 4e 45 29 20 3f 20 53 51 4c 49 54  TE_DONE) ? SQLIT
5510: 45 5f 4f 4b 20 3a 20 70 2d 3e 72 63 3b 0a 20 20  E_OK : p->rc;.  
5520: 73 71 6c 69 74 65 33 45 72 72 6f 72 28 70 2d 3e  sqlite3Error(p->
5530: 70 44 65 73 74 44 62 2c 20 72 63 2c 20 30 29 3b  pDestDb, rc, 0);
5540: 0a 0a 20 20 2f 2a 20 45 78 69 74 20 74 68 65 20  ..  /* Exit the 
5550: 6d 75 74 65 78 65 73 20 61 6e 64 20 66 72 65 65  mutexes and free
5560: 20 74 68 65 20 62 61 63 6b 75 70 20 63 6f 6e 74   the backup cont
5570: 65 78 74 20 73 74 72 75 63 74 75 72 65 2e 20 2a  ext structure. *
5580: 2f 0a 20 20 69 66 28 20 70 2d 3e 70 44 65 73 74  /.  if( p->pDest
5590: 44 62 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65  Db ){.    sqlite
55a0: 33 4c 65 61 76 65 4d 75 74 65 78 41 6e 64 43 6c  3LeaveMutexAndCl
55b0: 6f 73 65 5a 6f 6d 62 69 65 28 70 2d 3e 70 44 65  oseZombie(p->pDe
55c0: 73 74 44 62 29 3b 0a 20 20 7d 0a 20 20 73 71 6c  stDb);.  }.  sql
55d0: 69 74 65 33 42 74 72 65 65 4c 65 61 76 65 28 70  ite3BtreeLeave(p
55e0: 2d 3e 70 53 72 63 29 3b 0a 20 20 69 66 28 20 70  ->pSrc);.  if( p
55f0: 2d 3e 70 44 65 73 74 44 62 20 29 7b 0a 20 20 20  ->pDestDb ){.   
5600: 20 2f 2a 20 45 56 49 44 45 4e 43 45 2d 4f 46 3a   /* EVIDENCE-OF:
5610: 20 52 2d 36 34 38 35 32 2d 32 31 35 39 31 20 54   R-64852-21591 T
5620: 68 65 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75  he sqlite3_backu
5630: 70 20 6f 62 6a 65 63 74 20 69 73 20 63 72 65 61  p object is crea
5640: 74 65 64 20 62 79 20 61 0a 20 20 20 20 2a 2a 20  ted by a.    ** 
5650: 63 61 6c 6c 20 74 6f 20 73 71 6c 69 74 65 33 5f  call to sqlite3_
5660: 62 61 63 6b 75 70 5f 69 6e 69 74 28 29 20 61 6e  backup_init() an
5670: 64 20 69 73 20 64 65 73 74 72 6f 79 65 64 20 62  d is destroyed b
5680: 79 20 61 20 63 61 6c 6c 20 74 6f 0a 20 20 20 20  y a call to.    
5690: 2a 2a 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75  ** sqlite3_backu
56a0: 70 5f 66 69 6e 69 73 68 28 29 2e 20 2a 2f 0a 20  p_finish(). */. 
56b0: 20 20 20 73 71 6c 69 74 65 33 5f 66 72 65 65 28     sqlite3_free(
56c0: 70 29 3b 0a 20 20 7d 0a 20 20 73 71 6c 69 74 65  p);.  }.  sqlite
56d0: 33 4c 65 61 76 65 4d 75 74 65 78 41 6e 64 43 6c  3LeaveMutexAndCl
56e0: 6f 73 65 5a 6f 6d 62 69 65 28 70 53 72 63 44 62  oseZombie(pSrcDb
56f0: 29 3b 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a  );.  return rc;.
5700: 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20  }../*.** Return 
5710: 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 70 61  the number of pa
5720: 67 65 73 20 73 74 69 6c 6c 20 74 6f 20 62 65 20  ges still to be 
5730: 62 61 63 6b 65 64 20 75 70 20 61 73 20 6f 66 20  backed up as of 
5740: 74 68 65 20 6d 6f 73 74 20 72 65 63 65 6e 74 0a  the most recent.
5750: 2a 2a 20 63 61 6c 6c 20 74 6f 20 73 71 6c 69 74  ** call to sqlit
5760: 65 33 5f 62 61 63 6b 75 70 5f 73 74 65 70 28 29  e3_backup_step()
5770: 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33  ..*/.int sqlite3
5780: 5f 62 61 63 6b 75 70 5f 72 65 6d 61 69 6e 69 6e  _backup_remainin
5790: 67 28 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70  g(sqlite3_backup
57a0: 20 2a 70 29 7b 0a 20 20 72 65 74 75 72 6e 20 70   *p){.  return p
57b0: 2d 3e 6e 52 65 6d 61 69 6e 69 6e 67 3b 0a 7d 0a  ->nRemaining;.}.
57c0: 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68  ./*.** Return th
57d0: 65 20 74 6f 74 61 6c 20 6e 75 6d 62 65 72 20 6f  e total number o
57e0: 66 20 70 61 67 65 73 20 69 6e 20 74 68 65 20 73  f pages in the s
57f0: 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 20 61  ource database a
5800: 73 20 6f 66 20 74 68 65 20 6d 6f 73 74 20 0a 2a  s of the most .*
5810: 2a 20 72 65 63 65 6e 74 20 63 61 6c 6c 20 74 6f  * recent call to
5820: 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f   sqlite3_backup_
5830: 73 74 65 70 28 29 2e 0a 2a 2f 0a 69 6e 74 20 73  step()..*/.int s
5840: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 70 61  qlite3_backup_pa
5850: 67 65 63 6f 75 6e 74 28 73 71 6c 69 74 65 33 5f  gecount(sqlite3_
5860: 62 61 63 6b 75 70 20 2a 70 29 7b 0a 20 20 72 65  backup *p){.  re
5870: 74 75 72 6e 20 70 2d 3e 6e 50 61 67 65 63 6f 75  turn p->nPagecou
5880: 6e 74 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 69  nt;.}../*.** Thi
5890: 73 20 66 75 6e 63 74 69 6f 6e 20 69 73 20 63 61  s function is ca
58a0: 6c 6c 65 64 20 61 66 74 65 72 20 74 68 65 20 63  lled after the c
58b0: 6f 6e 74 65 6e 74 73 20 6f 66 20 70 61 67 65 20  ontents of page 
58c0: 69 50 61 67 65 20 6f 66 20 74 68 65 0a 2a 2a 20  iPage of the.** 
58d0: 73 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 20  source database 
58e0: 68 61 76 65 20 62 65 65 6e 20 6d 6f 64 69 66 69  have been modifi
58f0: 65 64 2e 20 49 66 20 70 61 67 65 20 69 50 61 67  ed. If page iPag
5900: 65 20 68 61 73 20 61 6c 72 65 61 64 79 20 62 65  e has already be
5910: 65 6e 20 0a 2a 2a 20 63 6f 70 69 65 64 20 69 6e  en .** copied in
5920: 74 6f 20 74 68 65 20 64 65 73 74 69 6e 61 74 69  to the destinati
5930: 6f 6e 20 64 61 74 61 62 61 73 65 2c 20 74 68 65  on database, the
5940: 6e 20 74 68 65 20 64 61 74 61 20 77 72 69 74 74  n the data writt
5950: 65 6e 20 74 6f 20 74 68 65 0a 2a 2a 20 64 65 73  en to the.** des
5960: 74 69 6e 61 74 69 6f 6e 20 69 73 20 6e 6f 77 20  tination is now 
5970: 69 6e 76 61 6c 69 64 61 74 65 64 2e 20 54 68 65  invalidated. The
5980: 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 63 6f 70   destination cop
5990: 79 20 6f 66 20 69 50 61 67 65 20 6e 65 65 64 73  y of iPage needs
59a0: 0a 2a 2a 20 74 6f 20 62 65 20 75 70 64 61 74 65  .** to be update
59b0: 64 20 77 69 74 68 20 74 68 65 20 6e 65 77 20 64  d with the new d
59c0: 61 74 61 20 62 65 66 6f 72 65 20 74 68 65 20 62  ata before the b
59d0: 61 63 6b 75 70 20 6f 70 65 72 61 74 69 6f 6e 20  ackup operation 
59e0: 69 73 0a 2a 2a 20 63 6f 6d 70 6c 65 74 65 2e 0a  is.** complete..
59f0: 2a 2a 0a 2a 2a 20 49 74 20 69 73 20 61 73 73 75  **.** It is assu
5a00: 6d 65 64 20 74 68 61 74 20 74 68 65 20 6d 75 74  med that the mut
5a10: 65 78 20 61 73 73 6f 63 69 61 74 65 64 20 77 69  ex associated wi
5a20: 74 68 20 74 68 65 20 42 74 53 68 61 72 65 64 20  th the BtShared 
5a30: 6f 62 6a 65 63 74 0a 2a 2a 20 63 6f 72 72 65 73  object.** corres
5a40: 70 6f 6e 64 69 6e 67 20 74 6f 20 74 68 65 20 73  ponding to the s
5a50: 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 20 69  ource database i
5a60: 73 20 68 65 6c 64 20 77 68 65 6e 20 74 68 69 73  s held when this
5a70: 20 66 75 6e 63 74 69 6f 6e 20 69 73 0a 2a 2a 20   function is.** 
5a80: 63 61 6c 6c 65 64 2e 0a 2a 2f 0a 76 6f 69 64 20  called..*/.void 
5a90: 73 71 6c 69 74 65 33 42 61 63 6b 75 70 55 70 64  sqlite3BackupUpd
5aa0: 61 74 65 28 73 71 6c 69 74 65 33 5f 62 61 63 6b  ate(sqlite3_back
5ab0: 75 70 20 2a 70 42 61 63 6b 75 70 2c 20 50 67 6e  up *pBackup, Pgn
5ac0: 6f 20 69 50 61 67 65 2c 20 63 6f 6e 73 74 20 75  o iPage, const u
5ad0: 38 20 2a 61 44 61 74 61 29 7b 0a 20 20 73 71 6c  8 *aData){.  sql
5ae0: 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 3b 20  ite3_backup *p; 
5af0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
5b00: 20 20 2f 2a 20 49 74 65 72 61 74 6f 72 20 76 61    /* Iterator va
5b10: 72 69 61 62 6c 65 20 2a 2f 0a 20 20 66 6f 72 28  riable */.  for(
5b20: 70 3d 70 42 61 63 6b 75 70 3b 20 70 3b 20 70 3d  p=pBackup; p; p=
5b30: 70 2d 3e 70 4e 65 78 74 29 7b 0a 20 20 20 20 61  p->pNext){.    a
5b40: 73 73 65 72 74 28 20 73 71 6c 69 74 65 33 5f 6d  ssert( sqlite3_m
5b50: 75 74 65 78 5f 68 65 6c 64 28 70 2d 3e 70 53 72  utex_held(p->pSr
5b60: 63 2d 3e 70 42 74 2d 3e 6d 75 74 65 78 29 20 29  c->pBt->mutex) )
5b70: 3b 0a 20 20 20 20 69 66 28 20 21 69 73 46 61 74  ;.    if( !isFat
5b80: 61 6c 45 72 72 6f 72 28 70 2d 3e 72 63 29 20 26  alError(p->rc) &
5b90: 26 20 69 50 61 67 65 3c 70 2d 3e 69 4e 65 78 74  & iPage<p->iNext
5ba0: 20 29 7b 0a 20 20 20 20 20 20 2f 2a 20 54 68 65   ){.      /* The
5bb0: 20 62 61 63 6b 75 70 20 70 72 6f 63 65 73 73 20   backup process 
5bc0: 70 20 68 61 73 20 61 6c 72 65 61 64 79 20 63 6f  p has already co
5bd0: 70 69 65 64 20 70 61 67 65 20 69 50 61 67 65 2e  pied page iPage.
5be0: 20 42 75 74 20 6e 6f 77 20 69 74 0a 20 20 20 20   But now it.    
5bf0: 20 20 2a 2a 20 68 61 73 20 62 65 65 6e 20 6d 6f    ** has been mo
5c00: 64 69 66 69 65 64 20 62 79 20 61 20 74 72 61 6e  dified by a tran
5c10: 73 61 63 74 69 6f 6e 20 6f 6e 20 74 68 65 20 73  saction on the s
5c20: 6f 75 72 63 65 20 70 61 67 65 72 2e 20 43 6f 70  ource pager. Cop
5c30: 79 0a 20 20 20 20 20 20 2a 2a 20 74 68 65 20 6e  y.      ** the n
5c40: 65 77 20 64 61 74 61 20 69 6e 74 6f 20 74 68 65  ew data into the
5c50: 20 62 61 63 6b 75 70 2e 0a 20 20 20 20 20 20 2a   backup..      *
5c60: 2f 0a 20 20 20 20 20 20 69 6e 74 20 72 63 3b 0a  /.      int rc;.
5c70: 20 20 20 20 20 20 61 73 73 65 72 74 28 20 70 2d        assert( p-
5c80: 3e 70 44 65 73 74 44 62 20 29 3b 0a 20 20 20 20  >pDestDb );.    
5c90: 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f    sqlite3_mutex_
5ca0: 65 6e 74 65 72 28 70 2d 3e 70 44 65 73 74 44 62  enter(p->pDestDb
5cb0: 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 20 20 20 20  ->mutex);.      
5cc0: 72 63 20 3d 20 62 61 63 6b 75 70 4f 6e 65 50 61  rc = backupOnePa
5cd0: 67 65 28 70 2c 20 69 50 61 67 65 2c 20 61 44 61  ge(p, iPage, aDa
5ce0: 74 61 2c 20 31 29 3b 0a 20 20 20 20 20 20 73 71  ta, 1);.      sq
5cf0: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76  lite3_mutex_leav
5d00: 65 28 70 2d 3e 70 44 65 73 74 44 62 2d 3e 6d 75  e(p->pDestDb->mu
5d10: 74 65 78 29 3b 0a 20 20 20 20 20 20 61 73 73 65  tex);.      asse
5d20: 72 74 28 20 72 63 21 3d 53 51 4c 49 54 45 5f 42  rt( rc!=SQLITE_B
5d30: 55 53 59 20 26 26 20 72 63 21 3d 53 51 4c 49 54  USY && rc!=SQLIT
5d40: 45 5f 4c 4f 43 4b 45 44 20 29 3b 0a 20 20 20 20  E_LOCKED );.    
5d50: 20 20 69 66 28 20 72 63 21 3d 53 51 4c 49 54 45    if( rc!=SQLITE
5d60: 5f 4f 4b 20 29 7b 0a 20 20 20 20 20 20 20 20 70  _OK ){.        p
5d70: 2d 3e 72 63 20 3d 20 72 63 3b 0a 20 20 20 20 20  ->rc = rc;.     
5d80: 20 7d 0a 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a 0a   }.    }.  }.}..
5d90: 2f 2a 0a 2a 2a 20 52 65 73 74 61 72 74 20 74 68  /*.** Restart th
5da0: 65 20 62 61 63 6b 75 70 20 70 72 6f 63 65 73 73  e backup process
5db0: 2e 20 54 68 69 73 20 69 73 20 63 61 6c 6c 65 64  . This is called
5dc0: 20 77 68 65 6e 20 74 68 65 20 70 61 67 65 72 20   when the pager 
5dd0: 6c 61 79 65 72 0a 2a 2a 20 64 65 74 65 63 74 73  layer.** detects
5de0: 20 74 68 61 74 20 74 68 65 20 64 61 74 61 62 61   that the databa
5df0: 73 65 20 68 61 73 20 62 65 65 6e 20 6d 6f 64 69  se has been modi
5e00: 66 69 65 64 20 62 79 20 61 6e 20 65 78 74 65 72  fied by an exter
5e10: 6e 61 6c 20 64 61 74 61 62 61 73 65 0a 2a 2a 20  nal database.** 
5e20: 63 6f 6e 6e 65 63 74 69 6f 6e 2e 20 49 6e 20 74  connection. In t
5e30: 68 69 73 20 63 61 73 65 20 74 68 65 72 65 20 69  his case there i
5e40: 73 20 6e 6f 20 77 61 79 20 6f 66 20 6b 6e 6f 77  s no way of know
5e50: 69 6e 67 20 77 68 69 63 68 20 6f 66 20 74 68 65  ing which of the
5e60: 0a 2a 2a 20 70 61 67 65 73 20 74 68 61 74 20 68  .** pages that h
5e70: 61 76 65 20 62 65 65 6e 20 63 6f 70 69 65 64 20  ave been copied 
5e80: 69 6e 74 6f 20 74 68 65 20 64 65 73 74 69 6e 61  into the destina
5e90: 74 69 6f 6e 20 64 61 74 61 62 61 73 65 20 61 72  tion database ar
5ea0: 65 20 73 74 69 6c 6c 20 0a 2a 2a 20 76 61 6c 69  e still .** vali
5eb0: 64 20 61 6e 64 20 77 68 69 63 68 20 61 72 65 20  d and which are 
5ec0: 6e 6f 74 2c 20 73 6f 20 74 68 65 20 65 6e 74 69  not, so the enti
5ed0: 72 65 20 70 72 6f 63 65 73 73 20 6e 65 65 64 73  re process needs
5ee0: 20 74 6f 20 62 65 20 72 65 73 74 61 72 74 65 64   to be restarted
5ef0: 2e 0a 2a 2a 0a 2a 2a 20 49 74 20 69 73 20 61 73  ..**.** It is as
5f00: 73 75 6d 65 64 20 74 68 61 74 20 74 68 65 20 6d  sumed that the m
5f10: 75 74 65 78 20 61 73 73 6f 63 69 61 74 65 64 20  utex associated 
5f20: 77 69 74 68 20 74 68 65 20 42 74 53 68 61 72 65  with the BtShare
5f30: 64 20 6f 62 6a 65 63 74 0a 2a 2a 20 63 6f 72 72  d object.** corr
5f40: 65 73 70 6f 6e 64 69 6e 67 20 74 6f 20 74 68 65  esponding to the
5f50: 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73 65   source database
5f60: 20 69 73 20 68 65 6c 64 20 77 68 65 6e 20 74 68   is held when th
5f70: 69 73 20 66 75 6e 63 74 69 6f 6e 20 69 73 0a 2a  is function is.*
5f80: 2a 20 63 61 6c 6c 65 64 2e 0a 2a 2f 0a 76 6f 69  * called..*/.voi
5f90: 64 20 73 71 6c 69 74 65 33 42 61 63 6b 75 70 52  d sqlite3BackupR
5fa0: 65 73 74 61 72 74 28 73 71 6c 69 74 65 33 5f 62  estart(sqlite3_b
5fb0: 61 63 6b 75 70 20 2a 70 42 61 63 6b 75 70 29 7b  ackup *pBackup){
5fc0: 0a 20 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75  .  sqlite3_backu
5fd0: 70 20 2a 70 3b 20 20 20 20 20 20 20 20 20 20 20  p *p;           
5fe0: 20 20 20 20 20 20 20 20 2f 2a 20 49 74 65 72 61          /* Itera
5ff0: 74 6f 72 20 76 61 72 69 61 62 6c 65 20 2a 2f 0a  tor variable */.
6000: 20 20 66 6f 72 28 70 3d 70 42 61 63 6b 75 70 3b    for(p=pBackup;
6010: 20 70 3b 20 70 3d 70 2d 3e 70 4e 65 78 74 29 7b   p; p=p->pNext){
6020: 0a 20 20 20 20 61 73 73 65 72 74 28 20 73 71 6c  .    assert( sql
6030: 69 74 65 33 5f 6d 75 74 65 78 5f 68 65 6c 64 28  ite3_mutex_held(
6040: 70 2d 3e 70 53 72 63 2d 3e 70 42 74 2d 3e 6d 75  p->pSrc->pBt->mu
6050: 74 65 78 29 20 29 3b 0a 20 20 20 20 70 2d 3e 69  tex) );.    p->i
6060: 4e 65 78 74 20 3d 20 31 3b 0a 20 20 7d 0a 7d 0a  Next = 1;.  }.}.
6070: 0a 23 69 66 6e 64 65 66 20 53 51 4c 49 54 45 5f  .#ifndef SQLITE_
6080: 4f 4d 49 54 5f 56 41 43 55 55 4d 0a 2f 2a 0a 2a  OMIT_VACUUM./*.*
6090: 2a 20 43 6f 70 79 20 74 68 65 20 63 6f 6d 70 6c  * Copy the compl
60a0: 65 74 65 20 63 6f 6e 74 65 6e 74 20 6f 66 20 70  ete content of p
60b0: 42 74 46 72 6f 6d 20 69 6e 74 6f 20 70 42 74 54  BtFrom into pBtT
60c0: 6f 2e 20 20 41 20 74 72 61 6e 73 61 63 74 69 6f  o.  A transactio
60d0: 6e 0a 2a 2a 20 6d 75 73 74 20 62 65 20 61 63 74  n.** must be act
60e0: 69 76 65 20 66 6f 72 20 62 6f 74 68 20 66 69 6c  ive for both fil
60f0: 65 73 2e 0a 2a 2a 0a 2a 2a 20 54 68 65 20 73 69  es..**.** The si
6100: 7a 65 20 6f 66 20 66 69 6c 65 20 70 54 6f 20 6d  ze of file pTo m
6110: 61 79 20 62 65 20 72 65 64 75 63 65 64 20 62 79  ay be reduced by
6120: 20 74 68 69 73 20 6f 70 65 72 61 74 69 6f 6e 2e   this operation.
6130: 20 49 66 20 61 6e 79 74 68 69 6e 67 20 0a 2a 2a   If anything .**
6140: 20 67 6f 65 73 20 77 72 6f 6e 67 2c 20 74 68 65   goes wrong, the
6150: 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 6f 6e 20   transaction on 
6160: 70 54 6f 20 69 73 20 72 6f 6c 6c 65 64 20 62 61  pTo is rolled ba
6170: 63 6b 2e 20 49 66 20 73 75 63 63 65 73 73 66 75  ck. If successfu
6180: 6c 2c 20 74 68 65 20 0a 2a 2a 20 74 72 61 6e 73  l, the .** trans
6190: 61 63 74 69 6f 6e 20 69 73 20 63 6f 6d 6d 69 74  action is commit
61a0: 74 65 64 20 62 65 66 6f 72 65 20 72 65 74 75 72  ted before retur
61b0: 6e 69 6e 67 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c  ning..*/.int sql
61c0: 69 74 65 33 42 74 72 65 65 43 6f 70 79 46 69 6c  ite3BtreeCopyFil
61d0: 65 28 42 74 72 65 65 20 2a 70 54 6f 2c 20 42 74  e(Btree *pTo, Bt
61e0: 72 65 65 20 2a 70 46 72 6f 6d 29 7b 0a 20 20 69  ree *pFrom){.  i
61f0: 6e 74 20 72 63 3b 0a 20 20 73 71 6c 69 74 65 33  nt rc;.  sqlite3
6200: 5f 66 69 6c 65 20 2a 70 46 64 3b 20 20 20 20 20  _file *pFd;     
6210: 20 20 20 20 20 20 20 20 20 2f 2a 20 46 69 6c 65           /* File
6220: 20 64 65 73 63 72 69 70 74 6f 72 20 66 6f 72 20   descriptor for 
6230: 64 61 74 61 62 61 73 65 20 70 54 6f 20 2a 2f 0a  database pTo */.
6240: 20 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70    sqlite3_backup
6250: 20 62 3b 0a 20 20 73 71 6c 69 74 65 33 42 74 72   b;.  sqlite3Btr
6260: 65 65 45 6e 74 65 72 28 70 54 6f 29 3b 0a 20 20  eeEnter(pTo);.  
6270: 73 71 6c 69 74 65 33 42 74 72 65 65 45 6e 74 65  sqlite3BtreeEnte
6280: 72 28 70 46 72 6f 6d 29 3b 0a 0a 20 20 61 73 73  r(pFrom);..  ass
6290: 65 72 74 28 20 73 71 6c 69 74 65 33 42 74 72 65  ert( sqlite3Btre
62a0: 65 49 73 49 6e 54 72 61 6e 73 28 70 54 6f 29 20  eIsInTrans(pTo) 
62b0: 29 3b 0a 20 20 70 46 64 20 3d 20 73 71 6c 69 74  );.  pFd = sqlit
62c0: 65 33 50 61 67 65 72 46 69 6c 65 28 73 71 6c 69  e3PagerFile(sqli
62d0: 74 65 33 42 74 72 65 65 50 61 67 65 72 28 70 54  te3BtreePager(pT
62e0: 6f 29 29 3b 0a 20 20 69 66 28 20 70 46 64 2d 3e  o));.  if( pFd->
62f0: 70 4d 65 74 68 6f 64 73 20 29 7b 0a 20 20 20 20  pMethods ){.    
6300: 69 36 34 20 6e 42 79 74 65 20 3d 20 73 71 6c 69  i64 nByte = sqli
6310: 74 65 33 42 74 72 65 65 47 65 74 50 61 67 65 53  te3BtreeGetPageS
6320: 69 7a 65 28 70 46 72 6f 6d 29 2a 28 69 36 34 29  ize(pFrom)*(i64)
6330: 73 71 6c 69 74 65 33 42 74 72 65 65 4c 61 73 74  sqlite3BtreeLast
6340: 50 61 67 65 28 70 46 72 6f 6d 29 3b 0a 20 20 20  Page(pFrom);.   
6350: 20 72 63 20 3d 20 73 71 6c 69 74 65 33 4f 73 46   rc = sqlite3OsF
6360: 69 6c 65 43 6f 6e 74 72 6f 6c 28 70 46 64 2c 20  ileControl(pFd, 
6370: 53 51 4c 49 54 45 5f 46 43 4e 54 4c 5f 4f 56 45  SQLITE_FCNTL_OVE
6380: 52 57 52 49 54 45 2c 20 26 6e 42 79 74 65 29 3b  RWRITE, &nByte);
6390: 0a 20 20 20 20 69 66 28 20 72 63 3d 3d 53 51 4c  .    if( rc==SQL
63a0: 49 54 45 5f 4e 4f 54 46 4f 55 4e 44 20 29 20 72  ITE_NOTFOUND ) r
63b0: 63 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20  c = SQLITE_OK;. 
63c0: 20 20 20 69 66 28 20 72 63 20 29 20 67 6f 74 6f     if( rc ) goto
63d0: 20 63 6f 70 79 5f 66 69 6e 69 73 68 65 64 3b 0a   copy_finished;.
63e0: 20 20 7d 0a 0a 20 20 2f 2a 20 53 65 74 20 75 70    }..  /* Set up
63f0: 20 61 6e 20 73 71 6c 69 74 65 33 5f 62 61 63 6b   an sqlite3_back
6400: 75 70 20 6f 62 6a 65 63 74 2e 20 73 71 6c 69 74  up object. sqlit
6410: 65 33 5f 62 61 63 6b 75 70 2e 70 44 65 73 74 44  e3_backup.pDestD
6420: 62 20 6d 75 73 74 20 62 65 20 73 65 74 0a 20 20  b must be set.  
6430: 2a 2a 20 74 6f 20 30 2e 20 54 68 69 73 20 69 73  ** to 0. This is
6440: 20 75 73 65 64 20 62 79 20 74 68 65 20 69 6d 70   used by the imp
6450: 6c 65 6d 65 6e 74 61 74 69 6f 6e 73 20 6f 66 20  lementations of 
6460: 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 73  sqlite3_backup_s
6470: 74 65 70 28 29 0a 20 20 2a 2a 20 61 6e 64 20 73  tep().  ** and s
6480: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 66 69  qlite3_backup_fi
6490: 6e 69 73 68 28 29 20 74 6f 20 64 65 74 65 63 74  nish() to detect
64a0: 20 74 68 61 74 20 74 68 65 79 20 61 72 65 20 62   that they are b
64b0: 65 69 6e 67 20 63 61 6c 6c 65 64 0a 20 20 2a 2a  eing called.  **
64c0: 20 66 72 6f 6d 20 74 68 69 73 20 66 75 6e 63 74   from this funct
64d0: 69 6f 6e 2c 20 6e 6f 74 20 64 69 72 65 63 74 6c  ion, not directl
64e0: 79 20 62 79 20 74 68 65 20 75 73 65 72 2e 0a 20  y by the user.. 
64f0: 20 2a 2f 0a 20 20 6d 65 6d 73 65 74 28 26 62 2c   */.  memset(&b,
6500: 20 30 2c 20 73 69 7a 65 6f 66 28 62 29 29 3b 0a   0, sizeof(b));.
6510: 20 20 62 2e 70 53 72 63 44 62 20 3d 20 70 46 72    b.pSrcDb = pFr
6520: 6f 6d 2d 3e 64 62 3b 0a 20 20 62 2e 70 53 72 63  om->db;.  b.pSrc
6530: 20 3d 20 70 46 72 6f 6d 3b 0a 20 20 62 2e 70 44   = pFrom;.  b.pD
6540: 65 73 74 20 3d 20 70 54 6f 3b 0a 20 20 62 2e 69  est = pTo;.  b.i
6550: 4e 65 78 74 20 3d 20 31 3b 0a 0a 20 20 2f 2a 20  Next = 1;..  /* 
6560: 30 78 37 46 46 46 46 46 46 46 20 69 73 20 74 68  0x7FFFFFFF is th
6570: 65 20 68 61 72 64 20 6c 69 6d 69 74 20 66 6f 72  e hard limit for
6580: 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 70   the number of p
6590: 61 67 65 73 20 69 6e 20 61 20 64 61 74 61 62 61  ages in a databa
65a0: 73 65 0a 20 20 2a 2a 20 66 69 6c 65 2e 20 42 79  se.  ** file. By
65b0: 20 70 61 73 73 69 6e 67 20 74 68 69 73 20 61 73   passing this as
65c0: 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 70   the number of p
65d0: 61 67 65 73 20 74 6f 20 63 6f 70 79 20 74 6f 0a  ages to copy to.
65e0: 20 20 2a 2a 20 73 71 6c 69 74 65 33 5f 62 61 63    ** sqlite3_bac
65f0: 6b 75 70 5f 73 74 65 70 28 29 2c 20 77 65 20 63  kup_step(), we c
6600: 61 6e 20 67 75 61 72 61 6e 74 65 65 20 74 68 61  an guarantee tha
6610: 74 20 74 68 65 20 63 6f 70 79 20 66 69 6e 69 73  t the copy finis
6620: 68 65 73 20 0a 20 20 2a 2a 20 77 69 74 68 69 6e  hes .  ** within
6630: 20 61 20 73 69 6e 67 6c 65 20 63 61 6c 6c 20 28   a single call (
6640: 75 6e 6c 65 73 73 20 61 6e 20 65 72 72 6f 72 20  unless an error 
6650: 6f 63 63 75 72 73 29 2e 20 54 68 65 20 61 73 73  occurs). The ass
6660: 65 72 74 28 29 20 73 74 61 74 65 6d 65 6e 74 0a  ert() statement.
6670: 20 20 2a 2a 20 63 68 65 63 6b 73 20 74 68 69 73    ** checks this
6680: 20 61 73 73 75 6d 70 74 69 6f 6e 20 2d 20 28 70   assumption - (p
6690: 2d 3e 72 63 29 20 73 68 6f 75 6c 64 20 62 65 20  ->rc) should be 
66a0: 73 65 74 20 74 6f 20 65 69 74 68 65 72 20 53 51  set to either SQ
66b0: 4c 49 54 45 5f 44 4f 4e 45 20 0a 20 20 2a 2a 20  LITE_DONE .  ** 
66c0: 6f 72 20 61 6e 20 65 72 72 6f 72 20 63 6f 64 65  or an error code
66d0: 2e 0a 20 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33  ..  */.  sqlite3
66e0: 5f 62 61 63 6b 75 70 5f 73 74 65 70 28 26 62 2c  _backup_step(&b,
66f0: 20 30 78 37 46 46 46 46 46 46 46 29 3b 0a 20 20   0x7FFFFFFF);.  
6700: 61 73 73 65 72 74 28 20 62 2e 72 63 21 3d 53 51  assert( b.rc!=SQ
6710: 4c 49 54 45 5f 4f 4b 20 29 3b 0a 20 20 72 63 20  LITE_OK );.  rc 
6720: 3d 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70  = sqlite3_backup
6730: 5f 66 69 6e 69 73 68 28 26 62 29 3b 0a 20 20 69  _finish(&b);.  i
6740: 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b  f( rc==SQLITE_OK
6750: 20 29 7b 0a 20 20 20 20 70 54 6f 2d 3e 70 42 74   ){.    pTo->pBt
6760: 2d 3e 62 74 73 46 6c 61 67 73 20 26 3d 20 7e 42  ->btsFlags &= ~B
6770: 54 53 5f 50 41 47 45 53 49 5a 45 5f 46 49 58 45  TS_PAGESIZE_FIXE
6780: 44 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20  D;.  }else{.    
6790: 73 71 6c 69 74 65 33 50 61 67 65 72 43 6c 65 61  sqlite3PagerClea
67a0: 72 43 61 63 68 65 28 73 71 6c 69 74 65 33 42 74  rCache(sqlite3Bt
67b0: 72 65 65 50 61 67 65 72 28 62 2e 70 44 65 73 74  reePager(b.pDest
67c0: 29 29 3b 0a 20 20 7d 0a 0a 20 20 61 73 73 65 72  ));.  }..  asser
67d0: 74 28 20 73 71 6c 69 74 65 33 42 74 72 65 65 49  t( sqlite3BtreeI
67e0: 73 49 6e 54 72 61 6e 73 28 70 54 6f 29 3d 3d 30  sInTrans(pTo)==0
67f0: 20 29 3b 0a 63 6f 70 79 5f 66 69 6e 69 73 68 65   );.copy_finishe
6800: 64 3a 0a 20 20 73 71 6c 69 74 65 33 42 74 72 65  d:.  sqlite3Btre
6810: 65 4c 65 61 76 65 28 70 46 72 6f 6d 29 3b 0a 20  eLeave(pFrom);. 
6820: 20 73 71 6c 69 74 65 33 42 74 72 65 65 4c 65 61   sqlite3BtreeLea
6830: 76 65 28 70 54 6f 29 3b 0a 20 20 72 65 74 75 72  ve(pTo);.  retur
6840: 6e 20 72 63 3b 0a 7d 0a 23 65 6e 64 69 66 20 2f  n rc;.}.#endif /
6850: 2a 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 56 41  * SQLITE_OMIT_VA
6860: 43 55 55 4d 20 2a 2f 0a                          CUUM */.