use 'f""' syntax

This commit is contained in:
Martin Wagner 2021-07-24 12:13:09 +02:00
parent c520e43bd4
commit 95cdf2e686

View File

@ -377,15 +377,15 @@ class MPRISInterface: # TODO emit Seeked if needed
self._metadata={} self._metadata={}
for tag, xesam_tag in (("album","album"),("title","title"),("date","contentCreated")): for tag, xesam_tag in (("album","album"),("title","title"),("date","contentCreated")):
if tag in song: if tag in song:
self._metadata["xesam:{}".format(xesam_tag)]=GLib.Variant("s", song[tag][0]) self._metadata[f"xesam:{xesam_tag}"]=GLib.Variant("s", song[tag][0])
for tag, xesam_tag in (("track","trackNumber"),("disc","discNumber")): for tag, xesam_tag in (("track","trackNumber"),("disc","discNumber")):
if tag in song: if tag in song:
self._metadata["xesam:{}".format(xesam_tag)]=GLib.Variant("i", int(song[tag][0])) self._metadata[f"xesam:{xesam_tag}"]=GLib.Variant("i", int(song[tag][0]))
for tag, xesam_tag in (("albumartist","albumArtist"),("artist","artist"),("composer","composer"),("genre","genre")): for tag, xesam_tag in (("albumartist","albumArtist"),("artist","artist"),("composer","composer"),("genre","genre")):
if tag in song: if tag in song:
self._metadata["xesam:{}".format(xesam_tag)]=GLib.Variant("as", song[tag]) self._metadata[f"xesam:{xesam_tag}"]=GLib.Variant("as", song[tag])
if "id" in song: if "id" in song:
self._metadata["mpris:trackid"]=GLib.Variant("o", self._MPRIS_PATH+"/Track/{}".format(song["id"][0])) self._metadata["mpris:trackid"]=GLib.Variant("o", f"{self._MPRIS_PATH}/Track/{song['id'][0]}")
if "duration" in song: if "duration" in song:
self._metadata["mpris:length"]=GLib.Variant("x", float(song["duration"][0])*1000000) self._metadata["mpris:length"]=GLib.Variant("x", float(song["duration"][0])*1000000)
if "file" in song: if "file" in song:
@ -394,10 +394,10 @@ class MPRISInterface: # TODO emit Seeked if needed
self._metadata["xesam:url"]=GLib.Variant("s", song_file) self._metadata["xesam:url"]=GLib.Variant("s", song_file)
else: else:
lib_path=self._settings.get_value("paths")[self._settings.get_int("active-profile")] lib_path=self._settings.get_value("paths")[self._settings.get_int("active-profile")]
self._metadata["xesam:url"]=GLib.Variant("s", "file://{}".format(os.path.join(lib_path, song_file))) self._metadata["xesam:url"]=GLib.Variant("s", f"file://{os.path.join(lib_path, song_file)}")
cover_path=self._client.get_cover_path(mpd_meta) cover_path=self._client.get_cover_path(mpd_meta)
if cover_path is not None: if cover_path is not None:
self._metadata["mpris:artUrl"]=GLib.Variant("s", "file://{}".format(cover_path)) self._metadata["mpris:artUrl"]=GLib.Variant("s", f"file://{cover_path}")
def _update_property(self, interface_name, prop): def _update_property(self, interface_name, prop):
getter, setter=self._prop_mapping[interface_name][prop] getter, setter=self._prop_mapping[interface_name][prop]
@ -446,7 +446,7 @@ class ClientHelper():
delta=datetime.timedelta(seconds=seconds) delta=datetime.timedelta(seconds=seconds)
if delta.days > 0: if delta.days > 0:
days=ngettext("{days} day", "{days} days", delta.days).format(days=delta.days) days=ngettext("{days} day", "{days} days", delta.days).format(days=delta.days)
time_string=days+", "+str(datetime.timedelta(seconds=delta.seconds)) time_string=f"{days}, {datetime.timedelta(seconds=delta.seconds)}"
else: else:
time_string=str(delta).lstrip("0").lstrip(":") time_string=str(delta).lstrip("0").lstrip(":")
return time_string.replace(":", "") # use 'ratio' as delimiter return time_string.replace(":", "") # use 'ratio' as delimiter
@ -464,8 +464,8 @@ class ClientHelper():
freq=locale.str(int(samplerate)/1000) freq=locale.str(int(samplerate)/1000)
except: except:
freq=samplerate freq=samplerate
channels=ngettext("{channels} channel", "{channels} channels", int_chan).format(channels=channels) channels=ngettext("{channels} channel", "{channels} channels", int_chan).format(channels=int_chan)
return "{} kHz • {} bit • {}".format(freq, bits, channels) return f"{freq} kHz • {bits} bit • {channels}"
def song_to_str_dict(song): # converts tags with multiple values to comma separated strings def song_to_str_dict(song): # converts tags with multiple values to comma separated strings
return_song={} return_song={}
@ -1116,7 +1116,7 @@ class ProfileSettings(Gtk.Grid):
def _on_add_button_clicked(self, *args): def _on_add_button_clicked(self, *args):
model=self._profiles_combo.get_model() model=self._profiles_combo.get_model()
self._settings.array_append("as", "profiles", "new profile ({})".format(len(model))) self._settings.array_append("as", "profiles", f"new profile ({len(model)})")
self._settings.array_append("as", "hosts", "localhost") self._settings.array_append("as", "hosts", "localhost")
self._settings.array_append("ai", "ports", 6600) self._settings.array_append("ai", "ports", 6600)
self._settings.array_append("as", "passwords", "") self._settings.array_append("as", "passwords", "")
@ -1789,9 +1789,9 @@ class AlbumPopover(Gtk.Popover):
pass pass
artist=(", ".join(song["artist"])) artist=(", ".join(song["artist"]))
if artist == album_artist or artist == "": if artist == album_artist or artist == "":
title_artist="<b>{}</b>".format(title) title_artist=f"<b>{title}</b>"
else: else:
title_artist="<b>{}</b> • {}".format(title, artist) title_artist=f"<b>{titel}</b> • {artist}"
title_artist=title_artist.replace("&", "&amp;") title_artist=title_artist.replace("&", "&amp;")
self._store.append([track, title_artist, song["human_duration"][0], song["file"][0], title]) self._store.append([track, title_artist, song["human_duration"][0], song["file"][0], title])
self._songs_view.set_model(self._store) self._songs_view.set_model(self._store)
@ -2387,10 +2387,10 @@ class AlbumWindow(FocusFrame):
number=length, duration=duration) number=length, duration=duration)
# album label # album label
if album["year"] == "": if album["year"] == "":
display_label="<b>{}</b>".format(album["album"]) display_label=f"<b>{album['album']}</b>"
else: else:
display_label="<b>{}</b> ({})".format(album["album"], album["year"]) display_label=f"<b>{album['album']}</b> ({album['year']})"
display_label_artist=display_label+"\n"+album["artist"] display_label_artist=f"{display_label}\n{album['artist']}"
display_label=display_label.replace("&", "&amp;") display_label=display_label.replace("&", "&amp;")
display_label_artist=display_label_artist.replace("&", "&amp;") display_label_artist=display_label_artist.replace("&", "&amp;")
# add album # add album
@ -2699,7 +2699,7 @@ class LyricsWindow(FocusFrame):
for char1, char2 in replaces: for char1, char2 in replaces:
title=title.replace(char1, char2) title=title.replace(char1, char2)
artist=artist.replace(char1, char2) artist=artist.replace(char1, char2)
req=requests.get("https://www.letras.mus.br/winamp.php?musica={0}&artista={1}".format(title,artist)) req=requests.get(f"https://www.letras.mus.br/winamp.php?musica={title}&artista={artist}")
soup=BeautifulSoup(req.text, "html.parser") soup=BeautifulSoup(req.text, "html.parser")
soup=soup.find(id="letra-cnt") soup=soup.find(id="letra-cnt")
if soup is None: if soup is None:
@ -3406,7 +3406,7 @@ class AudioFormat(Gtk.Box):
if audio_format is None: if audio_format is None:
self._format_label.set_markup("<small> </small>") self._format_label.set_markup("<small> </small>")
else: else:
self._format_label.set_markup("<small>"+ClientHelper.convert_audio_format(audio_format)+"</small>") self._format_label.set_markup(f"<small>{ClientHelper.convert_audio_format(audio_format)}</small>")
def _on_bitrate(self, emitter, brate): def _on_bitrate(self, emitter, brate):
# handle unknown bitrates: https://github.com/MusicPlayerDaemon/MPD/issues/428#issuecomment-442430365 # handle unknown bitrates: https://github.com/MusicPlayerDaemon/MPD/issues/428#issuecomment-442430365
@ -3535,7 +3535,7 @@ class OutputPopover(Gtk.Popover):
# widgets # widgets
box=Gtk.Box(orientation=Gtk.Orientation.VERTICAL, border_width=9) box=Gtk.Box(orientation=Gtk.Orientation.VERTICAL, border_width=9)
for output in self._client.outputs(): for output in self._client.outputs():
button=Gtk.ModelButton(label="{} ({})".format(output["outputname"], output["plugin"]), role=Gtk.ButtonRole.CHECK) button=Gtk.ModelButton(label=f"{output['outputname']} ({output['plugin']})", role=Gtk.ButtonRole.CHECK)
button.get_child().set_property("xalign", 0) button.get_child().set_property("xalign", 0)
if output["outputenabled"] == "1": if output["outputenabled"] == "1":
button.set_property("active", True) button.set_property("active", True)
@ -3994,12 +3994,12 @@ class MainWindow(Gtk.ApplicationWindow):
if song["date"] == "": if song["date"] == "":
date="" date=""
else: else:
date=" ("+song["date"]+")" date=f" ({song['date']})"
if self._use_csd: if self._use_csd:
self.set_title(song["title"]+" • "+song["artist"]) self.set_title(f"{song['title']} • {song['artist']}")
self._header_bar.set_subtitle(song["album"]+date) self._header_bar.set_subtitle(song["album"]+date)
else: else:
self.set_title(song["title"]+" • "+song["artist"]+" • "+song["album"]+date) self.set_title(f"{song['title']} • {song['artist']} • {song['album']}{date}")
if self._settings.get_boolean("send-notify"): if self._settings.get_boolean("send-notify"):
if not self.is_active() and self._client.status()["state"] == "play": if not self.is_active() and self._client.status()["state"] == "play":
self._notify.close() # clear previous notifications self._notify.close() # clear previous notifications