Hex Artifact Content
Not logged in

Artifact 5ad913c384f94b6fa54b89ec9a7aeb1e1f600144:

File src/vfile.c part of check-in [1871a93dd4] - Fix bugs that can cause a segfault if a blank check-in comment is entered. by drh on 2007-08-30 18:05:19.

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                                      ;.}.