fix merge-probs
This commit is contained in:
parent
1a4e68858d
commit
a15a2e2073
@ -1,77 +0,0 @@
|
||||
#!/usr/bin/env python3
|
||||
|
||||
import time
|
||||
import sys
|
||||
|
||||
import gi
|
||||
gi.require_version('Playerctl', '1.0')
|
||||
from gi.repository import Playerctl, GLib
|
||||
|
||||
MUSIC_ICON = '#1'
|
||||
PAUSE_ICON = '#2'
|
||||
PLAYER_CLOSED_ICON = '#3'
|
||||
|
||||
|
||||
class PlayerStatus:
|
||||
def __init__(self):
|
||||
self._player = None
|
||||
self._icon = PAUSE_ICON
|
||||
|
||||
self._last_artist = None
|
||||
self._last_title = None
|
||||
|
||||
self._last_status = ''
|
||||
|
||||
def show(self):
|
||||
self._init_player()
|
||||
|
||||
# Wait for events
|
||||
main = GLib.MainLoop()
|
||||
main.run()
|
||||
|
||||
def _init_player(self):
|
||||
while True:
|
||||
try:
|
||||
self._player = Playerctl.Player()
|
||||
self._player.on('metadata', self._on_metadata)
|
||||
self._player.on('play', self._on_play)
|
||||
self._player.on('pause', self._on_pause)
|
||||
self._player.on('exit', self._on_exit)
|
||||
break
|
||||
|
||||
except:
|
||||
self._print_flush(PLAYER_CLOSED_ICON)
|
||||
time.sleep(2)
|
||||
|
||||
def _on_metadata(self, player, e):
|
||||
if 'xesam:artist' in e.keys() and 'xesam:title' in e.keys():
|
||||
self._artist = e['xesam:artist'][0]
|
||||
self._title = e['xesam:title']
|
||||
self._print_song()
|
||||
|
||||
def _on_play(self, player):
|
||||
self._icon = MUSIC_ICON
|
||||
self._print_song()
|
||||
|
||||
def _on_pause(self, player):
|
||||
self._icon = PAUSE_ICON
|
||||
self._print_song()
|
||||
|
||||
def _on_exit(self, player):
|
||||
self._init_player()
|
||||
|
||||
def _print_song(self):
|
||||
self._print_flush(
|
||||
'{} {} - {}'.format(self._icon, self._artist, self._title))
|
||||
|
||||
"""
|
||||
Seems to assure print() actually prints when no terminal is connected
|
||||
"""
|
||||
|
||||
def _print_flush(self, status, **kwargs):
|
||||
if status != self._last_status:
|
||||
print(status, **kwargs)
|
||||
sys.stdout.flush()
|
||||
self._last_status = status
|
||||
|
||||
PlayerStatus().show()
|
@ -9,6 +9,7 @@ from gi.repository import Playerctl, GLib
|
||||
|
||||
MUSIC_ICON = '#1'
|
||||
PAUSE_ICON = '#2'
|
||||
PLAYER_CLOSED_ICON = '#3'
|
||||
|
||||
|
||||
class PlayerStatus:
|
||||
@ -39,7 +40,7 @@ class PlayerStatus:
|
||||
break
|
||||
|
||||
except:
|
||||
self._print_flush('')
|
||||
self._print_flush(PLAYER_CLOSED_ICON)
|
||||
time.sleep(2)
|
||||
|
||||
def _on_metadata(self, player, e):
|
||||
|
@ -1,56 +0,0 @@
|
||||
#!/bin/sh
|
||||
|
||||
sink=0
|
||||
|
||||
volume_up() {
|
||||
pactl set-sink-volume $sink +1%
|
||||
}
|
||||
|
||||
volume_down() {
|
||||
pactl set-sink-volume $sink -1%
|
||||
}
|
||||
|
||||
volume_mute() {
|
||||
pactl set-sink-mute $sink toggle
|
||||
}
|
||||
|
||||
volume_print() {
|
||||
muted=$(pamixer --sink $sink --get-mute)
|
||||
|
||||
if [ "$muted" = true ]; then
|
||||
echo "#1 --"
|
||||
else
|
||||
volume=$(pamixer --sink $sink --get-volume)
|
||||
|
||||
if [ "$volume" -lt 50 ]; then
|
||||
echo "#2 $volume %"
|
||||
else
|
||||
echo "#3 $volume %"
|
||||
fi
|
||||
fi
|
||||
}
|
||||
|
||||
listen() {
|
||||
volume_print
|
||||
|
||||
pactl subscribe | while read -r event; do
|
||||
if echo "$event" | grep -q "#$sink"; then
|
||||
volume_print
|
||||
fi
|
||||
done
|
||||
}
|
||||
|
||||
case "$1" in
|
||||
--up)
|
||||
volume_up
|
||||
;;
|
||||
--down)
|
||||
volume_down
|
||||
;;
|
||||
--mute)
|
||||
volume_mute
|
||||
;;
|
||||
*)
|
||||
listen
|
||||
;;
|
||||
esac
|
Loading…
x
Reference in New Issue
Block a user