-
Notifications
You must be signed in to change notification settings - Fork 1.8k
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
Lastgenre: Fix track-level handling, multi-genre keep, force behaviour, logging #4982
base: master
Are you sure you want to change the base?
Conversation
I'd request a review from you @sampsyo since I think you initially created it. Also @rain0r would be good since 5 years ago they added the In short: I think I fixed the plugin to now really reflect what's documented. Any nitpicking in my code or functionality-wise is appreciated. One question already. Here we do not state that a When I started out with using this plugin I was confused a verry long time about this option. As far as I understand it now: It doesn't do anything since it is default. So why keep it? Or is having a I think the both of you decided these options should look like that around here: #3220 (comment) |
Thanks for the extra context, @JOJ0! About the existence of |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thanks for the ping!! Here are a couple of straightforward comments.
1e81209
to
89ae925
Compare
89ae925
to
31ce30d
Compare
I'd like to pull out this conversation #4982 (comment) into a new thread, to make it more obvious for others as well. I think it could be a broader discussion of where this plugin should go. Basically we were talking about the current So from my point of view, the main problem with the current behaviour when The following idea would require a new config setting as well as a whole new branch of behaviour (Case 3): Case 1
Case 2
keep any string in present genre tag, only write last.fm genres when empty Case 3
keep present genres when whitelisted and add new last.fm genres (this is a new branch of behaviour and needs to be coded, I think there is open feature requests for it. Update: Something was feature-requested, but it might not be exactly as I'm proposing here: #4750) Case 4
cleanup only - keep present genres when whitelisted but don't add new last.fm genres; Only when genre is empty, add last.fm genres. That last combination is weird though....but it's what I proposed for Which of these would now make sense to be the new default? The new @sampsyo brainstorming request 🧐 |
Some more context / cross-linking: The initial reason why I got my hands dirty with this plugin was when I realised that comma separated multi-genres where not recognized: #4751 (comment) Here @arsaboo requests a feature that goes in direction of Case 3 above: #4750 |
So, we have two config options - Case 1: overwrite all, only fresh last.fm genres remain force: yes
keep_allowed: no Case 2: Since force: no
keep_allowed: no Case 3: keep present genres when whitelisted and add new last.fm genres force: yes
keep_allowed: yes Case 4: keep any string in the present genre tag; only write last.fm genres when empty. This will not touch pre-existing genre tags. force: no
keep_allowed: yes Thus, Case 4 seems like the best default choice. It does not affect existing genre tags and updates the empty ones. Case 3, on the other hand, is the most useful one (at least for me). |
This brainstorming honestly sounds great, y'all. It is indeed really weird that the |
Ähem I might be slow or too tired already. Which of those 4 cases are now different from my proposal @arsaboo ? Sorry I must have missed it! Help! :-) |
Not different....just a little more explicit about the |
fb9f58d
to
c12b26b
Compare
Thank you for the PR! The changelog has not been updated, so here is a friendly reminder to check if you need to add an entry. |
Hi @arsaboo! I finally managed to find time to almost finish this PR. The general behaviour and docs of the new config options combinations are finished. If you want to, an "early" review would be super helpful. Since it probably also for you is a long time ago it might be interesting what you think if you read through the docs. Is it 100% clear what force/keep_allowed options do? Certainly but only if you have the time, some playing around and checking if it also really works that way would be great. Thanks a ton! |
@JOJ0 this is AWESOME 🎉🎉 The docs look reasonably clear. I will play with this. The debug logs are great to see what is going on. |
When `lastgenre.source: track` is configured, - `lastgenre -a` _should not_ fall back to the album level genre (by making use of the with_album=False kwarg of the Libary's get method). - `lastgenre -a`, when finally storing the genres of _an album_, should _not_ also write the tracks genres (by making use of the inherit=False kwarg of the Album's store method.
It was rather confusing that the lastgenre plugin, when handling singletons, sometimes showed that it applied genres from last.fm and sometimes didn't (it did only in debug log). This streamlines the behaviour: - Change debug to info log. - Streamline wording. - Display details about the track.
When handling existing comma-separated genres in the _get_genre method of the plugin, make sure duplicate genres are removed.
is configured.
- Printing out album/item in default format could lead to unreadable clutter depending on the user's configured formats. - The album's name and the individual tracks' title should be just sufficient to provide context as well readability. - Log like this while importing as well as in standalone runs.
in lastgenre plugin.
generation, instead of a simple set(). This way we keep the original order of genres.
- Default to False. - During PR#4982 discussions we came to the conclusion that the following behaviour would be a good new default choice: - Keep whitelisted existing genres - Only Fetch last.fm genres for empty tags. - To get this we also have to change the default of the force option!!! - Resulting in "force: no" and "keep_allowed: yes"; see Case 4 in PR#4982 description - Options are not put to use yet, just defined and defaults set!
Keep both options' "Configuration" chapter texts as compact as possible, while linking to a new chapter that describes all 4 possible combinations in detail.
- Retrieving, filtering and deduplicating present genres of Items/Albums via separate methods. - Implement all four cases of behaviour as described in PR#4982 - Issues: - There is quite some unnecessary spliting of genres from strings into lists and the other way round happening throughout the plugin. - In the case where existing genres get "augmented" with last.fm genres, we might end up with _more_ genres than the configured limit.
- Handle genre combination logic in a well documented helper function that also include type hints. - Throughout the _get_genre function rename the result variable to new_genres to make it clearly descriptive. - Rewrite thze _get_genre function's docstring.
Description
Edit 2023-09: The original idea of this PR was:
Several fixes I had in the queue for months. Some of it required fixes in the library code which are through by now.
force
option: Don't always overwrite comma-separated multi-genres, compile a list and keep what's in the whitelist.lastgenre -A
in combination with config optionsource: track
- Tracks receive the album's genre even when this option is setEdit 2023-09: Additional option
keep_allowed
During review and discussions it turned out that besides the existing
force
option a second option would be required to really achieve a typical (expected) behaviour of aforce
option. This is what we came up with (copied over and slightly edited from #4982 (comment)):Two config options,
force
andkeep_allowed
, i.e. 4 possible settings:Case 1
Overwrite all. Only fresh last.fm genres remain.
Case 2
Add new last.fm genres when empty. Present tags stay untouched.
Case 3
Add new last.fm genres. Keep whitelisted genres in present tags.
Case 4 (default)
Add new last.fm genres when empty. Keep whitelisted genres in present tags.
To Do