Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Initial id type proposal #161

Merged
merged 61 commits into from
Mar 7, 2021
Merged
Changes from all commits
Commits
Show all changes
61 commits
Select commit Hold shift + click to select a range
fcd9ace
initial id type proposal
kstep Nov 29, 2020
58e4c19
use strip_prefix() (clippy advice)
kstep Nov 29, 2020
c3e722e
add try_join() and map_try_join()
kstep Nov 29, 2020
24a61dc
remove itertools
kstep Dec 1, 2020
e79e9bb
rewrite try join
kstep Dec 1, 2020
f0d26bb
cleanup
kstep Dec 1, 2020
8155bc4
from for iderror
kstep Dec 1, 2020
158eb0b
fix try_join/map_try_join
kstep Dec 2, 2020
59eab11
remove map_try_join
kstep Dec 2, 2020
c4d0ef8
get show, shows, episodes methods use &str instead of String and vali…
kstep Dec 3, 2020
b74787e
update changelog
kstep Dec 3, 2020
3672eb3
use Display instead of AsRefStr for Type, FromStr for Type
kstep Dec 17, 2020
a21d3bb
rewrite from_uri()
kstep Dec 17, 2020
88ab887
add Id type docs
kstep Dec 17, 2020
3c3f3b2
use Id type for arguments (TOOD: tests)
kstep Dec 17, 2020
2d62cc2
update tests
kstep Dec 17, 2020
2ee414e
Merge branch 'master' into uri-type
kstep Dec 17, 2020
9f2bb10
fix lifetimes
kstep Dec 17, 2020
5cfdcc5
update examples
kstep Dec 17, 2020
9967f35
add IdError docs
kstep Dec 17, 2020
afe67f7
add idbuf owning type, use type-safe id parsing
kstep Dec 24, 2020
ae250f3
update docs, FromStr for IdBuf
kstep Dec 24, 2020
9ed6566
fix intermediate collect
kstep Dec 24, 2020
a5d6242
add TrackIdOrPos type, update docs
kstep Dec 24, 2020
ce55680
fix playlist_remove_specific_occurences_of_track method
kstep Dec 24, 2020
c574e06
remove ClientError::IdError error variant: everything's type-safe now
kstep Dec 24, 2020
c22c9a6
use iterator to build query
kstep Dec 24, 2020
f055e96
move id types into a idtypes module
kstep Dec 24, 2020
1197dba
simplify from_uri()
kstep Dec 24, 2020
e67126c
helper id type aliases
kstep Dec 24, 2020
e4dc911
use id types aliases
kstep Dec 24, 2020
b31d600
add owned aliases for ids
kstep Dec 25, 2020
458e729
more methods and better conversions for idbuf/id
kstep Dec 25, 2020
77e1d47
show/episode methods
kstep Dec 29, 2020
c8776fe
user methods use id types
kstep Dec 29, 2020
375f181
remove Join trait, update tests, playable id type marker
kstep Dec 29, 2020
d132280
lifetime fix
kstep Dec 29, 2020
e5481a8
make start_playback type-safe
kstep Dec 29, 2020
7281287
split start_playback method into two
kstep Dec 29, 2020
603ecc9
implement serialize/deserialize for id types
kstep Jan 12, 2021
0fe650f
simplify offset type and make it enum
kstep Jan 12, 2021
8587edf
simplify join_ids
kstep Jan 12, 2021
4efbe0c
make id types unsized
kstep Jan 13, 2021
8744b20
replace transmute with typecast
kstep Jan 13, 2021
d446895
Merge branch 'master' into uri-type
kstep Feb 26, 2021
51750c4
use macro to reduce boilerplate
kstep Feb 26, 2021
5069e08
fmt
kstep Feb 26, 2021
19b3a3d
reformat comments
kstep Feb 26, 2021
ebcb2d6
updated changelog
kstep Feb 26, 2021
5d8f9d2
reformat comments
kstep Feb 28, 2021
9e4adbd
type-safer offset ctor
kstep Feb 28, 2021
e241820
typo fix, deref for idbuf
kstep Feb 28, 2021
2403a68
more comments format
kstep Feb 28, 2021
6a56b97
fix test
kstep Feb 28, 2021
1174f04
fmt
kstep Feb 28, 2021
8ba5fbc
even more type safe offset
kstep Feb 28, 2021
81394ca
fix offset position type
kstep Mar 2, 2021
15e0c23
update docs and changelog
kstep Mar 4, 2021
0c5f702
fix docs typos
kstep Mar 7, 2021
11fc5b0
remove unsafe code
kstep Mar 7, 2021
141e6e0
better fix
kstep Mar 7, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
15 changes: 12 additions & 3 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -13,6 +13,7 @@ If we missed any change or there's something you'd like to discuss about this ve
+ Remove `itertools` dependency by using the standard library.
+ Remove `rand` in place of `getrandom` to [reduce total dependencies and compile times](https://github.com/ramsayleung/rspotify/issues/108#issuecomment-673587185).
+ Cleanup, reduced repetitive code and boilerplate internally in several places ([#117](https://github.com/ramsayleung/rspotify/pull/117), [#113](https://github.com/ramsayleung/rspotify/pull/113), [#107](https://github.com/ramsayleung/rspotify/pull/107), [#106](https://github.com/ramsayleung/rspotify/pull/106)).
+ Added internal zero-copy type for Spotify ids, reduced number of allocations/clones ([#161](https://github.com/ramsayleung/rspotify/pull/161)).
+ Updated dependencies to the latest versions, integrated Dependabot to keep track of them ([#105](https://github.com/ramsayleung/rspotify/pull/105), [#111](https://github.com/ramsayleung/rspotify/pull/111)).
- ([#145](https://github.com/ramsayleung/rspotify/pull/145)) Mark `SimplifiedEpisode.language` as deprecated.
- ([#145](https://github.com/ramsayleung/rspotify/pull/145)) Derive `PartialEq` and `Eq` for models:
@@ -106,15 +107,15 @@ If we missed any change or there's something you'd like to discuss about this ve
+ The `ClientError::CLI` variant, for whenever user interaction goes wrong
- Fix typo in `user_playlist_remove_specific_occurrenes_of_tracks`, now it's `user_playlist_remove_specific_occurrences_of_tracks`.
- ([#123](https://github.com/ramsayleung/rspotify/pull/123))All fallible calls in the client return a `ClientError` rather than using `failure`.
- ([#128](https://github.com/ramsayleung/rspotify/pull/128)) Endpoints take `Vec<String>/&[String]` as parameter have changed to `impl IntoIterator<Item = &str>`, which is backward compatibility.
+ The endpoints which changes parameter from `Vec<String>` to `impl IntoIterator<Item = &str>`:
- ([#161](https://github.com/ramsayleung/rspotify/pull/161)) Endpoints taking `Vec<String>/&[String]` as parameter have changed to `impl IntoIterator<Item = &Id<Type>>`.
+ The endpoints which changes parameter from `Vec<String>` to `impl IntoIterator<Item = &Id<Type>>`:
- `artists`
- `albums`
- `save_shows`
- `get_several_episodes`
- `check_users_saved_shows`
- `remove_users_saved_shows`
+ The endpoints which changes parameter from `&[String]` to `impl IntoIterator<Item = &str>`:
+ The endpoints which changes parameter from `&[String]` to `impl IntoIterator<Item = &Id<Type>>`:
- `user_playlist_add_tracks`
- `user_playlist_replace_tracks`
- `user_playlist_remove_all_occurrences_of_tracks`
@@ -130,6 +131,13 @@ If we missed any change or there's something you'd like to discuss about this ve
- `user_follow_users`
- `user_unfollow_users`
- `audios_features`
+ The endpoints which changes parameter from `String` to `&Id<Type>`:
- `get_a_show`
- `get_an_episode`
- `get_shows_episodes`
+ The endpoint which changes parameter from `Vec<Map<String, Value>>` to `Vec<TrackPositions>`:
- `playlist_remove_specific_occurrences_of_tracks`
- The `Offset` type is now an enum to match API logic, `Offset::Position` is `u32` now (it's not a position in time, it's a position in a playlist, and you can't have both `position` and `uri` fields at the same time).
kstep marked this conversation as resolved.
Show resolved Hide resolved
- ([#128](https://github.com/ramsayleung/rspotify/pull/128)) Rename endpoints with more fitting name:
+ `audio_analysis` -> `track_analysis`
+ `audio_features` -> `track_features`
@@ -158,6 +166,7 @@ If we missed any change or there's something you'd like to discuss about this ve
+ Change `{FullArtist, FullPlaylist, PublicUser, PrivateUser}::followers` from `HashMap<String, Option<Value>>` to struct `Followers`
+ Replace `Actions::disallows` with a `Vec<DisallowKey>` by removing all entires whose value is false, which will result in a simpler API
+ Replace `{FullAlbum, SimplifiedEpisode, FullEpisode}::release_date_precision` from `String` to `DatePrecision` enum, makes it easier to use.
+ Id and URI parameters are type-safe now everywhere, `Id<Type>` and `IdBuf<Type>` types for ids/URIs added (non-owning and owning structs).
- ([#157](https://github.com/ramsayleung/rspotify/pull/157))Keep polishing models to make it easier to use:
+ Constrain visibility of `FullArtists` struct with `pub (in crate)`, make `artists` and `artist_related_artists` endpoints return a `Vec<FullArtist>` instead.
+ Constrain visibility of `FullTracks` struct with `pub (in crate)`, make `tracks` and `artist_top_tracks` endpoints return a `Vec<FullTrack>` instead.
3 changes: 2 additions & 1 deletion examples/album.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
use rspotify::client::SpotifyBuilder;
use rspotify::model::Id;
use rspotify::oauth2::CredentialsBuilder;

#[tokio::main]
@@ -34,7 +35,7 @@ async fn main() {
spotify.request_client_token().await.unwrap();

// Running the requests
let birdy_uri = "spotify:album:0sNOF9WDwhWunNAHPD3Baj";
let birdy_uri = Id::from_uri("spotify:album:0sNOF9WDwhWunNAHPD3Baj").unwrap();
let albums = spotify.album(birdy_uri).await;

println!("Response: {:#?}", albums);
3 changes: 2 additions & 1 deletion examples/track.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
use rspotify::client::SpotifyBuilder;
use rspotify::model::Id;
use rspotify::oauth2::CredentialsBuilder;

#[tokio::main]
@@ -34,7 +35,7 @@ async fn main() {
spotify.request_client_token().await.unwrap();

// Running the requests
let birdy_uri = "spotify:track:6rqhFgbbKwnb9MLmUQDhG6";
let birdy_uri = Id::from_uri("spotify:track:6rqhFgbbKwnb9MLmUQDhG6").unwrap();
let track = spotify.track(birdy_uri).await;

println!("Response: {:#?}", track);
5 changes: 3 additions & 2 deletions examples/tracks.rs
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
use rspotify::client::SpotifyBuilder;
use rspotify::model::Id;
use rspotify::oauth2::CredentialsBuilder;

#[tokio::main]
@@ -33,8 +34,8 @@ async fn main() {
// so `...` is used instead of `prompt_for_user_token`.
spotify.request_client_token().await.unwrap();

let birdy_uri1 = "spotify:track:3n3Ppam7vgaVa1iaRUc9Lp";
let birdy_uri2 = "spotify:track:3twNvmDtFQtAd5gMKedhLD";
let birdy_uri1 = Id::from_uri("spotify:track:3n3Ppam7vgaVa1iaRUc9Lp").unwrap();
let birdy_uri2 = Id::from_uri("spotify:track:3twNvmDtFQtAd5gMKedhLD").unwrap();
let track_uris = vec![birdy_uri1, birdy_uri2];
let tracks = spotify.tracks(track_uris, None).await;
println!("Response: {:?}", tracks);
7 changes: 4 additions & 3 deletions examples/with_refresh_token.rs
Original file line number Diff line number Diff line change
@@ -16,15 +16,16 @@
//! so in the case of Spotify it doesn't seem to revoke them at all.

use rspotify::client::{Spotify, SpotifyBuilder};
use rspotify::model::Id;
use rspotify::oauth2::{CredentialsBuilder, OAuthBuilder};

// Sample request that will follow some artists, print the user's
// followed artists, and then unfollow the artists.
async fn do_things(spotify: Spotify) {
let artists = vec![
"3RGLhK1IP9jnYFH4BRFJBS", // The Clash
"0yNLKJebCb8Aueb54LYya3", // New Order
"2jzc5TC5TVFLXQlBNiIUzE", // a-ha
Id::from_id("3RGLhK1IP9jnYFH4BRFJBS").unwrap(), // The Clash
Id::from_id("0yNLKJebCb8Aueb54LYya3").unwrap(), // New Order
Id::from_id("2jzc5TC5TVFLXQlBNiIUzE").unwrap(), // a-ha
];
spotify
.user_follow_artists(artists.clone())
Loading