X-Git-Url: https://git.plutz.net/?a=blobdiff_plain;f=tools.sh;h=2e98d674d764295b3e338fd3ca7a59c8c42ec0d9;hb=a88a2e833916c59ea6e99e9588543a58f02b9efe;hp=c88cc55c12bfdeaedf482d4dddcfed51941e7281;hpb=78a94a774fa0f9317b469995a9389551e0501a75;p=shellwiki diff --git a/tools.sh b/tools.sh old mode 100644 new mode 100755 index c88cc55..2e98d67 --- a/tools.sh +++ b/tools.sh @@ -1,5 +1,8 @@ #!/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 @@ -9,15 +12,26 @@ else fi mdfile(){ + # Check if page exists, if possible fall + # back to default page from installation local page="$(PATH "$1")" + # IMPORTANT: A Copy of this function exists + # in `handlers/10_translations.sh` + # Look into it now! + # Keep it synchronized, when changing anything + if [ -f "$_DATA/pages/$page/#page.md" ]; then printf %s\\n "$_DATA/pages/$page/#page.md" + return 0 elif [ -f "$_EXEC/pages/$page/#page.md" ]; then printf %s\\n "$_EXEC/pages/$page/#page.md" + return 0 else return 1 - fi + fi 2>&- + # ^^ suppress error messages produced + # by printf when stdout was closed } size_human(){ @@ -58,8 +72,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" @@ -75,8 +88,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 @@ -87,8 +100,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" @@ -96,3 +108,10 @@ page_children(){ fi done } + +page_abs(){ + case $1 in + /*) PATH "${1%/}/";; + *) PATH "${PATH_INFO%/*}/${1%/}/";; + esac +}