A RetroSearch Logo

Home - News ( United States | United Kingdom | Italy | Germany ) - Football scores

Search Query:

Showing content from https://mail.python.org/pipermail/python-dev/2003-July/036672.html below:

[Python-Dev] release candidate rules and timeit API question

[Python-Dev] release candidate rules and timeit API question [Python-Dev] release candidate rules and timeit API questionGuido van Rossum guido@python.org
Tue, 01 Jul 2003 07:12:11 -0400
>     Tim> It's not so fine that this delicate code is duplicated, so I'd
>     Tim> rather see an internal refactoring to use a common backoff-polling
>     Tim> class.
> 
> I recently copied it to my own code as well.  I'd like to see it whacked
> into something reusable.  This seems to work:
> 
>     import time
>     class Timeout(Exception): pass
> 
>     def await_condition(predicate, timeout):
>         delay = 0.0005
>         endtime = time.time() + timeout
>         while True:
>             if predicate():
>                 return
>             remaining = endtime - time.time()
>             if remaining <= 0:          # time's up, predicate always failed
>                 raise Timeout
>             delay = min(delay * 2, remaining, .05)
>             time.sleep(delay)           # reduce CPU usage by using a sleep
> 
> Skip

I wonder if the right refactoring wouldn't be to add an acquire with
timeout method to the built-in lock type?

--Guido van Rossum (home page: http://www.python.org/~guido/)



RetroSearch is an open source project built by @garambo | Open a GitHub Issue

Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo

HTML: 3.2 | Encoding: UTF-8 | Version: 0.7.4