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

[REQUEST] progress.Progress working with async code #3501

Closed
jamesbraza opened this issue Sep 25, 2024 · 2 comments
Closed

[REQUEST] progress.Progress working with async code #3501

jamesbraza opened this issue Sep 25, 2024 · 2 comments

Comments

@jamesbraza
Copy link

How would you improve Rich?

As of rich==13.8.1, it looks like Progress centers on a threading.RLock for thread safety. This is good for multithreading users.

Much of the Python community these days uses async (using asyncio or trio) code. threading.Lock/RLock are suboptimal for async code because they block all concurrent code in an event loop.

It would be nice to:

  • Support an async-equivalent of Progress
  • Document the thread-safety (and potential async safety) of Progress in the docs here

What problem does it solve for you?

Efficient asyncio code that uses rich for a progress bar

@willmcgugan
Copy link
Collaborator

AFAIK there are no issues with using progress in an async app.

The locks are there to synchronize with a thread that performs updates, and other threads launched by the dev. If they block, it is for microseconds, during which the cpu is 100% utilized and the async loop wouldn't be able to switch anyway.

In other words, the way Rich uses threading locks its no less optimal that any code between await keywords in an async app.

@Textualize Textualize deleted a comment from github-actions bot Sep 26, 2024
Copy link

I hope we solved your problem.

If you like using Rich, you might also enjoy Textual

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

No branches or pull requests

2 participants