-
-
Notifications
You must be signed in to change notification settings - Fork 600
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
Make ‘required words’ that start with a '+' an absolute requirement #8791
base: develop
Are you sure you want to change the base?
Conversation
WalkthroughThe changes involve updates to the user interface and functionality of the SickChill application. Modifications were made to Mako template files to enhance the readability of HTML elements and labels, including clarifications regarding words prefixed with a plus sign. Additionally, a new function was introduced in the Python code to validate the presence of required words in show names, improving the filtering process for releases. Import statements were also reorganized for better structure. Changes
Sequence Diagram(s)sequenceDiagram
participant User
participant UI
participant Validator
participant Filter
User->>UI: Enter search terms
UI->>Validator: Validate terms
Validator->>Filter: Check required words
Filter-->>Validator: Validation result
Validator-->>UI: Display results
Possibly related PRs
📜 Recent review detailsConfiguration used: .coderabbit.yaml 📒 Files selected for processing (1)
🚧 Files skipped from review as they are similar to previous changes (1)
Thank you for using CodeRabbit. We offer it for free to the OSS community and would appreciate your support in helping us grow. If you find it useful, would you consider giving us a shout-out on your favorite social media? 🪧 TipsChatThere are 3 ways to chat with CodeRabbit:
Note: Be mindful of the bot's finite context window. It's strongly recommended to break down tasks such as reading entire modules into smaller chunks. For a focused discussion, use review comments to chat about specific files and their changes, instead of using the PR comments. CodeRabbit Commands (Invoked using PR comments)
Other keywords and placeholders
Documentation and Community
|
@coderabbitai review |
Actions performedReview triggered.
|
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.
Actionable comments posted: 0
Review details
Configuration used: CodeRabbit UI
Review profile: CHILL
Files selected for processing (3)
- sickchill/gui/slick/views/config_search.mako (1 hunks)
- sickchill/gui/slick/views/editShow.mako (1 hunks)
- sickchill/oldbeard/show_name_helpers.py (3 hunks)
Additional comments not posted (5)
sickchill/oldbeard/show_name_helpers.py (3)
38-57
: LGTM!The new
contains_all_words
function is well-implemented and serves the purpose of checking for the presence of all specified words in a name. The regular expression ensures that partial matches do not falsely satisfy the condition. The function handles both string and list input formats, providing flexibility to the caller.
85-86
: LGTM!The new
remove_plus_sign
helper function is a simple utility that cleans up the list of words by removing leading '+' characters. It is used in multiple places to ensure consistency in how required words are processed.
92-94
: LGTM!The changes in the
filter_bad_releases
function enhance the filtering process by adding a stricter requirement for certain words, improving the overall functionality of the release filtering mechanism. The use of theremove_plus_sign
function ensures consistency in how required words are processed. The logging statements provide useful information when a release is ignored due to missing required words.Also applies to: 105-116
sickchill/gui/slick/views/editShow.mako (1)
373-373
: LGTM!The new label clearly communicates the requirement for search terms starting with a plus sign to always be present. This improves the user experience by providing explicit guidance on the search functionality.
sickchill/gui/slick/views/config_search.mako (1)
226-226
: LGTM!The updated label text clarifies that words starting with a plus sign must always be present in the search results. This improves the user experience by explicitly communicating the expected behavior.
Please also consider in the future giving your edits a relevant |
This pull request is stale because it has been open 30 days with no activity. Remove stale label or comment or this will be closed in 5 days. |
Push... |
This issue has now been unmarked as "stale" |
Sorry I have been away, I'll try to get this tested manually soon. |
This pull request is stale because it has been open 30 days with no activity. Remove stale label or comment or this will be closed in 5 days. |
Push... |
Upvote for this feature. For a long time I have wondered why SC is downloading episodes that don't have (all) my required words. |
It is documented that if you want all of them you're supposed to use regex. I'm going to accept this though, it shouldn't break anything. |
This has merge conflicts, as soon as those are fixed I'll merge it. |
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.
Actionable comments posted: 1
🧹 Outside diff range and nitpick comments (4)
sickchill/oldbeard/show_name_helpers.py (2)
38-57
: LGTM! Consider enhancing the docstring.The implementation is correct and efficient. The function properly handles word boundary matching and provides useful feedback for logging.
Consider adding parameter types and return value details to the docstring:
def contains_all_words(name, words): """ Filters out results based on filter_words name: name to check words : string of words separated by a ',' or list of words - Returns: True if all words from the list are present in name, or the first word from the list not found in name. + Args: + name (str): name to check + words (str|list): string of words separated by a ',' or list of words + + Returns: + Union[bool, str]: True if all words are present, or the first missing word if any are absent """
85-86
: LGTM! Consider standardizing error messages.The implementation correctly handles the new '+' prefix functionality and properly validates absolute requirements.
Consider standardizing the error messages for consistency:
- logger.info(f"Release: {name} doesn't contain required word {word}, ignoring it") + logger.info(f"Release: {name} doesn't contain any of {word}, ignoring it")Also applies to: 105-116
sickchill/gui/slick/views/config_search.mako (2)
85-86
: Consider extracting HTML from translation stringsHTML markup is embedded within translation strings, which can make translations more difficult and error-prone. Consider using Mako's HTML escaping features instead.
Example refactor:
-${_('''the URL of your flaresolverr server. Example: http://localhost:8191/v1'<br> -<b>note:</b> this is experimental and not fully implemented.''')}</label> +${_('the URL of your flaresolverr server. Example: http://localhost:8191/v1')} <br> +<b>${_('note')}:</b> ${_('this is experimental and not fully implemented.')}</label>
Line range hint
1-1289
: Consider breaking down the template into smaller componentsThis template file is quite large and handles multiple distinct configuration sections. Consider breaking it down into smaller, more focused components using Mako's <%include> directive for better maintainability.
Suggested structure:
- Create separate template files for NZB, Torrent, and Episode search configurations
- Use <%include> to compose the main template
- Share common form components through a separate template file
📜 Review details
Configuration used: .coderabbit.yaml
Review profile: CHILL
📒 Files selected for processing (3)
sickchill/gui/slick/views/config_search.mako
(50 hunks)sickchill/gui/slick/views/editShow.mako
(4 hunks)sickchill/oldbeard/show_name_helpers.py
(3 hunks)
🔇 Additional comments (3)
sickchill/gui/slick/views/editShow.mako (2)
372-374
: LGTM! Clear explanation of the new feature.
The updated help text clearly explains the new '+' prefix functionality and its implications.
438-439
: LGTM! Updated community link.
The Discord link update provides users with the correct channel for reporting scene exception issues.
sickchill/gui/slick/views/config_search.mako (1)
227-229
: Implementation aligns with PR objectives
The updated help text clearly explains the new feature where words starting with a plus sign must all be present in search results. This matches the PR's goal of making '+' prefixed words absolute requirements.
I don't have time to check these string changes on my laptop, but be careful with removing |
All lines changed with the PS. Now the errors are from the new xo 0.60.0 update fixed in another pull request. |
This pull request is stale because it has been open 30 days with no activity. Remove stale label or comment or this will be closed in 5 days. |
bump to prevent close |
This issue has now been unmarked as "stale" |
Proposed changes in this pull request:
This PR is based on my rejected PR #8786. However, this PR does not change the current behaviour of 'required words', but introduces the new possibility to add required words with a leading plus sign (+). Words with a leading plus sign are an absolute requirement and search results that do not contain all required words with a leading plus sign will be ignored. The log contains a message indicating the first required word which was missing if the result was ignored.
If no required word has a leading plus sign, the ‘required words’ function behaves as usual (at least one of the words must be present), and therefore this change is not disruptive. Rather, it extends the ‘required words’ functionality and makes it possible to define words that must always and cumulatively be present.
Summary by CodeRabbit
New Features
Bug Fixes
Style