X-Git-Url: https://git.plutz.net/?a=blobdiff_plain;f=tools.sh;h=c5545fb92e0cecc8975627514b7d80b32ea16aff;hb=32a46b9aa404d760772578be04d100ae1c9a55f7;hp=e40e25f4be075bb97589fc6415e09c3c2dc5b025;hpb=bba1d35607b3ac76b36591d427caa0684ad54bb8;p=shellwiki diff --git a/tools.sh b/tools.sh old mode 100644 new mode 100755 index e40e25f..c5545fb --- a/tools.sh +++ b/tools.sh @@ -1,5 +1,28 @@ #!/bin/sh +[ "$include_tools" ] && return 0 +include_tools="$0" + +if [ "$(which awk)" ]; then + md() { awk -f "$_EXEC/md_macros.awk" -f "$_EXEC/cgilite/markdown.awk"; } +elif [ "$(which busybox)" ]; then + md() { busybox awk -f "$_EXEC/md_macros.awk" -f "$_EXEC/cgilite/markdown.awk"; } +else + md() { cat; } +fi + +mdfile(){ + local page="$(PATH "$1")" + + if [ -f "$_DATA/pages/$page/#page.md" ]; then + printf %s\\n "$_DATA/pages/$page/#page.md" + elif [ -f "$_EXEC/pages/$page/#page.md" ]; then + printf %s\\n "$_EXEC/pages/$page/#page.md" + else + return 1 + fi +} + size_human(){ local size="$1" @@ -21,7 +44,7 @@ size_human(){ } page_glob(){ - local pattern="$1" IFS='' + local pattern="${1%/}/" IFS='' local glob page pagedir case $pattern in @@ -38,8 +61,7 @@ page_glob(){ | while read -r page; do case $page in \#*|*/\#*) continue;; - /*) pagedir="$(PATH "$page")";; - *) pagedir="$(PATH "$PATH_INFO/$page")";; + *) pagedir="$(page_abs "$page")";; esac [ -d "$_DATA/pages/$pagedir" -o -d "$_EXEC/pages/$pagedir" ] \ && printf '%s\n' "$page" @@ -55,8 +77,8 @@ page_children(){ case $page in /*) - for glob in "$_DATA/pages/${page}"*/; do printf '%s\n' "${glob#"$_DATA/pages"}"; done - for glob in "$_EXEC/pages/${page}"*/; do printf '%s\n' "${glob#"$_EXEC/pages"}"; done + for glob in "$_DATA/pages/${page}"*/; do printf '%s\n' "${glob#"$_DATA/pages/"}"; done + for glob in "$_EXEC/pages/${page}"*/; do printf '%s\n' "${glob#"$_EXEC/pages/"}"; done ;; *) for glob in "$_DATA/pages/$PATH_INFO/${page}"*/; do printf '%s\n' "${glob#"$_DATA/pages/$PATH_INFO/"}"; done @@ -67,8 +89,7 @@ page_children(){ | while read -r page; do case $page in \#*|*/\#*) continue;; - /*) pagedir="$(PATH "$page")";; - *) pagedir="$(PATH "$PATH_INFO/$page")";; + *) pagedir="$(page_abs "$page")";; esac if [ -d "$_DATA/pages/$pagedir" -o -d "$_EXEC/pages/$pagedir" ]; then printf %s\\n "$page" @@ -76,3 +97,10 @@ page_children(){ fi done } + +page_abs(){ + case $1 in + /*) PATH "${1%/}/";; + *) PATH "${PATH_INFO%/*}/${1%/}/";; + esac +}