0000: 2f 2a 0a 2a 2a 20 32 30 30 39 20 4a 61 6e 75 61 /*.** 2009 Janua
0010: 72 79 20 32 38 0a 2a 2a 0a 2a 2a 20 54 68 65 20 ry 28.**.** The
0020: 61 75 74 68 6f 72 20 64 69 73 63 6c 61 69 6d 73 author disclaims
0030: 20 63 6f 70 79 72 69 67 68 74 20 74 6f 20 74 68 copyright to th
0040: 69 73 20 73 6f 75 72 63 65 20 63 6f 64 65 2e 20 is source code.
0050: 20 49 6e 20 70 6c 61 63 65 20 6f 66 0a 2a 2a 20 In place of.**
0060: 61 20 6c 65 67 61 6c 20 6e 6f 74 69 63 65 2c 20 a legal notice,
0070: 68 65 72 65 20 69 73 20 61 20 62 6c 65 73 73 69 here is a blessi
0080: 6e 67 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 4d 61 79 ng:.**.** May
0090: 20 79 6f 75 20 64 6f 20 67 6f 6f 64 20 61 6e 64 you do good and
00a0: 20 6e 6f 74 20 65 76 69 6c 2e 0a 2a 2a 20 20 20 not evil..**
00b0: 20 4d 61 79 20 79 6f 75 20 66 69 6e 64 20 66 6f May you find fo
00c0: 72 67 69 76 65 6e 65 73 73 20 66 6f 72 20 79 6f rgiveness for yo
00d0: 75 72 73 65 6c 66 20 61 6e 64 20 66 6f 72 67 69 urself and forgi
00e0: 76 65 20 6f 74 68 65 72 73 2e 0a 2a 2a 20 20 20 ve others..**
00f0: 20 4d 61 79 20 79 6f 75 20 73 68 61 72 65 20 66 May you share f
0100: 72 65 65 6c 79 2c 20 6e 65 76 65 72 20 74 61 6b reely, never tak
0110: 69 6e 67 20 6d 6f 72 65 20 74 68 61 6e 20 79 6f ing more than yo
0120: 75 20 67 69 76 65 2e 0a 2a 2a 0a 2a 2a 2a 2a 2a u give..**.*****
0130: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a ****************
0140: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a ****************
0150: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a ****************
0160: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a ****************
0170: 2a 2a 2a 2a 0a 2a 2a 20 54 68 69 73 20 66 69 6c ****.** This fil
0180: 65 20 63 6f 6e 74 61 69 6e 73 20 74 68 65 20 69 e contains the i
0190: 6d 70 6c 65 6d 65 6e 74 61 74 69 6f 6e 20 6f 66 mplementation of
01a0: 20 74 68 65 20 73 71 6c 69 74 65 33 5f 62 61 63 the sqlite3_bac
01b0: 6b 75 70 5f 58 58 58 28 29 20 0a 2a 2a 20 41 50 kup_XXX() .** AP
01c0: 49 20 66 75 6e 63 74 69 6f 6e 73 20 61 6e 64 20 I functions and
01d0: 74 68 65 20 72 65 6c 61 74 65 64 20 66 65 61 74 the related feat
01e0: 75 72 65 73 2e 0a 2a 2f 0a 23 69 6e 63 6c 75 64 ures..*/.#includ
01f0: 65 20 22 73 71 6c 69 74 65 49 6e 74 2e 68 22 0a e "sqliteInt.h".
0200: 23 69 6e 63 6c 75 64 65 20 22 62 74 72 65 65 49 #include "btreeI
0210: 6e 74 2e 68 22 0a 0a 2f 2a 0a 2a 2a 20 53 74 72 nt.h"../*.** Str
0220: 75 63 74 75 72 65 20 61 6c 6c 6f 63 61 74 65 64 ucture allocated
0230: 20 66 6f 72 20 65 61 63 68 20 62 61 63 6b 75 70 for each backup
0240: 20 6f 70 65 72 61 74 69 6f 6e 2e 0a 2a 2f 0a 73 operation..*/.s
0250: 74 72 75 63 74 20 73 71 6c 69 74 65 33 5f 62 61 truct sqlite3_ba
0260: 63 6b 75 70 20 7b 0a 20 20 73 71 6c 69 74 65 33 ckup {. sqlite3
0270: 2a 20 70 44 65 73 74 44 62 3b 20 20 20 20 20 20 * pDestDb;
0280: 20 20 2f 2a 20 44 65 73 74 69 6e 61 74 69 6f 6e /* Destination
0290: 20 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c 65 database handle
02a0: 20 2a 2f 0a 20 20 42 74 72 65 65 20 2a 70 44 65 */. Btree *pDe
02b0: 73 74 3b 20 20 20 20 20 20 20 20 20 20 20 20 2f st; /
02c0: 2a 20 44 65 73 74 69 6e 61 74 69 6f 6e 20 62 2d * Destination b-
02d0: 74 72 65 65 20 66 69 6c 65 20 2a 2f 0a 20 20 75 tree file */. u
02e0: 33 32 20 69 44 65 73 74 53 63 68 65 6d 61 3b 20 32 iDestSchema;
02f0: 20 20 20 20 20 20 20 20 2f 2a 20 4f 72 69 67 69 /* Origi
0300: 6e 61 6c 20 73 63 68 65 6d 61 20 63 6f 6f 6b 69 nal schema cooki
0310: 65 20 69 6e 20 64 65 73 74 69 6e 61 74 69 6f 6e e in destination
0320: 20 2a 2f 0a 20 20 69 6e 74 20 62 44 65 73 74 4c */. int bDestL
0330: 6f 63 6b 65 64 3b 20 20 20 20 20 20 20 20 20 2f ocked; /
0340: 2a 20 54 72 75 65 20 6f 6e 63 65 20 61 20 77 72 * True once a wr
0350: 69 74 65 2d 74 72 61 6e 73 61 63 74 69 6f 6e 20 ite-transaction
0360: 69 73 20 6f 70 65 6e 20 6f 6e 20 70 44 65 73 74 is open on pDest
0370: 20 2a 2f 0a 0a 20 20 50 67 6e 6f 20 69 4e 65 78 */.. Pgno iNex
0380: 74 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 t;
0390: 2f 2a 20 50 61 67 65 20 6e 75 6d 62 65 72 20 6f /* Page number o
03a0: 66 20 74 68 65 20 6e 65 78 74 20 73 6f 75 72 63 f the next sourc
03b0: 65 20 70 61 67 65 20 74 6f 20 63 6f 70 79 20 2a e page to copy *
03c0: 2f 0a 20 20 73 71 6c 69 74 65 33 2a 20 70 53 72 /. sqlite3* pSr
03d0: 63 44 62 3b 20 20 20 20 20 20 20 20 20 2f 2a 20 cDb; /*
03e0: 53 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 20 Source database
03f0: 68 61 6e 64 6c 65 20 2a 2f 0a 20 20 42 74 72 65 handle */. Btre
0400: 65 20 2a 70 53 72 63 3b 20 20 20 20 20 20 20 20 e *pSrc;
0410: 20 20 20 20 20 2f 2a 20 53 6f 75 72 63 65 20 62 /* Source b
0420: 2d 74 72 65 65 20 66 69 6c 65 20 2a 2f 0a 0a 20 -tree file */..
0430: 20 69 6e 74 20 72 63 3b 20 20 20 20 20 20 20 20 int rc;
0440: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 42 61 63 /* Bac
0450: 6b 75 70 20 70 72 6f 63 65 73 73 20 65 72 72 6f kup process erro
0460: 72 20 63 6f 64 65 20 2a 2f 0a 0a 20 20 2f 2a 20 r code */.. /*
0470: 54 68 65 73 65 20 74 77 6f 20 76 61 72 69 61 62 These two variab
0480: 6c 65 73 20 61 72 65 20 73 65 74 20 62 79 20 65 les are set by e
0490: 76 65 72 79 20 63 61 6c 6c 20 74 6f 20 62 61 63 very call to bac
04a0: 6b 75 70 5f 73 74 65 70 28 29 2e 20 54 68 65 79 kup_step(). They
04b0: 20 61 72 65 0a 20 20 2a 2a 20 72 65 61 64 20 62 are. ** read b
04c0: 79 20 63 61 6c 6c 73 20 74 6f 20 62 61 63 6b 75 y calls to backu
04d0: 70 5f 72 65 6d 61 69 6e 69 6e 67 28 29 20 61 6e p_remaining() an
04e0: 64 20 62 61 63 6b 75 70 5f 70 61 67 65 63 6f 75 d backup_pagecou
04f0: 6e 74 28 29 2e 0a 20 20 2a 2f 0a 20 20 50 67 6e nt().. */. Pgn
0500: 6f 20 6e 52 65 6d 61 69 6e 69 6e 67 3b 20 20 20 o nRemaining;
0510: 20 20 20 20 20 20 2f 2a 20 4e 75 6d 62 65 72 20 /* Number
0520: 6f 66 20 70 61 67 65 73 20 6c 65 66 74 20 74 6f of pages left to
0530: 20 63 6f 70 79 20 2a 2f 0a 20 20 50 67 6e 6f 20 copy */. Pgno
0540: 6e 50 61 67 65 63 6f 75 6e 74 3b 20 20 20 20 20 nPagecount;
0550: 20 20 20 20 2f 2a 20 54 6f 74 61 6c 20 6e 75 6d /* Total num
0560: 62 65 72 20 6f 66 20 70 61 67 65 73 20 74 6f 20 ber of pages to
0570: 63 6f 70 79 20 2a 2f 0a 0a 20 20 69 6e 74 20 69 copy */.. int i
0580: 73 41 74 74 61 63 68 65 64 3b 20 20 20 20 20 20 sAttached;
0590: 20 20 20 20 2f 2a 20 54 72 75 65 20 6f 6e 63 65 /* True once
05a0: 20 62 61 63 6b 75 70 20 68 61 73 20 62 65 65 6e backup has been
05b0: 20 72 65 67 69 73 74 65 72 65 64 20 77 69 74 68 registered with
05c0: 20 70 61 67 65 72 20 2a 2f 0a 20 20 73 71 6c 69 pager */. sqli
05d0: 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 4e 65 78 te3_backup *pNex
05e0: 74 3b 20 20 20 2f 2a 20 4e 65 78 74 20 62 61 63 t; /* Next bac
05f0: 6b 75 70 20 61 73 73 6f 63 69 61 74 65 64 20 77 kup associated w
0600: 69 74 68 20 73 6f 75 72 63 65 20 70 61 67 65 72 ith source pager
0610: 20 2a 2f 0a 7d 3b 0a 0a 2f 2a 0a 2a 2a 20 54 48 */.};../*.** TH
0620: 52 45 41 44 20 53 41 46 45 54 59 20 4e 4f 54 45 READ SAFETY NOTE
0630: 53 3a 0a 2a 2a 0a 2a 2a 20 20 20 4f 6e 63 65 20 S:.**.** Once
0640: 69 74 20 68 61 73 20 62 65 65 6e 20 63 72 65 61 it has been crea
0650: 74 65 64 20 75 73 69 6e 67 20 62 61 63 6b 75 70 ted using backup
0660: 5f 69 6e 69 74 28 29 2c 20 61 20 73 69 6e 67 6c _init(), a singl
0670: 65 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 e sqlite3_backup
0680: 0a 2a 2a 20 20 20 73 74 72 75 63 74 75 72 65 20 .** structure
0690: 6d 61 79 20 62 65 20 61 63 63 65 73 73 65 64 20 may be accessed
06a0: 76 69 61 20 74 77 6f 20 67 72 6f 75 70 73 20 6f via two groups o
06b0: 66 20 74 68 72 65 61 64 2d 73 61 66 65 20 65 6e f thread-safe en
06c0: 74 72 79 20 70 6f 69 6e 74 73 3a 0a 2a 2a 0a 2a try points:.**.*
06d0: 2a 20 20 20 20 20 2a 20 56 69 61 20 74 68 65 20 * * Via the
06e0: 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 58 sqlite3_backup_X
06f0: 58 58 28 29 20 41 50 49 20 66 75 6e 63 74 69 6f XX() API functio
0700: 6e 20 62 61 63 6b 75 70 5f 73 74 65 70 28 29 20 n backup_step()
0710: 61 6e 64 20 0a 2a 2a 20 20 20 20 20 20 20 62 61 and .** ba
0720: 63 6b 75 70 5f 66 69 6e 69 73 68 28 29 2e 20 42 ckup_finish(). B
0730: 6f 74 68 20 74 68 65 73 65 20 66 75 6e 63 74 69 oth these functi
0740: 6f 6e 73 20 6f 62 74 61 69 6e 20 74 68 65 20 73 ons obtain the s
0750: 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 0a 2a ource database.*
0760: 2a 20 20 20 20 20 20 20 68 61 6e 64 6c 65 20 6d * handle m
0770: 75 74 65 78 20 61 6e 64 20 74 68 65 20 6d 75 74 utex and the mut
0780: 65 78 20 61 73 73 6f 63 69 61 74 65 64 20 77 69 ex associated wi
0790: 74 68 20 74 68 65 20 73 6f 75 72 63 65 20 42 74 th the source Bt
07a0: 53 68 61 72 65 64 20 0a 2a 2a 20 20 20 20 20 20 Shared .**
07b0: 20 73 74 72 75 63 74 75 72 65 2c 20 69 6e 20 74 structure, in t
07c0: 68 61 74 20 6f 72 64 65 72 2e 0a 2a 2a 0a 2a 2a hat order..**.**
07d0: 20 20 20 20 20 2a 20 56 69 61 20 74 68 65 20 42 * Via the B
07e0: 61 63 6b 75 70 55 70 64 61 74 65 28 29 20 61 6e ackupUpdate() an
07f0: 64 20 42 61 63 6b 75 70 52 65 73 74 61 72 74 28 d BackupRestart(
0800: 29 20 66 75 6e 63 74 69 6f 6e 73 2c 20 77 68 69 ) functions, whi
0810: 63 68 20 61 72 65 0a 2a 2a 20 20 20 20 20 20 20 ch are.**
0820: 69 6e 76 6f 6b 65 64 20 62 79 20 74 68 65 20 70 invoked by the p
0830: 61 67 65 72 20 6c 61 79 65 72 20 74 6f 20 72 65 ager layer to re
0840: 70 6f 72 74 20 76 61 72 69 6f 75 73 20 73 74 61 port various sta
0850: 74 65 20 63 68 61 6e 67 65 73 20 69 6e 0a 2a 2a te changes in.**
0860: 20 20 20 20 20 20 20 74 68 65 20 70 61 67 65 20 the page
0870: 63 61 63 68 65 20 61 73 73 6f 63 69 61 74 65 64 cache associated
0880: 20 77 69 74 68 20 74 68 65 20 73 6f 75 72 63 65 with the source
0890: 20 64 61 74 61 62 61 73 65 2e 20 54 68 65 20 6d database. The m
08a0: 75 74 65 78 0a 2a 2a 20 20 20 20 20 20 20 61 73 utex.** as
08b0: 73 6f 63 69 61 74 65 64 20 77 69 74 68 20 74 68 sociated with th
08c0: 65 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73 e source databas
08d0: 65 20 42 74 53 68 61 72 65 64 20 73 74 72 75 63 e BtShared struc
08e0: 74 75 72 65 20 77 69 6c 6c 20 61 6c 77 61 79 73 ture will always
08f0: 20 0a 2a 2a 20 20 20 20 20 20 20 62 65 20 68 65 .** be he
0900: 6c 64 20 77 68 65 6e 20 65 69 74 68 65 72 20 6f ld when either o
0910: 66 20 74 68 65 73 65 20 66 75 6e 63 74 69 6f 6e f these function
0920: 73 20 61 72 65 20 69 6e 76 6f 6b 65 64 2e 0a 2a s are invoked..*
0930: 2a 0a 2a 2a 20 20 20 54 68 65 20 6f 74 68 65 72 *.** The other
0940: 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f sqlite3_backup_
0950: 58 58 58 28 29 20 41 50 49 20 66 75 6e 63 74 69 XXX() API functi
0960: 6f 6e 73 2c 20 62 61 63 6b 75 70 5f 72 65 6d 61 ons, backup_rema
0970: 69 6e 69 6e 67 28 29 20 61 6e 64 0a 2a 2a 20 20 ining() and.**
0980: 20 62 61 63 6b 75 70 5f 70 61 67 65 63 6f 75 6e backup_pagecoun
0990: 74 28 29 20 61 72 65 20 6e 6f 74 20 74 68 72 65 t() are not thre
09a0: 61 64 2d 73 61 66 65 20 66 75 6e 63 74 69 6f 6e ad-safe function
09b0: 73 2e 20 49 66 20 74 68 65 79 20 61 72 65 20 63 s. If they are c
09c0: 61 6c 6c 65 64 0a 2a 2a 20 20 20 77 68 69 6c 65 alled.** while
09d0: 20 73 6f 6d 65 20 6f 74 68 65 72 20 74 68 72 65 some other thre
09e0: 61 64 20 69 73 20 63 61 6c 6c 69 6e 67 20 62 61 ad is calling ba
09f0: 63 6b 75 70 5f 73 74 65 70 28 29 20 6f 72 20 62 ckup_step() or b
0a00: 61 63 6b 75 70 5f 66 69 6e 69 73 68 28 29 2c 0a ackup_finish(),.
0a10: 2a 2a 20 20 20 74 68 65 20 76 61 6c 75 65 73 20 ** the values
0a20: 72 65 74 75 72 6e 65 64 20 6d 61 79 20 62 65 20 returned may be
0a30: 69 6e 76 61 6c 69 64 2e 20 54 68 65 72 65 20 69 invalid. There i
0a40: 73 20 6e 6f 20 77 61 79 20 66 6f 72 20 61 20 63 s no way for a c
0a50: 61 6c 6c 20 74 6f 0a 2a 2a 20 20 20 42 61 63 6b all to.** Back
0a60: 75 70 55 70 64 61 74 65 28 29 20 6f 72 20 42 61 upUpdate() or Ba
0a70: 63 6b 75 70 52 65 73 74 61 72 74 28 29 20 74 6f ckupRestart() to
0a80: 20 69 6e 74 65 72 66 65 72 65 20 77 69 74 68 20 interfere with
0a90: 62 61 63 6b 75 70 5f 72 65 6d 61 69 6e 69 6e 67 backup_remaining
0aa0: 28 29 0a 2a 2a 20 20 20 6f 72 20 62 61 63 6b 75 ().** or backu
0ab0: 70 5f 70 61 67 65 63 6f 75 6e 74 28 29 2e 0a 2a p_pagecount()..*
0ac0: 2a 0a 2a 2a 20 20 20 44 65 70 65 6e 64 69 6e 67 *.** Depending
0ad0: 20 6f 6e 20 74 68 65 20 53 51 4c 69 74 65 20 63 on the SQLite c
0ae0: 6f 6e 66 69 67 75 72 61 74 69 6f 6e 2c 20 74 68 onfiguration, th
0af0: 65 20 64 61 74 61 62 61 73 65 20 68 61 6e 64 6c e database handl
0b00: 65 73 20 61 6e 64 2f 6f 72 0a 2a 2a 20 20 20 74 es and/or.** t
0b10: 68 65 20 42 74 72 65 65 20 6f 62 6a 65 63 74 73 he Btree objects
0b20: 20 6d 61 79 20 68 61 76 65 20 74 68 65 69 72 20 may have their
0b30: 6f 77 6e 20 6d 75 74 65 78 65 73 20 74 68 61 74 own mutexes that
0b40: 20 72 65 71 75 69 72 65 20 6c 6f 63 6b 69 6e 67 require locking
0b50: 2e 0a 2a 2a 20 20 20 4e 6f 6e 2d 73 68 61 72 61 ..** Non-shara
0b60: 62 6c 65 20 42 74 72 65 65 73 20 28 69 6e 2d 6d ble Btrees (in-m
0b70: 65 6d 6f 72 79 20 64 61 74 61 62 61 73 65 73 20 emory databases
0b80: 66 6f 72 20 65 78 61 6d 70 6c 65 29 2c 20 64 6f for example), do
0b90: 20 6e 6f 74 20 68 61 76 65 0a 2a 2a 20 20 20 61 not have.** a
0ba0: 73 73 6f 63 69 61 74 65 64 20 6d 75 74 65 78 65 ssociated mutexe
0bb0: 73 2e 0a 2a 2f 0a 0a 2f 2a 0a 2a 2a 20 52 65 74 s..*/../*.** Ret
0bc0: 75 72 6e 20 61 20 70 6f 69 6e 74 65 72 20 63 6f urn a pointer co
0bd0: 72 72 65 73 70 6f 6e 64 69 6e 67 20 74 6f 20 64 rresponding to d
0be0: 61 74 61 62 61 73 65 20 7a 44 62 20 28 69 2e 65 atabase zDb (i.e
0bf0: 2e 20 22 6d 61 69 6e 22 2c 20 22 74 65 6d 70 22 . "main", "temp"
0c00: 29 0a 2a 2a 20 69 6e 20 63 6f 6e 6e 65 63 74 69 ).** in connecti
0c10: 6f 6e 20 68 61 6e 64 6c 65 20 70 44 62 2e 20 49 on handle pDb. I
0c20: 66 20 73 75 63 68 20 61 20 64 61 74 61 62 61 73 f such a databas
0c30: 65 20 63 61 6e 6e 6f 74 20 62 65 20 66 6f 75 6e e cannot be foun
0c40: 64 2c 20 72 65 74 75 72 6e 0a 2a 2a 20 61 20 4e d, return.** a N
0c50: 55 4c 4c 20 70 6f 69 6e 74 65 72 20 61 6e 64 20 ULL pointer and
0c60: 77 72 69 74 65 20 61 6e 20 65 72 72 6f 72 20 6d write an error m
0c70: 65 73 73 61 67 65 20 74 6f 20 70 45 72 72 6f 72 essage to pError
0c80: 44 62 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 74 68 65 Db..**.** If the
0c90: 20 22 74 65 6d 70 22 20 64 61 74 61 62 61 73 65 "temp" database
0ca0: 20 69 73 20 72 65 71 75 65 73 74 65 64 2c 20 69 is requested, i
0cb0: 74 20 6d 61 79 20 6e 65 65 64 20 74 6f 20 62 65 t may need to be
0cc0: 20 6f 70 65 6e 65 64 20 62 79 20 74 68 69 73 20 opened by this
0cd0: 0a 2a 2a 20 66 75 6e 63 74 69 6f 6e 2e 20 49 66 .** function. If
0ce0: 20 61 6e 20 65 72 72 6f 72 20 6f 63 63 75 72 73 an error occurs
0cf0: 20 77 68 69 6c 65 20 64 6f 69 6e 67 20 73 6f 2c while doing so,
0d00: 20 72 65 74 75 72 6e 20 30 20 61 6e 64 20 77 72 return 0 and wr
0d10: 69 74 65 20 61 6e 20 0a 2a 2a 20 65 72 72 6f 72 ite an .** error
0d20: 20 6d 65 73 73 61 67 65 20 74 6f 20 70 45 72 72 message to pErr
0d30: 6f 72 44 62 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 orDb..*/.static
0d40: 42 74 72 65 65 20 2a 66 69 6e 64 42 74 72 65 65 Btree *findBtree
0d50: 28 73 71 6c 69 74 65 33 20 2a 70 45 72 72 6f 72 (sqlite3 *pError
0d60: 44 62 2c 20 73 71 6c 69 74 65 33 20 2a 70 44 62 Db, sqlite3 *pDb
0d70: 2c 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 44 , const char *zD
0d80: 62 29 7b 0a 20 20 69 6e 74 20 69 20 3d 20 73 71 b){. int i = sq
0d90: 6c 69 74 65 33 46 69 6e 64 44 62 4e 61 6d 65 28 lite3FindDbName(
0da0: 70 44 62 2c 20 7a 44 62 29 3b 0a 0a 20 20 69 66 pDb, zDb);.. if
0db0: 28 20 69 3d 3d 31 20 29 7b 0a 20 20 20 20 50 61 ( i==1 ){. Pa
0dc0: 72 73 65 20 2a 70 50 61 72 73 65 3b 0a 20 20 20 rse *pParse;.
0dd0: 20 69 6e 74 20 72 63 20 3d 20 30 3b 0a 20 20 20 int rc = 0;.
0de0: 20 70 50 61 72 73 65 20 3d 20 73 71 6c 69 74 65 pParse = sqlite
0df0: 33 53 74 61 63 6b 41 6c 6c 6f 63 5a 65 72 6f 28 3StackAllocZero(
0e00: 70 45 72 72 6f 72 44 62 2c 20 73 69 7a 65 6f 66 pErrorDb, sizeof
0e10: 28 2a 70 50 61 72 73 65 29 29 3b 0a 20 20 20 20 (*pParse));.
0e20: 69 66 28 20 70 50 61 72 73 65 3d 3d 30 20 29 7b if( pParse==0 ){
0e30: 0a 20 20 20 20 20 20 73 71 6c 69 74 65 33 45 72 . sqlite3Er
0e40: 72 6f 72 57 69 74 68 4d 73 67 28 70 45 72 72 6f rorWithMsg(pErro
0e50: 72 44 62 2c 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 rDb, SQLITE_NOME
0e60: 4d 2c 20 22 6f 75 74 20 6f 66 20 6d 65 6d 6f 72 M, "out of memor
0e70: 79 22 29 3b 0a 20 20 20 20 20 20 72 63 20 3d 20 y");. rc =
0e80: 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 SQLITE_NOMEM;.
0e90: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 70 }else{. p
0ea0: 50 61 72 73 65 2d 3e 64 62 20 3d 20 70 44 62 3b Parse->db = pDb;
0eb0: 0a 20 20 20 20 20 20 69 66 28 20 73 71 6c 69 74 . if( sqlit
0ec0: 65 33 4f 70 65 6e 54 65 6d 70 44 61 74 61 62 61 e3OpenTempDataba
0ed0: 73 65 28 70 50 61 72 73 65 29 20 29 7b 0a 20 20 se(pParse) ){.
0ee0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 45 72 72 sqlite3Err
0ef0: 6f 72 57 69 74 68 4d 73 67 28 70 45 72 72 6f 72 orWithMsg(pError
0f00: 44 62 2c 20 70 50 61 72 73 65 2d 3e 72 63 2c 20 Db, pParse->rc,
0f10: 22 25 73 22 2c 20 70 50 61 72 73 65 2d 3e 7a 45 "%s", pParse->zE
0f20: 72 72 4d 73 67 29 3b 0a 20 20 20 20 20 20 20 20 rrMsg);.
0f30: 72 63 20 3d 20 53 51 4c 49 54 45 5f 45 52 52 4f rc = SQLITE_ERRO
0f40: 52 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 R;. }.
0f50: 20 73 71 6c 69 74 65 33 44 62 46 72 65 65 28 70 sqlite3DbFree(p
0f60: 45 72 72 6f 72 44 62 2c 20 70 50 61 72 73 65 2d ErrorDb, pParse-
0f70: 3e 7a 45 72 72 4d 73 67 29 3b 0a 20 20 20 20 20 >zErrMsg);.
0f80: 20 73 71 6c 69 74 65 33 50 61 72 73 65 72 52 65 sqlite3ParserRe
0f90: 73 65 74 28 70 50 61 72 73 65 29 3b 0a 20 20 20 set(pParse);.
0fa0: 20 20 20 73 71 6c 69 74 65 33 53 74 61 63 6b 46 sqlite3StackF
0fb0: 72 65 65 28 70 45 72 72 6f 72 44 62 2c 20 70 50 ree(pErrorDb, pP
0fc0: 61 72 73 65 29 3b 0a 20 20 20 20 7d 0a 20 20 20 arse);. }.
0fd0: 20 69 66 28 20 72 63 20 29 7b 0a 20 20 20 20 20 if( rc ){.
0fe0: 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 20 20 7d return 0;. }
0ff0: 0a 20 20 7d 0a 0a 20 20 69 66 28 20 69 3c 30 20 . }.. if( i<0
1000: 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 45 72 ){. sqlite3Er
1010: 72 6f 72 57 69 74 68 4d 73 67 28 70 45 72 72 6f rorWithMsg(pErro
1020: 72 44 62 2c 20 53 51 4c 49 54 45 5f 45 52 52 4f rDb, SQLITE_ERRO
1030: 52 2c 20 22 75 6e 6b 6e 6f 77 6e 20 64 61 74 61 R, "unknown data
1040: 62 61 73 65 20 25 73 22 2c 20 7a 44 62 29 3b 0a base %s", zDb);.
1050: 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 20 return 0;.
1060: 7d 0a 0a 20 20 72 65 74 75 72 6e 20 70 44 62 2d }.. return pDb-
1070: 3e 61 44 62 5b 69 5d 2e 70 42 74 3b 0a 7d 0a 0a >aDb[i].pBt;.}..
1080: 2f 2a 0a 2a 2a 20 41 74 74 65 6d 70 74 20 74 6f /*.** Attempt to
1090: 20 73 65 74 20 74 68 65 20 70 61 67 65 20 73 69 set the page si
10a0: 7a 65 20 6f 66 20 74 68 65 20 64 65 73 74 69 6e ze of the destin
10b0: 61 74 69 6f 6e 20 74 6f 20 6d 61 74 63 68 20 74 ation to match t
10c0: 68 65 20 70 61 67 65 20 73 69 7a 65 0a 2a 2a 20 he page size.**
10d0: 6f 66 20 74 68 65 20 73 6f 75 72 63 65 2e 0a 2a of the source..*
10e0: 2f 0a 73 74 61 74 69 63 20 69 6e 74 20 73 65 74 /.static int set
10f0: 44 65 73 74 50 67 73 7a 28 73 71 6c 69 74 65 33 DestPgsz(sqlite3
1100: 5f 62 61 63 6b 75 70 20 2a 70 29 7b 0a 20 20 69 _backup *p){. i
1110: 6e 74 20 72 63 3b 0a 20 20 72 63 20 3d 20 73 71 nt rc;. rc = sq
1120: 6c 69 74 65 33 42 74 72 65 65 53 65 74 50 61 67 lite3BtreeSetPag
1130: 65 53 69 7a 65 28 70 2d 3e 70 44 65 73 74 2c 73 eSize(p->pDest,s
1140: 71 6c 69 74 65 33 42 74 72 65 65 47 65 74 50 61 qlite3BtreeGetPa
1150: 67 65 53 69 7a 65 28 70 2d 3e 70 53 72 63 29 2c geSize(p->pSrc),
1160: 2d 31 2c 30 29 3b 0a 20 20 72 65 74 75 72 6e 20 -1,0);. return
1170: 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 72 65 rc;.}../*.** Cre
1180: 61 74 65 20 61 6e 20 73 71 6c 69 74 65 33 5f 62 ate an sqlite3_b
1190: 61 63 6b 75 70 20 70 72 6f 63 65 73 73 20 74 6f ackup process to
11a0: 20 63 6f 70 79 20 74 68 65 20 63 6f 6e 74 65 6e copy the conten
11b0: 74 73 20 6f 66 20 7a 53 72 63 44 62 20 66 72 6f ts of zSrcDb fro
11c0: 6d 0a 2a 2a 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 m.** connection
11d0: 68 61 6e 64 6c 65 20 70 53 72 63 44 62 20 74 6f handle pSrcDb to
11e0: 20 7a 44 65 73 74 44 62 20 69 6e 20 70 44 65 73 zDestDb in pDes
11f0: 74 44 62 2e 20 49 66 20 73 75 63 63 65 73 73 66 tDb. If successf
1200: 75 6c 2c 20 72 65 74 75 72 6e 0a 2a 2a 20 61 20 ul, return.** a
1210: 70 6f 69 6e 74 65 72 20 74 6f 20 74 68 65 20 6e pointer to the n
1220: 65 77 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 ew sqlite3_backu
1230: 70 20 6f 62 6a 65 63 74 2e 0a 2a 2a 0a 2a 2a 20 p object..**.**
1240: 49 66 20 61 6e 20 65 72 72 6f 72 20 6f 63 63 75 If an error occu
1250: 72 73 2c 20 4e 55 4c 4c 20 69 73 20 72 65 74 75 rs, NULL is retu
1260: 72 6e 65 64 20 61 6e 64 20 61 6e 20 65 72 72 6f rned and an erro
1270: 72 20 63 6f 64 65 20 61 6e 64 20 65 72 72 6f 72 r code and error
1280: 20 6d 65 73 73 61 67 65 0a 2a 2a 20 73 74 6f 72 message.** stor
1290: 65 64 20 69 6e 20 64 61 74 61 62 61 73 65 20 68 ed in database h
12a0: 61 6e 64 6c 65 20 70 44 65 73 74 44 62 2e 0a 2a andle pDestDb..*
12b0: 2f 0a 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 /.sqlite3_backup
12c0: 20 2a 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 *sqlite3_backup
12d0: 5f 69 6e 69 74 28 0a 20 20 73 71 6c 69 74 65 33 _init(. sqlite3
12e0: 2a 20 70 44 65 73 74 44 62 2c 20 20 20 20 20 20 * pDestDb,
12f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f /
1300: 2a 20 44 61 74 61 62 61 73 65 20 74 6f 20 77 72 * Database to wr
1310: 69 74 65 20 74 6f 20 2a 2f 0a 20 20 63 6f 6e 73 ite to */. cons
1320: 74 20 63 68 61 72 20 2a 7a 44 65 73 74 44 62 2c t char *zDestDb,
1330: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1340: 20 20 2f 2a 20 4e 61 6d 65 20 6f 66 20 64 61 74 /* Name of dat
1350: 61 62 61 73 65 20 77 69 74 68 69 6e 20 70 44 65 abase within pDe
1360: 73 74 44 62 20 2a 2f 0a 20 20 73 71 6c 69 74 65 stDb */. sqlite
1370: 33 2a 20 70 53 72 63 44 62 2c 20 20 20 20 20 20 3* pSrcDb,
1380: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1390: 2f 2a 20 44 61 74 61 62 61 73 65 20 63 6f 6e 6e /* Database conn
13a0: 65 63 74 69 6f 6e 20 74 6f 20 72 65 61 64 20 66 ection to read f
13b0: 72 6f 6d 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 63 rom */. const c
13c0: 68 61 72 20 2a 7a 53 72 63 44 62 20 20 20 20 20 har *zSrcDb
13d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f /
13e0: 2a 20 4e 61 6d 65 20 6f 66 20 64 61 74 61 62 61 * Name of databa
13f0: 73 65 20 77 69 74 68 69 6e 20 70 53 72 63 44 62 se within pSrcDb
1400: 20 2a 2f 0a 29 7b 0a 20 20 73 71 6c 69 74 65 33 */.){. sqlite3
1410: 5f 62 61 63 6b 75 70 20 2a 70 3b 20 20 20 20 20 _backup *p;
1420: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f /
1430: 2a 20 56 61 6c 75 65 20 74 6f 20 72 65 74 75 72 * Value to retur
1440: 6e 20 2a 2f 0a 0a 20 20 2f 2a 20 4c 6f 63 6b 20 n */.. /* Lock
1450: 74 68 65 20 73 6f 75 72 63 65 20 64 61 74 61 62 the source datab
1460: 61 73 65 20 68 61 6e 64 6c 65 2e 20 54 68 65 20 ase handle. The
1470: 64 65 73 74 69 6e 61 74 69 6f 6e 20 64 61 74 61 destination data
1480: 62 61 73 65 0a 20 20 2a 2a 20 68 61 6e 64 6c 65 base. ** handle
1490: 20 69 73 20 6e 6f 74 20 6c 6f 63 6b 65 64 20 69 is not locked i
14a0: 6e 20 74 68 69 73 20 72 6f 75 74 69 6e 65 2c 20 n this routine,
14b0: 62 75 74 20 69 74 20 69 73 20 6c 6f 63 6b 65 64 but it is locked
14c0: 20 69 6e 0a 20 20 2a 2a 20 73 71 6c 69 74 65 33 in. ** sqlite3
14d0: 5f 62 61 63 6b 75 70 5f 73 74 65 70 28 29 2e 20 _backup_step().
14e0: 54 68 65 20 75 73 65 72 20 69 73 20 72 65 71 75 The user is requ
14f0: 69 72 65 64 20 74 6f 20 65 6e 73 75 72 65 20 74 ired to ensure t
1500: 68 61 74 20 6e 6f 0a 20 20 2a 2a 20 6f 74 68 65 hat no. ** othe
1510: 72 20 74 68 72 65 61 64 20 61 63 63 65 73 73 65 r thread accesse
1520: 73 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f s the destinatio
1530: 6e 20 68 61 6e 64 6c 65 20 66 6f 72 20 74 68 65 n handle for the
1540: 20 64 75 72 61 74 69 6f 6e 0a 20 20 2a 2a 20 6f duration. ** o
1550: 66 20 74 68 65 20 62 61 63 6b 75 70 20 6f 70 65 f the backup ope
1560: 72 61 74 69 6f 6e 2e 20 20 41 6e 79 20 61 74 74 ration. Any att
1570: 65 6d 70 74 20 74 6f 20 75 73 65 20 74 68 65 20 empt to use the
1580: 64 65 73 74 69 6e 61 74 69 6f 6e 0a 20 20 2a 2a destination. **
1590: 20 64 61 74 61 62 61 73 65 20 63 6f 6e 6e 65 63 database connec
15a0: 74 69 6f 6e 20 77 68 69 6c 65 20 61 20 62 61 63 tion while a bac
15b0: 6b 75 70 20 69 73 20 69 6e 20 70 72 6f 67 72 65 kup is in progre
15c0: 73 73 20 6d 61 79 20 63 61 75 73 65 0a 20 20 2a ss may cause. *
15d0: 2a 20 61 20 6d 61 6c 66 75 6e 63 74 69 6f 6e 20 * a malfunction
15e0: 6f 72 20 61 20 64 65 61 64 6c 6f 63 6b 2e 0a 20 or a deadlock..
15f0: 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 */. sqlite3_mu
1600: 74 65 78 5f 65 6e 74 65 72 28 70 53 72 63 44 62 tex_enter(pSrcDb
1610: 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 73 71 6c 69 ->mutex);. sqli
1620: 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28 te3_mutex_enter(
1630: 70 44 65 73 74 44 62 2d 3e 6d 75 74 65 78 29 3b pDestDb->mutex);
1640: 0a 0a 20 20 69 66 28 20 70 53 72 63 44 62 3d 3d .. if( pSrcDb==
1650: 70 44 65 73 74 44 62 20 29 7b 0a 20 20 20 20 73 pDestDb ){. s
1660: 71 6c 69 74 65 33 45 72 72 6f 72 57 69 74 68 4d qlite3ErrorWithM
1670: 73 67 28 0a 20 20 20 20 20 20 20 20 70 44 65 73 sg(. pDes
1680: 74 44 62 2c 20 53 51 4c 49 54 45 5f 45 52 52 4f tDb, SQLITE_ERRO
1690: 52 2c 20 22 73 6f 75 72 63 65 20 61 6e 64 20 64 R, "source and d
16a0: 65 73 74 69 6e 61 74 69 6f 6e 20 6d 75 73 74 20 estination must
16b0: 62 65 20 64 69 73 74 69 6e 63 74 22 0a 20 20 20 be distinct".
16c0: 20 29 3b 0a 20 20 20 20 70 20 3d 20 30 3b 0a 20 );. p = 0;.
16d0: 20 7d 65 6c 73 65 20 7b 0a 20 20 20 20 2f 2a 20 }else {. /*
16e0: 41 6c 6c 6f 63 61 74 65 20 73 70 61 63 65 20 66 Allocate space f
16f0: 6f 72 20 61 20 6e 65 77 20 73 71 6c 69 74 65 33 or a new sqlite3
1700: 5f 62 61 63 6b 75 70 20 6f 62 6a 65 63 74 2e 2e _backup object..
1710: 2e 0a 20 20 20 20 2a 2a 20 45 56 49 44 45 4e 43 .. ** EVIDENC
1720: 45 2d 4f 46 3a 20 52 2d 36 34 38 35 32 2d 32 31 E-OF: R-64852-21
1730: 35 39 31 20 54 68 65 20 73 71 6c 69 74 65 33 5f 591 The sqlite3_
1740: 62 61 63 6b 75 70 20 6f 62 6a 65 63 74 20 69 73 backup object is
1750: 20 63 72 65 61 74 65 64 20 62 79 20 61 0a 20 20 created by a.
1760: 20 20 2a 2a 20 63 61 6c 6c 20 74 6f 20 73 71 6c ** call to sql
1770: 69 74 65 33 5f 62 61 63 6b 75 70 5f 69 6e 69 74 ite3_backup_init
1780: 28 29 20 61 6e 64 20 69 73 20 64 65 73 74 72 6f () and is destro
1790: 79 65 64 20 62 79 20 61 20 63 61 6c 6c 20 74 6f yed by a call to
17a0: 0a 20 20 20 20 2a 2a 20 73 71 6c 69 74 65 33 5f . ** sqlite3_
17b0: 62 61 63 6b 75 70 5f 66 69 6e 69 73 68 28 29 2e backup_finish().
17c0: 20 2a 2f 0a 20 20 20 20 70 20 3d 20 28 73 71 6c */. p = (sql
17d0: 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 29 73 71 ite3_backup *)sq
17e0: 6c 69 74 65 33 4d 61 6c 6c 6f 63 5a 65 72 6f 28 lite3MallocZero(
17f0: 73 69 7a 65 6f 66 28 73 71 6c 69 74 65 33 5f 62 sizeof(sqlite3_b
1800: 61 63 6b 75 70 29 29 3b 0a 20 20 20 20 69 66 28 ackup));. if(
1810: 20 21 70 20 29 7b 0a 20 20 20 20 20 20 73 71 6c !p ){. sql
1820: 69 74 65 33 45 72 72 6f 72 28 70 44 65 73 74 44 ite3Error(pDestD
1830: 62 2c 20 53 51 4c 49 54 45 5f 4e 4f 4d 45 4d 29 b, SQLITE_NOMEM)
1840: 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a 0a 20 20 2f ;. }. }.. /
1850: 2a 20 49 66 20 74 68 65 20 61 6c 6c 6f 63 61 74 * If the allocat
1860: 69 6f 6e 20 73 75 63 63 65 65 64 65 64 2c 20 70 ion succeeded, p
1870: 6f 70 75 6c 61 74 65 20 74 68 65 20 6e 65 77 20 opulate the new
1880: 6f 62 6a 65 63 74 2e 20 2a 2f 0a 20 20 69 66 28 object. */. if(
1890: 20 70 20 29 7b 0a 20 20 20 20 70 2d 3e 70 53 72 p ){. p->pSr
18a0: 63 20 3d 20 66 69 6e 64 42 74 72 65 65 28 70 44 c = findBtree(pD
18b0: 65 73 74 44 62 2c 20 70 53 72 63 44 62 2c 20 7a estDb, pSrcDb, z
18c0: 53 72 63 44 62 29 3b 0a 20 20 20 20 70 2d 3e 70 SrcDb);. p->p
18d0: 44 65 73 74 20 3d 20 66 69 6e 64 42 74 72 65 65 Dest = findBtree
18e0: 28 70 44 65 73 74 44 62 2c 20 70 44 65 73 74 44 (pDestDb, pDestD
18f0: 62 2c 20 7a 44 65 73 74 44 62 29 3b 0a 20 20 20 b, zDestDb);.
1900: 20 70 2d 3e 70 44 65 73 74 44 62 20 3d 20 70 44 p->pDestDb = pD
1910: 65 73 74 44 62 3b 0a 20 20 20 20 70 2d 3e 70 53 estDb;. p->pS
1920: 72 63 44 62 20 3d 20 70 53 72 63 44 62 3b 0a 20 rcDb = pSrcDb;.
1930: 20 20 20 70 2d 3e 69 4e 65 78 74 20 3d 20 31 3b p->iNext = 1;
1940: 0a 20 20 20 20 70 2d 3e 69 73 41 74 74 61 63 68 . p->isAttach
1950: 65 64 20 3d 20 30 3b 0a 0a 20 20 20 20 69 66 28 ed = 0;.. if(
1960: 20 30 3d 3d 70 2d 3e 70 53 72 63 20 7c 7c 20 30 0==p->pSrc || 0
1970: 3d 3d 70 2d 3e 70 44 65 73 74 20 7c 7c 20 73 65 ==p->pDest || se
1980: 74 44 65 73 74 50 67 73 7a 28 70 29 3d 3d 53 51 tDestPgsz(p)==SQ
1990: 4c 49 54 45 5f 4e 4f 4d 45 4d 20 29 7b 0a 20 20 LITE_NOMEM ){.
19a0: 20 20 20 20 2f 2a 20 4f 6e 65 20 28 6f 72 20 62 /* One (or b
19b0: 6f 74 68 29 20 6f 66 20 74 68 65 20 6e 61 6d 65 oth) of the name
19c0: 64 20 64 61 74 61 62 61 73 65 73 20 64 69 64 20 d databases did
19d0: 6e 6f 74 20 65 78 69 73 74 20 6f 72 20 61 6e 20 not exist or an
19e0: 4f 4f 4d 0a 20 20 20 20 20 20 2a 2a 20 65 72 72 OOM. ** err
19f0: 6f 72 20 77 61 73 20 68 69 74 2e 20 20 54 68 65 or was hit. The
1a00: 20 65 72 72 6f 72 20 68 61 73 20 61 6c 72 65 61 error has alrea
1a10: 64 79 20 62 65 65 6e 20 77 72 69 74 74 65 6e 20 dy been written
1a20: 69 6e 74 6f 20 74 68 65 0a 20 20 20 20 20 20 2a into the. *
1a30: 2a 20 70 44 65 73 74 44 62 20 68 61 6e 64 6c 65 * pDestDb handle
1a40: 2e 20 20 41 6c 6c 20 74 68 61 74 20 69 73 20 6c . All that is l
1a50: 65 66 74 20 74 6f 20 64 6f 20 68 65 72 65 20 69 eft to do here i
1a60: 73 20 66 72 65 65 20 74 68 65 0a 20 20 20 20 20 s free the.
1a70: 20 2a 2a 20 73 71 6c 69 74 65 33 5f 62 61 63 6b ** sqlite3_back
1a80: 75 70 20 73 74 72 75 63 74 75 72 65 2e 0a 20 20 up structure..
1a90: 20 20 20 20 2a 2f 0a 20 20 20 20 20 20 73 71 6c */. sql
1aa0: 69 74 65 33 5f 66 72 65 65 28 70 29 3b 0a 20 20 ite3_free(p);.
1ab0: 20 20 20 20 70 20 3d 20 30 3b 0a 20 20 20 20 7d p = 0;. }
1ac0: 0a 20 20 7d 0a 20 20 69 66 28 20 70 20 29 7b 0a . }. if( p ){.
1ad0: 20 20 20 20 70 2d 3e 70 53 72 63 2d 3e 6e 42 61 p->pSrc->nBa
1ae0: 63 6b 75 70 2b 2b 3b 0a 20 20 7d 0a 0a 20 20 73 ckup++;. }.. s
1af0: 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 qlite3_mutex_lea
1b00: 76 65 28 70 44 65 73 74 44 62 2d 3e 6d 75 74 65 ve(pDestDb->mute
1b10: 78 29 3b 0a 20 20 73 71 6c 69 74 65 33 5f 6d 75 x);. sqlite3_mu
1b20: 74 65 78 5f 6c 65 61 76 65 28 70 53 72 63 44 62 tex_leave(pSrcDb
1b30: 2d 3e 6d 75 74 65 78 29 3b 0a 20 20 72 65 74 75 ->mutex);. retu
1b40: 72 6e 20 70 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 41 rn p;.}../*.** A
1b50: 72 67 75 6d 65 6e 74 20 72 63 20 69 73 20 61 6e rgument rc is an
1b60: 20 53 51 4c 69 74 65 20 65 72 72 6f 72 20 63 6f SQLite error co
1b70: 64 65 2e 20 52 65 74 75 72 6e 20 74 72 75 65 20 de. Return true
1b80: 69 66 20 74 68 69 73 20 65 72 72 6f 72 20 69 73 if this error is
1b90: 20 0a 2a 2a 20 63 6f 6e 73 69 64 65 72 65 64 20 .** considered
1ba0: 66 61 74 61 6c 20 69 66 20 65 6e 63 6f 75 6e 74 fatal if encount
1bb0: 65 72 65 64 20 64 75 72 69 6e 67 20 61 20 62 61 ered during a ba
1bc0: 63 6b 75 70 20 6f 70 65 72 61 74 69 6f 6e 2e 20 ckup operation.
1bd0: 41 6c 6c 20 65 72 72 6f 72 73 0a 2a 2a 20 61 72 All errors.** ar
1be0: 65 20 63 6f 6e 73 69 64 65 72 65 64 20 66 61 74 e considered fat
1bf0: 61 6c 20 65 78 63 65 70 74 20 66 6f 72 20 53 51 al except for SQ
1c00: 4c 49 54 45 5f 42 55 53 59 20 61 6e 64 20 53 51 LITE_BUSY and SQ
1c10: 4c 49 54 45 5f 4c 4f 43 4b 45 44 2e 0a 2a 2f 0a LITE_LOCKED..*/.
1c20: 73 74 61 74 69 63 20 69 6e 74 20 69 73 46 61 74 static int isFat
1c30: 61 6c 45 72 72 6f 72 28 69 6e 74 20 72 63 29 7b alError(int rc){
1c40: 0a 20 20 72 65 74 75 72 6e 20 28 72 63 21 3d 53 . return (rc!=S
1c50: 51 4c 49 54 45 5f 4f 4b 20 26 26 20 72 63 21 3d QLITE_OK && rc!=
1c60: 53 51 4c 49 54 45 5f 42 55 53 59 20 26 26 20 41 SQLITE_BUSY && A
1c70: 4c 57 41 59 53 28 72 63 21 3d 53 51 4c 49 54 45 LWAYS(rc!=SQLITE
1c80: 5f 4c 4f 43 4b 45 44 29 29 3b 0a 7d 0a 0a 2f 2a _LOCKED));.}../*
1c90: 0a 2a 2a 20 50 61 72 61 6d 65 74 65 72 20 7a 53 .** Parameter zS
1ca0: 72 63 44 61 74 61 20 70 6f 69 6e 74 73 20 74 6f rcData points to
1cb0: 20 61 20 62 75 66 66 65 72 20 63 6f 6e 74 61 69 a buffer contai
1cc0: 6e 69 6e 67 20 74 68 65 20 64 61 74 61 20 66 6f ning the data fo
1cd0: 72 20 0a 2a 2a 20 70 61 67 65 20 69 53 72 63 50 r .** page iSrcP
1ce0: 67 20 66 72 6f 6d 20 74 68 65 20 73 6f 75 72 63 g from the sourc
1cf0: 65 20 64 61 74 61 62 61 73 65 2e 20 43 6f 70 79 e database. Copy
1d00: 20 74 68 69 73 20 64 61 74 61 20 69 6e 74 6f 20 this data into
1d10: 74 68 65 20 0a 2a 2a 20 64 65 73 74 69 6e 61 74 the .** destinat
1d20: 69 6f 6e 20 64 61 74 61 62 61 73 65 2e 0a 2a 2f ion database..*/
1d30: 0a 73 74 61 74 69 63 20 69 6e 74 20 62 61 63 6b .static int back
1d40: 75 70 4f 6e 65 50 61 67 65 28 0a 20 20 73 71 6c upOnePage(. sql
1d50: 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 2c 20 ite3_backup *p,
1d60: 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 /*
1d70: 42 61 63 6b 75 70 20 68 61 6e 64 6c 65 20 2a 2f Backup handle */
1d80: 0a 20 20 50 67 6e 6f 20 69 53 72 63 50 67 2c 20 . Pgno iSrcPg,
1d90: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1da0: 20 20 20 2f 2a 20 53 6f 75 72 63 65 20 64 61 74 /* Source dat
1db0: 61 62 61 73 65 20 70 61 67 65 20 74 6f 20 62 61 abase page to ba
1dc0: 63 6b 75 70 20 2a 2f 0a 20 20 63 6f 6e 73 74 20 ckup */. const
1dd0: 75 38 20 2a 7a 53 72 63 44 61 74 61 2c 20 20 20 u8 *zSrcData,
1de0: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 53 6f 75 /* Sou
1df0: 72 63 65 20 64 61 74 61 62 61 73 65 20 70 61 67 rce database pag
1e00: 65 20 64 61 74 61 20 2a 2f 0a 20 20 69 6e 74 20 e data */. int
1e10: 62 55 70 64 61 74 65 20 20 20 20 20 20 20 20 20 bUpdate
1e20: 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a 20 54 /* T
1e30: 72 75 65 20 66 6f 72 20 61 6e 20 75 70 64 61 74 rue for an updat
1e40: 65 2c 20 66 61 6c 73 65 20 6f 74 68 65 72 77 69 e, false otherwi
1e50: 73 65 20 2a 2f 0a 29 7b 0a 20 20 50 61 67 65 72 se */.){. Pager
1e60: 20 2a 20 63 6f 6e 73 74 20 70 44 65 73 74 50 61 * const pDestPa
1e70: 67 65 72 20 3d 20 73 71 6c 69 74 65 33 42 74 72 ger = sqlite3Btr
1e80: 65 65 50 61 67 65 72 28 70 2d 3e 70 44 65 73 74 eePager(p->pDest
1e90: 29 3b 0a 20 20 63 6f 6e 73 74 20 69 6e 74 20 6e );. const int n
1ea0: 53 72 63 50 67 73 7a 20 3d 20 73 71 6c 69 74 65 SrcPgsz = sqlite
1eb0: 33 42 74 72 65 65 47 65 74 50 61 67 65 53 69 7a 3BtreeGetPageSiz
1ec0: 65 28 70 2d 3e 70 53 72 63 29 3b 0a 20 20 69 6e e(p->pSrc);. in
1ed0: 74 20 6e 44 65 73 74 50 67 73 7a 20 3d 20 73 71 t nDestPgsz = sq
1ee0: 6c 69 74 65 33 42 74 72 65 65 47 65 74 50 61 67 lite3BtreeGetPag
1ef0: 65 53 69 7a 65 28 70 2d 3e 70 44 65 73 74 29 3b eSize(p->pDest);
1f00: 0a 20 20 63 6f 6e 73 74 20 69 6e 74 20 6e 43 6f . const int nCo
1f10: 70 79 20 3d 20 4d 49 4e 28 6e 53 72 63 50 67 73 py = MIN(nSrcPgs
1f20: 7a 2c 20 6e 44 65 73 74 50 67 73 7a 29 3b 0a 20 z, nDestPgsz);.
1f30: 20 63 6f 6e 73 74 20 69 36 34 20 69 45 6e 64 20 const i64 iEnd
1f40: 3d 20 28 69 36 34 29 69 53 72 63 50 67 2a 28 69 = (i64)iSrcPg*(i
1f50: 36 34 29 6e 53 72 63 50 67 73 7a 3b 0a 23 69 66 64)nSrcPgsz;.#if
1f60: 64 65 66 20 53 51 4c 49 54 45 5f 48 41 53 5f 43 def SQLITE_HAS_C
1f70: 4f 44 45 43 0a 20 20 2f 2a 20 55 73 65 20 42 74 ODEC. /* Use Bt
1f80: 72 65 65 47 65 74 52 65 73 65 72 76 65 4e 6f 4d reeGetReserveNoM
1f90: 75 74 65 78 28 29 20 66 6f 72 20 74 68 65 20 73 utex() for the s
1fa0: 6f 75 72 63 65 20 62 2d 74 72 65 65 2c 20 61 73 ource b-tree, as
1fb0: 20 61 6c 74 68 6f 75 67 68 20 69 74 20 69 73 0a although it is.
1fc0: 20 20 2a 2a 20 67 75 61 72 61 6e 74 65 65 64 20 ** guaranteed
1fd0: 74 68 61 74 20 74 68 65 20 73 68 61 72 65 64 2d that the shared-
1fe0: 6d 75 74 65 78 20 69 73 20 68 65 6c 64 20 62 79 mutex is held by
1ff0: 20 74 68 69 73 20 74 68 72 65 61 64 2c 20 68 61 this thread, ha
2000: 6e 64 6c 65 0a 20 20 2a 2a 20 70 2d 3e 70 53 72 ndle. ** p->pSr
2010: 63 20 6d 61 79 20 6e 6f 74 20 61 63 74 75 61 6c c may not actual
2020: 6c 79 20 62 65 20 74 68 65 20 6f 77 6e 65 72 2e ly be the owner.
2030: 20 20 2a 2f 0a 20 20 69 6e 74 20 6e 53 72 63 52 */. int nSrcR
2040: 65 73 65 72 76 65 20 3d 20 73 71 6c 69 74 65 33 eserve = sqlite3
2050: 42 74 72 65 65 47 65 74 52 65 73 65 72 76 65 4e BtreeGetReserveN
2060: 6f 4d 75 74 65 78 28 70 2d 3e 70 53 72 63 29 3b oMutex(p->pSrc);
2070: 0a 20 20 69 6e 74 20 6e 44 65 73 74 52 65 73 65 . int nDestRese
2080: 72 76 65 20 3d 20 73 71 6c 69 74 65 33 42 74 72 rve = sqlite3Btr
2090: 65 65 47 65 74 52 65 73 65 72 76 65 28 70 2d 3e eeGetReserve(p->
20a0: 70 44 65 73 74 29 3b 0a 23 65 6e 64 69 66 0a 20 pDest);.#endif.
20b0: 20 69 6e 74 20 72 63 20 3d 20 53 51 4c 49 54 45 int rc = SQLITE
20c0: 5f 4f 4b 3b 0a 20 20 69 36 34 20 69 4f 66 66 3b _OK;. i64 iOff;
20d0: 0a 0a 20 20 61 73 73 65 72 74 28 20 73 71 6c 69 .. assert( sqli
20e0: 74 65 33 42 74 72 65 65 47 65 74 52 65 73 65 72 te3BtreeGetReser
20f0: 76 65 4e 6f 4d 75 74 65 78 28 70 2d 3e 70 53 72 veNoMutex(p->pSr
2100: 63 29 3e 3d 30 20 29 3b 0a 20 20 61 73 73 65 72 c)>=0 );. asser
2110: 74 28 20 70 2d 3e 62 44 65 73 74 4c 6f 63 6b 65 t( p->bDestLocke
2120: 64 20 29 3b 0a 20 20 61 73 73 65 72 74 28 20 21 d );. assert( !
2130: 69 73 46 61 74 61 6c 45 72 72 6f 72 28 70 2d 3e isFatalError(p->
2140: 72 63 29 20 29 3b 0a 20 20 61 73 73 65 72 74 28 rc) );. assert(
2150: 20 69 53 72 63 50 67 21 3d 50 45 4e 44 49 4e 47 iSrcPg!=PENDING
2160: 5f 42 59 54 45 5f 50 41 47 45 28 70 2d 3e 70 53 _BYTE_PAGE(p->pS
2170: 72 63 2d 3e 70 42 74 29 20 29 3b 0a 20 20 61 73 rc->pBt) );. as
2180: 73 65 72 74 28 20 7a 53 72 63 44 61 74 61 20 29 sert( zSrcData )
2190: 3b 0a 0a 20 20 2f 2a 20 43 61 74 63 68 20 74 68 ;.. /* Catch th
21a0: 65 20 63 61 73 65 20 77 68 65 72 65 20 74 68 65 e case where the
21b0: 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 69 73 20 destination is
21c0: 61 6e 20 69 6e 2d 6d 65 6d 6f 72 79 20 64 61 74 an in-memory dat
21d0: 61 62 61 73 65 20 61 6e 64 20 74 68 65 0a 20 20 abase and the.
21e0: 2a 2a 20 70 61 67 65 20 73 69 7a 65 73 20 6f 66 ** page sizes of
21f0: 20 74 68 65 20 73 6f 75 72 63 65 20 61 6e 64 20 the source and
2200: 64 65 73 74 69 6e 61 74 69 6f 6e 20 64 69 66 66 destination diff
2210: 65 72 2e 20 0a 20 20 2a 2f 0a 20 20 69 66 28 20 er. . */. if(
2220: 6e 53 72 63 50 67 73 7a 21 3d 6e 44 65 73 74 50 nSrcPgsz!=nDestP
2230: 67 73 7a 20 26 26 20 73 71 6c 69 74 65 33 50 61 gsz && sqlite3Pa
2240: 67 65 72 49 73 4d 65 6d 64 62 28 70 44 65 73 74 gerIsMemdb(pDest
2250: 50 61 67 65 72 29 20 29 7b 0a 20 20 20 20 72 63 Pager) ){. rc
2260: 20 3d 20 53 51 4c 49 54 45 5f 52 45 41 44 4f 4e = SQLITE_READON
2270: 4c 59 3b 0a 20 20 7d 0a 0a 23 69 66 64 65 66 20 LY;. }..#ifdef
2280: 53 51 4c 49 54 45 5f 48 41 53 5f 43 4f 44 45 43 SQLITE_HAS_CODEC
2290: 0a 20 20 2f 2a 20 42 61 63 6b 75 70 20 69 73 20 . /* Backup is
22a0: 6e 6f 74 20 70 6f 73 73 69 62 6c 65 20 69 66 20 not possible if
22b0: 74 68 65 20 70 61 67 65 20 73 69 7a 65 20 6f 66 the page size of
22c0: 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e the destination
22d0: 20 69 73 20 63 68 61 6e 67 69 6e 67 0a 20 20 2a is changing. *
22e0: 2a 20 61 6e 64 20 61 20 63 6f 64 65 63 20 69 73 * and a codec is
22f0: 20 69 6e 20 75 73 65 2e 0a 20 20 2a 2f 0a 20 20 in use.. */.
2300: 69 66 28 20 6e 53 72 63 50 67 73 7a 21 3d 6e 44 if( nSrcPgsz!=nD
2310: 65 73 74 50 67 73 7a 20 26 26 20 73 71 6c 69 74 estPgsz && sqlit
2320: 65 33 50 61 67 65 72 47 65 74 43 6f 64 65 63 28 e3PagerGetCodec(
2330: 70 44 65 73 74 50 61 67 65 72 29 21 3d 30 20 29 pDestPager)!=0 )
2340: 7b 0a 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54 {. rc = SQLIT
2350: 45 5f 52 45 41 44 4f 4e 4c 59 3b 0a 20 20 7d 0a E_READONLY;. }.
2360: 0a 20 20 2f 2a 20 42 61 63 6b 75 70 20 69 73 20 . /* Backup is
2370: 6e 6f 74 20 70 6f 73 73 69 62 6c 65 20 69 66 20 not possible if
2380: 74 68 65 20 6e 75 6d 62 65 72 20 6f 66 20 62 79 the number of by
2390: 74 65 73 20 6f 66 20 72 65 73 65 72 76 65 20 73 tes of reserve s
23a0: 70 61 63 65 20 64 69 66 66 65 72 0a 20 20 2a 2a pace differ. **
23b0: 20 62 65 74 77 65 65 6e 20 73 6f 75 72 63 65 20 between source
23c0: 61 6e 64 20 64 65 73 74 69 6e 61 74 69 6f 6e 2e and destination.
23d0: 20 20 49 66 20 74 68 65 72 65 20 69 73 20 61 20 If there is a
23e0: 64 69 66 66 65 72 65 6e 63 65 2c 20 74 72 79 20 difference, try
23f0: 74 6f 0a 20 20 2a 2a 20 66 69 78 20 74 68 65 20 to. ** fix the
2400: 64 65 73 74 69 6e 61 74 69 6f 6e 20 74 6f 20 61 destination to a
2410: 67 72 65 65 20 77 69 74 68 20 74 68 65 20 73 6f gree with the so
2420: 75 72 63 65 2e 20 20 49 66 20 74 68 61 74 20 69 urce. If that i
2430: 73 20 6e 6f 74 20 70 6f 73 73 69 62 6c 65 2c 0a s not possible,.
2440: 20 20 2a 2a 20 74 68 65 6e 20 74 68 65 20 62 61 ** then the ba
2450: 63 6b 75 70 20 63 61 6e 6e 6f 74 20 70 72 6f 63 ckup cannot proc
2460: 65 65 64 2e 0a 20 20 2a 2f 0a 20 20 69 66 28 20 eed.. */. if(
2470: 6e 53 72 63 52 65 73 65 72 76 65 21 3d 6e 44 65 nSrcReserve!=nDe
2480: 73 74 52 65 73 65 72 76 65 20 29 7b 0a 20 20 20 stReserve ){.
2490: 20 75 33 32 20 6e 65 77 50 67 73 7a 20 3d 20 6e u32 newPgsz = n
24a0: 53 72 63 50 67 73 7a 3b 0a 20 20 20 20 72 63 20 SrcPgsz;. rc
24b0: 3d 20 73 71 6c 69 74 65 33 50 61 67 65 72 53 65 = sqlite3PagerSe
24c0: 74 50 61 67 65 73 69 7a 65 28 70 44 65 73 74 50 tPagesize(pDestP
24d0: 61 67 65 72 2c 20 26 6e 65 77 50 67 73 7a 2c 20 ager, &newPgsz,
24e0: 6e 53 72 63 52 65 73 65 72 76 65 29 3b 0a 20 20 nSrcReserve);.
24f0: 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 if( rc==SQLITE
2500: 5f 4f 4b 20 26 26 20 6e 65 77 50 67 73 7a 21 3d _OK && newPgsz!=
2510: 6e 53 72 63 50 67 73 7a 20 29 20 72 63 20 3d 20 nSrcPgsz ) rc =
2520: 53 51 4c 49 54 45 5f 52 45 41 44 4f 4e 4c 59 3b SQLITE_READONLY;
2530: 0a 20 20 7d 0a 23 65 6e 64 69 66 0a 0a 20 20 2f . }.#endif.. /
2540: 2a 20 54 68 69 73 20 6c 6f 6f 70 20 72 75 6e 73 * This loop runs
2550: 20 6f 6e 63 65 20 66 6f 72 20 65 61 63 68 20 64 once for each d
2560: 65 73 74 69 6e 61 74 69 6f 6e 20 70 61 67 65 20 estination page
2570: 73 70 61 6e 6e 65 64 20 62 79 20 74 68 65 20 73 spanned by the s
2580: 6f 75 72 63 65 20 0a 20 20 2a 2a 20 70 61 67 65 ource . ** page
2590: 2e 20 46 6f 72 20 65 61 63 68 20 69 74 65 72 61 . For each itera
25a0: 74 69 6f 6e 2c 20 76 61 72 69 61 62 6c 65 20 69 tion, variable i
25b0: 4f 66 66 20 69 73 20 73 65 74 20 74 6f 20 74 68 Off is set to th
25c0: 65 20 62 79 74 65 20 6f 66 66 73 65 74 0a 20 20 e byte offset.
25d0: 2a 2a 20 6f 66 20 74 68 65 20 64 65 73 74 69 6e ** of the destin
25e0: 61 74 69 6f 6e 20 70 61 67 65 2e 0a 20 20 2a 2f ation page.. */
25f0: 0a 20 20 66 6f 72 28 69 4f 66 66 3d 69 45 6e 64 . for(iOff=iEnd
2600: 2d 28 69 36 34 29 6e 53 72 63 50 67 73 7a 3b 20 -(i64)nSrcPgsz;
2610: 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 26 26 rc==SQLITE_OK &&
2620: 20 69 4f 66 66 3c 69 45 6e 64 3b 20 69 4f 66 66 iOff<iEnd; iOff
2630: 2b 3d 6e 44 65 73 74 50 67 73 7a 29 7b 0a 20 20 +=nDestPgsz){.
2640: 20 20 44 62 50 61 67 65 20 2a 70 44 65 73 74 50 DbPage *pDestP
2650: 67 20 3d 20 30 3b 0a 20 20 20 20 50 67 6e 6f 20 g = 0;. Pgno
2660: 69 44 65 73 74 20 3d 20 28 50 67 6e 6f 29 28 69 iDest = (Pgno)(i
2670: 4f 66 66 2f 6e 44 65 73 74 50 67 73 7a 29 2b 31 Off/nDestPgsz)+1
2680: 3b 0a 20 20 20 20 69 66 28 20 69 44 65 73 74 3d ;. if( iDest=
2690: 3d 50 45 4e 44 49 4e 47 5f 42 59 54 45 5f 50 41 =PENDING_BYTE_PA
26a0: 47 45 28 70 2d 3e 70 44 65 73 74 2d 3e 70 42 74 GE(p->pDest->pBt
26b0: 29 20 29 20 63 6f 6e 74 69 6e 75 65 3b 0a 20 20 ) ) continue;.
26c0: 20 20 69 66 28 20 53 51 4c 49 54 45 5f 4f 4b 3d if( SQLITE_OK=
26d0: 3d 28 72 63 20 3d 20 73 71 6c 69 74 65 33 50 61 =(rc = sqlite3Pa
26e0: 67 65 72 47 65 74 28 70 44 65 73 74 50 61 67 65 gerGet(pDestPage
26f0: 72 2c 20 69 44 65 73 74 2c 20 26 70 44 65 73 74 r, iDest, &pDest
2700: 50 67 29 29 0a 20 20 20 20 20 26 26 20 53 51 4c Pg)). && SQL
2710: 49 54 45 5f 4f 4b 3d 3d 28 72 63 20 3d 20 73 71 ITE_OK==(rc = sq
2720: 6c 69 74 65 33 50 61 67 65 72 57 72 69 74 65 28 lite3PagerWrite(
2730: 70 44 65 73 74 50 67 29 29 0a 20 20 20 20 29 7b pDestPg)). ){
2740: 0a 20 20 20 20 20 20 63 6f 6e 73 74 20 75 38 20 . const u8
2750: 2a 7a 49 6e 20 3d 20 26 7a 53 72 63 44 61 74 61 *zIn = &zSrcData
2760: 5b 69 4f 66 66 25 6e 53 72 63 50 67 73 7a 5d 3b [iOff%nSrcPgsz];
2770: 0a 20 20 20 20 20 20 75 38 20 2a 7a 44 65 73 74 . u8 *zDest
2780: 44 61 74 61 20 3d 20 73 71 6c 69 74 65 33 50 61 Data = sqlite3Pa
2790: 67 65 72 47 65 74 44 61 74 61 28 70 44 65 73 74 gerGetData(pDest
27a0: 50 67 29 3b 0a 20 20 20 20 20 20 75 38 20 2a 7a Pg);. u8 *z
27b0: 4f 75 74 20 3d 20 26 7a 44 65 73 74 44 61 74 61 Out = &zDestData
27c0: 5b 69 4f 66 66 25 6e 44 65 73 74 50 67 73 7a 5d [iOff%nDestPgsz]
27d0: 3b 0a 0a 20 20 20 20 20 20 2f 2a 20 43 6f 70 79 ;.. /* Copy
27e0: 20 74 68 65 20 64 61 74 61 20 66 72 6f 6d 20 74 the data from t
27f0: 68 65 20 73 6f 75 72 63 65 20 70 61 67 65 20 69 he source page i
2800: 6e 74 6f 20 74 68 65 20 64 65 73 74 69 6e 61 74 nto the destinat
2810: 69 6f 6e 20 70 61 67 65 2e 0a 20 20 20 20 20 20 ion page..
2820: 2a 2a 20 54 68 65 6e 20 63 6c 65 61 72 20 74 68 ** Then clear th
2830: 65 20 42 74 72 65 65 20 6c 61 79 65 72 20 4d 65 e Btree layer Me
2840: 6d 50 61 67 65 2e 69 73 49 6e 69 74 20 66 6c 61 mPage.isInit fla
2850: 67 2e 20 42 6f 74 68 20 74 68 69 73 20 6d 6f 64 g. Both this mod
2860: 75 6c 65 0a 20 20 20 20 20 20 2a 2a 20 61 6e 64 ule. ** and
2870: 20 74 68 65 20 70 61 67 65 72 20 63 6f 64 65 20 the pager code
2880: 75 73 65 20 74 68 69 73 20 74 72 69 63 6b 20 28 use this trick (
2890: 63 6c 65 61 72 69 6e 67 20 74 68 65 20 66 69 72 clearing the fir
28a0: 73 74 20 62 79 74 65 0a 20 20 20 20 20 20 2a 2a st byte. **
28b0: 20 6f 66 20 74 68 65 20 70 61 67 65 20 27 65 78 of the page 'ex
28c0: 74 72 61 27 20 73 70 61 63 65 20 74 6f 20 69 6e tra' space to in
28d0: 76 61 6c 69 64 61 74 65 20 74 68 65 20 42 74 72 validate the Btr
28e0: 65 65 20 6c 61 79 65 72 73 0a 20 20 20 20 20 20 ee layers.
28f0: 2a 2a 20 63 61 63 68 65 64 20 70 61 72 73 65 20 ** cached parse
2900: 6f 66 20 74 68 65 20 70 61 67 65 29 2e 20 4d 65 of the page). Me
2910: 6d 50 61 67 65 2e 69 73 49 6e 69 74 20 69 73 20 mPage.isInit is
2920: 6d 61 72 6b 65 64 20 0a 20 20 20 20 20 20 2a 2a marked . **
2930: 20 22 4d 55 53 54 20 42 45 20 46 49 52 53 54 22 "MUST BE FIRST"
2940: 20 66 6f 72 20 74 68 69 73 20 70 75 72 70 6f 73 for this purpos
2950: 65 2e 0a 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 e.. */.
2960: 20 20 6d 65 6d 63 70 79 28 7a 4f 75 74 2c 20 7a memcpy(zOut, z
2970: 49 6e 2c 20 6e 43 6f 70 79 29 3b 0a 20 20 20 20 In, nCopy);.
2980: 20 20 28 28 75 38 20 2a 29 73 71 6c 69 74 65 33 ((u8 *)sqlite3
2990: 50 61 67 65 72 47 65 74 45 78 74 72 61 28 70 44 PagerGetExtra(pD
29a0: 65 73 74 50 67 29 29 5b 30 5d 20 3d 20 30 3b 0a estPg))[0] = 0;.
29b0: 20 20 20 20 20 20 69 66 28 20 69 4f 66 66 3d 3d if( iOff==
29c0: 30 20 26 26 20 62 55 70 64 61 74 65 3d 3d 30 20 0 && bUpdate==0
29d0: 29 7b 0a 20 20 20 20 20 20 20 20 73 71 6c 69 74 ){. sqlit
29e0: 65 33 50 75 74 34 62 79 74 65 28 26 7a 4f 75 74 e3Put4byte(&zOut
29f0: 5b 32 38 5d 2c 20 73 71 6c 69 74 65 33 42 74 72 [28], sqlite3Btr
2a00: 65 65 4c 61 73 74 50 61 67 65 28 70 2d 3e 70 53 eeLastPage(p->pS
2a10: 72 63 29 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 rc));. }.
2a20: 20 20 7d 0a 20 20 20 20 73 71 6c 69 74 65 33 50 }. sqlite3P
2a30: 61 67 65 72 55 6e 72 65 66 28 70 44 65 73 74 50 agerUnref(pDestP
2a40: 67 29 3b 0a 20 20 7d 0a 0a 20 20 72 65 74 75 72 g);. }.. retur
2a50: 6e 20 72 63 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 49 n rc;.}../*.** I
2a60: 66 20 70 46 69 6c 65 20 69 73 20 63 75 72 72 65 f pFile is curre
2a70: 6e 74 6c 79 20 6c 61 72 67 65 72 20 74 68 61 6e ntly larger than
2a80: 20 69 53 69 7a 65 20 62 79 74 65 73 2c 20 74 68 iSize bytes, th
2a90: 65 6e 20 74 72 75 6e 63 61 74 65 20 69 74 20 74 en truncate it t
2aa0: 6f 0a 2a 2a 20 65 78 61 63 74 6c 79 20 69 53 69 o.** exactly iSi
2ab0: 7a 65 20 62 79 74 65 73 2e 20 49 66 20 70 46 69 ze bytes. If pFi
2ac0: 6c 65 20 69 73 20 6e 6f 74 20 6c 61 72 67 65 72 le is not larger
2ad0: 20 74 68 61 6e 20 69 53 69 7a 65 20 62 79 74 65 than iSize byte
2ae0: 73 2c 20 74 68 65 6e 0a 2a 2a 20 74 68 69 73 20 s, then.** this
2af0: 66 75 6e 63 74 69 6f 6e 20 69 73 20 61 20 6e 6f function is a no
2b00: 2d 6f 70 2e 0a 2a 2a 0a 2a 2a 20 52 65 74 75 72 -op..**.** Retur
2b10: 6e 20 53 51 4c 49 54 45 5f 4f 4b 20 69 66 20 65 n SQLITE_OK if e
2b20: 76 65 72 79 74 68 69 6e 67 20 69 73 20 73 75 63 verything is suc
2b30: 63 65 73 73 66 75 6c 2c 20 6f 72 20 61 6e 20 53 cessful, or an S
2b40: 51 4c 69 74 65 20 65 72 72 6f 72 20 0a 2a 2a 20 QLite error .**
2b50: 63 6f 64 65 20 69 66 20 61 6e 20 65 72 72 6f 72 code if an error
2b60: 20 6f 63 63 75 72 73 2e 0a 2a 2f 0a 73 74 61 74 occurs..*/.stat
2b70: 69 63 20 69 6e 74 20 62 61 63 6b 75 70 54 72 75 ic int backupTru
2b80: 6e 63 61 74 65 46 69 6c 65 28 73 71 6c 69 74 65 ncateFile(sqlite
2b90: 33 5f 66 69 6c 65 20 2a 70 46 69 6c 65 2c 20 69 3_file *pFile, i
2ba0: 36 34 20 69 53 69 7a 65 29 7b 0a 20 20 69 36 34 64 iSize){. i64
2bb0: 20 69 43 75 72 72 65 6e 74 3b 0a 20 20 69 6e 74 iCurrent;. int
2bc0: 20 72 63 20 3d 20 73 71 6c 69 74 65 33 4f 73 46 rc = sqlite3OsF
2bd0: 69 6c 65 53 69 7a 65 28 70 46 69 6c 65 2c 20 26 ileSize(pFile, &
2be0: 69 43 75 72 72 65 6e 74 29 3b 0a 20 20 69 66 28 iCurrent);. if(
2bf0: 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 26 rc==SQLITE_OK &
2c00: 26 20 69 43 75 72 72 65 6e 74 3e 69 53 69 7a 65 & iCurrent>iSize
2c10: 20 29 7b 0a 20 20 20 20 72 63 20 3d 20 73 71 6c ){. rc = sql
2c20: 69 74 65 33 4f 73 54 72 75 6e 63 61 74 65 28 70 ite3OsTruncate(p
2c30: 46 69 6c 65 2c 20 69 53 69 7a 65 29 3b 0a 20 20 File, iSize);.
2c40: 7d 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d }. return rc;.}
2c50: 0a 0a 2f 2a 0a 2a 2a 20 52 65 67 69 73 74 65 72 ../*.** Register
2c60: 20 74 68 69 73 20 62 61 63 6b 75 70 20 6f 62 6a this backup obj
2c70: 65 63 74 20 77 69 74 68 20 74 68 65 20 61 73 73 ect with the ass
2c80: 6f 63 69 61 74 65 64 20 73 6f 75 72 63 65 20 70 ociated source p
2c90: 61 67 65 72 20 66 6f 72 0a 2a 2a 20 63 61 6c 6c ager for.** call
2ca0: 62 61 63 6b 73 20 77 68 65 6e 20 70 61 67 65 73 backs when pages
2cb0: 20 61 72 65 20 63 68 61 6e 67 65 64 20 6f 72 20 are changed or
2cc0: 74 68 65 20 63 61 63 68 65 20 69 6e 76 61 6c 69 the cache invali
2cd0: 64 61 74 65 64 2e 0a 2a 2f 0a 73 74 61 74 69 63 dated..*/.static
2ce0: 20 76 6f 69 64 20 61 74 74 61 63 68 42 61 63 6b void attachBack
2cf0: 75 70 4f 62 6a 65 63 74 28 73 71 6c 69 74 65 33 upObject(sqlite3
2d00: 5f 62 61 63 6b 75 70 20 2a 70 29 7b 0a 20 20 73 _backup *p){. s
2d10: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 2a qlite3_backup **
2d20: 70 70 3b 0a 20 20 61 73 73 65 72 74 28 20 73 71 pp;. assert( sq
2d30: 6c 69 74 65 33 42 74 72 65 65 48 6f 6c 64 73 4d lite3BtreeHoldsM
2d40: 75 74 65 78 28 70 2d 3e 70 53 72 63 29 20 29 3b utex(p->pSrc) );
2d50: 0a 20 20 70 70 20 3d 20 73 71 6c 69 74 65 33 50 . pp = sqlite3P
2d60: 61 67 65 72 42 61 63 6b 75 70 50 74 72 28 73 71 agerBackupPtr(sq
2d70: 6c 69 74 65 33 42 74 72 65 65 50 61 67 65 72 28 lite3BtreePager(
2d80: 70 2d 3e 70 53 72 63 29 29 3b 0a 20 20 70 2d 3e p->pSrc));. p->
2d90: 70 4e 65 78 74 20 3d 20 2a 70 70 3b 0a 20 20 2a pNext = *pp;. *
2da0: 70 70 20 3d 20 70 3b 0a 20 20 70 2d 3e 69 73 41 pp = p;. p->isA
2db0: 74 74 61 63 68 65 64 20 3d 20 31 3b 0a 7d 0a 0a ttached = 1;.}..
2dc0: 2f 2a 0a 2a 2a 20 43 6f 70 79 20 6e 50 61 67 65 /*.** Copy nPage
2dd0: 20 70 61 67 65 73 20 66 72 6f 6d 20 74 68 65 20 pages from the
2de0: 73 6f 75 72 63 65 20 62 2d 74 72 65 65 20 74 6f source b-tree to
2df0: 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e the destination
2e00: 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 ..*/.int sqlite3
2e10: 5f 62 61 63 6b 75 70 5f 73 74 65 70 28 73 71 6c _backup_step(sql
2e20: 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 2c 20 ite3_backup *p,
2e30: 69 6e 74 20 6e 50 61 67 65 29 7b 0a 20 20 69 6e int nPage){. in
2e40: 74 20 72 63 3b 0a 20 20 69 6e 74 20 64 65 73 74 t rc;. int dest
2e50: 4d 6f 64 65 3b 20 20 20 20 20 20 20 2f 2a 20 44 Mode; /* D
2e60: 65 73 74 69 6e 61 74 69 6f 6e 20 6a 6f 75 72 6e estination journ
2e70: 61 6c 20 6d 6f 64 65 20 2a 2f 0a 20 20 69 6e 74 al mode */. int
2e80: 20 70 67 73 7a 53 72 63 20 3d 20 30 3b 20 20 20 pgszSrc = 0;
2e90: 20 2f 2a 20 53 6f 75 72 63 65 20 70 61 67 65 20 /* Source page
2ea0: 73 69 7a 65 20 2a 2f 0a 20 20 69 6e 74 20 70 67 size */. int pg
2eb0: 73 7a 44 65 73 74 20 3d 20 30 3b 20 20 20 2f 2a szDest = 0; /*
2ec0: 20 44 65 73 74 69 6e 61 74 69 6f 6e 20 70 61 67 Destination pag
2ed0: 65 20 73 69 7a 65 20 2a 2f 0a 0a 20 20 73 71 6c e size */.. sql
2ee0: 69 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 ite3_mutex_enter
2ef0: 28 70 2d 3e 70 53 72 63 44 62 2d 3e 6d 75 74 65 (p->pSrcDb->mute
2f00: 78 29 3b 0a 20 20 73 71 6c 69 74 65 33 42 74 72 x);. sqlite3Btr
2f10: 65 65 45 6e 74 65 72 28 70 2d 3e 70 53 72 63 29 eeEnter(p->pSrc)
2f20: 3b 0a 20 20 69 66 28 20 70 2d 3e 70 44 65 73 74 ;. if( p->pDest
2f30: 44 62 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 Db ){. sqlite
2f40: 33 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28 70 2d 3_mutex_enter(p-
2f50: 3e 70 44 65 73 74 44 62 2d 3e 6d 75 74 65 78 29 >pDestDb->mutex)
2f60: 3b 0a 20 20 7d 0a 0a 20 20 72 63 20 3d 20 70 2d ;. }.. rc = p-
2f70: 3e 72 63 3b 0a 20 20 69 66 28 20 21 69 73 46 61 >rc;. if( !isFa
2f80: 74 61 6c 45 72 72 6f 72 28 72 63 29 20 29 7b 0a talError(rc) ){.
2f90: 20 20 20 20 50 61 67 65 72 20 2a 20 63 6f 6e 73 Pager * cons
2fa0: 74 20 70 53 72 63 50 61 67 65 72 20 3d 20 73 71 t pSrcPager = sq
2fb0: 6c 69 74 65 33 42 74 72 65 65 50 61 67 65 72 28 lite3BtreePager(
2fc0: 70 2d 3e 70 53 72 63 29 3b 20 20 20 20 20 2f 2a p->pSrc); /*
2fd0: 20 53 6f 75 72 63 65 20 70 61 67 65 72 20 2a 2f Source pager */
2fe0: 0a 20 20 20 20 50 61 67 65 72 20 2a 20 63 6f 6e . Pager * con
2ff0: 73 74 20 70 44 65 73 74 50 61 67 65 72 20 3d 20 st pDestPager =
3000: 73 71 6c 69 74 65 33 42 74 72 65 65 50 61 67 65 sqlite3BtreePage
3010: 72 28 70 2d 3e 70 44 65 73 74 29 3b 20 20 20 2f r(p->pDest); /
3020: 2a 20 44 65 73 74 20 70 61 67 65 72 20 2a 2f 0a * Dest pager */.
3030: 20 20 20 20 69 6e 74 20 69 69 3b 20 20 20 20 20 int ii;
3040: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
3050: 20 20 20 20 20 20 20 2f 2a 20 49 74 65 72 61 74 /* Iterat
3060: 6f 72 20 76 61 72 69 61 62 6c 65 20 2a 2f 0a 20 or variable */.
3070: 20 20 20 69 6e 74 20 6e 53 72 63 50 61 67 65 20 int nSrcPage
3080: 3d 20 2d 31 3b 20 20 20 20 20 20 20 20 20 20 20 = -1;
3090: 20 20 20 20 20 20 2f 2a 20 53 69 7a 65 20 6f 66 /* Size of
30a0: 20 73 6f 75 72 63 65 20 64 62 20 69 6e 20 70 61 source db in pa
30b0: 67 65 73 20 2a 2f 0a 20 20 20 20 69 6e 74 20 62 ges */. int b
30c0: 43 6c 6f 73 65 54 72 61 6e 73 20 3d 20 30 3b 20 CloseTrans = 0;
30d0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f 2a /*
30e0: 20 54 72 75 65 20 69 66 20 73 72 63 20 64 62 20 True if src db
30f0: 72 65 71 75 69 72 65 73 20 75 6e 6c 6f 63 6b 69 requires unlocki
3100: 6e 67 20 2a 2f 0a 0a 20 20 20 20 2f 2a 20 49 66 ng */.. /* If
3110: 20 74 68 65 20 73 6f 75 72 63 65 20 70 61 67 65 the source page
3120: 72 20 69 73 20 63 75 72 72 65 6e 74 6c 79 20 69 r is currently i
3130: 6e 20 61 20 77 72 69 74 65 2d 74 72 61 6e 73 61 n a write-transa
3140: 63 74 69 6f 6e 2c 20 72 65 74 75 72 6e 0a 20 20 ction, return.
3150: 20 20 2a 2a 20 53 51 4c 49 54 45 5f 42 55 53 59 ** SQLITE_BUSY
3160: 20 69 6d 6d 65 64 69 61 74 65 6c 79 2e 0a 20 20 immediately..
3170: 20 20 2a 2f 0a 20 20 20 20 69 66 28 20 70 2d 3e */. if( p->
3180: 70 44 65 73 74 44 62 20 26 26 20 70 2d 3e 70 53 pDestDb && p->pS
3190: 72 63 2d 3e 70 42 74 2d 3e 69 6e 54 72 61 6e 73 rc->pBt->inTrans
31a0: 61 63 74 69 6f 6e 3d 3d 54 52 41 4e 53 5f 57 52 action==TRANS_WR
31b0: 49 54 45 20 29 7b 0a 20 20 20 20 20 20 72 63 20 ITE ){. rc
31c0: 3d 20 53 51 4c 49 54 45 5f 42 55 53 59 3b 0a 20 = SQLITE_BUSY;.
31d0: 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 }else{.
31e0: 72 63 20 3d 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a rc = SQLITE_OK;.
31f0: 20 20 20 20 7d 0a 0a 20 20 20 20 2f 2a 20 4c 6f }.. /* Lo
3200: 63 6b 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 ck the destinati
3210: 6f 6e 20 64 61 74 61 62 61 73 65 2c 20 69 66 20 on database, if
3220: 69 74 20 69 73 20 6e 6f 74 20 6c 6f 63 6b 65 64 it is not locked
3230: 20 61 6c 72 65 61 64 79 2e 20 2a 2f 0a 20 20 20 already. */.
3240: 20 69 66 28 20 53 51 4c 49 54 45 5f 4f 4b 3d 3d if( SQLITE_OK==
3250: 72 63 20 26 26 20 70 2d 3e 62 44 65 73 74 4c 6f rc && p->bDestLo
3260: 63 6b 65 64 3d 3d 30 0a 20 20 20 20 20 26 26 20 cked==0. &&
3270: 53 51 4c 49 54 45 5f 4f 4b 3d 3d 28 72 63 20 3d SQLITE_OK==(rc =
3280: 20 73 71 6c 69 74 65 33 42 74 72 65 65 42 65 67 sqlite3BtreeBeg
3290: 69 6e 54 72 61 6e 73 28 70 2d 3e 70 44 65 73 74 inTrans(p->pDest
32a0: 2c 20 32 29 29 20 0a 20 20 20 20 29 7b 0a 20 20 , 2)) . ){.
32b0: 20 20 20 20 70 2d 3e 62 44 65 73 74 4c 6f 63 6b p->bDestLock
32c0: 65 64 20 3d 20 31 3b 0a 20 20 20 20 20 20 73 71 ed = 1;. sq
32d0: 6c 69 74 65 33 42 74 72 65 65 47 65 74 4d 65 74 lite3BtreeGetMet
32e0: 61 28 70 2d 3e 70 44 65 73 74 2c 20 42 54 52 45 a(p->pDest, BTRE
32f0: 45 5f 53 43 48 45 4d 41 5f 56 45 52 53 49 4f 4e E_SCHEMA_VERSION
3300: 2c 20 26 70 2d 3e 69 44 65 73 74 53 63 68 65 6d , &p->iDestSchem
3310: 61 29 3b 0a 20 20 20 20 7d 0a 0a 20 20 20 20 2f a);. }.. /
3320: 2a 20 49 66 20 74 68 65 72 65 20 69 73 20 6e 6f * If there is no
3330: 20 6f 70 65 6e 20 72 65 61 64 2d 74 72 61 6e 73 open read-trans
3340: 61 63 74 69 6f 6e 20 6f 6e 20 74 68 65 20 73 6f action on the so
3350: 75 72 63 65 20 64 61 74 61 62 61 73 65 2c 20 6f urce database, o
3360: 70 65 6e 0a 20 20 20 20 2a 2a 20 6f 6e 65 20 6e pen. ** one n
3370: 6f 77 2e 20 49 66 20 61 20 74 72 61 6e 73 61 63 ow. If a transac
3380: 74 69 6f 6e 20 69 73 20 6f 70 65 6e 65 64 20 68 tion is opened h
3390: 65 72 65 2c 20 74 68 65 6e 20 69 74 20 77 69 6c ere, then it wil
33a0: 6c 20 62 65 20 63 6c 6f 73 65 64 0a 20 20 20 20 l be closed.
33b0: 2a 2a 20 62 65 66 6f 72 65 20 74 68 69 73 20 66 ** before this f
33c0: 75 6e 63 74 69 6f 6e 20 65 78 69 74 73 2e 0a 20 unction exits..
33d0: 20 20 20 2a 2f 0a 20 20 20 20 69 66 28 20 72 63 */. if( rc
33e0: 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 26 26 20 30 ==SQLITE_OK && 0
33f0: 3d 3d 73 71 6c 69 74 65 33 42 74 72 65 65 49 73 ==sqlite3BtreeIs
3400: 49 6e 52 65 61 64 54 72 61 6e 73 28 70 2d 3e 70 InReadTrans(p->p
3410: 53 72 63 29 20 29 7b 0a 20 20 20 20 20 20 72 63 Src) ){. rc
3420: 20 3d 20 73 71 6c 69 74 65 33 42 74 72 65 65 42 = sqlite3BtreeB
3430: 65 67 69 6e 54 72 61 6e 73 28 70 2d 3e 70 53 72 eginTrans(p->pSr
3440: 63 2c 20 30 29 3b 0a 20 20 20 20 20 20 62 43 6c c, 0);. bCl
3450: 6f 73 65 54 72 61 6e 73 20 3d 20 31 3b 0a 20 20 oseTrans = 1;.
3460: 20 20 7d 0a 0a 20 20 20 20 2f 2a 20 44 6f 20 6e }.. /* Do n
3470: 6f 74 20 61 6c 6c 6f 77 20 62 61 63 6b 75 70 20 ot allow backup
3480: 69 66 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 if the destinati
3490: 6f 6e 20 64 61 74 61 62 61 73 65 20 69 73 20 69 on database is i
34a0: 6e 20 57 41 4c 20 6d 6f 64 65 0a 20 20 20 20 2a n WAL mode. *
34b0: 2a 20 61 6e 64 20 74 68 65 20 70 61 67 65 20 73 * and the page s
34c0: 69 7a 65 73 20 61 72 65 20 64 69 66 66 65 72 65 izes are differe
34d0: 6e 74 20 62 65 74 77 65 65 6e 20 73 6f 75 72 63 nt between sourc
34e0: 65 20 61 6e 64 20 64 65 73 74 69 6e 61 74 69 6f e and destinatio
34f0: 6e 20 2a 2f 0a 20 20 20 20 70 67 73 7a 53 72 63 n */. pgszSrc
3500: 20 3d 20 73 71 6c 69 74 65 33 42 74 72 65 65 47 = sqlite3BtreeG
3510: 65 74 50 61 67 65 53 69 7a 65 28 70 2d 3e 70 53 etPageSize(p->pS
3520: 72 63 29 3b 0a 20 20 20 20 70 67 73 7a 44 65 73 rc);. pgszDes
3530: 74 20 3d 20 73 71 6c 69 74 65 33 42 74 72 65 65 t = sqlite3Btree
3540: 47 65 74 50 61 67 65 53 69 7a 65 28 70 2d 3e 70 GetPageSize(p->p
3550: 44 65 73 74 29 3b 0a 20 20 20 20 64 65 73 74 4d Dest);. destM
3560: 6f 64 65 20 3d 20 73 71 6c 69 74 65 33 50 61 67 ode = sqlite3Pag
3570: 65 72 47 65 74 4a 6f 75 72 6e 61 6c 4d 6f 64 65 erGetJournalMode
3580: 28 73 71 6c 69 74 65 33 42 74 72 65 65 50 61 67 (sqlite3BtreePag
3590: 65 72 28 70 2d 3e 70 44 65 73 74 29 29 3b 0a 20 er(p->pDest));.
35a0: 20 20 20 69 66 28 20 53 51 4c 49 54 45 5f 4f 4b if( SQLITE_OK
35b0: 3d 3d 72 63 20 26 26 20 64 65 73 74 4d 6f 64 65 ==rc && destMode
35c0: 3d 3d 50 41 47 45 52 5f 4a 4f 55 52 4e 41 4c 4d ==PAGER_JOURNALM
35d0: 4f 44 45 5f 57 41 4c 20 26 26 20 70 67 73 7a 53 ODE_WAL && pgszS
35e0: 72 63 21 3d 70 67 73 7a 44 65 73 74 20 29 7b 0a rc!=pgszDest ){.
35f0: 20 20 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54 rc = SQLIT
3600: 45 5f 52 45 41 44 4f 4e 4c 59 3b 0a 20 20 20 20 E_READONLY;.
3610: 7d 0a 20 20 0a 20 20 20 20 2f 2a 20 4e 6f 77 20 }. . /* Now
3620: 74 68 61 74 20 74 68 65 72 65 20 69 73 20 61 20 that there is a
3630: 72 65 61 64 2d 6c 6f 63 6b 20 6f 6e 20 74 68 65 read-lock on the
3640: 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 source database
3650: 2c 20 71 75 65 72 79 20 74 68 65 0a 20 20 20 20 , query the.
3660: 2a 2a 20 73 6f 75 72 63 65 20 70 61 67 65 72 20 ** source pager
3670: 66 6f 72 20 74 68 65 20 6e 75 6d 62 65 72 20 6f for the number o
3680: 66 20 70 61 67 65 73 20 69 6e 20 74 68 65 20 64 f pages in the d
3690: 61 74 61 62 61 73 65 2e 0a 20 20 20 20 2a 2f 0a atabase.. */.
36a0: 20 20 20 20 6e 53 72 63 50 61 67 65 20 3d 20 28 nSrcPage = (
36b0: 69 6e 74 29 73 71 6c 69 74 65 33 42 74 72 65 65 int)sqlite3Btree
36c0: 4c 61 73 74 50 61 67 65 28 70 2d 3e 70 53 72 63 LastPage(p->pSrc
36d0: 29 3b 0a 20 20 20 20 61 73 73 65 72 74 28 20 6e );. assert( n
36e0: 53 72 63 50 61 67 65 3e 3d 30 20 29 3b 0a 20 20 SrcPage>=0 );.
36f0: 20 20 66 6f 72 28 69 69 3d 30 3b 20 28 6e 50 61 for(ii=0; (nPa
3700: 67 65 3c 30 20 7c 7c 20 69 69 3c 6e 50 61 67 65 ge<0 || ii<nPage
3710: 29 20 26 26 20 70 2d 3e 69 4e 65 78 74 3c 3d 28 ) && p->iNext<=(
3720: 50 67 6e 6f 29 6e 53 72 63 50 61 67 65 20 26 26 Pgno)nSrcPage &&
3730: 20 21 72 63 3b 20 69 69 2b 2b 29 7b 0a 20 20 20 !rc; ii++){.
3740: 20 20 20 63 6f 6e 73 74 20 50 67 6e 6f 20 69 53 const Pgno iS
3750: 72 63 50 67 20 3d 20 70 2d 3e 69 4e 65 78 74 3b rcPg = p->iNext;
3760: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
3770: 20 2f 2a 20 53 6f 75 72 63 65 20 70 61 67 65 20 /* Source page
3780: 6e 75 6d 62 65 72 20 2a 2f 0a 20 20 20 20 20 20 number */.
3790: 69 66 28 20 69 53 72 63 50 67 21 3d 50 45 4e 44 if( iSrcPg!=PEND
37a0: 49 4e 47 5f 42 59 54 45 5f 50 41 47 45 28 70 2d ING_BYTE_PAGE(p-
37b0: 3e 70 53 72 63 2d 3e 70 42 74 29 20 29 7b 0a 20 >pSrc->pBt) ){.
37c0: 20 20 20 20 20 20 20 44 62 50 61 67 65 20 2a 70 DbPage *p
37d0: 53 72 63 50 67 3b 20 20 20 20 20 20 20 20 20 20 SrcPg;
37e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
37f0: 20 20 20 2f 2a 20 53 6f 75 72 63 65 20 70 61 67 /* Source pag
3800: 65 20 6f 62 6a 65 63 74 20 2a 2f 0a 20 20 20 20 e object */.
3810: 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 rc = sqlite3
3820: 50 61 67 65 72 41 63 71 75 69 72 65 28 70 53 72 PagerAcquire(pSr
3830: 63 50 61 67 65 72 2c 20 69 53 72 63 50 67 2c 20 cPager, iSrcPg,
3840: 26 70 53 72 63 50 67 2c 0a 20 20 20 20 20 20 20 &pSrcPg,.
3850: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
3860: 20 20 20 20 20 20 20 20 20 20 50 41 47 45 52 5f PAGER_
3870: 47 45 54 5f 52 45 41 44 4f 4e 4c 59 29 3b 0a 20 GET_READONLY);.
3880: 20 20 20 20 20 20 20 69 66 28 20 72 63 3d 3d 53 if( rc==S
3890: 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 QLITE_OK ){.
38a0: 20 20 20 20 20 20 72 63 20 3d 20 62 61 63 6b 75 rc = backu
38b0: 70 4f 6e 65 50 61 67 65 28 70 2c 20 69 53 72 63 pOnePage(p, iSrc
38c0: 50 67 2c 20 73 71 6c 69 74 65 33 50 61 67 65 72 Pg, sqlite3Pager
38d0: 47 65 74 44 61 74 61 28 70 53 72 63 50 67 29 2c GetData(pSrcPg),
38e0: 20 30 29 3b 0a 20 20 20 20 20 20 20 20 20 20 73 0);. s
38f0: 71 6c 69 74 65 33 50 61 67 65 72 55 6e 72 65 66 qlite3PagerUnref
3900: 28 70 53 72 63 50 67 29 3b 0a 20 20 20 20 20 20 (pSrcPg);.
3910: 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 }. }.
3920: 20 20 70 2d 3e 69 4e 65 78 74 2b 2b 3b 0a 20 20 p->iNext++;.
3930: 20 20 7d 0a 20 20 20 20 69 66 28 20 72 63 3d 3d }. if( rc==
3940: 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 SQLITE_OK ){.
3950: 20 20 20 70 2d 3e 6e 50 61 67 65 63 6f 75 6e 74 p->nPagecount
3960: 20 3d 20 6e 53 72 63 50 61 67 65 3b 0a 20 20 20 = nSrcPage;.
3970: 20 20 20 70 2d 3e 6e 52 65 6d 61 69 6e 69 6e 67 p->nRemaining
3980: 20 3d 20 6e 53 72 63 50 61 67 65 2b 31 2d 70 2d = nSrcPage+1-p-
3990: 3e 69 4e 65 78 74 3b 0a 20 20 20 20 20 20 69 66 >iNext;. if
39a0: 28 20 70 2d 3e 69 4e 65 78 74 3e 28 50 67 6e 6f ( p->iNext>(Pgno
39b0: 29 6e 53 72 63 50 61 67 65 20 29 7b 0a 20 20 20 )nSrcPage ){.
39c0: 20 20 20 20 20 72 63 20 3d 20 53 51 4c 49 54 45 rc = SQLITE
39d0: 5f 44 4f 4e 45 3b 0a 20 20 20 20 20 20 7d 65 6c _DONE;. }el
39e0: 73 65 20 69 66 28 20 21 70 2d 3e 69 73 41 74 74 se if( !p->isAtt
39f0: 61 63 68 65 64 20 29 7b 0a 20 20 20 20 20 20 20 ached ){.
3a00: 20 61 74 74 61 63 68 42 61 63 6b 75 70 4f 62 6a attachBackupObj
3a10: 65 63 74 28 70 29 3b 0a 20 20 20 20 20 20 7d 0a ect(p);. }.
3a20: 20 20 20 20 7d 0a 20 20 0a 20 20 20 20 2f 2a 20 }. . /*
3a30: 55 70 64 61 74 65 20 74 68 65 20 73 63 68 65 6d Update the schem
3a40: 61 20 76 65 72 73 69 6f 6e 20 66 69 65 6c 64 20 a version field
3a50: 69 6e 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 in the destinati
3a60: 6f 6e 20 64 61 74 61 62 61 73 65 2e 20 54 68 69 on database. Thi
3a70: 73 0a 20 20 20 20 2a 2a 20 69 73 20 74 6f 20 6d s. ** is to m
3a80: 61 6b 65 20 73 75 72 65 20 74 68 61 74 20 74 68 ake sure that th
3a90: 65 20 73 63 68 65 6d 61 2d 76 65 72 73 69 6f 6e e schema-version
3aa0: 20 72 65 61 6c 6c 79 20 64 6f 65 73 20 63 68 61 really does cha
3ab0: 6e 67 65 20 69 6e 0a 20 20 20 20 2a 2a 20 74 68 nge in. ** th
3ac0: 65 20 63 61 73 65 20 77 68 65 72 65 20 74 68 65 e case where the
3ad0: 20 73 6f 75 72 63 65 20 61 6e 64 20 64 65 73 74 source and dest
3ae0: 69 6e 61 74 69 6f 6e 20 64 61 74 61 62 61 73 65 ination database
3af0: 73 20 68 61 76 65 20 74 68 65 0a 20 20 20 20 2a s have the. *
3b00: 2a 20 73 61 6d 65 20 73 63 68 65 6d 61 20 76 65 * same schema ve
3b10: 72 73 69 6f 6e 2e 0a 20 20 20 20 2a 2f 0a 20 20 rsion.. */.
3b20: 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 if( rc==SQLITE
3b30: 5f 44 4f 4e 45 20 29 7b 0a 20 20 20 20 20 20 69 _DONE ){. i
3b40: 66 28 20 6e 53 72 63 50 61 67 65 3d 3d 30 20 29 f( nSrcPage==0 )
3b50: 7b 0a 20 20 20 20 20 20 20 20 72 63 20 3d 20 73 {. rc = s
3b60: 71 6c 69 74 65 33 42 74 72 65 65 4e 65 77 44 62 qlite3BtreeNewDb
3b70: 28 70 2d 3e 70 44 65 73 74 29 3b 0a 20 20 20 20 (p->pDest);.
3b80: 20 20 20 20 6e 53 72 63 50 61 67 65 20 3d 20 31 nSrcPage = 1
3b90: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 ;. }.
3ba0: 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 5f 4f if( rc==SQLITE_O
3bb0: 4b 20 7c 7c 20 72 63 3d 3d 53 51 4c 49 54 45 5f K || rc==SQLITE_
3bc0: 44 4f 4e 45 20 29 7b 0a 20 20 20 20 20 20 20 20 DONE ){.
3bd0: 72 63 20 3d 20 73 71 6c 69 74 65 33 42 74 72 65 rc = sqlite3Btre
3be0: 65 55 70 64 61 74 65 4d 65 74 61 28 70 2d 3e 70 eUpdateMeta(p->p
3bf0: 44 65 73 74 2c 31 2c 70 2d 3e 69 44 65 73 74 53 Dest,1,p->iDestS
3c00: 63 68 65 6d 61 2b 31 29 3b 0a 20 20 20 20 20 20 chema+1);.
3c10: 7d 0a 20 20 20 20 20 20 69 66 28 20 72 63 3d 3d }. if( rc==
3c20: 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 SQLITE_OK ){.
3c30: 20 20 20 20 20 69 66 28 20 70 2d 3e 70 44 65 73 if( p->pDes
3c40: 74 44 62 20 29 7b 0a 20 20 20 20 20 20 20 20 20 tDb ){.
3c50: 20 73 71 6c 69 74 65 33 52 65 73 65 74 41 6c 6c sqlite3ResetAll
3c60: 53 63 68 65 6d 61 73 4f 66 43 6f 6e 6e 65 63 74 SchemasOfConnect
3c70: 69 6f 6e 28 70 2d 3e 70 44 65 73 74 44 62 29 3b ion(p->pDestDb);
3c80: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20 . }.
3c90: 20 20 20 69 66 28 20 64 65 73 74 4d 6f 64 65 3d if( destMode=
3ca0: 3d 50 41 47 45 52 5f 4a 4f 55 52 4e 41 4c 4d 4f =PAGER_JOURNALMO
3cb0: 44 45 5f 57 41 4c 20 29 7b 0a 20 20 20 20 20 20 DE_WAL ){.
3cc0: 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 rc = sqlite3
3cd0: 42 74 72 65 65 53 65 74 56 65 72 73 69 6f 6e 28 BtreeSetVersion(
3ce0: 70 2d 3e 70 44 65 73 74 2c 20 32 29 3b 0a 20 20 p->pDest, 2);.
3cf0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a }. }.
3d00: 20 20 20 20 20 20 69 66 28 20 72 63 3d 3d 53 51 if( rc==SQ
3d10: 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 20 LITE_OK ){.
3d20: 20 20 20 69 6e 74 20 6e 44 65 73 74 54 72 75 6e int nDestTrun
3d30: 63 61 74 65 3b 0a 20 20 20 20 20 20 20 20 2f 2a cate;. /*
3d40: 20 53 65 74 20 6e 44 65 73 74 54 72 75 6e 63 61 Set nDestTrunca
3d50: 74 65 20 74 6f 20 74 68 65 20 66 69 6e 61 6c 20 te to the final
3d60: 6e 75 6d 62 65 72 20 6f 66 20 70 61 67 65 73 20 number of pages
3d70: 69 6e 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 in the destinati
3d80: 6f 6e 0a 20 20 20 20 20 20 20 20 2a 2a 20 64 61 on. ** da
3d90: 74 61 62 61 73 65 2e 20 54 68 65 20 63 6f 6d 70 tabase. The comp
3da0: 6c 69 63 61 74 69 6f 6e 20 68 65 72 65 20 69 73 lication here is
3db0: 20 74 68 61 74 20 74 68 65 20 64 65 73 74 69 6e that the destin
3dc0: 61 74 69 6f 6e 20 70 61 67 65 0a 20 20 20 20 20 ation page.
3dd0: 20 20 20 2a 2a 20 73 69 7a 65 20 6d 61 79 20 62 ** size may b
3de0: 65 20 64 69 66 66 65 72 65 6e 74 20 74 6f 20 74 e different to t
3df0: 68 65 20 73 6f 75 72 63 65 20 70 61 67 65 20 73 he source page s
3e00: 69 7a 65 2e 20 0a 20 20 20 20 20 20 20 20 2a 2a ize. . **
3e10: 0a 20 20 20 20 20 20 20 20 2a 2a 20 49 66 20 74 . ** If t
3e20: 68 65 20 73 6f 75 72 63 65 20 70 61 67 65 20 73 he source page s
3e30: 69 7a 65 20 69 73 20 73 6d 61 6c 6c 65 72 20 74 ize is smaller t
3e40: 68 61 6e 20 74 68 65 20 64 65 73 74 69 6e 61 74 han the destinat
3e50: 69 6f 6e 20 70 61 67 65 20 73 69 7a 65 2c 20 0a ion page size, .
3e60: 20 20 20 20 20 20 20 20 2a 2a 20 72 6f 75 6e 64 ** round
3e70: 20 75 70 2e 20 49 6e 20 74 68 69 73 20 63 61 73 up. In this cas
3e80: 65 20 74 68 65 20 63 61 6c 6c 20 74 6f 20 73 71 e the call to sq
3e90: 6c 69 74 65 33 4f 73 54 72 75 6e 63 61 74 65 28 lite3OsTruncate(
3ea0: 29 20 62 65 6c 6f 77 20 77 69 6c 6c 0a 20 20 20 ) below will.
3eb0: 20 20 20 20 20 2a 2a 20 66 69 78 20 74 68 65 20 ** fix the
3ec0: 73 69 7a 65 20 6f 66 20 74 68 65 20 66 69 6c 65 size of the file
3ed0: 2e 20 48 6f 77 65 76 65 72 20 69 74 20 69 73 20 . However it is
3ee0: 69 6d 70 6f 72 74 61 6e 74 20 74 6f 20 63 61 6c important to cal
3ef0: 6c 0a 20 20 20 20 20 20 20 20 2a 2a 20 73 71 6c l. ** sql
3f00: 69 74 65 33 50 61 67 65 72 54 72 75 6e 63 61 74 ite3PagerTruncat
3f10: 65 49 6d 61 67 65 28 29 20 68 65 72 65 20 73 6f eImage() here so
3f20: 20 74 68 61 74 20 61 6e 79 20 70 61 67 65 73 20 that any pages
3f30: 69 6e 20 74 68 65 20 0a 20 20 20 20 20 20 20 20 in the .
3f40: 2a 2a 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 66 ** destination f
3f50: 69 6c 65 20 74 68 61 74 20 6c 69 65 20 62 65 79 ile that lie bey
3f60: 6f 6e 64 20 74 68 65 20 6e 44 65 73 74 54 72 75 ond the nDestTru
3f70: 6e 63 61 74 65 20 70 61 67 65 20 6d 61 72 6b 20 ncate page mark
3f80: 61 72 65 0a 20 20 20 20 20 20 20 20 2a 2a 20 6a are. ** j
3f90: 6f 75 72 6e 61 6c 6c 65 64 20 62 79 20 50 61 67 ournalled by Pag
3fa0: 65 72 43 6f 6d 6d 69 74 50 68 61 73 65 4f 6e 65 erCommitPhaseOne
3fb0: 28 29 20 62 65 66 6f 72 65 20 74 68 65 79 20 61 () before they a
3fc0: 72 65 20 64 65 73 74 72 6f 79 65 64 0a 20 20 20 re destroyed.
3fd0: 20 20 20 20 20 2a 2a 20 62 79 20 74 68 65 20 66 ** by the f
3fe0: 69 6c 65 20 74 72 75 6e 63 61 74 69 6f 6e 2e 0a ile truncation..
3ff0: 20 20 20 20 20 20 20 20 2a 2f 0a 20 20 20 20 20 */.
4000: 20 20 20 61 73 73 65 72 74 28 20 70 67 73 7a 53 assert( pgszS
4010: 72 63 3d 3d 73 71 6c 69 74 65 33 42 74 72 65 65 rc==sqlite3Btree
4020: 47 65 74 50 61 67 65 53 69 7a 65 28 70 2d 3e 70 GetPageSize(p->p
4030: 53 72 63 29 20 29 3b 0a 20 20 20 20 20 20 20 20 Src) );.
4040: 61 73 73 65 72 74 28 20 70 67 73 7a 44 65 73 74 assert( pgszDest
4050: 3d 3d 73 71 6c 69 74 65 33 42 74 72 65 65 47 65 ==sqlite3BtreeGe
4060: 74 50 61 67 65 53 69 7a 65 28 70 2d 3e 70 44 65 tPageSize(p->pDe
4070: 73 74 29 20 29 3b 0a 20 20 20 20 20 20 20 20 69 st) );. i
4080: 66 28 20 70 67 73 7a 53 72 63 3c 70 67 73 7a 44 f( pgszSrc<pgszD
4090: 65 73 74 20 29 7b 0a 20 20 20 20 20 20 20 20 20 est ){.
40a0: 20 69 6e 74 20 72 61 74 69 6f 20 3d 20 70 67 73 int ratio = pgs
40b0: 7a 44 65 73 74 2f 70 67 73 7a 53 72 63 3b 0a 20 zDest/pgszSrc;.
40c0: 20 20 20 20 20 20 20 20 20 6e 44 65 73 74 54 72 nDestTr
40d0: 75 6e 63 61 74 65 20 3d 20 28 6e 53 72 63 50 61 uncate = (nSrcPa
40e0: 67 65 2b 72 61 74 69 6f 2d 31 29 2f 72 61 74 69 ge+ratio-1)/rati
40f0: 6f 3b 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 o;. if(
4100: 20 6e 44 65 73 74 54 72 75 6e 63 61 74 65 3d 3d nDestTruncate==
4110: 28 69 6e 74 29 50 45 4e 44 49 4e 47 5f 42 59 54 (int)PENDING_BYT
4120: 45 5f 50 41 47 45 28 70 2d 3e 70 44 65 73 74 2d E_PAGE(p->pDest-
4130: 3e 70 42 74 29 20 29 7b 0a 20 20 20 20 20 20 20 >pBt) ){.
4140: 20 20 20 20 20 6e 44 65 73 74 54 72 75 6e 63 61 nDestTrunca
4150: 74 65 2d 2d 3b 0a 20 20 20 20 20 20 20 20 20 20 te--;.
4160: 7d 0a 20 20 20 20 20 20 20 20 7d 65 6c 73 65 7b }. }else{
4170: 0a 20 20 20 20 20 20 20 20 20 20 6e 44 65 73 74 . nDest
4180: 54 72 75 6e 63 61 74 65 20 3d 20 6e 53 72 63 50 Truncate = nSrcP
4190: 61 67 65 20 2a 20 28 70 67 73 7a 53 72 63 2f 70 age * (pgszSrc/p
41a0: 67 73 7a 44 65 73 74 29 3b 0a 20 20 20 20 20 20 gszDest);.
41b0: 20 20 7d 0a 20 20 20 20 20 20 20 20 61 73 73 65 }. asse
41c0: 72 74 28 20 6e 44 65 73 74 54 72 75 6e 63 61 74 rt( nDestTruncat
41d0: 65 3e 30 20 29 3b 0a 0a 20 20 20 20 20 20 20 20 e>0 );..
41e0: 69 66 28 20 70 67 73 7a 53 72 63 3c 70 67 73 7a if( pgszSrc<pgsz
41f0: 44 65 73 74 20 29 7b 0a 20 20 20 20 20 20 20 20 Dest ){.
4200: 20 20 2f 2a 20 49 66 20 74 68 65 20 73 6f 75 72 /* If the sour
4210: 63 65 20 70 61 67 65 2d 73 69 7a 65 20 69 73 20 ce page-size is
4220: 73 6d 61 6c 6c 65 72 20 74 68 61 6e 20 74 68 65 smaller than the
4230: 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 70 61 67 destination pag
4240: 65 2d 73 69 7a 65 2c 0a 20 20 20 20 20 20 20 20 e-size,.
4250: 20 20 2a 2a 20 74 77 6f 20 65 78 74 72 61 20 74 ** two extra t
4260: 68 69 6e 67 73 20 6d 61 79 20 6e 65 65 64 20 74 hings may need t
4270: 6f 20 68 61 70 70 65 6e 3a 0a 20 20 20 20 20 20 o happen:.
4280: 20 20 20 20 2a 2a 0a 20 20 20 20 20 20 20 20 20 **.
4290: 20 2a 2a 20 20 20 2a 20 54 68 65 20 64 65 73 74 ** * The dest
42a0: 69 6e 61 74 69 6f 6e 20 6d 61 79 20 6e 65 65 64 ination may need
42b0: 20 74 6f 20 62 65 20 74 72 75 6e 63 61 74 65 64 to be truncated
42c0: 2c 20 61 6e 64 0a 20 20 20 20 20 20 20 20 20 20 , and.
42d0: 2a 2a 0a 20 20 20 20 20 20 20 20 20 20 2a 2a 20 **. **
42e0: 20 20 2a 20 44 61 74 61 20 73 74 6f 72 65 64 20 * Data stored
42f0: 6f 6e 20 74 68 65 20 70 61 67 65 73 20 69 6d 6d on the pages imm
4300: 65 64 69 61 74 65 6c 79 20 66 6f 6c 6c 6f 77 69 ediately followi
4310: 6e 67 20 74 68 65 20 0a 20 20 20 20 20 20 20 20 ng the .
4320: 20 20 2a 2a 20 20 20 20 20 70 65 6e 64 69 6e 67 ** pending
4330: 2d 62 79 74 65 20 70 61 67 65 20 69 6e 20 74 68 -byte page in th
4340: 65 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73 e source databas
4350: 65 20 6d 61 79 20 6e 65 65 64 20 74 6f 20 62 65 e may need to be
4360: 0a 20 20 20 20 20 20 20 20 20 20 2a 2a 20 20 20 . **
4370: 20 20 63 6f 70 69 65 64 20 69 6e 74 6f 20 74 68 copied into th
4380: 65 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 64 61 e destination da
4390: 74 61 62 61 73 65 2e 0a 20 20 20 20 20 20 20 20 tabase..
43a0: 20 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 63 */. c
43b0: 6f 6e 73 74 20 69 36 34 20 69 53 69 7a 65 20 3d onst i64 iSize =
43c0: 20 28 69 36 34 29 70 67 73 7a 53 72 63 20 2a 20 (i64)pgszSrc *
43d0: 28 69 36 34 29 6e 53 72 63 50 61 67 65 3b 0a 20 (i64)nSrcPage;.
43e0: 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 33 sqlite3
43f0: 5f 66 69 6c 65 20 2a 20 63 6f 6e 73 74 20 70 46 _file * const pF
4400: 69 6c 65 20 3d 20 73 71 6c 69 74 65 33 50 61 67 ile = sqlite3Pag
4410: 65 72 46 69 6c 65 28 70 44 65 73 74 50 61 67 65 erFile(pDestPage
4420: 72 29 3b 0a 20 20 20 20 20 20 20 20 20 20 50 67 r);. Pg
4430: 6e 6f 20 69 50 67 3b 0a 20 20 20 20 20 20 20 20 no iPg;.
4440: 20 20 69 6e 74 20 6e 44 73 74 50 61 67 65 3b 0a int nDstPage;.
4450: 20 20 20 20 20 20 20 20 20 20 69 36 34 20 69 4f i64 iO
4460: 66 66 3b 0a 20 20 20 20 20 20 20 20 20 20 69 36 ff;. i6
4470: 34 20 69 45 6e 64 3b 0a 0a 20 20 20 20 20 20 20 4 iEnd;..
4480: 20 20 20 61 73 73 65 72 74 28 20 70 46 69 6c 65 assert( pFile
4490: 20 29 3b 0a 20 20 20 20 20 20 20 20 20 20 61 73 );. as
44a0: 73 65 72 74 28 20 6e 44 65 73 74 54 72 75 6e 63 sert( nDestTrunc
44b0: 61 74 65 3d 3d 30 20 0a 20 20 20 20 20 20 20 20 ate==0 .
44c0: 20 20 20 20 20 20 7c 7c 20 28 69 36 34 29 6e 44 || (i64)nD
44d0: 65 73 74 54 72 75 6e 63 61 74 65 2a 28 69 36 34 estTruncate*(i64
44e0: 29 70 67 73 7a 44 65 73 74 20 3e 3d 20 69 53 69 )pgszDest >= iSi
44f0: 7a 65 20 7c 7c 20 28 0a 20 20 20 20 20 20 20 20 ze || (.
4500: 20 20 20 20 20 20 20 20 6e 44 65 73 74 54 72 75 nDestTru
4510: 6e 63 61 74 65 3d 3d 28 69 6e 74 29 28 50 45 4e ncate==(int)(PEN
4520: 44 49 4e 47 5f 42 59 54 45 5f 50 41 47 45 28 70 DING_BYTE_PAGE(p
4530: 2d 3e 70 44 65 73 74 2d 3e 70 42 74 29 2d 31 29 ->pDest->pBt)-1)
4540: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 26 26 . &&
4550: 20 69 53 69 7a 65 3e 3d 50 45 4e 44 49 4e 47 5f iSize>=PENDING_
4560: 42 59 54 45 20 26 26 20 69 53 69 7a 65 3c 3d 50 BYTE && iSize<=P
4570: 45 4e 44 49 4e 47 5f 42 59 54 45 2b 70 67 73 7a ENDING_BYTE+pgsz
4580: 44 65 73 74 0a 20 20 20 20 20 20 20 20 20 20 29 Dest. )
4590: 29 3b 0a 0a 20 20 20 20 20 20 20 20 20 20 2f 2a );.. /*
45a0: 20 54 68 69 73 20 62 6c 6f 63 6b 20 65 6e 73 75 This block ensu
45b0: 72 65 73 20 74 68 61 74 20 61 6c 6c 20 64 61 74 res that all dat
45c0: 61 20 72 65 71 75 69 72 65 64 20 74 6f 20 72 65 a required to re
45d0: 63 72 65 61 74 65 20 74 68 65 20 6f 72 69 67 69 create the origi
45e0: 6e 61 6c 0a 20 20 20 20 20 20 20 20 20 20 2a 2a nal. **
45f0: 20 64 61 74 61 62 61 73 65 20 68 61 73 20 62 65 database has be
4600: 65 6e 20 73 74 6f 72 65 64 20 69 6e 20 74 68 65 en stored in the
4610: 20 6a 6f 75 72 6e 61 6c 20 66 6f 72 20 70 44 65 journal for pDe
4620: 73 74 50 61 67 65 72 20 61 6e 64 20 74 68 65 0a stPager and the.
4630: 20 20 20 20 20 20 20 20 20 20 2a 2a 20 6a 6f 75 ** jou
4640: 72 6e 61 6c 20 73 79 6e 63 65 64 20 74 6f 20 64 rnal synced to d
4650: 69 73 6b 2e 20 53 6f 20 61 74 20 74 68 69 73 20 isk. So at this
4660: 70 6f 69 6e 74 20 77 65 20 6d 61 79 20 73 61 66 point we may saf
4670: 65 6c 79 20 6d 6f 64 69 66 79 0a 20 20 20 20 20 ely modify.
4680: 20 20 20 20 20 2a 2a 20 74 68 65 20 64 61 74 61 ** the data
4690: 62 61 73 65 20 66 69 6c 65 20 69 6e 20 61 6e 79 base file in any
46a0: 20 77 61 79 2c 20 6b 6e 6f 77 69 6e 67 20 74 68 way, knowing th
46b0: 61 74 20 69 66 20 61 20 70 6f 77 65 72 20 66 61 at if a power fa
46c0: 69 6c 75 72 65 0a 20 20 20 20 20 20 20 20 20 20 ilure.
46d0: 2a 2a 20 6f 63 63 75 72 73 2c 20 74 68 65 20 6f ** occurs, the o
46e0: 72 69 67 69 6e 61 6c 20 64 61 74 61 62 61 73 65 riginal database
46f0: 20 77 69 6c 6c 20 62 65 20 72 65 63 6f 6e 73 74 will be reconst
4700: 72 75 63 74 65 64 20 66 72 6f 6d 20 74 68 65 20 ructed from the
4710: 0a 20 20 20 20 20 20 20 20 20 20 2a 2a 20 6a 6f . ** jo
4720: 75 72 6e 61 6c 20 66 69 6c 65 2e 20 20 2a 2f 0a urnal file. */.
4730: 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 sqlite
4740: 33 50 61 67 65 72 50 61 67 65 63 6f 75 6e 74 28 3PagerPagecount(
4750: 70 44 65 73 74 50 61 67 65 72 2c 20 26 6e 44 73 pDestPager, &nDs
4760: 74 50 61 67 65 29 3b 0a 20 20 20 20 20 20 20 20 tPage);.
4770: 20 20 66 6f 72 28 69 50 67 3d 6e 44 65 73 74 54 for(iPg=nDestT
4780: 72 75 6e 63 61 74 65 3b 20 72 63 3d 3d 53 51 4c runcate; rc==SQL
4790: 49 54 45 5f 4f 4b 20 26 26 20 69 50 67 3c 3d 28 ITE_OK && iPg<=(
47a0: 50 67 6e 6f 29 6e 44 73 74 50 61 67 65 3b 20 69 Pgno)nDstPage; i
47b0: 50 67 2b 2b 29 7b 0a 20 20 20 20 20 20 20 20 20 Pg++){.
47c0: 20 20 20 69 66 28 20 69 50 67 21 3d 50 45 4e 44 if( iPg!=PEND
47d0: 49 4e 47 5f 42 59 54 45 5f 50 41 47 45 28 70 2d ING_BYTE_PAGE(p-
47e0: 3e 70 44 65 73 74 2d 3e 70 42 74 29 20 29 7b 0a >pDest->pBt) ){.
47f0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 44 62 Db
4800: 50 61 67 65 20 2a 70 50 67 3b 0a 20 20 20 20 20 Page *pPg;.
4810: 20 20 20 20 20 20 20 20 20 72 63 20 3d 20 73 71 rc = sq
4820: 6c 69 74 65 33 50 61 67 65 72 47 65 74 28 70 44 lite3PagerGet(pD
4830: 65 73 74 50 61 67 65 72 2c 20 69 50 67 2c 20 26 estPager, iPg, &
4840: 70 50 67 29 3b 0a 20 20 20 20 20 20 20 20 20 20 pPg);.
4850: 20 20 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 if( rc==SQLI
4860: 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 20 20 20 TE_OK ){.
4870: 20 20 20 20 20 20 20 20 20 72 63 20 3d 20 73 71 rc = sq
4880: 6c 69 74 65 33 50 61 67 65 72 57 72 69 74 65 28 lite3PagerWrite(
4890: 70 50 67 29 3b 0a 20 20 20 20 20 20 20 20 20 20 pPg);.
48a0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 50 61 67 sqlite3Pag
48b0: 65 72 55 6e 72 65 66 28 70 50 67 29 3b 0a 20 20 erUnref(pPg);.
48c0: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 }.
48d0: 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 }.
48e0: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 20 20 }.
48f0: 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 if( rc==SQLITE
4900: 5f 4f 4b 20 29 7b 0a 20 20 20 20 20 20 20 20 20 _OK ){.
4910: 20 20 20 72 63 20 3d 20 73 71 6c 69 74 65 33 50 rc = sqlite3P
4920: 61 67 65 72 43 6f 6d 6d 69 74 50 68 61 73 65 4f agerCommitPhaseO
4930: 6e 65 28 70 44 65 73 74 50 61 67 65 72 2c 20 30 ne(pDestPager, 0
4940: 2c 20 31 29 3b 0a 20 20 20 20 20 20 20 20 20 20 , 1);.
4950: 7d 0a 0a 20 20 20 20 20 20 20 20 20 20 2f 2a 20 }.. /*
4960: 57 72 69 74 65 20 74 68 65 20 65 78 74 72 61 20 Write the extra
4970: 70 61 67 65 73 20 61 6e 64 20 74 72 75 6e 63 61 pages and trunca
4980: 74 65 20 74 68 65 20 64 61 74 61 62 61 73 65 20 te the database
4990: 66 69 6c 65 20 61 73 20 72 65 71 75 69 72 65 64 file as required
49a0: 20 2a 2f 0a 20 20 20 20 20 20 20 20 20 20 69 45 */. iE
49b0: 6e 64 20 3d 20 4d 49 4e 28 50 45 4e 44 49 4e 47 nd = MIN(PENDING
49c0: 5f 42 59 54 45 20 2b 20 70 67 73 7a 44 65 73 74 _BYTE + pgszDest
49d0: 2c 20 69 53 69 7a 65 29 3b 0a 20 20 20 20 20 20 , iSize);.
49e0: 20 20 20 20 66 6f 72 28 0a 20 20 20 20 20 20 20 for(.
49f0: 20 20 20 20 20 69 4f 66 66 3d 50 45 4e 44 49 4e iOff=PENDIN
4a00: 47 5f 42 59 54 45 2b 70 67 73 7a 53 72 63 3b 20 G_BYTE+pgszSrc;
4a10: 0a 20 20 20 20 20 20 20 20 20 20 20 20 72 63 3d . rc=
4a20: 3d 53 51 4c 49 54 45 5f 4f 4b 20 26 26 20 69 4f =SQLITE_OK && iO
4a30: 66 66 3c 69 45 6e 64 3b 20 0a 20 20 20 20 20 20 ff<iEnd; .
4a40: 20 20 20 20 20 20 69 4f 66 66 2b 3d 70 67 73 7a iOff+=pgsz
4a50: 53 72 63 0a 20 20 20 20 20 20 20 20 20 20 29 7b Src. ){
4a60: 0a 20 20 20 20 20 20 20 20 20 20 20 20 50 67 48 . PgH
4a70: 64 72 20 2a 70 53 72 63 50 67 20 3d 20 30 3b 0a dr *pSrcPg = 0;.
4a80: 20 20 20 20 20 20 20 20 20 20 20 20 63 6f 6e 73 cons
4a90: 74 20 50 67 6e 6f 20 69 53 72 63 50 67 20 3d 20 t Pgno iSrcPg =
4aa0: 28 50 67 6e 6f 29 28 28 69 4f 66 66 2f 70 67 73 (Pgno)((iOff/pgs
4ab0: 7a 53 72 63 29 2b 31 29 3b 0a 20 20 20 20 20 20 zSrc)+1);.
4ac0: 20 20 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 rc = sqlit
4ad0: 65 33 50 61 67 65 72 47 65 74 28 70 53 72 63 50 e3PagerGet(pSrcP
4ae0: 61 67 65 72 2c 20 69 53 72 63 50 67 2c 20 26 70 ager, iSrcPg, &p
4af0: 53 72 63 50 67 29 3b 0a 20 20 20 20 20 20 20 20 SrcPg);.
4b00: 20 20 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 if( rc==SQLI
4b10: 54 45 5f 4f 4b 20 29 7b 0a 20 20 20 20 20 20 20 TE_OK ){.
4b20: 20 20 20 20 20 20 20 75 38 20 2a 7a 44 61 74 61 u8 *zData
4b30: 20 3d 20 73 71 6c 69 74 65 33 50 61 67 65 72 47 = sqlite3PagerG
4b40: 65 74 44 61 74 61 28 70 53 72 63 50 67 29 3b 0a etData(pSrcPg);.
4b50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 72 63 rc
4b60: 20 3d 20 73 71 6c 69 74 65 33 4f 73 57 72 69 74 = sqlite3OsWrit
4b70: 65 28 70 46 69 6c 65 2c 20 7a 44 61 74 61 2c 20 e(pFile, zData,
4b80: 70 67 73 7a 53 72 63 2c 20 69 4f 66 66 29 3b 0a pgszSrc, iOff);.
4b90: 20 20 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 }.
4ba0: 20 20 20 20 20 20 20 20 20 20 73 71 6c 69 74 65 sqlite
4bb0: 33 50 61 67 65 72 55 6e 72 65 66 28 70 53 72 63 3PagerUnref(pSrc
4bc0: 50 67 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d Pg);. }
4bd0: 0a 20 20 20 20 20 20 20 20 20 20 69 66 28 20 72 . if( r
4be0: 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a c==SQLITE_OK ){.
4bf0: 20 20 20 20 20 20 20 20 20 20 20 20 72 63 20 3d rc =
4c00: 20 62 61 63 6b 75 70 54 72 75 6e 63 61 74 65 46 backupTruncateF
4c10: 69 6c 65 28 70 46 69 6c 65 2c 20 69 53 69 7a 65 ile(pFile, iSize
4c20: 29 3b 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 0a );. }..
4c30: 20 20 20 20 20 20 20 20 20 20 2f 2a 20 53 79 6e /* Syn
4c40: 63 20 74 68 65 20 64 61 74 61 62 61 73 65 20 66 c the database f
4c50: 69 6c 65 20 74 6f 20 64 69 73 6b 2e 20 2a 2f 0a ile to disk. */.
4c60: 20 20 20 20 20 20 20 20 20 20 69 66 28 20 72 63 if( rc
4c70: 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b 0a 20 ==SQLITE_OK ){.
4c80: 20 20 20 20 20 20 20 20 20 20 20 72 63 20 3d 20 rc =
4c90: 73 71 6c 69 74 65 33 50 61 67 65 72 53 79 6e 63 sqlite3PagerSync
4ca0: 28 70 44 65 73 74 50 61 67 65 72 2c 20 30 29 3b (pDestPager, 0);
4cb0: 0a 20 20 20 20 20 20 20 20 20 20 7d 0a 20 20 20 . }.
4cc0: 20 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 }else{.
4cd0: 20 20 20 20 20 20 73 71 6c 69 74 65 33 50 61 67 sqlite3Pag
4ce0: 65 72 54 72 75 6e 63 61 74 65 49 6d 61 67 65 28 erTruncateImage(
4cf0: 70 44 65 73 74 50 61 67 65 72 2c 20 6e 44 65 73 pDestPager, nDes
4d00: 74 54 72 75 6e 63 61 74 65 29 3b 0a 20 20 20 20 tTruncate);.
4d10: 20 20 20 20 20 20 72 63 20 3d 20 73 71 6c 69 74 rc = sqlit
4d20: 65 33 50 61 67 65 72 43 6f 6d 6d 69 74 50 68 61 e3PagerCommitPha
4d30: 73 65 4f 6e 65 28 70 44 65 73 74 50 61 67 65 72 seOne(pDestPager
4d40: 2c 20 30 2c 20 30 29 3b 0a 20 20 20 20 20 20 20 , 0, 0);.
4d50: 20 7d 0a 20 20 20 20 0a 20 20 20 20 20 20 20 20 }. .
4d60: 2f 2a 20 46 69 6e 69 73 68 20 63 6f 6d 6d 69 74 /* Finish commit
4d70: 74 69 6e 67 20 74 68 65 20 74 72 61 6e 73 61 63 ting the transac
4d80: 74 69 6f 6e 20 74 6f 20 74 68 65 20 64 65 73 74 tion to the dest
4d90: 69 6e 61 74 69 6f 6e 20 64 61 74 61 62 61 73 65 ination database
4da0: 2e 20 2a 2f 0a 20 20 20 20 20 20 20 20 69 66 28 . */. if(
4db0: 20 53 51 4c 49 54 45 5f 4f 4b 3d 3d 72 63 0a 20 SQLITE_OK==rc.
4dc0: 20 20 20 20 20 20 20 20 26 26 20 53 51 4c 49 54 && SQLIT
4dd0: 45 5f 4f 4b 3d 3d 28 72 63 20 3d 20 73 71 6c 69 E_OK==(rc = sqli
4de0: 74 65 33 42 74 72 65 65 43 6f 6d 6d 69 74 50 68 te3BtreeCommitPh
4df0: 61 73 65 54 77 6f 28 70 2d 3e 70 44 65 73 74 2c aseTwo(p->pDest,
4e00: 20 30 29 29 0a 20 20 20 20 20 20 20 20 29 7b 0a 0)). ){.
4e10: 20 20 20 20 20 20 20 20 20 20 72 63 20 3d 20 53 rc = S
4e20: 51 4c 49 54 45 5f 44 4f 4e 45 3b 0a 20 20 20 20 QLITE_DONE;.
4e30: 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 0a 20 20 }. }.
4e40: 20 20 7d 0a 20 20 0a 20 20 20 20 2f 2a 20 49 66 }. . /* If
4e50: 20 62 43 6c 6f 73 65 54 72 61 6e 73 20 69 73 20 bCloseTrans is
4e60: 74 72 75 65 2c 20 74 68 65 6e 20 74 68 69 73 20 true, then this
4e70: 66 75 6e 63 74 69 6f 6e 20 6f 70 65 6e 65 64 20 function opened
4e80: 61 20 72 65 61 64 20 74 72 61 6e 73 61 63 74 69 a read transacti
4e90: 6f 6e 0a 20 20 20 20 2a 2a 20 6f 6e 20 74 68 65 on. ** on the
4ea0: 20 73 6f 75 72 63 65 20 64 61 74 61 62 61 73 65 source database
4eb0: 2e 20 43 6c 6f 73 65 20 74 68 65 20 72 65 61 64 . Close the read
4ec0: 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 68 65 72 transaction her
4ed0: 65 2e 20 54 68 65 72 65 20 69 73 0a 20 20 20 20 e. There is.
4ee0: 2a 2a 20 6e 6f 20 6e 65 65 64 20 74 6f 20 63 68 ** no need to ch
4ef0: 65 63 6b 20 74 68 65 20 72 65 74 75 72 6e 20 76 eck the return v
4f00: 61 6c 75 65 73 20 6f 66 20 74 68 65 20 62 74 72 alues of the btr
4f10: 65 65 20 6d 65 74 68 6f 64 73 20 68 65 72 65 2c ee methods here,
4f20: 20 61 73 0a 20 20 20 20 2a 2a 20 22 63 6f 6d 6d as. ** "comm
4f30: 69 74 74 69 6e 67 22 20 61 20 72 65 61 64 2d 6f itting" a read-o
4f40: 6e 6c 79 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 nly transaction
4f50: 63 61 6e 6e 6f 74 20 66 61 69 6c 2e 0a 20 20 20 cannot fail..
4f60: 20 2a 2f 0a 20 20 20 20 69 66 28 20 62 43 6c 6f */. if( bClo
4f70: 73 65 54 72 61 6e 73 20 29 7b 0a 20 20 20 20 20 seTrans ){.
4f80: 20 54 45 53 54 4f 4e 4c 59 28 20 69 6e 74 20 72 TESTONLY( int r
4f90: 63 32 20 29 3b 0a 20 20 20 20 20 20 54 45 53 54 c2 );. TEST
4fa0: 4f 4e 4c 59 28 20 72 63 32 20 20 3d 20 29 20 73 ONLY( rc2 = ) s
4fb0: 71 6c 69 74 65 33 42 74 72 65 65 43 6f 6d 6d 69 qlite3BtreeCommi
4fc0: 74 50 68 61 73 65 4f 6e 65 28 70 2d 3e 70 53 72 tPhaseOne(p->pSr
4fd0: 63 2c 20 30 29 3b 0a 20 20 20 20 20 20 54 45 53 c, 0);. TES
4fe0: 54 4f 4e 4c 59 28 20 72 63 32 20 7c 3d 20 29 20 TONLY( rc2 |= )
4ff0: 73 71 6c 69 74 65 33 42 74 72 65 65 43 6f 6d 6d sqlite3BtreeComm
5000: 69 74 50 68 61 73 65 54 77 6f 28 70 2d 3e 70 53 itPhaseTwo(p->pS
5010: 72 63 2c 20 30 29 3b 0a 20 20 20 20 20 20 61 73 rc, 0);. as
5020: 73 65 72 74 28 20 72 63 32 3d 3d 53 51 4c 49 54 sert( rc2==SQLIT
5030: 45 5f 4f 4b 20 29 3b 0a 20 20 20 20 7d 0a 20 20 E_OK );. }.
5040: 0a 20 20 20 20 69 66 28 20 72 63 3d 3d 53 51 4c . if( rc==SQL
5050: 49 54 45 5f 49 4f 45 52 52 5f 4e 4f 4d 45 4d 20 ITE_IOERR_NOMEM
5060: 29 7b 0a 20 20 20 20 20 20 72 63 20 3d 20 53 51 ){. rc = SQ
5070: 4c 49 54 45 5f 4e 4f 4d 45 4d 3b 0a 20 20 20 20 LITE_NOMEM;.
5080: 7d 0a 20 20 20 20 70 2d 3e 72 63 20 3d 20 72 63 }. p->rc = rc
5090: 3b 0a 20 20 7d 0a 20 20 69 66 28 20 70 2d 3e 70 ;. }. if( p->p
50a0: 44 65 73 74 44 62 20 29 7b 0a 20 20 20 20 73 71 DestDb ){. sq
50b0: 6c 69 74 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 lite3_mutex_leav
50c0: 65 28 70 2d 3e 70 44 65 73 74 44 62 2d 3e 6d 75 e(p->pDestDb->mu
50d0: 74 65 78 29 3b 0a 20 20 7d 0a 20 20 73 71 6c 69 tex);. }. sqli
50e0: 74 65 33 42 74 72 65 65 4c 65 61 76 65 28 70 2d te3BtreeLeave(p-
50f0: 3e 70 53 72 63 29 3b 0a 20 20 73 71 6c 69 74 65 >pSrc);. sqlite
5100: 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 70 2d 3_mutex_leave(p-
5110: 3e 70 53 72 63 44 62 2d 3e 6d 75 74 65 78 29 3b >pSrcDb->mutex);
5120: 0a 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a . return rc;.}.
5130: 0a 2f 2a 0a 2a 2a 20 52 65 6c 65 61 73 65 20 61 ./*.** Release a
5140: 6c 6c 20 72 65 73 6f 75 72 63 65 73 20 61 73 73 ll resources ass
5150: 6f 63 69 61 74 65 64 20 77 69 74 68 20 61 6e 20 ociated with an
5160: 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 2a 20 sqlite3_backup*
5170: 68 61 6e 64 6c 65 2e 0a 2a 2f 0a 69 6e 74 20 73 handle..*/.int s
5180: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 66 69 qlite3_backup_fi
5190: 6e 69 73 68 28 73 71 6c 69 74 65 33 5f 62 61 63 nish(sqlite3_bac
51a0: 6b 75 70 20 2a 70 29 7b 0a 20 20 73 71 6c 69 74 kup *p){. sqlit
51b0: 65 33 5f 62 61 63 6b 75 70 20 2a 2a 70 70 3b 20 e3_backup **pp;
51c0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
51d0: 2f 2a 20 50 74 72 20 74 6f 20 68 65 61 64 20 6f /* Ptr to head o
51e0: 66 20 70 61 67 65 72 73 20 62 61 63 6b 75 70 20 f pagers backup
51f0: 6c 69 73 74 20 2a 2f 0a 20 20 73 71 6c 69 74 65 list */. sqlite
5200: 33 20 2a 70 53 72 63 44 62 3b 20 20 20 20 20 20 3 *pSrcDb;
5210: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f /
5220: 2a 20 53 6f 75 72 63 65 20 64 61 74 61 62 61 73 * Source databas
5230: 65 20 63 6f 6e 6e 65 63 74 69 6f 6e 20 2a 2f 0a e connection */.
5240: 20 20 69 6e 74 20 72 63 3b 20 20 20 20 20 20 20 int rc;
5250: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
5260: 20 20 20 20 20 20 20 2f 2a 20 56 61 6c 75 65 20 /* Value
5270: 74 6f 20 72 65 74 75 72 6e 20 2a 2f 0a 0a 20 20 to return */..
5280: 2f 2a 20 45 6e 74 65 72 20 74 68 65 20 6d 75 74 /* Enter the mut
5290: 65 78 65 73 20 2a 2f 0a 20 20 69 66 28 20 70 3d exes */. if( p=
52a0: 3d 30 20 29 20 72 65 74 75 72 6e 20 53 51 4c 49 =0 ) return SQLI
52b0: 54 45 5f 4f 4b 3b 0a 20 20 70 53 72 63 44 62 20 TE_OK;. pSrcDb
52c0: 3d 20 70 2d 3e 70 53 72 63 44 62 3b 0a 20 20 73 = p->pSrcDb;. s
52d0: 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74 qlite3_mutex_ent
52e0: 65 72 28 70 53 72 63 44 62 2d 3e 6d 75 74 65 78 er(pSrcDb->mutex
52f0: 29 3b 0a 20 20 73 71 6c 69 74 65 33 42 74 72 65 );. sqlite3Btre
5300: 65 45 6e 74 65 72 28 70 2d 3e 70 53 72 63 29 3b eEnter(p->pSrc);
5310: 0a 20 20 69 66 28 20 70 2d 3e 70 44 65 73 74 44 . if( p->pDestD
5320: 62 20 29 7b 0a 20 20 20 20 73 71 6c 69 74 65 33 b ){. sqlite3
5330: 5f 6d 75 74 65 78 5f 65 6e 74 65 72 28 70 2d 3e _mutex_enter(p->
5340: 70 44 65 73 74 44 62 2d 3e 6d 75 74 65 78 29 3b pDestDb->mutex);
5350: 0a 20 20 7d 0a 0a 20 20 2f 2a 20 44 65 74 61 63 . }.. /* Detac
5360: 68 20 74 68 69 73 20 62 61 63 6b 75 70 20 66 72 h this backup fr
5370: 6f 6d 20 74 68 65 20 73 6f 75 72 63 65 20 70 61 om the source pa
5380: 67 65 72 2e 20 2a 2f 0a 20 20 69 66 28 20 70 2d ger. */. if( p-
5390: 3e 70 44 65 73 74 44 62 20 29 7b 0a 20 20 20 20 >pDestDb ){.
53a0: 70 2d 3e 70 53 72 63 2d 3e 6e 42 61 63 6b 75 70 p->pSrc->nBackup
53b0: 2d 2d 3b 0a 20 20 7d 0a 20 20 69 66 28 20 70 2d --;. }. if( p-
53c0: 3e 69 73 41 74 74 61 63 68 65 64 20 29 7b 0a 20 >isAttached ){.
53d0: 20 20 20 70 70 20 3d 20 73 71 6c 69 74 65 33 50 pp = sqlite3P
53e0: 61 67 65 72 42 61 63 6b 75 70 50 74 72 28 73 71 agerBackupPtr(sq
53f0: 6c 69 74 65 33 42 74 72 65 65 50 61 67 65 72 28 lite3BtreePager(
5400: 70 2d 3e 70 53 72 63 29 29 3b 0a 20 20 20 20 77 p->pSrc));. w
5410: 68 69 6c 65 28 20 2a 70 70 21 3d 70 20 29 7b 0a hile( *pp!=p ){.
5420: 20 20 20 20 20 20 70 70 20 3d 20 26 28 2a 70 70 pp = &(*pp
5430: 29 2d 3e 70 4e 65 78 74 3b 0a 20 20 20 20 7d 0a )->pNext;. }.
5440: 20 20 20 20 2a 70 70 20 3d 20 70 2d 3e 70 4e 65 *pp = p->pNe
5450: 78 74 3b 0a 20 20 7d 0a 0a 20 20 2f 2a 20 49 66 xt;. }.. /* If
5460: 20 61 20 74 72 61 6e 73 61 63 74 69 6f 6e 20 69 a transaction i
5470: 73 20 73 74 69 6c 6c 20 6f 70 65 6e 20 6f 6e 20 s still open on
5480: 74 68 65 20 42 74 72 65 65 2c 20 72 6f 6c 6c 20 the Btree, roll
5490: 69 74 20 62 61 63 6b 2e 20 2a 2f 0a 20 20 73 71 it back. */. sq
54a0: 6c 69 74 65 33 42 74 72 65 65 52 6f 6c 6c 62 61 lite3BtreeRollba
54b0: 63 6b 28 70 2d 3e 70 44 65 73 74 2c 20 53 51 4c ck(p->pDest, SQL
54c0: 49 54 45 5f 4f 4b 29 3b 0a 0a 20 20 2f 2a 20 53 ITE_OK);.. /* S
54d0: 65 74 20 74 68 65 20 65 72 72 6f 72 20 63 6f 64 et the error cod
54e0: 65 20 6f 66 20 74 68 65 20 64 65 73 74 69 6e 61 e of the destina
54f0: 74 69 6f 6e 20 64 61 74 61 62 61 73 65 20 68 61 tion database ha
5500: 6e 64 6c 65 2e 20 2a 2f 0a 20 20 72 63 20 3d 20 ndle. */. rc =
5510: 28 70 2d 3e 72 63 3d 3d 53 51 4c 49 54 45 5f 44 (p->rc==SQLITE_D
5520: 4f 4e 45 29 20 3f 20 53 51 4c 49 54 45 5f 4f 4b ONE) ? SQLITE_OK
5530: 20 3a 20 70 2d 3e 72 63 3b 0a 20 20 69 66 28 20 : p->rc;. if(
5540: 70 2d 3e 70 44 65 73 74 44 62 20 29 7b 0a 20 20 p->pDestDb ){.
5550: 20 20 73 71 6c 69 74 65 33 45 72 72 6f 72 28 70 sqlite3Error(p
5560: 2d 3e 70 44 65 73 74 44 62 2c 20 72 63 29 3b 0a ->pDestDb, rc);.
5570: 0a 20 20 20 20 2f 2a 20 45 78 69 74 20 74 68 65 . /* Exit the
5580: 20 6d 75 74 65 78 65 73 20 61 6e 64 20 66 72 65 mutexes and fre
5590: 65 20 74 68 65 20 62 61 63 6b 75 70 20 63 6f 6e e the backup con
55a0: 74 65 78 74 20 73 74 72 75 63 74 75 72 65 2e 20 text structure.
55b0: 2a 2f 0a 20 20 20 20 73 71 6c 69 74 65 33 4c 65 */. sqlite3Le
55c0: 61 76 65 4d 75 74 65 78 41 6e 64 43 6c 6f 73 65 aveMutexAndClose
55d0: 5a 6f 6d 62 69 65 28 70 2d 3e 70 44 65 73 74 44 Zombie(p->pDestD
55e0: 62 29 3b 0a 20 20 7d 0a 20 20 73 71 6c 69 74 65 b);. }. sqlite
55f0: 33 42 74 72 65 65 4c 65 61 76 65 28 70 2d 3e 70 3BtreeLeave(p->p
5600: 53 72 63 29 3b 0a 20 20 69 66 28 20 70 2d 3e 70 Src);. if( p->p
5610: 44 65 73 74 44 62 20 29 7b 0a 20 20 20 20 2f 2a DestDb ){. /*
5620: 20 45 56 49 44 45 4e 43 45 2d 4f 46 3a 20 52 2d EVIDENCE-OF: R-
5630: 36 34 38 35 32 2d 32 31 35 39 31 20 54 68 65 20 64852-21591 The
5640: 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 6f sqlite3_backup o
5650: 62 6a 65 63 74 20 69 73 20 63 72 65 61 74 65 64 bject is created
5660: 20 62 79 20 61 0a 20 20 20 20 2a 2a 20 63 61 6c by a. ** cal
5670: 6c 20 74 6f 20 73 71 6c 69 74 65 33 5f 62 61 63 l to sqlite3_bac
5680: 6b 75 70 5f 69 6e 69 74 28 29 20 61 6e 64 20 69 kup_init() and i
5690: 73 20 64 65 73 74 72 6f 79 65 64 20 62 79 20 61 s destroyed by a
56a0: 20 63 61 6c 6c 20 74 6f 0a 20 20 20 20 2a 2a 20 call to. **
56b0: 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 66 sqlite3_backup_f
56c0: 69 6e 69 73 68 28 29 2e 20 2a 2f 0a 20 20 20 20 inish(). */.
56d0: 73 71 6c 69 74 65 33 5f 66 72 65 65 28 70 29 3b sqlite3_free(p);
56e0: 0a 20 20 7d 0a 20 20 73 71 6c 69 74 65 33 4c 65 . }. sqlite3Le
56f0: 61 76 65 4d 75 74 65 78 41 6e 64 43 6c 6f 73 65 aveMutexAndClose
5700: 5a 6f 6d 62 69 65 28 70 53 72 63 44 62 29 3b 0a Zombie(pSrcDb);.
5710: 20 20 72 65 74 75 72 6e 20 72 63 3b 0a 7d 0a 0a return rc;.}..
5720: 2f 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 /*.** Return the
5730: 20 6e 75 6d 62 65 72 20 6f 66 20 70 61 67 65 73 number of pages
5740: 20 73 74 69 6c 6c 20 74 6f 20 62 65 20 62 61 63 still to be bac
5750: 6b 65 64 20 75 70 20 61 73 20 6f 66 20 74 68 65 ked up as of the
5760: 20 6d 6f 73 74 20 72 65 63 65 6e 74 0a 2a 2a 20 most recent.**
5770: 63 61 6c 6c 20 74 6f 20 73 71 6c 69 74 65 33 5f call to sqlite3_
5780: 62 61 63 6b 75 70 5f 73 74 65 70 28 29 2e 0a 2a backup_step()..*
5790: 2f 0a 69 6e 74 20 73 71 6c 69 74 65 33 5f 62 61 /.int sqlite3_ba
57a0: 63 6b 75 70 5f 72 65 6d 61 69 6e 69 6e 67 28 73 ckup_remaining(s
57b0: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a 70 qlite3_backup *p
57c0: 29 7b 0a 20 20 72 65 74 75 72 6e 20 70 2d 3e 6e ){. return p->n
57d0: 52 65 6d 61 69 6e 69 6e 67 3b 0a 7d 0a 0a 2f 2a Remaining;.}../*
57e0: 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20 74 .** Return the t
57f0: 6f 74 61 6c 20 6e 75 6d 62 65 72 20 6f 66 20 70 otal number of p
5800: 61 67 65 73 20 69 6e 20 74 68 65 20 73 6f 75 72 ages in the sour
5810: 63 65 20 64 61 74 61 62 61 73 65 20 61 73 20 6f ce database as o
5820: 66 20 74 68 65 20 6d 6f 73 74 20 0a 2a 2a 20 72 f the most .** r
5830: 65 63 65 6e 74 20 63 61 6c 6c 20 74 6f 20 73 71 ecent call to sq
5840: 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 73 74 65 lite3_backup_ste
5850: 70 28 29 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 p()..*/.int sqli
5860: 74 65 33 5f 62 61 63 6b 75 70 5f 70 61 67 65 63 te3_backup_pagec
5870: 6f 75 6e 74 28 73 71 6c 69 74 65 33 5f 62 61 63 ount(sqlite3_bac
5880: 6b 75 70 20 2a 70 29 7b 0a 20 20 72 65 74 75 72 kup *p){. retur
5890: 6e 20 70 2d 3e 6e 50 61 67 65 63 6f 75 6e 74 3b n p->nPagecount;
58a0: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 54 68 69 73 20 66 .}../*.** This f
58b0: 75 6e 63 74 69 6f 6e 20 69 73 20 63 61 6c 6c 65 unction is calle
58c0: 64 20 61 66 74 65 72 20 74 68 65 20 63 6f 6e 74 d after the cont
58d0: 65 6e 74 73 20 6f 66 20 70 61 67 65 20 69 50 61 ents of page iPa
58e0: 67 65 20 6f 66 20 74 68 65 0a 2a 2a 20 73 6f 75 ge of the.** sou
58f0: 72 63 65 20 64 61 74 61 62 61 73 65 20 68 61 76 rce database hav
5900: 65 20 62 65 65 6e 20 6d 6f 64 69 66 69 65 64 2e e been modified.
5910: 20 49 66 20 70 61 67 65 20 69 50 61 67 65 20 68 If page iPage h
5920: 61 73 20 61 6c 72 65 61 64 79 20 62 65 65 6e 20 as already been
5930: 0a 2a 2a 20 63 6f 70 69 65 64 20 69 6e 74 6f 20 .** copied into
5940: 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f 6e 20 the destination
5950: 64 61 74 61 62 61 73 65 2c 20 74 68 65 6e 20 74 database, then t
5960: 68 65 20 64 61 74 61 20 77 72 69 74 74 65 6e 20 he data written
5970: 74 6f 20 74 68 65 0a 2a 2a 20 64 65 73 74 69 6e to the.** destin
5980: 61 74 69 6f 6e 20 69 73 20 6e 6f 77 20 69 6e 76 ation is now inv
5990: 61 6c 69 64 61 74 65 64 2e 20 54 68 65 20 64 65 alidated. The de
59a0: 73 74 69 6e 61 74 69 6f 6e 20 63 6f 70 79 20 6f stination copy o
59b0: 66 20 69 50 61 67 65 20 6e 65 65 64 73 0a 2a 2a f iPage needs.**
59c0: 20 74 6f 20 62 65 20 75 70 64 61 74 65 64 20 77 to be updated w
59d0: 69 74 68 20 74 68 65 20 6e 65 77 20 64 61 74 61 ith the new data
59e0: 20 62 65 66 6f 72 65 20 74 68 65 20 62 61 63 6b before the back
59f0: 75 70 20 6f 70 65 72 61 74 69 6f 6e 20 69 73 0a up operation is.
5a00: 2a 2a 20 63 6f 6d 70 6c 65 74 65 2e 0a 2a 2a 0a ** complete..**.
5a10: 2a 2a 20 49 74 20 69 73 20 61 73 73 75 6d 65 64 ** It is assumed
5a20: 20 74 68 61 74 20 74 68 65 20 6d 75 74 65 78 20 that the mutex
5a30: 61 73 73 6f 63 69 61 74 65 64 20 77 69 74 68 20 associated with
5a40: 74 68 65 20 42 74 53 68 61 72 65 64 20 6f 62 6a the BtShared obj
5a50: 65 63 74 0a 2a 2a 20 63 6f 72 72 65 73 70 6f 6e ect.** correspon
5a60: 64 69 6e 67 20 74 6f 20 74 68 65 20 73 6f 75 72 ding to the sour
5a70: 63 65 20 64 61 74 61 62 61 73 65 20 69 73 20 68 ce database is h
5a80: 65 6c 64 20 77 68 65 6e 20 74 68 69 73 20 66 75 eld when this fu
5a90: 6e 63 74 69 6f 6e 20 69 73 0a 2a 2a 20 63 61 6c nction is.** cal
5aa0: 6c 65 64 2e 0a 2a 2f 0a 76 6f 69 64 20 73 71 6c led..*/.void sql
5ab0: 69 74 65 33 42 61 63 6b 75 70 55 70 64 61 74 65 ite3BackupUpdate
5ac0: 28 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 (sqlite3_backup
5ad0: 2a 70 42 61 63 6b 75 70 2c 20 50 67 6e 6f 20 69 *pBackup, Pgno i
5ae0: 50 61 67 65 2c 20 63 6f 6e 73 74 20 75 38 20 2a Page, const u8 *
5af0: 61 44 61 74 61 29 7b 0a 20 20 73 71 6c 69 74 65 aData){. sqlite
5b00: 33 5f 62 61 63 6b 75 70 20 2a 70 3b 20 20 20 20 3_backup *p;
5b10: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 2f /
5b20: 2a 20 49 74 65 72 61 74 6f 72 20 76 61 72 69 61 * Iterator varia
5b30: 62 6c 65 20 2a 2f 0a 20 20 66 6f 72 28 70 3d 70 ble */. for(p=p
5b40: 42 61 63 6b 75 70 3b 20 70 3b 20 70 3d 70 2d 3e Backup; p; p=p->
5b50: 70 4e 65 78 74 29 7b 0a 20 20 20 20 61 73 73 65 pNext){. asse
5b60: 72 74 28 20 73 71 6c 69 74 65 33 5f 6d 75 74 65 rt( sqlite3_mute
5b70: 78 5f 68 65 6c 64 28 70 2d 3e 70 53 72 63 2d 3e x_held(p->pSrc->
5b80: 70 42 74 2d 3e 6d 75 74 65 78 29 20 29 3b 0a 20 pBt->mutex) );.
5b90: 20 20 20 69 66 28 20 21 69 73 46 61 74 61 6c 45 if( !isFatalE
5ba0: 72 72 6f 72 28 70 2d 3e 72 63 29 20 26 26 20 69 rror(p->rc) && i
5bb0: 50 61 67 65 3c 70 2d 3e 69 4e 65 78 74 20 29 7b Page<p->iNext ){
5bc0: 0a 20 20 20 20 20 20 2f 2a 20 54 68 65 20 62 61 . /* The ba
5bd0: 63 6b 75 70 20 70 72 6f 63 65 73 73 20 70 20 68 ckup process p h
5be0: 61 73 20 61 6c 72 65 61 64 79 20 63 6f 70 69 65 as already copie
5bf0: 64 20 70 61 67 65 20 69 50 61 67 65 2e 20 42 75 d page iPage. Bu
5c00: 74 20 6e 6f 77 20 69 74 0a 20 20 20 20 20 20 2a t now it. *
5c10: 2a 20 68 61 73 20 62 65 65 6e 20 6d 6f 64 69 66 * has been modif
5c20: 69 65 64 20 62 79 20 61 20 74 72 61 6e 73 61 63 ied by a transac
5c30: 74 69 6f 6e 20 6f 6e 20 74 68 65 20 73 6f 75 72 tion on the sour
5c40: 63 65 20 70 61 67 65 72 2e 20 43 6f 70 79 0a 20 ce pager. Copy.
5c50: 20 20 20 20 20 2a 2a 20 74 68 65 20 6e 65 77 20 ** the new
5c60: 64 61 74 61 20 69 6e 74 6f 20 74 68 65 20 62 61 data into the ba
5c70: 63 6b 75 70 2e 0a 20 20 20 20 20 20 2a 2f 0a 20 ckup.. */.
5c80: 20 20 20 20 20 69 6e 74 20 72 63 3b 0a 20 20 20 int rc;.
5c90: 20 20 20 61 73 73 65 72 74 28 20 70 2d 3e 70 44 assert( p->pD
5ca0: 65 73 74 44 62 20 29 3b 0a 20 20 20 20 20 20 73 estDb );. s
5cb0: 71 6c 69 74 65 33 5f 6d 75 74 65 78 5f 65 6e 74 qlite3_mutex_ent
5cc0: 65 72 28 70 2d 3e 70 44 65 73 74 44 62 2d 3e 6d er(p->pDestDb->m
5cd0: 75 74 65 78 29 3b 0a 20 20 20 20 20 20 72 63 20 utex);. rc
5ce0: 3d 20 62 61 63 6b 75 70 4f 6e 65 50 61 67 65 28 = backupOnePage(
5cf0: 70 2c 20 69 50 61 67 65 2c 20 61 44 61 74 61 2c p, iPage, aData,
5d00: 20 31 29 3b 0a 20 20 20 20 20 20 73 71 6c 69 74 1);. sqlit
5d10: 65 33 5f 6d 75 74 65 78 5f 6c 65 61 76 65 28 70 e3_mutex_leave(p
5d20: 2d 3e 70 44 65 73 74 44 62 2d 3e 6d 75 74 65 78 ->pDestDb->mutex
5d30: 29 3b 0a 20 20 20 20 20 20 61 73 73 65 72 74 28 );. assert(
5d40: 20 72 63 21 3d 53 51 4c 49 54 45 5f 42 55 53 59 rc!=SQLITE_BUSY
5d50: 20 26 26 20 72 63 21 3d 53 51 4c 49 54 45 5f 4c && rc!=SQLITE_L
5d60: 4f 43 4b 45 44 20 29 3b 0a 20 20 20 20 20 20 69 OCKED );. i
5d70: 66 28 20 72 63 21 3d 53 51 4c 49 54 45 5f 4f 4b f( rc!=SQLITE_OK
5d80: 20 29 7b 0a 20 20 20 20 20 20 20 20 70 2d 3e 72 ){. p->r
5d90: 63 20 3d 20 72 63 3b 0a 20 20 20 20 20 20 7d 0a c = rc;. }.
5da0: 20 20 20 20 7d 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a }. }.}../*.
5db0: 2a 2a 20 52 65 73 74 61 72 74 20 74 68 65 20 62 ** Restart the b
5dc0: 61 63 6b 75 70 20 70 72 6f 63 65 73 73 2e 20 54 ackup process. T
5dd0: 68 69 73 20 69 73 20 63 61 6c 6c 65 64 20 77 68 his is called wh
5de0: 65 6e 20 74 68 65 20 70 61 67 65 72 20 6c 61 79 en the pager lay
5df0: 65 72 0a 2a 2a 20 64 65 74 65 63 74 73 20 74 68 er.** detects th
5e00: 61 74 20 74 68 65 20 64 61 74 61 62 61 73 65 20 at the database
5e10: 68 61 73 20 62 65 65 6e 20 6d 6f 64 69 66 69 65 has been modifie
5e20: 64 20 62 79 20 61 6e 20 65 78 74 65 72 6e 61 6c d by an external
5e30: 20 64 61 74 61 62 61 73 65 0a 2a 2a 20 63 6f 6e database.** con
5e40: 6e 65 63 74 69 6f 6e 2e 20 49 6e 20 74 68 69 73 nection. In this
5e50: 20 63 61 73 65 20 74 68 65 72 65 20 69 73 20 6e case there is n
5e60: 6f 20 77 61 79 20 6f 66 20 6b 6e 6f 77 69 6e 67 o way of knowing
5e70: 20 77 68 69 63 68 20 6f 66 20 74 68 65 0a 2a 2a which of the.**
5e80: 20 70 61 67 65 73 20 74 68 61 74 20 68 61 76 65 pages that have
5e90: 20 62 65 65 6e 20 63 6f 70 69 65 64 20 69 6e 74 been copied int
5ea0: 6f 20 74 68 65 20 64 65 73 74 69 6e 61 74 69 6f o the destinatio
5eb0: 6e 20 64 61 74 61 62 61 73 65 20 61 72 65 20 73 n database are s
5ec0: 74 69 6c 6c 20 0a 2a 2a 20 76 61 6c 69 64 20 61 till .** valid a
5ed0: 6e 64 20 77 68 69 63 68 20 61 72 65 20 6e 6f 74 nd which are not
5ee0: 2c 20 73 6f 20 74 68 65 20 65 6e 74 69 72 65 20 , so the entire
5ef0: 70 72 6f 63 65 73 73 20 6e 65 65 64 73 20 74 6f process needs to
5f00: 20 62 65 20 72 65 73 74 61 72 74 65 64 2e 0a 2a be restarted..*
5f10: 2a 0a 2a 2a 20 49 74 20 69 73 20 61 73 73 75 6d *.** It is assum
5f20: 65 64 20 74 68 61 74 20 74 68 65 20 6d 75 74 65 ed that the mute
5f30: 78 20 61 73 73 6f 63 69 61 74 65 64 20 77 69 74 x associated wit
5f40: 68 20 74 68 65 20 42 74 53 68 61 72 65 64 20 6f h the BtShared o
5f50: 62 6a 65 63 74 0a 2a 2a 20 63 6f 72 72 65 73 70 bject.** corresp
5f60: 6f 6e 64 69 6e 67 20 74 6f 20 74 68 65 20 73 6f onding to the so
5f70: 75 72 63 65 20 64 61 74 61 62 61 73 65 20 69 73 urce database is
5f80: 20 68 65 6c 64 20 77 68 65 6e 20 74 68 69 73 20 held when this
5f90: 66 75 6e 63 74 69 6f 6e 20 69 73 0a 2a 2a 20 63 function is.** c
5fa0: 61 6c 6c 65 64 2e 0a 2a 2f 0a 76 6f 69 64 20 73 alled..*/.void s
5fb0: 71 6c 69 74 65 33 42 61 63 6b 75 70 52 65 73 74 qlite3BackupRest
5fc0: 61 72 74 28 73 71 6c 69 74 65 33 5f 62 61 63 6b art(sqlite3_back
5fd0: 75 70 20 2a 70 42 61 63 6b 75 70 29 7b 0a 20 20 up *pBackup){.
5fe0: 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 2a sqlite3_backup *
5ff0: 70 3b 20 20 20 20 20 20 20 20 20 20 20 20 20 20 p;
6000: 20 20 20 20 20 2f 2a 20 49 74 65 72 61 74 6f 72 /* Iterator
6010: 20 76 61 72 69 61 62 6c 65 20 2a 2f 0a 20 20 66 variable */. f
6020: 6f 72 28 70 3d 70 42 61 63 6b 75 70 3b 20 70 3b or(p=pBackup; p;
6030: 20 70 3d 70 2d 3e 70 4e 65 78 74 29 7b 0a 20 20 p=p->pNext){.
6040: 20 20 61 73 73 65 72 74 28 20 73 71 6c 69 74 65 assert( sqlite
6050: 33 5f 6d 75 74 65 78 5f 68 65 6c 64 28 70 2d 3e 3_mutex_held(p->
6060: 70 53 72 63 2d 3e 70 42 74 2d 3e 6d 75 74 65 78 pSrc->pBt->mutex
6070: 29 20 29 3b 0a 20 20 20 20 70 2d 3e 69 4e 65 78 ) );. p->iNex
6080: 74 20 3d 20 31 3b 0a 20 20 7d 0a 7d 0a 0a 23 69 t = 1;. }.}..#i
6090: 66 6e 64 65 66 20 53 51 4c 49 54 45 5f 4f 4d 49 fndef SQLITE_OMI
60a0: 54 5f 56 41 43 55 55 4d 0a 2f 2a 0a 2a 2a 20 43 T_VACUUM./*.** C
60b0: 6f 70 79 20 74 68 65 20 63 6f 6d 70 6c 65 74 65 opy the complete
60c0: 20 63 6f 6e 74 65 6e 74 20 6f 66 20 70 42 74 46 content of pBtF
60d0: 72 6f 6d 20 69 6e 74 6f 20 70 42 74 54 6f 2e 20 rom into pBtTo.
60e0: 20 41 20 74 72 61 6e 73 61 63 74 69 6f 6e 0a 2a A transaction.*
60f0: 2a 20 6d 75 73 74 20 62 65 20 61 63 74 69 76 65 * must be active
6100: 20 66 6f 72 20 62 6f 74 68 20 66 69 6c 65 73 2e for both files.
6110: 0a 2a 2a 0a 2a 2a 20 54 68 65 20 73 69 7a 65 20 .**.** The size
6120: 6f 66 20 66 69 6c 65 20 70 54 6f 20 6d 61 79 20 of file pTo may
6130: 62 65 20 72 65 64 75 63 65 64 20 62 79 20 74 68 be reduced by th
6140: 69 73 20 6f 70 65 72 61 74 69 6f 6e 2e 20 49 66 is operation. If
6150: 20 61 6e 79 74 68 69 6e 67 20 0a 2a 2a 20 67 6f anything .** go
6160: 65 73 20 77 72 6f 6e 67 2c 20 74 68 65 20 74 72 es wrong, the tr
6170: 61 6e 73 61 63 74 69 6f 6e 20 6f 6e 20 70 54 6f ansaction on pTo
6180: 20 69 73 20 72 6f 6c 6c 65 64 20 62 61 63 6b 2e is rolled back.
6190: 20 49 66 20 73 75 63 63 65 73 73 66 75 6c 2c 20 If successful,
61a0: 74 68 65 20 0a 2a 2a 20 74 72 61 6e 73 61 63 74 the .** transact
61b0: 69 6f 6e 20 69 73 20 63 6f 6d 6d 69 74 74 65 64 ion is committed
61c0: 20 62 65 66 6f 72 65 20 72 65 74 75 72 6e 69 6e before returnin
61d0: 67 2e 0a 2a 2f 0a 69 6e 74 20 73 71 6c 69 74 65 g..*/.int sqlite
61e0: 33 42 74 72 65 65 43 6f 70 79 46 69 6c 65 28 42 3BtreeCopyFile(B
61f0: 74 72 65 65 20 2a 70 54 6f 2c 20 42 74 72 65 65 tree *pTo, Btree
6200: 20 2a 70 46 72 6f 6d 29 7b 0a 20 20 69 6e 74 20 *pFrom){. int
6210: 72 63 3b 0a 20 20 73 71 6c 69 74 65 33 5f 66 69 rc;. sqlite3_fi
6220: 6c 65 20 2a 70 46 64 3b 20 20 20 20 20 20 20 20 le *pFd;
6230: 20 20 20 20 20 20 2f 2a 20 46 69 6c 65 20 64 65 /* File de
6240: 73 63 72 69 70 74 6f 72 20 66 6f 72 20 64 61 74 scriptor for dat
6250: 61 62 61 73 65 20 70 54 6f 20 2a 2f 0a 20 20 73 abase pTo */. s
6260: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 62 3b qlite3_backup b;
6270: 0a 20 20 73 71 6c 69 74 65 33 42 74 72 65 65 45 . sqlite3BtreeE
6280: 6e 74 65 72 28 70 54 6f 29 3b 0a 20 20 73 71 6c nter(pTo);. sql
6290: 69 74 65 33 42 74 72 65 65 45 6e 74 65 72 28 70 ite3BtreeEnter(p
62a0: 46 72 6f 6d 29 3b 0a 0a 20 20 61 73 73 65 72 74 From);.. assert
62b0: 28 20 73 71 6c 69 74 65 33 42 74 72 65 65 49 73 ( sqlite3BtreeIs
62c0: 49 6e 54 72 61 6e 73 28 70 54 6f 29 20 29 3b 0a InTrans(pTo) );.
62d0: 20 20 70 46 64 20 3d 20 73 71 6c 69 74 65 33 50 pFd = sqlite3P
62e0: 61 67 65 72 46 69 6c 65 28 73 71 6c 69 74 65 33 agerFile(sqlite3
62f0: 42 74 72 65 65 50 61 67 65 72 28 70 54 6f 29 29 BtreePager(pTo))
6300: 3b 0a 20 20 69 66 28 20 70 46 64 2d 3e 70 4d 65 ;. if( pFd->pMe
6310: 74 68 6f 64 73 20 29 7b 0a 20 20 20 20 69 36 34 thods ){. i64
6320: 20 6e 42 79 74 65 20 3d 20 73 71 6c 69 74 65 33 nByte = sqlite3
6330: 42 74 72 65 65 47 65 74 50 61 67 65 53 69 7a 65 BtreeGetPageSize
6340: 28 70 46 72 6f 6d 29 2a 28 69 36 34 29 73 71 6c (pFrom)*(i64)sql
6350: 69 74 65 33 42 74 72 65 65 4c 61 73 74 50 61 67 ite3BtreeLastPag
6360: 65 28 70 46 72 6f 6d 29 3b 0a 20 20 20 20 72 63 e(pFrom);. rc
6370: 20 3d 20 73 71 6c 69 74 65 33 4f 73 46 69 6c 65 = sqlite3OsFile
6380: 43 6f 6e 74 72 6f 6c 28 70 46 64 2c 20 53 51 4c Control(pFd, SQL
6390: 49 54 45 5f 46 43 4e 54 4c 5f 4f 56 45 52 57 52 ITE_FCNTL_OVERWR
63a0: 49 54 45 2c 20 26 6e 42 79 74 65 29 3b 0a 20 20 ITE, &nByte);.
63b0: 20 20 69 66 28 20 72 63 3d 3d 53 51 4c 49 54 45 if( rc==SQLITE
63c0: 5f 4e 4f 54 46 4f 55 4e 44 20 29 20 72 63 20 3d _NOTFOUND ) rc =
63d0: 20 53 51 4c 49 54 45 5f 4f 4b 3b 0a 20 20 20 20 SQLITE_OK;.
63e0: 69 66 28 20 72 63 20 29 20 67 6f 74 6f 20 63 6f if( rc ) goto co
63f0: 70 79 5f 66 69 6e 69 73 68 65 64 3b 0a 20 20 7d py_finished;. }
6400: 0a 0a 20 20 2f 2a 20 53 65 74 20 75 70 20 61 6e .. /* Set up an
6410: 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 20 sqlite3_backup
6420: 6f 62 6a 65 63 74 2e 20 73 71 6c 69 74 65 33 5f object. sqlite3_
6430: 62 61 63 6b 75 70 2e 70 44 65 73 74 44 62 20 6d backup.pDestDb m
6440: 75 73 74 20 62 65 20 73 65 74 0a 20 20 2a 2a 20 ust be set. **
6450: 74 6f 20 30 2e 20 54 68 69 73 20 69 73 20 75 73 to 0. This is us
6460: 65 64 20 62 79 20 74 68 65 20 69 6d 70 6c 65 6d ed by the implem
6470: 65 6e 74 61 74 69 6f 6e 73 20 6f 66 20 73 71 6c entations of sql
6480: 69 74 65 33 5f 62 61 63 6b 75 70 5f 73 74 65 70 ite3_backup_step
6490: 28 29 0a 20 20 2a 2a 20 61 6e 64 20 73 71 6c 69 (). ** and sqli
64a0: 74 65 33 5f 62 61 63 6b 75 70 5f 66 69 6e 69 73 te3_backup_finis
64b0: 68 28 29 20 74 6f 20 64 65 74 65 63 74 20 74 68 h() to detect th
64c0: 61 74 20 74 68 65 79 20 61 72 65 20 62 65 69 6e at they are bein
64d0: 67 20 63 61 6c 6c 65 64 0a 20 20 2a 2a 20 66 72 g called. ** fr
64e0: 6f 6d 20 74 68 69 73 20 66 75 6e 63 74 69 6f 6e om this function
64f0: 2c 20 6e 6f 74 20 64 69 72 65 63 74 6c 79 20 62 , not directly b
6500: 79 20 74 68 65 20 75 73 65 72 2e 0a 20 20 2a 2f y the user.. */
6510: 0a 20 20 6d 65 6d 73 65 74 28 26 62 2c 20 30 2c . memset(&b, 0,
6520: 20 73 69 7a 65 6f 66 28 62 29 29 3b 0a 20 20 62 sizeof(b));. b
6530: 2e 70 53 72 63 44 62 20 3d 20 70 46 72 6f 6d 2d .pSrcDb = pFrom-
6540: 3e 64 62 3b 0a 20 20 62 2e 70 53 72 63 20 3d 20 >db;. b.pSrc =
6550: 70 46 72 6f 6d 3b 0a 20 20 62 2e 70 44 65 73 74 pFrom;. b.pDest
6560: 20 3d 20 70 54 6f 3b 0a 20 20 62 2e 69 4e 65 78 = pTo;. b.iNex
6570: 74 20 3d 20 31 3b 0a 0a 20 20 2f 2a 20 30 78 37 t = 1;.. /* 0x7
6580: 46 46 46 46 46 46 46 20 69 73 20 74 68 65 20 68 FFFFFFF is the h
6590: 61 72 64 20 6c 69 6d 69 74 20 66 6f 72 20 74 68 ard limit for th
65a0: 65 20 6e 75 6d 62 65 72 20 6f 66 20 70 61 67 65 e number of page
65b0: 73 20 69 6e 20 61 20 64 61 74 61 62 61 73 65 0a s in a database.
65c0: 20 20 2a 2a 20 66 69 6c 65 2e 20 42 79 20 70 61 ** file. By pa
65d0: 73 73 69 6e 67 20 74 68 69 73 20 61 73 20 74 68 ssing this as th
65e0: 65 20 6e 75 6d 62 65 72 20 6f 66 20 70 61 67 65 e number of page
65f0: 73 20 74 6f 20 63 6f 70 79 20 74 6f 0a 20 20 2a s to copy to. *
6600: 2a 20 73 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 * sqlite3_backup
6610: 5f 73 74 65 70 28 29 2c 20 77 65 20 63 61 6e 20 _step(), we can
6620: 67 75 61 72 61 6e 74 65 65 20 74 68 61 74 20 74 guarantee that t
6630: 68 65 20 63 6f 70 79 20 66 69 6e 69 73 68 65 73 he copy finishes
6640: 20 0a 20 20 2a 2a 20 77 69 74 68 69 6e 20 61 20 . ** within a
6650: 73 69 6e 67 6c 65 20 63 61 6c 6c 20 28 75 6e 6c single call (unl
6660: 65 73 73 20 61 6e 20 65 72 72 6f 72 20 6f 63 63 ess an error occ
6670: 75 72 73 29 2e 20 54 68 65 20 61 73 73 65 72 74 urs). The assert
6680: 28 29 20 73 74 61 74 65 6d 65 6e 74 0a 20 20 2a () statement. *
6690: 2a 20 63 68 65 63 6b 73 20 74 68 69 73 20 61 73 * checks this as
66a0: 73 75 6d 70 74 69 6f 6e 20 2d 20 28 70 2d 3e 72 sumption - (p->r
66b0: 63 29 20 73 68 6f 75 6c 64 20 62 65 20 73 65 74 c) should be set
66c0: 20 74 6f 20 65 69 74 68 65 72 20 53 51 4c 49 54 to either SQLIT
66d0: 45 5f 44 4f 4e 45 20 0a 20 20 2a 2a 20 6f 72 20 E_DONE . ** or
66e0: 61 6e 20 65 72 72 6f 72 20 63 6f 64 65 2e 0a 20 an error code..
66f0: 20 2a 2f 0a 20 20 73 71 6c 69 74 65 33 5f 62 61 */. sqlite3_ba
6700: 63 6b 75 70 5f 73 74 65 70 28 26 62 2c 20 30 78 ckup_step(&b, 0x
6710: 37 46 46 46 46 46 46 46 29 3b 0a 20 20 61 73 73 7FFFFFFF);. ass
6720: 65 72 74 28 20 62 2e 72 63 21 3d 53 51 4c 49 54 ert( b.rc!=SQLIT
6730: 45 5f 4f 4b 20 29 3b 0a 20 20 72 63 20 3d 20 73 E_OK );. rc = s
6740: 71 6c 69 74 65 33 5f 62 61 63 6b 75 70 5f 66 69 qlite3_backup_fi
6750: 6e 69 73 68 28 26 62 29 3b 0a 20 20 69 66 28 20 nish(&b);. if(
6760: 72 63 3d 3d 53 51 4c 49 54 45 5f 4f 4b 20 29 7b rc==SQLITE_OK ){
6770: 0a 20 20 20 20 70 54 6f 2d 3e 70 42 74 2d 3e 62 . pTo->pBt->b
6780: 74 73 46 6c 61 67 73 20 26 3d 20 7e 42 54 53 5f tsFlags &= ~BTS_
6790: 50 41 47 45 53 49 5a 45 5f 46 49 58 45 44 3b 0a PAGESIZE_FIXED;.
67a0: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 73 71 6c }else{. sql
67b0: 69 74 65 33 50 61 67 65 72 43 6c 65 61 72 43 61 ite3PagerClearCa
67c0: 63 68 65 28 73 71 6c 69 74 65 33 42 74 72 65 65 che(sqlite3Btree
67d0: 50 61 67 65 72 28 62 2e 70 44 65 73 74 29 29 3b Pager(b.pDest));
67e0: 0a 20 20 7d 0a 0a 20 20 61 73 73 65 72 74 28 20 . }.. assert(
67f0: 73 71 6c 69 74 65 33 42 74 72 65 65 49 73 49 6e sqlite3BtreeIsIn
6800: 54 72 61 6e 73 28 70 54 6f 29 3d 3d 30 20 29 3b Trans(pTo)==0 );
6810: 0a 63 6f 70 79 5f 66 69 6e 69 73 68 65 64 3a 0a .copy_finished:.
6820: 20 20 73 71 6c 69 74 65 33 42 74 72 65 65 4c 65 sqlite3BtreeLe
6830: 61 76 65 28 70 46 72 6f 6d 29 3b 0a 20 20 73 71 ave(pFrom);. sq
6840: 6c 69 74 65 33 42 74 72 65 65 4c 65 61 76 65 28 lite3BtreeLeave(
6850: 70 54 6f 29 3b 0a 20 20 72 65 74 75 72 6e 20 72 pTo);. return r
6860: 63 3b 0a 7d 0a 23 65 6e 64 69 66 20 2f 2a 20 53 c;.}.#endif /* S
6870: 51 4c 49 54 45 5f 4f 4d 49 54 5f 56 41 43 55 55 QLITE_OMIT_VACUU
6880: 4d 20 2a 2f 0a M */.