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

Parse the AniDB ID from the path if possible #63

Open
wants to merge 5 commits into
base: master
Choose a base branch
from

Conversation

Dillonb
Copy link

@Dillonb Dillonb commented Dec 17, 2023

Match the behavior of https://github.com/ZeroQI/Absolute-Series-Scanner - a Plex plugin.

I include anidb ids in the names of my anime directories to avoid incorrect matches. This PR will parse those out and use them, if it finds exactly one in the path. I've tested it and it works for my library.

Without this change, as an example, the plugin matched every season of a show in my library as season 1.

I'm open to and would appreciate feedback.

@nalsai
Copy link
Contributor

nalsai commented Dec 18, 2023

I am in favor of this change.

However, with Jellyfin you are supposed to use [anidbid-12345], which gets picked up by the standard info.ProviderIds.GetOrDefault, but of course that isn't compatible with ASS.


Also, I don't understand what you mean by

Without this change, as an example, the plugin matched every season of a show in my library as season 1.

This plugin first selects all similar enough titles and then matches the one that is the most similar to the title in Jellyfin (-> your folder name).
It will then be internally treated as season 1 or, if you enabled "Ignore Season" in the plugin settings, whatever season you have set it to. But that shouldn't matter much as long as you don't try to use multiple conflicting metadata plugins and you didn't change anything about it.

Copy link
Contributor

@nalsai nalsai left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

in the regex \d+ should be [0-9]+ and I believe you don't need the brackets

@Dillonb
Copy link
Author

Dillonb commented Dec 18, 2023

However, with Jellyfin you are supposed to use [anidbid-12345]

I didn't know that. I'm pretty new to Jellyfin and am running it in parallel to Plex for now while I iron out the kinks. This would be a perfect solution but unfortunately I do need it to be compatible with ASS... I don't think I have a unique use case here.

I can make my behavior a fallback if info.ProviderIds.GetOrDefault doesn't find an id instead of the other way around. What do you think?

This plugin first selects all similar enough titles and then matches the one that is the most similar to the title in Jellyfin (-> your folder name).
It will then be internally treated as season 1

Ah, yeah I do know about the internal representation as season 1 - I just meant it was failing to match a lot of my series, and when it did match it usually matched against the first season (even if the directory was named "Show X Second Season" exactly as it is on AniDB) - it had particular trouble with shows with a lot of very similarly-named seasons like Attack on Titan and Initial D. 😄

in the regex \d+ should be [0-9]+ and I believe you don't need the brackets

Good call, I'll switch to [0-9]+. As for the brackets, are you saying change the regex to something like @"anidb-([0-9]+)"? I think I need those outer brackets to be compatible with ASS and with how Jellyfin does it as in [anidbid-12345]

@nalsai
Copy link
Contributor

nalsai commented Dec 18, 2023

I think it's fine the way you did it but making your behavior a fallback after info.ProviderIds.GetOrDefault might be better, because that way it can keep the id after it was set and doesn't need to run the regex each time.

I meant \[anidb-[0-9]+\]

@Dillonb
Copy link
Author

Dillonb commented Dec 18, 2023

I meant \[anidb-[0-9]+\]

Ah. In that case, I definitely need the parentheses to make a capturing group so I can pull out just the integer ID.

I'll make it a fallback and make sure it still works, then update the PR. Thanks for the review and discussion.

@nalsai
Copy link
Contributor

nalsai commented Dec 18, 2023

Ah, yes of course 🤦‍♂️

@sjorge

This comment was marked as off-topic.

@nalsai
Copy link
Contributor

nalsai commented Dec 18, 2023

Technically from jellyfin's POV anidb only contains seasons as it's trying to strictly follow the TVDB naming. (Which for anime I personally do not agree with, as I like pure anidb naming more)

Where did you get that from?


The only thing we can do is keep it as is, or handle both cases (Series & Season) as best as possible.

@Dillonb
Copy link
Author

Dillonb commented Dec 19, 2023

  • The new behavior is now a fallback if we cannot already determine the anidb id another way
  • Use pattern matching syntax to pull out the capturing group

@oddstr13 oddstr13 requested a review from crobibero May 21, 2024 00:02
@Dillonb Dillonb force-pushed the anidb-id-from-path branch from 03be47e to b9335f4 Compare June 9, 2024 21:17
@Dillonb Dillonb requested a review from oddstr13 June 13, 2024 20:43
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

5 participants