dmenu_multicmd: a smarter replacement for dmenu_displays
This commit is contained in:
parent
30b50a204a
commit
6c778f9d1a
2 changed files with 52 additions and 17 deletions
|
@ -1,17 +0,0 @@
|
||||||
#!/usr/bin/env zsh
|
|
||||||
if [[ -r $HOME/.displayrc ]]; then
|
|
||||||
. $HOME/.displayrc
|
|
||||||
else
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
selection=$(printf "%s\n" $VARIANTS|/usr/bin/dmenu -p display "$@")
|
|
||||||
case $selection in
|
|
||||||
($VARIANTS[1]) /usr/bin/xrandr --output $EXT --off --output $BUILTIN $BUILTIN_MODE[@];;
|
|
||||||
($VARIANTS[2]) /usr/bin/xrandr --output $BUILTIN --off --output $EXT $EXT_MODE[@];;
|
|
||||||
($VARIANTS[3]) /usr/bin/xrandr --output $BUILTIN $BUILTIN_MODE[@] --auto --output $EXT $EXT_MODE[@] --right-of $BUILTIN;;
|
|
||||||
(*) exit 1 ;;
|
|
||||||
esac
|
|
||||||
/usr/bin/feh --bg-${WP_MODE-scale} $WALLPAPER
|
|
||||||
/usr/bin/sleep 1
|
|
||||||
exit 0
|
|
52
dmenu_multicmd
Executable file
52
dmenu_multicmd
Executable file
|
@ -0,0 +1,52 @@
|
||||||
|
#!/usr/bin/env python3
|
||||||
|
#pylint: disable=C0111
|
||||||
|
|
||||||
|
import os
|
||||||
|
import subprocess
|
||||||
|
import sys
|
||||||
|
import yaml
|
||||||
|
|
||||||
|
|
||||||
|
CONFIG_PATH = os.path.join(os.environ['HOME'], '.displayrc.yaml')
|
||||||
|
|
||||||
|
|
||||||
|
def run_cmd(cmd, stdin=subprocess.PIPE, data=None):
|
||||||
|
proc = subprocess.Popen(
|
||||||
|
cmd, stdout=subprocess.PIPE, stderr=subprocess.PIPE, stdin=stdin
|
||||||
|
)
|
||||||
|
stdout, stderr = (i.strip() for i in proc.communicate(data))
|
||||||
|
if proc.returncode:
|
||||||
|
err_msg = ['ERROR (' + str(proc.returncode) + '): ' + ' '.join(cmd)]
|
||||||
|
if stdout:
|
||||||
|
err_msg.append('out:\n' + stdout.decode('UTF-8'))
|
||||||
|
if stderr:
|
||||||
|
err_msg.append('err:\n' + stderr.decode('UTF-8'))
|
||||||
|
sys.stderr.write('\n'.join(err_msg) + '\n')
|
||||||
|
return stdout
|
||||||
|
|
||||||
|
|
||||||
|
def run_multicmd(cmds):
|
||||||
|
for cmd in cmds:
|
||||||
|
run_cmd(cmds[cmd])
|
||||||
|
|
||||||
|
|
||||||
|
def main():
|
||||||
|
config_path = sys.argv[1]
|
||||||
|
with open(config_path, mode='r') as config:
|
||||||
|
conf = yaml.load(config.read())
|
||||||
|
dmenu_cmd = ['/usr/bin/dmenu', '-p', conf.get('name', 'N/A')] + sys.argv[2:]
|
||||||
|
dmenu_opt = '\n'.join(conf['multicmd']).encode()
|
||||||
|
selection = run_cmd(dmenu_cmd, data=dmenu_opt).decode('UTF-8')
|
||||||
|
if not selection in conf['multicmd']:
|
||||||
|
sys.exit(1)
|
||||||
|
|
||||||
|
if 'cmd_pre' in conf:
|
||||||
|
run_multicmd(conf['cmd_pre'])
|
||||||
|
|
||||||
|
run_multicmd(conf['multicmd'][selection])
|
||||||
|
|
||||||
|
if 'cmd_post' in conf:
|
||||||
|
run_multicmd(conf['cmd_post'])
|
||||||
|
|
||||||
|
if __name__ == '__main__':
|
||||||
|
main()
|
Loading…
Reference in a new issue