0000: 2f 2a 0a 2a 2a 20 43 6f 70 79 72 69 67 68 74 20 /*.** Copyright
0010: 28 63 29 20 32 30 30 37 20 44 2e 20 52 69 63 68 (c) 2007 D. Rich
0020: 61 72 64 20 48 69 70 70 0a 2a 2a 0a 2a 2a 20 54 ard Hipp.**.** T
0030: 68 69 73 20 70 72 6f 67 72 61 6d 20 69 73 20 66 his program is f
0040: 72 65 65 20 73 6f 66 74 77 61 72 65 3b 20 79 6f ree software; yo
0050: 75 20 63 61 6e 20 72 65 64 69 73 74 72 69 62 75 u can redistribu
0060: 74 65 20 69 74 20 61 6e 64 2f 6f 72 0a 2a 2a 20 te it and/or.**
0070: 6d 6f 64 69 66 79 20 69 74 20 75 6e 64 65 72 20 modify it under
0080: 74 68 65 20 74 65 72 6d 73 20 6f 66 20 74 68 65 the terms of the
0090: 20 47 4e 55 20 47 65 6e 65 72 61 6c 20 50 75 62 GNU General Pub
00a0: 6c 69 63 0a 2a 2a 20 4c 69 63 65 6e 73 65 20 76 lic.** License v
00b0: 65 72 73 69 6f 6e 20 32 20 61 73 20 70 75 62 6c ersion 2 as publ
00c0: 69 73 68 65 64 20 62 79 20 74 68 65 20 46 72 65 ished by the Fre
00d0: 65 20 53 6f 66 74 77 61 72 65 20 46 6f 75 6e 64 e Software Found
00e0: 61 74 69 6f 6e 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 ation..**.** Thi
00f0: 73 20 70 72 6f 67 72 61 6d 20 69 73 20 64 69 73 s program is dis
0100: 74 72 69 62 75 74 65 64 20 69 6e 20 74 68 65 20 tributed in the
0110: 68 6f 70 65 20 74 68 61 74 20 69 74 20 77 69 6c hope that it wil
0120: 6c 20 62 65 20 75 73 65 66 75 6c 2c 0a 2a 2a 20 l be useful,.**
0130: 62 75 74 20 57 49 54 48 4f 55 54 20 41 4e 59 20 but WITHOUT ANY
0140: 57 41 52 52 41 4e 54 59 3b 20 77 69 74 68 6f 75 WARRANTY; withou
0150: 74 20 65 76 65 6e 20 74 68 65 20 69 6d 70 6c 69 t even the impli
0160: 65 64 20 77 61 72 72 61 6e 74 79 20 6f 66 0a 2a ed warranty of.*
0170: 2a 20 4d 45 52 43 48 41 4e 54 41 42 49 4c 49 54 * MERCHANTABILIT
0180: 59 20 6f 72 20 46 49 54 4e 45 53 53 20 46 4f 52 Y or FITNESS FOR
0190: 20 41 20 50 41 52 54 49 43 55 4c 41 52 20 50 55 A PARTICULAR PU
01a0: 52 50 4f 53 45 2e 20 20 53 65 65 20 74 68 65 20 RPOSE. See the
01b0: 47 4e 55 0a 2a 2a 20 47 65 6e 65 72 61 6c 20 50 GNU.** General P
01c0: 75 62 6c 69 63 20 4c 69 63 65 6e 73 65 20 66 6f ublic License fo
01d0: 72 20 6d 6f 72 65 20 64 65 74 61 69 6c 73 2e 0a r more details..
01e0: 2a 2a 20 0a 2a 2a 20 59 6f 75 20 73 68 6f 75 6c ** .** You shoul
01f0: 64 20 68 61 76 65 20 72 65 63 65 69 76 65 64 20 d have received
0200: 61 20 63 6f 70 79 20 6f 66 20 74 68 65 20 47 4e a copy of the GN
0210: 55 20 47 65 6e 65 72 61 6c 20 50 75 62 6c 69 63 U General Public
0220: 0a 2a 2a 20 4c 69 63 65 6e 73 65 20 61 6c 6f 6e .** License alon
0230: 67 20 77 69 74 68 20 74 68 69 73 20 6c 69 62 72 g with this libr
0240: 61 72 79 3b 20 69 66 20 6e 6f 74 2c 20 77 72 69 ary; if not, wri
0250: 74 65 20 74 6f 20 74 68 65 0a 2a 2a 20 46 72 65 te to the.** Fre
0260: 65 20 53 6f 66 74 77 61 72 65 20 46 6f 75 6e 64 e Software Found
0270: 61 74 69 6f 6e 2c 20 49 6e 63 2e 2c 20 35 39 20 ation, Inc., 59
0280: 54 65 6d 70 6c 65 20 50 6c 61 63 65 20 2d 20 53 Temple Place - S
0290: 75 69 74 65 20 33 33 30 2c 0a 2a 2a 20 42 6f 73 uite 330,.** Bos
02a0: 74 6f 6e 2c 20 4d 41 20 20 30 32 31 31 31 2d 31 ton, MA 02111-1
02b0: 33 30 37 2c 20 55 53 41 2e 0a 2a 2a 0a 2a 2a 20 307, USA..**.**
02c0: 41 75 74 68 6f 72 20 63 6f 6e 74 61 63 74 20 69 Author contact i
02d0: 6e 66 6f 72 6d 61 74 69 6f 6e 3a 0a 2a 2a 20 20 nformation:.**
02e0: 20 64 72 68 40 68 77 61 63 69 2e 63 6f 6d 0a 2a drh@hwaci.com.*
02f0: 2a 20 20 20 68 74 74 70 3a 2f 2f 77 77 77 2e 68 * http://www.h
0300: 77 61 63 69 2e 63 6f 6d 2f 64 72 68 2f 0a 2a 2a waci.com/drh/.**
0310: 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a .***************
0320: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a ****************
0330: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a ****************
0340: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a ****************
0350: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a ****************
0360: 0a 2a 2a 0a 2a 2a 20 50 72 6f 63 65 64 75 72 65 .**.** Procedure
0370: 73 20 66 6f 72 20 6d 61 6e 61 67 69 6e 67 20 74 s for managing t
0380: 68 65 20 56 46 49 4c 45 20 74 61 62 6c 65 2e 0a he VFILE table..
0390: 2a 2f 0a 23 69 6e 63 6c 75 64 65 20 22 63 6f 6e */.#include "con
03a0: 66 69 67 2e 68 22 0a 23 69 6e 63 6c 75 64 65 20 fig.h".#include
03b0: 22 76 66 69 6c 65 2e 68 22 0a 23 69 6e 63 6c 75 "vfile.h".#inclu
03c0: 64 65 20 3c 61 73 73 65 72 74 2e 68 3e 0a 23 69 de <assert.h>.#i
03d0: 6e 63 6c 75 64 65 20 3c 73 79 73 2f 74 79 70 65 nclude <sys/type
03e0: 73 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 3c 64 s.h>.#include <d
03f0: 69 72 65 6e 74 2e 68 3e 0a 0a 2f 2a 0a 2a 2a 20 irent.h>../*.**
0400: 47 69 76 65 6e 20 61 20 55 55 49 44 2c 20 72 65 Given a UUID, re
0410: 74 75 72 6e 20 74 68 65 20 63 6f 72 72 65 73 70 turn the corresp
0420: 6f 6e 64 69 6e 67 20 72 65 63 6f 72 64 20 49 44 onding record ID
0430: 2e 20 20 49 66 20 74 68 65 20 55 55 49 44 0a 2a . If the UUID.*
0440: 2a 20 64 6f 65 73 20 6e 6f 74 20 65 78 69 73 74 * does not exist
0450: 2c 20 74 68 65 6e 20 72 65 74 75 72 6e 20 30 2e , then return 0.
0460: 0a 2a 2a 0a 2a 2a 20 46 6f 72 20 74 68 69 73 20 .**.** For this
0470: 72 6f 75 74 69 6e 65 2c 20 74 68 65 20 55 55 49 routine, the UUI
0480: 44 20 6d 75 73 74 20 62 65 20 65 78 61 63 74 2e D must be exact.
0490: 20 20 46 6f 72 20 61 20 6d 61 74 63 68 20 61 67 For a match ag
04a0: 61 69 6e 73 74 0a 2a 2a 20 75 73 65 72 20 69 6e ainst.** user in
04b0: 70 75 74 20 77 69 74 68 20 6d 69 78 65 64 20 63 put with mixed c
04c0: 61 73 65 2c 20 75 73 65 20 72 65 73 6f 6c 76 65 ase, use resolve
04d0: 5f 75 75 69 64 28 29 2e 0a 2a 2a 0a 2a 2a 20 49 _uuid()..**.** I
04e0: 66 20 74 68 65 20 55 55 49 44 20 69 73 20 6e 6f f the UUID is no
04f0: 74 20 66 6f 75 6e 64 20 61 6e 64 20 70 68 61 6e t found and phan
0500: 74 6f 6d 69 7a 65 20 69 73 20 31 2c 20 74 68 65 tomize is 1, the
0510: 6e 20 61 74 74 65 6d 70 74 20 74 6f 20 0a 2a 2a n attempt to .**
0520: 20 63 72 65 61 74 65 20 61 20 70 68 61 6e 74 6f create a phanto
0530: 6d 20 72 65 63 6f 72 64 2e 0a 2a 2f 0a 69 6e 74 m record..*/.int
0540: 20 75 75 69 64 5f 74 6f 5f 72 69 64 28 63 6f 6e uuid_to_rid(con
0550: 73 74 20 63 68 61 72 20 2a 7a 55 75 69 64 2c 20 st char *zUuid,
0560: 69 6e 74 20 70 68 61 6e 74 6f 6d 69 7a 65 29 7b int phantomize){
0570: 0a 20 20 69 6e 74 20 72 69 64 2c 20 73 7a 3b 0a . int rid, sz;.
0580: 20 20 63 68 61 72 20 7a 5b 55 55 49 44 5f 53 49 char z[UUID_SI
0590: 5a 45 2b 31 5d 3b 0a 20 20 0a 20 20 73 7a 20 3d ZE+1];. . sz =
05a0: 20 73 74 72 6c 65 6e 28 7a 55 75 69 64 29 3b 0a strlen(zUuid);.
05b0: 20 20 69 66 28 20 73 7a 21 3d 55 55 49 44 5f 53 if( sz!=UUID_S
05c0: 49 5a 45 20 7c 7c 20 21 76 61 6c 69 64 61 74 65 IZE || !validate
05d0: 31 36 28 7a 55 75 69 64 2c 20 73 7a 29 20 29 7b 16(zUuid, sz) ){
05e0: 0a 20 20 20 20 72 65 74 75 72 6e 20 30 3b 0a 20 . return 0;.
05f0: 20 7d 0a 20 20 73 74 72 63 70 79 28 7a 2c 20 7a }. strcpy(z, z
0600: 55 75 69 64 29 3b 0a 20 20 63 61 6e 6f 6e 69 63 Uuid);. canonic
0610: 61 6c 31 36 28 7a 2c 20 73 7a 29 3b 0a 20 20 72 al16(z, sz);. r
0620: 69 64 20 3d 20 64 62 5f 69 6e 74 28 30 2c 20 22 id = db_int(0, "
0630: 53 45 4c 45 43 54 20 72 69 64 20 46 52 4f 4d 20 SELECT rid FROM
0640: 62 6c 6f 62 20 57 48 45 52 45 20 75 75 69 64 3d blob WHERE uuid=
0650: 25 51 22 2c 20 7a 29 3b 0a 20 20 69 66 28 20 72 %Q", z);. if( r
0660: 69 64 3d 3d 30 20 26 26 20 70 68 61 6e 74 6f 6d id==0 && phantom
0670: 69 7a 65 20 29 7b 0a 20 20 20 20 72 69 64 20 3d ize ){. rid =
0680: 20 63 6f 6e 74 65 6e 74 5f 70 75 74 28 30 2c 20 content_put(0,
0690: 7a 55 75 69 64 2c 20 30 29 3b 0a 20 20 7d 0a 20 zUuid, 0);. }.
06a0: 20 72 65 74 75 72 6e 20 72 69 64 3b 0a 7d 0a 0a return rid;.}..
06b0: 2f 2a 0a 2a 2a 20 56 65 72 69 66 79 20 74 68 61 /*.** Verify tha
06c0: 74 20 61 6e 20 6f 62 6a 65 63 74 20 69 73 20 6e t an object is n
06d0: 6f 74 20 61 20 70 68 61 6e 74 6f 6d 2e 20 20 49 ot a phantom. I
06e0: 66 20 74 68 65 20 6f 62 6a 65 63 74 20 69 73 0a f the object is.
06f0: 2a 2a 20 61 20 70 68 61 6e 74 6f 6d 2c 20 6f 75 ** a phantom, ou
0700: 74 70 75 74 20 61 6e 20 65 72 72 6f 72 20 6d 65 tput an error me
0710: 73 73 61 67 65 20 61 6e 64 20 71 75 69 63 6b 2e ssage and quick.
0720: 0a 2a 2f 0a 76 6f 69 64 20 76 66 69 6c 65 5f 76 .*/.void vfile_v
0730: 65 72 69 66 79 5f 6e 6f 74 5f 70 68 61 6e 74 6f erify_not_phanto
0740: 6d 28 69 6e 74 20 72 69 64 2c 20 63 6f 6e 73 74 m(int rid, const
0750: 20 63 68 61 72 20 2a 7a 46 69 6c 65 6e 61 6d 65 char *zFilename
0760: 29 7b 0a 20 20 69 66 28 20 64 62 5f 69 6e 74 28 ){. if( db_int(
0770: 2d 31 2c 20 22 53 45 4c 45 43 54 20 73 69 7a 65 -1, "SELECT size
0780: 20 46 52 4f 4d 20 62 6c 6f 62 20 57 48 45 52 45 FROM blob WHERE
0790: 20 72 69 64 3d 25 64 22 2c 20 72 69 64 29 3c 30 rid=%d", rid)<0
07a0: 20 29 7b 0a 20 20 20 20 69 66 28 20 7a 46 69 6c ){. if( zFil
07b0: 65 6e 61 6d 65 20 29 7b 0a 20 20 20 20 20 20 66 ename ){. f
07c0: 6f 73 73 69 6c 5f 66 61 74 61 6c 28 22 63 6f 6e ossil_fatal("con
07d0: 74 65 6e 74 20 6d 69 73 73 69 6e 67 20 66 6f 72 tent missing for
07e0: 20 25 73 22 2c 20 7a 46 69 6c 65 6e 61 6d 65 29 %s", zFilename)
07f0: 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 ;. }else{.
0800: 20 20 20 63 68 61 72 20 2a 7a 55 75 69 64 20 3d char *zUuid =
0810: 20 64 62 5f 74 65 78 74 28 30 2c 20 22 53 45 4c db_text(0, "SEL
0820: 45 43 54 20 75 75 69 64 20 46 52 4f 4d 20 62 6c ECT uuid FROM bl
0830: 6f 62 20 57 48 45 52 45 20 72 69 64 3d 25 64 22 ob WHERE rid=%d"
0840: 2c 20 72 69 64 29 3b 0a 20 20 20 20 20 20 69 66 , rid);. if
0850: 28 20 7a 55 75 69 64 20 29 7b 0a 20 20 20 20 20 ( zUuid ){.
0860: 20 20 20 66 6f 73 73 69 6c 5f 66 61 74 61 6c 28 fossil_fatal(
0870: 22 63 6f 6e 74 65 6e 74 20 6d 69 73 73 69 6e 67 "content missing
0880: 20 66 6f 72 20 5b 25 2e 31 30 73 5d 22 2c 20 7a for [%.10s]", z
0890: 55 75 69 64 29 3b 0a 20 20 20 20 20 20 7d 65 6c Uuid);. }el
08a0: 73 65 7b 0a 20 20 20 20 20 20 20 20 66 6f 73 73 se{. foss
08b0: 69 6c 5f 70 61 6e 69 63 28 22 62 61 64 20 6f 62 il_panic("bad ob
08c0: 6a 65 63 74 20 69 64 3a 20 25 64 22 2c 20 72 69 ject id: %d", ri
08d0: 64 29 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 d);. }.
08e0: 7d 0a 20 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 42 }. }.}../*.** B
08f0: 75 69 6c 64 20 61 20 63 61 74 61 6c 6f 67 20 6f uild a catalog o
0900: 66 20 61 6c 6c 20 66 69 6c 65 73 20 69 6e 20 61 f all files in a
0910: 20 62 61 73 65 6c 69 6e 65 2e 0a 2a 2a 20 57 65 baseline..** We
0920: 20 73 63 61 6e 20 74 68 65 20 62 61 73 65 6c 69 scan the baseli
0930: 6e 65 20 66 69 6c 65 20 66 6f 72 20 6c 69 6e 65 ne file for line
0940: 73 20 6f 66 20 74 68 65 20 66 6f 72 6d 3a 0a 2a s of the form:.*
0950: 2a 0a 2a 2a 20 20 20 20 20 46 20 4e 41 4d 45 20 *.** F NAME
0960: 55 55 49 44 0a 2a 2a 0a 2a 2a 20 45 61 63 68 20 UUID.**.** Each
0970: 73 75 63 68 20 6c 69 6e 65 20 6d 61 6b 65 73 20 such line makes
0980: 61 6e 20 65 6e 74 72 79 20 69 6e 20 74 68 65 20 an entry in the
0990: 56 46 49 4c 45 20 74 61 62 6c 65 2e 0a 2a 2f 0a VFILE table..*/.
09a0: 76 6f 69 64 20 76 66 69 6c 65 5f 62 75 69 6c 64 void vfile_build
09b0: 28 69 6e 74 20 76 69 64 2c 20 42 6c 6f 62 20 2a (int vid, Blob *
09c0: 70 29 7b 0a 20 20 69 6e 74 20 72 69 64 3b 0a 20 p){. int rid;.
09d0: 20 63 68 61 72 20 2a 7a 4e 61 6d 65 2c 20 2a 7a char *zName, *z
09e0: 55 75 69 64 3b 0a 20 20 53 74 6d 74 20 69 6e 73 Uuid;. Stmt ins
09f0: 3b 0a 20 20 42 6c 6f 62 20 6c 69 6e 65 2c 20 74 ;. Blob line, t
0a00: 6f 6b 65 6e 2c 20 6e 61 6d 65 2c 20 75 75 69 64 oken, name, uuid
0a10: 3b 0a 20 20 69 6e 74 20 73 65 65 6e 48 65 61 64 ;. int seenHead
0a20: 65 72 20 3d 20 30 3b 0a 20 20 64 62 5f 62 65 67 er = 0;. db_beg
0a30: 69 6e 5f 74 72 61 6e 73 61 63 74 69 6f 6e 28 29 in_transaction()
0a40: 3b 0a 20 20 76 66 69 6c 65 5f 76 65 72 69 66 79 ;. vfile_verify
0a50: 5f 6e 6f 74 5f 70 68 61 6e 74 6f 6d 28 76 69 64 _not_phantom(vid
0a60: 2c 20 30 29 3b 0a 20 20 64 62 5f 6d 75 6c 74 69 , 0);. db_multi
0a70: 5f 65 78 65 63 28 22 44 45 4c 45 54 45 20 46 52 _exec("DELETE FR
0a80: 4f 4d 20 76 66 69 6c 65 20 57 48 45 52 45 20 76 OM vfile WHERE v
0a90: 69 64 3d 25 64 22 2c 20 76 69 64 29 3b 0a 20 20 id=%d", vid);.
0aa0: 64 62 5f 70 72 65 70 61 72 65 28 26 69 6e 73 2c db_prepare(&ins,
0ab0: 0a 20 20 20 20 22 49 4e 53 45 52 54 20 49 4e 54 . "INSERT INT
0ac0: 4f 20 76 66 69 6c 65 28 76 69 64 2c 72 69 64 2c O vfile(vid,rid,
0ad0: 6d 72 69 64 2c 70 61 74 68 6e 61 6d 65 29 20 22 mrid,pathname) "
0ae0: 0a 20 20 20 20 22 20 56 41 4c 55 45 53 28 3a 76 . " VALUES(:v
0af0: 69 64 2c 3a 69 64 2c 3a 69 64 2c 3a 6e 61 6d 65 id,:id,:id,:name
0b00: 29 22 29 3b 0a 20 20 64 62 5f 62 69 6e 64 5f 69 )");. db_bind_i
0b10: 6e 74 28 26 69 6e 73 2c 20 22 3a 76 69 64 22 2c nt(&ins, ":vid",
0b20: 20 76 69 64 29 3b 0a 20 20 77 68 69 6c 65 28 20 vid);. while(
0b30: 62 6c 6f 62 5f 6c 69 6e 65 28 70 2c 20 26 6c 69 blob_line(p, &li
0b40: 6e 65 29 20 29 7b 0a 20 20 20 20 63 68 61 72 20 ne) ){. char
0b50: 2a 7a 20 3d 20 62 6c 6f 62 5f 62 75 66 66 65 72 *z = blob_buffer
0b60: 28 26 6c 69 6e 65 29 3b 0a 20 20 20 20 69 66 28 (&line);. if(
0b70: 20 7a 5b 30 5d 3d 3d 27 2d 27 20 29 7b 0a 20 20 z[0]=='-' ){.
0b80: 20 20 20 20 69 66 28 20 73 65 65 6e 48 65 61 64 if( seenHead
0b90: 65 72 20 29 20 62 72 65 61 6b 3b 0a 20 20 20 20 er ) break;.
0ba0: 20 20 77 68 69 6c 65 28 20 62 6c 6f 62 5f 6c 69 while( blob_li
0bb0: 6e 65 28 70 2c 20 26 6c 69 6e 65 29 3e 31 20 29 ne(p, &line)>1 )
0bc0: 7b 7d 0a 20 20 20 20 20 20 69 66 28 20 62 6c 6f {}. if( blo
0bd0: 62 5f 6c 69 6e 65 28 70 2c 20 26 6c 69 6e 65 29 b_line(p, &line)
0be0: 3d 3d 30 20 29 20 62 72 65 61 6b 3b 0a 20 20 20 ==0 ) break;.
0bf0: 20 7d 0a 20 20 20 20 73 65 65 6e 48 65 61 64 65 }. seenHeade
0c00: 72 20 3d 20 31 3b 0a 20 20 20 20 69 66 28 20 7a r = 1;. if( z
0c10: 5b 30 5d 21 3d 27 46 27 20 7c 7c 20 7a 5b 31 5d [0]!='F' || z[1]
0c20: 21 3d 27 20 27 20 29 20 63 6f 6e 74 69 6e 75 65 !=' ' ) continue
0c30: 3b 0a 20 20 20 20 62 6c 6f 62 5f 74 6f 6b 65 6e ;. blob_token
0c40: 28 26 6c 69 6e 65 2c 20 26 74 6f 6b 65 6e 29 3b (&line, &token);
0c50: 20 20 2f 2a 20 53 6b 69 70 20 74 68 65 20 22 46 /* Skip the "F
0c60: 22 20 74 6f 6b 65 6e 20 2a 2f 0a 20 20 20 20 69 " token */. i
0c70: 66 28 20 62 6c 6f 62 5f 74 6f 6b 65 6e 28 26 6c f( blob_token(&l
0c80: 69 6e 65 2c 20 26 6e 61 6d 65 29 3d 3d 30 20 29 ine, &name)==0 )
0c90: 20 62 72 65 61 6b 3b 0a 20 20 20 20 69 66 28 20 break;. if(
0ca0: 62 6c 6f 62 5f 74 6f 6b 65 6e 28 26 6c 69 6e 65 blob_token(&line
0cb0: 2c 20 26 75 75 69 64 29 3d 3d 30 20 29 20 62 72 , &uuid)==0 ) br
0cc0: 65 61 6b 3b 0a 20 20 20 20 7a 4e 61 6d 65 20 3d eak;. zName =
0cd0: 20 62 6c 6f 62 5f 73 74 72 28 26 6e 61 6d 65 29 blob_str(&name)
0ce0: 3b 0a 20 20 20 20 64 65 66 6f 73 73 69 6c 69 7a ;. defossiliz
0cf0: 65 28 7a 4e 61 6d 65 29 3b 0a 20 20 20 20 7a 55 e(zName);. zU
0d00: 75 69 64 20 3d 20 62 6c 6f 62 5f 73 74 72 28 26 uid = blob_str(&
0d10: 75 75 69 64 29 3b 0a 20 20 20 20 72 69 64 20 3d uuid);. rid =
0d20: 20 75 75 69 64 5f 74 6f 5f 72 69 64 28 7a 55 75 uuid_to_rid(zUu
0d30: 69 64 2c 20 30 29 3b 0a 20 20 20 20 76 66 69 6c id, 0);. vfil
0d40: 65 5f 76 65 72 69 66 79 5f 6e 6f 74 5f 70 68 61 e_verify_not_pha
0d50: 6e 74 6f 6d 28 72 69 64 2c 20 7a 4e 61 6d 65 29 ntom(rid, zName)
0d60: 3b 0a 20 20 20 20 69 66 28 20 72 69 64 3e 30 20 ;. if( rid>0
0d70: 26 26 20 66 69 6c 65 5f 69 73 5f 73 69 6d 70 6c && file_is_simpl
0d80: 65 5f 70 61 74 68 6e 61 6d 65 28 7a 4e 61 6d 65 e_pathname(zName
0d90: 29 20 29 7b 0a 20 20 20 20 20 20 64 62 5f 62 69 ) ){. db_bi
0da0: 6e 64 5f 69 6e 74 28 26 69 6e 73 2c 20 22 3a 69 nd_int(&ins, ":i
0db0: 64 22 2c 20 72 69 64 29 3b 0a 20 20 20 20 20 20 d", rid);.
0dc0: 64 62 5f 62 69 6e 64 5f 74 65 78 74 28 26 69 6e db_bind_text(&in
0dd0: 73 2c 20 22 3a 6e 61 6d 65 22 2c 20 7a 4e 61 6d s, ":name", zNam
0de0: 65 29 3b 0a 20 20 20 20 20 20 64 62 5f 73 74 65 e);. db_ste
0df0: 70 28 26 69 6e 73 29 3b 0a 20 20 20 20 20 20 64 p(&ins);. d
0e00: 62 5f 72 65 73 65 74 28 26 69 6e 73 29 3b 0a 20 b_reset(&ins);.
0e10: 20 20 20 7d 0a 20 20 20 20 62 6c 6f 62 5f 72 65 }. blob_re
0e20: 73 65 74 28 26 6e 61 6d 65 29 3b 0a 20 20 20 20 set(&name);.
0e30: 62 6c 6f 62 5f 72 65 73 65 74 28 26 75 75 69 64 blob_reset(&uuid
0e40: 29 3b 0a 20 20 7d 0a 20 20 64 62 5f 66 69 6e 61 );. }. db_fina
0e50: 6c 69 7a 65 28 26 69 6e 73 29 3b 0a 20 20 64 62 lize(&ins);. db
0e60: 5f 65 6e 64 5f 74 72 61 6e 73 61 63 74 69 6f 6e _end_transaction
0e70: 28 30 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 68 (0);.}../*.** Ch
0e80: 65 63 6b 20 74 68 65 20 66 69 6c 65 20 73 69 67 eck the file sig
0e90: 6e 61 74 75 72 65 20 6f 66 20 74 68 65 20 64 69 nature of the di
0ea0: 73 6b 20 69 6d 61 67 65 20 66 6f 72 20 65 76 65 sk image for eve
0eb0: 72 79 20 56 46 49 4c 45 20 6f 66 20 76 69 64 2e ry VFILE of vid.
0ec0: 0a 2a 2a 0a 2a 2a 20 53 65 74 20 74 68 65 20 56 .**.** Set the V
0ed0: 46 49 4c 45 2e 43 48 4e 47 45 44 20 66 69 65 6c FILE.CHNGED fiel
0ee0: 64 20 6f 6e 20 65 76 65 72 79 20 66 69 6c 65 20 d on every file
0ef0: 74 68 61 74 20 68 61 73 20 63 68 61 6e 67 65 64 that has changed
0f00: 2e 20 20 41 6c 73 6f 20 0a 2a 2a 20 73 65 74 20 . Also .** set
0f10: 56 46 49 4c 45 2e 43 48 4e 47 45 44 20 6f 6e 20 VFILE.CHNGED on
0f20: 65 76 65 72 79 20 66 6f 6c 64 65 72 20 74 68 61 every folder tha
0f30: 74 20 63 6f 6e 74 61 69 6e 73 20 61 20 66 69 6c t contains a fil
0f40: 65 20 6f 72 20 66 6f 6c 64 65 72 20 0a 2a 2a 20 e or folder .**
0f50: 74 68 61 74 20 68 61 73 20 63 68 61 6e 67 65 64 that has changed
0f60: 2e 0a 2a 2a 0a 2a 2a 20 49 66 20 56 46 49 4c 45 ..**.** If VFILE
0f70: 2e 44 45 4c 45 54 45 44 20 69 73 20 6e 75 6c 6c .DELETED is null
0f80: 20 6f 72 20 69 66 20 56 46 49 4c 45 2e 52 49 44 or if VFILE.RID
0f90: 20 69 73 20 7a 65 72 6f 2c 20 74 68 65 6e 20 77 is zero, then w
0fa0: 65 20 63 61 6e 20 61 73 73 75 6d 65 0a 2a 2a 20 e can assume.**
0fb0: 74 68 65 20 66 69 6c 65 20 68 61 73 20 63 68 61 the file has cha
0fc0: 6e 67 65 64 20 77 69 74 68 6f 75 74 20 68 61 76 nged without hav
0fd0: 69 6e 67 20 74 68 65 20 63 68 65 63 6b 20 74 68 ing the check th
0fe0: 65 20 6f 6e 2d 64 69 73 6b 20 69 6d 61 67 65 2e e on-disk image.
0ff0: 0a 2a 2f 0a 76 6f 69 64 20 76 66 69 6c 65 5f 63 .*/.void vfile_c
1000: 68 65 63 6b 5f 73 69 67 6e 61 74 75 72 65 28 69 heck_signature(i
1010: 6e 74 20 76 69 64 29 7b 0a 20 20 53 74 6d 74 20 nt vid){. Stmt
1020: 71 3b 0a 20 20 42 6c 6f 62 20 66 69 6c 65 43 6b q;. Blob fileCk
1030: 73 75 6d 2c 20 6f 72 69 67 43 6b 73 75 6d 3b 0a sum, origCksum;.
1040: 0a 20 20 64 62 5f 62 65 67 69 6e 5f 74 72 61 6e . db_begin_tran
1050: 73 61 63 74 69 6f 6e 28 29 3b 0a 20 20 64 62 5f saction();. db_
1060: 70 72 65 70 61 72 65 28 26 71 2c 20 22 53 45 4c prepare(&q, "SEL
1070: 45 43 54 20 69 64 2c 20 25 51 20 7c 7c 20 70 61 ECT id, %Q || pa
1080: 74 68 6e 61 6d 65 2c 22 0a 20 20 20 20 20 20 20 thname,".
1090: 20 20 20 20 20 20 20 20 20 20 22 20 20 20 20 20 "
10a0: 20 20 76 66 69 6c 65 2e 6d 72 69 64 2c 20 64 65 vfile.mrid, de
10b0: 6c 65 74 65 64 2c 20 63 68 6e 67 65 64 2c 20 75 leted, chnged, u
10c0: 75 69 64 22 0a 20 20 20 20 20 20 20 20 20 20 20 uid".
10d0: 20 20 20 20 20 20 22 20 20 46 52 4f 4d 20 76 66 " FROM vf
10e0: 69 6c 65 20 4c 45 46 54 20 4a 4f 49 4e 20 62 6c ile LEFT JOIN bl
10f0: 6f 62 20 4f 4e 20 76 66 69 6c 65 2e 6d 72 69 64 ob ON vfile.mrid
1100: 3d 62 6c 6f 62 2e 72 69 64 22 0a 20 20 20 20 20 =blob.rid".
1110: 20 20 20 20 20 20 20 20 20 20 20 20 22 20 57 48 " WH
1120: 45 52 45 20 76 69 64 3d 25 64 20 22 2c 20 67 2e ERE vid=%d ", g.
1130: 7a 4c 6f 63 61 6c 52 6f 6f 74 2c 20 76 69 64 29 zLocalRoot, vid)
1140: 3b 0a 20 20 77 68 69 6c 65 28 20 64 62 5f 73 74 ;. while( db_st
1150: 65 70 28 26 71 29 3d 3d 53 51 4c 49 54 45 5f 52 ep(&q)==SQLITE_R
1160: 4f 57 20 29 7b 0a 20 20 20 20 69 6e 74 20 69 64 OW ){. int id
1170: 2c 20 72 69 64 2c 20 69 73 44 65 6c 65 74 65 64 , rid, isDeleted
1180: 3b 0a 20 20 20 20 63 6f 6e 73 74 20 63 68 61 72 ;. const char
1190: 20 2a 7a 4e 61 6d 65 3b 0a 20 20 20 20 69 6e 74 *zName;. int
11a0: 20 63 68 6e 67 65 64 20 3d 20 30 3b 0a 20 20 20 chnged = 0;.
11b0: 20 69 6e 74 20 6f 6c 64 43 68 6e 67 65 64 3b 0a int oldChnged;.
11c0: 0a 20 20 20 20 69 64 20 3d 20 64 62 5f 63 6f 6c . id = db_col
11d0: 75 6d 6e 5f 69 6e 74 28 26 71 2c 20 30 29 3b 0a umn_int(&q, 0);.
11e0: 20 20 20 20 7a 4e 61 6d 65 20 3d 20 64 62 5f 63 zName = db_c
11f0: 6f 6c 75 6d 6e 5f 74 65 78 74 28 26 71 2c 20 31 olumn_text(&q, 1
1200: 29 3b 0a 20 20 20 20 72 69 64 20 3d 20 64 62 5f );. rid = db_
1210: 63 6f 6c 75 6d 6e 5f 69 6e 74 28 26 71 2c 20 32 column_int(&q, 2
1220: 29 3b 0a 20 20 20 20 69 73 44 65 6c 65 74 65 64 );. isDeleted
1230: 20 3d 20 64 62 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 = db_column_int
1240: 28 26 71 2c 20 33 29 3b 0a 20 20 20 20 6f 6c 64 (&q, 3);. old
1250: 43 68 6e 67 65 64 20 3d 20 64 62 5f 63 6f 6c 75 Chnged = db_colu
1260: 6d 6e 5f 69 6e 74 28 26 71 2c 20 34 29 3b 0a 20 mn_int(&q, 4);.
1270: 20 20 20 69 66 28 20 6f 6c 64 43 68 6e 67 65 64 if( oldChnged
1280: 3e 3d 32 20 29 7b 0a 20 20 20 20 20 20 63 68 6e >=2 ){. chn
1290: 67 65 64 20 3d 20 6f 6c 64 43 68 6e 67 65 64 3b ged = oldChnged;
12a0: 0a 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 69 . }else if( i
12b0: 73 44 65 6c 65 74 65 64 20 7c 7c 20 72 69 64 3d sDeleted || rid=
12c0: 3d 30 20 29 7b 0a 20 20 20 20 20 20 63 68 6e 67 =0 ){. chng
12d0: 65 64 20 3d 20 31 3b 0a 20 20 20 20 7d 0a 20 20 ed = 1;. }.
12e0: 20 20 69 66 28 20 63 68 6e 67 65 64 21 3d 31 20 if( chnged!=1
12f0: 29 7b 0a 20 20 20 20 20 20 64 62 5f 65 70 68 65 ){. db_ephe
1300: 6d 65 72 61 6c 5f 62 6c 6f 62 28 26 71 2c 20 35 meral_blob(&q, 5
1310: 2c 20 26 6f 72 69 67 43 6b 73 75 6d 29 3b 0a 20 , &origCksum);.
1320: 20 20 20 20 20 69 66 28 20 73 68 61 31 73 75 6d if( sha1sum
1330: 5f 66 69 6c 65 28 7a 4e 61 6d 65 2c 20 26 66 69 _file(zName, &fi
1340: 6c 65 43 6b 73 75 6d 29 20 29 7b 0a 20 20 20 20 leCksum) ){.
1350: 20 20 20 20 62 6c 6f 62 5f 7a 65 72 6f 28 26 66 blob_zero(&f
1360: 69 6c 65 43 6b 73 75 6d 29 3b 0a 20 20 20 20 20 ileCksum);.
1370: 20 7d 0a 20 20 20 20 20 20 69 66 28 20 62 6c 6f }. if( blo
1380: 62 5f 63 6f 6d 70 61 72 65 28 26 66 69 6c 65 43 b_compare(&fileC
1390: 6b 73 75 6d 2c 20 26 6f 72 69 67 43 6b 73 75 6d ksum, &origCksum
13a0: 29 20 29 7b 0a 20 20 20 20 20 20 20 20 63 68 6e ) ){. chn
13b0: 67 65 64 20 3d 20 31 3b 0a 20 20 20 20 20 20 7d ged = 1;. }
13c0: 0a 20 20 20 20 20 20 62 6c 6f 62 5f 72 65 73 65 . blob_rese
13d0: 74 28 26 6f 72 69 67 43 6b 73 75 6d 29 3b 0a 20 t(&origCksum);.
13e0: 20 20 20 20 20 62 6c 6f 62 5f 72 65 73 65 74 28 blob_reset(
13f0: 26 66 69 6c 65 43 6b 73 75 6d 29 3b 0a 20 20 20 &fileCksum);.
1400: 20 7d 0a 20 20 20 20 69 66 28 20 63 68 6e 67 65 }. if( chnge
1410: 64 21 3d 6f 6c 64 43 68 6e 67 65 64 20 29 7b 0a d!=oldChnged ){.
1420: 20 20 20 20 20 20 64 62 5f 6d 75 6c 74 69 5f 65 db_multi_e
1430: 78 65 63 28 22 55 50 44 41 54 45 20 76 66 69 6c xec("UPDATE vfil
1440: 65 20 53 45 54 20 63 68 6e 67 65 64 3d 25 64 20 e SET chnged=%d
1450: 57 48 45 52 45 20 69 64 3d 25 64 22 2c 20 63 68 WHERE id=%d", ch
1460: 6e 67 65 64 2c 20 69 64 29 3b 0a 20 20 20 20 7d nged, id);. }
1470: 0a 20 20 7d 0a 20 20 64 62 5f 66 69 6e 61 6c 69 . }. db_finali
1480: 7a 65 28 26 71 29 3b 0a 20 20 64 62 5f 65 6e 64 ze(&q);. db_end
1490: 5f 74 72 61 6e 73 61 63 74 69 6f 6e 28 30 29 3b _transaction(0);
14a0: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 57 72 69 74 65 20 .}../*.** Write
14b0: 61 6c 6c 20 66 69 6c 65 73 20 66 72 6f 6d 20 76 all files from v
14c0: 69 64 20 74 6f 20 74 68 65 20 64 69 73 6b 2e 20 id to the disk.
14d0: 20 4f 72 20 69 66 20 76 69 64 3d 3d 30 20 61 6e Or if vid==0 an
14e0: 64 20 69 64 21 3d 30 0a 2a 2a 20 77 72 69 74 65 d id!=0.** write
14f0: 20 6a 75 73 74 20 74 68 65 20 73 70 65 63 69 66 just the specif
1500: 69 63 20 66 69 6c 65 20 77 68 65 72 65 20 56 46 ic file where VF
1510: 49 4c 45 2e 49 44 3d 69 64 2e 0a 2a 2f 0a 76 6f ILE.ID=id..*/.vo
1520: 69 64 20 76 66 69 6c 65 5f 74 6f 5f 64 69 73 6b id vfile_to_disk
1530: 28 69 6e 74 20 76 69 64 2c 20 69 6e 74 20 69 64 (int vid, int id
1540: 2c 20 69 6e 74 20 76 65 72 62 6f 73 65 29 7b 0a , int verbose){.
1550: 20 20 53 74 6d 74 20 71 3b 0a 20 20 42 6c 6f 62 Stmt q;. Blob
1560: 20 63 6f 6e 74 65 6e 74 3b 0a 20 20 69 6e 74 20 content;. int
1570: 6e 52 65 70 6f 73 20 3d 20 73 74 72 6c 65 6e 28 nRepos = strlen(
1580: 67 2e 7a 4c 6f 63 61 6c 52 6f 6f 74 29 3b 0a 0a g.zLocalRoot);..
1590: 20 20 69 66 28 20 76 69 64 3e 30 20 26 26 20 69 if( vid>0 && i
15a0: 64 3d 3d 30 20 29 7b 0a 20 20 20 20 64 62 5f 70 d==0 ){. db_p
15b0: 72 65 70 61 72 65 28 26 71 2c 20 22 53 45 4c 45 repare(&q, "SELE
15c0: 43 54 20 69 64 2c 20 25 51 20 7c 7c 20 70 61 74 CT id, %Q || pat
15d0: 68 6e 61 6d 65 2c 20 6d 72 69 64 22 0a 20 20 20 hname, mrid".
15e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
15f0: 22 20 20 46 52 4f 4d 20 76 66 69 6c 65 22 0a 20 " FROM vfile".
1600: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1610: 20 20 22 20 57 48 45 52 45 20 76 69 64 3d 25 64 " WHERE vid=%d
1620: 20 41 4e 44 20 6d 72 69 64 3e 30 22 2c 0a 20 20 AND mrid>0",.
1630: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1640: 20 67 2e 7a 4c 6f 63 61 6c 52 6f 6f 74 2c 20 76 g.zLocalRoot, v
1650: 69 64 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20 20 id);. }else{.
1660: 20 20 61 73 73 65 72 74 28 20 76 69 64 3d 3d 30 assert( vid==0
1670: 20 26 26 20 69 64 3e 30 20 29 3b 0a 20 20 20 20 && id>0 );.
1680: 64 62 5f 70 72 65 70 61 72 65 28 26 71 2c 20 22 db_prepare(&q, "
1690: 53 45 4c 45 43 54 20 69 64 2c 20 25 51 20 7c 7c SELECT id, %Q ||
16a0: 20 70 61 74 68 6e 61 6d 65 2c 20 6d 72 69 64 22 pathname, mrid"
16b0: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 .
16c0: 20 20 20 20 22 20 20 46 52 4f 4d 20 76 66 69 6c " FROM vfil
16d0: 65 22 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 e".
16e0: 20 20 20 20 20 20 22 20 57 48 45 52 45 20 69 64 " WHERE id
16f0: 3d 25 64 20 41 4e 44 20 6d 72 69 64 3e 30 22 2c =%d AND mrid>0",
1700: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 .
1710: 20 20 20 20 67 2e 7a 4c 6f 63 61 6c 52 6f 6f 74 g.zLocalRoot
1720: 2c 20 69 64 29 3b 0a 20 20 7d 0a 20 20 77 68 69 , id);. }. whi
1730: 6c 65 28 20 64 62 5f 73 74 65 70 28 26 71 29 3d le( db_step(&q)=
1740: 3d 53 51 4c 49 54 45 5f 52 4f 57 20 29 7b 0a 20 =SQLITE_ROW ){.
1750: 20 20 20 69 6e 74 20 69 64 2c 20 72 69 64 3b 0a int id, rid;.
1760: 20 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a const char *
1770: 7a 4e 61 6d 65 3b 0a 0a 20 20 20 20 69 64 20 3d zName;.. id =
1780: 20 64 62 5f 63 6f 6c 75 6d 6e 5f 69 6e 74 28 26 db_column_int(&
1790: 71 2c 20 30 29 3b 0a 20 20 20 20 7a 4e 61 6d 65 q, 0);. zName
17a0: 20 3d 20 64 62 5f 63 6f 6c 75 6d 6e 5f 74 65 78 = db_column_tex
17b0: 74 28 26 71 2c 20 31 29 3b 0a 20 20 20 20 72 69 t(&q, 1);. ri
17c0: 64 20 3d 20 64 62 5f 63 6f 6c 75 6d 6e 5f 69 6e d = db_column_in
17d0: 74 28 26 71 2c 20 32 29 3b 0a 20 20 20 20 63 6f t(&q, 2);. co
17e0: 6e 74 65 6e 74 5f 67 65 74 28 72 69 64 2c 20 26 ntent_get(rid, &
17f0: 63 6f 6e 74 65 6e 74 29 3b 0a 20 20 20 20 69 66 content);. if
1800: 28 20 76 65 72 62 6f 73 65 20 29 20 70 72 69 6e ( verbose ) prin
1810: 74 66 28 22 25 73 5c 6e 22 2c 20 26 7a 4e 61 6d tf("%s\n", &zNam
1820: 65 5b 6e 52 65 70 6f 73 5d 29 3b 0a 20 20 20 20 e[nRepos]);.
1830: 62 6c 6f 62 5f 77 72 69 74 65 5f 74 6f 5f 66 69 blob_write_to_fi
1840: 6c 65 28 26 63 6f 6e 74 65 6e 74 2c 20 7a 4e 61 le(&content, zNa
1850: 6d 65 29 3b 0a 20 20 7d 0a 20 20 64 62 5f 66 69 me);. }. db_fi
1860: 6e 61 6c 69 7a 65 28 26 71 29 3b 0a 7d 0a 0a 0a nalize(&q);.}...
1870: 2f 2a 0a 2a 2a 20 44 65 6c 65 74 65 20 66 72 6f /*.** Delete fro
1880: 6d 20 74 68 65 20 64 69 73 6b 20 65 76 65 72 79 m the disk every
1890: 20 66 69 6c 65 20 69 6e 20 56 46 49 4c 45 20 76 file in VFILE v
18a0: 69 64 2e 0a 2a 2f 0a 76 6f 69 64 20 76 66 69 6c id..*/.void vfil
18b0: 65 5f 75 6e 6c 69 6e 6b 28 69 6e 74 20 76 69 64 e_unlink(int vid
18c0: 29 7b 0a 20 20 53 74 6d 74 20 71 3b 0a 20 20 64 ){. Stmt q;. d
18d0: 62 5f 70 72 65 70 61 72 65 28 26 71 2c 20 22 53 b_prepare(&q, "S
18e0: 45 4c 45 43 54 20 25 51 20 7c 7c 20 70 61 74 68 ELECT %Q || path
18f0: 6e 61 6d 65 20 46 52 4f 4d 20 76 66 69 6c 65 22 name FROM vfile"
1900: 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 .
1910: 20 20 22 20 57 48 45 52 45 20 76 69 64 3d 25 64 " WHERE vid=%d
1920: 20 41 4e 44 20 6d 72 69 64 3e 30 22 2c 20 67 2e AND mrid>0", g.
1930: 7a 4c 6f 63 61 6c 52 6f 6f 74 2c 20 76 69 64 29 zLocalRoot, vid)
1940: 3b 0a 20 20 77 68 69 6c 65 28 20 64 62 5f 73 74 ;. while( db_st
1950: 65 70 28 26 71 29 3d 3d 53 51 4c 49 54 45 5f 52 ep(&q)==SQLITE_R
1960: 4f 57 20 29 7b 0a 20 20 20 20 63 6f 6e 73 74 20 OW ){. const
1970: 63 68 61 72 20 2a 7a 4e 61 6d 65 3b 0a 0a 20 20 char *zName;..
1980: 20 20 7a 4e 61 6d 65 20 3d 20 64 62 5f 63 6f 6c zName = db_col
1990: 75 6d 6e 5f 74 65 78 74 28 26 71 2c 20 30 29 3b umn_text(&q, 0);
19a0: 0a 20 20 20 20 75 6e 6c 69 6e 6b 28 7a 4e 61 6d . unlink(zNam
19b0: 65 29 3b 0a 20 20 7d 0a 20 20 64 62 5f 66 69 6e e);. }. db_fin
19c0: 61 6c 69 7a 65 28 26 71 29 3b 0a 7d 0a 0a 2f 2a alize(&q);.}../*
19d0: 0a 2a 2a 20 4c 6f 61 64 20 69 6e 74 6f 20 74 61 .** Load into ta
19e0: 62 6c 65 20 53 46 49 4c 45 20 74 68 65 20 6e 61 ble SFILE the na
19f0: 6d 65 20 6f 66 20 65 76 65 72 79 20 6f 72 64 69 me of every ordi
1a00: 6e 61 72 79 20 66 69 6c 65 20 69 6e 0a 2a 2a 20 nary file in.**
1a10: 74 68 65 20 64 69 72 65 63 74 6f 72 79 20 70 50 the directory pP
1a20: 61 74 68 2e 20 20 53 75 62 64 69 72 65 63 74 6f ath. Subdirecto
1a30: 72 69 65 73 20 61 72 65 20 73 63 61 6e 6e 65 64 ries are scanned
1a40: 20 72 65 63 75 72 73 69 76 65 6c 79 2e 0a 2a 2a recursively..**
1a50: 20 4f 6d 69 74 20 66 69 6c 65 73 20 6e 61 6d 65 Omit files name
1a60: 64 20 69 6e 20 56 46 49 4c 45 2e 76 69 64 0a 2a d in VFILE.vid.*
1a70: 2f 0a 76 6f 69 64 20 76 66 69 6c 65 5f 73 63 61 /.void vfile_sca
1a80: 6e 28 69 6e 74 20 76 69 64 2c 20 42 6c 6f 62 20 n(int vid, Blob
1a90: 2a 70 50 61 74 68 29 7b 0a 20 20 44 49 52 20 2a *pPath){. DIR *
1aa0: 64 3b 0a 20 20 69 6e 74 20 6f 72 69 67 53 69 7a d;. int origSiz
1ab0: 65 3b 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 e;. const char
1ac0: 2a 7a 44 69 72 3b 0a 20 20 63 6f 6e 73 74 20 63 *zDir;. const c
1ad0: 68 61 72 20 2a 7a 46 6f 72 6d 61 74 3b 0a 20 20 har *zFormat;.
1ae0: 73 74 72 75 63 74 20 64 69 72 65 6e 74 20 2a 70 struct dirent *p
1af0: 45 6e 74 72 79 3b 0a 20 20 73 74 61 74 69 63 20 Entry;. static
1b00: 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 53 71 6c const char *zSql
1b10: 20 3d 20 22 53 45 4c 45 43 54 20 31 20 46 52 4f = "SELECT 1 FRO
1b20: 4d 20 76 66 69 6c 65 20 22 0a 20 20 20 20 20 20 M vfile ".
1b30: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
1b40: 20 20 20 20 20 20 22 20 57 48 45 52 45 20 70 61 " WHERE pa
1b50: 74 68 6e 61 6d 65 3d 25 42 20 41 4e 44 20 4e 4f thname=%B AND NO
1b60: 54 20 64 65 6c 65 74 65 64 22 3b 0a 0a 20 20 6f T deleted";.. o
1b70: 72 69 67 53 69 7a 65 20 3d 20 62 6c 6f 62 5f 73 rigSize = blob_s
1b80: 69 7a 65 28 70 50 61 74 68 29 3b 0a 20 20 7a 44 ize(pPath);. zD
1b90: 69 72 20 3d 20 62 6c 6f 62 5f 73 74 72 28 70 50 ir = blob_str(pP
1ba0: 61 74 68 29 3b 0a 20 20 69 66 28 20 7a 44 69 72 ath);. if( zDir
1bb0: 5b 30 5d 3d 3d 30 20 29 7b 0a 20 20 20 20 20 7a [0]==0 ){. z
1bc0: 44 69 72 20 3d 20 22 2e 22 3b 0a 20 20 20 20 20 Dir = ".";.
1bd0: 7a 46 6f 72 6d 61 74 20 3d 20 22 25 73 22 3b 0a zFormat = "%s";.
1be0: 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 7a 46 }else{. zF
1bf0: 6f 72 6d 61 74 20 3d 20 22 2f 25 73 22 3b 0a 20 ormat = "/%s";.
1c00: 20 7d 0a 20 20 64 20 3d 20 6f 70 65 6e 64 69 72 }. d = opendir
1c10: 28 7a 44 69 72 29 3b 0a 20 20 69 66 28 20 64 20 (zDir);. if( d
1c20: 29 7b 0a 20 20 20 20 77 68 69 6c 65 28 20 28 70 ){. while( (p
1c30: 45 6e 74 72 79 3d 72 65 61 64 64 69 72 28 64 29 Entry=readdir(d)
1c40: 29 21 3d 30 20 29 7b 0a 20 20 20 20 20 20 63 68 )!=0 ){. ch
1c50: 61 72 20 2a 7a 50 61 74 68 3b 0a 20 20 20 20 20 ar *zPath;.
1c60: 20 69 66 28 20 70 45 6e 74 72 79 2d 3e 64 5f 6e if( pEntry->d_n
1c70: 61 6d 65 5b 30 5d 3d 3d 27 2e 27 20 29 20 63 6f ame[0]=='.' ) co
1c80: 6e 74 69 6e 75 65 3b 0a 20 20 20 20 20 20 62 6c ntinue;. bl
1c90: 6f 62 5f 61 70 70 65 6e 64 66 28 70 50 61 74 68 ob_appendf(pPath
1ca0: 2c 20 7a 46 6f 72 6d 61 74 2c 20 70 45 6e 74 72 , zFormat, pEntr
1cb0: 79 2d 3e 64 5f 6e 61 6d 65 29 3b 0a 20 20 20 20 y->d_name);.
1cc0: 20 20 7a 50 61 74 68 20 3d 20 62 6c 6f 62 5f 73 zPath = blob_s
1cd0: 74 72 28 70 50 61 74 68 29 3b 0a 20 20 20 20 20 tr(pPath);.
1ce0: 20 69 66 28 20 66 69 6c 65 5f 69 73 64 69 72 28 if( file_isdir(
1cf0: 7a 50 61 74 68 29 3d 3d 31 20 29 7b 0a 20 20 20 zPath)==1 ){.
1d00: 20 20 20 20 20 76 66 69 6c 65 5f 73 63 61 6e 28 vfile_scan(
1d10: 76 69 64 2c 20 70 50 61 74 68 29 3b 0a 20 20 20 vid, pPath);.
1d20: 20 20 20 7d 65 6c 73 65 20 69 66 28 20 66 69 6c }else if( fil
1d30: 65 5f 69 73 66 69 6c 65 28 7a 50 61 74 68 29 20 e_isfile(zPath)
1d40: 26 26 20 21 64 62 5f 65 78 69 73 74 73 28 7a 53 && !db_exists(zS
1d50: 71 6c 2c 70 50 61 74 68 29 20 29 7b 0a 20 20 20 ql,pPath) ){.
1d60: 20 20 20 20 20 64 62 5f 6d 75 6c 74 69 5f 65 78 db_multi_ex
1d70: 65 63 28 22 49 4e 53 45 52 54 20 49 4e 54 4f 20 ec("INSERT INTO
1d80: 73 66 69 6c 65 20 56 41 4c 55 45 53 28 25 42 29 sfile VALUES(%B)
1d90: 22 2c 20 70 50 61 74 68 29 3b 0a 20 20 20 20 20 ", pPath);.
1da0: 20 7d 0a 20 20 20 20 20 20 62 6c 6f 62 5f 72 65 }. blob_re
1db0: 73 69 7a 65 28 70 50 61 74 68 2c 20 6f 72 69 67 size(pPath, orig
1dc0: 53 69 7a 65 29 3b 0a 20 20 20 20 7d 0a 20 20 7d Size);. }. }
1dd0: 0a 20 20 63 6c 6f 73 65 64 69 72 28 64 29 3b 0a . closedir(d);.
1de0: 7d 0a 0a 2f 2a 0a 2a 2a 20 43 6f 6d 70 75 74 65 }../*.** Compute
1df0: 20 61 6e 20 61 67 67 72 65 67 61 74 65 20 4d 44 an aggregate MD
1e00: 35 20 63 68 65 63 6b 73 75 6d 20 6f 76 65 72 20 5 checksum over
1e10: 74 68 65 20 64 69 73 6b 20 69 6d 61 67 65 20 6f the disk image o
1e20: 66 20 65 76 65 72 79 0a 2a 2a 20 66 69 6c 65 20 f every.** file
1e30: 69 6e 20 76 69 64 2e 20 20 54 68 65 20 66 69 6c in vid. The fil
1e40: 65 20 6e 61 6d 65 73 20 61 72 65 20 70 61 72 74 e names are part
1e50: 20 6f 66 20 74 68 65 20 63 68 65 63 6b 73 75 6d of the checksum
1e60: 2e 0a 2a 2a 0a 2a 2a 20 54 68 69 73 20 66 75 6e ..**.** This fun
1e70: 63 74 69 6f 6e 20 6f 70 65 72 61 74 65 73 20 64 ction operates d
1e80: 69 66 66 65 72 65 6e 74 6c 79 20 69 66 20 74 68 ifferently if th
1e90: 65 20 47 6c 6f 62 61 6c 2e 61 43 6f 6d 6d 69 74 e Global.aCommit
1ea0: 46 69 6c 65 0a 2a 2a 20 76 61 72 69 61 62 6c 65 File.** variable
1eb0: 20 69 73 20 6e 6f 74 20 4e 55 4c 4c 2e 20 49 6e is not NULL. In
1ec0: 20 74 68 61 74 20 63 61 73 65 2c 20 74 68 65 20 that case, the
1ed0: 64 69 73 6b 20 69 6d 61 67 65 20 69 73 20 75 73 disk image is us
1ee0: 65 64 20 66 6f 72 0a 2a 2a 20 65 61 63 68 20 66 ed for.** each f
1ef0: 69 6c 65 20 69 6e 20 61 43 6f 6d 6d 69 74 46 69 ile in aCommitFi
1f00: 6c 65 5b 5d 20 61 6e 64 20 74 68 65 20 72 65 70 le[] and the rep
1f10: 6f 73 69 74 6f 72 79 20 69 6d 61 67 65 20 28 73 ository image (s
1f20: 65 65 0a 2a 2a 20 76 66 69 6c 65 5f 61 67 67 72 ee.** vfile_aggr
1f30: 65 67 61 74 65 5f 63 68 65 63 6b 73 75 6d 5f 72 egate_checksum_r
1f40: 65 70 6f 73 69 74 6f 72 79 28 29 20 69 73 20 75 epository() is u
1f50: 73 65 64 20 66 6f 72 20 61 6c 6c 20 6f 74 68 65 sed for all othe
1f60: 72 73 29 2e 0a 2a 2a 20 4e 65 77 6c 79 20 61 64 rs)..** Newly ad
1f70: 64 65 64 20 66 69 6c 65 73 20 74 68 61 74 20 61 ded files that a
1f80: 72 65 20 6e 6f 74 20 63 6f 6e 74 61 69 6e 65 64 re not contained
1f90: 20 69 6e 20 74 68 65 20 72 65 70 6f 73 69 74 6f in the reposito
1fa0: 72 79 20 61 72 65 0a 2a 2a 20 6f 6d 69 74 74 65 ry are.** omitte
1fb0: 64 20 66 72 6f 6d 20 74 68 65 20 63 68 65 63 6b d from the check
1fc0: 73 75 6d 20 69 66 20 74 68 65 79 20 61 72 65 20 sum if they are
1fd0: 6e 6f 74 20 69 6e 20 47 6c 6f 62 61 6c 2e 61 43 not in Global.aC
1fe0: 6f 6d 6d 69 74 46 69 6c 65 2e 0a 2a 2a 0a 2a 2a ommitFile..**.**
1ff0: 20 52 65 74 75 72 6e 20 74 68 65 20 72 65 73 75 Return the resu
2000: 6c 74 69 6e 67 20 63 68 65 63 6b 73 75 6d 20 69 lting checksum i
2010: 6e 20 62 6c 6f 62 20 70 4f 75 74 2e 0a 2a 2f 0a n blob pOut..*/.
2020: 76 6f 69 64 20 76 66 69 6c 65 5f 61 67 67 72 65 void vfile_aggre
2030: 67 61 74 65 5f 63 68 65 63 6b 73 75 6d 5f 64 69 gate_checksum_di
2040: 73 6b 28 69 6e 74 20 76 69 64 2c 20 42 6c 6f 62 sk(int vid, Blob
2050: 20 2a 70 4f 75 74 29 7b 0a 20 20 46 49 4c 45 20 *pOut){. FILE
2060: 2a 69 6e 3b 0a 20 20 53 74 6d 74 20 71 3b 0a 20 *in;. Stmt q;.
2070: 20 63 68 61 72 20 7a 42 75 66 5b 34 30 39 36 5d char zBuf[4096]
2080: 3b 0a 0a 20 20 64 62 5f 6d 75 73 74 5f 62 65 5f ;.. db_must_be_
2090: 77 69 74 68 69 6e 5f 74 72 65 65 28 29 3b 0a 20 within_tree();.
20a0: 20 64 62 5f 70 72 65 70 61 72 65 28 26 71 2c 20 db_prepare(&q,
20b0: 0a 20 20 20 20 20 20 22 53 45 4c 45 43 54 20 25 . "SELECT %
20c0: 51 20 7c 7c 20 70 61 74 68 6e 61 6d 65 2c 20 70 Q || pathname, p
20d0: 61 74 68 6e 61 6d 65 2c 20 66 69 6c 65 5f 69 73 athname, file_is
20e0: 5f 73 65 6c 65 63 74 65 64 28 69 64 29 2c 20 72 _selected(id), r
20f0: 69 64 20 46 52 4f 4d 20 76 66 69 6c 65 22 0a 20 id FROM vfile".
2100: 20 20 20 20 20 22 20 57 48 45 52 45 20 4e 4f 54 " WHERE NOT
2110: 20 64 65 6c 65 74 65 64 20 41 4e 44 20 76 69 64 deleted AND vid
2120: 3d 25 64 22 0a 20 20 20 20 20 20 22 20 4f 52 44 =%d". " ORD
2130: 45 52 20 42 59 20 70 61 74 68 6e 61 6d 65 22 2c ER BY pathname",
2140: 0a 20 20 20 20 20 20 67 2e 7a 4c 6f 63 61 6c 52 . g.zLocalR
2150: 6f 6f 74 2c 20 76 69 64 0a 20 20 29 3b 0a 20 20 oot, vid. );.
2160: 6d 64 35 73 75 6d 5f 69 6e 69 74 28 29 3b 0a 20 md5sum_init();.
2170: 20 77 68 69 6c 65 28 20 64 62 5f 73 74 65 70 28 while( db_step(
2180: 26 71 29 3d 3d 53 51 4c 49 54 45 5f 52 4f 57 20 &q)==SQLITE_ROW
2190: 29 7b 0a 20 20 20 20 63 6f 6e 73 74 20 63 68 61 ){. const cha
21a0: 72 20 2a 7a 46 75 6c 6c 70 61 74 68 20 3d 20 64 r *zFullpath = d
21b0: 62 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 28 26 71 b_column_text(&q
21c0: 2c 20 30 29 3b 0a 20 20 20 20 63 6f 6e 73 74 20 , 0);. const
21d0: 63 68 61 72 20 2a 7a 4e 61 6d 65 20 3d 20 64 62 char *zName = db
21e0: 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 28 26 71 2c _column_text(&q,
21f0: 20 31 29 3b 0a 20 20 20 20 69 6e 74 20 69 73 53 1);. int isS
2200: 65 6c 65 63 74 65 64 20 3d 20 64 62 5f 63 6f 6c elected = db_col
2210: 75 6d 6e 5f 69 6e 74 28 26 71 2c 20 32 29 3b 0a umn_int(&q, 2);.
2220: 0a 20 20 20 20 69 66 28 20 69 73 53 65 6c 65 63 . if( isSelec
2230: 74 65 64 20 29 7b 0a 20 20 20 20 20 20 6d 64 35 ted ){. md5
2240: 73 75 6d 5f 73 74 65 70 5f 74 65 78 74 28 7a 4e sum_step_text(zN
2250: 61 6d 65 2c 20 2d 31 29 3b 0a 20 20 20 20 20 20 ame, -1);.
2260: 69 6e 20 3d 20 66 6f 70 65 6e 28 7a 46 75 6c 6c in = fopen(zFull
2270: 70 61 74 68 2c 22 72 62 22 29 3b 0a 20 20 20 20 path,"rb");.
2280: 20 20 69 66 28 20 69 6e 3d 3d 30 20 29 7b 0a 20 if( in==0 ){.
2290: 20 20 20 20 20 20 20 6d 64 35 73 75 6d 5f 73 74 md5sum_st
22a0: 65 70 5f 74 65 78 74 28 22 20 30 5c 6e 22 2c 20 ep_text(" 0\n",
22b0: 2d 31 29 3b 0a 20 20 20 20 20 20 20 20 63 6f 6e -1);. con
22c0: 74 69 6e 75 65 3b 0a 20 20 20 20 20 20 7d 0a 20 tinue;. }.
22d0: 20 20 20 20 20 66 73 65 65 6b 28 69 6e 2c 20 30 fseek(in, 0
22e0: 4c 2c 20 53 45 45 4b 5f 45 4e 44 29 3b 0a 20 20 L, SEEK_END);.
22f0: 20 20 20 20 73 70 72 69 6e 74 66 28 7a 42 75 66 sprintf(zBuf
2300: 2c 20 22 20 25 6c 64 5c 6e 22 2c 20 66 74 65 6c , " %ld\n", ftel
2310: 6c 28 69 6e 29 29 3b 0a 20 20 20 20 20 20 66 73 l(in));. fs
2320: 65 65 6b 28 69 6e 2c 20 30 4c 2c 20 53 45 45 4b eek(in, 0L, SEEK
2330: 5f 53 45 54 29 3b 0a 20 20 20 20 20 20 6d 64 35 _SET);. md5
2340: 73 75 6d 5f 73 74 65 70 5f 74 65 78 74 28 7a 42 sum_step_text(zB
2350: 75 66 2c 20 2d 31 29 3b 0a 20 20 20 20 20 20 66 uf, -1);. f
2360: 6f 72 28 3b 3b 29 7b 0a 20 20 20 20 20 20 20 20 or(;;){.
2370: 69 6e 74 20 6e 3b 0a 20 20 20 20 20 20 20 20 6e int n;. n
2380: 20 3d 20 66 72 65 61 64 28 7a 42 75 66 2c 20 31 = fread(zBuf, 1
2390: 2c 20 73 69 7a 65 6f 66 28 7a 42 75 66 29 2c 20 , sizeof(zBuf),
23a0: 69 6e 29 3b 0a 20 20 20 20 20 20 20 20 69 66 28 in);. if(
23b0: 20 6e 3c 3d 30 20 29 20 62 72 65 61 6b 3b 0a 20 n<=0 ) break;.
23c0: 20 20 20 20 20 20 20 6d 64 35 73 75 6d 5f 73 74 md5sum_st
23d0: 65 70 5f 74 65 78 74 28 7a 42 75 66 2c 20 6e 29 ep_text(zBuf, n)
23e0: 3b 0a 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 ;. }.
23f0: 66 63 6c 6f 73 65 28 69 6e 29 3b 0a 20 20 20 20 fclose(in);.
2400: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 69 6e 74 }else{. int
2410: 20 72 69 64 20 3d 20 64 62 5f 63 6f 6c 75 6d 6e rid = db_column
2420: 5f 69 6e 74 28 26 71 2c 20 33 29 3b 0a 20 20 20 _int(&q, 3);.
2430: 20 20 20 63 68 61 72 20 7a 42 75 66 5b 31 30 30 char zBuf[100
2440: 5d 3b 0a 20 20 20 20 20 20 42 6c 6f 62 20 66 69 ];. Blob fi
2450: 6c 65 3b 0a 0a 20 20 20 20 20 20 69 66 28 20 72 le;.. if( r
2460: 69 64 3e 30 20 29 7b 0a 20 20 20 20 20 20 20 20 id>0 ){.
2470: 6d 64 35 73 75 6d 5f 73 74 65 70 5f 74 65 78 74 md5sum_step_text
2480: 28 7a 4e 61 6d 65 2c 20 2d 31 29 3b 0a 20 20 20 (zName, -1);.
2490: 20 20 20 20 20 62 6c 6f 62 5f 7a 65 72 6f 28 26 blob_zero(&
24a0: 66 69 6c 65 29 3b 0a 20 20 20 20 20 20 20 20 63 file);. c
24b0: 6f 6e 74 65 6e 74 5f 67 65 74 28 72 69 64 2c 20 ontent_get(rid,
24c0: 26 66 69 6c 65 29 3b 0a 20 20 20 20 20 20 20 20 &file);.
24d0: 73 70 72 69 6e 74 66 28 7a 42 75 66 2c 20 22 20 sprintf(zBuf, "
24e0: 25 64 5c 6e 22 2c 20 62 6c 6f 62 5f 73 69 7a 65 %d\n", blob_size
24f0: 28 26 66 69 6c 65 29 29 3b 0a 20 20 20 20 20 20 (&file));.
2500: 20 20 6d 64 35 73 75 6d 5f 73 74 65 70 5f 74 65 md5sum_step_te
2510: 78 74 28 7a 42 75 66 2c 20 2d 31 29 3b 0a 20 20 xt(zBuf, -1);.
2520: 20 20 20 20 20 20 6d 64 35 73 75 6d 5f 73 74 65 md5sum_ste
2530: 70 5f 62 6c 6f 62 28 26 66 69 6c 65 29 3b 0a 20 p_blob(&file);.
2540: 20 20 20 20 20 20 20 62 6c 6f 62 5f 72 65 73 65 blob_rese
2550: 74 28 26 66 69 6c 65 29 3b 0a 20 20 20 20 20 20 t(&file);.
2560: 7d 0a 20 20 20 20 7d 0a 20 20 7d 0a 20 20 64 62 }. }. }. db
2570: 5f 66 69 6e 61 6c 69 7a 65 28 26 71 29 3b 0a 20 _finalize(&q);.
2580: 20 6d 64 35 73 75 6d 5f 66 69 6e 69 73 68 28 70 md5sum_finish(p
2590: 4f 75 74 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 Out);.}../*.** C
25a0: 6f 6d 70 75 74 65 20 61 6e 20 61 67 67 72 65 67 ompute an aggreg
25b0: 61 74 65 20 4d 44 35 20 63 68 65 63 6b 73 75 6d ate MD5 checksum
25c0: 20 6f 76 65 72 20 74 68 65 20 72 65 70 6f 73 69 over the reposi
25d0: 74 6f 72 79 20 69 6d 61 67 65 20 6f 66 20 65 76 tory image of ev
25e0: 65 72 79 0a 2a 2a 20 66 69 6c 65 20 69 6e 20 76 ery.** file in v
25f0: 69 64 2e 20 20 54 68 65 20 66 69 6c 65 20 6e 61 id. The file na
2600: 6d 65 73 20 61 72 65 20 70 61 72 74 20 6f 66 20 mes are part of
2610: 74 68 65 20 63 68 65 63 6b 73 75 6d 2e 0a 2a 2a the checksum..**
2620: 0a 2a 2a 20 52 65 74 75 72 6e 20 74 68 65 20 72 .** Return the r
2630: 65 73 75 6c 74 69 6e 67 20 63 68 65 63 6b 73 75 esulting checksu
2640: 6d 20 69 6e 20 62 6c 6f 62 20 70 4f 75 74 2e 0a m in blob pOut..
2650: 2a 2f 0a 76 6f 69 64 20 76 66 69 6c 65 5f 61 67 */.void vfile_ag
2660: 67 72 65 67 61 74 65 5f 63 68 65 63 6b 73 75 6d gregate_checksum
2670: 5f 72 65 70 6f 73 69 74 6f 72 79 28 69 6e 74 20 _repository(int
2680: 76 69 64 2c 20 42 6c 6f 62 20 2a 70 4f 75 74 29 vid, Blob *pOut)
2690: 7b 0a 20 20 42 6c 6f 62 20 66 69 6c 65 3b 0a 20 {. Blob file;.
26a0: 20 53 74 6d 74 20 71 3b 0a 20 20 63 68 61 72 20 Stmt q;. char
26b0: 7a 42 75 66 5b 31 30 30 5d 3b 0a 0a 20 20 64 62 zBuf[100];.. db
26c0: 5f 6d 75 73 74 5f 62 65 5f 77 69 74 68 69 6e 5f _must_be_within_
26d0: 74 72 65 65 28 29 3b 0a 20 20 0a 20 20 64 62 5f tree();. . db_
26e0: 70 72 65 70 61 72 65 28 26 71 2c 20 22 53 45 4c prepare(&q, "SEL
26f0: 45 43 54 20 70 61 74 68 6e 61 6d 65 2c 20 72 69 ECT pathname, ri
2700: 64 20 46 52 4f 4d 20 76 66 69 6c 65 22 0a 20 20 d FROM vfile".
2710: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 22 "
2720: 20 57 48 45 52 45 20 4e 4f 54 20 64 65 6c 65 74 WHERE NOT delet
2730: 65 64 20 41 4e 44 20 72 69 64 3e 30 20 41 4e 44 ed AND rid>0 AND
2740: 20 76 69 64 3d 25 64 22 0a 20 20 20 20 20 20 20 vid=%d".
2750: 20 20 20 20 20 20 20 20 20 20 22 20 4f 52 44 45 " ORDE
2760: 52 20 42 59 20 70 61 74 68 6e 61 6d 65 22 2c 0a R BY pathname",.
2770: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20
2780: 20 76 69 64 29 3b 0a 20 20 62 6c 6f 62 5f 7a 65 vid);. blob_ze
2790: 72 6f 28 26 66 69 6c 65 29 3b 0a 20 20 6d 64 35 ro(&file);. md5
27a0: 73 75 6d 5f 69 6e 69 74 28 29 3b 0a 20 20 77 68 sum_init();. wh
27b0: 69 6c 65 28 20 64 62 5f 73 74 65 70 28 26 71 29 ile( db_step(&q)
27c0: 3d 3d 53 51 4c 49 54 45 5f 52 4f 57 20 29 7b 0a ==SQLITE_ROW ){.
27d0: 20 20 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a const char *
27e0: 7a 4e 61 6d 65 20 3d 20 64 62 5f 63 6f 6c 75 6d zName = db_colum
27f0: 6e 5f 74 65 78 74 28 26 71 2c 20 30 29 3b 0a 20 n_text(&q, 0);.
2800: 20 20 20 69 6e 74 20 72 69 64 20 3d 20 64 62 5f int rid = db_
2810: 63 6f 6c 75 6d 6e 5f 69 6e 74 28 26 71 2c 20 31 column_int(&q, 1
2820: 29 3b 0a 20 20 20 20 6d 64 35 73 75 6d 5f 73 74 );. md5sum_st
2830: 65 70 5f 74 65 78 74 28 7a 4e 61 6d 65 2c 20 2d ep_text(zName, -
2840: 31 29 3b 0a 20 20 20 20 63 6f 6e 74 65 6e 74 5f 1);. content_
2850: 67 65 74 28 72 69 64 2c 20 26 66 69 6c 65 29 3b get(rid, &file);
2860: 0a 20 20 20 20 73 70 72 69 6e 74 66 28 7a 42 75 . sprintf(zBu
2870: 66 2c 20 22 20 25 64 5c 6e 22 2c 20 62 6c 6f 62 f, " %d\n", blob
2880: 5f 73 69 7a 65 28 26 66 69 6c 65 29 29 3b 0a 20 _size(&file));.
2890: 20 20 20 6d 64 35 73 75 6d 5f 73 74 65 70 5f 74 md5sum_step_t
28a0: 65 78 74 28 7a 42 75 66 2c 20 2d 31 29 3b 0a 20 ext(zBuf, -1);.
28b0: 20 20 20 6d 64 35 73 75 6d 5f 73 74 65 70 5f 62 md5sum_step_b
28c0: 6c 6f 62 28 26 66 69 6c 65 29 3b 0a 20 20 20 20 lob(&file);.
28d0: 62 6c 6f 62 5f 72 65 73 65 74 28 26 66 69 6c 65 blob_reset(&file
28e0: 29 3b 0a 20 20 7d 0a 20 20 64 62 5f 66 69 6e 61 );. }. db_fina
28f0: 6c 69 7a 65 28 26 71 29 3b 0a 20 20 6d 64 35 73 lize(&q);. md5s
2900: 75 6d 5f 66 69 6e 69 73 68 28 70 4f 75 74 29 3b um_finish(pOut);
2910: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 43 6f 6d 70 75 74 .}../*.** Comput
2920: 65 20 61 6e 20 61 67 67 72 65 67 61 74 65 20 4d e an aggregate M
2930: 44 35 20 63 68 65 63 6b 73 75 6d 20 6f 76 65 72 D5 checksum over
2940: 20 74 68 65 20 72 65 70 6f 73 69 74 6f 72 79 20 the repository
2950: 69 6d 61 67 65 20 6f 66 20 65 76 65 72 79 0a 2a image of every.*
2960: 2a 20 66 69 6c 65 20 69 6e 20 6d 61 6e 69 66 65 * file in manife
2970: 73 74 20 76 69 64 2e 20 20 54 68 65 20 66 69 6c st vid. The fil
2980: 65 20 6e 61 6d 65 73 20 61 72 65 20 70 61 72 74 e names are part
2990: 20 6f 66 20 74 68 65 20 63 68 65 63 6b 73 75 6d of the checksum
29a0: 2e 0a 2a 2a 0a 2a 2a 20 52 65 74 75 72 6e 20 74 ..**.** Return t
29b0: 68 65 20 72 65 73 75 6c 74 69 6e 67 20 63 68 65 he resulting che
29c0: 63 6b 73 75 6d 20 69 6e 20 62 6c 6f 62 20 70 4f cksum in blob pO
29d0: 75 74 2e 0a 2a 2f 0a 76 6f 69 64 20 76 66 69 6c ut..*/.void vfil
29e0: 65 5f 61 67 67 72 65 67 61 74 65 5f 63 68 65 63 e_aggregate_chec
29f0: 6b 73 75 6d 5f 6d 61 6e 69 66 65 73 74 28 69 6e ksum_manifest(in
2a00: 74 20 76 69 64 2c 20 42 6c 6f 62 20 2a 70 4f 75 t vid, Blob *pOu
2a10: 74 2c 20 42 6c 6f 62 20 2a 70 4d 61 6e 4f 75 74 t, Blob *pManOut
2a20: 29 7b 0a 20 20 69 6e 74 20 69 2c 20 66 69 64 3b ){. int i, fid;
2a30: 0a 20 20 42 6c 6f 62 20 66 69 6c 65 2c 20 6d 66 . Blob file, mf
2a40: 69 6c 65 3b 0a 20 20 4d 61 6e 69 66 65 73 74 20 ile;. Manifest
2a50: 6d 3b 0a 20 20 63 68 61 72 20 7a 42 75 66 5b 31 m;. char zBuf[1
2a60: 30 30 5d 3b 0a 0a 20 20 62 6c 6f 62 5f 7a 65 72 00];.. blob_zer
2a70: 6f 28 70 4f 75 74 29 3b 0a 20 20 69 66 28 20 70 o(pOut);. if( p
2a80: 4d 61 6e 4f 75 74 20 29 7b 0a 20 20 20 20 62 6c ManOut ){. bl
2a90: 6f 62 5f 7a 65 72 6f 28 70 4d 61 6e 4f 75 74 29 ob_zero(pManOut)
2aa0: 3b 0a 20 20 7d 0a 20 20 64 62 5f 6d 75 73 74 5f ;. }. db_must_
2ab0: 62 65 5f 77 69 74 68 69 6e 5f 74 72 65 65 28 29 be_within_tree()
2ac0: 3b 0a 20 20 63 6f 6e 74 65 6e 74 5f 67 65 74 28 ;. content_get(
2ad0: 76 69 64 2c 20 26 6d 66 69 6c 65 29 3b 0a 20 20 vid, &mfile);.
2ae0: 69 66 28 20 6d 61 6e 69 66 65 73 74 5f 70 61 72 if( manifest_par
2af0: 73 65 28 26 6d 2c 20 26 6d 66 69 6c 65 29 3d 3d se(&m, &mfile)==
2b00: 30 20 29 7b 0a 20 20 20 20 66 6f 73 73 69 6c 5f 0 ){. fossil_
2b10: 70 61 6e 69 63 28 22 6d 61 6e 69 66 65 73 74 20 panic("manifest
2b20: 66 69 6c 65 20 28 25 64 29 20 69 73 20 6d 61 6c file (%d) is mal
2b30: 66 6f 72 6d 65 64 22 2c 20 76 69 64 29 3b 0a 20 formed", vid);.
2b40: 20 7d 0a 20 20 66 6f 72 28 69 3d 30 3b 20 69 3c }. for(i=0; i<
2b50: 6d 2e 6e 46 69 6c 65 3b 20 69 2b 2b 29 7b 0a 20 m.nFile; i++){.
2b60: 20 20 20 66 69 64 20 3d 20 75 75 69 64 5f 74 6f fid = uuid_to
2b70: 5f 72 69 64 28 6d 2e 61 46 69 6c 65 5b 69 5d 2e _rid(m.aFile[i].
2b80: 7a 55 75 69 64 2c 20 30 29 3b 0a 20 20 20 20 6d zUuid, 0);. m
2b90: 64 35 73 75 6d 5f 73 74 65 70 5f 74 65 78 74 28 d5sum_step_text(
2ba0: 6d 2e 61 46 69 6c 65 5b 69 5d 2e 7a 4e 61 6d 65 m.aFile[i].zName
2bb0: 2c 20 2d 31 29 3b 0a 20 20 20 20 63 6f 6e 74 65 , -1);. conte
2bc0: 6e 74 5f 67 65 74 28 66 69 64 2c 20 26 66 69 6c nt_get(fid, &fil
2bd0: 65 29 3b 0a 20 20 20 20 73 70 72 69 6e 74 66 28 e);. sprintf(
2be0: 7a 42 75 66 2c 20 22 20 25 64 5c 6e 22 2c 20 62 zBuf, " %d\n", b
2bf0: 6c 6f 62 5f 73 69 7a 65 28 26 66 69 6c 65 29 29 lob_size(&file))
2c00: 3b 0a 20 20 20 20 6d 64 35 73 75 6d 5f 73 74 65 ;. md5sum_ste
2c10: 70 5f 74 65 78 74 28 7a 42 75 66 2c 20 2d 31 29 p_text(zBuf, -1)
2c20: 3b 0a 20 20 20 20 6d 64 35 73 75 6d 5f 73 74 65 ;. md5sum_ste
2c30: 70 5f 62 6c 6f 62 28 26 66 69 6c 65 29 3b 0a 20 p_blob(&file);.
2c40: 20 20 20 62 6c 6f 62 5f 72 65 73 65 74 28 26 66 blob_reset(&f
2c50: 69 6c 65 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20 ile);. }. if(
2c60: 70 4d 61 6e 4f 75 74 20 29 7b 0a 20 20 20 20 62 pManOut ){. b
2c70: 6c 6f 62 5f 61 70 70 65 6e 64 28 70 4d 61 6e 4f lob_append(pManO
2c80: 75 74 2c 20 6d 2e 7a 52 65 70 6f 43 6b 73 75 6d ut, m.zRepoCksum
2c90: 2c 20 2d 31 29 3b 0a 20 20 7d 0a 20 20 6d 61 6e , -1);. }. man
2ca0: 69 66 65 73 74 5f 63 6c 65 61 72 28 26 6d 29 3b ifest_clear(&m);
2cb0: 0a 20 20 6d 64 35 73 75 6d 5f 66 69 6e 69 73 68 . md5sum_finish
2cc0: 28 70 4f 75 74 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a (pOut);.}../*.**
2cd0: 20 43 4f 4d 4d 41 4e 44 3a 20 74 65 73 74 2d 61 COMMAND: test-a
2ce0: 67 67 2d 63 6b 73 75 6d 0a 2a 2f 0a 76 6f 69 64 gg-cksum.*/.void
2cf0: 20 74 65 73 74 5f 61 67 67 5f 63 6b 73 75 6d 5f test_agg_cksum_
2d00: 63 6d 64 28 76 6f 69 64 29 7b 0a 20 20 69 6e 74 cmd(void){. int
2d10: 20 76 69 64 3b 0a 20 20 42 6c 6f 62 20 68 61 73 vid;. Blob has
2d20: 68 2c 20 68 61 73 68 32 3b 0a 20 20 64 62 5f 6d h, hash2;. db_m
2d30: 75 73 74 5f 62 65 5f 77 69 74 68 69 6e 5f 74 72 ust_be_within_tr
2d40: 65 65 28 29 3b 0a 20 20 76 69 64 20 3d 20 64 62 ee();. vid = db
2d50: 5f 6c 67 65 74 5f 69 6e 74 28 22 63 68 65 63 6b _lget_int("check
2d60: 6f 75 74 22 2c 20 30 29 3b 0a 20 20 76 66 69 6c out", 0);. vfil
2d70: 65 5f 61 67 67 72 65 67 61 74 65 5f 63 68 65 63 e_aggregate_chec
2d80: 6b 73 75 6d 5f 64 69 73 6b 28 76 69 64 2c 20 26 ksum_disk(vid, &
2d90: 68 61 73 68 29 3b 0a 20 20 70 72 69 6e 74 66 28 hash);. printf(
2da0: 22 64 69 73 6b 3a 20 20 20 20 20 25 73 5c 6e 22 "disk: %s\n"
2db0: 2c 20 62 6c 6f 62 5f 73 74 72 28 26 68 61 73 68 , blob_str(&hash
2dc0: 29 29 3b 0a 20 20 62 6c 6f 62 5f 72 65 73 65 74 ));. blob_reset
2dd0: 28 26 68 61 73 68 29 3b 0a 20 20 76 66 69 6c 65 (&hash);. vfile
2de0: 5f 61 67 67 72 65 67 61 74 65 5f 63 68 65 63 6b _aggregate_check
2df0: 73 75 6d 5f 72 65 70 6f 73 69 74 6f 72 79 28 76 sum_repository(v
2e00: 69 64 2c 20 26 68 61 73 68 29 3b 0a 20 20 70 72 id, &hash);. pr
2e10: 69 6e 74 66 28 22 61 72 63 68 69 76 65 3a 20 20 intf("archive:
2e20: 25 73 5c 6e 22 2c 20 62 6c 6f 62 5f 73 74 72 28 %s\n", blob_str(
2e30: 26 68 61 73 68 29 29 3b 0a 20 20 62 6c 6f 62 5f &hash));. blob_
2e40: 72 65 73 65 74 28 26 68 61 73 68 29 3b 0a 20 20 reset(&hash);.
2e50: 76 66 69 6c 65 5f 61 67 67 72 65 67 61 74 65 5f vfile_aggregate_
2e60: 63 68 65 63 6b 73 75 6d 5f 6d 61 6e 69 66 65 73 checksum_manifes
2e70: 74 28 76 69 64 2c 20 26 68 61 73 68 2c 20 26 68 t(vid, &hash, &h
2e80: 61 73 68 32 29 3b 0a 20 20 70 72 69 6e 74 66 28 ash2);. printf(
2e90: 22 6d 61 6e 69 66 65 73 74 3a 20 25 73 5c 6e 22 "manifest: %s\n"
2ea0: 2c 20 62 6c 6f 62 5f 73 74 72 28 26 68 61 73 68 , blob_str(&hash
2eb0: 29 29 3b 0a 20 20 70 72 69 6e 74 66 28 22 72 65 ));. printf("re
2ec0: 63 6f 72 64 65 64 3a 20 25 73 5c 6e 22 2c 20 62 corded: %s\n", b
2ed0: 6c 6f 62 5f 73 74 72 28 26 68 61 73 68 32 29 29 lob_str(&hash2))
2ee0: 3b 0a 7d 0a ;.}.