X-Git-Url: https://git.plutz.net/?a=blobdiff_plain;f=tools.sh;h=a298394c9cf5881cb4a764587302fe4467030d67;hb=e5ea4373a0510820e542e2b4eed63ff64211da9a;hp=57ae8274cc6d1fde2a5be157531734c8b246832d;hpb=f17f2a98e2387cf9c2e68005c420b9a34ade17c9;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 +}