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

Upgrade from guessit 3.1.1 to 3.3.1 breaks custom rebulk rules #692

Closed
h3llrais3r opened this issue Mar 26, 2021 · 4 comments · Fixed by #694
Closed

Upgrade from guessit 3.1.1 to 3.3.1 breaks custom rebulk rules #692

h3llrais3r opened this issue Mar 26, 2021 · 4 comments · Fixed by #694

Comments

@h3llrais3r
Copy link

h3llrais3r commented Mar 26, 2021

Guessit with custom rebulk rules are broken.
I'm using guessit as mentioned below:

from guessit.api import default_api

from autosubliminal.parsers.guessit.rules import rules

# Add our custom rules to the default guessit api
default_api.configure({})
default_api.rebulk.rebulk(rules())

Afterwards I'm using the adapted default_api:

custom_options = dict(options) if options else dict()
custom_options.update(dict(expected_title=expected_titles, expected_group=expected_release_groups))
result = default_api.guessit(string, options=custom_options)

The default_api.guessit calls internally again the configure()

Within the configure() it compares if the advanced_config has changed and forces a rebuild of rebulk when different.

Commit 51e0021#diff-66e80a71bd17399af0e8d250f0b561e30ca0090d84cd4b306ea13bfdfc90f842 has introduced a breaking change when guessit is extended with custom rebulk rules.
Within this change, the pattern and regex are popped from the config options (really removed from the advanced_config) which breaks the comparison in the configure() in the GuessitApi class in api.py.

should_build_rebulk = force or not self.rebulk or not self.advanced_config or \
                              self.advanced_config != advanced_config

Because the advanced_config is no longer identical, rebulk is rebuild and my custom rebulk rules are lost...
On 3.1.1 this was not the case...

Fix seems fairly easy and is tested by me:

  • Replace pattern.pop('pattern') by pattern.get('pattern')
  • Replace kwargs.pop('regex', False) by kwargs.get('regex', False)

This doesn't physically removes the items from the dict and ensures that the config is not changed, so the rebulk rules are not lost.

Can you please verify if my findings are correct and fix it in case you agree?
Thanks!

h3llrais3r added a commit to h3llrais3r/Auto-Subliminal that referenced this issue Mar 26, 2021
Temporarily fix guessit until guessit-io/guessit#692 is fixed.
@Toilal
Copy link
Member

Toilal commented Mar 29, 2021

Your issue is with no doubt caused by those mutations. I'll try to find another solution though, as I don't want pattern and regex keywords to be passed to underlying function.

@h3llrais3r
Copy link
Author

Let me know when you have a solution. I'm happy to test it. 😉

h3llrais3r added a commit to h3llrais3r/Auto-Subliminal that referenced this issue Apr 4, 2021
Temporarily fix guessit until guessit-io/guessit#692 is fixed.
@Toilal
Copy link
Member

Toilal commented Apr 4, 2021

Could you give a try with develop branch ?

@h3llrais3r
Copy link
Author

@Toilal
I've just tried the develop branch on my local machine and I confirm that the issue is fixed.
No rebuild is done now and my custom rules are still taken into account.
👍

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging a pull request may close this issue.

2 participants