mirror of
https://github.com/librespot-org/librespot.git
synced 2025-10-03 09:49:31 +02:00
refactor: Introduce SpotifyUri struct (#1538)
* refactor: Introduce SpotifyUri struct Contributes to #1266 Introduces a new `SpotifyUri` struct which is layered on top of the existing `SpotifyId`, but has the capability to support URIs that do not confirm to the canonical base62 encoded format. This allows it to describe URIs like `spotify:local`, `spotify:genre` and others that `SpotifyId` cannot represent. Changed the internal player state to use these URIs as much as possible, such that the player could in the future accept a URI of the type `spotify:local`, as a means of laying the groundwork for local file support. * fix: Don't pass unknown URIs from deprecated player methods * refactor: remove SpotifyUri::to_base16 This should be deprecated for the same reason to_base62 is, and could unpredictably throw errors -- consumers should match on the inner ID if they need a base62 representation and handle failure appropriately * refactor: Store original data in SpotifyUri::Unknown Instead of assuming Unknown has a u128 SpotifyId, store the original data and type that we failed to parse. * refactor: Remove SpotifyItemType * refactor: Address review feedback * test: Add more SpotifyUri tests * chore: Correctly mark changes as breaking in CHANGELOG.md * refactor: Respond to review feedback * chore: Changelog updates
This commit is contained in:
parent
0e5531ff54
commit
df5f957bdd
23 changed files with 937 additions and 625 deletions
|
@ -1,5 +1,5 @@
|
|||
use crate::{
|
||||
core::{Error, SpotifyId},
|
||||
core::{Error, SpotifyId, SpotifyUri},
|
||||
protocol::{
|
||||
context::Context,
|
||||
context_page::ContextPage,
|
||||
|
@ -449,8 +449,10 @@ impl ConnectState {
|
|||
(Some(uri), _) if uri.contains(['?', '%']) => {
|
||||
Err(StateError::InvalidTrackUri(Some(uri.clone())))?
|
||||
}
|
||||
(Some(uri), _) if !uri.is_empty() => SpotifyId::from_uri(uri)?,
|
||||
(_, Some(gid)) if !gid.is_empty() => SpotifyId::from_raw(gid)?,
|
||||
(Some(uri), _) if !uri.is_empty() => SpotifyUri::from_uri(uri)?,
|
||||
(_, Some(gid)) if !gid.is_empty() => SpotifyUri::Track {
|
||||
id: SpotifyId::from_raw(gid)?,
|
||||
},
|
||||
_ => Err(StateError::InvalidTrackUri(None))?,
|
||||
};
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue