#!/bin/sh
+isnum() {
+ grep -xq '[0-9]\+' <<<"$1"
+}
+
+findfile() {
+ local file tail eq eqt m
+ for file in "$1"*; do
+ tail="${file#$1}"
+ eq="${tail%.*}"
+ m=n
+ if [ "${eq%% *}" -eq "$2" ] 2>/dev/null; then
+ if [[ "$eq" == *\ * ]]; then
+ eqt="${eq#* }"
+ else
+ eqt=
+ fi
+ m=y
+ elif [ "${eq:0:${#2}}" = "$2" ]; then
+ eqt="${eq:${#2}}"
+ if [ "${eqt:0:1}" = " " -o -z "$eqt" ]; then
+ eqt="${eqt# }"
+ m=y
+ fi
+ fi
+ if [ "$m" = y ]; then
+ if [ "$eqt" = "$3" -o "$eqt" = "($3)" ]; then
+ echo "$file"
+ return 0
+ fi
+ fi
+ done
+ return 1
+}
+
cmdline=(mplayer -fs)
while [ "${1:0:1}" = - ]; do
a="$1"
shift
case "$a" in
+ -h)
+ echo "usage: planime [-ht] [-s PAR VAL] [NAME-QUAL] [EP|.] [TYPE-QUAL]" >&2
+ exit 0
+ ;;
-t)
cmdline=("${cmdline[@]}" -ao oss:/dev/dsp1)
;;
esac
done
-if [ $# -lt 1 ]; then
- echo "usage: planime [QUAL] EPNUM" >&2
- exit 1
-fi
-if [ $# -eq 1 ]; then
- ep="$1"
- unset qual
+base="$(basename "$(pwd)")"
+nextep=n
+file=
+tqual=
+if [ $# -eq 0 ]; then
+ nextep=y
+elif [ $# -eq 1 ]; then
+ if [ -r "$1" ]; then
+ file="$1"
+ else
+ if findfile "$base - " "$1" >/dev/null; then
+ ep="$1"
+ else
+ nextep=y
+ base="$base $1"
+ fi
+ fi
elif [ $# -eq 2 ]; then
- qual="$1"
+ if findfile "$base - " "$1" "$2" >/dev/null; then
+ ep="$1"
+ tqual="$2"
+ else
+ base="$base $1"
+ ep="$2"
+ fi
+else
+ base="$base $1"
ep="$2"
+ tqual="$3"
+fi
+if [ "$ep" = . ]; then nextep=y; fi
+if [ "$nextep" = y -a -r nextep ]; then
+ ep="$(<nextep)"
+ if ! isnum "$ep"; then
+ echo "planime: nextep is non-numeric" >&2
+ exit 1
+ fi
fi
+file="$(findfile "$base - " "$ep" "$qual")"
+
+if [ -z "$file" ]; then
+ echo "planime: no matching file found" >&2
+ exit 1
+fi
+
+echo "$file"
+exit 0
if [ ! -r "$ep" ]; then
if [ -z "$qual" ]; then