librespot-python/librespot/player/codecs/VorbisOnlyAudioQuality.py

45 lines
1.5 KiB
Python
Raw Normal View History

2021-02-24 00:46:59 +01:00
from __future__ import annotations
import logging
2021-04-24 12:17:02 +02:00
import typing
2021-02-24 00:46:59 +01:00
2021-05-22 03:26:35 +02:00
from librespot.audio.decoders.AudioQuality import AudioQuality
2021-02-24 00:46:59 +01:00
from librespot.audio.format.AudioQualityPicker import AudioQualityPicker
from librespot.audio.format.SuperAudioFormat import SuperAudioFormat
from librespot.proto import Metadata
class VorbisOnlyAudioQuality(AudioQualityPicker):
_LOGGER: logging = logging.getLogger(__name__)
preferred: AudioQuality
def __init__(self, preferred: AudioQuality):
self.preferred = preferred
@staticmethod
2021-04-24 12:17:02 +02:00
def get_vorbis_file(files: typing.List[Metadata.AudioFile]):
2021-02-24 00:46:59 +01:00
for file in files:
2021-05-22 03:26:33 +02:00
if (
hasattr(file, "format")
and SuperAudioFormat.get(file.format) == SuperAudioFormat.VORBIS
):
2021-02-24 00:46:59 +01:00
return file
return None
2021-04-24 12:17:02 +02:00
def get_file(self, files: typing.List[Metadata.AudioFile]):
2021-05-22 03:26:33 +02:00
matches: typing.List[Metadata.AudioFile] = self.preferred.get_matches(files)
vorbis: Metadata.AudioFile = VorbisOnlyAudioQuality.get_vorbis_file(matches)
2021-02-24 00:46:59 +01:00
if vorbis is None:
2021-05-22 03:26:33 +02:00
vorbis: Metadata.AudioFile = VorbisOnlyAudioQuality.get_vorbis_file(files)
2021-02-24 00:46:59 +01:00
if vorbis is not None:
self._LOGGER.warning(
"Using {} because preferred {} couldn't be found.".format(
2021-05-22 03:26:33 +02:00
vorbis.format, self.preferred
)
)
2021-02-24 00:46:59 +01:00
else:
2021-05-22 03:26:33 +02:00
self._LOGGER.fatal("Couldn't find any Vorbis file, available: {}")
2021-02-24 00:46:59 +01:00
return vorbis