X-Git-Url: https://git.plutz.net/?a=blobdiff_plain;f=tools.sh;h=c88cc55c12bfdeaedf482d4dddcfed51941e7281;hb=277d06327a184eb1fb72ba46fd8a3194c9c37362;hp=926c7e4e3bdf51ed763aa55b862dd25d53bdabfb;hpb=e83851d3bdcb41a24687a1579e35dcfa39db4722;p=shellwiki diff --git a/tools.sh b/tools.sh index 926c7e4..c88cc55 100644 --- a/tools.sh +++ b/tools.sh @@ -1,5 +1,25 @@ #!/bin/sh +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 +41,7 @@ size_human(){ } page_glob(){ - local pattern="$1" IFS='' + local pattern="${1%/}/" IFS='' local glob page pagedir case $pattern in @@ -47,11 +67,11 @@ page_glob(){ } page_children(){ - local page="${1%/}/" depth="${2:--1}" + local page="${1:-${PATH_INFO}}" depth="${2:-1}" local glob pagedir IFS='' + page="${page%/}/" [ "$depth" -eq 0 ] && return 0 - printf %s\\n "$page" case $page in /*) @@ -70,7 +90,9 @@ page_children(){ /*) pagedir="$(PATH "$page")";; *) pagedir="$(PATH "$PATH_INFO/$page")";; esac - [ -d "$_DATA/pages/$pagedir" -o -d "$_EXEC/pages/$pagedir" ] \ - && page_children "$page" "$((depth - 1))" + if [ -d "$_DATA/pages/$pagedir" -o -d "$_EXEC/pages/$pagedir" ]; then + printf %s\\n "$page" + page_children "$page" "$((depth - 1))" + fi done }