Hex Artifact Content
Not logged in

Artifact c5f7f1444b05d43c49c583124304d4106f1bab7c:

File src/tagview.c part of check-in [a12cb216b7] - Reenable the "Tags" menu item, but make it go to the new "taglist" page. Also add separate "tagtimeline" page and separate "brlist" into "brlist" and "brtimeline". by drh on 2009-01-22 13:08:42.

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 20 43 6f 70 79  ard Hipp.** Copy
0030: 72 69 67 68 74 20 28 63 29 20 32 30 30 38 20 53  right (c) 2008 S
0040: 74 65 70 68 61 6e 20 42 65 61 6c 0a 2a 2a 0a 2a  tephan Beal.**.*
0050: 2a 20 54 68 69 73 20 70 72 6f 67 72 61 6d 20 69  * This program i
0060: 73 20 66 72 65 65 20 73 6f 66 74 77 61 72 65 3b  s free software;
0070: 20 79 6f 75 20 63 61 6e 20 72 65 64 69 73 74 72   you can redistr
0080: 69 62 75 74 65 20 69 74 20 61 6e 64 2f 6f 72 0a  ibute it and/or.
0090: 2a 2a 20 6d 6f 64 69 66 79 20 69 74 20 75 6e 64  ** modify it und
00a0: 65 72 20 74 68 65 20 74 65 72 6d 73 20 6f 66 20  er the terms of 
00b0: 74 68 65 20 47 4e 55 20 47 65 6e 65 72 61 6c 20  the GNU General 
00c0: 50 75 62 6c 69 63 0a 2a 2a 20 4c 69 63 65 6e 73  Public.** Licens
00d0: 65 20 61 73 20 70 75 62 6c 69 73 68 65 64 20 62  e as published b
00e0: 79 20 74 68 65 20 46 72 65 65 20 53 6f 66 74 77  y the Free Softw
00f0: 61 72 65 20 46 6f 75 6e 64 61 74 69 6f 6e 3b 20  are Foundation; 
0100: 65 69 74 68 65 72 0a 2a 2a 20 76 65 72 73 69 6f  either.** versio
0110: 6e 20 32 20 6f 66 20 74 68 65 20 4c 69 63 65 6e  n 2 of the Licen
0120: 73 65 2c 20 6f 72 20 28 61 74 20 79 6f 75 72 20  se, or (at your 
0130: 6f 70 74 69 6f 6e 29 20 61 6e 79 20 6c 61 74 65  option) any late
0140: 72 20 76 65 72 73 69 6f 6e 2e 0a 2a 2a 0a 2a 2a  r version..**.**
0150: 20 54 68 69 73 20 70 72 6f 67 72 61 6d 20 69 73   This program is
0160: 20 64 69 73 74 72 69 62 75 74 65 64 20 69 6e 20   distributed in 
0170: 74 68 65 20 68 6f 70 65 20 74 68 61 74 20 69 74  the hope that it
0180: 20 77 69 6c 6c 20 62 65 20 75 73 65 66 75 6c 2c   will be useful,
0190: 0a 2a 2a 20 62 75 74 20 57 49 54 48 4f 55 54 20  .** but WITHOUT 
01a0: 41 4e 59 20 57 41 52 52 41 4e 54 59 3b 20 77 69  ANY WARRANTY; wi
01b0: 74 68 6f 75 74 20 65 76 65 6e 20 74 68 65 20 69  thout even the i
01c0: 6d 70 6c 69 65 64 20 77 61 72 72 61 6e 74 79 20  mplied warranty 
01d0: 6f 66 0a 2a 2a 20 4d 45 52 43 48 41 4e 54 41 42  of.** MERCHANTAB
01e0: 49 4c 49 54 59 20 6f 72 20 46 49 54 4e 45 53 53  ILITY or FITNESS
01f0: 20 46 4f 52 20 41 20 50 41 52 54 49 43 55 4c 41   FOR A PARTICULA
0200: 52 20 50 55 52 50 4f 53 45 2e 20 20 53 65 65 20  R PURPOSE.  See 
0210: 74 68 65 20 47 4e 55 0a 2a 2a 20 47 65 6e 65 72  the GNU.** Gener
0220: 61 6c 20 50 75 62 6c 69 63 20 4c 69 63 65 6e 73  al Public Licens
0230: 65 20 66 6f 72 20 6d 6f 72 65 20 64 65 74 61 69  e for more detai
0240: 6c 73 2e 0a 2a 2a 0a 2a 2a 20 59 6f 75 20 73 68  ls..**.** You sh
0250: 6f 75 6c 64 20 68 61 76 65 20 72 65 63 65 69 76  ould have receiv
0260: 65 64 20 61 20 63 6f 70 79 20 6f 66 20 74 68 65  ed a copy of the
0270: 20 47 4e 55 20 47 65 6e 65 72 61 6c 20 50 75 62   GNU General Pub
0280: 6c 69 63 0a 2a 2a 20 4c 69 63 65 6e 73 65 20 61  lic.** License a
0290: 6c 6f 6e 67 20 77 69 74 68 20 74 68 69 73 20 6c  long with this l
02a0: 69 62 72 61 72 79 3b 20 69 66 20 6e 6f 74 2c 20  ibrary; if not, 
02b0: 77 72 69 74 65 20 74 6f 20 74 68 65 0a 2a 2a 20  write to the.** 
02c0: 46 72 65 65 20 53 6f 66 74 77 61 72 65 20 46 6f  Free Software Fo
02d0: 75 6e 64 61 74 69 6f 6e 2c 20 49 6e 63 2e 2c 20  undation, Inc., 
02e0: 35 39 20 54 65 6d 70 6c 65 20 50 6c 61 63 65 20  59 Temple Place 
02f0: 2d 20 53 75 69 74 65 20 33 33 30 2c 0a 2a 2a 20  - Suite 330,.** 
0300: 42 6f 73 74 6f 6e 2c 20 4d 41 20 20 30 32 31 31  Boston, MA  0211
0310: 31 2d 31 33 30 37 2c 20 55 53 41 2e 0a 2a 2a 0a  1-1307, USA..**.
0320: 2a 2a 20 41 75 74 68 6f 72 20 63 6f 6e 74 61 63  ** Author contac
0330: 74 20 69 6e 66 6f 72 6d 61 74 69 6f 6e 3a 0a 2a  t information:.*
0340: 2a 20 20 20 64 72 68 40 68 77 61 63 69 2e 63 6f  *   drh@hwaci.co
0350: 6d 0a 2a 2a 20 20 20 68 74 74 70 3a 2f 2f 77 77  m.**   http://ww
0360: 77 2e 68 77 61 63 69 2e 63 6f 6d 2f 64 72 68 2f  w.hwaci.com/drh/
0370: 0a 2a 2a 0a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  .**.************
0380: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
0390: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
03a0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
03b0: 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a 2a  ****************
03c0: 2a 2a 2a 0a 2a 2a 0a 2a 2a 20 49 6d 70 6c 65 6d  ***.**.** Implem
03d0: 65 6e 74 61 74 69 6f 6e 20 6f 66 20 74 68 65 20  entation of the 
03e0: 54 61 67 20 56 69 65 77 20 70 61 67 65 0a 2a 2f  Tag View page.*/
03f0: 0a 23 69 6e 63 6c 75 64 65 20 3c 61 73 73 65 72  .#include <asser
0400: 74 2e 68 3e 0a 23 69 6e 63 6c 75 64 65 20 22 63  t.h>.#include "c
0410: 6f 6e 66 69 67 2e 68 22 0a 23 69 6e 63 6c 75 64  onfig.h".#includ
0420: 65 20 22 74 61 67 76 69 65 77 2e 68 22 0a 0a 23  e "tagview.h"..#
0430: 69 66 20 30 20 20 2f 2a 20 44 49 53 41 42 4c 45  if 0  /* DISABLE
0440: 44 20 2a 2f 0a 0a 23 69 66 20 30 0a 23 20 20 64  D */..#if 0.#  d
0450: 65 66 69 6e 65 20 54 41 47 56 49 45 57 5f 44 45  efine TAGVIEW_DE
0460: 46 41 55 4c 54 5f 46 49 4c 54 45 52 20 22 41 4e  FAULT_FILTER "AN
0470: 44 20 74 2e 74 61 67 6e 61 6d 65 20 4e 4f 54 20  D t.tagname NOT 
0480: 47 4c 4f 42 20 27 77 69 6b 69 2d 2a 27 20 22 0a  GLOB 'wiki-*' ".
0490: 23 65 6c 73 65 0a 23 20 20 64 65 66 69 6e 65 20  #else.#  define 
04a0: 54 41 47 56 49 45 57 5f 44 45 46 41 55 4c 54 5f  TAGVIEW_DEFAULT_
04b0: 46 49 4c 54 45 52 0a 23 65 6e 64 69 66 0a 0a 2f  FILTER.#endif../
04c0: 2a 0a 2a 2a 20 4c 69 73 74 73 20 61 6c 6c 20 74  *.** Lists all t
04d0: 61 67 73 20 6d 61 74 63 68 69 6e 67 20 74 68 65  ags matching the
04e0: 20 67 69 76 65 6e 20 4c 49 4b 45 20 63 6c 61 75   given LIKE clau
04f0: 73 65 20 28 77 68 69 63 68 0a 2a 2a 20 6d 61 79  se (which.** may
0500: 20 62 65 20 30 29 2e 0a 2a 2f 0a 73 74 61 74 69   be 0)..*/.stati
0510: 63 20 76 6f 69 64 20 74 61 67 76 69 65 77 5f 70  c void tagview_p
0520: 61 67 65 5f 6c 69 73 74 5f 74 61 67 73 28 63 6f  age_list_tags(co
0530: 6e 73 74 20 63 68 61 72 20 2a 7a 4c 69 6b 65 29  nst char *zLike)
0540: 7b 0a 20 20 63 68 61 72 20 2a 7a 4c 69 6b 65 43  {.  char *zLikeC
0550: 6c 61 75 73 65 20 3d 20 30 3b 0a 20 20 63 6f 6e  lause = 0;.  con
0560: 73 74 20 69 6e 74 20 6c 69 6d 69 74 20 3d 20 31  st int limit = 1
0570: 30 3b 0a 20 20 63 68 61 72 20 2a 7a 4c 69 6d 69  0;.  char *zLimi
0580: 74 20 3d 20 30 3b 0a 20 20 63 68 61 72 20 2a 7a  t = 0;.  char *z
0590: 53 71 6c 3b 0a 0a 20 20 69 66 28 20 7a 4c 69 6b  Sql;..  if( zLik
05a0: 65 20 26 26 20 7a 4c 69 6b 65 5b 30 5d 20 29 7b  e && zLike[0] ){
05b0: 0a 20 20 20 20 7a 4c 69 6b 65 43 6c 61 75 73 65  .    zLikeClause
05c0: 20 3d 20 6d 70 72 69 6e 74 66 28 20 22 41 4e 44   = mprintf( "AND
05d0: 20 74 2e 74 61 67 6e 61 6d 65 20 4c 49 4b 45 20   t.tagname LIKE 
05e0: 27 25 25 25 71 25 25 27 22 2c 20 7a 4c 69 6b 65  '%%%q%%'", zLike
05f0: 20 29 3b 0a 20 20 20 20 7a 4c 69 6d 69 74 20 3d   );.    zLimit =
0600: 20 22 22 3b 0a 20 20 20 20 40 20 3c 68 32 3e 54   "";.    @ <h2>T
0610: 61 67 73 20 6d 61 74 63 68 69 6e 67 20 5b 25 68  ags matching [%h
0620: 28 7a 4c 69 6b 65 43 6c 61 75 73 65 29 5d 3a 3c  (zLikeClause)]:<
0630: 2f 68 32 3e 0a 20 20 7d 65 6c 73 65 7b 0a 20 20  /h2>.  }else{.  
0640: 20 20 7a 4c 69 6d 69 74 20 3d 20 6d 70 72 69 6e    zLimit = mprin
0650: 74 66 28 20 22 4c 49 4d 49 54 20 25 64 22 2c 20  tf( "LIMIT %d", 
0660: 6c 69 6d 69 74 20 29 3b 0a 20 20 20 20 7a 4c 69  limit );.    zLi
0670: 6b 65 43 6c 61 75 73 65 20 3d 20 22 22 3b 0a 20  keClause = "";. 
0680: 20 20 20 40 20 3c 68 32 3e 25 64 28 6c 69 6d 69     @ <h2>%d(limi
0690: 74 29 20 6d 6f 73 74 20 72 65 63 65 6e 74 20 74  t) most recent t
06a0: 61 67 73 3a 3c 2f 68 32 3e 0a 20 20 7d 0a 20 20  ags:</h2>.  }.  
06b0: 7a 53 71 6c 20 3d 20 6d 70 72 69 6e 74 66 28 20  zSql = mprintf( 
06c0: 0a 20 20 20 20 22 53 45 4c 45 43 54 20 22 0a 20  .    "SELECT ". 
06d0: 20 20 20 22 20 20 20 6c 69 6e 6b 74 61 67 69 64     "   linktagid
06e0: 28 74 2e 74 61 67 69 64 29 20 41 53 20 27 54 61  (t.tagid) AS 'Ta
06f0: 67 20 49 44 27 2c 22 0a 20 20 20 20 22 20 20 20  g ID',".    "   
0700: 6c 69 6e 6b 74 61 67 6e 61 6d 65 28 74 2e 74 61  linktagname(t.ta
0710: 67 6e 61 6d 65 29 20 41 53 20 27 4e 61 6d 65 27  gname) AS 'Name'
0720: 2c 22 0a 20 20 20 20 22 20 20 20 44 41 54 45 54  ,".    "   DATET
0730: 49 4d 45 28 74 78 2e 6d 74 69 6d 65 29 20 41 53  IME(tx.mtime) AS
0740: 20 27 54 69 6d 65 73 74 61 6d 70 27 2c 22 0a 20   'Timestamp',". 
0750: 20 20 20 22 20 20 20 6c 69 6e 6b 75 75 69 64 28     "   linkuuid(
0760: 62 2e 75 75 69 64 29 20 41 53 20 27 56 65 72 73  b.uuid) AS 'Vers
0770: 69 6f 6e 27 22 0a 20 20 20 20 22 20 20 46 52 4f  ion'".    "  FRO
0780: 4d 20 74 61 67 20 74 2c 20 74 61 67 78 72 65 66  M tag t, tagxref
0790: 20 74 78 2c 20 62 6c 6f 62 20 62 20 22 0a 20 20   tx, blob b ".  
07a0: 20 20 22 20 57 48 45 52 45 20 74 2e 74 61 67 69    " WHERE t.tagi
07b0: 64 3d 74 78 2e 74 61 67 69 64 20 41 4e 44 20 74  d=tx.tagid AND t
07c0: 78 2e 72 69 64 3d 62 2e 72 69 64 22 0a 20 20 20  x.rid=b.rid".   
07d0: 20 22 20 25 73 20 22 0a 20 20 20 20 54 41 47 56   " %s ".    TAGV
07e0: 49 45 57 5f 44 45 46 41 55 4c 54 5f 46 49 4c 54  IEW_DEFAULT_FILT
07f0: 45 52 0a 20 20 20 20 22 20 4f 52 44 45 52 20 42  ER.    " ORDER B
0800: 59 20 74 78 2e 6d 74 69 6d 65 20 44 45 53 43 20  Y tx.mtime DESC 
0810: 25 73 22 2c 0a 20 20 20 20 7a 4c 69 6b 65 43 6c  %s",.    zLikeCl
0820: 61 75 73 65 2c 20 7a 4c 69 6d 69 74 0a 20 20 29  ause, zLimit.  )
0830: 3b 0a 20 20 64 62 5f 67 65 6e 65 72 69 63 5f 71  ;.  db_generic_q
0840: 75 65 72 79 5f 76 69 65 77 28 7a 53 71 6c 2c 20  uery_view(zSql, 
0850: 31 29 3b 0a 20 20 66 72 65 65 28 7a 53 71 6c 29  1);.  free(zSql)
0860: 3b 0a 20 20 69 66 28 20 7a 4c 69 6b 65 43 6c 61  ;.  if( zLikeCla
0870: 75 73 65 5b 30 5d 20 29 20 66 72 65 65 28 7a 4c  use[0] ) free(zL
0880: 69 6b 65 43 6c 61 75 73 65 29 3b 0a 20 20 69 66  ikeClause);.  if
0890: 28 20 7a 4c 69 6d 69 74 5b 30 5d 20 29 20 66 72  ( zLimit[0] ) fr
08a0: 65 65 28 7a 4c 69 6d 69 74 29 3b 0a 7d 0a 0a 2f  ee(zLimit);.}../
08b0: 2a 0a 2a 2a 20 41 20 73 6d 61 6c 6c 20 73 65 61  *.** A small sea
08c0: 72 63 68 20 66 6f 72 6d 20 77 68 69 63 68 20 66  rch form which f
08d0: 6f 72 77 61 72 64 73 20 74 6f 20 3f 6c 69 6b 65  orwards to ?like
08e0: 3d 53 45 41 52 43 48 5f 53 54 52 49 4e 47 0a 2a  =SEARCH_STRING.*
08f0: 2f 0a 73 74 61 74 69 63 20 76 6f 69 64 20 74 61  /.static void ta
0900: 67 76 69 65 77 5f 70 61 67 65 5f 73 65 61 72 63  gview_page_searc
0910: 68 5f 6d 69 6e 69 66 6f 72 6d 28 76 6f 69 64 29  h_miniform(void)
0920: 7b 0a 20 20 63 68 61 72 20 63 6f 6e 73 74 20 2a  {.  char const *
0930: 20 6c 69 6b 65 20 3d 20 50 28 22 6c 69 6b 65 22   like = P("like"
0940: 29 3b 0a 20 20 40 20 3c 64 69 76 20 63 6c 61 73  );.  @ <div clas
0950: 73 3d 27 6d 69 6e 69 66 6f 72 6d 27 3e 0a 20 20  s='miniform'>.  
0960: 40 20 3c 66 6f 72 6d 20 61 63 74 69 6f 6e 3d 27  @ <form action='
0970: 74 61 67 76 69 65 77 27 20 6d 65 74 68 6f 64 3d  tagview' method=
0980: 27 70 6f 73 74 27 3e 0a 20 20 40 20 53 65 61 72  'post'>.  @ Sear
0990: 63 68 20 66 6f 72 20 74 61 67 73 3a 20 0a 20 20  ch for tags: .  
09a0: 40 20 3c 69 6e 70 75 74 20 74 79 70 65 3d 27 74  @ <input type='t
09b0: 65 78 74 27 20 6e 61 6d 65 3d 27 6c 69 6b 65 27  ext' name='like'
09c0: 20 76 61 6c 75 65 3d 27 25 68 28 28 6c 69 6b 65   value='%h((like
09d0: 3f 6c 69 6b 65 3a 22 22 29 29 27 20 73 69 7a 65  ?like:""))' size
09e0: 3d 27 31 30 27 2f 3e 0a 20 20 40 20 3c 69 6e 70  ='10'/>.  @ <inp
09f0: 75 74 20 74 79 70 65 3d 27 73 75 62 6d 69 74 27  ut type='submit'
0a00: 2f 3e 0a 20 20 40 20 3c 69 6e 70 75 74 20 74 79  />.  @ <input ty
0a10: 70 65 3d 27 68 69 64 64 65 6e 27 20 6e 61 6d 65  pe='hidden' name
0a20: 3d 27 72 61 77 27 20 76 61 6c 75 65 3d 27 79 27  ='raw' value='y'
0a30: 2f 3e 0a 20 20 40 20 3c 2f 66 6f 72 6d 3e 0a 20  />.  @ </form>. 
0a40: 20 40 20 3c 2f 64 69 76 3e 0a 7d 0a 0a 2f 2a 0a   @ </div>.}../*.
0a50: 2a 2a 20 74 61 67 76 69 65 77 5f 70 61 67 65 5f  ** tagview_page_
0a60: 64 65 66 61 75 6c 74 28 29 20 72 65 6e 64 65 72  default() render
0a70: 73 20 74 68 65 20 64 65 66 61 75 6c 74 20 70 61  s the default pa
0a80: 67 65 20 66 6f 72 20 74 61 67 76 69 65 77 5f 70  ge for tagview_p
0a90: 61 67 65 28 29 2e 0a 2a 2f 0a 73 74 61 74 69 63  age()..*/.static
0aa0: 20 76 6f 69 64 20 74 61 67 76 69 65 77 5f 70 61   void tagview_pa
0ab0: 67 65 5f 64 65 66 61 75 6c 74 28 76 6f 69 64 29  ge_default(void)
0ac0: 7b 0a 20 20 74 61 67 76 69 65 77 5f 70 61 67 65  {.  tagview_page
0ad0: 5f 6c 69 73 74 5f 74 61 67 73 28 20 30 20 29 3b  _list_tags( 0 );
0ae0: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 4c 69 73 74 73 20  .}../*.** Lists 
0af0: 61 6c 6c 20 74 61 67 73 20 6d 61 74 63 68 69 6e  all tags matchin
0b00: 67 20 74 68 65 20 67 69 76 65 6e 20 74 61 67 69  g the given tagi
0b10: 64 2e 0a 2a 2f 0a 73 74 61 74 69 63 20 76 6f 69  d..*/.static voi
0b20: 64 20 74 61 67 76 69 65 77 5f 70 61 67 65 5f 74  d tagview_page_t
0b30: 61 67 5f 62 79 5f 69 64 28 20 69 6e 74 20 74 61  ag_by_id( int ta
0b40: 67 69 64 20 29 7b 0a 20 20 63 68 61 72 20 2a 7a  gid ){.  char *z
0b50: 53 71 6c 3b 0a 20 20 40 20 3c 68 32 3e 54 61 67  Sql;.  @ <h2>Tag
0b60: 20 23 25 64 28 74 61 67 69 64 29 3a 3c 2f 68 32   #%d(tagid):</h2
0b70: 3e 0a 20 20 7a 53 71 6c 20 3d 20 6d 70 72 69 6e  >.  zSql = mprin
0b80: 74 66 28 20 0a 20 20 20 20 22 53 45 4c 45 43 54  tf( .    "SELECT
0b90: 20 44 49 53 54 49 4e 43 54 22 0a 20 20 20 20 22   DISTINCT".    "
0ba0: 20 20 20 20 20 20 20 6c 69 6e 6b 74 61 67 6e 61         linktagna
0bb0: 6d 65 28 74 2e 74 61 67 6e 61 6d 65 29 20 41 53  me(t.tagname) AS
0bc0: 20 27 54 61 67 20 4e 61 6d 65 27 2c 22 0a 20 20   'Tag Name',".  
0bd0: 20 20 22 20 20 20 20 20 20 20 44 41 54 45 54 49    "       DATETI
0be0: 4d 45 28 74 78 2e 6d 74 69 6d 65 29 20 41 53 20  ME(tx.mtime) AS 
0bf0: 27 54 69 6d 65 73 74 61 6d 70 27 2c 22 0a 20 20  'Timestamp',".  
0c00: 20 20 22 20 20 20 20 20 20 20 6c 69 6e 6b 75 75    "       linkuu
0c10: 69 64 28 62 2e 75 75 69 64 29 20 41 53 20 27 56  id(b.uuid) AS 'V
0c20: 65 72 73 69 6f 6e 27 22 0a 20 20 20 20 22 20 20  ersion'".    "  
0c30: 46 52 4f 4d 20 74 61 67 20 74 2c 20 74 61 67 78  FROM tag t, tagx
0c40: 72 65 66 20 74 78 2c 20 62 6c 6f 62 20 62 22 0a  ref tx, blob b".
0c50: 20 20 20 20 22 20 57 48 45 52 45 20 74 2e 74 61      " WHERE t.ta
0c60: 67 69 64 3d 25 64 20 41 4e 44 20 74 2e 74 61 67  gid=%d AND t.tag
0c70: 69 64 3d 74 78 2e 74 61 67 69 64 20 41 4e 44 20  id=tx.tagid AND 
0c80: 74 78 2e 72 69 64 3d 62 2e 72 69 64 20 22 0a 20  tx.rid=b.rid ". 
0c90: 20 20 20 54 41 47 56 49 45 57 5f 44 45 46 41 55     TAGVIEW_DEFAU
0ca0: 4c 54 5f 46 49 4c 54 45 52 0a 20 20 20 20 22 20  LT_FILTER.    " 
0cb0: 4f 52 44 45 52 20 42 59 20 74 78 2e 6d 74 69 6d  ORDER BY tx.mtim
0cc0: 65 20 44 45 53 43 22 2c 0a 20 20 20 20 74 61 67  e DESC",.    tag
0cd0: 69 64 0a 20 20 29 3b 0a 20 20 64 62 5f 67 65 6e  id.  );.  db_gen
0ce0: 65 72 69 63 5f 71 75 65 72 79 5f 76 69 65 77 28  eric_query_view(
0cf0: 7a 53 71 6c 2c 20 31 29 3b 0a 20 20 66 72 65 65  zSql, 1);.  free
0d00: 28 7a 53 71 6c 29 3b 0a 7d 0a 0a 2f 2a 0a 2a 2a  (zSql);.}../*.**
0d10: 20 4c 69 73 74 73 20 61 6c 6c 20 74 61 67 73 20   Lists all tags 
0d20: 6d 61 74 63 68 69 6e 67 20 74 68 65 20 67 69 76  matching the giv
0d30: 65 6e 20 74 61 67 20 6e 61 6d 65 2e 0a 2a 2f 0a  en tag name..*/.
0d40: 73 74 61 74 69 63 20 76 6f 69 64 20 74 61 67 76  static void tagv
0d50: 69 65 77 5f 70 61 67 65 5f 74 61 67 5f 62 79 5f  iew_page_tag_by_
0d60: 6e 61 6d 65 28 20 63 68 61 72 20 63 6f 6e 73 74  name( char const
0d70: 20 2a 20 74 61 67 6e 61 6d 65 20 29 7b 0a 20 20   * tagname ){.  
0d80: 63 68 61 72 20 2a 7a 53 71 6c 3b 0a 20 20 40 20  char *zSql;.  @ 
0d90: 3c 68 32 3e 54 61 67 20 27 25 73 28 74 61 67 6e  <h2>Tag '%s(tagn
0da0: 61 6d 65 29 27 3a 3c 2f 68 32 3e 0a 20 20 7a 53  ame)':</h2>.  zS
0db0: 71 6c 20 3d 20 6d 70 72 69 6e 74 66 28 20 0a 20  ql = mprintf( . 
0dc0: 20 20 20 22 53 45 4c 45 43 54 20 44 49 53 54 49     "SELECT DISTI
0dd0: 4e 43 54 22 0a 20 20 20 20 22 20 20 20 20 20 20  NCT".    "      
0de0: 20 6c 69 6e 6b 74 61 67 69 64 28 74 2e 74 61 67   linktagid(t.tag
0df0: 69 64 29 20 41 53 20 27 54 61 67 20 49 44 27 2c  id) AS 'Tag ID',
0e00: 22 0a 20 20 20 20 22 20 20 20 20 20 20 20 6c 69  ".    "       li
0e10: 6e 6b 74 61 67 6e 61 6d 65 28 74 2e 74 61 67 6e  nktagname(t.tagn
0e20: 61 6d 65 29 20 41 53 20 27 4e 61 6d 65 27 2c 22  ame) AS 'Name',"
0e30: 0a 20 20 20 20 22 20 20 20 20 20 20 20 44 41 54  .    "       DAT
0e40: 45 54 49 4d 45 28 74 78 2e 6d 74 69 6d 65 29 20  ETIME(tx.mtime) 
0e50: 41 53 20 27 54 69 6d 65 73 74 61 6d 70 27 2c 22  AS 'Timestamp',"
0e60: 0a 20 20 20 20 22 20 20 20 20 20 20 20 6c 69 6e  .    "       lin
0e70: 6b 75 75 69 64 28 62 2e 75 75 69 64 29 20 41 53  kuuid(b.uuid) AS
0e80: 20 27 56 65 72 73 69 6f 6e 27 22 0a 20 20 20 20   'Version'".    
0e90: 22 20 20 46 52 4f 4d 20 74 61 67 20 74 2c 20 74  "  FROM tag t, t
0ea0: 61 67 78 72 65 66 20 74 78 2c 20 62 6c 6f 62 20  agxref tx, blob 
0eb0: 62 20 22 0a 20 20 20 20 22 20 57 48 45 52 45 20  b ".    " WHERE 
0ec0: 28 20 74 2e 74 61 67 6e 61 6d 65 3d 27 25 71 27  ( t.tagname='%q'
0ed0: 20 4f 52 20 20 74 2e 74 61 67 6e 61 6d 65 3d 27   OR  t.tagname='
0ee0: 73 79 6d 2d 25 71 27 29 20 22 0a 20 20 20 20 22  sym-%q') ".    "
0ef0: 20 20 20 41 4e 44 20 74 2e 74 61 67 69 64 3d 74     AND t.tagid=t
0f00: 78 2e 74 61 67 69 64 20 41 4e 44 20 74 78 2e 72  x.tagid AND tx.r
0f10: 69 64 3d 62 2e 72 69 64 20 22 0a 20 20 20 20 54  id=b.rid ".    T
0f20: 41 47 56 49 45 57 5f 44 45 46 41 55 4c 54 5f 46  AGVIEW_DEFAULT_F
0f30: 49 4c 54 45 52 0a 20 20 20 20 22 20 4f 52 44 45  ILTER.    " ORDE
0f40: 52 20 42 59 20 74 78 2e 6d 74 69 6d 65 20 44 45  R BY tx.mtime DE
0f50: 53 43 22 2c 0a 20 20 20 20 74 61 67 6e 61 6d 65  SC",.    tagname
0f60: 2c 74 61 67 6e 61 6d 65 29 3b 0a 20 20 64 62 5f  ,tagname);.  db_
0f70: 67 65 6e 65 72 69 63 5f 71 75 65 72 79 5f 76 69  generic_query_vi
0f80: 65 77 28 7a 53 71 6c 2c 20 31 29 3b 0a 20 20 66  ew(zSql, 1);.  f
0f90: 72 65 65 28 7a 53 71 6c 29 3b 0a 7d 0a 0a 2f 2a  ree(zSql);.}../*
0fa0: 0a 2a 2a 20 49 6e 74 65 72 6e 61 6c 20 76 69 65  .** Internal vie
0fb0: 77 20 6f 66 20 74 61 67 73 0a 2a 2f 0a 76 6f 69  w of tags.*/.voi
0fc0: 64 20 72 61 77 5f 74 61 67 76 69 65 77 5f 70 61  d raw_tagview_pa
0fd0: 67 65 28 76 6f 69 64 29 7b 0a 20 20 63 68 61 72  ge(void){.  char
0fe0: 20 63 6f 6e 73 74 20 2a 20 63 68 65 63 6b 20 3d   const * check =
0ff0: 20 30 3b 0a 20 20 6c 6f 67 69 6e 5f 63 68 65 63   0;.  login_chec
1000: 6b 5f 63 72 65 64 65 6e 74 69 61 6c 73 28 29 3b  k_credentials();
1010: 0a 20 20 2f 2a 20 69 66 28 20 21 67 2e 6f 6b 52  .  /* if( !g.okR
1020: 64 57 69 6b 69 20 29 7b 20 2a 2f 0a 20 20 69 66  dWiki ){ */.  if
1030: 28 20 21 67 2e 6f 6b 41 64 6d 69 6e 20 29 7b 0a  ( !g.okAdmin ){.
1040: 20 20 20 20 6c 6f 67 69 6e 5f 6e 65 65 64 65 64      login_needed
1050: 28 29 3b 0a 20 20 7d 0a 20 20 73 74 79 6c 65 5f  ();.  }.  style_
1060: 68 65 61 64 65 72 28 22 52 61 77 20 54 61 67 73  header("Raw Tags
1070: 22 29 3b 0a 20 20 6c 6f 67 69 6e 5f 61 6e 6f 6e  ");.  login_anon
1080: 79 6d 6f 75 73 5f 61 76 61 69 6c 61 62 6c 65 28  ymous_available(
1090: 29 3b 0a 20 20 74 61 67 76 69 65 77 5f 70 61 67  );.  tagview_pag
10a0: 65 5f 73 65 61 72 63 68 5f 6d 69 6e 69 66 6f 72  e_search_minifor
10b0: 6d 28 29 3b 0a 20 20 40 20 3c 68 72 2f 3e 0a 20  m();.  @ <hr/>. 
10c0: 20 69 66 28 20 30 20 21 3d 20 28 63 68 65 63 6b   if( 0 != (check
10d0: 20 3d 20 50 28 22 74 61 67 69 64 22 29 29 20 29   = P("tagid")) )
10e0: 7b 0a 20 20 20 20 74 61 67 76 69 65 77 5f 70 61  {.    tagview_pa
10f0: 67 65 5f 74 61 67 5f 62 79 5f 69 64 28 20 61 74  ge_tag_by_id( at
1100: 6f 69 28 63 68 65 63 6b 29 20 29 3b 0a 20 20 7d  oi(check) );.  }
1110: 65 6c 73 65 20 69 66 28 20 30 20 21 3d 20 28 63  else if( 0 != (c
1120: 68 65 63 6b 20 3d 20 50 28 22 6c 69 6b 65 22 29  heck = P("like")
1130: 29 20 29 7b 0a 20 20 20 20 74 61 67 76 69 65 77  ) ){.    tagview
1140: 5f 70 61 67 65 5f 6c 69 73 74 5f 74 61 67 73 28  _page_list_tags(
1150: 20 63 68 65 63 6b 20 29 3b 0a 20 20 7d 65 6c 73   check );.  }els
1160: 65 20 69 66 28 20 30 20 21 3d 20 28 63 68 65 63  e if( 0 != (chec
1170: 6b 20 3d 20 50 28 22 6e 61 6d 65 22 29 29 20 29  k = P("name")) )
1180: 7b 0a 20 20 20 20 74 61 67 76 69 65 77 5f 70 61  {.    tagview_pa
1190: 67 65 5f 74 61 67 5f 62 79 5f 6e 61 6d 65 28 20  ge_tag_by_name( 
11a0: 63 68 65 63 6b 20 29 3b 0a 20 20 7d 65 6c 73 65  check );.  }else
11b0: 7b 0a 20 20 20 20 74 61 67 76 69 65 77 5f 70 61  {.    tagview_pa
11c0: 67 65 5f 64 65 66 61 75 6c 74 28 29 3b 0a 20 20  ge_default();.  
11d0: 7d 0a 20 20 73 74 79 6c 65 5f 66 6f 6f 74 65 72  }.  style_footer
11e0: 28 29 3b 0a 7d 0a 0a 23 75 6e 64 65 66 20 54 41  ();.}..#undef TA
11f0: 47 56 49 45 57 5f 44 45 46 41 55 4c 54 5f 46 49  GVIEW_DEFAULT_FI
1200: 4c 54 45 52 0a 0a 2f 2a 0a 2a 2a 20 47 65 6e 65  LTER../*.** Gene
1210: 72 61 74 65 20 61 20 74 69 6d 65 6c 69 6e 65 20  rate a timeline 
1220: 66 6f 72 20 74 68 65 20 63 68 6f 73 65 6e 20 74  for the chosen t
1230: 61 67 0a 2a 2f 0a 76 6f 69 64 20 74 61 67 76 69  ag.*/.void tagvi
1240: 65 77 5f 70 72 69 6e 74 5f 74 69 6d 65 6c 69 6e  ew_print_timelin
1250: 65 28 63 68 61 72 20 63 6f 6e 73 74 20 2a 7a 4e  e(char const *zN
1260: 61 6d 65 2c 20 63 68 61 72 20 63 6f 6e 73 74 20  ame, char const 
1270: 2a 7a 50 72 65 66 69 78 29 7b 0a 20 20 63 68 61  *zPrefix){.  cha
1280: 72 20 2a 7a 53 71 6c 3b 0a 20 20 53 74 6d 74 20  r *zSql;.  Stmt 
1290: 71 3b 0a 20 20 69 6e 74 20 74 61 67 69 64 20 3d  q;.  int tagid =
12a0: 20 64 62 5f 69 6e 74 28 30 2c 20 22 53 45 4c 45   db_int(0, "SELE
12b0: 43 54 20 74 61 67 69 64 20 46 52 4f 4d 20 74 61  CT tagid FROM ta
12c0: 67 20 57 48 45 52 45 20 74 61 67 6e 61 6d 65 3d  g WHERE tagname=
12d0: 27 25 71 25 71 27 22 2c 0a 20 20 20 20 20 20 20  '%q%q'",.       
12e0: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20                  
12f0: 20 7a 50 72 65 66 69 78 2c 20 7a 4e 61 6d 65 29   zPrefix, zName)
1300: 3b 0a 20 20 7a 53 71 6c 20 3d 20 6d 70 72 69 6e  ;.  zSql = mprin
1310: 74 66 28 22 25 73 20 41 4e 44 20 45 58 49 53 54  tf("%s AND EXIST
1320: 53 20 28 53 45 4c 45 43 54 20 31 22 0a 20 20 20  S (SELECT 1".   
1330: 20 20 20 20 20 20 22 20 46 52 4f 4d 20 74 61 67        " FROM tag
1340: 78 72 65 66 22 0a 20 20 20 20 20 20 20 20 20 22  xref".         "
1350: 20 20 57 48 45 52 45 20 74 61 67 78 72 65 66 2e    WHERE tagxref.
1360: 72 69 64 20 3d 20 65 76 65 6e 74 2e 6f 62 6a 69  rid = event.obji
1370: 64 22 0a 20 20 20 20 20 20 20 20 20 22 20 20 41  d".         "  A
1380: 4e 44 20 74 61 67 78 72 65 66 2e 74 61 67 74 79  ND tagxref.tagty
1390: 70 65 20 3e 20 30 22 0a 20 20 20 20 20 20 20 20  pe > 0".        
13a0: 20 22 20 20 41 4e 44 20 74 61 67 78 72 65 66 2e   "  AND tagxref.
13b0: 74 61 67 69 64 20 3d 20 25 64 29 22 0a 20 20 20  tagid = %d)".   
13c0: 20 20 20 20 20 20 22 20 4f 52 44 45 52 20 42 59        " ORDER BY
13d0: 20 33 20 64 65 73 63 22 2c 0a 20 20 20 20 20 20   3 desc",.      
13e0: 20 20 20 74 69 6d 65 6c 69 6e 65 5f 71 75 65 72     timeline_quer
13f0: 79 5f 66 6f 72 5f 77 77 77 28 29 2c 20 74 61 67  y_for_www(), tag
1400: 69 64 0a 20 20 29 3b 0a 20 20 64 62 5f 70 72 65  id.  );.  db_pre
1410: 70 61 72 65 28 26 71 2c 20 7a 53 71 6c 29 3b 0a  pare(&q, zSql);.
1420: 20 20 66 72 65 65 28 7a 53 71 6c 29 3b 0a 20 20    free(zSql);.  
1430: 77 77 77 5f 70 72 69 6e 74 5f 74 69 6d 65 6c 69  www_print_timeli
1440: 6e 65 28 26 71 2c 20 30 2c 20 30 29 3b 0a 20 20  ne(&q, 0, 0);.  
1450: 64 62 5f 66 69 6e 61 6c 69 7a 65 28 26 71 29 3b  db_finalize(&q);
1460: 0a 7d 0a 0a 2f 2a 0a 2a 2a 20 57 45 42 20 50 41  .}../*.** WEB PA
1470: 47 45 3a 20 2f 74 61 67 76 69 65 77 0a 2a 2f 0a  GE: /tagview.*/.
1480: 76 6f 69 64 20 74 61 67 76 69 65 77 5f 70 61 67  void tagview_pag
1490: 65 28 76 6f 69 64 29 7b 0a 20 20 63 68 61 72 20  e(void){.  char 
14a0: 63 6f 6e 73 74 20 2a 7a 4e 61 6d 65 20 3d 20 30  const *zName = 0
14b0: 3b 0a 20 20 63 68 61 72 20 63 6f 6e 73 74 20 2a  ;.  char const *
14c0: 7a 54 69 74 6c 65 20 3d 20 30 3b 0a 20 20 69 6e  zTitle = 0;.  in
14d0: 74 20 6e 54 61 67 20 3d 20 30 3b 0a 20 20 6c 6f  t nTag = 0;.  lo
14e0: 67 69 6e 5f 63 68 65 63 6b 5f 63 72 65 64 65 6e  gin_check_creden
14f0: 74 69 61 6c 73 28 29 3b 0a 20 20 69 66 28 20 21  tials();.  if( !
1500: 67 2e 6f 6b 52 65 61 64 20 29 7b 0a 20 20 20 20  g.okRead ){.    
1510: 6c 6f 67 69 6e 5f 6e 65 65 64 65 64 28 29 3b 0a  login_needed();.
1520: 20 20 7d 0a 20 20 69 66 20 28 20 50 28 22 74 61    }.  if ( P("ta
1530: 67 69 64 22 29 20 7c 7c 20 50 28 22 6c 69 6b 65  gid") || P("like
1540: 22 29 20 7c 7c 20 50 28 22 72 61 77 22 29 20 29  ") || P("raw") )
1550: 20 7b 0a 20 20 20 20 72 61 77 5f 74 61 67 76 69   {.    raw_tagvi
1560: 65 77 5f 70 61 67 65 28 29 3b 0a 20 20 20 20 72  ew_page();.    r
1570: 65 74 75 72 6e 3b 0a 20 20 7d 0a 20 20 6c 6f 67  eturn;.  }.  log
1580: 69 6e 5f 61 6e 6f 6e 79 6d 6f 75 73 5f 61 76 61  in_anonymous_ava
1590: 69 6c 61 62 6c 65 28 29 3b 0a 20 20 69 66 28 20  ilable();.  if( 
15a0: 30 20 21 3d 20 28 7a 4e 61 6d 65 20 3d 20 50 28  0 != (zName = P(
15b0: 22 6e 61 6d 65 22 29 29 20 29 7b 0a 20 20 20 20  "name")) ){.    
15c0: 42 6c 6f 62 20 75 75 69 64 3b 0a 20 20 20 20 69  Blob uuid;.    i
15d0: 66 28 20 67 2e 6f 6b 41 64 6d 69 6e 20 29 7b 0a  f( g.okAdmin ){.
15e0: 20 20 20 20 20 20 73 74 79 6c 65 5f 73 75 62 6d        style_subm
15f0: 65 6e 75 5f 65 6c 65 6d 65 6e 74 28 22 52 61 77  enu_element("Raw
1600: 54 61 67 73 22 2c 20 22 49 6e 74 65 72 6e 61 6c  Tags", "Internal
1610: 20 54 69 63 6b 65 74 20 56 69 65 77 22 2c 0a 20   Ticket View",. 
1620: 20 20 20 20 20 20 20 22 25 73 2f 74 61 67 76 69         "%s/tagvi
1630: 65 77 3f 6e 61 6d 65 3d 25 73 26 72 61 77 3d 79  ew?name=%s&raw=y
1640: 22 2c 20 67 2e 7a 54 6f 70 2c 20 7a 4e 61 6d 65  ", g.zTop, zName
1650: 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20 7a 54 69  );.    }.    zTi
1660: 74 6c 65 20 3d 20 22 54 61 67 67 65 64 20 41 72  tle = "Tagged Ar
1670: 74 69 66 61 63 74 73 22 3b 0a 20 20 20 20 40 20  tifacts";.    @ 
1680: 3c 68 32 3e 25 73 28 7a 4e 61 6d 65 29 3a 3c 2f  <h2>%s(zName):</
1690: 68 32 3e 0a 20 20 20 20 69 66 28 20 73 79 6d 5f  h2>.    if( sym_
16a0: 74 61 67 5f 74 6f 5f 75 75 69 64 28 7a 4e 61 6d  tag_to_uuid(zNam
16b0: 65 2c 20 26 75 75 69 64 29 20 3e 20 30 29 7b 0a  e, &uuid) > 0){.
16c0: 20 20 20 20 20 20 74 61 67 76 69 65 77 5f 70 72        tagview_pr
16d0: 69 6e 74 5f 74 69 6d 65 6c 69 6e 65 28 7a 4e 61  int_timeline(zNa
16e0: 6d 65 2c 20 22 73 79 6d 2d 22 29 3b 0a 20 20 20  me, "sym-");.   
16f0: 20 7d 65 6c 73 65 20 69 66 28 20 74 61 67 5f 74   }else if( tag_t
1700: 6f 5f 75 75 69 64 28 7a 4e 61 6d 65 2c 20 26 75  o_uuid(zName, &u
1710: 75 69 64 2c 20 22 22 29 20 3e 20 30 29 7b 0a 20  uid, "") > 0){. 
1720: 20 20 20 20 20 74 61 67 76 69 65 77 5f 70 72 69       tagview_pri
1730: 6e 74 5f 74 69 6d 65 6c 69 6e 65 28 7a 4e 61 6d  nt_timeline(zNam
1740: 65 2c 20 22 22 29 3b 0a 20 20 20 20 7d 65 6c 73  e, "");.    }els
1750: 65 7b 0a 20 20 20 20 20 20 40 20 54 68 65 72 65  e{.      @ There
1760: 20 69 73 20 6e 6f 20 61 72 74 69 66 61 63 74 20   is no artifact 
1770: 77 69 74 68 20 74 68 69 73 20 74 61 67 2e 0a 20  with this tag.. 
1780: 20 20 20 7d 0a 20 20 7d 65 6c 73 65 7b 0a 20 20     }.  }else{.  
1790: 20 20 53 74 6d 74 20 71 3b 0a 20 20 20 20 63 6f    Stmt q;.    co
17a0: 6e 73 74 20 63 68 61 72 20 2a 70 72 65 66 69 78  nst char *prefix
17b0: 20 3d 20 22 73 79 6d 2d 22 3b 0a 20 20 20 20 69   = "sym-";.    i
17c0: 6e 74 20 70 72 65 66 6c 65 6e 20 3d 20 73 74 72  nt preflen = str
17d0: 6c 65 6e 28 70 72 65 66 69 78 29 3b 0a 20 20 20  len(prefix);.   
17e0: 20 69 66 28 20 67 2e 6f 6b 41 64 6d 69 6e 20 29   if( g.okAdmin )
17f0: 7b 0a 20 20 20 20 20 20 73 74 79 6c 65 5f 73 75  {.      style_su
1800: 62 6d 65 6e 75 5f 65 6c 65 6d 65 6e 74 28 22 52  bmenu_element("R
1810: 61 77 54 61 67 73 22 2c 20 22 49 6e 74 65 72 6e  awTags", "Intern
1820: 61 6c 20 54 69 63 6b 65 74 20 56 69 65 77 22 2c  al Ticket View",
1830: 0a 20 20 20 20 20 20 20 20 22 25 73 2f 74 61 67  .        "%s/tag
1840: 76 69 65 77 3f 72 61 77 3d 79 22 2c 20 67 2e 7a  view?raw=y", g.z
1850: 54 6f 70 29 3b 0a 20 20 20 20 7d 0a 20 20 20 20  Top);.    }.    
1860: 7a 54 69 74 6c 65 20 3d 20 22 54 61 67 73 22 3b  zTitle = "Tags";
1870: 0a 20 20 20 20 64 62 5f 70 72 65 70 61 72 65 28  .    db_prepare(
1880: 26 71 2c 0a 20 20 20 20 20 20 22 53 45 4c 45 43  &q,.      "SELEC
1890: 54 20 74 61 67 6e 61 6d 65 22 0a 20 20 20 20 20  T tagname".     
18a0: 20 22 20 20 46 52 4f 4d 20 74 61 67 22 0a 20 20   "  FROM tag".  
18b0: 20 20 20 20 22 20 57 48 45 52 45 20 45 58 49 53      " WHERE EXIS
18c0: 54 53 28 53 45 4c 45 43 54 20 31 20 46 52 4f 4d  TS(SELECT 1 FROM
18d0: 20 74 61 67 78 72 65 66 22 0a 20 20 20 20 20 20   tagxref".      
18e0: 22 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20  "               
18f0: 57 48 45 52 45 20 74 61 67 69 64 3d 74 61 67 2e  WHERE tagid=tag.
1900: 74 61 67 69 64 22 0a 20 20 20 20 20 20 22 20 20  tagid".      "  
1910: 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 41                 A
1920: 4e 44 20 74 61 67 74 79 70 65 3e 30 29 22 0a 20  ND tagtype>0)". 
1930: 20 20 20 20 20 22 20 41 4e 44 20 74 61 67 69 64       " AND tagid
1940: 20 3e 20 25 64 22 0a 20 20 20 20 20 20 22 20 41   > %d".      " A
1950: 4e 44 20 74 61 67 6e 61 6d 65 20 4e 4f 54 20 47  ND tagname NOT G
1960: 4c 4f 42 20 27 77 69 6b 69 2d 2a 27 22 0a 20 20  LOB 'wiki-*'".  
1970: 20 20 20 20 22 20 41 4e 44 20 74 61 67 6e 61 6d      " AND tagnam
1980: 65 20 4e 4f 54 20 47 4c 4f 42 20 27 74 6b 74 2d  e NOT GLOB 'tkt-
1990: 2a 27 22 0a 20 20 20 20 20 20 22 20 4f 52 44 45  *'".      " ORDE
19a0: 52 20 42 59 20 74 61 67 6e 61 6d 65 22 2c 0a 20  R BY tagname",. 
19b0: 20 20 20 20 20 4d 41 58 5f 49 4e 54 5f 54 41 47       MAX_INT_TAG
19c0: 0a 20 20 20 20 29 3b 0a 20 20 20 20 40 20 3c 75  .    );.    @ <u
19d0: 6c 3e 0a 20 20 20 20 77 68 69 6c 65 28 20 64 62  l>.    while( db
19e0: 5f 73 74 65 70 28 26 71 29 3d 3d 53 51 4c 49 54  _step(&q)==SQLIT
19f0: 45 5f 52 4f 57 20 29 7b 0a 20 20 20 20 20 20 63  E_ROW ){.      c
1a00: 6f 6e 73 74 20 63 68 61 72 20 2a 6e 61 6d 65 20  onst char *name 
1a10: 3d 20 64 62 5f 63 6f 6c 75 6d 6e 5f 74 65 78 74  = db_column_text
1a20: 28 26 71 2c 20 30 29 3b 0a 20 20 20 20 20 20 6e  (&q, 0);.      n
1a30: 54 61 67 2b 2b 3b 0a 20 20 20 20 20 20 69 66 28  Tag++;.      if(
1a40: 20 67 2e 6f 6b 48 69 73 74 6f 72 79 20 29 7b 0a   g.okHistory ){.
1a50: 20 20 20 20 20 20 20 20 69 66 28 20 73 74 72 6e          if( strn
1a60: 63 6d 70 28 6e 61 6d 65 2c 20 70 72 65 66 69 78  cmp(name, prefix
1a70: 2c 20 70 72 65 66 6c 65 6e 29 3d 3d 30 20 29 7b  , preflen)==0 ){
1a80: 0a 20 20 20 20 20 20 20 20 20 20 40 20 3c 6c 69  .          @ <li
1a90: 3e 3c 61 20 68 72 65 66 3d 25 73 28 67 2e 7a 42  ><a href=%s(g.zB
1aa0: 61 73 65 55 52 4c 29 2f 74 61 67 76 69 65 77 3f  aseURL)/tagview?
1ab0: 6e 61 6d 65 3d 25 73 28 6e 61 6d 65 2b 70 72 65  name=%s(name+pre
1ac0: 66 6c 65 6e 29 3e 0a 20 20 20 20 20 20 20 20 20  flen)>.         
1ad0: 20 40 20 25 73 28 6e 61 6d 65 2b 70 72 65 66 6c   @ %s(name+prefl
1ae0: 65 6e 29 3c 2f 61 3e 0a 20 20 20 20 20 20 20 20  en)</a>.        
1af0: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 20  }else{.         
1b00: 20 40 20 3c 6c 69 3e 3c 61 20 68 72 65 66 3d 25   @ <li><a href=%
1b10: 73 28 67 2e 7a 42 61 73 65 55 52 4c 29 2f 74 61  s(g.zBaseURL)/ta
1b20: 67 76 69 65 77 3f 6e 61 6d 65 3d 25 73 28 6e 61  gview?name=%s(na
1b30: 6d 65 29 3e 0a 20 20 20 20 20 20 20 20 20 20 40  me)>.          @
1b40: 20 25 73 28 6e 61 6d 65 29 3c 2f 61 3e 0a 20 20   %s(name)</a>.  
1b50: 20 20 20 20 20 20 7d 0a 20 20 20 20 20 20 7d 65        }.      }e
1b60: 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 69 66 28  lse{.        if(
1b70: 20 73 74 72 6e 63 6d 70 28 6e 61 6d 65 2c 20 70   strncmp(name, p
1b80: 72 65 66 69 78 2c 20 70 72 65 66 6c 65 6e 29 3d  refix, preflen)=
1b90: 3d 30 20 29 7b 0a 20 20 20 20 20 20 20 20 20 20  =0 ){.          
1ba0: 40 20 3c 6c 69 3e 3c 73 74 72 6f 6e 67 3e 25 73  @ <li><strong>%s
1bb0: 28 6e 61 6d 65 2b 70 72 65 66 6c 65 6e 29 3c 2f  (name+preflen)</
1bc0: 73 74 72 6f 6e 67 3e 0a 20 20 20 20 20 20 20 20  strong>.        
1bd0: 7d 65 6c 73 65 7b 0a 20 20 20 20 20 20 20 20 20  }else{.         
1be0: 20 40 20 3c 6c 69 3e 3c 73 74 72 6f 6e 67 3e 25   @ <li><strong>%
1bf0: 73 28 6e 61 6d 65 29 3c 2f 73 74 72 6f 6e 67 3e  s(name)</strong>
1c00: 0a 20 20 20 20 20 20 20 20 7d 0a 20 20 20 20 20  .        }.     
1c10: 20 7d 0a 20 20 20 20 20 20 69 66 28 20 73 74 72   }.      if( str
1c20: 6e 63 6d 70 28 6e 61 6d 65 2c 20 70 72 65 66 69  ncmp(name, prefi
1c30: 78 2c 20 70 72 65 66 6c 65 6e 29 3d 3d 30 20 29  x, preflen)==0 )
1c40: 7b 0a 20 20 20 20 20 20 20 20 40 20 28 73 79 6d  {.        @ (sym
1c50: 62 6f 6c 69 63 20 6c 61 62 65 6c 29 0a 20 20 20  bolic label).   
1c60: 20 20 20 7d 0a 20 20 20 20 20 20 40 20 3c 2f 6c     }.      @ </l
1c70: 69 3e 0a 20 20 20 20 7d 0a 20 20 20 20 40 20 3c  i>.    }.    @ <
1c80: 2f 75 6c 3e 0a 20 20 20 20 69 66 28 20 6e 54 61  /ul>.    if( nTa
1c90: 67 20 3d 3d 20 30 29 20 7b 0a 20 20 20 20 20 20  g == 0) {.      
1ca0: 40 20 54 68 65 72 65 20 61 72 65 20 6e 6f 20 72  @ There are no r
1cb0: 65 6c 65 76 61 6e 74 20 74 61 67 73 2e 0a 20 20  elevant tags..  
1cc0: 20 20 7d 0a 20 20 20 20 64 62 5f 66 69 6e 61 6c    }.    db_final
1cd0: 69 7a 65 28 26 71 29 3b 0a 20 20 7d 0a 20 20 73  ize(&q);.  }.  s
1ce0: 74 79 6c 65 5f 68 65 61 64 65 72 28 7a 54 69 74  tyle_header(zTit
1cf0: 6c 65 29 3b 0a 20 20 2f 2a 0a 20 20 20 2a 20 50  le);.  /*.   * P
1d00: 75 74 20 69 6e 20 64 75 6d 6d 79 20 66 75 6e 63  ut in dummy func
1d10: 74 69 6f 6e 73 20 73 69 6e 63 65 20 77 77 77 5f  tions since www_
1d20: 70 72 69 6e 74 5f 74 69 6d 65 6c 69 6e 65 20 68  print_timeline h
1d30: 61 73 20 67 65 6e 65 72 61 74 65 64 20 63 61 6c  as generated cal
1d40: 6c 73 20 74 6f 0a 20 20 20 2a 20 74 68 65 6d 2e  ls to.   * them.
1d50: 20 53 6f 6d 65 20 62 72 6f 77 73 65 72 73 20 64   Some browsers d
1d60: 6f 6e 27 74 20 73 65 65 6d 20 74 6f 20 63 61 72  on't seem to car
1d70: 65 2c 20 62 75 74 20 62 65 74 74 65 72 20 74 6f  e, but better to
1d80: 20 62 65 20 73 61 66 65 2e 0a 20 20 20 2a 20 41   be safe..   * A
1d90: 63 74 75 61 6c 6c 79 2c 20 69 74 20 77 6f 75 6c  ctually, it woul
1da0: 64 20 62 65 20 6e 69 63 65 20 74 6f 20 75 73 65  d be nice to use
1db0: 20 74 68 65 20 66 75 6e 63 74 69 6f 6e 73 20 6f   the functions o
1dc0: 6e 20 74 68 69 73 20 70 61 67 65 2c 20 62 75 74  n this page, but
1dd0: 20 61 74 0a 20 20 20 2a 20 74 68 65 20 6d 6f 6d   at.   * the mom
1de0: 65 6e 74 20 69 74 20 6c 6f 6f 6b 73 20 74 6f 20  ent it looks to 
1df0: 62 65 20 74 6f 6f 20 64 69 66 66 69 63 75 6c 74  be too difficult
1e00: 2e 0a 20 20 20 2a 2f 0a 20 20 40 20 3c 73 63 72  ..   */.  @ <scr
1e10: 69 70 74 3e 0a 20 20 40 20 66 75 6e 63 74 69 6f  ipt>.  @ functio
1e20: 6e 20 78 69 6e 28 69 64 29 7b 0a 20 20 40 20 7d  n xin(id){.  @ }
1e30: 0a 20 20 40 20 66 75 6e 63 74 69 6f 6e 20 78 6f  .  @ function xo
1e40: 75 74 28 69 64 29 7b 0a 20 20 40 20 7d 0a 20 20  ut(id){.  @ }.  
1e50: 40 20 3c 2f 73 63 72 69 70 74 3e 0a 0a 20 20 73  @ </script>..  s
1e60: 74 79 6c 65 5f 66 6f 6f 74 65 72 28 29 3b 0a 7d  tyle_footer();.}
1e70: 0a 0a 23 65 6e 64 69 66 20 2f 2a 20 44 49 53 41  ..#endif /* DISA
1e80: 42 4c 45 44 20 2a 2f 0a                          BLED */.