X-Git-Url: https://git.plutz.net/?a=blobdiff_plain;f=tools.sh;h=a298394c9cf5881cb4a764587302fe4467030d67;hb=04a8c0c771a9dba7e9ead58f97b2b2ca19513399;hp=57ae8274cc6d1fde2a5be157531734c8b246832d;hpb=f8bec3740e1d99684a5c33680e48d1f523c09983;p=shellwiki diff --git a/tools.sh b/tools.sh index 57ae827..a298394 100755 --- a/tools.sh +++ b/tools.sh @@ -151,11 +151,12 @@ page_abs(){ } has_tags() { + # true if PAGE is tagges with all TAGS local page="$(page_abs "$1")"; shift 1; local tdir="$_DATA/tags" tag dt df for tag in "$@"; do - tag="$(printf %s "$tag" |awk '{ sub(/^#/, ""); gsub(/[^[:alnum:]]/, "_"); print toupper($0); }')" + tag="$(printf %s "$tag" |awk '{ sub(/^[#!]/, ""); gsub(/[^[:alnum:]]/, "_"); print toupper($0); }')" dt="$(DBM "${tdir}/${tag}" get "${page}")" || return 1 df="$(stat -c %Y "$(mdfile "$page")")" || return 1 if [ "$df" -gt "$dt" ]; then @@ -165,3 +166,22 @@ has_tags() { done return 0 } + +has_tag() { + # true if PAGE is tagged with any of TAGS + local page="$(page_abs "$1")"; shift 1; + local tdir="$_DATA/tags" tag dt df + + for tag in "$@"; do + tag="$(printf %s "$tag" |awk '{ sub(/^[#!]/, ""); gsub(/[^[:alnum:]]/, "_"); print toupper($0); }')" + dt="$(DBM "${tdir}/${tag}" get "${page}")" || continue + df="$(stat -c %Y "$(mdfile "$page")")" || return 1 + if [ "$df" -gt "$dt" ]; then + DBM "${tdir}/${tag}" remove "${page}" + continue + else + return 0 + fi + done + return 1 +}