Total rewrite #15

Merged
emma merged 14 commits from rewrite into main 2023-03-22 12:42:30 -06:00
Showing only changes of commit e4501794f2 - Show all commits

View File

@ -29,19 +29,19 @@ fi
# check if we have tomcat(1) # check if we have tomcat(1)
if ! command -v tomcat >/dev/null 2>&1; then if ! command -v tomcat >/dev/null 2>&1; then
printf "%s: Missing dependency: stoml(1)\n" "$argv0" 1>&2 printf "%s: Missing dependency: tomcat(1)\n" "$argv0" 1>&2
exit 71 # sysexits(3) EX_OSERR exit 71 # sysexits(3) EX_OSERR
fi fi
# set the XDG_COMMAND # set the XDG_COMMAND
test -n "$XDG_COMMAND" || XDG_COMMAND="$(tomcat tools.xdg $CONFIG)" test -n "$XDG_COMMAND" || XDG_COMMAND="$(tomcat tools.xdg "$CONFIG")"
! command -v handlr >/dev/null 2>&1 && ! command -v xdg-open >/dev/null 2>&1 \ ! command -v handlr >/dev/null 2>&1 && ! command -v xdg-open >/dev/null 2>&1 \
&& XDG_COMMAND=false \ && XDG_COMMAND=false \
|| true || true
# check if we have a BROWSER # check if we have a BROWSER
test -n "$BROWSER" || BROWSER="$(tomcat tools.browser $CONFIG)" test -n "$BROWSER" || BROWSER="$(tomcat tools.browser "$CONFIG")"
if ! test -n "$BROWSER"; then if ! test -n "$BROWSER"; then
printf "\ printf "\
%s: \$BROWSER not filled. %s: \$BROWSER not filled.
@ -61,40 +61,41 @@ while test -n "$1"; do
xargs echo)" xargs echo)"
# get the pattern for the extensions to MATCH # get the pattern for the extensions to MATCH
MATCH=$(printf "%s\n" "$URL" | sed -ne 's/^h.\+\/\///p' |\ MATCH="$(printf "%s\n" "$URL" | sed -ne 's/^h.\+\/\///p' |\
sed -e 's/\/.*\+//g') sed -e 's/\/.*\+//g')"
# run through MIME extensions # run through MIME extensions
for file in \ for file in \
"$XDG_DATA_HOME"/xdg-sanity/*-mime.toml \ "$XDG_DATA_HOME"/xdg-sanity/*-mime.toml \
/usr/share/xdg-sanity/*-mime.toml \ /usr/share/xdg-sanity/*-mime.toml \
/usr/local/share/xdg-sanity/*-mime.toml \ /usr/local/share/xdg-sanity/*-mime.toml
/dev/null
do do
if test -e "$file"; then
i=$(tomcat replace.urls "$file" | sed 's/ /\n/g' | wc -l) i=$(tomcat replace.urls "$file" | sed 's/ /\n/g' | wc -l)
printf "$i\n"
while ! [ "$i" = 0 ]; do while ! [ "$i" = 0 ]; do
if [ "$MATCH" = "$(tomcat replace.urls[$i] $file)" ]; then if [ "$MATCH" = "$(tomcat replace.urls["$i"] "$file")" ]; then
MIME=$(tomcat with.mime "$file") MIME="$(tomcat with.mime "$file")"
fi fi
i=$(dc -e "$i 1 - p") i="$(dc -e "$i 1 - p")"
done done
fi
done done
# and the replace extensions # and the replace extensions
for file in \ for file in \
"$XDG_DATA_HOME"/xdg-sanity/*-replace.toml \ "$XDG_DATA_HOME"/xdg-sanity/*-replace.toml \
/usr/share/xdg-sanity/*-replace.toml \ /usr/share/xdg-sanity/*-replace.toml \
/usr/local/share/xdg-sanity/*-replace.toml \ /usr/local/share/xdg-sanity/*-replace.toml
/dev/null
do do
if test -e "$file"; then
i=$(tomcat replace.urls "$file" | sed 's/ /\n/g' | wc -l) i=$(tomcat replace.urls "$file" | sed 's/ /\n/g' | wc -l)
while ! [ "$i" = 0 ]; do while ! [ "$i" = 0 ]; do
if [ "$MATCH" = "$(tomcat replace.urls[$i] $file)" ]; then if [ "$MATCH" = "$(tomcat replace.urls["$i"] "$file")" ]; then
URL=$(tomcat with.url "$file") URL="$(tomcat with.url "$file")"
fi fi
i=$(dc -e "$i 1 - p") i="$(dc -e "$i 1 - p")"
done done
fi
done done
# these commands may fail; this is intentional # these commands may fail; this is intentional
@ -103,10 +104,10 @@ while test -n "$1"; do
else else
case "$(command -v $XDG_COMMAND)" in case "$(command -v $XDG_COMMAND)" in
*/handlr ) */handlr )
"XDG_COMMAND" "$MIME" -- "$URL" handlr launch "$MIME" -- "$URL"
;; ;;
*/xdg-open ) */xdg-open )
"$(xdg-mime query default $MIME)" "$URL" "$(xdg-mime query default "$MIME")" "$URL"
;; ;;
false ) false )
exit 69 # sysexits(3) EX_UNAVAILABLE exit 69 # sysexits(3) EX_UNAVAILABLE