forked from speedie/spmenu
add some really nice features, and WIP file navigation to spmenu_run
This commit is contained in:
parent
6e74d78ff8
commit
68716f15a3
|
@ -658,6 +658,8 @@ The selected option is piped to /bin/sh (by default). Unlike dmenu_run,
|
||||||
spmenu_run has some cool features. For example:
|
spmenu_run has some cool features. For example:
|
||||||
|
|
||||||
- Prepending `#` will spawn it in a terminal instead of just a shell.
|
- Prepending `#` will spawn it in a terminal instead of just a shell.
|
||||||
|
- Prepending `?` will run the command in a function, most of the time used to
|
||||||
|
display the man page.
|
||||||
- Prepending `magnet` will open a magnet link in $TORRENT
|
- Prepending `magnet` will open a magnet link in $TORRENT
|
||||||
- Prepending `www` will open a page in $BROWSER
|
- Prepending `www` will open a page in $BROWSER
|
||||||
|
|
||||||
|
|
|
@ -1,21 +1,26 @@
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
[ -z "$CONFDIR" ] && CONFDIR="${XDG_CONFIG_HOME:-$HOME/.config}"
|
# spmenu_run
|
||||||
[ -z "$TERMINAL" ] && TERMINAL="st -e"
|
# Run launcher for spmenu
|
||||||
[ -z "$BROWSER" ] && BROWSER="xdg-open"
|
|
||||||
[ -z "$TORRENT" ] && TORRENT="qbittorrent"
|
# Set basic variables, in case the config isn't valid, env variables and config file can override these
|
||||||
[ -z "$WEB_GREP" ] && WEB_GREP="http:|https:|www[.]"
|
CONFDIR="${CONFDIR:-${XDG_CONFIG_HOME:-$HOME/.config}}"
|
||||||
[ -z "$MAGNET_GREP" ] && MAGNET_GREP="magnet:?"
|
TERMINAL="${TERMINAL:-st -e}"
|
||||||
[ -z "$HISTORY" ] && HISTORY="${XDG_CACHE_HOME:-$HOME/.cache/}/spmenu_run.hist"
|
BROWSER="${BROWSER:-xdg-open}"
|
||||||
[ -z "$RUNLAUNCHER" ] && RUNLAUNCHER=spmenu
|
TORRENT="${TORRENT:-qbittorrent}"
|
||||||
[ -z "$RUNLAUNCHER_ARGS" ] && RUNLAUNCHER_ARGS="--insert --hist-file $HISTORY $*"
|
WEB_GREP="${WEB_GREP:-http:|https:|www[.]}"
|
||||||
[ -z "$PREFIX" ] && PREFIX="/usr"
|
MAGNET_GREP="${MAGNET_GREP:-magnet:?}"
|
||||||
[ -z "$SORT_BY_NUMBER" ] && SORT_BY_NUMBER="true"
|
HISTORY="${HISTORY:-${XDG_CACHE_HOME:-$HOME/.cache/}/spmenu_run.hist}"
|
||||||
[ -z "$SORT_IN_REVERSE" ] && SORT_IN_REVERSE="true"
|
RUNLAUNCHER="${RUNLAUNCHER:-spmenu}"
|
||||||
[ -z "$SORT_BY_RECENT" ] && SORT_BY_RECENT="false"
|
PREFIX="${PREFIX:-/usr}"
|
||||||
[ -z "$SORT_ARGS" ] && SORT_ARGS=""
|
DESTDIR="${DESTDIR:-}"
|
||||||
[ -z "$HIDDEN_KEYWORDS" ] && HIDDEN_KEYWORDS="spmenu"
|
SORT_BY_NUMBER="${SORT_BY_NUMBER:-true}"
|
||||||
[ -z "$KEYWORDS" ] && KEYWORDS=""
|
SORT_IN_REVERSE="${SORT_IN_REVERSE:-true}"
|
||||||
[ -z "$DISPLAY_DUPLICATES" ] && DISPLAY_DUPLICATES="false"
|
SORT_BY_RECENT="${SORT_BY_RECENT:-false}"
|
||||||
|
SORT_ARGS="${SORT_ARGS:-}"
|
||||||
|
UNIQ_ARGS="${UNIQ_ARGS:-}"
|
||||||
|
HIDDEN_KEYWORDS="${HIDDEN_KEYWORDS:-spmenu}"
|
||||||
|
KEYWORDS="${KEYWORDS:-}"
|
||||||
|
DISPLAY_DUPLICATES="${DISPLAY_DUPLICATES:-false}"
|
||||||
|
|
||||||
check() {
|
check() {
|
||||||
[ ! -d "$CONFDIR/spmenu/run" ] && mkdir -p "$CONFDIR/spmenu/run"
|
[ ! -d "$CONFDIR/spmenu/run" ] && mkdir -p "$CONFDIR/spmenu/run"
|
||||||
|
@ -53,7 +58,7 @@ path() {
|
||||||
if [ "$DISPLAY_DUPLICATES" != "false" ]; then
|
if [ "$DISPLAY_DUPLICATES" != "false" ]; then
|
||||||
print_menu
|
print_menu
|
||||||
else
|
else
|
||||||
print_menu | uniq
|
print_menu | uniq $UNIQ_ARGS
|
||||||
fi
|
fi
|
||||||
|
|
||||||
command -v pre_func && pre_func
|
command -v pre_func && pre_func
|
||||||
|
@ -68,11 +73,23 @@ To configure spmenu, you may also copy ${DESTDIR}${PREFIX}/share/spmenu/example.
|
||||||
- Type in '?' to show this help screen at any time.
|
- Type in '?' to show this help screen at any time.
|
||||||
- If the entry selected starts with 'www', it will instead be treated as a link and spawned in a web browser (\$BROWSER)
|
- If the entry selected starts with 'www', it will instead be treated as a link and spawned in a web browser (\$BROWSER)
|
||||||
- If the entry selected starts with 'magnet', it will instead be treated as a magnet link and spawned in a torrent client (\$TORRENT)
|
- If the entry selected starts with 'magnet', it will instead be treated as a magnet link and spawned in a torrent client (\$TORRENT)
|
||||||
|
- If the entry selected starts with '?' followed by a valid command, it will be opened as a man page in spmenu.
|
||||||
|
- If the entry starts with '#' followed by a valid command, it will be opened in the defined terminal emulator.
|
||||||
|
|
||||||
$(printf '\033[0;31m')Note: This may also be displayed if you deleted your spmenu configuration directory.
|
$(printf '\033[0;31m')Note: This may also be displayed if you deleted your spmenu configuration directory.
|
||||||
EOF
|
EOF
|
||||||
}
|
}
|
||||||
|
|
||||||
|
print_cli_help() {
|
||||||
|
cat << EOF
|
||||||
|
spmenu_run - Run launcher for spmenu
|
||||||
|
|
||||||
|
spmenu -x, --run List entries in \$PATH.
|
||||||
|
spmenu -f, --fm <dir> List files and directories in <dir>.
|
||||||
|
spmeni -h, --help Print this help.
|
||||||
|
EOF
|
||||||
|
}
|
||||||
|
|
||||||
print_config() {
|
print_config() {
|
||||||
[ -f "$CONFDIR/spmenu/run/config" ] && . "$CONFDIR/spmenu/run/config" && return
|
[ -f "$CONFDIR/spmenu/run/config" ] && . "$CONFDIR/spmenu/run/config" && return
|
||||||
mkdir -p "$CONFDIR/spmenu/run"
|
mkdir -p "$CONFDIR/spmenu/run"
|
||||||
|
@ -82,8 +99,8 @@ cat << EOF > "$CONFDIR/spmenu/run/config"
|
||||||
# This is the configuration file for the run launcher spmenu comes with.
|
# This is the configuration file for the run launcher spmenu comes with.
|
||||||
# It is not the configuration file for spmenu, see ~/.config/spmenu/spmenu.conf for that.
|
# It is not the configuration file for spmenu, see ~/.config/spmenu/spmenu.conf for that.
|
||||||
#
|
#
|
||||||
# spmenu_run runs function 'pre_func' before spawning spmenu, and 'post_func' after spawning spmenu.
|
# spmenu_run runs function 'pre_func' before spawning spmenu, 'post_func' after spawning spmenu, and 'read_man' when reading a man page.
|
||||||
# You may create those functions below. For 'post_func', the selected item is passed as an argument (\$1)
|
# You may create those functions below. For 'post_func' and 'read_man', the selected item is passed as an argument (\$1)
|
||||||
#
|
#
|
||||||
# For example, to implement a basic history file:
|
# For example, to implement a basic history file:
|
||||||
#
|
#
|
||||||
|
@ -99,7 +116,7 @@ WEB_GREP="http:|https:|www[.]" # Needs to be in grep -E syntax
|
||||||
MAGNET_GREP="magnet:?" # Needs to be in grep -E syntax
|
MAGNET_GREP="magnet:?" # Needs to be in grep -E syntax
|
||||||
HISTORY="\${XDG_CACHE_HOME:-\$HOME/.cache/}/spmenu_run.hist" # History file, spmenu (meaning your user) must have permission to read and write to it.
|
HISTORY="\${XDG_CACHE_HOME:-\$HOME/.cache/}/spmenu_run.hist" # History file, spmenu (meaning your user) must have permission to read and write to it.
|
||||||
RUNLAUNCHER="\${RUNLAUNCHER:-spmenu}" # Run launcher to use
|
RUNLAUNCHER="\${RUNLAUNCHER:-spmenu}" # Run launcher to use
|
||||||
RUNLAUNCHER_ARGS="--insert --hist-file \$HISTORY \$*" # Arguments passed to \$RUNLAUNCHER
|
RUNLAUNCHER_ARGS="--insert --hist-file \$HISTORY \$args" # Arguments passed to \$RUNLAUNCHER
|
||||||
SORT_BY_NUMBER="true" # Sort by numbers
|
SORT_BY_NUMBER="true" # Sort by numbers
|
||||||
SORT_IN_REVERSE="true" # Sort in reverse
|
SORT_IN_REVERSE="true" # Sort in reverse
|
||||||
SORT_BY_RECENT="false" # Sort by recent
|
SORT_BY_RECENT="false" # Sort by recent
|
||||||
|
@ -107,6 +124,11 @@ SORT_ARGS="" # Extra arguments passed to the sort command.
|
||||||
HIDDEN_KEYWORDS="spmenu" # Keywords that will be ignored, needs to be in grep -vE syntax.
|
HIDDEN_KEYWORDS="spmenu" # Keywords that will be ignored, needs to be in grep -vE syntax.
|
||||||
KEYWORDS="" # Keywords that will be matched, needs to be in grep -E syntax.
|
KEYWORDS="" # Keywords that will be matched, needs to be in grep -E syntax.
|
||||||
DISPLAY_DUPLICATES="false" # Display duplicates or not
|
DISPLAY_DUPLICATES="false" # Display duplicates or not
|
||||||
|
DEFAULT_FEATURE="run" # spmenu_run default feature (run/fm/help)
|
||||||
|
DEFAULT_DIRECTORY="\$(pwd)" # Directory to start -fm if none is specified.
|
||||||
|
|
||||||
|
# function to read the man page in spmenu
|
||||||
|
read_man() { man "\$1" | col -b | \${RUNLAUNCHER:-spmenu} --lines 40 --columns 1 -p "man "\$1"; }
|
||||||
EOF
|
EOF
|
||||||
[ -f "$CONFDIR/spmenu/run/config" ] && . "$CONFDIR/spmenu/run/config" && return
|
[ -f "$CONFDIR/spmenu/run/config" ] && . "$CONFDIR/spmenu/run/config" && return
|
||||||
}
|
}
|
||||||
|
@ -115,10 +137,16 @@ parse() {
|
||||||
dout="$(path | sed "s/\&/\&/g" | $RUNLAUNCHER $RUNLAUNCHER_ARGS)"
|
dout="$(path | sed "s/\&/\&/g" | $RUNLAUNCHER $RUNLAUNCHER_ARGS)"
|
||||||
|
|
||||||
# parse
|
# parse
|
||||||
[ "$(printf '%c' "$dout")" = "#" ] && EXEC=term
|
case "$(printf '%c' "$dout")" in
|
||||||
[ "$(printf "$dout" | awk '{ print $1 }')" = "magnet" ] && EXEC=torrent
|
"#") EXEC="term" ;;
|
||||||
[ "$(printf "$dout" | awk '{ print $1 }')" = "www" ] && EXEC=web
|
"?") EXEC="man" ;;
|
||||||
[ "$(printf "$dout" | awk '{ print $1 }')" = "?" ] && print_help && main && return
|
esac
|
||||||
|
|
||||||
|
case "$(printf "%s" "$dout" | awk '{ print $1 }')" in
|
||||||
|
"magnet") EXEC=torrent ;;
|
||||||
|
"www") EXEC=web ;;
|
||||||
|
"?") [ "$EXEC" != "man" ] && print_help && main && return ;;
|
||||||
|
esac
|
||||||
|
|
||||||
# check for keywords
|
# check for keywords
|
||||||
printf "%s" "$dout" | grep -qE "$WEB_GREP" && EXEC=web
|
printf "%s" "$dout" | grep -qE "$WEB_GREP" && EXEC=web
|
||||||
|
@ -129,19 +157,77 @@ exec_cmd() {
|
||||||
[ -z "$EXEC" ] && EXEC=shell
|
[ -z "$EXEC" ] && EXEC=shell
|
||||||
command -v post_func > /dev/null && post_func "$dout"
|
command -v post_func > /dev/null && post_func "$dout"
|
||||||
|
|
||||||
|
read_nman() {
|
||||||
|
$TERMINAL -e man "$1"
|
||||||
|
}
|
||||||
|
|
||||||
case "$EXEC" in
|
case "$EXEC" in
|
||||||
"shell") printf "%s" "$dout" | sed "s/#//g" | ${SHELL:-"/bin/sh"} & ;;
|
"shell") printf "%s" "$dout" | sed "s/#//g" | ${SHELL:-"/bin/sh"} & ;;
|
||||||
"term") $TERMINAL -e "$(printf "%s" "$dout" | sed "s/#//g")" & ;;
|
"term") $TERMINAL -e "$(printf "%s" "$dout" | sed "s/#//g")" & ;;
|
||||||
"web") $BROWSER "$(printf "%s" "$dout" | sed "s/www //g")" & ;;
|
"web") $BROWSER "$(printf "%s" "$dout" | sed "s/www //g")" & ;;
|
||||||
"torrent") $TORRENT "$(printf "%s" "$dout" | sed "s/magnet //g")" & ;;
|
"torrent") $TORRENT "$(printf "%s" "$dout" | sed "s/magnet //g")" & ;;
|
||||||
|
"man") exec="$(printf "%s" "$dout" | sed "s/?//g")"
|
||||||
|
[ -x "$(command -v "$exec")" ] || return
|
||||||
|
if [ "$(command -v read_man)" ]; then
|
||||||
|
read_man "$exec"
|
||||||
|
return
|
||||||
|
else
|
||||||
|
read_nman "$exec"
|
||||||
|
return
|
||||||
|
fi
|
||||||
|
;;
|
||||||
esac
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
|
remove_arg() { args="$(printf "%s\n" "$args" | sed "s|$1||g")"; }
|
||||||
|
|
||||||
|
read_args() {
|
||||||
|
function="${DEFAULT_FEATURE:-run}" # default functionality
|
||||||
|
dir="${DEFAULT_DIRECTORY:-$(pwd)}" # default directory
|
||||||
|
args="$(printf "%s\n" "$@")"
|
||||||
|
argc="$(printf "%s\n" "$@" | wc -l)"
|
||||||
|
|
||||||
|
while true; do
|
||||||
|
i=$(($i+1))
|
||||||
|
arg="$(printf "%s\n" "$args" | sed "${i}q;d")"
|
||||||
|
narg="$(printf "%s\n" "$args" | sed "$((i+1))q;d")"
|
||||||
|
|
||||||
|
case "$arg" in
|
||||||
|
-x|-run|--run) remove_arg "$arg" && function=run ;;
|
||||||
|
-f|-fm|--fm) remove_arg "$arg"
|
||||||
|
[ -d "$narg" ] && dir="$narg" && remove_arg "$narg"
|
||||||
|
function=fm ;;
|
||||||
|
-h|--help) remove_arg "$arg" && function=help ;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
[ "$argc" = "$i" ] && break
|
||||||
|
done
|
||||||
|
}
|
||||||
|
|
||||||
main() {
|
main() {
|
||||||
check "$@"
|
read_args "$@"
|
||||||
print_config "$@"
|
check "$args"
|
||||||
parse "$@"
|
print_config "$args"
|
||||||
exec_cmd "$@"
|
|
||||||
|
RUNLAUNCHER_ARGS="${RUNLAUNCHER_ARGS:- --insert --hist-file $HISTORY $args}"
|
||||||
|
|
||||||
|
# $PATH listing
|
||||||
|
case "$function" in
|
||||||
|
"run")
|
||||||
|
parse "$args"
|
||||||
|
exec_cmd "$args"
|
||||||
|
;;
|
||||||
|
"fm") printf "Directory: %s\n" "$dir"
|
||||||
|
;;
|
||||||
|
"help")
|
||||||
|
print_cli_help
|
||||||
|
exit 0
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
printf "Undefined function: '%s'\n" "$function"
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
}
|
}
|
||||||
|
|
||||||
main "$@"
|
main "$@"
|
||||||
|
|
3
spmenu.1
3
spmenu.1
|
@ -698,6 +698,9 @@ For example:
|
||||||
Prepending \f[V]#\f[R] will spawn it in a terminal instead of just a
|
Prepending \f[V]#\f[R] will spawn it in a terminal instead of just a
|
||||||
shell.
|
shell.
|
||||||
.IP \[bu] 2
|
.IP \[bu] 2
|
||||||
|
Prepending \f[V]?\f[R] will run the command in a function, most of the
|
||||||
|
time used to display the man page.
|
||||||
|
.IP \[bu] 2
|
||||||
Prepending \f[V]magnet\f[R] will open a magnet link in $TORRENT
|
Prepending \f[V]magnet\f[R] will open a magnet link in $TORRENT
|
||||||
.IP \[bu] 2
|
.IP \[bu] 2
|
||||||
Prepending \f[V]www\f[R] will open a page in $BROWSER
|
Prepending \f[V]www\f[R] will open a page in $BROWSER
|
||||||
|
|
Loading…
Reference in a new issue