Fossil

Hex Artifact Content
Login

Artifact 23a693054f1e70a9a63ca032ad5f66611cab0dfa:


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 38 20 44 2e 20 52 69 63 68  (c) 2008 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 53 69 6d 70 6c 69 66 69 65 64 20 42 53 44 20   Simplified BSD 
00a0: 4c 69 63 65 6e 73 65 20 28 61 6c 73 6f 0a 2a 2a  License (also.**
00b0: 20 6b 6e 6f 77 6e 20 61 73 20 74 68 65 20 22 32   known as the "2
00c0: 2d 43 6c 61 75 73 65 20 4c 69 63 65 6e 73 65 22  -Clause License"
00d0: 20 6f 72 20 22 46 72 65 65 42 53 44 20 4c 69 63   or "FreeBSD Lic
00e0: 65 6e 73 65 22 2e 29 0a 0a 2a 2a 20 54 68 69 73  ense".)..** This
00f0: 20 70 72 6f 67 72 61 6d 20 69 73 20 64 69 73 74   program is dist
0100: 72 69 62 75 74 65 64 20 69 6e 20 74 68 65 20 68  ributed in the h
0110: 6f 70 65 20 74 68 61 74 20 69 74 20 77 69 6c 6c  ope that it will
0120: 20 62 65 20 75 73 65 66 75 6c 2c 0a 2a 2a 20 62   be useful,.** b
0130: 75 74 20 77 69 74 68 6f 75 74 20 61 6e 79 20 77  ut without any w
0140: 61 72 72 61 6e 74 79 3b 20 77 69 74 68 6f 75 74  arranty; without
0150: 20 65 76 65 6e 20 74 68 65 20 69 6d 70 6c 69 65   even the implie
0160: 64 20 77 61 72 72 61 6e 74 79 20 6f 66 0a 2a 2a  d warranty of.**
0170: 20 6d 65 72 63 68 61 6e 74 61 62 69 6c 69 74 79   merchantability
0180: 20 6f 72 20 66 69 74 6e 65 73 73 20 66 6f 72 20   or fitness for 
0190: 61 20 70 61 72 74 69 63 75 6c 61 72 20 70 75 72  a particular pur
01a0: 70 6f 73 65 2e 0a 2a 2a 0a 2a 2a 20 41 75 74 68  pose..**.** Auth
01b0: 6f 72 20 63 6f 6e 74 61 63 74 20 69 6e 66 6f 72  or contact infor
01c0: 6d 61 74 69 6f 6e 3a 0a 2a 2a 20 20 20 64 72 68  mation:.**   drh
01d0: 40 68 77 61 63 69 2e 63 6f 6d 0a 2a 2a 20 20 20  @hwaci.com.**   
01e0: 68 74 74 70 3a 2f 2f 77 77 77 2e 68 77 61 63 69  http://www.hwaci
01f0: 2e 63 6f 6d 2f 64 72 68 2f 0a 2a 2a 0a 2a 2a 2a  .com/drh/.**.***
0200: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0210: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0220: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0230: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0240: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 0a 2a 2a 0a  ************.**.
0250: 2a 2a 20 54 68 69 73 20 66 69 6c 65 20 63 6f 6e  ** This file con
0260: 74 61 69 6e 73 20 63 6f 64 65 20 74 6f 20 69 6d  tains code to im
0270: 70 6c 65 6d 65 6e 74 20 74 68 65 20 66 69 6c 65  plement the file
0280: 20 62 72 6f 77 73 65 72 20 77 65 62 20 69 6e 74   browser web int
0290: 65 72 66 61 63 65 2e 0a 2a 2f 0a 23 69 6e 63 6c  erface..*/.#incl
02a0: 75 64 65 20 22 63 6f 6e 66 69 67 2e 68 22 0a 23  ude "config.h".#
02b0: 69 6e 63 6c 75 64 65 20 22 62 72 6f 77 73 65 2e  include "browse.
02c0: 68 22 0a 23 69 6e 63 6c 75 64 65 20 3c 61 73 73  h".#include <ass
02d0: 65 72 74 2e 68 3e 0a 0a 2f 2a 0a 2a 2a 20 54 68  ert.h>../*.** Th
02e0: 69 73 20 69 73 20 74 68 65 20 69 6d 70 6c 65 6d  is is the implem
02f0: 65 6e 74 69 6f 6e 20 6f 66 20 74 68 65 20 22 70  ention of the "p
0300: 61 74 68 65 6c 65 6d 65 6e 74 28 58 2c 4e 29 22  athelement(X,N)"
0310: 20 53 51 4c 20 66 75 6e 63 74 69 6f 6e 2e 0a 2a   SQL function..*
0320: 2a 0a 2a 2a 20 49 66 20 58 20 69 73 20 61 20 75  *.** If X is a u
0330: 6e 69 78 2d 6c 69 6b 65 20 70 61 74 68 6e 61 6d  nix-like pathnam
0340: 65 20 28 77 69 74 68 20 22 2f 22 20 73 65 70 61  e (with "/" sepa
0350: 72 61 74 6f 72 73 29 20 61 6e 64 20 4e 20 69 73  rators) and N is
0360: 20 61 6e 0a 2a 2a 20 69 6e 74 65 67 65 72 2c 20   an.** integer, 
0370: 74 68 65 6e 20 73 6b 69 70 20 74 68 65 20 69 6e  then skip the in
0380: 69 74 69 61 6c 20 4e 20 63 68 61 72 61 63 74 65  itial N characte
0390: 72 73 20 6f 66 20 58 20 61 6e 64 20 72 65 74 75  rs of X and retu
03a0: 72 6e 20 74 68 65 0a 2a 2a 20 6e 61 6d 65 20 6f  rn the.** name o
03b0: 66 20 74 68 65 20 70 61 74 68 20 63 6f 6d 70 6f  f the path compo
03c0: 6e 65 6e 74 20 74 68 61 74 20 62 65 67 69 6e 73  nent that begins
03d0: 20 6f 6e 20 74 68 65 20 4e 2b 31 74 68 20 63 68   on the N+1th ch
03e0: 61 72 61 63 74 65 72 0a 2a 2a 20 28 6e 75 6d 62  aracter.** (numb
03f0: 65 72 65 64 20 66 72 6f 6d 20 30 29 2e 20 20 49  ered from 0).  I
0400: 66 20 74 68 65 20 70 61 74 68 20 63 6f 6d 70 6f  f the path compo
0410: 6e 65 6e 74 20 69 73 20 61 20 64 69 72 65 63 74  nent is a direct
0420: 6f 72 79 20 28 69 66 0a 2a 2a 20 69 74 20 69 73  ory (if.** it is
0430: 20 66 6f 6c 6c 6f 77 65 64 20 62 79 20 6f 74 68   followed by oth
0440: 65 72 20 70 61 74 68 20 63 6f 6d 70 6f 6e 65 6e  er path componen
0450: 74 73 29 20 74 68 65 6e 20 70 72 65 70 65 6e 64  ts) then prepend
0460: 20 22 2f 22 2e 0a 2a 2a 0a 2a 2a 20 45 78 61 6d   "/"..**.** Exam
0470: 70 6c 65 73 3a 0a 2a 2a 0a 2a 2a 20 20 20 20 20  ples:.**.**     
0480: 20 70 61 74 68 65 6c 65 6d 65 6e 74 28 27 61 62   pathelement('ab
0490: 63 2f 70 71 72 2f 78 79 7a 27 2c 20 34 29 20 20  c/pqr/xyz', 4)  
04a0: 2d 3e 20 20 27 2f 70 71 72 27 0a 2a 2a 20 20 20  ->  '/pqr'.**   
04b0: 20 20 20 70 61 74 68 65 6c 65 6d 65 6e 74 28 27     pathelement('
04c0: 61 62 63 2f 70 71 72 27 2c 20 34 29 20 20 20 20  abc/pqr', 4)    
04d0: 20 20 2d 3e 20 20 27 70 71 72 27 0a 2a 2a 20 20    ->  'pqr'.**  
04e0: 20 20 20 20 70 61 74 68 65 6c 65 6d 65 6e 74 28      pathelement(
04f0: 27 61 62 63 2f 70 71 72 2f 78 79 7a 27 2c 20 30  'abc/pqr/xyz', 0
0500: 29 20 20 2d 3e 20 20 27 2f 61 62 63 27 0a 2a 2f  )  ->  '/abc'.*/
0510: 0a 73 74 61 74 69 63 20 76 6f 69 64 20 70 61 74  .static void pat
0520: 68 65 6c 65 6d 65 6e 74 46 75 6e 63 28 0a 20 20  helementFunc(.  
0530: 73 71 6c 69 74 65 33 5f 63 6f 6e 74 65 78 74 20  sqlite3_context 
0540: 2a 63 6f 6e 74 65 78 74 2c 0a 20 20 69 6e 74 20  *context,.  int 
0550: 61 72 67 63 2c 0a 20 20 73 71 6c 69 74 65 33 5f  argc,.  sqlite3_
0560: 76 61 6c 75 65 20 2a 2a 61 72 67 76 0a 29 7b 0a  value **argv.){.
0570: 20 20 63 6f 6e 73 74 20 75 6e 73 69 67 6e 65 64    const unsigned
0580: 20 63 68 61 72 20 2a 7a 3b 0a 20 20 69 6e 74 20   char *z;.  int 
0590: 6c 65 6e 2c 20 6e 2c 20 69 3b 0a 20 20 63 68 61  len, n, i;.  cha
05a0: 72 20 2a 7a 4f 75 74 3b 0a 0a 20 20 61 73 73 65  r *zOut;..  asse
05b0: 72 74 28 20 61 72 67 63 3d 3d 32 20 29 3b 0a 20  rt( argc==2 );. 
05c0: 20 7a 20 3d 20 73 71 6c 69 74 65 33 5f 76 61 6c   z = sqlite3_val
05d0: 75 65 5f 74 65 78 74 28 61 72 67 76 5b 30 5d 29  ue_text(argv[0])
05e0: 3b 0a 20 20 69 66 28 20 7a 3d 3d 30 20 29 20 72  ;.  if( z==0 ) r
05f0: 65 74 75 72 6e 3b 0a 20 20 6c 65 6e 20 3d 20 73  eturn;.  len = s
0600: 71 6c 69 74 65 33 5f 76 61 6c 75 65 5f 62 79 74  qlite3_value_byt
0610: 65 73 28 61 72 67 76 5b 30 5d 29 3b 0a 20 20 6e  es(argv[0]);.  n
0620: 20 3d 20 73 71 6c 69 74 65 33 5f 76 61 6c 75 65   = sqlite3_value
0630: 5f 69 6e 74 28 61 72 67 76 5b 31 5d 29 3b 0a 20  _int(argv[1]);. 
0640: 20 69 66 28 20 6c 65 6e 3c 3d 6e 20 29 20 72 65   if( len<=n ) re
0650: 74 75 72 6e 3b 0a 20 20 69 66 28 20 6e 3e 30 20  turn;.  if( n>0 
0660: 26 26 20 7a 5b 6e 2d 31 5d 21 3d 27 2f 27 20 29  && z[n-1]!='/' )
0670: 20 72 65 74 75 72 6e 3b 0a 20 20 66 6f 72 28 69   return;.  for(i
0680: 3d 6e 3b 20 69 3c 6c 65 6e 20 26 26 20 7a 5b 69  =n; i<len && z[i
0690: 5d 21 3d 27 2f 27 3b 20 69 2b 2b 29 7b 7d 0a 20  ]!='/'; i++){}. 
06a0: 20 69 66 28 20 69 3d 3d 6c 65 6e 20 29 7b 0a 20   if( i==len ){. 
06b0: 20 20 20 73 71 6c 69 74 65 33 5f 72 65 73 75 6c     sqlite3_resul
06c0: 74 5f 74 65 78 74 28 63 6f 6e 74 65 78 74 2c 20  t_text(context, 
06d0: 28 63 68 61 72 2a 29 26 7a 5b 6e 5d 2c 20 6c 65  (char*)&z[n], le
06e0: 6e 2d 6e 2c 20 53 51 4c 49 54 45 5f 54 52 41 4e  n-n, SQLITE_TRAN
06f0: 53 49 45 4e 54 29 3b 0a 20 20 7d 65 6c 73 65 7b  SIENT);.  }else{
0700: 0a 20 20 20 20 7a 4f 75 74 20 3d 20 73 71 6c 69  .    zOut = sqli
0710: 74 65 33 5f 6d 70 72 69 6e 74 66 28 22 2f 25 2e  te3_mprintf("/%.
0720: 2a 73 22 2c 20 69 2d 6e 2c 20 26 7a 5b 6e 5d 29  *s", i-n, &z[n])
0730: 3b 0a 20 20 20 20 73 71 6c 69 74 65 33 5f 72 65  ;.    sqlite3_re
0740: 73 75 6c 74 5f 74 65 78 74 28 63 6f 6e 74 65 78  sult_text(contex
0750: 74 2c 20 7a 4f 75 74 2c 20 69 2d 6e 2b 31 2c 20  t, zOut, i-n+1, 
0760: 73 71 6c 69 74 65 33 5f 66 72 65 65 29 3b 0a 20  sqlite3_free);. 
0770: 20 7d 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 47 69 76 65   }.}../*.** Give
0780: 6e 20 61 20 70 61 74 68 6e 61 6d 65 20 77 68 69  n a pathname whi
0790: 63 68 20 69 73 20 61 20 72 65 6c 61 74 69 76 65  ch is a relative
07a0: 20 70 61 74 68 20 66 72 6f 6d 20 74 68 65 20 72   path from the r
07b0: 6f 6f 74 20 6f 66 0a 2a 2a 20 74 68 65 20 72 65  oot of.** the re
07c0: 70 6f 73 69 74 6f 72 79 20 74 6f 20 61 20 66 69  pository to a fi
07d0: 6c 65 20 6f 72 20 64 69 72 65 63 74 6f 72 79 2c  le or directory,
07e0: 20 63 6f 6d 70 75 74 65 20 61 20 73 74 72 69 6e   compute a strin
07f0: 67 20 77 68 69 63 68 0a 2a 2a 20 69 73 20 61 6e  g which.** is an
0800: 20 48 54 4d 4c 20 72 65 6e 64 65 72 69 6e 67 20   HTML rendering 
0810: 6f 66 20 74 68 61 74 20 70 61 74 68 20 77 69 74  of that path wit
0820: 68 20 68 79 70 65 72 6c 69 6e 6b 73 20 6f 6e 20  h hyperlinks on 
0830: 65 61 63 68 0a 2a 2a 20 64 69 72 65 63 74 6f 72  each.** director
0840: 79 20 63 6f 6d 70 6f 6e 65 6e 74 20 6f 66 20 74  y component of t
0850: 68 65 20 70 61 74 68 20 77 68 65 72 65 20 74 68  he path where th
0860: 65 20 68 79 70 65 72 6c 69 6e 6b 20 72 65 64 69  e hyperlink redi
0870: 72 65 63 74 73 0a 2a 2a 20 74 6f 20 74 68 65 20  rects.** to the 
0880: 22 64 69 72 22 20 70 61 67 65 20 66 6f 72 20 74  "dir" page for t
0890: 68 65 20 64 69 72 65 63 74 6f 72 79 2e 0a 2a 2a  he directory..**
08a0: 0a 2a 2a 20 54 68 65 72 65 20 69 73 20 6e 6f 20  .** There is no 
08b0: 68 79 70 65 72 6c 69 6e 6b 20 6f 6e 20 74 68 65  hyperlink on the
08c0: 20 66 69 6c 65 20 65 6c 65 6d 65 6e 74 20 6f 66   file element of
08d0: 20 74 68 65 20 70 61 74 68 2e 0a 2a 2a 0a 2a 2a   the path..**.**
08e0: 20 54 68 65 20 63 6f 6d 70 75 74 65 64 20 73 74   The computed st
08f0: 72 69 6e 67 20 69 73 20 61 70 70 65 6e 64 65 64  ring is appended
0900: 20 74 6f 20 74 68 65 20 70 4f 75 74 20 62 6c 6f   to the pOut blo
0910: 62 2e 20 20 70 4f 75 74 20 73 68 6f 75 6c 64 0a  b.  pOut should.
0920: 2a 2a 20 68 61 76 65 20 61 6c 72 65 61 64 79 20  ** have already 
0930: 62 65 65 6e 20 69 6e 69 74 69 61 6c 69 7a 65 64  been initialized
0940: 2e 0a 2a 2f 0a 76 6f 69 64 20 68 79 70 65 72 6c  ..*/.void hyperl
0950: 69 6e 6b 65 64 5f 70 61 74 68 28 63 6f 6e 73 74  inked_path(const
0960: 20 63 68 61 72 20 2a 7a 50 61 74 68 2c 20 42 6c   char *zPath, Bl
0970: 6f 62 20 2a 70 4f 75 74 29 7b 0a 20 20 69 6e 74  ob *pOut){.  int
0980: 20 69 2c 20 6a 3b 0a 20 20 63 68 61 72 20 2a 7a   i, j;.  char *z
0990: 53 65 70 20 3d 20 22 22 3b 0a 0a 20 20 66 6f 72  Sep = "";..  for
09a0: 28 69 3d 30 3b 20 7a 50 61 74 68 5b 69 5d 3b 20  (i=0; zPath[i]; 
09b0: 69 3d 6a 29 7b 0a 20 20 20 20 66 6f 72 28 6a 3d  i=j){.    for(j=
09c0: 69 3b 20 7a 50 61 74 68 5b 6a 5d 20 26 26 20 7a  i; zPath[j] && z
09d0: 50 61 74 68 5b 6a 5d 21 3d 27 2f 27 3b 20 6a 2b  Path[j]!='/'; j+
09e0: 2b 29 7b 7d 0a 20 20 20 20 69 66 28 20 7a 50 61  +){}.    if( zPa
09f0: 74 68 5b 6a 5d 20 26 26 20 67 2e 6f 6b 48 69 73  th[j] && g.okHis
0a00: 74 6f 72 79 20 29 7b 0a 20 20 20 20 20 20 62 6c  tory ){.      bl
0a10: 6f 62 5f 61 70 70 65 6e 64 66 28 70 4f 75 74 2c  ob_appendf(pOut,
0a20: 20 22 25 73 3c 61 20 68 72 65 66 3d 5c 22 25 73   "%s<a href=\"%s
0a30: 2f 64 69 72 3f 6e 61 6d 65 3d 25 23 54 5c 22 3e  /dir?name=%#T\">
0a40: 25 23 68 3c 2f 61 3e 22 2c 20 0a 20 20 20 20 20  %#h</a>", .     
0a50: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 7a 53                zS
0a60: 65 70 2c 20 67 2e 7a 42 61 73 65 55 52 4c 2c 20  ep, g.zBaseURL, 
0a70: 6a 2c 20 7a 50 61 74 68 2c 20 6a 2d 69 2c 20 26  j, zPath, j-i, &
0a80: 7a 50 61 74 68 5b 69 5d 29 3b 0a 20 20 20 20 7d  zPath[i]);.    }
0a90: 65 6c 73 65 7b 0a 20 20 20 20 20 20 62 6c 6f 62  else{.      blob
0aa0: 5f 61 70 70 65 6e 64 66 28 70 4f 75 74 2c 20 22  _appendf(pOut, "
0ab0: 25 73 25 23 68 22 2c 20 7a 53 65 70 2c 20 6a 2d  %s%#h", zSep, j-
0ac0: 69 2c 20 26 7a 50 61 74 68 5b 69 5d 29 3b 0a 20  i, &zPath[i]);. 
0ad0: 20 20 20 7d 0a 20 20 20 20 7a 53 65 70 20 3d 20     }.    zSep = 
0ae0: 22 2f 22 3b 0a 20 20 20 20 77 68 69 6c 65 28 20  "/";.    while( 
0af0: 7a 50 61 74 68 5b 6a 5d 3d 3d 27 2f 27 20 29 7b  zPath[j]=='/' ){
0b00: 20 6a 2b 2b 3b 20 7d 0a 20 20 7d 0a 7d 0a 0a 0a   j++; }.  }.}...
0b10: 2f 2a 0a 2a 2a 20 57 45 42 50 41 47 45 3a 20 64  /*.** WEBPAGE: d
0b20: 69 72 0a 2a 2a 0a 2a 2a 20 51 75 65 72 79 20 70  ir.**.** Query p
0b30: 61 72 61 6d 65 74 65 72 73 3a 0a 2a 2a 0a 2a 2a  arameters:.**.**
0b40: 20 20 20 20 6e 61 6d 65 3d 50 41 54 48 20 20 20      name=PATH   
0b50: 20 20 20 20 20 44 69 72 65 63 74 6f 72 79 20 74       Directory t
0b60: 6f 20 64 69 73 70 6c 61 79 2e 20 20 52 65 71 75  o display.  Requ
0b70: 69 72 65 64 2e 0a 2a 2a 20 20 20 20 63 69 3d 4c  ired..**    ci=L
0b80: 41 42 45 4c 20 20 20 20 20 20 20 20 20 53 68 6f  ABEL         Sho
0b90: 77 20 6f 6e 6c 79 20 66 69 6c 65 73 20 69 6e 20  w only files in 
0ba0: 74 68 69 73 20 63 68 65 63 6b 2d 69 6e 2e 20 20  this check-in.  
0bb0: 4f 70 74 69 6f 6e 61 6c 2e 0a 2a 2f 0a 76 6f 69  Optional..*/.voi
0bc0: 64 20 70 61 67 65 5f 64 69 72 28 76 6f 69 64 29  d page_dir(void)
0bd0: 7b 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  {.  const char *
0be0: 7a 44 20 3d 20 50 28 22 6e 61 6d 65 22 29 3b 0a  zD = P("name");.
0bf0: 20 20 69 6e 74 20 6d 78 4c 65 6e 3b 0a 20 20 69    int mxLen;.  i
0c00: 6e 74 20 6e 43 6f 6c 2c 20 6e 52 6f 77 3b 0a 20  nt nCol, nRow;. 
0c10: 20 69 6e 74 20 63 6e 74 2c 20 69 3b 0a 20 20 63   int cnt, i;.  c
0c20: 68 61 72 20 2a 7a 50 72 65 66 69 78 3b 0a 20 20  har *zPrefix;.  
0c30: 53 74 6d 74 20 71 3b 0a 20 20 63 6f 6e 73 74 20  Stmt q;.  const 
0c40: 63 68 61 72 20 2a 7a 43 49 20 3d 20 50 28 22 63  char *zCI = P("c
0c50: 69 22 29 3b 0a 20 20 69 6e 74 20 72 69 64 20 3d  i");.  int rid =
0c60: 20 30 3b 0a 20 20 42 6c 6f 62 20 63 6f 6e 74 65   0;.  Blob conte
0c70: 6e 74 3b 0a 20 20 42 6c 6f 62 20 64 69 72 6e 61  nt;.  Blob dirna
0c80: 6d 65 3b 0a 20 20 4d 61 6e 69 66 65 73 74 20 6d  me;.  Manifest m
0c90: 3b 0a 20 20 63 6f 6e 73 74 20 63 68 61 72 20 2a  ;.  const char *
0ca0: 7a 53 75 62 64 69 72 4c 69 6e 6b 3b 0a 0a 20 20  zSubdirLink;..  
0cb0: 6c 6f 67 69 6e 5f 63 68 65 63 6b 5f 63 72 65 64  login_check_cred
0cc0: 65 6e 74 69 61 6c 73 28 29 3b 0a 20 20 69 66 28  entials();.  if(
0cd0: 20 21 67 2e 6f 6b 48 69 73 74 6f 72 79 20 29 7b   !g.okHistory ){
0ce0: 20 6c 6f 67 69 6e 5f 6e 65 65 64 65 64 28 29 3b   login_needed();
0cf0: 20 72 65 74 75 72 6e 3b 20 7d 0a 20 20 73 74 79   return; }.  sty
0d00: 6c 65 5f 68 65 61 64 65 72 28 22 46 69 6c 65 20  le_header("File 
0d10: 4c 69 73 74 22 29 3b 0a 20 20 73 71 6c 69 74 65  List");.  sqlite
0d20: 33 5f 63 72 65 61 74 65 5f 66 75 6e 63 74 69 6f  3_create_functio
0d30: 6e 28 67 2e 64 62 2c 20 22 70 61 74 68 65 6c 65  n(g.db, "pathele
0d40: 6d 65 6e 74 22 2c 20 32 2c 20 53 51 4c 49 54 45  ment", 2, SQLITE
0d50: 5f 55 54 46 38 2c 20 30 2c 0a 20 20 20 20 20 20  _UTF8, 0,.      
0d60: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
0d70: 20 20 20 20 70 61 74 68 65 6c 65 6d 65 6e 74 46      pathelementF
0d80: 75 6e 63 2c 20 30 2c 20 30 29 3b 0a 0a 20 20 2f  unc, 0, 0);..  /
0d90: 2a 20 49 66 20 74 68 65 20 6e 61 6d 65 3d 20 70  * If the name= p
0da0: 61 72 61 6d 65 74 65 72 20 69 73 20 61 6e 20 65  arameter is an e
0db0: 6d 70 74 79 20 73 74 72 69 6e 67 2c 20 6d 61 6b  mpty string, mak
0dc0: 65 20 69 74 20 61 20 4e 55 4c 4c 20 70 6f 69 6e  e it a NULL poin
0dd0: 74 65 72 20 2a 2f 0a 20 20 69 66 28 20 7a 44 20  ter */.  if( zD 
0de0: 26 26 20 73 74 72 6c 65 6e 28 7a 44 29 3d 3d 30  && strlen(zD)==0
0df0: 20 29 7b 20 7a 44 20 3d 20 30 3b 20 7d 0a 0a 20   ){ zD = 0; }.. 
0e00: 20 2f 2a 20 49 66 20 61 20 73 70 65 63 69 66 69   /* If a specifi
0e10: 63 20 63 68 65 63 6b 2d 69 6e 20 69 73 20 72 65  c check-in is re
0e20: 71 75 65 73 74 65 64 2c 20 66 65 74 63 68 20 61  quested, fetch a
0e30: 6e 64 20 70 61 72 73 65 20 69 74 2e 20 2a 2f 0a  nd parse it. */.
0e40: 20 20 69 66 28 20 7a 43 49 20 26 26 20 28 72 69    if( zCI && (ri
0e50: 64 20 3d 20 6e 61 6d 65 5f 74 6f 5f 72 69 64 28  d = name_to_rid(
0e60: 7a 43 49 29 29 21 3d 30 20 26 26 20 63 6f 6e 74  zCI))!=0 && cont
0e70: 65 6e 74 5f 67 65 74 28 72 69 64 2c 20 26 63 6f  ent_get(rid, &co
0e80: 6e 74 65 6e 74 29 20 29 7b 0a 20 20 20 20 69 66  ntent) ){.    if
0e90: 28 20 21 6d 61 6e 69 66 65 73 74 5f 70 61 72 73  ( !manifest_pars
0ea0: 65 28 26 6d 2c 20 26 63 6f 6e 74 65 6e 74 29 20  e(&m, &content) 
0eb0: 7c 7c 20 6d 2e 74 79 70 65 21 3d 43 46 54 59 50  || m.type!=CFTYP
0ec0: 45 5f 4d 41 4e 49 46 45 53 54 20 29 7b 0a 20 20  E_MANIFEST ){.  
0ed0: 20 20 20 20 7a 43 49 20 3d 20 30 3b 0a 20 20 20      zCI = 0;.   
0ee0: 20 7d 0a 20 20 7d 0a 0a 20 20 2f 2a 20 43 6f 6d   }.  }..  /* Com
0ef0: 70 75 74 65 20 74 68 65 20 74 69 74 6c 65 20 6f  pute the title o
0f00: 66 20 74 68 65 20 70 61 67 65 20 2a 2f 20 20 0a  f the page */  .
0f10: 20 20 62 6c 6f 62 5f 7a 65 72 6f 28 26 64 69 72    blob_zero(&dir
0f20: 6e 61 6d 65 29 3b 0a 20 20 69 66 28 20 7a 44 20  name);.  if( zD 
0f30: 29 7b 0a 20 20 20 20 62 6c 6f 62 5f 61 70 70 65  ){.    blob_appe
0f40: 6e 64 28 26 64 69 72 6e 61 6d 65 2c 20 22 69 6e  nd(&dirname, "in
0f50: 20 64 69 72 65 63 74 6f 72 79 20 22 2c 20 2d 31   directory ", -1
0f60: 29 3b 0a 20 20 20 20 68 79 70 65 72 6c 69 6e 6b  );.    hyperlink
0f70: 65 64 5f 70 61 74 68 28 7a 44 2c 20 26 64 69 72  ed_path(zD, &dir
0f80: 6e 61 6d 65 29 3b 0a 20 20 20 20 7a 50 72 65 66  name);.    zPref
0f90: 69 78 20 3d 20 6d 70 72 69 6e 74 66 28 22 25 68  ix = mprintf("%h
0fa0: 2f 22 2c 20 7a 44 29 3b 0a 20 20 7d 65 6c 73 65  /", zD);.  }else
0fb0: 7b 0a 20 20 20 20 62 6c 6f 62 5f 61 70 70 65 6e  {.    blob_appen
0fc0: 64 28 26 64 69 72 6e 61 6d 65 2c 20 22 69 6e 20  d(&dirname, "in 
0fd0: 74 68 65 20 74 6f 70 2d 6c 65 76 65 6c 20 64 69  the top-level di
0fe0: 72 65 63 74 6f 72 79 22 2c 20 2d 31 29 3b 0a 20  rectory", -1);. 
0ff0: 20 20 20 7a 50 72 65 66 69 78 20 3d 20 22 22 3b     zPrefix = "";
1000: 0a 20 20 7d 0a 20 20 69 66 28 20 7a 43 49 20 29  .  }.  if( zCI )
1010: 7b 0a 20 20 20 20 63 68 61 72 20 2a 7a 55 75 69  {.    char *zUui
1020: 64 20 3d 20 64 62 5f 74 65 78 74 28 30 2c 20 22  d = db_text(0, "
1030: 53 45 4c 45 43 54 20 75 75 69 64 20 46 52 4f 4d  SELECT uuid FROM
1040: 20 62 6c 6f 62 20 57 48 45 52 45 20 72 69 64 3d   blob WHERE rid=
1050: 25 64 22 2c 20 72 69 64 29 3b 0a 20 20 20 20 63  %d", rid);.    c
1060: 68 61 72 20 7a 53 68 6f 72 74 5b 32 30 5d 3b 0a  har zShort[20];.
1070: 20 20 20 20 6d 65 6d 63 70 79 28 7a 53 68 6f 72      memcpy(zShor
1080: 74 2c 20 7a 55 75 69 64 2c 20 31 30 29 3b 0a 20  t, zUuid, 10);. 
1090: 20 20 20 7a 53 68 6f 72 74 5b 31 30 5d 20 3d 20     zShort[10] = 
10a0: 30 3b 0a 20 20 20 20 40 20 3c 68 32 3e 46 69 6c  0;.    @ <h2>Fil
10b0: 65 73 20 6f 66 20 63 68 65 63 6b 2d 69 6e 20 5b  es of check-in [
10c0: 3c 61 20 68 72 65 66 3d 22 76 69 6e 66 6f 3f 6e  <a href="vinfo?n
10d0: 61 6d 65 3d 25 54 28 7a 55 75 69 64 29 22 3e 25  ame=%T(zUuid)">%
10e0: 73 28 7a 53 68 6f 72 74 29 3c 2f 61 3e 5d 0a 20  s(zShort)</a>]. 
10f0: 20 20 20 40 20 25 73 28 62 6c 6f 62 5f 73 74 72     @ %s(blob_str
1100: 28 26 64 69 72 6e 61 6d 65 29 29 3c 2f 68 32 3e  (&dirname))</h2>
1110: 0a 20 20 20 20 7a 53 75 62 64 69 72 4c 69 6e 6b  .    zSubdirLink
1120: 20 3d 20 6d 70 72 69 6e 74 66 28 22 25 73 2f 64   = mprintf("%s/d
1130: 69 72 3f 63 69 3d 25 53 26 6e 61 6d 65 3d 25 54  ir?ci=%S&name=%T
1140: 22 2c 20 67 2e 7a 54 6f 70 2c 20 7a 55 75 69 64  ", g.zTop, zUuid
1150: 2c 20 7a 50 72 65 66 69 78 29 3b 0a 20 20 20 20  , zPrefix);.    
1160: 69 66 28 20 7a 44 20 29 7b 0a 20 20 20 20 20 20  if( zD ){.      
1170: 73 74 79 6c 65 5f 73 75 62 6d 65 6e 75 5f 65 6c  style_submenu_el
1180: 65 6d 65 6e 74 28 22 54 6f 70 22 2c 20 22 54 6f  ement("Top", "To
1190: 70 22 2c 20 22 25 73 2f 64 69 72 3f 63 69 3d 25  p", "%s/dir?ci=%
11a0: 53 22 2c 20 67 2e 7a 54 6f 70 2c 20 7a 55 75 69  S", g.zTop, zUui
11b0: 64 29 3b 0a 20 20 20 20 20 20 73 74 79 6c 65 5f  d);.      style_
11c0: 73 75 62 6d 65 6e 75 5f 65 6c 65 6d 65 6e 74 28  submenu_element(
11d0: 22 41 6c 6c 22 2c 20 22 41 6c 6c 22 2c 20 22 25  "All", "All", "%
11e0: 73 2f 64 69 72 3f 6e 61 6d 65 3d 25 74 22 2c 20  s/dir?name=%t", 
11f0: 67 2e 7a 54 6f 70 2c 20 7a 44 29 3b 0a 20 20 20  g.zTop, zD);.   
1200: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 73 74   }else{.      st
1210: 79 6c 65 5f 73 75 62 6d 65 6e 75 5f 65 6c 65 6d  yle_submenu_elem
1220: 65 6e 74 28 22 41 6c 6c 22 2c 20 22 41 6c 6c 22  ent("All", "All"
1230: 2c 20 22 25 73 2f 64 69 72 22 2c 20 67 2e 7a 42  , "%s/dir", g.zB
1240: 61 73 65 55 52 4c 29 3b 0a 20 20 20 20 7d 0a 20  aseURL);.    }. 
1250: 20 7d 65 6c 73 65 7b 0a 20 20 20 20 40 20 3c 68   }else{.    @ <h
1260: 32 3e 54 68 65 20 75 6e 69 6f 6e 20 6f 66 20 61  2>The union of a
1270: 6c 6c 20 66 69 6c 65 73 20 66 72 6f 6d 20 61 6c  ll files from al
1280: 6c 20 63 68 65 63 6b 2d 69 6e 73 0a 20 20 20 20  l check-ins.    
1290: 40 20 25 73 28 62 6c 6f 62 5f 73 74 72 28 26 64  @ %s(blob_str(&d
12a0: 69 72 6e 61 6d 65 29 29 3c 2f 68 32 3e 0a 20 20  irname))</h2>.  
12b0: 20 20 7a 53 75 62 64 69 72 4c 69 6e 6b 20 3d 20    zSubdirLink = 
12c0: 6d 70 72 69 6e 74 66 28 22 25 73 2f 64 69 72 3f  mprintf("%s/dir?
12d0: 6e 61 6d 65 3d 25 54 22 2c 20 67 2e 7a 42 61 73  name=%T", g.zBas
12e0: 65 55 52 4c 2c 20 7a 50 72 65 66 69 78 29 3b 0a  eURL, zPrefix);.
12f0: 20 20 20 20 69 66 28 20 7a 44 20 29 7b 0a 20 20      if( zD ){.  
1300: 20 20 20 20 73 74 79 6c 65 5f 73 75 62 6d 65 6e      style_submen
1310: 75 5f 65 6c 65 6d 65 6e 74 28 22 54 6f 70 22 2c  u_element("Top",
1320: 20 22 54 6f 70 22 2c 20 22 25 73 2f 64 69 72 22   "Top", "%s/dir"
1330: 2c 20 67 2e 7a 42 61 73 65 55 52 4c 29 3b 0a 20  , g.zBaseURL);. 
1340: 20 20 20 20 20 73 74 79 6c 65 5f 73 75 62 6d 65       style_subme
1350: 6e 75 5f 65 6c 65 6d 65 6e 74 28 22 54 69 70 22  nu_element("Tip"
1360: 2c 20 22 54 69 70 22 2c 20 22 25 73 2f 64 69 72  , "Tip", "%s/dir
1370: 3f 6e 61 6d 65 3d 25 74 26 63 69 3d 74 69 70 22  ?name=%t&ci=tip"
1380: 2c 0a 20 20 20 20 20 20 20 20 20 20 20 20 20 20  ,.              
1390: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 67 2e                g.
13a0: 7a 42 61 73 65 55 52 4c 2c 20 7a 44 29 3b 0a 20  zBaseURL, zD);. 
13b0: 20 20 20 20 20 73 74 79 6c 65 5f 73 75 62 6d 65       style_subme
13c0: 6e 75 5f 65 6c 65 6d 65 6e 74 28 22 54 72 75 6e  nu_element("Trun
13d0: 6b 22 2c 20 22 54 72 75 6e 6b 22 2c 20 22 25 73  k", "Trunk", "%s
13e0: 2f 64 69 72 3f 6e 61 6d 65 3d 25 74 26 63 69 3d  /dir?name=%t&ci=
13f0: 74 72 75 6e 6b 22 2c 0a 20 20 20 20 20 20 20 20  trunk",.        
1400: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
1410: 20 20 20 20 20 67 2e 7a 42 61 73 65 55 52 4c 2c       g.zBaseURL,
1420: 7a 44 29 3b 0a 20 20 20 20 7d 65 6c 73 65 7b 0a  zD);.    }else{.
1430: 20 20 20 20 20 20 73 74 79 6c 65 5f 73 75 62 6d        style_subm
1440: 65 6e 75 5f 65 6c 65 6d 65 6e 74 28 22 54 69 70  enu_element("Tip
1450: 22 2c 20 22 54 69 70 22 2c 20 22 25 73 2f 64 69  ", "Tip", "%s/di
1460: 72 3f 63 69 3d 74 69 70 22 2c 20 67 2e 7a 42 61  r?ci=tip", g.zBa
1470: 73 65 55 52 4c 29 3b 0a 20 20 20 20 20 20 73 74  seURL);.      st
1480: 79 6c 65 5f 73 75 62 6d 65 6e 75 5f 65 6c 65 6d  yle_submenu_elem
1490: 65 6e 74 28 22 54 72 75 6e 6b 22 2c 20 22 54 72  ent("Trunk", "Tr
14a0: 75 6e 6b 22 2c 20 22 25 73 2f 64 69 72 3f 63 69  unk", "%s/dir?ci
14b0: 3d 74 72 75 6e 6b 22 2c 20 67 2e 7a 42 61 73 65  =trunk", g.zBase
14c0: 55 52 4c 29 3b 0a 20 20 20 20 7d 0a 20 20 7d 0a  URL);.    }.  }.
14d0: 0a 20 20 2f 2a 20 43 6f 6d 70 75 74 65 20 74 68  .  /* Compute th
14e0: 65 20 74 65 6d 70 6f 72 61 72 79 20 74 61 62 6c  e temporary tabl
14f0: 65 20 22 6c 6f 63 61 6c 66 69 6c 65 73 22 20 63  e "localfiles" c
1500: 6f 6e 74 61 69 6e 69 6e 67 20 74 68 65 20 6e 61  ontaining the na
1510: 6d 65 73 0a 20 20 2a 2a 20 6f 66 20 61 6c 6c 20  mes.  ** of all 
1520: 66 69 6c 65 73 20 61 6e 64 20 73 75 62 64 69 72  files and subdir
1530: 65 63 74 6f 72 69 65 73 20 69 6e 20 74 68 65 20  ectories in the 
1540: 7a 44 5b 5d 20 64 69 72 65 63 74 6f 72 79 2e 20  zD[] directory. 
1550: 20 0a 20 20 2a 2a 0a 20 20 2a 2a 20 53 75 62 64   .  **.  ** Subd
1560: 69 72 65 63 74 6f 72 79 20 6e 61 6d 65 73 20 62  irectory names b
1570: 65 67 69 6e 20 77 69 74 68 20 22 2f 22 2e 20 20  egin with "/".  
1580: 54 68 69 73 20 63 61 75 73 65 73 20 74 68 65 6d  This causes them
1590: 20 74 6f 20 73 6f 72 74 0a 20 20 2a 2a 20 66 69   to sort.  ** fi
15a0: 72 73 74 20 61 6e 64 20 69 74 20 61 6c 73 6f 20  rst and it also 
15b0: 67 69 76 65 73 20 75 73 20 61 6e 20 65 61 73 79  gives us an easy
15c0: 20 77 61 79 20 74 6f 20 64 69 73 74 69 6e 67 75   way to distingu
15d0: 69 73 68 20 66 69 6c 65 73 0a 20 20 2a 2a 20 66  ish files.  ** f
15e0: 72 6f 6d 20 64 69 72 65 63 74 6f 72 69 65 73 20  rom directories 
15f0: 69 6e 20 74 68 65 20 6c 6f 6f 70 20 74 68 61 74  in the loop that
1600: 20 66 6f 6c 6c 6f 77 73 2e 0a 20 20 2a 2f 0a 20   follows..  */. 
1610: 20 64 62 5f 6d 75 6c 74 69 5f 65 78 65 63 28 0a   db_multi_exec(.
1620: 20 20 20 20 20 22 43 52 45 41 54 45 20 54 45 4d       "CREATE TEM
1630: 50 20 54 41 42 4c 45 20 6c 6f 63 61 6c 66 69 6c  P TABLE localfil
1640: 65 73 28 78 20 55 4e 49 51 55 45 20 4e 4f 54 20  es(x UNIQUE NOT 
1650: 4e 55 4c 4c 2c 20 75 29 3b 22 0a 20 20 20 20 20  NULL, u);".     
1660: 22 43 52 45 41 54 45 20 54 45 4d 50 20 54 41 42  "CREATE TEMP TAB
1670: 4c 45 20 61 6c 6c 66 69 6c 65 73 28 78 20 55 4e  LE allfiles(x UN
1680: 49 51 55 45 20 4e 4f 54 20 4e 55 4c 4c 2c 20 75  IQUE NOT NULL, u
1690: 29 3b 22 0a 20 20 29 3b 0a 20 20 69 66 28 20 7a  );".  );.  if( z
16a0: 43 49 20 29 7b 0a 20 20 20 20 53 74 6d 74 20 69  CI ){.    Stmt i
16b0: 6e 73 3b 0a 20 20 20 20 69 6e 74 20 69 3b 0a 20  ns;.    int i;. 
16c0: 20 20 20 64 62 5f 70 72 65 70 61 72 65 28 26 69     db_prepare(&i
16d0: 6e 73 2c 20 22 49 4e 53 45 52 54 20 49 4e 54 4f  ns, "INSERT INTO
16e0: 20 61 6c 6c 66 69 6c 65 73 20 56 41 4c 55 45 53   allfiles VALUES
16f0: 28 3a 78 2c 20 3a 75 29 22 29 3b 0a 20 20 20 20  (:x, :u)");.    
1700: 66 6f 72 28 69 3d 30 3b 20 69 3c 6d 2e 6e 46 69  for(i=0; i<m.nFi
1710: 6c 65 3b 20 69 2b 2b 29 7b 0a 20 20 20 20 20 20  le; i++){.      
1720: 64 62 5f 62 69 6e 64 5f 74 65 78 74 28 26 69 6e  db_bind_text(&in
1730: 73 2c 20 22 3a 78 22 2c 20 6d 2e 61 46 69 6c 65  s, ":x", m.aFile
1740: 5b 69 5d 2e 7a 4e 61 6d 65 29 3b 0a 20 20 20 20  [i].zName);.    
1750: 20 20 64 62 5f 62 69 6e 64 5f 74 65 78 74 28 26    db_bind_text(&
1760: 69 6e 73 2c 20 22 3a 75 22 2c 20 6d 2e 61 46 69  ins, ":u", m.aFi
1770: 6c 65 5b 69 5d 2e 7a 55 75 69 64 29 3b 0a 20 20  le[i].zUuid);.  
1780: 20 20 20 20 64 62 5f 73 74 65 70 28 26 69 6e 73      db_step(&ins
1790: 29 3b 0a 20 20 20 20 20 20 64 62 5f 72 65 73 65  );.      db_rese
17a0: 74 28 26 69 6e 73 29 3b 0a 20 20 20 20 7d 0a 20  t(&ins);.    }. 
17b0: 20 20 20 64 62 5f 66 69 6e 61 6c 69 7a 65 28 26     db_finalize(&
17c0: 69 6e 73 29 3b 0a 20 20 7d 65 6c 73 65 7b 0a 20  ins);.  }else{. 
17d0: 20 20 20 64 62 5f 6d 75 6c 74 69 5f 65 78 65 63     db_multi_exec
17e0: 28 0a 20 20 20 20 20 20 22 49 4e 53 45 52 54 20  (.      "INSERT 
17f0: 49 4e 54 4f 20 61 6c 6c 66 69 6c 65 73 20 53 45  INTO allfiles SE
1800: 4c 45 43 54 20 6e 61 6d 65 2c 20 4e 55 4c 4c 20  LECT name, NULL 
1810: 46 52 4f 4d 20 66 69 6c 65 6e 61 6d 65 22 0a 20  FROM filename". 
1820: 20 20 20 29 3b 0a 20 20 7d 0a 20 20 69 66 28 20     );.  }.  if( 
1830: 7a 44 20 29 7b 0a 20 20 20 20 64 62 5f 6d 75 6c  zD ){.    db_mul
1840: 74 69 5f 65 78 65 63 28 0a 20 20 20 20 20 20 20  ti_exec(.       
1850: 22 49 4e 53 45 52 54 20 4f 52 20 49 47 4e 4f 52  "INSERT OR IGNOR
1860: 45 20 49 4e 54 4f 20 6c 6f 63 61 6c 66 69 6c 65  E INTO localfile
1870: 73 20 22 0a 20 20 20 20 20 20 20 22 20 20 53 45  s ".       "  SE
1880: 4c 45 43 54 20 70 61 74 68 65 6c 65 6d 65 6e 74  LECT pathelement
1890: 28 78 2c 25 64 29 2c 20 75 20 46 52 4f 4d 20 61  (x,%d), u FROM a
18a0: 6c 6c 66 69 6c 65 73 22 0a 20 20 20 20 20 20 20  llfiles".       
18b0: 22 20 20 20 57 48 45 52 45 20 78 20 47 4c 4f 42  "   WHERE x GLOB
18c0: 20 27 25 71 2f 2a 27 22 2c 0a 20 20 20 20 20 20   '%q/*'",.      
18d0: 20 73 74 72 6c 65 6e 28 7a 44 29 2b 31 2c 20 7a   strlen(zD)+1, z
18e0: 44 0a 20 20 20 20 29 3b 0a 20 20 7d 65 6c 73 65  D.    );.  }else
18f0: 7b 0a 20 20 20 20 64 62 5f 6d 75 6c 74 69 5f 65  {.    db_multi_e
1900: 78 65 63 28 0a 20 20 20 20 20 20 20 22 49 4e 53  xec(.       "INS
1910: 45 52 54 20 4f 52 20 49 47 4e 4f 52 45 20 49 4e  ERT OR IGNORE IN
1920: 54 4f 20 6c 6f 63 61 6c 66 69 6c 65 73 20 22 0a  TO localfiles ".
1930: 20 20 20 20 20 20 20 22 20 20 53 45 4c 45 43 54         "  SELECT
1940: 20 70 61 74 68 65 6c 65 6d 65 6e 74 28 78 2c 30   pathelement(x,0
1950: 29 2c 20 75 20 46 52 4f 4d 20 61 6c 6c 66 69 6c  ), u FROM allfil
1960: 65 73 22 0a 20 20 20 20 29 3b 0a 20 20 7d 0a 0a  es".    );.  }..
1970: 20 20 2f 2a 20 47 65 6e 65 72 61 74 65 20 61 20    /* Generate a 
1980: 6d 75 6c 74 69 2d 63 6f 6c 75 6d 6e 20 74 61 62  multi-column tab
1990: 6c 65 20 6c 69 73 74 69 6e 67 20 74 68 65 20 63  le listing the c
19a0: 6f 6e 74 65 6e 74 73 20 6f 66 20 7a 44 5b 5d 0a  ontents of zD[].
19b0: 20 20 2a 2a 20 64 69 72 65 63 74 6f 72 79 2e 0a    ** directory..
19c0: 20 20 2a 2f 0a 20 20 6d 78 4c 65 6e 20 3d 20 64    */.  mxLen = d
19d0: 62 5f 69 6e 74 28 31 32 2c 20 22 53 45 4c 45 43  b_int(12, "SELEC
19e0: 54 20 6d 61 78 28 6c 65 6e 67 74 68 28 78 29 29  T max(length(x))
19f0: 20 46 52 4f 4d 20 6c 6f 63 61 6c 66 69 6c 65 73   FROM localfiles
1a00: 20 2f 2a 73 63 61 6e 2a 2f 22 29 3b 0a 20 20 63   /*scan*/");.  c
1a10: 6e 74 20 3d 20 64 62 5f 69 6e 74 28 30 2c 20 22  nt = db_int(0, "
1a20: 53 45 4c 45 43 54 20 63 6f 75 6e 74 28 2a 29 20  SELECT count(*) 
1a30: 46 52 4f 4d 20 6c 6f 63 61 6c 66 69 6c 65 73 20  FROM localfiles 
1a40: 2f 2a 73 63 61 6e 2a 2f 22 29 3b 0a 20 20 6e 43  /*scan*/");.  nC
1a50: 6f 6c 20 3d 20 34 3b 0a 20 20 6e 52 6f 77 20 3d  ol = 4;.  nRow =
1a60: 20 28 63 6e 74 2b 6e 43 6f 6c 2d 31 29 2f 6e 43   (cnt+nCol-1)/nC
1a70: 6f 6c 3b 0a 20 20 64 62 5f 70 72 65 70 61 72 65  ol;.  db_prepare
1a80: 28 26 71 2c 20 22 53 45 4c 45 43 54 20 78 2c 20  (&q, "SELECT x, 
1a90: 75 20 46 52 4f 4d 20 6c 6f 63 61 6c 66 69 6c 65  u FROM localfile
1aa0: 73 20 4f 52 44 45 52 20 42 59 20 78 20 2f 2a 73  s ORDER BY x /*s
1ab0: 63 61 6e 2a 2f 22 29 3b 0a 20 20 40 20 3c 74 61  can*/");.  @ <ta
1ac0: 62 6c 65 20 62 6f 72 64 65 72 3d 22 30 22 20 77  ble border="0" w
1ad0: 69 64 74 68 3d 22 31 30 30 25 25 22 3e 3c 74 72  idth="100%%"><tr
1ae0: 3e 3c 74 64 20 76 61 6c 69 67 6e 3d 22 74 6f 70  ><td valign="top
1af0: 22 20 77 69 64 74 68 3d 22 32 35 25 25 22 3e 0a  " width="25%%">.
1b00: 20 20 69 20 3d 20 30 3b 0a 20 20 77 68 69 6c 65    i = 0;.  while
1b10: 28 20 64 62 5f 73 74 65 70 28 26 71 29 3d 3d 53  ( db_step(&q)==S
1b20: 51 4c 49 54 45 5f 52 4f 57 20 29 7b 0a 20 20 20  QLITE_ROW ){.   
1b30: 20 63 6f 6e 73 74 20 63 68 61 72 20 2a 7a 46 4e   const char *zFN
1b40: 3b 0a 20 20 20 20 69 66 28 20 69 3d 3d 6e 52 6f  ;.    if( i==nRo
1b50: 77 20 29 7b 0a 20 20 20 20 20 20 40 20 3c 2f 74  w ){.      @ </t
1b60: 64 3e 3c 74 64 20 76 61 6c 69 67 6e 3d 22 74 6f  d><td valign="to
1b70: 70 22 20 77 69 64 74 68 3d 22 32 35 25 25 22 3e  p" width="25%%">
1b80: 0a 20 20 20 20 20 20 69 20 3d 20 30 3b 0a 20 20  .      i = 0;.  
1b90: 20 20 7d 0a 20 20 20 20 69 2b 2b 3b 0a 20 20 20    }.    i++;.   
1ba0: 20 7a 46 4e 20 3d 20 64 62 5f 63 6f 6c 75 6d 6e   zFN = db_column
1bb0: 5f 74 65 78 74 28 26 71 2c 20 30 29 3b 0a 20 20  _text(&q, 0);.  
1bc0: 20 20 69 66 28 20 7a 46 4e 5b 30 5d 3d 3d 27 2f    if( zFN[0]=='/
1bd0: 27 20 29 7b 0a 20 20 20 20 20 20 7a 46 4e 2b 2b  ' ){.      zFN++
1be0: 3b 0a 20 20 20 20 20 20 40 20 3c 6c 69 3e 3c 61  ;.      @ <li><a
1bf0: 20 68 72 65 66 3d 22 25 73 28 7a 53 75 62 64 69   href="%s(zSubdi
1c00: 72 4c 69 6e 6b 29 25 54 28 7a 46 4e 29 22 3e 25  rLink)%T(zFN)">%
1c10: 68 28 7a 46 4e 29 2f 3c 2f 61 3e 3c 2f 6c 69 3e  h(zFN)/</a></li>
1c20: 0a 20 20 20 20 7d 65 6c 73 65 20 69 66 28 20 7a  .    }else if( z
1c30: 43 49 20 29 7b 0a 20 20 20 20 20 20 63 6f 6e 73  CI ){.      cons
1c40: 74 20 63 68 61 72 20 2a 7a 55 75 69 64 20 3d 20  t char *zUuid = 
1c50: 64 62 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74 28 26  db_column_text(&
1c60: 71 2c 20 31 29 3b 0a 20 20 20 20 20 20 40 20 3c  q, 1);.      @ <
1c70: 6c 69 3e 3c 61 20 68 72 65 66 3d 22 25 73 28 67  li><a href="%s(g
1c80: 2e 7a 42 61 73 65 55 52 4c 29 2f 61 72 74 69 66  .zBaseURL)/artif
1c90: 61 63 74 3f 6e 61 6d 65 3d 25 73 28 7a 55 75 69  act?name=%s(zUui
1ca0: 64 29 22 3e 25 68 28 7a 46 4e 29 3c 2f 61 3e 0a  d)">%h(zFN)</a>.
1cb0: 20 20 20 20 7d 65 6c 73 65 7b 0a 20 20 20 20 20      }else{.     
1cc0: 20 40 20 3c 6c 69 3e 3c 61 20 68 72 65 66 3d 22   @ <li><a href="
1cd0: 25 73 28 67 2e 7a 42 61 73 65 55 52 4c 29 2f 66  %s(g.zBaseURL)/f
1ce0: 69 6e 66 6f 3f 6e 61 6d 65 3d 25 54 28 7a 50 72  info?name=%T(zPr
1cf0: 65 66 69 78 29 25 54 28 7a 46 4e 29 22 3e 25 68  efix)%T(zFN)">%h
1d00: 28 7a 46 4e 29 3c 2f 61 3e 0a 20 20 20 20 7d 0a  (zFN)</a>.    }.
1d10: 20 20 7d 0a 20 20 64 62 5f 66 69 6e 61 6c 69 7a    }.  db_finaliz
1d20: 65 28 26 71 29 3b 0a 20 20 40 20 3c 2f 74 64 3e  e(&q);.  @ </td>
1d30: 3c 2f 74 72 3e 3c 2f 74 61 62 6c 65 3e 0a 20 20  </tr></table>.  
1d40: 73 74 79 6c 65 5f 66 6f 6f 74 65 72 28 29 3b 0a  style_footer();.
1d50: 7d 0a                                            }.