Merge pull request #2958 from JonnyTischbein/mediaplayer-exclude

pull/2965/merge
Alexis Rouillard 2024-02-24 00:06:03 +01:00 committed by GitHub
commit 601af3de81
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 10 additions and 2 deletions

View File

@ -23,7 +23,7 @@ def signal_handler(sig, frame):
class PlayerManager: class PlayerManager:
def __init__(self, selected_player=None): def __init__(self, selected_player=None, excluded_player=[]):
self.manager = Playerctl.PlayerManager() self.manager = Playerctl.PlayerManager()
self.loop = GLib.MainLoop() self.loop = GLib.MainLoop()
self.manager.connect( self.manager.connect(
@ -35,11 +35,14 @@ class PlayerManager:
signal.signal(signal.SIGTERM, signal_handler) signal.signal(signal.SIGTERM, signal_handler)
signal.signal(signal.SIGPIPE, signal.SIG_DFL) signal.signal(signal.SIGPIPE, signal.SIG_DFL)
self.selected_player = selected_player self.selected_player = selected_player
self.excluded_player = excluded_player.split(',') if excluded_player else []
self.init_players() self.init_players()
def init_players(self): def init_players(self):
for player in self.manager.props.player_names: for player in self.manager.props.player_names:
if player.name in self.excluded_player:
continue
if self.selected_player is not None and self.selected_player != player.name: if self.selected_player is not None and self.selected_player != player.name:
logger.debug(f"{player.name} is not the filtered player, skipping it") logger.debug(f"{player.name} is not the filtered player, skipping it")
continue continue
@ -149,6 +152,8 @@ def parse_arguments():
# Increase verbosity with every occurrence of -v # Increase verbosity with every occurrence of -v
parser.add_argument("-v", "--verbose", action="count", default=0) parser.add_argument("-v", "--verbose", action="count", default=0)
parser.add_argument("-x", "--exclude", "- Comma-separated list of excluded player")
# Define for which player we"re listening # Define for which player we"re listening
parser.add_argument("--player") parser.add_argument("--player")
@ -174,7 +179,10 @@ def main():
logger.info("Creating player manager") logger.info("Creating player manager")
if arguments.player: if arguments.player:
logger.info(f"Filtering for player: {arguments.player}") logger.info(f"Filtering for player: {arguments.player}")
player = PlayerManager(arguments.player) if arguments.exclude:
logger.info(f"Exclude player {arguments.exclude}")
player = PlayerManager(arguments.player, arguments.exclude)
player.run() player.run()