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

fix/exception-in-console #215

Merged
merged 2 commits into from
Dec 1, 2024
Merged

Conversation

sankarngrjn
Copy link
Contributor

@sankarngrjn sankarngrjn commented Nov 24, 2024

Previously, when passing rich_console in context_settings, all outputs except exceptions were rendered under the provided console. This caused inconsistencies in the output format, as exceptions would bypass the rich console, leading to a mismatch in styling or behavior.

This change ensures that exceptions are also captured and displayed within the provided rich_console. By addressing this, all outputs, including exceptions, will now conform to the same console formatting, maintaining consistency across the board.

Ref. Past
1
2

Ref. Present
3

@sankarngrjn sankarngrjn force-pushed the fix/exception-in-console branch from dae982c to af7b401 Compare November 24, 2024 18:32
Copy link
Collaborator

@dwreeves dwreeves left a comment

Choose a reason for hiding this comment

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

Hello, thank you for your PR. Your description of the issue makes sense, although I have one note on the test changes.

tests/test_config.py Outdated Show resolved Hide resolved
@sankarngrjn sankarngrjn force-pushed the fix/exception-in-console branch from af7b401 to 0fa7a62 Compare November 25, 2024 17:44
@dwreeves
Copy link
Collaborator

dwreeves commented Nov 25, 2024

Thanks for the change! It seems correct to me looking at the code, but I'll need to manually test before merging. A simple reproducible example will help with that, otherwise I'll make my own example and review the change on my own time (hopefully end of this week?).

Don't worry about adding a unit test if you don't want to because we need to eventually revamp the entire testing approach, so until then we are OK with no coverage. Just an example works.

@sankarngrjn sankarngrjn requested a review from dwreeves November 25, 2024 17:49
@sankarngrjn sankarngrjn force-pushed the fix/exception-in-console branch from 0fa7a62 to c7e8b8e Compare November 29, 2024 17:16
@sankarngrjn sankarngrjn force-pushed the fix/exception-in-console branch from c7e8b8e to 6618bfb Compare November 29, 2024 17:44
@sankarngrjn
Copy link
Contributor Author

sankarngrjn commented Nov 29, 2024

Hi, sorry for the delayed response—got caught up with some personal work!

I've also noticed a few other drawbacks and have pushed an update. I believe that whenever we're using rich_console in context settings, everything should consistently fall under the rich_console. It didn’t seem logical to only use the console in these scenarios when a rich context is present, so I’ve made this adjustment accordingly.

Here’s an example to demonstrate the change:

import rich_click as click

from catppuccin.extras.rich_ctp import mocha
from rich.console import Console
from rich.theme import Theme

mocha = mocha.styles
mocha["none"] = f" on {mocha['base']}"

console = Console(theme=Theme(mocha), width=80)

context_settings = dict(
    rich_console=console
)

# context_settings = None

@click.command(cls=click.RichCommand, context_settings=context_settings)
def greet():
    """Print a friendly greeting."""
    click.echo("Hello! Welcome to the RichClick example!")

if __name__ == "__main__":
    greet()

When the line context_settings = None is uncommented, the help error will behave as usual.

Regarding the test case, I’ll address that in a future update when we revamp the testing approach, as you mentioned. For now, I hope the example provided helps with the review.

Let me know your thoughts!

Copy link
Collaborator

@dwreeves dwreeves left a comment

Choose a reason for hiding this comment

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

LGTM

@dwreeves
Copy link
Collaborator

dwreeves commented Dec 1, 2024

Very cool. Ran it and it works great! Thank you for your work on this @sankarngrjn, I will get it out shortly.

@dwreeves dwreeves merged commit 964019e into ewels:main Dec 1, 2024
34 checks passed
@sankarngrjn sankarngrjn deleted the fix/exception-in-console branch December 3, 2024 06:47
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.

2 participants