X-Git-Url: https://wannabe.guru.org/gitweb/?a=blobdiff_plain;f=smart_future.py;h=604c149520464bcd9d8c5a55cf8905acd5ec34d4;hb=a2854e489282ad19ab1a96105dd31dc57041fc68;hp=2f3cbd9a9949f681e8a7cc70bd35ca43626e2861;hpb=865825894beeedd47d26dd092d40bfee582f5475;p=python_utils.git diff --git a/smart_future.py b/smart_future.py index 2f3cbd9..604c149 100644 --- a/smart_future.py +++ b/smart_future.py @@ -28,9 +28,11 @@ def wait_any( real_futures = [] smart_future_by_real_future = {} completed_futures = set() - for _ in futures: - real_futures.append(_.wrapped_future) - smart_future_by_real_future[_.wrapped_future] = _ + for f in futures: + assert type(f) == SmartFuture + real_futures.append(f.wrapped_future) + smart_future_by_real_future[f.wrapped_future] = f + while len(completed_futures) != len(real_futures): newly_completed_futures = concurrent.futures.as_completed(real_futures) for f in newly_completed_futures: @@ -56,7 +58,11 @@ def wait_all( *, log_exceptions: bool = True, ) -> None: - real_futures = [x.wrapped_future for x in futures] + real_futures = [] + for f in futures: + assert type(f) == SmartFuture + real_futures.append(f.wrapped_future) + (done, not_done) = concurrent.futures.wait( real_futures, timeout=None, return_when=concurrent.futures.ALL_COMPLETED ) @@ -83,6 +89,7 @@ class SmartFuture(DeferredOperand): """ def __init__(self, wrapped_future: fut.Future) -> None: + assert type(wrapped_future) == fut.Future self.wrapped_future = wrapped_future self.id = id_generator.get("smart_future_id")