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 */.