Hex Artifact Content
Not logged in

Artifact 4c209ff3a1c0757b57cdfd304bc2443bb7ed5b29:

File todo.txt part of check-in [08c4cc6d16] - Added the todo.txt list. by drh on 2007-07-30 23:01:35.

0000: 54 68 69 6e 67 73 20 74 6f 20 77 6f 72 6b 20 6f  Things to work o
0010: 6e 3a 0a 0a 20 2a 20 20 4f 6e 20 65 76 65 72 79  n:.. *  On every
0020: 20 70 75 73 68 2c 20 70 75 6c 6c 2c 20 6f 72 20   push, pull, or 
0030: 63 6c 6f 6e 65 20 63 6f 6d 6d 61 6e 64 2c 20 72  clone command, r
0040: 65 6d 65 6d 62 65 72 20 74 68 65 20 55 52 4c 20  emember the URL 
0050: 6f 66 20 74 68 65 0a 20 20 20 20 73 65 72 76 65  of the.    serve
0060: 72 20 75 73 69 6e 67 20 64 62 5f 70 75 74 28 29  r using db_put()
0070: 2e 20 20 4f 6e 20 73 75 62 73 65 71 75 65 6e 74  .  On subsequent
0080: 20 70 75 73 68 65 73 20 61 6e 64 20 70 75 6c 6c   pushes and pull
0090: 73 2c 20 61 6c 6c 6f 77 0a 20 20 20 20 74 68 65  s, allow.    the
00a0: 20 55 52 4c 20 74 6f 20 62 65 20 6f 6d 69 74 74   URL to be omitt
00b0: 65 64 20 61 6e 64 20 73 75 62 73 74 69 74 75 74  ed and substitut
00c0: 65 20 74 68 65 20 55 52 4c 20 74 68 61 74 20 77  e the URL that w
00d0: 61 73 20 75 73 65 64 20 74 68 65 0a 20 20 20 20  as used the.    
00e0: 70 72 65 76 69 6f 75 73 20 74 69 6d 65 2e 20 20  previous time.  
00f0: 44 69 73 70 6c 61 79 20 74 68 65 20 73 61 76 65  Display the save
0100: 64 20 55 52 4c 20 61 73 20 70 61 72 74 20 6f 66  d URL as part of
0110: 20 74 68 65 20 22 69 6e 66 6f 22 0a 20 20 20 20   the "info".    
0120: 63 6f 6d 6d 61 6e 64 20 69 6e 20 74 68 65 20 63  command in the c
0130: 6c 69 2e 0a 0a 20 2a 20 20 49 66 20 74 68 65 20  li... *  If the 
0140: 73 65 72 76 65 72 20 64 6f 65 73 20 6e 6f 74 20  server does not 
0150: 68 61 76 65 20 77 72 69 74 65 20 70 65 72 6d 69  have write permi
0160: 73 73 69 6f 6e 20 6f 6e 20 74 68 65 20 64 61 74  ssion on the dat
0170: 61 62 61 73 65 0a 20 20 20 20 66 69 6c 65 2c 20  abase.    file, 
0180: 6f 72 20 6f 6e 20 74 68 65 20 64 69 72 65 63 74  or on the direct
0190: 6f 72 79 20 63 6f 6e 74 61 69 6e 69 6e 67 20 74  ory containing t
01a0: 68 65 20 64 61 74 61 62 61 73 65 20 66 69 6c 65  he database file
01b0: 20 28 61 6e 64 20 0a 20 20 20 20 69 74 20 69 73   (and .    it is
01c0: 20 74 68 75 73 20 75 6e 61 62 6c 65 20 74 6f 20   thus unable to 
01d0: 75 70 64 61 74 65 20 64 61 74 61 62 61 73 65 20  update database 
01e0: 62 65 63 61 75 73 65 20 69 74 20 63 61 6e 6e 6f  because it canno
01f0: 74 20 63 72 65 61 74 65 0a 20 20 20 20 61 20 72  t create.    a r
0200: 6f 6c 6c 62 61 63 6b 20 6a 6f 75 72 6e 61 6c 29  ollback journal)
0210: 20 74 68 65 6e 20 69 74 20 63 75 72 72 65 6e 74   then it current
0220: 6c 79 20 66 61 69 6c 73 20 73 69 6c 65 6e 74 6c  ly fails silentl
0230: 79 20 6f 6e 20 61 20 70 75 73 68 2e 0a 20 20 20  y on a push..   
0240: 20 49 74 20 6e 65 65 64 73 20 74 6f 20 72 65 74   It needs to ret
0250: 75 72 6e 20 61 20 68 65 6c 70 66 75 6c 20 65 72  urn a helpful er
0260: 72 6f 72 2e 0a 0a 20 2a 20 20 54 68 65 20 22 6c  ror... *  The "l
0270: 65 61 76 65 73 20 3f 55 55 49 44 3f 22 20 63 6f  eaves ?UUID?" co
0280: 6d 6d 61 6e 64 20 64 69 73 70 6c 61 79 73 20 61  mmand displays a
0290: 6c 6c 20 6c 65 61 66 20 76 65 72 73 69 6f 6e 73  ll leaf versions
02a0: 20 66 6f 72 20 74 68 65 0a 20 20 20 20 76 65 72   for the.    ver
02b0: 73 69 6f 6e 20 55 55 49 44 20 6f 72 20 66 6f 72  sion UUID or for
02c0: 20 74 68 65 20 63 75 72 72 65 6e 74 20 76 65 72   the current ver
02d0: 73 69 6f 6e 20 69 66 20 55 55 49 44 20 69 73 20  sion if UUID is 
02e0: 6f 6d 69 74 74 65 64 2e 20 20 49 66 0a 20 20 20  omitted.  If.   
02f0: 20 55 55 49 44 20 69 73 20 69 74 73 65 6c 66 20   UUID is itself 
0300: 61 20 6c 65 61 66 2c 20 69 74 20 77 6f 75 6c 64  a leaf, it would
0310: 20 62 65 20 6d 6f 72 65 20 68 65 6c 70 66 75 6c   be more helpful
0320: 20 74 6f 20 64 69 73 70 6c 61 79 20 61 0a 20 20   to display a.  
0330: 20 20 6d 65 73 73 61 67 65 20 74 6f 20 74 68 61    message to tha
0340: 74 20 65 66 66 65 63 74 3a 20 20 22 3c 75 75 69  t effect:  "<uui
0350: 64 3e 20 69 73 20 69 74 73 65 6c 66 20 61 20 6c  d> is itself a l
0360: 65 61 66 22 0a 0a 20 2a 20 20 57 65 20 6e 65 65  eaf".. *  We nee
0370: 64 20 61 20 63 6f 6d 6d 61 6e 64 20 74 6f 20 73  d a command to s
0380: 68 6f 77 20 6f 74 68 65 72 20 62 72 61 6e 63 68  how other branch
0390: 65 73 20 2d 20 6c 65 61 76 65 73 20 6f 66 20 74  es - leaves of t
03a0: 68 65 20 72 6f 6f 74 0a 20 20 20 20 77 68 69 63  he root.    whic
03b0: 68 20 61 72 65 20 6e 6f 74 20 6c 65 61 76 65 73  h are not leaves
03c0: 20 6f 66 20 74 68 65 20 69 6e 64 69 63 61 74 65   of the indicate
03d0: 64 20 6e 6f 64 65 2e 0a 0a 20 2a 20 20 41 64 64  d node... *  Add
03e0: 69 74 69 6f 6e 61 6c 20 69 6e 66 6f 72 6d 61 74  itional informat
03f0: 69 6f 6e 20 64 69 73 70 6c 61 79 65 64 20 66 6f  ion displayed fo
0400: 72 20 74 68 65 20 22 76 69 6e 66 6f 22 20 70 61  r the "vinfo" pa
0410: 67 65 3a 0a 0a 20 20 20 20 20 2b 20 20 54 68 65  ge:..     +  The
0420: 20 63 6f 6d 6d 65 6e 74 20 61 6e 64 20 75 73 65   comment and use
0430: 72 20 66 6f 72 20 74 68 69 73 20 76 65 72 73 69  r for this versi
0440: 6f 6e 20 28 61 76 61 69 6c 61 62 6c 65 20 69 6e  on (available in
0450: 0a 20 20 20 20 20 20 20 20 74 68 65 20 65 76 65  .        the eve
0460: 6e 74 20 74 61 62 6c 65 29 2e 0a 20 20 20 20 20  nt table)..     
0470: 2b 20 20 41 6c 6c 20 64 65 63 65 6e 64 65 6e 74  +  All decendent
0480: 73 20 6f 66 20 74 68 69 73 20 76 65 72 73 69 6f  s of this versio
0490: 6e 20 28 74 6f 67 65 74 68 65 72 20 77 69 74 68  n (together with
04a0: 20 64 61 74 65 2c 0a 20 20 20 20 20 20 20 20 75   date,.        u
04b0: 73 65 72 2c 20 63 6f 6d 6d 65 6e 74 2c 20 61 6e  ser, comment, an
04c0: 64 20 68 79 70 65 72 6c 69 6e 6b 20 74 6f 20 74  d hyperlink to t
04d0: 68 65 20 76 69 6e 66 6f 20 70 61 67 65 29 20 66  he vinfo page) f
04e0: 6f 72 0a 20 20 20 20 20 20 20 20 4e 20 67 65 6e  or.        N gen
04f0: 65 72 61 74 69 6f 6e 73 2e 20 20 4e 20 74 6f 20  erations.  N to 
0500: 62 65 20 64 65 74 65 72 6d 69 6e 65 64 2e 20 20  be determined.  
0510: 50 65 72 68 61 70 73 20 63 6f 6e 66 69 67 75 72  Perhaps configur
0520: 61 62 6c 65 0a 20 20 20 20 20 20 20 20 75 73 69  able.        usi
0530: 6e 67 20 64 62 5f 67 65 74 5f 69 6e 74 28 29 2f  ng db_get_int()/
0540: 64 62 5f 73 65 74 5f 69 6e 74 28 29 2e 20 20 4e  db_set_int().  N
0550: 6f 74 65 3a 20 64 65 63 65 6e 64 65 6e 74 73 20  ote: decendents 
0560: 63 61 6e 0a 20 20 20 20 20 20 20 20 62 65 20 66  can.        be f
0570: 6f 75 6e 64 20 75 73 69 6e 67 20 74 68 65 20 70  ound using the p
0580: 6c 69 6e 6b 20 74 61 62 6c 65 2e 0a 20 20 20 20  link table..    
0590: 20 2b 20 20 41 6c 6c 20 6c 65 61 76 65 73 20 6f   +  All leaves o
05a0: 66 20 74 68 69 73 20 76 65 72 73 69 6f 6e 20 74  f this version t
05b0: 68 61 74 20 61 72 65 20 6e 6f 74 20 69 6e 63 6c  hat are not incl
05c0: 75 64 65 64 20 69 6e 20 74 68 65 0a 20 20 20 20  uded in the.    
05d0: 20 20 20 20 64 65 63 65 6e 64 65 6e 74 20 6c 69      decendent li
05e0: 73 74 2e 20 20 57 69 74 68 20 64 61 74 65 2c 20  st.  With date, 
05f0: 75 73 65 72 2c 20 63 6f 6d 6d 65 6e 74 2c 20 61  user, comment, a
0600: 6e 64 20 68 79 70 65 72 6c 69 6e 6b 2e 0a 20 20  nd hyperlink..  
0610: 20 20 20 20 20 20 4c 65 61 76 65 73 20 69 6e 20        Leaves in 
0620: 74 68 65 20 64 65 63 65 6e 64 65 6e 74 20 74 61  the decendent ta
0630: 62 6c 65 20 73 68 6f 75 6c 64 20 62 65 20 6d 61  ble should be ma
0640: 72 6b 65 64 20 61 73 20 73 75 63 68 2e 0a 20 20  rked as such..  
0650: 20 20 20 20 20 20 53 65 65 20 74 68 65 20 63 6f        See the co
0660: 6d 70 75 74 65 5f 6c 65 61 76 65 73 28 29 20 66  mpute_leaves() f
0670: 75 6e 63 74 69 6f 6e 20 74 6f 20 73 65 65 20 68  unction to see h
0680: 6f 77 20 74 6f 20 66 69 6e 64 20 61 6c 6c 0a 20  ow to find all. 
0690: 20 20 20 20 20 20 20 6c 65 61 76 65 73 2e 0a 20         leaves.. 
06a0: 20 20 20 20 2b 20 20 41 6c 6c 20 61 6e 63 65 73      +  All ances
06b0: 74 6f 72 73 20 6f 66 20 74 68 65 20 63 75 72 72  tors of the curr
06c0: 65 6e 74 20 76 65 72 73 69 6f 6e 20 77 69 74 68  ent version with
06d0: 20 64 61 74 65 2c 20 75 73 65 72 2c 0a 20 20 20   date, user,.   
06e0: 20 20 20 20 20 63 6f 6d 6d 65 6e 74 2c 20 68 79       comment, hy
06f0: 70 65 72 6c 69 6e 6b 2e 20 20 4d 20 67 65 6e 65  perlink.  M gene
0700: 72 61 74 69 6f 6e 73 20 62 61 63 6b 2c 20 77 68  rations back, wh
0710: 65 72 65 20 4d 20 69 73 0a 20 20 20 20 20 20 20  ere M is.       
0720: 20 74 6f 20 62 65 20 64 65 74 65 72 6d 69 6e 65   to be determine
0730: 64 2e 0a 20 20 20 20 20 2b 20 20 4c 69 73 74 20  d..     +  List 
0740: 6f 66 20 66 69 6c 65 73 20 61 64 64 65 64 20 6f  of files added o
0750: 72 20 6d 6f 64 69 66 69 65 64 20 62 79 20 74 68  r modified by th
0760: 69 73 20 76 65 72 73 69 6f 6e 2e 0a 20 20 20 20  is version..    
0770: 20 20 20 20 49 6e 66 6f 72 6d 61 74 69 6f 6e 20      Information 
0780: 61 76 61 69 6c 61 62 6c 65 20 69 6e 20 74 68 65  available in the
0790: 20 6d 6c 69 6e 6b 20 74 61 62 6c 65 2e 20 20 48   mlink table.  H
07a0: 79 70 65 72 6c 69 6e 6b 73 20 74 6f 0a 20 20 20  yperlinks to.   
07b0: 20 20 20 20 20 74 68 65 20 66 69 6e 66 6f 20 70       the finfo p
07c0: 61 67 65 20 66 6f 72 20 65 61 63 68 20 66 69 6c  age for each fil
07d0: 65 2e 0a 20 20 20 20 20 2b 20 20 48 79 70 65 72  e..     +  Hyper
07e0: 6c 69 6e 6b 73 20 74 6f 20 64 69 66 66 20 61 6c  links to diff al
07f0: 6c 20 66 69 6c 65 73 20 69 6e 20 74 68 69 73 20  l files in this 
0800: 76 65 72 73 69 6f 6e 20 61 67 61 69 6e 73 74 20  version against 
0810: 61 6e 79 0a 20 20 20 20 20 20 20 20 6f 66 20 74  any.        of t
0820: 68 65 20 6e 61 6d 65 64 20 64 65 63 65 6e 64 65  he named decende
0830: 6e 74 73 20 6f 72 20 61 6e 63 65 73 74 6f 72 73  nts or ancestors
0840: 2e 20 20 54 68 65 20 75 6e 69 66 69 65 64 5f 64  .  The unified_d
0850: 69 66 66 28 29 0a 20 20 20 20 20 20 20 20 66 75  iff().        fu
0860: 6e 63 74 69 6f 6e 20 77 69 6c 6c 20 63 6f 6d 70  nction will comp
0870: 75 74 65 20 61 20 75 6e 69 66 69 65 64 20 64 69  ute a unified di
0880: 66 66 20 67 69 76 65 6e 20 74 6f 20 66 69 6c 65  ff given to file
0890: 20 62 6c 6f 62 73 2e 0a 0a 20 2a 20 20 41 20 6e   blobs... *  A n
08a0: 65 77 20 77 65 62 70 61 67 65 3a 20 22 66 69 6e  ew webpage: "fin
08b0: 66 6f 22 20 20 49 6e 66 6f 72 6d 61 74 69 6f 6e  fo"  Information
08c0: 20 61 62 6f 75 74 20 61 20 70 61 72 74 69 63 75   about a particu
08d0: 6c 61 72 20 66 69 6c 65 0a 20 20 20 20 67 69 76  lar file.    giv
08e0: 65 6e 20 69 74 73 20 6e 61 6d 65 2e 0a 0a 20 20  en its name...  
08f0: 20 20 20 2b 20 20 41 6c 6c 20 68 69 73 74 6f 72     +  All histor
0900: 69 63 61 6c 20 63 68 61 6e 67 65 73 20 74 6f 20  ical changes to 
0910: 74 68 69 73 20 66 69 6c 65 20 77 69 74 68 20 76  this file with v
0920: 65 72 73 69 6f 6e 20 6e 75 6d 62 65 72 2c 0a 20  ersion number,. 
0930: 20 20 20 20 20 20 20 75 73 65 72 2c 20 61 6e 64         user, and
0940: 20 63 6f 6d 6d 65 6e 74 2c 20 61 6e 64 20 68 79   comment, and hy
0950: 70 65 72 6c 69 6e 6b 20 74 6f 20 74 68 65 20 76  perlink to the v
0960: 69 6e 66 6f 20 70 61 67 65 20 66 6f 72 0a 20 20  info page for.  
0970: 20 20 20 20 20 20 74 68 65 20 76 65 72 73 69 6f        the versio
0980: 6e 2e 20 20 49 6e 66 6f 72 6d 61 74 69 6f 6e 20  n.  Information 
0990: 61 76 61 69 6c 61 62 6c 65 20 66 72 6f 6d 20 74  available from t
09a0: 68 65 20 6d 69 6e 66 6f 20 74 61 62 6c 65 2e 0a  he minfo table..
09b0: 20 20 20 20 20 2b 20 20 48 79 70 65 72 6c 69 6e       +  Hyperlin
09c0: 6b 73 20 66 6f 72 20 64 69 66 66 69 6e 67 20 63  ks for diffing c
09d0: 6f 6e 73 65 63 75 74 69 76 65 20 76 65 72 73 69  onsecutive versi
09e0: 6f 6e 73 20 6f 66 20 74 68 65 20 66 69 6c 65 2e  ons of the file.
09f0: 0a 0a 20 2a 20 20 47 69 76 65 6e 20 61 6e 79 20  .. *  Given any 
0a00: 76 65 72 73 69 6f 6e 20 75 75 69 64 2c 20 63 6f  version uuid, co
0a10: 6e 73 74 72 75 63 74 20 61 20 5a 49 50 20 61 72  nstruct a ZIP ar
0a20: 63 68 69 76 65 20 74 68 61 74 20 63 6f 6e 74 61  chive that conta
0a30: 69 6e 73 0a 20 20 20 20 74 68 65 20 63 6f 6d 70  ins.    the comp
0a40: 6c 65 74 65 20 63 6f 6e 74 65 6e 74 20 66 6f 72  lete content for
0a50: 20 74 68 61 74 20 76 65 72 73 69 6f 6e 2e 20 20   that version.  
0a60: 46 65 61 74 75 72 65 20 73 68 6f 75 6c 64 20 62  Feature should b
0a70: 65 0a 20 20 20 20 63 61 6c 6c 61 62 6c 65 20 66  e.    callable f
0a80: 72 6f 6d 20 74 68 65 20 63 6f 6d 6d 61 6e 64 2d  rom the command-
0a90: 6c 69 6e 65 20 6f 72 20 66 72 6f 6d 20 74 68 65  line or from the
0aa0: 20 77 77 77 20 69 6e 74 65 72 66 61 63 65 2e 0a   www interface..
0ab0: 20 20 20 20 50 65 72 68 61 70 73 20 61 20 68 79      Perhaps a hy
0ac0: 70 65 72 6c 69 6e 6b 20 6f 6e 20 74 68 65 20 76  perlink on the v
0ad0: 69 6e 66 6f 20 70 61 67 65 20 74 6f 20 64 6f 77  info page to dow
0ae0: 6e 6c 6f 61 64 20 74 68 65 20 5a 49 50 20 61 72  nload the ZIP ar
0af0: 63 68 69 76 65 0a 20 20 20 20 66 6f 72 20 61 6e  chive.    for an
0b00: 79 20 76 65 72 73 69 6f 6e 2e 0a 0a 20 2a 20 20  y version... *  
0b10: 54 69 6d 65 6c 69 6e 65 20 65 6e 68 61 6e 63 65  Timeline enhance
0b20: 64 20 73 6f 20 74 68 61 74 20 79 6f 75 20 63 61  d so that you ca
0b30: 6e 20 73 70 65 63 69 66 79 20 61 20 72 61 6e 67  n specify a rang
0b40: 65 20 6f 66 20 64 61 74 65 73 2e 0a 0a 20 2a 20  e of dates... * 
0b50: 20 54 68 65 20 2f 78 66 65 72 20 68 61 6e 64 6c   The /xfer handl
0b60: 65 72 20 28 66 6f 72 20 70 75 73 68 2c 20 70 75  er (for push, pu
0b70: 6c 6c 2c 20 61 6e 64 20 63 6c 6f 6e 65 29 20 64  ll, and clone) d
0b80: 6f 65 73 20 6e 6f 74 20 64 6f 0a 20 20 20 20 64  oes not do.    d
0b90: 65 6c 74 61 20 63 6f 6d 70 72 65 73 73 69 6f 6e  elta compression
0ba0: 2e 20 20 54 68 69 73 20 72 65 73 75 6c 74 73 20  .  This results 
0bb0: 69 6e 20 65 78 63 65 73 73 20 62 61 6e 64 77 69  in excess bandwi
0bc0: 64 74 68 20 75 73 61 67 65 2e 0a 20 20 20 20 54  dth usage..    T
0bd0: 68 65 72 65 20 61 72 65 20 73 6f 6d 65 20 63 6f  here are some co
0be0: 64 65 20 69 6e 20 78 66 65 72 2e 63 20 74 68 61  de in xfer.c tha
0bf0: 74 20 61 72 65 20 73 6b 65 74 63 68 65 73 20 6f  t are sketches o
0c00: 66 20 69 64 65 61 73 20 6f 6e 0a 20 20 20 20 68  f ideas on.    h
0c10: 6f 77 20 74 6f 20 64 6f 20 64 65 6c 74 61 20 63  ow to do delta c
0c20: 6f 6d 70 72 65 73 73 69 6f 6e 2c 20 62 75 74 20  ompression, but 
0c30: 6e 6f 74 68 69 6e 67 20 68 61 73 20 62 65 65 6e  nothing has been
0c40: 20 69 6d 70 6c 65 6d 65 6e 74 65 64 2e 0a 0a 20   implemented... 
0c50: 2a 20 20 54 69 63 6b 65 74 69 6e 67 20 69 6e 74  *  Ticketing int
0c60: 65 72 66 61 63 65 20 28 65 78 70 61 6e 64 20 74  erface (expand t
0c70: 68 69 73 20 62 75 6c 6c 65 74 29 0a 0a 20 2a 20  his bullet).. * 
0c80: 20 57 69 6b 69 20 69 6e 74 65 72 66 61 63 65 20   Wiki interface 
0c90: 28 65 78 70 61 6e 64 20 74 68 69 73 20 62 75 6c  (expand this bul
0ca0: 6c 65 74 29 0a 0a 20 2a 20 20 46 75 6c 6c 2d 74  let).. *  Full-t
0cb0: 65 78 74 20 73 65 61 72 63 68 20 61 67 61 69 6e  ext search again
0cc0: 73 74 20 63 68 65 63 6b 2d 69 6e 20 63 6f 6d 6d  st check-in comm
0cd0: 65 6e 74 73 20 61 6e 64 20 64 69 66 66 73 20 6f  ents and diffs o
0ce0: 66 20 65 61 63 68 0a 20 20 20 20 63 68 65 63 6b  f each.    check
0cf0: 2d 69 6e 2e 0a 0a 20 2a 20 20 4e 65 77 20 63 6c  -in... *  New cl
0d00: 69 20 63 6f 6d 6d 61 6e 64 73 3a 20 22 64 65 63  i commands: "dec
0d10: 6f 6e 73 74 72 75 63 74 22 20 61 6e 64 20 22 72  onstruct" and "r
0d20: 65 63 6f 6e 73 74 72 75 63 74 22 2e 20 20 54 68  econstruct".  Th
0d30: 65 20 64 65 63 6f 6e 73 74 72 75 63 74 0a 20 20  e deconstruct.  
0d40: 20 20 63 6f 6d 6d 61 6e 64 20 70 6f 70 75 6c 61    command popula
0d50: 74 65 73 20 61 6e 20 69 6e 64 69 63 61 74 65 64  tes an indicated
0d60: 20 64 69 72 65 63 74 6f 72 79 20 77 69 74 68 20   directory with 
0d70: 63 6f 70 69 65 73 20 6f 66 20 61 6c 6c 20 66 69  copies of all fi
0d80: 6c 65 73 0a 20 20 20 20 63 6f 6e 74 61 69 6e 65  les.    containe
0d90: 64 20 77 69 74 68 69 6e 20 74 68 65 20 72 65 70  d within the rep
0da0: 6f 73 69 74 6f 72 79 2e 20 20 46 69 6c 65 73 20  ository.  Files 
0db0: 61 72 65 20 6e 61 6d 65 64 20 61 61 61 2f 62 62  are named aaa/bb
0dc0: 62 62 62 62 62 20 77 68 65 72 65 0a 20 20 20 20  bbbbb where.    
0dd0: 61 61 61 20 69 73 20 74 68 65 20 66 69 72 73 74  aaa is the first
0de0: 20 33 20 63 68 61 72 61 63 74 65 72 73 20 6f 66   3 characters of
0df0: 20 74 68 65 20 75 75 69 64 20 61 6e 64 20 62 62   the uuid and bb
0e00: 62 62 62 62 20 69 73 20 74 68 65 0a 20 20 20 20  bbbb is the.    
0e10: 72 65 6d 61 69 6e 69 6e 67 20 33 37 20 63 68 61  remaining 37 cha
0e20: 72 61 63 74 65 72 73 2e 20 20 72 65 63 6f 6e 73  racters.  recons
0e30: 74 72 75 63 74 20 62 75 69 6c 64 73 20 61 20 6e  truct builds a n
0e40: 65 77 20 72 65 70 6f 73 69 74 6f 72 79 0a 20 20  ew repository.  
0e50: 20 20 63 6f 6e 74 61 69 6e 69 6e 67 20 61 6c 6c    containing all
0e60: 20 66 69 6c 65 73 20 69 6e 20 61 6e 20 69 6e 64   files in an ind
0e70: 69 63 61 74 65 64 20 64 69 72 65 63 74 6f 72 79  icated directory
0e80: 2e 20 20 57 68 65 6e 20 72 65 63 6f 6e 73 74 72  .  When reconstr
0e90: 75 63 74 69 6e 67 2c 0a 20 20 20 20 73 6f 6d 65  ucting,.    some
0ea0: 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 20 69 73 20   information is 
0eb0: 6c 6f 73 74 3a 20 70 72 6f 6a 65 63 74 2d 63 6f  lost: project-co
0ec0: 64 65 2c 20 73 65 72 76 65 72 2d 63 6f 64 65 2c  de, server-code,
0ed0: 20 75 73 65 72 73 2e 20 20 0a 20 20 20 20 4a 75   users.  .    Ju
0ee0: 73 74 20 6d 61 6b 65 20 75 70 20 61 20 6e 65 77  st make up a new
0ef0: 20 70 72 6f 6a 65 63 74 2d 63 6f 64 65 2e 20 20   project-code.  
0f00: 0a 0a 20 2a 20 20 47 65 74 20 61 20 62 75 69 6c  .. *  Get a buil
0f10: 64 20 77 6f 72 6b 69 6e 67 20 66 6f 72 20 77 69  d working for wi
0f20: 6e 33 32 2e 20 20 50 65 72 68 61 70 73 20 75 73  n32.  Perhaps us
0f30: 65 20 63 79 67 77 69 6e 2e 20 20 4f 72 20 6f 6d  e cygwin.  Or om
0f40: 69 74 0a 20 20 20 20 74 68 65 20 73 65 72 76 65  it.    the serve
0f50: 72 20 63 6f 6d 70 6f 6e 65 6e 74 20 66 72 6f 6d  r component from
0f60: 20 77 69 6e 33 32 20 28 74 6f 20 65 6c 69 6d 69   win32 (to elimi
0f70: 6e 61 74 65 20 74 68 65 20 6e 65 65 64 20 66 6f  nate the need fo
0f80: 72 20 66 6f 72 6b 28 29 29 2e 0a                 r fork())..