Compare commits

..

No commits in common. "exceptional_errors" and "master" have entirely different histories.

View File

@ -29,7 +29,6 @@
###
import liblistenbrainz
from liblistenbrainz.errors import ListenBrainzAPIException
from supybot import utils, plugins, ircutils, callbacks
from supybot.commands import *
@ -44,7 +43,8 @@ class ListenBrainz(callbacks.Plugin):
threaded = True
def __init__(self, irc):
super().__init__(irc)
self.__parent = super(ListenBrainz, self)
self.__parent.__init__(irc)
self.client = liblistenbrainz.ListenBrainz()
self.DISPLAY_LIMIT = 3
@ -54,16 +54,8 @@ class ListenBrainz(callbacks.Plugin):
Announces the track currently being played by <user>.
"""
try:
listen = self.client.get_playing_now(user)
except ListenBrainzAPIException as e:
irc.error(f"ListenBrainz API Error fetching listens for {user}: {e}", Raise=True)
return
except Exception as e:
irc.error(f"An unexpected error occurred: {e}", Raise=True)
return
if not listen:
listen = self.client.get_playing_now(user)
if listen is None:
response = f"{user} doen't seem to be listening to anything"
else:
response = (
@ -80,16 +72,8 @@ class ListenBrainz(callbacks.Plugin):
Announces total number of tracks scrobbled by <user>
"""
try:
count = self.client.get_user_listen_count(user)
except ListenBrainzAPIException as e:
irc.error(f"ListenBrainz API Error fetching listens for {user}: {e}", Raise=True)
return
except Exception as e:
irc.error(f"An unexpected error occurred: {e}", Raise=True)
return
if not count:
count = self.client.get_user_listen_count(user)
if count is None:
response = "Nothing recorded"
else:
response = (f"{user} has recorded listening to {count} tracks")
@ -105,9 +89,7 @@ class ListenBrainz(callbacks.Plugin):
try:
data = self.client.get_user_recordings(user)
payload = data.get("payload", {})
except ListenBrainzAPIException as e:
irc.error(f"ListenBrainz API Error fetching listens for {user}: {e}", Raise=True)
return
except Exception as e:
irc.error(f"An unexpected error occurred: {e}", Raise=True)
return
@ -118,7 +100,7 @@ class ListenBrainz(callbacks.Plugin):
irc.reply(f"{user} has no recorded tracks.")
return
top_tracks = recordings[:self.DISPLAY_LIMIT]
top_tracks = recordings[:DISPLAY_LIMIT]
header = f"{user}'s Top {len(top_tracks)} Tracks (Total unique tracks: {total_tracks:,}):"
irc.reply(header)
for i, track in enumerate(top_tracks):
@ -147,9 +129,6 @@ class ListenBrainz(callbacks.Plugin):
try:
data = self.client.get_user_releases(user)
payload = data.get("payload", {})
except ListenBrainzAPIException as e:
irc.error(f"ListenBrainz API Error fetching listens for {user}: {e}", Raise=True)
return
except Exception as e:
irc.error(f"An unexpected error occurred: {e}", Raise=True)
return
@ -161,7 +140,7 @@ class ListenBrainz(callbacks.Plugin):
irc.reply(f"{user} has no recorded releases.")
return
top_releases = releases[:self.DISPLAY_LIMIT]
top_releases = releases[:DISPLAY_LIMIT]
header = f"{user}'s Top {len(top_releases)} Releases (Total unique releases: {total_albums:,}):"
irc.reply(header)