/ Hex Artifact Content
Login

Artifact 97a3859d8585eb4fcb1e81a795cf4b3fdd82f30f:


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 2a 0a 2a 2a 20 24 49 64 3a  ures..**.** $Id:
01f0: 20 62 61 63 6b 75 70 2e 63 2c 76 20 31 2e 31 38   backup.c,v 1.18
0200: 20 32 30 30 39 2f 30 37 2f 30 32 20 30 37 3a 34   2009/07/02 07:4
0210: 37 3a 33 33 20 64 61 6e 69 65 6c 6b 31 39 37 37  7:33 danielk1977
0220: 20 45 78 70 20 24 0a 2a 2f 0a 23 69 6e 63 6c 75   Exp $.*/.#inclu
0230: 64 65 20 22 73 71 6c 69 74 65 49 6e 74 2e 68 22  de "sqliteInt.h"
0240: 0a 23 69 6e 63 6c 75 64 65 20 22 62 74 72 65 65  .#include "btree
0250: 49 6e 74 2e 68 22 0a 0a 2f 2a 20 4d 61 63 72 6f  Int.h"../* Macro
0260: 20 74 6f 20 66 69 6e 64 20 74 68 65 20 6d 69 6e   to find the min
0270: 69 6d 75 6d 20 6f 66 20 74 77 6f 20 6e 75 6d 65  imum of two nume
0280: 72 69 63 20 76 61 6c 75 65 73 2e 0a 2a 2f 0a 23  ric values..*/.#
0290: 69 66 6e 64 65 66 20 4d 49 4e 0a 23 20 64 65 66  ifndef MIN.# def
02a0: 69 6e 65 20 4d 49 4e 28 78 2c 79 29 20 28 28 78  ine MIN(x,y) ((x
02b0: 29 3c 28 79 29 3f 28 78 29 3a 28 79 29 29 0a 23  )<(y)?(x):(y)).#
02c0: 65 6e 64 69 66 0a 0a 2f 2a 0a 2a 2a 20 53 74 72  endif../*.** Str
02d0: 75 63 74 75 72 65 20 61 6c 6c 6f 63 61 74 65 64  ucture allocated
02e0: 20 66 6f 72 20 65 61 63 68 20 62 61 63 6b 75 70   for each backup
02f0: 20 6f 70 65 72 61 74 69 6f 6e 2e 0a 2a 2f 0a 73   operation..*/.s
0300: 74 72 75 63 74 20 73 71 6c 69 74 65 33 5f 62 61  truct sqlite3_ba
0310: 63 6b 75 70 20 7b 0a 20 20 73 71 6c 69 74 65 33  ckup {.  sqlite3
0320: 2a 20 70 44 65 73 74 44 62 3b 20 20 20 20 20 20  * pDestDb;      
0330: 20 20 2f 2a 20 44 65 73 74 69 6e 61 74 69 6f 6e    /* Destination
0340: 20 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c 65   database handle
0350: 20 2a 2f 0a 20 20 42 74 72 65 65 20 2a 70 44 65   */.  Btree *pDe
0360: 73 74 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f  st;            /
0370: 2a 20 44 65 73 74 69 6e 61 74 69 6f 6e 20 62 2d  * Destination b-
0380: 74 72 65 65 20 66 69 6c 65 20 2a 2f 0a 20 20 75  tree file */.  u
0390: 33 32 20 69 44 65 73 74 53 63 68 65 6d 61 3b 20  32 iDestSchema; 
03a0: 20 20 20 20 20 20 20 20 2f 2a 20 4f 72 69 67 69          /* Origi
03b0: 6e 61 6c 20 73 63 68 65 6d 61 20 63 6f 6f 6b 69  nal schema cooki
03c0: 65 20 69 6e 20 64 65 73 74 69 6e 61 74 69 6f 6e  e in destination
03d0: 20 2a 2f 0a 20 20 69 6e 74 20 62 44 65 73 74 4c   */.  int bDestL
03e0: 6f 63 6b 65 64 3b 20 20 20 20 20 20 20 20 20 2f  ocked;         /
03f0: 2a 20 54 72 75 65 20 6f 6e 63 65 20 61 20 77 72  * True once a wr
0400: 69 74 65 2d 74 72 61 6e 73 61 63 74 69 6f 6e 20  ite-transaction 
0410: 69 73 20 6f 70 65 6e 20 6f 6e 20 70 44 65 73 74  is open on pDest
0420: 20 2a 2f 0a 0a 20 20 50 67 6e 6f 20 69 4e 65 78   */..  Pgno iNex
0430: 74 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20  t;              
0440: 2f 2a 20 50 61 67 65 20 6e 75 6d 62 65 72 20 6f  /* Page number o
0450: 66 20 74 68 65 20 6e 65 78 74 20 73 6f 75 72 63  f the next sourc
0460: 65 20 70 61 67 65 20 74 6f 20 63 6f 70 79 20 2a  e page to copy *
0470: 2f 0a 20 20 73 71 6c 69 74 65 33 2a 20 70 53 72  /.  sqlite3* pSr
0480: 63 44 62 3b 20 20 20 20 20 20 20 20 20 2f 2a 20  cDb;         /* 
0490: 53 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 20  Source database 
04a0: 68 61 6e 64 6c 65 20 2a 2f 0a 20 20 42 74 72 65  handle */.  Btre
04b0: 65 20 2a 70 53 72 63 3b 20 20 20 20 20 20 20 20  e *pSrc;        
04c0: 20 20 20 20 20 2f 2a 20 53 6f 75 72 63 65 20 62       /* Source b
04d0: 2d 74 72 65 65 20 66 69 6c 65 20 2a 2f 0a 0a 20  -tree file */.. 
04e0: 20 69 6e 74 20 72 63 3b 20 20 20 20 20 20 20 20   int rc;        
04f0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 42 61 63            /* Bac
0500: 6b 75 70 20 70 72 6f 63 65 73 73 20 65 72 72 6f  kup process erro
0510: 72 20 63 6f 64 65 20 2a 2f 0a 0a 20 20 2f 2a 20  r code */..  /* 
0520: 54 68 65 73 65 20 74 77 6f 20 76 61 72 69 61 62  These two variab
0530: 6c 65 73 20 61 72 65 20 73 65 74 20 62 79 20 65  les are set by e
0540: 76 65 72 79 20 63 61 6c 6c 20 74 6f 20 62 61 63  very call to bac
0550: 6b 75 70 5f 73 74 65 70 28 29 2e 20 54 68 65 79  kup_step(). They
0560: 20 61 72 65 0a 20 20 2a 2a 20 72 65 61 64 20 62   are.  ** read b
0570: 79 20 63 61 6c 6c 73 20 74 6f 20 62 61 63 6b 75  y calls to backu
0580: 70 5f 72 65 6d 61 69 6e 69 6e 67 28 29 20 61 6e  p_remaining() an
0590: 64 20 62 61 63 6b 75 70 5f 70 61 67 65 63 6f 75  d backup_pagecou
05a0: 6e 74 28 29 2e 0a 20 20 2a 2f 0a 20 20 50 67 6e  nt()..  */.  Pgn
05b0: 6f 20 6e 52 65 6d 61 69 6e 69 6e 67 3b 20 20 20  o nRemaining;   
05c0: 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20        /* Number 
05d0: 6f 66 20 70 61 67 65 73 20 6c 65 66 74 20 74 6f  of pages left to
05e0: 20 63 6f 70 79 20 2a 2f 0a 20 20 50 67 6e 6f 20   copy */.  Pgno 
05f0: 6e 50 61 67 65 63 6f 75 6e 74 3b 20 20 20 20 20  nPagecount;     
0600: 20 20 20 20 2f 2a 20 54 6f 74 61 6c 20 6e 75 6d      /* Total num
0610: 62 65 72 20 6f 66 20 70 61 67 65 73 20 74 6f 20  ber of pages to 
0620: 63 6f 70 79 20 2a 2f 0a 0a 20 20 69 6e 74 20 69  copy */..  int i
0630: 73 41 74 74 61 63 68 65 64 3b 20 20 20 20 20 20  sAttached;      
0640: 20 20 20 20 2f 2a 20 54 72 75 65 20 6f 6e 63 65      /* True once
0650: 20 62 61 63 6b 75 70 20 68 61 73 20 62 65 65 6e   backup has been
0660: 20 72 65 67 69 73 74 65 72 65 64 20 77 69 74 68   registered with
0670: 20 70 61 67 65 72 20 2a 2f 0a 20 20 73 71 6c 69   pager */.  sqli
0680: 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 4e 65 78  te3_backup *pNex
0690: 74 3b 20 20 20 2f 2a 20 4e 65 78 74 20 62 61 63  t;   /* Next bac
06a0: 6b 75 70 20 61 73 73 6f 63 69 61 74 65 64 20 77  kup associated w
06b0: 69 74 68 20 73 6f 75 72 63 65 20 70 61 67 65 72  ith source pager
06c0: 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20 54 48   */.};../*.** TH
06d0: 52 45 41 44 20 53 41 46 45 54 59 20 4e 4f 54 45  READ SAFETY NOTE
06e0: 53 3a 0a 2a 2a 0a 2a 2a 20 20 20 4f 6e 63 65 20  S:.**.**   Once 
06f0: 69 74 20 68 61 73 20 62 65 65 6e 20 63 72 65 61  it has been crea
0700: 74 65 64 20 75 73 69 6e 67 20 62 61 63 6b 75 70  ted using backup
0710: 5f 69 6e 69 74 28 29 2c 20 61 20 73 69 6e 67 6c  _init(), a singl
0720: 65 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70  e sqlite3_backup
0730: 0a 2a 2a 20 20 20 73 74 72 75 63 74 75 72 65 20  .**   structure 
0740: 6d 61 79 20 62 65 20 61 63 63 65 73 73 65 64 20  may be accessed 
0750: 76 69 61 20 74 77 6f 20 67 72 6f 75 70 73 20 6f  via two groups o
0760: 66 20 74 68 72 65 61 64 2d 73 61 66 65 20 65 6e  f thread-safe en
0770: 74 72 79 20 70 6f 69 6e 74 73 3a 0a 2a 2a 0a 2a  try points:.**.*
0780: 2a 20 20 20 20 20 2a 20 56 69 61 20 74 68 65 20  *     * Via the 
0790: 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 58  sqlite3_backup_X
07a0: 58 58 28 29 20 41 50 49 20 66 75 6e 63 74 69 6f  XX() API functio
07b0: 6e 20 62 61 63 6b 75 70 5f 73 74 65 70 28 29 20  n backup_step() 
07c0: 61 6e 64 20 0a 2a 2a 20 20 20 20 20 20 20 62 61  and .**       ba
07d0: 63 6b 75 70 5f 66 69 6e 69 73 68 28 29 2e 20 42  ckup_finish(). B
07e0: 6f 74 68 20 74 68 65 73 65 20 66 75 6e 63 74 69  oth these functi
07f0: 6f 6e 73 20 6f 62 74 61 69 6e 20 74 68 65 20 73  ons obtain the s
0800: 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 0a 2a  ource database.*
0810: 2a 20 20 20 20 20 20 20 68 61 6e 64 6c 65 20 6d  *       handle m
0820: 75 74 65 78 20 61 6e 64 20 74 68 65 20 6d 75 74  utex and the mut
0830: 65 78 20 61 73 73 6f 63 69 61 74 65 64 20 77 69  ex associated wi
0840: 74 68 20 74 68 65 20 73 6f 75 72 63 65 20 42 74  th the source Bt
0850: 53 68 61 72 65 64 20 0a 2a 2a 20 20 20 20 20 20  Shared .**      
0860: 20 73 74 72 75 63 74 75 72 65 2c 20 69 6e 20 74   structure, in t
0870: 68 61 74 20 6f 72 64 65 72 2e 0a 2a 2a 0a 2a 2a  hat order..**.**
0880: 20 20 20 20 20 2a 20 56 69 61 20 74 68 65 20 42       * Via the B
0890: 61 63 6b 75 70 55 70 64 61 74 65 28 29 20 61 6e  ackupUpdate() an
08a0: 64 20 42 61 63 6b 75 70 52 65 73 74 61 72 74 28  d BackupRestart(
08b0: 29 20 66 75 6e 63 74 69 6f 6e 73 2c 20 77 68 69  ) functions, whi
08c0: 63 68 20 61 72 65 0a 2a 2a 20 20 20 20 20 20 20  ch are.**       
08d0: 69 6e 76 6f 6b 65 64 20 62 79 20 74 68 65 20 70  invoked by the p
08e0: 61 67 65 72 20 6c 61 79 65 72 20 74 6f 20 72 65  ager layer to re
08f0: 70 6f 72 74 20 76 61 72 69 6f 75 73 20 73 74 61  port various sta
0900: 74 65 20 63 68 61 6e 67 65 73 20 69 6e 0a 2a 2a  te changes in.**
0910: 20 20 20 20 20 20 20 74 68 65 20 70 61 67 65 20         the page 
0920: 63 61 63 68 65 20 61 73 73 6f 63 69 61 74 65 64  cache associated
0930: 20 77 69 74 68 20 74 68 65 20 73 6f 75 72 63 65   with the source
0940: 20 64 61 74 61 62 61 73 65 2e 20 54 68 65 20 6d   database. The m
0950: 75 74 65 78 0a 2a 2a 20 20 20 20 20 20 20 61 73  utex.**       as
0960: 73 6f 63 69 61 74 65 64 20 77 69 74 68 20 74 68  sociated with th
0970: 65 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73  e source databas
0980: 65 20 42 74 53 68 61 72 65 64 20 73 74 72 75 63  e BtShared struc
0990: 74 75 72 65 20 77 69 6c 6c 20 61 6c 77 61 79 73  ture will always
09a0: 20 0a 2a 2a 20 20 20 20 20 20 20 62 65 20 68 65   .**       be he
09b0: 6c 64 20 77 68 65 6e 20 65 69 74 68 65 72 20 6f  ld when either o
09c0: 66 20 74 68 65 73 65 20 66 75 6e 63 74 69 6f 6e  f these function
09d0: 73 20 61 72 65 20 69 6e 76 6f 6b 65 64 2e 0a 2a  s are invoked..*
09e0: 2a 0a 2a 2a 20 20 20 54 68 65 20 6f 74 68 65 72  *.**   The other
09f0: 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f   sqlite3_backup_
0a00: 58 58 58 28 29 20 41 50 49 20 66 75 6e 63 74 69  XXX() API functi
0a10: 6f 6e 73 2c 20 62 61 63 6b 75 70 5f 72 65 6d 61  ons, backup_rema
0a20: 69 6e 69 6e 67 28 29 20 61 6e 64 0a 2a 2a 20 20  ining() and.**  
0a30: 20 62 61 63 6b 75 70 5f 70 61 67 65 63 6f 75 6e   backup_pagecoun
0a40: 74 28 29 20 61 72 65 20 6e 6f 74 20 74 68 72 65  t() are not thre
0a50: 61 64 2d 73 61 66 65 20 66 75 6e 63 74 69 6f 6e  ad-safe function
0a60: 73 2e 20 49 66 20 74 68 65 79 20 61 72 65 20 63  s. If they are c
0a70: 61 6c 6c 65 64 0a 2a 2a 20 20 20 77 68 69 6c 65  alled.**   while
0a80: 20 73 6f 6d 65 20 6f 74 68 65 72 20 74 68 72 65   some other thre
0a90: 61 64 20 69 73 20 63 61 6c 6c 69 6e 67 20 62 61  ad is calling ba
0aa0: 63 6b 75 70 5f 73 74 65 70 28 29 20 6f 72 20 62  ckup_step() or b
0ab0: 61 63 6b 75 70 5f 66 69 6e 69 73 68 28 29 2c 0a  ackup_finish(),.
0ac0: 2a 2a 20 20 20 74 68 65 20 76 61 6c 75 65 73 20  **   the values 
0ad0: 72 65 74 75 72 6e 65 64 20 6d 61 79 20 62 65 20  returned may be 
0ae0: 69 6e 76 61 6c 69 64 2e 20 54 68 65 72 65 20 69  invalid. There i
0af0: 73 20 6e 6f 20 77 61 79 20 66 6f 72 20 61 20 63  s no way for a c
0b00: 61 6c 6c 20 74 6f 0a 2a 2a 20 20 20 42 61 63 6b  all to.**   Back
0b10: 75 70 55 70 64 61 74 65 28 29 20 6f 72 20 42 61  upUpdate() or Ba
0b20: 63 6b 75 70 52 65 73 74 61 72 74 28 29 20 74 6f  ckupRestart() to
0b30: 20 69 6e 74 65 72 66 65 72 65 20 77 69 74 68 20   interfere with 
0b40: 62 61 63 6b 75 70 5f 72 65 6d 61 69 6e 69 6e 67  backup_remaining
0b50: 28 29 0a 2a 2a 20 20 20 6f 72 20 62 61 63 6b 75  ().**   or backu
0b60: 70 5f 70 61 67 65 63 6f 75 6e 74 28 29 2e 0a 2a  p_pagecount()..*
0b70: 2a 0a 2a 2a 20 20 20 44 65 70 65 6e 64 69 6e 67  *.**   Depending
0b80: 20 6f 6e 20 74 68 65 20 53 51 4c 69 74 65 20 63   on the SQLite c
0b90: 6f 6e 66 69 67 75 72 61 74 69 6f 6e 2c 20 74 68  onfiguration, th
0ba0: 65 20 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c  e database handl
0bb0: 65 73 20 61 6e 64 2f 6f 72 0a 2a 2a 20 20 20 74  es and/or.**   t
0bc0: 68 65 20 42 74 72 65 65 20 6f 62 6a 65 63 74 73  he Btree objects
0bd0: 20 6d 61 79 20 68 61 76 65 20 74 68 65 69 72 20   may have their 
0be0: 6f 77 6e 20 6d 75 74 65 78 65 73 20 74 68 61 74  own mutexes that
0bf0: 20 72 65 71 75 69 72 65 20 6c 6f 63 6b 69 6e 67   require locking
0c00: 2e 0a 2a 2a 20 20 20 4e 6f 6e 2d 73 68 61 72 61  ..**   Non-shara
0c10: 62 6c 65 20 42 74 72 65 65 73 20 28 69 6e 2d 6d  ble Btrees (in-m
0c20: 65 6d 6f 72 79 20 64 61 74 61 62 61 73 65 73 20  emory databases 
0c30: 66 6f 72 20 65 78 61 6d 70 6c 65 29 2c 20 64 6f  for example), do
0c40: 20 6e 6f 74 20 68 61 76 65 0a 2a 2a 20 20 20 61   not have.**   a
0c50: 73 73 6f 63 69 61 74 65 64 20 6d 75 74 65 78 65  ssociated mutexe
0c60: 73 2e 0a 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 52 65 74  s..*/../*.** Ret
0c70: 75 72 6e 20 61 20 70 6f 69 6e 74 65 72 20 63 6f  urn a pointer co
0c80: 72 72 65 73 70 6f 6e 64 69 6e 67 20 74 6f 20 64  rresponding to d
0c90: 61 74 61 62 61 73 65 20 7a 44 62 20 28 69 2e 65  atabase zDb (i.e
0ca0: 2e 20 22 6d 61 69 6e 22 2c 20 22 74 65 6d 70 22  . "main", "temp"
0cb0: 29 0a 2a 2a 20 69 6e 20 63 6f 6e 6e 65 63 74 69  ).** in connecti
0cc0: 6f 6e 20 68 61 6e 64 6c 65 20 70 44 62 2e 20 49  on handle pDb. I
0cd0: 66 20 73 75 63 68 20 61 20 64 61 74 61 62 61 73  f such a databas
0ce0: 65 20 63 61 6e 6e 6f 74 20 62 65 20 66 6f 75 6e  e cannot be foun
0cf0: 64 2c 20 72 65 74 75 72 6e 0a 2a 2a 20 61 20 4e  d, return.** a N
0d00: 55 4c 4c 20 70 6f 69 6e 74 65 72 20 61 6e 64 20  ULL pointer and 
0d10: 77 72 69 74 65 20 61 6e 20 65 72 72 6f 72 20 6d  write an error m
0d20: 65 73 73 61 67 65 20 74 6f 20 70 45 72 72 6f 72  essage to pError
0d30: 44 62 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 74 68 65  Db..**.** If the
0d40: 20 22 74 65 6d 70 22 20 64 61 74 61 62 61 73 65   "temp" database
0d50: 20 69 73 20 72 65 71 75 65 73 74 65 64 2c 20 69   is requested, i
0d60: 74 20 6d 61 79 20 6e 65 65 64 20 74 6f 20 62 65  t may need to be
0d70: 20 6f 70 65 6e 65 64 20 62 79 20 74 68 69 73 20   opened by this 
0d80: 0a 2a 2a 20 66 75 6e 63 74 69 6f 6e 2e 20 49 66  .** function. If
0d90: 20 61 6e 20 65 72 72 6f 72 20 6f 63 63 75 72 73   an error occurs
0da0: 20 77 68 69 6c 65 20 64 6f 69 6e 67 20 73 6f 2c   while doing so,
0db0: 20 72 65 74 75 72 6e 20 30 20 61 6e 64 20 77 72   return 0 and wr
0dc0: 69 74 65 20 61 6e 20 0a 2a 2a 20 65 72 72 6f 72  ite an .** error
0dd0: 20 6d 65 73 73 61 67 65 20 74 6f 20 70 45 72 72   message to pErr
0de0: 6f 72 44 62 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  orDb..*/.static 
0df0: 42 74 72 65 65 20 2a 66 69 6e 64 42 74 72 65 65  Btree *findBtree
0e00: 28 73 71 6c 69 74 65 33 20 2a 70 45 72 72 6f 72  (sqlite3 *pError
0e10: 44 62 2c 20 73 71 6c 69 74 65 33 20 2a 70 44 62  Db, sqlite3 *pDb
0e20: 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 44  , const char *zD
0e30: 62 29 7b 0a 20 20 69 6e 74 20 69 20 3d 20 73 71  b){.  int i = sq
0e40: 6c 69 74 65 33 46 69 6e 64 44 62 4e 61 6d 65 28  lite3FindDbName(
0e50: 70 44 62 2c 20 7a 44 62 29 3b 0a 0a 20 20 69 66  pDb, zDb);..  if
0e60: 28 20 69 3d 3d 31 20 29 7b 0a 20 20 20 20 50 61  ( i==1 ){.    Pa
0e70: 72 73 65 20 2a 70 50 61 72 73 65 3b 0a 20 20 20  rse *pParse;.   
0e80: 20 69 6e 74 20 72 63 20 3d 20 30 3b 0a 20 20 20   int rc = 0;.   
0e90: 20 70 50 61 72 73 65 20 3d 20 73 71 6c 69 74 65   pParse = sqlite
0ea0: 33 53 74 61 63 6b 41 6c 6c 6f 63 5a 65 72 6f 28  3StackAllocZero(
0eb0: 70 45 72 72 6f 72 44 62 2c 20 73 69 7a 65 6f 66  pErrorDb, sizeof
0ec0: 28 2a 70 50 61 72 73 65 29 29 3b 0a 20 20 20 20  (*pParse));.    
0ed0: 69 66 28 20 70 50 61 72 73 65 3d 3d 30 20 29 7b  if( pParse==0 ){
0ee0: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 45 72  .      sqlite3Er
0ef0: 72 6f 72 28 70 45 72 72 6f 72 44 62 2c 20 53 51  ror(pErrorDb, SQ
0f00: 4c 49 54 45 5f 4e 4f 4d 45 4d 2c 20 22 6f 75 74  LITE_NOMEM, "out
0f10: 20 6f 66 20 6d 65 6d 6f 72 79 22 29 3b 0a 20 20   of memory");.  
0f20: 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45 5f      rc = SQLITE_
0f30: 4e 4f 4d 45 4d 3b 0a 20 20 20 20 7d 65 6c 73 65  NOMEM;.    }else
0f40: 7b 0a 20 20 20 20 20 20 70 50 61 72 73 65 2d 3e  {.      pParse->
0f50: 64 62 20 3d 20 70 44 62 3b 0a 20 20 20 20 20 20  db = pDb;.      
0f60: 69 66 28 20 73 71 6c 69 74 65 33 4f 70 65 6e 54  if( sqlite3OpenT
0f70: 65 6d 70 44 61 74 61 62 61 73 65 28 70 50 61 72  empDatabase(pPar
0f80: 73 65 29 20 29 7b 0a 20 20 20 20 20 20 20 20 73  se) ){.        s
0f90: 71 6c 69 74 65 33 45 72 72 6f 72 43 6c 65 61 72  qlite3ErrorClear
0fa0: 28 70 50 61 72 73 65 29 3b 0a 20 20 20 20 20 20  (pParse);.      
0fb0: 20 20 73 71 6c 69 74 65 33 45 72 72 6f 72 28 70    sqlite3Error(p
0fc0: 45 72 72 6f 72 44 62 2c 20 70 50 61 72 73 65 2d  ErrorDb, pParse-
0fd0: 3e 72 63 2c 20 22 25 73 22 2c 20 70 50 61 72 73  >rc, "%s", pPars
0fe0: 65 2d 3e 7a 45 72 72 4d 73 67 29 3b 0a 20 20 20  e->zErrMsg);.   
0ff0: 20 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45       rc = SQLITE
1000: 5f 45 52 52 4f 52 3b 0a 20 20 20 20 20 20 7d 0a  _ERROR;.      }.
1010: 20 20 20 20 20 20 73 71 6c 69 74 65 33 53 74 61        sqlite3Sta
1020: 63 6b 46 72 65 65 28 70 45 72 72 6f 72 44 62 2c  ckFree(pErrorDb,
1030: 20 70 50 61 72 73 65 29 3b 0a 20 20 20 20 7d 0a   pParse);.    }.
1040: 20 20 20 20 69 66 28 20 72 63 20 29 7b 0a 20 20      if( rc ){.  
1050: 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20      return 0;.  
1060: 20 20 7d 0a 20 20 7d 0a 0a 20 20 69 66 28 20 69    }.  }..  if( i
1070: 3c 30 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65  <0 ){.    sqlite
1080: 33 45 72 72 6f 72 28 70 45 72 72 6f 72 44 62 2c  3Error(pErrorDb,
1090: 20 53 51 4c 49 54 45 5f 45 52 52 4f 52 2c 20 22   SQLITE_ERROR, "
10a0: 75 6e 6b 6e 6f 77 6e 20 64 61 74 61 62 61 73 65  unknown database
10b0: 20 25 73 22 2c 20 7a 44 62 29 3b 0a 20 20 20 20   %s", zDb);.    
10c0: 72 65 74 75 72 6e 20 30 3b 0a 20 20 7d 0a 0a 20  return 0;.  }.. 
10d0: 20 72 65 74 75 72 6e 20 70 44 62 2d 3e 61 44 62   return pDb->aDb
10e0: 5b 69 5d 2e 70 42 74 3b 0a 7d 0a 0a 2f 2a 0a 2a  [i].pBt;.}../*.*
10f0: 2a 20 43 72 65 61 74 65 20 61 6e 20 73 71 6c 69  * Create an sqli
1100: 74 65 33 5f 62 61 63 6b 75 70 20 70 72 6f 63 65  te3_backup proce
1110: 73 73 20 74 6f 20 63 6f 70 79 20 74 68 65 20 63  ss to copy the c
1120: 6f 6e 74 65 6e 74 73 20 6f 66 20 7a 53 72 63 44  ontents of zSrcD
1130: 62 20 66 72 6f 6d 0a 2a 2a 20 63 6f 6e 6e 65 63  b from.** connec
1140: 74 69 6f 6e 20 68 61 6e 64 6c 65 20 70 53 72 63  tion handle pSrc
1150: 44 62 20 74 6f 20 7a 44 65 73 74 44 62 20 69 6e  Db to zDestDb in
1160: 20 70 44 65 73 74 44 62 2e 20 49 66 20 73 75 63   pDestDb. If suc
1170: 63 65 73 73 66 75 6c 2c 20 72 65 74 75 72 6e 0a  cessful, return.
1180: 2a 2a 20 61 20 70 6f 69 6e 74 65 72 20 74 6f 20  ** a pointer to 
1190: 74 68 65 20 6e 65 77 20 73 71 6c 69 74 65 33 5f  the new sqlite3_
11a0: 62 61 63 6b 75 70 20 6f 62 6a 65 63 74 2e 0a 2a  backup object..*
11b0: 2a 0a 2a 2a 20 49 66 20 61 6e 20 65 72 72 6f 72  *.** If an error
11c0: 20 6f 63 63 75 72 73 2c 20 4e 55 4c 4c 20 69 73   occurs, NULL is
11d0: 20 72 65 74 75 72 6e 65 64 20 61 6e 64 20 61 6e   returned and an
11e0: 20 65 72 72 6f 72 20 63 6f 64 65 20 61 6e 64 20   error code and 
11f0: 65 72 72 6f 72 20 6d 65 73 73 61 67 65 0a 2a 2a  error message.**
1200: 20 73 74 6f 72 65 64 20 69 6e 20 64 61 74 61 62   stored in datab
1210: 61 73 65 20 68 61 6e 64 6c 65 20 70 44 65 73 74  ase handle pDest
1220: 44 62 2e 0a 2a 2f 0a 73 71 6c 69 74 65 33 5f 62  Db..*/.sqlite3_b
1230: 61 63 6b 75 70 20 2a 73 71 6c 69 74 65 33 5f 62  ackup *sqlite3_b
1240: 61 63 6b 75 70 5f 69 6e 69 74 28 0a 20 20 73 71  ackup_init(.  sq
1250: 6c 69 74 65 33 2a 20 70 44 65 73 74 44 62 2c 20  lite3* pDestDb, 
1260: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1270: 20 20 20 20 2f 2a 20 44 61 74 61 62 61 73 65 20      /* Database 
1280: 74 6f 20 77 72 69 74 65 20 74 6f 20 2a 2f 0a 20  to write to */. 
1290: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 44 65   const char *zDe
12a0: 73 74 44 62 2c 20 20 20 20 20 20 20 20 20 20 20  stDb,           
12b0: 20 20 20 20 20 20 20 2f 2a 20 4e 61 6d 65 20 6f         /* Name o
12c0: 66 20 64 61 74 61 62 61 73 65 20 77 69 74 68 69  f database withi
12d0: 6e 20 70 44 65 73 74 44 62 20 2a 2f 0a 20 20 73  n pDestDb */.  s
12e0: 71 6c 69 74 65 33 2a 20 70 53 72 63 44 62 2c 20  qlite3* pSrcDb, 
12f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1300: 20 20 20 20 20 2f 2a 20 44 61 74 61 62 61 73 65       /* Database
1310: 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 74 6f 20 72   connection to r
1320: 65 61 64 20 66 72 6f 6d 20 2a 2f 0a 20 20 63 6f  ead from */.  co
1330: 6e 73 74 20 63 68 61 72 20 2a 7a 53 72 63 44 62  nst char *zSrcDb
1340: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1350: 20 20 20 20 2f 2a 20 4e 61 6d 65 20 6f 66 20 64      /* Name of d
1360: 61 74 61 62 61 73 65 20 77 69 74 68 69 6e 20 70  atabase within p
1370: 53 72 63 44 62 20 2a 2f 0a 29 7b 0a 20 20 73 71  SrcDb */.){.  sq
1380: 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 3b  lite3_backup *p;
1390: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
13a0: 20 20 20 20 2f 2a 20 56 61 6c 75 65 20 74 6f 20      /* Value to 
13b0: 72 65 74 75 72 6e 20 2a 2f 0a 0a 20 20 2f 2a 20  return */..  /* 
13c0: 4c 6f 63 6b 20 74 68 65 20 73 6f 75 72 63 65 20  Lock the source 
13d0: 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c 65 2e  database handle.
13e0: 20 54 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e   The destination
13f0: 20 64 61 74 61 62 61 73 65 0a 20 20 2a 2a 20 68   database.  ** h
1400: 61 6e 64 6c 65 20 69 73 20 6e 6f 74 20 6c 6f 63  andle is not loc
1410: 6b 65 64 20 69 6e 20 74 68 69 73 20 72 6f 75 74  ked in this rout
1420: 69 6e 65 2c 20 62 75 74 20 69 74 20 69 73 20 6c  ine, but it is l
1430: 6f 63 6b 65 64 20 69 6e 0a 20 20 2a 2a 20 73 71  ocked in.  ** sq
1440: 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 73 74 65  lite3_backup_ste
1450: 70 28 29 2e 20 54 68 65 20 75 73 65 72 20 69 73  p(). The user is
1460: 20 72 65 71 75 69 72 65 64 20 74 6f 20 65 6e 73   required to ens
1470: 75 72 65 20 74 68 61 74 20 6e 6f 0a 20 20 2a 2a  ure that no.  **
1480: 20 6f 74 68 65 72 20 74 68 72 65 61 64 20 61 63   other thread ac
1490: 63 65 73 73 65 73 20 74 68 65 20 64 65 73 74 69  cesses the desti
14a0: 6e 61 74 69 6f 6e 20 68 61 6e 64 6c 65 20 66 6f  nation handle fo
14b0: 72 20 74 68 65 20 64 75 72 61 74 69 6f 6e 0a 20  r the duration. 
14c0: 20 2a 2a 20 6f 66 20 74 68 65 20 62 61 63 6b 75   ** of the backu
14d0: 70 20 6f 70 65 72 61 74 69 6f 6e 2e 20 20 41 6e  p operation.  An
14e0: 79 20 61 74 74 65 6d 70 74 20 74 6f 20 75 73 65  y attempt to use
14f0: 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e   the destination
1500: 0a 20 20 2a 2a 20 64 61 74 61 62 61 73 65 20 63  .  ** database c
1510: 6f 6e 6e 65 63 74 69 6f 6e 20 77 68 69 6c 65 20  onnection while 
1520: 61 20 62 61 63 6b 75 70 20 69 73 20 69 6e 20 70  a backup is in p
1530: 72 6f 67 72 65 73 73 20 6d 61 79 20 63 61 75 73  rogress may caus
1540: 65 0a 20 20 2a 2a 20 61 20 6d 61 6c 66 75 6e 63  e.  ** a malfunc
1550: 74 69 6f 6e 20 6f 72 20 61 20 64 65 61 64 6c 6f  tion or a deadlo
1560: 63 6b 2e 0a 20 20 2a 2f 0a 20 20 73 71 6c 69 74  ck..  */.  sqlit
1570: 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28 70  e3_mutex_enter(p
1580: 53 72 63 44 62 2d 3e 6d 75 74 65 78 29 3b 0a 20  SrcDb->mutex);. 
1590: 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65   sqlite3_mutex_e
15a0: 6e 74 65 72 28 70 44 65 73 74 44 62 2d 3e 6d 75  nter(pDestDb->mu
15b0: 74 65 78 29 3b 0a 0a 20 20 69 66 28 20 70 53 72  tex);..  if( pSr
15c0: 63 44 62 3d 3d 70 44 65 73 74 44 62 20 29 7b 0a  cDb==pDestDb ){.
15d0: 20 20 20 20 73 71 6c 69 74 65 33 45 72 72 6f 72      sqlite3Error
15e0: 28 0a 20 20 20 20 20 20 20 20 70 44 65 73 74 44  (.        pDestD
15f0: 62 2c 20 53 51 4c 49 54 45 5f 45 52 52 4f 52 2c  b, SQLITE_ERROR,
1600: 20 22 73 6f 75 72 63 65 20 61 6e 64 20 64 65 73   "source and des
1610: 74 69 6e 61 74 69 6f 6e 20 6d 75 73 74 20 62 65  tination must be
1620: 20 64 69 73 74 69 6e 63 74 22 0a 20 20 20 20 29   distinct".    )
1630: 3b 0a 20 20 20 20 70 20 3d 20 30 3b 0a 20 20 7d  ;.    p = 0;.  }
1640: 65 6c 73 65 20 7b 0a 20 20 20 20 2f 2a 20 41 6c  else {.    /* Al
1650: 6c 6f 63 61 74 65 20 73 70 61 63 65 20 66 6f 72  locate space for
1660: 20 61 20 6e 65 77 20 73 71 6c 69 74 65 33 5f 62   a new sqlite3_b
1670: 61 63 6b 75 70 20 6f 62 6a 65 63 74 20 2a 2f 0a  ackup object */.
1680: 20 20 20 20 70 20 3d 20 28 73 71 6c 69 74 65 33      p = (sqlite3
1690: 5f 62 61 63 6b 75 70 20 2a 29 73 71 6c 69 74 65  _backup *)sqlite
16a0: 33 5f 6d 61 6c 6c 6f 63 28 73 69 7a 65 6f 66 28  3_malloc(sizeof(
16b0: 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 29 29  sqlite3_backup))
16c0: 3b 0a 20 20 20 20 69 66 28 20 21 70 20 29 7b 0a  ;.    if( !p ){.
16d0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 45 72 72        sqlite3Err
16e0: 6f 72 28 70 44 65 73 74 44 62 2c 20 53 51 4c 49  or(pDestDb, SQLI
16f0: 54 45 5f 4e 4f 4d 45 4d 2c 20 30 29 3b 0a 20 20  TE_NOMEM, 0);.  
1700: 20 20 7d 0a 20 20 7d 0a 0a 20 20 2f 2a 20 49 66    }.  }..  /* If
1710: 20 74 68 65 20 61 6c 6c 6f 63 61 74 69 6f 6e 20   the allocation 
1720: 73 75 63 63 65 65 64 65 64 2c 20 70 6f 70 75 6c  succeeded, popul
1730: 61 74 65 20 74 68 65 20 6e 65 77 20 6f 62 6a 65  ate the new obje
1740: 63 74 2e 20 2a 2f 0a 20 20 69 66 28 20 70 20 29  ct. */.  if( p )
1750: 7b 0a 20 20 20 20 6d 65 6d 73 65 74 28 70 2c 20  {.    memset(p, 
1760: 30 2c 20 73 69 7a 65 6f 66 28 73 71 6c 69 74 65  0, sizeof(sqlite
1770: 33 5f 62 61 63 6b 75 70 29 29 3b 0a 20 20 20 20  3_backup));.    
1780: 70 2d 3e 70 53 72 63 20 3d 20 66 69 6e 64 42 74  p->pSrc = findBt
1790: 72 65 65 28 70 44 65 73 74 44 62 2c 20 70 53 72  ree(pDestDb, pSr
17a0: 63 44 62 2c 20 7a 53 72 63 44 62 29 3b 0a 20 20  cDb, zSrcDb);.  
17b0: 20 20 70 2d 3e 70 44 65 73 74 20 3d 20 66 69 6e    p->pDest = fin
17c0: 64 42 74 72 65 65 28 70 44 65 73 74 44 62 2c 20  dBtree(pDestDb, 
17d0: 70 44 65 73 74 44 62 2c 20 7a 44 65 73 74 44 62  pDestDb, zDestDb
17e0: 29 3b 0a 20 20 20 20 70 2d 3e 70 44 65 73 74 44  );.    p->pDestD
17f0: 62 20 3d 20 70 44 65 73 74 44 62 3b 0a 20 20 20  b = pDestDb;.   
1800: 20 70 2d 3e 70 53 72 63 44 62 20 3d 20 70 53 72   p->pSrcDb = pSr
1810: 63 44 62 3b 0a 20 20 20 20 70 2d 3e 69 4e 65 78  cDb;.    p->iNex
1820: 74 20 3d 20 31 3b 0a 20 20 20 20 70 2d 3e 69 73  t = 1;.    p->is
1830: 41 74 74 61 63 68 65 64 20 3d 20 30 3b 0a 0a 20  Attached = 0;.. 
1840: 20 20 20 69 66 28 20 30 3d 3d 70 2d 3e 70 53 72     if( 0==p->pSr
1850: 63 20 7c 7c 20 30 3d 3d 70 2d 3e 70 44 65 73 74  c || 0==p->pDest
1860: 20 29 7b 0a 20 20 20 20 20 20 2f 2a 20 4f 6e 65   ){.      /* One
1870: 20 28 6f 72 20 62 6f 74 68 29 20 6f 66 20 74 68   (or both) of th
1880: 65 20 6e 61 6d 65 64 20 64 61 74 61 62 61 73 65  e named database
1890: 73 20 64 69 64 20 6e 6f 74 20 65 78 69 73 74 2e  s did not exist.
18a0: 20 41 6e 20 65 72 72 6f 72 20 68 61 73 0a 20 20   An error has.  
18b0: 20 20 20 20 2a 2a 20 61 6c 72 65 61 64 79 20 62      ** already b
18c0: 65 65 6e 20 77 72 69 74 74 65 6e 20 69 6e 74 6f  een written into
18d0: 20 74 68 65 20 70 44 65 73 74 44 62 20 68 61 6e   the pDestDb han
18e0: 64 6c 65 2e 20 41 6c 6c 20 74 68 61 74 20 69 73  dle. All that is
18f0: 20 6c 65 66 74 0a 20 20 20 20 20 20 2a 2a 20 74   left.      ** t
1900: 6f 20 64 6f 20 68 65 72 65 20 69 73 20 66 72 65  o do here is fre
1910: 65 20 74 68 65 20 73 71 6c 69 74 65 33 5f 62 61  e the sqlite3_ba
1920: 63 6b 75 70 20 73 74 72 75 63 74 75 72 65 2e 0a  ckup structure..
1930: 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20 20 73        */.      s
1940: 71 6c 69 74 65 33 5f 66 72 65 65 28 70 29 3b 0a  qlite3_free(p);.
1950: 20 20 20 20 20 20 70 20 3d 20 30 3b 0a 20 20 20        p = 0;.   
1960: 20 7d 0a 20 20 7d 0a 20 20 69 66 28 20 70 20 29   }.  }.  if( p )
1970: 7b 0a 20 20 20 20 70 2d 3e 70 53 72 63 2d 3e 6e  {.    p->pSrc->n
1980: 42 61 63 6b 75 70 2b 2b 3b 0a 20 20 7d 0a 0a 20  Backup++;.  }.. 
1990: 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c   sqlite3_mutex_l
19a0: 65 61 76 65 28 70 44 65 73 74 44 62 2d 3e 6d 75  eave(pDestDb->mu
19b0: 74 65 78 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f  tex);.  sqlite3_
19c0: 6d 75 74 65 78 5f 6c 65 61 76 65 28 70 53 72 63  mutex_leave(pSrc
19d0: 44 62 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 72 65  Db->mutex);.  re
19e0: 74 75 72 6e 20 70 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  turn p;.}../*.**
19f0: 20 41 72 67 75 6d 65 6e 74 20 72 63 20 69 73 20   Argument rc is 
1a00: 61 6e 20 53 51 4c 69 74 65 20 65 72 72 6f 72 20  an SQLite error 
1a10: 63 6f 64 65 2e 20 52 65 74 75 72 6e 20 74 72 75  code. Return tru
1a20: 65 20 69 66 20 74 68 69 73 20 65 72 72 6f 72 20  e if this error 
1a30: 69 73 20 0a 2a 2a 20 63 6f 6e 73 69 64 65 72 65  is .** considere
1a40: 64 20 66 61 74 61 6c 20 69 66 20 65 6e 63 6f 75  d fatal if encou
1a50: 6e 74 65 72 65 64 20 64 75 72 69 6e 67 20 61 20  ntered during a 
1a60: 62 61 63 6b 75 70 20 6f 70 65 72 61 74 69 6f 6e  backup operation
1a70: 2e 20 41 6c 6c 20 65 72 72 6f 72 73 0a 2a 2a 20  . All errors.** 
1a80: 61 72 65 20 63 6f 6e 73 69 64 65 72 65 64 20 66  are considered f
1a90: 61 74 61 6c 20 65 78 63 65 70 74 20 66 6f 72 20  atal except for 
1aa0: 53 51 4c 49 54 45 5f 42 55 53 59 20 61 6e 64 20  SQLITE_BUSY and 
1ab0: 53 51 4c 49 54 45 5f 4c 4f 43 4b 45 44 2e 0a 2a  SQLITE_LOCKED..*
1ac0: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 69 73 46  /.static int isF
1ad0: 61 74 61 6c 45 72 72 6f 72 28 69 6e 74 20 72 63  atalError(int rc
1ae0: 29 7b 0a 20 20 72 65 74 75 72 6e 20 28 72 63 21  ){.  return (rc!
1af0: 3d 53 51 4c 49 54 45 5f 4f 4b 20 26 26 20 72 63  =SQLITE_OK && rc
1b00: 21 3d 53 51 4c 49 54 45 5f 42 55 53 59 20 26 26  !=SQLITE_BUSY &&
1b10: 20 41 4c 57 41 59 53 28 72 63 21 3d 53 51 4c 49   ALWAYS(rc!=SQLI
1b20: 54 45 5f 4c 4f 43 4b 45 44 29 29 3b 0a 7d 0a 0a  TE_LOCKED));.}..
1b30: 2f 2a 0a 2a 2a 20 50 61 72 61 6d 65 74 65 72 20  /*.** Parameter 
1b40: 7a 53 72 63 44 61 74 61 20 70 6f 69 6e 74 73 20  zSrcData points 
1b50: 74 6f 20 61 20 62 75 66 66 65 72 20 63 6f 6e 74  to a buffer cont
1b60: 61 69 6e 69 6e 67 20 74 68 65 20 64 61 74 61 20  aining the data 
1b70: 66 6f 72 20 0a 2a 2a 20 70 61 67 65 20 69 53 72  for .** page iSr
1b80: 63 50 67 20 66 72 6f 6d 20 74 68 65 20 73 6f 75  cPg from the sou
1b90: 72 63 65 20 64 61 74 61 62 61 73 65 2e 20 43 6f  rce database. Co
1ba0: 70 79 20 74 68 69 73 20 64 61 74 61 20 69 6e 74  py this data int
1bb0: 6f 20 74 68 65 20 0a 2a 2a 20 64 65 73 74 69 6e  o the .** destin
1bc0: 61 74 69 6f 6e 20 64 61 74 61 62 61 73 65 2e 0a  ation database..
1bd0: 2a 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 62 61  */.static int ba
1be0: 63 6b 75 70 4f 6e 65 50 61 67 65 28 73 71 6c 69  ckupOnePage(sqli
1bf0: 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 2c 20 50  te3_backup *p, P
1c00: 67 6e 6f 20 69 53 72 63 50 67 2c 20 63 6f 6e 73  gno iSrcPg, cons
1c10: 74 20 75 38 20 2a 7a 53 72 63 44 61 74 61 29 7b  t u8 *zSrcData){
1c20: 0a 20 20 50 61 67 65 72 20 2a 20 63 6f 6e 73 74  .  Pager * const
1c30: 20 70 44 65 73 74 50 61 67 65 72 20 3d 20 73 71   pDestPager = sq
1c40: 6c 69 74 65 33 42 74 72 65 65 50 61 67 65 72 28  lite3BtreePager(
1c50: 70 2d 3e 70 44 65 73 74 29 3b 0a 20 20 63 6f 6e  p->pDest);.  con
1c60: 73 74 20 69 6e 74 20 6e 53 72 63 50 67 73 7a 20  st int nSrcPgsz 
1c70: 3d 20 73 71 6c 69 74 65 33 42 74 72 65 65 47 65  = sqlite3BtreeGe
1c80: 74 50 61 67 65 53 69 7a 65 28 70 2d 3e 70 53 72  tPageSize(p->pSr
1c90: 63 29 3b 0a 20 20 69 6e 74 20 6e 44 65 73 74 50  c);.  int nDestP
1ca0: 67 73 7a 20 3d 20 73 71 6c 69 74 65 33 42 74 72  gsz = sqlite3Btr
1cb0: 65 65 47 65 74 50 61 67 65 53 69 7a 65 28 70 2d  eeGetPageSize(p-
1cc0: 3e 70 44 65 73 74 29 3b 0a 20 20 63 6f 6e 73 74  >pDest);.  const
1cd0: 20 69 6e 74 20 6e 43 6f 70 79 20 3d 20 4d 49 4e   int nCopy = MIN
1ce0: 28 6e 53 72 63 50 67 73 7a 2c 20 6e 44 65 73 74  (nSrcPgsz, nDest
1cf0: 50 67 73 7a 29 3b 0a 20 20 63 6f 6e 73 74 20 69  Pgsz);.  const i
1d00: 36 34 20 69 45 6e 64 20 3d 20 28 69 36 34 29 69  64 iEnd = (i64)i
1d10: 53 72 63 50 67 2a 28 69 36 34 29 6e 53 72 63 50  SrcPg*(i64)nSrcP
1d20: 67 73 7a 3b 0a 0a 20 20 69 6e 74 20 72 63 20 3d  gsz;..  int rc =
1d30: 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 69 36   SQLITE_OK;.  i6
1d40: 34 20 69 4f 66 66 3b 0a 0a 20 20 61 73 73 65 72  4 iOff;..  asser
1d50: 74 28 20 70 2d 3e 62 44 65 73 74 4c 6f 63 6b 65  t( p->bDestLocke
1d60: 64 20 29 3b 0a 20 20 61 73 73 65 72 74 28 20 21  d );.  assert( !
1d70: 69 73 46 61 74 61 6c 45 72 72 6f 72 28 70 2d 3e  isFatalError(p->
1d80: 72 63 29 20 29 3b 0a 20 20 61 73 73 65 72 74 28  rc) );.  assert(
1d90: 20 69 53 72 63 50 67 21 3d 50 45 4e 44 49 4e 47   iSrcPg!=PENDING
1da0: 5f 42 59 54 45 5f 50 41 47 45 28 70 2d 3e 70 53  _BYTE_PAGE(p->pS
1db0: 72 63 2d 3e 70 42 74 29 20 29 3b 0a 20 20 61 73  rc->pBt) );.  as
1dc0: 73 65 72 74 28 20 7a 53 72 63 44 61 74 61 20 29  sert( zSrcData )
1dd0: 3b 0a 0a 20 20 2f 2a 20 43 61 74 63 68 20 74 68  ;..  /* Catch th
1de0: 65 20 63 61 73 65 20 77 68 65 72 65 20 74 68 65  e case where the
1df0: 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 69 73 20   destination is 
1e00: 61 6e 20 69 6e 2d 6d 65 6d 6f 72 79 20 64 61 74  an in-memory dat
1e10: 61 62 61 73 65 20 61 6e 64 20 74 68 65 0a 20 20  abase and the.  
1e20: 2a 2a 20 70 61 67 65 20 73 69 7a 65 73 20 6f 66  ** page sizes of
1e30: 20 74 68 65 20 73 6f 75 72 63 65 20 61 6e 64 20   the source and 
1e40: 64 65 73 74 69 6e 61 74 69 6f 6e 20 64 69 66 66  destination diff
1e50: 65 72 2e 20 0a 20 20 2a 2f 0a 20 20 69 66 28 20  er. .  */.  if( 
1e60: 6e 53 72 63 50 67 73 7a 21 3d 6e 44 65 73 74 50  nSrcPgsz!=nDestP
1e70: 67 73 7a 20 26 26 20 73 71 6c 69 74 65 33 50 61  gsz && sqlite3Pa
1e80: 67 65 72 49 73 4d 65 6d 64 62 28 73 71 6c 69 74  gerIsMemdb(sqlit
1e90: 65 33 42 74 72 65 65 50 61 67 65 72 28 70 2d 3e  e3BtreePager(p->
1ea0: 70 44 65 73 74 29 29 20 29 7b 0a 20 20 20 20 72  pDest)) ){.    r
1eb0: 63 20 3d 20 53 51 4c 49 54 45 5f 52 45 41 44 4f  c = SQLITE_READO
1ec0: 4e 4c 59 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 54  NLY;.  }..  /* T
1ed0: 68 69 73 20 6c 6f 6f 70 20 72 75 6e 73 20 6f 6e  his loop runs on
1ee0: 63 65 20 66 6f 72 20 65 61 63 68 20 64 65 73 74  ce for each dest
1ef0: 69 6e 61 74 69 6f 6e 20 70 61 67 65 20 73 70 61  ination page spa
1f00: 6e 6e 65 64 20 62 79 20 74 68 65 20 73 6f 75 72  nned by the sour
1f10: 63 65 20 0a 20 20 2a 2a 20 70 61 67 65 2e 20 46  ce .  ** page. F
1f20: 6f 72 20 65 61 63 68 20 69 74 65 72 61 74 69 6f  or each iteratio
1f30: 6e 2c 20 76 61 72 69 61 62 6c 65 20 69 4f 66 66  n, variable iOff
1f40: 20 69 73 20 73 65 74 20 74 6f 20 74 68 65 20 62   is set to the b
1f50: 79 74 65 20 6f 66 66 73 65 74 0a 20 20 2a 2a 20  yte offset.  ** 
1f60: 6f 66 20 74 68 65 20 64 65 73 74 69 6e 61 74 69  of the destinati
1f70: 6f 6e 20 70 61 67 65 2e 0a 20 20 2a 2f 0a 20 20  on page..  */.  
1f80: 66 6f 72 28 69 4f 66 66 3d 69 45 6e 64 2d 28 69  for(iOff=iEnd-(i
1f90: 36 34 29 6e 53 72 63 50 67 73 7a 3b 20 72 63 3d  64)nSrcPgsz; rc=
1fa0: 3d 53 51 4c 49 54 45 5f 4f 4b 20 26 26 20 69 4f  =SQLITE_OK && iO
1fb0: 66 66 3c 69 45 6e 64 3b 20 69 4f 66 66 2b 3d 6e  ff<iEnd; iOff+=n
1fc0: 44 65 73 74 50 67 73 7a 29 7b 0a 20 20 20 20 44  DestPgsz){.    D
1fd0: 62 50 61 67 65 20 2a 70 44 65 73 74 50 67 20 3d  bPage *pDestPg =
1fe0: 20 30 3b 0a 20 20 20 20 50 67 6e 6f 20 69 44 65   0;.    Pgno iDe
1ff0: 73 74 20 3d 20 28 50 67 6e 6f 29 28 69 4f 66 66  st = (Pgno)(iOff
2000: 2f 6e 44 65 73 74 50 67 73 7a 29 2b 31 3b 0a 20  /nDestPgsz)+1;. 
2010: 20 20 20 69 66 28 20 69 44 65 73 74 3d 3d 50 45     if( iDest==PE
2020: 4e 44 49 4e 47 5f 42 59 54 45 5f 50 41 47 45 28  NDING_BYTE_PAGE(
2030: 70 2d 3e 70 44 65 73 74 2d 3e 70 42 74 29 20 29  p->pDest->pBt) )
2040: 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 20 20 69   continue;.    i
2050: 66 28 20 53 51 4c 49 54 45 5f 4f 4b 3d 3d 28 72  f( SQLITE_OK==(r
2060: 63 20 3d 20 73 71 6c 69 74 65 33 50 61 67 65 72  c = sqlite3Pager
2070: 47 65 74 28 70 44 65 73 74 50 61 67 65 72 2c 20  Get(pDestPager, 
2080: 69 44 65 73 74 2c 20 26 70 44 65 73 74 50 67 29  iDest, &pDestPg)
2090: 29 0a 20 20 20 20 20 26 26 20 53 51 4c 49 54 45  ).     && SQLITE
20a0: 5f 4f 4b 3d 3d 28 72 63 20 3d 20 73 71 6c 69 74  _OK==(rc = sqlit
20b0: 65 33 50 61 67 65 72 57 72 69 74 65 28 70 44 65  e3PagerWrite(pDe
20c0: 73 74 50 67 29 29 0a 20 20 20 20 29 7b 0a 20 20  stPg)).    ){.  
20d0: 20 20 20 20 63 6f 6e 73 74 20 75 38 20 2a 7a 49      const u8 *zI
20e0: 6e 20 3d 20 26 7a 53 72 63 44 61 74 61 5b 69 4f  n = &zSrcData[iO
20f0: 66 66 25 6e 53 72 63 50 67 73 7a 5d 3b 0a 20 20  ff%nSrcPgsz];.  
2100: 20 20 20 20 75 38 20 2a 7a 44 65 73 74 44 61 74      u8 *zDestDat
2110: 61 20 3d 20 73 71 6c 69 74 65 33 50 61 67 65 72  a = sqlite3Pager
2120: 47 65 74 44 61 74 61 28 70 44 65 73 74 50 67 29  GetData(pDestPg)
2130: 3b 0a 20 20 20 20 20 20 75 38 20 2a 7a 4f 75 74  ;.      u8 *zOut
2140: 20 3d 20 26 7a 44 65 73 74 44 61 74 61 5b 69 4f   = &zDestData[iO
2150: 66 66 25 6e 44 65 73 74 50 67 73 7a 5d 3b 0a 0a  ff%nDestPgsz];..
2160: 20 20 20 20 20 20 2f 2a 20 43 6f 70 79 20 74 68        /* Copy th
2170: 65 20 64 61 74 61 20 66 72 6f 6d 20 74 68 65 20  e data from the 
2180: 73 6f 75 72 63 65 20 70 61 67 65 20 69 6e 74 6f  source page into
2190: 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e   the destination
21a0: 20 70 61 67 65 2e 0a 20 20 20 20 20 20 2a 2a 20   page..      ** 
21b0: 54 68 65 6e 20 63 6c 65 61 72 20 74 68 65 20 42  Then clear the B
21c0: 74 72 65 65 20 6c 61 79 65 72 20 4d 65 6d 50 61  tree layer MemPa
21d0: 67 65 2e 69 73 49 6e 69 74 20 66 6c 61 67 2e 20  ge.isInit flag. 
21e0: 42 6f 74 68 20 74 68 69 73 20 6d 6f 64 75 6c 65  Both this module
21f0: 0a 20 20 20 20 20 20 2a 2a 20 61 6e 64 20 74 68  .      ** and th
2200: 65 20 70 61 67 65 72 20 63 6f 64 65 20 75 73 65  e pager code use
2210: 20 74 68 69 73 20 74 72 69 63 6b 20 28 63 6c 65   this trick (cle
2220: 61 72 69 6e 67 20 74 68 65 20 66 69 72 73 74 20  aring the first 
2230: 62 79 74 65 0a 20 20 20 20 20 20 2a 2a 20 6f 66  byte.      ** of
2240: 20 74 68 65 20 70 61 67 65 20 27 65 78 74 72 61   the page 'extra
2250: 27 20 73 70 61 63 65 20 74 6f 20 69 6e 76 61 6c  ' space to inval
2260: 69 64 61 74 65 20 74 68 65 20 42 74 72 65 65 20  idate the Btree 
2270: 6c 61 79 65 72 73 0a 20 20 20 20 20 20 2a 2a 20  layers.      ** 
2280: 63 61 63 68 65 64 20 70 61 72 73 65 20 6f 66 20  cached parse of 
2290: 74 68 65 20 70 61 67 65 29 2e 20 4d 65 6d 50 61  the page). MemPa
22a0: 67 65 2e 69 73 49 6e 69 74 20 69 73 20 6d 61 72  ge.isInit is mar
22b0: 6b 65 64 20 0a 20 20 20 20 20 20 2a 2a 20 22 4d  ked .      ** "M
22c0: 55 53 54 20 42 45 20 46 49 52 53 54 22 20 66 6f  UST BE FIRST" fo
22d0: 72 20 74 68 69 73 20 70 75 72 70 6f 73 65 2e 0a  r this purpose..
22e0: 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20 20 6d        */.      m
22f0: 65 6d 63 70 79 28 7a 4f 75 74 2c 20 7a 49 6e 2c  emcpy(zOut, zIn,
2300: 20 6e 43 6f 70 79 29 3b 0a 20 20 20 20 20 20 28   nCopy);.      (
2310: 28 75 38 20 2a 29 73 71 6c 69 74 65 33 50 61 67  (u8 *)sqlite3Pag
2320: 65 72 47 65 74 45 78 74 72 61 28 70 44 65 73 74  erGetExtra(pDest
2330: 50 67 29 29 5b 30 5d 20 3d 20 30 3b 0a 20 20 20  Pg))[0] = 0;.   
2340: 20 7d 0a 20 20 20 20 73 71 6c 69 74 65 33 50 61   }.    sqlite3Pa
2350: 67 65 72 55 6e 72 65 66 28 70 44 65 73 74 50 67  gerUnref(pDestPg
2360: 29 3b 0a 20 20 7d 0a 0a 20 20 72 65 74 75 72 6e  );.  }..  return
2370: 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 49 66   rc;.}../*.** If
2380: 20 70 46 69 6c 65 20 69 73 20 63 75 72 72 65 6e   pFile is curren
2390: 74 6c 79 20 6c 61 72 67 65 72 20 74 68 61 6e 20  tly larger than 
23a0: 69 53 69 7a 65 20 62 79 74 65 73 2c 20 74 68 65  iSize bytes, the
23b0: 6e 20 74 72 75 6e 63 61 74 65 20 69 74 20 74 6f  n truncate it to
23c0: 0a 2a 2a 20 65 78 61 63 74 6c 79 20 69 53 69 7a  .** exactly iSiz
23d0: 65 20 62 79 74 65 73 2e 20 49 66 20 70 46 69 6c  e bytes. If pFil
23e0: 65 20 69 73 20 6e 6f 74 20 6c 61 72 67 65 72 20  e is not larger 
23f0: 74 68 61 6e 20 69 53 69 7a 65 20 62 79 74 65 73  than iSize bytes
2400: 2c 20 74 68 65 6e 0a 2a 2a 20 74 68 69 73 20 66  , then.** this f
2410: 75 6e 63 74 69 6f 6e 20 69 73 20 61 20 6e 6f 2d  unction is a no-
2420: 6f 70 2e 0a 2a 2a 0a 2a 2a 20 52 65 74 75 72 6e  op..**.** Return
2430: 20 53 51 4c 49 54 45 5f 4f 4b 20 69 66 20 65 76   SQLITE_OK if ev
2440: 65 72 79 74 68 69 6e 67 20 69 73 20 73 75 63 63  erything is succ
2450: 65 73 73 66 75 6c 2c 20 6f 72 20 61 6e 20 53 51  essful, or an SQ
2460: 4c 69 74 65 20 65 72 72 6f 72 20 0a 2a 2a 20 63  Lite error .** c
2470: 6f 64 65 20 69 66 20 61 6e 20 65 72 72 6f 72 20  ode if an error 
2480: 6f 63 63 75 72 73 2e 0a 2a 2f 0a 73 74 61 74 69  occurs..*/.stati
2490: 63 20 69 6e 74 20 62 61 63 6b 75 70 54 72 75 6e  c int backupTrun
24a0: 63 61 74 65 46 69 6c 65 28 73 71 6c 69 74 65 33  cateFile(sqlite3
24b0: 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c 20 69 36  _file *pFile, i6
24c0: 34 20 69 53 69 7a 65 29 7b 0a 20 20 69 36 34 20  4 iSize){.  i64 
24d0: 69 43 75 72 72 65 6e 74 3b 0a 20 20 69 6e 74 20  iCurrent;.  int 
24e0: 72 63 20 3d 20 73 71 6c 69 74 65 33 4f 73 46 69  rc = sqlite3OsFi
24f0: 6c 65 53 69 7a 65 28 70 46 69 6c 65 2c 20 26 69  leSize(pFile, &i
2500: 43 75 72 72 65 6e 74 29 3b 0a 20 20 69 66 28 20  Current);.  if( 
2510: 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 26 26  rc==SQLITE_OK &&
2520: 20 69 43 75 72 72 65 6e 74 3e 69 53 69 7a 65 20   iCurrent>iSize 
2530: 29 7b 0a 20 20 20 20 72 63 20 3d 20 73 71 6c 69  ){.    rc = sqli
2540: 74 65 33 4f 73 54 72 75 6e 63 61 74 65 28 70 46  te3OsTruncate(pF
2550: 69 6c 65 2c 20 69 53 69 7a 65 29 3b 0a 20 20 7d  ile, iSize);.  }
2560: 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a  .  return rc;.}.
2570: 0a 2f 2a 0a 2a 2a 20 52 65 67 69 73 74 65 72 20  ./*.** Register 
2580: 74 68 69 73 20 62 61 63 6b 75 70 20 6f 62 6a 65  this backup obje
2590: 63 74 20 77 69 74 68 20 74 68 65 20 61 73 73 6f  ct with the asso
25a0: 63 69 61 74 65 64 20 73 6f 75 72 63 65 20 70 61  ciated source pa
25b0: 67 65 72 20 66 6f 72 0a 2a 2a 20 63 61 6c 6c 62  ger for.** callb
25c0: 61 63 6b 73 20 77 68 65 6e 20 70 61 67 65 73 20  acks when pages 
25d0: 61 72 65 20 63 68 61 6e 67 65 64 20 6f 72 20 74  are changed or t
25e0: 68 65 20 63 61 63 68 65 20 69 6e 76 61 6c 69 64  he cache invalid
25f0: 61 74 65 64 2e 0a 2a 2f 0a 73 74 61 74 69 63 20  ated..*/.static 
2600: 76 6f 69 64 20 61 74 74 61 63 68 42 61 63 6b 75  void attachBacku
2610: 70 4f 62 6a 65 63 74 28 73 71 6c 69 74 65 33 5f  pObject(sqlite3_
2620: 62 61 63 6b 75 70 20 2a 70 29 7b 0a 20 20 73 71  backup *p){.  sq
2630: 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 2a 70  lite3_backup **p
2640: 70 3b 0a 20 20 61 73 73 65 72 74 28 20 73 71 6c  p;.  assert( sql
2650: 69 74 65 33 42 74 72 65 65 48 6f 6c 64 73 4d 75  ite3BtreeHoldsMu
2660: 74 65 78 28 70 2d 3e 70 53 72 63 29 20 29 3b 0a  tex(p->pSrc) );.
2670: 20 20 70 70 20 3d 20 73 71 6c 69 74 65 33 50 61    pp = sqlite3Pa
2680: 67 65 72 42 61 63 6b 75 70 50 74 72 28 73 71 6c  gerBackupPtr(sql
2690: 69 74 65 33 42 74 72 65 65 50 61 67 65 72 28 70  ite3BtreePager(p
26a0: 2d 3e 70 53 72 63 29 29 3b 0a 20 20 70 2d 3e 70  ->pSrc));.  p->p
26b0: 4e 65 78 74 20 3d 20 2a 70 70 3b 0a 20 20 2a 70  Next = *pp;.  *p
26c0: 70 20 3d 20 70 3b 0a 20 20 70 2d 3e 69 73 41 74  p = p;.  p->isAt
26d0: 74 61 63 68 65 64 20 3d 20 31 3b 0a 7d 0a 0a 2f  tached = 1;.}../
26e0: 2a 0a 2a 2a 20 43 6f 70 79 20 6e 50 61 67 65 20  *.** Copy nPage 
26f0: 70 61 67 65 73 20 66 72 6f 6d 20 74 68 65 20 73  pages from the s
2700: 6f 75 72 63 65 20 62 2d 74 72 65 65 20 74 6f 20  ource b-tree to 
2710: 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e 2e  the destination.
2720: 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f  .*/.int sqlite3_
2730: 62 61 63 6b 75 70 5f 73 74 65 70 28 73 71 6c 69  backup_step(sqli
2740: 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 2c 20 69  te3_backup *p, i
2750: 6e 74 20 6e 50 61 67 65 29 7b 0a 20 20 69 6e 74  nt nPage){.  int
2760: 20 72 63 3b 0a 0a 20 20 73 71 6c 69 74 65 33 5f   rc;..  sqlite3_
2770: 6d 75 74 65 78 5f 65 6e 74 65 72 28 70 2d 3e 70  mutex_enter(p->p
2780: 53 72 63 44 62 2d 3e 6d 75 74 65 78 29 3b 0a 20  SrcDb->mutex);. 
2790: 20 73 71 6c 69 74 65 33 42 74 72 65 65 45 6e 74   sqlite3BtreeEnt
27a0: 65 72 28 70 2d 3e 70 53 72 63 29 3b 0a 20 20 69  er(p->pSrc);.  i
27b0: 66 28 20 70 2d 3e 70 44 65 73 74 44 62 20 29 7b  f( p->pDestDb ){
27c0: 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 6d 75 74  .    sqlite3_mut
27d0: 65 78 5f 65 6e 74 65 72 28 70 2d 3e 70 44 65 73  ex_enter(p->pDes
27e0: 74 44 62 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 7d  tDb->mutex);.  }
27f0: 0a 0a 20 20 72 63 20 3d 20 70 2d 3e 72 63 3b 0a  ..  rc = p->rc;.
2800: 20 20 69 66 28 20 21 69 73 46 61 74 61 6c 45 72    if( !isFatalEr
2810: 72 6f 72 28 72 63 29 20 29 7b 0a 20 20 20 20 50  ror(rc) ){.    P
2820: 61 67 65 72 20 2a 20 63 6f 6e 73 74 20 70 53 72  ager * const pSr
2830: 63 50 61 67 65 72 20 3d 20 73 71 6c 69 74 65 33  cPager = sqlite3
2840: 42 74 72 65 65 50 61 67 65 72 28 70 2d 3e 70 53  BtreePager(p->pS
2850: 72 63 29 3b 20 20 20 20 20 2f 2a 20 53 6f 75 72  rc);     /* Sour
2860: 63 65 20 70 61 67 65 72 20 2a 2f 0a 20 20 20 20  ce pager */.    
2870: 50 61 67 65 72 20 2a 20 63 6f 6e 73 74 20 70 44  Pager * const pD
2880: 65 73 74 50 61 67 65 72 20 3d 20 73 71 6c 69 74  estPager = sqlit
2890: 65 33 42 74 72 65 65 50 61 67 65 72 28 70 2d 3e  e3BtreePager(p->
28a0: 70 44 65 73 74 29 3b 20 20 20 2f 2a 20 44 65 73  pDest);   /* Des
28b0: 74 20 70 61 67 65 72 20 2a 2f 0a 20 20 20 20 69  t pager */.    i
28c0: 6e 74 20 69 69 3b 20 20 20 20 20 20 20 20 20 20  nt ii;          
28d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
28e0: 20 20 2f 2a 20 49 74 65 72 61 74 6f 72 20 76 61    /* Iterator va
28f0: 72 69 61 62 6c 65 20 2a 2f 0a 20 20 20 20 69 6e  riable */.    in
2900: 74 20 6e 53 72 63 50 61 67 65 20 3d 20 2d 31 3b  t nSrcPage = -1;
2910: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2920: 20 2f 2a 20 53 69 7a 65 20 6f 66 20 73 6f 75 72   /* Size of sour
2930: 63 65 20 64 62 20 69 6e 20 70 61 67 65 73 20 2a  ce db in pages *
2940: 2f 0a 20 20 20 20 69 6e 74 20 62 43 6c 6f 73 65  /.    int bClose
2950: 54 72 61 6e 73 20 3d 20 30 3b 20 20 20 20 20 20  Trans = 0;      
2960: 20 20 20 20 20 20 20 20 20 2f 2a 20 54 72 75 65           /* True
2970: 20 69 66 20 73 72 63 20 64 62 20 72 65 71 75 69   if src db requi
2980: 72 65 73 20 75 6e 6c 6f 63 6b 69 6e 67 20 2a 2f  res unlocking */
2990: 0a 0a 20 20 20 20 2f 2a 20 49 66 20 74 68 65 20  ..    /* If the 
29a0: 73 6f 75 72 63 65 20 70 61 67 65 72 20 69 73 20  source pager is 
29b0: 63 75 72 72 65 6e 74 6c 79 20 69 6e 20 61 20 77  currently in a w
29c0: 72 69 74 65 2d 74 72 61 6e 73 61 63 74 69 6f 6e  rite-transaction
29d0: 2c 20 72 65 74 75 72 6e 0a 20 20 20 20 2a 2a 20  , return.    ** 
29e0: 53 51 4c 49 54 45 5f 42 55 53 59 20 69 6d 6d 65  SQLITE_BUSY imme
29f0: 64 69 61 74 65 6c 79 2e 0a 20 20 20 20 2a 2f 0a  diately..    */.
2a00: 20 20 20 20 69 66 28 20 70 2d 3e 70 44 65 73 74      if( p->pDest
2a10: 44 62 20 26 26 20 70 2d 3e 70 53 72 63 2d 3e 70  Db && p->pSrc->p
2a20: 42 74 2d 3e 69 6e 54 72 61 6e 73 61 63 74 69 6f  Bt->inTransactio
2a30: 6e 3d 3d 54 52 41 4e 53 5f 57 52 49 54 45 20 29  n==TRANS_WRITE )
2a40: 7b 0a 20 20 20 20 20 20 72 63 20 3d 20 53 51 4c  {.      rc = SQL
2a50: 49 54 45 5f 42 55 53 59 3b 0a 20 20 20 20 7d 65  ITE_BUSY;.    }e
2a60: 6c 73 65 7b 0a 20 20 20 20 20 20 72 63 20 3d 20  lse{.      rc = 
2a70: 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 20 20 7d  SQLITE_OK;.    }
2a80: 0a 0a 20 20 20 20 2f 2a 20 4c 6f 63 6b 20 74 68  ..    /* Lock th
2a90: 65 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 64 61  e destination da
2aa0: 74 61 62 61 73 65 2c 20 69 66 20 69 74 20 69 73  tabase, if it is
2ab0: 20 6e 6f 74 20 6c 6f 63 6b 65 64 20 61 6c 72 65   not locked alre
2ac0: 61 64 79 2e 20 2a 2f 0a 20 20 20 20 69 66 28 20  ady. */.    if( 
2ad0: 53 51 4c 49 54 45 5f 4f 4b 3d 3d 72 63 20 26 26  SQLITE_OK==rc &&
2ae0: 20 70 2d 3e 62 44 65 73 74 4c 6f 63 6b 65 64 3d   p->bDestLocked=
2af0: 3d 30 0a 20 20 20 20 20 26 26 20 53 51 4c 49 54  =0.     && SQLIT
2b00: 45 5f 4f 4b 3d 3d 28 72 63 20 3d 20 73 71 6c 69  E_OK==(rc = sqli
2b10: 74 65 33 42 74 72 65 65 42 65 67 69 6e 54 72 61  te3BtreeBeginTra
2b20: 6e 73 28 70 2d 3e 70 44 65 73 74 2c 20 32 29 29  ns(p->pDest, 2))
2b30: 20 0a 20 20 20 20 29 7b 0a 20 20 20 20 20 20 70   .    ){.      p
2b40: 2d 3e 62 44 65 73 74 4c 6f 63 6b 65 64 20 3d 20  ->bDestLocked = 
2b50: 31 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33  1;.      sqlite3
2b60: 42 74 72 65 65 47 65 74 4d 65 74 61 28 70 2d 3e  BtreeGetMeta(p->
2b70: 70 44 65 73 74 2c 20 42 54 52 45 45 5f 53 43 48  pDest, BTREE_SCH
2b80: 45 4d 41 5f 56 45 52 53 49 4f 4e 2c 20 26 70 2d  EMA_VERSION, &p-
2b90: 3e 69 44 65 73 74 53 63 68 65 6d 61 29 3b 0a 20  >iDestSchema);. 
2ba0: 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 20 49 66 20     }..    /* If 
2bb0: 74 68 65 72 65 20 69 73 20 6e 6f 20 6f 70 65 6e  there is no open
2bc0: 20 72 65 61 64 2d 74 72 61 6e 73 61 63 74 69 6f   read-transactio
2bd0: 6e 20 6f 6e 20 74 68 65 20 73 6f 75 72 63 65 20  n on the source 
2be0: 64 61 74 61 62 61 73 65 2c 20 6f 70 65 6e 0a 20  database, open. 
2bf0: 20 20 20 2a 2a 20 6f 6e 65 20 6e 6f 77 2e 20 49     ** one now. I
2c00: 66 20 61 20 74 72 61 6e 73 61 63 74 69 6f 6e 20  f a transaction 
2c10: 69 73 20 6f 70 65 6e 65 64 20 68 65 72 65 2c 20  is opened here, 
2c20: 74 68 65 6e 20 69 74 20 77 69 6c 6c 20 62 65 20  then it will be 
2c30: 63 6c 6f 73 65 64 0a 20 20 20 20 2a 2a 20 62 65  closed.    ** be
2c40: 66 6f 72 65 20 74 68 69 73 20 66 75 6e 63 74 69  fore this functi
2c50: 6f 6e 20 65 78 69 74 73 2e 0a 20 20 20 20 2a 2f  on exits..    */
2c60: 0a 20 20 20 20 69 66 28 20 72 63 3d 3d 53 51 4c  .    if( rc==SQL
2c70: 49 54 45 5f 4f 4b 20 26 26 20 30 3d 3d 73 71 6c  ITE_OK && 0==sql
2c80: 69 74 65 33 42 74 72 65 65 49 73 49 6e 52 65 61  ite3BtreeIsInRea
2c90: 64 54 72 61 6e 73 28 70 2d 3e 70 53 72 63 29 20  dTrans(p->pSrc) 
2ca0: 29 7b 0a 20 20 20 20 20 20 72 63 20 3d 20 73 71  ){.      rc = sq
2cb0: 6c 69 74 65 33 42 74 72 65 65 42 65 67 69 6e 54  lite3BtreeBeginT
2cc0: 72 61 6e 73 28 70 2d 3e 70 53 72 63 2c 20 30 29  rans(p->pSrc, 0)
2cd0: 3b 0a 20 20 20 20 20 20 62 43 6c 6f 73 65 54 72  ;.      bCloseTr
2ce0: 61 6e 73 20 3d 20 31 3b 0a 20 20 20 20 7d 0a 20  ans = 1;.    }. 
2cf0: 20 0a 20 20 20 20 2f 2a 20 4e 6f 77 20 74 68 61   .    /* Now tha
2d00: 74 20 74 68 65 72 65 20 69 73 20 61 20 72 65 61  t there is a rea
2d10: 64 2d 6c 6f 63 6b 20 6f 6e 20 74 68 65 20 73 6f  d-lock on the so
2d20: 75 72 63 65 20 64 61 74 61 62 61 73 65 2c 20 71  urce database, q
2d30: 75 65 72 79 20 74 68 65 0a 20 20 20 20 2a 2a 20  uery the.    ** 
2d40: 73 6f 75 72 63 65 20 70 61 67 65 72 20 66 6f 72  source pager for
2d50: 20 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 70   the number of p
2d60: 61 67 65 73 20 69 6e 20 74 68 65 20 64 61 74 61  ages in the data
2d70: 62 61 73 65 2e 0a 20 20 20 20 2a 2f 0a 20 20 20  base..    */.   
2d80: 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f   if( rc==SQLITE_
2d90: 4f 4b 20 29 7b 0a 20 20 20 20 20 20 72 63 20 3d  OK ){.      rc =
2da0: 20 73 71 6c 69 74 65 33 50 61 67 65 72 50 61 67   sqlite3PagerPag
2db0: 65 63 6f 75 6e 74 28 70 53 72 63 50 61 67 65 72  ecount(pSrcPager
2dc0: 2c 20 26 6e 53 72 63 50 61 67 65 29 3b 0a 20 20  , &nSrcPage);.  
2dd0: 20 20 7d 0a 20 20 20 20 66 6f 72 28 69 69 3d 30    }.    for(ii=0
2de0: 3b 20 28 6e 50 61 67 65 3c 30 20 7c 7c 20 69 69  ; (nPage<0 || ii
2df0: 3c 6e 50 61 67 65 29 20 26 26 20 70 2d 3e 69 4e  <nPage) && p->iN
2e00: 65 78 74 3c 3d 28 50 67 6e 6f 29 6e 53 72 63 50  ext<=(Pgno)nSrcP
2e10: 61 67 65 20 26 26 20 21 72 63 3b 20 69 69 2b 2b  age && !rc; ii++
2e20: 29 7b 0a 20 20 20 20 20 20 63 6f 6e 73 74 20 50  ){.      const P
2e30: 67 6e 6f 20 69 53 72 63 50 67 20 3d 20 70 2d 3e  gno iSrcPg = p->
2e40: 69 4e 65 78 74 3b 20 20 20 20 20 20 20 20 20 20  iNext;          
2e50: 20 20 20 20 20 20 20 2f 2a 20 53 6f 75 72 63 65         /* Source
2e60: 20 70 61 67 65 20 6e 75 6d 62 65 72 20 2a 2f 0a   page number */.
2e70: 20 20 20 20 20 20 69 66 28 20 69 53 72 63 50 67        if( iSrcPg
2e80: 21 3d 50 45 4e 44 49 4e 47 5f 42 59 54 45 5f 50  !=PENDING_BYTE_P
2e90: 41 47 45 28 70 2d 3e 70 53 72 63 2d 3e 70 42 74  AGE(p->pSrc->pBt
2ea0: 29 20 29 7b 0a 20 20 20 20 20 20 20 20 44 62 50  ) ){.        DbP
2eb0: 61 67 65 20 2a 70 53 72 63 50 67 3b 20 20 20 20  age *pSrcPg;    
2ec0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
2ed0: 20 20 20 20 20 20 20 20 20 2f 2a 20 53 6f 75 72           /* Sour
2ee0: 63 65 20 70 61 67 65 20 6f 62 6a 65 63 74 20 2a  ce page object *
2ef0: 2f 0a 20 20 20 20 20 20 20 20 72 63 20 3d 20 73  /.        rc = s
2f00: 71 6c 69 74 65 33 50 61 67 65 72 47 65 74 28 70  qlite3PagerGet(p
2f10: 53 72 63 50 61 67 65 72 2c 20 69 53 72 63 50 67  SrcPager, iSrcPg
2f20: 2c 20 26 70 53 72 63 50 67 29 3b 0a 20 20 20 20  , &pSrcPg);.    
2f30: 20 20 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49      if( rc==SQLI
2f40: 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 20 20 20  TE_OK ){.       
2f50: 20 20 20 72 63 20 3d 20 62 61 63 6b 75 70 4f 6e     rc = backupOn
2f60: 65 50 61 67 65 28 70 2c 20 69 53 72 63 50 67 2c  ePage(p, iSrcPg,
2f70: 20 73 71 6c 69 74 65 33 50 61 67 65 72 47 65 74   sqlite3PagerGet
2f80: 44 61 74 61 28 70 53 72 63 50 67 29 29 3b 0a 20  Data(pSrcPg));. 
2f90: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33           sqlite3
2fa0: 50 61 67 65 72 55 6e 72 65 66 28 70 53 72 63 50  PagerUnref(pSrcP
2fb0: 67 29 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20  g);.        }.  
2fc0: 20 20 20 20 7d 0a 20 20 20 20 20 20 70 2d 3e 69      }.      p->i
2fd0: 4e 65 78 74 2b 2b 3b 0a 20 20 20 20 7d 0a 20 20  Next++;.    }.  
2fe0: 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45    if( rc==SQLITE
2ff0: 5f 4f 4b 20 29 7b 0a 20 20 20 20 20 20 70 2d 3e  _OK ){.      p->
3000: 6e 50 61 67 65 63 6f 75 6e 74 20 3d 20 6e 53 72  nPagecount = nSr
3010: 63 50 61 67 65 3b 0a 20 20 20 20 20 20 70 2d 3e  cPage;.      p->
3020: 6e 52 65 6d 61 69 6e 69 6e 67 20 3d 20 6e 53 72  nRemaining = nSr
3030: 63 50 61 67 65 2b 31 2d 70 2d 3e 69 4e 65 78 74  cPage+1-p->iNext
3040: 3b 0a 20 20 20 20 20 20 69 66 28 20 70 2d 3e 69  ;.      if( p->i
3050: 4e 65 78 74 3e 28 50 67 6e 6f 29 6e 53 72 63 50  Next>(Pgno)nSrcP
3060: 61 67 65 20 29 7b 0a 20 20 20 20 20 20 20 20 72  age ){.        r
3070: 63 20 3d 20 53 51 4c 49 54 45 5f 44 4f 4e 45 3b  c = SQLITE_DONE;
3080: 0a 20 20 20 20 20 20 7d 65 6c 73 65 20 69 66 28  .      }else if(
3090: 20 21 70 2d 3e 69 73 41 74 74 61 63 68 65 64 20   !p->isAttached 
30a0: 29 7b 0a 20 20 20 20 20 20 20 20 61 74 74 61 63  ){.        attac
30b0: 68 42 61 63 6b 75 70 4f 62 6a 65 63 74 28 70 29  hBackupObject(p)
30c0: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 7d 0a  ;.      }.    }.
30d0: 20 20 0a 20 20 20 20 69 66 28 20 72 63 3d 3d 53    .    if( rc==S
30e0: 51 4c 49 54 45 5f 44 4f 4e 45 20 29 7b 0a 20 20  QLITE_DONE ){.  
30f0: 20 20 20 20 63 6f 6e 73 74 20 69 6e 74 20 6e 53      const int nS
3100: 72 63 50 61 67 65 73 69 7a 65 20 3d 20 73 71 6c  rcPagesize = sql
3110: 69 74 65 33 42 74 72 65 65 47 65 74 50 61 67 65  ite3BtreeGetPage
3120: 53 69 7a 65 28 70 2d 3e 70 53 72 63 29 3b 0a 20  Size(p->pSrc);. 
3130: 20 20 20 20 20 63 6f 6e 73 74 20 69 6e 74 20 6e       const int n
3140: 44 65 73 74 50 61 67 65 73 69 7a 65 20 3d 20 73  DestPagesize = s
3150: 71 6c 69 74 65 33 42 74 72 65 65 47 65 74 50 61  qlite3BtreeGetPa
3160: 67 65 53 69 7a 65 28 70 2d 3e 70 44 65 73 74 29  geSize(p->pDest)
3170: 3b 0a 20 20 20 20 20 20 69 6e 74 20 6e 44 65 73  ;.      int nDes
3180: 74 54 72 75 6e 63 61 74 65 3b 0a 20 20 0a 20 20  tTruncate;.  .  
3190: 20 20 20 20 2f 2a 20 55 70 64 61 74 65 20 74 68      /* Update th
31a0: 65 20 73 63 68 65 6d 61 20 76 65 72 73 69 6f 6e  e schema version
31b0: 20 66 69 65 6c 64 20 69 6e 20 74 68 65 20 64 65   field in the de
31c0: 73 74 69 6e 61 74 69 6f 6e 20 64 61 74 61 62 61  stination databa
31d0: 73 65 2e 20 54 68 69 73 0a 20 20 20 20 20 20 2a  se. This.      *
31e0: 2a 20 69 73 20 74 6f 20 6d 61 6b 65 20 73 75 72  * is to make sur
31f0: 65 20 74 68 61 74 20 74 68 65 20 73 63 68 65 6d  e that the schem
3200: 61 2d 76 65 72 73 69 6f 6e 20 72 65 61 6c 6c 79  a-version really
3210: 20 64 6f 65 73 20 63 68 61 6e 67 65 20 69 6e 0a   does change in.
3220: 20 20 20 20 20 20 2a 2a 20 74 68 65 20 63 61 73        ** the cas
3230: 65 20 77 68 65 72 65 20 74 68 65 20 73 6f 75 72  e where the sour
3240: 63 65 20 61 6e 64 20 64 65 73 74 69 6e 61 74 69  ce and destinati
3250: 6f 6e 20 64 61 74 61 62 61 73 65 73 20 68 61 76  on databases hav
3260: 65 20 74 68 65 0a 20 20 20 20 20 20 2a 2a 20 73  e the.      ** s
3270: 61 6d 65 20 73 63 68 65 6d 61 20 76 65 72 73 69  ame schema versi
3280: 6f 6e 2e 0a 20 20 20 20 20 20 2a 2f 0a 20 20 20  on..      */.   
3290: 20 20 20 73 71 6c 69 74 65 33 42 74 72 65 65 55     sqlite3BtreeU
32a0: 70 64 61 74 65 4d 65 74 61 28 70 2d 3e 70 44 65  pdateMeta(p->pDe
32b0: 73 74 2c 20 31 2c 20 70 2d 3e 69 44 65 73 74 53  st, 1, p->iDestS
32c0: 63 68 65 6d 61 2b 31 29 3b 0a 20 20 20 20 20 20  chema+1);.      
32d0: 69 66 28 20 70 2d 3e 70 44 65 73 74 44 62 20 29  if( p->pDestDb )
32e0: 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65  {.        sqlite
32f0: 33 52 65 73 65 74 49 6e 74 65 72 6e 61 6c 53 63  3ResetInternalSc
3300: 68 65 6d 61 28 70 2d 3e 70 44 65 73 74 44 62 2c  hema(p->pDestDb,
3310: 20 30 29 3b 0a 20 20 20 20 20 20 7d 0a 0a 20 20   0);.      }..  
3320: 20 20 20 20 2f 2a 20 53 65 74 20 6e 44 65 73 74      /* Set nDest
3330: 54 72 75 6e 63 61 74 65 20 74 6f 20 74 68 65 20  Truncate to the 
3340: 66 69 6e 61 6c 20 6e 75 6d 62 65 72 20 6f 66 20  final number of 
3350: 70 61 67 65 73 20 69 6e 20 74 68 65 20 64 65 73  pages in the des
3360: 74 69 6e 61 74 69 6f 6e 0a 20 20 20 20 20 20 2a  tination.      *
3370: 2a 20 64 61 74 61 62 61 73 65 2e 20 54 68 65 20  * database. The 
3380: 63 6f 6d 70 6c 69 63 61 74 69 6f 6e 20 68 65 72  complication her
3390: 65 20 69 73 20 74 68 61 74 20 74 68 65 20 64 65  e is that the de
33a0: 73 74 69 6e 61 74 69 6f 6e 20 70 61 67 65 0a 20  stination page. 
33b0: 20 20 20 20 20 2a 2a 20 73 69 7a 65 20 6d 61 79       ** size may
33c0: 20 62 65 20 64 69 66 66 65 72 65 6e 74 20 74 6f   be different to
33d0: 20 74 68 65 20 73 6f 75 72 63 65 20 70 61 67 65   the source page
33e0: 20 73 69 7a 65 2e 20 0a 20 20 20 20 20 20 2a 2a   size. .      **
33f0: 0a 20 20 20 20 20 20 2a 2a 20 49 66 20 74 68 65  .      ** If the
3400: 20 73 6f 75 72 63 65 20 70 61 67 65 20 73 69 7a   source page siz
3410: 65 20 69 73 20 73 6d 61 6c 6c 65 72 20 74 68 61  e is smaller tha
3420: 6e 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f  n the destinatio
3430: 6e 20 70 61 67 65 20 73 69 7a 65 2c 20 0a 20 20  n page size, .  
3440: 20 20 20 20 2a 2a 20 72 6f 75 6e 64 20 75 70 2e      ** round up.
3450: 20 49 6e 20 74 68 69 73 20 63 61 73 65 20 74 68   In this case th
3460: 65 20 63 61 6c 6c 20 74 6f 20 73 71 6c 69 74 65  e call to sqlite
3470: 33 4f 73 54 72 75 6e 63 61 74 65 28 29 20 62 65  3OsTruncate() be
3480: 6c 6f 77 20 77 69 6c 6c 0a 20 20 20 20 20 20 2a  low will.      *
3490: 2a 20 66 69 78 20 74 68 65 20 73 69 7a 65 20 6f  * fix the size o
34a0: 66 20 74 68 65 20 66 69 6c 65 2e 20 48 6f 77 65  f the file. Howe
34b0: 76 65 72 20 69 74 20 69 73 20 69 6d 70 6f 72 74  ver it is import
34c0: 61 6e 74 20 74 6f 20 63 61 6c 6c 0a 20 20 20 20  ant to call.    
34d0: 20 20 2a 2a 20 73 71 6c 69 74 65 33 50 61 67 65    ** sqlite3Page
34e0: 72 54 72 75 6e 63 61 74 65 49 6d 61 67 65 28 29  rTruncateImage()
34f0: 20 68 65 72 65 20 73 6f 20 74 68 61 74 20 61 6e   here so that an
3500: 79 20 70 61 67 65 73 20 69 6e 20 74 68 65 20 0a  y pages in the .
3510: 20 20 20 20 20 20 2a 2a 20 64 65 73 74 69 6e 61        ** destina
3520: 74 69 6f 6e 20 66 69 6c 65 20 74 68 61 74 20 6c  tion file that l
3530: 69 65 20 62 65 79 6f 6e 64 20 74 68 65 20 6e 44  ie beyond the nD
3540: 65 73 74 54 72 75 6e 63 61 74 65 20 70 61 67 65  estTruncate page
3550: 20 6d 61 72 6b 20 61 72 65 0a 20 20 20 20 20 20   mark are.      
3560: 2a 2a 20 6a 6f 75 72 6e 61 6c 6c 65 64 20 62 79  ** journalled by
3570: 20 50 61 67 65 72 43 6f 6d 6d 69 74 50 68 61 73   PagerCommitPhas
3580: 65 4f 6e 65 28 29 20 62 65 66 6f 72 65 20 74 68  eOne() before th
3590: 65 79 20 61 72 65 20 64 65 73 74 72 6f 79 65 64  ey are destroyed
35a0: 0a 20 20 20 20 20 20 2a 2a 20 62 79 20 74 68 65  .      ** by the
35b0: 20 66 69 6c 65 20 74 72 75 6e 63 61 74 69 6f 6e   file truncation
35c0: 2e 0a 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20  ..      */.     
35d0: 20 69 66 28 20 6e 53 72 63 50 61 67 65 73 69 7a   if( nSrcPagesiz
35e0: 65 3c 6e 44 65 73 74 50 61 67 65 73 69 7a 65 20  e<nDestPagesize 
35f0: 29 7b 0a 20 20 20 20 20 20 20 20 69 6e 74 20 72  ){.        int r
3600: 61 74 69 6f 20 3d 20 6e 44 65 73 74 50 61 67 65  atio = nDestPage
3610: 73 69 7a 65 2f 6e 53 72 63 50 61 67 65 73 69 7a  size/nSrcPagesiz
3620: 65 3b 0a 20 20 20 20 20 20 20 20 6e 44 65 73 74  e;.        nDest
3630: 54 72 75 6e 63 61 74 65 20 3d 20 28 6e 53 72 63  Truncate = (nSrc
3640: 50 61 67 65 2b 72 61 74 69 6f 2d 31 29 2f 72 61  Page+ratio-1)/ra
3650: 74 69 6f 3b 0a 20 20 20 20 20 20 20 20 69 66 28  tio;.        if(
3660: 20 6e 44 65 73 74 54 72 75 6e 63 61 74 65 3d 3d   nDestTruncate==
3670: 28 69 6e 74 29 50 45 4e 44 49 4e 47 5f 42 59 54  (int)PENDING_BYT
3680: 45 5f 50 41 47 45 28 70 2d 3e 70 44 65 73 74 2d  E_PAGE(p->pDest-
3690: 3e 70 42 74 29 20 29 7b 0a 20 20 20 20 20 20 20  >pBt) ){.       
36a0: 20 20 20 6e 44 65 73 74 54 72 75 6e 63 61 74 65     nDestTruncate
36b0: 2d 2d 3b 0a 20 20 20 20 20 20 20 20 7d 0a 20 20  --;.        }.  
36c0: 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20      }else{.     
36d0: 20 20 20 6e 44 65 73 74 54 72 75 6e 63 61 74 65     nDestTruncate
36e0: 20 3d 20 6e 53 72 63 50 61 67 65 20 2a 20 28 6e   = nSrcPage * (n
36f0: 53 72 63 50 61 67 65 73 69 7a 65 2f 6e 44 65 73  SrcPagesize/nDes
3700: 74 50 61 67 65 73 69 7a 65 29 3b 0a 20 20 20 20  tPagesize);.    
3710: 20 20 7d 0a 20 20 20 20 20 20 73 71 6c 69 74 65    }.      sqlite
3720: 33 50 61 67 65 72 54 72 75 6e 63 61 74 65 49 6d  3PagerTruncateIm
3730: 61 67 65 28 70 44 65 73 74 50 61 67 65 72 2c 20  age(pDestPager, 
3740: 6e 44 65 73 74 54 72 75 6e 63 61 74 65 29 3b 0a  nDestTruncate);.
3750: 0a 20 20 20 20 20 20 69 66 28 20 6e 53 72 63 50  .      if( nSrcP
3760: 61 67 65 73 69 7a 65 3c 6e 44 65 73 74 50 61 67  agesize<nDestPag
3770: 65 73 69 7a 65 20 29 7b 0a 20 20 20 20 20 20 20  esize ){.       
3780: 20 2f 2a 20 49 66 20 74 68 65 20 73 6f 75 72 63   /* If the sourc
3790: 65 20 70 61 67 65 2d 73 69 7a 65 20 69 73 20 73  e page-size is s
37a0: 6d 61 6c 6c 65 72 20 74 68 61 6e 20 74 68 65 20  maller than the 
37b0: 64 65 73 74 69 6e 61 74 69 6f 6e 20 70 61 67 65  destination page
37c0: 2d 73 69 7a 65 2c 0a 20 20 20 20 20 20 20 20 2a  -size,.        *
37d0: 2a 20 74 77 6f 20 65 78 74 72 61 20 74 68 69 6e  * two extra thin
37e0: 67 73 20 6d 61 79 20 6e 65 65 64 20 74 6f 20 68  gs may need to h
37f0: 61 70 70 65 6e 3a 0a 20 20 20 20 20 20 20 20 2a  appen:.        *
3800: 2a 0a 20 20 20 20 20 20 20 20 2a 2a 20 20 20 2a  *.        **   *
3810: 20 54 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e   The destination
3820: 20 6d 61 79 20 6e 65 65 64 20 74 6f 20 62 65 20   may need to be 
3830: 74 72 75 6e 63 61 74 65 64 2c 20 61 6e 64 0a 20  truncated, and. 
3840: 20 20 20 20 20 20 20 2a 2a 0a 20 20 20 20 20 20         **.      
3850: 20 20 2a 2a 20 20 20 2a 20 44 61 74 61 20 73 74    **   * Data st
3860: 6f 72 65 64 20 6f 6e 20 74 68 65 20 70 61 67 65  ored on the page
3870: 73 20 69 6d 6d 65 64 69 61 74 65 6c 79 20 66 6f  s immediately fo
3880: 6c 6c 6f 77 69 6e 67 20 74 68 65 20 0a 20 20 20  llowing the .   
3890: 20 20 20 20 20 2a 2a 20 20 20 20 20 70 65 6e 64       **     pend
38a0: 69 6e 67 2d 62 79 74 65 20 70 61 67 65 20 69 6e  ing-byte page in
38b0: 20 74 68 65 20 73 6f 75 72 63 65 20 64 61 74 61   the source data
38c0: 62 61 73 65 20 6d 61 79 20 6e 65 65 64 20 74 6f  base may need to
38d0: 20 62 65 0a 20 20 20 20 20 20 20 20 2a 2a 20 20   be.        **  
38e0: 20 20 20 63 6f 70 69 65 64 20 69 6e 74 6f 20 74     copied into t
38f0: 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 64  he destination d
3900: 61 74 61 62 61 73 65 2e 0a 20 20 20 20 20 20 20  atabase..       
3910: 20 2a 2f 0a 20 20 20 20 20 20 20 20 63 6f 6e 73   */.        cons
3920: 74 20 69 36 34 20 69 53 69 7a 65 20 3d 20 28 69  t i64 iSize = (i
3930: 36 34 29 6e 53 72 63 50 61 67 65 73 69 7a 65 20  64)nSrcPagesize 
3940: 2a 20 28 69 36 34 29 6e 53 72 63 50 61 67 65 3b  * (i64)nSrcPage;
3950: 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33  .        sqlite3
3960: 5f 66 69 6c 65 20 2a 20 63 6f 6e 73 74 20 70 46  _file * const pF
3970: 69 6c 65 20 3d 20 73 71 6c 69 74 65 33 50 61 67  ile = sqlite3Pag
3980: 65 72 46 69 6c 65 28 70 44 65 73 74 50 61 67 65  erFile(pDestPage
3990: 72 29 3b 0a 0a 20 20 20 20 20 20 20 20 61 73 73  r);..        ass
39a0: 65 72 74 28 20 70 46 69 6c 65 20 29 3b 0a 20 20  ert( pFile );.  
39b0: 20 20 20 20 20 20 61 73 73 65 72 74 28 20 28 69        assert( (i
39c0: 36 34 29 6e 44 65 73 74 54 72 75 6e 63 61 74 65  64)nDestTruncate
39d0: 2a 28 69 36 34 29 6e 44 65 73 74 50 61 67 65 73  *(i64)nDestPages
39e0: 69 7a 65 20 3e 3d 20 69 53 69 7a 65 20 7c 7c 20  ize >= iSize || 
39f0: 28 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  (.              
3a00: 6e 44 65 73 74 54 72 75 6e 63 61 74 65 3d 3d 28  nDestTruncate==(
3a10: 69 6e 74 29 28 50 45 4e 44 49 4e 47 5f 42 59 54  int)(PENDING_BYT
3a20: 45 5f 50 41 47 45 28 70 2d 3e 70 44 65 73 74 2d  E_PAGE(p->pDest-
3a30: 3e 70 42 74 29 2d 31 29 0a 20 20 20 20 20 20 20  >pBt)-1).       
3a40: 20 20 20 20 26 26 20 69 53 69 7a 65 3e 3d 50 45      && iSize>=PE
3a50: 4e 44 49 4e 47 5f 42 59 54 45 20 26 26 20 69 53  NDING_BYTE && iS
3a60: 69 7a 65 3c 3d 50 45 4e 44 49 4e 47 5f 42 59 54  ize<=PENDING_BYT
3a70: 45 2b 6e 44 65 73 74 50 61 67 65 73 69 7a 65 0a  E+nDestPagesize.
3a80: 20 20 20 20 20 20 20 20 29 29 3b 0a 20 20 20 20          ));.    
3a90: 20 20 20 20 69 66 28 20 53 51 4c 49 54 45 5f 4f      if( SQLITE_O
3aa0: 4b 3d 3d 28 72 63 20 3d 20 73 71 6c 69 74 65 33  K==(rc = sqlite3
3ab0: 50 61 67 65 72 43 6f 6d 6d 69 74 50 68 61 73 65  PagerCommitPhase
3ac0: 4f 6e 65 28 70 44 65 73 74 50 61 67 65 72 2c 20  One(pDestPager, 
3ad0: 30 2c 20 31 29 29 0a 20 20 20 20 20 20 20 20 20  0, 1)).         
3ae0: 26 26 20 53 51 4c 49 54 45 5f 4f 4b 3d 3d 28 72  && SQLITE_OK==(r
3af0: 63 20 3d 20 62 61 63 6b 75 70 54 72 75 6e 63 61  c = backupTrunca
3b00: 74 65 46 69 6c 65 28 70 46 69 6c 65 2c 20 69 53  teFile(pFile, iS
3b10: 69 7a 65 29 29 0a 20 20 20 20 20 20 20 20 20 26  ize)).         &
3b20: 26 20 53 51 4c 49 54 45 5f 4f 4b 3d 3d 28 72 63  & SQLITE_OK==(rc
3b30: 20 3d 20 73 71 6c 69 74 65 33 50 61 67 65 72 53   = sqlite3PagerS
3b40: 79 6e 63 28 70 44 65 73 74 50 61 67 65 72 29 29  ync(pDestPager))
3b50: 0a 20 20 20 20 20 20 20 20 29 7b 0a 20 20 20 20  .        ){.    
3b60: 20 20 20 20 20 20 69 36 34 20 69 4f 66 66 3b 0a        i64 iOff;.
3b70: 20 20 20 20 20 20 20 20 20 20 69 36 34 20 69 45            i64 iE
3b80: 6e 64 20 3d 20 4d 49 4e 28 50 45 4e 44 49 4e 47  nd = MIN(PENDING
3b90: 5f 42 59 54 45 20 2b 20 6e 44 65 73 74 50 61 67  _BYTE + nDestPag
3ba0: 65 73 69 7a 65 2c 20 69 53 69 7a 65 29 3b 0a 20  esize, iSize);. 
3bb0: 20 20 20 20 20 20 20 20 20 66 6f 72 28 0a 20 20           for(.  
3bc0: 20 20 20 20 20 20 20 20 20 20 69 4f 66 66 3d 50            iOff=P
3bd0: 45 4e 44 49 4e 47 5f 42 59 54 45 2b 6e 53 72 63  ENDING_BYTE+nSrc
3be0: 50 61 67 65 73 69 7a 65 3b 20 0a 20 20 20 20 20  Pagesize; .     
3bf0: 20 20 20 20 20 20 20 72 63 3d 3d 53 51 4c 49 54         rc==SQLIT
3c00: 45 5f 4f 4b 20 26 26 20 69 4f 66 66 3c 69 45 6e  E_OK && iOff<iEn
3c10: 64 3b 20 0a 20 20 20 20 20 20 20 20 20 20 20 20  d; .            
3c20: 69 4f 66 66 2b 3d 6e 53 72 63 50 61 67 65 73 69  iOff+=nSrcPagesi
3c30: 7a 65 0a 20 20 20 20 20 20 20 20 20 20 29 7b 0a  ze.          ){.
3c40: 20 20 20 20 20 20 20 20 20 20 20 20 50 67 48 64              PgHd
3c50: 72 20 2a 70 53 72 63 50 67 20 3d 20 30 3b 0a 20  r *pSrcPg = 0;. 
3c60: 20 20 20 20 20 20 20 20 20 20 20 63 6f 6e 73 74             const
3c70: 20 50 67 6e 6f 20 69 53 72 63 50 67 20 3d 20 28   Pgno iSrcPg = (
3c80: 50 67 6e 6f 29 28 28 69 4f 66 66 2f 6e 53 72 63  Pgno)((iOff/nSrc
3c90: 50 61 67 65 73 69 7a 65 29 2b 31 29 3b 0a 20 20  Pagesize)+1);.  
3ca0: 20 20 20 20 20 20 20 20 20 20 72 63 20 3d 20 73            rc = s
3cb0: 71 6c 69 74 65 33 50 61 67 65 72 47 65 74 28 70  qlite3PagerGet(p
3cc0: 53 72 63 50 61 67 65 72 2c 20 69 53 72 63 50 67  SrcPager, iSrcPg
3cd0: 2c 20 26 70 53 72 63 50 67 29 3b 0a 20 20 20 20  , &pSrcPg);.    
3ce0: 20 20 20 20 20 20 20 20 69 66 28 20 72 63 3d 3d          if( rc==
3cf0: 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20  SQLITE_OK ){.   
3d00: 20 20 20 20 20 20 20 20 20 20 20 75 38 20 2a 7a             u8 *z
3d10: 44 61 74 61 20 3d 20 73 71 6c 69 74 65 33 50 61  Data = sqlite3Pa
3d20: 67 65 72 47 65 74 44 61 74 61 28 70 53 72 63 50  gerGetData(pSrcP
3d30: 67 29 3b 0a 20 20 20 20 20 20 20 20 20 20 20 20  g);.            
3d40: 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 4f 73    rc = sqlite3Os
3d50: 57 72 69 74 65 28 70 46 69 6c 65 2c 20 7a 44 61  Write(pFile, zDa
3d60: 74 61 2c 20 6e 53 72 63 50 61 67 65 73 69 7a 65  ta, nSrcPagesize
3d70: 2c 20 69 4f 66 66 29 3b 0a 20 20 20 20 20 20 20  , iOff);.       
3d80: 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 20       }.         
3d90: 20 20 20 73 71 6c 69 74 65 33 50 61 67 65 72 55     sqlite3PagerU
3da0: 6e 72 65 66 28 70 53 72 63 50 67 29 3b 0a 20 20  nref(pSrcPg);.  
3db0: 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20          }.      
3dc0: 20 20 7d 0a 20 20 20 20 20 20 7d 65 6c 73 65 7b    }.      }else{
3dd0: 0a 20 20 20 20 20 20 20 20 72 63 20 3d 20 73 71  .        rc = sq
3de0: 6c 69 74 65 33 50 61 67 65 72 43 6f 6d 6d 69 74  lite3PagerCommit
3df0: 50 68 61 73 65 4f 6e 65 28 70 44 65 73 74 50 61  PhaseOne(pDestPa
3e00: 67 65 72 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20  ger, 0, 0);.    
3e10: 20 20 7d 0a 20 20 0a 20 20 20 20 20 20 2f 2a 20    }.  .      /* 
3e20: 46 69 6e 69 73 68 20 63 6f 6d 6d 69 74 74 69 6e  Finish committin
3e30: 67 20 74 68 65 20 74 72 61 6e 73 61 63 74 69 6f  g the transactio
3e40: 6e 20 74 6f 20 74 68 65 20 64 65 73 74 69 6e 61  n to the destina
3e50: 74 69 6f 6e 20 64 61 74 61 62 61 73 65 2e 20 2a  tion database. *
3e60: 2f 0a 20 20 20 20 20 20 69 66 28 20 53 51 4c 49  /.      if( SQLI
3e70: 54 45 5f 4f 4b 3d 3d 72 63 0a 20 20 20 20 20 20  TE_OK==rc.      
3e80: 20 26 26 20 53 51 4c 49 54 45 5f 4f 4b 3d 3d 28   && SQLITE_OK==(
3e90: 72 63 20 3d 20 73 71 6c 69 74 65 33 42 74 72 65  rc = sqlite3Btre
3ea0: 65 43 6f 6d 6d 69 74 50 68 61 73 65 54 77 6f 28  eCommitPhaseTwo(
3eb0: 70 2d 3e 70 44 65 73 74 29 29 0a 20 20 20 20 20  p->pDest)).     
3ec0: 20 29 7b 0a 20 20 20 20 20 20 20 20 72 63 20 3d   ){.        rc =
3ed0: 20 53 51 4c 49 54 45 5f 44 4f 4e 45 3b 0a 20 20   SQLITE_DONE;.  
3ee0: 20 20 20 20 7d 0a 20 20 20 20 7d 0a 20 20 0a 20      }.    }.  . 
3ef0: 20 20 20 2f 2a 20 49 66 20 62 43 6c 6f 73 65 54     /* If bCloseT
3f00: 72 61 6e 73 20 69 73 20 74 72 75 65 2c 20 74 68  rans is true, th
3f10: 65 6e 20 74 68 69 73 20 66 75 6e 63 74 69 6f 6e  en this function
3f20: 20 6f 70 65 6e 65 64 20 61 20 72 65 61 64 20 74   opened a read t
3f30: 72 61 6e 73 61 63 74 69 6f 6e 0a 20 20 20 20 2a  ransaction.    *
3f40: 2a 20 6f 6e 20 74 68 65 20 73 6f 75 72 63 65 20  * on the source 
3f50: 64 61 74 61 62 61 73 65 2e 20 43 6c 6f 73 65 20  database. Close 
3f60: 74 68 65 20 72 65 61 64 20 74 72 61 6e 73 61 63  the read transac
3f70: 74 69 6f 6e 20 68 65 72 65 2e 20 54 68 65 72 65  tion here. There
3f80: 20 69 73 0a 20 20 20 20 2a 2a 20 6e 6f 20 6e 65   is.    ** no ne
3f90: 65 64 20 74 6f 20 63 68 65 63 6b 20 74 68 65 20  ed to check the 
3fa0: 72 65 74 75 72 6e 20 76 61 6c 75 65 73 20 6f 66  return values of
3fb0: 20 74 68 65 20 62 74 72 65 65 20 6d 65 74 68 6f   the btree metho
3fc0: 64 73 20 68 65 72 65 2c 20 61 73 0a 20 20 20 20  ds here, as.    
3fd0: 2a 2a 20 22 63 6f 6d 6d 69 74 74 69 6e 67 22 20  ** "committing" 
3fe0: 61 20 72 65 61 64 2d 6f 6e 6c 79 20 74 72 61 6e  a read-only tran
3ff0: 73 61 63 74 69 6f 6e 20 63 61 6e 6e 6f 74 20 66  saction cannot f
4000: 61 69 6c 2e 0a 20 20 20 20 2a 2f 0a 20 20 20 20  ail..    */.    
4010: 69 66 28 20 62 43 6c 6f 73 65 54 72 61 6e 73 20  if( bCloseTrans 
4020: 29 7b 0a 20 20 20 20 20 20 54 45 53 54 4f 4e 4c  ){.      TESTONL
4030: 59 28 20 69 6e 74 20 72 63 32 20 29 3b 0a 20 20  Y( int rc2 );.  
4040: 20 20 20 20 54 45 53 54 4f 4e 4c 59 28 20 72 63      TESTONLY( rc
4050: 32 20 20 3d 20 29 20 73 71 6c 69 74 65 33 42 74  2  = ) sqlite3Bt
4060: 72 65 65 43 6f 6d 6d 69 74 50 68 61 73 65 4f 6e  reeCommitPhaseOn
4070: 65 28 70 2d 3e 70 53 72 63 2c 20 30 29 3b 0a 20  e(p->pSrc, 0);. 
4080: 20 20 20 20 20 54 45 53 54 4f 4e 4c 59 28 20 72       TESTONLY( r
4090: 63 32 20 7c 3d 20 29 20 73 71 6c 69 74 65 33 42  c2 |= ) sqlite3B
40a0: 74 72 65 65 43 6f 6d 6d 69 74 50 68 61 73 65 54  treeCommitPhaseT
40b0: 77 6f 28 70 2d 3e 70 53 72 63 29 3b 0a 20 20 20  wo(p->pSrc);.   
40c0: 20 20 20 61 73 73 65 72 74 28 20 72 63 32 3d 3d     assert( rc2==
40d0: 53 51 4c 49 54 45 5f 4f 4b 20 29 3b 0a 20 20 20  SQLITE_OK );.   
40e0: 20 7d 0a 20 20 0a 20 20 20 20 70 2d 3e 72 63 20   }.  .    p->rc 
40f0: 3d 20 72 63 3b 0a 20 20 7d 0a 20 20 69 66 28 20  = rc;.  }.  if( 
4100: 70 2d 3e 70 44 65 73 74 44 62 20 29 7b 0a 20 20  p->pDestDb ){.  
4110: 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f    sqlite3_mutex_
4120: 6c 65 61 76 65 28 70 2d 3e 70 44 65 73 74 44 62  leave(p->pDestDb
4130: 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 7d 0a 20 20  ->mutex);.  }.  
4140: 73 71 6c 69 74 65 33 42 74 72 65 65 4c 65 61 76  sqlite3BtreeLeav
4150: 65 28 70 2d 3e 70 53 72 63 29 3b 0a 20 20 73 71  e(p->pSrc);.  sq
4160: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76  lite3_mutex_leav
4170: 65 28 70 2d 3e 70 53 72 63 44 62 2d 3e 6d 75 74  e(p->pSrcDb->mut
4180: 65 78 29 3b 0a 20 20 72 65 74 75 72 6e 20 72 63  ex);.  return rc
4190: 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 6c 65 61  ;.}../*.** Relea
41a0: 73 65 20 61 6c 6c 20 72 65 73 6f 75 72 63 65 73  se all resources
41b0: 20 61 73 73 6f 63 69 61 74 65 64 20 77 69 74 68   associated with
41c0: 20 61 6e 20 73 71 6c 69 74 65 33 5f 62 61 63 6b   an sqlite3_back
41d0: 75 70 2a 20 68 61 6e 64 6c 65 2e 0a 2a 2f 0a 69  up* handle..*/.i
41e0: 6e 74 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75  nt sqlite3_backu
41f0: 70 5f 66 69 6e 69 73 68 28 73 71 6c 69 74 65 33  p_finish(sqlite3
4200: 5f 62 61 63 6b 75 70 20 2a 70 29 7b 0a 20 20 73  _backup *p){.  s
4210: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 2a  qlite3_backup **
4220: 70 70 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  pp;             
4230: 20 20 20 20 2f 2a 20 50 74 72 20 74 6f 20 68 65      /* Ptr to he
4240: 61 64 20 6f 66 20 70 61 67 65 72 73 20 62 61 63  ad of pagers bac
4250: 6b 75 70 20 6c 69 73 74 20 2a 2f 0a 20 20 73 71  kup list */.  sq
4260: 6c 69 74 65 33 5f 6d 75 74 65 78 20 2a 6d 75 74  lite3_mutex *mut
4270: 65 78 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  ex;             
4280: 20 20 20 2f 2a 20 4d 75 74 65 78 20 74 6f 20 70     /* Mutex to p
4290: 72 6f 74 65 63 74 20 73 6f 75 72 63 65 20 64 61  rotect source da
42a0: 74 61 62 61 73 65 20 2a 2f 0a 20 20 69 6e 74 20  tabase */.  int 
42b0: 72 63 3b 20 20 20 20 20 20 20 20 20 20 20 20 20  rc;             
42c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
42d0: 20 2f 2a 20 56 61 6c 75 65 20 74 6f 20 72 65 74   /* Value to ret
42e0: 75 72 6e 20 2a 2f 0a 0a 20 20 2f 2a 20 45 6e 74  urn */..  /* Ent
42f0: 65 72 20 74 68 65 20 6d 75 74 65 78 65 73 20 2a  er the mutexes *
4300: 2f 0a 20 20 69 66 28 20 70 3d 3d 30 20 29 20 72  /.  if( p==0 ) r
4310: 65 74 75 72 6e 20 53 51 4c 49 54 45 5f 4f 4b 3b  eturn SQLITE_OK;
4320: 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 78  .  sqlite3_mutex
4330: 5f 65 6e 74 65 72 28 70 2d 3e 70 53 72 63 44 62  _enter(p->pSrcDb
4340: 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 73 71 6c 69  ->mutex);.  sqli
4350: 74 65 33 42 74 72 65 65 45 6e 74 65 72 28 70 2d  te3BtreeEnter(p-
4360: 3e 70 53 72 63 29 3b 0a 20 20 6d 75 74 65 78 20  >pSrc);.  mutex 
4370: 3d 20 70 2d 3e 70 53 72 63 44 62 2d 3e 6d 75 74  = p->pSrcDb->mut
4380: 65 78 3b 0a 20 20 69 66 28 20 70 2d 3e 70 44 65  ex;.  if( p->pDe
4390: 73 74 44 62 20 29 7b 0a 20 20 20 20 73 71 6c 69  stDb ){.    sqli
43a0: 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28  te3_mutex_enter(
43b0: 70 2d 3e 70 44 65 73 74 44 62 2d 3e 6d 75 74 65  p->pDestDb->mute
43c0: 78 29 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 44 65  x);.  }..  /* De
43d0: 74 61 63 68 20 74 68 69 73 20 62 61 63 6b 75 70  tach this backup
43e0: 20 66 72 6f 6d 20 74 68 65 20 73 6f 75 72 63 65   from the source
43f0: 20 70 61 67 65 72 2e 20 2a 2f 0a 20 20 69 66 28   pager. */.  if(
4400: 20 70 2d 3e 70 44 65 73 74 44 62 20 29 7b 0a 20   p->pDestDb ){. 
4410: 20 20 20 70 2d 3e 70 53 72 63 2d 3e 6e 42 61 63     p->pSrc->nBac
4420: 6b 75 70 2d 2d 3b 0a 20 20 7d 0a 20 20 69 66 28  kup--;.  }.  if(
4430: 20 70 2d 3e 69 73 41 74 74 61 63 68 65 64 20 29   p->isAttached )
4440: 7b 0a 20 20 20 20 70 70 20 3d 20 73 71 6c 69 74  {.    pp = sqlit
4450: 65 33 50 61 67 65 72 42 61 63 6b 75 70 50 74 72  e3PagerBackupPtr
4460: 28 73 71 6c 69 74 65 33 42 74 72 65 65 50 61 67  (sqlite3BtreePag
4470: 65 72 28 70 2d 3e 70 53 72 63 29 29 3b 0a 20 20  er(p->pSrc));.  
4480: 20 20 77 68 69 6c 65 28 20 2a 70 70 21 3d 70 20    while( *pp!=p 
4490: 29 7b 0a 20 20 20 20 20 20 70 70 20 3d 20 26 28  ){.      pp = &(
44a0: 2a 70 70 29 2d 3e 70 4e 65 78 74 3b 0a 20 20 20  *pp)->pNext;.   
44b0: 20 7d 0a 20 20 20 20 2a 70 70 20 3d 20 70 2d 3e   }.    *pp = p->
44c0: 70 4e 65 78 74 3b 0a 20 20 7d 0a 0a 20 20 2f 2a  pNext;.  }..  /*
44d0: 20 49 66 20 61 20 74 72 61 6e 73 61 63 74 69 6f   If a transactio
44e0: 6e 20 69 73 20 73 74 69 6c 6c 20 6f 70 65 6e 20  n is still open 
44f0: 6f 6e 20 74 68 65 20 42 74 72 65 65 2c 20 72 6f  on the Btree, ro
4500: 6c 6c 20 69 74 20 62 61 63 6b 2e 20 2a 2f 0a 20  ll it back. */. 
4510: 20 73 71 6c 69 74 65 33 42 74 72 65 65 52 6f 6c   sqlite3BtreeRol
4520: 6c 62 61 63 6b 28 70 2d 3e 70 44 65 73 74 29 3b  lback(p->pDest);
4530: 0a 0a 20 20 2f 2a 20 53 65 74 20 74 68 65 20 65  ..  /* Set the e
4540: 72 72 6f 72 20 63 6f 64 65 20 6f 66 20 74 68 65  rror code of the
4550: 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 64 61 74   destination dat
4560: 61 62 61 73 65 20 68 61 6e 64 6c 65 2e 20 2a 2f  abase handle. */
4570: 0a 20 20 72 63 20 3d 20 28 70 2d 3e 72 63 3d 3d  .  rc = (p->rc==
4580: 53 51 4c 49 54 45 5f 44 4f 4e 45 29 20 3f 20 53  SQLITE_DONE) ? S
4590: 51 4c 49 54 45 5f 4f 4b 20 3a 20 70 2d 3e 72 63  QLITE_OK : p->rc
45a0: 3b 0a 20 20 73 71 6c 69 74 65 33 45 72 72 6f 72  ;.  sqlite3Error
45b0: 28 70 2d 3e 70 44 65 73 74 44 62 2c 20 72 63 2c  (p->pDestDb, rc,
45c0: 20 30 29 3b 0a 0a 20 20 2f 2a 20 45 78 69 74 20   0);..  /* Exit 
45d0: 74 68 65 20 6d 75 74 65 78 65 73 20 61 6e 64 20  the mutexes and 
45e0: 66 72 65 65 20 74 68 65 20 62 61 63 6b 75 70 20  free the backup 
45f0: 63 6f 6e 74 65 78 74 20 73 74 72 75 63 74 75 72  context structur
4600: 65 2e 20 2a 2f 0a 20 20 69 66 28 20 70 2d 3e 70  e. */.  if( p->p
4610: 44 65 73 74 44 62 20 29 7b 0a 20 20 20 20 73 71  DestDb ){.    sq
4620: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76  lite3_mutex_leav
4630: 65 28 70 2d 3e 70 44 65 73 74 44 62 2d 3e 6d 75  e(p->pDestDb->mu
4640: 74 65 78 29 3b 0a 20 20 7d 0a 20 20 73 71 6c 69  tex);.  }.  sqli
4650: 74 65 33 42 74 72 65 65 4c 65 61 76 65 28 70 2d  te3BtreeLeave(p-
4660: 3e 70 53 72 63 29 3b 0a 20 20 69 66 28 20 70 2d  >pSrc);.  if( p-
4670: 3e 70 44 65 73 74 44 62 20 29 7b 0a 20 20 20 20  >pDestDb ){.    
4680: 73 71 6c 69 74 65 33 5f 66 72 65 65 28 70 29 3b  sqlite3_free(p);
4690: 0a 20 20 7d 0a 20 20 73 71 6c 69 74 65 33 5f 6d  .  }.  sqlite3_m
46a0: 75 74 65 78 5f 6c 65 61 76 65 28 6d 75 74 65 78  utex_leave(mutex
46b0: 29 3b 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a  );.  return rc;.
46c0: 7d 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20  }../*.** Return 
46d0: 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 70 61  the number of pa
46e0: 67 65 73 20 73 74 69 6c 6c 20 74 6f 20 62 65 20  ges still to be 
46f0: 62 61 63 6b 65 64 20 75 70 20 61 73 20 6f 66 20  backed up as of 
4700: 74 68 65 20 6d 6f 73 74 20 72 65 63 65 6e 74 0a  the most recent.
4710: 2a 2a 20 63 61 6c 6c 20 74 6f 20 73 71 6c 69 74  ** call to sqlit
4720: 65 33 5f 62 61 63 6b 75 70 5f 73 74 65 70 28 29  e3_backup_step()
4730: 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33  ..*/.int sqlite3
4740: 5f 62 61 63 6b 75 70 5f 72 65 6d 61 69 6e 69 6e  _backup_remainin
4750: 67 28 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70  g(sqlite3_backup
4760: 20 2a 70 29 7b 0a 20 20 72 65 74 75 72 6e 20 70   *p){.  return p
4770: 2d 3e 6e 52 65 6d 61 69 6e 69 6e 67 3b 0a 7d 0a  ->nRemaining;.}.
4780: 0a 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68  ./*.** Return th
4790: 65 20 74 6f 74 61 6c 20 6e 75 6d 62 65 72 20 6f  e total number o
47a0: 66 20 70 61 67 65 73 20 69 6e 20 74 68 65 20 73  f pages in the s
47b0: 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 20 61  ource database a
47c0: 73 20 6f 66 20 74 68 65 20 6d 6f 73 74 20 0a 2a  s of the most .*
47d0: 2a 20 72 65 63 65 6e 74 20 63 61 6c 6c 20 74 6f  * recent call to
47e0: 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f   sqlite3_backup_
47f0: 73 74 65 70 28 29 2e 0a 2a 2f 0a 69 6e 74 20 73  step()..*/.int s
4800: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 70 61  qlite3_backup_pa
4810: 67 65 63 6f 75 6e 74 28 73 71 6c 69 74 65 33 5f  gecount(sqlite3_
4820: 62 61 63 6b 75 70 20 2a 70 29 7b 0a 20 20 72 65  backup *p){.  re
4830: 74 75 72 6e 20 70 2d 3e 6e 50 61 67 65 63 6f 75  turn p->nPagecou
4840: 6e 74 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 69  nt;.}../*.** Thi
4850: 73 20 66 75 6e 63 74 69 6f 6e 20 69 73 20 63 61  s function is ca
4860: 6c 6c 65 64 20 61 66 74 65 72 20 74 68 65 20 63  lled after the c
4870: 6f 6e 74 65 6e 74 73 20 6f 66 20 70 61 67 65 20  ontents of page 
4880: 69 50 61 67 65 20 6f 66 20 74 68 65 0a 2a 2a 20  iPage of the.** 
4890: 73 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 20  source database 
48a0: 68 61 76 65 20 62 65 65 6e 20 6d 6f 64 69 66 69  have been modifi
48b0: 65 64 2e 20 49 66 20 70 61 67 65 20 69 50 61 67  ed. If page iPag
48c0: 65 20 68 61 73 20 61 6c 72 65 61 64 79 20 62 65  e has already be
48d0: 65 6e 20 0a 2a 2a 20 63 6f 70 69 65 64 20 69 6e  en .** copied in
48e0: 74 6f 20 74 68 65 20 64 65 73 74 69 6e 61 74 69  to the destinati
48f0: 6f 6e 20 64 61 74 61 62 61 73 65 2c 20 74 68 65  on database, the
4900: 6e 20 74 68 65 20 64 61 74 61 20 77 72 69 74 74  n the data writt
4910: 65 6e 20 74 6f 20 74 68 65 0a 2a 2a 20 64 65 73  en to the.** des
4920: 74 69 6e 61 74 69 6f 6e 20 69 73 20 6e 6f 77 20  tination is now 
4930: 69 6e 76 61 6c 69 64 61 74 65 64 2e 20 54 68 65  invalidated. The
4940: 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 63 6f 70   destination cop
4950: 79 20 6f 66 20 69 50 61 67 65 20 6e 65 65 64 73  y of iPage needs
4960: 0a 2a 2a 20 74 6f 20 62 65 20 75 70 64 61 74 65  .** to be update
4970: 64 20 77 69 74 68 20 74 68 65 20 6e 65 77 20 64  d with the new d
4980: 61 74 61 20 62 65 66 6f 72 65 20 74 68 65 20 62  ata before the b
4990: 61 63 6b 75 70 20 6f 70 65 72 61 74 69 6f 6e 20  ackup operation 
49a0: 69 73 0a 2a 2a 20 63 6f 6d 70 6c 65 74 65 2e 0a  is.** complete..
49b0: 2a 2a 0a 2a 2a 20 49 74 20 69 73 20 61 73 73 75  **.** It is assu
49c0: 6d 65 64 20 74 68 61 74 20 74 68 65 20 6d 75 74  med that the mut
49d0: 65 78 20 61 73 73 6f 63 69 61 74 65 64 20 77 69  ex associated wi
49e0: 74 68 20 74 68 65 20 42 74 53 68 61 72 65 64 20  th the BtShared 
49f0: 6f 62 6a 65 63 74 0a 2a 2a 20 63 6f 72 72 65 73  object.** corres
4a00: 70 6f 6e 64 69 6e 67 20 74 6f 20 74 68 65 20 73  ponding to the s
4a10: 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 20 69  ource database i
4a20: 73 20 68 65 6c 64 20 77 68 65 6e 20 74 68 69 73  s held when this
4a30: 20 66 75 6e 63 74 69 6f 6e 20 69 73 0a 2a 2a 20   function is.** 
4a40: 63 61 6c 6c 65 64 2e 0a 2a 2f 0a 76 6f 69 64 20  called..*/.void 
4a50: 73 71 6c 69 74 65 33 42 61 63 6b 75 70 55 70 64  sqlite3BackupUpd
4a60: 61 74 65 28 73 71 6c 69 74 65 33 5f 62 61 63 6b  ate(sqlite3_back
4a70: 75 70 20 2a 70 42 61 63 6b 75 70 2c 20 50 67 6e  up *pBackup, Pgn
4a80: 6f 20 69 50 61 67 65 2c 20 63 6f 6e 73 74 20 75  o iPage, const u
4a90: 38 20 2a 61 44 61 74 61 29 7b 0a 20 20 73 71 6c  8 *aData){.  sql
4aa0: 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 3b 20  ite3_backup *p; 
4ab0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4ac0: 20 20 2f 2a 20 49 74 65 72 61 74 6f 72 20 76 61    /* Iterator va
4ad0: 72 69 61 62 6c 65 20 2a 2f 0a 20 20 66 6f 72 28  riable */.  for(
4ae0: 70 3d 70 42 61 63 6b 75 70 3b 20 70 3b 20 70 3d  p=pBackup; p; p=
4af0: 70 2d 3e 70 4e 65 78 74 29 7b 0a 20 20 20 20 61  p->pNext){.    a
4b00: 73 73 65 72 74 28 20 73 71 6c 69 74 65 33 5f 6d  ssert( sqlite3_m
4b10: 75 74 65 78 5f 68 65 6c 64 28 70 2d 3e 70 53 72  utex_held(p->pSr
4b20: 63 2d 3e 70 42 74 2d 3e 6d 75 74 65 78 29 20 29  c->pBt->mutex) )
4b30: 3b 0a 20 20 20 20 69 66 28 20 21 69 73 46 61 74  ;.    if( !isFat
4b40: 61 6c 45 72 72 6f 72 28 70 2d 3e 72 63 29 20 26  alError(p->rc) &
4b50: 26 20 69 50 61 67 65 3c 70 2d 3e 69 4e 65 78 74  & iPage<p->iNext
4b60: 20 29 7b 0a 20 20 20 20 20 20 2f 2a 20 54 68 65   ){.      /* The
4b70: 20 62 61 63 6b 75 70 20 70 72 6f 63 65 73 73 20   backup process 
4b80: 70 20 68 61 73 20 61 6c 72 65 61 64 79 20 63 6f  p has already co
4b90: 70 69 65 64 20 70 61 67 65 20 69 50 61 67 65 2e  pied page iPage.
4ba0: 20 42 75 74 20 6e 6f 77 20 69 74 0a 20 20 20 20   But now it.    
4bb0: 20 20 2a 2a 20 68 61 73 20 62 65 65 6e 20 6d 6f    ** has been mo
4bc0: 64 69 66 69 65 64 20 62 79 20 61 20 74 72 61 6e  dified by a tran
4bd0: 73 61 63 74 69 6f 6e 20 6f 6e 20 74 68 65 20 73  saction on the s
4be0: 6f 75 72 63 65 20 70 61 67 65 72 2e 20 43 6f 70  ource pager. Cop
4bf0: 79 0a 20 20 20 20 20 20 2a 2a 20 74 68 65 20 6e  y.      ** the n
4c00: 65 77 20 64 61 74 61 20 69 6e 74 6f 20 74 68 65  ew data into the
4c10: 20 62 61 63 6b 75 70 2e 0a 20 20 20 20 20 20 2a   backup..      *
4c20: 2f 0a 20 20 20 20 20 20 69 6e 74 20 72 63 20 3d  /.      int rc =
4c30: 20 62 61 63 6b 75 70 4f 6e 65 50 61 67 65 28 70   backupOnePage(p
4c40: 2c 20 69 50 61 67 65 2c 20 61 44 61 74 61 29 3b  , iPage, aData);
4c50: 0a 20 20 20 20 20 20 61 73 73 65 72 74 28 20 72  .      assert( r
4c60: 63 21 3d 53 51 4c 49 54 45 5f 42 55 53 59 20 26  c!=SQLITE_BUSY &
4c70: 26 20 72 63 21 3d 53 51 4c 49 54 45 5f 4c 4f 43  & rc!=SQLITE_LOC
4c80: 4b 45 44 20 29 3b 0a 20 20 20 20 20 20 69 66 28  KED );.      if(
4c90: 20 72 63 21 3d 53 51 4c 49 54 45 5f 4f 4b 20 29   rc!=SQLITE_OK )
4ca0: 7b 0a 20 20 20 20 20 20 20 20 70 2d 3e 72 63 20  {.        p->rc 
4cb0: 3d 20 72 63 3b 0a 20 20 20 20 20 20 7d 0a 20 20  = rc;.      }.  
4cc0: 20 20 7d 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a    }.  }.}../*.**
4cd0: 20 52 65 73 74 61 72 74 20 74 68 65 20 62 61 63   Restart the bac
4ce0: 6b 75 70 20 70 72 6f 63 65 73 73 2e 20 54 68 69  kup process. Thi
4cf0: 73 20 69 73 20 63 61 6c 6c 65 64 20 77 68 65 6e  s is called when
4d00: 20 74 68 65 20 70 61 67 65 72 20 6c 61 79 65 72   the pager layer
4d10: 0a 2a 2a 20 64 65 74 65 63 74 73 20 74 68 61 74  .** detects that
4d20: 20 74 68 65 20 64 61 74 61 62 61 73 65 20 68 61   the database ha
4d30: 73 20 62 65 65 6e 20 6d 6f 64 69 66 69 65 64 20  s been modified 
4d40: 62 79 20 61 6e 20 65 78 74 65 72 6e 61 6c 20 64  by an external d
4d50: 61 74 61 62 61 73 65 0a 2a 2a 20 63 6f 6e 6e 65  atabase.** conne
4d60: 63 74 69 6f 6e 2e 20 49 6e 20 74 68 69 73 20 63  ction. In this c
4d70: 61 73 65 20 74 68 65 72 65 20 69 73 20 6e 6f 20  ase there is no 
4d80: 77 61 79 20 6f 66 20 6b 6e 6f 77 69 6e 67 20 77  way of knowing w
4d90: 68 69 63 68 20 6f 66 20 74 68 65 0a 2a 2a 20 70  hich of the.** p
4da0: 61 67 65 73 20 74 68 61 74 20 68 61 76 65 20 62  ages that have b
4db0: 65 65 6e 20 63 6f 70 69 65 64 20 69 6e 74 6f 20  een copied into 
4dc0: 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e 20  the destination 
4dd0: 64 61 74 61 62 61 73 65 20 61 72 65 20 73 74 69  database are sti
4de0: 6c 6c 20 0a 2a 2a 20 76 61 6c 69 64 20 61 6e 64  ll .** valid and
4df0: 20 77 68 69 63 68 20 61 72 65 20 6e 6f 74 2c 20   which are not, 
4e00: 73 6f 20 74 68 65 20 65 6e 74 69 72 65 20 70 72  so the entire pr
4e10: 6f 63 65 73 73 20 6e 65 65 64 73 20 74 6f 20 62  ocess needs to b
4e20: 65 20 72 65 73 74 61 72 74 65 64 2e 0a 2a 2a 0a  e restarted..**.
4e30: 2a 2a 20 49 74 20 69 73 20 61 73 73 75 6d 65 64  ** It is assumed
4e40: 20 74 68 61 74 20 74 68 65 20 6d 75 74 65 78 20   that the mutex 
4e50: 61 73 73 6f 63 69 61 74 65 64 20 77 69 74 68 20  associated with 
4e60: 74 68 65 20 42 74 53 68 61 72 65 64 20 6f 62 6a  the BtShared obj
4e70: 65 63 74 0a 2a 2a 20 63 6f 72 72 65 73 70 6f 6e  ect.** correspon
4e80: 64 69 6e 67 20 74 6f 20 74 68 65 20 73 6f 75 72  ding to the sour
4e90: 63 65 20 64 61 74 61 62 61 73 65 20 69 73 20 68  ce database is h
4ea0: 65 6c 64 20 77 68 65 6e 20 74 68 69 73 20 66 75  eld when this fu
4eb0: 6e 63 74 69 6f 6e 20 69 73 0a 2a 2a 20 63 61 6c  nction is.** cal
4ec0: 6c 65 64 2e 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c  led..*/.void sql
4ed0: 69 74 65 33 42 61 63 6b 75 70 52 65 73 74 61 72  ite3BackupRestar
4ee0: 74 28 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70  t(sqlite3_backup
4ef0: 20 2a 70 42 61 63 6b 75 70 29 7b 0a 20 20 73 71   *pBackup){.  sq
4f00: 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 3b  lite3_backup *p;
4f10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
4f20: 20 20 20 2f 2a 20 49 74 65 72 61 74 6f 72 20 76     /* Iterator v
4f30: 61 72 69 61 62 6c 65 20 2a 2f 0a 20 20 66 6f 72  ariable */.  for
4f40: 28 70 3d 70 42 61 63 6b 75 70 3b 20 70 3b 20 70  (p=pBackup; p; p
4f50: 3d 70 2d 3e 70 4e 65 78 74 29 7b 0a 20 20 20 20  =p->pNext){.    
4f60: 61 73 73 65 72 74 28 20 73 71 6c 69 74 65 33 5f  assert( sqlite3_
4f70: 6d 75 74 65 78 5f 68 65 6c 64 28 70 2d 3e 70 53  mutex_held(p->pS
4f80: 72 63 2d 3e 70 42 74 2d 3e 6d 75 74 65 78 29 20  rc->pBt->mutex) 
4f90: 29 3b 0a 20 20 20 20 70 2d 3e 69 4e 65 78 74 20  );.    p->iNext 
4fa0: 3d 20 31 3b 0a 20 20 7d 0a 7d 0a 0a 23 69 66 6e  = 1;.  }.}..#ifn
4fb0: 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f  def SQLITE_OMIT_
4fc0: 56 41 43 55 55 4d 0a 2f 2a 0a 2a 2a 20 43 6f 70  VACUUM./*.** Cop
4fd0: 79 20 74 68 65 20 63 6f 6d 70 6c 65 74 65 20 63  y the complete c
4fe0: 6f 6e 74 65 6e 74 20 6f 66 20 70 42 74 46 72 6f  ontent of pBtFro
4ff0: 6d 20 69 6e 74 6f 20 70 42 74 54 6f 2e 20 20 41  m into pBtTo.  A
5000: 20 74 72 61 6e 73 61 63 74 69 6f 6e 0a 2a 2a 20   transaction.** 
5010: 6d 75 73 74 20 62 65 20 61 63 74 69 76 65 20 66  must be active f
5020: 6f 72 20 62 6f 74 68 20 66 69 6c 65 73 2e 0a 2a  or both files..*
5030: 2a 0a 2a 2a 20 54 68 65 20 73 69 7a 65 20 6f 66  *.** The size of
5040: 20 66 69 6c 65 20 70 54 6f 20 6d 61 79 20 62 65   file pTo may be
5050: 20 72 65 64 75 63 65 64 20 62 79 20 74 68 69 73   reduced by this
5060: 20 6f 70 65 72 61 74 69 6f 6e 2e 20 49 66 20 61   operation. If a
5070: 6e 79 74 68 69 6e 67 20 0a 2a 2a 20 67 6f 65 73  nything .** goes
5080: 20 77 72 6f 6e 67 2c 20 74 68 65 20 74 72 61 6e   wrong, the tran
5090: 73 61 63 74 69 6f 6e 20 6f 6e 20 70 54 6f 20 69  saction on pTo i
50a0: 73 20 72 6f 6c 6c 65 64 20 62 61 63 6b 2e 20 49  s rolled back. I
50b0: 66 20 73 75 63 63 65 73 73 66 75 6c 2c 20 74 68  f successful, th
50c0: 65 20 0a 2a 2a 20 74 72 61 6e 73 61 63 74 69 6f  e .** transactio
50d0: 6e 20 69 73 20 63 6f 6d 6d 69 74 74 65 64 20 62  n is committed b
50e0: 65 66 6f 72 65 20 72 65 74 75 72 6e 69 6e 67 2e  efore returning.
50f0: 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 42  .*/.int sqlite3B
5100: 74 72 65 65 43 6f 70 79 46 69 6c 65 28 42 74 72  treeCopyFile(Btr
5110: 65 65 20 2a 70 54 6f 2c 20 42 74 72 65 65 20 2a  ee *pTo, Btree *
5120: 70 46 72 6f 6d 29 7b 0a 20 20 69 6e 74 20 72 63  pFrom){.  int rc
5130: 3b 0a 20 20 73 71 6c 69 74 65 33 5f 62 61 63 6b  ;.  sqlite3_back
5140: 75 70 20 62 3b 0a 20 20 73 71 6c 69 74 65 33 42  up b;.  sqlite3B
5150: 74 72 65 65 45 6e 74 65 72 28 70 54 6f 29 3b 0a  treeEnter(pTo);.
5160: 20 20 73 71 6c 69 74 65 33 42 74 72 65 65 45 6e    sqlite3BtreeEn
5170: 74 65 72 28 70 46 72 6f 6d 29 3b 0a 0a 20 20 2f  ter(pFrom);..  /
5180: 2a 20 53 65 74 20 75 70 20 61 6e 20 73 71 6c 69  * Set up an sqli
5190: 74 65 33 5f 62 61 63 6b 75 70 20 6f 62 6a 65 63  te3_backup objec
51a0: 74 2e 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75  t. sqlite3_backu
51b0: 70 2e 70 44 65 73 74 44 62 20 6d 75 73 74 20 62  p.pDestDb must b
51c0: 65 20 73 65 74 0a 20 20 2a 2a 20 74 6f 20 30 2e  e set.  ** to 0.
51d0: 20 54 68 69 73 20 69 73 20 75 73 65 64 20 62 79   This is used by
51e0: 20 74 68 65 20 69 6d 70 6c 65 6d 65 6e 74 61 74   the implementat
51f0: 69 6f 6e 73 20 6f 66 20 73 71 6c 69 74 65 33 5f  ions of sqlite3_
5200: 62 61 63 6b 75 70 5f 73 74 65 70 28 29 0a 20 20  backup_step().  
5210: 2a 2a 20 61 6e 64 20 73 71 6c 69 74 65 33 5f 62  ** and sqlite3_b
5220: 61 63 6b 75 70 5f 66 69 6e 69 73 68 28 29 20 74  ackup_finish() t
5230: 6f 20 64 65 74 65 63 74 20 74 68 61 74 20 74 68  o detect that th
5240: 65 79 20 61 72 65 20 62 65 69 6e 67 20 63 61 6c  ey are being cal
5250: 6c 65 64 0a 20 20 2a 2a 20 66 72 6f 6d 20 74 68  led.  ** from th
5260: 69 73 20 66 75 6e 63 74 69 6f 6e 2c 20 6e 6f 74  is function, not
5270: 20 64 69 72 65 63 74 6c 79 20 62 79 20 74 68 65   directly by the
5280: 20 75 73 65 72 2e 0a 20 20 2a 2f 0a 20 20 6d 65   user..  */.  me
5290: 6d 73 65 74 28 26 62 2c 20 30 2c 20 73 69 7a 65  mset(&b, 0, size
52a0: 6f 66 28 62 29 29 3b 0a 20 20 62 2e 70 53 72 63  of(b));.  b.pSrc
52b0: 44 62 20 3d 20 70 46 72 6f 6d 2d 3e 64 62 3b 0a  Db = pFrom->db;.
52c0: 20 20 62 2e 70 53 72 63 20 3d 20 70 46 72 6f 6d    b.pSrc = pFrom
52d0: 3b 0a 20 20 62 2e 70 44 65 73 74 20 3d 20 70 54  ;.  b.pDest = pT
52e0: 6f 3b 0a 20 20 62 2e 69 4e 65 78 74 20 3d 20 31  o;.  b.iNext = 1
52f0: 3b 0a 0a 20 20 2f 2a 20 30 78 37 46 46 46 46 46  ;..  /* 0x7FFFFF
5300: 46 46 20 69 73 20 74 68 65 20 68 61 72 64 20 6c  FF is the hard l
5310: 69 6d 69 74 20 66 6f 72 20 74 68 65 20 6e 75 6d  imit for the num
5320: 62 65 72 20 6f 66 20 70 61 67 65 73 20 69 6e 20  ber of pages in 
5330: 61 20 64 61 74 61 62 61 73 65 0a 20 20 2a 2a 20  a database.  ** 
5340: 66 69 6c 65 2e 20 42 79 20 70 61 73 73 69 6e 67  file. By passing
5350: 20 74 68 69 73 20 61 73 20 74 68 65 20 6e 75 6d   this as the num
5360: 62 65 72 20 6f 66 20 70 61 67 65 73 20 74 6f 20  ber of pages to 
5370: 63 6f 70 79 20 74 6f 0a 20 20 2a 2a 20 73 71 6c  copy to.  ** sql
5380: 69 74 65 33 5f 62 61 63 6b 75 70 5f 73 74 65 70  ite3_backup_step
5390: 28 29 2c 20 77 65 20 63 61 6e 20 67 75 61 72 61  (), we can guara
53a0: 6e 74 65 65 20 74 68 61 74 20 74 68 65 20 63 6f  ntee that the co
53b0: 70 79 20 66 69 6e 69 73 68 65 73 20 0a 20 20 2a  py finishes .  *
53c0: 2a 20 77 69 74 68 69 6e 20 61 20 73 69 6e 67 6c  * within a singl
53d0: 65 20 63 61 6c 6c 20 28 75 6e 6c 65 73 73 20 61  e call (unless a
53e0: 6e 20 65 72 72 6f 72 20 6f 63 63 75 72 73 29 2e  n error occurs).
53f0: 20 54 68 65 20 61 73 73 65 72 74 28 29 20 73 74   The assert() st
5400: 61 74 65 6d 65 6e 74 0a 20 20 2a 2a 20 63 68 65  atement.  ** che
5410: 63 6b 73 20 74 68 69 73 20 61 73 73 75 6d 70 74  cks this assumpt
5420: 69 6f 6e 20 2d 20 28 70 2d 3e 72 63 29 20 73 68  ion - (p->rc) sh
5430: 6f 75 6c 64 20 62 65 20 73 65 74 20 74 6f 20 65  ould be set to e
5440: 69 74 68 65 72 20 53 51 4c 49 54 45 5f 44 4f 4e  ither SQLITE_DON
5450: 45 20 0a 20 20 2a 2a 20 6f 72 20 61 6e 20 65 72  E .  ** or an er
5460: 72 6f 72 20 63 6f 64 65 2e 0a 20 20 2a 2f 0a 20  ror code..  */. 
5470: 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f   sqlite3_backup_
5480: 73 74 65 70 28 26 62 2c 20 30 78 37 46 46 46 46  step(&b, 0x7FFFF
5490: 46 46 46 29 3b 0a 20 20 61 73 73 65 72 74 28 20  FFF);.  assert( 
54a0: 62 2e 72 63 21 3d 53 51 4c 49 54 45 5f 4f 4b 20  b.rc!=SQLITE_OK 
54b0: 29 3b 0a 20 20 72 63 20 3d 20 73 71 6c 69 74 65  );.  rc = sqlite
54c0: 33 5f 62 61 63 6b 75 70 5f 66 69 6e 69 73 68 28  3_backup_finish(
54d0: 26 62 29 3b 0a 20 20 69 66 28 20 72 63 3d 3d 53  &b);.  if( rc==S
54e0: 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20  QLITE_OK ){.    
54f0: 70 54 6f 2d 3e 70 42 74 2d 3e 70 61 67 65 53 69  pTo->pBt->pageSi
5500: 7a 65 46 69 78 65 64 20 3d 20 30 3b 0a 20 20 7d  zeFixed = 0;.  }
5510: 0a 0a 20 20 73 71 6c 69 74 65 33 42 74 72 65 65  ..  sqlite3Btree
5520: 4c 65 61 76 65 28 70 46 72 6f 6d 29 3b 0a 20 20  Leave(pFrom);.  
5530: 73 71 6c 69 74 65 33 42 74 72 65 65 4c 65 61 76  sqlite3BtreeLeav
5540: 65 28 70 54 6f 29 3b 0a 20 20 72 65 74 75 72 6e  e(pTo);.  return
5550: 20 72 63 3b 0a 7d 0a 23 65 6e 64 69 66 20 2f 2a   rc;.}.#endif /*
5560: 20 53 51 4c 49 54 45 5f 4f 4d 49 54 5f 56 41 43   SQLITE_OMIT_VAC
5570: 55 55 4d 20 2a 2f 0a                             UUM */.