mirror of
https://github.com/librespot-org/librespot.git
synced 2024-12-18 17:11:53 +00:00
Fix #173 (a track cannot be played with librespot)
Some tracks might have several `allowed` fields, librespot assumes that all fields must match, otherwise track cannot be played. This change collects all `allowed` and `forbidden` lists, then does the final check on whole lists at once.
This commit is contained in:
parent
6f24e3b731
commit
4a17a15a82
1 changed files with 13 additions and 7 deletions
|
@ -16,13 +16,19 @@ fn countrylist_contains(list: &str, country: &str) -> bool {
|
|||
fn parse_restrictions<'s, I>(restrictions: I, country: &str, catalogue: &str) -> bool
|
||||
where I: IntoIterator<Item = &'s protocol::metadata::Restriction>
|
||||
{
|
||||
restrictions.into_iter()
|
||||
.filter(|r| r.get_catalogue_str().contains(&catalogue.to_owned()))
|
||||
.all(|r| {
|
||||
!countrylist_contains(r.get_countries_forbidden(), country) &&
|
||||
(!r.has_countries_allowed() ||
|
||||
countrylist_contains(r.get_countries_allowed(), country))
|
||||
})
|
||||
let mut forbidden = "".to_string();
|
||||
let mut allowed = "".to_string();
|
||||
let rs = restrictions.into_iter().filter(|r|
|
||||
r.get_catalogue_str().contains(&catalogue.to_owned())
|
||||
);
|
||||
|
||||
for r in rs {
|
||||
forbidden.push_str(r.get_countries_forbidden());
|
||||
allowed.push_str(r.get_countries_allowed());
|
||||
}
|
||||
|
||||
(forbidden == "" || !countrylist_contains(forbidden.as_str(), country)) &&
|
||||
(allowed == "" || countrylist_contains(allowed.as_str(), country))
|
||||
}
|
||||
|
||||
pub trait MetadataTrait : Send + 'static {
|
||||
|
|
Loading…
Reference in a new issue