example-code-2e/19-concurrency/primes/spinner_prime_proc.py

44 lines
1.2 KiB
Python
Raw Normal View History

2021-01-30 01:05:03 +01:00
# spinner_prime_proc.py
# credits: Adapted from Michele Simionato's
# multiprocessing example in the python-list:
# https://mail.python.org/pipermail/python-list/2009-February/675659.html
2021-02-13 19:35:34 +01:00
import itertools
2021-01-30 01:05:03 +01:00
from multiprocessing import Process, Event
from multiprocessing import synchronize
from primes import is_prime
def spin(msg: str, done: synchronize.Event) -> None: # <1>
for char in itertools.cycle(r'\|/-'): # <2>
status = f'\r{char} {msg}' # <3>
print(status, end='', flush=True)
if done.wait(.1): # <4>
break # <5>
blanks = ' ' * len(status)
print(f'\r{blanks}\r', end='') # <6>
def check(n: int) -> int:
return is_prime(n)
def supervisor(n: int) -> int: # <1>
done = Event() # <2>
spinner = Process(target=spin,
args=('thinking!', done)) # <3>
2021-02-13 19:35:34 +01:00
print(f'spinner object: {spinner}') # <4>
2021-01-30 01:05:03 +01:00
spinner.start() # <5>
result = check(n) # <6>
done.set() # <7>
spinner.join() # <8>
return result
def main() -> None:
n = 5_000_111_000_222_021
result = supervisor(n) # <9>
msg = 'is' if result else 'is not'
print(f'{n:,} {msg} prime')
if __name__ == '__main__':
main()